

*Public Version*

# **AM/DM37x Multimedia Device Silicon Revision 1.x**

**Version O**

## **Technical Reference Manual**



Literature Number: SPRUGN4O  
May 2010–Revised January 2012

## **WARNING: EXPORT NOTICE**

**Recipient agrees to not knowingly export or re-export, directly or indirectly, any product or technical data (as defined by the U.S., EU, and other Export Administration Regulations) including software, or any controlled product restricted by other applicable national regulations, received from Disclosing party under this Agreement, or any direct product of such technology, to any destination to which such export or re-export is restricted or prohibited by U.S. or other applicable laws, without obtaining prior authorisation from U.S. Department of Commerce and other competent Government authorities to the extent required by those laws. This provision shall survive termination or expiration of this Agreement.**

**According to our best knowledge of the state and end-use of this product or technology, and in compliance with the export control regulations of dual-use goods in force in the origin and exporting countries, this technology is classified as follows:**

**US ECCN: 3E991**

**EU ECCN: EAR99**

**And may require export or re-export license for shipping it in compliance with the applicable regulations of certain countries.**



## Contents

|                                                                                 |            |
|---------------------------------------------------------------------------------|------------|
| <b>Preface .....</b>                                                            | <b>171</b> |
| <b>1    Introduction .....</b>                                                  | <b>183</b> |
| 1.1    Overview .....                                                           | 184        |
| 1.2    Environment .....                                                        | 186        |
| 1.3    Description .....                                                        | 187        |
| 1.3.1    MPU Subsystem .....                                                    | 188        |
| 1.3.2    IVA2.2 Subsystem .....                                                 | 188        |
| 1.3.3    On-Chip Memory .....                                                   | 189        |
| 1.3.4    External Memory Interfaces .....                                       | 189        |
| 1.3.5    DMA Controllers .....                                                  | 190        |
| 1.3.6    Multimedia Accelerators .....                                          | 190        |
| 1.3.7    Comprehensive Power Management .....                                   | 191        |
| 1.3.8    Peripherals .....                                                      | 191        |
| 1.4    Package-On-Package Concept .....                                         | 192        |
| 1.5    AM/DM37x Family .....                                                    | 195        |
| 1.5.1    Device Features .....                                                  | 195        |
| 1.5.2    Device Identification .....                                            | 197        |
| 1.5.3    General Recommendations Relative to Unavailable Features/Modules ..... | 199        |
| <b>2    Memory Mapping .....</b>                                                | <b>201</b> |
| 2.1    Introduction .....                                                       | 202        |
| 2.2    Global Memory Space Mapping .....                                        | 204        |
| 2.3    L3 and L4 Memory Space Mapping .....                                     | 207        |
| 2.3.1    L3 Memory Space Mapping .....                                          | 207        |
| 2.3.2    L4 Memory Space Mapping .....                                          | 208        |
| 2.3.2.1    L4-Core Memory Space Mapping .....                                   | 208        |
| 2.3.2.2    L4-Wakeup Memory Space Mapping .....                                 | 211        |
| 2.3.2.3    L4-Peripheral Memory Space Mapping .....                             | 212        |
| 2.3.2.4    L4-Emulation Memory Space Mapping .....                              | 213        |
| 2.3.3    Register Access Restrictions .....                                     | 214        |
| 2.4    IVA2.2 Subsystem Memory Space Mapping .....                              | 216        |
| 2.4.1    IVA2.2 Subsystem Internal Memory and Cache Allocation .....            | 216        |
| 2.4.1.1    IVA2.2 Subsystem Memory Hierarchy .....                              | 216        |
| 2.4.1.2    IVA2.2 Cache Allocation .....                                        | 217        |
| 2.4.2    DSP Access to L2 Memories .....                                        | 218        |
| 2.4.2.1    DSP Access to L2 ROM .....                                           | 218        |
| 2.4.2.2    DSP Access to L2 RAM .....                                           | 218        |
| 2.4.3    DSP and EDMA Access to Memories and Peripherals .....                  | 218        |
| 2.4.4    L3 Interconnect View of the IVA2.2 Subsystem Memory Space .....        | 219        |
| 2.4.5    DSP View of the IVA2.2 Subsystem Memory Space .....                    | 220        |
| 2.4.6    EDMA View of the IVA2.2 Subsystem Memory Space .....                   | 221        |
| <b>3    Power, Reset, and Clock Management .....</b>                            | <b>223</b> |
| 3.1    Introduction to Power Managements .....                                  | 224        |
| 3.1.1    Goal of Power Management .....                                         | 224        |

|            |                                                              |     |
|------------|--------------------------------------------------------------|-----|
| 3.1.2      | Power-Management Techniques .....                            | 224 |
| 3.1.2.1    | Dynamic Voltage and Frequency Scaling .....                  | 224 |
| 3.1.2.2    | SmartReflex Adaptive Voltage Scaling (AVS) .....             | 225 |
| 3.1.2.3    | Dynamic Power Switching .....                                | 226 |
| 3.1.2.4    | Standby Leakage Management .....                             | 226 |
| 3.1.2.5    | DPS Versus SLM .....                                         | 227 |
| 3.1.2.6    | Adaptive Body Bias (ABB) .....                               | 227 |
| 3.1.2.7    | Combining Power-Management Techniques .....                  | 227 |
| 3.1.3      | Architectural Blocks for Power Management .....              | 228 |
| 3.1.3.1    | Clock Domain .....                                           | 228 |
| 3.1.3.2    | Power Domain .....                                           | 229 |
| 3.1.3.3    | Voltage Domain .....                                         | 230 |
| 3.1.4      | Device Power-Management Architecture .....                   | 231 |
| 3.1.4.1    | Module Interface and Functional Clocks .....                 | 232 |
| 3.1.4.2    | Autoidle Clock Control .....                                 | 233 |
| 3.1.5      | SmartReflex Voltage-Control Overview .....                   | 234 |
| 3.1.5.1    | Manual SmartReflex Voltage Control .....                     | 235 |
| 3.1.5.2    | Automatic SmartReflex Voltage Control .....                  | 236 |
| 3.2        | PRCM Overview .....                                          | 237 |
| 3.2.1      | Introduction .....                                           | 237 |
| 3.2.2      | PRCM Features .....                                          | 239 |
| 3.3        | PRCM Environment .....                                       | 240 |
| 3.3.1      | External Clock Signals .....                                 | 241 |
| 3.3.2      | External Reset Signals .....                                 | 242 |
| 3.3.3      | External Power Signals .....                                 | 243 |
| 3.4        | PRCM Integration .....                                       | 244 |
| 3.4.1      | Power-Management Scheme, Reset, and Interrupt Requests ..... | 247 |
| 3.4.1.1    | Power Domain .....                                           | 247 |
| 3.4.1.2    | Resets .....                                                 | 247 |
| 3.4.1.3    | Interrupt Requests .....                                     | 248 |
| 3.5        | PRCM Functional Description .....                            | 249 |
| 3.5.1      | PRCM Reset Manager Functional Description .....              | 249 |
| 3.5.1.1    | Overview .....                                               | 249 |
| 3.5.1.2    | General Characteristics of Reset Signals .....               | 249 |
| 3.5.1.2.1  | Scope .....                                                  | 250 |
| 3.5.1.2.2  | Occurrence .....                                             | 250 |
| 3.5.1.2.3  | Source Type .....                                            | 250 |
| 3.5.1.3    | Reset Sources .....                                          | 251 |
| 3.5.1.3.1  | Global Reset Sources .....                                   | 251 |
| 3.5.1.3.2  | Local Reset Sources .....                                    | 252 |
| 3.5.1.4    | Reset Distribution .....                                     | 253 |
| 3.5.1.5    | Power Domain Reset Descriptions .....                        | 254 |
| 3.5.1.5.1  | MPU Power Domain .....                                       | 254 |
| 3.5.1.5.2  | NEON Power Domain .....                                      | 255 |
| 3.5.1.5.3  | IVA2 Power Domain .....                                      | 255 |
| 3.5.1.5.4  | CORE Power Domain .....                                      | 255 |
| 3.5.1.5.5  | DSS Power Domain .....                                       | 255 |
| 3.5.1.5.6  | CAM Power Domain .....                                       | 256 |
| 3.5.1.5.7  | USBHOST Power Domain .....                                   | 256 |
| 3.5.1.5.8  | SGX Power Domain .....                                       | 256 |
| 3.5.1.5.9  | WKUP Power Domain .....                                      | 256 |
| 3.5.1.5.10 | PER Power Domain .....                                       | 256 |
| 3.5.1.5.11 | SmartReflex Power Domain .....                               | 257 |

---

|            |                                                     |     |
|------------|-----------------------------------------------------|-----|
| 3.5.1.5.12 | DPLL Power Domains .....                            | 257 |
| 3.5.1.5.13 | EFUSE Power Domain .....                            | 257 |
| 3.5.1.5.14 | BANDGAP Logic .....                                 | 257 |
| 3.5.1.5.15 | External Warm Reset Assertion .....                 | 258 |
| 3.5.1.6    | Reset Logging .....                                 | 258 |
| 3.5.1.6.1  | PRCM Reset Logging Mechanism .....                  | 258 |
| 3.5.1.6.2  | SCM Reset Logging .....                             | 258 |
| 3.5.1.7    | Reset Management Overview .....                     | 259 |
| 3.5.1.8    | Reset Summary .....                                 | 264 |
| 3.5.1.9    | Reset Sequences .....                               | 267 |
| 3.5.1.9.1  | Power-Up Sequence .....                             | 267 |
| 3.5.1.9.2  | Global Warm Reset Sequence .....                    | 269 |
| 3.5.1.9.3  | IVA2.2 Subsystem Power-Up Sequence .....            | 271 |
| 3.5.1.9.4  | IVA2 Software Reset Sequence .....                  | 273 |
| 3.5.1.9.5  | IVA2 Global Warm Reset Sequence .....               | 275 |
| 3.5.1.9.6  | IVA2 Power Domain Wake-Up Cold Reset Sequence ..... | 277 |
| 3.5.2      | PRCM Power Manager Functional Description .....     | 280 |
| 3.5.2.1    | Overview .....                                      | 280 |
| 3.5.2.1.1  | Introduction .....                                  | 280 |
| 3.5.2.1.2  | Device Partitioning .....                           | 281 |
| 3.5.2.1.3  | Memory and Logic Power Management .....             | 283 |
| 3.5.2.1.4  | Retention Till Access (RTA) Memory Feature .....    | 283 |
| 3.5.2.1.5  | Power Domain States .....                           | 284 |
| 3.5.2.1.6  | Power State Transitions .....                       | 284 |
| 3.5.2.1.7  | Device Power Modes .....                            | 285 |
| 3.5.2.1.8  | Isolation Between Power Domains .....               | 285 |
| 3.5.2.2    | Power Domain Implementation .....                   | 285 |
| 3.5.2.2.1  | Device Power Domains .....                          | 285 |
| 3.5.2.2.2  | Power Domain Memory Status .....                    | 287 |
| 3.5.2.2.3  | Power Domain State Transition Rules .....           | 287 |
| 3.5.2.2.4  | Power Domain Dependencies .....                     | 287 |
| 3.5.2.2.5  | Power Domain Controls .....                         | 288 |
| 3.5.3      | PRCM Clock Manager Functional Description .....     | 290 |
| 3.5.3.1    | Overview .....                                      | 290 |
| 3.5.3.1.1  | Interface and Functional Clocks .....               | 291 |
| 3.5.3.2    | External Clock I/Os .....                           | 292 |
| 3.5.3.2.1  | External Clock Inputs .....                         | 292 |
| 3.5.3.2.2  | External Clock Outputs .....                        | 293 |
| 3.5.3.2.3  | Summary .....                                       | 293 |
| 3.5.3.3    | Internal Clock Generation .....                     | 293 |
| 3.5.3.3.1  | PRM .....                                           | 295 |
| 3.5.3.3.2  | CM .....                                            | 297 |
| 3.5.3.3.3  | DPLLs .....                                         | 299 |
| 3.5.3.3.4  | DPLL Clock Summary .....                            | 307 |
| 3.5.3.3.5  | Summary .....                                       | 307 |
| 3.5.3.4    | Clock Distribution .....                            | 308 |
| 3.5.3.4.1  | Power Domain Clock Distribution .....               | 308 |
| 3.5.3.4.2  | Clock Distribution Summary .....                    | 322 |
| 3.5.3.5    | External Clock Controls .....                       | 324 |
| 3.5.3.5.1  | Clock Request (sys_clkreq) Control .....            | 324 |
| 3.5.3.5.2  | System Clock Oscillator Control .....               | 325 |
| 3.5.3.5.3  | External Output Clock1 (sys_clkout1) Control .....  | 328 |
| 3.5.3.5.4  | External Output Clock2 (sys_clkout2) Control .....  | 328 |

|            |                                                                               |     |
|------------|-------------------------------------------------------------------------------|-----|
| 3.5.3.6    | DPLL Control .....                                                            | 328 |
| 3.5.3.6.1  | DPLL Multiplier and Divider Factors .....                                     | 328 |
| 3.5.3.6.2  | DPLL Modes .....                                                              | 328 |
| 3.5.3.6.3  | DPLL Low-Power Mode .....                                                     | 330 |
| 3.5.3.6.4  | DPLL Clock Path Power Down .....                                              | 331 |
| 3.5.3.6.5  | Recalibration .....                                                           | 331 |
| 3.5.3.6.6  | DPLL Programming Sequence .....                                               | 332 |
| 3.5.3.7    | Internal Clock Controls .....                                                 | 333 |
| 3.5.3.7.1  | PRM Source-Clock Controls .....                                               | 333 |
| 3.5.3.7.2  | CM Source-Clock Controls .....                                                | 335 |
| 3.5.3.7.3  | Common Interface Clock Controls .....                                         | 337 |
| 3.5.3.7.4  | DPLL Source-Clock Controls .....                                              | 338 |
| 3.5.3.7.5  | SGX Power Domain Clock Controls .....                                         | 339 |
| 3.5.3.7.6  | CORE Power Domain Clock Controls .....                                        | 340 |
| 3.5.3.7.7  | EFUSE Power Domain Clock Controls .....                                       | 342 |
| 3.5.3.7.8  | DSS Power Domain Clock Controls .....                                         | 342 |
| 3.5.3.7.9  | CAM Power Domain Clock Controls .....                                         | 343 |
| 3.5.3.7.10 | USBHOST Power Domain Clock Controls .....                                     | 344 |
| 3.5.3.7.11 | WKUP Power Domain Clock Controls .....                                        | 345 |
| 3.5.3.7.12 | PER Power Domain Clock Controls .....                                         | 346 |
| 3.5.3.7.13 | SMARTREFLEX Power Domain Clock Controls .....                                 | 348 |
| 3.5.3.8    | Clock Configurations .....                                                    | 349 |
| 3.5.3.8.1  | Processor Clock Configurations .....                                          | 349 |
| 3.5.3.8.2  | Interface and Peripheral Functional Clock Configurations .....                | 350 |
| 3.5.4      | PRCM Idle and Wake-Up Management .....                                        | 353 |
| 3.5.4.1    | Overview .....                                                                | 353 |
| 3.5.4.2    | Sleep Transition .....                                                        | 355 |
| 3.5.4.3    | Wakeup .....                                                                  | 355 |
| 3.5.4.4    | Device Wake-Up Events .....                                                   | 356 |
| 3.5.4.5    | Sleep and Wake-Up Dependencies .....                                          | 361 |
| 3.5.4.5.1  | Sleep Dependencies .....                                                      | 361 |
| 3.5.4.5.2  | Wake-Up Dependencies .....                                                    | 363 |
| 3.5.4.6    | USBHOST/USBTLL Save-and-Restore Management .....                              | 366 |
| 3.5.4.6.1  | USBHOST SAR Sequences .....                                                   | 368 |
| 3.5.4.6.2  | USB TLL SAR Sequences .....                                                   | 368 |
| 3.5.5      | PRCM Interrupts .....                                                         | 369 |
| 3.5.6      | PRCM Voltage Management Functional Description .....                          | 371 |
| 3.5.6.1    | Overview .....                                                                | 371 |
| 3.5.6.2    | Voltage Domains .....                                                         | 375 |
| 3.5.6.3    | Voltage Domain Dependencies .....                                             | 376 |
| 3.5.6.4    | Voltage-Control Architecture .....                                            | 377 |
| 3.5.6.5    | VDD1 and VDD2 Control .....                                                   | 379 |
| 3.5.6.5.1  | Direct Control With VMODE Signals .....                                       | 379 |
| 3.5.6.5.2  | Direct Voltage Control With I <sup>2</sup> C Interface .....                  | 380 |
| 3.5.6.5.3  | Voltage Controller and Dedicated SmartReflex I <sup>2</sup> C Interface ..... | 380 |
| 3.5.6.5.4  | SmartReflex Voltage Control .....                                             | 380 |
| 3.5.6.6    | Analog Cells, LDOs, and Level Shifter Controls .....                          | 389 |
| 3.5.6.6.1  | ABB LDOs Control .....                                                        | 389 |
| 3.5.6.6.2  | SRAM Voltage Control .....                                                    | 390 |
| 3.5.6.6.3  | Wake-Up and Emulation Voltage Control .....                                   | 390 |
| 3.5.7      | PRCM Off-Mode Management .....                                                | 391 |
| 3.5.7.1    | Overview .....                                                                | 391 |
| 3.5.7.2    | Device Off-Mode Configuration .....                                           | 391 |

---

|            |                                                                               |     |
|------------|-------------------------------------------------------------------------------|-----|
| 3.5.7.2.1  | Overview .....                                                                | 391 |
| 3.5.7.2.2  | I/O Wake-Up Mechanism .....                                                   | 392 |
| 3.5.7.3    | CORE Power Domain Off-Mode Sequences .....                                    | 393 |
| 3.5.7.3.1  | Sleep Sequences (Transition From On to Retention/Off) .....                   | 393 |
| 3.5.7.3.2  | Wake-Up Sequences (Transition From Retention/Off to On) .....                 | 394 |
| 3.5.7.4    | Device Off-Mode Sequences .....                                               | 394 |
| 3.5.7.4.1  | Sleep Sequences .....                                                         | 395 |
| 3.5.7.4.2  | Wake-Up Sequences .....                                                       | 396 |
| 3.6        | PRCM Basic Programming Model .....                                            | 397 |
| 3.6.1      | Global Registers .....                                                        | 397 |
| 3.6.1.1    | Revision Information Registers .....                                          | 397 |
| 3.6.1.2    | PRCM Configuration Registers .....                                            | 397 |
| 3.6.1.3    | Interrupt Configuration Registers .....                                       | 398 |
| 3.6.1.3.1  | MPU Interrupt Event Sources .....                                             | 398 |
| 3.6.1.3.2  | MPU Interrupt Registers .....                                                 | 399 |
| 3.6.1.3.3  | IVA2.2 Interrupt Event Sources .....                                          | 399 |
| 3.6.1.3.4  | IVA2 Interrupt Registers .....                                                | 399 |
| 3.6.1.4    | Event Generator Control Registers .....                                       | 400 |
| 3.6.1.5    | Output Signal Polarity Control Registers .....                                | 400 |
| 3.6.1.5.1  | CM_POLCTRL (CM Polarity Control Register) .....                               | 400 |
| 3.6.1.5.2  | PRM_POLCTRL (PRM Polarity Control Register) .....                             | 401 |
| 3.6.1.6    | SRAM Precharge Time Control Register .....                                    | 402 |
| 3.6.1.6.1  | PRM_SRAM_PCHARGE (Voltage SRAM Precharge Counter Register) .....              | 402 |
| 3.6.2      | Clock Management Registers .....                                              | 402 |
| 3.6.2.1    | System Clock Control Registers .....                                          | 402 |
| 3.6.2.1.1  | PRM_CLKSRC_CTRL (Clock Source Control Register) .....                         | 402 |
| 3.6.2.1.2  | PRM_CLKSETUP (Source-Clock Setup Register) .....                              | 402 |
| 3.6.2.1.3  | PRM_CLKSEL (Source-Clock Selection Register) .....                            | 402 |
| 3.6.2.2    | External Clock Output Control Registers .....                                 | 402 |
| 3.6.2.2.1  | PRM_CLKOUT_CTRL (Clock Out Control Register) .....                            | 402 |
| 3.6.2.2.2  | CM_CLKOUT_CTRL (Clock Out Control Register) .....                             | 403 |
| 3.6.2.3    | DPLL Clock Control Registers .....                                            | 403 |
| 3.6.2.3.1  | CM_CLKSELn_PLL_processor_name (Processor DPLL Clock Selection Register) ..... | 403 |
| 3.6.2.3.2  | CM_CLKSELn_PLL (DPLL Clock Selection Register) .....                          | 403 |
| 3.6.2.3.3  | CM_CLKEN_PLL_processor_name (Processor DPLL Clock Enable Register) .....      | 404 |
| 3.6.2.3.4  | CM_CLKEN_PLL (DPLL Enable Register) .....                                     | 404 |
| 3.6.2.3.5  | CM_AUTOIDLE_PLL_processor_name (Processor DPLL Autoidle Register) .....       | 405 |
| 3.6.2.3.6  | CM_AUTOIDLE_PLL (DPLL Autoidle Register) .....                                | 405 |
| 3.6.2.3.7  | CM_AUTOIDLE1_PLL (DPLL5 Autoidle Register) .....                              | 405 |
| 3.6.2.3.8  | CM_IDLEST_CKGEN (Source-Clock Idle-Status Register) .....                     | 405 |
| 3.6.2.3.9  | CM_IDLEST2_CKGEN (DPLL5 Source-Clock Idle-Status Register) .....              | 405 |
| 3.6.2.3.10 | CM_IDLEST_PLL_processor_name (Processor DPLL Idle-Status Register) .....      | 406 |
| 3.6.2.4    | Power-Domain Clock Control Registers .....                                    | 406 |
| 3.6.2.4.1  | CM_CLKSEL_domain_name (Clock Select Register) .....                           | 406 |
| 3.6.2.4.2  | CM_FCLKEN_domain_name (Functional Clock Enable Register) .....                | 407 |
| 3.6.2.4.3  | CM_ICLKEN_domain_name (Interface Clock Enable Register) .....                 | 407 |
| 3.6.2.4.4  | CM_AUTOIDLE_domain_name (Autoidle Register) .....                             | 408 |
| 3.6.2.4.5  | CM_IDLEST_domain_name (Idle-Status Register) .....                            | 408 |
| 3.6.2.4.6  | CM_CLKSTCTRL_domain_name (Clock State Control Register) .....                 | 409 |
| 3.6.2.4.7  | CM_CLKSTST_domain_name (Clock State Status Register) .....                    | 410 |
| 3.6.2.4.8  | CM_SLEEPDEP_domain_name (Sleep Dependency Control Register) .....             | 410 |
| 3.6.2.5    | Domain Wake-Up Control Registers .....                                        | 411 |
| 3.6.2.5.1  | PM_WKEN_domain_name (Wake-Up Enable Register) .....                           | 412 |

|           |                                                                                                             |     |
|-----------|-------------------------------------------------------------------------------------------------------------|-----|
| 3.6.2.5.2 | PM_WKST_domain_name (Wake-Up Status Register) .....                                                         | 412 |
| 3.6.2.5.3 | PM_WKDEP_domain_name (Wake-Up Dependency Register) .....                                                    | 412 |
| 3.6.2.5.4 | PM_processor_name GRPSEL_domain_name (Processor Group Selection Register) ..                                | 414 |
| 3.6.3     | Reset Management Registers .....                                                                            | 414 |
| 3.6.3.1   | Reset Control .....                                                                                         | 414 |
| 3.6.3.1.1 | PRM_RSTTIME (Reset Time Register) .....                                                                     | 414 |
| 3.6.3.1.2 | RM_RSTCTRL_domain_name (Reset Control Register) .....                                                       | 414 |
| 3.6.3.1.3 | RM_RSTST_domain_name (Reset Status Register) .....                                                          | 415 |
| 3.6.4     | Power Management Registers .....                                                                            | 416 |
| 3.6.4.1   | PM_PWSTCTRL_domain_name (Power State Control Register) .....                                                | 416 |
| 3.6.4.2   | PM_PWSTST_domain_name (Power State Status Register) .....                                                   | 418 |
| 3.6.4.3   | PM_PREPWSTST_domain_name (Previous Power State Status Register) .....                                       | 419 |
| 3.6.5     | Voltage Management Registers .....                                                                          | 419 |
| 3.6.5.1   | External Voltage Control Register Descriptions .....                                                        | 419 |
| 3.6.5.1.1 | PRM_VOLTSETUP (Voltage Setup Time Register) .....                                                           | 419 |
| 3.6.5.1.2 | PRM_VOLTOFFSET (Voltage Offset Register) .....                                                              | 420 |
| 3.6.5.1.3 | PRM_VOLTCTRL (Voltage Source Control Register) .....                                                        | 421 |
| 3.6.5.2   | Voltage Controller Registers .....                                                                          | 421 |
| 3.6.5.2.1 | PRM_VC_SMPS_SA (Voltage Controller SMPS Slave Address Register) .....                                       | 422 |
| 3.6.5.2.2 | PRM_VC_SMPS_VOL_RA (Voltage Controller SMPS Voltage Register Address Register) .....                        | 422 |
| 3.6.5.2.3 | PRM_VC_SMPS_CMD_RA (Voltage Controller SMPS Command Register Address Register) .....                        | 422 |
| 3.6.5.2.4 | PRM_VC_CMD_VAL_0 and PRM_VC_CMD_VAL_1 (Voltage Controller Command and Voltage Value Register 0 and 1) ..... | 422 |
| 3.6.5.2.5 | PRM_VC_CH_CONF (Voltage Controller Channel Configuration Register) .....                                    | 422 |
| 3.6.5.2.6 | PRM_VC_I2C_CFG (Voltage Controller I <sup>2</sup> C Interface Configuration Register) .....                 | 422 |
| 3.6.5.2.7 | PRM_VC_BYPASS_VAL (Voltage Controller Bypass Command Register) .....                                        | 423 |
| 3.6.5.3   | Voltage Processor Registers .....                                                                           | 423 |
| 3.6.5.3.1 | PRM_VP_CONFIG (Voltage Processor Configuration Register) .....                                              | 423 |
| 3.6.5.3.2 | PRM_VP_VSTEPMIN (Voltage Processor Minimum Voltage Step) .....                                              | 423 |
| 3.6.5.3.3 | PRM_VP_VSTEPMAX (Voltage Processor Maximum Voltage Step) .....                                              | 423 |
| 3.6.5.3.4 | PRM_VP_VLIMITTO (Voltage Processor Voltage Limit and Time-Out) .....                                        | 424 |
| 3.6.5.3.5 | PRM_VP_VOLTAGE (Voltage Processor Voltage Register) .....                                                   | 424 |
| 3.6.5.3.6 | PRM_VP_STATUS (Voltage Processor Status Register) .....                                                     | 424 |
| 3.6.6     | Generic Programming Examples .....                                                                          | 424 |
| 3.6.6.1   | Clock Control .....                                                                                         | 424 |
| 3.6.6.1.1 | Enabling and Disabling the Functional Clocks .....                                                          | 424 |
| 3.6.6.1.2 | Enabling and Disabling the Interface Clocks .....                                                           | 426 |
| 3.6.6.1.3 | Enabling and Disabling the Inactive State .....                                                             | 427 |
| 3.6.6.1.4 | Processor Clock Control .....                                                                               | 428 |
| 3.6.6.2   | Reset Management .....                                                                                      | 431 |
| 3.6.6.3   | Wake-Up Control .....                                                                                       | 431 |
| 3.6.6.4   | SmartReflex Module Initialization Basic Programming Model .....                                             | 432 |
| 3.6.6.5   | Voltage Processor Initialization Basic Programming Model .....                                              | 435 |
| 3.6.6.6   | Voltage Controller Initialization Basic Programming Model .....                                             | 439 |
| 3.6.6.7   | Changing OPP Using the SmartReflex Module .....                                                             | 442 |
| 3.6.6.8   | Changing OPP Using Only the Voltage Processor Module .....                                                  | 444 |
| 3.6.6.9   | Event Generator Programming Examples .....                                                                  | 446 |
| 3.7       | PRCM Register Manual .....                                                                                  | 447 |
| 3.7.1     | CM Module Registers .....                                                                                   | 447 |
| 3.7.1.1   | CM Instance Summary .....                                                                                   | 447 |
| 3.7.1.2   | IVA2_CM Registers .....                                                                                     | 447 |
| 3.7.1.2.1 | IVA2_CM Register Summary .....                                                                              | 447 |

---

|            |                                             |     |
|------------|---------------------------------------------|-----|
| 3.7.1.2.2  | IVA2_CM Registers .....                     | 448 |
| 3.7.1.3    | OCP_System_Reg_CM Registers .....           | 454 |
| 3.7.1.3.1  | OCP_System_Reg_CM Register Summary .....    | 454 |
| 3.7.1.3.2  | OCP_System_Reg_CM Registers .....           | 454 |
| 3.7.1.4    | MPU_CM Registers .....                      | 455 |
| 3.7.1.4.1  | MPU_CM Register Summary .....               | 455 |
| 3.7.1.4.2  | MPU_CM Registers .....                      | 455 |
| 3.7.1.5    | CORE_CM Registers .....                     | 461 |
| 3.7.1.5.1  | CORE_CM Register Summary .....              | 461 |
| 3.7.1.5.2  | CORE_CM Registers .....                     | 462 |
| 3.7.1.6    | SGX_CM Registers .....                      | 475 |
| 3.7.1.6.1  | SGX_CM Register Summary .....               | 475 |
| 3.7.1.6.2  | SGX_CM Registers .....                      | 476 |
| 3.7.1.7    | WKUP_CM Registers .....                     | 480 |
| 3.7.1.7.1  | WKUP_CM Register Summary .....              | 480 |
| 3.7.1.7.2  | WKUP_CM Registers .....                     | 480 |
| 3.7.1.8    | Clock_Control_Reg_CM Registers .....        | 485 |
| 3.7.1.8.1  | Clock_Control_Reg_CM Register Summary ..... | 485 |
| 3.7.1.8.2  | Clock_Control_Reg_CM Registers .....        | 486 |
| 3.7.1.9    | DSS_CM Registers .....                      | 498 |
| 3.7.1.9.1  | DSS_CM Register Summary .....               | 498 |
| 3.7.1.9.2  | DSS_CM Registers .....                      | 498 |
| 3.7.1.10   | CAM_CM Registers .....                      | 505 |
| 3.7.1.10.1 | CAM_CM Register Summary .....               | 505 |
| 3.7.1.10.2 | CAM_CM Registers .....                      | 506 |
| 3.7.1.11   | PER_CM Registers .....                      | 511 |
| 3.7.1.11.1 | PER_CM Register Summary .....               | 511 |
| 3.7.1.11.2 | PER_CM Registers .....                      | 512 |
| 3.7.1.12   | EMU_CM Registers .....                      | 522 |
| 3.7.1.12.1 | EMU_CM Register Summary .....               | 522 |
| 3.7.1.12.2 | EMU_CM Registers .....                      | 523 |
| 3.7.1.13   | Global_Reg_CM Registers .....               | 528 |
| 3.7.1.13.1 | Global_Reg_CM Register Summary .....        | 528 |
| 3.7.1.13.2 | Global_Reg_CM Registers .....               | 528 |
| 3.7.1.14   | NEON_CM Registers .....                     | 529 |
| 3.7.1.14.1 | NEON_CM Register Summary .....              | 529 |
| 3.7.1.14.2 | NEON_CM Registers .....                     | 529 |
| 3.7.1.15   | USBHOST_CM Registers .....                  | 531 |
| 3.7.1.15.1 | USBHOST_CM Register Summary .....           | 531 |
| 3.7.1.15.2 | USBHOST_CM Registers .....                  | 531 |
| 3.7.2      | PRM Module Registers .....                  | 536 |
| 3.7.2.1    | PRM Instance Summary .....                  | 536 |
| 3.7.2.2    | IVA2_PRM Registers .....                    | 536 |
| 3.7.2.2.1  | IVA2_PRM Register Summary .....             | 536 |
| 3.7.2.2.2  | IVA2_PRM Registers .....                    | 537 |
| 3.7.2.3    | OCP_System_Reg_PRM Registers .....          | 547 |
| 3.7.2.3.1  | OCP_System_Reg_PRM Register Summary .....   | 547 |
| 3.7.2.3.2  | OCP_System_Reg_PRM Registers .....          | 547 |
| 3.7.2.4    | MPU_PRM Registers Registers .....           | 556 |
| 3.7.2.4.1  | MPU_PRM Registers Register Summary .....    | 556 |
| 3.7.2.4.2  | MPU_PRM Registers .....                     | 556 |
| 3.7.2.5    | CORE_PRM Registers .....                    | 563 |
| 3.7.2.5.1  | CORE_PRM Register Summary .....             | 563 |

|            |                                                                    |            |
|------------|--------------------------------------------------------------------|------------|
| 3.7.2.5.2  | CORE_PRM Registers .....                                           | 563        |
| 3.7.2.6    | SGX_PRM Registers .....                                            | 579        |
| 3.7.2.6.1  | SGX_PRM Register Summary .....                                     | 579        |
| 3.7.2.6.2  | SGX_PRM Registers .....                                            | 580        |
| 3.7.2.7    | WKUP_PRM Registers .....                                           | 584        |
| 3.7.2.7.1  | WKUP_PRM Register Summary .....                                    | 584        |
| 3.7.2.7.2  | WKUP_PRM Registers .....                                           | 584        |
| 3.7.2.8    | Clock_Control_Reg_PRM Registers .....                              | 589        |
| 3.7.2.8.1  | Clock_Control_Reg_PRM Register Summary .....                       | 589        |
| 3.7.2.8.2  | Clock_Control_Reg_PRM Registers .....                              | 589        |
| 3.7.2.9    | DSS_PRM Registers .....                                            | 590        |
| 3.7.2.9.1  | DSS_PRM Register Summary .....                                     | 590        |
| 3.7.2.9.2  | DSS_PRM Registers .....                                            | 591        |
| 3.7.2.10   | CAM_PRM Registers .....                                            | 595        |
| 3.7.2.10.1 | CAM_PRM Registers .....                                            | 595        |
| 3.7.2.10.2 | CAM_PRM Registers .....                                            | 595        |
| 3.7.2.11   | PER_PRM Registers .....                                            | 599        |
| 3.7.2.11.1 | PER_PRM Register Summary .....                                     | 599        |
| 3.7.2.11.2 | PER_PRM Registers .....                                            | 600        |
| 3.7.2.12   | EMU_PRM Registers .....                                            | 613        |
| 3.7.2.12.1 | EMU_PRM Register Summary .....                                     | 613        |
| 3.7.2.12.2 | EMU_PRM Registers .....                                            | 613        |
| 3.7.2.13   | Global_Reg_PRM Registers .....                                     | 615        |
| 3.7.2.13.1 | Global_Reg_PRM Register Summary .....                              | 615        |
| 3.7.2.13.2 | Global_Reg_PRM Registers .....                                     | 616        |
| 3.7.2.14   | NEON_PRM Registers .....                                           | 639        |
| 3.7.2.14.1 | NEON_PRM Register Summary .....                                    | 639        |
| 3.7.2.14.2 | NEON_PRM Registers .....                                           | 639        |
| 3.7.2.15   | USBHOST_PRM Registers .....                                        | 643        |
| 3.7.2.15.1 | USBHOST_PRM Register Summary .....                                 | 643        |
| 3.7.2.15.2 | USBHOST_PRM Registers .....                                        | 643        |
| 3.7.3      | SR Registers .....                                                 | 650        |
| 3.7.3.1    | SR Instance Summary .....                                          | 650        |
| 3.7.3.2    | SR Registers .....                                                 | 650        |
| 3.7.3.2.1  | SR Register Summary .....                                          | 650        |
| 3.7.3.2.2  | SR Registers .....                                                 | 650        |
| <b>4</b>   | <b>MPU Subsystem .....</b>                                         | <b>663</b> |
| 4.1        | MPU Subsystem Overview .....                                       | 664        |
| 4.1.1      | Introduction .....                                                 | 664        |
| 4.1.2      | Features .....                                                     | 664        |
| 4.2        | MPU Subsystem Integration .....                                    | 666        |
| 4.2.1      | MPU Subsystem Clock and Reset Distribution .....                   | 667        |
| 4.2.1.1    | Clock Distribution .....                                           | 667        |
| 4.2.1.2    | Reset Distribution .....                                           | 668        |
| 4.2.2      | ARM Subchip .....                                                  | 670        |
| 4.2.2.1    | ARM Overview .....                                                 | 670        |
| 4.2.2.2    | ARM Description .....                                              | 670        |
| 4.2.2.2.1  | ARM Cortex-A8 Instruction, Data, and Private Peripheral Port ..... | 670        |
| 4.2.2.2.2  | MPU Subsystem Features .....                                       | 670        |
| 4.2.2.3    | Clock, Reset, and Power Management .....                           | 671        |
| 4.2.2.3.1  | Clocks .....                                                       | 671        |
| 4.2.2.3.2  | Reset .....                                                        | 671        |
| 4.2.2.3.3  | Power Management .....                                             | 671        |

---

|           |                                                    |            |
|-----------|----------------------------------------------------|------------|
| 4.2.3     | Local Interconnect .....                           | 671        |
| 4.2.3.1   | Description .....                                  | 671        |
| 4.2.3.2   | Clocks, Reset, and Power Management .....          | 671        |
| 4.2.3.2.1 | Clocks .....                                       | 671        |
| 4.2.3.2.2 | Reset .....                                        | 671        |
| 4.2.3.2.3 | Power Management .....                             | 672        |
| 4.2.4     | Interrupt Controller .....                         | 672        |
| 4.2.4.1   | Clocks .....                                       | 672        |
| 4.2.4.2   | Reset .....                                        | 672        |
| 4.2.4.3   | Power Management .....                             | 672        |
| 4.3       | MPU Subsystem Functional Description .....         | 673        |
| 4.3.1     | Interrupts .....                                   | 673        |
| 4.3.2     | Power Management .....                             | 673        |
| 4.3.2.1   | Power Domains .....                                | 673        |
| 4.3.2.2   | Power States .....                                 | 674        |
| 4.3.2.3   | Power Modes .....                                  | 674        |
| 4.3.2.4   | Transitions .....                                  | 676        |
| 4.4       | MPU Subsystem Basic Programming Model .....        | 678        |
| 4.4.1     | MPU Subsystem Initialization Sequence .....        | 678        |
| 4.4.2     | Clock Control .....                                | 678        |
| 4.4.3     | MPU Power Mode Transitions .....                   | 678        |
| 4.4.3.1   | Basic Power-On Reset .....                         | 678        |
| 4.4.3.2   | MPU Into Standby Mode .....                        | 678        |
| 4.4.3.3   | MPU Out of Standby Mode .....                      | 679        |
| 4.4.3.4   | MPU Power-On From a Powered-Off State .....        | 679        |
| 4.4.4     | ARM Programming Model .....                        | 679        |
| <b>5</b>  | <b>IVA2.2 Subsystem .....</b>                      | <b>681</b> |
| 5.1       | IVA2.2 Subsystem Overview .....                    | 682        |
| 5.1.1     | IVA2.2 Subsystem Key Features .....                | 682        |
| 5.2       | IVA2.2 Subsystem Integration .....                 | 684        |
| 5.2.1     | Clocking, Reset, and Power-Management Scheme ..... | 686        |
| 5.2.1.1   | Clocks .....                                       | 686        |
| 5.2.1.1.1 | IVA2.2 Clocks .....                                | 686        |
| 5.2.1.2   | Resets .....                                       | 686        |
| 5.2.1.2.1 | Hardware Resets .....                              | 686        |
| 5.2.1.2.2 | Software Resets .....                              | 688        |
| 5.2.1.3   | Power Domain .....                                 | 688        |
| 5.2.2     | Hardware Requests .....                            | 690        |
| 5.2.2.1   | DMA Requests .....                                 | 690        |
| 5.2.2.2   | Interrupt Requests .....                           | 691        |
| 5.3       | IVA2.2 Subsystem Functional Description .....      | 695        |
| 5.3.1     | DSP Megamodule .....                               | 695        |
| 5.3.1.1   | DSP Overview .....                                 | 696        |
| 5.3.1.2   | Program Memory Controller Overview .....           | 697        |
| 5.3.1.3   | DMC Overview .....                                 | 697        |
| 5.3.1.4   | UMC Overview .....                                 | 698        |
| 5.3.1.5   | EMC Overview .....                                 | 699        |
| 5.3.1.6   | Memory Protection Overview .....                   | 699        |
| 5.3.1.7   | INTC .....                                         | 699        |
| 5.3.1.7.1 | Event Type .....                                   | 701        |
| 5.3.1.7.2 | Event Behavior .....                               | 701        |
| 5.3.1.7.3 | Event Detection .....                              | 702        |
| 5.3.1.7.4 | Event Selection .....                              | 702        |

|           |                                                      |     |
|-----------|------------------------------------------------------|-----|
| 5.3.1.7.5 | Event Combination .....                              | 703 |
| 5.3.1.7.6 | Interrupt Event Error .....                          | 703 |
| 5.3.1.7.7 | PDC Overview .....                                   | 703 |
| 5.3.1.8   | Other DSP Reference Documents .....                  | 703 |
| 5.3.2     | DMA Engines .....                                    | 705 |
| 5.3.2.1   | EDMA .....                                           | 705 |
| 5.3.2.1.1 | Third-Party Channel Controller .....                 | 706 |
| 5.3.2.1.2 | Third-Party Transfer Controller .....                | 711 |
| 5.3.2.1.3 | EDMA Hardware Parameters .....                       | 714 |
| 5.3.2.2   | EDMA Access to Video Accelerator/Sequencer .....     | 715 |
| 5.3.2.3   | IDMA .....                                           | 716 |
| 5.3.3     | MMU .....                                            | 716 |
| 5.3.3.1   | MMU VA-to-PA Translation .....                       | 717 |
| 5.3.3.2   | MMU Configuration .....                              | 718 |
| 5.3.4     | Video Accelerator/Sequencer Local Interconnect ..... | 719 |
| 5.3.5     | SL2 Interface .....                                  | 720 |
| 5.3.5.1   | BWO .....                                            | 721 |
| 5.3.5.2   | Arbiter .....                                        | 722 |
| 5.3.5.3   | Restrictions on SL2 Memory Usage .....               | 722 |
| 5.3.5.4   | Error Management .....                               | 722 |
| 5.3.6     | Wake-Up Generator .....                              | 722 |
| 5.3.6.1   | Interrupts, DMA Requests, and Event Management ..... | 723 |
| 5.3.6.1.1 | Event Generation .....                               | 723 |
| 5.3.6.1.2 | Individual Event Masking .....                       | 724 |
| 5.3.6.1.3 | Individual Event Mask Clear .....                    | 725 |
| 5.3.6.2   | Idle Handshake .....                                 | 726 |
| 5.3.7     | SYSC Module .....                                    | 726 |
| 5.3.7.1   | Divided Clock Generation .....                       | 727 |
| 5.3.7.2   | Clock Management, Power-Down, and Wake-Up .....      | 727 |
| 5.3.7.3   | Boot Configuration .....                             | 728 |
| 5.3.7.4   | Interconnect Optimization .....                      | 728 |
| 5.3.7.5   | Video Accelerator/Sequencer SYSC .....               | 728 |
| 5.3.7.5.1 | Reset .....                                          | 728 |
| 5.3.7.5.2 | Power Management .....                               | 728 |
| 5.3.7.5.3 | Interrupt Handler .....                              | 729 |
| 5.3.8     | Local Memories .....                                 | 729 |
| 5.3.8.1   | ROM Overview .....                                   | 731 |
| 5.3.8.2   | RAM Overview .....                                   | 731 |
| 5.3.9     | Local Interconnect Network .....                     | 731 |
| 5.3.9.1   | Endianness .....                                     | 732 |
| 5.3.10    | Error Reporting .....                                | 732 |
| 5.4       | IVA2.2 Subsystem Basic Programming Model .....       | 733 |
| 5.4.1     | IVA2.2 Boot .....                                    | 733 |
| 5.4.1.1   | IVA2.2 Boot Configuration .....                      | 733 |
| 5.4.1.1.1 | IDLE Boot Mode .....                                 | 734 |
| 5.4.1.1.2 | Wait in Self-Loop Mode .....                         | 734 |
| 5.4.1.1.3 | Default Config Cache Mode .....                      | 734 |
| 5.4.1.1.4 | User Defined Bootstrap Mode .....                    | 735 |
| 5.4.1.2   | Example of IVA2.2 Boot .....                         | 735 |
| 5.4.1.2.1 | Boot Under MPU Control .....                         | 735 |
| 5.4.1.2.2 | Autonomous Boot .....                                | 737 |
| 5.4.2     | Sequencer Boot/Reset .....                           | 738 |
| 5.4.3     | Cache Management .....                               | 738 |

---

|            |                                                                  |     |
|------------|------------------------------------------------------------------|-----|
| 5.4.3.1    | Cache-Size Configuration .....                                   | 738 |
| 5.4.3.2    | Cache Mode Configuration .....                                   | 740 |
| 5.4.3.3    | Cacheability Settings .....                                      | 741 |
| 5.4.3.4    | Coherence Maintenance .....                                      | 741 |
| 5.4.3.4.1  | Memory-Mapped L1P and L1D Coherence .....                        | 741 |
| 5.4.3.4.2  | Memory-Mapped L2 Coherence .....                                 | 741 |
| 5.4.3.4.3  | Device Memory Coherence .....                                    | 741 |
| 5.4.3.4.4  | Global Cache Management .....                                    | 742 |
| 5.4.3.4.5  | Block Cache Management .....                                     | 743 |
| 5.4.3.4.6  | Write-Back Completion .....                                      | 745 |
| 5.4.3.4.7  | Performance Consideration Timing .....                           | 746 |
| 5.4.4      | DMA Management .....                                             | 746 |
| 5.4.4.1    | Transfers From/to Device Memories/Peripherals (EDMA) .....       | 746 |
| 5.4.4.2    | Internal Memory-to-Memory Transfer (IDMA) .....                  | 746 |
| 5.4.4.3    | Programming an EDMA Transfer .....                               | 747 |
| 5.4.4.4    | Defining a Logical Channel .....                                 | 747 |
| 5.4.4.4.1  | Single Logical Channel Definition .....                          | 747 |
| 5.4.4.4.2  | Controlling Submission Granularity .....                         | 749 |
| 5.4.4.4.3  | Linking to Another Logical Channel .....                         | 749 |
| 5.4.4.4.4  | Chaining Logical Channel .....                                   | 749 |
| 5.4.4.5    | Prioritizing Defined Transfers .....                             | 750 |
| 5.4.4.5.1  | Mapping Between DMA/QDMA Events and Event Queues .....           | 750 |
| 5.4.4.5.2  | Mapping a Queue to a Transfer Controller .....                   | 750 |
| 5.4.4.5.3  | Handling Priority .....                                          | 750 |
| 5.4.4.5.4  | Aged Priority .....                                              | 750 |
| 5.4.4.5.5  | Optimizing 2D Transfers .....                                    | 751 |
| 5.4.4.6    | Starting the Transfer .....                                      | 751 |
| 5.4.4.6.1  | Assigning a Logical Channel to a Trigger Event .....             | 751 |
| 5.4.4.6.2  | Manual Trigger (Software-Synchronized Transfers) .....           | 751 |
| 5.4.4.6.3  | Hardware Trigger (Hardware-Synchronized Transfers) .....         | 752 |
| 5.4.4.6.4  | Automatic Trigger (QDMA) .....                                   | 752 |
| 5.4.4.6.5  | Offloaded Configuration (Using IDMA) .....                       | 752 |
| 5.4.4.6.6  | Direct Configuration to Transfer Channel (Not Recommended) ..... | 753 |
| 5.4.4.6.7  | DMA Completion Mode .....                                        | 753 |
| 5.4.4.6.8  | Partial Versus Total Completion .....                            | 754 |
| 5.4.4.6.9  | Tracking DMA Completion .....                                    | 754 |
| 5.4.4.6.10 | DMA Interrupt Service Routine .....                              | 755 |
| 5.4.4.6.11 | Benchmarking .....                                               | 755 |
| 5.4.5      | IVA2.2 Extended Function Interface .....                         | 756 |
| 5.4.5.1    | Overview .....                                                   | 756 |
| 5.4.5.2    | C64x+ EFI Instructions .....                                     | 756 |
| 5.4.5.3    | C64x+ EFI Use in IVA2.2 .....                                    | 760 |
| 5.4.5.3.1  | Read Registers Using the EFI Programming Model .....             | 760 |
| 5.4.5.3.2  | Write Registers Using the EFI Programming Model .....            | 760 |
| 5.4.6      | iME and iLF Basic Programming Model .....                        | 762 |
| 5.4.6.1    | Typical Use .....                                                | 762 |
| 5.4.7      | iVLCD Basic Programming Model .....                              | 763 |
| 5.4.7.1    | Setting Up Registers for Q/IQ Operation .....                    | 765 |
| 5.4.7.1.1  | Q/IQ Matrix Setup - Inverse Quantizer Matrix .....               | 765 |
| 5.4.7.1.2  | Q/IQ Rounding .....                                              | 765 |
| 5.4.7.1.3  | Q/IQ Offset .....                                                | 765 |
| 5.4.7.1.4  | Q/IQ Threshold .....                                             | 765 |
| 5.4.7.2    | Setting Up Registers for VLC Operation .....                     | 765 |

|            |                                                                                       |     |
|------------|---------------------------------------------------------------------------------------|-----|
| 5.4.7.3    | Setting Up Registers for VLD Operation .....                                          | 767 |
| 5.4.7.4    | Calculating the Number of Bits Processed During a VLD Run .....                       | 769 |
| 5.4.7.5    | Setting Up Registers for CAVLC Operation .....                                        | 769 |
| 5.4.8      | Interrupt Management .....                                                            | 771 |
| 5.4.8.1    | Interrupt Flow in IVA2.2 Subsystem .....                                              | 771 |
| 5.4.8.2    | Event Combined Programming Sequence .....                                             | 773 |
| 5.4.8.3    | Event <-> Interrupt Mapping Programming Sequence .....                                | 773 |
| 5.4.8.4    | Interrupt Exception Programming Sequence .....                                        | 773 |
| 5.4.8.5    | Interrupt Controller Basic Programming Model for Power Down of IVA2.2 Subsystem ..... | 774 |
| 5.4.8.6    | Interrupt Controller Basic Programming Model for Power On of IVA2.2 Subsystem .....   | 775 |
| 5.4.8.7    | Video and Sequencer Module interrupt Handling .....                                   | 777 |
| 5.4.8.7.1  | Sequencer Interrupt .....                                                             | 777 |
| 5.4.8.7.2  | DSP Megamodule Interrupt .....                                                        | 778 |
| 5.4.9      | Memory Management .....                                                               | 779 |
| 5.4.9.1    | External Memory .....                                                                 | 779 |
| 5.4.9.1.1  | Cacheability .....                                                                    | 779 |
| 5.4.9.1.2  | Virtual Addressing .....                                                              | 779 |
| 5.4.9.2    | Internal Memory .....                                                                 | 779 |
| 5.4.9.2.1  | Memory Protection .....                                                               | 779 |
| 5.4.9.2.2  | Bandwidth Management .....                                                            | 784 |
| 5.4.9.3    | SL2 Memory Management .....                                                           | 786 |
| 5.4.9.3.1  | SL2 Performance Optimizations .....                                                   | 786 |
| 5.4.9.3.2  | SL2 Performance Limitations .....                                                     | 786 |
| 5.4.9.3.3  | SL2 Illegal Accesses .....                                                            | 787 |
| 5.4.10     | IVA2.2 Power Management .....                                                         | 788 |
| 5.4.10.1   | Clock Management .....                                                                | 788 |
| 5.4.10.1.1 | Clock Configuration .....                                                             | 788 |
| 5.4.10.1.2 | Clock Gating .....                                                                    | 788 |
| 5.4.10.2   | Reset Management .....                                                                | 788 |
| 5.4.10.3   | Power-Down and Wake-Up Management .....                                               | 789 |
| 5.4.10.4   | Powering Down L2\$ Memory While IVA2 is Active .....                                  | 792 |
| 5.4.10.5   | Video and Sequencer Module Management .....                                           | 793 |
| 5.4.10.5.1 | Module Dynamic Power Savings .....                                                    | 793 |
| 5.4.10.5.2 | System Dynamic Power Savings .....                                                    | 793 |
| 5.4.11     | Error Identification Process .....                                                    | 794 |
| 5.4.11.1   | Error Reporting for IDMA Module .....                                                 | 794 |
| 5.4.11.2   | Error Reporting for EDMA Module .....                                                 | 794 |
| 5.4.11.3   | Error Reporting for the L3 Interconnect .....                                         | 795 |
| 5.4.12     | Recommendations for Static Settings .....                                             | 795 |
| 5.5        | IVA2.2 Subsystem Register Manual .....                                                | 796 |
| 5.5.1      | IC Registers .....                                                                    | 797 |
| 5.5.1.1    | IC Register Mapping Summary .....                                                     | 797 |
| 5.5.1.2    | IC Register Descriptions .....                                                        | 797 |
| 5.5.2      | SYS Registers .....                                                                   | 805 |
| 5.5.2.1    | SYS Register Mapping Summary .....                                                    | 805 |
| 5.5.2.2    | SYS Register Descriptions .....                                                       | 805 |
| 5.5.3      | IDMA Registers .....                                                                  | 808 |
| 5.5.3.1    | IDMA Register Mapping Summary .....                                                   | 808 |
| 5.5.3.2    | IDMA Register Descriptions .....                                                      | 808 |
| 5.5.4      | XMC Registers .....                                                                   | 820 |
| 5.5.4.1    | XMC Register Mapping Summary .....                                                    | 820 |
| 5.5.4.2    | XMC Register Descriptions .....                                                       | 821 |
| 5.5.5      | TPCC Registers .....                                                                  | 847 |

---

|           |                                                                                                |             |
|-----------|------------------------------------------------------------------------------------------------|-------------|
| 5.5.5.1   | TPCC Register Mapping Summary .....                                                            | 847         |
| 5.5.5.2   | TPCC Register Descriptions .....                                                               | 849         |
| 5.5.6     | TPTC0 and TPTC1 Registers .....                                                                | 947         |
| 5.5.6.1   | TPTC0 and TPTC1 Register Mapping Summary .....                                                 | 947         |
| 5.5.6.2   | TPTC0 and TPTC1 Register Descriptions .....                                                    | 949         |
| 5.5.7     | SYSC Registers .....                                                                           | 973         |
| 5.5.7.1   | SYSC Register Mapping Summary .....                                                            | 973         |
| 5.5.7.2   | SYSC Register Descriptions .....                                                               | 974         |
| 5.5.8     | WUGEN Registers .....                                                                          | 978         |
| 5.5.8.1   | WUGEN Register Mapping Summary .....                                                           | 978         |
| 5.5.8.2   | WUGEN Register Descriptions .....                                                              | 979         |
| 5.5.9     | iLCD Registers .....                                                                           | 997         |
| 5.5.9.1   | iLCD Register Mapping Summary .....                                                            | 997         |
| 5.5.9.2   | iLCD Register Descriptions .....                                                               | 999         |
| 5.5.10    | SEQ Registers .....                                                                            | 1038        |
| 5.5.10.1  | SEQ Register Mapping Summary .....                                                             | 1038        |
| 5.5.10.2  | SEQ Register Descriptions .....                                                                | 1038        |
| 5.5.11    | Video System Controller Registers .....                                                        | 1045        |
| 5.5.11.1  | Video System Controller Register Mapping Summary .....                                         | 1045        |
| 5.5.11.2  | Video System Controller Register Descriptions .....                                            | 1045        |
| 5.5.12    | iME Registers .....                                                                            | 1051        |
| 5.5.12.1  | iME Register Mapping Summary .....                                                             | 1051        |
| 5.5.12.2  | iME Register Descriptions .....                                                                | 1052        |
| 5.5.13    | iLF Registers .....                                                                            | 1062        |
| 5.5.13.1  | iLF Register Mapping Summary .....                                                             | 1062        |
| 5.5.13.2  | iLF Register Descriptions .....                                                                | 1063        |
| 5.5.14    | IA_GEM Registers .....                                                                         | 1073        |
| 5.5.14.1  | IA_GEM Register Mapping Summary .....                                                          | 1073        |
| 5.5.14.2  | IA_GEM Register Descriptions .....                                                             | 1073        |
| 5.5.15    | IA_EDMA Registers .....                                                                        | 1074        |
| 5.5.15.1  | IA_EDMA Register Mapping Summary .....                                                         | 1074        |
| 5.5.15.2  | IA_EDMA Register Descriptions .....                                                            | 1074        |
| 5.5.16    | IA_SEQ Registers .....                                                                         | 1075        |
| 5.5.16.1  | IA_SEQ Register Mapping Summary .....                                                          | 1075        |
| 5.5.16.2  | IA_SEQ Register Descriptions .....                                                             | 1076        |
| <b>6</b>  | <b>Camera Image Signal Processor .....</b>                                                     | <b>1079</b> |
| 6.1       | Camera ISP Overview .....                                                                      | 1080        |
| 6.1.1     | Camera ISP Features .....                                                                      | 1082        |
| 6.2       | Camera ISP Environment .....                                                                   | 1085        |
| 6.2.1     | Camera ISP Functions .....                                                                     | 1085        |
| 6.2.2     | Camera ISP Signal Descriptions .....                                                           | 1086        |
| 6.2.3     | Camera ISP Connectivity Schemes .....                                                          | 1087        |
| 6.2.4     | Camera ISP Protocols and Data Formats .....                                                    | 1090        |
| 6.2.4.1   | Camera ISP Parallel Generic Configuration Protocol and Data Format (8, 10, 11, 12 Bits) ..     | 1090        |
| 6.2.4.2   | Camera ISP Parallel Generic Configuration: JPEG Sensor Connection on the Parallel Interface .. | 1091        |
| 6.2.4.3   | Camera ISP ITU-R BT.656 Protocol and Data Formats (8, 10 Bits) .....                           | 1091        |
| 6.2.4.4   | Camera ISP CSI1/CCP2 Protocol and Data Formats .....                                           | 1093        |
| 6.2.4.4.1 | Camera ISP CSI1/CCP2 Pixel Data Format .....                                                   | 1096        |
| 6.2.4.5   | Camera ISP CSI2 Protocol and Data Format .....                                                 | 1106        |
| 6.2.4.5.1 | Camera ISP CSI2 Lane Merger .....                                                              | 1106        |
| 6.2.4.5.2 | Camera ISP CSI2 Protocol Layer .....                                                           | 1107        |
| 6.2.4.5.3 | Camera ISP CSI2 Pixel Data Format .....                                                        | 1114        |

|           |                                                                                 |      |
|-----------|---------------------------------------------------------------------------------|------|
| 6.3       | Camera ISP Integration .....                                                    | 1133 |
| 6.3.1     | Camera ISP Clocking, Reset, and Power-Management Scheme .....                   | 1133 |
| 6.3.1.1   | Camera ISP Clocks .....                                                         | 1133 |
| 6.3.1.1.1 | Camera ISP Clock Tree .....                                                     | 1134 |
| 6.3.1.1.2 | Camera ISP Clock Descriptions .....                                             | 1134 |
| 6.3.1.1.3 | Camera ISP Clock Configuration .....                                            | 1135 |
| 6.3.1.2   | Camera ISP Power Management .....                                               | 1136 |
| 6.3.1.2.1 | Camera ISP Local Power Management .....                                         | 1136 |
| 6.3.1.2.2 | Camera ISP System Power Management .....                                        | 1136 |
| 6.3.1.3   | Camera ISP Power Domain .....                                                   | 1137 |
| 6.3.1.4   | Camera ISP Resets .....                                                         | 1138 |
| 6.3.1.4.1 | Camera ISP Hardware Reset .....                                                 | 1138 |
| 6.3.1.4.2 | Camera ISP Software Reset .....                                                 | 1138 |
| 6.3.2     | Camera ISP Hardware Requests .....                                              | 1138 |
| 6.3.2.1   | Camera ISP Interrupt Requests .....                                             | 1138 |
| 6.4       | Camera ISP Functional Description .....                                         | 1148 |
| 6.4.1     | Camera ISP Block Diagram .....                                                  | 1148 |
| 6.4.1.1   | Camera ISP Possible Data Paths Inside the module .....                          | 1150 |
| 6.4.1.1.1 | Camera ISP RGB RAW Data .....                                                   | 1151 |
| 6.4.1.1.2 | Camera ISP YUV4:2:2 Data .....                                                  | 1152 |
| 6.4.1.1.3 | JPEG Data .....                                                                 | 1152 |
| 6.4.2     | Camera ISP CSI1/CCP2B Receiver .....                                            | 1153 |
| 6.4.2.1   | Camera ISP CSI1/CCP2B Receiver Features .....                                   | 1153 |
| 6.4.2.2   | Camera ISP CSI1/CCP2B Receiver Functional Description .....                     | 1153 |
| 6.4.2.2.1 | Camera ISP CSI1/CCP2B Overview .....                                            | 1153 |
| 6.4.2.2.2 | Camera ISP CSI1/CCP2B Associated PHY .....                                      | 1154 |
| 6.4.2.2.3 | Camera ISP CSI1/CCP2B Physical Layer .....                                      | 1154 |
| 6.4.2.2.4 | Camera ISP CSI1/CCP2B Protocol Layer .....                                      | 1155 |
| 6.4.2.2.5 | Camera ISP CSI1/CCP2B Memory Read Channel .....                                 | 1159 |
| 6.4.2.2.6 | Camera ISP CSI1/CCP2B Image Data Operating Modes and Alignment Constraints .... | 1168 |
| 6.4.3     | Camera ISP CSI2 Receiver .....                                                  | 1170 |
| 6.4.3.1   | Camera ISP CSI2 Receiver Features .....                                         | 1170 |
| 6.4.3.2   | Camera ISP CSI2 Receiver Block Diagram .....                                    | 1170 |
| 6.4.3.3   | Camera ISP CSI2 Physical Layer Lane Configuration .....                         | 1171 |
| 6.4.3.4   | Camera ISP CSI2 ECC and Checksum Generation .....                               | 1171 |
| 6.4.3.4.1 | Camera ISP CSI2 ECC .....                                                       | 1172 |
| 6.4.3.4.2 | Camera ISP CSI2 Checksum .....                                                  | 1172 |
| 6.4.3.5   | Camera ISP CSI2 RAW Image Transcoding with DPCM and A-law Compression .....     | 1172 |
| 6.4.3.6   | Camera ISP CSI2 Short Packet .....                                              | 1176 |
| 6.4.3.7   | Camera ISP CSI2 Virtual Channel and Context .....                               | 1176 |
| 6.4.3.8   | Camera ISP CSI2 DMA Engine .....                                                | 1177 |
| 6.4.3.8.1 | Camera ISP CSI2 Progressive Frame to Progressive Storage .....                  | 1178 |
| 6.4.3.8.2 | Camera ISP CSI2 Interlaced Frame to Progressive Storage .....                   | 1178 |
| 6.4.3.9   | Camera ISP CSI2 PHYs .....                                                      | 1179 |
| 6.4.3.10  | Camera ISP CSI2 Data Decompression .....                                        | 1181 |
| 6.4.3.11  | Camera ISP CSI2 EndOfFrame and EndOfLine Pulses .....                           | 1181 |
| 6.4.4     | Camera ISP Timing Control .....                                                 | 1182 |
| 6.4.4.1   | Camera ISP Timing Control Features .....                                        | 1182 |
| 6.4.4.2   | Camera ISP Timing Control Overview .....                                        | 1182 |
| 6.4.4.2.1 | Camera ISP Timing Control Generator .....                                       | 1182 |
| 6.4.4.2.2 | Camera ISP Timing Control Control-Signal Generator .....                        | 1182 |
| 6.4.5     | Camera ISP Bridge-Lane Shifter .....                                            | 1186 |
| 6.4.6     | Camera ISP Video-Processing Front End .....                                     | 1186 |

---

|            |                                                                                                                                                                            |      |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 6.4.6.1    | Camera ISP CCDC .....                                                                                                                                                      | 1187 |
| 6.4.6.1.1  | Camera ISP CCDC Features .....                                                                                                                                             | 1187 |
| 6.4.6.1.2  | Camera ISP CCDC Block Diagram .....                                                                                                                                        | 1187 |
| 6.4.6.1.3  | Camera ISP CCDC Functional Operations .....                                                                                                                                | 1189 |
| 6.4.6.1.4  | Camera ISP CCDC DMA .....                                                                                                                                                  | 1200 |
| 6.4.6.1.5  | Camera ISP CCDC Memories .....                                                                                                                                             | 1200 |
| 6.4.7      | Camera ISP Video-Processing Back End .....                                                                                                                                 | 1200 |
| 6.4.7.1    | Camera ISP VPBE Preview Engine Features .....                                                                                                                              | 1200 |
| 6.4.7.1.1  | Camera ISP VPBE Preview Block Diagram .....                                                                                                                                | 1200 |
| 6.4.7.1.2  | Camera ISP VPBE Preview Input Interface .....                                                                                                                              | 1201 |
| 6.4.7.1.3  | Camera ISP VPBE Preview Input Formatter/Averager .....                                                                                                                     | 1202 |
| 6.4.7.1.4  | Camera ISP VPBE Preview Dark-Frame Write .....                                                                                                                             | 1202 |
| 6.4.7.1.5  | Camera ISP VPBE Preview Inverse A-Law .....                                                                                                                                | 1202 |
| 6.4.7.1.6  | Camera ISP VPBE Preview Dark-Frame Subtract or Shading Compensation .....                                                                                                  | 1203 |
| 6.4.7.1.7  | Camera ISP VPBE Preview Horizontal Median Filter .....                                                                                                                     | 1203 |
| 6.4.7.1.8  | Camera ISP VPBE Preview Noise Filter and Faulty Pixel Correction .....                                                                                                     | 1203 |
| 6.4.7.1.9  | Camera ISP VPBE Preview White Balance .....                                                                                                                                | 1203 |
| 6.4.7.1.10 | Camera ISP VPBE Preview CFA Interpolation .....                                                                                                                            | 1204 |
| 6.4.7.1.11 | Camera ISP VPBE Preview Black Adjustment .....                                                                                                                             | 1204 |
| 6.4.7.1.12 | Camera ISP VPBE Preview RGB Blending .....                                                                                                                                 | 1204 |
| 6.4.7.1.13 | Camera ISP VPBE Preview Gamma Correction .....                                                                                                                             | 1205 |
| 6.4.7.1.14 | Camera ISP VPBE Preview RGB to YCbCr Conversion, Luminance Enhancement, Chrominance Suppression, Contrast and Brightness, and 4:2:2 Downsampling and Output Clipping ..... | 1205 |
| 6.4.7.1.15 | Camera ISP VPBE Preview Write-Buffer Interface .....                                                                                                                       | 1206 |
| 6.4.7.2    | Camera ISP VPBE Resizer .....                                                                                                                                              | 1206 |
| 6.4.7.2.1  | Camera ISP VPBE Resizer Features .....                                                                                                                                     | 1206 |
| 6.4.7.2.2  | Camera ISP VPBE Resizer Block Diagram .....                                                                                                                                | 1207 |
| 6.4.7.2.3  | Camera ISP VPBE Resizer Input and Output Interfaces .....                                                                                                                  | 1208 |
| 6.4.7.2.4  | Camera ISP VPBE Resizer Horizontal and Vertical Resizing .....                                                                                                             | 1209 |
| 6.4.7.2.5  | Camera ISP VPBE Resizer Resampling Algorithm .....                                                                                                                         | 1213 |
| 6.4.7.2.6  | Camera ISP VPBE Resizer Luma Edge Enhancement .....                                                                                                                        | 1217 |
| 6.4.8      | Camera ISP Statistics Collection Modules .....                                                                                                                             | 1218 |
| 6.4.8.1    | Camera ISP H3A .....                                                                                                                                                       | 1218 |
| 6.4.8.1.1  | Camera ISP H3A Features .....                                                                                                                                              | 1218 |
| 6.4.8.1.2  | Camera ISP H3A Autofocus Engine .....                                                                                                                                      | 1219 |
| 6.4.8.1.3  | Camera ISP H3A AE/AWB Engine .....                                                                                                                                         | 1219 |
| 6.4.8.2    | Camera ISP Histogram .....                                                                                                                                                 | 1219 |
| 6.4.8.2.1  | Camera ISP Histogram Features .....                                                                                                                                        | 1219 |
| 6.4.8.2.2  | Camera ISP Histogram Block Diagram .....                                                                                                                                   | 1220 |
| 6.4.8.2.3  | Camera ISP Histogram Input Interface .....                                                                                                                                 | 1220 |
| 6.4.8.2.4  | Camera ISP Histogram White Balance .....                                                                                                                                   | 1220 |
| 6.4.8.2.5  | Camera ISP Histogram Binning .....                                                                                                                                         | 1221 |
| 6.4.9      | Camera ISP Central-Resource Shared Buffer Logic .....                                                                                                                      | 1222 |
| 6.4.9.1    | Camera ISP Shared Buffer Logic Block Diagram .....                                                                                                                         | 1223 |
| 6.4.9.2    | Camera ISP Shared Buffer Logic Functional Operations .....                                                                                                                 | 1225 |
| 6.4.9.2.1  | Camera ISP Shared Buffer Logic Parameters .....                                                                                                                            | 1225 |
| 6.4.9.2.2  | Camera ISP Shared Buffer Logic Write-Buffer Logic (WBL) and Write Buffer .....                                                                                             | 1225 |
| 6.4.9.2.3  | Camera ISP Shared Buffer Logic Read Buffer Logic (RBL) and Read Buffer .....                                                                                               | 1226 |
| 6.4.9.2.4  | Camera ISP Shared Buffer Logic Arbitration .....                                                                                                                           | 1226 |
| 6.4.9.3    | Camera ISP Shared Buffer Logic Memories .....                                                                                                                              | 1226 |
| 6.4.9.4    | Camera ISP Shared Buffer Logic Debug Registers .....                                                                                                                       | 1226 |
| 6.4.10     | Camera ISP Circular Buffer .....                                                                                                                                           | 1227 |
| 6.4.10.1   | Camera ISP Circular Buffer Feature List .....                                                                                                                              | 1227 |

|            |                                                                                                                        |      |
|------------|------------------------------------------------------------------------------------------------------------------------|------|
| 6.4.10.2   | Camera ISP Circular Buffer Interrupts .....                                                                            | 1228 |
| 6.4.10.3   | Camera ISP Circular Buffer Functional Description .....                                                                | 1228 |
| 6.4.10.3.1 | Camera ISP Circular Buffer Bandwidth Control Feedback Loop .....                                                       | 1228 |
| 6.4.10.3.2 | Camera ISP Circular Buffer Window Management .....                                                                     | 1234 |
| 6.4.10.3.3 | Camera ISP Circular Buffer CPU Interaction .....                                                                       | 1237 |
| 6.4.11     | Camera ISP MMU Logic .....                                                                                             | 1238 |
| 6.4.11.1   | Camera ISP MMU Features .....                                                                                          | 1238 |
| 6.4.11.2   | Camera ISP MMU Functional Description .....                                                                            | 1238 |
| 6.5        | Camera ISP Basic Programming Model .....                                                                               | 1238 |
| 6.5.1      | Programming the ISP PRCM Clocks Configuration .....                                                                    | 1238 |
| 6.5.2      | Programming the CSI1/CCP2B or CSI2 Receiver Associated PHY .....                                                       | 1238 |
| 6.5.2.1    | Camera ISP CSIPHY Initialization for Work With CSI2 Receiver .....                                                     | 1238 |
| 6.5.2.2    | Camera ISP CSIPHY Initialization for Work With CSI1/CCP2B Receiver .....                                               | 1241 |
| 6.5.3      | Programming the CSI1/CCP2B Receiver .....                                                                              | 1242 |
| 6.5.3.1    | Camera ISP CSI1/CCP2B Hardware Setup/Initialization .....                                                              | 1242 |
| 6.5.3.1.1  | Camera ISP CSI1/CCP2B Reset Behavior .....                                                                             | 1242 |
| 6.5.3.2    | Camera ISP CSI1/CCP2B Event and Status Checking .....                                                                  | 1242 |
| 6.5.3.3    | Camera ISP CSI1/CCP2B Register Accessibility During Frame Processing .....                                             | 1242 |
| 6.5.3.4    | Camera ISP CSI1/CCP2B Enable/Disable the Hardware .....                                                                | 1243 |
| 6.5.3.5    | Camera ISP CSI1/CCP2B Select the Signaling Scheme .....                                                                | 1243 |
| 6.5.3.6    | Camera ISP CSI1/CCP2B Control of the PHY .....                                                                         | 1243 |
| 6.5.3.7    | Camera ISP CSI1/CCP2B Select the Mode: MIPI CSI1 or CCP2B .....                                                        | 1243 |
| 6.5.3.8    | Camera ISP CSI1/CCP2B Burst Settings .....                                                                             | 1243 |
| 6.5.3.9    | Camera ISP CSI1/CCP2B Debug Mode .....                                                                                 | 1243 |
| 6.5.3.10   | Camera ISP CSI1/CCP2B Video Port .....                                                                                 | 1244 |
| 6.5.3.11   | Camera ISP CSI1/CCP2B Logical Channels .....                                                                           | 1245 |
| 6.5.3.12   | Camera ISP CSI1/CCP2B Controls .....                                                                                   | 1245 |
| 6.5.3.13   | Camera ISP CSI1/CCP2B Region of Interest .....                                                                         | 1245 |
| 6.5.3.14   | Camera ISP CSI1/CCP2B CRC .....                                                                                        | 1245 |
| 6.5.3.15   | Camera ISP CSI1/CCP2B Destination Format .....                                                                         | 1245 |
| 6.5.3.16   | Camera ISP CSI1/CCP2B Frame Acquisition .....                                                                          | 1246 |
| 6.5.3.17   | Camera ISP CSI1/CCP2B Synchronization Codes .....                                                                      | 1246 |
| 6.5.3.18   | Camera ISP CSI1/CCP2B Status Data .....                                                                                | 1246 |
| 6.5.3.19   | Camera ISP CSI1/CCP2B Pixel Data Region .....                                                                          | 1247 |
| 6.5.3.20   | Camera ISP CSI1/CCP2B Memory Read Channel .....                                                                        | 1249 |
| 6.5.3.20.1 | Camera ISP CSI1/CCP2B Write Data From Sensor to Memory .....                                                           | 1249 |
| 6.5.3.20.2 | Camera ISP CSI1/CCP2B Read Data from Memory .....                                                                      | 1250 |
| 6.5.4      | Programming the CSI2 Receiver .....                                                                                    | 1251 |
| 6.5.4.1    | Camera ISP CSI2 Enabling the Interface .....                                                                           | 1251 |
| 6.5.4.2    | Camera ISP CSI2 Reset Management .....                                                                                 | 1251 |
| 6.5.4.3    | Camera ISP CSI2 Enable Video/Picture Acquisition .....                                                                 | 1252 |
| 6.5.4.4    | Camera ISP CSI2 Disable Video/Picture Acquisition .....                                                                | 1252 |
| 6.5.4.5    | Camera ISP CSI2 Capture a Finite Number of Frames .....                                                                | 1253 |
| 6.5.4.6    | Camera ISP CSI2 Configure a Periodic Event During Frame Acquisition .....                                              | 1253 |
| 6.5.4.7    | Camera ISP CSI2 Linking a Context to a Virtual Channel and a Data Type .....                                           | 1253 |
| 6.5.4.8    | Camera ISP CSI2 Progressive and Interleaved Frame Configuration .....                                                  | 1255 |
| 6.5.5      | Programming the Timing CTRL Module .....                                                                               | 1255 |
| 6.5.5.1    | Camera ISP Timing CTRL Timing Generator .....                                                                          | 1255 |
| 6.5.5.2    | Camera ISP Timing CTRL Camera-Control Signal Generator .....                                                           | 1256 |
| 6.5.5.2.1  | Camera ISP Timing CTRL Vertical Synchro-Based Control-Signal Generation or Externally-Generated cam_global_reset ..... | 1256 |
| 6.5.5.2.2  | Camera ISP Timing CTRL Internally-Generated cam_global_reset-Based Control-Signal Generation .....                     | 1257 |
| 6.5.5.2.3  | Camera ISP Timing CTRL STROBE and PRESTROBE Signal Generation for Red-Eye .....                                        | 1257 |

---

|                                                                                  |      |
|----------------------------------------------------------------------------------|------|
| Removal .....                                                                    | 1258 |
| 6.5.6 Programming the CCDC .....                                                 | 1258 |
| 6.5.6.1 Camera ISP CCDC Hardware Setup/Initialization .....                      | 1258 |
| 6.5.6.1.1 Camera ISP CCDC Reset Behavior .....                                   | 1258 |
| 6.5.6.1.2 Camera ISP CCDC Register Setup .....                                   | 1259 |
| 6.5.6.1.3 Camera ISP CCDC Pixel Selection (Framing) Register Dependencies .....  | 1260 |
| 6.5.6.2 Camera ISP CCDC Enable/Disable Hardware .....                            | 1262 |
| 6.5.6.3 Camera ISP CCDC Events and Status Checking .....                         | 1262 |
| 6.5.6.3.1 Camera ISP CCDC Interrupts .....                                       | 1262 |
| 6.5.6.3.2 Camera ISP CCDC CCDC_VD0_IRQ and CCDC_VD1_IRQ Interrupts .....         | 1262 |
| 6.5.6.3.3 Camera ISP CCDC CCDC_VD2_IRQ Interrupt .....                           | 1263 |
| 6.5.6.3.4 Camera ISP CCDC Status Checking .....                                  | 1263 |
| 6.5.6.4 Camera ISP CCDC Register Accessibility During Frame Processing .....     | 1263 |
| 6.5.6.5 Camera ISP CCDC Interframe Operations .....                              | 1264 |
| 6.5.6.6 Camera ISP CCDC Operations .....                                         | 1265 |
| 6.5.6.6.1 Camera ISP CCDC Image-Sensor Configuration .....                       | 1265 |
| 6.5.6.6.2 Camera ISP CCDC Image-Signal Processing .....                          | 1267 |
| 6.5.6.6.7 Camera ISP CCDC Summary of Constraints .....                           | 1274 |
| 6.5.7 Programming the Preview Engine .....                                       | 1274 |
| 6.5.7.1 Camera ISP Preview Setup/Initialization .....                            | 1274 |
| 6.5.7.1.1 Camera ISP Preview Reset Behavior .....                                | 1274 |
| 6.5.7.1.2 Camera ISP Preview Register Setup .....                                | 1274 |
| 6.5.7.1.3 Camera ISP Preview Table Setup .....                                   | 1276 |
| 6.5.7.2 Camera ISP Preview Enable/Disable Hardware .....                         | 1277 |
| 6.5.7.3 Camera ISP Preview Events and Status Checking .....                      | 1277 |
| 6.5.7.4 Camera ISP Preview Register Accessibility During Frame Processing .....  | 1277 |
| 6.5.7.5 Camera ISP Preview Interframe Operations .....                           | 1278 |
| 6.5.7.6 Camera ISP Preview Summary of Constraints .....                          | 1278 |
| 6.5.8 Programming the Resizer .....                                              | 1279 |
| 6.5.8.1 Camera ISP Resizer Setup/Initialization .....                            | 1279 |
| 6.5.8.1.1 Camera ISP Resizer Reset Behavior .....                                | 1279 |
| 6.5.8.1.2 Camera ISP Resizer Register Setup .....                                | 1279 |
| 6.5.8.2 Camera ISP Resizer Enable/Disable Hardware .....                         | 1280 |
| 6.5.8.3 Camera ISP Resizer Events and Status Checking .....                      | 1280 |
| 6.5.8.4 Camera ISP Resizer Register Accessibility During Frame Processing .....  | 1281 |
| 6.5.8.5 Camera ISP Resizer Inter-Frame Operations .....                          | 1281 |
| 6.5.8.5.1 Camera ISP Resizer Multiple Passes for Large Resizing Operations ..... | 1282 |
| 6.5.8.5.2 Camera ISP Resizer Processing Time Calculation .....                   | 1282 |
| 6.5.8.6 Camera ISP Resizer Summary of Constraints .....                          | 1283 |
| 6.5.9 Programming the H3A .....                                                  | 1284 |
| 6.5.9.1 Camera ISP H3A Setup/Initialization .....                                | 1284 |
| 6.5.9.1.1 Camera ISP H3A Reset Behavior .....                                    | 1284 |
| 6.5.9.1.2 Camera ISP H3A Register Setup .....                                    | 1284 |
| 6.5.9.2 Camera ISP H3A Enable/Disable Hardware .....                             | 1285 |
| 6.5.9.3 Camera ISP H3A Event and Status Checking .....                           | 1286 |
| 6.5.9.4 Camera ISP H3A Register Accessibility During Frame Processing .....      | 1286 |
| 6.5.9.5 Camera ISP H3A Interframe Operations .....                               | 1286 |
| 6.5.9.6 Camera ISP H3A Summary of Constraints .....                              | 1286 |
| 6.5.10 Programming the Histogram .....                                           | 1287 |
| 6.5.10.1 Camera ISP Histogram Setup/Initialization .....                         | 1287 |
| 6.5.10.1.1 Camera ISP Histogram Reset Behavior .....                             | 1287 |
| 6.5.10.1.2 Camera ISP Histogram Reset of Histogram Output Memory .....           | 1287 |
| 6.5.10.1.3 Camera ISP Histogram Register Setup .....                             | 1287 |

|            |                                                                                      |      |
|------------|--------------------------------------------------------------------------------------|------|
| 6.5.10.2   | Camera ISP Histogram Enable/Disable Hardware .....                                   | 1288 |
| 6.5.10.3   | Camera ISP Histogram Event and Status Checking .....                                 | 1288 |
| 6.5.10.4   | Camera ISP Histogram Register Accessibility During Frame Processing .....            | 1288 |
| 6.5.10.5   | Camera ISP Histogram Interframe Operations .....                                     | 1289 |
| 6.5.10.6   | Camera ISP Histogram Summary of Constraints .....                                    | 1289 |
| 6.5.11     | Programming the Central-Resource SBL .....                                           | 1289 |
| 6.5.11.1   | Camera ISP Central-Resource SBL Setup/Initialization .....                           | 1290 |
| 6.5.11.1.1 | Camera ISP Central-Resource SBLReset Behavior .....                                  | 1290 |
| 6.5.11.1.2 | Camera ISP Central-Resource SBLRegister Setup .....                                  | 1290 |
| 6.5.11.2   | Camera ISP Central-Resource SBL Enable/Disable Hardware .....                        | 1290 |
| 6.5.11.3   | Camera ISP Central-Resource SBL Event and Status Checking .....                      | 1290 |
| 6.5.11.4   | Camera ISP Central-Resource SBL Register Accessibility During Frame Processing ..... | 1291 |
| 6.5.11.5   | Camera ISP Central-Resource SBL Camera ISP Bandwidth Adjustments .....               | 1291 |
| 6.5.11.5.1 | Camera ISP Central-Resource SBL Input From CCDC Video-Port Interface .....           | 1292 |
| 6.5.11.5.2 | Camera ISP Central-Resource SBL Input From Memory .....                              | 1292 |
| 6.5.12     | Programming the Circular Buffer .....                                                | 1293 |
| 6.5.12.1   | Camera ISP CBUFF Setup/Initialization .....                                          | 1293 |
| 6.5.12.2   | Camera ISP CBUFF Reset Behavior .....                                                | 1293 |
| 6.5.12.3   | Camera ISP CBUFF Register Setup .....                                                | 1293 |
| 6.5.12.4   | Camera ISP CBUFF Event and status Checking .....                                     | 1294 |
| 6.5.12.4.1 | Camera ISP CBUFF Interrupts .....                                                    | 1294 |
| 6.5.12.4.2 | Camera ISP CBUFF Status Checking .....                                               | 1294 |
| 6.5.12.5   | Camera ISP CBUFF Register Accessibility During Frame Processing .....                | 1294 |
| 6.5.12.6   | Camera ISP CBUFF Operations .....                                                    | 1294 |
| 6.5.13     | Programming the Camera ISP Software Reset .....                                      | 1295 |
| 6.6        | Camera ISP Register Manual .....                                                     | 1296 |
| 6.6.1      | Camera ISP Instance Summary .....                                                    | 1296 |
| 6.6.1.1    | Camera ISP Registers Summary .....                                                   | 1296 |
| 6.6.1.2    | Camera ISP Register Description .....                                                | 1297 |
| 6.6.2      | Camera ISP CBUFF Registers .....                                                     | 1324 |
| 6.6.2.1    | Camera ISP CBUFF Register Summary .....                                              | 1324 |
| 6.6.2.2    | Camera ISP CBUF Register Description .....                                           | 1324 |
| 6.6.3      | Camera ISP CCP2 Registers .....                                                      | 1334 |
| 6.6.3.1    | Camera ISP CCP2 Register Summary .....                                               | 1334 |
| 6.6.3.2    | Camera ISP CCP2 Register Description .....                                           | 1335 |
| 6.6.4      | Camera ISP CCDC Registers .....                                                      | 1367 |
| 6.6.4.1    | Camera ISP CCDC Register Summary .....                                               | 1367 |
| 6.6.4.2    | Camera ISP CCDC Register Description .....                                           | 1368 |
| 6.6.5      | Camera ISP HIST Registers .....                                                      | 1400 |
| 6.6.5.1    | Camera ISP HIST Register Summary .....                                               | 1400 |
| 6.6.5.2    | Camera ISP HIST Register Description .....                                           | 1400 |
| 6.6.6      | Camera ISP H3A Registers .....                                                       | 1407 |
| 6.6.6.1    | Camera ISP H3A Register Summary .....                                                | 1407 |
| 6.6.6.2    | Camera ISP H3A Register Description .....                                            | 1408 |
| 6.6.7      | Camera ISP PREVIEW Registers .....                                                   | 1421 |
| 6.6.7.1    | Camera ISP PREVIEW Register Summary .....                                            | 1421 |
| 6.6.7.2    | Camera ISP PREVIEW Register Description .....                                        | 1422 |
| 6.6.8      | Camera ISP RESIZER Registers .....                                                   | 1447 |
| 6.6.8.1    | Camera ISP RESIZER Register Summary .....                                            | 1447 |
| 6.6.8.2    | Camera ISP RESIZER Register Description .....                                        | 1448 |
| 6.6.9      | Camera ISP SBL Registers .....                                                       | 1472 |
| 6.6.9.1    | Camera ISP SBL Register Summary .....                                                | 1472 |
| 6.6.9.2    | Camera ISP SBL Register Description .....                                            | 1473 |

---

|            |                                                                          |             |
|------------|--------------------------------------------------------------------------|-------------|
| 6.6.10     | Camera ISP CSI2 Registers .....                                          | 1519        |
| 6.6.10.1   | Camera ISP CSI2 REGS1 Register Summary .....                             | 1519        |
| 6.6.10.2   | Camera ISP CSI2 REGS1 Register Description .....                         | 1520        |
| 6.6.10.3   | Camera ISP CSI2 REGS2 Register Summary .....                             | 1549        |
| 6.6.10.4   | Camera ISP CSI2 REGS2 Register Description .....                         | 1549        |
| 6.6.11     | Camera ISP CSIPHY Registers .....                                        | 1550        |
| 6.6.11.1   | Camera ISP CSIPHY Register Summary .....                                 | 1550        |
| 6.6.11.2   | Camera ISP CSIPHY Register Description .....                             | 1550        |
| <b>7</b>   | <b>Display Subsystem .....</b>                                           | <b>1555</b> |
| 7.1        | Display Subsystem Overview .....                                         | 1556        |
| 7.2        | Display Subsystem Environment .....                                      | 1561        |
| 7.2.1      | LCD Support .....                                                        | 1561        |
| 7.2.1.1    | Parallel Interface .....                                                 | 1565        |
| 7.2.1.1.1  | Parallel Interface in RFBI Mode (MIPI DBI Protocol) .....                | 1565        |
| 7.2.1.1.2  | Parallel Interface in Bypass Mode (MIPI DPI Protocol) .....              | 1568        |
| 7.2.1.1.3  | LCD Output and Data Format for the Parallel Interface .....              | 1569        |
| 7.2.1.1.4  | Transaction Timing Diagrams .....                                        | 1573        |
| 7.2.1.2    | DSI Serial Interface .....                                               | 1581        |
| 7.2.2      | LCD Support With MIPI DSI 1.0 Protocol and Data Format .....             | 1581        |
| 7.2.2.1    | Physical Layer .....                                                     | 1581        |
| 7.2.2.1.1  | Data/Clock Configuration .....                                           | 1582        |
| 7.2.2.1.2  | ULPS .....                                                               | 1583        |
| 7.2.2.2    | Video Port (VP) Interface .....                                          | 1583        |
| 7.2.2.2.1  | Video Port Used for Video Mode .....                                     | 1584        |
| 7.2.2.2.2  | Video Port Used on Command Mode .....                                    | 1589        |
| 7.2.2.2.3  | Burst Mode .....                                                         | 1591        |
| 7.2.2.3    | Multilane Layer .....                                                    | 1592        |
| 7.2.2.3.1  | SoT and EoT in Multilane Configurations .....                            | 1592        |
| 7.2.2.3.2  | Lane Splitter .....                                                      | 1592        |
| 7.2.2.4    | Protocol Layer .....                                                     | 1593        |
| 7.2.2.4.1  | Short Packet .....                                                       | 1593        |
| 7.2.2.4.2  | Long Packet .....                                                        | 1594        |
| 7.2.2.4.3  | Data Identifier .....                                                    | 1595        |
| 7.2.2.4.4  | Virtual Channel ID - VC Field, DI[7:6] .....                             | 1595        |
| 7.2.2.4.5  | Data Type Field DT[5:0] .....                                            | 1595        |
| 7.2.2.4.6  | Pixel Data Formats in Video Mode .....                                   | 1595        |
| 7.2.2.4.7  | Synchronization Codes .....                                              | 1596        |
| 7.2.2.4.8  | Blanking .....                                                           | 1596        |
| 7.2.2.4.9  | Frame Structures .....                                                   | 1600        |
| 7.2.2.4.10 | Virtual Channels .....                                                   | 1604        |
| 7.2.2.5    | Pixel Data Formats .....                                                 | 1604        |
| 7.2.2.5.1  | 24 Bits per Pixel - RGB Color Format, Long Packet .....                  | 1604        |
| 7.2.2.5.2  | 18 Bits per Pixel (Loosely Packed) - RGB Color Format, Long Packet ..... | 1605        |
| 7.2.2.5.3  | 18 Bits per Pixel (Packed) - RGB Color Format, Long Packet .....         | 1606        |
| 7.2.2.5.4  | 16 Bits per Pixel - RGB Color Format, Long Packet .....                  | 1607        |
| 7.2.3      | TV Display Support .....                                                 | 1608        |
| 7.2.3.1    | TV Output and Data Format .....                                          | 1612        |
| 7.2.3.2    | Digital-to-Analog Converters .....                                       | 1613        |
| 7.3        | Display Subsystem Integration .....                                      | 1613        |
| 7.3.1      | Clocking, Reset, and Power-Management Scheme .....                       | 1615        |
| 7.3.1.1    | Clocks .....                                                             | 1615        |
| 7.3.1.2    | Resets .....                                                             | 1618        |
| 7.3.1.2.1  | Hardware Reset .....                                                     | 1618        |

|           |                                                            |      |
|-----------|------------------------------------------------------------|------|
| 7.3.1.2.2 | Software Reset .....                                       | 1619 |
| 7.3.1.3   | Power Domain .....                                         | 1619 |
| 7.3.1.4   | Power Management .....                                     | 1619 |
| 7.3.1.4.1 | Clock Activity Mode .....                                  | 1619 |
| 7.3.1.4.2 | Autoidle Mode .....                                        | 1620 |
| 7.3.1.4.3 | Idle Mode .....                                            | 1620 |
| 7.3.1.4.4 | Wake-Up Mode .....                                         | 1621 |
| 7.3.1.4.5 | Standby Mode .....                                         | 1621 |
| 7.3.2     | Hardware Requests .....                                    | 1624 |
| 7.3.2.1   | DMA Requests .....                                         | 1624 |
| 7.3.2.1.1 | Display Controller DMA Request (Line Trigger) .....        | 1624 |
| 7.3.2.1.2 | DSI Protocol Engine DMA Request .....                      | 1625 |
| 7.3.2.1.3 | RFBI DMA Request .....                                     | 1625 |
| 7.3.2.2   | Interrupt Requests .....                                   | 1625 |
| 7.3.2.2.1 | DISPC Interrupt Request .....                              | 1626 |
| 7.3.2.2.2 | DSI Interrupt Request .....                                | 1627 |
| 7.4       | Display Subsystem Functional Description .....             | 1630 |
| 7.4.1     | Block Diagram .....                                        | 1630 |
| 7.4.2     | Display Controller Functionalities .....                   | 1630 |
| 7.4.2.1   | Display Modes .....                                        | 1632 |
| 7.4.2.1.1 | LCD Output .....                                           | 1632 |
| 7.4.2.1.2 | Digital Output .....                                       | 1632 |
| 7.4.2.2   | Graphics Pipeline .....                                    | 1632 |
| 7.4.2.2.1 | Graphics Memory Format .....                               | 1632 |
| 7.4.2.2.2 | Color Look-Up Table/Gamma Table .....                      | 1634 |
| 7.4.2.2.3 | Video Pipeline .....                                       | 1636 |
| 7.4.2.3.1 | Video Memory Formats .....                                 | 1636 |
| 7.4.2.3.2 | Color Space Conversion .....                               | 1638 |
| 7.4.2.3.3 | Hardware Cursor .....                                      | 1640 |
| 7.4.2.3.4 | Up-/Down-Sampling .....                                    | 1640 |
| 7.4.2.2.4 | Overlay Support .....                                      | 1644 |
| 7.4.2.4.1 | Priority Rule .....                                        | 1644 |
| 7.4.2.4.2 | Transparency Color Keys .....                              | 1649 |
| 7.4.2.4.3 | Overlay Optimization (Only Available in Normal Mode) ..... | 1651 |
| 7.4.2.2.5 | Active/Passive Matrix Display Data Path .....              | 1651 |
| 7.4.2.5.1 | Color Phase Rotation .....                                 | 1652 |
| 7.4.2.5.2 | Passive Matrix Display Dithering Logic .....               | 1653 |
| 7.4.2.5.3 | Passive Matrix Display Output FIFO .....                   | 1653 |
| 7.4.2.5.4 | Multiple Cycle Output Format .....                         | 1653 |
| 7.4.2.2.6 | Video Line Buffer .....                                    | 1654 |
| 7.4.2.2.7 | Synchronized Buffer Update .....                           | 1654 |
| 7.4.2.2.8 | Rotation .....                                             | 1654 |
| 7.4.2.2.9 | Multiple Buffer Support .....                              | 1655 |
| 7.4.3     | DSI Protocol Engine Functionalities .....                  | 1655 |
| 7.4.3.1   | DSI Protocol Architecture .....                            | 1655 |
| 7.4.3.2   | Clock Requirements .....                                   | 1657 |
| 7.4.3.2.1 | Timing Parameters for an LP to HS Transaction .....        | 1658 |
| 7.4.3.2.2 | Timing Parameters for an HS to LP Transaction .....        | 1660 |
| 7.4.3.2.3 | Extra LP Transitions .....                                 | 1662 |
| 7.4.3.3   | DSI Transfer Modes .....                                   | 1663 |
| 7.4.3.3.1 | Video Mode .....                                           | 1663 |
| 7.4.3.3.2 | Command Mode .....                                         | 1663 |
| 7.4.3.3.3 | Video + Command Modes .....                                | 1664 |

---

|           |                                                             |      |
|-----------|-------------------------------------------------------------|------|
| 7.4.3.3.4 | Burst Modes .....                                           | 1664 |
| 7.4.3.3.5 | Interleaving Mode .....                                     | 1665 |
| 7.4.3.4   | Power Management .....                                      | 1669 |
| 7.4.3.5   | Serial Configuration Port (SCP) Interface .....             | 1669 |
| 7.4.3.5.1 | Shadowing Register .....                                    | 1669 |
| 7.4.3.5.2 | Busy Signal .....                                           | 1670 |
| 7.4.3.6   | Power Control .....                                         | 1670 |
| 7.4.3.6.1 | Complex I/O Power Control Commands .....                    | 1670 |
| 7.4.3.6.2 | DSI PLL Power Control Commands .....                        | 1671 |
| 7.4.3.7   | Timers .....                                                | 1674 |
| 7.4.3.7.1 | Twakeup Timer .....                                         | 1674 |
| 7.4.3.7.2 | ForceTxStopMode FSM .....                                   | 1674 |
| 7.4.3.7.3 | TurnRequest FSM .....                                       | 1675 |
| 7.4.3.7.4 | Peripheral Reset Timer .....                                | 1676 |
| 7.4.3.7.5 | HS TX Timer .....                                           | 1676 |
| 7.4.3.7.6 | LP RX Timer .....                                           | 1677 |
| 7.4.3.8   | Bus Turnaround .....                                        | 1678 |
| 7.4.3.9   | PHY Triggers .....                                          | 1680 |
| 7.4.3.9.1 | Reset .....                                                 | 1680 |
| 7.4.3.9.2 | Tearing Effect .....                                        | 1680 |
| 7.4.3.9.3 | Acknowledge .....                                           | 1681 |
| 7.4.3.10  | ECC Generation .....                                        | 1682 |
| 7.4.3.11  | Checksum Generation for Long Packet Payloads .....          | 1682 |
| 7.4.3.12  | End of Transfer Packet .....                                | 1683 |
| 7.4.4     | DSI PLL Controller Functionalities .....                    | 1683 |
| 7.4.4.1   | DSI PLL Controller Overview .....                           | 1683 |
| 7.4.4.2   | DSI PLL Controller Architecture .....                       | 1684 |
| 7.4.4.3   | DSI PLL Operations .....                                    | 1685 |
| 7.4.4.4   | DSI PLL Controller Shadowing Mechanism .....                | 1686 |
| 7.4.4.5   | Error Handling .....                                        | 1686 |
| 7.4.5     | DSI Complex I/O Functionalities .....                       | 1686 |
| 7.4.5.1   | DSI Complex I/O Overview .....                              | 1686 |
| 7.4.6     | RFBI Functionalities .....                                  | 1687 |
| 7.4.6.1   | RFBI FIFO .....                                             | 1687 |
| 7.4.6.2   | RFBI Interconnect FIFO .....                                | 1687 |
| 7.4.6.3   | Input Pixel Formats .....                                   | 1687 |
| 7.4.6.4   | Output Parallel Modes .....                                 | 1688 |
| 7.4.6.5   | Unmodified Bits .....                                       | 1688 |
| 7.4.6.6   | Bypass Mode .....                                           | 1688 |
| 7.4.6.7   | Send Commands .....                                         | 1688 |
| 7.4.6.8   | Read/Write .....                                            | 1689 |
| 7.4.7     | Video Encoder Functionalities .....                         | 1689 |
| 7.4.7.1   | Test Pattern Generation .....                               | 1690 |
| 7.4.7.2   | Luma Stage .....                                            | 1691 |
| 7.4.7.3   | Chroma Stage .....                                          | 1691 |
| 7.4.7.4   | Subcarrier and Burst Generation .....                       | 1691 |
| 7.4.7.5   | Closed Caption Encoding .....                               | 1692 |
| 7.4.7.6   | Wide-Screen Signaling (WSS) Encoding .....                  | 1694 |
| 7.4.7.7   | Video DAC Stage – Architecture and Control .....            | 1695 |
| 7.4.7.8   | Video DC/AC Coupled TV Load .....                           | 1697 |
| 7.4.7.9   | TV Detection/Disconnection Pulse Generation and Usage ..... | 1697 |
| 7.4.7.9.1 | TV Detection/Disconnection Pulse Generation .....           | 1697 |
| 7.4.7.9.2 | TV Detection Procedure .....                                | 1698 |

|            |                                                             |      |
|------------|-------------------------------------------------------------|------|
| 7.4.7.9.3  | TV Disconnection Procedure .....                            | 1698 |
| 7.4.7.9.4  | Recommended TV Detection/Disconnection Pulse Waveform ..... | 1699 |
| 7.4.7.9.5  | TV Detection/Disconnection Usage .....                      | 1700 |
| 7.4.7.10   | Video DAC Stage Bypass Mode .....                           | 1701 |
| 7.4.7.11   | Video DAC Stage Test Mode .....                             | 1702 |
| 7.4.7.12   | Video DAC Stage Power Management .....                      | 1703 |
| 7.5        | Display Subsystem Basic Programming Model .....             | 1705 |
| 7.5.1      | Display Subsystem Reset .....                               | 1705 |
| 7.5.2      | Display Subsystem Configuration Phase .....                 | 1705 |
| 7.5.3      | Display Controller Basic Programming Model .....            | 1705 |
| 7.5.3.1    | Display Controller Configuration .....                      | 1707 |
| 7.5.3.2    | Graphics Layer Configuration .....                          | 1707 |
| 7.5.3.2.1  | Graphics DMA Registers .....                                | 1707 |
| 7.5.3.2.2  | Graphics Layer Configuration Registers .....                | 1709 |
| 7.5.3.2.3  | Graphics Window Attributes .....                            | 1709 |
| 7.5.3.3    | Video Layer Configuration .....                             | 1712 |
| 7.5.3.3.1  | Video DMA Registers .....                                   | 1712 |
| 7.5.3.3.2  | Video Configuration Register .....                          | 1713 |
| 7.5.3.3.3  | Video Window Attributes .....                               | 1714 |
| 7.5.3.3.4  | Video Up-/Down-Sampling Configuration .....                 | 1715 |
| 7.5.3.3.5  | Video Color Space Conversion Configuration .....            | 1717 |
| 7.5.3.4    | Rotation/Mirroring Display Subsystem Settings .....         | 1717 |
| 7.5.3.4.1  | Image Data Formats .....                                    | 1718 |
| 7.5.3.4.2  | Image Data from On-Chip SRAM .....                          | 1718 |
| 7.5.3.4.3  | Image Data From External SRAM .....                         | 1723 |
| 7.5.3.4.4  | Additional Configuration When Using YUV Format .....        | 1726 |
| 7.5.3.4.5  | Video DMA Optimization .....                                | 1727 |
| 7.5.3.5    | LCD-Specific Control Registers .....                        | 1728 |
| 7.5.3.5.1  | LCD Attributes .....                                        | 1728 |
| 7.5.3.5.2  | LCD Timings .....                                           | 1728 |
| 7.5.3.5.3  | LCD Overlay .....                                           | 1731 |
| 7.5.3.5.4  | LCD TDM .....                                               | 1732 |
| 7.5.3.5.5  | LCD Spatial/Temporal Dithering .....                        | 1732 |
| 7.5.3.5.6  | LCD Color Phase Rotation .....                              | 1733 |
| 7.5.3.6    | TV Set-Specific Control Registers .....                     | 1736 |
| 7.5.3.6.1  | Digital Timings .....                                       | 1737 |
| 7.5.3.6.2  | Digital Frame/Field Size .....                              | 1737 |
| 7.5.3.6.3  | Digital Overlay .....                                       | 1737 |
| 7.5.4      | DSI Protocol Engine Basic Programming Model .....           | 1737 |
| 7.5.4.1    | Software Reset .....                                        | 1737 |
| 7.5.4.2    | Power Management .....                                      | 1738 |
| 7.5.4.3    | Interrupts .....                                            | 1738 |
| 7.5.4.4    | Global Register Controls .....                              | 1738 |
| 7.5.4.5    | Virtual Channels .....                                      | 1739 |
| 7.5.4.6    | Packets .....                                               | 1739 |
| 7.5.4.7    | DSI Complex I/O .....                                       | 1740 |
| 7.5.4.8    | Video Mode .....                                            | 1740 |
| 7.5.4.9    | Video Port Data Bus .....                                   | 1741 |
| 7.5.4.10   | Command Mode .....                                          | 1741 |
| 7.5.4.10.1 | Command Mode TX FIFO .....                                  | 1741 |
| 7.5.4.10.2 | Command Mode RX FIFO .....                                  | 1743 |
| 7.5.4.10.3 | Command Mode DMA Requests .....                             | 1744 |
| 7.5.4.11   | Ultra-Low Power State .....                                 | 1746 |

---

|            |                                                             |      |
|------------|-------------------------------------------------------------|------|
| 7.5.4.11.1 | Entering ULPS .....                                         | 1746 |
| 7.5.4.11.2 | Exiting ULPS .....                                          | 1746 |
| 7.5.4.12   | DSI Programming Sequence Example .....                      | 1747 |
| 7.5.4.12.1 | Video Mode Transfer .....                                   | 1748 |
| 7.5.4.12.2 | Command Mode Transfer Example 1 .....                       | 1748 |
| 7.5.4.12.3 | Command Mode Transfer Example 2 .....                       | 1749 |
| 7.5.5      | DSI PLL Controller Basic Programming Model .....            | 1750 |
| 7.5.5.1    | Software Reset .....                                        | 1750 |
| 7.5.5.2    | DSI PLL Programming Blocks .....                            | 1750 |
| 7.5.5.3    | DSI PLL Go Sequence .....                                   | 1751 |
| 7.5.5.4    | DSI PLL Clock Gating Sequence .....                         | 1753 |
| 7.5.5.5    | DSI PLL Lock Sequence .....                                 | 1754 |
| 7.5.5.6    | DSI PLL Error Handling .....                                | 1757 |
| 7.5.5.7    | DSI PLL Recommended Values .....                            | 1757 |
| 7.5.6      | DSI Complex I/O Basic Programming Model .....               | 1758 |
| 7.5.6.1    | Software Reset .....                                        | 1758 |
| 7.5.6.2    | Reset-Done Bits .....                                       | 1758 |
| 7.5.6.3    | Pad Configuration .....                                     | 1759 |
| 7.5.6.4    | Display Timing Configuration .....                          | 1759 |
| 7.5.6.4.1  | High-Speed Clock Transmission .....                         | 1759 |
| 7.5.6.4.2  | High-Speed Data Transmission .....                          | 1760 |
| 7.5.6.4.3  | Turn-Around Request in Transmit Mode .....                  | 1762 |
| 7.5.6.4.4  | Turn-Around Request in Receive Mode .....                   | 1762 |
| 7.5.6.4.5  | Other DSI_PHY Transmission and Reception .....              | 1763 |
| 7.5.6.5    | Error Handling .....                                        | 1763 |
| 7.5.7      | RFBI Basic Programming Model .....                          | 1764 |
| 7.5.7.1    | DISPC Control Registers .....                               | 1764 |
| 7.5.7.2    | RFBI Control Registers .....                                | 1764 |
| 7.5.7.2.1  | High Threshold .....                                        | 1764 |
| 7.5.7.2.2  | Bypass Mode .....                                           | 1765 |
| 7.5.7.2.3  | Enable .....                                                | 1765 |
| 7.5.7.2.4  | Configuration Selection .....                               | 1765 |
| 7.5.7.2.5  | ITE Bit .....                                               | 1766 |
| 7.5.7.2.6  | Number of Pixels to Transfer .....                          | 1766 |
| 7.5.7.2.7  | Programmable Line Number .....                              | 1766 |
| 7.5.7.3    | RFBI Configuration .....                                    | 1767 |
| 7.5.7.3.1  | Parallel Mode .....                                         | 1767 |
| 7.5.7.3.2  | Trigger Mode .....                                          | 1767 |
| 7.5.7.3.3  | VSYNC Pulse Width (Minimum Value) .....                     | 1767 |
| 7.5.7.3.4  | HSYNC Pulse Width (Minimum Value) .....                     | 1767 |
| 7.5.7.3.5  | Cycle Format .....                                          | 1767 |
| 7.5.7.3.6  | Unused Bits .....                                           | 1768 |
| 7.5.7.3.7  | RFBI Timings .....                                          | 1768 |
| 7.5.7.3.8  | RFBI State-Machine .....                                    | 1769 |
| 7.5.7.3.9  | RFBI Configuration Flow Charts .....                        | 1770 |
| 7.5.8      | Video Encoder Basic Programming Model .....                 | 1773 |
| 7.5.8.1    | Video Encoder Software Reset .....                          | 1773 |
| 7.5.8.2    | Video DAC Stage Settings .....                              | 1773 |
| 7.5.8.3    | Video Encoder Programming Sequence .....                    | 1775 |
| 7.5.8.4    | Video Encoder Register Settings .....                       | 1775 |
| 7.6        | Display Subsystem Use Cases and Tips .....                  | 1777 |
| 7.6.1      | How to Configure the Scaling Unit in the DISPC Module ..... | 1777 |
| 7.6.1.1    | Filtering .....                                             | 1777 |

|           |                                                                           |      |
|-----------|---------------------------------------------------------------------------|------|
| 7.6.1.1.1 | Vertical Filtering .....                                                  | 1777 |
| 7.6.1.1.2 | Horizontal Filtering .....                                                | 1779 |
| 7.6.1.2   | Scaling Algorithms .....                                                  | 1779 |
| 7.6.1.3   | Scaling Settings .....                                                    | 1781 |
| 7.6.1.3.1 | Register List .....                                                       | 1781 |
| 7.6.1.3.2 | Enabling .....                                                            | 1782 |
| 7.6.1.3.3 | Factor .....                                                              | 1783 |
| 7.6.1.3.4 | Initial Phase .....                                                       | 1783 |
| 7.6.1.3.5 | Coefficients .....                                                        | 1784 |
| 7.6.2     | Display Low-Power Refresh Settings .....                                  | 1788 |
| 7.6.2.1   | Display Low-Power Refresh Overview .....                                  | 1789 |
| 7.6.2.2   | Display Subsystem Clock .....                                             | 1789 |
| 7.6.2.2.1 | Display Subsystem Clock Configuration .....                               | 1789 |
| 7.6.2.2.2 | Display Subsystem Clock Enable .....                                      | 1790 |
| 7.6.2.3   | DPLL4 in Low-Power Mode .....                                             | 1791 |
| 7.6.2.4   | Autoidle and Smart Idle .....                                             | 1791 |
| 7.6.2.4.1 | Autoidle .....                                                            | 1791 |
| 7.6.2.4.2 | Smart-Idle .....                                                          | 1791 |
| 7.6.2.5   | FIFO Thresholds .....                                                     | 1791 |
| 7.6.2.5.1 | FIFO Threshold Settings to Reduce Power Consumption .....                 | 1792 |
| 7.6.2.6   | Vertical and Horizontal Timings .....                                     | 1792 |
| 7.6.2.6.1 | Horizontal and Vertical Timing Settings to Reduce Power Consumption ..... | 1793 |
| 7.6.3     | How to Configure the DSI PLL in Video Mode .....                          | 1793 |
| 7.6.4     | DSI Video Mode Using the DISPC Video Port .....                           | 1795 |
| 7.6.4.1   | Display Subsystem Clock Configuration .....                               | 1797 |
| 7.6.4.2   | Configure DSI, DSI PLL and Complex I/O .....                              | 1798 |
| 7.6.4.2.1 | Reset DSI Modules .....                                                   | 1798 |
| 7.6.4.2.2 | Set Up DSI DPLL .....                                                     | 1798 |
| 7.6.4.2.3 | Switch to DSI PLL Clock Source .....                                      | 1799 |
| 7.6.4.2.4 | Set Up DSI Protocol Engine .....                                          | 1799 |
| 7.6.4.2.5 | Configure DSI_PHY .....                                                   | 1801 |
| 7.6.4.2.6 | Drive Stop State .....                                                    | 1801 |
| 7.6.4.3   | Initialization of the External MIPI Display Controller .....              | 1802 |
| 7.6.4.4   | Configure the DISPC .....                                                 | 1802 |
| 7.6.4.4.1 | Reset DISPC .....                                                         | 1802 |
| 7.6.4.4.2 | Configure DISPC Timing, Window, and Color .....                           | 1802 |
| 7.6.4.5   | Enable Video Mode Using the DISPC Video Port .....                        | 1803 |
| 7.6.5     | DSI Command Mode Using the DISPC Video Port .....                         | 1803 |
| 7.6.5.1   | Display Subsystem Use Cases and Tips .....                                | 1803 |
| 7.6.5.1.1 | Configure DSS Clocks at the PRCM Module .....                             | 1805 |
| 7.6.5.1.2 | Configure DSI Protocol Engine, DSI PLL, and Complex I/O .....             | 1805 |
| 7.6.5.1.3 | Initialization of the External MIPI LCD Controller .....                  | 1810 |
| 7.6.5.1.4 | Configure the DISPC .....                                                 | 1810 |
| 7.6.5.1.5 | Enable Command Mode Using DISPC Video Port .....                          | 1811 |
| 7.6.5.1.6 | Send Frame Data to LCD Panel Using Automatic TE .....                     | 1812 |
| 7.7       | Display Subsystem Register Manual .....                                   | 1813 |
| 7.7.1     | Display Subsystem Register Mapping Summary .....                          | 1813 |
| 7.7.1.1   | Display Subsystem Register Mapping Summary .....                          | 1813 |
| 7.7.1.2   | Display Controller Register Mapping Summary .....                         | 1814 |
| 7.7.1.3   | Display Controller VID1 Register Mapping Summary .....                    | 1814 |
| 7.7.1.4   | Display Controller VID2 Register Mapping Summary .....                    | 1815 |
| 7.7.1.5   | RFBI Register Mapping Summary .....                                       | 1816 |
| 7.7.1.6   | Video Encoder Register Mapping Summary .....                              | 1816 |

---

|           |                                                              |             |
|-----------|--------------------------------------------------------------|-------------|
| 7.7.1.7   | DSI Protocol Engine Register Mapping Summary .....           | 1818        |
| 7.7.1.8   | DSI_PHY Register Mapping Summary .....                       | 1819        |
| 7.7.1.9   | DSI PLL Controller Register Mapping Summary .....            | 1819        |
| 7.7.2     | Display Subsystem Register Descriptions .....                | 1819        |
| 7.7.2.1   | Display Subsystem Registers .....                            | 1819        |
| 7.7.2.2   | Display Controller Registers .....                           | 1824        |
| 7.7.2.3   | RFBI Registers .....                                         | 1871        |
| 7.7.2.4   | Video Encoder Registers .....                                | 1886        |
| 7.7.2.5   | DSI Protocol Engine Registers .....                          | 1913        |
| 7.7.2.6   | DSI Complex I/O Registers .....                              | 1956        |
| 7.7.2.7   | DSI PLL Control Module Registers .....                       | 1962        |
| <b>8</b>  | <b>2D/3D Graphics Accelerator .....</b>                      | <b>1969</b> |
| 8.1       | SGX Overview .....                                           | 1970        |
| 8.1.1     | POWERVR SGX Main Features .....                              | 1970        |
| 8.1.2     | SGX 3D Features .....                                        | 1971        |
| 8.1.3     | Universal Scalable Shader Engine (USSE) – Key Features ..... | 1972        |
| 8.2       | SGX Integration .....                                        | 1973        |
| 8.2.1     | Clocking, Reset, and Power-Management Scheme .....           | 1973        |
| 8.2.1.1   | Clocks .....                                                 | 1973        |
| 8.2.1.2   | Resets .....                                                 | 1974        |
| 8.2.1.3   | Power Management .....                                       | 1974        |
| 8.2.2     | Hardware Requests .....                                      | 1974        |
| 8.2.2.1   | Interrupt Request .....                                      | 1974        |
| 8.3       | SGX Functional Description .....                             | 1975        |
| 8.3.1     | SGX Block Diagram .....                                      | 1975        |
| 8.3.2     | SGX Elements Description .....                               | 1975        |
| 8.4       | SGX Register Manual .....                                    | 1977        |
| 8.4.1     | SGX Instance Summary .....                                   | 1977        |
| 8.4.2     | SGX OCP Registers .....                                      | 1977        |
| 8.4.2.1   | SGX OCP Register Summary .....                               | 1977        |
| 8.4.2.2   | SGX OCP Register Description .....                           | 1978        |
| <b>9</b>  | <b>Interconnect .....</b>                                    | <b>1993</b> |
| 9.1       | Interconnect Overview .....                                  | 1994        |
| 9.1.1     | Terminology .....                                            | 1994        |
| 9.1.2     | Architecture Overview .....                                  | 1996        |
| 9.1.3     | Module Distribution .....                                    | 1998        |
| 9.1.3.1   | L3 Interconnect Agents .....                                 | 1998        |
| 9.1.3.2   | L4-Core Agents .....                                         | 1999        |
| 9.1.3.3   | L4-Per Agents .....                                          | 2000        |
| 9.1.3.4   | L4-Emu Agents .....                                          | 2000        |
| 9.1.3.5   | L4-Wakeup Agents .....                                       | 2001        |
| 9.1.4     | Connectivity Matrix .....                                    | 2001        |
| 9.2       | L3 Interconnect .....                                        | 2003        |
| 9.2.1     | Overview .....                                               | 2003        |
| 9.2.2     | L3 Interconnect Integration .....                            | 2004        |
| 9.2.2.1   | Clocking, Reset, and Power-Management Scheme .....           | 2004        |
| 9.2.2.1.1 | Clocks .....                                                 | 2004        |
| 9.2.2.1.2 | Resets .....                                                 | 2004        |
| 9.2.2.1.3 | Power Domain .....                                           | 2004        |
| 9.2.2.1.4 | Power Management .....                                       | 2004        |
| 9.2.2.2   | Hardware Requests .....                                      | 2005        |
| 9.2.2.2.1 | Interrupt Requests .....                                     | 2005        |
| 9.2.3     | L3 Interconnect Functional Description .....                 | 2005        |

|           |                                                            |      |
|-----------|------------------------------------------------------------|------|
| 9.2.3.1   | Initiator Identification .....                             | 2005 |
| 9.2.3.2   | Register Target .....                                      | 2005 |
| 9.2.3.3   | L3 Protection and Firewalls .....                          | 2006 |
| 9.2.3.3.1 | Protection Region .....                                    | 2007 |
| 9.2.3.3.2 | Priority Level Overview .....                              | 2009 |
| 9.2.3.3.3 | Read and Write Permission .....                            | 2011 |
| 9.2.3.3.4 | REQ_INFO_PERMISSION Configuration .....                    | 2012 |
| 9.2.3.3.5 | L3 Firewall Registers Overview .....                       | 2013 |
| 9.2.3.3.6 | L3 Firewall Error-Logging Registers .....                  | 2014 |
| 9.2.3.3.7 | L3 Firewall and System Control Module .....                | 2014 |
| 9.2.3.4   | Error Handling .....                                       | 2015 |
| 9.2.3.4.1 | Error Detection and Logging .....                          | 2015 |
| 9.2.3.4.2 | Time-Out .....                                             | 2018 |
| 9.2.3.4.3 | Error Steering .....                                       | 2019 |
| 9.2.3.4.4 | Global Error Reporting .....                               | 2020 |
| 9.2.4     | L3 Interconnect Basic Programming Model .....              | 2024 |
| 9.2.4.1   | General Recommendation .....                               | 2024 |
| 9.2.4.2   | Initialization .....                                       | 2024 |
| 9.2.4.3   | Error Analysis .....                                       | 2025 |
| 9.2.4.3.1 | Time-Out Handling .....                                    | 2026 |
| 9.2.4.3.2 | Acknowledging Errors .....                                 | 2027 |
| 9.2.4.3.4 | Typical Example of Firewall Programming Example .....      | 2027 |
| 9.2.5     | L3 Interconnect Register Manual .....                      | 2031 |
| 9.2.5.1   | L3 Initiator Agent (L3 IA) .....                           | 2031 |
| 9.2.5.1.1 | L3 Initiator Agent (L3 IA) Registers Description .....     | 2033 |
| 9.2.5.2   | L3 Target Agent (L3 TA) .....                              | 2038 |
| 9.2.5.2.1 | L3 Target Agent (L3 TA) Registers Description .....        | 2039 |
| 9.2.5.3   | Register Target (RT) .....                                 | 2044 |
| 9.2.5.3.1 | Register Target (RT) Registers Description .....           | 2044 |
| 9.2.5.4   | Protection Mechanism (PM) .....                            | 2047 |
| 9.2.5.4.1 | Protection Mechanism (PM) Registers Description .....      | 2048 |
| 9.2.5.5   | Sideband Interconnect (SI) .....                           | 2056 |
| 9.2.5.5.1 | Sideband Interconnect (SI) Registers Description .....     | 2056 |
| 9.3       | L4 Interconnects .....                                     | 2059 |
| 9.3.1     | Overview .....                                             | 2059 |
| 9.3.1.1   | L4-Core Interconnect .....                                 | 2061 |
| 9.3.1.2   | L4-Per Interconnect .....                                  | 2061 |
| 9.3.1.3   | L4-Emu Interconnect .....                                  | 2062 |
| 9.3.1.4   | L4-Wakeup Interconnect .....                               | 2063 |
| 9.3.2     | L4 Interconnects Integration .....                         | 2064 |
| 9.3.2.1   | Clocking, Reset, and Power-Management Scheme .....         | 2064 |
| 9.3.2.1.1 | Clocks .....                                               | 2064 |
| 9.3.2.1.2 | Resets .....                                               | 2064 |
| 9.3.2.1.3 | Power Domain .....                                         | 2064 |
| 9.3.2.1.4 | Power Management .....                                     | 2065 |
| 9.3.3     | L4 Interconnects Functional Description .....              | 2065 |
| 9.3.3.1   | L4-Interconnects Initiator Identification .....            | 2065 |
| 9.3.3.2   | Endianness Management .....                                | 2065 |
| 9.3.3.3   | L4 Protection and Firewalls .....                          | 2065 |
| 9.3.3.3.1 | Protection Mechanism .....                                 | 2065 |
| 9.3.3.3.2 | Protection Group .....                                     | 2066 |
| 9.3.3.3.3 | Segments and Regions .....                                 | 2067 |
| 9.3.3.3.4 | L4 Firewall Address and Protection Registers Setting ..... | 2073 |

---

|            |                                                                                        |             |
|------------|----------------------------------------------------------------------------------------|-------------|
| 9.3.3.4    | Error Handling .....                                                                   | 2074        |
| 9.3.3.4.1  | Overview .....                                                                         | 2074        |
| 9.3.3.4.2  | Error Logging .....                                                                    | 2074        |
| 9.3.3.4.3  | TA Software Reset .....                                                                | 2076        |
| 9.3.3.4.4  | Error Reporting .....                                                                  | 2076        |
| 9.3.4      | L4 Interconnect Programming Guide .....                                                | 2077        |
| 9.3.4.1    | L4 Interconnect Low-Level Programming Models .....                                     | 2077        |
| 9.3.4.1.1  | Global Initialization .....                                                            | 2077        |
| 9.3.4.1.2  | Operational Modes Configuration .....                                                  | 2078        |
| 9.3.5      | L4 Interconnects Register Manual .....                                                 | 2082        |
| 9.3.5.1    | L4 Initiator Agent (L4 IA) .....                                                       | 2084        |
| 9.3.5.1.1  | L4 Initiator Agent (L4 IA) Registers Description .....                                 | 2085        |
| 9.3.5.2    | L4 Target Agent (L4 TA) .....                                                          | 2090        |
| 9.3.5.2.1  | L4 Target Agent (L4 TA) Registers Description .....                                    | 2097        |
| 9.3.5.3    | L4 Link Register Agent (LA) .....                                                      | 2101        |
| 9.3.5.3.1  | L4 Link Register Agent (LA) Registers Description .....                                | 2102        |
| 9.3.5.4    | L4 Address Protection (AP) .....                                                       | 2106        |
| 9.3.5.4.1  | L4 Address Protection (AP) Registers Description .....                                 | 2107        |
| <b>10</b>  | <b>Memory Subsystem .....</b>                                                          | <b>2119</b> |
| 10.1       | General-Purpose Memory Controller .....                                                | 2120        |
| 10.1.1     | General-Purpose Memory Controller Overview .....                                       | 2120        |
| 10.1.1.1   | GPMC Features .....                                                                    | 2120        |
| 10.1.2     | GPMC Environment .....                                                                 | 2121        |
| 10.1.3     | GPMC Integration .....                                                                 | 2124        |
| 10.1.3.1   | Description .....                                                                      | 2124        |
| 10.1.3.2   | Clocking, Reset, and Power-Management Scheme .....                                     | 2125        |
| 10.1.3.2.1 | Clocking .....                                                                         | 2125        |
| 10.1.3.2.2 | Hardware Reset .....                                                                   | 2125        |
| 10.1.3.2.3 | Software Reset .....                                                                   | 2125        |
| 10.1.3.2.4 | Power Domain, Power Saving, and Reset Management .....                                 | 2125        |
| 10.1.3.2.5 | Hardware Requests .....                                                                | 2125        |
| 10.1.3.3   | GPMC Address and Data Bus .....                                                        | 2126        |
| 10.1.3.3.1 | GPMC I/O Configuration Setting (in Default Pinout Mode 0) .....                        | 2126        |
| 10.1.3.3.2 | GPMC CS0 Default Configuration at IC Reset .....                                       | 2127        |
| 10.1.4     | GPMC Functional Description .....                                                      | 2127        |
| 10.1.4.1   | Description .....                                                                      | 2127        |
| 10.1.4.2   | L3 Interconnect Interface .....                                                        | 2128        |
| 10.1.4.3   | Address Decoder, GPMC Configuration, and Chip-Select Configuration Register File ..... | 2129        |
| 10.1.4.4   | Error Correction Code Engine .....                                                     | 2129        |
| 10.1.4.5   | Prefetch and Write-Posting Engine .....                                                | 2130        |
| 10.1.4.6   | External Device/Memory Port Interface .....                                            | 2130        |
| 10.1.5     | GPMC Basic Programming Model .....                                                     | 2130        |
| 10.1.5.1   | Chip-Select Base Address and Region Size Configuration .....                           | 2130        |
| 10.1.5.2   | Access Protocol Configuration .....                                                    | 2132        |
| 10.1.5.2.1 | Supported Devices .....                                                                | 2132        |
| 10.1.5.2.2 | Access Size Adaptation and Device Width .....                                          | 2132        |
| 10.1.5.2.3 | Address/Data-Multiplexing Interface .....                                              | 2132        |
| 10.1.5.2.4 | Address and Data Bus .....                                                             | 2132        |
| 10.1.5.2.5 | Asynchronous and Synchronous Access .....                                              | 2132        |
| 10.1.5.2.6 | Page and Burst Support .....                                                           | 2133        |
| 10.1.5.2.7 | System Burst Versus External Device Burst Support .....                                | 2133        |
| 10.1.5.3   | Timing Setting .....                                                                   | 2134        |
| 10.1.5.3.1 | Read Cycle Time and Write Cycle Time (RDCYCLETIME/WRCYCLETIME) .....                   | 2135        |

|             |                                                                                                                                                   |      |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 10.1.5.3.2  | nCS: Chip-Select Signal Control Assertion/Deassertion Time (CSONTIME/CSRDOFFTIME/CSWROFFTIME/CSEXTRADELAY) .....                                  | 2136 |
| 10.1.5.3.3  | nADV/ALE: Address Valid/Address Latch Enable Signal Control Assertion/Deassertion Time (ADVONTIME/ADVRDOFFTIME/ADVWRROFFTIME/ADVEXTRADELAY) ..... | 2136 |
| 10.1.5.3.4  | nOE/nRE: Output Enable/Read Enable Signal Control Assertion/Deassertion Time (OEONTIME/OEOFETIME/OEEXTRADELAY) .....                              | 2137 |
| 10.1.5.3.5  | nWE: Write Enable Signal Control Assertion/Deassertion Time (WEONTIME/WEOFETIME/WEEXTRADELAY) .....                                               | 2137 |
| 10.1.5.3.6  | GPMC_CLK .....                                                                                                                                    | 2138 |
| 10.1.5.3.7  | GPMC_CLK and Control Signals Setup and Hold .....                                                                                                 | 2138 |
| 10.1.5.3.8  | Access Time (RDACCESSTIME / WRACCESSTIME) .....                                                                                                   | 2138 |
| 10.1.5.3.9  | Page Burst Access Time (PAGEBURSTACCESSTIME) .....                                                                                                | 2139 |
| 10.1.5.3.10 | Bus Keeping Support .....                                                                                                                         | 2140 |
| 10.1.5.4    | WAIT Pin Monitoring Control .....                                                                                                                 | 2140 |
| 10.1.5.4.1  | Wait Monitoring During an Asynchronous Read Access .....                                                                                          | 2140 |
| 10.1.5.4.2  | Wait Monitoring During an Asynchronous Write Access .....                                                                                         | 2142 |
| 10.1.5.4.3  | Wait Monitoring During a Synchronous Read Access .....                                                                                            | 2142 |
| 10.1.5.4.4  | Wait Monitoring During a Synchronous Write Access .....                                                                                           | 2143 |
| 10.1.5.4.5  | WAIT With NAND Device .....                                                                                                                       | 2144 |
| 10.1.5.4.6  | Idle Cycle Control Between Successive Accesses .....                                                                                              | 2144 |
| 10.1.5.4.7  | Slow Device Support (TIMEPARAGRANULARITY Parameter) .....                                                                                         | 2146 |
| 10.1.5.5    | gpmc_io_dir Pin .....                                                                                                                             | 2146 |
| 10.1.5.6    | Reset .....                                                                                                                                       | 2146 |
| 10.1.5.7    | WRITE PROTECT (nWP) .....                                                                                                                         | 2147 |
| 10.1.5.8    | BYTE ENABLE (nBE1/nBE0) .....                                                                                                                     | 2147 |
| 10.1.5.9    | Asynchronous Access Description .....                                                                                                             | 2147 |
| 10.1.5.9.1  | Asynchronous Single Read .....                                                                                                                    | 2147 |
| 10.1.5.9.2  | Asynchronous Single Write .....                                                                                                                   | 2150 |
| 10.1.5.9.3  | Asynchronous Multiple (Page Mode) Read .....                                                                                                      | 2152 |
| 10.1.5.10   | Synchronous Access .....                                                                                                                          | 2153 |
| 10.1.5.10.1 | Synchronous Single Read .....                                                                                                                     | 2154 |
| 10.1.5.10.2 | Synchronous Single Write .....                                                                                                                    | 2156 |
| 10.1.5.10.3 | Synchronous Multiple (Burst) Read (4-, 8-, 16-Word16 Burst With Wraparound Capability) .....                                                      | 2157 |
| 10.1.5.10.4 | Synchronous Multiple (Burst) Write .....                                                                                                          | 2159 |
| 10.1.5.11   | pSRAM Basic Programming Model .....                                                                                                               | 2162 |
| 10.1.5.12   | Error Handling .....                                                                                                                              | 2163 |
| 10.1.5.13   | Boot Configuration .....                                                                                                                          | 2163 |
| 10.1.5.14   | NAND Device Basic Programming Model .....                                                                                                         | 2163 |
| 10.1.5.14.1 | NAND Memory Device in Byte or Word16 Stream Mode .....                                                                                            | 2163 |
| 10.1.5.14.2 | NAND Device-Ready Pin .....                                                                                                                       | 2169 |
| 10.1.5.14.3 | ECC Calculator .....                                                                                                                              | 2170 |
| 10.1.5.14.4 | Prefetch and Write-Posting Engine .....                                                                                                           | 2186 |
| 10.1.6      | GPMC Use Cases and Tips .....                                                                                                                     | 2193 |
| 10.1.6.1    | How to Set GPMC Timing Parameters for Typical Accesses .....                                                                                      | 2193 |
| 10.1.6.1.1  | External Memory Attached to the GPMC Module .....                                                                                                 | 2193 |
| 10.1.6.1.2  | Typical GPMC Setup .....                                                                                                                          | 2193 |
| 10.1.6.2    | How to Choose a Suitable Memory to Use With the GPMC .....                                                                                        | 2199 |
| 10.1.6.2.1  | Supported Memories or Devices .....                                                                                                               | 2199 |
| 10.1.6.2.2  | GPMC Features and Settings .....                                                                                                                  | 2201 |
| 10.1.7      | GPMC Register Manual .....                                                                                                                        | 2202 |
| 10.1.7.1    | GPMC Instance Summary .....                                                                                                                       | 2202 |
| 10.1.7.2    | GPMC Register Summary .....                                                                                                                       | 2202 |
| 10.1.7.3    | GPMC Register Description .....                                                                                                                   | 2203 |

---

|             |                                                    |      |
|-------------|----------------------------------------------------|------|
| 10.2        | SDRAM Controller (SDRC) Subsystem .....            | 2230 |
| 10.2.1      | SDRC Subsystem Overview .....                      | 2230 |
| 10.2.1.1    | Features .....                                     | 2231 |
| 10.2.2      | SDRC Subsystem Environment .....                   | 2233 |
| 10.2.2.1    | SDRC Subsystem Description .....                   | 2233 |
| 10.2.2.2    | External Interface Configuration .....             | 2235 |
| 10.2.2.2.1  | CS0, CS1 Memory Spaces .....                       | 2235 |
| 10.2.2.2.2  | AC Timing Control .....                            | 2235 |
| 10.2.2.2.3  | Address Multiplexing .....                         | 2235 |
| 10.2.3      | SDRC Subsystem Integration .....                   | 2240 |
| 10.2.3.1    | Clocking, Reset, and Power Management Scheme ..... | 2241 |
| 10.2.3.1.1  | Clocking .....                                     | 2241 |
| 10.2.3.1.2  | Hardware Reset .....                               | 2242 |
| 10.2.3.1.3  | Software Reset .....                               | 2242 |
| 10.2.3.1.4  | Power Management .....                             | 2242 |
| 10.2.4      | SDRC Subsystem Functional Description .....        | 2243 |
| 10.2.4.1    | SDRAM Memory Scheduler .....                       | 2243 |
| 10.2.4.1.1  | Memory Access Scheduling .....                     | 2245 |
| 10.2.4.1.2  | Arbitration Policy .....                           | 2245 |
| 10.2.4.1.3  | Internal Class Arbitration .....                   | 2247 |
| 10.2.4.1.4  | Firewalls .....                                    | 2248 |
| 10.2.4.1.5  | Rotation Engine .....                              | 2251 |
| 10.2.4.1.6  | Violation Reporting .....                          | 2252 |
| 10.2.4.2    | Module Power Saving .....                          | 2253 |
| 10.2.4.3    | System Power Management .....                      | 2253 |
| 10.2.4.4    | SDRC .....                                         | 2253 |
| 10.2.4.4.1  | CS0-CS1 Memory Spaces .....                        | 2254 |
| 10.2.4.4.2  | Bank Tracking .....                                | 2255 |
| 10.2.4.4.3  | Address Multiplexing .....                         | 2256 |
| 10.2.4.4.4  | Bank Allocation Setting .....                      | 2256 |
| 10.2.4.4.5  | Data Multiplexing During Write Operations .....    | 2260 |
| 10.2.4.4.6  | Data Demultiplexing During Read Operations .....   | 2261 |
| 10.2.4.4.7  | Refresh Management .....                           | 2263 |
| 10.2.4.4.8  | System Power Management .....                      | 2263 |
| 10.2.4.4.9  | Power-Saving Features .....                        | 2264 |
| 10.2.4.4.10 | SDRC Power-Down Mode .....                         | 2266 |
| 10.2.4.4.11 | Controlled Delay Line .....                        | 2267 |
| 10.2.4.5    | Mode Registers .....                               | 2270 |
| 10.2.4.5.1  | Mode Register (MR) .....                           | 2270 |
| 10.2.4.5.2  | Extended Mode Register 2 (EMR2) .....              | 2270 |
| 10.2.5      | SDRC Subsystem Basic Programming Model .....       | 2271 |
| 10.2.5.1    | SMS Basic Programming Model .....                  | 2271 |
| 10.2.5.1.1  | SMS Firewall Usage .....                           | 2271 |
| 10.2.5.1.2  | VRFB Context Configuration .....                   | 2271 |
| 10.2.5.1.3  | Memory-Access Scheduler Configuration .....        | 2273 |
| 10.2.5.1.4  | Error Logging .....                                | 2273 |
| 10.2.5.2    | SDRC Configuration .....                           | 2274 |
| 10.2.5.2.1  | IP Revision .....                                  | 2274 |
| 10.2.5.2.2  | Reset Behavior .....                               | 2274 |
| 10.2.5.3    | SDRC Setup .....                                   | 2274 |
| 10.2.5.3.1  | Chip-Select Configuration .....                    | 2275 |
| 10.2.5.3.2  | Memory Configuration .....                         | 2275 |
| 10.2.5.3.3  | SDRAM AC Timing Parameters .....                   | 2275 |

|      |                                                                   |             |
|------|-------------------------------------------------------------------|-------------|
|      | 10.2.5.3.4 DLL/CDL Configuration .....                            | 2276        |
|      | 10.2.5.3.5 Mode Register Programming and Modes of Operation ..... | 2277        |
|      | 10.2.5.3.6 Autorefresh Management .....                           | 2278        |
|      | 10.2.5.3.7 Page Closure Strategy .....                            | 2279        |
|      | 10.2.5.4 Manual Software Commands .....                           | 2279        |
|      | 10.2.5.4.1 Low-Power SDR/Mobile DDR Initialization Sequence ..... | 2280        |
|      | 10.2.5.4.2 Read/Write Access .....                                | 2281        |
|      | 10.2.5.4.3 Memory Power Management .....                          | 2281        |
|      | 10.2.5.5 Error Management .....                                   | 2283        |
|      | 10.2.6 SDRC Use Cases and Tips .....                              | 2284        |
|      | 10.2.6.1 How to Program the VRFB .....                            | 2284        |
|      | 10.2.6.1.1 VRFB Rotation Mechanism .....                          | 2284        |
|      | 10.2.6.1.2 Setting a VRFB Context .....                           | 2286        |
|      | 10.2.6.1.3 Applicative Use Case and Tips .....                    | 2289        |
|      | 10.2.6.2 SMS Mode of Operation .....                              | 2292        |
|      | 10.2.6.2.1 SDRAM Memory Scheduler and Arbitration Policy .....    | 2292        |
|      | 10.2.6.2.2 Arbitration Decision .....                             | 2293        |
|      | 10.2.6.2.3 Arbitration Granularity .....                          | 2295        |
|      | 10.2.6.2.4 How these Mechanisms Interact .....                    | 2297        |
|      | 10.2.6.3 Understanding SDRAM Subsystem Address Spaces .....       | 2302        |
|      | 10.2.6.3.1 Physical vs Virtual Address Spaces .....               | 2302        |
|      | 10.2.6.3.2 CS Memory Spaces .....                                 | 2303        |
|      | 10.2.6.4 How to Choose a Suitable SDRAM .....                     | 2305        |
|      | 10.2.6.4.1 SDRAM Device Parameters .....                          | 2305        |
|      | 10.2.6.4.2 SDRC Characteristics .....                             | 2306        |
|      | 10.2.6.4.3 SDRAM Device Compatibility Verification .....          | 2306        |
|      | 10.2.7 SMS Register Manual .....                                  | 2308        |
|      | 10.2.7.1 SMS Instance Summary .....                               | 2308        |
|      | 10.2.7.2 SMS Register Summary .....                               | 2308        |
|      | 10.2.7.3 SMS Register Description .....                           | 2308        |
|      | 10.2.8 SDRC Register Manual .....                                 | 2321        |
|      | 10.2.8.1 SDRC Instance Summary .....                              | 2321        |
|      | 10.2.8.2 SDRC Register Summary .....                              | 2321        |
|      | 10.2.8.3 SDRC Register Description .....                          | 2321        |
| 10.3 | On-Chip Memory Subsystem .....                                    | 2339        |
|      | 10.3.1 OCM Subsystem Overview .....                               | 2339        |
|      | 10.3.2 OCM Subsystem Integration .....                            | 2340        |
|      | 10.3.2.1 Description .....                                        | 2340        |
|      | 10.3.2.2 Clocking, Reset, and Power-Management Scheme .....       | 2340        |
|      | 10.3.2.2.1 Clocking .....                                         | 2340        |
|      | 10.3.2.2.2 Hardware Reset .....                                   | 2341        |
|      | 10.3.2.2.3 Power Domain .....                                     | 2341        |
|      | 10.3.3 OCM Subsystem Functional Description .....                 | 2341        |
|      | 10.3.3.1 OCM_ROM .....                                            | 2341        |
|      | 10.3.3.2 OCM_RAM .....                                            | 2341        |
| 11   | <b>SDMA .....</b>                                                 | <b>2343</b> |
|      | 11.1 SDMA Overview .....                                          | 2344        |
|      | 11.2 SDMA Environment .....                                       | 2346        |
|      | 11.2.1 External SDMA Request Signals .....                        | 2346        |
|      | 11.2.2 External SDMA Requests Typical Application .....           | 2346        |
|      | 11.2.3 SDMA Request Scheme .....                                  | 2347        |
|      | 11.3 SDMA Integration .....                                       | 2348        |
|      | 11.3.1 Clocking, Reset, and Power-Management Scheme .....         | 2349        |

---

|             |                                                        |      |
|-------------|--------------------------------------------------------|------|
| 11.3.1.1    | Power Domain .....                                     | 2349 |
| 11.3.1.2    | Clocking .....                                         | 2349 |
| 11.3.1.3    | Hardware Reset .....                                   | 2349 |
| 11.3.1.4    | Power Management .....                                 | 2350 |
| 11.3.1.4.1  | Internal Clock Gating (Auto-Idle) .....                | 2350 |
| 11.3.1.4.2  | Automatic Standby Mode .....                           | 2350 |
| 11.3.1.4.3  | Idle Mode .....                                        | 2350 |
| 11.3.2      | Hardware Requests .....                                | 2351 |
| 11.3.2.1    | SDMA Interrupts .....                                  | 2351 |
| 11.3.2.2    | DMA Requests to the SDMA Controller .....              | 2351 |
| 11.4        | SDMA Functional Description .....                      | 2354 |
| 11.4.1      | Logical Channel Transfer Overview .....                | 2354 |
| 11.4.2      | FIFO Queue Memory Pool .....                           | 2356 |
| 11.4.3      | Addressing Modes .....                                 | 2356 |
| 11.4.4      | Packed Accesses .....                                  | 2360 |
| 11.4.5      | Burst Transactions .....                               | 2361 |
| 11.4.6      | Endianism Conversion .....                             | 2361 |
| 11.4.7      | Transfer Synchronization .....                         | 2361 |
| 11.4.7.1    | Software Synchronization .....                         | 2361 |
| 11.4.7.2    | Hardware Synchronization .....                         | 2361 |
| 11.4.8      | Thread Budget Allocation .....                         | 2364 |
| 11.4.9      | FIFO Budget Allocation .....                           | 2364 |
| 11.4.10     | Chained Logical Channel Transfers .....                | 2365 |
| 11.4.11     | Reprogramming an Active Channel .....                  | 2365 |
| 11.4.12     | Interrupt Generation .....                             | 2366 |
| 11.4.13     | Packet Synchronization .....                           | 2366 |
| 11.4.14     | Graphics Acceleration Support .....                    | 2367 |
| 11.4.15     | Supervisor Modes .....                                 | 2368 |
| 11.4.16     | Posted and Nonposted Writes .....                      | 2368 |
| 11.4.17     | Disabling a Channel During Transfer .....              | 2368 |
| 11.4.18     | FIFO Draining Mechanism .....                          | 2368 |
| 11.4.19     | Linked List .....                                      | 2369 |
| 11.4.19.1   | Overview .....                                         | 2369 |
| 11.4.19.2   | Link-List Transfer Profile .....                       | 2369 |
| 11.4.19.3   | Descriptors .....                                      | 2370 |
| 11.4.19.3.1 | Type 1 .....                                           | 2371 |
| 11.4.19.3.2 | Type 2 .....                                           | 2371 |
| 11.4.19.3.3 | Type 3 .....                                           | 2372 |
| 11.4.19.4   | Linked-List Control and Monitoring .....               | 2373 |
| 11.4.19.4.1 | Transfer Mode Setting .....                            | 2373 |
| 11.4.19.4.2 | Starting a Linked List .....                           | 2373 |
| 11.4.19.4.3 | Monitoring a Linked-List Progression .....             | 2373 |
| 11.4.19.4.4 | Interrupt During Linked-List Execution .....           | 2373 |
| 11.4.19.4.5 | Pause a Linked List .....                              | 2374 |
| 11.4.19.4.6 | Stop a Linked List (Abort or Drain) .....              | 2375 |
| 11.4.19.4.7 | Status Bit Behavior .....                              | 2375 |
| 11.4.19.4.8 | Linked-List Channel Linking .....                      | 2376 |
| 11.5        | SDMA Basic Programming Model .....                     | 2377 |
| 11.5.1      | Setup Configuration .....                              | 2377 |
| 11.5.2      | Software-Triggered (Nonsynchronized) Transfer .....    | 2377 |
| 11.5.3      | Hardware-Synchronized Transfer .....                   | 2378 |
| 11.5.4      | Synchronized Transfer Monitoring Using CDAC .....      | 2380 |
| 11.5.5      | Concurrent Software and Hardware Synchronization ..... | 2380 |

|            |                                                    |             |
|------------|----------------------------------------------------|-------------|
| 11.5.6     | Chained Transfer .....                             | 2380        |
| 11.5.7     | 90-Degree Clockwise Image Rotation .....           | 2381        |
| 11.5.8     | Graphic Operations .....                           | 2382        |
| 11.6       | SDMA Register Manual .....                         | 2383        |
| 11.6.1     | SDMA Instance Summary .....                        | 2383        |
| 11.6.2     | SDMA Register Summary .....                        | 2383        |
| 11.6.3     | SDMA Register Description .....                    | 2384        |
| 12         | <b>Interrupt Controller .....</b>                  | <b>2413</b> |
| 12.1       | Interrupt Controller Overview .....                | 2414        |
| 12.2       | Interrupt Controller Environment .....             | 2416        |
| 12.3       | MPU Subsystem INTCPS Integration .....             | 2417        |
| 12.3.1     | Clocking, Reset, and Power Management Scheme ..... | 2417        |
| 12.3.1.1   | MPU Subsystem INTC Clocks .....                    | 2417        |
| 12.3.1.2   | Hardware and Software Reset .....                  | 2418        |
| 12.3.1.3   | Power Management .....                             | 2418        |
| 12.3.2     | Interrupt Request Lines .....                      | 2418        |
| 12.4       | Interrupt Controller Functional Description .....  | 2421        |
| 12.4.1     | Interrupt Processing .....                         | 2423        |
| 12.4.1.1   | Input Selection .....                              | 2423        |
| 12.4.1.2   | Masking .....                                      | 2423        |
| 12.4.1.2.1 | Individual Masking .....                           | 2423        |
| 12.4.1.2.2 | Priority Masking .....                             | 2423        |
| 12.4.1.3   | Priority Sorting .....                             | 2423        |
| 12.4.2     | Register Protection .....                          | 2424        |
| 12.4.3     | Module Power Saving .....                          | 2424        |
| 12.4.4     | Interrupt Latency .....                            | 2424        |
| 12.5       | Interrupt Controller Basic Programming Model ..... | 2425        |
| 12.5.1     | Initialization Sequence .....                      | 2425        |
| 12.5.2     | MPU INTC Processing Sequence .....                 | 2425        |
| 12.5.3     | MPU INTC Preemptive Processing Sequence .....      | 2429        |
| 12.5.4     | MPU INTC Spurious Interrupt Handling .....         | 2432        |
| 12.6       | Interrupt Controller Register Manual .....         | 2433        |
| 12.6.1     | Instance Summary .....                             | 2433        |
| 12.6.2     | Register Summary .....                             | 2433        |
| 12.6.3     | MPU INTC Register Descriptions .....               | 2434        |
| 12.6.4     | Modem INTC Register Descriptions .....             | 2445        |
| 13         | <b>System Control Module .....</b>                 | <b>2447</b> |
| 13.1       | SCM Overview .....                                 | 2448        |
| 13.2       | SCM Environment .....                              | 2449        |
| 13.2.1     | Functional Interfaces .....                        | 2450        |
| 13.2.1.1   | Basic SCM Pins .....                               | 2450        |
| 13.2.1.2   | SCM Interface Description .....                    | 2450        |
| 13.3       | SCM Integration .....                              | 2450        |
| 13.3.1     | Clocking, Reset, and Power-Management Scheme ..... | 2452        |
| 13.3.1.1   | Clock .....                                        | 2452        |
| 13.3.1.2   | Resets .....                                       | 2452        |
| 13.3.1.3   | Power Domain .....                                 | 2452        |
| 13.3.1.4   | Power Management .....                             | 2453        |
| 13.3.1.4.1 | System Power Management .....                      | 2453        |
| 13.3.1.4.2 | Module Power Saving .....                          | 2453        |
| 13.3.2     | Hardware Requests .....                            | 2454        |
| 13.4       | SCM Functional Description .....                   | 2454        |
| 13.4.1     | Block Diagram .....                                | 2454        |

---

|             |                                                                              |      |
|-------------|------------------------------------------------------------------------------|------|
| 13.4.2      | SCM Initialization .....                                                     | 2456 |
| 13.4.3      | Wake-Up Control Module .....                                                 | 2456 |
| 13.4.4      | Pad Functional Multiplexing and Configuration .....                          | 2456 |
| 13.4.4.1    | Mode Selection .....                                                         | 2458 |
| 13.4.4.2    | Pull Selection .....                                                         | 2459 |
| 13.4.4.3    | Pad Multiplexing Register Fields .....                                       | 2459 |
| 13.4.4.4    | System Off Mode .....                                                        | 2476 |
| 13.4.4.4.1  | Save-and-Restore Mechanism .....                                             | 2476 |
| 13.4.4.4.2  | Wake-Up Event Detection .....                                                | 2477 |
| 13.4.5      | Extended-Drain I/O Pin and PBIAS Cells .....                                 | 2479 |
| 13.4.5.1    | PBIAS Cells .....                                                            | 2480 |
| 13.4.5.2    | Extended-Drain I/Os .....                                                    | 2481 |
| 13.4.6      | Band Gap Voltage and Temperature Sensor .....                                | 2483 |
| 13.4.6.1    | Band Gap Voltage Reference .....                                             | 2484 |
| 13.4.6.2    | Temperature Sensor .....                                                     | 2485 |
| 13.4.6.2.1  | Single Conversion Mode (CONTCONV = 0) .....                                  | 2485 |
| 13.4.6.2.2  | Continuous Conversion Mode (CONTCONV = 1) .....                              | 2485 |
| 13.4.6.2.3  | ADC Codes Versus Temperature .....                                           | 2486 |
| 13.4.7      | Functional Register Description .....                                        | 2487 |
| 13.4.7.1    | Static Device Configuration Registers .....                                  | 2487 |
| 13.4.7.2    | MPU and/or DSP (IVA2.2) MSuspend Configuration Registers .....               | 2487 |
| 13.4.7.3    | IVA2.2 Boot Registers .....                                                  | 2488 |
| 13.4.7.4    | PBIAS LITE Control Register .....                                            | 2488 |
| 13.4.7.5    | Temperature Sensor Control Register .....                                    | 2489 |
| 13.4.7.6    | Signal Integrity Parameter Control Registers With Pad Group Assignment ..... | 2489 |
| 13.4.7.6.1  | Signal Integrity Parameter Controls Overview .....                           | 2489 |
| 13.4.7.6.2  | DDR Buffer Drive Strength Related Settings .....                             | 2489 |
| 13.4.7.6.3  | High Speed I/Os Far End Load Settings .....                                  | 2489 |
| 13.4.7.6.4  | Low-Speed I/Os Combined Slew Rate vs TL Length and Load Settings .....       | 2490 |
| 13.4.7.6.5  | SDMMC Pullup Strength Control .....                                          | 2490 |
| 13.4.7.6.6  | I2Cx I/Os Group Pullupresx Controls and Load Range Settings .....            | 2491 |
| 13.4.7.6.7  | Device Interfaces Signal Group Controls Mapping .....                        | 2491 |
| 13.4.8      | Protection Status Registers .....                                            | 2497 |
| 13.4.9      | SDRC Registers .....                                                         | 2498 |
| 13.4.10     | Debug and Observability .....                                                | 2498 |
| 13.4.10.1   | Description .....                                                            | 2498 |
| 13.4.10.2   | Observability Tables .....                                                   | 2501 |
| 13.4.11     | EMI Reduction for Clocking Generation (Spreading) .....                      | 2535 |
| 13.4.11.1   | Overview .....                                                               | 2535 |
| 13.4.11.2   | Integration .....                                                            | 2536 |
| 13.4.11.2.1 | Clocking, Reset, and Power-Management Scheme .....                           | 2537 |
| 13.4.11.3   | Functional Description .....                                                 | 2537 |
| 13.4.11.3.1 | Spreading Generation Block .....                                             | 2537 |
| 13.4.11.3.2 | SSC .....                                                                    | 2538 |
| 13.4.11.3.3 | SSC Generation Control In The Device .....                                   | 2540 |
| 13.4.11.4   | Basic Programming Model .....                                                | 2542 |
| 13.4.11.4.1 | SSC Configuration .....                                                      | 2542 |
| 13.5        | SCM Programming Model .....                                                  | 2543 |
| 13.5.1      | Feature Settings .....                                                       | 2543 |
| 13.5.1.1    | Force Pad Configuration MuxMode by High-Speed USB .....                      | 2543 |
| 13.5.1.2    | Video Driver .....                                                           | 2543 |
| 13.5.1.3    | McBSP1 Internal Clock .....                                                  | 2543 |
| 13.5.1.4    | McBSP2 Internal Clock .....                                                  | 2544 |

|            |                                                             |             |
|------------|-------------------------------------------------------------|-------------|
| 13.5.1.5   | McBSP3 Internal Clock .....                                 | 2544        |
| 13.5.1.6   | McBSP4 Internal Clock .....                                 | 2544        |
| 13.5.1.7   | McBSP5 Internal Clock .....                                 | 2544        |
| 13.5.1.8   | MMC/SD/SDIO2 Module Input Clock Selection .....             | 2544        |
| 13.5.1.9   | Setting Sensitivity on sys_ndmareq[3:0] Input Pins .....    | 2545        |
| 13.5.1.10  | I <sup>2</sup> C I/O Internal Pullup Enable .....           | 2545        |
| 13.5.1.11  | SDRC I/O Drive Strength Selection .....                     | 2545        |
| 13.5.1.12  | GPMC I/O Far End Load Settings .....                        | 2546        |
| 13.5.1.13  | MCBSP2 I/O Far End Load Settings .....                      | 2548        |
| 13.5.1.14  | MCSPI1 I/O Far End Load Settings .....                      | 2548        |
| 13.5.1.15  | Force MPU Writes to Be Nonposted .....                      | 2549        |
| 13.5.2     | Extended-Drain I/Os and PBIAS Cells Programming Guide ..... | 2549        |
| 13.5.2.1   | PBIAS Error Generation .....                                | 2552        |
| 13.5.2.2   | Critical Timing Requirements .....                          | 2552        |
| 13.5.2.3   | Speed Control and Voltage Supply State .....                | 2552        |
| 13.5.3     | Off Mode Preliminary Settings .....                         | 2553        |
| 13.5.4     | Pad Configuration Programming Points .....                  | 2553        |
| 13.5.5     | I/O Power Optimization Guidelines .....                     | 2555        |
| 13.6       | SCM Register Manual .....                                   | 2559        |
| 13.6.1     | SCM Instance Summary .....                                  | 2559        |
| 13.6.2     | SCM Register Summary .....                                  | 2559        |
| 13.6.3     | SCM Register Description .....                              | 2567        |
| 13.6.3.1   | INTERFACE Register Description .....                        | 2567        |
| 13.6.3.2   | PADCONFS Register Description .....                         | 2568        |
| 13.6.3.3   | GENERAL Register Description .....                          | 2582        |
| 13.6.3.4   | MEM_WKUP Register Description .....                         | 2646        |
| 13.6.3.5   | PADCONFS_WKUP Register Description .....                    | 2646        |
| 13.6.3.6   | GENERAL_WKUP Register Description .....                     | 2648        |
| <b>14</b>  | <b>Interprocessor Communication .....</b>                   | <b>2659</b> |
| 14.1       | IPC Overview .....                                          | 2660        |
| 14.2       | IPC Integration .....                                       | 2660        |
| 14.2.1     | Clocking, Reset, and Power-Management Scheme .....          | 2661        |
| 14.2.1.1   | Clocks .....                                                | 2661        |
| 14.2.1.1.1 | Module Clocks .....                                         | 2661        |
| 14.2.1.2   | Resets .....                                                | 2661        |
| 14.2.1.2.1 | Hardware Reset .....                                        | 2661        |
| 14.2.1.2.2 | Software Reset .....                                        | 2661        |
| 14.2.1.3   | Power Domains .....                                         | 2661        |
| 14.2.1.4   | Power Management .....                                      | 2662        |
| 14.2.1.4.1 | System Power Management .....                               | 2662        |
| 14.2.1.4.2 | Module Power Management .....                               | 2662        |
| 14.2.2     | Hardware Requests .....                                     | 2663        |
| 14.2.2.1   | Interrupt Requests .....                                    | 2663        |
| 14.2.2.2   | Idle Handshake Protocol .....                               | 2663        |
| 14.3       | IPC Mailbox Functional Description .....                    | 2664        |
| 14.3.1     | Block Diagram .....                                         | 2664        |
| 14.3.2     | Mailbox Assignment .....                                    | 2665        |
| 14.3.2.1   | Description .....                                           | 2665        |
| 14.3.3     | Sending and Receiving Messages .....                        | 2665        |
| 14.3.3.1   | Description .....                                           | 2665        |
| 14.3.4     | 16-Bit Register Access .....                                | 2666        |
| 14.3.4.1   | Description .....                                           | 2666        |
| 14.4       | IPC Mailbox Basic Programming Model .....                   | 2667        |

---

|            |                                                                            |             |
|------------|----------------------------------------------------------------------------|-------------|
| 14.4.1     | Initialization Flow for the Mailbox Module .....                           | 2667        |
| 14.4.1.1   | Software Reset .....                                                       | 2667        |
| 14.4.1.2   | Idle Mode and Clock Configuration .....                                    | 2667        |
| 14.4.2     | Mailbox Assignment .....                                                   | 2667        |
| 14.4.3     | Mailbox Communication Preparation .....                                    | 2667        |
| 14.4.4     | Mailbox Communication Sequence .....                                       | 2668        |
| 14.4.5     | Example of Communication .....                                             | 2668        |
| 14.4.5.1   | Sending a Message (Polling Method) .....                                   | 2669        |
| 14.4.5.2   | Sending a Message (Interrupt Method) .....                                 | 2669        |
| 14.4.5.3   | Receiving Messages (Interrupt Method) .....                                | 2670        |
| 14.5       | IPC Mailbox Register Manual .....                                          | 2672        |
| 14.5.1     | Mailbox Register Mapping Summary .....                                     | 2672        |
| 14.5.2     | Register Description .....                                                 | 2672        |
| <b>15</b>  | <b>Memory Management Units .....</b>                                       | <b>2679</b> |
| 15.1       | MMU Overview .....                                                         | 2680        |
| 15.2       | MMU Integration .....                                                      | 2681        |
| 15.2.1     | Clock Domains .....                                                        | 2681        |
| 15.2.2     | Power Management .....                                                     | 2682        |
| 15.2.2.1   | System Power Management .....                                              | 2682        |
| 15.2.2.2   | Module Power Saving .....                                                  | 2682        |
| 15.2.3     | Reset .....                                                                | 2683        |
| 15.2.4     | Interrupts .....                                                           | 2683        |
| 15.3       | MMU Functional Description .....                                           | 2684        |
| 15.3.1     | MMU Benefits .....                                                         | 2684        |
| 15.3.2     | MMU Architecture .....                                                     | 2685        |
| 15.3.2.1   | MMU Address Translation Process .....                                      | 2686        |
| 15.3.3     | Translation Tables .....                                                   | 2687        |
| 15.3.3.1   | Translation Table Hierarchy .....                                          | 2687        |
| 15.3.3.2   | First-Level Translation Table .....                                        | 2688        |
| 15.3.3.2.1 | First-Level Descriptor Format .....                                        | 2689        |
| 15.3.3.2.2 | First-Level Page Descriptor Format .....                                   | 2689        |
| 15.3.3.2.3 | First-Level Section Descriptor Format .....                                | 2690        |
| 15.3.3.2.4 | Section Translation Summary .....                                          | 2690        |
| 15.3.3.2.5 | Supersection Translation Summary .....                                     | 2690        |
| 15.3.3.3   | Two-Level Translation .....                                                | 2691        |
| 15.3.3.3.1 | Second-Level Descriptor Format .....                                       | 2692        |
| 15.3.3.3.2 | Small Page Translation Summary .....                                       | 2692        |
| 15.3.3.3.3 | Large Page Translation Summary .....                                       | 2693        |
| 15.3.3.4   | Translation Lookaside Buffer .....                                         | 2693        |
| 15.3.3.4.1 | TLB Entry Format .....                                                     | 2694        |
| 15.3.3.5   | MMU Error Handling .....                                                   | 2695        |
| 15.3.3.6   | MMU Instance Design Parameters .....                                       | 2695        |
| 15.4       | MMU Basic Programming Model .....                                          | 2696        |
| 15.4.1     | Writing TLB Entries Statically .....                                       | 2697        |
| 15.4.1.1   | Protecting TLB Entries .....                                               | 2698        |
| 15.4.1.2   | Deleting TLB Entries .....                                                 | 2698        |
| 15.4.1.3   | Reading TLB Entries .....                                                  | 2698        |
| 15.4.2     | Programming the MMU Dynamically .....                                      | 2699        |
| 15.4.2.1   | Programming the MMU Using First- and Second-Level Translation Tables ..... | 2700        |
| 15.5       | MMU Register Manual .....                                                  | 2703        |
| 15.5.1     | Register Mapping Summary .....                                             | 2703        |
| 15.5.2     | MMU Register Description .....                                             | 2704        |
| <b>16</b>  | <b>Timers .....</b>                                                        | <b>2717</b> |

---

|            |                                                                         |      |
|------------|-------------------------------------------------------------------------|------|
| 16.1       | Timers Overview .....                                                   | 2718 |
| 16.2       | General-Purpose Timers .....                                            | 2719 |
| 16.2.1     | GP Timers Overview .....                                                | 2719 |
| 16.2.1.1   | GP Timers Features .....                                                | 2720 |
| 16.2.2     | GP Timers Environment .....                                             | 2720 |
| 16.2.2.1   | GP Timers External System Interface .....                               | 2720 |
| 16.2.3     | GP Timers Integration .....                                             | 2722 |
| 16.2.3.1   | Clocking, Reset, and Power-Management Scheme .....                      | 2722 |
| 16.2.3.1.1 | Clock Management .....                                                  | 2722 |
| 16.2.3.1.2 | Wake-Up Capability .....                                                | 2725 |
| 16.2.3.1.3 | Reset and Power Management .....                                        | 2726 |
| 16.2.3.2   | Software Reset .....                                                    | 2726 |
| 16.2.3.3   | GP Timer Interrupts .....                                               | 2727 |
| 16.2.4     | GP Timers Functional Description .....                                  | 2728 |
| 16.2.4.1   | GP Timers Block Diagram .....                                           | 2728 |
| 16.2.4.2   | Timer Mode Functionality .....                                          | 2730 |
| 16.2.4.2.1 | 1-ms Tick Generation (Only GPTIMER1, GPTIMER2, and GPTIMER10) .....     | 2731 |
| 16.2.4.3   | Capture Mode Functionality .....                                        | 2733 |
| 16.2.4.4   | Compare Mode Functionality .....                                        | 2734 |
| 16.2.4.5   | Prescaler Functionality .....                                           | 2735 |
| 16.2.4.6   | Pulse-Width Modulation .....                                            | 2735 |
| 16.2.4.7   | Timer Counting Rate .....                                               | 2736 |
| 16.2.5     | Timer Under Emulation .....                                             | 2737 |
| 16.2.6     | Accessing GP Timer Registers .....                                      | 2737 |
| 16.2.6.1   | Writing to Timer Registers .....                                        | 2738 |
| 16.2.6.1.1 | Write Posting Synchronization Mode .....                                | 2738 |
| 16.2.6.1.2 | Write Nonposting Synchronization Mode .....                             | 2739 |
| 16.2.6.2   | Reading From Timer Counter Registers .....                              | 2739 |
| 16.3       | General-Purpose Timers Register Manual .....                            | 2740 |
| 16.3.1     | GP Timer Register Map .....                                             | 2740 |
| 16.3.1.1   | Instance Summary .....                                                  | 2740 |
| 16.3.2     | GP Timer Register Mapping Summary .....                                 | 2740 |
| 16.3.3     | GP Timer Register Descriptions .....                                    | 2743 |
| 16.4       | Watchdog Timers .....                                                   | 2766 |
| 16.4.1     | WDTs Overview .....                                                     | 2766 |
| 16.4.1.1   | WDT Features .....                                                      | 2766 |
| 16.4.2     | WDT Integration .....                                                   | 2767 |
| 16.4.2.1   | Clocking, Reset, and Power-Management Scheme .....                      | 2767 |
| 16.4.2.1.1 | Clock Management .....                                                  | 2767 |
| 16.4.2.1.2 | Reset and Power Management .....                                        | 2769 |
| 16.4.2.2   | Interrupts .....                                                        | 2770 |
| 16.4.3     | WDTs Functional Description .....                                       | 2770 |
| 16.4.3.1   | General WDT Operation .....                                             | 2770 |
| 16.4.3.2   | Reset Context .....                                                     | 2770 |
| 16.4.3.3   | Overflow/Reset Generation .....                                         | 2771 |
| 16.4.3.4   | Prescaler Value/Timer Reset Frequency .....                             | 2771 |
| 16.4.3.5   | Triggering a Timer Reload .....                                         | 2772 |
| 16.4.3.6   | Start/Stop Sequence for WDTs (Using WDTi.WSPR Register) .....           | 2773 |
| 16.4.3.7   | Modifying Timer Count/Load Values and Prescaler Setting .....           | 2773 |
| 16.4.3.8   | Watchdog Counter Register Access Restriction (WDTi.WCRR Register) ..... | 2773 |
| 16.4.3.9   | WDT Interrupt Generation .....                                          | 2773 |
| 16.4.3.10  | WDT Under Emulation .....                                               | 2774 |
| 16.4.3.11  | Accessing Watchdog Timer Registers .....                                | 2774 |

---

|             |                                                                                 |             |
|-------------|---------------------------------------------------------------------------------|-------------|
| 16.5        | Watchdog Timer Register Manual .....                                            | 2775        |
| 16.5.1      | Instance Summary .....                                                          | 2775        |
| 16.5.2      | WDT Register Mapping Summary .....                                              | 2775        |
| 16.5.3      | WDT Register Descriptions .....                                                 | 2776        |
| 16.6        | 32-kHz Synchronized Timer .....                                                 | 2783        |
| 16.6.1      | 32-kHz Sync Timer Functional Description .....                                  | 2783        |
| 16.6.1.1    | Reading the 32-kHz Sync Timer .....                                             | 2783        |
| 16.6.1.2    | 32-kHz Sync Timer Features .....                                                | 2783        |
| 16.6.2      | 32-kHz Sync Timer Environment .....                                             | 2783        |
| 16.6.3      | 32-kHz Sync Timer Integration .....                                             | 2784        |
| 16.6.3.1    | Clocking, Reset, and Power-Management Scheme .....                              | 2784        |
| 16.6.3.2    | Interrupts .....                                                                | 2784        |
| 16.6.3.3    | Sync Timer 32k and MSuspend Signal .....                                        | 2784        |
| 16.7        | 32-kHz Sync Timer Register Manual .....                                         | 2785        |
| 16.7.1      | 32-kHz Sync Timer Instance Summary .....                                        | 2785        |
| 16.7.2      | 32-kHz Sync Timer Register Mapping Summary .....                                | 2785        |
| 16.7.3      | 32-kHz Sync Timer Register Descriptions .....                                   | 2785        |
| <b>17</b>   | <b>Multimaster High-Speed I<sup>2</sup>C Controller .....</b>                   | <b>2787</b> |
| 17.1        | HS I <sup>2</sup> C Overview .....                                              | 2788        |
| 17.2        | HS I <sup>2</sup> C Environment .....                                           | 2790        |
| 17.2.1      | HS I <sup>2</sup> C in I <sup>2</sup> C Mode .....                              | 2790        |
| 17.2.1.1    | HS I <sup>2</sup> C Pins for Typical Connections in I <sup>2</sup> C Mode ..... | 2790        |
| 17.2.1.2    | HS I <sup>2</sup> C Interface Typical Connections .....                         | 2790        |
| 17.2.1.3    | HS I <sup>2</sup> C Typical Connection Protocol and Data Format .....           | 2791        |
| 17.2.1.3.1  | HS I <sup>2</sup> C Serial Data Format .....                                    | 2791        |
| 17.2.1.3.2  | HS I <sup>2</sup> C Data Validity .....                                         | 2791        |
| 17.2.1.3.3  | HS I <sup>2</sup> C Start and Stop Conditions .....                             | 2791        |
| 17.2.1.3.4  | HS I <sup>2</sup> C Addressing .....                                            | 2792        |
| 17.2.1.3.5  | HS I <sup>2</sup> C Master Transmitter Mode .....                               | 2793        |
| 17.2.1.3.6  | HS I <sup>2</sup> C Master Receiver Mode .....                                  | 2793        |
| 17.2.1.3.7  | HS I <sup>2</sup> C Slave Transmitter Mode .....                                | 2793        |
| 17.2.1.3.8  | HS I <sup>2</sup> C Slave Receiver Mode .....                                   | 2793        |
| 17.2.1.3.9  | HS I <sup>2</sup> C Bus Arbitration .....                                       | 2794        |
| 17.2.1.3.10 | HS I <sup>2</sup> C Clock Generation and Synchronization .....                  | 2794        |
| 17.2.2      | HS I <sup>2</sup> C in SCCB Mode .....                                          | 2795        |
| 17.2.2.1    | HS I <sup>2</sup> C Controller Pins for Typical Connections in SCCB Mode .....  | 2796        |
| 17.2.2.2    | HS I <sup>2</sup> C SCCB Interface Typical Connections .....                    | 2797        |
| 17.2.2.3    | HS I <sup>2</sup> C SCCB Typical Connection Protocol and Data Format .....      | 2798        |
| 17.2.2.3.1  | HS I <sup>2</sup> C Serial Transmission Timing Diagram .....                    | 2798        |
| 17.2.2.3.2  | HS I <sup>2</sup> C SCCB Transmission Data Formats .....                        | 2798        |
| 17.2.3      | HS I <sup>2</sup> C Communication With Power Chip(s) .....                      | 2799        |
| 17.2.3.1    | HS I <sup>2</sup> C Pins for Typical Connections for I2C4 .....                 | 2800        |
| 17.2.3.2    | HS I <sup>2</sup> C Interface Typical Connections for I2C4 .....                | 2800        |
| 17.2.3.3    | HS I <sup>2</sup> C Typical Connections Protocol and Data Format for I2C4 ..... | 2801        |
| 17.2.3.3.1  | HS I <sup>2</sup> C Serial Data Format for I2C4 .....                           | 2801        |
| 17.2.3.3.2  | HS I <sup>2</sup> C Data Validity for I2C4 .....                                | 2801        |
| 17.2.3.3.3  | HS I <sup>2</sup> C Start and Stop Conditions for I2C4 .....                    | 2801        |
| 17.2.3.3.4  | HS I <sup>2</sup> C Addressing for I2C4 .....                                   | 2801        |
| 17.3        | HS I <sup>2</sup> C Integration .....                                           | 2802        |
| 17.3.1      | HS I <sup>2</sup> C Clocking, Reset, and Power-Management Scheme .....          | 2803        |
| 17.3.1.1    | HS I <sup>2</sup> C Clocks .....                                                | 2803        |
| 17.3.1.1.1  | HS I <sup>2</sup> C Module Clocks .....                                         | 2803        |
| 17.3.1.2    | HS I <sup>2</sup> C Power Management .....                                      | 2804        |

|            |                                                                                                                        |      |
|------------|------------------------------------------------------------------------------------------------------------------------|------|
| 17.3.1.2.1 | HS I <sup>2</sup> C Module Power Saving .....                                                                          | 2804 |
| 17.3.1.2.2 | HS I <sup>2</sup> C System Power Management .....                                                                      | 2804 |
| 17.3.1.2.3 | HS I <sup>2</sup> C Wake-Up Capability .....                                                                           | 2805 |
| 17.3.1.3   | HS I <sup>2</sup> C Resets .....                                                                                       | 2807 |
| 17.3.1.3.1 | HS I <sup>2</sup> C Hardware Reset .....                                                                               | 2807 |
| 17.3.1.3.2 | HS I <sup>2</sup> C Software Reset .....                                                                               | 2807 |
| 17.3.1.4   | HS I <sup>2</sup> C Power Domain .....                                                                                 | 2808 |
| 17.3.2     | HS I <sup>2</sup> C Hardware Requests .....                                                                            | 2808 |
| 17.3.2.1   | HS I <sup>2</sup> C DMA Requests .....                                                                                 | 2808 |
| 17.3.2.2   | HS I <sup>2</sup> C Interrupt Requests .....                                                                           | 2808 |
| 17.4       | HS I <sup>2</sup> C Functional Description .....                                                                       | 2811 |
| 17.4.1     | HS I <sup>2</sup> C Block Diagram .....                                                                                | 2811 |
| 17.4.2     | HS I <sup>2</sup> C Transmit Mode in I <sup>2</sup> C Mode .....                                                       | 2811 |
| 17.4.3     | HS I <sup>2</sup> C Receive Mode in I <sup>2</sup> C Mode .....                                                        | 2812 |
| 17.4.4     | HS I <sup>2</sup> C FIFO Management .....                                                                              | 2812 |
| 17.4.4.1   | HS I <sup>2</sup> C FIFO Interrupt Mode Operation .....                                                                | 2812 |
| 17.4.4.2   | HS I <sup>2</sup> C FIFO Polling Mode Operation .....                                                                  | 2814 |
| 17.4.4.3   | HS I <sup>2</sup> C FIFO DMA Mode Operation (I <sup>2</sup> C Mode Only) .....                                         | 2814 |
| 17.4.4.4   | HS I <sup>2</sup> C Draining Feature (I <sup>2</sup> C Mode Only) .....                                                | 2816 |
| 17.4.5     | HS I <sup>2</sup> C Programmable Multislave Channel Feature (I <sup>2</sup> C Mode Only) .....                         | 2817 |
| 17.4.6     | HS I <sup>2</sup> C Automatic Blocking of the I <sup>2</sup> C Clock Feature (I <sup>2</sup> C Mode Only) .....        | 2817 |
| 17.4.7     | HS I <sup>2</sup> C Clocking .....                                                                                     | 2817 |
| 17.4.8     | HS I <sup>2</sup> C Noise Filter .....                                                                                 | 2818 |
| 17.4.9     | HS I <sup>2</sup> C System Test Mode .....                                                                             | 2819 |
| 17.4.10    | HS I <sup>2</sup> C Write and Read Operations in SCCB Mode .....                                                       | 2820 |
| 17.4.11    | HS I <sup>2</sup> C Power Chip Communication Operations .....                                                          | 2820 |
| 17.5       | HS I <sup>2</sup> C Basic Programming Model .....                                                                      | 2820 |
| 17.5.1     | HS I <sup>2</sup> C Controller Basic Programming Model in I <sup>2</sup> C Mode .....                                  | 2820 |
| 17.5.1.1   | HS I <sup>2</sup> C Main Program (I <sup>2</sup> C Mode) .....                                                         | 2820 |
| 17.5.1.1.1 | HS I <sup>2</sup> C Configure the Module Before Enabling the I <sup>2</sup> C Controller (I <sup>2</sup> C Mode) ..... | 2820 |
| 17.5.1.1.2 | HS I <sup>2</sup> C Initialize the I <sup>2</sup> C Controller (I <sup>2</sup> C Mode) .....                           | 2821 |
| 17.5.1.1.3 | HS I <sup>2</sup> C Configure Slave Address and the Data Control Register (I <sup>2</sup> C Mode) .....                | 2822 |
| 17.5.1.1.4 | HS I <sup>2</sup> C Initiate a Transfer (I <sup>2</sup> C Mode) .....                                                  | 2822 |
| 17.5.1.1.5 | HS I <sup>2</sup> C Receive Data (I <sup>2</sup> C Mode) .....                                                         | 2822 |
| 17.5.1.1.6 | HS I <sup>2</sup> C Transmit Data (I <sup>2</sup> C Mode) .....                                                        | 2822 |
| 17.5.1.2   | HS I <sup>2</sup> C Interrupt Subroutine Sequence (I <sup>2</sup> C Mode) .....                                        | 2822 |
| 17.5.1.3   | HS I <sup>2</sup> C Programming Flow Diagrams (I <sup>2</sup> C Mode) .....                                            | 2823 |
| 17.5.2     | HS I <sup>2</sup> C Controller Basic Programming Model in SCCB Mode .....                                              | 2832 |
| 17.5.2.1   | HS I <sup>2</sup> C Main Program (SCCB Mode) .....                                                                     | 2832 |
| 17.5.2.1.1 | HS I <sup>2</sup> C Configure the Module Before Enabling the I <sup>2</sup> C Controller (SCCB Mode) .....             | 2832 |
| 17.5.2.1.2 | HS I <sup>2</sup> C Initialize the I <sup>2</sup> C Controller (SCCB Mode) .....                                       | 2833 |
| 17.5.2.1.3 | HS I <sup>2</sup> C Initiate a Transfer (SCCB Mode) .....                                                              | 2833 |
| 17.5.2.1.4 | HS I <sup>2</sup> C Receive Data (SCCB Mode) .....                                                                     | 2833 |
| 17.5.2.1.5 | HS I <sup>2</sup> C Transmit Data (SCCB Mode) .....                                                                    | 2833 |
| 17.5.2.2   | HS I <sup>2</sup> C Interrupt Subroutine Sequence (SCCB Mode) .....                                                    | 2833 |
| 17.5.2.3   | HS I <sup>2</sup> C Programming Flow Diagrams (SCCB Mode) .....                                                        | 2833 |
| 17.5.3     | HS I <sup>2</sup> C Controller I <sup>2</sup> C4 Basic Programming Model for Communication With Power Chips .....      | 2839 |
| 17.5.3.1   | HS I <sup>2</sup> C Configure the Voltage Controller Registers .....                                                   | 2839 |
| 17.5.3.2   | HS I <sup>2</sup> C Configure the HS I <sup>2</sup> C4 .....                                                           | 2839 |
| 17.5.3.3   | HS I <sup>2</sup> C Configure the External Power Chip(s) .....                                                         | 2839 |
| 17.6       | HS I <sup>2</sup> C Register Manual .....                                                                              | 2840 |
| 17.6.1     | HS I <sup>2</sup> C Instance Summary .....                                                                             | 2840 |
| 17.6.2     | HS I <sup>2</sup> C Registers .....                                                                                    | 2840 |

---

|           |                                                                           |             |
|-----------|---------------------------------------------------------------------------|-------------|
| 17.6.2.1  | HS I <sup>2</sup> C Register Summary .....                                | 2840        |
| 17.6.2.2  | HS I <sup>2</sup> C Register Summary .....                                | 2841        |
| <b>18</b> | <b>HDQ/1-Wire .....</b>                                                   | <b>2863</b> |
| 18.1      | HDQ/1-Wire Overview .....                                                 | 2864        |
| 18.2      | HDQ/1-Wire Environment .....                                              | 2865        |
| 18.2.1    | HDQ/1-Wire Functional Interface .....                                     | 2865        |
| 18.2.2    | HDQ and 1-Wire (SDQ) Protocols .....                                      | 2865        |
| 18.2.2.1  | HDQ Protocol Initialization (Default) .....                               | 2865        |
| 18.2.2.2  | 1-Wire (SDQ) Protocol Initialization .....                                | 2866        |
| 18.2.2.3  | Communication Sequence (HDQ and 1-Wire Protocols) .....                   | 2866        |
| 18.3      | HDQ/1-Wire Integration .....                                              | 2868        |
| 18.3.1    | Clocking, Reset, and Power-Management Scheme .....                        | 2868        |
| 18.3.1.1  | HDQ/1-Wire Clocks .....                                                   | 2868        |
| 18.3.1.2  | HDQ/1-Wire Reset Scheme .....                                             | 2869        |
| 18.3.1.3  | HDQ/1-Wire Power Domain .....                                             | 2869        |
| 18.3.2    | Hardware Requests .....                                                   | 2869        |
| 18.4      | HDQ/1-Wire Functional Description .....                                   | 2870        |
| 18.4.1    | HDQ/1-Wire Block Diagram .....                                            | 2870        |
| 18.4.2    | HDQ Mode (Default) .....                                                  | 2871        |
| 18.4.2.1  | HDQ Mode Features .....                                                   | 2871        |
| 18.4.2.2  | Description .....                                                         | 2871        |
| 18.4.2.3  | Single-Bit Mode .....                                                     | 2872        |
| 18.4.2.4  | Interrupt Conditions .....                                                | 2872        |
| 18.4.3    | 1-Wire Mode .....                                                         | 2873        |
| 18.4.3.1  | 1-Wire Mode Features .....                                                | 2873        |
| 18.4.3.2  | Description .....                                                         | 2873        |
| 18.4.3.3  | 1-Wire Single-Bit Mode Operation .....                                    | 2873        |
| 18.4.3.4  | Interrupt Conditions .....                                                | 2874        |
| 18.4.3.5  | Status Flags .....                                                        | 2874        |
| 18.4.4    | Module Power Saving .....                                                 | 2874        |
| 18.4.4.1  | Autoidle Mode .....                                                       | 2874        |
| 18.4.4.2  | Power-Down Mode .....                                                     | 2874        |
| 18.4.5    | System Power Management and Wakeup .....                                  | 2874        |
| 18.5      | HDQ/1-Wire Basic Programming Model .....                                  | 2876        |
| 18.5.1    | Module Initialization Sequence .....                                      | 2876        |
| 18.5.1.1  | Mode Selection .....                                                      | 2876        |
| 18.5.1.2  | Reset/Initialization .....                                                | 2876        |
| 18.5.2    | HDQ Protocol Basic Programming Model .....                                | 2876        |
| 18.5.2.1  | Write Operation .....                                                     | 2876        |
| 18.5.2.2  | Read Operation .....                                                      | 2877        |
| 18.5.3    | 1-Wire Mode (SDQ) Basic Programming Model .....                           | 2877        |
| 18.5.3.1  | Write Operation .....                                                     | 2877        |
| 18.5.3.2  | Read Operation .....                                                      | 2878        |
| 18.5.3.3  | 1-Wire Bit Mode Operation .....                                           | 2878        |
| 18.5.4    | Power Management .....                                                    | 2878        |
| 18.5.4.1  | Module Power-Down Mode .....                                              | 2878        |
| 18.5.4.2  | System Idle Mode .....                                                    | 2879        |
| 18.6      | HDQ/1-Wire Use Cases and Tips .....                                       | 2880        |
| 18.6.1    | How to Configure the HDQ/1-Wire when Connected with a BQ27000 Gauge ..... | 2880        |
| 18.6.1.1  | Environment .....                                                         | 2880        |
| 18.6.1.2  | Programming Flow .....                                                    | 2880        |
| 18.6.1.3  | Pad Configuration and HDQ/1-Wire Clock and Power Management .....         | 2880        |
| 18.6.1.4  | HDQ/1-Wire Software Reset .....                                           | 2881        |

|            |                                                                   |             |
|------------|-------------------------------------------------------------------|-------------|
| 18.6.1.5   | Interrupts Enable .....                                           | 2881        |
| 18.6.1.6   | Read and Write Operations .....                                   | 2882        |
| 18.7       | HDQ/1-Wire Register Manual .....                                  | 2883        |
| 18.7.1     | HDQ/1-Wire Instance Summary .....                                 | 2883        |
| 18.7.2     | HDQ/1-Wire Register Mapping Summary .....                         | 2883        |
| 18.7.3     | HDQ/1-Wire Register Description .....                             | 2884        |
| <b>19</b>  | <b>UART/IrDA/CIR .....</b>                                        | <b>2891</b> |
| 19.1       | UART/IrDA/CIR Overview .....                                      | 2892        |
| 19.1.1     | UART Features .....                                               | 2892        |
| 19.1.2     | IrDA Features .....                                               | 2893        |
| 19.1.3     | CIR Features .....                                                | 2894        |
| 19.2       | UART/IrDA/CIR Environment .....                                   | 2895        |
| 19.2.1     | System Using UART Communication with Hardware Handshake .....     | 2895        |
| 19.2.2     | System Using IrDA Communication Protocol .....                    | 2895        |
| 19.2.3     | System Using CIR Communication Protocol with Remote Control ..... | 2895        |
| 19.2.4     | UART Interface Description .....                                  | 2896        |
| 19.2.4.1   | UART Interface Description .....                                  | 2896        |
| 19.2.4.2   | UART Protocol and Data Format .....                               | 2896        |
| 19.2.5     | IrDA Functional Interfaces .....                                  | 2897        |
| 19.2.5.1   | UART3 Interface Description .....                                 | 2897        |
| 19.2.5.2   | IrDA Protocol and Data Format .....                               | 2897        |
| 19.2.5.2.1 | SIR Mode .....                                                    | 2897        |
| 19.2.5.2.2 | SIR Free Format Mode .....                                        | 2900        |
| 19.2.5.2.3 | MIR Mode .....                                                    | 2901        |
| 19.2.5.2.4 | FIR Mode .....                                                    | 2902        |
| 19.2.6     | CIR Functional Interfaces .....                                   | 2904        |
| 19.2.6.1   | CIR Interface Description .....                                   | 2904        |
| 19.2.6.2   | CIR Protocol and Data Format .....                                | 2904        |
| 19.2.6.2.1 | Carrier Modulation .....                                          | 2904        |
| 19.2.6.2.2 | Pulse Duty Cycle .....                                            | 2905        |
| 19.2.6.2.3 | Consumer IR Encoding/Decoding .....                               | 2905        |
| 19.3       | UART/IrDA/CIR Integration .....                                   | 2908        |
| 19.3.1     | Clocking, Reset, and Power-Management Scheme .....                | 2908        |
| 19.3.1.1   | Clocking .....                                                    | 2908        |
| 19.3.1.2   | Hardware Reset .....                                              | 2909        |
| 19.3.1.3   | Software Reset .....                                              | 2909        |
| 19.3.1.4   | Power Domain .....                                                | 2910        |
| 19.3.2     | Hardware Requests .....                                           | 2910        |
| 19.3.2.1   | Interrupts .....                                                  | 2910        |
| 19.3.2.2   | DMA Requests .....                                                | 2910        |
| 19.3.2.3   | Wake-up Request .....                                             | 2911        |
| 19.4       | UART/IrDA/CIR Functional Description .....                        | 2912        |
| 19.4.1     | UART/IrDA/CIR Block Description .....                             | 2912        |
| 19.4.2     | FIFO Management .....                                             | 2913        |
| 19.4.2.1   | FIFO Trigger .....                                                | 2914        |
| 19.4.2.1.1 | Transmit FIFO Trigger .....                                       | 2914        |
| 19.4.2.1.2 | Receive FIFO Trigger .....                                        | 2914        |
| 19.4.2.2   | FIFO Interrupt Mode .....                                         | 2914        |
| 19.4.2.3   | FIFO Polled Mode Operation .....                                  | 2916        |
| 19.4.2.4   | FIFO DMA Mode Operation .....                                     | 2916        |
| 19.4.2.4.1 | DMA Transfers (DMA Mode 1, 2, or 3) .....                         | 2916        |
| 19.4.2.4.2 | DMA Transmission .....                                            | 2919        |
| 19.4.2.4.3 | DMA Reception .....                                               | 2919        |

---

|            |                                                              |      |
|------------|--------------------------------------------------------------|------|
| 19.4.3     | Mode Selection .....                                         | 2920 |
| 19.4.3.1   | Register Access Modes .....                                  | 2920 |
| 19.4.3.1.1 | Operational Mode and Configuration Modes .....               | 2920 |
| 19.4.3.1.2 | Register Access Submode .....                                | 2921 |
| 19.4.3.1.3 | Registers Available to Register Access Modes .....           | 2921 |
| 19.4.3.2   | UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection .....           | 2923 |
| 19.4.3.2.1 | Registers Available for the UART Function .....              | 2923 |
| 19.4.3.2.2 | Registers Available for the IrDA Function (UART3 Only) ..... | 2924 |
| 19.4.3.2.3 | Registers Available for the CIR Function (UART3 Only) .....  | 2925 |
| 19.4.4     | Protocol Formatting .....                                    | 2926 |
| 19.4.4.1   | UART Mode .....                                              | 2926 |
| 19.4.4.1.1 | UART Clock Generation: Baud Rate Generation .....            | 2926 |
| 19.4.4.1.2 | Choosing the Appropriate Divisor Value .....                 | 2927 |
| 19.4.4.1.3 | UART Data Formatting .....                                   | 2927 |
| 19.4.4.1.4 | UART Mode Interrupt Management .....                         | 2931 |
| 19.4.4.2   | IrDA Mode (UART3 Only) .....                                 | 2932 |
| 19.4.4.2.1 | IrDA Clock Generation: Baud Generator .....                  | 2932 |
| 19.4.4.2.2 | Choosing the Appropriate Divisor Value .....                 | 2933 |
| 19.4.4.2.3 | IrDA Data Formatting .....                                   | 2934 |
| 19.4.4.2.4 | SIR Mode DATA Formatting .....                               | 2935 |
| 19.4.4.2.5 | MIR and FIR Mode Data Formatting .....                       | 2936 |
| 19.4.4.2.6 | IrDA Mode Interrupt Management .....                         | 2936 |
| 19.4.4.3   | CIR Mode (UART3 Only) .....                                  | 2937 |
| 19.4.4.3.1 | CIR Mode Clock Generation .....                              | 2937 |
| 19.4.4.3.2 | CIR Data Formatting .....                                    | 2939 |
| 19.4.4.3.3 | CIR Mode Interrupt Management .....                          | 2940 |
| 19.4.5     | Power Management .....                                       | 2940 |
| 19.4.5.1   | UART Mode Power Management .....                             | 2940 |
| 19.4.5.1.1 | Module Power Saving .....                                    | 2940 |
| 19.4.5.1.2 | System Power Saving .....                                    | 2941 |
| 19.4.5.2   | IrDA Mode Power Management (UART3 Only) .....                | 2941 |
| 19.4.5.2.1 | Module Power Saving .....                                    | 2941 |
| 19.4.5.2.2 | System Power Saving .....                                    | 2941 |
| 19.4.5.3   | CIR Mode Power Management (UART3 Only) .....                 | 2941 |
| 19.4.5.3.1 | Module Power Saving .....                                    | 2941 |
| 19.4.5.3.2 | System Power Saving .....                                    | 2941 |
| 19.5       | UART/IrDA/CIR Basic Programming Model .....                  | 2942 |
| 19.5.1     | UART Programming Model .....                                 | 2942 |
| 19.5.1.1   | Quick start .....                                            | 2942 |
| 19.5.1.1.1 | Software Reset .....                                         | 2942 |
| 19.5.1.1.2 | FIFOs and DMA Settings .....                                 | 2942 |
| 19.5.1.1.3 | Protocol, Baud Rate, and Interrupt Settings .....            | 2943 |
| 19.5.1.2   | Hardware and Software Flow Control Configuration .....       | 2945 |
| 19.5.1.2.1 | Hardware Flow Control Configuration .....                    | 2945 |
| 19.5.1.2.2 | Software Flow Control Configuration .....                    | 2945 |
| 19.5.2     | IrDA Programming Model (UART3 Only) .....                    | 2947 |
| 19.5.2.1   | SIR Mode .....                                               | 2947 |
| 19.5.2.1.1 | Receive .....                                                | 2947 |
| 19.5.2.1.2 | Transmit .....                                               | 2947 |
| 19.5.2.2   | MIR Mode .....                                               | 2948 |
| 19.5.2.2.1 | Receive .....                                                | 2948 |
| 19.5.2.2.2 | Transmit .....                                               | 2948 |
| 19.5.2.2.3 | FIR Mode .....                                               | 2949 |

|            |                                                          |             |
|------------|----------------------------------------------------------|-------------|
| 19.6       | UART/IrDA/CIR Register Manual .....                      | 2950        |
| 19.6.1     | UART/IrDA/CIR Instance Summary .....                     | 2950        |
| 19.6.2     | UART/IrDA/CIR Register Summary .....                     | 2950        |
| 19.6.3     | UART/IrDA/CIR Register Description .....                 | 2953        |
| <b>20</b>  | <b>Multichannel SPI .....</b>                            | <b>2997</b> |
| 20.1       | McSPI Overview .....                                     | 2998        |
| 20.2       | McSPI Environment .....                                  | 3001        |
| 20.2.1     | SPI Interface in Master Mode .....                       | 3001        |
| 20.2.2     | SPI Interface in Slave Mode .....                        | 3002        |
| 20.3       | McSPI Functional Interface .....                         | 3004        |
| 20.3.1     | Basic McSPI Pins for Master Mode .....                   | 3004        |
| 20.3.2     | Basic McSPI Pins for Slave Mode .....                    | 3004        |
| 20.3.3     | Multichannel SPI Protocol and Data Format .....          | 3005        |
| 20.3.3.1   | Transfer Format .....                                    | 3006        |
| 20.4       | McSPI Integration .....                                  | 3009        |
| 20.4.1     | McSPI Description .....                                  | 3009        |
| 20.4.2     | Clocking, Reset, and Power-Management Scheme .....       | 3009        |
| 20.4.2.1   | Clocking .....                                           | 3009        |
| 20.4.2.2   | Power Domain .....                                       | 3010        |
| 20.4.2.3   | Hardware Reset .....                                     | 3010        |
| 20.4.2.4   | Software Reset .....                                     | 3010        |
| 20.4.3     | Hardware Requests .....                                  | 3011        |
| 20.4.3.1   | DMA Requests .....                                       | 3011        |
| 20.4.3.2   | Interrupt Requests .....                                 | 3012        |
| 20.4.3.3   | Wake-Up Requests .....                                   | 3012        |
| 20.5       | McSPI Functional Description .....                       | 3013        |
| 20.5.1     | McSPI Block Diagram .....                                | 3013        |
| 20.5.2     | Master Mode .....                                        | 3014        |
| 20.5.2.1   | Master Mode Features .....                               | 3014        |
| 20.5.2.2   | Master Transmit-and-Receive Mode (Full Duplex) .....     | 3014        |
| 20.5.2.3   | Master Transmit-Only Mode (Half Duplex) .....            | 3015        |
| 20.5.2.4   | Master Receive-Only Mode (Half Duplex) .....             | 3015        |
| 20.5.2.5   | Single-Channel Master Mode .....                         | 3016        |
| 20.5.2.5.1 | Programming Tips When Switching to Another Channel ..... | 3016        |
| 20.5.2.5.2 | Force spim_csx Mode .....                                | 3016        |
| 20.5.2.5.3 | Turbo Mode .....                                         | 3018        |
| 20.5.2.6   | Start Bit Mode .....                                     | 3018        |
| 20.5.2.7   | Chip-Select Timing Control .....                         | 3018        |
| 20.5.2.8   | Programmable SPI Clock (spim_clk) .....                  | 3019        |
| 20.5.2.8.1 | Clock Ratio Granularity .....                            | 3019        |
| 20.5.3     | Slave Mode .....                                         | 3020        |
| 20.5.3.1   | Dedicated Resources .....                                | 3020        |
| 20.5.3.2   | Slave Transmit-and-Receive Mode .....                    | 3022        |
| 20.5.3.3   | Slave Transmit-Only Mode .....                           | 3022        |
| 20.5.3.4   | Slave Receive-Only Mode .....                            | 3023        |
| 20.5.4     | FIFO Buffer Management .....                             | 3024        |
| 20.5.4.1   | Buffer Almost Full .....                                 | 3026        |
| 20.5.4.2   | Buffer Almost Empty .....                                | 3026        |
| 20.5.4.3   | End of Transfer Management .....                         | 3027        |
| 20.5.5     | Interrupts .....                                         | 3027        |
| 20.5.5.1   | Interrupt Events in Master Mode .....                    | 3028        |
| 20.5.5.1.1 | TXx_EMPTY .....                                          | 3028        |
| 20.5.5.1.2 | TXx_UNDERFLOW .....                                      | 3028        |

---

|            |                                                                      |             |
|------------|----------------------------------------------------------------------|-------------|
| 20.5.5.1.3 | RXX_FULL .....                                                       | 3028        |
| 20.5.5.1.4 | End Of Word Count .....                                              | 3028        |
| 20.5.5.2   | Interrupt Events in Slave Mode .....                                 | 3029        |
| 20.5.5.2.1 | TXx_EMPTY .....                                                      | 3029        |
| 20.5.5.2.2 | TXx_UNDERFLOW .....                                                  | 3029        |
| 20.5.5.2.3 | RXX_FULL .....                                                       | 3029        |
| 20.5.5.2.4 | RX0_OVERFLOW .....                                                   | 3029        |
| 20.5.5.2.5 | End Of Word Count .....                                              | 3030        |
| 20.5.5.3   | Interrupt-Driven Operation .....                                     | 3030        |
| 20.5.5.4   | Polling .....                                                        | 3030        |
| 20.5.6     | DMA Requests .....                                                   | 3030        |
| 20.5.7     | Power Saving Management .....                                        | 3031        |
| 20.5.7.1   | Normal Mode .....                                                    | 3031        |
| 20.5.7.2   | Idle Mode .....                                                      | 3031        |
| 20.5.7.2.1 | Wake-Up Event in Smart-Idle Mode .....                               | 3032        |
| 20.5.7.2.2 | Transitions From Smart-Idle Mode to Normal Mode .....                | 3033        |
| 20.5.7.2.3 | Force-Idle Mode .....                                                | 3033        |
| 20.6       | McSPI Basic Programming Model .....                                  | 3034        |
| 20.6.1     | Initialization of Modules .....                                      | 3034        |
| 20.6.2     | Transfer Procedures without FIFO .....                               | 3034        |
| 20.6.2.1   | Common Transfer Procedure .....                                      | 3035        |
| 20.6.2.2   | End-of-Transfer Procedure .....                                      | 3035        |
| 20.6.2.3   | Transmit and Receive Procedure .....                                 | 3037        |
| 20.6.2.4   | Transmit-Only Procedure .....                                        | 3038        |
| 20.6.2.4.1 | Based on Interrupt Requests .....                                    | 3038        |
| 20.6.2.4.2 | Transmit-Only Based on DMA Write Requests .....                      | 3038        |
| 20.6.2.5   | Receive-Only Procedure .....                                         | 3039        |
| 20.6.2.5.1 | Master Normal Receive-Only Procedure .....                           | 3039        |
| 20.6.2.5.2 | Master Turbo Receive-Only Procedure .....                            | 3041        |
| 20.6.2.5.3 | Slave Receive-Only Procedure .....                                   | 3043        |
| 20.6.2.6   | McSPI Configuration and Operations Example .....                     | 3045        |
| 20.6.2.6.1 | McSPI Initialization Sequence .....                                  | 3045        |
| 20.6.2.6.2 | Operations for the First Slave (On Channel 0) .....                  | 3045        |
| 20.6.2.6.3 | Programming in Interrupt Mode .....                                  | 3046        |
| 20.6.2.6.4 | Operations for the Second Slave (on Channel 1) in Polling Mode ..... | 3046        |
| 20.6.3     | Transfer Procedures with FIFO .....                                  | 3047        |
| 20.6.3.1   | Common Transfer Procedure .....                                      | 3047        |
| 20.6.3.2   | Transmit-Receive Procedure With Word Count (WCNT≠0) .....            | 3049        |
| 20.6.3.3   | Transmit-Receive Procedure Without Word Count (WCNT=0) .....         | 3050        |
| 20.6.3.4   | Transmit-Only Procedure .....                                        | 3051        |
| 20.6.3.5   | Receive-Only Procedure With Word Count (WCNT≠0) .....                | 3052        |
| 20.6.3.6   | Receive-Only Procedure Without Word Count (WCNT=0) .....             | 3053        |
| 20.7       | McSPI Register Manual .....                                          | 3055        |
| 20.7.1     | McSPI Instance Summary .....                                         | 3055        |
| 20.7.2     | McSPI Register Summary .....                                         | 3055        |
| 20.7.3     | McSPI Register Description .....                                     | 3056        |
| <b>21</b>  | <b>Multichannel Buffered Serial Port .....</b>                       | <b>3077</b> |
| 21.1       | McBSP Overview .....                                                 | 3078        |
| 21.1.1     | McBSP Features .....                                                 | 3078        |
| 21.1.2     | SIDETONE Core .....                                                  | 3080        |
| 21.2       | McBSP Environment .....                                              | 3081        |
| 21.2.1     | McBSP Functions .....                                                | 3081        |
| 21.2.2     | McBSP Signals Descriptions .....                                     | 3081        |

|            |                                                                                 |      |
|------------|---------------------------------------------------------------------------------|------|
| 21.2.3     | McBSP Functions Description .....                                               | 3082 |
| 21.2.3.1   | McBSP Modes .....                                                               | 3082 |
| 21.2.3.2   | McBSP Functions .....                                                           | 3084 |
| 21.2.3.2.1 | McBSP Function 1: Control and Data .....                                        | 3084 |
| 21.2.3.2.2 | McBSP Function 2: Audio Data .....                                              | 3084 |
| 21.2.3.2.3 | McBSP Function 3: Voice Data .....                                              | 3085 |
| 21.2.4     | McBSP Protocols and Data Formats .....                                          | 3085 |
| 21.2.4.1   | Word, Frame, and Phase Definitions .....                                        | 3086 |
| 21.2.4.1.1 | Words or Channels .....                                                         | 3086 |
| 21.2.4.1.2 | Frames .....                                                                    | 3086 |
| 21.2.4.1.3 | Phases .....                                                                    | 3086 |
| 21.2.4.2   | Serial Protocol and Data Formats .....                                          | 3087 |
| 21.2.4.2.1 | Protocol .....                                                                  | 3087 |
| 21.2.4.2.2 | Data Format .....                                                               | 3087 |
| 21.2.4.3   | Audio Protocol and Data Formats .....                                           | 3088 |
| 21.2.4.3.1 | Protocol .....                                                                  | 3088 |
| 21.2.4.3.2 | Data Formats .....                                                              | 3088 |
| 21.2.4.4   | Voice Protocol and Data Formats .....                                           | 3090 |
| 21.2.4.4.1 | Protocol .....                                                                  | 3090 |
| 21.2.4.4.2 | Data Formats .....                                                              | 3090 |
| 21.3       | McBSP Integration .....                                                         | 3091 |
| 21.3.1     | Signal Source Control .....                                                     | 3095 |
| 21.3.1.1   | McBSP1 Module (6-Pin Configuration) .....                                       | 3095 |
| 21.3.1.2   | McBSP2, 3, 4, and 5 Modules (4-Pin Configuration) .....                         | 3096 |
| 21.3.2     | Clocking, Reset, and Power Management Scheme .....                              | 3096 |
| 21.3.2.1   | Power Domain .....                                                              | 3096 |
| 21.3.2.2   | Clocks .....                                                                    | 3096 |
| 21.3.2.2.1 | McBSP1 Clocks .....                                                             | 3096 |
| 21.3.2.2.2 | McBSP2 Clocks .....                                                             | 3097 |
| 21.3.2.2.3 | McBSP3 Clocks .....                                                             | 3098 |
| 21.3.2.2.4 | McBSP4 Clocks .....                                                             | 3099 |
| 21.3.2.2.5 | McBSP5 Clocks .....                                                             | 3100 |
| 21.3.2.2.6 | SIDETONE Clock .....                                                            | 3101 |
| 21.3.2.3   | Hardware and Software Reset .....                                               | 3102 |
| 21.3.2.4   | Power Management .....                                                          | 3102 |
| 21.3.2.4.1 | McBSP Operating States .....                                                    | 3102 |
| 21.3.2.4.2 | McBSP Acknowledgment Modes .....                                                | 3102 |
| 21.3.2.4.3 | Wake-Up Capability .....                                                        | 3104 |
| 21.3.2.4.4 | Analysis of the Receiver Smart-Idle Behavior .....                              | 3106 |
| 21.3.3     | Hardware Requests .....                                                         | 3108 |
| 21.3.3.1   | DMA Requests .....                                                              | 3108 |
| 21.3.3.2   | Interrupt Requests .....                                                        | 3108 |
| 21.3.3.2.1 | McBSP Interrupt Requests .....                                                  | 3108 |
| 21.3.3.2.2 | SIDETONE_McBSP Interrupt Requests .....                                         | 3110 |
| 21.4       | McBSP Functional Description .....                                              | 3112 |
| 21.4.1     | Block Diagram .....                                                             | 3112 |
| 21.4.2     | McBSP Data Transfer Process .....                                               | 3114 |
| 21.4.2.1   | Data Transfer Process for 8- / 12- / 16- / 20- / 24- / 32-bits Long Words ..... | 3115 |
| 21.4.2.2   | Bit Reordering (Option to Transfer LSB First) .....                             | 3116 |
| 21.4.2.3   | Clocking and Framing Data .....                                                 | 3116 |
| 21.4.2.3.1 | Clocking .....                                                                  | 3117 |
| 21.4.2.3.2 | Serial Words .....                                                              | 3118 |
| 21.4.2.3.3 | Frames and Frame Synchronization .....                                          | 3118 |

---

|                                                                                         |      |
|-----------------------------------------------------------------------------------------|------|
| 21.4.2.3.4 Detecting Frame-Synchronization Pulses, Even in Reset State .....            | 3119 |
| 21.4.2.3.5 Ignoring Frame-Synchronization Pulses .....                                  | 3119 |
| 21.4.2.3.6 Frame Frequency .....                                                        | 3120 |
| 21.4.2.3.7 Maximum Frame Frequency .....                                                | 3120 |
| 21.4.2.4 Frame Phases (Dual-Phase Frame I <sup>2</sup> S Support) .....                 | 3120 |
| 21.4.2.4.1 Number of Phases, Words, and Bits per Frame .....                            | 3121 |
| 21.4.2.4.2 Single-Phase Frame Example .....                                             | 3121 |
| 21.4.2.4.3 Dual-Phase Frame Example .....                                               | 3122 |
| 21.4.2.5 McBSP Reception .....                                                          | 3122 |
| 21.4.2.6 McBSP Transmission .....                                                       | 3123 |
| 21.4.2.7 Enable/Disable the Transmit and Receive Processes .....                        | 3124 |
| 21.4.2.8 MCBSP Data Transfer Mode .....                                                 | 3125 |
| 21.4.2.8.1 Transmit Full Cycle Mode .....                                               | 3125 |
| 21.4.2.8.2 Transmit Half Cycle Mode .....                                               | 3125 |
| 21.4.2.8.3 Receive Full Cycle Mode .....                                                | 3126 |
| 21.4.2.8.4 Receive Half Cycle Mode .....                                                | 3126 |
| 21.4.3 McBSP SRG .....                                                                  | 3126 |
| 21.4.3.1 Clock Generation in the SRG .....                                              | 3128 |
| 21.4.3.2 Frame Sync Generation in the SRG .....                                         | 3129 |
| 21.4.3.2.1 Choosing the Width of the Frame-sync Pulse .....                             | 3129 |
| 21.4.3.2.2 Controlling the Period Between the Starting Edges of Frame Sync Pulses ..... | 3129 |
| 21.4.3.2.3 Keeping FSG Synchronized to an External Clock .....                          | 3130 |
| 21.4.3.3 Synchronizing SRG Outputs to an External Clock .....                           | 3130 |
| 21.4.3.3.1 Operating the Transmitter Synchronously with the Receiver .....              | 3130 |
| 21.4.3.3.2 Synchronization Examples .....                                               | 3130 |
| 21.4.4 McBSP Exception/Error Conditions .....                                           | 3131 |
| 21.4.4.1 Introduction .....                                                             | 3131 |
| 21.4.4.2 Overrun in the Receiver .....                                                  | 3132 |
| 21.4.4.3 Unexpected Receive Frame-sync Pulse .....                                      | 3133 |
| 21.4.4.3.1 Possible Responses to Receive Frame-sync Pulses .....                        | 3133 |
| 21.4.4.3.2 Example of an Unexpected Receive Frame-sync Pulse .....                      | 3133 |
| 21.4.4.3.3 Preventing Unexpected Receive Frame-sync Pulses .....                        | 3133 |
| 21.4.4.4 Underflow in the Receiver .....                                                | 3134 |
| 21.4.4.5 Underflow in the Transmitter .....                                             | 3134 |
| 21.4.4.6 Unexpected Transmit Frame-sync Pulse .....                                     | 3135 |
| 21.4.4.6.1 Possible Responses to Transmit Frame-sync Pulses .....                       | 3135 |
| 21.4.4.6.2 Example of Unexpected Transmit Frame-Synchronization Pulse .....             | 3135 |
| 21.4.4.6.3 Preventing Unexpected Transmit Frame-sync Pulses .....                       | 3135 |
| 21.4.4.7 Overflow in the Transmitter .....                                              | 3136 |
| 21.4.5 McBSP DMA Configuration .....                                                    | 3136 |
| 21.4.6 Multichannel Selection Modes .....                                               | 3137 |
| 21.4.6.1 Channels, Blocks, and Partitions .....                                         | 3137 |
| 21.4.6.2 Multichannel Selection .....                                                   | 3137 |
| 21.4.6.3 Configuring a Frame for Multichannel Selection .....                           | 3137 |
| 21.4.6.4 Using Eight Partitions .....                                                   | 3138 |
| 21.4.6.5 Receive Multichannel Selection Mode .....                                      | 3139 |
| 21.4.6.6 Using Two Partitions (Legacy Only) .....                                       | 3139 |
| 21.4.6.7 Transmit Multichannel Selection Modes .....                                    | 3140 |
| 21.4.6.7.1 Disabling/Enabling Versus Masking/Unmasking .....                            | 3141 |
| 21.4.6.7.2 Activity on McBSP Pins for Different Values of XMCM .....                    | 3141 |
| 21.4.7 SIDETONE Mode (ALP) .....                                                        | 3143 |
| 21.4.7.1 Introduction .....                                                             | 3143 |
| 21.4.7.2 SIDETONE Interface .....                                                       | 3143 |

|            |                                                                                       |             |
|------------|---------------------------------------------------------------------------------------|-------------|
| 21.4.7.3   | Data Processing Path .....                                                            | 3145        |
| 21.4.7.4   | Data Processing .....                                                                 | 3146        |
| 21.4.7.4.1 | Filtering .....                                                                       | 3147        |
| 21.4.7.4.2 | Applying Gain .....                                                                   | 3147        |
| 21.4.7.4.3 | Enabling SIDETONE .....                                                               | 3147        |
| 21.4.7.4.4 | FIR Accuracy .....                                                                    | 3147        |
| 21.4.7.5   | Interrupt Operation .....                                                             | 3147        |
| 21.5       | McBSP Basic Programming Model .....                                                   | 3148        |
| 21.5.1     | McBSP Core .....                                                                      | 3148        |
| 21.5.1.1   | McBSP Initialization Procedure .....                                                  | 3148        |
| 21.5.1.2   | Reset and Initialization Procedure for the Sample Rate Generator .....                | 3151        |
| 21.5.1.3   | Data Transfer DMA Request Configuration .....                                         | 3154        |
| 21.5.1.4   | Interrupt Configuration .....                                                         | 3154        |
| 21.5.1.4.1 | L4-Compliant Interrupt Line .....                                                     | 3154        |
| 21.5.1.4.2 | Legacy Interrupt Line .....                                                           | 3155        |
| 21.5.1.5   | Receiver Configuration .....                                                          | 3156        |
| 21.5.1.5.1 | Resetting (Step 1) and Enabling (Step 3) the Receiver .....                           | 3156        |
| 21.5.1.5.2 | Programming the McBSP Registers for the Desired Receiver Configuration (Step 2) ..... | 3157        |
| 21.5.1.6   | Transmitter Configuration .....                                                       | 3165        |
| 21.5.1.6.1 | Resetting (Step 1) and Enabling (Step 3) the Transmitter .....                        | 3165        |
| 21.5.1.6.2 | Programming the McBSP Registers for the Desired Transmitter Operation (Step 2) .....  | 3166        |
| 21.5.1.7   | General-Purpose I/O on the McBSP Pins (Legacy Only) .....                             | 3172        |
| 21.5.1.8   | Data Packing Examples .....                                                           | 3173        |
| 21.5.1.8.1 | Data Packing Using Frame Length and Word Length .....                                 | 3173        |
| 21.5.1.8.2 | Data Packing Using Word Length and the Frame-Sync Ignore Function .....               | 3174        |
| 21.5.2     | SIDETONE Feature .....                                                                | 3175        |
| 21.5.2.1   | SIDETONE Activation Procedure .....                                                   | 3175        |
| 21.5.2.2   | SIDETONE Initialization Procedure .....                                               | 3176        |
| 21.5.2.3   | SIDETONE FIR Coefficients Writing .....                                               | 3176        |
| 21.5.2.4   | SIDETONE FIR Coefficients Reading .....                                               | 3176        |
| 21.6       | McBSP Register Manual .....                                                           | 3177        |
| 21.6.1     | McBSP Register Mapping Summary .....                                                  | 3177        |
| 21.6.2     | SIDETONE Register Mapping Summary .....                                               | 3182        |
| 21.6.3     | McBSP Register Description .....                                                      | 3183        |
| 21.6.4     | SIDETONE Register Description .....                                                   | 3232        |
| 22         | <b>High-Speed USB Host Subsystem and High-Speed USB OTG Controller .....</b>          | <b>3237</b> |
| 22.1       | High-Speed USB OTG Controller .....                                                   | 3239        |
| 22.1.1     | High-Speed USB OTG Controller Overview .....                                          | 3239        |
| 22.1.1.1   | Main Features .....                                                                   | 3239        |
| 22.1.1.2   | High-Speed USB OTG Controller Environment .....                                       | 3241        |
| 22.1.2.1   | High-Speed USB Controller Functional Interfaces .....                                 | 3242        |
| 22.1.2.1.1 | Basic High-Speed USB Controller Pins .....                                            | 3242        |
| 22.1.2.1.2 | High-Speed USB Controller Interface Description .....                                 | 3242        |
| 22.1.3     | High-Speed USB OTG Controller Integration .....                                       | 3243        |
| 22.1.3.1   | Clocking, Reset, and Power-Management Scheme .....                                    | 3243        |
| 22.1.3.1.1 | Clocks .....                                                                          | 3243        |
| 22.1.3.1.2 | Resets .....                                                                          | 3244        |
| 22.1.3.1.3 | Power-Management Scheme .....                                                         | 3244        |
| 22.1.3.1.4 | Power Domain .....                                                                    | 3247        |
| 22.1.3.2   | Hardware Requests .....                                                               | 3247        |
| 22.1.3.2.1 | Interrupt Requests .....                                                              | 3247        |
| 22.1.3.2.2 | IDLE Handshake Protocol .....                                                         | 3248        |
| 22.1.3.2.3 | MSTANDBY Handshake Protocol .....                                                     | 3248        |

---

|            |                                                               |      |
|------------|---------------------------------------------------------------|------|
| 22.1.3.2.4 | Wake-Up Request .....                                         | 3248 |
| 22.1.4     | High-Speed USB OTG Controller Functional Description .....    | 3249 |
| 22.1.4.1   | Inventra™ MUSBMHDRC .....                                     | 3249 |
| 22.1.4.2   | Configuration .....                                           | 3250 |
| 22.1.4.3   | Basic Operation .....                                         | 3250 |
| 22.1.4.3.1 | Module Initialization .....                                   | 3250 |
| 22.1.4.3.2 | Transaction Handling .....                                    | 3251 |
| 22.1.4.4   | Optional Features .....                                       | 3251 |
| 22.1.4.4.1 | Double Packet Buffering .....                                 | 3251 |
| 22.1.4.4.2 | High-Speed USB OTG Support for Big Endian .....               | 3251 |
| 22.1.4.4.3 | DMA .....                                                     | 3253 |
| 22.1.4.5   | Automatic Packet Splitting/Combining for Bulk Transfers ..... | 3254 |
| 22.1.4.6   | High-Bandwidth Isochronous Endpoints .....                    | 3254 |
| 22.1.5     | High-Speed USB OTG Controller Basic Programming Model .....   | 3254 |
| 22.1.5.1   | High-Speed USB Controller Interface Selection .....           | 3254 |
| 22.1.5.2   | Enable Simulation Acceleration Features .....                 | 3254 |
| 22.1.5.3   | Enabling MSTANDBY in Force-Standby Mode .....                 | 3255 |
| 22.1.5.4   | Power Management Basic Programming Model .....                | 3255 |
| 22.1.5.4.1 | High-Speed USB Controller Not Used for Application .....      | 3255 |
| 22.1.5.4.2 | High-Speed USB Controller in Host Mode .....                  | 3255 |
| 22.1.5.4.3 | High-Speed USB Controller in Peripheral Mode .....            | 3256 |
| 22.1.5.4.4 | High-Speed USB Controller in Host/Peripheral Mode .....       | 3256 |
| 22.1.6     | High-Speed USB OTG Controller Register Manual .....           | 3258 |
| 22.1.6.1   | High-Speed USB OTG Controller Registers .....                 | 3258 |
| 22.1.6.1.1 | High-Speed USB Register Summary .....                         | 3258 |
| 22.1.6.1.2 | High-Speed USB Register Description .....                     | 3258 |
| 22.2       | High-Speed USB Host Subsystem .....                           | 3262 |
| 22.2.1     | High-Speed USB Host Subsystem Overview .....                  | 3262 |
| 22.2.1.1   | Main Features .....                                           | 3263 |
| 22.2.2     | High-Speed USB Host Subsystem Environment .....               | 3266 |
| 22.2.2.1   | Standard USB Implementation: Transceiver Connection .....     | 3266 |
| 22.2.2.2   | TLL Connection .....                                          | 3266 |
| 22.2.2.3   | ULPI Interfaces .....                                         | 3267 |
| 22.2.2.3.1 | Transceiver Interface Configurations .....                    | 3270 |
| 22.2.2.3.2 | TLL Configurations .....                                      | 3270 |
| 22.2.2.3.3 | High-Speed USB Host Subsystem Functional Interfaces .....     | 3272 |
| 22.2.2.4   | Serial Interfaces .....                                       | 3274 |
| 22.2.2.4.1 | Encoding in Serial Mode .....                                 | 3276 |
| 22.2.2.4.2 | Sideband Signals for Serial Modes .....                       | 3279 |
| 22.2.2.4.3 | Transceiver Interface Configurations .....                    | 3280 |
| 22.2.2.4.4 | TLL Configurations .....                                      | 3283 |
| 22.2.2.4.5 | High-Speed USB Host Subsystem Interface Description .....     | 3286 |
| 22.2.3     | High-Speed USB Host Subsystem Integration .....               | 3289 |
| 22.2.3.1   | Reset, Clocking, and Power-Management Scheme .....            | 3290 |
| 22.2.3.1.1 | High-Speed USB Host Subsystem Resets .....                    | 3291 |
| 22.2.3.1.2 | High-Speed USB Host Subsystem Clocks .....                    | 3291 |
| 22.2.3.1.3 | Power-Management Scheme .....                                 | 3294 |
| 22.2.3.2   | Hardware Requests .....                                       | 3298 |
| 22.2.3.2.1 | Interrupt Requests .....                                      | 3298 |
| 22.2.3.2.2 | IDLE Handshake Protocol .....                                 | 3298 |
| 22.2.3.2.3 | MSTANDBY Handshake Protocol .....                             | 3298 |
| 22.2.3.2.4 | Wake-Up Request .....                                         | 3298 |
| 22.2.4     | High-Speed USB Host Subsystem Functional Description .....    | 3299 |

|            |                                                                                             |             |
|------------|---------------------------------------------------------------------------------------------|-------------|
| 22.2.4.1   | High-Speed USB Host Controller Functionality .....                                          | 3299        |
| 22.2.4.1.1 | High-Speed USB Host Controller Architecture .....                                           | 3299        |
| 22.2.4.1.2 | OHCI Implementation Specifications .....                                                    | 3300        |
| 22.2.4.1.3 | UTMI Ports .....                                                                            | 3301        |
| 22.2.4.1.4 | ULPI Ports .....                                                                            | 3301        |
| 22.2.4.1.5 | Port Status .....                                                                           | 3301        |
| 22.2.4.1.6 | Save and Restore .....                                                                      | 3302        |
| 22.2.4.1.7 | L3 Burst Control .....                                                                      | 3302        |
| 22.2.4.2   | USBTLL Module Functionality .....                                                           | 3302        |
| 22.2.4.2.1 | Channels and Ports .....                                                                    | 3302        |
| 22.2.4.2.2 | Channel Architecture .....                                                                  | 3303        |
| 22.2.4.2.3 | Channel Configuration .....                                                                 | 3304        |
| 22.2.4.2.4 | VBUS Management and Emulations .....                                                        | 3307        |
| 22.2.4.2.5 | Multimode Serial Port .....                                                                 | 3308        |
| 22.2.4.2.6 | Attach/Connect Emulation for Serial TLL Modes .....                                         | 3309        |
| 22.2.4.2.7 | Save and Restore .....                                                                      | 3310        |
| 22.2.5     | High-Speed USB Host Subsystem Basic Programming Model .....                                 | 3311        |
| 22.2.5.1   | Selecting and Configuring USB Connectivity .....                                            | 3311        |
| 22.2.5.1.1 | ULPI Interface Selection .....                                                              | 3313        |
| 22.2.5.1.2 | Serial Interface Selection .....                                                            | 3314        |
| 22.2.5.2   | USBTLL Registers .....                                                                      | 3314        |
| 22.2.5.2.1 | TLL Control and Status Registers .....                                                      | 3314        |
| 22.2.5.2.2 | ULPI PHY-side Registers .....                                                               | 3315        |
| 22.2.6     | High-Speed USB Host Subsystem Register Manual .....                                         | 3316        |
| 22.2.6.1   | USBTLL ULPI PHY-Side Register Space .....                                                   | 3316        |
| 22.2.6.2   | L4-Core Interconnect Register Space .....                                                   | 3316        |
| 22.2.6.3   | High-Speed USB Host Subsystem Register Summary .....                                        | 3316        |
| 22.2.6.4   | High-Speed USB Host Subsystem Register Description .....                                    | 3320        |
| 22.2.6.4.1 | USBTLL Registers .....                                                                      | 3320        |
| 22.2.6.4.2 | UHH_config Registers .....                                                                  | 3353        |
| 22.2.6.4.3 | OHCI Registers .....                                                                        | 3358        |
| 22.2.6.4.4 | EHCI Registers .....                                                                        | 3376        |
| <b>23</b>  | <b>Memory Stick PRO Host Controller .....</b>                                               | <b>3391</b> |
| 23.1       | Memory Stick PRO Host Controller Overview .....                                             | 3392        |
| 23.1.1     | Main Features .....                                                                         | 3392        |
| <b>24</b>  | <b>MMC/SD/SDIO Card Interface .....</b>                                                     | <b>3393</b> |
| 24.1       | MMC/SD/SDIO Overview .....                                                                  | 3394        |
| 24.1.1     | MMC/SD/SDIO Features .....                                                                  | 3395        |
| 24.2       | MMC/SD/SDIO Environment .....                                                               | 3397        |
| 24.2.1     | MMC/SD/SDIO Connected to MMC, SD, or SDIO Card .....                                        | 3397        |
| 24.2.2     | MMC/SD/SDIO Connected to MMC, SD, or SDIO Card Through an External Transceiver Device ..... | 3397        |
| 24.2.3     | MMC/SD/SDIO Functional Interfaces .....                                                     | 3398        |
| 24.2.3.1   | Basic MMC/SD/SDIOi Pins Without External Transceiver .....                                  | 3398        |
| 24.2.3.2   | Basic MMC/SD/SDIO2 Pins With External Transceiver .....                                     | 3399        |
| 24.2.3.3   | MMC/SD/SDIO Protocol and Data Format .....                                                  | 3399        |
| 24.2.3.3.1 | Protocol .....                                                                              | 3400        |
| 24.2.3.3.2 | Data Format .....                                                                           | 3402        |
| 24.3       | MMC/SD/SDIO Integration .....                                                               | 3405        |
| 24.3.1     | Clocking, Reset, and Power-Management Scheme .....                                          | 3405        |
| 24.3.1.1   | Clocks .....                                                                                | 3405        |
| 24.3.1.1.1 | Module Clocks .....                                                                         | 3405        |
| 24.3.1.2   | Power Management .....                                                                      | 3406        |

---

|            |                                                                |      |
|------------|----------------------------------------------------------------|------|
| 24.3.1.2   | Resets .....                                                   | 3408 |
| 24.3.1.2.1 | Hardware Reset .....                                           | 3408 |
| 24.3.1.2.2 | Software Reset .....                                           | 3408 |
| 24.3.1.3   | Power Domain .....                                             | 3409 |
| 24.3.2     | Hardware Requests .....                                        | 3409 |
| 24.3.2.1   | DMA Requests .....                                             | 3409 |
| 24.3.2.1.1 | DMA Receive Mode .....                                         | 3409 |
| 24.3.2.1.2 | DMA Transmit Mode .....                                        | 3410 |
| 24.3.2.2   | Interrupt Requests .....                                       | 3411 |
| 24.3.2.2.1 | Interrupt-Driven Operation .....                               | 3412 |
| 24.3.2.2.2 | Polling .....                                                  | 3412 |
| 24.4       | MMC/SD/SDIO Functional Description .....                       | 3413 |
| 24.4.1     | Description .....                                              | 3413 |
| 24.4.2     | Mode Selection .....                                           | 3415 |
| 24.4.3     | Buffer Management .....                                        | 3415 |
| 24.4.3.1   | Data Buffer .....                                              | 3415 |
| 24.4.3.1.1 | Data Buffer Status .....                                       | 3418 |
| 24.4.4     | Transfer Process .....                                         | 3419 |
| 24.4.4.1   | Different Types of Commands .....                              | 3419 |
| 24.4.4.2   | Different Types of Responses .....                             | 3419 |
| 24.4.5     | Transfer or Command Status and Error Reporting .....           | 3419 |
| 24.4.5.1   | Busy Timeout For R1b, R5b Response Type .....                  | 3420 |
| 24.4.5.2   | Busy Timeout After Write CRC Status .....                      | 3420 |
| 24.4.5.3   | Write CRC Status Timeout .....                                 | 3421 |
| 24.4.5.4   | Read Data Timeout .....                                        | 3421 |
| 24.4.5.5   | Boot Acknowledge Timeout .....                                 | 3422 |
| 24.4.6     | Autocommand 12 Timings .....                                   | 3423 |
| 24.4.6.1   | Autocommand 12 Timings During Write Transfer .....             | 3423 |
| 24.4.6.2   | Autocommand 12 Timings During Read Transfer .....              | 3424 |
| 24.4.7     | Transfer Stop .....                                            | 3424 |
| 24.4.8     | MMC CE-ATA Command Completion Disable Management .....         | 3425 |
| 24.5       | MMC/SD/SDIO Basic Programming Model .....                      | 3426 |
| 24.5.1     | MMC/SD/SDIO Host Controller Initialization Flow .....          | 3426 |
| 24.5.1.1   | Enable Interface and Functional clock for MMC Controller ..... | 3426 |
| 24.5.1.2   | MMCHS Soft Reset Flow .....                                    | 3426 |
| 24.5.1.3   | Set MMCHS Default Capabilities .....                           | 3427 |
| 24.5.1.4   | Wake-Up Configuration .....                                    | 3427 |
| 24.5.1.5   | MMC Host and Bus Configuration .....                           | 3428 |
| 24.5.2     | Basic Operations for MMC/SD/SDIO Host Controller .....         | 3429 |
| 24.5.2.1   | Card Detection, Identification, and Selection .....            | 3430 |
| 24.5.2.2   | Read/Write Transfer Flow in DMA Mode With Interrupt .....      | 3431 |
| 24.5.2.3   | Read/Write Transfer Flow in DMA Mode With Polling .....        | 3432 |
| 24.5.2.4   | Read/Write Transfer Flow Wthout DMA and With Polling .....     | 3434 |
| 24.5.2.5   | Read/Write Transfer Flow in CE-ATA Mode .....                  | 3435 |
| 24.5.2.6   | Suspend-Resume Flow .....                                      | 3435 |
| 24.5.2.6.1 | Suspend Flow .....                                             | 3435 |
| 24.5.2.6.2 | Resume Flow .....                                              | 3436 |
| 24.5.2.7   | Basic Operations - Step Details .....                          | 3437 |
| 24.5.2.7.1 | Command Transfer Flow .....                                    | 3437 |
| 24.5.2.7.2 | MMCHS Clock Frequency Change .....                             | 3439 |
| 24.5.3     | MMC/SD/SDIO1 Bus Voltage Selection .....                       | 3440 |
| 24.6       | MMC/SD/SDIO Use Cases and Tips .....                           | 3442 |
| 24.6.1     | MMCHS Controller Usage .....                                   | 3442 |

|            |                                                         |             |
|------------|---------------------------------------------------------|-------------|
| 24.6.1.1   | Overview .....                                          | 3442        |
| 24.6.1.2   | Environment .....                                       | 3443        |
| 24.6.1.2.1 | Command and Data Transfer Formats .....                 | 3443        |
| 24.6.1.3   | Programming Flow .....                                  | 3444        |
| 24.6.1.3.1 | Initial Configuration .....                             | 3444        |
| 24.6.1.3.2 | MMC Card Identification .....                           | 3447        |
| 24.6.1.3.3 | MMC Bus Setting Change After Card Identification .....  | 3449        |
| 24.6.1.3.4 | Reading the CSD Register of an MMC Card .....           | 3449        |
| 24.6.1.3.5 | MMC Write Transfer .....                                | 3451        |
| 24.6.1.3.6 | MMC Read Transfer .....                                 | 3453        |
| 24.6.1.3.7 | Dealing With High-Capacity Cards .....                  | 3453        |
| 24.7       | MMC/SD/SDIO Register Manual .....                       | 3454        |
| 24.7.1     | MMC/SD/SDIO Instance Summary .....                      | 3454        |
| 24.7.2     | MMC/SD/SDIO Registers .....                             | 3454        |
| 24.7.2.1   | MMC/SD/SDIO Register Summary .....                      | 3454        |
| 24.7.2.2   | MMCHS Registers .....                                   | 3455        |
| <b>25</b>  | <b>General-Purpose Interface .....</b>                  | <b>3493</b> |
| 25.1       | General-Purpose Interface Overview .....                | 3494        |
| 25.1.1     | Global Features .....                                   | 3494        |
| 25.2       | General-Purpose Interface Environment .....             | 3497        |
| 25.2.1     | GPIO as a Keyboard Interface .....                      | 3497        |
| 25.2.2     | General-Purpose Interface Functional Interfaces .....   | 3499        |
| 25.2.2.1   | General-Purpose Interface Pins .....                    | 3499        |
| 25.3       | General-Purpose Interface Integration .....             | 3500        |
| 25.3.1     | Description .....                                       | 3500        |
| 25.3.1.1   | Clocking, Reset, and Power-Management Scheme .....      | 3500        |
| 25.3.1.1.1 | Clocking .....                                          | 3500        |
| 25.3.1.1.2 | Reset .....                                             | 3501        |
| 25.3.1.1.3 | Power Domain .....                                      | 3501        |
| 25.3.1.1.4 | Power Management .....                                  | 3501        |
| 25.3.1.2   | Hardware Requests .....                                 | 3504        |
| 25.3.1.2.1 | Interrupt Requests .....                                | 3504        |
| 25.4       | General-Purpose Interface Functional Description .....  | 3507        |
| 25.4.1     | Operational Description .....                           | 3508        |
| 25.4.1.1   | Interrupt and Wake-Up Features .....                    | 3508        |
| 25.4.1.1.1 | Synchronous Path: Interrupt Request Generation .....    | 3508        |
| 25.4.1.1.2 | Asynchronous Path: Wake-Up Request Generation .....     | 3509        |
| 25.4.1.1.3 | Interrupt (or Wake-Up) Line Release .....               | 3510        |
| 25.5       | General-Purpose Interface Basic Programming Model ..... | 3511        |
| 25.5.1     | Power Saving by Grouping the Edge/Level Detection ..... | 3511        |
| 25.5.2     | Set and Clear Instructions .....                        | 3511        |
| 25.5.2.1   | Description .....                                       | 3511        |
| 25.5.2.2   | Clear Instruction .....                                 | 3511        |
| 25.5.2.2.1 | Clear Register Addresses .....                          | 3511        |
| 25.5.2.2.2 | Clear Instruction Example .....                         | 3512        |
| 25.5.2.3   | Set Instruction .....                                   | 3512        |
| 25.5.2.3.1 | Set Register Addresses .....                            | 3512        |
| 25.5.2.3.2 | Set Instruction Example .....                           | 3513        |
| 25.5.3     | Interrupt and Wakeup .....                              | 3513        |
| 25.5.3.1   | Involved Configuration Registers .....                  | 3513        |
| 25.5.3.2   | Description .....                                       | 3514        |
| 25.5.4     | Data Input (Capture)/Output (Drive) .....               | 3515        |
| 25.5.5     | Debouncing Time .....                                   | 3516        |

---

|           |                                                                            |             |
|-----------|----------------------------------------------------------------------------|-------------|
| 25.6      | General-Purpose Interface Register Manual .....                            | 3517        |
|           | 25.6.1 General-Purpose Interface Register Mapping Summary .....            | 3517        |
|           | 25.6.2 Register Descriptions .....                                         | 3521        |
| <b>26</b> | <b>Initialization .....</b>                                                | <b>3541</b> |
| 26.1      | Initialization Overview .....                                              | 3542        |
|           | 26.1.1 Terminology .....                                                   | 3542        |
|           | 26.1.2 Initialization Process .....                                        | 3542        |
| 26.2      | Preinitialization .....                                                    | 3543        |
|           | 26.2.1 Power Connections .....                                             | 3543        |
|           | 26.2.2 Clock and Reset .....                                               | 3545        |
|           | 26.2.2.1 Clock and Reset Overview .....                                    | 3545        |
|           | 26.2.2.2 Clock Configuration .....                                         | 3546        |
|           | 26.2.2.2.1 Required System Input Clocks .....                              | 3546        |
|           | 26.2.2.2.2 Optional System Input Clock: sys_altcclk .....                  | 3547        |
|           | 26.2.2.2.3 Optional System Output Clock: sys_clkout1 and sys_clkout2 ..... | 3547        |
|           | 26.2.2.2.3 Reset Configuration .....                                       | 3547        |
|           | 26.2.3 Boot Configuration .....                                            | 3548        |
| 26.3      | Power, Clocks, and Reset Power-Up Sequence .....                           | 3552        |
| 26.4      | Device Initialization by ROM Code .....                                    | 3552        |
|           | 26.4.1 Booting Overview .....                                              | 3552        |
|           | 26.4.1.1 Booting Types .....                                               | 3552        |
|           | 26.4.1.2 Main Features .....                                               | 3553        |
|           | 26.4.2 Memory Map .....                                                    | 3555        |
|           | 26.4.2.1 ROM Memory Map .....                                              | 3555        |
|           | 26.4.2.2 RAM Memory Map .....                                              | 3556        |
|           | 26.4.3 Overall Booting Sequence .....                                      | 3559        |
|           | 26.4.4 Startup and Configuration .....                                     | 3560        |
|           | 26.4.4.1 Startup .....                                                     | 3560        |
|           | 26.4.4.2 Clocking Configuration .....                                      | 3560        |
|           | 26.4.4.3 Booting Device List Setup .....                                   | 3561        |
|           | 26.4.4.4 Software Booting Configuration .....                              | 3562        |
|           | 26.4.5 Peripheral Booting .....                                            | 3564        |
|           | 26.4.5.1 Overview .....                                                    | 3564        |
|           | 26.4.5.2 UART .....                                                        | 3567        |
|           | 26.4.5.3 USB .....                                                         | 3567        |
|           | 26.4.5.3.1 USB Driver Descriptors .....                                    | 3567        |
|           | 26.4.5.3.2 USB Customized Descriptors .....                                | 3571        |
|           | 26.4.5.3.3 USB Driver Functionality .....                                  | 3571        |
|           | 26.4.5.6 Fast External Booting .....                                       | 3572        |
|           | 26.4.6.1 Overview .....                                                    | 3572        |
|           | 26.4.6.2 External Booting .....                                            | 3572        |
|           | 26.4.7 Memory Booting .....                                                | 3573        |
|           | 26.4.7.1 Overview .....                                                    | 3573        |
|           | 26.4.7.2 Non-XIP Memory .....                                              | 3574        |
|           | 26.4.7.3 XIP Memory .....                                                  | 3576        |
|           | 26.4.7.3.1 GPMC Initialization .....                                       | 3576        |
|           | 26.4.7.4 NAND .....                                                        | 3577        |
|           | 26.4.7.4.1 Initialization and NAND Detection .....                         | 3577        |
|           | 26.4.7.4.2 SLC NAND Read Sector Procedure .....                            | 3584        |
|           | 26.4.7.4.3 MLC NAND Read Sector Procedure .....                            | 3586        |
|           | 26.4.7.5 OneNAND/Flex-OneNAND .....                                        | 3588        |
|           | 26.4.7.5.1 Initialization and OneNAND/Flex-OneNAND Detection .....         | 3588        |
|           | 26.4.7.5.2 OneNAND/Flex-OneNAND Read Sector Procedure .....                | 3589        |

|            |                                                  |             |
|------------|--------------------------------------------------|-------------|
| 26.4.7.5.3 | OneNAND/Flex-OneNAND Support Limitations .....   | 3590        |
| 26.4.7.6   | MMC/SD Cards .....                               | 3590        |
| 26.4.7.6.1 | Initialization and MMC/SD Card Detection .....   | 3592        |
| 26.4.7.6.2 | Read Sector Procedure .....                      | 3593        |
| 26.4.7.6.3 | File System Handling .....                       | 3593        |
| 26.4.7.7   | DiskOnChip .....                                 | 3599        |
| 26.4.8     | Image Format .....                               | 3599        |
| 26.4.8.1   | Overview .....                                   | 3599        |
| 26.4.8.2   | Configuration Header .....                       | 3600        |
| 26.4.8.2.1 | CHSETTINGS .....                                 | 3601        |
| 26.4.8.2.2 | CHRAM .....                                      | 3602        |
| 26.4.8.2.3 | CHFLASH .....                                    | 3603        |
| 26.4.8.2.4 | CHMMCSD .....                                    | 3604        |
| 26.4.8.3   | Image Format for GP Devices .....                | 3605        |
| 26.4.8.4   | Image Execution .....                            | 3605        |
| 26.4.9     | Tracing .....                                    | 3606        |
| 26.5       | Wake-Up Booting by ROM Code .....                | 3608        |
| 26.6       | Debug Configuration .....                        | 3612        |
| 26.6.1     | Overview .....                                   | 3612        |
| 26.6.2     | JTAG Port Signal Description .....               | 3612        |
| 26.6.3     | Initial Scan Chain Configuration .....           | 3612        |
| 26.6.4     | Adding TAPs to the Scan Chain .....              | 3613        |
| 26.6.5     | Debugger Address Space .....                     | 3613        |
| <b>27</b>  | <b>Debug and Emulation .....</b>                 | <b>3615</b> |
| 27.1       | Debug and Emulation Overview .....               | 3616        |
| 27.1.1     | Debug and Emulation Overview Features .....      | 3616        |
| 27.1.2     | Debug and Emulation Functional Description ..... | 3616        |
| 27.1.2.1   | ICEPick .....                                    | 3616        |
| 27.1.2.2   | SDTI .....                                       | 3617        |
| 27.1.2.3   | EPM .....                                        | 3617        |
| 27.1.2.4   | DAP .....                                        | 3617        |
| 27.1.2.5   | ETM .....                                        | 3617        |
| 27.1.2.6   | ETB .....                                        | 3617        |
| 27.1.2.7   | TPIU .....                                       | 3617        |
| 27.2       | ICEPick Module .....                             | 3618        |
| 27.2.1     | ICEPick Overview .....                           | 3618        |
| 27.2.2     | ICEPick Environment .....                        | 3618        |
| 27.2.3     | ICEPick Integration .....                        | 3619        |
| 27.2.4     | ICEPick Functional Description .....             | 3619        |
| 27.2.4.1   | ICEPick Block Diagram .....                      | 3619        |
| 27.2.4.2   | ICEPick Secondary Debug TAPs .....               | 3620        |
| 27.2.4.3   | ICEPick TAP states .....                         | 3620        |
| 27.2.4.4   | ICEPick Boot Modes .....                         | 3621        |
| 27.2.4.5   | ICEPick Instructions .....                       | 3621        |
| 27.2.4.5.1 | ICEPick Instruction List .....                   | 3621        |
| 27.2.4.5.2 | Instruction Register Scan Path and State .....   | 3622        |
| 27.2.4.5.3 | Data Shift Register Scan Path and State .....    | 3622        |
| 27.2.4.6   | ICEPick Registers .....                          | 3625        |
| 27.2.4.6.1 | Registers .....                                  | 3625        |
| 27.2.4.6.2 | Register Reset Conditions .....                  | 3626        |
| 27.2.4.6.3 | Register Description .....                       | 3626        |
| 27.2.5     | ICEPick Basic Programming Model .....            | 3635        |
| 27.2.5.1   | Basic Initialization .....                       | 3635        |

---

|            |                                                |             |
|------------|------------------------------------------------|-------------|
| 27.2.5.2   | Adding a TAP in the Debug Chain .....          | 3636        |
| 27.3       | SDTI Module .....                              | 3638        |
| 27.3.1     | SDTI Overview .....                            | 3638        |
| 27.3.2     | SDTI Environment .....                         | 3638        |
| 27.3.2.1   | SDTI Pins Configuration Mode .....             | 3639        |
| 27.3.2.2   | SDTI Protocol .....                            | 3639        |
| 27.3.2.3   | SDTI Data Format .....                         | 3640        |
| 27.3.3     | SDTI Integration .....                         | 3642        |
| 27.3.3.1   | Clocking and Reset .....                       | 3642        |
| 27.3.3.1.1 | Clocks .....                                   | 3642        |
| 27.3.3.1.2 | Reset .....                                    | 3642        |
| 27.3.4     | SDTI Functional Description .....              | 3643        |
| 27.3.4.1   | SDTI Block Diagram .....                       | 3643        |
| 27.3.4.2   | SDTI Ownership .....                           | 3643        |
| 27.3.4.2.1 | Ownership States .....                         | 3643        |
| 27.3.4.2.2 | Ownership Commands .....                       | 3644        |
| 27.3.4.2.3 | Claim Bits .....                               | 3644        |
| 27.3.4.2.4 | Claim Resets .....                             | 3645        |
| 27.3.4.3   | Trace Data Collection .....                    | 3645        |
| 27.3.4.4   | Trace Buffer FIFO .....                        | 3646        |
| 27.3.4.5   | Serial Interface Test Pattern Generation ..... | 3646        |
| 27.3.4.5.1 | Simple Patterns .....                          | 3647        |
| 27.3.4.5.2 | Walking Ones .....                             | 3647        |
| 27.3.4.5.3 | Ramp Pattern .....                             | 3647        |
| 27.3.4.5.4 | Pseudo Random (LFSR) Pattern .....             | 3647        |
| 27.3.4.6   | CoreSight Integration Mode .....               | 3648        |
| 27.3.4.7   | Serial Interface Clock Generation .....        | 3648        |
| 27.3.4.8   | SDTI Memory Mapping .....                      | 3648        |
| 27.3.4.9   | SDTI Error Handling .....                      | 3649        |
| 27.3.5     | SDTI Basic Programming Model .....             | 3650        |
| 27.3.5.1   | Trace Setup .....                              | 3650        |
| 27.3.5.2   | Serial Interface Test Mode Setup .....         | 3650        |
| 27.3.5.3   | CoreSight Integration Mode Setup .....         | 3651        |
| 27.3.5.4   | SDTI Register Ownership .....                  | 3651        |
| 27.3.6     | SDTI Register Manual .....                     | 3652        |
| 27.3.6.1   | SDTI Register Summary .....                    | 3652        |
| 27.3.6.2   | SDTI Register Description .....                | 3653        |
| 27.4       | Emulation Pin Manager .....                    | 3670        |
| 27.4.1     | EPM Overview .....                             | 3670        |
| 27.4.2     | EPM Integration .....                          | 3670        |
| 27.4.3     | EPM Functional Description .....               | 3670        |
| 27.4.3.1   | EPM Overview .....                             | 3670        |
| 27.4.3.2   | EPM Multiplexing .....                         | 3670        |
| 27.4.3.3   | Concurrent Debug Support .....                 | 3673        |
| 27.4.3.4   | EPM Control Access .....                       | 3673        |
| 27.4.3.5   | Claim Procedure .....                          | 3674        |
| 27.4.4     | EPM Programming Model .....                    | 3675        |
| 27.4.4.1   | EPM Concurrent Debug Examples .....            | 3675        |
| 27.4.5     | EPM Register Manual .....                      | 3676        |
| 27.4.5.1   | EPM Register Summary .....                     | 3676        |
| 27.4.5.2   | EPM Register Description .....                 | 3676        |
| <b>A</b>   | <b>Glossary .....</b>                          | <b>3679</b> |

---

---

## List of Figures

|       |                                                                  |     |
|-------|------------------------------------------------------------------|-----|
| 1-1.  | AM/DM37x Environment Using TPS65950 .....                        | 186 |
| 1-2.  | Block Diagram .....                                              | 187 |
| 1-3.  | POP Concept (CBP Package) .....                                  | 193 |
| 1-4.  | Stacked Memory Package on the POP Device (CBP Package) .....     | 193 |
| 1-5.  | Stacked Memory Package on the POP Device (CBP Package) .....     | 194 |
| 2-1.  | Interconnect Overview.....                                       | 203 |
| 2-2.  | IVA2.2 Subsystem Memory Hierarchy .....                          | 217 |
| 2-3.  | L1D RAM Cache Allocation Example (L3 Interconnect View) .....    | 218 |
| 2-4.  | IVA2.2 iMMU Address Translation.....                             | 219 |
| 3-1.  | Comparison of Energy Consumption With/Without DVFS.....          | 224 |
| 3-2.  | SmartReflex Example .....                                        | 225 |
| 3-3.  | Comparison of Energy Consumed With/Without DPS .....             | 226 |
| 3-4.  | Performance Level and Applied Power-Management Techniques.....   | 228 |
| 3-5.  | Generic Clock Domain .....                                       | 229 |
| 3-6.  | Generic Power Domain .....                                       | 229 |
| 3-7.  | Generic Voltage Domain.....                                      | 231 |
| 3-8.  | Voltage, Power, and Clock Domain Hierarchical Architecture ..... | 232 |
| 3-9.  | Functional and Interface Clocks .....                            | 233 |
| 3-10. | SmartReflex Voltage-Control Functional Overview.....             | 235 |
| 3-11. | PRCM Overview .....                                              | 238 |
| 3-12. | PRCM Functional External Interface (Detailed View) .....         | 240 |
| 3-13. | External Clock Interface.....                                    | 241 |
| 3-14. | PRCM External Clock Sources.....                                 | 242 |
| 3-15. | External Reset Signals .....                                     | 243 |
| 3-16. | Power Control Interface for External Power IC .....              | 243 |
| 3-17. | PRCM Integration .....                                           | 245 |
| 3-18. | Device Power Domains .....                                       | 246 |
| 3-19. | PRCM Reset Signals .....                                         | 248 |
| 3-20. | Reset Manager Interface With Generic Power Domain.....           | 249 |
| 3-21. | Reset Sources Overview.....                                      | 251 |
| 3-22. | Reset Destination Overview .....                                 | 254 |
| 3-23. | External Warm Reset Interface .....                              | 258 |
| 3-24. | Device Reset Manager Overview .....                              | 260 |
| 3-25. | Power Domain Reset Management: Part 1 .....                      | 261 |
| 3-26. | Power Domain Reset Management: Part 2 .....                      | 262 |
| 3-27. | Power Domain Reset Management: Part 3 .....                      | 263 |
| 3-28. | Power-Up Sequence.....                                           | 267 |
| 3-29. | Warm Reset Sequence .....                                        | 270 |
| 3-30. | IVA2.2 Subsystem Power-Up Reset Sequence.....                    | 272 |
| 3-31. | IVA2 Software Reset Sequence .....                               | 274 |
| 3-32. | IVA2 Global Warm Reset Sequence .....                            | 276 |
| 3-33. | IVA2 Power Domain Power Transition Reset Sequence .....          | 278 |
| 3-34. | Power Control Overview .....                                     | 281 |
| 3-35. | PRCM Clock Manager Overview .....                                | 291 |
| 3-36. | External Clock I/O.....                                          | 292 |
| 3-37. | Internal Clock Sources .....                                     | 294 |
| 3-38. | PRM Clock Generator .....                                        | 296 |

---

|       |                                                                         |     |
|-------|-------------------------------------------------------------------------|-----|
| 3-39. | CM Clock Generator Functional Overview .....                            | 298 |
| 3-40. | Generic DPLL Functional Diagram .....                                   | 300 |
| 3-41. | DPLL3 Clocks .....                                                      | 302 |
| 3-42. | DPLL5 Clocks .....                                                      | 303 |
| 3-43. | DPLL4 Functional Diagram .....                                          | 304 |
| 3-44. | DPLL4 Clocks .....                                                      | 305 |
| 3-45. | MPU Power Domain Clocking Scheme .....                                  | 308 |
| 3-46. | IVA2 Power Domain Clocking Scheme .....                                 | 309 |
| 3-47. | SGX Power Domain Clocking Scheme .....                                  | 310 |
| 3-48. | CORE Clock Signals: Part 1.....                                         | 311 |
| 3-49. | CORE Clock Signals: Part 2.....                                         | 312 |
| 3-50. | CORE Clock Signals: Part 3.....                                         | 313 |
| 3-51. | EFUSE Clock Signals .....                                               | 314 |
| 3-52. | DSS Clock Signals.....                                                  | 315 |
| 3-53. | CAM Clock Signals .....                                                 | 316 |
| 3-54. | USBHOST Clock Signals .....                                             | 317 |
| 3-55. | WKUP Clock Signals .....                                                | 318 |
| 3-56. | PER Clock Signals.....                                                  | 319 |
| 3-57. | SMARTREFLEX Clock Signals .....                                         | 320 |
| 3-58. | DPLL Clock Signals .....                                                | 321 |
| 3-59. | System Clock Oscillator Controls .....                                  | 327 |
| 3-60. | Common PRM Source-Clock Controls.....                                   | 334 |
| 3-61. | Common CM Source-Clock Controls.....                                    | 336 |
| 3-62. | Common Interface Clock Controls .....                                   | 337 |
| 3-63. | DPLL Power Domain Clock Controls.....                                   | 338 |
| 3-64. | SGX Power Domain Clock Controls .....                                   | 339 |
| 3-65. | CORE Power Domain Clock Controls: Part 1 .....                          | 340 |
| 3-66. | CORE Power Domain Clock Controls: Part 2 .....                          | 341 |
| 3-67. | EFUSE Power Domain Clock Controls .....                                 | 342 |
| 3-68. | DSS Power Domain Clock Controls .....                                   | 343 |
| 3-69. | CAM Power Domain Clock Controls .....                                   | 344 |
| 3-70. | USBHOST Power Domain Clock Controls .....                               | 344 |
| 3-71. | WKUP Power Domain Clock Controls .....                                  | 345 |
| 3-72. | PER Power Domain Clock Controls: Part 1 .....                           | 346 |
| 3-73. | PER Power Domain Clock Controls: Part 2 .....                           | 347 |
| 3-74. | SMARTREFLEX Power Domain Clock Controls.....                            | 348 |
| 3-75. | Power Domain Sleep/Wake-Up Transition .....                             | 353 |
| 3-76. | Device Power Reset and Clock Controllers .....                          | 354 |
| 3-77. | Save-and-Restore Sequence.....                                          | 367 |
| 3-78. | Overview of Device Voltage Domains.....                                 | 372 |
| 3-79. | Overview of Device Voltage Distribution .....                           | 374 |
| 3-80. | PRM Voltage Control Architecture .....                                  | 378 |
| 3-81. | Voltage Transition Controlled by sys_nvmode2 .....                      | 379 |
| 3-82. | SmartReflex Integration .....                                           | 381 |
| 3-83. | SmartReflex Module Functional Overview.....                             | 382 |
| 3-84. | Voltage Processor Functional Overview .....                             | 386 |
| 3-85. | SmartReflex - SMPS Communication for Automatic Voltage Adjustments..... | 389 |
| 3-86. | Device Off-Mode Control Overview .....                                  | 392 |
| 3-87. | sys_clkout2 Gating Polarity Control .....                               | 401 |

|                                                                |     |
|----------------------------------------------------------------|-----|
| 3-88. Off Mode Wakeup Using I <sup>2</sup> C.....              | 420 |
| 3-89. OFF Mode Wakeup Using SYS_OFF_MODE .....                 | 421 |
| 3-90. Functional Clock Basic Programming Model .....           | 425 |
| 3-91. Functional Clock Switching .....                         | 426 |
| 3-92. Interface Clock Basic Programming Model.....             | 427 |
| 3-93. Domain Inactive STATE Basic Programming Model .....      | 428 |
| 3-94. Processor Clock Basic Programming Model .....            | 430 |
| 3-95. Wake-up Basic Programming Model .....                    | 432 |
| 3-96. SmartReflex Initialization Flow Chart.....               | 433 |
| 3-97. Voltage Processor Initialization Flow Chart.....         | 436 |
| 3-98. Voltage Controller Initialization Flow Chart .....       | 439 |
| 3-99. SmartReflex - OPP Change Flow Chart .....                | 442 |
| 3-100. Voltage Processor - OPP Change Flow Chart .....         | 445 |
| 4-1. MPU Subsystem Overview .....                              | 664 |
| 4-2. MPU Subsystem Integration Overview.....                   | 666 |
| 4-3. MPU Subsystem Clocking Scheme .....                       | 667 |
| 4-4. MPU Subsystem Reset Scheme.....                           | 669 |
| 4-5. MPU Subsystem Power Domain Overview.....                  | 673 |
| 5-1. IVA2.2 Subsystem Highlight .....                          | 682 |
| 5-2. IVA2.2 Subsystem Integration.....                         | 685 |
| 5-3. IVA2.2 Subsystem Resets .....                             | 687 |
| 5-4. IVA2.2 Power Domain .....                                 | 689 |
| 5-5. IVA2.2 EDMA Requests.....                                 | 690 |
| 5-6. IVA2.2 Interrupt Management .....                         | 692 |
| 5-7. IVA2.2 Subsystem Block Diagram.....                       | 695 |
| 5-8. DSP Megamodule Block Diagram .....                        | 696 |
| 5-9. DSP Megamodule INTC Block Diagram .....                   | 700 |
| 5-10. Interrupt Selector Block Diagram .....                   | 702 |
| 5-11. IVA2.2 EDMA Overview .....                               | 706 |
| 5-12. TPCC Block Diagram.....                                  | 707 |
| 5-13. DMA/QDMA Channel Mapping and PaRAM Entry .....           | 709 |
| 5-14. TPTC Block Diagram .....                                 | 712 |
| 5-15. Transfer Geometry.....                                   | 713 |
| 5-16. IVA2.2 MMU Block Diagram.....                            | 717 |
| 5-17. IVA2.2 MMU Translation Table Hierarchy .....             | 718 |
| 5-18. SL2 Memory Interface Block Diagram .....                 | 721 |
| 5-19. IVA2.2 WUGEN Description .....                           | 723 |
| 5-20. WUGEN Event Generation .....                             | 724 |
| 5-21. WUGEN Event Masking.....                                 | 725 |
| 5-22. WUGEN Event Mask Clear .....                             | 726 |
| 5-23. SYSC Block Diagram.....                                  | 727 |
| 5-24. IVA2.2 Local Memories Hierarchy .....                    | 730 |
| 5-25. IVA2 Boot Mode Configuration .....                       | 733 |
| 5-26. IVA2 Boot Basic Programming Model.....                   | 737 |
| 5-27. iME/iLF Typical Use Flow Chart .....                     | 763 |
| 5-28. iLCD Typical Use Flow hart.....                          | 764 |
| 5-29. IVA2.2 Interrupt Flow .....                              | 772 |
| 5-30. Process of Identifying Source Event of an Interrupt..... | 778 |
| 5-31. L1P Memory Protection Registers .....                    | 779 |

---

|       |                                                                                 |      |
|-------|---------------------------------------------------------------------------------|------|
| 5-32. | L1D Memory Protection Registers .....                                           | 780  |
| 5-33. | L2 Memory Protection Registers .....                                            | 780  |
| 5-34. | IVA2 Power Off .....                                                            | 790  |
| 5-35. | IVA2 Power Down .....                                                           | 791  |
| 5-36. | IVA2 Wake Up .....                                                              | 792  |
| 6-1.  | Camera ISP Overview Diagram .....                                               | 1081 |
| 6-2.  | Camera ISP Synchronization Signals and Frame Timing in SYNC Mode .....          | 1090 |
| 6-3.  | Camera ISP Synchronization Signals and Data Timing in SYNC Mode .....           | 1090 |
| 6-4.  | Camera ISP SYNC Mode Clock Gating .....                                         | 1091 |
| 6-5.  | Camera ISP JPEG Stream Timing Diagrams .....                                    | 1091 |
| 6-6.  | Camera ISP Data Timing With Embedded Synchronization Signals (8-Bit Case) ..... | 1092 |
| 6-7.  | Camera ISP Example of 0xFF00 0002 Transmission .....                            | 1096 |
| 6-8.  | Camera ISP CSI1/CCP2 YUV422 Big Endian .....                                    | 1096 |
| 6-9.  | Camera ISP CSI1/CCP2 YUV422 Little Endian .....                                 | 1097 |
| 6-10. | Camera ISP CSI1/CCP2 YUV420 .....                                               | 1098 |
| 6-11. | Camera ISP CSI1/CCP2 RGB888 .....                                               | 1099 |
| 6-12. | Camera ISP CSI1/CCP2 RGB565 .....                                               | 1100 |
| 6-13. | Camera ISP CSI1/CCP2 RGB444 .....                                               | 1100 |
| 6-14. | Camera ISP CSI1/CCP2 RAW 6 .....                                                | 1101 |
| 6-15. | Camera ISP CSI1/CCP2 RAW 7 .....                                                | 1102 |
| 6-16. | Camera ISP CSI1/CCP2 RAW8 .....                                                 | 1103 |
| 6-17. | Camera ISP CSI1/CCP2 RAW10 .....                                                | 1104 |
| 6-18. | Camera ISP CSI1/CCP2 RAW12 .....                                                | 1105 |
| 6-19. | Camera ISP CSI1/CCP2 JPEG8 and JPEG8 FSP .....                                  | 1106 |
| 6-20. | Camera ISP CSI2 Two Data-Lane Merger Configuration .....                        | 1107 |
| 6-21. | Camera ISP CSI2 One Data-Lane Configuration .....                               | 1107 |
| 6-22. | Camera ISP CSI2 Protocol Layer With Short and Long Packets .....                | 1108 |
| 6-23. | Camera ISP CSI2 Short Packet Structure .....                                    | 1108 |
| 6-24. | Camera ISP CSI2 Long Packet Structure .....                                     | 1109 |
| 6-25. | Camera ISP CSI2 Data Identifier Structure .....                                 | 1110 |
| 6-26. | Camera ISP CSI2 Virtual Channel .....                                           | 1110 |
| 6-27. | Camera ISP CSI2 General Frame Structure (Informative) .....                     | 1113 |
| 6-28. | Camera ISP CSI2 Digital Interlaced Video Frame (Informative) .....              | 1114 |
| 6-29. | Camera ISP CSI2 YUV420 8-Bit .....                                              | 1115 |
| 6-30. | Camera ISP CSI2 YUV420 10-Bit .....                                             | 1116 |
| 6-31. | Camera ISP CSI2 YUV420 8-Bit Legacy .....                                       | 1117 |
| 6-32. | Camera ISP CSI2 YUV420 8-Bit + CSPS .....                                       | 1118 |
| 6-33. | Camera ISP CSI2 YUV420 10-Bit + CSPS .....                                      | 1119 |
| 6-34. | Camera ISP CSI2 YUV422 8-Bit .....                                              | 1120 |
| 6-35. | Camera ISP CSI2 YUV422 10-Bit .....                                             | 1120 |
| 6-36. | Camera ISP CSI2 RGB565 .....                                                    | 1121 |
| 6-37. | Camera ISP CSI2 RGB888 .....                                                    | 1122 |
| 6-38. | Camera ISP CSI2 RGB666 .....                                                    | 1123 |
| 6-39. | Camera ISP CSI2 RGB444 .....                                                    | 1124 |
| 6-40. | Camera ISP CSI2 RGB555 .....                                                    | 1124 |
| 6-41. | Camera ISP CSI2 RAW6 .....                                                      | 1125 |
| 6-42. | Camera ISP CSI2 RAW7 .....                                                      | 1126 |
| 6-43. | Camera ISP CSI2 RAW8 .....                                                      | 1127 |
| 6-44. | Camera ISP CSI2 RAW10 .....                                                     | 1128 |

---

|                                                                                                        |      |
|--------------------------------------------------------------------------------------------------------|------|
| 6-45. Camera ISP CSI2 RAW12 .....                                                                      | 1129 |
| 6-46. Camera ISP CSI2 RAW14 .....                                                                      | 1130 |
| 6-47. Camera ISP CSI2 JPEG8 .....                                                                      | 1131 |
| 6-48. Camera ISP CSI2 Generic .....                                                                    | 1131 |
| 6-49. Camera ISP CSI2 Byte-Swap.....                                                                   | 1132 |
| 6-50. Camera ISP Integration.....                                                                      | 1133 |
| 6-51. Camera ISP Clock Tree Diagram .....                                                              | 1134 |
| 6-52. Camera ISP Interrupt Generation Tree .....                                                       | 1139 |
| 6-53. Camera ISP Block Diagram.....                                                                    | 1149 |
| 6-54. Camera ISP/Data Path/RAW RGB Images .....                                                        | 1151 |
| 6-55. Camera ISP / Data Path/YUV4:2:2 Images .....                                                     | 1152 |
| 6-56. Camera ISP/Data Path/JPEG Images .....                                                           | 1153 |
| 6-57. Camera ISP CSI1/CCP2B Receiver Block Diagram.....                                                | 1154 |
| 6-58. Camera ISP CSI1/CCP2B Synchronization State-Machine .....                                        | 1156 |
| 6-59. Camera ISP CSI1/CCP2B Frame Structure: Non-JPEG Data Format .....                                | 1157 |
| 6-60. Camera ISP CSI1/CCP2B Frame Structure: JPEG8 Data Format .....                                   | 1157 |
| 6-61. Camera ISP CSI1/CCP2B Data Structure .....                                                       | 1158 |
| 6-62. Camera ISP CSI1/CCP2B Muxing .....                                                               | 1159 |
| 6-63. Camera ISP CSI1/CCP2B Data Organization in Memory.....                                           | 1164 |
| 6-64. Camera ISP CSI1/CCP2B Data Organization in Memory Continued .....                                | 1165 |
| 6-65. Camera ISP CSI1/CCP2B Data Organization in Memory 3 .....                                        | 1166 |
| 6-66. Camera ISP CSI2 Receiver Block Diagram.....                                                      | 1171 |
| 6-67. Camera ISP CSI2 RAW Image Transcoding Diagram .....                                              | 1173 |
| 6-68. Camera ISP CSI2 Frame Cropping .....                                                             | 1174 |
| 6-69. Camera ISP CSI2 SHORT_PACKET Field Format.....                                                   | 1176 |
| 6-70. Camera ISP CSI2 Virtual Channel to Context.....                                                  | 1177 |
| 6-71. Camera ISP CSI2 Pixel Data Destination Setting in Progressive and Interlaced Mode .....          | 1179 |
| 6-72. Camera ISP CSI2 PHY Overview .....                                                               | 1179 |
| 6-73. Camera ISP CSIPHY Power FSM .....                                                                | 1180 |
| 6-74. Camera ISP CSI2 RxMode and StopState FSM .....                                                   | 1181 |
| 6-75. Camera ISP Timing Control block diagram .....                                                    | 1182 |
| 6-76. Camera ISP Timing Control Control-Signal Generation.....                                         | 1183 |
| 6-77. Camera ISP Timing Control Use of cam_global_reset With Global Reset Release Camera Modules ..... | 1185 |
| 6-78. Camera ISP CCDC Block Diagram .....                                                              | 1188 |
| 6-79. Camera ISP CCDC Optical Clamp Representation.....                                                | 1190 |
| 6-80. Camera ISP CCDC Data Formatter Conversion Area Selection.....                                    | 1192 |
| 6-81. Camera ISP CCDC/Culling: Example for Decimation Pattern.....                                     | 1195 |
| 6-82. Camera ISP CCDC A-Law Table.....                                                                 | 1196 |
| 6-83. Camera ISP CCDC/Line-Output Control: Sample Formats of Input and Output Images .....             | 1197 |
| 6-84. Camera ISP VPBE Preview Engine Block Diagram .....                                               | 1201 |
| 6-85. Camera ISP VPBE Preview Horizontal Distances for Different Patterns .....                        | 1202 |
| 6-86. Camera ISP VPBE Resizer Process.....                                                             | 1208 |
| 6-87. Camera ISP VPBE Resizer Resizer in Memory-Input Mode .....                                       | 1209 |
| 6-88. Camera ISP VPBE Resizer Typical Sample-Rate Converter.....                                       | 1210 |
| 6-89. Camera ISP VPBE Resizer Functionality .....                                                      | 1210 |
| 6-90. Camera ISP VPBE Resizer Approximation Scheme .....                                               | 1210 |
| 6-91. Camera ISP VPBE Resizer Cutoff Frequency for Low-Pass Filter .....                               | 1210 |
| 6-92. Camera ISP VPBE Resizer Alignment of Input Pixels to Tap Coefficients .....                      | 1212 |
| 6-93. Camera ISP VPBE Resizer Pseudo-Code Description of the Resizer Algorithm in the 4-Tap/8-Phase    |      |

---

|                                                                                                                 |      |
|-----------------------------------------------------------------------------------------------------------------|------|
| Mode .....                                                                                                      | 1213 |
| 6-94. Camera ISP VPBE Resizer Pseudo-Code Description of the Resizer Algorithm in the 7-Tap/4-Phase Mode .....  | 1214 |
| 6-95. Camera ISP Histogram Process.....                                                                         | 1220 |
| 6-96. Camera ISP Histogram Color Pattern Index .....                                                            | 1221 |
| 6-97. Camera ISP Histogram Region Priority.....                                                                 | 1222 |
| 6-98. Camera ISP Shared Buffer Logic Block Diagram .....                                                        | 1224 |
| 6-99. Camera ISP Circular Buffer Single Slice Buffer (Write Mode).....                                          | 1229 |
| 6-100. Camera ISP Circular Buffer Single Slice Buffer Example (Write Mode) .....                                | 1229 |
| 6-101. Camera ISP Circular Buffer Control Feedback Loop Example .....                                           | 1231 |
| 6-102. Camera ISP Circular Buffer Extended Slice Buffer Example .....                                           | 1232 |
| 6-103. Camera ISP Circular Buffer Fragmentation Support.....                                                    | 1232 |
| 6-104. Camera ISP Circular VRFB Buffer Performed Translation.....                                               | 1234 |
| 6-105. Camera ISP CSI1/CCP2B CCP2_CTRL.VP_CLK_POL Settings.....                                                 | 1245 |
| 6-106. Camera ISP CSI1/CCP2B SOF and EOF Region Settings.....                                                   | 1247 |
| 6-107. Camera ISP CSI1/CCP2B Pixel Data Region Settings.....                                                    | 1248 |
| 6-108. Camera ISP CSI1/CCP2B Pixel Data Destination Settings.....                                               | 1249 |
| 6-109. Camera ISP CSI2 Receiver Global Reset Flow Chart.....                                                    | 1251 |
| 6-110. cam_strobe Signal-Generation for Red-Eye Removal.....                                                    | 1258 |
| 6-111. Camera ISP CCDC Dependencies Among Framing Settings in Data Flow .....                                   | 1261 |
| 6-112. Camera ISP CCDC CCDC_VD0_IRQ/CCDC_VD1_IRQ Interrupt Behavior When VDPOL = 0.....                         | 1263 |
| 6-113. Camera ISP CCDC CCDC_VD0_IRQ/CCDC_VD1_IRQ Interrupt Behavior When VDPOL = 1.....                         | 1263 |
| 6-114. Camera ISP CCDC CCDC_VD2_IRQ Interrupt Behavior.....                                                     | 1263 |
| 6-115. Camera ISP CCDC HS/VS Sync Pulse Output Timings .....                                                    | 1266 |
| 6-116. Camera ISP CCDC Mosaic Filter - CCDC_COLPTN Bit Field Settings.....                                      | 1267 |
| 6-117. Camera ISP CCDC Data Packing - Pixel Ordering .....                                                      | 1272 |
| 6-118. Camera ISP CCDC Clipping Window Before Output to Memory .....                                            | 1273 |
| 6-119. Camera ISP Resizer Firmware Interactions for Memory-Input Resizing .....                                 | 1281 |
| 6-120. Camera ISP Central-Resource SBL Video-Port Interface Bandwidth Balancing .....                           | 1292 |
| 6-121. Camera ISP Central-Resource SBL Memory Read Bandwidth Balancing .....                                    | 1293 |
| 6-122. Camera ISP Software Reset Sequence .....                                                                 | 1295 |
| 7-1. Display Subsystem Highlight.....                                                                           | 1557 |
| 7-2. LCD Support Parallel Interface (RFBI Mode) .....                                                           | 1566 |
| 7-3. External Generation of TE Signal Based on Logical OR Operation Between HSYNC and VSYNC (Active-High) ..... | 1567 |
| 7-4. LCD Support Parallel Interface (Bypass Mode) .....                                                         | 1568 |
| 7-5. LCD Pixel Data Monochrome4 Passive Matrix .....                                                            | 1569 |
| 7-6. LCD Pixel Data Monochrome8 Passive Matrix .....                                                            | 1570 |
| 7-7. LCD Pixel Data Color Passive Matrix.....                                                                   | 1570 |
| 7-8. LCD Pixel Data Color12 Active Matrix .....                                                                 | 1571 |
| 7-9. LCD Pixel Data Color16 Active Matrix .....                                                                 | 1572 |
| 7-10. LCD Pixel Data Color18 Active Matrix .....                                                                | 1572 |
| 7-11. LCD Pixel Data Color24 Active Matrix .....                                                                | 1573 |
| 7-12. RFBI Data Stall Signal Diagram .....                                                                      | 1573 |
| 7-13. RFBI Data Stall Signal Diagram With Handcheck .....                                                       | 1574 |
| 7-14. Command Data Write .....                                                                                  | 1574 |
| 7-15. Display Data Read .....                                                                                   | 1575 |
| 7-16. Read to Write and Write to Read.....                                                                      | 1575 |
| 7-17. Active Matrix Timing Diagram of Configuration 1 (Start of Frame) .....                                    | 1576 |

|       |                                                                        |      |
|-------|------------------------------------------------------------------------|------|
| 7-18. | Active Matrix Timing Diagram of Configuration 1 (Between Lines) .....  | 1576 |
| 7-19. | Active Matrix Timing Diagram of Configuration 1 (Between Frames) ..... | 1577 |
| 7-20. | Active Matrix Timing Diagram of Configuration 1 (End of Frame) .....   | 1577 |
| 7-21. | Active Matrix Timing Diagram of Configuration 2 (Start of Frame) ..... | 1577 |
| 7-22. | Active Matrix Timing Diagram of Configuration 2 (Between Lines) .....  | 1578 |
| 7-23. | Active Matrix Timing Diagram of Configuration 2 (Between Frames) ..... | 1578 |
| 7-24. | Active Matrix Timing Diagram of Configuration 2 (End of Frame) .....   | 1578 |
| 7-25. | Active Matrix Timing Diagram of Configuration 3 (Start of Frame) ..... | 1579 |
| 7-26. | Active Matrix Timing Diagram of Configuration 3 (Between Lines) .....  | 1579 |
| 7-27. | Active Matrix Timing Diagram of Configuration 3 (Between Frames) ..... | 1579 |
| 7-28. | Active Matrix Timing Diagram of Configuration 3 (End of Frame) .....   | 1579 |
| 7-29. | Passive Matrix Timing Diagram (Start of Frame) .....                   | 1580 |
| 7-30. | Passive Matrix Timing Diagram (Between Lines) .....                    | 1580 |
| 7-31. | Passive Matrix Timing Diagram (Between Frames) .....                   | 1580 |
| 7-32. | Passive Matrix Timing Diagram (End of Frame) .....                     | 1580 |
| 7-33. | Typical DSI Connection.....                                            | 1581 |
| 7-34. | DSI Video Mode Without Burst (No-Line Buffer) .....                    | 1586 |
| 7-35. | DSI Video Mode Without Burst (One-Line Buffer) .....                   | 1587 |
| 7-36. | DSI Video Mode With Burst (Two-Line Buffers).....                      | 1588 |
| 7-37. | Stall Timing With Pixel on Rising Edge.....                            | 1590 |
| 7-38. | Stall Timing With Pixel on Falling Edge .....                          | 1590 |
| 7-39. | Data Flow in Command Mode Using the Video Port .....                   | 1591 |
| 7-40. | Two Data Lane Configuration.....                                       | 1592 |
| 7-41. | One Data Lane Configuration.....                                       | 1592 |
| 7-42. | Two Packets Using Two-Data Lane Configuration (Example) .....          | 1593 |
| 7-43. | Protocol Layer With Short and Long Packets.....                        | 1593 |
| 7-44. | Short Packet Structure.....                                            | 1594 |
| 7-45. | Long Packet Structure .....                                            | 1594 |
| 7-46. | Data Identifier Structure .....                                        | 1595 |
| 7-47. | Virtual Channel Controller .....                                       | 1595 |
| 7-48. | DSI Video Mode: Nonburst Transfer With VE and HE .....                 | 1598 |
| 7-49. | DSI Video Mode: Nonburst Transfer Without VE and HE.....               | 1599 |
| 7-50. | DSI Video Mode: Burst Transfer Without VE and HE .....                 | 1600 |
| 7-51. | DSI General Frame Structure.....                                       | 1601 |
| 7-52. | DSI General Frame Structure Using Burst Mode .....                     | 1602 |
| 7-53. | DSI General Frame Structure Using Burst Mode and Interleaving .....    | 1603 |
| 7-54. | 24 Bits per Pixel RGB Color Format, Long Packet .....                  | 1605 |
| 7-55. | 18 Bits per Pixel (Loosely Packed) RGB Color Format, Long Packet.....  | 1606 |
| 7-56. | 18 Bits per Pixel (Packed) RGB Color Format, Long Packet .....         | 1607 |
| 7-57. | 16 Bits per Pixel RGB Color Format, Long Packet .....                  | 1608 |
| 7-58. | TV Display Interface (S-video mode, DC coupled, High FS Swing) .....   | 1609 |
| 7-59. | TV Display Interface (Composite Mode, DC coupled, High FS Swing) ..... | 1609 |
| 7-60. | TV Display Interface (Composite Mode, AC coupled, Low FS Swing) .....  | 1610 |
| 7-61. | TV Display Interface (Bypass Mode, Dual Channel).....                  | 1610 |
| 7-62. | Display Subsystem Integration .....                                    | 1614 |
| 7-63. | Display Subsystem Clock Tree .....                                     | 1615 |
| 7-64. | Display Subsystem DMA Tree.....                                        | 1624 |
| 7-65. | DSI Interrupt Tree .....                                               | 1625 |
| 7-66. | DISPC and DSS Interrupts Tree .....                                    | 1626 |

---

|                                                                                               |      |
|-----------------------------------------------------------------------------------------------|------|
| 7-67. Display Subsystem Full Schematic .....                                                  | 1630 |
| 7-68. Display Controller Architecture Overview .....                                          | 1631 |
| 7-69. Palette/Gamma Correction Architecture .....                                             | 1635 |
| 7-70. YCbCr 4:2:2 to YCbCr 4:4:4 (0- or 180-Degree Rotation) .....                            | 1638 |
| 7-71. YCbCr 4:2:2 to YCbCr 4:4:4 (90- or 270-Degree Rotation) .....                           | 1638 |
| 7-72. Interpolation of the Missing Chrominance Component .....                                | 1638 |
| 7-73. YCbCr to RGB Registers (VIDFULLRANGE = 0) .....                                         | 1639 |
| 7-74. YCbCr to RGB Registers (VIDFULLRANGE = 1) .....                                         | 1639 |
| 7-75. Color Space Conversion Macro-Architecture .....                                         | 1640 |
| 7-76. Video Upsampling .....                                                                  | 1641 |
| 7-77. Resampling Macro-Architecture (3-Coefficient Processing) .....                          | 1642 |
| 7-78. Overlay Manager in Normal Mode .....                                                    | 1645 |
| 7-79. Display Attributes in Normal Mode .....                                                 | 1645 |
| 7-80. Overlay Manager in Alpha Mode .....                                                     | 1646 |
| 7-81. Display Attributes in Alpha Mode .....                                                  | 1647 |
| 7-82. Alpha Blending Macro Architecture with Pre-multiplied Alpha Support .....               | 1648 |
| 7-83. Video Source Transparency Example .....                                                 | 1650 |
| 7-84. Graphics Destination Transparency Example .....                                         | 1651 |
| 7-85. Color Phase Rotation Matrix .....                                                       | 1652 |
| 7-86. Color Phase Rotation Macro Architecture .....                                           | 1652 |
| 7-87. DSI Protocol Engine .....                                                               | 1656 |
| 7-88. DSI Transmitter/Receiver Data Flow .....                                                | 1657 |
| 7-89. LP to HS Timing .....                                                                   | 1658 |
| 7-90. HS to LP Timing .....                                                                   | 1660 |
| 7-91. HS Command Mode Interleaving .....                                                      | 1666 |
| 7-92. LP Command Mode Interleaving .....                                                      | 1668 |
| 7-93. Complex I/O Power FSM .....                                                             | 1671 |
| 7-94. DSI PLL Power FSM .....                                                                 | 1672 |
| 7-95. DSI PLL HS Clock FSM .....                                                              | 1673 |
| 7-96. ForceTxStopMode FSM .....                                                               | 1675 |
| 7-97. TurnRequest FSM .....                                                                   | 1676 |
| 7-98. High-Speed TX Timer FSM .....                                                           | 1677 |
| 7-99. Low-Power RX Timer FSM .....                                                            | 1678 |
| 7-100. 64-Bit ECC Generation on TX Side .....                                                 | 1682 |
| 7-101. Checksum Transmission .....                                                            | 1682 |
| 7-102. 16 Bit CRC Generation Using a Shift Register .....                                     | 1683 |
| 7-103. DSI PLL Controller Overview .....                                                      | 1684 |
| 7-104. DSI PLL Reference Diagram .....                                                        | 1685 |
| 7-105. RFBI Architecture Overview .....                                                       | 1687 |
| 7-106. Video Encoder Architecture Overview .....                                              | 1690 |
| 7-107. Closed Captioning Timing .....                                                         | 1693 |
| 7-108. WSS Timing .....                                                                       | 1695 |
| 7-109. Video DAC Stage Architecture .....                                                     | 1696 |
| 7-110. DC-Coupling TV Detect Waveforms for TV Connected and Disconnected .....                | 1699 |
| 7-111. AC-Coupling TV Detect Waveforms for TV Connected and Disconnected .....                | 1700 |
| 7-112. GPIO Signal Waveform Proposal for TV Detection/Disconnection in DC-Coupling Mode ..... | 1701 |
| 7-113. GPIO Signal Waveform Proposal for TV Detection/Disconnection in AC-Coupling Mode ..... | 1701 |
| 7-114. DAC Test Mode in Composite Video Mode .....                                            | 1702 |
| 7-115. DAC Test Mode in Separate video Mode .....                                             | 1703 |

|                                                                     |      |
|---------------------------------------------------------------------|------|
| 7-116. Overlay Optimization: Case 1 .....                           | 1710 |
| 7-117. Overlay Optimization: Case 2 .....                           | 1711 |
| 7-118. Overlay Optimization: Case 3 .....                           | 1711 |
| 7-119. Overlay Optimization: Case 4 .....                           | 1712 |
| 7-120. 90° DMA Rotation Example .....                               | 1718 |
| 7-121. Rotation/Mirroring Settings .....                            | 1721 |
| 7-122. 90° Rotation With Mirroring .....                            | 1722 |
| 7-123. Offset for VRFB Rotation .....                               | 1724 |
| 7-124. Offset for VRFB Rotation With Mirroring .....                | 1726 |
| 7-125. Timing Values Description (Active Matrix Display) .....      | 1729 |
| 7-126. PCDmin Formulas (V Down-Sampling Only) .....                 | 1731 |
| 7-127. Color Phase Rotation Matrix .....                            | 1733 |
| 7-128. Color Phase Rotation Matrix (R Component Only) .....         | 1733 |
| 7-129. Color Phase Rotation Matrix (G Component Only) .....         | 1733 |
| 7-130. Color Phase Rotation Matrix (B Component Only) .....         | 1733 |
| 7-131. Diagonal Matrix Configuration .....                          | 1734 |
| 7-132. Example - Diagonal Matrix Configuration .....                | 1734 |
| 7-133. Image With and Without CPR (Diagonal Matrix) .....           | 1735 |
| 7-134. Example - Image With and Without CPR (Standard Matrix) ..... | 1736 |
| 7-135. DSI PLL Programming Blocks .....                             | 1751 |
| 7-136. DSI PLL Go Sequence (Manual Mode) .....                      | 1752 |
| 7-137. DSI PLL Go Sequence (Automatic Mode) .....                   | 1753 |
| 7-138. Gated Mode Sequence .....                                    | 1754 |
| 7-139. DSI PLL Programming Sequence .....                           | 1755 |
| 7-140. High-Speed Clock Transmission .....                          | 1759 |
| 7-141. High-Speed Data Transmission .....                           | 1761 |
| 7-142. Turn-Around Request in Transmit Mode .....                   | 1762 |
| 7-143. Turn-Around Request in Receive Mode .....                    | 1763 |
| 7-144. How to Use RFBI .....                                        | 1771 |
| 7-145. RFBI Initial Configuration .....                             | 1772 |
| 7-146. RFBI Output Enable .....                                     | 1773 |
| 7-147. Vertical Filtering Macro Architecture (Three Taps) .....     | 1777 |
| 7-148. Vertical Filtering Macro Architecture (Five Taps) .....      | 1778 |
| 7-149. Horizontal Filtering Macro Architecture (Five Taps) .....    | 1779 |
| 7-150. Vertical Up-/Down-Sampling Algorithm .....                   | 1780 |
| 7-151. Horizontal Up-/Down-Sampling Algorithm .....                 | 1781 |
| 7-152. QVGA LCD Timings .....                                       | 1793 |
| 7-153. DSI Clock Tree in Video Mode .....                           | 1793 |
| 7-154. Overview .....                                               | 1797 |
| 7-155. Overview .....                                               | 1804 |
| 8-1. Graphics Accelerator Highlight .....                           | 1970 |
| 8-2. SGX Subsystem Integration .....                                | 1973 |
| 8-3. SGX Block Diagram .....                                        | 1975 |
| 9-1. Interconnect Architecture Overview .....                       | 1997 |
| 9-2. L3 Interconnect Overview .....                                 | 2003 |
| 9-3. Flow Chart of the Protection Mechanism .....                   | 2007 |
| 9-4. L3 Firewall Implementation .....                               | 2008 |
| 9-5. L3 Region Overlay and Priority Level Overview .....            | 2011 |
| 9-6. Example of REQ_INFO_PERMISSION Register .....                  | 2013 |

---

|        |                                                                                     |      |
|--------|-------------------------------------------------------------------------------------|------|
| 9-7.   | L3 Error Reporting Structure .....                                                  | 2017 |
| 9-8.   | Global Error Routing .....                                                          | 2021 |
| 9-9.   | L3 Error Routing .....                                                              | 2022 |
| 9-10.  | Typical Error Analysis Sequence .....                                               | 2025 |
| 9-11.  | Firewall Configuration Solution 1 .....                                             | 2029 |
| 9-12.  | Firewall Configuration Solution 2 .....                                             | 2030 |
| 9-13.  | L4 Interconnect Overview .....                                                      | 2060 |
| 9-14.  | L4 Initiator-Target Connectivity for L4-Core and L4-Per .....                       | 2060 |
| 9-15.  | Example of CONNID_BIT_VECTOR.....                                                   | 2066 |
| 9-16.  | L4 Firewall Overview .....                                                          | 2068 |
| 9-17.  | L4 Error Reporting.....                                                             | 2077 |
| 9-18.  | Typical Error Analysis Sequence .....                                               | 2079 |
| 9-19.  | Typical Error Analysis Sequence.....                                                | 2080 |
| 10-1.  | GPMC Environment .....                                                              | 2120 |
| 10-2.  | GPMC to 16-Bit Address/Data-Multiplexed Memory.....                                 | 2121 |
| 10-3.  | GPMC to 16-Bit NAND Device .....                                                    | 2122 |
| 10-4.  | GPMC Integration in the Device .....                                                | 2124 |
| 10-5.  | GPMC Functional Diagram.....                                                        | 2128 |
| 10-6.  | Chip-Select Address Mapping and Decoding Mask .....                                 | 2131 |
| 10-7.  | Asynchronous Single Read on a Nonmultiplexed Address/Data Device.....               | 2135 |
| 10-8.  | Wait Behavior During an Asynchronous Single Read Access (GPMCFCLKDIVIDER = 1) ..... | 2141 |
| 10-9.  | Wait Behavior During a Synchronous Read Burst Access.....                           | 2143 |
| 10-10. | Asynchronous Single Read on an Address/Data-Nonmultiplexed Device .....             | 2147 |
| 10-11. | Asynchronous Single Read on an Address/Data-Multiplexed Device .....                | 2148 |
| 10-12. | Asynchronous Single Write on an Address/Data-Nonmultiplexed Device .....            | 2150 |
| 10-13. | Asynchronous Single Write on an Address/Data-Multiplexed Device .....               | 2151 |
| 10-14. | Asynchronous Multiple (Page Mode) Read .....                                        | 2152 |
| 10-15. | Synchronous Single Read (GPMCFCLKDIVIDER = 0) .....                                 | 2154 |
| 10-16. | Synchronous Single Read (GPMCFCLKDIVIDER = 1) .....                                 | 2155 |
| 10-17. | Synchronous Single Write on an Address/Data-Multiplexed Device .....                | 2156 |
| 10-18. | Synchronous Multiple (Burst) Read (GPMCFCLKDIVIDER = 0) .....                       | 2157 |
| 10-19. | Synchronous Multiple (Burst) Read (GPMCFCLKDIVIDER = 1) .....                       | 2158 |
| 10-20. | Synchronous Multiple (Burst) Write .....                                            | 2160 |
| 10-21. | Synchronous Multiple Write (Burst Write) in Address/Data-Multiplexed Mode .....     | 2162 |
| 10-22. | NAND Command Latch Cycle .....                                                      | 2166 |
| 10-23. | NAND Address Latch Cycle.....                                                       | 2166 |
| 10-24. | NAND Data Read Cycle .....                                                          | 2167 |
| 10-25. | NAND Data Write Cycle .....                                                         | 2168 |
| 10-26. | Hamming Code Accumulation Algorithm (1/2).....                                      | 2172 |
| 10-27. | Hamming Code Accumulation Algorithm (2/2).....                                      | 2173 |
| 10-28. | ECC Computation for a 256-Byte Data Stream (Read or Write) .....                    | 2173 |
| 10-29. | ECC Computation for a 512-Byte Data Stream (Read or Write) .....                    | 2174 |
| 10-30. | 128 Word16 ECC Computation.....                                                     | 2175 |
| 10-31. | 256 Word16 ECC Computation.....                                                     | 2175 |
| 10-32. | Manual Mode Sequence and Mapping .....                                              | 2180 |
| 10-33. | NAND Page Mapping and ECC: Per-Sector Schemes.....                                  | 2184 |
| 10-34. | NAND Page Mapping and ECC: Pooled Spare Schemes .....                               | 2185 |
| 10-35. | NAND Page Mapping and ECC: Per-Sector Schemes, With Separate ECC.....               | 2186 |
| 10-36. | NAND Read Cycle Optimization Timing Description .....                               | 2192 |

|                                                                                   |      |
|-----------------------------------------------------------------------------------|------|
| 10-37. GPMC Connection to an External NOR Flash Memory .....                      | 2194 |
| 10-38. Synchronous Burst Read Access (Timing Parameters in Clock Cycles).....     | 2196 |
| 10-39. Asynchronous Single Read Access (Timing Parameters in Clock Cycles) .....  | 2197 |
| 10-40. Asynchronous Single Write Access (Timing Parameters in Clock Cycles) ..... | 2198 |
| 10-41. SDRC Subsystem Environment .....                                           | 2231 |
| 10-42. SDRC Subsystem Connections to SDR SDRAM .....                              | 2233 |
| 10-43. SDRC Subsystem Connections to DDR SDRAM .....                              | 2234 |
| 10-44. SDRC SDR/DDR-SDRAM System Address Multiplexing Schemes (1 of 3) .....      | 2238 |
| 10-45. SDRC SDR/DDR-SDRAM System Address Multiplexing Schemes (2 of 3) .....      | 2239 |
| 10-46. SDRC SDR/DDR-SDRAM System Address Multiplexing Schemes (3 of 3) .....      | 2240 |
| 10-47. SDRC Integration to the Device .....                                       | 2241 |
| 10-48. SMS Top-Level Diagram .....                                                | 2244 |
| 10-49. Region Organization .....                                                  | 2250 |
| 10-50. SDRC Architecture .....                                                    | 2254 |
| 10-51. CS0/CS1 Chip-Select Start Address Slots .....                              | 2255 |
| 10-52. SDRAM Controller Block Diagram .....                                       | 2257 |
| 10-53. Address Multiplexing Scheme According to BANKALLOCATION .....              | 2258 |
| 10-54. Simplified View of Bank-Row-Column vs Row-Bank-Column Bank Allocation..... | 2259 |
| 10-55. Data Multiplexing Scheme.....                                              | 2261 |
| 10-56. Data Demultiplexing Scheme .....                                           | 2262 |
| 10-57. Generic DDR Data-Write and Data-Read Waveforms.....                        | 2268 |
| 10-58. Required Synchronization DFF Input Signals .....                           | 2268 |
| 10-59. DLL/CDL Architecture.....                                                  | 2269 |
| 10-60. Simplified DLL/CDL Block Diagram.....                                      | 2270 |
| 10-61. Natural Scan Order.....                                                    | 2273 |
| 10-62. SDRC Subsystem Overview .....                                              | 2285 |
| 10-63. YUV Format: Pixel Representation.....                                      | 2286 |
| 10-64. VRFB Context Configuration .....                                           | 2287 |
| 10-65. Example of VRFB Context 1 Configuration .....                              | 2288 |
| 10-66. Display a Rotated QVGA Image.....                                          | 2290 |
| 10-67. Arbitration Granularity Versus Arbitration Decision .....                  | 2293 |
| 10-68. BURST-COMPLETE On Class 2-Group 3 .....                                    | 2294 |
| 10-69. Priority Between Classes .....                                             | 2295 |
| 10-70. Idle Cycle Mechanism Within A Burst .....                                  | 2296 |
| 10-71. Example of EXTENDEDGRANT Mechanism.....                                    | 2297 |
| 10-72. Arbitration Between Classes .....                                          | 2298 |
| 10-73. Arbitration Within a Class .....                                           | 2299 |
| 10-74. Generic Arbitration Decision .....                                         | 2300 |
| 10-75. Arbitration Granularity.....                                               | 2301 |
| 10-76. SDRC Address Space in MPU Global Address Space.....                        | 2302 |
| 10-77. CS Start and End Address Configuration Example .....                       | 2305 |
| 10-78. OCM Subsystem Overview .....                                               | 2339 |
| 10-79. OCM Subsystem Integration to the Device .....                              | 2340 |
| 11-1. SDMA Overview .....                                                         | 2345 |
| 11-2. External SDMA Requests Typical Application .....                            | 2347 |
| 11-3. Edge-Sensitive DMA Request Scheme .....                                     | 2348 |
| 11-4. Transition-Sensitive DMA Request Scheme .....                               | 2348 |
| 11-5. SDMA Controller Integration .....                                           | 2349 |
| 11-6. SDMA Controller Top-Level Block Diagram .....                               | 2354 |

---

|        |                                                                              |      |
|--------|------------------------------------------------------------------------------|------|
| 11-7.  | Example Showing Double-Index Addressing, Elements, Frames, and Strides ..... | 2358 |
| 11-8.  | Addressing Mode Example (a) .....                                            | 2358 |
| 11-9.  | Addressing Mode Example (b) .....                                            | 2358 |
| 11-10. | Addressing Mode Example (c).....                                             | 2359 |
| 11-11. | Example of a 90° Clockwise Image Rotation .....                              | 2360 |
| 11-12. | 2-D Graphic Transparent Color Block Diagram .....                            | 2368 |
| 12-1.  | Interrupt Controllers Highlight.....                                         | 2415 |
| 12-2.  | Interrupts From External Devices .....                                       | 2416 |
| 12-3.  | MPU Subsystem INTCPS Integration.....                                        | 2417 |
| 12-4.  | Top-Level Block Diagram.....                                                 | 2422 |
| 12-5.  | IRQ/FIQ Processing Sequence .....                                            | 2428 |
| 12-6.  | Nested IRQ/FIQ Sequence.....                                                 | 2431 |
| 13-1.  | SCM Overview .....                                                           | 2448 |
| 13-2.  | SCM Environment Overview .....                                               | 2449 |
| 13-3.  | SCM Interface Signals .....                                                  | 2450 |
| 13-4.  | SCM Integration .....                                                        | 2451 |
| 13-5.  | Internal Clock Implementation .....                                          | 2454 |
| 13-6.  | SCM Block Diagram.....                                                       | 2455 |
| 13-7.  | Pad Configuration Register Functionality .....                               | 2456 |
| 13-8.  | Pad Configuration Diagram .....                                              | 2458 |
| 13-9.  | Off Mode Pad Control Overview.....                                           | 2476 |
| 13-10. | Save-and-Restore Mechanism Overview .....                                    | 2477 |
| 13-11. | Wake-Up Event Detection Overview.....                                        | 2478 |
| 13-12. | Functional Block Diagram .....                                               | 2479 |
| 13-13. | Extended-Drain I/O .....                                                     | 2482 |
| 13-14. | Functional Block Diagram .....                                               | 2484 |
| 13-15. | Single Conversion Mode (CONTCONV = 0).....                                   | 2485 |
| 13-16. | Continuous Conversion Mode (CONTCONV = 1).....                               | 2486 |
| 13-17. | Overview of the Debug and Observability Register Functionality.....          | 2499 |
| 13-18. | DPLL With EMI Reduction Feature .....                                        | 2535 |
| 13-19. | DPLL-D Integration .....                                                     | 2536 |
| 13-20. | Spreading Generation Block Diagram .....                                     | 2537 |
| 13-21. | Effect of the SSC in Frequency.....                                          | 2538 |
| 13-22. | Effect of the SSC in the Time Domain.....                                    | 2539 |
| 13-23. | Peak Reduction Caused by Spreading .....                                     | 2539 |
| 13-24. | Flow Chart.....                                                              | 2550 |
| 13-25. | VDDS Ramps Up Before VDD2 .....                                              | 2552 |
| 13-26. | I/O Power Optimization Flow Chart .....                                      | 2556 |
| 14-1.  | Simplified Block Diagram of the IPC .....                                    | 2660 |
| 14-2.  | IPC Integration .....                                                        | 2661 |
| 14-3.  | Mailbox Block Diagram .....                                                  | 2664 |
| 14-4.  | Example of Communication .....                                               | 2671 |
| 15-1.  | Device MMU Instances .....                                                   | 2680 |
| 15-2.  | Camera MMU System Integration.....                                           | 2681 |
| 15-3.  | IVA2.2 MMU System Integration .....                                          | 2681 |
| 15-4.  | MMU Address Translation.....                                                 | 2684 |
| 15-5.  | MMU Usage Examples .....                                                     | 2685 |
| 15-6.  | MMU Architecture .....                                                       | 2686 |
| 15-7.  | Translation Process .....                                                    | 2687 |

|                                                                                                     |      |
|-----------------------------------------------------------------------------------------------------|------|
| 15-8. Translation Hierarchy .....                                                                   | 2688 |
| 15-9. First-Level Descriptor Address Calculation .....                                              | 2688 |
| 15-10. Detailed First-Level Descriptor Address Calculation.....                                     | 2689 |
| 15-11. Section Translation Summary .....                                                            | 2690 |
| 15-12. Supersection Translation Summary.....                                                        | 2691 |
| 15-13. Two-Level Translation .....                                                                  | 2691 |
| 15-14. Small Page Translation Summary.....                                                          | 2692 |
| 15-15. Large Page Translation Summary .....                                                         | 2693 |
| 15-16. TLB Entry Lock Mechanism.....                                                                | 2694 |
| 15-17. TLB Entry Structure .....                                                                    | 2695 |
| 15-18. MMU Configuration Strategies.....                                                            | 2697 |
| 15-19. MMUn Translation Table Hierarchy .....                                                       | 2699 |
| 15-20. Translation of a Supersection.....                                                           | 2700 |
| 15-21. Translation of a Section .....                                                               | 2701 |
| 15-22. Translation of a Large Page Included in a Page Table.....                                    | 2701 |
| 15-23. Translation of an Extended Small Page Included in a Page Table .....                         | 2702 |
| 16-1. Timers .....                                                                                  | 2718 |
| 16-2. GP Timers Overview .....                                                                      | 2719 |
| 16-3. GP Timers External System Interface .....                                                     | 2721 |
| 16-4. GP Timer Integration.....                                                                     | 2722 |
| 16-5. Wake-Up Request Generation.....                                                               | 2726 |
| 16-6. Block Diagram of GPTIMER3 through GPTIMER9 and GPTIMER11.....                                 | 2729 |
| 16-7. Block Diagram of GPTIMER1, GPTIMER2, and GPTIMER10 .....                                      | 2730 |
| 16-8. GPTi.TCRR Timing Value .....                                                                  | 2731 |
| 16-9. Block Diagram of the 1-ms Tick Module.....                                                    | 2732 |
| 16-10. Capture Wave Example for GPTi.TCLR[13] CAPT_MODE = 0 .....                                   | 2734 |
| 16-11. Capture Wave Example for GPTi.TCLR[13] CAPT_MODE = 1 .....                                   | 2734 |
| 16-12. Timing Diagram of PWM With GPTi.TCLR[7] SCPWM Bit = 0.....                                   | 2736 |
| 16-13. Timing Diagram of PWM With GPTi.TCLR[7] SCPWM Bit = 1 .....                                  | 2736 |
| 16-14. WDTs Block Diagram .....                                                                     | 2766 |
| 16-15. WDT Integration .....                                                                        | 2767 |
| 16-16. 32-Bit WDT Functional Block Diagram .....                                                    | 2770 |
| 16-17. WDT General Functional View .....                                                            | 2771 |
| 16-18. 32-kHz Sync Timer Block Diagram .....                                                        | 2783 |
| 17-1. HS I <sup>2</sup> C Controllers Overview Block Diagram.....                                   | 2788 |
| 17-2. HS I <sup>2</sup> C Controllers and Typical Connections to I <sup>2</sup> C Devices .....     | 2790 |
| 17-3. HS I <sup>2</sup> C Controller Interface Signals in I <sup>2</sup> C Mode.....                | 2790 |
| 17-4. HS I <sup>2</sup> C Serial Data Transfer .....                                                | 2791 |
| 17-5. HS I <sup>2</sup> C Bit Data Validity Transfer on the I <sup>2</sup> C Bus .....              | 2791 |
| 17-6. HS I <sup>2</sup> C Start and Stop Condition Events .....                                     | 2792 |
| 17-7. HS I <sup>2</sup> C Data Transfer Formats in F/S Mode .....                                   | 2792 |
| 17-8. HS I <sup>2</sup> C Data Transfers in HS Mode .....                                           | 2793 |
| 17-9. HS I <sup>2</sup> C Arbitration Between Master Transmitters.....                              | 2794 |
| 17-10. HS I <sup>2</sup> C Synchronization of I <sup>2</sup> C Clock Generators.....                | 2795 |
| 17-11. HS I <sup>2</sup> C Controllers and Typical Connections to SCCB Devices.....                 | 2796 |
| 17-12. HS I <sup>2</sup> C Controller Interface Signals in SCCB Mode.....                           | 2797 |
| 17-13. HS I <sup>2</sup> C 3-Wire SCCB Transmission Timing Diagram .....                            | 2798 |
| 17-14. HS I <sup>2</sup> C SCCB Transmission Data Formats.....                                      | 2798 |
| 17-15. HS I <sup>2</sup> C Typical Connection Between Power Chip(s) and for I <sup>2</sup> C4 ..... | 2800 |

---

|        |                                                                                                                  |      |
|--------|------------------------------------------------------------------------------------------------------------------|------|
| 17-16. | HS I <sup>2</sup> C Interface Signals for I <sup>2</sup> C4 .....                                                | 2800 |
| 17-17. | HS I <sup>2</sup> C Data Transfer Format in F/S Mode for I2C4 .....                                              | 2801 |
| 17-18. | HS I <sup>2</sup> C Data Transfer Format in HS Mode for I2C4.....                                                | 2802 |
| 17-19. | HS I <sup>2</sup> C Controller Integration Diagram.....                                                          | 2803 |
| 17-20. | HS I <sup>2</sup> C Wake-up Generation Flow.....                                                                 | 2806 |
| 17-21. | HS I <sup>2</sup> C Controllers Functional Block Diagram .....                                                   | 2811 |
| 17-22. | HS I <sup>2</sup> C Receive FIFO Interrupt Request Generation .....                                              | 2813 |
| 17-23. | HS I <sup>2</sup> C Transmit FIFO Interrupt Request Generation.....                                              | 2813 |
| 17-24. | HS I <sup>2</sup> C Receive FIFO DMA Request Generation.....                                                     | 2815 |
| 17-25. | HS I <sup>2</sup> C Transmit FIFO Request Generation (High Threshold).....                                       | 2815 |
| 17-26. | HS I <sup>2</sup> C Transmit FIFO Request Generation (Low Threshold) .....                                       | 2816 |
| 17-27. | HS I <sup>2</sup> C Clock Generation .....                                                                       | 2817 |
| 17-28. | HS I <sup>2</sup> C Mode Setup Procedure (I <sup>2</sup> C Mode).....                                            | 2824 |
| 17-29. | HS I <sup>2</sup> C Master Transmitter Mode, Polling Method, in F/S and HS Modes (I <sup>2</sup> C Mode) .....   | 2825 |
| 17-30. | HS I <sup>2</sup> C Master Receiver Mode, Polling Method, in F/S and HS Modes (I <sup>2</sup> C Mode) .....      | 2826 |
| 17-31. | HS I <sup>2</sup> C Master Transmitter Mode, Interrupt Method, in F/S and HS Modes (I <sup>2</sup> C Mode) ..... | 2827 |
| 17-32. | HS I <sup>2</sup> C Master Receiver Mode, Interrupt Method, in F/S and HS Modes (I <sup>2</sup> C Mode) .....    | 2828 |
| 17-33. | HS I <sup>2</sup> C Master Transmitter Mode, DMA Method in F/S and HS Modes (I <sup>2</sup> C Mode) .....        | 2829 |
| 17-34. | HS I <sup>2</sup> C Master Receiver Mode, DMA Method in F/S and HS Modes (I <sup>2</sup> C Mode) .....           | 2830 |
| 17-35. | HS I <sup>2</sup> C Slave Transmitter/Receiver Mode, Polling (I <sup>2</sup> C Mode).....                        | 2831 |
| 17-36. | HS I <sup>2</sup> C Slave Transmitter/Receiver Mode, Interrupt (I <sup>2</sup> C Mode).....                      | 2832 |
| 17-37. | HS I <sup>2</sup> C Setup Procedure (SCCB Mode) .....                                                            | 2834 |
| 17-38. | HS I <sup>2</sup> C Master Transmitter Mode, Polling (SCCB Mode) .....                                           | 2835 |
| 17-39. | HS I <sup>2</sup> C Master Receiver Mode, Polling (SCCB Mode) .....                                              | 2836 |
| 17-40. | HS I <sup>2</sup> C Master Transmitter Mode, Interrupt (SCCB Mode).....                                          | 2837 |
| 17-41. | HS I <sup>2</sup> C Master Receiver Mode, Interrupt (SCCB Mode).....                                             | 2838 |
| 18-1.  | HDQ/1-Wire Highlight .....                                                                                       | 2864 |
| 18-2.  | HDQ/1-Wire Typical Application System Overview .....                                                             | 2865 |
| 18-3.  | HDQ Break-Pulse Timing Diagram.....                                                                              | 2866 |
| 18-4.  | 1-Wire (SDQ) Reset Timing Diagram .....                                                                          | 2866 |
| 18-5.  | HDQ/1-Wire Transmitted Bit Timing .....                                                                          | 2867 |
| 18-6.  | HDQ/1-Wire Communication Sequence .....                                                                          | 2867 |
| 18-7.  | HDQ/1-Wire Integration.....                                                                                      | 2868 |
| 18-8.  | HDQ/1-Wire Block Diagram .....                                                                                   | 2870 |
| 18-9.  | Protocol Registers Description.....                                                                              | 2871 |
| 18-10. | Environment.....                                                                                                 | 2880 |
| 18-11. | HDQ/1-Wire Configuration in HDQ Mode .....                                                                       | 2880 |
| 18-12. | Software Reset Flowchart .....                                                                                   | 2881 |
| 19-1.  | UART Module .....                                                                                                | 2892 |
| 19-2.  | UART Mode Bus System Overview .....                                                                              | 2895 |
| 19-3.  | IrDA System Overview .....                                                                                       | 2895 |
| 19-4.  | CIR System Overview .....                                                                                        | 2896 |
| 19-5.  | UART Frame Data Format .....                                                                                     | 2897 |
| 19-6.  | IrDA SIR Frame Format .....                                                                                      | 2898 |
| 19-7.  | IrDA SIR Encoding Mechanism.....                                                                                 | 2899 |
| 19-8.  | IrDA SIR Decoding Mechanism .....                                                                                | 2900 |
| 19-9.  | SIR Free Format Mode .....                                                                                       | 2901 |
| 19-10. | MIR Transmit Frame Format.....                                                                                   | 2901 |
| 19-11. | MIR Baud Rate Adjustment Mechanism .....                                                                         | 2902 |

---

|                                                                                                    |      |
|----------------------------------------------------------------------------------------------------|------|
| 19-12. SIP.....                                                                                    | 2902 |
| 19-13. CIR Pulse Modulation.....                                                                   | 2904 |
| 19-14. CIR Modulation Duty Cycle .....                                                             | 2905 |
| 19-15. RC-5 Bit Encoding.....                                                                      | 2906 |
| 19-16. SIRC Bit Encoding .....                                                                     | 2906 |
| 19-17. RC-5 Standard Packet Format .....                                                           | 2907 |
| 19-18. SIRC Packet Format .....                                                                    | 2907 |
| 19-19. SIRC Bit Transmission Example .....                                                         | 2907 |
| 19-20. UART Functional Integration.....                                                            | 2908 |
| 19-21. UART/IrDA/CIR Block Diagram.....                                                            | 2912 |
| 19-22. FIFO Management Registers .....                                                             | 2913 |
| 19-23. Receive FIFO Interrupt Request Generation .....                                             | 2915 |
| 19-24. Transmit FIFO Interrupt Request Generation.....                                             | 2915 |
| 19-25. Receive FIFO DMA Request Generation (32 Characters).....                                    | 2917 |
| 19-26. Transmit FIFO DMA Request Generation (56 Spaces) .....                                      | 2917 |
| 19-27. Transmit FIFO DMA Request Generation (8 Spaces).....                                        | 2918 |
| 19-28. Transmit FIFO DMA Request Generation (1 Space) .....                                        | 2919 |
| 19-29. Transmission Process .....                                                                  | 2919 |
| 19-30. Reception Process .....                                                                     | 2920 |
| 19-31. Baud Rate Generation .....                                                                  | 2926 |
| 19-32. Baud Rate Generator .....                                                                   | 2933 |
| 19-33. CIR Mode Block Components .....                                                             | 2938 |
| 20-1. Multichannel Modules SPI1, SPI2, SPI3, and SPI4.....                                         | 2999 |
| 20-2. Typical Application Using the McSPI .....                                                    | 3001 |
| 20-3. McSPI Master Mode (Full-Duplex) .....                                                        | 3002 |
| 20-4. McSPI Master Single Mode (Receive-Only) .....                                                | 3002 |
| 20-5. McSPI Slave Mode (Full Duplex) .....                                                         | 3003 |
| 20-6. McSPI Slave Single Mode (Transmit Only) .....                                                | 3003 |
| 20-7. McSPI Interface Signals in Master Mode.....                                                  | 3004 |
| 20-8. McSPI Interface Signals in Slave Mode .....                                                  | 3004 |
| 20-9. Phase and Polarity Combinations.....                                                         | 3006 |
| 20-10. Full-Duplex Transfer Format With PHA = 0 .....                                              | 3007 |
| 20-11. Extended SPI Transfer With a Start-Bit (SBE = 1).....                                       | 3008 |
| 20-12. McSPI Integration .....                                                                     | 3009 |
| 20-13. McSPI Block Diagram.....                                                                    | 3013 |
| 20-14. SPI Full-Duplex Transmission (Example) .....                                                | 3015 |
| 20-15. Continuous Transfers With spim_csx Maintained Active (Single-Data-Pin Interface Mode) ..... | 3017 |
| 20-16. Continuous Transfers With spim_csx Maintained Active (Dual-Data-Pin Interface Mode) .....   | 3017 |
| 20-17. Chip-Select SPIEN Timing Controls .....                                                     | 3018 |
| 20-18. Example of McSPI Slave With One Master and Multiple Slave Devices on Channel 0.....         | 3021 |
| 20-19. SPI Half-Duplex Transmission (Transmit-Only Slave).....                                     | 3023 |
| 20-20. SPI Half-Duplex Transmission (Receive-Only Slave).....                                      | 3024 |
| 20-21. Buffer Use in Transmit Direction Only .....                                                 | 3025 |
| 20-22. Buffer Use in Receive Direction Only .....                                                  | 3025 |
| 20-23. Buffer Used For Both Transmit/Receive Directions .....                                      | 3025 |
| 20-24. Buffer Almost Full Level (AFL).....                                                         | 3026 |
| 20-25. Buffer Almost Empty Level (AEL) .....                                                       | 3027 |
| 20-26. Module Initialization Flow .....                                                            | 3034 |
| 20-27. Common Transfer Sequence: Main Process .....                                                | 3035 |

---

|                                                                                                                                                 |      |
|-------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 20-28. Transmit and Receive (Master and Slave) .....                                                                                            | 3037 |
| 20-29. Transmit-Only With Interrupts (Master and Slave) .....                                                                                   | 3038 |
| 20-30. Transmit-Only With DMA (Master and Slave) .....                                                                                          | 3039 |
| 20-31. Receive Only With Interrupt (Master Normal) .....                                                                                        | 3040 |
| 20-32. Receive-Only With DMA (Master Normal) .....                                                                                              | 3041 |
| 20-33. Receive-Only With Interrupt (Master Turbo) .....                                                                                         | 3042 |
| 20-34. Receive-Only With DMA (Master Turbo) .....                                                                                               | 3043 |
| 20-35. Receive Only (Slave).....                                                                                                                | 3044 |
| 20-36. Two SPI Transfers With PHA = 0 (Flexibility of McSPI).....                                                                               | 3045 |
| 20-37. Common Transfer Sequence/Main Process .....                                                                                              | 3048 |
| 20-38. Transmit-Receive With Word Count .....                                                                                                   | 3050 |
| 20-39. Transmit-Receive Without Word Count.....                                                                                                 | 3051 |
| 20-40. Transmit-Only .....                                                                                                                      | 3052 |
| 20-41. Receive-Only With Word Count .....                                                                                                       | 3053 |
| 20-42. Receive-Only Without Word Count.....                                                                                                     | 3054 |
| 21-1. McBSP Highlight.....                                                                                                                      | 3078 |
| 21-2. SIDETONE Core Architecture .....                                                                                                          | 3080 |
| 21-3. Mode Overview of McBSP1 Module .....                                                                                                      | 3083 |
| 21-4. Mode Overview of McBSPi Module .....                                                                                                      | 3084 |
| 21-5. DBB Data Application .....                                                                                                                | 3084 |
| 21-6. Audio Data Application.....                                                                                                               | 3085 |
| 21-7. Voice Data Application .....                                                                                                              | 3085 |
| 21-8. McBSP Reception/Transmission Signal Activity.....                                                                                         | 3087 |
| 21-9. Serial Data Formats .....                                                                                                                 | 3087 |
| 21-10. TDM Data Format; Word Width: 32 Bits; Data Length: 24 Bits .....                                                                         | 3088 |
| 21-11. I2S Data Format; Word Width: 32 Bits; Data Length: 24 Bits .....                                                                         | 3089 |
| 21-12. Left-Justified Data Format; Word Width: 32 Bits; Data Length: 24 Bits .....                                                              | 3089 |
| 21-13. Right-Justified Data Format; Word Width: 32 Bits; Data Length: 24 Bits .....                                                             | 3089 |
| 21-14. PCM Protocol – Mode 1 Data Format .....                                                                                                  | 3090 |
| 21-15. PCM Protocol – Mode 2 Data Format .....                                                                                                  | 3090 |
| 21-16. McBSP1 Integration .....                                                                                                                 | 3091 |
| 21-17. McBSP2 Integration .....                                                                                                                 | 3092 |
| 21-18. McBSP3 Integration .....                                                                                                                 | 3093 |
| 21-19. McBSP4 Integration .....                                                                                                                 | 3094 |
| 21-20. McBSP5 Integration .....                                                                                                                 | 3095 |
| 21-21. McBSP1, McBSP4 and McBSP5 Block Diagrams .....                                                                                           | 3112 |
| 21-22. McBSP2 Block Diagram .....                                                                                                               | 3113 |
| 21-23. McBSP3 Block Diagram .....                                                                                                               | 3114 |
| 21-24. McBSP Data Transfer Paths .....                                                                                                          | 3115 |
| 21-25. McBSP2 Data Transfer Paths .....                                                                                                         | 3115 |
| 21-26. Conceptual Block Diagram for Clock and Frame Generation When MCBSPLP_SPCR1_REG[15] ALB = 0 and CONTROL_DEVCONF0[3] MCBSPLP_CLKR = 0..... | 3116 |
| 21-27. Clock Signal Control of Bit Transfer Timing.....                                                                                         | 3118 |
| 21-28. McBSP Operating at Maximum Packet Frequency .....                                                                                        | 3120 |
| 21-29. Single-Phase Frame for a McBSP Data Transfer .....                                                                                       | 3122 |
| 21-30. Dual-Phase Frame for a McBSP Data Transfer.....                                                                                          | 3122 |
| 21-31. McBSP Reception Physical Data Path .....                                                                                                 | 3123 |
| 21-32. McBSP Reception Signal Activity .....                                                                                                    | 3123 |
| 21-33. McBSP Transmission Physical Data Path .....                                                                                              | 3123 |

|                                                                                    |      |
|------------------------------------------------------------------------------------|------|
| 21-34. McBSP Transmission Signal Activity .....                                    | 3124 |
| 21-35. Transmit Full Cycle Timing Diagram .....                                    | 3125 |
| 21-36. Transmit Half Cycle Timing Diagram .....                                    | 3125 |
| 21-37. Receive Full Cycle Timing Diagram.....                                      | 3126 |
| 21-38. Receive Half Cycle Timing Diagram .....                                     | 3126 |
| 21-39. Conceptual Block Diagram of the Sample Rate Generator .....                 | 3127 |
| 21-40. CLKG Synchronization and FSG Generation (GSYNC = 1 and CLKGDV = 0x1) .....  | 3131 |
| 21-41. CLKG Synchronization and FSG Generation (GSYNC = 1 and CLKGDV = 0x3) .....  | 3131 |
| 21-42. Overrun in the McBSP Receiver .....                                         | 3133 |
| 21-43. Unexpected Frame-sync Pulse During a McBSP Reception .....                  | 3133 |
| 21-44. Proper Positioning of Receive Frame-sync Pulses .....                       | 3134 |
| 21-45. Unexpected Frame-sync Pulse During a McBSP Transmission .....               | 3135 |
| 21-46. Proper Positioning of Transmit Frame-sync Pulses.....                       | 3136 |
| 21-47. McBSP Data Transfer in 8-Partition Mode .....                               | 3139 |
| 21-48. Alternating Between Partitions A and B Channels .....                       | 3140 |
| 21-49. Activity on McBSP Pins When XMCM=0b00 .....                                 | 3142 |
| 21-50. Activity on McBSP Pins When XMCM=0b01 .....                                 | 3142 |
| 21-51. Activity on McBSP Pins When XMCM=0b10 .....                                 | 3142 |
| 21-52. Activity on McBSP Pins When XMCM=0b11 .....                                 | 3143 |
| 21-53. SIDETONE Data Path .....                                                    | 3144 |
| 21-54. McBSP to SIDETONE Data Exchange .....                                       | 3145 |
| 21-55. SIDETONE to McBSP Data Exchange .....                                       | 3145 |
| 21-56. SIDETONE Processed Data Interfaces .....                                    | 3146 |
| 21-57. Flow Diagram of McBSP Initialization Procedure for Master Mode.....         | 3149 |
| 21-58. Flow Diagram of McBSP Initialization Procedure for Slave Mode .....         | 3150 |
| 21-59. Flow Diagram for the SRG Registers Programmation.....                       | 3153 |
| 21-60. Important Tasks to Configure the McBSP Receiver (Part 1) .....              | 3157 |
| 21-61. Important Tasks to Configure the McBSP Receiver (Part 2) .....              | 3158 |
| 21-62. Range of Programmable Data Delay .....                                      | 3160 |
| 21-63. 2-Bit Data Delay Used to Skip a Framing Bit .....                           | 3161 |
| 21-64. Data Externally Clocked on a Rising Edge and Sampled on a Falling Edge..... | 3163 |
| 21-65. Frame of Period 16 CLKG Periods and Active Width of 2 CLKG Periods .....    | 3164 |
| 21-66. Important Tasks to Configure the McBSP Transmitter (Part 1) .....           | 3166 |
| 21-67. Important Tasks to Configure the McBSP Transmitter (Part 2) .....           | 3167 |
| 21-68. Range of Programmable Data Delay .....                                      | 3169 |
| 21-69. 2-Bit Data Delay Used to Skip a Framing Bit .....                           | 3169 |
| 21-70. Four 8-bit Data Words Transferred To/From McBSP Module .....                | 3174 |
| 21-71. One 32-bit Data Word Transferred To/From McBSP Module .....                 | 3174 |
| 21-72. 8-bit Data Words Transferred at Maximum Packet Frequency.....               | 3175 |
| 21-73. Configuring the Data Stream as a Continuous 32-bit Word .....               | 3175 |
| 22-1. USB Modules Overview .....                                                   | 3238 |
| 22-2. High-Speed USB Controller Highlight.....                                     | 3239 |
| 22-3. High-Speed USB Controller Typical Application System.....                    | 3241 |
| 22-4. High-Speed USB Controller Functional Interface Signals.....                  | 3242 |
| 22-5. High-Speed USB Controller Integration .....                                  | 3243 |
| 22-6. High-Speed USB Controller .....                                              | 3249 |
| 22-7. High-Speed USB OTG Controller Endianess .....                                | 3252 |
| 22-8. High-Speed USB Host Subsystem Highlight.....                                 | 3263 |
| 22-9. USB Connection .....                                                         | 3266 |

---

|                                                                                                  |      |
|--------------------------------------------------------------------------------------------------|------|
| 22-10. High-Speed USB Host Controller Connection-With and Without TLL .....                      | 3267 |
| 22-11. High-Speed USB Host Controller Typical Application System - ULPI Interfaces .....         | 3268 |
| 22-12. High-Speed USB Host Subsystem Typical Application System - ULPI TLL Interfaces .....      | 3269 |
| 22-13. ULPI Interfaces - 12-Pin/8-Bit Data SDR Version .....                                     | 3270 |
| 22-14. ULPI TLL Interfaces - 12-Pin/8-Bit Data SDR Version .....                                 | 3271 |
| 22-15. ULPI TLL Interfaces - 8-Pin/4-Bit Data DDR Version .....                                  | 3271 |
| 22-16. High-Speed USB Host Subsystem Functional Interface Signals .....                          | 3272 |
| 22-17. High-Speed USB Host Subsystem Typical Application System .....                            | 3275 |
| 22-18. Serial Interface Sideband Integration - Transceiver Configuration .....                   | 3279 |
| 22-19. Serial Interface Sideband Integration - TLL Configuration .....                           | 3280 |
| 22-20. 6-Pin Unidirectional Using DAT/SE0 Signaling .....                                        | 3281 |
| 22-21. 6-Pin Unidirectional Using DP/DM Signaling .....                                          | 3281 |
| 22-22. 3-Pin Bidirectional Using DAT/SE0 Signaling .....                                         | 3282 |
| 22-23. 4-Pin Bidirectional Using DP/DM Signaling .....                                           | 3282 |
| 22-24. 6-Pin Unidirectional TLL Using DAT/SE0 Signaling .....                                    | 3283 |
| 22-25. 6-Pin Unidirectional TLL Using DP/DM Signaling .....                                      | 3284 |
| 22-26. 3-Pin Bidirectional TLL Using DAT/SE0 Signaling .....                                     | 3284 |
| 22-27. 4-Pin Bidirectional TLL Using DP/DM Signaling .....                                       | 3285 |
| 22-28. 2-Pin Bidirectional TLL Using DP/DM Encoding, With 4-Pin Bidirectional USB Device .....   | 3285 |
| 22-29. 2-Pin Bidirectional TLL Using DAT/SE0 Encoding, With 3-Pin Bidirectional USB Device ..... | 3286 |
| 22-30. High-Speed USB Subsystem Integration .....                                                | 3290 |
| 22-31. High-Speed USB Host Controller Architecture .....                                         | 3300 |
| 22-32. USBTLL Channel .....                                                                      | 3303 |
| 22-33. Per-Configuration Datapath Through USBTLL .....                                           | 3306 |
| 22-34. Selecting and Configuring High-Speed USB Host Subsystem Connectivity .....                | 3312 |
| 23-1. Memory Stick PRO Host Controller Overview .....                                            | 3392 |
| 24-1. MMC/SD/SDIO1 and 3 Overview .....                                                          | 3394 |
| 24-2. MMC/SD/SDIO2 Overview .....                                                                | 3395 |
| 24-3. MMC/SD/SDIO Connected to MMC, SD, or SDIO Card Without External Transceiver .....          | 3397 |
| 24-4. MMC/SD/SDIO2 Connected to MMC, SD, SDIO Card with External Transceiver .....               | 3398 |
| 24-5. MMC/SD/SDIOi Interface Signals .....                                                       | 3398 |
| 24-6. MMC/SD/SDIO2 Interface Signals .....                                                       | 3399 |
| 24-7. Sequential Read Operation (MMC Cards Only) .....                                           | 3400 |
| 24-8. Sequential Write Operation (MMC Cards Only) .....                                          | 3400 |
| 24-9. Multiple Block Read Operation .....                                                        | 3401 |
| 24-10. Multiple Block Write Operation with Card Busy Signal .....                                | 3401 |
| 24-11. Command Token Format .....                                                                | 3402 |
| 24-12. Response Token Format (R1, R3, R4, R5, R6) .....                                          | 3402 |
| 24-13. Response Token Format (R2) .....                                                          | 3402 |
| 24-14. Data Token Format for 1-Bit Transfers .....                                               | 3403 |
| 24-15. Data Token Format for 4-Bit Transfers .....                                               | 3403 |
| 24-16. Data Token Format for 8-Bit Transfers .....                                               | 3404 |
| 24-17. MMC/SD/SDIO1 Integration .....                                                            | 3405 |
| 24-18. DMA Receive Mode .....                                                                    | 3410 |
| 24-19. DMA Transmit Mode .....                                                                   | 3411 |
| 24-20. MMC/SD/SDIO Diagram .....                                                                 | 3414 |
| 24-21. Buffer Management for a Write .....                                                       | 3417 |
| 24-22. Buffer Management for a Read .....                                                        | 3418 |
| 24-23. Busy Timeout for R1b, R5b Response Type .....                                             | 3420 |

|                                                                                           |      |
|-------------------------------------------------------------------------------------------|------|
| 24-24. Busy Timeout After Write CRC Status.....                                           | 3421 |
| 24-25. Write CRC Status Timeout .....                                                     | 3421 |
| 24-26. Read Data Timeout .....                                                            | 3422 |
| 24-27. Boot Acknowledge Timeout When Using CMD0 .....                                     | 3422 |
| 24-28. Boot Acknowledge Timeout When CMD Line Tied To 0 .....                             | 3423 |
| 24-29. Autocommand 12 Timings During Write Transfer.....                                  | 3423 |
| 24-30. Autocommand 12 Timings During Read Transfer.....                                   | 3424 |
| 24-31. MMC/SD/SDIO Controller Meta Initialization Steps .....                             | 3426 |
| 24-32. MMC/SD/SDIO Controller Software Reset Flow .....                                   | 3427 |
| 24-33. MMC/SD/SDIO Controller Wake-Up Configuration .....                                 | 3428 |
| 24-34. MMC/SD/SDIO Controller Bus Configuration .....                                     | 3429 |
| 24-35. MMC/SD/SDIO Controller Card Identification and Selection - Part 1.....             | 3430 |
| 24-36. MMC/SD/SDIO Controller Card Identification and Selection - Part 2.....             | 3431 |
| 24-37. MMC/SD/SDIO Controller Read/Write Transfer Flow in DMA Mode With Interrupt .....   | 3432 |
| 24-38. MMC/SD/SDIO Controller Read/Write Transfer Flow in DMA Mode With Polling .....     | 3433 |
| 24-39. MMC/SD/SDIO Controller Read/Write Transfer Flow Without DMA and With Polling ..... | 3434 |
| 24-40. MMC/SD/SDIO Controller Read/Write in CE-ATA Mode.....                              | 3435 |
| 24-41. MMC/SD/SDIO Controller Suspend Flow .....                                          | 3436 |
| 24-42. MMC/SD/SDIO Controller Resume Flow .....                                           | 3437 |
| 24-43. MMC/SD/SDIO Controller Command Transfer Flow With Polling .....                    | 3438 |
| 24-44. MMC/SD/SDIO Controller Command Transfer Flow With Interrupts .....                 | 3439 |
| 24-45. MMC/SD/SDIO Controller Clock Frequency Change Flow .....                           | 3440 |
| 24-46. MMC/SD/SDIO Power Switching Procedure.....                                         | 3441 |
| 24-47. Overview .....                                                                     | 3442 |
| 24-48. Environment.....                                                                   | 3443 |
| 24-49. Command Transfer.....                                                              | 3444 |
| 24-50. Data Read Transfer .....                                                           | 3444 |
| 24-51. Data Write Transfer .....                                                          | 3444 |
| 25-1. General-Purpose Interface Overview .....                                            | 3495 |
| 25-2. General-Purpose Interface Typical Application System Overview .....                 | 3497 |
| 25-3. General-Purpose Interface Used as a Keyboard Interface .....                        | 3498 |
| 25-4. General-Purpose Interface Integration .....                                         | 3500 |
| 25-5. General-Purpose Interface Description .....                                         | 3507 |
| 25-6. Synchronous Path .....                                                              | 3507 |
| 25-7. Asynchronous Path.....                                                              | 3508 |
| 25-8. Interrupt Request Generation .....                                                  | 3509 |
| 25-9. Wake-Up Request Generation.....                                                     | 3510 |
| 25-10. Write @GPIO_CLEARDATAOUT Register Example .....                                    | 3512 |
| 25-11. Write @GPIO_SETIRQENABLEx Register Example.....                                    | 3513 |
| 26-1. Initialization Process .....                                                        | 3542 |
| 26-2. Device and Power Connections .....                                                  | 3543 |
| 26-3. Clock and Reset Environment .....                                                   | 3545 |
| 26-4. Clock Interface .....                                                               | 3546 |
| 26-5. ROM Code Architecture .....                                                         | 3554 |
| 26-6. 32KB ROM Memory Map.....                                                            | 3555 |
| 26-7. 64KB RAM Memory Map of GP Devices.....                                              | 3557 |
| 26-8. Overall Booting Sequence .....                                                      | 3559 |
| 26-9. Booting Device List Setup .....                                                     | 3562 |
| 26-10. Common Peripheral Booting Protocol .....                                           | 3564 |

[www.ti.com](http://www.ti.com)

---

|                                                                  |      |
|------------------------------------------------------------------|------|
| 26-11. Peripheral Booting Procedure .....                        | 3566 |
| 26-12. Customer USB Descriptor Selection .....                   | 3571 |
| 26-13. Fast External Boot Procedure .....                        | 3573 |
| 26-14. Memory Booting Procedure .....                            | 3574 |
| 26-15. Detailed Memory Booting for Non-XIP Booting Devices ..... | 3575 |
| 26-16. NAND Device Detection .....                               | 3581 |
| 26-17. NAND ID2 Detection .....                                  | 3582 |
| 26-18. Bad NAND Invalid Block Detection .....                    | 3584 |
| 26-19. ECC Locations in NAND Spare Areas.....                    | 3585 |
| 26-20. ECC Locations in 4-KB Page NAND Spare Areas.....          | 3586 |
| 26-21. MLC NAND Data Encoding .....                              | 3587 |
| 26-22. MLC NAND Page Layout.....                                 | 3588 |
| 26-23. OneNAND/Flex-OneNAND Read Sector .....                    | 3589 |
| 26-24. MMC/SD Booting .....                                      | 3591 |
| 26-25. MMC/SD Detection Procedure.....                           | 3592 |
| 26-26. SD/MMC Booting .....                                      | 3594 |
| 26-27. MBR Detection Procedure.....                              | 3596 |
| 26-28. Get MBR Partition .....                                   | 3597 |
| 26-29. Image Format .....                                        | 3600 |
| 26-30. CH Format.....                                            | 3601 |
| 26-31. CONTROL_SAVE_RESTORE_MEM Format .....                     | 3609 |
| 27-1. Debug and Emulation Hardware in the Device .....           | 3616 |
| 27-2. ICEPick Overview .....                                     | 3618 |
| 27-3. ICEPick Overview .....                                     | 3619 |
| 27-4. TAP State Transitions.....                                 | 3620 |
| 27-5. Multiple Read in ROUTER Instruction .....                  | 3625 |
| 27-6. Multiple Write in ROUTER Instruction .....                 | 3625 |
| 27-7. Mixed Read and Write in ROUTER Instruction.....            | 3625 |
| 27-8. SDTI in the Device .....                                   | 3638 |
| 27-9. SDTI Connected in Four Data Pins Mode.....                 | 3639 |
| 27-10. SDTI Connected in Two Data Pins Mode .....                | 3639 |
| 27-11. SDTI Connected in One Data Pin Mode .....                 | 3639 |
| 27-12. Dual-Edge Clock Waveform.....                             | 3640 |
| 27-13. Single-Edge Clock Waveform.....                           | 3640 |
| 27-14. SDTI Integration .....                                    | 3642 |
| 27-15. SDTI Block Diagram .....                                  | 3643 |
| 27-16. EPM Overview .....                                        | 3670 |
| 27-17. EPM Control Access .....                                  | 3674 |

## List of Tables

|       |                                                                                                      |     |
|-------|------------------------------------------------------------------------------------------------------|-----|
| 1-1.  | AM/DM37x Peripherals.....                                                                            | 192 |
| 1-2.  | Summary of Memories Supported by the POP Interface .....                                             | 194 |
| 1-3.  | Subsystem, Co-Processor, and Peripheral Support on AM/DM37x Devices (CBP, CBC and CUS Packages)..... | 195 |
| 1-4.  | CONTROL_PRODUCTION_ID .....                                                                          | 197 |
| 1-5.  | Device Identification Registers .....                                                                | 197 |
| 1-6.  | Chip Identification .....                                                                            | 198 |
| 1-7.  | CONTROL_IDCODE Register Value.....                                                                   | 199 |
| 1-8.  | CONTROL_PRODUCTION_ID Register Silicon Type Identification .....                                     | 199 |
| 1-9.  | CONTROL_DIE_ID .....                                                                                 | 199 |
| 2-1.  | Global Memory Space Mapping .....                                                                    | 205 |
| 2-2.  | L3 Control Register Mapping .....                                                                    | 207 |
| 2-3.  | L4-Core Memory Space Mapping .....                                                                   | 209 |
| 2-4.  | L4-Wakeup Memory Space Mapping .....                                                                 | 211 |
| 2-5.  | L4-Peripheral Memory Space Mapping .....                                                             | 212 |
| 2-6.  | L4-Emulation Memory Space Mapping .....                                                              | 213 |
| 2-7.  | Register Access Restrictions .....                                                                   | 215 |
| 2-8.  | L3 Interconnect View of the IVA2.2 Subsystem Memory Space .....                                      | 219 |
| 2-9.  | DSP View of the IVA2.2 Subsystem Memory Space.....                                                   | 220 |
| 2-10. | EDMA View of the IVA2.2 Subsystem Memory Space .....                                                 | 221 |
| 3-1.  | States of a Clock Domain.....                                                                        | 229 |
| 3-2.  | External Clock Signals .....                                                                         | 241 |
| 3-3.  | External Reset Signals .....                                                                         | 243 |
| 3-4.  | Power Control Interface .....                                                                        | 244 |
| 3-5.  | PRCM Power Domains.....                                                                              | 247 |
| 3-6.  | PRCM Reset Signals .....                                                                             | 247 |
| 3-7.  | Global Reset Sources .....                                                                           | 251 |
| 3-8.  | Local Reset Sources .....                                                                            | 252 |
| 3-9.  | MPU Power Domain Reset Signal.....                                                                   | 254 |
| 3-10. | NEON Power Domain Reset Signal.....                                                                  | 255 |
| 3-11. | IVA2 Power Domain Reset Signals.....                                                                 | 255 |
| 3-12. | CORE Power Domain Reset Signals.....                                                                 | 255 |
| 3-13. | DSS Power Domain Reset Signal .....                                                                  | 256 |
| 3-14. | CAM Power Domain Reset Signal .....                                                                  | 256 |
| 3-15. | USBHOST Power Domain Reset Signal.....                                                               | 256 |
| 3-16. | SGX Power Domain Reset Signal .....                                                                  | 256 |
| 3-17. | WKUP Power Domain Reset Signals .....                                                                | 256 |
| 3-18. | PER Power Domain Reset Signal .....                                                                  | 257 |
| 3-19. | SmartReflex Power Domain Reset Signal .....                                                          | 257 |
| 3-20. | DPLL Power Domain Reset Signals.....                                                                 | 257 |
| 3-21. | EFUSE Power Domain Reset Signal.....                                                                 | 257 |
| 3-22. | BANDGAP Logic Reset Signal .....                                                                     | 257 |
| 3-23. | Global Reset Summary .....                                                                           | 264 |
| 3-24. | Local Reset Summary .....                                                                            | 265 |
| 3-25. | Power Domain Modules.....                                                                            | 282 |
| 3-26. | Power Domain States .....                                                                            | 284 |
| 3-27. | Domain Power Control Summary .....                                                                   | 285 |

---

|       |                                                      |     |
|-------|------------------------------------------------------|-----|
| 3-28. | System Clock Input Configurations .....              | 292 |
| 3-29. | External Clock I/Os .....                            | 293 |
| 3-30. | Low-Jitter DPLL Output Clocks .....                  | 307 |
| 3-31. | Other DPLL Output Clocks .....                       | 307 |
| 3-32. | Source-Clock Summary .....                           | 307 |
| 3-33. | Clock Distribution .....                             | 322 |
| 3-34. | Peripheral Module Functional Clock Frequencies ..... | 324 |
| 3-35. | sys_clkreq Pad Direction Control .....               | 325 |
| 3-36. | System Clock Operation Modes .....                   | 326 |
| 3-37. | Oscillator Controls .....                            | 327 |
| 3-38. | DPLL Multiplier and Divider Factors .....            | 328 |
| 3-39. | DPLL Power Modes .....                               | 329 |
| 3-40. | DPLL Power Mode Support .....                        | 329 |
| 3-41. | DPLL Power Mode Control .....                        | 330 |
| 3-42. | LP Mode Control .....                                | 330 |
| 3-43. | Clock Path Power-Down Control .....                  | 331 |
| 3-44. | DPLL Recalibration Controls .....                    | 332 |
| 3-45. | Common PRM Source-Clock Gating Controls .....        | 334 |
| 3-46. | Common CM Source-Clock Gating Controls .....         | 337 |
| 3-47. | Common Interface Clock-Gating Controls .....         | 337 |
| 3-48. | DPLL Power Domain Clock-Gating Controls .....        | 338 |
| 3-49. | SGX Power Domain Clock-Gating Controls .....         | 339 |
| 3-50. | CORE Power Domain Clock-Gating Controls .....        | 341 |
| 3-51. | EFUSE Power Domain Clock-Gating Control .....        | 342 |
| 3-52. | DSS Power Domain Clock-Gating Controls .....         | 343 |
| 3-53. | CAM Power Domain Clock-Gating Controls .....         | 344 |
| 3-54. | USBHOST Power Domain Clock-Gating Controls .....     | 344 |
| 3-55. | WKUP Power Domain Clock-Gating Controls .....        | 345 |
| 3-56. | PER Power Domain Clock-Gating Controls .....         | 348 |
| 3-57. | SMARTREFLEX Power Domain Clock-Gating Controls ..... | 348 |
| 3-58. | Processor Clock Configuration Controls .....         | 350 |
| 3-59. | Processor Clock Configurations .....                 | 350 |
| 3-60. | Interface Clock Configuration Controls .....         | 351 |
| 3-61. | Functional Clock Configuration Controls .....        | 351 |
| 3-62. | Power-State-Related Sleep Transition Actions .....   | 355 |
| 3-63. | MPU Power Domain Wake-Up Events .....                | 356 |
| 3-64. | NEON Power Domain Wake-Up Events .....               | 357 |
| 3-65. | IVA2 Power Domain Wake-Up Events .....               | 357 |
| 3-66. | SGX Power Domain Wake-Up Events .....                | 358 |
| 3-67. | CORE Power Domain Wake-Up Events .....               | 358 |
| 3-68. | DSS Power Domain Wake-Up Events .....                | 359 |
| 3-69. | CAM Power Domain Wake-Up Events .....                | 359 |
| 3-70. | USBHOST Power Domain Wake-Up Events .....            | 359 |
| 3-71. | PER Power Domain Wake-Up Events .....                | 360 |
| 3-72. | EMU Power Domain Wake-Up Events .....                | 360 |
| 3-73. | WKUP Power Domain Wake-Up Events .....               | 361 |
| 3-74. | Clock Domain Mute Conditions .....                   | 361 |
| 3-75. | Sleep Dependencies .....                             | 363 |
| 3-76. | Wake-Up Dependencies .....                           | 364 |

|                                                                      |     |
|----------------------------------------------------------------------|-----|
| 3-77. Interrupt Descriptions .....                                   | 369 |
| 3-78. MPU Interrupt Event Descriptions .....                         | 369 |
| 3-79. IVA2 Interrupt Event Descriptions .....                        | 371 |
| 3-80. Voltage Domain Controls Summary .....                          | 375 |
| 3-81. VDD1 Voltage Domain Dependencies .....                         | 376 |
| 3-82. VDD2 Voltage Domain Dependencies .....                         | 376 |
| 3-83. Remaining Voltage Domain Dependencies .....                    | 377 |
| 3-84. SmartReflex Interrupts .....                                   | 384 |
| 3-85. SmartReflex Interrupt Enable and Status Bits .....             | 384 |
| 3-86. Voltage Processor Interrupts .....                             | 386 |
| 3-87. Voltage Processor Interrupt Enable and Status Bits .....       | 387 |
| 3-88. GFX Functional Clock Ratio Settings .....                      | 406 |
| 3-89. Interface Clock Autoidle Settings .....                        | 408 |
| 3-90. Clock State Transition Settings .....                          | 409 |
| 3-91. Sleep Dependency Settings .....                                | 411 |
| 3-92. CM Instance Summary .....                                      | 447 |
| 3-93. IVA2_CM Register Summary .....                                 | 447 |
| 3-94. CM_FCLKEN_IVA2 .....                                           | 448 |
| 3-95. Register Call Summary for Register CM_FCLKEN_IVA2 .....        | 448 |
| 3-96. CM_CLKEN_PLL_IVA2 .....                                        | 448 |
| 3-97. Register Call Summary for Register CM_CLKEN_PLL_IVA2 .....     | 449 |
| 3-98. CM_IDLEST_IVA2 .....                                           | 449 |
| 3-99. Register Call Summary for Register CM_IDLEST_IVA2 .....        | 450 |
| 3-100. CM_IDLEST_PLL_IVA2 .....                                      | 450 |
| 3-101. Register Call Summary for Register CM_IDLEST_PLL_IVA2 .....   | 450 |
| 3-102. CM_AUTOIDLE_PLL_IVA2 .....                                    | 450 |
| 3-103. Register Call Summary for Register CM_AUTOIDLE_PLL_IVA2 ..... | 451 |
| 3-104. CM_CLKSEL1_PLL_IVA2 .....                                     | 451 |
| 3-105. Register Call Summary for Register CM_CLKSEL1_PLL_IVA2 .....  | 451 |
| 3-106. CM_CLKSEL2_PLL_IVA2 .....                                     | 452 |
| 3-107. Register Call Summary for Register CM_CLKSEL2_PLL_IVA2 .....  | 452 |
| 3-108. CM_CLKSTCTRL_IVA2 .....                                       | 453 |
| 3-109. Register Call Summary for Register CM_CLKSTCTRL_IVA2 .....    | 453 |
| 3-110. CM_CLKSTST_IVA2 .....                                         | 453 |
| 3-111. Register Call Summary for Register CM_CLKSTST_IVA2 .....      | 454 |
| 3-112. OCP_System_Reg_CM Register Summary .....                      | 454 |
| 3-113. CM_REVISION .....                                             | 454 |
| 3-114. Register Call Summary for Register CM_REVISION .....          | 454 |
| 3-115. CM_SYSCONFIG .....                                            | 455 |
| 3-116. Register Call Summary for Register CM_SYSCONFIG .....         | 455 |
| 3-117. MPU_CM Register Summary .....                                 | 455 |
| 3-118. CM_CLKEN_PLL_MPU .....                                        | 456 |
| 3-119. Register Call Summary for Register CM_CLKEN_PLL_MPU .....     | 456 |
| 3-120. CM_IDLEST_MPU .....                                           | 457 |
| 3-121. Register Call Summary for Register CM_IDLEST_MPU .....        | 457 |
| 3-122. CM_IDLEST_PLL_MPU .....                                       | 457 |
| 3-123. Register Call Summary for Register CM_IDLEST_PLL_MPU .....    | 457 |
| 3-124. CM_AUTOIDLE_PLL_MPU .....                                     | 458 |
| 3-125. Register Call Summary for Register CM_AUTOIDLE_PLL_MPU .....  | 458 |

---

|                                                                   |     |
|-------------------------------------------------------------------|-----|
| 3-126. CM_CLKSEL1_PLL_MPU .....                                   | 458 |
| 3-127. Register Call Summary for Register CM_CLKSEL1_PLL_MPU..... | 459 |
| 3-128. CM_CLKSEL2_PLL_MPU .....                                   | 459 |
| 3-129. Register Call Summary for Register CM_CLKSEL2_PLL_MPU..... | 460 |
| 3-130. CM_CLKSTCTRL_MPU.....                                      | 460 |
| 3-131. Register Call Summary for Register CM_CLKSTCTRL_MPU .....  | 461 |
| 3-132. CM_CLKSTST_MPU .....                                       | 461 |
| 3-133. Register Call Summary for Register CM_CLKSTST_MPU.....     | 461 |
| 3-134. CORE_CM Register Summary .....                             | 462 |
| 3-135. CM_FCLKEN1_CORE .....                                      | 462 |
| 3-136. Register Call Summary for Register CM_FCLKEN1_CORE .....   | 463 |
| 3-137. CM_FCLKEN3_CORE .....                                      | 464 |
| 3-138. Register Call Summary for Register CM_FCLKEN3_CORE .....   | 464 |
| 3-139. CM_ICLKEN1_CORE .....                                      | 464 |
| 3-140. Register Call Summary for Register CM_ICLKEN1_CORE .....   | 466 |
| 3-141. CM_ICLKEN3_CORE .....                                      | 466 |
| 3-142. Register Call Summary for Register CM_ICLKEN3_CORE .....   | 467 |
| 3-143. CM_IDLEST1_CORE.....                                       | 467 |
| 3-144. Register Call Summary for Register CM_IDLEST1_CORE .....   | 469 |
| 3-145. CM_IDLEST3_CORE.....                                       | 469 |
| 3-146. Register Call Summary for Register CM_IDLEST3_CORE .....   | 470 |
| 3-147. CM_AUTOIDLE1_CORE .....                                    | 470 |
| 3-148. Register Call Summary for Register CM_AUTOIDLE1_CORE ..... | 472 |
| 3-149. CM_AUTOIDLE3_CORE .....                                    | 473 |
| 3-150. Register Call Summary for Register CM_AUTOIDLE3_CORE ..... | 473 |
| 3-151. CM_CLKSEL_CORE .....                                       | 473 |
| 3-152. Register Call Summary for Register CM_CLKSEL_CORE.....     | 474 |
| 3-153. CM_CLKSTCTRL_CORE.....                                     | 474 |
| 3-154. Register Call Summary for Register CM_CLKSTCTRL_CORE ..... | 475 |
| 3-155. CM_CLKSTST_CORE .....                                      | 475 |
| 3-156. Register Call Summary for Register CM_CLKSTST_CORE .....   | 475 |
| 3-157. SGX_CM Register Summary .....                              | 476 |
| 3-158. CM_FCLKEN_SGX .....                                        | 476 |
| 3-159. Register Call Summary for Register CM_FCLKEN_SGX .....     | 476 |
| 3-160. CM_ICLKEN_SGX.....                                         | 477 |
| 3-161. Register Call Summary for Register CM_ICLKEN_SGX .....     | 477 |
| 3-162. CM_IDLEST_SGX .....                                        | 477 |
| 3-163. Register Call Summary for Register CM_IDLEST_SGX.....      | 477 |
| 3-164. CM_CLKSEL_SGX .....                                        | 478 |
| 3-165. Register Call Summary for Register CM_CLKSEL_SGX .....     | 478 |
| 3-166. CM_SLEEPDEP_SGX .....                                      | 478 |
| 3-167. Register Call Summary for Register CM_SLEEPDEP_SGX .....   | 479 |
| 3-168. CM_CLKSTCTRL_SGX .....                                     | 479 |
| 3-169. Register Call Summary for Register CM_CLKSTCTRL_SGX .....  | 479 |
| 3-170. CM_CLKSTST_SGX .....                                       | 480 |
| 3-171. Register Call Summary for Register CM_CLKSTST_SGX .....    | 480 |
| 3-172. WKUP_CM Register Summary .....                             | 480 |
| 3-173. CM_FCLKEN_WKUP.....                                        | 481 |
| 3-174. Register Call Summary for Register CM_FCLKEN_WKUP .....    | 481 |

|                                                                  |     |
|------------------------------------------------------------------|-----|
| 3-175. CM_ICLKEN_WKUP .....                                      | 482 |
| 3-176. Register Call Summary for Register CM_ICLKEN_WKUP .....   | 482 |
| 3-177. CM_IDLEST_WKUP .....                                      | 483 |
| 3-178. Register Call Summary for Register CM_IDLEST_WKUP .....   | 483 |
| 3-179. CM_AUTOIDLE_WKUP .....                                    | 484 |
| 3-180. Register Call Summary for Register CM_AUTOIDLE_WKUP ..... | 484 |
| 3-181. CM_CLKSEL_WKUP .....                                      | 485 |
| 3-182. Register Call Summary for Register CM_CLKSEL_WKUP .....   | 485 |
| 3-183. Clock_Control_Reg_CM Register Summary .....               | 485 |
| 3-184. CM_CLKEN_PLL .....                                        | 486 |
| 3-185. Register Call Summary for Register CM_CLKEN_PLL .....     | 487 |
| 3-186. CM_CLKEN2_PLL .....                                       | 488 |
| 3-187. Register Call Summary for Register CM_CLKEN2_PLL .....    | 488 |
| 3-188. CM_IDLEST_CKGEN .....                                     | 489 |
| 3-189. Register Call Summary for Register CM_IDLEST_CKGEN .....  | 490 |
| 3-190. CM_IDLEST2_CKGEN .....                                    | 490 |
| 3-191. Register Call Summary for Register CM_IDLEST2_CKGEN ..... | 491 |
| 3-192. CM_AUTOIDLE_PLL .....                                     | 491 |
| 3-193. Register Call Summary for Register CM_AUTOIDLE_PLL .....  | 491 |
| 3-194. CM_AUTOIDLE2_PLL .....                                    | 492 |
| 3-195. Register Call Summary for Register CM_AUTOIDLE2_PLL ..... | 492 |
| 3-196. CM_CLKSEL1_PLL .....                                      | 492 |
| 3-197. Register Call Summary for Register CM_CLKSEL1_PLL .....   | 494 |
| 3-198. CM_CLKSEL2_PLL .....                                      | 494 |
| 3-199. Register Call Summary for Register CM_CLKSEL2_PLL .....   | 494 |
| 3-200. CM_CLKSEL3_PLL .....                                      | 495 |
| 3-201. Register Call Summary for Register CM_CLKSEL3_PLL .....   | 495 |
| 3-202. CM_CLKSEL4_PLL .....                                      | 496 |
| 3-203. Register Call Summary for Register CM_CLKSEL4_PLL .....   | 496 |
| 3-204. CM_CLKSEL5_PLL .....                                      | 496 |
| 3-205. Register Call Summary for Register CM_CLKSEL5_PLL .....   | 497 |
| 3-206. CM_CLKOUT_CTRL .....                                      | 497 |
| 3-207. Register Call Summary for Register CM_CLKOUT_CTRL .....   | 498 |
| 3-208. DSS_CM Register Summary .....                             | 498 |
| 3-209. CM_FCLKEN_DSS .....                                       | 498 |
| 3-210. Register Call Summary for Register CM_FCLKEN_DSS .....    | 499 |
| 3-211. CM_ICLKEN_DSS .....                                       | 499 |
| 3-212. Register Call Summary for Register CM_ICLKEN_DSS .....    | 499 |
| 3-213. CM_IDLEST_DSS .....                                       | 500 |
| 3-214. Register Call Summary for Register CM_IDLEST_DSS .....    | 500 |
| 3-215. CM_AUTOIDLE_DSS .....                                     | 500 |
| 3-216. Register Call Summary for Register CM_AUTOIDLE_DSS .....  | 501 |
| 3-217. CM_CLKSEL_DSS .....                                       | 501 |
| 3-218. Register Call Summary for Register CM_CLKSEL_DSS .....    | 503 |
| 3-219. CM_SLEEPDEP_DSS .....                                     | 504 |
| 3-220. Register Call Summary for Register CM_SLEEPDEP_DSS .....  | 504 |
| 3-221. CM_CLKSTCTRL_DSS .....                                    | 504 |
| 3-222. Register Call Summary for Register CM_CLKSTCTRL_DSS ..... | 505 |
| 3-223. CM_CLKSTST_DSS .....                                      | 505 |

---

|                                                                  |     |
|------------------------------------------------------------------|-----|
| 3-224. Register Call Summary for Register CM_CLKSTST_DSS .....   | 505 |
| 3-225. CAM_CM Register Summary.....                              | 506 |
| 3-226. CM_FCLKEN_CAM.....                                        | 506 |
| 3-227. Register Call Summary for Register CM_FCLKEN_CAM .....    | 506 |
| 3-228. CM_ICLKEN_CAM.....                                        | 507 |
| 3-229. Register Call Summary for Register CM_ICLKEN_CAM .....    | 507 |
| 3-230. CM_IDLEST_CAM.....                                        | 507 |
| 3-231. Register Call Summary for Register CM_IDLEST_CAM .....    | 507 |
| 3-232. CM_AUTOIDLE_CAM.....                                      | 508 |
| 3-233. Register Call Summary for Register CM_AUTOIDLE_CAM .....  | 508 |
| 3-234. CM_CLKSEL_CAM .....                                       | 508 |
| 3-235. Register Call Summary for Register CM_CLKSEL_CAM .....    | 509 |
| 3-236. CM_SLEEPDEP_CAM .....                                     | 510 |
| 3-237. Register Call Summary for Register CM_SLEEPDEP_CAM.....   | 510 |
| 3-238. CM_CLKSTCTRL_CAM.....                                     | 510 |
| 3-239. Register Call Summary for Register CM_CLKSTCTRL_CAM ..... | 511 |
| 3-240. CM_CLKSTST_CAM .....                                      | 511 |
| 3-241. Register Call Summary for Register CM_CLKSTST_CAM.....    | 511 |
| 3-242. PER_CM Register Summary .....                             | 512 |
| 3-243. CM_FCLKEN_PER .....                                       | 512 |
| 3-244. Register Call Summary for Register CM_FCLKEN_PER.....     | 513 |
| 3-245. CM_ICLKEN_PER .....                                       | 514 |
| 3-246. Register Call Summary for Register CM_ICLKEN_PER .....    | 515 |
| 3-247. CM_IDLEST_PER .....                                       | 515 |
| 3-248. Register Call Summary for Register CM_IDLEST_PER.....     | 517 |
| 3-249. CM_AUTOIDLE_PER .....                                     | 517 |
| 3-250. Register Call Summary for Register CM_AUTOIDLE_PER .....  | 519 |
| 3-251. CM_CLKSEL_PER .....                                       | 520 |
| 3-252. Register Call Summary for Register CM_CLKSEL_PER .....    | 520 |
| 3-253. CM_SLEEPDEP_PER .....                                     | 521 |
| 3-254. Register Call Summary for Register CM_SLEEPDEP_PER .....  | 521 |
| 3-255. CM_CLKSTCTRL_PER .....                                    | 521 |
| 3-256. Register Call Summary for Register CM_CLKSTCTRL_PER.....  | 522 |
| 3-257. CM_CLKSTST_PER.....                                       | 522 |
| 3-258. Register Call Summary for Register CM_CLKSTST_PER .....   | 522 |
| 3-259. EMU_CM Register Summary.....                              | 523 |
| 3-260. CM_CLKSEL1_EMU .....                                      | 523 |
| 3-261. Register Call Summary for Register CM_CLKSEL1_EMU .....   | 526 |
| 3-262. CM_CLKSTCTRL_EMU.....                                     | 526 |
| 3-263. Register Call Summary for Register CM_CLKSTCTRL_EMU ..... | 526 |
| 3-264. CM_CLKSTST_EMU .....                                      | 527 |
| 3-265. Register Call Summary for Register CM_CLKSTST_EMU .....   | 527 |
| 3-266. CM_CLKSEL2_EMU .....                                      | 527 |
| 3-267. Register Call Summary for Register CM_CLKSEL2_EMU .....   | 528 |
| 3-268. CM_CLKSEL3_EMU .....                                      | 528 |
| 3-269. Register Call Summary for Register CM_CLKSEL3_EMU .....   | 528 |
| 3-270. Global_Reg_CM Register Summary .....                      | 528 |
| 3-271. CM_POLCTRL .....                                          | 529 |
| 3-272. Register Call Summary for Register CM_POLCTRL .....       | 529 |

|                                                                      |     |
|----------------------------------------------------------------------|-----|
| 3-273. NEON_CM Register Summary .....                                | 529 |
| 3-274. CM_IDLEST_NEON .....                                          | 530 |
| 3-275. Register Call Summary for Register CM_IDLEST_NEON.....        | 530 |
| 3-276. CM_CLKSTCTRL_NEON.....                                        | 530 |
| 3-277. Register Call Summary for Register CM_CLKSTCTRL_NEON .....    | 531 |
| 3-278. USBHOST_CM Register Summary.....                              | 531 |
| 3-279. CM_FCLKEN_USBHOST.....                                        | 531 |
| 3-280. Register Call Summary for Register CM_FCLKEN_USBHOST .....    | 532 |
| 3-281. CM_ICLKEN_USBHOST .....                                       | 532 |
| 3-282. Register Call Summary for Register CM_ICLKEN_USBHOST .....    | 532 |
| 3-283. CM_IDLEST_USBHOST .....                                       | 532 |
| 3-284. Register Call Summary for Register CM_IDLEST_USBHOST .....    | 533 |
| 3-285. CM_AUTOIDLE_USBHOST.....                                      | 533 |
| 3-286. Register Call Summary for Register CM_AUTOIDLE_USBHOST .....  | 534 |
| 3-287. CM_SLEEPDEP_USBHOST .....                                     | 534 |
| 3-288. Register Call Summary for Register CM_SLEEPDEP_USBHOST.....   | 534 |
| 3-289. CM_CLKSTCTRL_USBHOST .....                                    | 535 |
| 3-290. Register Call Summary for Register CM_CLKSTCTRL_USBHOST ..... | 535 |
| 3-291. CM_CLKSTST_USBHOST .....                                      | 535 |
| 3-292. Register Call Summary for Register CM_CLKSTST_USBHOST.....    | 536 |
| 3-293. PRM Instance Summary .....                                    | 536 |
| 3-294. IVA2_PRM Register Summary .....                               | 536 |
| 3-295. RM_RSTCTRL_IVA2 .....                                         | 537 |
| 3-296. Register Call Summary for Register RM_RSTCTRL_IVA2.....       | 537 |
| 3-297. RM_RSTST_IVA2.....                                            | 538 |
| 3-298. Register Call Summary for Register RM_RSTST_IVA2 .....        | 539 |
| 3-299. PM_WKDEP_IVA2.....                                            | 540 |
| 3-300. Register Call Summary for Register PM_WKDEP_IVA2 .....        | 540 |
| 3-301. PM_PWSTCTRL_IVA2.....                                         | 541 |
| 3-302. Register Call Summary for Register PM_PWSTCTRL_IVA2 .....     | 542 |
| 3-303. PM_PWSTST_IVA2 .....                                          | 543 |
| 3-304. Register Call Summary for Register PM_PWSTST_IVA2 .....       | 544 |
| 3-305. PM_PREPWSTST_IVA2 .....                                       | 544 |
| 3-306. Register Call Summary for Register PM_PREPWSTST_IVA2 .....    | 545 |
| 3-307. PRM_IRQSTATUS_IVA2 .....                                      | 545 |
| 3-308. Register Call Summary for Register PRM_IRQSTATUS_IVA2.....    | 546 |
| 3-309. PRM_IRQENABLE_IVA2 .....                                      | 546 |
| 3-310. Register Call Summary for Register PRM_IRQENABLE_IVA2.....    | 547 |
| 3-311. OCP_System_Reg_PRM Register Summary .....                     | 547 |
| 3-312. PRM_REVISION .....                                            | 547 |
| 3-313. Register Call Summary for Register PRM_REVISION.....          | 548 |
| 3-314. PRM_SYSCONFIG .....                                           | 548 |
| 3-315. Register Call Summary for Register PRM_SYSCONFIG.....         | 548 |
| 3-316. PRM_IRQSTATUS_MPU .....                                       | 548 |
| 3-317. Register Call Summary for Register PRM_IRQSTATUS_MPU.....     | 553 |
| 3-318. PRM_IRQENABLE_MPU .....                                       | 553 |
| 3-319. Register Call Summary for Register PRM_IRQENABLE_MPU.....     | 556 |
| 3-320. MPU_PRM Register Summary.....                                 | 556 |
| 3-321. RM_RSTST_MPU .....                                            | 556 |

---

|                                                                      |     |
|----------------------------------------------------------------------|-----|
| 3-322. Register Call Summary for Register RM_RSTST_MPUMPU.....       | 557 |
| 3-323. PM_WKDEP_MPUMPU.....                                          | 557 |
| 3-324. Register Call Summary for Register PM_WKDEP_MPUMPU.....       | 558 |
| 3-325. PM_EVGENCTRL_MPUMPU.....                                      | 558 |
| 3-326. Register Call Summary for Register PM_EVGENCTRL_MPUMPU.....   | 559 |
| 3-327. PM_EVGENONTIM_MPUMPU.....                                     | 559 |
| 3-328. Register Call Summary for Register PM_EVGENONTIM_MPUMPU.....  | 560 |
| 3-329. PM_EVGENOFFTIM_MPUMPU.....                                    | 560 |
| 3-330. Register Call Summary for Register PM_EVGENOFFTIM_MPUMPU..... | 560 |
| 3-331. PM_PWSTCTRL_MPUMPU.....                                       | 560 |
| 3-332. Register Call Summary for Register PM_PWSTCTRL_MPUMPU.....    | 561 |
| 3-333. PM_PWSTST_MPUMPU.....                                         | 561 |
| 3-334. Register Call Summary for Register PM_PWSTST_MPUMPU.....      | 562 |
| 3-335. PM_PREPWSTST_MPUMPU.....                                      | 562 |
| 3-336. Register Call Summary for Register PM_PREPWSTST_MPUMPU.....   | 563 |
| 3-337. CORE_PRM Register Summary .....                               | 563 |
| 3-338. RM_RSTST_CORE.....                                            | 564 |
| 3-339. Register Call Summary for Register RM_RSTST_CORE .....        | 564 |
| 3-340. PM_WKEN1_CORE .....                                           | 565 |
| 3-341. Register Call Summary for Register PM_WKEN1_CORE .....        | 566 |
| 3-342. PM_MPUGRPSEL1_CORE .....                                      | 566 |
| 3-343. Register Call Summary for Register PM_MPUGRPSEL1_CORE .....   | 568 |
| 3-344. PM_IVA2GRPSEL1_CORE .....                                     | 569 |
| 3-345. Register Call Summary for Register PM_IVA2GRPSEL1_CORE .....  | 571 |
| 3-346. PM_WKST1_CORE .....                                           | 571 |
| 3-347. Register Call Summary for Register PM_WKST1_CORE .....        | 573 |
| 3-348. PM_WKST3_CORE .....                                           | 573 |
| 3-349. Register Call Summary for Register PM_WKST3_CORE .....        | 574 |
| 3-350. PM_PWSTCTRL_CORE .....                                        | 574 |
| 3-351. Register Call Summary for Register PM_PWSTCTRL_CORE .....     | 575 |
| 3-352. PM_PWSTST_CORE .....                                          | 576 |
| 3-353. Register Call Summary for Register PM_PWSTST_CORE .....       | 576 |
| 3-354. PM_PREPWSTST_CORE .....                                       | 577 |
| 3-355. Register Call Summary for Register PM_PREPWSTST_CORE .....    | 577 |
| 3-356. PM_WKEN3_CORE .....                                           | 578 |
| 3-357. Register Call Summary for Register PM_WKEN3_CORE .....        | 578 |
| 3-358. PM_IVA2GRPSEL3_CORE .....                                     | 578 |
| 3-359. Register Call Summary for Register PM_IVA2GRPSEL3_CORE .....  | 579 |
| 3-360. PM_MPUGRPSEL3_CORE .....                                      | 579 |
| 3-361. Register Call Summary for Register PM_MPUGRPSEL3_CORE .....   | 579 |
| 3-362. SGX_PRM Register Summary .....                                | 579 |
| 3-363. RM_RSTST_SGX.....                                             | 580 |
| 3-364. Register Call Summary for Register RM_RSTST_SGX .....         | 581 |
| 3-365. PM_WKDEP_SGX.....                                             | 581 |
| 3-366. Register Call Summary for Register PM_WKDEP_SGX .....         | 581 |
| 3-367. PM_PWSTCTRL_SGX .....                                         | 582 |
| 3-368. Register Call Summary for Register PM_PWSTCTRL_SGX .....      | 582 |
| 3-369. PM_PWSTST_SGX .....                                           | 582 |
| 3-370. Register Call Summary for Register PM_PWSTST_SGX .....        | 583 |

|                                                                    |     |
|--------------------------------------------------------------------|-----|
| 3-371. PM_PREPWSTST_SGX .....                                      | 583 |
| 3-372. Register Call Summary for Register PM_PREPWSTST_SGX .....   | 584 |
| 3-373. WKUP_PRM Register Summary.....                              | 584 |
| 3-374. PM_WKEN_WKUP .....                                          | 584 |
| 3-375. Register Call Summary for Register PM_WKEN_WKUP .....       | 585 |
| 3-376. PM_MPUGRPSEL_WKUP .....                                     | 585 |
| 3-377. Register Call Summary for Register PM_MPUGRPSEL_WKUP .....  | 586 |
| 3-378. PM_IVA2GRPSEL_WKUP.....                                     | 587 |
| 3-379. Register Call Summary for Register PM_IVA2GRPSEL_WKUP ..... | 587 |
| 3-380. PM_WKST_WKUP.....                                           | 588 |
| 3-381. Register Call Summary for Register PM_WKST_WKUP .....       | 589 |
| 3-382. Clock_Control_Reg_PRM Register Summary .....                | 589 |
| 3-383. PRM_CLKSEL.....                                             | 589 |
| 3-384. Register Call Summary for Register PRM_CLKSEL .....         | 590 |
| 3-385. PRM_CLKOUT_CTRL .....                                       | 590 |
| 3-386. Register Call Summary for Register PRM_CLKOUT_CTRL .....    | 590 |
| 3-387. DSS_PRM Register Summary .....                              | 591 |
| 3-388. RM_RSTST_DSS .....                                          | 591 |
| 3-389. Register Call Summary for Register RM_RSTST_DSS .....       | 592 |
| 3-390. PM_WKEN_DSS .....                                           | 592 |
| 3-391. Register Call Summary for Register PM_WKEN_DSS .....        | 592 |
| 3-392. PM_WKDEP_DSS .....                                          | 592 |
| 3-393. Register Call Summary for Register PM_WKDEP_DSS .....       | 593 |
| 3-394. PM_PWSTCTRL_DSS .....                                       | 593 |
| 3-395. Register Call Summary for Register PM_PWSTCTRL_DSS.....     | 594 |
| 3-396. PM_PWSTST_DSS.....                                          | 594 |
| 3-397. Register Call Summary for Register PM_PWSTST_DSS .....      | 594 |
| 3-398. PM_PREPWSTST_DSS .....                                      | 595 |
| 3-399. Register Call Summary for Register PM_PREPWSTST_DSS.....    | 595 |
| 3-400. CAM_PRM Register Summary .....                              | 595 |
| 3-401. RM_RSTST_CAM .....                                          | 596 |
| 3-402. Register Call Summary for Register RM_RSTST_CAM .....       | 596 |
| 3-403. PM_WKDEP_CAM.....                                           | 597 |
| 3-404. Register Call Summary for Register PM_WKDEP_CAM .....       | 597 |
| 3-405. PM_PWSTCTRL_CAM.....                                        | 597 |
| 3-406. Register Call Summary for Register PM_PWSTCTRL_CAM .....    | 598 |
| 3-407. PM_PWSTST_CAM .....                                         | 598 |
| 3-408. Register Call Summary for Register PM_PWSTST_CAM.....       | 599 |
| 3-409. PM_PREPWSTST_CAM.....                                       | 599 |
| 3-410. Register Call Summary for Register PM_PREPWSTST_CAM .....   | 599 |
| 3-411. PER_PRM Register Summary .....                              | 600 |
| 3-412. RM_RSTST_PER .....                                          | 600 |
| 3-413. Register Call Summary for Register RM_RSTST_PER .....       | 601 |
| 3-414. PM_WKEN_PER .....                                           | 601 |
| 3-415. Register Call Summary for Register PM_WKEN_PER .....        | 602 |
| 3-416. PM_MPUGRPSEL_PER .....                                      | 603 |
| 3-417. Register Call Summary for Register PM_MPUGRPSEL_PER .....   | 605 |
| 3-418. PM_IVA2GRPSEL_PER .....                                     | 605 |
| 3-419. Register Call Summary for Register PM_IVA2GRPSEL_PER.....   | 607 |

---

|                                                                    |     |
|--------------------------------------------------------------------|-----|
| 3-420. PM_WKST_PER .....                                           | 607 |
| 3-421. Register Call Summary for Register PM_WKST_PER.....         | 610 |
| 3-422. PM_WKDEP_PER .....                                          | 610 |
| 3-423. Register Call Summary for Register PM_WKDEP_PER .....       | 610 |
| 3-424. PM_PWSTCTRL_PER .....                                       | 611 |
| 3-425. Register Call Summary for Register PM_PWSTCTRL_PER.....     | 611 |
| 3-426. PM_PWSTST_PER.....                                          | 612 |
| 3-427. Register Call Summary for Register PM_PWSTST_PER .....      | 612 |
| 3-428. PM_PREPWSTST_PER .....                                      | 612 |
| 3-429. Register Call Summary for Register PM_PREPWSTST_PER.....    | 613 |
| 3-430. EMU_PRM Register Summary.....                               | 613 |
| 3-431. RM_RSTST_EMU .....                                          | 614 |
| 3-432. Register Call Summary for Register RM_RSTST_EMU.....        | 614 |
| 3-433. PM_PWSTST_EMU .....                                         | 615 |
| 3-434. Register Call Summary for Register PM_PWSTST_EMU.....       | 615 |
| 3-435. Global_Reg_PRM Register Summary.....                        | 615 |
| 3-436. PRM_VC_SMPS_SA .....                                        | 616 |
| 3-437. Register Call Summary for Register PRM_VC_SMPS_SA .....     | 617 |
| 3-438. PRM_VC_SMPS_VOL_RA .....                                    | 617 |
| 3-439. Register Call Summary for Register PRM_VC_SMPS_VOL_RA ..... | 617 |
| 3-440. PRM_VC_SMPS_CMD_RA .....                                    | 617 |
| 3-441. Register Call Summary for Register PRM_VC_SMPS_CMD_RA.....  | 618 |
| 3-442. PRM_VC_CMD_VAL_0 .....                                      | 618 |
| 3-443. Register Call Summary for Register PRM_VC_CMD_VAL_0.....    | 618 |
| 3-444. PRM_VC_CMD_VAL_1 .....                                      | 618 |
| 3-445. Register Call Summary for Register PRM_VC_CMD_VAL_1.....    | 619 |
| 3-446. PRM_VC_CH_CONF.....                                         | 619 |
| 3-447. Register Call Summary for Register PRM_VC_CH_CONF .....     | 619 |
| 3-448. PRM_VC_I2C_CFG .....                                        | 620 |
| 3-449. Register Call Summary for Register PRM_VC_I2C_CFG .....     | 620 |
| 3-450. PRM_VC_BYPASS_VAL .....                                     | 620 |
| 3-451. Register Call Summary for Register PRM_VC_BYPASS_VAL.....   | 621 |
| 3-452. PRM_RSTCTRL.....                                            | 621 |
| 3-453. Register Call Summary for Register PRM_RSTCTRL .....        | 622 |
| 3-454. PRM_RSTTIME .....                                           | 622 |
| 3-455. Register Call Summary for Register PRM_RSTTIME.....         | 622 |
| 3-456. PRM_RSTST .....                                             | 622 |
| 3-457. Register Call Summary for Register PRM_RSTST.....           | 624 |
| 3-458. PRM_VOLTCTRL .....                                          | 624 |
| 3-459. Register Call Summary for Register PRM_VOLTCTRL .....       | 625 |
| 3-460. PRM_SRAM_PCHARGE .....                                      | 625 |
| 3-461. Register Call Summary for Register PRM_SRAM_PCHARGE .....   | 625 |
| 3-462. PRM_CLKSRC_CTRL .....                                       | 626 |
| 3-463. Register Call Summary for Register PRM_CLKSRC_CTRL .....    | 627 |
| 3-464. PRM_OBS .....                                               | 627 |
| 3-465. Register Call Summary for Register PRM_OBS.....             | 627 |
| 3-466. PRM_VOLTSETUP1 .....                                        | 627 |
| 3-467. Register Call Summary for Register PRM_VOLTSETUP1 .....     | 628 |
| 3-468. PRM_VOLTOFFSET .....                                        | 628 |

|                                                                   |     |
|-------------------------------------------------------------------|-----|
| 3-469. Register Call Summary for Register PRM_VOLTOFFSET .....    | 628 |
| 3-470. PRM_CLKSETUP .....                                         | 628 |
| 3-471. Register Call Summary for Register PRM_CLKSETUP .....      | 629 |
| 3-472. PRM_POLCTRL .....                                          | 629 |
| 3-473. Register Call Summary for Register PRM_POLCTRL .....       | 629 |
| 3-474. PRM_VOLTSETUP2 .....                                       | 630 |
| 3-475. Register Call Summary for Register PRM_VOLTSETUP2 .....    | 630 |
| 3-476. PRM_VP1_CONFIG .....                                       | 630 |
| 3-477. Register Call Summary for Register PRM_VP1_CONFIG .....    | 631 |
| 3-478. PRM_VP1_VSTEPMIN .....                                     | 631 |
| 3-479. Register Call Summary for Register PRM_VP1_VSTEPMIN .....  | 631 |
| 3-480. PRM_VP1_VSTEPMAX .....                                     | 632 |
| 3-481. Register Call Summary for Register PRM_VP1_VSTEPMAX .....  | 632 |
| 3-482. PRM_VP1_VLIMITTO .....                                     | 632 |
| 3-483. Register Call Summary for Register PRM_VP1_VLIMITTO .....  | 632 |
| 3-484. PRM_VP1_VOLTAGE .....                                      | 633 |
| 3-485. Register Call Summary for Register PRM_VP1_VOLTAGE .....   | 633 |
| 3-486. PRM_VP1_STATUS .....                                       | 633 |
| 3-487. Register Call Summary for Register PRM_VP1_STATUS .....    | 633 |
| 3-488. PRM_VP2_CONFIG .....                                       | 634 |
| 3-489. Register Call Summary for Register PRM_VP2_CONFIG .....    | 634 |
| 3-490. PRM_VP2_VSTEPMIN .....                                     | 635 |
| 3-491. Register Call Summary for Register PRM_VP2_VSTEPMIN .....  | 635 |
| 3-492. PRM_VP2_VSTEPMAX .....                                     | 635 |
| 3-493. Register Call Summary for Register PRM_VP2_VSTEPMAX .....  | 635 |
| 3-494. PRM_VP2_VLIMITTO .....                                     | 636 |
| 3-495. Register Call Summary for Register PRM_VP2_VLIMITTO .....  | 636 |
| 3-496. PRM_VP2_VOLTAGE .....                                      | 636 |
| 3-497. Register Call Summary for Register PRM_VP2_VOLTAGE .....   | 636 |
| 3-498. PRM_VP2_STATUS .....                                       | 637 |
| 3-499. Register Call Summary for Register PRM_VP2_STATUS .....    | 637 |
| 3-500. PRM_LDO_ABB_SETUP .....                                    | 637 |
| 3-501. Register Call Summary for Register PRM_LDO_ABB_SETUP ..... | 638 |
| 3-502. PRM_LDO_ABB_CTRL .....                                     | 638 |
| 3-503. Register Call Summary for Register PRM_LDO_ABB_CTRL .....  | 639 |
| 3-504. NEON_PRM Register Summary .....                            | 639 |
| 3-505. RM_RSTST_NEON .....                                        | 639 |
| 3-506. Register Call Summary for Register RM_RSTST_NEON .....     | 640 |
| 3-507. PM_WKDEP_NEON .....                                        | 640 |
| 3-508. Register Call Summary for Register PM_WKDEP_NEON .....     | 641 |
| 3-509. PM_PWSTCTRL_NEON .....                                     | 641 |
| 3-510. Register Call Summary for Register PM_PWSTCTRL_NEON .....  | 641 |
| 3-511. PM_PWSTST_NEON .....                                       | 642 |
| 3-512. Register Call Summary for Register PM_PWSTST_NEON .....    | 642 |
| 3-513. PM_PREPWSTST_NEON .....                                    | 642 |
| 3-514. Register Call Summary for Register PM_PREPWSTST_NEON ..... | 643 |
| 3-515. USBHOST_PRM Register Summary .....                         | 643 |
| 3-516. RM_RSTST_USBHOST .....                                     | 643 |
| 3-517. Register Call Summary for Register RM_RSTST_USBHOST .....  | 644 |

---

|                                                                       |     |
|-----------------------------------------------------------------------|-----|
| 3-518. PM_WKEN_USBHOST .....                                          | 644 |
| 3-519. Register Call Summary for Register PM_WKEN_USBHOST .....       | 645 |
| 3-520. PM_MPUGRPSEL_USBHOST .....                                     | 645 |
| 3-521. Register Call Summary for Register PM_MPUGRPSEL_USBHOST .....  | 645 |
| 3-522. PM_IVA2GRPSEL_USBHOST .....                                    | 645 |
| 3-523. Register Call Summary for Register PM_IVA2GRPSEL_USBHOST ..... | 646 |
| 3-524. PM_WKST_USBHOST .....                                          | 646 |
| 3-525. Register Call Summary for Register PM_WKST_USBHOST .....       | 646 |
| 3-526. PM_WKDEP_USBHOST .....                                         | 647 |
| 3-527. Register Call Summary for Register PM_WKDEP_USBHOST .....      | 647 |
| 3-528. PM_PWSTCTRL_USBHOST .....                                      | 648 |
| 3-529. Register Call Summary for Register PM_PWSTCTRL_USBHOST .....   | 648 |
| 3-530. PM_PWSTST_USBHOST .....                                        | 649 |
| 3-531. Register Call Summary for Register PM_PWSTST_USBHOST .....     | 649 |
| 3-532. PM_PREPWSTST_USBHOST .....                                     | 649 |
| 3-533. Register Call Summary for Register PM_PREPWSTST_USBHOST .....  | 650 |
| 3-534. SR Instance Summary .....                                      | 650 |
| 3-535. SR Register Summary .....                                      | 650 |
| 3-536. SRCONFIG .....                                                 | 651 |
| 3-537. Register Call Summary for Register SRCONFIG .....              | 651 |
| 3-538. SRSTATUS .....                                                 | 652 |
| 3-539. Register Call Summary for Register SRSTATUS .....              | 652 |
| 3-540. SENVAL .....                                                   | 653 |
| 3-541. Register Call Summary for Register SENVAL .....                | 653 |
| 3-542. SENMIN .....                                                   | 653 |
| 3-543. Register Call Summary for Register SENMIN .....                | 653 |
| 3-544. SENMAX .....                                                   | 654 |
| 3-545. Register Call Summary for Register SENMAX .....                | 654 |
| 3-546. SENAVG .....                                                   | 654 |
| 3-547. Register Call Summary for Register SENAVG .....                | 654 |
| 3-548. AVGWEIGHT .....                                                | 655 |
| 3-549. Register Call Summary for Register AVGWEIGHT .....             | 655 |
| 3-550. NVALUERECIPROCAL .....                                         | 655 |
| 3-551. Register Call Summary for Register NVALUERECIPROCAL .....      | 656 |
| 3-552. IRQSTATUS_RAW .....                                            | 656 |
| 3-553. Register Call Summary for Register IRQSTATUS_RAW .....         | 656 |
| 3-554. IRQSTATUS .....                                                | 657 |
| 3-555. Register Call Summary for Register IRQSTATUS .....             | 657 |
| 3-556. IRQENABLE_SET .....                                            | 658 |
| 3-557. Register Call Summary for Register IRQENABLE_SET .....         | 659 |
| 3-558. IRQENABLE_CLR .....                                            | 659 |
| 3-559. Register Call Summary for Register IRQENABLE_CLR .....         | 660 |
| 3-560. SENERROR_REG .....                                             | 660 |
| 3-561. Register Call Summary for Register SENERROR_REG .....          | 660 |
| 3-562. ERRCONFIG .....                                                | 660 |
| 3-563. Register Call Summary for Register ERRCONFIG .....             | 661 |
| 4-1. MPU DLL Clock Signals .....                                      | 668 |
| 4-2. MPU Subsystem Reset Signals .....                                | 669 |
| 4-3. ARM Core Key Features .....                                      | 670 |

|       |                                                               |     |
|-------|---------------------------------------------------------------|-----|
| 4-4.  | MPU Subsystem Clock Signal .....                              | 671 |
| 4-5.  | ARM Reset Signals .....                                       | 671 |
| 4-6.  | Bridges Clock Signals .....                                   | 671 |
| 4-7.  | MPU Subsystem Reset Signal .....                              | 671 |
| 4-8.  | Bridge Clock Signals .....                                    | 672 |
| 4-9.  | MPU Subsystem Reset Signal .....                              | 672 |
| 4-10. | Overview of the MPU Subsystem Power Domain .....              | 674 |
| 4-11. | MPU Power States.....                                         | 674 |
| 4-12. | MPU DPLL Power Modes.....                                     | 674 |
| 4-13. | MPU Retention Modes .....                                     | 675 |
| 4-14. | MPU Subsystem Operation Power Modes .....                     | 675 |
| 4-15. | Power Mode Allowable Transitions.....                         | 677 |
| 5-1.  | IVA2.2 Internal Clock .....                                   | 686 |
| 5-2.  | IVA2.2 Subsystem EDMA Request Mappings .....                  | 690 |
| 5-3.  | IVA2.2 Interrupt Mappings .....                               | 692 |
| 5-4.  | IVA2.2 EDMA Hardware Parameters .....                         | 715 |
| 5-5.  | EDMA Memory Mapping for the Video Accelerator/Sequencer ..... | 715 |
| 5-6.  | Video Accelerator/Sequencer Memory Mapping.....               | 719 |
| 5-7.  | LSYS Input Interrupts.....                                    | 729 |
| 5-8.  | IVA2.2 DSP Megamodule Cache Controller Features .....         | 730 |
| 5-9.  | Boot Loader Configuration .....                               | 733 |
| 5-10. | PDCCMD Programmed Value in IDLE Boot Mode .....               | 734 |
| 5-11. | Header Format Used in Default Config Cache Mode .....         | 734 |
| 5-12. | Header Format Used in User Defined Bootstrap Mode.....        | 735 |
| 5-13. | Cache Size Specified by L1PMODE .....                         | 738 |
| 5-14. | Cache Size Specified by L1DMODE .....                         | 739 |
| 5-15. | Cache Size Specified by L2MODE .....                          | 739 |
| 5-16. | Switching Cache Modes .....                                   | 739 |
| 5-17. | Default Cache Configuration .....                             | 740 |
| 5-18. | Cache Mode Configuration .....                                | 740 |
| 5-19. | iVLCD List of Register Values for Standard Algorithms .....   | 769 |
| 5-20. | IVA2.2 Megamodule Memory Protection Page Registers .....      | 781 |
| 5-21. | Request-Type Access Controls .....                            | 783 |
| 5-22. | Instance Summary .....                                        | 796 |
| 5-23. | IC Register Summary.....                                      | 797 |
| 5-24. | EVTFLAGi.....                                                 | 797 |
| 5-25. | Register Call Summary for Register EVTFLAGi .....             | 797 |
| 5-26. | EVTSETi .....                                                 | 798 |
| 5-27. | Register Call Summary for Register EVTSETi.....               | 798 |
| 5-28. | EVTCLRI .....                                                 | 798 |
| 5-29. | Register Call Summary for Register EVTCLRI.....               | 798 |
| 5-30. | EVTMASKi .....                                                | 799 |
| 5-31. | Register Call Summary for Register EVTMASKi .....             | 799 |
| 5-32. | MEVTFLAGi .....                                               | 799 |
| 5-33. | Register Call Summary for Register MEVTFLAGi.....             | 799 |
| 5-34. | EXPMASKi.....                                                 | 800 |
| 5-35. | Register Call Summary for Register EXPMASKi .....             | 800 |
| 5-36. | MEXPFLAGi .....                                               | 800 |
| 5-37. | Register Call Summary for Register MEXPFLAGi.....             | 800 |

---

|       |                                                      |     |
|-------|------------------------------------------------------|-----|
| 5-38. | INTMUXj.....                                         | 800 |
| 5-39. | Register Call Summary for Register INTMUXj .....     | 801 |
| 5-40. | INTXSTAT .....                                       | 801 |
| 5-41. | Register Call Summary for Register INTXSTAT .....    | 802 |
| 5-42. | INTXCLR .....                                        | 802 |
| 5-43. | Register Call Summary for Register INTXCLR .....     | 802 |
| 5-44. | INTDMASK.....                                        | 802 |
| 5-45. | Register Call Summary for Register INTDMASK .....    | 803 |
| 5-46. | EVTASRT .....                                        | 803 |
| 5-47. | Register Call Summary for Register EVTASRT.....      | 804 |
| 5-48. | SYS Register Summary .....                           | 805 |
| 5-49. | PDCCMD.....                                          | 805 |
| 5-50. | Register Call Summary for Register PDCCMD .....      | 806 |
| 5-51. | REVID .....                                          | 807 |
| 5-52. | Register Call Summary for Register REVID.....        | 807 |
| 5-53. | IDMA Register Summary.....                           | 808 |
| 5-54. | IDMA0_STAT .....                                     | 808 |
| 5-55. | Register Call Summary for Register IDMA0_STAT .....  | 809 |
| 5-56. | IDMA0_MASK .....                                     | 809 |
| 5-57. | Register Call Summary for Register IDMA0_MASK.....   | 811 |
| 5-58. | IDMA0_SOURCE .....                                   | 811 |
| 5-59. | Register Call Summary for Register IDMA0_SOURCE..... | 811 |
| 5-60. | IDMA0_DEST.....                                      | 811 |
| 5-61. | Register Call Summary for Register IDMA0_DEST .....  | 811 |
| 5-62. | IDMA0_COUNT .....                                    | 812 |
| 5-63. | Register Call Summary for Register IDMA0_COUNT.....  | 812 |
| 5-64. | IDMA1_STAT .....                                     | 812 |
| 5-65. | Register Call Summary for Register IDMA1_STAT .....  | 812 |
| 5-66. | IDMA1_SOURCE .....                                   | 813 |
| 5-67. | Register Call Summary for Register IDMA1_SOURCE..... | 813 |
| 5-68. | IDMA1_DEST.....                                      | 813 |
| 5-69. | Register Call Summary for Register IDMA1_DEST .....  | 813 |
| 5-70. | IDMA1_COUNT .....                                    | 814 |
| 5-71. | Register Call Summary for Register IDMA1_COUNT.....  | 814 |
| 5-72. | CPUARBE .....                                        | 814 |
| 5-73. | Register Call Summary for Register CPUARBE .....     | 815 |
| 5-74. | IDMAARBE .....                                       | 815 |
| 5-75. | Register Call Summary for Register IDMAARBE .....    | 816 |
| 5-76. | SDMAARBE .....                                       | 816 |
| 5-77. | Register Call Summary for Register SDMAARBE .....    | 816 |
| 5-78. | MDMAARBE .....                                       | 816 |
| 5-79. | Register Call Summary for Register MDMAARBE .....    | 817 |
| 5-80. | ICFGMPFAR.....                                       | 817 |
| 5-81. | Register Call Summary for Register ICFGMPFAR .....   | 817 |
| 5-82. | ICFGMPFSR.....                                       | 817 |
| 5-83. | Register Call Summary for Register ICFGMPFSR .....   | 818 |
| 5-84. | ICFGMPFCR .....                                      | 818 |
| 5-85. | Register Call Summary for Register ICFGMPFCR .....   | 818 |
| 5-86. | IBUSERR .....                                        | 818 |

|                                                          |     |
|----------------------------------------------------------|-----|
| 5-87. Register Call Summary for Register IBUSERR .....   | 819 |
| 5-88. IBUSERRCLR .....                                   | 819 |
| 5-89. Register Call Summary for Register IBUSERRCLR..... | 820 |
| 5-90. XMC Register Summary .....                         | 820 |
| 5-91. L2CFG .....                                        | 821 |
| 5-92. Register Call Summary for Register L2CFG .....     | 822 |
| 5-93. L1PCFG .....                                       | 822 |
| 5-94. Register Call Summary for Register L1PCFG .....    | 822 |
| 5-95. L1PCC .....                                        | 823 |
| 5-96. Register Call Summary for Register L1PCC .....     | 823 |
| 5-97. L1DCFG .....                                       | 823 |
| 5-98. Register Call Summary for Register L1DCFG .....    | 824 |
| 5-99. L1DCC.....                                         | 824 |
| 5-100. Register Call Summary for Register L1DCC .....    | 824 |
| 5-101. CPUARBU .....                                     | 824 |
| 5-102. Register Call Summary for Register CPUARBU.....   | 825 |
| 5-103. IDMAARBU .....                                    | 825 |
| 5-104. Register Call Summary for Register IDMAARBU.....  | 825 |
| 5-105. SDMAARBU .....                                    | 826 |
| 5-106. Register Call Summary for Register SDMAARBU ..... | 826 |
| 5-107. UCARBU .....                                      | 826 |
| 5-108. Register Call Summary for Register UCARBU.....    | 827 |
| 5-109. CPUARBD .....                                     | 827 |
| 5-110. Register Call Summary for Register CPUARBD.....   | 827 |
| 5-111. IDMAARBD .....                                    | 828 |
| 5-112. Register Call Summary for Register IDMAARBD.....  | 828 |
| 5-113. SDMAARBD .....                                    | 828 |
| 5-114. Register Call Summary for Register SDMAARBD.....  | 829 |
| 5-115. UCARBD .....                                      | 829 |
| 5-116. Register Call Summary for Register UCARBD.....    | 829 |
| 5-117. L2WBAR .....                                      | 829 |
| 5-118. Register Call Summary for Register L2WBAR .....   | 830 |
| 5-119. L2WWC .....                                       | 830 |
| 5-120. Register Call Summary for Register L2WWC .....    | 830 |
| 5-121. L2WIBAR.....                                      | 830 |
| 5-122. Register Call Summary for Register L2WIBAR .....  | 830 |
| 5-123. L2WIWC.....                                       | 831 |
| 5-124. Register Call Summary for Register L2WIWC .....   | 831 |
| 5-125. L2IBAR .....                                      | 831 |
| 5-126. Register Call Summary for Register L2IBAR.....    | 831 |
| 5-127. L2IWC .....                                       | 831 |
| 5-128. Register Call Summary for Register L2IWC.....     | 832 |
| 5-129. L1PIBAR .....                                     | 832 |
| 5-130. Register Call Summary for Register L1PIBAR .....  | 832 |
| 5-131. L1PIWC .....                                      | 832 |
| 5-132. Register Call Summary for Register L1PIWC .....   | 832 |
| 5-133. L1DWIBAR.....                                     | 833 |
| 5-134. Register Call Summary for Register L1DWIBAR ..... | 833 |
| 5-135. L1DWIWC.....                                      | 833 |

---

|                                                                     |     |
|---------------------------------------------------------------------|-----|
| 5-136. Register Call Summary for Register L1DWIWC .....             | 833 |
| 5-137. L1DWBAR .....                                                | 833 |
| 5-138. Register Call Summary for Register L1DWBAR .....             | 834 |
| 5-139. L1DWWC .....                                                 | 834 |
| 5-140. Register Call Summary for Register L1DWWC .....              | 834 |
| 5-141. L1DIBAR .....                                                | 834 |
| 5-142. Register Call Summary for Register L1DIBAR .....             | 834 |
| 5-143. L1DIWC .....                                                 | 835 |
| 5-144. Register Call Summary for Register L1DIWC .....              | 835 |
| 5-145. L2WB .....                                                   | 835 |
| 5-146. Register Call Summary for Register L2WB .....                | 835 |
| 5-147. L2WBINV .....                                                | 836 |
| 5-148. Register Call Summary for Register L2WBINV .....             | 836 |
| 5-149. L2INV .....                                                  | 836 |
| 5-150. Register Call Summary for Register L2INV .....               | 836 |
| 5-151. L1PINV .....                                                 | 837 |
| 5-152. Register Call Summary for Register L1PINV .....              | 837 |
| 5-153. L1DWB .....                                                  | 837 |
| 5-154. Register Call Summary for Register L1DWB .....               | 837 |
| 5-155. L1DWBINV .....                                               | 838 |
| 5-156. Register Call Summary for Register L1DWBINV .....            | 838 |
| 5-157. L1DINV .....                                                 | 838 |
| 5-158. Register Call Summary for Register L1DINV .....              | 838 |
| 5-159. MARi .....                                                   | 839 |
| 5-160. Register Call Summary for Register MARi .....                | 839 |
| 5-161. L2MPFAR .....                                                | 839 |
| 5-162. Register Call Summary for Register L2MPFAR .....             | 839 |
| 5-163. L2MPFSR .....                                                | 840 |
| 5-164. Register Call Summary for Register L2MPFSR .....             | 840 |
| 5-165. L2MPFCR .....                                                | 840 |
| 5-166. Register Call Summary for Register L2MPFCR .....             | 840 |
| 5-167. L2MPPA <sub>j</sub> .....                                    | 841 |
| 5-168. Register Call Summary for Register L2MPPA <sub>j</sub> ..... | 841 |
| 5-169. L1PMPFAR .....                                               | 842 |
| 5-170. Register Call Summary for Register L1PMPFAR .....            | 842 |
| 5-171. L1PMPFSR .....                                               | 842 |
| 5-172. Register Call Summary for Register L1PMPFSR .....            | 843 |
| 5-173. L1PMPFCR .....                                               | 843 |
| 5-174. Register Call Summary for Register L1PMPFCR .....            | 843 |
| 5-175. L1PMPPAk .....                                               | 843 |
| 5-176. Register Call Summary for Register L1PMPPAk .....            | 844 |
| 5-177. L1DMPFAR .....                                               | 844 |
| 5-178. Register Call Summary for Register L1DMPFAR .....            | 844 |
| 5-179. L1DMPFSR .....                                               | 845 |
| 5-180. Register Call Summary for Register L1DMPFSR .....            | 845 |
| 5-181. L1DMPFCR .....                                               | 845 |
| 5-182. Register Call Summary for Register L1DMPFCR .....            | 846 |
| 5-183. L1DMPPAk .....                                               | 846 |
| 5-184. Register Call Summary for Register L1DMPPAk .....            | 846 |

|                                                               |     |
|---------------------------------------------------------------|-----|
| 5-185. TPCC Register Summary .....                            | 847 |
| 5-186. TPCC_PID .....                                         | 849 |
| 5-187. Register Call Summary for Register TPCC_PID.....       | 850 |
| 5-188. TPCC_CCCFG .....                                       | 850 |
| 5-189. Register Call Summary for Register TPCC_CCCFG.....     | 851 |
| 5-190. TPCC_DCHMAPi .....                                     | 851 |
| 5-191. Register Call Summary for Register TPCC_DCHMAPi.....   | 851 |
| 5-192. TPCC_QCHMAPj .....                                     | 852 |
| 5-193. Register Call Summary for Register TPCC_QCHMAPj.....   | 852 |
| 5-194. TPCC_DMAQNUM0.....                                     | 852 |
| 5-195. Register Call Summary for Register TPCC_DMAQNUM0 ..... | 853 |
| 5-196. TPCC_DMAQNUM1 .....                                    | 854 |
| 5-197. Register Call Summary for Register TPCC_DMAQNUM1 ..... | 855 |
| 5-198. TPCC_DMAQNUM2 .....                                    | 855 |
| 5-199. Register Call Summary for Register TPCC_DMAQNUM2 ..... | 856 |
| 5-200. TPCC_DMAQNUM3.....                                     | 856 |
| 5-201. Register Call Summary for Register TPCC_DMAQNUM3 ..... | 857 |
| 5-202. TPCC_DMAQNUM4 .....                                    | 858 |
| 5-203. Register Call Summary for Register TPCC_DMAQNUM4 ..... | 859 |
| 5-204. TPCC_DMAQNUM5 .....                                    | 859 |
| 5-205. Register Call Summary for Register TPCC_DMAQNUM5 ..... | 860 |
| 5-206. TPCC_DMAQNUM6.....                                     | 860 |
| 5-207. Register Call Summary for Register TPCC_DMAQNUM6 ..... | 861 |
| 5-208. TPCC_DMAQNUM7 .....                                    | 862 |
| 5-209. Register Call Summary for Register TPCC_DMAQNUM7 ..... | 863 |
| 5-210. TPCC_QDMAQNUM .....                                    | 863 |
| 5-211. Register Call Summary for Register TPCC_QDMAQNUM.....  | 864 |
| 5-212. TPCC_QUETCMAP .....                                    | 864 |
| 5-213. Register Call Summary for Register TPCC_QUETCMAP ..... | 865 |
| 5-214. TPCC_QUEPRI .....                                      | 865 |
| 5-215. Register Call Summary for Register TPCC_QUEPRI.....    | 866 |
| 5-216. TPCC_EMR.....                                          | 866 |
| 5-217. Register Call Summary for Register TPCC_EMR .....      | 867 |
| 5-218. TPCC_EMRH.....                                         | 867 |
| 5-219. Register Call Summary for Register TPCC_EMRH .....     | 868 |
| 5-220. TPCC_EMCR.....                                         | 868 |
| 5-221. Register Call Summary for Register TPCC_EMCR .....     | 869 |
| 5-222. TPCC_EMCRH.....                                        | 869 |
| 5-223. Register Call Summary for Register TPCC_EMCRH .....    | 870 |
| 5-224. TPCC_QEMR.....                                         | 870 |
| 5-225. Register Call Summary for Register TPCC_QEMR .....     | 870 |
| 5-226. TPCC_QEMCR.....                                        | 871 |
| 5-227. Register Call Summary for Register TPCC_QEMCR .....    | 871 |
| 5-228. TPCC_CCERR .....                                       | 871 |
| 5-229. Register Call Summary for Register TPCC_CCERR.....     | 872 |
| 5-230. TPCC_CCERRCLR.....                                     | 872 |
| 5-231. Register Call Summary for Register TPCC_CCERRCLR ..... | 872 |
| 5-232. TPCC_EEVAL .....                                       | 873 |
| 5-233. Register Call Summary for Register TPCC_EEVAL .....    | 873 |

---

|                                                              |     |
|--------------------------------------------------------------|-----|
| 5-234. TPCC_DRAEj.....                                       | 873 |
| 5-235. Register Call Summary for Register TPCC_DRAEj .....   | 874 |
| 5-236. TPCC_DRAEHj.....                                      | 874 |
| 5-237. Register Call Summary for Register TPCC_DRAEHj .....  | 875 |
| 5-238. TPCC_QRAEj .....                                      | 875 |
| 5-239. Register Call Summary for Register TPCC_QRAEj .....   | 876 |
| 5-240. TPCC_Q0Ek .....                                       | 876 |
| 5-241. Register Call Summary for Register TPCC_Q0Ek .....    | 876 |
| 5-242. TPCC_Q1Ek .....                                       | 877 |
| 5-243. Register Call Summary for Register TPCC_Q1Ek .....    | 877 |
| 5-244. TPCC_QSTATI .....                                     | 877 |
| 5-245. Register Call Summary for Register TPCC_QSTATI.....   | 878 |
| 5-246. TPCC_QWMTHRA .....                                    | 878 |
| 5-247. Register Call Summary for Register TPCC_QWMTHRA.....  | 878 |
| 5-248. TPCC_QWMTHRb .....                                    | 879 |
| 5-249. Register Call Summary for Register TPCC_QWMTHRb ..... | 879 |
| 5-250. TPCC_CCSTAT .....                                     | 879 |
| 5-251. Register Call Summary for Register TPCC_CCSTAT .....  | 880 |
| 5-252. TPCC_MP FAR .....                                     | 880 |
| 5-253. Register Call Summary for Register TPCC_MP FAR .....  | 881 |
| 5-254. TPCC_MPFSR .....                                      | 881 |
| 5-255. Register Call Summary for Register TPCC_MPFSR .....   | 882 |
| 5-256. TPCC_MPFCR .....                                      | 882 |
| 5-257. Register Call Summary for Register TPCC_MPFCR.....    | 882 |
| 5-258. TPCC_MPPAG .....                                      | 882 |
| 5-259. Register Call Summary for Register TPCC_MPPAG .....   | 883 |
| 5-260. TPCC_MPPAj .....                                      | 884 |
| 5-261. Register Call Summary for Register TPCC_MPPAj .....   | 885 |
| 5-262. TPCC_ER .....                                         | 885 |
| 5-263. Register Call Summary for Register TPCC_ER .....      | 886 |
| 5-264. TPCC_ECR .....                                        | 886 |
| 5-265. Register Call Summary for Register TPCC_ECR .....     | 887 |
| 5-266. TPCC_ECRH .....                                       | 887 |
| 5-267. Register Call Summary for Register TPCC_ECRH .....    | 888 |
| 5-268. TPCC_ESR .....                                        | 888 |
| 5-269. Register Call Summary for Register TPCC_ESR.....      | 889 |
| 5-270. TPCC_ESRH .....                                       | 889 |
| 5-271. Register Call Summary for Register TPCC_ESRH.....     | 890 |
| 5-272. TPCC_CER .....                                        | 890 |
| 5-273. Register Call Summary for Register TPCC_CER .....     | 891 |
| 5-274. TPCC_CERH .....                                       | 891 |
| 5-275. Register Call Summary for Register TPCC_CERH .....    | 892 |
| 5-276. TPCC_EER .....                                        | 892 |
| 5-277. Register Call Summary for Register TPCC_EER.....      | 893 |
| 5-278. TPCC_EECR .....                                       | 893 |
| 5-279. Register Call Summary for Register TPCC_EECR.....     | 894 |
| 5-280. TPCC_EESR .....                                       | 894 |
| 5-281. Register Call Summary for Register TPCC_EESR.....     | 895 |
| 5-282. TPCC_SER .....                                        | 895 |

|                                                              |     |
|--------------------------------------------------------------|-----|
| 5-283. Register Call Summary for Register TPCC_SER.....      | 896 |
| 5-284. TPCC_SERH .....                                       | 896 |
| 5-285. Register Call Summary for Register TPCC_SERH.....     | 897 |
| 5-286. TPCC_SECR .....                                       | 897 |
| 5-287. Register Call Summary for Register TPCC_SECR.....     | 898 |
| 5-288. TPCC_SECRH .....                                      | 898 |
| 5-289. Register Call Summary for Register TPCC_SECRH.....    | 899 |
| 5-290. TPCC_IER .....                                        | 899 |
| 5-291. Register Call Summary for Register TPCC_IER.....      | 900 |
| 5-292. TPCC_IERH .....                                       | 900 |
| 5-293. Register Call Summary for Register TPCC_IERH.....     | 901 |
| 5-294. TPCC_IECR .....                                       | 901 |
| 5-295. Register Call Summary for Register TPCC_IECR .....    | 902 |
| 5-296. TPCC_IECRH .....                                      | 902 |
| 5-297. Register Call Summary for Register TPCC_IECRH.....    | 903 |
| 5-298. TPCCIESR .....                                        | 903 |
| 5-299. Register Call Summary for Register TPCCIESR .....     | 904 |
| 5-300. TPCCIESRH .....                                       | 904 |
| 5-301. Register Call Summary for Register TPCCIESRH .....    | 905 |
| 5-302. TPCC_IPR .....                                        | 905 |
| 5-303. Register Call Summary for Register TPCC_IPR.....      | 906 |
| 5-304. TPCC_IPRH .....                                       | 906 |
| 5-305. Register Call Summary for Register TPCC_IPRH.....     | 907 |
| 5-306. TPCC_ICR .....                                        | 907 |
| 5-307. Register Call Summary for Register TPCC_ICR .....     | 908 |
| 5-308. TPCC_ICRH .....                                       | 908 |
| 5-309. Register Call Summary for Register TPCC_ICRH.....     | 909 |
| 5-310. TPCCIEVAL .....                                       | 909 |
| 5-311. Register Call Summary for Register TPCCIEVAL .....    | 910 |
| 5-312. TPCC_QER.....                                         | 910 |
| 5-313. Register Call Summary for Register TPCC_QER .....     | 910 |
| 5-314. TPCCQEER .....                                        | 911 |
| 5-315. Register Call Summary for Register TPCCQEER .....     | 911 |
| 5-316. TPCCQEECR .....                                       | 911 |
| 5-317. Register Call Summary for Register TPCCQEECR.....     | 912 |
| 5-318. TPCCQEESR .....                                       | 912 |
| 5-319. Register Call Summary for Register TPCCQEESR .....    | 912 |
| 5-320. TPCC_QSER .....                                       | 912 |
| 5-321. Register Call Summary for Register TPCC_QSER .....    | 913 |
| 5-322. TPCCQSECR .....                                       | 913 |
| 5-323. Register Call Summary for Register TPCCQSECR.....     | 913 |
| 5-324. TPCC_ER_Rn .....                                      | 914 |
| 5-325. Register Call Summary for Register TPCC_ER_Rn .....   | 914 |
| 5-326. TPCC_ECR_Rn .....                                     | 915 |
| 5-327. Register Call Summary for Register TPCC_ECR_Rn .....  | 915 |
| 5-328. TPCC_ECRH_Rn .....                                    | 916 |
| 5-329. Register Call Summary for Register TPCC_ECRH_Rn ..... | 916 |
| 5-330. TPCC_ESR_Rn .....                                     | 917 |
| 5-331. Register Call Summary for Register TPCC_ESR_Rn.....   | 917 |

|                                                              |     |
|--------------------------------------------------------------|-----|
| 5-332. TPCC_ESRH_Rn .....                                    | 918 |
| 5-333. Register Call Summary for Register TPCC_ESRH_Rn.....  | 918 |
| 5-334. TPCC_CER_Rn .....                                     | 919 |
| 5-335. Register Call Summary for Register TPCC_CER_Rn .....  | 920 |
| 5-336. TPCC_CERH_Rn .....                                    | 920 |
| 5-337. Register Call Summary for Register TPCC_CERH_Rn.....  | 921 |
| 5-338. TPCC_EER_Rn .....                                     | 921 |
| 5-339. Register Call Summary for Register TPCC_EER_Rn.....   | 922 |
| 5-340. TPCC_EECR_Rn .....                                    | 922 |
| 5-341. Register Call Summary for Register TPCC_EECR_Rn.....  | 922 |
| 5-342. TPCC_EESR_Rn .....                                    | 923 |
| 5-343. Register Call Summary for Register TPCC_EESR_Rn.....  | 923 |
| 5-344. TPCC_SER_Rn .....                                     | 924 |
| 5-345. Register Call Summary for Register TPCC_SER_Rn.....   | 924 |
| 5-346. TPCC_SERH_Rn .....                                    | 925 |
| 5-347. Register Call Summary for Register TPCC_SERH_Rn.....  | 925 |
| 5-348. TPCC_SECR_Rn .....                                    | 926 |
| 5-349. Register Call Summary for Register TPCC_SECR_Rn.....  | 926 |
| 5-350. TPCC_SECRH_Rn .....                                   | 927 |
| 5-351. Register Call Summary for Register TPCC_SECRH_Rn..... | 927 |
| 5-352. TPCC_IER_Rn .....                                     | 928 |
| 5-353. Register Call Summary for Register TPCC_IER_Rn.....   | 928 |
| 5-354. TPCC_IERH_Rn .....                                    | 929 |
| 5-355. Register Call Summary for Register TPCC_IERH_Rn.....  | 929 |
| 5-356. TPCC_IECR_Rn .....                                    | 930 |
| 5-357. Register Call Summary for Register TPCC_IECR_Rn.....  | 930 |
| 5-358. TPCC_IECRH_Rn .....                                   | 931 |
| 5-359. Register Call Summary for Register TPCC_IECRH_Rn..... | 931 |
| 5-360. TPCCIESR_Rn .....                                     | 932 |
| 5-361. Register Call Summary for Register TPCCIESR_Rn.....   | 932 |
| 5-362. TPCCIESRH_Rn .....                                    | 933 |
| 5-363. Register Call Summary for Register TPCCIESRH_Rn.....  | 933 |
| 5-364. TPCC_IPR_Rn .....                                     | 934 |
| 5-365. Register Call Summary for Register TPCC_IPR_Rn.....   | 934 |
| 5-366. TPCC_IPRH_Rn .....                                    | 935 |
| 5-367. Register Call Summary for Register TPCC_IPRH_Rn.....  | 935 |
| 5-368. TPCC_ICR_Rn .....                                     | 936 |
| 5-369. Register Call Summary for Register TPCC_ICR_Rn.....   | 936 |
| 5-370. TPCC_ICRH_Rn .....                                    | 937 |
| 5-371. Register Call Summary for Register TPCC_ICRH_Rn.....  | 937 |
| 5-372. TPCCIEVAL_Rn .....                                    | 938 |
| 5-373. Register Call Summary for Register TPCCIEVAL_Rn.....  | 938 |
| 5-374. TPCC_QER_Rn.....                                      | 938 |
| 5-375. Register Call Summary for Register TPCC_QER_Rn .....  | 939 |
| 5-376. TPCCQEER_Rn .....                                     | 939 |
| 5-377. Register Call Summary for Register TPCCQEER_Rn.....   | 939 |
| 5-378. TPCCQEECR_Rn .....                                    | 939 |
| 5-379. Register Call Summary for Register TPCCQEECR_Rn.....  | 940 |
| 5-380. TPCCQEECSR_Rn .....                                   | 940 |

|                                                               |     |
|---------------------------------------------------------------|-----|
| 5-381. Register Call Summary for Register TPCC_QEESR_Rn ..... | 940 |
| 5-382. TPCC_QSER_Rn .....                                     | 941 |
| 5-383. Register Call Summary for Register TPCC_QSER_Rn.....   | 941 |
| 5-384. TPCC_QSECR_Rn .....                                    | 941 |
| 5-385. Register Call Summary for Register TPCC_QSECR_Rn.....  | 942 |
| 5-386. TPCC_OPTm.....                                         | 942 |
| 5-387. Register Call Summary for Register TPCC_OPTm .....     | 943 |
| 5-388. TPCC_SRCm.....                                         | 943 |
| 5-389. Register Call Summary for Register TPCC_SRCm .....     | 943 |
| 5-390. TPCC_ABCNTm .....                                      | 944 |
| 5-391. Register Call Summary for Register TPCC_ABCNTm.....    | 944 |
| 5-392. TPCC_DSTm .....                                        | 944 |
| 5-393. Register Call Summary for Register TPCC_DSTm .....     | 944 |
| 5-394. TPCC_BIDXm .....                                       | 945 |
| 5-395. Register Call Summary for Register TPCC_BIDXm.....     | 945 |
| 5-396. TPCC_LNKm .....                                        | 945 |
| 5-397. Register Call Summary for Register TPCC_LNKm.....      | 946 |
| 5-398. TPCC_CIDXm .....                                       | 946 |
| 5-399. Register Call Summary for Register TPCC_CIDXm .....    | 947 |
| 5-400. TPCC_CCNTm.....                                        | 947 |
| 5-401. Register Call Summary for Register TPCC_CCNTm .....    | 947 |
| 5-402. TPTC0 and TPTC1 Register Summary .....                 | 947 |
| 5-403. TPTCj_PID .....                                        | 949 |
| 5-404. Register Call Summary for Register TPTCj_PID .....     | 949 |
| 5-405. TPTCj_TCCFG .....                                      | 949 |
| 5-406. Register Call Summary for Register TPTCj_TCCFG.....    | 950 |
| 5-407. TPTCj_TCSTAT .....                                     | 950 |
| 5-408. Register Call Summary for Register TPTCj_TCSTAT .....  | 951 |
| 5-409. TPTCj_INTSTAT .....                                    | 951 |
| 5-410. Register Call Summary for Register TPTCj_INTSTAT.....  | 952 |
| 5-411. TPTCj_INTEN .....                                      | 952 |
| 5-412. Register Call Summary for Register TPTCj_INTEN.....    | 952 |
| 5-413. TPTCj_INTCLR.....                                      | 952 |
| 5-414. Register Call Summary for Register TPTCj_INTCLR .....  | 953 |
| 5-415. TPTCj_INTCMD .....                                     | 953 |
| 5-416. Register Call Summary for Register TPTCj_INTCMD .....  | 953 |
| 5-417. TPTCj_ERRSTAT.....                                     | 954 |
| 5-418. Register Call Summary for Register TPTCj_ERRSTAT ..... | 954 |
| 5-419. TPTCj_ERREN .....                                      | 954 |
| 5-420. Register Call Summary for Register TPTCj_ERREN .....   | 955 |
| 5-421. TPTCj_ERRCLR .....                                     | 955 |
| 5-422. Register Call Summary for Register TPTCj_ERRCLR.....   | 956 |
| 5-423. TPTCj_ERRDET .....                                     | 956 |
| 5-424. Register Call Summary for Register TPTCj_ERRDET .....  | 957 |
| 5-425. TPTCj_ERRCMD .....                                     | 957 |
| 5-426. Register Call Summary for Register TPTCj_ERRCMD .....  | 957 |
| 5-427. TPTCj_RDRATE .....                                     | 957 |
| 5-428. Register Call Summary for Register TPTCj_RDRATE .....  | 958 |
| 5-429. TPTCj_POPT .....                                       | 958 |

|                                                                 |     |
|-----------------------------------------------------------------|-----|
| 5-430. Register Call Summary for Register TPTCj_POPT .....      | 959 |
| 5-431. TPTCj_PSRC .....                                         | 959 |
| 5-432. Register Call Summary for Register TPTCj_PSRC .....      | 959 |
| 5-433. TPTCj_PCNT .....                                         | 960 |
| 5-434. Register Call Summary for Register TPTCj_PCNT .....      | 960 |
| 5-435. TPTCj_PDST .....                                         | 960 |
| 5-436. Register Call Summary for Register TPTCj_PDST.....       | 960 |
| 5-437. TPTCj_PBIDX .....                                        | 961 |
| 5-438. Register Call Summary for Register TPTCj_PBIDX.....      | 961 |
| 5-439. TPTCj_PMPXY .....                                        | 961 |
| 5-440. Register Call Summary for Register TPTCj_PMPXY.....      | 962 |
| 5-441. TPTCj_SAOPT .....                                        | 962 |
| 5-442. Register Call Summary for Register TPTCj_SAOPT.....      | 963 |
| 5-443. TPTCj_SASRC .....                                        | 963 |
| 5-444. Register Call Summary for Register TPTCj_SASRC.....      | 963 |
| 5-445. TPTCj_SACNT .....                                        | 964 |
| 5-446. Register Call Summary for Register TPTCj_SACNT .....     | 964 |
| 5-447. TPTCj_SADST .....                                        | 964 |
| 5-448. Register Call Summary for Register TPTCj_SADST .....     | 964 |
| 5-449. TPTCj_SABIDX .....                                       | 965 |
| 5-450. Register Call Summary for Register TPTCj_SABIDX .....    | 965 |
| 5-451. TPTCj_SAMPPXY .....                                      | 965 |
| 5-452. Register Call Summary for Register TPTCj_SAMPPXY .....   | 966 |
| 5-453. TPTCj_SACNTRLD .....                                     | 966 |
| 5-454. Register Call Summary for Register TPTCj_SACNTRLD .....  | 966 |
| 5-455. TPTCj_SASRCBREF .....                                    | 967 |
| 5-456. Register Call Summary for Register TPTCj_SASRCBREF ..... | 967 |
| 5-457. TPTCj_SADSTBREF .....                                    | 967 |
| 5-458. Register Call Summary for Register TPTCj_SADSTBREF.....  | 967 |
| 5-459. TPTCj_DFCNTRLD .....                                     | 968 |
| 5-460. Register Call Summary for Register TPTCj_DFCNTRLD .....  | 968 |
| 5-461. TPTCj_DFSRCBREF .....                                    | 968 |
| 5-462. Register Call Summary for Register TPTCj_DFSRCBREF ..... | 968 |
| 5-463. TPTCj_DFDSTBREF .....                                    | 969 |
| 5-464. Register Call Summary for Register TPTCj_DFDSTBREF.....  | 969 |
| 5-465. TPTCj_DFOPTi.....                                        | 969 |
| 5-466. Register Call Summary for Register TPTCj_DFOPTi .....    | 970 |
| 5-467. TPTCj_DFSRCi .....                                       | 970 |
| 5-468. Register Call Summary for Register TPTCj_DFSRCi .....    | 970 |
| 5-469. TPTCj_DFCNTi.....                                        | 971 |
| 5-470. Register Call Summary for Register TPTCj_DFCNTi .....    | 971 |
| 5-471. TPTCj_DFDSTi.....                                        | 971 |
| 5-472. Register Call Summary for Register TPTCj_DFDSTi .....    | 971 |
| 5-473. TPTCj_DFBIDX .....                                       | 972 |
| 5-474. Register Call Summary for Register TPTCj_DFBIDX .....    | 972 |
| 5-475. TPTCj_DFMPPXY .....                                      | 972 |
| 5-476. Register Call Summary for Register TPTCj_DFMPPXY .....   | 973 |
| 5-477. SYSC Register Summary .....                              | 973 |
| 5-478. SYSC_REVISION.....                                       | 974 |

|                                                                  |     |
|------------------------------------------------------------------|-----|
| 5-479. Register Call Summary for Register SYSC_REVISION .....    | 974 |
| 5-480. SYSC_SYSCONFIG.....                                       | 974 |
| 5-481. Register Call Summary for Register SYSC_SYSCONFIG .....   | 974 |
| 5-482. SYSC_LICFG0 .....                                         | 975 |
| 5-483. Register Call Summary for Register SYSC_LICFG0.....       | 975 |
| 5-484. SYSC_LICFG1 .....                                         | 976 |
| 5-485. Register Call Summary for Register SYSC_LICFG1.....       | 976 |
| 5-486. SYSC_BOOTADDR .....                                       | 976 |
| 5-487. Register Call Summary for Register SYSC_BOOTADDR.....     | 977 |
| 5-488. SYSC_BOOTMOD.....                                         | 977 |
| 5-489. Register Call Summary for Register SYSC_BOOTMOD .....     | 977 |
| 5-490. WUGEN Register Summary .....                              | 978 |
| 5-491. WUGEN_REVISION.....                                       | 979 |
| 5-492. Register Call Summary for Register WUGEN_REVISION .....   | 979 |
| 5-493. WUGEN_SYSCONFIG .....                                     | 979 |
| 5-494. Register Call Summary for Register WUGEN_SYSCONFIG .....  | 979 |
| 5-495. WUGEN_MEVT0.....                                          | 980 |
| 5-496. Register Call Summary for Register WUGEN_MEVT0 .....      | 981 |
| 5-497. WUGEN_MEVT1.....                                          | 981 |
| 5-498. Register Call Summary for Register WUGEN_MEVT1 .....      | 981 |
| 5-499. WUGEN_MEVT2.....                                          | 982 |
| 5-500. Register Call Summary for Register WUGEN_MEVT2 .....      | 982 |
| 5-501. WUGEN_MEVTCLEAR0 .....                                    | 983 |
| 5-502. Register Call Summary for Register WUGEN_MEVTCLEAR0.....  | 984 |
| 5-503. WUGEN_MEVTCLEAR1 .....                                    | 984 |
| 5-504. Register Call Summary for Register WUGEN_MEVTCLEAR1 ..... | 985 |
| 5-505. WUGEN_MEVTCLEAR2 .....                                    | 985 |
| 5-506. Register Call Summary for Register WUGEN_MEVTCLEAR2.....  | 986 |
| 5-507. WUGEN_MEVTSET0 .....                                      | 987 |
| 5-508. Register Call Summary for Register WUGEN_MEVTSET0 .....   | 988 |
| 5-509. WUGEN_MEVTSET1 .....                                      | 988 |
| 5-510. Register Call Summary for Register WUGEN_MEVTSET1 .....   | 989 |
| 5-511. WUGEN_MEVTSET2 .....                                      | 989 |
| 5-512. Register Call Summary for Register WUGEN_MEVTSET2 .....   | 990 |
| 5-513. WUGEN_PENDEVT0 .....                                      | 991 |
| 5-514. Register Call Summary for Register WUGEN_PENDEVT0 .....   | 992 |
| 5-515. WUGEN_PENDEVT1 .....                                      | 992 |
| 5-516. Register Call Summary for Register WUGEN_PENDEVT1 .....   | 992 |
| 5-517. WUGEN_PENDEVT2 .....                                      | 993 |
| 5-518. Register Call Summary for Register WUGEN_PENDEVT2 .....   | 993 |
| 5-519. WUGEN_PENDEVTCLR0 .....                                   | 994 |
| 5-520. Register Call Summary for Register WUGEN_PENDEVTCLR0..... | 995 |
| 5-521. WUGEN_PENDEVTCLR1 .....                                   | 995 |
| 5-522. Register Call Summary for Register WUGEN_PENDEVTCLR1..... | 995 |
| 5-523. WUGEN_PENDEVTCLR2 .....                                   | 996 |
| 5-524. Register Call Summary for Register WUGEN_PENDEVTCLR2..... | 996 |
| 5-525. iVLCD Register Mapping Summary .....                      | 997 |
| 5-526. iVLCD_REVISION .....                                      | 999 |
| 5-527. Register Call Summary for Register iVLCD_REVISION.....    | 999 |

|                                                                    |      |
|--------------------------------------------------------------------|------|
| 5-528. IVLCD_SYSCONFIG .....                                       | 999  |
| 5-529. Register Call Summary for Register IVLCD_SYSCONFIG .....    | 1000 |
| 5-530. IVLCD_SYSSTATUS .....                                       | 1000 |
| 5-531. Register Call Summary for Register IVLCD_SYSSTATUS .....    | 1000 |
| 5-532. IVLCD_CPUTATUSREG .....                                     | 1000 |
| 5-533. Register Call Summary for Register IVLCD_CPUTATUSREG .....  | 1001 |
| 5-534. IVLCD_CONFIGREG .....                                       | 1001 |
| 5-535. Register Call Summary for Register IVLCD_CONFIGREG.....     | 1002 |
| 5-536. IVLCD_COMMAND .....                                         | 1002 |
| 5-537. Register Call Summary for Register IVLCD_COMMAND .....      | 1002 |
| 5-538. VLCD_START .....                                            | 1002 |
| 5-539. Register Call Summary for Register VLCD_START .....         | 1003 |
| 5-540. VLCD_MODE .....                                             | 1003 |
| 5-541. Register Call Summary for Register VLCD_MODE .....          | 1004 |
| 5-542. VLCD_QIN_ADDR .....                                         | 1004 |
| 5-543. Register Call Summary for Register VLCD_QIN_ADDR .....      | 1004 |
| 5-544. VLCD_QOUT_ADDR .....                                        | 1005 |
| 5-545. Register Call Summary for Register VLCD_QOUT_ADDR .....     | 1005 |
| 5-546. VLCD_IQIN_ADDR.....                                         | 1005 |
| 5-547. Register Call Summary for Register VLCD_IQIN_ADDR .....     | 1005 |
| 5-548. VLCD_IQOUT_ADDR.....                                        | 1006 |
| 5-549. Register Call Summary for Register VLCD_IQOUT_ADDR .....    | 1006 |
| 5-550. VLCD_VLCDIN_ADDR .....                                      | 1006 |
| 5-551. Register Call Summary for Register VLCD_VLCDIN_ADDR .....   | 1007 |
| 5-552. VLCD_VLCDOUT_ADDR .....                                     | 1007 |
| 5-553. Register Call Summary for Register VLCD_VLCDOUT_ADDR .....  | 1007 |
| 5-554. VLCD_DC_PREDj .....                                         | 1007 |
| 5-555. Register Call Summary for Register VLCD_DC_PREDj .....      | 1008 |
| 5-556. VLCD_IDC_PREDj .....                                        | 1008 |
| 5-557. Register Call Summary for Register VLCD_IDC_PREDj.....      | 1008 |
| 5-558. VLCD_MPEG_INVQ .....                                        | 1008 |
| 5-559. Register Call Summary for Register VLCD_MPEG_INVQ .....     | 1008 |
| 5-560. VLCD_MPEG_Q .....                                           | 1009 |
| 5-561. Register Call Summary for Register VLCD_MPEG_Q .....        | 1009 |
| 5-562. VLCD_MPEG_DELTA_Q .....                                     | 1009 |
| 5-563. Register Call Summary for Register VLCD_MPEG_DELTA_Q .....  | 1009 |
| 5-564. VLCD_MPEG_DELTA_IQ.....                                     | 1009 |
| 5-565. Register Call Summary for Register VLCD_MPEG_DELTA_IQ ..... | 1010 |
| 5-566. VLCD_MPEG_THRED.....                                        | 1010 |
| 5-567. Register Call Summary for Register VLCD_MPEG_THRED .....    | 1010 |
| 5-568. VLCD_MPEG_CBP .....                                         | 1010 |
| 5-569. Register Call Summary for Register VLCD_MPEG_CBP .....      | 1011 |
| 5-570. VLCD_LUMA_VECTOR .....                                      | 1011 |
| 5-571. Register Call Summary for Register VLCD_LUMA_VECTOR.....    | 1011 |
| 5-572. VLCD_HUFFTAB_DCY .....                                      | 1012 |
| 5-573. Register Call Summary for Register VLCD_HUFFTAB_DCY .....   | 1012 |
| 5-574. VLCD_HUFFTAB_DCUV .....                                     | 1012 |
| 5-575. Register Call Summary for Register VLCD_HUFFTAB_DCUV .....  | 1012 |
| 5-576. VLCD_HUFFTAB_ACi .....                                      | 1013 |

|                                                                   |      |
|-------------------------------------------------------------------|------|
| 5-577. Register Call Summary for Register VLCD_HUFFTAB_ACi.....   | 1013 |
| 5-578. VLCD_OFLEV_MAXiTAB .....                                   | 1013 |
| 5-579. Register Call Summary for Register VLCD_OFLEV_MAXiTAB..... | 1013 |
| 5-580. VLCD_CTLTAB_DCY.....                                       | 1014 |
| 5-581. Register Call Summary for Register VLCD_CTLTAB_DCY .....   | 1014 |
| 5-582. VLCD_CTLTAB_DCUV .....                                     | 1014 |
| 5-583. Register Call Summary for Register VLCD_CTLTAB_DCUV .....  | 1014 |
| 5-584. VLCD_CTLTAB_ACi .....                                      | 1015 |
| 5-585. Register Call Summary for Register VLCD_CTLTAB_ACi.....    | 1015 |
| 5-586. VLCD_OFFSET_DCY .....                                      | 1015 |
| 5-587. Register Call Summary for Register VLCD_OFFSET_DCY .....   | 1015 |
| 5-588. VLCD_OFFSET_DCUV .....                                     | 1016 |
| 5-589. Register Call Summary for Register VLCD_OFFSET_DCUV .....  | 1016 |
| 5-590. VLCD_OFFSET_ACi.....                                       | 1016 |
| 5-591. Register Call Summary for Register VLCD_OFFSET_ACi .....   | 1016 |
| 5-592. VLCD_SYMTAB_DCY .....                                      | 1017 |
| 5-593. Register Call Summary for Register VLCD_SYMTAB_DCY.....    | 1017 |
| 5-594. VLCD_SYMTAB_DCUV .....                                     | 1017 |
| 5-595. Register Call Summary for Register VLCD_SYMTAB_DCUV.....   | 1017 |
| 5-596. VLCD_SYMTAB_ACi .....                                      | 1018 |
| 5-597. Register Call Summary for Register VLCD_SYMTAB_ACi.....    | 1018 |
| 5-598. VLCD_VLD_CTL .....                                         | 1018 |
| 5-599. Register Call Summary for Register VLCD_VLD_CTL .....      | 1019 |
| 5-600. VLCD_VLD_NRBIT_DC .....                                    | 1019 |
| 5-601. Register Call Summary for Register VLCD_VLD_NRBIT_DC.....  | 1019 |
| 5-602. VLCD_VLD_NRBIT_AC .....                                    | 1019 |
| 5-603. Register Call Summary for Register VLCD_VLD_NRBIT_AC.....  | 1020 |
| 5-604. VLCD_BITS_BPTR.....                                        | 1020 |
| 5-605. Register Call Summary for Register VLCD_BITS_BPTR .....    | 1020 |
| 5-606. VLCD_BITS_WORD .....                                       | 1020 |
| 5-607. Register Call Summary for Register VLCD_BITS_WORD .....    | 1021 |
| 5-608. VLCD_BYTE_ALIGN.....                                       | 1021 |
| 5-609. Register Call Summary for Register VLCD_BYTE_ALIGN .....   | 1021 |
| 5-610. VLCD_HEAD_ADDR.....                                        | 1021 |
| 5-611. Register Call Summary for Register VLCD_HEAD_ADDR .....    | 1021 |
| 5-612. VLCD_HEAD_NUM .....                                        | 1022 |
| 5-613. Register Call Summary for Register VLCD_HEAD_NUM.....      | 1022 |
| 5-614. VLCD_QIQ_CONFIGj.....                                      | 1022 |
| 5-615. Register Call Summary for Register VLCD_QIQ_CONFIGj .....  | 1023 |
| 5-616. VLCD_VLD_ERRCTL.....                                       | 1023 |
| 5-617. Register Call Summary for Register VLCD_VLD_ERRCTL .....   | 1023 |
| 5-618. VLCD_VLD_ERRSTAT .....                                     | 1023 |
| 5-619. Register Call Summary for Register VLCD_VLD_ERRSTAT .....  | 1024 |
| 5-620. VLCD_RING_START .....                                      | 1024 |
| 5-621. Register Call Summary for Register VLCD_RING_START.....    | 1024 |
| 5-622. VLCD_RING_END .....                                        | 1024 |
| 5-623. Register Call Summary for Register VLCD_RING_END .....     | 1025 |
| 5-624. VLCD_CTRL .....                                            | 1025 |
| 5-625. Register Call Summary for Register VLCD_CTRL.....          | 1026 |

---

|                                                                    |      |
|--------------------------------------------------------------------|------|
| 5-626. VLCD_VLD_PREFIX_DC .....                                    | 1026 |
| 5-627. Register Call Summary for Register VLCD_VLD_PREFIX_DC ..... | 1026 |
| 5-628. VLCD_VLD_PREFIX_AC .....                                    | 1026 |
| 5-629. Register Call Summary for Register VLCD_VLD_PREFIX_AC ..... | 1027 |
| 5-630. VLCD_WMV9_CONFIG .....                                      | 1027 |
| 5-631. Register Call Summary for Register VLCD_WMV9_CONFIG .....   | 1027 |
| 5-632. VLCD_FIRST_FRAME .....                                      | 1028 |
| 5-633. Register Call Summary for Register VLCD_FIRST_FRAME .....   | 1028 |
| 5-634. VLCD_H264_MODE .....                                        | 1028 |
| 5-635. Register Call Summary for Register VLCD_H264_MODE .....     | 1028 |
| 5-636. VLCD_NRBITSTH .....                                         | 1029 |
| 5-637. Register Call Summary for Register VLCD_NRBITSTH .....      | 1029 |
| 5-638. CAVLC_GO_REG .....                                          | 1029 |
| 5-639. Register Call Summary for Register CAVLC_GO_REG .....       | 1029 |
| 5-640. CAVLC_MBTYPE .....                                          | 1030 |
| 5-641. Register Call Summary for Register CAVLC_MBTYPE .....       | 1030 |
| 5-642. CAVLC_RBTOP .....                                           | 1030 |
| 5-643. Register Call Summary for Register CAVLC_RBTOP .....        | 1030 |
| 5-644. CAVLC_RBEND .....                                           | 1031 |
| 5-645. Register Call Summary for Register CAVLC_RBEND .....        | 1031 |
| 5-646. CAVLC_BUFPTR .....                                          | 1031 |
| 5-647. Register Call Summary for Register CAVLC_BUFPTR .....       | 1031 |
| 5-648. CAVLC_BITPTR .....                                          | 1032 |
| 5-649. Register Call Summary for Register CAVLC_BITPTR .....       | 1032 |
| 5-650. CAVLC_STRMWDU .....                                         | 1032 |
| 5-651. Register Call Summary for Register CAVLC_STRMWDU .....      | 1032 |
| 5-652. CAVLC_STRMWDL .....                                         | 1033 |
| 5-653. Register Call Summary for Register CAVLC_STRMWDL .....      | 1033 |
| 5-654. CAVLC_HDPTR .....                                           | 1033 |
| 5-655. Register Call Summary for Register CAVLC_HDPTR .....        | 1033 |
| 5-656. CAVLC_HDCOUNT .....                                         | 1034 |
| 5-657. Register Call Summary for Register CAVLC_HDCOUNT .....      | 1034 |
| 5-658. CAVLC_NAPTR .....                                           | 1034 |
| 5-659. Register Call Summary for Register CAVLC_NAPTR .....        | 1034 |
| 5-660. CAVLC_NBPTR .....                                           | 1035 |
| 5-661. Register Call Summary for Register CAVLC_NBPTR .....        | 1035 |
| 5-662. CAVLC_COEFFPTR .....                                        | 1035 |
| 5-663. Register Call Summary for Register CAVLC_COEFFPTR .....     | 1035 |
| 5-664. CAVLC_IBUFSEL .....                                         | 1036 |
| 5-665. Register Call Summary for Register CAVLC_IBUFSEL .....      | 1036 |
| 5-666. CAVLC_NUMTTL .....                                          | 1036 |
| 5-667. Register Call Summary for Register CAVLC_NUMTTL .....       | 1037 |
| 5-668. CAVLC_NUMHD .....                                           | 1037 |
| 5-669. Register Call Summary for Register CAVLC_NUMHD .....        | 1037 |
| 5-670. CAVLC_NUMRESI .....                                         | 1037 |
| 5-671. Register Call Summary for Register CAVLC_NUMRESI .....      | 1037 |
| 5-672. SEQ Register Mapping Summary .....                          | 1038 |
| 5-673. SEQ_REVISION .....                                          | 1038 |
| 5-674. Register Call Summary for Register SEQ_REVISION .....       | 1038 |

|                                                                            |      |
|----------------------------------------------------------------------------|------|
| 5-675. SEQ_SYSCONFIG .....                                                 | 1039 |
| 5-676. Register Call Summary for Register SEQ_SYSCONFIG .....              | 1039 |
| 5-677. SEQ_IRQMASK .....                                                   | 1039 |
| 5-678. Register Call Summary for Register SEQ_IRQMASK .....                | 1040 |
| 5-679. SEQ_IRQCLR .....                                                    | 1040 |
| 5-680. Register Call Summary for Register SEQ_IRQCLR .....                 | 1041 |
| 5-681. SEQ_IRQSET .....                                                    | 1041 |
| 5-682. Register Call Summary for Register SEQ_IRQSET .....                 | 1042 |
| 5-683. SEQ_IRQSTATE .....                                                  | 1042 |
| 5-684. Register Call Summary for Register SEQ_IRQSTATE .....               | 1043 |
| 5-685. SEQ_SWICLR .....                                                    | 1043 |
| 5-686. Register Call Summary for Register SEQ_SWICLR .....                 | 1043 |
| 5-687. SEQ_SWISET .....                                                    | 1043 |
| 5-688. Register Call Summary for Register SEQ_SWISET .....                 | 1043 |
| 5-689. SEQ_SWISTATE .....                                                  | 1044 |
| 5-690. Register Call Summary for Register SEQ_SWISTATE .....               | 1044 |
| 5-691. VIDEOSYSC Register Mapping Summary .....                            | 1045 |
| 5-692. VIDEOSYSC_REVISION .....                                            | 1045 |
| 5-693. Register Call Summary for Register VIDEOSYSC_REVISION .....         | 1045 |
| 5-694. VIDEOSYSC_SYSCONFIG .....                                           | 1046 |
| 5-695. Register Call Summary for Register VIDEOSYSC_SYSCONFIG .....        | 1046 |
| 5-696. VIDEOSYSC_IRQMASK .....                                             | 1046 |
| 5-697. Register Call Summary for Register VIDEOSYSC_IRQMASK .....          | 1046 |
| 5-698. VIDEOSYSC_IRQCLR .....                                              | 1047 |
| 5-699. Register Call Summary for Register VIDEOSYSC_IRQCLR .....           | 1047 |
| 5-700. VIDEOSYSC_IRQSET .....                                              | 1047 |
| 5-701. Register Call Summary for Register VIDEOSYSC_IRQSET .....           | 1047 |
| 5-702. VIDEOSYSC_IRQSTATE .....                                            | 1048 |
| 5-703. Register Call Summary for Register VIDEOSYSC_IRQSTATE .....         | 1048 |
| 5-704. VIDEOSYSC_CLKCTL .....                                              | 1048 |
| 5-705. Register Call Summary for Register VIDEOSYSC_CLKCTL .....           | 1049 |
| 5-706. VIDEOSYSC_CLKDIV .....                                              | 1049 |
| 5-707. Register Call Summary for Register VIDEOSYSC_CLKDIV .....           | 1049 |
| 5-708. VIDEOSYSC_CLKST .....                                               | 1050 |
| 5-709. Register Call Summary for Register VIDEOSYSC_CLKST .....            | 1050 |
| 5-710. iME Register Mapping Summary .....                                  | 1051 |
| 5-711. iME_REVISION .....                                                  | 1052 |
| 5-712. Register Call Summary for Register iME_REVISION .....               | 1052 |
| 5-713. iME_SYSCONFIG .....                                                 | 1052 |
| 5-714. Register Call Summary for Register iME_SYSCONFIG .....              | 1053 |
| 5-715. iME_SYSSTATUS .....                                                 | 1053 |
| 5-716. Register Call Summary for Register iME_SYSSTATUS .....              | 1053 |
| 5-717. iME_PROGRAMBUFFERLINENLSBi .....                                    | 1053 |
| 5-718. Register Call Summary for Register iME_PROGRAMBUFFERLINENLSBi ..... | 1053 |
| 5-719. iME_PROGRAMBUFFERLINEMSBi .....                                     | 1054 |
| 5-720. Register Call Summary for Register iME_PROGRAMBUFFERLINEMSBi .....  | 1054 |
| 5-721. iME_ERRORTABLEj .....                                               | 1054 |
| 5-722. Register Call Summary for Register iME_ERRORTABLEj .....            | 1054 |
| 5-723. iME_REFERENCEBLOCKk .....                                           | 1054 |

|                                                                            |      |
|----------------------------------------------------------------------------|------|
| 5-724. Register Call Summary for Register iME_REFERENCEBLOCKk .....        | 1055 |
| 5-725. iME_COEFFREGBANKI.....                                              | 1055 |
| 5-726. Register Call Summary for Register iME_COEFFREGBANKI .....          | 1055 |
| 5-727. iME_PARAMETERSTACKLj .....                                          | 1055 |
| 5-728. Register Call Summary for Register iME_PARAMETERSTACKLj .....       | 1055 |
| 5-729. iME_PARAMETERSTACKHj .....                                          | 1056 |
| 5-730. Register Call Summary for Register iME_PARAMETERSTACKHj .....       | 1056 |
| 5-731. iME_XMVCTm .....                                                    | 1056 |
| 5-732. Register Call Summary for Register iME_XMVCTm.....                  | 1056 |
| 5-733. iME_YMVCTm .....                                                    | 1056 |
| 5-734. Register Call Summary for Register iME_YMVCTm.....                  | 1057 |
| 5-735. iME_MINERRORTHRESHOLD .....                                         | 1057 |
| 5-736. Register Call Summary for Register iME_MINERRORTHRESHOLD .....      | 1057 |
| 5-737. iME_ABSMINREACHED .....                                             | 1057 |
| 5-738. Register Call Summary for Register iME_ABSMINREACHED .....          | 1057 |
| 5-739. iME_CPUSTATUSREG.....                                               | 1058 |
| 5-740. Register Call Summary for Register iME_CPUSTATUSREG .....           | 1058 |
| 5-741. iME_IRQLOG .....                                                    | 1059 |
| 5-742. Register Call Summary for Register iME_IRQLOG .....                 | 1059 |
| 5-743. iME_LATESTERRORS .....                                              | 1059 |
| 5-744. Register Call Summary for Register iME_LATESTERRORS.....            | 1059 |
| 5-745. iME_CONFIGREG .....                                                 | 1060 |
| 5-746. Register Call Summary for Register iME_CONFIGREG .....              | 1060 |
| 5-747. iME_SL2INSTADDRESS .....                                            | 1060 |
| 5-748. Register Call Summary for Register iME_SL2INSTADDRESS .....         | 1060 |
| 5-749. iME_COMMANDREG.....                                                 | 1061 |
| 5-750. Register Call Summary for Register iME_COMMANDREG .....             | 1061 |
| 5-751. iLF Register Mapping Summary .....                                  | 1062 |
| 5-752. iLF_REVISION .....                                                  | 1063 |
| 5-753. Register Call Summary for Register iLF_REVISION .....               | 1063 |
| 5-754. iLF_SYSCONFIG .....                                                 | 1063 |
| 5-755. Register Call Summary for Register iLF_SYSCONFIG .....              | 1064 |
| 5-756. iLF_SYSSTATUS.....                                                  | 1064 |
| 5-757. Register Call Summary for Register iLF_SYSSTATUS .....              | 1064 |
| 5-758. iLF_PROGRAMBUFFERLINENLSBi .....                                    | 1064 |
| 5-759. Register Call Summary for Register iLF_PROGRAMBUFFERLINENLSBi ..... | 1064 |
| 5-760. iLF_PROGRAMBUFFERLINENMSBi.....                                     | 1065 |
| 5-761. Register Call Summary for Register iLF_PROGRAMBUFFERLINENMSBi ..... | 1065 |
| 5-762. iLF_PARAMETERSTACKUPj.....                                          | 1065 |
| 5-763. Register Call Summary for Register iLF_PARAMETERSTACKUPj .....      | 1065 |
| 5-764. iLF_PARAMETERSTACKLWk.....                                          | 1065 |
| 5-765. Register Call Summary for Register iLF_PARAMETERSTACKLWk .....      | 1066 |
| 5-766. iLF_EFPTABLEENTRYI .....                                            | 1066 |
| 5-767. Register Call Summary for Register iLF_EFPTABLEENTRYI.....          | 1066 |
| 5-768. iLF_INOUTBUFFERm .....                                              | 1066 |
| 5-769. Register Call Summary for Register iLF_INOUTBUFFERm.....            | 1066 |
| 5-770. iLF_CPUSTATUSREG.....                                               | 1067 |
| 5-771. Register Call Summary for Register iLF_CPUSTATUSREG .....           | 1067 |
| 5-772. iLF_IRQLOG .....                                                    | 1068 |

|                                                                                      |      |
|--------------------------------------------------------------------------------------|------|
| 5-773. Register Call Summary for Register iLF_IRQLOG .....                           | 1068 |
| 5-774. iLF_EFPTD .....                                                               | 1068 |
| 5-775. Register Call Summary for Register iLF_EFPTD .....                            | 1068 |
| 5-776. iLF_CONFIGREG .....                                                           | 1069 |
| 5-777. Register Call Summary for Register iLF_CONFIGREG .....                        | 1069 |
| 5-778. iLF_PARSEDATAREG0 .....                                                       | 1069 |
| 5-779. Register Call Summary for Register iLF_PARSEDATAREG0.....                     | 1069 |
| 5-780. iLF_PARSEDATAREG1 .....                                                       | 1070 |
| 5-781. Register Call Summary for Register iLF_PARSEDATAREG1.....                     | 1070 |
| 5-782. iLF_PARSEDATAREG2 .....                                                       | 1070 |
| 5-783. Register Call Summary for Register iLF_PARSEDATAREG2.....                     | 1071 |
| 5-784. iLF_INSTBUFFER_ADDRESS .....                                                  | 1071 |
| 5-785. Register Call Summary for Register iLF_INSTBUFFER_ADDRESS.....                | 1071 |
| 5-786. iLF_LINESFILTERPROTOTYPES .....                                               | 1071 |
| 5-787. Register Call Summary for Register iLF_LINESFILTERPROTOTYPES.....             | 1072 |
| 5-788. iLF_CLIPLIMITSENTRYn .....                                                    | 1072 |
| 5-789. Register Call Summary for Register iLF_CLIPLIMITSENTRYn .....                 | 1072 |
| 5-790. iLF_COMMANDREG.....                                                           | 1072 |
| 5-791. Register Call Summary for Register iLF_COMMANDREG .....                       | 1073 |
| 5-792. IA_GEM Register Mapping Summary .....                                         | 1073 |
| 5-793. GEM_AGENT_STATUS .....                                                        | 1073 |
| 5-794. Register Call Summary for Register GEM_AGENT_STATUS .....                     | 1074 |
| 5-795. IA_EDMA Register Mapping Summary .....                                        | 1074 |
| 5-796. EDMA_AGENT_STATUS .....                                                       | 1074 |
| 5-797. Register Call Summary for Register EDMA_AGENT_STATUS.....                     | 1075 |
| 5-798. IA_SEQ Register Mapping Summary .....                                         | 1076 |
| 5-799. SEQ_AGENT_STATUS .....                                                        | 1076 |
| 5-800. Register Call Summary for Register SEQ_AGENT_STATUS.....                      | 1077 |
| 6-1. Camera ISP Functions .....                                                      | 1085 |
| 6-2. IO Description.....                                                             | 1086 |
| 6-3. Camera ISP Connectivity Schemes.....                                            | 1087 |
| 6-4. Camera ISP Video Timing Reference Codes for SAV and EAV .....                   | 1092 |
| 6-5. Camera ISP F, V, H Signal Descriptions .....                                    | 1092 |
| 6-6. Camera ISP F, V, H Protection (Error-Correction) Bits.....                      | 1093 |
| 6-7. Camera ISP BT.656 Mode Data Format in SDRAM .....                               | 1093 |
| 6-8. Camera ISP CSI1/CCP2B Image Data Operating Modes and Alignment Constraints..... | 1094 |
| 6-9. Camera ISP CSI2 Long Packet Structure Description .....                         | 1109 |
| 6-10. Camera ISP CSI2 Pixel Format Modes .....                                       | 1110 |
| 6-11. Camera ISP CSI2 Synchronization Codes .....                                    | 1111 |
| 6-12. Camera ISP Clock Descriptions .....                                            | 1134 |
| 6-13. Camera ISP cam_xclka Configuration.....                                        | 1135 |
| 6-14. Camera ISP cam_xclkb Configuration.....                                        | 1136 |
| 6-15. Camera ISP Interrupts .....                                                    | 1139 |
| 6-16. Camera ISP CBUFF Interrupt Details .....                                       | 1141 |
| 6-17. Camera ISP CSI1/CCP2B Receiver Interrupt Details .....                         | 1142 |
| 6-18. Camera ISP CSI2A and CSI2C Receivers Event Generation .....                    | 1145 |
| 6-19. Camera ISP CSI2A and CSI2C Receiver Event Generation from PHY .....            | 1146 |
| 6-20. Camera ISP CSI2A and CSI2C CTx Receiver Event Generation .....                 | 1147 |
| 6-21. Camera ISP Allowed Data Flows for Hardware .....                               | 1150 |

---

|                                                                                                       |      |
|-------------------------------------------------------------------------------------------------------|------|
| 6-22. Camera ISP CSI1/CCP2B Transmitter Classification.....                                           | 1154 |
| 6-23. Camera ISP CSI1/CCP2B Logical Channel Values in Synchronization Codes.....                      | 1159 |
| 6-24. Camera ISP CSI1/CCP2B Memory-to-Memory Supported Operations .....                               | 1160 |
| 6-25. Camera ISP CSI1/CCP2B Memory-to-Video Processing Hardware Supported Formats.....                | 1162 |
| 6-26. Camera ISP CSI1/CCP2B Data Packing Benefit and Constraints .....                                | 1166 |
| 6-27. Camera ISP CSI1/CCP2B Output Width Restrictions in Memory-to-Memory Operation .....             | 1167 |
| 6-28. Camera ISP CSI1/CCP2B Image Data Operating Modes and Alignment Constraints.....                 | 1168 |
| 6-29. Camera ISP CSI2 ECC Event Logging .....                                                         | 1172 |
| 6-30. Camera ISP Pixel Format Modes .....                                                             | 1173 |
| 6-31. Camera ISP CSI2 Transcode Alignment Constraints.....                                            | 1175 |
| 6-32. Camera ISP CSI2 Supported Transcoding Output Formats .....                                      | 1175 |
| 6-33. Camera ISP CSI2 Possible Time-Out Value for RxMode Counter .....                                | 1180 |
| 6-34. Camera ISP Timing Control Control-Signal Generator: CNTCLK Frequencies .....                    | 1184 |
| 6-35. Camera ISP Bridge-Lane Shifter .....                                                            | 1186 |
| 6-36. Camera ISP CCDC Reformatter Output Limitations .....                                            | 1192 |
| 6-37. Camera ISP CCDC CCDC_SDOFST Description .....                                                   | 1196 |
| 6-38. Camera ISP CCDC Memory Output Format for RAW Data .....                                         | 1198 |
| 6-39. Camera ISP CCDC Memory Output Format for YUV Data .....                                         | 1199 |
| 6-40. Camera ISP VPBE Preview Image Cropping by Preview Functions .....                               | 1206 |
| 6-41. Camera ISP VPBE Resizer Use Constraints .....                                                   | 1207 |
| 6-42. Camera ISP VPBE Resizer Arrangement of the Filter Coefficients.....                             | 1211 |
| 6-43. Camera ISP VPBE Resizer Input Size Calculations .....                                           | 1212 |
| 6-44. Camera ISP VPBE Resizer Processing Example for 1:2:56 Horizontal Resize.....                    | 1217 |
| 6-45. Camera ISP Histogram White Balance Field-to-Pattern Assignments .....                           | 1220 |
| 6-46. Camera ISP Histogram Regions and Bins .....                                                     | 1221 |
| 6-47. Camera ISP Shared Buffer Logic Fixed Parameters .....                                           | 1225 |
| 6-48. Camera ISP Shared Buffer Logic Number of Request Registers .....                                | 1227 |
| 6-49. Camera ISP Circular Buffer Fragmentation Support Physical Window Addresses.....                 | 1233 |
| 6-50. Camera ISP Circular Buffer VRFB Maximum Supported Frame Size.....                               | 1233 |
| 6-51. Camera ISP Circular Buffer VRFB Extended Supported Frame Size .....                             | 1233 |
| 6-52. Camera ISP Circular Buffer Internal Variables .....                                             | 1234 |
| 6-53. Camera ISP Circular Buffer Internal State After Reset.....                                      | 1235 |
| 6-54. Camera ISP Circular Buffer Address Identification .....                                         | 1235 |
| 6-55. Camera ISP Circular Buffer Address Translation .....                                            | 1236 |
| 6-56. Camera ISP Circular Buffer Window Level Increment.....                                          | 1236 |
| 6-57. Camera ISP Circular Buffer Window Level Comparison .....                                        | 1237 |
| 6-58. Camera ISP PRCM Registers Settings.....                                                         | 1238 |
| 6-59. Camera ISP CSI1/CCP2B CCP2_LCx_CTRL[7:2] FORMAT and CCP2_CTRL[11] VP_ONLY_EN = 1 Settings ..... | 1244 |
| 6-60. Camera ISP CSI2 Receiver-Supported Data Types .....                                             | 1253 |
| 6-61. Camera ISP CCDC Required Configuration Parameters .....                                         | 1259 |
| 6-62. Camera ISP CCDC Conditional Configuration Parameters.....                                       | 1259 |
| 6-63. Camera ISP CCDC Conventional Readout Pattern 1 to 1 .....                                       | 1268 |
| 6-64. Camera ISP CCDC Dual Readout Pattern 1 to 1 .....                                               | 1269 |
| 6-65. Camera ISP CCDC Dual Readout Pattern 1 to 3 .....                                               | 1270 |
| 6-66. Camera ISP CCDC CCDC_ALAW [2:0] GWDI.....                                                       | 1271 |
| 6-67. Camera ISP Preview Engine Required Configuration Parameters .....                               | 1275 |
| 6-68. Camera ISP Preview Engine Conditional Configuration Parameters .....                            | 1275 |
| 6-69. Camera ISP Resizer Required Configuration Parameters .....                                      | 1279 |

|        |                                                                    |      |
|--------|--------------------------------------------------------------------|------|
| 6-70.  | Camera ISP Resizer Conditional Configuration Parameters .....      | 1280 |
| 6-71.  | Camera ISP Resizer How to Set Input Height and Width.....          | 1283 |
| 6-72.  | Camera ISP H3A AF Engine Required Configuration Parameters .....   | 1284 |
| 6-73.  | Camera ISP H3A AF Engine Conditional Configuration Parameters..... | 1285 |
| 6-74.  | Camera ISP H3A AEW Engine Required Configuration Parameters.....   | 1285 |
| 6-75.  | Camera ISP Histogram Required Configuration Parameters .....       | 1287 |
| 6-76.  | Camera ISP Histogram Conditional Configuration Parameters .....    | 1288 |
| 6-77.  | Camera ISP Central-Resource SBL Write-Buffer Overflow Events.....  | 1290 |
| 6-78.  | Camera ISP Central-Resource SBL Read-Buffer Underflow Events.....  | 1291 |
| 6-79.  | Camera ISP Software Register Settings .....                        | 1295 |
| 6-80.  | Camera ISP Instance Summary .....                                  | 1296 |
| 6-81.  | ISP Register Mapping Summary .....                                 | 1296 |
| 6-82.  | ISP_REVISION .....                                                 | 1297 |
| 6-83.  | Register Call Summary for Register ISP_REVISION.....               | 1297 |
| 6-84.  | ISP_SYSCONFIG .....                                                | 1297 |
| 6-85.  | Register Call Summary for Register ISP_SYSCONFIG.....              | 1298 |
| 6-86.  | ISP_SYSSTATUS .....                                                | 1298 |
| 6-87.  | Register Call Summary for Register ISP_SYSSTATUS.....              | 1299 |
| 6-88.  | ISP_IRQ0ENABLE .....                                               | 1299 |
| 6-89.  | Register Call Summary for Register ISP_IRQ0ENABLE.....             | 1301 |
| 6-90.  | ISP_IRQ0STATUS .....                                               | 1302 |
| 6-91.  | Register Call Summary for Register ISP_IRQ0STATUS.....             | 1305 |
| 6-92.  | ISP_IRQ1ENABLE .....                                               | 1305 |
| 6-93.  | Register Call Summary for Register ISP_IRQ1ENABLE.....             | 1308 |
| 6-94.  | ISP_IRQ1STATUS .....                                               | 1308 |
| 6-95.  | Register Call Summary for Register ISP_IRQ1STATUS.....             | 1312 |
| 6-96.  | TCTRL_GRESET_LENGTH .....                                          | 1312 |
| 6-97.  | Register Call Summary for Register TCTRL_GRESET_LENGTH.....        | 1312 |
| 6-98.  | TCTRL_PSTRB_REPLY.....                                             | 1313 |
| 6-99.  | Register Call Summary for Register TCTRL_PSTRB_REPLY .....         | 1313 |
| 6-100. | ISP_CTRL .....                                                     | 1313 |
| 6-101. | Register Call Summary for Register ISP_CTRL.....                   | 1317 |
| 6-102. | TCTRL_CTRL.....                                                    | 1317 |
| 6-103. | Register Call Summary for Register TCTRL_CTRL .....                | 1319 |
| 6-104. | TCTRL_FRAME .....                                                  | 1320 |
| 6-105. | Register Call Summary for Register TCTRL_FRAME .....               | 1320 |
| 6-106. | TCTRL_PSTRB_DELAY .....                                            | 1321 |
| 6-107. | Register Call Summary for Register TCTRL_PSTRB_DELAY .....         | 1321 |
| 6-108. | TCTRL_STRB_DELAY .....                                             | 1321 |
| 6-109. | Register Call Summary for Register TCTRL_STRB_DELAY .....          | 1321 |
| 6-110. | TCTRL_SHUT_DELAY .....                                             | 1322 |
| 6-111. | Register Call Summary for Register TCTRL_SHUT_DELAY.....           | 1322 |
| 6-112. | TCTRL_PSTRB_LENGTH .....                                           | 1322 |
| 6-113. | Register Call Summary for Register TCTRL_PSTRB_LENGTH.....         | 1322 |
| 6-114. | TCTRL_STRB_LENGTH .....                                            | 1323 |
| 6-115. | Register Call Summary for Register TCTRL_STRB_LENGTH.....          | 1323 |
| 6-116. | TCTRL_SHUT_LENGTH .....                                            | 1323 |
| 6-117. | Register Call Summary for Register TCTRL_SHUT_LENGTH.....          | 1323 |
| 6-118. | ISP_CBUFF Register Summary .....                                   | 1324 |

---

|                                                                     |      |
|---------------------------------------------------------------------|------|
| 6-119. CBUFF_REVISION.....                                          | 1324 |
| 6-120. Register Call Summary for Register CBUFF_REVISION .....      | 1325 |
| 6-121. CBUFF_SYSCONFIG.....                                         | 1325 |
| 6-122. Register Call Summary for Register CBUFF_SYSCONFIG .....     | 1325 |
| 6-123. CBUFF_SYSSTATUS .....                                        | 1325 |
| 6-124. Register Call Summary for Register CBUFF_SYSSTATUS .....     | 1325 |
| 6-125. CBUFF_IRQSTATUS .....                                        | 1325 |
| 6-126. Register Call Summary for Register CBUFF_IRQSTATUS.....      | 1326 |
| 6-127. CBUFF_IRQENABLE .....                                        | 1327 |
| 6-128. Register Call Summary for Register CBUFF_IRQENABLE.....      | 1327 |
| 6-129. CBUFFx_CTRL .....                                            | 1328 |
| 6-130. Register Call Summary for Register CBUFFx_CTRL.....          | 1329 |
| 6-131. CBUFFx_STATUS .....                                          | 1329 |
| 6-132. Register Call Summary for Register CBUFFx_STATUS .....       | 1330 |
| 6-133. CBUFFx_START .....                                           | 1330 |
| 6-134. Register Call Summary for Register CBUFFx_START.....         | 1330 |
| 6-135. CBUFFx_END .....                                             | 1331 |
| 6-136. Register Call Summary for Register CBUFFx_END .....          | 1331 |
| 6-137. CBUFFx_WINDOWSIZE .....                                      | 1331 |
| 6-138. Register Call Summary for Register CBUFFx_WINDOWSIZE .....   | 1331 |
| 6-139. CBUFFx_THRESHOLD .....                                       | 1332 |
| 6-140. Register Call Summary for Register CBUFFx_THRESHOLD .....    | 1332 |
| 6-141. CBUFFx_ADDRy .....                                           | 1332 |
| 6-142. Register Call Summary for Register CBUFFx_ADDRy.....         | 1332 |
| 6-143. CBUFF_VRFB_CTRL.....                                         | 1333 |
| 6-144. Register Call Summary for Register CBUFF_VRFB_CTRL .....     | 1334 |
| 6-145. ISP_CCP2 Register Summary.....                               | 1334 |
| 6-146. CCP2_REVISION .....                                          | 1335 |
| 6-147. Register Call Summary for Register CCP2_REVISION .....       | 1335 |
| 6-148. CCP2_SYSCONFIG .....                                         | 1336 |
| 6-149. Register Call Summary for Register CCP2_SYSCONFIG .....      | 1336 |
| 6-150. CCP2_SYSSTATUS .....                                         | 1337 |
| 6-151. Register Call Summary for Register CCP2_SYSSTATUS .....      | 1337 |
| 6-152. CCP2_LC01_IRQENABLE .....                                    | 1337 |
| 6-153. Register Call Summary for Register CCP2_LC01_IRQENABLE ..... | 1339 |
| 6-154. CCP2_LC01_IRQSTATUS .....                                    | 1339 |
| 6-155. Register Call Summary for Register CCP2_LC01_IRQSTATUS ..... | 1342 |
| 6-156. CCP2_LC23_IRQENABLE .....                                    | 1342 |
| 6-157. Register Call Summary for Register CCP2_LC23_IRQENABLE ..... | 1344 |
| 6-158. CCP2_LC23_IRQSTATUS .....                                    | 1345 |
| 6-159. Register Call Summary for Register CCP2_LC23_IRQSTATUS ..... | 1347 |
| 6-160. CCP2_LCM_IRQENABLE.....                                      | 1348 |
| 6-161. Register Call Summary for Register CCP2_LCM_IRQENABLE .....  | 1348 |
| 6-162. CCP2_LCM_IRQSTATUS.....                                      | 1348 |
| 6-163. Register Call Summary for Register CCP2_LCM_IRQSTATUS .....  | 1349 |
| 6-164. CCP2_CTRL .....                                              | 1349 |
| 6-165. Register Call Summary for Register CCP2_CTRL.....            | 1351 |
| 6-166. CCP2_DBG .....                                               | 1351 |
| 6-167. Register Call Summary for Register CCP2_DBG .....            | 1352 |

|                                                                        |      |
|------------------------------------------------------------------------|------|
| 6-168. CCP2_GNQ .....                                                  | 1352 |
| 6-169. Register Call Summary for Register CCP2_GNQ.....                | 1352 |
| 6-170. CCP2_CTRL1 .....                                                | 1353 |
| 6-171. Register Call Summary for Register CCP2_CTRL1 .....             | 1353 |
| 6-172. CCP2_LCx_CTRL .....                                             | 1354 |
| 6-173. Register Call Summary for Register CCP2_LCx_CTRL .....          | 1356 |
| 6-174. CCP2_LCx_CODE .....                                             | 1356 |
| 6-175. Register Call Summary for Register CCP2_LCx_CODE.....           | 1357 |
| 6-176. CCP2_LCx_STAT_START .....                                       | 1357 |
| 6-177. Register Call Summary for Register CCP2_LCx_STAT_START .....    | 1357 |
| 6-178. CCP2_LCx_STAT_SIZE.....                                         | 1357 |
| 6-179. Register Call Summary for Register CCP2_LCx_STAT_SIZE .....     | 1358 |
| 6-180. CCP2_LCx_SOF_ADDR .....                                         | 1358 |
| 6-181. Register Call Summary for Register CCP2_LCx_SOF_ADDR.....       | 1358 |
| 6-182. CCP2_LCx_EOF_ADDR .....                                         | 1359 |
| 6-183. Register Call Summary for Register CCP2_LCx_EOF_ADDR.....       | 1359 |
| 6-184. CCP2_LCx_DAT_START .....                                        | 1359 |
| 6-185. Register Call Summary for Register CCP2_LCx_DAT_START.....      | 1359 |
| 6-186. CCP2_LCx_DAT_SIZE .....                                         | 1360 |
| 6-187. Register Call Summary for Register CCP2_LCx_DAT_SIZE.....       | 1360 |
| 6-188. CCP2_LCx_DAT_PING_ADDR .....                                    | 1360 |
| 6-189. Register Call Summary for Register CCP2_LCx_DAT_PING_ADDR ..... | 1360 |
| 6-190. CCP2_LCx_DAT_PONG_ADDR .....                                    | 1361 |
| 6-191. Register Call Summary for Register CCP2_LCx_DAT_PONG_ADDR.....  | 1361 |
| 6-192. CCP2_LCx_DAT_OFST .....                                         | 1361 |
| 6-193. Register Call Summary for Register CCP2_LCx_DAT_OFST .....      | 1362 |
| 6-194. CCP2_LCM_CTRL .....                                             | 1362 |
| 6-195. Register Call Summary for Register CCP2_LCM_CTRL.....           | 1363 |
| 6-196. CCP2_LCM_VSIZE .....                                            | 1364 |
| 6-197. Register Call Summary for Register CCP2_LCM_VSIZE .....         | 1364 |
| 6-198. CCP2_LCM_HSIZE .....                                            | 1364 |
| 6-199. Register Call Summary for Register CCP2_LCM_HSIZE .....         | 1364 |
| 6-200. CCP2_LCM_PREFETCH.....                                          | 1365 |
| 6-201. Register Call Summary for Register CCP2_LCM_PREFETCH .....      | 1365 |
| 6-202. CCP2_LCM_SRC_ADDR .....                                         | 1365 |
| 6-203. Register Call Summary for Register CCP2_LCM_SRC_ADDR .....      | 1366 |
| 6-204. CCP2_LCM_SRC_OFST.....                                          | 1366 |
| 6-205. Register Call Summary for Register CCP2_LCM_SRC_OFST .....      | 1366 |
| 6-206. CCP2_LCM_DST_ADDR.....                                          | 1366 |
| 6-207. Register Call Summary for Register CCP2_LCM_DST_ADDR .....      | 1367 |
| 6-208. CCP2_LCM_DST_OFST .....                                         | 1367 |
| 6-209. Register Call Summary for Register CCP2_LCM_DST_OFST.....       | 1367 |
| 6-210. ISP_CCDC Register Summary .....                                 | 1367 |
| 6-211. CCDC_PID .....                                                  | 1368 |
| 6-212. Register Call Summary for Register CCDC_PID.....                | 1369 |
| 6-213. CCDC_PCR .....                                                  | 1369 |
| 6-214. Register Call Summary for Register CCDC_PCR .....               | 1369 |
| 6-215. CCDC_SYN_MODE.....                                              | 1369 |
| 6-216. Register Call Summary for Register CCDC_SYN_MODE .....          | 1372 |

---

|                                                                 |      |
|-----------------------------------------------------------------|------|
| 6-217. CCDC_HD_VD_WID .....                                     | 1372 |
| 6-218. Register Call Summary for Register CCDC_HD_VD_WID .....  | 1372 |
| 6-219. CCDC_PIX_LINES .....                                     | 1373 |
| 6-220. Register Call Summary for Register CCDC_PIX_LINES.....   | 1373 |
| 6-221. CCDC_HORZ_INFO .....                                     | 1373 |
| 6-222. Register Call Summary for Register CCDC_HORZ_INFO.....   | 1374 |
| 6-223. CCDC_VERT_START .....                                    | 1374 |
| 6-224. Register Call Summary for Register CCDC_VERT_START.....  | 1375 |
| 6-225. CCDC_VERT_LINES .....                                    | 1375 |
| 6-226. Register Call Summary for Register CCDC_VERT_LINES.....  | 1375 |
| 6-227. CCDC_CULLING .....                                       | 1375 |
| 6-228. Register Call Summary for Register CCDC_CULLING.....     | 1376 |
| 6-229. CCDC_HSIZE_OFF .....                                     | 1376 |
| 6-230. Register Call Summary for Register CCDC_HSIZE_OFF .....  | 1376 |
| 6-231. CCDC_SDOFST .....                                        | 1377 |
| 6-232. Register Call Summary for Register CCDC_SDOFST .....     | 1378 |
| 6-233. CCDC_SDR_ADDR .....                                      | 1379 |
| 6-234. Register Call Summary for Register CCDC_SDR_ADDR .....   | 1379 |
| 6-235. CCDC_CLAMP .....                                         | 1379 |
| 6-236. Register Call Summary for Register CCDC_CLAMP .....      | 1380 |
| 6-237. CCDC_DCSUB .....                                         | 1380 |
| 6-238. Register Call Summary for Register CCDC_DCSUB.....       | 1381 |
| 6-239. CCDC_COLPTN.....                                         | 1381 |
| 6-240. Register Call Summary for Register CCDC_COLPTN .....     | 1383 |
| 6-241. CCDC_BLKCMP .....                                        | 1383 |
| 6-242. Register Call Summary for Register CCDC_BLKCMP .....     | 1384 |
| 6-243. CCDC_FPC .....                                           | 1384 |
| 6-244. Register Call Summary for Register CCDC_FPC.....         | 1385 |
| 6-245. CCDC_FPC_ADDR .....                                      | 1385 |
| 6-246. Register Call Summary for Register CCDC_FPC_ADDR.....    | 1386 |
| 6-247. CCDC_VDINT.....                                          | 1386 |
| 6-248. Register Call Summary for Register CCDC_VDINT .....      | 1386 |
| 6-249. CCDC_ALAW .....                                          | 1387 |
| 6-250. Register Call Summary for Register CCDC_ALAW.....        | 1387 |
| 6-251. CCDC_REC656IF .....                                      | 1387 |
| 6-252. Register Call Summary for Register CCDC_REC656IF.....    | 1388 |
| 6-253. CCDC_CFG .....                                           | 1388 |
| 6-254. Register Call Summary for Register CCDC_CFG .....        | 1389 |
| 6-255. CCDC_FMTCFG .....                                        | 1390 |
| 6-256. Register Call Summary for Register CCDC_FMTCFG .....     | 1391 |
| 6-257. CCDC_FMT_HORZ .....                                      | 1391 |
| 6-258. Register Call Summary for Register CCDC_FMT_HORZ.....    | 1391 |
| 6-259. CCDC_FMT_VERT .....                                      | 1392 |
| 6-260. Register Call Summary for Register CCDC_FMT_VERT .....   | 1392 |
| 6-261. CCDC_FMT_ADDR_i.....                                     | 1392 |
| 6-262. Register Call Summary for Register CCDC_FMT_ADDR_i ..... | 1393 |
| 6-263. CCDC_PRGEVEN0 .....                                      | 1393 |
| 6-264. Register Call Summary for Register CCDC_PRGEVEN0.....    | 1394 |
| 6-265. CCDC_PRGEVEN1 .....                                      | 1394 |

|                                                                       |      |
|-----------------------------------------------------------------------|------|
| 6-266. Register Call Summary for Register CCDC_PRGEVEN1.....          | 1394 |
| 6-267. CCDC_PRGODD0 .....                                             | 1395 |
| 6-268. Register Call Summary for Register CCDC_PRGODD0.....           | 1395 |
| 6-269. CCDC_PRGODD1 .....                                             | 1395 |
| 6-270. Register Call Summary for Register CCDC_PRGODD1.....           | 1396 |
| 6-271. CCDC_VP_OUT .....                                              | 1396 |
| 6-272. Register Call Summary for Register CCDC_VP_OUT .....           | 1397 |
| 6-273. CCDC_LSC_CONFIG .....                                          | 1397 |
| 6-274. Register Call Summary for Register CCDC_LSC_CONFIG .....       | 1398 |
| 6-275. CCDC_LSC_INITIAL.....                                          | 1399 |
| 6-276. Register Call Summary for Register CCDC_LSC_INITIAL .....      | 1399 |
| 6-277. CCDC_LSC_TABLE_BASE.....                                       | 1399 |
| 6-278. Register Call Summary for Register CCDC_LSC_TABLE_BASE .....   | 1399 |
| 6-279. CCDC_LSC_TABLE_OFFSET .....                                    | 1400 |
| 6-280. Register Call Summary for Register CCDC_LSC_TABLE_OFFSET ..... | 1400 |
| 6-281. ISP_HIST Register Summary.....                                 | 1400 |
| 6-282. HIST_PID .....                                                 | 1401 |
| 6-283. Register Call Summary for Register HIST_PID .....              | 1401 |
| 6-284. HIST_PCR.....                                                  | 1401 |
| 6-285. Register Call Summary for Register HIST_PCR .....              | 1401 |
| 6-286. HIST_CNT.....                                                  | 1402 |
| 6-287. Register Call Summary for Register HIST_CNT .....              | 1402 |
| 6-288. HIST_WB_GAIN .....                                             | 1403 |
| 6-289. Register Call Summary for Register HIST_WB_GAIN .....          | 1403 |
| 6-290. HIST_Rn_HORZ.....                                              | 1403 |
| 6-291. Register Call Summary for Register HIST_Rn_HORZ .....          | 1404 |
| 6-292. HIST_Rn_VERT .....                                             | 1404 |
| 6-293. Register Call Summary for Register HIST_Rn_VERT.....           | 1404 |
| 6-294. HIST_ADDR.....                                                 | 1404 |
| 6-295. Register Call Summary for Register HIST_ADDR .....             | 1405 |
| 6-296. HIST_DATA .....                                                | 1405 |
| 6-297. Register Call Summary for Register HIST_DATA.....              | 1405 |
| 6-298. HIST_RADD.....                                                 | 1405 |
| 6-299. Register Call Summary for Register HIST_RADD .....             | 1406 |
| 6-300. HIST_RADD_OFF .....                                            | 1406 |
| 6-301. Register Call Summary for Register HIST_RADD_OFF .....         | 1406 |
| 6-302. HIST_H_V_INFO .....                                            | 1406 |
| 6-303. Register Call Summary for Register HIST_H_V_INFO.....          | 1407 |
| 6-304. ISP_H3A Register Summary.....                                  | 1407 |
| 6-305. H3A_PID .....                                                  | 1408 |
| 6-306. Register Call Summary for Register H3A_PID .....               | 1408 |
| 6-307. H3A_PCR.....                                                   | 1408 |
| 6-308. Register Call Summary for Register H3A_PCR .....               | 1409 |
| 6-309. H3A_AFPAX1 .....                                               | 1409 |
| 6-310. Register Call Summary for Register H3A_AFPAX1 .....            | 1410 |
| 6-311. H3A_AFPAX2 .....                                               | 1410 |
| 6-312. Register Call Summary for Register H3A_AFPAX2 .....            | 1410 |
| 6-313. H3A_AFPAXSTART.....                                            | 1411 |
| 6-314. Register Call Summary for Register H3A_AFPAXSTART .....        | 1411 |

---

|                                                                 |      |
|-----------------------------------------------------------------|------|
| 6-315. H3A_AFIIRSH.....                                         | 1411 |
| 6-316. Register Call Summary for Register H3A_AFIIRSH .....     | 1411 |
| 6-317. H3A_AFBUFST .....                                        | 1412 |
| 6-318. Register Call Summary for Register H3A_AFBUFST .....     | 1412 |
| 6-319. H3A_AFCEOEF010.....                                      | 1412 |
| 6-320. Register Call Summary for Register H3A_AFCEOEF010 .....  | 1413 |
| 6-321. H3A_AFCEOEF032.....                                      | 1413 |
| 6-322. Register Call Summary for Register H3A_AFCEOEF032 .....  | 1413 |
| 6-323. H3A_AFCEOEF054.....                                      | 1413 |
| 6-324. Register Call Summary for Register H3A_AFCEOEF054 .....  | 1414 |
| 6-325. H3A_AFCEOEF076.....                                      | 1414 |
| 6-326. Register Call Summary for Register H3A_AFCEOEF076 .....  | 1414 |
| 6-327. H3A_AFCEOEF098.....                                      | 1414 |
| 6-328. Register Call Summary for Register H3A_AFCEOEF098 .....  | 1415 |
| 6-329. H3A_AFCEOEF0010 .....                                    | 1415 |
| 6-330. Register Call Summary for Register H3A_AFCEOEF0010 ..... | 1415 |
| 6-331. H3A_AFCEOEF110.....                                      | 1415 |
| 6-332. Register Call Summary for Register H3A_AFCEOEF110 .....  | 1416 |
| 6-333. H3A_AFCEOEF132.....                                      | 1416 |
| 6-334. Register Call Summary for Register H3A_AFCEOEF132 .....  | 1416 |
| 6-335. H3A_AFCEOEF154.....                                      | 1416 |
| 6-336. Register Call Summary for Register H3A_AFCEOEF154 .....  | 1417 |
| 6-337. H3A_AFCEOEF176.....                                      | 1417 |
| 6-338. Register Call Summary for Register H3A_AFCEOEF176 .....  | 1417 |
| 6-339. H3A_AFCEOEF198.....                                      | 1417 |
| 6-340. Register Call Summary for Register H3A_AFCEOEF198 .....  | 1418 |
| 6-341. H3A_AFCEOEF1010 .....                                    | 1418 |
| 6-342. Register Call Summary for Register H3A_AFCEOEF1010 ..... | 1418 |
| 6-343. H3A_AEWWIN1 .....                                        | 1418 |
| 6-344. Register Call Summary for Register H3A_AEWWIN1 .....     | 1419 |
| 6-345. H3A_AEWINSTART.....                                      | 1419 |
| 6-346. Register Call Summary for Register H3A_AEWINSTART .....  | 1419 |
| 6-347. H3A_AEWINBLK .....                                       | 1420 |
| 6-348. Register Call Summary for Register H3A_AEWINBLK.....     | 1420 |
| 6-349. H3A_AEWSUBWIN .....                                      | 1420 |
| 6-350. Register Call Summary for Register H3A_AEWSUBWIN.....    | 1421 |
| 6-351. H3A_AEWBUFST .....                                       | 1421 |
| 6-352. Register Call Summary for Register H3A_AEWBUFST .....    | 1421 |
| 6-353. ISP_PREVIEW Register Summary .....                       | 1421 |
| 6-354. PRV_PID .....                                            | 1422 |
| 6-355. Register Call Summary for Register PRV_PID .....         | 1423 |
| 6-356. PRV_PCR .....                                            | 1423 |
| 6-357. Register Call Summary for Register PRV_PCR .....         | 1425 |
| 6-358. PRV_HORZ_INFO .....                                      | 1426 |
| 6-359. Register Call Summary for Register PRV_HORZ_INFO .....   | 1426 |
| 6-360. PRV_VERT_INFO .....                                      | 1426 |
| 6-361. Register Call Summary for Register PRV_VERT_INFO .....   | 1427 |
| 6-362. PRV_RSDR_ADDR .....                                      | 1427 |
| 6-363. Register Call Summary for Register PRV_RSDR_ADDR .....   | 1427 |

|                                                                 |      |
|-----------------------------------------------------------------|------|
| 6-364. PRV_RADR_OFFSET .....                                    | 1428 |
| 6-365. Register Call Summary for Register PRV_RADR_OFFSET.....  | 1428 |
| 6-366. PRV_DSDR_ADDR .....                                      | 1428 |
| 6-367. Register Call Summary for Register PRV_DSDR_ADDR.....    | 1429 |
| 6-368. PRV_DRKF_OFFSET .....                                    | 1429 |
| 6-369. Register Call Summary for Register PRV_DRKF_OFFSET ..... | 1429 |
| 6-370. PRV_WSDR_ADDR.....                                       | 1429 |
| 6-371. Register Call Summary for Register PRV_WSDR_ADDR .....   | 1430 |
| 6-372. PRV_WADD_OFFSET.....                                     | 1430 |
| 6-373. Register Call Summary for Register PRV_WADD_OFFSET ..... | 1430 |
| 6-374. PRV_AVE.....                                             | 1431 |
| 6-375. Register Call Summary for Register PRV_AVE .....         | 1431 |
| 6-376. PRV_HMED .....                                           | 1432 |
| 6-377. Register Call Summary for Register PRV_HMED .....        | 1432 |
| 6-378. PRV_NF .....                                             | 1432 |
| 6-379. Register Call Summary for Register PRV_NF .....          | 1432 |
| 6-380. PRV_WB_DGAIN.....                                        | 1433 |
| 6-381. Register Call Summary for Register PRV_WB_DGAIN .....    | 1433 |
| 6-382. PRV_WBGAIN .....                                         | 1433 |
| 6-383. Register Call Summary for Register PRV_WBGAIN .....      | 1434 |
| 6-384. PRV_WBSEL .....                                          | 1434 |
| 6-385. Register Call Summary for Register PRV_WBSEL .....       | 1436 |
| 6-386. PRV_CFA.....                                             | 1436 |
| 6-387. Register Call Summary for Register PRV_CFA .....         | 1436 |
| 6-388. PRV_BLKADJOFF .....                                      | 1437 |
| 6-389. Register Call Summary for Register PRV_BLKADJOFF .....   | 1437 |
| 6-390. PRV_RGB_MAT1 .....                                       | 1437 |
| 6-391. Register Call Summary for Register PRV_RGB_MAT1 .....    | 1437 |
| 6-392. PRV_RGB_MAT2 .....                                       | 1438 |
| 6-393. Register Call Summary for Register PRV_RGB_MAT2 .....    | 1438 |
| 6-394. PRV_RGB_MAT3 .....                                       | 1438 |
| 6-395. Register Call Summary for Register PRV_RGB_MAT3 .....    | 1439 |
| 6-396. PRV_RGB_MAT4 .....                                       | 1439 |
| 6-397. Register Call Summary for Register PRV_RGB_MAT4 .....    | 1439 |
| 6-398. PRV_RGB_MAT5 .....                                       | 1439 |
| 6-399. Register Call Summary for Register PRV_RGB_MAT5 .....    | 1440 |
| 6-400. PRV_RGB_OFF1.....                                        | 1440 |
| 6-401. Register Call Summary for Register PRV_RGB_OFF1 .....    | 1440 |
| 6-402. PRV_RGB_OFF2.....                                        | 1440 |
| 6-403. Register Call Summary for Register PRV_RGB_OFF2 .....    | 1441 |
| 6-404. PRV_CSC0.....                                            | 1441 |
| 6-405. Register Call Summary for Register PRV_CSC0 .....        | 1441 |
| 6-406. PRV_CSC1.....                                            | 1442 |
| 6-407. Register Call Summary for Register PRV_CSC1 .....        | 1442 |
| 6-408. PRV_CSC2.....                                            | 1442 |
| 6-409. Register Call Summary for Register PRV_CSC2 .....        | 1443 |
| 6-410. PRV_CSC_OFFSET .....                                     | 1443 |
| 6-411. Register Call Summary for Register PRV_CSC_OFFSET.....   | 1443 |
| 6-412. PRV_CNT_BRT .....                                        | 1444 |

---

|                                                                  |      |
|------------------------------------------------------------------|------|
| 6-413. Register Call Summary for Register PRV_CNT_BRT .....      | 1444 |
| 6-414. PRV_CSUP .....                                            | 1444 |
| 6-415. Register Call Summary for Register PRV_CSUP .....         | 1445 |
| 6-416. PRV_SETUP_YC.....                                         | 1445 |
| 6-417. Register Call Summary for Register PRV_SETUP_YC .....     | 1445 |
| 6-418. PRV_SET_TBL_ADDR .....                                    | 1445 |
| 6-419. Register Call Summary for Register PRV_SET_TBL_ADDR.....  | 1446 |
| 6-420. PRV_SET_TBL_DATA.....                                     | 1446 |
| 6-421. Register Call Summary for Register PRV_SET_TBL_DATA ..... | 1446 |
| 6-422. PRV_CDC_THRx.....                                         | 1446 |
| 6-423. Register Call Summary for Register PRV_CDC_THRx .....     | 1447 |
| 6-424. ISP_RESIZER Register Summary .....                        | 1447 |
| 6-425. RSZ_PID.....                                              | 1448 |
| 6-426. Register Call Summary for Register RSZ_PID .....          | 1448 |
| 6-427. RSZ_PCR .....                                             | 1448 |
| 6-428. Register Call Summary for Register RSZ_PCR .....          | 1449 |
| 6-429. RSZ_CNT.....                                              | 1449 |
| 6-430. Register Call Summary for Register RSZ_CNT .....          | 1450 |
| 6-431. RSZ_OUT_SIZE .....                                        | 1451 |
| 6-432. Register Call Summary for Register RSZ_OUT_SIZE .....     | 1451 |
| 6-433. RSZ_IN_START .....                                        | 1451 |
| 6-434. Register Call Summary for Register RSZ_IN_START.....      | 1452 |
| 6-435. RSZ_IN_SIZE .....                                         | 1452 |
| 6-436. Register Call Summary for Register RSZ_IN_SIZE .....      | 1453 |
| 6-437. RSZ_SDR_INADD .....                                       | 1453 |
| 6-438. Register Call Summary for Register RSZ_SDR_INADD .....    | 1453 |
| 6-439. RSZ_SDR_INOFF .....                                       | 1453 |
| 6-440. Register Call Summary for Register RSZ_SDR_INOFF .....    | 1454 |
| 6-441. RSZ_SDR_OUTADD .....                                      | 1454 |
| 6-442. Register Call Summary for Register RSZ_SDR_OUTADD .....   | 1454 |
| 6-443. RSZ_SDR_OUTOFF .....                                      | 1455 |
| 6-444. Register Call Summary for Register RSZ_SDR_OUTOFF .....   | 1455 |
| 6-445. RSZ_HFILT10.....                                          | 1455 |
| 6-446. Register Call Summary for Register RSZ_HFILT10 .....      | 1456 |
| 6-447. RSZ_HFILT32.....                                          | 1456 |
| 6-448. Register Call Summary for Register RSZ_HFILT32 .....      | 1456 |
| 6-449. RSZ_HFILT54.....                                          | 1456 |
| 6-450. Register Call Summary for Register RSZ_HFILT54 .....      | 1457 |
| 6-451. RSZ_HFILT76.....                                          | 1457 |
| 6-452. Register Call Summary for Register RSZ_HFILT76 .....      | 1457 |
| 6-453. RSZ_HFILT98.....                                          | 1457 |
| 6-454. Register Call Summary for Register RSZ_HFILT98 .....      | 1457 |
| 6-455. RSZ_HFILT1110.....                                        | 1458 |
| 6-456. Register Call Summary for Register RSZ_HFILT1110 .....    | 1458 |
| 6-457. RSZ_HFILT1312.....                                        | 1458 |
| 6-458. Register Call Summary for Register RSZ_HFILT1312 .....    | 1458 |
| 6-459. RSZ_HFILT1514.....                                        | 1459 |
| 6-460. Register Call Summary for Register RSZ_HFILT1514 .....    | 1459 |
| 6-461. RSZ_HFILT1716.....                                        | 1459 |

|                                                               |      |
|---------------------------------------------------------------|------|
| 6-462. Register Call Summary for Register RSZ_HFILT1716 ..... | 1459 |
| 6-463. RSZ_HFILT1918.....                                     | 1460 |
| 6-464. Register Call Summary for Register RSZ_HFILT1918 ..... | 1460 |
| 6-465. RSZ_HFILT2120.....                                     | 1460 |
| 6-466. Register Call Summary for Register RSZ_HFILT2120 ..... | 1460 |
| 6-467. RSZ_HFILT2322.....                                     | 1461 |
| 6-468. Register Call Summary for Register RSZ_HFILT2322 ..... | 1461 |
| 6-469. RSZ_HFILT2524.....                                     | 1461 |
| 6-470. Register Call Summary for Register RSZ_HFILT2524 ..... | 1461 |
| 6-471. RSZ_HFILT2726.....                                     | 1462 |
| 6-472. Register Call Summary for Register RSZ_HFILT2726 ..... | 1462 |
| 6-473. RSZ_HFILT2928.....                                     | 1462 |
| 6-474. Register Call Summary for Register RSZ_HFILT2928 ..... | 1462 |
| 6-475. RSZ_HFILT3130.....                                     | 1463 |
| 6-476. Register Call Summary for Register RSZ_HFILT3130 ..... | 1463 |
| 6-477. RSZ_VFILT10.....                                       | 1463 |
| 6-478. Register Call Summary for Register RSZ_VFILT10 .....   | 1463 |
| 6-479. RSZ_VFILT32.....                                       | 1464 |
| 6-480. Register Call Summary for Register RSZ_VFILT32 .....   | 1464 |
| 6-481. RSZ_VFILT54.....                                       | 1464 |
| 6-482. Register Call Summary for Register RSZ_VFILT54 .....   | 1464 |
| 6-483. RSZ_VFILT76.....                                       | 1465 |
| 6-484. Register Call Summary for Register RSZ_VFILT76 .....   | 1465 |
| 6-485. RSZ_VFILT98.....                                       | 1465 |
| 6-486. Register Call Summary for Register RSZ_VFILT98 .....   | 1465 |
| 6-487. RSZ_VFILT1110.....                                     | 1466 |
| 6-488. Register Call Summary for Register RSZ_VFILT1110 ..... | 1466 |
| 6-489. RSZ_VFILT1312.....                                     | 1466 |
| 6-490. Register Call Summary for Register RSZ_VFILT1312 ..... | 1466 |
| 6-491. RSZ_VFILT1514.....                                     | 1467 |
| 6-492. Register Call Summary for Register RSZ_VFILT1514 ..... | 1467 |
| 6-493. RSZ_VFILT1716.....                                     | 1467 |
| 6-494. Register Call Summary for Register RSZ_VFILT1716 ..... | 1467 |
| 6-495. RSZ_VFILT1918.....                                     | 1468 |
| 6-496. Register Call Summary for Register RSZ_VFILT1918 ..... | 1468 |
| 6-497. RSZ_VFILT2120.....                                     | 1468 |
| 6-498. Register Call Summary for Register RSZ_VFILT2120 ..... | 1468 |
| 6-499. RSZ_VFILT2322.....                                     | 1469 |
| 6-500. Register Call Summary for Register RSZ_VFILT2322 ..... | 1469 |
| 6-501. RSZ_VFILT2524.....                                     | 1469 |
| 6-502. Register Call Summary for Register RSZ_VFILT2524 ..... | 1469 |
| 6-503. RSZ_VFILT2726.....                                     | 1470 |
| 6-504. Register Call Summary for Register RSZ_VFILT2726 ..... | 1470 |
| 6-505. RSZ_VFILT2928.....                                     | 1470 |
| 6-506. Register Call Summary for Register RSZ_VFILT2928 ..... | 1470 |
| 6-507. RSZ_VFILT3130.....                                     | 1471 |
| 6-508. Register Call Summary for Register RSZ_VFILT3130 ..... | 1471 |
| 6-509. RSZ_YENH.....                                          | 1471 |
| 6-510. Register Call Summary for Register RSZ_YENH .....      | 1472 |

---

|                                                                  |      |
|------------------------------------------------------------------|------|
| 6-511. ISP_SBL Register Mapping Summary.....                     | 1472 |
| 6-512. SBL_PID .....                                             | 1473 |
| 6-513. Register Call Summary for Register SBL_PID .....          | 1474 |
| 6-514. SBL_PCR.....                                              | 1474 |
| 6-515. Register Call Summary for Register SBL_PCR .....          | 1476 |
| 6-516. SBL_GLB_REG_0.....                                        | 1476 |
| 6-517. Register Call Summary for Register SBL_GLB_REG_0 .....    | 1477 |
| 6-518. SBL_GLB_REG_1.....                                        | 1477 |
| 6-519. Register Call Summary for Register SBL_GLB_REG_1 .....    | 1478 |
| 6-520. SBL_GLB_REG_2.....                                        | 1478 |
| 6-521. Register Call Summary for Register SBL_GLB_REG_2 .....    | 1479 |
| 6-522. SBL_GLB_REG_3.....                                        | 1479 |
| 6-523. Register Call Summary for Register SBL_GLB_REG_3 .....    | 1480 |
| 6-524. SBL_GLB_REG_4.....                                        | 1480 |
| 6-525. Register Call Summary for Register SBL_GLB_REG_4 .....    | 1481 |
| 6-526. SBL_GLB_REG_5.....                                        | 1481 |
| 6-527. Register Call Summary for Register SBL_GLB_REG_5 .....    | 1482 |
| 6-528. SBL_GLB_REG_6.....                                        | 1482 |
| 6-529. Register Call Summary for Register SBL_GLB_REG_6 .....    | 1483 |
| 6-530. SBL_GLB_REG_7.....                                        | 1483 |
| 6-531. Register Call Summary for Register SBL_GLB_REG_7 .....    | 1484 |
| 6-532. SBL_CCDC_WR_0.....                                        | 1484 |
| 6-533. Register Call Summary for Register SBL_CCDC_WR_0 .....    | 1485 |
| 6-534. SBL_CCDC_WR_1.....                                        | 1485 |
| 6-535. Register Call Summary for Register SBL_CCDC_WR_1 .....    | 1485 |
| 6-536. SBL_CCDC_WR_2.....                                        | 1486 |
| 6-537. Register Call Summary for Register SBL_CCDC_WR_2 .....    | 1486 |
| 6-538. SBL_CCDC_WR_3.....                                        | 1486 |
| 6-539. Register Call Summary for Register SBL_CCDC_WR_3 .....    | 1487 |
| 6-540. SBL_CCDC_FP_RD_0 .....                                    | 1487 |
| 6-541. Register Call Summary for Register SBL_CCDC_FP_RD_0 ..... | 1487 |
| 6-542. SBL_CCDC_FP_RD_1 .....                                    | 1488 |
| 6-543. Register Call Summary for Register SBL_CCDC_FP_RD_1 ..... | 1488 |
| 6-544. SBL_PRV_RD_0 .....                                        | 1488 |
| 6-545. Register Call Summary for Register SBL_PRV_RD_0 .....     | 1489 |
| 6-546. SBL_PRV_RD_1 .....                                        | 1489 |
| 6-547. Register Call Summary for Register SBL_PRV_RD_1 .....     | 1489 |
| 6-548. SBL_PRV_RD_2 .....                                        | 1490 |
| 6-549. Register Call Summary for Register SBL_PRV_RD_2 .....     | 1490 |
| 6-550. SBL_PRV_RD_3 .....                                        | 1490 |
| 6-551. Register Call Summary for Register SBL_PRV_RD_3 .....     | 1491 |
| 6-552. SBL_PRV_WR_0 .....                                        | 1491 |
| 6-553. Register Call Summary for Register SBL_PRV_WR_0 .....     | 1491 |
| 6-554. SBL_PRV_WR_1 .....                                        | 1492 |
| 6-555. Register Call Summary for Register SBL_PRV_WR_1 .....     | 1492 |
| 6-556. SBL_PRV_WR_2 .....                                        | 1492 |
| 6-557. Register Call Summary for Register SBL_PRV_WR_2 .....     | 1493 |
| 6-558. SBL_PRV_WR_3 .....                                        | 1493 |
| 6-559. Register Call Summary for Register SBL_PRV_WR_3 .....     | 1493 |

|                                                                |      |
|----------------------------------------------------------------|------|
| 6-560. SBL_PRV_DK_RD_0 .....                                   | 1493 |
| 6-561. Register Call Summary for Register SBL_PRV_DK_RD_0..... | 1494 |
| 6-562. SBL_PRV_DK_RD_1 .....                                   | 1494 |
| 6-563. Register Call Summary for Register SBL_PRV_DK_RD_1..... | 1495 |
| 6-564. SBL_PRV_DK_RD_2 .....                                   | 1495 |
| 6-565. Register Call Summary for Register SBL_PRV_DK_RD_2..... | 1495 |
| 6-566. SBL_PRV_DK_RD_3 .....                                   | 1496 |
| 6-567. Register Call Summary for Register SBL_PRV_DK_RD_3..... | 1496 |
| 6-568. SBL_RSZ_RD_0.....                                       | 1496 |
| 6-569. Register Call Summary for Register SBL_RSZ_RD_0 .....   | 1497 |
| 6-570. SBL_RSZ_RD_1.....                                       | 1497 |
| 6-571. Register Call Summary for Register SBL_RSZ_RD_1 .....   | 1497 |
| 6-572. SBL_RSZ_RD_2.....                                       | 1498 |
| 6-573. Register Call Summary for Register SBL_RSZ_RD_2 .....   | 1498 |
| 6-574. SBL_RSZ_RD_3.....                                       | 1498 |
| 6-575. Register Call Summary for Register SBL_RSZ_RD_3 .....   | 1499 |
| 6-576. SBL_RSZ1_WR_0 .....                                     | 1499 |
| 6-577. Register Call Summary for Register SBL_RSZ1_WR_0 .....  | 1499 |
| 6-578. SBL_RSZ1_WR_1 .....                                     | 1500 |
| 6-579. Register Call Summary for Register SBL_RSZ1_WR_1 .....  | 1500 |
| 6-580. SBL_RSZ1_WR_2 .....                                     | 1500 |
| 6-581. Register Call Summary for Register SBL_RSZ1_WR_2 .....  | 1501 |
| 6-582. SBL_RSZ1_WR_3 .....                                     | 1501 |
| 6-583. Register Call Summary for Register SBL_RSZ1_WR_3 .....  | 1501 |
| 6-584. SBL_RSZ2_WR_0 .....                                     | 1501 |
| 6-585. Register Call Summary for Register SBL_RSZ2_WR_0 .....  | 1502 |
| 6-586. SBL_RSZ2_WR_1 .....                                     | 1502 |
| 6-587. Register Call Summary for Register SBL_RSZ2_WR_1 .....  | 1503 |
| 6-588. SBL_RSZ2_WR_2 .....                                     | 1503 |
| 6-589. Register Call Summary for Register SBL_RSZ2_WR_2 .....  | 1503 |
| 6-590. SBL_RSZ2_WR_3 .....                                     | 1503 |
| 6-591. Register Call Summary for Register SBL_RSZ2_WR_3 .....  | 1504 |
| 6-592. SBL_RSZ3_WR_0 .....                                     | 1504 |
| 6-593. Register Call Summary for Register SBL_RSZ3_WR_0 .....  | 1504 |
| 6-594. SBL_RSZ3_WR_1 .....                                     | 1505 |
| 6-595. Register Call Summary for Register SBL_RSZ3_WR_1 .....  | 1505 |
| 6-596. SBL_RSZ3_WR_2 .....                                     | 1505 |
| 6-597. Register Call Summary for Register SBL_RSZ3_WR_2 .....  | 1506 |
| 6-598. SBL_RSZ3_WR_3 .....                                     | 1506 |
| 6-599. Register Call Summary for Register SBL_RSZ3_WR_3 .....  | 1506 |
| 6-600. SBL_RSZ4_WR_0 .....                                     | 1506 |
| 6-601. Register Call Summary for Register SBL_RSZ4_WR_0 .....  | 1507 |
| 6-602. SBL_RSZ4_WR_1 .....                                     | 1507 |
| 6-603. Register Call Summary for Register SBL_RSZ4_WR_1 .....  | 1508 |
| 6-604. SBL_RSZ4_WR_2 .....                                     | 1508 |
| 6-605. Register Call Summary for Register SBL_RSZ4_WR_2 .....  | 1508 |
| 6-606. SBL_RSZ4_WR_3 .....                                     | 1508 |
| 6-607. Register Call Summary for Register SBL_RSZ4_WR_3 .....  | 1509 |
| 6-608. SBL_HIST_RD_0.....                                      | 1509 |

---

|                                                                     |      |
|---------------------------------------------------------------------|------|
| 6-609. Register Call Summary for Register SBL_HIST_RD_0 .....       | 1509 |
| 6-610. SBL_HIST_RD_1 .....                                          | 1510 |
| 6-611. Register Call Summary for Register SBL_HIST_RD_1 .....       | 1510 |
| 6-612. SBL_H3A_AF_WR_0 .....                                        | 1510 |
| 6-613. Register Call Summary for Register SBL_H3A_AF_WR_0.....      | 1511 |
| 6-614. SBL_H3A_AF_WR_1 .....                                        | 1511 |
| 6-615. Register Call Summary for Register SBL_H3A_AF_WR_1.....      | 1511 |
| 6-616. SBL_H3A_AEAWB_WR_0 .....                                     | 1512 |
| 6-617. Register Call Summary for Register SBL_H3A_AEAWB_WR_0 .....  | 1512 |
| 6-618. SBL_H3A_AEAWB_WR_1 .....                                     | 1512 |
| 6-619. Register Call Summary for Register SBL_H3A_AEAWB_WR_1 .....  | 1513 |
| 6-620. SBL_CSIA_WR_0 .....                                          | 1513 |
| 6-621. Register Call Summary for Register SBL_CSIA_WR_0.....        | 1513 |
| 6-622. SBL_CSIA_WR_1 .....                                          | 1513 |
| 6-623. Register Call Summary for Register SBL_CSIA_WR_1.....        | 1514 |
| 6-624. SBL_CSIA_WR_2 .....                                          | 1514 |
| 6-625. Register Call Summary for Register SBL_CSIA_WR_2.....        | 1515 |
| 6-626. SBL_CSIA_WR_3 .....                                          | 1515 |
| 6-627. Register Call Summary for Register SBL_CSIA_WR_3.....        | 1515 |
| 6-628. SBL_CSIB_WR_0 .....                                          | 1515 |
| 6-629. Register Call Summary for Register SBL_CSIB_WR_0.....        | 1516 |
| 6-630. SBL_CSIB_WR_1 .....                                          | 1516 |
| 6-631. Register Call Summary for Register SBL_CSIB_WR_1.....        | 1516 |
| 6-632. SBL_CSIB_WR_2 .....                                          | 1517 |
| 6-633. Register Call Summary for Register SBL_CSIB_WR_2.....        | 1517 |
| 6-634. SBL_CSIB_WR_3 .....                                          | 1517 |
| 6-635. Register Call Summary for Register SBL_CSIB_WR_3.....        | 1518 |
| 6-636. SBL_SDR_REQ_EXP .....                                        | 1518 |
| 6-637. Register Call Summary for Register SBL_SDR_REQ_EXP .....     | 1518 |
| 6-638. CAMERA_ISP_CSI2_REGS1 Register Summary .....                 | 1519 |
| 6-639. CSI2_REVISION.....                                           | 1520 |
| 6-640. Register Call Summary for Register CSI2_REVISION .....       | 1520 |
| 6-641. CSI2_SYSCONFIG.....                                          | 1520 |
| 6-642. Register Call Summary for Register CSI2_SYSCONFIG .....      | 1521 |
| 6-643. CSI2_SYSSTATUS .....                                         | 1521 |
| 6-644. Register Call Summary for Register CSI2_SYSSTATUS .....      | 1521 |
| 6-645. CSI2_IRQSTATUS .....                                         | 1522 |
| 6-646. Register Call Summary for Register CSI2_IRQSTATUS.....       | 1523 |
| 6-647. CSI2_IRQENABLE .....                                         | 1524 |
| 6-648. Register Call Summary for Register CSI2_IRQENABLE.....       | 1525 |
| 6-649. CSI2_CTRL .....                                              | 1525 |
| 6-650. Register Call Summary for Register CSI2_CTRL.....            | 1527 |
| 6-651. CSI2_DBG_H .....                                             | 1527 |
| 6-652. Register Call Summary for Register CSI2_DBG_H.....           | 1527 |
| 6-653. CSI2_GNQ .....                                               | 1527 |
| 6-654. Register Call Summary for Register CSI2_GNQ .....            | 1528 |
| 6-655. CSI2_COMPLEXIO_CFG1.....                                     | 1528 |
| 6-656. Register Call Summary for Register CSI2_COMPLEXIO_CFG1 ..... | 1530 |
| 6-657. CSI2_COMPLEXIO1_IRQSTATUS .....                              | 1530 |

|                                                                                   |      |
|-----------------------------------------------------------------------------------|------|
| 6-658. Register Call Summary for Register CSI2_COMPLEXIO1_IRQSTATUS.....          | 1533 |
| 6-659. CSI2_SHORT_PACKET.....                                                     | 1533 |
| 6-660. Register Call Summary for Register CSI2_SHORT_PACKET .....                 | 1533 |
| 6-661. CSI2_COMPLEXIO1_IRQENABLE .....                                            | 1534 |
| 6-662. Register Call Summary for Register CSI2_COMPLEXIO1_IRQENABLE.....          | 1536 |
| 6-663. CSI2_DBG_P .....                                                           | 1536 |
| 6-664. Register Call Summary for Register CSI2_DBG_P .....                        | 1536 |
| 6-665. CSI2_TIMING .....                                                          | 1536 |
| 6-666. Register Call Summary for Register CSI2_TIMING.....                        | 1537 |
| 6-667. CSI2_CTLx_CTRL1 .....                                                      | 1537 |
| 6-668. Register Call Summary for Register CSI2_CTLx_CTRL1 .....                   | 1540 |
| 6-669. CSI2_CTLx_CTRL2 .....                                                      | 1540 |
| 6-670. Register Call Summary for Register CSI2_CTLx_CTRL2 .....                   | 1543 |
| 6-671. CSI2_CTLx_DAT_OFST .....                                                   | 1544 |
| 6-672. Register Call Summary for Register CSI2_CTLx_DAT_OFST .....                | 1544 |
| 6-673. CSI2_CTLx_DAT_PING_ADDR .....                                              | 1544 |
| 6-674. Register Call Summary for Register CSI2_CTLx_DAT_PING_ADDR .....           | 1545 |
| 6-675. CSI2_CTLx_DAT_PONG_ADDR .....                                              | 1545 |
| 6-676. Register Call Summary for Register CSI2_CTLx_DAT_PONG_ADDR.....            | 1545 |
| 6-677. CSI2_CTLx_IRQENABLE.....                                                   | 1545 |
| 6-678. Register Call Summary for Register CSI2_CTLx_IRQENABLE .....               | 1546 |
| 6-679. CSI2_CTLx_IRQSTATUS.....                                                   | 1547 |
| 6-680. Register Call Summary for Register CSI2_CTLx_IRQSTATUS .....               | 1548 |
| 6-681. CSI2_CTLx_CTRL3 .....                                                      | 1548 |
| 6-682. Register Call Summary for Register CSI2_CTLx_CTRL3 .....                   | 1548 |
| 6-683. CAMERA_ISP_CSI2_REGS2 Registers Mapping Summary.....                       | 1549 |
| 6-684. CSI2_CTLx_TRANSCODEH .....                                                 | 1549 |
| 6-685. Register Call Summary for Register CSI2_CTLx_TRANSCODEH.....               | 1549 |
| 6-686. CSI2_CTLx_TRANSCODEV .....                                                 | 1550 |
| 6-687. Register Call Summary for Register CSI2_CTLx_TRANSCODEV .....              | 1550 |
| 6-688. CAMERA_ISP_CSIPHY Registers Mapping Summary.....                           | 1550 |
| 6-689. CSIPHY_REG0 .....                                                          | 1551 |
| 6-690. Register Call Summary for Register CSIPHY_REG0.....                        | 1551 |
| 6-691. CSIPHY_REG1 .....                                                          | 1552 |
| 6-692. Register Call Summary for Register CSIPHY_REG1.....                        | 1553 |
| 6-693. CSIPHY_REG2 .....                                                          | 1553 |
| 6-694. Register Call Summary for Register CSIPHY_REG2.....                        | 1553 |
| 7-1. LCD Interface Signals and Configurations .....                               | 1562 |
| 7-2. I/O Pad Mode Selection .....                                                 | 1565 |
| 7-3. LCD Interface Signals (RFBI Mode) .....                                      | 1566 |
| 7-4. LCD Interface Signals (Bypass Mode).....                                     | 1568 |
| 7-5. Number of Displayed Pixels per Pixel Clock Cycle Based on Display Type ..... | 1569 |
| 7-6. Programmable Timing Fields in RFBI Mode .....                                | 1574 |
| 7-7. Programmable Fields in Bypass Mode .....                                     | 1575 |
| 7-8. I/O Description for DSI Serial Interface.....                                | 1581 |
| 7-9. DSI Lane Configuration .....                                                 | 1582 |
| 7-10. Video Interface for DSI Protocol Engine.....                                | 1583 |
| 7-11. Video Interface in the Context of Video Mode .....                          | 1584 |
| 7-12. Video Interface in the Context of Command Mode .....                        | 1589 |

---

|       |                                                                                      |      |
|-------|--------------------------------------------------------------------------------------|------|
| 7-13. | Pixel Data Format in Video Mode .....                                                | 1596 |
| 7-14. | Synchronization Codes .....                                                          | 1596 |
| 7-15. | Sync Short Packet Values.....                                                        | 1597 |
| 7-16. | Virtual Channel Values .....                                                         | 1604 |
| 7-17. | TV Display Interface Pins .....                                                      | 1611 |
| 7-18. | Typical values for Rout, Rset and Cout .....                                         | 1611 |
| 7-19. | Display Subsystem Clocks .....                                                       | 1616 |
| 7-20. | Possible Digital Clock Division for the Video Encoder.....                           | 1618 |
| 7-21. | DSS DMA Requests Description .....                                                   | 1624 |
| 7-22. | Display Subsystem Interrupts.....                                                    | 1626 |
| 7-23. | DSI Global Interrupts.....                                                           | 1627 |
| 7-24. | DSI Complex I/O Interrupts .....                                                     | 1628 |
| 7-25. | DSI Virtual Channel Interrupts .....                                                 | 1629 |
| 7-26. | Functional Clock Frequency Requirement in RGB16 YUV4:2:2—Active Matrix Display ..... | 1643 |
| 7-27. | Functional Clock Frequency Requirement in RGB24—Active Matrix Display .....          | 1643 |
| 7-28. | Alpha Blending 4-Bit Values .....                                                    | 1649 |
| 7-29. | 8-Bit Interface Configuration/24-Bit Mode .....                                      | 1654 |
| 7-30. | Maximum Width Allowed .....                                                          | 1654 |
| 7-31. | LP to HS Timing Parameters .....                                                     | 1658 |
| 7-32. | LP to HS Timing Parameters Example for 400-MHz DDR Clock .....                       | 1659 |
| 7-33. | HS to LP Timing Parameters .....                                                     | 1661 |
| 7-34. | HS to LP Timing Parameters Example for 400-MHz DDR Clock and Two Data Lanes .....    | 1661 |
| 7-35. | Extra NULL Packet Header .....                                                       | 1662 |
| 7-36. | Extra NULL Packet Payload .....                                                      | 1663 |
| 7-37. | DSI PLL Operation Modes When Not Locked .....                                        | 1685 |
| 7-38. | 16-Bit Interface Configuration/24-Bit Mode .....                                     | 1688 |
| 7-39. | Read/Write Function Description .....                                                | 1689 |
| 7-40. | Minimum Cycle Time for CSx/WE Always Asserted .....                                  | 1689 |
| 7-41. | 100/100 Color Bar Table .....                                                        | 1690 |
| 7-42. | VENC_S_CARR Register Recommended Values .....                                        | 1691 |
| 7-43. | Closed-Caption Data Format.....                                                      | 1692 |
| 7-44. | Closed-Caption Run Clock Frequency Settings .....                                    | 1693 |
| 7-45. | Closed-Caption Standard Timing Values.....                                           | 1693 |
| 7-46. | Wide-Screen Signaling Run Clock Frequency Settings .....                             | 1694 |
| 7-47. | Analog TV Output Control .....                                                       | 1696 |
| 7-48. | Video DAC Stage Power Management.....                                                | 1704 |
| 7-49. | Shadow Registers .....                                                               | 1706 |
| 7-50. | Vertical/Horizontal Accumulator Phase .....                                          | 1716 |
| 7-51. | Color Space Conversion Register Values.....                                          | 1717 |
| 7-52. | 90-degree DMA Rotation Example Description .....                                     | 1719 |
| 7-53. | DMA Rotation Register Settings.....                                                  | 1721 |
| 7-54. | Video Rotation Register Settings (With RGB24 Packet Format).....                     | 1722 |
| 7-55. | Register Settings for DMA Rotation With Mirroring .....                              | 1723 |
| 7-56. | VRFB Rotation - DMA Settings .....                                                   | 1723 |
| 7-57. | VRFB Rotation With Mirroring - DMA Settings .....                                    | 1725 |
| 7-58. | Video Rotation Register Settings (YUV Only) .....                                    | 1726 |
| 7-59. | Video Rotation With Mirroring Register Settings (YUV only) .....                     | 1727 |
| 7-60. | Programming Rules .....                                                              | 1729 |
| 7-61. | Pixel Clock Frequency Limitations - RGB16 and YUV4:2:2 Active Matrix Display .....   | 1730 |

|        |                                                                                             |      |
|--------|---------------------------------------------------------------------------------------------|------|
| 7-62.  | Pixel Clock Frequency Limitations - RGB16 and YUV4:2:2 Passive Matrix Display - Mono4 ..... | 1730 |
| 7-63.  | Pixel Clock Frequency Limitations - RGB16 and YUV4:2:2 Passive Matrix Display - Mono8 ..... | 1730 |
| 7-64.  | Pixel Clock Frequency Limitations - RGB16 and YUV4:2:2 Passive Matrix Display - Color ..... | 1730 |
| 7-65.  | Register Access Width Limitations .....                                                     | 1738 |
| 7-66.  | Virtual Channel TX FIFO Size Values .....                                                   | 1743 |
| 7-67.  | Virtual Channel TX FIFO Start Address .....                                                 | 1743 |
| 7-68.  | Virtual Channel RX FIFO Size Values .....                                                   | 1744 |
| 7-69.  | Virtual Channel RX FIFO Start Address .....                                                 | 1744 |
| 7-70.  | Recommended Programming Values.....                                                         | 1757 |
| 7-71.  | RFBI Behavior .....                                                                         | 1765 |
| 7-72.  | RFBI Timings Configuration.....                                                             | 1769 |
| 7-73.  | Analog TV Output Modes .....                                                                | 1774 |
| 7-74.  | Video Encoder Register Programming Values .....                                             | 1775 |
| 7-75.  | Vertical FIR Coefficients Corresponding Table (3-Tap Configuration) .....                   | 1781 |
| 7-76.  | Vertical FIR Coefficients Corresponding Table (5-Tap Configuration) .....                   | 1782 |
| 7-77.  | Horizontal FIR Coefficients Corresponding Table (5-Tap Configuration) .....                 | 1782 |
| 7-78.  | Vertical/Horizontal Accumulator Phase .....                                                 | 1784 |
| 7-79.  | Up-Sampling Vertical Filter Coefficients (Three Taps) .....                                 | 1785 |
| 7-80.  | Up-Sampling Vertical Filter Coefficients (Five Taps) .....                                  | 1785 |
| 7-81.  | Up-Sampling Horizontal Filter Coefficients (Five Taps) .....                                | 1785 |
| 7-82.  | Down-Sampling Vertical Filter Coefficients (Three Taps).....                                | 1786 |
| 7-83.  | Down-Sampling Vertical Filter Coefficients (Five Taps) .....                                | 1787 |
| 7-84.  | Down-Sampling Horizontal Filter Coefficients (Five Taps) .....                              | 1787 |
| 7-85.  | Ratio R .....                                                                               | 1794 |
| 7-86.  | Main Steps .....                                                                            | 1797 |
| 7-87.  | PRCM Registers .....                                                                        | 1798 |
| 7-88.  | Resets.....                                                                                 | 1798 |
| 7-89.  | DSI PLL Configuration Registers.....                                                        | 1798 |
| 7-90.  | DSI Control Registers.....                                                                  | 1799 |
| 7-91.  | DSI Complex I/O Registers .....                                                             | 1800 |
| 7-92.  | DSI Timing Registers .....                                                                  | 1800 |
| 7-93.  | Calculate DSI_PHY Timing .....                                                              | 1801 |
| 7-94.  | Drive Stop State .....                                                                      | 1801 |
| 7-95.  | Reset DISPC.....                                                                            | 1802 |
| 7-96.  | Configure DISPC Registers .....                                                             | 1802 |
| 7-97.  | Configure Color Space Coefficient Registers.....                                            | 1802 |
| 7-98.  | Configure DISPC_CONTROL.....                                                                | 1803 |
| 7-99.  | Configure DISPC_VID1_ATTRIBUTES .....                                                       | 1803 |
| 7-100. | Enable DISPC.....                                                                           | 1803 |
| 7-101. | Main Sequence .....                                                                         | 1805 |
| 7-102. | Configure DSS Clocks at the PRCM Module .....                                               | 1805 |
| 7-103. | Configure DSI Protocol Engine, DSI PLL, and Complex I/O .....                               | 1805 |
| 7-104. | Reset DSI Modules.....                                                                      | 1806 |
| 7-105. | Configure DSI PLL .....                                                                     | 1806 |
| 7-106. | Switch to DSI PLL Clock Source .....                                                        | 1807 |
| 7-107. | DSI Control Registers.....                                                                  | 1807 |
| 7-108. | DSI Complex I/O Registers .....                                                             | 1807 |
| 7-109. | DSI Timing Registers .....                                                                  | 1808 |
| 7-110. | Configure DSI_PHY Timing .....                                                              | 1809 |

---

|                                                                      |      |
|----------------------------------------------------------------------|------|
| 7-111. Drive Stop State .....                                        | 1810 |
| 7-112. Initialization of the External MIPI LCD Controller .....      | 1810 |
| 7-113. Reset DISPC .....                                             | 1810 |
| 7-114. Configure DISPC Registers .....                               | 1811 |
| 7-115. Configure DISPC_CONTROL.....                                  | 1811 |
| 7-116. Enable Command Mode and Automatic TE .....                    | 1811 |
| 7-117. Send Frame Data to LCD Panel Using Automatic TE .....         | 1812 |
| 7-118. Display Subsystem Instance Summary.....                       | 1813 |
| 7-119. Display Subsystem Register Mapping Summary.....               | 1813 |
| 7-120. Display Controller Register Mapping Summary .....             | 1814 |
| 7-121. Display Controller VID1 Register Mapping Summary .....        | 1815 |
| 7-122. Display Controller VID2 Register Mapping Summary .....        | 1815 |
| 7-123. RFBI Register Mapping Summary .....                           | 1816 |
| 7-124. Video Encoder Register Mapping Summary.....                   | 1817 |
| 7-125. DSI Protocol Engine Register Mapping Summary .....            | 1818 |
| 7-126. DSI_PHY Register Mapping Summary .....                        | 1819 |
| 7-127. DSI PLL Controller Register Mapping Summary .....             | 1819 |
| 7-128. DSS_REVISIONNUMBER .....                                      | 1819 |
| 7-129. Register Call Summary for Register DSS_REVISIONNUMBER .....   | 1819 |
| 7-130. DSS_SYSCONFIG .....                                           | 1820 |
| 7-131. Register Call Summary for Register DSS_SYSCONFIG.....         | 1820 |
| 7-132. DSS_SYSSTATUS .....                                           | 1820 |
| 7-133. Register Call Summary for Register DSS_SYSSTATUS .....        | 1821 |
| 7-134. DSS_IRQSTATUS .....                                           | 1821 |
| 7-135. Register Call Summary for Register DSS_IRQSTATUS .....        | 1821 |
| 7-136. DSS_CONTROL.....                                              | 1821 |
| 7-137. Register Call Summary for Register DSS_CONTROL .....          | 1822 |
| 7-138. DSS_CLK_STATUS.....                                           | 1823 |
| 7-139. Register Call Summary for Register DSS_CLK_STATUS .....       | 1823 |
| 7-140. DISPC_REVISION .....                                          | 1824 |
| 7-141. Register Call Summary for Register DISPC_REVISION.....        | 1824 |
| 7-142. DISPC_SYSCONFIG .....                                         | 1824 |
| 7-143. Register Call Summary for Register DISPC_SYSCONFIG .....      | 1825 |
| 7-144. DISPC_SYSSTATUS .....                                         | 1825 |
| 7-145. Register Call Summary for Register DISPC_SYSSTATUS.....       | 1826 |
| 7-146. DISPC_IRQSTATUS.....                                          | 1826 |
| 7-147. Register Call Summary for Register DISPC_IRQSTATUS .....      | 1828 |
| 7-148. DISPC_IRQENABLE .....                                         | 1829 |
| 7-149. Register Call Summary for Register DISPC_IRQENABLE .....      | 1830 |
| 7-150. DISPC_CONTROL .....                                           | 1831 |
| 7-151. Register Call Summary for Register DISPC_CONTROL.....         | 1833 |
| 7-152. DISPC_CONFIG.....                                             | 1835 |
| 7-153. Register Call Summary for Register DISPC_CONFIG .....         | 1837 |
| 7-154. DISPC_DEFAULT_COLOR_m .....                                   | 1838 |
| 7-155. Register Call Summary for Register DISPC_DEFAULT_COLOR_m..... | 1838 |
| 7-156. DISPC_TRANS_COLOR_m .....                                     | 1838 |
| 7-157. Register Call Summary for Register DISPC_TRANS_COLOR_m.....   | 1839 |
| 7-158. DISPC_LINE_STATUS .....                                       | 1839 |
| 7-159. Register Call Summary for Register DISPC_LINE_STATUS.....     | 1839 |

|                                                                             |      |
|-----------------------------------------------------------------------------|------|
| 7-160. DISPC_LINE_NUMBER .....                                              | 1839 |
| 7-161. Register Call Summary for Register DISPC_LINE_NUMBER.....            | 1839 |
| 7-162. DISPC_TIMING_H .....                                                 | 1840 |
| 7-163. Register Call Summary for Register DISPC_TIMING_H.....               | 1840 |
| 7-164. DISPC_TIMING_V .....                                                 | 1840 |
| 7-165. Register Call Summary for Register DISPC_TIMING_V .....              | 1841 |
| 7-166. DISPC_POL_FREQ .....                                                 | 1841 |
| 7-167. Register Call Summary for Register DISPC_POL_FREQ .....              | 1842 |
| 7-168. DISPC_DIVISOR .....                                                  | 1842 |
| 7-169. Register Call Summary for Register DISPC_DIVISOR.....                | 1843 |
| 7-170. DISPC_GLOBAL_ALPHA .....                                             | 1843 |
| 7-171. Register Call Summary for Register DISPC_GLOBAL_ALPHA.....           | 1843 |
| 7-172. DISPC_SIZE_DIG .....                                                 | 1844 |
| 7-173. Register Call Summary for Register DISPC_SIZE_DIG .....              | 1844 |
| 7-174. DISPC_SIZE_LCD .....                                                 | 1844 |
| 7-175. Register Call Summary for Register DISPC_SIZE_LCD.....               | 1845 |
| 7-176. DISPC_GFX_BAj .....                                                  | 1845 |
| 7-177. Register Call Summary for Register DISPC_GFX_BAj .....               | 1845 |
| 7-178. DISPC_GFX_POSITION .....                                             | 1846 |
| 7-179. Register Call Summary for Register DISPC_GFX_POSITION.....           | 1846 |
| 7-180. DISPC_GFX_SIZE .....                                                 | 1846 |
| 7-181. Register Call Summary for Register DISPC_GFX_SIZE.....               | 1847 |
| 7-182. DISPC_GFX_ATTRIBUTES .....                                           | 1847 |
| 7-183. Register Call Summary for Register DISPC_GFX_ATTRIBUTES .....        | 1849 |
| 7-184. DISPC_GFX_FIFO_THRESHOLD .....                                       | 1849 |
| 7-185. Register Call Summary for Register DISPC_GFX_FIFO_THRESHOLD .....    | 1849 |
| 7-186. DISPC_GFX_FIFO_SIZE_STATUS .....                                     | 1850 |
| 7-187. Register Call Summary for Register DISPC_GFX_FIFO_SIZE_STATUS.....   | 1850 |
| 7-188. DISPC_GFX_ROW_INC .....                                              | 1850 |
| 7-189. Register Call Summary for Register DISPC_GFX_ROW_INC .....           | 1850 |
| 7-190. DISPC_GFX_PIXEL_INC .....                                            | 1851 |
| 7-191. Register Call Summary for Register DISPC_GFX_PIXEL_INC .....         | 1851 |
| 7-192. DISPC_GFX_WINDOW_SKIP.....                                           | 1851 |
| 7-193. Register Call Summary for Register DISPC_GFX_WINDOW_SKIP .....       | 1851 |
| 7-194. DISPC_GFX_TABLE_BA.....                                              | 1852 |
| 7-195. Register Call Summary for Register DISPC_GFX_TABLE_BA .....          | 1852 |
| 7-196. DISPC_VIDn_BAj.....                                                  | 1852 |
| 7-197. Register Call Summary for Register DISPC_VIDn_BAj .....              | 1852 |
| 7-198. DISPC_VIDn_POSITION .....                                            | 1853 |
| 7-199. Register Call Summary for Register DISPC_VIDn_POSITION .....         | 1853 |
| 7-200. DISPC_VIDn_SIZE .....                                                | 1853 |
| 7-201. Register Call Summary for Register DISPC_VIDn_SIZE .....             | 1854 |
| 7-202. DISPC_VIDn_ATTRIBUTES .....                                          | 1854 |
| 7-203. Register Call Summary for Register DISPC_VIDn_ATTRIBUTES .....       | 1857 |
| 7-204. DISPC_VIDn_FIFO_THRESHOLD .....                                      | 1858 |
| 7-205. Register Call Summary for Register DISPC_VIDn_FIFO_THRESHOLD .....   | 1858 |
| 7-206. DISPC_VIDn_FIFO_SIZE_STATUS .....                                    | 1858 |
| 7-207. Register Call Summary for Register DISPC_VIDn_FIFO_SIZE_STATUS ..... | 1858 |
| 7-208. DISPC_VIDn_ROW_INC .....                                             | 1859 |

|                                                                         |      |
|-------------------------------------------------------------------------|------|
| 7-209. Register Call Summary for Register DISPC_VIDn_ROW_INC.....       | 1859 |
| 7-210. DISPC_VIDn_PIXEL_INC .....                                       | 1859 |
| 7-211. Register Call Summary for Register DISPC_VIDn_PIXEL_INC .....    | 1860 |
| 7-212. DISPC_VIDn_FIR .....                                             | 1860 |
| 7-213. Register Call Summary for Register DISPC_VIDn_FIR .....          | 1860 |
| 7-214. DISPC_VIDn_PICTURE_SIZE .....                                    | 1861 |
| 7-215. Register Call Summary for Register DISPC_VIDn_PICTURE_SIZE ..... | 1861 |
| 7-216. DISPC_VIDn_ACCUI .....                                           | 1862 |
| 7-217. Register Call Summary for Register DISPC_VIDn_ACCUI .....        | 1862 |
| 7-218. DISPC_VIDn_FIR_COEF_Hi .....                                     | 1862 |
| 7-219. Register Call Summary for Register DISPC_VIDn_FIR_COEF_Hi.....   | 1863 |
| 7-220. DISPC_VIDn_FIR_COEF_HVi.....                                     | 1863 |
| 7-221. Register Call Summary for Register DISPC_VIDn_FIR_COEF_HVi ..... | 1863 |
| 7-222. DISPC_VIDn_CONV_COEF0 .....                                      | 1864 |
| 7-223. Register Call Summary for Register DISPC_VIDn_CONV_COEF0 .....   | 1864 |
| 7-224. DISPC_VIDn_CONV_COEF1 .....                                      | 1864 |
| 7-225. Register Call Summary for Register DISPC_VIDn_CONV_COEF1 .....   | 1865 |
| 7-226. DISPC_VIDn_CONV_COEF2 .....                                      | 1865 |
| 7-227. Register Call Summary for Register DISPC_VIDn_CONV_COEF2 .....   | 1865 |
| 7-228. DISPC_VIDn_CONV_COEF3 .....                                      | 1865 |
| 7-229. Register Call Summary for Register DISPC_VIDn_CONV_COEF3 .....   | 1866 |
| 7-230. DISPC_VIDn_CONV_COEF4 .....                                      | 1866 |
| 7-231. Register Call Summary for Register DISPC_VIDn_CONV_COEF4 .....   | 1866 |
| 7-232. DISPC_DATA_CYCLEk .....                                          | 1867 |
| 7-233. Register Call Summary for Register DISPC_DATA_CYCLEk .....       | 1867 |
| 7-234. DISPC_VIDn_FIR_COEF_Vi .....                                     | 1868 |
| 7-235. Register Call Summary for Register DISPC_VIDn_FIR_COEF_Vi .....  | 1868 |
| 7-236. DISPC_CPR_COEF_R .....                                           | 1868 |
| 7-237. Register Call Summary for Register DISPC_CPR_COEF_R .....        | 1869 |
| 7-238. DISPC_CPR_COEF_G .....                                           | 1869 |
| 7-239. Register Call Summary for Register DISPC_CPR_COEF_G .....        | 1869 |
| 7-240. DISPC_CPR_COEF_B .....                                           | 1869 |
| 7-241. Register Call Summary for Register DISPC_CPR_COEF_B .....        | 1870 |
| 7-242. DISPC_GFX_PRELOAD .....                                          | 1870 |
| 7-243. Register Call Summary for Register DISPC_GFX_PRELOAD .....       | 1870 |
| 7-244. DISPC_VIDn_PRELOAD .....                                         | 1871 |
| 7-245. Register Call Summary for Register DISPC_VIDn_PRELOAD .....      | 1871 |
| 7-246. RFBI_REVISION .....                                              | 1871 |
| 7-247. Register Call Summary for Register RFBI_REVISION .....           | 1871 |
| 7-248. RFBI_SYSCONFIG .....                                             | 1872 |
| 7-249. Register Call Summary for Register RFBI_SYSCONFIG .....          | 1872 |
| 7-250. RFBI_SYSSTATUS .....                                             | 1873 |
| 7-251. Register Call Summary for Register RFBI_SYSSTATUS .....          | 1873 |
| 7-252. RFBI_CONTROL .....                                               | 1873 |
| 7-253. Register Call Summary for Register RFBI_CONTROL.....             | 1874 |
| 7-254. RFBI_PIXEL_CNT.....                                              | 1875 |
| 7-255. Register Call Summary for Register RFBI_PIXEL_CNT .....          | 1875 |
| 7-256. RFBI_LINE_NUMBER .....                                           | 1875 |
| 7-257. Register Call Summary for Register RFBI_LINE_NUMBER.....         | 1875 |

|                                                                      |      |
|----------------------------------------------------------------------|------|
| 7-258. RFBI_CMD .....                                                | 1876 |
| 7-259. Register Call Summary for Register RFBI_CMD.....              | 1876 |
| 7-260. RFBI_PARAM.....                                               | 1876 |
| 7-261. Register Call Summary for Register RFBI_PARAM .....           | 1876 |
| 7-262. RFBI_DATA .....                                               | 1877 |
| 7-263. Register Call Summary for Register RFBI_DATA.....             | 1877 |
| 7-264. RFBI_READ.....                                                | 1877 |
| 7-265. Register Call Summary for Register RFBI_READ .....            | 1878 |
| 7-266. RFBI_STATUS.....                                              | 1878 |
| 7-267. Register Call Summary for Register RFBI_STATUS .....          | 1878 |
| 7-268. RFBI_CONFIGi .....                                            | 1879 |
| 7-269. Register Call Summary for Register RFBI_CONFIGi.....          | 1880 |
| 7-270. RFBI_ONOFF_TIMEi .....                                        | 1880 |
| 7-271. Register Call Summary for Register RFBI_ONOFF_TIMEi.....      | 1881 |
| 7-272. RFBI_CYCLE_TIMEi.....                                         | 1881 |
| 7-273. Register Call Summary for Register RFBI_CYCLE_TIMEi .....     | 1882 |
| 7-274. RFBI_DATA_CYCLE1_i .....                                      | 1882 |
| 7-275. Register Call Summary for Register RFBI_DATA_CYCLE1_i.....    | 1882 |
| 7-276. RFBI_DATA_CYCLE2_i .....                                      | 1883 |
| 7-277. Register Call Summary for Register RFBI_DATA_CYCLE2_i.....    | 1883 |
| 7-278. RFBI_DATA_CYCLE3_i .....                                      | 1884 |
| 7-279. Register Call Summary for Register RFBI_DATA_CYCLE3_i.....    | 1884 |
| 7-280. RFBI_VSYNC_WIDTH.....                                         | 1885 |
| 7-281. Register Call Summary for Register RFBI_VSYNC_WIDTH .....     | 1885 |
| 7-282. RFBI_HSYNC_WIDTH.....                                         | 1885 |
| 7-283. Register Call Summary for Register RFBI_HSYNC_WIDTH .....     | 1885 |
| 7-284. VENC_REV_ID .....                                             | 1886 |
| 7-285. Register Call Summary for Register VENC_REV_ID.....           | 1886 |
| 7-286. VENC_STATUS .....                                             | 1886 |
| 7-287. Register Call Summary for Register VENC_STATUS.....           | 1887 |
| 7-288. VENC_F_CONTROL.....                                           | 1887 |
| 7-289. Register Call Summary for Register VENC_F_CONTROL .....       | 1888 |
| 7-290. VENC_VIDOUT_CTRL .....                                        | 1888 |
| 7-291. Register Call Summary for Register VENC_VIDOUT_CTRL.....      | 1888 |
| 7-292. VENC_SYNC_CTRL .....                                          | 1888 |
| 7-293. Register Call Summary for Register VENC_SYNC_CTRL .....       | 1889 |
| 7-294. VENC_LLEN .....                                               | 1890 |
| 7-295. Register Call Summary for Register VENC_LLEN.....             | 1890 |
| 7-296. VENC_FLENS .....                                              | 1890 |
| 7-297. Register Call Summary for Register VENC_FLENS.....            | 1890 |
| 7-298. VENC_HFLTR_CTRL.....                                          | 1891 |
| 7-299. Register Call Summary for Register VENC_HFLTR_CTRL .....      | 1891 |
| 7-300. VENC_CC_CARR_WSS_CARR .....                                   | 1891 |
| 7-301. Register Call Summary for Register VENC_CC_CARR_WSS_CARR..... | 1891 |
| 7-302. VENC_C_PHASE .....                                            | 1892 |
| 7-303. Register Call Summary for Register VENC_C_PHASE .....         | 1892 |
| 7-304. VENC_GAIN_U .....                                             | 1892 |
| 7-305. Register Call Summary for Register VENC_GAIN_U .....          | 1893 |
| 7-306. VENC_GAIN_V .....                                             | 1893 |

|                                                                                      |      |
|--------------------------------------------------------------------------------------|------|
| 7-307. Register Call Summary for Register VENC_GAIN_V.....                           | 1893 |
| 7-308. VENC_GAIN_Y .....                                                             | 1893 |
| 7-309. Register Call Summary for Register VENC_GAIN_Y.....                           | 1894 |
| 7-310. VENC_BLACK_LEVEL .....                                                        | 1894 |
| 7-311. Register Call Summary for Register VENC_BLACK_LEVEL.....                      | 1894 |
| 7-312. VENC_BLANK_LEVEL .....                                                        | 1894 |
| 7-313. Register Call Summary for Register VENC_BLANK_LEVEL.....                      | 1895 |
| 7-314. VENC_X_COLOR .....                                                            | 1895 |
| 7-315. Register Call Summary for Register VENC_X_COLOR.....                          | 1895 |
| 7-316. VENC_M_CONTROL .....                                                          | 1896 |
| 7-317. Register Call Summary for Register VENC_M_CONTROL.....                        | 1896 |
| 7-318. VENC_BSTAMP_WSS_DATA.....                                                     | 1897 |
| 7-319. Register Call Summary for Register VENC_BSTAMP_WSS_DATA.....                  | 1897 |
| 7-320. VENC_S_CARR .....                                                             | 1897 |
| 7-321. Register Call Summary for Register VENC_S_CARR.....                           | 1898 |
| 7-322. VENC_LINE21 .....                                                             | 1898 |
| 7-323. Register Call Summary for Register VENC_LINE21 .....                          | 1898 |
| 7-324. VENC_LN_SEL .....                                                             | 1899 |
| 7-325. Register Call Summary for Register VENC_LN_SEL .....                          | 1899 |
| 7-326. VENC_L21_WC_CTL .....                                                         | 1899 |
| 7-327. Register Call Summary for Register VENC_L21_WC_CTL .....                      | 1900 |
| 7-328. VENC_HTRIGGER_VTRIGGER .....                                                  | 1900 |
| 7-329. Register Call Summary for Register VENC_HTRIGGER_VTRIGGER.....                | 1901 |
| 7-330. VENC_SAVID_EAVID .....                                                        | 1901 |
| 7-331. Register Call Summary for Register VENC_SAVID_EAVID .....                     | 1901 |
| 7-332. VENC_FLEN_FAL.....                                                            | 1901 |
| 7-333. Register Call Summary for Register VENC_FLEN_FAL .....                        | 1902 |
| 7-334. VENC_LAL_PHASE_RESET .....                                                    | 1902 |
| 7-335. Register Call Summary for Register VENC_LAL_PHASE_RESET.....                  | 1902 |
| 7-336. VENC_HS_INT_START_STOP_X .....                                                | 1903 |
| 7-337. Register Call Summary for Register VENC_HS_INT_START_STOP_X .....             | 1903 |
| 7-338. VENC_HS_EXT_START_STOP_X .....                                                | 1903 |
| 7-339. Register Call Summary for Register VENC_HS_EXT_START_STOP_X.....              | 1903 |
| 7-340. VENC_VS_INT_START_X .....                                                     | 1904 |
| 7-341. Register Call Summary for Register VENC_VS_INT_START_X .....                  | 1904 |
| 7-342. VENC_VS_INT_STOP_X_VS_INT_START_Y .....                                       | 1904 |
| 7-343. Register Call Summary for Register VENC_VS_INT_STOP_X_VS_INT_START_Y .....    | 1904 |
| 7-344. VENC_VS_INT_STOP_Y_VS_EXT_START_X .....                                       | 1905 |
| 7-345. Register Call Summary for Register VENC_VS_INT_STOP_Y_VS_EXT_START_X .....    | 1905 |
| 7-346. VENC_VS_EXT_STOP_X_VS_EXT_START_Y .....                                       | 1905 |
| 7-347. Register Call Summary for Register VENC_VS_EXT_STOP_X_VS_EXT_START_Y.....     | 1905 |
| 7-348. VENC_VS_EXT_STOP_Y .....                                                      | 1906 |
| 7-349. Register Call Summary for Register VENC_VS_EXT_STOP_Y .....                   | 1906 |
| 7-350. VENC_AVID_START_STOP_X .....                                                  | 1906 |
| 7-351. Register Call Summary for Register VENC_AVID_START_STOP_X.....                | 1906 |
| 7-352. VENC_AVID_START_STOP_Y .....                                                  | 1907 |
| 7-353. Register Call Summary for Register VENC_AVID_START_STOP_Y .....               | 1907 |
| 7-354. VENC_FID_INT_START_X_FID_INT_START_Y .....                                    | 1907 |
| 7-355. Register Call Summary for Register VENC_FID_INT_START_X_FID_INT_START_Y ..... | 1907 |

|                                                                                       |      |
|---------------------------------------------------------------------------------------|------|
| 7-356. VENC_FID_INT_OFFSET_Y_FID_EXT_START_X .....                                    | 1908 |
| 7-357. Register Call Summary for Register VENC_FID_INT_OFFSET_Y_FID_EXT_START_X.....  | 1908 |
| 7-358. VENC_FID_EXT_START_Y_FID_EXT_OFFSET_Y .....                                    | 1908 |
| 7-359. Register Call Summary for Register VENC_FID_EXT_START_Y_FID_EXT_OFFSET_Y ..... | 1908 |
| 7-360. VENC_TVDETGP_INT_START_STOP_X .....                                            | 1909 |
| 7-361. Register Call Summary for Register VENC_TVDETGP_INT_START_STOP_X .....         | 1909 |
| 7-362. VENC_TVDETGP_INT_START_STOP_Y .....                                            | 1909 |
| 7-363. Register Call Summary for Register VENC_TVDETGP_INT_START_STOP_Y .....         | 1909 |
| 7-364. VENC_GEN_CTRL.....                                                             | 1910 |
| 7-365. Register Call Summary for Register VENC_GEN_CTRL .....                         | 1911 |
| 7-366. VENC_OUTPUT_CONTROL .....                                                      | 1911 |
| 7-367. Register Call Summary for Register VENC_OUTPUT_CONTROL.....                    | 1912 |
| 7-368. VENC_OUTPUT_TEST .....                                                         | 1912 |
| 7-369. Register Call Summary for Register VENC_OUTPUT_TEST .....                      | 1913 |
| 7-370. DSI_REVISION .....                                                             | 1913 |
| 7-371. Register Call Summary for Register DSI_REVISION.....                           | 1913 |
| 7-372. DSI_SYSCONFIG .....                                                            | 1913 |
| 7-373. Register Call Summary for Register DSI_SYSCONFIG.....                          | 1914 |
| 7-374. DSI_SYSSTATUS .....                                                            | 1915 |
| 7-375. Register Call Summary for Register DSI_SYSSTATUS .....                         | 1915 |
| 7-376. DSI_IRQSTATUS.....                                                             | 1915 |
| 7-377. Register Call Summary for Register DSI_IRQSTATUS .....                         | 1918 |
| 7-378. DSI_IRQENABLE.....                                                             | 1918 |
| 7-379. Register Call Summary for Register DSI_IRQENABLE .....                         | 1919 |
| 7-380. DSI_CTRL.....                                                                  | 1920 |
| 7-381. Register Call Summary for Register DSI_CTRL .....                              | 1923 |
| 7-382. DSI_COMPLEXIO_CFG1 .....                                                       | 1924 |
| 7-383. Register Call Summary for Register DSI_COMPLEXIO_CFG1.....                     | 1925 |
| 7-384. DSI_COMPLEXIO_IRQSTATUS .....                                                  | 1926 |
| 7-385. Register Call Summary for Register DSI_COMPLEXIO_IRQSTATUS.....                | 1928 |
| 7-386. DSI_COMPLEXIO_IRQENABLE .....                                                  | 1929 |
| 7-387. Register Call Summary for Register DSI_COMPLEXIO_IRQENABLE.....                | 1931 |
| 7-388. DSI_CLK_CTRL .....                                                             | 1931 |
| 7-389. Register Call Summary for Register DSI_CLK_CTRL.....                           | 1933 |
| 7-390. DSI_TIMING1 .....                                                              | 1933 |
| 7-391. Register Call Summary for Register DSI_TIMING1.....                            | 1934 |
| 7-392. DSI_TIMING2 .....                                                              | 1935 |
| 7-393. Register Call Summary for Register DSI_TIMING2.....                            | 1936 |
| 7-394. DSI_VM_TIMING1 .....                                                           | 1936 |
| 7-395. Register Call Summary for Register DSI_VM_TIMING1 .....                        | 1936 |
| 7-396. DSI_VM_TIMING2 .....                                                           | 1936 |
| 7-397. Register Call Summary for Register DSI_VM_TIMING2 .....                        | 1937 |
| 7-398. DSI_VM_TIMING3 .....                                                           | 1937 |
| 7-399. Register Call Summary for Register DSI_VM_TIMING3 .....                        | 1937 |
| 7-400. DSI_CLK_TIMING.....                                                            | 1938 |
| 7-401. Register Call Summary for Register DSI_CLK_TIMING .....                        | 1938 |
| 7-402. DSI_TX_FIFO_VC_SIZE .....                                                      | 1938 |
| 7-403. Register Call Summary for Register DSI_TX_FIFO_VC_SIZE.....                    | 1939 |
| 7-404. DSI_RX_FIFO_VC_SIZE .....                                                      | 1939 |

|                                                                             |      |
|-----------------------------------------------------------------------------|------|
| 7-405. Register Call Summary for Register DSI_RX_FIFO_VC_SIZE .....         | 1940 |
| 7-406. DSI_COMPLEXIO_CFG2 .....                                             | 1940 |
| 7-407. Register Call Summary for Register DSI_COMPLEXIO_CFG2.....           | 1942 |
| 7-408. DSI_RX_FIFO_VC_FULLNESS .....                                        | 1943 |
| 7-409. Register Call Summary for Register DSI_RX_FIFO_VC_FULLNESS .....     | 1943 |
| 7-410. DSI_VM_TIMING4 .....                                                 | 1943 |
| 7-411. Register Call Summary for Register DSI_VM_TIMING4 .....              | 1944 |
| 7-412. DSI_TX_FIFO_VC_EMPTINESS.....                                        | 1944 |
| 7-413. Register Call Summary for Register DSI_TX_FIFO_VC_EMPTINESS .....    | 1944 |
| 7-414. DSI_VM_TIMING5 .....                                                 | 1944 |
| 7-415. Register Call Summary for Register DSI_VM_TIMING5 .....              | 1945 |
| 7-416. DSI_VM_TIMING6 .....                                                 | 1945 |
| 7-417. Register Call Summary for Register DSI_VM_TIMING6 .....              | 1945 |
| 7-418. DSI_VM_TIMING7 .....                                                 | 1946 |
| 7-419. Register Call Summary for Register DSI_VM_TIMING7 .....              | 1946 |
| 7-420. DSI_STOPCLK_TIMING .....                                             | 1946 |
| 7-421. Register Call Summary for Register DSI_STOPCLK_TIMING .....          | 1947 |
| 7-422. DSI_VCn_CTRL .....                                                   | 1947 |
| 7-423. Register Call Summary for Register DSI_VCn_CTRL.....                 | 1950 |
| 7-424. DSI_VCn_TE .....                                                     | 1950 |
| 7-425. Register Call Summary for Register DSI_VCn_TE .....                  | 1951 |
| 7-426. DSI_VCn_LONG_PACKET_HEADER.....                                      | 1951 |
| 7-427. Register Call Summary for Register DSI_VCn_LONG_PACKET_HEADER .....  | 1951 |
| 7-428. DSI_VCn_LONG_PACKET_PAYLOAD .....                                    | 1952 |
| 7-429. Register Call Summary for Register DSI_VCn_LONG_PACKET_PAYLOAD.....  | 1952 |
| 7-430. DSI_VCn_SHORT_PACKET_HEADER .....                                    | 1953 |
| 7-431. Register Call Summary for Register DSI_VCn_SHORT_PACKET_HEADER ..... | 1953 |
| 7-432. DSI_VCn_IRQSTATUS.....                                               | 1953 |
| 7-433. Register Call Summary for Register DSI_VCn_IRQSTATUS .....           | 1955 |
| 7-434. DSI_VCn_IRQENABLE .....                                              | 1955 |
| 7-435. Register Call Summary for Register DSI_VCn_IRQENABLE .....           | 1956 |
| 7-436. DSI_PHY_REGISTER0.....                                               | 1957 |
| 7-437. Register Call Summary for Register DSI_PHY_REGISTER0 .....           | 1957 |
| 7-438. DSI_PHY_REGISTER1.....                                               | 1958 |
| 7-439. Register Call Summary for Register DSI_PHY_REGISTER1 .....           | 1959 |
| 7-440. DSI_PHY_REGISTER2.....                                               | 1959 |
| 7-441. Register Call Summary for Register DSI_PHY_REGISTER2 .....           | 1960 |
| 7-442. DSI_PHY_REGISTER3.....                                               | 1960 |
| 7-443. Register Call Summary for Register DSI_PHY_REGISTER3 .....           | 1960 |
| 7-444. DSI_PHY_REGISTER4.....                                               | 1961 |
| 7-445. Register Call Summary for Register DSI_PHY_REGISTER4 .....           | 1961 |
| 7-446. DSI_PHY_REGISTER5.....                                               | 1961 |
| 7-447. Register Call Summary for Register DSI_PHY_REGISTER5 .....           | 1962 |
| 7-448. DSI_PLL_CONTROL .....                                                | 1962 |
| 7-449. Register Call Summary for Register DSI_PLL_CONTROL.....              | 1963 |
| 7-450. DSI_PLL_STATUS .....                                                 | 1963 |
| 7-451. Register Call Summary for Register DSI_PLL_STATUS.....               | 1964 |
| 7-452. DSI_PLL_GO .....                                                     | 1965 |
| 7-453. Register Call Summary for Register DSI_PLL_GO .....                  | 1965 |

|                                                                        |      |
|------------------------------------------------------------------------|------|
| 7-454. DSI_PLL_CONFIGURATION1.....                                     | 1965 |
| 7-455. Register Call Summary for Register DSI_PLL_CONFIGURATION1 ..... | 1966 |
| 7-456. DSI_PLL_CONFIGURATION2.....                                     | 1966 |
| 7-457. Register Call Summary for Register DSI_PLL_CONFIGURATION2 ..... | 1968 |
| 8-1. Clock Descriptions.....                                           | 1973 |
| 8-2. SGX Instance Summary .....                                        | 1977 |
| 8-3. SGX Registers Mapping Summary.....                                | 1977 |
| 8-4. OCP_REVISION.....                                                 | 1978 |
| 8-5. Register Call Summary for Register OCP_REVISION .....             | 1978 |
| 8-6. OCP_HWINFO.....                                                   | 1978 |
| 8-7. Register Call Summary for Register OCP_HWINFO .....               | 1978 |
| 8-8. OCP_SYSCONFIG.....                                                | 1979 |
| 8-9. Register Call Summary for Register OCP_SYSCONFIG .....            | 1979 |
| 8-10. OCP_IRQSTATUS_RAW_0 .....                                        | 1979 |
| 8-11. Register Call Summary for Register OCP_IRQSTATUS_RAW_0.....      | 1980 |
| 8-12. OCP_IRQSTATUS_RAW_1 .....                                        | 1980 |
| 8-13. Register Call Summary for Register OCP_IRQSTATUS_RAW_1 .....     | 1980 |
| 8-14. OCP_IRQSTATUS_RAW_2 .....                                        | 1981 |
| 8-15. Register Call Summary for Register OCP_IRQSTATUS_RAW_2 .....     | 1981 |
| 8-16. OCP_IRQSTATUS_0 .....                                            | 1981 |
| 8-17. Register Call Summary for Register OCP_IRQSTATUS_0.....          | 1982 |
| 8-18. OCP_IRQSTATUS_1 .....                                            | 1982 |
| 8-19. Register Call Summary for Register OCP_IRQSTATUS_1 .....         | 1982 |
| 8-20. OCP_IRQSTATUS_2 .....                                            | 1983 |
| 8-21. Register Call Summary for Register OCP_IRQSTATUS_2.....          | 1983 |
| 8-22. OCP_IRQENABLE_SET_0 .....                                        | 1983 |
| 8-23. Register Call Summary for Register OCP_IRQENABLE_SET_0 .....     | 1984 |
| 8-24. OCP_IRQENABLE_SET_1 .....                                        | 1984 |
| 8-25. Register Call Summary for Register OCP_IRQENABLE_SET_1 .....     | 1984 |
| 8-26. OCP_IRQENABLE_SET_2 .....                                        | 1985 |
| 8-27. Register Call Summary for Register OCP_IRQENABLE_SET_2 .....     | 1985 |
| 8-28. OCP_IRQENABLE_CLR_0 .....                                        | 1985 |
| 8-29. Register Call Summary for Register OCP_IRQENABLE_CLR_0 .....     | 1986 |
| 8-30. OCP_IRQENABLE_CLR_1 .....                                        | 1986 |
| 8-31. Register Call Summary for Register OCP_IRQENABLE_CLR_1 .....     | 1986 |
| 8-32. OCP_IRQENABLE_CLR_2 .....                                        | 1987 |
| 8-33. Register Call Summary for Register OCP_IRQENABLE_CLR_2 .....     | 1987 |
| 8-34. OCP_PAGE_CONFIG .....                                            | 1987 |
| 8-35. Register Call Summary for Register OCP_PAGE_CONFIG .....         | 1988 |
| 8-36. OCP_INTERRUPT_EVENT .....                                        | 1988 |
| 8-37. Register Call Summary for Register OCP_INTERRUPT_EVENT .....     | 1989 |
| 8-38. OCP_DEBUG_CONFIG .....                                           | 1990 |
| 8-39. Register Call Summary for Register OCP_DEBUG_CONFIG .....        | 1990 |
| 8-40. OCP_DEBUG_STATUS .....                                           | 1991 |
| 8-41. Register Call Summary for Register OCP_DEBUG_STATUS .....        | 1992 |
| 9-1. MCmd Qualifier Description .....                                  | 1995 |
| 9-2. MReqInfo Qualifier Description .....                              | 1995 |
| 9-3. SResp Qualifier Description .....                                 | 1995 |
| 9-4. L3 Initiator Agents .....                                         | 1998 |

---

|       |                                                               |      |
|-------|---------------------------------------------------------------|------|
| 9-5.  | L3 Target Agents .....                                        | 1998 |
| 9-6.  | L4-Core Initiator Agent.....                                  | 1999 |
| 9-7.  | L4-Core Target Agents .....                                   | 1999 |
| 9-8.  | L4-Per Initiator Agent .....                                  | 2000 |
| 9-9.  | L4-Per Target Agents .....                                    | 2000 |
| 9-10. | L4-Emu Initiator Agents.....                                  | 2000 |
| 9-11. | L4-Emu Target Agents.....                                     | 2000 |
| 9-12. | L4-Wakeup Initiator Agent.....                                | 2001 |
| 9-13. | L4-Wakeup Target Agents .....                                 | 2001 |
| 9-14. | Connectivity Matrix .....                                     | 2001 |
| 9-15. | L3 Interconnect Clocks .....                                  | 2004 |
| 9-16. | L3 Interconnect Reset .....                                   | 2004 |
| 9-17. | L3 Interconnect Power Domain.....                             | 2004 |
| 9-18. | L3 Interconnect Hardware Requests.....                        | 2005 |
| 9-19. | InitiatorID Definition .....                                  | 2005 |
| 9-20. | Target Firewall and Region Configuration.....                 | 2006 |
| 9-21. | L3 Firewall Size Parameter Definition .....                   | 2009 |
| 9-22. | MReqInfo Parameter Combinations.....                          | 2012 |
| 9-23. | L3 Firewall Permission-Setting Registers .....                | 2013 |
| 9-24. | L3 Firewall Error Logging Registers .....                     | 2014 |
| 9-25. | Error Types.....                                              | 2018 |
| 9-26. | CODE Field Definition .....                                   | 2018 |
| 9-27. | L3 Timeout Register Target and Agent Programming.....         | 2019 |
| 9-28. | L3 External Input Flags .....                                 | 2021 |
| 9-29. | L3_SI_FLAG_STATUS_0 for Application Error .....               | 2022 |
| 9-30. | L3_SI_FLAG_STATUS_1 for Debug Error.....                      | 2023 |
| 9-31. | Error Clearing .....                                          | 2027 |
| 9-32. | MReqInfo Parameter Example.....                               | 2028 |
| 9-33. | Instance Summary .....                                        | 2031 |
| 9-34. | Initiator Agent Common Register Summary .....                 | 2032 |
| 9-35. | Initiator Agent Common Register Summary .....                 | 2032 |
| 9-36. | Initiator Agent Common Register Summary .....                 | 2032 |
| 9-37. | Initiator Agent Common Register Summary .....                 | 2032 |
| 9-38. | L3_IA_COMPONENT .....                                         | 2033 |
| 9-39. | Register Call Summary for Register L3_IA_COMPONENT .....      | 2033 |
| 9-40. | L3_IA_CORE.....                                               | 2033 |
| 9-41. | Register Call Summary for Register L3_IA_CORE .....           | 2033 |
| 9-42. | L3_IA_AGENT_CONTROL .....                                     | 2034 |
| 9-43. | Register Call Summary for Register L3_IA_AGENT_CONTROL .....  | 2035 |
| 9-44. | L3_IA_AGENT_STATUS .....                                      | 2035 |
| 9-45. | Register Call Summary for Register L3_IA_AGENT_STATUS .....   | 2037 |
| 9-46. | L3_IA_ERROR_LOG .....                                         | 2037 |
| 9-47. | Register Call Summary for Register L3_IA_ERROR_LOG .....      | 2038 |
| 9-48. | L3_IA_ERROR_LOG_ADDR .....                                    | 2038 |
| 9-49. | Register Call Summary for Register L3_IA_ERROR_LOG_ADDR ..... | 2038 |
| 9-50. | Target Agent Common Register Summary .....                    | 2039 |
| 9-51. | Target Agent Common Register Summary .....                    | 2039 |
| 9-52. | Target Agent Common Register Summary .....                    | 2039 |
| 9-53. | Target Agent Common Register Summary .....                    | 2039 |

|                                                                                                                   |      |
|-------------------------------------------------------------------------------------------------------------------|------|
| 9-54. L3_TA_COMPONENT .....                                                                                       | 2040 |
| 9-55. Register Call Summary for Register L3_TA_COMPONENT.....                                                     | 2040 |
| 9-56. L3_TA_CORE .....                                                                                            | 2040 |
| 9-57. Register Call Summary for Register L3_TA_CORE .....                                                         | 2040 |
| 9-58. L3_TA_AGENT_CONTROL.....                                                                                    | 2041 |
| 9-59. Register Call Summary for Register L3_TA_AGENT_CONTROL .....                                                | 2041 |
| 9-60. L3_TA_AGENT_STATUS .....                                                                                    | 2042 |
| 9-61. Register Call Summary for Register L3_TA_AGENT_STATUS.....                                                  | 2043 |
| 9-62. L3_TA_ERROR_LOG.....                                                                                        | 2043 |
| 9-63. Register Call Summary for Register L3_TA_ERROR_LOG .....                                                    | 2043 |
| 9-64. L3_TA_ERROR_LOG_ADDR .....                                                                                  | 2044 |
| 9-65. Register Call Summary for Register L3_TA_ERROR_LOG_ADDR .....                                               | 2044 |
| 9-66. RT Register Summary .....                                                                                   | 2044 |
| 9-67. L3_RT_COMPONENT .....                                                                                       | 2044 |
| 9-68. Register Call Summary for Register L3_RT_COMPONENT .....                                                    | 2045 |
| 9-69. L3_RT_NETWORK.....                                                                                          | 2045 |
| 9-70. Register Call Summary for Register L3_RT_NETWORK .....                                                      | 2045 |
| 9-71. L3_RT_INITID_READBACK .....                                                                                 | 2045 |
| 9-72. Register Call Summary for Register L3_RT_INITID_READBACK.....                                               | 2046 |
| 9-73. L3_RT_NETWORK_CONTROL .....                                                                                 | 2046 |
| 9-74. Register Call Summary for Register L3_RT_NETWORK_CONTROL .....                                              | 2047 |
| 9-75. Protection Mechanism Common Register Summary .....                                                          | 2047 |
| 9-76. Protection Mechanism Common Register Summary .....                                                          | 2047 |
| 9-77. Protection Mechanism Common Register Summary .....                                                          | 2048 |
| 9-78. L3_PM_ERROR_LOG .....                                                                                       | 2048 |
| 9-79. Register Call Summary for Register L3_PM_ERROR_LOG .....                                                    | 2049 |
| 9-80. L3_PM_CONTROL.....                                                                                          | 2049 |
| 9-81. Register Call Summary for Register L3_PM_CONTROL .....                                                      | 2050 |
| 9-82. L3_PM_ERROR_CLEAR_SINGLE .....                                                                              | 2050 |
| 9-83. Register Call Summary for Register L3_PM_ERROR_CLEAR_SINGLE .....                                           | 2050 |
| 9-84. L3_PM_ERROR_CLEAR_MULTI .....                                                                               | 2050 |
| 9-85. Register Call Summary for Register L3_PM_ERROR_CLEAR_MULTI.....                                             | 2051 |
| 9-86. L3_PM_REQ_INFO_PERMISSION_i.....                                                                            | 2051 |
| 9-87. Register Call Summary for Register L3_PM_REQ_INFO_PERMISSION_i .....                                        | 2051 |
| 9-88. Reset Value for REQ_INFO_PERMISSION .....                                                                   | 2051 |
| 9-89. L3_PM_READ_PERMISSION_i .....                                                                               | 2052 |
| 9-90. Register Call Summary for Register L3_PM_READ_PERMISSION_i .....                                            | 2052 |
| 9-91. L3_PM_WRITE_PERMISSION_i.....                                                                               | 2053 |
| 9-92. Register Call Summary for Register L3_PM_WRITE_PERMISSION_i .....                                           | 2053 |
| 9-93. Bit Availability and Initialization Values for L3_PM_READ_PERMISSION_i and<br>L3_PM_WRITE_PERMISSION_i..... | 2054 |
| 9-94. L3_PM_ADDR_MATCH_k .....                                                                                    | 2055 |
| 9-95. Register Call Summary for Register L3_PM_ADDR_MATCH_k.....                                                  | 2055 |
| 9-96. Reset Value for L3_PM_ADDR_MATCH_k.....                                                                     | 2056 |
| 9-97. SI Register Summary .....                                                                                   | 2056 |
| 9-98. L3_SI_CONTROL .....                                                                                         | 2057 |
| 9-99. Register Call Summary for Register L3_SI_CONTROL.....                                                       | 2057 |
| 9-100. L3_SI_FLAG_STATUS_0 .....                                                                                  | 2057 |
| 9-101. Register Call Summary for Register L3_SI_FLAG_STATUS_0.....                                                | 2058 |

---

|                                                                             |      |
|-----------------------------------------------------------------------------|------|
| 9-102. L3_SI_FLAG_STATUS_1 .....                                            | 2058 |
| 9-103. Register Call Summary for Register L3_SI_FLAG_STATUS_1.....          | 2058 |
| 9-104. L4-Core Target Agents .....                                          | 2061 |
| 9-105. L4-Per Target Agents .....                                           | 2061 |
| 9-106. L4-Emu Target Agents.....                                            | 2062 |
| 9-107. L4-Emu Initiator Agents.....                                         | 2063 |
| 9-108. L4-Wakeup Target Agents .....                                        | 2063 |
| 9-109. L4-Wakeup Initiator Agents .....                                     | 2063 |
| 9-110. L4 Interconnect Clocks .....                                         | 2064 |
| 9-111. L4 Interconnect Hardware Reset.....                                  | 2064 |
| 9-112. L4 Interconnect Power Domains .....                                  | 2064 |
| 9-113. Region Allocation for L4-Core Interconnect.....                      | 2068 |
| 9-114. Region Allocation for L4-Per Interconnect .....                      | 2071 |
| 9-115. Region Allocation for L4-Emu Interconnect .....                      | 2072 |
| 9-116. L4 Firewall Register Description Overview.....                       | 2073 |
| 9-117. L4 Time-Out Link and TA Programming.....                             | 2075 |
| 9-118. L4 Time-Out TA Programming.....                                      | 2075 |
| 9-119. Global Initialization of Surrounding Modules.....                    | 2077 |
| 9-120. Main Sequence – Error Analysis Mode.....                             | 2080 |
| 9-121. Subprocess Call Summary for Main Sequence – Error Analysis Mode..... | 2080 |
| 9-122. Protection Violation Error Identification .....                      | 2081 |
| 9-123. Unsupported Command/Address Hole Error Identification .....          | 2081 |
| 9-124. Reset TA and Module.....                                             | 2081 |
| 9-125. Time-Out Configuration .....                                         | 2082 |
| 9-126. Firewall Configuration .....                                         | 2082 |
| 9-127. L4-Core Instance Summary .....                                       | 2082 |
| 9-128. L4-Per Instance Summary.....                                         | 2083 |
| 9-129. L4-Emu Instance Summary .....                                        | 2084 |
| 9-130. L4-WKUP Instance Summary.....                                        | 2084 |
| 9-131. L4_IA Register Summary (1) .....                                     | 2084 |
| 9-132. L4_IA Register Summary (2) .....                                     | 2085 |
| 9-133. L4_IA_COMPONENT_L .....                                              | 2085 |
| 9-134. Register Call Summary for Register L4_IA_COMPONENT_L .....           | 2085 |
| 9-135. L4_IA_COMPONENT_H .....                                              | 2086 |
| 9-136. Register Call Summary for Register L4_IA_COMPONENT_H .....           | 2086 |
| 9-137. L4_IA_CORE_L.....                                                    | 2086 |
| 9-138. Register Call Summary for Register L4_IA_CORE_L .....                | 2086 |
| 9-139. L4_IA_CORE_H .....                                                   | 2086 |
| 9-140. Register Call Summary for Register L4_IA_CORE_H.....                 | 2087 |
| 9-141. L4_IA_AGENT_CONTROL_L .....                                          | 2087 |
| 9-142. Register Call Summary for Register L4_IA_AGENT_CONTROL_L .....       | 2087 |
| 9-143. L4_IA_AGENT_CONTROL_H .....                                          | 2088 |
| 9-144. Register Call Summary for Register L4_IA_AGENT_CONTROL_H .....       | 2088 |
| 9-145. L4_IA_AGENT_STATUS_L .....                                           | 2088 |
| 9-146. Register Call Summary for Register L4_IA_AGENT_STATUS_L .....        | 2088 |
| 9-147. L4_IA_AGENT_STATUS_H.....                                            | 2089 |
| 9-148. Register Call Summary for Register L4_IA_AGENT_STATUS_H .....        | 2089 |
| 9-149. L4_IA_ERROR_LOG_L .....                                              | 2089 |
| 9-150. Register Call Summary for Register L4_IA_ERROR_LOG_L .....           | 2089 |

|                                                                       |      |
|-----------------------------------------------------------------------|------|
| 9-151. L4_IA_ERROR_LOG_H .....                                        | 2090 |
| 9-152. Register Call Summary for Register L4_IA_ERROR_LOG_H.....      | 2090 |
| 9-153. CORE_TA Common Register Summary .....                          | 2090 |
| 9-154. CORE_TA Common Register Summary .....                          | 2090 |
| 9-155. CORE_TA Common Register Summary .....                          | 2091 |
| 9-156. CORE_TA Common Register Summary .....                          | 2091 |
| 9-157. CORE_TA Common Register Summary .....                          | 2091 |
| 9-158. CORE_TA Common Register Summary .....                          | 2091 |
| 9-159. CORE_TA Common Register Summary .....                          | 2092 |
| 9-160. CORE_TA Common Register Summary .....                          | 2092 |
| 9-161. CORE_TA Common Register Summary .....                          | 2092 |
| 9-162. CORE_TA Common Register Summary .....                          | 2093 |
| 9-163. CORE_TA Common Register Summary .....                          | 2093 |
| 9-164. CORE_TA Common Register Summary .....                          | 2093 |
| 9-165. CORE_TA Common Register Summary .....                          | 2093 |
| 9-166. CORE_TA Common Register Summary .....                          | 2094 |
| 9-167. CORE_TA Common Register Summary .....                          | 2094 |
| 9-168. PER_TA Common Register Summary.....                            | 2094 |
| 9-169. PER_TA Common Register Summary.....                            | 2094 |
| 9-170. PER_TA Common Register Summary.....                            | 2095 |
| 9-171. PER_TA Common Register Summary.....                            | 2095 |
| 9-172. PER_TA Common Register Summary.....                            | 2095 |
| 9-173. PER_TA Common Register Summary.....                            | 2096 |
| 9-174. PER_TA Common Register Summary.....                            | 2096 |
| 9-175. EMU_TA Common Register Summary .....                           | 2096 |
| 9-176. EMU_TA Common Register Summary .....                           | 2096 |
| 9-177. WKUP_TA Common Register Summary .....                          | 2097 |
| 9-178. WKUP_TA Common Register Summary .....                          | 2097 |
| 9-179. L4_TA_COMPONENT_L .....                                        | 2097 |
| 9-180. Register Call Summary for Register L4_TA_COMPONENT_L.....      | 2098 |
| 9-181. L4_TA_COMPONENT_H.....                                         | 2098 |
| 9-182. Register Call Summary for Register L4_TA_COMPONENT_H .....     | 2098 |
| 9-183. L4_TA_CORE_L .....                                             | 2098 |
| 9-184. Register Call Summary for Register L4_TA_CORE_L .....          | 2098 |
| 9-185. L4_TA_CORE_H .....                                             | 2099 |
| 9-186. Register Call Summary for Register L4_TA_CORE_H.....           | 2099 |
| 9-187. L4_TA_AGENT_CONTROL_L.....                                     | 2099 |
| 9-188. Register Call Summary for Register L4_TA_AGENT_CONTROL_L ..... | 2100 |
| 9-189. L4_TA_AGENT_CONTROL_H .....                                    | 2100 |
| 9-190. Register Call Summary for Register L4_TA_AGENT_CONTROL_H.....  | 2100 |
| 9-191. L4_TA_AGENT_STATUS_L .....                                     | 2100 |
| 9-192. Register Call Summary for Register L4_TA_AGENT_STATUS_L.....   | 2101 |
| 9-193. L4_TA_AGENT_STATUS_H.....                                      | 2101 |
| 9-194. Register Call Summary for Register L4_TA_AGENT_STATUS_H .....  | 2101 |
| 9-195. L4 LA Register Summary.....                                    | 2101 |
| 9-196. L4_LA_COMPONENT_L .....                                        | 2102 |
| 9-197. Register Call Summary for Register L4_LA_COMPONENT_L.....      | 2102 |
| 9-198. L4_LA_COMPONENT_H.....                                         | 2102 |
| 9-199. Register Call Summary for Register L4_LA_COMPONENT_H .....     | 2102 |

|                                                                              |      |
|------------------------------------------------------------------------------|------|
| 9-200. L4_LA_NETWORK_L .....                                                 | 2102 |
| 9-201. Register Call Summary for Register L4_LA_NETWORK_L .....              | 2103 |
| 9-202. L4_LA_NETWORK_H .....                                                 | 2103 |
| 9-203. Register Call Summary for Register L4_LA_NETWORK_H .....              | 2103 |
| 9-204. L4_LA_INITIATOR_INFO_L .....                                          | 2103 |
| 9-205. Register Call Summary for Register L4_LA_INITIATOR_INFO_L .....       | 2104 |
| 9-206. Reset value for L4_LA_INITIATOR_INFO_L .....                          | 2104 |
| 9-207. L4_LA_INITIATOR_INFO_H .....                                          | 2104 |
| 9-208. Register Call Summary for Register L4_LA_INITIATOR_INFO_H .....       | 2104 |
| 9-209. Reset value for L4_LA_INITIATOR_INFO_H .....                          | 2105 |
| 9-210. L4_LA_NETWORK_CONTROL_L .....                                         | 2105 |
| 9-211. Register Call Summary for Register L4_LA_NETWORK_CONTROL_L .....      | 2105 |
| 9-212. L4_LA_NETWORK_CONTROL_H .....                                         | 2105 |
| 9-213. Register Call Summary for Register L4_LA_NETWORK_CONTROL_H .....      | 2106 |
| 9-214. L4_AP Register Summary .....                                          | 2106 |
| 9-215. L4_AP Register Summary .....                                          | 2107 |
| 9-216. L4_AP_COMPONENT_L .....                                               | 2107 |
| 9-217. Register Call Summary for Register L4_AP_COMPONENT_L .....            | 2108 |
| 9-218. L4_AP_COMPONENT_H .....                                               | 2108 |
| 9-219. Register Call Summary for Register L4_AP_COMPONENT_H .....            | 2108 |
| 9-220. L4_AP_SEGMENT_i_L .....                                               | 2108 |
| 9-221. Register Call Summary for Register L4_AP_SEGMENT_i_L .....            | 2108 |
| 9-222. L4_AP_SEGMENT_i_L Reset Values .....                                  | 2109 |
| 9-223. L4_AP_SEGMENT_i_H .....                                               | 2109 |
| 9-224. Register Call Summary for Register L4_AP_SEGMENT_i_H .....            | 2109 |
| 9-225. L4_AP_SEGMENT_i_H Reset Values .....                                  | 2110 |
| 9-226. L4_AP_PROT_GROUP_MEMBERS_k_L .....                                    | 2110 |
| 9-227. Register Call Summary for Register L4_AP_PROT_GROUP_MEMBERS_k_L ..... | 2110 |
| 9-228. L4_AP_PROT_GROUP_MEMBERS_k_H .....                                    | 2110 |
| 9-229. Register Call Summary for Register L4_AP_PROT_GROUP_MEMBERS_k_H ..... | 2110 |
| 9-230. L4_AP_PROT_GROUP_ROLES_k_L .....                                      | 2111 |
| 9-231. Register Call Summary for Register L4_AP_PROT_GROUP_ROLES_k_L .....   | 2111 |
| 9-232. L4_AP_PROT_GROUP_ROLES_k_H .....                                      | 2111 |
| 9-233. Register Call Summary for Register L4_AP_PROT_GROUP_ROLES_k_H .....   | 2111 |
| 9-234. L4_AP_REGION_I_L .....                                                | 2112 |
| 9-235. Register Call Summary for Register L4_AP_REGION_I_L .....             | 2112 |
| 9-236. L4_AP_REGION_I_H .....                                                | 2112 |
| 9-237. Register Call Summary for Register L4_AP_REGION_I_H .....             | 2113 |
| 9-238. Reset Values for CORE_AP L4_AP_REGION_I_L and L4_AP_REGION_I_H .....  | 2113 |
| 9-239. Reset Values for PER_AP L4_AP_REGION_I_L and L4_AP_REGION_I_H .....   | 2115 |
| 9-240. Reset Values for EMU_AP L4_AP_REGION_I_L and L4_AP_REGION_I_H .....   | 2116 |
| 9-241. Reset Values for WKPUP_AP L4_AP_REGION_I_L and L4_AP_REGION_I_H ..... | 2117 |
| 10-1. GPMC I/O Description .....                                             | 2122 |
| 10-2. GPMC Pin Multiplexing Options .....                                    | 2123 |
| 10-3. Idle Cycle Insertion Configuration .....                               | 2145 |
| 10-4. Chip-Select Configuration for NAND Interfacing .....                   | 2164 |
| 10-5. ECC Enable Settings .....                                              | 2171 |
| 10-6. Flattened BCH Codeword Mapping (512 Bytes + 104 Bits) .....            | 2176 |
| 10-7. Aligned Message Byte Mapping in 8-bit NAND .....                       | 2177 |

|        |                                                                             |      |
|--------|-----------------------------------------------------------------------------|------|
| 10-8.  | Aligned Message Byte Mapping in 16-bit NAND .....                           | 2177 |
| 10-9.  | Aligned Nibble Mapping of Message in 8-bit NAND .....                       | 2177 |
| 10-10. | Misaligned Nibble Mapping of Message in 8-bit NAND .....                    | 2178 |
| 10-11. | Aligned Nibble Mapping of Message in 16-bit NAND.....                       | 2178 |
| 10-12. | Misaligned Nibble Mapping of Message in 16-bit NAND (1 Unused Nibble) ..... | 2178 |
| 10-13. | Misaligned Nibble Mapping of Message in 16-bit NAND (2 Unused Nibbles)..... | 2178 |
| 10-14. | Misaligned Nibble Mapping of Message in 16-bit NAND (3 Unused Nibbles)..... | 2178 |
| 10-15. | Prefetch Mode Configuration .....                                           | 2188 |
| 10-16. | Write-Posting Mode Configuration .....                                      | 2190 |
| 10-17. | GPMC Signals .....                                                          | 2193 |
| 10-18. | Useful Timing Parameters on the Memory Side.....                            | 2194 |
| 10-19. | Calculating GPMC Timing Parameters .....                                    | 2195 |
| 10-20. | AC Characteristics for Asynchronous Read Access .....                       | 2196 |
| 10-21. | GPMC Timing Parameters for Asynchronous Read Access.....                    | 2197 |
| 10-22. | AC Characteristics for Asynchronous Single Write ( Memory Side) .....       | 2198 |
| 10-23. | GPMC Timing parameters for Asynchronous Single Write .....                  | 2198 |
| 10-24. | Supported Memory Interfaces .....                                           | 2199 |
| 10-25. | NAND Interface Bus Operations Summary .....                                 | 2200 |
| 10-26. | NOR Interface Bus Operations Summary .....                                  | 2201 |
| 10-27. | GPMC Instance Summary.....                                                  | 2202 |
| 10-28. | GPMC Registers Mapping Summary .....                                        | 2202 |
| 10-29. | GPMC_REVISION .....                                                         | 2203 |
| 10-30. | Register Call Summary for Register GPMC_REVISION .....                      | 2203 |
| 10-31. | GPMC_SYSCONFIG .....                                                        | 2203 |
| 10-32. | Register Call Summary for Register GPMC_SYSCONFIG .....                     | 2204 |
| 10-33. | GPMC_SYSSTATUS .....                                                        | 2204 |
| 10-34. | Register Call Summary for Register GPMC_SYSSTATUS.....                      | 2204 |
| 10-35. | GPMC_IRQSTATUS .....                                                        | 2205 |
| 10-36. | Register Call Summary for Register GPMC_IRQSTATUS .....                     | 2206 |
| 10-37. | GPMC_IRQENABLE .....                                                        | 2206 |
| 10-38. | Register Call Summary for Register GPMC_IRQENABLE .....                     | 2207 |
| 10-39. | GPMC_TIMEOUT_CONTROL.....                                                   | 2207 |
| 10-40. | Register Call Summary for Register GPMC_TIMEOUT_CONTROL .....               | 2207 |
| 10-41. | GPMC_ERR_ADDRESS .....                                                      | 2208 |
| 10-42. | Register Call Summary for Register GPMC_ERR_ADDRESS.....                    | 2208 |
| 10-43. | GPMC_ERR_TYPE .....                                                         | 2208 |
| 10-44. | Register Call Summary for Register GPMC_ERR_TYPE.....                       | 2209 |
| 10-45. | GPMC_CONFIG .....                                                           | 2209 |
| 10-46. | Register Call Summary for Register GPMC_CONFIG .....                        | 2210 |
| 10-47. | GPMC_STATUS.....                                                            | 2210 |
| 10-48. | Register Call Summary for Register GPMC_STATUS .....                        | 2211 |
| 10-49. | GPMC_CONFIG1_i .....                                                        | 2211 |
| 10-50. | Register Call Summary for Register GPMC_CONFIG1_i.....                      | 2213 |
| 10-51. | GPMC_CONFIG2_i .....                                                        | 2213 |
| 10-52. | Register Call Summary for Register GPMC_CONFIG2_i.....                      | 2214 |
| 10-53. | GPMC_CONFIG3_i .....                                                        | 2214 |
| 10-54. | Register Call Summary for Register GPMC_CONFIG3_i.....                      | 2215 |
| 10-55. | GPMC_CONFIG4_i .....                                                        | 2215 |
| 10-56. | Register Call Summary for Register GPMC_CONFIG4_i.....                      | 2216 |

---

|                                                                                                        |      |
|--------------------------------------------------------------------------------------------------------|------|
| 10-57. GPMC_CONFIG5_i .....                                                                            | 2216 |
| 10-58. Register Call Summary for Register GPMC_CONFIG5_i .....                                         | 2217 |
| 10-59. GPMC_CONFIG6_i .....                                                                            | 2217 |
| 10-60. Register Call Summary for Register GPMC_CONFIG6_i .....                                         | 2218 |
| 10-61. GPMC_CONFIG7_i .....                                                                            | 2218 |
| 10-62. Register Call Summary for Register GPMC_CONFIG7_i .....                                         | 2219 |
| 10-63. GPMC_NAND_COMMAND_i .....                                                                       | 2219 |
| 10-64. Register Call Summary for Register GPMC_NAND_COMMAND_i .....                                    | 2219 |
| 10-65. GPMC_NAND_ADDRESS_i .....                                                                       | 2219 |
| 10-66. Register Call Summary for Register GPMC_NAND_ADDRESS_i .....                                    | 2220 |
| 10-67. GPMC_NAND_DATA_i .....                                                                          | 2220 |
| 10-68. Register Call Summary for Register GPMC_NAND_DATA_i .....                                       | 2220 |
| 10-69. GPMC_PREFETCH_CONFIG1 .....                                                                     | 2220 |
| 10-70. Register Call Summary for Register GPMC_PREFETCH_CONFIG1 .....                                  | 2222 |
| 10-71. GPMC_PREFETCH_CONFIG2 .....                                                                     | 2222 |
| 10-72. Register Call Summary for Register GPMC_PREFETCH_CONFIG2 .....                                  | 2222 |
| 10-73. GPMC_PREFETCH_CONTROL .....                                                                     | 2222 |
| 10-74. Register Call Summary for Register GPMC_PREFETCH_CONTROL .....                                  | 2223 |
| 10-75. GPMC_PREFETCH_STATUS .....                                                                      | 2223 |
| 10-76. Register Call Summary for Register GPMC_PREFETCH_STATUS .....                                   | 2224 |
| 10-77. GPMC_ECC_CONFIG .....                                                                           | 2224 |
| 10-78. Register Call Summary for Register GPMC_ECC_CONFIG .....                                        | 2225 |
| 10-79. GPMC_ECC_CONTROL .....                                                                          | 2225 |
| 10-80. Register Call Summary for Register GPMC_ECC_CONTROL .....                                       | 2226 |
| 10-81. GPMC_ECC_SIZE_CONFIG .....                                                                      | 2226 |
| 10-82. Register Call Summary for Register GPMC_ECC_SIZE_CONFIG .....                                   | 2227 |
| 10-83. GPMC_ECCj_RESULT .....                                                                          | 2227 |
| 10-84. Register Call Summary for Register GPMC_ECCj_RESULT .....                                       | 2228 |
| 10-85. GPMC_BCH_RESULT0_i .....                                                                        | 2228 |
| 10-86. Register Call Summary for Register GPMC_BCH_RESULT0_i .....                                     | 2228 |
| 10-87. GPMC_BCH_RESULT1_i .....                                                                        | 2229 |
| 10-88. Register Call Summary for Register GPMC_BCH_RESULT1_i .....                                     | 2229 |
| 10-89. GPMC_BCH_RESULT2_i .....                                                                        | 2229 |
| 10-90. Register Call Summary for Register GPMC_BCH_RESULT2_i .....                                     | 2229 |
| 10-91. GPMC_BCH_RESULT3_i .....                                                                        | 2229 |
| 10-92. Register Call Summary for Register GPMC_BCH_RESULT3_i .....                                     | 2230 |
| 10-93. GPMC_BCH_SWDATA .....                                                                           | 2230 |
| 10-94. Register Call Summary for Register GPMC_BCH_SWDATA .....                                        | 2230 |
| 10-95. SDRC Subsystem I/O Description .....                                                            | 2234 |
| 10-96. SDRC Address Multiplexing Scheme Selection vs SDRAM Configurations (x16 Memory Interface) ..... | 2236 |
| 10-97. SDRC Address Multiplexing Scheme Selection vs SDRAM Configurations (x32 Memory Interface) ..... | 2236 |
| 10-98. Arbitration Class Allocation .....                                                              | 2245 |
| 10-99. ReqInfo Parameters Ordering .....                                                               | 2248 |
| 10-100. VRFB Contexts Virtual Address Spaces vs Rotation Angle .....                                   | 2251 |
| 10-101. Mobile DDR SDRAM AC Timing Parameters .....                                                    | 2259 |
| 10-102. SDRC Data Lane Configurations .....                                                            | 2260 |
| 10-103. Dynamic Power Saving Configurations .....                                                      | 2265 |
| 10-104. Memory Configuration .....                                                                     | 2275 |
| 10-105. Programmable AC Parameters .....                                                               | 2276 |

|                                                                         |      |
|-------------------------------------------------------------------------|------|
| 10-106. Nonprogrammable AC Parameters .....                             | 2276 |
| 10-107. Calculating Image Size .....                                    | 2289 |
| 10-108. SDRC and SMS Configuration Register Space .....                 | 2302 |
| 10-109. VRFB Contexts vs Rotation Angle .....                           | 2303 |
| 10-110. SDRAM vs SDRC Characteristics .....                             | 2307 |
| 10-111. SMS Instance Summary .....                                      | 2308 |
| 10-112. SMS Register Summary .....                                      | 2308 |
| 10-113. SMS_REVISION .....                                              | 2309 |
| 10-114. Register Call Summary for Register SMS_REVISION .....           | 2309 |
| 10-115. SMS_SYSCONFIG .....                                             | 2309 |
| 10-116. Register Call Summary for Register SMS_SYSCONFIG .....          | 2310 |
| 10-117. SMS_SYSSTATUS .....                                             | 2310 |
| 10-118. Register Call Summary for Register SMS_SYSSTATUS .....          | 2310 |
| 10-119. SMS_RG_ATTi .....                                               | 2310 |
| 10-120. Register Call Summary for Register SMS_RG_ATTi .....            | 2311 |
| 10-121. SMS_RG_RDPERMi .....                                            | 2311 |
| 10-122. Register Call Summary for Register SMS_RG_RDPERMi .....         | 2311 |
| 10-123. SMS_RG_WRPERMi .....                                            | 2311 |
| 10-124. Register Call Summary for Register SMS_RG_WRPERMi .....         | 2312 |
| 10-125. SMS_RG_STARTj .....                                             | 2312 |
| 10-126. Register Call Summary for Register SMS_RG_STARTj .....          | 2312 |
| 10-127. SMS_RG_ENDj .....                                               | 2312 |
| 10-128. Register Call Summary for Register SMS_RG_ENDj .....            | 2313 |
| 10-129. SMS_CLASS_ARBITER0 .....                                        | 2313 |
| 10-130. Register Call Summary for Register SMS_CLASS_ARBITER0 .....     | 2313 |
| 10-131. SMS_CLASS_ARBITER1 .....                                        | 2314 |
| 10-132. Register Call Summary for Register SMS_CLASS_ARBITER1 .....     | 2314 |
| 10-133. SMS_CLASS_ARBITER2 .....                                        | 2315 |
| 10-134. Register Call Summary for Register SMS_CLASS_ARBITER2 .....     | 2315 |
| 10-135. SMS_INTERCLASS_ARBITER .....                                    | 2316 |
| 10-136. Register Call Summary for Register SMS_INTERCLASS_ARBITER ..... | 2316 |
| 10-137. SMS_CLASS_ROTATIONm .....                                       | 2316 |
| 10-138. Register Call Summary for Register SMS_CLASS_ROTATIONm .....    | 2316 |
| 10-139. SMS_ERR_ADDR .....                                              | 2317 |
| 10-140. Register Call Summary for Register SMS_ERR_ADDR .....           | 2317 |
| 10-141. SMS_ERR_TYPE .....                                              | 2317 |
| 10-142. Register Call Summary for Register SMS_ERR_TYPE .....           | 2318 |
| 10-143. SMS_POW_CTRL .....                                              | 2319 |
| 10-144. Register Call Summary for Register SMS_POW_CTRL .....           | 2319 |
| 10-145. SMS_ROT_CONTROLn .....                                          | 2319 |
| 10-146. Register Call Summary for Register SMS_ROT_CONTROLn .....       | 2319 |
| 10-147. SMS_ROT_SIZEn .....                                             | 2320 |
| 10-148. Register Call Summary for Register SMS_ROT_SIZEn .....          | 2320 |
| 10-149. SMS_ROT_PHYSICAL_BAn .....                                      | 2320 |
| 10-150. Register Call Summary for Register SMS_ROT_PHYSICAL_BAn .....   | 2320 |
| 10-151. SDRC Instance Summary .....                                     | 2321 |
| 10-152. SDRC Register Summary .....                                     | 2321 |
| 10-153. SDRC_REVISION .....                                             | 2322 |
| 10-154. Register Call Summary for Register SDRC_REVISION .....          | 2322 |

---

|                                                                             |      |
|-----------------------------------------------------------------------------|------|
| 10-155. SDRC_SYSCONFIG.....                                                 | 2322 |
| 10-156. Register Call Summary for Register SDRC_SYSCONFIG .....             | 2323 |
| 10-157. SDRC_SYSSTATUS .....                                                | 2323 |
| 10-158. Register Call Summary for Register SDRC_SYSSTATUS .....             | 2323 |
| 10-159. SDRC_CS_CFG .....                                                   | 2324 |
| 10-160. Register Call Summary for Register SDRC_CS_CFG .....                | 2324 |
| 10-161. SDRC_SHARING .....                                                  | 2324 |
| 10-162. Register Call Summary for Register SDRC_SHARING.....                | 2325 |
| 10-163. SDRC_ERR_ADDR.....                                                  | 2325 |
| 10-164. Register Call Summary for Register SDRC_ERR_ADDR .....              | 2326 |
| 10-165. SDRC_ERR_TYPE .....                                                 | 2326 |
| 10-166. Register Call Summary for Register SDRC_ERR_TYPE.....               | 2327 |
| 10-167. SDRC_DLLA_CTRL .....                                                | 2327 |
| 10-168. Register Call Summary for Register SDRC_DLLA_CTRL.....              | 2328 |
| 10-169. SDRC_DLLA_STATUS.....                                               | 2328 |
| 10-170. Register Call Summary for Register SDRC_DLLA_STATUS .....           | 2328 |
| 10-171. SDRC_POWER_REG .....                                                | 2329 |
| 10-172. Register Call Summary for Register SDRC_POWER_REG .....             | 2330 |
| 10-173. SDRC_MCFG_p .....                                                   | 2330 |
| 10-174. Register Call Summary for Register SDRC_MCFG_p .....                | 2331 |
| 10-175. SDRC_MR_p .....                                                     | 2333 |
| 10-176. Register Call Summary for Register SDRC_MR_p.....                   | 2334 |
| 10-177. SDRC_EMR2_p .....                                                   | 2334 |
| 10-178. Register Call Summary for Register SDRC_EMR2_p .....                | 2335 |
| 10-179. SDRC_ACTIM_CTRLA_p.....                                             | 2335 |
| 10-180. Register Call Summary for Register SDRC_ACTIM_CTRLA_p .....         | 2336 |
| 10-181. SDRC_ACTIM_CTRLB_p.....                                             | 2336 |
| 10-182. Register Call Summary for Register SDRC_ACTIM_CTRLB_p .....         | 2337 |
| 10-183. SDRC_RFR_CTRL_p .....                                               | 2337 |
| 10-184. Register Call Summary for Register SDRC_RFR_CTRL_p .....            | 2337 |
| 10-185. SDRC_MANUAL_p .....                                                 | 2337 |
| 10-186. Register Call Summary for Register SDRC_MANUAL_p .....              | 2338 |
| 11-1. External SDMA Request Signals .....                                   | 2346 |
| 11-2. SDMA Interrupts .....                                                 | 2351 |
| 11-3. SDMA Request Mapping .....                                            | 2351 |
| 11-4. Parameter Values for Addressing Mode Examples (a), (b), and (c) ..... | 2359 |
| 11-5. Equations for Rotation .....                                          | 2359 |
| 11-6. Example Parameter Values for a 90° Clockwise Image Rotation.....      | 2360 |
| 11-7. Buffering Disable .....                                               | 2363 |
| 11-8. Logical DMA Channel Events.....                                       | 2366 |
| 11-9. Type 1.....                                                           | 2371 |
| 11-10. Type 2 With Source and Destination Address Updates .....             | 2372 |
| 11-11. Type 2 With Source or Destination Address Update .....               | 2372 |
| 11-12. Type 3 With Source and Destination Address Updates .....             | 2372 |
| 11-13. Type 3 With Source or Destination Address Update .....               | 2373 |
| 11-14. SDMA Instance Summary .....                                          | 2383 |
| 11-15. SDMA Register Summary .....                                          | 2383 |
| 11-16. DMA4_REVISION .....                                                  | 2384 |
| 11-17. Register Call Summary for Register DMA4_REVISION.....                | 2384 |

|                                                                    |      |
|--------------------------------------------------------------------|------|
| 11-18. DMA4 IRQSTATUS_Lj .....                                     | 2384 |
| 11-19. Register Call Summary for Register DMA4 IRQSTATUS_Lj .....  | 2385 |
| 11-20. DMA4 IRQENABLE_Lj .....                                     | 2385 |
| 11-21. Register Call Summary for Register DMA4 IRQENABLE_Lj .....  | 2385 |
| 11-22. DMA4 SYSSTATUS .....                                        | 2385 |
| 11-23. Register Call Summary for Register DMA4 SYSSTATUS .....     | 2386 |
| 11-24. DMA4_OCP_SYSCONFIG .....                                    | 2386 |
| 11-25. Register Call Summary for Register DMA4_OCP_SYSCONFIG ..... | 2387 |
| 11-26. DMA4_CAPS_0 .....                                           | 2387 |
| 11-27. Register Call Summary for Register DMA4_CAPS_0 .....        | 2388 |
| 11-28. DMA4_CAPS_2 .....                                           | 2388 |
| 11-29. Register Call Summary for Register DMA4_CAPS_2 .....        | 2389 |
| 11-30. DMA4_CAPS_3 .....                                           | 2389 |
| 11-31. Register Call Summary for Register DMA4_CAPS_3 .....        | 2390 |
| 11-32. DMA4_CAPS_4 .....                                           | 2391 |
| 11-33. Register Call Summary for Register DMA4_CAPS_4 .....        | 2392 |
| 11-34. DMA4_GCR .....                                              | 2392 |
| 11-35. Register Call Summary for Register DMA4_GCR .....           | 2393 |
| 11-36. DMA4_CCRi .....                                             | 2394 |
| 11-37. Register Call Summary for Register DMA4_CCRi .....          | 2396 |
| 11-38. DMA4_CLNK_CTRLi .....                                       | 2397 |
| 11-39. Register Call Summary for Register DMA4_CLNK_CTRLi .....    | 2397 |
| 11-40. DMA4_CICRi .....                                            | 2397 |
| 11-41. Register Call Summary for Register DMA4_CICRi .....         | 2399 |
| 11-42. DMA4_CSRi .....                                             | 2399 |
| 11-43. Register Call Summary for Register DMA4_CSRi .....          | 2401 |
| 11-44. DMA4_CSDPi .....                                            | 2401 |
| 11-45. Register Call Summary for Register DMA4_CSDPi .....         | 2403 |
| 11-46. DMA4_CENi .....                                             | 2403 |
| 11-47. Register Call Summary for Register DMA4_CENi .....          | 2403 |
| 11-48. DMA4_CFNi .....                                             | 2404 |
| 11-49. Register Call Summary for Register DMA4_CFNi .....          | 2404 |
| 11-50. DMA4_CSSAi .....                                            | 2404 |
| 11-51. Register Call Summary for Register DMA4_CSSAi .....         | 2404 |
| 11-52. DMA4_CDSSAi .....                                           | 2405 |
| 11-53. Register Call Summary for Register DMA4_CDSSAi .....        | 2405 |
| 11-54. DMA4_CSEli .....                                            | 2405 |
| 11-55. Register Call Summary for Register DMA4_CSEli .....         | 2405 |
| 11-56. DMA4_CSFl .....                                             | 2406 |
| 11-57. Register Call Summary for Register DMA4_CSFl .....          | 2406 |
| 11-58. DMA4_CDFl .....                                             | 2406 |
| 11-59. Register Call Summary for Register DMA4_CDFl .....          | 2406 |
| 11-60. DMA4_CDFli .....                                            | 2407 |
| 11-61. Register Call Summary for Register DMA4_CDFli .....         | 2407 |
| 11-62. DMA4_CSACi .....                                            | 2407 |
| 11-63. Register Call Summary for Register DMA4_CSACi .....         | 2407 |
| 11-64. DMA4_CDACi .....                                            | 2408 |
| 11-65. Register Call Summary for Register DMA4_CDACi .....         | 2408 |
| 11-66. DMA4_CCENi .....                                            | 2408 |

---

|                                                                     |      |
|---------------------------------------------------------------------|------|
| 11-67. Register Call Summary for Register DMA4_CCENi .....          | 2408 |
| 11-68. DMA4_CCFNi .....                                             | 2409 |
| 11-69. Register Call Summary for Register DMA4_CCFNi .....          | 2409 |
| 11-70. DMA4_COLORi .....                                            | 2409 |
| 11-71. Register Call Summary for Register DMA4_COLORi .....         | 2409 |
| 11-72. DMA4_CDPI .....                                              | 2410 |
| 11-73. Register Call Summary for Register DMA4_CDPI .....           | 2411 |
| 11-74. DMA4_CNDPi .....                                             | 2411 |
| 11-75. Register Call Summary for Register DMA4_CNDPi .....          | 2411 |
| 11-76. DMA4_CCDNi .....                                             | 2412 |
| 11-77. Register Call Summary for Register DMA4_CCDNi .....          | 2412 |
| 12-1. MPU Subsystem INTC Clock Rates .....                          | 2417 |
| 12-2. Hardware and Software Reset .....                             | 2418 |
| 12-3. Interrupt Lines Incoming and Outgoing .....                   | 2418 |
| 12-4. Interrupt Mapping to the MPU Subsystem .....                  | 2418 |
| 12-5. INTC Instance Summary .....                                   | 2433 |
| 12-6. MPU INTC Register Summary .....                               | 2433 |
| 12-7. Modem INTC Register Summary .....                             | 2434 |
| 12-8. INTCPS_REVISION .....                                         | 2434 |
| 12-9. Register Call Summary for Register INTCPS_REVISION .....      | 2434 |
| 12-10. INTCPS_SYSCONFIG .....                                       | 2434 |
| 12-11. Register Call Summary for Register INTCPS_SYSCONFIG .....    | 2435 |
| 12-12. INTCPS_SYSSTATUS .....                                       | 2435 |
| 12-13. Register Call Summary for Register INTCPS_SYSSTATUS .....    | 2435 |
| 12-14. INTCPS_SIR_IRQ .....                                         | 2436 |
| 12-15. Register Call Summary for Register INTCPS_SIR_IRQ .....      | 2436 |
| 12-16. INTCPS_SIR_FIQ .....                                         | 2436 |
| 12-17. Register Call Summary for Register INTCPS_SIR_FIQ .....      | 2436 |
| 12-18. INTCPS_CONTROL .....                                         | 2437 |
| 12-19. Register Call Summary for Register INTCPS_CONTROL .....      | 2437 |
| 12-20. INTCPS_PROTECTION .....                                      | 2437 |
| 12-21. Register Call Summary for Register INTCPS_PROTECTION .....   | 2438 |
| 12-22. INTCPS_IDLE .....                                            | 2438 |
| 12-23. Register Call Summary for Register INTCPS_IDLE .....         | 2438 |
| 12-24. INTCPS_IRQ_PRIORITY .....                                    | 2439 |
| 12-25. Register Call Summary for Register INTCPS_IRQ_PRIORITY ..... | 2439 |
| 12-26. INTCPS_FIQ_PRIORITY .....                                    | 2439 |
| 12-27. Register Call Summary for Register INTCPS_FIQ_PRIORITY ..... | 2439 |
| 12-28. INTCPS_THRESHOLD .....                                       | 2440 |
| 12-29. Register Call Summary for Register INTCPS_THRESHOLD .....    | 2440 |
| 12-30. INTCPS_ITRn .....                                            | 2440 |
| 12-31. Register Call Summary for Register INTCPS_ITRn .....         | 2440 |
| 12-32. INTCPS_MIRn .....                                            | 2441 |
| 12-33. Register Call Summary for Register INTCPS_MIRn .....         | 2441 |
| 12-34. INTCPS_MIR_CLEARn .....                                      | 2441 |
| 12-35. Register Call Summary for Register INTCPS_MIR_CLEARn .....   | 2441 |
| 12-36. INTCPS_MIR_SETn .....                                        | 2442 |
| 12-37. Register Call Summary for Register INTCPS_MIR_SETn .....     | 2442 |
| 12-38. INTCPS_ISR_SETn .....                                        | 2442 |

|                                                                                                   |      |
|---------------------------------------------------------------------------------------------------|------|
| 12-39. Register Call Summary for Register INTCPS_ISR_SETn .....                                   | 2442 |
| 12-40. INTCPS_ISR_CLEARn .....                                                                    | 2443 |
| 12-41. Register Call Summary for Register INTCPS_ISR_CLEARn.....                                  | 2443 |
| 12-42. INTCPS_PENDING_IRQn .....                                                                  | 2443 |
| 12-43. Register Call Summary for Register INTCPS_PENDING_IRQn .....                               | 2443 |
| 12-44. INTCPS_PENDING_FIQn.....                                                                   | 2444 |
| 12-45. Register Call Summary for Register INTCPS_PENDING_FIQn .....                               | 2444 |
| 12-46. INTCPS_ILRm .....                                                                          | 2444 |
| 12-47. Register Call Summary for Register INTCPS_ILRm.....                                        | 2444 |
| 12-48. INTC_SYSCONFIG .....                                                                       | 2445 |
| 12-49. Register Call Summary for Register INTC_SYSCONFIG .....                                    | 2445 |
| 12-50. INTC_IDLE .....                                                                            | 2445 |
| 12-51. Register Call Summary for Register INTC_IDLE.....                                          | 2446 |
| 13-1. SCM I/O Description .....                                                                   | 2450 |
| 13-2. Mode Selection .....                                                                        | 2458 |
| 13-3. Pull Selection.....                                                                         | 2459 |
| 13-4. Core Control Module Pad Configuration Register Fields.....                                  | 2460 |
| 13-5. Core Control Module D2D Pad Configuration Register Fields .....                             | 2470 |
| 13-6. Wkup Control Module Pad Configuration Register Fields.....                                  | 2473 |
| 13-7. Bit Directions for CONTROL_PADCONF_x Registers .....                                        | 2478 |
| 13-8. PBIAS Cell and Extended-Drain I/O Pin Bit Controls.....                                     | 2480 |
| 13-9. Power Supplies .....                                                                        | 2480 |
| 13-10. Band Gap Voltage and Temperature Sensor Signals Description .....                          | 2484 |
| 13-11. ADC Code Versus Temperature.....                                                           | 2486 |
| 13-12. Static Device Configuration Registers .....                                                | 2487 |
| 13-13. MSuspendMux Control Registers .....                                                        | 2487 |
| 13-14. IVA2.2 Boot Registers .....                                                                | 2488 |
| 13-15. IVA2.2 Boot Modes.....                                                                     | 2488 |
| 13-16. PBIAS Control Register.....                                                                | 2488 |
| 13-17. Temperature Sensor Register .....                                                          | 2489 |
| 13-18. Signal Integrity Parameter Control Registers .....                                         | 2489 |
| 13-19. DS Parameter Settings .....                                                                | 2489 |
| 13-20. LB Parameter Settings for High-Speed I/O Cells .....                                       | 2490 |
| 13-21. Recommended SC vs LB Parameter Settings for TL With Length in the Range 2–20cm.....        | 2490 |
| 13-22. Recommended SC vs LB Parameter Settings for Dual TL With Length in the Range 20–40cm ..... | 2490 |
| 13-23. Group Pullup Strength Setting for SDMMC1 I/Os .....                                        | 2490 |
| 13-24. Example I2Cx Pullupresx vs I2C LB Parameter Settings in Different Modes .....              | 2491 |
| 13-25. Internal Pullup Resistor in Fast/HS Mode .....                                             | 2491 |
| 13-26. Signal Group Parameter Controls to Different Interface I/O Pads Mapping .....              | 2491 |
| 13-27. Protection Status Registers .....                                                          | 2497 |
| 13-28. SDRC Registers .....                                                                       | 2498 |
| 13-29. Observability Registers .....                                                              | 2499 |
| 13-30. Internal Signals Multiplexed on OBSMUX0 .....                                              | 2501 |
| 13-31. Internal Signals Multiplexed on OBSMUX1 .....                                              | 2502 |
| 13-32. Internal Signals Multiplexed on OBSMUX2 .....                                              | 2502 |
| 13-33. Internal Signals Multiplexed on OBSMUX3 .....                                              | 2503 |
| 13-34. Internal Signals Multiplexed on OBSMUX4 .....                                              | 2504 |
| 13-35. Internal Signals Multiplexed on OBSMUX5 .....                                              | 2505 |
| 13-36. Internal Signals Multiplexed on OBSMUX6 .....                                              | 2505 |

---

|                                                                    |      |
|--------------------------------------------------------------------|------|
| 13-37. Internal Signals Multiplexed on OBSMUX7 .....               | 2507 |
| 13-38. Internal Signals Multiplexed on OBSMUX8 .....               | 2508 |
| 13-39. Internal Signals Multiplexed on OBSMUX9 .....               | 2509 |
| 13-40. Internal Signals Multiplexed on OBSMUX10.....               | 2510 |
| 13-41. Internal Signals Multiplexed on OBSMUX11.....               | 2511 |
| 13-42. Internal Signals Multiplexed on OBSMUX12.....               | 2512 |
| 13-43. Internal Signals Multiplexed on OBSMUX13.....               | 2512 |
| 13-44. Internal Signals Multiplexed on OBSMUX14.....               | 2513 |
| 13-45. Internal Signals Multiplexed on OBSMUX15.....               | 2514 |
| 13-46. Internal Signals Multiplexed on OBSMUX16.....               | 2515 |
| 13-47. Internal Signals Multiplexed on OBSMUX17.....               | 2516 |
| 13-48. Internal Signals Multiplexed on WKUPOBSMUX0 .....           | 2517 |
| 13-49. Internal Signals Multiplexed on WKUPOBSMUX1 .....           | 2518 |
| 13-50. Internal Signals Multiplexed on WKUPOBSMUX2 .....           | 2519 |
| 13-51. Internal Signals Multiplexed on WKUPOBSMUX3 .....           | 2520 |
| 13-52. Internal Signals Multiplexed on WKUPOBSMUX4 .....           | 2521 |
| 13-53. Internal Signals Multiplexed on WKUPOBSMUX5 .....           | 2522 |
| 13-54. Internal Signals Multiplexed on WKUPOBSMUX6 .....           | 2523 |
| 13-55. Internal Signals Multiplexed on WKUPOBSMUX7 .....           | 2524 |
| 13-56. Internal Signals Multiplexed on WKUPOBSMUX8 .....           | 2525 |
| 13-57. Internal Signals Multiplexed on WKUPOBSMUX9 .....           | 2526 |
| 13-58. Internal Signals Multiplexed on WKUPOBSMUX10 .....          | 2527 |
| 13-59. Internal Signals Multiplexed on WKUPOBSMUX11 .....          | 2528 |
| 13-60. Internal Signals Multiplexed on WKUPOBSMUX12 .....          | 2529 |
| 13-61. Internal Signals Multiplexed on WKUPOBSMUX13 .....          | 2530 |
| 13-62. Internal Signals Multiplexed on WKUPOBSMUX14 .....          | 2531 |
| 13-63. Internal Signals Multiplexed on WKUPOBSMUX15 .....          | 2532 |
| 13-64. Internal Signals Multiplexed on WKUPOBSMUX16 .....          | 2533 |
| 13-65. Internal Signals Multiplexed on WKUPOBSMUX17 .....          | 2534 |
| 13-66. Control Signals.....                                        | 2549 |
| 13-67. Voltage Configuration .....                                 | 2550 |
| 13-68. PBIAS Error Signal Truth Table .....                        | 2552 |
| 13-69. Pin Types .....                                             | 2555 |
| 13-70. Recommended Configuration For Unconnected Device Pads ..... | 2558 |
| 13-71. SCM Instance Summary.....                                   | 2559 |
| 13-72. INTERFACE Register Summary .....                            | 2559 |
| 13-73. PADCONFS Register Summary.....                              | 2559 |
| 13-74. GENERAL Register Summary .....                              | 2563 |
| 13-75. MEM_WKUP Register Summary .....                             | 2566 |
| 13-76. PADCONFS_WKUP Register Summary .....                        | 2566 |
| 13-77. GENERAL_WKUP Register Summary .....                         | 2567 |
| 13-78. CONTROL_REVISION .....                                      | 2567 |
| 13-79. Register Call Summary for Register CONTROL_REVISION .....   | 2567 |
| 13-80. CONTROL_SYSCONFIG .....                                     | 2568 |
| 13-81. Register Call Summary for Register CONTROL_SYSCONFIG .....  | 2568 |
| 13-82. CONTROL_PADCONF_X.....                                      | 2569 |
| 13-83. Register Call Summary for Register CONTROL_PADCONF_X .....  | 2570 |
| 13-84. CONTROL_PADCONF_CAPABILITIES .....                          | 2571 |
| 13-85. CONTROL_PADCONF_OFF .....                                   | 2582 |

|                                                                                |      |
|--------------------------------------------------------------------------------|------|
| 13-86. Register Call Summary for Register CONTROL_PADCONF_OFF .....            | 2582 |
| 13-87. CONTROL_DEVCONF0.....                                                   | 2583 |
| 13-88. Register Call Summary for Register CONTROL_DEVCONF0 .....               | 2583 |
| 13-89. CONTROL_MSUSPENDMUX_0 .....                                             | 2584 |
| 13-90. Register Call Summary for Register CONTROL_MSUSPENDMUX_0.....           | 2585 |
| 13-91. CONTROL_MSUSPENDMUX_1 .....                                             | 2585 |
| 13-92. Register Call Summary for Register CONTROL_MSUSPENDMUX_1.....           | 2588 |
| 13-93. CONTROL_MSUSPENDMUX_2 .....                                             | 2588 |
| 13-94. Register Call Summary for Register CONTROL_MSUSPENDMUX_2.....           | 2591 |
| 13-95. CONTROL_MSUSPENDMUX_3 .....                                             | 2591 |
| 13-96. Register Call Summary for Register CONTROL_MSUSPENDMUX_3.....           | 2592 |
| 13-97. CONTROL_MSUSPENDMUX_4 .....                                             | 2592 |
| 13-98. Register Call Summary for Register CONTROL_MSUSPENDMUX_4.....           | 2592 |
| 13-99. CONTROL_MSUSPENDMUX_5 .....                                             | 2593 |
| 13-100. Register Call Summary for Register CONTROL_MSUSPENDMUX_5 .....         | 2594 |
| 13-101. CONTROL_PROT_CTRL.....                                                 | 2594 |
| 13-102. Register Call Summary for Register CONTROL_PROT_CTRL .....             | 2595 |
| 13-103. CONTROL_DEVCONF1 .....                                                 | 2595 |
| 13-104. Register Call Summary for Register CONTROL_DEVCONF1 .....              | 2597 |
| 13-105. CONTROL_PROT_ERR_STATUS .....                                          | 2597 |
| 13-106. Register Call Summary for Register CONTROL_PROT_ERR_STATUS.....        | 2598 |
| 13-107. CONTROL_PROT_ERR_STATUS_DEBUG .....                                    | 2599 |
| 13-108. Register Call Summary for Register CONTROL_PROT_ERR_STATUS_DEBUG ..... | 2600 |
| 13-109. CONTROL_STATUS .....                                                   | 2600 |
| 13-110. Register Call Summary for Register CONTROL_STATUS .....                | 2600 |
| 13-111. CONTROL_GENERAL_PURPOSE_STATUS .....                                   | 2601 |
| 13-112. Register Call Summary for Register CONTROL_GENERAL_PURPOSE_STATUS..... | 2601 |
| 13-113. CONTROL_RPUB_KEY_H_0 .....                                             | 2601 |
| 13-114. Register Call Summary for Register CONTROL_RPUB_KEY_H_0.....           | 2601 |
| 13-115. CONTROL_RPUB_KEY_H_1 .....                                             | 2602 |
| 13-116. Register Call Summary for Register CONTROL_RPUB_KEY_H_1.....           | 2602 |
| 13-117. CONTROL_RPUB_KEY_H_2 .....                                             | 2602 |
| 13-118. Register Call Summary for Register CONTROL_RPUB_KEY_H_2.....           | 2602 |
| 13-119. CONTROL_RPUB_KEY_H_3 .....                                             | 2602 |
| 13-120. Register Call Summary for Register CONTROL_RPUB_KEY_H_3.....           | 2602 |
| 13-121. CONTROL_RPUB_KEY_H_4 .....                                             | 2603 |
| 13-122. Register Call Summary for Register CONTROL_RPUB_KEY_H_4.....           | 2603 |
| 13-123. CONTROL_USB_CONF_0 .....                                               | 2603 |
| 13-124. Register Call Summary for Register CONTROL_USB_CONF_0.....             | 2603 |
| 13-125. CONTROL_USB_CONF_1 .....                                               | 2603 |
| 13-126. Register Call Summary for Register CONTROL_USB_CONF_1.....             | 2604 |
| 13-127. CONTROL_FUSE OPP1G_VDD1 .....                                          | 2604 |
| 13-128. Register Call Summary for Register CONTROL_FUSE OPP1G_VDD1.....        | 2604 |
| 13-129. CONTROL_FUSE OPP50_VDD1 .....                                          | 2604 |
| 13-130. Register Call Summary for Register CONTROL_FUSE OPP50_VDD1 .....       | 2604 |
| 13-131. CONTROL_FUSE OPP100_VDD1 .....                                         | 2605 |
| 13-132. Register Call Summary for Register VDD1 .....                          | 2605 |
| 13-133. CONTROL_FUSE OPP130_VDD1 .....                                         | 2605 |
| 13-134. Register Call Summary for Register CONTROL_FUSE OPP130_VDD1 .....      | 2605 |

---

|                                                                                 |      |
|---------------------------------------------------------------------------------|------|
| 13-135. CONTROL_FUSE_OPP50_VDD2 .....                                           | 2606 |
| 13-136. Register Call Summary for Register CONTROL_FUSE_OPP50_VDD2 .....        | 2606 |
| 13-137. CONTROL_FUSE_OPP100_VDD2 .....                                          | 2606 |
| 13-138. Register Call Summary for Register CONTROL_FUSE_OPP100_VDD2 .....       | 2606 |
| 13-139. CONTROL_FUSE_SR .....                                                   | 2606 |
| 13-140. Register Call Summary for Register CONTROL_FUSE_SR .....                | 2607 |
| 13-141. CONTROL_IVA2_BOOTADDR .....                                             | 2607 |
| 13-142. Register Call Summary for Register CONTROL_IVA2_BOOTADDR .....          | 2607 |
| 13-143. CONTROL_IVA2_BOOTMOD .....                                              | 2607 |
| 13-144. Register Call Summary for Register CONTROL_IVA2_BOOTMOD .....           | 2607 |
| 13-145. CONTROL_PROG_IO2 .....                                                  | 2608 |
| 13-146. Register Call Summary for Register CONTROL_PROG_IO2 .....               | 2610 |
| 13-147. CONTROL_MEM_RTA_CTRL .....                                              | 2611 |
| 13-148. Register Call Summary for Register CONTROL_MEM_RTA_CTRL .....           | 2611 |
| 13-149. CONTROL_DEBOBS_0 .....                                                  | 2611 |
| 13-150. Register Call Summary for Register CONTROL_DEBOBS_0 .....               | 2611 |
| 13-151. CONTROL_DEBOBS_1 .....                                                  | 2612 |
| 13-152. Register Call Summary for Register CONTROL_DEBOBS_1 .....               | 2612 |
| 13-153. CONTROL_DEBOBS_2 .....                                                  | 2612 |
| 13-154. Register Call Summary for Register CONTROL_DEBOBS_2 .....               | 2612 |
| 13-155. CONTROL_DEBOBS_3 .....                                                  | 2613 |
| 13-156. Register Call Summary for Register CONTROL_DEBOBS_3 .....               | 2613 |
| 13-157. CONTROL_DEBOBS_4 .....                                                  | 2613 |
| 13-158. Register Call Summary for Register CONTROL_DEBOBS_4 .....               | 2613 |
| 13-159. CONTROL_DEBOBS_5 .....                                                  | 2614 |
| 13-160. Register Call Summary for Register CONTROL_DEBOBS_5 .....               | 2614 |
| 13-161. CONTROL_DEBOBS_6 .....                                                  | 2614 |
| 13-162. Register Call Summary for Register CONTROL_DEBOBS_6 .....               | 2614 |
| 13-163. CONTROL_DEBOBS_7 .....                                                  | 2615 |
| 13-164. Register Call Summary for Register CONTROL_DEBOBS_7 .....               | 2615 |
| 13-165. CONTROL_DEBOBS_8 .....                                                  | 2615 |
| 13-166. Register Call Summary for Register CONTROL_DEBOBS_8 .....               | 2615 |
| 13-167. CONTROL_PROG_IO0 .....                                                  | 2616 |
| 13-168. Register Call Summary for Register CONTROL_PROG_IO0 .....               | 2619 |
| 13-169. CONTROL_PROG_IO1 .....                                                  | 2619 |
| 13-170. Register Call Summary for Register CONTROL_PROG_IO1 .....               | 2622 |
| 13-171. CONTROL_DSS_DPLL_SPREADING .....                                        | 2622 |
| 13-172. Register Call Summary for Register CONTROL_DSS_DPLL_SPREADING .....     | 2623 |
| 13-173. CONTROL_CORE_DPLL_SPREADING .....                                       | 2623 |
| 13-174. Register Call Summary for Register CONTROL_CORE_DPLL_SPREADING .....    | 2624 |
| 13-175. CONTROL_PER_DPLL_SPREADING .....                                        | 2624 |
| 13-176. Register Call Summary for Register CONTROL_PER_DPLL_SPREADING .....     | 2625 |
| 13-177. CONTROL_USBHOST_DPLL_SPREADING .....                                    | 2625 |
| 13-178. Register Call Summary for Register CONTROL_USBHOST_DPLL_SPREADING ..... | 2625 |
| 13-179. CONTROL_SDRC_SHARING .....                                              | 2626 |
| 13-180. Register Call Summary for Register CONTROL_SDRC_SHARING .....           | 2626 |
| 13-181. CONTROL_SDRC_MCFG0 .....                                                | 2626 |
| 13-182. Register Call Summary for Register CONTROL_SDRC_MCFG0 .....             | 2627 |
| 13-183. CONTROL_SDRC_MCFG1 .....                                                | 2627 |

|                                                                                         |      |
|-----------------------------------------------------------------------------------------|------|
| 13-184. Register Call Summary for Register CONTROL_SDRC_MCFG1.....                      | 2627 |
| 13-185. CONTROL_MODEM_FW_CONFIGURATION_LOCK.....                                        | 2627 |
| 13-186. Register Call Summary for Register CONTROL_MODEM_FW_CONFIGURATION_LOCK .....    | 2628 |
| 13-187. Type Value For CONTROL_MODEM_FW_CONFIGURATION_LOCK.....                         | 2628 |
| 13-188. CONTROL_MODEM_MEMORY_RESOURCES_CONF .....                                       | 2628 |
| 13-189. Register Call Summary for Register CONTROL_MODEM_MEMORY_RESOURCES_CONF.....     | 2629 |
| 13-190. Type Value For CONTROL_MODEM_MEMORY_RESOURCES_CONF .....                        | 2629 |
| 13-191. CONTROL_MODEM_GPMC_DT_FW_REQ_INFO .....                                         | 2629 |
| 13-192. Register Call Summary for Register CONTROL_MODEM_GPMC_DT_FW_REQ_INFO .....      | 2629 |
| 13-193. Type Value For CONTROL_MODEM_GPMC_DT_FW_REQ_INFO .....                          | 2629 |
| 13-194. CONTROL_MODEM_GPMC_DT_FW_RD.....                                                | 2629 |
| 13-195. Register Call Summary for Register CONTROL_MODEM_GPMC_DT_FW_RD .....            | 2630 |
| 13-196. Type Value For CONTROL_MODEM_GPMC_DT_FW_RD .....                                | 2630 |
| 13-197. CONTROL_MODEM_GPMC_DT_FW_WR .....                                               | 2630 |
| 13-198. Register Call Summary for Register CONTROL_MODEM_GPMC_DT_FW_WR.....             | 2630 |
| 13-199. Type Value For CONTROL_MODEM_GPMC_DT_FW_WR.....                                 | 2630 |
| 13-200. CONTROL_MODEM_GPMC_BOOT_CODE.....                                               | 2630 |
| 13-201. Register Call Summary for Register CONTROL_MODEM_GPMC_BOOT_CODE .....           | 2631 |
| 13-202. Type Value For CONTROL_MODEM_GPMC_BOOT_CODE .....                               | 2631 |
| 13-203. CONTROL_MODEM_SMS_RG_ATT1.....                                                  | 2631 |
| 13-204. Register Call Summary for Register CONTROL_MODEM_SMS_RG_ATT1 .....              | 2632 |
| 13-205. Type Value For CONTROL_MODEM_SMS_RG_ATT1 .....                                  | 2632 |
| 13-206. CONTROL_MODEM_SMS_RG_RDPERM1 .....                                              | 2632 |
| 13-207. Register Call Summary for Register CONTROL_MODEM_SMS_RG_RDPERM1 .....           | 2632 |
| 13-208. Type Value For CONTROL_MODEM_SMS_RG_RDPERM1.....                                | 2632 |
| 13-209. CONTROL_MODEM_SMS_RG_WRPERM1 .....                                              | 2632 |
| 13-210. Register Call Summary for Register CONTROL_MODEM_SMS_RG_WRPERM1 .....           | 2633 |
| 13-211. Type Value For CONTROL_MODEM_SMS_RG_WRPERM1 .....                               | 2633 |
| 13-212. CONTROL_MODEM_D2D_FW_DEBUG_MODE .....                                           | 2633 |
| 13-213. Register Call Summary for Register CONTROL_MODEM_D2D_FW_DEBUG_MODE .....        | 2633 |
| 13-214. Type Value For CONTROL_MODEM_D2D_FW_DEBUG_MODE .....                            | 2633 |
| 13-215. CONTROL_DPF_OCM_RAM_FW_ADDR_MATCH .....                                         | 2633 |
| 13-216. Register Call Summary for Register CONTROL_DPF_OCM_RAM_FW_ADDR_MATCH.....       | 2634 |
| 13-217. CONTROL_DPF_OCM_RAM_FW_REQINFO.....                                             | 2634 |
| 13-218. Register Call Summary for Register CONTROL_DPF_OCM_RAM_FW_REQINFO .....         | 2634 |
| 13-219. CONTROL_DPF_OCM_RAM_FW_WR.....                                                  | 2634 |
| 13-220. Register Call Summary for Register CONTROL_DPF_OCM_RAM_FW_WR .....              | 2634 |
| 13-221. CONTROL_DPF_REGION4_GPMC_FW_ADDR_MATCH .....                                    | 2635 |
| 13-222. Register Call Summary for Register CONTROL_DPF_REGION4_GPMC_FW_ADDR_MATCH.....  | 2635 |
| 13-223. CONTROL_DPF_REGION4_GPMC_FW_REQINFO.....                                        | 2635 |
| 13-224. Register Call Summary for Register CONTROL_DPF_REGION4_GPMC_FW_REQINFO .....    | 2635 |
| 13-225. CONTROL_DPF_REGION4_GPMC_FW_WR.....                                             | 2636 |
| 13-226. Register Call Summary for Register CONTROL_DPF_REGION4_GPMC_FW_WR .....         | 2636 |
| 13-227. CONTROL_DPF_REGION1_IVA2_FW_ADDR_MATCH.....                                     | 2636 |
| 13-228. Register Call Summary for Register CONTROL_DPF_REGION1_IVA2_FW_ADDR_MATCH ..... | 2636 |
| 13-229. CONTROL_DPF_REGION1_IVA2_FW_REQINFO .....                                       | 2636 |
| 13-230. Register Call Summary for Register CONTROL_DPF_REGION1_IVA2_FW_REQINFO.....     | 2637 |
| 13-231. CONTROL_DPF_REGION1_IVA2_FW_WR .....                                            | 2637 |
| 13-232. Register Call Summary for Register CONTROL_DPF_REGION1_IVA2_FW_WR .....         | 2637 |

---

|                                                                                     |      |
|-------------------------------------------------------------------------------------|------|
| 13-233. CONTROL_PBIAS_LITE .....                                                    | 2637 |
| 13-234. Register Call Summary for Register CONTROL_PBIAS_LITE .....                 | 2638 |
| 13-235. CONTROL_TEMP_SENSOR .....                                                   | 2639 |
| 13-236. Register Call Summary for Register CONTROL_TEMP_SENSOR .....                | 2639 |
| 13-237. CONTROL_DPF_MAD2D_FW_ADDR_MATCH.....                                        | 2639 |
| 13-238. Register Call Summary for Register CONTROL_DPF_MAD2D_FW_ADDR_MATCH .....    | 2639 |
| 13-239. CONTROL_DPF_MAD2D_FW_REQINFO .....                                          | 2640 |
| 13-240. Register Call Summary for Register CONTROL_DPF_MAD2D_FW_REQINFO.....        | 2640 |
| 13-241. CONTROL_DPF_MAD2D_FW_WR .....                                               | 2640 |
| 13-242. Register Call Summary for Register CONTROL_DPF_MAD2D_FW_WR .....            | 2640 |
| 13-243. CONTROL_DSS_DPLL_SPREADING_FREQ.....                                        | 2640 |
| 13-244. Register Call Summary for Register CONTROL_DSS_DPLL_SPREADING_FREQ .....    | 2641 |
| 13-245. CONTROL_CORE_DPLL_SPREADING_FREQ .....                                      | 2641 |
| 13-246. Register Call Summary for Register CONTROL_CORE_DPLL_SPREADING_FREQ .....   | 2641 |
| 13-247. CONTROL_PER_DPLL_SPREADING_FREQ.....                                        | 2642 |
| 13-248. Register Call Summary for Register CONTROL_PER_DPLL_SPREADING_FREQ .....    | 2642 |
| 13-249. CONTROL_USBHOST_DPLL_SPREADING_FREQ .....                                   | 2642 |
| 13-250. Register Call Summary for Register CONTROL_USBHOST_DPLL_SPREADING_FREQ..... | 2643 |
| 13-251. CONTROL_AVDAC1 .....                                                        | 2643 |
| 13-252. Register Call Summary for Register CONTROL_AVDAC1.....                      | 2644 |
| 13-253. CONTROL_AVDAC2 .....                                                        | 2644 |
| 13-254. Register Call Summary for Register CONTROL_AVDAC2.....                      | 2645 |
| 13-255. CONTROL_CAMERA_PHY_CTRL.....                                                | 2645 |
| 13-256. Register Call Summary for Register CONTROL_CAMERA_PHY_CTRL .....            | 2645 |
| 13-257. CONTROL_IDCODE .....                                                        | 2646 |
| 13-258. Register Call Summary for Register CONTROL_IDCODE .....                     | 2646 |
| 13-259. CONTROL_PADCONF_WKUP_CAPABILITIES .....                                     | 2648 |
| 13-260. CONTROL_WKUP_CTRL .....                                                     | 2649 |
| 13-261. Register Call Summary for Register CONTROL_WKUP_CTRL.....                   | 2649 |
| 13-262. CONTROL_WKUP_DEBOBS_0 .....                                                 | 2650 |
| 13-263. Register Call Summary for Register CONTROL_WKUP_DEBOBS_0.....               | 2650 |
| 13-264. Type Value For CONTROL_WKUP_DEBOBS_0 Register .....                         | 2650 |
| 13-265. CONTROL_WKUP_DEBOBS_1 .....                                                 | 2650 |
| 13-266. Register Call Summary for Register CONTROL_WKUP_DEBOBS_1.....               | 2651 |
| 13-267. Type Value For CONTROL_WKUP_DEBOBS_1 Register .....                         | 2651 |
| 13-268. CONTROL_WKUP_DEBOBS_2 .....                                                 | 2651 |
| 13-269. Register Call Summary for Register CONTROL_WKUP_DEBOBS_2.....               | 2652 |
| 13-270. Type Value For CONTROL_WKUP_DEBOBS_2 Register .....                         | 2652 |
| 13-271. CONTROL_WKUP_DEBOBS_3 .....                                                 | 2652 |
| 13-272. Register Call Summary for Register CONTROL_WKUP_DEBOBS_3.....               | 2652 |
| 13-273. Type Value For CONTROL_WKUP_DEBOBS_3 Register .....                         | 2653 |
| 13-274. CONTROL_WKUP_DEBOBS_4 .....                                                 | 2653 |
| 13-275. Register Call Summary for Register CONTROL_WKUP_DEBOBS_4.....               | 2653 |
| 13-276. Type Value For CONTROL_WKUP_DEBOBS_4 Register .....                         | 2654 |
| 13-277. CONTROL_PROG_IO_WKUP1 .....                                                 | 2654 |
| 13-278. Register Call Summary for Register CONTROL_PROG_IO_WKUP1 .....              | 2656 |
| 13-279. CONTROL_BGAPTS_WKUP .....                                                   | 2656 |
| 13-280. Register Call Summary for Register CONTROL_BGAPTS_WKUP .....                | 2657 |
| 13-281. CONTROL_SRAM_LDO_CTRL.....                                                  | 2657 |

|                                                                         |      |
|-------------------------------------------------------------------------|------|
| 13-282. Register Call Summary for Register CONTROL_SRAM_LDO_CTRL .....  | 2657 |
| 13-283. CONTROL_VBBLDO_SW_CTRL.....                                     | 2657 |
| 13-284. Register Call Summary for Register CONTROL_VBBLDO_SW_CTRL ..... | 2658 |
| 14-1. Mailbox Power Management Modes.....                               | 2662 |
| 14-2. Mailbox Instance Summary .....                                    | 2672 |
| 14-3. MLB Register Summary .....                                        | 2672 |
| 14-4. MAILBOX_REVISION.....                                             | 2672 |
| 14-5. Register Call Summary for Register MAILBOX_REVISION .....         | 2673 |
| 14-6. MAILBOX_SYSCONFIG.....                                            | 2673 |
| 14-7. Register Call Summary for Register MAILBOX_SYSCONFIG .....        | 2674 |
| 14-8. MAILBOX_SYSSTATUS .....                                           | 2674 |
| 14-9. Register Call Summary for Register MAILBOX_SYSSTATUS .....        | 2674 |
| 14-10. MAILBOX_MESSAGE_m .....                                          | 2674 |
| 14-11. Register Call Summary for Register MAILBOX_MESSAGE_m .....       | 2675 |
| 14-12. MAILBOX_FIFOSTATUS_m .....                                       | 2675 |
| 14-13. Register Call Summary for Register MAILBOX_FIFOSTATUS_m .....    | 2675 |
| 14-14. MAILBOX_MSGSTATUS_m .....                                        | 2676 |
| 14-15. Register Call Summary for Register MAILBOX_MSGSTATUS_m .....     | 2676 |
| 14-16. MAILBOX_IRQSTATUS_u .....                                        | 2676 |
| 14-17. Register Call Summary for Register MAILBOX_IRQSTATUS_u.....      | 2677 |
| 14-18. MAILBOX_IRQENABLE_u .....                                        | 2677 |
| 14-19. Register Call Summary for Register MAILBOX_IRQENABLE_u.....      | 2677 |
| 15-1. Power Domains of the MMU Instances.....                           | 2682 |
| 15-2. Power Domains of the MMU Instances.....                           | 2682 |
| 15-3. Reset Domains of the MMU Instances .....                          | 2683 |
| 15-4. Interrupts of the MMU Instances .....                             | 2683 |
| 15-5. First-Level Descriptor Format .....                               | 2689 |
| 15-6. Second-Level Descriptor Format .....                              | 2692 |
| 15-7. Design Parameters of the MMU Instances.....                       | 2696 |
| 15-8. MMU Instance Summary .....                                        | 2703 |
| 15-9. MMU Register Summary .....                                        | 2703 |
| 15-10. MMU_REVISION .....                                               | 2704 |
| 15-11. Register Call Summary for Register MMU_REVISION.....             | 2704 |
| 15-12. MMU_SYSCONFIG .....                                              | 2704 |
| 15-13. Register Call Summary for Register MMU_SYSCONFIG.....            | 2705 |
| 15-14. MMU_SYSSTATUS .....                                              | 2705 |
| 15-15. Register Call Summary for Register MMU_SYSSTATUS.....            | 2705 |
| 15-16. MMU_IRQSTATUS.....                                               | 2706 |
| 15-17. Register Call Summary for Register MMU_IRQSTATUS .....           | 2706 |
| 15-18. MMU_IRQENABLE.....                                               | 2707 |
| 15-19. Register Call Summary for Register MMU_IRQENABLE .....           | 2707 |
| 15-20. MMU_WALKING_ST.....                                              | 2708 |
| 15-21. Register Call Summary for Register MMU_WALKING_ST .....          | 2708 |
| 15-22. MMU_CNTL .....                                                   | 2708 |
| 15-23. Register Call Summary for Register MMU_CNTL .....                | 2709 |
| 15-24. MMU_FAULT_AD .....                                               | 2709 |
| 15-25. Register Call Summary for Register MMU_FAULT_AD .....            | 2709 |
| 15-26. MMU_TTB .....                                                    | 2709 |
| 15-27. Register Call Summary for Register MMU_TTB .....                 | 2710 |

---

|                                                                 |      |
|-----------------------------------------------------------------|------|
| 15-28. MMU_LOCK.....                                            | 2710 |
| 15-29. Register Call Summary for Register MMU_LOCK .....        | 2710 |
| 15-30. MMU_LD_TLB .....                                         | 2710 |
| 15-31. Register Call Summary for Register MMU_LD_TLB.....       | 2711 |
| 15-32. MMU_CAM .....                                            | 2711 |
| 15-33. Register Call Summary for Register MMU_CAM.....          | 2712 |
| 15-34. MMU_RAM .....                                            | 2712 |
| 15-35. Register Call Summary for Register MMU_RAM.....          | 2712 |
| 15-36. MMU_GFLUSH .....                                         | 2713 |
| 15-37. Register Call Summary for Register MMU_GFLUSH.....       | 2713 |
| 15-38. MMU_FLUSH_ENTRY.....                                     | 2713 |
| 15-39. Register Call Summary for Register MMU_FLUSH_ENTRY ..... | 2714 |
| 15-40. MMU_READ_CAM .....                                       | 2714 |
| 15-41. Register Call Summary for Register MMU_READ_CAM.....     | 2714 |
| 15-42. MMU_READ_RAM .....                                       | 2715 |
| 15-43. Register Call Summary for Register MMU_READ_RAM.....     | 2715 |
| 15-44. MMU_EMUFAULT_AD .....                                    | 2715 |
| 15-45. Register Call Summary for Register MMU_EMUFAULT_AD ..... | 2716 |
| 16-1. Input/Output Description.....                             | 2721 |
| 16-2. Clock, Power, and Reset Domains for GP Timers .....       | 2723 |
| 16-3. GP Timer PRCM Clock Selection Bits .....                  | 2723 |
| 16-4. GP Timer PRCM Clock Control Bits .....                    | 2723 |
| 16-5. IDLEMODE Settings .....                                   | 2724 |
| 16-6. CLOCKACTIVITY Settings .....                              | 2725 |
| 16-7. Timer Interrupt Names and Processor IRQ Mapping .....     | 2727 |
| 16-8. Value Loaded in GPTi.TCRR to Generate 1-ms Tick .....     | 2732 |
| 16-9. Prescaler/Timer Reload Values Versus Contexts .....       | 2735 |
| 16-10. Prescaler Clock Ratio Values .....                       | 2736 |
| 16-11. Value and Corresponding Interrupt Period.....            | 2737 |
| 16-12. GP Timer Instance Summary .....                          | 2740 |
| 16-13. GPTIMER1 to GPTIMER4 Register Summary .....              | 2741 |
| 16-14. GPTIMER5 to GPTIMER8 Register Summary .....              | 2742 |
| 16-15. GPTIMER9 to GPTIMER11 Register Summary .....             | 2743 |
| 16-16. TIDR.....                                                | 2744 |
| 16-17. Register Call Summary for Register TIDR .....            | 2744 |
| 16-18. TIOCP_CFG.....                                           | 2745 |
| 16-19. Register Call Summary for Register TIOCP_CFG .....       | 2746 |
| 16-20. TISTAT.....                                              | 2747 |
| 16-21. Register Call Summary for Register TISTAT .....          | 2747 |
| 16-22. TISR .....                                               | 2748 |
| 16-23. Register Call Summary for Register TISR .....            | 2749 |
| 16-24. TIER.....                                                | 2749 |
| 16-25. Register Call Summary for Register TIER .....            | 2750 |
| 16-26. TWER .....                                               | 2750 |
| 16-27. Register Call Summary for Register TWER.....             | 2751 |
| 16-28. TCLR .....                                               | 2751 |
| 16-29. Register Call Summary for Register TCLR .....            | 2753 |
| 16-30. TCRR .....                                               | 2753 |
| 16-31. Register Call Summary for Register TCRR .....            | 2754 |

|                                                              |      |
|--------------------------------------------------------------|------|
| 16-32. TLDR .....                                            | 2754 |
| 16-33. Register Call Summary for Register TLDR .....         | 2755 |
| 16-34. TTGR.....                                             | 2755 |
| 16-35. Register Call Summary for Register TTGR .....         | 2755 |
| 16-36. TWPS .....                                            | 2756 |
| 16-37. Register Call Summary for Register TWPS.....          | 2757 |
| 16-38. TMAR .....                                            | 2758 |
| 16-39. Register Call Summary for Register TMAR .....         | 2758 |
| 16-40. TCAR1 .....                                           | 2759 |
| 16-41. Register Call Summary for Register TCAR1.....         | 2759 |
| 16-42. TSICR .....                                           | 2760 |
| 16-43. Register Call Summary for Register TSICR .....        | 2760 |
| 16-44. TCAR2 .....                                           | 2761 |
| 16-45. Register Call Summary for Register TCAR2.....         | 2761 |
| 16-46. TPIR.....                                             | 2762 |
| 16-47. Register Call Summary for Register TPIR .....         | 2762 |
| 16-48. TNIR.....                                             | 2762 |
| 16-49. Register Call Summary for Register TNIR .....         | 2763 |
| 16-50. TCVR.....                                             | 2763 |
| 16-51. Register Call Summary for Register TCVR .....         | 2763 |
| 16-52. TOCR .....                                            | 2764 |
| 16-53. Register Call Summary for Register TOCR .....         | 2764 |
| 16-54. TOWR.....                                             | 2764 |
| 16-55. Register Call Summary for Register TOWR .....         | 2764 |
| 16-56. WD Timers Default State for GP and EMU devices .....  | 2766 |
| 16-57. Clock, Power, and Reset Domains for WDTs .....        | 2768 |
| 16-58. WDT PRCM Clock Control Bits.....                      | 2768 |
| 16-59. IDLEMODE Settings .....                               | 2768 |
| 16-60. CLOCKACTIVITY Settings .....                          | 2769 |
| 16-61. WDT Interrupt Names and Processor IRQ Mapping.....    | 2770 |
| 16-62. Count and Prescaler Default Reset Values .....        | 2771 |
| 16-63. Prescaler Clock Ratios.....                           | 2771 |
| 16-64. Reset Period Examples.....                            | 2772 |
| 16-65. Default WDT Time Periods.....                         | 2772 |
| 16-66. WDT Instance Summary .....                            | 2775 |
| 16-67. WDTIMER2 Register Summary .....                       | 2775 |
| 16-68. WDTIMER3 Register Summary .....                       | 2775 |
| 16-69. WIDR.....                                             | 2776 |
| 16-70. Register Call Summary for Register WIDR .....         | 2776 |
| 16-71. WD_SYSCONFIG .....                                    | 2776 |
| 16-72. Register Call Summary for Register WD_SYSCONFIG.....  | 2777 |
| 16-73. WD_SYSSTATUS .....                                    | 2777 |
| 16-74. Register Call Summary for Register WD_SYSSTATUS ..... | 2778 |
| 16-75. WISR .....                                            | 2778 |
| 16-76. Register Call Summary for Register WISR .....         | 2778 |
| 16-77. WIER .....                                            | 2779 |
| 16-78. Register Call Summary for Register WIER .....         | 2779 |
| 16-79. WCLR .....                                            | 2779 |
| 16-80. Register Call Summary for Register WCLR.....          | 2780 |

---

|                                                                                                              |      |
|--------------------------------------------------------------------------------------------------------------|------|
| 16-81. WCRR.....                                                                                             | 2780 |
| 16-82. Register Call Summary for Register WCRR .....                                                         | 2780 |
| 16-83. WLDR .....                                                                                            | 2780 |
| 16-84. Register Call Summary for Register WLDR.....                                                          | 2781 |
| 16-85. WTGR .....                                                                                            | 2781 |
| 16-86. Register Call Summary for Register WTGR .....                                                         | 2781 |
| 16-87. WWPS .....                                                                                            | 2781 |
| 16-88. Register Call Summary for Register WWPS.....                                                          | 2782 |
| 16-89. WSPR .....                                                                                            | 2782 |
| 16-90. Register Call Summary for Register WSPR .....                                                         | 2782 |
| 16-91. Clock, Power, and Reset Domains for 32-kHz Sync Timer.....                                            | 2784 |
| 16-92. 32-kHz Sync Timer Instance Summary.....                                                               | 2785 |
| 16-93. 32-kHz Sync Timer Register Summary.....                                                               | 2785 |
| 16-94. REG_32KSYNCNT_REV.....                                                                                | 2785 |
| 16-95. Register Call Summary for Register REG_32KSYNCNT_REV .....                                            | 2786 |
| 16-96. REG_32KSYNCNT_SYSCONFIG .....                                                                         | 2786 |
| 16-97. Register Call Summary for Register REG_32KSYNCNT_SYSCONFIG .....                                      | 2786 |
| 16-98. REG_32KSYNCNT_CR .....                                                                                | 2786 |
| 16-99. Register Call Summary for Register REG_32KSYNCNT_CR .....                                             | 2786 |
| 17-1. HS I <sup>2</sup> C Input/Output .....                                                                 | 2791 |
| 17-2. HS I <sup>2</sup> C Input/Output .....                                                                 | 2797 |
| 17-3. HS I <sup>2</sup> C Input/Output Description for I2C4 .....                                            | 2801 |
| 17-4. HS I <sup>2</sup> C Power Management Modes .....                                                       | 2805 |
| 17-5. HS I <sup>2</sup> C State of the Interface and Functional Clocks When the Module is in Idle Mode ..... | 2805 |
| 17-6. HS I <sup>2</sup> C Wake-Up Events.....                                                                | 2806 |
| 17-7. HS I <sup>2</sup> C DMA Requests .....                                                                 | 2808 |
| 17-8. HS I <sup>2</sup> C Interrupt Requests .....                                                           | 2808 |
| 17-9. HS I <sup>2</sup> C Interrupt Events .....                                                             | 2809 |
| 17-10. HS I <sup>2</sup> C Operation Mode Selection.....                                                     | 2811 |
| 17-11. HS I <sup>2</sup> C RX and TX FIFO Depths .....                                                       | 2812 |
| 17-12. HS I <sup>2</sup> C t <sub>LOW</sub> and t <sub>HIGH</sub> Values of the I <sup>2</sup> C Clock.....  | 2818 |
| 17-13. HS I <sup>2</sup> C List of tests for the HS I <sup>2</sup> C Controllers .....                       | 2819 |
| 17-14. HS I <sup>2</sup> C List of Data In/Out Checks .....                                                  | 2819 |
| 17-15. HS I <sup>2</sup> C Instance Summary.....                                                             | 2840 |
| 17-16. HS I <sup>2</sup> C Registers Mapping Summary .....                                                   | 2840 |
| 17-17. I2C_REV.....                                                                                          | 2841 |
| 17-18. Register Call Summary for Register I2C_REV .....                                                      | 2841 |
| 17-19. I2C_IE.....                                                                                           | 2841 |
| 17-20. Register Call Summary for Register I2C_IE .....                                                       | 2843 |
| 17-21. I2C_STAT .....                                                                                        | 2843 |
| 17-22. Register Call Summary for Register I2C_STAT .....                                                     | 2846 |
| 17-23. I2C_WE .....                                                                                          | 2847 |
| 17-24. Register Call Summary for Register I2C_WE .....                                                       | 2848 |
| 17-25. I2C_SYSS .....                                                                                        | 2848 |
| 17-26. Register Call Summary for Register I2C_SYSS.....                                                      | 2849 |
| 17-27. I2C_BUF .....                                                                                         | 2849 |
| 17-28. Register Call Summary for Register I2C_BUF .....                                                      | 2849 |
| 17-29. I2C_CNT .....                                                                                         | 2850 |
| 17-30. Register Call Summary for Register I2C_CNT .....                                                      | 2850 |

|                                                                |      |
|----------------------------------------------------------------|------|
| 17-31. I2C_DATA .....                                          | 2851 |
| 17-32. Register Call Summary for Register I2C_DATA.....        | 2851 |
| 17-33. I2C_SYSC .....                                          | 2851 |
| 17-34. Register Call Summary for Register I2C_SYSC .....       | 2852 |
| 17-35. I2C_CON .....                                           | 2852 |
| 17-36. Register Call Summary for Register I2C_CON.....         | 2854 |
| 17-37. I2C_OA0 .....                                           | 2854 |
| 17-38. Register Call Summary for Register I2C_OA0 .....        | 2854 |
| 17-39. I2C_SA.....                                             | 2855 |
| 17-40. Register Call Summary for Register I2C_SA .....         | 2855 |
| 17-41. I2C_PSC .....                                           | 2855 |
| 17-42. Register Call Summary for Register I2C_PSC .....        | 2856 |
| 17-43. I2C_SCLL.....                                           | 2856 |
| 17-44. Register Call Summary for Register I2C_SCLL .....       | 2856 |
| 17-45. I2C_SCLH .....                                          | 2857 |
| 17-46. Register Call Summary for Register I2C_SCLH.....        | 2857 |
| 17-47. I2C_SYSTEST .....                                       | 2857 |
| 17-48. Register Call Summary for Register I2C_SYSTEST .....    | 2859 |
| 17-49. I2C_BUFSTAT .....                                       | 2859 |
| 17-50. Register Call Summary for Register I2C_BUFSTAT .....    | 2859 |
| 17-51. I2C_OA1 .....                                           | 2860 |
| 17-52. Register Call Summary for Register I2C_OA1 .....        | 2860 |
| 17-53. I2C_OA2 .....                                           | 2860 |
| 17-54. Register Call Summary for Register I2C_OA2 .....        | 2860 |
| 17-55. I2C_OA3 .....                                           | 2861 |
| 17-56. Register Call Summary for Register I2C_OA3 .....        | 2861 |
| 17-57. I2C_ACTOA .....                                         | 2861 |
| 17-58. Register Call Summary for Register I2C_ACTOA .....      | 2862 |
| 17-59. I2C_SBLOCK .....                                        | 2862 |
| 17-60. Register Call Summary for Register I2C_SBLOCK .....     | 2862 |
| 18-1. I/O Description .....                                    | 2865 |
| 18-2. HDQ/1-Wire Command Byte .....                            | 2867 |
| 18-3. Registers Print for HDQ/1-Wire Configuration .....       | 2880 |
| 18-4. Registers Print for HDQ/1-Wire Software Reset .....      | 2881 |
| 18-5. Registers Print for HDQ/1-Wire Interrupts Enable .....   | 2882 |
| 18-6. Instance Summary .....                                   | 2883 |
| 18-7. HDQ/1-Wire Register Summary .....                        | 2883 |
| 18-8. HDQ_REVISION.....                                        | 2884 |
| 18-9. Register Call Summary for Register HDQ_REVISION .....    | 2884 |
| 18-10. HDQ_TX_DATA .....                                       | 2884 |
| 18-11. Register Call Summary for Register HDQ_TX_DATA.....     | 2884 |
| 18-12. HDQ_RX_DATA .....                                       | 2885 |
| 18-13. Register Call Summary for Register HDQ_RX_DATA.....     | 2885 |
| 18-14. HDQ_CTRL_STATUS .....                                   | 2885 |
| 18-15. Register Call Summary for Register HDQ_CTRL_STATUS..... | 2886 |
| 18-16. HDQ_INT_STATUS .....                                    | 2887 |
| 18-17. Register Call Summary for Register HDQ_INT_STATUS.....  | 2887 |
| 18-18. HDQ_SYSCONFIG.....                                      | 2888 |
| 18-19. Register Call Summary for Register HDQ_SYSCONFIG .....  | 2888 |

---

|                                                                             |      |
|-----------------------------------------------------------------------------|------|
| 18-20. HDQ_SYSSTATUS .....                                                  | 2888 |
| 18-21. Register Call Summary for Register HDQ_SYSSTATUS .....               | 2889 |
| 19-1. UART Mode Baud Rates, Divisor Values, and Error Rates.....            | 2893 |
| 19-2. UART IrDA Mode Baud Rates, Divisor Values, and Error Rates .....      | 2894 |
| 19-3. UART I/O Pin Description .....                                        | 2896 |
| 19-4. UART3 I/O Description .....                                           | 2897 |
| 19-5. EFR_REG[0-1] IR Address Checking Options .....                        | 2900 |
| 19-6. FIR Transmit Frame Format .....                                       | 2903 |
| 19-7. 4-PPM Format .....                                                    | 2903 |
| 19-8. FIR Preamble, Start Flag, and Stop Flag .....                         | 2903 |
| 19-9. FIR Data Byte Transmission Order Example .....                        | 2903 |
| 19-10. CIR I/O Description.....                                             | 2904 |
| 19-11. UART Clocks.....                                                     | 2909 |
| 19-12. Reset Domain.....                                                    | 2909 |
| 19-13. Power Domain .....                                                   | 2910 |
| 19-14. Interrupt Mapping to MPU Subsystem.....                              | 2910 |
| 19-15. Interrupt Mapping to IVA2.2 Subsystem.....                           | 2910 |
| 19-16. UART DMA Requests to System DMA .....                                | 2910 |
| 19-17. UART DMA Requests to IVA2.2 Subsystem DMA.....                       | 2910 |
| 19-18. Wake-Up Requests From PRCM.....                                      | 2911 |
| 19-19. TX FIFO Trigger Level Setting Summary .....                          | 2914 |
| 19-20. RX FIFO Trigger Level Setting Summary .....                          | 2914 |
| 19-21. UART/IrDA/CIR Register Access Mode Programming (Using LCR_REG) ..... | 2920 |
| 19-22. Sub-Configuration_Mode_A Mode Summary.....                           | 2921 |
| 19-23. Sub-Configuration_Mode_B Mode Summary.....                           | 2921 |
| 19-24. Sub-Operational_Mode Mode Summary .....                              | 2921 |
| 19-25. UART/IrDA/CIR Register Access Mode Overview .....                    | 2921 |
| 19-26. UART Mode Selection .....                                            | 2923 |
| 19-27. UART Mode Register Overview .....                                    | 2923 |
| 19-28. IrDA Mode Register Overview .....                                    | 2924 |
| 19-29. CIR Mode Register Overview .....                                     | 2925 |
| 19-30. UART Baud Rate Settings (48-MHz Clock).....                          | 2927 |
| 19-31. UART Parity Bit Encoding .....                                       | 2927 |
| 19-32. EFR_REG[0-3] Software Flow Control Options .....                     | 2928 |
| 19-33. UART Mode Interrupts .....                                           | 2932 |
| 19-34. IrDA Baud Rates Settings .....                                       | 2933 |
| 19-35. IrDA Mode Interrupts .....                                           | 2937 |
| 19-36. Duty Cycle .....                                                     | 2939 |
| 19-37. CIR Mode Interrupts.....                                             | 2940 |
| 19-38. UART/IrDA/CIR Instance Summary.....                                  | 2950 |
| 19-39. UART/IrDA/CIR Register Summary Part 1 .....                          | 2950 |
| 19-40. UART/IrDA/CIR Register Summary Part 2.....                           | 2951 |
| 19-41. DLL_REG.....                                                         | 2953 |
| 19-42. Register Call Summary for Register DLL_REG .....                     | 2953 |
| 19-43. RHR_REG.....                                                         | 2954 |
| 19-44. Register Call Summary for Register RHR_REG .....                     | 2954 |
| 19-45. THR_REG .....                                                        | 2954 |
| 19-46. Register Call Summary for Register THR_REG.....                      | 2955 |
| 19-47. IER_REG .....                                                        | 2955 |

|                                                                |      |
|----------------------------------------------------------------|------|
| 19-48. Register Call Summary for Register IER_REG.....         | 2956 |
| 19-49. DLH_REG .....                                           | 2958 |
| 19-50. Register Call Summary for Register DLH_REG.....         | 2958 |
| 19-51. FCR_REG .....                                           | 2958 |
| 19-52. Register Call Summary for Register FCR_REG.....         | 2960 |
| 19-53. IIR_REG .....                                           | 2960 |
| 19-54. Register Call Summary for Register IIR_REG.....         | 2961 |
| 19-55. EFR_REG .....                                           | 2962 |
| 19-56. Register Call Summary for Register EFR_REG.....         | 2963 |
| 19-57. LCR_REG .....                                           | 2964 |
| 19-58. Register Call Summary for Register LCR_REG.....         | 2965 |
| 19-59. MCR_REG .....                                           | 2965 |
| 19-60. Register Call Summary for Register MCR_REG .....        | 2966 |
| 19-61. XON1_ADDR1_REG.....                                     | 2966 |
| 19-62. Register Call Summary for Register XON1_ADDR1_REG ..... | 2967 |
| 19-63. LSR_REG .....                                           | 2967 |
| 19-64. Register Call Summary for Register LSR_REG .....        | 2968 |
| 19-65. XON2_ADDR2_REG.....                                     | 2970 |
| 19-66. Register Call Summary for Register XON2_ADDR2_REG ..... | 2970 |
| 19-67. XOFF1_REG .....                                         | 2970 |
| 19-68. Register Call Summary for Register XOFF1_REG .....      | 2970 |
| 19-69. TCR_REG .....                                           | 2971 |
| 19-70. Register Call Summary for Register TCR_REG.....         | 2971 |
| 19-71. MSR_REG.....                                            | 2971 |
| 19-72. Register Call Summary for Register MSR_REG .....        | 2972 |
| 19-73. SPR_REG .....                                           | 2972 |
| 19-74. Register Call Summary for Register SPR_REG.....         | 2972 |
| 19-75. XOFF2_REG .....                                         | 2973 |
| 19-76. Register Call Summary for Register XOFF2_REG .....      | 2973 |
| 19-77. TLR_REG.....                                            | 2973 |
| 19-78. Register Call Summary for Register TLR_REG .....        | 2974 |
| 19-79. MDR1_REG .....                                          | 2974 |
| 19-80. Register Call Summary for Register MDR1_REG .....       | 2975 |
| 19-81. MDR2_REG .....                                          | 2975 |
| 19-82. Register Call Summary for Register MDR2_REG .....       | 2976 |
| 19-83. TXFLL_REG.....                                          | 2977 |
| 19-84. Register Call Summary for Register TXFLL_REG .....      | 2977 |
| 19-85. SFLSR_REG .....                                         | 2977 |
| 19-86. Register Call Summary for Register SFLSR_REG .....      | 2978 |
| 19-87. RESUME_REG .....                                        | 2978 |
| 19-88. Register Call Summary for Register RESUME_REG.....      | 2979 |
| 19-89. TXFLH_REG .....                                         | 2979 |
| 19-90. Register Call Summary for Register TXFLH_REG.....       | 2979 |
| 19-91. RXFLL_REG .....                                         | 2980 |
| 19-92. Register Call Summary for Register RXFLL_REG .....      | 2980 |
| 19-93. SFREGL_REG .....                                        | 2980 |
| 19-94. Register Call Summary for Register SFREGL_REG .....     | 2981 |
| 19-95. SFREGH_REG .....                                        | 2981 |
| 19-96. Register Call Summary for Register SFREGH_REG .....     | 2981 |

---

|                                                                 |      |
|-----------------------------------------------------------------|------|
| 19-97. RXFLH_REG .....                                          | 2982 |
| 19-98. Register Call Summary for Register RXFLH_REG .....       | 2982 |
| 19-99. BLR_REG .....                                            | 2982 |
| 19-100. Register Call Summary for Register BLR_REG.....         | 2983 |
| 19-101. UASR_REG.....                                           | 2983 |
| 19-102. Register Call Summary for Register UASR_REG .....       | 2984 |
| 19-103. ACREG_REG.....                                          | 2984 |
| 19-104. Register Call Summary for Register ACREG_REG .....      | 2985 |
| 19-105. SCR_REG.....                                            | 2985 |
| 19-106. Register Call Summary for Register SCR_REG .....        | 2986 |
| 19-107. SSR_REG.....                                            | 2987 |
| 19-108. Register Call Summary for Register SSR_REG .....        | 2987 |
| 19-109. EBLR_REG .....                                          | 2988 |
| 19-110. Register Call Summary for Register EBLR_REG.....        | 2988 |
| 19-111. MVR_REG .....                                           | 2989 |
| 19-112. Register Call Summary for Register MVR_REG.....         | 2989 |
| 19-113. SYSC_REG.....                                           | 2989 |
| 19-114. Register Call Summary for Register SYSC_REG .....       | 2990 |
| 19-115. SYSS_REG .....                                          | 2990 |
| 19-116. Register Call Summary for Register SYSS_REG.....        | 2991 |
| 19-117. WER_REG .....                                           | 2991 |
| 19-118. Register Call Summary for Register WER_REG .....        | 2992 |
| 19-119. CFPS_REG .....                                          | 2992 |
| 19-120. Register Call Summary for Register CFPS_REG.....        | 2993 |
| 19-121. RXFIFO_LVL_REG .....                                    | 2993 |
| 19-122. Register Call Summary for Register RXFIFO_LVL_REG.....  | 2993 |
| 19-123. TXFIFO_LVL_REG .....                                    | 2993 |
| 19-124. Register Call Summary for Register TXFIFO_LVL_REG ..... | 2993 |
| 19-125. IER2_REG .....                                          | 2994 |
| 19-126. Register Call Summary for Register IER2_REG.....        | 2994 |
| 19-127. ISR2_REG .....                                          | 2994 |
| 19-128. Register Call Summary for Register ISR2_REG.....        | 2995 |
| 19-129. MDR3_REG.....                                           | 2995 |
| 19-130. Register Call Summary for Register MDR3_REG .....       | 2995 |
| 20-1. McSPI I/O Description (Master Mode) .....                 | 3004 |
| 20-2. McSPI I/O Description (Slave Mode) .....                  | 3005 |
| 20-3. SPI Master Clock Rates .....                              | 3005 |
| 20-4. Phase and Polarity Combinations.....                      | 3006 |
| 20-5. McSPI Clocks .....                                        | 3010 |
| 20-6. Power Domain .....                                        | 3010 |
| 20-7. McSPI Hardware Reset.....                                 | 3010 |
| 20-8. DMA Requests.....                                         | 3011 |
| 20-9. Interrupt Requests.....                                   | 3012 |
| 20-10. Wake-Up Requests.....                                    | 3012 |
| 20-11. SPI Master Clock Rates .....                             | 3019 |
| 20-12. CLKSP PIO High/Low Time Computation .....                | 3019 |
| 20-13. Clock Granularity Examples.....                          | 3020 |
| 20-14. FIFO Writes, Word Length Relationship.....               | 3025 |
| 20-15. Smart-Idle Mode and Wake-Up Capabilities .....           | 3032 |

|                                                                    |      |
|--------------------------------------------------------------------|------|
| 20-16. End-of-Transfer Sequences .....                             | 3036 |
| 20-17. End-of-Transfer Types .....                                 | 3049 |
| 20-18. McSPI Instance Summary.....                                 | 3055 |
| 20-19. McSPI Register Summary .....                                | 3055 |
| 20-20. MCSPI_REVISION .....                                        | 3056 |
| 20-21. Register Call Summary for Register MCSPI_REVISION.....      | 3056 |
| 20-22. MCSPI_SYSCONFIG .....                                       | 3056 |
| 20-23. Register Call Summary for Register MCSPI_SYSCONFIG.....     | 3057 |
| 20-24. MCSPI_SYSSTATUS .....                                       | 3058 |
| 20-25. Register Call Summary for Register MCSPI_SYSSTATUS .....    | 3058 |
| 20-26. MCSPI_IRQSTATUS .....                                       | 3058 |
| 20-27. Register Call Summary for Register MCSPI_IRQSTATUS .....    | 3061 |
| 20-28. MCSPI_IRQENABLE .....                                       | 3061 |
| 20-29. Register Call Summary for Register MCSPI_IRQENABLE .....    | 3063 |
| 20-30. MCSPI_WAKEUPENABLE.....                                     | 3063 |
| 20-31. Register Call Summary for Register MCSPI_WAKEUPENABLE ..... | 3063 |
| 20-32. MCSPI_SYST .....                                            | 3064 |
| 20-33. Register Call Summary for Register MCSPI_SYST .....         | 3065 |
| 20-34. MCSPI_MODULCTRL .....                                       | 3066 |
| 20-35. Register Call Summary for Register MCSPI_MODULCTRL.....     | 3066 |
| 20-36. MCSPI_CHxCONF .....                                         | 3067 |
| 20-37. Register Call Summary for Register MCSPI_CHxCONF.....       | 3070 |
| 20-38. MCSPI_CHxSTAT .....                                         | 3070 |
| 20-39. Register Call Summary for Register MCSPI_CHxSTAT .....      | 3071 |
| 20-40. MCSPI_CHxCTRL.....                                          | 3072 |
| 20-41. Register Call Summary for Register MCSPI_CHxCTRL .....      | 3072 |
| 20-42. MCSPI_Tx .....                                              | 3073 |
| 20-43. Register Call Summary for Register MCSPI_Tx.....            | 3073 |
| 20-44. MCSPI_Rx .....                                              | 3074 |
| 20-45. Register Call Summary for Register MCSPI_Rx .....           | 3074 |
| 20-46. MCSPI_XFERLEVEL .....                                       | 3075 |
| 21-1. Functions Description .....                                  | 3081 |
| 21-2. Input/Output Description.....                                | 3082 |
| 21-3. Clocking Signals Input to McBSP Module.....                  | 3096 |
| 21-4. Software Reset Signals to All McBSP Modules .....            | 3102 |
| 21-5. State of Clocks When the Module is in Idle State.....        | 3103 |
| 21-6. McBSP Smart Idle Mode Configuration Behavior .....           | 3106 |
| 21-7. McBSP DMA Requests .....                                     | 3108 |
| 21-8. McBSP Common Interrupt Requests .....                        | 3108 |
| 21-9. McBSP Transmit Interrupt Requests .....                      | 3109 |
| 21-10. McBSP Receive Interrupt Requests .....                      | 3109 |
| 21-11. McBSP Transmit Interrupt Events .....                       | 3109 |
| 21-12. McBSP Receive Interrupt Events .....                        | 3110 |
| 21-13. SIDETONE_McBSP Interrupt Requests.....                      | 3110 |
| 21-14. SIDETONE_McBSP Interrupt Events.....                        | 3111 |
| 21-15. Receiver Clock Mode .....                                   | 3117 |
| 21-16. Phases, Words and Bits per Frame Control Bit .....          | 3121 |
| 21-17. Assumptions for the Single-Phase Frame Example .....        | 3121 |
| 21-18. Assumptions for the Dual-Phase Frame Example .....          | 3122 |

---

|                                                                                       |      |
|---------------------------------------------------------------------------------------|------|
| 21-19. Effects of DLB and ALB Bits on Clock Modes .....                               | 3128 |
| 21-20. Eight Partitions – Receive Channel Assignment and Control .....                | 3138 |
| 21-21. Eight Partitions – Transmit Channel Assignment and Control.....                | 3138 |
| 21-22. Selecting a Transmit Multichannel Selection Mode With the XMCM Bit Field ..... | 3140 |
| 21-23. McBSP Channel Control Options .....                                            | 3141 |
| 21-24. McBSP Configuration in Function of the SRG Clock Source Selected.....          | 3151 |
| 21-25. Input Clock Selection for Sample Rate Generator .....                          | 3154 |
| 21-26. How to Calculate the Length of the Receive Frame .....                         | 3160 |
| 21-27. Example: Use of RJUST Bit Field With 12-bit Data Value 0xABCD .....            | 3161 |
| 21-28. Example: Use of RJUST Bit Field With 20-bit Data Value 0xABCD.....             | 3161 |
| 21-29. FSRM and GSYNC Effects on Frame-Sync Signal and mcbsp_fsr Pin.....             | 3162 |
| 21-30. CLKRM Effect on Receive Clock Signal and mcbsp_clkr Pin .....                  | 3164 |
| 21-31. How to Calculate the Length of the Transmit Frame .....                        | 3168 |
| 21-32. How FSXM and FSGM Select the Source of Transmit Frame-Sync Pulses .....        | 3170 |
| 21-33. CLKXM Bit Effect on Transmit Clock and MCBSPLP.CLKX Pin .....                  | 3171 |
| 21-34. Using McBSP Pins for General-Purpose I/O .....                                 | 3173 |
| 21-35. Selection of the SIDETONE Input and Output Channels .....                      | 3176 |
| 21-36. McBSP Instance Summary.....                                                    | 3177 |
| 21-37. McBSP1 Registers Mapping Summary.....                                          | 3177 |
| 21-38. McBSP5 Registers Mapping Summary.....                                          | 3178 |
| 21-39. McBSP2 Registers Mapping Summary.....                                          | 3179 |
| 21-40. McBSP3 Registers Mapping Summary.....                                          | 3180 |
| 21-41. McBSP4 Registers Mapping Summary .....                                         | 3181 |
| 21-42. SIDETONE_McBSP2 Registers Mapping Summary .....                                | 3182 |
| 21-43. SIDETONE_McBSP3 Registers Mapping Summary .....                                | 3183 |
| 21-44. MCBSPLP_DRR_REG .....                                                          | 3183 |
| 21-45. Register Call Summary for Register MCBSPLP_DRR_REG .....                       | 3183 |
| 21-46. MCBSPLP_DXR_REG.....                                                           | 3184 |
| 21-47. Register Call Summary for Register MCBSPLP_DXR_REG .....                       | 3184 |
| 21-48. MCBSPLP_SPCR2_REG .....                                                        | 3184 |
| 21-49. Register Call Summary for Register MCBSPLP_SPCR2_REG.....                      | 3186 |
| 21-50. MCBSPLP_SPCR1_REG .....                                                        | 3186 |
| 21-51. Register Call Summary for Register MCBSPLP_SPCR1_REG.....                      | 3187 |
| 21-52. MCBSPLP_RCR2_REG .....                                                         | 3188 |
| 21-53. Register Call Summary for Register MCBSPLP_RCR2_REG .....                      | 3189 |
| 21-54. MCBSPLP_RCR1_REG .....                                                         | 3190 |
| 21-55. Register Call Summary for Register MCBSPLP_RCR1_REG .....                      | 3190 |
| 21-56. MCBSPLP_XCR2_REG .....                                                         | 3191 |
| 21-57. Register Call Summary for Register MCBSPLP_XCR2_REG.....                       | 3192 |
| 21-58. MCBSPLP_XCR1_REG .....                                                         | 3192 |
| 21-59. Register Call Summary for Register MCBSPLP_XCR1_REG.....                       | 3193 |
| 21-60. MCBSPLP_SRGR2_REG .....                                                        | 3194 |
| 21-61. Register Call Summary for Register MCBSPLP_SRGR2_REG .....                     | 3195 |
| 21-62. MCBSPLP_SRGR1_REG .....                                                        | 3195 |
| 21-63. Register Call Summary for Register MCBSPLP_SRGR1_REG .....                     | 3196 |
| 21-64. MCBSPLP_MCR2_REG.....                                                          | 3196 |
| 21-65. Register Call Summary for Register MCBSPLP_MCR2_REG .....                      | 3198 |
| 21-66. MCBSPLP_MCR1_REG.....                                                          | 3198 |
| 21-67. Register Call Summary for Register MCBSPLP_MCR1_REG .....                      | 3199 |

|                                                                        |      |
|------------------------------------------------------------------------|------|
| 21-68. MCBSPLP_RCERA_REG .....                                         | 3200 |
| 21-69. Register Call Summary for Register MCBSPLP_RCERA_REG .....      | 3200 |
| 21-70. MCBSPLP_RCERB_REG .....                                         | 3201 |
| 21-71. Register Call Summary for Register MCBSPLP_RCERB_REG .....      | 3201 |
| 21-72. MCBSPLP_XCERA_REG .....                                         | 3201 |
| 21-73. Register Call Summary for Register MCBSPLP_XCERA_REG .....      | 3202 |
| 21-74. MCBSPLP_XCERB_REG .....                                         | 3202 |
| 21-75. Register Call Summary for Register MCBSPLP_XCERB_REG .....      | 3202 |
| 21-76. MCBSPLP_PCR_REG .....                                           | 3203 |
| 21-77. Register Call Summary for Register MCBSPLP_PCR_REG .....        | 3205 |
| 21-78. MCBSPLP_RCERC_REG .....                                         | 3206 |
| 21-79. Register Call Summary for Register MCBSPLP_RCERC_REG .....      | 3206 |
| 21-80. MCBSPLP_RCERD_REG .....                                         | 3206 |
| 21-81. Register Call Summary for Register MCBSPLP_RCERD_REG .....      | 3207 |
| 21-82. MCBSPLP_XCERC_REG .....                                         | 3207 |
| 21-83. Register Call Summary for Register MCBSPLP_XCERC_REG .....      | 3207 |
| 21-84. MCBSPLP_XCERD_REG .....                                         | 3208 |
| 21-85. Register Call Summary for Register MCBSPLP_XCERD_REG .....      | 3208 |
| 21-86. MCBSPLP_RCERE_REG .....                                         | 3208 |
| 21-87. Register Call Summary for Register MCBSPLP_RCERE_REG .....      | 3209 |
| 21-88. MCBSPLP_RCERF_REG .....                                         | 3209 |
| 21-89. Register Call Summary for Register MCBSPLP_RCERF_REG .....      | 3209 |
| 21-90. MCBSPLP_XCERE_REG .....                                         | 3210 |
| 21-91. Register Call Summary for Register MCBSPLP_XCERE_REG .....      | 3210 |
| 21-92. MCBSPLP_XCERF_REG .....                                         | 3210 |
| 21-93. Register Call Summary for Register MCBSPLP_XCERF_REG .....      | 3211 |
| 21-94. MCBSPLP_RCERG_REG .....                                         | 3211 |
| 21-95. Register Call Summary for Register MCBSPLP_RCERG_REG .....      | 3211 |
| 21-96. MCBSPLP_RCERH_REG .....                                         | 3212 |
| 21-97. Register Call Summary for Register MCBSPLP_RCERH_REG .....      | 3212 |
| 21-98. MCBSPLP_XCERG_REG .....                                         | 3212 |
| 21-99. Register Call Summary for Register MCBSPLP_XCERG_REG .....      | 3213 |
| 21-100. MCBSPLP_XCERH_REG .....                                        | 3213 |
| 21-101. Register Call Summary for Register MCBSPLP_XCERH_REG .....     | 3213 |
| 21-102. MCBSPLP_REV_REG .....                                          | 3214 |
| 21-103. Register Call Summary for Register MCBSPLP_REV_REG .....       | 3214 |
| 21-104. MCBSPLP_RINTCLR_REG .....                                      | 3214 |
| 21-105. Register Call Summary for Register MCBSPLP_RINTCLR_REG .....   | 3215 |
| 21-106. MCBSPLP_XINTCLR_REG .....                                      | 3215 |
| 21-107. Register Call Summary for Register MCBSPLP_XINTCLR_REG .....   | 3215 |
| 21-108. MCBSPLP_ROVFLCLR_REG .....                                     | 3215 |
| 21-109. Register Call Summary for Register MCBSPLP_ROVFLCLR_REG .....  | 3216 |
| 21-110. MCBSPLP_SYSCONFIG_REG .....                                    | 3217 |
| 21-111. Register Call Summary for Register MCBSPLP_SYSCONFIG_REG ..... | 3218 |
| 21-112. MCBSPLP_THRSH2_REG .....                                       | 3218 |
| 21-113. Register Call Summary for Register MCBSPLP_THRSH2_REG .....    | 3218 |
| 21-114. MCBSPLP_THRSH1_REG .....                                       | 3219 |
| 21-115. Register Call Summary for Register MCBSPLP_THRSH1_REG .....    | 3219 |
| 21-116. MCBSPLP_IRQSTATUS_REG .....                                    | 3220 |

---

|                                                                           |      |
|---------------------------------------------------------------------------|------|
| 21-117. Register Call Summary for Register MCBSPLP_IRQSTATUS_REG .....    | 3222 |
| 21-118. MCBSPLP_IRQENABLE_REG .....                                       | 3222 |
| 21-119. Register Call Summary for Register MCBSPLP_IRQENABLE_REG .....    | 3223 |
| 21-120. MCBSPLP_WAKEUPEN_REG .....                                        | 3224 |
| 21-121. Register Call Summary for Register MCBSPLP_WAKEUPEN_REG .....     | 3225 |
| 21-122. MCBSPLP_XCCR_REG .....                                            | 3225 |
| 21-123. Register Call Summary for Register MCBSPLP_XCCR_REG.....          | 3227 |
| 21-124. MCBSPLP_RCCR_REG .....                                            | 3227 |
| 21-125. Register Call Summary for Register MCBSPLP_RCCR_REG.....          | 3228 |
| 21-126. MCBSPLP_XBUFFSTAT_REG .....                                       | 3229 |
| 21-127. Register Call Summary for Register MCBSPLP_XBUFFSTAT_REG.....     | 3229 |
| 21-128. MCBSPLP_RBUFFSTAT_REG .....                                       | 3229 |
| 21-129. Register Call Summary for Register MCBSPLP_RBUFFSTAT_REG .....    | 3230 |
| 21-130. MCBSPLP_SSELCR_REG .....                                          | 3230 |
| 21-131. Register Call Summary for Register MCBSPLP_SSELCR_REG.....        | 3231 |
| 21-132. MCBSPLP_STATUS_REG .....                                          | 3231 |
| 21-133. Register Call Summary for Register MCBSPLP_STATUS_REG.....        | 3231 |
| 21-134. ST_REV_REG .....                                                  | 3232 |
| 21-135. Register Call Summary for Register ST_REV_REG .....               | 3232 |
| 21-136. ST_SYSCONFIG_REG .....                                            | 3232 |
| 21-137. Register Call Summary for Register ST_SYSCONFIG_REG .....         | 3232 |
| 21-138. ST_IRQSTATUS_REG .....                                            | 3233 |
| 21-139. Register Call Summary for Register ST_IRQSTATUS_REG .....         | 3233 |
| 21-140. ST_IRQENABLE_REG .....                                            | 3233 |
| 21-141. Register Call Summary for Register ST_IRQENABLE_REG .....         | 3234 |
| 21-142. ST_SGAINCR_REG .....                                              | 3234 |
| 21-143. Register Call Summary for Register ST_SGAINCR_REG.....            | 3234 |
| 21-144. ST_SFIRCR_REG .....                                               | 3234 |
| 21-145. Register Call Summary for Register ST_SFIRCR_REG .....            | 3235 |
| 21-146. ST_SSELCR_REG .....                                               | 3235 |
| 21-147. Register Call Summary for Register ST_SSELCR_REG .....            | 3236 |
| 22-1. Input/Output Description.....                                       | 3242 |
| 22-2. USB Clocks.....                                                     | 3243 |
| 22-3. High-Speed USB Interface Clock .....                                | 3244 |
| 22-4. High-Speed USB Master Interface Power Management Modes .....        | 3246 |
| 22-5. High-Speed USB Slave Interface Power Management Modes.....          | 3247 |
| 22-6. High-Speed USB Interrupts .....                                     | 3248 |
| 22-7. Interconnect Data and MByteEn in Little- and Big-Endian Modes ..... | 3252 |
| 22-8. High-Speed USB Controller Instance Summary .....                    | 3258 |
| 22-9. High-Speed USB Controller Register Summary.....                     | 3258 |
| 22-10. OTG_REVISION.....                                                  | 3258 |
| 22-11. Register Call Summary for Register OTG_REVISION .....              | 3259 |
| 22-12. OTG_SYSCONFIG.....                                                 | 3259 |
| 22-13. Register Call Summary for Register OTG_SYSCONFIG .....             | 3259 |
| 22-14. OTG_SYSSTATUS.....                                                 | 3260 |
| 22-15. Register Call Summary for Register OTG_SYSSTATUS .....             | 3260 |
| 22-16. OTG_INTERFSEL.....                                                 | 3260 |
| 22-17. Register Call Summary for Register OTG_INTERFSEL .....             | 3260 |
| 22-18. OTG_SIMENABLE .....                                                | 3261 |

|                                                                                                                              |      |
|------------------------------------------------------------------------------------------------------------------------------|------|
| 22-19. Register Call Summary for Register OTG_SIMENABLE .....                                                                | 3261 |
| 22-20. OTG_FORCESTDBY .....                                                                                                  | 3261 |
| 22-21. Register Call Summary for Register OTG_FORCESTDBY .....                                                               | 3261 |
| 22-22. OTG_BIGENDIAN .....                                                                                                   | 3262 |
| 22-23. Register Call Summary for Register OTG_BIGENDIAN .....                                                                | 3262 |
| 22-24. USB Connectivity Modes .....                                                                                          | 3264 |
| 22-25. I/O Description .....                                                                                                 | 3273 |
| 22-26. Signaling Between High-Speed USB Host Subsystem and 6-Pin Unidirectional USB Transceiver (DAT/SE0 Signaling) .....    | 3276 |
| 22-27. Signaling Between High-Speed USB Host Subsystem and 6-Pin Unidirectional USB Transceiver (DP/DM Signaling) .....      | 3277 |
| 22-28. Signaling Between High-Speed USB Host Subsystem and 3-Pin Bidirectional USB Transceiver Using DAT/SE0 Signaling ..... | 3277 |
| 22-29. Signaling Between High-Speed USB Host Subsystem and 4-Pin Bidirectional USB Transceiver Using DP/DM Signaling .....   | 3278 |
| 22-30. Pullup/Pulldown Configuration for DP/DM Encoding .....                                                                | 3286 |
| 22-31. Pullup/Pulldown Configuration for DAT/SE0 Encoding .....                                                              | 3286 |
| 22-32. I/O Description .....                                                                                                 | 3287 |
| 22-33. High-Speed USB Host Subsystem Reset Description .....                                                                 | 3291 |
| 22-34. High-Speed USB Host Subsystem Clocks .....                                                                            | 3292 |
| 22-35. High-Speed USB Controller L3 Master Interface Clock .....                                                             | 3293 |
| 22-36. USBTLL Module Interface Clock .....                                                                                   | 3293 |
| 22-37. High-Speed USB Host Controller PRCM Clock Control Bits .....                                                          | 3294 |
| 22-38. High-Speed USB Host Controller MIDLEMODE Settings .....                                                               | 3295 |
| 22-39. High-Speed USB Host Controller SIDLEMODE Settings .....                                                               | 3296 |
| 22-40. High-Speed USB Host Controller CLOCKACTIVITY Settings .....                                                           | 3296 |
| 22-41. USBTLL Module PRCM Clock Control Bits .....                                                                           | 3296 |
| 22-42. USBTLL Module SIDLEMODE Settings .....                                                                                | 3297 |
| 22-43. USBTLL Module CLOCKACTIVITY Settings .....                                                                            | 3297 |
| 22-44. High-Speed USB Host Subsystem Interrupts .....                                                                        | 3298 |
| 22-45. USBTLL Channel USB Ports .....                                                                                        | 3303 |
| 22-46. USBTLL Channel Configuration .....                                                                                    | 3304 |
| 22-47. VBUS Level Software Reporting for Serial Transceiver Configuration .....                                              | 3307 |
| 22-48. Emulation of VBUS Levels for UTMI-to-ULPI TLL Mode .....                                                              | 3308 |
| 22-49. Serial Mode Description, Signal Functionality .....                                                                   | 3309 |
| 22-50. Pullup Enable Emulation in Serial TLL Modes .....                                                                     | 3310 |
| 22-51. USBTLL Registers Impacted by the SAR Context .....                                                                    | 3310 |
| 22-52. Register Call Summary for Selecting and Configuring High-Speed USB Host Subsystem Connectivity .....                  | 3312 |
| 22-53. Subprocess Call Summary for Selecting and Configuring High-Speed USB Host Subsystem Connectivity .....                | 3312 |
| 22-54. USB Connectivity Mode Description .....                                                                               | 3314 |
| 22-55. High-Speed USB Host Subsystem Instance Summary .....                                                                  | 3316 |
| 22-56. USBTLL Registers Mapping Summary (L4-Core Interconnect Register Space) .....                                          | 3317 |
| 22-57. UHH_config Registers Mapping Summary .....                                                                            | 3318 |
| 22-58. OHCI Registers Mapping Summary .....                                                                                  | 3318 |
| 22-59. EHCI Registers Mapping Summary .....                                                                                  | 3319 |
| 22-60. USBTLL_REVISION .....                                                                                                 | 3320 |
| 22-61. Register Call Summary for Register USBTLL_REVISION .....                                                              | 3320 |
| 22-62. USBTLL_SYSCONFIG .....                                                                                                | 3320 |
| 22-63. Register Call Summary for Register USBTLL_SYSCONFIG .....                                                             | 3321 |

---

|                                                                             |      |
|-----------------------------------------------------------------------------|------|
| 22-64. USBTLL_SYSSTATUS .....                                               | 3321 |
| 22-65. Register Call Summary for Register USBTLL_SYSSTATUS .....            | 3322 |
| 22-66. USBTLL_IRQSTATUS .....                                               | 3322 |
| 22-67. Register Call Summary for Register USBTLL_IRQSTATUS .....            | 3322 |
| 22-68. USBTLL_IRQENABLE .....                                               | 3323 |
| 22-69. Register Call Summary for Register USBTLL_IRQENABLE .....            | 3323 |
| 22-70. TLL_SHARED_CONF .....                                                | 3323 |
| 22-71. Register Call Summary for Register TLL_SHARED_CONF .....             | 3324 |
| 22-72. TLL_CHANNEL_CONF_i .....                                             | 3325 |
| 22-73. Register Call Summary for Register TLL_CHANNEL_CONF_i .....          | 3327 |
| 22-74. ULPI_VENDOR_ID_LO_i .....                                            | 3327 |
| 22-75. Register Call Summary for Register ULPI_VENDOR_ID_LO_i .....         | 3327 |
| 22-76. ULPI_VENDOR_ID_HI_i .....                                            | 3328 |
| 22-77. Register Call Summary for Register ULPI_VENDOR_ID_HI_i .....         | 3328 |
| 22-78. ULPI_PRODUCT_ID_LO_i .....                                           | 3328 |
| 22-79. Register Call Summary for Register ULPI_PRODUCT_ID_LO_i .....        | 3328 |
| 22-80. ULPI_PRODUCT_ID_HI_i .....                                           | 3328 |
| 22-81. Register Call Summary for Register ULPI_PRODUCT_ID_HI_i .....        | 3329 |
| 22-82. ULPI_FUNCTION_CTRL_i .....                                           | 3329 |
| 22-83. Register Call Summary for Register ULPI_FUNCTION_CTRL_i .....        | 3329 |
| 22-84. ULPI_FUNCTION_CTRL_SET_i .....                                       | 3330 |
| 22-85. Register Call Summary for Register ULPI_FUNCTION_CTRL_SET_i .....    | 3330 |
| 22-86. ULPI_FUNCTION_CTRL_CLR_i .....                                       | 3330 |
| 22-87. Register Call Summary for Register ULPI_FUNCTION_CTRL_CLR_i .....    | 3331 |
| 22-88. ULPI_INTERFACE_CTRL_i .....                                          | 3331 |
| 22-89. Register Call Summary for Register ULPI_INTERFACE_CTRL_i .....       | 3332 |
| 22-90. ULPI_INTERFACE_CTRL_SET_i .....                                      | 3332 |
| 22-91. Register Call Summary for Register ULPI_INTERFACE_CTRL_SET_i .....   | 3333 |
| 22-92. ULPI_INTERFACE_CTRL_CLR_i .....                                      | 3333 |
| 22-93. Register Call Summary for Register ULPI_INTERFACE_CTRL_CLR_i .....   | 3334 |
| 22-94. ULPI_OTG_CTRL_i .....                                                | 3334 |
| 22-95. Register Call Summary for Register ULPI_OTG_CTRL_i .....             | 3335 |
| 22-96. ULPI_OTG_CTRL_SET_i .....                                            | 3335 |
| 22-97. Register Call Summary for Register ULPI_OTG_CTRL_SET_i .....         | 3336 |
| 22-98. ULPI_OTG_CTRL_CLR_i .....                                            | 3336 |
| 22-99. Register Call Summary for Register ULPI_OTG_CTRL_CLR_i .....         | 3336 |
| 22-100. ULPI_USB_INT_EN_RISE_i .....                                        | 3337 |
| 22-101. Register Call Summary for Register ULPI_USB_INT_EN_RISE_i .....     | 3337 |
| 22-102. ULPI_USB_INT_EN_RISE_SET_i .....                                    | 3337 |
| 22-103. Register Call Summary for Register ULPI_USB_INT_EN_RISE_SET_i ..... | 3338 |
| 22-104. ULPI_USB_INT_EN_RISE_CLR_i .....                                    | 3338 |
| 22-105. Register Call Summary for Register ULPI_USB_INT_EN_RISE_CLR_i ..... | 3339 |
| 22-106. ULPI_USB_INT_EN_FALL_i .....                                        | 3339 |
| 22-107. Register Call Summary for Register ULPI_USB_INT_EN_FALL_i .....     | 3340 |
| 22-108. ULPI_USB_INT_EN_FALL_SET_i .....                                    | 3340 |
| 22-109. Register Call Summary for Register ULPI_USB_INT_EN_FALL_SET_i ..... | 3341 |
| 22-110. ULPI_USB_INT_EN_FALL_CLR_i .....                                    | 3341 |
| 22-111. Register Call Summary for Register ULPI_USB_INT_EN_FALL_CLR_i ..... | 3342 |
| 22-112. ULPI_USB_INT_STATUS_i .....                                         | 3342 |

|                                                                              |      |
|------------------------------------------------------------------------------|------|
| 22-113. Register Call Summary for Register ULPI_USB_INT_STATUS_i .....       | 3343 |
| 22-114. ULPI_USB_INT_LATCH_i .....                                           | 3343 |
| 22-115. Register Call Summary for Register ULPI_USB_INT_LATCH_i .....        | 3343 |
| 22-116. ULPI_DEBUG_i .....                                                   | 3344 |
| 22-117. Register Call Summary for Register ULPI_DEBUG_i .....                | 3344 |
| 22-118. ULPI_SCRATCH_REGISTER_i .....                                        | 3344 |
| 22-119. Register Call Summary for Register ULPI_SCRATCH_REGISTER_i .....     | 3344 |
| 22-120. ULPI_SCRATCH_REGISTER_SET_i .....                                    | 3345 |
| 22-121. Register Call Summary for Register ULPI_SCRATCH_REGISTER_SET_i ..... | 3345 |
| 22-122. ULPI_SCRATCH_REGISTER_CLR_i .....                                    | 3345 |
| 22-123. Register Call Summary for Register ULPI_SCRATCH_REGISTER_CLR_i ..... | 3345 |
| 22-124. ULPI_EXTENDED_SET_ACCESS_i .....                                     | 3345 |
| 22-125. Register Call Summary for Register ULPI_EXTENDED_SET_ACCESS_i .....  | 3346 |
| 22-126. ULPI_UTMI_VCONTROL_EN_i .....                                        | 3346 |
| 22-127. Register Call Summary for Register ULPI_UTMI_VCONTROL_EN_i .....     | 3346 |
| 22-128. ULPI_UTMI_VCONTROL_EN_SET_i .....                                    | 3346 |
| 22-129. Register Call Summary for Register ULPI_UTMI_VCONTROL_EN_SET_i ..... | 3347 |
| 22-130. ULPI_UTMI_VCONTROL_EN_CLR_i .....                                    | 3347 |
| 22-131. Register Call Summary for Register ULPI_UTMI_VCONTROL_EN_CLR_i ..... | 3348 |
| 22-132. ULPI_UTMI_VCONTROL_STATUS_i .....                                    | 3348 |
| 22-133. Register Call Summary for Register ULPI_UTMI_VCONTROL_STATUS_i ..... | 3348 |
| 22-134. ULPI_UTMI_VCONTROL_LATCH_i .....                                     | 3348 |
| 22-135. Register Call Summary for Register ULPI_UTMI_VCONTROL_LATCH_i .....  | 3349 |
| 22-136. ULPI_UTMI_VSTATUS_i .....                                            | 3349 |
| 22-137. Register Call Summary for Register ULPI_UTMI_VSTATUS_i .....         | 3349 |
| 22-138. ULPI_UTMI_VSTATUS_SET_i .....                                        | 3349 |
| 22-139. Register Call Summary for Register ULPI_UTMI_VSTATUS_SET_i .....     | 3350 |
| 22-140. ULPI_UTMI_VSTATUS_CLR_i .....                                        | 3350 |
| 22-141. Register Call Summary for Register ULPI_UTMI_VSTATUS_CLR_i .....     | 3350 |
| 22-142. ULPI_USB_INT_LATCH_NOCLR_i .....                                     | 3350 |
| 22-143. Register Call Summary for Register ULPI_USB_INT_LATCH_NOCLR_i .....  | 3351 |
| 22-144. ULPI_VENDOR_INT_EN_i .....                                           | 3351 |
| 22-145. Register Call Summary for Register ULPI_VENDOR_INT_EN_i .....        | 3351 |
| 22-146. ULPI_VENDOR_INT_EN_SET_i .....                                       | 3351 |
| 22-147. Register Call Summary for Register ULPI_VENDOR_INT_EN_SET_i .....    | 3352 |
| 22-148. ULPI_VENDOR_INT_EN_CLR_i .....                                       | 3352 |
| 22-149. Register Call Summary for Register ULPI_VENDOR_INT_EN_CLR_i .....    | 3352 |
| 22-150. ULPI_VENDOR_INT_STATUS_i .....                                       | 3352 |
| 22-151. Register Call Summary for Register ULPI_VENDOR_INT_STATUS_i .....    | 3353 |
| 22-152. ULPI_VENDOR_INT_LATCH_i .....                                        | 3353 |
| 22-153. Register Call Summary for Register ULPI_VENDOR_INT_LATCH_i .....     | 3353 |
| 22-154. UHH_REVISION .....                                                   | 3353 |
| 22-155. Register Call Summary for Register UHH_REVISION .....                | 3353 |
| 22-156. UHH_SYSCONFIG .....                                                  | 3354 |
| 22-157. Register Call Summary for Register UHH_SYSCONFIG .....               | 3354 |
| 22-158. UHH_SYSSTATUS .....                                                  | 3355 |
| 22-159. Register Call Summary for Register UHH_SYSSTATUS .....               | 3355 |
| 22-160. UHH_HOSTCONFIG .....                                                 | 3355 |
| 22-161. Register Call Summary for Register UHH_HOSTCONFIG .....              | 3356 |

---

|                                                                     |      |
|---------------------------------------------------------------------|------|
| 22-162. UHH_DEBUG_CSR .....                                         | 3357 |
| 22-163. Register Call Summary for Register UHH_DEBUG_CSR .....      | 3358 |
| 22-164. HCREVISION.....                                             | 3358 |
| 22-165. Register Call Summary for Register HCREVISION .....         | 3358 |
| 22-166. HCCONTROL .....                                             | 3358 |
| 22-167. Register Call Summary for Register HCCONTROL .....          | 3359 |
| 22-168. HCCOMMANDSTATUS .....                                       | 3359 |
| 22-169. Register Call Summary for Register HCCOMMANDSTATUS .....    | 3360 |
| 22-170. HCINTERRUPTSTATUS.....                                      | 3360 |
| 22-171. Register Call Summary for Register HCINTERRUPTSTATUS .....  | 3361 |
| 22-172. HCINTERRUPTENABLE.....                                      | 3361 |
| 22-173. Register Call Summary for Register HCINTERRUPTENABLE .....  | 3362 |
| 22-174. HCINTERRUPTDISABLE .....                                    | 3362 |
| 22-175. Register Call Summary for Register HCINTERRUPTDISABLE ..... | 3363 |
| 22-176. HCHCCA .....                                                | 3363 |
| 22-177. Register Call Summary for Register HCHCCA.....              | 3363 |
| 22-178. HCPERIODCURRENTED .....                                     | 3364 |
| 22-179. Register Call Summary for Register HCPERIODCURRENTED .....  | 3364 |
| 22-180. HCCONTROLHEADED .....                                       | 3364 |
| 22-181. Register Call Summary for Register HCCONTROLHEADED .....    | 3364 |
| 22-182. HCCONTROLCURRENTED.....                                     | 3364 |
| 22-183. Register Call Summary for Register HCCONTROLCURRENTED ..... | 3365 |
| 22-184. HCBULKHEADED .....                                          | 3365 |
| 22-185. Register Call Summary for Register HCBULKHEADED .....       | 3365 |
| 22-186. HCBULKCURRENTED.....                                        | 3365 |
| 22-187. Register Call Summary for Register HCBULKCURRENTED .....    | 3365 |
| 22-188. HCDONEHEAD .....                                            | 3366 |
| 22-189. Register Call Summary for Register HCDONEHEAD .....         | 3366 |
| 22-190. HCFMINTERVAL.....                                           | 3366 |
| 22-191. Register Call Summary for Register HCFMINTERVAL .....       | 3366 |
| 22-192. HCFMREMAINING .....                                         | 3367 |
| 22-193. Register Call Summary for Register HCFMREMAINING .....      | 3367 |
| 22-194. HCFMNUMBER .....                                            | 3367 |
| 22-195. Register Call Summary for Register HCFMNUMBER.....          | 3367 |
| 22-196. HCPERIODICSTART .....                                       | 3368 |
| 22-197. Register Call Summary for Register HCPERIODICSTART .....    | 3368 |
| 22-198. HCLSTHRESHOLD.....                                          | 3368 |
| 22-199. Register Call Summary for Register HCLSTHRESHOLD .....      | 3368 |
| 22-200. HCRHDESCRIPTORA .....                                       | 3368 |
| 22-201. Register Call Summary for Register HCRHDESCRIPTORA.....     | 3369 |
| 22-202. HCRHDESCRIPTORB .....                                       | 3369 |
| 22-203. Register Call Summary for Register HCRHDESCRIPTORB.....     | 3370 |
| 22-204. HCRHSTATUS .....                                            | 3370 |
| 22-205. Register Call Summary for Register HCRHSTATUS.....          | 3371 |
| 22-206. HCRHPORTSTATUS_1.....                                       | 3371 |
| 22-207. Register Call Summary for Register HCRHPORTSTATUS_1 .....   | 3372 |
| 22-208. HCRHPORTSTATUS_2.....                                       | 3372 |
| 22-209. Register Call Summary for Register HCRHPORTSTATUS_2 .....   | 3374 |
| 22-210. HCRHPORTSTATUS_3.....                                       | 3374 |

|                                                                           |      |
|---------------------------------------------------------------------------|------|
| 22-211. Register Call Summary for Register HCRHPORTSTATUS_3 .....         | 3376 |
| 22-212. HCCAPBASE .....                                                   | 3376 |
| 22-213. Register Call Summary for Register HCCAPBASE .....                | 3376 |
| 22-214. HCSPARAMS .....                                                   | 3376 |
| 22-215. Register Call Summary for Register HCSPARAMS .....                | 3377 |
| 22-216. HCCPARAMS .....                                                   | 3377 |
| 22-217. Register Call Summary for Register HCCPARAMS .....                | 3378 |
| 22-218. USBCMD .....                                                      | 3378 |
| 22-219. Register Call Summary for Register USBCMD .....                   | 3380 |
| 22-220. USBSTS .....                                                      | 3380 |
| 22-221. Register Call Summary for Register USBSTS .....                   | 3381 |
| 22-222. USBINTR .....                                                     | 3382 |
| 22-223. Register Call Summary for Register USBINTR .....                  | 3382 |
| 22-224. FRINDEX .....                                                     | 3383 |
| 22-225. Register Call Summary for Register FRINDEX .....                  | 3383 |
| 22-226. CTRLDSSEGMENT .....                                               | 3383 |
| 22-227. Register Call Summary for Register CTRLDSSEGMENT .....            | 3383 |
| 22-228. PERIODICLISTBASE .....                                            | 3383 |
| 22-229. Register Call Summary for Register PERIODICLISTBASE .....         | 3384 |
| 22-230. ASYNCLISTADDR .....                                               | 3384 |
| 22-231. Register Call Summary for Register ASYNCLISTADDR .....            | 3384 |
| 22-232. CONFIGFLAG .....                                                  | 3384 |
| 22-233. Register Call Summary for Register CONFIGFLAG .....               | 3385 |
| 22-234. PORTSC_i .....                                                    | 3385 |
| 22-235. Register Call Summary for Register PORTSC_i .....                 | 3387 |
| 22-236. INSNREG00 .....                                                   | 3387 |
| 22-237. Register Call Summary for Register INSNREG00 .....                | 3387 |
| 22-238. INSNREG01 .....                                                   | 3387 |
| 22-239. Register Call Summary for Register INSNREG01 .....                | 3388 |
| 22-240. INSNREG02 .....                                                   | 3388 |
| 22-241. Register Call Summary for Register INSNREG02 .....                | 3388 |
| 22-242. INSNREG03 .....                                                   | 3388 |
| 22-243. Register Call Summary for Register INSNREG03 .....                | 3388 |
| 22-244. INSNREG04 .....                                                   | 3389 |
| 22-245. Register Call Summary for Register INSNREG04 .....                | 3389 |
| 22-246. INSNREG05_UTMI .....                                              | 3389 |
| 22-247. Register Call Summary for Register INSNREG05_UTMI .....           | 3390 |
| 22-248. INSNREG05_ULPI .....                                              | 3390 |
| 22-249. Register Call Summary for Register INSNREG05_ULPI .....           | 3390 |
| 24-1. MMC/SD/SDIOi I/O Description .....                                  | 3398 |
| 24-2. MMC/SD/SDIO2 I/O Description .....                                  | 3399 |
| 24-3. Relation Between Configuration and Name of Response Type .....      | 3403 |
| 24-4. Smart Idle Mode and Wake-Up Capabilities .....                      | 3407 |
| 24-5. MMC, SD, SDIO responses in the MMCHS_RSPxx registers .....          | 3419 |
| 24-6. CC and TC Values Upon Error Detected .....                          | 3419 |
| 24-7. MMC/SD/SDIOi Controller Transfer Stop Command Summary .....         | 3425 |
| 24-8. Register Print for the MMCHS1 Controller Clock Initialization ..... | 3445 |
| 24-9. Software-Reset Register Description .....                           | 3445 |
| 24-10. MMCHS Controller Voltage Capabilities Initialization .....         | 3445 |

---

|                                                                    |      |
|--------------------------------------------------------------------|------|
| 24-11. MMC Controller Default Initialization Values.....           | 3446 |
| 24-12. MMCHS Controller INIT Procedure Start.....                  | 3446 |
| 24-13. MMCHS Controller Precard Identification Configuration ..... | 3446 |
| 24-14. Sending CMD0.....                                           | 3447 |
| 24-15. Sending CMD5.....                                           | 3447 |
| 24-16. Sending CMD8.....                                           | 3447 |
| 24-17. Sending CMD55 .....                                         | 3448 |
| 24-18. Sending CMD1.....                                           | 3448 |
| 24-19. Sending CMD2.....                                           | 3448 |
| 24-20. Sending CMD3.....                                           | 3449 |
| 24-21. MMC Bus Setting Change Table .....                          | 3449 |
| 24-22. Sending CMD9.....                                           | 3449 |
| 24-23. MMCHS_SYSCTL Value .....                                    | 3450 |
| 24-24. Sending CMD7.....                                           | 3450 |
| 24-25. Setting Data Bus Width With CMD6 .....                      | 3451 |
| 24-26. MMCHS_HCTL Value.....                                       | 3451 |
| 24-27. Enabling High-Speed With CMD6.....                          | 3451 |
| 24-28. MMCHS_SYSCTL Value .....                                    | 3451 |
| 24-29. Setting Block Length .....                                  | 3452 |
| 24-30. Setting Number of Blocks .....                              | 3452 |
| 24-31. CMD25 Issuing .....                                         | 3452 |
| 24-32. CMD18 Issuing .....                                         | 3453 |
| 24-33. Instance Summary .....                                      | 3454 |
| 24-34. MMC/SD/SDIO Register Summary .....                          | 3454 |
| 24-35. MMCHS_SYSCONFIG .....                                       | 3455 |
| 24-36. Register Call Summary for Register MMCHS_SYSCONFIG .....    | 3456 |
| 24-37. MMCHS_SYSSTATUS .....                                       | 3456 |
| 24-38. Register Call Summary for Register MMCHS_SYSSTATUS .....    | 3456 |
| 24-39. MMCHS_CSRE .....                                            | 3457 |
| 24-40. Register Call Summary for Register MMCHS_CSRE .....         | 3457 |
| 24-41. MMCHS_SYSTEST .....                                         | 3457 |
| 24-42. Register Call Summary for Register MMCHS_SYSTEST.....       | 3461 |
| 24-43. MMCHS_CON .....                                             | 3461 |
| 24-44. Register Call Summary for Register MMCHS_CON.....           | 3464 |
| 24-45. MMCHS_PWCNT .....                                           | 3465 |
| 24-46. Register Call Summary for Register MMCHS_PWCNT .....        | 3465 |
| 24-47. MMCHS_BLK .....                                             | 3465 |
| 24-48. Register Call Summary for Register MMCHS_BLK.....           | 3466 |
| 24-49. MMCHS_ARG .....                                             | 3467 |
| 24-50. Register Call Summary for Register MMCHS_ARG .....          | 3467 |
| 24-51. MMCHS_CMD .....                                             | 3467 |
| 24-52. Register Call Summary for Register MMCHS_CMD.....           | 3469 |
| 24-53. MMCHS_RSP10.....                                            | 3469 |
| 24-54. Register Call Summary for Register MMCHS_RSP10 .....        | 3470 |
| 24-55. MMCHS_RSP32.....                                            | 3470 |
| 24-56. Register Call Summary for Register MMCHS_RSP32 .....        | 3470 |
| 24-57. MMCHS_RSP54 .....                                           | 3471 |
| 24-58. Register Call Summary for Register MMCHS_RSP54 .....        | 3471 |
| 24-59. MMCHS_RSP76.....                                            | 3471 |

|                                                                   |      |
|-------------------------------------------------------------------|------|
| 24-60. Register Call Summary for Register MMCHS_RSP76 .....       | 3471 |
| 24-61. MMCHS_DATA .....                                           | 3472 |
| 24-62. Register Call Summary for Register MMCHS_DATA.....         | 3472 |
| 24-63. MMCHS_PSTATE .....                                         | 3473 |
| 24-64. Register Call Summary for Register MMCHS_PSTATE .....      | 3475 |
| 24-65. MMCHS_HCTL .....                                           | 3475 |
| 24-66. Register Call Summary for Register MMCHS_HCTL.....         | 3477 |
| 24-67. MMCHS_SYSCTL.....                                          | 3477 |
| 24-68. Register Call Summary for Register MMCHS_SYSCTL .....      | 3479 |
| 24-69. MMCHS_STAT .....                                           | 3479 |
| 24-70. Register Call Summary for Register MMCHS_STAT .....        | 3483 |
| 24-71. MMCHS_IE.....                                              | 3483 |
| 24-72. Register Call Summary for Register MMCHS_IE .....          | 3485 |
| 24-73. MMCHS_ISE .....                                            | 3485 |
| 24-74. Register Call Summary for Register MMCHS_ISE .....         | 3487 |
| 24-75. MMCHS_AC12.....                                            | 3487 |
| 24-76. Register Call Summary for Register MMCHS_AC12 .....        | 3488 |
| 24-77. MMCHS_CAPA .....                                           | 3488 |
| 24-78. Register Call Summary for Register MMCHS_CAPA .....        | 3490 |
| 24-79. MMCHS_CUR_CAPA.....                                        | 3490 |
| 24-80. Register Call Summary for Register MMCHS_CUR_CAPA .....    | 3490 |
| 24-81. MMCHS_REV.....                                             | 3492 |
| 24-82. Register Call Summary for Register MMCHS_REV .....         | 3492 |
| 25-1. I/O Pin Description .....                                   | 3499 |
| 25-2. Clocks .....                                                | 3501 |
| 25-3. Interrupts.....                                             | 3504 |
| 25-4. Wake-Up Signals .....                                       | 3505 |
| 25-5. GPIO Channel Description .....                              | 3505 |
| 25-6. Instance Summary .....                                      | 3517 |
| 25-7. GPIO1 Register Summary.....                                 | 3517 |
| 25-8. GPIO2 Register Summary.....                                 | 3518 |
| 25-9. GPIO3 Register Summary.....                                 | 3518 |
| 25-10. GPIO4 Register Summary.....                                | 3519 |
| 25-11. GPIO5 Register Summary.....                                | 3519 |
| 25-12. GPIO6 Register Summary.....                                | 3520 |
| 25-13. GPIO_REVISION .....                                        | 3521 |
| 25-14. Register Call Summary for Register GPIO_REVISION .....     | 3522 |
| 25-15. GPIO_SYSCONFIG .....                                       | 3522 |
| 25-16. Register Call Summary for Register GPIO_SYSCONFIG .....    | 3522 |
| 25-17. GPIO_SYSSTATUS.....                                        | 3523 |
| 25-18. Register Call Summary for Register GPIO_SYSSTATUS .....    | 3523 |
| 25-19. GPIO_IRQSTATUS1 .....                                      | 3524 |
| 25-20. Register Call Summary for Register GPIO_IRQSTATUS1 .....   | 3524 |
| 25-21. GPIO_IRQENABLE1 .....                                      | 3524 |
| 25-22. Register Call Summary for Register GPIO_IRQENABLE1 .....   | 3525 |
| 25-23. GPIO_WAKEUPENABLE .....                                    | 3525 |
| 25-24. Register Call Summary for Register GPIO_WAKEUPENABLE ..... | 3525 |
| 25-25. GPIO_IRQSTATUS2.....                                       | 3526 |
| 25-26. Register Call Summary for Register GPIO_IRQSTATUS2 .....   | 3526 |

---

|                                                                      |      |
|----------------------------------------------------------------------|------|
| 25-27. GPIO_IRQENABLE2 .....                                         | 3527 |
| 25-28. Register Call Summary for Register GPIO_IRQENABLE2 .....      | 3527 |
| 25-29. GPIO_CTRL.....                                                | 3528 |
| 25-30. Register Call Summary for Register GPIO_CTRL .....            | 3528 |
| 25-31. GPIO_OE .....                                                 | 3529 |
| 25-32. Register Call Summary for Register GPIO_OE .....              | 3529 |
| 25-33. GPIO_DATAIN.....                                              | 3529 |
| 25-34. Register Call Summary for Register GPIO_DATAIN .....          | 3530 |
| 25-35. GPIO_DATAOUT .....                                            | 3530 |
| 25-36. Register Call Summary for Register GPIO_DATAOUT .....         | 3530 |
| 25-37. GPIO_LEVELDETECT0 .....                                       | 3531 |
| 25-38. Register Call Summary for Register GPIO_LEVELDETECT0.....     | 3531 |
| 25-39. GPIO_LEVELDETECT1 .....                                       | 3531 |
| 25-40. Register Call Summary for Register GPIO_LEVELDETECT1.....     | 3532 |
| 25-41. GPIO_RISINGDETECT .....                                       | 3532 |
| 25-42. Register Call Summary for Register GPIO_RISINGDETECT .....    | 3532 |
| 25-43. GPIO_FALLINGDETECT .....                                      | 3533 |
| 25-44. Register Call Summary for Register GPIO_FALLINGDETECT .....   | 3533 |
| 25-45. GPIO_DEBOUNCENABLE .....                                      | 3533 |
| 25-46. Register Call Summary for Register GPIO_DEBOUNCENABLE .....   | 3534 |
| 25-47. GPIO_DEBOUNCINGTIME .....                                     | 3534 |
| 25-48. Register Call Summary for Register GPIO_DEBOUNCINGTIME.....   | 3534 |
| 25-49. GPIO_CLEARIRQENABLE1 .....                                    | 3535 |
| 25-50. Register Call Summary for Register GPIO_CLEARIRQENABLE1 ..... | 3535 |
| 25-51. GPIO_SETIRQENABLE1 .....                                      | 3535 |
| 25-52. Register Call Summary for Register GPIO_SETIRQENABLE1 .....   | 3536 |
| 25-53. GPIO_CLEARIRQENABLE2 .....                                    | 3536 |
| 25-54. Register Call Summary for Register GPIO_CLEARIRQENABLE2 ..... | 3536 |
| 25-55. GPIO_SETIRQENABLE2 .....                                      | 3536 |
| 25-56. Register Call Summary for Register GPIO_SETIRQENABLE2 .....   | 3537 |
| 25-57. GPIO_CLEARWKUENA .....                                        | 3537 |
| 25-58. Register Call Summary for Register GPIO_CLEARWKUENA .....     | 3537 |
| 25-59. GPIO_SETWKUENA.....                                           | 3538 |
| 25-60. Register Call Summary for Register GPIO_SETWKUENA .....       | 3538 |
| 25-61. GPIO_CLEARDATAOUT .....                                       | 3538 |
| 25-62. Register Call Summary for Register GPIO_CLEARDATAOUT .....    | 3539 |
| 25-63. GPIO_SETDATAOUT.....                                          | 3539 |
| 25-64. Register Call Summary for Register GPIO_SETDATAOUT .....      | 3539 |
| 26-1. Power Pins .....                                               | 3544 |
| 26-2. Mapping For Input Sources .....                                | 3547 |
| 26-3. Memory Preferred Booting Configuration Pins After POR .....    | 3549 |
| 26-4. Peripheral Preferred Booting Configuration Pins After POR..... | 3550 |
| 26-5. Booting Configuration Pins After a Warm Reset .....            | 3551 |
| 26-6. Pin Multiplexing According to Boot Peripheral.....             | 3553 |
| 26-7. ROM Exception Vectors .....                                    | 3555 |
| 26-8. Dead Loops .....                                               | 3556 |
| 26-9. Tracing Data .....                                             | 3557 |
| 26-10. RAM Exception Vectors .....                                   | 3557 |
| 26-11. ROM Code Default Clock Settings .....                         | 3561 |

|                                                              |      |
|--------------------------------------------------------------|------|
| 26-12. Software Booting Configuration Structure .....        | 3562 |
| 26-13. ASIC-ID Structure .....                               | 3564 |
| 26-14. Boot Messages .....                                   | 3565 |
| 26-15. Device Descriptor.....                                | 3567 |
| 26-16. Device-Qualifier Descriptor.....                      | 3568 |
| 26-17. Configuration Descriptor.....                         | 3568 |
| 26-18. Other Speed Configuration Descriptor.....             | 3568 |
| 26-19. Interface Descriptor .....                            | 3569 |
| 26-20. BULK IN Endpoint Descriptor.....                      | 3569 |
| 26-21. BULK OUT Endpoint Descriptor .....                    | 3569 |
| 26-22. Language ID String Descriptor .....                   | 3570 |
| 26-23. Manufacturer ID String Descriptor.....                | 3570 |
| 26-24. Product ID String Descriptor .....                    | 3570 |
| 26-25. Configuration String Descriptor .....                 | 3570 |
| 26-26. Interface String Descriptor.....                      | 3570 |
| 26-27. Customized Descriptor Parameters.....                 | 3571 |
| 26-28. Standard Device Requests Supported .....              | 3572 |
| 26-29. Blocks and Sectors Searched on Non-XIP Memories ..... | 3575 |
| 26-30. XIP Timing Parameters .....                           | 3576 |
| 26-31. NAND Timing Parameters.....                           | 3577 |
| 26-32. Supported NAND Devices.....                           | 3578 |
| 26-33. Fourth NAND ID Data Byte .....                        | 3579 |
| 26-34. ID2 Byte Description .....                            | 3583 |
| 26-35. Bad Block Mark Locations in NAND Spare Areas .....    | 3584 |
| 26-36. Hamming Code Parity Bit Locations .....               | 3585 |
| 26-37. Master Boot Record Structure .....                    | 3595 |
| 26-38. Partition Table Entry .....                           | 3595 |
| 26-39. FAT Directory Entry .....                             | 3598 |
| 26-40. FAT Entry Description .....                           | 3599 |
| 26-41. CH TOC Item .....                                     | 3601 |
| 26-42. CHSETTINGS.....                                       | 3601 |
| 26-43. CHRAM .....                                           | 3602 |
| 26-44. CHFLASH .....                                         | 3604 |
| 26-45. CHMMCSD CH .....                                      | 3604 |
| 26-46. GP Device Software Image .....                        | 3605 |
| 26-47. Booting Parameter Structure.....                      | 3605 |
| 26-48. Tracing Vector .....                                  | 3606 |
| 26-49. CONTROL_SAVE_RESTORE_MEM Field Definitions.....       | 3609 |
| 26-50. PRCM Register Organization in the SCM Block .....     | 3610 |
| 26-51. SDRC Register Organization in the SCM Block.....      | 3610 |
| 26-52. Debug POR Signals.....                                | 3612 |
| 26-53. Debugger Address Space .....                          | 3613 |
| 27-1. JTAG Pins .....                                        | 3618 |
| 27-2. Secondary Debug TAP Mapping .....                      | 3620 |
| 27-3. ICEPick Boot Mode .....                                | 3621 |
| 27-4. ICEPick Instructions.....                              | 3621 |
| 27-5. ICEPick Registers .....                                | 3626 |
| 27-6. Register Reset Conditions.....                         | 3626 |
| 27-7. DSR .....                                              | 3626 |

---

|                                                                |      |
|----------------------------------------------------------------|------|
| 27-8. IR .....                                                 | 3627 |
| 27-9. BP .....                                                 | 3627 |
| 27-10. TAPID .....                                             | 3627 |
| 27-11. UC .....                                                | 3628 |
| 27-12. IPID.....                                               | 3628 |
| 27-13. CONNECT.....                                            | 3628 |
| 27-14. TAP_ROUTING.....                                        | 3629 |
| 27-15. TAP Routing Mode Block Selection.....                   | 3629 |
| 27-16. ICEPick Control Block Registers .....                   | 3630 |
| 27-17. ALL0S .....                                             | 3630 |
| 27-18. CONTROL.....                                            | 3630 |
| 27-19. LINKING_MODE.....                                       | 3631 |
| 27-20. DESELECTMODE Values.....                                | 3632 |
| 27-21. TAPLINKMODE Values.....                                 | 3632 |
| 27-22. Debug TAP Linking Control Block Registers .....         | 3633 |
| 27-23. SDTRj .....                                             | 3633 |
| 27-24. RESETCONTROL Values.....                                | 3635 |
| 27-25. DEBUGMODE Values .....                                  | 3635 |
| 27-26. SDTI Pins.....                                          | 3638 |
| 27-27. SDTI CPU Software Messages.....                         | 3640 |
| 27-28. CPU1 Timestamped Message .....                          | 3641 |
| 27-29. CPU1 Message .....                                      | 3641 |
| 27-30. CPU2 Timestamped Message .....                          | 3641 |
| 27-31. CPU2 Message .....                                      | 3642 |
| 27-32. Ownership Commands .....                                | 3644 |
| 27-33. Claim Bits .....                                        | 3644 |
| 27-34. FIFO Data Organization .....                            | 3646 |
| 27-35. Test Pattern Format.....                                | 3646 |
| 27-36. Simple Test Pattern .....                               | 3647 |
| 27-37. Walking Test Pattern.....                               | 3647 |
| 27-38. sdti_clk Divider Value .....                            | 3648 |
| 27-39. SDTI Memory Mapping .....                               | 3648 |
| 27-40. Channel Access Example .....                            | 3649 |
| 27-41. SDTI Register Ownership .....                           | 3651 |
| 27-42. SDTI Instance Summary .....                             | 3652 |
| 27-43. SDTI Register Summary.....                              | 3652 |
| 27-44. SDTI_REVISION .....                                     | 3653 |
| 27-45. Register Call Summary for Register SDTI_REVISION .....  | 3653 |
| 27-46. SDTI_SYSCONFIG .....                                    | 3653 |
| 27-47. Register Call Summary for Register SDTI_SYSCONFIG ..... | 3654 |
| 27-48. SDTI_SYSSTATUS .....                                    | 3654 |
| 27-49. Register Call Summary for Register SDTI_SYSSTATUS ..... | 3654 |
| 27-50. SDTI_WINCTRL .....                                      | 3655 |
| 27-51. Register Call Summary for Register SDTI_WINCTRL.....    | 3655 |
| 27-52. SDTI_SCONFIG .....                                      | 3656 |
| 27-53. Register Call Summary for Register SDTI_SCONFIG.....    | 3656 |
| 27-54. SDTI_TESTCTRL .....                                     | 3657 |
| 27-55. Register Call Summary for Register SDTI_TESTCTRL.....   | 3657 |
| 27-56. INT_MODE_CTRL_REG .....                                 | 3657 |

|                                                                      |      |
|----------------------------------------------------------------------|------|
| 27-57. Register Call Summary for Register INT_MODE_CTRL_REG.....     | 3658 |
| 27-58. INT_OUTPUT_REG.....                                           | 3658 |
| 27-59. Register Call Summary for Register INT_OUTPUT_REG .....       | 3658 |
| 27-60. INT_INPUT_REG.....                                            | 3659 |
| 27-61. Register Call Summary for Register INT_INPUT_REG .....        | 3659 |
| 27-62. CLAIM_TAG_SET_REG.....                                        | 3659 |
| 27-63. Register Call Summary for Register CLAIM_TAG_SET_REG .....    | 3660 |
| 27-64. CLAIM_TAG_CLEAR_REG .....                                     | 3660 |
| 27-65. Register Call Summary for Register CLAIM_TAG_CLEAR_REG .....  | 3660 |
| 27-66. LOCK_ACCESS_REG.....                                          | 3661 |
| 27-67. Register Call Summary for Register LOCK_ACCESS_REG .....      | 3661 |
| 27-68. LOCK_STATUS_REG .....                                         | 3661 |
| 27-69. Register Call Summary for Register LOCK_STATUS_REG.....       | 3662 |
| 27-70. AUTHENTICATION_STATUS .....                                   | 3662 |
| 27-71. Register Call Summary for Register AUTHENTICATION_STATUS..... | 3662 |
| 27-72. DEVICE_ID.....                                                | 3663 |
| 27-73. Register Call Summary for Register DEVICE_ID .....            | 3663 |
| 27-74. DEVICE_TYPE_REG .....                                         | 3663 |
| 27-75. Register Call Summary for Register DEVICE_TYPE_REG.....       | 3663 |
| 27-76. PERIPHERAL_ID4 .....                                          | 3664 |
| 27-77. Register Call Summary for Register PERIPHERAL_ID4.....        | 3664 |
| 27-78. PERIPHERAL_ID5 .....                                          | 3664 |
| 27-79. Register Call Summary for Register PERIPHERAL_ID5.....        | 3664 |
| 27-80. PERIPHERAL_ID6 .....                                          | 3665 |
| 27-81. Register Call Summary for Register PERIPHERAL_ID6.....        | 3665 |
| 27-82. PERIPHERAL_ID7 .....                                          | 3665 |
| 27-83. Register Call Summary for Register PERIPHERAL_ID7.....        | 3665 |
| 27-84. PERIPHERAL_ID0 .....                                          | 3666 |
| 27-85. Register Call Summary for Register PERIPHERAL_ID0.....        | 3666 |
| 27-86. PERIPHERAL_ID1 .....                                          | 3666 |
| 27-87. Register Call Summary for Register PERIPHERAL_ID1.....        | 3666 |
| 27-88. PERIPHERAL_ID2 .....                                          | 3667 |
| 27-89. Register Call Summary for Register PERIPHERAL_ID2.....        | 3667 |
| 27-90. PERIPHERAL_ID3 .....                                          | 3667 |
| 27-91. Register Call Summary for Register PERIPHERAL_ID3.....        | 3668 |
| 27-92. COMPONENT_ID0.....                                            | 3668 |
| 27-93. Register Call Summary for Register COMPONENT_ID0 .....        | 3668 |
| 27-94. COMPONENT_ID1 .....                                           | 3668 |
| 27-95. Register Call Summary for Register COMPONENT_ID1 .....        | 3668 |
| 27-96. COMPONENT_ID2.....                                            | 3669 |
| 27-97. Register Call Summary for Register COMPONENT_ID2 .....        | 3669 |
| 27-98. COMPONENT_ID3.....                                            | 3669 |
| 27-99. Register Call Summary for Register COMPONENT_ID3 .....        | 3669 |
| 27-100. EPM Multiplexing.....                                        | 3672 |
| 27-101. EPM Control .....                                            | 3673 |
| 27-102. Concurrent Debug Interfaces .....                            | 3673 |
| 27-103. Claim States .....                                           | 3674 |
| 27-104. Claim Commands .....                                         | 3674 |
| 27-105. Triggers.....                                                | 3675 |

[www.ti.com](http://www.ti.com)

---

|                                                                                   |      |
|-----------------------------------------------------------------------------------|------|
| 27-106. Trigger + HS-RTDX .....                                                   | 3675 |
| 27-107. SDTI [Single-Pin Data + Clock] + ETM16 .....                              | 3675 |
| 27-108. Trigger + HS-RTDX + ETM8 + SDTI [4-Pin Data + Clock/Dedicated Port] ..... | 3675 |
| 27-109. Trigger + HS-RTDX + ETM8 + SDTI [2-Pin Data + Clock] .....                | 3675 |
| 27-110. ETM8 + SDTI [4-Pin Data + Clock] .....                                    | 3676 |
| 27-111. EPM Instance Summary .....                                                | 3676 |
| 27-112. EPM Register Summary.....                                                 | 3676 |
| 27-113. DAPC_EPM0 .....                                                           | 3677 |
| 27-114. Register Call Summary for Register DAPC_EPM0.....                         | 3677 |
| 27-115. DAPC_EPM1 .....                                                           | 3677 |
| 27-116. Register Call Summary for Register DAPC_EPM1.....                         | 3677 |
| 27-117. DAPC_EPM2 .....                                                           | 3678 |
| 27-118. Register Call Summary for Register DAPC_EPM2.....                         | 3678 |





## ***Read This First***

---

---

---

### **Community Resources**

The following link connects to TI community resources. Linked contents are provided "AS IS" by the respective contributors. They do not constitute TI specifications and do not necessarily reflect TI's views; see TI's [Terms of Use](#).

**[TI Embedded Processors Wiki](#)** —Texas Instruments Embedded Processors Wiki

Established to assist developers using the many Embedded Processors from Texas Instruments to get started, help each other innovate, and foster the growth of general knowledge about the hardware and software surrounding these devices.

---

If You Need Assistance. . .

[www.ti.com](http://www.ti.com)

**If You Need Assistance. . .**

| If you want to . . .                                                                      | Do this . . .                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Request more information about Texas Instruments Digital Signal Processing (DSP) products | Call the CRC <sup>(1)</sup> hotline:<br><b>(800) 336-5236</b><br>Or write to:<br>Texas Instruments Incorporated<br>Market Communications Manager, MS 736<br>P.O. Box 1443<br>Houston, Texas 77251-1443 |
| Order Texas Instruments documentation                                                     | Call the CRC <sup>(1)</sup> hotline:<br><b>(800) 336-5236</b>                                                                                                                                          |

<sup>(1)</sup> Texas Instruments Customer Response Center

## About This Manual

### FCC Warning

This equipment is intended for use in a laboratory test environment only. It generates, uses, and can radiate radio frequency energy and has not been tested for compliance with the limits of computing devices pursuant to subpart J of part 15 of FCC rules, which are designed to provide reasonable protection against radio frequency interference. Operation of this equipment in other environments may cause interference with radio communications, in which case the user at his own expense will be required to take whatever measures may be required to correct this interference.

### Information About Cautions and Warnings

This book may contain cautions and warnings.

#### **CAUTION**

This is an example of a caution statement.

A caution statement describes a situation that could potentially damage your software or equipment.

#### **WARNING**

**This is an example of a warning statement.**

**A warning statement describes a situation that could potentially cause harm to you.**

The information in a caution or a warning is provided for your protection. Please read each caution and warning carefully.

## Register, Field, and Bit Calls

The naming convention applied for a call consists of:

- For a register call: <Module name>.<Register name>; for example: UART.UASR
- For a bit field call:
  - <Module name>.<Register name>[End:Start] <Field name> field; for example, UART.UASR[4:0] SPEED bit field
  - <Field name> field <Module name>.<Register name>[End:Start]; for example, SPEED bit field UART.UASR[4:0]
- For a bit call:
  - <Module name>.<Register name>[pos] <Bit name> bit; for example, UART.UASR[5] BIT\_BY\_CHAR bit
  - <Bit name> bit <Module name>.<Register name>[pos]; for example, BIT\_BY\_CHAR bit UART.UASR[5]

To help the reader navigate the document, each register call is hyperlinked to its register description in the register manual section. After each register description, a table summarizes all hyperlinked register calls.

To navigate in the PDF documents, see [Acrobat Reader Tips](#).

## Coding Rules

The programming models or code listings follow the rules:

| Type        | Definition                                                                                                     | Example                                                                                                         |
|-------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| File        | Starts with the module name                                                                                    | PRCM_test1.c<br>MCBSP1_init.h                                                                                   |
| Variable    | Global variables are prefixed by "g_"<br>Pointers are prefixed by "p"<br>Global pointers are prefixed by "g_p" | g_SDMA_LogicalChan<br>pAddrCounter<br>g_pSDMA_LogicalChan                                                       |
| Function    | Starts with the module name                                                                                    | PRCM_SetupClocks()<br>ArmlIntC_MaskInterrupts()                                                                 |
| Typedef     | Ends with "_t"                                                                                                 | PRCM_Struct_t                                                                                                   |
| Definition  | Starts with the module name and is followed by the register name                                               | #define SMS_ERR_TYPE *((volatile UInt32*)0x680080F4)<br>#define MCBSP2_RCR1_REG *((volatile UInt32*)0x4807401C) |
| Enumeration | Starts with the module name                                                                                    | Typedef enum DMA_Mode_Label<br>{<br>INPUT_MODE<br>OUTPUT_MODE<br>} DMA_Mode_t;                                  |

## Flow Chart Rules

Flow charts follow the following rules:

| Shape                                                                               | Name                              | Definition                                                                                                                                  |
|-------------------------------------------------------------------------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
|    | Process                           | Any computational steps or processing function of a program; defined operation(s) causing change in value, form, or location of information |
|    | Decision                          | A decision or switching-type operation that determines which of a number of alternate paths is followed                                     |
|    | Predefined process or sub-process | One or more named operations or program steps specified in a subroutine or another set of flow charts                                       |
|    | Data or I/O                       | General I/O function; information available for processing (input) or recording of processed information (output)                           |
|    | Terminator                        | Terminal point in a flow chart: start, stop, halt, delay, or interrupt; may show exit from a closed subroutine                              |
|   | Annotation                        | Additional descriptive clarification, comment                                                                                               |
|  | On page connector (reference)     | Exit to, or entry from, another part of chart in the same page                                                                              |
|  | Off page connector (reference)    | The flow continues on a different page.                                                                                                     |
|  | Summing Junction                  | Logical AND                                                                                                                                 |
|  | Or                                | Logical OR                                                                                                                                  |
|  | Parallel mode (ISO)               | Beginning or end of two or more simultaneous operations                                                                                     |
|  | Flow Line                         | Lines indicate the sequence of steps and the direction of flow.                                                                             |

## Acrobat Reader Tips

Acrobat includes two methods to search for words in a PDF:

- The Find toolbar provides a basic set of options to locate a word in the current PDF.
- The Search window lists words or partial words that match your text in the current PDF.

These guidelines apply to Acrobat Reader 5.x, 6.0, and 7.0.

For more information on Acrobat Reader search features, see the Adobe Reader Help.

### To search for words in a document using the Find dialog box:

1. Open the document.
2. To display the Find toolbar, right-click in the toolbar area and select Find.
3. In the Find box, type the word, words, or partial words for which you want to search.
4. From the Find Options menu, select options as desired.
5. To view each search result, click the Find toolbar, the Find Previous button, or the Find Next button to go backward or forward through the document.

### To search for words in a document using the Search PDF window:

1. Open the document.
2. Click the Search button on the File toolbar or right-click on your document and select Search.
3. Type the word, words, or part of a word for which you want to search.
4. Click Search.
5. The results appear in page order and, if applicable, show a few words of context. Each result displays an icon to identify the type of occurrence. All other searchable areas display the Search Result icon.
6. To display the page that contains a search result, click an item in the Results list. The occurrence is highlighted.
7. To navigate to the next result, choose Edit > Search Results > Next Result (or Ctrl+G).
8. To navigate to the previous result, choose Edit > Search Results > Previous Result (or Shift+Ctrl+G).

### Navigate through your previous view

To retrace your path within an Adobe PDF document:

- For the previous view: Choose View > Go To > Previous View or Alt+Left Arrow.
- For the next view: Choose View > Go To > Next View or Alt+Right Arrow. The Next View command is available only if you have chosen Previous View.

If you view the PDF document in a browser, use options on the Navigation toolbar to move between views.

- Right-click the toolbar area, and then choose *Navigation*.
- Click the Go To Previous View button or the Go To Next View button.

---

**NOTE:** This navigation tip is useful to return to your previous view after clicking on a register call hyperlink.

---

## AM/DM37x Disclaimer

All programming models and use cases presented in this manual are provided for educative purposes only and may differ from or be optimized for your applications.

All peripheral devices presented in this manual are provided for illustration purposes and may be different from those in your system.

## AM/DM37x MIPI® Disclaimer

The material contained herein is not a license, either expressly or impliedly, to any IPR owned or controlled by any of the authors or developers of this material or MIPI. The material contained herein is provided on an "AS IS" basis and to the maximum extent permitted by applicable law, this material is provided AS IS AND WITH ALL FAULTS, and the authors and developers of this material and MIPI hereby disclaim all other warranties and conditions, either express, implied or statutory, including, but not limited to, any (if any) implied warranties, duties or conditions of merchantability, of fitness for a particular purpose, of accuracy or completeness of responses, of results, of workmanlike effort, of lack of viruses, and of lack of negligence.

**ALSO, THERE IS NO WARRANTY OF CONDITION OF TITLE, QUIET ENJOYMENT, QUIET POSSESSION, CORRESPONDENCE TO DESCRIPTION OR NON-INFRINGEMENT WITH REGARD TO THIS MATERIAL OR THE CONTENTS OF THIS DOCUMENT. IN NO EVENT WILL ANY AUTHOR OR DEVELOPER OF THIS MATERIAL OR THE CONTENTS OF THIS DOCUMENT OR MIPI BE LIABLE TO ANY OTHER PARTY FOR THE COST OF PROCURING SUBSTITUTE GOODS OR SERVICES, LOST PROFITS, LOSS OF USE, LOSS OF DATA, OR ANY INCIDENTAL, CONSEQUENTIAL, DIRECT, INDIRECT, OR SPECIAL DAMAGES WHETHER UNDER CONTRACT, TORT, WARRANTY, OR OTHERWISE, ARISING IN ANY WAY OUT OF THIS OR ANY OTHER AGREEMENT, SPECIFICATION OR DOCUMENT RELATING TO THIS MATERIAL, WHETHER OR NOT SUCH PARTY HAD ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES.**

Without limiting the generality of this Disclaimer stated above, the user of the contents of this Document is further notified that MIPI: (a) does not evaluate, test or verify the accuracy, soundness or credibility of the contents of this Document; (b) does not monitor or enforce compliance with the contents of this Document; and (c) does not certify, test, or in any manner investigate products or services or any claims of compliance with the contents of this Document. The use or implementation of the contents of this Document may involve or require the use of intellectual property rights ("IPR") including (but not limited to) patents, patent applications, or copyrights owned by one or more parties, whether or not Members of MIPI. MIPI does not make any search or investigation for IPR, nor does MIPI require or request the disclosure of any IPR or claims of IPR as respects the contents of this Document or otherwise. Questions pertaining to this document, or the terms or conditions of its provision, should be addressed to:

MIPI Alliance, Inc. c/o IEEE-ISTO 445 Hoes Lane Piscataway, NJ 08854 Attn: Board Secretary

## Trademarks

OMAP, TMS320DMC64x, C64x, AM, Sitara, ICECrusher and SmartReflex are trademarks of Texas Instruments Incorporated.

ARM, JAZELLE, and THUMB are registered trademarks of ARM Limited. ETM, ETB, ARM9, CoreSight, Cortex and Neon are trademarks of ARM Limited.

Java is a trademark of Sun Microsystems, Inc.

Bluetooth is a registered trademark of Bluetooth SIG, Inc. and is licensed to Texas Instruments.

Memory Stick is a registered trademark of Sony Corporation, and Memory Stick PRO is a trademark of Sony Corporation.

HDQ is a trademark of Benchmarkq.

1-Wire is a registered trademark of Dallas Semiconductor.

Windows and Direct3D are registered trademarks of Microsoft Corporation in the United States and other countries.

USSE and POWERVR are trademarks or registered trademarks of Imagination Technologies Ltd.

Mentor Graphics is a registered trademark of Mentor Graphics Corporation or its affiliated companies in the United States and other countries.

DiskOnChip is a trademark of M-Systems.

OpenGL is a trademark of Silicon Graphics, Inc.

OpenVG is a trademark of Khronos Group, Inc.

SD is a registered trademark of Toshiba Corporation.

eSD is a trademark of SD Association.

MMC and eMMC are trademarks of MultiMediaCard Association.

SonicsMX, Sonics3220 are trademarks or registered trademarks of Sonics, Inc.

Super CCD Honeycom is a registered trademark of Fuji Photo Film Co., Ltd.

JTAG is a registered trademark of JTAG Technologies, Inc.

Linux is a registered trademark of Linus Torvalds.

Symbian and all Symbian based trademarks and logos are trademarks of Symbian Software Limited.

Synopsys is a registered trademark of Synopsys, Inc.

MIPI is a registered trademark of the Mobile Industry Processor Interface (MIPI) Alliance.

Flex-OneNAND and OneNAND are trademarks of SAMSUNG Electronics, Corporation.

All other trademarks are the property of their respective owners.

## History

The following table summarizes the AM/DM37x TRM versions.

| Version | Literature Number | Date           | Notes              |
|---------|-------------------|----------------|--------------------|
| *       | SPRUGN4           | May 2010       | See <sup>(1)</sup> |
| A       | SPRUGN4           | August 2010    | See <sup>(2)</sup> |
| B       | SPRUGN4           | August 2010    | See <sup>(3)</sup> |
| C       | SPRUGN4           | September 2010 | See <sup>(4)</sup> |
| D       | SPRUGN4           | October 2010   | See <sup>(5)</sup> |
| E       | SPRUGN4           | November 2010  | See <sup>(6)</sup> |

<sup>(1)</sup> Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.1 Technical Reference Manual* - Initial release (SPRUGN4)

<sup>(2)</sup> Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* - version A (SPRUGN4A). Chapters impacted by changes between version \* and version A:

- Chapter 1: Introduction
- Chapter 3: Power, Reset, and Clock Management
- Chapter 6: Camera Image Signal Processor
- Chapter 7: Display Subsystem
- Chapter 10: Memory Subsystem
- Chapter 21: Multichannel Buffered Serial Port
- Chapter 22: High-Speed USB Host Subsystem and High-Speed USB OTG Controller
- Chapter 26: Initialization

For more details about the changes between initial version (SPRUGN4) and version A (SPRUGN4A), see the AM/DM37x Technical Reference Manual Delta between initial version \* and version A (lit number - SPRUGW9) available on ti.com

<sup>(3)</sup> Public Version of *AM/DM37X Multimedia Device Silicon Revision 1.x Technical Reference Manual* - version B (SPRUGN4B). Chapters impacted by changes between version A and version B:

- Chapter 3: Power, Reset, and Clock Management
- Chapter 7: Display Subsystem
- Chapter 9: Interconnect
- Chapter 13: System Control Module
- Chapter 22: High-Speed USB Host Subsystem and High-Speed USB OTG Controller
- Chapter 26: Initialization

For more details about the changes between version A and version B, see the AM/DM37x Technical Reference Manual Delta between version A and version B (lit number - SPRUGW9A) available on ti.com.

<sup>(4)</sup> Public Version of *AM/DM37X Multimedia Device Silicon Revision 1.x Technical Reference Manual* - version C (SPRUGN4C). Chapters impacted by changes between version B and version C:

- Chapter 1: Introduction
- Chapter 3: Power, Reset, and Clock Management
- Chapter 5: IVA2.2 Subsystem
- Chapter 7: Display Subsystem
- Chapter 9: Interconnect
- Chapter 10: Memory Subsystem
- Chapter 13: System Control Module
- Chapter 25: General-Purpose Interface

For more details about the changes between version B and version C, see the AM/DM37x Technical Reference Manual Delta between version B and version C (lit number - SPRUGW9B) available on ti.com.

<sup>(5)</sup> Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* - version D (SPRUGN4D). Chapters impacted by changes between version C and version D:

- Chapter 3: Power, Reset, and Clock Management
- Chapter 13: System Control Module
- Chapter 19: UART/IrDA/CIR

For more details about the changes between version C and version D, see the AM/DM37x Technical Reference Manual Delta between version C and version D (lit number - SPRUGW9C) available on ti.com.

<sup>(6)</sup> Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* - version E (SPRUGN4E). Chapters impacted by changes between version D and version E:

- Chapter 3: Power, Reset, and Clock Management
- Chapter 6: Camera Image Signal Processor
- Chapter 7: Display Subsystem
- Chapter 13: System Control Module
- Chapter 26: Initialization

For more details about the changes between version D and version E, see the AM/DM37x Technical Reference Manual Delta between version D and version E (lit number - SPRUGW9D) available on ti.com.

| Version | Literature Number | Date          | Notes               |
|---------|-------------------|---------------|---------------------|
| F       | SPRUGN4           | December 2010 | See <sup>(7)</sup>  |
| G       | SPRUGN4           | January 2011  | See <sup>(8)</sup>  |
| H       | SPRUGN4           | February 2011 | See <sup>(9)</sup>  |
| I       | SPRUGN4           | March 2011    | See <sup>(10)</sup> |
| J       | SPRUGN4           | April 2011    | See <sup>(11)</sup> |
| K       | SPRUGN4           | May 2011      | See <sup>(12)</sup> |

<sup>(7)</sup> Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* - version F (SPRUGN4F) Chapters impacted by changes between version E and version F:

- Chapter 3: Power, Reset, and Clock Management
- Chapter 4: MPU Subsystem
- Chapter 10: Memory Subsystem
- Chapter 13: System Control Module
- Chapter 17: Multimaster High-Speed I<sup>2</sup>C Controller
- Chapter 20: Multichannel SPI
- Chapter 21: Multichannel Buffered Serial Port
- Chapter 22: High-Speed USB Host Subsystem and High-Speed USB OTG Controller
- Chapter 24: MMC/SD/SDIO/Card Interface
- Chapter 26: Initialization

For more details about the changes between version E and version F, see the AM/DM37x Technical Reference Manual Delta between version E and version F (lit number - SPRUGW9E) available on ti.com.

<sup>(8)</sup> Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* - version G (SPRUGN4G) Chapters impacted by changes between version F and version G:

- Chapter 3: Power, Reset, and Clock Management
- Chapter 11: SDMA
- Chapter 17: Multimaster High-Speed I<sup>2</sup>C Controller
- Chapter 24: MMC/SD/SDIO Card Interface
- Chapter 25: General-Purpose Interface
- Chapter 26: Initialization

For more details about the changes between version F and version G, see the AM/DM37x Technical Reference Manual Delta between version F and version G (lit number - SPRUGW9F) available on ti.com.

<sup>(9)</sup> Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* version H (SPRUGN4H). Chapters impacted by changes between version G and version H:

- Chapter 3: Power, Reset, and Clock Management
- Chapter 6: Camera Image Signal Processor
- Chapter 7: Display Subsystem
- Chapter 10: Memory Subsystem
- Chapter 13: System Control Module
- Chapter 26: Initialization

For more details about the changes between version G and version H, see the AM/DM37x Technical Reference Manual Delta between version G and version H (lit number - SPRUGW9G) available on ti.com.

<sup>(10)</sup> Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* version I (SPRUGN4I). Chapters impacted by changes between version H and version I:

- Chapter 6: Camera Image Signal Processor
- Chapter 7: Display Subsystem
- Chapter 16: Timers
- Chapter 18: HDQ/1-Wire
- Chapter 21: Multichannel Buffered Serial Port

For more details about the changes between version H and version I, see the AM/DM37x Technical Reference Manual Delta between version H and version I (lit number - SPRUGW9H) available on ti.com.

<sup>(11)</sup> Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* version J (SPRUGN4J). Chapters impacted by changes between version I and version J:

- Chapter 3: Power, Reset, and Clock Management
- Chapter 7: Display Subsystem
- Chapter 13: System Control Module

For more details about the changes between version I and version J, see the AM/DM37x Technical Reference Manual Delta between version I and version J (lit number - SPRUGW9J) available on ti.com.

<sup>(12)</sup> Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* version K (SPRUGN4K). Chapters impacted by changes between version J and version K:

- Chapter 17: Multimaster High-Speed I<sup>2</sup>C Controller

For more details about the changes between version J and version K, see the AM/DM37x Technical Reference Manual Delta between version J and version K (lit number - SPRUGWK) available on ti.com.

## History

www.ti.com

| Version | Literature Number | Date           | Notes                    |
|---------|-------------------|----------------|--------------------------|
| L       | SPRUGN4           | June 2011      | See <a href="#">(13)</a> |
| M       | SPRUGN4           | July 2011      | See <a href="#">(14)</a> |
| N       | SPRUGN4           | September 2011 | See <a href="#">(15)</a> |
| O       | SPRUGN4           | January 2012   | See <a href="#">(16)</a> |

- (13) Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* version K (SPRUGN4L). Chapters impacted by changes between version K and version L:  
  - Chapter 3: Power, Reset, and Clock Management
  - Chapter 13: System Control Module
  - Chapter 17: Multimaster High-Speed I<sup>2</sup>C Controller
  - Chapter 24: MMC/SD/SDIO Card Interface

For more details about the changes between version J and version K, see the AM/DM37x Technical Reference Manual Delta between version K and version L (lit number - SPRUGWL) available on ti.com.

- (14) Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* version M (SPRUGN4M). Chapters impacted by changes between version L and version M:  
  - Chapter 3: Power, Reset, and Clock Management
  - Chapter 6: Camera Image Signal Processor
  - Chapter 7: Display Subsystem
  - Chapter 8: 2D/3D Graphics Accelerator
  - Chapter 10: Memory Subsystem
  - Chapter 11: sDMA
  - Chapter 13: System Control Module
  - Chapter 17: Multimaster High-Speed I<sup>2</sup>C Controller
  - Chapter 18: HDQ/1-Wire
  - Chapter 19: UART/IrDA/CIR
  - Chapter 20: Multichannel SPI
  - Chapter 21: Multichannel Buffered Serial Port
  - Chapter 22: High-Speed USB Host Subsystem and High-Speed USB OTG Controller
  - Chapter 25: General-Purpose Interface
  - Chapter 26: Initialization

For more details about the changes between version L and version M, see the AM/DM37x Technical Reference Manual Delta between version L and version M (lit number - SPRUGWL) available on ti.com.

- (15) Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* version N (SPRUGN4N). Chapters impacted by changes between version M and version N:  
  - Chapter 1: Introduction
  - Chapter 3: Power, Reset, and Clock Management
  - Chapter 10: Memory Subsystem
  - Chapter 13: System Control Module
  - Chapter 17: Multimaster High-Speed I<sup>2</sup>C Controller

For more details about the changes between version M and version N, see the AM/DM37x Technical Reference Manual Delta between version M and version N (lit number - SPRUGW9N) available on ti.com.

- (16) Public Version of *AM/DM37x Multimedia Device Silicon Revision 1.x Technical Reference Manual* version O (SPRUGN4O). Chapters impacted by changes between version N and version O:  
  - Chapter 7: Display Subsystem
  - Chapter 26: Initialization

For more details about the changes between version N and version O, see the AM/DM37x Technical Reference Manual Delta between version N and version O (lit number - SPRUGW9O) available on ti.com.

## ***Introduction***

This chapter introduces the features, supporting subsystems, and architecture of the AM/DM37x high-performance microprocessors.

| <b>Topic</b>                                | <b>Page</b> |
|---------------------------------------------|-------------|
| <b>1.1 Overview .....</b>                   | <b>184</b>  |
| <b>1.2 Environment .....</b>                | <b>186</b>  |
| <b>1.3 Description .....</b>                | <b>187</b>  |
| <b>1.4 Package-On-Package Concept .....</b> | <b>192</b>  |
| <b>1.5 AM/DM37x Family .....</b>            | <b>195</b>  |

## 1.1 Overview

The AM/DM37x family of high-performance microprocessors are based on the enhanced device architecture and are integrated on TI's advanced 45-nm process technology.

---

**NOTE:** This architecture is configured with different sets of features in different devices. This technical reference manual details all of the features available in current and future AM/DM37x devices. Some features may not be available or supported in your particular device. For more information, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual.

---

The architecture is designed to provide best-in-class video, image, and graphics processing sufficient to support the following:

- Streaming video
- 2D/3D gaming
- Video conferencing
- High-resolution still image

The architecture of AM/DM37x is designed to provide maximum flexibility in a wide range of end applications including but not limited to:

- Portable Data Terminals
- Navigation
- Auto Infotainment
- Gaming
- Medical imaging
- Home Automation
- Human Interface
- Industrial Control
- Test and Measurement
- Single board Computers

The device can support numerous HLOS and RTOS solutions including Linux and Windows Embedded CE which are available directly from TI.

This device includes state-of-the-art power-management techniques required for high-performance mobile products.

The following subsystems are part of the device:

- Microprocessor unit (MPU) subsystem based on the ARM® Cortex™-A8 microprocessor
- IVA2.2 subsystem with a C64x+ digital signal processor (DSP) core
- SGX subsystem for 2D and 3D graphics acceleration to support display and gaming effects

---

**NOTE:** IVA2.2 and SGX are not available on all devices. See [Section 1.5, AM/DM37x Family](#), for more information on available features.

---

- Camera image signal processor (ISP) that supports multiple formats and interfacing options connected to a wide variety of image sensors
- Display subsystem with a wide variety of features for multiple concurrent image manipulation, and a programmable interface supporting a wide variety of displays. The display subsystem also supports NTSC/PAL video out.
- Level 3 (L3) and level 4 (L4) interconnects that provide high-bandwidth data transfers for multiple initiators to the internal and external memory controllers and to on-chip peripherals

The device also offers:

- A comprehensive power and clock-management scheme that enables high-performance, low-power operation, and ultralow-power standby features. The device also supports SmartReflex™ adaptative voltage control. This power management technique for automatic control of the operating voltage of a module reduces the active power consumption.
- A memory stacking feature using the package-on-package (POP) implementation (see [Section 1.4, Package-on-Package Concept](#))

## 1.2 Environment

This section provides an overview of the device environment. The device is associated with a power integrated circuit (IC). Texas Instruments provides a global solution with the TPS65950 device. For more information on the TPS65950 device, contact your TI representative.

Figure 1-1 provides an overview of a nonexhaustive environment for the high-tier AM/DM37x device.

**Figure 1-1. AM/DM37x Environment Using TPS65950**



**NOTE:** Some features are not available on all devices. See [Section 1.5, AM/DM37x Family](#), for more information on available features.

### 1.3 Description

The device is offered in three packages:

- CBP package: 515-ball, 12 x 12 mm, package-on-package (POP) 0.5-mm (top) and 0.4-mm (bottom) ball pitch package. Some balls are available at the top of the device to allow memory stacking. For more information, see [Section 1.4, Package-on-Package Concept](#).
- CUS package: 423-ball, 16 x 16mm, 0.65-mm (bottom) ball pitch package
- CBC package: 515-ball, 14 x 14mm, 0.5-mm (bottom), and 0.65-mm (top) ball pitch package.

[Figure 1-2](#) shows the block diagram.

**Figure 1-2. Block Diagram**




---

**NOTE:** Some features are not available on all devices. See [Section 1.5, AM/DM37x Family](#), for more information on available features.

---

### 1.3.1 MPU Subsystem

The MPU subsystem integrates the following modules

- ARM subchip
  - ARM® Cortex™-A8 core
  - ARM Version 7™ ISA: Standard ARM instruction set + Thumb®-2, Jazelle® RCT Java accelerator, and media extensions
  - NEON™ SIMD coprocessor (VFP lite + media streaming instructions)
  - Cache memories
    - Level 1: 32KB instruction and 32KB data—4-way set associative cache, 64 bytes/line
    - Level 2: see [Section 1.5, AM/DM37x Family](#).
- Interrupt controller (MPU IN TC) of 96 synchronous interrupt lines
- Asynchronous interface with core logic
- Debug, trace, and emulation features: ICE-Crusher, ETM, ETB modules.
- Secure state machine (trust zone support)

### 1.3.2 IVA2.2 Subsystem

The device includes a high-performance imaging video and audio (IVA2.2) accelerator based on the Texas Instruments TMS320DMC64x+ VLIW DSP core.

The IVA2.2 subsystem includes the following main features:

- 32-bit fixed-point media processor
- Very long instruction word (VLIW) architecture based on the programmable enhanced version of C64x DSP core
- Eight instructions/cycle, eight execution units
  - Optimized instruction set for video and imaging processing
  - Eight 8 x 8 or 16 x 16 multiply accumulate (MAC) per cycle
  - Eight slave asynchronous die (SAD) per cycle
  - Eight interpolations ( $a + b + 1 \gg 1$ ) per cycle
  - Two (32-bit x 32-bit > 64-bit) multiply operations per cycle
- Low-power processor and megacell
  - Dynamically mixed 32-bit and 16-bit instruction sets
  - Software pipelined loop (SPLOOP) instruction buffer
  - Separate power domain
  - Supported multiple power-down states
- Two-level memory subsystem hierarchy
  - L1P (program)
    - 32KB direct-mapped cache—32-byte cache line, configurable as cache or memory mapped (Possible values are: 0KB cache/32KB memory, 4KB/28KB, 8KB/24KB, 16KB/16KB, or 32KB/0KB)
  - L1D (data)
    - 32KB 2-way set associative cache—4-byte cache line, configurable as cache or memory mapped (Possible values are: 0KB cache/32KB memory, 4KB/28KB, 8KB/24KB, 16KB/16KB, or 32KB/0KB)
    - 48KB memory-mapped SRAM
  - L2 (program and data)
    - 64KB 4-way set associative cache—128-byte cache line, configurable as cache or memory mapped (Possible values are: 0KB cache/64KB memory, 32KB/32KB, or 64KB/0KB)
    - 32KB memory-mapped SRAM

- 16KB ROM
- Video hardware accelerators
  - Improved motion estimation (iME) dedicated hardware
  - Improved loop filtering (iLF) dedicated hardware
  - Improved variable length coder/decoder (iVLCD) with quantizing capabilities dedicated hardware
  - Video dedicated sequencer
  - Video local interconnect
  - Local level 2 (L2) memory interface/arbiter
- Private direct memory access (DMA) controller:
  - 128 logical channels
  - 1D/2D addressing
  - Chaining capability
  - Fully pipelined, two 64-bit read ports, two 64-bit write ports
  - Single access 32-byte or 64-byte incrementing bursts
- Level 1 (L1) interrupt controller (INTC)
- Local IVA2.2 digital phase-locked loop (DPLL) supplying the IVA2.2 subsystem clocking
- 32-entry memory management unit (MMU) for seamless integration in high-level OS environment
- IVA2.2 system interfaces
  - 64-bit L3 port shared for external memory accesses
    - Multithreaded link shared by DSP core and DMA accesses
    - Interface with the L3 interconnect that can be synchronous or asynchronous for clock decoupling between IVA2.2 and L3 interconnect
    - Incrementing burst support
    - Critical line first to reduce line fetch latency to the processor
  - Host port interface (HPI) for MMU programming and access to the IVA2.2 internal memories. Can be synchronous or asynchronous
  - System interfaces: clocking, power management
- C-friendly environment (state-of-the-art C compiler for VLIW architecture)
- Texas Instruments low-overhead DSP-BIOS operating system

---

**NOTE:** IVA2.2 is not available on all devices. See [Section 1.5, AM/DM37x Family](#), for more information on available features.

---

### 1.3.3 On-Chip Memory

On-chip memory configuration offers memory resources for program and data storage:

- 120 KBytes ROM (88KB secure/32KB public)
- 64 KBytes single-access SRAM (62KB secure/2KB public)

### 1.3.4 External Memory Interfaces

The device includes two external memory interfaces supporting the stacking of a multichip memory package using the generic POP interface:

- General-purpose memory controller (GPMC)
  - NOR flash, NAND flash (with ECC Hamming code calculation), SRAM and Pseudo-SRAM asynchronous and synchronous protocols
  - Flexible asynchronous protocol control for external ASIC or peripheral interfacing
  - 16-bit data, up to 8 chip-selects (CSs)

**Description**

www.ti.com

- 128M-byte addressable per chip-select, 1G-byte total address space
- Nonmultiplexed device with limited address (2K bytes)
- SDRAM controller (SDRC)
  - Mobile single data rate (M-SDR) SDRAM and low-power double data rate (LPDDR) SDRAM
  - 16-bit or 32-bit data, two chip-selects, configurations for a maximum of 4 G-bits supported on each chip-select
  - Work in conjunction with the SDRAM memory scheduler (SMS) companion module

**1.3.5 DMA Controllers**

The device embeds one generic DMA controller, the system DMA (sDMA) controller, used for memory-to-memory, memory-to-peripheral, and peripheral-to-memory transfers:

- One read port, one write port
- 32 prioritizable logical channels
- 96 hardware requests
- 256 x 32-bit FIFO dynamically allocable between active channels

The device also embeds three dedicated DMA controllers: enhanced DMA (EDMA), which is embedded in the IVA2.2 subsystem, display DMA, and USB HS DMA.

**1.3.6 Multimedia Accelerators**

The device uses the following multimedia accelerators for display and gaming effects as well as high-end imaging and video applications:

- 2D and 3D graphics accelerator (SGX)
  - 2D and 3D graphics and video codecs supported on common hardware
  - Tile-based architecture
  - Universal scalable shader engine (USSE™) multithreaded engine incorporating pixel and vertex shader functionality reducing die area
  - Advanced shader feature set in excess of Microsoft VS3.0, PS3.0, and OGL2.0
  - Industry standard API support Direct3D mobile, OGL-ES 1.1 and 2.0, OpenVG 1.0, OpenMax
  - Fine-grained task switching, load balancing, and power management
  - Programmable high-quality image anti-aliasing
  - Advanced geometry DMA driven operation for minimum CPU interaction
  - Fully virtualized memory addressing for OS operation in a unified memory architecture
  - Advanced and standard 2D operations (that is, vector graphics, BLTs, ROPs, etc.)
  - Programmable video encode and decode support for H.264, H.263, MPEG4 (SP), WMV9, and JPEG

---

**NOTE:** Multimedia accelerators are not available on all devices. See [Section 1.5, AM/DM37x Family](#), for more information on available features.

---

- Camera interface
  - Supports most of the raw image sensors available in the market
  - Includes video processing hardware
  - 12-bit parallel interface supported
  - Pixel clock up to 75 MHz

**CAUTION**

Clock configurations depend on the core voltage and maximum clock frequencies. Values in this document might not apply to production devices. Refer to your device-specific data manual for supported values for production devices.

- Display interface
  - Display controller
  - Color and monochrome displays up to 2048 x 2048 x 24-bpp resolution
  - 256 x 24-bit entries palette in red, green, blue (RGB)
  - 3,375 colors, 15 grayscales
  - Picture-in-picture (overlay), color-space conversion, rotation, color-phase rotation, and resizing support
  - Remote frame buffer interface
  - Liquid-crystal display (LCD) pixel interfaces (MIPI DPI 1.0) and LCD bus interfaces (MIPI DBI 1.0) supported
  - NTSC/PAL video encoder outputs with integrated digital-to-analog converters (DACs) output are supported on CVBS and S-video TV analog output signals
  - Embedded DMA controller

### 1.3.7 Comprehensive Power Management

AM/DM37x devices include the following power management features:

- Clock and reset generation and distribution
- Wake-up event management
- SmartReflex™ technology
- Dynamic voltage frequency shifting
- Dynamic power shifting
- Static leakage management

### 1.3.8 Peripherals

The device supports a comprehensive set of peripherals to provide flexible and high-speed interfacing and on-chip programming resources. [Table 1-1](#) provides a list and description of the peripherals available on AM/DM37x devices.

**Table 1-1. AM/DM37x Peripherals**

| Type                                          | Name                                                                        | Number           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------------------------|-----------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Serial Communication                          | Multi-channel Buffered Serial Ports (McBSPs)                                | 5                | The McBSPs provide a full-duplex direct serial interface between the device and other devices in a system such as audio and voice codecs and other application chips. McBSP1, McBSP2, and McBSP3 serve as general purpose serial ports while McBSP2 and McBSP3 include additional audio-loopback capability.                                                                                                                                                                                                                                                                                                             |
|                                               | Multi-channel Serial Port Interface (McSPI)                                 | 4                | The McSPIs provide a master/slave interface to SPI devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                               | High-speed Multi-port USB Host Controller                                   | 1                | High-speed USB2.0 host controller with three host ports each offering high-speed data transactions (up to 480 Mbps) or full-speed/low-speed data transactions (12 and 1.5 Mbps, respectively). In high-speed mode, the USB host controller ports interface to external USB PHYs using a 12-pin or 8-pin UTMI low pin interface (ULPI). In full-speed and low-speed mode, the ports interface to external USB PHYs using a 6-/4-/3-pin serial interface. Additionally each port can be directly connected to a USB device (bypassing the need for USB PHY) by using an on-chip transceiver-less link logic (TLL) adapter. |
|                                               | High-speed USB OTG Controller                                               | 1                | High-speed USB2.0 OTG controller that offers high-speed data transactions (up to 480 Mbps) on a USB port with embedded DMA controller. The high-speed USB OTG controller interfaces to an external USB PHY using a 12-pin UTMI low pin interface (ULPI).                                                                                                                                                                                                                                                                                                                                                                 |
|                                               | HDQ/1-Wire®                                                                 | 1                | The HDQ/1-Wire interface supports the Benchmark HDQ protocol and the Dallas Semiconductor 1-Wire protocol.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                               | Universal Asynchronous Receiver/Transmitter (UART)                          | 3                | Serial communication interfaces compatible to the industry standard TL16C550 asynchronous communications element. UART1 and UART 2 are general serial communication interfaces. UART3 provides additional support for infrared data association (IrDA) and consumer infrared (CIR) communications.                                                                                                                                                                                                                                                                                                                       |
| Removable Media                               | High-speed (HS) Inter-integrated Circuit (I2C) Controllers                  | 3 <sup>(1)</sup> | Master/slave I2C high-speed standard interfaces with support for standard mode (up to 100K bits/s), fast mode (up to 400K bits/s), and high-speed mode (up to 3.4M bits/s).                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                               | Multimedia Card/Secure Digital/Secure Digital I/O (MMC/SDIO) Card Interface | 1                | MMC memory card, SD memory card, or SDIO cards interface.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Miscellaneous                                 | GP timers                                                                   | 12               | Twelve general-purpose timers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                               | Watchdog timers (WDTs)                                                      | 2                | Three watchdog timers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                               | 32-kHz synchronization timer                                                | 1                | 32-kHz clock timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                               | General-purpose input/output (GPIO)                                         | Package-specific | General-purpose input/output pins controlled by six GPIO controllers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                               | Mailbox                                                                     | 6                | MPU/IVA2.2 inter-processor communications mailboxes. All six mailboxes are available in chassis mode, however, only two mailboxes are available in stand-alone mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                               | Control module                                                              | 1                | I/O multiplexing and chip-configuration control.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Security Modules (High-security Devices Only) |                                                                             |                  | RNG, Fast PKA, 2xDES/3DES, SHA1/MD5, SHA2/MD5, 2xAES, Secure Watchdog Timer, and universal subscriber identity module (USIM).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

<sup>(1)</sup> A fourth master/transmitter high-speed I2C interface (I2C4) is included in the power, reset, and clock management (PRCM) module to perform dynamic voltage control and power sequencing.

## 1.4 Package-On-Package Concept

The AM/DM37x CBP/CBC package provides a package-on-package (POP) memory interface to support multiple stacked package configurations, including a flash multi-chip package, depending on customer needs.

The stacked memory package is directly connected to the two memory interfaces (GPMC and SDRC) of the AM/DM37x CBP/CBC package through the POP interface present at the top. For more information on the interconnect between the stacked memory package and the AM/DM37x CBP/CBC package, see [Chapter 10, Memory Subsystem](#), and your device-specific AM/DM37x data manual.

**NOTE:** Before using the POP memory interface, a compatible memory device supply must first be secured directly from specific memory vendors.

[Figure 1-3](#) shows the concept of the POP solution, and [Figure 1-4](#) shows stacked memory package on the POP device.

**Figure 1-3. POP Concept (CBP Package)**



**Figure 1-4. Stacked Memory Package on the POP Device (CBP Package)**



The memory interfaces should be correctly configured based on the memory package used with the POP device.

[Table 1-2](#) summarizes the supported configurations with the generic POP interface.

**Table 1-2. Summary of Memories Supported by the POP Interface**

| Generic POP Interface Features Set | SDRC Interface | GPMC Interface                                                                                                                                                         |
|------------------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Type of memory supported           | MDDR           | NOR flash asynchronous and synchronous burst flash<br>NAND flash "CE don't care"<br>One NAND on CS0 and CS1<br>NOR flash address/data nonmultiplexed is not supported. |
| Number of chip-selects             | 2              | 2                                                                                                                                                                      |
| Maximum density per chip-select    | 4G bits        | 2G bits                                                                                                                                                                |
| Maximum size per interface         | 8G bits        | 4G bits                                                                                                                                                                |
| Interface width                    | X 32 bits      | X 16 bits                                                                                                                                                              |
| I/O voltage                        | 1.8 V LVCMOS   | 1.8 V LVCMOS                                                                                                                                                           |

For more information on the memory interface configuration, see the *Memory Subsystem* chapter.

The POP device includes feedthroughs in addition to the GPMC and SDRC interfaces positioned at the top of the package. Several feedthroughs are defined from the bottom ball-grid array (BGA) to the top (or POP) interface to support different memory combinations.

The feedthroughs either provide power to a top memory device or provide specific memory signals (for example, control and/or address signals) from the bottom BGA to the POP interface.

**NOTE:** It is possible to monitor the DDR SDRAM temperature if the memory multichip package allows the temperature sensing option. A feedthrough is used to lower the temperature sensing dedicated signal to make a connection with a GPIO. For more information on DDR SDRAM temperature sensing management, see the *Memory Subsystem* and the *General-Purpose Interface* chapters.

Figure 1-5 shows the implementation of feedthroughs on the POP and the different paths between the bottom and the top of the package.

**Figure 1-5. Stacked Memory Package on the POP Device (CBP Package)**

- (1) Path 1: feedthrough only; Path 2: all but feedthrough; Path 3: POP interface (SDRC + subset GPMC)

## 1.5 AM/DM37x Family

### 1.5.1 Device Features

This architecture is configured with different sets of features in different devices. This technical reference manual details all of the features available in current and future AM/DM37x devices. Some features may not be available or supported in your particular device. The features supported across different AM/DM37x devices are shown on [Table 1-3](#) (CBP, CBC, and CUS packages). For more information on the CBP, CBC, and CUS packages, refer to your device-specific data manual.

**Table 1-3. Subsystem, Co-Processor, and Peripheral Support on AM/DM37x Devices (CBP, CBC and CUS Packages)**

| Subsystem/Co-Processor/Peripheral                | Chapter | DM3730                                       | DM3725                                       | AM3715                                       | AM3703                                       |
|--------------------------------------------------|---------|----------------------------------------------|----------------------------------------------|----------------------------------------------|----------------------------------------------|
| IVA2.2 Subsystem                                 | 5       | ✓                                            | ✓                                            |                                              |                                              |
| 2D/3D Graphics Accelerator                       | 8       | ✓                                            |                                              | ✓                                            |                                              |
| Cortex-A8 Neon Co-Processor                      | 4       | ✓                                            | ✓                                            | ✓                                            | ✓                                            |
| SDRAM Controller <sup>(1)</sup>                  | 10      | ✓                                            | ✓                                            | ✓                                            | ✓                                            |
| General-Purpose Memory Controller <sup>(1)</sup> | 10      | ✓                                            | ✓                                            | ✓                                            | ✓                                            |
| Package-on-Package                               | 1       | ✓                                            | ✓                                            | ✓                                            | ✓                                            |
| Camera ISP                                       | 6       | ✓                                            | ✓                                            | ✓                                            | ✓                                            |
| Interface                                        |         |                                              |                                              |                                              |                                              |
| Input width @ Max Clk                            |         | 12 bit input @ 75MHz<br>8 bit input @ 150MHz | 12 bit input @ 75MHz<br>8 bit input @ 150MHz | 12 bit input @ 75MHz<br>8 bit input @ 150MHz | 12 bit input @ 75MHz<br>8 bit input @ 150MHz |
| Parallel Input mode                              |         | ✓                                            | ✓                                            | ✓                                            | ✓                                            |
| Sync input Mode                                  |         | ✓                                            | ✓                                            | ✓                                            | ✓                                            |
| ITU input Mode                                   |         | ✓                                            | ✓                                            | ✓                                            | ✓                                            |
| CSI1 input mode                                  |         |                                              |                                              |                                              |                                              |
| CSI2 input mode                                  |         |                                              |                                              |                                              |                                              |
| Multiple Cameras                                 |         |                                              |                                              |                                              |                                              |
| CCDC Raw image processing                        |         |                                              |                                              |                                              |                                              |
| Optical Clamp                                    |         |                                              |                                              |                                              |                                              |
| Optical Black Clamp                              |         |                                              |                                              |                                              |                                              |
| LUT faulty pixel correction                      |         |                                              |                                              |                                              |                                              |
| 2D lens shading comp                             |         |                                              |                                              |                                              |                                              |
| Data Formatter                                   |         |                                              |                                              |                                              |                                              |
| Output Formatter                                 |         |                                              |                                              |                                              |                                              |
| Preview Module                                   |         |                                              |                                              |                                              |                                              |
| A-law decompression                              |         |                                              |                                              |                                              |                                              |
| Noise reduction                                  |         |                                              |                                              |                                              |                                              |
| Digital gain                                     |         |                                              |                                              |                                              |                                              |
| White Balance                                    |         |                                              |                                              |                                              |                                              |
| prog. CFA                                        |         |                                              |                                              |                                              |                                              |
| Black adjustment                                 |         |                                              |                                              |                                              |                                              |
| Prog. color correction                           |         |                                              |                                              |                                              |                                              |
| Prog. Color Space Conv.                          |         |                                              |                                              |                                              |                                              |
| Prog. Gamma Correction                           |         |                                              |                                              |                                              |                                              |
| Color subsampling                                |         |                                              |                                              |                                              |                                              |

<sup>(1)</sup> CBP and CBC package only PoP interface is available.

**Table 1-3. Subsystem, Co-Processor, and Peripheral Support on AM/DM37x Devices (CBP, CBC and CUS Packages) (continued)**

| Subsystem/Co-Processor/Peripheral             | Chapter | DM3730 | DM3725 | AM3715 | AM3703 |
|-----------------------------------------------|---------|--------|--------|--------|--------|
| Luma enhancement                              |         |        |        |        |        |
| Resizer                                       |         | ✓      | ✓      | ✓      | ✓      |
| Statistic Collection                          |         |        |        |        |        |
| H3A metrics                                   |         |        |        |        |        |
| Histogram                                     |         |        |        |        |        |
| Buffer Management                             |         |        |        |        |        |
| Central resource SBL                          |         | ✓      | ✓      | ✓      | ✓      |
| Circular Buffer                               |         | ✓      | ✓      | ✓      | ✓      |
| Display Subsystem                             | 7       | ✓      | ✓      | ✓      | ✓      |
| LCD and TV Output Interface                   |         | ✓      | ✓      | ✓      | ✓      |
| Display Serial Interface (DSI)                |         |        |        |        |        |
| McBSP1/2/3/4/5 <sup>(2)</sup>                 | 21      | ✓      | ✓      | ✓      | ✓      |
| McSPI1/2/3/4                                  | 20      | ✓      | ✓      | ✓      | ✓      |
| High-Speed USB OTG Controller                 | 22      | ✓      | ✓      | ✓      | ✓      |
| High-Speed USB Host Controller <sup>(3)</sup> | 22      | ✓      | ✓      | ✓      | ✓      |
| HDQ/1-Wire                                    | 18      | ✓      | ✓      | ✓      | ✓      |
| UART1/2/4                                     | 19      | ✓      | ✓      | ✓      | ✓      |
| UART3/IrDA/CIR <sup>(4)</sup>                 | 19      | ✓      | ✓      | ✓      | ✓      |
| I2C1/2/3 <sup>(5)</sup>                       | 17      | ✓      | ✓      | ✓      | ✓      |
| MMC/SD/SDIO1/2/3                              | 24      | ✓      | ✓      | ✓      | ✓      |
| GP Timer (x12)                                | 16      | ✓      | ✓      | ✓      | ✓      |
| Watchdog Timer (x2)                           | 16      | ✓      | ✓      | ✓      | ✓      |
| 32-kHz Sync Timer                             | 16      | ✓      | ✓      | ✓      | ✓      |
| GPIO <sup>(4)</sup>                           | 25      | ✓      | ✓      | ✓      | ✓      |
| Secure ROM                                    | 1       | ✓      | ✓      | ✓      | ✓      |
| RNG                                           | 1       |        |        |        |        |
| DES/3DES                                      | 1       |        |        |        |        |
| SHA1/MD5                                      | 1       |        |        |        |        |
| SHA2/MD5                                      | 1       |        |        |        |        |
| AES                                           | 1       |        |        |        |        |
| Fast PKA                                      | 1       |        |        |        |        |
| Secure Watchdog Timer                         | 1       | ✓      | ✓      | ✓      | ✓      |
| Universal Subscriber Identify Module          | 1       |        | ✓      | ✓      | ✓      |
| High-security Device                          | 1       |        |        |        |        |
| General-purpose Device                        | 1       | ✓      | ✓      | ✓      | ✓      |

<sup>(2)</sup> Chip select pins mcspi1\_cs1 and mcspi1\_cs2 are not available on the CUS package.

<sup>(3)</sup> High-speed USB host controller port 3 is not available on the CUS package.

<sup>(4)</sup> A maximum of 170 GPIO pins are supported. The following GPIO pins are not available: gpio\_52, gpio\_53, gpio\_63 gpio\_64, gpio\_144, gpio\_145, gpio\_146, gpio\_147, gpio\_152, gpio\_153, gpio\_154, gpio\_155, gpio\_175, and gpio\_176. Pin muxing restricts the total number of GPIO pins available at one time. See your device-specific data manual for more information on pin multiplexing.

<sup>(5)</sup> The fourth HS I<sup>2</sup>C4 controller (I2C4) is in the power, reset, and clock management (PRCM) module to perform dynamic voltage control and power sequencing.

**Table 1-4. CONTROL\_PRODUCTION\_ID**

|                         |                                                                    |                 |         |
|-------------------------|--------------------------------------------------------------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0000                                                        | <b>Instance</b> | GENERAL |
| <b>Physical Address</b> | 0x4830 A208                                                        |                 |         |
| <b>Description</b>      | This register shows the device type and some options availability. |                 |         |
| <b>Type</b>             | R                                                                  |                 |         |



| Bits   | Field Name  | Description                                 | Type | Reset Value |
|--------|-------------|---------------------------------------------|------|-------------|
| 127:72 | RESERVED    | RESERVED                                    | R    | 0           |
| 71:64  | DEVICE_TYPE | 0xF0 = GP device<br>Other values = Reserved | R    | 0           |
| 63:0   | RESERVED    | RESERVED                                    | R    | 0           |

### 1.5.2 Device Identification

The identification registers include the CONTROL\_IDCODE and CONTROL\_DIE\_ID data registers. These registers are accessible through the L4 interconnect port starting at physical address 0x4830 A204 and 0x4830 A218, respectively. See the Memory Mapping chapter for more information about the L4 memory space mapping. [Table 1-5](#) describes the identification registers.

The silicon type can be read in the HAWKEYE bit field value of the CONTROL.CONTROL\_IDCODE register. The silicon revision can be read in the VERSION bit field value of the CONTROL.CONTROL\_IDCODE register.

**Table 1-5. Device Identification Registers**

| Register Name                 | Address     | Size |
|-------------------------------|-------------|------|
| CONTROL.CONTROL_IDCODE[31:0]  | 0x4830 A204 | 32   |
| CONTROL.CONTROL_DIE_ID[127:0] | 0x4830 A218 | 128  |

To retrieve AM/DM37x chip identification, see [Table 1-6](#). This register helps software identify chip derivative.

**Table 1-6. Chip Identification**

| Scalable Resource                                         | Name                             | Bit   | Value                   | Description                                                    | DM3730 | DM3725 | AM3715 | AM3703 |
|-----------------------------------------------------------|----------------------------------|-------|-------------------------|----------------------------------------------------------------|--------|--------|--------|--------|
| SGX                                                       | 2D/3D graphics accelerator       | 14:13 | 00<br>01<br>10<br>11    | Full use.<br>Reserved<br>HW not present.<br>Reserved.          | 00     | 10     | 00     | 10     |
| IVA                                                       | IVA2.2 subsystem                 | 12    | 0<br>1                  | Full use.<br>Not available                                     | 0      | 0      | 1      | 1      |
| MPU L2 Cache Size                                         | MPU subsystem L2 cache size      | 11:10 | 00<br>01<br>10<br>11    | 0 KB.<br>Reserved<br>128 KB.<br>Full use (256 KB).             |        |        |        |        |
| Speed Binned                                              | MPU/IVA Frequency <sup>(1)</sup> | 9     | 0<br>1                  | 800/600 MHz<br>1000/800 MHz                                    | X      | X      | X      | X      |
| Reserved                                                  | Reserved                         | 8:4   |                         | Reserved<br>Reserved.<br>Reserved<br>Reserved.                 |        |        |        |        |
| FEAT_TIERING                                              | Feature tiering                  | 3:0   | 0<br>1<br>All<br>Others | All features are available<br>ISP is not available<br>Reserved | 0000   | 0000   | 0000   | 0000   |
| Control Device Status Register 15:0 (Address 0x4800 244C) |                                  |       |                         | ARM/IVA 800/600MHz                                             | 0x0C00 | 0x4C00 | 0x1C00 | 0x5C00 |
|                                                           |                                  |       |                         | ARM/IVA 1000/800 MHz                                           | 0x0E00 | 0x4E00 | 0x1E00 | 0x5E00 |

<sup>(1)</sup> This bit is valid only in production devices

**Table 1-7. CONTROL\_IDCODE Register Value**

| Silicon Type   | Bit Field                    | Value      |
|----------------|------------------------------|------------|
| AM/DM37x ES1.0 | CONTROL.CONTROL_IDCODE[31:0] | 0xB89 102F |
| AM/DM37x ES1.1 | CONTROL.CONTROL_IDCODE[31:0] | 0xB89 102F |
| AM/DM37x ES1.2 | CONTROL.CONTROL_IDCODE[31:0] | 0xB89 102F |

**Table 1-8. CONTROL\_PRODUCTION\_ID Register Silicon Type Identification**

| Silicon Type           | Field                                 | Value       |
|------------------------|---------------------------------------|-------------|
| AM/DM37x all revisions | CONTROL.CONTROL_PRODUCTION_ID[12:9:6] | 0xCAFE B891 |

**Table 1-9. CONTROL\_DIE\_ID**

| Field         | Bits | Value | Comments              |
|---------------|------|-------|-----------------------|
| DIE_ID[127:0] | -    | 0x-   | Single die identifier |

### 1.5.3 General Recommendations Relative to Unavailable Features/Modules

As explained in the previous section, some features are not available in all AM/DM37x devices. For unavailable features, use the following recommendations:

- Memory mapping: Memory area of unavailable modules and features are RESERVED, read is undefined, and write can lead to unpredictable behavior.
- Interrupt controllers: Ensure that interrupts of unavailable modules and features are masked in MPU/IVA subsystems.
- DMA: Ensure that DMA requests of unavailable modules and features are masked in DMA subsystems.
- System Control Module (SCM): Unavailable modules and feature pins are not functional and should not be used.
- Power, Reset, and Clock Management Module (PRCM): For power management and power-saving consideration, ensure that power domains of unavailable features/modules are switched off and clocks are cut off.
- Interconnect: To flag potential interconnect outstanding commands, the time-out of target agents attached to unavailable modules can be enabled with the lowest setting.



## **Memory Mapping**

This chapter describes memory mapping in the device.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                                  | Page       |
|--------------------------------------------------------|------------|
| 2.1 <b>Introduction</b> .....                          | <b>202</b> |
| 2.2 <b>Global Memory Space Mapping</b> .....           | <b>204</b> |
| 2.3 <b>L3 and L4 Memory Space Mapping</b> .....        | <b>207</b> |
| 2.4 <b>IVA2.2 Subsystem Memory Space Mapping</b> ..... | <b>216</b> |

## 2.1 Introduction

The microprocessor unit (MPU) has a 32-bit address port, allowing it to handle a 4-GB space divided into several regions, depending on the target type.

The memory map is composed of a memory space (general-purpose memory controller [GPMC], synchronous dynamic random-access memory [SDRAM] controller [SDRC], etc.), register space (level 3 [L3] and level 4 [L4] interconnects), and dedicated spaces (image and video accelerator [IVA2.2] subsystem, graphics accelerator (SGX), etc.), all of which are shared among the initiators (for example, the MPU subsystem or the IVA2.2 subsystem).

The GPMC and SDRC are dedicated to memory connection. The GPMC is used for NOR/NAND flash and SRAM memories. The SDRC is used for SDRAM memories, such as regular SDR-SDRAM (single data rate), regular JEDEC DDR1 memory (double data rate), low-power SDR-SDRAM, and mobile DDR-SDRAM. For more information, see [Chapter 10, Memory Subsystem](#).

The L3 interconnect allows the sharing of resources, such as peripherals and external or on-chip memories, among all the initiators of the platform. The L4 interconnects control access to the peripherals.

Transfers between initiators and targets across the platform are physically conditioned by the chip interconnect and can be logically conditioned by firewalls. For more information about the intercommunication (L3 and L4 interconnects) and protection mechanisms implemented in the device, see [Chapter 9, Interconnect](#).

[Figure 2-1](#) shows the interconnect of the device and the main modules and subsystems in the platform.

**Figure 2-1. Interconnect Overview**


memmap-177-001

## 2.2 Global Memory Space Mapping

This section provides a global view of the memory mapping and describes the boot, GPMC, SDRC, and virtual rotated frame buffer (VRFB) memory spaces.

The system memory mapping is flexible, with two levels of granularity for target address space allocation:

- Level 1 (L1): Four quarters are labeled Q0, Q1, Q2, and Q3. Each quarter corresponds to a 1-GB address space (total address space is 4GB).
- Level 2 (L2): Each quarter is divided into eight blocks of 128MB, with target spaces mapped in the blocks.

This organization allows all target spaces to be decoded based on the five most-significant bits (MSBs) of the 32-bit address ([31:27]).

- **Boot space**

The system has a 1-MB boot space in the on-chip boot ROM or on the GPMC memory space.

When booting from the on-chip ROM with the appropriate external sys\_boot5 pin configuration, the 1-MB memory space is redirected to the on-chip boot ROM memory address space [0x4000 0000 – 0x400F FFFF].

When booting from the GPMC with the appropriate external sys\_boot5 pin configuration, the memory space is part of the GPMC memory space.

For more information about sys\_boot5 pin configuration, see [Chapter 10, Memory Subsystem](#), and [Chapter 26, Initialization](#).

- **GPMC space**

Eight independent GPMC chip-selects (gpmc\_ncs0 to gpmc\_ncs7) are available in the first quarter (Q0) of the addressing space to access NOR/NAND flash and SRAM memories. The chip-selects have a programmable start address and programmable size (16, 32, 64, or 128MB) in a total memory space of 1GB.

- **SDRC space**

Two SDRC chip-selects (sdrc\_ncs0 and sdrc\_ncs1) are available on the third quarter (Q2) of the addressing space to access SDRAM memories. The chip-selects have a programmable size (64, 128, 256, or 512MB) in a total memory space of 1GB.

The base address of the chip-select 0 (sdrc\_ncs0) memory space is always 0x8000 0000. The base address of the chip-select 1 (sdrc\_ncs1) memory space is programmable. The default value after reset is 0xA000 0000.

- **VRFB space**

The SDRC-SMS virtual memory space is a different memory space used to access a subset of the SDRC memory space through the rotation engine (ROT). The virtual address space size is 768MB split into two parts: The first 256-MB part is in the second quarter (Q1) of the memory; the second 512-MB part is in the fourth quarter (Q3) of the memory.

For more information about boot, GPMC, SDRC, and VRFB, see [Chapter 10, Memory Subsystem](#).

This section describes all modules and features in the high-tier device. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

[Table 2-1](#) describes the global memory space mapping.

**Table 2-1. Global Memory Space Mapping**

| Quarter             | Device Name                              | Start Address (Hex) | End Address (Hex) | Size                              | Description                                         |
|---------------------|------------------------------------------|---------------------|-------------------|-----------------------------------|-----------------------------------------------------|
| <b>Q0<br/>(1GB)</b> | <b>Boot space<sup>(1)</sup><br/>GPMC</b> |                     |                   | <b>1MB<br/>1GB<br/>or 1GB-1MB</b> |                                                     |
|                     | GPMC                                     | 0x0000 0000         | 0x3FFF FFFF       | 1GB                               | 8/16 Ex <sup>(2)</sup> /R/W                         |
| <b>Q1<br/>(1GB)</b> | <b>On-chip memory</b>                    |                     |                   | <b>128MB</b>                      | <b>ROM/SRAM address space</b>                       |
|                     | Boot ROM internal <sup>(1)</sup>         | 0x4000 0000         | 0x4001 3FFF       | 80KB                              | Reserved for boot code<br>Not accessible after boot |
|                     |                                          | 0x4001 4000         | 0x4001 BFFF       | 32KB                              | 32-bit Ex <sup>(2)</sup> /R                         |
|                     | Reserved                                 | 0x4001 C000         | 0x400F FFFF       | 912KB                             | Reserved                                            |
|                     | Reserved                                 | 0x4010 0000         | 0x401F FFFF       | 1MB                               | Reserved                                            |
|                     | SRAM internal                            | 0x4020 0000         | 0x4020 FFFF       | 64KB                              | 32-bit Ex <sup>(2)</sup> /RW                        |
|                     | Reserved                                 | 0x4021 0000         | 0x4024 FFFF       | 256KB                             | Reserved                                            |
|                     | Reserved                                 | 0x4025 0000         | 0x47FF FFFF       | 128,704KB                         | Reserved                                            |
|                     | <b>L4 interconnects</b>                  |                     |                   | <b>128MB</b>                      | <b>All system peripherals</b>                       |
|                     | L4-Core                                  | 0x4800 0000         | 0x48FF FFFF       | 16MB                              | See <a href="#">Table 2-3</a> .                     |
|                     | (L4-Wakeup) <sup>(3)</sup>               | (0x4830 0000)       | (0x4833 FFFF)     | (256KB)                           | See <a href="#">Table 2-4</a> .                     |
|                     | L4-Per                                   | 0x4900 0000         | 0x490F FFFF       | 1MB                               | See <a href="#">Table 2-5</a> .                     |
|                     | Reserved                                 | 0x4910 0000         | 0x4FFF FFFF       | 111MB                             | Reserved                                            |
|                     | <b>SGX</b>                               |                     |                   | <b>64MB</b>                       | <b>Graphic accelerator slave port</b>               |
|                     | SGX                                      | 0x5000 0000         | 0x5000 FFFF       | 64KB                              | Graphic accelerator slave port                      |
|                     | Reserved                                 | 0x5001 0000         | 0x53FF FFFF       | 65,472KB                          | Reserved                                            |
|                     | <b>L4 emulation</b>                      |                     |                   | <b>64MB</b>                       | <b>Emulation</b>                                    |
|                     | L4-Emu                                   | 0x5400 0000         | 0x547F FFFF       | 8MB                               | See <a href="#">Table 2-6</a> .                     |
|                     | Reserved                                 | 0x5480 0000         | 0x57FF FFFF       | 56MB                              | Reserved                                            |
|                     | <b>Reserved</b>                          |                     |                   | <b>64MB</b>                       | <b>Reserved</b>                                     |
|                     | Reserved                                 | 0x5800 0000         | 0x5BFF 0FFF       | 64MB                              | Reserved                                            |
|                     | <b>IVA2.2 subsystem</b>                  |                     |                   | <b>64MB</b>                       | <b>IVA2.2 subsystem</b>                             |
|                     | IVA2.2 subsystem                         | 0x5C00 0000         | 0x5EFF FFFF       | 48MB                              | IVA2.2 subsystem. See <a href="#">Table 2-8</a> .   |
|                     | Reserved                                 | 0x5F00 0000         | 0x5FFF FFFF       | 16MB                              | Reserved                                            |
|                     | <b>Reserved</b>                          |                     |                   | <b>128MB</b>                      | <b>Reserved</b>                                     |
|                     | Reserved                                 | 0x6000 0000         | 0x67FF FFFF       | 128MB                             | Reserved                                            |
|                     | <b>L3 interconnect</b>                   |                     |                   | <b>128MB</b>                      | <b>Control registers</b>                            |
|                     | L3 control registers                     | 0x6800 0000         | 0x68FF FFFF       | 16MB                              | See <a href="#">Table 2-2</a> .                     |
|                     | Reserved                                 | 0x6900 0000         | 0x6BFF FFFF       | 48MB                              | Reserved                                            |
|                     | SMS registers                            | 0x6C00 0000         | 0x6CFF FFFF       | 16MB                              | Configuration registers SMS address space 2         |
|                     | SDRC registers                           | 0x6D00 0000         | 0x6DFF FFFF       | 16MB                              | Configuration registers SMS address space 3         |
|                     | GPMC registers                           | 0x6E00 0000         | 0x6EFF FFFF       | 16MB                              | Configuration registers GPMC address space 1        |
|                     | Reserved                                 | 0x6F00 0000         | 0x6FFF FFFF       | 16MB                              | Reserved                                            |
|                     | <b>SDRC/SMS</b>                          |                     |                   | <b>256MB</b>                      | <b>SDRC/SMS</b>                                     |

<sup>(1)</sup> Boot space location depends on the external sys\_boot5 pin configuration.

<sup>(2)</sup> Executable

<sup>(3)</sup> Peripherals connected to the L4-Wakeup interconnect are accessed through the L4-Core interconnect.

**Table 2-1. Global Memory Space Mapping (continued)**

| Quarter             | Device Name                      | Start Address (Hex) | End Address (Hex) | Size         | Description                           |
|---------------------|----------------------------------|---------------------|-------------------|--------------|---------------------------------------|
|                     | SDRC/SMS virtual Address space 0 | 0x7000 0000         | 0x7FFF FFFF       | 256MB        | SDRC-SMS virtual address space 0      |
| <b>Q2<br/>(1GB)</b> | <b>SDRC/SMS</b>                  |                     |                   | <b>1GB</b>   | <b>SDRAM main address space (SMS)</b> |
|                     | CS0 – SDRAM <sup>(4)</sup>       | 0x8000 0000         | 0x9FFF FFFF       | 512MB        | SDRC/SMS                              |
| <b>Q3<br/>(1GB)</b> | CS1 – SDRAM <sup>(4)</sup>       | 0xA000 0000         | 0xBFFF FFFF       | 512MB        | SDRC/SMS                              |
|                     | <b>Reserved</b>                  |                     |                   | <b>512MB</b> | <b>Reserved</b>                       |
|                     | Reserved                         | 0xC000 0000         | 0xDFFF FFFF       | 512MB        | Reserved for future use               |
|                     | <b>SDRC/SMS</b>                  |                     |                   | <b>512MB</b> | <b>SDRC/SMS</b>                       |
|                     | SDRC/SMS virtual Address space 1 | 0xE000 0000         | 0xFFFF FFFF       | 512MB        | SDRC-SMS virtual address space 1      |

<sup>(4)</sup> Chip-select 0 and chip-select 1 spaces are configurable in the 1-GB SDRC/SMS space.

## 2.3 L3 and L4 Memory Space Mapping

The memory space system is hierarchical: L1, L2, L3, and L4.

L1 and L2 are memories in the MPU and IVA2.2 subsystems.

The chip-level interconnect, which consists of one L3 and four L4s, enables communication among all modules and subsystems.

L3 handles many types of data transfers, including data exchange with system on-chip/external memories.

The four L4s handle transfers with peripherals, but are in four distinct power domains: the L4-Core, L4-Wakeup, L4-Per, and L4-Emu interconnects, which are in the CORE, WKUP, PER, and EMU power domains, respectively.

For more information about the interconnect, see [Chapter 9, Interconnect](#).

The following sections describe the register mapping of the L3 and L4 interconnects. Software configures these registers.

### 2.3.1 L3 Memory Space Mapping

The L3 interconnect control registers are mapped in a 16-MB space and allow the configuration of the L3 interconnect parameters.

The L3 default settings are fully functional and enable all possible functional data paths. However, the interconnect parameters can be changed to accommodate requirements.

Accesses to the L3 interconnect can be configured on a per-module basis using the internal L3 registers, which are grouped into five register block types:

- IA: Initiator agent configuration registers
- TA: Target agent configuration registers
- RT: Register target (global) configuration registers
- PM: Protection mechanism (firewalls) configuration registers
- SI: Global sideband signal configuration registers

For more information, see [Chapter 9, Interconnect](#).

This section describes all modules and features in the high-tier device. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

[Table 2-2](#) describes the mapping of the L3 interconnect control registers.

**Table 2-2. L3 Control Register Mapping**

| Device Name         | Start Address (Hex) | End Address (Hex) | Size (KB) | Description                                         |
|---------------------|---------------------|-------------------|-----------|-----------------------------------------------------|
| L3 RT               | 0x6800 0000         | 0x6800 03FF       | 1         | L3 configuration registers                          |
| L3 SI               | 0x6800 0400         | 0x6800 07FF       | 1         | Sideband signal configuration                       |
| Reserved            | 0x6800 0800         | 0x6800 13FF       | 3         | Reserved                                            |
| MPU subsystem IA    | 0x6800 1400         | 0x6800 17FF       | 1         | MPU subsystem instruction port agent configuration  |
| IVA2.2 subsystem IA | 0x6800 1800         | 0x6800 1BFF       | 1         | IVA2.2 subsystem initiator port agent configuration |
| SGX subsystem IA    | 0x6800 1C00         | 0x6800 1FFF       | 1         | SGX subsystem initiator port agent configuration    |
| SMS TA              | 0x6800 2000         | 0x6800 23FF       | 1         | SMS target port agent configuration                 |
| GPMC TA             | 0x6800 2400         | 0x6800 27FF       | 1         | GPMC target port agent configuration                |
| OCM RAM TA          | 0x6800 2800         | 0x6800 2BFF       | 1         | OCM RAM target port agent configuration             |
| OCM ROM TA          | 0x6800 2C00         | 0x6800 2FFF       | 1         | OCM ROM target port agent configuration             |

**Table 2-2. L3 Control Register Mapping (continued)**

| Device Name          | Start Address (Hex) | End Address (Hex) | Size (KB) | Description                                             |
|----------------------|---------------------|-------------------|-----------|---------------------------------------------------------|
| D2D IA               | 0x6800 3000         | 0x6800 33FF       | 1         | Die-to-die (D2D) initiator port agent configuration     |
| D2D TA               | 0x6800 3400         | 0x6800 37FF       | 1         | D2D target port agent configuration                     |
| Reserved             | 0x6800 3800         | 0x6800 3FFF       | 2         | Reserved                                                |
| HS USB host IA       | 0x6800 4000         | 0x6800 43FF       | 1         | HS USB host initiator port agent configuration          |
| HS USB OTG IA        | 0x6800 4400         | 0x6800 47FF       | 1         | HS USB OTG initiator port agent configuration           |
| Reserved             | 0x6800 4800         | 0x6800 4BFF       | 1         | Reserved                                                |
| sDMA RD IA           | 0x6800 4C00         | 0x6800 4FFF       | 1         | System DMA (sDMA) RD initiator port agent configuration |
| sDMA WR IA           | 0x6800 5000         | 0x6800 53FF       | 1         | sDMA WR initiator port agent configuration              |
| Display subsystem IA | 0x6800 5400         | 0x6800 57FF       | 1         | Display subsystem initiator port agent configuration    |
| CAMERA ISP IA        | 0x6800 5800         | 0x6800 5BFF       | 1         | Camera ISP initiator port agent configuration           |
| DAP IA               | 0x6800 5C00         | 0x6800 5FFF       | 1         | Debug access port initiator port agent configuration    |
| IVA2.2 subsystem TA  | 0x6800 6000         | 0x6800 63FF       | 1         | IVA2.2 subsystem target port agent configuration        |
| SGX subsystem TA     | 0x6800 6400         | 0x6800 67FF       | 1         | SGX subsystem target port agent configuration           |
| L4-Core TA           | 0x6800 6800         | 0x6800 6BFF       | 1         | L4-Core target port agent configuration                 |
| L4-Per TA            | 0x6800 6C00         | 0x6800 6FFF       | 1         | L4-Per target port agent configuration                  |
| Reserved             | 0x6800 7000         | 0x6800 FFFF       | 36        | Reserved                                                |
| RT PM                | 0x6801 0000         | 0x6801 03FF       | 1         | Register target port protection                         |
| Reserved             | 0x6801 0400         | 0x6801 23FF       | 8         | Reserved                                                |
| GPMC PM              | 0x6801 2400         | 0x6801 27FF       | 1         | GPMC target port protection                             |
| OCM RAM PM           | 0x6801 2800         | 0x6801 2BFF       | 1         | OCM RAM target port protection                          |
| OCM ROM PM           | 0x6801 2C00         | 0x6801 2FFF       | 1         | OCM ROM target port protection                          |
| D2D PM               | 0x6801 3000         | 0x6801 33FF       | 1         | D2D target port protection                              |
| Reserved             | 0x6801 3400         | 0x6801 3FFF       | 3         | Reserved                                                |
| IVA2.2 PM            | 0x6801 4000         | 0x6801 43FF       | 1         | IVA2.2 subsystem target port protection                 |
| Reserved             | 0x6801 4400         | 0x68FF FFFF       | 16,303    | Reserved                                                |

### 2.3.2 L4 Memory Space Mapping

The device contains four L4 interconnects: L4-Core, L4-Wakeup, L4-Per, and L4-Emu.

As with the L3 interconnect, the L4 interconnects can be configured to tune the access depending on the characteristics of each module.

For more information about the L4 interconnect, see [Chapter 9, Interconnect](#).

#### 2.3.2.1 L4-Core Memory Space Mapping

The L4-Core interconnect is a 16-MB space composed of the L4-Core interconnect configuration registers and the module registers.

[Table 2-3](#) describes the mapping of the registers for the L4-Core interconnect.

**NOTE:** All memory spaces described as modules provide direct access to module registers outside the L4-Core interconnect. All other accesses are internal to the L4-Core interconnect.

This section describes all modules and features in the high-tier device. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

**Table 2-3. L4-Core Memory Space Mapping <sup>(1)</sup>**

| Device Name                            | Start Address (Hex) | End Address (Hex) | Size  | Description             |
|----------------------------------------|---------------------|-------------------|-------|-------------------------|
| <b>L4-Core</b>                         | 0x4800 0000         | 0x48FF FFFF       | 16MB  |                         |
| Reserved                               | 0x4800 0000         | 0x4800 1FFF       | 8KB   | Reserved                |
| System control module (SCM)            | 0x4800 2000         | 0x4800 2FFF       | 4KB   | Module                  |
|                                        | 0x4800 3000         | 0x4800 3FFF       | 4KB   | L4 interconnect         |
| Clock manager                          | 0x4800 4000         | 0x4800 5FFF       | 8KB   | Module region A         |
| • DPLL                                 | 0x4800 6000         | 0x4800 67FF       | 2KB   | Module region B         |
| • Clock manager                        | 0x4800 6800         | 0x4800 6FFF       | 2KB   | Reserved                |
|                                        | 0x4800 7000         | 0x4800 7FFF       | 4KB   | L4 interconnect         |
| Reserved                               | 0x4800 8000         | 0x4802 3FFF       | 112KB | Reserved                |
| Reserved                               | 0x4802 4000         | 0x4802 4FFF       | 4KB   | Reserved                |
|                                        | 0x4802 5000         | 0x4802 5FFF       | 4KB   | Reserved                |
| Reserved                               | 0x4802 6000         | 0x4803 FFFF       | 104KB | Reserved                |
| L4-Core configuration                  | 0x4804 0000         | 0x4804 07FF       | 2KB   | Address/protection (AP) |
|                                        | 0x4804 0800         | 0x4804 0FFF       | 2KB   | Initiator port (IP)     |
|                                        | 0x4804 1000         | 0x4804 1FFF       | 4KB   | Link agent (LA)         |
| Reserved                               | 0x4804 2000         | 0x4804 FBFF       | 55KB  | Reserved                |
| Display subsystem                      | 0x4804 FBFF         | 0x4804 FFFF       | 1KB   | DSI                     |
| • DSI                                  | 0x4805 0000         | 0x4805 03FF       | 1KB   | Display subsystem top   |
| • Display subsystem top                | 0x4805 0400         | 0x4805 07FF       | 1KB   | Display controller      |
| • Display controller                   | 0x4805 0800         | 0x4805 0BFF       | 1KB   | RFBI                    |
| • Remote frame buffer interface (RFBI) | 0x4805 0C00         | 0x4805 0FFF       | 1KB   | Video encoder           |
| • Video encoder (VENC)                 | 0x4805 1000         | 0x4805 1FFF       | 4KB   | L4 interconnect         |
| Reserved                               | 0x4805 2000         | 0x4805 5FFF       | 16KB  | Reserved                |
| sDMA                                   | 0x4805 6000         | 0x4805 6FFF       | 4KB   | Module                  |
|                                        | 0x4805 7000         | 0x4805 7FFF       | 4KB   | L4 interconnect         |
| Reserved                               | 0x4805 8000         | 0x4805 FFFF       | 32KB  | Reserved                |
| I2C3                                   | 0x4806 0000         | 0x4806 0FFF       | 4KB   | Module                  |
|                                        | 0x4806 1000         | 0x4806 1FFF       | 4KB   | L4 interconnect         |
| USBTLL                                 | 0x4806 2000         | 0x4806 2FFF       | 4KB   | Module                  |
|                                        | 0x4806 3000         | 0x4806 3FFF       | 4KB   | L4 interconnect         |
| HS USB Host                            | 0x4806 4000         | 0x4806 4FFF       | 4KB   | Module                  |
|                                        | 0x4806 5000         | 0x4806 5FFF       | 4KB   | L4 interconnect         |
| Reserved                               | 0x4806 6000         | 0x4806 9FFF       | 16KB  | Reserved                |
| UART1                                  | 0x4806 A000         | 0x4806 AFFF       | 4KB   | Module                  |
|                                        | 0x4806 B000         | 0x4806 BFFF       | 4KB   | L4 interconnect         |
| UART2                                  | 0x4806 C000         | 0x4806 CFFF       | 4KB   | Module                  |
|                                        | 0x4806 D000         | 0x4806 DFFF       | 4KB   | L4 interconnect         |
| Reserved                               | 0x4806 E000         | 0x4806 FFFF       | 8KB   | Reserved                |
| I2C1                                   | 0x4807 0000         | 0x4807 0FFF       | 4KB   | Module                  |
|                                        | 0x4807 1000         | 0x4807 1FFF       | 4KB   | L4 interconnect         |

<sup>(1)</sup> The registers mapped in this range are shadow registers of the first 2-KB region A [0x4800 4000 – 0x4800 47FF]. Region A and region B share the same port.

**Table 2-3. L4-Core Memory Space Mapping <sup>(2)</sup> (continued)**

| Device Name                         | Start Address (Hex) | End Address (Hex) | Size | Description     |
|-------------------------------------|---------------------|-------------------|------|-----------------|
| I2C2                                | 0x4807 2000         | 0x4807 2FFF       | 4KB  | Module          |
|                                     | 0x4807 3000         | 0x4807 3FFF       | 4KB  | L4 interconnect |
| McBSP1<br>(digital baseband data)   | 0x4807 4000         | 0x4807 4FFF       | 4KB  | Module          |
|                                     | 0x4807 5000         | 0x4807 5FFF       | 4KB  | L4 interconnect |
| Reserved                            | 0x4807 6000         | 0x4808 5FFF       | 64KB | Reserved        |
| GPTIMER10                           | 0x4808 6000         | 0x4808 6FFF       | 4KB  | Module          |
|                                     | 0x4808 7000         | 0x4808 7FFF       | 4KB  | L4 interconnect |
| GPTIMER11                           | 0x4808 8000         | 0x4808 8FFF       | 4KB  | Module          |
|                                     | 0x4808 9000         | 0x4808 9FFF       | 4KB  | L4 interconnect |
| Reserved                            | 0x4808 A000         | 0x4808 AFFF       | 4KB  | Reserved        |
|                                     | 0x4808 B000         | 0x4808 BFFF       | 4KB  | Reserved        |
| Reserved                            | 0x4808 C000         | 0x4809 3FFF       | 32KB | Reserved        |
| Mailbox                             | 0x4809 4000         | 0x4809 4FFF       | 4KB  | Module          |
|                                     | 0x4809 5000         | 0x4809 5FFF       | 4KB  | L4 interconnect |
| McBSP5<br>(MIDI data)               | 0x4809 6000         | 0x4809 6FFF       | 4KB  | Module          |
|                                     | 0x4809 7000         | 0x4809 7FFF       | 4KB  | L4 interconnect |
| McSPI1                              | 0x4809 8000         | 0x4809 8FFF       | 4KB  | Module          |
|                                     | 0x4809 9000         | 0x4809 9FFF       | 4KB  | L4 interconnect |
| McSPI2                              | 0x4809 A000         | 0x4809 AFFF       | 4KB  | Module          |
|                                     | 0x4809 B000         | 0x4809 BFFF       | 4KB  | L4 interconnect |
| MMC/SD/SDIO1                        | 0x4809 C000         | 0x4809 CFFF       | 4KB  | Module          |
|                                     | 0x4809 D000         | 0x4809 DFFF       | 4KB  | L4 interconnect |
| Reserved                            | 0x4809 E000         | 0x4809 EFFF       | 4KB  | Reserved        |
|                                     | 0x4809 F000         | 0x4809 FFFF       | 4KB  | Reserved        |
| Reserved                            | 0x480A 0000         | 0x480A AFFF       | 44KB | Reserved        |
| HS USB OTG                          | 0x480A B000         | 0x480A BFFF       | 4KB  | Module          |
|                                     | 0x480A C000         | 0x480A CFFF       | 4KB  | L4 interconnect |
| MMC/SD/SDIO3                        | 0x480A D000         | 0x480A DFFF       | 4KB  | Module          |
|                                     | 0x480A E000         | 0x480A EFFF       | 4KB  | L4 interconnect |
| Reserved                            | 0x480A F000         | 0x480A FFFF       | 4KB  | Reserved        |
| Reserved                            | 0x480B 0000         | 0x480B 0FFF       | 4KB  | Reserved        |
|                                     | 0x480B 1000         | 0x480B 1FFF       | 4KB  | Reserved        |
| HDQ™/1-Wire®                        | 0x480B 2000         | 0x480B 2FFF       | 4KB  | Module          |
|                                     | 0x480B 3000         | 0x480B 3FFF       | 4KB  | L4 interconnect |
| MMC/SD/SDIO2                        | 0x480B 4000         | 0x480B 4FFF       | 4KB  | Module          |
|                                     | 0x480B 5000         | 0x480B 5FFF       | 4KB  | L4 interconnect |
| ICR MPU port<br>(chassis mode only) | 0x480B 6000         | 0x480B 6FFF       | 4KB  | Module          |
|                                     | 0x480B 7000         | 0x480B 7FFF       | 4KB  | L4 interconnect |
| McSPI3                              | 0x480B 8000         | 0x480B 8FFF       | 4KB  | Module          |
|                                     | 0x480B 9000         | 0x480B 9FFF       | 4KB  | L4 interconnect |
| McSPI4                              | 0x480B A000         | 0x480B AFFF       | 4KB  | Module          |
|                                     | 0x480B B000         | 0x480B BFFF       | 4KB  | L4 interconnect |
| Camera ISP                          | 0x480B C000         | 0x480B FFFF       | 16KB | Camera ISP      |
|                                     | 0x480C 0000         | 0x480C 0FFF       | 4KB  | L4 interconnect |
| Reserved                            | 0x480C 1000         | 0x480C 8FFF       | 32KB | Reserved        |
| SR1                                 | 0x480C 9000         | 0x480C 9FFF       | 4KB  | Module          |
|                                     | 0x480C A000         | 0x480C AFFF       | 4KB  | L4 interconnect |

**Table 2-3. L4-Core Memory Space Mapping <sup>(2)</sup> (continued)**

| Device Name                           | Start Address (Hex) | End Address (Hex) | Size     | Description              |
|---------------------------------------|---------------------|-------------------|----------|--------------------------|
| SR2                                   | 0x480C B000         | 0x480C BFFF       | 4KB      | Module                   |
|                                       | 0x480C C000         | 0x480C CFFF       | 4KB      | L4 interconnect          |
| ICR modem port<br>(chassis mode only) | 0x480C D000         | 0x480C DFFF       | 4KB      | Module                   |
|                                       | 0x480C E000         | 0x480C EFFF       | 4KB      | L4 interconnect          |
| Reserved                              | 0x480C F000         | 0x482F FFFF       | 2208KB   | Reserved                 |
| L4-Wakeup interconnect (region A)     | 0x4830 0000         | 0x4830 9FFF       | 40KB     | Nonshared device mapping |
| Control module ID code                | 0x4830 A000         | 0x4830 AFFF       | 4KB      | See Table 2-4.           |
|                                       | 0x4830 B000         | 0x4830 BFFF       | 4KB      | L4 interconnect          |
| L4-Wakeup interconnect (Region B)     | 0x4830 C000         | 0x4833 FFFF       | 208KB    | See Table 2-4.           |
|                                       | 0x4834 0000         | 0x4834 0FFF       | 4KB      | L4 interconnect          |
| Reserved                              | 0x4834 1000         | 0x48FF EFFF       | 13,052KB | Reserved                 |

### 2.3.2.2 L4-Wakeup Memory Space Mapping

The L4-Wakeup interconnect is a 256-KB space composed of the L4-Wakeup interconnect configuration registers and the module registers.

Table 2-4 describes the mapping of the registers for the L4-Wakeup interconnect.

---

**NOTE:** All memory spaces described as modules provide direct access to module registers outside the L4-Wakeup interconnect. All other accesses are internal to the L4-Wakeup interconnect.

---

**Table 2-4. L4-Wakeup Memory Space Mapping**

| Device Name             | Start Address (Hex) | End Address (Hex) | Size (KB) | Description                    |
|-------------------------|---------------------|-------------------|-----------|--------------------------------|
| <b>L4-Wakeup</b>        | 0x4830 0000         | 0x4833 FFFF       | 256       |                                |
| Reserved                | 0x4830 0000         | 0x4830 5FFF       | 24        | Reserved                       |
| Power and reset manager | 0x4830 6000         | 0x4830 7FFF       | 8         | Module region A                |
| • Power manager         | 0x4830 8000         | 0x4830 87FF       | 2         | Module region B <sup>(1)</sup> |
| • Reset manager         | 0x4830 8800         | 0x4830 8FFF       | 2         | Reserved                       |
|                         | 0x4830 9000         | 0x4830 9FFF       | 4         | L4 interconnect                |
| Reserved                | 0x4830 A000         | 0x4830 FFFF       | 24        | Reserved                       |
| GPIO1                   | 0x4831 0000         | 0x4831 0FFF       | 4         | Module                         |
|                         | 0x4831 1000         | 0x4831 1FFF       | 4         | L4 interconnect                |
| Reserved                | 0x4831 2000         | 0x4831 3FFF       | 8         | Reserved                       |
| WDT2                    | 0x4831 4000         | 0x4831 4FFF       | 4         | Module                         |
|                         | 0x4831 5000         | 0x4831 5FFF       | 4         | L4 interconnect                |
| Reserved                | 0x4831 6000         | 0x4831 7FFF       | 8         | Reserved                       |
| GPTIMER1                | 0x4831 8000         | 0x4831 8FFF       | 4         | Module                         |
|                         | 0x4831 9000         | 0x4831 9FFF       | 4         | L4 interconnect                |
| Reserved                | 0x4831 A000         | 0x4831 FFFF       | 24        | Reserved                       |
| 32KTIMER                | 0x4832 0000         | 0x4832 0FFF       | 4         | Module                         |
|                         | 0x4832 1000         | 0x4832 1FFF       | 4         | L4 interconnect                |
| Reserved                | 0x4832 2000         | 0x4832 7FFF       | 24        | Reseved                        |

<sup>(1)</sup> The registers mapped in this range are shadow registers of the first 2-KB region A [0x4830 6000 – 0x4830 67FF]. Regions A and B share the same port.

**Table 2-4. L4-Wakeup Memory Space Mapping (continued)**

| Device Name             | Start Address (Hex) | End Address (Hex) | Size (KB) | Description |
|-------------------------|---------------------|-------------------|-----------|-------------|
| L4-Wakeup configuration | 0x4832 8000         | 0x4832 87FF       | 2         | AP          |
|                         | 0x4832 8800         | 0x4832 8FFF       | 2         | IP L4-Core  |
|                         | 0x4832 9000         | 0x4832 9FFF       | 4         | LA          |
|                         | 0x4832 A000         | 0x4832 A7FF       | 2         | IP L4-Emu   |
| Reserved                | 0x4832 A800         | 0x4833 FFFF       | 86        | Reserved    |

### 2.3.2.3 L4-Peripheral Memory Space Mapping

The L4-Per interconnect is a 1-MB space composed of the L4-Per interconnect configuration registers and the module registers.

Table 2-5 describes the mapping of the registers for the L4-Per interconnect.

---

**NOTE:** All memory spaces described as modules provide direct access to the module registers outside the L4-Per interconnect. All other accesses are internal to the L4-Per interconnect.

---

**Table 2-5. L4-Peripheral Memory Space Mapping**

| Device Name                             | Start Address (Hex) | End Address (Hex) | Size  | Description     |
|-----------------------------------------|---------------------|-------------------|-------|-----------------|
| L4-Per                                  | 0x4900 0000         | 0x490F FFFF       | 1MB   |                 |
| L4-Per configuration                    | 0x4900 0000         | 0x4900 07FF       | 2KB   | AP              |
|                                         | 0x4900 0800         | 0x4900 0FFF       | 2KB   | IP              |
|                                         | 0x4900 1000         | 0x4900 1FFF       | 4KB   | LA              |
|                                         | 0x4900 2000         | 0x4901 FFFF       | 120KB | Reserved        |
| UART3<br>(infrared)                     | 0x4902 0000         | 0x4902 0FFF       | 4KB   | Module          |
|                                         | 0x4902 1000         | 0x4902 1FFF       | 4KB   | L4 interconnect |
| McBSP2<br>(audio for codec)             | 0x4902 2000         | 0x4902 2FFF       | 4KB   | Module          |
|                                         | 0x4902 3000         | 0x4902 3FFF       | 4KB   | L4 interconnect |
| McBSP3<br>(Bluetooth ® voice data)      | 0x4902 4000         | 0x4902 4FFF       | 4KB   | Module          |
|                                         | 0x4902 5000         | 0x4902 5FFF       | 4KB   | L4 interconnect |
| McBSP4<br>(digital baseband voice data) | 0x4902 6000         | 0x4902 6FFF       | 4KB   | Module          |
|                                         | 0x4902 7000         | 0x4902 7FFF       | 4KB   | L4 interconnect |
| McBSP2 (sidetone)                       | 0x4902 8000         | 0x4902 8FFF       | 4KB   | Module          |
|                                         | 0x4902 9000         | 0x4902 9FFF       | 4KB   | L4 interconnect |
| McBSP3 (sidetone)                       | 0x4902 A000         | 0x4902 AFFF       | 4KB   | Module          |
|                                         | 0x4902 B000         | 0x4902 BFFF       | 4KB   | L4 interconnect |
| Reserved                                | 0x4902 C000         | 0x4902 FFFF       | 16KB  | Reserved        |
| WDT3                                    | 0x4903 0000         | 0x4903 0FFF       | 4KB   | Module          |
|                                         | 0x4903 1000         | 0x4903 1FFF       | 4KB   | L4 interconnect |
| GPTIMER2                                | 0x4903 2000         | 0x4903 2FFF       | 4KB   | Module          |
|                                         | 0x4903 3000         | 0x4903 3FFF       | 4KB   | L4 interconnect |
| GPTIMER3                                | 0x4903 4000         | 0x4903 4FFF       | 4KB   | Module          |
|                                         | 0x4903 5000         | 0x4903 5FFF       | 4KB   | L4 interconnect |
| GPTIMER4                                | 0x4903 6000         | 0x4903 6FFF       | 4KB   | Module          |
|                                         | 0x4903 7000         | 0x4903 7FFF       | 4KB   | L4 interconnect |
| GPTIMER5                                | 0x4903 8000         | 0x4903 8FFF       | 4KB   | Module          |
|                                         | 0x4903 9000         | 0x4903 9FFF       | 4KB   | L4 interconnect |

**Table 2-5. L4-Peripheral Memory Space Mapping (continued)**

| Device Name | Start Address (Hex) | End Address (Hex) | Size  | Description     |
|-------------|---------------------|-------------------|-------|-----------------|
| GPTIMER6    | 0x4903 A000         | 0x4903 AFFF       | 4KB   | Module          |
|             | 0x4903 B000         | 0x4903 BFFF       | 4KB   | L4 interconnect |
| GPTIMER7    | 0x4903 C000         | 0x4903 CFFF       | 4KB   | Module          |
|             | 0x4903 D000         | 0x4903 DFFF       | 4KB   | L4 interconnect |
| GPTIMER8    | 0x4903 E000         | 0x4903 EFFF       | 4KB   | Module          |
|             | 0x4903 F000         | 0x4903 FFFF       | 4KB   | L4 interconnect |
| GPTIMER9    | 0x4904 0000         | 0x4904 0FFF       | 4KB   | Module          |
|             | 0x4904 1000         | 0x4904 1FFF       | 4KB   | L4 interconnect |
| UART4       | 0x4904 2000         | 0x4904 2FFF       | 4KB   | Module          |
|             | 0x4904 3000         | 0x4904 3FFF       | 4KB   | L4 interconnect |
| Reserved    | 0x4904 4000         | 0x4904 FFFF       | 48KB  | Reserved        |
| GPIO2       | 0x4905 0000         | 0x4905 0FFF       | 4KB   | Module          |
|             | 0x4905 1000         | 0x4905 1FFF       | 4KB   | L4 interconnect |
| GPIO3       | 0x4905 2000         | 0x4905 2FFF       | 4KB   | Module          |
|             | 0x4905 3000         | 0x4905 3FFF       | 4KB   | L4 interconnect |
| GPIO4       | 0x4905 4000         | 0x4905 4FFF       | 4KB   | Module          |
|             | 0x4905 5000         | 0x4905 5FFF       | 4KB   | L4 interconnect |
| GPIO5       | 0x4905 6000         | 0x4905 6FFF       | 4KB   | Module          |
|             | 0x4905 7000         | 0x4905 7FFF       | 4KB   | L4 interconnect |
| GPIO6       | 0x4905 8000         | 0x4905 8FFF       | 4KB   | Module          |
|             | 0x4905 9000         | 0x4905 9FFF       | 4KB   | L4 interconnect |
| Reserved    | 0x4905 A000         | 0x490F FFFF       | 664KB | Reserved        |

### 2.3.2.4 L4-Emulation Memory Space Mapping

The L4-Emu interconnect is an 8-MB space composed of the L4-Emu interconnect configuration registers and module registers.

Table 2-6 describes the mapping of the registers for the L4-Emu interconnect.

---

**NOTE:** All memory spaces described as modules provide direct access to the module registers outside the L4-Emu interconnect. All other accesses are internal to the L4-Emu interconnect.

---

**Table 2-6. L4-Emulation Memory Space Mapping**

| Device Name          | Start Address (Hex) | End Address (Hex) | Size | Description     |
|----------------------|---------------------|-------------------|------|-----------------|
| <b>L4-Emu</b>        | 0x5400 0000         | 0x547F FFFF       | 8MB  |                 |
| Reserved             | 0x5400 0000         | 0x5400 3FFF       | 16KB | Reserved        |
| Reserved             | 0x5400 4000         | 0x5400 5FFF       | 8KB  | Reserved        |
| L4-Emu configuration | 0x5400 6000         | 0x5400 67FF       | 2KB  | AP              |
|                      | 0x5400 6800         | 0x5400 6FFF       | 2KB  | IP L4-Core      |
|                      | 0x5400 7000         | 0x5400 7FFF       | 4KB  | LA              |
|                      | 0x5400 8000         | 0x5400 87FF       | 2KB  | IP DAP          |
| Reserved             | 0x5400 8800         | 0x5400 FFFF       | 30KB | Reserved        |
| MPU emulation        | 0x5401 0000         | 0x5401 7FFF       | 16KB | Module          |
|                      | 0x5401 8000         | 0x5401 7FFF       | 4KB  | L4 interconnect |

**Table 2-6. L4-Emulation Memory Space Mapping (continued)**

| Device Name                                              | Start Address (Hex) | End Address (Hex) | Size   | Description                    |
|----------------------------------------------------------|---------------------|-------------------|--------|--------------------------------|
| TPIU                                                     | 0x5401 9000         | 0x5401 9FFF       | 4KB    | Module                         |
|                                                          | 0x5401 A000         | 0x5401 AFFF       | 4KB    | L4 interconnect                |
| ETB                                                      | 0x5401 B000         | 0x5401 BFFF       | 4KB    | Module                         |
|                                                          | 0x5401 C000         | 0x5401 CFFF       | 4KB    | L4 interconnect                |
| DAPCTL                                                   | 0x5401 D000         | 0x5401 DFFF       | 4KB    | Module                         |
|                                                          | 0x5401 E000         | 0x5401 EFFF       | 4KB    | L4 interconnect                |
| SDTI                                                     | 0x5401 F000         | 0x5401 FFFF       | 4KB    | L4 interconnect                |
|                                                          | 0x5402 0000         | 0x544F FFFF       | 4992KB | Reserved                       |
|                                                          | 0x5450 0000         | 0x5450 FFFF       | 4KB    | SDTI module (configuration)    |
|                                                          | 0x5451 0000         | 0x545F FFFF       | 1984KB | Reserved                       |
|                                                          | 0x5460 0000         | 0x546F FFFF       | 1MB    | SDTI module (window)           |
| Reserved                                                 | 0x5470 0000         | 0x5470 5FFF       | 24KB   | Reserved                       |
| Power and reset manager<br>(WKUP domain <sup>(1)</sup> ) | 0x5470 6000         | 0x5470 7FFF       | 8KB    | Module region A                |
|                                                          | 0x5470 8000         | 0x5470 87FF       | 2KB    | Module region B <sup>(2)</sup> |
|                                                          | 0x5470 8800         | 0x5470 8FFF       | 2KB    | Reserved                       |
|                                                          | 0x5470 9000         | 0x5470 9FFF       | 4KB    | L4 interconnect                |
| Reserved                                                 | 0x5470 A000         | 0x5470 FFFF       | 24KB   | Reserved                       |
| GPIO1<br>(WKUP domain <sup>(3)</sup> )                   | 0x5471 0000         | 0x5471 0FFF       | 4KB    | Module                         |
|                                                          | 0x5471 1000         | 0x5471 1FFF       | 4KB    | L4 interconnect                |
| Reserved                                                 | 0x5471 2000         | 0x5471 3FFF       | 8KB    | Reserved                       |
| WDT2<br>(WKUP domain <sup>(3)</sup> )                    | 0x5471 4000         | 0x5471 4FFF       | 4KB    | Module                         |
|                                                          | 0x5471 5000         | 0x5471 5FFF       | 4KB    | L4 interconnect                |
| Reserved                                                 | 0x5471 6000         | 0x5471 7FFF       | 8KB    | Reserved                       |
| GPTIMER1<br>(WKUP domain <sup>(3)</sup> )                | 0x5471 8000         | 0x5471 8FFF       | 4KB    | Module                         |
|                                                          | 0x5471 9000         | 0x5471 9FFF       | 4KB    | L4 interconnect                |
| Reserved                                                 | 0x5471 A000         | 0x5471 FFFF       | 24KB   | Reserved                       |
| 32KTIMER<br>(WKUP domain <sup>(3)</sup> )                | 0x5472 0000         | 0x5472 0FFF       | 4KB    | Module                         |
|                                                          | 0x5472 1000         | 0x5472 1FFF       | 4KB    | L4 interconnect                |
| Reserved                                                 | 0x5472 2000         | 0x5472 7FFF       | 24KB   | Reserved                       |
| L4-Wakeup configuration<br>(WKUP domain <sup>(3)</sup> ) | 0x5472 8000         | 0x5472 87FF       | 2KB    | AP                             |
|                                                          | 0x5472 8800         | 0x5472 8FFF       | 2KB    | IP L4-Core                     |
|                                                          | 0x5472 9000         | 0x5472 9FFF       | 4KB    | LA                             |
|                                                          | 0x5472 A000         | 0x5472 A7FF       | 2KB    | IP L4-Emu                      |
| Reserved                                                 | 0x5472 A800         | 0x547F FFFF       | 854KB  | Reserved                       |

<sup>(1)</sup> These modules are accessed through the L4-Wakeup interconnect (for emulation only).<sup>(2)</sup> The registers mapped in this range are shadow registers of the first 2-KB region A [0x5470 6000 – 0x5470 67FF]. Regions A and B share the same port.<sup>(3)</sup> These modules are accessed through the L4-Wakeup interconnect (for emulation only).

### 2.3.3 Register Access Restrictions

This section describes all modules and features in the high-tier device. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

Table 2-7 lists the supported data access widths per module.

**Table 2-7. Register Access Restrictions**

| <b>Module</b>                  | <b>Allowed Access (Bits)</b> |
|--------------------------------|------------------------------|
| MPU subsystem                  | 8/16/32                      |
| IVA2.2 subsystem               | 32                           |
| SGX subsystem                  | 32                           |
| Camera ISP                     | 8/16/32                      |
| Display subsystem              | 32                           |
| GPMC                           | 8/16/32                      |
| SMS                            | 8/16/32                      |
| SDRC                           | 8/16/32                      |
| sDMA                           | 8/16/32                      |
| HS USB host                    | 32                           |
| USBTLL                         | 32                           |
| USB – ULPI and UTMI registers  | 8                            |
| HS USB OTG                     | 32                           |
| L3 interconnect                | 8/16/32                      |
| L4-Wakeup interconnect         | 8/16/32                      |
| L4-Core interconnect           | 8/16/32                      |
| Clock manager                  | 32                           |
| Power and reset manager        | 32                           |
| System control module          | 8/16/32                      |
| ICR (chassis mode only)        | 32                           |
| 32KTIMER                       | 16/32                        |
| GPIO                           | 8/16/32                      |
| GPTIMER                        | 16/32                        |
| WDTIMER                        | 16/32                        |
| I2C                            | 8/16                         |
| HDQ/1-Wire                     | 32                           |
| McBSP                          | 32                           |
| Sidetone                       | 8/16/32                      |
| McSPI                          | 8/16/32                      |
| UART                           | 8/16/32                      |
| MMC/SD/SDIO                    | 32                           |
| Mailbox                        | 8/16/32                      |
| MPU INTC                       | 16/32                        |
| MODEM INTC (chassis mode only) | 16/32                        |
| SR                             | 8/16/32                      |

## 2.4 IVA2.2 Subsystem Memory Space Mapping

This section describes the hardware accelerators of IVA2.2. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

The device includes the high-performance Texas Instruments IVA2.2. For more information, see [Chapter 5, IVA2.2 Subsystem](#).

This section describes how internal memories and registers of the IVA2.2 are accessed through the L3 interconnect and by the internal initiators of the IVA2.2 (the digital signal processor [DSP] and the enhanced direct memory access [EDMA]).

Three views of the IVA2.2 subsystem memory space mapping are provided:

- L3 interconnect view: External view (subsystem memories and configuration registers) as seen by the MPU subsystem and most of the initiators of the platform through the L3 interconnect
- IVA2.2 DSP view: Internal view as seen by the DSP
- IVA2.2 EDMA view: Internal view as seen by the EDMA

---

**NOTE:** The IVA2.2 subsystem also contains a local interconnect with its own memory space mapping that can be accessed only by the DSP and the video accelerator and sequencer in the IVA2.2 subsystem. For more information about this video accelerator/sequencer local interconnect and its memory space mapping, see [Chapter 5, IVA2.2 Subsystem](#).

---

### 2.4.1 IVA2.2 Subsystem Internal Memory and Cache Allocation

#### 2.4.1.1 IVA2.2 Subsystem Memory Hierarchy

The IVA2.2 subsystem includes the following memory features:

- L1P (program)
  - 32-KB configurable: Memory-mapped (default after reset) or direct-mapped cache—32-byte cache line
- L1D (data)
  - 32-KB configurable: Memory-mapped (default after reset) or 2-way set associative cache—64-byte cache line
  - 48-KB memory-mapped
- L2 (program and data)
  - 64-KB configurable: Memory-mapped (default after reset) or 2-way set associative cache—128-byte cache line
  - 32-KB memory-mapped
  - 16-KB ROM

The local memories can be used as cache RAMs or memory-mapped RAMs, depending on the configuration of the different memory controllers in the IVA2.2 subsystem.

[Figure 2-2](#) shows the memory hierarchy of the IVA2.2 subsystem.

**Figure 2-2. IVA2.2 Subsystem Memory Hierarchy**

memmap-002

#### 2.4.1.2 IVA2.2 Cache Allocation

After reset, the L1P RAM is used as a 32-KB memory-mapped RAM. The L1P RAM can be programmed in the C64x+™ DSP program memory controller to allocate 0 (default), 4, 8, 16, or 32KB to cache. When 32KB are allocated to cache, there is no more memory-mapped L1P.

After reset, the L1D RAM is used as an 80-KB memory-mapped RAM. The L1D RAM can be programmed in the C64x+ DSP data memory controller to allocate 0 (default), 4, 8, 16, or 32KB to cache. When 32KB are allocated to cache, 48KB are still allocated to the memory-mapped L1D.

After reset, L2 is used as a 96-KB memory-mapped RAM. L2 can be programmed to allocate 0 (default), 32, or 64KB to cache. When 64KB are allocated to cache, 32KB are still allocated to memory-mapped L2.

[Figure 2-3](#) is an example of the L1D RAM cache allocation, where 16KB are allocated to cache.

**Figure 2-3. L1D RAM Cache Allocation Example (L3 Interconnect View)**

## 2.4.2 DSP Access to L2 Memories

### 2.4.2.1 DSP Access to L2 ROM

The IVA2.2 subsystem contains 16KB of L2 ROM. The L2 ROM provides boot code.

When the L1P cache is configured to be inactive (default configuration), DSP program fetch accesses to the L2 ROM are performed directly, and thus suffer the L2 latency.

When the L1P cache is configured to be active, DSP program fetch accesses to L2 ROM are always serviced by the L1P cache controller, which partly hides the L2 latency.

### 2.4.2.2 DSP Access to L2 RAM

The IVA2.2 contains 96KB of L2 RAM. The L2 RAM can be configured to allocate up to 64KB to the L2 cache.

When the L1P and L1D caches are configured to be inactive (default configuration), DSP accesses to the L2 RAM are accomplished directly, and thus suffer the L2 latency.

When the L1P and L1D RAM are configured to be active, DSP program accesses to L2 RAM are always serviced by the L1P cache controller (if code fetch) or the L1D cache controller (if data access), which partly hides the L2 latency

## 2.4.3 DSP and EDMA Access to Memories and Peripherals

The IVA2.2 DSP and EDMA access the memories and peripherals using virtual addressing. This lets the DSP and EDMA access memories and peripherals in the same contiguous view, even when the memory is physically segmented. [Table 2-9](#) and [Table 2-10](#) give the address range where the DSP and the EDMA can access the memories and peripherals, respectively.

The IVA2.2 memory management unit (IVA2.2 iMMU) handles the virtual-to-physical address translation based on the software configuration (typically under control of the MPU subsystem).

Virtual addresses are issued by the initiator to the IVA2.2 iMMU. Using the translation look-aside buffer (TLB), the MMU translates the initiator virtual addresses into real physical addresses.

[Figure 2-4](#) shows the relationship among physical addresses, virtual addresses, and the IVA2.2 iMMU.

**Figure 2-4. IVA2.2 iMMU Address Translation**



For more information about the MMU, see [Chapter 15, Memory Management Units](#).

#### 2.4.4 L3 Interconnect View of the IVA2.2 Subsystem Memory Space

[Table 2-8](#) lists the IVA2.2 subsystem memory space mapping from the perspective of the MPU subsystem through the L3 interconnect.

**Table 2-8. L3 Interconnect View of the IVA2.2 Subsystem Memory Space**

| Region Name                     | Start Address (Hex) | End Address (Hex)  | Size        | Description              |
|---------------------------------|---------------------|--------------------|-------------|--------------------------|
| <b>Address space 0</b>          | <b>0x5C00 0000</b>  | <b>0x5CFF FFFF</b> | <b>16MB</b> |                          |
| Reserved                        | 0x5C00 0000         | 0x5C7D FFFF        | 8064KB      | Reserved                 |
| L2 ROM                          | 0x5C7E 0000         | 0x5C7E 3FFF        | 16KB        | IVA2.2 internal memories |
| Reserved                        | 0x5C7E 4000         | 0x5C7F 7FFF        | 80KB        | Reserved                 |
| L2 RAM                          | 0x5C7F 8000         | 0x5C7F FFFF        | 32KB        | IVA2.2 internal memories |
| L2 RAM (cache)                  | 0x5C80 0000         | 0x5C80 FFFF        | 64KB        | IVA2.2 internal memories |
| Reserved                        | 0x5C81 0000         | 0x5CDF FFFF        | 6080KB      | Reserved                 |
| L1P RAM (cache)                 | 0x5CE0 0000         | 0x5CE0 7FFF        | 32KB        | IVA2.2 internal memories |
| Reserved                        | 0x5CE0 8000         | 0x5CF0 3FFF        | 1008KB      | Reserved                 |
| L1D RAM                         | 0x5CF0 4000         | 0x5CF0 FFFF        | 48KB        | IVA2.2 internal memories |
| L1D RAM (cache)                 | 0x5CF1 0000         | 0x5CF1 7FFF        | 32KB        | IVA2.2 internal memories |
| Reserved                        | 0x5CF1 8000         | 0x5CFF FFFF        | 928KB       | Reserved                 |
| <b>Address space 1</b>          | <b>0x5D00 0000</b>  | <b>0x5DFF FFFF</b> | <b>16MB</b> |                          |
| MMU registers                   | 0x5D00 0000         | 0x5D00 0FFF        | 4KB         | IVA2.2 iMMU              |
| Reserved                        | 0x5D00 1000         | 0x5DFF FFFF        | 16,380KB    | Reserved                 |
| <b>Address space 2</b>          | <b>0x5E00 0000</b>  | <b>0x5EFF FFFF</b> | <b>16MB</b> |                          |
| Video coprocessor and sequencer | 0x5E00 0000         | 0x5E0F FFFF        | 1MB         | IVA2.2 video modules     |
| Reserved                        | 0x5E10 0000         | 0x5EFF FFFF        | 15MB        | Reserved                 |

## 2.4.5 DSP View of the IVA2.2 Subsystem Memory Space

Table 2-9 lists the IVA2.2 subsystem memory space mapping internally from the perspective of the DSP.

**Table 2-9. DSP View of the IVA2.2 Subsystem Memory Space**

| Region Name                    | Start Address (Hex) | End Address (Hex) | Size (KB) | Description                                |
|--------------------------------|---------------------|-------------------|-----------|--------------------------------------------|
| Reserved                       | 0x0000 0000         | 0x007D FFFF       | 8064      | Reserved                                   |
| L2 ROM                         | 0x007E 0000         | 0x007E 3FFF       | 16        | IVA2.2 internal memories                   |
| Reserved                       | 0x007E 4000         | 0x007F 7FFF       | 80        | Reserved                                   |
| L2 RAM                         | 0x007F 8000         | 0x007F FFFF       | 32        | IVA2.2 internal memories                   |
| L2 RAM (cache)                 | 0x0080 0000         | 0x0080 FFFF       | 64        | IVA2.2 internal memories                   |
| Reserved                       | 0x0081 0000         | 0x00DF FFFF       | 6080      | Reserved                                   |
| L1P RAM (cache)                | 0x00E0 0000         | 0x00E0 7FFF       | 32        | IVA2.2 internal memories                   |
| Reserved                       | 0x00E0 8000         | 0x00F0 3FFF       | 1008      | Reserved                                   |
| L1D RAM                        | 0x00F0 4000         | 0x00F0 FFFF       | 48        | IVA2.2 internal memories                   |
| L1D RAM (cache)                | 0x00F1 0000         | 0x00F1 7FFF       | 32        | IVA2.2 internal memories                   |
| Reserved                       | 0x00F1 8000         | 0x017F FFFF       | 9120      | Reserved                                   |
| C64x+ interrupt selector       | 0x0180 0000         | 0x0180 FFFF       | 64        | C64x+ DSP interrupt controller             |
| C64x+ PDC                      | 0x0181 0000         | 0x0181 0FFF       | 4         | C64x+ DSP power-down controller            |
| C64x+ protection ID            | 0x0181 1000         | 0x0181 1FFF       | 4         | C64x+ DSP protection ID                    |
| C64x+ revision ID              | 0x0181 2000         | 0x0181 2FFF       | 4         | C64x+ DSP revision ID                      |
| Reserved                       | 0x0181 3000         | 0x0181 FFFF       | 52        | Reserved                                   |
| C64x+ EMC                      | 0x0182 0000         | 0x0182 FFFF       | 64        | C64x+ DSP extended memory controller       |
| Reserved                       | 0x0183 0000         | 0x0183 FFFF       | 64        | Reserved                                   |
| C64x+ memory system            | 0x0184 0000         | 0x0184 FFFF       | 64        | Memory controller control registers        |
| Reserved                       | 0x0185 0000         | 0x01BF FFFF       | 3776      | Reserved                                   |
| TPCC configuration             | 0x01C0 0000         | 0x01C0 FFFF       | 64        | DMA transfer engine control registers      |
| TPTC0 configuration            | 0x01C1 0000         | 0x01C1 03FF       | 1         | DMA transfer scheduler 0 control registers |
| TPTC1 configuration            | 0x01C1 0400         | 0x01C1 07FF       | 1         | DMA transfer scheduler 1 control registers |
| Reserved                       | 0x01C1 0800         | 0x01C1 FFFF       | 62        | Reserved                                   |
| SYSC configuration             | 0x01C2 0000         | 0x01C2 0FFF       | 4         | SYSC module control registers              |
| WUGEN configuration            | 0x01C2 1000         | 0x01C2 1FFF       | 4         | Wake-up generator control registers        |
| Reserved                       | 0x01C2 2000         | 0x0FFF FFFF       | 233,336   | Reserved                                   |
| Reserved                       | 0x1000 0000         | 0x107D FFFF       | 8064      | Reserved                                   |
| L2 ROM <sup>(1)</sup>          | 0x107E 0000         | 0x107E 3FFF       | 16        | IVA2.2 internal memories                   |
| Reserved                       | 0x107E 4000         | 0x107F 7FFF       | 80        | Reserved                                   |
| L2 RAM <sup>(1)</sup>          | 0x107F 8000         | 0x107F FFFF       | 32        | IVA2.2 internal memories                   |
| L2 RAM (cache) <sup>(1)</sup>  | 0x1080 0000         | 0x1080 FFFF       | 64        | IVA2.2 internal memories                   |
| Reserved                       | 0x1081 0000         | 0x10DF FFFF       | 6080      | Reserved                                   |
| L1P RAM (cache) <sup>(1)</sup> | 0x10E0 0000         | 0x10E0 7FFF       | 32        | IVA2.2 internal memories                   |
| Reserved                       | 0x10E0 8000         | 0x10F0 3FFF       | 1008      | Reserved                                   |
| L1D RAM <sup>(1)</sup>         | 0x10F0 4000         | 0x10F0 FFFF       | 48        | IVA2.2 internal memories                   |
| L1D RAM (cache) <sup>(1)</sup> | 0x10F1 0000         | 0x10F1 7FFF       | 32        | IVA2.2 internal memories                   |
| Reserved                       | 0x10F1 8000         | 0x10FF FFFF       | 928       | Reserved                                   |

<sup>(1)</sup> IVA2.2 internal memories are reachable in the [0x007E 0000-0x00F1 7FFF] and [0x107E 0000-0x10F1 7FFF] (aliasing) ranges.

**Table 2-9. DSP View of the IVA2.2 Subsystem Memory Space (continued)**

| Region Name                             | Start Address (Hex) | End Address (Hex) | Size (KB) | Description                                                                                      |
|-----------------------------------------|---------------------|-------------------|-----------|--------------------------------------------------------------------------------------------------|
| Memories and peripherals <sup>(2)</sup> | 0x1100 0000         | 0xFFFF FFFF       | 3,915,776 | Controlled by the IVA2.2 MMU to access memories and peripherals external to the IVA2.2 subsystem |

<sup>(2)</sup> For more information, see [Chapter 5, IVA2.2 Subsystem](#).

## 2.4.6 EDMA View of the IVA2.2 Subsystem Memory Space

[Table 2-10](#) lists the IVA2.2 subsystem memory space mapping from the perspective of the EDMA.

**Table 2-10. EDMA View of the IVA2.2 Subsystem Memory Space**

| Region Name        | Start Address (Hex) | End Address (Hex) | Size (KB) | Description                                                      |
|--------------------|---------------------|-------------------|-----------|------------------------------------------------------------------|
| Reserved           | 0x0000 0000         | 0x0007 FFFF       | 512       | Reserved                                                         |
| iLCD CFG           | 0x0008 0000         | 0x0008 1FFF       | 8         | Improved variable-length coding decoding configuration registers |
| Reserved           | 0x0008 2000         | 0x0008 3FFF       | 8         | Reserved                                                         |
| iLCD IBUF0A        | 0x0008 4000         | 0x0008 43FF       | 1         | Improved variable-length coding decoding buffer                  |
| Reserved           | 0x0008 4400         | 0x0008 4FFF       | 3         | Reserved                                                         |
| iLCD IBUF0B        | 0x0008 5000         | 0x0008 53FF       | 1         | Improved variable-length coding decoding buffer                  |
| Reserved           | 0x0008 5400         | 0x0008 5FFF       | 3         | Reserved                                                         |
| iLCD IBUF1         | 0x0008 6000         | 0x0008 6BFF       | 3         | Improved variable-length coding decoding buffer                  |
| Reserved           | 0x0008 6C00         | 0x0008 7FFF       | 5         | Reserved                                                         |
| iLCD QMEM          | 0x0008 8000         | 0x0008 83FF       | 1         | Improved variable-length coding decoding quantize memory         |
| Reserved           | 0x0008 8400         | 0x0008 BFFF       | 15        | Reserved                                                         |
| iLCD HMEM          | 0x0008 C000         | 0x0008 DBFF       | 7         | Improved variable-length coding decoding huffman memory          |
| Reserved           | 0x0008 DC00         | 0x0008 FFFF       | 9         | Reserved                                                         |
| SEQ CFG            | 0x0009 0000         | 0x0009 07FF       | 2         | Video sequencer configuration registers                          |
| Reserved           | 0x0009 0800         | 0x0009 3FFF       | 14        | Reserved                                                         |
| SEQ DMEM           | 0x0009 4000         | 0x0009 4FFF       | 4         | Video sequencer data memory                                      |
| Reserved           | 0x0009 5000         | 0x0009 7FFF       | 12        | Reserved                                                         |
| SEQ IMEM           | 0x0009 8000         | 0x0009 9FFF       | 8         | Video sequencer instruction memory                               |
| Reserved           | 0x0009 A000         | 0x0009 BFFF       | 8         | Reserved                                                         |
| Video sysc         | 0x0009 C000         | 0x0009 CFFF       | 4         | Video system controller                                          |
| Reserved           | 0x0009 D000         | 0x0009 FFFF       | 12        | Reserved                                                         |
| iME CFG            | 0x000A 0000         | 0x000A 0FFF       | 4         | Improved motion estimation configuration registers               |
| iLF CFG            | 0x000A 1000         | 0x000A 1FFF       | 4         | Variable-length coding decoding configuration registers          |
| Reserved           | 0x000A 2000         | 0x000F 7FFF       | 344       | Reserved                                                         |
| Local interconnect | 0x000F 8000         | 0x000F BFFF       | 16        | Video accelerator/sequencer local interconnect                   |
| Reserved           | 0x000F C000         | 0x000F FFFF       | 16        | Reserved                                                         |
| Reserved           | 0x0010 0000         | 0x107D FFFF       | 269,184   | Reserved                                                         |
| L2 ROM             | 0x107E 0000         | 0x107E 3FFF       | 16        | IVA2.2 internal memories                                         |

**Table 2-10. EDMA View of the IVA2.2 Subsystem Memory Space (continued)**

| Region Name                             | Start Address (Hex) | End Address (Hex) | Size (KB) | Description                                                                                      |
|-----------------------------------------|---------------------|-------------------|-----------|--------------------------------------------------------------------------------------------------|
| Reserved                                | 0x107E 4000         | 0x107F 7FFF       | 80        | Reserved                                                                                         |
| L2 RAM                                  | 0x107F 8000         | 0x107F FFFF       | 32        | IVA2.2 internal memories                                                                         |
| L2 RAM (cache)                          | 0x1080 0000         | 0x1080 FFFF       | 64        | IVA2.2 internal memories                                                                         |
| Reserved                                | 0x1081 0000         | 0x10DF FFFF       | 6080      | Reserved                                                                                         |
| L1P RAM (cache)                         | 0x10E0 0000         | 0x10E0 7FFF       | 32        | IVA2.2 internal memories                                                                         |
| Reserved                                | 0x10E0 8000         | 0x10F0 3FFF       | 1008      | Reserved                                                                                         |
| L1D RAM                                 | 0x10F0 4000         | 0x10F0 FFFF       | 48        | IVA2.2 internal memories                                                                         |
| L1D RAM (cache)                         | 0x10F1 0000         | 0x10F1 7FFF       | 32        | IVA2.2 internal memories                                                                         |
| Reserved                                | 0x10F1 8000         | 0x10FF FFFF       | 928       | Reserved                                                                                         |
| Memories and peripherals <sup>(1)</sup> | 0x1100 0000         | 0xFFFF FFFF       | 3,915,776 | Controlled by the IVA2.2 MMU to access memories and peripherals external to the IVA2.2 subsystem |

<sup>(1)</sup> For more information, see [Chapter 5, IVA2.2 Subsystem](#).

## **Power, Reset, and Clock Management**

This chapter describes power, reset, and clock management in the device.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

For power-management saving consideration, ensure that power domains of unavailable features and modules are switched off and clocks are cut off.

---

| Topic                                              | Page                |
|----------------------------------------------------|---------------------|
| 3.1 <b>Introduction to Power Managements</b> ..... | <a href="#">224</a> |
| 3.2 <b>PRCM Overview</b> .....                     | <a href="#">237</a> |
| 3.3 <b>PRCM Environment</b> .....                  | <a href="#">240</a> |
| 3.4 <b>PRCM Integration</b> .....                  | <a href="#">244</a> |
| 3.5 <b>PRCM Functional Description</b> .....       | <a href="#">249</a> |
| 3.6 <b>PRCM Basic Programming Model</b> .....      | <a href="#">397</a> |
| 3.7 <b>PRCM Register Manual</b> .....              | <a href="#">447</a> |

### 3.1 Introduction to Power Managements

This introduction contains the following information:

- Requirement and goal of power management in mobile devices
- State-of-the-art power-management techniques for maximizing battery life for mobile devices
- Essential architectural building blocks for power management
- Overview of the device power-management architecture

#### 3.1.1 Goal of Power Management

Power management (efficient use of the available limited battery resources of a mobile device) is one of the most important design aspects of any mobile system. It imposes strong control over limited available power resources to ensure that they function for the longest possible time.

The device architecture ensures maximum performance for user satisfaction (audio/video support) while offering versatile power-management techniques for maximum design flexibility, depending on application requirements.

#### 3.1.2 Power-Management Techniques

The following sections describe the state-of-the-art power-management techniques supported by the device.

---

**NOTE:** The values in [Figure 3-1](#) through [Figure 3-4](#), which show power-management techniques, are hypothetical only. They do not represent valid test results on the device.

---

##### 3.1.2.1 Dynamic Voltage and Frequency Scaling

Dynamic voltage and frequency scaling (DVFS) reduces the device voltage and frequency by minimizing the idle time of the system. The DVFS technique uses dynamic selection of the optimal operating frequency and voltage to let a task be performed in the required amount of time. This reduces the active power consumption (power consumed while executing a task) of the device while still meeting task requirements.

[Figure 3-1](#) compares energy consumption with and without DVFS.

**Figure 3-1. Comparison of Energy Consumption With/Without DVFS**



[Figure 3-1](#) shows the DVFS technique by comparing a process executed at maximum frequency and operating voltage without applying DVFS to the same process executed at optimal frequency and voltage using DVFS, based on the task requirements. If a task that must terminate in 4 seconds is performed at

maximum operating frequency (left side of the figure), it terminates in 1 second, and the remaining 3 seconds are spent in idle mode. With DVFS (right side of the figure), the operating frequency is reduced to an optimal level; the task takes the full 4 seconds to complete, but power consumption is reduced. In addition, voltage can be further reduced to save power so dynamic and leakage power consumption are reduced.

DVFS requires control over the clock frequency and the operating voltage of the device elements. By intelligently switching the individual elements of the device to their optimal operating points, it is possible to minimize the power consumption of the device for a given task.

For practical reasons related to device making (flow, tools), DVFS can be used for only a few discrete steps, not over a continuum of voltage and frequency values. Each step, or operating performance point (OPP), is composed of a voltage (V) and frequency (F) pair. For an OPP, the frequency corresponds to the maximum frequency allowed at a voltage, or reciprocally, the voltage corresponds to the minimum voltage allowed for a frequency.

When applying DVFS, a processor or system always runs at the lowest OPP that meets the performance requirement at a given time. The user determines the optimal OPP for a given task and then switches to that OPP to save power.

### 3.1.2.2 SmartReflex Adaptive Voltage Scaling (AVS)

SmartReflex™ is a power-management technique for automatic control of the operating voltage of a module to reduce active power consumption.

With SmartReflex, power-supply voltage is adapted to silicon performance, statically (based on performance points predefined in the manufacturing process of a given device) or dynamically (based on the temperature-induced real-time performance of the device). A comparison of these predefined performance points to the real-time on-chip measured performance determines whether to raise or lower the power-supply voltage.

SmartReflex achieves the optimal performance/power trade-off for all devices across the technology process spectrum and across temperature variations.

Figure 3-2 shows an example of SmartReflex power management.

Figure 3-2. SmartReflex Example



In Figure 3-2, the self-adjusting voltage scaling with SmartReflex ensures the frequency performance of the current OPP. For a given device operating frequency, the device voltage is automatically adapted to maintain performance of the device. This ensures optimal power consumption for a given OPP.

With SmartReflex, the frequency steps are identified and the voltage is adapted according to the silicon performance of the device. In this case, instead of a voltage step for each frequency step, there is a corresponding range of voltages. The range depends on the fabrication process of the device and its real-time operating state (temperature) at a given frequency.

### 3.1.2.3 Dynamic Power Switching

Like DVFS, dynamic power switching (DPS) is a power-management technique that reduces active power consumption of a device. However, whereas DVFS reduces dynamic and leakage power consumption, DPS reduces only leakage power consumption, at the expense of a slight overhead in dynamic power consumption.

With DPS, the system switches dynamically between high- and low-consumption system power modes during system active time. When DPS is applied, a processor or system runs at the highest OPP (maximum frequency and voltage) to complete its tasks quickly, followed by an automatic switch to a low-power mode for minimum power consumption. DPS is useful when a real-time application is waiting for an event. The system can switch to a low-power system mode if the wake-up latency conditions allow it.

This technique consists of maximizing the idle period of the system to reduce its power consumption.

[Figure 3-3](#) compares energy consumption with and without DPS.

**Figure 3-3. Comparison of Energy Consumed With/Without DPS**



[Figure 3-3](#) compares the power consumption behavior for the same device operation without DPS (left side of the figure) and with DPS (right side of the figure). When operating without DPS, the device has a constant leakage current in idle mode. By using DPS, the system reduces the leakage current to zero. However, the transitions between system power modes can require storing the information before entering a low-power inactive state and restoring the information after a wake-up event (see [Figure 3-3](#)). This results in additional dynamic power consumption, referred to as the transition overhead, (see [Figure 3-3](#)). Transition overhead must be considered for a DPS operation.

For efficient deployment of DPS techniques, it is necessary to dynamically predict the performance requirement of the applications running on the processor. The DPS controller must account for the overhead of wake-up latencies related to domain switching and ensure that they do not significantly affect the performance of the device. Even with transition overhead, however, the user can identify an optimal idle-time limit after which the DPS is useful for dynamic power-saving.

### 3.1.2.4 Standby Leakage Management

Standby leakage management (SLM) is a power-management technique that reduces standby power consumption by reducing power leakage.

With SLM, the device switches to low-power system modes automatically or in response to user requests during system standby (in situations when no application is started and system activity is negligible or limited).

When applying SLM, the system remains in the lowest static power mode compatible with the system response time requirement.

This technique trades static power consumption for wake-up latency.

### 3.1.2.5 DPS Versus SLM

DPS and SLM are similar concepts: they consist of switching the system between high- and low-power consumption modes. However, their operating timescales differ, principally in the latency allowed for mode transitions.

DPS is generally used in an applicative context (tasks are started). Therefore, mode transitions are related to system performance requirements or the processor load. DPS transition latencies must be small (typically between 10 µs and 100 µs) compared to the time constraints or deadlines of the application so that they do not degrade application performance. DPS requires performance prediction to ensure that transition latencies do not deteriorate device performance to the point that real-time application deadlines are missed or the user experience degrades too much for an interactive application.

SLM is not used in an applicative context (no task started). Mode transitions are more related to system responsiveness, and the transition latencies must be small compared to user sensitivity so that they do not degrade the user experience. For SLM, transition latencies are typically 1 ms to 10 ms or more.

DPS and SLM also differ in the type of wake-up event used to exit low-power idle mode. For DPS, wake-up events are application-related (timer, DMA request, peripheral interrupt, etc.); for SLM, wake-up events are user-related (touch screen, key pressed, peripheral connections, etc.).

### 3.1.2.6 Adaptive Body Bias (ABB)

The device implements the following transistor body bias technique:

- Forward Body-Bias (FBB) for operating clock frequency boost for operation at higher operating performance points (OPPs).

ABB is based on the process corner and the current OPP. This is configured in the eFuse at the device characterization and is not continuously updated. A dedicated LDO (VBBLDO) is used to produce the voltage bias.

### 3.1.2.7 Combining Power-Management Techniques

The DVFS, DPS, SLM, and SmartReflex power-management techniques have different features and are most effective when used under specific device operating conditions. Hence, the best active power saving is obtained by combining the techniques. For a given operating state, one or more of the power-saving techniques can be applied to ensure optimal operation with maximum power saving.

SmartReflex can be used at boot time to adapt the voltage to device process characteristics (strong/weak) and then used continuously to compensate for temperature variations. It can also ensure maximum available application performance of the device at a given OPP.

When medium application performance is required, or when application performance requirements vary, DVFS can be applied. The voltage and frequency can be scaled to match the closest OPP that meets the performance requirement.

When application performance requirements fall between two OPPs, or when required application performance is below the lowest performance OPP, DPS can be applied to switch to low-power mode.

When combining DVFS and DPS, the operating frequency must not be scaled to match the performance requirement without scaling the voltage. Lower operating frequency increases task completion time and reduces idle time. This prevents DPS or reduces its efficiency (DPS becomes more effective as idle time increases). Unless DPS cannot be applied for other reasons, for a given operating point of DVFS, the operating frequency must always be set to the maximum allowed at a given voltage. This ensures optimal process completion time and application of DPS.

If DPS cannot be applied in a given context, scaling the frequency while keeping the voltage constant does not save energy. It does, however, reduce peak power consumption. This can have a positive effect on temperature dissipation and battery life.

In situations where no applications are running and performance requirement drops to zero, SLM must be used.

[Figure 3-4](#) compares combinations of the power-management techniques.

**NOTE:** The OPPs shown in [Figure 3-4](#) are for explanation only. They do not correspond to validated OPPs of the device.

**Figure 3-4. Performance Level and Applied Power-Management Techniques**



### 3.1.3 Architectural Blocks for Power Management

The device supports the power-management techniques through three architectural blocks: the power, clock, and voltage domains. A domain is a group of modules or subsections of the device that share a common entity (clock, voltage, or power switching).

#### 3.1.3.1 Clock Domain

A clock domain is a group of modules fed by the same gated clock signal (see [Figure 3-5](#)). By gating the clock to each domain, it is possible to cut a clock to a group of inactive modules to lower their active power consumption. Thus, a clock domain allows control of dynamic power consumption by the device.

**Figure 3-5. Generic Clock Domain**


Table 3-1 lists the two possible states of the clock domain.

**Table 3-1. States of a Clock Domain**

| State  | Description                           |
|--------|---------------------------------------|
| Active | The domain clock is running.          |
| Idle   | The domain clock is stopped or gated. |

### 3.1.3.2 Power Domain

A power domain is a section of the device with independent and dedicated power rails (see [Figure 3-6](#)). A power domain can be turned on/off without affecting the other parts of the device.

**Figure 3-6. Generic Power Domain**


To minimize device power consumption, the modules are placed in power domains. All power domains embed some logic and some memory. The memory contains a memory array powered by a dedicated voltage rail (Varray + arrayon switch) and some logic powered by the same voltage rail as the power domain logic (VDD + power on switch).

The memory area contains two entities:

- Memory bank: The memory bank is composed of memory arrays. It is powered by a dedicated voltage rail and an associated power switch. The memory array within the memory bank may be of RTA (retention-till-access) (see [Section 3.5.2.1.4](#)) or non-RTA type.
- Memory logic: The memory logic powered by the same voltage source as the logic area of the power domain, but has its dedicated power switch.

---

**NOTE:** The behavior of the Varray, arrayon, and power on switches can be selected by software (PWSTCTRL registers) hardwired; once the selection is made, the switches are handled automatically by the PRCM module.

---

The power domain logic for the CORE and the PER power domains can be split between retention flip flops (RFF) or nonretention flip flops (DFF). All other power domains embed only DFF.

A power domain can be in several power domain states: On, inactive, open/closed switch retention (OSWR, CSWR), or off.

- On: Power on is set to 1; Vdd is provided to the logic (DFF and RFF) and to the memory logic. All the logic is fully working. Depending on the software settings, Varray can keep its active value or be lowered, and the arrayon switch can be open or closed (depending on the power domain, this can be hardwired). As a consequence, the memory content can be accessible, retained, or lost.
- Inactive: The same as power on but all clocks are cut. Logic is not working, because no clock is running.
- Closed-switch retention (CSWR): Power on is set to 1, Vdd is provided to the logic (DFF and RFF) and to the memory logic, but Vdd can be lowered to its retention value. The logic is not functional, but is retained. Depending on software settings, Varray can keep its active value (if needed by another memory array in another power domain), or be lowered, and the arrayon switch can be open or closed (depending on the power domain, this can be hardwired). As a consequence, the memory content can be retained or lost.
- Open-switch retention (OSWR) (CORE and PER power domains only): Power on is set to 0, Vdd, which can be lowered to its retention value, is provided only to the RFF logic. Only the RFF logic is retained. The DFF logic is lost and reset on wakeup. Depending on software settings, Varray can keep its active value (if needed by another memory array in another power domain), or be lowered, and the arrayon switch can be open or closed (depending on the power domain, this can be hardwired). As a consequence, the memory content can be retained or lost.
- Off: Power on is set to 0, Vdd is usually cut, all the logic (DFF and RFF) is lost, except for the context that has been saved in the scratchpad memory of the WKUP power domain (always on). Varray can keep its active value (if needed by another memory array sharing the same Varray voltage rail in another power domain), be lowered (if all other memory arrays sharing the same Varray voltage rail are set to be in retention), or be cut (0 V) when the entire device is in off mode. The arrayon switch is open and the memory content is lost.

The retention state is useful for quickly switching to low-power idle mode without losing the context, and then quickly switching back to active state when necessary. In retention state, power consumption is less than in normal operating mode.

### 3.1.3.3 Voltage Domain

A voltage domain is a group of modules supplied by the same voltage regulator (embedded or external). The power consumption of this group can be controlled by regulating its voltage independently.

[Figure 3-7](#) shows the voltage domain.

**Figure 3-7. Generic Voltage Domain**

prcm-007

By partitioning the device into independent voltage domains, it is possible to assign different operating voltages to the different modules. The independent voltage control allows voltage scaling of device subsections to ensure that each module operates at the optimal operating voltage level based on the application performance requirements. When all modules in a voltage domain are inactive, the domain voltage can be lowered to reduce power consumption and then be switched back to normal operating voltage when a wake-up event is received.

### 3.1.4 Device Power-Management Architecture

The device architecture integrates the power-management architectural blocks for power-management support. It is composed of scalable/switchable voltage domains (their voltage can be controlled) and switchable power domains. [Figure 3-8](#) shows the general hierarchical architecture scheme of the voltage, power, and clock domains.

A clock domain is a subset of a power domain. This avoids unnecessary dependencies between power domains caused by clocks covering multiple power domains. Each clock in a power domain, with an independent gating control, is a separate clock domain.

**Figure 3-8. Voltage, Power, and Clock Domain Hierarchical Architecture**

prcm-008

Each power domain is supplied by one or more voltage domains that can be scaled down or switched off to save power. Internal memory and logic can be put in standby (retention) mode independently. In this state, memory is not operational, but the content is retained with minimized leakage. This feature lets power consumption be reduced when the device is in sleep mode while maintaining memory contents for fast context restore. The logic and memory standby feature is software-controllable.

The device supports a clock distribution and control architecture, which is described in the following sections.

### 3.1.4.1 Module Interface and Functional Clocks

The clocks delivered to the modules in the device are divided into two categories: interface clocks and functional clocks (see [Figure 3-9](#)).

**Figure 3-9. Functional and Interface Clocks**

Interface clocks have the following characteristics:

- They ensure proper communication between any module/subsystem and the interconnect.
- In most cases, they supply the module interface and registers.
- A typical module has one interface clock, but it can have several.
- They are synchronous across the entire device, because the interconnect fabric is fully synchronous.
- Interface clock management is done at the device level.
- From the standpoint of the PRCM module, an interface clock is distributed through the device interconnect and is identified with an \_ICLK suffix.

Functional clocks have the following characteristics:

- They supply the functional part of a module or a subsystem.
- Each module can have several functional clocks, or none. A module may or may not require its functional clocks to be active (nonidle).
- Several modules can share the same functional clock signals, but the branches of the clock tree are not balanced among the modules.
- From the PRCM module standpoint, a functional clock is directly distributed to the related modules through a dedicated clock tree. It is identified with an \_FCLK suffix.

---

**NOTE:** At the module level, the interface clocks are always fed by the interface clock outputs of the PRCM module. The functional clocks are fed by a PRCM functional clock output or a PRCM interface clock output. In the latter case, the functional and interface clocks of the module inherit capabilities (autoidle features) from the PRCM interface clock (see [Section 3.5.3, Clock Manager Functional Description](#)).

---

### 3.1.4.2 Autoidle Clock Control

The device supports an autoidle clock control scheme for the module interface clocks. With this control scheme, the PRCM module can automatically activate and deactivate the interface clock of any device module, depending on its operating mode. This scheme executes under hardware control and is transparent to the software. This scheme identifies two module types in the device: the target and the initiator modules, or subsystems.

---

**NOTE:** The functional clocks do not have the autoidle clock scheme, and the software must gate the functional clock of each module when it is not needed.

---

#### Initiator

An initiator can generate bus transactions (read, write, etc.) toward targets. It is considered active when it generates transactions. If it enters standby mode, it stops generating transactions. Because most initiators also support a target port for configuration, they are both targets and initiators. Some examples of initiators are processors, direct memory access (DMA), and memory management unit (MMU).

### Target

A target is a passive module that can process bus transactions (read/write to memory-mapped registers). It is considered active when its interface clocks and some or all of its functional clocks are available so it can accept incoming transactions. A target can be put in idle mode by the PRCM module, and in this mode, its interface clock can be gated at any time. An idle module can still receive its functional clocks and generate interrupts and DMA requests. It can also generate asynchronous wake-up requests, if it is wakeup-capable.

### Active, Idle, and Standby Modes

The PRCM module handles automatic clock control differently for initiator and target modules.

For the initiator module, the following hardware handshake scheme is employed:

1. The initiator, when switching from active to idle mode, signals its status to the PRCM module.
2. The PRCM module cuts off the interface clock to the initiator module.
3. When the initiator module must reactivate, it signals the PRCM module, which reactivates its functional and interface clocks.

For the target module, the following hardware handshake scheme is employed:

1. When the PRCM module confirms that the target module satisfies the idle conditions, it signals the target module.
2. The target module acknowledges the idle request of the PRCM module, depending on its idle mode internal settings (for details about idle mode settings, see the chapter in the technical reference manual for the corresponding device module):
  - If the module is set to smart-idle mode, it terminates its current operations, then acknowledges the idle request to the PRCM module.
  - If the module is set to force-idle mode, it acknowledges immediately, regardless of its state. Because pending transfers, interrupts, and DMA requests can be lost, special software care must be taken.
  - If the module is set to no-idle mode, it does not acknowledge the idle request. This forces the PRCM module to maintain the clock active.
3. The PRCM module cuts off the module clocks.
4. The target module can be awakened by the PRCM module when its wake-up conditions are satisfied (wake-up event). It activates the module clocks, and then signals the wakeup.
5. The target module acknowledges the wake-up request.
6. Some target modules can support wake-up capability. They can explicitly request the PRCM module to activate their clock.

This automatic clock control ensures reduced dynamic power consumption of the device without any associated software overhead.

#### 3.1.5 SmartReflex Voltage-Control Overview

SmartReflex™ is a power-management technique for controlling the operating voltage of a device to reduce its active power consumption.

With SmartReflex, the power-supply voltage is adapted to the silicon performance statically (adapted to the manufacturing process of a given device) or dynamically (adapted to the temperature-induced current performance of the device). A comparison of predefined performance points to real-time on-chip measured performance determines whether to raise or lower the power supply voltage.

SmartReflex achieves optimal performance/power trade-off for all devices across the technology process spectrum and across temperature variations.

**Figure 3-10** is a functional overview of the SmartReflex voltage-control architecture of the device connected to an external power integrated circuit (IC).

**Figure 3-10. SmartReflex Voltage-Control Functional Overview**



prcm-UC-001

SmartReflex voltage control consists of the following modules:

- SmartReflex
- Microprocessor unit (MPU) interrupt controller (INTC)
- Voltage processor
- Voltage controller
- Inter-integrated circuit ( $I^2C$ ) interface
- Switch mode power supply (SMPS)

The SmartReflex module senses input voltage (VDD) and generates an error value that identifies the difference between the desired voltage and the actual value of the SMPS. This error value is set in an internal register (for software read, if necessary) and is also passed to the voltage processor.

The voltage processor converts the error value to a voltage command that defines the change in the output voltage of the SMPS required to bring it to the desired voltage level.

The voltage command is sent to the voltage controller, which passes it to the power IC through the dedicated  $I^2C$  interface. The power IC then adjusts the output voltage of the SMPS according to the command.

In this way, the SmartReflex module dynamically adjusts the SMPS voltage to compensate for voltage variations.

The device supports two operational modes for SmartReflex voltage control:

- Manual (software-controlled)
- Automatic (hardware-controlled)

### 3.1.5.1 Manual SmartReflex Voltage Control

In manual voltage control, the SmartReflex module interrupts the MPU when the voltage level crosses the defined voltage limits (minimum/maximum). The MPU reads the error value and determines the new voltage command to be sent to the SMPS to return the voltage to within the limits. The new voltage command is sent to the voltage controller, which passes the command to the SMPS and acknowledges its reception.

In manual control, the voltage processor is bypassed.

### 3.1.5.2 Automatic SmartReflex Voltage Control

In automatic voltage control, the SmartReflex module interrupts the voltage processor module when the voltage level crosses the defined voltage limits (minimum/maximum). The voltage processor reads the error value and determines the new voltage command to be sent to the SMPS to return the voltage to within the limits. The new voltage command is sent to the voltage controller, which passes the command to the SMPS and acknowledges its reception.

In automatic mode, the software does not intervene in voltage control; the entire loop is handled by the hardware modules.

## 3.2 PRCM Overview

This section describes all modules and features in the high-tier device. To save power, ensure that power domains of unavailable features and modules are switched off and clocks are cut off.

### 3.2.1 Introduction

The power-management framework of the device significantly reduces dynamic power consumption and static leakage current to extend the life of the battery in the end product. This framework incorporates support for state-of-the-art power-management techniques. It ensures optimal device operation with significantly reduced power consumption. The PRCM module, which is the enhanced power-management subsystem of the device, is the central control module for the clock, reset, and power-management signals in the device.

The device supports the power-management techniques with the following features:

- Partitioning of the device into 16 voltage domains and 18 power domains
- Domain isolation that allows any combination of domain on/off states
- Clock tree with selective clock-gating conditions
- Hardware-controlled reset sequencing management
- Power, reset, and clock control hardware mechanism to manage sleep and wake-up dependencies of power domains
- Support for hardware-controlled autogating of module clocks
- Memory retention capability for preserving memory contents in low-power sleep mode
- Scalable voltage and frequency support for the processors, CORE, and peripherals for DVFS
- SmartReflex adaptive voltage scaling for real-time performance adjustments
- Support for low-power device off mode input/output (I/O) pad configuration for minimum power consumption when in off power state

The PRCM module interfaces with all the components of the device for power, clock, and reset management through power-control signals. It integrates enhanced features to let the device adapt energy consumption dynamically according to changing application and performance requirements. The innovative hardware architecture allows a substantial reduction in leakage current.

The PRCM module is composed of two main entities:

- Power reset manager (PRM): Handles power, reset, wake-up management, and system clock source control (oscillator)
- Clock manager (CM): Handles clock generation, distribution, and management

The PRCM module is fully configurable through its L4 interface port.

[Figure 3-11](#) is an overview of the PRCM module and its internal connections with a generic power domain.

Figure 3-11. PRCM Overview



### 3.2.2 PRCM Features

The PRCM module includes the following features:

- Managing 18 independent power domains
- Controlling two scalable and three memory-selectable voltage modes
- Handling idle/wake-up procedures
- Allowing software and partial hardware control
- Monitoring and handling wake-up events
- Controlling system clock/reset input sources
- Managing and distributing clocks and resets with high granularity
- Handling power-up sequences
- Debug and emulation features
- Controlling external supply voltage regulation through dedicated high-speed (HS) I<sup>2</sup>C interface
- CM implementation of RFFs to support DPS

### 3.3 PRCM Environment

The PRCM module receives the external reset, clock, and power signals. Figure 3-12 shows the interface of the PRCM module with external reset, clock, and power sources.

**Figure 3-12. PRCM Functional External Interface (Detailed View)**



**NOTE:** In the remainder of this chapter, "power IC" refers to a peripheral power source IC that is interfaced with the device. It receives power control commands (voltage scaling and power switching) from the device and provides the necessary voltages and reset signals.

The following sections describe the interfaces for external clock, reset, and power sources.

### 3.3.1 External Clock Signals

The device has three external clock inputs: low frequency (sys\_32k), high frequency (sys\_xtalin), and an optional clock (sys\_altclk). The device has two configurable clock outputs: sys\_clkout1 and sys\_clkout2. Figure 3-13 shows the external clock signals of the PRCM module. Table 3-2 lists the external clock signals, I/Os, and module reset values.

**Figure 3-13. External Clock Interface**



**Table 3-2. External Clock Signals**

| Signal      | I/O <sup>(1)</sup> | Description                                                                                                                                    | Module Reset Value     |
|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| sys_boot6   | I                  | Boot oscillator mode control                                                                                                                   | Unknown <sup>(2)</sup> |
| sys_32k     | I                  | 32-kHz clock input                                                                                                                             | Unknown <sup>(3)</sup> |
| sys_xtalout | O                  | Oscillator output                                                                                                                              | 0                      |
| sys_xtalin  | I                  | Main input clock. Crystal oscillator clock (only at 12, 13, 16.8, or 19.2 MHz) or CMOS digital clock (at 12, 13, 16.8, 19.2, 26, or 38.4 MHz). | Unknown                |
| sys_clkreq  | I/O                | Clock request to/ from device for system clock                                                                                                 | HiZ/1 <sup>(4)</sup>   |
| sys_clkout1 | O                  | Configurable output clock 1                                                                                                                    | 0                      |
| sys_altclk  | I                  | Additional selectable clock source                                                                                                             | Unknown <sup>(5)</sup> |
| sys_clkout2 | O                  | Configurable output clock 2                                                                                                                    | 0                      |

<sup>(1)</sup> I = Input; O = Output

<sup>(2)</sup> sys\_boot6 is either powered down or powered up

<sup>(3)</sup> Reset cannot be released without 32K stable and running

<sup>(4)</sup> sys\_clkreq depends on sys\_boot6

<sup>(5)</sup> sys\_altclk is not enabled by default

[Figure 3-14](#) shows the PRCM external clock sources.

**Figure 3-14. PRCM External Clock Sources**

Solution 1: Use of an external quartz



Solution 2: Use of an external square clock source



prcm-012

The system clock source can be either of the following:

- Internal oscillator with crystal connected between sys\_xtalin and sys\_xtalout
- CMOS digital clock that arrives at the sys\_xtalin pin

In the first option, the sys\_clkreq signal is used in input mode to control sys\_clkout1 and the internal clock oscillator. In the second option, the signal is used in output mode to request the external system clock.

An external pulldown or pullup tied on sys\_boot6 determines whether the internal oscillator is used or an external clock source is supplied, respectively.

#### CAUTION

Only one clock source option can be used at a time.

An additional clock input (sys\_altclk) provides a precise clock source for 54 MHz, 48 MHz, or other frequencies (for example, 59 MHz or 49.04 MHz for VDAC).

For more information about external clock signals, see [Section 3.5.3.5 , External Clock Controls](#).

### 3.3.2 External Reset Signals

The device supports two reset signals: power-on (sys\_nrespwron) and warm reset (sys\_nreswarm).

sys\_nrespwron is asserted at power up to reset the full logic in the device. sys\_nreswarm can be activated at any time by an external device or an external reset push-button action (see [Figure 3-12](#)) to cause a global warm reset event.

Because sys\_nreswarm is bidirectional, it can also drive a reset of external devices. Any global warm reset source (for example, a push-button) causes sys\_nreswarm to be driven out and maintained for a limited length of time at the boundary of the device. In this way, the device and its related peripherals are reset together.

The sys\_nrespwron assertion also causes assertion of sys\_nreswarm.

[Figure 3-15](#) shows the external reset signals. [Table 3-3](#) lists the external reset signals, I/Os, and module reset values.

**Figure 3-15. External Reset Signals**

prcm-014

**Table 3-3. External Reset Signals**

| Signal        | I/O <sup>(1)</sup> | Description     | Module Reset Value |
|---------------|--------------------|-----------------|--------------------|
| sys_nreswarm  | I/O                | Warm-boot reset | 1                  |
| sys_nrespwron | I                  | Power-on reset  | Unknown            |

<sup>(1)</sup> I = Input; O = Output

**NOTE:** sys\_nrespwron must be kept asserted until the voltage and power domains are ramped up which depends on the power IC used. At the PRCM boundary, a sys\_nrespwron pulse of 1 ns resets the device.

sys\_nreswarm assertion is asynchronously sampled in the PRM. It is kept internally asserted.

### 3.3.3 External Power Signals

The power control signals let the PRCM module control the device voltage levels. The voltage level of the scalable voltage sources in the external power IC can be scaled by sending commands to the power IC through this interface. The PRCM module can also command the power IC to switch the device voltages off when the device is in off mode and activate them when it wakes up.

Figure 3-16 shows the power control interface for the external power IC. Table 3-4 lists the signals, I/Os, and module reset values for the external power IC.

**Figure 3-16. Power Control Interface for External Power IC**

prcm-015

**Table 3-4. Power Control Interface**

| Signal               | I/O <sup>(1)</sup> | Description                                                                                                                                                     | Module Reset Value |
|----------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| sys_nvmode1/i2c4_scl | O                  | Commands the external power IC for control of VDD1 and VDD2 voltages.<br>Shared by the VMODE interface and the SmartReflex dedicated I <sup>2</sup> C interface | 0x1                |
| sys_nvmode2/i2c4_sda | O                  | Commands the external power IC for control of VDD1 and VDD2 voltages.<br>Shared by the VMODE interface and the SmartReflex dedicated I <sup>2</sup> C interface | 0x1                |
| sys_off_mode         | O                  | Requests the external power IC to switch the device voltage level according to the device power status                                                          | 0x0                |

<sup>(1)</sup> I = Input; O = Output

### 3.4 PRCM Integration

The PRCM internal registers can be accessed for configuration and controlled through the WKUP L4 interconnect. In addition to the L4 interconnect, the PRCM internal module interface contains the following:

- A set of signals for idle/wake-up control for each module
- Clocks and reset signals
- Power control signals (switches and memories) to the power domains
- Interrupts to the MPU subsystem and IVA2.2 subsystem INTCs
- Voltage error commands from the SmartReflex modules
- Digital phase-locked loop (DPLL) control commands for recalibration and bypass
- System clock oscillator control for device-level sleep/wake-up transitions

Figure 3-17 shows details of the control interface to a generic power domain.

**Figure 3-17. PRCM Integration**


To significantly reduce leakage in sleep modes (SLM strategy) and to optimize active power consumption (DPS strategy), the device is segmented into 18 power domains (see [Figure 3-18](#)).

**Figure 3-18. Device Power Domains**

prcm-017

Each power domain is fed through an independent switch controlled by the PRM module. In this way, depending on the application scenario, unused parts (domains) can be switched off or put in retention state while others remain active.

### 3.4.1 Power-Management Scheme, Reset, and Interrupt Requests

#### 3.4.1.1 Power Domain

The PRCM module is in two power domains (see [Table 3-5](#)).

**Table 3-5. PRCM Power Domains**

| PRCM Subsystem Modules | Power Domain |
|------------------------|--------------|
| PRM                    | WKUP         |
| CM                     | CORE         |

The PRM module is in the WKUP power domain, which is continuously active. It is composed of the logic that must be permanently supplied to manage domain power-state transitions and detect wake-up events.

The CM module is in the CORE power domain, which can be activated and deactivated according to the requirements of the executing applications.

#### 3.4.1.2 Resets

The PRM and CM modules are reset by independent reset signals (see [Table 3-6](#)).

**Table 3-6. PRCM Reset Signals**

| PRCM Subsystem | Reset Signal    |
|----------------|-----------------|
| PRM            | PRM_RSTPWRON    |
| CM             | CM_RSTPWRON_RET |

The PRM module is reset by the cold reset signal PRM\_RSTPWRON. The CM module is reset by assertion of the CM\_RSTPWRON\_RET signal.

The CM logic is reset on:

- Any global cold reset
- A CORE power domain transition from off to on

The PRM logic is reset on any global cold reset.

CM and PRM registers that are sensitive to a warm reset are also reset when a global warm reset occurs. However, the CM and PRM logic is not reset.

**NOTE:** At global cold reset:

- Only the device finite state-machine (FSM) in the PRM operates on the 32-kHz clock, and it is released from reset on the release of the global reset.
- PRM logic operates on the system clock and is released from reset on release of the reset PRM\_RSTPWRON.

[Figure 3-19](#) shows the PRCM reset signals.

**Figure 3-19. PRCM Reset Signals**

### 3.4.1.3 Interrupt Requests

The PRCM module can generate two interrupts:

- PRCM\_MPU\_IRQ: Mapped to the MPU INTC module (M\_IRQ\_11 interrupt line)
- PRCM\_IVA\_IRQ: Mapped to the IVA2.2 WUGEN module (IVA2\_IRQ[12] interrupt line)

## 3.5 PRCM Functional Description

### 3.5.1 PRCM Reset Manager Functional Description

#### 3.5.1.1 Overview

The PRCM module manages the reset of all modules in the device. Resets are distributed across the 18 independent power domains (including DPLLs and SmartReflex modules).

In each power domain, one or more reset domains are defined. A reset domain is defined by a unique reset signal that originates from the reset manager and is connected to one or more modules of the device. All the connected modules of the reset domain are reset simultaneously when the reset signal is asserted. Independent control of these reset domains allows sequencing the release of resets and ensures a safe reset of the entire power domain.

Figure 3-20 is an overview of the reset manager interface with a generic power domain in the device.

**Figure 3-20. Reset Manager Interface With Generic Power Domain**



Resets can be generated by hardware sources or software control. For a module that can be reset by software control, a software-reset bit is implemented in its module\_name\_SYSConfig configuration register. Software reset has the same effect on the module logic as a hardware reset.

Special reset control is available to reset specific reset domains when the device operates under emulation control.

**NOTE:** All reset assertion is asynchronous, and all reset signals are active low, except for the DPLL reset signals, which are active high.

#### 3.5.1.2 General Characteristics of Reset Signals

Reset signals can be categorized based on three criteria:

- Scope
- Occurrence
- Source type

### 3.5.1.2.1 Scope

A reset signal can be categorized according to its scope (the area of the device affected by that reset):

- Global reset: Affects the entire device; all modules are reset. Generally, occurs when the device powers up or an abnormal operation is detected (the eFuse bad device is detected, etc.).
- Local reset: Affects one power or reset domain. Generally, when a power domain transitions from off mode to active mode, or when a software-reset control bit for a domain is set, only the group of modules within that domain is affected.

### 3.5.1.2.2 Occurrence

A reset signal can be categorized depending on when the reset occurs:

- Cold reset: Occurs only on device power up or in certain emulation modes. The cold reset is a global reset that affects every module in the device. It usually corresponds to the initial power-on reset.
- Warm reset: Occurs when the device is in normal operating state. The warm reset is also a global reset, but it does not affect all the modules in the device. Usually, the device does not require a complete reboot on a warm reset. Several reset sources, such as the global software reset and the watchdog reset, are warm resets.

Modules that behave differently in cold reset and warm reset have two reset signals: RST and PWRON\_RST. These reset signals reconstruct warm reset and cold reset in modules that require them.

For a global warm reset, the PRCM module performs the following sequence:

1. Applies a warm reset on all the modules, including modules built with RFFs.
2. Applies a warm reset on the external modem interface.
3. Drives the sys\_nreswarm reset output low and holds it for a specified length of time (programmed in the PRCM.PRM\_RSTTIME[7:0] RSTTIME1 bit field).
4. All ongoing transactions on the voltage control I<sup>2</sup>C interface (I2C4 module) are aborted, and the external power IC is expected to return to nominal voltage values on receiving a sys\_nreswarm reset.
5. All power domains that are in off power mode are switched to on power mode.

A global warm reset does not apply to the following modules of the device:

- SDRC
- System control module (SCM) (I/O control)
- Part of PRM and CM registers (see note below)
- 32-kHz synchronization timer
- DPLL3 (see [Section 3.5.1.9.2](#))
- Emulation modules
- eFuse farm

---

**NOTE:** For information about the PRCM registers affected by the global warm reset, see the register mapping summary tables in [Section 3.7, PRCM Register Manual](#).

---

### 3.5.1.2.3 Source Type

A reset can be categorized depending on whether it is software-controlled or hardware-triggered:

- Software reset: Triggered by setting a bit in a configuration register of the PRCM module
- Hardware reset: Triggered by a signal from a hardware module inside or outside the PRCM module

### 3.5.1.3 Reset Sources

Figure 3-21 is an overview of the reset sources.

**Figure 3-21. Reset Sources Overview**



\*The green region in the figure represents the boundary of the PRCM.

prcm-020

#### 3.5.1.3.1 Global Reset Sources

Table 3-7 lists the global reset sources of the device. The global reset source signals received by the reset manager trigger the reset of all the device modules. For all hardware reset signals, the source of the reset is identified; for the software reset signals, the reset triggering bit is identified.

**Table 3-7. Global Reset Sources**

| Type <sup>(1)</sup> | Name          | Source/Control | Description                             |
|---------------------|---------------|----------------|-----------------------------------------|
| H/C                 | sys_nrespwron | Input pin      | The entire device is reset on power up. |

<sup>(1)</sup> H = Hardware reset, S = Software reset, C = Cold reset, W = Warm reset

**Table 3-7. Global Reset Sources (continued)**

| Type <sup>(1)</sup> | Name           | Source/Control                                 | Description                                                                                                                              |
|---------------------|----------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| H/C                 | BAD_DEVICE_RST | PRCM                                           | Asserted when during the power-up sequence the device is identified as bad, after reading eFuses                                         |
| H/W                 | sys_nreswarm   | Bidirectional pin                              | External hardware warm reset                                                                                                             |
| H/W                 | MPU_WD_RST     | WDTIMER2                                       | MPU watchdog timer overflow reset                                                                                                        |
| S/W                 | GLOBAL_SW_RST  | PRCM. <a href="#">PRM_RSTCTRL[1]</a> RST_GS    | Global software reset                                                                                                                    |
| H/W                 | VDD1_VM_RST    | PRCM                                           | Asserted by the voltage manager FSMs when no response from the power IC is received during wake-up transition from retention or off mode |
| H/W                 | VDD2_VM_RST    | PRCM                                           |                                                                                                                                          |
| S/W                 | DPLL3_SW_RST   | PRCM. <a href="#">PRM_RSTCTRL[2]</a> RST_DPLL3 | Local cold reset for DPLL3 and a global cold reset to the device                                                                         |

### 3.5.1.3.2 Local Reset Sources

Table 3-8 lists the local reset sources of the device. A local reset source signal received by the reset manager resets only some of the device modules.

**Table 3-8. Local Reset Sources**

| Type <sup>(1)</sup> | Name             | Source/Control                                        | Description                                                                          |
|---------------------|------------------|-------------------------------------------------------|--------------------------------------------------------------------------------------|
| H/C                 | CORE_DOM_RET_RST | PRCM                                                  | Asserted only for a power domain state transition from off to active state           |
| H/C                 | USB_DOM_RET_RST  | PRCM                                                  |                                                                                      |
| H/C                 | PER_DOM_RET_RST  | PRCM                                                  |                                                                                      |
| H/C                 | MPU_DOM_RST      | PRCM                                                  | Asserted for any power domain transition from off or retention state to active state |
| H/C                 | IVA2_DOM_RST     | PRCM                                                  |                                                                                      |
| H/C                 | NEON_DOM_RST     | PRCM                                                  |                                                                                      |
| H/C                 | SGX_DOM_RST      | PRCM                                                  |                                                                                      |
| H/C                 | CORE_DOM_RST     | PRCM                                                  |                                                                                      |
| H/C                 | PER_DOM_RST      | PRCM                                                  |                                                                                      |
| H/C                 | CAM_DOM_RST      | PRCM                                                  |                                                                                      |
| H/C                 | DSS_DOM_RST      | PRCM                                                  |                                                                                      |
| H/C                 | DPLL1_DOM_RST    | PRCM                                                  |                                                                                      |
| H/C                 | DPLL2_DOM_RST    | PRCM                                                  |                                                                                      |
| H/C                 | DPLL3_DOM_RST    | PRCM                                                  |                                                                                      |
| H/C                 | DPLL4_DOM_RST    | PRCM                                                  |                                                                                      |
| H/C                 | DPLL5_DOM_RST    | PRCM                                                  |                                                                                      |
| S/W                 | IVA2_SW_RST1     | PRCM. <a href="#">RM_RSTCTRL_IVA2[0]</a><br>RST1_IVA2 | IVA2.2: DSP reset control                                                            |
| S/W                 | IVA2_SW_RST2     | PRCM. <a href="#">RM_RSTCTRL_IVA2[1]</a><br>RST2_IVA2 | IVA2.2: MMU reset control and video sequencer hardware accelerator reset control     |
| S/W                 | IVA2_SW_RST3     | PRCM. <a href="#">RM_RSTCTRL_IVA2[2]</a><br>RST3_IVA2 | Video sequencer reset control                                                        |

<sup>(1)</sup> H = Hardware reset, S = Software reset, C = Cold reset, W = Warm reset

---

**NOTE:**

- For power domains with domain name\_DOM\_RST and domain name\_DOM\_RET\_RST, the reset sources are asserted together when the domain transitions from off to on power state, whereas only domain name\_DOM\_RET\_RST is asserted on a global or local warm reset.
  - Because the modem reset signals are not supported in the device stand-alone configuration, they are not discussed in this section.
- 

### 3.5.1.4 Reset Distribution

Each power domain can contain one power-on reset (RSTPWRON) and one or more reset (RST) signals. These signals behave as follows:

- On any global or local cold reset, RST and RSTPWRON are asserted.
- On any global or local warm reset, only RST is asserted.

The CORE power domain receives two additional retention logic reset signals: retention reset (RST\_RET) and power-on retention reset (RSTPWRON\_RET). These signals behave as follows:

- On any global cold reset or wakeup from off state to active state, RST\_RET and RSTPWRON\_RET are asserted.
- On any global warm reset, only RST\_RET is asserted.
- On wakeup from retention state, these signals are not asserted.

The IVA2 power domain outputs the IVA2\_RST\_DONE signal, which handles the synchronous reset scheme of the IVA2.2 subsystem.

Figure 3-22 shows the reset distribution among the 18 power domains.

**Figure 3-22. Reset Destination Overview**

\* The green region in the figure represents the boundary of the PRCM

prcm-021

### 3.5.1.5 Power Domain Reset Descriptions

#### 3.5.1.5.1 MPU Power Domain

The MPU power domain has two reset input signals and one reset output signal (see [Table 3-9](#)).

**Table 3-9. MPU Power Domain Reset Signal**

| Name    | I/O <sup>(1)</sup> | Source/Destination <sup>(2)</sup> | Reset Domain                                                                      |
|---------|--------------------|-----------------------------------|-----------------------------------------------------------------------------------|
| MPU_RST | I                  | PRM                               | Resets the MPU processor core and the asynchronous bridge in the MPU power domain |

<sup>(1)</sup> I = Input; O = Output

<sup>(2)</sup> Source for an input signal and destination for an output signal

### **3.5.1.5.2 NEON Power Domain**

The NEON power domain has one reset input signal (see [Table 3-10](#)).

**Table 3-10. NEON Power Domain Reset Signal**

| Name     | I/O <sup>(1)</sup> | Source | Reset Domain                |
|----------|--------------------|--------|-----------------------------|
| NEON_RST | I                  | PRM    | Resets the NEON coprocessor |

<sup>(1)</sup> I = Input; O = Output

### **3.5.1.5.3 IVA2 Power Domain**

The IVA2 power domain has four inputs and one output reset signal (see [Table 3-11](#)).

**Table 3-11. IVA2 Power Domain Reset Signals**

| Name          | I/O <sup>(1)</sup> | Source/Destination <sup>(2)</sup> | Reset Domain                                                                                                             |
|---------------|--------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| IVA2_RST1     | I                  | PRM                               | Resets the IVA2.2 DSP and part of the two asynchronous bridges in the IVA2 power domain                                  |
| IVA2_RST2     | I                  | PRM                               | Resets the IVA2.2 MMU                                                                                                    |
| IVA2_RST3     | I                  | PRM                               | Resets the video sequencer module                                                                                        |
| IVA2_RSTPWRON | I                  | PRM                               | Performs a power-on reset on the IVA2.2 subsystem. Active on a cold reset only.                                          |
| IVA2_RSTDONE  | O                  | PRM                               | Release condition of the IVA_RST1 and RST2. Generated by the IVA2.2 subsystem at the end of the initialization sequence. |

<sup>(1)</sup> I = Input; O = Output

<sup>(2)</sup> Source for an input signal and destination for an output signal

### **3.5.1.5.4 CORE Power Domain**

The CORE power domain has eight inputs and one output reset signal (see [Table 3-12](#)).

**Table 3-12. CORE Power Domain Reset Signals**

| Name              | I/O <sup>(1)</sup> | Source/Destination <sup>(2)</sup> | Reset Domain                                                                                                                                                                                                                   |
|-------------------|--------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CORE_RST          | I                  | PRM                               | Resets parts of the three asynchronous bridges, MPU INTC, IVA2.2 WUGEN, interconnects, ICR, modem INTC, SAD2D, mailboxes, GPMC, OCM, UART[1,2], HDQ, HS USB, I2C[1..3], McBSP 1 and 5, McSPI [1..3], MMC[1..3], GPTIMER[10,11] |
| CORE_RST_RET      | I                  | PRM                               | Resets part of the SDRC, SDMA, SMS, MPU INTC, and IVA2 WUGEN                                                                                                                                                                   |
| CORE_RSTPWRON_RET | I                  | PRM                               | Resets part of the SDRC and SCM                                                                                                                                                                                                |
| CM_RSTPWRON_RET   | I                  | PRM                               | Resets the clock manager                                                                                                                                                                                                       |
| USBTLL_RST        | I                  | PRM                               | Resets the USB TLL asynchronously                                                                                                                                                                                              |

<sup>(1)</sup> I = Input; O = Output

<sup>(2)</sup> Source for an input signal and destination for an output signal

The CM logic is reset on:

- Any global cold reset
- A CORE power domain transition from off to on

Because the CM logic is not reset in this case, CM registers that are sensitive to a warm reset must also be reset synchronously with the L4 clock when a global warm reset occurs.

### **3.5.1.5.5 DSS Power Domain**

The DSS power domain has one reset input signal (see [Table 3-13](#)).

**Table 3-13. DSS Power Domain Reset Signal**

| Name    | I/O <sup>(1)</sup> | Source | Reset Domain                        |
|---------|--------------------|--------|-------------------------------------|
| DSS_RST | I                  | PRM    | Resets the entire display subsystem |

<sup>(1)</sup> I = Input; O = Output

### 3.5.1.5.6 CAM Power Domain

The CAM power domain has one reset input signal (see [Table 3-14](#)).

**Table 3-14. CAM Power Domain Reset Signal**

| Name    | I/O <sup>(1)</sup> | Source | Reset Domain                       |
|---------|--------------------|--------|------------------------------------|
| CAM_RST | I                  | PRM    | Resets the entire camera subsystem |

<sup>(1)</sup> I = Input; O = Output

### 3.5.1.5.7 USBHOST Power Domain

The USBHOST power domain has one reset input signal (see [Table 3-15](#)).

**Table 3-15. USBHOST Power Domain Reset Signal**

| Name        | I/O <sup>(1)</sup> | Source | Reset Domain                            |
|-------------|--------------------|--------|-----------------------------------------|
| USBHOST_RST | I                  | PRM    | Resets the entire HS USB host subsystem |

<sup>(1)</sup> I = Input; O = Output

### 3.5.1.5.8 SGX Power Domain

The SGX power domain has one reset input signal (see [Table 3-16](#)).

**Table 3-16. SGX Power Domain Reset Signal**

| Name    | I/O <sup>(1)</sup> | Source | Reset Domain                    |
|---------|--------------------|--------|---------------------------------|
| SGX_RST | I                  | PRM    | Resets the entire SGX subsystem |

<sup>(1)</sup> I = Input, O = Output

### 3.5.1.5.9 WKUP Power Domain

The WKUP power domain has three reset input signals and two reset output signals (see [Table 3-17](#)).

**Table 3-17. WKUP Power Domain Reset Signals**

| Name          | I/O <sup>(1)</sup> | Source/Destination <sup>(2)</sup> | Reset Domain                                      |
|---------------|--------------------|-----------------------------------|---------------------------------------------------|
| WKUP_RST      | I                  | PRM                               | Resets the GPTIMER1, WDTIMER2, GPIO 1             |
| WKUP_RSTPWRON | I                  | PRM                               | Resets the wake-up control module                 |
| MPU_WD_RST    | O                  | PRM                               | Global warm reset for PRM. Generated by WDTIMER2. |

<sup>(1)</sup> I = Input; O = Output

<sup>(2)</sup> Source for an input signal and destination for an output signal

The PRM logic is reset on any global cold reset. Because the PRM logic is not reset in this case, PRM registers that are sensitive to a warm reset must also be reset synchronously with the system clock when a global warm reset occurs.

### 3.5.1.5.10 PER Power Domain

The PER power domain has two reset input signals (see [Table 3-18](#)).

**Table 3-18. PER Power Domain Reset Signal**

| Name        | I/O <sup>(1)</sup> | Source | Reset Domain                                                            |
|-------------|--------------------|--------|-------------------------------------------------------------------------|
| PER_RST     | I                  | PRCM   | Resets the UART[3, 4], McBSP[2,3,4], GPTIMER[2,...,9], WDTIMER3 modules |
| PER_RST_RET | I                  | PRCM   | Resets the GPIO [2,..,6] modules                                        |

<sup>(1)</sup> I = Input; O = Output

### 3.5.1.5.11 SmartReflex Power Domain

The SmartReflex power domain has one reset input signal (see [Table 3-19](#)).

**Table 3-19. SmartReflex Power Domain Reset Signal**

| Name   | I/O <sup>(1)</sup> | Source | Reset Domain                   |
|--------|--------------------|--------|--------------------------------|
| SR_RST | I                  | PRCM   | Resets the SR1 and SR2 modules |

<sup>(1)</sup> I = Input; O = Output

### 3.5.1.5.12 DPLL Power Domains

The DPLL power domains for DPLL1, DPLL2, DPLL3, DPLL4 and DPLL5 each have one reset input signal.

**Table 3-20. DPLL Power Domain Reset Signals**

| Name           | I/O <sup>(1)</sup> | Source | Reset Domain            |
|----------------|--------------------|--------|-------------------------|
| DPLL1_RSTPWRON | I                  | PRCM   | Resets the DPLL1 module |
| DPLL2_RSTPWRON | I                  | PRCM   | Resets the DPLL2 module |
| DPLL3_RSTPWRON | I                  | PRCM   | Resets the DPLL3 module |
| DPLL4_RSTPWRON | I                  | PRCM   | Resets the DPLL4 module |
| DPLL5_RSTPWRON | I                  | PRCM   | Resets the DPLL5 module |

<sup>(1)</sup> I = Input; O = Output

They are asserted for any type of global cold reset.

### 3.5.1.5.13 EFUSE Power Domain

The EFUSE power domain has one reset input signal (see [Table 3-21](#)).

**Table 3-21. EFUSE Power Domain Reset Signal**

| Name           | I/O <sup>(1)</sup> | Source | Reset Domain                |
|----------------|--------------------|--------|-----------------------------|
| EFUSE_RSTPWRON | I                  | PRCM   | Resets the eFuse controller |

<sup>(1)</sup> I = Input; O = Output

This signal is asserted for any type of global cold reset and when the device wakes up from off mode.

### 3.5.1.5.14 BANDGAP Logic

The BANDGAP logic has one reset input signal (see [Table 3-22](#)).

**Table 3-22. BANDGAP Logic Reset Signal**

| Name             | I/O <sup>(1)</sup> | Source | Reset Domain             |
|------------------|--------------------|--------|--------------------------|
| BANDGAP_RSTPWRON | I                  | PRCM   | Resets the BANDGAP logic |

<sup>(1)</sup> I = Input; O = Output

This signal is asserted for any type of global cold reset and when the device wakes up from off mode.

### 3.5.1.5.15 External Warm Reset Assertion

Figure 3-23 shows the external warm reset interface.

**Figure 3-23. External Warm Reset Interface**



prcm-022

Any global reset source (internal or external) causes `sys_nreswarm_out` to be driven and maintained at the boundary of the device for at least the amount of time configured in the PRCM.[PRM\\_RSTTIME\[7:0\]](#) RSTTIME1 bit field. This ensures that the device and its related peripherals are reset together.

**NOTE:** Because the system warm-reset output is implemented on a bidirectional pad, any input pulse on `sys_nreswarm` causes a global warm reset.

### 3.5.1.6 Reset Logging

A reset of the device is logged in two ways. First, dedicated registers in the PRCM module (the RM\_RSTST\_power domain and [PRM\\_RSTST](#) registers) log the reset source. Second, the SCM logs the device reset activity in dedicated registers.

#### 3.5.1.6.1 PRCM Reset Logging Mechanism

The reset status registers (RM\_RSTST\_power domain and [PRM\\_RSTST](#)) are reset asynchronously on assertion of a global cold reset. However, a reset status bit is always logged when the reset is released to the domain.

For this reason, after the assertion of a global cold reset, the reset status register is cleared to 0. When the domain reset is released, the register bit to log the global cold reset (the RM\_RSTST\_power domain [0] GLOBALCOLD\_RST bit) is updated to 1. For the same reason, the reset status register of domains released from reset by software is updated only when software releases the domain reset.

The assertion of a global cold reset prevents logging any other source of reset until after the release of the domain reset. This is valid in the following situations:

- A source of reset other than global cold reset is asserted before, during, or after the active period of a global cold source of reset and before the release of the domain reset signal.
- A source of reset other than global cold reset was asserted and then released, but a global cold reset source was asserted before the release of the domain reset signal.

#### 3.5.1.6.2 SCM Reset Logging

The PRM exports reset the activity status signals to the SCM. The SCM uses these signals to log a reset status in the SCM.CONTROL\_SEC\_STATUS register. The reset activity status signal is asserted high when any source of reset to the power domain is active.

It also provides reset status for the following global reset signals:

- Global cold reset

- Global warm reset

There is one reset activity status signal for each of the following power domains:

- CAM
- CORE
- DSS
- EMU
- SGX
- IVA2
- MPU
- NEON
- PER
- USBHOST

These signals are asserted high on assertion of any source of reset on the domain and logged. For information about the SCM, see [Chapter 13, System Control Module](#).

### 3.5.1.7 Reset Management Overview

Reset management in the device is a 2-layered structure composed of multiple instances of the reset manager. In the first layer, a top-level reset manager, called the device reset manager, handles all sources of global reset (cold and warm). It provides reset managers for the second layer, called local reset managers, and the global reset and global power-on reset signals.

Each power domain has a minimum of one local reset manager. The local reset manager also receives resets, such as the software reset and domain power transition reset, from the local reset source for the power domain.

[Figure 3-24](#) through [Figure 3-27](#) provide an overview of reset management in the device. They do not provide reset sequencing between the reset managers.

---

**NOTE:** The power domain must be ready (the domain clocks must be active) before its reset is released.

---

**Figure 3-24. Device Reset Manager Overview**

prcm-023

**Figure 3-25. Power Domain Reset Management: Part 1**


prcm-024

**Figure 3-26. Power Domain Reset Management: Part 2**

prcm-025

**Figure 3-27. Power Domain Reset Management: Part 3**


### 3.5.1.8 Reset Summary

Table 3-23 and Table 3-24 summarize the sources of global and local resets and their actions on the reset signals.

**Table 3-23. Global Reset Summary<sup>(1)</sup>**

| Domain Resets |                   | Reset Sources   |              |                  |            |               |             |             |
|---------------|-------------------|-----------------|--------------|------------------|------------|---------------|-------------|-------------|
| Power Domain  | Signal            | Cold Reset      |              | Warm Reset       |            |               |             |             |
|               |                   | sys_nres_pweron | DPLL3_SW_RST | sys_nres_warm_in | MPU_WD_RST | GLOBAL_SW_RST | VDD1_VM_RST | VDD2_VM_RST |
| MPU           | MPU_RST           |                 |              |                  |            |               |             |             |
| NEON          | NEON_RST          |                 |              |                  |            |               |             |             |
| IVA2          | IVA2_RST1         |                 |              |                  |            |               |             |             |
|               | IVA2_RST2         |                 |              |                  |            |               |             |             |
|               | IVA2_RST3         |                 |              |                  |            |               |             |             |
|               | IVA2_RSTPWRON     |                 |              |                  |            |               |             |             |
| SGX           | SGX_RST           |                 |              |                  |            |               |             |             |
| CORE          | CORE_RST          |                 |              |                  |            |               |             |             |
|               | CORE_RSTPWRON     |                 |              |                  |            |               |             |             |
|               | CORE_RST_RET      |                 |              |                  |            |               |             |             |
|               | CORE_RSTPWRON_RET |                 |              |                  |            |               |             |             |
|               | CM_RSTPWRON_RET   |                 |              |                  |            |               |             |             |
|               | USBTLL_RST        |                 |              |                  |            |               |             |             |
| WKUP          | WKUP_RST          |                 |              |                  |            |               |             |             |
|               | SYNCT_RST         |                 |              |                  |            |               |             |             |
| PER           | PER_RST           |                 |              |                  |            |               |             |             |
|               | PER_RST_RET       |                 |              |                  |            |               |             |             |
| DSS           | DSS_RST           |                 |              |                  |            |               |             |             |
| CAM           | CAM_RST           |                 |              |                  |            |               |             |             |
| USBHOST       | USBHOST_RST       |                 |              |                  |            |               |             |             |
| DPLL1         | DPLL1_RSTPWRON    |                 |              |                  |            |               |             |             |
| DPLL2         | DPLL2_RSTPWRON    |                 |              |                  |            |               |             |             |
| DPLL3         | DPLL3_RSTPWRON    |                 |              |                  |            |               |             |             |
| DPLL4         | DPLL4_RSTPWRON    |                 |              |                  |            |               |             |             |
| DPLL5         | DPLL5_RSTPWRON    |                 |              |                  |            |               |             |             |
| SR            | SR_RST            |                 |              |                  |            |               |             |             |
| EFUSE         | EFUSE_RSTPWRON    |                 |              |                  |            |               |             |             |

<sup>(1)</sup> The shaded blocks identify the power domain reset signals triggered as a result of the reset source signal (at the head of the column).

**Table 3-23. Global Reset Summary<sup>(1)</sup> (continued)**

| Domain Resets       |                  | Reset Sources   |              |                  |            |               |             |             |
|---------------------|------------------|-----------------|--------------|------------------|------------|---------------|-------------|-------------|
| Power Domain        | Signal           | Cold Reset      |              | Warm Reset       |            |               |             |             |
|                     |                  | sys_nres_pweron | DPLL3_SW_RST | sys_nres_warm_in | MPU_WD_RST | GLOBAL_SW_RST | VDD1_VM_RST | VDD2_VM_RST |
| BANDGAP             | BANDGAP_RSTPWRON |                 |              |                  |            |               |             |             |
| Device pad (output) | sys_nreswarm_out |                 |              |                  |            |               |             |             |

**Table 3-24. Local Reset Summary<sup>(1)</sup>**

| Domain Resets |                   | Reset Sources    |                 |              |                  |              |              |              |
|---------------|-------------------|------------------|-----------------|--------------|------------------|--------------|--------------|--------------|
| Power Domain  | Signal            | Cold Reset       |                 |              |                  | Warm Reset   |              |              |
|               |                   | CORE_DOM_RET_RST | PER_DOM_RET_RST | DPLL3_SW_RST | BAD_DEVICE_RESET | IVA2_SW_RST1 | IVA2_SW_RST2 | IVA2_SW_RST3 |
| MPU           | MPU_RST           |                  |                 |              |                  |              |              |              |
| NEON          | NEON_RST          |                  |                 |              |                  |              |              |              |
| IVA2          | IVA2_RST1         |                  |                 |              |                  |              |              |              |
|               | IVA2_RST2         |                  |                 |              |                  |              |              |              |
|               | IVA2_RST3         |                  |                 |              |                  |              |              |              |
|               | IVA2_RSTPWRON     |                  |                 |              |                  |              |              |              |
| SGX           | SGX_RST           |                  |                 |              |                  |              |              |              |
| CORE          | CORE_RST          |                  |                 |              |                  |              |              |              |
|               | CORE_RST_RET      |                  |                 |              |                  |              |              |              |
|               | CORE_RSTPWRON_RET |                  |                 |              |                  |              |              |              |
|               | CM_RSTPWRON_RET   |                  |                 |              |                  |              |              |              |
|               | USBTLL_RST        |                  |                 |              |                  |              |              |              |
| WKUP          | WKUP_RST          |                  |                 |              |                  |              |              |              |
|               | SYNCT_RST         |                  |                 |              |                  |              |              |              |
| PER           | PER_RST           |                  |                 |              |                  |              |              |              |
|               | PER_RST_RET       |                  |                 |              |                  |              |              |              |
| DSS           | DSS_RST           |                  |                 |              |                  |              |              |              |
| CAM           | CAM_RST           |                  |                 |              |                  |              |              |              |
| USBHOST       | USBHOST_RST       |                  |                 |              |                  |              |              |              |
| DPLL1         | DPLL1_RSTPWRON    |                  |                 |              |                  |              |              |              |
| DPLL2         | DPLL2_RSTPWRON    |                  |                 |              |                  |              |              |              |

<sup>(1)</sup> The shaded blocks identify the power domain reset signals triggered as a result of the reset source signal (at the head of the column).

**Table 3-24. Local Reset Summary<sup>(1)</sup> (continued)**

| Domain Resets       |                  | Reset Sources    |                 |              |                  |              |              |              |
|---------------------|------------------|------------------|-----------------|--------------|------------------|--------------|--------------|--------------|
| Power Domain        | Signal           | Cold Reset       |                 |              |                  | Warm Reset   |              |              |
|                     |                  | CORE_DOM_RET_RST | PER_DOM_RET_RST | DPLL3_SW_RST | BAD_DEVICE_RESET | IVA2_SW_RST1 | IVA2_SW_RST2 | IVA2_SW_RST3 |
| DPLL3               | DPLL3_RSTPWRON   |                  |                 |              |                  |              |              |              |
| DPLL4               | DPLL4_RSTPWRON   |                  |                 |              |                  |              |              |              |
| DPLL5               | DPLL5_RSTPWRON   |                  |                 |              |                  |              |              |              |
| SR                  | SR_RST           |                  |                 |              |                  |              |              |              |
| EFUSE               | EFUSE_RSTPWRON   |                  |                 |              |                  |              |              |              |
| BANDGAP             | BANDGAP_RSTPWRON |                  |                 |              |                  |              |              |              |
| Device pad (output) | sys_nreswarm_out |                  |                 |              |                  |              |              |              |

### 3.5.1.9 Reset Sequences

#### 3.5.1.9.1 Power-Up Sequence

Figure 3-28 shows the power-up sequence.

**Figure 3-28. Power-Up Sequence**



prcm-096

The power-up sequence shown in [Figure 3-28](#) is:

1. Voltages ramp up and global power-on reset is asserted by the external power IC:
  - vdds, vdds\_mem, vdda\_wkup\_bg\_bb, vdda\_sram voltage rails are ramped up.
  - sys\_nrespwron is asserted (set to low).
  - vdda\_dpll\_dll and vdda\_dpll\_per voltage rails are ramped up before release of sys\_nrespwron (transition to high).
  - The VDD3 voltage domain LDO (WKUP power domain) tracks vdda\_wkup voltage rail and automatically ramps up.
  - After VDD3 voltage domain stabilization, the power IC ramps up VDD2 voltage domain.
  - After VDD2 voltage domain stabilization, the power IC ramps up VDD1 voltage domain.
2. Source clock stabilizes:
  - The 32-kHz input clock and the system clock oscillator stabilize.
  - The device reset manager holds the entire device under reset.
  - The system clock (SYS\_CLK) is on.
3. The global power-on reset sys\_nrespwron released (to high) when vdda\_dpll\_dll and vdda\_dpll\_per voltage rails are stabilized.
4. The eFuse farm reset is released.
5. Internal memory LDOs ramp up:
  - Processor memory LDO (VDD4 voltage domain) is ramped up.
  - CORE memory LDO (VDD5 voltage domain) is ramped up.
  - The PRCM module waits for internal memory LDO stabilization.
6. Global resets are released. Global power-on reset and global warm reset are extended (remain asserted) on release of the external power-on reset until the following conditions are met:
  - Voltages are stable in the processor power domains, CORE power domain, and WKUP power domain.
  - System clock is stable.
  - Internal memory LDO is stable.
  - Device reset manager counter overflows (set up by the PRCM.[PRM\\_RSTTIME\[7:0\]](#) RSTTIME1 bit field).
  - Hardware conditions, such as eFuse farm ready, are set.
7. The PRM\_RSTPWRON reset is released.
8. The CM\_SYS\_CLK clock starts running (gating logic is enabled).
9. The CM\_RSTPWRON\_RET reset is released.
10. The reset of the DLLs is released.
11. The DLL3\_ALWON\_FCLK clock starts to run (gating logic is enabled).
12. The L3\_ICLK clock starts to run.
13. The DLL1\_ALWON\_FCLK clock starts to run (logic controlling the clock-gating conditions element is clocked and the clock is requested).
14. The CORE\_RST reset is released.
15. The MPU\_CLK clock starts to run.
16. The MPU boots.

---

**NOTE:**

- The IVA2 power domain is held under reset after power up by assertion of the software source of reset.
  - Power domains such as DSS, CAM, SGX, and NEON are held under reset after power up until the MPU software enables the power domain interface clocks.
-

### 3.5.1.9.2 Global Warm Reset Sequence

This section describes the global reset sequence.

The assumptions are:

- vdds, vdds\_mem, vdda\_dppll\_pll, vdda\_dppll\_per, vdda\_wkup\_bg\_bb and vdda\_sram power rails are regulated at 1.8 V.
- The VDD2 voltage domain (vdd\_core power rail) is regulated at 1.0 V.
- The VDD1 voltage domain (vdd\_mpu\_iva power rail) is regulated at 1.2 V.
- The VDD3, VDD4, and VDD5 voltage domains are regulated at 1.2 V.
- The system is running:
  - Resets are released.
  - CORE DPLL and processor DPLL are locked.

[Figure 3-29](#) shows the global warm reset sequence.

Figure 3-29. Warm Reset Sequence



prcm-097

The steps of a global warm reset sequence are as follows:

1. On assertion of the warm reset source:
  - The device reset manager resets part of the device by asserting the global warm reset.

- The external warm reset (sys\_nreswarm\_out) is asserted.
  - All the power domain warm resets are asserted.
  - DPLL1 and DPLL3 transit to bypass mode. DPLL2, DPLL4, and DPLL5 transit to stop mode. The system clock, SYS\_CLK, continues running at system clock frequency.
  - The registers sensitive to a warm reset are synchronously reset (PRM and CM register sets).
  - The CM cuts all the clocks not requested, according to the register reset value settings.
2. The global warm reset is released and extended after release of the warm reset source until the following conditions are met:
- Device reset manager counter overflows (set up by the PRCM.[PRM\\_RSTTIME\[7:0\]](#) RSTTIME1 bit field).
  - Voltage domains (VDD1, VDD2, VDD4 and VDD5) are stable.
- 
- NOTE:** Voltage stabilization is an additional condition if voltage scaling was performed before the assertion of the warm reset.
- 
3. The CORE domain is released from reset (warm sensitive modules in CORE power domain).
  4. The MPU\_CLK clock is running.
  5. The MPU power domain is released from reset. The MPU boots.

---

**NOTE:**

- The IVA2 power domain is held under reset after global warm reset by assertion of the software source of the reset.
  - Power domains such as PER, DSS, CAM, SGX, and NEON are held under reset after global warm reset until the MPU software enables their interface clock.
- 

### 3.5.1.9.3 IVA2.2 Subsystem Power-Up Sequence

This section describes the power-up reset sequence and timing relationships of the IVA2.2 subsystem.

The assumptions are:

- The MPU is running.
- All sources of reset to the IVA2.2 subsystem are released except for the software sources of reset.

[Figure 3-30](#) shows the IVA2.2 power-up sequence.

Figure 3-30. IVA2.2 Subsystem Power-Up Reset Sequence



prcm-029

The sequence is:

1. Software enables the IVA2.2 subsystem clock.

2. Software clears the PRCM.RM\_RSTCTRL\_IVA2[1] RST2\_IVA2 bit. The PRM module releases the IVA2\_RSTPWRON reset signal when reset manager 2 in the IVA2 power domain times out.
3. On release of IVA2\_RSTPWRON, the IVA2.2 subsystem performs an initialization sequence.
4. The IVA2.2 subsystem asserts the IVA2\_RST\_DONE signal when initialization completes.
5. The PRM module releases the IVA2\_RST2 reset signal.
6. The PRCM.RM\_RSTST\_IVA2[9] IVA2\_SW\_RST2 status bit is updated accordingly on release of the IVA2\_RST2 reset signal. The MPU software can now program the MMU or download the DSP code.
7. Software clears the PRCM.RM\_RSTCTRL\_IVA2[0] RST1\_IVA2 bit. The PRM module waits for reset manager 1 in the IVA2 power domain to time out.
8. The PRM module releases the IVA2\_RST1 reset signal. The DSP boots.
9. The PRCM.RM\_RSTST\_IVA2[8] IVA2\_SW\_RST1 status bit is updated accordingly on release of the IVA2\_RST1 reset signal.
10. DSP software enables the video sequencer (SEQ) clock.
11. DSP software clears the PRCM.RM\_RSTCTRL\_IVA2[2] RST3\_IVA2 bit. The PRM waits for reset manager 3 in the IVA2 power domain to time out.
12. After reset manager 3 times out, the PRM can release the IVA2\_RST3 reset signal. The SEQ boots.
13. The PRCM.RM\_RSTST\_IVA2[10] IVA2\_SW\_RST3 bit is updated accordingly on release of the IVA2\_RST3 reset signal.

### 3.5.1.9.4 IVA2 Software Reset Sequence

This section describes the software reset sequence and timing relationships of the IVA2.2 subsystem.

The assumptions are:

- The MPU is running.
- All sources of reset to the IVA2.2 subsystem are released.
- The software ensures that the IVA2.2 subsystem software sources of reset are not asserted while the IVA2 power domain clocks are running.
- The software clears the previous reset status.

Figure 3-31 shows the IVA2 software reset sequence.

Figure 3-31. IVA2 Software Reset Sequence



The sequence is:

1. DSP software puts the SEQ in idle, and can safely assert the IVA2 power domain software reset.
2. The PRM module asserts the IVA2\_RST3 reset asynchronously.

3. The DSP goes to idle, and the CM gates the IVA\_CLK clock.
4. MPU software asserts the IVA2.2 subsystem software reset.
5. The PRM asserts all remaining IVA2 power domain warm resets asynchronously.
6. MPU software enables the IVA2 power domain clock. A partial initialization sequence is performed.
7. MPU software clears the PRCM.[RM\\_RSTCTRL\\_IVA2\[1\]](#) RST2\_IVA2 bit.
8. The IVA2.2 subsystem asserts the IVA2\_RST\_DONE signal when initialization completes.
9. The PRM module releases the IVA2\_RST2 reset signal when reset manager 2 in the IVA2 power domain times out.
10. The PRCM.[RM\\_RSTST\\_IVA2\[9\]](#) IVA2\_SW\_RST2 status bit is updated accordingly on release of the IVA2\_RST2 reset signal. MPU software now programs the MMU or downloads the DSP code.
11. Software clears the PRCM.[RM\\_RSTCTRL\\_IVA2\[0\]](#) RST1\_IVA2 bit. The PRM module waits for reset manager 1 in the IVA2 power domain to time out.
12. After reset manager 1 times out, the PRM module releases the IVA2\_RST1 reset signal. The DSP boots.
13. The PRCM.[RM\\_RSTST\\_IVA2\[8\]](#) IVA2\_SW\_RST1 status bit is updated accordingly on release of the IVA2\_RST1 reset signal.
14. DSP software enables the SEQ clock.
15. DSP software clears the PRCM.[RM\\_RSTCTRL\\_IVA2\[2\]](#) RST3\_IVA2 bit. The PRM module waits for reset manager 3 in the IVA2 power domain to time out.
16. The PRM module releases the IVA2\_RST3 reset signal. The SEQ boots.
17. The PRCM.[RM\\_RSTST\\_IVA2\[10\]](#) IVA2\_SW\_RST3 status bit is updated accordingly on release of the IVA2\_RST3 reset signal.

### 3.5.1.9.5 IVA2 Global Warm Reset Sequence

This section describes the reset sequence of the IVA2.2 subsystem and timing relationships on a global warm reset.

The assumptions are:

- The MPU is running.
- All sources of reset to the IVA2.2 subsystem are released.
- Software clears the previous reset status.

[Figure 3-32](#) shows the IVA2 global warm reset sequence.

**Figure 3-32. IVA2 Global Warm Reset Sequence**

prcm-031

The sequence is:

1. A global warm reset source is asserted (see `sys_nreswarm` in Figure 3-32).

2. The PRM asserts asynchronously all IVA2 power domain warm reset signals (and all other warm reset signals).
3. The PRCM.RM\_RSTCTRL\_IVA2 register is reset to its default value. As a result, the IVA2 power domain warm reset signals stay asserted on release of the global warm source of reset.
4. DPPLL2 is held under its reset configuration; the IVA2 power domain clocks are stopped.
5. The sys\_nreswarm global warm source of reset is deasserted.
6. The PRCM.RM\_RSTST\_IVA2 status register is updated accordingly when the device reset manager times out.
7. The MPU boots and the MPU software sequence, shown in [Section 3.5.1.9.4](#), from point 6, starts.

### 3.5.1.9.6 IVA2 Power Domain Wake-Up Cold Reset Sequence

This section describes the cold reset sequence of the IVA2.2 subsystem when the IVA2 power domain transitions from retention to on power state.

The assumptions are:

- The MPU is running.
- All sources of reset to the IVA2 are released.
- The software ensures that the IVA2 power domain software sources of reset are not asserted while the IVA2 clocks are running.
- The software clears the previous reset status.

[Figure 3-33](#) shows the IVA2 power domain wake-up cold reset sequence.

Figure 3-33. IVA2 Power Domain Power Transition Reset Sequence



prcm-032

The sequence is:

1. DSP software puts the SEQ in inactive state.

2. MPU software programs the IVA2 power domain to go to retention power state during the next sleep transition.
3. The DSP goes to idle mode, and the CM gates the IVA2 clock. The IVA2 power domain enters inactive power state.
4. The IVA2 power domain enters retention power state.
5. The IVA2 power domain is awakened.
6. The PRM asserts the cold reset IVA\_RSTPWRON and all IVA2 warm resets asynchronously.
7. The PRCM.[RM\\_RSTCTRL\\_IVA2\[2\]](#) RST3\_IVA2 bit is automatically reset to its reset value.
8. The IVA2 power domain is inactive.
9. IVA2 clocks are automatically reenabled. The IVA2 power domain enters active power state.
10. The PRM releases the IVA2\_RSTPWRON reset signal when reset manager 2 in the IVA2 power domain times out.
11. On release of IVA2\_RSTPWRON, the IVA2 performs an initialization sequence.
12. The PRCM.[RM\\_RSTST\\_IVA2](#) register is updated accordingly on release of the IVA2\_RSTPWRON reset signal.
13. The IVA2.2 subsystem asserts the IVA2\_RSTDONE signal when initialization completes.
14. The PRM module releases the IVA2\_RST1 and IVA2\_RST2 reset signals. The DSP boots in autonomous mode.
15. DSP software enables the SEQ clock.
16. DSP software clears the PRCM.[RM\\_RSTCTRL\\_IVA2\[2\]](#) RST3\_IVA2 bit. The PRM module waits for reset manager 3 in the IVA2 power domain to time out.
17. After reset manager 3 times out, the PRM module releases the IVA2\_RST3 reset signal. The SEQ boots.
18. The PRCM.[RM\\_RSTST\\_IVA2\[10\]](#) IVA2\_SW\_RST3 bit is updated accordingly on release of the IVA2\_RST3 reset signal.

There are two alternate sequences:

- The DSP is held under reset when exiting retention power state. This is done when the MPU software writes 1 to the PRCM.[RM\\_RSTCTRL\\_IVA2\[0\]](#) RST1\_IVA2 bit. In this case, the MPU software must clear this bit to 0 to reboot the DSP.
- The DSP and MMU are held under reset when exiting retention power state (the MPU software writes 1 to the PRCM.[RM\\_RSTCTRL\\_IVA2\[0\]](#) RST1\_IVA2 and PRCM.[RM\\_RSTCTRL\\_IVA2\[1\]](#) RST2\_IVA2 bits). In this case, the MPU software must first clear the PRCM.[RM\\_RSTCTRL\\_IVA2\[1\]](#) RST2\_IVA2 bit to allow the release of the reset IVA\_RSTPWRON and subsequently (after initialization) the release of IVA2\_RST2. Only after the MPU software reprograms the MMU or downloads the DSP code can it clear the PRCM.[RM\\_RSTCTRL\\_IVA2\[0\]](#) RST1\_IVA2 bit field to boot the DSP.

---

**NOTE:**

- Although the IVA2.2 WUGEN module and DPLL2 are part of the IVA2.2 subsystem, they are also part of the CORE power domain and the DPLL2 power domain, respectively. They are reset independently from the IVA2 power domain.
  - The IVA2\_RSTPWRON reset is released by software by programming the PRCM.[RM\\_RSTCTRL\\_IVA2\[1\]](#) RST2\_IVA2 bit. Setting the PRCM.[RM\\_RSTCTRL\\_IVA2\[1\]](#) RST2\_IVA2 bit does not assert IVA2\_RSTPWRON.
  - IVA2\_RST3 is asserted when the IVA2 power domain transitions from off or retention state to on state. The corresponding bit in the PRCM.[RM\\_RSTCTRL\\_IVA2](#) register is automatically set to 1 during this transition.
  - The release of the IVA2\_RST3 reset is stalled as long as the IVA2\_RST2 reset is not released.
  - The release of the IVA2\_RST2 and IVA2\_RST1 resets causes IVA2 to deassert the IVA2\_RSTDONE signal.
-

### 3.5.2 PRCM Power Manager Functional Description

#### 3.5.2.1 Overview

##### 3.5.2.1.1 Introduction

To efficiently manage leakage and reduce dynamic power consumption, the device supports several power-management techniques:

- Dynamic clock-gating conditions
- DVFS
- DPS
- SLM

These power-management techniques require software control and specific hardware features. The hardware features are fully controlled by the PRM part of the PRCM module. These features are:

- Device partitioning into 18 power domains
- Device partitioning into several voltage domains communicating through level shifters
- Logic power-switch control
- RFF control
- Memory power-switch control
- Embedded LDOs (SRAMs, wakeup, emulation) control
- I/O off-mode control
- Level shifter control
- External power IC control

[Figure 3-34](#) is an overview of PRM power management in the device.

**Figure 3-34. Power Control Overview**


prcm-033

### 3.5.2.1.2 Device Partitioning

To substantially reduce leakage in sleep modes (SLM strategy) and to optimize active power-consumption savings (DPS strategy), the device is segmented into 18 power domains:

- MPU: Microprocessors
- NEON: Multimedia coprocessor
- IVA2: DSP
- SGX: Graphics engine
- CORE: Interconnect, memory controllers, peripherals, and clock management
- DSS: Display subsystem
- CAM: Camera controller
- PER: Low-power use case peripherals
- WKUP: Wakeup (always active)
- USBHOST: USB HOST power domain
- EMU: Emulation
- SMARTREFLEX: SmartReflex modules
- EFUSE: eFuse farm
- DPLL1: MPU DPLL

- DPOLL2: IVA2.2 DLL
- DPOLL3: CORE DLL
- DPOLL4: Peripherals DLL
- DPOLL5: Peripherals DLL2

Each power domain receives power through an independent switch controlled by the PRM module. In this way, depending on the application scenario, unused power domains can be switched off or put in retention state while others remain active.

[Table 3-25](#) lists the device modules in relation to the power domains.

**Table 3-25. Power Domain Modules**

| Power Domain | Modules                        |
|--------------|--------------------------------|
| MPU          | MPU core                       |
|              | ICECrusher CS                  |
|              | MPU async bridge (master)      |
| NEON         | NEON coprocessor               |
| IVA2         | IVA2.2 DSP                     |
|              | IVA2 async bridge 1 (master)   |
|              | IVA2 async bridge 2 (slave)    |
|              | Video sequencer (SEQ)          |
| SGX          | SGX subsystem                  |
| CORE         | GPMC                           |
|              | USB TLL                        |
|              | GPTIMER[10, 11]                |
|              | HDQ/1-Wire                     |
|              | HS USB                         |
|              | I2C[1, 2, 3]                   |
|              | ICR                            |
|              | IVA2.2 async bridge 1 (slave)  |
|              | IVA2.2 async bridge 2 (master) |
|              | IVA2.2 WUGEN                   |
|              | MAILBOXES                      |
|              | McBSP[1, 5]                    |
|              | McSPI[1, 2, 3, 4]              |
|              | MMC/SD/SDIO[1, 2, 3]           |
|              | MPU async bridge (slave)       |
|              | MPU INTC                       |
|              | OCM_RAM                        |
|              | OCM_ROM                        |
|              | SCM                            |
|              | SDRC                           |
|              | SMS                            |
|              | L3 interconnect                |
|              | UART[1, 2]                     |
|              | SDMA                           |
|              | Temperature sensor (x2)]       |
|              | L4-Core interconnect           |
| DSS          | Display subsystem              |
|              | Video DAC                      |
| CAM          | Camera subsystem               |

**Table 3-25. Power Domain Modules (continued)**

| Power Domain | Modules                                                                                     |
|--------------|---------------------------------------------------------------------------------------------|
| PER          | UART[3, 4]<br>WDTIMER3<br>McBSP[2..4]<br>GPIO[2..6]<br>GPTIMER[2..9]<br>L4-Per interconnect |
| WKUP         | GPIO1<br>GPTIMER1<br>WDTIMER2<br>L4-Wake-up interconnect                                    |
| USBHOST      | HS USB host subsystem                                                                       |
| EMU          | CWT<br>DAP-APB<br>ETB<br>ICEPICK<br>TRACEPORT<br>L4-EMU interconnect                        |
| SMARTREFLEX  | SmartReflex1<br>SmartReflex2                                                                |
| EFUSE        | eFuse farm                                                                                  |
| DPLL1        | MPU DPLL                                                                                    |
| DPLL2        | IVA2.2 DPLL                                                                                 |
| DPLL3        | CORE DPLL                                                                                   |
| DPLL4        | Peripherals DPLL                                                                            |
| DPLL5        | Peripherals DPLL2                                                                           |

### 3.5.2.1.3 Memory and Logic Power Management

Device power domains can have separate control for logic and memory. This depends on the power domain implementation in the device (for details, see [Section 3.5.2.2, Power Domain Implementation](#)).

Generally, separate switches allow separate management of the logic and memory power states in a power domain.

Memory banks in the MPU (L2 cache), IVA2 (L1, L1 flat, L2, L2 flat), CORE (CORE memory banks 1 to 6), SGX, CAM, DSS, USBHOST, and EMU power domain memories have their own voltage and power control, independent of the logic. However, the user must ensure that memory states are programmed consistently with the logic state.

MPU L1 cache memory does not have an independent control and is supplied with the MPU logic.

CORE memory banks 3,4, 5, and 6 are associated to the domain power state and controlled with the domain logic.

MPU and IVA2 memories are supplied by a common LDO (VDD4). CORE, SGX, CAM, DSS, USBHOST, and EMU memories are supplied by another LDO (VDD5).

### 3.5.2.1.4 Retention Till Access (RTA) Memory Feature

Most high-density memories within the device support the RTA feature. It consists of putting automatically part or entire memory array into retention when no access is made to the corresponding locations. This is managed within the memory bank, by the hardware and is completely transparent to the user software. As a consequence, RTA memories do not have any retention mode control signal coming from the PRCM.

The RTA feature is controlled (enabled/disabled) from a software-controlled override capability through a bit in the System Control Module (that is, the CONTROL\_MEM\_RTA\_CTRL[0] HD\_MEM\_RTA\_SEL bit field.)

### 3.5.2.1.5 Power Domain States

Each power domain can be driven by the PRM to four different states, depending on the functional mode required by the user. Power domain states are hardware-defined and depend on the domain clock activity and domain memory/logic switch states.

[Table 3-26](#) defines the power states a power domain can reach in the device.

**Table 3-26. Power Domain States**

| Power State      | Power   |                       | Clocks            |
|------------------|---------|-----------------------|-------------------|
|                  | Logic   | Memory                |                   |
| Active           | On      | On, retention, or off | On (at least one) |
| Inactive         | On      | On, retention, or off | Off (all clocks)  |
| Retention (CSWR) | On      | Retention or off      | Off (all clocks)  |
| Retention (OSWR) | Off/RFF |                       |                   |
| Off              | Off     | Off                   | Off (all clocks)  |

**NOTE:**

- Closed-switch retention (CSWR): Full domain logic supply is maintained, and supply voltage can be dropped to minimize leakage.
- Open-switch retention (OSWR): Full domain logic is switched off, but the context is saved for modules that embed RFFs.
- Throughout the rest of this chapter, when reference is made only to retention state without explicitly stating whether it is CSWR or OSWR, then the description applies to the two retention states.

In CSWR and OSWR, memories are put in retention or can also be switched off.

### 3.5.2.1.6 Power State Transitions

For each power domain, the PRM manages all transitions controlling domain clocks, domain resets, domain logic power switches, memory power switches, and memory retention.

As previously mentioned, a power domain is characterized by different power states: Active, inactive, retention, and off.

A transition is a passage from one state to another.

Two types of power state transitions are possible:

- Sleep: Moving from a higher consumption power state (active) to a lower consumption power state (inactive, retention, or off)
- Wake-up: Moving directly from a lower consumption power state (inactive, retention, or off) to the active power state

For instance, a power domain with initiators and target modules in standby and idle modes operates an active-to-inactive transition. It is then ready to operate an inactive-to-retention or off transition, depending on the requirements.

The device supports six transitions:

- Active to inactive
- Inactive to active
- Active to retention
- Retention to active
- Active to off

- Off to active

### **3.5.2.1.7 Device Power Modes**

A device power mode is a specific functional combination of the power states of all the power domains of the device.

Unlike power domain states (see [Section 3.5.2.1.5](#)), device power modes are not hardware-defined; they are defined by software as relevant combinations of the power domain states.

There are two types of device power modes:

- Active: Any valid combination of power domain states in which one or several domains are still active, regardless of whether any software is running
- Standby: Any valid combination of power domain states in which all the domains are in inactive, retention, or off state

---

**NOTE:** All power domain states are hardware-supported, thereby preventing electrical damage to the device. However, software ensures that the power domain states are set correctly, to result in a valid device power mode and ensure correct functioning.

---

### **3.5.2.1.8 Isolation Between Power Domains**

When switching a power domain from one state to another, the PRCM module automatically manages domain output isolation to prevent electrical damage.

This mechanism is hardware-supervised and does not require software action.

## **3.5.2.2 Power Domain Implementation**

### **3.5.2.2.1 Device Power Domains**

[Table 3-27](#) summarizes the power mode implementation in the device and the control granularity for each power and memory domain.

**Table 3-27. Domain Power Control Summary**

| Functional Domain or Subsystem | Power Domain       | PRCM Power Control Type               |
|--------------------------------|--------------------|---------------------------------------|
| MPU                            | MPU                | Logic on-off                          |
|                                | NEON               | Logic on-off                          |
|                                | CORE               | Logic on-off                          |
|                                | EMU                | Logic on-off                          |
|                                | L1 cache SRAM      | Logic on-off                          |
|                                | L2 cache SRAM      | On-off<br>BB retention                |
| IVA2.2                         | IVA2               | Logic on-off                          |
|                                | CORE               | Memory tags retention<br>Logic on-off |
|                                | L1 cache SRAM      | Logic retention<br>On-off             |
|                                | L1 flat cache SRAM | BB retention<br>On-off                |
|                                | L2 cache SRAM      | BB retention<br>On-off                |
|                                | L2 flat cache SRAM | BB retention<br>On-off                |

**Table 3-27. Domain Power Control Summary (continued)**

| Functional Domain or Subsystem                       | Power Domain     | PRCM Power Control Type         |
|------------------------------------------------------|------------------|---------------------------------|
|                                                      | Misc SRAM        | Logic on-off                    |
| All MPU and IVA2.2 memories                          |                  | LDO retention                   |
| GRAPHICS                                             | SGX              | Logic on-off                    |
|                                                      | Misc SRAM        | Logic on-off                    |
| DISPLAY                                              | DSS              | Logic on-off                    |
|                                                      | Misc SRAM        | Logic on-off                    |
| CAMERA                                               | CAM              | Logic on-off                    |
|                                                      | Misc SRAM        | Logic on-off                    |
| USBHOST                                              | USB              | Logic on-off                    |
|                                                      | Misc SRAM        | Logic on-off                    |
|                                                      | CORE             | Logic on-off                    |
|                                                      | SRAM bank 1      | Logic retention<br>On-off       |
| CORE (interconnect, memory controllers, peripherals) | SRAM bank 2      | BB retention<br>On-off          |
|                                                      | OSWR SRAM 3      | BB retention<br>Logic on-off    |
|                                                      | CSWR SRAM bank 4 | BB retention<br>On-off          |
|                                                      |                  | BB retention                    |
| PERIPHERALS                                          | PER              | Logic on-off<br>Logic retention |
|                                                      |                  |                                 |
| WKUP                                                 | WKUP             | none                            |
|                                                      | EMU              | Logic on-off                    |
| EMULATION                                            | ETB SRAM         | On-off<br>BB retention          |
|                                                      |                  |                                 |
| SmartReflex                                          | SR1, SR2         | Logic on-off                    |
| EFUSE                                                | eFuse farm       | none                            |
| MPU DLL                                              | DPLL1            | Logic on-off                    |
| IVA2.2 DLL                                           | DPLL2            | Logic on-off                    |
| CORE DLL                                             | DPLL3            | Logic on-off                    |
| Peripherals DLL                                      | DPLL4            | Logic on-off                    |
| Peripherals DLL2                                     | DPLL5            | Logic on-off                    |

**NOTE:**

- BB: Back-bias or local memory retention
- OSWR: Open-switch retention
- CSWR: Closed-switch retention
- LDO retention: All memories are in BB mode and the memory array is dropped down.
- Logic on-off: Memory is controlled with the logic (and does not support retention).
- OSWR SRAM bank 3: Corresponds to memories that must be retained when the CORE OSWR mode is activated (the CORE context is maintained only by keeping RFFs alive). These memories are scratchpad, SDMA, and SMS.
- CSWR SRAM bank 4: Corresponds to memories that are retained only in case of CSWR (all logic is maintained with reduced voltage). These memories are USB and MAILBOXES.

The CORE power domain has six memory blocks. Of these six, the power state of only two memory blocks, SRAM bank 1 and SRAM bank 2, can be configured vis-a-vis the domain power state through software setting of the corresponding bit fields in the PRCM.[PM\\_PWSTCTRL\\_CORE](#) register. The power states of the rest of the memory banks are automatically controlled by the PRCM module (hardware-controlled) and no software setting is possible.

Memory bank 5 of the CORE power domain is used for the USB TLL module save and restore operations. (see [Section 3.5.4.6, USBHOST/USBTLL Save-and-Restore Management](#)). Similarly, the memory bank 6 is for the system control module save and restore feature (see [Chapter 13, System Control Module](#)).

---

**NOTE:** Before initiating a domain sleep transition (ON to OFF) on the MPU and CORE power domains, the CORE memory banks must be configured to automatically switch to ON power state when the CORE power domain wakes up (OFF to ON). This is required for correct booting.

This is done by setting the [PM\\_PWSTCTRL\\_CORE\[19:18\]](#) MEM2ONSTATE bit field to 0x3 and the [PM\\_PWSTCTRL\\_CORE\[17:16\]](#) MEM1ONSTATE bit field to 0x3.

---

### 3.5.2.2.2 Power Domain Memory Status

The PRCM module logs the memory status in the SCM.CONTROL\_SEC\_STATUS register. The memory status is logged for CORE power domain memory banks 1 and 2 (OCM RAM) and for the L1 and L2 caches of the MPU.

Two statuses are logged for each memory bank:

- Memory is destroyed: The memory array is powered down.
- Memory is not accessible: The memory array is powered down or is in retention.

For information about the SCM, see [Chapter 13, System Control Module](#).

### 3.5.2.2.3 Power Domain State Transition Rules

As previously described, a power domain can reach different states. These states are linked to the power applied to the domain and to the domain clock activity.

Any power state transition always depends on and starts with power domain clock activity control. Any active clock in a power domain sets the domain as active (see [Section 3.5.2.2.1](#)). Therefore, a sleep transition always starts by shutting down the power domain clocks. For more information about power domain clock controls, see [Section 3.5.3, Clock Manager Functional Description](#).

When all clocks are shut down in a power domain, transitions from inactive-to-off or inactive-to-retention can occur.

Similarly, when a wake-up transition occurs between a lower-power domain state and a higher one, the transition to active state becomes effective when the required clocks are restarted.

[Section 3.5.4, Idle and Wake-Up Management](#), describes sleep and wake-up transitions.

### 3.5.2.2.4 Power Domain Dependencies

Besides the inner conditions to operate a state transition on a single power domain, the device offers hardwired and software-programmable dependencies between the power domains.

Two kinds of dependencies exist:

- Sleep dependencies: Used to start a sleep transition on a power domain only if the related power domains are in mute mode (not requesting any service from the linked power domain)
- Wake-up dependencies: Used to initiate a wake-up transition on a power domain as a consequence of a linked power domain wake-up transition

Two dedicated sets of registers (PRCM.CM\_SLEEPDEP\_domain and PRCM.PM\_WKDEP\_domain) allow the setting of programmable dependencies.

[Section 3.5.4.5, Sleep and Wake-Up Dependencies](#), summarizes the possible dependency combinations between power domains.

### 3.5.2.2.5 Power Domain Controls

#### 3.5.2.2.5.1 Power Domain Hardware Control

Each power domain in the device is controlled by a dedicated power state controller (PSCON) in the PRCM module.

When a state transition occurs for a given power domain, the related PSCON automatically manages the sequence.

The following sequences are for information only. They do not require software control and are hardware-managed by the PSCON.

- Active-to-retention transition:
  1. The PSCON isolates the power domain outputs.
  2. The PSCON saves the flip-flop content.
  3. The PSCON opens the power switch.
- Retention-to-active transition:
  1. The PSCON closes the power switch.
  2. The PSCON restores the flip-flop content.
  3. The PSCON deactivates the isolation of the power domain outputs.
- Active-to-off transition:
  1. The PSCON isolates the power domain outputs.
  2. The PSCON opens the power switch.
- Off-to-active transition:
  1. The PSCON closes the power switch.
  2. The PSCON deactivates the isolation of the power domain outputs.

Device power domain implementation also depends on hardwired dependencies, both sleep and wake-up transitions, between power domains. This means a single power domain transitions from one power state to another depending on the states and transitions of the linked domains.

For details about the dependencies between power domains, see [Section 3.5.4, Idle and Wake-Up Management](#), and [Section 3.6, Basic Programming Model](#).

#### 3.5.2.2.5.2 Power Domain Software Controls

If all conditions are met to initiate a power domain state transition (all the modules are idle/standby and the related clocks are shut down), the PRCM module automatically manages the transition according to the following settings:

- Dependencies setting: The PRCM.CM\_SLEEPDEP\_domain registers and PRCM.PM\_WKDEP\_domain registers are used to set/clear programmable dependencies between power domains.

Not all dependencies are programmable by software; some are hardwired and thus do not allow any control. For more information about the dependencies between power domains, see [Section 3.5.4, Idle and Wake-Up Management](#), and [Section 3.6, Basic Programming Model](#).

- Power state transitions setting: The transitions of each power domain state can be controlled by software through a set of dedicated status registers (PRCM.PM\_PWSTCTRL\_domain\_name) that allow the configuration of the power state that the domain enters after completing a transition (PRCM.PM\_PWSTCTRL\_domain\_name[1:0] POWERSTATE bit field). These status registers are used to check the current state of the logic and memories in a power domain and to learn about any ongoing state transition.

Also, if the power domain offers different settings for logic and memory, the PRCM.PM\_PWSTCTRL\_domain\_name registers allow selection of the state to which the logic and memory go when the power domain is put in retention. They also allow selection of the state to which

the memory will go when the power domain is put into on state.

These features depend on each power domain implementation. For details, see [Section 3.6, Basic Programming Model](#), and [Section 3.7, PRCM Registers Manual](#).

- Event generator: Three registers (`PRCM.PM_EVGENCTRL_MPU`, `PRCM.PM_EVGENONTIM_MPU`, and `PRCM.PM_EVGENOFFTIM_MPU`) let the MPU power domain be switched between on and off (or placed in inactive mode). The `PRCM.PM_EVGENONTIM_MPU` and `PRCM.PM_EVGENOFFTIM_MPU` registers set the durations of the on and off modes, respectively.

For details, see [Section 3.6, Basic Programming Model](#), and [Section 3.7, PRCM Registers Manual](#).

### 3.5.3 PRCM Clock Manager Functional Description

This section describes all modules and features in the high-tier device. To save power, ensure that power domains of unavailable features and modules are switched off and clocks are cut off.

---

**NOTE:** For a detailed visual representation of the distribution and management of the device clocks, see the device [Clock Tree Tool \(CTT\)](#).

For AM/DM37x, use the OMAP3630 Clock Tree Tool.

---

#### 3.5.3.1 Overview

The PRCM module provides control for clock generation, division, distribution, synchronization, and gating. It distributes the clock sources to all modules in the device.

The device-level clock generation is handled by an internal oscillator (the system clock oscillator) and DPLLs; clock division and gating are handled by the PRM and the CM sections of the PRCM module. [Figure 3-35](#) shows the high-level clock-management scheme in the device.

**Figure 3-35. PRCM Clock Manager Overview**


### **3.5.3.1.1 Interface and Functional Clocks**

The PRCM module propagates two kinds of clocks:

- Interface clock: Ensures proper communication between any module and the system interconnects (level 3 [L3] or level 4 [L4]). In most cases, the interface clock supplies the interface and registers of the module. For some modules, the interface clock is also used as the functional clock.
- Functional clock: Supplies the functional part of a module or subsystem. In some cases, a module or subsystem can require several functional clocks.

To be operational, a module requires a functional clock(s); to communicate with other modules, it requires an interface clock. For example, the functional clock of a general-purpose timer (GPTIMER) must be active for it to run, but its interface clock can be turned off.

A module can use one or more optional functional clocks. Because an optional functional clock is used only for specific features of the module, it can be shut down without stopping the module activity (for example, 54 MHz for the DSS power domain and 96 MHz for the CAM power domain).

### 3.5.3.2 External Clock I/Os

[Figure 3-36](#) shows the external clock I/Os of the device.

**Figure 3-36. External Clock I/O**



#### 3.5.3.2.1 External Clock Inputs

##### 3.5.3.2.1.1 32-kHz Always-On Clock

The sys\_32k input pin supplies the 32-kHz always-on clock (32K\_FCLK clock). This clock is used for low-frequency operation (timers, debouncing, etc.). It also supplies the WKUP power domain for operation in the lowest power mode.

##### 3.5.3.2.1.2 High-Frequency System Clock

The high-frequency system clock (SYS\_CLK) is supplied to the device from an external clock source through the sys\_xtalin input pin or is generated internally by a local system clock crystal oscillator. In the latter case, a crystal is connected between the sys\_xtalout and sys\_xtalin device pins. The sys\_boot[6] pin sets the oscillator operating mode (see [Figure 3-14](#)).

The source system clock can be 12, 13, 16.8, 19.2, 26, or 38.4 MHz and can be divided by 2 to provide the standard system clock frequencies (using internal system clock divider configuration in the PRCM.PRM\_CLKSRC\_CTRL[7:6] SYSLKDIV bit field). It supplies the reference to the DPLLs and is also used by several modules. The system clock is activated in the device after the device power-on reset is released by the reset manager in the PRCM module.

The source-clock selection register (the PRCM.PRM\_CLKSEL [2:0] SYS\_CLKIN\_SEL bit field) is set by the software to identify the input frequency of the system clock.

[Table 3-28](#) lists the system clock input configurations.

**Table 3-28. System Clock Input Configurations**

| Input Source                     | Device Pin Mapping                        | Description                      |
|----------------------------------|-------------------------------------------|----------------------------------|
| Quartz                           | sys_xtalin and sys_xtalout                | Internal oscillator is enabled.  |
| Square clock (1.8-V CMOS signal) | sys_xtalin (sys_xtalout is not connected) | Internal oscillator is bypassed. |

---

**NOTE:** An external pullup or pulldown tied on the sys\_boot6 input pin of the device determines whether the internal oscillator is used (oscillator mode) or an external clock source is supplied to the sys\_xtalin input pin (bypass mode).

---

### 3.5.3.2.1.3 Alternate Clock

The sys\_altclk pin can provide an additional 54-MHz, 48-MHz, or any other frequency clock.

### 3.5.3.2.2 External Clock Outputs

The device can output two clocks externally:

- sys\_clkout1 can output an oscillator clock (12, 13, 16.8, 19.2, 26, or 38.4 MHz) at any time. The output oscillator clock can be controlled by software or externally using sys\_clkreq control. When the device is in off state, sys\_clkreq can be asserted to enable the oscillator and activate sys\_clkout1 without waking up the device. The off state polarity of sys\_clkout1 is programmable.
- sys\_clkout2 can output CM\_SYS\_CLK (12, 13, 16.8, 19.2, 26, or 38.4 MHz), CORE\_CLK (CORE DPLL output), or 96-MHz or 54-MHz clocks. It can be divided by 2, 4, 8, or 16, and its off state polarity is programmable. This output is active only when the CORE power domain is active. Also, the selected source clock must be enabled by software. Enabling sys\_clkout2 does not automatically request the required source clock.

### 3.5.3.2.3 Summary

Table 3-29 summarizes the external clock I/O.

**Table 3-29. External Clock I/Os**

| Name        | I/O <sup>(1)</sup> | Source/Destination | Description                                                                                                                                    |
|-------------|--------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| sys_xtalin  | I                  | Oscillator         | Main input clock. Crystal oscillator clock (only at 12, 13, 16.8, or 19.2 MHz) or CMOS digital clock (at 12, 13, 16.8, 19.2, 26, or 38.4 MHz). |
| sys_xtalout | O                  | Oscillator         | Output of oscillator                                                                                                                           |
| sys_clkout1 | O                  | PRCM               | Configurable output clock 1                                                                                                                    |
| sys_clkout2 | O                  | PRCM               | Configurable output clock 2                                                                                                                    |
| sys_32k     | I                  | PRCM               | 32-kHz clock input                                                                                                                             |
| sys_altclk  | I                  | PRCM               | Additional selectable clock source                                                                                                             |

<sup>(1)</sup> I = Input, O = Output

### 3.5.3.3 Internal Clock Generation

The device generates internal clocks from following sources:

- PRM
- CM
- DPLLS

Figure 3-37 shows the internal clock-generation scheme of the device.

**Figure 3-37. Internal Clock Sources**

prcm-036

### 3.5.3.3.1 PRM

The PRM resides in the WKUP power domain. It handles the generation of the 32-kHz low-frequency clocks and the high-frequency system clocks from the SYS\_CLK. It also manages the clock oscillator and the external clock output sys\_clkout1.

SYS\_CLK is generated by the internal oscillator or supplied as the external clock signal on the sys\_xtalin pin. It supplies most of the clocks in the device. Some of the device clocks sourced by SYS\_CLK are always powered (clocks are present even when the CORE power domain is in off state). SYS\_CLK is also the source of the WKUP power domain interface clocks.

It also handles the gating and distribution of the 96-MHz clock from DPLL4 to the CM and PER power domain modules.

[Figure 3-38](#) is a functional overview of the PRM. The other clocks in the figure are explained in the following sections.

**Figure 3-38. PRM Clock Generator**

prcm-037

### 3.5.3.3.2 CM

The CM clock generator generates interface clocks and peripheral functional clocks for most of the modules. It also controls DPLL3, DPLL4, and the external peripheral clock output sys\_clkout2 (see [Figure 3-39](#)).

The CM is in the CORE power domain, which can be powered off. When the CORE power domain is powered off, the clocks are not available, and their off state is latched. The DPLL controls are also latched. The RFF architecture ensures that the full CM setting is saved when the CORE power domain goes to retention state, and is transparently restored when it reactivates.

DPLL3 receives SYS\_CLK from the PRM module and generates CORE\_CLK through the CM. CORE\_CLK is the source for the interface clocks (L3 and L4) and the functional clock . The L3 and L4 interface clocks supply the device interconnects and all module interface clocks. The L4 clock is divided for USB (full-speed clock limitation at 50 MHz) and to supply the reset managers (PRM) in the WKUP power domain. The clocks derived from CORE\_CLK are fully balanced over the device.

The 96M\_FCLK, 48M\_FCLK, and 12M\_FCLK clocks are functional unbalanced clocks for a number of modules in the CORE and PER power domains.

The functional 96-MHz clock path can be bypassed with SYS\_CLK to allow a peripheral such as I<sup>2</sup>C to function while the DPLL4 is not powered on. The default configuration after initial power on is bypassed with the system clock. Software must switch to the DPLL-generated clock after programming the system settings.

The 96-MHz clock input from the PRM to the CM (CM\_96M\_FCLK) is internally gated by the CM.

[Figure 3-39](#) is the functional overview of the CM.

Figure 3-39. CM Clock Generator Functional Overview



prcm-038

### 3.5.3.3.3 DPLLs

To generate high-frequency clocks, the device supports five on-chip DPLLs controlled directly by the PRCM module:

- DPLL1 (MPU)
- DPLL2 (IVA2)
- DPLL3 (CORE)
- DPLL4 (PER)
- DPLL5 (PER2)

---

**NOTE:** This chapter discusses only DPLL1 to DPLL5, because they are directly controlled by the PRCM module. [Chapter 7, Display Subsystem](#), discusses the DPLLs in the display subsystem.

---

The DPLLs are of two types. Type A DPLLs are DPLL1, DPLL2, DPLL3 and DPLL5. Type B DPLL is DPLL4.

### 3.5.3.3.3.1 Type A DLLs

Type A DLLs that are controlled directly by the PRCM module:

- DLL1 (MPU)
- DLL2 (IVA2)
- DLL3 (CORE)
- DLL5 (PER2)

Figure 3-40 shows the functional architecture of a generic DLL.

**Figure 3-40. Generic DLL Functional Diagram**



prcm-039

Depending on its hardware configuration, the DLL can receive one or two clock inputs.

When the DLL has two clock inputs, it uses one as the reference clock ( $F_{ref}$ ) to generate the high-frequency clock; the second one serves as the bypass clock when the DLL is in bypass mode (not locked and generating the high-frequency clock). For example, DLL1 and DLL2 receive the high-frequency bypass clock from the DLL3 output, and the reference clock from the PRM module.

When the DLL has only one clock input, it uses that clock input as the reference clock and bypass clock. For example, DLL3, and DLL5 receive only one input clock from PRM module, and it is used as the reference and the bypass clock.

It internally generates two main clocks according to the following equations:

- $CLKOUTX2 = (F_{ref} \times 2 \times M)/(N+1)$
- $CLKOUT = CLKOUTX2/2$

where M is an 11-bit multiplier and N is a 7-bit divider.

---

**NOTE:** When M is set to 0 or 1, the DLL is forced to bypass mode.

---

The internal clocks (CLKOUT and CLKOUTX2) of the DLL can then be used to generate six independent output clocks:

- $CLKOUT\_M2 = CLKOUT/M2$
- $CLKOUT\_M2X2 = CLKOUTX2/M2$
- $CLKOUT\_M3X2 = CLKOUTX2/M3$
- $CLKOUT\_M4X2 = CLKOUTX2/M4$
- $CLKOUT\_M5X2 = CLKOUTX2/M5$
- $CLKOUT\_M6X2 = CLKOUTX2/M6$

where M2, M3, M5, and M6 are additional dividers for the DLL-synthesized clock.

The output clock frequencies defined by these equations are generated by the DPLL only when it is locked. When the DPLL is in bypass mode, however, all clock outputs run at the bypass clock frequency. The bypass clock can be a high-frequency bypass clock (only for DPLL1 and DPLL2) or the low-frequency reference clock.

The DPLL also provides an independent clock-gating signal for each of the six output clocks. The PRCM module provides the DPLL with a clock-gating control signal, and the DPLL returns a clock activity status signal indicating whether the output clock is effectively gated or running.

For an explanation of the DPLL multiplier, divider settings, and gating controls, see [Section 3.5.3.6, DPLL Control](#).

Each clock-generating DPLL of the device has the following features:

- Independent power domain
- Control by the CM
- Fed by always-on SYS\_CLK with independent gating control for the SYS\_CLK
- Analog part supplied by a dedicated power supply (VDDPLL and VDDADAC at 1.8 V) and an embedded LDO to eliminate 1-MHz noise
- Up to six independent output dividers for simultaneous generation of multiple output clocks with different frequencies

#### 3.5.3.3.3.1.1 DPLL1 (MPU) and DPLL2 (IVA2)

DPLL1 and DPLL2 are in the MPU and IVA2.2 subsystems, respectively. The DPLLs supply the source clocks for their respective subsystems, which use the source clocks to internally generate all subsystem clocks.

DPLL1 and DPLL2 each use a reference clock (DPLL1\_ALWON\_FCLK and DPLL2\_ALWON\_FCLK, respectively) to produce their synthesized clocks. They receive these reference clocks from the PRM module, and their high-frequency bypass clocks (DPLL1\_FCLK and DPLL2\_FCLK, respectively) from the CM. The reference clock is SYS\_CLK, and the high-frequency bypass clock is CORE\_CLK.

To save on DPLL power consumption by the processors, the high-frequency bypass input clock from DPLL3 (CORE) is used when the DPLLs are set to bypass mode (statically, or dynamically during relock time) or when the processors are not required to run faster than at L3 clock speed. This use of the high-frequency bypass input clock also optimizes the performance of the DPLLs during frequency scaling.

#### 3.5.3.3.3.1.2 DPLL3 (CORE)

[Figure 3-41](#) is a block diagram of DPLL3.

**Figure 3-41. DPLL3 Clocks**

prcm-040

DPLL3 receives its reference clock (DPLL3\_ALWON\_FCLK), which is the SYS\_CLK, from the PRM. DPLL3 does not receive a high-frequency bypass clock, and it uses the reference clock as the low-frequency bypass clock. DPLL3 supplies the source clock for all interfaces and a few functional clocks for the device modules. It is also the source of the emulation trace clock. While the CORE power domain is on, the output of DPLL3 can be used as HS bypass clock input to DPLL1 and DPLL2.

### 3.5.3.3.3.1.3 DPLL5 (Peripherals)

Figure 3-42 is a block diagram of DPLL5.

**Figure 3-42. DPLL5 Clocks**

prcm-089

DPLL5 receives its reference clock (DPLL5\_ALWON\_FCLK), which is the SYS\_CLK, from the PRM. DPLL5 does not receive a high-frequency bypass clock, and it uses the reference clock as the low-frequency bypass clock. DPLL5 generates clocks for the peripherals, supplying five clock sources:

- 120-MHz functional clock to the peripheral domain modules

### 3.5.3.3.3.2 Type B DPLL (Low-Jitter)

To generate high-frequency clocks, the device supports one on-chip low-jitter DPLL controlled directly by the PRCM module:

- DPLL4 (PER)

Figure 3-43 shows the functional architecture of DPLL4.

**Figure 3-43. DPLL4 Functional Diagram**



prcm-102

DPLL4 receives only one input clock from PRM module, and it is used as the reference and the bypass clock.

---

**NOTE:** The DPLL4 reference clock can be pre-divided before feeding the DPLL4. This is done in the PRM thanks to a dedicated programmable register [PRM\\_CLKSRC\\_CTRL\[8\]](#) DPLL4\_CLKINP\_DIV.

---

It internally generates one main clock according to the following equation:

- $CLKOUT = (F_{ref} \times M)/(N+1)$

where M is a 12-bit multiplier and N is a 7-bit divider.

---

**NOTE:** When M is set to 0 or 1, the DPLL is forced to bypass mode.

---

The internal clock (CLKOUT) of the DPLL can then be used to generate five independent output clocks:

- $CLKOUT\_M2 = CLKOUT/M2$
- $CLKOUT\_M3 = CLKOUT/M3$
- $CLKOUT\_M4 = CLKOUT/M4$
- $CLKOUT\_M5 = CLKOUT/M5$
- $CLKOUT\_M6 = CLKOUT/M6$

where M2, M3, M4, M5, and M6 are additional dividers for the DPLL-synthesized clock.

The output clock frequencies defined by these equations are generated by the DPLL only when it is locked. When the DPLL is in bypass mode, however, all clock outputs run at the bypass clock frequency. The bypass clock in DPLL4 can be only the low-frequency reference clock.

DPLL4 requires 2 additional settings than the other DPLLS.

- The user must select which one of the digitally controlled oscillators (DCO) of the DPLL4 is used, depending on the targeted lock frequency. This is done in [CM\\_CLKSEL2\\_PLL\[23:21\]](#) DCO\_SEL.

- The user must program the DPLL4 sigma-delta divider. This is done in [CM\\_CLKSEL2\\_PLL\[31:24\]](#) SD\_DIV. This divider value is given by the following equation: SD\_DIV = ceiling (CLKOUT/250), where CLKOUT Is in MHz

**NOTE:** Incorrect programming of the sigma-delta divider will lead to complete non-functionality or poor performance.

The DPLL also provides an independent clock-gating signal for each of the six output clocks. The PRCM module provides the DPLL with a clock-gating control signal, and the DPLL returns a clock activity status signal indicating whether the output clock is effectively gated or running.

For an explanation of the DPLL multiplier, divider settings, and gating controls, see [Section 3.5.3.6, DPLL Control](#).

Each clock-generating DPLL of the device has the following features:

- Independent power domain
- Control by the CM
- Fed by always-on SYS\_CLK with independent gating control for the SYS\_CLK
- Analog part supplied by a dedicated power supply (VDDPLL and VDDADAC at 1.8 V) and an embedded LDO to eliminate 1-MHz noise
- Up to five independent output dividers for simultaneous generation of multiple output clocks with different frequencies

### 3.5.3.3.3.2.1 DPLL4 (Peripherals)

[Figure 3-44](#) is a block diagram of DPLL4.

Figure 3-44. DPLL4 Clocks



DPLL4 receives its reference clock (DPLL4\_ALWON\_FCLK), which is the SYS\_CLK from the PRM, and can be divided before feeding the DPLL4. This is done in the PRM through dedicated programmable

register ([PRM\\_CLKSRC\\_CTRL\[8\]](#) DPLL4\_CLKINP\_DIV). This divider is intended to be used in case a 13-MHz system clock is used, to be able to lock DPLL4 at 864 MHz. There is a divider that can define the DPLL4 source clock, and it is controlled by [PRM\\_CLKSRC\\_CTRL\[8\]](#) DPLL4\_CLKINP\_DIV Ratios: 1, 6.5. DPLL4 does not receive a high-frequency bypass clock, and it uses the reference clock as the low-frequency bypass clock. DPLL4 generates clocks for the peripherals, supplying five clock sources:

- 96-MHz always-on source clock for the PRM
- 54-MHz to TV DAC
- Display functional clock
- Camera sensor clock
- Emulation trace clock

The clock outputs to the DSS, PER, and EMU power domains are always on.

### 3.5.3.3.4 DPLL Clock Summary

[Table 3-30](#) and [Table 3-31](#) summarizes the use of the divided output clocks of the DPLLS in the device.

**Table 3-30. Low-Jitter DPLL Output Clocks**

|       | <b>CLKOUT_M2</b> | <b>CLKOUT_M3</b> | <b>CLKOUT_M4</b> | <b>CLKOUT_M5</b> | <b>CLKOUT_M6</b> |
|-------|------------------|------------------|------------------|------------------|------------------|
| DPLL4 | X                | X <sup>(1)</sup> | X                | X                | X                |

<sup>(1)</sup> X represents the DPLL clock output used.

**Table 3-31. Other DPLL Output Clocks**

|       | <b>CLKOUT_M2</b> | <b>CLKOUT_M2X2</b> | <b>CLKOUT_M3X2</b> | <b>CLKOUT_M4X2</b> | <b>CLKOUT_M5X2</b> | <b>CLKOUT_M6X2</b> |
|-------|------------------|--------------------|--------------------|--------------------|--------------------|--------------------|
| DPLL1 | X <sup>(1)</sup> |                    |                    |                    |                    |                    |
| DPLL2 | X                |                    |                    |                    |                    |                    |
| DPLL3 | X                | X                  | X                  |                    |                    |                    |
| DPLL5 | X                |                    |                    |                    |                    |                    |

<sup>(1)</sup> X represents the DPLL clock output used.

### 3.5.3.3.5 Summary

[Table 3-32](#) summarizes the source clocks in the device.

**Table 3-32. Source-Clock Summary**

| <b>Clock</b>       | <b>External/Internal Source</b> | <b>Clock Generator</b> | <b>Description</b>                                                                                               |
|--------------------|---------------------------------|------------------------|------------------------------------------------------------------------------------------------------------------|
| 32K_FCLK           | sys_32k (input pin)             | PRM                    |                                                                                                                  |
| SYS_CLK            | Oscillator                      | PRM                    | System clock. Serves as primary source clock of the device. Also used as functional and interface clock for PRM. |
| DSS_TV_CLK         | DPLL4/sys_altclk (input pin)    | CM                     | DSS TV clock                                                                                                     |
| 120M_FCLK          | DPLL5                           | CM                     |                                                                                                                  |
| 96M_FCLK           | DPLL4                           | CM                     |                                                                                                                  |
| 48M_FCLK           | DPLL4/sys_altclk (input pin)    | CM                     |                                                                                                                  |
| 12M_FCLK           | DPLL4/sys_altclk (input pin)    | CM                     |                                                                                                                  |
| PRM_192M_ALWON_CLK |                                 | DPLL4                  | Direct from DPLL4                                                                                                |
| CORE_CLK           | DPLL3                           | CM                     | DPLL3 clock output frequency                                                                                     |
| COREX2_CLK         | DPLL3                           | CM                     | DPLL3 clock output frequency x 2                                                                                 |
| L3_ICLK            | DPLL3                           | CM                     | L3 interconnect interface clock                                                                                  |
| L4_ICLK            | DPLL3                           | CM                     | L4 interconnect interface clock                                                                                  |
| MPU_CLK            |                                 | DPLL1                  | MPU subsystem source clock                                                                                       |
| IVA2_CLK           |                                 | DPLL2                  | IVA2.2 subsystem source clock                                                                                    |

### 3.5.3.4 Clock Distribution

#### 3.5.3.4.1 Power Domain Clock Distribution

This section describes the PRCM clock distribution over device power domains.

##### 3.5.3.4.1.1 MPU Power Domain

The PRCM module does not directly provide any clock to the MPU power domain. It feeds only DPLL1, which generates MPU\_CLK. All clocks are then locally generated by the clock generator in the MPU subsystem.

[Figure 3-45](#) shows the clocking scheme in the MPU power domain.

**Figure 3-45. MPU Power Domain Clocking Scheme**



prcm-042

---

**NOTE:** ARM\_FCLK is sourced by MPU\_CLK and has the same frequency. (For more information about ARM\_FCLK, see [Chapter 4, MPU Subsystem](#)).

---

##### 3.5.3.4.1.2 IVA2 Power Domain

The PRCM module does not directly provide any clock to the IVA2 power domain. It feeds only DPLL2, which generates IVA2\_CLK. All clocks are then locally generated by a clock generator in the IVA2.2 subsystem.

[Figure 3-46](#) shows the clocking scheme in the IVA2 power domain.

**Figure 3-46. IVA2 Power Domain Clocking Scheme**


prcm-043

### **3.5.3.4.1.3 SGX Power Domain**

This section describes all modules and features in the high-tier device. To save power, ensure that power domains of unavailable features and modules are switched off and clocks are cut off.

The SGX subsystem interface clock is sourced by the L3 clock. The functional clock source can be selected between CORE\_CLK, COREX2\_CLK, CM\_96M\_FCLK and SGX\_192M\_FCLK. When the functional clock source is CORE\_CLK, its frequency can be divided (by 2, 3, 4, or 6). When the functional clock source is COREX2\_CLK, its frequency can be divided (by 3 or 5).

Figure 3-47 shows the clocking scheme in the SGX power domain.

**Figure 3-47. SGX Power Domain Clocking Scheme**

prcm-044

#### 3.5.3.4.1.4 CORE Power Domain

The CORE power domain has L3- and L4-derived clock domains.

The CORE power domain receives several functional clocks (12-, 48-, 96-MHz, system, and 32-kHz) that feed its peripherals and modules, with following exception:

- The McBSP 1 and McBSP 5 modules can be clocked by CORE\_96M\_FCLK from the CM or from an external clock, MCBSP\_CLKS. The SCM manages the selection between the two sources. For more information about the SCM, see [Chapter 13, System Control Module](#).

[Figure 3-48](#) through [Figure 3-50](#) show the clock signals and their relationships in the CORE power domain.

**Figure 3-48. CORE Clock Signals: Part 1**


prcm-045

Figure 3-49. CORE Clock Signals: Part 2



prcm-046

**Figure 3-50. CORE Clock Signals: Part 3**

prcm-047

#### 3.5.3.4.1.5 EFUSE Power Domain

Figure 3-51 shows the clock signals and their relationships in the EFUSE power domain.

**Figure 3-51. EFUSE Clock Signals**

The EFUSE power domain lets the eFuse configuration be saved even when the CORE power domain is off. The EFUSE sense procedure is performed at device power up and on device wakeup from off mode. During this procedure, the PRM enables the EFUSE\_ALWON\_FCLK clock.

#### 3.5.3.4.1.6 DSS Power Domain

This section describes all modules and features in the high-tier device. To save power, ensure that power domains of unavailable features and modules are switched off and clocks are cut off.

Figure 3-52 shows the clock signals and their relationships in the DSS power domain.

**Figure 3-52. DSS Clock Signals**

prcm-049

The DSS subsystem interface is clocked with the L3 and L4 clocks. It receives four functional clocks:

- DSS1\_ALWON\_FCLK: Issued from DPPLL4. Its frequency can be a division by 1 to 16 of the frequency of the DPPLL4 synthesized clock.
- DSS2\_ALWON\_FCLK: The gated SYS\_CLK. Used mainly for display in low-power refresh modes.
- DSS\_TV\_FCLK: Required when TV output is activated

#### 3.5.3.4.1.7 CAM Power Domain

This section describes all modules and features in the high-tier device. To save power, ensure that power domains of unavailable features and modules are switched off and clocks are cut off.

Figure 3-53 shows the clock signals and their relationships in the CAM power domain.

**Figure 3-53. CAM Clock Signals**

prcm-050

The camera subsystem interface is clocked with the L3 and L4 clocks (CAM\_L3\_ICLK and CAM\_L4\_ICLK, respectively). CAM\_L3\_ICLK is also used as the main functional clock. The functional clock (CAM\_MCLK) is provided by DPLL4 to supply the external sensor.

#### 3.5.3.4.1.8 USBHOST Power Domain

Figure 3-54 shows the clock signals and their relationships in the USBHOST power domain.

**Figure 3-54. USBHOST Clock Signals**



prcm-090

The HS USB host subsystem interface is clocked with the L3 and L4 clocks (USBHOST\_L3\_ICLK and USBHOST\_L4\_ICLK, respectively).

The HS USB host subsystem requires two functional clocks (USBHOST\_120M\_FCLK and USBHOST\_48M\_FCLK) that may or may not be requested simultaneously. Therefore, they are gated independently based on the configuration of the [CM\\_FCLKEN\\_USBHOST\[0\]](#) EN\_USBHOST1 and [CM\\_FCLKEN\\_USBHOST\[1\]](#) EN\_USBHOST2 bits.

The HS USB host subsystem gets an additional functional clock from the PRM (USBHOST\_SAR\_FCLK). It is dedicated to the save-and-restore mechanism and is automatically gated/enabled by the PRM, based on the HS USB host save-and-restore bit configuration (the [PM\\_PWSTCTRL\\_USBHOST\[4\]](#) SAVEANDRESTORE bit) and on the USBHOST power domain state transitions.

#### 3.5.3.4.1.9 WKUP Power Domain

[Figure 3-55](#) shows the clock signals and their relationships in the WKUP power domain.

**Figure 3-55. WKUP Clock Signals**

prcm-051

All clocks in the WKUP power domain are generated by the PRM. The functional clock GPT1\_FCLK of GPTIMER1 can be selected as SYS\_CLK or 32K\_FCLK. The 32-kHz sync timer, WDTIMER2, and GPIO1 receive 32K\_FCLK as their functional clock. This is the low-frequency always-on clock.

The voltage controller module in the PRM receives SYS\_CLK as its functional clock. The dedicated SmartReflex I2C4 module implemented in the voltage controller uses the same functional clock (SYS\_CLK).

The PRM receives SYS\_CLK as the L4 interface clock. For all other modules of the WKUP power domain, the L4 interface clock WKUP\_L4\_ICLK is derived from SYS\_CLK. Communication between the WKUP power domain and CORE L4 interconnects is asynchronous.

#### 3.5.3.4.1.10 PER Power Domain

Figure 3-56 shows the clock signals and their relationships in the PER power domain.

**Figure 3-56. PER Clock Signals**


prcm-052

The PER power domain receives several functional clocks (48M\_FCLK, 96M\_ALWON\_FCLK, SYS\_CLK, and 32K\_FCLK) that feed its peripherals and modules. All the functional clocks (except 48M\_FCLK) are permanently supplied so that the peripherals can be used during low-power scenarios, even when the CORE power domain is off. [Figure 3-56](#) shows the clock distribution scheme in the PER power domain.

The McBSP 2, 3, and 4 modules can be clocked by a clock from PRM (PER\_96M\_FCLK) or from an external clock (MCBSP\_CLKS). This clock must be permanently buffered from the pad to the PER power domain. The device SCM manages the selection between the two (see [Chapter 13, System Control Module](#)).

#### 3.5.3.4.1.11 SMARTREFLEX Power Domain

The two SmartReflex modules in the device have a common L4 interface clock (SR\_L4\_ICLK) and a functional clock (SR\_ALWON\_FCLK) (see [Figure 3-57](#)).

**Figure 3-57. SMARTREFLEX Clock Signals**

prcm-053

### 3.5.3.4.1.12 DPLL Domains

The PRCM module provides clock sources for the five DPLLs, as shown in [Figure 3-58](#).

**Figure 3-58. DPLL Clock Signals**


prcm-054

The PRCM module also manages clock-gating control for these DPLL outputs.

The MPU and IVA2 processors use clock outputs locally in their respective subsystems. The CM uses the DPLL3 clock outputs to generate all interface clocks and some functional clocks. The CM uses two of the five clocks generated by DPLL4 and one clock output of DPLL5 to generate functional clocks for the peripheral domain modules. The remaining three clocks of DPLL4 are propagated to their corresponding modules.

### 3.5.3.4.2 Clock Distribution Summary

#### 3.5.3.4.2.1 Power Domain Source Clocks

[Table 3-33](#) summarizes clock distribution for each power domain. The clock type indicates whether a clock is supplied when the CM (CORE power domain) is off. "Normal" means that the clock is gated when the power domain is off, while the always-on clock remains active even when the CORE power domain is off.

**Table 3-33. Clock Distribution**

| Power Domain | Clock              | Generator | Type      | Destination                                                                                                                                                                 |
|--------------|--------------------|-----------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MPU          | MPU_CLK            | DPLL1     | Normal    | MPU subsystem                                                                                                                                                               |
| NEON         |                    |           |           | NEON                                                                                                                                                                        |
| IVA2         | IVA2_CLK           | DPLL2     | Normal    | IVA2.2 subsystem                                                                                                                                                            |
| SGX          | SGX_FCLK           | CM        | Normal    | SGX subsystem                                                                                                                                                               |
|              | SGX_L3_ICLK        | CM        | Normal    |                                                                                                                                                                             |
| CORE         | CORE_120M_FCLK     | CM        | Normal    | USB TLL                                                                                                                                                                     |
|              | CORE_96M_FCLK      | CM        | Normal    | McBSP[1,5], MMC[1,2,3], I2C[1,2,3]                                                                                                                                          |
|              | CORE_48M_FCLK      | CM        | Normal    | UART[1,2], McSPI[1..4]                                                                                                                                                      |
|              | CORE_12M_FCLK      | CM        | Normal    | HDQ                                                                                                                                                                         |
|              | GPT10_FCLK         | CM        | Normal    | GPTIMER10                                                                                                                                                                   |
|              | GPT11_FCLK         | CM        | Normal    | GPTIMER11                                                                                                                                                                   |
|              | USBTLL_SAR_FCLK    | PRM       | Normal    | USB TLL                                                                                                                                                                     |
|              | CM_32K_CLK         | PRM       | Normal    | Temperature sensor (x2), MMC[1,2,3]                                                                                                                                         |
|              | CORE_L3_ICLK       | CM        | Normal    | L3 interconnect, SDMA, MPU async bridge (slave), IVA2 async bridge 1 (slave), IVA2 async bridge 2 (master), HS USB, SMS, GPMC, OCM ROM, SDRC, OCM RAM, CORE L3 interconnect |
|              | CORE_L4_ICLK       | CM        | Normal    | L3 interconnect, SDMA, HS USB, ICR, McBSP[1,5], MMC[1,2], I2C[1..3], GPTIMER [10,11], UART[1,2], McSPI[1..4], HDQ, CORE L4 interconnect, MAILBOXES, SCM                     |
| DSS          | DSS_TV_FCLK        | CM        | Normal    | DSS, VDAC                                                                                                                                                                   |
|              | DSS1_ALWON_FCLK    | DPLL4     | Always-on | DSS                                                                                                                                                                         |
|              | DSS2_ALWON_FCLK    | PRM       | Always-on |                                                                                                                                                                             |
|              | DSS_L3_ICLK        | CM        | Normal    |                                                                                                                                                                             |
|              | DSS_L4_ICLK        | CM        | Normal    |                                                                                                                                                                             |
| CAM          | CAM_MCLK           | DPLL4     | Normal    | Camera subsystem                                                                                                                                                            |
|              | CAM_L3_ICLK        | CM        | Normal    | Camera subsystem, CSI2 interface                                                                                                                                            |
|              | CAM_L4_ICLK        | CM        | Normal    | Camera subsystem                                                                                                                                                            |
|              | CSI2_96M_FCLK      | CM        | Normal    | CSI2 interface                                                                                                                                                              |
| PER          | 96M_ALWON_FCLK     | PRM       | Always-on | McBSP[2..4]                                                                                                                                                                 |
|              | PER_48M_FCLK       | CM        | Normal    | UART[3, 4]                                                                                                                                                                  |
|              | PER_32K_ALWON_FCLK | CM        | Always-on | WDTIMER3, GPIO[2..6],                                                                                                                                                       |
|              | GPT2_ALWON_FCLK    | PRM       | Always-on | GPTIMER2                                                                                                                                                                    |

**Table 3-33. Clock Distribution (continued)**

| Power Domain | Clock            | Generator | Type      | Destination                                                                             |
|--------------|------------------|-----------|-----------|-----------------------------------------------------------------------------------------|
|              | GPT3_ALWON_FCLK  | PRM       | Always-on | GPTIMER3                                                                                |
|              | GPT4_ALWON_FCLK  | PRM       | Always-on | GPTIMER4                                                                                |
|              | GPT5_ALWON_FCLK  | PRM       | Always-on | GPTIMER5                                                                                |
|              | GPT6_ALWON_FCLK  | PRM       | Always-on | GPTIMER6                                                                                |
|              | GPT7_ALWON_FCLK  | PRM       | Always-on | GPTIMER7                                                                                |
|              | GPT8_ALWON_FCLK  | PRM       | Always-on | GPTIMER8                                                                                |
|              | GPT9_ALWON_FCLK  | PRM       | Always-on | GPTIMER9                                                                                |
|              | PER_L4_ICLK      | CM        | Normal    | UART[3, 4], PER L4 interconnect,<br>WDTIMER3, GPIO[2..6],<br>GPTIMER[2..9], McBSP[2..4] |
| WKUP         | WKUP_32K_FCLK    | PRM       | Always-on | WDTIMER2, GPIO1                                                                         |
|              | 32K_FCLK         | PRM       | Always-on | 32-kHz sync timer                                                                       |
|              | GPT1_FCLK        | PRM       | Always-on | GPTIMER1                                                                                |
|              | WKUP_L4_ICLK     | PRM       | Normal    | WKUP L4 interconnect, GPTIMER1,<br>32-kHz sync timer, GPIO1, WDTIMER2                   |
| SMARTREFLEX  | SR_ALWON_FCLK    | PRM       | Always-on | SR1, SR2                                                                                |
|              | SR_L4_ICLK       | CM        | Normal    | SR1, SR2                                                                                |
| EFUSE        | EFUSE_ALWON_FCLK | PRM       | Always-on | eFuse farm                                                                              |
| DPLL1        | DPLL1_ALWON_FCLK | PRM       | Always-on | DPLL1                                                                                   |
|              | DPLL1_FCLK       | CM        | Normal    |                                                                                         |
| DPLL2        | DPLL2_ALWON_FCLK | PRM       | Always-on | DPLL2                                                                                   |
|              | DPLL2_FCLK       | CM        | Normal    |                                                                                         |
| DPLL3        | DPLL3_ALWON_FCLK | PRM       | Always-on | DPLL3                                                                                   |
| DPLL4        | DPLL4_ALWON_FCLK | PRM       | Always-on | DPLL4                                                                                   |
| DPLL5        | DPLL5_ALWON_FCLK | PRM       | Always-on | DPLL5                                                                                   |

**NOTE:**

- Modules supplied only by the L3 interface clock:
  - MPU asynchronous bridge
  - IVA2.2 asynchronous bridges
  - All memory controllers (OCM ROM, OCM RAM, SDRC, SMS, and GPMC)
- Modules that require L3 and L4 clocks:
  - SDMA
  - HS USB
- Modules fed by the L4 clock:
  - SCM
  - Mailboxes
  - ICR
  - Modem INTC
  - All peripherals (McBSP1, McBSP5, MMC1, MMC2, MMC3, I2C1, I2C2, I2C3, McSPI1, McSPI2, McSPI3, McSPI4, UART1, UART2, HDQ, GPTIMER10, GPTIMER11, McBSP2, McBSP3, McBSP4, UART3, UART4, GPIO2, GPIO3, GPIO4, GPIO5, GPIO6, WDT3, GPTIMER2, GPTIMER3, GPTIMER4, GPTIMER5, GPTIMER6, GPTIMER7, GPTIMER8 and GPTIMER9)

**NOTE:** The system clock version provided to the DPLL4 can be pre-divided by a factor of 6.5 before feeding the DPLL4. This is done in the PRM through a dedicated programmable register. This divider is intended to be used in case a 13-MHz system clock is used so that the DPLL4 can be locked at 864 MHz.

### 3.5.3.4.2.2 Peripheral Module Clocks

**Table 3-34** lists the peripherals, DSS, and CAM functional clock frequency requirements. These frequencies must be operational over the full VDD2 voltage range.

**Table 3-34. Peripheral Module Functional Clock Frequencies**

| Module              | Functional Clock   | Frequency                                                                           |
|---------------------|--------------------|-------------------------------------------------------------------------------------|
| MMC-SDIO[1,2,3]     | 96M_FCLK           | 96 MHz                                                                              |
| McBSP[1, 5]         | 96M_FCLK           | 96 MHz                                                                              |
| CAM                 | CAM_MCLK           | Up to 216 MHz                                                                       |
| McSPI[1..4]         | CORE_48M_FCLK      | 48 MHz                                                                              |
| UART[1..4]          |                    |                                                                                     |
| Display subsystem   | DSS1_ALWON_FCLK    | Up to 173 MHz at nominal voltage (OPP100), and up to 100 MHz at low voltage (OPP50) |
|                     | DSS2_ALWON_FCLK    | System clock                                                                        |
|                     | DSS_TV_FCLK        | 54 MHz                                                                              |
| SGX                 | SGX_FCLK           | Up to 200 MHz                                                                       |
| I2C[1..3]           | CORE_96M_FCLK      | 96 MHz                                                                              |
| HDQ                 | CORE_12M_FCLK      | 12 MHz                                                                              |
| GPTIMER1            | GPT1_FCLK          | 32-kHz (p) or system clock                                                          |
| GPTIMER[2..9]       | GPTn_ALWON_FCLK    | 32-kHz (p) or system clock                                                          |
| GPTIMER[10, 11]     | GPTn_FCLK          | 32-kHz or system clock                                                              |
| ICR                 |                    |                                                                                     |
| WDTIMER2            | WKUP_32K_FCLK      | 32 kHz                                                                              |
| WDTIMER3            | PER_32K_ALWON_FCLK | 32 kHz                                                                              |
| GPIO1               | WKUP_32K_FCLK      | 32 kHz                                                                              |
| GPIO[2-6]           | PER_32K_ALWON_FCLK | 32 kHz                                                                              |
| 32-kHz sync timer   | 32K_FCLK           | 32 kHz (p)                                                                          |
| Bandgap/temp sensor | 32K_FCLK           | 32 kHz (p)                                                                          |
| System control      | CORE_L4_ICLK       | L4_ICLK                                                                             |

### 3.5.3.5 External Clock Controls

Because the use of sys\_32k and sys\_altclk is described in [Section 3.5.3.3.1, PRM](#), and [Section 3.5.3.3.2, CM](#), these clock signals are not discussed here. This section discusses the remaining external clock signals.

#### 3.5.3.5.1 Clock Request (sys\_clkreq) Control

The system clock request signal sys\_clkreq is bidirectional.

In bypass mode in the system clock oscillator (see [Section 3.5.3.5.2](#)), it is an output signal driven by the device to request an external clock. In this case, the output buffer is driven as long as the system clock is requested by the device; otherwise, it remains in high impedance. In this way, other external peripherals can share the same clock request signal with the device.

If the [PRM\\_POLCTRL\[1\] CLKREQ\\_POL](#) bit = 1, the software must configure the SCM to select the internal pulldown on the sys\_clkreq pad, or an external pulldown is connected to the pad.

If the [PRM\\_POLCTRL\[1\]](#) CLKREQ\_POL bit = 0, the internal pullup on the sys\_clkreq pad, or an external pull-up, is connected to the pad.

In master mode in the system clock oscillator (see [Section 3.5.3.5.2](#)), sys\_clkreq is an input.

If the [PRM\\_POLCTRL\[1\]](#) CLKREQ\_POL bit = 1, the software must configure the SCM to select the internal pulldown on the sys\_clkreq pad, or an external pulldown is connected to the pad.

If the [PRM\\_POLCTRL\[1\]](#) CLKREQ\_POL bit = 0, the internal pullup on the sys\_clkreq pad, or an external pullup, is connected to the pad.

The PRCM.PRM\_POLCTRL[1] CLKREQ\_POL bit allows software control over the polarity of sys\_clkreq. This software setting takes effect when the clock is requested by the device, and also when the clock request is driven externally. The output buffer is driven directly by this register when the clock request comes from device.

[Table 3-35](#) describes the bidirectional control of the sys\_clkreq pad.

**Table 3-35. sys\_clkreq Pad Direction Control**

| Oscillator Mode | Sys_boot 6 | Internal Clock Request (Always Active-High) | External Clock Request (Note: polarity depends on CLKREQ_POL) | Sys_clkreq Direction                                                                                       | Description                                                                                       |
|-----------------|------------|---------------------------------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| Master mode     | 0          | 0                                           | 0 <sup>(1)</sup>                                              | Input (output buffer in Hi-Z)<br><br><b>Note:</b> Input is not driven from outside of device in this case. | The clock is not requested internally (by the device) or externally (external device/peripheral). |
|                 | 0          | 0                                           | 1 <sup>(1)</sup>                                              | Input (output buffer in Hi-Z)                                                                              | The clock is requested externally.                                                                |
|                 | 0          | 1                                           | 0 <sup>(1)</sup>                                              | Output                                                                                                     | The clock is requested internally.                                                                |
|                 | 0          | 1                                           | 1 <sup>(1)</sup>                                              | Output<br><br><b>Note:</b> The pad is driven both by device and from outside of device in this case.       | The clock is requested internally and externally.                                                 |
| Bypass mode     | 1          | 0                                           | 0 <sup>(1)</sup>                                              | Input (output buffer in Hi-Z)<br><br><b>Note:</b> Input is not driven from outside of device in this case. | The clock is not requested internally or externally.                                              |
|                 | 1          | 0                                           | 1 <sup>(1)</sup>                                              | Input (output buffer in Hi-Z)                                                                              | The clock is requested externally.                                                                |
|                 | 1          | 1                                           | 0 <sup>(1)</sup>                                              | Output                                                                                                     | The clock is requested internally.                                                                |
|                 | 1          | 1                                           | 1 <sup>(1)</sup>                                              | Output<br><br><b>Note:</b> The pad is driven by device and from outside of device in this case.            | The clock is requested internally and externally.                                                 |

<sup>(1)</sup> Case when PRM\_POLCTRL.CLKREQ\_POL = 1 (sys\_clkreq active high). If PRM\_POLCTRL.CLKREQ\_POL = 0 (sys\_clkreq active low), these values should be inverted in [Table 3-35](#).

### 3.5.3.5.2 System Clock Oscillator Control

Depending on the hardware configuration, the device can receive the system clock from an external source or generate it locally using the internal system clock crystal oscillator. Thus, the device oscillator has two possible operating modes:

- Master (oscillator enable) mode: The oscillator is enabled and connected to an external quartz. It provides the system clock to the device. The oscillator is activated on a device wakeup or on an external clock request. It is set to the power-down (off) state when the device switches to off mode (see [Table 3-37](#)), except when the external system clock request is active on sys\_clkreq pin.
- Bypass (oscillator inactive) mode: The system clock is supplied by an external device and the oscillator is always set in bypass mode. The oscillator is insensitive to the external system clock request on the sys\_clkreq pin.

**NOTE:** An external pullup or pulldown tied on the sys\_boot6 input pin of the device determines whether the oscillator is in master or bypass mode. See [Section 3.3.1, External Clock Signals](#).

When operating in master mode, the device receives an external clock request (sys\_clkreq) and provides the oscillator clock (OSC\_SYS\_CLK) to external peripherals through the sys\_clkout1 pin; in bypass mode, the device generates a clock request to the external clock source to request the system clock.

The selected mode of the oscillator can be read from the PRCM.[PRM\\_CLKSRC\\_CTRL\[1:0\]](#) SYSCLKSEL bit field.

Regardless of oscillator mode, the oscillator can be powered down when the device enters inactive, retention or off mode, unless an external system clock request is active (from the sys\_clkreq pin). This setting is configured in the PRCM.[PRM\\_CLKSRC\\_CTRL\[4:3\]](#) AUTOEXTCLKMODE bit field. [Table 3-37](#) lists the four possible operation modes of the system clock.

**Table 3-36. System Clock Operation Modes**

| AUTOEXTCLKMODE | System Clock Mode                                    | Oscillator Mode | Description                                                                                                                                                                              |
|----------------|------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0            | Always-active mode                                   | Master          | The oscillator is kept active even when the clock is not requested by the device internally (all device clocks are inactive) or externally (the sysclkreq input signal is not asserted). |
|                |                                                      | Bypass          | The sys_clkreq output signal is permanently asserted by the device, regardless of its internal clock states (active or inactive).                                                        |
| 0x1            | Off when device in inactive, retention, or off state | Master          | The oscillator is switched to off mode when the device is in inactive, retention, or off mode and the sys_clkreq input signal is not asserted.                                           |
|                |                                                      | Bypass          | The sys_clkreq output signal is deasserted when the device is in idle, retention, or off mode.                                                                                           |
| 0x2            | Off when device in retention or off state            | Master          | The oscillator is switched to off mode when the device is in retention or off mode and the sys_clkreq input signal is not asserted.                                                      |
|                |                                                      | Bypass          | The sys_clkreq output signal is deasserted when the device is in retention or off mode.                                                                                                  |
| 0x3            | Off when device in off state                         | Master          | The oscillator is switched to off mode when the device is in off mode and the sys_clkreq input signal is not asserted.                                                                   |
|                |                                                      | Bypass          | The sys_clkreq output signal is deasserted when the device is in off mode.                                                                                                               |

To exit power-down mode, the oscillator requires a device wakeup or an external clock request.

The device allows configuring of the system clock stabilization time to ensure a stable system clock in the device. This delay is configured in the PRCM.[PRM\\_CLKSETUP\[15:0\]](#) SETUP\_TIME bit field.

[Figure 3-59](#) shows the system clock oscillator controls in the device.

**Figure 3-59. System Clock Oscillator Controls**


[Table 3-37](#) lists the oscillator controls.

**Table 3-37. Oscillator Controls**

| Oscillator Mode | Internal Clock Request <sup>(1)</sup> | External Clock Request <sup>(1)</sup> | Oscillator State | sys_clkreq Pad Direction                                                                                              | sys_clkreq <sup>(1)</sup>    | Description                                                                                                   |
|-----------------|---------------------------------------|---------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------|------------------------------|---------------------------------------------------------------------------------------------------------------|
| Master          | Not asserted                          | Not asserted                          | Off              | Input and output                                                                                                      | Not asserted                 | System clock not requested internally (within the device) or externally (by an external device or peripheral) |
|                 | Not asserted                          | Asserted                              | Active           | Input                                                                                                                 | Asserted                     | System clock is requested externally only.                                                                    |
|                 | Asserted                              | Not asserted                          | Active           | Output                                                                                                                | Asserted                     | System clock is requested internally only.                                                                    |
|                 | Asserted                              | Asserted                              | Active           | Input and output (driven internally by device and externally by peripheral)                                           | Asserted                     | System clock is requested internally and externally.                                                          |
| Bypass          | Not asserted                          | x <sup>(2)</sup>                      | Bypass           | Input and output (when external request is not asserted) or input (when external request is asserted)                 | External clock request state | System clock is not requested internally (sys_clkreq input has no effect).                                    |
|                 | Asserted                              | x <sup>(2)</sup>                      | Bypass           | Output (when only internal request is asserted) or input and output (when external and internal request are asserted) | Asserted                     | System clock is requested internally (sys_clkreq input has no effect).                                        |

<sup>(1)</sup>

- If the PRCM.PRM\_POLCTRL[1] CLKREQ\_POL is set to active high (0x1), Asserted = 1, and Not asserted = 0.
- If the PRCM.PRM\_POLCTRL[1] CLKREQ\_POL is set to active low (0x0), Asserted = 0, and Not asserted = 1.

<sup>(2)</sup> x indicates that the signal may be asserted or not asserted.

### 3.5.3.5.3 External Output Clock1 (sys\_clkout1) Control

The sys\_clkout1 clock is active if the oscillator clock (OSC\_SYS\_CLK) is active (stable) and an external system clock request is active. It can be gated by programming the PRCM.PRM\_CLKOUT\_CTRL[7] CLKOUT\_EN bit. The polarity of the sys\_clkout1 signal, when the clock is gated, is controllable by programming the PRCM.PRM\_POLCTRL[2] CLKOUT\_POL bit.

When the device is in standby mode, SYS\_CLK and sys\_clkout1 are disabled. In this case, reactivation of sys\_clkout1 depends on the oscillator mode:

- Oscillator in active mode (sys\_boot6 is 0): The sys\_clkout1 clock can be reactivated (after oscillator stabilization), provided its gating was enabled by programming the PRCM.PRM\_CLKOUT\_CTRL[7] CLKOUT\_EN bit and asserting an external clock request. This activation does not generate a device wake-up event; an external clock request activates only the internal SYS\_CLK oscillator and sys\_clkout1.
- Oscillator in bypass mode (sys\_boot6 is 1): The sys\_clkout1 clock can be reactivated only after the device wakes up (on any wake-up event) and SYS\_CLK is active. When the device is active, SYS\_CLK is running and sys\_clkout1 is enabled as soon as requested by software.

### 3.5.3.5.4 External Output Clock2 (sys\_clkout2) Control

A second output clock, sys\_clkout2, is generated with a frequency that can be the source-clock frequency divided by 1, 2, 4, 8, or 16. Its source clock can be CORE\_CLK, CM\_SYS\_CLK, 96 MHz, or 54 MHz. Unlike sys\_clkout1, this second external clock is not active when the device is in off power mode. Also, the selected source clock must be enabled by software. Enabling sys\_clkout2 does not automatically request the required source clock. The polarity of the sys\_clkout2 signal, when the clock is gated, is controllable by programming the PRCM.CM\_POLCTRL[0] CLKOUT2\_POL bit.

### 3.5.3.6 DPLL Control

The PRCM module allows the configuration of the output clock frequencies of the DPLLs by setting their multipliers and dividers. It also allows control of the operating mode of the DPLLs and automatic recalibration mode.

#### 3.5.3.6.1 DPLL Multiplier and Divider Factors

DPLL clock outputs are set by programming the corresponding multiplier and divider factors M, N, M2, M3, M4, M5, and M6. [Table 3-38](#) lists the register bit fields for configuration of the multiplier and divider factors for the DPLLs.

**Table 3-38. DPLL Multiplier and Divider Factors**

|    | DPLL1                                            | DPLL2                                              | DPLL3                                           | DPLL4                                      | DPLL5                                       |
|----|--------------------------------------------------|----------------------------------------------------|-------------------------------------------------|--------------------------------------------|---------------------------------------------|
| M  | PRCM.CM_CLKSEL1_PLL_MPU[18:8] MPU_DPLL_MULT      | PRCM.CM_CLKSEL1_PLL_IVA2[18:8] IVA2_DPLL_MULT      | PRCM.CM_CLKSEL1_PLL[26:16] CORE_DPLL_MULT       | PRCM.CM_CLKSEL2_PLL[18:8] PERIPH_DPLL_MULT | PRCM.CM_CLKSEL4_PLL[18:8] PERIPH2_DPLL_MULT |
| N  | PRCM.CM_CLKSEL1_PLL_MPU[6:0] MPU_DPLL_DIV        | PRCM.CM_CLKSEL1_PLL_IVA2[6:0] IVA2_DPLL_DIV        | PRCM.CM_CLKSEL1_PLL[14:8] CORE_DPLL_DIV         | PRCM.CM_CLKSEL2_PLL[6:0] PERIPH_DPLL_DIV   | PRCM.CM_CLKSEL4_PLL[6:0] PERIPH2_DPLL_DIV   |
| M2 | PRCM.CM_CLKSEL2_PLL_MPU[4:0] MPU_DPLL_CLKOUT_DIV | PRCM.CM_CLKSEL2_PLL_IVA2[4:0] IVA2_DPLL_CLKOUT_DIV | PRCM.CM_CLKSEL1_PLL[31:27] CORE_DPLL_CLKOUT_DIV | PRCM.CM_CLKSEL3_PLL[4:0] DIV_96M           | PRCM.CM_CLKSEL5_PLL[4:0] DIV_120M           |
| M3 | Not used                                         | Not used                                           | PRCM.CM_CLKSEL1_EMU[21:16] DIV_DPLL3            | PRCM.CM_CLKSEL_DSS[13:8] CLKSEL_TV         | Not used                                    |
| M4 | Not used                                         | Not used                                           | Not used                                        | PRCM.CM_CLKSEL_DSS[5:0] CLKSEL_DSS1        | Not used                                    |
| M5 | Not used                                         | Not used                                           | Not used                                        | PRCM.CM_CLKSEL_CAM[5:0] CLKSEL_CAM         | Not used                                    |
| M6 | Not used                                         | Not used                                           | Not used                                        | PRCM.CM_CLKSEL1_EMU[29:24] DIV_DPLL4       | Not used                                    |

#### 3.5.3.6.2 DPLL Modes

DPLL supports several power modes (see [Table 3-39](#)). Each mode results in a tradeoff between power savings and relock time.

**Table 3-39. DPLL Power Modes**

| Mode               | Clock Input | Clock Output     | DPLL Power State | Power Consumption | Latency                    |
|--------------------|-------------|------------------|------------------|-------------------|----------------------------|
| Locked             | On          | Lock frequency   | ON               | Maximum           | N/A                        |
| Low-power bypass   | On          | Bypass frequency | ON               | Less than locked  | Same as low-power stop     |
| Fast-relock bypass | On          | Bypass frequency | ON               | Less than locked  | Less than low-power bypass |
| Low-power stop     | On          | Bypass frequency | ON               | Less than locked  | Same as low-power bypass   |
| MN bypass          | On          | Bypass frequency | ON               | Less than locked  | Maximum                    |
| Off                | Off         | Off              | Off              | Minimum           | Maximum                    |

A DPLL power mode can be achieved on a software request (manual) and/or automatically (automatic), depending on the specific hardware conditions. After a device power-on reset, the DPLL can be kept in low-power stop mode (DPLL2 , DPLL4, and DPLL5) or MN bypass mode (DPLL1 and DPLL3).

A DPLL can switch from one mode to the other as a result of the following:

- Software-programmed transition only (manual): The software configures a dedicated register for the next desired DPLL mode. It must ensure that the transition can be performed based on the activity on the device.
- Combined software-programmed and hardware-conditions-based transition (automatic): The PRCM module triggers the transition when the software requests it (by configuring the registers) and the hardware conditions are satisfied. When the hardware conditions are no longer met, the PRCM module triggers the return transition.

For automatic transition, automatic mode must be enabled by programming the PRCM.[CM\\_AUTOIDLE\\_PLL](#) or the PRCM.[CM\\_AUTOIDLE\\_PLL\\_processor\\_name](#) registers.

[Table 3-40](#) describes the manual and automatic control of the DPLL power modes by the PRCM module.

**Table 3-40. DPLL Power Mode Support**

| Mode               | DPLL1                                                  | DPLL2                                                                                           | DPLL3                                                                    | DPLL4                                                                                                                           | DPLL5                                                                                                                                           |
|--------------------|--------------------------------------------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Locked             | Software request (manual) or MPU wakes up (automatic). | Software request (manual) or IVA2.2 wakes up (automatic).                                       | Software request (manual) or CORE wakes up (automatic).                  | Software request (manual) or at least one peripheral clock is used (automatic).                                                 | Software request (manual) or at least one peripheral clock is used (automatic).                                                                 |
| Low-power bypass   | Software request (manual)                              | Software request (manual)                                                                       | Software request (manual) or all interface clocks are gated (automatic). | N/A                                                                                                                             | N/A                                                                                                                                             |
| Fast-relock bypass | N/A                                                    | N/A                                                                                             | Software request (manual)                                                | N/A                                                                                                                             | N/A                                                                                                                                             |
| Low-power stop     | MPU is idle (automatic).                               | Software request (manual) or IVA2.2 is idle (automatic) or on global reset release (automatic). | Device is idle (automatic).                                              | (Default state) Software request (manual) or all functional clocks from DPLL are unused or on global reset release (automatic). | (Default state) Software request (manual) or all functional clocks from DPLL (120-MHz clock) are unused or on global reset release (automatic). |
| MN bypass          | Global reset (automatic)                               | N/A                                                                                             | Global reset (automatic)                                                 | N/A                                                                                                                             | N/A                                                                                                                                             |
| Off                | Device off (automatic)                                 | Device off (automatic)                                                                          | Device off (automatic)                                                   | Device off (automatic)                                                                                                          | Device off (automatic)                                                                                                                          |

---

**NOTE:** DPLL1 and DPLL3 cannot be manually forced to switch to low-power stop mode from any other power mode. They must be in Locked state with automatic transition to low-power stop mode configured and the hardware condition for the transition (identified in [Table 3-40](#)) must be satisfied, in order to switch to the low-power stop mode.

---

[Table 3-41](#) lists the bit fields that must be programmed for manual and automatic mode control of the five DLLs.

**Table 3-41. DPLL Power Mode Control**

| Mode  | Manual Control                              | Auto Control                                  |
|-------|---------------------------------------------|-----------------------------------------------|
| DPLL1 | PRCM.CM_CLKEN_PLL_MPU[2:0]<br>EN_MPU_DPLL   | PRCM.CM_AUTOIDLE_PLL_MPU[2:0] AUTO_MPU_DPLL   |
| DPLL2 | PRCM.CM_CLKEN_PLL_IVA2[2:0]<br>EN_IVA2_DPLL | PRCM.CM_AUTOIDLE_PLL_IVA2[2:0] AUTO_IVA2_DPLL |
| DPLL3 | PRCM.CM_CLKEN_PLL[2:0]<br>EN_CORE_DPLL      | PRCM.CM_AUTOIDLE_PLL[2:0] AUTO_CORE_DPLL      |
| DPLL4 | PRCM.CM_CLKEN_PLL[18:16]<br>EN_PERIPH_DPLL  | PRCM.CM_AUTOIDLE_PLL[5:3] AUTO_PERIPH_DPLL    |
| DPLL5 | PRCM.CM_CLKEN2_PLL[2:0]<br>EN_PERIPH2_DPLL  | PRCM.CM_AUTOIDLE2_PLL[2:0] AUTO_PERIPH2_DPLL  |

---

**NOTE:** The DPLL automatically enters locked mode on a power domain wakeup only if the DPLL is locked before the sleep transition and one of the automatic modes is enabled.

---

### 3.5.3.6.3 DPLL Low-Power Mode

The LPMODE control enables the optimization of power consumption of the module in the combination of low input frequency and low output frequency. It is recommended that this mode be enabled for cases in which CLKINP / (N + 1) ≤ 1 MHz and CLKINP × M / (N + 1) ≤ 100 MHz conditions are verified.

However, the period jitter increases from peak-peak by ±0.5% of the clock period when LPMODE is enabled.

The LPMODE programming bit must not be changed on the fly when in locked condition. INITIALIZATION should follow after changing the LPMODE bit.

Software can enable/disable automatic switching of the DPLL between normal mode and low-power mode. The new mode is effective only after the DPLL is relocked. Low-power mode control is considered only during the following transitions:

- Bypass mode to lock
- Stop mode to lock
- Lock to relock

[Table 3-42](#) lists the bit fields that must be programmed for manual control of DPLL1, DPLL2, DPLL3, and DPLL5 (LPMODE is not supported by DPLL4).

**Table 3-42. LP Mode Control**

| Mode  | Manual Control                                 |
|-------|------------------------------------------------|
| DPLL1 | PRCM.CM_CLKEN_PLL_MPU[10] EN_MPU_DPLL_LPMODE   |
| DPLL2 | PRCM.CM_CLKEN_PLL_IVA2[10] EN_IVA2_DPLL_LPMODE |
| DPLL3 | PRCM.CM_CLKEN_PLL[10] EN_CORE_DPLL_LPMODE      |
| DPLL5 | PRCM.CM_CLKEN2_PLL[10] EN_PERIPH2_DPLL_LPMODE  |

### 3.5.3.6.4 DPLL Clock Path Power Down

DPLL3 and DPLL4 can power down the CLKOUTX2 path. A small section of logic is powered down, because the M2 post divider is shared with the CLKOUT path, which remains functional.

The HSDIVIDER can power down each CLKOUT $n$  path (with  $n$  in the range of 3 to 6) independently, therefore allowing further power savings. The clock output path is also powered down when the DPLL is in stop mode, regardless of the software setting.

Software must ensure correct sequencing of the control. To avoid a glitch at the output, activate this control when the clock is not required, and when the output clock is gated. Conversely, ensure a delay between deactivation and reactivation of the clock by using the power-down control.

[Table 3-43](#) lists the bit fields and the corresponding clock outputs of the DPLLS.

**Table 3-43. Clock Path Power-Down Control**

| DPLL  | Control Bit Field                      | Clock Path                                |
|-------|----------------------------------------|-------------------------------------------|
| DPLL4 | PRCM.CM_CLKEN_PLL[27] PWRDN_96M        | 96-MHz clock output (DPLL4 output M2)     |
|       | PRCM.CM_CLKEN_PLL[28] PWRDN_TV         | DSS TV clock output (DPLL4 output M3)     |
|       | PRCM.CM_CLKEN_PLL[29] PWRDN_DSS1       | DSS1 clock output (DPLL4 output M4)       |
|       | PRCM.CM_CLKEN_PLL[30] PWRDN_CAM        | CAM clock output (DPLL4 output M5)        |
|       | PRCM.CM_CLKEN_PLL[31] PWRDN_EMU_PERIPH | EMU_PERIPH clock output (DPLL4 output M6) |
| DPLL3 | PRCM.CM_CLKEN_PLL[12] PWRDN_EMU_CORE   | EMU_CORE clock output (DPLL3 output M3X2) |

### 3.5.3.6.5 Recalibration

A lock sequence occurs during an initial lock or during a relock following a new multiplier or divider value. Each time the DPLL is reset or performs a lock sequence, it performs a recalibration of the output frequency, based on voltage and temperature conditions. By compensating for voltage and temperature changes within a certain range, calibration allows the lock frequency to remain steady. If the voltage or temperature drifts outside the acceptable range, the DPLL asserts a recalibration flag.

For example, a large temperature drift can cause the DPLL to lose its lock and require recalibration. When the DPLL locks at a temperature within the 080 degrees Celsius range, the maximum temperature drift is approximately 55 degrees Celsius. When DPLL starts at a negative temperature, the maximum temperature drift is higher.

If the DPLL locks at 30 degrees Celsius, the temperature can change by 60 degrees Celsius (from 30 to +90 degrees Celsius) and the DPLL does not lose the lock. However, for temperatures above the 60 degrees Celsius range, the DPLL may need to be relocked. A new relock sequence reinitializes the starting temperature.

This compensation mechanism is active only while the DPLL is locked. When the DPLL is in off or bypass mode (low-power or fast-relock), it does not assert the recalibration flag. If the voltage or temperature exceeds the drift limits while the DPLL is not locked, and then the DPLL tries to relock, the DPLL fails to lock within the normal delay and recalibrates automatically before eventually locking. The only difference from a standard relock is the delay.

The DPLL can automatically start recalibration when the recalibration flag is asserted, or recalibration can be managed by the software. The mode of operation is selected by configuring the corresponding registers in the PRCM module (see [Table 3-44](#)). The software or manual control mode is selected by default.

---

**NOTE:** Automatic recalibration of the DPLL can start at any time. While relocking, the DPLL switches to bypass mode. For modules that are sensitive to frequency change while operating, this can introduce operational instability. For example, the SDRC is sensitive to a frequency change on DPLL3 because its embedded DLL relocks on a frequency change. Any access during this DLL relock period can be corrupted. It is important; therefore, to stall SDRC access during DPLL recalibration.

---

To let the software recalibrate the DPLL at the correct time depending on the device activity, the PRCM module can generate a wake-up event on the MPU power domain, followed by an interrupt on the MPU when the DPLL recalibration flag is asserted.

[Table 3-44](#) summarizes software programming control over the DPLL recalibration feature.

**Table 3-44. DPLL Recalibration Controls**

| DPLL         | Software Control                                      | Description                                                     |
|--------------|-------------------------------------------------------|-----------------------------------------------------------------|
| DPLL1 (MPU)  | PRCM.CM_CLKEN_PLL_MP[3]<br>MPU_DPLL_DRIFTGUARD        | Enable/disable the MPU DPLL automatic recalibration feature.    |
|              | PRCM.PRM_IRQENABLE_MP[7]<br>MPU_DPLL_RECAL_EN         | Enable/disable the MPU DPLL recalibration interrupt to MPU.     |
|              | PRCM.PRM_IRQSTATUS_MP[7] MPU_DPLL_ST                  | Status of the MPU DPLL recalibration interrupt                  |
| DPLL2 (IVA2) | PRCM.CM_CLKEN_PLL_IVA2[3]<br>IVA2_DPLL_DRIFTGUARD     | Enable/disable the IVA2 DPLL automatic recalibration feature.   |
|              | PRCM.PRM_IRQENABLE_MP[8]<br>IVA2_DPLL_RECAL_EN        | Enable/disable the IVA2 DPLL recalibration interrupt to MPU.    |
|              | PRCM.PRM_IRQSTATUS_MP[8] IVA2_DPLL_ST                 | Status of the IVA2 DPLL recalibration interrupt to MPU          |
|              | PRCM.PRM_IRQENABLE_IVA2[2]<br>IVA2_DPLL_RECAL_EN      | Enable/disable the IVA2 DPLL recalibration interrupt to IVA2.2. |
|              | PRCM.PRM_IRQSTATUS_IVA2[2] IVA2_DPLL_ST               | Status of the IVA2 DPLL recalibration interrupt to IVA2.2       |
| DPLL3 (CORE) | PRCM.CM_CLKEN_PLL[3]<br>EN_CORE_DPLL_DRIFTGUARD       | Enable/disable the CORE DPLL automatic recalibration feature.   |
|              | PRCM.PRM_IRQENABLE_MP[5] CORE_DPLL_RECAL              | Enable/disable the CORE DPLL recalibration interrupt to MPU.    |
|              | PRCM.PRM_IRQSTATUS_MP[5] CORE_DPLL_ST                 | Status of the CORE DPLL recalibration interrupt                 |
| DPLL4 (PER)  | PRCM.CM_CLKEN_PLL[19]<br>EN_PERIPH_DPLL_DRIFTGUARD    | Enable/disable the PER DPLL automatic recalibration feature.    |
|              | PRCM.PRM_IRQENABLE_MP[6]<br>PERIPH_DPLL_RECAL         | Enable/disable the PER DPLL recalibration interrupt to MPU.     |
|              | PRCM.PRM_IRQSTATUS_MP[6] PERIPH_DPLL_ST               | Status of the PER DPLL recalibration interrupt                  |
| DPLL5 (PER2) | PRCM.CM_CLKEN2_PLL[3]<br>EN_PERIPH2_DPLL_DRIFTGUARD   | Enable/disable the PER DPLL2 automatic recalibration feature.   |
|              | PRCM.PRM_IRQENABLE_MP[25]<br>SND_PERIPH_DPLL_RECAL_EN | Enable/disable the PER DPLL2 recalibration interrupt to MPU.    |
|              | PRCM.PRM_IRQSTATUS_MP[25] SND_PERIPH_DPLL_ST          | Status of the PER DPLL2 recalibration interrupt                 |

---

**NOTE:** DPLL recalibration is not necessary in real use (specified operating voltage and temperature range).

---

### 3.5.3.6.6 DPLL Programming Sequence

The DPLL programming sequence follows:

1. Set the M and N values for the desired CLKOUT frequency (see [Section 3.5.3.6.1](#)).
2. Set the corresponding output dividers (M2, M3, M4, M5, and M6) (see [Section 3.5.3.6.1](#)).
3. Enable/disable the auto-recalibration feature (see [Section 3.5.3.6.5](#)).
4. Enable/disable the autoidle feature (see [Section 3.5.3.6.2](#)).
5. Mask/unmask the interrupt to the MPU (and the DPLL2 interrupt to IVA2) (see [Section 3.5.3.6.5](#)).
6. Enable the DPLL lock mode (see [Section 3.5.3.6.2](#)).

### 3.5.3.7 Internal Clock Controls

This section describes the software and hardware controls of the internal source clocks. [Figure 3-60](#) through [Figure 3-74](#) list the clock controls. The Source selection/division column lists the PRCM register bits that select or divide the clocks. The Software control column lists the PRCM register bits that enable/disable the clocks. The Hardware control column lists the hardware conditions required to effectively gate the clocks.

In the Hardware control column, the boxes labeled CL, GS, GC, and HC indicate specific information about the hardware clock controls:

- CL (combinational logic): The functional or interface clock is required by more than one module across more than one power domain. The gating control is the OR combination of all the domain clock requests. If any module of this clock domain requests the clock, the clock is not gated.
- GS (gating selection): The clock is selectable among several possible source clocks for a module. The gating control depends on the software programming of the CM\_CLKSEL\_domain\_name type of register. The clock request of the module or domain must be set by the CM\_CLKSEL bit.
- GC (gating control): The functional/interface clock is required by a single module across the power domain. The gating control depends only on the software programming of the FCLKEN/ICLKEN bit. For the interface clock, the enable bit is effective only if autoidle mode is not used. If autoidle mode is used, the gating control also depends on the state of the power domain.
- HC (hardware control): A specific rule not covered by CL, GS, or GC.

---

**NOTE:** Because the PRCM module must receive hardware acknowledgment from the different modules before it can gate the clock, the clock is not gated immediately after the software requests clock-gating conditions.

---

#### 3.5.3.7.1 PRM Source-Clock Controls

[Figure 3-60](#) shows the common source-clock controls for the PRM.

**Figure 3-60. Common PRCM Source-Clock Controls**

prcm-056

Table 3-45 shows the common source-clock gating controls for the PRCM.

**Table 3-45. Common PRCM Source-Clock Gating Controls**

| Clock Name  | Reset   | Clock-Gating Control                                                                                                                              | Gating Description                                                                                                                                       |
|-------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSC_SYS_CLK | Running | PRCM.PRM_CLKSRC_CTRL[4:3] (AUTOEXTCLKMODE) and device power state and sys_clkreq                                                                  | Gated when the oscillator is programmed to power down with the device sleep/retention/off transition                                                     |
| sys_clkout1 | Running | PRCM.PRM_CLKOUT_CTRL[7] CLKOUT_EN and PRCM.PRM_POLCTRL[2] CLKOUT_POL and sys_clkreq                                                               | Active when OSC_SYS_CLK is active, sys_clkout1 is enabled, and sys_clkreq is asserted                                                                    |
| SYS_CLK     | Running | Activated after clksetup_count_overflow                                                                                                           | Active when OSC_SYS_CLK is active and the SYS_CLK setup time is up                                                                                       |
| CM_SYS_CLK  | Running | PRCM.CM_CLKSEL_CORE[6] CLKSEL_GPT10, PRCM.CM_CLKSEL_CORE[7] CLKSEL_GPT11, and depends on the clock-gating conditions of GPT10_FCLK and GPT11_FCLK | Active if it is the source clock of the GPT10_FCLK or GPT11_FCLK and the functional clock is active                                                      |
| 32K_FCLK    | Running | None                                                                                                                                              | Always-active clock from the sys_32k input pin                                                                                                           |
| CM_32K_CLK  | Running | PRCM.CM_CLKSEL_CORE[6] CLKSEL_GPT10, PRCM.CM_CLKSEL_CORE[7] CLKSEL_GPT11, and depends on the clock-gating conditions of GPT10_FCLK and GPT11_FCLK | Active if it is the source clock of the GPT10_FCLK or GPT11_FCLK and the functional clock is active                                                      |
| CM_96M_FCLK | Gated   | CM_CLKSEL1_PLL[3] SOURCE_48M bit cleared, and depends on the clock-gating condition of 96M_FCLK, 48M_FCLK, and 12M_FCLK                           | Active if the derived clocks (96M_FCLK, 48M_FCLK, and 12M_FCLK) are active or when SGX has its functional clock enable and its source is the 96MHz clock |

**Table 3-45. Common PRM Source-Clock Gating Controls (continued)**

| Clock Name     | Reset | Clock-Gating Control                                                                                                                                                                 | Gating Description                                                                      |
|----------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| 96M_ALWON_FCLK | Gated | <a href="#">CM_FCLKEN_PER[0]</a> EN_MCBSP2,<br><a href="#">CM_FCLKEN_PER[1]</a> EN_MCBSP3,<br><a href="#">CM_FCLKEN_PER[2]</a> EN_MCBSP4,<br><a href="#">CM_FCLKEN_SGX[1]</a> EN_SGX | Gated when none of the three McBSPs [2..4] have their functional clock enable requested |
| SGX_192M_FCLK  | Gated | <a href="#">CM_FCLKEN_SGX[1]</a> EN_SGX                                                                                                                                              | Active when SGX has its functional clock enabled and its source is the 192MHz clock     |

The oscillator output clock (OSC\_SYS\_CLK) is gated when the PRCM.[PRM\\_CLKSRC\\_CTRL\[4:3\]](#) AUTOEXTCLKMODE bit field is programmed to power down the oscillator when the device enters retention or off mode. In this condition, all the clock trees in the device must be gated, and the four DPLLs (DPLL1, DPLL2, DPLL3, and DPLL4) must enter stop mode before this transition can occur.

SYS\_CLK is gated under the same conditions as the oscillator output clock, but it is enabled only after the oscillator stabilizes. Oscillator stabilization is determined by a counter overflow configured in the PRCM.[PRM\\_CLKSETUP\[15:0\]](#) SETUP\_TIME bit field.

The sys\_clkreq active condition is described in [Section 3.5.3.5, External Clock Control](#).

### 3.5.3.7.2 CM Source-Clock Controls

[Figure 3-61](#) shows the common source-clock controls for the CM.

Figure 3-61. Common CM Source-Clock Controls



prcm-057

**Table 3-46** shows the common source-clock gating controls for the CM.

**Table 3-46. Common CM Source-Clock Gating Controls**

| Clock Name   | Reset   | Clock-Gating Control                                                                                 | Gating Description                                                                                                             |
|--------------|---------|------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| CORE_CLK     | Running | Depends on the clock-gating conditions of L3_ICLK and L4_ICLK                                        | Gated when all interface clocks of the different modules of the device are gated                                               |
| 96M_FCLK     | Stopped | Depends on the clock-gating conditions of CORE_96M_FCLK                                              | If the dependent clocks are active, the clock is active.                                                                       |
| 48M_FCLK     | Stopped | Depends on the clock-gating conditions of CORE_12M_FCLK, PER_48M_FCLK and USBHOST_48M_FCLK           | If the dependent clocks are active, the clock is active.                                                                       |
| 12M_FCLK     | Stopped | Depends on the clock-gating conditions of CORE_12M_FCLK                                              | If the dependent clock is active, the clock is active.                                                                         |
| sys_clkout2  | Stopped | PRCM.CM_CLKOUT_CTRL[7] CLKOUT2_EN                                                                    | Active if enabled                                                                                                              |
| DPLL4_M2_CLK | Stopped | Depends on the clock-gating conditions of: 96M_FCLK                                                  | If the dependent clocks are active, the clock is active.                                                                       |
| DPLL4_M3_CLK | Stopped | CM_CLKSEL1_PLL.SOURCE_54M and depends on the clock-gating conditions of: DPLL4_M2_CLK and DSS_TV_CLK | If the dependent clocks are active, the clock is active. DSS_TV_CLK is a dependent clock if set by the register configuration. |
| 120M_FCLK    | Stopped | CM_FCLKEN_USBHOST[1] EN_USBHOST2, CM_FCLKEN3_CORE[2] EN_USBTL                                        | If any of the dependent clocks (CORE_120M_FCLK or USBHOST_12M_FCLK) is active, the clock is active.                            |

### 3.5.3.7.3 Common Interface Clock Controls

Figure 3-62 shows the clock controls for the common interface.

**Figure 3-62. Common Interface Clock Controls**



prcm-058

**Table 3-47** shows the clock-gating controls for the common interface.

**Table 3-47. Common Interface Clock-Gating Controls**

| Clock Name | Reset   | Clock-Gating Control                                                                                                        | Gating Description                                                                  |
|------------|---------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| L3X2_ICLK  | Running | CORE_CLK gating conditions                                                                                                  | Depends on the gating conditions of the CORE_CLK                                    |
| L3_ICLK    | Running | Depends on the clock-gating conditions of GFX_L3_ICLK, CORE_L3_ICLK, and CAM_L3_ICLK                                        | Gated when all L3 interface clocks of the different modules of the device are gated |
| L4_ICLK    | Running | Depends on the clock-gating conditions of CORE_L4_ICLK, CAM_L4_ICLK, DSS_L4_ICLK, PER_L4_ICLK, SR_L4_ICLK, and WKUP_L4_ICLK | Gated when all L4 interface clocks of the different modules of the device are gated |
| RM_ICLK    | Running | None                                                                                                                        | Gated with source clock (CORE_CLK)                                                  |

### 3.5.3.7.4 DPLL Source-Clock Controls

Figure 3-63 shows the clock controls for the DPLL power domain.

**Figure 3-63. DPLL Power Domain Clock Controls**



prcm-059

Table 3-48 shows the clock-gating controls for the DPLL power domain.

**Table 3-48. DPLL Power Domain Clock-Gating Controls**

| Clock Name       | Reset   | Clock-Gating Control                                                                                                                                       | Gating Description                                                                                                                                                                                     |
|------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DPLL1_ALWON_FCLK | Running | PRCM.CM_AUTOIDLE_PLL_MPUS[2:0]<br>AUTO_MPUS_DPLL,<br>PRCM.CM_CLKEN_PLL_MPUS[2:0]<br>EN_MPUS_DPLL, and MPU domain power state                               | Gated if the DPLL is set to automatic active control and enabled in lock mode while the MPU power domain goes into retention or off mode. Also gated if DPLL is set to low-power bypass mode.          |
| DPLL1_FCLK       | Stopped |                                                                                                                                                            |                                                                                                                                                                                                        |
| DPLL2_ALWON_FCLK | Stopped | PRCM.CM_AUTOIDLE_PLL_IVA2[2:0]<br>AUTO_IVA2_DPLL,<br>PRCM.CM_CLKEN_PLL_IVA2[2:0]<br>EN_IVA2_DPLL, and IVA2 power domain power state                        | Gated if the DPLL is set to automatic active control and enabled in lock mode while the IVA2 power domain goes into retention or off mode. Also gated if DPLL is set to low-power stop or bypass mode. |
| DPLL2_FCLK       | Stopped |                                                                                                                                                            |                                                                                                                                                                                                        |
| DPLL3_ALWON_FCLK | Running | PRCM.CM_AUTOIDLE_PLL[2:0]<br>AUTO_CORE_DPLL,<br>PRCM.CM_CLKEN_PLL[2:0]<br>EN_CORE_DPLL, and CORE domain power clocks state                                 | Gated if the DPLL is set to automatic active control and enabled in lock mode while the CORE power domain is idle. Also gated if DPLL is set to low-power or fast-relock bypass mode.                  |
| DPLL4_ALWON_FCLK | Stopped | PRCM.CM_AUTOIDLE_PLL[5:3]<br>AUTO_PERIPH_DPLL,<br>PRCM.CM_CLKEN_PLL[18:16]<br>EN_PERIPH_DPLL, and depends on the clock-gating conditions of DPLL4_M2_CLK   | Gated if the DPLL is set to automatic active control and enabled in lock mode while its dependent clock is inactive. Also gated if DPLL is set to low-power stop mode.                                 |
| DPLL5_ALWON_FCLK | Stopped | PRCM.CM_AUTOIDLE2_PLL[2:0]<br>AUTO_PERIPH2_DPLL,<br>PRCM.CM_CLKEN2_PLL[2:0]<br>EN_PERIPH2_DPLL, and depends on the clock-gating conditions of DPLL5_M2_CLK | Gated if the DPLL is set to automatic active control and enabled in lock mode while its dependent clock is inactive. Also gated if DPLL is set to low-power stop mode.                                 |

### 3.5.3.7.5 SGX Power Domain Clock Controls

This section describes all modules and features in the high-tier device. To save power, ensure that power domains of unavailable features and modules are switched off and clocks are cut off.

Figure 3-64 shows the clock controls for the SGX power domain.

**Figure 3-64. SGX Power Domain Clock Controls**



prcm-060

Table 3-49 lists the clock-gating controls for the SGX power domain.

**Table 3-49. SGX Power Domain Clock-Gating Controls**

| Clock Name  | Reset   | Clock-Gating Control         | Gating Description                    |
|-------------|---------|------------------------------|---------------------------------------|
| SGX_FCLK    | Stopped | PRCM.CM_FCLKEN_SGX[1] EN_SGX | Gated when the enable bit is set to 0 |
| SGX_L3_ICLK | Stopped | PRCM.CM_ICLKEN_SGX[1] EN_SGX | Gated when the enable bit is set to 0 |

### 3.5.3.7.6 CORE Power Domain Clock Controls

Figure 3-65 through Figure 3-66 show the clock controls for the CORE power domain.

**Figure 3-65. CORE Power Domain Clock Controls: Part 1**



prcm-061

**Figure 3-66. CORE Power Domain Clock Controls: Part 2**


prcm-GN3-001

[Table 3-50](#) lists the clock-gating controls for the CORE power domain.

**Table 3-50. CORE Power Domain Clock-Gating Controls**

| Clock Name    | Reset   | Clock-Gating Control                                                                                      | Gating Description                                                                                                                         |
|---------------|---------|-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| GPT10_FCLK    | Stopped | PRCM.CM_FCLKEN1_CORE[11] EN_GPT10                                                                         | Gated when the enable bit is set to 0                                                                                                      |
| GPT11_FCLK    | Stopped | PRCM.CM_FCLKEN1_CORE[12] EN_GPT11                                                                         | Gated when the enable bit is set to 0                                                                                                      |
| CORE_96M_FCLK | Stopped | McBSP[1..5] input clock source select (in SCM) and PRCM.CM_FCLKEN1_CORE (MMC[1-2], McBSP[1, 5], I2C[1-3]) | Gated when the enable bits of the module functional clock are set to 0. (The McBSPs can have MCBSP_CLKS as an alternate functional clock.) |
| CORE_48M_FCLK | Stopped | PRCM.CM_FCLKEN1_CORE (UART[1-2], McSPI[1-4])                                                              | Gated when the functional clock enable bits of the module are set to 0                                                                     |
| CORE_12M_FCLK | Stopped | PRCM.CM_FCLKEN1_CORE[22] EN_HDQ                                                                           | Gated when the enable bit is set to 0                                                                                                      |

**Table 3-50. CORE Power Domain Clock-Gating Controls (continued)**

| Clock Name      | Reset   | Clock-Gating Control                                                                                                                                                                                                                                           | Gating Description                                                                                                                                                                                                                    |
|-----------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CORE_L3_ICLK    | Running | PRCM.CM_ICLKEN1_CORE<br>EN_(SDRC, HSOTGUSB),<br>PRCM.CM_AUTOIDLE1_CORE[4]<br>AUTO_HSOTGUSB                                                                                                                                                                     | Gated when: <ul style="list-style-type: none"><li>• All enable bits are set to 0.</li><li>• The enable-autoidle bit pair is set to 1, the remaining enable bits are set to 0, and the clock is not requested by any module.</li></ul> |
| CORE_L4_ICLK    | Running | PRCM.CM_ICLKEN1_CORE<br>(MMC[1..2], HDQ, MCSPI[1-4],<br>I2C[1-3], UART[1,2], GPT[10,11],<br>MCBSP[1,5], MAILBOXES, SCCTRL)<br>and PRCM.CM_AUTOIDLE1_CORE<br>(MMC[1..2], HDQ, MCSPI[1-4],<br>I2C[1-3], UART[1,2], GPT[10,11],<br>MCBSP[1,5], MAILBOXES, SCCTRL) | Gated when: <ul style="list-style-type: none"><li>• All enable bits are set to 0.</li><li>• All enable-autoidle bit pairs are set to 1, and the clock is not requested by any module.</li></ul>                                       |
| CORE_32K_FCLK   | Stopped | CM_FCLKEN1_CORE[24] EN_MMC1,<br>CM_FCLKEN1_CORE[25] EN_MMC2,<br>CM_FCLKEN1_CORE[30] EN_MMC3,<br>CM_FCLKEN3_CORE[1] EN_TS                                                                                                                                       | Gated when all enable bits are set to 0                                                                                                                                                                                               |
| USBTLL_SAR_FCLK | Stopped | CORE power domain power state and<br>PM_PWSTCTRL_CORE[4]<br>SAVEANDRESTORE                                                                                                                                                                                     | Gated when the save-restore bit is set to 0, or when the CORE power domain is in off state after the save operation completes or in on state after the restore operation completes                                                    |
| CORE_120M_FCLK  | Stopped | CM_FCLKEN3_CORE[0] EN_USBPLL<br>and DPLL5 operating mode                                                                                                                                                                                                       | Gated when the enable bit is set to 0, or the DPLL5 is in stop or bypass mode                                                                                                                                                         |

### 3.5.3.7.7 EFUSE Power Domain Clock Controls

Figure 3-67 shows the clock controls for the EFUSE power domain. Table 3-51 lists the clock-gating control for the EFUSE power domain.

**Figure 3-67. EFUSE Power Domain Clock Controls**

prcm-064

**Table 3-51. EFUSE Power Domain Clock-Gating Control**

| Clock Name       | Reset   | Clock-Gating Control | Gating Description                                                                    |
|------------------|---------|----------------------|---------------------------------------------------------------------------------------|
| EFUSE_ALWON_FCLK | Running | None                 | Active when VDD1 and VDD2 are switched on and eFuse-ready hardware signal is released |

### 3.5.3.7.8 DSS Power Domain Clock Controls

This section describes all modules and features in the high-tier device. To save power, ensure that power domains of unavailable features and modules are switched off and clocks are cut off.

Figure 3-68 shows the clock controls for the DSS power domain. Table 3-52 lists the clock-gating controls for the DSS power domain.

**Figure 3-68. DSS Power Domain Clock Controls**


prcm-065

**Table 3-52. DSS Power Domain Clock-Gating Controls**

| Clock Name      | Reset   | Clock-Gating Control                                              | Gating Description                                                                                                                                                                  |
|-----------------|---------|-------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DSS1_ALWON_FCLK | Stopped | PRCM.CM_FCLKEN_DSS[0] EN_DSS1                                     | Gated when the enable bit is set to 0                                                                                                                                               |
| DSS2_ALWON_FCLK | Stopped | PRCM.CM_FCLKEN_DSS[1] EN_DSS2                                     | Gated when the enable bit is set to 0                                                                                                                                               |
| DSS_TV_FCLK     | Stopped | PRCM.CM_FCLKEN_DSS[2] EN_TV                                       | Gated when the enable bit is set to 0                                                                                                                                               |
| DSS_L3_ICLK     | Stopped | PRCM.CM_ICLKEN_DSS[0] EN_DSS,<br>PRCM.CM_AUTOIDLE_DSS[0] AUTO_DSS | Gated when: <ul style="list-style-type: none"><li>• Enable bit is set to 0.</li><li>• Enable-autoidle bit pair is set to 1, and the clock is not requested by any module.</li></ul> |
| DSS_L4_ICLK     | Stopped |                                                                   |                                                                                                                                                                                     |

### 3.5.3.7.9 CAM Power Domain Clock Controls

This section describes all modules and features in the high-tier device. To save power, ensure that power domains of unavailable features and modules are switched off and clocks are cut off.

Figure 3-69 shows the clock controls for the CAM power domain. Table 3-53 lists the clock-gating controls for the CAM power domain.

**Figure 3-69. CAM Power Domain Clock Controls****Table 3-53. CAM Power Domain Clock-Gating Controls**

| Clock Name  | Reset   | Clock-Gating Control                                              | Gating Description                                                                                                                                                                 |
|-------------|---------|-------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CAM_MCLK    | Stopped | PRCM.CM_FCLKEN_CAM[0] EN_CAM                                      | Gated when the enable bit is set to 0                                                                                                                                              |
| CAM_L3_ICLK | Stopped | PRCM.CM_ICLKEN_CAM[0] EN_CAM,<br>PRCM.CM_AUTOIDLE_CAM[0] AUTO_CAM | Gated when: <ul style="list-style-type: none"><li>• Enable bit is set to 0.</li><li>• Enable-autoidle bit pair is set to 1, and the clock is not requested by subsystem.</li></ul> |
| CAM_L4_ICLK | Stopped |                                                                   |                                                                                                                                                                                    |

### 3.5.3.7.10 USBHOST Power Domain Clock Controls

Figure 3-70 shows the clock controls for the USBHOST power domain. Table 3-54 lists the clock-gating controls for the USBHOST power domain.

**Figure 3-70. USBHOST Power Domain Clock Controls****Table 3-54. USBHOST Power Domain Clock-Gating Controls**

| Clock Name       | Reset   | Clock-Gating Control                  | Gating Description                    |
|------------------|---------|---------------------------------------|---------------------------------------|
| USBHOST_48M_FCLK | Stopped | PRCM.CM_FCLKEN_USBHOST[0] EN_USBHOST1 | Gated when the enable bit is set to 0 |

**Table 3-54. USBHOST Power Domain Clock-Gating Controls (continued)**

| Clock Name        | Reset   | Clock-Gating Control                                                                 | Gating Description                                                                                                                                                                 |
|-------------------|---------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| USBHOST_120M_FCLK | Stopped | PRCM.CM_FCLKEN_USBHOST[1] EN_USBHOST2                                                | Gated when the enable bit is set to 0                                                                                                                                              |
| USBHOST_L3_ICLK   | Stopped | PRCM.CM_ICLKEN_USBHOST[0] EN_USBHOST,<br>PRCM.CM_AUTOIDLE_USBHOST[0]<br>AUTO_USBHOST | Gated when: <ul style="list-style-type: none"><li>• Enable bit is set to 0.</li><li>• Enable-autoidle bit pair is set to 1, and the clock is not requested by subsystem.</li></ul> |
| USBHOST_L4_ICLK   | Stopped |                                                                                      |                                                                                                                                                                                    |
| USBHOST_SAR_FCLK  | Stopped | PRCM.PM_PWSTCTRL_USBHOST[4]<br>SAVEANDRESTORE                                        | Gated when the save-restore bit is set to 0, or when the power domain is in off state after the save operation completes or in on state after the restore operation completes.     |

### 3.5.3.7.11 WKUP Power Domain Clock Controls

Figure 3-71 shows the clock controls for the WKUP power domain. Table 3-55 lists the clock-gating controls for the WKUP power domain.

**Figure 3-71. WKUP Power Domain Clock Controls**


prcm-067

**Table 3-55. WKUP Power Domain Clock-Gating Controls**

| Clock Name    | Reset   | Clock-Gating Control                                         | Gating Description                      |
|---------------|---------|--------------------------------------------------------------|-----------------------------------------|
| GPT1_FCLK     | Stopped | PRCM.CM_FCLKEN_WKUP[0] EN_GPT1                               | Gated when the enable bit is set to 0   |
| WKUP_32K_FCLK | Stopped | PRCM.CM_FCLKEN_WKUP[3] GPIO1 and PRCM.CM_FCLKEN_WKUP[5] WDT2 | Gated when the enable bits are set to 0 |

**Table 3-55. WKUP Power Domain Clock-Gating Controls (continued)**

| Clock Name   | Reset   | Clock-Gating Control                                                                                                     | Gating Description                                                                                                                                                                             |
|--------------|---------|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WKUP_L4_ICLK | Running | PRCM.CM_ICLKEN_WKUP EN_(WDT2, GPIO1, 32KSYNC, GPTIMER1), PRCM.CM_AUTOIDLE_WKUP AUTO_(WDT2, GPIO1, 32KSYNC, and GPTIMER1) | Gated when: <ul style="list-style-type: none"> <li>All enable bits are set to 0.</li> <li>All enable-autoidle bit pairs are set to 1, and the clock is not requested by any module.</li> </ul> |

### 3.5.3.7.12 PER Power Domain Clock Controls

Figure 3-72 and Figure 3-73 show the clock controls for the PER power domain.

**Figure 3-72. PER Power Domain Clock Controls: Part 1**

prcm-068

**Figure 3-73. PER Power Domain Clock Controls: Part 2**

| Source selection/division | Software control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Hardware control                                                                     |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| L4_ICLK                   | PRCM.CM_ICLKEN_PER[18]<br>EN_UART4<br>PRCM.CM_ICLKEN_PER[17]<br>EN_GPIO6<br>PRCM.CM_ICLKEN_PER[16]<br>EN_GPIO5<br>PRCM.CM_ICLKEN_PER[15]<br>EN_GPIO4<br>PRCM.CM_ICLKEN_PER[14]<br>EN_GPIO3<br>PRCM.CM_ICLKEN_PER[13]<br>EN_GPIO2<br>PRCM.CM_ICLKEN_PER[12]<br>EN_WDT3<br>PRCM.CM_ICLKEN_PER[11]<br>EN_UART3<br>PRCM.CM_ICLKEN_PER[10]<br>EN_GPT9<br>PRCM.CM_ICLKEN_PER[9]<br>EN_GPT8<br>PRCM.CM_ICLKEN_PER[8]<br>EN_GPT7<br>PRCM.CM_ICLKEN_PER[7]<br>EN_GPT6<br>PRCM.CM_ICLKEN_PER[6]<br>EN_GPT5<br>PRCM.CM_ICLKEN_PER[5]<br>EN_GPT4<br>PRCM.CM_ICLKEN_PER[4]<br>EN_GPT3<br>PRCM.CM_ICLKEN_PER[3]<br>EN_GPT2<br>PRCM.CM_ICLKEN_PER[2]<br>EN_MCBSP4<br>PRCM.CM_ICLKEN_PER[1]<br>EN_MCBSP3<br>PRCM.CM_ICLKEN_PER[0]<br>EN_MCBSP2                                                                             |   |
|                           | PRCM.CM_AUTOIDLE_PER[18]<br>AUTO_UART4<br>PRCM.CM_AUTOIDLE_PER[17]<br>AUTO_GPIO6<br>PRCM.CM_AUTOIDLE_PER[16]<br>AUTO_GPIO5<br>PRCM.CM_AUTOIDLE_PER[15]<br>AUTO_GPIO4<br>PRCM.CM_AUTOIDLE_PER[14]<br>AUTO_GPIO3<br>PRCM.CM_AUTOIDLE_PER[13]<br>AUTO_GPIO2<br>PRCM.CM_AUTOIDLE_PER[12]<br>AUTO_WDT3<br>PRCM.CM_AUTOIDLE_PER[11]<br>AUTO_UART3<br>PRCM.CM_AUTOIDLE_PER[10]<br>AUTO_GPT9<br>PRCM.CM_AUTOIDLE_PER[9]<br>AUTO_GPT8<br>PRCM.CM_AUTOIDLE_PER[8]<br>AUTO_GPT7<br>PRCM.CM_AUTOIDLE_PER[7]<br>AUTO_GPT6<br>PRCM.CM_AUTOIDLE_PER[6]<br>AUTO_GPT5<br>PRCM.CM_AUTOIDLE_PER[5]<br>AUTO_GPT4<br>PRCM.CM_AUTOIDLE_PER[4]<br>AUTO_GPT3<br>PRCM.CM_AUTOIDLE_PER[3]<br>AUTO_GPT2<br>PRCM.CM_AUTOIDLE_PER[2]<br>AUTO_MCBSP4<br>PRCM.CM_AUTOIDLE_PER[1]<br>AUTO_MCBSP3<br>PRCM.CM_AUTOIDLE_PER[0]<br>AUTO_MCBSP2 |  |

prcm-069

Table 3-56 lists the clock-gating controls for the PER power domain.

**Table 3-56. PER Power Domain Clock-Gating Controls**

| Clock Name         | Reset   | Clock-Gating Control                                                                                                                                                  | Gating Description                                                                                                                                                                             |
|--------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PER_48M_FCLK       | Stopped | PRCM.CM_FCLKEN_PER EN_UART[3-4]                                                                                                                                       | Gated when the enable bit is set to 0                                                                                                                                                          |
| PER_96M_FCLK       | Stopped | McBSP[2..4] input clock source select (in SCM) and PRCM.CM_FCLKEN_PER EN_MCBSP[2-4] and the DPLL4 operating mode                                                      | Gated when the enable bits of the module functional clock are set to 0 (the McBSPs can have MCBSP_CLKS as an alternate functional clock) or DPLL4 is in stop or bypass mode                    |
| MCBSP_CLKS         | Stopped | See <a href="#">Chapter 13, System Control Module</a> .                                                                                                               |                                                                                                                                                                                                |
| PER_32K_ALWON_FCLK | Stopped | PRCM.CM_FCLKEN_PER EN_GPIO[2-6] and PRCM.CM_FCLKEN_PER[12] EN_WDT3                                                                                                    | Gated when all the enable bits are set to 0                                                                                                                                                    |
| GPT2_ALWON_FCLK    | Stopped | PRCM.CM_FCLKEN_PER[3] EN_GPT2                                                                                                                                         | Gated when the enable bit is set to 0                                                                                                                                                          |
| GPT3_ALWON_FCLK    | Stopped | PRCM.CM_FCLKEN_PER[4] EN_GPT3                                                                                                                                         | Gated when the enable bit is set to 0                                                                                                                                                          |
| GPT4_ALWON_FCLK    | Stopped | PRCM.CM_FCLKEN_PER[5] EN_GPT4                                                                                                                                         | Gated when the enable bit is set to 0                                                                                                                                                          |
| GPT5_ALWON_FCLK    | Stopped | PRCM.CM_FCLKEN_PER[6] EN_GPT5                                                                                                                                         | Gated when the enable bit is set to 0                                                                                                                                                          |
| GPT6_ALWON_FCLK    | Stopped | PRCM.CM_FCLKEN_PER[7] EN_GPT6                                                                                                                                         | Gated when the enable bit is set to 0                                                                                                                                                          |
| GPT7_ALWON_FCLK    | Stopped | PRCM.CM_FCLKEN_PER[8] EN_GPT7                                                                                                                                         | Gated when the enable bit is set to 0                                                                                                                                                          |
| GPT8_ALWON_FCLK    | Stopped | PRCM.CM_FCLKEN_PER[9] EN_GPT8                                                                                                                                         | Gated when the enable bit is set to 0                                                                                                                                                          |
| GPT9_ALWON_FCLK    | Stopped | PRCM.CM_FCLKEN_PER[10] EN_GPT9                                                                                                                                        | Gated when the enable bit is set to 0                                                                                                                                                          |
| PER_L4_ICLK        | Stopped | PRCM.CM_ICLKEN_PER EN_(GPIO[2..6], WDT3, UART[3, 4], GPT[2..9], MCBSP[2..4]) and PRCM.CM_AUTOIDLE_PER AUTO_(GPIO[2..6], WDT3, UART[3, 4], GPT[2..9], and MCBSP[2..4]) | Gated when: <ul style="list-style-type: none"> <li>All enable bits are set to 0.</li> <li>All enable-autoidle bit pairs are set to 1, and the clock is not requested by any module.</li> </ul> |
| 96M_ALWON_FCLK     | Stopped | None                                                                                                                                                                  | Always-on clock                                                                                                                                                                                |

For audio applications, the McBSP functional clocks are provided externally by the MCBSP\_CLKS pin. This clock must be permanently supplied, to let McBSPs function when the CORE power domain is in the off power state. If the external clock input is selected as the functional clock, the PER power domain sleep transition is prevented.

### 3.5.3.7.13 SMARTREFLEX Power Domain Clock Controls

[Figure 3-74](#) shows the clock controls for the SMARTREFLEX power domain. [Table 3-57](#) lists the clock-gating controls for the SMARTREFLEX power domain.

**Figure 3-74. SMARTREFLEX Power Domain Clock Controls****Table 3-57. SMARTREFLEX Power Domain Clock-Gating Controls**

| Clock Name    | Reset   | Clock-Gating Control                                            | Gating Description                       |
|---------------|---------|-----------------------------------------------------------------|------------------------------------------|
| SR_ALWON_FCLK | Stopped | PRCM.CM_FCLKEN_WKUP[6] EN_SR1 and PRCM.CM_FCLKEN_WKUP[7] EN_SR2 | Gated when both enable bits are set to 0 |
| SR_L4_ICLK    | Running | Depends on L4_ICLK activity (hardware control)                  |                                          |

### 3.5.3.8 Clock Configurations

The device supports several clock configurations. A clock configuration is a consistent set of divider ratios programmed into the PRCM module to obtain a certain combination of clock speed to match the performance requirement.

In the device, the MPU and IVA2.2 processors are connected to the interconnects through asynchronous bridges. The functional frequency of these processors can be configured independently of their interface clock frequency.

Therefore, the clock configurations of the device are split into two sections: one for device processor clocks and one for device interface clocks.

An OPP of the device can be defined as a pair of device operating voltage and corresponding frequency. The device processors are in the VDD1 voltage domain and the interface clocks are generated by the CM clock generator in the VDD2 voltage domain. Hence, the OPPs of the processor clocks are identified for the VDD1 voltage levels, independent of the interface clocks, which are associated with the VDD2 voltage levels.

#### CAUTION

Clock configuration frequencies depend on the device operating voltage values.

#### 3.5.3.8.1 Processor Clock Configurations

The processor OPPs are identified as the pair of VDD1 operating voltage level and processor clock frequency.

Four generic processor OPPs can be defined as:

1. OPP1G (VDD1 = v3, (MPU\_CLK =  $f_{mpu}3$ , IVA2\_CLK =  $f_{iva}3$ ))
2. OPP130 (VDD1 = v2, (MPU\_CLK =  $f_{mpu}2$ , IVA2\_CLK =  $f_{iva}2$ ))
3. OPP100 (VDD1 = v1, (MPU\_CLK =  $f_{mpu}1$ , IVA2\_CLK =  $f_{iva}1$ ))
4. OPP50 (VDD1 = v0, (MPU\_CLK =  $f_{mpu}0$ , IVA2\_CLK =  $f_{iva}0$ ))

where v3 v2 v1 v0,

$f_{mpu}3 \geq f_{mpu}2 \geq f_{mpu}1 \geq f_{mpu}0$ ,

$f_{iva}3 \geq f_{iva}2 \geq f_{iva}1 \geq f_{iva}0$  and

$f_{mpu}$  may not be equal to  $f_{iva}$

The clock configuration for the MPU and the IVA applies to the following clocks of the device:

- DPLL1 (MPU DPLL) synthesized clock frequency (CLKOUT) configured by setting the M and N parameters of the DPLL
- DPLL1 (MPU DPLL) output clock frequency (MPU\_CLK) configured by setting the M2 parameter of the DPLL

---

**NOTE:** The MPU\_CLK is used to generate the ARM\_FCLK. ARM\_FCLK is equal to MPU\_CLK (For information about ARM\_FCLK, see [Chapter 4, MPU Subsystem](#).)

---

- DPLL2 (IVA2 DPLL) synthesized clock frequency (CLKOUT) configured by setting the M and N parameters of the DPLL
- DPLL2 (IVA2 DPLL) output clock frequency (IVA2\_CLK) configured by setting the M2 parameter of the DPLL

The frequency of the processor clocks (MPU\_CLK and IVA2\_FCLK) must be configured according to the selected OPP (the clock frequency associated with the operating voltage VDD1). [Table 3-58](#) identifies the clocks of the processors, their source clocks, and the configuration register bit fields.

**Table 3-58. Processor Clock Configuration Controls**

| Module | Clocks                 | Reference Clock | Multiplier (Factors) | Divider (Factors) | Configuration Bits                                    |
|--------|------------------------|-----------------|----------------------|-------------------|-------------------------------------------------------|
| DPLL1  | CLKOUT                 | SYS_CLK         | M (0 ... 2047)       |                   | PRCM.CM_CLKSEL1_PLL_MPU[18:8]<br>MPU_DPLL_MULT        |
|        |                        |                 |                      | N (0 ... 127)     | PRCM.CM_CLKSEL1_PLL_MPU[6:0]<br>MPU_DPLL_DIV          |
|        | MPU_CLK <sup>(1)</sup> | CLKOUT          |                      | M2                | PRCM.CM_CLKSEL2_PLL_MPU[4:0]<br>MPU_DPLL_CLKOUT_DIV   |
| DPLL2  | CLKOUT                 | SYS_CLK         | M (0 ... 2047)       |                   | PRCM.CM_CLKSEL1_PLL_IVA2[18:8]<br>IVA2_DPLL_MULT      |
|        |                        |                 |                      | N (0 ... 127)     | PRCM.CM_CLKSEL1_PLL_IVA2[6:0]<br>IVA2_DPLL_DIV        |
|        | IVA2_CLK               | CLKOUT          |                      | M2 (1 ... 16)     | PRCM.CM_CLKSEL2_PLL_IVA2[4:0]<br>IVA2_DPLL_CLKOUT_DIV |

<sup>(1)</sup> The MPU\_CLK is generating the ARM\_FCLK. ARM\_FCLK is equal to the MPU\_CLK. For information about ARM\_FCLK, see Chapter 4, *MPU Subsystem*.

**Table 3-59. Processor Clock Configurations**

| DPLL State                           | BYPASS                               | LOCKED                       |
|--------------------------------------|--------------------------------------|------------------------------|
| MPU_CLK                              | DPLL1_FCLK (bypass clock from DPLL3) | (SYS_CLK * M) / ([N+1] * M2) |
| ARM_FCLK                             | MPU_CLK                              | MPU_CLK                      |
| MPU subsystem internal module clocks | ARM_FCLK/2                           | ARM_FCLK/2                   |

### 3.5.3.8.2 Interface and Peripheral Functional Clock Configurations

The interface clock OPPs are identified as the pair of VDD2 operating voltage level and the device interface clocks frequencies.

The DPLL3 (CORE DPLL) generates the CORE\_CLK, which serves as the source clock for the L3\_ICLK and L4\_ICLK interface clocks of the device. The CORE\_CLOCK is also used by the DPLL1 and DPLL2 as the bypass clock. The L3\_ICLK is supplied to the SGX module as SGX\_L3\_ICLK and is used as its interface clock. The L4\_ICLK is used by RM\_L4\_CLK as its source clock.

The interface and peripheral functional clock frequencies can be configured according to the device performance requirements for the OPP.

DPLL3 synthesized clock frequencies are configured as:

- $f_{CLKOUT} = (f_{SYS\_CLK} \times M) / (N+1)$
- $f_{CLKOUTx2} = f_{CLKOUT} \times 2$

DPLL3 output clock frequencies are configured as:

- $f_{CORE\_CLK} = f_{CLKOUT}/M2$
- $f_{COREx2\_CLK} = f_{CLKOUTx2}/M2$

L3\_ICLK, L4\_ICLK and RM\_L4\_ICLK frequencies are configured as:

- $f_{L3\_ICLK} = f_{CORE\_CLK}/DIV\_L3$
- $f_{L4\_ICLK} = f_{L3\_ICLK}/DIV\_L4$
- $f_{RM\_L4\_ICLK} = f_{L4\_ICLK}/DIV\_RM$

Table 3-60 identifies the interface clocks, their reference clocks, and the control bits for configuration of the interface clock frequencies.

**Table 3-60. Interface Clock Configuration Controls**

| Module          | Clock      | Reference Clock | Multiplier (Factor) | Divider (Factor) | Configuration Bits                                 |
|-----------------|------------|-----------------|---------------------|------------------|----------------------------------------------------|
| DPLL3           | CLKOUT     | SYS_CLK         | M (0 ... 2047)      |                  | PRCM.CM_CLKSEL1_PLL[26:16]<br>CORE_DPLL_MULT       |
|                 | CLKOUTX2   |                 |                     |                  | PRCM.CM_CLKSEL1_PLL[14:8]<br>CORE_DPLL_DIV         |
| CORE_CLK        | CORE_CLK   | CLKOUT          |                     | M2 (1 ... 31)    | PRCM.CM_CLKSEL1_PLL[31:27]<br>CORE_DPLL_CLKOUT_DIV |
|                 | COREX2_CLK | CLKOUTX2        |                     |                  |                                                    |
| L3 interconnect | L3_ICLK    | CORE_CLK        |                     | DIV_L3 (1 ... 2) | PRCM.CM_CLKSEL_CORE[1:0]<br>CLKSEL_L3              |
| L4 interconnect | L4_ICLK    | L3_ICLK         |                     | DIV_L4 (1 ... 2) | PRCM.CM_CLKSEL_CORE[3:2]<br>CLKSEL_L4              |
| RM clock        | RM_L4_ICLK | L4_ICLK         |                     | DIV_RM (1 ... 2) | PRCM.CM_CLKSEL_WKUP[2:1]<br>CLKSEL_RM              |

SGX\_FCLK frequencies are configured depending on the source clock as:

- $f_{SGX\_FCLK} = f_{CORE\_CLK}/DIV\_SGX$
- $f_{SGX\_FCLK} = f_{COREX2\_CLK}/DIV2\_SGX$
- $f_{SGX\_FCLK} = f_{SGX\_192M\_FCLK}$
- $f_{SGX\_FCLK} = f_{CM\_96M\_FCLK}$

DPLL1\_FCLK (bypass mode) and DPLL2\_FCLK (bypass mode) frequencies are configured as:

- $f_{DPLL1\_FCLK} = f_{CORE\_CLK}/DIV\_DPLL1$
- $f_{DPLL2\_FCLK} = f_{CORE\_CLK}/DIV\_DPLL2$

**Table 3-61** identifies the functional clocks, their reference clocks, and the control bits for configuration of the functional clock frequencies.

**Table 3-61. Functional Clock Configuration Controls**

| Module         | Clock      | Reference Clock | Divider (Factor)     | Configuration Bits                              |
|----------------|------------|-----------------|----------------------|-------------------------------------------------|
| SGX            | SGX_FCLK   | CORE_CLK        | DIV_SGX (2, 3, 4, 6) | PRCM.CM_CLKSEL_SGX[2:0] CLKSEL_SGX              |
|                |            | COREX2_CLK      | DIV2_SGX (3, 5)      | PRCM.CM_CLKSEL_SGX[2:0] CLKSEL_SGX              |
|                |            | SGX_192M_FCLK   |                      | PRCM.CM_CLKSEL_SGX[2:0] CLKSEL_SGX              |
|                |            | CM_96M_FCLK     |                      | PRCM.CM_CLKSEL_SGX[2:0] CLKSEL_SGX              |
| MPU HS bypass  | DPLL1_FCLK | CORE_CLK        | DIV_DPLL1 (1, 2, 4)  | PRCM.CM_CLKSEL1_PLL_MPU[20:19]<br>MPU_CLK_SRC   |
| IVA2 HS bypass | DPLL2_FCLK | CORE_CLK        | DIV_DPLL2 (1, 2, 4)  | PRCM.CM_CLKSEL1_PLL_IVA2[20:19]<br>IVA2_CLK_SRC |

The rest of the functional clocks are issued from DPLL4 and DPLL5 and remain invariable, regardless of the interface clock configuration. In all clock configurations, any divider ratio to generate functional clocks is applicable, provided it complies with the maximum frequency specification.

**CAUTION**

Before any transition to OPP50, set the DPLL2 bypass clock to CORE\_CLK/2 in the [CM\\_CLKSEL1\\_PLL\\_IVA2\[20:19\]](#) IVA2\_CLK\_SRC bit field. During the relock phase, the DSP clock is 200 MHz. This has no effect on performance because the DPLL2 relock time is only a few  $\mu$ s.

Always set the DPLL1 bypass clock to CORE\_CLK/1 in the [CM\\_CLKSEL1\\_PLL\\_MPUMPU\[20:19\]](#) MPU\_CLK\_SRC bit field.

### 3.5.4 PRCM Idle and Wake-Up Management

#### 3.5.4.1 Overview

When a group of modules belonging to a clock domain in a power domain does not require a clock (interface or functional), the PRCM module can be programmed to automatically cut the clock to these modules, thereby reducing their power consumption. The PRCM module can then switch the power domain to low-power retention or off mode to ensure minimum power consumption. When all clocks in a domain are cut, the domain is idle.

Similarly, when a module belonging to a power domain in low-power idle mode is required to switch to active mode, the PRCM module switches on the power to the entire power domain and activates the necessary clock signals to the module. This is a wake-up transition. Generally, a wake-up event triggers the wake-up transition.

A sleep/wake-up dependency can be defined between power domains. A sleep dependency ensures that a power domain does not make a sleep transition unless all the dependent power domains are in idle mode and do not require the power domain. Similarly, a wake-up dependency ensures that a power domain wakes up when any of its dependent power domains wakes up.

The PRCM module automatically handles the sequence clock-gating conditions and power switching for each power domain, based on the configured dependencies between the domains and the clock-control bits of the modules.

**Figure 3-75** shows the sleep/wake-up transition of the power domains. The INACTIVE state is a transient power state of a power domain, while moving from ACTIVE to RETENTION or OFF power state. In INACTIVE state, all the domain clocks are gated. A power domain cannot switch from OFF to RETENTION or RETENTION to OFF power state without passing to the ACTIVE power state.

A low-power state (INACTIVE, RETENTION, or OFF) means less power consumption. However, wake-up latency increases as the power domain switches to INACTIVE, RETENTION, or OFF power state.

**Figure 3-75. Power Domain Sleep/Wake-Up Transition**



prcm-071

Functionally, the PRCM module is composed of a single global control block and a power-control block for each power domain. The domain power-control block handles power switching, wake-up events, and clock-gating control for the domain. The domain power controllers communicate with each other for power sequencing, sleep dependencies, and wake-up dependencies. All these blocks interact with the global control block that handles reset management, clock generation and distribution, and all PRCM registers.

**Figure 3-76. Device Power Reset and Clock Controllers**

prcm-072

**Figure 3-76** shows the functions in one power domain block:

- A module clock controller (for example, module X clock controller) uses a hardware handshake protocol to communicate directly with the module. It controls the idle transition of the target module and responds to the standby requests of the initiator module (for details, see [Section 3.1.4.2, Autoidle Clock Control](#)). Depending on the mode, the clock controller sends clock commands (enable/disable) to the clock generator. The registers that control the functional and interface clocks in the module are directly mapped to the module clock controller.
- The domain clock controller gathers information from the following:
  - All module clock controllers of the power domain
  - The domain power controller
  - The domain wake-up controller
  - The other power domain control blocks
- The domain clock controller informs the domain power controller when all conditions for the domain power transition are met (domain clocks are idle, no initiator is requesting service, no wake-up event is pending) to allow a domain power transition. On a wake-up event, the domain clock controller starts the module domain clocks, if power is present.
- The domain power controller communicates with the domain clock controller, the domain wake-up controller, and PSCON. Depending on the register settings for clock domain activity (idle or active), it sends requests to the PSCON to power down/up the domain logic and memory, or to enable retention mode.
- The PSCON sequences all sleep and wake-up transitions between on, off, and retention modes for

logic and memory. It also ensures that the domain is correctly isolated when it enters off or retention mode.

- The domain wake-up controller gathers all events that can wake up the power domain. Some events are active only when the domain is on (these switch on the clocks, when required); others also allow domain power up. These events can be internal (coming from the modules in the power domain, such as general-purpose [GP] timer time-out), external (coming from another power domain control block dependency), or global (voltage stabilization).
- The reset manager globally controls all resets in the device. It gathers information from all power domain control blocks to sequence power and clocks, and resets the activation of each domain.
- The clock generator generates and distributes clocks over the device, depending on requests from all module clock controllers and on other global conditions.

### **3.5.4.2 Sleep Transition**

The PRCM module can initiate a domain sleep transition on a power domain only if the domain meets the following conditions:

- All initiator modules are idle (they have completed their activity and idled themselves through software requests).
- All target modules are idle (automatically when all initiators are in standby mode or on software request).
- All sleep dependencies with other domains are met (can be set by software).

When the sleep conditions are met (based on the settings of the PRCM.PRM\_PWSTCTRL\_power domain[1,0] POWERSTATE bit field), the PRCM module performs the actions described in [Table 3-62](#) automatically or when instructed by the software.

**Table 3-62. Power-State-Related Sleep Transition Actions**

| Power Domain State | Action                                                                                                                                                   |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| ON                 | All functional and interface clocks in the power domain are shut down when the sleep conditions are met. The power domain is idle and is not functional. |
| Retention          | The power domain is idle and part or all of the logic and memory of the domain is switched to retention mode.                                            |
| Off                | The domain is idled and all the logic and memory in the domain are switched off.                                                                         |

The power domain state transition can be set to automatic (hardware controlled) or software-controlled by setting the PRCM.CM\_CLKSTCTRL\_power domain CLKTRCTRL\_power domain bit field.

### **3.5.4.3 Wakeup**

A wake-up event switches on two domains:

- A power domain (logic and associated memories) that is in inactive state
- A clock domain (including related clock sources, such as a DPLL)

If a domain is already on and the clock domain is idle, only the clocks are reactivated on a wake-up event.

To wake up, a processor requires an interrupt associated with the wake-up event. If its power domain is to transition from off or retention state to active, it must be reset.

There are three types of wake-up events:

- Global: Generated on a particular device event (device wakeup, voltage transition completed, DPLL recalibration, etc.). Used mainly to wake up the MPU domain
- Module: Functional wake-up event issued from a module, which wakes up the domain where the module resides. It can also directly wake up the MPU or the IVA2.2 processor, depending on software settings in the PRCM.PM\_MPUGRPSEL\_power domain and PRCM.PM\_IVA2GRPSEL\_power domain registers.
- Dependency: A power domain can wake up on the wakeup of another power domain. The dependency is software-controllable by configuring the PRCM.PM\_WKDEP\_power domain register.

### 3.5.4.4 Device Wake-Up Events

This section summarizes the wake-up events for each power domain. [Table 3-63](#) through [Table 3-73](#) list the wake-up events, related control registers, and MPU and IVA2.2 interrupts.

Two registers, PRCM.PRM\_IRQENABLE\_MPU and PRCM.PRM\_IRQENABLE\_IVA2, enable the MPU and IVA2.2 interrupts. In some cases, they can also enable the wake-up feature associated with the interrupt (DPLL recalibration requests, voltage controller and processors errors, and device wake-up event).

**NOTE:**

- The PRCM module can be configured to generate an interrupt to the MPU or the IVA2 subsystem as a result of a wake-up event from the CORE, WKUP, and PER power domain modules to the MPU and the IVA2. However, these modules can also directly interrupt the MPU and the IVA2 subsystems. To avoid a double interrupt (from the PRCM module and one of these modules) as the result of a single event (wakeup), one interrupt must be masked when the other is unmasked. For more information about the interrupt capability of a module, see the module chapter.
- The UART, GPIO, and McSPI modules generate an asynchronous wake-up event (their interface and functional clocks can be gated during the sleep period). However, because the GPTIMERs generate a synchronous wake-up event, they require their functional clock to be active during the sleep period; their interface clock can be gated. McBSP modules can generate a synchronous or asynchronous wake-up event, based on the mode configurations. For more information about the interrupt capability of a module, see the module chapter.
- The ability of a module to generate a wake-up event depends on the power state of the power domain in which the module resides. If the power domain is inactive (the functional and interface clocks of the domain are gated), only the asynchronous wake-up modules can wake up the power domain. If only the interface clocks in the domain are gated, synchronous and asynchronous wake-up modules can generate a wake-up event to activate the interface clock. Similarly, if the power domain is in retention or off power state (the domain logic is nonfunctional), no wake-up event can be generated by any module in that power domain.

**Table 3-63. MPU Power Domain Wake-Up Events**

| Internal Wake-Up Events                    | Source Module | PRCM Software Control                                                                                                                                                                                                                                                                              | Wake-Up Event | Interrupt/Type                                                                         | Interrupt to |
|--------------------------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------------------------------------------------------------------------------------|--------------|
| IVA2, CORE, DSS, and PER domain dependency | PRCM          | <a href="#">PM_WKDEP_MPU</a>                                                                                                                                                                                                                                                                       | Yes           | No                                                                                     | N/A          |
| Peripherals wake-up events                 | Peripherals   | <a href="#">PM_MPUGRPSEL1_CORE</a>                                                                                                                                                                                                                                                                 | Yes           | MPU peripheral group event occurred.                                                   | MPU          |
|                                            |               | <a href="#">PM_MPUGRPSEL3_CORE</a>                                                                                                                                                                                                                                                                 |               |                                                                                        |              |
|                                            |               | <a href="#">PM_MPUGRPSEL_WKUP</a>                                                                                                                                                                                                                                                                  |               |                                                                                        |              |
|                                            |               | <a href="#">PM_MPUGRPSEL_PER</a>                                                                                                                                                                                                                                                                   |               |                                                                                        |              |
| Event generator on, off time               | PRCM          | <a href="#">PM_EVGENCTRL_MPU</a>                                                                                                                                                                                                                                                                   | Yes           | Event generator on, off                                                                | MPU          |
| Forced wake-up transition                  | PRCM          | <a href="#">CM_CLKSTCTRL_IVA2</a><br><a href="#">CM_CLKSTCTRL_NEON</a><br><a href="#">CM_CLKSTCTRL_SGX</a><br><a href="#">CM_CLKSTCTRL_DSS</a><br><a href="#">CM_CLKSTCTRL_CAM</a><br><a href="#">CM_CLKSTCTRL_PER</a><br><a href="#">CM_CLKSTCTRL_USBHOST</a><br><a href="#">CM_CLKSTCTRL_EMU</a> | No            | Wake-up transition is complete (IVA2, NEON, SGX, USBHOST, DSS, CAM, PER, EMU domains). | MPU          |

**Table 3-63. MPU Power Domain Wake-Up Events (continued)**

| Internal Wake-Up Events     | Source Module | PRCM Software Control | Wake-Up Event | Interrupt/Type                                                                       | Interrupt to |
|-----------------------------|---------------|-----------------------|---------------|--------------------------------------------------------------------------------------|--------------|
| Forced sleep transition     | PRCM          | CM_CLKSTCTRL_IVA2     | No            | Sleep transition is complete (IVA2, NEON, SGX, USBHOST, DSS, CAM, PER, EMU domains). | MPU          |
|                             |               | CM_CLKSTCTRL_NEON     |               |                                                                                      |              |
|                             |               | CM_CLKSTCTRL_SGX      |               |                                                                                      |              |
|                             |               | CM_CLKSTCTRL_DSS      |               |                                                                                      |              |
|                             |               | CM_CLKSTCTRL_CAM      |               |                                                                                      |              |
|                             |               | CM_CLKSTCTRL_PER      |               |                                                                                      |              |
|                             |               | CM_CLKSTCTRL_USBHOST  |               |                                                                                      |              |
|                             |               | CM_CLKSTCTRL_EMU      |               |                                                                                      |              |
| DPLL1 recalibration request | PRCM          | N/A                   | Yes           | MPU DPLL recalibration event                                                         | MPU          |
| DPLL2 recalibration request | PRCM          | N/A                   | Yes           | IVA2 DPLL recalibration event                                                        | MPU, IVA2    |
| DPLL3 recalibration request | PRCM          | N/A                   | Yes           | CORE DPLL recalibration event                                                        | MPU          |
| DPLL4 recalibration request | PRCM          | N/A                   | Yes           | Peripheral DPLL recalibration event                                                  | MPU          |
| DPLL5 recalibration request | PRCM          | N/A                   | Yes           | Peripheral DPLL2 recalibration event                                                 | MPU          |
| Voltage controller error    | PRCM          | N/A                   | Yes           | Voltage controller error status (I <sup>2</sup> C frame not acknowledged)            | MPU          |
| Voltage processor 1, 2      | PRCM          | N/A                   | Yes           | Voltage processor 1 and voltage processor 2 status                                   | MPU          |
| Device wake-up event        | PRCM          | N/A                   | Yes           | Any PAD wake-up event when CORE domain is off                                        | MPU          |

**Table 3-64. NEON Power Domain Wake-Up Events**

| Internal Wake-Up Events   | Source Module | PRCM Software Control | Wake-Up Event | Interrupt/Type                  | Interrupt to |
|---------------------------|---------------|-----------------------|---------------|---------------------------------|--------------|
| MPU domain dependency     | PRCM          | PM_WKDEP_NEON         | Yes           | No                              | N/A          |
| Forced wake-up transition | PRCM          | CM_CLKSTCTRL_NEON     | Yes           | Wake-up transition is complete. | MPU          |

**Table 3-65. IVA2 Power Domain Wake-Up Events**

| Internal Wake-Up Events   | Source Module | PRCM Software Control | Wake-Up Event | Interrupt/Type                           | Interrupt to |
|---------------------------|---------------|-----------------------|---------------|------------------------------------------|--------------|
| MPU domain dependency     | PRCM          | PM_WKDEP_IVA2         | Yes           | No                                       | N/A          |
| CORE domain dependency    | PRCM          | PM_WKDEP_IVA2         | Yes           | No                                       | N/A          |
| DSS domain dependency     | PRCM          | PM_WKDEP_IVA2         | Yes           | No                                       | N/A          |
| PER domain dependency     | PRCM          | PM_WKDEP_IVA2         | Yes           | No                                       | N/A          |
| WKUP domain dependency    | PRCM          | PM_WKDEP_IVA2         | Yes           | No                                       | N/A          |
| Peripheral wake-up events | Peripherals   | PM_IVA2GRPSEL1_CORE   | Yes           | IVA2.2 peripheral group event occurred . | IVA          |

**Table 3-65. IVA2 Power Domain Wake-Up Events (continued)**

| Internal Wake-Up Events   | Source Module | PRCM Software Control | Wake-Up Event | Interrupt/Type                  | Interrupt to |
|---------------------------|---------------|-----------------------|---------------|---------------------------------|--------------|
|                           |               | PM_IVA2GRPSEL3_CORE   |               |                                 |              |
|                           |               | PM_IVA2GRPSEL_PER     |               |                                 |              |
| Forced wake-up transition | PRCM          | CM_CLKSTCTRL_IVA2     | Yes           | Wake-up transition is complete. | IVA, MPU     |

**Table 3-66. SGX Power Domain Wake-Up Events**

| Internal Wake-Up Events   | Source Module | PRCM Software Control | Wake-Up Event | Interrupt/Type                  | Interrupt to |
|---------------------------|---------------|-----------------------|---------------|---------------------------------|--------------|
| MPU domain dependency     | PRCM          | PM_WKDEP_SGX          | Yes           | No                              | N/A          |
| IVA2 domain dependency    | PRCM          | PM_WKDEP_SGX          | Yes           | No                              | N/A          |
| WKUP domain dependency    | PRCM          | PM_WKDEP_SGX          | Yes           | No                              | N/A          |
| Forced wake-up transition | PRCM          | CM_CLKSTCTRL_SGX      | Yes           | Wake-up transition is complete. | MPU          |

**Table 3-67. CORE Power Domain Wake-Up Events**

| Internal Wake-Up Events   | Source Module | PRCM Software Control                   | Wake-Up Event | Interrupt/Type | Interrupt to |
|---------------------------|---------------|-----------------------------------------|---------------|----------------|--------------|
| MPU domain dependency     | PRCM          | Hardware set (always-enabled)           | Yes           | No             | N/A          |
| IVA2 domain dependency    | PRCM          |                                         | Yes           | No             | N/A          |
| CAM domain dependency     | PRCM          |                                         | Yes           | No             | N/A          |
| DSS domain dependency     | PRCM          |                                         | Yes           | No             | N/A          |
| USBHOST domain dependency | PRCM          |                                         | Yes           | No             | N/A          |
| PER domain dependency     | PRCM          |                                         | Yes           | No             | N/A          |
| SGX domain dependency     | PRCM          |                                         | Yes           | No             | N/A          |
| WKUP domain dependency    | PRCM          |                                         | Yes           | No             | N/A          |
| HS USB OTG wakeup         | HS USB OTG    | PM_processorGRPSEL1_CORE, PM_WKEN1_CORE | Yes           | No             | N/A          |
| McBSP1 wakeup             | McBSP 1       |                                         | Yes           | No             | N/A          |
| McBSP5 wakeup             | McBSP 5       |                                         | Yes           | No             | N/A          |
| GPTIMER10 wakeup          | GPTIMER 10    |                                         | Yes           | No             | N/A          |
| GPTIMER11 wakeup          | GPTIMER 11    |                                         | Yes           | No             | N/A          |
| UART1 wakeup              | UART 1        |                                         | Yes           | No             | N/A          |
| UART2 wakeup              | UART 2        |                                         | Yes           | No             | N/A          |
| McSPI1 wakeup             | McSP 1        |                                         | Yes           | No             | N/A          |
| McSPI2 wakeup             | McSP 2        |                                         | Yes           | No             | N/A          |
| McSPI3 wakeup             | McSP 3        |                                         | Yes           | No             | N/A          |
| McSPI4 wakeup             | McSP 4        |                                         | Yes           | No             | N/A          |
| MMC1 wakeup               | MMC 1         |                                         | Yes           | No             | N/A          |

**Table 3-67. CORE Power Domain Wake-Up Events (continued)**

| <b>Internal Wake-Up Events</b> | <b>Source Module</b> | <b>PRCM Software Control</b> | <b>Wake-Up Event</b> | <b>Interrupt/Type</b>                         | <b>Interrupt to</b> |
|--------------------------------|----------------------|------------------------------|----------------------|-----------------------------------------------|---------------------|
| MMC2 wakeup                    | MMC 2                |                              | Yes                  | No                                            | N/A                 |
| MMC3 wakeup                    | MMC 3                |                              | Yes                  | No                                            | N/A                 |
| USBTLL wakeup                  | USBTLL               |                              | Yes                  | No                                            | N/A                 |
| Device wake-up event           | PRCM                 | N/A                          | Yes                  | Any PAD wake-up event when CORE domain is off | MPU                 |

**Table 3-68. DSS Power Domain Wake-Up Events**

| <b>Internal Wake-Up Events</b> | <b>Source Module</b> | <b>PRCM Software Control</b>              | <b>Wake-Up Event</b> | <b>Interrupt/Type</b>           | <b>Interrupt to</b> |
|--------------------------------|----------------------|-------------------------------------------|----------------------|---------------------------------|---------------------|
| MPU domain dependency          | PRCM                 | <a href="#">PM_WKDEP_DSS</a> register     | Yes                  | No                              | N/A                 |
| IVA2 domain dependency         | PRCM                 | <a href="#">PM_WKDEP_DSS</a> register     | Yes                  | No                              | N/A                 |
| WKUP domain dependency         | PRCM                 | <a href="#">PM_WKDEP_DSS</a> register     | Yes                  | No                              | N/A                 |
| Forced transition state wakeup | PRCM                 | <a href="#">CM_CLKSTCTRL_DSS</a> register | Yes                  | Wake-up transition is complete. | MPU                 |

**Table 3-69. CAM Power Domain Wake-Up Events**

| <b>Internal Wake-Up Events</b> | <b>Source Module</b> | <b>PRCM Software Control</b>              | <b>Wake-Up Event</b> | <b>Interrupt/Type</b>           | <b>Interrupt to</b> |
|--------------------------------|----------------------|-------------------------------------------|----------------------|---------------------------------|---------------------|
| MPU domain dependency          | PRCM                 | <a href="#">PM_WKDEP_CAM</a> register     | Yes                  | No                              | N/A                 |
| IVA2 domain dependency         | PRCM                 | <a href="#">PM_WKDEP_CAM</a> register     | Yes                  | No                              | N/A                 |
| WKUP domain dependency         | PRCM                 | <a href="#">PM_WKDEP_CAM</a> register     | Yes                  | No                              | N/A                 |
| Forced transition state wakeup | PRCM                 | <a href="#">CM_CLKSTCTRL_CAM</a> register | Yes                  | Wake-up transition is complete. | MPU                 |

**Table 3-70. USBHOST Power Domain Wake-Up Events**

| <b>Internal Wake-Up Events</b> | <b>Source Module</b> | <b>PRCM Software Control</b>                                                    | <b>Wake-Up Event</b> | <b>Interrupt/Type</b>           | <b>Interrupt to</b> |
|--------------------------------|----------------------|---------------------------------------------------------------------------------|----------------------|---------------------------------|---------------------|
| MPU domain dependency          | PRCM                 | <a href="#">PM_WKDEP_USBHOST</a> register                                       | Yes                  | No                              | N/A                 |
| CORE domain dependency         | PRCM                 | <a href="#">PM_WKDEP_USBHOST</a> register                                       | Yes                  | No                              | N/A                 |
| IVA2 domain dependency         | PRCM                 | <a href="#">PM_WKDEP_USBHOST</a> register                                       | Yes                  | No                              | N/A                 |
| WKUP domain dependency         | PRCM                 | <a href="#">PM_WKDEP_USBHOST</a> register                                       | Yes                  | No                              | N/A                 |
| USBHOST wake-up                | HS USB Host          | <a href="#">PM_processorGRPSEL_USBHOST</a> ,<br><a href="#">PM_WKEN_USBHOST</a> | Yes                  | No                              | N/A                 |
| Forced transition state wakeup | PRCM                 | <a href="#">CM_CLKSTCTRL_USBHOST</a> register                                   | Yes                  | Wake-up transition is complete. | MPU                 |

**Table 3-71. PER Power Domain Wake-Up Events**

| Internal Wake-Up Events        | Source Module | PRCM Software Control                                                 | Wake-Up Event | Interrupt/Type                  | Interrupt to |
|--------------------------------|---------------|-----------------------------------------------------------------------|---------------|---------------------------------|--------------|
| MPU domain dependency          | PRCM          | <a href="#">PM_WKDEP_PER</a> register                                 | Yes           | No                              | N/A          |
| IVA2 domain dependency         | PRCM          | <a href="#">PM_WKDEP_PER</a> register                                 | Yes           | No                              | N/A          |
| CORE domain dependency         | PRCM          | <a href="#">PM_WKDEP_PER</a> register                                 | Yes           | No                              | N/A          |
| WKUP domain dependency         | PRCM          | <a href="#">PM_WKDEP_PER</a> register                                 | Yes           | No                              | N/A          |
| McBSP2 wakeup                  | McBSP 2       | <a href="#">PM_processorGRPSEL1_PER</a> , <a href="#">PM_WKEN_PER</a> | Yes           | No                              | N/A          |
| McBSP3 wakeup                  | McBSP 3       |                                                                       | Yes           | No                              | N/A          |
| McBSP4 wakeup                  | McBSP 4       |                                                                       | Yes           | No                              | N/A          |
| GPTIMER2 wakeup                | GPTIMER2      |                                                                       | Yes           | No                              | N/A          |
| GPTIMER3 wakeup                | GPTIMER3      |                                                                       | Yes           | No                              | N/A          |
| GPTIMER4 wakeup                | GPTIMER4      |                                                                       | Yes           | No                              | N/A          |
| GPTIMER5 wakeup                | GPTIMER5      |                                                                       | Yes           | No                              | N/A          |
| GPTIMER6 wakeup                | GPTIMER6      |                                                                       | Yes           | No                              | N/A          |
| GPTIMER7 wakeup                | GPTIMER7      |                                                                       | Yes           | No                              | N/A          |
| GPTIMER8 wakeup                | GPTIMER 8     |                                                                       | Yes           | No                              | N/A          |
| GPTIMER9 wakeup                | GPTIMER9      |                                                                       | Yes           | No                              | N/A          |
| UART3 wakeup                   | UART3         |                                                                       | Yes           | No                              | N/A          |
| UART4 wakeup                   | UART4         |                                                                       | Yes           | No                              | N/A          |
| GPIO2 wakeup                   | GPIO 2        |                                                                       | Yes           | No                              | N/A          |
| GPIO3 wakeup                   | GPIO 3        |                                                                       | Yes           | No                              | N/A          |
| GPIO4 wakeup                   | GPIO 4        |                                                                       | Yes           | No                              | N/A          |
| GPIO5 wakeup                   | GPIO 5        |                                                                       | Yes           | No                              | N/A          |
| GPIO6 wakeup                   | GPIO 6        |                                                                       | Yes           | No                              | N/A          |
| Forced transition state wakeup | PRCM          | <a href="#">CM_CLKSTCTRL_PER</a> register                             | Yes           | Wake-up transition is complete. | MPU          |

**Table 3-72. EMU Power Domain Wake-Up Events**

| Internal Wake-Up Events        | Source Module | PRCM Software Control                     | Wake-Up Event | Interrupt/Type                  | Interrupt to |
|--------------------------------|---------------|-------------------------------------------|---------------|---------------------------------|--------------|
| EMU wakeup                     | ICEPick-C     | N/A                                       | Yes           | No                              | N/A          |
| Forced transition state wakeup | PRCM          | <a href="#">CM_CLKSTCTRL_EMU</a> register | Yes           | Wake-up transition is complete. | MPU          |

**Table 3-73. WKUP Power Domain Wake-Up Events**

| Internal Wake-Up Events | Source Module | PRCM Software Control        | Wake-Up Event | Interrupt/Type | Interrupt to |
|-------------------------|---------------|------------------------------|---------------|----------------|--------------|
| Device wakeup           | PRCM          | <a href="#">PM_WKEN_WKUP</a> | Yes           | No             | N/A          |
| SmartReflex1 wakeup     | SmartReflex1  |                              | Yes           | No             | N/A          |
| SmartReflex2 wakeup     | SmartReflex2  |                              | Yes           | No             | N/A          |
| GPTIMER1 wakeup         | GPTIMER1      |                              | Yes           | No             | N/A          |
| GPIO1 wakeup            | GPIO 1        |                              | Yes           | No             | N/A          |

**NOTE:** Some of the 32 I/O pins for the GPIO1 in the WKUP power domain are connected to the device I/O pad logic in the CORE power domain (VDD2) and to the reset to the device I/O pad logic in the WKUP power domain (VDD3). As a result, when the CORE power domain is off, the corresponding I/O pins of the GPIO1 cannot generate a wake-up event. For details, see [Chapter 25, General-Purpose Interface Module](#).

### 3.5.4.5 Sleep and Wake-Up Dependencies

#### 3.5.4.5.1 Sleep Dependencies

The (clock activity) dependencies between power domains are implemented to manage their sleep and wake-up transitions to ensure stable operation of the device.

A power domain sleep transition is achieved when all its clock domains (that is, functional and interface) are gated. For the gating of a clock domain, the following conditions must be satisfied:

- All initiator modules in the clock domain are in standby mode, that is, they cannot initiate any new transitions.
- All target modules in the clock domain are in idle mode and have no pending transitions.
- If the power domain depends on another power domain (that is, has a sleep dependency), the clock domains of the other power domain must be muted.

A clock domain is said to be muted when all its public initiator modules (that is, the initiator modules of the clock domain that can generate interconnect transactions towards targets outside the clock domain) are in standby mode, and the domain cannot initiate new interconnect transactions toward other domains.

[Table 3-74](#) describes the mute conditions for the clock domains.

**Table 3-74. Clock Domain Mute Conditions**

| Clock Domain Name | Clock Domain Composition                                    | Mute Conditions                |
|-------------------|-------------------------------------------------------------|--------------------------------|
| MPU               | MPU power domain and MPU INTC in CORE power domain          | MPU in stand-by, MPU INTC idle |
| IVA2              | IVA2 power domain and WUGEN in CORE power domain            | IVA2.2 in stand-by, WUGEN idle |
| SGX               | SGX power domain                                            | SGX in stand-by                |
| CAM               | CAM power domain                                            | CAM in stand-by                |
| DSS               | DSS power domain                                            | DSS in stand-by                |
| PER               | PER power domain                                            | N/A (No public Initiator)      |
| CORE_L3           | L3 interconnect, L3 targets/initiators in CORE power domain | sDMA in standby                |
| CORE_L4           | L4 interconnect, L4 targets in CORE power domain            | N/A (No public Initiator)      |
| USBHOST           | USBHOST power domain                                        | USBHOST in stand-by            |
| WKUP              | WKUP power domain                                           | N/A (No public Initiator)      |

A sleep dependency prevents the PRCM module from gating the clocks to a power domain (for sleep transition to inactive, retention, or off state from on state) if a dependent power domain is active (its clocks are active). A power domain can depend on several other power domains.

A power domain sleep dependency is programmed by setting the PRCM.CM\_SLEEPDEP\_domain register.

**Example:**

The PER domain has a programmable sleep dependency with the MPU and IVA2 power domains, and a hardwired sleep dependency with the CORE power domain. Therefore, if all software dependencies are enabled, the PER domain can go to idle mode only if the MPU, IVA2, and CORE-L3 clock domains are idle. If all software dependencies are disabled, the PER domain can go to idle mode, provided that the CORE-L3 clock domain is muted (no access to the PER domain can be pending).

Table 3-75 summarizes the programmable and hardwired sleep dependencies among the domains.

---

**NOTE:** The first row of the table identifies the dependent power domains for a power domain listed in the first column. Therefore, to identify the sleep dependency of power domain X, identify domain X in the first column, then follow its row to its sleep dependency with another power domain (identified in the top row).

---

**Table 3-75. Sleep Dependencies**

|              |              | Sleep Dependency |      |      |     |     |     |     |         |         |         |          |      |
|--------------|--------------|------------------|------|------|-----|-----|-----|-----|---------|---------|---------|----------|------|
| Power Domain | Clock Domain | MPU              | NEON | IVA2 | SGX | CAM | DSS | PER | CORE_L3 | CORE_L4 | CORE_CM | USB HOST | WKUP |
| MPU          | MPU          | N/A              | 0    | 0    | 0   | 0   | 0   | 0   | 0       | 0       | 0       | 0        | 0    |
| NEON         | MPU          | 1                | N/A  | 0    | 0   | 0   | 0   | 0   | 0       | 0       | 0       | 0        | 0    |
| IVA2         | IVA2         | 0                | 0    | N/A  | 0   | 0   | 0   | 0   | 0       | 0       | 0       | 0        | 0    |
| SGX          | SGX          | RW               | 0    | 0    | N/A | 0   | 0   | 0   | 0       | 0       | 0       | 0        | 0    |
| CAM          | CAM          | RW               | 0    | 0    | 0   | N/A | 0   | 0   | 0       | 0       | 0       | 0        | 0    |
| DSS          | DSS          | RW               | 0    | RW   | 0   | 0   | N/A | 0   | RW      | 0       | 0       | 0        | 0    |
| PER          | PER          | RW               | 0    | RW   | 0   | 0   | 0   | N/A | 1       | 0       | 0       | 0        | 0    |
| CORE         | CORE_L3      | 1                | 0    | 1    | 1   | 1   | 1   | 1   | N/A     | 1       | 0       | 1        | 1    |
|              | CORE_L4      | 1                | 0    | 1    | 0   | 0   | 0   | 0   | 1       | N/A     | 0       | 0        | 0    |
|              | CORE_CM      | 1                | 1    | 1    | 1   | 1   | 1   | 1   | 1       | N/A     | 1       | 1        | 1    |
| USBHOST      | USBHOST      | RW               | 0    | RW   | 0   |     |     | 0   | 0       | 0       | 0       | N/A      | 0    |
| WKUP         | WKUP         | 1                | 0    | 1    | 0   | 0   | 0   | 0   | 1       | 0       | 0       | 0        | N/A  |

**Notes:**

|                                         |     |                    |
|-----------------------------------------|-----|--------------------|
| No software control (hardwired values): | 0   | Does not depend on |
|                                         | 1   | Depends on         |
| Software controllable                   | RW  | Read and write     |
|                                         | N/A | Not applicable     |

### 3.5.4.5.2 Wake-Up Dependencies

A wake-up dependency allows a power domain to wake up (from off, retention or inactive state to on state) when another power domain wakes up (from off, retention or inactive state to on state). For example, power domain one (PD1) provides a service to power domain two (PD2), which creates a dependency between the two domains. When the dependent power domain (PD2) wakes up, it signals PD1 with a broadcasted wake-up event, causing PD1 to wake up.

A broadcasted wake-up event can originate from one of two sources:

- PD2 internal wake-up event (typically, a peripheral wake-up event)
- Abortion of the mute mode (at least one initiator in the domain exits standby mode) of PD2 when both the sleep dependency and wake-up dependency with PD1 are enabled.

**NOTE:** The domain wake-up dependency is a non-transitive property.

If power domain PD1 has wake-up dependency with power domain PD2, the PRCM.PM\_WKDEP\_PD1. EN\_PD2 bit is set to 1, and if PD2 has wake-up dependency with power domain PD3, the PRCM.PM\_WKDEP\_PD2. EN\_PD3 bit is set to 1.

However, if PD1 does not have a direct wake-up dependency with PD3, the PRCM.PM\_WKDEP\_PD1. EN\_PD3 bit is set to 0. If PD1 and PD2 are in INACTIVE/RETENTION or OFF power state and PD3 is inactive and is woken-up by a wake-up event, PD2 is also woken-up, but PD1 is not.

Because a power domain can depend on several other power domains, it can broadcast the wake-up signal to each power domain on which it depends.

A power domain wake-up dependency can either be hardwired (set in the hardware) or programmable through software by configuring the PM\_WKDEP\_domain register for that power domain. Continuing the example of PD2 as dependent on PD1, setting the PM\_WKDEP\_PD1.PD2 bit means that when PD2 wakes up, PD1 also wakes up.

The MPU power domain can be wakened only by the IVA2, DSS, USBHOST, PER, CORE-L3, CORE-L4, and WKUP power domains. Similarly, the IVA2 power domain can be wakened only by the MPU, DSS, USBHOST, PER, CORE-L3, CORE-L4, and WKUP power domains. All wake-up dependencies of the MPU and the IVA2 power domain are software-configurable.

For the processor power domains (MPU and the IVA2 power domain), when the wake-up dependency with other power domains is software-programmable (that is, with the USBHOST, PER, CORE, and WKUP power domains), two registers may need be configured: PM\_WKDEP\_domain and PM\_processorGROUPSEL\_domain.

The PM\_WKDEP\_domain register serves only to enable/disable the global wake-up dependency of the processor power domain on these three power domains. The PM\_processorGROUPSEL\_domain register must be configured to enable the particular wake-up event in these domains that will wake up the processor domain. Thus, the global wake-up dependency for a dependent domain must be enabled so that a wake-up event can occur, if it has been enabled in the corresponding GROUPSEL register.

For example, if the wake-up dependency of the MPU power domain is to be enabled for a wake-up event from the GPIO2 module of the PER power domain, the following configuration is required:

- PRCM.PM\_MPUGRPSEL\_PER[13] GRPSEL\_GPIO2
- PRCM.PM\_WKDEP\_MPU[7] EN\_PER

Table 3-76 summarizes the programmable and hardwired wake-up dependencies among the domains.

**Table 3-76. Wake-Up Dependencies**

|              |              | Wake-Up Dependency |      |      |     |     |     |          |     |         |         |         |      |
|--------------|--------------|--------------------|------|------|-----|-----|-----|----------|-----|---------|---------|---------|------|
| Power Domain | Clock Domain | MPU                | NEON | IVA2 | SGX | CAM | DSS | USB HOST | PER | CORE_L3 | CORE_L4 | CORE_CM | WKUP |
| MPU          | MPU          | N/A                | 0    | RW   | 0   | 0   | RW  | RW**     | RW* | RW*     | RW*     | 0       | RW** |
| NEON         | MPU          | RW                 | N/A  | 0    | 0   | 0   | 0   | 0        | 0   | 0       | 0       | 0       | 0    |
| IVA2         | IVA2         | RW                 | 0    | N/A  | 0   | 0   | RW  | RW**     | RW* | RW*     | RW*     | 0       | RW*  |
| SGX          | SGX          | RW                 | 0    | RW   | N/A | 0   | 0   | 0        | 0   | 0       | 0       | 0       | RW   |

**Table 3-76. Wake-Up Dependencies (continued)**

|              |              | Wake-Up Dependency |      |      |     |     |     |          |     |         |         |         |      |
|--------------|--------------|--------------------|------|------|-----|-----|-----|----------|-----|---------|---------|---------|------|
| Power Domain | Clock Domain | MPU                | NEON | IVA2 | SGX | CAM | DSS | USB HOST | PER | CORE_L3 | CORE_L4 | CORE_CM | WKUP |
| CAM          | CAM          | RW                 | 0    | RW   | 0   | N/A | 0   | 0        | 0   | 0       | 0       | 0       | RW   |
| DSS          | DSS          | RW                 | 0    | RW   | 0   | 0   | N/A | 0        | 0   | 0       | 0       | 0       | RW   |
| USBHOST      | USBHOST      | RW                 | 0    | RW   | 0   | 0   | 0   | N/A      | 0   | RW      | 0       | 0       | RW   |
| PER          | PER          | RW                 | 0    | RW   | 0   | 0   | 0   | 0        | N/A | RW      | 0       | 0       | RW   |
| CORE         | CORE_L3      | 1                  | 0    | 1    | 0   | 0   | 1   | 1        | 1   | N/A     | 1       | 0       | 1    |
|              | CORE_L4      | 1                  | 0    | 1    | 0   | 0   | 0   | 0        | 0   | 0       | N/A     | 0       | 1    |
|              | CORE_CM      | 1                  | 0    | 1    | 0   | 0   | 1   | 1        | 1   | 1       | 1       | N/A     | 1    |
| WKUP         | WKUP         | 1                  | 0    | 1    | 0   | 0   | 0   | 1        | 1   | 1       | 1       | 0       | N/A  |

**Notes:**

|      |                                                                              |
|------|------------------------------------------------------------------------------|
| RW   | Software wakeup dependency: dependency by PM_WKDEP_ register                 |
| RW*  | Software wakeup dependency: dependency by PM_WKDEP_ and PM_GRPSEL_ registers |
| RW** | Software wakeup dependency: dependency by PM_GRPSEL_ registers               |
| 1    | Hardware wakeup dependency: dependency always enabled                        |
| 0    | No wakeup dependency applicable                                              |

### 3.5.4.6 USBHOST/USBTLL Save-and-Restore Management

Both USBHOST and USBTLL support a save-and-restore mechanism. When the device enters into off mode (that is, all power domains, except the WKUP power domain, are off), the user may want to save the USBHOST context and restore it when exiting off mode. The save-and-restore mechanism for the HS USB Host is enabled by setting the PRCM.PM\_PWSTCTRL\_USBHOST[4] SAVEANDRESTORE bit; for the USBTLL, it is configured by the PRCM.PM\_PWSTCTRL\_CORE[4] SAVEANDRESTORE bit. The save mechanism is initiated as the power domain transitions from active to off state (or to OSWR state for the USBTLL), whereas the restore mechanism is initiated as the power domain transitions from off to active power state.

[Figure 3-77](#) shows the generic save-and-restore sequence applicable to both the USBHOST and the USBTLL. The sequence follows:

1. When the PRCM module intends to initiate a sleep transition over the power domain (the USBHOST power domain for the HS USB Host subsystem and the CORE power domain for the USBTLL module), it sends a sleep request to the power domain. When the domain modules acknowledge the sleep request, the functional and interface clocks to the modules are gated.
2. The PRCM module enables the SAR\_FCLK functional clock and initiates the save sequence for the module. SAR\_FCLK is gated when the save sequence completes.
3. The PRCM module switches the power domain state to off power state. When a wake-up event occurs, the PRCM module switches on the power domain.
4. The power domain local reset is asserted and then released by the reset manager.
5. The PRCM module enables the SAR\_FCLK functional clock, and then initiates the restore sequence for the module. SAR\_FCLK is gated when the restore sequence completes.
6. The PRCM module enables the functional and interface clocks to the modules and releases the sleep request. The modules acknowledge, and the wake-up sequence completes.

---

**NOTE:** The PRCM sleep request and the module acknowledge signals are part of a hardware communication interface to ensure the correct sleep and wake-up sequence.

---

[Figure 3-77](#) shows the save-and-restore sequence. It does not provide the exact timing delays between the switching of the signals and serves only to highlight the sequence of events.

**Figure 3-77. Save-and-Restore Sequence**


prcm-092

### 3.5.4.6.1 USBHOST SAR Sequences

#### 3.5.4.6.1.1 Save Sequence on Sleep Transition

A precondition to the save sequence on sleep transition is that the save-and-restore mechanism is enabled (the PRCM.[PM\\_PWSTCTRL\\_USBHOST\[4\]](#) SAVEANDRESTORE bit is set to 1). The sequence is initiated when the power domain switches from ON to OFF power state.

1. The PRCM module activates USBHOST\_SAR\_FCLK and starts the save sequence.
2. When the USBHOST power domain is idled (all clocks of the power domain are gated), the PRM initiates the power domain transition to OFF power state by setting the PRCM.[PM\\_PWSTCTRL\\_USBHOST\[1:0\]](#) POWERSTATE bit field to 0x0.
3. When the save sequence completes, USBHOST\_SAR\_FCLK is gated.
4. The power domain sleep transition to OFF power state completes.

#### 3.5.4.6.1.2 Restore Sequence on Wake-Up Transition

A precondition to the restore sequence on wake-up transition is that the save-and-restore mechanism is enabled (the PRCM.[PM\\_PWSTCTRL\\_USBHOST\[4\]](#) SAVEANDRESTORE bit is set to 1). The sequence is initiated when the power domain switches from off to on power state.

1. The PRCM switches the power domain to ON power state.
2. The PRCM asserts the USBHOST domain reset. The functional reset is released locally when the functional clocks are back.
3. The PRCM releases the USBHOST domain reset.
4. The PRCM module activates USBHOST\_SAR\_FCLK and starts the restore sequence.
5. When the restore sequence completes, USBHOST\_SAR\_FCLK is gated.
6. The power domain wake-up transition to ON power state completes.

### 3.5.4.6.2 USB TLL SAR Sequences

#### 3.5.4.6.2.1 Save Sequence on Sleep Transition

A precondition to the save sequence on sleep transition is that the save-and-restore mechanism is enabled (the PRCM.[PM\\_PWSTCTRL\\_CORE\[4\]](#) SAVEANDRESTORE bit is set to 1). The sequence is initiated when the power domain switches from ON to Open Switch Retention (OSWR) or OFF power state.

1. When the CORE power domain is idled (all clocks of the power domain are gated), the PRM initiates the power domain transition to OFF or OSWR power state by setting the PRCM.[PM\\_PWSTCTRL\\_CORE\[1:0\]](#) POWERSTATE bit field to 0x0 or 0x1.
2. The PRCM module activates USBTLL\_SAR\_FCLK and starts the save sequence.
3. When the save sequence completes, USBTLL\_SAR\_FCLK is gated.
4. The power domain sleep transition to OFF or OSWR power state completes.

#### 3.5.4.6.2.2 Restore Sequence on Wake-Up Transition

A precondition to the restore sequence on wake-up transition is that the save-and-restore mechanism is enabled (the PRCM.[PM\\_PWSTCTRL\\_CORE\[4\]](#) SAVEANDRESTORE bit is set to 1). The sequence is initiated when the power domain switches from OFF or OSWR to ON power state.

1. PRCM switches the power domain to ON power state.
2. Assert CORE domain reset (must override the functional stall conditions of the reset manager). The functional reset is released locally when the functional clocks are back.
3. Release CORE domain reset.
4. The PRCM module activates the USBTLL\_SAR\_FCLK and starts the restore sequence.
5. When the restore sequence completes, USBTLL\_SAR\_FCLK is gated.
6. The power domain wake-up transition to ON power state completes.

### **3.5.5 PRCM Interrupts**

Table 3-77 lists the interrupts from the PRCM module to the MPU and the IVA2.

**Table 3-77. Interrupt Descriptions**

| Interrupt Name | Mapping      | Description                                 |
|----------------|--------------|---------------------------------------------|
| PRCM_MPU_IRQ   | M_IRQ_11     | To MPU interrupt controller (MPU INTC)      |
| PRCM_IVA_IRQ   | IVA2_IRQ[12] | To IVA2.2 wake-up controller (IVA2.2 WUGEN) |

Table 3-78 and Table 3-79 summarize the event flags (in PRM IRQSTATUS\_MPU and PRM IRQSTATUS\_IVA2 registers) and mask (in PRM IRQENABLE\_MPU and PRM IRQENABLE\_IVA2 registers) related to the events generating PRCM interrupts to the MPU and the IVA2.

**Table 3-78. MPU Interrupt Event Descriptions**

| Event Flag                                | Event Mask                                | Map to       | Automatic<br>MPU Domain<br>Wake-Up Event | Description                                                                                                   |
|-------------------------------------------|-------------------------------------------|--------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| PRM_IRQSTATUS_MPU[0] WKUP_ST              | PRM_IRQENABLE_MPU[0] WKUP_EN              | PRCM_MPU_IRQ | No                                       | MPU peripheral group wakeup                                                                                   |
| PRM_IRQSTATUS_MPU[2] EVGENON_ST           | PRM_IRQENABLE_MPU[2] EVGENON_EN           | PRCM_MPU_IRQ | No                                       | Event generator end of on time                                                                                |
| PRM_IRQSTATUS_MPU[3] EVGENOFF_ST          | PRM_IRQENABLE_MPU[3] EVGENOFF_EN          | PRCM_MPU_IRQ | No                                       | Event generator end of off time                                                                               |
| PRM_IRQSTATUS_MPU[4] TRANSITION_ST        | PRM_IRQENABLE_MPU[4] TRANSITION_EN        | PRCM_MPU_IRQ | No                                       | A sleep or wake-up transition completion event for IVA2, NEON, SGX, DSS, CAM, PER, EMU, USBHOST power domains |
| PRM_IRQSTATUS_MPU[5] CORE_DPLL_ST         | PRM_IRQENABLE_MPU[5] CORE_DPLL_RECAL_EN   | PRCM_MPU_IRQ | Yes                                      | DPLL3 recalibration event                                                                                     |
| PRM_IRQSTATUS_MPU[6] PERIPH_DPLL_ST       | PRM_IRQENABLE_MPU[6] PERIPH_DPLL_RECAL_EN | PRCM_MPU_IRQ | Yes                                      | DPLL4 recalibration event                                                                                     |
| PRM_IRQSTATUS_MPU[7] MPU_DPLL_ST          | PRM_IRQENABLE_MPU[7] MPU_DPLL_RECAL_EN    | PRCM_MPU_IRQ | Yes                                      | DPLL2 recalibration event                                                                                     |
| PRM_IRQSTATUS_MPU[8] IVA2_DPLL_ST         | PRM_IRQENABLE_MPU[8] IVA2_DPLL_RECAL_EN   | PRCM_MPU_IRQ | Yes                                      | DPLL1 recalibration event                                                                                     |
| PRM_IRQSTATUS_MPU[9] IO_ST                | PRM_IRQENABLE_MPU[9] IO_EN                | PRCM_MPU_IRQ | No                                       | I/O pads wake-up event                                                                                        |
| PRM_IRQSTATUS_MPU[10] VP1_OPCHANGEDONE_ST | PRM_IRQENABLE_MPU[10] VP1_OPCHANGEDONE_EN | PRCM_MPU_IRQ | No                                       | Voltage processor 1 OPP change done event.                                                                    |
| PRM_IRQSTATUS_MPU[11] VP1_MINVDD_ST       | PRM_IRQENABLE_MPU[11] VP1_MINVDD_EN       | PRCM_MPU_IRQ | No                                       | Voltage processor 1 new voltage reached the minimum voltage value allowed.                                    |
| PRM_IRQSTATUS_MPU[12] VP1_MAXVDD_ST       | PRM_IRQENABLE_MPU[12] VP1_MAXVDD_EN       | PRCM_MPU_IRQ | No                                       | Voltage processor 1 new voltage reached the maximum voltage value allowed.                                    |
| PRM_IRQSTATUS_MPU[13] VP1_NOSMPSACK_ST    | PRM_IRQENABLE_MPU[13] VP1_NOSMPSACK_EN    | PRCM_MPU_IRQ | No                                       | Voltage processor 1 time-out occurred while waiting for the power IC device acknowledge.                      |
| PRM_IRQSTATUS_MPU[14] VP1_EQVALUE_ST      | PRM_IRQENABLE_MPU[14] VP1_EQVALUE_EN      | PRCM_MPU_IRQ | No                                       | Voltage processor 1 new voltage is the same as the current voltage.                                           |

**Table 3-78. MPU Interrupt Event Descriptions (continued)**

| Event Flag                                     | Event Mask                                     | Map to       | Automatic<br>MPU Domain<br>Wake-Up Event | Description                                                                                                                                                                     |
|------------------------------------------------|------------------------------------------------|--------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PRM IRQSTATUS_MPU[15] VP1_TRANXDONE_ST         | PRM_IRQENABLE_MPU[15] VP1_TRANXDONE_EN         | PRCM_MPU_IRQ | No                                       | Voltage processor 1 transaction is complete.                                                                                                                                    |
| PRM IRQSTATUS_MPU[16] VP2_OPCHANGEDONE_ST      | PRM_IRQENABLE_MPU[16] VP2_OPCHANGEDONE_EN      | PRCM_MPU_IRQ | No                                       | Voltage processor 2 OPP change done event.                                                                                                                                      |
| PRM IRQSTATUS_MPU[17] VP2_MINVDD_ST            | PRM_IRQENABLE_MPU[17] VP2_MINVDD_EN            | PRCM_MPU_IRQ | No                                       | Voltage processor 2 new voltage reached the minimum voltage value allowed.                                                                                                      |
| PRM IRQSTATUS_MPU[18] VP2_MAXVDD_ST            | PRM_IRQENABLE_MPU[18] VP2_MAXVDD_EN            | PRCM_MPU_IRQ | No                                       | Voltage processor 2 new voltage reached the maximum voltage value allowed.                                                                                                      |
| PRM IRQSTATUS_MPU[19] VP2_NOSMPSACK_ST         | PRM_IRQENABLE_MPU[19] VP2_NOSMPSACK_EN         | PRCM_MPU_IRQ | No                                       | Voltage processor 2 time-out occurred while waiting for the power IC device acknowledge.                                                                                        |
| PRM IRQSTATUS_MPU[20] VP2_EQVALUE_ST           | PRM_IRQENABLE_MPU[20] VP2_EQVALUE_EN           | PRCM_MPU_IRQ | No                                       | Voltage processor 2 new voltage is the same as the current voltage.                                                                                                             |
| PRM IRQSTATUS_MPU[21] VP2_TRANXDONE_ST         | PRM_IRQENABLE_MPU[21] VP2_TRANXDONE_EN         | PRCM_MPU_IRQ | No                                       | Voltage processor 2 transaction is done.                                                                                                                                        |
| PRM IRQSTATUS_MPU[22] VC_SAERR_ST              | PRM_IRQENABLE_MPU[22] VC_SAERR_EN              | PRCM_MPU_IRQ | Yes                                      | Slave address in an I <sup>2</sup> C frame sent by the voltage controller not acknowledged by the power IC device                                                               |
| PRM IRQSTATUS_MPU[23] VC_RAERR_ST              | PRM_IRQENABLE_MPU[23] VC_RAERR_EN              | PRCM_MPU_IRQ | Yes                                      | Register address in an I <sup>2</sup> C frame sent by the voltage controller not acknowledged by the power IC device                                                            |
| PRM IRQSTATUS_MPU[24] VC_TIMEOUTERR_ST         | PRM_IRQENABLE_MPU[24] VC_TIMEOUTERR_EN         | PRCM_MPU_IRQ | Yes                                      | Last byte of an I <sup>2</sup> C frame issued from the bypass port or from the voltage manager FSM ports sent by the voltage controller not acknowledged by the power IC device |
| PRM IRQSTATUS_MPU[25] SND_PERIPH_DPLL_RECAL_ST | PRM_IRQENABLE_MPU[25] SND_PERIPH_DPLL_RECAL_EN | PRCM_MPU_IRQ | Yes                                      | DPLL5 recalibration event                                                                                                                                                       |
| PRM IRQSTATUS_MPU[26] ABB_LDO_TRANXDONE_ST     | PRM_IRQENABLE_MPU[26] ABB_LDO_TRANXDONE_EN     | PRCM_MPU_IRQ | No                                       | ABB LDO transaction completion status. This status is set when a software-initiated transaction is completed in ABB LDO (active mode transition only).                          |
| PRM IRQSTATUS_MPU[27] VC_VP1_ACK_ST            | PRM_IRQENABLE_MPU[27] VC_VP1_ACK_EN            | PRCM_MPU_IRQ | No                                       | Voltage controller's acknowledge to the VDD1 voltage processor status                                                                                                           |
| PRM IRQSTATUS_MPU[28] VC_BYPASS_ACK_ST         | PRM_IRQENABLE_MPU[28] VC_BYPASS_ACK_EN         | PRCM_MPU_IRQ | No                                       | Voltage controller's acknowledge to the bypass interface status                                                                                                                 |

---

**NOTE:** TRANXDONE and OPPCHANGEDONE interrupt events are generated under the same conditions (after voltage change).

---

**Table 3-79. IVA2 Interrupt Event Descriptions**

| Event Flag                            | Event Mask                                  | Map to       | IVA2 Domain Wake-Up Event | Description                                            |
|---------------------------------------|---------------------------------------------|--------------|---------------------------|--------------------------------------------------------|
| PRM IRQSTATUS_IVA2[0]<br>WKUP_ST      | PRM IRQENABLE_IVA2[0]<br>WKUP_EN            | PRCM_IVA_IRQ | No                        | IVA2 peripheral group wakeup                           |
| PRM IRQSTATUS_IVA2[1]<br>FORCEWKUP_ST | PRM IRQENABLE_IVA2[1]<br>FORCEWKUP_EN       | PRCM_IVA_IRQ | No                        | IVA2 power domain forced wake-up transition completion |
| PRM IRQSTATUS_IVA2[2]<br>IVA2_DPLL_ST | PRM IRQENABLE_IVA2[2]<br>IVA2_DPLL_RECAL_EN | PRCM_IVA_IRQ | Yes                       | DPLL2 recalibration required                           |

---

**NOTE:** The software must first read the event flag to determine the cause of the interrupt and then write 1 to it to clear the flag.

---

### 3.5.6 PRCM Voltage Management Functional Description

This section describes the voltage domains and voltage control architecture. It also explains the interactions between the device and the external power IC.

#### 3.5.6.1 Overview

Figure 3-78 is an overview of the device voltage domains.

**Figure 3-78. Overview of Device Voltage Domains**

prcm-073

The device is split into voltage domains:

- Three voltage domains for logic (VDD1, VDD2, and VDD3)
- Two voltage domains for memory (VDD4 and VDD5)
- Two voltage domains for PLLs and analog cells (VDDPLL and VDDPER)
- Voltage domain for the I/Os

This partition of the voltage domains ensures independent voltage control of each voltage domain through dedicated SMPS or LDO. Functionally, however, voltage control of a voltage domain may depend on the voltage level of another voltage domain; for example, VDD1 voltage-level control may depend on the VDD2 voltage level. [Figure 3-78](#) shows the voltage dependency between domains.

[Figure 3-79](#) is an overview of the device voltage sources and their controls. The PRM directly manages the following voltage sources:

- VDD1: Processor voltage
- VDD2: CORE voltage

- VDD3: Wake-up voltage
- VDD4: Processor SRAM voltage
- VDD5: CORE SRAM voltage

The remaining voltage sources (VDDS, VDDPLL, and MMC-VDDS) are either controlled directly by the external device or software-controlled through an I<sup>2</sup>C interface independent of the PRM. [Figure 3-79](#) is an overview of PRCM voltage control.

**Figure 3-79. Overview of Device Voltage Distribution**

**NOTE:** Memory I/Os (1.8 V) are not supplied with the other I/Os. They come directly from the power IC.

### 3.5.6.2 Voltage Domains

**Table 3-80** summarizes, for each voltage domain, the voltage level corresponding to its OPP when its power domains are on and the voltage level when its power domains are in retention or off power state. The exact values depend on the silicon.

**Table 3-80. Voltage Domain Controls Summary**

| Voltage Domain (Power Rail)               | Operating Point                     | Control   | Supplied Modules                                                                                       |
|-------------------------------------------|-------------------------------------|-----------|--------------------------------------------------------------------------------------------------------|
| VDD1 voltage domain (vdd_mpu_iva)         | Off                                 | HW and SW | MPU subsystem, IVA2.2 subsystem, digital part of DPLL1 and DPLL2, SmartReflex1                         |
|                                           | Retention                           |           |                                                                                                        |
|                                           | OPP50                               |           |                                                                                                        |
|                                           | OPP100                              |           |                                                                                                        |
|                                           | OPP130                              |           |                                                                                                        |
|                                           | OPP1G                               |           |                                                                                                        |
| VDD2 voltage domain (vdd_core)            | Off                                 | HW and SW | Most modules, interconnects, peripherals.<br><br>SmartReflex2, digital part of DPLL3, DPLL4, and DPLL5 |
|                                           | Retention                           |           |                                                                                                        |
|                                           | OPP50                               |           |                                                                                                        |
|                                           | OPP100                              |           |                                                                                                        |
| VDD3 voltage domain (vdda_wkup_bb)        | Low-power mode                      | HW        | WKUP and EMU domains                                                                                   |
|                                           | Normal mode                         |           |                                                                                                        |
|                                           | Emulation mode                      |           |                                                                                                        |
| VDD4 voltage domain (vdda_sram)           | All memories off                    | HW        | Processor memories                                                                                     |
|                                           | All memories in retention           |           |                                                                                                        |
|                                           | VDD1 is in OPP50, or OPP100         |           |                                                                                                        |
|                                           | VDD1 in OPP130                      |           |                                                                                                        |
| VDD5 voltage domain (vdda_sram)           | Off                                 | HW        | CORE, SGX, CAM, DSS, PER, USBHOST, and EMU memories                                                    |
|                                           | Retention                           |           |                                                                                                        |
|                                           | VDD2 is in OPP50, or OPP100         |           |                                                                                                        |
| VDDS voltage domain (vdds)                | Always-on                           | None      | I/Os                                                                                                   |
| VDDADAC voltage domain (vdda_dac)         | Software-driven only <sup>(1)</sup> | SW        | Video DAC                                                                                              |
| VDDPLL voltage domain (vdda_dpll_dll)     | Always-on <sup>(1)</sup>            | None      | Analog part of DPLL1, DPLL2, and DPLL3                                                                 |
| VDDPLL_PER voltage domain (vdda_dpll_per) | Always-on <sup>(1)</sup>            | None      | Analog part of DPLL4 and DPLL5                                                                         |
| External memory I/Os (vdds_mem)           | Always-on <sup>(1)</sup>            | None      | External memory, SDRC, and GPMC I/Os                                                                   |
| CSIPHY1 (vdda_csiphy1)                    | Always-on <sup>(1)</sup>            | None      | CAM balls                                                                                              |
| DSI (vdda_dsi)                            | Always-on <sup>(1)</sup>            | None      | DSI balls                                                                                              |
| CSIPHY2 (vdda_csiphy2)                    | Always-on <sup>(1)</sup>            | None      | CSI2 balls                                                                                             |
| SIM (vdds_sim)                            | Always-on <sup>(1)</sup>            | None      | SIM                                                                                                    |
| MMC_VDDS voltage domain (vdds_mmc1)       | Always-on <sup>(1)</sup>            | None      | MMC1                                                                                                   |

<sup>(1)</sup> Identifies voltage domains that can be switched to 0.0 V when the interface/module is not in use.

**NOTE:**

- Full device logic retention is also feasible by keeping all power domains on and lowering VDD1 and VDD2 to minimum OPP (CSWR). This consumes more power than the first option, but allows for a fast restart.
- When the user programs all memories in retention, VDD4 and VDD5 are automatically set to RETENTION voltage level by the PRM, which allows the memory arrays to be retained.

**3.5.6.3 Voltage Domain Dependencies**

**Table 3-81** and **Table 3-82** summarize the hardware conditions and the software setting required to switch the VDD1 and VDD2 to their respective low-power states.

**Table 3-81. VDD1 Voltage Domain Dependencies**

| VDD1 Domain State | Power Domains State                                                                                                          | DPLL State                        | sys_clk            | Software Control                               | VDD2            | VDD3             | VDD4            | VDD5            |
|-------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--------------------|------------------------------------------------|-----------------|------------------|-----------------|-----------------|
| SLEEP             | Software controlled power domains of VDD1 are in inactive, retention, or off state.                                          | DPLL1 and DPLL2 are in Stop mode. | N/A                | AUTO_SLEEP = 1<br>AUTO_RET = 0<br>AUTO_OFF = 0 | ON or SLEEP     | ON or Overdriven | ON or retention | ON or retention |
| Retention         | Software controlled power domains of VDD1 are in retention or off state and of VDD2 are in INACTIVE, retention or off state. | DPLL1 and DPLL2 are in Stop mode. | N/A                | AUTO_SLEEP = 0<br>AUTO_RET = 1<br>AUTO_OFF = 0 | ON or retention | ON or Overdriven | Retention       | ON or retention |
| Off               | Software controllable power domains of VDD1 and VDD2 are in off state.                                                       | All DLLs are in Stop mode.        | No longer required | AUTO_SLEEP = 0<br>AUTO_RET = 0<br>AUTO_OFF = 1 | Off             | SLEEP            | Off             | Off             |

**NOTE:** It is mandatory to program the three bit fields AUTO\_SLEEP, AUTO\_RET, and AUTO\_OFF in an exclusive manner.

**Table 3-82. VDD2 Voltage Domain Dependencies**

| VDD2 Domain State | Power Domains State                                                                         | DPLL State                 | sys_clk            | Software Control                               | VDD1  | VDD3             | VDD4            | VDD5            |
|-------------------|---------------------------------------------------------------------------------------------|----------------------------|--------------------|------------------------------------------------|-------|------------------|-----------------|-----------------|
| SLEEP             | Software controlled power domains of VDD1 and VDD2 are in inactive, retention or off state. | All DLLs are in Stop mode. | No longer required | AUTO_SLEEP = 1<br>AUTO_RET = 0<br>AUTO_OFF = 0 | SLEEP | ON or Overdriven | ON or retention | ON or retention |

**Table 3-82. VDD2 Voltage Domain Dependencies (continued)**

| VDD2 Domain State | Power Domains State                                                                                                          | DPLL State                  | sys_clk            | Software Control                                | VDD1            | VDD3             | VDD4            | VDD5      |
|-------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--------------------|-------------------------------------------------|-----------------|------------------|-----------------|-----------|
| Retention         | Software controlled power domains of VDD1 are in inactive, retention or off state and of VDD2 are in retention or off state. | All DPLLs are in Stop mode. | No longer required | AUTO_SLEE P = 0<br>AUTO_RET = 1<br>AUTO_OFF = 0 | ON or retention | ON or Overdriven | ON or retention | Retention |
| Off               | Software controllable power domains of VDD1 and VDD2 are in off state.                                                       | All DPLLs are in Stop mode. | No longer required | AUTO_SLEE P = 0<br>AUTO_RET = 0<br>AUTO_OFF = 1 | Off             | SLEEP            | Off             | Off       |

**NOTE:**

- In voltage domain SLEEP state, the current load decreases because of reduced activity level; however, the voltage level remains that of on state.
- In voltage domain overdriven state, the domain voltage is raised above the nominal operating voltage to boost performance; however, power consumption also increases.
- AUTO\_SLEEP, AUTO\_RET and AUTO\_OFF, in the Software Control column, refer to the [PRM\\_VOLTCTRL\[0\]](#) AUTO\_SLEEP, [PRM\\_VOLTCTRL\[1\]](#) AUTO\_RET and [PRM\\_VOLTCTRL\[2\]](#) AUTO\_OFF bits.

**Table 3-83. Remaining Voltage Domain Dependencies**

| Voltage              | Condition                                |
|----------------------|------------------------------------------|
| VDDS                 |                                          |
| External memory I/Os |                                          |
| VDDADAC              |                                          |
| VDDPLL               |                                          |
| VDDPLL_PER           |                                          |
| CSIB                 |                                          |
| DSI                  |                                          |
| CSIPHY2              |                                          |
| SIM                  |                                          |
| MMC_VDDS             | No dependency with other device voltages |

### 3.5.6.4 Voltage-Control Architecture

The PRM is split over several blocks that manage the different voltage sources.

- VDD1 and VDD2 voltages are managed by multiple control sources:
  - Automatic voltage adjustment (for optimal performance at an OPP) and software-requested voltage scaling (for OPP change) are managed by two SmartReflex voltage control modules connected to two voltage processor modules. They generate voltage-adjustment commands based on the desired and current performance levels of the device. These commands are sent to the external power IC through a voltage controller and a dedicated I<sup>2</sup>C interface.
  - Direct software control of VDD1 and VDD2 is also possible by writing to the registers of the voltage

controller, which then sends the voltage commands to the power IC through the dedicated I<sup>2</sup>C interface.

- Two voltage finite state-machines (FSM 1 and FSM 2) can also manage the VDD1 and VDD2 voltages either by sending commands to the voltage controller (I<sup>2</sup>C mode) or by sending the sys\_nvmode1 and sys\_nvmode2 control signals (direct-control mode). The FSMS control voltage-level switching, based on the power state of the device.
- The FSMS in the PRM also control SRAM and wake-up LDOs, sleep mode for analog cells, and level shifters.
- A device FSM sequences the memory, wakeup, voltage, and I/O FSMS during the device off, sleep, and wake-up transitions.

**NOTE:** The SmartReflex module allows dynamic voltage adjustments around an OPP voltage level to ensure target performance. It also allows switching from one OPP to another. However, it does not control voltage switching to retention or off as the power domains or the device change power states. This is handled by the voltage FSMS.

Figure 3-80 shows the architecture for PRM voltage control.

**Figure 3-80. PRM Voltage Control Architecture**



\* The green region in the figure represents the boundary of the PRM.

prcm-075

**CAUTION**

It is highly recommended to use the embedded dedicated I<sup>2</sup>C4 instead of VMODE, which is a legacy mode. The I<sup>2</sup>C4 provides greater flexibility and higher efficiency in terms of power optimization.

**3.5.6.5 VDD1 and VDD2 Control**

The main power-supply sources, VDD1 and VDD2, can be controlled using mutually exclusive modes specified in the SCM:

- Direct control with VMODE signals or I<sup>2</sup>C interface
- Dedicated SmartReflex I<sup>2</sup>C control

Because both control modes are multiplexed on the same device pins, direct control signals can be used alternately with I<sup>2</sup>C control signals. The muxes are managed by the SCM.

**3.5.6.5.1 Direct Control With VMODE Signals**

In direct-control mode, the VDD1 and VDD2 voltage sources can be controlled by the voltage FSMs in the PRM to trigger a voltage transition based on the power domain states. The voltage FSMs use a VMODE interface to send voltage commands through the sys\_nvmode1 and sys\_nvmode2 pins of the device to the external power IC. The simple voltage-control commands of the VMODE interface can be used to set two voltage values (VDD1 and VDD2) per voltage domain.

The sys\_nvmode[1,2] signals request new voltage levels to the external SMPS. The polarity of the sys\_nvmode[1,2] signals from the PRM is configured by the PRCM.PRM\_POLCTRL[0] EXTVOOL\_POL bit, which is active-low by default. When the signal goes low, a lower voltage is supplied, and when it goes high, a higher voltage is supplied.

The VMODE voltage control is enabled by setting the PRM.PRM\_VOLTCTRL[4] SEL\_VMODE bit, and is triggered when the device switches between low-power (retention or off) mode and normal (on) mode.

**Figure 3-81** is an example of a VDD2 voltage transition from an operational voltage (OPP100) to the lowest functional voltage of the device (LOW). In this example, the PRCM module is programmed to automatically lower sys\_nvmode2 when the device enters sleep mode. The power IC is programmed to ramp the VDD2 voltage down to LOW when sys\_nvmode2 is deasserted and to ramp up the voltage to OPP100 when sys\_nvmode2 is asserted. The PRCM module must also wait for the VDD2 regulator to stabilize when sys\_nvmode2 is deasserted and asserted. This stabilization time is programmable by software using the PRCM.PRM\_VOLTSETUP1 register.

**Figure 3-81. Voltage Transition Controlled by sys\_nvmode2**



prcm-076

Internally, the PRM manipulates two logical voltage levels (L0 and L1) for each sys\_nvmode[1,2] signal. One level is set when all the power domains in the voltage domain are in retention or off mode, while the other is set when a power domain is on. The power IC must be configured to switch to low voltage when the associated sys\_nvmode[1,2] signal is received, and vice versa.

For example, if L0 is the lower voltage and an active-low polarity (default setting) on the sys\_nvmode[1,2] signal:

- L0 logical level sys\_nvmode[1,2] = 1 VDD = OPP100
- L1 logical level sys\_nvmode[1,2] = 0 VDD = LOW

The polarity of the logical voltage-level signal from the PRM can be controlled by the PRCM.PRM\_POLCTRL[0] EXT VOL POL bit. It is active-low by default (L0 = 1, L1 = 0).

### 3.5.6.5.2 Direct Voltage Control With I<sup>2</sup>C Interface

PRM can send VDD1 and VDD2 sleep commands to the power IC through the dedicated I<sup>2</sup>C. This allows the power IC to activate sleep mode (the voltage regulator switches in sleep mode, where voltage is maintained but only small load is supported). This also allows external power IC to reduce its power consumption.

### 3.5.6.5.3 Voltage Controller and Dedicated SmartReflex I<sup>2</sup>C Interface

The dedicated I<sup>2</sup>C voltage control mode is dedicated to SmartReflex technology. The central modules for the I<sup>2</sup>C control mode are the voltage controller and the I<sup>2</sup>C interface. The voltage controller receives voltage control commands from five input ports:

- Voltage processor 1 and 2 ports: The voltage processors send commands to the voltage controller depending on the SmartReflex module calculations (during device activity).
- Voltage FSM 1 and 2 ports: The voltage FSMs send commands to the voltage controller when the device enters retention or off power state, and also when the device wakes up.
- PRM register port: The PRM registers give direct software control over the voltage levels of the VDD1 and VDD2 voltage domains.

An arbitration scheme in the voltage controller manages concurrent requests on multiple ports.

Externally, the voltage controller interfaces to a power IC through a dedicated I<sup>2</sup>C interface (I<sup>2</sup>C4). To reduce the latency of voltage changes, the voltage controller is configurable to run in HS I<sup>2</sup>C mode.

Each internal port has a handshake to indicate when the I<sup>2</sup>C frame that results from the request on that port is acknowledged by the external power IC.

### 3.5.6.5.4 SmartReflex Voltage Control

As explained previously (see [Section 3.1.2.2, SmartReflex Adaptive Voltage Scaling](#)), SmartReflex technology uses adaptive power control to reduce active power consumption by the device. SmartReflex voltage control in the device is based on the dedicated SmartReflex modules and the voltage processors, in addition to the voltage controller and I<sup>2</sup>C interface, which are shared with the voltage FSMs and voltage control registers.

The SmartReflex modules allow a continuous real-time voltage supply and device performance monitoring to do the following:

- Minimize the supply voltage to reduce the device power consumption.
- Maintain the desired device performance (by dynamically adjusting the device voltage) as the temperature of the device varies.

Within the device, the SmartReflex modules can be used to stabilize performance at a given OPP or for the DVFS (that is, switching from one OPP to another).

Because the SmartReflex modules and the voltage processors are dedicated to SmartReflex voltage control, they are described together in this section.

#### 3.5.6.5.4.1 SmartReflex in the Device

[Figure 3-82](#) shows the SmartReflex integration.

**Figure 3-82. SmartReflex Integration**


prcm-UC-002

SmartReflex voltage control in the device is implemented for simultaneous control of two independent voltage sources. One SmartReflex module controls the VDD1 voltage, while the second one is dedicated to VDD2 control. Each SmartReflex module is connected to a voltage processor. Voltage commands from both voltage processors are passed to a voltage control, which sends them through a dedicated I<sup>2</sup>C master interface to the power IC.

#### **3.5.6.5.4.2 SmartReflex Module**

Figure 3-83 is a functional overview of the SmartReflex module.

Figure 3-83. SmartReflex Module Functional Overview



### 3.5.6.5.4.3 SmartReflex Submodules

The SmartReflex module is enabled by setting the SRn<sup>(1)</sup>. The SRn.SRCONFIG[11] SR\_EN bit is composed of six blocks:

- Clock generator
- Sensor core
- Accumulator
- Minimum/maximum/average
- Error generator
- Interrupt generator

#### Clock Generator

The clock generator provides the internal SR\_CLK sampling clock to the sensor core of the module. The SRn.SRCONFIG[21:12] SRCLKLENGTH bit field allows the setting of the frequency divider ratio between the SR\_ALWON\_FCLK and the SR\_CLK. It is calculated using Equation 1:

$$\text{SRn.SRCONFIG[21:12] SRCLKLENGTH} = f_{\text{SR\_ALWON\_FCLK}} / (2 * f_{\text{SR\_CLK}}) \quad (1)$$

Where  $f_{\text{SR\_ALWON\_FCLK}}$  is the frequency of the SR\_ALWON\_FCLK and  $f_{\text{SR\_CLK}}$  is the desired SR\_CLK frequency.

To accurately use the target values programmed for SmartReflex modules in the device, the SRCLKLENGTH parameter must be set correctly. The target values for the SmartReflex modules are calculated with the SR\_CLK frequency set at 100 kHz. It is thus mandatory that the value of the SRCLKLENGTH parameter is calculated from Equation 4-1 with  $f_{\text{SR\_CLK}}$  set at 100 kHz.

For example, if the system clock has a frequency of 38.4 MHz, and the target SR\_CLK frequency is 100 kHz, the SRn.SRCONFIG[21:12] SRCLKLENGTH is 192 (0x0C0).

#### Sensor Core

<sup>(1)</sup> SR1 and SR2 instances of the SmartReflex module in the device; n varies from 1 to 2.

The sensor core receives the SR\_CLK sampling clock and the voltage to be sensed. It generates sensor value samples proportional to the voltage sensed. For accuracy, a sensor core is composed of two sensors and generates two values per sample (one from each sensor).

The two sample values generated by the sensor core output can be read from the SRn.[SENV\[15:0\]](#) SENVAL bit field and the SRn.[SENV\[31:16\]](#) SENPVAL bit field.

The sensor core is enabled by the SRn.[SRCONFIG\[10\]](#) SENENABLE bit.

### Accumulator

The accumulator consists of two stacks that store multiple samples of the two sensor values received from the sensor core.

The SRn.[SRCONFIG\[31:22\]](#) ACCUMDATA bit field defines the size of the accumulator in the number of samples to be stored. The allowable range is from 2 to 1023. The SRn.[SRCONFIG\[31:22\]](#) ACCUMDATA value is related to the desired sampling time window ( $T_{TimeWindow}$ ) and the SR\_CLK frequency ( $f_{SR\_CLK}$ ). It can be calculated using [Equation 2](#):

$$SRn.SRCONFIG[31:22] \text{ ACCUMDATA} = T_{TimeWindow} * f_{SR\_CLK} \quad (2)$$

For example, for an accumulator time window of 10 ms and SR\_CLK frequency of 32 kHz, the SRn.[SRCONFIG\[31:22\]](#) ACCUMDATA value is 320 (0x140). The accumulation window must be large enough so that the minimum, maximum, and average counter values are accurate.

### Minimum/Maximum/Average

The minimum/maximum/average block reads the samples stored in the accumulator and returns the minimum, maximum, and average values of the samples. Because the accumulator contains two separate groups of samples (one from each sensor of the sensor core), the minimum/maximum/average block also generates two sets of minimum, maximum, and average values.

The minimum, maximum, and average values of the samples of the first sensor can be read from the SRn.[SENNMIN\[15:0\]](#) SENNMIN, SRn.[SENNMAX\[15:0\]](#) SENNMAX, and SRn.[SENAVG\[15:0\]](#) SENNAVG bit fields.

For the sample values of the second sensor, the minimum, maximum, and average values can be read from the SRn.[SENNMIN\[31:16\]](#) SENPMIN, SRn.[SENNMAX\[31:16\]](#) SENPMAX, and SRn.[SENAVG\[31:16\]](#) SENPAVG bit fields.

The minimum/maximum/average block is enabled by the SRn.[SRCONFIG\[8\]](#) MINMAXAVGENABLE bit.

### Error Generator

The error-generator block reads the sample value generated by the sensor core and compares it with a reference value to calculate the error. This error is then passed to the voltage processor and the internal interrupt generator block.

The reference value for a given OPP of the device is configured by setting the SRn.[NVALUERECIPROCAL\[23:20\]](#) SENPGAIN, SRn.[NVALUERECIPROCAL\[19:16\]](#) SENNGAIN, SRn.[NVALUERECIPROCAL\[15:8\]](#) RNSENP, and SRn.[NVALUERECIPROCAL\[7:0\]](#) RNSENN bit fields by reading corresponding values from the eFuses (see [Section 3.5.6.5.4.5, eFuse Values](#)).

The error generator sets the SRn.[SRSTATUS\[1\]](#) ERRGEN\_VALID status bit when a valid error value is set in the SRn.[SENERROR\\_REG](#) register.

The SRn.[SENERROR\\_REG](#) register contains the average error (SRn.[SENERROR\\_REG\[15:8\]](#) AVGERROR) and the percentage of error (SRn.[SENERROR\\_REG\[7:0\]](#) SENERROR).

The error generator block is enabled by the SRn.[SRCONFIG\[9\]](#) ERRORGENERATORENABLE bit.

### Interrupt Generator

The interrupt generator block generates interrupts to the MPU INTC and the voltage processor module (if the corresponding interrupts are enabled) to indicate errors.

[Table 3-84](#) and [Table 3-85](#) list the interrupt sources in the SmartReflex module and their enable and status bits.

**Table 3-84. SmartReflex Interrupts**

| Interrupt Type      | Destination       | Description                                                                                                                                                                                                     |
|---------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Accumulator         | MPU INTC          | The minimum/maximum/average module has completed computation over the accumulator data.                                                                                                                         |
| Valid               | MPU INTC          | The average error is less than 2 percent of the true average error.                                                                                                                                             |
| Disable acknowledge | MPU INTC          | The SmartReflex module is disabled and has cleared all MCU and VP interrupts (internal registers are reset). This interrupt indicates to the software that the SmartReflex module is available for programming. |
| Bounds              | MPU INTC          | The frequency error has crossed the maximum limit (ERRMAXLIMIT) or the minimum limit (ERRMINLIMIT).                                                                                                             |
|                     | Voltage processor |                                                                                                                                                                                                                 |

The interrupt mappings to the MPU INTC are:

- SR1\_IRQ from the SmartReflex1 module to the M\_IRQ\_18 interrupt line of the MPU INTC
- SR2\_IRQ from the SmartReflex2 module to the M\_IRQ\_19 interrupt line of the MPU INTC

**Table 3-85. SmartReflex Interrupt Enable and Status Bits**

| Interrupt Type      | Enable Bit                                     | Status Bit                               |
|---------------------|------------------------------------------------|------------------------------------------|
| Accumulator         | SRn.IRQENABLE_SET[3]<br>MCUACCUMINTENASET      | SRn.IRQSTATUS[3]<br>MCUACCUMINTSTATENA   |
| Valid               | SRn.IRQENABLE_SET[2]<br>MCUVALIDINTENASET      | SRn.IRQSTATUS[2]<br>MCUVALIDINTSTATENA   |
| Disable acknowledge | SRn.IRQENABLE_SET[0]<br>MCUDISABLEACTINTENASET | SRn.IRQSTATUS[0]<br>MCUDISABLEACKINTSTAT |
| Bounds              | SRn.IRQENABLE_SET[1]<br>MCUBOUNDSINTSTATENA    | SRn.IRQSTATUS[1]<br>MCUBOUNDSINTENASET   |
|                     | SRn.ERRCONFIG[22]<br>VPBOUNDSINTENABLE         | SRn.ERRCONFIG[23]<br>VPBOUNDSINTSTATENA  |

The minimum and maximum error limits for the bounds interrupt are configured in the SRn.ERRCONFIG[15:8] ERRMAXLIMIT and SRn.ERRCONFIG[7:0] ERMINLIMIT bit fields.

With automatic (hardware) voltage control, the voltage processor interrupt (iSRn.ERRCONFIG[22] VPBOUNDSINTENABLE) is enabled and the SmartReflex module interrupts the voltage processor module when the error crosses the error limits. In this case, the MPU interrupts can also be enabled to allow the software to monitor the SmartReflex module behavior.

With manual (software) voltage control, the voltage processor interrupt remains disabled and only the MPU interrupts are enabled. Thus, when an interrupt condition occurs, the MPU is interrupted and the software can then control the voltage by generating voltage commands.

Writing 1 to a bit in the **IRQSTATUS** register clears the interrupt pending status of each interrupt source whose corresponding bit is 1 in the value written. Other interrupt pending status bits are not affected (writing 0 to that bit does not affect the status).

#### 3.5.6.5.4.4 Status Register

The status register (**SRSTATUS**) indicates the validity of the minimum/maximum/average and error-generator output values.

**SRSTATUS** has the following bits and bit fields:

- SRn.SRSTATUS[3] AVGERRVALID: Indicates the validity of the value in the SRn.SENERROR\_REG[15:8] AVGERROR bit field. When the value is 0, the average error is not valid. When the value is 1, the average error is within 2 percent of the valid average error.
- SRn.SRSTATUS[2] MINMAXAVGVALID: Indicates the validity of the SRn.SENVAL, SRn.SENMIN, SRn.SENMAX, and SRn.SENAVG registers. When the value is 0, the registers are not valid. When the value is 1, the registers contain valid values, although the values are not necessarily fully accumulated.

- SRn.**SRSTATUS[1]** ERRGEN\_VALID: Indicates the validity of the value in the SRn.**SENERROR\_REG[7:0]** SENERROR bit field. When the value is 0, the error value is invalid. When the value is 1, the error value is valid.
- SRn.**SRSTATUS[0]** MINMAXAVGACCUMVALID: Indicates that the SRn.**SENVAL**, SRn.**SENMIN**, SRn.**SENMAX**, and SRn.**SENAVG** registers contain their final values accumulated over the defined sample time period.

### 3.5.6.5.4.5 SmartReflex Parameters Set After Silicon Characterization

Certain parameters of the SmartReflex module are characterized and calibrated after silicon testing. These values are then either set in the eFuse farm of the device or provided in a separately. The user must configure these parameters according to their given values to ensure correct functioning of the module.

The values for the following parameters (explained in [Section 3.5.6.5.4.3](#)) are set in the device eFuse after device silicon characterization:

- SRn.**SRCONFIG[1]** SENNENABLE
- SRn.**SRCONFIG[4:3]** SENPENABLE
- SRn.**NVALUERECIPROCAL[23:20]** SENPGAIN
- SRn.**NVALUERECIPROCAL[19:16]** SENNGAIN
- SRn.**NVALUERECIPROCAL[15:8]** RNSENP
- SRn.**NVALUERECIPROCAL[7:0]** RNSENN

The eFuse values of these parameters can be read from the corresponding registers of the SCM. The SCM registers associated with the parameters SENPGAIN, SENNGAIN, RNSENP, and RNSENN of the SR1 module are:

- CONTROL.CONTROL\_FUSE OPP50\_VDD1
- CONTROL.CONTROL\_FUSE OPP100\_VDD1
- CONTROL.CONTROL\_FUSE OPP130\_VDD1
- CONTROL.CONTROL\_FUSE OPP1G\_VDD1

The SCM registers associated with the parameters SENPGAIN, SENNGAIN, RNSENP, and RNSENN of the SR2 module are:

- CONTROL.CONTROL\_FUSE OPP50\_VDD2
- CONTROL.CONTROL\_FUSE OPP100\_VDD2

The SCM register associated with the parameters SENNENABLE and SENPENABLE of the SR1 and SR2 module is:

- CONTROL.CONTROL\_FUSE\_SR

Information about the following parameters of the SmartReflex module is provided after silicon characterization :

- SRn.**AVGWEIGHT[3:2]** SENP**AVGWEIGHT**
- SRn.**AVGWEIGHT[1:0]** SENN**AVGWEIGHT**
- SRn.**ERRCONFIG[18:16]** ERRWEIGHT
- SRn.**ERRCONFIG[15:8]** ERRMAXLIMIT
- SRn.**ERRCONFIG[7:0]** ERRMINLIMIT

### 3.5.6.5.4.6 Voltage Processor Module

[Figure 3-84](#) is a functional overview of the voltage processor.

**Figure 3-84. Voltage Processor Functional Overview**

prcm-UC-004

The voltage processor receives an error value and a VP interrupt signal from the SmartReflex module. Each time a new error value is sent, the SmartReflex module triggers an interrupt to inform the voltage processor. The voltage processor consists of an error-to-voltage command converter and a state controller. It processes an error and sends a voltage command to the voltage controller. It receives an acknowledge signal from the voltage controller when the SMPS receives the command. The voltage processor in turn acknowledges the SmartReflex module by clearing its interrupt.

The voltage processor is enabled by the PRCM.PRM\_VPn\_CONFIG[0] VPENABLE bit.

#### Voltage-Processor Interrupts

The voltage processor uses the PRCM\_MPU\_IRQ (M\_IRQ\_11) interrupt line of the MPU INTC to interrupt the MPU. [Table 3-86](#) and [Table 3-87](#) list the interrupt sources in the voltage processor module and their enable and status bits.

**Table 3-86. Voltage Processor Interrupts**

| Interrupt Type      | Destination | Description                                                                           |
|---------------------|-------------|---------------------------------------------------------------------------------------|
| Transaction done    | MPU INTC    | Voltage processor transaction is complete.                                            |
| Equal value         | MPU INTC    | Voltage requested in the new voltage command is the same as the current SMPS voltage. |
| No SMPS acknowledge | MPU INTC    | SMPS has not responded in a defined time interval to the transmitted voltage command. |
| Maximum VDD         | MPU INTC    | New voltage requested in the voltage command is equal to or greater than maximum VDD. |
| Minimum VDD         | MPU INTC    | New voltage requested in the voltage command is equal to or less than minimum VDD.    |

**Table 3-86. Voltage Processor Interrupts (continued)**

| Interrupt Type  | Destination | Description                                    |
|-----------------|-------------|------------------------------------------------|
| OPP change done | MPU INTC    | The average error is within the desired limit. |

**Table 3-87. Voltage Processor Interrupt Enable and Status Bits**

| Interrupt Type      | Enable Bit                                         | Status Bit                                         |
|---------------------|----------------------------------------------------|----------------------------------------------------|
| Transaction done    | PRCM.PRM_IRQENABLE_MPU[21]<br>VP2_TRANXDONE_EN     | PRCM.PRM_IRQSTATUS_MPU[21]<br>VP2_TRANXDONE_ST     |
|                     | PRCM.PRM_IRQENABLE_MPU[15]<br>VP1_TRANXDONE_EN     | PRCM.PRM_IRQSTATUS_MPU[15]<br>VP1_TRANXDONE_ST     |
| Equal value         | PRCM.PRM_IRQENABLE_MPU[20]<br>VP2_EQVALUE_EN       | PRCM.PRM_IRQSTATUS_MPU[20]<br>VP2_EQVALUE_ST       |
|                     | PRCM.PRM_IRQENABLE_MPU[14]<br>VP1_EQVALUE_EN       | PRCM.PRM_IRQSTATUS_MPU[14]<br>VP1_EQVALUE_ST       |
| No SMPS acknowledge | PRCM.PRM_IRQENABLE_MPU[19]<br>VP2_NOSMPSACK_EN     | PRCM.PRM_IRQSTATUS_MPU[19]<br>VP2_NOSMPSACK_ST     |
|                     | PRCM.PRM_IRQENABLE_MPU[13]<br>VP1_NOSMPSACK_EN     | PRCM.PRM_IRQSTATUS_MPU[13]<br>VP1_NOSMPSACK_ST     |
| Maximum VDD         | PRCM.PRM_IRQENABLE_MPU[18]<br>VP2_MAXVDD_EN        | PRCM.PRM_IRQSTATUS_MPU[18]<br>VP2_MAXVDD_ST        |
|                     | PRCM.PRM_IRQENABLE_MPU[12]<br>VP1_MAXVDD_EN        | PRCM.PRM_IRQSTATUS_MPU[12]<br>VP1_MAXVDD_ST        |
| Minimum VDD         | PRCM.PRM_IRQENABLE_MPU[17]<br>VP2_MINVDD_EN        | PRCM.PRM_IRQSTATUS_MPU[17]<br>VP2_MINVDD_ST        |
|                     | PRCM.PRM_IRQENABLE_MPU[11]<br>VP1_MINVDD_EN        | PRCM.PRM_IRQSTATUS_MPU[11]<br>VP1_MINVDD_ST        |
| OPP change done     | PRCM.PRM_IRQENABLE_MPU[16]<br>VP2_OPPCHANGEDONE_EN | PRCM.PRM_IRQSTATUS_MPU[16]<br>VP2_OPPCHANGEDONE_ST |
|                     | PRCM.PRM_IRQENABLE_MPU[10]<br>VP1_OPPCHANGEDONE_EN | PRCM.PRM_IRQSTATUS_MPU[10]<br>VP1_OPPCHANGEDONE_ST |

### Voltage-Processor Status

The status of the voltage processor is represented by the following:

|                                        |                          |                                                                       |
|----------------------------------------|--------------------------|-----------------------------------------------------------------------|
| PRCM.PRM_VPn_VOLTAGE[7:0]<br>VPVOLTAGE | Current voltage for SMPS | Value of the current voltage level requested by the voltage processor |
| PRCM.PRM_VPn_STATUS[0] VPINIDLE        | VP in inactive state     | The voltage processor is in idle mode.                                |

### Voltage-Processor Parameters

The following parameters of the voltage processor must be configured:

| Bit/Bit Field                          | Parameter           | Description                                                        |
|----------------------------------------|---------------------|--------------------------------------------------------------------|
| PRCM.PRM_VPn_CONFIG[31:24] ERROROFFSET | Error offset        | Error in voltage offset value                                      |
| PRCM.PRM_VPn_CONFIG[23:16] ERRORGAIN   | Error gain          | Error in voltage gain value                                        |
| PRCM.PRM_VPn_CONFIG[3] TIMEOUTEN       | Time-out enable     | Enables/disables the time-out set by the time-out delay parameter  |
| PRCM.PRM_VPn_VSTEPMIN[7:0] VSTEPMIN    | Minimum step size   | Minimum voltage step size                                          |
| PRCM.PRM_VPn_VSTEPMAX[7:0] VSTEPMAX    | Maximum step size   | Maximum voltage step size                                          |
| PRCM.PRM_VPn_VLIMITTO[31:24] VDDMAX    | Maximum VDD limit   | Maximum voltage limit of the VDD                                   |
| PRCM.PRM_VPn_VLIMITTO[23:16] VDDMIN    | Minimum VDD limit   | Minimum voltage limit of the VDD                                   |
| PRCM.PRM_VPn_VLIMITTO[15:0] TIMEOUT    | Time-out delay      | Maximum delay between a voltage change command and its acknowledge |
| PRCM.PRM_VPn_CONFIG[15:8] INITVDD      | Initial VDD voltage | Initial voltage set in the voltage processor                       |

| Bit/Bit Field                                  | Parameter              | Description                                                                            |
|------------------------------------------------|------------------------|----------------------------------------------------------------------------------------|
| PRCM.PRM_VPn_CONFIG[2] INITVDD                 | Initialize VDD         | Set initial voltage given in initial VDD voltage parameter in the voltage processor    |
| PRCM.PRM_VPn_VSTEPMIN[23:8]<br>SMPSWAITTIMEMIN | Minimum SMPS wait time | Slew rate for negative voltage steps                                                   |
| PRCM.PRM_VPn_VSTEPMAX[28:8]<br>SMPSWAITTIMEMAX | Maximum SMPS wait time | Slew rate for positive voltage steps                                                   |
| PRCM.PRM_VPn_CONFIG[1] FORCEUPDATE             | Force update           | Sends the value of the VP current voltage parameter as the new voltage command to SMPS |

### 3.5.6.5.4.7 SMPS Parameter Configuration

The values of the following parameters depend on the characteristics of the SMPS used:

- PRCM.PRM\_VPn\_CONFIG[31:24] ERROROFFSET
- PRCM.PRM\_VPn\_CONFIG[231:16] ERRORGAIN
- PRCM.PRM\_VPn\_VSTEPMIN[7:0] VSTEPMIN
- PRCM.PRM\_VPn\_VSTEPMAX[7:0] VSTEPMAX
- PRCM.PRM\_VPn\_VLIMITTO[31:24] VDDMAX
- PRCM.PRM\_VPn\_VLIMITTO[23:16] VDDMIN
- PRCM.PRM\_VPn\_VLIMITTO[15:0] TIMEOUT
- PRCM.PRM\_VPn\_VSTEPMIN[23:8] SMPSWAITTIMEMIN
- PRCM.PRM\_VPn\_VSTEPMAX[28:8] SMPSWAITTIMEMAX

For information about the values of these parameters, see the specification document of the SMPS used.

### 3.5.6.5.4.8 Communication Between SmartReflex, Voltage Processor, Voltage Controller, and SMPS

The SmartReflex module, voltage processor, voltage controller, and SMPS implement a simple handshake protocol based on a request/acknowledge mechanism (see [Figure 3-85](#)):

1. The SmartReflex module generates a VP interrupt (clears to 0) when the average error crosses the minimum or maximum error bounds.
2. The average VDDx error is passed to the voltage processor when automatic voltage control is enabled.
3. The voltage processor reads the error and generates the voltage command for the SMPS. It then informs the voltage controller that a new voltage command is ready for the SMPS. The voltage controller sends the voltage command to the SMPS (external power IC) through the dedicated I<sup>2</sup>C interface.
4. The SMPS responds to the reception of the voltage command with an acknowledgment to the voltage controller, which in turn sends the acknowledgment to the voltage processor.
5. On reception of the voltage command by the SMPS, the voltage processor sends the interrupt-clear signal to the SmartReflex module. The SmartReflex module then clears the VP interrupt. The SmartReflex module is again ready to send a new frequency-error interrupt to the voltage processor.

**Figure 3-85. SmartReflex - SMPS Communication for Automatic Voltage Adjustments**



prcm-UC-005

### 3.5.6.6 Analog Cells, LDOs, and Level Shifter Controls

In addition to the VDD1 and VDD2 voltage controls, the PRM handles the following operations automatically, based on hardware conditions, without any software control:

- Reduces SRAM LDOs voltage when all memories are in retention
- Reduces wake-up LDO voltage when the device enters off mode (wake-up leakage reduction)
- Increases wake-up LDO voltage when emulation trace is active
- Actively isolates level shifters during VDD1 and VDD2 removal
- Activates sleep mode in all analog cells when the device enters off mode

#### 3.5.6.6.1 ABB LDOs Control

ABB LDO supports two voltage modes:

- **BYPASS mode:** In this mode the x\_ABB LDO is bypassed and outputs the VDD\_x\_L voltages (x refers to MPU and IVA). This mode is activated when FBB is not required, or when voltage domain enters low-power mode.
- **FBB mode:** is enabled when the device is at highest OPP (OPP1G).

The PRCM provides the [PRM\\_LDO\\_ABB\\_CTRL](#) register for configuration with the following controls:

- SR2EN - To enable or bypass the ABB power management
- ACTIVE\_FBB\_SEL - To enable or bypass FBB mode
- SR2\_WTCNT\_VALUE - LDO settling delay on OPP change. The delay is in number of system clock cycles.

The PRCM provides [PRM\\_LDO\\_ABB\\_SETUP](#) register for control:

- OPP\_SEL - Current operational OPP
- OPP\_CHANGE - Initiate an OPP based ABB LDO setting change
- SR2\_STATUS - Current mode of operation of ABB LDO
- SR2\_IN\_TRANSITION - ABB LDO is in transition.

### 3.5.6.6.2 SRAM Voltage Control

The two embedded SRAM LDOs supply regulated voltage (VDD4 or VDD5) to memory banks. The processor memory LDO (VDD4) has three reference voltages, while the CORE memory LDO (VDD5) supports two:

- 1.2 V is the normal voltage reference, used for processors OPP50 and OPP100.
- Tracking between 1.2 V and 1.35 V: The processor SRAM LDO (VDD4) tracks and follows VDD1 voltage when it exceeds OPP100 (1.2 V) nominal voltage. VDD1 (up to 1.35 V) is the overdrive voltage reference when processors operate at OPP1G.
- 1.05 V is set when all memory banks belonging to the LDO are in retention state.

When not used (all memories are off), the LDO is in sleep mode. These modes are managed automatically by hardware (PRM).

### 3.5.6.6.3 Wake-Up and Emulation Voltage Control

The embedded wake-up LDO (VDD3) supplies both WKUP and EMU power domains. It is permanently active and feeds the WKUP power domain continuously. An embedded switch allows the PRM to control power to the EMU power domain. This switch is closed on a software request command when a debug session starts, or automatically on JTAG® plug detection.

This LDO has three reference voltages:

- 1.05 V is the normal voltage reference, used in device active mode.
- 1.15 V is the overdrive voltage reference used when emulation is activated and MPU emulation trace is required.
- 0.82 V is set when the device is in low-power (off) mode, to minimize leakage.

These modes are managed automatically by hardware.

### 3.5.7 PRCM Off-Mode Management

#### 3.5.7.1 Overview

The CORE power domain can be switched from ON to OFF or retention state.

When the CORE power domain is inactive, the clock manager does not generate an interface clock, and device interconnects are inactive; therefore, the device is effectively in off mode. In retention state, however, the logic in the CORE domain is retained, and the device wake-up latency is small compared to the latency when the CORE power domain is in off state. In waking from the CORE domain off state, the CORE logic configuration must be loaded from a scratchpad memory in the WKUP power domain.

---

**NOTE:** Although some modules in the device can be kept active while the CORE power domain is off or in retention, this is not recommended.

---

When the device is put in off mode (the CORE power domain is in retention or off state), the device voltage domains can be switched off to minimize leakage currents. However, reactivity to wake-up events must be ensured.

The device supports a unique off-mode management scheme that allows deactivation of all modules, isolation of their outputs, and configuration of a dedicated off mode on the I/O pads of the device, to listen to wake-up events. A wake-up event on any I/O pad is detected by the PRM (in WKUP always-on power domain), which can then wake up the device.

#### 3.5.7.2 Device Off-Mode Configuration

##### 3.5.7.2.1 Overview

Any I/O pad of the device can be configured to generate a wake-up event when the device is in off mode. The off-mode scheme is based on the following components of the device:

- I/O pads
- SCM

[Figure 3-86](#) is an overview of the I/O pad off-mode scheme. In this mode, the I/O pads of the device form a daisy chain. The I/O pad logic at the two ends of the chain is connected to the PRM.

When a wake-up event (WUEVT) occurs on an enabled I/O pad in the chain, the event is propagated through the chain to the PRM. Multiple I/O pads can receive a wake-up event simultaneously; however, the PRM receives only the OR output for all the enabled I/O pads. When the device wakes up, the MPU can determine all sources of the current wake-up event logged into the corresponding CONTROL.CONTROL\_PADCONF\_IOPad[15] WAKEUPEVENT0 or CONTROL.CONTROL\_PADCONF\_IOPad[31] WAKEUPEVENT1 bit in the SCM.

The I/O pad wake-up scheme must be enabled globally by setting the PRCM.PM\_WKEN\_WKUP[8] EN\_IO bit and the PRCM.PM\_WKEN\_WKUP[16] EN\_IO\_CHAIN bit. The wake-up event from each I/O pad of the device can be individually enabled/disabled (EVT\_EN signal) by writing to the CONTROL.CONTROL\_PADCONF\_IOPad[14] WAKEUPENABLE0 or CONTROL.CONTROL\_PADCONF\_IOPad[30] WAKEUPENABLE1 bit in the SCM.

For information about the SCM, see [Chapter 13, System Control Module](#).

---

**NOTE:** As explained previously (see [Section 3.5.4, Idle and Wake-Up Management](#)), module-specific wake-up events other than the I/O pad wake-up scheme can wake up the device from off mode. For example, the GPIO pads in the WKUP power domain can also wake up the device.

---

---

**NOTE:** For the wake-up features of the GPIO pads , see [Chapter 25, General-Purpose Interface](#).

---

**Figure 3-86. Device Off-Mode Control Overview**

prcm-077

### 3.5.7.2.2 I/O Wake-Up Mechanism

There are two ways to capture an I/O event. The expected way is to use GPIO modules. However, these modules may be powered-off when there is a need to capture an I/O event. The second way to capture an I/O event is through an I/O wake-up scheme controlled by the I/O daisy chain.

Only one GPIO module is in the WKUP domain, which is not switchable, and the other GPIO modules are in the PER domain, which is switchable. Therefore, the I/O wake-up scheme for the corresponding I/O must be enabled before transitioning the PER domain to a nonfunctional state. This typically happens when the device is programmed to enter OFF state.

During off mode, only six pins of the GPIO module in the WAKEUP domain are wake-up capable; therefore, the I/O wake-up scheme must be enabled for the other 26 I/Os before transitioning to OFF state.

The I/O wake-up scheme can be enabled when the PER domain is in ACTIVE state.

Software must enable and disable the I/O wake-up scheme and ensure an overlap window between the GPIO wake-up capability and the I/O wake-up capability. Software must manage this overlap window.

The I/O wake-up scheme in each pad is enabled through the I/O daisy chain:

- The I/O wake-up capability is enabled by programming the corresponding register (CONTROL.CONTROL\_PADCONF\_X) in the control module.
- The global I/O wake-up enable bit is enabled by programming a dedicated register (PRCM.PM\_WKEN\_WKUP[8] EN\_IO) in the PRCM module.
- The I/O wake-up scheme is enabled by triggering the I/O daisy chain control (Wu clock) by programming a dedicated register (PRCM.PM\_WKEN\_WKUP[16] EN\_IO\_CHAIN) in the PRCM module.

Software must wait for the I/O daisy chain to complete before it transitions the PER domain to a nonfunctional state. This is done by polling a dedicated status bit in the PRCM module (PRCM.PM\_WKST\_WKUP[16] ST\_IO\_CHAIN). This status bit must be cleared by software when the bit is read to 1.

The I/O wake-up scheme in each pad is disabled through the I/O daisy chain:

- The I/O wake-up scheme is disabled by programming the dedicated register (PRCM.PM\_WKEN\_WKUP[16] EN\_IO\_CHAIN) in the PRCM module.
- The global I/O wake-up enable bit is disabled by programming a dedicated register (PRCM.PM\_WKEN\_WKUP[8] EN\_IO) in the PRCM module.
- The I/O wake-up scheme is disabled by triggering the I/O daisy chain control (Wu clock) by writing 1 in a dedicated register (PRCM.PM\_WKST\_WKUP[8] ST\_IO) in the PRCM

This bit is also used to log the source of the I/O wakeup. Writing 1 in this register clears this bit to 0.

### 3.5.7.3 CORE Power Domain Off-Mode Sequences

The I/O pad wake-up scheme can be activated to detect wake-up events when the CORE power domain is switched to inactive, retention, or off state. The off state sequences for the CORE power domain include the sequence for going from on state to retention or off power state (while enabling the I/O pad wake-up scheme), and then switching back to the on power state (while disabling the I/O pad wake-up scheme) on an I/O wake-up event.

#### 3.5.7.3.1 Sleep Sequences (Transition From On to Retention/Off)

When the CORE power domain is in RETENTION state, the logic is switched off, its context is saved by the RFFs in the modules, and the memory blocks are retained. In OFF state, however, the logic and memories are switched off, and the RFFs are not saved.

**NOTE:** If the PER power domain is kept on while the CORE power domain is in RETENTION state, all I/O wake-up enable (EVT\_EN signals) signals to the I/O pads related to the PER power domain inputs must be disabled (by clearing the CONTROL.CONTROL\_PADCONF\_IOPad[14] WAKEUPENABLE bit in the SCM). in this case, wake-up events are generated by the PER domain and not through the daisy chain.

For information about the SCM, see [Chapter 13, System Control Module](#).

The following sequence is used to go from ON to RETENTION or OFF state:

1. Software sets the PRCM.PM\_WKEN\_WKUP[8] EN\_IO bit and the PRCM.PM\_WKEN\_WKUP[16] EN\_IO\_CHAIN bit to enable the I/O pad wake-up scheme. The WAKEUPEVENT bit in the corresponding CONTROL.CONTROL\_PADCONF\_IO register is cleared, when the daisy chain is enabled.
2. The MPU initiates the sleep sequence. When all conditions are met, the CORE power domain clocks are shut down. At this stage, most of the pads are inactive, but some, such as the PER and DSS power domains, can stay active.
3. The PRM initializes and resets the I/O wake-up detection scheme and saves all RFFs. Its CORE power domain output is isolated from the I/O pads.
4. The PRM switches the CORE power domain to RETENTION/OFF power state. The I/O configuration is saved on wake-up power domain registers; see [Section 13.4.4.4.1, Save-and-Restore Mechanism](#), in [Chapter 13, System Control Module](#), for more information.
5. The PRM waits for a wake-up event from the daisy chain. Other possible wake-up sources can be a wake-up event from a module in the wake-up power domain or from a global warm reset.

**NOTE:** When the CORE power domain is in RETENTION state, VDD2 voltage must be at retention or on voltage level to maintain stable CORE power domain output values to the I/Os.

### 3.5.7.3.2 Wake-Up Sequences (Transition From Retention/Off to On)

The PRM detects a wake-up event from the daisy chain. Several wake-up events can occur simultaneously, but PRM only sees the ORing of them. Depending on whether the CORE power domain is in RETENTION or OFF state, the following sequence is followed to wake up the CORE and MPU power domains:

1. When the CORE power domain wakes up from OFF/RETENTION power state, reset is asserted for both the MPU and the CORE power domains.
2. The MPU and the CORE power domains are switched to ON power state.
3. The domain clocks of the MPU and the CORE power domains are restarted.
4. If the CORE power domain was in OFF power state, its reset is released before the MPU power domain.
  - Hardware restores the I/O pad configuration and some configuration registers of the control module. This configuration has been saved in the scratchpad memory (by the control module save procedure initiated by software control prior to the transition to OFF power state).
  - The PRCM module switches the I/O pad configurations to the normal restored configuration (The I/O pad isolation is released).
  - The reset is released for MPU power domain.
5. If the CORE power domain was in RETENTION power state, the reset is released for both the MPU and the CORE power domains at the same time.
6. When the MPU boots, software accesses the SCM to read the wake-up event source (identified by the CONTROL.CONTROL\_PADCONF\_IOPAD[15] WAKEUPEVENT bits in the SCM corresponding to all enabled pads).
7. Software disables the wake-up daisy chain by clearing the PRCM.[PM\\_WKEN\\_WKUP](#)[8] EN\_IO bit and the PRCM.[PM\\_WKEN\\_WKUP](#)[16] EN\_IO\_CHAIN bit.

---

**NOTE:** A daisy-chain wake-up event always causes the MPU to restart and boot. Other independent wake-up events activated in off mode (for example, a GPIO wake-up event) always cause the CORE power domain to be activated. The MPU is wakened if a wake-up dependency has been set by the user, or if the modem generates an interrupt to the MPU.

---

### 3.5.7.4 Device Off-Mode Sequences

Device off-mode sequencing requires preliminary settings that can be done during device initialization. The following actions are performed once and remain valid for all device off/on transitions:

1. Configure valid off and active pad configuration for each pad by programming the SCM CONTROL.CONTROL\_PADCONF\_IOPAD register.
2. Save the active pad configuration by asserting the CONTROL.CONTROL\_PADCONF\_OFF[1] STARTSAVE bit in the SCM. This process can be repeated each time the active pad configuration of the device is changed.
3. Set the SCM to smart-idle mode by configuring the CONTROL.CONTROL\_SYSConfig[4:3] IDLEMODE bit field. This ensures that the module clocks remain active during the configuration save procedure.
4. Disable all the modules running on system clock or switch them on the 32 kHz clock when required.
5. Configure the voltage regulator setup times (the PRCM.[PRM\\_VOLTSETUP1](#)[15:0] SETUP\_TIME1 and PRCM.[PRM\\_VOLTSETUP1](#)[31:16] SETUP\_TIME2 bit fields).
6. Set sys\_off\_mode deassertion time in the PRCM.[PRM\\_VOLTOFFSET](#)[15:0] OFFSET\_TIME bit field.
7. Configure the system clock oscillator setup time in the PRCM.[PRM\\_CLKSETUP](#)[15:0] SETUP\_TIME bit field.

For information about the SCM, see [Chapter 13, System Control Module](#).

### 3.5.7.4.1 Sleep Sequences

The sleep sequences exemplify the two types of device transitions from ON to OFF mode:

- Device off-mode transition without using the SYS\_OFF\_MODE signal
- Device off-mode transition using only the SYS\_OFF\_MODE signal

#### 3.5.7.4.1.1 Device Off-Mode Transition Without Using the SYS\_OFF\_MODE Signal

The following sequence must be performed each time the device enters I/O-pad-off configuration mode:

1. Software sets the PRCM.PM\_WKEN\_WKUP[8] EN\_IO bit and the PRCM.PM\_WKEN\_WKUP[16] EN\_IO\_CHAIN bit to enable the I/O wake-up scheme. The WAKEUPEVENT bit in the corresponding CONTROL.CONTROL\_PADCONF\_IO register is cleared when the daisy chain is enabled.
2. The MPU initiates the sleep sequence. When all sleep conditions are met, all domain clocks are shut down. At this stage, all output pads are inactive and static.
3. The PRM configures the I/O daisy-chain for the wake-up detection scheme.
4. The CORE domain output is isolated.  
When conditions for entering off mode are met, the PRM proceeds with the sequence.
5. It switches off all domains, including the CORE power domain, and then switches from active mode pad configuration to off mode pad configuration.
6. It isolates the pads before the removal of VDD1 and VDD2.
7. It shuts down all analog cells (DPLL, DLL).
8. It switches to off all the DPLL power domains and the SR power domain.
9. It sends the off command for VDD1 to the voltage controller
10. It shuts down the SRAM LDOs.
11. The daisy chain is now ready to detect I/O pad wake-up events.
12. The PRM sends the off command for VDD1 to the voltage controller. Through I2C4, the voltage controller requests the power IC to set VDD1 to the voltage corresponding to the PRM\_VC\_CMD\_VAL\_0[7:0] OFF bit field. (A legacy mode exists where vmode pins can be used instead of I2C4, depending on the PRM\_VOLTCTRL[4] SEL\_VMODE bit. In this case, the PRM asserts sys\_nvemode1 and the power IC updates VDD1 to its previously programmed value.)
13. Upon reception of the I2C4 transaction acknowledge, and after waiting for the VDD1 regulator setup time counter to expire (the PRM\_VOLTSETUP1[15:0] SETUPTIME1 bit field), the PRM sends the off command for VDD2 to the voltage controller. Through I2C4, the voltage controller requests the power IC to set VDD2 to the voltage corresponding to PRM\_VC\_CMD\_VAL\_1[7:0] OFF bit field. (If vmode legacy mode is used, the PRM asserts sys\_nvemode2 and the power IC restores VDD2 to its previously programmed value.)
14. Upon reception of the I2C4 transaction acknowledge, and after waiting for the VDD2 regulator setup time counter to expire (the PRM\_VOLTSETUP1[31:16] SETUPTIME2 bit field), the PRM gates the internal system clock.
15. It releases sys\_clkreq and disables the system clock oscillator (if used).
16. The PRM ramps down the wake-up LDO to 1 V.
17. It waits for a wake-up event from the daisy chain or from an internal event (timer) from the WKUP domain.

---

**NOTE:** If an I/O pad toggles, when the I/O daisy-chain is already configured for the wake-up detection scheme, and before off mode transition occurs, then a not real wake-up event is logged in its padconf register.

---

#### 3.5.7.4.1.2 Device Off-Mode Transition Using Only the SYS\_OFF\_MODE Signal

Depending on the external power IC capability and the user setting, VDD1 and VDD2 voltage control may use the direct sys\_off\_mode signal and not send the commands through the I<sup>2</sup>C interface.

in this case, the initial sequence for device off-mode transition is the same as in [Section 3.5.7.4.1.1, Device Off-Mode Transition Without Using SYS\\_OFF\\_MODE Signal](#), up to Step 8. After this, the following steps are executed:

1. It shuts down the SRAM LDOs.
2. It asserts sys\_off\_mode. At this point, VDD1 and VDD2 are shut down.
3. It ramps down the wake-up LDO to 1 V.
4. It releases CLKREQ and disables the system clock oscillator (if used)
5. It waits for a wake-up event from the daisy chain.

### 3.5.7.4.2 Wake-Up Sequences

---

**NOTE:** vdda\_dpll\_per and vdda\_dpll\_dll can be ramped up any time before VDD1 ramps up.

---

#### 3.5.7.4.2.1 Device Wakeup from Off Mode Without Using the SYS\_OFF\_MODE Signal

On detection of a wake-up event from the daisy chain, the PRM performs the following steps:

1. It enables the system clock oscillator, asserts sys\_clkreq, and ramps up the wake-up LDO.
2. It waits for the oscillator set-up time and the wake-up LDO stabilization time.
3. It sends the on command for VDD2 to the voltage controller. Through I2C4, the voltage controller requests the power IC to set VDD2 to set the voltage corresponding to the [PRM\\_VC\\_CMD\\_VAL\\_1\[31:24\]](#) ON bit field. (A legacy mode exists where vmode pins can be used instead of I2C4, depending on the [PRM\\_VOLTCTRL\[4\]](#) SEL\_VMODE bit. In this case, the voltage controller deasserts sys\_nvmode2 and the power IC restores VDD2 to its previously programmed value). At this point, VDD2 ramps up (the reset is not yet asserted on VDD2 logic).
4. It waits for the VDD2 regulator setup time counter to expire ([PRM\\_VOLTSETUP1\[31:16\]](#) SETUPTIME2).
5. It sends the on command for VDD1 to the voltage controller. Through I2C4, the voltage controller requests the power IC to set VDD1 to set the voltage corresponding to the [PRM\\_VC\\_CMD\\_VAL\\_0\[31:24\]](#) ON bit field. (If vmode legacy mode is used, the voltage controller deasserts sys\_nvmode1 and the power IC restores VDD1 to its previously programmed value). At this point, VDD1 ramps up (the reset is not yet asserted on VDD1 logic).
6. It waits for the VDD1 regulator setup time counter to expire ([PRM\\_VOLTSETUP1\[15:0\]](#) SETUPTIME1).
7. It restarts the memory LDOs.
8. It powers up all analog cells on the VDD2 domain and waits for the settling time of the LDO and analog cells (internal counter).
9. The following steps can occur in parallel:
  - The DPLL, CORE, and MPU power domains are powered up.
  - The reset on the eFuse controller, DPLL, CORE, SR, and MPU power domains is asserted.
10. When the CORE, MPU, DPLLS, and SR are on, the PRM releases the eFuse controller reset, and the eFuse scan starts.
11. When the scan completes, the DPLL resets are released. The DPLLS are in bypass and the clocks start flowing (DPLL1 and DPLL3).
12. When the CORE and MPU domains are on, the PRM releases their corresponding domain output isolations.
13. When the CORE power domain is on and DPLL3 is in bypass, the reset timer for the CORE power domain starts.
14. When the MPU power domain is on and DPLL1 is in bypass, the reset timer for the MPU power domain starts.
15. When the CORE reset time expires, the CORE domain reset is released.
16. When the CORE domain exits reset and the SCM context and I/O configuration are restored from ScratchPad, memory starts.

17. When the PRM receives the acknowledge from the SCM, it releases the MPU and CORE domain output isolations and the I/O isolation.
18. The PRM switches the I/O pad configuration.
19. When the MPU reset time expires and pad configuration returns to normal mode, the MPU domain reset is released.
20. When the MPU boots, the software accesses the control module to read the wake-up event source.
21. The software disables the I/O wake-up daisy chain by clearing the PRCM.[PM\\_WKEN\\_WKUP\[8\]](#) EN\_IO bit and the PRCM.[PM\\_WKEN\\_WKUP\[16\]](#) EN\_IO\_CHAIN bit.

### 3.5.7.4.2.2 Device Wakeup From Off Mode Using Only the SYS\_OFF\_MODE Signal

Depending on the external power IC capability and the user setting, VDD1 and VDD2 voltage control use the direct sys\_off\_mode signal and do not send commands through the I<sup>2</sup>C interface.

in this case, the first part of the sequence in [Section 3.5.7.4.2.1](#) is as follows.

Upon detection of a wakeup from the daisy chain, the PRM performs the following steps:

1. It enables the system clock oscillator and asserts sys\_clkreq.
2. It ramps up the wake-up LDO.
3. It releases sys\_off\_mode.
4. It waits for the system clock oscillator setup time.
5. It waits for VDD1 and VDD2 setup time. The two counts are started in parallel.
6. When both timers expire, the following steps happen in parallel:
  - Reset is asserted on the MPU and CORE power domains.
  - The MPU and CORE power domains are powered up.
  - The PRM restarts the CORE and processor memory LDOs.
  - The PRM powers up all analog cells in the VDD1 and VDD2 domains.

## 3.6 PRCM Basic Programming Model

The PRCM module supports an extensive set of module-specific registers that allow programming control over numerous features of the clocks, resets, and power-management signals for each power domain of the device.

These registers are fully programmable and accessible by the MPU and the IVA2.2 subsystems.

Logically, the registers are grouped into five categories:

- Global
- Clock management
- Reset management
- Power management
- Voltage management

### 3.6.1 Global Registers

#### 3.6.1.1 Revision Information Registers

- [CM\\_REVISION](#): Indicates the CM module revision code; it is read-only
- [PRM\\_REVISION](#): Indicates the PRM module revision code; it is read-only

#### 3.6.1.2 PRCM Configuration Registers

- [CM\\_SYSCONFIG](#): Holds an AUTOIDLE bit to control the CM internal clock autogating feature
- [PRM\\_SYSCONFIG](#): Holds an AUTOIDLE bit to control the PRM internal clock autogating feature

### 3.6.1.3 Interrupt Configuration Registers

The PRM can interrupt the MPU and the IVA2.2 subsystems as a result of four events:

- PRM internal event (event generator, sleep transition, wake-up transition, voltage processors, voltage controller)
- Peripheral wake-up event for a peripheral with interrupt capability (GPTIMER[1..11], GPIO[1..6], McBSP[1..5], UART[1..4], HS USB OTG, I2C[1..3], McSPI[1..4], MMC[1,2], SR[1,2])
- Module/device-level event not associated with any interrupt (DPLL recalibration, I/O wakeup)

The PRM interrupt is enabled by programming the PRM\_IRQENABLE\_processor\_name register; the interrupt status can be read from the PRM\_IRQSTATUS\_processor\_name register.

The device has four processor interrupt registers:

- [PRM\\_IRQSTATUS\\_MPU](#)
- [PRM\\_IRQENABLE\\_MPU](#)
- [PRM\\_IRQSTATUS\\_IVA2](#)
- [PRM\\_IRQENABLE\\_IVA2](#)

#### 3.6.1.3.1 MPU Interrupt Event Sources

The MPU interrupt registers correspond to the interrupt sources connected to the interrupt line mapped to the MPU interrupt controller.

Multiple events can activate this interrupt line:

- MPU peripheral group wake-up event
- Event-generator module end-of-on time and end-of-off time events
- Sleep or wake-up transition (SGX, USBHOST, IVA2, PER, DSS, CAM, NEON, EMU power domains)
- DPLL1/DPLL2/DPLL3/DPLL4/DPLL5 recalibration request
- I/O pad wake-up event
- Voltage processor 1 or 2 OPP Change Done event
- Voltage processor 1 or 2 new voltage reached the minimum voltage value allowed.
- Voltage processor 1 or 2 new voltage reached the maximum voltage value allowed.
- Voltage processor 1 or 2 time-out occurred while waiting for the power IC device acknowledge.
- Voltage processor 1 or 2 new voltage is the same as the current one.
- Voltage processor 1 or 2 transaction is done.
- Slave address in an I<sup>2</sup>C frame sent by the voltage controller not acknowledged by the power IC device
- Register address in an I<sup>2</sup>C frame sent by the voltage controller not acknowledged by the power IC device
- Last byte of an I<sup>2</sup>C frame issued from the bypass port or the voltage manager FSM ports sent by the voltage controller not acknowledged by the power IC device

The end-of-on time period and end-of-off time period events of the event generator module are sources of interrupts to the MPU processor (the corresponding bits in the [PRM\\_IRQENABLE\\_MPU](#) are set to 1). The end-of-off time period is the source of wake-up events on the MPU domain.

The MPU can force a sleep or wake-up transition on some domains (SGX, USBHOST, IVA2, PER, DSS, CAM, NEON, EMU). The PRM triggers the MPU interrupt when the domain enters a power state. The software must clear the CM\_CLKSTCTRL\_domain\_name register only after getting the interrupt. If the software clears this bit before getting the interrupt, the interrupt never occurs, regardless of whether the transition occurs.

An interrupt for a peripheral with wake-up capability is enabled when the wake-up enable bit (PM\_WKEN\_domain\_name register type) and group select bit (PM\_processor\_nameGRPSEL\_domain\_name type of register) are set to 1.

The PRM triggers its interrupt line on the I/O daisy chain wake-up event. This wake-up event is enabled by setting the corresponding bit in the PRCM [PM\\_WKEN\\_WKUP](#) register to 1.

The PRM triggers the MPU interrupt as long as the DPLL recalibration flag is set and the corresponding interrupt enable bit in the PRM\_IRQENABLE\_processor\_name register is set to 1. The recalibration flag is set by the DPLL and remains active if the DPLL is not reinitialized.

### 3.6.1.3.2 MPU Interrupt Registers

#### 3.6.1.3.2.1 PRM\_IRQENABLE\_MPU (MPU Interrupt Enable Register)

The MPU interrupt enable register allows independent masking/unmasking of each MPU internal interrupt source.

---

**NOTE:** If the following interrupts are enabled and the MPU power domain is idled, then when the event occurs, the PRCM module sets the interrupt that wakes up the power domain:

- DPLL1/DPLL2/DPLL3/DPLL4/DPLL5 recalibration event
  - Voltage controller errors
- 

#### 3.6.1.3.2.2 PRM\_IRQSTATUS\_MPU (MPU Interrupt Status Register)

The MPU interrupt status register provides the status of all PRCM internal events that can generate an MPU interrupt. Software must read this register to identify the interrupt cause, and then clear the pending interrupt by setting the corresponding bit to 1.

### 3.6.1.3.3 IVA2.2 Interrupt Event Sources

The IVA2.2 interrupt registers correspond to the interrupt sources connected to the interrupt line mapped to the IVA2.2 interrupt controller.

Three events can activate this interrupt line:

- An IVA2.2 peripheral group wake-up event
- A force wake-up transition completion (IVA2 domain)
- A required IVA2 DPLL recalibration

The PRM also interrupts IVA2.2 if the corresponding bit in the [PM\\_IVA2GRPSEL\\_WKUP](#) register is set to 1.

The PRM triggers the interrupt line dedicated to the IVA2 processor when the MPU performs a force wake-up transition on the IVA2 domain. This interrupt is triggered under the same conditions as that of the MPU.

The PRM triggers an IVA2.2 interrupt if the DPLL recalibration flag is set and the corresponding interrupt enable bit in the PRM\_IRQENABLE\_processor\_name register is set to 1. The recalibration flag is set by the DPLL and remains active if the DPLL is not reinitialized.

### 3.6.1.3.4 IVA2 Interrupt Registers

#### 3.6.1.3.4.1 PRM\_IRQENABLE\_IVA2 (IVA2.2 Interrupt Enable Register)

The IVA2.2 interrupt enable register allows independent masking/unmasking of each of the three internal interrupt sources.

---

**NOTE:** If the IVA2 DPLL recalibration event interrupt is enabled and the IVA2 power domain is idled, then when the event occurs, the PRCM module sets the interrupt, thus waking up the power domain.

---

### 3.6.1.3.4.2 PRM\_IRQSTATUS\_IVA2 (IVA2.2 Interrupt Status Register)

The IVA2.2 interrupt status register provides the status of the three events that can generate an IVA2.2 interrupt. Software must read the register to identify the interrupt cause, and then clear the pending interrupt by setting the corresponding bit to 1.

### 3.6.1.4 Event Generator Control Registers

For details about the event generator module, see the public ARM Cortex-A8 technical reference manual.

In the PRCM module, three event generator registers allow configuration of the event generator module:

- [PM\\_EVTGENCTRL\\_MPU](#) (event generator control register): Event-generator settings
- [PM\\_EVTGENONTIM\\_MPU](#) (event generator on-time register): On-time duration setting
- [PM\\_EVTGENOFFTIM\\_MPU](#) (event generator off-time register): Off-time duration setting

### 3.6.1.5 Output Signal Polarity Control Registers

#### 3.6.1.5.1 CM\_POLCTRL (CM Polarity Control Register)

The [CM\\_POLCTRL](#) register allows the setting of the polarity of sys\_clkout2 when gated (disabled). sys\_clkout2 can be gated to a low level or a high level, depending on the software programming of this register. [Figure 3-87](#) shows the normal behavior of sys\_clkout2 when gated.

**Figure 3-87. sys\_clkout2 Gating Polarity Control**


### **3.6.1.5.2 PRM\_POLCTRL (PRM Polarity Control Register)**

The PRM polarity control register allows the setting of the polarity of the external signals controlled by the PRM. It contains the following polarity control bits:

- OFFMODE\_POL: Polarity of sys\_off\_mode
- CLKOUT\_POL: Polarity of sys\_clkout1
- CLKREQ\_POL: Polarity of sys\_clkreq
- EXTVOL\_POL: Polarity of both sys\_nvmode signals: sys\_nvmode1 and sys\_nvmode2

At device power up, the reset values of polarity settings are OFFMODE\_POL = 1 and CLKREQ\_POL = 1. For details about using these signals, see [Section 3.5.3, Clock Manager Functional Description](#).

### 3.6.1.6 SRAM Precharge Time Control Register

#### 3.6.1.6.1 PRM\_SRAM\_PCHARGE (Voltage SRAM Precharge Counter Register)

The voltage SRAM precharge counter register allows the setting of the precharge duration of the SRAM. It has following bit field:

- PCHARGE\_TIME: Number of system clock cycles defined for the SRAM precharge duration

### 3.6.2 Clock Management Registers

#### 3.6.2.1 System Clock Control Registers

##### 3.6.2.1.1 PRM\_CLKSRC\_CTRL (Clock Source Control Register)

The clock source control register is dedicated to the clock source controls of the device. It contains the following bit fields:

- SYSCLKSEL: Indicates the oscillator mode (oscillator/bypass) and is automatically updated at power up
- AUTOEXTCLKMODE: Enables autogating for the system clock, depending on the device power state. The clock can be configured to be automatically gated when all power domains are in either off or retention state. When the gating condition is satisfied, the internal oscillator is turned off, if it is used. Otherwise, sys\_clkreq is asserted to notify the external clock source to turn off.

---

**NOTE:** Power consumption is reduced with the SYS\_CLK off; however, wake-up latency is increased because of oscillator stabilization time after the clock is turned on again.

---

- SYSCLKDIV: Input divider (1, 2) of the system clock

##### 3.6.2.1.2 PRM\_CLKSETUP (Source-Clock Setup Register)

The source-clock setup register allows the setting of the setup time of the oscillator system clock, based on the number of 32-kHz clock cycles. This duration corresponds to the time required by the oscillator to stabilize before propagating the system clock.

Because the reset lasts long enough for oscillator stabilization, this register is not used at power-on reset of the device. This is ensured either by the external reset source (power IC) or by the reset extension in the PRCM module (RSTTIME0 timer). The [PRM\\_CLKSETUP](#) register is cleared on cold reset only.

---

**NOTE:** The clock setup time is implemented using the oscillator mode or the external clock mode (bypass mode). (The mode of the oscillator is selected by the SYSCLKSEL bits in the [PRM\\_CLKSRC\\_CTRL](#) register).

---

##### 3.6.2.1.3 PRM\_CLKSEL (Source-Clock Selection Register)

The PRCM.[PRM\\_CLKSEL](#)[2:0] SYS\_CLKIN\_SEL bit field is used to select the input frequency of the system clock (12, 13, 16.8, 19.2, 26, or 38.4 MHz).

### 3.6.2.2 External Clock Output Control Registers

#### 3.6.2.2.1 PRM\_CLKOUT\_CTRL (Clock Out Control Register)

The PRM clock out control register provides control to enable and disable the gating of the sys\_clkout1 output clock.

### 3.6.2.2.2 CM\_CLKOUT\_CTRL (Clock Out Control Register)

The CM clock out control register provides control over the device output clock sys\_clkout2, which can be used externally for functional or test purposes. The register allows the following:

- Selection of the source clock for sys\_clkout2:
  - CORE\_CLK
  - CM\_SYS\_CLK
  - 96-MHz clock
  - 54-MHz clock
- Dividing-down the selected source clock by 1, 2, 4, 8, or 16
- Enabling/disabling of the gating of sys\_clkout2

### 3.6.2.3 DPLL Clock Control Registers

A set of registers controls the clock features of the five DPLLs (DPLL1, DPLL2, DPLL3, DPLL4, and DPLL5):

- CM\_CLKSELn\_PLL\_processor\_name
- CM\_CLKSELn\_PLL
- CM\_CLKEN\_PLL\_processor\_name
- [CM\\_CLKEN\\_PLL](#)
- CM\_AUTOIDLE\_PLL\_processor\_name
- [CM\\_AUTOIDLE\\_PLL](#)
- CM\_IDLEST\_PLL\_processor\_name
- [CM\\_IDLEST\\_CKGEN](#)
- [CM\\_IDLEST2\\_CKGEN](#)

The following sections describe the purposes of these registers.

#### 3.6.2.3.1 CM\_CLKSELn\_PLL\_processor\_name (Processor DPLL Clock Selection Register)

The processor DPLL clock selection register controls the clock configuration of DPLL1 and DPLL2, including the following features:

- The multiplier (M) and divider (N) values of the DPLL
- Selection of the fast bypass clock (CORE\_CLK or CORE\_CLK/2) in bypass mode
- Configuration of DPLL output clock divider values (M2 factor)

The device has four DPLL clock selection registers for DPLL1 and DPLL2:

- [CM\\_CLKSEL1\\_PLL\\_MPU](#): DPLL1 multiplier, divider, and fast bypass clock selection
- [CM\\_CLKSEL2\\_PLL\\_MPU](#): DPLL1 output clock divider selection
- [CM\\_CLKSEL1\\_PLL\\_IVA2](#): DPLL2 multiplier, divider, and fast bypass clock selection
- [CM\\_CLKSEL2\\_PLL\\_IVA2](#): DPLL2 output clock divider selection

#### 3.6.2.3.2 CM\_CLKSELn\_PLL (DPLL Clock Selection Register)

The DPLL clock selection register controls the clock configuration for DPLL3, DPLL4, and DPLL5, including the following features:

- The multiplier (M) and divider (N) values of the DPLL
- Configuration of DPLL output clock divider values

The device has the following DPLL clock selection registers for DPLL3, DPLL4, and DPLL5:

- [CM\\_CLKSEL1\\_PLL](#): DPLL3 multiplier, divider, and output clock division configuration. Source selection for the 54-MHz and 48-MHz clock (48M\_FCLK) between DPLL4 output and sys\_altclk.
- [CM\\_CLKSEL2\\_PLL](#): DPLL4 multiplier and divider configuration

- [CM\\_CLKSEL3\\_PLL](#): Divider configuration for 96-MHz clock (96M\_FCLK)
- [CM\\_CLKSEL4\\_PLL](#): DPLL5 multiplier and divider configuration
- [CM\\_CLKSEL5\\_PLL](#): Divider configuration for 120-MHz clock (120M\_FCLK)

### 3.6.2.3.3 CM\_CLKEN\_PLL\_processor\_name (Processor DPLL Clock Enable Register)

The processor DPLL clock enable register allows the enabling or disabling of DPLL1 and DPLL2. It allows an immediate setting of the DPLL.

The device has two DPLL clock enable registers, one for DPLL1 and one for DPLL2:

- [CM\\_CLKEN\\_PLL\\_MPUs](#): DPLL1 (MPU)
- [CM\\_CLKEN\\_PLL\\_IVA2s](#): DPLL2 (IVA2)

The CM\_CLKEN\_PLL\_processor\_name register allows programmable control of the following DPLL features:

- Low-power stop mode (only for DPLL2)/low-power bypass mode/lock mode selection
- Automatic recalibration enable/disable
- Programmable internal frequency range of the DPLL
- The DPLL LP mode can be enabled or disabled. However, switching between LP and normal mode is effective only when the DPLL has performed a recalibration; therefore, the DPLL must lock or relock. Also, the LP mode control is considered only during the following transitions:
  - From bypass to lock
  - From stop mode to lock
  - From lock to relock

---

**NOTE:** DPLL1 enters its internal power state (MNBYPASS) after being released from reset or when a multiplier value of 0 or 1 is loaded into the DPLL. Therefore, even if the [CM\\_CLKEN\\_PLL\\_MPUs\[2:0\]](#) EN\_MPUs\_DPLL bit field is reset to the low-power bypass mode, DPLL1 automatically transitions to MNBYPASS mode, because the multiplier value (the [CM\\_CLKSEL1\\_PLL\\_MPUs\[18:8\]](#) MPUs\_DPLL\_MULT bit field) resets to 0.

---

### 3.6.2.3.4 CM\_CLKEN\_PLL (DPLL Enable Register)

The DPLL enable register allows control of DPLL3, DPLL4, and DPLL5. It allows an immediate setting of the DPLLS. This register controls the following features of the two DPLLS:

- DPLL operation mode:
  - Low-power bypass, fast-relock bypass, and lock modes for DPLL3
  - Low-power bypass and lock modes for DPLL4
- Programmable automatic recalibration
- Programmable internal frequency range for the DPLL
- The DPLL3 output M3X2 and the DPLL4 outputs M2, M3, M4, M5, and M6 clock paths can be powered down. However, the setting takes effect only when the output clock is gated. It is also powered down whenever the DPLL is in stop mode, regardless of the software settings.
- The DPLL LP mode can be enabled or disabled. However, switching between LP and normal mode is effective only when the DPLL has performed a recalibration; therefore, the DPLL must lock or relock. Also, the LP mode control is considered only during the following transition:
  - From bypass to lock
  - From stop mode to lock
  - From lock to relock

### 3.6.2.3.5 CM\_AUTOIDLE\_PLL\_processor\_name (Processor DPLL Autoidle Register)

The processor DPLL autoidle register allows the enabling/disabling of the automatic processor DPLL activity control. In automatic mode, the DPLL automatically enters low-power stop mode when the DPLL clock is not required. It is also restarted automatically.

The following are the device DPLL autocontrol registers:

- [CM\\_AUTOIDLE\\_PLL\\_MP1](#): DPLL1 autoidle mode control
- [CM\\_AUTOIDLE\\_PLL\\_IVA2](#): DPLL2 autoidle mode control

### 3.6.2.3.6 CM\_AUTOIDLE\_PLL (DPLL Autoidle Register)

The DPLL autoidle register allows the enabling/disabling of the automatic mode-switching control for DPLL3 and DPLL4. This automatic mode takes effect only when the DPLLS are locked.

DPLL3 can be configured to automatically switch to either low-power bypass mode or low-power stop mode when the CORE power domain clock is not required.

DPLL4 can be configured to automatically switch to low-power stop mode when the PER power domain clock is not required.

### 3.6.2.3.7 CM\_AUTOIDLE1\_PLL (DPLL5 Autoidle Register)

The DPLL5 autoidle register allows the enabling/disabling of the automatic mode-switching control. This automatic mode takes effect only when the DPLL is locked.

When enabled, DPLL5 is automatically switched to low-power stop mode whenever the 120-MHz output clock is gated.

### 3.6.2.3.8 CM\_IDLEST\_CKGEN (Source-Clock Idle-Status Register)

The source-clock idle-status register provides a status of DPLL3 and DPLL4 clock activity. It also provides the status of the functional clocks derived from DPLL4 output.

The activity status for DPLL3 and DPLL4 can be:

- DPLL is bypassed.
- DPLL is locked.

The activity status for the functional clocks can be:

- The functional 96-MHz clock is active, or not.
- The functional 48-MHz clock is active, or not.
- The functional 12-MHz clock is active, or not.
- The functional 54-MHz clock is active, or not.

The functional 96-MHz clock and all other functional clocks derived from it are active only when DPLL4 is locked and the clock is required.

The functional 48-MHz and 12-MHz clocks are qualified as active only if the clock is required and when the external alternate clock is selected as the source clock.

The functional 54-MHz clock (DSS\_TV\_CLK) is active only when DPLL4 is locked, selected as the source clock, and required.

### 3.6.2.3.9 CM\_IDLEST2\_CKGEN (DPLL5 Source-Clock Idle-Status Register)

The source-clock idle-status register provides the status of DPLL5 clock activity. It also provides the status of the functional clocks derived from DPLL5 output.

The activity status for DPLL5 can be:

- DPLL is bypassed.
- DPLL is locked.

The activity status for the functional clocks can be:

- The 120-MHz functional clock is active, or not.
- The output stage of the 120-MHz functional clock is active, or not.

### **3.6.2.3.10 CM\_IDLEST\_PLL\_processor\_name (Processor DPLL Idle-Status Register)**

The processor DPLL idle-status register indicates the status of the processor DPLL: whether it is in locked or bypass mode.

The device DPLL idle-status registers are:

- [CM\\_IDLEST\\_PLL\\_MPUs](#): DPLL1 activity status
- [CM\\_IDLEST\\_PLL\\_IVA2s](#): DPLL2 activity status

### **3.6.2.4 Power-Domain Clock Control Registers**

An identical set of registers controls the clock features of the power domains in the device:

- CM\_CLKSEL\_domain\_name
- CM\_FCLKEN\_domain\_name
- CM\_ICLKEN\_domain\_name
- CM\_AUTOIDLE\_domain\_name
- CM\_IDLEST\_domain\_name
- CM\_CLKSTCTRL\_domain\_name
- CM\_CLKSTST\_domain\_name
- CM\_SLEEPDEP\_domain\_name

The following sections describe the purposes of these registers.

#### **3.6.2.4.1 CM\_CLKSEL\_domain\_name (Clock Select Register)**

The clock select register controls the selection of the module or subsystem input clock frequency (except for the processor modules). Therefore, it deals only with modules or subsystems for which the frequency is scalable or selectable (the others have fixed and nonprogrammable frequencies). Both functional and interface clocks can be scaled. In most cases, their value is a divided value from the DPLL3 (CORE) or the DPLL4 (PER) output clock.

The device includes the following clock select registers:

- [CM\\_CLKSEL\\_COREs](#): L3 and L4 interconnects, and GPTIMER10 and 11 functional clocks
- [CM\\_CLKSEL\\_CAMs](#): Camera subsystem functional clock
- [CM\\_CLKSEL\\_DSSs](#): DSS functional clock 1 and TV functional clock
- [CM\\_CLKSEL\\_PERs](#): GPTIMER2, 3, 4, 5, 6, 7, 8, and 9 functional clocks
- [CM\\_CLKSEL\\_SGXs](#): SGX subsystem functional clock
- [CM\\_CLKSEL\\_WKUPs](#): GPTIMER1 functional clock and reset manager counter clock

The 32-kHz functional clock (32K\_FCLK) is selected when the device enters off mode. The functional clock of the GPTIMER1 is selectable between the always-on 32K\_FCLK and the system clock (SYS\_CLK), but it is used with the 32-kHz clock.

The [CM\\_CLKSEL\\_SGX](#) register controls the SGX functional clock source and divider ratio, which is divided from the CORE\_CLK source clock or COREX2\_CLK. [Table 3-88](#) summarizes SGX\_FCLK frequency for different configurations of the register field.

**Table 3-88. GFX Functional Clock Ratio Settings**

| <a href="#">CM_CLKSEL_SGX</a> .CLKSEL_SGX | SGX_L3_FCLK |
|-------------------------------------------|-------------|
| 0x0                                       | CORE_CLK/3  |
| 0x1                                       | CORE_CLK/4  |
| 0x2                                       | CORE_CLK/6  |

**Table 3-88. GFX Functional Clock Ratio Settings (continued)**

| CM_CLKSEL_SGX.CLKSEL_SGX | SGX_L3_FCLK   |
|--------------------------|---------------|
| 0x3                      | CM_96M_FCLK   |
| 0x4                      | SGX_192M_FCLK |
| 0x5                      | CORE_CLK/2    |
| 0x6                      | COREX2_CLK/3  |
| 0x7                      | COREX2_CLK/5  |

### 3.6.2.4.2 CM\_FCLKEN\_domain\_name (Functional Clock Enable Register)

The functional clock enable register allows control of the functional clock activity of each module or subsystem. All module functional clocks are controllable by software, except for the MPU, interconnect, and memory subsystems, for which the clocks are automatically controlled by the PRCM.

The device has the following functional clock control registers:

- [CM\\_FCLKEN1\\_CORE](#) and [CM\\_FCLKEN3\\_CORE](#): CORE domain peripherals set
- [CM\\_FCLKEN\\_CAM](#): Camera subsystem
- [CM\\_FCLKEN\\_DSS](#): DSS subsystem
- [CM\\_FCLKEN\\_PER](#): PER domain peripherals set
- [CM\\_FCLKEN\\_IVA2](#): IVA2.2 subsystem
- [CM\\_FCLKEN\\_SGX](#): SGX subsystem
- [CM\\_FCLKEN\\_WKUP](#): WKUP domain peripherals set
- [CM\\_FCLKEN\\_USBHOST](#): HS USB Host subsystem

The software effect is immediate and direct. The functional clock is turned on as soon as the bit is set, and turned off if the bit is cleared and the clock is not required by any module. On module wakeup, the functional clock can be automatically restarted.

---

**NOTE:** The functional clock supplies the functional part of a module or subsystem, which is not operational without its functional clock. In some cases, a module or a subsystem may require multiple functional clocks.

---

### 3.6.2.4.3 CM\_ICLKEN\_domain\_name (Interface Clock Enable Register)

The interface clock enable register allows control of the interface clock activity of each module or subsystem. This register provides control over each module in the device.

The device has following interface clock control registers:

- [CM\\_ICLKEN1\\_CORE](#) and [CM\\_ICLKEN3\\_CORE](#): CORE domain peripherals set
- [CM\\_ICLKEN\\_CAM](#): Camera subsystem
- [CM\\_ICLKEN\\_DSS](#): DSS subsystem
- [CM\\_ICLKEN\\_PER](#): PER domain peripherals set
- [CM\\_ICLKEN\\_SGX](#): SGX subsystem
- [CM\\_ICLKEN\\_WKUP](#): WKUP domain peripherals set
- [CM\\_ICLKEN\\_USBHOST](#): HS USB Host subsystem

This register has an immediate effect, causing the source of the interface clock to be effectively cut (if the appropriate bit is cleared and no module requires this clock) or activated (if the appropriate bit is set).

Independent functional and interface clock control registers provide potential power savings for each module. For example, because the configuration port and interface of the module are still active, disabling a functional clock of a module while keeping its interface clock active (leaving the module inactive but allowing access to its registers) reduces power consumption.

When the interface clock is disabled, the module cannot communicate with the rest of the device; therefore, it is in idle mode. For example, the interface clock of a peripheral can be disabled while its functional clock is active; it is then idled, from the device standpoint, while it can detect any external event. This configuration typically allows a main part of the device to go into idle mode while keeping a peripheral active and ready to wake up from an external event.

Because a module may or may not be able to function without its functional or interface clocks, power-management strategies must be adapted accordingly. This relation is programmable and is defined in the CLOCKACTIVITY bits of the module SYSCONFIG register; therefore, it requires consistent programming of the CM\_FCLKEN and CM\_ICLKEN registers.

---

**NOTE:** The interface clock ensures proper communication between any module and the interconnect (L3 or L4), in most cases supplying the module interface and registers.

---

#### 3.6.2.4.4 CM\_AUTOIDLE\_domain\_name (Autoidle Register)

The autoidle register holds an AUTOIDLE bit per module that belongs to the related power domain. Each AUTOIDLE bit enables/disables automatic (hardware) gating of a module interface clock.

When AUTOIDLE and ICLKEN are set for a module, the module interface clock is managed automatically (that is, by hardware control) according to the power domain clock activity; for example, stopped before a power domain sleep transition and reenabled on wakeup. [Table 3-89](#) lists the possible autoidle settings for the interface clock.

**Table 3-89. Interface Clock Autoidle Settings**

| CM_AUTOIDLE.AUTO_module | CM_ICLKEN.EN_module | Interface Clock              |
|-------------------------|---------------------|------------------------------|
| 0                       | 0                   | Disabled                     |
| 0                       | 1                   | Enabled                      |
| 1                       | 0                   | Disabled                     |
| 1                       | 1                   | Automatic enabling/disabling |

The device has the following autoidle control registers:

- [CM\\_AUTOIDLE1\\_CORE](#) and [CM\\_AUTOIDLE3\\_CORE](#): CORE domain peripherals set
- [CM\\_AUTOIDLE\\_CAM](#): Camera subsystem
- [CM\\_AUTOIDLE\\_DSS](#): DSS subsystem
- [CM\\_AUTOIDLE\\_PER](#): PER domain peripherals set
- [CM\\_AUTOIDLE\\_WKUP](#): WKUP domain peripherals set
- [CM\\_AUTOIDLE\\_USBHOST](#): HS USB Host subsystem

---

**NOTE:** For SmartReflex1 and 2, IVA2.2, and GFX modules, the automatic idle mode is always enabled, and is not software-controllable.

---

#### 3.6.2.4.5 CM\_IDLEST\_domain\_name (Idle-Status Register)

The idle-status register allows checking whether a target module is in idle mode or if an initiator module is in standby mode. Software must not access a target module in idle mode. A target access in this state can lead to an error.

The idle mode of any module can depend on the configuration of the CM\_FCLKEN\_domain\_name and CM\_ICLKEN\_domain\_name registers, or may be controlled automatically by hardware, depending on the configuration of the CM\_AUTOIDLE\_domain\_name registers.

In the case of IVA2.2 subsystem, standby mode is reached after the IVA2.2 processor has performed its idle instruction.

The device has the following idle status registers:

- [CM\\_IDLEST\\_MPUS](#): MPU subsystem
- [CM\\_IDLEST1\\_CORE](#) and [CM\\_IDLEST3\\_CORE](#): CORE domain peripherals set
- [CM\\_IDLEST\\_CAM](#): Camera subsystem
- [CM\\_IDLEST\\_DSS](#): DSS
- [CM\\_IDLEST\\_PER](#): Peripheral domain peripherals set
- [CM\\_IDLEST\\_NEON](#): NEON subsystem
- [CM\\_IDLEST\\_IVA2](#): IVA2.2 subsystem
- [CM\\_IDLEST\\_SGX](#) SGX subsystem
- [CM\\_IDLEST\\_WKUP](#): WKUP domain peripherals set
- [CM\\_IDLEST\\_USBHOST](#): HS USB Host subsystem

#### 3.6.2.4.6 CM\_CLKSTCTRL\_ domain\_name (*Clock State Control Register*)

The clock state control register holds a CLKTRCTRL\_clock domain bit field for each clock domain in the power domain. It controls the hardware- and software-supervised state transitions between active and inactive states. [Table 3-90](#) lists the clock state transition settings.

**Table 3-90. Clock State Transition Settings**

| CM_CLKSTCTRL_pwr domain.<br>CLKTRCTRL_clk domain | Description                                                                                                                                                                                                                         |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0                                              | The automatic hardware-supervised mode is disabled. The clocks in a clock domain cannot be cut automatically. This prevents any power transition on the power domain.                                                               |
| 0x1                                              | Starts software-supervised (forced) sleep transition on the domain. All clocks in the clock domain are automatically cut whenever the initiators in the modules are in standby mode.                                                |
| 0x2                                              | Starts software-supervised (forced) wake-up transition on the domain. The clocks in the clock domain are restarted.                                                                                                                 |
| 0x3                                              | The automatic hardware-supervised mode is enabled, and the clocks in the clock domain are automatically cut whenever the modules and subsystem in the clock domain are in idle or standby mode and the domain dependencies are met. |

The hardware-supervised mode and the software-supervised (forced) sleep mode are mutually exclusive. It is a software decision to program one mode or another, and the software programs the PRCM module accordingly.

The hardware-supervised mode is coupled to the sleep and wake-up dependencies programmed in the PRCM module, whereas the software-supervised mode must be independent of those dependencies. Therefore, the sleep and wake-up dependencies must be disabled before the software forces a sleep transition on a power domain; otherwise, the forced-domain will be wakened immediately because of the wake-up dependency.

The device has the following clock state control registers:

- [CM\\_CLKSTCTRL\\_MPUS](#): MPU subsystem clock domain
- [CM\\_CLKSTCTRL\\_CORE](#): L3, L4, and D2D clock domains
- [CM\\_CLKSTCTRL\\_CAM](#): Camera subsystem clock domain
- [CM\\_CLKSTCTRL\\_DSS](#): DSS clock domain
- [CM\\_CLKSTCTRL\\_PER](#): Peripherals clock domain
- [CM\\_CLKSTCTRL\\_NEON](#): NEON clock domain
- [CM\\_CLKSTCTRL\\_IVA2](#): IVA2.2 clock domain
- [CM\\_CLKSTCTRL\\_SGX](#): Graphics clock domain
- [CM\\_CLKSTCTRL\\_EMU](#): Emulation clock domain
- [CM\\_CLKSTCTRL\\_USBHOST](#): HS USB Host clock domain

The CORE domain has three clock domains (L3, L4, and D2D); it does not have forced sleep and forced wake-up ability.

Although the sleep transition in the MPU power domain cannot be initiated by software using this register, a software-initiated forced wake-up capability exists. This can be used to wake up the MPU power domain if it does not wake up when the CORE power domain wakes up (the MPU wake-up-dependency [PM\\_WKDEP\\_MPUMPU\[0\]](#) EN\_CORE bit is set to 0).

If the hardware-supervised mode is enabled, the following occur:

- The MPU domain clock is automatically cut if the MPU executes the wait-for-interrupt instruction.
- The IVA2 domain clock is automatically cut when the DSP completes its idle procedure, and the IVA2.2 subsystem is ready for standby.
- The L3 domain clock is automatically cut when all initiators are in standby mode and slave ports are idled.
- The L4 domain clock is automatically cut when all peripherals and slave ports are idled.
- The DSS interface clock is automatically cut when it stops fetching data from the frame buffer (provided the MPU is also in standby mode, if sleep dependency in the MPU power domain is enabled). The display functional clock is controlled only by the [CM\\_FCLKEN\\_DSS](#) register.
- The PER domain clock is automatically cut when all initiators are in standby mode and all slave ports are in idle (provided the MPU and the DSP are in standby mode and the CORE power domain is inactive, if sleep dependency in their domains is enabled).
- The USBHOST power domain clock is automatically cut whenever the USBHOST is in standby mode (provided MPU is also in standby mode, if sleep dependency in the MPU domain is enabled, and IVA2 is also in standby mode, if sleep dependency in the IVA2 domain is enabled).
- Because of the hardwired sleep dependency between NEON and the MPU domain, NEON can go into idle only if the MPU goes into standby mode. The MPU domain must also be configured in automatic hardware supervised mode for the NEON power domain idle transition to occur.

#### **3.6.2.4.7 CM\_CLKSTST\_domain\_name (Clock State Status Register)**

The clock state status register logs the activity status of the power domain clock. This includes the activity of the interface clocks running only on the domain.

The device has following clock state status registers:

- [CM\\_CLKSTST\\_MPUMPU](#): MPU subsystem clock activity
- [CM\\_CLKSTST\\_CORE](#): L3 clock domain activity and L4 clock domain activity
- [CM\\_CLKSTST\\_CAM](#): Camera subsystem clock activity
- [CM\\_CLKSTST\\_DSS](#): DSS clock activity
- [CM\\_CLKSTST\\_PER](#): PER clock domain activity
- [CM\\_CLKSTST\\_IVA2](#): IVA2.2 clock domain activity
- [CM\\_CLKSTST\\_SGX](#): Graphics subsystem clock activity
- [CM\\_CLKSTST\\_EMU](#): Emulation clock activity
- [CM\\_CLKSTST\\_USBHOST](#): USBHOST clock activity

#### **3.6.2.4.8 CM\_SLEEPDEP\_domain\_name (Sleep Dependency Control Register)**

The sleep dependency control register allows the enabling or disabling of the sleep transition dependency of a power domain with respect to other power domains.

The device has following sleep dependency registers:

- [CM\\_SLEEPDEP\\_CAM](#): CAM power domain sleep dependency with the MPU power domain
- [CM\\_SLEEPDEP\\_DSS](#): Display power domain sleep dependency with the MPU power domain and the IVA2 power domain
- [CM\\_SLEEPDEP\\_PER](#): PER power domain sleep dependencies with the MPU, IVA2, and CORE power domains
- [CM\\_SLEEPDEP\\_SGX](#): SGX power domain sleep dependency with the MPU power domain
- [CM\\_SLEEPDEP\\_USBHOST](#): USBHOST power domain sleep dependency with the MPU and IVA2

### power domains

Although the CORE power domain is composed of L3 and L4 clock domains, the sleep dependency with the L3 clock domain is always enabled (not programmable by software); there is no sleep dependency between the PER power domain and the CORE\_L4 clock domain.

The dependencies listed in [Table 3-91](#) can be enabled or disabled by software.

**Table 3-91. Sleep Dependency Settings**

|                         | <b>Parent Domain</b> |                     |                |
|-------------------------|----------------------|---------------------|----------------|
| <b>Dependent Domain</b> | <b>MPU</b>           | <b>IVA2</b>         | <b>CORE-L3</b> |
| CAM                     | Software controlled  |                     |                |
| DSS                     | Software controlled  | Software controlled |                |
| PER                     | Software controlled  | Software controlled | Always enabled |
| SGX                     | Software controlled  |                     |                |
| USBHOST                 | Software controlled  | Software controlled |                |

### 3.6.2.5 Domain Wake-Up Control Registers

The following modules have programmable wake-up control:

- CORE power domain:
  - USBTLL
  - HS USB OTG
  - McBSP 1 and 5
  - GPTIMER[10,11]
  - UART[1,2]
  - I2C[1..3]
  - McSPI[1..4]
  - MMC[1,2,3]
- PER power domain:
  - McBSP[2..4]
  - GPTIMER[2..9]
  - UART [3,4]
  - WDTIMER3
  - GPIO[2..6]
- WKUP power domain:
  - GPTIMER1
  - GPIO1
  - SR[1,2]
  - I/O pad
- DSS power domain:
  - DSS subsystem
- USBHOST power domain:
  - HS USB Host subsystem

The registers in the following sections control the wake-up settings.

### 3.6.2.5.1 PM\_WKEN\_domain\_name (Wake-Up Enable Register)

The wake-up enable register applies only to modules that can generate wake-up events. It allows the enabling or disabling of the wakeup of the related power domain on a module or subsystem wake-up event. Each EN\_module bit in the register enables/disables the wake-up event from the module to the PRCM module.

The device has the following wake-up enable registers:

- [PM\\_WKEN1\\_CORE](#) and [PM\\_WKEN3\\_CORE](#): CORE domain modules wake-up control
- [PM\\_WKEN\\_DSS](#): Display subsystem (DSS) wake-up control
- [PM\\_WKEN\\_PER](#): Peripheral domain modules wake-up control
- [PM\\_WKEN\\_WKUP](#): WKUP domain modules wake-up control
- [PM\\_WKEN\\_USBHOST](#): HS USB Host subsystem wake-up control

---

**NOTE:** The wake-up signals issued from the MPU and IVA2.2 INTCs are nonmaskable in the PRCM module. However, they cannot be generated if the corresponding interrupts are masked in the INTCs.

---

### 3.6.2.5.2 PM\_WKST\_domain\_name (Wake-Up Status Register)

The wake-up status register logs wake-up events from all modules. Each ST\_module bit of this register logs a given module-generated wake-up event.

The device has the following wake-up status registers:

- [PM\\_WKST1\\_CORE](#) and [PM\\_WKST3\\_CORE](#): CORE domain modules wake-up event status
- [PM\\_WKST\\_PER](#): Peripheral domain modules wake-up event status
- [PM\\_WKST\\_WKUP](#): WKUP domain modules wake-up event status
- [PM\\_WKST\\_USBHOST](#): HS USB Host subsystem wake-up control

The functional clock of the module causing the wakeup automatically restarts on the wakeup, but the software must enable the functional clock (CM\_FCLKEN\_domain\_name register) before clearing the wake-up status bit.

---

**NOTE:**

- Software must clear this register before a new sleep transition request; otherwise, the register prevents the sleep transition from occurring.
  - If the PRM interrupt is enabled on a module wakeup, the PM\_WKST\_domain\_name must be cleared before clearing the PRM\_IRQSTATUS\_processor\_name interrupt status register.
- 

### 3.6.2.5.3 PM\_WKDEP\_domain\_name (Wake-Up Dependency Register)

The wake-up dependency register allows the enabling/disabling of a wake-up dependency between power domains. When a domain wakes up, it can wake up another domain.

The device has the following wake-up dependency registers:

- [PM\\_WKDEP\\_MPU](#): MPU power domain wake-up dependency with the following domains:
  - CORE
  - IVA2
  - WKUP
  - DSS
  - PER
- [PM\\_WKDEP\\_DSS](#): DSS power domain wake-up dependency with the following domains:
  - MPU

- IVA2
- WKUP
- **PM\_WKDEP\_CAM:** The CAM power domain has programmable wake-up dependency with the following domains:
  - MPU
  - IVA2
  - WKUP
- **PM\_WKDEP\_PER:** The PER power domain has programmable wake-up dependency with the following domains:
  - MPU
  - IVA2
  - WKUP
  - COREThe PER power domain can be wakened only by a wakeup of the L3 and D2D clock domains, not by an L4 clock domain.
- **PM\_WKDEP\_NEON:** The NEON power domain has programmable wake-up dependency with the following domain:
  - MPU
- **PM\_WKDEP\_IVA2:** The IVA2 power domain has programmable wake-up dependency with the following domains:
  - MPU
  - PER
  - WKUP
  - CORE
- **PM\_WKDEP\_SGX:** The SGX power domain has programmable wake-up dependency with the following domains:
  - MPU
  - IVA2
  - WKUP
- **PM\_WKDEP\_USBHOST:** The USBHOST power domain has programmable wake-up dependency with the following domains:
  - MPU
  - IVA2
  - WKUP
  - CORE

There is no wake-up dependency control for the WKUP power domain, because it is always on.

Because the CORE power domain wake-up dependencies are not programmable, the CORE power domain always wakes up on a wake-up event on the following domains:

- MPU
- IVA2
- WKUP
- CAM
- DSS
- SGX
- PER
- USBHOST

### **3.6.2.5.4 PM\_processor\_name GRPSEL\_domain\_name (Processor Group Selection Register)**

The processor group selection register allows defining the group of modules in the domain that can wake up a processor domain (MPU or IVA2). This bit is effective only if the module wake-up capability is enabled (PM\_WKEN\_domain\_name register).

The device has the following processor group selection registers:

- [PM\\_MPUGRPSEL1\\_CORE](#) and [PM\\_MPUGRPSEL3\\_CORE](#): CORE power domain modules MPU wake-up control
- [PM\\_IVA2GRPSEL1\\_CORE](#) and [PM\\_IVA2GRPSEL3\\_CORE](#): CORE power domain modules IVA2 wake-up control
- [PM\\_MPUGRPSEL\\_PER](#): PER power domain modules MPU wake-up control
- [PM\\_IVA2GRPSEL\\_PER](#): PER power domain modules IVA2 wake-up control
- [PM\\_MPUGRPSEL\\_WKUP](#): WKUP power domain modules MPU wake-up control
- [PM\\_IVA2GRPSEL\\_WKUP](#): WKUP power domain modules IVA2 wake-up control
- [PM\\_MPUGRPSEL\\_USBHOST](#): HS USB Host subsystem MPU wake-up control
- [PM\\_IVA2GRPSEL\\_USBHOST](#): HS USB Host subsystem IVA2 wake-up control

---

**NOTE:** The wake-up capability of the DSS is always attached to the MPU group; it cannot be attached to the IVA2.2, and therefore is not programmable.

---

## **3.6.3 Reset Management Registers**

### **3.6.3.1 Reset Control**

#### **3.6.3.1.1 PRM\_RSTTIME (Reset Time Register)**

The reset time register provides control over reset duration. Two durations are configurable:

- RSTTIME1: Minimum duration (by default, two cycles of the 32-kHz clock) of the global warm reset (sys\_nreswarm) assertion for external devices, such as flash memories. At power-up reset, DLLs are reset and the power domains are switched on and stabilized during this duration.
- RSTTIME2: Minimum duration (by default, 16 cycles of the RM\_ICLK clock) to control power domain resets when the domain clocks are on.

For global cold and warm resets, the reset is applied for the RSTTIME1 + RSTTIME2 duration. In the other cases, when a power domain individually goes from off to active, the reset is applied only for the RSTTIME2 duration (plus the power domain wake-up duration).

RSTTIME1 and RSTTIME2 can be reprogrammed for different behavior after the initial power up.

#### **3.6.3.1.2 RM\_RSTCTRL\_domain\_name (Reset Control Register)**

The reset control register provides control over the local domain software reset.

Most device modules include an individual software reset that can be controlled using the related module SYS\_CONFIG register.

The RM\_RSTCTRL\_domain\_name register is used for specific subsystems or modules that do not support this local reset or that require a specific system control (the IVA2.2 subsystem).

The [PRM\\_RSTCTRL](#) register also handles the global software warm reset control.

The device includes the following reset control registers:

- [PRM\\_RSTCTRL](#): This register allows control of the assertion of the global software reset and the DLL3 software reset. These bits are automatically cleared. Assertion of the DLL3 software reset triggers a device global cold reset. The reset condition of this register depends on the bit field:
  - The RST\_GS bit is set on any global source of reset (warm or cold).
  - The RST\_DLL3 bit is set only on a global cold source of reset.

- [RM\\_RSTCTRL\\_IVA2](#): IVA2 power domain software resets the IVA2.2 and SEQ subsystems. Both subsystems are held under reset after power up and are released by software. The SEQ software reset bit is reset to 1 (SEQ reset active) on an IVA2 domain power transition from off or retention to on.

### 3.6.3.1.3 RM\_RSTST\_domain\_name (Reset Status Register)

The reset status register logs any source that has generated a reset in the related power domain. Depending on the domain, several causes of reset can be logged:

- Global device cold reset
- Global device warm reset
- Power domain transition (off to active, and inactive to active)
- Software reset
- Processor emulation reset

The [PRM\\_RSTST](#) register logs the source of the global reset:

- VDD1/VDD2 voltage manager reset
- External warm reset
- MPU watchdog reset
- Global software reset and DPLL3 software reset
- Global cold reset

The device includes the following reset status registers:

- [RM\\_RSTST\\_MPU](#)
- [RM\\_RSTST\\_CORE](#)
- [RM\\_RSTST\\_DSS](#)
- [RM\\_RSTST\\_CAM](#)
- [RM\\_RSTST\\_IVA2](#)
- [RM\\_RSTST\\_PER](#)
- [RM\\_RSTST\\_NEON](#)
- [RM\\_RSTST\\_SGX](#)
- [RM\\_RSTST\\_EMU](#)
- [PRM\\_RSTST](#)
- [RM\\_RSTST\\_USBHOST](#)

Only the [RM\\_RSTST\\_CORE](#), [RM\\_RSTST\\_IVA2](#), and [PRM\\_RSTST](#) registers log software sources of reset.

Each bit of these registers is set on the effective release of the respective reset signal.

### 3.6.4 Power Management Registers

#### 3.6.4.1 PM\_PWSTCTRL\_domain\_name (Power State Control Register)

The power state control register allows controlling the power state transition of the domain.

This register holds the following bit fields:

- POWERSTATE: Power state (ON, retention, or off) to be applied for the next transition
- LOGICRETSTATE: Logic is retained or switched off when the domain goes into retention. This feature is domain-dependent and is not necessarily programmable (read only).
- MEMRETSTATE[1 to X]: Memory block i is retained (RAM state retained) or switched off (RAM state not retained) when the domain goes into retention. This feature is domain-dependent and is not necessarily programmable (read only).
- MEMONSTATE[1 to X]: Memory block i in the domain is on (RAM active), retained (RAM inactive but state retained) or switched off (RAM state not retained) when the domain is on. This feature is domain-dependent and is not necessarily programmable (read only).
- MEMORYCHANGE: Allows updating the memory state according to latest MEMONSSTATE[1 to X] setting.

The device has the following power state control registers:

- [PM\\_PWSTCTRL\\_MPUS](#): MPU domain power management
- [PM\\_PWSTCTRL\\_CORES](#): CORE domain power management
- [PM\\_PWSTCTRL\\_SGXs](#): SGX domain power management
- [PM\\_PWSTCTRL\\_DSSs](#): DSS domain power management
- [PM\\_PWSTCTRL\\_CAMs](#): CAM domain power management
- [PM\\_PWSTCTRL\\_PERs](#): PER domain power management
- [PM\\_PWSTCTRL\\_NEONs](#): NEON domain power management
- [PM\\_PWSTCTRL\\_IVA2s](#): IVA2 domain power management
- [PM\\_PWSTCTRL\\_USBHOSTs](#): USBHOST domain power management

MPU domain power management has the following features:

- The power state is programmable to on, retention, and off states.
- Logic and L1 cache state are switchable to off and retention states when the power domain is in retention state.
- L2 cache state is switchable to off and retention states when the power domain is in retention state.
- L2 cache state is switchable to off and on states when the power domain is in on state.
- L2 cache state can be switched dynamically when the domain state is on (no power transition is required).
- The L1 cache is always on when the power domain state is on.

CORE domain power management has the following features:

- The power state is programmable to on, retention, or off states.
- Nonretained logic is switchable to off and retention states when the power domain is in retention state.
- Memory bank 1 and 2 states are switchable to off and retention states when the power domain is in retention state.
- Memory bank 1 and 2 states are switchable to off, retention, and on states when the power domain is in on state.
- Memory bank 1 and 2 states can be switched dynamically when the domain state is on (no power transition is required).

SGX domain power management has the following features:

- The power state is programmable to on, retention, and off states.
- The logic is always in retention state when the power domain is in retention state.

- The memory is always in retention state when the power domain is in retention state.
- The memory is always in on state when the power domain is in on state.

DSS domain power management has the following features:

- The power state is programmable to on, retention, and off states.
- The logic is always in retention state when the power domain is in retention state.
- The memory is always in retention state when the power domain is in retention state.
- The memory is always in on state when the power domain is in on state.

CAM domain power management has the following features:

- The power state is programmable to on, retention, and off states.
- The logic is always in retention state when the power domain is in retention state.
- The memory is always in retention state when the power domain is in retention state.
- The memory is always in on state when the power domain is in on state.

PER domain power management has the following features:

- The power state is programmable to on, retention, and off states.
- The logic is always in retention state when the power domain is in retention state.

NEON domain power management has the following features:

- The power state is programmable to on, retention, and off states.
- The logic is always in retention state when the power domain is in retention state.

IVA2 domain power management has the following features:

- The power state is programmable to on, retention, and off states.
- Logic state is switchable to off and retention states when the power domain is in retention state.
- L1 cache state is switchable to off and retention states when the power domain is in retention state.
- L1 flat memory state is switchable to off and retention states when the power domain is in retention state.
- L2 cache state is switchable to off and retention states when the power domain is in retention state.
- L2 flat memory state is switchable to off and retention states when the power domain is in retention state.
- L1 cache state is always on when the power domain is in on state.
- L1 flat memory state is always on when the power domain is in on state.
- L2 cache state is switchable to off and on states when the power domain is in on state.
- L2 flat memory state is always on when the power domain is in on state.
- L2 cache memory state can be switched dynamically to off state and back to on state when the domain state is on (no domain power transition is required).

USBHOST domain power management has the following features:

- The power state is programmable to on, retention, and off states.
- The logic is always in retention state when the power domain is in retention state.
- The memory is always in retention state when the power domain is in retention state, and the memory is always on when the power domain is in on state.

The EMU power state is not programmable. The EMU domain is always powered down when the software or hardware conditions that allow a power transition are met. Thus, the EMU domain is automatically powered down after the power-up sequence if no emulation hardware is connected.

**NOTE:** The L1 cache memory bank can be configured to be either entirely or partially cache or flat memory. This configuration is done in the IVA2.2 subsystem. The part that is configured as cache memory can be retained; however, because tag and validity bit information are not retained in the case of L1 cache, this part cannot be retrieved after wakeup. It is important to configure the L1 cache memory state with a consistent value depending on the chosen configuration when the domain is in retention state:

- If the L1 cache memory bank is entirely configured as cache memory, set the [PM\\_PWSTCTRL\\_IVA2\[8\]](#) SHAREDL1CACHEFLATRETSTATE bit to the same value as the [PM\\_PWSTCTRL\\_IVA2\[2\]](#) LOGICRETSTATE bit.
- If the L1 cache memory bank is entirely or partially configured as flat memory, set the [PM\\_PWSTCTRL\\_IVA2\[8\]](#) SHAREDL1CACHEFLATRETSTATE bit to the same value as the [PM\\_PWSTCTRL\\_IVA2\[9\]](#) L1FLATMEMRETSTATE bit.

The same mechanism applies to the L2 cache memory bank.

---

Because the L2 cache may not be useful in a system when the DSP frequency and interconnect frequencies are in the same range, this memory bank can be switched off when the domain is on.

### 3.6.4.2 PM\_PWSTST\_domain\_name (Power State Status Register)

The power state status register provides the status of the power state transition of the domain.

This register holds the following bit fields:

- POWERSTATESTATUS: Indicates the current power state of the domain (on, retention, off)
- LOGICSTATESTATUS: Indicates the current logic power state
- MEMORYSTATESTATUS: Indicates the current memory power state
- INTRANSITION: Indicates an ongoing power state transition from ON power state to inactive, off, or retention, and from inactive, off, or retention power states to on power state

The memory power state is updated by performing a dynamic memory change (the [PM\\_PWSTCTRL\\_domain\\_name](#) MEMORYCHANGE bit). Software clears the [PM\\_PREPWST\\_domain\\_name](#) register (this forces a memory change to the same value).

The device has the following power state status registers:

- [PM\\_PWSTST\\_MPUS](#): MPU domain power state status
- [PM\\_PWSTST\\_CORES](#): CORE domain power state status
- [PM\\_PWSTST\\_SGX](#): SGX domain power state status
- [PM\\_PWSTST\\_DSS](#): DSS domain power state status
- [PM\\_PWSTST\\_CAM](#): CAM domain power state status
- [PM\\_PWSTST\\_PER](#): PER domain power state status
- [PM\\_PWSTST\\_NEON](#): NEON domain power state status
- [PM\\_PWSTST\\_EMU](#): EMU domain power state status
- [PM\\_PWSTST\\_IVA2](#): IVA2 domain power state status
- [PM\\_PWSTST\\_USBHOST](#): USBHOST domain power state status

The MPU domain power state status register indicates the current domain, logic, L1 cache (on or off), and L2 cache (on, retention, or off) power state.

The CORE domain power state status register indicates the current domain, logic (on or off), and memory banks 1 and 2 (on, retention, or off) power state.

The SGX, DSS, CAM, PER, NEON, USBHOST, and EMU domain power state status registers indicate the current domain (on, inactive, retention, or off) power state or that the power domain transition is in progress. Because the SGX memory state is not programmable and reflects the power state, the SGX power domain does not require a memory power state.

The IVA2 domain power state status register indicates the current domain (on, inactive, retention, or off), logic (on or off), L1 cache and flat memory (on, retention, or off), L2 cache and flat memory (on, retention, or off) power state status.

### 3.6.4.3 PM\_PREPWSTST\_domain\_name (Previous Power State Status Register)

The previous power state status register indicates the power state entered during the last sleep transition. The information in this register is useful when the domain switches back to on state (following a wake-up transition). This register must only be read when the domain power state is on.

This register has the following bit fields:

- LASTPOWERSTATEENTERED: Last domain power state entered after the last sleep transition
- LASTLOGICSTATEENTERED: Last logic power state entered after the last sleep transition
- LASTMEMORYSTATEENTERED: Last memory power state entered after the last sleep transition or before the last memory change update

The device has the following previous power state status registers:

- [PM\\_PREPWSTST\\_MPUS](#): The MPU power domain previous power state status
- [PM\\_PREPWSTST\\_CORES](#): The CORE power domain previous power state status
- [PM\\_PREPWSTST\\_SGXs](#): The SGX power domain previous power state status
- [PM\\_PREPWSTST\\_DSSs](#): The DSS power domain previous power state status
- [PM\\_PREPWSTST\\_CAMs](#): The CAM power domain previous power state status
- [PM\\_PREPWSTST\\_PERs](#): The PER power domain previous power state status
- [PM\\_PREPWSTST\\_NEONs](#): The NEON power domain previous power state status
- [PM\\_PREPWSTST\\_IVA2s](#): The IVA2 power domain previous power state status
- [PM\\_PREPWSTST\\_USBHOSTs](#): The USBHOST power domain previous power state status

The previous power state status register for the MPU power domain indicates the previous domain, logic, L1 cache (on or off), and L2 cache (on, retention, or off) power state.

The previous power state status register for the CORE power domain indicates the previous domain, logic (on or off), and memory banks 1 and 2 (on, retention, or off) power state.

The previous power state status registers for the SGX, DSS, CAM, PER, NEON, USBHOST and EMU power domains indicate the previous domain (on, inactive, retention, or off) power state. The SGX power domain does not require a memory power state status, because the SGX memory state is not programmable and reflects the power state.

The previous power state status register for the IVA2 power domain indicates the previous domain (on, inactive, retention, or off), logic (on or off), L1 cache and flat memory (on, retention, or off), and L2 cache and flat memory (on, retention, or off) power state status.

The current memory state depends on the setting of the PM\_PWSCTRL\_domain\_name MEMONSTATE bit during the last wake-up transition or during the last memory change operation.

This register must be cleared by software by writing any value to it; this operation must be done when the domain power state is on. Clearing this register does the following:

- Resets the PM\_PREPWSTST\_domain\_name LASTPOWERSTATEENTERED bit field and the PM\_PREPWSTST\_domain\_name LASTLOGICSTATEENTERED bit to the on state
- Sets the bit fields corresponding to the last memory state of the power domain to the current memory state

---

**NOTE:** Performing a memory change (the PM\_PWSCTRL\_domain\_name[3] MEMORYCHANGE bit for MPU, IVA2, and CORE) has the same effect as clearing this register.

---

## 3.6.5 Voltage Management Registers

### 3.6.5.1 External Voltage Control Register Descriptions

#### 3.6.5.1.1 PRM\_VOLTSETUP (Voltage Setup Time Register)

The device has two voltage setup registers:

- [PRM\\_VOLTSETUP1](#)
- [PRM\\_VOLTSETUP2](#)

These registers allow controlling the setup time of the VDD1 and VDD2 power supplies when the device exits the off mode or when the voltage is scaled. It is a constant value that depends on the connected power IC. At power-up reset, this register is not used, because the external power supply is already stable. After boot up, the software must set the correct value to ensure proper sequences when performing voltage scaling or sleep transitions.

The [PRM\\_VOLTSETUP1](#) register has the following bit fields:

- SETUPTIME1: The setup time of the VDD1 regulator. It is computed as  $8 \times \text{NbCycles}$  (number of cycles of the system clock), where NbCycles is configured in the register bit field.
- SETUPTIME2: The setup time of the VDD2 regulator. It is computed as  $8 \times \text{NbCycles}$  (number of cycles of the system clock), where NbCycles is configured in the register bit field.

The [PRM\\_VOLTSETUP1](#) register is used when the device exits the off mode and manages the sequencing of the voltage regulation steps (the [PRM\\_VOLTCTRL\[3\]](#) SEL\_OFF bit is set to 0).

The [PRM\\_VOLTSETUP2](#) register has the following bit field:

- OFFMODESETUPTIME: The number of 32-kHz clock cycles for the overall setup time of the power management IC when coming back from off mode.

The [PRM\\_VOLTSETUP2](#) register is used only when the device exits off mode and an external power IC manages the sequencing of the voltages regulation steps ([PRM\\_VOLTCTRL\[3\]](#) SEL\_OFF is set to 1).

Figure 3-88 shows off mode wakeup using I<sup>2</sup>C.

**Figure 3-88. Off Mode Wakeup Using I<sup>2</sup>C**



- (1) [PRM\\_VOLTSETUP1\[31:16\]](#) SETUPTIME2 and [PRM\\_VOLTSETUP1\[15:0\]](#) SETUPTIME1 are not used during voltage scaling (between different OPPs).

### 3.6.5.1.2 PRM\_VOLTOFFSET (Voltage Offset Register)

This register allows setting the offset time, which is the time duration between the assertion of sys\_clkreq and the deassertion of sys\_off\_mode when the device is exiting off mode. This time, set as a number of 32-kHz clock cycles, is used to delay the deassertion of sys\_off\_mode (and as a consequence, the voltage ramping) after the clock has been requested. This is done to avoid waiting for the clock to stabilize

when the voltage is already ramped and stabilized, which would induce some leakage. Program this bit field to match the following equation: **PRM\_VOLTOFFSET[15:0]OFFSET\_TIME = PRM\_CLKSETUP[15:0]SETUPTIME – PRM\_VOLTSETUP2[15:0]OFFMODESETUPTIME**. This way, the voltages and clock are ready at the same time. This register is used on device wakeup from off mode when the off sequence is supervised by the power IC.

The OFFSET\_TIME bit field of this register is configured as the number of 32-kHz clock cycles time delay in assertion of sys\_off\_mode. This register is used on device wakeup from off mode when the off sequence is supervised by the power IC.

Figure 3-89 shows off mode wakeup using SYS\_OFF\_MODE.

**Figure 3-89. OFF Mode Wakeup Using SYS\_OFF\_MODE**



(1) PRM\_CLKSETUP[15:0] SETUPTIME is not used during device cold boot-up sequence.

### 3.6.5.1.3 PRM\_VOLTCTRL (Voltage Source Control Register)

This register allows control of the power IC. The following are the register bit fields:

- **AUTO\_SLEEP**: Automatically sends the sleep command when the voltage domain is in the appropriate standby mode
- **AUTO\_RET**: Automatically sends the retention command when the voltage domain is in the appropriate standby mode
- **AUTO\_OFF**: Automatically sends the off command when the voltage domain is in the appropriate standby mode
- **SEL\_OFF**: Controls whether the off command is sent through the voltage controller I<sup>2</sup>C interface or the signal sys\_off\_mode is asserted when entering off mode
- **SEL\_VMODE**: Allows control of the power IC through either the voltage controller I<sup>2</sup>C interface or the VMODE interface

### 3.6.5.2 Voltage Controller Registers

A specific set of registers allows control of the voltage controller. This register set provides programming flexibility to address different power IC device types through an I<sup>2</sup>C interface.

The register set is composed of the following registers:

- Registers to store the addresses on the I<sup>2</sup>C bus:
  - **PRM\_VC\_SMPS\_SA**

- [PRM\\_VC\\_SMPS\\_VOL\\_RA](#)
- [PRM\\_VC\\_SMPS\\_CMD\\_RA](#)
- Registers to store the voltage values or voltage commands:
  - [PRM\\_VC\\_CMD\\_VAL\\_0](#)
  - [PRM\\_VC\\_CMD\\_VAL\\_1](#)
- Register to configure the VDD channel:
  - [PRM\\_VC\\_CH\\_CONF](#)
- Register to configure the I<sup>2</sup>C interface:
  - [PRM\\_VC\\_I2C\\_CFG](#)
- Register to use the bypass command:
  - [PRM\\_VC\\_BYPASS\\_VAL](#)

### **3.6.5.2.1 PRM\_VC\_SMPS\_SA (Voltage Controller SMPS Slave Address Register)**

This register stores the I<sup>2</sup>C slave address value of the power IC device. Two address values can be stored in case two different power IC chips are used to control the two VDD channels (VDD1 and VDD2).

### **3.6.5.2.2 PRM\_VC\_SMPS\_VOL\_RA (Voltage Controller SMPS Voltage Register Address Register)**

This register stores the address value of the voltage configuration registers in the power IC device. Two different register address values can be configured.

### **3.6.5.2.3 PRM\_VC\_SMPS\_CMD\_RA (Voltage Controller SMPS Command Register Address Register)**

This register stores the address value of the command configuration register in the power IC device. Two different register address values can be configured.

### **3.6.5.2.4 PRM\_VC\_CMD\_VAL\_0 and PRM\_VC\_CMD\_VAL\_1 (Voltage Controller Command and Voltage Value Register 0 and 1)**

The voltage controller can store two sets of voltage-level commands for each of the four power states (on, low power, retention, and off) for the power IC. The voltage commands depend on the power IC device used.

### **3.6.5.2.5 PRM\_VC\_CH\_CONF (Voltage Controller Channel Configuration Register)**

This register consists of a set of select bits for the VDD1 and VDD2 channels, the slave address, command register address, voltage register address, and voltage-level command settings for power modes (on/low power, on/retention/off). A pair of bit fields can be configured for each of these parameters. The [PRM\\_VC\\_CH\\_CONF](#) register allows the allocation of either of the two bit fields (for each of these parameters) to each voltage channel (VDD1 and VDD2). For example, when PRCM.[PRM\\_VC\\_CH\\_CONF\[0\]](#) SA0 = 0x1, the voltage controller allocates PRCM.[PRM\\_VC\\_SMPS\\_SA\[22:16\]](#) SA1 as the slave address for the VDD1 channel. When PRCM.[PRM\\_VC\\_CH\\_CONF\[0\]](#) SA0 = 0x0, the voltage controller allocates PRCM.[PRM\\_VC\\_SMPS\\_SA\[6:0\]](#) SA0 as the slave address for the VDD1 channel.

### **3.6.5.2.6 PRM\_VC\_I2C\_CFG (Voltage Controller I<sup>2</sup>C Interface Configuration Register)**

This register allows the setting of the I<sup>2</sup>C interface configuration parameters:

- Master code value when I<sup>2</sup>C interface is used in HS mode
- Enable and disable the HS mode
- Enable and disable the repeated start-operation mode
- Enable and disable the HSMASTER mode

### 3.6.5.2.7 PRM\_VC\_BYPASS\_VAL (*Voltage Controller Bypass Command Register*)

This register is used to address directly the power IC device through the I<sup>2</sup>C interface. It has the following bit fields:

- SLAVEADDR: Slave address value of the I<sup>2</sup>C interface of the power IC device (similar to [PRM\\_VC\\_SMPS\\_SA](#))
- REGADDR: Address of the command or voltage value register of the power IC device (similar to [PRM\\_VC\\_SMPS\\_VOL\\_RA](#) or [PRM\\_VC\\_SMPS\\_CMD\\_RA](#))
- DATA: Data to be written to the command or voltage value register
- VALID: Voltage command transaction enable and acknowledge bit

### 3.6.5.3 Voltage Processor Registers

Two identical sets of registers allow controlling both voltage processor modules.

The register sets are composed of the following registers:

- PRM\_VPn\_CONFIG: [PRM\\_VP1\\_CONFIG](#) and [PRM\\_VP2\\_CONFIG](#)
- PRM\_VPn\_VSTEPMIN: [PRM\\_VP1\\_VSTEPMIN](#) and [PRM\\_VP2\\_VSTEPMIN](#)
- PRM\_VPn\_VSTEPMAX: [PRM\\_VP1\\_VSTEPMAX](#) and [PRM\\_VP2\\_VSTEPMAX](#)
- PRM\_VPn\_VLIMITTO: [PRM\\_VP1\\_VLIMITTO](#) and [PRM\\_VP2\\_VLIMITTO](#)
- PRM\_VPn\_VOLTAGE: [PRM\\_VP1\\_VOLTAGE](#) and [PRM\\_VP2\\_VOLTAGE](#)
- PRM\_VPn\_STATUS: [PRM\\_VP1\\_STATUS](#) and [PRM\\_VP2\\_STATUS](#)

#### 3.6.5.3.1 PRM\_VP\_CONFIG (*Voltage Processor Configuration Register*)

This register allows the configuration of the voltage processor module. It controls the following features of the voltage processor:

- Enable/disable the voltage processor
- Force a voltage update into the power IC device
- Initialize the power IC device initial VDD value into the voltage processor
- Enable/disable the time-out capability of the voltage processor
- Set the power IC initial VDD value
- Set the error to voltage controller gain value
- Set the error to voltage controller error offset

The device has the following voltage processor configuration registers:

- [PRM\\_VP1\\_CONFIG](#)
- [PRM\\_VP2\\_CONFIG](#)

#### 3.6.5.3.2 PRM\_VP\_VSTEPMIN (*Voltage Processor Minimum Voltage Step*)

This register allows controlling the following features:

- The minimum value of a voltage step between two updates
- The slew rate for negative voltage step (in the number of cycles per step)

The device has the following voltage processor configuration registers:

- [PRM\\_VP1\\_VSTEPMIN](#)
- [PRM\\_VP2\\_VSTEPMIN](#)

#### 3.6.5.3.3 PRM\_VP\_VSTEPMAX (*Voltage Processor Maximum Voltage Step*)

This register allows setting the following:

- The maximum value of a voltage step between two updates
- The slew rate for positive voltage step (in the number of cycles per step)

The device has the following voltage processor configuration registers:

- [PRM\\_VP1\\_VSTEPMAX](#)
- [PRM\\_VP1\\_VSTEPMAX](#)

The voltage processor picks up the voltage step and the waiting time among the minimum and maximum values depending on the VDD returned by the error to the voltage controller.

#### **3.6.5.3.4 PRM\_VP\_VLIMITTO (Voltage Processor Voltage Limit and Time-Out)**

This register allows setting the following:

- The minimum allowed voltage value
- The maximum allowed voltage value
- The time-out value (in the number of clock cycles) to wait for an update

The device has the following voltage processor configuration registers:

- [PRM\\_VP1\\_VLIMITTO](#)
- [PRM\\_VP2\\_VLIMITTO](#)

#### **3.6.5.3.5 PRM\_VP\_VOLTAGE (Voltage Processor Voltage Register)**

The voltage register in the voltage processor indicates the current value of the power IC device voltage. This register is updated only when the voltage processor sends the update command to the voltage controller.

The device has the following voltage processor voltage registers:

- [PRM\\_VP1\\_VOLTAGE](#)
- [PRM\\_VP2\\_VOLTAGE](#)

#### **3.6.5.3.6 PRM\_VP\_STATUS (Voltage Processor Status Register)**

The status register in the voltage processor indicates whether the voltage processor is in idle mode. This information is useful before trying to reprogram the voltage processor. Unlike other voltage processor status events logged as a source of an interrupt on the MPU, the event logged in this register is not a cause of the interrupt.

The device has the following voltage processor status registers:

- [PRM\\_VP1\\_STATUS](#)
- [PRM\\_VP2\\_STATUS](#)

### **3.6.6 Generic Programming Examples**

#### **3.6.6.1 Clock Control**

The module clock management is controlled through three programmable steps:

- Enabling or disabling the functional clocks
- Enabling or disabling the interface clocks
- Enabling or disabling the automatic idle mode for the interface clocks

##### **3.6.6.1.1 Enabling and Disabling the Functional Clocks**

The flow chart in [Figure 3-90](#) shows how to enable or disable a functional clock.

The first step before enabling a functional clock is to select the proper source clock using the corresponding clock selection register (CM\_CLKSEL\_domain\_name). It can be either an external source clock or an internal clock; that is, sys\_altclk or DPLL4\_M3\_CLK for the DSS\_TV\_FCLK functional clock of the DSS.

If the source clock is a DPLL3 or DPLL4 output clock, the DPLL multiplier, divider, and output clock ratios are set in the CM\_CLKSELn\_PLL register, where n is from 1 to 3. The DPLL operating mode is set in the CM\_CLKEN\_PLL register.

The functional clock is enabled or disabled by writing the dedicated bit in the CM\_FCLKEN\_domain\_name register. This bit has a direct effect on the clock activity:

- The functional clock is turned on if the bit is enabled and the clock is not yet active.
- The functional clock is turned off if the bit is disabled and the clock is not required by any other module.

**Figure 3-90. Functional Clock Basic Programming Model**



\* Clock domain Idle conditions are:  
 a. No other module sharing the same clock domain needs the clock.  
 (All modules of the clock domain are idled)  
 b. No wake-up event.

prcm-085

The functional clock must be disabled before switching or scaling its source clock. This means that all the modules using the particular functional clock must not be active during clock switching. To switch a source clock, perform the following sequence:

1. Disable the functional clock by setting the CM\_FCLKEN\_power domainEN\_module bits to 0.
2. Modify the CM\_CLKSEL\_power domainCLKSEL\_clock bits to select the new clock source or clock divider.
3. Enable the functional clock by setting the CM\_FCLKEN\_power domainEN\_module bits to 1.

The timing diagram in [Figure 3-91](#) is a generic example of this sequencing for a functional clock (CLK1). The source clock can be switched between source clock 1 and source clock 2 using the CM\_CLKSEL\_DOM.CLKSEL\_CLK1 bit (source clock 1 is selected when the bit is set to 0; otherwise, source clock 2 is selected). CLK1 can be requested by two modules, M1 and M2. The CM\_FCLKEN\_DOM.EN\_M1 and CM\_FCLKEN\_DOM.EN\_M2 bits control the functional clock enable for the two modules.

**NOTE:** The activation or deactivation of the clock is implementation-dependent, not one cycle of the source clock, as shown in [Figure 3-91](#).

**Figure 3-91. Functional Clock Switching**



prcm-080

The following functional clocks require this switching sequence:

- sys\_clkout2
- 48M\_FCLK (and all gated versions of it)
- 12M\_FCLK (and all gated versions of it)
- DSS\_TV\_CLK
- GPTx\_FCLK (with  $x = 1, 10, \text{ and } 11$ )
- GPTx\_ALWON\_FCLK (with  $x = 2 \text{ up to } 9$ )

### 3.6.6.1.2 Enabling and Disabling the Interface Clocks

The flow chart in [Figure 3-92](#) shows the enable/disable sequence of the interface clock.

The first step before enabling an interface clock is to select the proper source clock using the corresponding clock selection register (CM\_CLKSEL\_domain). This register allows selection of the interconnect frequency (L3\_ICLK, L4\_ICLK) from among several divider ratios.

The interface clock is enabled or disabled by writing the dedicated bit in the CM\_ICLKEN\_domain register. This bit has a direct effect on the clock activity:

- The interface clock is turned on if the bit is enabled and the clock is not yet active.
- The interface clock is turned off if the bit is disabled and the clock is not required by any other module.

The interface clock can be automatically enabled or disabled by the PRCM module, based on hardware conditions. This automatic clock activity control mode is enabled by writing the corresponding bit in the CM\_AUTOIDLE\_domain register. It takes effect only if the interface clock is enabled (the corresponding bit in the CM\_ICLKEN\_domain is set to 1).

The hardware conditions for automatic gating (deactivation) of the clock are as follows:

- The module activity; that is, the module is inactive.
- The domain activity; that is, all modules in the domain are inactive.

The software can read the idle status register CM\_IDLESTAT\_domain at any time to know whether the module is accessible. A module is inaccessible if its idle status bit is set. Accessing an idle module generates an error (if the interface clock is still running) or a time-out (if the interface clock is cut).

**Figure 3-92. Interface Clock Basic Programming Model**


prcm-086

The frequency ratio between the CORE\_CLK, the L3\_ICLK, and the L4\_ICLK is configured by setting the corresponding [CM\\_CLKSEL\\_CORE](#) register bit fields. This configuration must be done before switching DPLL3 to lock mode. In this way, the clock ratio is switched while DPLL3 is operating at system clock frequency, and then only DPLL3 is switched to high-frequency locked mode.

If the configuration of the interface clock needs to be changed, first put DPLL3 in bypass mode, select the new configuration, and then relock DPLL3.

---

**NOTE:** When performing frequency scaling, the clock division can be done directly by programming the DPLL output divider. In this case, there is no need to change the configuration of the interface clock.

---

### 3.6.6.1.3 Enabling and Disabling the Inactive State

The flow chart in [Figure 3-93](#) shows how to put a domain into inactive state. This state is required before any power transition from on state to retention or off state.

A domain is said to be in inactive state if:

- All the functional and interface clocks of the domain are gated (deactivated).
- All the initiator modules are in standby mode.
- All the dependent domains have reached their mute state. The sleep dependency between the power domains is configured by programming the CM\_SLEEPDEP\_domain register.

The domain transition from active state to inactive state is effective only if the CM\_CLKSTCTRL\_domain register is programmed for hardware-supervised state transition.

The CM\_CLKSTST\_domain register identifies whether a power domain or a clock domain within the power domain is accessible. A domain is inaccessible if its corresponding bit in the CM\_CLKSTST\_domain register is set to 1.

**Figure 3-93. Domain Inactive STATE Basic Programming Model**



prcm-087

#### 3.6.6.1.4 Processor Clock Control

The flow chart in [Figure 3-94](#) shows the control sequence of the processor clock.

The processor source clock is generated by the dedicated processor DPLL (DPLL1 and DPLL2). After power up, the processor DPLL is in bypass or stop mode. This means the processor clock is either the system clock or is shut off.

The first step is to program the multiplier and divider ratios of the processor DPLL. Those two values are written in the CM\_CLKSEL1\_PLL\_processor register.

For frequency scaling, the processor DPLL integrates an additional divider to scale down the synthesized clock. The value of this second divider is written in the CM\_CLKSEL2\_PLL\_processor register. This divider can be configured dynamically (while the processor executes instructions), and the DPLL output clock is scaled without any glitches.

The processor DPLL must be locked at a desired frequency, provided the clock frequency is higher than the system clock. It can then be set to low-power bypass mode when the high-frequency clock is not required. The DPLL operating mode (locked or bypassed) is controlled by programming the CM\_CLKEN\_PLL\_processor register.

The processor clock can be switched automatically, based on hardware conditions, between the processor DPLL synthesized clock and a bypass clock. This mode is enabled by programming the corresponding mode in the CM\_AUTOIDLE\_PLL\_processor register. It takes effect only if the processor DPLL is locked (the CM\_CLKEN\_PLL\_processor register is set in lock mode).

The HS bypass clock for the processor DPLL can be:

- The DPLL3 output clock (CORE\_CLK)
- The DPLL3 output clock (CORE\_CLK) divided by 2

The HS bypass clock is selected by programming the CM\_CLKSEL1\_PLL\_processor register.

The software can read the CM\_IDLEST\_PLL\_processor register at any time to determine whether the DPLL is in lock mode (DPLL output is a high-frequency synthesized clock) or bypass mode (DPLL output is not the synthesized clock; the DPLL output is the bypass clock, or the DPLL is in transitioning state).

**Figure 3-94. Processor Clock Basic Programming Model**

prcm-088

### 3.6.6.2 Reset Management

The reset sequence is hardware-driven. On power on, once all the reset sources have been released, the PRM holds the entire device under reset long enough to ensure the stabilization of the power IC voltages and the oscillator system clock frequency. This reset delay is programmed in the [PRM\\_RSTTIME](#) register.

The IVA2.2 and the modem domain resets are held active after power up. They are released by writing to the corresponding bits in the [RM\\_RSTCTRL\\_domain](#) register.

A domain reset status register ([PRM\\_RSTST\\_domain](#)) identifies the source of the current reset applied to the domain. The software must clear this status bit after reset.

A global reset status register ([PRM\\_RSTST](#)) provides information about the global source of resets. All sources of warm reset are logged separately in this register, and all sources of cold reset are logged in a common status bit.

### 3.6.6.3 Wake-Up Control

The flow chart in [Figure 3-95](#) shows the control sequence of the module wake-up event.

This procedure consists of the following steps:

1. Program the PRCM module to consider the wake-up event.
2. Switch to idle mode and wait for the wake-up event.
3. Wake up on the wake-up event and activate the module functional clock.
4. Acknowledge the wake-up event.

The peripheral that can generate a wake-up event must be attached to a group of wake-up event generating modules for one or both processors by programming the [PM\\_processorGRPSEL](#) register. Writing 1 to this register allows the corresponding processor to be wakened on a peripheral wake-up event, assuming that the peripheral wake-up capability has been enabled by programming the register [PM\\_WKEN\\_domain](#).

After this is configured, the PRCM module initiates a wake-up procedure on receiving the peripheral wake-up event. The peripheral functional clock must be reenabled by programming the [CM\\_FCLKEN\\_domain](#) register, and then the wake-up event can be acknowledged by clearing the [PM\\_WKST\\_domain](#) register.

**Figure 3-95. Wake-up Basic Programming Model**

prcm-084

A power domain A can have a functional dependency on a power domain B. Thus, when power domain A wakes up, it may be necessary to wake up power domain B. This wake-up dependency is hardcoded for the CORE power domain, but is programmable for the other power domains through the PM\_WKDEP\_domain register.

### 3.6.6.4 SmartReflex Module Initialization Basic Programming Model

Figure 3-96 is a flow chart of the SmartReflex initialization.

**Figure 3-96. SmartReflex Initialization Flow Chart**


After the device power-on reset is complete, the SmartReflex module is disabled and its functional clock is gated.

### 1. Clock setting

Setting the clock consists of configuring the internal clock frequency of the SmartReflex module and the state of the functional clock when the module switches to inactive state, and then enabling the functional clock from the PRCM module of the device.

The internal clock frequency configuration depends on the frequency of SR\_ALWON\_FCLK and can be calculated from [Equation 2](#). For example, if SR\_ALWON\_FCLK has a frequency of 38.4 MHz, and the target SR\_CLK frequency is 100 kHz, SRCLKLENGTH is set to 192 (0x0C0).

|                                                     |     |                                            |
|-----------------------------------------------------|-----|--------------------------------------------|
| SRn. <a href="#">SRCONFIG[21:12]</a><br>SRCLKLENGTH |     | Calculated from <a href="#">Equation 1</a> |
| PRCM. <a href="#">CM_FCLKEN_WKUP[6]</a><br>EN_SR1   | 0x1 | SR1 functional clock enable                |
| PRCM. <a href="#">CM_FCLKEN_WKUP[7]</a><br>EN_SR2   | 0x1 | SR2 functional clock enable                |

## 2. Sensor core setting

Setting the sensor core consists of configuring the sensor core parameters and enabling the sensor core. The sensor core parameters are obtained by reading the CONTROL.CONTROL\_FUSE OPP\_4[23:16] and CONTROL.CONTROL\_FUSE OPP\_4[31:24] bit fields.

|                                               |     |                                                                    |
|-----------------------------------------------|-----|--------------------------------------------------------------------|
| SRn. <a href="#">SRCONFIG[1]</a> SENNENABLE   |     | Configured according to the values read for the SCM register.      |
| SRn. <a href="#">SRCONFIG[4:3]</a> SENPENABLE |     | See <a href="#">Section 3.5.6.5.4.5, Parameter Configuration</a> . |
| SRn. <a href="#">SRCONFIG[10]</a> SENNENABLE  | 0x1 | Enable the sensor module.                                          |

## 3. Accumulator and minimum/maximum/average setting

The accumulator setting consists of setting the size of the accumulator. The minimum/maximum/average setting consists of setting the average weight parameter for the A and B sensors, and then enabling the minimum/maximum/average block. The accumulator size is calculated using [Equation 1](#).

For example, if the SR\_CLK has a frequency of 100 kHz, and the accumulator time window is 5 ms, ACCUMDATA is set to 500 (0x1F4).

|                                                   |     |                                            |
|---------------------------------------------------|-----|--------------------------------------------|
| SRn. <a href="#">SRCONFIG[31:22]</a> ACCUMDATA    |     | Calculated from <a href="#">Equation 2</a> |
| SRn. <a href="#">AVGWEIGHT[1:0]</a> SENNAVGWEIGHT |     | Provided after silicon characterization    |
| SRn. <a href="#">AVGWEIGHT[3:2]</a> SENPAVGWEIGHT |     |                                            |
| SRn. <a href="#">SRCONFIG[8]</a> MINMAXAVGENABLE  | 0x1 | Enable minimum/maximum/average.            |

## 4. Error generator setting

The error generator setting consists of setting the four reference value parameters according the current OPP, and then enabling the error generator.

|                                                       |     |                                                                                                       |
|-------------------------------------------------------|-----|-------------------------------------------------------------------------------------------------------|
| SRn. <a href="#">NVALUERECIPROCAL[23:20]</a> SENPGAIN |     | Configured according to the values read for the current operating voltage level from the SCM register |
| SRn. <a href="#">NVALUERECIPROCAL[19:16]</a> SENNGAIN |     | See <a href="#">Section 3.5.6.5.4.5, Parameter Configuration</a> .                                    |
| SRn. <a href="#">NVALUERECIPROCAL[15:8]</a> RNSENP    |     |                                                                                                       |
| SRn. <a href="#">NVALUERECIPROCAL[7:0]</a> RNSENN     |     |                                                                                                       |
| SRn. <a href="#">SRCONFIG[9]</a> ERRORGENERATORENABLE | 0x1 | Enable the error generator.                                                                           |

## 5. Interrupt generator setting

The interrupt generator setting consists of setting the error weight and the minimum/maximum error limits. Then, depending on operational requirements for hardware and software voltage control, the voltage processor interrupts are configured.

With software voltage control, the voltage processor interrupt remains disabled and only the MPU interrupts are enabled.

With automatic hardware voltage control, the voltage processor interrupt is enabled. The MPU interrupts can also be enabled to monitor the SmartReflex module behavior.

For details about the interrupts, see [Table 3-85](#).

|                                                      |     |                                         |
|------------------------------------------------------|-----|-----------------------------------------|
| SRn. <a href="#">ERRCONFIG[18:16]</a> ERRWEIGHT      |     | Provided after silicon characterization |
| SRn. <a href="#">ERRCONFIG[15:8]</a> ERRMAXLIMIT     |     |                                         |
| SRn. <a href="#">ERRCONFIG[7:0]</a> ERRMINLIMIT      |     |                                         |
| SRn. <a href="#">ERRCONFIG[22]</a> VPBOUNDSINTENABLE | 0x1 | Enable the VP bounds interrupt.         |

|                                                           |     |                                       |
|-----------------------------------------------------------|-----|---------------------------------------|
| SRn. <a href="#">IRQENABLE_SET[3]</a> MCUACCUMINTENASET   | 0x1 | Enable the MCU accumulator interrupt. |
| SRn. <a href="#">IRQENABLE_SET[2]</a> MCUVALIDINTENASET   | 0x1 | Enable the MCU valid interrupt.       |
| SRn. <a href="#">IRQENABLE_SET[1]</a> MCUBOUNDSINTSTATENA | 0x1 | Enable the MCU bounds interrupt.      |

## 6. Enable the module

In the final phase of configuration, the SmartReflex module is enabled. When the module is enabled, the sensors generate values and the error generator is active. The module can generate the interrupt when the enabled interrupt conditions occur.

|                                           |     |                                |
|-------------------------------------------|-----|--------------------------------|
| SRn. <a href="#">SRCRCONFIG[11]</a> SR_EN | 0x1 | Enable the SmartReflex module. |
|-------------------------------------------|-----|--------------------------------|

---

**NOTE:** Each time the device configuration is changed (for instance, the OPP is switched) after this initial configuration phase completes, the module must be disabled.

---

### 3.6.6.5 Voltage Processor Initialization Basic Programming Model

[Figure 3-97](#) is a flow chart of the voltage processor initialization.

**Figure 3-97. Voltage Processor Initialization Flow Chart**

prcm-UC-007

1. Error-to-voltage converter setting

The error-to-voltage converter setting consists of configuring the error offset, error gain, minimum and maximum step size, and the minimum and maximum voltage limits, depending on the characteristics of the SMPS. The default voltage level of the SMPS, after boot up, must also be configured.

---

**NOTE:** For the characteristics of the SMPS, see the power IC device performance addendum.

---

|                                        |  |                                            |
|----------------------------------------|--|--------------------------------------------|
| PRCM.PRM_VPn_CONFIG[31:24] ERROROFFSET |  | Depend on the characteristics of the SMPS. |
| PRCM.PRM_VPn_CONFIG[13:16] ERRORGAIN   |  |                                            |
| PRCM.PRM_VPn_VSTEPMIN[7:0] VSTEPMIN    |  |                                            |
| PRCM.PRM_VPn_VSTEPMAX[7:0] VSTEPMAX    |  |                                            |

## 2. FSM register setting

The FSM register settings consist of setting the time-out delay for the acknowledge return from SMPS, the initial voltage level of the SMPS and asserting it in the FSM, and setting the slew rate for the positive and negative voltage steps of the SMPS.

The time-out delay ensures that the voltage processor is not blocked if there is no command acknowledge by the SMPS.

---

**NOTE:**

- When an initial voltage is configured and asserted to the FSM, it is added to the SMPS voltage register in the voltage processor, but it is not sent as a command to the SMPS.
  - The slew rates programmed into the voltage processor depend on the characteristics of the SMPS.
- 

|                                             |     |                                                                          |
|---------------------------------------------|-----|--------------------------------------------------------------------------|
| PRCM.PRM_VPn_VLIMITTO[15:0] TIMEOUT         |     | Maximum amount of time to wait for the command acknowledge from the SMPS |
| PRCM.PRM_VPn_CONFIG[15:8] INITVOLTAGE       |     | Initial voltage level of the SMPS                                        |
| PRCM.PRM_VPn_CONFIG[2] INITVDD              | 0x1 | Assert the initial voltage into the voltage processor FSM.               |
| PRCM.PRM_VPn_VSTEPMIN[23:8] SMPSWAITTIMEMIN |     | Slew rate of the negative voltage step of the SMPS                       |
| PRCM.PRM_VPn_VSTEPMAX[23:8] SMPSWAITTIMEMAX |     | Slew rate of the positive voltage step of the SMPS                       |

## 3. Enable interrupts

The interrupt generator setting consists of setting the error weight and the minimum/maximum error limits. Then depending on operational requirements for hardware or software voltage control, the voltage processor interrupts are configured.

With software voltage control, the voltage processor interrupt remains disabled and only the MPU interrupts are enabled.

With automatic hardware voltage control, the voltage processor interrupt is enabled. The MPU interrupts can also be enabled to monitor the SmartReflex module behavior.

For details about the interrupts, see [Table 3-85](#).

|                                             |   |                                                                                                                   |
|---------------------------------------------|---|-------------------------------------------------------------------------------------------------------------------|
| PRCM.PRM_IRQENABLE_MPU[21] VP2_TRANXDONE_EN | - | 0x0: Mask the VP2 transaction-done interrupt.<br>(Default)<br><br>0x1: Unmask the VP2 transaction-done interrupt. |
| PRCM.PRM_IRQENABLE_MPU[15] VP1_TRANXDONE_EN | - | 0x0: Mask the VP1 transaction-done interrupt.<br>(Default)<br><br>0x1: Unmask the VP1 transaction-done interrupt. |
| PRCM.PRM_IRQENABLE_MPU[20] VP2_EQVALUE_EN   | - | 0x0: Mask the VP2 equal-value interrupt. (Default)<br><br>0x1: Unmask the VP2 equal-value interrupt.              |
| PRCM.PRM_IRQENABLE_MPU[14] VP1_EQVALUE_EN   | - | 0x0: Mask the VP1 equal-value interrupt. (Default)                                                                |

|                                                    |   |                                                                                                                  |
|----------------------------------------------------|---|------------------------------------------------------------------------------------------------------------------|
| PRCM.PRM_IRQENABLE_MPU[19] VP2_NOSMPSACK_EN        | - | 0x1: Unmask the VP1 equal-value interrupt.<br>0x0: Mask the VP2 no-SMPS acknowledge. (Default)                   |
| PRCM.PRM_IRQENABLE_MPU[13] VP1_NOSMPSACK_EN        | - | 0x0: Mask the VP1 no-SMPS acknowledge interrupt. (Default)<br>0x1: Unmask the VP1 no-SMPS acknowledge interrupt. |
| PRCM.PRM_IRQENABLE_MPU[18] VP2_MAXVDD_EN           | - | 0x0: Mask the VP2 maximum-VDD interrupt. (Default)<br>0x1: Unmask the VP2 maximum-VDD interrupt.                 |
| PRCM.PRM_IRQENABLE_MPU[12] VP1_MAXVDD_EN           | - | 0x0: Mask the VP1 maximum-VDD interrupt. (Default)<br>0x1: Unmask the VP1 maximum-VDD interrupt.                 |
| PRCM.PRM_IRQENABLE_MPU[17] VP2_MINVDD_EN           | - | 0x0: Mask the VP2 minimum-VDD interrupt. (Default)<br>0x1: Unmask the VP2 minimum-VDD interrupt.                 |
| PRCM.PRM_IRQENABLE_MPU[11] VP1_MINVDD_EN           | - | 0x0: Mask the VP1 minimum-VDD interrupt. (Default)<br>0x1: Unmask the VP1 minimum-VDD interrupt.                 |
| PRCM.PRM_IRQENABLE_MPU[16]<br>VP2_OPPCHANGEDONE_EN | - | 0x0: Mask the VP2 OPP change-done interrupt. (Default)<br>0x1: Unmask the VP2 OPP change-done interrupt.         |
| PRCM.PRM_IRQENABLE_MPU[10] VP1_OPPCHANGEDONE_EN    | - | 0x0: Mask the VP1 OPP change-done interrupt. (Default)<br>0x1: Unmask the VP1 OPP change-done interrupt.         |

#### 4. Enable the module

In the final phase of configuration, the voltage-processor module is enabled. Once the module is enabled, any interrupt from the SmartReflex module triggers the module FSM. The voltage processor reads the frequency error and converts it to the corresponding voltage command for the SMPS. It then waits for a command acknowledge from the SMPS before clearing the SmartReflex interrupt.

|                                    |     |                                      |
|------------------------------------|-----|--------------------------------------|
| PRCM.PRM_VPn_CONFIG[0]<br>VPENABLE | 0x1 | Enable the voltage processor module. |
|------------------------------------|-----|--------------------------------------|

### 3.6.6.6 Voltage Controller Initialization Basic Programming Model

Figure 3-98 is the flow chart for voltage controller initialization.

**Figure 3-98. Voltage Controller Initialization Flow Chart**



1. Assign power IC slave addresses.

To support the I<sup>2</sup>C communication with external power ICs, the slave address of the power ICs must be configured in the voltage controller registers. The voltage controller can support two slave addresses to control VDD1 and VDD2 independently, from two different power ICs. At least one valid slave address is required to communicate with a power IC.

---

**NOTE:** The slave address for the following depends on the configured slave address of the power IC:

- PRCM.PRM\_VC\_SMPS\_SA[6:0] SA0
  - PRCM.PRM\_VC\_SMPS\_SA[22:16] SA1
- 

## 2. Set voltage configuration register addresses.

The addresses of the voltage configuration registers of the power ICs are set in the corresponding bit fields. The voltage controller can support addresses of two different voltage configuration registers (belonging to same or different power ICs).

|                                       |  |                                                           |
|---------------------------------------|--|-----------------------------------------------------------|
| PRCM.PRM_VC_SMPS_VOL_RA[7:0] VOLRA0   |  | Depend on the characteristics of the connected power ICs. |
| PRCM.PRM_VC_SMPS_VOL_RA[23:16] VOLRA1 |  |                                                           |

## 3. Set command configuration register addresses.

The addresses of the command configuration registers of the power ICs are set in the corresponding bit fields. The voltage controller can support addresses of two different command configuration registers (belonging to same or different power ICs).

|                                       |  |                                                           |
|---------------------------------------|--|-----------------------------------------------------------|
| PRCM.PRM_VC_SMPS_CMD_RA[7:0] CMDRA0   |  | Depend on the characteristics of the connected power ICs. |
| PRCM.PRM_VC_SMPS_CMD_RA[23:16] CMDRA1 |  |                                                           |

## 4. Set configuration pointers for the VDD channels.

The configuration pointers allow the selection of one of four configurations for each voltage channel (VDD1 and VDD2):

- Two slave I<sup>2</sup>C interfaces (slave address)
- Two voltage configuration registers
- Two command configuration registers
- Two power-mode voltage levels

|                                |  |                                                                                                          |
|--------------------------------|--|----------------------------------------------------------------------------------------------------------|
| PRCM.PRM_VC_CH_CONF[16] SA1    |  | Slave address pointer (SA1 for VDD2, and SA0 for VDD1)                                                   |
| PRCM.PRM_VC_CH_CONF[0] SA0     |  |                                                                                                          |
| PRCM.PRM_VC_CH_CONF[17] RAV1   |  | Voltage configuration register address pointer (RAV1 for VDD2, and RAV0 for VDD1)                        |
| PRCM.PRM_VC_CH_CONF[1] RAV0    |  |                                                                                                          |
| PRCM.PRM_VC_CH_CONF[18] RAC1   |  | Command configuration register address pointer (RAC1 for VDD2, and RAC0 for VDD1)                        |
| PRCM.PRM_VC_CH_CONF[2] RAC0    |  |                                                                                                          |
| PRCM.PRM_VC_CH_CONF[19] RACEN1 |  | Select voltage or command configuration register for FSM commands (RACEN1 for VDD2, and RACEN0 for VDD1) |
| PRCM.PRM_VC_CH_CONF[3] RACEN0  |  |                                                                                                          |
| PRCM.PRM_VC_CH_CONF[20] CMD1   |  | Command voltage level selection pointer (CMD1 for VDD2, and CMD0 for VDD1)                               |
| PRCM.PRM_VC_CH_CONF[4] CMD0    |  |                                                                                                          |

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

At power-on reset, the I<sup>2</sup>C4 is in HS mode. In HS mode, a master code value must be configured for the preamble I<sup>2</sup>C HS transmission. If the external power ICs do not support I<sup>2</sup>C HS mode, the interface can be switched to fast/standard (F/S) mode. By default, a repeated-start operation for communication is enabled. If necessary, it can be disabled.

For more information, see [Chapter 17, I<sup>2</sup>C](#).

|                                |     |                                              |
|--------------------------------|-----|----------------------------------------------|
| PRCM.PRM_VC_I2C_CFG[2:0] MCODE |     | Master code for I <sup>2</sup> C HS preamble |
| PRCM.PRM_VC_I2C_CFG[3] HSEN    | 0x0 | Switch to F/S mode.                          |
| PRCM.PRM_VC_I2C_CFG[4] SREN    | 0x0 | Disable repeated start operation.            |

### 3.6.6.7 Changing OPP Using the SmartReflex Module

Figure 3-99 is a flow chart of the OPP change.

**Figure 3-99. SmartReflex - OPP Change Flow Chart**



When switching from OPP<sub>x</sub> to OPP<sub>y</sub> so the clock frequency at OPP<sub>x</sub> is higher than the clock frequency at OPP<sub>y</sub>, the DPLL is first switched to the lower frequency of OPP<sub>y</sub> and only voltage scaling is initiated (see [Figure 3-99a](#)). However, if the clock frequency of OPP<sub>x</sub> is less than the frequency of OPP<sub>y</sub>, voltage scaling is initiated before the frequency scaling (see [Figure 3-99b](#)).

OPP voltage switching complete is detected by the OPPCHANGEDONE interrupt from the voltage processor to the MPU. For this, the corresponding MPU interrupt must be unmasked.

---

**NOTE:** In the following steps, VP<sub>n</sub> refers to VP1 if VDD1 OPP is changed, and to VP2 if VDD2 OPP is changed.

---

1. Disable the modules.

To configure the parameters of the SmartReflex module, both the SmartReflex and voltage processor modules are disabled. This ensures that no voltage command is passed to the SMPS while the OPP change is being configured.

|                                              |     |                                       |
|----------------------------------------------|-----|---------------------------------------|
| SRn. <a href="#">SRCONFIG[11]</a> SR_EN      | 0x0 | Disable the SmartReflex module.       |
| PRCM.PRM_VP <sub>n</sub> _CONFIG[0] VPENABLE | 0x0 | Disable the voltage processor module. |

2. Configure settings for OPP<sub>y</sub>.

Setting the error generator consists of setting its parameters according to the target OPP, and then enabling the error-generator block. These values are configured according to the target operating performance point of the device.

|                                                       |     |                                                                          |
|-------------------------------------------------------|-----|--------------------------------------------------------------------------|
| SRn. <a href="#">NVALUERECIPROCAL[23:20]</a> SENPGAIN |     | Configured according to the current OPP values read for the SCM register |
| SRn. <a href="#">NVALUERECIPROCAL[19:16]</a> SENNGAIN |     | See <a href="#">Section 3.5.6.5.4.5, Parameter Configuration</a> .       |
| SRn. <a href="#">NVALUERECIPROCAL[15:8]</a> RNSENP    |     |                                                                          |
| SRn. <a href="#">NVALUERECIPROCAL[7:0]</a> RNSENN     |     |                                                                          |
| SRn. <a href="#">SRCONFIG[9]</a> ERRORGENERATORENABLE | 0x1 | Enable the error generator.                                              |

3. Set SmartReflex and voltage processor interrupts.

To automatically adjust the voltage from OPP<sub>x</sub> level to OPP<sub>y</sub> level, the voltage processor interrupt from the SmartReflex module to the voltage processor module must be unmasked. Similarly, to detect completion of the switch to OPP<sub>y</sub>, the OPP change-done interrupt from the voltage processor to the MPU must be unmasked.

This is especially important when switching to a higher-frequency operating point, because the voltage must be stable before the frequency is switched.

The remaining SmartReflex and voltage processor interrupts can be masked.

SmartReflex interrupt setting:

|                                                      |     |                                 |
|------------------------------------------------------|-----|---------------------------------|
| SRn. <a href="#">ERRCONFIG[22]</a> VPBOUNDSINTENABLE | 0x1 | Enable the VP bounds interrupt. |
|------------------------------------------------------|-----|---------------------------------|

Voltage processor interrupt setting:

|                                                            |     |                                                       |
|------------------------------------------------------------|-----|-------------------------------------------------------|
| PRCM.PRM_IRQENABLE_MPU<br>VP <sub>n</sub> _OPPCANGEDONE_EN | 0x1 | Enable the VP <sub>n</sub> OPP change-done interrupt. |
|------------------------------------------------------------|-----|-------------------------------------------------------|

---

**NOTE:** After reset, all interrupts are masked.

---

4. Enable the modules.

The voltage processor is enabled first, and then the SmartReflex module is enabled. The SmartReflex module counters start counting the pulses, and the error-generator logic is active. The module generates the error to the voltage processor module to send the voltage command to SMPS. The voltage is thus adjusted according to OPP<sub>y</sub>.

|                                 |     |                                      |
|---------------------------------|-----|--------------------------------------|
| PRCM.PRM_VPn_CONFIG[0] VPENABLE | 0x1 | Enable the voltage processor module. |
| SRn.SRCNFIG[11] SR_EN           | 0x1 | Enable the SmartReflex module.       |

5. OPPy voltage switch is done.

The voltage processor sends an interrupt to the MPU when the interrupt condition is satisfied (the voltage change from OPPx to OPPy is complete). The interrupt status bit can be read to validate the interrupt, and then cleared by writing 0x1 to it.

|                                              |      |                                                          |
|----------------------------------------------|------|----------------------------------------------------------|
| PRCM.PRM_IRQSTATUS_MPU VPn_ OPPCHANGEDONE_ST | Read | On read, if this bit is 0x1, the OPP change is complete. |
| PRCM.PRM_IRQSTATUS_MPU VPn_ OPPCHANGEDONE_ST | 0x1  | Writing 0x1 clears the interrupt status bit.             |

### 3.6.6.8 Changing OPP Using Only the Voltage Processor Module

The device OPP change for the VDD1 or VDD2 voltage domains can also be handled through an alternate method of using only the voltage processor module. In this case, the SmartReflex module is disabled and the voltage processor is configured to initiate the OPP transition. [Figure 3-100](#) is the flow chart of the OPP change.

**Figure 3-100. Voltage Processor - OPP Change Flow Chart**


When switching from the current OPP to a target OPP, if the clock frequency of the target OPP is less than that of current OPP, the DPLL is first switched to the lower frequency of target OPP, and only then the voltage scaling is initiated. However, if the clock frequency of the target OPP is greater than that of current OPP, voltage scaling is initiated before frequency scaling (see [Figure 3-100](#)).

OPP voltage-switching-complete is detected by the OPPCHANGEDONE interrupt from the voltage processor to the MPU. For this, the corresponding MPU interrupt must be unmasked.

---

**NOTE:** In the following steps, VP<sub>n</sub> refers to VP1 if VDD1 OPP is changed, and to VP2 if VDD2 OPP is changed.

---

1. Disable the modules.

To configure the parameters of the voltage processor module, both the SmartReflex and the voltage processor modules are disabled. This ensures that no voltage command is passed to the SMPS while the OPP change is being configured.

|                                 |     |                                       |
|---------------------------------|-----|---------------------------------------|
| PRCM.PRM_VPn_CONFIG[0] VPENABLE | 0x0 | Disable the voltage processor module. |
| SRn.SRCONFIG[11] SR_EN          | 0x0 | Disable the SmartReflex module.       |

## 2. Force SMPS voltage update.

The voltage processor INITVDD bit is set so that the initial voltage in the voltage processor module is set according to the target OPP (OPPy). Before asserting the force update command, the voltage processor must be in idle mode. The SMPS is force-updated to switch from OPPx to OPPy by asserting the FORCEUPDATE bit of the voltage processor.

---

**NOTE:** The SmartReflex and voltage processor interrupts are masked.

---

|                                    |     |                                                                                     |
|------------------------------------|-----|-------------------------------------------------------------------------------------|
| PRCM.PRM_VPn_CONFIG[0] INITVOLTAGE |     | Configured according to the target OPP voltage value.                               |
| PRCM.PRM_VPn_CONFIG[15:8] INITVDD  | 0x1 | Triggers a write of the value in the INITVOLTAGE bit field in the voltage processor |
| PRCM.PRM_VPn_CONFIG[1] FORCEUPDATE | 0x1 | Force update of the SMPS.                                                           |

---

**NOTE:** To support OPP50, the DPLL2 and DPLL1 bypass clocks must be set properly. The DPLL1 bypass clock must always be set to CORE\_CLK/2. The DPLL2 bypass clock must always be set to CORE\_CLK/2. For more information, see [Section 3.5.3.8.2, Interface and Peripheral Functional Clock Configurations](#)

---

### 3.6.6.9 Event Generator Programming Examples

The event generator feature allows the MPU power domain to be switched between on and off (or placed in idled mode). This is intended to implement an efficient activity modulation of the MPU power state with minimum software support.

When the event generator is activated, the PRCM module ensures that the CORE power domain always follows the MPU power domain activity.

The PRCM.PM\_EVGENONTIM\_MPU and PRCM.PM\_EVGENOFFTIM\_MPU registers of the event generator counter allow the configuration of the on and off durations (the number of system clock cycles) for the MPU power domain. The PRCM.PM\_EVGENCTRL\_MPU register allows the enabling/disabling of the event generator feature and control of the way on and off values are loaded in the counter.

There are three ways to load the counter with the next counting value:

- Load on update of the corresponding PRCM.PM\_EVGENONTIM\_MPU or PRCM.PM\_EVGENOFFTIM\_MPU register.
- Load the on-time value when the MPU power domain wakes up, and the off-time value when the MPU power domain starts the sleep transition (the MPU executes the WFI instruction).
- Automatically load the on-time value when the off-time value expires, and automatically load the off-time value when the on-time value expires.

When the counter times out at the end of the on/off time, it triggers the interrupt/wake-up transition, respectively. The software can use the on-time interrupt to trigger the WFI processor instruction to idle the processor clock. Similarly, the wake-up event at the end of the off time restarts the processor clock and interrupts the processor. To enable the corresponding interrupts, the MPU interrupts mask must be set in the PRCM.PRM\_IRQENABLE\_MPU register.

### **3.7 PRCM Register Manual**

This section gives information about all modules and features in the high-tier device. For power-management saving consideration, ensure that power domains of unavailable features and modules are switched off and clocks are cut off.

[Table 3-92](#) lists the Instance Summary of the CM modules. [Table 3-93](#) through [Table 3-291](#) provide register mapping summaries of the CM registers and describe the bits in the individual registers.

[Table 3-293](#) lists the Instance Summary of the PRM modules. [Table 3-294](#) through [Table 3-532](#) provide register mapping summaries of the PRM registers and describe the bits in the individual registers.

#### **3.7.1 CM Module Registers**

##### **3.7.1.1 CM Instance Summary**

**Table 3-92. CM Instance Summary**

| Module Name          | Base Address (hex) | Size       |
|----------------------|--------------------|------------|
| IVA2_CM              | 0x4800 4000        | 8192 bytes |
| OCP_System_Reg_CM    | 0x4800 4800        | 8192 bytes |
| MPU_CM               | 0x4800 4900        | 8192 bytes |
| CORE_CM              | 0x4800 4A00        | 8192 bytes |
| SGX_CM               | 0x4800 4B00        | 8192 bytes |
| WKUP_CM              | 0x4800 4C00        | 8192 bytes |
| Clock_Control_Reg_CM | 0x4800 4D00        | 8192 bytes |
| DSS_CM               | 0x4800 4E00        | 8192 bytes |
| CAM_CM               | 0x4800 4F00        | 8192 bytes |
| PER_CM               | 0x4800 5000        | 8192 bytes |
| EMU_CM               | 0x4800 5100        | 8192 bytes |
| Global_Reg_CM        | 0x4800 5200        | 8192 bytes |
| NEON_CM              | 0x4800 5300        | 8192 bytes |
| USBHOST_CM           | 0x4800 5400        | 8192 bytes |

##### **3.7.1.2 IVA2\_CM Registers**

###### **3.7.1.2.1 IVA2\_CM Register Summary**

**Table 3-93. IVA2\_CM Register Summary**

| Register Name                        | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|--------------------------------------|------|-----------------------|----------------|------------------|------------|
| <a href="#">CM_FCLKEN_IVA2</a>       | RW   | 32                    | 0x0000 0000    | 0x4800 4000      | W          |
| <a href="#">CM_CLKEN_PLL_IVA2</a>    | RW   | 32                    | 0x0000 0004    | 0x4800 4004      | W          |
| <a href="#">CM_IDLEST_IVA2</a>       | R    | 32                    | 0x0000 0020    | 0x4800 4020      | C          |
| <a href="#">CM_IDLEST_PLL_IVA2</a>   | R    | 32                    | 0x0000 0024    | 0x4800 4024      | C          |
| <a href="#">CM_AUTOIDLE_PLL_IVA2</a> | RW   | 32                    | 0x0000 0034    | 0x4800 4034      | W          |
| <a href="#">CM_CLKSEL1_PLL_IVA2</a>  | RW   | 32                    | 0x0000 0040    | 0x4800 4040      | W          |
| <a href="#">CM_CLKSEL2_PLL_IVA2</a>  | RW   | 32                    | 0x0000 0044    | 0x4800 4044      | W          |
| <a href="#">CM_CLKSTCTRL_IVA2</a>    | RW   | 32                    | 0x0000 0048    | 0x4800 4048      | W          |
| <a href="#">CM_CLKSTST_IVA2</a>      | R    | 32                    | 0x0000 004C    | 0x4800 404C      | C          |

### 3.7.1.2.2 IVA2\_CM Registers

**Table 3-94. CM\_FCLKEN\_IVA2**

|                       |                                                                   |                         |             |                 |         |
|-----------------------|-------------------------------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 0000                                                       | <b>Physical Address</b> | 0x4800 4000 | <b>Instance</b> | IVA2_CM |
| <b>Description</b>    | This register controls the IVA2 domain functional clock activity. |                         |             |                 |         |
| <b>Type</b>           | RW                                                                |                         |             |                 |         |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |         |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---------|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | EN_IVA2 |   |   |

| Bits | Field Name | Description                                                                            | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                     | R    | 0x00000000 |
| 0    | EN_IVA2    | IVA2 functional clock control<br>0x0: IVA2_CLK is disabled<br>0x1: IVA2_CLK is enabled | RW   | 0x0        |

**Table 3-95. Register Call Summary for Register CM\_FCLKEN\_IVA2**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [IVA2\\_CM Registers: \[1\]](#)

**Table 3-96. CM\_CLKEN\_PLL\_IVA2**

|                       |                                             |                         |             |                 |         |
|-----------------------|---------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 0004                                 | <b>Physical Address</b> | 0x4800 4004 | <b>Instance</b> | IVA2_CM |
| <b>Description</b>    | This register controls the IVA2 DPLL modes. |                         |             |                 |         |
| <b>Type</b>           | RW                                          |                         |             |                 |         |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|--------------|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | EN_IVA2_DPLL |   |   |

| Bits  | Field Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset     |
|-------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:11 | RESERVED                | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                    | R    | 0x0000000 |
| 10    | EN_IVA2_DPLL_LPMODE     | This bit allows to enable or disable the LP mode of the IVA2 DPLL. Writing this bit to switch the mode between LP or normal mode will take effect only when the DPLL will have transition into the bypass or stop state, followed by a lock or re-lock of the DPLL.<br><br>0x0: Disables the DPLL LP mode to re-enter the normal mode at the following lock or re-lock sequence.<br><br>0x1: Enables the DPLL LP mode to enter the LP mode at the following lock or re-lock sequence. | RW   | 0x0       |
| 9:8   | RESERVED                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x0       |
| 7:4   | RESERVED                | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW   | 0x1       |
| 3     | EN_IVA2_DPLL_DRIFTGUARD | This bit allows to enable or disable the automatic recalibration feature of the IVA2 DPLL. The IVA2 DPLL will automatically start a recalibration process upon assertion of the recal flag if this bit is set.<br><br>0x0: Disables the IVA2 DPLL automatic recalibration mode<br><br>0x1: Enables the IVA2 DPLL automatic recalibration mode                                                                                                                                         | RW   | 0x0       |
| 2:0   | EN_IVA2_DPLL            | IVA2 DPLL control; Other enums: Reserved<br><br>0x1: Put the IVA2 DPLL in low power stop mode<br><br>0x5: Put the IVA2 DPLL in low power bypass mode<br><br>0x7: Enables the IVA2 DPLL in lock mode                                                                                                                                                                                                                                                                                   | RW   | 0x1       |

**Table 3-97. Register Call Summary for Register CM\_CLKEN\_PLL\_IVA2**

## PRCM Functional Description

- [DPLL Control: \[0\]](#) [\[1\]](#) [\[2\]](#)
- [Internal Clock Controls: \[3\]](#)

## PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[4\]](#)

## PRCM Register Manual

- [IVA2\\_CM Registers: \[5\]](#)

**Table 3-98. CM\_IDLEST\_IVA2**

|                         |                                                                                                               |                 |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------|-----------------|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0020                                                                                                   |                 |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 4020                                                                                                   | <b>Instance</b> | IVA2_CM |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| <b>Description</b>      | IVA2 standby status and access availability monitoring. This register is read only and automatically updated. |                 |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                             |                 |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |
| RESERVED                |                                                                                                               |                 |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ST_IVA2 |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                 | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Read returns 0.                                                                                             | R    | 0x00000000 |
| 0    | ST_IVA2    | IVA2 standby status.<br><br>0x0: IVA2 sub-system is active.<br><br>0x1: IVA2 sub-system is in standby mode. | R    | 0x1        |

**Table 3-99. Register Call Summary for Register CM\_IDLEST\_IVA2**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [IVA2\\_CM Registers: \[1\]](#)

**Table 3-100. CM\_IDLEST\_PLL\_IVA2**

|                         |                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|---------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0024                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | IVA2_CM |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 4024                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 | IVA2_CM |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register allows monitoring the master clock activity. This register is read only and automatically updated. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Bit Mask:

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

RESERVED

ST\_IVA2\_CLK

| Bits | Field Name  | Description                                                                 | Type | Reset      |
|------|-------------|-----------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED    | Read returns 0.                                                             | R    | 0x00000000 |
| 0    | ST_IVA2_CLK | IVA2_CLK activity<br>0x0: IVA2 DPLL is bypassed<br>0x1: IVA2 DPLL is locked | R    | 0x0        |

**Table 3-101. Register Call Summary for Register CM\_IDLEST\_PLL\_IVA2**

PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [IVA2\\_CM Registers: \[1\]](#)

**Table 3-102. CM\_AUTOIDLE\_PLL\_IVA2**

|                         |                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|---------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0034                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | IVA2_CM |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 4034                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 | IVA2_CM |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register provides automatic control over the IVA2 DPLL activity. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Bit Mask:

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

RESERVED

AUTO\_IVA2\_DPLL

| Bits | Field Name     | Description                                                                                                                                                                                                                     | Type | Reset      |
|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                              | R    | 0x00000000 |
| 2:0  | AUTO_IVA2_DPLL | IVA2 DPLL automatic control; Other enums: Reserved<br>0x0: Auto control disabled<br>0x1: IVA2 DPLL is automatically put in low power stop mode when the IVA2 clock is not required anymore. It is also restarted automatically. | RW   | 0x0        |

**Table 3-103. Register Call Summary for Register CM\_AUTOIDLE\_PLL\_IVA2**

PRCM Functional Description

- [DPLL Control: \[0\]](#)
- [Internal Clock Controls: \[1\]](#)

PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[2\]](#)

PRCM Register Manual

- [IVA2\\_CM Registers: \[3\]](#)

**Table 3-104. CM\_CLKSEL1\_PLL\_IVA2**

|                         |                                                     |    |    |    |    |    |              |    |                |    |    |    |    |    |                 |               |    |    |    |    |    |   |   |
|-------------------------|-----------------------------------------------------|----|----|----|----|----|--------------|----|----------------|----|----|----|----|----|-----------------|---------------|----|----|----|----|----|---|---|
| <b>Address Offset</b>   | 0x0000 0040                                         |    |    |    |    |    |              |    |                |    |    |    |    |    | <b>Instance</b> | IVA2_CM       |    |    |    |    |    |   |   |
| <b>Physical Address</b> | <a href="#">0x4800 4040</a>                         |    |    |    |    |    |              |    |                |    |    |    |    |    |                 |               |    |    |    |    |    |   |   |
| <b>Description</b>      | This register provides controls over the IVA2 DPLL. |    |    |    |    |    |              |    |                |    |    |    |    |    |                 |               |    |    |    |    |    |   |   |
| <b>Type</b>             | RW                                                  |    |    |    |    |    |              |    |                |    |    |    |    |    |                 |               |    |    |    |    |    |   |   |
| 31                      | 30                                                  | 29 | 28 | 27 | 26 | 25 | 24           | 23 | 22             | 21 | 20 | 19 | 18 | 17 | 16              | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| RESERVED                |                                                     |    |    |    |    |    | IVA2_CLK_SRC |    | IVA2_DPLL_MULT |    |    |    |    |    | RESERVED        | IVA2_DPLL_DIV |    |    |    |    |    |   |   |

| Bits  | Field Name     | Description                                                                                                                                                                                          | Type | Reset |
|-------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:22 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                   | R    | 0x000 |
| 21:19 | IVA2_CLK_SRC   | Selects the IVA2 DPLL bypass source clock; Other enums: Reserved<br>0x1: DPLL2_FCLK is CORE_CLK divided by 1<br>0x2: DPLL2_FCLK is CORE_CLK divided by 2<br>0x4: DPLL2_FCLK is CORE_CLK divided by 4 | RW   | 0x1   |
| 18:8  | IVA2_DPLL_MULT | IVA2 DPLL multiplier factor (0 to 2047)                                                                                                                                                              | RW   | 0x000 |
| 7     | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                   | R    | 0x0   |
| 6:0   | IVA2_DPLL_DIV  | IVA2 DPLL divider factor (0 to 127)                                                                                                                                                                  | RW   | 0x00  |

**Table 3-105. Register Call Summary for Register CM\_CLKSEL1\_PLL\_IVA2**

PRCM Functional Description

- [Clock Configurations: \[0\] \[1\] \[2\] \[3\]](#)

PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[4\]](#)

PRCM Register Manual

- [IVA2\\_CM Registers: \[9\]](#)

**Table 3-106. CM\_CLKSEL2\_PLL\_IVA2**

|                         |                                                     |                         |                 |                 |                      |
|-------------------------|-----------------------------------------------------|-------------------------|-----------------|-----------------|----------------------|
| <b>Address Offset</b>   | 0x0000 0044                                         | <b>Physical Address</b> | 0x4800 4044     | <b>Instance</b> | IVA2_CM              |
| <b>Description</b>      | This register provides controls over the IVA2 DPLL. |                         |                 |                 |                      |
| <b>Type</b>             | RW                                                  |                         |                 |                 |                      |
| 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 |                 |                      |
|                         |                                                     |                         |                 | RESERVED        | IVA2_DPLL_CLKOUT_DIV |

| Bits | Field Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset     |
|------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | RESERVED             | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R    | 0x0000000 |
| 4:0  | IVA2_DPLL_CLKOUT_DIV | <p>IVA2 DPLL output clock divider factor (1 up to 16); Other enums: Reserved</p> <p>0x1: DPLL2 CLKOUTX2 divided by 1</p> <p>0x2: DPLL2 CLKOUTX2 divided by 2</p> <p>0x3: DPLL2 CLKOUTX2 divided by 3</p> <p>0x4: DPLL2 CLKOUTX2 divided by 4</p> <p>0x5: DPLL2 CLKOUTX2 divided by 5</p> <p>0x6: DPLL2 CLKOUTX2 divided by 6</p> <p>0x7: DPLL2 CLKOUTX2 divided by 7</p> <p>0x8: DPLL2 CLKOUTX2 divided by 8</p> <p>0x9: DPLL2 CLKOUTX2 divided by 9</p> <p>0xA: DPLL2 CLKOUTX2 divided by 10</p> <p>0xB: DPLL2 CLKOUTX2 divided by 11</p> <p>0xC: DPLL2 CLKOUTX2 divided by 12</p> <p>0xD: DPLL2 CLKOUTX2 divided by 13</p> <p>0xE: DPLL2 CLKOUTX2 divided by 14</p> <p>0xF: DPLL2 CLKOUTX2 divided by 15</p> <p>0x10: DPLL2 CLKOUTX2 divided by 16</p> | RW   | 0x01      |

**Table 3-107. Register Call Summary for Register CM\_CLKSEL2\_PLL\_IVA2**

## PRCM Functional Description

- [Clock Configurations: \[0\]](#)

## PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[1\]](#)

## PRCM Register Manual

- [IVA2\\_CM Registers: \[2\]](#)

**Table 3-108. CM\_CLKSTCTRL\_IVA2**

|                         |                                                                                                                                                          |                         |                 |                 |                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 0048                                                                                                                                              | <b>Physical Address</b> | 0x4800 4048     | <b>Instance</b> | IVA2_CM        |
| <b>Description</b>      | This register enables the domain power state transition. It controls the HW supervised domain power state transition between ACTIVE and INACTIVE states. |                         |                 |                 |                |
| <b>Type</b>             | RW                                                                                                                                                       |                         |                 |                 |                |
| 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 |                 |                |
| RESERVED                |                                                                                                                                                          |                         |                 |                 | CLKTRCTRL_IVA2 |

| Bits | Field Name     | Description                                                                                                                                                                                                                                                                                                                                              | Type | Reset      |
|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                       | R    | 0x00000000 |
| 1:0  | CLKTRCTRL_IVA2 | <p>Controls the clock state transition of the IVA2 clock domain.</p> <p>0x0: Automatic transition is disabled</p> <p>0x1: Start a software supervised sleep transition on the domain</p> <p>0x2: Start a software supervised wake-up transition on the domain</p> <p>0x3: Automatic transition is enabled. Transition is supervised by the HardWare.</p> | RW   | 0x0        |

**Table 3-109. Register Call Summary for Register CM\_CLKSTCTRL\_IVA2**

PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#) [\[1\]](#) [\[2\]](#)

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[3\]](#)

PRCM Register Manual

- [IVA2\\_CM Registers: \[4\]](#)

**Table 3-110. CM\_CLKSTST\_IVA2**

|                         |                                                                                               |                         |                 |                 |                  |
|-------------------------|-----------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|------------------|
| <b>Address Offset</b>   | 0x0000 004C                                                                                   | <b>Physical Address</b> | 0x4800 404C     | <b>Instance</b> | IVA2_CM          |
| <b>Description</b>      | This register provides a status on the clock activity in the domain (IVA2 DPLL output clock). |                         |                 |                 |                  |
| <b>Type</b>             | R                                                                                             |                         |                 |                 |                  |
| 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 |                 |                  |
| RESERVED                |                                                                                               |                         |                 |                 | CLKACTIVITY_IVA2 |

| Bits | Field Name       | Description                                                                           | Type | Reset      |
|------|------------------|---------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED         | Write 0s for future compatibility. Read returns 0.                                    | R    | 0x00000000 |
| 0    | CLKACTIVITY_IVA2 | Clock activity status<br>0x0: No domain clock activity<br>0x1: Domain clock is active | R    | 0x0        |
|      |                  |                                                                                       |      |            |

**Table 3-111. Register Call Summary for Register CM\_CLKSTST\_IVA2**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [IVA2\\_CM Registers: \[1\]](#)

### 3.7.1.3 OCP\_System\_Reg\_CM Registers

#### 3.7.1.3.1 OCP\_System\_Reg\_CM Register Summary

**Table 3-112. OCP\_System\_Reg\_CM Register Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|---------------|------|-----------------------|----------------|------------------|------------|
| CM_REVISION   | R    | 32                    | 0x0000 0000    | 0x4800 4800      | C          |
| CM_SYSCONFIG  | RW   | 32                    | 0x0000 0010    | 0x4800 4810      | W          |

#### 3.7.1.3.2 OCP\_System\_Reg\_CM Registers

**Table 3-113. CM\_REVISION**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                         |          |                   |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|----------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----|--|--|--|--|--|--|--|
| Address Offset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0000 0000                                                             | Instance | OCP_System_Reg_CM |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| Physical Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x4800 4800                                                             |          |                   |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | This register contains the IP revision code for the CM part of the PRCM |          |                   |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R                                                                       |          |                   |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td> </tr> <tr> <td colspan="16">RESERVED</td><td colspan="8">REV</td></tr> </table> |                                                                         |          |                   | 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | REV |  |  |  |  |  |  |  |
| 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 |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                         |          |                   |    |    |    |    |    |    |    |    |    |    |    |    | REV |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                         | Type | Reset    |
|------|------------|-----------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | RESERVED   | Reads returns 0.                                                                                    | R    | 0x000000 |
| 7:0  | REV        | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision<br>Examples: 0x10 for 1.0, 0x21 for 2.1 | R    | 0x10     |

**Table 3-114. Register Call Summary for Register CM\_REVISION**

PRCM Basic Programming Model

- [Revision Information Registers: \[0\]](#)

PRCM Register Manual

- [OCP\\_System\\_Reg\\_CM Registers: \[1\]](#)

**Table 3-115. CM\_SYS CONFIG**

|                         |                                                                      |                         |                 |                 |                   |
|-------------------------|----------------------------------------------------------------------|-------------------------|-----------------|-----------------|-------------------|
| <b>Address Offset</b>   | 0x0000 0010                                                          | <b>Physical Address</b> | 0x4800 4810     | <b>Instance</b> | OCP_System_Reg_CM |
| <b>Description</b>      | This register controls the various parameters of the interface clock |                         |                 |                 |                   |
| <b>Type</b>             | RW                                                                   |                         |                 |                 |                   |
| 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 |                 |                   |
|                         |                                                                      |                         |                 | RESERVED        | AUTOIDLE          |

| Bits | Field Name | Description                                                                                                                                                                                       | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Reads returns 0.                                                                                                                                               | R    | 0x00000000 |
| 0    | AUTOIDLE   | Internal clock gating strategy (for the CM part of the PRCM)<br><br>0x0: Interface clock is free-running<br><br>0x1: Automatic clock gating strategy is enabled, based on the interface activity. | RW   | 0x1        |

**Table 3-116. Register Call Summary for Register CM\_SYS CONFIG**

PRCM Basic Programming Model  
 • [PRCM Configuration Registers: \[0\]](#)

PRCM Register Manual  
 • [OCP\\_System\\_Reg\\_CM Registers: \[1\]](#)

### 3.7.1.4 MPU\_CM Registers

#### 3.7.1.4.1 MPU\_CM Register Summary

**Table 3-117. MPU\_CM Register Summary**

| Register Name       | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|---------------------|------|-----------------------|----------------|------------------|------------|
| CM_CLKEN_PLL_MPU    | RW   | 32                    | 0x0000 0004    | 0x4800 4904      | W          |
| CM_IDLEST_MPU       | R    | 32                    | 0x0000 0020    | 0x4800 4920      | C          |
| CM_IDLEST_PLL_MPU   | R    | 32                    | 0x0000 0024    | 0x4800 4924      | C          |
| CM_AUTOIDLE_PLL_MPU | RW   | 32                    | 0x0000 0034    | 0x4800 4934      | W          |
| CM_CLKSEL1_PLL_MPU  | RW   | 32                    | 0x0000 0040    | 0x4800 4940      | W          |
| CM_CLKSEL2_PLL_MPU  | RW   | 32                    | 0x0000 0044    | 0x4800 4944      | W          |
| CM_CLKSTCTRL_MPU    | RW   | 32                    | 0x0000 0048    | 0x4800 4948      | W          |
| CM_CLKSTST_MPU      | R    | 32                    | 0x0000 004C    | 0x4800 494C      | C          |

#### 3.7.1.4.2 MPU\_CM Registers

**Table 3-118. CM\_CLKEN\_PLL\_MPU**

|                         |                                         |                         |                 |                   |                       |
|-------------------------|-----------------------------------------|-------------------------|-----------------|-------------------|-----------------------|
| <b>Address Offset</b>   | 0x0000 0004                             | <b>Physical Address</b> | 0x4800 4904     | <b>Instance</b>   | MPU_CM                |
| <b>Description</b>      | This register controls the DPLL1 modes. |                         |                 |                   |                       |
| <b>Type</b>             | RW                                      |                         |                 |                   |                       |
| 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 |                   |                       |
|                         |                                         |                         |                 |                   |                       |
|                         | RESERVED                                |                         |                 | RESERVED          | RESERVED              |
|                         |                                         |                         |                 | EN_MPUDPLL_LPMODE | EN_MPUDPLL_DRIFTGUARD |
|                         |                                         |                         |                 |                   | EN_MPUDPLL            |

| Bits  | Field Name            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset    |
|-------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:11 | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0x000000 |
| 10    | EN_MPUDPLL_LPMODE     | <p>This bit allows to enable or disable the LP mode of the MPU DPLL. Writing this bit to switch the mode between LP or normal mode will take effect only when the DPLL will have transition into the bypass or stop state, followed by a lock or re-lock of the DPLL.</p> <p>0x0: Disables the DPLL LP mode to re-enter the normal mode at the following lock or re-lock sequence.</p> <p>0x1: Enables the DPLL LP mode to enter the LP mode at the following lock or re-lock sequence.</p> | RW   | 0x0      |
| 9:8   | RESERVED              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0x0      |
| 7:4   | RESERVED              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0x1      |
| 3     | EN_MPUDPLL_DRIFTGUARD | <p>This bit allows to enable or disable the automatic recalibration feature of the MPU DPLL. The DPLL1 will automatically start a recalibration process upon assertion of the recal flag if this bit is set.</p> <p>0x0: Disables the DPLL1 automatic recalibration mode</p> <p>0x1: Enables the DPLL1 automatic recalibration mode</p>                                                                                                                                                     | RW   | 0x0      |
| 2:0   | EN_MPUDPLL            | <p>DPLL1 control; Other enums: Reserved</p> <p>0x5: Put the DPLL1 in low power bypass mode</p> <p>0x7: Enables the DPLL1 in lock mode</p>                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x5      |

**Table 3-119. Register Call Summary for Register CM\_CLKEN\_PLL\_MPU**

## PRCM Functional Description

- [DPLL Control: \[0\] \[1\] \[2\]](#)
- [Internal Clock Controls: \[3\]](#)

## PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[4\] \[5\]](#)

## PRCM Register Manual

- [MPU\\_CM Registers: \[6\]](#)

**Table 3-120. CM\_IDLEST\_MPU**

|                         |                                                                                               |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0020                                                                                   |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 4920                                                                                   |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Modules access availability monitoring. This register is read only and automatically updated. |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                             |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                               |                       |                 | ST_MPU   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                | Type | Reset      |
|------|------------|----------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Read returns 0.                                                            | R    | 0x00000000 |
| 0    | ST_MPU     | MPU standby status.<br>0x0: MPU is active.<br>0x1: MPU is in standby mode. | R    | 0x1        |

**Table 3-121. Register Call Summary for Register CM\_IDLEST\_MPU**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [MPU\\_CM Registers: \[1\]](#)

**Table 3-122. CM\_IDLEST\_PLL\_MPU**

|                         |                                                                                                                  |                       |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0024                                                                                                      |                       |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 4924                                                                                                      |                       |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register allows monitoring the master clock activity. This register is read only and automatically updated. |                       |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                |                       |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                                                  |                       |                 | ST_MPU_CLK |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                        | Type | Reset      |
|------|------------|--------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Read returns 0.                                                    | R    | 0x00000000 |
| 0    | ST_MPU_CLK | MPU_CLK activity<br>0x0: DPLL1 is bypassed<br>0x1: DPLL1 is locked | R    | 0x0        |

**Table 3-123. Register Call Summary for Register CM\_IDLEST\_PLL\_MPU**

PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [MPU\\_CM Registers: \[1\]](#)

**Table 3-124. CM\_AUTOIDLE\_PLL\_MPU**

|                         |                                                                   |                         |                 |                 |               |
|-------------------------|-------------------------------------------------------------------|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 0034                                                       | <b>Physical Address</b> | 0x4800 4934     | <b>Instance</b> | MPU_CM        |
| <b>Description</b>      | This register provides automatic control over the DPLL1 activity. |                         |                 |                 |               |
| <b>Type</b>             | RW                                                                |                         |                 |                 |               |
| 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 |                 |               |
| RESERVED                |                                                                   |                         |                 |                 | AUTO_MPU_DPLL |

| Bits | Field Name    | Description                                                                                                                                                                                                                    | Type | Reset      |
|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED      | Write Os for future compatibility. Read returns 0.                                                                                                                                                                             | R    | 0x00000000 |
| 2:0  | AUTO_MPU_DPLL | DPLL1 automatic control; Other enums: Reserved<br><br>0x0: Auto control disabled<br><br>0x1: DPLL1 is automatically put in low power stop mode when the MPU clock is not required anymore. It is also restarted automatically. | RW   | 0x0        |

**Table 3-125. Register Call Summary for Register CM\_AUTOIDLE\_PLL\_MPU**

## PRCM Functional Description

- [DPLL Control: \[0\]](#)
- [Internal Clock Controls: \[1\]](#)

## PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[2\]](#)

## PRCM Register Manual

- [MPU\\_CM Registers: \[3\]](#)

**Table 3-126. CM\_CLKSEL1\_PLL\_MPU**

|                         |                                                    |                         |                 |                 |              |
|-------------------------|----------------------------------------------------|-------------------------|-----------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x0000 0040                                        | <b>Physical Address</b> | 0x4800 4940     | <b>Instance</b> | MPU_CM       |
| <b>Description</b>      | This register provides controls over the MPU DPLL. |                         |                 |                 |              |
| <b>Type</b>             | RW                                                 |                         |                 |                 |              |
| 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 |                 |              |
| RESERVED                |                                                    | MPU_CLK_SRC             | MPU_DPLL_MULT   |                 | MPU_DPLL_DIV |
|                         |                                                    |                         |                 |                 |              |

| Bits  | Field Name    | Description                                                                                                                                                                                             | Type | Reset |
|-------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:22 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                      | R    | 0x000 |
| 21:19 | MPU_CLK_SRC   | Selects the DPLL1 bypass source clock; Other enums:<br>Reserved<br><br>0x1: DPLL1_FCLK is CORE_CLK divided by 1<br>0x2: DPLL1_FCLK is CORE_CLK divided by 2<br>0x4: DPLL1_FCLK is CORE_CLK divided by 4 | RW   | 0x1   |
| 18:8  | MPU_DPLL_MULT | DPLL1 multiplier factor (0 to 2047)                                                                                                                                                                     | RW   | 0x000 |
| 7     | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                      | R    | 0x0   |
| 6:0   | MPU_DPLL_DIV  | DPLL1 divider factor (0 to 127)                                                                                                                                                                         | RW   | 0x00  |

**Table 3-127. Register Call Summary for Register CM\_CLKSEL1\_PLL\_MPU**

PRCM Functional Description

- [Clock Configurations: \[0\] \[1\] \[2\] \[3\]](#)

PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[4\] \[5\]](#)

PRCM Register Manual

- [MPU\\_CM Registers: \[10\]](#)

**Table 3-128. CM\_CLKSEL2\_PLL\_MPU**

|                         |                                                    |    |    |    |    |    |    |    |    |    |                 |    |    |    |        |                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|----------------------------------------------------|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|--------|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 0044                                        |    |    |    |    |    |    |    |    |    |                 |    |    |    |        |                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | <a href="#">0x4800 4944</a>                        |    |    |    |    |    |    |    |    |    | <b>Instance</b> |    |    |    | MPU_CM |                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | This register provides controls over the MPU DPLL. |    |    |    |    |    |    |    |    |    |                 |    |    |    |        |                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                 |    |    |    |    |    |    |    |    |    |                 |    |    |    |        |                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                    |    |    |    |    |    |    |    |    |    |                 |    |    |    |        | MPU_DPLL_CLKOUT_DIV |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset     |
|------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | RESERVED            | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0x0000000 |
| 4:0  | MPU_DPLL_CLKOUT_DIV | DPLL1 output clock divider factor (1 up to 16); Other enums: Reserved<br><br>0x1: DPLL1 CLKOUTX2 divided by 1<br>0x2: DPLL1 CLKOUTX2 divided by 2<br>0x3: DPLL1 CLKOUTX2 divided by 3<br>0x4: DPLL1 CLKOUTX2 divided by 4<br>0x5: DPLL1 CLKOUTX2 divided by 5<br>0x6: DPLL1 CLKOUTX2 divided by 6<br>0x7: DPLL1 CLKOUTX2 divided by 7<br>0x8: DPLL1 CLKOUTX2 divided by 8<br>0x9: DPLL1 CLKOUTX2 divided by 9<br>0xA: DPLL1 CLKOUTX2 divided by 10<br>0xB: DPLL1 CLKOUTX2 divided by 11<br>0xC: DPLL1 CLKOUTX2 divided by 12<br>0xD: DPLL1 CLKOUTX2 divided by 13<br>0xE: DPLL1 CLKOUTX2 divided by 14<br>0xF: DPLL1 CLKOUTX2 divided by 15<br>0x10: DPLL1 CLKOUTX2 divided by 16 | RW   | 0x01      |

**Table 3-129. Register Call Summary for Register CM\_CLKSEL2\_PLL\_MPU**

PRCM Functional Description

- [Clock Configurations: \[0\]](#)

PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[1\]](#)

PRCM Register Manual

- [MPU\\_CM Registers: \[2\]](#)

**Table 3-130. CM\_CLKSTCTRL\_MPU**

|                         |                                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 0048                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x4800 4948                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | This register enables the domain power state transition. It controls the HW supervised domain power state transition between ACTIVE and INACTIVE states. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CLKTRCTRL_MPU |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name    | Description                                                                                                                                                                                                                                                                                           | Type | Reset      |
|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                    | R    | 0x00000000 |
| 1:0  | CLKTRCTRL_MPU | <p>Controls the clock state transition of the MPU clock domain.</p> <p>0x0: Automatic transition is disabled</p> <p>0x1: Reserved</p> <p>0x2: Start a software supervised wake-up transition on the domain</p> <p>0x3: Automatic transition is enabled. Transition is supervised by the HardWare.</p> | RW   | 0x0        |

**Table 3-131. Register Call Summary for Register CM\_CLKSTCTRL\_MPU**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [MPU\\_CM Registers: \[1\]](#)

**Table 3-132. CM\_CLKSTST\_MPU**

|                         |                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |               |                 |
|-------------------------|----------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|---------------|-----------------|
| <b>Address Offset</b>   | 0x0000 004C                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |               |                 |
| <b>Physical Address</b> | <a href="#">0x4800 494C</a>                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b> | <b>MPU_CM</b> |                 |
| <b>Description</b>      | This register provides a status on the clock activity in the domain (MPU DPLL output clock). |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |               |                 |
| <b>Type</b>             | R                                                                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |               |                 |
| 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 |
| RESERVED                |                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |               |                 |

CLKACTIVITY\_MPU

| Bits | Field Name      | Description                                                                                          | Type | Reset      |
|------|-----------------|------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED        | Write 0s for future compatibility. Read returns 0.                                                   | R    | 0x00000000 |
| 0    | CLKACTIVITY_MPU | <p>Clock activity status</p> <p>0x0: No domain clock activity</p> <p>0x1: Domain clock is active</p> | R    | 0x0        |

**Table 3-133. Register Call Summary for Register CM\_CLKSTST\_MPU**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [MPU\\_CM Registers: \[1\]](#)

### 3.7.1.5 CORE\_CM Registers

#### 3.7.1.5.1 CORE\_CM Register Summary

**Table 3-134. CORE\_CM Register Summary**

| Register Name                | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|------------------------------|------|-----------------------|----------------|------------------|------------|
| CM_FCLKEN1_CORE              | RW   | 32                    | 0x0000 0000    | 0x4800 4A00      | W          |
| CM_FCLKEN3_CORE              | RW   | 32                    | 0x0000 0008    | 0x4800 4A08      | W          |
| CM_ICLKEN1_CORE              | RW   | 32                    | 0x0000 0010    | 0x4800 4A10      | W          |
| Reserved for non-GP devices. | RW   | 32                    | 0x0000 0014    | 0x4800 4A14      | W          |
| CM_ICLKEN3_CORE              | RW   | 32                    | 0x0000 0018    | 0x4800 4A18      | W          |
| CM_IDLEST1_CORE              | R    | 32                    | 0x0000 0020    | 0x4800 4A20      | C          |
| Reserved for non-GP devices. | R    | 32                    | 0x0000 0024    | 0x4800 4A24      | C          |
| CM_IDLEST3_CORE              | R    | 32                    | 0x0000 0028    | 0x4800 4A28      | C          |
| CM_AUTOIDLE1_CORE            | RW   | 32                    | 0x0000 0030    | 0x4800 4A30      | W          |
| Reserved for non-GP devices. | RW   | 32                    | 0x0000 0034    | 0x4800 4A34      | W          |
| CM_AUTOIDLE3_CORE            | RW   | 32                    | 0x0000 0038    | 0x4800 4A38      | W          |
| CM_CLKSEL_CORE               | RW   | 32                    | 0x0000 0040    | 0x4800 4A40      | W          |
| CM_CLKSTCTRL_CORE            | RW   | 32                    | 0x0000 0048    | 0x4800 4A48      | W          |
| CM_CLKSTST_CORE              | R    | 32                    | 0x0000 004C    | 0x4800 4A4C      | C          |

**3.7.1.5.2 CORE\_CM Registers****Table 3-135. CM\_FCLKEN1\_CORE**

|                  |  |                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |
|------------------|--|------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|--|
| Address Offset   |  | 0x0000 0000                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |
| Physical Address |  | 0x4800 4A00                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Instance |  |  |  |
| Description      |  | Controls the module functional clock activity. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |
| Type             |  | RW                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |

|          |         |          |    |         |         |          |        |           |           |           |           |         |         |         |          |          |          |          |           |           |          |   |   |   |   |   |   |   |          |   |   |
|----------|---------|----------|----|---------|---------|----------|--------|-----------|-----------|-----------|-----------|---------|---------|---------|----------|----------|----------|----------|-----------|-----------|----------|---|---|---|---|---|---|---|----------|---|---|
| 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 |
| RESERVED | EN_MMC3 | RESERVED |    | EN_MMC2 | EN_MMC1 | RESERVED | EN_HDQ | EN_MCSPI4 | EN_MCSPI3 | EN_MCSPI2 | EN_MCSPI1 | EN_I2C3 | EN_I2C2 | EN_I2C1 | EN_UART2 | EN_UART1 | EN_GPT11 | EN_GPT10 | EN_MCBSP5 | EN_MCBSP1 | RESERVED |   |   |   |   |   |   |   | RESERVED |   |   |

| Bits  | Field Name | Description                                                                                                           | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                    | RW   | 0x0   |
| 30    | EN_MMC3    | MMC3 functional clock control.<br>0x0: MMC3 functional clock is disabled<br>0x1: MMC3 functional clock is enabled     | RW   | 0x0   |
| 29:26 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                    | R    | 0x0   |
| 25    | EN_MMC2    | MMC2 functional clock control.<br>0x0: MMC2 functional clock is disabled<br>0x1: MMC2 functional clock is enabled     | RW   | 0x0   |
| 24    | EN_MMC1    | MMC1 functional clock control.<br>0x0: MMC 1 functional clock is disabled<br>0x1: MMC 1 functional clock is enabled   | RW   | 0x0   |
| 23    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                    | RW   | 0x0   |
| 22    | EN_HDQ     | HDQ-1 wire functional clock control.<br>0x0: HDQ functional clock is disabled<br>0x1: HDQ functional clock is enabled | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                         | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 21   | EN_MCSPI4  | McSPI 4 functional clock control.<br>0x0: McSPI 4 functional clock is disabled<br>0x1: McSPI 4 functional clock is enabled          | RW   | 0x0   |
| 20   | EN_MCSPI3  | McSPI 3 functional clock control.<br>0x0: McSPI 3 functional clock is disabled<br>0x1: McSPI 3 functional clock is enabled          | RW   | 0x0   |
| 19   | EN_MCSPI2  | McSPI 2 functional clock control.<br>0x0: McSPI 2 functional clock is disabled<br>0x1: McSPI 2 functional clock is enabled          | RW   | 0x0   |
| 18   | EN_MCSPI1  | McSPI 1 functional clock control.<br>0x0: McSPI 1 functional clock is disabled<br>0x1: McSPI 1 functional clock is enabled          | RW   | 0x0   |
| 17   | EN_I2C3    | I2C 3 functional clock control.<br>0x0: I2C 3 functional clock is disabled<br>0x1: I2C 3 functional clock is enabled                | RW   | 0x0   |
| 16   | EN_I2C2    | I2C 2 functional clock control.<br>0x0: I2C 2 functional clock is disabled<br>0x1: I2C 2 functional clock is enabled                | RW   | 0x0   |
| 15   | EN_I2C1    | I2C 1 functional clock control.<br>0x0: I2C 1 functional clock is disabled<br>0x1: I2C 1 functional clock is enabled                | RW   | 0x0   |
| 14   | EN_UART2   | UART 2 functional clock control.<br>0x0: UART 2 functional clock is disabled<br>0x1: UART 2 functional clock is enabled             | RW   | 0x0   |
| 13   | EN_UART1   | UART 1 functional clock control.<br>0x0: UART 1 functional clock is disabled<br>0x1: UART 1 functional clock is enabled             | RW   | 0x0   |
| 12   | EN_GPT11   | GPTIMER 11 functional clock control.<br>0x0: GPTIMER 11 functional clock is disabled<br>0x1: GPTIMER 11 functional clock is enabled | RW   | 0x0   |
| 11   | EN_GPT10   | GPTIMER 10 functional clock control.<br>0x0: GPTIMER 10 functional clock is disabled<br>0x1: GPTIMER 10 functional clock is enabled | RW   | 0x0   |
| 10   | EN_MCBSP5  | McBSP 5 functional clock control.<br>0x0: McBSP 5 functional clock is disabled<br>0x1: McBSP 5 functional clock is enabled          | RW   | 0x0   |
| 9    | EN_MCBSP1  | McBSP 1 functional clock control.<br>0x0: McBSP 1 functional clock is disabled<br>0x1: McBSP 1 functional clock is enabled          | RW   | 0x0   |
| 8:1  | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                                  | R    | 0x00  |
| 0    | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                                  | RW   | 0x0   |

**Table 3-136. Register Call Summary for Register CM\_FCLKEN1\_CORE**

PRCM Functional Description

- [Internal Clock Controls: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\]](#)

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[8\]](#)

PRCM Register Manual

- [CORE\\_CM Registers: \[9\]](#)

**Table 3-137. CM\_FCLKEN3\_CORE**

|                         |                                                |                         |                 |                 |                                |
|-------------------------|------------------------------------------------|-------------------------|-----------------|-----------------|--------------------------------|
| <b>Address Offset</b>   | 0x0000 0008                                    | <b>Physical Address</b> | 0x4800 4A08     | <b>Instance</b> | CORE_CM                        |
| <b>Description</b>      | Controls the module functional clock activity. |                         |                 |                 |                                |
| <b>Type</b>             | RW                                             |                         |                 |                 |                                |
| 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 |                 |                                |
|                         |                                                |                         |                 | RESERVED        |                                |
|                         |                                                |                         |                 |                 | EN_USBPLL<br>EN_TS<br>RESERVED |

| Bits | Field Name | Description                                                                                                                                                                                          | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                   | R    | 0x00000000 |
| 2    | EN_USBPLL  | USB PLL functional clock control.<br>0x0: USB PLL functional clock is disabled<br>0x1: USB PLL functional clock is enabled                                                                           | RW   | 0x0        |
| 1    | EN_TS      | Temperature Sensors functional clock control.<br>0x0: Temperature Sensors functional clock is disabled (for both BandGap)<br>0x1: Temperature Sensors functional clock is enabled (for both BandGap) | RW   | 0x0        |
| 0    | RESERVED   | Reserved for non-GP devices.                                                                                                                                                                         | RW   | 0x0        |

**Table 3-138. Register Call Summary for Register CM\_FCLKEN3\_CORE**

PRCM Functional Description

- Internal Clock Controls: [0] [1] [2]

PRCM Basic Programming Model

- Power-Domain Clock Control Registers: [3]

PRCM Register Manual

- CORE\_CM Registers: [4]

**Table 3-139. CM\_ICLKEN1\_CORE**

|                         |                                                |                         |                 |                 |              |
|-------------------------|------------------------------------------------|-------------------------|-----------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x0000 0010                                    | <b>Physical Address</b> | 0x4800 4A10     | <b>Instance</b> | CORE_CM      |
| <b>Description</b>      | Controls the modules interface clock activity. |                         |                 |                 |              |
| <b>Type</b>             | RW                                             |                         |                 |                 |              |
| 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 |                 |              |
| RESERVED                | EN_MMC3                                        | EN_ICR                  | RESERVED        | EN_MMC2         | EN_MMC1      |
|                         |                                                |                         |                 | EN_HDQ          | EN_MCSPI4    |
|                         |                                                |                         |                 | EN_MCSPI3       | EN_MCSPI2    |
|                         |                                                |                         |                 | EN_MCSPI1       | EN_I2C3      |
|                         |                                                |                         |                 | EN_I2C2         | EN_I2C1      |
|                         |                                                |                         |                 | EN_UART2        | EN_UART1     |
|                         |                                                |                         |                 | EN_GPT11        | EN_GPT10     |
|                         |                                                |                         |                 | EN_MCBSP5       | EN_MCBSP1    |
|                         |                                                |                         |                 | RESERVED        | EN_MAILBOXES |
|                         |                                                |                         |                 |                 | EN_SCMCTRL   |
|                         |                                                |                         |                 |                 | RESERVED     |
|                         |                                                |                         |                 |                 | EN_HSOTGUSB  |
|                         |                                                |                         |                 |                 | RESERVED     |
|                         |                                                |                         |                 |                 | RESERVED     |
|                         |                                                |                         |                 |                 | EN_SDRC      |
|                         |                                                |                         |                 |                 | RESERVED     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31          | RESERVED          | Read returns 0.                                                                                                                      | R           | 0x0          |
| 30          | EN_MMC3           | MMC SDIO 3 interface clock control.<br><br>0x0: MMC 3 interface clock is disabled<br>0x1: MMC 3 interface clock is enabled           | RW          | 0x0          |
| 29          | EN_ICR            | ICR interface clock control.<br><br>0x0: ICR interface clock is disabled<br>0x1: ICR interface clock is enabled                      | RW          | 0x0          |
| 28:26       | RESERVED          | Reserved for non-GP devices.                                                                                                         | RW          | 0x0          |
| 25          | EN_MMC2           | MMC SDIO 2 interface clock control.<br><br>0x0: MMC 2 interface clock is disabled<br>0x1: MMC 2 interface clock is enabled           | RW          | 0x0          |
| 24          | EN_MMC1           | MMC SDIO 1 interface clock control.<br><br>0x0: MMC 1 interface clock is disabled<br>0x1: MMC 1 interface clock is enabled           | RW          | 0x0          |
| 23          | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                   | RW          | 0x0          |
| 22          | EN_HDQ            | HDQ-wire interface clock control.<br><br>0x0: HDQ interface clock is disabled<br>0x1: HDQ interface clock is enabled                 | RW          | 0x0          |
| 21          | EN_MCSPI4         | McSPI 4 interface clock control.<br><br>0x0: McSPI 4 interface clock is disabled<br>0x1: McSPI 4 interface clock is enabled          | RW          | 0x0          |
| 20          | EN_MCSPI3         | McSPI 3 interface clock control.<br><br>0x0: McSPI 3 interface clock is disabled<br>0x1: McSPI 3 interface clock is enabled          | RW          | 0x0          |
| 19          | EN_MCSPI2         | McSPI 2 interface clock control.<br><br>0x0: McSPI 2 interface clock is disabled<br>0x1: McSPI 2 interface clock is enabled          | RW          | 0x0          |
| 18          | EN_MCSPI1         | McSPI 1 interface clock control.<br><br>0x0: McSPI 1 interface clock is disabled<br>0x1: McSPI 1 interface clock is enabled          | RW          | 0x0          |
| 17          | EN_I2C3           | I2C 3 interface clock control.<br><br>0x0: I2C 3 interface clock is disabled<br>0x1: I2C 3 interface clock is enabled                | RW          | 0x0          |
| 16          | EN_I2C2           | I2C 2 interface clock control.<br><br>0x0: I2C 2 interface clock is disabled<br>0x1: I2C 2 interface clock is enabled                | RW          | 0x0          |
| 15          | EN_I2C1           | I2C 1 interface clock control.<br><br>0x0: I2C 1 interface clock is disabled<br>0x1: I2C 1 interface clock is enabled                | RW          | 0x0          |
| 14          | EN_UART2          | UART 2 interface clock control.<br><br>0x0: UART 2 interface clock is disabled<br>0x1: UART 2 interface clock is enabled             | RW          | 0x0          |
| 13          | EN_UART1          | UART 1 interface clock control.<br><br>0x0: UART 1 interface clock is disabled<br>0x1: UART 1 interface clock is enabled             | RW          | 0x0          |
| 12          | EN_GPT11          | GPTIMER 11 interface clock control.<br><br>0x0: GPTIMER 11 interface clock is disabled<br>0x1: GPTIMER 11 interface clock is enabled | RW          | 0x0          |

| Bits | Field Name   | Description                                                                                                                      | Type | Reset |
|------|--------------|----------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 11   | EN_GPT10     | GPTIMER 10 interface clock control.<br>0x0: GPTIMER 10 interface clock is disabled<br>0x1: GPTIMER 10 interface clock is enabled | RW   | 0x0   |
| 10   | EN_MCBSP5    | McBSP 5 interface clock control.<br>0x0: McBSP 5 interface clock is disabled<br>0x1: McBSP 5 interface clock is enabled          | RW   | 0x0   |
| 9    | EN_MCBSP1    | McBSP 1 interface clock control.<br>0x0: McBSP 1 interface clock is disabled<br>0x1: McBSP 1 interface clock is enabled          | RW   | 0x0   |
| 8    | RESERVED     | Read returns 0.                                                                                                                  | R    | 0x0   |
| 7    | EN_MAILBOXES | Mailboxes interface clock control<br>0x0: Mailboxes interface clock is disabled<br>0x1: Mailboxes interface clock is enabled     | RW   | 0x0   |
| 6    | EN_SCMCTRL   | System Control Module interface clock control<br>0x0: SCM interface clock is disabled<br>0x1: SCM interface clock is enabled     | RW   | 0x1   |
| 5    | RESERVED     | Read returns 0.                                                                                                                  | R    | 0x0   |
| 4    | EN_HSOTGUSB  | HS OTG USB interface clock control.<br>0x0: HS OTG USB interface clock is disabled<br>0x1: HS OTG USB interface clock is enabled | RW   | 0x0   |
| 3    | RESERVED     | Read returns 0.                                                                                                                  | R    | 0x01  |
| 2    | RESERVED     | Read returns 0.                                                                                                                  | R    | 0x0   |
| 1    | EN_SDRC      | SDRC interface clock control.<br>0x0: SDRC interface clock is disabled<br>0x1: SDRC interface clock is enabled                   | RW   | 0x1   |
| 0    | RESERVED     | Read returns 0.                                                                                                                  | RW   | 0x0   |

**Table 3-140. Register Call Summary for Register CM\_ICLKEN1\_CORE**

PRCM Functional Description

- Internal Clock Controls: [0] [1]
- Sleep and Wake-Up Dependencies:

PRCM Basic Programming Model

- Power-Domain Clock Control Registers: [3]

PRCM Register Manual

- CORE\_CM Registers: [4]

**Table 3-141. CM\_ICLKEN3\_CORE**

|                         |                                               |    |    |    |    |    |    |    |    |    |    |    |                 |         |    |          |           |          |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|-----------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------|---------|----|----------|-----------|----------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 0018                                   |    |    |    |    |    |    |    |    |    |    |    |                 |         |    |          |           |          |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x4800 4A18                                   |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b> | CORE_CM |    |          |           |          |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | Controls the module interface clock activity. |    |    |    |    |    |    |    |    |    |    |    |                 |         |    |          |           |          |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                            |    |    |    |    |    |    |    |    |    |    |    |                 |         |    |          |           |          |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                               |    |    |    |    |    |    |    |    |    |    |    |                 |         |    | RESERVED | EN_USBTLL | RESERVED |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                 | Type | Reset     |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:4 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                          | R    | 0x0000000 |
| 3    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                          | RW   | 0x0       |
| 2    | EN_USBPLL  | USB PLL interface clock control.<br><br>0x0: USB PLL interface clock is disabled<br>0x1: USB PLL interface clock is enabled | RW   | 0x0       |
| 1:0  | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                          | R    | 0x0       |

**Table 3-142. Register Call Summary for Register CM\_ICLKEN3\_CORE**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [CORE\\_CM Registers: \[1\]](#)

**Table 3-143. CM\_IDLEST1\_CORE**

|                         |  |                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--|----------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   |  | 0x0000 0020                                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> |  | 0x4800 4A20                                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      |  | CORE modules access availability monitoring. This register is read only and automatically updated. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             |  | R                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |         |        |          |         |         |          |        |           |           |           |           |         |         |         |          |          |          |          |           |           |          |              |            |                  |                   |          |         |         |          |   |   |
|----------|---------|--------|----------|---------|---------|----------|--------|-----------|-----------|-----------|-----------|---------|---------|---------|----------|----------|----------|----------|-----------|-----------|----------|--------------|------------|------------------|-------------------|----------|---------|---------|----------|---|---|
| 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 |
| RESERVED | ST_MMC3 | ST_ICR | RESERVED | ST_MMC2 | ST_MMC1 | RESERVED | ST_HDQ | ST_MCSPI4 | ST_MCSPI3 | ST_MCSPI2 | ST_MCSPI1 | ST_I2C3 | ST_I2C2 | ST_I2C1 | ST_UART2 | ST_UART1 | ST_GPT11 | ST_GPT10 | ST_MCBSP5 | ST_MCBSP1 | RESERVED | ST_MAILBOXES | ST_SCMCTRL | ST_HSOTGUSB_IDLE | ST_HSOTGUSB_STDBY | RESERVED | ST_SDMA | ST_SDRC | RESERVED |   |   |

| Bits  | Field Name | Description                                                                                                                  | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                           | R    | 0x1   |
| 30    | ST_MMC3    | MMC 3 idle status.<br><br>0x0: MMC 3 can be accessed.<br>0x1: MMC 3 cannot be accessed. Any access may return an error.      | R    | 0x1   |
| 29    | ST_ICR     | ICR idle status.<br><br>0x0: ICR can be accessed.<br>0x1: ICR cannot be accessed. Any access may return an error.            | R    | 0x1   |
| 28:26 | RESERVED   | Reserved for non-GP devices.                                                                                                 | R    | 0x7   |
| 25    | ST_MMC2    | MMC 2 idle status.<br><br>0x0: MMC 2 can be accessed.<br>0x1: MMC 2 cannot be accessed. Any access may return an error.      | R    | 0x1   |
| 24    | ST_MMC1    | MMC SDIO 1 idle status.<br><br>0x0: MMC 1 can be accessed.<br>0x1: MMC 1 cannot be accessed. Any access may return an error. | R    | 0x1   |
| 23    | RESERVED   | Read returns 1.                                                                                                              | R    | 0x1   |

## PRCM Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                                                        | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 22   | ST_HDQ     | HDQ-1 wire idle status.<br>0x0: HDQ can be accessed.<br>0x1: HDQ cannot be accessed. Any access may return an error.               | R    | 0x1   |
| 21   | ST_MCSPI4  | McSPI 4 idle status.<br>0x0: McSPI 4 can be accessed.<br>0x1: McSPI 4 cannot be accessed. Any access may return an error.          | R    | 0x1   |
| 20   | ST_MCSPI3  | McSPI 3 idle status.<br>0x0: McSPI 3 can be accessed.<br>0x1: McSPI 3 cannot be accessed. Any access may return an error.          | R    | 0x1   |
| 19   | ST_MCSPI2  | McSPI 2 idle status.<br>0x0: McSPI 2 can be accessed.<br>0x1: McSPI 2 cannot be accessed. Any access may return an error.          | R    | 0x1   |
| 18   | ST_MCSPI1  | McSPI 1 idle status.<br>0x0: McSPI 1 can be accessed.<br>0x1: McSPI 1 cannot be accessed. Any access may return an error.          | R    | 0x1   |
| 17   | ST_I2C3    | I2C 3 idle status.<br>0x0: I2C 3 can be accessed.<br>0x1: I2C 3 cannot be accessed. Any access may return an error.                | R    | 0x1   |
| 16   | ST_I2C2    | I2C 2 idle status.<br>0x0: I2C 2 can be accessed.<br>0x1: I2C 2 cannot be accessed. Any access may return an error.                | R    | 0x1   |
| 15   | ST_I2C1    | I2C 1 idle status.<br>0x0: I2C 1 can be accessed.<br>0x1: I2C 1 cannot be accessed. Any access may return an error.                | R    | 0x1   |
| 14   | ST_UART2   | UART 2 idle status.<br>0x0: UART 2 can be accessed.<br>0x1: UART 2 cannot be accessed. Any access may return an error.             | R    | 0x1   |
| 13   | ST_UART1   | UART 1 idle status.<br>0x0: UART 1 can be accessed.<br>0x1: UART 1 cannot be accessed. Any access may return an error.             | R    | 0x1   |
| 12   | ST_GPT11   | GPTIMER 11 idle status.<br>0x0: GPTIMER 11 can be accessed.<br>0x1: GPTIMER 11 cannot be accessed. Any access may return an error. | R    | 0x1   |
| 11   | ST_GPT10   | GPTIMER 10 idle status.<br>0x0: GPTIMER 10 can be accessed.<br>0x1: GPTIMER 10 cannot be accessed. Any access may return an error. | R    | 0x1   |
| 10   | ST_MCBSP5  | McBSP 5 idle status.<br>0x0: McBSP 5 can be accessed.<br>0x1: McBSP 5 cannot be accessed. Any access may return an error.          | R    | 0x1   |

| Bits | Field Name        | Description                                                                                                                                | Type | Reset |
|------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 9    | ST_MCBSP1         | McBSP 1 idle status.<br><br>0x0: McBSP 1 can be accessed.<br><br>0x1: McBSP 1 cannot be accessed. Any access may return an error.          | R    | 0x1   |
| 8    | RESERVED          | Read undefined.                                                                                                                            | R    | 0x1   |
| 7    | ST_MAILBOXES      | Mailboxes idle status<br><br>0x0: Mailboxes can be accessed.<br><br>0x1: Mailboxes cannot be accessed. Any access may return an error.     | R    | 0x1   |
| 6    | ST_SCMCTRL        | System Control Module idle status<br><br>0x0: SCM can be accessed.<br><br>0x1: SCM cannot be accessed. Any access may return an error.     | R    | 0x1   |
| 5    | ST_HSOTGUSB_IDLE  | HS OTG USB idle status.<br><br>0x0: HS OTG USB can be accessed.<br><br>0x1: HS OTG USB cannot be accessed. Any access may return an error. | R    | 0x1   |
| 4    | ST_HSOTGUSB_STDBY | HS OTG USB standby status.<br><br>0x0: HS OTG USB is active.<br><br>0x1: HS OTG USB is in standby mode.                                    | R    | 0x1   |
| 3    | RESERVED          | Read returns 1.                                                                                                                            | R    | 0x1   |
| 2    | ST_SDMA           | System DMA standby status.<br><br>0x0: System DMA is active.<br><br>0x1: System DMA is in standby mode.                                    | R    | 0x1   |
| 1    | ST_SDRC           | SDRC idle status.<br><br>0x0: SDRC can be accessed.<br><br>0x1: SDRC cannot be accessed. Any access may return an error.                   | R    | 0x1   |
| 0    | RESERVED          | Read returns 1.                                                                                                                            | R    | 0x1   |

**Table 3-144. Register Call Summary for Register CM\_IDLEST1\_CORE**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [CORE\\_CM Registers: \[1\]](#)

**Table 3-145. CM\_IDLEST3\_CORE**

|                         |                                                                                                    |                         |                 |                 |           |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-----------|--|--|
| <b>Address Offset</b>   | 0x0000 0028                                                                                        | <b>Physical Address</b> | 0x4800 4A28     | <b>Instance</b> | CORE_CM   |  |  |
| <b>Description</b>      | CORE modules access availability monitoring. This register is read only and automatically updated. |                         |                 |                 |           |  |  |
| <b>Type</b>             | R                                                                                                  |                         |                 |                 |           |  |  |
| 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 | RESERVED        | ST_USBTLL |  |  |
|                         |                                                                                                    |                         |                 | RESERVED        | RESERVED  |  |  |
| RESERVED                |                                                                                                    |                         |                 |                 |           |  |  |

| Bits | Field Name | Description                                                                                                                       | Type | Reset     |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:4 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                | R    | 0x0000000 |
| 3    | RESERVED   | Read returns 1.                                                                                                                   | R    | 0x1       |
| 2    | ST_USBPLL  | USB PLL idle status.<br><br>0x0: USB PLL can be accessed.<br><br>0x1: USB PLL cannot be accessed. Any access may return an error. | R    | 0x1       |
| 1    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                | R    | 0x0       |
| 0    | RESERVED   | Reserved for non-GP devices.                                                                                                      | R    | 0x1       |

**Table 3-146. Register Call Summary for Register CM\_IDLEST3\_CORE**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [CORE\\_CM Registers: \[1\]](#)

**Table 3-147. CM\_AUTOIDLE1\_CORE**

|                  |  |                                                                                            |  |          |  |         |  |  |  |  |  |  |  |  |  |
|------------------|--|--------------------------------------------------------------------------------------------|--|----------|--|---------|--|--|--|--|--|--|--|--|--|
| Address Offset   |  | 0x0000 0030                                                                                |  |          |  |         |  |  |  |  |  |  |  |  |  |
| Physical Address |  | 0x4800 4A30                                                                                |  | Instance |  | CORE_CM |  |  |  |  |  |  |  |  |  |
| Description      |  | This register controls the automatic control of the CORE modules interface clock activity. |  |          |  |         |  |  |  |  |  |  |  |  |  |
| Type             |  | RW                                                                                         |  |          |  |         |  |  |  |  |  |  |  |  |  |

|          |           |          |          |           |           |          |          |             |             |             |             |           |           |           |            |            |            |            |             |             |          |                |              |          |               |          |          |          |          |   |   |
|----------|-----------|----------|----------|-----------|-----------|----------|----------|-------------|-------------|-------------|-------------|-----------|-----------|-----------|------------|------------|------------|------------|-------------|-------------|----------|----------------|--------------|----------|---------------|----------|----------|----------|----------|---|---|
| 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 |
| RESERVED | AUTO_MMC3 | AUTO_ICR | RESERVED | AUTO_MMC2 | AUTO_MMC1 | RESERVED | AUTO_HDQ | AUTO_MCSPI4 | AUTO_MCSPI3 | AUTO_MCSPI2 | AUTO_MCSPI1 | AUTO_I2C3 | AUTO_I2C2 | AUTO_I2C1 | AUTO_UART2 | AUTO_UART1 | AUTO_GPT11 | AUTO_GPT10 | AUTO_MCBSP5 | AUTO_MCBSP1 | RESERVED | AUTO_MAILBOXES | AUTO_SCMCTRL | RESERVED | AUTO_HSOTGUSB | RESERVED | RESERVED | RESERVED | RESERVED |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                  | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                           | RW   | 0x0   |
| 30    | AUTO_MMC3  | MMC SDIO 3 auto clock control.<br><br>0x0: MMC 3 interface clock is unrelated to the domain state transition.<br><br>0x1: MMC 3 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |
| 29    | AUTO_ICR   | ICR auto clock control.<br><br>0x0: ICR interface clock is unrelated to the domain state transition.<br><br>0x1: ICR interface clock is automatically enabled or disabled along with the domain state transition.            | RW   | 0x0   |
| 28:26 | RESERVED   | Reserved for non-GP devices.                                                                                                                                                                                                 | RW   | 0x0   |
| 25    | AUTO_MMC2  | MMC SDIO 2 auto clock control.<br><br>0x0: MMC 2 interface clock is unrelated to the domain state transition.<br><br>0x1: MMC 2 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                            | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 24          | AUTO_MMC1         | MMC SDIO 1 auto clock control.<br><br>0x0: MMC 1 interface clock is unrelated to the domain state transition.<br><br>0x1: MMC 1 interface clock is automatically enabled or disabled along with the domain state transition.  | RW          | 0x0          |
| 23          | RESERVED          | Read returns 0.                                                                                                                                                                                                               | RW          | 0x0          |
| 22          | AUTO_HDQ          | HDQ-1 wire auto clock control.<br><br>0x0: HDQ interface clock is unrelated to the domain state transition.<br><br>0x1: HDQ interface clock is automatically enabled or disabled along with the domain state transition.      | RW          | 0x0          |
| 21          | AUTO_MCSPI4       | McSPI 4 auto clock control.<br><br>0x0: McSPI 4 interface clock is unrelated to the domain state transition.<br><br>0x1: McSPI 4 interface clock is automatically enabled or disabled along with the domain state transition. | RW          | 0x0          |
| 20          | AUTO_MCSPI3       | McSPI 3 auto clock control.<br><br>0x0: McSPI 3 interface clock is unrelated to the domain state transition.<br><br>0x1: McSPI 3 interface clock is automatically enabled or disabled along with the domain state transition. | RW          | 0x0          |
| 19          | AUTO_MCSPI2       | McSPI 2 auto clock control.<br><br>0x0: McSPI 2 interface clock is unrelated to the domain state transition.<br><br>0x1: McSPI 2 interface clock is automatically enabled or disabled along with the domain state transition. | RW          | 0x0          |
| 18          | AUTO_MCSPI1       | McSPI 1 auto clock control.<br><br>0x0: McSPI 1 interface clock is unrelated to the domain state transition.<br><br>0x1: McSPI 1 interface clock is automatically enabled or disabled along with the domain state transition. | RW          | 0x0          |
| 17          | AUTO_I2C3         | I2C 3 auto clock control.<br><br>0x0: I2C 3 interface clock is unrelated to the domain state transition.<br><br>0x1: I2C 3 interface clock is automatically enabled or disabled along with the domain state transition.       | RW          | 0x0          |
| 16          | AUTO_I2C2         | I2C 2 auto clock control.<br><br>0x0: I2C 2 interface clock is unrelated to the domain state transition.<br><br>0x1: I2C 2 interface clock is automatically enabled or disabled along with the domain state transition.       | RW          | 0x0          |
| 15          | AUTO_I2C1         | I2C 1 auto clock control.<br><br>0x0: I2C 1 interface clock is unrelated to the domain state transition.<br><br>0x1: I2C 1 interface clock is automatically enabled or disabled along with the domain state transition.       | RW          | 0x0          |
| 14          | AUTO_UART2        | UART 2 auto clock control.<br><br>0x0: UART 2 interface clock is unrelated to the domain state transition.<br><br>0x1: UART 2 interface clock is automatically enabled or disabled along with the domain state transition.    | RW          | 0x0          |
| 13          | AUTO_UART1        | UART 1 auto clock control.<br><br>0x0: UART 1 interface clock is unrelated to the domain state transition.<br><br>0x1: UART 1 interface clock is automatically enabled or disabled along with the domain state transition.    | RW          | 0x0          |

| Bits | Field Name     | Description                                                                                                                                                                                                                            | Type | Reset |
|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 12   | AUTO_GPT11     | GPTIMER 11 auto clock control.<br><br>0x0: GPTIMER 11 interface clock is unrelated to the domain state transition.<br><br>0x1: GPTIMER 11 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |
| 11   | AUTO_GPT10     | GPTIMER 10 auto clock control.<br><br>0x0: GPTIMER 10 interface clock is unrelated to the domain state transition.<br><br>0x1: GPTIMER 10 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |
| 10   | AUTO_MCBSP5    | McBSP 5 auto clock control.<br><br>0x0: McBSP 5 interface clock is unrelated to the domain state transition.<br><br>0x1: McBSP 5 interface clock is automatically enabled or disabled along with the domain state transition.          | RW   | 0x0   |
| 9    | AUTO_MCBSP1    | McBSP 1 auto clock control.<br><br>0x0: McBSP 1 interface clock is unrelated to the domain state transition.<br><br>0x1: McBSP 1 interface clock is automatically enabled or disabled along with the domain state transition.          | RW   | 0x0   |
| 8    | RESERVED       | Read returns 0.                                                                                                                                                                                                                        | R    | 0x0   |
| 7    | AUTO_MAILBOXES | Mailboxes auto clock control<br><br>0x0: Mailboxes interface clock is unrelated to the domain state transition.<br><br>0x1: Mailboxes interface clock is automatically enabled or disabled along with the domain state transition.     | RW   | 0x0   |
| 6    | AUTO_SCMCTRL   | System Control Module auto clock control<br><br>0x0: SCM interface clock is unrelated to the domain state transition.<br><br>0x1: SCM interface clock is automatically enabled or disabled along with the domain state transition.     | RW   | 0x0   |
| 5    | RESERVED       | Read returns 0.                                                                                                                                                                                                                        | R    | 0x0   |
| 4    | AUTO_HSOTGUSB  | HS OTG USB auto clock control.<br><br>0x0: HS OTG USB interface clock is unrelated to the domain state transition.<br><br>0x1: HS OTG USB interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |
| 3    | RESERVED       | Write 1s for future compatibility. Read returns 1.                                                                                                                                                                                     | RW   | 0x1   |
| 2:1  | RESERVED       | Read returns 0.                                                                                                                                                                                                                        | R    | 0x0   |
| 0    | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                     | RW   | 0x0   |

**Table 3-148. Register Call Summary for Register CM\_AUTOIDLE1\_CORE**

## PRCM Functional Description

- [Internal Clock Controls: \[0\] \[1\]](#)

## PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[2\]](#)

## PRCM Register Manual

- [CORE\\_CM Registers: \[3\]](#)

**Table 3-149. CM\_AUTOIDLE3\_CORE**

|                         |                                                                                            |                         |                 |                 |                         |
|-------------------------|--------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-------------------------|
| <b>Address Offset</b>   | 0x0000 0038                                                                                | <b>Physical Address</b> | 0x4800 4A38     | <b>Instance</b> | CORE_CM                 |
| <b>Description</b>      | This register controls the automatic control of the CORE modules interface clock activity. |                         |                 |                 |                         |
| <b>Type</b>             | RW                                                                                         |                         |                 |                 |                         |
| 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 |                 |                         |
| RESERVED                |                                                                                            |                         |                 |                 | AUTO_USBPLL<br>RESERVED |

| Bits | Field Name  | Description                                                                                                                                                                                                                   | Type | Reset      |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                            | R    | 0x00000000 |
| 2    | AUTO_USBPLL | USB PLL auto clock control.<br><br>0x0: USB PLL interface clock is unrelated to the domain state transition.<br><br>0x1: USB PLL interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0        |
| 1:0  | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                            | R    | 0x0        |

**Table 3-150. Register Call Summary for Register CM\_AUTOIDLE3\_CORE**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [CORE\\_CM Registers: \[1\]](#)

**Table 3-151. CM\_CLKSEL\_CORE**

|                         |                               |                         |                 |                 |                                                  |
|-------------------------|-------------------------------|-------------------------|-----------------|-----------------|--------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0040                   | <b>Physical Address</b> | 0x4800 4A40     | <b>Instance</b> | CORE_CM                                          |
| <b>Description</b>      | CORE modules clock selection. |                         |                 |                 |                                                  |
| <b>Type</b>             | RW                            |                         |                 |                 |                                                  |
| 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 |                 |                                                  |
| RESERVED                |                               |                         |                 |                 | CLKSEL_96M<br>RESERVED<br>CLKSEL_L4<br>CLKSEL_L3 |

| Bits  | Field Name | Description                                                                                                                                                                  | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                           | R    | 0x00000 |
| 13:12 | CLKSEL_96M | Selects the 96 MHz clock; Other enums: Reserved.<br><br>0x1: The clock 96 MHz is the DPLL4_M2_CLK divided by 1<br><br>0x2: The clock 96 MHz is the DPLL4_M2_CLK divided by 2 | RW   | 0x1     |
| 11:8  | RESERVED   | Write the reset value, read returns reset value.                                                                                                                             | RW   | 0x1     |

| Bits | Field Name   | Description                                                                                                                                                         | Type | Reset |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7    | CLKSEL_GPT11 | Selects GPTIMER 11 source clock<br>0x0: source is CM_32K_CLK<br>0x1: source is CM_SYS_CLK                                                                           | RW   | 0x0   |
| 6    | CLKSEL_GPT10 | Selects GPTIMER 10 source clock<br>0x0: source is CM_32K_CLK<br>0x1: source is CM_SYS_CLK                                                                           | RW   | 0x0   |
| 5:4  | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                  | R    | 0x0   |
| 3:2  | CLKSEL_L4    | Selects Peripherals interconnect clock (L4_CLK); Other enums: Reserved<br>0x1: L4_CLK is L3_CLK divided by 1 (boot mode only)<br>0x2: L4_CLK is L3_CLK divided by 2 | RW   | 0x1   |
| 1:0  | CLKSEL_L3    | Selects L3 interconnect clock (L3_CLK); Other enums: Reserved<br>0x1: L3_CLK is CORE_CLK divided by 1<br>0x2: L3_CLK is CORE_CLK divided by 2                       | RW   | 0x1   |

**Table 3-152. Register Call Summary for Register CM\_CLKSEL\_CORE**

## PRCM Functional Description

- Internal Clock Controls: [0] [1] [2] [3]
- Clock Configurations: [4] [5]

## PRCM Basic Programming Model

- Power-Domain Clock Control Registers: [6]
- Clock Control: [7]

## PRCM Register Manual

- CORE\_CM Registers: [8]

**Table 3-153. CM\_CLKSTCTRL\_CORE**

|                         |                                                                                                                                                          |                       |                 |          |  |  |  |  |  |  |  |  |                 |         |  |              |              |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|-----------------|---------|--|--------------|--------------|--|--|
| <b>Address Offset</b>   | 0x0000 0048                                                                                                                                              |                       |                 |          |  |  |  |  |  |  |  |  |                 |         |  |              |              |  |  |
| <b>Physical Address</b> | 0x4800 4A48                                                                                                                                              |                       |                 |          |  |  |  |  |  |  |  |  | <b>Instance</b> | CORE_CM |  |              |              |  |  |
| <b>Description</b>      | This register enables the domain power state transition. It controls the HW supervised domain power state transition between ACTIVE and INACTIVE states. |                       |                 |          |  |  |  |  |  |  |  |  |                 |         |  |              |              |  |  |
| <b>Type</b>             | RW                                                                                                                                                       |                       |                 |          |  |  |  |  |  |  |  |  |                 |         |  |              |              |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  |  |                 |         |  | CLKTRCTRL_L4 | CLKTRCTRL_L3 |  |  |

| Bits | Field Name   | Description                                                                                                                                                                                                               | Type | Reset     |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:4 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                        | R    | 0x0000000 |
| 3:2  | CLKTRCTRL_L4 | Controls the clock state transition of the L4 clock domain.<br>0x0: Automatic transition is disabled<br>0x1: Reserved<br>0x2: Reserved<br>0x3: Automatic transition is enabled. Transition is supervised by the HardWare. | RW   | 0x0       |

| Bits | Field Name   | Description                                                                                                                                                                                                               | Type | Reset |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1:0  | CLKTRCTRL_L3 | Controls the clock state transition of the L3 clock domain.<br>0x0: Automatic transition is disabled<br>0x1: Reserved<br>0x2: Reserved<br>0x3: Automatic transition is enabled. Transition is supervised by the HardWare. | RW   | 0x0   |

**Table 3-154. Register Call Summary for Register CM\_CLKSTCTRL\_CORE**

PRCM Functional Description

- [Sleep and Wake-Up Dependencies](#):

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers](#): [1]

PRCM Register Manual

- [CORE\\_CM Registers](#): [2]

**Table 3-155. CM\_CLKSTST\_CORE**

|                         |                                                                                |                       |                 |                |                |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------|-----------------------|-----------------|----------------|----------------|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|
| Address Offset          | 0x0000 004C                                                                    |                       |                 |                |                |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| Physical Address        | 0x4800 4A4C                                                                    |                       |                 |                |                |  |  |  |  |  |  |  |  |  |  |  | Instance |  |  |  |  |  |  |  | CORE_CM |  |  |  |  |  |  |  |
| Description             | This register provides a status on the interface clock activity in the domain. |                       |                 |                |                |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| Type                    | R                                                                              |                       |                 |                |                |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 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 | CLKACTIVITY_L4 | CLKACTIVITY_L3 |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| RESERVED                |                                                                                |                       |                 |                |                |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |

| Bits | Field Name     | Description                                                                                                                 | Type | Reset      |
|------|----------------|-----------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                          | R    | 0x00000000 |
| 1    | CLKACTIVITY_L4 | L4_ICLK interface clock activity status<br>0x0: No domain interface clock activity<br>0x1: Domain interface clock is active | R    | 0x0        |
| 0    | CLKACTIVITY_L3 | L3_ICLK interface clock activity status<br>0x0: No domain interface clock activity<br>0x1: Domain interface clock is active | R    | 0x0        |

**Table 3-156. Register Call Summary for Register CM\_CLKSTST\_CORE**

PRCM Functional Description

- [Sleep and Wake-Up Dependencies](#):

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers](#): [1]

PRCM Register Manual

- [CORE\\_CM Registers](#): [2]

### 3.7.1.6 SGX\_CM Registers

#### 3.7.1.6.1 SGX\_CM Register Summary

**Table 3-157. SGX\_CM Register Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|------------------|------|-----------------------|----------------|------------------|------------|
| CM_FCLKEN_SGX    | RW   | 32                    | 0x0000 0000    | 0x4800 4B00      | W          |
| CM_ICLKEN_SGX    | RW   | 32                    | 0x0000 0010    | 0x4800 4B10      | W          |
| CM_IDLEST_SGX    | R    | 32                    | 0x0000 0020    | 0x4800 4B20      | C          |
| CM_CLKSEL_SGX    | RW   | 32                    | 0x0000 0040    | 0x4800 4B40      | W          |
| CM_SLEEPDEP_SGX  | RW   | 32                    | 0x0000 0044    | 0x4800 4B44      | W          |
| CM_CLKSTCTRL_SGX | RW   | 32                    | 0x0000 0048    | 0x4800 4B48      | W          |
| CM_CLKSTST_SGX   | R    | 32                    | 0x0000 004C    | 0x4800 4B4C      | C          |

**3.7.1.6.2 SGX\_CM Registers****Table 3-158. CM\_FCLKEN\_SGX**

|                         |                                                        |                       |                 |          |        |          |  |  |  |  |  |  |  |  |  |          |        |  |  |  |
|-------------------------|--------------------------------------------------------|-----------------------|-----------------|----------|--------|----------|--|--|--|--|--|--|--|--|--|----------|--------|--|--|--|
| Address Offset          | 0x0000 0000                                            |                       |                 |          |        |          |  |  |  |  |  |  |  |  |  | Instance | SGX_CM |  |  |  |
| Physical Address        | 0x4800 4B00                                            |                       |                 |          |        |          |  |  |  |  |  |  |  |  |  |          |        |  |  |  |
| Description             | Controls the Graphic engine functional clock activity. |                       |                 |          |        |          |  |  |  |  |  |  |  |  |  |          |        |  |  |  |
| Type                    | RW                                                     |                       |                 |          |        |          |  |  |  |  |  |  |  |  |  |          |        |  |  |  |
| 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 | RESERVED | EN_SGX | RESERVED |  |  |  |  |  |  |  |  |  |          |        |  |  |  |

| Bits | Field Name | Description                                                                          | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                   | R    | 0x00000000 |
| 1    | EN_SGX     | SGX functional clock enable<br>0x0: SGX_FCLK is disabled<br>0x1: SGX_FCLK is enabled | RW   | 0x0        |
| 0    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                   | R    | 0x0        |

**Table 3-159. Register Call Summary for Register CM\_FCLKEN\_SGX**

PRCM Functional Description

- Internal Clock Controls: [0] [1] [2]

PRCM Basic Programming Model

- Power-Domain Clock Control Registers: [3]

PRCM Register Manual

- SGX\_CM Registers: [4]

**Table 3-160. CM\_ICLKEN\_SGX**

|                         |                                                       |                       |                 |  |  |  |  |  |  |  |  |  |  |        |
|-------------------------|-------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--------|
| <b>Address Offset</b>   | 0x0000 0010                                           |                       |                 |  |  |  |  |  |  |  |  |  |  |        |
| <b>Physical Address</b> | 0x4800 4B10                                           |                       |                 |  |  |  |  |  |  |  |  |  |  |        |
| <b>Description</b>      | Controls the Graphic engine interface clock activity. |                       |                 |  |  |  |  |  |  |  |  |  |  |        |
| <b>Type</b>             | RW                                                    |                       |                 |  |  |  |  |  |  |  |  |  |  |        |
| 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 |  |  |  |  |  |  |  |  |  |  |        |
| RESERVED                |                                                       |                       |                 |  |  |  |  |  |  |  |  |  |  | EN_SGX |

| Bits | Field Name | Description                                                                                | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                         | R    | 0x00000000 |
| 0    | EN_SGX     | SGX interface clock control<br>0x0: SGX_L3_ICLK is disabled<br>0x1: SGX_L3_ICLK is enabled | RW   | 0x0        |
|      |            |                                                                                            |      |            |

**Table 3-161. Register Call Summary for Register CM\_ICLKEN\_SGX**

PRCM Functional Description

- Internal Clock Controls: [0]

PRCM Basic Programming Model

- Power-Domain Clock Control Registers: [1]

PRCM Register Manual

- SGX\_CM Registers: [2]

**Table 3-162. CM\_IDLEST\_SGX**

|                         |                                                                           |                       |                 |  |  |  |  |  |  |  |  |  |  |        |
|-------------------------|---------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--------|
| <b>Address Offset</b>   | 0x0000 0020                                                               |                       |                 |  |  |  |  |  |  |  |  |  |  |        |
| <b>Physical Address</b> | 0x4800 4B20                                                               |                       |                 |  |  |  |  |  |  |  |  |  |  |        |
| <b>Description</b>      | SGX standby status. This register is read only and automatically updated. |                       |                 |  |  |  |  |  |  |  |  |  |  |        |
| <b>Type</b>             | R                                                                         |                       |                 |  |  |  |  |  |  |  |  |  |  |        |
| 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 |  |  |  |  |  |  |  |  |  |  |        |
| RESERVED                |                                                                           |                       |                 |  |  |  |  |  |  |  |  |  |  | ST_SGX |

| Bits | Field Name | Description                                                                                    | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Read returns 0                                                                                 | R    | 0x00000000 |
| 0    | ST_SGX     | SGX standby status.<br>0x0: SGX subsystem is active.<br>0x1: SGX subsystem is in standby mode. | R    | 0x1        |
|      |            |                                                                                                |      |            |

**Table 3-163. Register Call Summary for Register CM\_IDLEST\_SGX**

PRCM Basic Programming Model

- Power-Domain Clock Control Registers: [0]

PRCM Register Manual

- SGX\_CM Registers: [1]

**Table 3-164. CM\_CLKSEL\_SGX**

|                         |                         |                         |                 |                 |            |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0040             | <b>Physical Address</b> | 0x4800 4B40     | <b>Instance</b> | SGX_CM     |
| <b>Description</b>      | SGX clock selection.    |                         |                 |                 |            |
| <b>Type</b>             | RW                      |                         |                 |                 |            |
| 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 |                 |            |
|                         |                         |                         |                 | RESERVED        | CLKSEL_SGX |

  

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED   | Write 0s for future compatibility. Read return 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R    | 0x00000000 |
| 2:0  | CLKSEL_SGX | <p>Selects SGX functional clock</p> <p>0x0: SGX functional clock is CORE_CLK divided by 3</p> <p>0x1: SGX functional clock is CORE_CLK divided by 4</p> <p>0x2: SGX functional clock is CORE_CLK divided by 6</p> <p>0x3: SGX functional clock is CM_96M_FCLK clock</p> <p>0x4: SGX functional clock is SGX_192M_FCLK clock</p> <p>0x5: SGX functional clock is CORE_CLK divided by 2</p> <p>0x6: SGX functional clock is COREX2_CLK divided by 3</p> <p>0x7: SGX functional clock is COREX2_CLK divided by 5</p> | RW   | 0x0        |

**Table 3-165. Register Call Summary for Register CM\_CLKSEL\_SGX**

## PRCM Functional Description

- [Clock Configurations: \[0\] \[1\] \[2\] \[3\]](#)

## PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[4\] \[5\] \[6\]](#)

## PRCM Register Manual

- [SGX\\_CM Registers: \[7\]](#)

**Table 3-166. CM\_SLEEPDEP\_SGX**

|                         |                                                                                                                        |                         |                 |                 |                    |
|-------------------------|------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|--------------------|
| <b>Address Offset</b>   | 0x0000 0044                                                                                                            | <b>Physical Address</b> | 0x4800 4B44     | <b>Instance</b> | SGX_CM             |
| <b>Description</b>      | This register allows enabling or disabling the sleep transition dependency of SGX domain with respect to other domain. |                         |                 |                 |                    |
| <b>Type</b>             | RW                                                                                                                     |                         |                 |                 |                    |
| 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 |                 |                    |
|                         |                                                                                                                        |                         |                 | RESERVED        | EN_MP0<br>RESERVED |

| Bits | Field Name | Description                                                                                                                                                    | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                             | R    | 0x00000000 |
| 1    | EN_MPU     | MPU domain dependency<br><br>0x0: SGX domain sleep dependency with MPU domain is disabled.<br><br>0x1: SGX domain sleep dependency with MPU domain is enabled. | RW   | 0x0        |
| 0    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                             | R    | 0x0        |

**Table 3-167. Register Call Summary for Register CM\_SLEEPDEP\_SGX**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [SGX\\_CM Registers: \[1\]](#)

**Table 3-168. CM\_CLKSTCTRL\_SGX**

|                         |                                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |        |   |   |   |   |   |   |   |               |   |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|--------|---|---|---|---|---|---|---|---------------|---|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0048                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |        |   |   |   |   |   |   |   |               |   |  |  |  |  |
| <b>Physical Address</b> | <a href="#">0x4800 4B48</a>                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b> | SGX_CM |   |   |   |   |   |   |   |               |   |  |  |  |  |
| <b>Description</b>      | This register enables the domain power state transition. It controls the HW supervised domain power state transition between ACTIVE and INACTIVE states. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |        |   |   |   |   |   |   |   |               |   |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |        |   |   |   |   |   |   |   |               |   |  |  |  |  |
| 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 |  |  |  |  |
| RESERVED                |                                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |        |   |   |   |   |   |   |   | CLKTRCTRL_SGX |   |  |  |  |  |

| Bits | Field Name    | Description                                                                                                                                                                                                                                                                                                                          | Type | Reset      |
|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED      | Write 0s for future compatibility. Reads returns 0.                                                                                                                                                                                                                                                                                  | R    | 0x00000000 |
| 1:0  | CLKTRCTRL_SGX | Controls the clock state transition of the SGX clock domain.<br><br>0x0: Automatic transition is disabled<br>0x1: Start a software supervised sleep transition on the domain<br>0x2: Start a software supervised wake-up transition on the domain<br>0x3: Automatic transition is enabled. Transition is supervised by the hardware. | RW   | 0x0        |

**Table 3-169. Register Call Summary for Register CM\_CLKSTCTRL\_SGX**

PRCM Functional Description

- [Device Wake-Up Events: \[0\] \[1\] \[2\]](#)

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[3\]](#)

PRCM Register Manual

- [SGX\\_CM Registers: \[4\]](#)

**Table 3-170. CM\_CLKSTST\_SGX**

|                         |                                                                                |                         |                 |                 |        |
|-------------------------|--------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 004C                                                                    | <b>Physical Address</b> | 0x4800 4B4C     | <b>Instance</b> | SGX_CM |
| <b>Description</b>      | This register provides a status on the interface clock activity in the domain. |                         |                 |                 |        |
| <b>Type</b>             | R                                                                              |                         |                 |                 |        |
| 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 |                 |        |
| RESERVED                |                                                                                |                         |                 |                 |        |
| CLKACTIVITY_SGX         |                                                                                |                         |                 |                 |        |

| Bits | Field Name      | Description                                                                                                         | Type | Reset      |
|------|-----------------|---------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED        | Write 0s for future compatibility. Read returns 0.                                                                  | R    | 0x00000000 |
| 0    | CLKACTIVITY_SGX | Interface clock activity status<br>0x0: No domain interface clock activity<br>0x1: Domain interface clock is active | R    | 0x0        |
|      |                 |                                                                                                                     |      |            |

**Table 3-171. Register Call Summary for Register CM\_CLKSTST\_SGX**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [SGX\\_CM Registers: \[1\]](#)

### 3.7.1.7 WKUP\_CM Registers

#### 3.7.1.7.1 WKUP\_CM Register Summary

**Table 3-172. WKUP\_CM Register Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|------------------|------|-----------------------|----------------|------------------|------------|
| CM_FCLKEN_WKUP   | RW   | 32                    | 0x0000 0000    | 0x4800 4C00      | W          |
| CM_ICLKEN_WKUP   | RW   | 32                    | 0x0000 0010    | 0x4800 4C10      | W          |
| CM_IDLEST_WKUP   | R    | 32                    | 0x0000 0020    | 0x4800 4C20      | C          |
| CM_AUTOIDLE_WKUP | RW   | 32                    | 0x0000 0030    | 0x4800 4C30      | W          |
| CM_CLKSEL_WKUP   | RW   | 32                    | 0x0000 0040    | 0x4800 4C40      | W          |

#### 3.7.1.7.2 WKUP\_CM Registers

**Table 3-173. CM\_FCLKEN\_WKUP**

|                         |                                                 |                                                                                                                                                 |                 |                 |              |
|-------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x0000 0000                                     | <b>Physical Address</b>                                                                                                                         | 0x4800 4C00     | <b>Instance</b> | WKUP_CM      |
| <b>Description</b>      | Controls the modules functional clock activity. |                                                                                                                                                 |                 |                 |              |
| <b>Type</b>             | RW                                              |                                                                                                                                                 |                 |                 |              |
| 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 |                 |              |
|                         |                                                 |                                                                                                                                                 |                 | RESERVED        | RESERVED     |
|                         |                                                 |                                                                                                                                                 |                 | EN_SR2          | EN_SR1       |
|                         |                                                 |                                                                                                                                                 |                 | EN_WDT2         | RESERVED     |
|                         |                                                 |                                                                                                                                                 |                 | EN_GPIO1        | RESERVED     |
|                         |                                                 |                                                                                                                                                 |                 | EN_GPT1         |              |
|                         |                                                 |                                                                                                                                                 |                 |                 |              |
| <b>Bits</b>             | <b>Field Name</b>                               | <b>Description</b>                                                                                                                              |                 | <b>Type</b>     | <b>Reset</b> |
| 31:10                   | RESERVED                                        | Write 0s for future compatibility. Read returns 0.                                                                                              |                 | R               | 0x0000000    |
| 9                       | RESERVED                                        | Reserved for non-GP devices.                                                                                                                    |                 | RW              | 0x0          |
| 8                       | RESERVED                                        | Write 0s for future compatibility. Read returns 0.                                                                                              |                 | R               | 0x0          |
| 7                       | EN_SR2                                          | Smart Reflex 2 functional clock control.<br>0x0: Smart Reflex 2 functional clock is disabled<br>0x1: Smart Reflex 2 functional clock is enabled |                 | RW              | 0x0          |
| 6                       | EN_SR1                                          | Smart Reflex 1 functional clock control.<br>0x0: Smart Reflex 1 functional clock is disabled<br>0x1: Smart Reflex 1 functional clock is enabled |                 | RW              | 0x0          |
| 5                       | EN_WDT2                                         | WDTIMER 2 functional clock control.<br>0x0: WDTIMER 2 functional clock is disabled<br>0x1: WDTIMER 2 functional clock is enabled                |                 | RW              | 0x0          |
| 4                       | RESERVED                                        | Write 0s for future compatibility. Read returns 0.                                                                                              |                 | R               | 0x0          |
| 3                       | EN_GPIO1                                        | GPIO 1 clock control<br>0x0: GPIO 1 functional clock is disabled<br>0x1: GPIO 1 functional clock is enabled                                     |                 | RW              | 0x0          |
| 2:1                     | RESERVED                                        | Write 0s for future compatibility. Read returns 0.                                                                                              |                 | R               | 0x0          |
| 0                       | EN_GPT1                                         | GPTIMER 1 clock control<br>0x0: GPTIMER 1 functional clock is disabled<br>0x1: GPTIMER 1 functional clock is enabled                            |                 | RW              | 0x0          |

**Table 3-174. Register Call Summary for Register CM\_FCLKEN\_WKUP**
**PRCM Functional Description**

- [Internal Clock Controls: \[0\] \[1\] \[2\] \[3\] \[4\]](#)

**PRCM Basic Programming Model**

- [Power-Domain Clock Control Registers: \[5\]](#)
- [SmartReflex Module Initialization Basic Programming Model: \[6\] \[7\]](#)

**PRCM Register Manual**

- [WKUP\\_CM Registers: \[10\]](#)

**Table 3-175. CM\_ICLKEN\_WKUP**

|                         |                                                |                         |                 |                 |            |
|-------------------------|------------------------------------------------|-------------------------|-----------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0010                                    | <b>Physical Address</b> | 0x4800 4C10     | <b>Instance</b> | WKUP_CM    |
| <b>Description</b>      | Controls the modules interface clock activity. |                         |                 |                 |            |
| <b>Type</b>             | RW                                             |                         |                 |                 |            |
| 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 |                 |            |
|                         |                                                |                         |                 | RESERVED        | RESERVED   |
|                         |                                                |                         |                 |                 | EN_WDT2    |
|                         |                                                |                         |                 |                 | RESERVED   |
|                         |                                                |                         |                 |                 | EN_GPIO1   |
|                         |                                                |                         |                 |                 | EN_32KSYNC |
|                         |                                                |                         |                 |                 | RESERVED   |
|                         |                                                |                         |                 |                 | EN_GPT1    |
|                         |                                                |                         |                 |                 |            |

  

| Bits  | Field Name | Description                                                                                                                                    | Type | Reset     |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:10 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                             | R    | 0x0000000 |
| 9     | RESERVED   | Reserved for non-GP devices                                                                                                                    | RW   | 0x0       |
| 8:6   | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                             | R    | 0x0       |
| 5     | EN_WDT2    | WDTIMER 2 interface clock<br>0x0: WDTIMER 2 interface clock is disabled<br>0x1: WDTIMER 2 interface clock is enabled                           | RW   | 0x0       |
| 4     | RESERVED   | Reserved for non-GP devices                                                                                                                    | RW   | 0x0       |
| 3     | EN_GPIO1   | GPIO 1 interface clock control<br>0x0: GPIO 1 interface clock is disabled<br>0x1: GPIO 1 interface clock is enabled                            | RW   | 0x0       |
| 2     | EN_32KSYNC | 32 kHz Sync Timer interface clock control<br>0x0: 32k Sync Timer interface clock is disabled<br>0x1: 32k Sync Timer interface clock is enabled | RW   | 0x0       |
| 1     | RESERVED   | Reserved for non-GP devices                                                                                                                    | RW   | 0x0       |
| 0     | EN_GPT1    | GPTIMER 1 interface clock control<br>0x0: GPTIMER 1 interface clock is disabled<br>0x1: GPTIMER 1 interface clock is enabled                   | RW   | 0x0       |

**Table 3-176. Register Call Summary for Register CM\_ICLKEN\_WKUP**

## PRCM Functional Description

- Internal Clock Controls: [0]

## PRCM Basic Programming Model

- Power-Domain Clock Control Registers: [1]

## PRCM Register Manual

- WKUP\_CM Registers: [2]

**Table 3-177. CM\_IDLEST\_WKUP**

| <b>Address Offset</b>   | 0x0000 0020                                                                                    | <b>Physical Address</b>                                                                                                                                  | 0x4800 4C20     | <b>Instance</b> | WKUP_CM    |
|-------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|------------|
| <b>Description</b>      | WAKEUP domain modules access monitoring. This register is read only and automatically updated. |                                                                                                                                                          |                 |                 |            |
| <b>Type</b>             | R                                                                                              |                                                                                                                                                          |                 |                 |            |
| 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 |                 |            |
|                         |                                                                                                |                                                                                                                                                          |                 | RESERVED        | RESERVED   |
|                         |                                                                                                |                                                                                                                                                          |                 | RESERVED        | ST_WDT2    |
|                         |                                                                                                |                                                                                                                                                          |                 | RESERVED        | ST_GPIO1   |
|                         |                                                                                                |                                                                                                                                                          |                 | RESERVED        | ST_32KSYNC |
|                         |                                                                                                |                                                                                                                                                          |                 | RESERVED        | ST_GPT1    |
|                         |                                                                                                |                                                                                                                                                          |                 |                 |            |
| Bits                    | Field Name                                                                                     | Description                                                                                                                                              |                 | Type            | Reset      |
| 31:10                   | RESERVED                                                                                       | Read returns 0.                                                                                                                                          |                 | R               | 0x000000   |
| 9                       | RESERVED                                                                                       | Reserved for non-GP devices                                                                                                                              |                 | R               | 0x1        |
| 8                       | RESERVED                                                                                       | Read returns 0.                                                                                                                                          |                 | R               | 0x0        |
| 7                       | ST_SR2                                                                                         | Smart Reflex 2 idle status.<br><br>0x0: Smart Reflex 2 can be accessed.<br><br>0x1: Smart Reflex 2 cannot be accessed. Any access may return an error.   |                 | R               | 0x1        |
| 6                       | ST_SR1                                                                                         | Smart Reflex 1 idle status.<br><br>0x0: Smart Reflex 1 can be accessed.<br><br>0x1: Smart Reflex 1 cannot be accessed. Any access may return an error.   |                 | R               | 0x1        |
| 5                       | ST_WDT2                                                                                        | WDTIMER 2 idle status<br><br>0x0: WDTIMER 2 can be accessed.<br><br>0x1: WDTIMER 2 cannot be accessed. Any access may return an error.                   |                 | R               | 0x1        |
| 4                       | RESERVED                                                                                       | Reserved for non-GP devices                                                                                                                              |                 | R               | 0x1        |
| 3                       | ST_GPIO1                                                                                       | GPIO 1 idle status<br><br>0x0: GPIO 1 can be accessed.<br><br>0x1: GPIO 1 cannot be accessed. Any access may return an error.                            |                 | R               | 0x1        |
| 2                       | ST_32KSYNC                                                                                     | 32 kHz Sync Timer idle status<br><br>0x0: 32k Sync Timer can be accessed.<br><br>0x1: 32k Sync Timer cannot be accessed. Any access may return an error. |                 | R               | 0x1        |
| 1                       | RESERVED                                                                                       | Reserved for non-GP devices                                                                                                                              |                 | R               | 0x1        |
| 0                       | ST_GPT1                                                                                        | GPTIMER 1 idle status<br><br>0x0: GPTIMER 1 can be accessed<br><br>0x1: GPTIMER 1 cannot be accessed. Any access may return an error.                    |                 | R               | 0x1        |

**Table 3-178. Register Call Summary for Register CM\_IDLEST\_WKUP**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [WKUP\\_CM Registers: \[1\]](#)

**Table 3-179. CM\_AUTOIDLE\_WKUP**

|                         |                                                                                                                                                |                         |                 |                 |              |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x0000 0030                                                                                                                                    | <b>Physical Address</b> | 0x4800 4C30     | <b>Instance</b> | WKUP_CM      |
| <b>Description</b>      | This register controls the automatic control of the WAKEUP modules interface clock activity. This activity is related to CORE domain activity. |                         |                 |                 |              |
| <b>Type</b>             | RW                                                                                                                                             |                         |                 |                 |              |
| 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 |                 |              |
|                         |                                                                                                                                                |                         |                 |                 |              |
|                         | RESERVED                                                                                                                                       |                         | RESERVED        | AUTO_WDT2       | RESERVED     |
|                         |                                                                                                                                                |                         |                 | AUTO_GPIO1      | AUTO_32KSYNC |
|                         |                                                                                                                                                |                         |                 | RESERVED        | RESERVED     |
|                         |                                                                                                                                                |                         |                 | AUTO_GPT1       |              |

  

| Bits  | Field Name   | Description                                                                                                                                                                                                                          | Type | Reset    |
|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:10 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                   | R    | 0x000000 |
| 9     | RESERVED     | Reserved for non-GP devices                                                                                                                                                                                                          | RW   | 0x0      |
| 8:6   | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                   | R    | 0x0      |
| 5     | AUTO_WDT2    | WDTIMER 2 autoidle control<br><br>0x0: WDTIMER 2 interface clock is unrelated to the domain activity.<br><br>0x1: WDTIMER 2 interface clock is automatically enabled or disabled according to the domain activity.                   | RW   | 0x0      |
| 4     | RESERVED     | Reserved for non-GP devices                                                                                                                                                                                                          | RW   | 0x0      |
| 3     | AUTO_GPIO1   | GPIO 1 autoidle control<br><br>0x0: GPIO 1 interface clock is unrelated to the domain activity.<br><br>0x1: GPIO 1 interface clock is automatically enabled / disabled according to the domain activity.                             | RW   | 0x0      |
| 2     | AUTO_32KSYNC | 32 kHz Sync Timer autoidle control<br><br>0x0: 32k Sync Timer interface clock is unrelated to the domain activity.<br><br>0x1: 32k Sync Timer interface clock is automatically enabled or disabled according to the domain activity. | RW   | 0x0      |
| 1     | RESERVED     | Reserved for non-GP devices                                                                                                                                                                                                          | RW   | 0x0      |
| 0     | AUTO_GPT1    | GPTIMER 1 autoidle control<br><br>0x0: GPTIMER 1 interface clock is unrelated to the domain activity.<br><br>0x1: GPTIMER 1 interface clock is automatically enabled or disabled according to the domain activity.                   | RW   | 0x0      |

**Table 3-180. Register Call Summary for Register CM\_AUTOIDLE\_WKUP**

## PRCM Functional Description

- Internal Clock Controls: [0]

## PRCM Basic Programming Model

- Power-Domain Clock Control Registers: [1]

## PRCM Register Manual

- WKUP\_CM Registers: [2]

**Table 3-181. CM\_CLKSEL\_WKUP**

|                         |                                               |                         |                 |                 |             |
|-------------------------|-----------------------------------------------|-------------------------|-----------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 0040                                   | <b>Physical Address</b> | 0x4800 4C40     | <b>Instance</b> | WKUP_CM     |
| <b>Description</b>      | WAKEUP domain modules source clock selection. |                         |                 |                 |             |
| <b>Type</b>             | RW                                            |                         |                 |                 |             |
| 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 |                 |             |
|                         |                                               |                         |                 | RESERVED        | RESERVED    |
|                         |                                               |                         |                 |                 | CLKSEL_RM   |
|                         |                                               |                         |                 |                 | CLKSEL_GPT1 |

| Bits | Field Name  | Description                                                                                                                             | Type | Reset     |
|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:7 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                      | R    | 0x0000000 |
| 6:3  | RESERVED    | Reserved for non-GP devices                                                                                                             | RW   | 0x2       |
| 2:1  | CLKSEL_RM   | Selects the Reset Manager clock; Other enums:<br>Reserved<br>0x1: RM_ICLK is L4_CLK divided by 1<br>0x2: RM_ICLK is L4_CLK divided by 2 | RW   | 0x1       |
| 0    | CLKSEL_GPT1 | Selects GPTIMER 1 source clock<br>0x0: source is 32K_FCLK<br>0x1: source is SYS_CLK                                                     | RW   | 0x0       |

**Table 3-182. Register Call Summary for Register CM\_CLKSEL\_WKUP**

PRCM Functional Description

- [Clock Configurations: \[0\]](#)

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[1\]](#)

PRCM Register Manual

- [WKUP\\_CM Registers: \[2\]](#)

### 3.7.1.8 Clock\_Control\_Reg\_CM Registers

#### 3.7.1.8.1 Clock\_Control\_Reg\_CM Register Summary

**Table 3-183. Clock\_Control\_Reg\_CM Register Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|------------------|------|-----------------------|----------------|------------------|------------|
| CM_CLKEN_PLL     | RW   | 32                    | 0x0000 0000    | 0x4800 4D00      | W          |
| CM_CLKEN2_PLL    | RW   | 32                    | 0x0000 0004    | 0x4800 4D04      | W          |
| CM_IDLEST_CKGEN  | R    | 32                    | 0x0000 0020    | 0x4800 4D20      | C          |
| CM_IDLEST2_CKGEN | R    | 32                    | 0x0000 0024    | 0x4800 4D24      | C          |
| CM_AUTOIDLE_PLL  | RW   | 32                    | 0x0000 0030    | 0x4800 4D30      | W          |
| CM_AUTOIDLE2_PLL | RW   | 32                    | 0x0000 0034    | 0x4800 4D34      | W          |
| CM_CLKSEL1_PLL   | RW   | 32                    | 0x0000 0040    | 0x4800 4D40      | W          |
| CM_CLKSEL2_PLL   | RW   | 32                    | 0x0000 0044    | 0x4800 4D44      | W          |
| CM_CLKSEL3_PLL   | RW   | 32                    | 0x0000 0048    | 0x4800 4D48      | W          |
| CM_CLKSEL4_PLL   | RW   | 32                    | 0x0000 004C    | 0x4800 4D4C      | W          |
| CM_CLKSEL5_PLL   | RW   | 32                    | 0x0000 0050    | 0x4800 4D50      | W          |

**Table 3-183. Clock\_Control\_Reg\_CM Register Summary (continued)**

| Register Name  | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|----------------|------|-----------------------|----------------|------------------|------------|
| CM_CLKOUT_CTRL | RW   | 32                    | 0x0000 0070    | 0x4800 4D70      | C          |

**3.7.1.8.2 Clock\_Control\_Reg\_CM Registers****Table 3-184. CM\_CLKEN\_PLL**

| Address Offset | 0x0000 0000                                                 | Physical Address | 0x4800 4D00 | Instance | Clock_Control_Reg_CM |
|----------------|-------------------------------------------------------------|------------------|-------------|----------|----------------------|
| Description    | This register allows controlling the DPLL3 and DPLL4 modes. |                  |             |          |                      |
| Type           | RW                                                          |                  |             |          |                      |

| 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 |
|------------------|-----------|------------|----------|-----------|----------|----|----|----|----|----------------|----------|----|----|----|----|----------------|----------|----------|---------------------|----------|----------|---|---|---|---|-------------------------|--------------|---|---|---|---|
| PWRDN_EMU_PERIPH | PWRDN_CAM | PWRDN_DSS1 | PWRDN_TV | PWRDN_96M | RESERVED |    |    |    |    | EN_PERIPH_DPLL | RESERVED |    |    |    |    | PWRDN_EMU_CORE | RESERVED | RESERVED | EN_CORE_DPLL_LPMODE | RESERVED | RESERVED |   |   |   |   | EN_CORE_DPLL_DRIFTGUARD | EN_CORE_DPLL |   |   |   |   |

| Bits  | Field Name       | Description                                                                                                                                                                                                                            | Type | Reset |
|-------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | PWRDN_EMU_PERIPH | This bit allows to power-down or not the DPLL4_M6_CLK HSDIVIDER path.<br><br>0x0: Power-up the DPLL4_M6_CLK HSDIVIDER path.<br>0x1: Power-down the DPLL4_M6_CLK HSDIVIDER path.<br>Writting this bit to 1 will take effect immediatly. | RW   | 0x0   |
| 30    | PWRDN_CAM        | This bit allows to power-down or not the DPLL4_M5_CLK HSDIVIDER path.<br><br>0x0: Power-up the DPLL4_M5_CLK HSDIVIDER path.<br>0x1: Power-down the DPLL4_M5_CLK HSDIVIDER path.<br>Writting this bit to 1 will take effect immediatly. | RW   | 0x0   |
| 29    | PWRDN_DSS1       | This bit allows to power-down or not the DPLL4_M4_CLK HSDIVIDER path.<br><br>0x0: Power-up the DPLL4_M4_CLK HSDIVIDER path.<br>0x1: Power-down the DPLL4_M4_CLK HSDIVIDER path.<br>Writting this bit to 1 will take effect immediatly. | RW   | 0x0   |
| 28    | PWRDN_TV         | This bit allows to power-down or not the DPLL4_M3_CLK HSDIVIDER path.<br><br>0x0: Power-up the DPLL4_M3_CLK HSDIVIDER path.<br>0x1: Power-down the DPLL4_M3_CLK HSDIVIDER path.<br>Writting this bit to 1 will take effect immediatly. | RW   | 0x0   |
| 27    | PWRDN_96M        | This bit allows to power-down or not the DPLL4_M2_CLK path.<br><br>0x0: Power-up the DPLL4_M2_CLK path.<br>0x1: Power-down the DPLL4_M2_CLK path. Writting this bit to 1 will take effect immediatly.                                  | RW   | 0x0   |
| 26:20 | RESERVED         |                                                                                                                                                                                                                                        | RW   | 0x01  |

| Bits  | Field Name                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset |
|-------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 19    | EN_PERIPH_DPLL_DRIFTGUARD | This bit allows to enable or disable the automatic recalibration feature of the DPLL4. The DPLL4 will automatically start a recalibration process upon assertion of the recal flag if this bit is set.<br><br>0x0: Disables the DPLL4 automatic recalibration mode<br>0x1: Enables the DPLL4 automatic recalibration mode                                                                                                                                                     | RW   | 0x0   |
| 18:16 | EN_PERIPH_DPLL            | DPLL4 control; Other enums: Reserved<br><br>0x1: Put the DPLL4 in low power stop mode<br>0x7: Enables the DPLL4 in lock mode                                                                                                                                                                                                                                                                                                                                                  | RW   | 0x1   |
| 15:13 | RESERVED                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R    | 0x0   |
| 12    | PWRDN_EMU_CORE            | This bit allows to power-down or not the DPLL3_M3X2 HSDIVIDER path.<br><br>0x0: Power-up the DPLL3_M3X2 HSDIVIDER path.<br>0x1: Power-down the DPLL3_M3X2 HSDIVIDER path. Writing this bit to 1 will take effect immediately.                                                                                                                                                                                                                                                 | RW   | 0x0   |
| 11    | RESERVED                  | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                            | R    | 0x0   |
| 10    | EN_CORE_DPLL_LPMODE       | This bit allows to enable or disable the LP mode of the DPLL3. Writing this bit to switch the mode between LP or normal mode will take effect only when the DPLL will have transition into the bypass or stop state, followed by a lock or re-lock of the DPLL.<br><br>0x0: Disables the DPLL LP mode to re-enter the normal mode at the following lock or re-lock sequence.<br>0x1: Enables the DPLL LP mode to enter the LP mode at the following lock or re-lock sequence. | RW   | 0x0   |
| 9:8   | RESERVED                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW   | 0x0   |
| 7:4   | RESERVED                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW   | 0x1   |
| 3     | EN_CORE_DPLL_DRIFTGUARD   | This bit allows to enable or disable the automatic recalibration feature of the DPLL3. The DPLL3 will automatically start a recalibration process upon assertion of the recal flag if this bit is set.<br><br>0x0: Disables the DPLL3 automatic recalibration mode<br>0x1: Enables the DPLL3 automatic recalibration mode                                                                                                                                                     | RW   | 0x0   |
| 2:0   | EN_CORE_DPLL              | DPLL3 control; Other enums: Reserved<br><br>0x5: Put the DPLL3 in low power bypass<br>0x6: Put the DPLL3 in fast relock bypass<br>0x7: Enables the DPLL3 in lock mode                                                                                                                                                                                                                                                                                                         | RW   | 0x5   |

**Table 3-185. Register Call Summary for Register CM\_CLKEN\_PLL**
**PRCM Functional Description**

- [DPLL Control: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\]](#)
- [Internal Clock Controls: \[12\] \[13\]](#)

**PRCM Basic Programming Model**

- [DPLL Clock Control Registers: \[14\]](#)
- [Clock Control: \[15\]](#)

**PRCM Register Manual**

- [Clock\\_Control\\_Reg\\_CM Registers: \[16\]](#)

**Table 3-186. CM\_CLKEN2\_PLL**

|                         |                                         |                         |                 |                        |                            |
|-------------------------|-----------------------------------------|-------------------------|-----------------|------------------------|----------------------------|
| <b>Address Offset</b>   | 0x0000 0004                             | <b>Physical Address</b> | 0x4800 4D04     | <b>Instance</b>        | Clock_Control_Reg_CM       |
| <b>Description</b>      | This register controls the DPLL5 modes. |                         |                 |                        |                            |
| <b>Type</b>             | RW                                      |                         |                 |                        |                            |
| 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 |                        |                            |
|                         |                                         |                         |                 |                        |                            |
|                         | RESERVED                                |                         |                 | RESERVED               | RESERVED                   |
|                         |                                         |                         |                 | EN_PERIPH2_DPLL_LPMODE | EN_PERIPH2_DPLL_DRIFTGUARD |
|                         |                                         |                         |                 | RESERVED               | EN_PERIPH2_DPLL            |

| Bits  | Field Name                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset     |
|-------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:11 | RESERVED                   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                       | R    | 0x0000000 |
| 10    | EN_PERIPH2_DPLL_LPMODE     | <p>This bit allows to enable or disable the LP mode of the DPLL5. Writing this bit to switch the mode between LP or normal mode will take effect only when the DPLL will have transition into the bypass or stop state, followed by a lock or re-lock of the DPLL.</p> <p>0x0: Disables the DPLL LP mode to re-enter the normal mode at the following lock or re-lock sequence.</p> <p>0x1: Enables the DPLL LP mode to enter the LP mode at the following lock or re-lock sequence.</p> | RW   | 0x0       |
| 9:8   | RESERVED                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x0       |
| 7:4   | RESERVED                   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RW   | 0x1       |
| 3     | EN_PERIPH2_DPLL_DRIFTGUARD | <p>This bit allows to enable or disable the automatic recalibration feature of the DPLL5. The DPLL5 will automatically start a recalibration process upon assertion of the recal flag if this bit is set.</p> <p>0x0: Disables the DPLL5 automatic recalibration mode</p> <p>0x1: Enables the DPLL5 automatic recalibration mode</p>                                                                                                                                                     | RW   | 0x0       |
| 2:0   | EN_PERIPH2_DPLL            | <p>DPLL5 control; Other enums: Reserved</p> <p>0x1: Put the second DPLL5 in low power stop mode</p> <p>0x7: Enables the DPLL5 in lock mode</p>                                                                                                                                                                                                                                                                                                                                           | RW   | 0x1       |

**Table 3-187. Register Call Summary for Register CM\_CLKEN2\_PLL**

## PRCM Functional Description

- [DPLL Control: \[1\] \[2\] \[3\]](#)
- [Internal Clock Controls: \[4\]](#)

## PRCM Register Manual

- [Clock\\_Control\\_Reg\\_CM Registers: \[5\]](#)

**Table 3-188. CM\_IDLEST\_CKGEN**

|                         |                                                                                                                  |                 |                      |
|-------------------------|------------------------------------------------------------------------------------------------------------------|-----------------|----------------------|
| <b>Address Offset</b>   | 0x0000 0020                                                                                                      |                 |                      |
| <b>Physical Address</b> | 0x4800 4D20                                                                                                      | <b>Instance</b> | Clock_Control_Reg_CM |
| <b>Description</b>      | This register allows monitoring the master clock activity. This register is read only and automatically updated. |                 |                      |
| <b>Type</b>             | R                                                                                                                |                 |                      |



| Bits  | Field Name        | Description                                                                                                                              | Type | Reset   |
|-------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | RESERVED          | Read returns 0.                                                                                                                          | R    | 0x00000 |
| 13    | ST_EMU_PERIPH_CLK | Emulation clock activity at the output stage of the DPLL4<br>0x0: EMU_PER_ALWON_CLK is not active<br>0x1: EMU_PER_ALWON_CLK is active    | R    | 0x0     |
| 12    | ST_CAM_CLK        | CAMERA functional clock activity at the output stage of the DPLL4<br>0x0: CAM_MCLK is not active<br>0x1: CAM_MCLK is active              | R    | 0x0     |
| 11    | ST_DSS1_CLK       | DSS functional clock 1 activity at the output stage of the DPLL4<br>0x0: DSS1_ALWON_FCLK is not active<br>0x1: DSS1_ALWON_FCLK is active | R    | 0x0     |
| 10    | ST_TV_CLK         | TV clock activity at the output stage of the DPLL4<br>0x0: DPLL4_M3_CLK is not active<br>0x1: DPLL4_M3_CLK is active                     | R    | 0x0     |
| 9     | ST_FUNC96M_CLK    | 96 MHz clock activity at the output stage of the DPLL4<br>0x0: DPLL4_M2_CLK is not active<br>0x1: DPLL4_M2_CLK is active                 | R    | 0x0     |
| 8     | ST_EMU_CORE_CLK   | Emulation clock activity at the output stage of the DPLL3<br>0x0: EMU_CORE_ALWON_CLK is not active<br>0x1: EMU_CORE_ALWON_CLK is active  | R    | 0x0     |
| 7:6   | RESERVED          | Read returns 0.                                                                                                                          | R    | 0x0     |
| 5     | ST_54M_CLK        | Functional clock 54 MHz activity<br>0x0: 54MHz clock is not active<br>0x1: 54MHz clock is active                                         | R    | 0x0     |
| 4     | ST_12M_CLK        | Functional clock 12 MHz activity<br>0x0: 12M_FCLK is not active<br>0x1: 12M_FCLK is active                                               | R    | 0x0     |
| 3     | ST_48M_CLK        | Functional clock 48 MHz activity<br>0x0: 48M_FCLK is not active<br>0x1: 48M_FCLK is active                                               | R    | 0x0     |

| Bits | Field Name    | Description                                                                                | Type | Reset |
|------|---------------|--------------------------------------------------------------------------------------------|------|-------|
| 2    | ST_96M_CLK    | Functional clock 96 MHz activity<br>0x0: 96M_FCLK is not active<br>0x1: 96M_FCLK is active | R    | 0x0   |
| 1    | ST_PERIPH_CLK | DPLL4 clock activity<br>0x0: DPLL4 is bypassed<br>0x1: DPLL4 is locked                     | R    | 0x0   |
| 0    | ST_CORE_CLK   | DPLL3 clock activity<br>0x0: DPLL3 is bypassed<br>0x1: DPLL3 is locked                     | R    | 0x0   |

**Table 3-189. Register Call Summary for Register CM\_IDLEST\_CKGEN**

PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [Clock\\_Control\\_Reg\\_CM Registers: \[1\]](#)

**Table 3-190. CM\_IDLEST2\_CKGEN**

|                         |                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |          |                                      |   |                                                              |                 |
|-------------------------|------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----------|--------------------------------------|---|--------------------------------------------------------------|-----------------|
| Address Offset          | 0x0000 0024                                                                                                      |    |    |    |    |    |    |    |    |    |    |    |          |                                      |   |                                                              |                 |
| Physical Address        | <a href="#">0x4800 4D24</a>                                                                                      |    |    |    |    |    |    |    |    |    |    |    | Instance | <a href="#">Clock_Control_Reg_CM</a> |   |                                                              |                 |
| Description             | This register allows monitoring the master clock activity. This register is read only and automatically updated. |    |    |    |    |    |    |    |    |    |    |    |          |                                      |   |                                                              |                 |
| Type                    | R                                                                                                                |    |    |    |    |    |    |    |    |    |    |    |          |                                      |   |                                                              |                 |
| 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 |
| RESERVED                |                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |          |                                      |   | ST_FUNC120M_CLK<br>RESERVED<br>ST_120M_CLK<br>ST_PERIPH2_CLK |                 |

| Bits | Field Name      | Description                                                                                                                 | Type | Reset     |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:4 | RESERVED        | Read returns 0.                                                                                                             | R    | 0x0000000 |
| 3    | ST_FUNC120M_CLK | 120-MHz clock activity at the output stage of the DPLL5<br>0x0: DPLL5_M2_CLK is not active.<br>0x1: DPLL5_M2_CLK is active. | R    | 0x0       |
| 2    | RESERVED        | Reserved for non-GP devices                                                                                                 | R    | 0x0       |
| 1    | ST_120M_CLK     | USB HOST functional clock 120-MHz activity<br>0x0: USB HOST 120M_FCLK is not active.<br>0x1: USB HOST 120M_FCLK is active.  | R    | 0x0       |
| 0    | ST_PERIPH2_CLK  | DPLL5 clock activity<br>0x0: DPLL5 is bypassed.<br>0x1: DPLL5 is locked.                                                    | R    | 0x0       |

**Table 3-191. Register Call Summary for Register CM\_IDLEST2\_CKGEN**


---

 PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[0\]](#)
- 

PRCM Register Manual

- [Clock\\_Control\\_Reg\\_CM Registers: \[1\]](#)
- 

**Table 3-192. CM\_AUTOIDLE\_PLL**

|                         |                                                                             |                 |                      |
|-------------------------|-----------------------------------------------------------------------------|-----------------|----------------------|
| <b>Address Offset</b>   | 0x0000 0030                                                                 | <b>Instance</b> | Clock_Control_Reg_CM |
| <b>Physical Address</b> | <a href="#">0x4800 4D30</a>                                                 |                 |                      |
| <b>Description</b>      | This register provides automatic control over the DPLL3 and DPLL4 activity. |                 |                      |
| <b>Type</b>             | RW                                                                          |                 |                      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name       | Description                                                                                                                                                                                                                                                                                                                                                               | Type | Reset     |
|------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:6 | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                        | R    | 0x0000000 |
| 5:3  | AUTO_PERIPH_DPLL | DPLL4 automatic control; Other enums: Reserved<br>0x0: Auto control disabled<br>0x1: DPLL4 is automatically put in low power stop mode when none of the 96 MHz and 54 MHz clocks are required anymore. It is also restarted automatically.                                                                                                                                | RW   | 0x0       |
| 2:0  | AUTO_CORE_DPLL   | DPLL3 automatic control; Other enums: Reserved<br>0x0: Auto control disabled<br>0x1: DPLL3 is automatically put in low power stop mode when the CORE clock is not required anymore. It is also restarted automatically.<br>0x5: DPLL3 is automatically put in idle bypass low power mode when the CORE clock is not required anymore. It is also restarted automatically. | RW   | 0x0       |

**Table 3-193. Register Call Summary for Register CM\_AUTOIDLE\_PLL**


---

 PRCM Functional Description

- [DPLL Control: \[0\] \[1\] \[2\] \[3\]](#)
  - [Internal Clock Controls: \[4\] \[5\]](#)
- 

PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[6\]](#)
- 

PRCM Register Manual

- [Clock\\_Control\\_Reg\\_CM Registers: \[7\]](#)
-

**Table 3-194. CM\_AUTOIDLE2\_PLL**

|                         |                                                                   |                         |                 |                 |                      |
|-------------------------|-------------------------------------------------------------------|-------------------------|-----------------|-----------------|----------------------|
| <b>Address Offset</b>   | 0x0000 0034                                                       | <b>Physical Address</b> | 0x4800 4D34     | <b>Instance</b> | Clock_Control_Reg_CM |
| <b>Description</b>      | This register provides automatic control over the DPLL5 activity. |                         |                 |                 |                      |
| <b>Type</b>             | RW                                                                |                         |                 |                 |                      |
| 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 |                 |                      |
|                         |                                                                   |                         |                 | RESERVED        | AUTO_PERIPH2_DPLL    |

| Bits | Field Name        | Description                                                                                                                                                                                                                | Type | Reset      |
|------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED          | Write Os for future compatibility. Read returns 0.                                                                                                                                                                         | R    | 0x00000000 |
| 2:0  | AUTO_PERIPH2_DPLL | DPLL5 automatic control; Other enums: Reserved<br>0x0: Auto control disabled<br>0x1: DPLL5 is automatically put in low power stop mode when the 120 MHz clock is not required anymore. It is also restarted automatically. | RW   | 0x0        |

**Table 3-195. Register Call Summary for Register CM\_AUTOIDLE2\_PLL**

## PRCM Functional Description

- [DPLL Control: \[0\]](#)
- [Internal Clock Controls: \[1\]](#)

## PRCM Register Manual

- [Clock\\_Control\\_Reg\\_CM Registers: \[2\]](#)

**Table 3-196. CM\_CLKSEL1\_PLL**

|                         |                                                                       |                         |                 |                                                             |                      |
|-------------------------|-----------------------------------------------------------------------|-------------------------|-----------------|-------------------------------------------------------------|----------------------|
| <b>Address Offset</b>   | 0x0000 0040                                                           | <b>Physical Address</b> | 0x4800 4D40     | <b>Instance</b>                                             | Clock_Control_Reg_CM |
| <b>Description</b>      | This register controls the selection of the master clock frequencies. |                         |                 |                                                             |                      |
| <b>Type</b>             | RW                                                                    |                         |                 |                                                             |                      |
| 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 |                                                             |                      |
| CORE_DPLL_CLKOUT_DIV    | CORE_DPLL_MULT                                                        | RESERVED                | CORE_DPLL_DIV   | RESERVED SOURCE_96M SOURCE_54M RESERVED SOURCE_48M RESERVED | RESERVED             |

| <b>Bits</b> | <b>Field Name</b>    | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:27       | CORE_DPLL_CLKOUT_DIV | DPLL3 output clock divider factor M2; Other enums:<br>Reserved<br>0x1: DPLL3 output clock is divided by 1<br>0x2: DPLL3 output clock is divided by 2<br>0x3: DPLL3 output clock is divided by 3<br>0x4: DPLL3 output clock is divided by 4<br>0x5: DPLL3 output clock is divided by 5<br>0x6: DPLL3 output clock is divided by 6<br>0x7: DPLL3 output clock is divided by 7<br>0x8: DPLL3 output clock is divided by 8<br>0x9: DPLL3 output clock is divided by 9<br>0xA: DPLL3 output clock is divided by 10<br>0xB: DPLL3 output clock is divided by 11<br>0xC: DPLL3 output clock is divided by 12<br>0xD: DPLL3 output clock is divided by 13<br>0xE: DPLL3 output clock is divided by 14<br>0xF: DPLL3 output clock is divided by 15<br>0x10: DPLL3 output clock is divided by 16<br>0x11: DPLL3 output clock is divided by 17<br>0x12: DPLL3 output clock is divided by 18<br>0x13: DPLL3 output clock is divided by 19<br>0x14: DPLL3 output clock is divided by 20<br>0x15: DPLL3 output clock is divided by 21<br>0x16: DPLL3 output clock is divided by 22<br>0x17: DPLL3 output clock is divided by 23<br>0x18: DPLL3 output clock is divided by 24<br>0x19: DPLL3 output clock is divided by 25<br>0x1A: DPLL3 output clock is divided by 26<br>0x1B: DPLL3 output clock is divided by 27<br>0x1C: DPLL3 output clock is divided by 28<br>0x1D: DPLL3 output clock is divided by 29<br>0x1E: DPLL3 output clock is divided by 30<br>0x1F: DPLL3 output clock is divided by 31 | RW          | 0x01         |
| 26:16       | CORE_DPLL_MULT       | DPLL3 multiplier factor (0 to 2047)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW          | 0x000        |
| 15          | RESERVED             | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R           | 0x0          |
| 14:8        | CORE_DPLL_DIV        | DPLL3 divider factor (0 to 127)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW          | 0x00         |
| 7           | RESERVED             | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R           | 0x0          |
| 6           | SOURCE_96M           | Selection of 96M_FCLK source<br>0x0: source is the CM_96M_FCLK<br>0x1: source is CM_SYS_CLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW          | 0x1          |
| 5           | SOURCE_54M           | Selection of 54MHz clock source<br>0x0: source is the DPLL4_M3_CLK<br>0x1: source is sys_altclk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW          | 0x0          |
| 4           | RESERVED             | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R           | 0x0          |
| 3           | SOURCE_48M           | Selection of Func_12M_clk and Func_48M_clk source<br>0x0: source is the CM_96M_FCLK<br>0x1: source is sys_altclk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW          | 0x0          |
| 2:0         | RESERVED             | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R           | 0x0          |

**Table 3-197. Register Call Summary for Register CM\_CLKSEL1\_PLL**

## PRCM Functional Description

- Internal Clock Controls: [0] [1]
- Clock Configurations: [2] [3] [4]

## PRCM Basic Programming Model

- DPLL Clock Control Registers: [5]

## PRCM Register Manual

- Clock\_Control\_Reg\_CM Registers: [8]

**Table 3-198. CM\_CLKSEL2\_PLL**

|                         |                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |                      |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|----------------------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0044                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | Clock_Control_Reg_CM |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 4D44                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |                      |  |  |  |  |  |  |
| <b>Description</b>      | This register controls the selection of the master clock frequencies. |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |                      |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |                      |  |  |  |  |  |  |

| 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 |  |                 |
|--------|----|----|----|----|----|----|----|---------|----------|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|--|-----------------|
| SD_DIV |    |    |    |    |    |    |    | DCO_SEL | RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RESERVED |   |   |   |   |   |   |   |  | PERIPH_DPLL_DIV |

| Bits  | Field Name       | Description                                                                                                                                                                                                                                                                                 | Type | Reset  |
|-------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:24 | SD_DIV           | This register bits field allows setting the sigma-delta divider factor of the PERIPHERAL DPLL. It must be comprise between 2 and 255. The values 0 and 1 are reserved.                                                                                                                      | RW   | 0x02   |
| 23:21 | DCO_SEL          | This register bits field allows selecting the DCO used by the PERIPHERAL DPLL to synthesize its output clock;<br>Other enums: Reserved<br><br>0x2: The lock frequency is comprised between 500 MHz and 1000 MHz.<br><br>0x4: The lock frequency is comprised between 1000 MHz and 2000 MHz. | RW   | 0x2    |
| 20    | RESERVED         | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                                                                          | R    | 0x0000 |
| 19:8  | PERIPH_DPLL_MULT | DPLL4 multiplier factor (0 to 4095)                                                                                                                                                                                                                                                         | RW   | 0x000  |
| 7     | RESERVED         | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                                                                          | R    | 0x0    |
| 6:0   | PERIPH_DPLL_DIV  | DPLL4 divider factor (0 to 127)                                                                                                                                                                                                                                                             | RW   | 0x00   |

**Table 3-199. Register Call Summary for Register CM\_CLKSEL2\_PLL**

## PRCM Functional Description

- Internal Clock Generation: [0] [1]

## PRCM Basic Programming Model

- DPLL Clock Control Registers: [2]

## PRCM Register Manual

- Clock\_Control\_Reg\_CM Registers: [3]

**Table 3-200. CM\_CLKSEL3\_PLL**

| <b>Address Offset</b>   | 0x0000 0048                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |           |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Physical Address</b> | <a href="#">0x4800 4D48</a>                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |           |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | This register controls the selection of the master clock frequencies. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |           |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |           |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |           |    |    |    |    |    |    |    |    |    |    |    |    | DIV_96M |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bits                    | Field Name                                                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset     |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 31:5                    | RESERVED                                                              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0x0000000 |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 4:0                     | DIV_96M                                                               | 96 MHz clock divider factor M2 (1 up to 31); Other enums: Reserved<br><br>0x1: 96 MHz clock is DPLL4 clock divided by 1<br>0x2: 96 MHz clock is DPLL4 clock divided by 2<br>0x3: 96 MHz clock is DPLL4 clock divided by 3<br>0x4: 96 MHz clock is DPLL4 clock divided by 4<br>0x5: 96 MHz clock is DPLL4 clock divided by 5<br>0x6: 96 MHz clock is DPLL4 clock divided by 6<br>0x7: 96 MHz clock is DPLL4 clock divided by 7<br>0x8: 96 MHz clock is DPLL4 clock divided by 8<br>0x9: 96 MHz clock is DPLL4 clock divided by 9<br>0xA: 96 MHz clock is DPLL4 clock divided by 10<br>0xB: 96 MHz clock is DPLL4 clock divided by 11<br>0xC: 96 MHz clock is DPLL4 clock divided by 12<br>0xD: 96 MHz clock is DPLL4 clock divided by 13<br>0xE: 96 MHz clock is DPLL4 clock divided by 14<br>0xF: 96 MHz clock is DPLL4 clock divided by 15<br>0x10: 96 MHz clock is DPLL4 clock divided by 16<br>0x11: 96 MHz clock is DPLL4 clock divided by 17<br>0x12: 96 MHz clock is DPLL4 clock divided by 18<br>0x13: 96 MHz clock is DPLL4 clock divided by 19<br>0x14: 96 MHz clock is DPLL4 clock divided by 20<br>0x15: 96 MHz clock is DPLL4 clock divided by 21<br>0x16: 96 MHz clock is DPLL4 clock divided by 22<br>0x17: 96 MHz clock is DPLL4 clock divided by 23<br>0x18: 96 MHz clock is DPLL4 clock divided by 24<br>0x19: 96 MHz clock is DPLL4 clock divided by 25<br>0x1A: 96 MHz clock is DPLL4 clock divided by 26<br>0x1B: 96 MHz clock is DPLL4 clock divided by 27<br>0x1C: 96 MHz clock is DPLL4 clock divided by 28<br>0x1D: 96 MHz clock is DPLL4 clock divided by 29<br>0x1E: 96 MHz clock is DPLL4 clock divided by 30<br>0x1F: 96 MHz clock is DPLL4 clock divided by 31 | RW   | 0x01      |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Table 3-201. Register Call Summary for Register CM\_CLKSEL3\_PLL**

PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [Clock\\_Control\\_Reg\\_CM Registers: \[1\]](#)

**Table 3-202. CM\_CLKSEL4\_PLL**

|                         |                                                                       |                         |                 |                  |                      |
|-------------------------|-----------------------------------------------------------------------|-------------------------|-----------------|------------------|----------------------|
| <b>Address Offset</b>   | 0x0000 004C                                                           | <b>Physical Address</b> | 0x4800 4D4C     | <b>Instance</b>  | Clock_Control_Reg_CM |
| <b>Description</b>      | This register controls the selection of the master clock frequencies. |                         |                 |                  |                      |
| <b>Type</b>             | RW                                                                    |                         |                 |                  |                      |
| 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 |                  |                      |
| RESERVED                |                                                                       | PERIPH2_DPLL_MULT       | RESERVED        | PERIPH2_DPLL_DIV |                      |

| Bits  | Field Name        | Description                                        | Type | Reset  |
|-------|-------------------|----------------------------------------------------|------|--------|
| 31:19 | RESERVED          | Write 0s for future compatibility. Read returns 0. | R    | 0x0000 |
| 18:8  | PERIPH2_DPLL_MULT | DPLL5 multiplier factor (0 to 2047)                | RW   | 0x000  |
| 7     | RESERVED          | Write 0s for future compatibility. Read returns 0. | R    | 0x0    |
| 6:0   | PERIPH2_DPLL_DIV  | DPLL5 divider factor (0 to 127)                    | RW   | 0x00   |

**Table 3-203. Register Call Summary for Register CM\_CLKSEL4\_PLL**

PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [Clock\\_Control\\_Reg\\_CM Registers: \[1\]](#)

**Table 3-204. CM\_CLKSEL5\_PLL**

|                         |                                                                       |                         |                 |                 |                      |
|-------------------------|-----------------------------------------------------------------------|-------------------------|-----------------|-----------------|----------------------|
| <b>Address Offset</b>   | 0x0000 0050                                                           | <b>Physical Address</b> | 0x4800 4D50     | <b>Instance</b> | Clock_Control_Reg_CM |
| <b>Description</b>      | This register controls the selection of the master clock frequencies. |                         |                 |                 |                      |
| <b>Type</b>             | RW                                                                    |                         |                 |                 |                      |
| 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 | RESERVED        | DIV_120M             |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Type | Reset     |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R    | 0x0000000 |
| 4:0  | DIV_120M   | 120 MHz clock divider factor M2 (1 up to 16); Other enums: Reserved<br><br>0x1: 120 MHz clock is DPLL5 clock divided by 1<br>0x2: 120 MHz clock is DPLL5 clock divided by 2<br>0x3: 120 MHz clock is DPLL5 clock divided by 3<br>0x4: 120 MHz clock is DPLL5 clock divided by 4<br>0x5: 120 MHz clock is DPLL5 clock divided by 5<br>0x6: 120 MHz clock is DPLL5 clock divided by 6<br>0x7: 120 MHz clock is DPLL5 clock divided by 7<br>0x8: 120 MHz clock is DPLL5 clock divided by 8<br>0x9: 120 MHz clock is DPLL5 clock divided by 9<br>0xA: 120 MHz clock is DPLL5 clock divided by 10<br>0xB: 120 MHz clock is DPLL5 clock divided by 11<br>0xC: 120 MHz clock is DPLL5 clock divided by 12<br>0xD: 120 MHz clock is DPLL5 clock divided by 13<br>0xE: 120 MHz clock is DPLL5 clock divided by 14<br>0xF: 120 MHz clock is DPLL5 clock divided by 15<br>0x10: 120 MHz clock is DPLL5 clock divided by 16 | RW   | 0x01      |

**Table 3-205. Register Call Summary for Register CM\_CLKSEL5\_PLL**

PRCM Basic Programming Model

- [DPLL Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [Clock\\_Control\\_Reg\\_CM Registers: \[1\]](#)

**Table 3-206. CM\_CLKOUT\_CTRL**

|                         |                                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          |             |    |          |                |   |   |   |   |   |   |   |   |   |   |
|-------------------------|-------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----------|-------------|----|----------|----------------|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 0070                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          |             |    |          |                |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | <a href="#">0x4800 4D70</a>                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          |             |    |          |                |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | This register provides control over the SYS_CLKOUT2 output clock. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          |             |    |          |                |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          |             |    |          |                |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CLKOUT2_EN | RESERVED | CLKOUT2_DIV |    | RESERVED | CLKOUT2_SOURCE |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                             | Type | Reset     |
|------|------------|-------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:8 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                      | R    | 0x0000000 |
| 7    | CLKOUT2_EN | This bit controls the external output clock activity<br><br>0x0: sys_clkout2 is disabled<br>0x1: sys_clkout2 is enabled | RW   | 0x0       |
| 6    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                      | R    | 0x0       |

| Bits | Field Name    | Description                                                                                                                                                                                                   | Type | Reset |
|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 5:3  | CLKOUT2_DIV   | This field controls the external output clock division;<br>Other enums: Reserved<br><br>0x0: sys_clkout2 / 1<br>0x1: sys_clkout2 / 2<br>0x2: sys_clkout2 / 4<br>0x3: sys_clkout2 / 8<br>0x4: sys_clkout2 / 16 | RW   | 0x0   |
| 2    | RESERVED      | Write Os for future compatibility. Read returns 0.                                                                                                                                                            | R    | 0x0   |
| 1:0  | CLKOUT2SOURCE | This field selects the external output clock source<br><br>0x0: source is CORE_CLK<br>0x1: source is CM_SYS_CLK<br>0x2: source is CM_96M_FCLK<br>0x3: source is 54 MHz clock                                  | RW   | 0x3   |

**Table 3-207. Register Call Summary for Register CM\_CLKOUT\_CTRL**

PRCM Functional Description

- [Internal Clock Controls: \[0\]](#)

PRCM Register Manual

- [Clock\\_Control\\_Reg\\_CM Registers: \[1\]](#)

### 3.7.1.9 DSS\_CM Registers

#### 3.7.1.9.1 DSS\_CM Register Summary

**Table 3-208. DSS\_CM Register Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|------------------|------|-----------------------|----------------|------------------|------------|
| CM_FCLKEN_DSS    | RW   | 32                    | 0x0000 0000    | 0x4800 4E00      | W          |
| CM_ICLKEN_DSS    | RW   | 32                    | 0x0000 0010    | 0x4800 4E10      | W          |
| CM_IDLEST_DSS    | R    | 32                    | 0x0000 0020    | 0x4800 4E20      | C          |
| CM_AUTOIDLE_DSS  | RW   | 32                    | 0x0000 0030    | 0x4800 4E30      | W          |
| CM_CLKSEL_DSS    | RW   | 32                    | 0x0000 0040    | 0x4800 4E40      | W          |
| CM_SLEEPDEP_DSS  | RW   | 32                    | 0x0000 0044    | 0x4800 4E44      | W          |
| CM_CLKSTCTRL_DSS | RW   | 32                    | 0x0000 0048    | 0x4800 4E48      | W          |
| CM_CLKSTST_DSS   | R    | 32                    | 0x0000 004C    | 0x4800 4E4C      | C          |

#### 3.7.1.9.2 DSS\_CM Registers

**Table 3-209. CM\_FCLKEN\_DSS**

|                  |                                                 |          |        |
|------------------|-------------------------------------------------|----------|--------|
| Address Offset   | 0x0000 0000                                     | Instance | DSS_CM |
| Physical Address | <a href="#">0x4800 4E00</a>                     |          |        |
| Description      | Controls the modules functional clock activity. |          |        |
| Type             | RW                                              |          |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                          | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                   | R    | 0x00000000 |
| 2    | EN_TV      | DSS_TV_FCLK functional clock control<br>0x0: DSS_TV_FCLK is disabled<br>0x1: DSS_TV_FCLK is enabled                  | RW   | 0x0        |
| 1    | EN_DSS2    | Display Sub-System functional clock 2 control<br>0x0: DSS2_ALWON_FCLK is disabled<br>0x1: DSS2_ALWON_FCLK is enabled | RW   | 0x0        |
| 0    | EN_DSS1    | Display Sub-System functional clock 1 control<br>0x0: DSS1_ALWON_FCLK is disabled<br>0x1: DSS1_ALWON_FCLK is enabled | RW   | 0x0        |

**Table 3-210. Register Call Summary for Register CM\_FCLKEN\_DSS**

PRCM Functional Description

- Internal Clock Controls: [0] [1] [2]

PRCM Basic Programming Model

- Power-Domain Clock Control Registers: [3] [4]

PRCM Register Manual

- DSS\_CM Registers: [5]

**Table 3-211. CM\_ICLKEN\_DSS**

|                         |                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0010                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 4E10                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Controls the modules interface clock activity. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits | Field Name | Description                                                                                                                                 | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                          | R    | 0x00000000 |
| 0    | EN_DSS     | Display sub-system interface clock control<br>0x0: DSS_L3_ICLK and DSS_L4_ICLK are disabled<br>0x1: DSS_L3_ICLK and DSS_L4_ICLK are enabled | RW   | 0x0        |

**Table 3-212. Register Call Summary for Register CM\_ICLKEN\_DSS**

PRCM Functional Description

- Internal Clock Controls: [0]

PRCM Basic Programming Model

- Power-Domain Clock Control Registers: [1]

PRCM Register Manual

- DSS\_CM Registers: [2]

**Table 3-213. CM\_IDLEST\_DSS**

|                       |                                                                                               |                         |             |                 |        |
|-----------------------|-----------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|--------|
| <b>Address Offset</b> | 0x0000 0020                                                                                   | <b>Physical Address</b> | 0x4800 4E20 | <b>Instance</b> | DSS_CM |
| <b>Description</b>    | Modules access availability monitoring. This register is read only and automatically updated. |                         |             |                 |        |
| <b>Type</b>           | R                                                                                             |                         |             |                 |        |



| Bits | Field Name   | Description                                                                                                                              | Type | Reset      |
|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED     | Read returns 0.                                                                                                                          | R    | 0x00000000 |
| 1    | ST_DSS_IDLE  | Display Sub-System idle status.<br>0x0: Display Sub-System is active.<br>0x1: Display Sub-System is in idle mode and cannot be accessed. | R    | 0x1        |
| 0    | ST_DSS_STDBY | Display Sub-System standby status.<br>0x0: Display Sub-System is active.<br>0x1: Display Sub-System is in standby mode.                  | R    | 0x1        |

**Table 3-214. Register Call Summary for Register CM\_IDLEST\_DSS**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [DSS\\_CM Registers: \[1\]](#)

**Table 3-215. CM\_AUTOIDLE\_DSS**

|                       |                                                                                       |                         |             |                 |        |
|-----------------------|---------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|--------|
| <b>Address Offset</b> | 0x0000 0030                                                                           | <b>Physical Address</b> | 0x4800 4E30 | <b>Instance</b> | DSS_CM |
| <b>Description</b>    | This register controls the automatic control of the modules interface clock activity. |                         |             |                 |        |
| <b>Type</b>           | RW                                                                                    |                         |             |                 |        |



| Bits | Field Name | Description                                                                                                                                                                                                                                            | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                     | R    | 0x00000000 |
| 0    | AUTO_DSS   | Display Sub-System auto clock control.<br>0x0: Display Sub-System interface clock is unrelated to the domain state transition.<br>0x1: Display Sub-System interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0        |

**Table 3-216. Register Call Summary for Register CM\_AUTOIDLE\_DSS**


---

 PRCM Functional Description

- [Internal Clock Controls: \[0\]](#)
- 

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[1\]](#)
- 

PRCM Register Manual

- [DSS\\_CM Registers: \[2\]](#)
- 

**Table 3-217. CM\_CLKSEL\_DSS**

| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0000 0040              | <b>Instance</b> | DSS_CM |    |    |    |    |    |    |    |    |           |    |    |          |    |             |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |           |  |  |          |  |             |  |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----------------|--------|----|----|----|----|----|----|----|----|-----------|----|----|----------|----|-------------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|--|--|--|--|-----------|--|--|----------|--|-------------|--|--|--|--|--|--|
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x4800 4E40              |                 |        |    |    |    |    |    |    |    |    |           |    |    |          |    |             |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |           |  |  |          |  |             |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Modules clock selection. |                 |        |    |    |    |    |    |    |    |    |           |    |    |          |    |             |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |           |  |  |          |  |             |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW                       |                 |        |    |    |    |    |    |    |    |    |           |    |    |          |    |             |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |           |  |  |          |  |             |  |  |  |  |  |  |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th>31</th><th>30</th><th>29</th><th>28</th><th>27</th><th>26</th><th>25</th><th>24</th><th>23</th><th>22</th><th>21</th><th>20</th><th>19</th><th>18</th><th>17</th><th>16</th><th>15</th><th>14</th><th>13</th><th>12</th><th>11</th><th>10</th><th>9</th><th>8</th><th>7</th><th>6</th><th>5</th><th>4</th><th>3</th><th>2</th><th>1</th><th>0</th></tr> </thead> <tbody> <tr> <td colspan="12" style="text-align: center;">RESERVED</td><td colspan="3" style="text-align: center;">CLKSEL_TV</td><td colspan="2" style="text-align: center;">RESERVED</td><td colspan="7" style="text-align: center;">CLKSEL_DSS1</td></tr> </tbody> </table> |                          |                 |        | 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  | CLKSEL_TV |  |  | RESERVED |  | CLKSEL_DSS1 |  |  |  |  |  |  |
| 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 |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |           |  |  |          |  |             |  |  |  |  |  |  |
| RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                          |                 |        |    |    |    |    |    |    |    |    | CLKSEL_TV |    |    | RESERVED |    | CLKSEL_DSS1 |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |           |  |  |          |  |             |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R    | 0x00000 |
| 13:8  | CLKSEL_TV  | TV functional clock divider factor DPLL4 M3 (1 up to 32);<br>Other enums: Reserved<br>0x1: TV functional clock is DPLL4 clock divided by 1<br>0x2: TV functional clock is DPLL4 clock divided by 2<br>0x3: TV functional clock is DPLL4 clock divided by 3<br>0x4: TV functional clock is DPLL4 clock divided by 4<br>0x5: TV functional clock is DPLL4 clock divided by 5<br>0x6: TV functional clock is DPLL4 clock divided by 6<br>0x7: TV functional clock is DPLL4 clock divided by 7<br>0x8: TV functional clock is DPLL4 clock divided by 8<br>0x9: TV functional clock is DPLL4 clock divided by 9<br>0xA: TV functional clock is DPLL4 clock divided by 10<br>0xB: TV functional clock is DPLL4 clock divided by 11<br>0xC: TV functional clock is DPLL4 clock divided by 12<br>0xD: TV functional clock is DPLL4 clock divided by 13<br>0xE: TV functional clock is DPLL4 clock divided by 14<br>0xF: TV functional clock is DPLL4 clock divided by 15<br>0x10: TV functional clock is DPLL4 clock divided by 16<br>0x11: TV functional clock is DPLL4 clock divided by 17<br>0x12: TV functional clock is DPLL4 clock divided by 18<br>0x13: TV functional clock is DPLL4 clock divided by 19<br>0x14: TV functional clock is DPLL4 clock divided by 20<br>0x15: TV functional clock is DPLL4 clock divided by 21<br>0x16: TV functional clock is DPLL4 clock divided by 22<br>0x17: TV functional clock is DPLL4 clock divided by 23<br>0x18: TV functional clock is DPLL4 clock divided by 24<br>0x19: TV functional clock is DPLL4 clock divided by 25<br>0x1A: TV functional clock is DPLL4 clock divided by 26<br>0x1B: TV functional clock is DPLL4 clock divided by 27<br>0x1C: TV functional clock is DPLL4 clock divided by 28<br>0x1D: TV functional clock is DPLL4 clock divided by 29<br>0x1E: TV functional clock is DPLL4 clock divided by 30<br>0x1F: TV functional clock is DPLL4 clock divided by 31<br>0x20: TV functional clock is DPLL4 clock divided by 32 | RW   | 0x04    |
| 7:6   | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R    | 0x0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 5:0         | CLKSEL_DSS1       | DPLL4 M4 divide factor for DSS1_ALWON_FCLK (1 up to 32); Other enums: Reserved<br>0x1: DSS1_ALWON_FCLK is DPLL4 clock divided by 1<br>0x2: DSS1_ALWON_FCLK is DPLL4 clock divided by 2<br>0x3: DSS1_ALWON_FCLK is DPLL4 clock divided by 3<br>0x4: DSS1_ALWON_FCLK is DPLL4 clock divided by 4<br>0x5: DSS1_ALWON_FCLK is DPLL4 clock divided by 5<br>0x6: DSS1_ALWON_FCLK is DPLL4 clock divided by 6<br>0x7: DSS1_ALWON_FCLK is DPLL4 clock divided by 7<br>0x8: DSS1_ALWON_FCLK is DPLL4 clock divided by 8<br>0x9: DSS1_ALWON_FCLK is DPLL4 clock divided by 9<br>0xA: DSS1_ALWON_FCLK is DPLL4 clock divided by 10<br>0xB: DSS1_ALWON_FCLK is DPLL4 clock divided by 11<br>0xC: DSS1_ALWON_FCLK is DPLL4 clock divided by 12<br>0xD: DSS1_ALWON_FCLK is DPLL4 clock divided by 13<br>0xE: DSS1_ALWON_FCLK is DPLL4 clock divided by 14<br>0xF: DSS1_ALWON_FCLK is DPLL4 clock divided by 15<br>0x10: DSS1_ALWON_FCLK is DPLL4 clock divided by 16<br>0x11: DSS1_ALWON_FCLK is DPLL4 clock divided by 17<br>0x12: DSS1_ALWON_FCLK is DPLL4 clock divided by 18<br>0x13: DSS1_ALWON_FCLK is DPLL4 clock divided by 19<br>0x14: DSS1_ALWON_FCLK is DPLL4 clock divided by 20<br>0x15: DSS1_ALWON_FCLK is DPLL4 clock divided by 21<br>0x16: DSS1_ALWON_FCLK is DPLL4 clock divided by 22<br>0x17: DSS1_ALWON_FCLK is DPLL4 clock divided by 23<br>0x18: DSS1_ALWON_FCLK is DPLL4 clock divided by 24<br>0x19: DSS1_ALWON_FCLK is DPLL4 clock divided by 25<br>0x1A: DSS1_ALWON_FCLK is DPLL4 clock divided by 26<br>0x1B: DSS1_ALWON_FCLK is DPLL4 clock divided by 27<br>0x1C: DSS1_ALWON_FCLK is DPLL4 clock divided by 28<br>0x1D: DSS1_ALWON_FCLK is DPLL4 clock divided by 29<br>0x1E: DSS1_ALWON_FCLK is DPLL4 clock divided by 30<br>0x1F: DSS1_ALWON_FCLK is DPLL4 clock divided by 31<br>0x20: DSS1_ALWON_FCLK is DPLL4 clock divided by 32 | RW          | 0x10         |

**Table 3-218. Register Call Summary for Register CM\_CLKSEL\_DSS**


---

 PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)
- 

PRCM Register Manual

- [DSS\\_CM Registers: \[1\]](#)
-

**Table 3-219. CM\_SLEEPDEP\_DSS**

|                         |                                                                                                                        |                         |                 |                 |                                                                                                                                                                                                                   |
|-------------------------|------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0044                                                                                                            | <b>Physical Address</b> | 0x4800 4E44     | <b>Instance</b> | DSS_CM                                                                                                                                                                                                            |
| <b>Description</b>      | This register allows enabling or disabling the sleep transition dependency of DSS domain with respect to other domain. |                         |                 |                 |                                                                                                                                                                                                                   |
| <b>Type</b>             | RW                                                                                                                     |                         |                 |                 |                                                                                                                                                                                                                   |
| 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 |                 |                                                                                                                                                                                                                   |
| RESERVED                |                                                                                                                        |                         |                 |                 | <span style="border: 1px solid black; padding: 2px;">EN_IVA2</span><br><span style="border: 1px solid black; padding: 2px;">EN_MPUs</span><br><span style="border: 1px solid black; padding: 2px;">EN_CORE</span> |

| Bits | Field Name | Description                                                                                                                                                       | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                                                                | R    | 0x00000000 |
| 2    | EN_IVA2    | IVA2 domain dependency<br><br>0x0: DSS domain sleep dependency with IVA2 domain is disabled.<br><br>0x1: DSS domain sleep dependency with IVA2 domain is enabled. | RW   | 0x0        |
| 1    | EN_MPUs    | MPU domain dependency<br><br>0x0: DSS domain sleep dependency with MPU domain is disabled.<br><br>0x1: DSS domain sleep dependency with MPU domain is enabled.    | RW   | 0x0        |
| 0    | EN_CORE    | CORE domain dependency<br><br>0x0: DSS domain sleep dependency with CORE domain is disabled.<br><br>0x1: DSS domain sleep dependency with CORE domain is enabled. | RW   | 0          |

**Table 3-220. Register Call Summary for Register CM\_SLEEPDEP\_DSS**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [DSS\\_CM Registers: \[1\]](#)

**Table 3-221. CM\_CLKSTCTRL\_DSS**

|                         |                                                                                                                                                          |                         |                 |                 |               |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 0048                                                                                                                                              | <b>Physical Address</b> | 0x4800 4E48     | <b>Instance</b> | DSS_CM        |
| <b>Description</b>      | This register enables the domain power state transition. It controls the HW supervised domain power state transition between ACTIVE and INACTIVE states. |                         |                 |                 |               |
| <b>Type</b>             | RW                                                                                                                                                       |                         |                 |                 |               |
| 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 |                 |               |
| RESERVED                |                                                                                                                                                          |                         |                 |                 | CLKTRCTRL_DSS |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                      | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:2        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                      | R           | 0x00000000   |
| 1:0         | CLKTRCTRL_DSS     | <p>Controls the clock state transition of the DSS clock domain.</p> <p>0x0: Automatic transition is disabled</p> <p>0x1: Start a software supervised sleep transition on the domain</p> <p>0x2: Start a software supervised wake-up transition on the domain</p> <p>0x3: Automatic transition is enabled. Transition is supervised by the HardWare.</p> | RW          | 0x0          |

**Table 3-222. Register Call Summary for Register CM\_CLKSTCTRL\_DSS**

- ## PRCM Functional Description

- ## PRCM Basic Programming Model

- PRCM Register Manual

Table 3-223. CM CLKSTST DSS

|                         |                                                                                    |                 |        |
|-------------------------|------------------------------------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 004C                                                                        |                 |        |
| <b>Physical Address</b> | <a href="#">0x4800 4E4C</a>                                                        | <b>Instance</b> | DSS_CM |
| <b>Description</b>      | This register provides a status on the OCP interface clock activity in the domain. |                 |        |
| <b>Type</b>             | R                                                                                  |                 |        |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:1        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                  | R           | 0x00000000   |
| 0           | CLKACTIVITY_DSS   | Interface clock activity status<br>0x0: No domain Interface clock activity<br>0x1: Domain Interface clock is active | R           | 0x0          |

**Table 3-224. Register Call Summary for Register CM\_CLKSTST\_DSS**

- Power-Domain Clock Control Registers: [0]

PRCM Register Manual

  - DSS CM Registers: [1]

### 3.7.1.10 CAM CM Registers

### **3.7.1.10.1 CAM CM Register Summary**

**Table 3-225. CAM\_CM Register Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|------------------|------|-----------------------|----------------|------------------|------------|
| CM_FCLKEN_CAM    | RW   | 32                    | 0x0000 0000    | 0x4800 4F00      | W          |
| CM_ICLKEN_CAM    | RW   | 32                    | 0x0000 0010    | 0x4800 4F10      | W          |
| CM_IDLEST_CAM    | R    | 32                    | 0x0000 0020    | 0x4800 4F20      | C          |
| CM_AUTOIDLE_CAM  | RW   | 32                    | 0x0000 0030    | 0x4800 4F30      | W          |
| CM_CLKSEL_CAM    | RW   | 32                    | 0x0000 0040    | 0x4800 4F40      | W          |
| CM_SLEEPDEP_CAM  | RW   | 32                    | 0x0000 0044    | 0x4800 4F44      | W          |
| CM_CLKSTCTRL_CAM | RW   | 32                    | 0x0000 0048    | 0x4800 4F48      | W          |
| CM_CLKSTST_CAM   | R    | 32                    | 0x0000 004C    | 0x4800 4F4C      | C          |

**3.7.1.10.2 CAM\_CM Registers****Table 3-226. CM\_FCLKEN\_CAM**

|                       |                                                 |                         |             |                 |        |
|-----------------------|-------------------------------------------------|-------------------------|-------------|-----------------|--------|
| <b>Address Offset</b> | 0x0000 0000                                     | <b>Physical Address</b> | 0x4800 4F00 | <b>Instance</b> | CAM_CM |
| <b>Description</b>    | Controls the modules functional clock activity. |                         |             |                 |        |
| <b>Type</b>           | RW                                              |                         |             |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                               | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                        | R    | 0x00000000 |
| 1    | EN_CSI2    | CSI2 functional clock control (96 MHz)<br>0x0: CSI2_96M_FCLK is disabled<br>0x1: CSI2_96M_FCLK is enabled | RW   | 0x0        |
| 0    | EN_CAM     | Camera functional clock control<br>0x0: CAM_MCLK is disabled<br>0x1: CAM_MCLK is enabled                  | RW   | 0x0        |

**Table 3-227. Register Call Summary for Register CM\_FCLKEN\_CAM**

PRCM Functional Description

- Internal Clock Controls: [0]

PRCM Basic Programming Model

- Power-Domain Clock Control Registers: [1]

PRCM Register Manual

- CAM\_CM Registers: [2]

**Table 3-228. CM\_ICLKEN\_CAM**

|                         |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--------|
| <b>Address Offset</b>   | 0x0000 0010             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| <b>Physical Address</b> | 0x4800 4F10             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| <b>Description</b>      | Instance                |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| <b>Type</b>             | CAM_CM                  |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| RESERVED                |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | EN_CAM |

| Bits | Field Name | Description                                                                                                                   | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                            | R    | 0x00000000 |
| 0    | EN_CAM     | Camera interface clock control<br>0x0: CAM_L3_ICK and CAM_L4_ICLK are disabled<br>0x1: CAM_L3_ICK and CAM_L4_ICLK are enabled | RW   | 0x0        |
|      |            |                                                                                                                               |      |            |

**Table 3-229. Register Call Summary for Register CM\_ICLKEN\_CAM**

PRCM Functional Description

- [Internal Clock Controls: \[0\]](#)

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[1\]](#)

PRCM Register Manual

- [CAM\\_CM Registers: \[2\]](#)

**Table 3-230. CM\_IDLEST\_CAM**

|                         |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--------|
| <b>Address Offset</b>   | 0x0000 0020             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| <b>Physical Address</b> | 0x4800 4F20             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| <b>Description</b>      | Instance                |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| <b>Type</b>             | CAM_CM                  |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  | ST_CAM |
| RESERVED                |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |

| Bits | Field Name | Description                                                                         | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Read returns 0.                                                                     | R    | 0x00000000 |
| 0    | ST_CAM     | Camera standby status.<br>0x0: Camera is active.<br>0x1: Camera is in standby mode. | R    | 0x1        |
|      |            |                                                                                     |      |            |

**Table 3-231. Register Call Summary for Register CM\_IDLEST\_CAM**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [CAM\\_CM Registers: \[1\]](#)

**Table 3-232. CM\_AUTOIDLE\_CAM**

|                         |                                                                                       |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |          |
|-------------------------|---------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|----------|
| <b>Address Offset</b>   | 0x0000 0030                                                                           |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |          |
| <b>Physical Address</b> | 0x4800 4F30                                                                           |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |          |
| <b>Description</b>      | This register controls the automatic control of the modules interface clock activity. |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |          |
| <b>Type</b>             | RW                                                                                    |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |          |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  | AUTO_CAM |

| Bits | Field Name | Description                                                                                                                                                                                                   | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                            | R    | 0x00000000 |
| 0    | AUTO_CAM   | <p>Camera auto clock control.</p> <p>0x0: Camera clock is unrelated to the domain state transition.</p> <p>0x1: Camera clock is automatically enabled or disabled along with the domain state transition.</p> | RW   | 0x0        |

**Table 3-233. Register Call Summary for Register CM\_AUTOIDLE\_CAM**

PRCM Functional Description

- Internal Clock Controls: [0]

PRCM Basic Programming Model

- Power-Domain Clock Control Registers: [1]

PRCM Register Manual

- CAM\_CM Registers: [2]

**Table 3-234. CM\_CLKSEL\_CAM**

|                         |                             |                       |                 |          |  |  |  |  |  |  |  |            |  |  |  |  |
|-------------------------|-----------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|------------|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0040                 |                       |                 |          |  |  |  |  |  |  |  |            |  |  |  |  |
| <b>Physical Address</b> | 0x4800 4F40                 |                       |                 |          |  |  |  |  |  |  |  |            |  |  |  |  |
| <b>Description</b>      | CAM module clock selection. |                       |                 |          |  |  |  |  |  |  |  |            |  |  |  |  |
| <b>Type</b>             | RW                          |                       |                 |          |  |  |  |  |  |  |  |            |  |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  | CLKSEL_CAM |  |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------|-------------|--------------|
| 31:6        | RESERVED          | Write 0s for future compatibility. Read returns 0.                   | R           | 0x0000000    |
| 5:0         | CLKSEL_CAM        | CAM_MCLK divider factor DPLL4 M5 (1 up to 32); Other enums: Reserved | RW          | 0x04         |
|             |                   | 0x1: CAM_MCLK is DPLL4 clock divided by 1                            |             |              |
|             |                   | 0x2: CAM_MCLK is DPLL4 clock divided by 2                            |             |              |
|             |                   | 0x3: CAM_MCLK is DPLL4 clock divided by 3                            |             |              |
|             |                   | 0x4: CAM_MCLK is DPLL4 clock divided by 4                            |             |              |
|             |                   | 0x5: CAM_MCLK is DPLL4 clock divided by 5                            |             |              |
|             |                   | 0x6: CAM_MCLK is DPLL4 clock divided by 6                            |             |              |
|             |                   | 0x7: CAM_MCLK is DPLL4 clock divided by 7                            |             |              |
|             |                   | 0x8: CAM_MCLK is DPLL4 clock divided by 8                            |             |              |
|             |                   | 0x9: CAM_MCLK is DPLL4 clock divided by 9                            |             |              |
|             |                   | 0xA: CAM_MCLK is DPLL4 clock divided by 10                           |             |              |
|             |                   | 0xB: CAM_MCLK is DPLL4 clock divided by 11                           |             |              |
|             |                   | 0xC: CAM_MCLK is DPLL4 clock divided by 12                           |             |              |
|             |                   | 0xD: CAM_MCLK is DPLL4 clock divided by 13                           |             |              |
|             |                   | 0xE: CAM_MCLK is DPLL4 clock divided by 14                           |             |              |
|             |                   | 0xF: CAM_MCLK is DPLL4 clock divided by 15                           |             |              |
|             |                   | 0x10: CAM_MCLK is DPLL4 clock divided by 16                          |             |              |
|             |                   | 0x11: CAM_MCLK is DPLL4 clock divided by 17                          |             |              |
|             |                   | 0x12: CAM_MCLK is DPLL4 clock divided by 18                          |             |              |
|             |                   | 0x13: CAM_MCLK is DPLL4 clock divided by 19                          |             |              |
|             |                   | 0x14: CAM_MCLK is DPLL4 clock divided by 20                          |             |              |
|             |                   | 0x15: CAM_MCLK is DPLL4 clock divided by 21                          |             |              |
|             |                   | 0x16: CAM_MCLK is DPLL4 clock divided by 22                          |             |              |
|             |                   | 0x17: CAM_MCLK is DPLL4 clock divided by 23                          |             |              |
|             |                   | 0x18: CAM_MCLK is DPLL4 clock divided by 24                          |             |              |
|             |                   | 0x19: CAM_MCLK is DPLL4 clock divided by 25                          |             |              |
|             |                   | 0x1A: CAM_MCLK is DPLL4 clock divided by 26                          |             |              |
|             |                   | 0x1B: CAM_MCLK is DPLL4 clock divided by 27                          |             |              |
|             |                   | 0x1C: CAM_MCLK is DPLL4 clock divided by 28                          |             |              |
|             |                   | 0x1D: CAM_MCLK is DPLL4 clock divided by 29                          |             |              |
|             |                   | 0x1E: CAM_MCLK is DPLL4 clock divided by 30                          |             |              |
|             |                   | 0x1F: CAM_MCLK is DPLL4 clock divided by 31                          |             |              |
|             |                   | 0x20: CAM_MCLK is DPLL4 clock divided by 32                          |             |              |

**Table 3-235. Register Call Summary for Register CM\_CLKSEL\_CAM**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [CAM\\_CM Registers: \[1\]](#)

**Table 3-236. CM\_SLEEPDEP\_CAM**

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:2        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                     | R           | 0x00000000   |
| 1           | EN_MPUs           | MPU domain dependency<br>0x0: CAM domain sleep dependency with MPU domain is disabled.<br>0x1: CAM domain sleep dependency with MPU domain is enabled. | RW          | 0x0          |
| 0           | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                     | R           | 0x0          |

**Table 3-237. Register Call Summary for Register CM\_SLEEPDEP\_CAM**

- **Power-Domain Clock Control Registers:** [0]

---

  - **PRCM Register Manual**
  - **CAM CM Registers:** [1]

**Table 3-238. CM CLKSTCTRL CAM**

|                         |                                                                                                               |                       |                 |
|-------------------------|---------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0048                                                                                                   |                       |                 |
| <b>Physical Address</b> | 0x4800 4F48                                                                                                   | <b>Instance</b>       | CAM_CM          |
| <b>Description</b>      | This register allows to enable or disable SW and HW supervised transition between ACTIVE and INACTIVE states. |                       |                 |
| <b>Type</b>             | RW                                                                                                            |                       |                 |
| 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 |
| RESERVED                |                                                                                                               |                       |                 |
| CLKTRCTRL_CAM           |                                                                                                               |                       |                 |

| Bits | Field Name    | Description                                                                                                                                                                                                                                                                                                                                                | Type | Reset      |
|------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                         | R    | 0x00000000 |
| 1:0  | CLKTRCTRL_CAM | <p>Controls the clock state transition of the CAMERA clock domain.</p> <p>0x0: Automatic transition is disabled</p> <p>0x1: Start a software supervised sleep transition on the domain</p> <p>0x2: Start a software supervised wake-up transition on the domain</p> <p>0x3: Automatic transition is enabled. Transition is supervised by the hardware.</p> | RW   | 0x0        |

**Table 3-239. Register Call Summary for Register CM\_CLKSTCTRL\_CAM**

PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#) [\[1\]](#) [\[2\]](#)

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[3\]](#)

PRCM Register Manual

- [CAM\\_CM Registers: \[4\]](#)

**Table 3-240. CM\_CLKSTST\_CAM**

|                  |                                                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------|------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Address Offset   | 0x0000 004C                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Physical Address | <a href="#">0x4800 4F4C</a>                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Description      | This register provides a status on the OCP interface clock activity in the domain. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type             | R                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED         |                                                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CLKACTIVITY_CAM |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name      | Description                                                                                                                        | Type | Reset      |
|------|-----------------|------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED        | Write 0s for future compatibility. Read returns 0.                                                                                 | R    | 0x00000000 |
| 0    | CLKACTIVITY_CAM | <p>Interface clock activity status</p> <p>0x0: No domain interface clock activity</p> <p>0x1: Domain interface clock is active</p> | R    | 0x0        |

**Table 3-241. Register Call Summary for Register CM\_CLKSTST\_CAM**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [CAM\\_CM Registers: \[1\]](#)

### 3.7.1.11 PER\_CM Registers

#### 3.7.1.11.1 PER\_CM Register Summary

**Table 3-242. PER\_CM Register Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|------------------|------|-----------------------|----------------|------------------|------------|
| CM_FCLKEN_PER    | RW   | 32                    | 0x0000 0000    | 0x4800 5000      | W          |
| CM_ICLKEN_PER    | RW   | 32                    | 0x0000 0010    | 0x4800 5010      | W          |
| CM_IDLEST_PER    | R    | 32                    | 0x0000 0020    | 0x4800 5020      | C          |
| CM_AUTOIDLE_PER  | RW   | 32                    | 0x0000 0030    | 0x4800 5030      | W          |
| CM_CLKSEL_PER    | RW   | 32                    | 0x0000 0040    | 0x4800 5040      | W          |
| CM_SLEEPDEP_PER  | RW   | 32                    | 0x0000 0044    | 0x4800 5044      | W          |
| CM_CLKSTCTRL_PER | RW   | 32                    | 0x0000 0048    | 0x4800 5048      | W          |
| CM_CLKSTST_PER   | R    | 32                    | 0x0000 004C    | 0x4800 504C      | C          |

**3.7.1.11.2 PER\_CM Registers****Table 3-243. CM\_FCLKEN\_PER**

|                                                                                             |                                                 |                                                                                                                                                                                                                            |             |          |        |
|---------------------------------------------------------------------------------------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------|--------|
| Address Offset                                                                              | 0x0000 0000                                     | Physical Address                                                                                                                                                                                                           | 0x4800 5000 | Instance | PER_CM |
| Description                                                                                 | Controls the modules functional clock activity. |                                                                                                                                                                                                                            |             |          |        |
| Type                                                                                        | RW                                              |                                                                                                                                                                                                                            |             |          |        |
| 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 | RESERVED                                        | EN_UART4<br>EN_GPIO6<br>EN_GPIO5<br>EN_GPIO4<br>EN_GPIO3<br>EN_GPIO2<br>EN_WDT3<br>EN_UART3<br>EN_GPT9<br>EN_GPT8<br>EN_GPT7<br>EN_GPT6<br>EN_GPT5<br>EN_GPT4<br>EN_GPT3<br>EN_GPT2<br>EN_MCBSP4<br>EN_MCBSP3<br>EN_MCBSP2 |             |          |        |

| Bits  | Field Name | Description                                                                                                                      | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:19 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                               | R    | 0x0000 |
| 18    | EN_UART4   | UART4 functional clock control.<br>0x0: UART 4 functional clock is disabled<br>0x1: UART 4 functional clock is enabled           | RW   | 0x0    |
| 17    | EN_GPIO6   | GPIO 6 functional clock control<br>0x0: GPIO 6 functional clock is disabled<br>0x1: GPIO 6 functional clock is enabled           | RW   | 0x0    |
| 16    | EN_GPIO5   | GPIO 5 functional clock control<br>0x0: GPIO 5 functional clock is disabled<br>0x1: GPIO 5 functional clock is enabled           | RW   | 0x0    |
| 15    | EN_GPIO4   | GPIO 4 functional clock control<br>0x0: GPIO 4 functional clock is disabled<br>0x1: GPIO 4 functional clock is enabled           | RW   | 0x0    |
| 14    | EN_GPIO3   | GPIO 3 functional clock control<br>0x0: GPIO 3 functional clock is disabled<br>0x1: GPIO 3 functional clock is enabled           | RW   | 0x0    |
| 13    | EN_GPIO2   | GPIO 2 functional clock control<br>0x0: GPIO 2 functional clock is disabled<br>0x1: GPIO 2 functional clock is enabled           | RW   | 0x0    |
| 12    | EN_WDT3    | WDTIMER 3 functional clock control.<br>0x0: WDTIMER 3 functional clock is disabled<br>0x1: WDTIMER 3 functional clock is enabled | RW   | 0x0    |

| Bits | Field Name | Description                                                                                                                      | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 11   | EN_UART3   | UART3 functional clock control.<br>0x0: UART 3 functional clock is disabled<br>0x1: UART 3 functional clock is enabled           | RW   | 0x0   |
| 10   | EN_GPT9    | GPTIMER 9 functional clock control.<br>0x0: GPTIMER 9 functional clock is disabled<br>0x1: GPTIMER 9 functional clock is enabled | RW   | 0x0   |
| 9    | EN_GPT8    | GPTIMER 8 functional clock control.<br>0x0: GPTIMER 8 functional clock is disabled<br>0x1: GPTIMER 8 functional clock is enabled | RW   | 0x0   |
| 8    | EN_GPT7    | GPTIMER 7 functional clock control.<br>0x0: GPTIMER 7 functional clock is disabled<br>0x1: GPTIMER 7 functional clock is enabled | RW   | 0x0   |
| 7    | EN_GPT6    | GPTIMER 6 functional clock control.<br>0x0: GPTIMER 6 functional clock is disabled<br>0x1: GPTIMER 6 functional clock is enabled | RW   | 0x0   |
| 6    | EN_GPT5    | GPTIMER 5 functional clock control.<br>0x0: GPTIMER 5 functional clock is disabled<br>0x1: GPTIMER 5 functional clock is enabled | RW   | 0x0   |
| 5    | EN_GPT4    | GPTIMER 4 functional clock control.<br>0x0: GPTIMER 4 functional clock is disabled<br>0x1: GPTIMER 4 functional clock is enabled | RW   | 0x0   |
| 4    | EN_GPT3    | GPTIMER 3 functional clock control.<br>0x0: GPTIMER 3 functional clock is disabled<br>0x1: GPTIMER 3 functional clock is enabled | RW   | 0x0   |
| 3    | EN_GPT2    | GPTIMER 2 functional clock control.<br>0x0: GPTIMER 2 functional clock is disabled<br>0x1: GPTIMER 2 functional clock is enabled | RW   | 0x0   |
| 2    | EN_MCBSP4  | McBSP 4 functional clock control.<br>0x0: McBSP 4 functional clock is disabled<br>0x1: McBSP 4 functional clock is enabled       | RW   | 0x0   |
| 1    | EN_MCBSP3  | McBSP3 functional clock control.<br>0x0: McBSP 3 functional clock is disabled<br>0x1: McBSP 3 functional clock is enabled        | RW   | 0x0   |
| 0    | EN_MCBSP2  | McBSP 2 functional clock control.<br>0x0: McBSP 2 functional clock is disabled<br>0x1: McBSP 2 functional clock is enabled       | RW   | 0x0   |

**Table 3-244. Register Call Summary for Register CM\_FCLKEN\_PER**

## PRCM Functional Description

- [Internal Clock Controls: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\]](#)

## PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[15\]](#)

## PRCM Register Manual

- [PER\\_CM Registers: \[16\]](#)

**Table 3-245. CM\_ICLKEN\_PER**

|                         |                                                |                                                                                                                                                                                                                            |                 |                 |        |
|-------------------------|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 0010                                    | <b>Physical Address</b>                                                                                                                                                                                                    | 0x4800 5010     | <b>Instance</b> | PER_CM |
| <b>Description</b>      | Controls the modules interface clock activity. |                                                                                                                                                                                                                            |                 |                 |        |
| <b>Type</b>             | RW                                             |                                                                                                                                                                                                                            |                 |                 |        |
| 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 |                 |        |
|                         |                                                | EN_UART4<br>EN_GPIO6<br>EN_GPIO5<br>EN_GPIO4<br>EN_GPIO3<br>EN_GPIO2<br>EN_WDT3<br>EN_UART3<br>EN_GPT9<br>EN_GPT8<br>EN_GPT7<br>EN_GPT6<br>EN_GPT5<br>EN_GPT4<br>EN_GPT3<br>EN_GPT2<br>EN_MCBSP4<br>EN_MCBSP3<br>EN_MCBSP2 |                 |                 |        |
| RESERVED                |                                                |                                                                                                                                                                                                                            |                 |                 |        |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:19       | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                | R           | 0x0000       |
| 18          | EN_UART4          | UART4 interface clock control.<br><br>0x0: UART 4 interface clock is disabled<br>0x1: UART 4 interface clock is enabled           | RW          | 0x0          |
| 17          | EN_GPIO6          | GPIO 6 interface clock control<br><br>0x0: GPIO 6 interface clock is disabled<br>0x1: GPIO 6 interface clock is enabled           | RW          | 0x0          |
| 16          | EN_GPIO5          | GPIO 5 interface clock control<br><br>0x0: GPIO 5 interface clock is disabled<br>0x1: GPIO 5 interface clock is enabled           | RW          | 0x0          |
| 15          | EN_GPIO4          | GPIO 4 interface clock control<br><br>0x0: GPIO 4 interface clock is disabled<br>0x1: GPIO 4 interface clock is enabled           | RW          | 0x0          |
| 14          | EN_GPIO3          | GPIO 3 interface clock control<br><br>0x0: GPIO 3 interface clock is disabled<br>0x1: GPIO 3 interface clock is enabled           | RW          | 0x0          |
| 13          | EN_GPIO2          | GPIO 2 interface clock control<br><br>0x0: GPIO 2 interface clock is disabled<br>0x1: GPIO 2 interface clock is enabled           | RW          | 0x0          |
| 12          | EN_WDT3           | WDTIMER 3 interface clock control.<br><br>0x0: WDTIMER 3 interface clock is disabled<br>0x1: WDTIMER 3 interface clock is enabled | RW          | 0x0          |
| 11          | EN_UART3          | UART3 interface clock control.<br><br>0x0: UART 3 interface clock is disabled<br>0x1: UART 3 interface clock is enabled           | RW          | 0x0          |
| 10          | EN_GPT9           | GPTIMER 9 interface clock control.<br><br>0x0: GPTIMER 9 interface clock is disabled<br>0x1: GPTIMER 9 interface clock is enabled | RW          | 0x0          |
| 9           | EN_GPT8           | GPTIMER 8 interface clock control.<br><br>0x0: GPTIMER 8 interface clock is disabled<br>0x1: GPTIMER 8 interface clock is enabled | RW          | 0x0          |
| 8           | EN_GPT7           | GPTIMER 7 interface clock control.<br><br>0x0: GPTIMER 7 interface clock is disabled<br>0x1: GPTIMER 7 interface clock is enabled | RW          | 0x0          |

| Bits | Field Name | Description                                                                                                                   | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7    | EN_GPT6    | GPTIMER 6 interface clock control.<br>0x0: GPTIMER 6 interface clock is disabled<br>0x1: GPTIMER 6 interface clock is enabled | RW   | 0x0   |
| 6    | EN_GPT5    | GPTIMER 5 interface clock control.<br>0x0: GPTIMER 5 interface clock is disabled<br>0x1: GPTIMER 5 interface clock is enabled | RW   | 0x0   |
| 5    | EN_GPT4    | GPTIMER 4 interface clock control.<br>0x0: GPTIMER 4 interface clock is disabled<br>0x1: GPTIMER 4 interface clock is enabled | RW   | 0x0   |
| 4    | EN_GPT3    | GPTIMER 3 interface clock control.<br>0x0: GPTIMER 3 interface clock is disabled<br>0x1: GPTIMER 3 interface clock is enabled | RW   | 0x0   |
| 3    | EN_GPT2    | GPTIMER 2 interface clock control.<br>0x0: GPTIMER 2 interface clock is disabled<br>0x1: GPTIMER 2 interface clock is enabled | RW   | 0x0   |
| 2    | EN_MCBSP4  | McBSP 4 interface clock control.<br>0x0: McBSP 4 interface clock is disabled<br>0x1: McBSP 4 interface clock is enabled       | RW   | 0x0   |
| 1    | EN_MCBSP3  | McBSP 3 interface clock control.<br>0x0: McBSP 3 interface clock is disabled<br>0x1: McBSP 3 interface clock is enabled       | RW   | 0x0   |
| 0    | EN_MCBSP2  | McBSP 2 interface clock control.<br>0x0: McBSP 2 interface clock is disabled<br>0x1: McBSP 2 interface clock is enabled       | RW   | 0x0   |

**Table 3-246. Register Call Summary for Register CM\_ICLKEN\_PER**

PRCM Functional Description

- [Internal Clock Controls: \[0\]](#)

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[1\]](#)

PRCM Register Manual

- [PER\\_CM Registers: \[2\]](#)

**Table 3-247. CM\_IDLEST\_PER**

|                       |                                                                                               |                         |             |                 |        |
|-----------------------|-----------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|--------|
| <b>Address Offset</b> | 0x0000 0020                                                                                   | <b>Physical Address</b> | 0x4800 5020 | <b>Instance</b> | PER_CM |
| <b>Description</b>    | Modules access availability monitoring. This register is read only and automatically updated. |                         |             |                 |        |
| <b>Type</b>           | R                                                                                             |                         |             |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                             | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:19 | RESERVED   | Read returns 0.                                                                                                                         | R    | 0x0000 |
| 18    | ST_UART4   | UART4 idle status.<br><br>0x0: UART 4 can be accessed.<br><br>0x1: UART 4 cannot be accessed. Any access may return an error.           | R    | 0x1    |
| 17    | ST_GPIO6   | GPIO 6 idle status<br><br>0x0: GPIO 6 can be accessed.<br><br>0x1: GPIO 6 cannot be accessed. Any access may return an error.           | R    | 0x1    |
| 16    | ST_GPIO5   | GPIO 5 idle status<br><br>0x0: GPIO 5 can be accessed.<br><br>0x1: GPIO 5 cannot be accessed. Any access may return an error.           | R    | 0x1    |
| 15    | ST_GPIO4   | GPIO 4 idle status<br><br>0x0: GPIO 4 can be accessed.<br><br>0x1: GPIO 4 cannot be accessed. Any access may return an error.           | R    | 0x1    |
| 14    | ST_GPIO3   | GPIO 3 idle status<br><br>0x0: GPIO 3 can be accessed.<br><br>0x1: GPIO 3 cannot be accessed. Any access may return an error.           | R    | 0x1    |
| 13    | ST_GPIO2   | GPIO 2 idle status<br><br>0x0: GPIO 2 can be accessed.<br><br>0x1: GPIO 2 cannot be accessed. Any access may return an error.           | R    | 0x1    |
| 12    | ST_WDT3    | WDTIMER 3 idle status.<br><br>0x0: WDTIMER 3 can be accessed.<br><br>0x1: WDTIMER 3 cannot be accessed. Any access may return an error. | R    | 0x1    |
| 11    | ST_UART3   | UART3 idle status.<br><br>0x0: UART 3 can be accessed.<br><br>0x1: UART 3 cannot be accessed. Any access may return an error.           | R    | 0x1    |
| 10    | ST_GPT9    | GPTIMER 9 idle status.<br><br>0x0: GPTIMER 9 can be accessed.<br><br>0x1: GPTIMER 9 cannot be accessed. Any access may return an error. | R    | 0x1    |
| 9     | ST_GPT8    | GPTIMER 8 idle status.<br><br>0x0: GPTIMER 8 can be accessed.<br><br>0x1: GPTIMER 8 cannot be accessed. Any access may return an error. | R    | 0x1    |
| 8     | ST_GPT7    | GPTIMER 7 idle status.<br><br>0x0: GPTIMER 7 can be accessed.<br><br>0x1: GPTIMER 7 cannot be accessed. Any access may return an error. | R    | 0x1    |
| 7     | ST_GPT6    | GPTIMER 6 idle status.<br><br>0x0: GPTIMER 6 can be accessed.<br><br>0x1: GPTIMER 6 cannot be accessed. Any access may return an error. | R    | 0x1    |
| 6     | ST_GPT5    | GPTIMER 5 idle status.<br><br>0x0: GPTIMER 5 can be accessed.<br><br>0x1: GPTIMER 5 cannot be accessed. Any access may return an error. | R    | 0x1    |

| Bits | Field Name | Description                                                                                                                     | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 5    | ST_GPT4    | GPTIMER 4 idle status.<br>0x0: GPTIMER 4 can be accessed.<br>0x1: GPTIMER 4 cannot be accessed. Any access may return an error. | R    | 0x1   |
| 4    | ST_GPT3    | GPTIMER 3 idle status.<br>0x0: GPTIMER 3 can be accessed.<br>0x1: GPTIMER 3 cannot be accessed. Any access may return an error. | R    | 0x1   |
| 3    | ST_GPT2    | GPTIMER 2 idle status.<br>0x0: GPTIMER 2 can be accessed.<br>0x1: GPTIMER 2 cannot be accessed. Any access may return an error. | R    | 0x1   |
| 2    | ST_MCBSP4  | McBSP 4 idle status.<br>0x0: McBSP 4 can be accessed.<br>0x1: McBSP 4 cannot be accessed. Any access may return an error.       | R    | 0x1   |
| 1    | ST_MCBSP3  | McBSP 3 idle status.<br>0x0: McBSP 3 can be accessed.<br>0x1: McBSP 3 cannot be accessed. Any access may return an error.       | R    | 0x1   |
| 0    | ST_MCBSP2  | McBSP 2 idle status.<br>0x0: McBSP 2 can be accessed.<br>0x1: McBSP 2 cannot be accessed. Any access may return an error.       | R    | 0x1   |

**Table 3-248. Register Call Summary for Register CM\_IDLEST\_PER**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [PER\\_CM Registers: \[1\]](#)

**Table 3-249. CM\_AUTOIDLE\_PER**

|                         |                                                                                                                                                                                                                                                |                                       |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| <b>Address Offset</b>   | 0x0000 0030                                                                                                                                                                                                                                    |                                       |
| <b>Physical Address</b> | 0x4800 5030                                                                                                                                                                                                                                    | <b>Instance</b>                       |
| <b>Description</b>      | This register controls the automatic control of the modules interface clock activity.                                                                                                                                                          |                                       |
| <b>Type</b>             | RW                                                                                                                                                                                                                                             |                                       |
| 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 |
| RESERVED                | AUTO_UART4<br>AUTO_GPO6<br>AUTO_GPO5<br>AUTO_GPO4<br>AUTO_GPO3<br>AUTO_GPO2<br>AUTO_WDT3<br>AUTO_UART3<br>AUTO_GPT9<br>AUTO_GPT8<br>AUTO_GPT7<br>AUTO_GPT6<br>AUTO_GPT5<br>AUTO_GPT4<br>AUTO_GPT2<br>AUTO_MCBSP4<br>AUTO_MCBSP3<br>AUTO_MCBSP2 |                                       |

| Bits  | Field Name | Description                                                                                                                                                                                                       | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:19 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                | R    | 0x0000 |
| 18    | AUTO_UART4 | UART4 auto clock control.<br>0x0: UART 4 interface clock is unrelated to the domain state transition.<br>0x1: UART 4 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0    |

| Bits | Field Name | Description                                                                                                                                                                                                                         | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 17   | AUTO_GPIO6 | GPIO 6 auto clock control<br><br>0x0: GPIO 6 interface clock is unrelated to the domain state transition.<br><br>0x1: GPIO 6 interface clock is automatically enabled or disabled along with the domain state transition.           | RW   | 0x0   |
| 16   | AUTO_GPIO5 | GPIO 5 auto clock control<br><br>0x0: GPIO 5 interface clock is unrelated to the domain state transition.<br><br>0x1: GPIO 5 interface clock is automatically enabled or disabled along with the domain state transition.           | RW   | 0x0   |
| 15   | AUTO_GPIO4 | GPIO 4 auto clock control<br><br>0x0: GPIO 4 interface clock is unrelated to the domain state transition.<br><br>0x1: GPIO 4 interface clock is automatically enabled or disabled along with the domain state transition.           | RW   | 0x0   |
| 14   | AUTO_GPIO3 | GPIO 3 auto clock control<br><br>0x0: GPIO 3 interface clock is unrelated to the domain state transition.<br><br>0x1: GPIO 3 interface clock is automatically enabled or disabled along with the domain state transition.           | RW   | 0x0   |
| 13   | AUTO_GPIO2 | GPIO 2 auto clock control<br><br>0x0: GPIO 2 interface clock is unrelated to the domain state transition.<br><br>0x1: GPIO 2 interface clock is automatically enabled or disabled along with the domain state transition.           | RW   | 0x0   |
| 12   | AUTO_WDT3  | WDTIMER 3 auto clock control.<br><br>0x0: WDTIMER 3 interface clock is unrelated to the domain state transition.<br><br>0x1: WDTIMER 3 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |
| 11   | AUTO_UART3 | UART3 auto clock control.<br><br>0x0: UART 3 interface clock is unrelated to the domain state transition.<br><br>0x1: UART 3 interface clock is automatically enabled or disabled along with the domain state transition.           | RW   | 0x0   |
| 10   | AUTO_GPT9  | GPTIMER 9 auto clock control.<br><br>0x0: GPTIMER 9 interface clock is unrelated to the domain state transition.<br><br>0x1: GPTIMER 9 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |
| 9    | AUTO_GPT8  | GPTIMER 8 auto clock control.<br><br>0x0: GPTIMER 8 interface clock is unrelated to the domain state transition.<br><br>0x1: GPTIMER 8 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |
| 8    | AUTO_GPT7  | GPTIMER 7 auto clock control.<br><br>0x0: GPTIMER 7 interface clock is unrelated to the domain state transition.<br><br>0x1: GPTIMER 7 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |
| 7    | AUTO_GPT6  | GPTIMER 6 auto clock control.<br><br>0x0: GPTIMER 6 interface clock is unrelated to the domain state transition.<br><br>0x1: GPTIMER 6 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |

| Bits | Field Name  | Description                                                                                                                                                                                                                         | Type | Reset |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 6    | AUTO_GPT5   | GPTIMER 5 auto clock control.<br><br>0x0: GPTIMER 5 interface clock is unrelated to the domain state transition.<br><br>0x1: GPTIMER 5 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |
| 5    | AUTO_GPT4   | GPTIMER 4 auto clock control.<br><br>0x0: GPTIMER 4 interface clock is unrelated to the domain state transition.<br><br>0x1: GPTIMER 4 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |
| 4    | AUTO_GPT3   | GPTIMER 3 auto clock control.<br><br>0x0: GPTIMER 3 interface clock is unrelated to the domain state transition.<br><br>0x1: GPTIMER 3 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |
| 3    | AUTO_GPT2   | GPTIMER 2 auto clock control.<br><br>0x0: GPTIMER 2 interface clock is unrelated to the domain state transition.<br><br>0x1: GPTIMER 2 interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0   |
| 2    | AUTO_MCBSP4 | McBSP 4 auto clock control.<br><br>0x0: McBSP 4 interface clock is unrelated to the domain state transition.<br><br>0x1: McBSP 4 interface clock is automatically enabled or disabled along with the domain state transition.       | RW   | 0x0   |
| 1    | AUTO_MCBSP3 | McBSP 3 auto clock control.<br><br>0x0: McBSP 3 interface clock is unrelated to the domain state transition.<br><br>0x1: McBSP 3 interface clock is automatically enabled or disabled along with the domain state transition.       | RW   | 0x0   |
| 0    | AUTO_MCBSP2 | McBSP 2 auto clock control.<br><br>0x0: McBSP 2 interface clock is unrelated to the domain state transition.<br><br>0x1: McBSP 2 interface clock is automatically enabled or disabled along with the domain state transition.       | RW   | 0x0   |

**Table 3-250. Register Call Summary for Register CM\_AUTOIDLE\_PER**

## PRCM Functional Description

- [Internal Clock Controls: \[0\]](#)

## PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[1\]](#)

## PRCM Register Manual

- [PER\\_CM Registers: \[2\]](#)

**Table 3-251. CM\_CLKSEL\_PER**

|                         |                                            |                         |             |                                                                                                                      |        |
|-------------------------|--------------------------------------------|-------------------------|-------------|----------------------------------------------------------------------------------------------------------------------|--------|
| <b>Address Offset</b>   | 0x0000 0040                                | <b>Physical Address</b> | 0x4800 5040 | <b>Instance</b>                                                                                                      | PER_CM |
| <b>Description</b>      | PER domain modules source clock selection. |                         |             |                                                                                                                      |        |
| <b>Type</b>             | RW                                         |                         |             |                                                                                                                      |        |
| 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                                                                                                      |        |
|                         |                                            |                         | RESERVED    | CLKSEL_GPT9<br>CLKSEL_GPT8<br>CLKSEL_GPT7<br>CLKSEL_GPT6<br>CLKSEL_GPT5<br>CLKSEL_GPT4<br>CLKSEL_GPT3<br>CLKSEL_GPT2 |        |

| Bits | Field Name  | Description                                                                         | Type | Reset    |
|------|-------------|-------------------------------------------------------------------------------------|------|----------|
| 31:8 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                  | R    | 0x000000 |
| 7    | CLKSEL_GPT9 | Selects GPTIMER 9 source clock<br>0x0: source is 32K_FCLK<br>0x1: source is SYS_CLK | RW   | 0x0      |
| 6    | CLKSEL_GPT8 | Selects GPTIMER 8 source clock<br>0x0: source is 32K_FCLK<br>0x1: source is SYS_CLK | RW   | 0x0      |
| 5    | CLKSEL_GPT7 | Selects GPTIMER 7 source clock<br>0x0: source is 32K_FCLK<br>0x1: source is SYS_CLK | RW   | 0x0      |
| 4    | CLKSEL_GPT6 | Selects GPTIMER 6 source clock<br>0x0: source is 32K_FCLK<br>0x1: source is SYS_CLK | RW   | 0x0      |
| 3    | CLKSEL_GPT5 | Selects GPTIMER 5 source clock<br>0x0: source is 32K_FCLK<br>0x1: source is SYS_CLK | RW   | 0x0      |
| 2    | CLKSEL_GPT4 | Selects GPTIMER 4 source clock<br>0x0: source is 32K_FCLK<br>0x1: source is SYS_CLK | RW   | 0x0      |
| 1    | CLKSEL_GPT3 | Selects GPTIMER 3 source clock<br>0x0: source is 32K_FCLK<br>0x1: source is SYS_CLK | RW   | 0x0      |
| 0    | CLKSEL_GPT2 | Selects GPTIMER 2 source clock<br>0x0: source is 32K_FCLK<br>0x1: source is SYS_CLK | RW   | 0x0      |

**Table 3-252. Register Call Summary for Register CM\_CLKSEL\_PER**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [PER\\_CM Registers: \[1\]](#)

**Table 3-253. CM\_SLEEPDEP\_PER**

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:3        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                        | R           | 0x00000000   |
| 2           | EN_IVA2           | IVA2 domain dependency<br>0x0: PER domain sleep dependency with IVA2 domain is disabled.<br>0x1: PER domain sleep dependency with IVA2 domain is enabled. | RW          | 0x0          |
| 1           | EN_MPUs           | MPU domain dependency<br>0x0: PER domain sleep dependency with MPU domain is disabled.<br>0x1: PER domain sleep dependency with MPU domain is enabled.    | RW          | 0x0          |
| 0           | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                        | RW          | 0x0          |

**Table 3-254. Register Call Summary for Register CM\_SLEEPDEP\_PER**

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

  - [PER\\_CMR Registers: \[1\]](#)

Table 3-255 CM CI KSTCTBI PER

| Bits | Field Name    | Description                                                                                                                                                                                                                                                                                                                                                    | Type | Reset      |
|------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                             | R    | 0x00000000 |
| 1:0  | CLKTRCTRL_PER | <p>Controls the clock state transition of the PERIPHERAL clock domain.</p> <p>0x0: Automatic transition is disabled</p> <p>0x1: Start a software supervised sleep transition on the domain</p> <p>0x2: Start a software supervised wake-up transition on the domain</p> <p>0x3: Automatic transition is enabled. Transition is supervised by the HardWare.</p> | RW   | 0x0        |

**Table 3-256. Register Call Summary for Register CM\_CLKSTCTRL\_PER**

PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#) [\[1\]](#) [\[2\]](#)

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[3\]](#)

PRCM Register Manual

- [PER\\_CM Registers: \[4\]](#)

**Table 3-257. CM\_CLKSTST\_PER**

|                         |                                                                                    |  |          |                 |
|-------------------------|------------------------------------------------------------------------------------|--|----------|-----------------|
| Address Offset          | 0x0000 004C                                                                        |  | Instance | PER_CM          |
| Physical Address        | <a href="#">0x4800 504C</a>                                                        |  |          |                 |
| Description             | This register provides a status on the OCP interface clock activity in the domain. |  |          |                 |
| Type                    | R                                                                                  |  |          |                 |
| 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                                                                    |  |          |                 |
| RESERVED                |                                                                                    |  |          | CLKACTIVITY_PER |

| Bits | Field Name      | Description                                                                                                                        | Type | Reset      |
|------|-----------------|------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED        | Write 0s for future compatibility. Read returns 0.                                                                                 | R    | 0x00000000 |
| 0    | CLKACTIVITY_PER | <p>Interface clock activity status</p> <p>0x0: No domain interface clock activity</p> <p>0x1: Domain interface clock is active</p> | R    | 0x0        |

**Table 3-258. Register Call Summary for Register CM\_CLKSTST\_PER**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [PER\\_CM Registers: \[1\]](#)

### 3.7.1.12 EMU\_CM Registers

#### 3.7.1.12.1 EMU\_CM Register Summary

**Table 3-259. EMU\_CM Register Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|------------------|------|-----------------------|----------------|------------------|------------|
| CM_CLKSEL1_EMU   | RW   | 32                    | 0x0000 0040    | 0x4800 5140      | W          |
| CM_CLKSTCTRL_EMU | RW   | 32                    | 0x0000 0048    | 0x4800 5148      | C          |
| CM_CLKSTST_EMU   | R    | 32                    | 0x0000 004C    | 0x4800 514C      | C          |
| CM_CLKSEL2_EMU   | RW   | 32                    | 0x0000 0050    | 0x4800 5150      | W          |
| CM_CLKSEL3_EMU   | RW   | 32                    | 0x0000 0054    | 0x4800 5154      | W          |

### 3.7.1.12.2 EMU\_CM Registers

**Table 3-260. CM\_CLKSEL1\_EMU**

|                       |                          |                         |             |                 |        |
|-----------------------|--------------------------|-------------------------|-------------|-----------------|--------|
| <b>Address Offset</b> | 0x0000 0040              | <b>Physical Address</b> | 0x4800 5140 | <b>Instance</b> | EMU_CM |
| <b>Description</b>    | Modules clock selection. |                         |             |                 |        |
| <b>Type</b>           | RW                       |                         |             |                 |        |

| 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 |
|----------|----|-----------|----|----------|----|-----------|----|----------|----|-----------------|----|-------------|----|--------------|----|--------------|----|----------------|----|----------|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    | DIV_DPLL4 |    | RESERVED |    | DIV_DPLL3 |    | RESERVED |    | CLKSEL_TRACECLK |    | CLKSEL_PCLK |    | CLKSEL_PCLK2 |    | CLKSEL_ATCLK |    | TRACE_MUX_CTRL |    | MUX_CTRL |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x0   |
| 29:24 | DIV_DPLL4  | DPLL4 M6 clock divider factor (1 up to 32); Other enums:<br>Reserved<br>0x1: EMU_PER_ALWON_CLK is DPLL4 clock divided by 1<br>0x2: EMU_PER_ALWON_CLK is DPLL4 clock divided by 2<br>0x3: EMU_PER_ALWON_CLK is DPLL4 clock divided by 3<br>0x4: EMU_PER_ALWON_CLK is DPLL4 clock divided by 4<br>0x5: EMU_PER_ALWON_CLK is DPLL4 clock divided by 5<br>0x6: EMU_PER_ALWON_CLK is DPLL4 clock divided by 6<br>0x7: EMU_PER_ALWON_CLK is DPLL4 clock divided by 7<br>0x8: EMU_PER_ALWON_CLK is DPLL4 clock divided by 8<br>0x9: EMU_PER_ALWON_CLK is DPLL4 clock divided by 9<br>0xA: EMU_PER_ALWON_CLK is DPLL4 clock divided by 10<br>0xB: EMU_PER_ALWON_CLK is DPLL4 clock divided by 11<br>0xC: EMU_PER_ALWON_CLK is DPLL4 clock divided by 12<br>0xD: EMU_PER_ALWON_CLK is DPLL4 clock divided by 13<br>0xE: EMU_PER_ALWON_CLK is DPLL4 clock divided by 14<br>0xF: EMU_PER_ALWON_CLK is DPLL4 clock divided by 15<br>0x10: EMU_PER_ALWON_CLK is DPLL4 clock divided by 16<br>0x11: EMU_PER_ALWON_CLK is DPLL4 clock divided by 17<br>0x12: EMU_PER_ALWON_CLK is DPLL4 clock divided by 18<br>0x13: EMU_PER_ALWON_CLK is DPLL4 clock divided by 19<br>0x14: EMU_PER_ALWON_CLK is DPLL4 clock divided by 20 | RW   | 0x04  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|       |            | 0x15: EMU_PER_ALWON_CLK is DPLL4 clock divided by 21<br>0x16: EMU_PER_ALWON_CLK is DPLL4 clock divided by 22<br>0x17: EMU_PER_ALWON_CLK is DPLL4 clock divided by 23<br>0x18: EMU_PER_ALWON_CLK is DPLL4 clock divided by 24<br>0x19: EMU_PER_ALWON_CLK is DPLL4 clock divided by 25<br>0x1A: EMU_PER_ALWON_CLK is DPLL4 clock divided by 26<br>0x1B: EMU_PER_ALWON_CLK is DPLL4 clock divided by 27<br>0x1C: EMU_PER_ALWON_CLK is DPLL4 clock divided by 28<br>0x1D: EMU_PER_ALWON_CLK is DPLL4 clock divided by 29<br>0x1E: EMU_PER_ALWON_CLK is DPLL4 clock divided by 30<br>0x1F: EMU_PER_ALWON_CLK is DPLL4 clock divided by 31<br>0x20: EMU_PER_ALWON_CLK is DPLL4 clock divided by 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |       |
| 23:22 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R    | 0x0   |
| 21:16 | DIV_DPLL3  | DPLL3_M3X2 clock divider factor (1 up to 32); Other enums:<br>Reserved<br>0x1: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 1<br>0x2: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 2<br>0x3: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 3<br>0x4: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 4<br>0x5: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 5<br>0x6: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 6<br>0x7: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 7<br>0x8: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 8<br>0x9: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 9<br>0xA: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 10<br>0xB: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 11<br>0xC: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 12<br>0xD: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 13<br>0xE: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 14<br>0xF: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 15<br>0x10: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 16<br>0x11: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 17<br>0x12: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 18<br>0x13: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 19<br>0x14: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 20<br>0x15: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 21<br>0x16: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 22 | RW   | 0x04  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
|             |                   | 0x17: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 23<br>0x18: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 24<br>0x19: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 25<br>0x1A: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 26<br>0x1B: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 27<br>0x1C: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 28<br>0x1D: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 29<br>0x1E: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 30<br>0x1F: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 31<br>0x20: EMU_CORE_ALWON_CLK is DPLL3 clock divided by 32 |             |              |
| 15:14       | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R           | 0x0          |
| 13:11       | CLKSEL_TRACECLK   | Selects the TRACE clock; Other enums: Reserved<br>0x1: TRACECLK.FCLK is the selected TRACE source clock divided by 1<br>0x2: TRACECLK.FCLK is the selected TRACE source clock divided by 2<br>0x4: TRACECLK.FCLK is the selected TRACE source clock divided by 4                                                                                                                                                                                                                                                                                                                       | RW          | 0x1          |
| 10:8        | CLKSEL_PCLK       | Selects the PCLK clock; Other enums: Reserved<br>0x2: PCLK.FCLK is the selected PCLK source clock divided by 2<br>0x3: PCLK.FCLK is the selected PCLK source clock divided by 3<br>0x4: PCLK.FCLK is the selected PCLK source clock divided by 4<br>0x6: PCLK.FCLK is the selected PCLK source clock divided by 6                                                                                                                                                                                                                                                                      | RW          | 0x2          |
| 7:6         | CLKSEL_PCLKX2     | Selects the PCLKx2 clock; Other enums: Reserved<br>0x1: PCLKx2.FCLK is the selected PCLK source clock divided by 1<br>0x2: PCLKx2.FCLK is the selected PCLK source clock divided by 2<br>0x3: PCLKx2.FCLK is the selected PCLK source clock divided by 3                                                                                                                                                                                                                                                                                                                               | RW          | 0x1          |
| 5:4         | CLKSEL_ATCLK      | Selects the ATCLK clock; Other enums: Reserved<br>0x1: ATCLK.FCLK is the selected ATCLK source clock divided by 1<br>0x2: ATCLK.FCLK is the selected ATCLK source clock divided by 2                                                                                                                                                                                                                                                                                                                                                                                                   | RW          | 0x1          |
| 3:2         | TRACE_MUX_CTRL    | Selection of TRACECLK.FCLK source clock<br>0x0: TRACE source clock is SYS_CLK<br>0x1: TRACE source clock is EMU_CORE_ALWON_CLK<br>0x2: TRACE source clock is EMU_PER_ALWON clock<br>0x3: TRACE source clock is EMU_MPU_ALWON clock                                                                                                                                                                                                                                                                                                                                                     | RW          | 0x0          |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1:0  | MUX_CTRL   | Selection of ATCLK.FCLK, PCLK.FCLK and PCLKx2.FCLK source clock<br>0x0: ATCLK, PCLK and PCLKx2 source clock is SYS_CLK<br>0x1: ATCLK, PCLK and PCLKx2 source clock is EMU_CORE_ALWON_CLK<br>0x2: ATCLK, PCLK and PCLKx2 source clock is EMU_PER_ALWON clock<br>0x3: ATCLK, PCLK and PCLKx2 source clock is EMU_MPU_ALWON_CLK | RW   | 0x0   |

**Table 3-261. Register Call Summary for Register CM\_CLKSEL1\_EMU**

PRCM Register Manual

- [EMU\\_CM Registers: \[0\]](#)

**Table 3-262. CM\_CLKSTCTRL\_EMU**

|                         |                                                                                                               |                                       |
|-------------------------|---------------------------------------------------------------------------------------------------------------|---------------------------------------|
| Address Offset          | 0x0000 0048                                                                                                   |                                       |
| Physical Address        | 0x4800 5148                                                                                                   | Instance<br>EMU_CM                    |
| Description             | This register allows to enable or disable SW and HW supervised transition between ACTIVE and INACTIVE states. |                                       |
| Type                    | RW                                                                                                            |                                       |
| 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 |
| RESERVED                |                                                                                                               | CLKTRCTRL_EMU                         |

| Bits | Field Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset      |
|------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                     | R    | 0x00000000 |
| 1:0  | CLKTRCTRL_EMU | Controls the clock state transition of the EMULATION clock domain.<br>0x0: Reserved<br>0x1: Start a software supervised sleep transition on the domain<br>0x2: Start a software supervised wake-up transition on the domain or maintain emulation domain active. (force wakeup has to be kept asserted to keep Emulation domain ON)<br>0x3: Automatic transition is enabled. Transition is supervised by the HardWare. | RW   | 0x2        |

**Table 3-263. Register Call Summary for Register CM\_CLKSTCTRL\_EMU**

PRCM Functional Description

- [Device Wake-Up Events: \[0\] \[1\] \[2\]](#)

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[3\]](#)

PRCM Register Manual

- [EMU\\_CM Registers: \[4\]](#)

**Table 3-264. CM\_CLKSTST\_EMU**

|                         |                                                                                                             |                         |                 |                 |        |
|-------------------------|-------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 004C                                                                                                 | <b>Physical Address</b> | 0x4800 514C     | <b>Instance</b> | EMU_CM |
| <b>Description</b>      | This register provides a status on the clock activity in the domain (depends on the selected source clock). |                         |                 |                 |        |
| <b>Type</b>             | R                                                                                                           |                         |                 |                 |        |
| 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 |                 |        |
| RESERVED                |                                                                                                             |                         |                 |                 |        |

CLKACTIVITY\_EMU

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:1        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                               | R           | 0x00000000   |
| 0           | CLKACTIVITY_EMU   | Clock activity status (depends on the selected source clock)<br><br>0x0: No domain clock activity<br>0x1: Domain clock is active | R           | 0x0          |
|             |                   |                                                                                                                                  |             |              |

**Table 3-265. Register Call Summary for Register CM\_CLKSTST\_EMU**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [EMU\\_CM Registers: \[1\]](#)

**Table 3-266. CM\_CLKSEL2\_EMU**

|                         |                                                          |                         |                    |                 |                   |
|-------------------------|----------------------------------------------------------|-------------------------|--------------------|-----------------|-------------------|
| <b>Address Offset</b>   | 0x0000 0050                                              | <b>Physical Address</b> | 0x4800 5150        | <b>Instance</b> | EMU_CM            |
| <b>Description</b>      | This register provides override controls over the DPLL3. |                         |                    |                 |                   |
| <b>Type</b>             | RW                                                       |                         |                    |                 |                   |
| 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    |                 |                   |
| RESERVED                |                                                          | OVERWRITE_ENABLE        | CORE_DPLL_EMU_MULT | RESERVED        | CORE_DPLL_EMU_DIV |

| <b>Bits</b> | <b>Field Name</b>  | <b>Description</b>                                                                                                                                                                | <b>Type</b> | <b>Reset</b> |
|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:20       | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                                                | R           | 0x000        |
| 19          | OVERWRITE_ENABLE   | This bit allows to enable or disable the emulation override controls<br><br>0x0: The emulation override controls are disabled<br>0x1: The emulation override controls are enabled | RW          | 0x0          |
| 18:8        | CORE_DPLL_EMU_MULT | DPLL3 override multiplier factor (0 to 2047)                                                                                                                                      | RW          | 0x000        |

| Bits | Field Name        | Description                                        | Type | Reset |
|------|-------------------|----------------------------------------------------|------|-------|
| 7    | RESERVED          | Write 0s for future compatibility. Read returns 0. | R    | 0x0   |
| 6:0  | CORE_DPLL_EMU_DIV | DPLL3 override divider factor (0 to 127)           | RW   | 0x00  |

**Table 3-267. Register Call Summary for Register CM\_CLKSEL2\_EMU**

PRCM Register Manual

- [EMU\\_CM Registers: \[0\]](#)

**Table 3-268. CM\_CLKSEL3\_EMU**

|                       |                                                                    |                         |             |                 |        |
|-----------------------|--------------------------------------------------------------------|-------------------------|-------------|-----------------|--------|
| <b>Address Offset</b> | 0x0000 0054                                                        | <b>Physical Address</b> | 0x4800 5154 | <b>Instance</b> | EMU_CM |
| <b>Description</b>    | This register provides override controls over the PERIPHERAL DPLL. |                         |             |                 |        |
| <b>Type</b>           | RW                                                                 |                         |             |                 |        |



| Bits  | Field Name           | Description                                                                                                                                                                   | Type | Reset |
|-------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:20 | RESERVED             | Write 0s for future compatibility. Read returns 0.                                                                                                                            | R    | 0x000 |
| 19    | OVERRIDE_ENABLE      | This bit allows to enable or disable the emulation override controls<br>0x0: The emulation override controls are disabled<br>0x1: The emulation override controls are enabled | RW   | 0x0   |
| 18:8  | PERIPH_DPLL_EMU_MULT | DPLL4 override multiplier factor (0 to 2047)                                                                                                                                  | RW   | 0x000 |
| 7     | RESERVED             | Write 0s for future compatibility. Read returns 0.                                                                                                                            | R    | 0x0   |
| 6:0   | PERIPH_DPLL_EMU_DIV  | DPLL4 override divider factor (0 to 127)                                                                                                                                      | RW   | 0x00  |

**Table 3-269. Register Call Summary for Register CM\_CLKSEL3\_EMU**

PRCM Register Manual

- [EMU\\_CM Registers: \[0\]](#)

### 3.7.1.13 Global\_Reg\_CM Registers

#### 3.7.1.13.1 Global\_Reg\_CM Register Summary

**Table 3-270. Global\_Reg\_CM Register Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|---------------|------|-----------------------|----------------|------------------|------------|
| CM_POLCTRL    | RW   | 32                    | 0x0000 009C    | 0x4800 529C      | C          |

#### 3.7.1.13.2 Global\_Reg\_CM Registers

**Table 3-271. CM\_POLCTRL**

|                         |                                                                              |                         |                 |                 |               |
|-------------------------|------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 009C                                                                  | <b>Physical Address</b> | 0x4800 529C     | <b>Instance</b> | Global_Reg_CM |
| <b>Description</b>      | This register allows setting the polarity of device outputs control signals. |                         |                 |                 |               |
| <b>Type</b>             | RW                                                                           |                         |                 |                 |               |
| 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 |                 |               |
| RESERVED                |                                                                              |                         |                 |                 |               |

CLKOUT2\_POL

| Bits | Field Name  | Description                                                                                                                                                    | Type | Reset      |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                             | R    | 0x00000000 |
| 0    | CLKOUT2_POL | Controls the external output clock 2 polarity when disabled<br><br>0x0: sys_clkout2 is gated low when inactive<br>0x1: sys_clkout2 is gated high when inactive | RW   | 0x0        |

**Table 3-272. Register Call Summary for Register CM\_POLCTRL**

PRCM Functional Description

- [External Clock Controls: \[0\]](#)

PRCM Basic Programming Model

- [Output Signal Polarity Control Registers: \[1\]](#)

PRCM Register Manual

- [Global\\_Reg\\_CM Registers: \[2\]](#)

### 3.7.1.14 NEON\_CM Registers

#### 3.7.1.14.1 NEON\_CM Register Summary

**Table 3-273. NEON\_CM Register Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|-------------------|------|-----------------------|----------------|------------------|------------|
| CM_IDLEST_NEON    | R    | 32                    | 0x0000 0020    | 0x4800 5320      | C          |
| CM_CLKSTCTRL_NEON | RW   | 32                    | 0x0000 0048    | 0x4800 5348      | W          |

#### 3.7.1.14.2 NEON\_CM Registers

**Table 3-274. CM\_IDLEST\_NEON**

|                         |                                                                                               |                         |                 |                 |         |
|-------------------------|-----------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0020                                                                                   | <b>Physical Address</b> | 0x4800 5320     | <b>Instance</b> | NEON_CM |
| <b>Description</b>      | Modules access availability monitoring. This register is read only and automatically updated. |                         |                 |                 |         |
| <b>Type</b>             | R                                                                                             |                         |                 |                 |         |
| 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 |                 |         |
| RESERVED                |                                                                                               |                         |                 |                 |         |

| Bits | Field Name | Description                                                                 | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Read returns 0.                                                             | R    | 0x00000000 |
| 0    | ST_NEON    | NEON standby status.<br>0x0: NEON is active<br>0x1: NEON is in standby mode | R    | 0x1        |

**Table 3-275. Register Call Summary for Register CM\_IDLEST\_NEON**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [NEON\\_CM Registers: \[1\]](#)

**Table 3-276. CM\_CLKSTCTRL\_NEON**

|                         |                                                                                                                                                          |                         |                 |                 |         |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0048                                                                                                                                              | <b>Physical Address</b> | 0x4800 5348     | <b>Instance</b> | NEON_CM |
| <b>Description</b>      | This register enables the domain power state transition. It controls the HW supervised domain power state transition between ACTIVE and INACTIVE states. |                         |                 |                 |         |
| <b>Type</b>             | RW                                                                                                                                                       |                         |                 |                 |         |
| 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 |                 |         |
| RESERVED                |                                                                                                                                                          |                         |                 |                 |         |

| Bits | Field Name     | Description                                                                                                                                                                                                                                                                                                                       | Type | Reset      |
|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                | R    | 0x00000000 |
| 1:0  | CLKTRCTRL_NEON | Controls the clock state transition of the NEON clock domain.<br>0x0: Automatic transition is disabled<br>0x1: Start a software supervised sleep transition on the domain<br>0x2: Start a software supervised wake-up transition on the domain<br>0x3: Automatic transition is enabled. Transition is supervised by the HardWare. | RW   | 0x0        |

**Table 3-277. Register Call Summary for Register CM\_CLKSTCTRL\_NEON**
**PRCM Functional Description**

- [Device Wake-Up Events: \[0\] \[1\] \[2\]](#)

**PRCM Basic Programming Model**

- [Power-Domain Clock Control Registers: \[3\]](#)

**PRCM Register Manual**

- [NEON\\_CM Registers: \[4\]](#)

### 3.7.1.15 USBHOST\_CM Registers

#### 3.7.1.15.1 USBHOST\_CM Register Summary

**Table 3-278. USBHOST\_CM Register Summary**

| Register Name        | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|----------------------|------|-----------------------|----------------|------------------|------------|
| CM_FCLKEN_USBHOST    | RW   | 32                    | 0x0000 0000    | 0x4800 5400      | W          |
| CM_ICLKEN_USBHOST    | RW   | 32                    | 0x0000 0010    | 0x4800 5410      | W          |
| CM_IDLEST_USBHOST    | R    | 32                    | 0x0000 0020    | 0x4800 5420      | C          |
| CM_AUTOIDLE_USBHOST  | RW   | 32                    | 0x0000 0030    | 0x4800 5430      | W          |
| CM_SLEEPDEP_USBHOST  | RW   | 32                    | 0x0000 0044    | 0x4800 5444      | W          |
| CM_CLKSTCTRL_USBHOST | RW   | 32                    | 0x0000 0048    | 0x4800 5448      | W          |
| CM_CLKSTST_USBHOST   | R    | 32                    | 0x0000 004C    | 0x4800 544C      | C          |

#### 3.7.1.15.2 USBHOST\_CM Registers

**Table 3-279. CM\_FCLKEN\_USBHOST**

|                         |                                                 |                         |                 |                 |                            |
|-------------------------|-------------------------------------------------|-------------------------|-----------------|-----------------|----------------------------|
| <b>Address Offset</b>   | 0x0000 0000                                     | <b>Physical Address</b> | 0x4800 5400     | <b>Instance</b> | USBHOST_CM                 |
| <b>Description</b>      | Controls the modules functional clock activity. |                         |                 |                 |                            |
| <b>Type</b>             | RW                                              |                         |                 |                 |                            |
| 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 |                 |                            |
|                         |                                                 |                         |                 | RESERVED        | EN_USBHOST2<br>EN_USBHOST1 |

| Bits | Field Name  | Description                                                                                                          | Type | Reset      |
|------|-------------|----------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                   | R    | 0x00000000 |
| 1    | EN_USBHOST2 | USB HOST 120-MHz functional clock control<br>0x0: USBHOST_120M_FCLK is disabled<br>0x1: USBHOST_120M_FCLK is enabled | RW   | 0x0        |
| 0    | EN_USBHOST1 | USB HOST 48-MHz functional clock control<br>0x0: USBHOST_48M_FCLK is disabled<br>0x1: USBHOST_48M_FCLK is enabled    | RW   | 0x0        |

**Table 3-280. Register Call Summary for Register CM\_FCLKEN\_USBHOST**

## PRCM Functional Description

- [Clock Distribution: \[0\] \[1\]](#)
- [Internal Clock Controls: \[2\] \[3\] \[4\]](#)

## PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[5\]](#)

## PRCM Register Manual

- [USBHOST\\_CM Registers: \[6\]](#)

**Table 3-281. CM\_ICLKEN\_USBHOST**

|                         |                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                 |
|-------------------------|------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----------------|
| <b>Address Offset</b>   | 0x0000 0010                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                 |
| <b>Physical Address</b> | 0x4800 5410                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | USBHOST_CM      |
| <b>Description</b>      | Controls the modules interface clock activity. |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                 |
| <b>Type</b>             | RW                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                 |
| 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 |
| RESERVED                |                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                 |
| EN_USBHOST              |                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                 |

| Bits | Field Name | Description                                                                                                                   | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                            | R    | 0x00000000 |
| 0    | EN_USBHOST | USB HOST interface clock control<br><br>0x0: USB HOST interface clock is disabled<br>0x1: USB HOST interface clock is enabled | RW   | 0x0        |

**Table 3-282. Register Call Summary for Register CM\_ICLKEN\_USBHOST**

## PRCM Functional Description

- [Internal Clock Controls: \[0\]](#)

## PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[1\]](#)

## PRCM Register Manual

- [USBHOST\\_CM Registers: \[2\]](#)

**Table 3-283. CM\_IDLEST\_USBHOST**

|                         |                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |
|-------------------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|------------|
| <b>Address Offset</b>   | 0x0000 0020                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |
| <b>Physical Address</b> | 0x4800 5420                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | USBHOST_CM |
| <b>Description</b>      | Modules access availability monitoring. This register is read only and automatically updated. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |
| <b>Type</b>             | R                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----------------|------------------|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | ST_USBHOST_IDLE | ST_USBHOST_STDBY |   |

| Bits | Field Name       | Description                                                                                                | Type | Reset      |
|------|------------------|------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED         | Read returns 0.                                                                                            | R    | 0x00000000 |
| 1    | ST_USBHOST_IDLE  | USB HOST idle status.<br>0x0: USB HOST is active.<br>0x1: USB HOST is in idle mode and cannot be accessed. | R    | 0x1        |
| 0    | ST_USBHOST_STDBY | USB HOST standby status.<br>0x0: USB HOST is active.<br>0x1: USB HOST is in standby mode.                  | R    | 0x1        |

**Table 3-284. Register Call Summary for Register CM\_IDLEST\_USBHOST**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [USBHOST\\_CM Registers: \[1\]](#)

**Table 3-285. CM\_AUTOIDLE\_USBHOST**

|                         |                                                                                       |    |                 |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|---------------------------------------------------------------------------------------|----|-----------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 0030                                                                           |    | <b>Instance</b> | USBHOST_CM   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x4800 5430                                                                           |    |                 |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | This register controls the automatic control of the modules interface clock activity. |    |                 |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                                                    |    |                 |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                                                       |    |                 | AUTO_USBHOST |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name   | Description                                                                                                                                                                                                              | Type | Reset      |
|------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                       | R    | 0x00000000 |
| 0    | AUTO_USBHOST | USB HOST auto clock control.<br>0x0: USB HOST interface clock is unrelated to the domain state transition.<br>0x1: USB HOST interface clock is automatically enabled or disabled along with the domain state transition. | RW   | 0x0        |

**Table 3-286. Register Call Summary for Register CM\_AUTOIDLE\_USBHOST**

PRCM Functional Description

- [Internal Clock Controls: \[0\]](#)

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[1\]](#)

PRCM Register Manual

- [USBHOST\\_CM Registers: \[2\]](#)

**Table 3-287. CM\_SLEEPDEP\_USBHOST**

|                         |                                                                                                                             |                       |                 |         |       |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|---------|-------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0044                                                                                                                 |                       |                 |         |       |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 5444                                                                                                                 |                       |                 |         |       |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register allows enabling or disabling the sleep transition dependency of USB HOST domain with respect to other domain. |                       |                 |         |       |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                          |                       |                 |         |       |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | EN_IVA2 | EN_MP | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                                                                         | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                  | R    | 0x00000000 |
| 2    | EN_IVA2    | IVA2 domain dependency<br>0x0: USB HOST domain sleep dependency with IVA2 domain is disabled.<br>0x1: USB HOST domain sleep dependency with IVA2 domain is enabled. | RW   | 0x0        |
| 1    | EN_MP      | MPU domain dependency<br>0x0: USB HOST domain sleep dependency with MPU domain is disabled.<br>0x1: USB HOST domain sleep dependency with MPU domain is enabled.    | RW   | 0x0        |
| 0    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                  | R    | 0x0        |

**Table 3-288. Register Call Summary for Register CM\_SLEEPDEP\_USBHOST**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [USBHOST\\_CM Registers: \[1\]](#)

**Table 3-289. CM\_CLKSTCTRL\_USBHOST**

|                         |                                                                                                                                                          |                         |                 |                 |                   |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-------------------|
| <b>Address Offset</b>   | 0x0000 0048                                                                                                                                              | <b>Physical Address</b> | 0x4800 5448     | <b>Instance</b> | USBHOST_CM        |
| <b>Description</b>      | This register enables the domain power state transition. It controls the HW supervised domain power state transition between ACTIVE and INACTIVE states. |                         |                 |                 |                   |
| <b>Type</b>             | RW                                                                                                                                                       |                         |                 |                 |                   |
| 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 |                 |                   |
| RESERVED                |                                                                                                                                                          |                         |                 |                 | CLKTRCTRL_USBHOST |

| Bits | Field Name        | Description                                                                                                                                                                                                                                                                                                                                                  | Type | Reset      |
|------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                           | R    | 0x00000000 |
| 1:0  | CLKTRCTRL_USBHOST | <p>Controls the clock state transition of the USB HOST clock domain.</p> <p>0x0: Automatic transition is disabled</p> <p>0x1: Start a software supervised sleep transition on the domain</p> <p>0x2: Start a software supervised wake-up transition on the domain</p> <p>0x3: Automatic transition is enabled. Transition is supervised by the HardWare.</p> | RW   | 0x0        |

**Table 3-290. Register Call Summary for Register CM\_CLKSTCTRL\_USBHOST**

PRCM Functional Description

- [Device Wake-Up Events: \[0\] \[1\] \[2\]](#)

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[3\]](#)

PRCM Register Manual

- [USBHOST\\_CM Registers: \[4\]](#)

**Table 3-291. CM\_CLKSTST\_USBHOST**

|                         |                                                                                |                         |                 |                 |                     |
|-------------------------|--------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|---------------------|
| <b>Address Offset</b>   | 0x0000 004C                                                                    | <b>Physical Address</b> | 0x4800 544C     | <b>Instance</b> | USBHOST_CM          |
| <b>Description</b>      | This register provides a status on the interface clock activity in the domain. |                         |                 |                 |                     |
| <b>Type</b>             | R                                                                              |                         |                 |                 |                     |
| 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 |                 |                     |
| RESERVED                |                                                                                |                         |                 |                 | CLKACTIVITY_USBHOST |

| Bits | Field Name          | Description                                                                                                         | Type | Reset      |
|------|---------------------|---------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED            | Write 0s for future compatibility. Read returns 0.                                                                  | R    | 0x00000000 |
| 0    | CLKACTIVITY_USBHOST | Interface clock activity status<br>0x0: No domain interface clock activity<br>0x1: Domain interface clock is active | R    | 0x0        |

**Table 3-292. Register Call Summary for Register CM\_CLKSTST\_USBHOST**

PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[0\]](#)

PRCM Register Manual

- [USBHOST\\_CM Registers: \[1\]](#)

### 3.7.2 PRM Module Registers

This section describes the PRM module registers. [Table 3-293](#) lists the physical address of the the PRM modules. [Table 3-294](#) through [Table 3-532](#) provide register mapping summaries and describe the bits in the individual registers.

#### 3.7.2.1 PRM Instance Summary

**Table 3-293. PRM Instance Summary**

| Module Name           | Base address (hex) | Size        |
|-----------------------|--------------------|-------------|
| IVA2_PRM              | 0x4830 6000        | 8192 bytes  |
| OCP_System_Reg_PRM    | 0x4830 6800        | 8192 bytes  |
| MPU_PRM               | 0x4830 6900        | 8192 bytes  |
| CORE_PRM              | 0x4830 6A00        | 8192 bytes  |
| SGX_PRM               | 0x4830 6B00        | 8192 bytes  |
| WKUP_PRM              | 0x4830 6C00        | 8192 bytes  |
| Clock_Control_Reg_PRM | 0x4830 6D00        | 8192 bytes  |
| DSS_PRM               | 0x4830 6E00        | 8192 bytes  |
| CAM_PRM               | 0x4830 6F00        | 8192 bytes  |
| PER_PRM               | 0x4830 7000        | 8192 bytes  |
| EMU_PRM               | 0x4830 7100        | 8192 bytes  |
| Global_Reg_PRM        | 0x4830 7200        | 65536 bytes |
| NEON_PRM              | 0x4830 7300        | 8192 bytes  |
| USBHOST_PRM           | 0x4830 7400        | 8192 bytes  |

#### 3.7.2.2 IVA2\_PRM Registers

##### 3.7.2.2.1 IVA2\_PRM Register Summary

**Table 3-294. IVA2\_PRM Register Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type                                       |
|------------------|------|-----------------------|----------------|------------------|--------------------------------------------------|
| RM_RSTCTRL_IVA2  | RW   | 32                    | 0x0000 0050    | 0x4830 6050      | C ( refer to <a href="#">Section 3.6.3.1.2</a> ) |
| RM_RSTST_IVA2    | RW   | 32                    | 0x0000 0058    | 0x4830 6058      | C                                                |
| PM_WKDEP_IVA2    | RW   | 32                    | 0x0000 00C8    | 0x4830 60C8      | W                                                |
| PM_PWSTCTRL_IVA2 | RW   | 32                    | 0x0000 00E0    | 0x4830 60E0      | W                                                |

**Table 3-294. IVA2\_PRM Register Summary (continued)**

| Register Name      | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|--------------------|------|-----------------------|----------------|------------------|------------|
| PM_PWSTST_IVA2     | R    | 32                    | 0x0000 00E4    | 0x4830 60E4      | C          |
| PM_PREPWSTST_IVA2  | RW   | 32                    | 0x0000 00E8    | 0x4830 60E8      | C          |
| PRM IRQSTATUS_IVA2 | RW   | 32                    | 0x0000 00F8    | 0x4830 60F8      | W          |
| PRM IRQENABLE_IVA2 | RW   | 32                    | 0x0000 00FC    | 0x4830 60FC      | W          |

### 3.7.2.2.2 IVA2\_PRM Registers

**Table 3-295. RM\_RSTCTRL\_IVA2**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |           |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |           |  |           |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|-----------|----|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------|--|-----------|--|-----------|--|
| Address Offset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0000 0050                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |           |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |           |  |           |  |
| Physical Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x4830 6050                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |           |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |           |  |           |  |
| Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | This register controls the release of the IVA2 sub-system resets. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |           |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |           |  |           |  |
| Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW                                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |           |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |           |  |           |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="16" style="height: 40px;">RESERVED</td><td colspan="2" style="border-left: none;">RST3_IVA2</td><td colspan="2" style="border-left: none;">RST2_IVA2</td><td colspan="2" style="border-left: none;">RST1_IVA2</td></tr> </table> |                                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RST3_IVA2 |  | RST2_IVA2 |  | RST1_IVA2 |  |
| 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  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |           |  |           |  |
| RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RST3_IVA2 |    | RST2_IVA2 |    | RST1_IVA2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |           |  |           |  |

| Bits | Field Name | Description                                                                                                                                                                                                                            | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                     | R    | 0x00000000 |
| 2    | RST3_IVA2  | Video sequencer reset control<br>0x0: Video sequencer reset is cleared<br>0x1: Resets video sequencer                                                                                                                                  | RW   | 0x1        |
| 1    | RST2_IVA2  | IVA2 - MMU reset control and Video Sequencer hardware accelerator reset control<br>0x0: IVA2 - MMU reset and Video Sequencer hardware accelerator reset are cleared<br>0x1: Resets IVA2 - MMU and Video Sequencer hardware accelerator | RW   | 0x1        |
| 0    | RST1_IVA2  | IVA2 - DSP reset control<br>0x0: IVA2 - DSP reset is cleared<br>0x1: Resets IVA2 - DSP                                                                                                                                                 | RW   | 0x1        |

**Table 3-296. Register Call Summary for Register RM\_RSTCTRL\_IVA2**
**PRCM Functional Description**

- [Reset Sources: \[0\] \[1\] \[2\]](#)
- [Reset Sequences: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\]](#)

**PRCM Basic Programming Model**

- [Reset Control: \[20\]](#)

**PRCM Register Manual**

- [IVA2\\_PRM Registers: \[21\]](#)

**Table 3-297. RM\_RSTST\_IVA2**

|                         |                                                                                                                                                          |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0058                                                                                                                                              |
| <b>Physical Address</b> | 0x4830 6058                                                                                                                                              |
| <b>Instance</b>         | IVA2_PRM                                                                                                                                                 |
| <b>Description</b>      | This register logs the different reset sources of the IVA2 domain. Each bit is set upon release of the domain reset signal. Must be cleared by software. |
| <b>Type</b>             | RW                                                                                                                                                       |
| 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                                                                                                                                          |
| RESERVED                | EMULATION_SEQ_RST<br>EMULATION_VIDEO_HWA_RST<br>EMULATION_IVA2_RST<br>IVA2_SW_RST3<br>IVA2_SW_RST2<br>IVA2_SW_RST1                                       |
| RESERVED                | COREDOMAINWKUP_RST<br>DOMAINWKUP_RST<br>GLOBALWARM_RST<br>GLOBALCOLD_RST                                                                                 |

| Bits  | Field Name              | Description                                                                                                                                                                                                                                                                             | Type | Reset   |
|-------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | RESERVED                | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                      | R    | 0x00000 |
| 13    | EMULATION_SEQ_RST       | <p>Emulation reset</p> <p>Read 0x0: No emulation reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Video Sequencer has been reset upon an emulation reset</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                | RW   | 0x0     |
| 12    | EMULATION_VIDEO_HWA_RST | <p>Emulation reset</p> <p>Read 0x0: No emulation reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Video Sequencer hardware accelerator has been reset upon an emulation reset</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                           | RW   | 0x0     |
| 11    | EMULATION_IVA2_RST      | <p>Emulation reset</p> <p>Read 0x0: No emulation reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: IVA2 (DSP) has been reset upon an emulation reset</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                     | RW   | 0x0     |
| 10    | IVA2_SW_RST3            | <p>IVA2-Video Sequencer software reset</p> <p>Read 0x0: No IVA2-Video Sequencer software reset occurred.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: IVA2 domain has been reset upon IVA2-Video Sequencer software reset.</p> <p>Write 0x1: Status bit is cleared to 0.</p> | RW   | 0x0     |
| 9     | IVA2_SW_RST2            | <p>IVA2-MMU software reset</p> <p>Read 0x0: No IVA2-MMU software reset occurred.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: IVA2 domain has been reset upon IVA2-MMU software reset.</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                     | RW   | 0x0     |

| Bits | Field Name         | Description                                                                                                                                                                                                                                      | Type | Reset |
|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 8    | IVA2_SW_RST1       | IVA2 - DSP software reset<br>Read 0x0: No IVA2-DSP software reset occurred.<br>Write 0x0: Status bit unchanged<br>Read 0x1: IVA2 domain has been reset upon IVA2-DSP software reset.<br>Write 0x1: Status bit is cleared to 0.                   | RW   | 0x0   |
| 7:4  | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                               | R    | 0x0   |
| 3    | COREDOMAINWKUP_RST | CORE domain wake-up reset<br>Read 0x0: No power domain wake-up reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: IVA2 domain has been reset following a CORE power domain wake-up from OFF to ON.<br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0   |
| 2    | DOMAINWKUP_RST     | Power domain wake-up reset<br>Read 0x0: No DSP domain wake-up.<br>Write 0x0: Status bit unchanged<br>Read 0x1: IVA2 domain has been reset following an IVA2 domain wake-up.<br>Write 0x1: Status bit is cleared to 0.                            | RW   | 0x0   |
| 1    | GLOBALWARM_RST     | Global warm reset<br>Read 0x0: No Global warm reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: IVA2 domain has been reset upon global warm reset.<br>Write 0x1: Status bit is cleared to 0.                                                | RW   | 0x0   |
| 0    | GLOBALCOLD_RST     | Global cold reset<br>Read 0x0: No global cold reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: IVA2 domain has been reset upon a global cold reset<br>Write 0x1: Status bit is cleared to 0.                                               | RW   | 0x1   |

**Table 3-298. Register Call Summary for Register RM\_RSTST\_IVA2**

## PRCM Functional Description

- [Reset Sequences: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\]](#)

## PRCM Basic Programming Model

- [Reset Control: \[9\] \[10\]](#)

## PRCM Register Manual

- [IVA2\\_PRM Registers: \[11\]](#)

**Table 3-299. PM\_WKDEP\_IVA2**

| <b>Address Offset</b>   | 0x0000 00C8                                                                                                  | <b>Physical Address</b>                                                                                                                                           | 0x4830 60C8     | <b>Instance</b>                                                                     | IVA2_PRM |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------------------------------------------------------------------------------|----------|--|--|
| <b>Description</b>      | This register allows enabling or disabling the wake-up of the IVA2 domain upon another domain wakeup events. |                                                                                                                                                                   |                 |                                                                                     |          |  |  |
| <b>Type</b>             | RW                                                                                                           |                                                                                                                                                                   |                 |                                                                                     |          |  |  |
| 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 | EN_PER<br>RESERVED<br>EN_DSS<br>EN_WKUP<br>RESERVED<br>RESERVED<br>EN_MP<br>EN_CORE |          |  |  |
| RESERVED                |                                                                                                              |                                                                                                                                                                   |                 |                                                                                     |          |  |  |
| Bits                    | Field Name                                                                                                   | Description                                                                                                                                                       | Type            | Reset                                                                               |          |  |  |
| 31:8                    | RESERVED                                                                                                     | Write Os for future compatibility. Read returns 0.                                                                                                                | R               | 0x000000                                                                            |          |  |  |
| 7                       | EN_PER                                                                                                       | PER domain dependency<br><br>0x0: IVA2 domain is independent of PER domain wake-up event.<br><br>0x1: IVA2 domain is woken-up upon PER domain wake-up event.      | RW              | 0x1                                                                                 |          |  |  |
| 6                       | RESERVED                                                                                                     | Write Os for future compatibility. Read returns 0.                                                                                                                | R               | 0x0                                                                                 |          |  |  |
| 5                       | EN_DSS                                                                                                       | WAKEUP domain dependency<br><br>0x0: IVA2 domain is independent of DSS domain wake-up event.<br><br>0x1: IVA2 domain is woken-up upon DSS domain wake-up event.   | RW              | 0x1                                                                                 |          |  |  |
| 4                       | EN_WKUP                                                                                                      | WAKEUP domain dependency<br><br>0x0: IVA2 domain is independent of WKUP domain wake-up event.<br><br>0x1: IVA2 domain is woken-up upon WKUP domain wake-up event. | RW              | 0x1                                                                                 |          |  |  |
| 3                       | RESERVED                                                                                                     | Write Os for future compatibility. Read returns 0.                                                                                                                | R               | 0x0                                                                                 |          |  |  |
| 2                       | RESERVED                                                                                                     | Write Os for future compatibility. Read returns 0.                                                                                                                | R               | 0x0                                                                                 |          |  |  |
| 1                       | EN_MP                                                                                                        | MPU domain dependency<br><br>0x0: IVA2 domain is independent of MPU domain wake-up event.<br><br>0x1: IVA2 domain is woken-up upon MPU domain wake-up event.      | RW              | 0x1                                                                                 |          |  |  |
| 0                       | EN_CORE                                                                                                      | CORE domain dependency<br><br>0x0: IVA2 domain is independent of CORE domain wake-up event.<br><br>0x1: IVA2 domain is woken-up upon CORE domain wake-up event.   | RW              | 0x1                                                                                 |          |  |  |

**Table 3-300. Register Call Summary for Register PM\_WKDEP\_IVA2**

## PRCM Functional Description

- [Device Wake-Up Events: \[0\] \[1\] \[2\] \[3\] \[4\]](#)

## PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[5\]](#)

## PRCM Register Manual

- [IVA2\\_PRM Registers: \[6\]](#)

**Table 3-301. PM\_PWSTCTRL\_IVA2**

|                       |                                                                |                         |             |                 |          |
|-----------------------|----------------------------------------------------------------|-------------------------|-------------|-----------------|----------|
| <b>Address Offset</b> | 0x0000 00E0                                                    | <b>Physical Address</b> | 0x4830 60E0 | <b>Instance</b> | IVA2_PRM |
| <b>Description</b>    | This register controls the IVA2 domain power state transition. |                         |             |                 |          |
| <b>Type</b>           | RW                                                             |                         |             |                 |          |

| 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 |
|----|----|----|----|----|----|----|----|------------------|--------------------------|------------------|--------------------------|----|----------|-------------------|---------------------------|-------------------|---------------------------|----|----------|--------------|---------------|------------|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    | L2FLATMEMONSTATE | SHAREDL2CACHEFLATONSTATE | L1FLATMEMONSTATE | SHAREDL1CACHEFLATONSTATE |    | RESERVED | L2FLATMEMRETSTATE | SHAREDL2CACHEFLATRETSTATE | L1FLATMEMRETSTATE | SHAREDL1CACHEFLATRETSTATE |    | RESERVED | MEMORYCHANGE | LOGICRETSTATE | POWERSTATE |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name               | Description                                                                                                                                                                                                                  | Type | Reset |
|-------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | RESERVED                 | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                           | R    | 0x00  |
| 23:22 | L2FLATMEMONSTATE         | L2 Flat memory state when domain is ON; Other enums:<br>Reserved<br>0x0: Reserved<br>0x1: Reserved<br>0x2: Reserved<br>0x3: L2 Flat memory is always ON when domain is ON.                                                   | R    | 0x3   |
| 21:20 | SHAREDL2CACHEFLATONSTATE | Shared L2 Cache and Flat memory state when domain is ON<br>0x0: Shared L2 Cache and Flat memory is OFF when domain is ON.<br>0x1: Reserved<br>0x2: Reserved<br>0x3: Shared L2 Cache and Flat memory is ON when domain is ON. | RW   | 0x3   |
| 19:18 | L1FLATMEMONSTATE         | L1 Flat memory state when domain is ON; Other enums:<br>Reserved<br>0x0: Reserved<br>0x1: Reserved<br>0x2: Reserved<br>0x3: L1 Flat memory is always ON when domain is ON.                                                   | R    | 0x3   |
| 17:16 | SHAREDL1CACHEFLATONSTATE | Shared L1 Cache and Flat memory state when domain is ON<br>0x0: Reserved<br>0x1: Reserved<br>0x2: Reserved<br>0x3: Shared L1 Cache and Flat memory is always ON when domain is ON.                                           | R    | 0x3   |
| 15:12 | RESERVED                 | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                           | R    | 0x0   |

| Bits | Field Name                | Description                                                                                                                                                                                                                                     | Type | Reset |
|------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 11   | L2FLATMEMRETSTATE         | L2 Flat memory state when domain is RETENTION<br><br>0x0: L2 Flat memory is OFF when domain is in RETENTION state.<br><br>0x1: L2 Flat memory is retained when domain is in RETENTION state.                                                    | RW   | 0x1   |
| 10   | SHAREDL2CACHEFLATRETSTATE | Shared L2 Cache and Flat memory state when domain is RETENTION<br><br>0x0: Shared L2 Cache and Flat memory is OFF when domain is in RETENTION state.<br><br>0x1: Shared L2 Cache and Flat memory is retained when domain is in RETENTION state. | RW   | 0x1   |
| 9    | L1FLATMEMRETSTATE         | L1 Flat memory state when domain is RETENTION<br><br>0x0: L1 Flat memory is OFF when domain is in RETENTION state.<br><br>0x1: L1 Flat memory is retained when domain is in RETENTION state.                                                    | RW   | 0x1   |
| 8    | SHAREDL1CACHEFLATRETSTATE | Shared L1 Cache and Flat memory state when domain is RETENTION<br><br>0x0: Shared L1 Cache and Flat memory is OFF when domain is in RETENTION state.<br><br>0x1: Shared L1 Cache and Flat memory is retained when domain is in RETENTION state. | RW   | 0x1   |
| 7:4  | RESERVED                  | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                              | R    | 0x0   |
| 3    | MEMORYCHANGE              | Memory change control in ON state<br><br>0x0: Disable memory change<br><br>0x1: Enable memory change state in ON state. This bit is automatically cleared when memory state is effectively changed.                                             | RW   | 0x0   |
| 2    | LOGICRETSTATE             | Logic state when RETENTION<br><br>0x0: Logic is OFF when domain is in RETENTION state.<br><br>0x1: Logic is retained when domain is in RETENTION state.                                                                                         | RW   | 0x1   |
| 1:0  | POWERSTATE                | Power state control<br><br>0x0: OFF state<br><br>0x1: RETENTION state<br><br>0x2: Reserved<br><br>0x3: ON state                                                                                                                                 | RW   | 0x3   |

**Table 3-302. Register Call Summary for Register PM\_PWSTCTRL\_IVA2**

PRCM Basic Programming Model

- [PM\\_PWSTCTRL\\_domain\\_name \(Power State Control Register\): \[0\] \[1\] \[2\] \[3\] \[4\]](#)

PRCM Register Manual

- [IVA2\\_PRM Registers: \[5\]](#)

**Table 3-303. PM\_PWSTST\_IVA2**

|                         |                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00E4                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 60E4                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register provides a status on the power state transition of the IVA2 domain. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



| Bits  | Field Name               | Description                                                                                                                                                                                                        | Type | Reset |
|-------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED                 | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                 | R    | 0x000 |
| 20    | INTRANSITION             | Domain transition status<br>0x0: No transition<br>0x1: IVA2 power domain transition is in progress.                                                                                                                | R    | 0x0   |
| 19:12 | RESERVED                 | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                 | R    | 0x00  |
| 11:10 | L2FLATMEMSTATETEST       | L2 Flat memory state status<br>0x0: L2 Flat memory is OFF<br>0x1: L2 Flat memory is in RETENTION<br>0x2: Reserved<br>0x3: L2 Flat memory is ON                                                                     | R    | 0x3   |
| 9:8   | SHAREDL2CACHEFLATSTATEST | Shared L2 Cache and Flat memory state status<br>0x0: Shared L2 Cache and Flat memory is OFF<br>0x1: Shared L2 Cache and Flat memory is in RETENTION<br>0x2: Reserved<br>0x3: Shared L2 Cache and Flat memory is ON | R    | 0x3   |
| 7:6   | L1FLATMEMSTATETEST       | L1 Flat memory state status<br>0x0: L1 Flat memory is OFF<br>0x1: L1 Flat memory is in RETENTION<br>0x2: Reserved<br>0x3: L1 Flat memory is ON                                                                     | R    | 0x3   |
| 5:4   | SHAREDL1CACHEFLATSTATEST | Shared L1 Cache and Flat memory state status<br>0x0: Shared L1 Cache and Flat memory is OFF<br>0x1: Shared L1 Cache and Flat memory is in RETENTION<br>0x2: Reserved<br>0x3: Shared L1 Cache and Flat memory is ON | R    | 0x3   |
| 3     | RESERVED                 | Read returns 0.                                                                                                                                                                                                    | R    | 0x0   |
| 2     | LOGICSTATETEST           | Logic state status<br>0x0: IVA2 domain logic is OFF<br>0x1: IVA2 domain logic is ON                                                                                                                                | R    | 0x1   |

| Bits | Field Name   | Description                                                                                                                                             | Type | Reset |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1:0  | POWERSTATEST | Current power state status<br>0x0: Power domain is OFF<br>0x1: Power domain is in RETENTION<br>0x2: Power domain is INACTIVE<br>0x3: Power domain is ON | R    | 0x3   |

**Table 3-304. Register Call Summary for Register PM\_PWSTST\_IVA2**

PRCM Basic Programming Model

- [PM\\_PWSTST\\_domain\\_name \(Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [IVA2\\_PRM Registers: \[1\]](#)

**Table 3-305. PM\_PREPWSTST\_IVA2**

|                         |                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00E8                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | <a href="#">0x4830 60E8</a>                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register provides a status on the IVA2 domain previous power state. It indicates the state entered during the last sleep transition. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                           |                                   |                           |                                   |          |                       |                       |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------------------------|-----------------------------------|---------------------------|-----------------------------------|----------|-----------------------|-----------------------|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | LASTL2FLATMEMSTATEENTERED | LASTSHAREDL2CACHEFLATSTATEENTERED | LASTL1FLATMEMSTATEENTERED | LASTSHAREDL1CACHEFLATSTATEENTERED | RESERVED | LASTLOGICSTATEENTERED | LASTPOWERSTATEENTERED |   |

| Bits  | Field Name                        | Description                                                                                                                                                                                                                                                  | Type | Reset   |
|-------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED                          | Read returns 0.                                                                                                                                                                                                                                              | R    | 0x00000 |
| 11:10 | LASTL2FLATMEMSTATEENTERED         | Last L2 Flat memory state entered<br>0x0: L2 Flat memory was previously OFF<br>0x1: L2 Flat memory was previously in RETENTION<br>0x2: Reserved<br>0x3: L2 Flat memory was previously ON                                                                     | RW   | 0x0     |
| 9:8   | LASTSHAREDL2CACHEFLATSTATEENTERED | Shared L2 Cache and Flat memory last state entered<br>0x0: Shared L2 Cache and Flat memory was previously OFF<br>0x1: Shared L2 Cache and Flat memory was previously in RETENTION<br>0x2: Reserved<br>0x3: Shared L2 Cache and Flat memory was previously ON | RW   | 0x0     |

| Bits | Field Name                                | Description                                                                                                                                                                                                                                                                  | Type | Reset |
|------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:6  | LASTL1FLATMEMSTATEENTE<br>RED             | Last L1 Flat memory state entered<br><br>0x0: L1 Flat memory was previously OFF<br><br>0x1: L1 Flat memory was previously in RETENTION<br><br>0x2: Reserved<br><br>0x3: L1 Flat memory was previously ON                                                                     | RW   | 0x0   |
| 5:4  | LASTSHAREDL1CACHEFLATS<br>TATE<br>ENTERED | Shared L1 Cache and Flat memory last state entered<br><br>0x0: Shared L1 Cache and Flat memory was previously OFF<br><br>0x1: Shared L1 Cache and Flat memory was previously in RETENTION<br><br>0x2: Reserved<br><br>0x3: Shared L1 Cache and Flat memory was previously ON | RW   | 0x0   |
| 3    | RESERVED                                  | Read returns 0.                                                                                                                                                                                                                                                              | R    | 0x0   |
| 2    | LASTLOGICSTATEENTERED                     | Last logic state entered<br><br>0x0: IVA2 domain logic was previously OFF<br><br>0x1: IVA2 domain logic was previously ON                                                                                                                                                    | RW   | 0x0   |
| 1:0  | LASTPOWERSTATEENTERED                     | Last power state entered<br><br>0x0: IVA2 domain was previously OFF<br><br>0x1: IVA2 domain was previously in RETENTION<br><br>0x2: IVA2 domain was previously INACTIVE<br><br>0x3: IVA2 domain was previously ON                                                            | RW   | 0x0   |

**Table 3-306. Register Call Summary for Register PM\_PREPWSTST\_IVA2**

PRCM Basic Programming Model

- [PM\\_PREPWSTST\\_domain\\_name \(Previous Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [IVA2\\_PRM Registers: \[1\]](#)

**Table 3-307. PRM\_IRQSTATUS\_IVA2**

|                         |                                                                                                                                                                                                                                                     |                       |                 |          |              |              |         |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--------------|--------------|---------|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00F8                                                                                                                                                                                                                                         |                       |                 |          |              |              |         |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | <a href="#">0x4830 60F8</a>                                                                                                                                                                                                                         |                       |                 |          |              |              |         |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This interrupt status register regroups all the status of the module internal events that can generate an interrupt. Write 1 to a given bit resets this bit. This register applies on the interrupt line 1 mapped to the IVA2 interrupt controller. |                       |                 |          |              |              |         |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                  |                       |                 |          |              |              |         |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED | IVA2_DPLL_ST | FORCEWKUP_ST | WKUP_ST |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name   | Description                                                                                                                                                                                                                                      | Type | Reset      |
|------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                               | R    | 0x00000000 |
| 2    | IVA2_DPLL_ST | <p>DPLL2 recalibration event status</p> <p>Read 0x0: DPLL2 recalibration event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: DPLL2 recalibration event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>    | RW   | 0x0        |
| 1    | FORCEWKUP_ST | <p>Force wake-up IVA2 domain transition completed event status</p> <p>Read 0x0: Wake-up event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Wake-up event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p> | RW   | 0x0        |
| 0    | WKUP_ST      | <p>IVA2 peripherals group wake-up event status</p> <p>Read 0x0: Wake-up event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Wake-up event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                 | RW   | 0x0        |

**Table 3-308. Register Call Summary for Register PRM\_IRQSTATUS\_IVA2**

- PRCM Functional Description
    - DPLL Control: [0]
    - PRCM Interrupts: [1] [2] [3] [4]

- ## PRCM Basic Programming Model

  - **Interrupt Configuration Registers:** [5]

- PRCM Register Manual

**Table 3-309. PRM IRQENABLE IVA2**

| <b>Bits</b> | <b>Field Name</b>  | <b>Description</b>                                                                                                            | <b>Type</b> | <b>Reset</b> |
|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:3        | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                            | R           | 0x00000000   |
| 2           | IVA2_DPLL_RECAL_EN | DPLL2 recalibration mask<br>0x0: DPLL2 recalibration event is masked<br>0x1: DPLL2 recalibration event generates an interrupt | RW          | 0x0          |

| Bits | Field Name   | Description                                                                                                                                                                                                                  | Type | Reset |
|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | FORCEWKUP_EN | Force wake-up IVA2 domain transition completed event mask<br><br>0x0: Force wake-up IVA2 domain transition completed event is masked<br><br>0x1: Force wake-up IVA2 domain transition completed event generates an interrupt | RW   | 0x0   |
| 0    | WKUP_EN      | IVA2 peripherals group wake-up event mask<br><br>0x0: IVA2 peripherals group wake-up event is masked<br><br>0x1: IVA2 peripherals group wake-up event generates an interrupt                                                 | RW   | 0x0   |

**Table 3-310. Register Call Summary for Register PRM\_IRQENABLE\_IVA2**

## PRCM Functional Description

- [DPLL Control: \[0\]](#)
- [Device Wake-Up Events: \[1\]](#)
- [PRCM Interrupts: \[2\] \[3\] \[4\] \[5\]](#)

## PRCM Basic Programming Model

- [Interrupt Configuration Registers: \[6\]](#)

## PRCM Register Manual

- [IVA2\\_PRM Registers: \[7\]](#)

### 3.7.2.3 OCP\_System\_Reg\_PRM Registers

#### 3.7.2.3.1 OCP\_System\_Reg\_PRM Register Summary

**Table 3-311. OCP\_System\_Reg\_PRM Register Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|-------------------|------|-----------------------|----------------|------------------|------------|
| PRM_REVISION      | R    | 32                    | 0x0000 0004    | 0x4830 6804      | C          |
| PRM_SYSCONFIG     | RW   | 32                    | 0x0000 0014    | 0x4830 6814      | W          |
| PRM_IRQSTATUS_MPU | RW   | 32                    | 0x0000 0018    | 0x4830 6818      | W          |
| PRM_IRQENABLE_MPU | RW   | 32                    | 0x0000 001C    | 0x4830 681C      | W          |

#### 3.7.2.3.2 OCP\_System\_Reg\_PRM Registers

**Table 3-312. PRM\_REVISION**

|                  |                                                                          |          |                    |
|------------------|--------------------------------------------------------------------------|----------|--------------------|
| Address Offset   | 0x0000 0004                                                              | Instance | OCP_System_Reg_PRM |
| Physical Address | 0x4830 6804                                                              |          |                    |
| Description      | This register contains the IP revision code for the PRM part of the PRCM |          |                    |
| Type             | R                                                                        |          |                    |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | REV |   |   |   |   |   |

| Bits | Field Name | Description                                                                                         | Type | Reset    |
|------|------------|-----------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | RESERVED   | Reads returns 0.                                                                                    | R    | 0x000000 |
| 7:0  | REV        | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision<br>Examples: 0x10 for 1.0, 0x21 for 2.1 | R    | 0x10     |

**Table 3-313. Register Call Summary for Register PRM\_REVISION**

PRCM Basic Programming Model

- [Revision Information Registers: \[0\]](#)

PRCM Register Manual

- [OCP\\_System\\_Reg\\_PRM Registers: \[1\]](#)

**Table 3-314. PRM\_SYSCONFIG**

|                         |                         |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                    |                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--------------------|----------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0014             |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b>    | OCP_System_Reg_PRM                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 6814             |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  | <b>Description</b> | This register controls the various parameters of the interface |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                    |                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | AUTOIDLE |  |  |  |  |  |  |  |  |  |  |  |  |                    |                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

RESERVED

| Bits | Field Name | Description                                                                                                                                                                               | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Reads returns 0.                                                                                                                                       | R    | 0x00000000 |
| 0    | AUTOIDLE   | Internal clock gating strategy (for the CM part of the PRCM)<br>0x0: Interface clock is free-running<br>0x1: Automatic clock gating strategy is enabled, based on the interface activity. | RW   | 0x1        |

**Table 3-315. Register Call Summary for Register PRM\_SYSCONFIG**

PRCM Basic Programming Model

- [PRCM Configuration Registers: \[0\]](#)

PRCM Register Manual

- [OCP\\_System\\_Reg\\_PRM Registers: \[1\]](#)

**Table 3-316. PRM\_IRQSTATUS\_MPU**

|                         |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |                    |                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0018             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b>    | OCP_System_Reg_PRM                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 6818             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Description</b> | This interrupt status register regroups all the status of the module internal events that can generate an interrupt. Write 1 to a given bit resets this bit. This register applies on the interrupt line 0 mapped to the MPU interrupt controller. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |                    |                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |                    |                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

RESERVED

|                  |               |                      |                    |                  |             |             |                  |                |                 |               |               |                     |                  |                |                 |               |               |                     |       |              |             |                |              |               |             |            |          |         |
|------------------|---------------|----------------------|--------------------|------------------|-------------|-------------|------------------|----------------|-----------------|---------------|---------------|---------------------|------------------|----------------|-----------------|---------------|---------------|---------------------|-------|--------------|-------------|----------------|--------------|---------------|-------------|------------|----------|---------|
| VC_BYPASS_ACK_ST | VC_VP1_ACK_ST | ABB_LDO_TRANXDONE_ST | SND_PERIPH_DPLL_ST | VC_TIMEOUTERR_ST | VC_RAERR_ST | VC_SAERR_ST | VP2_TRANXDONE_ST | VP2_EQVALUE_ST | VP2_NOSMPACK_ST | VP2_MAXVDD_ST | VP2_MINVDD_ST | VP2_OPCHANGEDONE_ST | VP1_TRANXDONE_ST | VP1_EQVALUE_ST | VP1_NOSMPACK_ST | VP1_MAXVDD_ST | VP1_MINVDD_ST | VP1_OPCHANGEDONE_ST | IO_ST | IVA2_DPLL_ST | MPU_DPLL_ST | PERIPH_DPLL_ST | CORE_DPLL_ST | TRANSITION_ST | EVGENOFF_ST | EVGENON_ST | RESERVED | WKUP_ST |
|------------------|---------------|----------------------|--------------------|------------------|-------------|-------------|------------------|----------------|-----------------|---------------|---------------|---------------------|------------------|----------------|-----------------|---------------|---------------|---------------------|-------|--------------|-------------|----------------|--------------|---------------|-------------|------------|----------|---------|

| <b>Bits</b> | <b>Field Name</b>    | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                          | <b>Type</b> | <b>Reset</b> |
|-------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:29       | RESERVED             | Write 0s for future compatibility. Reads returns 0.                                                                                                                                                                                                                                                                                                                                                         | R           | 0x00         |
| 28          | VC_BYPASS_ACK_ST     | <p>Voltage controller's acknowledge to the bypass interface status. It is cleared by software.</p> <p>Read 0x0: Voltage controller's acknowledge to the bypass interface event is false.</p> <p>Write 0x0: Status bit unchanged.</p> <p>Read 0x1: Voltage controller's acknowledge to the bypass interface event is true (pending).</p> <p>Write 0x1: Status bit is cleared to 0.</p>                       | RW dual     | 0            |
| 27          | VC_VP1_ACK_ST        | <p>Voltage controller's acknowledge to the VDD1 voltage processor status. It is cleared by software.</p> <p>Read 0x0: Voltage controller's acknowledge to the VDD1 voltage processor event is false.</p> <p>Write 0x0: Status bit unchanged.</p> <p>Read 0x1: Voltage controller's acknowledge to the VDD1 voltage processor event is true (pending).</p> <p>Write 0x1: Status bit is cleared to 0.</p>     | RW dual     | 0            |
| 26          | ABB_LDO_TRANXDONE_ST | <p>ABB LDO transaction completion status. This status is set when a software-initiated transaction is completed in ABB LDO (active mode transition only). It is cleared by software.</p> <p>Read 0x0: ABB LDO transaction done event is false.</p> <p>Write 0x0: Status bit unchanged.</p> <p>Read 0x1: ABB LDO transaction done event is true (pending).</p> <p>Write 0x1: Status bit is cleared to 0.</p> | RW dual     | 0            |
| 25          | SND_PERIPH_DPLL_ST   | <p>DPLL5 recalibration event status</p> <p>Read 0x0: DPLL5 recalibration event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: DPLL5 recalibration event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                                                                                                               | RW          | 0x0          |
| 24          | VC_TIMEOUTERR_ST     | <p>Voltage Controller timeout error event status</p> <p>Read 0x0: Voltage Controller timeout error event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Controller timeout error event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                                                                        | RW          | 0x0          |
| 23          | VC_RAERR_ST          | <p>Voltage Controller register address acknowledge error event status</p> <p>Read 0x0: Voltage Controller register address acknowledge error event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Controller register address acknowledge error event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                         | RW          | 0x0          |
| 22          | VC_SAERR_ST          | <p>Voltage Controller slave address acknowledge error event status</p> <p>Read 0x0: Voltage Controller slave address acknowledge error event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Controller slave address acknowledge error event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                  | RW          | 0x0          |

| Bits | Field Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset |
|------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 21   | VP2_TRANXDONE_ST     | <p>Voltage Processor 2 transaction completion status. This status is set when a transaction is completed in the voltage processor. It is cleared by software.</p> <p>Read 0x0: Voltage Processor 2 transaction done event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Processor 2 transaction done event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                             | RW   | 0x0   |
| 20   | VP2_EQVALUE_ST       | <p>Voltage Processor 2 voltage value change event. This status is set when an update has been requested but the new voltage value is the same as the current SMPS voltage value. It is cleared by software.</p> <p>Read 0x0: Voltage Processor 2 no voltage value change event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Processor 2 no voltage value change event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p> | RW   | 0x0   |
| 19   | VP2_NOSMPSACK_ST     | <p>Voltage Processor 2 timeout event status. This status is set when the timeout occurred before the SMPS acknowledge. It is cleared by SW.</p> <p>Read 0x0: Voltage Processor 2 timeout event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Processor 2 timeout event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                                                 | RW   | 0x0   |
| 18   | VP2_MAXVDD_ST        | <p>Voltage Processor 2 voltage higher limit event status. This status is set when the voltage higher limit is reached. It is cleared by SW.</p> <p>Read 0x0: Voltage Processor 2 voltage higher limit event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Processor 2 voltage higher limit event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                       | RW   | 0x0   |
| 17   | VP2_MINVDD_ST        | <p>Voltage Processor 2 voltage lower limit event status. This status is set when the voltage lower limit is reached. It is cleared by SW.</p> <p>Read 0x0: Voltage Processor 2 voltage lower limit event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Processor 2 voltage lower limit event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                           | RW   | 0x0   |
| 16   | VP2_OPPCHANGEDONE_ST | <p>Voltage Processor 2 OPP change done status.</p> <p>Read 0x0: Voltage Processor 2 OPP change done event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Processor 2 OPP change done event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                                                                                                                              | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b>    | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                              | <b>Type</b> | <b>Reset</b> |
|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 15          | VP1_TRANXDONE_ST     | <p>Voltage Processor 1 transaction completion status. This status is set when a transaction is completed in the voltage processor. It is cleared by SW.</p> <p>Read 0x0: Voltage Processor 1 transaction done event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Processor 1 transaction done event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                             | RW          | 0x0          |
| 14          | VP1_EQVALUE_ST       | <p>Voltage Processor 1 voltage value change event. This status is set when an update has been requested but the new voltage value is the same as the current SMPS voltage value. It is cleared by SW.</p> <p>Read 0x0: Voltage Processor 1 no voltage value change event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Processor 1 no voltage value change event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p> | RW          | 0x0          |
| 13          | VP1_NOSMPSACK_ST     | <p>Voltage Processor 1 timeout event status. This status is set when the timeout occurred before the SMPS acknowledge. It is cleared by SW.</p> <p>Read 0x0: Voltage Processor 1 timeout event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Processor 1 timeout event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                                           | RW          | 0x0          |
| 12          | VP1_MAXVDD_ST        | <p>Voltage Processor 1 voltage higher limit event status. This status is set when the voltage higher limit is reached. It is cleared by SW.</p> <p>Read 0x0: Voltage Processor 1 voltage higher limit event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Processor 1 voltage higher limit event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                 | RW          | 0x0          |
| 11          | VP1_MINVDD_ST        | <p>Voltage Processor 1 voltage lower limit event status. This status is set when the voltage lower limit is reached. It is cleared by SW.</p> <p>Read 0x0: Voltage Processor 1 voltage lower limit event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Processor 1 voltage lower limit event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                     | RW          | 0x0          |
| 10          | VP1_OPPCHANGEDONE_ST | <p>Voltage Processor 1 OPP change done status.</p> <p>Read 0x0: Voltage Processor 1 OPP change done event is false</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Voltage Processor 1 OPP change done event is true (pending)</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                                                                                                                                                        | RW          | 0x0          |

| Bits | Field Name     | Description                                                                                                                                                                                                                                                                           | Type | Reset |
|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 9    | IO_ST          | IO pad event status<br>Read 0x0: IO pad event is false<br>Write 0x0: Status bit unchanged<br>Read 0x1: IO pad event is true (pending)<br>Write 0x1: Status bit is cleared to 0.                                                                                                       | RW   | 0x0   |
| 8    | IVA2_DPLL_ST   | IVA2 DPLL recalibration event status<br>Read 0x0: IVA2 DPLL recalibration event is false<br>Write 0x0: Status bit unchanged<br>Read 0x1: IVA2 DPLL recalibration event is true (pending)<br>Write 0x1: Status bit is cleared to 0.                                                    | RW   | 0x0   |
| 7    | MPU_DPLL_ST    | DPLL1 recalibration event status<br>Read 0x0: DPLL1 recalibration event is false<br>Write 0x0: Status bit unchanged<br>Read 0x1: DPLL1 recalibration event is true (pending)<br>Write 0x1: Status bit is cleared to 0.                                                                | RW   | 0x0   |
| 6    | PERIPH_DPLL_ST | DPLL4 recalibration event status<br>Read 0x0: DPLL4 recalibration event is false<br>Write 0x0: Status bit unchanged<br>Read 0x1: DPLL4 recalibration event is true (pending)<br>Write 0x1: Status bit is cleared to 0.                                                                | RW   | 0x0   |
| 5    | CORE_DPLL_ST   | DPLL3 recalibration event status<br>Read 0x0: DPLL3 recalibration event is false<br>Write 0x0: Status bit unchanged<br>Read 0x1: DPLL3 recalibration event is true (pending)<br>Write 0x1: Status bit is cleared to 0.                                                                | RW   | 0x0   |
| 4    | TRANSITION_ST  | Software supervised transition completed event status<br>Read 0x0: Software supervised transition completed event is false<br>Write 0x0: Status bit unchanged<br>Read 0x1: Software supervised transition completed event is true (pending)<br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0   |
| 3    | EVGENOFF_ST    | Event Generator endOFFtime status<br>Read 0x0: End of OFF time event is false<br>Write 0x0: Status bit unchanged<br>Read 0x1: End of OFF time event is true (pending)<br>Write 0x1: Status bit is cleared to 0.                                                                       | RW   | 0x0   |
| 2    | EVGENON_ST     | Event Generator endONtime status<br>Read 0x0: End of ON time event is false<br>Write 0x0: Status bit unchanged<br>Read 0x1: End of ON time event is true (pending)<br>Write 0x1: Status bit is cleared to 0.                                                                          | RW   | 0x0   |
| 1    | RESERVED       | Write 0s for future compatibility. Reads returns 0.                                                                                                                                                                                                                                   | R    | 0x0   |
| 0    | WKUP_ST        | MPU peripherals group wake-up event status<br>Read 0x0: Wake-up event is false<br>Write 0x0: Status bit unchanged<br>Read 0x1: Wake-up event is true (pending)<br>Write 0x1: Status bit is cleared to 0.                                                                              | RW   | 0x0   |

**Table 3-317. Register Call Summary for Register PRM\_IRQSTATUS\_MPU**
**PRCM Functional Description**

- [DPLL Control: \[0\] \[1\] \[2\] \[3\] \[4\]](#)
- [PRCM Interrupts: \[5\]](#)
- [VDD1 and VDD2 Control: \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\]](#)

**PRCM Basic Programming Model**

- [Interrupt Configuration Registers: \[18\]](#)
- [Changing OPP Using the SmartReflex Module: \[19\] \[20\]](#)

**PRCM Register Manual**

- [OCP\\_System\\_Reg\\_PRM Registers: \[29\]](#)

**Table 3-318. PRM\_IRQENABLE\_MPU**

| <b>Address Offset</b>   | 0x0000 001C                                                                                                                                                                                                        |    |                  |               |                      |                          |                  |             |             |                  |                |                  |               |               |                      |                  | <b>Instance</b> | OCP_System_Reg_PRM |               |               |                      |       |                    |                   |                      |                    |               |             |            |          |         |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------------------|---------------|----------------------|--------------------------|------------------|-------------|-------------|------------------|----------------|------------------|---------------|---------------|----------------------|------------------|-----------------|--------------------|---------------|---------------|----------------------|-------|--------------------|-------------------|----------------------|--------------------|---------------|-------------|------------|----------|---------|
| <b>Physical Address</b> | 0x4830 681C                                                                                                                                                                                                        |    |                  |               |                      |                          |                  |             |             |                  |                |                  |               |               |                      |                  | <b>Type</b>     | RW                 |               |               |                      |       |                    |                   |                      |                    |               |             |            |          |         |
| <b>Description</b>      | The interrupt enable register allows masking/unmasking the module internal sources of interrupt, on a event-by-event basis. This registers applies on the interrupt line 0 mapped to the MPU interrupt controller. |    |                  |               |                      |                          |                  |             |             |                  |                |                  |               |               |                      |                  | <b>Type</b>     |                    |               |               |                      |       |                    |                   |                      |                    |               |             |            |          |         |
| 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       |
| RESERVED                |                                                                                                                                                                                                                    |    | VC_BYPASS_ACK_EN | VC_VP1_ACK_EN | ABB_LDO_TRANXDONE_EN | SND_PERIPH_DPLL_RECAL_EN | VC_TIMEOUTERR_EN | VC_RAERR_EN | VC_SAERR_EN | VP2_TRANXDONE_EN | VP2_EQVALUE_EN | VP2_NOSMPSACK_EN | VP2_MAXVDD_EN | VP2_MINVDD_EN | VP2_OPPCHANGEDONE_EN | VP1_TRANXDONE_EN | VP1_EQVALUE_EN  | VP1_NOSMPSACK_EN   | VP1_MAXVDD_EN | VP1_MINVDD_EN | VP1_OPPCHANGEDONE_EN | IO_EN | IVA2_DPLL_RECAL_EN | MPU_DPLL_RECAL_EN | PERIPH_DPLL_RECAL_EN | CORE_DPLL_RECAL_EN | TRANSITION_EN | EVGENOFF_EN | EVGENON_EN | RESERVED | WKUP_EN |

| <b>Bits</b> | <b>Field Name</b>            | <b>Description</b>                                                                                                                                                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:29       | RESERVED                     | Write 0s for future compatibility. Reads returns 0.                                                                                                                                                                                                                       | R           | 0x00         |
| 28          | VC_BYPASS_ACK_EN             | Voltage controller's acknowledge to the bypass interface mask.<br><br>0x0: Voltage controller's acknowledge to the bypass interface event is masked.<br><br>0x1: Voltage controller's acknowledge to the bypass interface event generates an interrupt.                   | RW dual     | 0            |
| 27          | VC_VP1_ACK_EN                | Voltage controller's acknowledge to the VDD1 voltage processor mask.<br><br>0x0: Voltage controller's acknowledge to the VDD1 voltage processor event is masked.<br><br>0x1: Voltage controller's acknowledge to the VDD1 voltage processor event generates an interrupt. | RW dual     | 0            |
| 26          | ABB_LDO_TRANXDONE_EN         | ABB LDO transaction done mask.<br><br>0x0: ABB LDO transaction done event is masked.<br><br>0x1: ABB LDO transaction done event generates an interrupt.                                                                                                                   | RW dual     | 0            |
| 25          | SND_PERIPH_DPLL_RECAL_E<br>N | DPLL5 recalibration mask<br><br>0x0: DPLL5 recalibration event is masked<br><br>0x1: DPLL5 recalibration event generates an interrupt                                                                                                                                     | RW          | 0x0          |

| Bits | Field Name           | Description                                                                                                                                                                                                                                  | Type | Reset |
|------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 24   | VC_TIMEOUTERR_EN     | Voltage Controller timeout error mask.<br><br>0x0: Voltage Controller timeout error event is masked<br><br>0x1: Voltage Controller timeout error event generates an interrupt                                                                | RW   | 0x0   |
| 23   | VC_RAERR_EN          | Voltage Controller register address acknowledge error mask.<br><br>0x0: Voltage Controller register address acknowledge error event is masked<br><br>0x1: Voltage Controller register address acknowledge error event generates an interrupt | RW   | 0x0   |
| 22   | VC_SAERR_EN          | Voltage Controller slave address acknowledge error mask.<br><br>0x0: Voltage Controller slave address acknowledge error event is masked<br><br>0x1: Voltage Controller slave address acknowledge error event generates an interrupt          | RW   | 0x0   |
| 21   | VP2_TRANXDONE_EN     | Voltage Processor 2 transaction done mask.<br><br>0x0: Voltage Processor 2 transaction done event is masked<br><br>0x1: Voltage Processor 2 transaction done event generates an interrupt                                                    | RW   | 0x0   |
| 20   | VP2_EQVALUE_EN       | Voltage Processor 2 voltage value change mask.<br><br>0x0: Voltage Processor 2 voltage value change event is masked<br><br>0x1: Voltage Processor 2 voltage value change event generates an interrupt                                        | RW   | 0x0   |
| 19   | VP2_NOSMPSACK_EN     | Voltage Processor 2 timeout mask.<br><br>0x0: Voltage Processor 2 timeout event is masked<br><br>0x1: Voltage Processor 2 timeout event generates an interrupt                                                                               | RW   | 0x0   |
| 18   | VP2_MAXVDD_EN        | Voltage Processor 2 higher voltage limit mask.<br><br>0x0: Voltage Processor 2 higher voltage limit event is masked<br><br>0x1: Voltage Processor 2 higher voltage limit event generates an interrupt                                        | RW   | 0x0   |
| 17   | VP2_MINVDD_EN        | Voltage Processor 2 lower voltage limit mask.<br><br>0x0: Voltage Processor 2 lower voltage limit event is masked<br><br>0x1: Voltage Processor 2 lower voltage limit event generates an interrupt                                           | RW   | 0x0   |
| 16   | VP2_OPPCHANGEDONE_EN | Voltage Processor 2 OPP change done mask.<br><br>0x0: Voltage Processor 2 OPPChangeDone event is masked<br><br>0x1: Voltage Processor 2 OPPChangeDone event generates an interrupt                                                           | RW   | 0x0   |
| 15   | VP1_TRANXDONE_EN     | Voltage Processor 1 transaction done mask.<br><br>0x0: Voltage Processor 1 transaction done event is masked<br><br>0x1: Voltage Processor 1 transaction done event generates an interrupt                                                    | RW   | 0x0   |
| 14   | VP1_EQVALUE_EN       | Voltage Processor 1 voltage value change mask.<br><br>0x0: Voltage Processor 1 voltage value change event is masked<br><br>0x1: Voltage Processor 1 voltage value change event generates an interrupt                                        | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b>    | <b>Description</b>                                                                                                                                                                                           | <b>Type</b> | <b>Reset</b> |
|-------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 13          | VP1_NOSMPSACK_EN     | Voltage Processor 1 timeout mask.<br><br>0x0: Voltage Processor 1 timeout event is masked<br><br>0x1: Voltage Processor 1 timeout event generates an interrupt                                               | RW          | 0x0          |
| 12          | VP1_MAXVDD_EN        | Voltage Processor 1 voltage higher limit mask.<br><br>0x0: Voltage Processor 1 voltage higher limit event is masked<br><br>0x1: Voltage Processor 1 voltage higher limit event generates an interrupt        | RW          | 0x0          |
| 11          | VP1_MINVDD_EN        | Voltage Processor 1 voltage lower limit mask.<br><br>0x0: Voltage Processor 1 voltage lower limit event is masked<br><br>0x1: Voltage Processor 1 voltage lower limit event generates an interrupt           | RW          | 0x0          |
| 10          | VP1_OPPCHANGEDONE_EN | Voltage Processor 1 OPP change done mask.<br><br>0x0: Voltage Processor 1 OPPChangeDone event is masked<br><br>0x1: Voltage Processor 1 OPPChangeDone event generates an interrupt                           | RW          | 0x0          |
| 9           | IO_EN                | IO pad event mask<br><br>0x0: IO pad event is masked<br><br>0x1: IO pad event generates an interrupt                                                                                                         | RW          | 0x0          |
| 8           | IVA2_DPLL_RECAL_EN   | IVA2 DPLL recalibration mask<br><br>0x0: IVA2 DPLL recalibration event is masked<br><br>0x1: IVA2 DPLL recalibration event generates an interrupt                                                            | RW          | 0x0          |
| 7           | MPU_DPLL_RECAL_EN    | DPLL1 recalibration mask<br><br>0x0: DPLL1 recalibration event is masked<br><br>0x1: DPLL1 recalibration event generates an interrupt                                                                        | RW          | 0x0          |
| 6           | PERIPH_DPLL_RECAL_EN | DPLL4 recalibration mask<br><br>0x0: DPLL4 recalibration event is masked<br><br>0x1: DPLL4 recalibration event generates an interrupt                                                                        | RW          | 0x0          |
| 5           | CORE_DPLL_RECAL_EN   | DPLL3 recalibration mask<br><br>0x0: DPLL3 recalibration event is masked<br><br>0x1: DPLL3 recalibration event generates an interrupt                                                                        | RW          | 0x0          |
| 4           | TRANSITION_EN        | Software supervised transition completed event mask<br><br>0x0: Software supervised transition completed event is masked.<br><br>0x1: Software supervised transition completed event generates an interrupt. | RW          | 0x0          |
| 3           | EVGENOFF_EN          | Event Generator endOFFtime mask<br><br>0x0: End of OFF time event is masked<br><br>0x1: End of OFF time event generates an interrupt                                                                         | RW          | 0x0          |
| 2           | EVGENON_EN           | Event Generator endONTIME mask<br><br>0x0: End of ON time event is masked<br><br>0x1: End of ON time event generates an interrupt                                                                            | RW          | 0x0          |
| 1           | RESERVED             | Write 0s for future compatibility. Reads returns 0.                                                                                                                                                          | R           | 0x0          |
| 0           | WKUP_EN              | MPU peripherals group wake-up event mask<br><br>0x0: MPU peripherals group wake-up event is masked<br><br>0x1: MPU peripherals group wake-up event generates an interrupt                                    | RW          | 0x0          |

**Table 3-319. Register Call Summary for Register PRM\_IRQENABLE\_MPU**

## PRCM Functional Description

- DPLL Control: [0] [1] [2] [3] [4]
- Device Wake-Up Events: [5]
- PRCM Interrupts: [6]
- VDD1 and VDD2 Control: [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18]

## PRCM Basic Programming Model

- Interrupt Configuration Registers: [19] [20]
- Voltage Processor Initialization Basic Programming Model: [21] [22] [23] [24] [25] [26] [27] [28] [29] [30] [31] [32]
- Changing OPP Using the SmartReflex Module: [33]
- Event Generator Programming Examples: [34]

## PRCM Register Manual

- OCP\_System\_Reg\_PRM Registers: [39]

**3.7.2.4 MPU\_PRM Registers Registers****3.7.2.4.1 MPU\_PRM Registers Register Summary****Table 3-320. MPU\_PRM Register Summary**

| Register Name      | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|--------------------|------|-----------------------|----------------|------------------|------------|
| RM_RSTST_MPU       | RW   | 32                    | 0x0000 0058    | 0x4830 6958      | C          |
| PM_WKDEP_MPU       | RW   | 32                    | 0x0000 00C8    | 0x4830 69C8      | W          |
| PM_EVGENCTRL_MPU   | RW   | 32                    | 0x0000 00D4    | 0x4830 69D4      | W          |
| PM_EVGENONTIM_MPU  | RW   | 32                    | 0x0000 00D8    | 0x4830 69D8      | W          |
| PM_EVGENOFFTIM_MPU | RW   | 32                    | 0x0000 00DC    | 0x4830 69DC      | W          |
| PM_PWSTCTRL_MPU    | RW   | 32                    | 0x0000 00E0    | 0x4830 69E0      | W          |
| PM_PWSTST_MPU      | R    | 32                    | 0x0000 00E4    | 0x4830 69E4      | C          |
| PM_PREPWSTST_MPU   | RW   | 32                    | 0x0000 00E8    | 0x4830 69E8      | C          |

**3.7.2.4.2 MPU\_PRM Registers****Table 3-321. RM\_RSTST\_MPU**

|                  |                                                                                                                                                         |          |         |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|
| Address Offset   | 0x0000 0058                                                                                                                                             | Instance | MPU_PRM |
| Physical Address | 0x4830 6958                                                                                                                                             |          |         |
| Description      | This register logs the different reset sources of the MPU domain. Each bit is set upon release of the domain reset signal. Must be cleared by software. |          |         |
| Type             | RW                                                                                                                                                      |          |         |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |          |    |    |    |    |   |   |   |                    |                |                |                |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----------|----|----|----|----|---|---|---|--------------------|----------------|----------------|----------------|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EMULATION_MPU_RST | RESERVED |    |    |    |    |   |   |   | COREDOMAINWKUP_RST | DOMAINWKUP_RST | GLOBALWARM_RST | GLOBALCOLD_RST |   |   |   |

| Bits  | Field Name         | Description                                                                                                                                                                                                                                     | Type | Reset   |
|-------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                              | R    | 0x00000 |
| 11    | EMULATION_MPU_RST  | Emulation reset<br>Read 0x0: No emulation reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: MPU domain has been reset upon an emulation reset<br>Write 0x1: Status bit is cleared to 0.                                                    | RW   | 0x0     |
| 10:4  | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                              | R    | 0x00    |
| 3     | COREDOMAINWKUP_RST | CORE domain wake-up reset<br>Read 0x0: No power domain wake-up reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: MPU domain has been reset following a CORE power domain wake-up from OFF to ON.<br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0     |
| 2     | DOMAINWKUP_RST     | Power domain wake-up reset<br>Read 0x0: No power domain wake-up reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: MPU domain has been reset following a MPU power domain wake-up.<br>Write 0x1: Status bit is cleared to 0.                | RW   | 0x0     |
| 1     | GLOBALWARM_RST     | Global warm reset<br>Read 0x0: No global warm reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: MPU domain has been reset upon a global warm reset<br>Write 0x1: Status bit is cleared to 0.                                               | RW   | 0x0     |
| 0     | GLOBALCOLD_RST     | Global cold reset<br>Read 0x0: No global cold reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: MPU domain has been reset upon a global cold reset<br>Write 0x1: Status bit is cleared to 0.                                               | RW   | 0x1     |

**Table 3-322. Register Call Summary for Register RM\_RSTST\_MPU**

PRCM Basic Programming Model

- [Reset Control: \[0\]](#)

PRCM Register Manual

- [MPU\\_PRM Registers Registers: \[1\]](#)

**Table 3-323. PM\_WKDEP\_MPU**

|                         |                                                                                                             |                 |         |
|-------------------------|-------------------------------------------------------------------------------------------------------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 00C8                                                                                                 | <b>Instance</b> | MPU_PRM |
| <b>Physical Address</b> | <a href="#">0x4830 69C8</a>                                                                                 |                 |         |
| <b>Description</b>      | This register allows enabling or disabling the wake-up of the MPU domain upon another domain wakeup events. |                 |         |
| <b>Type</b>             | RW                                                                                                          |                 |         |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |        |          |        |          |         |          |         |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------|----------|--------|----------|---------|----------|---------|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | EN_PER | RESERVED | EN_DSS | RESERVED | EN_IVA2 | RESERVED | EN_CORE |   |

| Bits | Field Name | Description                                                                                                                                           | Type | Reset    |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                    | R    | 0x000000 |
| 7    | EN_PER     | PER domain dependency<br>0x0: MPU domain is independent of PER domain wake-up event.<br>0x1: MPU domain is woken-up upon PER domain wake-up event.    | RW   | 0x1      |
| 6    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                    | R    | 0x0      |
| 5    | EN_DSS     | DSS domain dependency<br>0x0: MPU domain is independent of DSS domain wake-up event.<br>0x1: MPU domain is woken-up upon DSS domain wake-up event.    | RW   | 0x1      |
| 4:3  | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                    | R    | 0x0      |
| 2    | EN_IVA2    | IVA2 domain dependency<br>0x0: MPU domain is independent of IVA2 domain wake-up event.<br>0x1: MPU domain is woken-up upon IVA2 domain wake-up event. | RW   | 0x1      |
| 1    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                    | R    | 0x0      |
| 0    | EN_CORE    | CORE domain dependency<br>0x0: MPU domain is independent of CORE domain wake-up event.<br>0x1: MPU domain is woken-up upon CORE domain wake-up event. | RW   | 0x1      |

**Table 3-324. Register Call Summary for Register PM\_WKDEP\_MPU**

## PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#)
- [Sleep and Wake-Up Dependencies: \[1\]](#)

## PRCM Basic Programming Model

- [Power-Domain Clock Control Registers: \[2\]](#)
- [Domain Wake-Up Control Registers: \[3\]](#)

## PRCM Register Manual

- [MPU\\_PRM Registers Registers: \[4\]](#)

**Table 3-325. PM\_EVGENCTRL\_MPU**

|                  |                                                                      |          |         |
|------------------|----------------------------------------------------------------------|----------|---------|
| Address Offset   | 0x0000 00D4                                                          | Instance | MPU_PRM |
| Physical Address | 0x4830 69D4                                                          |          |         |
| Description      | This register allows controlling the feature of the event generator. |          |         |
| Type             | RW                                                                   |          |         |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------|------------|--------|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | OFFLOADMODE | ONLOADMODE | ENABLE |   |   |   |   |

| Bits | Field Name  | Description                                                                                                                                                            | Type | Reset     |
|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | RESERVED    | Write 0s for future compatibility . Read returns 0                                                                                                                     | R    | 0x0000000 |
| 4:3  | OFFLOADMODE | OFF load mode setting<br>0x0: Load on update of <a href="#">PM_EVGENOFFTIM_MPUMPU</a><br>0x1: Reserved<br>0x2: Load on MPU standby signal assertion<br>0x3: Auto load  | RW   | 0x2       |
| 2:1  | ONLOADMODE  | ON load mode setting<br>0x0: Load on update of <a href="#">PM_EVGENONTIM_MPUMPU</a><br>0x1: Load on MPU standby signal de-assertion<br>0x2: Reserved<br>0x3: Auto load | RW   | 0x1       |
| 0    | ENABLE      | Event generator control<br>0x0: Disable event generator<br>0x1: Enable event generator                                                                                 | RW   | 0x0       |

**Table 3-326. Register Call Summary for Register PM\_EVGENCTRL\_MPUMPU**

## PRCM Functional Description

- [Power Domain Implementation: \[0\]](#)
- [Device Wake-Up Events: \[1\]](#)

## PRCM Basic Programming Model

- [Event Generator Control Registers: \[2\]](#)
- [Event Generator Programming Examples: \[3\]](#)

## PRCM Register Manual

- [MPU\\_PRM Registers Registers: \[4\]](#)

**Table 3-327. PM\_EVGENONTIM\_MPUMPU**

|                         |                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|--------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 00D8                                                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | <a href="#">0x4830 69D8</a>                                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | This register sets the ON count duration of the event generator (number of system clock cycles). |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| ONTIMEVAL               |                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                      | Type | Reset      |
|------|------------|--------------------------------------------------|------|------------|
| 31:0 | ONTIMEVAL  | Number of system clock cycles for the ON period. | RW   | 0x00000000 |

**Table 3-328. Register Call Summary for Register PM\_EVGENONTIM\_MPU**

## PRCM Functional Description

- Power Domain Implementation: [0] [1]

## PRCM Basic Programming Model

- Event Generator Control Registers: [2]
- Event Generator Programming Examples: [3] [4]

## PRCM Register Manual

- MPU\_PRM Registers Registers: [5] [6]

**Table 3-329. PM\_EVGENOFFTIM\_MPU**

|                         |                                                                                                   |                       |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------|-----------------------|-----------------|------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00DC                                                                                       |                       |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 69DC                                                                                       |                       |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register sets the OFF count duration of the event generator (number of system clock cycles). |                       |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                |                       |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | OFFTIMEVAL |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                       | Type | Reset      |
|------|------------|---------------------------------------------------|------|------------|
| 31:0 | OFFTIMEVAL | Number of system clock cycles for the OFF period. | RW   | 0x00000000 |

**Table 3-330. Register Call Summary for Register PM\_EVGENOFFTIM\_MPU**

## PRCM Functional Description

- Power Domain Implementation: [0] [1]

## PRCM Basic Programming Model

- Event Generator Control Registers: [2]
- Event Generator Programming Examples: [3] [4]

## PRCM Register Manual

- MPU\_PRM Registers Registers: [5] [6]

**Table 3-331. PM\_PWSTCTRL\_MPU**

|                         |                                                               |                       |                 |                |  |  |  |          |  |  |  |                 |  |  |  |          |  |              |  |                      |  |            |  |
|-------------------------|---------------------------------------------------------------|-----------------------|-----------------|----------------|--|--|--|----------|--|--|--|-----------------|--|--|--|----------|--|--------------|--|----------------------|--|------------|--|
| <b>Address Offset</b>   | 0x0000 00E0                                                   |                       |                 |                |  |  |  |          |  |  |  |                 |  |  |  |          |  |              |  |                      |  |            |  |
| <b>Physical Address</b> | 0x4830 69E0                                                   |                       |                 |                |  |  |  |          |  |  |  |                 |  |  |  |          |  |              |  |                      |  |            |  |
| <b>Description</b>      | This register controls the MPU domain power state transition. |                       |                 |                |  |  |  |          |  |  |  |                 |  |  |  |          |  |              |  |                      |  |            |  |
| <b>Type</b>             | RW                                                            |                       |                 |                |  |  |  |          |  |  |  |                 |  |  |  |          |  |              |  |                      |  |            |  |
| 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 | RESERVED       |  |  |  |          |  |  |  |                 |  |  |  |          |  |              |  |                      |  |            |  |
|                         |                                                               |                       |                 | L2CACHEONSTATE |  |  |  | RESERVED |  |  |  | L2CACHERETSTATE |  |  |  | RESERVED |  | MEMORYCHANGE |  | LOGICL1CACHERETSTATE |  | POWERSTATE |  |

| Bits  | Field Name           | Description                                                                                                                                                                                             | Type | Reset  |
|-------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:18 | RESERVED             | Write 0s for future compatibility. Read returns 0.                                                                                                                                                      | R    | 0x0000 |
| 17:16 | L2CACHEONSTATE       | L2 Cache memory state when domain is ON; Other enums: Reserved<br><br>0x0: L2 Cache memory is OFF when domain is ON.<br>0x1: Reserved<br>0x2: Reserved<br>0x3: L2 Cache memory is ON when domain is ON. | RW   | 0x3    |
| 15:9  | RESERVED             | Write 0s for future compatibility. Read returns 0.                                                                                                                                                      | R    | 0x00   |
| 8     | L2CACHERETSTATE      | L2 Cache memory state when domain is RETENTION<br><br>0x0: L2 Cache memory is OFF when domain is in RETENTION state.<br>0x1: L2 Cache memory is retained when domain is in RETENTION state.             | RW   | 0x1    |
| 7:4   | RESERVED             | Write 0s for future compatibility. Read returns 0.                                                                                                                                                      | R    | 0x0    |
| 3     | MEMORYCHANGE         | Memory change control in ON state<br><br>0x0: Disable memory change<br>0x1: Enable memory change state in ON state. This bit is automaticaly cleared when memory state is effectively changed.          | RW   | 0x0    |
| 2     | LOGICL1CACHERETSTATE | Logic and L1 Cache state when domain is RETENTION<br><br>0x0: Logic and L1 Cache are OFF when domain is in RETENTION state.<br>0x1: Logic and L1 Cache are retained when domain is in RETENTION state.  | RW   | 0x1    |
| 1:0   | POWERSTATE           | Power state control<br><br>0x0: OFF state<br>0x1: RETENTION state<br>0x2: Reserved<br>0x3: ON state                                                                                                     | RW   | 0x3    |

**Table 3-332. Register Call Summary for Register PM\_PWSTCTRL\_MPU**

PRCM Basic Programming Model

- [PM\\_PWSTCTRL\\_domain\\_name \(Power State Control Register\): \[0\]](#)

PRCM Register Manual

- [MPU\\_PRM Registers Registers: \[1\]](#)

**Table 3-333. PM\_PWSTST\_MPU**

|                         |                                                                |    |    |    |    |    |    |             |    |          |                 |    |    |    |         |    |    |    |    |              |    |          |   |                   |   |            |   |   |   |   |   |
|-------------------------|----------------------------------------------------------------|----|----|----|----|----|----|-------------|----|----------|-----------------|----|----|----|---------|----|----|----|----|--------------|----|----------|---|-------------------|---|------------|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 00E4                                                    |    |    |    |    |    |    |             |    |          |                 |    |    |    |         |    |    |    |    |              |    |          |   |                   |   |            |   |   |   |   |   |
| <b>Physical Address</b> | <a href="#">0x4830 69E4</a>                                    |    |    |    |    |    |    |             |    |          | <b>Instance</b> |    |    |    | MPU_PRM |    |    |    |    |              |    |          |   |                   |   |            |   |   |   |   |   |
| <b>Description</b>      | This register provides a status on the MPU domain power state. |    |    |    |    |    |    |             |    |          |                 |    |    |    |         |    |    |    |    |              |    |          |   |                   |   |            |   |   |   |   |   |
| <b>Type</b>             | R                                                              |    |    |    |    |    |    |             |    |          |                 |    |    |    |         |    |    |    |    |              |    |          |   |                   |   |            |   |   |   |   |   |
| 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 |
| RESERVED                |                                                                |    |    |    |    |    |    | INTRASITION |    | RESERVED |                 |    |    |    |         |    |    |    |    | L2CACHESTATE |    | RESERVED |   | LOGICL1CACHESTATE |   | POWERSTATE |   |   |   |   |   |

| Bits  | Field Name            | Description                                                                                                                                             | Type | Reset |
|-------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED              | Read returns 0.                                                                                                                                         | R    | 0x000 |
| 20    | INTRANSITION          | Domain transition status<br>0x0: No transition<br>0x1: MPU power domain transition is in progress.                                                      | R    | 0x0   |
| 19:8  | RESERVED              | Read returns 0.                                                                                                                                         | R    | 0x000 |
| 7:6   | L2CACHESTATETEST      | L2 Cache memory state status<br>0x0: L2 Cache memory is OFF<br>0x1: L2 Cache memory is in RETENTION<br>0x2: Reserved<br>0x3: L2 Cache memory is ON      | R    | 0x3   |
| 5:3   | RESERVED              | Read returns 0.                                                                                                                                         | R    | 0x0   |
| 2     | LOGICL1CACHESTATETEST | Logic and L1 Cache state status<br>0x0: MPU domain logic and L1 Cache is OFF<br>0x1: MPU domain logic and L1 Cache is ON                                | R    | 0x1   |
| 1:0   | POWERSTATETEST        | Current power state status<br>0x0: Power domain is OFF<br>0x1: Power domain is in RETENTION<br>0x2: Power domain is INACTIVE<br>0x3: Power domain is ON | R    | 0x3   |

**Table 3-334. Register Call Summary for Register PM\_PWSTST\_MPUMPU**

PRCM Basic Programming Model

- [PM\\_PWSTST\\_domain\\_name \(Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [MPU\\_PRM Registers Registers: \[1\]](#)

**Table 3-335. PM\_PREPWSTST\_MPUMPU**

|                         |                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |    |          |    |                              |    |                       |   |   |   |   |   |   |   |   |   |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------|----|----------|----|------------------------------|----|-----------------------|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 00E8                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |    |          |    |                              |    |                       |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x4830 69E8                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |    |          |    |                              |    |                       |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | This register provides a status on the MPU domain previous power state. It indicates the state entered during the last sleep transition. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |    |          |    |                              |    |                       |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |    |          |    |                              |    |                       |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LASTL2CACHESTATEENTERED |    | RESERVED |    | LASTLOGICL1CACHESTATEENTERED |    | LASTPOWERSTATEENTERED |   |   |   |   |   |   |   |   |   |

| Bits | Field Name                   | Description                                                                                                                                                                                   | Type | Reset    |
|------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | RESERVED                     | Read returns 0.                                                                                                                                                                               | R    | 0x000000 |
| 7:6  | LASTL2CACHESTATEENTERED      | Last L2 Cache memory state entered<br>0x0: L2 Cache memory was previously OFF<br>0x1: L2 Cache memory was previously in RETENTION<br>0x2: Reserved<br>0x3: L2 Cache memory was previously ON  | RW   | 0x0      |
| 5:3  | RESERVED                     | Read returns 0.                                                                                                                                                                               | R    | 0x0      |
| 2    | LASTLOGICL1CACHESTATEENTERED | Last logic and L1 Cache state entered<br>0x0: MPU domain logic and L1 Cache was previously OFF<br>0x1: MPU domain logic and L1 Cache was previously ON                                        | RW   | 0x0      |
| 1:0  | LASTPOWERSTATEENTERED        | Last power state entered<br>0x0: MPU domain was previously OFF<br>0x1: MPU domain was previously in RETENTION<br>0x2: MPU domain was previously INACTIVE<br>0x3: MPU domain was previously ON | RW   | 0x0      |

**Table 3-336. Register Call Summary for Register PM\_PREPWSTST\_MPUMPU**

PRCM Basic Programming Model

- [PM\\_PREPWSTST\\_domain\\_name \(Previous Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [MPU\\_PRM Registers Registers: \[1\]](#)

### 3.7.2.5 CORE\_PRM Registers

#### 3.7.2.5.1 CORE\_PRM Register Summary

**Table 3-337. CORE\_PRM Register Summary**

| Register Name       | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|---------------------|------|-----------------------|----------------|------------------|------------|
| RM_RSTST_CORE       | RW   | 32                    | 0x0000 0058    | 0x4830 6A58      | C          |
| PM_WKEN1_CORE       | RW   | 32                    | 0x0000 00A0    | 0x4830 6AA0      | W          |
| PM_MPUGRPSEL1_CORE  | RW   | 32                    | 0x0000 00A4    | 0x4830 6AA4      | W          |
| PM_IVA2GRPSEL1_CORE | RW   | 32                    | 0x0000 00A8    | 0x4830 6AA8      | W          |
| PM_WKST1_CORE       | RW   | 32                    | 0x0000 00B0    | 0x4830 6AB0      | C          |
| PM_WKST3_CORE       | RW   | 32                    | 0x0000 00B8    | 0x4830 6AB8      | C          |
| PM_PWSTCTRL_CORE    | RW   | 32                    | 0x0000 00E0    | 0x4830 6AE0      | W          |
| PM_PWSTST_CORE      | R    | 32                    | 0x0000 00E4    | 0x4830 6AE4      | C          |
| PM_PREPWSTST_CORE   | RW   | 32                    | 0x0000 00E8    | 0x4830 6AE8      | C          |
| PM_WKEN3_CORE       | RW   | 32                    | 0x0000 00F0    | 0x4830 6AF0      | W          |
| PM_IVA2GRPSEL3_CORE | RW   | 32                    | 0x0000 00F4    | 0x4830 6AF4      | W          |
| PM_MPUGRPSEL3_CORE  | RW   | 32                    | 0x0000 00F8    | 0x4830 6AF8      | W          |

#### 3.7.2.5.2 CORE\_PRM Registers

**Table 3-338. RM\_RSTST\_CORE**

|                         |                                                                                                                                                          |  |  |  |  |  |  |                |                |                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|----------------|----------------|----------------|
| <b>Address Offset</b>   | 0x0000 0058                                                                                                                                              |  |  |  |  |  |  |                |                |                |
| <b>Physical Address</b> | 0x4830 6A58                                                                                                                                              |  |  |  |  |  |  |                |                |                |
| <b>Instance</b>         | CORE_PRM                                                                                                                                                 |  |  |  |  |  |  |                |                |                |
| <b>Description</b>      | This register logs the different reset sources of the CORE domain. Each bit is set upon release of the domain reset signal. Must be cleared by software. |  |  |  |  |  |  |                |                |                |
| <b>Type</b>             | RW                                                                                                                                                       |  |  |  |  |  |  |                |                |                |
| 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                                                                                                                                          |  |  |  |  |  |  |                |                |                |
| RESERVED                |                                                                                                                                                          |  |  |  |  |  |  |                |                |                |
|                         |                                                                                                                                                          |  |  |  |  |  |  | DOMAINWKUP_RST | GLOBALWARM_RST | GLOBALCOLD_RST |

| Bits | Field Name     | Description                                                                                                                                                                                                                                               | Type | Reset      |
|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                        | R    | 0x00000000 |
| 2    | DOMAINWKUP_RST | <p>Power domain wake-up reset</p> <p>Read 0x0: No power domain wake-up reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: CORE domain has been reset following a CORE power domain wake-up.</p> <p>Write 0x1: Status bit is cleared to 0.</p> | RW   | 0x0        |
| 1    | GLOBALWARM_RST | <p>Global warm reset</p> <p>Read 0x0: No global warm reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: CORE domain has been reset upon a global warm reset</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                 | RW   | 0x0        |
| 0    | GLOBALCOLD_RST | <p>Global cold reset</p> <p>Read 0x0: No global cold reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: CORE domain has been reset upon a global cold reset</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                 | RW   | 0x1        |

**Table 3-339. Register Call Summary for Register RM\_RSTST\_CORE**

---

PRCM Basic Programming Model

- Reset Control: [0] [1]

---

PRCM Register Manual

- CORE\_PRM Registers: [2]

**Table 3-340. PM\_WKEN1\_CORE**

|                         |  |                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--|-----------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   |  | 0x0000 00A0                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> |  | 0x4830 6AA0                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      |  | This register allows enabling/disabling modules wake-up events. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             |  | RW                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |         |          |         |         |          |           |           |           |           |         |         |         |          |          |          |          |           |           |          |             |          |          |          |          |          |          |          |          |          |          |   |
|----------|---------|----------|---------|---------|----------|-----------|-----------|-----------|-----------|---------|---------|---------|----------|----------|----------|----------|-----------|-----------|----------|-------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|---|
| 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 |
| RESERVED | EN_MMC3 | RESERVED | EN_MMC2 | EN_MMC1 | RESERVED | EN_MCSPI4 | EN_MCSPI3 | EN_MCSPI2 | EN_MCSPI1 | EN_I2C3 | EN_I2C2 | EN_I2C1 | EN_UART2 | EN_UART1 | EN_GPT11 | EN_GPT10 | EN_MCBSP5 | EN_MCBSP1 | RESERVED | EN_HSOTGUSB | RESERVED |   |

| Bits  | Field Name | Description                                                                                              | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------|------|-------|
| 31    | RESERVED   | Write 1's for future compatibility. Read returns 1.                                                      | RW   | 0x1   |
| 30    | EN_MMC3    | MMC SDIO 3 wake-up control<br><br>0x0: MMC 3 wake-up is disabled<br>0x1: MMC 3 wake-up event is enabled  | RW   | 0x1   |
| 29:26 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                       | R    | 0x0   |
| 25    | EN_MMC2    | MMC SDIO 2 wake-up control<br><br>0x0: MMC 2 wake-up is disabled<br>0x1: MMC 2 wake-up event is enabled  | RW   | 0x1   |
| 24    | EN_MMC1    | MMC SDIO 1 wake-up control<br><br>0x0: MMC 1 wake-up is disabled<br>0x1: MMC 1 wake-up event is enabled  | RW   | 0x1   |
| 23:22 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                       | R    | 0x0   |
| 21    | EN_MCSPI4  | McSPI 4 wake-up control<br><br>0x0: McSPI 4 wake-up is disabled<br>0x1: McSPI 4 wake-up event is enabled | RW   | 0x1   |
| 20    | EN_MCSPI3  | McSPI 3 wake-up control<br><br>0x0: McSPI 3 wake-up is disabled<br>0x1: McSPI 3 wake-up event is enabled | RW   | 0x1   |
| 19    | EN_MCSPI2  | McSPI 2 wake-up control<br><br>0x0: McSPI 2 wake-up is disabled<br>0x1: McSPI 2 wake-up event is enabled | RW   | 0x1   |
| 18    | EN_MCSPI1  | McSPI 1 wake-up control<br><br>0x0: McSPI 1 wake-up is disabled<br>0x1: McSPI 1 wake-up event is enabled | RW   | 0x1   |
| 17    | EN_I2C3    | I2C 3 wake-up control<br><br>0x0: I2C 3 wake-up is disabled<br>0x1: I2C 3 wake-up event is enabled       | RW   | 0x1   |
| 16    | EN_I2C2    | I2C 2 wake-up control<br><br>0x0: I2C 2 wake-up is disabled<br>0x1: I2C 2 wake-up event is enabled       | RW   | 0x1   |
| 15    | EN_I2C1    | I2C 1 wake-up control<br><br>0x0: I2C 1 wake-up is disabled<br>0x1: I2C 1 wake-up event is enabled       | RW   | 0x1   |

| Bits | Field Name  | Description                                                                                                   | Type | Reset |
|------|-------------|---------------------------------------------------------------------------------------------------------------|------|-------|
| 14   | EN_UART2    | UART 2 wake-up control<br>0x0: UART 2 wake-up is disabled<br>0x1: UART 2 wake-up event is enabled             | RW   | 0x1   |
| 13   | EN_UART1    | UART 1 wake-up control<br>0x0: UART 1 wake-up is disabled<br>0x1: UART 1 wake-up event is enabled             | RW   | 0x1   |
| 12   | EN_GPT11    | GPTIMER 11 wake-up control<br>0x0: GPTIMER 11 wake-up is disabled<br>0x1: GPTIMER 11 wake-up event is enabled | RW   | 0x1   |
| 11   | EN_GPT10    | GPTIMER 10 wake-up control<br>0x0: GPTIMER 10 wake-up is disabled<br>0x1: GPTIMER 10 wake-up event is enabled | RW   | 0x1   |
| 10   | EN_MCBSP5   | McBSP 5 wake-up control<br>0x0: McBSP 5 wake-up is disabled<br>0x1: McBSP 5 wake-up event is enabled          | RW   | 0x1   |
| 9    | EN_MCBSP1   | McBSP 1 wake-up control<br>0x0: McBSP 1 wake-up is disabled<br>0x1: McBSP 1 wake-up event is enabled          | RW   | 0x1   |
| 8:5  | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                            | R    | 0x0   |
| 4    | EN_HSOTGUSB | HS OTG USB wake-up control<br>0x0: HS OTG USB wake-up is disabled<br>0x1: HS OTG USB wake-up event is enabled | RW   | 0x1   |
| 3:0  | RESERVED    | Write 0x8 for future compatibility. Read returns 0x8.                                                         | R    | 0x8   |

**Table 3-341. Register Call Summary for Register PM\_WKEN1\_CORE**

PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#)

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[1\]](#)

PRCM Register Manual

- [CORE\\_PRM Registers: \[2\]](#)

**Table 3-342. PM\_MPUGRPSEL1\_CORE**

| Address Offset   |              | 0x0000 00A4                                                               |    | Instance     |          |              |              |              |              |             |             |             |              |              |              |              |               |               |          | CORE_PRM |    |   |                 |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|--------------|---------------------------------------------------------------------------|----|--------------|----------|--------------|--------------|--------------|--------------|-------------|-------------|-------------|--------------|--------------|--------------|--------------|---------------|---------------|----------|----------|----|---|-----------------|----------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Physical Address |              | 0x4830 6AA4                                                               |    |              |          |              |              |              |              |             |             |             |              |              |              |              |               |               |          |          |    |   |                 |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      |              | This register allows selecting the group of modules that wake-up the MPU. |    |              |          |              |              |              |              |             |             |             |              |              |              |              |               |               |          |          |    |   |                 |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             |              | RW                                                                        |    |              |          |              |              |              |              |             |             |             |              |              |              |              |               |               |          |          |    |   |                 |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED         | GRPSEL_MMCI3 | RESERVED                                                                  |    | GRPSEL_MMCI2 | RESERVED | GRPSEL_MCSI4 | GRPSEL_MCSI3 | GRPSEL_MCSI2 | GRPSEL_MCSI1 | GRPSEL_I2C3 | GRPSEL_I2C2 | GRPSEL_I2C1 | GRPSEL_UART2 | GRPSEL_UART1 | GRPSEL_GPTI1 | GRPSEL_GPTI0 | GRPSEL_MCBSP5 | GRPSEL_MCBSP1 | RESERVED |          |    |   | GRPSEL_HSOTGUSB | RESERVED |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31          | RESERVED          | Write 1's for future compatibility. Read returns 1.                                                                                                                                      | RW          | 0x1          |
| 30          | GRPSEL_MMC3       | Select the MMC 3 in the MPU wake-up events group<br><br>0x0: MMC 3 is not attached to the MPU wake-up events group.<br><br>0x1: MMC 3 is attached to the MPU wake-up events group.       | RW          | 0x1          |
| 29:26       | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                       | R           | 0x0          |
| 25          | GRPSEL_MMC2       | Select the MMC 2 in the MPU wake-up events group<br><br>0x0: MMC 2 is not attached to the MPU wake-up events group.<br><br>0x1: MMC 2 is attached to the MPU wake-up events group.       | RW          | 0x1          |
| 24          | GRPSEL_MMC1       | Select the MMC 1 in the MPU wake-up events group<br><br>0x0: MMC 1 is not attached to the MPU wake-up events group.<br><br>0x1: MMC 1 is attached to the MPU wake-up events group.       | RW          | 0x1          |
| 23:22       | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                       | R           | 0x0          |
| 21          | GRPSEL_MCSPI4     | Select the McSPI 4 in the MPU wake-up events group<br><br>0x0: McSPI 4 is not attached to the MPU wake-up events group.<br><br>0x1: McSPI 4 is attached to the MPU wake-up events group. | RW          | 0x1          |
| 20          | GRPSEL_MCSPI3     | Select the McSPI 3 in the MPU wake-up events group<br><br>0x0: McSPI 3 is not attached to the MPU wake-up events group.<br><br>0x1: McSPI 3 is attached to the MPU wake-up events group. | RW          | 0x1          |
| 19          | GRPSEL_MCSPI2     | Select the McSPI 2 in the MPU wake-up events group<br><br>0x0: McSPI 2 is not attached to the MPU wake-up events group.<br><br>0x1: McSPI 2 is attached to the MPU wake-up events group. | RW          | 0x1          |
| 18          | GRPSEL_MCSPI1     | Select the McSPI 1 in the MPU wake-up events group<br><br>0x0: McSPI 1 is not attached to the MPU wake-up events group.<br><br>0x1: McSPI 1 is attached to the MPU wake-up events group. | RW          | 0x1          |
| 17          | GRPSEL_I2C3       | Select the I2C 3 in the MPU wake-up events group<br><br>0x0: I2C 3 is not attached to the MPU wake-up events group.<br><br>0x1: I2C 3 is attached to the MPU wake-up events group.       | RW          | 0x1          |
| 16          | GRPSEL_I2C2       | Select the I2C 2 in the MPU wake-up events group<br><br>0x0: I2C 2 is not attached to the MPU wake-up events group.<br><br>0x1: I2C 2 is attached to the MPU wake-up events group.       | RW          | 0x1          |
| 15          | GRPSEL_I2C1       | Select the I2C 1 in the MPU wake-up events group<br><br>0x0: I2C 1 is not attached to the MPU wake-up events group.<br><br>0x1: I2C 1 is attached to the MPU wake-up events group.       | RW          | 0x1          |
| 14          | GRPSEL_UART2      | Select the UART 2 in the MPU wake-up events group<br><br>0x0: UART 2 is not attached to the MPU wake-up events group.<br><br>0x1: UART 2 is attached to the MPU wake-up events group.    | RW          | 0x1          |

| Bits | Field Name      | Description                                                                                                                                                                                       | Type | Reset |
|------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 13   | GRPSEL_UART1    | Select the UART 1 in the MPU wake-up events group<br><br>0x0: UART 1 is not attached to the MPU wake-up events group.<br><br>0x1: UART 1 is attached to the MPU wake-up events group.             | RW   | 0x1   |
| 12   | GRPSEL_GPT11    | Select the GPTIMER 11 in the MPU wake-up events group<br><br>0x0: GPTIMER 11 is not attached to the MPU wake-up events group.<br><br>0x1: GPTIMER 11 is attached to the MPU wake-up events group. | RW   | 0x1   |
| 11   | GRPSEL_GPT10    | Select the GPTIMER 10 in the MPU wake-up events group<br><br>0x0: GPTIMER 10 is not attached to the MPU wake-up events group.<br><br>0x1: GPTIMER 10 is attached to the MPU wake-up events group. | RW   | 0x1   |
| 10   | GRPSEL_MCBSP5   | Select the McBSP 5 in the MPU wake-up events group<br><br>0x0: McBSP 5 is not attached to the MPU wake-up events group.<br><br>0x1: McBSP 5 is attached to the MPU wake-up events group.          | RW   | 0x1   |
| 9    | GRPSEL_MCBSP1   | Select the McBSP 1 in the MPU wake-up events group<br><br>0x0: McBSP 1 is not attached to the MPU wake-up events group.<br><br>0x1: McBSP 1 is attached to the MPU wake-up events group.          | RW   | 0x1   |
| 8:5  | RESERVED        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                | R    | 0x0   |
| 4    | GRPSEL_HSOTGUSB | Select the HS OTG USB in the MPU wake-up events group<br><br>0x0: HS OTG USB is not attached to the MPU wake-up events group.<br><br>0x1: HS OTG USB is attached to the MPU wake-up events group. | RW   | 0x1   |
| 3:0  | RESERVED        | Write 0x8 for future compatibility. Read returns 0x8.                                                                                                                                             | R    | 0x8   |

**Table 3-343. Register Call Summary for Register PM\_MPUGRPSEL1\_CORE**

PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#)

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[1\]](#)

PRCM Register Manual

- [CORE\\_PRM Registers: \[2\]](#)

**Table 3-344. PM\_IVA2GRPSEL1\_CORE**

|                         |                                                                            |                 |          |
|-------------------------|----------------------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 00A8                                                                |                 |          |
| <b>Physical Address</b> | <a href="#">0x4830 6AA8</a>                                                | <b>Instance</b> | CORE_PRM |
| <b>Description</b>      | This register allows selecting the group of modules that wake-up the IVA2. |                 |          |
| <b>Type</b>             | RW                                                                         |                 |          |

|          |              |          |    |    |    |              |              |          |    |    |    |               |               |               |               |             |             |             |              |              |              |              |               |               |          |   |   |   |                 |          |   |  |  |
|----------|--------------|----------|----|----|----|--------------|--------------|----------|----|----|----|---------------|---------------|---------------|---------------|-------------|-------------|-------------|--------------|--------------|--------------|--------------|---------------|---------------|----------|---|---|---|-----------------|----------|---|--|--|
| 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 |  |  |
| RESERVED | GRPSEL_MMIC3 | RESERVED |    |    |    | GRPSEL_MMIC2 | GRPSEL_MMIC1 | RESERVED |    |    |    | GRPSEL_MCSPI4 | GRPSEL_MCSPI3 | GRPSEL_MCSPI2 | GRPSEL_MCSPI1 | GRPSEL_I2C3 | GRPSEL_I2C2 | GRPSEL_I2C1 | GRPSEL_UART2 | GRPSEL_UART1 | GRPSEL_GPT11 | GRPSEL_GPT10 | GRPSEL_MCBSP5 | GRPSEL_MCBSP1 | RESERVED |   |   |   | GRPSEL_HSOTGUSB | RESERVED |   |  |  |

| Bits  | Field Name    | Description                                                                                                                                                                             | Type | Reset |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | RESERVED      | Write 1's for future compatibility. Read returns 1.                                                                                                                                     | RW   | 0x1   |
| 30    | GRPSEL_MMC3   | Select the MMC 3 in the IVA2 wake-up events group<br><br>0x0: MMC 3 is not attached to the IVA2 wake-up events group.<br>0x1: MMC 3 is attached to the IVA2 wake-up events group.       | RW   | 0x1   |
| 29:26 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                      | R    | 0x0   |
| 25    | GRPSEL_MMC2   | Select the MMC 2 in the IVA2 wake-up events group<br><br>0x0: MMC 2 is not attached to the IVA2 wake-up events group.<br>0x1: MMC 2 is attached to the IVA2 wake-up events group.       | RW   | 0x1   |
| 24    | GRPSEL_MMC1   | Select the MMC 1 in the IVA2 wake-up events group<br><br>0x0: MMC 1 is not attached to the IVA2 wake-up events group.<br>0x1: MMC 1 is attached to the IVA2 wake-up events group.       | RW   | 0x1   |
| 23:22 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                      | R    | 0x0   |
| 21    | GRPSEL_MCSPI4 | Select the McSPI 4 in the IVA2 wake-up events group<br><br>0x0: McSPI 4 is not attached to the IVA2 wake-up events group.<br>0x1: McSPI 4 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 20    | GRPSEL_MCSPI3 | Select the McSPI 3 in the IVA2 wake-up events group<br><br>0x0: McSPI 3 is not attached to the IVA2 wake-up events group.<br>0x1: McSPI 3 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 19    | GRPSEL_MCSPI2 | Select the McSPI 2 in the IVA2 wake-up events group<br><br>0x0: McSPI 2 is not attached to the IVA2 wake-up events group.<br>0x1: McSPI 2 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 18    | GRPSEL_MCSPI1 | Select the McSPI 1 in the IVA2 wake-up events group<br><br>0x0: McSPI 1 is not attached to the IVA2 wake-up events group.<br>0x1: McSPI 1 is attached to the IVA2 wake-up events group. | RW   | 0x1   |

| Bits | Field Name      | Description                                                                                                                                                                                          | Type | Reset |
|------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 17   | GRPSEL_I2C3     | Select the I2C 3 in the IVA2 wake-up events group<br><br>0x0: I2C 3 is not attached to the IVA2 wake-up events group.<br><br>0x1: I2C 3 is attached to the IVA2 wake-up events group.                | RW   | 0x1   |
| 16   | GRPSEL_I2C2     | Select the I2C 2 in the IVA2 wake-up events group<br><br>0x0: I2C 2 is not attached to the IVA2 wake-up events group.<br><br>0x1: I2C 2 is attached to the IVA2 wake-up events group.                | RW   | 0x1   |
| 15   | GRPSEL_I2C1     | Select the I2C 1 in the IVA2 wake-up events group<br><br>0x0: I2C 1 is not attached to the IVA2 wake-up events group.<br><br>0x1: I2C 1 is attached to the IVA2 wake-up events group.                | RW   | 0x1   |
| 14   | GRPSEL_UART2    | Select the UART 2 in the IVA2 wake-up events group<br><br>0x0: UART 2 is not attached to the IVA2 wake-up events group.<br><br>0x1: UART 2 is attached to the IVA2 wake-up events group.             | RW   | 0x1   |
| 13   | GRPSEL_UART1    | Select the UART 1 in the IVA2 wake-up events group<br><br>0x0: UART 1 is not attached to the IVA2 wake-up events group.<br><br>0x1: UART 1 is attached to the IVA2 wake-up events group.             | RW   | 0x1   |
| 12   | GRPSEL_GPT11    | Select the GPTIMER 11 in the IVA2 wake-up events group<br><br>0x0: GPTIMER 11 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPTIMER 11 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 11   | GRPSEL_GPT10    | Select the GPTIMER 10 in the IVA2 wake-up events group<br><br>0x0: GPTIMER 10 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPTIMER 10 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 10   | GRPSEL_MCBSP5   | Select the McBSP 5 in the IVA2 wake-up events group<br><br>0x0: McBSP 5 is not attached to the IVA2 wake-up events group.<br><br>0x1: McBSP 5 is attached to the IVA2 wake-up events group.          | RW   | 0x1   |
| 9    | GRPSEL_MCBSP1   | Select the McBSP 1 in the IVA2 wake-up events group<br><br>0x0: McBSP 1 is not attached to the IVA2 wake-up events group.<br><br>0x1: McBSP 1 is attached to the IVA2 wake-up events group.          | RW   | 0x1   |
| 8:5  | RESERVED        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                   | R    | 0x0   |
| 4    | GRPSEL_HSOTGUSB | Select the HS OTG USB in the IVA2 wake-up events group<br><br>0x0: HS OTG USB is not attached to the IVA2 wake-up events group.<br><br>0x1: HS OTG USB is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 3:0  | RESERVED        | Write 0x8 for future compatibility. Read returns 0x8.                                                                                                                                                | R    | 0x8   |

**Table 3-345. Register Call Summary for Register PM\_IVA2GRPSEL1\_CORE**

## PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#)

## PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[1\]](#)

## PRCM Register Manual

- [CORE\\_PRM Registers: \[2\]](#)

**Table 3-346. PM\_WKST1\_CORE**

|                         |  |                                                                                                                                     |  |  |  |  |  |  |  |  |  |                 |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--|-------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   |  | 0x0000 00B0                                                                                                                         |  |  |  |  |  |  |  |  |  |                 |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> |  | 0x4830 6AB0                                                                                                                         |  |  |  |  |  |  |  |  |  | <b>Instance</b> |  | CORE_PRM |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      |  | This register logs module wake-up events. Must be cleared by software. If it is not cleared, it prevents further domain transition. |  |  |  |  |  |  |  |  |  |                 |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             |  | RW                                                                                                                                  |  |  |  |  |  |  |  |  |  |                 |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|---------|----------|----|---------|---------|----------|-----------|-----------|-----------|-----------|---------|---------|---------|----------|----------|----------|----------|-----------|-----------|----------|----|---|-------------|----------|---|---|---|---|---|---|---|
| RESERVED | ST_MMC3 | RESERVED |    | ST_MMC2 | ST_MMC1 | RESERVED | ST_MCSPI4 | ST_MCSPI3 | ST_MCSPI2 | ST_MCSPI1 | ST_I2C3 | ST_I2C2 | ST_I2C1 | ST_UART2 | ST_UART1 | ST_GPT11 | ST_GPT10 | ST_MCBSP5 | ST_MCBSP1 | RESERVED |    |   | ST_HSOTGUSB | RESERVED |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                              | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                       | RW   | 0x0   |
| 30    | ST_MMC3    | MMC 3 Wake-up status<br><br>Read 0x0: MMC 3 wake-up did not occur or was masked.<br>Write 0x0: Status bit unchanged<br>Read 0x1: MMC 3 wake-up occurred.<br>Write 0x1: Status bit is cleared to 0.       | RW   | 0x0   |
| 29:26 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                       | R    | 0x0   |
| 25    | ST_MMC2    | MMC 2 Wake-up status<br><br>Read 0x0: MMC 2 wake-up did not occur or was masked.<br>Write 0x0: Status bit unchanged<br>Read 0x1: MMC 2 wake-up occurred.<br>Write 0x1: Status bit is cleared to 0.       | RW   | 0x0   |
| 24    | ST_MMC1    | MMC 1 Wake-up status<br><br>Read 0x0: MMC 1 wake-up did not occur or was masked.<br>Write 0x0: Status bit unchanged<br>Read 0x1: MMC 1 wake-up occurred.<br>Write 0x1: Status bit is cleared to 0.       | RW   | 0x0   |
| 23:22 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                       | R    | 0x0   |
| 21    | ST_MCSPI4  | McSPI 4 Wake-up status<br><br>Read 0x0: McSPI 4 wake-up did not occur or was masked.<br>Write 0x0: Status bit unchanged<br>Read 0x1: McSPI 4 wake-up occurred.<br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                                                                                                                          | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 20   | ST_MCSPI3  | <p>McSPI 3 Wake-up status</p> <p>Read 0x0: McSPI 3 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: McSPI 3 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>          | RW   | 0x0   |
| 19   | ST_MCSPI2  | <p>McSPI 2 Wake-up status</p> <p>Read 0x0: McSPI 2 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: McSPI 2 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>          | RW   | 0x0   |
| 18   | ST_MCSPI1  | <p>McSPI 1 Wake-up status</p> <p>Read 0x0: McSPI 1 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: McSPI 1 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>          | RW   | 0x0   |
| 17   | ST_I2C3    | <p>I2C 3 Wake-up status</p> <p>Read 0x0: I2C 3 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: I2C 3 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>                | RW   | 0x0   |
| 16   | ST_I2C2    | <p>I2C 2 Wake-up status</p> <p>Read 0x0: I2C 2 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: I2C 2 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>                | RW   | 0x0   |
| 15   | ST_I2C1    | <p>I2C 1 Wake-up status</p> <p>Read 0x0: I2C 1 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: I2C 1 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>                | RW   | 0x0   |
| 14   | ST_UART2   | <p>UART 2 Wake-up status</p> <p>Read 0x0: UART 2 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: UART 2 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>             | RW   | 0x0   |
| 13   | ST_UART1   | <p>UART 1 Wake-up status</p> <p>Read 0x0: UART 1 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: UART 1 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>             | RW   | 0x0   |
| 12   | ST_GPT11   | <p>GPTIMER 11 Wake-up status</p> <p>Read 0x0: GPTIMER 11 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Status bit is cleared to 0.</p> <p>Write 0x1: GPTIMER 11 wake-up occurred.</p> | RW   | 0x0   |

| Bits | Field Name  | Description                                                                                                                                                                                                                   | Type | Reset |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 11   | ST_GPT10    | GPTIMER 10 Wake-up status<br><br>Read 0x0: GPTIMER 10 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: GPTIMER 10 wake-up occurred.<br><br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0   |
| 10   | ST_MCBSP5   | McBSP 5 Wake-up status<br><br>Read 0x0: McBSP 5 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: McBSP 5 wake-up occurred.<br><br>Write 0x1: Status bit is cleared to 0.          | RW   | 0x0   |
| 9    | ST_MCBSP1   | McBSP 1 Wake-up status<br><br>Read 0x0: McBSP 1 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: McBSP 1 wake-up occurred.<br><br>Write 0x1: Status bit is cleared to 0.          | RW   | 0x0   |
| 8:5  | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                            | R    | 0x0   |
| 4    | ST_HSOTGUSB | HS OTG USB Wake-up status<br><br>Read 0x0: HS OTG USB wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: HS OTG USB wake-up occurred.<br><br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0   |
| 3:0  | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                            | R    | 0x0   |

**Table 3-347. Register Call Summary for Register PM\_WKST1\_CORE**

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[0\]](#)

PRCM Register Manual

- [CORE\\_PRM Registers: \[1\]](#)

**Table 3-348. PM\_WKST3\_CORE**

|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 00B8                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | <a href="#">0x4830 6AB8</a>                                                                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | This register logs module wake-up events. Must be cleared by software. If it is not cleared, it prevents further domain transition. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                          | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                   | R    | 0x00000000 |
| 2    | ST_USBPLL  | USB TLL wake-up status<br>Read 0x0: USB TLL wake-up did not occur or was masked.<br>Write 0x0: Status bit unchanged<br>Read 0x1: USB TLL wake-up occurred.<br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0        |
| 1:0  | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                   | R    | 0x0        |

**Table 3-349. Register Call Summary for Register PM\_WKST3\_CORE**

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[0\]](#)

PRCM Register Manual

- [CORE\\_PRM Registers: \[1\]](#)

**Table 3-350. PM\_PWSTCTRL\_CORE**

|                         |                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00E0                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 6AE0                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register controls the CORE domain power state transition. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |             |             |          |    |    |    |    |    |              |              |          |    |                |              |               |            |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|-------------|-------------|----------|----|----|----|----|----|--------------|--------------|----------|----|----------------|--------------|---------------|------------|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    | MEM2ONSTATE | MEM1ONSTATE | RESERVED |    |    |    |    |    | MEM2RETSTATE | MEM1RETSTATE | RESERVED |    | SAVEANDRESTORE | MEMORYCHANGE | LOGICRETSTATE | POWERSTATE |   |   |   |   |   |   |   |   |

| Bits  | Field Name   | Description                                                                                                                                                                                                        | Type | Reset |
|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:20 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                 | R    | 0x00  |
| 19:18 | MEM2ONSTATE  | Memory block 2 state when domain is ON<br>0x0: Memory block 2 is OFF when domain is ON.<br>0x1: Memory block 2 is in RETENTION when domain is ON.<br>0x2: Reserved<br>0x3: Memory block 2 is ON when domain is ON. | RW   | 0x3   |
| 17:16 | MEM1ONSTATE  | Memory block 1 state when domain is ON<br>0x0: Memory block 1 is OFF when domain is ON.<br>0x1: Memory block 1 is in RETENTION when domain is ON.<br>0x2: Reserved<br>0x3: Memory block 1 is ON when domain is ON. | RW   | 0x3   |
| 15:10 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                 | R    | 0x00  |
| 9     | MEM2RETSTATE | Memory block 2 state when domain is RETENTION<br>0x0: Memory block 2 is OFF when domain is in RETENTION state.<br>0x1: Memory block 2 is retained when domain is in RETENTION state.                               | RW   | 0x1   |

| Bits | Field Name     | Description                                                                                                                                                                                                                                                                    | Type | Reset |
|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 8    | MEM1RETSTATE   | Memory block 1 state when domain is RETENTION<br><br>0x0: Memory block 1 is OFF when domain is in RETENTION state.<br><br>0x1: Memory block 1 is retained when domain is in RETENTION state.                                                                                   | RW   | 0x1   |
| 7:5  | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                             | R    | 0x0   |
| 4    | SAVEANDRESTORE | Save And Restore mechanism for the USB TLL module<br><br>0x0: Disable the save and restore mechanism for the USB TLL module<br><br>0x1: Enable the save and restore mechanism for the USB TLL module                                                                           | RW   | 0x0   |
| 3    | MEMORYCHANGE   | Memory change control in ON state<br><br>0x0: Disable memory change.<br><br>0x1: Enable memory change state in ON state. This bit is automatically cleared when memory state is effectively changed.                                                                           | RW   | 0x0   |
| 2    | LOGICRETSTATE  | Logic state when domain is RETENTION<br><br>0x0: Logic build with retention flip-flop (SMS, SDRC, control module, clock management) is retained and remaining logic is OFF when domain is in RETENTION state.<br><br>0x1: Logic is retained when domain is in RETENTION state. | RW   | 0x1   |
| 1:0  | POWERSTATE     | Power state control<br><br>0x0: OFF state<br><br>0x1: RETENTION state<br><br>0x2: Reserved<br><br>0x3: ON state                                                                                                                                                                | RW   | 0x3   |

**Table 3-351. Register Call Summary for Register PM\_PWSTCTRL\_CORE**

---

PRCM Functional Description

- [Power Domain Implementation](#): [0] [1] [2]
  - [Internal Clock Controls](#): [3]
  - [USBHOST/USBTLL Save-and-Restore Management](#): [4] [5] [6] [7]
- 

PRCM Basic Programming Model

- [PM\\_PWSTCTRL\\_domain\\_name \(Power State Control Register\)](#): [8]
- 

PRCM Register Manual

- [CORE\\_PRM Registers](#): [9] [10] [11]
- 

**NOTE:** Before initiating a domain sleep transition (ON to OFF) on the MPU and CORE power domains, the CORE memory banks must be configured to automatically switch to ON power state when the CORE power domain wakes up (OFF to ON). This is required for correct booting.

This is done by setting the [PM\\_PWSTCTRL\\_CORE \[19:18\]](#) MEM2ONSTATE bit field to 0x3 and the [PM\\_PWSTCTRL\\_CORE \[17:16\]](#) MEM1ONSTATE bit field to 0x3."

---

**Table 3-352. PM\_PWSTST\_CORE**

|                         |                                                                                   |                 |          |
|-------------------------|-----------------------------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 00E4                                                                       |                 |          |
| <b>Physical Address</b> | 0x4830 6AE4                                                                       | <b>Instance</b> | CORE_PRM |
| <b>Description</b>      | This register provides a status on the power state transition of the CORE domain. |                 |          |
| <b>Type</b>             | R                                                                                 |                 |          |



| Bits  | Field Name   | Description                                                                                                                                             | Type | Reset |
|-------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED     | Read returns 0.                                                                                                                                         | R    | 0x000 |
| 20    | INTRANSITION | Domain transition status<br>0x0: No transition<br>0x1: CORE power domain transition is in progress.                                                     | R    | 0x0   |
| 19:8  | RESERVED     | Read returns 0.                                                                                                                                         | R    | 0x000 |
| 7:6   | MEM2STATEST  | Memory block 2 state status<br>0x0: Memory is OFF<br>0x1: Memory is in RETENTION<br>0x2: Reserved<br>0x3: Memory is ON                                  | R    | 0x3   |
| 5:4   | MEM1STATEST  | Memory block 1 state status<br>0x0: Memory is OFF<br>0x1: Memory is in RETENTION<br>0x2: Reserved<br>0x3: Memory is ON                                  | R    | 0x3   |
| 3     | RESERVED     | Read returns 0.                                                                                                                                         | R    | 0x0   |
| 2     | LOGICSTATEST | Logic state status<br>0x0: CORE domain logic is OFF<br>0x1: CORE domain logic is ON                                                                     | R    | 0x1   |
| 1:0   | POWERSTATEST | Current power state status<br>0x0: Power domain is OFF<br>0x1: Power domain is in RETENTION<br>0x2: Power domain is INACTIVE<br>0x3: Power domain is ON | R    | 0x3   |

**Table 3-353. Register Call Summary for Register PM\_PWSTST\_CORE**

- **PM\_PWSTST\_domain\_name** (Power State Status Register): [0]

- ## PRCM Register Manual

**Table 3-354. PM\_PREPWSTST\_CORE**

|                         |                                                                                                                                           |                         |                 |                      |                      |          |                       |                       |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|----------------------|----------------------|----------|-----------------------|-----------------------|
| <b>Address Offset</b>   | 0x0000 00E8                                                                                                                               | <b>Physical Address</b> | 0x4830 6AE8     | <b>Instance</b>      | CORE_PRM             |          |                       |                       |
| <b>Description</b>      | This register provides a status on the CORE domain previous power state. It indicates the state entered during the last sleep transition. |                         |                 |                      |                      |          |                       |                       |
| <b>Type</b>             | RW                                                                                                                                        |                         |                 |                      |                      |          |                       |                       |
| 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 |                      |                      |          |                       |                       |
|                         |                                                                                                                                           |                         |                 | LASTMEM2STATEENTERED | LASTMEM1STATEENTERED | RESERVED | LASTLOGICSTATEENTERED | LASTPOWERSTATEENTERED |
| RESERVED                |                                                                                                                                           |                         |                 |                      |                      |          |                       |                       |

| Bits | Field Name            | Description                                                                                                                                                                                           | Type | Reset     |
|------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:8 | RESERVED              | Read returns 0.                                                                                                                                                                                       | R    | 0x0000000 |
| 7:6  | LASTMEM2STATEENTERED  | Last Memory block 2 state entered<br><br>0x0: Memory was previously OFF<br>0x1: Memory was previously in RETENTION<br>0x2: Reserved<br>0x3: Memory was previously ON                                  | RW   | 0x0       |
| 5:4  | LASTMEM1STATEENTERED  | Last Memory block 1 state entered<br><br>0x0: Memory was previously OFF<br>0x1: Memory was previously in RETENTION<br>0x2: Reserved<br>0x3: Memory was previously ON                                  | RW   | 0x0       |
| 3    | RESERVED              | Read returns 0.                                                                                                                                                                                       | R    | 0x0       |
| 2    | LASTLOGICSTATEENTERED | Last logic state entered<br><br>0x0: CORE domain logic was previously OFF<br>0x1: CORE domain logic was previously ON                                                                                 | RW   | 0x0       |
| 1:0  | LASTPOWERSTATEENTERED | Last power state entered<br><br>0x0: CORE domain was previously OFF<br>0x1: CORE domain was previously in RETENTION<br>0x2: CORE domain was previously INACTIVE<br>0x3: CORE domain was previously ON | RW   | 0x0       |

**Table 3-355. Register Call Summary for Register PM\_PREPWSTST\_CORE**
**PRCM Basic Programming Model**

- [PM\\_PREPWSTST\\_domain\\_name \(Previous Power State Status Register\): \[0\]](#)

**PRCM Register Manual**

- [CORE\\_PRM Registers: \[1\]](#)

**Table 3-356. PM\_WKEN3\_CORE**

|                         |                                                                 |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00F0                                                     |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 6AF0                                                     |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register allows enabling/disabling modules wake-up events. |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                              |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                          | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                   | R    | 0x00000000 |
| 2    | EN_USBPLL  | USB TLL wake-up control<br>0x0: USB TLL wake-up is disabled<br>0x1: USB TLL wake-up event is enabled | RW   | 0x1        |
| 1:0  | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                   | R    | 0x0        |

**Table 3-357. Register Call Summary for Register PM\_WKEN3\_CORE**

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[0\]](#)

PRCM Register Manual

- [CORE\\_PRM Registers: \[1\]](#)

**Table 3-358. PM\_IVA2GRPSEL3\_CORE**

|                         |                                                                            |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00F4                                                                |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 6AF4                                                                |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register allows selecting the group of modules that wake-up the IVA2. |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                         |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name    | Description                                                                                                                                                                        | Type | Reset      |
|------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                 | R    | 0x00000000 |
| 2    | GRPSEL_USBPLL | Select the USB TLL in the IVA2 wake-up events group<br>0x0: USB TLL is not attached to the IVA2 wake-up events group<br>0x1: USB TLL is attached to the IVA2 wake-up events group. | RW   | 0x1        |
| 1:0  | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                 | R    | 0x0        |

**Table 3-359. Register Call Summary for Register PM\_IVA2GRPSEL3\_CORE**

---

PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#)

---

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[1\]](#)

---

PRCM Register Manual

- [CORE\\_PRM Registers: \[2\]](#)

**Table 3-360. PM\_MPUGRPSEL3\_CORE**

|                         |                                                                           |                 |          |
|-------------------------|---------------------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 00F8                                                               |                 |          |
| <b>Physical Address</b> | 0x4830 6AF8                                                               | <b>Instance</b> | CORE_PRM |
| <b>Description</b>      | This register allows selecting the group of modules that wake-up the MPU. |                 |          |
| <b>Type</b>             | RW                                                                        |                 |          |



| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:3        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                       | R           | 0x00000000   |
| 2           | GRPSEL_USBPLL     | Select the USB TLL in the MPU wake-up events group<br><br>0x0: USB TLL is not attached to the MPU wake-up events group.<br><br>0x1: USB TLL is attached to the MPU wake-up events group. | RW          | 0x1          |
| 1:0         | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                       | R           | 0x0          |

**Table 3-361. Register Call Summary for Register PM\_MPUGRPSEL3\_CORE**

---

PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#)

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[1\]](#)

---

PRCM Register Manual

- [CORE\\_PRM Registers: \[2\]](#)

### **3.7.2.6 SGX\_PRM Registers**

### **3.7.2.6.1 SGX\_PRM Register Summary**

**Table 3-362. SGX\_PRM Register Summary**

| Register Name   | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|-----------------|------|-----------------------|----------------|------------------|------------|
| RM_RSTST_SGX    | RW   | 32                    | 0x0000 0058    | 0x4830 6B58      | C          |
| PM_WKDEP_SGX    | RW   | 32                    | 0x0000 00C8    | 0x4830 6BC8      | W          |
| PM_PWSTCTRL_SGX | RW   | 32                    | 0x0000 00E0    | 0x4830 6BE0      | W          |
| PM_PWSTST_SGX   | R    | 32                    | 0x0000 00E4    | 0x4830 6BE4      | C          |

**Table 3-362. SGX\_PRM Register Summary (continued)**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|------------------|------|-----------------------|----------------|------------------|------------|
| PM_PREPWSTST_SGX | RW   | 32                    | 0x0000 00E8    | 0x4830 6BE8      | C          |

### 3.7.2.6.2 SGX\_PRM Registers

**Table 3-363. RM\_RSTST\_SGX**

|                         |                                                                                                                                                         |                       |                 |          |                  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|------------------|
| Address Offset          | 0x0000 0058                                                                                                                                             | Physical Address      | 0x4830 6B58     | Instance | SGX_PRM          |
| Description             | This register logs the different reset sources of the SGX domain. Each bit is set upon release of the domain reset signal. Must be cleared by software. |                       |                 |          |                  |
| Type                    | RW                                                                                                                                                      |                       |                 |          |                  |
| 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 |          |                  |
|                         |                                                                                                                                                         |                       |                 | RESERVED |                  |
|                         |                                                                                                                                                         |                       |                 |          | COREDOMEWKUP_RST |
|                         |                                                                                                                                                         |                       |                 |          | DOMAINWKUP_RST   |
|                         |                                                                                                                                                         |                       |                 |          | GLOBALWARM_RST   |
|                         |                                                                                                                                                         |                       |                 |          | GLOBALCOLD_RST   |

| Bits | Field Name       | Description                                                                                                                                                                                                                                                            | Type | Reset     |
|------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:4 | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                     | R    | 0x0000000 |
| 3    | COREDOMEWKUP_RST | <p>CORE domain wake-up reset</p> <p>Read 0x0: No power domain wake-up reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: SGX domain has been reset following a CORE power domain wake-up from OFF to ON.</p> <p>Write 0x1: Status bit is cleared to 0.</p> | RW   | 0x0       |
| 2    | DOMAINWKUP_RST   | <p>Power domain wake-up reset</p> <p>Read 0x0: SGX domain is not reset</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: SGX domain has been reset following a SGX domain wake-up.</p> <p>Write 0x1: Status bit is cleared to 0.</p>                             | RW   | 0x0       |
| 1    | GLOBALWARM_RST   | <p>Global warm reset</p> <p>Read 0x0: No global warm reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: SGX domain has been reset upon a global warm reset</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                               | RW   | 0x0       |
| 0    | GLOBALCOLD_RST   | <p>Global cold reset</p> <p>Read 0x0: No global cold reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: SGX domain has been reset upon a global cold reset</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                               | RW   | 0x1       |

**Table 3-364. Register Call Summary for Register RM\_RSTST\_SGX**


---

 PRCM Basic Programming Model

- [Reset Control: \[0\]](#)
- 

PRCM Register Manual

- [SGX\\_PRM Registers: \[1\]](#)
- 

**Table 3-365. PM\_WKDEP\_SGX**

|                       |                                                                                                      |                         |             |                 |         |
|-----------------------|------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 00C8                                                                                          | <b>Physical Address</b> | 0x4830 6BC8 | <b>Instance</b> | SGX_PRM |
| <b>Description</b>    | This register allows enabling or disabling the wake-up of the SGX domain upon another domain wakeup. |                         |             |                 |         |
| <b>Type</b>           | RW                                                                                                   |                         |             |                 |         |



| Bits | Field Name | Description                                                                                                                                             | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:5 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                      | R    | 0x00000000 |
| 4    | EN_WKUP    | WAKEUP domain dependency<br>0x0: SGX domain is independent of WKUP domain wake-up event.<br>0x1: SGX domain is woken-up upon WKUP domain wake-up event. | RW   | 0x1        |
| 3    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                      | R    | 0x0        |
| 2    | EN_IVA2    | IVA2 domain dependency<br>0x0: SGX domain is independent of IVA2 domain wake-up event.<br>0x1: SGX domain is woken-up upon IVA2 domain wake-up event.   | RW   | 0x1        |
| 1    | EN_MPUM    | MPU domain dependency<br>0x0: SGX domain is independent of MPU domain wake-up.<br>0x1: SGX domain is woken-up upon MPU domain wake-up.                  | RW   | 0x1        |
| 0    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                      | R    | 0x0        |

**Table 3-366. Register Call Summary for Register PM\_WKDEP\_SGX**


---

 PRCM Functional Description

- [Device Wake-Up Events: \[0\] \[1\] \[2\]](#)
- 

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[3\]](#)
- 

PRCM Register Manual

- [SGX\\_PRM Registers: \[4\]](#)
-

**Table 3-367. PM\_PWSTCTRL\_SGX**

|                       |                                                               |                         |             |                 |         |
|-----------------------|---------------------------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 00E0                                                   | <b>Physical Address</b> | 0x4830 6BE0 | <b>Instance</b> | SGX_PRM |
| <b>Description</b>    | This register controls the SGX domain power state transition. |                         |             |                 |         |
| <b>Type</b>           | RW                                                            |                         |             |                 |         |



| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:18       | RESERVED          | Write 0s for future compatibility. Read returns 0.                                               | R           | 0x0000       |
| 17:16       | MEMONSTATE        | Memory state when ON<br>0x3: Memory is always ON when domain is ON.                              | R           | 0x3          |
| 15:9        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                               | R           | 0x00         |
| 8           | MEMRETSTATE       | Memory state when RETENTION<br>0x1: Memory is always retained when domain is in RETENTION state. | R           | 0x1          |
| 7:3         | RESERVED          | Write 0s for future compatibility. Read returns 0.                                               | R           | 0x00         |
| 2           | LOGICRETSTATE     | Logic state when RETENTION<br>0x1: Logic is always retained when domain is in RETENTION state.   | R           | 0x1          |
| 1:0         | POWERSTATE        | Power state control<br>0x0: OFF state<br>0x1: RETENTION state<br>0x2: Reserved<br>0x3: ON state  | RW          | 0x3          |

**Table 3-368. Register Call Summary for Register PM\_PWSTCTRL\_SGX**

PRCM Basic Programming Model

- [PM\\_PWSTCTRL\\_domain\\_name \(Power State Control Register\): \[0\]](#)

PRCM Register Manual

- [SGX\\_PRM Registers: \[1\]](#)

**Table 3-369. PM\_PWSTST\_SGX**

|                       |                                                                                  |                         |             |                 |         |
|-----------------------|----------------------------------------------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 00E4                                                                      | <b>Physical Address</b> | 0x4830 6BE4 | <b>Instance</b> | SGX_PRM |
| <b>Description</b>    | This register provides a status on the power state transition of the SGX domain. |                         |             |                 |         |
| <b>Type</b>           | R                                                                                |                         |             |                 |         |



| Bits  | Field Name   | Description                                                                                                                                                             | Type | Reset   |
|-------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:21 | RESERVED     | Read returns 0.                                                                                                                                                         | R    | 0x000   |
| 20    | INTRANSITION | Domain transition status<br><br>0x0: No transition<br><br>0x1: SGX power domain transition is in progress.                                                              | R    | 0x0     |
| 19:2  | RESERVED     | Read returns 0.                                                                                                                                                         | R    | 0x00000 |
| 1:0   | POWERSTATE   | Current power state status<br><br>0x0: Power domain is OFF<br><br>0x1: Power domain is in RETENTION<br><br>0x2: Power domain is INACTIVE<br><br>0x3: Power domain is ON | R    | 0x3     |

**Table 3-370. Register Call Summary for Register PM\_PWSTST\_SGX**

PRCM Basic Programming Model

- [PM\\_PWSTST\\_domain\\_name \(Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [SGX\\_PRM Registers: \[1\]](#)

**Table 3-371. PM\_PREPWSTST\_SGX**

|                         |                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    |                 |                         |    |    |    |    |    |    |    |   |   |                       |   |   |   |   |   |   |   |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------|-------------------------|----|----|----|----|----|----|----|---|---|-----------------------|---|---|---|---|---|---|---|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00E8                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |                 |                         |    |    |    |    |    |    |    |   |   |                       |   |   |   |   |   |   |   |  |  |  |  |
| <b>Physical Address</b> | <a href="#">0x4830 6BE8</a>                                                                                                              |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b> | <a href="#">SGX_PRM</a> |    |    |    |    |    |    |    |   |   |                       |   |   |   |   |   |   |   |  |  |  |  |
| <b>Description</b>      | This register provides a status on the SGX domain previous power state. It indicates the state entered during the last sleep transition. |    |    |    |    |    |    |    |    |    |    |    |                 |                         |    |    |    |    |    |    |    |   |   |                       |   |   |   |   |   |   |   |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |                 |                         |    |    |    |    |    |    |    |   |   |                       |   |   |   |   |   |   |   |  |  |  |  |
| 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 |  |  |  |  |
| RESERVED                |                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    |                 |                         |    |    |    |    |    |    |    |   |   | LASTPOWERSTATEENTERED |   |   |   |   |   |   |   |  |  |  |  |

| Bits | Field Name            | Description                                                                                                                                                                                       | Type | Reset      |
|------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                | R    | 0x00000000 |
| 1:0  | LASTPOWERSTATEENTERED | Last power state entered<br><br>0x0: SGX domain was previously OFF<br>0x1: SGX domain was previously in RETENTION<br>0x2: SGX domain was previously INACTIVE<br>0x3: SGX domain was previously ON | RW   | 0x0        |

**Table 3-372. Register Call Summary for Register PM\_PREPWSTST\_SGX**

PRCM Basic Programming Model

- [PM\\_PREPWSTST\\_domain\\_name \(Previous Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [SGX\\_PRM Registers: \[1\]](#)

### 3.7.2.7 WKUP\_PRM Registers

#### 3.7.2.7.1 WKUP\_PRM Register Summary

**Table 3-373. WKUP\_PRM Register Summary**

| Register Name      | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|--------------------|------|-----------------------|----------------|------------------|------------|
| PM_WKEN_WKUP       | RW   | 32                    | 0x0000 00A0    | 0x4830 6CA0      | W          |
| PM_MPUGRPSEL_WKUP  | RW   | 32                    | 0x0000 00A4    | 0x4830 6CA4      | W          |
| PM_IVA2GRPSEL_WKUP | RW   | 32                    | 0x0000 00A8    | 0x4830 6CA8      | W          |
| PM_WKST_WKUP       | RW   | 32                    | 0x0000 00B0    | 0x4830 6CB0      | C          |

#### 3.7.2.7.2 WKUP\_PRM Registers

**Table 3-374. PM\_WKEN\_WKUP**

|                |                                                                 |                  |             |          |          |
|----------------|-----------------------------------------------------------------|------------------|-------------|----------|----------|
| Address Offset | 0x0000 00A0                                                     | Physical Address | 0x4830 6CA0 | Instance | WKUP_PRM |
| Description    | This register allows enabling/disabling modules wake-up events. |                  |             |          |          |
| Type           | RW                                                              |                  |             |          |          |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |          |    |    |    |          |       |        |        |          |          |          |          |         |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|----------|----|----|----|----------|-------|--------|--------|----------|----------|----------|----------|---------|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EN_IO_CHAIN | RESERVED |    |    |    | RESERVED | EN_IO | EN_SR2 | EN_SR1 | RESERVED | EN_GPIO1 | RESERVED | RESERVED | EN_GPT1 |   |   |

| Bits  | Field Name  | Description                                                                                                                            | Type | Reset    |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:17 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                     | R    | 0x000000 |
| 16    | EN_IO_CHAIN | I/O daisy chain wakeup is disabled.<br><br>0x0: I/O wake-up daisy chain is disabled.<br>0x1: I/O wake-up daisy chain event is enabled. | RW   | 1        |
| 15:10 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                     | R    | 0x000000 |
| 9     | RESERVED    | Reserved for non-GP devices                                                                                                            | RW   | 0x1      |

| Bits | Field Name | Description                                                                                                           | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------|------|-------|
| 8    | EN_IO      | IO pad wake-up control<br>0x0: IO pad wakeup is disabled<br>0x1: IO pad wake-up event is enabled                      | RW   | 0x1   |
| 7    | EN_SR2     | SmartRefex 2 wake-up control<br>0x0: SmartReflex 2 wakeup is disabled<br>0x1: Smart Reflex 2 wake-up event is enabled | RW   | 0x1   |
| 6    | EN_SR1     | Smart Refex 1 wakeup control<br>0x0: SmartReflex 1 wakeup is disabled<br>0x1: SmartReflex 1 wake-up event is enabled  | RW   | 0x1   |
| 5:4  | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                    | R    | 0x0   |
| 3    | EN_GPIO1   | GPIO 1 wake-up control<br>0x0: GPIO 1 wakeup is disabled<br>0x1: GPIO 1 wake-up event is enabled                      | RW   | 0x1   |
| 2    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                    | R    | 0x0   |
| 1    | RESERVED   | Reserved for non-GP devices                                                                                           | R    | 0x1   |
| 0    | EN_GPT1    | GPTIMER 1 wake-up control<br>0x0: GPTIMER 1 wakeup is disabled<br>0x1: GPTIMER 1 wake-up event is enabled             | RW   | 0x1   |

**Table 3-375. Register Call Summary for Register PM\_WKEN\_WKUP**
**PRCM Functional Description**

- [Device Wake-Up Events: \[0\] \[1\]](#)
- [Device Off-Mode Configuration: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\]](#)
- [CORE Power Domain Off-Mode Sequences: \[8\] \[9\] \[10\] \[11\]](#)
- [Device Off-Mode Sequences: \[12\] \[13\] \[14\] \[15\]](#)

**PRCM Basic Programming Model**

- [Interrupt Configuration Registers: \[16\]](#)
- [Domain Wake-Up Control Registers: \[17\]](#)

**PRCM Register Manual**

- [WKUP\\_PRM Registers: \[18\]](#)

**Table 3-376. PM\_MPUGRPSEL\_WKUP**

|                         |                                                           |    |    |    |    |    |    |    |    |    |    |    |                 |                          |    |          |           |            |            |          |              |          |          |             |   |   |   |   |   |   |   |
|-------------------------|-----------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------|--------------------------|----|----------|-----------|------------|------------|----------|--------------|----------|----------|-------------|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 00A4                                               |    |    |    |    |    |    |    |    |    |    |    |                 |                          |    |          |           |            |            |          |              |          |          |             |   |   |   |   |   |   |   |
| <b>Physical Address</b> | <a href="#">0x4830 6CA4</a>                               |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b> | <a href="#">WKUP_PRM</a> |    |          |           |            |            |          |              |          |          |             |   |   |   |   |   |   |   |
| <b>Description</b>      | IO pad is always selected in the MPU wake-up events group |    |    |    |    |    |    |    |    |    |    |    |                 |                          |    |          |           |            |            |          |              |          |          |             |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                        |    |    |    |    |    |    |    |    |    |    |    |                 |                          |    |          |           |            |            |          |              |          |          |             |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                           |    |    |    |    |    |    |    |    |    |    |    |                 |                          |    | RESERVED | GRPSEL_IO | GRPSEL_SR2 | GRPSEL_SR1 | RESERVED | GRPSEL_GPIO1 | RESERVED | RESERVED | GRPSEL_GPT1 |   |   |   |   |   |   |   |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |           |          |          |          |          |          |          |             |          |          |          |          |          |          |          |          |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|-----------|----------|----------|----------|----------|----------|----------|-------------|----------|----------|----------|----------|----------|----------|----------|----------|
| 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        |          |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RESERVED | GRPSEL_IO | RESERVED | RESERVED | RESERVED | RESERVED | RESERVED | RESERVED | GRPSEL_GPT1 | RESERVED |

| Bits  | Field Name   | Description                                                                                                                                                                                                   | Type | Reset    |
|-------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:10 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                            | R    | 0x000000 |
| 9     | RESERVED     | Reserved for non-GP devices.                                                                                                                                                                                  | RW   | 0x1      |
| 8     | GRPSEL_IO    | IO pad is always selected in the MPU wake-up events group                                                                                                                                                     | R    | 0x1      |
| 7     | GRPSEL_SR2   | Select the Smart Reflex 2 in the MPU wake-up events group<br><br>0x0: Smart Reflex 2 is not attached to the MPU wake-up events group.<br><br>0x1: Smart Reflex 2 is attached to the MPU wake-up events group. | RW   | 0x1      |
| 6     | GRPSEL_SR1   | Select the Smart Reflex 1 in the MPU wake-up events group<br><br>0x0: Smart Reflex 1 is not attached to the MPU wake-up events group.<br><br>0x1: Smart Reflex 1 is attached to the MPU wake-up events group. | RW   | 0x1      |
| 5:4   | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                            | R    | 0x0      |
| 3     | GRPSEL_GPIO1 | Select the GPIO 1 in the MPU wake-up events group<br><br>0x0: GPIO 1 is not attached to the MPU wake-up events group.<br><br>0x1: GPIO 1 is attached to the MPU wake-up events group.                         | RW   | 0x1      |
| 2     | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                            | R    | 0x0      |
| 1     | RESERVED     | Reserved for non-GP devices.                                                                                                                                                                                  | R    | 0x1      |
| 0     | GRPSEL_GPT1  | Select the GPTIMER 1 in the MPU wake-up events group<br><br>0x0: GPTIMER 1 is not attached to the MPU wake-up events group.<br><br>0x1: GPTIMER 1 is attached to the MPU wake-up events group.                | RW   | 0x1      |

**Table 3-377. Register Call Summary for Register PM\_MPUGRPSEL\_WKUP**

## PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#)

## PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[1\]](#)

## PRCM Register Manual

- [WKUP\\_PRM Registers: \[2\]](#)

**Table 3-378. PM\_IVA2GRPSEL\_WKUP**

|                       |                                                                            |                         |             |                 |          |
|-----------------------|----------------------------------------------------------------------------|-------------------------|-------------|-----------------|----------|
| <b>Address Offset</b> | 0x0000 00A8                                                                | <b>Physical Address</b> | 0x4830 6CA8 | <b>Instance</b> | WKUP_PRM |
| <b>Description</b>    | This register allows selecting the group of modules that wake-up the IVA2. |                         |             |                 |          |
| <b>Type</b>           | RW                                                                         |                         |             |                 |          |



| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:10       | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                               | R           | 0x000000     |
| 9           | RESERVED          | Reserved for non-GP devices.                                                                                                                                                                                     | RW          | 0x0          |
| 8           | GRPSEL_IO         | Select the IO pad in the IVA2 wake-up events group<br><br>0x0: IO pad module is not attached to the IVA2 wake-up events group.<br><br>0x1: IO pad module is attached to the IVA2 wake-up events group.           | RW          | 0x0          |
| 7           | GRPSEL_SR2        | Select the Smart Reflex 2 in the IVA2 wake-up events group<br><br>0x0: Smart Reflex 2 is not attached to the IVA2 wake-up events group.<br><br>0x1: Smart Reflex 2 is attached to the IVA2 wake-up events group. | RW          | 0x0          |
| 6           | GRPSEL_SR1        | Select the Smart Reflex 1 in the IVA2 wake-up events group<br><br>0x0: Smart Reflex 1 is not attached to the IVA2 wake-up events group.<br><br>0x1: Smart Reflex 1 is attached to the IVA2 wake-up events group. | RW          | 0x0          |
| 5:4         | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                               | R           | 0x0          |
| 3           | GRPSEL_GPIO1      | Select the GPIO 1 in the IVA2 wake-up events group<br><br>0x0: GPIO 1 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPIO 1 is attached to the IVA2 wake-up events group.                         | RW          | 0x0          |
| 2           | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                               | R           | 0x0          |
| 1           | RESERVED          | Reserved for non-GP devices.                                                                                                                                                                                     | RW          | 0x0          |
| 0           | GRPSEL_GPT1       | Select the GPTIMER 1 in the IVA2 wake-up events group<br><br>0x0: GPTIMER 1 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPTIMER 1 is attached to the IVA2 wake-up events group.                | RW          | 0x0          |

**Table 3-379. Register Call Summary for Register PM\_IVA2GRPSEL\_WKUP**

PRCM Basic Programming Model

- [Interrupt Configuration Registers: \[0\]](#)
- [Domain Wake-Up Control Registers: \[1\]](#)

PRCM Register Manual

- [WKUP\\_PRM Registers: \[2\]](#)

**Table 3-380. PM\_WKST\_WKUP**

| <b>Address Offset</b>   | 0x0000 00B0                                                                                                                         | <b>Physical Address</b>                                                                                                                                                                                                                                               | 0x4830 6CB0     | <b>Instance</b> | WKUP_PRM |          |          |          |          |          |         |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|----------|----------|----------|----------|----------|----------|---------|
| <b>Description</b>      | This register logs module wake-up events. Must be cleared by software. If it is not cleared, it prevents further domain transition. |                                                                                                                                                                                                                                                                       |                 |                 |          |          |          |          |          |          |         |
| <b>Type</b>             | RW                                                                                                                                  |                                                                                                                                                                                                                                                                       |                 |                 |          |          |          |          |          |          |         |
| 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 |                 |          |          |          |          |          |          |         |
| 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 |                 |          |          |          |          |          |          |         |
| RESERVED                |                                                                                                                                     |                                                                                                                                                                                                                                                                       |                 |                 |          |          |          |          |          |          |         |
|                         |                                                                                                                                     | ST_IO_CHAIN                                                                                                                                                                                                                                                           | RESERVED        | RESERVED        | ST_IO    | RESERVED | RESERVED | ST_GPIO1 | RESERVED | RESERVED | ST_GPT1 |
| Bits                    | Field Name                                                                                                                          | Description                                                                                                                                                                                                                                                           |                 |                 |          |          | Type     | Reset    |          |          |         |
| 31:17                   | RESERVED                                                                                                                            | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                    |                 |                 |          |          | R        | 0x000000 |          |          |         |
| 16                      | ST_IO_CHAIN                                                                                                                         | I/O wake-up scheme completion status.<br><br>Read 0x0: The I/O wake-up scheme is not enabled or is not complete.<br><br>Write 0x0: The status bit is unchanged.<br><br>Read 0x1: The I/O wake-up scheme is enabled.<br><br>Write 0x1: The status bit is cleared to 0. |                 |                 |          |          | RW       | 0        |          |          |         |
| 15:10                   | RESERVED                                                                                                                            | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                    |                 |                 |          |          | R        | 0x000000 |          |          |         |
| 9                       | RESERVED                                                                                                                            | Reserved for non-GP devices                                                                                                                                                                                                                                           |                 |                 |          |          | RW       | 0x0      |          |          |         |
| 8                       | ST_IO                                                                                                                               | IO pad wake-up status<br><br>Read 0x0: IO pad wakeup did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: IO pad wakeup occurred.<br><br>Write 0x1: Status bit is cleared to 0.                                                       |                 |                 |          |          | RW       | 0x0      |          |          |         |
| 7                       | ST_SR2                                                                                                                              | Smart Reflex 2 wake-up status<br><br>Read 0x0: Smart Reflex 2 wakeup did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: Smart Reflex 2 wakeup occurred.<br><br>Write 0x1: Status bit is cleared to 0.                               |                 |                 |          |          | RW       | 0x0      |          |          |         |
| 6                       | ST_SR1                                                                                                                              | Smart Reflex 1 wake-up status<br><br>Read 0x0: Smart Reflex 1 wakeup did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: Smart Reflex 1 wakeup occurred.<br><br>Write 0x1: Status bit is cleared to 0.                               |                 |                 |          |          | RW       | 0x0      |          |          |         |
| 5:4                     | RESERVED                                                                                                                            | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                    |                 |                 |          |          | R        | 0x0      |          |          |         |
| 3                       | ST_GPIO1                                                                                                                            | GPIO 1 Wake-up status<br><br>Read 0x0: GPIO 1 wakeup did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: GPIO 1 wakeup occurred.<br><br>Write 0x1: Status bit is cleared to 0.                                                       |                 |                 |          |          | RW       | 0x0      |          |          |         |
| 2                       | RESERVED                                                                                                                            | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                    |                 |                 |          |          | R        | 0x0      |          |          |         |
| 1                       | RESERVED                                                                                                                            | Reserved for non-GP devices.                                                                                                                                                                                                                                          |                 |                 |          |          | RW       | 0x0      |          |          |         |

| Bits | Field Name | Description                                                                                                                                                                                              | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | ST_GPT1    | GPTIMER 1 wake-up status<br>Read 0x0: GPTIMER 1 wakeup did not occur or was masked.<br>Write 0x0: Status bit unchanged<br>Read 0x1: GPTIMER 1 wakeup occurred.<br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0   |

**Table 3-381. Register Call Summary for Register PM\_WKST\_WKUP**

PRCM Functional Description

- [Device Off-Mode Configuration: \[0\] \[1\]](#)

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[2\]](#)

PRCM Register Manual

- [WKUP\\_PRM Registers: \[3\]](#)

### 3.7.2.8 Clock\_Control\_Reg\_PRM Registers

#### 3.7.2.8.1 Clock\_Control\_Reg\_PRM Register Summary

**Table 3-382. Clock\_Control\_Reg\_PRM Register Summary**

| Register Name   | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|-----------------|------|-----------------------|----------------|------------------|------------|
| PRM_CLKSEL      | RW   | 32                    | 0x0000 0040    | 0x4830 6D40      | C          |
| PRM_CLKOUT_CTRL | RW   | 32                    | 0x0000 0070    | 0x4830 6D70      | C          |

#### 3.7.2.8.2 Clock\_Control\_Reg\_PRM Registers

**Table 3-383. PRM\_CLKSEL**

|                         |                                                                                                              |                       |                 |          |                       |
|-------------------------|--------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|-----------------------|
| Address Offset          | 0x0000 0040                                                                                                  | Physical Address      | 0x4830 6D40     | Instance | Clock_Control_Reg_PRM |
| Description             | This register controls the selection of the system clock frequency. This register is reset on power-up only. |                       |                 |          |                       |
| Type                    | RW                                                                                                           |                       |                 |          |                       |
| 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 | RESERVED | SYS_CLKIN_SEL         |
|                         |                                                                                                              |                       |                 |          |                       |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                            | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:3        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                            | R           | 0x00000000   |
| 2:0         | SYS_CLKIN_SEL     | System clock input selection; Other enums: Reserved<br>0x0: OSC_SYS_CLK is 12 MHz<br>0x1: OSC_SYS_CLK is 13 MHz<br>0x2: OSC_SYS_CLK is 19.2 MHz<br>0x3: OSC_SYS_CLK is 26 MHz<br>0x4: OSC_SYS_CLK is 38.4 MHz<br>0x5: OSC_SYS_CLK is 16.8 MHz | RW          | 0x4          |

**Table 3-384. Register Call Summary for Register PRM\_CLKSEL**

- ## PRCM Functional Description

- External Clock I/Os: [0]

- PRCM Basic Programming Model

- System Clock Control Registers: [1]

- PRCM Register Manual

- **Clock\_Control\_Reg\_PRM Registers: [2]**

**Table 3-385. PRM\_CLKOUT\_CTRL**

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:8        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                               | R           | 0x000000     |
| 7           | CLKOUT_EN         | <p>This bit controls the external output clock (sys_clkout1) activity</p> <p>0x0: sys_clkout1 is disabled</p> <p>0x1: sys_clkout1 is enabled</p> | RW          | 0x1          |
| 6:0         | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                               | R           | 0x00         |

**Table 3-386. Register Call Summary for Register PRM\_CLKOUT\_CTRL**

- PRCM Functional Description

- External Clock Controls: [0] [1]

- Internal Clock Controls: [2]

- PRCM Register Manual

- Clock Control Req PRM Registers: [3]

### 3.7.2.9 DSS PRM Registers

### **3.7.2.9.1 DSS PRM Register Summary**

**Table 3-387. DSS\_PRM Register Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|------------------|------|-----------------------|----------------|------------------|------------|
| RM_RSTST_DSS     | RW   | 32                    | 0x0000 0058    | 0x4830 6E58      | C          |
| PM_WKEN_DSS      | RW   | 32                    | 0x0000 00A0    | 0x4830 6EA0      | W          |
| PM_WKDEP_DSS     | RW   | 32                    | 0x0000 00C8    | 0x4830 6EC8      | W          |
| PM_PWSTCTRL_DSS  | RW   | 32                    | 0x0000 00E0    | 0x4830 6EE0      | W          |
| PM_PWSTST_DSS    | R    | 32                    | 0x0000 00E4    | 0x4830 6EE4      | C          |
| PM_PREPWSTST_DSS | RW   | 32                    | 0x0000 00E8    | 0x4830 6EE8      | C          |

### 3.7.2.9.2 DSS\_PRM Registers

**Table 3-388. RM\_RSTST\_DSS**

|                         |                                                                                                                                                         |                       |                 |                    |                |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--------------------|----------------|--|--|
| Address Offset          | 0x0000 0058                                                                                                                                             | Physical Address      | 0x4830 6E58     | Instance           | DSS_PRM        |  |  |
| Description             | This register logs the different reset sources of the DSS domain. Each bit is set upon release of the domain reset signal. Must be cleared by software. |                       |                 |                    |                |  |  |
| Type                    | RW                                                                                                                                                      |                       |                 |                    |                |  |  |
| 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 | COREDOMAINWKUP_RST | DOMAINWKUP_RST |  |  |
|                         |                                                                                                                                                         |                       |                 | GLOBALWARM_RST     | GLOBALCOLD_RST |  |  |
| RESERVED                |                                                                                                                                                         |                       |                 |                    |                |  |  |

| Bits | Field Name         | Description                                                                                                                                                                                                                                                     | Type | Reset     |
|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:4 | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                              | R    | 0x0000000 |
| 3    | COREDOMAINWKUP_RST | CORE domain wake-up reset<br><br>Read 0x0: No power domain wake-up reset.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: DSS domain has been reset following a CORE power domain wake-up from OFF to ON.<br><br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0       |
| 2    | DOMAINWKUP_RST     | Power domain wake-up reset<br><br>Read 0x0: Status bit unchanged<br><br>Write 0x0: No power domain wake-up reset.<br><br>Read 0x1: DSS domain has been reset following a DSS power domain wake-up.<br><br>Write 0x1: Status bit is cleared to 0.                | RW   | 0x0       |
| 1    | GLOBALWARM_RST     | Global warm reset<br><br>Read 0x0: No global warm reset.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: DISPLAY domain has been reset upon a global warm reset<br><br>Write 0x1: Status bit is cleared to 0.                                           | RW   | 0x0       |

| Bits | Field Name     | Description                                                                                                                                                                                               | Type | Reset |
|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | GLOBALCOLD_RST | Global cold reset<br><br>Read 0x0: No global cold reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: DISPLAY domain has been reset upon a global cold reset<br>Write 0x1: Status bit is cleared to 0. | RW   | 0x1   |

**Table 3-389. Register Call Summary for Register RM\_RSTST\_DSS**

PRCM Basic Programming Model

- [Reset Control: \[0\]](#)

PRCM Register Manual

- [DSS\\_PRM Registers: \[1\]](#)

**Table 3-390. PM\_WKEN\_DSS**

|                         |                                                                 |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
|-------------------------|-----------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--------|
| <b>Address Offset</b>   | 0x0000 00A0                                                     |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| <b>Physical Address</b> | 0x4830 6EA0                                                     |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| <b>Description</b>      | This register allows enabling/disabling modules wake-up events. |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| <b>Type</b>             | RW                                                              |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |        |
| RESERVED                |                                                                 |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | EN_DSS |

| Bits | Field Name | Description                                                                                 | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                          | R    | 0x00000000 |
| 0    | EN_DSS     | DSS Wake-up enable<br><br>0x0: DSS wake-up is disabled<br>0x1: DSS wake-up event is enabled | RW   | 0x1        |

**Table 3-391. Register Call Summary for Register PM\_WKEN\_DSS**

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[0\]](#)

PRCM Register Manual

- [DSS\\_PRM Registers: \[1\]](#)

**Table 3-392. PM\_WKDEP\_DSS**

|                         |                                                                                                          |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |                                                     |
|-------------------------|----------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|-----------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 00C8                                                                                              |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |                                                     |
| <b>Physical Address</b> | 0x4830 6EC8                                                                                              |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |                                                     |
| <b>Description</b>      | This register allows enabling or disabling the wake-up of the DISPLAY domain upon another domain wakeup. |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |                                                     |
| <b>Type</b>             | RW                                                                                                       |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |                                                     |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |                                                     |
| RESERVED                |                                                                                                          |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | EN_WKUP<br>RESERVED<br>EN_IVA2<br>EN_MP<br>RESERVED |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                              | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:5        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                              | R           | 0x0000000    |
| 4           | EN_WKUP           | WAKEUP domain dependency<br><br>0x0: DSS domain is independent of WKUP domain wake-up event.<br><br>0x1: DSS domain is woken-up upon WKUP domain wake-up event. | RW          | 0x1          |
| 3           | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                              | R           | 0x0          |
| 2           | EN_IVA2           | IVA2 domain dependency<br><br>0x0: DSS domain is independent of IVA2 domain wake-up event.<br><br>0x1: DSS domain is woken-up upon IVA2 domain wake-up event.   | RW          | 0x1          |
| 1           | EN_MPUMPU         | MPU domain dependency<br><br>0x0: DSS domain is independent of MPU domain wake-up.<br><br>0x1: DSS domain is woken-up upon MPU domain wake-up.                  | RW          | 0x1          |
| 0           | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                              | R           | 0x0          |

**Table 3-393. Register Call Summary for Register PM\_WKDEP\_DSS**

PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#) [\[1\]](#) [\[2\]](#)

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[3\]](#)

PRCM Register Manual

- [DSS\\_PRM Registers: \[4\]](#)

**Table 3-394. PM\_PWSTCTRL\_DSS**

|                         |                                                                   |    |    |    |    |    |    |    |    |            |                 |    |    |    |             |          |    |    |    |               |            |   |   |   |   |   |   |   |   |   |   |
|-------------------------|-------------------------------------------------------------------|----|----|----|----|----|----|----|----|------------|-----------------|----|----|----|-------------|----------|----|----|----|---------------|------------|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 00E0                                                       |    |    |    |    |    |    |    |    |            |                 |    |    |    |             |          |    |    |    |               |            |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | <a href="#">0x4830 6EE0</a>                                       |    |    |    |    |    |    |    |    |            | <b>Instance</b> |    |    |    | DSS_PRM     |          |    |    |    |               |            |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | This register controls the DISPLAY domain power state transition. |    |    |    |    |    |    |    |    |            |                 |    |    |    |             |          |    |    |    |               |            |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                                |    |    |    |    |    |    |    |    |            |                 |    |    |    |             |          |    |    |    |               |            |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                                   |    |    |    |    |    |    |    |    | MEMONSTATE | RESERVED        |    |    |    | MEMRETSTATE | RESERVED |    |    |    | LOGICRETSTATE | POWERSTATE |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:18       | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                   | R           | 0x0000       |
| 17:16       | MEMONSTATE        | Memory state when ON<br><br>0x3: Memory is always ON when domain is ON.                              | R           | 0x3          |
| 15:9        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                   | R           | 0x00         |
| 8           | MEMRETSTATE       | Memory state when RETENTION<br><br>0x1: Memory is always retained when domain is in RETENTION state. | R           | 0x1          |
| 7:3         | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                   | R           | 0x00         |

| Bits | Field Name    | Description                                                                                     | Type | Reset |
|------|---------------|-------------------------------------------------------------------------------------------------|------|-------|
| 2    | LOGICRETSTATE | Logic state when RETENTION<br>0x1: Logic is always retained when domain is in RETENTION state.  | R    | 0x1   |
| 1:0  | POWERSTATE    | Power state control<br>0x0: OFF state<br>0x1: RETENTION state<br>0x2: Reserved<br>0x3: ON state | RW   | 0x3   |

**Table 3-395. Register Call Summary for Register PM\_PWSTCTRL\_DSS**

PRCM Basic Programming Model

- [PM\\_PWSTCTRL\\_domain\\_name \(Power State Control Register\): \[0\]](#)

PRCM Register Manual

- [DSS\\_PRM Registers: \[1\]](#)

**Table 3-396. PM\_PWSTST\_DSS**

|                  |                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|----------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 00E4                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | 0x4830 6EE4                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | This register provides a status on the power state transition of the DSS domain. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | R                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



| Bits  | Field Name     | Description                                                                                                                                             | Type | Reset   |
|-------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:21 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                      | R    | 0x000   |
| 20    | INTRANSITION   | Domain transition status<br>0x0: No transition<br>0x1: DISPLAY power domain transition is in progress.                                                  | R    | 0x0     |
| 19:2  | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                      | R    | 0x00000 |
| 1:0   | POWERSTATETEST | Current power state status<br>0x0: Power domain is OFF<br>0x1: Power domain is in RETENTION<br>0x2: Power domain is INACTIVE<br>0x3: Power domain is ON | R    | 0x3     |

**Table 3-397. Register Call Summary for Register PM\_PWSTST\_DSS**

PRCM Basic Programming Model

- [PM\\_PWSTST\\_domain\\_name \(Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [DSS\\_PRM Registers: \[1\]](#)

**Table 3-398. PM\_PREPWSTST\_DSS**

|                         |                                                                                                                                          |                         |                 |                 |                       |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-----------------------|
| <b>Address Offset</b>   | 0x0000 00E8                                                                                                                              | <b>Physical Address</b> | 0x4830 6EE8     | <b>Instance</b> | DSS_PRM               |
| <b>Description</b>      | This register provides a status on the DSS domain previous power state. It indicates the state entered during the last sleep transition. |                         |                 |                 |                       |
| <b>Type</b>             | RW                                                                                                                                       |                         |                 |                 |                       |
| 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 |                 |                       |
| RESERVED                |                                                                                                                                          |                         |                 |                 | LASTPOWERSTATEENTERED |

| Bits | Field Name            | Description                                                                                                                                                                                       | Type | Reset      |
|------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                | R    | 0x00000000 |
| 1:0  | LASTPOWERSTATEENTERED | Last power state entered<br><br>0x0: DSS domain was previously OFF<br>0x1: DSS domain was previously in RETENTION<br>0x2: DSS domain was previously INACTIVE<br>0x3: DSS domain was previously ON | RW   | 0x0        |

**Table 3-399. Register Call Summary for Register PM\_PREPWSTST\_DSS**

PRCM Basic Programming Model

- [PM\\_PREPWSTST\\_domain\\_name \(Previous Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [DSS\\_PRM Registers: \[1\]](#)

### 3.7.2.10 CAM\_PRM Registers

#### 3.7.2.10.1 CAM\_PRM Registers

**Table 3-400. CAM\_PRM Register Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|------------------|------|-----------------------|----------------|------------------|------------|
| RM_RSTST_CAM     | RW   | 32                    | 0x0000 0058    | 0x4830 6F58      | C          |
| PM_WKDEP_CAM     | RW   | 32                    | 0x0000 00C8    | 0x4830 6FC8      | W          |
| PM_PWSTCTRL_CAM  | RW   | 32                    | 0x0000 00E0    | 0x4830 6FE0      | W          |
| PM_PWSTST_CAM    | R    | 32                    | 0x0000 00E4    | 0x4830 6FE4      | C          |
| PM_PREPWSTST_CAM | RW   | 32                    | 0x0000 00E8    | 0x4830 6FE8      | C          |

#### 3.7.2.10.2 CAM\_PRM Registers

**Table 3-401. RM\_RSTST\_CAM**

| Bits | Field Name         | Description                                                                                                                                                                                                                                                            | Type | Reset      |
|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:4 | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                     | R    | 0x00000000 |
| 3    | COREDOMAINWKUP_RST | <p>CORE domain wake-up reset</p> <p>Read 0x0: No power domain wake-up reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: CAM domain has been reset following a CORE power domain wake-up from OFF to ON.</p> <p>Write 0x1: Status bit is cleared to 0.</p> | RW   | 0x0        |
| 2    | DOMAINWKUP_RST     | <p>Power domain wake-up reset</p> <p>Read 0x0: No power domain wake-up reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: CAM domain has been reset following a CAMERA power domain wake-up.</p> <p>Write 0x1: Status bit is cleared to 0.</p>             | RW   | 0x0        |
| 1    | GLOBALWARM_RST     | <p>Global warm reset</p> <p>Read 0x0: No global warm reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: CAM domain has been reset upon a global warm reset</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                               | RW   | 0x0        |
| 0    | GLOBALCOLD_RST     | <p>Global cold reset</p> <p>Read 0x0: No global cold reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: CAM domain has been reset upon a global cold reset</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                               | RW   | 0x1        |

**Table 3-402. Register Call Summary for Register RM\_RSTST\_CAM**

- PRCM Basic Programming Model

- Reset Control: [0]

- PRCM Register Manual

- CAM\_PRM Registers: [1]

**Table 3-403. PM\_WKDEP\_CAM**

| Bits | Field Name | Description                                                                                                                                             | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:5 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                      | R    | 0x00000000 |
| 4    | EN_WKUP    | WAKEUP domain dependency<br>0x0: CAM domain is independent of WKUP domain wake-up event.<br>0x1: CAM domain is woken-up upon WKUP domain wake-up event. | RW   | 0x1        |
| 3    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                      | R    | 0x0        |
| 2    | EN_IVA2    | IVA2 domain dependency<br>0x0: CAM domain is independent of IVA2 domain wake-up event.<br>0x1: CAM domain is woken-up upon IVA2 domain wake-up event.   | RW   | 0x1        |
| 1    | EN_MPUMPU  | MPU domain dependency<br>0x0: CAM domain is independent of MPU domain wake-up.<br>0x1: CAM domain is woken-up upon MPU domain wake-up.                  | RW   | 0x1        |
| 0    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                      | R    | 0x0        |

**Table 3-404. Register Call Summary for Register PM\_WKDEP\_CAM**

- [Device Wake-Up Events: \[0\] \[1\] \[2\]](#)
  - [Domain Wake-Up Control Registers: \[3\]](#)

---

[PRCM Register Manual](#)

  - [CAM\\_PRM Registers: \[4\]](#)

**Table 3-405. PM\_PWSTCTRL\_CAM**

|                         |                                                                |                 |         |
|-------------------------|----------------------------------------------------------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 00E0                                                    |                 |         |
| <b>Physical Address</b> | 0x4830 6FE0                                                    | <b>Instance</b> | CAM_PRM |
| <b>Description</b>      | This register controls the CORE domain power state transition. |                 |         |
| <b>Type</b>             | RW                                                             |                 |         |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name    | Description                                                                                      | Type | Reset  |
|-------|---------------|--------------------------------------------------------------------------------------------------|------|--------|
| 31:18 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                               | R    | 0x0000 |
| 17:16 | MEMONSTATE    | Memory state when ON<br>0x3: Memory is always ON when domain is ON.                              | R    | 0x3    |
| 15:9  | RESERVED      | Write 0s for future compatibility. Read returns 0.                                               | R    | 0x00   |
| 8     | MEMRETSTATE   | Memory state when RETENTION<br>0x1: Memory is always retained when domain is in RETENTION state. | R    | 0x1    |
| 7:3   | RESERVED      | Write 0s for future compatibility. Read returns 0.                                               | R    | 0x00   |
| 2     | LOGICRETSTATE | Logic state when RETENTION<br>0x1: Logic is always retained when domain is in RETENTION state.   | R    | 0x1    |
| 1:0   | POWERSTATE    | Power state control<br>0x0: OFF state<br>0x1: RETENTION state<br>0x2: Reserved<br>0x3: ON state  | RW   | 0x3    |

**Table 3-406. Register Call Summary for Register PM\_PWSTCTRL\_CAM**

PRCM Basic Programming Model

- [PM\\_PWSTCTRL\\_domain\\_name \(Power State Control Register\): \[0\]](#)

PRCM Register Manual

- [CAM\\_PRM Registers: \[1\]](#)

**Table 3-407. PM\_PWSTST\_CAM**

|                  |                                                                                     |          |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------|----------|--|--|--|--|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 00E4                                                                         |          |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | 0x4830 6FE4                                                                         | Instance |  |  |  |  |  |  |  |  |  |  |  | CAM_PRM |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | This register provides a status on the power state transition of the CAMERA domain. |          |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | R                                                                                   |          |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name   | Description                                                                                           | Type | Reset |
|-------|--------------|-------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                    | R    | 0x000 |
| 20    | INTRANSITION | Domain transition status<br>0x0: No transition<br>0x1: CAMERA power domain transition is in progress. | R    | 0x0   |

| Bits | Field Name   | Description                                                                                                                                                 | Type | Reset    |
|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 19:2 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                          | R    | 0x000000 |
| 1:0  | POWERSTATEST | Current power state status<br><br>0x0: Power domain is OFF<br>0x1: Power domain is in RETENTION<br>0x2: Power domain is INACTIVE<br>0x3: Power domain is ON | R    | 0x3      |

**Table 3-408. Register Call Summary for Register PM\_PWSTST\_CAM**

PRCM Basic Programming Model

- [PM\\_PWSTST\\_domain\\_name \(Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [CAM\\_PRM Registers: \[1\]](#)

**Table 3-409. PM\_PREPWSTST\_CAM**

|                       |                                                                                                                                          |  |                         |             |                 |         |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 00E8                                                                                                                              |  | <b>Physical Address</b> | 0x4830 6FE8 | <b>Instance</b> | CAM_PRM |
| <b>Description</b>    | This register provides a status on the CAM domain previous power state. It indicates the state entered during the last sleep transition. |  | <b>Type</b>             | RW          |                 |         |
|                       |                                                                                                                                          |  |                         |             |                 |         |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |                       |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----------------------|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | LASTPOWERSTATEENTERED |   |   |   |

| Bits | Field Name            | Description                                                                                                                                                                                       | Type | Reset      |
|------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                | R    | 0x00000000 |
| 1:0  | LASTPOWERSTATEENTERED | Last power state entered<br><br>0x0: CAM domain was previously OFF<br>0x1: CAM domain was previously in RETENTION<br>0x2: CAM domain was previously INACTIVE<br>0x3: CAM domain was previously ON | RW   | 0x0        |

**Table 3-410. Register Call Summary for Register PM\_PREPWSTST\_CAM**

PRCM Basic Programming Model

- [PM\\_PREPWSTST\\_domain\\_name \(Previous Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [CAM\\_PRM Registers: \[1\]](#)

### 3.7.2.11 PER\_PRM Registers

#### 3.7.2.11.1 PER\_PRM Register Summary

**Table 3-411. PER\_PRM Register Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|-------------------|------|-----------------------|----------------|------------------|------------|
| RM_RSTST_PER      | RW   | 32                    | 0x0000 0058    | 0x4830 7058      | C          |
| PM_WKEN_PER       | RW   | 32                    | 0x0000 00A0    | 0x4830 70A0      | W          |
| PM_MPUGRPSEL_PER  | RW   | 32                    | 0x0000 00A4    | 0x4830 70A4      | W          |
| PM_IVA2GRPSEL_PER | RW   | 32                    | 0x0000 00A8    | 0x4830 70A8      | W          |
| PM_WKST_PER       | RW   | 32                    | 0x0000 00B0    | 0x4830 70B0      | C          |
| PM_WKDEP_PER      | RW   | 32                    | 0x0000 00C8    | 0x4830 70C8      | W          |
| PM_PWSTCTRL_PER   | RW   | 32                    | 0x0000 00E0    | 0x4830 70E0      | W          |
| PM_PWSTST_PER     | R    | 32                    | 0x0000 00E4    | 0x4830 70E4      | C          |
| PM_PREPWSTST_PER  | RW   | 32                    | 0x0000 00E8    | 0x4830 70E8      | C          |

**3.7.2.11.2 PER\_PRM Registers****Table 3-412. RM\_RSTST\_PER**

|                         |                                                                                                                                                                |                       |                 |                    |                |                |                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--------------------|----------------|----------------|----------------|
| Address Offset          | 0x0000 0058                                                                                                                                                    | Physical Address      | 0x4830 7058     | Instance           | PER_PRM        |                |                |
| Description             | This register logs the different reset sources of the PERIPHERAL domain. Each bit is set upon release of the domain reset signal. Must be cleared by software. |                       |                 |                    |                |                |                |
| Type                    | RW                                                                                                                                                             |                       |                 |                    |                |                |                |
| 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 |                    |                |                |                |
|                         |                                                                                                                                                                |                       |                 | COREDOMAINWKUP_RST | DOMAINWKUP_RST | GLOBALWARM_RST | GLOBALCOLD_RST |
| RESERVED                |                                                                                                                                                                |                       |                 |                    |                |                |                |

| Bits | Field Name         | Description                                                                                                                                                                                                                                                 | Type | Reset      |
|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:4 | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                          | R    | 0x00000000 |
| 3    | COREDOMAINWKUP_RST | CORE domain wake-up reset<br><br>Read 0x0: No power domain wake-up reset.<br>Write 0x0: Status bit unchanged<br><br>Read 0x1: PER domain has been reset following a CORE power domain wake-up from OFF to ON.<br><br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0        |
| 2    | DOMAINWKUP_RST     | Power domain wake-up reset<br><br>Read 0x0: No power domain wake-up reset.<br>Write 0x0: Status bit unchanged<br><br>Read 0x1: PER domain has been reset following a PERIPHERAL power domain wake-up.<br><br>Write 0x1: Status bit is cleared to 0.         | RW   | 0x0        |

| Bits | Field Name     | Description                                                                                                                                                                                       | Type | Reset |
|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | GLOBALWARM_RST | Global warm reset<br>Read 0x0: No global warm reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: PER domain has been reset upon a global warm reset<br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0   |
| 0    | GLOBALCOLD_RST | Global cold reset<br>Read 0x0: No global cold reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: PER domain has been reset upon a global cold reset<br>Write 0x1: Status bit is cleared to 0. | RW   | 0x1   |

**Table 3-413. Register Call Summary for Register RM\_RSTST\_PER**

PRCM Basic Programming Model

- [Reset Control: \[0\]](#)

PRCM Register Manual

- [PER\\_PRM Registers: \[1\]](#)

**Table 3-414. PM\_WKEN\_PER**

|                  |                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|-----------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 00A0                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | <a href="#">0x4830 70A0</a>                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | This register allows enabling/disabling modules wake-up events. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | RW                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

  

|          |    |    |    |    |    |    |    |          |          |          |          |          |          |          |          |         |         |         |         |         |         |         |         |           |           |           |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----------|----------|----------|----------|----------|----------|----------|----------|---------|---------|---------|---------|---------|---------|---------|---------|-----------|-----------|-----------|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    | EN_UART4 | EN_GPIO6 | EN_GPIO5 | EN_GPIO4 | EN_GPIO3 | EN_GPIO2 | RESERVED | EN_UART3 | EN_GPT9 | EN_GPT8 | EN_GPT7 | EN_GPT6 | EN_GPT5 | EN_GPT4 | EN_GPT3 | EN_GPT2 | EN_MCBSP4 | EN_MCBSP3 | EN_MCBSP2 |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                       | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------|------|--------|
| 31:19 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                | R    | 0x0000 |
| 18    | EN_UART4   | UART 4 wake-up control<br>0x0: UART 4 wake-up is disabled<br>0x1: UART 4 wake-up event is enabled | RW   | 0x1    |
| 17    | EN_GPIO6   | GPIO 6 wake-up control<br>0x0: GPIO 6 wake-up is disabled<br>0x1: GPIO 6 wake-up event is enabled | RW   | 0x1    |
| 16    | EN_GPIO5   | GPIO 5 wake-up control<br>0x0: GPIO 5 wake-up is disabled<br>0x1: GPIO 5 wake-up event is enabled | RW   | 0x1    |
| 15    | EN_GPIO4   | GPIO 4 wake-up control<br>0x0: GPIO 4 wake-up is disabled<br>0x1: GPIO 4 wake-up event is enabled | RW   | 0x1    |
| 14    | EN_GPIO3   | GPIO 3 wake-up control<br>0x0: GPIO 3 wake-up is disabled<br>0x1: GPIO 3 wake-up event is enabled | RW   | 0x1    |

| Bits | Field Name | Description                                                                                                | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------|------|-------|
| 13   | EN_GPIO2   | GPIO 2 wake-up control<br>0x0: GPIO 2 wake-up is disabled<br>0x1: GPIO 2 wake-up event is enabled          | RW   | 0x1   |
| 12   | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                         | R    | 0x0   |
| 11   | EN_UART3   | UART 3 wake-up control<br>0x0: UART 3 wake-up is disabled<br>0x1: UART 3 wake-up event is enabled          | RW   | 0x1   |
| 10   | EN_GPT9    | GPTIMER 9 wake-up control<br>0x0: GPTIMER 9 wake-up is disabled<br>0x1: GPTIMER 9 wake-up event is enabled | RW   | 0x1   |
| 9    | EN_GPT8    | GPTIMER 8 wake-up control<br>0x0: GPTIMER 8 wake-up is disabled<br>0x1: GPTIMER 8 wake-up event is enabled | RW   | 0x1   |
| 8    | EN_GPT7    | GPTIMER 7 wake-up control<br>0x0: GPTIMER 7 wake-up is disabled<br>0x1: GPTIMER 7 wake-up event is enabled | RW   | 0x1   |
| 7    | EN_GPT6    | GPTIMER 6 wake-up control<br>0x0: GPTIMER 6 wake-up is disabled<br>0x1: GPTIMER 6 wake-up event is enabled | RW   | 0x1   |
| 6    | EN_GPT5    | GPTIMER 5 wake-up control<br>0x0: GPTIMER 5 wake-up is disabled<br>0x1: GPTIMER 5 wake-up event is enabled | RW   | 0x1   |
| 5    | EN_GPT4    | GPTIMER 4 wake-up control<br>0x0: GPTIMER 4 wake-up is disabled<br>0x1: GPTIMER 4 wake-up event is enabled | RW   | 0x1   |
| 4    | EN_GPT3    | GPTIMER 3 wake-up control<br>0x0: GPTIMER 3 wake-up is disabled<br>0x1: GPTIMER 3 wake-up event is enabled | RW   | 0x1   |
| 3    | EN_GPT2    | GPTIMER 2 wake-up control<br>0x0: GPTIMER 2 wake-up is disabled<br>0x1: GPTIMER 2 wake-up event is enabled | RW   | 0x1   |
| 2    | EN_MCBSP4  | McBSP 4 wake-up control<br>0x0: McBSP 4 wake-up is disabled<br>0x1: McBSP 4 wake-up event is enabled       | RW   | 0x1   |
| 1    | EN_MCBSP3  | McBSP3 wake-up control<br>0x0: McBSP 3 wake-up is disabled<br>0x1: McBSP 3 wake-up event is enabled        | RW   | 0x1   |
| 0    | EN_MCBSP2  | McBSP 2 wake-up control<br>0x0: McBSP 2 wake-up is disabled<br>0x1: McBSP 2 wake-up event is enabled       | RW   | 0x1   |

**Table 3-415. Register Call Summary for Register PM\_WKEN\_PER**

## PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#)

## PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[1\]](#)

## PRCM Register Manual

- [PER\\_PRM Registers: \[2\]](#)

**Table 3-416. PM\_MPUGRPSEL\_PER**

| <b>Address Offset</b>   | 0x0000 00A4                                                               |                                                                                                                                                                               |                 |  |  |  |  |               |               |               |              |              |              |             |              |        |
|-------------------------|---------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|---------------|---------------|---------------|--------------|--------------|--------------|-------------|--------------|--------|
| <b>Physical Address</b> | 0x4830 70A4                                                               |                                                                                                                                                                               |                 |  |  |  |  |               |               |               |              |              |              |             |              |        |
| <b>Description</b>      | This register allows selecting the group of modules that wake-up the MPU. |                                                                                                                                                                               |                 |  |  |  |  |               |               |               |              |              |              |             |              |        |
| <b>Type</b>             | RW                                                                        |                                                                                                                                                                               |                 |  |  |  |  |               |               |               |              |              |              |             |              |        |
| 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 |  |  |  |  |               |               |               |              |              |              |             |              |        |
| RESERVED                |                                                                           |                                                                                                                                                                               |                 |  |  |  |  | GRPSEL_UART4  | GRPSEL_GPIO6  | GRPSEL_GPIO5  | GRPSEL_GPIO4 | GRPSEL_GPIO3 | GRPSEL_GPIO2 | RESERVED    | GRPSEL_UART3 |        |
| RESERVED                |                                                                           |                                                                                                                                                                               |                 |  |  |  |  | GRPSEL_GPT9   | GRPSEL_GPT8   | GRPSEL_GPT7   | GRPSEL_GPT6  | GRPSEL_GPT5  | GRPSEL_GPT4  | GRPSEL_GPT3 | GRPSEL_GPT2  |        |
| RESERVED                |                                                                           |                                                                                                                                                                               |                 |  |  |  |  | GRPSEL_MCBSP4 | GRPSEL_MCBSP3 | GRPSEL_MCBSP2 |              |              |              |             |              |        |
| Bits                    | Field Name                                                                | <b>Description</b>                                                                                                                                                            |                 |  |  |  |  |               |               |               |              |              |              |             | Type         | Reset  |
| 31:19                   | RESERVED                                                                  | Write 0s for future compatibility. Read returns 0.                                                                                                                            |                 |  |  |  |  |               |               |               |              |              |              |             | R            | 0x0000 |
| 18                      | GRPSEL_UART4                                                              | Select the UART 4 in the MPU wake-up events group<br>0x0: UART 4 is not attached to the MPU wake-up events group.<br>0x1: UART 4 is attached to the MPU wake-up events group. |                 |  |  |  |  |               |               |               |              |              |              |             | RW           | 0x1    |
| 17                      | GRPSEL_GPIO6                                                              | Select the GPIO 6 in the MPU wake-up events group<br>0x0: GPIO 6 is not attached to the MPU wake-up events group.<br>0x1: GPIO 6 is attached to the MPU wake-up events group. |                 |  |  |  |  |               |               |               |              |              |              |             | RW           | 0x1    |
| 16                      | GRPSEL_GPIO5                                                              | Select the GPIO 5 in the MPU wake-up events group<br>0x0: GPIO 5 is not attached to the MPU wake-up events group.<br>0x1: GPIO 5 is attached to the MPU wake-up events group. |                 |  |  |  |  |               |               |               |              |              |              |             | RW           | 0x1    |
| 15                      | GRPSEL_GPIO4                                                              | Select the GPIO 4 in the MPU wake-up events group<br>0x0: GPIO 4 is not attached to the MPU wake-up events group.<br>0x1: GPIO 4 is attached to the MPU wake-up events group. |                 |  |  |  |  |               |               |               |              |              |              |             | RW           | 0x1    |
| 14                      | GRPSEL_GPIO3                                                              | Select the GPIO 3 in the MPU wake-up events group<br>0x0: GPIO 3 is not attached to the MPU wake-up events group.<br>0x1: GPIO 3 is attached to the MPU wake-up events group. |                 |  |  |  |  |               |               |               |              |              |              |             | RW           | 0x1    |
| 13                      | GRPSEL_GPIO2                                                              | Select the GPIO 2 in the MPU wake-up events group<br>0x0: GPIO 2 is not attached to the MPU wake-up events group.<br>0x1: GPIO 2 is attached to the MPU wake-up events group. |                 |  |  |  |  |               |               |               |              |              |              |             | RW           | 0x1    |
| 12                      | RESERVED                                                                  | Write 0s for future compatibility. Read returns 0.                                                                                                                            |                 |  |  |  |  |               |               |               |              |              |              |             | R            | 0x0    |
| 11                      | GRPSEL_UART3                                                              | Select the UART 3 in the MPU wake-up events group<br>0x0: UART 3 is not attached to the MPU wake-up events group.<br>0x1: UART 3 is attached to the MPU wake-up events group. |                 |  |  |  |  |               |               |               |              |              |              |             | RW           | 0x1    |

| Bits | Field Name    | Description                                                                                                                                                                                    | Type | Reset |
|------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 10   | GRPSEL_GPT9   | Select the GPTIMER 9 in the MPU wake-up events group<br><br>0x0: GPTIMER 9 is not attached to the MPU wake-up events group.<br><br>0x1: GPTIMER 9 is attached to the MPU wake-up events group. | RW   | 0x1   |
| 9    | GRPSEL_GPT8   | Select the GPTIMER 8 in the MPU wake-up events group<br><br>0x0: GPTIMER 8 is not attached to the MPU wake-up events group.<br><br>0x1: GPTIMER 8 is attached to the MPU wake-up events group. | RW   | 0x1   |
| 8    | GRPSEL_GPT7   | Select the GPTIMER 7 in the MPU wake-up events group<br><br>0x0: GPTIMER 7 is not attached to the MPU wake-up events group.<br><br>0x1: GPTIMER 7 is attached to the MPU wake-up events group. | RW   | 0x1   |
| 7    | GRPSEL_GPT6   | Select the GPTIMER 6 in the MPU wake-up events group<br><br>0x0: GPTIMER 6 is not attached to the MPU wake-up events group.<br><br>0x1: GPTIMER 6 is attached to the MPU wake-up events group. | RW   | 0x1   |
| 6    | GRPSEL_GPT5   | Select the GPTIMER 5 in the MPU wake-up events group<br><br>0x0: GPTIMER 5 is not attached to the MPU wake-up events group.<br><br>0x1: GPTIMER 5 is attached to the MPU wake-up events group. | RW   | 0x1   |
| 5    | GRPSEL_GPT4   | Select the GPTIMER 4 in the MPU wake-up events group<br><br>0x0: GPTIMER 4 is not attached to the MPU wake-up events group.<br><br>0x1: GPTIMER 4 is attached to the MPU wake-up events group. | RW   | 0x1   |
| 4    | GRPSEL_GPT3   | Select the GPTIMER 3 in the MPU wake-up events group<br><br>0x0: GPTIMER 3 is not attached to the MPU wake-up events group.<br><br>0x1: GPTIMER 3 is attached to the MPU wake-up events group. | RW   | 0x1   |
| 3    | GRPSEL_GPT2   | Select the GPTIMER 2 in the MPU wake-up events group<br><br>0x0: GPTIMER 2 is not attached to the MPU wake-up events group.<br><br>0x1: GPTIMER 2 is attached to the MPU wake-up events group. | RW   | 0x1   |
| 2    | GRPSEL_MCBSP4 | Select the McBSP 4 in the MPU wake-up events group<br><br>0x0: McBSP 4 is not attached to the MPU wake-up events group.<br><br>0x1: McBSP 4 is attached to the MPU wake-up events group.       | RW   | 0x1   |
| 1    | GRPSEL_MCBSP3 | Select the McBSP 3 in the MPU wake-up events group<br><br>0x0: McBSP 3 is not attached to the MPU wake-up events group.<br><br>0x1: McBSP 3 is attached to the MPU wake-up events group.       | RW   | 0x1   |
| 0    | GRPSEL_MCBSP2 | Select the McBSP 2 in the MPU wake-up events group<br><br>0x0: McBSP 2 is not attached to the MPU wake-up events group.<br><br>0x1: McBSP 2 is attached to the MPU wake-up events group.       | RW   | 0x1   |

**Table 3-417. Register Call Summary for Register PM\_MPUGRPSEL\_PER**
**PRCM Functional Description**

- [Device Wake-Up Events: \[0\]](#)
- [Sleep and Wake-Up Dependencies: \[1\]](#)

**PRCM Basic Programming Model**

- [Domain Wake-Up Control Registers: \[2\]](#)

**PRCM Register Manual**

- [PER\\_PRM Registers: \[3\]](#)

**Table 3-418. PM\_IVA2GRPSEL\_PER**

|                       |                                                                            |                         |             |                 |         |
|-----------------------|----------------------------------------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 00A8                                                                | <b>Physical Address</b> | 0x4830 70A8 | <b>Instance</b> | PER_PRM |
| <b>Description</b>    | This register allows selecting the group of modules that wake-up the IVA2. |                         |             |                 |         |
| <b>Type</b>           | RW                                                                         |                         |             |                 |         |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name   | Description                                                                                                                                                                              | Type | Reset  |
|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:19 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                       | R    | 0x0000 |
| 18    | GRPSEL_UART4 | Select the UART 4 in the IVA2 wake-up events group<br><br>0x0: UART 4 is not attached to the IVA2 wake-up events group.<br><br>0x1: UART 4 is attached to the IVA2 wake-up events group. | RW   | 0x1    |
| 17    | GRPSEL_GPIO6 | Select the GPIO 6 in the IVA2 wake-up events group<br><br>0x0: GPIO 6 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPIO 6 is attached to the IVA2 wake-up events group. | RW   | 0x1    |
| 16    | GRPSEL_GPIO5 | Select the GPIO 5 in the IVA2 wake-up events group<br><br>0x0: GPIO 5 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPIO 5 is attached to the IVA2 wake-up events group. | RW   | 0x1    |
| 15    | GRPSEL_GPIO4 | Select the GPIO 4 in the IVA2 wake-up events group<br><br>0x0: GPIO 4 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPIO 4 is attached to the IVA2 wake-up events group. | RW   | 0x1    |
| 14    | GRPSEL_GPIO3 | Select the GPIO 3 in the IVA2 wake-up events group<br><br>0x0: GPIO 3 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPIO 3 is attached to the IVA2 wake-up events group. | RW   | 0x1    |

| Bits | Field Name    | Description                                                                                                                                                                                       | Type | Reset |
|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 13   | GRPSEL_GPIO2  | Select the GPIO 2 in the IVA2 wake-up events group<br><br>0x0: GPIO 2 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPIO 2 is attached to the IVA2 wake-up events group.          | RW   | 0x1   |
| 12   | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                | R    | 0x0   |
| 11   | GRPSEL_UART3  | Select the UART 3 in the IVA2 wake-up events group<br><br>0x0: UART 3 is not attached to the IVA2 wake-up events group.<br><br>0x1: UART 3 is attached to the IVA2 wake-up events group.          | RW   | 0x1   |
| 10   | GRPSEL_GPT9   | Select the GPTIMER 9 in the IVA2 wake-up events group<br><br>0x0: GPTIMER 9 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPTIMER 9 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 9    | GRPSEL_GPT8   | Select the GPTIMER 8 in the IVA2 wake-up events group<br><br>0x0: GPTIMER 8 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPTIMER 8 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 8    | GRPSEL_GPT7   | Select the GPTIMER 7 in the IVA2 wake-up events group<br><br>0x0: GPTIMER 7 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPTIMER 7 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 7    | GRPSEL_GPT6   | Select the GPTIMER 6 in the IVA2 wake-up events group<br><br>0x0: GPTIMER 6 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPTIMER 6 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 6    | GRPSEL_GPT5   | Select the GPTIMER 5 in the IVA2 wake-up events group<br><br>0x0: GPTIMER 5 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPTIMER 5 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 5    | GRPSEL_GPT4   | Select the GPTIMER 4 in the IVA2 wake-up events group<br><br>0x0: GPTIMER 4 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPTIMER 4 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 4    | GRPSEL_GPT3   | Select the GPTIMER 3 in the IVA2 wake-up events group<br><br>0x0: GPTIMER 3 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPTIMER 3 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 3    | GRPSEL_GPT2   | Select the GPTIMER 2 in the IVA2 wake-up events group<br><br>0x0: GPTIMER 2 is not attached to the IVA2 wake-up events group.<br><br>0x1: GPTIMER 2 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 2    | GRPSEL_MCBSP4 | Select the McBSP 4 in the IVA2 wake-up events group<br><br>0x0: McBSP 4 is not attached to the IVA2 wake-up events group.<br><br>0x1: McBSP 4 is attached to the IVA2 wake-up events group.       | RW   | 0x1   |

| Bits | Field Name    | Description                                                                                                                                                                                 | Type | Reset |
|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | GRPSEL_MCBSP3 | Select the McBSP 3 in the IVA2 wake-up events group<br><br>0x0: McBSP 3 is not attached to the IVA2 wake-up events group.<br><br>0x1: McBSP 3 is attached to the IVA2 wake-up events group. | RW   | 0x1   |
| 0    | GRPSEL_MCBSP2 | Select the McBSP 2 in the IVA2 wake-up events group<br><br>0x0: McBSP 2 is not attached to the IVA2 wake-up events group.<br><br>0x1: McBSP 2 is attached to the IVA2 wake-up events group. | RW   | 0x1   |

**Table 3-419. Register Call Summary for Register PM\_IVA2GRPSEL\_PER**

PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#)

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[1\]](#)

PRCM Register Manual

- [PER\\_PRM Registers: \[2\]](#)

**Table 3-420. PM\_WKST\_PER**

|                         |                                                                                                                                     |                                                                                  |                       |                                                                                                                                         |                 |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 00B0                                                                                                                         | <b>Physical Address</b>                                                          | 0x4830 70B0           | <b>Instance</b>                                                                                                                         | PER_PRM         |  |  |
| <b>Description</b>      | This register logs module wake-up events. Must be cleared by software. If it is not cleared, it prevents further domain transition. |                                                                                  |                       |                                                                                                                                         |                 |  |  |
| <b>Type</b>             | RW                                                                                                                                  |                                                                                  |                       |                                                                                                                                         |                 |  |  |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16                                                                                                             | ST_UART4<br>ST_GPIO6<br>ST_GPIO5<br>ST_GPIO4<br>ST_GPIO3<br>ST_GPIO2<br>RESERVED | 15 14 13 12 11 10 9 8 | ST_UART3<br>ST_GPT9<br>ST_GPT8<br>ST_GPT7<br>ST_GPT6<br>ST_GPT5<br>ST_GPT4<br>ST_GPT3<br>ST_GPT2<br>EN_MCBSP4<br>EN_MCBSP3<br>EN_MCBSP2 | 7 6 5 4 3 2 1 0 |  |  |
| RESERVED                |                                                                                                                                     |                                                                                  |                       |                                                                                                                                         |                 |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                       | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:19 | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                                                                                                                | R    | 0x0000 |
| 18    | ST_UART4   | UART 4 Wake-up status<br><br>Read 0x0: UART 4 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: UART 4 wake-up occurred.<br><br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0    |
| 17    | ST_GPIO6   | GPIO 6 Wake-up status<br><br>Read 0x0: GPIO 6 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: GPIO 6 wake-up occurred.<br><br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0    |

| Bits | Field Name | Description                                                                                                                                                                                                                       | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 16   | ST_GPIO5   | <p>GPIO 5 Wake-up status</p> <p>Read 0x0: GPIO 5 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: GPIO 5 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>          | RW   | 0x0   |
| 15   | ST_GPIO4   | <p>GPIO 4 Wake-up status</p> <p>Read 0x0: GPIO 4 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: GPIO 4 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>          | RW   | 0x0   |
| 14   | ST_GPIO3   | <p>GPIO 3 Wake-up status</p> <p>Read 0x0: GPIO 3 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: GPIO 3 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>          | RW   | 0x0   |
| 13   | ST_GPIO2   | <p>GPIO 2 Wake-up status</p> <p>Read 0x0: GPIO 2 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: GPIO 2 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>          | RW   | 0x0   |
| 12   | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                | R    | 0x0   |
| 11   | ST_UART3   | <p>UART 3 Wake-up status</p> <p>Read 0x0: UART 3 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: UART 3 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p>          | RW   | 0x0   |
| 10   | ST_GPT9    | <p>GPTIMER 9 Wake-up status</p> <p>Read 0x0: GPTIMER 9 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: GPTIMER 9 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p> | RW   | 0x0   |
| 9    | ST_GPT8    | <p>GPTIMER 8 Wake-up status</p> <p>Read 0x0: GPTIMER 8 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: GPTIMER 8 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p> | RW   | 0x0   |
| 8    | ST_GPT7    | <p>GPTIMER 7 Wake-up status</p> <p>Read 0x0: GPTIMER 7 wake-up did not occur or was masked.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: GPTIMER 7 wake-up occurred.</p> <p>Write 0x1: Status bit is cleared to 0.</p> | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 7           | ST_GPT6           | GPTIMER 6 Wake-up status<br><br>Read 0x0: GPTIMER 6 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br>Read 0x1: GPTIMER 6 wake-up occurred.<br>Write 0x1: Status bit is cleared to 0. | RW          | 0x0          |
| 6           | ST_GPT5           | GPTIMER 5 Wake-up status<br><br>Read 0x0: GPTIMER 5 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br>Read 0x1: GPTIMER 5 wake-up occurred.<br>Write 0x1: Status bit is cleared to 0. | RW          | 0x0          |
| 5           | ST_GPT4           | GPTIMER 4 Wake-up status<br><br>Read 0x0: GPTIMER 4 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br>Read 0x1: GPTIMER 4 wake-up occurred.<br>Write 0x1: Status bit is cleared to 0. | RW          | 0x0          |
| 4           | ST_GPT3           | GPTIMER 3 Wake-up status<br><br>Read 0x0: GPTIMER 3 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br>Read 0x1: GPTIMER 3 wake-up occurred.<br>Write 0x1: Status bit is cleared to 0. | RW          | 0x0          |
| 3           | ST_GPT2           | GPTIMER 2 Wake-up status<br><br>Read 0x0: GPTIMER 2 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br>Read 0x1: GPTIMER 2 wake-up occurred.<br>Write 0x1: Status bit is cleared to 0. | RW          | 0x0          |
| 2           | EN_MCBSP4         | McBSP 4 Wake-up status<br><br>Read 0x0: McBSP 4 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br>Read 0x1: McBSP 4 wake-up occurred.<br>Write 0x1: Status bit is cleared to 0.       | RW          | 0x0          |
| 1           | EN_MCBSP3         | McBSP3 Wake-up status<br><br>Read 0x0: McBSP 3 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br>Read 0x1: McBSP 3 wake-up occurred.<br>Write 0x1: Status bit is cleared to 0.        | RW          | 0x0          |
| 0           | EN_MCBSP2         | McBSP 2 Wake-up status<br><br>Read 0x0: McBSP 2 wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br>Read 0x1: McBSP 2 wake-up occurred.<br>Write 0x1: Status bit is cleared to 0.       | RW          | 0x0          |

**Table 3-421. Register Call Summary for Register PM\_WKST\_PER**

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[0\]](#)

PRCM Register Manual

- [PER\\_PRM Registers: \[1\]](#)

**Table 3-422. PM\_WKDEP\_PER**

|                       |                                                                                                             |                         |             |                 |         |
|-----------------------|-------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 00C8                                                                                                 | <b>Physical Address</b> | 0x4830 70C8 | <b>Instance</b> | PER_PRM |
| <b>Description</b>    | This register allows enabling or disabling the wake-up of the PER domain upon another domain wakeup events. |                         |             |                 |         |
| <b>Type</b>           | RW                                                                                                          |                         |             |                 |         |



| Bits | Field Name | Description                                                                                                                                                                                                                             | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:5 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                      | R    | 0x00000000 |
| 4    | EN_WKUP    | WAKEUP domain dependency<br>0x0: PER domain is independent of WKUP domain wake-up event.<br>0x1: PER domain is woken-up upon WKUP domain wake-up event.                                                                                 | RW   | 0x1        |
| 3    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                      | R    | 0x0        |
| 2    | EN_IVA2    | IVA2 domain dependency<br>0x0: PER domain is independent of IVA2 domain wake-up event.<br>0x1: PER domain is woken-up upon IVA2 domain wake-up event.                                                                                   | RW   | 0x1        |
| 1    | EN_MPUS    | MPU domain dependency<br>0x0: PER domain is independent of MPU domain wake-up event.<br>0x1: PER domain is woken-up upon MPU domain wake-up event.                                                                                      | RW   | 0x1        |
| 0    | EN_CORE    | CORE domain dependency (CORE-L3 clock domain only, not CORE-L4)<br>0x0: PER domain is independent of CORE domain wake-up event (CORE-L3 clock domain only, not CORE-L4).<br>0x1: PER domain is woken-up upon CORE domain wake-up event. | RW   | 0x1        |

**Table 3-423. Register Call Summary for Register PM\_WKDEP\_PER**

PRCM Functional Description

- [Device Wake-Up Events: \[0\] \[1\] \[2\] \[3\]](#)

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[4\]](#)

PRCM Register Manual

- [PER\\_PRM Registers: \[5\]](#)

**Table 3-424. PM\_PWSTCTRL\_PER**

|                         |             |                    |                                                               |  |
|-------------------------|-------------|--------------------|---------------------------------------------------------------|--|
| <b>Address Offset</b>   | 0x0000 00E0 | <b>Instance</b>    | PER_PRM                                                       |  |
| <b>Physical Address</b> | 0x4830 70E0 | <b>Description</b> |                                                               |  |
| <b>Description</b>      |             |                    | This register controls the PER domain power state transition. |  |
| <b>Type</b>             |             |                    | RW                                                            |  |



| Bits  | Field Name    | Description                                                                                                                                                                                                                             | Type | Reset  |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:18 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                      | R    | 0x0000 |
| 17:16 | MEMONSTATE    | Memory state when ON<br><br>0x3: Memory is always ON when domain is ON.                                                                                                                                                                 | R    | 0x3    |
| 15:9  | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                      | R    | 0x00   |
| 8     | MEMRETSTATE   | Memory state when RETENTION<br><br>0x1: Memory is always retained when domain is in RETENTION state.                                                                                                                                    | R    | 0x1    |
| 7:3   | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                      | R    | 0x00   |
| 2     | LOGICRETSTATE | Logic state when domain is RETENTION<br><br>0x0: Logic build with retention flip-flop (GPIO) is retained and remaining logic is OFF when domain is in RETENTION state.<br><br>0x1: Logic is retained when domain is in RETENTION state. | RW   | 0x1    |
| 1:0   | POWERSTATE    | Power state control<br><br>0x0: OFF state<br><br>0x1: RETENTION state<br><br>0x2: Reserved<br><br>0x3: ON state                                                                                                                         | RW   | 0x3    |

**Table 3-425. Register Call Summary for Register PM\_PWSTCTRL\_PER**
**PRCM Basic Programming Model**

- [PM\\_PWSTCTRL\\_domain\\_name \(Power State Control Register\): \[0\]](#)

**PRCM Register Manual**

- [PER\\_PRM Registers: \[1\]](#)

**Table 3-426. PM\_PWSTST\_PER**

|                         |                                                                                         |                       |                 |                |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------|-----------------------|-----------------|----------------|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00E4                                                                             |                       |                 |                |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 70E4                                                                             |                       |                 |                |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register provides a status on the power state transition of the PERIPHERAL domain. |                       |                 |                |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                       |                       |                 |                |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |                |  |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | INTRANSITION                                                                            | RESERVED              | LOGICSTATETEST  | POWERSTATETEST |  |  |  |  |  |  |  |  |  |  |  |  |

  

| Bits  | Field Name     | Description                                                                                                                                                             | Type | Reset   |
|-------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:21 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                      | R    | 0x000   |
| 20    | INTRANSITION   | Domain transition status<br><br>0x0: No transition<br><br>0x1: PERIPHERAL power domain transition is in progress.                                                       | R    | 0x0     |
| 19:3  | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                      | R    | 0x00000 |
| 2     | LOGICSTATETEST | Logic state status<br><br>0x0: PER domain logic is OFF<br><br>0x1: PER domain logic is ON                                                                               | R    | 0x1     |
| 1:0   | POWERSTATETEST | Current power state status<br><br>0x0: Power domain is OFF<br><br>0x1: Power domain is in RETENTION<br><br>0x2: Power domain is INACTIVE<br><br>0x3: Power domain is ON | R    | 0x3     |

**Table 3-427. Register Call Summary for Register PM\_PWSTST\_PER**

PRCM Basic Programming Model

- [PM\\_PWSTST\\_domain\\_name \(Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [PER\\_PRM Registers: \[1\]](#)

**Table 3-428. PM\_PREPWSTST\_PER**

|                         |                                                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00E8                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 70E8                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register provides a status on the PER domain previous power state. It indicates the state entered during the last sleep transition. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

RESERVED

| Bits | Field Name            | Description                                                                                                                                                                                   | Type | Reset      |
|------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                            | R    | 0x00000000 |
| 2    | LASTLOGICSTATEENTERED | Last logic state entered<br>0x0: PER domain logic was previously OFF<br>0x1: PER domain logic was previously ON                                                                               | RW   | 0x0        |
| 1:0  | LASTPOWERSTATEENTERED | Last power state entered<br>0x0: PER domain was previously OFF<br>0x1: PER domain was previously in RETENTION<br>0x2: PER domain was previously INACTIVE<br>0x3: PER domain was previously ON | RW   | 0x0        |

**Table 3-429. Register Call Summary for Register PM\_PREPWSTST\_PER**

PRCM Basic Programming Model

- [PM\\_PREPWSTST\\_domain\\_name \(Previous Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [PER\\_PRM Registers: \[1\]](#)

### 3.7.2.12 EMU\_PRM Registers

#### 3.7.2.12.1 EMU\_PRM Register Summary

**Table 3-430. EMU\_PRM Register Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|---------------|------|-----------------------|----------------|------------------|------------|
| RM_RSTST_EMU  | RW   | 32                    | 0x0000 0058    | 0x4830 7158      | C          |
| PM_PWSTST_EMU | RW   | 32                    | 0x0000 00E4    | 0x4830 71E4      | C          |

#### 3.7.2.12.2 EMU\_PRM Registers

**Table 3-431. RM\_RSTST\_EMU**

|                         |                                                                                                                                                         |                         |                 |                 |                                                    |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|----------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0058                                                                                                                                             | <b>Physical Address</b> | 0x4830 7158     | <b>Instance</b> | EMU_PRM                                            |
| <b>Description</b>      | This register logs the different reset sources of the EMU domain. Each bit is set upon release of the domain reset signal. Must be cleared by software. |                         |                 |                 |                                                    |
| <b>Type</b>             | RW                                                                                                                                                      |                         |                 |                 |                                                    |
| 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 |                 |                                                    |
|                         |                                                                                                                                                         |                         |                 |                 |                                                    |
| RESERVED                |                                                                                                                                                         |                         |                 |                 |                                                    |
|                         |                                                                                                                                                         |                         |                 |                 | DOMAINWKUP_RST<br>GLOBALWARM_RST<br>GLOBALCOLD_RST |

  

| Bits | Field Name     | Description                                                                                                                                                                                                                                   | Type | Reset      |
|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                            | R    | 0x00000000 |
| 2    | DOMAINWKUP_RST | Power domain wake-up reset<br>Read 0x0: No power domain wake-up reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: EMULATION domain has been reset following an EMULATION power domain wake-up.<br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0        |
| 1    | GLOBALWARM_RST | Global warm reset<br>Read 0x0: No global warm reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: MPU domain has been reset upon a global warm reset<br>Write 0x1: Status bit is cleared to 0.                                             | RW   | 0x0        |
| 0    | GLOBALCOLD_RST | Global cold reset<br>Read 0x0: No global cold reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: MPU domain has been reset upon a global cold reset<br>Write 0x1: Status bit is cleared to 0.                                             | RW   | 0x1        |

**Table 3-432. Register Call Summary for Register RM\_RSTST\_EMU**

## PRCM Basic Programming Model

- [Reset Control: \[0\]](#)

## PRCM Register Manual

- [EMU\\_PRM Registers: \[1\]](#)

**Table 3-433. PM\_PWSTST\_EMU**

|                         |             |                                                                                        |         |  |
|-------------------------|-------------|----------------------------------------------------------------------------------------|---------|--|
| <b>Address Offset</b>   | 0x0000 00E4 | <b>Instance</b>                                                                        | EMU_PRM |  |
| <b>Physical Address</b> | 0x4830 71E4 | <b>Description</b>                                                                     |         |  |
| <b>Description</b>      |             | This register provides a status on the power state transition of the EMULATION domain. |         |  |
| <b>Type</b>             |             | RW                                                                                     |         |  |



| Bits  | Field Name   | Description                                                                                                                         | Type | Reset   |
|-------|--------------|-------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:21 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                  | R    | 0x000   |
| 20    | INTRANSITION | Domain transition status<br><br>0x0: No transition<br><br>0x1: EMULATION power domain transition is in progress.                    | R    | 0x0     |
| 19:2  | RESERVED     | Write 0x0040 for future compatibility. Read returns 0x0040.                                                                         | R    | 0x00040 |
| 1:0   | POWERSTATEST | Current power state status<br><br>0x0: Power domain is OFF<br><br>0x1: Reserved<br><br>0x2: Reserved<br><br>0x3: Power domain is ON | R    | 0x3     |

**Table 3-434. Register Call Summary for Register PM\_PWSTST\_EMU**

PRCM Basic Programming Model

- [PM\\_PWSTST\\_domain\\_name \(Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [EMU\\_PRM Registers: \[1\]](#)

### 3.7.2.13 Global\_Reg\_PRM Registers

#### 3.7.2.13.1 Global\_Reg\_PRM Register Summary

**Table 3-435. Global\_Reg\_PRM Register Summary**

| Register Name      | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|--------------------|------|-----------------------|----------------|------------------|------------|
| PRM_VC_SMPS_SA     | RW   | 32                    | 0x0000 0020    | 0x4830 7220      | W          |
| PRM_VC_SMPS_VOL_RA | RW   | 32                    | 0x0000 0024    | 0x4830 7224      | W          |
| PRM_VC_SMPS_CMD_RA | RW   | 32                    | 0x0000 0028    | 0x4830 7228      | W          |
| PRM_VC_CMD_VAL_0   | RW   | 32                    | 0x0000 002C    | 0x4830 722C      | W          |
| PRM_VC_CMD_VAL_1   | RW   | 32                    | 0x0000 0030    | 0x4830 7230      | W          |
| PRM_VC_CH_CONF     | RW   | 32                    | 0x0000 0034    | 0x4830 7234      | W          |
| PRM_VC_I2C_CFG     | RW   | 32                    | 0x0000 0038    | 0x4830 7238      | W          |
| PRM_VC_BYPASS_VAL  | RW   | 32                    | 0x0000 003C    | 0x4830 723C      | W          |
| PRM_RSTCTRL        | RW   | 32                    | 0x0000 0050    | 0x4830 7250      | C          |
| PRM_RSTTIME        | RW   | 32                    | 0x0000 0054    | 0x4830 7254      | C          |

**Table 3-435. Global\_Reg\_PRM Register Summary (continued)**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|-------------------|------|-----------------------|----------------|------------------|------------|
| PRM_RSTST         | RW   | 32                    | 0x0000 0058    | 0x4830 7258      | C          |
| PRM_VOLTCTRL      | RW   | 32                    | 0x0000 0060    | 0x4830 7260      | W          |
| PRM_SRAM_PCHARGE  | RW   | 32                    | 0x0000 0064    | 0x4830 7264      | C          |
| PRM_CLKSRC_CTRL   | RW   | 32                    | 0x0000 0070    | 0x4830 7270      | C          |
| PRM_OBS           | R    | 32                    | 0x0000 0080    | 0x4830 7280      | C          |
| PRM_VOLTSETUP1    | RW   | 32                    | 0x0000 0090    | 0x4830 7290      | C          |
| PRM_VOLTOFFSET    | RW   | 32                    | 0x0000 0094    | 0x4830 7294      | C          |
| PRM_CLKSETUP      | RW   | 32                    | 0x0000 0098    | 0x4830 7298      | C          |
| PRM_POLCTRL       | RW   | 32                    | 0x0000 009C    | 0x4830 729C      | C          |
| PRM_VOLTSETUP2    | RW   | 32                    | 0x0000 00A0    | 0x4830 72A0      | C          |
| PRM_VP1_CONFIG    | RW   | 32                    | 0x0000 00B0    | 0x4830 72B0      | W          |
| PRM_VP1_VSTEPMIN  | RW   | 32                    | 0x0000 00B4    | 0x4830 72B4      | W          |
| PRM_VP1_VSTEPMAX  | RW   | 32                    | 0x0000 00B8    | 0x4830 72B8      | W          |
| PRM_VP1_VLIMITTO  | RW   | 32                    | 0x0000 00BC    | 0x4830 72BC      | W          |
| PRM_VP1_VOLTAGE   | R    | 32                    | 0x0000 00C0    | 0x4830 72C0      | W          |
| PRM_VP1_STATUS    | R    | 32                    | 0x0000 00C4    | 0x4830 72C4      | W          |
| PRM_VP2_CONFIG    | RW   | 32                    | 0x0000 00D0    | 0x4830 72D0      | W          |
| PRM_VP2_VSTEPMIN  | RW   | 32                    | 0x0000 00D4    | 0x4830 72D4      | W          |
| PRM_VP2_VSTEPMAX  | RW   | 32                    | 0x0000 00D8    | 0x4830 72D8      | W          |
| PRM_VP2_VLIMITTO  | RW   | 32                    | 0x0000 00DC    | 0x4830 72DC      | W          |
| PRM_VP2_VOLTAGE   | R    | 32                    | 0x0000 00E0    | 0x4830 72E0      | W          |
| PRM_VP2_STATUS    | R    | 32                    | 0x0000 00E4    | 0x4830 72E4      | W          |
| PRM_LDO_ABB_SETUP | RW   | 32                    | 0x0000 00F0    | 0x4830 72F0      | W          |
| PRM_LDO_ABB_CTRL  | RW   | 32                    | 0x0000 00F4    | 0x4830 72F4      | W          |

**3.7.2.13.2 Global\_Reg\_PRM Registers****Table 3-436. PRM\_VC\_SMPS\_SA**

|                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |                |  |                         |                         |                       |                 |          |     |          |     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|-----------------|--|--|--|----------------|--|-------------------------|-------------------------|-----------------------|-----------------|----------|-----|----------|-----|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                     | 0x0000 0020                                                                                    |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |                |  |                         |                         |                       |                 |          |     |          |     |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                   | 0x4830 7220                                                                                    |                       |                 |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  | Global_Reg_PRM |  |                         |                         |                       |                 |          |     |          |     |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                        | This register allows the setting of the I <sup>2</sup> C slave address of the Power IC device. |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |                |  |                         |                         |                       |                 |          |     |          |     |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                               | RW                                                                                             |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |                |  |                         |                         |                       |                 |          |     |          |     |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 20%;">31 30 29 28 27 26 25 24</td> <td style="width: 20%;">23 22 21 20 19 18 17 16</td> <td style="width: 20%;">15 14 13 12 11 10 9 8</td> <td style="width: 20%;">7 6 5 4 3 2 1 0</td> </tr> <tr> <td>RESERVED</td> <td>SA1</td> <td>RESERVED</td> <td>SA0</td> </tr> </table> |                                                                                                |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |                |  | 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 | RESERVED | SA1 | RESERVED | SA0 |
| 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 |  |  |  |  |  |  |  |                 |  |  |  |                |  |                         |                         |                       |                 |          |     |          |     |
| RESERVED                                                                                                                                                                                                                                                                                                                                                                  | SA1                                                                                            | RESERVED              | SA0             |  |  |  |  |  |  |  |                 |  |  |  |                |  |                         |                         |                       |                 |          |     |          |     |

| Bits  | Field Name | Description                                                                           | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------|------|-------|
| 31:23 | RESERVED   | Write 0s for future compatibility. Read is undefined.                                 | R    | 0x000 |
| 22:16 | SA1        | Set the I <sup>2</sup> C slave address value for the second (if any) Power IC device. | RW   | 0x00  |
| 15:7  | RESERVED   | Write 0s for future compatibility. Read is undefined.                                 | R    | 0x000 |
| 6:0   | SA0        | Set the I <sup>2</sup> C slave address value for the first Power IC device.           | RW   | 0x00  |

**Table 3-437. Register Call Summary for Register PRM\_VC\_SMPS\_SA**
**PRCM Basic Programming Model**

- [Voltage Controller Registers: \[0\] \[1\] \[2\] \[3\]](#)
- [Voltage Controller Initialization Basic Programming Model: \[4\] \[5\]](#)

**PRCM Register Manual**

- [Global\\_Reg\\_PRM Registers: \[7\]](#)

**Table 3-438. PRM\_VC\_SMPS\_VOL\_RA**

| <b>Address Offset</b>   | 0x0000 0024                                                                                          |                                                                                         |                 |  |  |  |  |  |  |  |  |  |  |  |             |              |
|-------------------------|------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|-------------|--------------|
| <b>Physical Address</b> | <a href="#">0x4830 7224</a>                                                                          |                                                                                         |                 |  |  |  |  |  |  |  |  |  |  |  |             |              |
| <b>Description</b>      | This register allows the setting of the voltage configuration register address for the VDD channels. |                                                                                         |                 |  |  |  |  |  |  |  |  |  |  |  |             |              |
| <b>Type</b>             | RW                                                                                                   |                                                                                         |                 |  |  |  |  |  |  |  |  |  |  |  |             |              |
| 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 |  |  |  |  |  |  |  |  |  |  |  |             |              |
| RESERVED                | VOLRA1                                                                                               | RESERVED                                                                                | VOLRA0          |  |  |  |  |  |  |  |  |  |  |  |             |              |
| Bits                    | Field Name                                                                                           | <b>Description</b>                                                                      |                 |  |  |  |  |  |  |  |  |  |  |  | <b>Type</b> | <b>Reset</b> |
| 31:24                   | RESERVED                                                                                             | Write 0s for future compatibility. Read is undefined.                                   |                 |  |  |  |  |  |  |  |  |  |  |  | R           | 0x00         |
| 23:16                   | VOLRA1                                                                                               | Set the voltage configuration register address value for the second VDD channel (VDD2). |                 |  |  |  |  |  |  |  |  |  |  |  | RW          | 0x00         |
| 15:8                    | RESERVED                                                                                             | Write 0s for future compatibility. Read is undefined.                                   |                 |  |  |  |  |  |  |  |  |  |  |  | R           | 0x00         |
| 7:0                     | VOLRA0                                                                                               | Set the voltage configuration register address value for the first VDD channel (VDD1).  |                 |  |  |  |  |  |  |  |  |  |  |  | RW          | 0x00         |

**Table 3-439. Register Call Summary for Register PRM\_VC\_SMPS\_VOL\_RA**
**PRCM Basic Programming Model**

- [Voltage Controller Registers: \[0\] \[1\]](#)
- [Voltage Controller Initialization Basic Programming Model: \[2\] \[3\]](#)

**PRCM Register Manual**

- [Global\\_Reg\\_PRM Registers: \[6\]](#)

**Table 3-440. PRM\_VC\_SMPS\_CMD\_RA**

| <b>Address Offset</b>   | 0x0000 0028                                                                                                                                                                                                                              |                                                                                                                |                 |  |  |  |  |  |  |  |  |  |  |  |             |              |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|-------------|--------------|
| <b>Physical Address</b> | <a href="#">0x4830 7228</a>                                                                                                                                                                                                              |                                                                                                                |                 |  |  |  |  |  |  |  |  |  |  |  |             |              |
| <b>Description</b>      | This register allows the setting of the ON/Retention/OFF command configuration register address for the VDD channels. It is used if the Power IC device has different register addresses for voltage value and ON/Retention/OFF command. |                                                                                                                |                 |  |  |  |  |  |  |  |  |  |  |  |             |              |
| <b>Type</b>             | RW                                                                                                                                                                                                                                       |                                                                                                                |                 |  |  |  |  |  |  |  |  |  |  |  |             |              |
| 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 |  |  |  |  |  |  |  |  |  |  |  |             |              |
| RESERVED                | CMDRA1                                                                                                                                                                                                                                   | RESERVED                                                                                                       | CMDRA0          |  |  |  |  |  |  |  |  |  |  |  |             |              |
| Bits                    | Field Name                                                                                                                                                                                                                               | <b>Description</b>                                                                                             |                 |  |  |  |  |  |  |  |  |  |  |  | <b>Type</b> | <b>Reset</b> |
| 31:24                   | RESERVED                                                                                                                                                                                                                                 | Write 0s for future compatibility. Read is undefined.                                                          |                 |  |  |  |  |  |  |  |  |  |  |  | R           | 0x00         |
| 23:16                   | CMDRA1                                                                                                                                                                                                                                   | Set the ON/ON-LP/Retention/OFF command configuration register address value for the second VDD channel (VDD2). |                 |  |  |  |  |  |  |  |  |  |  |  | RW          | 0x00         |
| 15:8                    | RESERVED                                                                                                                                                                                                                                 | Write 0s for future compatibility. Read is undefined.                                                          |                 |  |  |  |  |  |  |  |  |  |  |  | R           | 0x00         |
| 7:0                     | CMDRA0                                                                                                                                                                                                                                   | Set the ON/ON-LP/Retention/OFF command configuration register address value for the first VDD channel (VDD1).  |                 |  |  |  |  |  |  |  |  |  |  |  | RW          | 0x00         |

**Table 3-441. Register Call Summary for Register PRM\_VC\_SMPS\_CMD\_RA**

PRCM Basic Programming Model

- [Voltage Controller Registers: \[0\] \[1\]](#)
- [Voltage Controller Initialization Basic Programming Model: \[2\] \[3\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[4\]](#)

**Table 3-442. PRM\_VC\_CMD\_VAL\_0**

|                         |                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 002C                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 722C                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register allows the setting of the ON/Retention/OFF voltage level values for the first VDD channel. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| ON                      | ONLP                    | RET                   | OFF             |

| Bits  | Field Name | Description                                                         | Type | Reset |
|-------|------------|---------------------------------------------------------------------|------|-------|
| 31:24 | ON         | Set the ON voltage level value for the first VDD channel (VDD1).    | RW   | 0x00  |
| 23:16 | ONLP       | Set the ON-LP voltage level value for the first VDD channel (VDD1). | RW   | 0x00  |
| 15:8  | RET        | Set the RET voltage level value for the first VDD channel (VDD1).   | RW   | 0x00  |
| 7:0   | OFF        | Set the OFF voltage level value for the first VDD channel (VDD1).   | RW   | 0x00  |

**Table 3-443. Register Call Summary for Register PRM\_VC\_CMD\_VAL\_0**

PRCM Functional Description

- [Device Off-Mode Sequences: \[0\] \[1\]](#)

PRCM Basic Programming Model

- [Voltage Controller Registers: \[2\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[3\]](#)

**Table 3-444. PRM\_VC\_CMD\_VAL\_1**

|                         |                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0030                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 7230                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register allows the setting of the ON/Retention/OFF voltage level values for the second VDD channel. It is used if the second channel has different values than the first channel. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| ON                      | ONLP                    | RET                   | OFF             |

| Bits  | Field Name | Description                                                          | Type | Reset |
|-------|------------|----------------------------------------------------------------------|------|-------|
| 31:24 | ON         | Set the ON voltage level value for the second VDD channel (VDD2).    | RW   | 0x00  |
| 23:16 | ONLP       | Set the ON-LP voltage level value for the second VDD channel (VDD2). | RW   | 0x00  |
| 15:8  | RET        | Set the RET voltage level value for the second VDD channel (VDD2).   | RW   | 0x00  |

| Bits | Field Name | Description                                                        | Type | Reset |
|------|------------|--------------------------------------------------------------------|------|-------|
| 7:0  | OFF        | Set the OFF voltage level value for the second VDD channel (VDD2). | RW   | 0x00  |

**Table 3-445. Register Call Summary for Register PRM\_VC\_CMD\_VAL\_1**

PRCM Functional Description

- [Device Off-Mode Sequences: \[0\] \[1\]](#)

PRCM Basic Programming Model

- [Voltage Controller Registers: \[2\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[3\]](#)

**Table 3-446. PRM\_VC\_CH\_CONF**

|                         |                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0034                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 7234                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register allows the configuration pointers for both VDD channels. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |      |        |      |      |     |          |    |    |    |    |    |    |    |      |        |      |      |     |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|------|--------|------|------|-----|----------|----|----|----|----|----|----|----|------|--------|------|------|-----|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    | CMD1 | RACEN1 | RAC1 | RAV1 | SA1 | RESERVED |    |    |    |    |    |    |    | CMD0 | RACENO | RAC0 | RAV0 | SA0 |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                      | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED   | Write 0s for future compatibility. Read is undefined.                                                            | R    | 0x000 |
| 20    | CMD1       | Selects the ON/ON-LP/Retention/OFF voltage values for the second VDD channel (VDD2).                             | RW   | 0x0   |
| 19    | RACEN1     | Enable bit for usage of RAC1.                                                                                    | RW   | 0x0   |
| 18    | RAC1       | Set the ON/ON-LP/Retention/OFF command configuration register address pointer for the second VDD channel (VDD2). | RW   | 0x0   |
| 17    | RAV1       | Set the voltage configuration register address pointer for the second VDD channel (VDD2).                        | RW   | 0x0   |
| 16    | SA1        | Set the slave address pointer for the second VDD channel (VDD2).                                                 | RW   | 0x0   |
| 15:5  | RESERVED   | Write 0s for future compatibility. Read is undefined.                                                            | R    | 0x000 |
| 4     | CMD0       | Selects the ON/ON-LP/Retention/OFF voltage values for the first VDD channel (VDD1).                              | RW   | 0x0   |
| 3     | RACENO     | Enable bit for usage of RAC0.                                                                                    | RW   | 0x0   |
| 2     | RAC0       | Set the ON/ON-LP/Retention/OFF command configuration register address pointer for the first VDD channel (VDD1).  | RW   | 0x0   |
| 1     | RAV0       | Set the voltage configuration register address pointer for the first VDD channel (VDD1).                         | RW   | 0x0   |
| 0     | SA0        | Set the slave address pointer for the first VDD channel (VDD1).                                                  | RW   | 0x0   |

**Table 3-447. Register Call Summary for Register PRM\_VC\_CH\_CONF**

PRCM Basic Programming Model

- [Voltage Controller Registers: \[0\] \[1\] \[2\] \[3\]](#)
- [Voltage Controller Initialization Basic Programming Model: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[14\]](#)

**Table 3-448. PRM\_VC\_I2C\_CFG**

| <b>Address Offset</b>   | 0x0000 0038                                                            | <b>Physical Address</b>                                                                                                                                  | 0x4830 7238     | <b>Instance</b> | Global_Reg_PRM          |
|-------------------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|-------------------------|
| <b>Description</b>      | This register allows the configuration pointers for both VDD channels. |                                                                                                                                                          |                 |                 |                         |
| <b>Type</b>             | RW                                                                     |                                                                                                                                                          |                 |                 |                         |
| 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 |                 |                         |
|                         |                                                                        |                                                                                                                                                          |                 | RESERVED        | HMASTER SREN HSEN MCODE |
| Bits                    | Field Name                                                             | Description                                                                                                                                              | Type            | Reset           |                         |
| 31:6                    | RESERVED                                                               | Write 0s for future compatibility. Read is undefined.                                                                                                    | R               | 0x0000000       |                         |
| 5                       | HMASTER                                                                | Put the I2C pads in a low power mode in case of light load.<br><br>0x0: Disables the I2C pads low power mode<br>0x1: Enables the I2C pads low power mode | RW              | 0x0             |                         |
| 4                       | SREN                                                                   | Enables the I2C repeated start operation mode.<br><br>0x0: Disables the repeated start operation mode<br>0x1: Enables the repeated start operation mode  | RW              | 0x1             |                         |
| 3                       | HSEN                                                                   | Enables I2C bus High Speed mode.<br><br>0x0: Disables the I2C high speed mode<br>0x1: Enables the I2C high speed mode                                    | RW              | 0x1             |                         |
| 2:0                     | MCODE                                                                  | Master code value for I2C High Speed preamble transmission.                                                                                              | RW              | 0x0             |                         |

**Table 3-449. Register Call Summary for Register PRM\_VC\_I2C\_CFG**

PRCM Basic Programming Model

- [Voltage Controller Registers: \[0\]](#)
- [Voltage Controller Initialization Basic Programming Model: \[1\] \[2\] \[3\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[6\]](#)

**Table 3-450. PRM\_VC\_BYPASS\_VAL**

|                         |                                                                                         |                         |                 |                 |                |
|-------------------------|-----------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 003C                                                                             | <b>Physical Address</b> | 0x4830 723C     | <b>Instance</b> | Global_Reg_PRM |
| <b>Description</b>      | This register allows the programming of the Power IC device using the bypass interface. |                         |                 |                 |                |
| <b>Type</b>             | RW                                                                                      |                         |                 |                 |                |
| 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 |                 |                |
| RESERVED                | VALID                                                                                   | DATA                    | REGADDR         | RESERVED        | SLAVEADDR      |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:25 | RESERVED   | Write 0s for future compatibility. Read is undefined.                                                                                                                                                                                                                                                                                                        | RW   | 0x00  |
| 24    | VALID      | <p>This bit validates the bypass command. It is automatically cleared by HW either after getting the acknowledge back from the SMPS or if an error occurred.</p> <p>0x0: Reserved<br/>0x0: The last command send has been acknowledged<br/>0x1: The Voltage Controller send the command to the I2C interface<br/>0x1: Pending command is being processed</p> | RW   | 0x0   |
| 23:16 | DATA       | Data to send to the Power IC device.                                                                                                                                                                                                                                                                                                                         | RW   | 0x00  |
| 15:8  | REGADDR    | Set the address of Power IC device register to configure.                                                                                                                                                                                                                                                                                                    | RW   | 0x00  |
| 7     | RESERVED   | Write 0s for future compatibility. Read is undefined.                                                                                                                                                                                                                                                                                                        | RW   | 0x0   |
| 6:0   | SLAVEADDR  | Set the I2C slave address value.                                                                                                                                                                                                                                                                                                                             | RW   | 0x00  |

**Table 3-451. Register Call Summary for Register PRM\_VC\_BYPASS\_VAL**

PRCM Basic Programming Model

- Voltage Controller Registers: [0]

---

PRCM Register Manual

- Global\_Reg\_PRM Registers: [1]

**Table 3-452. PRM RSTCTRL**

|                         |                                                                                                                          |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0050                                                                                                              |
| <b>Physical Address</b> | 0x4830 7250                                                                                                              |
| <b>Instance</b>         | Global_Reg_PRM                                                                                                           |
| <b>Description</b>      | Global software and DPLL3 reset control. This register is auto-cleared. Only write 1 is possible. A read returns 0 only. |
| <b>Type</b>             | RW                                                                                                                       |
| 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                                                                                                          |
| RESERVED                | RST_DPLL3 RST_GS RESERVED                                                                                                |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:3        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                               | R           | 0x00000000   |
| 2           | RST_DPLL3         | <p>DPLL3 software reset control. This bit is reset only upon a global cold source of reset.</p> <p>0x0: DPLL3 software reset is cleared.</p> <p>0x1: Asserts the DPLL3 software reset and induces a global cold reset on the whole chip. The software must ensure the SDRAM is properly put in self-refresh mode before applying this reset.</p> | RW          | 0x0          |
| 1           | RST_GS            | <p>Global software reset control. This bit is reset upon any global source of reset (warm and cold).</p> <p>0x0: Global software reset is cleared.</p> <p>0x1: Asserts a global software reset.</p>                                                                                                                                              | RW          | 0x0          |
| 0           | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                               | R           | 0x0          |

**Table 3-453. Register Call Summary for Register PRM\_RSTCTRL**

PRCM Functional Description

- [Reset Sources: \[0\] \[1\]](#)

PRCM Basic Programming Model

- [Reset Control: \[2\] \[3\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[4\]](#)

**Table 3-454. PRM\_RSTTIME**

|                         |                             |                 |                |
|-------------------------|-----------------------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 0054                 | <b>Instance</b> | Global_Reg_PRM |
| <b>Physical Address</b> | <a href="#">0x4830 7254</a> |                 |                |
| <b>Description</b>      | Reset duration control.     |                 |                |
| <b>Type</b>             | RW                          |                 |                |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RSTTIME2 |    |    |    |    | RSTTIME1 |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                         | Type | Reset   |
|-------|------------|---------------------------------------------------------------------|------|---------|
| 31:13 | RESERVED   | Write 0s for future compatibility. Read returns 0.                  | R    | 0x00000 |
| 12:8  | RSTTIME2   | (Power domain) reset duration 2<br>(number of RM_ICLK clock cycles) | RW   | 0x10    |
| 7:0   | RSTTIME1   | (Global) reset duration 1<br>(number of Func_32k.clk clock cycles)  | RW   | 0x06    |

**Table 3-455. Register Call Summary for Register PRM\_RSTTIME**

PRCM Functional Description

- [General Characteristics of Reset Signals: \[0\]](#)
- [Power Domain Reset Descriptions: \[1\]](#)
- [Reset Sequences: \[2\] \[3\]](#)

PRCM Basic Programming Model

- [Reset Management: \[4\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[5\]](#)

**Table 3-456. PRM\_RSTST**

|                         |                                                                                                                                    |                 |                |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 0058                                                                                                                        | <b>Instance</b> | Global_Reg_PRM |
| <b>Physical Address</b> | <a href="#">0x4830 7258</a>                                                                                                        |                 |                |
| <b>Description</b>      | This register logs the global reset sources. Each bit is set upon release of the domain reset signal. Must be cleared by software. |                 |                |
| <b>Type</b>             | RW                                                                                                                                 |                 |                |

| 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          |          |          |               |                 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------------|-------------|--------------------------|--------------------------|-------------------|----------|------------|----------|----------|---------------|-----------------|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | ICECRUSHER_RST | ICEPICK_RST | VDD2_VOLTAGE_MANAGER_RST | VDD1_VOLTAGE_MANAGER_RST | EXTERNAL_WARM_RST | RESERVED | MPU_WD_RST | RESERVED | RESERVED | GLOBAL_SW_RST | GLOBAL_COLD_RST |

| Bits  | Field Name               | Description                                                                                                                                                                                                                               | Type | Reset    |
|-------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:11 | RESERVED                 | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                        | R    | 0x000000 |
| 10    | ICECRUSHER_RST           | IceCrusher reset event. This is a source of warm reset initiated by the emulation.<br>Read 0x0: No IceCrusher reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: IceCrusher reset occurred.<br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0      |
| 9     | ICEPICK_RST              | IcePick reset event. This is a source of warm reset initiated by the emulation.<br>Read 0x0: No IcePick reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: IcePick reset occurred.<br>Write 0x1: Status bit is cleared to 0.          | RW   | 0x0      |
| 8     | VDD2_VOLTAGE_MANAGER_RST | VDD2 voltage manager reset event<br>Read 0x0: No VDD2 voltage manager reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: VDD2 voltage manager reset occurred.<br>Write 0x1: Status bit is cleared to 0.                               | RW   | 0x0      |
| 7     | VDD1_VOLTAGE_MANAGER_RST | VDD1 voltage manager reset event<br>Read 0x0: No VDD1 voltage manager reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: VDD1 voltage manager reset occurred.<br>Write 0x1: Status bit is cleared to 0.                               | RW   | 0x0      |
| 6     | EXTERNAL_WARM_RST        | External warm reset event<br>Read 0x0: No global warm reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: Global external warm reset occurred.<br>Write 0x1: Status bit is cleared to 0.                                               | RW   | 0x0      |
| 5     | RESERVED                 | Reserved for non-GP devices.                                                                                                                                                                                                              | RW   | 0x0      |
| 4     | MPU_WD_RST               | MPU watchdog reset event<br>Read 0x0: No MPU watchdog reset.<br>Write 0x0: Status bit unchanged<br>Read 0x1: MPU wachdog reset occurred.<br>Write 0x1: Status bit is cleared to 0.                                                        | RW   | 0x0      |
| 3     | RESERVED                 | Reserved for non-GP devices.                                                                                                                                                                                                              | RW   | 0x0      |
| 2     | RESERVED                 | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                        | R    | 0x0      |

| Bits | Field Name      | Description                                                                                                                                                                                                  | Type | Reset |
|------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | GLOBAL_SW_RST   | Global software reset event<br><br>Read 0x0: No global software reset.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: Global software reset occurred.<br><br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0   |
| 0    | GLOBAL_COLD_RST | Power-up (cold) reset event<br><br>Read 0x0: No power-on reset.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: Power-on reset occurred.<br><br>Write 0x1: Status bit is cleared to 0.               | RW   | 0x1   |

**Table 3-457. Register Call Summary for Register PRM\_RSTST**

## PRCM Functional Description

- [Reset Logging: \[0\] \[1\]](#)

## PRCM Basic Programming Model

- [Reset Control: \[2\] \[3\] \[4\]](#)
- [Reset Management: \[5\]](#)

## PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[6\]](#)

**Table 3-458. PRM\_VOLTCTRL**

|                       |                                                                 |                         |             |                 |                |
|-----------------------|-----------------------------------------------------------------|-------------------------|-------------|-----------------|----------------|
| <b>Address Offset</b> | 0x0000 0060                                                     | <b>Physical Address</b> | 0x4830 7260 | <b>Instance</b> | Global_Reg_PRM |
| <b>Description</b>    | This register allows a direct control on the external power IC. |                         |             |                 |                |
| <b>Type</b>           | RW                                                              |                         |             |                 |                |



| Bits | Field Name | Description                                                                                                                                                                                                                        | Type | Reset     |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:9 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                 | R    | 0x0000000 |
| 8:5  | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                 | R    | 0x0       |
| 4    | SEL_VMODE  | This bit allows to select the mode used to control the Power IC (I2C or VMODE).<br><br>0x0: The Power IC is controlled through the SR dedicated I2C interface.<br><br>0x1: The Power IC is controlled through the VMODE interface. | RW   | 0x0       |
| 3    | SEL_OFF    | This bit allows to select the mode used to send the OFF command.<br><br>0x0: The OFF command is send through the voltage controller I2C interface.<br><br>0x1: The signal SYS.OFF_MODE is asserted.                                | RW   | 0x0       |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 2           | AUTO_OFF          | <p>This bit allows to send an OFF command to the Power IC.</p> <p>0x0: The OFF command is not send.</p> <p>0x1: The OFF command is automatically send when the voltage domain is in the appropriate standby mode.</p>                                                               | RW          | 0x0          |
| 1           | AUTO_RET          | <p>This bit allows to send a RETENTION command to the Power IC through the voltage controller I2C interface.</p> <p>0x0: The RETENTION command is not send.</p> <p>0x1: The RETENTION command is automatically send when the voltage domain is in the appropriate standby mode.</p> | RW          | 0x0          |
| 0           | AUTO_SLEEP        | <p>This bit allows to send a SLEEP command to the Power IC through the voltage controller I2C interface.</p> <p>0x0: The SLEEP command is not send.</p> <p>0x1: The SLEEP command is automatically send when the voltage domain is in the appropriate standby mode.</p>             | RW          | 0x0          |

**Table 3-459. Register Call Summary for Register PRM\_VOLTCTRL**


---

**PRCM Functional Description**

- [Voltage Domain Dependencies: \[0\] \[1\] \[2\]](#)
  - [VDD1 and VDD2 Control: \[3\]](#)
  - [Device Off-Mode Sequences: \[4\] \[5\]](#)
- 

**PRCM Basic Programming Model**

- [External Voltage Control Register Descriptions: \[6\] \[7\]](#)
- 

**PRCM Register Manual**

- [Global\\_Reg\\_PRM Registers: \[9\]](#)
- 

**Table 3-460. PRM\_SRAM\_PCHARGE**

|                         |                                                               |                       |                 |          |  |  |  |  |  |  |  |              |  |  |  |
|-------------------------|---------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--------------|--|--|--|
| <b>Address Offset</b>   | 0x0000 0064                                                   |                       |                 |          |  |  |  |  |  |  |  |              |  |  |  |
| <b>Physical Address</b> | <a href="#">0x4830 7264</a>                                   |                       |                 |          |  |  |  |  |  |  |  |              |  |  |  |
| <b>Description</b>      | This register allows setting the pre-charge time of the SRAM. |                       |                 |          |  |  |  |  |  |  |  |              |  |  |  |
| <b>Type</b>             | RW                                                            |                       |                 |          |  |  |  |  |  |  |  |              |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  | PCHARGE_TIME |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                              | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------|-------------|--------------|
| 31:8        | RESERVED          | Write 0s for future compatibility. Read returns 0.              | R           | 0x0000000    |
| 7:0         | PCHARGE_TIME      | Number of system clock cycles for the SRAM pre-charge duration. | RW          | 0x50         |

**Table 3-461. Register Call Summary for Register PRM\_SRAM\_PCHARGE**


---

**PRCM Register Manual**

- [Global\\_Reg\\_PRM Registers: \[0\]](#)
-

**Table 3-462. PRM\_CLKSRC\_CTRL**

|                       |                                                              |                         |             |                 |                |
|-----------------------|--------------------------------------------------------------|-------------------------|-------------|-----------------|----------------|
| <b>Address Offset</b> | 0x0000 0070                                                  | <b>Physical Address</b> | 0x4830 7270 | <b>Instance</b> | Global_Reg_PRM |
| <b>Description</b>    | This register provides control over the device source clock. |                         |             |                 |                |
| <b>Type</b>           | RW                                                           |                         |             |                 |                |



| Bits | Field Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset     |
|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:9 | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0x0000000 |
| 8    | DPLL4_CLKINP_DIV | <p>This field controls the divider of the DPLL4 reference clock.</p> <p>0x0: The DPLL4 reference clock is the system clock divided by 1.</p> <p>0x1: The DPLL4 reference clock is the system clock divided by 6.5.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0x0       |
| 7:6  | SYSCLKDIV        | <p>This field controls the system clock input divider</p> <p>0x0: Reserved</p> <p>0x1: Syst_clk is external clock / 1</p> <p>0x2: Syst_clk is external clock / 2</p> <p>0x3: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0x1       |
| 5    | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0x0       |
| 4:3  | AUTOEXTCLKMODE   | <p>This field allows to control the external clock request (CLKREQ) and the oscillator</p> <p>0x0: CLKREQ is kept asserted or the oscillator is always active (in master mode)</p> <p>0x1: CLKREQ is de-asserted or the oscillator is put in power-down mode (in master mode) when all the voltages domains are SLEEP, RETENTION or OFF states.</p> <p>0x2: CLKREQ is de-asserted or the oscillator is put in power-down mode (in master mode) when all the voltages domains are RETENTION or OFF states.</p> <p>0x3: CLKREQ is de-asserted or the oscillator is put in power-down mode (in master mode) only when all the voltage domains are in OFF states.</p> | RW   | 0x0       |
| 2    | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0x0       |
| 1:0  | SYSCLKSEL        | <p>This field reflects the mode of the oscillator. It is automatically set accordingly to the external tied-off configuration and its value is unsignificant before the release of the power-on reset.</p> <p>0x0: Bypass mode: the system clock is issued from an external square clock source</p> <p>0x1: Oscillator mode: the system clock is issued from an external quartz</p> <p>0x2: Reserved</p> <p>0x3: Unknown state (not known before release of the power-on reset)</p>                                                                                                                                                                               | R    | 0x3       |

**Table 3-463. Register Call Summary for Register PRM\_CLKSRC\_CTRL**


---

 PRCM Functional Description

- External Clock I/Os: [0]
  - Internal Clock Generation: [1] [2] [3]
  - External Clock Controls: [4] [5]
  - Internal Clock Controls: [6] [7]
- 

## PRCM Basic Programming Model

- System Clock Control Registers: [8]
- 

## PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[9\]](#)
- 

**Table 3-464. PRM\_OBS**

|                         |                                                                                                                                                          |                       |                 |  |  |  |  |         |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|---------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0080                                                                                                                                              |                       |                 |  |  |  |  |         |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | <a href="#">0x4830 7280</a>                                                                                                                              |                       |                 |  |  |  |  |         |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register logs the observable signals (18 bits). This register is intended to be read through the debugger interface when the device is in OFF mode. |                       |                 |  |  |  |  |         |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                        |                       |                 |  |  |  |  |         |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |         |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                                                                                                                                          |                       |                 |  |  |  |  | OBS_BUS |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                        | Type | Reset   |
|-------|------------|----------------------------------------------------|------|---------|
| 31:18 | RESERVED   | Read is undefined.                                 | R    | 0x0000  |
| 17:0  | OBS_BUS    | Indicates the current value on the observable bus. | R    | 0x00000 |

**Table 3-465. Register Call Summary for Register PRM\_OBS**


---

 PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[0\]](#)
- 

**Table 3-466. PRM\_VOLTSETUP1**

|                         |                                                                                                                                                                                                                                            |                       |                 |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|-------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0090                                                                                                                                                                                                                                |                       |                 |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | <a href="#">0x4830 7290</a>                                                                                                                                                                                                                |                       |                 |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register allows setting the setup time of the VDD1 and VDD2 regulators. This register is used when exiting OFF/RET/SLEEP mode (or enters OFF/RET/SLEEP mode) and when device manages the sequencing of the voltages regulation steps. |                       |                 |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                         |                       |                 |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |
| SETUP_TIME2             |                                                                                                                                                                                                                                            |                       |                 |  |  |  |  | SETUP_TIME1 |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                    | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | SETUPTIME2 | The value, in number of cycles of SYS_CLK, determines the setup duration of VDD2 regulator. The setup duration is computed as = 8 x number of cycles of SYS_CLK set in the register bit field. | RW   | 0x0000 |
| 15:0  | SETUPTIME1 | The value, in number of cycles of SYS_CLK, determines the setup duration of VDD1 regulator. The setup duration is computed as = 8 x number of cycles of SYS_CLK set in the register bit field. | RW   | 0x0000 |

**Table 3-467. Register Call Summary for Register PRM\_VOLTSETUP1**

## PRCM Functional Description

- VDD1 and VDD2 Control: [0]
- Device Off-Mode Sequences: [1] [2] [3] [4] [5] [6]

## PRCM Basic Programming Model

- External Voltage Control Register Descriptions: [7] [8] [9] [10] [11]

## PRCM Register Manual

- Global\_Reg\_PRM Registers: [14]

**Table 3-468. PRM\_VOLTOFFSET**

|                         |                                                                                                                                                                                                                                          |                                                           |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |             |              |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|-------------|--------------|--|
| <b>Address Offset</b>   | 0x0000 0094                                                                                                                                                                                                                              |                                                           |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |             |              |  |
| <b>Physical Address</b> | 0x4830 7294                                                                                                                                                                                                                              |                                                           |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |             |              |  |
| <b>Description</b>      | This register allows controlling the sys_offmode signal upon wake-up from OFF mode when the OFF sequence is supervised by the Power IC. This register allows setting the offset-time to de-assert sys_offmode when exiting the OFF mode. |                                                           |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |             |              |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                       |                                                           |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |             |              |  |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |             |              |  |
| <b>Bits</b>             | <b>Field Name</b>                                                                                                                                                                                                                        | <b>Description</b>                                        |                 |          |  |  |  |  |  |  |  |  |  |  |  |  | <b>Type</b> | <b>Reset</b> |  |
| 31:16                   | RESERVED                                                                                                                                                                                                                                 | Write 0s for future compatibility. Read returns 0.        |                 |          |  |  |  |  |  |  |  |  |  |  |  |  | R           | 0x0000       |  |
| 15:0                    | OFFSET_TIME                                                                                                                                                                                                                              | Number of 32kHz clock cycles for the OFF mode offset time |                 |          |  |  |  |  |  |  |  |  |  |  |  |  | RW          | 0x0000       |  |

**Table 3-469. Register Call Summary for Register PRM\_VOLTOFFSET**

## PRCM Functional Description

- Device Off-Mode Sequences: [0]

## PRCM Basic Programming Model

- External Voltage Control Register Descriptions: [1]

## PRCM Register Manual

- Global\_Reg\_PRM Registers: [2]

**Table 3-470. PRM\_CLKSETUP**

|                         |                                                                                                                               |                                                     |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |             |              |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|-------------|--------------|--|
| <b>Address Offset</b>   | 0x0000 0098                                                                                                                   |                                                     |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |             |              |  |
| <b>Physical Address</b> | 0x4830 7298                                                                                                                   |                                                     |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |             |              |  |
| <b>Description</b>      | This register allows setting the setup time of the oscillator system clock (sys_clk), based on number of 32 kHz clock cycles. |                                                     |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |             |              |  |
| <b>Type</b>             | RW                                                                                                                            |                                                     |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |             |              |  |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |             |              |  |
| <b>Bits</b>             | <b>Field Name</b>                                                                                                             | <b>Description</b>                                  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  | <b>Type</b> | <b>Reset</b> |  |
| 31:16                   | RESERVED                                                                                                                      | Write 0s for future compatibility. Read returns 0.  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  | R           | 0x0000       |  |
| 15:0                    | SETUP_TIME                                                                                                                    | Number of 32kHz clock cycles for the SETUP duration |                 |          |  |  |  |  |  |  |  |  |  |  |  |  | RW          | 0x0000       |  |

**Table 3-471. Register Call Summary for Register PRM\_CLKSETUP**

---

PRCM Functional Description

- External Clock Controls: [0]
- Internal Clock Controls: [1]
- Device Off-Mode Sequences: [2]

---

PRCM Basic Programming Model

- System Clock Control Registers: [3]
- External Voltage Control Register Descriptions: [4] [5]

---

PRCM Register Manual

- Global\_Reg\_PRM Registers: [6]

**Table 3-472. PRM\_POLCTRL**

|                         |                                                                              |                 |                |
|-------------------------|------------------------------------------------------------------------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 009C                                                                  |                 |                |
| <b>Physical Address</b> | <a href="#">0x4830 729C</a>                                                  | <b>Instance</b> | Global_Reg_PRM |
| <b>Description</b>      | This register allows setting the polarity of device outputs control signals. |                 |                |
| <b>Type</b>             | RW                                                                           |                 |                |



| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:4        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                     | R           | 0x00000000   |
| 3           | OFFMODE_POL       | Controls the polarity of the sys_offmode signal<br>0x0: sys_offmode is active low<br>0x1: sys_offmode is active high                                   | RW          | 0x1          |
| 2           | CLKOUT_POL        | Controls the external output clock polarity when disabled<br>0x0: sys_clkout is gated low when inactive<br>0x1: sys_clkout is gated high when inactive | RW          | 0x0          |
| 1           | CLKREQ_POL        | Controls the polarity of the sys_clkreq signal<br>0x0: sys_clkreq is active low<br>0x1: sys_clkreq is active high                                      | RW          | 0x1          |
| 0           | EXTVOL_POL        | Controls the polarity of sys_vmode signal<br>0x0: sys_vmode signal is active low<br>0x1: sys_vmode signal is active high                               | RW          | 0x0          |

**Table 3-473. Register Call Summary for Register PRM\_POLCTRL**

---

PRCM Functional Description

- External Clock Controls: [0] [1] [2] [3] [4] [5] [6] [7]
- Internal Clock Controls: [8]
- VDD1 and VDD2 Control: [9] [10]

PRCM Register Manual

- Global\_Reg\_PRM Registers: [12]

**Table 3-474. PRM\_VOLTSETUP2**

|                         |                                                                                                                                                                                                             |                         |                 |                  |                |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|------------------|----------------|
| <b>Address Offset</b>   | 0x0000 00A0                                                                                                                                                                                                 | <b>Physical Address</b> | 0x4830 72A0     | <b>Instance</b>  | Global_Reg_PRM |
| <b>Description</b>      | This register allows setting the overall setup time of VDD1 and VDD2 regulators. This register is used when exiting OFF mode and when the Power IC manages the sequencing of the voltages regulation steps. |                         |                 |                  |                |
| <b>Type</b>             | RW                                                                                                                                                                                                          |                         |                 |                  |                |
| 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 |                  |                |
| RESERVED                |                                                                                                                                                                                                             |                         |                 | OFFMODESETUPTIME |                |

| Bits  | Field Name       | Description                                                                          | Type | Reset  |
|-------|------------------|--------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED         | Write 0s for future compatibility. Read returns 0.                                   | R    | 0x0000 |
| 15:0  | OFFMODESETUPTIME | Number of 32kHz clock cycles for the overall setup time of VDD1 and VDD2 regulators. | RW   | 0x0000 |

**Table 3-475. Register Call Summary for Register PRM\_VOLTSETUP2**

## PRCM Basic Programming Model

- External Voltage Control Register Descriptions: [0] [1] [2] [3]

## PRCM Register Manual

- Global\_Reg\_PRM Registers: [4]

**Table 3-476. PRM\_VP1\_CONFIG**

|                         |                                                                           |                         |                 |                 |                                    |
|-------------------------|---------------------------------------------------------------------------|-------------------------|-----------------|-----------------|------------------------------------|
| <b>Address Offset</b>   | 0x0000 00B0                                                               | <b>Physical Address</b> | 0x4830 72B0     | <b>Instance</b> | Global_Reg_PRM                     |
| <b>Description</b>      | This register allows the configuration of the Voltage Processor 1 (VDD1). |                         |                 |                 |                                    |
| <b>Type</b>             | RW                                                                        |                         |                 |                 |                                    |
| 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 |                 |                                    |
| ERROROFFSET             | ERRORGAIN                                                                 | INITVOLTAGE             | RESERVED        | TIMEOUTEN       | INITVDD<br>FORCEUPDATE<br>OPENABLE |

| Bits  | Field Name  | Description                                                                                                                                                                                                  | Type | Reset |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | ERROROFFSET | Offset value in the Error to Voltage converter (two's complement number).                                                                                                                                    | RW   | 0x00  |
| 23:16 | ERRORGAIN   | Gain value in the Error to Voltage converter (two's complement number).                                                                                                                                      | RW   | 0x00  |
| 15:8  | INITVOLTAGE | Set the initial voltage level of the SMPS. It must be reconfigured before SmartReflex is enabled around a new OPP.                                                                                           | RW   | 0x00  |
| 7:4   | RESERVED    | Write 0s for future compatibility. Read is undefined.                                                                                                                                                        | R    | 0x0   |
| 3     | TIMEOUTEN   | Enable or disable the timeout capability of the Voltage Controller State Machine.<br><br>0x0: Timeout is disabled. Loop will wait indefinitely.<br>0x1: Timeout will occur when TIMEOUT cycles have elapsed. | RW   | 0x0   |

| Bits | Field Name  | Description                                                                                                                                                                                                       | Type | Reset |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 2    | INITVDD     | Initializes the voltage in the Voltage Processor.<br><br>0x0: Reset the initialization bit.<br><br>0x1: The positive edge of InitVdd triggers a write of the value in the InitVoltage into the Voltage Processor. | RW   | 0x0   |
| 1    | FORCEUPDATE | Forces an update of the SMPS.<br><br>0x0: Reset the force bit.<br><br>0x1: The positive edge of ForceUpdate triggers an update of the voltage to the SMPS.                                                        | RW   | 0x0   |
| 0    | VENABLE     | Enables or disables the Voltage Processor.<br><br>0x0: Disables the Voltage Processor.<br><br>0x1: Enables the Voltage Processor.                                                                                 | RW   | 0x0   |

**Table 3-477. Register Call Summary for Register PRM\_VP1\_CONFIG**

PRCM Basic Programming Model

- [Voltage Processor Registers: \[0\] \[1\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[7\]](#)

**Table 3-478. PRM\_VP1\_VSTEPMIN**

|                         |                                                                                                                      |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |          |          |                |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|----------|----------|----------------|--|
| <b>Address Offset</b>   | 0x0000 00B4                                                                                                          |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |          |          |                |  |
| <b>Physical Address</b> | 0x4830 72B4                                                                                                          |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |          | Instance | Global_Reg_PRM |  |
| <b>Description</b>      | This register allows the programming of the minimum voltage step and waiting time of the Voltage Processor 1 (VDD1). |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |          |          |                |  |
| <b>Type</b>             | RW                                                                                                                   |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |          |          |                |  |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |          |          |                |  |
| SMPSWAITTIMEMIN         |                                                                                                                      |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  | VSTEPMIN |          |                |  |

| Bits  | Field Name      | Description                                                         | Type | Reset  |
|-------|-----------------|---------------------------------------------------------------------|------|--------|
| 31:24 | RESERVED        | Write 0s for future compatibility. Read is undefined.               | R    | 0x00   |
| 23:8  | SMPSWAITTIMEMIN | Slew rate for negative voltage step (in number of cycles per step). | RW   | 0x0000 |
| 7:0   | VSTEPMIN        | Minimum voltage step                                                | RW   | 0x00   |

**Table 3-479. Register Call Summary for Register PRM\_VP1\_VSTEPMIN**

PRCM Basic Programming Model

- [Voltage Processor Registers: \[0\] \[1\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[2\]](#)

**Table 3-480. PRM\_VP1\_VSTEPMAX**

|                         |                                                                                                                      |                         |                 |                 |                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 00B8                                                                                                          | <b>Physical Address</b> | 0x4830 72BC     | <b>Instance</b> | Global_Reg_PRM |
| <b>Description</b>      | This register allows the programming of the maximum voltage step and waiting time of the Voltage Processor 1 (VDD1). |                         |                 |                 |                |
| <b>Type</b>             | RW                                                                                                                   |                         |                 |                 |                |
| 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 |                 |                |
| RESERVED                | SMPSWAITTIMEMAX                                                                                                      |                         |                 |                 |                |

| Bits  | Field Name      | Description                                                         | Type | Reset  |
|-------|-----------------|---------------------------------------------------------------------|------|--------|
| 31:24 | RESERVED        | Write 0s for future compatibility. Read is undefined.               | R    | 0x00   |
| 23:8  | SMPSWAITTIMEMAX | Slew rate for positive voltage step (in number of cycles per step). | RW   | 0x0000 |
| 7:0   | VSTEPMAX        | Maximum voltage step                                                | RW   | 0x00   |

**Table 3-481. Register Call Summary for Register PRM\_VP1\_VSTEPMAX**

PRCM Basic Programming Model

- [Voltage Processor Registers: \[0\] \[1\] \[2\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[3\]](#)

**Table 3-482. PRM\_VP1\_VLIMITTO**

|                         |                                                                                                                    |                         |                 |                 |                |
|-------------------------|--------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 00BC                                                                                                        | <b>Physical Address</b> | 0x4830 72BC     | <b>Instance</b> | Global_Reg_PRM |
| <b>Description</b>      | This register allows the configuration of the voltage limits and timeout values of the Voltage Processor 1 (VDD1). |                         |                 |                 |                |
| <b>Type</b>             | RW                                                                                                                 |                         |                 |                 |                |
| 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 |                 |                |
| VDDMAX                  | VDDMIN                                                                                                             | TIMEOUT                 |                 |                 |                |

| Bits  | Field Name | Description                                                 | Type | Reset  |
|-------|------------|-------------------------------------------------------------|------|--------|
| 31:24 | VDDMAX     | Defines the maximum voltage supply level.                   | RW   | 0x00   |
| 23:16 | VDDMIN     | Defines the minimum voltage supply level.                   | RW   | 0x00   |
| 15:0  | TIMEOUT    | Defines Voltage Controller maximum wait time for responses. | RW   | 0x0000 |

**Table 3-483. Register Call Summary for Register PRM\_VP1\_VLIMITTO**

PRCM Basic Programming Model

- [Voltage Processor Registers: \[0\] \[1\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[2\]](#)

**Table 3-484. PRM\_VP1\_VOLTAGE**

|                         |                                                                                                   |                       |                 |          |  |  |  |  |  |  |  |           |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|-----------|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00C0                                                                                       |                       |                 |          |  |  |  |  |  |  |  |           |  |  |  |  |
| <b>Physical Address</b> | <a href="#">0x4830 72C0</a>                                                                       |                       |                 |          |  |  |  |  |  |  |  |           |  |  |  |  |
| <b>Description</b>      | This register indicates the current value of the SMPS voltage for the Voltage Processor 1 (VDD1). |                       |                 |          |  |  |  |  |  |  |  |           |  |  |  |  |
| <b>Type</b>             | R                                                                                                 |                       |                 |          |  |  |  |  |  |  |  |           |  |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  | VPVOLTAGE |  |  |  |  |

| Bits | Field Name | Description                                    | Type | Reset     |
|------|------------|------------------------------------------------|------|-----------|
| 31:8 | RESERVED   | Read is undefined.                             | R    | 0x0000000 |
| 7:0  | VPVOLTAGE  | Indicates the current SMPS programmed voltage. | R    | 0x00      |

**Table 3-485. Register Call Summary for Register PRM\_VP1\_VOLTAGE**

- PRCM Basic Programming Model
  - [Voltage Processor Registers: \[0\] \[1\]](#)
 PRCM Register Manual
  - [Global\\_Reg\\_PRM Registers: \[2\]](#)

**Table 3-486. PRM\_VP1\_STATUS**

|                         |                                                                                                                                |                       |                 |          |  |  |  |  |  |  |  |          |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|----------|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00C4                                                                                                                    |                       |                 |          |  |  |  |  |  |  |  |          |  |  |  |  |
| <b>Physical Address</b> | <a href="#">0x4830 72C4</a>                                                                                                    |                       |                 |          |  |  |  |  |  |  |  |          |  |  |  |  |
| <b>Description</b>      | This register reflects the idle state of the Voltage Processor 1 (VDD1). This register is read only and automatically updated. |                       |                 |          |  |  |  |  |  |  |  |          |  |  |  |  |
| <b>Type</b>             | R                                                                                                                              |                       |                 |          |  |  |  |  |  |  |  |          |  |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  | VPINIDLE |  |  |  |  |

| Bits | Field Name | Description                                                                                                                               | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write Os for future compatibility. Read is undefined.                                                                                     | R    | 0x00000000 |
| 0    | VPINIDLE   | Voltage Processor 1 idle status.<br><br>0x0: The Voltage Processor 1 is processing.<br><br>0x1: The Voltage Processor 1 is in idle state. | R    | 0x1        |

**Table 3-487. Register Call Summary for Register PRM\_VP1\_STATUS**

- PRCM Basic Programming Model
  - [Voltage Processor Registers: \[0\] \[1\]](#)
 PRCM Register Manual
  - [Global\\_Reg\\_PRM Registers: \[2\]](#)

**Table 3-488. PRM\_VP2\_CONFIG**

|                       |                                                                           |                         |             |                 |                |
|-----------------------|---------------------------------------------------------------------------|-------------------------|-------------|-----------------|----------------|
| <b>Address Offset</b> | 0x0000 00D0                                                               | <b>Physical Address</b> | 0x4830 72D0 | <b>Instance</b> | Global_Reg_PRM |
| <b>Description</b>    | This register allows the configuration of the Voltage Processor 2 (VDD2). |                         |             |                 |                |
| <b>Type</b>           | RW                                                                        |                         |             |                 |                |

| 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                                 |
|-------------------------|-------------------------|-----------------------|-------------------------------------------------|
| ERROROFFSET             | ERRORGAIN               | INITVOLTAGE           | RESERVED TIMEOUTEN INITVDD FORCEUPDATE VPENABLE |

| Bits  | Field Name  | Description                                                                                                                                                                                                       | Type | Reset |
|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | ERROROFFSET | Offset value in the Error to Voltage converter (two's complement number).                                                                                                                                         | RW   | 0x00  |
| 23:16 | ERRORGAIN   | Gain value in the Error to Voltage converter (two's complement number).                                                                                                                                           | RW   | 0x00  |
| 15:8  | INITVOLTAGE | Set the initial voltage level of the SMPS. It must be reconfigured before SmartReflex is enabled around a new OPP.                                                                                                | RW   | 0x00  |
| 7:4   | RESERVED    | Write 0s for future compatibility. Read is undefined.                                                                                                                                                             | R    | 0x0   |
| 3     | TIMEOUTEN   | Enable or disable the timeout capability of the Voltage Controller State Machine.<br><br>0x0: Timeout is disabled. Loop will wait indefinitely.<br>0x1: Timeout will occur when TIMEOUT cycles have elapsed.      | RW   | 0x0   |
| 2     | INITVDD     | Initializes the voltage in the Voltage Processor.<br><br>0x0: Reset the initialization bit.<br><br>0x1: The positive edge of InitVdd triggers a write of the value in the InitVoltage into the Voltage Processor. | RW   | 0x0   |
| 1     | FORCEUPDATE | Forces an update of the SMPS.<br><br>0x0: Reset the force bit.<br><br>0x1: The positive edge of ForceUpdate triggers an update of the voltage to the SMPS.                                                        | RW   | 0x0   |
| 0     | VPENABLE    | Enables or disables the Voltage Processor.<br><br>0x0: Disables the Voltage Processor.<br>0x1: Enables the Voltage Processor.                                                                                     | RW   | 0x0   |

**Table 3-489. Register Call Summary for Register PRM\_VP2\_CONFIG**

## PRCM Basic Programming Model

- [Voltage Processor Registers: \[0\] \[1\]](#)

## PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[7\]](#)

**Table 3-490. PRM\_VP2\_VSTEPMIN**

|                         |                                                                                                                      |                         |                 |                 |                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 00D4                                                                                                          | <b>Physical Address</b> | 0x4830 72D4     | <b>Instance</b> | Global_Reg_PRM |
| <b>Description</b>      | This register allows the programming of the minimum voltage step and waiting time of the Voltage Processor 2 (VDD2). |                         |                 |                 |                |
| <b>Type</b>             | RW                                                                                                                   |                         |                 |                 |                |
| 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 |                 |                |
| RESERVED                | SMPSWAITTIMEMIN                                                                                                      |                         |                 |                 |                |

| Bits  | Field Name      | Description                                                         | Type | Reset  |
|-------|-----------------|---------------------------------------------------------------------|------|--------|
| 31:24 | RESERVED        | Write 0s for future compatibility. Read is undefined.               | R    | 0x00   |
| 23:8  | SMPSWAITTIMEMIN | Slew rate for negative voltage step (in number of cycles per step). | RW   | 0x0000 |
| 7:0   | VSTEPMIN        | Minimum voltage step                                                | RW   | 0x00   |

**Table 3-491. Register Call Summary for Register PRM\_VP2\_VSTEPMIN**

- PRCM Basic Programming Model
- [Voltage Processor Registers: \[0\] \[1\]](#)
- PRCM Register Manual
- [Global\\_Reg\\_PRM Registers: \[2\]](#)

**Table 3-492. PRM\_VP2\_VSTEPMAX**

|                         |                                                                                                                      |                         |                 |                 |                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 00D8                                                                                                          | <b>Physical Address</b> | 0x4830 72D8     | <b>Instance</b> | Global_Reg_PRM |
| <b>Description</b>      | This register allows the programming of the maximum voltage step and waiting time of the Voltage Processor 2 (VDD2). |                         |                 |                 |                |
| <b>Type</b>             | RW                                                                                                                   |                         |                 |                 |                |
| 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 |                 |                |
| RESERVED                | SMPSWAITTIMEMAX                                                                                                      |                         |                 |                 |                |

| Bits  | Field Name      | Description                                                         | Type | Reset  |
|-------|-----------------|---------------------------------------------------------------------|------|--------|
| 31:24 | RESERVED        | Write 0s for future compatibility. Read is undefined.               | R    | 0x00   |
| 23:8  | SMPSWAITTIMEMAX | Slew rate for positive voltage step (in number of cycles per step). | RW   | 0x0000 |
| 7:0   | VSTEPMAX        | Maximum voltage step                                                | RW   | 0x00   |

**Table 3-493. Register Call Summary for Register PRM\_VP2\_VSTEPMAX**

- PRCM Basic Programming Model
- [Voltage Processor Registers: \[0\]](#)
- PRCM Register Manual
- [Global\\_Reg\\_PRM Registers: \[1\]](#)

**Table 3-494. PRM\_VP2\_VLIMITTO**

| <b>Address Offset</b>   | 0x0000 00DC                                                                                                        |                                                             |                 |  |  |  |  |  |  |  |  |  |  |  |      |         |
|-------------------------|--------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|------|---------|
| <b>Physical Address</b> | 0x4830 72DC                                                                                                        |                                                             |                 |  |  |  |  |  |  |  |  |  |  |  |      |         |
| <b>Description</b>      | This register allows the configuration of the voltage limits and timeout values of the Voltage Processor 2 (VDD2). |                                                             |                 |  |  |  |  |  |  |  |  |  |  |  |      |         |
| <b>Type</b>             | RW                                                                                                                 |                                                             |                 |  |  |  |  |  |  |  |  |  |  |  |      |         |
| 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 |  |  |  |  |  |  |  |  |  |  |  |      |         |
| VDDMAX                  | VDDMIN                                                                                                             |                                                             |                 |  |  |  |  |  |  |  |  |  |  |  |      | TIMEOUT |
| Bits                    | Field Name                                                                                                         | Description                                                 |                 |  |  |  |  |  |  |  |  |  |  |  | Type | Reset   |
| 31:24                   | VDDMAX                                                                                                             | Defines the maximum voltage supply level.                   |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00    |
| 23:16                   | VDDMIN                                                                                                             | Defines the minimum voltage supply level.                   |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00    |
| 15:0                    | TIMEOUT                                                                                                            | Defines Voltage Controller maximum wait time for responses. |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x0000  |

**Table 3-495. Register Call Summary for Register PRM\_VP2\_VLIMITTO**

- PRCM Basic Programming Model
  - [Voltage Processor Registers: \[0\] \[1\]](#)
PRCM Register Manual
  - [Global\\_Reg\\_PRM Registers: \[2\]](#)

**Table 3-496. PRM\_VP2\_VOLTAGE**

| <b>Address Offset</b>   | 0x0000 00E0                                                                                       |                                                |                 |  |  |  |  |  |  |  |  |  |  |  |          |           |
|-------------------------|---------------------------------------------------------------------------------------------------|------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|----------|-----------|
| <b>Physical Address</b> | 0x4830 72E0                                                                                       |                                                |                 |  |  |  |  |  |  |  |  |  |  |  |          |           |
| <b>Description</b>      | This register indicates the current value of the SMPS voltage for the Voltage Processor 2 (VDD2). |                                                |                 |  |  |  |  |  |  |  |  |  |  |  |          |           |
| <b>Type</b>             | R                                                                                                 |                                                |                 |  |  |  |  |  |  |  |  |  |  |  |          |           |
| 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 |  |  |  |  |  |  |  |  |  |  |  |          |           |
|                         |                                                                                                   |                                                |                 |  |  |  |  |  |  |  |  |  |  |  | RESERVED | VPVOLTAGE |
| Bits                    | Field Name                                                                                        | Description                                    |                 |  |  |  |  |  |  |  |  |  |  |  | Type     | Reset     |
| 31:8                    | RESERVED                                                                                          | Read is undefined.                             |                 |  |  |  |  |  |  |  |  |  |  |  | R        | 0x0000000 |
| 7:0                     | VPVOLTAGE                                                                                         | Indicates the current SMPS programmed voltage. |                 |  |  |  |  |  |  |  |  |  |  |  | R        | 0x00      |

**Table 3-497. Register Call Summary for Register PRM\_VP2\_VOLTAGE**

- PRCM Basic Programming Model
  - [Voltage Processor Registers: \[0\] \[1\]](#)
PRCM Register Manual
  - [Global\\_Reg\\_PRM Registers: \[2\]](#)

**Table 3-498. PRM\_VP2\_STATUS**

|                         |                                                                                                                                |                         |                 |                 |                |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 00E4                                                                                                                    | <b>Physical Address</b> | 0x4830 72E4     | <b>Instance</b> | Global_Reg_PRM |
| <b>Description</b>      | This register reflects the idle state of the Voltage Processor 2 (VDD2). This register is read only and automatically updated. |                         |                 |                 |                |
| <b>Type</b>             | R                                                                                                                              |                         |                 |                 |                |
| 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 | RESERVED        |                |
|                         |                                                                                                                                |                         |                 |                 | VPINIDLE       |

  

| Bits | Field Name | Description                                                                                                                       | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read is undefined.                                                                             | R    | 0x00000000 |
| 0    | VPINIDLE   | Voltage Processor 2 idle status.<br>0x0: The Voltage Processor 2 is processing.<br>0x1: The Voltage Processor 2 is in idle state. | R    | 0x1        |

**Table 3-499. Register Call Summary for Register PRM\_VP2\_STATUS**

PRCM Basic Programming Model

- [Voltage Processor Registers: \[0\] \[1\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[2\]](#)

**Table 3-500. PRM\_LDO\_ABB\_SETUP**

|                         |                                                               |                         |                 |                   |                |
|-------------------------|---------------------------------------------------------------|-------------------------|-----------------|-------------------|----------------|
| <b>Address Offset</b>   | 0x0000 00F0                                                   | <b>Physical Address</b> | 0x4830 72F0     | <b>Instance</b>   | Global_Reg_PRM |
| <b>Description</b>      | This register allows the configuration of the ABB LDO (VDD1). |                         |                 |                   |                |
| <b>Type</b>             | RW                                                            |                         |                 |                   |                |
| 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 | RESERVED          |                |
|                         |                                                               |                         |                 | SR2_IN_TRANSITION | RESERVED       |
|                         |                                                               |                         |                 | SR2_STATUS        | OPP_CHANGE     |
|                         |                                                               |                         |                 | OPP_SEL           |                |

  

| Bits | Field Name        | Description                                                                                                                                                                                                                                            | Type | Reset      |
|------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:7 | RESERVED          | Write 0s for future compatibility. Read is undefined.                                                                                                                                                                                                  | R    | 0x00000000 |
| 6    | SR2_IN_TRANSITION | Indicates if the ABB LDO is transitioning into a new mode of operation.<br>0x0: The ABB LDO is not transition and the SR2_STATUS bits field is stable.<br>0x1: The ABB LDO is transitioning in a new mode and the SR2_STATUS bits field is not stable. | R    | 0x0        |
| 5    | RESERVED          | Write 0s for future compatibility. Read is undefined.                                                                                                                                                                                                  | R    | 0x0        |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                        | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4:3  | SR2_STATUS | Indicates the current mode of operation of the ABB LDO.<br>0x0: The ABB LDO is in bypass mode.<br>0x1: Reserved<br>0x2: The ABB LDO is in FBB mode.<br>0x3: Reserved.                                                                                                                                                                              | R    | 0x0   |
| 2    | OPP_CHANGE | The ABB LDO controller samples OPP_SEL bits field and ACTIVE_RRB_SEL and ACTIVE_FBB_SEL bit fields upon rising edge of this bit. It is automatically cleared by the PRCM HW upon completion of the ABB LDO transition.<br>0x0: No ABB LDO transition on going or ABB LDO transition has been completed.<br>0x1: Request the ABB LDO to transition. | RW   | 0x0   |
| 1:0  | OPP_SEL    | Selects the OPP at which the voltage VDD1 is operating (or is going to switch to).<br>0x0: Default is nominal OPP.<br>0x1: Fast OPP.<br>0x2: Nominal OPP.<br>0x3: Slow OPP.                                                                                                                                                                        | RW   | 0x0   |

**Table 3-501. Register Call Summary for Register PRM\_LDO\_ABB\_SETUP**

## PRCM Functional Description

- [Analog Cells, LDOs, and Level Shifter Controls: \[0\]](#)

## PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[1\]](#)

**Table 3-502. PRM\_LDO\_ABB\_CTRL**

| Address Offset          | 0x0000 00F4                                                   |  |  |  |  |  |  |  |                       |                 |  |  |  |                                     |  |                                         |          |                |  |  |  |
|-------------------------|---------------------------------------------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|--|--|--|-------------------------------------|--|-----------------------------------------|----------|----------------|--|--|--|
| Physical Address        | 0x4830 72F4                                                   |  |  |  |  |  |  |  |                       |                 |  |  |  |                                     |  |                                         | Instance | Global_Reg_PRM |  |  |  |
| Description             | This register allows the configuration of the ABB LDO (VDD1). |  |  |  |  |  |  |  |                       |                 |  |  |  |                                     |  |                                         |          |                |  |  |  |
| Type                    | RW                                                            |  |  |  |  |  |  |  |                       |                 |  |  |  |                                     |  |                                         |          |                |  |  |  |
| 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 |  |  |  | ACTIVE_FBB_SEL<br>RESERVED<br>SR2EN |  |                                         |          |                |  |  |  |
| RESERVED                |                                                               |  |  |  |  |  |  |  |                       |                 |  |  |  |                                     |  | SR2_WTCNT_VALUE<br>RESERVED<br>RESERVED |          |                |  |  |  |

| Bits  | Field Name      | Description                                                                                                                                                     | Type | Reset  |
|-------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED        | Write 0s for future compatibility. Read is undefined.                                                                                                           | R    | 0x0000 |
| 15:8  | SR2_WTCNT_VALUE | This value times 8 is used to set the ABB LDO settling time to switch from the bypass mode to a Body-Bias mode.<br>0x0: No wait-cycles are inserted.            | RW   | 0x00   |
| 7:3   | RESERVED        | Write 0s for future compatibility. Read is undefined.                                                                                                           | R    | 0x00   |
| 2     | ACTIVE_FBB_SEL  | Defines the ABB LDO mode when the voltage (VDD1) is in fast OPP (OPP1G).<br>0x0: ABB LDO will operate in bypass mode.<br>0x1: ABB LDO will operate in FBB mode. | RW   | 0x0    |

| Bits | Field Name | Description                                                                                                                                                                 | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | RESERVED   | Write 0s for future compatibility. Read is undefined.                                                                                                                       | R    | 0X0   |
| 0    | SR2EN      | Enables the ABB LDO.<br><br>0x0: ABB LDO is in bypass mode.<br><br>0x1: ABB LDO will operate in FBB mode or bypass mode accordingly to the other SW settings and HW events. | RW   | 0x0   |

**Table 3-503. Register Call Summary for Register PRM\_LDO\_ABB\_CTRL**

PRCM Functional Description

- [Analog Cells, LDOs, and Level Shifter Controls: \[0\]](#)

PRCM Register Manual

- [Global\\_Reg\\_PRM Registers: \[1\]](#)

### 3.7.2.14 NEON\_PRM Registers

#### 3.7.2.14.1 NEON\_PRM Register Summary

**Table 3-504. NEON\_PRM Register Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|-------------------|------|-----------------------|----------------|------------------|------------|
| RM_RSTST_NEON     | RW   | 32                    | 0x0000 0058    | 0x4830 7358      | C          |
| PM_WKDEP_NEON     | RW   | 32                    | 0x0000 00C8    | 0x4830 73C8      | W          |
| PM_PWSTCTRL_NEON  | RW   | 32                    | 0x0000 00E0    | 0x4830 73E0      | W          |
| PM_PWSTST_NEON    | R    | 32                    | 0x0000 00E4    | 0x4830 73E4      | C          |
| PM_PREPWSTST_NEON | RW   | 32                    | 0x0000 00E8    | 0x4830 73E8      | C          |

#### 3.7.2.14.2 NEON\_PRM Registers

**Table 3-505. RM\_RSTST\_NEON**

|                |                                                                                                                                                          |                  |             |          |          |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------|----------|----------|
| Address Offset | 0x0000 0058                                                                                                                                              | Physical Address | 0x4830 7358 | Instance | NEON_PRM |
| Description    | This register logs the different reset sources of the NEON domain. Each bit is set upon release of the domain reset signal. Must be cleared by software. |                  |             |          |          |
| Type           | RW                                                                                                                                                       |                  |             |          |          |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                    |   |                |   |                |   |                |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------------------|---|----------------|---|----------------|---|----------------|--|
| 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              |  |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | COREDOMAINWKUP_RST |   | DOMAINWKUP_RST |   | GLOBALWARM_RST |   | GLOBALCOLD_RST |  |

| Bits | Field Name         | Description                                                                                                                                                                                                                                                             | Type | Reset      |
|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:4 | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                      | R    | 0x00000000 |
| 3    | COREDOMAINWKUP_RST | <p>CORE domain wake-up reset</p> <p>Read 0x0: No power domain wake-up reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: NEON domain has been reset following a CORE power domain wake-up from OFF to ON.</p> <p>Write 0x1: Status bit is cleared to 0.</p> | RW   | 0x0        |
| 2    | DOMAINWKUP_RST     | <p>Power domain wake-up reset</p> <p>Read 0x0: No power domain wake-up reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: NEON domain has been reset following a NEON power domain wake-up.</p> <p>Write 0x1: Status bit is cleared to 0.</p>               | RW   | 0x0        |
| 1    | GLOBALWARM_RST     | <p>Global warm reset</p> <p>Read 0x0: No global warm reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: NEON domain has been reset upon a global warm reset</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                               | RW   | 0x0        |
| 0    | GLOBALCOLD_RST     | <p>Global cold reset</p> <p>Read 0x0: No global cold reset.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: NEON domain has been reset upon a global cold reset</p> <p>Write 0x1: Status bit is cleared to 0.</p>                                               | RW   | 0x1        |

**Table 3-506. Register Call Summary for Register RM\_RSTST\_NEON**

- PRCM Basic Programming Model

- Reset Control: [0]

- PRCM Register Manual

- NEON\_PRM Registers: [1]

**Table 3-507. PM WKDEP NEON**

| Bits | Field Name | Description                                                                                                                                      | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                               | R    | 0x00000000 |
| 1    | EN_MPU     | MPU domain dependency<br><br>0x0: NEON domain is independent of MPU domain wake-up.<br><br>0x1: NEON domain is woken-up upon MPU domain wake-up. | RW   | 0x1        |
| 0    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                               | R    | 0x0        |

**Table 3-508. Register Call Summary for Register PM\_WKDEP\_NEON**

PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#)

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[1\]](#)

PRCM Register Manual

- [NEON\\_PRM Registers: \[2\]](#)

**Table 3-509. PM\_PWSTCTRL\_NEON**

|                         |                                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |          |    |    |    |               |            |   |   |   |   |   |   |   |   |   |
|-------------------------|----------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----------|----|----|----|---------------|------------|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 00E0                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |          |    |    |    |               |            |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | <a href="#">0x4830 73E0</a>                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b> | NEON_PRM |    |    |    |               |            |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | This register controls the NEON domain power state transition. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |          |    |    |    |               |            |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |          |    |    |    |               |            |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |          |    |    |    | LOGICRETSTATE | POWERSTATE |   |   |   |   |   |   |   |   |   |

| Bits | Field Name    | Description                                                                                                     | Type | Reset      |
|------|---------------|-----------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                              | R    | 0x00000000 |
| 2    | LOGICRETSTATE | Logic state when RETENTION<br><br>0x1: Logic is always retained when domain is in RETENTION state.              | R    | 0x1        |
| 1:0  | POWERSTATE    | Power state control<br><br>0x0: OFF state<br><br>0x1: RETENTION state<br><br>0x2: Reserved<br><br>0x3: ON state | RW   | 0x3        |

**Table 3-510. Register Call Summary for Register PM\_PWSTCTRL\_NEON**

PRCM Basic Programming Model

- [PM\\_PWSTCTRL\\_domain\\_name \(Power State Control Register\): \[0\]](#)

PRCM Register Manual

- [NEON\\_PRM Registers: \[1\]](#)

**Table 3-511. PM\_PWSTST\_NEON**

|                         |                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00E4                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 73E4                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register provides a status on the power state transition of the NEON domain. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



| Bits  | Field Name     | Description                                                                                                                                             | Type | Reset   |
|-------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:21 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                      | R    | 0x000   |
| 20    | INTRANSITION   | Domain transition status<br>0x0: No transition<br>0x1: NEON power domain transition is in progress.                                                     | R    | 0x0     |
| 19:2  | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                      | R    | 0x00000 |
| 1:0   | POWERSTATETEST | Current power state status<br>0x0: Power domain is OFF<br>0x1: Power domain is in RETENTION<br>0x2: Power domain is INACTIVE<br>0x3: Power domain is ON | R    | 0x3     |

**Table 3-512. Register Call Summary for Register PM\_PWSTST\_NEON**

PRCM Basic Programming Model

- [PM\\_PWSTST\\_domain\\_name \(Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [NEON\\_PRM Registers: \[1\]](#)

**Table 3-513. PM\_PREPWSTST\_NEON**

|                         |                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00E8                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 73E8                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register provides a status on the NEON domain previous power state. It indicates the state entered during the last sleep transition. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



| Bits | Field Name            | Description                                                                                                                                                                                           | Type | Reset      |
|------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                    | R    | 0x00000000 |
| 1:0  | LASTPOWERSTATEENTERED | Last power state entered<br><br>0x0: NEON domain was previously OFF<br>0x1: NEON domain was previously in RETENTION<br>0x2: NEON domain was previously INACTIVE<br>0x3: NEON domain was previously ON | RW   | 0x0        |

**Table 3-514. Register Call Summary for Register PM\_PREPWSTST\_NEON**

PRCM Basic Programming Model

- [PM\\_PREPWSTST\\_domain\\_name \(Previous Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [NEON\\_PRM Registers: \[1\]](#)

### 3.7.2.15 USBHOST\_PRM Registers

#### 3.7.2.15.1 USBHOST\_PRM Register Summary

**Table 3-515. USBHOST\_PRM Register Summary**

| Register Name         | Type | Register Width (Bits) | Address Offset | Physical Address | Reset Type |
|-----------------------|------|-----------------------|----------------|------------------|------------|
| RM_RSTST_USBHOST      | RW   | 32                    | 0x0000 0058    | 0x4830 7458      | C          |
| PM_WKEN_USBHOST       | RW   | 32                    | 0x0000 00A0    | 0x4830 74A0      | W          |
| PM_MPUGRPSEL_USBHOST  | RW   | 32                    | 0x0000 00A4    | 0x4830 74A4      | W          |
| PM_IVA2GRPSEL_USBHOST | RW   | 32                    | 0x0000 00A8    | 0x4830 74A8      | W          |
| PM_WKST_USBHOST       | RW   | 32                    | 0x0000 00B0    | 0x4830 74B0      | W          |
| PM_WKDEP_USBHOST      | RW   | 32                    | 0x0000 00C8    | 0x4830 74C8      | W          |
| PM_PWSTCTRL_USBHOST   | RW   | 32                    | 0x0000 00E0    | 0x4830 74E0      | W          |
| PM_PWSTST_USBHOST     | R    | 32                    | 0x0000 00E4    | 0x4830 74E4      | C          |
| PM_PREPWSTST_USBHOST  | RW   | 32                    | 0x0000 00E8    | 0x4830 74E8      | C          |

#### 3.7.2.15.2 USBHOST\_PRM Registers

**Table 3-516. RM\_RSTST\_USBHOST**

|                       |                                                                                                                                                              |                         |             |                 |             |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 0058                                                                                                                                                  | <b>Physical Address</b> | 0x4830 7458 | <b>Instance</b> | USBHOST_PRM |
| <b>Description</b>    | This register logs the different reset sources of the USB HOST domain. Each bit is set upon release of the domain reset signal. Must be cleared by software. |                         |             |                 |             |
| <b>Type</b>           | RW                                                                                                                                                           |                         |             |                 |             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name         | Description                                                                                                                                                                                                                                                      | Type | Reset      |
|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:4 | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                               | R    | 0x00000000 |
| 3    | COREDOMAINWKUP_RST | CORE domain wake-up reset<br><br>Read 0x0: No power domain wake-up reset.<br>Write 0x0: Status bit unchanged<br><br>Read 0x1: USB HOST domain has been reset following a CORE power domain wake-up from OFF to ON.<br><br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0        |
| 2    | DOMAINWKUP_RST     | Power domain wake-up reset<br><br>Read 0x0: No power domain wake-up reset.<br>Write 0x0: Status bit unchanged<br><br>Read 0x1: USB HOST domain has been reset following an USB HOST power domain wake-up.<br><br>Write 0x1: Status bit is cleared to 0.          | RW   | 0x0        |
| 1    | GLOBALWARM_RST     | Global warm reset<br><br>Read 0x0: No global warm reset.<br>Write 0x0: Status bit unchanged<br><br>Read 0x1: USB HOST domain has been reset upon a global warm reset<br><br>Write 0x1: Status bit is cleared to 0.                                               | RW   | 0x0        |
| 0    | GLOBALCOLD_RST     | Global cold reset<br><br>Read 0x0: No global cold reset.<br>Write 0x0: Status bit unchanged<br><br>Read 0x1: USB HOST domain has been reset upon a global cold reset<br><br>Write 0x1: Status bit is cleared to 0.                                               | RW   | 0x1        |

**Table 3-517. Register Call Summary for Register RM\_RSTST\_USBHOST**

PRCM Basic Programming Model

- [Reset Control: \[0\]](#)

PRCM Register Manual

- [USBHOST\\_PRM Registers: \[1\]](#)

**Table 3-518. PM\_WKEN\_USBHOST**

|                  |                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------|-----------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Address Offset   | 0x0000 00A0                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Physical Address | 0x4830 74A0                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Description      | This register allows enabling/disabling modules wake-up events. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type             | RW                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED         |                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EN_USBHOST |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                         | R    | 0x00000000 |
| 0    | EN_USBHOST | USB HOST Wake-up enable<br><br>0x0: USB HOST wake-up is disabled<br>0x1: USB HOST wake-up event is enabled | RW   | 0x1        |

**Table 3-519. Register Call Summary for Register PM\_WKEN\_USBHOST**


---

 PRCM Functional Description

- [Device Wake-Up Events: \[0\]](#)
- 

## PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[1\]](#)
- 

## PRCM Register Manual

- [USBHOST\\_PRM Registers: \[2\]](#)
- 

**Table 3-520. PM\_MPUGRPSEL\_USBHOST**

|                         |                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00A4                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | USBHOST_PRM |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 74A4                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 | USBHOST_PRM |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register allows selecting the group of modules that wake-up the MPU. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name     | Description                                                                                                                                                                              | Type | Reset      |
|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                       | R    | 0x00000000 |
| 0    | GRPSEL_USBHOST | Select the USBHOST in the MPU wake-up events group<br><br>0x0: USBHOST is not attached to the MPU wake-up events group.<br><br>0x1: USBHOST is attached to the MPU wake-up events group. | RW   | 0x1        |

**Table 3-521. Register Call Summary for Register PM\_MPUGRPSEL\_USBHOST**


---

 PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[0\]](#)
- 

## PRCM Register Manual

- [USBHOST\\_PRM Registers: \[1\]](#)
- 

**Table 3-522. PM\_IVA2GRPSEL\_USBHOST**

|                         |                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00A8                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | USBHOST_PRM |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 74A8                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 | USBHOST_PRM |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register allows selecting the group of modules that wake-up the IVA2. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name     | Description                                                                                                                                                                                 | Type | Reset      |
|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                          | R    | 0x00000000 |
| 0    | GRPSEL_USBHOST | Select the USBHOST in the IVA2 wake-up events group<br><br>0x0: USBHOST is not attached to the IVA2 wake-up events group.<br><br>0x1: USBHOST is attached to the IVA2 wake-up events group. | RW   | 0x1        |

**Table 3-523. Register Call Summary for Register PM\_IVA2GRPSEL\_USBHOST**

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[0\]](#)

PRCM Register Manual

- [USBHOST\\_PRM Registers: \[1\]](#)

**Table 3-524. PM\_WKST\_USBHOST**

|                         |                                                                                                                                     |                       |                 |             |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|-------------|
| Address Offset          | 0x0000 00B0                                                                                                                         |                       | Instance        | USBHOST_PRM |
| Physical Address        | 0x4830 74B0                                                                                                                         |                       |                 |             |
| Description             | This register logs module wake-up events. Must be cleared by software. If it is not cleared, it prevents further domain transition. |                       |                 |             |
| Type                    | RW                                                                                                                                  |                       |                 |             |
| 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 | ST_USBHOST  |
| RESERVED                |                                                                                                                                     |                       |                 |             |

| Bits | Field Name | Description                                                                                                                                                                                                             | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                      | R    | 0x00000000 |
| 0    | ST_USBHOST | USB HOST Wake-up status<br><br>Read 0x0: USB HOST wake-up did not occur or was masked.<br><br>Write 0x0: Status bit unchanged<br><br>Read 0x1: USB HOST wake-up occurred.<br><br>Write 0x1: Status bit is cleared to 0. | RW   | 0x0        |

**Table 3-525. Register Call Summary for Register PM\_WKST\_USBHOST**

PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[0\]](#)

PRCM Register Manual

- [USBHOST\\_PRM Registers: \[1\]](#)

**Table 3-526. PM\_WKDEP\_USBHOST**

| <b>Address Offset</b>   | 0x0000 00C8                                                                                               | <b>Physical Address</b>                                                                                                                                                   | 0x4830 74C8     | <b>Instance</b> | USBHOST_PRM                                        |
|-------------------------|-----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|----------------------------------------------------|
| <b>Description</b>      | This register allows enabling or disabling the wake-up of the USB HOST domain upon another domain wakeup. |                                                                                                                                                                           |                 |                 |                                                    |
| <b>Type</b>             | RW                                                                                                        |                                                                                                                                                                           |                 |                 |                                                    |
| 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 |                 |                                                    |
| RESERVED                |                                                                                                           |                                                                                                                                                                           |                 |                 | EN_WKUP<br>RESERVED<br>EN_IVA2<br>EN_MP<br>EN_CORE |
| Bits                    | Field Name                                                                                                | Description                                                                                                                                                               | Type            | Reset           |                                                    |
| 31:5                    | RESERVED                                                                                                  | Write 0s for future compatibility. Read returns 0.                                                                                                                        | R               | 0x0000000       |                                                    |
| 4                       | EN_WKUP                                                                                                   | WAKEUP domain dependency<br><br>0x0: USB HOST domain is independent of WKUP domain wake-up event.<br><br>0x1: USB HOST domain is woken-up upon WKUP domain wake-up event. | RW              | 0x1             |                                                    |
| 3                       | RESERVED                                                                                                  | Write 0s for future compatibility. Read returns 0.                                                                                                                        | R               | 0x0             |                                                    |
| 2                       | EN_IVA2                                                                                                   | IVA2 domain dependency<br><br>0x0: USB HOST domain is independent of IVA2 domain wake-up event.<br><br>0x1: USB HOST domain is woken-up upon IVA2 domain wake-up event.   | RW              | 0x1             |                                                    |
| 1                       | EN_MP                                                                                                     | MPU domain dependency<br><br>0x0: USB HOST domain is independent of MPU domain wake-up.<br><br>0x1: USB HOST domain is woken-up upon MPU domain wake-up.                  | RW              | 0x1             |                                                    |
| 0                       | EN_CORE                                                                                                   | CORE domain dependency<br><br>0x0: USB HOST domain is independent of CORE domain wake-up.<br><br>0x1: USB HOST domain is woken-up upon CORE domain wake-up.               | RW              | 0x1             |                                                    |

**Table 3-527. Register Call Summary for Register PM\_WKDEP\_USBHOST**

## PRCM Functional Description

- [Device Wake-Up Events: \[0\] \[1\] \[2\] \[3\]](#)

## PRCM Basic Programming Model

- [Domain Wake-Up Control Registers: \[4\]](#)

## PRCM Register Manual

- [USBHOST\\_PRM Registers: \[5\]](#)

**Table 3-528. PM\_PWSTCTRL\_USBHOST**

|                       |                                                                    |                         |             |                 |             |
|-----------------------|--------------------------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 00E0                                                        | <b>Physical Address</b> | 0x4830 74E0 | <b>Instance</b> | USBHOST_PRM |
| <b>Description</b>    | This register controls the USB HOST domain power state transition. |                         |             |                 |             |
| <b>Type</b>           | RW                                                                 |                         |             |                 |             |

  

|          |    |    |    |    |    |    |    |            |          |    |    |    |    |    |    |    |             |          |                |          |               |            |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|------------|----------|----|----|----|----|----|----|----|-------------|----------|----------------|----------|---------------|------------|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    | MEMONSTATE | RESERVED |    |    |    |    |    |    |    | MEMRETSTATE | RESERVED | SAVEANDRESTORE | RESERVED | LOGICRETSTATE | POWERSTATE |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name     | Description                                                                                                                                                                                     | Type | Reset  |
|-------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:18 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                              | R    | 0x0000 |
| 17:16 | MEMONSTATE     | Memory state when ON<br>0x3: Memory is always ON when domain is ON.                                                                                                                             | R    | 0x3    |
| 15:9  | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                              | R    | 0x00   |
| 8     | MEMRETSTATE    | Memory state when RETENTION<br>0x1: Memory is always retained when domain is in RETENTION state.                                                                                                | R    | 0x1    |
| 7:5   | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                              | R    | 0x0    |
| 4     | SAVEANDRESTORE | Save And Restore mechanism for the USB HOST module<br>0x0: Disable the save and restore mechanism for the USB HOST module<br>0x1: Enable the save and restore mechanism for the USB HOST module | RW   | 0x0    |
| 3     | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                              | R    | 0x0    |
| 2     | LOGICRETSTATE  | Logic state when RETENTION<br>0x1: Logic is always retained when domain is in RETENTION state.                                                                                                  | R    | 0x1    |
| 1:0   | POWERSTATE     | Power state control<br>0x0: OFF state<br>0x1: RETENTION state<br>0x2: Reserved<br>0x3: ON state                                                                                                 | RW   | 0x3    |

**Table 3-529. Register Call Summary for Register PM\_PWSTCTRL\_USBHOST**

## PRCM Functional Description

- [Clock Distribution: \[0\]](#)
- [Internal Clock Controls: \[1\]](#)
- [USBHOST/USBTLL Save-and-Restore Management: \[2\] \[3\] \[4\] \[5\]](#)

## PRCM Basic Programming Model

- [PM\\_PWSTCTRL\\_domain\\_name \(Power State Control Register\): \[6\]](#)

## PRCM Register Manual

- [USBHOST\\_PRM Registers: \[7\]](#)

**Table 3-530. PM\_PWSTST\_USBHOST**

|                         |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00E4                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4830 74E4                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register provides a status on the power state transition of the USB HOST domain. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



| Bits  | Field Name     | Description                                                                                                                                             | Type | Reset   |
|-------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:21 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                      | R    | 0x000   |
| 20    | INTRANSITION   | Domain transition status<br>0x0: No transition<br>0x1: USB HOST power domain transition is in progress.                                                 | R    | 0x0     |
| 19:2  | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                      | R    | 0x00000 |
| 1:0   | POWERSTATETEST | Current power state status<br>0x0: Power domain is OFF<br>0x1: Power domain is in RETENTION<br>0x2: Power domain is INACTIVE<br>0x3: Power domain is ON | R    | 0x3     |

**Table 3-531. Register Call Summary for Register PM\_PWSTST\_USBHOST**

PRCM Basic Programming Model

- [PM\\_PWSTST\\_domain\\_name \(Power State Status Register\): \[0\]](#)

PRCM Register Manual

- [USBHOST\\_PRM Registers: \[1\]](#)

**Table 3-532. PM\_PREPWSTST\_USBHOST**

|                         |                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |                       |   |   |   |   |   |   |   |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|-----------------------|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 00E8                                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |                       |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x4830 74E8                                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |                       |   |   |   |   |   |   |   |
| <b>Description</b>      | This register provides a status on the USBHOST domain previous power state. It indicates the state entered during the last sleep transition. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |                       |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                                                                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |                       |   |   |   |   |   |   |   |
| 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 |
|                         |                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |   |   | LASTPOWERSTATEENTERED |   |   |   |   |   |   |   |

| Bits | Field Name            | Description                                                                                                                                                                                                           | Type | Reset      |
|------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                    | R    | 0x00000000 |
| 1:0  | LASTPOWERSTATEENTERED | Last power state entered<br><br>0x0: USB HOST domain was previously OFF<br>0x1: USB HOST domain was previously in RETENTION<br>0x2: USB HOST domain was previously INACTIVE<br>0x3: USB HOST domain was previously ON | RW   | 0x0        |

**Table 3-533. Register Call Summary for Register PM\_PREPWSTST\_USBHOST**

PRCM Register Manual

- [USBHOST\\_PRM Registers: \[0\]](#)

### 3.7.3 SR Registers

#### 3.7.3.1 SR Instance Summary

**Table 3-534. SR Instance Summary**

| Module Name | Base address (hex) | Size     |
|-------------|--------------------|----------|
| SR1         | 0x480C 9000        | 4K bytes |
| SR2         | 0x480C B000        | 4K bytes |

#### 3.7.3.2 SR Registers

##### 3.7.3.2.1 SR Register Summary

**Table 3-535. SR Register Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | SR1 Physical Address | SR2 Physical Address |
|------------------|------|-----------------------|----------------|----------------------|----------------------|
| SRCONFIG         | RW   | 32                    | 0x0000 0000    | 0x480C 9000          | 0x480C B000          |
| SRSTATUS         | R    | 32                    | 0x0000 0004    | 0x480C 9004          | 0x480C B004          |
| SENVAL           | R    | 32                    | 0x0000 0008    | 0x480C 9008          | 0x480C B008          |
| SENMIN           | R    | 32                    | 0x0000 000C    | 0x480C 900C          | 0x480C B00C          |
| SENMAX           | R    | 32                    | 0x0000 0010    | 0x480C 9010          | 0x480C B010          |
| SENAVG           | R    | 32                    | 0x0000 0014    | 0x480C 9014          | 0x480C B014          |
| AVGWEIGHT        | RW   | 32                    | 0x0000 0018    | 0x480C 9018          | 0x480C B018          |
| NVALUERECIPROCAL | RW   | 32                    | 0x0000 001C    | 0x480C 901C          | 0x480C B01C          |
| RESERVED         | W    | 32                    | 0x0000 0020    | 0x480C 9020          | 0x480C B020          |
| IRQSTATUS_RAW    | RW   | 32                    | 0x0000 0024    | 0x480C 9024          | 0x480C B024          |
| IRQSTATUS        | RW   | 32                    | 0x0000 0028    | 0x480C 9028          | 0x480C B028          |
| IRQENABLE_SET    | RW   | 32                    | 0x0000 002C    | 0x480C 902C          | 0x480C B02C          |
| IRQENABLE_CLR    | RW   | 32                    | 0x0000 0030    | 0x480C 9030          | 0x480C B030          |
| SENEROR_REG      | R    | 32                    | 0x0000 0034    | 0x480C 9034          | 0x480C B034          |
| ERRCONFIG        | RW   | 32                    | 0x0000 0038    | 0x480C 9038          | 0x480C B038          |

##### 3.7.3.2.2 SR Registers

**Table 3-536. SRCONFIG**

|                         |                                                                                      |                 |                   |  |  |
|-------------------------|--------------------------------------------------------------------------------------|-----------------|-------------------|--|--|
| <b>Address Offset</b>   | 0x0000 0000                                                                          | <b>Instance</b> | SR1<br>SR2<br>SR2 |  |  |
| <b>Physical Address</b> | 0x480C 9000<br>0x480C B000<br>0x480C B000                                            |                 |                   |  |  |
| <b>Description</b>      | This register contains configuration bits for the sensor core and digital processing |                 |                   |  |  |
| <b>Type</b>             | RW                                                                                   |                 |                   |  |  |



| Bits  | Field Name           | Description                                                                                                                                                                                                                                              | Type | Reset |
|-------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:22 | ACCUMDATA            | Number of values to accumulate                                                                                                                                                                                                                           | RW   | 0x080 |
| 21:12 | SRCLKLENGTH          | Determines the frequency of SRCIk                                                                                                                                                                                                                        | RW   | 0x200 |
| 11    | SRENABLE             | 0x0: Asynchronously resets MinMaxAvgAccumValid, MinMaxAvgValid, ErrorGeneratorValid, AccumData sensor, SRCIk counter, and MinMaxAvg registers. Also gates the clock for power savings and disables all the digital logic.<br><br>0x1: Enables the module | RW   | 0x0   |
| 10    | SENENABLE            | Sensor module enable<br><br>0x0: Disable all sensors<br><br>0x1: Enable sensors                                                                                                                                                                          | RW   | 0x1   |
| 9     | ERRORGENERATORENABLE | Error generator module enable<br><br>0x0: Disable error generator module<br><br>0x1: Enable error generator module                                                                                                                                       | RW   | 0x0   |
| 8     | MINMAXAVGENABLE      | Min/Max/Avg detector module enable<br><br>0x0: Disable min max avg detector module<br><br>0x1: Enable min max avg detector module                                                                                                                        | RW   | 0x0   |
| 7:2   | RESERVED             | Reserved                                                                                                                                                                                                                                                 | RW   | 0x00  |
| 1     | SENNENABLE           | Enable/disable SenN sensor<br><br>0x0: Disable SenN sensor<br><br>0x1: Enable SenN sensor                                                                                                                                                                | RW   | 0x1   |
| 0     | SENPNABLE            | Enable/disable SenP sensor<br><br>0x0: Disable SenP sensor<br><br>0x1: Enable SenP sensor                                                                                                                                                                | RW   | 0x0   |

**Table 3-537. Register Call Summary for Register SRCONFIG**
**PRCM Functional Description**

- [VDD1 and VDD2 Control: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\]](#)

**PRCM Basic Programming Model**

- [SmartReflex Module Initialization Basic Programming Model: \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\]](#)
- [Changing OPP Using the SmartReflex Module: \[19\] \[20\] \[21\]](#)
- [Changing OPP Using Only the Voltage Processor Module: \[22\]](#)

**Table 3-537. Register Call Summary for Register SRCONFIG (continued)**

---

PRCM Register Manual

- SR Registers: [43]

**Table 3-538. SRSTATUS**

|                         |                                                                                                                    |                 |            |
|-------------------------|--------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0004                                                                                                        |                 |            |
| <b>Physical Address</b> | 0x480C 9004<br>0x480C B004                                                                                         | <b>Instance</b> | SR1<br>SR2 |
|                         | 0x480C B004                                                                                                        |                 | SR2        |
| <b>Description</b>      | This register contains status bits that indicate that the values in the register are valid or events have occurred |                 |            |
| <b>Type</b>             | R                                                                                                                  |                 |            |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |             |                |                      |                     |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------|----------------|----------------------|---------------------|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | AVGERRVALID | MINMAXAVGVALID | ERRORGGENERATORVALID | MINMAXAVGACCUMVALID |   |   |   |

| Bits | Field Name          | Description                                                                                                                           | Type | Reset      |
|------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:4 | RESERVED            |                                                                                                                                       | R    | 0x00000000 |
| 3    | AVGERRVALID         | 0x0: SenAvg register are not valid<br>0x1: SenAvg register are valid                                                                  | R    | 0x0        |
| 2    | MINMAXAVGVALID      | 0x0: SenVal, SenMin, SenMax, SenAvg registers are not valid<br>0x1: SenVal, SenMin, SenMax, SenAvg registers are valid                | R    | 0x0        |
| 1    | ERRORGENERATORVALID | 0x0: SenErr register do not have valid data<br>0x1: SenErr register have valid data                                                   | R    | 0x0        |
| 0    | MINMAXAVGACCUMVALID | 0x0: SenVal, SenMin, SenMax, SenAvg registers do not have final data<br>0x1: SenVal, SenMin, SenMax, SenAvg registers have final data | R    | 0x0        |

**Table 3-539. Register Call Summary for Register SRSTATUS**

PRCM Functional Description

- VDD1 and VDD2 Control: [0] [1] [2] [3] [4] [5] [6]

PRCM Register Manual

- SR Registers: [7]

**Table 3-540. SENVAL**

|                         |                                                          |                 |                   |
|-------------------------|----------------------------------------------------------|-----------------|-------------------|
| <b>Address Offset</b>   | 0x0000 0008                                              | <b>Instance</b> | SR1<br>SR2<br>SR2 |
| <b>Physical Address</b> | 0x480C 9008<br>0x480C B008<br>0x480C B008                |                 |                   |
| <b>Description</b>      | This register gives the sensor value for the sensor core |                 |                   |
| <b>Type</b>             | R                                                        |                 |                   |

|                                                                                             |         |
|---------------------------------------------------------------------------------------------|---------|
| 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 |         |
| SENPVAL                                                                                     | SENNVAL |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                    | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------|-------------|--------------|
| 31:16       | SENPVAL           | Latest Value of SenP from sensor Core | R           | 0x0000       |
| 15:0        | SENNVAL           | Latest Value of SenN from Sensor Core | R           | 0x0000       |

**Table 3-541. Register Call Summary for Register SENVAL**

PRCM Functional Description

- [VDD1 and VDD2 Control: \[0\] \[1\] \[2\] \[3\]](#)

PRCM Register Manual

- [SR Registers: \[4\]](#)

**Table 3-542. SENMIN**

|                         |                                              |                 |                   |
|-------------------------|----------------------------------------------|-----------------|-------------------|
| <b>Address Offset</b>   | 0x0000 000C                                  | <b>Instance</b> | SR1<br>SR2<br>SR2 |
| <b>Physical Address</b> | 0x480C 900C<br>0x480C B00C<br>0x480C B00C    |                 |                   |
| <b>Description</b>      | This register gives the minimum sensor value |                 |                   |
| <b>Type</b>             | R                                            |                 |                   |

|                                                                                             |         |
|---------------------------------------------------------------------------------------------|---------|
| 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 |         |
| SENPMIN                                                                                     | SENNMIN |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>    | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------|-------------|--------------|
| 31:16       | SENPMIN           | Minimum value of SenP | R           | 0xFFFF       |
| 15:0        | SENNMIN           | Minimum value of SenN | R           | 0xFFFF       |

**Table 3-543. Register Call Summary for Register SENMIN**

PRCM Functional Description

- [VDD1 and VDD2 Control: \[0\] \[1\] \[2\] \[3\]](#)

PRCM Register Manual

- [SR Registers: \[4\]](#)

**Table 3-544. SENMAX**

|                         |                                             |                 |                   |
|-------------------------|---------------------------------------------|-----------------|-------------------|
| <b>Address Offset</b>   | 0x0000 0010                                 |                 |                   |
| <b>Physical Address</b> | 0x480C 9010<br>0x480C B010<br>0x480C B010   | <b>Instance</b> | SR1<br>SR2<br>SR2 |
| <b>Description</b>      | This register give the maximum sensor value |                 |                   |
| <b>Type</b>             | R                                           |                 |                   |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| SENPMAX                 |                         |                       | SENNMAX         |

| Bits  | Field Name | Description           | Type | Reset  |
|-------|------------|-----------------------|------|--------|
| 31:16 | SENPMAX    | Maximum Value of SenP | R    | 0x0000 |
| 15:0  | SENNMAX    | Maximum value of SenN | R    | 0x0000 |

**Table 3-545. Register Call Summary for Register SENMAX**

PRCM Functional Description

- [VDD1 and VDD2 Control: \[0\] \[1\] \[2\] \[3\]](#)

PRCM Register Manual

- [SR Registers: \[4\]](#)

**Table 3-546. SENAvg**

|                         |                                               |                 |                   |
|-------------------------|-----------------------------------------------|-----------------|-------------------|
| <b>Address Offset</b>   | 0x0000 0014                                   |                 |                   |
| <b>Physical Address</b> | 0x480C 9014<br>0x480C B014<br>0x480C B014     | <b>Instance</b> | SR1<br>SR2<br>SR2 |
| <b>Description</b>      | This register gives the average sensor values |                 |                   |
| <b>Type</b>             | R                                             |                 |                   |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| SENPAVG                 |                         |                       | SENNAVG         |

| Bits  | Field Name | Description                        | Type | Reset  |
|-------|------------|------------------------------------|------|--------|
| 31:16 | SENPAVG    | Running average of the SenP values | R    | 0x0000 |
| 15:0  | SENNAVG    | Running average of the SenN values | R    | 0x0000 |

**Table 3-547. Register Call Summary for Register SENAvg**

PRCM Functional Description

- [VDD1 and VDD2 Control: \[0\] \[1\] \[2\] \[3\]](#)

PRCM Register Manual

- [SR Registers: \[4\]](#)

**Table 3-548. AVGWEIGHT**

|                         |                                                                    |                       |                   |
|-------------------------|--------------------------------------------------------------------|-----------------------|-------------------|
| <b>Address Offset</b>   | 0x0000 0018                                                        |                       |                   |
| <b>Physical Address</b> | 0x480C 9018<br>0x480C B018<br>0x480C B018                          | <b>Instance</b>       | SR1<br>SR2<br>SR2 |
| <b>Description</b>      | This register gives the weighing factor in the average computation |                       |                   |
| <b>Type</b>             | RW                                                                 |                       |                   |
| 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   |
| RESERVED                |                                                                    |                       | SENPAVGWEIGHT     |
| SENNAVGWEIGHT           |                                                                    |                       |                   |

| Bits | Field Name    | Description                                | Type | Reset      |
|------|---------------|--------------------------------------------|------|------------|
| 31:4 | RESERVED      | Reserved bits                              | R    | 0x00000000 |
| 3:2  | SENPAVGWEIGHT | The weighting factor for the SenP Averager | RW   | 0x0        |
| 1:0  | SENNAVGWEIGHT | The weighting factor for the SenN Averager | RW   | 0x0        |

**Table 3-549. Register Call Summary for Register AVGWEIGHT**

## PRCM Functional Description

- [VDD1 and VDD2 Control: \[0\] \[1\] \[2\] \[3\]](#)

## PRCM Basic Programming Model

- [SmartReflex Module Initialization Basic Programming Model: \[4\] \[5\] \[6\] \[7\]](#)

## PRCM Register Manual

- [SR Registers: \[12\]](#)

**Table 3-550. NVALUERECIPROCAL**

|                         |                                                                                               |                       |                   |
|-------------------------|-----------------------------------------------------------------------------------------------|-----------------------|-------------------|
| <b>Address Offset</b>   | 0x0000 001C                                                                                   |                       |                   |
| <b>Physical Address</b> | 0x480C 901C<br>0x480C B01C<br>0x480C B01C                                                     | <b>Instance</b>       | SR1<br>SR2<br>SR2 |
| <b>Description</b>      | This Register contain the reciprocal of the SenN and SenP values used in the error generation |                       |                   |
| <b>Type</b>             | RW                                                                                            |                       |                   |
| 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   |
| RESERVED                |                                                                                               | SENPGAIN              | SENNGAIN          |
|                         |                                                                                               | RNSENP                |                   |
|                         |                                                                                               | RNSENN                |                   |

| Bits  | Field Name | Description                                     | Type | Reset |
|-------|------------|-------------------------------------------------|------|-------|
| 31:24 | RESERVED   | Reserved                                        | R    | 0x00  |
| 23:20 | SENPGAIN   | Gain Value Of reciprocal SenP                   | RW   | 0x0   |
| 19:16 | SENNGAIN   | Gain Value of reciprocal SenN                   | RW   | 0x0   |
| 15:8  | RNSENP     | The Scale value of the SenP RN reciprocal value | RW   | 0x00  |
| 7:0   | RNSENN     | The Scale value of the SenN RN reciprocal value | RW   | 0x00  |

**Table 3-551. Register Call Summary for Register NVALUERECIPROCAL**

## PRCM Functional Description

- [VDD1 and VDD2 Control: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\]](#)

## PRCM Basic Programming Model

- [SmartReflex Module Initialization Basic Programming Model: \[8\] \[9\] \[10\] \[11\]](#)
- [Changing OPP Using the SmartReflex Module: \[12\] \[13\] \[14\] \[15\]](#)

## PRCM Register Manual

- [SR Registers: \[36\]](#)

**Table 3-552. IRQSTATUS\_RAW**

|                         |                                  |                         |                            |                                                                                            |            |  |  |
|-------------------------|----------------------------------|-------------------------|----------------------------|--------------------------------------------------------------------------------------------|------------|--|--|
| <b>Address Offset</b>   | 0x0000 0024                      | <b>Physical Address</b> | 0x480C 9024<br>0x480C B024 | <b>Instance</b>                                                                            | SR1<br>SR2 |  |  |
|                         |                                  |                         | 0x480C B024                |                                                                                            | SR2        |  |  |
| <b>Description</b>      | MCU raw interrupt status and set |                         |                            |                                                                                            |            |  |  |
| <b>Type</b>             | RW                               |                         |                            |                                                                                            |            |  |  |
| 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            | MCUACCUMINTSTATRAW<br>MCUVALIDINTSTATRAW<br>MCUBOUNDSINTSTATRAW<br>MCUDISABLEACKINTSTATRAW |            |  |  |
| RESERVED                |                                  |                         |                            |                                                                                            |            |  |  |

| Bits | Field Name              | Description                                                                                  | Type | Reset     |
|------|-------------------------|----------------------------------------------------------------------------------------------|------|-----------|
| 31:4 | RESERVED                | Reserved                                                                                     | R    | 0x0000000 |
| 3    | MCUACCUMINTSTATRAW      | 0: Accum interrupt status is unchanged.<br>1: Accum interrupt status is set .                | RW   | 0         |
| 2    | MCUVALIDINTSTATRAW      | 0: Valid interrupt status is unchanged.<br>1: Valid interrupt status is set.                 | RW   | 0         |
| 1    | MCUBOUNDSINTSTATRAW     | 0: Bounds interrupt status is unchanged.<br>1: Bounds interrupt status is set.               | RW   | 0         |
| 0    | MCUDISABLEACKINTSTATRAW | 0: MCU Disable acknowledge status is unchanged.<br>1: MCU Disable acknowledge status is set. | RW   | 0         |

**Table 3-553. Register Call Summary for Register IRQSTATUS\_RAW**

## PRCM Register Manual

- [SR Registers: \[0\]](#)

**Table 3-554. IRQSTATUS**

|                         |                                       |                 |            |
|-------------------------|---------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0028                           |                 |            |
| <b>Physical Address</b> | 0x480C 9028<br>0x480C B028            | <b>Instance</b> | SR1<br>SR2 |
|                         | 0x480C B028                           |                 | SR2        |
| <b>Description</b>      | MCU masked interrupt status and clear |                 |            |
| <b>Type</b>             | RW                                    |                 |            |

| <b>Bits</b> | <b>Field Name</b>       | <b>Description</b>                                                                                                                                                                                             | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:4        | RESERVED                | Reserved                                                                                                                                                                                                       | R           | 0x00000000   |
| 3           | MCUACCUMINTSTATENA      | Read 0: Accum interrupt status is unchanged.<br>Read 1: Accum interrupt status is set.<br>Write 0: Accum interrupt status is unchanged.<br>Write 1: Accum interrupt status is cleared.                         | RW          | 0            |
| 2           | MCUVALIDINTSTATENA      | Read 0: Valid interrupt status is unchanged.<br>Read 1: Valid interrupt status is set.<br>Write 0: Valid interrupt status is unchanged.<br>Write 1: Valid interrupt status is cleared.                         | RW          | 0            |
| 1           | MCUBOUNDSINTSTATENA     | Read 0: Bounds interrupt status is unchanged.<br>Read 1: Bounds interrupt status is set.<br>Write 0: Bounds interrupt status is unchanged.<br>Write 1: Bounds interrupt status is cleared.                     | RW          | 0            |
| 0           | MCUDISABLEACKINTSTATENA | Read 0: MCUDisable acknowledge status is unchanged.<br>Read 1: MCUDisable acknowledge status is set.<br>Write 0: MCUDisable interrupt status is unchanged.<br>Write 1: MCUDisable interrupt status is cleared. | RW          | 0            |

**Table 3-555. Register Call Summary for Register IRQSTATUS**

PRCM Functional Description

- VDD1 and VDD2 Control: [0] [1] [2] [3] [4]

---

PRCM Register Manual

- SR Registers: [5]

**Table 3-556. IRQENABLE\_SET**

|                         |                                           |                 |                   |
|-------------------------|-------------------------------------------|-----------------|-------------------|
| <b>Address Offset</b>   | 0x0000 002C                               |                 |                   |
| <b>Physical Address</b> | 0x480C 902C<br>0x480C B02C<br>0x480C B02C | <b>Instance</b> | SR1<br>SR2<br>SR2 |
| <b>Description</b>      | MCU interrupt enable flag and set         |                 |                   |
| <b>Type</b>             | RW                                        |                 |                   |



| Bits | Field Name              | Description                                                                                                                                                                                                                                 | Type | Reset     |
|------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:4 | RESERVED                | Reserved                                                                                                                                                                                                                                    | R    | 0x0000000 |
| 3    | MCUACCUMINTENASET       | Read mode:<br>0: Accum interrupt generation is disabled/masked.<br>1: Accum interrupt generation is enabled.<br>Write mode:<br>0: No change to Accum interrupt enable.<br>1: Enable Accum interrupt generation.                             | RW   | 0         |
| 2    | MCUVAILDINTENASET       | Read mode:<br>0: Valid interrupt generation is disabled/masked.<br>1: Valid interrupt generation is enabled.<br>Write mode:<br>0: No change to valid interrupt enable.<br>1: Enable valid interrupt generation.                             | RW   | 0         |
| 1    | MCUBOUNDSINTENASET      | Read mode:<br>0: Bounds interrupt generation is disabled/masked.<br>1: Bounds interrupt generation is enabled.<br>Write mode:<br>0: No change to bounds interrupt enable.<br>1: Enable bounds interrupt generation.                         | RW   | 0         |
| 0    | MCUDISABLEACKINTSTATENA | Read mode:<br>0: MCUDisableAck interrupt generation is disabled/masked.<br>1: MCUDisableAck interrupt generation is enabled.<br>Write mode:<br>0: No change to MCUDisAck interrupt enable.<br>1: Enable MCUDisableAck interrupt generation. | RW   | 0         |

**Table 3-557. Register Call Summary for Register IRQENABLE\_SET**

---

PRCM Functional Description

- [VDD1 and VDD2 Control](#): [0] [1] [2] [3]

PRCM Basic Programming Model

- [SmartReflex Module Initialization Basic Programming Model](#): [4] [5] [6]

---

PRCM Register Manual

- [SR Registers](#): [8]

**Table 3-558. IRQENABLE\_CLR**

|                         |                                     |                 |     |
|-------------------------|-------------------------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 0030                         |                 |     |
| <b>Physical Address</b> | 0x480C 9030                         | <b>Instance</b> | SR1 |
|                         | 0x480C B030                         |                 | SR2 |
|                         | 0x480C B030                         |                 | SR2 |
| <b>Description</b>      | MCU interrupt enable flag and clear |                 |     |
| <b>Type</b>             | RW                                  |                 |     |

| Bits | Field Name             | Description                                                                                                                                                                                                                                     | Type | Reset      |
|------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:4 | RESERVED               | Reserved                                                                                                                                                                                                                                        | R    | 0x00000000 |
| 3    | MCUACCUMINTENACLR      | <p>Read mode:</p> <p>0: Accum interrupt generation is disabled/masked.</p> <p>1: Accum interrupt generation is enabled.</p> <p>Write mode:</p> <p>0: No change to accum interrupt enable.</p> <p>1: Disable accum interrupt generation.</p>     | RW   | 0          |
| 2    | MCUVALIDINTENACLR      | <p>Read mode:</p> <p>0: Valid interrupt generation is disabled/masked.</p> <p>1: Valid interrupt generation is enabled.</p> <p>Write mode:</p> <p>0: No change to valid interrupt enable.</p> <p>1: Disable valid interrupt generation.</p>     | RW   | 0          |
| 1    | MCUBOUNDSINTENACLR     | <p>Read mode:</p> <p>0: Bounds interrupt generation is disabled/masked.</p> <p>1: Bounds interrupt generation is enabled.</p> <p>Write mode:</p> <p>0: No change to bounds interrupt enable.</p> <p>1: Disable bounds interrupt generation.</p> | RW   | 0          |
| 0    | MCUDISABLEACKINTENACLR | Read mode:                                                                                                                                                                                                                                      | RW   | 0          |

| Bits | Field Name | Description                                                                                                                                                                                                                        | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0: MCUDisableAck interrupt generation is disabled/masked.<br>1: MCUDisableAck interrupt generation is enabled.<br><br>Write mode:<br>0: No change to MCUDisAck interrupt enable,<br>1: Disable MCUDisableAck interrupt generation. |      |       |

**Table 3-559. Register Call Summary for Register IRQENABLE\_CLR**

PRCM Register Manual

- [SR Registers: \[0\]](#)

**Table 3-560. SENERROR\_REG**

|                         |                                                               |                 |     |     |
|-------------------------|---------------------------------------------------------------|-----------------|-----|-----|
| <b>Address Offset</b>   | 0x0000 0034                                                   |                 |     |     |
| <b>Physical Address</b> | <a href="#">0x480C 9034</a><br><a href="#">0x480C B034</a>    | <b>Instance</b> | SR1 | SR2 |
|                         | 0x480C B034                                                   |                 | SR2 |     |
| <b>Description</b>      | This register gives the sensor error from the error generator |                 |     |     |
| <b>Type</b>             | R                                                             |                 |     |     |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | AVGERROR |    |    |    |    | SENERROR |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                | Type | Reset  |
|-------|------------|----------------------------|------|--------|
| 31:16 | RESERVED   | Reseved                    | R    | 0x0000 |
| 15:8  | AVGERROR   | Average sensor error       | R    | 0x00   |
| 7:0   | SENERROR   | Percentage of sensor error | R    | 0x00   |

**Table 3-561. Register Call Summary for Register SENERROR\_REG**

PRCM Functional Description

- [VDD1 and VDD2 Control: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\]](#)

PRCM Register Manual

- [SR Registers: \[6\]](#)

**Table 3-562. ERRCONFIG**

|                         |                                                            |                 |     |     |
|-------------------------|------------------------------------------------------------|-----------------|-----|-----|
| <b>Address Offset</b>   | 0x0000 0038                                                |                 |     |     |
| <b>Physical Address</b> | <a href="#">0x480C 9038</a><br><a href="#">0x480C B038</a> | <b>Instance</b> | SR1 | SR2 |
|                         | 0x480C B038                                                |                 | SR2 |     |
| <b>Description</b>      | This register is used for error configuration              |                 |     |     |
| <b>Type</b>             | RW                                                         |                 |     |     |

| 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 |
|----------|----|--------------|----|----------|----|--------------------|-------------------|----------|----|-----------|----|-------------|----|----|-------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    | WAKEUPENABLE |    | IDLEMODE |    | VPBOUNDSINTSTATENA | VPBOUNDSINTENABLE | RESERVED |    | ERRWEIGHT |    | ERRMAXLIMIT |    |    | ERRMINLIMIT |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name         | Description                                                                                                               | Type | Reset |
|-------|--------------------|---------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | RESERVED           | Reserved                                                                                                                  | R    | 0x00  |
| 26    | WAKEUPENABLE       | Wakeup from MCU Interrupts enable.<br>0x0: Disables wakeup from MCU interrupts<br>0x1: Enables wakeup from MCU interrupts | RW   | 0x0   |
| 25:24 | IDLEMODE           | 0x0: Force-idle mode<br>0x1: No-idle mode<br>0x2: Smart-idle mode 2<br>0x3: Smart-idle-wakeup mode                        | RW   | 0x0   |
| 23    | VPBOUNDSINTSTATENA | 0x0: Bounds interrupt status is unchanged.<br>0x1: Bounds interrupt status is cleared.                                    | RW   | 0x0   |
| 22    | VPBOUNDSINTENABLE  | 0x0: Bounds interrupt disabled<br>0x1: Bounds interrupt enabled                                                           | RW   | 0x0   |
| 21:19 | RESERVED           | Reserved                                                                                                                  | RW   | 0x0   |
| 18:16 | ERRWEIGHT          | Average Sensor Error weight                                                                                               | RW   | 0x0   |
| 15:8  | ERRMAXLIMIT        | Upper limit of sensor error for interrupt generation                                                                      | RW   | 0x7F  |
| 7:0   | ERRMINLIMIT        | Lower limit of sensor error for interrupt generation                                                                      | RW   | 0x80  |

**Table 3-563. Register Call Summary for Register ERRCONFIG**

PRCM Functional Description

- [VDD1 and VDD2 Control: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\]](#)

PRCM Basic Programming Model

- [SmartReflex Module Initialization Basic Programming Model: \[8\] \[9\] \[10\] \[11\]](#)
- [Changing OPP Using the SmartReflex Module: \[12\]](#)

PRCM Register Manual

- [SR Registers: \[25\]](#)



## **MPU Subsystem**

This chapter describes the microprocessor unit (MPU) subsystem.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| <b>Topic</b> |                                                    | <b>Page</b> |
|--------------|----------------------------------------------------|-------------|
| <b>4.1</b>   | <b>MPU Subsystem Overview .....</b>                | <b>664</b>  |
| <b>4.2</b>   | <b>MPU Subsystem Integration .....</b>             | <b>666</b>  |
| <b>4.3</b>   | <b>MPU Subsystem Functional Description .....</b>  | <b>673</b>  |
| <b>4.4</b>   | <b>MPU Subsystem Basic Programming Model .....</b> | <b>678</b>  |

## 4.1 MPU Subsystem Overview

### 4.1.1 Introduction

The MPU subsystem of the device handles transactions among the ARM® core, the L3 interconnect, and the interrupt controller (INTC).

The MPU subsystem is hard-macro, thus integrating the ARM subchip with additional logic for protocol conversion, emulation, interrupt handling, and debug enhancements. [Figure 4-1](#) shows the high-level block diagram of the MPU subsystem.

**Figure 4-1. MPU Subsystem Overview**



mpu-006

### 4.1.2 Features

The MPU subsystem integrates the following:

- ARM subchip
  - ARM Cortex™-A8 core revision r3p2. For more information, refer to the ARM Cortex-A8 TRM.
  - ARM Version 7 ISA™: Standard ARM instruction set + Thumb®-2, JazelleX™ Java™ accelerator, and media extensions
  - ARM NEON™ core - single instruction, multiple data (SIMD) coprocessor (VFP light + media streaming instructions)

- Cache memories
  - Level 1: 32KB instruction and 32KB data caches - 4 ways associative, 64 bytes/line
  - Level 2: L2 cache and cache controller are embedded within the ARM Cortex-A8 CPU - 256KB, 8 ways associative, 64 bytes/line, parity and error-correction code (ECC) supported
- Memory management unit (MMU) and translation look-aside buffers (TLBs) - separate instruction and data TLB, 32 entries each
- integrated trace and debug features
- Interrupt controller (INTC) - allows up to 96 level-sensitive interrupt inputs (For details, see [Chapter 12, Interrupt Controller](#).)
- Local interconnect between ARM Cortex-A8 CPU, Interrupt controller, and L3 interconnect
- Clock generation and control module - generates clocks, power modes, and idle and active acknowledge signals
- Emulation features: ICECrusher™, Embedded Trace Macrocell™ ( ETM™). The Cortex-A8 MPU implements an APB (Advanced Peripheral Bus) slave interface that allows access to ETM, ICECrusherCS and debug registers.

## 4.2 MPU Subsystem Integration

The MPU subsystem integrates a group of submodules:

- ARM Cortex-A8 CPU, which provides high-processing capability; this submodule includes the NEON technology for mobile multimedia acceleration. The ARM CPU receives interrupts from the MPU subsystem interrupt controller (MPU INTC).
- Interrupt controller that handles device module interrupts (For details, see [Chapter 12, Interrupt Controller](#).)
- Local interconnect between ARM Cortex-A8 CPU, Interrupt controller, and L3 interconnect
- MPU clock generator: Provides clocks to internal modules of the MPU subsystem; fed by the MPU digital phase-locked loop (DPLL) of the power, reset, and clock management (PRCM) module of the device. The MPU DPLL generates clock for the ARM Cortex-A8 CPU and the Cortex-A8 MPU subsystem logic. All power, reset and the MPU DPLL source clock is generated from the device PRCM.

[Figure 4-2](#) shows the signals that interface with the external modules.

**Figure 4-2. MPU Subsystem Integration Overview**



**NOTE:** Some debug, trace, and emulation features are implemented in the MPU subsystem. Only the clock/reset inputs and power management aspects of these features are listed in this chapter. For details, see the Emulation TRM.

## 4.2.1 MPU Subsystem Clock and Reset Distribution

### 4.2.1.1 Clock Distribution

The MPU subsystem includes a clock generator block that supplies clocks for the modules in the MPU subsystem. It is fed by the MPU\_CLK clock from the PRCM module.

All major modules in the MPU subsystem are clocked at half the frequency of the ARM core. The divider of the output clock can be programmed with the PRCM.CM\_CLKSEL2\_PLL\_MPU[4:0]

MPU\_DPLL\_CLKOUT\_DIV bit field; the frequency is relative to the ARM core. For details, see [Chapter 3, Power, Reset, and Clock Management](#). The clock generator generates the following functional clocks:

- ARM (ARM\_FCLK):** This is the core clock. It is the base fast clock that is routed internally to the ARM logic and internal RAMs, including NEON, L2 cache, the ETM core (emulation), and the ARM core. It runs at the frequency of the MPU\_CLK when DPLL1 is locked, and runs as the frequency of the bypass clock when DPLL1 is bypassed.
- Local interconnect clock (AXI\_FCLK):** This clock is half the frequency of the MPU clock (MPU\_CLK). The L3 interconnect interface thus performs at one half the frequency of the MPU.
- Interrupt Controller Functional Clock (MPU\_INTC\_FCLK):** This clock, which is part of the INTc module, is half the frequency of the MPU clock (MPU\_CLK).
- ICECrusher™ Functional Clock (ICECRUSHER\_FCLK):** ICECrusher clocking operates on the APB interface, using the ARM core clocking. For details, see the Emulation TRM.

**Emulation Clocking:** Except for the ICECrusher functional clock, which is provided by the MPU DLL, the emulation modules inside the MPU subsystem are not generated by the MPU subsystem DPLL, but by an EMU DPLL. These clocks (EMU\_CLOCKS) are distributed by the device PRCM module, are asynchronous to the ARM core clock (ARM\_FCLK) and can run at a maximum of 1/3 the ARM core clock. For details, see the Emulation TRM.

[Figure 4-3](#) shows the MPU subsystem clocking scheme.

**Figure 4-3. MPU Subsystem Clocking Scheme**



mpu-008

For more information about MPU\_DPLL, see [Section 3.5.3.3.3, DLLs](#), in [Chapter 3, Power, Reset, and Clock Management](#).

[Table 4-1](#) summarizes the clocks generated in the MPU subsystem by the MPU DPLL and clock generator.

**Table 4-1. MPU DPLL Clock Signals**

| Signal Name     | I/O | Interface          | Comments                            |
|-----------------|-----|--------------------|-------------------------------------|
| MPU_CLK         | I   | PRCM               | MPU DPLL clock                      |
| ARM_FCLK        | O   | ARM                | ARM functional clock                |
| MPU_INTC_FCLK   | O   | MPU INTC           | MPU INTC functional clock           |
| AXI_FCLK        | O   | Local interconnect | Local interconnect functional clock |
| ICECRUSHER_FCLK | O   | ICECrusher         | ICECrusher functional clock         |

#### 4.2.1.2 Reset Distribution

Resets to the MPU subsystem are provided by the PRCM and controlled by the clock generator module. There are as many reset signals as power domains. For details about power domains, see [Section 4.3.2.1](#). [Figure 4-4](#) shows the reset scheme of the MPU subsystem.

**Figure 4-4. MPU Subsystem Reset Scheme**

**Table 4-2. MPU Subsystem Reset Signals**

| Signal Name   | I/O | Interface | Comments                                               |
|---------------|-----|-----------|--------------------------------------------------------|
| MPU_RST       | I   | PRCM      | MPU power domain reset                                 |
| NEON_RST      | I   | PRCM      | NEON power domain reset                                |
| CORE_RST      | I   | PRCM      | CORE power domain reset                                |
| MPU_PWRON_RST | I   | PRCM      | ICECrusher reset. It is active upon a Cold reset only. |
| EMU_RST       | I   | PRCM      | Emulation interconnect reset                           |
| EMU_RSTPWRON  | I   | PRCM      | Emulation modules reset                                |

For details about clocks, resets, and power domains, see [Chapter 3, Power, Reset, and Clock Management](#).

## 4.2.2 ARM Subchip

### 4.2.2.1 ARM Overview

The ARM Cortex-A8 processor incorporates the technologies available in the ARMv7 architecture. These technologies include NEON for media and signal processing and Jazelle® Runtime Compilation Target (RCT) for acceleration of realtime compilers, Thumb-2 technology for code density and the VFPv3 floating point architecture. For details, see the ARM Cortex-A8 Technical Reference Manual.

### 4.2.2.2 ARM Description

#### 4.2.2.2.1 ARM Cortex-A8 Instruction, Data, and Private Peripheral Port

The CPU bus interface to the local interconnect is the main interface to the ARM system bus. It performs L2 cache fills and non-cacheable accesses for both instructions and data. The bus interface supports 64-bit wide input and output data buses.

See the ARM Cortex-A8 Technical Reference Manual for a complete programming model of the transaction rules (ordering, posting, and pipeline synchronization) that are applied depending on the memory region attribute associated with the transaction destination address.

#### 4.2.2.2.2 MPU Subsystem Features

[Table 4-3](#) lists the main functionalities of the ARM core supported in the MPU subsystem of the device. The MPU subsystem implements the ARM Version 7 Instruction Set Architecture (ISA).

**Table 4-3. ARM Core Key Features**

| Feature                               | Comment                                                                                                                                                |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| ARM version 7 ISA                     | Standard ARM instruction set + Thumb-2, JazelleX Java accelerator, and Media extensions. Backward-compatible with previous ARM ISA versions.           |
| L1 Icache and Dcache                  | 32KB, 4-way, 64-byte cache line, 128 bit interface for Icache and 64 bit interface for Dcache.<br>Note: L1 memories cannot be put into retention mode. |
| L2 cache                              | The L2 cache and cache controller are embedded in the ARM core. 256KB , 8-way, 64 bytes cache line size, 128 bit interface to L1 cache.                |
| TLB                                   | Fully associative and separate ITLB with 32 entries and DTLB with 32 entries                                                                           |
| CoreSight™ ETM                        | The CoreSight ETM is embedded in the ARM core. The 4KB buffer (ETB) exists at the device level. For details, see the Emulation TRM.                    |
| Branch target address cache           | 512 entries                                                                                                                                            |
| Enhanced Memory Management Unit (MMU) | Mapping sizes are 4KB, 64KB, 1MB, and 16MB. ARM MMU adds extended physical address ranges.                                                             |
| NEON                                  | Enhances throughput for media workloads and VFP-Lite support                                                                                           |
| Low interrupt latency                 | Possible via a closely coupled INTC to the Cortex-A8 core                                                                                              |
| Vectored Interrupt Controller Port    | Present                                                                                                                                                |
| JTAG based debug                      | Supported through DAP                                                                                                                                  |
| Trace support                         | Supported through TPIU                                                                                                                                 |
| External coprocessor                  | Not supported                                                                                                                                          |

For more information, see the [ARM Cortex-A8 Technical Reference Manual](#).

### **4.2.2.3 Clock, Reset, and Power Management**

#### **4.2.2.3.1 Clocks**

[Table 4-4](#) describes the ARM functional clock. For configuration, see [Chapter 3, Clock, Reset, and Power Management](#).

**Table 4-4. MPU Subsystem Clock Signal**

| Signal Name | I/O | Interface           | Comments         |
|-------------|-----|---------------------|------------------|
| ARM_FCLK    | I   | MPU clock generator | Functional clock |

#### **4.2.2.3.2 Reset**

[Table 4-5](#) lists the resets for the ARM. They include the power domains reset; NEON\_RST, which resets the neon module of the ARM subchip only; and MPU\_RST, which resets the rest of the ARM subchip and also the local interconnect.

**Table 4-5. ARM Reset Signals**

| Signal Name  | I/O | Interface | Comments                     |
|--------------|-----|-----------|------------------------------|
| MPU_RST      | I   | PRCM      | MPU power domain reset       |
| NEON_RST     | I   | PRCM      | Reset NEON only              |
| EMU_RST      | I   | PRCM      | Emulation interconnect reset |
| EMU_RSTPWRON | I   | PRCM      | Emulation modules reset      |

#### **4.2.2.3.3 Power Management**

For details, see [Section 4.3.2](#).

### **4.2.3 Local Interconnect**

#### **4.2.3.1 Description**

The local interconnect inside the MPU connects the ARM Cortex-A8 CPU, Interrupt controller, and L3 interconnect.

#### **4.2.3.2 Clocks, Reset, and Power Management**

##### **4.2.3.2.1 Clocks**

[Table 4-6](#) lists the bridge functional clocks.

**Table 4-6. Bridges Clock Signals**

| Signal Name | I/O | Interface           | Comments         |
|-------------|-----|---------------------|------------------|
| AXI_FCLK    | I   | MPU clock generator | functional clock |

##### **4.2.3.2.2 Reset**

[Table 4-7](#) lists the bridge reset. It is a power domain reset that also resets the ARM.

**Table 4-7. MPU Subsystem Reset Signal**

| Signal Name | I/O | Interface | Comments               |
|-------------|-----|-----------|------------------------|
| MPU_RST     | I   | PRCM      | MPU power domain reset |

#### 4.2.3.2.3 Power Management

For details, see [Section 4.3.2](#).

#### 4.2.4 Interrupt Controller

For information, see [Chapter 12, Interrupt Controllers](#).

##### 4.2.4.1 Clocks

[Table 4-8](#) lists the INTC clocks.

**Table 4-8. Bridge Clock Signals**

| Signal Name   | I/O | Interface           | Comments              |
|---------------|-----|---------------------|-----------------------|
| MPU_INTC_FCLK | I   | MPU clock generator | INTC functional clock |

##### 4.2.4.2 Reset

[Table 4-9](#) lists the reset of the INTC. It is a power domain reset that also resets the whole core domain. For details, see [Chapter 12, Interrupt Controller](#) and [Chapter 3, Power, Reset, and Clock Management](#).

**Table 4-9. MPU Subsystem Reset Signal**

| Signal Name | I/O | Interface | Comments                |
|-------------|-----|-----------|-------------------------|
| CORE_RST    | I   | PRCM      | CORE power domain reset |

##### 4.2.4.3 Power Management

See [Chapter 12, Interrupt Controller](#), and [Chapter 3, Power, Reset, and Clock Management](#).

## 4.3 MPU Subsystem Functional Description

### 4.3.1 Interrupts

The MPU INTC is connected to the MPU through the local interconnect. It runs at half-processor speed. The INTC prioritizes all service requests from the system peripherals and generates either an IRQ or an FIQ to the MPU, depending on the INTC programming. The INTC handles only the interrupts directed to the MPU subsystem. A maximum of 96 requests can be steered/prioritized as MPU FIQ or IRQ interrupt requests. For details, see [Chapter 12, Interrupt Controller](#).

### 4.3.2 Power Management

#### 4.3.2.1 Power Domains

The MPU subsystem is divided into 5 power domains controlled by the PRCM, as shown in [Figure 4-5](#). Note that the emulation domain and the core domain are not fully embedded in the MPU subsystem.

**Figure 4-5. MPU Subsystem Power Domain Overview**



mpu-010

Power management requirements at the device level govern power domains for the MPU subsystem.

The device-level power domains are directly aligned with voltage domains and, thus, can be represented as a cross reference to the different voltage domains. [Table 4-10](#) shows the different power domains of the MPU subsystem and the modules inside.

**Table 4-10. Overview of the MPU Subsystem Power Domain**

| Functional Power Domain | Physical Power Domain per System/Module                                                        |
|-------------------------|------------------------------------------------------------------------------------------------|
| MPU subsystem domain    | ARM, local interconnect, ARM L1 and L2 periphery logic and array, ICECrusher, ETM, APB modules |
| MPU NEON domain         | ARM NEON accelerator                                                                           |
| DPLL1 domain            | MPU DPLL                                                                                       |
| CORE domain             | MPU interrupt controller                                                                       |
| EMU domain              | EMU (ETB, DAP)                                                                                 |

**NOTE:** The L1 and L2 array memories have separate control signals into the in MPU subsystem, thus, they are directly controlled by the PRCM.

For details on the physical power domains and the voltage domains, see [Chapter 3, Power, Reset, and Clock Management](#).

#### 4.3.2.2 Power States

Each power domain can be driven by the PRCM in four different states, depending on the functional mode required by the user. [Table 4-11](#) lists the MPU power states.

**Table 4-11. MPU Power States**

| Power State | Logic Power | Memory Power | Clocks                  | Memory State Retention |
|-------------|-------------|--------------|-------------------------|------------------------|
| Active      | On          | On or Off    | On (at least one clock) | All                    |
| Inactive    | On          | On or Off    | Off                     | All                    |
| Retention   | On or Off   | On or Off    | Off (all clocks)        | All or part            |
| Off         | Off         | Off          | Off (all clocks)        | None                   |

The PRCM manages all transitions for each power domain by controlling domain clocks, domain resets, domain logic power switches, memory power switches, and memory retention. The MPU subsystem DPLL then internally synchronizes the internal clocks, resets, and switches.

#### 4.3.2.3 Power Modes

##### **MPU DPLL power modes:**

The PRCM.CM\_AUTOIDLE\_PLL\_MPU[2:0] AUTO\_MPU\_DPLL register bit field allows putting the MPU DPLL in an autoidle mode when set to 0x1. In this mode, the MPU DPLL is automatically put into low-power stop mode when the MPU clock is no longer required. It is also restarted automatically.

[Table 4-12](#) describes the different modes that the MPU DPLL can be used in autoidle or manual mode.

The manual modes (locked and low-power bypass) can be configured by the PRCM.CM\_CLKEN\_PLL\_MPU[2:0] EN\_MPU\_DPLL register bit field. The status of the MPU DPLL clock activity can be checked with the PRCM.CM\_IDLEST\_PLL\_MPU[0] ST\_MPU\_CLK bit.

**Table 4-12. MPU DPLL Power Modes**

| Mode             | System Input Clock | Clock Output | DPLL Power State | Condition                                                     |
|------------------|--------------------|--------------|------------------|---------------------------------------------------------------|
| Locked           | ON                 | ON           | ON               | Software request (manual) or MPU wakes up (auto)              |
| Low power bypass | ON                 | ON           | ON               | Software request (manual) or upon global reset release (auto) |
| Stop low power   | OFF                | OFF          | ON               | MPU is RET or OFF (auto)                                      |

**Table 4-12. MPU DPLL Power Modes (continued)**

| Mode | System Input Clock | Clock Output | DPLL Power State | Condition            |
|------|--------------------|--------------|------------------|----------------------|
| OFF  | OFF                | OFF          | OFF              | Device is OFF (auto) |

The MPU DPLL power domain is switched off automatically by the PRCM only when the device enters the OFF mode.

**MPU subsystem power modes:**

The major part of the MPU subsystem belongs to the MPU power domain. The modules inside this power domain can be off at a time when the ARM processor is in an OFF or standby mode. IDLE/WAKEUP control is managed by the clock generator block, but initiated by the PRCM module. The MPU standby status can be checked with the PRCM.CM\_IDLEST\_MPUMPU[0] ST\_MPUMPU bit.

For the MPU to be on, the core (referred here as the device core) power must be on.

The device power management does not allow INTC to go to OFF state when MPU domain is on (active or one of retention modes).

The NEON core has independent power off mode when not in use. Enabling and disabling of NEON can be controlled by software.

The MPU retention modes are described in [Table 4-13](#).

**Table 4-13. MPU Retention Modes**

| Name    | ARM Logic | L1  | L2  |
|---------|-----------|-----|-----|
| Dormant | OFF       | OFF | RET |
| RET     | RET       | RET | RET |

[Table 4-14](#) outlines the supported operational power modes. All other combinations are illegal. The ARM L2, NEON, and ETM/Debug can be powered up/down independently. The APB/ATB ETM/Debug column refers to all three features: ARM emulation, trace, and debug.

**Table 4-14. MPU Subsystem Operation Power Modes**

| Mode | MPU and ARM Core Logic | ARM L2 RAM | NEON   | MPU INTC | APB/ATB Debug and ETM | Comments                                                                                                                  |
|------|------------------------|------------|--------|----------|-----------------------|---------------------------------------------------------------------------------------------------------------------------|
| 1    | Active                 | Active     | Active | Active   | Disabled or enabled   | Functional active run mode (ETM enabled mode when emulation/debug required. Production devices should have ETM disabled). |
| 2    | Active                 | Active     | OFF    | Active   | Disabled or enabled   | Functional active run mode. NEON disabled via SW; NEON is internally clock gated.                                         |
| 3    | Active                 | RET        | Active | Active   | Disabled or enabled   | Do not use; see <sup>(1)</sup>                                                                                            |
| 4    | Active                 | RET        | OFF    | Active   | Disabled or enabled   | Do not use; see <sup>(1)</sup>                                                                                            |
| 5    | Active                 | OFF        | Active | Active   | Disabled or enabled   | Active mode, L2 is off. Controlled via SW to PRCM. L2 context save and restore required or L2 flush.                      |
| 6    | Active                 | OFF        | OFF    | Active   | Disabled or enabled   | Active mode, L2 is off. Controlled via SW to PRCM. L2 context save and restore required or L2 flush.                      |

<sup>(1)</sup> The L2 can be put into retention mode regardless of other voltage domain states. The combination of Cortex Logic active and L2 in retention mode (modes 3 and 4) is legal, but would result in improper execution of instructions with referencing data from L2. This combination must not be used.

**Table 4-14. MPU Subsystem Operation Power Modes (continued)**

| Mode | MPU and ARM Core Logic | ARM L2 RAM | NEON    | MPU INTC | APB/ATB Debug and ETM | Comments                                                                                                                                              |
|------|------------------------|------------|---------|----------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | OFF                    | RET        | OFF     | OFF      | Disabled or enabled   | Lowest power sleep mode (dormant mode), L2 is in retention. Controlled via SW to PRCM. ARM core and L1 context save and restore required or L1 flush. |
| 8    | Standby                | Active     | Standby | Active   | Disabled or enabled   | Standby mode. StandbyWFI controlled to put into standby and wakeup via interrupt.                                                                     |
| 9    | Standby                | Active     | OFF     | Active   | Disabled or enabled   | Standby mode. StandbyWFI controlled to put into standby and wakeup via interrupt when NEON is off.                                                    |
| 10   | Standby                | RET        | Standby | Active   | Disabled or enabled   | Standby mode (retention mode). StandbyWFI controlled to put into standby and wakeup via interrupt when L2 is in retention.                            |
| 11   | Standby                | RET        | OFF     | Active   | Disabled or enabled   | Standby mode (retention mode). StandbyWFI controlled to put into standby and wakeup via interrupt when L2 is in retention and NEON is off.            |
| 12   | Standby                | OFF        | Standby | Active   | Disabled or enabled   | Standby mode. StandbyWFI controlled to put into standby and wakeup via interrupt when L2 is off.                                                      |
| 13   | Standby                | OFF        | OFF     | Active   | Disabled or enabled   | Standby mode. StandbyWFI controlled to put into standby and wakeup via interrupt when both L2 and NEON are off.                                       |
| 14   | OFF                    | OFF        | OFF     | OFF      | Disabled or enabled   | Power-down mode                                                                                                                                       |

In any mode where the MPU or NEON power domains are active, the MPU DPLL clocks must be active (modes 1, 3, and 5 require active clocks from the DPLL, while Modes 7 and 8 do not).

Thus, the MPU DPLL must be in one of these states:

- Locked state
- Low power bypass state: `inclk = on, clkout = on, power = on`

When the MPU DPLL is not providing clocks, the MPU subsystem must be in a power mode where the MPU power domain, NEON power domain, debug power domain, and INTC power domain are in standby, retention, or off state. The states of the MPU DPLL can be:

- Locked
- STOP low power
- OFF

#### 4.3.2.4 Transitions

[Table 4-15](#) describes allowable transitions from power modes described in [Table 4-14](#). For example, a transition from mode 13 to mode 4 is allowed, but the reverse is not true because the L2 RET to OFF is illegal.

Any mode change that requires state saving or flush must be serialized. For example, L2 RET does not require state saving, so it can happen at the same time as power-down NEON. L2 off and NEON off cannot happen at the same time, because L2 flush and NEON state saving must be serialized. Standby mode can enter from active mode only by executing the wait for interruption (WFI) instruction.

**Table 4-15. Power Mode Allowable Transitions**

|      | To Power Mode |   |   |   |   |   |   |   |   |    |    |    |    |    |
|------|---------------|---|---|---|---|---|---|---|---|----|----|----|----|----|
| From | 1             | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 |
| 1    | Y             | Y | Y | Y | Y |   |   | Y |   |    |    |    |    | Y  |
| 2    | Y             | Y | Y | Y |   | Y |   |   | Y |    | Y  |    |    | Y  |
| 3    | Y             | Y | Y | Y |   |   | Y |   |   | Y  |    |    |    |    |
| 4    | Y             | Y | Y | Y |   |   | Y |   |   |    | Y  |    |    |    |
| 5    | Y             |   | Y | Y | Y | Y | Y |   |   | Y  |    | Y  |    | Y  |
| 6    |               | Y | Y | Y | Y | Y | Y |   |   |    | Y  |    | Y  | Y  |
| 7    | Y             | Y | Y | Y |   |   | Y |   |   |    |    |    |    |    |
| 8    | Y             |   | Y |   |   |   |   | Y |   | Y  |    |    |    |    |
| 9    | Y             | Y | Y | Y |   |   |   |   | Y |    | Y  |    |    |    |
| 10   | Y             |   | Y |   |   |   |   | Y |   | Y  |    |    |    |    |
| 11   | Y             | Y | Y | Y |   |   |   |   | Y |    | Y  |    |    |    |
| 12   | Y             |   | Y |   | Y |   |   |   |   |    |    | Y  |    |    |
| 13   | Y             | Y | Y | Y | Y | Y |   |   | Y |    | Y  |    | Y  |    |
| 14   | Y             | Y | Y | Y | Y | Y | Y |   |   |    |    |    |    | Y  |

For more information about clocks, reset, power management, and wake-up events for the MPU subsystem, see [Chapter 3, Power, Reset, and Clock Management](#).

## 4.4 MPU Subsystem Basic Programming Model

For detailed descriptions of registers used for MPU configuration, see [Chapter 3, Power, Reset, and Clock Management](#), and [Chapter 12, Interrupt Controller](#).

### 4.4.1 MPU Subsystem Initialization Sequence

The MPU\_RST signal must be asserted when the DPLL1\_FCLK clock is actively toggling. This assumes that the DPLL has already been programmed and generating a clock inside the MPU subsystem. The MPU\_RST signal starts the module clocks at a div/2 ratio as the DPLL1\_FCLK clock and ARM at a div/1 ratio. The ARM\_RST is asserted 18 ARM clock cycles after MPU\_RST. The first request from ARM only emerges after this.

For more information, see [Chapter 26, Initialization](#).

### 4.4.2 Clock Control

For clock configuration settings, see [Chapter 3, Power, Reset, and Clock Management](#).

### 4.4.3 MPU Power Mode Transitions

The following subsections describe transitions of different power modes for MPU power domain:

- Basic power on reset
- MPU into standby mode
- MPU out of standby mode
- MPU power on from a powered-off state

#### 4.4.3.1 Basic Power-On Reset

The power on reset follows the following sequence of operation and applies to initial power-up and wakeup from device-off mode.

1. Reset DPLL, supply reference clock, program the MPU DPLL in applicable DPLL mode to generate clocks for MPU subsystem modules. This is controlled solely by the PRCM module.
2. Reset the INTC (CORE\_RST) and the MPU subsystem modules (MPU\_RST). The clocks must be active during the MPU reset and CORE reset.

#### 4.4.3.2 MPU Into Standby Mode

The MPU into standby mode uses the following sequence of operation and is applicable to initial power-up and wakeup from device-off mode.

1. The ARM core initiates entering into standby through software only (CP15 - WFI).
2. The MPU modules are requested internally by MPU subsystem to enter idle after ARM core standby is detected.
3. The MPU is in standby, its output asserted by PRCM (all outputs assured to be at reset values).
4. The PRCM can now request INTC to enter into idle mode. Acknowledgment from INTC goes to PRCM.
5. The PRCM can start to shut down clocks through DPLL programming.

---

**NOTE:** The INTC SWAKEUP output is a pure hardware signal to PRCM for the status of its IDLE request and IDLE acknowledge handshake.

---



---

**NOTE:** In debug mode, the ICECrusher can prevent the MPU subsystem from entering into IDLE mode. See IceCrusher programming details in the emulation TRM.

---

#### 4.4.3.3 MPU Out of Standby Mode

The MPU out of standby mode uses the following sequence of operation and applies to initial power-up and wakeup from device off mode.

1. The PRCM must start clocks through DPLL programming.
2. Detect active clocking through status output of DPLL
3. Initiate an interrupt through the INTC to wake up the ARM core from STANDBYWFI mode.

#### 4.4.3.4 MPU Power-On From a Powered-Off State

1. DPLL Power On, MPU Power On, NEON Power On, Core Power On (INTC) should follow the ordered sequence per power switch daisy chain to minimize the peaking of current during power-up.

---

**NOTE:** The core domain must be on, and reset, with the clocks of the DPLL on, before the MPU can be reset.

---

2. Next, follow the reset sequence as described in [Section 4.4.3.1, Basic Power-On Reset](#).

#### 4.4.4 ARM Programming Model

For the complete programming model, see the *ARM Cortex-A8 Technical Reference Manual*.



## **IVA2.2 Subsystem**

This chapter describes the image video and audio accelerator (IVA2.2) subsystem.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| <b>Topic</b>                                        |       | <b>Page</b> |
|-----------------------------------------------------|-------|-------------|
| <b>5.1 IVA2.2 Subsystem Overview</b>                | ..... | <b>682</b>  |
| <b>5.2 IVA2.2 Subsystem Integration</b>             | ..... | <b>684</b>  |
| <b>5.3 IVA2.2 Subsystem Functional Description</b>  | ..... | <b>695</b>  |
| <b>5.4 IVA2.2 Subsystem Basic Programming Model</b> | ..... | <b>733</b>  |
| <b>5.5 IVA2.2 Subsystem Register Manual</b>         | ..... | <b>796</b>  |

## 5.1 IVA2.2 Subsystem Overview

The device includes the high-performance Texas Instruments image video and audio accelerator (IVA2.2), based on the TMS320DMC64X+ VLIW digital signal processor (DSP) core.

The internal architecture is an assembly of the following components:

- High-performance TI DSP (TMS320DMC64X+) integrated in a megamodule, including local L1/L2 cache and memory controllers
- L1 RAM and L2 RAM and ROM
- Video hardware accelerator module, including local sequencer
- Dedicated enhanced data memory access (EDMA) engine to download/upload data from/to memories and peripherals external to the subchip
- Dedicated memory management unit (MMU) for accessing level 3 (L3) interconnect address space
- Local interconnect network
- Dedicated modules SYSC and WUGEN in charge of power management, clock generation, and connection to the power, reset, and clock manager (PRCM) module

Figure 5-1 shows the IVA2.2 subsystem top-level architecture.

**Figure 5-1. IVA2.2 Subsystem Highlight**



### 5.1.1 IVA2.2 Subsystem Key Features

The IVA2.2 subsystem has the following main features:

- 32-bit fixed-point media processor
- VLIW architecture based on programmable enhanced version of C64x DSP core

- 8 instructions/cycle, 8 execution units:
  - Optimized instruction set for video and image processing
  - Eight 8 x 8 or 16 x 16 MAC per cycle
  - Eight SAD per cycle
  - Eight interpolations ( $a + b + 1 >> 1$ ) per cycle
  - Two (32-bit x 32-bit > 64-bit) multiply operations per cycle
- Low-power processor and megamodule:
  - Dynamically mixed 32-bit and 16-bit instruction sets
  - Software pipelined loop (SPLOOP) instruction buffer
  - Separate power domain
  - Supported multiple power-down states
- 2-level memory subsystem hierarchy:
  - L1P (program):
    - 32KB direct-mapped cache-32-byte cache line, configurable as cache or memory-mapped (possible values are: 0KB cache/32KB memory, 4KB/28KB, 8KB/24KB, 16KB/16KB, or 32KB/0KB)
  - L1D (data):
    - 32KB 2-way set associative cache-64-byte cache line, configurable as cache or memory-mapped (possible values are: 0KB cache/32KB memory, 4KB/28KB, 8KB/24KB, 16KB/16KB, or 32KB/0KB)
    - 48-KB memory-mapped SRAM
  - L2 (program and data):
    - 64KB 2-way set associative cache-128-byte cache line, configurable as cache or memory-mapped (possible values are: 0KB cache/64KB memory, 32KB/32KB, or 64KB/0KB)
    - 32-KB memory-mapped SRAM
    - 16-KB ROM
- Video hardware accelerator:
  - Improved motion estimation dedicated hardware
  - Improved loop-filtering dedicated hardware
  - Improved variable-length coder/decoder with quantizing-capabilities-dedicated hardware
  - Dedicated sequencer
  - Local interconnect
  - Shared level 2 (L2) memory interface/arbitrer
- Private direct memory access (DMA) controller:
  - 128 logical channels
  - 1D/2D addressing
  - Chaining capability
  - Fully pipelined, two 64-bit read ports, two 64-bit write ports
  - Single-access 32-byte or 64-byte incrementing bursts
- Level 1 (L1) interrupt controller
- Local IVA digital phase-locked loop (DPLL) supplying IVA subsystem clocking
- 32-entry MMU for seamless integration in high-level operating system (OS) environment
- IVA2.2 system interfaces:
  - 64-bit L3 port shared for external memory accesses:
    - Multithreaded link shared by DSP core and DMA accesses
    - Interface with the L3 interconnect that can be synchronous or asynchronous for clock decoupling between IVA2.2 and L3

- Incrementing burst support
- Critical line first, to reduce line-fetch latency to the processor
- Host port interface (HPI) for MMU programming and access to IVA2.2 internal memories. Can be synchronous or asynchronous.
- System interfaces: clocking, power management
- C-friendly environment (state-of-the-art C-compiler for VLIW architecture)
- Texas Instruments low-overhead DSP-BIOS operating system

## 5.2 IVA2.2 Subsystem Integration

Figure 5-2 shows IVA2.2 subsystem integration in the device.

**Figure 5-2. IVA2.2 Subsystem Integration**


## 5.2.1 Clocking, Reset, and Power-Management Scheme

### 5.2.1.1 Clocks

#### 5.2.1.1.1 IVA2.2 Clocks

The IVA2.2 subsystem receives one single clock signal (IVA\_CLK) from the PRCM.

---

**NOTE:** When the IVA2.2 subsystem does not require an internal clock, the internal clocks can be disabled at the PRCM level by setting the PRCM.CM\_FCLKEN\_IVA2\_EN\_IVA2 bit to 0.

---

From this clock (IVA\_CLK), three internal clocks are generated by the IVA2.2 system control module (SYSC):

- CD0\_CLK: Fastest IVA2.2 subsystem functional clock, dedicated to the DSP. Its frequency can be adjusted at the PRCM level by setting the PRCM.CM\_CLKSEL1\_PLL\_IVA2 and PRCM.CM\_CLKSEL2\_PLL\_IVA2 registers.
- CD1\_CLK: Divide-by-two of the CD0\_CLK clock
- CD2\_CLK: Divide-by-two of the CD0\_CLK clock

Generation of these three clocks is handled internally to the IVA2.2 subsystem by the SYSC module under direct control of the PRCM.

Table 5-1 lists the clock domains in the IVA2.2 subsystem and shows the roles of the clocks.

**Table 5-1. IVA2.2 Internal Clock**

|            |         |                                                                                                              |
|------------|---------|--------------------------------------------------------------------------------------------------------------|
| <b>CD0</b> | CD0_CLK | DSP core + PMC + DMC                                                                                         |
| <b>CD1</b> | CD1_CLK | UMC + power-down + interrupt controller                                                                      |
| <b>CD2</b> | CD2_CLK | EMC + IDMA + DSP megamodule external interfaces + local interconnect + EDMA + MMU + SYSC + iVLCD + iME + iLF |

---

**NOTE:** The internal clocks can be shut down by the PRCM module after the handshake protocol is complete. To configure the PRCM so that internal clocks are hardware-supervised, set the PRCM.CM\_AUTOIDLE\_PLL\_IVA2[2:0] AUTO\_IVA2\_DPLL field to 0x1. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

---

The video sequencer module receives SEQ\_CLK from CD2\_CLK. This divided clock is generated in the video accelerator/sequencer system configuration. For more information about the divided clock of the sequencer, see [Section 5.4.10.1, Clock Management](#).

**CAUTION**

Clock configurations depend on core voltage, and maximum clock frequencies may not apply to production.

### 5.2.1.2 Resets

#### 5.2.1.2.1 Hardware Resets

[Figure 5-3](#) shows the seven hardware input reset signals at the boundary of the IVA2.2 subsystem:

- IVA2\_RST1, connected to the DSP megamodule and EDMA modules
- IVA2\_RST2, connected to the SYSC, MMU, improved variable-length coder/decoder (iVLCD), iME, iLF, and local interconnect
- IVA2\_RST3, connected to the sequencer
- CORE\_RST, connected to the IVA2.2 subsystem wake-up generator (WUGEN) module

- RET\_RST, connected to the subsystem WUGEN retention logic to reset registers that keep their value across a warm reset sequence
- IVA2\_RSTPWRON, which performs a power-on initialization of IVA2.2 logic

**Figure 5-3. IVA2.2 Subsystem Resets**



iva2-003

After chip power on, the IVA2.2 subsystem is kept under reset and only the RET\_RST is released from reset. Then, only the WUGEN is released from reset as part of the core domain. The IVA2.2 remains under reset until the microprocessor unit (MPU) clears the PRCM.RM\_RSTCTRL\_IVA2[1] RST2\_IVA2 bit. On this action, the PRCM switches on the IVA2.2 power domain, sets the clocks back, and releases the power-on reset. When the IVA2.2 power-on sequence completes (hardware handshake), the PRCM releases the IVA2\_RST2 reset. At this stage, the DSP megamodule is kept under reset (unless the MPU also cleared the PRCM.RM\_RSTCTRL\_IVA2[0] RST1\_IVA2 bit); the MPU can upload some code and data in the C64x+ memory. When the MPU has uploaded the code in the C64x+ memory, the MPU clears the RST1\_IVA2 bit, releasing the DSP megamodule from reset. At this point, the sequencer is kept under reset (unless the PRCM.RM\_RSTCTRL\_IVA2[2] RST3\_IVA2 bit was cleared); the DSP can upload some code and data in the sequencer memory. When the DSP has uploaded the coded in the sequencer memory, the DSP clears the RST3\_IVA2 bit, releasing the sequencer from reset.

The MPU can apply a software reset to the IVA2.2. For a software reset to be safe, the IVA2.2 must be in clock-off mode (DSP in idle mode with clocks shut down by the PRCM; for information about the clock-off state transition, see [Section 5.4.10.3, Power-Down and Wake-Up Management](#).) For instance, the MPU can use a mailbox interrupt to ask the IVA2.2 to go to IDLE state. In that case, only IVA2\_RST1 and/or IVA2\_RST2 and/or IVA2\_RST3 are applied, depending on which bits are set, and CORE\_RST and IVA2\_RSTPWRON are never applied.

The IVA2.2 can also program the PRCM to go to OFF state automatically when the IVA2.2 is idle. Then, in response to a wake-up event (for example, an interrupt), the PRCM can switch on the IVA2.2 power domain, set the clocks back, and release the power-on reset. When the IVA2.2 power-on sequence completes (hardware handshake), the PRCM releases the IVA2\_RST3, IVA2\_RST2, and IVA2\_RST1 resets (RST1, RST2, and RST3 SW bits are assumed to be clear). However, for the IDLE instruction (to transition to OFF state) to be executed, the user must program the PRCM to prevent the sequencer (IVA2\_RST3) from being released from reset after a wakeup of the IVA2 from POWER OFF state. CORE\_RST can be applied only if the device is coming out of CHIP OFF state (CORE power domain also in OFF state). In this case, CORE\_RST is released at the same time as the IVA power-on reset.

For some detected severe issues or if the user applies an external system reset, the IVA2.2 can receive a warm reset. IVA2\_RST1, IVA2\_RST2, IVA2\_RST3, DPLL\_RST, RET\_RST, and CORE\_RST are applied. When the warm reset source is released, IVA2\_RST1, IVA2\_RST2, IVA2\_RST3, and CORE\_RST are released. Power-on reset is not applied in this case.

### 5.2.1.2.2 Software Resets

IVA2.2 subsystem reset signals are sourced from the PRCM module. Some modules of the DSP subsystem can also be reset by software control.

The IVA2\_RST1 signal maps to the PRCM.RM\_RSTCTL\_IVA2\_RST1\_IVA2 bit, the IVA2\_RST2 signal maps to the PRCM.RM\_RSTCTL\_IVA2\_RST2\_IVA2 bit, and the IVA2\_RST3 signal maps to the PRCM.RM\_RSTCTL\_IVA2\_RST3\_IVA2 bit in the PRCM register RM\_RSTCTRL\_IVA2. Writing these three bit fields lets the software reset the IVA2.2 subsystem.

---

**NOTE:** Software reset can be applied only while the IVA2.2 subsystem is in clock-off mode.

---

The WUGEN reset signal (CORE\_RST) is reset with the CORE power domain, which is reset at the occurrence of either global cold or global warm reset events. For more information about global reset sources, see [Chapter 3, Power, Reset, and Clock Management](#).

For more information about software resets, see [Section 5.4.10.2, Reset Management](#).

### 5.2.1.3 Power Domain

The IVA2.2 subsystem comprises three power domains that can be shared with other subsystems at the chip level (see [Figure 5-4](#)):

- DSP power domain: Everything specified in the IVA2.2 subsystem, except the wake-up generator
- CORE power domain: Includes the WUGEN

**Figure 5-4. IVA2.2 Power Domain**

The DSP power domain can be powered off if the CORE power domain is powered on. The PRCM ensures that the DSP power domain is always powered off when the CORE power domain is powered off.

The CORE power domain includes several other system-level components of the device. The WUGEN module is included in the CORE power domain to enable the powered-off DSP subsystem to be awakened after receiving an interrupt, a DMA request, or an L3 slave port access.

Memory voltage can be reduced locally when memory is not being used, to reduce memory leakage:

- If IVA2.2 is not active, this is controlled by the PRCM.PM\_PWSTCTRL\_IVA2 register by setting the MEMONSTATE and/or MEMRETSTATE bit fields.

For a detailed description of power domains and controls in the device, see [Chapter 3, Power, Reset, and Clock Management](#).

## 5.2.2 Hardware Requests

### 5.2.2.1 DMA Requests

The IVA2.2 subsystem receives 14 DMA requests from specific peripherals, such as the McBSP module and the UART module (see [Figure 5-5](#)).

**Figure 5-5. IVA2.2 EDMA Requests**



For a description of the EDMA controller, see [Section 5.3.2.1, EDMA](#).

[Table 5-2](#) lists EDMA request mappings to the IVA2.2 subsystem EDMA controller.

**Table 5-2. IVA2.2 Subsystem EDMA Request Mappings**

| DMA     | Source        | Description                       |
|---------|---------------|-----------------------------------|
| D_DMA_0 | MCBSP1_DMA_TX | MCBSP module 1 - transmit request |
| D_DMA_1 | MCBSP1_DMA_RX | MCBSP module 1 - receive request  |
| D_DMA_2 | MCBSP2_DMA_TX | MCBSP module 2 - transmit request |
| D_DMA_3 | MCBSP2_DMA_RX | MCBSP module 2 - receive request  |
| D_DMA_4 | MCBSP3_DMA_TX | MCBSP module 3 - transmit request |
| D_DMA_5 | MCBSP3_DMA_RX | MCBSP module 3 - receive request  |
| D_DMA_6 | MCBSP4_DMA_TX | MCBSP module 4 - transmit request |

**Table 5-2. IVA2.2 Subsystem EDMA Request Mappings (continued)**

| DMA      | Source        | Description                       |
|----------|---------------|-----------------------------------|
| D_DMA_7  | MCBSP4_DMA_RX | MCBSP module 4 - receive request  |
| D_DMA_8  | MCBSP5_DMA_TX | MCBSP module 5 - transmit request |
| D_DMA_9  | MCBSP5_DMA_RX | MCBSP module 5 - receive request  |
| D_DMA_10 | UART3_DMA_TX  | UART module 3 - transmit request  |
| D_DMA_11 | UART3_DMA_RX  | UART module 3 - receive request   |
| D_DMA_12 | Reserved      |                                   |
| D_DMA_13 | Reserved      |                                   |
| D_DMA_14 | Reserved      |                                   |
| D_DMA_15 | Reserved      |                                   |
| D_DMA_16 | Reserved      |                                   |
| D_DMA_17 | Reserved      |                                   |
| D_DMA_18 | Reserved      |                                   |
| D_DMA_19 | Reserved      |                                   |

**NOTE:** All EDMA requests are shared DMA requests; they are also mapped on the system DMA (sDMA). For more information, see [Chapter 11, DMA](#).

For more information about EDMA request management, see [Section 5.4.4.3, Programming an EDMA Transfer](#).

### 5.2.2.2 Interrupt Requests

The IVA2.2 subsystem manages three types of interrupts (see [Figure 5-6](#)):

- Internal interrupts: Requests generated by modules in the IVA2.2 subsystem or in the DSP megamodule included in the IVA2.2 subsystem
- External interrupts: Requests generated by peripherals external to the IVA2.2 subsystem, like SPI, display subsystem, or camera subsystem. Peripherals that generate interrupts at the IVA2.2 level use the IVA2\_IRQ[47:0] input lines of the IVA2.2 subsystem.
- MMU interrupt: The IVA2.2 MMU can generate an interrupt to an external host outside the IVA2.2 subsystem. As shown in [Figure 5-2](#), the interrupt line of the MMU, IVA2\_MMU\_IRQ, is connected to M\_IRQ\_28 of the MPU subsystem interrupt controller.

For more information about the functionality of the IVA2.2 MMU, see [Section 5.3, IVA2.2 Subsystem Functional Description](#).

To manage and expand the interrupt capabilities of the DSP megamodule (internal and external interrupt requests), the IVA2.2 subsystem includes two levels of interrupt control (see [Figure 5-6](#)):

- One interrupt controller (INTC), integrated in the DSP megamodule. This module controls all interrupt requests (internal and external) except the MMU interrupt.  
For more information about the INTC, see [Section 5.3.1.7](#).
- One WUGEN: Responsible at the IVA2.2 subsystem level for detecting wake-up events (interrupts, DMA requests, and slave port access) when the IVA2.2 is powered down. The WUGEN also handles formatting interrupts from device peripherals to the DSP megamodule INTC.

Figure 5-6. IVA2.2 Interrupt Management



iva2-006

In addition to interrupt sources internal to the IVA2.2 subsystem, several interrupt sources coming from device peripherals are connected to the DSP megamodule INTc, but not directly.

These external interrupt sources are first resynchronized in the WUGEN module, synchronously with the CD2 clock domain clock (CD2\_CLK). Then the resynchronized versions are connected to the INTc.

Table 5-3 lists the global interrupt mappings of the IVA2.2 subsystem.

Table 5-3. IVA2.2 Interrupt Mappings

| EVT   | Interrupts/Events | IVA2.2 Pin Name | Interrupt Source | Interrupt Description                         |
|-------|-------------------|-----------------|------------------|-----------------------------------------------|
| 0     | EVT0              | N/A (internal)  | DSP INT CTL      | Output of event combiner 0, for events 4-31   |
| 1     | EVT1              | N/A (internal)  | DSP INT CTL      | Output of event combiner 1, for events 32-63  |
| 2     | EVT2              | N/A (internal)  | DSP INT CTL      | Output of event combiner 2, for events 64-95  |
| 3     | EVT3              | N/A (internal)  | DSP INT CTL      | Output of event combiner 3, for events 96-127 |
| 4-8   | Reserved          | N/A (internal)  | N/A              | N/A                                           |
| 9     | EMU_DTDMA         | N/A (internal)  | DSP ECM          | ECM interrupt (host scan access, DTDMA)       |
| 10    | Reserved          | N/A (internal)  | N/A              | N/A                                           |
| 11    | EMU_RTDXRX        | N/A (internal)  | DSP RTDX         | RTDX receive complete                         |
| 12    | EMU_RTDXTX        | N/A (internal)  | DSP RTDX         | RTDX transmit complete                        |
| 13    | IDMAINT0          | N/A (internal)  | DSP IDMA         | Internal DMA (IDMA) channel 0 interrupt       |
| 14    | IDMAINT1          | N/A (internal)  | DSP IDMA         | IDMA channel 1 interrupt                      |
| 15-27 | Reserved          | N/A (internal)  | N/A              | N/A                                           |
| 28    | CCMPINT           | N/A (internal)  | EDMA TPCC        | TPCC memory protection interrupt              |
| 29    | CCINTG            | N/A (internal)  | EDMA TPCC        | TPCC global interrupt                         |

**Table 5-3. IVA2.2 Interrupt Mappings (continued)**

| EVT   | Interrupts/Events | IVA2.2 Pin Name | Interrupt Source  | Interrupt Description             |
|-------|-------------------|-----------------|-------------------|-----------------------------------|
| 30    | CCINT3            | N/A (internal)  | EDMA_TPCC         | TPCC region 3 interrupt           |
| 31    | CCINT4            | N/A (internal)  | EDMA_TPCC         | TPCC region 4 interrupt           |
| 32    | CCINT5            | N/A (internal)  | EDMA_TPCC         | TPCC region 5 interrupt           |
| 33    | CCINT6            | N/A (internal)  | EDMA_TPCC         | TPCC region 6 interrupt           |
| 34    | CCINT7            | N/A (internal)  | EDMA_TPCC         | TPCC region 7 interrupt           |
| 35    | CCINT8            | N/A (internal)  | EDMA_TPCC         | TPCC region 8 interrupt           |
| 36    | CCINT1            | N/A (internal)  | EDMA_TPCC         | TPCC region 1 interrupt           |
| 37    | CCINT2            | N/A (internal)  | EDMA_TPCC         | TPCC region 2 interrupt           |
| 38    | CCERRINT          | N/A (internal)  | EDMA_TPCC         | TPCC error interrupt              |
| 39    | TCERRINT0         | N/A (internal)  | EDMA_TPTC0        | TPTC0 error interrupt             |
| 40    | TCERRINT1         | N/A (internal)  | EDMA_TPTC1        | TPTC1 error interrupt             |
| 41-44 | Reserved          | N/A (internal)  | N/A               | N/A                               |
| 45-50 | Reserved          | IVA2_IRQ[0-5]   | N/A               | Reserved                          |
| 51    | GPT5_IRQ          | IVA2_IRQ[6]     | GPTIMER5          | General-purpose timer module 5    |
| 52    | GPT6_IRQ          | IVA2_IRQ[7]     | GPTIMER6          | General-purpose timer module 6    |
| 53    | GPT7_IRQ          | IVA2_IRQ[8]     | GPTIMER7          | General-purpose timer module 7    |
| 54    | GPT8_IRQ          | IVA2_IRQ[9]     | GPTIMER8          | General-purpose timer module 8    |
| 55    | MAIL_U1_IVA2_IRQ  | IVA2_IRQ[10]    | MAILBOX           | Mailbox user 1 interrupt request  |
| 56    | CAM_IRQ1          | IVA2_IRQ[11]    | Camera subsystem  | Camera module interrupt request 1 |
| 57    | PRCM_IVA_IRQ      | IVA2_IRQ[12]    | PRCM              | PRCM module                       |
| 58    | DSS_IRQ           | IVA2_IRQ[13]    | Display subsystem | Display subsystem module          |
| 59    | Reserved          | IVA2_IRQ[14]    | N/A               | N/A                               |
| 60    | UART3_IRQ         | IVA2_IRQ[15]    | UART3             | UART module 3 (also infrared)     |
| 61    | MCBSP1_IRQ_TX     | IVA2_IRQ[16]    | MCBSP1            | MCBSP module 1 transmit           |
| 62    | MCBSP1_IRQ_RX     | IVA2_IRQ[17]    | MCBSP1            | MCBSP module 1 receive            |
| 63    | Reserved          | IVA2_IRQ[18]    | N/A               | N/A                               |
| 64    | MCBSP2_IRQ_TX     | IVA2_IRQ[19]    | MCBSP2            | MCBSP module 2 transmit           |
| 65    | MCBSP2_IRQ_RX     | IVA2_IRQ[20]    | MCBSP2            | MCBSP module 2 receive            |
| 66    | MCBSP3_IRQ_TX     | IVA2_IRQ[21]    | MCBSP3            | MCBSP module 3 transmit           |
| 67    | MCBSP3_IRQ_RX     | IVA2_IRQ[22]    | MCBSP3            | MCBSP module 3 receive            |
| 68    | MCBSP4_IRQ_TX     | IVA2_IRQ[23]    | MCBSP4            | MCBSP module 4 transmit           |
| 69    | MCBSP4_IRQ_RX     | IVA2_IRQ[24]    | MCBSP4            | MCBSP module 4 receive            |
| 70    | MCBSP5_IRQ_TX     | IVA2_IRQ[25]    | MCBSP5            | MCBSP module 5 transmit           |
| 71    | MCBSP5_IRQ_RX     | IVA2_IRQ[26]    | MCBSP5            | MCBSP module 5 receive            |
| 72    | Reserved          | IVA2_IRQ[27]    | Reserved          | Reserved                          |
| 73    | GPIO1_IVA2_IRQ    | IVA2_IRQ[28]    | GPIO1             | GPIO module 1                     |
| 74    | GPIO2_IVA2_IRQ    | IVA2_IRQ[29]    | GPIO2             | GPIO module 2                     |
| 75    | GPIO3_IVA2_IRQ    | IVA2_IRQ[30]    | GPIO3             | GPIO module 3                     |
| 76    | GPIO4_IVA2_IRQ    | IVA2_IRQ[31]    | GPIO4             | GPIO module 4                     |
| 77    | GPIO5_IVA2_IRQ    | IVA2_IRQ[32]    | GPIO5             | GPIO module 5                     |
| 78    | MCBSP1_IRQ        | IVA2_IRQ[33]    | MCBSP1            | MCBSP module 1                    |
| 79    | MCBSP2_IRQ        | IVA2_IRQ[34]    | MCBSP2            | MCBSP module 2                    |
| 80    | MCBSP3_IRQ        | IVA2_IRQ[35]    | MCBSP3            | MCBSP module 3                    |
| 81    | MCBSP4_IRQ        | IVA2_IRQ[36]    | MCBSP4            | MCBSP module 4                    |
| 82    | MCBSP5_IRQ        | IVA2_IRQ[37]    | MCBSP5            | MCBSP module 5                    |

**Table 5-3. IVA2.2 Interrupt Mappings (continued)**

| EVT     | Interrupts/Events | IVA2.2 Pin Name | Interrupt Source  | Interrupt Description                              |
|---------|-------------------|-----------------|-------------------|----------------------------------------------------|
| 83      | Reserved          | IVA2_IRQ[38]    | Reserved          | Reserved                                           |
| 84      | L3_IVA2_Error IRQ | IVA2_IRQ[39]    | L3                | L3 interconnect out-of-band error interrupt        |
| 85      | D2DSPINT          | IVA2_IRQ[40]    | 3G modem          | For speech data processing                         |
| 86-87   | Reserved          | IVA2_IRQ[41-42] | Reserved          | Reserved                                           |
| 88      | GPIO6_IVA2_IRQ    | IVA2_IRQ[43]    | GPIO6             | GPIO module 6                                      |
| 89      | SDMA_IRQ_0        | IVA2_IRQ[44]    | SDMA              | sDMA interrupt request 0                           |
| 90      | SDMA_IRQ_1        | IVA2_IRQ[45]    | SDMA              | sDMA interrupt request 1                           |
| 91-92   | Reserved          | IVA2_IRQ[46-47] | Reserved          | Spare interrupts (provision)                       |
| 93      | Reserved          | N/A (internal)  | N/A               | N/A                                                |
| 94      | Reserved          | N/A (internal)  | N/A               | N/A <sup>(1)</sup>                                 |
| 95      | VIDEO_INT         | N/A (internal)  | Video accelerator | Video accelerator interrupt (managed by VIDEOSYSC) |
| 96      | INTERR            | N/A (internal)  | DSP INT CTL       | Dropped CPU interrupt event                        |
| 97      | EMC_IDMAERR       | N/A (internal)  | EMC               | Invalid IDMA parameters                            |
| 98      | Reserved          | N/A (internal)  | Reserved          | Reserved                                           |
| 99      | Reserved          | N/A (internal)  | N/A               | N/A                                                |
| 100     | EFIINTA           | N/A (internal)  | EFI               | EFI interrupt from side A                          |
| 101     | EFIINTB           | N/A (internal)  | EFI               | EFI interrupt from side B                          |
| 102-112 | Reserved          | N/A (internal)  | N/A               | N/A                                                |
| 113     | EMC_ED            | N/A (internal)  | DSP PMC           | Single bit error detected during DMA read          |
| 114-115 | Reserved          | N/A (internal)  | N/A               | N/A                                                |
| 116     | UMC_ED1           | N/A (internal)  | DSP UMC           | Corrected bit error detected                       |
| 117     | UMC_ED2           | N/A (internal)  | DSP UMC           | Uncorrected bit error detected                     |
| 118     | PDC_INT           | N/A (internal)  | DSP PDC           | PDC sleep interrupt                                |
| 119     | SYS_CMPA          | N/A (internal)  | DSP PMC           | SYS CPU memory protection fault                    |
| 120     | PMC_CMPA          | N/A (internal)  | DSP PMC           | CPU memory protection fault                        |
| 121     | PMC_DMPA          | N/A (internal)  | DSP PMC           | DMA memory protection fault                        |
| 122     | DMC_CMPA          | N/A (internal)  | DSP DMC           | CPU memory protection fault                        |
| 123     | DMC_DMPA          | N/A (internal)  | DSP DMC           | DMA memory protection fault                        |
| 124     | UMC_CMPA          | N/A (internal)  | DSP UMC           | CPU memory protection fault                        |
| 125     | UMC_DMPA          | N/A (internal)  | DSP UMC           | DMA memory protection fault                        |
| 126     | EMC_CMPA          | N/A (internal)  | DSP EMC           | CPU memory protection fault                        |
| 127     | EMC_BUSERR        | N/A (internal)  | DSP EMC           | BUSERR interrupt                                   |

<sup>(1)</sup> EVT94 is used by the DSP to generate an interrupt to the sequencer by means of the HOST\_MBX in the SEQ\_IRQSTATE register.

The interrupts generated by the WUGEN module (interrupts from device peripherals) are programmable using a set of registers accessible by the user.

Events related to these external interrupts can be masked by writing to the IVA2.[WUGEN\\_MEVTSET0](#) or IVA2.[WUGEN\\_MEVTSET1](#) registers. The interrupts can also be individually unmasked by using the IVA2.[WUGEN\\_MEVTCLR0](#) or IVA2.[WUGEN\\_MEVTCLR1](#) registers. By default (after power on), these external interrupts are masked in WUGEN.

All other interrupts are directly managed by the IVA2.2 DSP INTC, and the DSP registers are set. For information about the DSP INTC, see the documents listed in [Section 5.3.1.8, Other DSP Reference Documents](#).

### **5.3 IVA2.2 Subsystem Functional Description**

The IVA2.2 subsystem is composed of a DSP megamodule coupled with several submodules that enable its integration in the device architecture. The IVA2.2 subsystem provides one slave port and one master port; both ports are connected to the L3 interconnect.

Figure 5-7 is a block diagram of the IVA2.2 subsystem.

**Figure 5-7. IVA2.2 Subsystem Block Diagram**



NOTE: This indicates the number of threads for IVA2.2 master/slave port interrupts. For details, see [Chapter 9, Interconnect](#).

### **5.3.1 DSP Megamodule**

The C64x+ DSP megamodule is a class of derivative sections of the generalized embedded megamodule. DSP megamodule is a hardware-configurable megamodule module that comprises a version of the C64x+, an L1 program memory controller (PMC), an L1 data memory controller (DMC), a unified memory controller (UMC), an extended memory controller (EMC), an INTC, and a power-down controller (PDC).

[Figure 5-8](#) is a block diagram of the DSP megamodule.

Figure 5-8. DSP Megamodule Block Diagram



iva22-108

### 5.3.1.1 DSP Overview

The C64x+ is an extension of the first C64x DSP section (also named Kelvin).

The C64x features the following:

- 32-bit fixed-point media processor
- VLIW architecture
- 8 instructions/cycle, 8 execution units

- Optimized instruction set for video and image processing
- Eight 8 x 8 or 16 x 16 MAC per cycle
- Eight SAD per cycle
- Eight interpolations ( $a + b + 1 >> 1$ ) per cycle
- Two (32-bit x 32-bit > 64-bit) multiply operations per cycle

In addition to existing C64x features, the C64x+ includes the following:

- SPLOOP
- Compact instructions
- Extended function support
- Exception handling
- Privilege mode support
- HLOS time-stamp counter register

**CAUTION**

Clock configurations depend on core voltage, and maximum clock frequencies may not apply to production.

For information about C64x+ DSP, see the C64x+ reference manual ([Section 5.3.1.8](#)).

### 5.3.1.2 Program Memory Controller Overview

The PMC is the DSP megamodule component that delivers program fetch packets when they are requested by the DSP.

The PMC supports the following features:

- One 256-bit fetch packet per cycle (sustainable)
- 32KB 0-wait state least-significant bit (LSB)-banked SRAM
- L1 program cache controller - 32KB maximum
- Software-programmable allocation of SRAM to cache or memory-mapped SRAM
- DMA transfer from/to SRAM
- Fair priority-based arbitration between DSP, DMA, and cache controller for access to the SRAM
- Block and global program-initiated cache coherence support (invalidate)
- Freeze mode support

In the IVA2.2 subsystem, the PMC controls the 32-KB SRAM typically used as cache RAM. However, the allocation of SRAM can be software-configured to keep a section of the memory as memory-mapped SRAM.

For more information, see [Section 5.4.9, Memory Management](#).

### 5.3.1.3 DMC Overview

The DMC is the DSP megamodule component that reads or writes data from/to local memories, as requested by the DSP.

The DMC supports the following features:

- Two 64-bit memory accesses per cycle (sustainable)
- A memory access pair can be any combination of read and write, with no incurred penalty.
- 80KB 0-wait state LSB-banked SRAM
- L1 data cache controller (capabilities listed in [Table 5-13](#)) - 32KB maximum
- Software-programmable allocation of SRAM to cache or memory-mapped SRAM

- DMA transfer from/to SRAM
- Fair priority-based arbitration between DSP, DMA, and cache controller for access to the SRAM
- Hardware coherence maintenance with L2 (snooping)
- Block and global program-initiated cache coherence support (write-back, invalidate, and write-back-invalidate)
- Freeze and bypass mode support
- Per-page memory-protection attribute check support

The DMC operates to up to 365 MHz in the context of the IVA2.2. The DMC always operates at the same frequency as the DSP.

#### **CAUTION**

Clock configurations depend on core voltage, and maximum clock frequencies might not apply to production.

#### **5.3.1.4 UMC Overview**

The UMC is the DSP megamodule component that reads or writes program and data from/to memory, as requested by the DMC and/or the PMC.

The UMC supports the following features:

- 64KB low-latency state SRAM (first port)
- 32KB low-latency state memory-mapped only SRAM (second port)
- 16KB low-latency ROM (second port)
- L2 unified cache controller (capabilities listed in [Table 5-14](#)) - 64KB maximum
- Software-programmable allocation of SRAM to cache or memory-mapped SRAM
- DMA transfer from/to SRAM and from ROM
- Fair priority-based arbitration between DSP, DMA, and cache controller for access to the SRAM
- Block and global program-initiated cache coherence support (write-back, invalidate, and write-back-invalidate)
- Freeze and bypass modes support
- Per-page memory protection attribute check support
- Emulation support
- Long-distance access support (noncacheable data accesses)
- Page-based memory automatic power-down (to clock-off state) and wake-up support

The UMC contains the interfaces to L2 memory, the L1D, the L1P, and the EMC. The EMC houses the interfaces to the EDMA and internal data memory access (IDMA) engines, and thus allows the UMC and ultimately the CPU to communicate with peripherals and external memory.

The UMC has two L2 memory ports, each of which is 256 bits wide. Although accesses to the two ports are initiated serially for each requestor, only one new access is initiated per UMC clock cycle, to avoid memory-bank conflicts between the ports.

The UMC has three requestor ports: the PMC, the DMC, and the EMC. Peripheral configuration and DMA/IDMA interfacing are handled by the EMC. The PMC interface to the UMC consists of a 256-bit read-only path (L1P fetch only). The DMC and the EMC interface to the UMC, and each has separate 256-bit read and write paths of its own.

The UMC operates to up to 182.5 MHz in the context of the IVA2.2. The UMC always operates at half the frequency of the DSP.

**CAUTION**

Clock configurations depend on core voltage, and maximum clock frequencies might not apply to production.

### 5.3.1.5 EMC Overview

The EMC is the megamodule component that reads or writes program and data external memory and configuration registers, as requested by the UMC.

The EMC supports the following features:

- IDMA
- 64-bit slave port for accesses from an external DMA engine and/or host to L1 or L2 memory
- 64-bit master port to serve accesses from the UMC to external memory or configuration registers

The EMC operates up to 182.5 MHz in the context of the IVA2.2. The EMC can operate at half or one third the frequency of the DSP.

**CAUTION**

Clock configurations depend on core voltage, and maximum clock frequencies might not apply to production.

### 5.3.1.6 Memory Protection Overview

The DSP megamodule memory protection architecture divides the memory map into pages. Each page has an associated set of permissions.

Memory protection provides many benefits to a system:

- Protects operating system data structures from poorly behaving code
- Helps in debugging by providing information about illegal memory accesses
- Prevents unauthorized access to sensitive data
- Allows the OS to enforce clearly defined boundaries between supervisor and user mode accesses, leading to greater system robustness

Memory protection is implemented for the PMC, DMC, UMC, and EMC, and also for the IDMA and EDMA modules.

### 5.3.1.7 INTC

The DSP megamodule INTC detects, potentially combines, and routes up to 128 system events (internal and external) to the DSP CPU interrupt lines. [Table 5-5](#) lists the global interrupt mappings of the IVA2.2 subsystem (internal and external interrupts).

The DSP CPU has 12 maskable interrupts and one exception input. The INTC includes an interrupt selector, an exception combiner, and an event combiner. The interrupt selector allows the routing of any of the 128 system events (or a combination of them) to the 12 maskable interrupts of the DSP CPU, and software determines the priorities of those system events. To handle potential conflicts, the 12 CPU interrupts have fixed priorities. The exception combiner allows the combination of any of the 128 system events to the single exception input of the DSP CPU (see [Figure 5-9](#)).

Figure 5-9. DSP Megamodule INTC Block Diagram



iva22-108

**NOTE:** Not all of the 128 event inputs of the INTC are connected to an internal or external event line. [Table 5-3](#) lists the global interrupt mapping of the DSP INTC. Some interrupts at the IVA2.2 boundary are reserved for future use or are not used by the IVA2.2 subsystem. For information about the DSP core INTC, see the C64x+ DSP documents listed in [Section 5.3.1.8, Other DSP Reference Documents](#).

### 5.3.1.7.1 Event Type

The interrupt controller provides three types of interrupt sources to the DSP CPU:

- Single event
  - A single system event can be directly routed to a CPU interrupt input.
  - A dropped system event is supported through the CPU dropped interrupt reporting mechanism; that is, if the CPU misses the interrupt input, the system event is missed.
- Combined event
  - Up to four event combiners
  - Each combiner allows up to 32 system events to be logically ORed into a single event that can be routed to the DSP CPU.
- Exception event: This event is considered a single event, but it is directly connected to the exception input of the DSP CPU.

### 5.3.1.7.2 Event Behavior

- Single event source: The interrupt selector routes 1 of 124 events to a DSP CPU interrupt, as programmed in the interrupt selector registers (IC.[INTMUXj](#) registers (where j is 1 to 3). Logic in the CPU and the INTC combine to detect instances where an interrupt request is asserted before an earlier interrupt request was serviced. The INTC records the interrupt number of the first interrupt and keeps this information until directed to release the interrupt, either through reset or by application software. This record can be used as an additional system event to notify the application of an interrupt failure. Interrupts that qualify for dropped detection are defined through an IDROP mask that sets the IC.[INTDMASK](#) register. The masked IDROP event output (EVT96; see [Table 5-3](#)) is available as a system event that can be selected as either a DSP CPU interrupt or an exception event.
- Combined source: The event combiners create a combined event from the logical OR of 32 system-event flags qualified by a mask provided through programmable registers (IC.[EVTMASKi](#) where i = 0 to 3). The combination of the event flags creates an event that is asserted when any of the event flags included in its generation is active. Software must clear the event flags (IC.[EVTCLRI](#) where i = 0 to 3) to deassert a combined event.

---

**NOTE:** The use of event flags makes it impossible for the CPU to detect the dropping of independent system events; therefore, dropped interrupt capability is not directly supported for combined events.

---

The interrupt event combiners create four shared interrupt sources:

- EVT0: Logical OR of [EVTFLAGi\[31:04\]](#) (i = 0) masked by [EVTMASKi\[31:04\]](#) (i = 0)
- EVT1: Logical OR of [EVTFLAGi\[63:32\]](#) (i = 1) masked by [EVTMASKi\[63:32\]](#) (i = 1)
- EVT2: Logical OR of [EVTFLAGi\[95:64\]](#) (i = 2) masked by [EVTMASKi\[95:64\]](#) (i = 2)
- EVT3: Logical OR of [EVTFLAGi\[127:96\]](#) (i = 3) masked by [EVTMASKi\[127:96\]](#) (i = 3)

[EVTFLAGi](#) are the event flag registers and [EVTMASKi](#) are the event mask registers. These combined events are presented to the interrupt selection logic.

- Exception event source: As with the event combiner, the exception combiner allows multiple system events to be grouped as a single event input to the CPU, and the combiner provides mask registers to remove undesirable events. Because only one exception is input to the CPU, all mask registers work together to combine up to 128 events as a single EXCEP output. This lets the CPU service all available system exceptions.

The shared exception source is created as follows:

EXCEP: Logical OR of EF[127:04] masked by XM[127:04]

Where EF[i \* 32 + j] = [EVTFLAGi\[j\]](#) and XM[i \* 32 + j] = [EXPMASKi\[j\]](#) (i = 0, 1, 2, 3 and j = 0 to 31).

The logic is similar to that of the event combiners, except that only one combined event is routed to EXCEP.

### 5.3.1.7.3 Event Detection

The INTC contains a set of status and control registers to manage the status of system events received by the controller. These include set, flag, and clear registers covering all 128 system events. Enabling of the events is managed in the CPU for direct mapped interrupts, in the event combiner for combined events, and in the exception combiner for system exceptions. Events to the interrupt controller can be enabled/disabled only at the event source.

The event flag registers (IC.EVTFLAG<sub>i</sub> where  $i = 0$  to 3) capture every system event received, regardless of its destination: event combiner, exception combiner, or interrupt selector. Events that are not masked by either the event combiner or the exception combiner are captured in the IC.EVTFLAG<sub>i</sub> (where  $i = 0$  to 3) register corresponding to the event, and are used to determine when the combined event is generated. Events that are masked by either the event combiner or the exception combiner are captured in the IC.EVTFLAG<sub>i</sub> register, but do not affect when the DSP CPU interrupt is generated.

The event flags in the IC.EVTFLAG<sub>i</sub> registers retain the value of 1 for any event received. These registers are read-only and must be cleared through the write-only IC.EVTCLR<sub>i</sub> registers. The IC.EVTSET<sub>i</sub> registers can be used to manually set bits in the IC.EVTFLAG<sub>i</sub> registers, including those that are masked.

---

**NOTE:** Because external events are maintained by the peripheral until they are explicitly cleared by software, drop event detection does not work for external events (interrupts from peripherals external to the IVA2.2 subsystem).

---

### 5.3.1.7.4 Event Selection

The DSP CPU has 12 available maskable interrupts. The interrupt selector allows any of the 128 system events, either from the event inputs or from the event combiners, to be routed to any of the 12 CPU interrupt inputs (see Figure 5-10).

**Figure 5-10. Interrupt Selector Block Diagram**



iva2-010

The user can choose which of the 128 input events is mapped to each of the 12 CPU interrupts by writing the event number in the bit field corresponding to the CPU interrupt in the INTMUX<sub>j</sub> register. CPU priority is fixed. This event -> interrupt mapping allows software to define the priority of the event. For more information, see Section 5.4, IVA2.2 Subsystem Basic Programming Model.

### 5.3.1.7.5 Event Combination

The event combiner allows multiple system events to be combined as single event for routing to the interrupt selector. This allows the CPU to service all available system events, even though only 12 are available.

A set of event mask registers (IC.[EVTMASKi](#) where i = 0 to 3), is used to program the event combiner. These registers allow up to 32 events to be combined as a single event output that is used as a single DSP CPU interrupt. The event mask bits in the [EVTMASKi](#) registers act as enablers for the received system events combined on the event outputs. There are four event outputs to the interrupt selector (EVT[3:0]).

By default, every system event is unmasked and combined with its associated EVTx. To mask out an event source (for example, to disable an event from being combined), the corresponding mask bit (the IC.[EVTMASKi\[y\]](#) EMy bit for EVTy) must be set to 1.

---

**NOTE:** Because the event masks for events 0 through 3 are combined events and thus cannot contribute to the generation of a combined event, they are reserved.

---

For more information, see [Section 5.4.8, Interrupt Management](#).

### 5.3.1.7.6 Interrupt Event Error

The INTC can generate a system event internally routed to system event input EVT96. This event is generated when a DSP CPU interrupt is received while the interrupt flag (IFR, internal DSP register) is already set in the CPU. This signals possible problems in the code, such as whether interrupts were disabled for an extended time, or whether pipelined (noninterruptible) code sections were too long.

---

**NOTE:** The same strategy of register settings (events, event set, event clear, event mask) is used in the WUGEN (which is not really an INTC), which enables defining wake-up events so that they can wake up the IVA2.2 subsystem. For more information, see [Section 5.3.6, Wake-Up Generator](#).

---

For more information, see [Section 5.4.8, Interrupt Management](#). See [Section 5.4, IVA2.2 Subsystem Basic Programming Model](#), for information on associated programming.

### 5.3.1.7.7 PDC Overview

The DSP megamodule PDC allows power management under software control. Different power-down states are defined and can be reached during a period of DSP inactivity. The PDC ensures handshakes with DSP modules so that they go to power-down state in the correct order, on request from the user, and publishes the relevant standby status to the IVA2.2 SYSC module.

The power-down attributes of the DSP components are mapped through the PDC, through the SYS.[PDCCMD](#) register.

For information about power-down settings, see [Section 5.4.10.3 , Power-Down and Wake-Up Management](#).

### 5.3.1.8 Other DSP Reference Documents

For more information about the DSP megamodule architecture, the instruction set, and the DSP core interrupt controller, and for a complete description of the DSP memory-mapped registers, see the following documents ([www.ti.com](#)):

- *TMS320C6000 DSP Peripherals Overview Reference Guide* (TI literature number SPRU190) describes the peripherals available on the TMS320C6000 DSPs.
- *TMS320C64x Technical Overview* (TI literature number SPRU395) introduces the TMS320C64x DSP and discusses the application areas enhanced by the TMS320C64x VelociT.
- *TMS320C64x+ DSP Megamodule Reference Guide* (TI literature number SPRU871) describes the C64x+ megamodule peripherals.

- *TMS320C64x/C64x+ DSP CPU and Instruction Set Reference Guide* (TI literature number SPRU732)
- *TMS320C6000 Programmers Guide* (TI literature number SPRU198) describes ways to optimize C and assembly code for the TMS320C6000 DSPs, and includes application program examples.
- *TMS320C64x to TMS320C64x+ CPU Migration Guide* application note (TI literature number SPRAA84A)

## 5.3.2 DMA Engines

### 5.3.2.1 EDMA

The IVA2.2 subsystem has an EDMA to transfer instructions and data from/to any external memory connected to the L3 interconnect to/from the DSP megamodule L1D and L2 and, potentially, L1P (if not configured as full cache) local memories. The EDMA can also perform transfers from external memory to external memory and from DSP megamodule internal memory to DSP megamodule internal memory, with some performance loss caused by resource sharing between the read and write ports. For DSP megamodule internal memory to internal memory, use the IDMA.

For the IDMA functional description and a description of IDMA relative programming, see [Section 5.3.2.3, IDMA](#), and [Section 5.4.4.2, Internal Memory-to-Memory Transfer \(IDMA\)](#), respectively.

The EDMA is based on two primary components:

- Third-party DMA channel controller (TPCC)
- Third-party DMA transfer controller (TPTC)

There are two instances of the TPTC in the IVA2.2 subsystem.

[Figure 5-11](#) shows how the EDMA is integrated in the IVA2.2 subsystem:

- Code running on the DSP can configure the EDMA; through the DSP megamodule configuration port and the local interconnect, the code can program DMA transfers and software-trigger them by writing to the TPCC configuration registers.
- Preprogrammed DMA transfers can be triggered by external events, referred to in this chapter as DMA requests.
- The TPCC schedules DMA transfers to the TPTC DMA engines (TPTC0 and TPTC1) through dedicated local interconnect 32-bit configuration ports.
- Each TPTC issues concurrent traffic on the local interconnect through dedicated read and write 64-bit ports.
- Interrupts generated by the EDMA are routed to the DSP INTC.
- Power-management handshakes are exchanged between EDMA components and the SYSC module.

Figure 5-11. IVA2.2 EDMA Overview



iva2-011

### 5.3.2.1.1 Third-Party Channel Controller

The TPCC is the DMA transfer scheduler responsible for scheduling, arbitrating, and issuing user-programmed transfers to the two TPTCs.

#### 5.3.2.1.1.1 TPCC Features

The TPCC features are as follows:

- Parameter RAM (PaRAM entires) holding up to 128 transfer contexts, with the following capabilities:
  - Ping-pong and circular buffering
  - Channel chaining
  - Auto-reloading

Each PaRAM entry can be used as a DMA entry (up to 64), QDMA entry (up to 8), or link entry (remaining):

- Up to 64 DMA logical channels:
  - 64 channels can be triggered explicitly by the DSP CPU (DMA entry).
  - 64 channels can be triggered by 20 external events (see [Table 5-2](#)).
  - All channels can be triggered by completion of a previous transfer in a user-programmed chain of transfers (linked entry).
  - 8 channels can be triggered automatically and indirectly by the CPU using the IDMA, reducing CPU offload for DMA configuration (QDMA entry).
- 12 interrupt lines connected to the DSP CPU
- Boundaries for synchronization with the CPU are programmable.
- Two queues holding events waiting for submission to TPTC
- Memory protection
- Each transfer can be programmed to a priority level (three possible levels).

[Figure 5-12](#) is a block diagram of the TPCC.

**Figure 5-12. TPCC Block Diagram**



iva2-012

**NOTE:**

1. Although it is depicted twice in [Figure 5-12](#), there is only one physical register set for the QDMA to PaRAM set mapping block.
2. For more information, see [Table 5-3](#).

A channel is a specific event that can cause a transfer to be submitted to the TPTCs as a transfer request. The TPCC supports up to 64 DMA channels and up to 8 QDMA channels. These channels are identical, except for the ways they are triggered:

- DMA channels can be triggered by external events (such as McBSP TX Evt and McBSP RX Evt) by the software writing 1 to a given bit location or channel, by the event set register, or through chaining.
- QDMA channels are triggered automatically (auto-triggered) by the CPU using the IDMA. QDMAs allow a minimum number of linear writes (optimized for the DSP IDMA feature) to be issued to the TPCC to force a series of transfers to occur.

The TPCC arbitrates among all pending DMA/QDMA events with a fixed 64:1 and 4:1 priority encoder for DMA and QDMA events, respectively (a low channel number corresponds to a high priority). DMA events are always higher priority than QDMA events. The higher-priority event is placed in the event queue to await submission to the transfer controller, which occurs at the earliest opportunity. Each event queue is serviced in FIFO order, with a maximum of 16 queued events per event queue. If more than one TPTC is ready to be programmed with a transmission request (TR), the event queues are serviced with fixed priority, Q0 higher than Q1. When an event is ready to be queued and both the event queue and the TC channel are empty, the event bypasses the event queue and goes directly to the PaRAM processing logic for submission to the appropriate TC. If the TR bus/PaRAM processing is busy, the bypass path is not used. The bypass is not used to dequeue for a higher-priority event.

Events are extracted from the event queue when the TPTC is available for a new TR to be programmed into the TPTC (signaled with the empty signal, indicating an empty program register set). As an event is extracted from the event queue, the associated PaRAM entry is processed and submitted to the TPTC as a TR. The TPCC updates the appropriate counts and addresses in the PaRAM entry in anticipation of the next trigger event for that PaRAM entry. The PaRAM entry consists of eight words of DMA context, including source address, destination address, count, indexes, etc.

### 5.3.2.1.1.2 DMA Versus QDMA

The only difference between a QDMA and a DMA transfer is the specific means of generating/recognizing TR synchronization. From the user point of view, DMA and QDMA transfer types can be combined to perform various types of transfers.

DMA channel TR synchronization can be generated from one of three sources:

- Event-triggered: The event register ([TPCC\\_ER](#)) channel  $n$  bit is set as the result of an external event. An external event is latched in the event register. If the corresponding event is enabled through the event enable register ([TPCC\\_EER](#)), this is recognized as a TR synchronization.
- Manually triggered: The event set register channel  $n$  bit is set manually to the event set register ([TPCC\\_ESR](#) and [TPCC\\_ESRH](#) registers) for channel  $n$  ([TPCC\\_ESR\[n\]](#) En bit or [TPCC\\_ESRH\[n\]](#) En bit). Manually set events do not need to be enabled to be recognized as a TR synchronization.
- Chain-triggered: The chain event register channel  $n$  ([TPCC\\_CER](#) and [TPCC\\_CERH](#) registers) bit is set when a chaining completion code is detected on the completion interface for channel  $n$ . Chain events do not need to be enabled. If a chain trigger is detected, this is always recognized as a TR synchronization.

QDMA TR synchronization occurs one of two ways:

- Auto-triggered: The QDMA event register channel  $n$  ([TPCC\\_QER](#) and [TPCC\\_QERH\[n\]](#) En) bit is set when a CPU write address matches the address defined by the QDMA mapping register for channel  $n$  ([TPCC\\_QCHMAPj](#)) and the QDMA channel is enabled ([TPCC\\_QEER\[n\]](#) En bit field).
- Link-triggered: The [TPCC\\_QER\[n\]](#) En bit is set when a link update is performed on a PaRAM address that matches the [TPCC\\_QCHMAPj](#) setting, and the [TPCC\\_QEER\[n\]](#) En bit is set.

There is a subtle difference between each trigger type and the associated enablers. Event assertion always results in the [TPCC\\_ER\[n\]](#) En bit being set, regardless of the state of the enable ([TPCC\\_EER](#).En). It is recognized as a TR synchronization only if enabled. Chain triggering always sets the [TPCC\\_CER\[n\]](#) En bit and is always treated as a TR synchronization. Manual triggering always sets the [TPCC\\_ESR\[n\]](#) En bit and is always treated as a TR synchronization. Auto-triggering (QDMA) sets only the event register [TPCC\\_QER\[n\]](#) En bit only if the corresponding event is enabled ([TPCC\\_QEER\[n\]](#) En); when the [TPCC\\_QER\[n\]](#) En bit is set, it is always treated as a TR synchronization.

For more information, see [Section 5.4, IVA2.2 Subsystem Basic Programming Model](#).

### 5.3.2.1.1.3 DMA/QDMA Channel Mapping and PaRAM Entry

The DMA and QDMA channel mapping registers ([TPCC\\_DCHMAPi](#) and [TPCC\\_QCHMAPi](#)) allow each DMA and QDMA channel to be mapped to arbitrary locations in the PaRAM memory map. The entry is designated with a 9-bit PAENTRY ([TPCC\\_DCHMAPi\[13:5\]](#) PAENTRY and [TPCC\\_QCHMAPi\[13:5\]](#) PAENTRY bit fields) PaRAM entry number that defines the entry number in a 128-entry maximum PaRAM (see [Figure 5-13](#)). [TPCC\\_QCHMAPi\[4:2\]](#) TRWORD points to the trigger word of the PaRAM entry defined by PAENTRY. A write to the trigger word results in a QDMA event being recognized.

**Figure 5-13. DMA/QDMA Channel Mapping and PaRAM Entry**



iva2-013

**NOTE:** Each parameter entry of PaRAM is organized as eight 32-bit words or 32 bytes, as shown in [Figure 5-13](#).

The location of fields in each entry, as well as bit positions in the options field, must match the TR packet format as closely as possible to the requirements of the TPTC0 and TPTC1 programming. Each PaRAM entry consists of 16-bit and 32-bit parameters that correspond to the transfer geometry. For more information about the parameters, see [Section 5.3.2.1.1.2, DMA Versus QDMA](#).

### 5.3.2.1.1.4 Types of TPCC Transfers

The TPCC streamlines transfers into an orthogonal transfer structure that is always defined by three dimensions. Of the three dimensions, only two synchronization types are supported: 1D synchronized transfers and 2D synchronized transfers; 3D synchronized transfers can be logically achieved by chaining.

The following terms are used:

- 1-dimension (1D) transfer or array: ACNT contiguous bytes transfer. For information about the 1D transfer programming model, see [Section 5.3.2.1.1.5, Transfer Synchronization](#).
- 2-dimension (2D) transfer or frame: BCNT arrays of ACNT bytes transfer. Each array transfer in 2D transfer is separated from the other transfers by an index programmed through the TPCC.SBIDX or TPCC.DBIDX registers.
- 3-dimension (3D) or block: CCNT frames of BCNT arrays of ACNT bytes. Each transfer in the third dimension is separated from the previous transfer by an index programmed by the TPCC.SCIDX or TPCC.DCIDX registers. The reference point for the index depends on the synchronization type.

### 5.3.2.1.1.5 Transfer Synchronization

In a 1D synchronized transfer, each TPCC TR synchronization triggers the transfer of the first dimension of ACNT bytes, or one array of ACNT bytes. In other words, each TR packet consists of transfer information for only one array. Arrays can be separated by SBIDX and DBIDX, as shown in [Figure 5-13](#), where the start address of array N equals the start address of array 1 plus SRC or DST BIDX. Frames can be separated by SCIDX and DCIDX. For 1D synchronized transfers, after the frame is exhausted, the address is updated by adding (S|D)CIDX to the beginning address of the last array in the frame.

Contrast this to the (S|D)CIDX update in 2D synchronized transfers, which are referenced from the beginning address of the first array in the previous frame. For information about parameter updates, see [Section 5.3.10, Error Reporting](#).

In a 2D synchronized transfer, each TR synchronization triggers the transfer of two dimensions or one frame. In other words, each TR packet conveys information for one entire frame of BCNT arrays of ACNT bytes. Arrays can be separated by SBIDX and DBIDX, as shown in [Figure 5-15](#). Frames can be separated by SCIDX and DCIDX. For 2D synchronized transfers, after a TR for the frame is submitted, the address is updated by adding (S|D)CIDX to the beginning address of the beginning array in the frame. Contrast this to the (S|D)BIDX update in 1D synchronized transfers. For information about parameter updates, see [Section 5.3.10, Error Reporting](#).

### 5.3.2.1.1.6 DMA Channel Prioritization

If multiple trigger sources (event trigger/chain trigger/manual trigger) for a single channel are active at the same time, the TPCC services events in the following order:

1. Event trigger (through event register [ER])
2. Chain trigger (through chain event register [CER])
3. Manual trigger (through event set register [ESR])

### 5.3.2.1.1.7 Transfer Completion

Transfer completion can be used for two different mechanisms in the TPCC:

- Generating chained events
- Generating interrupts to an external processor

The underlying mechanism for both features is the same. The user programs the PaRAM Options field with a specific transfer completion code ([TPCC\\_OPTm\[17:12\] TCC](#)) and indicates whether that completion code is to be used to generate a chained event and/or to generate an interrupt on completion of a transfer (either or both can be done). The user can selectively program whether completion signaling is enabled for the final TR of a PaRAM set, for all except the final TR of a PaRAM set, or for all TRs of a PaRAM set. The specific TCC value (6-bit binary value) programmed by the user dictates which bit of the 64-bit CER and/or interrupt pending register (IPR) is used.

There is no direct correlation between the TCC value used for a specific PaRAM entry and the channel number for that entry. Software controls the allocation of TCC values. There is always a 1:1 relationship between the TCC value and the IPR bit and/or the CER bit set when that transfer completes. For example, completion of the PaRAM entry for channel 0 can chain-trigger the PaRAM entry for channel 1.

### 5.3.2.1.2 Third-Party Transfer Controller

The TPTC is the DMA transfer engine that generates transfers as programmed in dedicated working registers, using two dedicated master ports: a read-only port and a write-only port.

---

**NOTE:** The port data bus width of the instances of the TPTC is fixed at 64 bits.

---

#### 5.3.2.1.2.1 TPTC Features

The TPTC features are as follows:

- Pipelined transfers (multiple inflight transfers)
- Background programming
- 2D or 1D transfer
- Increment addressing modes
- Clock-stop handshaking with the SYSC controller
- Programmable tracking of transfer completion
- 2D qualifications of transfers to allow 2D bandwidth optimization

Two instances of the TPTC generate concurrent traffic on the IVA2.2 local interconnect. Each TC controller consists of the following components:

- DMA program register set: Stores the context for the DMA transfer that is loaded into the active register set on completion of the current active register set. The CPU or TPCC programs the program register set, not the active register set. For typical stand-alone operation, the CPU programs the program register while the TC services the active register set. The program register set includes ownership control that synchronizes the CPU software and the DMA.
- Source DMA active register set: Stores the context (src/dst/cnt/etc) for the DMA transfer request in progress in the read controller. The active register set is split into independent source and distant register halves, because the source local interconnect controller and distant local interconnect controller operate independently of each other.
- Distant DMA register set: Stores the context (src/dst/cnt/etc) for the DMA transfer request in progress, or pending, in the write controller. The pending register sets are required to allow the source controller to begin processing a new TR while the distant register set is still processing the previous TR.
- Channel FIFO: Temporary holding buffer for inflight data. The read return data of the source peripheral is stored in the data FIFO and then written to the destination peripheral by the write command/data bus.
- Read controller/local interconnect read interface: The local interconnect read interface issues optimally sized read commands to the source peripheral, based on a burst size of 64 bytes and the available landing space in the channel FIFO.
- Write controller/local interconnect write interface: The local interconnect write interface issues optimally sized write commands to the destination peripheral, based on a burst size of 64 bytes and available data in the channel FIFO.
- Completion interface: The completion interface sends completion information to the TPCC for posting interrupts in the TPCC.
- Configuration port: Slave interface that provides read/write access to program registers, and provides read access to all memory-mapped TC registers. For information about TPTC registers, see [Section 5.5, IVA2.2 Subsystem Register Manual](#).

[Table 5-4](#) lists the hardware settings.

[Figure 5-14](#) shows the internal structure of the TPTC and its connection to the TPCC.

**Figure 5-14. TPTC Block Diagram**

iva2-014

The primary responsibility of the TPTC is to perform read and write transfers through the local interconnect to the slave peripherals, as programmed in the active and program register sets:

- In the TC stand-alone use model, the user directly programs the program and active register sets for a given channel (TPTC0 or TPTC1). Because of the TPCC, this mode is not the use case targeted for device applications, so it is not emphasized in this chapter. For information about its programming model, see [Section 5.4.4.6.6, Direct Configuration to Transfer Channel \(Not Recommended\)](#).
- In the TC external-control use model, the user does not directly program the active and program register sets. Instead, the TPCC is the user interface to the EDMA system, and the TPTCs (TPTC0 and TPTC1) are slaves to the TPCC. This is the use case of the EDMA in device applications.

### 5.3.2.1.2.2 Transfer Geometry

The TPTC supports a transfer geometry fully defined by the registers summarized here (see [Figure 5-15](#)).

- OPTx = options, (where x = 0, 1)
  - SAM = Source address mode, controls whether the source array is from incrementing addresses or from a single FIFO address
  - DAM = Distant address mode, controls whether the destination array is to an incrementing address or to a single FIFO address
  - FWID = Controls the width of the FIFO
- SRC = Source address
- DST = Distant address
- CNT = BCNT, ACNT
  - ACNT = Number of bytes in each array
  - BCNT = Number of arrays in each TR
- BIDX = DBIDX, SBIDX
  - SBIDX = Source B-dimension index, defines the address offset between starting addresses of each source array
  - DBIDX = Distant B-dimension index, defines the address offset between starting addresses of each destination array

**Figure 5-15. Transfer Geometry**

iva2-015

**NOTE:** Many Texas Instruments DMA controllers employ a concept of element size and element indexing. To maintain orthogonality, the concept of element size has been dropped. An element-indexed transfer is logically achieved by programming ACNT to the size of the element and BCNT to the number of elements that must be transferred.

### 5.3.2.1.2.3 Tracking Transfers

Each TPTC channel consists of three register sets: a program register set, a source-active register set, and a distant FIFO register set. The status of each of these register sets is indicated by the PROGBUSY, SRCACTV, DSTACTV, and WSACTV status bits, which are user-readable in the [TPTCj\\_TCSTAT](#) register.

The program register set ([TPTCj\\_POPT](#), [TPTCj\\_PSRC](#), [TPTCj\\_PCNT](#), [TPTCj\\_PDST](#), [TPTCj\\_PBIDX](#), and [TPTCj\\_PMPPRXY](#)) is never modified by the TPTC, because they are simply holding registers processed by the active register sets. The source active register set ([TPTCj\\_SAOPT](#), [TPTCj\\_SASRC](#), [TPTCj\\_SACNT](#), [TPTCj\\_SADST](#), [TPTCj\\_SABIDX](#), [TPTCj\\_SAMPPRXY](#), [TPTCj\\_SACNTRLD](#), [TPTCj\\_SASRCBREF](#), and [TPTCj\\_SADSTBREF](#)) tracks commands for the source side of the transfer, and the distant FIFO register set ([TPTCj\\_DFOPTi](#), [TPTCj\\_DFSRCi](#), [TPTCj\\_DFCNTi](#), [TPTCj\\_DFDSTi](#), [TPTCj\\_DFBIDXi](#), and [TPTCj\\_DFMPPRXYi](#)) tracks commands for the distant side of the transfer.

As the source and distant controllers process a TR, the SRC, DST, and CNT fields must be continuously updated as commands are issued. A reference value for these registers is also maintained. The active register set uses the reference address (SRCBREF and/or DSTBREF) to calculate the addresses of the subsequent arrays in a transfer. This is required because subsequent arrays are defined as an offset from the starting address of the current array. Similarly, when a new array begins, the CNT must be restored (from CNTRLD) to the originally programmed value and decremented as the new array is processed.

The following summarizes register use for the active register sets:

- Static fields
  - OPT
  - BIDX = DBIDX/SBIDX
- Dynamic fields
  - SRC = Source address of the next read command to be issued
    - Tracked by source active register set

- DST = Distant address of the next write command to be issued
  - Tracked by distant FIFO register set
- CNT = BCNT/ACNT
  - BCNT = Number of arrays remaining to be transferred. This includes the current array; that is, BCNT is decremented after all commands for an array are issued (or at least after all read or write commands are scheduled).
  - ACNT = Number of bytes remaining to be transferred
    - Tracked independently in source and distant FIFO register sets
- Reference fields
  - CNTRLD = ACNTRLD only
    - CNTRLD.ACNTRLD is set with the initial CNT.ACNT value. The reload value is copied into CNT.ACNT when CNT.ACNT decrements to 0.
    - Tracked independently in source and distant FIFO register sets
  - Because a command is complete when BCNT decrements to 0, there is no BCNT reload value.
- SRCBREF = Source address reference points to the starting address of the array being read. The starting address of the next array is calculated as SRCBREF + SBIDX.
  - Tracked by source active register set
- DSTBREF = Distant address reference points to the starting address of the array being written. The starting address of the next array is calculated as DSTBREF + DBIDX.
  - Tracked by distant FIFO register set

#### 5.3.2.1.2.4 Completion Interface to TPCC

The TPCC can request that the TPTC send completion information to the TPCC when a TR completes. Completion status is requested in the TR options registers ([TPTCj\\_DFOPTI\[20\]](#) TCINTEN and [TPTCj\\_DFOPTI\[22\]](#) TCCHEN bits, and [TPTCj\\_DFOPTI\[17:12\]](#) TCC where i = 0 to 3 when j = 0 and i = 0 or 1 when j = 1).

If TCINTEN or TCCHEN is set to 1, the TPTC must return completion information on completion of the entire TR. The TPCC uses completion information for chaining (enabled by TCCHEN) or for posting interrupts (enabled by TCINTEN).

The TPTC generates status conditions based on completion of a transfer ([TPTCj\\_INTSTAT\[1\]](#) TRDONE bit) and based on the program register set transitioning to the downstream registers ([TPTCj\\_INTSTAT\[0\]](#) PROGEMPTY bit).

These two conditions can be enabled by the corresponding bits in the [TPTCj\\_INTEN](#) register to generate an interrupt to the DSP CPU through the TCERRINTx interrupt line (TCERRINT0 for TPTC0 and TCERRINT1 for TPTC1). For the event mapping of these interrupt lines, see [Table 5-2](#).

---

**NOTE:** Status bits TRDONE and PROGEMPTY are always available and are stored in the [TPTCj\\_INTSTAT](#) register regardless of use model and regardless of whether the corresponding bits are enabled. Typically, these bits are not used in the TPCC use model. They are used in a stand-alone use model in which the user directly programs the TC.

---

For more information about EDMA completion and its programming model, see [Section 5.4.4.1, Transfers From/to Device Memories/Peripherals \(EDMA\)](#).

#### 5.3.2.1.3 EDMA Hardware Parameters

[Table 5-4](#) lists the hardware parameter settings for the IVA2.2 subsystem.

**Table 5-4. IVA2.2 EDMA Hardware Parameters**

| Module | Parameter | IVA2.2                  |
|--------|-----------|-------------------------|
| EDMA   | TC        | FIFO size for TC0       |
|        |           | FIFO size for TC1       |
|        |           | Data bus width          |
|        |           | TR pipelining depth TC0 |
|        |           | TR pipelining depth TC1 |
|        |           | Endianness              |
|        |           | Burst size              |
|        | CC        | Number of DMA channels  |
|        |           | Number of QDMA channels |
|        |           | Number of PaRAM entries |
|        |           | Number of Event Qs      |
|        |           | Number of TPTCs         |

**NOTE:** The TR pipelining depth controls the number of read TRs for a given transfer channel that can be serviced by the source transfer controller without being serviced by the distant transfer controller. This dictates the amount of storage required in the distant queue channel registers for inflight TRs

The user cannot directly program burst size, as with the sDMA, but must rely on the ACNT/BCNT and issue 1D synchronization transfers to do so.

### 5.3.2.2 EDMA Access to Video Accelerator/Sequencer

To improve performance and to offload themselves, the DSP megamodule and sequencer can both program the EDMA in IVA2.2 to transfer memory to/from the video accelerator/sequencer (sequencer, iLF, iME, iVLCD) to/from external memories. The DSP megamodule programs the EDMA through the IVA2.2 local interconnect, whereas the sequencer programs the EDMA through the video and sequencer local interconnect. The EDMA can access the following module registers and memories in the video accelerator/sequencer:

- iME configuration registers
- iLF configuration registers
- iVLCD configuration registers and memories
- Sequencer memories
- SL2 memory (access through the IVA2.2 local interconnect)

The DMA accesses the video and sequencer modules with the memory mappings listed in [Table 5-5](#).

**Table 5-5. EDMA Memory Mapping for the Video Accelerator/Sequencer**

| Device Name  | Start Address (Hex) | End Address (Hex) | Size (in Kbytes) |
|--------------|---------------------|-------------------|------------------|
| Reserved     | 0x0000 0000         | 0x0007 FFFF       | 512              |
| iVLCD CFG    | 0x0008 0000         | 0x0008 1FFF       | 8                |
| Reserved     | 0x0008 2000         | 0x0008 3FFF       | 8                |
| iVLCD IBUF0A | 0x0008 4000         | 0x0008 43FF       | 1                |
| Reserved     | 0x0008 4400         | 0x0008 4FFF       | 3                |
| iVLCD IBUF0B | 0x0008 5000         | 0x0008 53FF       | 1                |
| Reserved     | 0x0008 5400         | 0x0008 5FFF       | 3                |
| iVLCD IBUF1  | 0x0008 6000         | 0x0008 6BFF       | 3                |
| Reserved     | 0x0008 6C00         | 0x0008 7FFF       | 5                |
| iVLCD QMEM   | 0x0008 8000         | 0x0008 83FF       | 1                |

**Table 5-5. EDMA Memory Mapping for the Video Accelerator/Sequencer (continued)**

| Device Name            | Start Address (Hex) | End Address (Hex) | Size (in Kbytes) |
|------------------------|---------------------|-------------------|------------------|
| Reserved               | 0x0008 8400         | 0x0008 BFFF       | 15               |
| iLCD HMEM              | 0x0008 C000         | 0x0008 DBFF       | 7                |
| Reserved               | 0x0008 DC00         | 0x0008 FFFF       | 9                |
| SEQ CFG                | 0x0009 0000         | 0x0009 07FF       | 2                |
| Reserved               | 0x0009 0800         | 0x0009 3FFF       | 14               |
| SEQ DMEM               | 0x0009 4000         | 0x0009 4FFF       | 4                |
| Reserved               | 0x0009 5000         | 0x0009 7FFF       | 12               |
| SEQ IMEM               | 0x0009 8000         | 0x0009 9FFF       | 8                |
| Reserved               | 0x0009 A000         | 0x0009 BFFF       | 8                |
| SYSC - CFG             | 0x0009 C000         | 0x0009 CFFF       | 4                |
| Reserved               | 0x0009 D000         | 0x0009 FFFF       | 12               |
| iME CFG                | 0x000A 0000         | 0x000A 0FFF       | 4                |
| iLF CFG                | 0x000A 1000         | 0x000A 1FFF       | 4                |
| Reserved               | 0x000A 2000         | 0x000F 7FFF       | 344              |
| Video interconnect CFG | 0x000F 8000         | 0x000F BFFF       | 16               |
| Reserved               | 0x000F C000         | 0x000F FFFF       | 16               |
| Other MEMS and PERIPHS | 0x0010 0000         | 0xFFFF FFFF       | 4,193,280        |

### 5.3.2.3 IDMA

The IDMA is a simple DMA engine that performs block transfers between any two memory locations local to the DSP megamodule. A local memory has a controller that is included in the DSP megamodule. Local memory can be L1P, L1D, or L2 memories or DSP megamodule port configuration for an offloaded configuration. The IDMA controller consists of two DMA channels (channel 0 and channel 1) that can be independently programmed (a dedicated set of registers) to perform block moves between internal DSP megamodule resources.

IDMA channel 0 is used only to configure registers of IVA2.2 modules connected to the DSP megamodule configuration port, and it is useful for the DMA PaRAM entries.

To allow an easy configuration of IVA2.2 modules, the IDMA channel contains five registers: status, mask, source address, destination address, and window count.

For information about the use of channel 0 for an offloaded configuration, see [Section 5.4.4.6.5, Offloaded Configuration \(Using IDMA\)](#).

IDMA channel 1 allows transfers between any two DSP megamodule local internal memories (L2, L1P, L1D). Channel 1 is intended for background transfers in internal memory, such as block moves between the relatively high-latency L2 and the zero-latency L1D SRAM. This lets the CPU process data directly within L1D with minimal CPU impact.

For more information, see [Section 5.4.4.2, Internal Memory-to-Memory Transfer \(IDMA\)](#).

### 5.3.3 MMU

The IVA2.2 MMU communicates accesses from the DSP core of the IVA2.2 subsystem to the L3 interconnect, mapping the 4G bytes of the DSP virtual addresses to any place in the 4G-byte address space of the device.

At reset, the MMU is disabled, and the IVA2.2 DSP CPU can access device global memory mapping from the 0x1100 0000 address. The range of addresses 0x00000000 to 0x10FF FFFF is reachable only by the DSP CPU, because it performs its own internal memory-mapping function. For more information, see [Chapter 2, Memory Mapping](#).

The IVA2.2 MMU main features are:

- 32 entries/fully associative translation lookaside buffer (TLB)
- One interrupt line to the MPU
- 32-bit virtual addresses, 32-bit physical addresses
- 4-KB and 64-KB pages, 1-MB section, 16-MB supersection
- Predefined (static), software-driven (interrupt-based) or table-driven (hardware table-walker) software translation strategies

**NOTE:** The endianness conversion capability of the MMU module is not used in the IVA2.2 subsystem (the DSP is configured as a little-endian processor in the device). With this configuration, the MMU2.MMU\_RAM[9] ENDIANNESS bit setting is ignored, even if the user changes the value.

Figure 5-16 shows the integration and functionality of the IVA2.2 MMU module.

**Figure 5-16. IVA2.2 MMU Block Diagram**



iva2-016

### 5.3.3.1 MMU VA-to-PA Translation

The IVA2.2 MMU translates the 32-bit DSP external addresses to physical addresses in the 32-bit MPU address space. Address translation is performed by a translation table structure (TTB) that maps the most-significant bits (MSBs) of the DSP byte address to another set of MSBs of a 32-bit MPU byte address. The least-significant bits (LSBs) of the DSP-generated byte address are used as page/section indices in the address translations and are not altered when forming the new 32-bit physical address. The TTB translations are expedited by a TLB that serves as a cache of recently used page translations. The address mapping can be programmed at the TTB level or by writing the TLB entries directly. The IVA2.2 MMU contains 32 TLB entries that can be configured to remap 4-KB, 64-KB, 1-MB, or 16-MB segments of memory.

The TLB can be managed statically or dynamically (through the use of interrupts) by the MPU OS, but the MMU also includes hardware table-walking logic that lets the MMU autonomously traverse the page table on a TLB miss. On a TLB miss, the translation table-walking logic automatically retrieves the information from the translation table stored in physical memory and updates the TLB cache.

Figure 5-17 shows the TTB structure in detail.

**Figure 5-17. IVA2.2 MMU Translation Table Hierarchy**

iva2-017

**NOTE:** The MMU passes the lower bits of the virtual address unchanged.

### 5.3.3.2 MMU Configuration

If the IVA2.2 MMU requires software intervention, the MPU services the event; IVA2.2 MMU service requests are signaled to the MPU with a dedicated interrupt, M\_IRQ[28].

Generally, the MMU is initialized at boot time, but it can also be dynamically reprogrammed. Typically, the MMU is programmed by the MPU through the IVA2.2 slave port on the L3 interconnect when a new task is created on the IVA2.2 subsystem. But the DSP also has access to the MMU configuration registers for the save and restore process. At reset, MMU is disabled and DSP virtual addresses are passed directly through as physical addresses (not translated). IVA2.2 MMU configuration registers are at system base address 0x5D00 0000.

For more information about the functionality of the IVA2.2 subsystem MMU module, including interrupts, register descriptions, and programming model, see [Chapter 15, Memory Management Units](#).

### 5.3.4 Video Accelerator/Sequencer Local Interconnect

The video accelerator/sequencer local interconnect allows the DSP megamodule and the sequencer to access the coprocessor, the sequence and video accelerator system control, the shared L2 memory interface, and the IVA2.2 EDMA.

All sequencer reads and writes are performed through the video accelerator/sequencer local interconnect. The DSP can access the interconnect with EFI instructions (EFSDW, EFSW, EFRW, and EFRDW). A write is always composed of an EFSDW (32b). Depending on the destination value associated with the instruction, the pair of DSP megamodule registers contains either the address (32b; only the lowest 20 bits are significant) and the 32b data, or only the 64b data (auto-incrementing, constant addressing mode). A read is composed of a pair of EFSW and EFRW or EFRDW, depending on the size of the read data. For consistency, reads have the same addressing modes as writes.

---

**NOTE:** The DSP accesses the shared L2 memory and the IVA2.2 EDMA through the IVA interconnect.

---

**Table 5-6** shows the video accelerator/sequencer interconnect memory mapping. Addresses correspond to the DSP megamodule address using the EFI instruction.

For more information about EFI instruction in IVA2.2, see [Section 5.4.5, IVA2.2 Extended Function Interface](#).

**Table 5-6. Video Accelerator/Sequencer Memory Mapping**

| Device Name          | Start Address (Hex) | End Address (Hex) | Size  | Description                  |
|----------------------|---------------------|-------------------|-------|------------------------------|
| L2 memory            | 0x0 0000            | 0x0 7FFF          | 32KB  | L2 shared SRAM               |
| Reserved             | 0x0 8000            | 0x1 FFFF          | 96KB  | Reserved                     |
| DMA registers        | 0x2 0000            | 0x3 FFFF          | 128KB | Configuration registers      |
| Reserved             | 0x4 0000            | 0x7 FFFF          | 256KB | Reserved                     |
| iVLCD registers      | 0x8 0000            | 0x8 1FFF          | 8KB   | Configuration registers      |
| Reserved             | 0x8 2000            | 0x8 3FFF          | 8KB   | Reserved                     |
| iVLCD IBUF0_A        | 0x8 4000            | 0x8 43FF          | 1KB   | iVLCD image buffer 0 part A  |
| Reserved             | 0x8 4400            | 0x8 4FFF          | 3KB   | Reserved                     |
| iVLCD IBUF0_B        | 0x8 5000            | 0x8 53FF          | 1KB   | iVLCD image buffer 0 part B  |
| Reserved             | 0x8 5400            | 0x8 5FFF          | 3KB   | Reserved                     |
| iVLCD IBUF1          | 0x8 6000            | 0x5 6BFF          | 3KB   | iVLCD image buffer 1         |
| Reserved             | 0x8 6C00            | 0x8 7FFF          | 5KB   | Reserved                     |
| iVLCD QMEM           | 0x8 8000            | 0x8 83FF          | 1KB   | iVLCD quantizer memory       |
| Reserved             | 0x8 8400            | 0x8 BFFF          | 15KB  | Reserved                     |
| iVLCD HMEM           | 0x8 C000            | 0x8 DBFF          | 7KB   | iVLCD Huffman memory         |
| Reserved             | 0x8 DC00            | 0x8 FFFF          | 9KB   | Reserved                     |
| SEQ registers        | 0x9 0000            | 0x9 07FF          | 2KB   | Configuration registers      |
| Reserved             | 0x9 0800            | 0x9 0FFF          | 2KB   | Reserved                     |
| Reserved             | 0x9 1000            | 0x9 3FFF          | 12KB  | Reserved                     |
| SEQ DMEM             | 0x9 4000            | 0x9 4FFF          | 4KB   | Sequencer data memory        |
| Reserved             | 0x9 5000            | 0x9 7FFF          | 12KB  | Reserved                     |
| SEQIMEM              | 0x9 8000            | 0x9 9FFF          | 8KB   | Sequencer instruction memory |
| Reserved             | 0x9 A000            | 0x9 BFFF          | 8KB   | Reserved                     |
| Video SYSC registers | 0x9 C000            | 0x9 CFFF          | 4KB   | Configuration registers      |
| Reserved             | 0x9 D000            | 0x9 FFFF          | 12KB  | Reserved                     |
| iME registers        | 0xA 0000            | 0xA 0FFF          | 4KB   | Configuration registers      |
| iLF registers        | 0xA 1000            | 0xA 1FFF          | 4KB   | Configuration registers      |
| Reserved             | 0xA 2000            | 0xF 7FFF          | 344KB | Reserved                     |

**Table 5-6. Video Accelerator/Sequencer Memory Mapping (continued)**

| Device Name            | Start Address (Hex) | End Address (Hex) | Size | Description             |
|------------------------|---------------------|-------------------|------|-------------------------|
| Interconnect registers | 0xF 8000            | 0xF BFFF          | 16KB | Configuration registers |
| Reserved               | 0xF C000            | 0xF FFFF          | 16KB | Reserved                |

### 5.3.5 SL2 Interface

The SL2 memory interface (SL2IF) provides access to L2 memory for the following units:

- iME
- iLF
- Video accelerator/sequencer interconnect

The SL2 memory interface is composed of two modules:

- Bandwidth optimizer (BWO) for video accelerator/sequencer local interface interconnect
- Arbiter

[Figure 5-18](#) is a block diagram of the SL2 memory interface.

**Figure 5-18. SL2 Memory Interface Block Diagram**


iva2-029

### 5.3.5.1 BWO

The BWO optimizes write bandwidth and read latency for connections from/to the local interconnect from/to the shared L2 memory. It has two components:

- 256b write buffer to gather bursted write data before sending them to the shared L2

- 256b read buffer to prefetch a read line from which the burst is read

These buffers are completely decoupled; writes use the write buffer and reads use the read buffer. This is not a data cache, as there is no load-forwarding from the write buffer, and no prefetch buffer to be updated by an incoming write.

---

**NOTE:** There is no concept of dirty bit and write-back policy.

---

### 5.3.5.2 Arbiter

The arbiter allows the three modules (iME, iLF, BWO) to access L2 memory without taking care of concurrent access themselves. No bubble is introduced by the arbitration, which means that when a request is initiated by the iME, the iLF, or the BWO, a request is transmitted to the SL2. This arbitration ensures 100 percent bandwidth use. The arbitration is fair and does not starve an initiator for more than three cycles.

To return data to the correct initiator, the arbiter keeps track of the ordering of memory requests committed to the SL2 memory interface.

The SL2 memory interface can sustain a 2x16-byte request per SL2 memory interface clock cycle, whether the request is a read or write or interleaved reads and writes, and regardless of which module generates the request (iME, iLF, or local interconnect port initiators), if the initiator is not preempted by the others (no competition) and provides an equivalent input throughput.

### 5.3.5.3 Restrictions on SL2 Memory Usage

Because accesses to SL2 (from iME, iLF, or any other initiator with access to the SL2IF interface) are not checked for access permission, the SL2 memory must not be used for memory-protected or sensitive data.

SL2 memory must not be used to store sequencer instructions to be fetched directly by the sequencer; the SL2IF is not designed to efficiently serve sequencer instruction fetches. SL2 memory can hold sequencer instructions, but they must be transferred by the EDMA module into the ITCM before being executed.

### 5.3.5.4 Error Management

The SL2 memory interface responds to the following conditions with an in-band error (SResp = ERR):

- Nonaligned address (MAddr[1:0] <>0)
- Unsupported command (MCmd not belonging to READ/WR/WRNP)

All valid accesses are propagated to the SL2 memory interface; the address must always be mapped in SL2.

### 5.3.6 Wake-Up Generator

The wake-up generator (WUGEN) controls the following:

- Implementing the IVA2.2 idle handshake protocol with the PRCM
- Resynchronizing interrupts and DMA requests from device peripherals external to the IVA2.2 subsystem
- Blocking the interrupts and DMA requests to the IVA2.2 on clean boundaries, when the WUGEN is asked to go into IDLE state
- Detecting the enabled wake-up interrupts and DMA requests and generating a wake-up event to the PRCM
- Formatting interrupts to DSP megamodule interrupt format

Figure 5-19 shows the WUGEN in the IVA2.2 subsystem and its interactions with other submodules.

**Figure 5-19. IVA2.2 WUGEN Description**


iva2-030

### 5.3.6.1 Interrupts, DMA Requests, and Event Management

Interrupts and DMA requests are generated the same way in the WUGEN module. In this section, both are called events.

To manage interrupts, DMA requests, and slave port accesses from external modules, the WUGEN module uses several sets of user-programmable registers:

- The [WUGEN\\_MEVT0](#), [WUGEN\\_MEVT1](#), and [WUGEN\\_MEVT2](#) registers define individual mask bits for external asynchronous events (interrupts, DMA requests, slave port access). This register is read-only, only by the DSP. To modify the value of the individual mask, write 1 to the associated bits of [WUGEN\\_MEVTCR0](#), [WUGEN\\_MEVTCR1](#), and [WUGEN\\_MEVTCR2](#) (to clear) and [WUGEN\\_MEVTSET0](#), [WUGEN\\_MEVTSET1](#), and [WUGEN\\_MEVTSET2](#) (to set).
- The [WUGEN\\_PENDEVTO](#), [WUGEN\\_PENDEVT1](#), and [WUGEN\\_PENDEVT2](#) registers are read-only registers that track which external events are pending in the WUGEN module and are not yet generated to the DSP megamodule interrupt controller (INTC) or to the EDMA. If an event is masked, this information is stable until the corresponding mask bit is cleared. If an event is unmasked, this information may not be stable, and therefore corresponds to a transitive period of processing the event in the WUGEN module.

#### 5.3.6.1.1 Event Generation

Figure 5-20 shows event-generation steps in the WUGEN.

**Figure 5-20. WUGEN Event Generation**

**NOTE:** IVA2.2\_EVT[x] refers to either IVA2.2nIRQ[x] or IVA2.2\_nDMAREQ[x].

- An asynchronous event is asserted.
- The event is resynchronized and detected. Because the event is not masked, it is propagated to DSP megamodule/EDMA.
- The event-pending flag is cleared because the event was generated. The event to DSP megamodule/EDMA is deasserted after one WUGEN clock cycle.
- After some time, the source of the event is released (probably because it cleared in the corresponding interrupt status register).
- The release of the event is detected and clears the internal EVT\_GENERATED flag for that interrupt.

### 5.3.6.1.2 Individual Event Masking

To mask individual events, write 1 in the [WUGEN\\_MEVTSET0](#), [WUGEN\\_MEVTSET1](#), or [WUGEN\\_MEVTSET2](#) register of the WUGEN module. These registers are used to mask interrupts and DMA requests.

[Figure 5-21](#) shows the mechanism of event masking in the WUGEN module.

**Figure 5-21. WUGEN Event Masking**


iva2-032

**NOTE:** IVA2.2\_EVT[x] refers to either IVA2.2\_nIRQ[x] or IVA2.2\_nDMAREQ[x].

- (A) The user sets the corresponding bit in the mask. Event generation is disabled.
- (B) Event mask completion is reflected in the IVA2.2.[WUGEN\\_MEVT0](#) to IVA2.2.[WUGEN\\_MEVT2](#) registers (where i = 0 to 2) for reads.
- (C) An asynchronous event is asserted.
- (D) The event is resynchronized and detected. Because the event is masked, it is not propagated to DSP megamodule/EDMA. The event-pending flag is kept active (sticky) until the mask is removed.

#### 5.3.6.1.3 Individual Event Mask Clear

To unmask individual events, write 1 in the [WUGEN\\_MEVTCLR0](#), [WUGEN\\_MEVTCLR1](#), or [WUGEN\\_MEVTCLR2](#) register of the WUGEN module.

[Figure 5-22](#) shows the event-mask-clear mechanism in the WUGEN module.

**Figure 5-22. WUGEN Event Mask Clear**

iva2-033

**NOTE:** IVA2.2\_EVT[x] refers to either IVA2.2\_nIRQ[x] or IVA2.2\_nDMAREQ[x].

- (A) An asynchronous event is asserted.
- (B) The event is resynchronized and detected. Because the event is masked, it is not propagated to DSP megamodule/EDMA. The event-pending flag is kept active (sticky) until the mask is removed.
- (C) After some time, clear the corresponding bit in the WUGEN mask. The event is automatically generated to DSP megamodule if the event is still seen as active. If the event is not seen as active, nothing happens.
- (D) In both cases, the event-pending flag is cleared.

For more information about interrupts and the EDMA programming model, see [Section 5.4.8, Interrupt Management](#), and [Section 5.4.4.1, Transfers From/to Device Memories/Peripherals \(EDMA\)](#).

### 5.3.6.2 Idle Handshake

After reset, the WUGEN waits for a request. If the user executes the DSP IDLE instruction to put the DSP in standby state, the SYSC initiates a clock-off handshake with the WUGEN.

### 5.3.7 SYSC Module

The SYSC module of the IVA2.2 subsystem controls the following functions:

- Generation of the divided clocks to all components of the IVA2.2 subsystem
- Synchronization of the IVA2.2 divided clocks and the DSP megamodule internal-divided clocks
- PRCM power handshaking

- Sequencing of clock-to-off transition for the IVA2.2 modules
- Reset input resynchronization of the active-to-nonactive transition to the CD2\_CLK clock
- IVA2.2 boot configuration and its access from the DSP

Figure 5-23 is the block diagram of the SYSC in the IVA2.2 subsystem.

**Figure 5-23. SYSC Block Diagram**



iva2-034

**NOTE:** For more information, see [Section 5.2.1, Clocking, Reset, and Power-Management Scheme](#).

### 5.3.7.1 Divided Clock Generation

The SYSC module generates the divided clocks used by the modules in the IVA2.2 subsystem. The SYSC generates three clocks:

- CD0\_CLK
- CD1\_CLK
- CD2\_CLK

Based on the IVA2.2\_FCLK clock, these three clocks are configured from the PRCM. For details, see [Section 5.2.1, Clocking, Reset, and Power-Management Scheme](#).

### 5.3.7.2 Clock Management, Power-Down, and Wake-Up

The SYSC ensures correct generation of the clocks described in [Figure 5-23](#). The SYSC also allows management of the clock gating of the EDMA, video accelerator, sequencer, and DSP megamodule if the user wants to lead some dynamic power aspects.

The SYSC module controls the transition to IVA2.2 subsystem standby state and standby signal

generation (IVA2.2\_MSTANDBY signal in [Figure 5-23](#)) to the PCRM. Using the signals DSP\_MEGRACELL\_STANDBY, EDMA\_STANDBY, VIDEO\_STANDBY, Mx\_IdleReq, and Mx\_IdleAck, the SYSC manages and controls the correct power-down transition of the IVA2.2 subsystem and its submodules to ensure that the IVA2.2 internal clocks can be cut. For information about the IVA2.2 power-down transition and its programming model, see [Section 5.4.10.3, Power-Down and Wake-Up Management](#).

External events can also occur at the IVA2.2 boundary (access to IVA2.2 using the slave access port or external nonmasked events), requiring the restart of the IVA2.2 clocks (in case of IVA2.2 standby state). The WUGEN module controls the asynchronous generation of a wake-up signal to the PRCM; this signal restarts IVA2.2 PLL clock generation, allowing the SYSC to regenerate the IVA2.2 internal clocks.

### 5.3.7.3 Boot Configuration

The IVA\_SYSC.[SYSC\\_BOOTADDR](#) and IVA\_SYSC.[SYSC\\_BOOTMOD](#) registers are the boot-time configuration registers. These read-only registers are accessible only by the DSP, and their values are determined when the IVA2.2 subsystem is released from reset by the PRCM.

The values of these registers are driven externally by two system control module registers, SYSC\_GENERAL1.CONTROL\_IVA2\_BOOTADDR and SYSC\_GENERAL1.CONTROL\_IVA2\_BOOTMOD, which are read-write accessible by the MPU subsystem for MPU-driven IVA2.2 boot sequence and/or by the IVA2.2 DSP for autonomous boot. For more information, see [Section 5.4.1, IVA2.2 Boot](#).

---

**NOTE:** If the values of the SYSC\_GENERAL1.CONTROL\_IVA2\_BOOTADDR and SYSC\_GENERAL1.CONTROL\_IVA2\_BOOTMOD registers change, the new IVA2.2.[SYSC\\_BOOTADDR](#) and IVA2.2.[SYSC\\_BOOTMOD](#) register values are not updated until the next reset.

---

For more information, see [Section 5.4.1, IVA2.2 Boot](#).

### 5.3.7.4 Interconnect Optimization

The IVA2.2.[SYSC\\_LICFG0](#) and IVA2.2.[SYSC\\_LICFG1](#) registers are local interconnect configuration registers. They are read-write accessible by the DSP only. Setting these registers enables or disables interconnect optimization.

### 5.3.7.5 Video Accelerator/Sequencer SYSC

The video and sequencer system control module (called VIDEOSYSC in [Section 5.5.11, Video System Controller Registers](#)) controls module reset, power management, and interrupt handling for the video accelerators/sequencer modules.

#### 5.3.7.5.1 Reset

The reset module resynchronizes asynchronous reset for the following modules:

- iVLCD
- iME
- iLF
- SL2IF
- Video and sequencer interconnect
- Sequencer

For details, see [Section 5.2, IVA2.2 Subsystem Integration](#).

#### 5.3.7.5.2 Power Management

The video accelerator/sequencer SYSC controls clock gating for the iLF, iME, iVLCD, and sequencer modules and controls clock division for the sequencer module.

The **VIDEOSYSC\_CLKCTL** register is used to stop or restart the module clocks. A write of 1 requests the module logic to go idle and to stop the clock. A write of 0 requests a restart of logic and clock. When a new request or command occurs, a module automatically exits the IDLE state and the clock starts. Clock gating can be controlled for the following modules:

- SL2 memory interface (controlled by the **VIDEOSYSC\_CLKCTL[5]** SL2IFCLKEN bit)
- Sequencer memory and slave port (controlled by the **VIDEOSYSC\_CLKCTL[4]** SEQMEMCLKEN bit)
- iLCD module (controlled by the **VIDEOSYSC\_CLKCTL[2]** IVLCDCLKEN bit)
- iME module (controlled by the **VIDEOSYSC\_CLKCTL[1]** IMECLKEN bit)
- iLF module (controlled by the **VIDEOSYSC\_CLKCTL[0]** ILFCLKEN bit)

For details, see [Section 5.5.11 Video System Controller Registers](#).

The **VIDEOSYSC\_CLKDIV[1:0]** SEQCLKDIV bit field is used to set a clock divider for the sequencer. A divider of 1, 2, 3, or 4 is available. For details, see [Section 5.5.11, Video System Controller Registers](#).

#### 5.3.7.5.3 Interrupt Handler

The video accelerator/sequencer SYSC has a single interrupt output, VIDEO\_INT, which is an active low-level interrupt connected to the DSP megamodule. Once asserted, it can be cleared explicitly only by software. It can be enabled or disabled by software. It is asserted when one of the enabled event lines gets asserted. [Table 5-7](#) lists these interrupts.

**Table 5-7. LSYS Input Interrupts**

| Nb | Name       | Description           |
|----|------------|-----------------------|
| 7  | Reserved   | Reserved              |
| 6  | SEQ_MBX    | Sequencer mailbox IRQ |
| 5  | DMA_ERROR  | DMA error IRQ         |
| 4  | HOST_ERROR | HOST error IRQ        |
| 3  | Reserved   | Reserved              |
| 2  | iLCD       | iLCD IRQ              |
| 1  | iLF        | iLF IRQ               |
| 0  | iME        | iME IRQ               |

Four registers are defined for IRQ operation:

- The IVA.[VIDEOSYSC\\_IRQSTATE](#) register tracks input events. Each event is associated with a bit in this register. When the bit is set after an active pulse on the associated event line, this bit is kept active (sticky) until the user explicitly writes 1 to that bit.
- The IVA.[VIDEOSYSC\\_IRQMASK](#) register controls the sensitivity of the interrupt line to input events. Each event is associated with a bit in this register. When the user writes 1 to a bit, the associated active event is not allowed to trigger an interrupt. When the user writes 0, the associated active event triggers an interrupt.
- The IVA.[VIDEOSYSC\\_IRQSET](#) register is used to set the interrupt bits (used to test interrupt). Each event is associated with a bit in this register. When the user writes 1 to a bit, the associated event is set in the IVA.[VIDEOSYSC\\_IRQSTATE](#) register. When the user writes 0, there is no effect.
- The IVA.[VIDEOSYSC\\_IRQCLR](#) register is used to clear the interrupt bits in the IVA.[VIDEOSYSC\\_IRQSTATE](#) register. Each event is associated with a bit in this register. When the user writes 1 to a bit, the associated event is cleared in the IVA.[VIDEOSYSC\\_IRQSTATE](#) register. When the user writes 0, there is no effect.

#### 5.3.8 Local Memories

The IVA2.2 subsystem integrates three memory controllers under the control of the DSP megamodule:

- DMC
- PMC
- UMC

Depending on the software configuration of these memory controllers, the IVA2.2 subsystem local memories (ROM and RAMs) can be used as cache or memory-mapped memories.

Figure 5-24 shows the memory hierarchy of the IVA2.2 subsystem.

**Figure 5-24. IVA2.2 Local Memories Hierarchy**



iva22-035

Table 5-8 lists the IVA2.2 DSP megamodule cache controller features.

**Table 5-8. IVA2.2 DSP Megamodule Cache Controller Features**

| Cache                          | L1 Program Cache                                                | L1 Data Cache                                                    | L2 Unified Cache                                        |
|--------------------------------|-----------------------------------------------------------------|------------------------------------------------------------------|---------------------------------------------------------|
| SIZE                           | Programmable to 0KB, 4KB, 8KB, 16KB, or 32KB                    | Programmable to 0KB, 4KB, 8KB, 16KB, or 32KB                     | Programmable to 0KB, 32KB, or 64KB                      |
| ASSOCIATIVITY                  | Direct-mapped                                                   | Two-way set associative                                          | Four-way set associative                                |
| SRAM MODE [memory-mapped SRAM] | Programmable to 0KB, 16KB, 24KB, 28KB, 32KB (32KB – cache size) | Programmable to 48KB, 64KB, 72KB, 76KB, 80KB (80KB – cache size) | Programmable to 32KB, 64KB, or 96KB (96KB – cache size) |
| WRITE BUFFER                   | NR                                                              | Yes                                                              | Yes                                                     |
| HIT UNDER MISS                 | Yes                                                             | Yes                                                              | No                                                      |
| MISS PIPELINING                | Yes                                                             | Yes                                                              | No                                                      |
| REPLACEMENT POLICY             | NR                                                              | True LRU                                                         | True LRU (pseudo-LRU)                                   |
| CACHEABILITY                   | Always cached                                                   | Programmable                                                     | Programmable                                            |
| BUFFERABILITY                  | NR                                                              | Always buffered                                                  | Always buffered                                         |
| WRITE POLICY                   | NR                                                              | Always write-back                                                | Always write-back                                       |
| ALLOCATION POLICY              | Read-allocate                                                   | Read-allocate                                                    | Read-write-allocate                                     |

**Table 5-8. IVA2.2 DSP Megamodule Cache Controller Features (continued)**

| Cache               | L1 Program Cache                                       | L1 Data Cache | L2 Unified Cache |
|---------------------|--------------------------------------------------------|---------------|------------------|
| CRITICAL WORD FIRST | No                                                     | No            | No               |
| CRITICAL LINE FIRST | NR                                                     | NR            | Yes              |
| ADVANCE FETCH       | Yes, because of DSP advanced fetch-and-miss pipelining | NR            | NR               |

### 5.3.8.1 ROM Overview

The IVA2.2 subsystem contains 16KB L2 ROM. The content of this ROM includes boot code.

For information about boot code and the IVA2.2 boot mechanism, see [Section 5.4.1, IVA2.2 Boot](#).

When the L1P SRAM is configured to be inactive (that is, fully memory-mapped SRAM), DSP program fetch accesses to the L2 ROM are realized directly, and thus suffer the L2 latency.

### 5.3.8.2 RAM Overview

- 32KB L1 program RAM (L1P)
- 80KB L1 data RAM (L1D)
- 96KB L2 unified RAM (L2)

---

**NOTE:** The maximum cache size for the PMC is 32KB. L1P memory-mapped RAM can be programmed to allocate 0KB (full-cache), 16KB, 24KB, 28KB, or 32KB (no cache, default) using the PMC registers. The remaining memory is allocated to the cache controller.

The maximum cache size for the DMC is the default 32K bytes. L1D memory-mapped RAM can be programmed to allocate 48KB (full-cache), 64KB, 72KB, 76KB, or 80KB (no cache, default). The remaining memory is allocated to the cache controller (DMC).

---

L1P and L1D RAM operate at the DSP frequency (CD0 clock domain).

L2 RAM operates at half the DSP frequency (CD1 clock domain).

In the IVA2.2 subsystem, L2 can be configured so that the memory-mapped RAM allocates 32KB, 64KB, or 96KB (no cache) of L2 memory. The remaining memory is allocated to the cache controller.

By default, L2 memory is used as 96-KB local memory-mapped RAM. However, L2 RAM is typically used as 64KB allocated to the cache RAM. This is programmable in the DSP megamodule UMC.

The L2 memory-mapped SRAM is shared by the DSP megamodule and the SL2 interface. An arbitration mechanism is implemented for concurrent access, with the DSP megamodule having priority. These last 32KB cannot be used as cache RAM, but only as memory-mapped RAM. Because of address restrictions, the iME and iLF modules can access only the last 32KB of shared L2.

For information about the software programming model for cache management of the local RAM memories of the IVA2.2 subsystem, see [Section 5.4.3, Cache Management](#).

### 5.3.9 Local Interconnect Network

The local interconnect network is the IVA2.2 internal logic that allows internal communication between the modules of the subsystem (for example, the DSP megamodule can communicate with the EDMA or with the WUGEN module). Communication with the rest of the system is through the MMU as master port (accesses from the IVA2.2 subsystem to the L3 interconnect), and through a slave port for accesses from the L3 interconnect (accesses from the L3 interconnect to the IVA2.2 subsystem).

For information about global memory mapping of the IVA2.2 subsystem (DSP CPU view or MPU view through the L3 interconnect), see [Chapter 2, Memory Mapping](#).

### 5.3.9.1 Endianness

The IVA2.2 local interconnect network does not support the big-endian convention or any type of endianness conversion. Only little-endian is supported by the local interconnect network.

### 5.3.10 Error Reporting

Several mechanisms are available in the IVA2.2 subsystem to report errors at different levels.

The INTC of the DSP megamodule allows reporting of dropped interrupts, through the INTERR signal.

L3 out-of-band errors are also reported through the external L3 interrupt signal. For details about interrupt mapping, see [Table 5-3](#). For information about L3 interconnect error reporting, see [Chapter 9, Interconnect](#).

The IDMA and EDMA have their own error-reporting mechanism. Error-status registers and error interrupts inform the user of problems during IVA2.2 internal operation (data error, bus activity error, etc.).

For information about error management and the register set that allows error tracing, see [Section 5.4.11, Error Identification Process](#).

## 5.4 IVA2.2 Subsystem Basic Programming Model

### **5.4.1 IVA2.2 Boot**

The boot-time configuration registers are IVA\_SYSC.**SYSC\_BOOTADDR** and IVA\_SYSC.**SYSC\_BOOTMOD**. These read-only registers are accessible only by the DSP CPU, and their values are determined when the IVA2.2 is released from reset, using the CONTROL.CONTROL\_IVA2\_BOOTADDR and CONTROL.CONTROL\_IVA2\_BOOTMOD registers of the system control module. For more information, see [Chapter 13, System Control Module](#). A change to those registers is not seen (not sampled) by the IVA2.2 until the next reset.

## The IVA2.2 boots two ways:

- Boot under MPU control, described in [Section 5.4.1.2.1, Boot Under MPU Control](#).
  - Autonomous boot, described in [Section 5.4.1.2.2, Autonomous Boot](#).

A boot under MPU control is typically used after the device cold reset as a first-time configuration of the IVA2.2 subsystem. Subsequent boots of the IVA2.2, resulting from a wake-up transition from OFF state, for example, use the autonomous boot.

#### **5.4.1.1 IVA2.2 Boot Configuration**

Figure 5-25 shows the boot sequence followed by IVA2 on release from reset.

**Figure 5-25. IVA2 Boot Mode Configuration**



When the IVA2.2 subsystem is released from reset and CONTROL.CONTROL\_IVA2\_BOOTMOD[3:0] BootMode equals 0x0, the first fetch address of the C64x equals the address defined in the CONTROL.CONTROL\_IVA2\_BOOTADDR[31:10] BOOTLOADADDR bit field. This address can be aligned on any 1-K byte boundary, in ROM, in IVA2.2 local RAM, in on-chip memory (OCM-RAM), or directly in external memory (for example, SDRAM through the SDRC).

When the IVA2.2 subsystem is released from reset and CONTROL.CONTROL\_IVA2\_BOOTMOD[3:0] BOOTMODE is different from 0x0, the first fetch address of the C64x is fixed to 0x007E0000 (in IVA2.2 local ROM). ROM code boot loader configuration is detailed in [Table 5-9](#).

**Table 5-9. Boot Loader Configuration**

| Value of<br><b>SYSC_IVA2_BOOTMOD</b> | Description                                                                                                                                  |
|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 0x01                                 | IDLE Boot: Boot loader configures the <a href="#">PDCCMD</a> and then executes the IDLE instruction. See <a href="#">Section 5.4.1.1.1</a> . |
| 0x02                                 | Wait in self-loop mode: Boot loader puts IVA2.2 in a self-loop. See <a href="#">Section 5.4.1.1.2</a> .                                      |
| 0x03                                 | Cache Config Mode: Boot loader configures the L1P, L1D, L2 caches and the MAR register. See <a href="#">Section 5.4.1.1.3</a> .              |
| 0x04                                 | User defined bootstrap mode: Boot loader copies the boot strap into L2 memory and branches to it. See <a href="#">Section 5.4.1.1.4</a> .    |
| 0x05                                 | Reserved.                                                                                                                                    |

#### 5.4.1.1.1 IDLE Boot Mode

In this boot mode the **PDCCMD** register is configured before the IDLE instruction is executed. When the IDLE instruction is executed, if there are no pending requests from either the DMA or an interrupt, IVA goes into sleep mode.

The **PDCCMD** register is programmed as shown in [Table 5-10](#).

**Table 5-10. PDCCMD Programmed Value in IDLE Boot Mode**

| BitField | Value | Description                                                                                                                                                                               |
|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GEMPD    | 1     | Sleep mode. Power-down DSP CPU and megamodule when DSP CPU enters IDLE state.                                                                                                             |
| EMCMEM   | 11    | Internal RAMs sleep with retention.                                                                                                                                                       |
| EMCLOG   | 11    | Maximum dynamic clock gating of module regions, with potential : latencies/penalties for wake when megamodule is active and Static clock gating to the EMC when megamodule is in standby. |
| UMCMEM   | 11    | Sleep mode 3. Internal RAMs sleep with retention, L2 defined at chip-level.                                                                                                               |
| UMCLOG   | 11    | Maximum dynamic clock gating of module regions, with potential latencies/penalties for wake when megamodule is active and Static clock gating to the UMC when megamodule is in standby.   |
| DMCMEM   | 11    | Sleep mode 3. Internal RAMs sleep with retention, L1D defined at chip-level.                                                                                                              |
| DMCLOG   | 11    | Maximum dynamic clock gating of module regions, with potential latencies/penalties for wake when megamodule is active and Static clock gating to the DMC when megamodule is in standby    |
| PMCMEM   | 11    | Sleep mode 3. Internal RAMs sleep with retention, L1P defined at chip-level.                                                                                                              |
| PMCLOG   | 11    | Maximum dynamic clock gating of module regions, with potential latencies/penalties for wake when megamodule is active and Static clock gating to the PMC when megamodule is in standby    |

#### 5.4.1.1.2 Wait in Self-Loop Mode

In this mode boot loader puts the IVA2 in a self-loop. The MPU then has the option to download the bootstrap code from the MPU side directly into IVA2 internal memory through host port interface (L3 slave interface). MPU then sets up CONTROL.CONTROL\_IVA2\_BOOTMOD[3:0] BOOTMODE to 0 and CONTROL.CONTROL\_IVA2\_BOOTADDR[31:10] BOOTLOADADDR to the internal memory address where it copied the bootstrap, IVA2.2 is then released from reset. When the reset sequence completes, IVA2.2 jumps to the bootstrap code loaded by the user in its internal memory and starts executing it.

#### 5.4.1.1.3 Default Config Cache Mode

In this mode the boot loader configures the L1P, L1D, L2 caches and the MAR registers of DSP megamodule. After performing this configuration the boot loader branches to an external memory address. The values with which these settings are done and the external memory address to which the boot loader jumps is specified using a header.

[Table 5-11](#) specifies the format of the header.

**Table 5-11. Header Format Used in Default Config Cache Mode**

| Offset from Base Address of Header (in bytes) | Fields Description                                                                                                                              |
|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00                                          | Value of <b>L1PCFG</b> register to be loaded.                                                                                                   |
| 0x04                                          | Value of <b>L1DCFG</b> register to be loaded.                                                                                                   |
| 0x08                                          | Value of <b>L2CFG</b> register to be loaded.                                                                                                    |
| 0x0C                                          | 1 -> Set PC bit of all <b>MARi</b> registers to 1<br>0 -> No action will be taken as by default PC bit of all <b>MARi</b> registers is set to 0 |
| 0x10                                          | Address of external memory to which boot loader should branch to.                                                                               |

The address of this table (header) should be specified in the CONTROL.CONTROL\_IVA2\_BOOTADDR[31:10] BOOTLOADADDR register before IVA2.2 is released from reset.

Setting of the [L1PCFG](#), [L1DCFG](#), and [L2CFG](#) is done as follows:

- The desired cache mode is written to the [L1PCFG](#), [L1DCFG](#), and [L2CFG](#).
- [L1PCFG](#), [L1DCFG](#), and [L2CFG](#) are read back. This stalls the CPU until the mode change completes

Setting of the MAR registers is done as follows:

- The desired value (in our case 1) is written to the MAR
- The final value written to the MAR address is read back. This stalls the CPU until all the MAR writes are completed.

#### **5.4.1.1.4 User Defined Bootstrap Mode**

In this mode the boot loader downloads a user bootstrap code, which is kept in the external memory, into the L2 memory of IVA2.2. After transferring, the boot loader branches to the user bootstrap code. Please note that all sections of the user bootstrap code should fit into L2 memory and no section of the bootstrap code should be mapped to either L1P or L1D memory.

Various parameters that the boot loader needs to transfer the bootstrap code are provided using a user bootstrap header present in the external memory. The CONTROL.CONTROL\_IVA2\_BOOTADDR[31:10] BOOTLOADADDR is setup with the address of this user bootstrap header before IVA2.2 is released from reset.

[Table 5-12](#) specifies the format of the bootstrap header.

**Table 5-12. Header Format Used in User Defined Bootstrap Mode**

| Offset from Base Address of Header (in bytes) | Fields Description                                                                                                           |
|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| 0x00                                          | Size of the boot strap code in bytes that will be downloaded into internal memory.                                           |
| 0x04                                          | 0 -> Use DMA for transferring the bootstrap code<br>1 -> Use CPU copy for transferring the bootstrap code.                   |
| 0x08                                          | Value of <a href="#">L2CFG</a> register to be loaded.                                                                        |
| 0x0C                                          | Absolute address of L2 memory where the boot strap code is to be copied.                                                     |
| 0x10                                          | Offset in bytes from the beginning of the bootstrap code where the first executable instruction of the bootstrap is present. |
| 0x14                                          | Absolute address in external memory from where the bootstrap code will be copied.                                            |

---

**NOTE:** It is mandatory for the user bootstrap code to be a multiple of 4 words on IVA2.2

---

#### **5.4.1.2 Example of IVA2.2 Boot**

##### **5.4.1.2.1 Boot Under MPU Control**

Before waking up the IVA2.2 subsystem, the MPU performs the following sequence (also shown in [Figure 5-26](#)):

1. The MPU prepares a translation table hierarchy (TTH) in SDRAM at address <TTH Physical Address>. This TTH must contain at least an address translation for the IVA2.2 MMU physical address range.

---

**NOTE:** The DSP CPU does not require an address translation for the TTH, as the TTH is under MPU control only. The IVA2.2 DSP CPU is responsible only for saving and restoring an IVA2.2 MMU context that has been programmed by the MPU.

2. The MPU writes a bootstrap sequence in SDRAM at address <BootLoader Physical Address>. This

sequence is executable by the DSP CPU and contains only relative address references, so that it is relocatable without code modification. This sequence must contain at least (in order):

- (a) Set the size of the bootstrap code.
- (b) Program the IVA2.2 MMU using physical addresses, as described in the following steps.

---

**NOTE:** The device has two instances of MMU: camera MMU or MMU1 (used for the camera subsystem) and IVA2.2 MMU or MMU2 (used for the IVA2.2 subsystem). These two instances are programmed by two identical sets of configuration registers. For more information, see [Chapter 15, Memory Management Units](#).

---

3. Programming of the MMU2 is functionally restricted to setting the MMU2.MMU\_CNTL[1] MMUENABLE bit, and the TLB misses are served by the MPU-dedicated interrupt service routine (ISR). However, MMU table-walking logic is preferred because the IVA2.2 must be autonomous after the preliminary settings.

Moreover, it is critical that the duration of the MMU save-and-restore process use a minimum number of cycles, so that address translation for the MMU configuration registers uses a TLB locked entry. For those reasons, it is recommended that the bootstrap follow the MMU initialization sequence:

- (a) Write <TTH physical address>[31:7] to the MMU2.MMU\_TTB[31:17] TTBADDRESS bit field.
- (b) Lock the address translation for the MMU configuration registers.
  - (i) Write 0x0 to the MMU2.MMU\_LOCK[8:4] CURRENTVICTIM bit field.
  - (ii) Write <MMU virtual address>[31:12] to the MMU2.MMU\_CAM[31:12] VATAG bit field.
  - (iii) Write 1 to the MMU2.MMU\_CAM[2] V bit.
  - (iv) Write 0x2 to the MMU2.MMU\_CAM[1:0] PAGESIZE bit field.
  - (v) Write <MMU physical address>[31:12] to the MMU2.MMU\_RAM[31:12] PHYSICALADDRESS bit field.
  - (vi) Write 1 to the MMU2.MMU\_LD\_TLB[0] LDTLBITEM bit.
  - (vii) Write 0x1 to the MMU2.MMU\_LOCK[8:4] CURRENTVICTIM bit field.
  - (viii) Write 0x1 to the MMU2.MMU\_LOCK[14:10] BASEVALUE bit field.
- (c) Write 1 to the MMU2.MMU\_CNTL[2] TWLENABLE bit.
- (d) Write 1 to the MMU2.MMU\_CNTL[1] MMUENABLE bit.
- (e) Read back the MMU2.MMU\_CNTL register to ensure write completion.

---

**NOTE:** This read does not generate a TLB miss, because the address translation for MMU configuration registers is locked in the TLB.

---

4. The MPU can lock some other TLB entries, define some power-management MMU settings, and/or enable some interrupts.
5. The MPU correctly programs the associated L3 firewall, ensuring that the DSP CPU has read access to the memory area containing the IVA2.2 bootstrap sequence.
6. The MPU programs the associated L3 firewall, ensuring that the DSP CPU has read and write access to the configuration registers of the MMU2.
7. The MPU writes <bootloader physical address> to the CONTROL.CONTROL\_IVA2\_BOOTADDR[31:10] BOOTADDR bit field and configures the correct CONTROL.CONTROL\_IVA2\_BOOTMOD[3:0] BOOTMOD bit field nonzero value.

---

**NOTE:** For a detailed description of the system boot registers, see [Chapter 13, System Control Module](#).

---

8. The MPU configures the IVA2.2 clock rate and IVA2.2-related power-management settings in the PRCM.

After initialization completes, the MPU allows the IVA2.2 to boot:

- (a) The MPU releases the IVA2.2 from the OFF state by programming the PRCM.

- (b) The MPU sets the clocks back to the IVA2.2.
- (c) The MPU releases the IVA2.2 from reset.

**NOTE:** Following Steps 1 through 8, the IVA2.2 boot sequence is identical to the autonomous boot sequence. For information about the IVA2.2 boot sequence, see [Section 5.4.1, IVA2.2 Boot](#).

**Figure 5-26. IVA2 Boot Basic Programming Model**



iva2-037

#### 5.4.1.2.2 Autonomous Boot

On an OFF-to-ACTIVE transition (under MPU control or upon interrupt wakeup), the IVA2.2 subsystem is released from reset.

After hardware configuration of values for DSP megamodule generic parameters, the IVA2.2 starts fetching from the address 0x00000000 in ROM. The IVA2.2 must follow the (nonexhaustive) boot process:

1. Configure memory protection:
  - (a) Specify cache RAMs versus IDMA and DMA accesses.
  - (b) Define accessible L2 space (static shared L2 with the MPU/LCD).
2. Load the bootstrap code:
  - (a) Read the IVA\_SYSC.SYSC\_BOOTADDR[31:12] BOOTLOADADDR bit field.
  - (b) Read the number of bootstrap words <NbOfWords> to transfer in the first word at the address pointed to by BOOTLOADADDR.
  - (c) Transfer as many words as defined in <NbOfWords>.
3. Execute the bootstrap code.

**NOTE:** This prepares the MMU for address translation of external accesses. In the case of a boot upon interrupt wakeup, the MMU is restored to its exact context before the IVA2.2 is shut off, if this context was saved correctly.

Only from this point can the IVA2.2 subsystem work with virtual addresses.

## 5.4.2 Sequencer Boot/Reset

After the reset input signal is applied to the video accelerator/sequencer, all modules are operational except the sequencer CPU, which is maintained under reset so that the host can initialize some configuration registers and upload some boot code in the ITCM and DTCM memories of the sequencer.

The sequencer reset is connected on IVA2\_RST3, and this reset is controlled by the PRCM. The DSP megamodule or the MPU can release the IVA2\_RST3 by clearing the PRCM.RM\_RSTCTRL\_IVA2[2] RST3\_IVA2 bit.

When the sequencer reset (IVA2\_RST3) is released, the sequencer starts fetching instructions from ITCM memory, which is initialized by the DSP megamodule or the MPU before the sequencer reset is released. Thus, a classic boot/reset sequence follows the sequence (only the sequencer is under reset; other modules like iME, iVLCD, and iLF are already out of reset):

1. The DSP initializes the ITCM sequencer memory with sequencer code.
2. The DSP initializes the DTCM sequencer memory with sequencer data.
3. The DSP sets the clock divider for the sequencer module in the IVA.[VIDEOSYSC\\_CLKDIV](#) register.
4. The DSP releases the sequencer from reset by clearing the PRCM.RM\_RSTCTRL\_IVA2[2] RST3\_IVA2 bit.

The sequencer is autonomous (no longer under DSP control).

The DSP and the sequencer processor communicate through a message box; two interrupts are provided for this purpose.

---

**NOTE:** For more information about sequencer boot/reset, see *ARM968E-S Technical Reference Manual ARM*.

---

## 5.4.3 Cache Management

The IVA2.2 subsystem has a 2-level cache-based architecture. Level 1 data memory/cache (L1D) consists of an 80-KB memory space dedicated to data. L1D memory can be configured as mapped memory, cache, or a combination of the two. The level 1 program memory/cache (L1P) consists of a 32-KB memory space dedicated to program instructions. L1P memory can be configured as mapped memory, cache, or a combination of the two. Level 2 memory/cache (L2) consists of a 96-KB memory space shared by program and data space. L2 memory can be configured as mapped memory, cache, or a combination of the two.

Configuration of the allocation of the L1D, L1P, and L2 memories to mapped memory and/or cache is described in [Section 5.4.3.1, Cache-Size Configuration](#).

The virtual address space is split into contiguous chunks to configure which parts of the memory are cacheable and not cacheable. Configuration of cacheability is described in [Section 5.4.3.3, Cacheability Settings](#).

### 5.4.3.1 Cache-Size Configuration

Cache-size configuration is controlled by a set of registers: IVA\_XMC.[L1PCFG](#), IVA\_XMC.[L1DCFG](#), and IVA\_XMC.[L2CFG](#), that correspond to the L1P, L1D, and L2 memories, respectively.

The IVA\_XMC.[L1PCFG](#) register allows the selection of the size of the L1P cache. The user selects the size of the L1P cache by writing the requested mode to the [L1PCFG\[2:0\]](#) L1PMODE bit field.

[Table 5-13](#) lists the valid settings of L1PMODE.

**Table 5-13. Cache Size Specified by L1PMODE**

| <b>L1PCFG[2:0] L1PMODE</b> | <b>Amount of L1P</b> |
|----------------------------|----------------------|
| Setting                    | Cache                |
| 000b                       | 0 KB (default)       |
| 001b                       | 4KB                  |

**Table 5-13. Cache Size Specified by L1PMODE (continued)**

| <b>L1PCFG[2:0] L1PMODE</b> | <b>Amount of L1P</b>         |
|----------------------------|------------------------------|
| 010b                       | 8KB                          |
| 011b                       | 16KB                         |
| 100b                       | 32KB                         |
| 101b                       | Not used                     |
| 110b                       | Not used                     |
| 111b                       | Maximum cache (maps to 32KB) |

The IVA\_XMC.L1DCFG register allows the selection of the size of the L1D cache. The user selects the size of the L1D cache by writing the requested mode to the **L1DCFG[2:0]** L1DMODE bit field.

[Table 5-14](#) lists the valid settings of L1DMODE.

**Table 5-14. Cache Size Specified by L1DMODE**

| <b>L1DCFG[2:0] L1DMODE</b> | <b>Amount of L1D</b>         |
|----------------------------|------------------------------|
| Setting                    | Cache                        |
| 000b                       | 0KB (default)                |
| 001b                       | 4KB                          |
| 010b                       | 8KB                          |
| 011b                       | 16KB                         |
| 100b                       | 32KB                         |
| 101b                       | Not used                     |
| 110b                       | Not used                     |
| 111b                       | Maximum cache (maps to 32KB) |

In the same way, the **L2CFG[2:0]** L2MODE bit field controls the size of the L2 cache. The user sets the amount of L2 memory mapped as L2 cache by writing the desired cache mode to this bit field.

[Table 5-15](#) shows the valid settings for L2MODE.

**Table 5-15. Cache Size Specified by L2MODE**

| <b>L2CFG[2:0] L2MODE</b> | <b>Amount of L2</b> |
|--------------------------|---------------------|
| Setting                  | Cache               |
| 000b                     | 0KB (default)       |
| 001b                     | 32KB                |
| 010b                     | 64KB                |

When programs initiate a cache mode change, the L1D cache must write back and invalidate its current contents without losing data. This ensures that all updated data held in cache is written back, and that no false hits occur because of a change in the interpretation of cache tags. It also ensures that the L1D snoop tag RAM in the UMC stays in sync with L1D.

While the write-back-invalidate is required to ensure correct cache behavior and to ensure that no cached data is lost, it is not sufficient to prevent data loss as a result of portions of L1D RAM becoming cache. To safely change L1D cache modes, applications must adhere to the procedure described in [Table 5-16](#).

**Table 5-16. Switching Cache Modes**

| <b>To switch from</b>        | <b>To</b>              | <b>The program must perform the following steps:</b>                                                                                                                                                                  |
|------------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A mode with no or some cache | A mode with more cache | 1: EDMA, IDMA, or copy necessary data out of the affected range of RAM.<br>2: Write the desired cache mode to the bit field in the configuration cache register ( <b>L1DCFG</b> , <b>L1PCFG</b> , and <b>L2CFG</b> ). |

**Table 5-16. Switching Cache Modes (continued)**

| To switch from         | To                           | The program must perform the following steps:                                                                                                                                                                                                                                        |
|------------------------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A mode with some cache | A mode with less or no cache | <p>3: Read back the register to stall the DSP CPU until the mode change completes.</p> <p>1: Write the desired cache mode to the bit field in the cache configuration register concerned.</p> <p>2. Read back the register to stall the DSP CPU until the mode change completes.</p> |

L1P RAM is typically used as cache RAM, with no local flat RAM (not the default; must be configured by the user).

L1D RAM is typically used as 32KB allocated to the cache RAM and 48KB has local memory-mapped RAM. By default, L2 memory is configured as 0KB allocated to the cache RAM and 96KB as local memory-mapped RAM (see [Table 5-17](#)).

**Table 5-17. Default Cache Configuration**

| Memory Type | Memory Size | Default Cache Setting |
|-------------|-------------|-----------------------|
| L1P RAM     | 32KB        | 0KB cache             |
| L1D RAM     | 80KB        | 0KB cache             |
| L2 RAM      | 96KB        | 0KB cache             |

#### 5.4.3.2 Cache Mode Configuration

The memory cache controllers of the DSP megamodule (L1D, L1P, and L2) offer two additional operating modes: freeze and/or bypass. These modes are set by the [L1DCC\[2:0\]](#) OPER bit field for L1D, the [L1PCC\[2:0\]](#) OPER bit field for L1P, and the [L2CFG\[4:3\]](#) L2CC bit field for L2.

The freeze and bypass modes affect the operation of only the cache section (no impact on the memory-mapped section of the memory) of each memory controller.

This feature allows real-time applications to limit the amount of data evicted from cache controllers, such as interrupt handlers, during various sections of code.

[Table 5-18](#) summarizes the freeze and bypass modes for each cache controller (set through the OPER field in the [L1PCC](#) register for the L1P cache controller, the OPER field in the [L1DCC](#) register, and the L2CC field of the [L2CFG](#) register for the L2 cache controller).

**Table 5-18. Cache Mode Configuration**

| Cache Controller | Operation Mode                                                                                                       | Cache Controller Operation                                                                                                                                |                                                                                                                      |        |
|------------------|----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--------|
|                  |                                                                                                                      | Normal                                                                                                                                                    | Freeze                                                                                                               | Bypass |
| L1P              | Cache operates normally. Read hits return data from the cache. Write hits update the cached data for the cache line. | The L1P cache does not allocate new cache lines on read misses, nor does it cause existing cache contents to be marked invalid. Write misses are dropped. | The L1P cache responds normally to program-initiated cache controls (invalidate, mode change).                       | N/A    |
| L1D              | Cache operates normally.                                                                                             | The L1D cache does not allocate new cache lines on read misses, nor does it evict existing cache contents.                                                | The L1D cache responds normally to program-initiated cache commands (invalidate, write-back-invalidate mode change). | N/A    |

**Table 5-18. Cache Mode Configuration (continued)**

| Cache Controller | Operation Mode           |                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | Normal                   | Freeze                                                                                                                                                                                                                                                                                            | Bypass                                                                                                                                                                                                                                                                                                                                                                      |
| L2               | Cache operates normally. | Cache frozen. Hits proceed normally. L2 sends read and write misses directly to external memory, as if the L2 cache is not present. The L2 does not allocate a new cache line while frozen. Lines can be evicted from L2 only during freeze mode by program-initiated cache coherence operations. | Cache disabled, although internal cache state is retained. When in bypass mode, the L2 cache responds to neither reads nor writes. All requests for external addresses are sent externally. L2 does not update its contents in this mode. As with freeze mode, L2 evicts lines from L2 only during bypass mode as a result of program-initiated cache coherence operations. |

#### 5.4.3.3 Cacheability Settings

The address space of the IVA2.2 subsystem is split into contiguous regions of 16M bytes each. Each region has a cacheable attribute that defines whether a reference to a location belonging to the associated memory region must be sent directly to the memory (with exact size and occurrence as requested by the CPU) or must induce a cache line refill and potentially an eviction of another cache line.

The UMC contains registers that control whether certain ranges of memory are cacheable, and whether one or more requestors is allowed access to these ranges.

#### 5.4.3.4 Coherence Maintenance

##### 5.4.3.4.1 Memory-Mapped L1P and L1D Coherence

L1D and L1P are never cached, so there is no coherence maintenance for those memories.

##### 5.4.3.4.2 Memory-Mapped L2 Coherence

Coherence is maintained by hardware between L1D cache content and the L2 memory-mapped memory region.

An L2 reference from the DSP CPU updating an L1D cache location is automatically made visible to the DMA and any master processor on the device with access to the DSP megamodule memory-mapped L2 through the IVA2.2 slave port.

An L2 reference from the DMA and any other master processor on the device with access to the DSP megamodule memory-mapped L2 through the IVA2.2 subsystem slave port is automatically made visible to the DSP CPU through the L1D cache, if it is holding the associated cache line.

---

**NOTE:** To reduce the complexity of the L1P cache controller to the L2 controller interface, the L1P cache coherency protocol is removed. This means that coherency between L2 cache and L1P cache is not maintained. On the C64x+ CPU, writes to L2 do not invalidate the corresponding region in L1P. This must be done manually.

---

##### 5.4.3.4.3 Device Memory Coherence

Coherence is not maintained by hardware between the L2 cache (and L1D cache/L1P cache) and device memories (on-chip memories external to the IVA2.2 subsystem and off-chip memories connected to the SDRAM controller and/or general-purpose memory controller [GPMC]). Coherence in this case must be handled by software. The DSP megamodule offers two sets of registers for user-initiated coherence maintenance between DSP local memories and device memories.

Software coherence maintenance must be synchronized in the system (for example, through message passing; for information, see [Chapter 14, Interprocessor Communication](#)). In the producer/consumer model, the producer sends a completion message to the consumer only after the write is complete in end

memory. If the producer has a cache-based architecture, the producer must initiate a write-back and track for the completion of the write-back sequence in end memory. For a description of how the write-back sequence occurs in the IVA2.2 subsystem, see [Section 5.4.3.4.6, Write-Back Completion](#). When the consumer receives the message, if the consumer has a cache-based architecture, updates by the producer must be effectively seen (not a local nonupdated copy). For a description of how the invalidate sequence occurs in the IVA2.2 subsystem, see [Section 5.4.3.4.4, Global Cache Management](#).

Two types of cache coherence management are possible:

- Global cache coherence allows the DSP CPU to ensure coherence of the entire cache at once. See [Section 5.4.3.4.4, Global Cache Management](#).
- Block cache coherence allows the DSP CPU to ensure coherence of a contiguous region of the virtual address map, restricted in size to only what is needed. See [Section 5.4.3.4.5, Block Cache Management](#).

Each management type provides three sets of actions:

- Invalidate ensures that all required lines are made invalid in the cache. After that operation, any update (before invalidate operation) in end memory by an alternate processor/DMA is seen by the DSP CPU, forcing a cache line refill.
- Write-back ensures that all required cache lines modified by the DSP CPU (also called dirty lines) are written back to end memory, so that any local update by the DSP CPU is made visible by an alternate processor/DMA. This applies only to L1D cache and L2 cache, not to L1P cache.
- Write-back and invalidate ensure that all required cache lines modified by the DSP CPU (also called dirty lines) are written back to end memory so that any local update by the DSP CPU is made visible by an alternate processor/DMA, and they ensure that all required lines are made invalid in the cache. After that operation, any update in end memory by an alternate processor/DMA is seen by the DSP CPU, forcing a cache line refill. This applies only to L1D cache and L2 cache, not to L1P cache.

#### **5.4.3.4.4 Global Cache Management**

This section describes how to invalidate and write back the cache memory

- Global invalidate

Global invalidate is controlled by the following registers: IVA\_XMC.[L2INV](#), IVA\_XMC.[L1DINV](#), and IVA\_XMC.[L1PINV](#).

Example of global invalidate:

```
/* ----- */
/* Invalidate anything held in cache. */
/* ----- */
L2INV = 1;
/* ----- */
/* Now, spin waiting for operation to complete. */
/* ----- */
while ((L2INV & 1) != 0)
;
```

[L2INV](#) = 0 ensures that L1D cache and L1P cache are also globally invalidated before the L2 cache invalidate process.

- Global write-back

Global write-back is controlled by the following registers: IVA\_XMC.[L2WB](#) and IVA\_XMC.[L1DWB](#).

Example of global write-back:

```
/* ----- */
/* Write back anything held in cache. */
/* ----- */
L2WB = 1;
/* ----- */
/* Now, spin waiting for operation to complete. */
/* ----- */
```

```
/* ----- */
while ((L2WB & 1) != 0)
;
```

To ensure write-back completion of a specific buffer (contiguous address range), see [Section 5.4.3.4.6, Write-Back Completion](#), for additional programming steps and an example.

- Global write-back and block invalidate

Global write-back and block invalidate is controlled by the following registers: IVA\_XMC.[L2WBINV](#) and IVA\_XMC.[L1DWBINV](#).

Example of global write-back and block invalidate:

```
/* ----- */
/* Write back and invalidate anything held in cache. */
/* ----- */
L2WBINV = 1;
/* ----- */
/* Now, spin waiting for operation to complete. */
/* ----- */
while ((L2WBINV & 1) != 0)
;
```

To ensure write-back completion of a specific buffer (contiguous address range), see [Section 5.4.3.4.6, Write-Back Completion](#), for additional programming steps and an example.

#### **5.4.3.4.5 Block Cache Management**

- Block invalidate

Block invalidate is controlled by the following registers: IVA\_XMC.L2BAR, IVA\_XMC.[L2IWC](#), IVA\_XMC.[L1DIBAR](#), IVA\_XMC.[L1DIWC](#), IVA\_XMC.[L1PIBAR](#), and IVA\_XMC.[L1PIWC](#).

Example of block invalidate:

```
/* ----- */
/* Write base address of array to Base Address Register. /
/* Then write length of the array, in words, to the Word*/
/* Count register. */
/* ----- */
L2IBAR = &array[0];
L2IWC = sizeof(array) / sizeof(int);
/* . . . */
/* ----- */
/* The CPU can execute other code here. Block cache operations proceed in parallel with CPU
execution, stalling the CPU minimally. */
/* ----- */
/* . . . */
/* ----- */
/* Now, spin waiting for operation to complete. */
/* ----- */
while (L2IWC != 0)
;
```

[L2IWC](#) = 0 ensures that L1D cache and L1P cache are also block invalidated before the L2 cache invalidate process.

- Block write-back

Block write-back is controlled by the following registers: IVA\_XMC.[L2WBAR](#), IVA\_XMC.[L2WWC](#), IVA\_XMC.[L1DWBAR](#), and IVA\_XMC.[L1DWWC](#).

Example of block write-back:

```
/* ----- */
/* Write base address of array to Base Address Register.*/
/* Then write length of array, in words, to the Word */
/* Count register. */
/* ----- */
L2WBAR = &array[0];
L2WWC = sizeof(array) / sizeof(int);
/* . . . */
/* ----- */
/* CPU can execute other code here. Block cache operations proceed in parallel with CPU
execution, stalling CPU minimally. */
/* ----- */
/* . . . */
/* ----- */
/* Now, spin waiting for operation to complete. */
/* ----- */
while (L2WWC != 0)
;
```

To ensure write-back completion of a specific buffer (contiguous address range), see [Section 5.4.3.4.6, Write-Back Completion](#), for additional programming steps and an example.

- Block write-back and invalidate

Block write-back and invalidate is controlled by the following registers: IVA\_XMC.[L2WIBAR](#), IVA\_XMC.[L2WIWC](#), IVA\_XMC.[L1DWIBAR](#), and IVA\_XMC.[L1DWIWC](#).

Example of block write-back and invalidate:

```
/* ----- */
/* Write base address of array to Base Address Register.*/
/* Then write length of array, in words, to the Word */
/* Count register. */
/* ----- */
L2WIBAR = &array[0];
L2WIWC = (array) / sizeof(int);
/* . . . */
/* ----- */
/*The CPU can execute other code here. Block cache operations proceed in parallel with CPU
execution, stalling the CPU minimally. */
/* ----- */
/* . . . */
/* ----- */
/* Now, spin waiting for operation to complete. */
/* ----- */
while (L2WIWC != 0)
;
```

To ensure write-back completion of a specific buffer (contiguous address range), see [Section 5.4.3.4.6](#) for additional programming steps and an example.

#### 5.4.3.4.6 Write-Back Completion

The [SYSC\\_LICFG0\[15\]](#) GEMTRUECOMPEN bit must be set to 1 before any DSP CPU C64x+ write for which completion must be ensured. This applies to writes to noncacheable regions and to cache-line write-back completions. By default, [SYSC\\_LICFG0\[15\]](#) GEMTRUECOMPEN = 0. This default is recommended, to statically set that bit (unless the user wants to locally send a large number of writes to a noncacheable memory region):

- [SYSC\\_LICFG0.GEMTRUECOMPEN](#) = 1;

Polling on the L\*WWC (resp. L\*WIWC) ensures that the block write-back operation (and associated invalidate, when applicable) was completely issued by the associated cache controller, but does not ensure that the write-back is effective in end memory.

To get completion of the write-back of a specific buffer after block or global cache write-back, the user must read back from a noncacheable region of the same L3 or L4 target as the buffer (if data is written in external DDR memory, the read access can be on an SDRC register). The C64x + is uninstalled only after the read following the write-back is complete.

In the producer/consumer model, the cache-based producer typically ensures that the produced buffer is visible to the consumer of that buffer by writing back the address range of that buffer and checking for completion of the write-back sequence before sending a completion message to the consumer.

Example:

```
/* ----- */
/* nonCachedArea to be linked to non-cached SDRAM region*/
/* ----- */
#pragma DATA_SECTION(nonCachedDummyVar, ".nonCachedArea")
volatile int nonCachedDummyVar;
/* ----- */
/* outBuffer is produced buffer in SDRAM to be visible to the consumer */
/* ----- */
L2WBAR = &outBuffer[0];
L2WWC = sizeof(outBuffer) / sizeof(int);
/* ----- */
/* L2WWC ensures the sequence is completed by the cache controller but not completed in end
memory */
/* ----- */
while (L2WWC != 0)
;
/* ----- */
/*C64x+ is stalled until dummy memory read has completed which the hardware ensures happens after
write-back of outBuffer completed in SDRAM. */
/* ----- */
int dummyRead = nonCachedDummyVar;
/* ----- */
/* Then C64x SW (producer) can send message to consumer */
/* ----- */
• sendCompletionMsgToConsumer();
```

---

**NOTE:** To ensure completion, the nonCachedDummyVar must be in the same target as the written-back buffer.

---

In the case of the C64x writing in the noncache area: To ensure the completion of the C64x write in physical end memory, set the [SYSC\\_LICFG0 \[15\]](#) GEMTRUECOMPEN bit to 1 and also read back after the last C64x write.

1. DSP write and DMA read

The user writes to some noncache region with DSP and then reads from the same area with DMA.

To ensure completion of the DSP write in physical end memory, set the SYSC.LICFG0[15] GEMTRUECOMPEN bit to 1 and also read back after the last DSP write. The sequence is:

- (a) Set the **SYSC\_LICFG0[15]** GEMTRUECOMPEN bit to 1.
  - (b) DSP writes data in external memory, noncache area.
  - (c) DSP reads data in external memory, noncache area: last write data for instance.
  - (d) DMA reads data from external memory.
2. DMA write and DSP read
- The opposite of 1. To ensure the completion of DMA write in physical end memory, set the **SYSC\_LICFG0** DMATRUECOMPEN bit to 1 and PARAM [LCHi].OPT.TCCMODE to 0 (no early completion). The sequence is:
- (a) Set the **SYSC\_LICFG0.DMATRUECOMPEN** bit to 1.
  - (b) Set PARAM[LCHi].OPT.TCCMODE to 0.
  - (c) Set PARAM[LCHi].OPT.TCCMODE to 0.
  - (d) DSP waits for end of DMA transferred:
    - IPR/IPRH bit update (for polling-scheme)
    - Interrupt generation (for interrupt-scheme)
    - CER/CERH bit update (for chaining)
    - DSP reads data from external memory.

#### **5.4.3.4.7 Performance Consideration Timing**

Long burst is key to improving the efficiency of the SDRAM and reducing cache-line refill and cache-line write-back latencies. The IVA2.2 subsystem allows for improving the burst generation over the device interconnect. This is configurable with the **SYSC\_LICFG0[16].GEMBURSTOPTEN** bit. By default, **SYSC\_LICFG0[16]** GEMBURSTOPTEN = 0, and the burst optimization is disabled. This default is recommended to statically set the bit:

**SYSC\_LICFG0.GEMBURSTOPTEN** = 1

### **5.4.4 DMA Management**

#### **5.4.4.1 Transfers From/to Device Memories/Peripherals (EDMA)**

The EDMA optimizes transfers from/to the DSP megamodule (memory-mapped) memories to/from device on-chip and off-chip memories.

The EDMA can perform transfers from IVA2.2 internal memories to IVA2.2 internal memories, but it is not designed for that purpose. The IDMA is recommended in that case (unless a 2-dimensional transfer is required).

The EDMA can perform transfers from device memories/peripherals to device memories/peripherals, but it is not designed for that purpose. The sDMA is recommended in that case. For more information, see [Chapter 11, DMA](#).

#### **5.4.4.2 Internal Memory-to-Memory Transfer (IDMA)**

The user can quickly page memory regions or fill a memory region of the DSP megamodule memories by using channel 1 of the IDMA module (internal to the DSP megamodule).

The IDMA.**IDMA1\_COUNT[16]** FILL bit defines whether this is a transfer from memory to memory or if this is a solid-color fill.

An IDMA1 transfer where IDMA.**IDMA1\_COUNT[16]** FILL = 0 copies IDMA.**IDMA1\_COUNT[15:2]** COUNT bytes from the address defined in the IDMA.**IDMA1\_SOURCE** register to the address defined in the IDMA.**IDMA1\_DEST** register. The addresses must be aligned on word (4-byte) boundaries. The byte count must be a multiple of 4 bytes.

The IDMA.IDMA1\_COUNT[28] INT register bit enables the IDMA\_INT1 interrupt (Evt 14; for information about generation on completion of the IDMA1 transfer, see [Table 5-3](#)). By default, no interrupt is generated.

When conflicts occur, the IDMA.IDMA1\_COUNT[31:29] PRI bit field defines the priority of the IDMA transfer with respect to DSP and DMA/HOST accesses.

The memory paging programming example follows:

- `IDMA1_SOURCE = &mySrcTable[0]; // mySrcTable aligned on word boundary`
- `IDMA1_DEST = &myDstTable[0]; // myDstTable aligned on word boundary`
- `IDMA1_COUNT = (IDMA1_COUNT & ~(0xFFFF)) | size of (mySrcTable);`
- `IDMA1_COUNT = (IDMA1_COUNT & ~(116)) | 016; // copy mode`
- `IDMA1_COUNT = (IDMA1_COUNT & ~(128)) | 028; // no interrupt`
- `IDMA1_COUNT = (IDMA1_COUNT & ~(0x729)) | 0x729; // low priority`

An IDMA1 transfer where iDMA.IDMA1\_COUNT[16] FILL = 1 replicates the IDMA.IDMA1\_SOURCE word as many times as defined in IDMA. An `IDMA1_COUNT.COUNT` (count divided by 4) to the address defined in the IDMA.IDMA1\_DEST destination address must be aligned on word (4-byte) boundaries. The byte count must be a multiple of 4 bytes.

The solid-color copy (SSC) programming example follows:

- `IDMA1_SOURCE = my32bPattern; // 32b pattern to be replicated`
- `IDMA1_DEST = &myDstTable[0]; // myDstTable aligned on word boundary`
- `IDMA1_COUNT = (IDMA1_COUNT & ~(0xFFFF)) | size of (mySrcTable);`
- `IDMA1_COUNT = (IDMA1_COUNT & ~(116)) | 116; // SCC mode`
- `IDMA1_COUNT = (IDMA1_COUNT & ~(128)) | 028; // no interrupt`
- `IDMA1_COUNT = (IDMA1_COUNT & ~(0x729)) | 0x729; // low priority`

---

**NOTE:** Because the IVA2.2 subsystem is typically configured (recommended for video applications) so that L1D has memory-mapped SRAM, IDMA1 is normally used only for L1D>L1D fast copy.

---

#### 5.4.4.3 Programming an EDMA Transfer

Programming a complete EDMA transfer requires the following steps:

1. Define the logical channel(s).
2. Prioritize the defined transfer (with respect to other defined transfers).
3. Start the transfer.
4. Review the progression and completion of the transfer.

#### 5.4.4.4 Defining a Logical Channel

##### 5.4.4.4.1 Single Logical Channel Definition

A complete EDMA transfer can be defined by one or several chained and/or linked logical channels.

Up to 128 independent contexts, each fully defining a logical channel, can be defined. These 128 contexts correspond to the 128 PaRAM entries available in the IVA2.2 subsystem. For more information about these PaRAM entries, see [Section 5.3.2.1.1.3, DMA/QDMA Channel Mapping and PaRAM Entry](#), and the corresponding [Figure 5-13](#).

Logical channel definition relies on the following:

- Base addresses:
  - `PARAM[LCH#].SRCi`: 32-bit source address
  - `PARAM[LCH#].DSTi`: 32-bit destination address

- Transfer sizes:

Transfer size is common to source and destination. A transfer can be constituted on a 3-dimensional array; C is an array of CCNT arrays, each composed of BCNT arrays, each composed of ACNT bytes:

- PARAM[LCH#].ACNT: Number of bytes in the A array (from 0 to 65,535)
- PARAM[LCH#].BCNT: Number of A arrays in the B array (from 0 to 65,535)
- PARAM[LCH#].CCNT: Number of B arrays in the C array (from 0 to 65,535)

---

**NOTE:** Setting one of the ACNT, BCNT, or CCNT arrays to 0x0 prevents a transfer from being submitted to one of the physical channels (assuming that the compatibility mode is not set).

- PARAM[LCH#].BCNTRLD: BCNT reload value when BCNT reaches 0 (from 0 to 65,535)

---

**NOTE:** When programming CCNT>1, programming PARAM[LCH#].BCNTRLD to be equal to PARAM[LCH#].BCNT is recommended.

- Indexes between dimensions:

- PARAM[LCH#].SRCBIDX: Index between A arrays at source (from -32,768 to 32,767)
- PARAM[LCH#].SRCIDX: Index between B arrays at source (from -32,768 to 32,767)
- PARAM[LCH#].DSTBIDX: Index between A arrays at destination (from -32,768 to 32,767)
- PARAM[LCH#].DSTCIDX: Index between B arrays at destination (from -32,768 to 32,767)

---

**NOTE:** Programming the logical channel does not automatically start it. See [Section 5.4.4.6.1, Assigning a Logical Channel to a Trigger Event](#).

- Addressing modes:

- PARAM[LCH#].OPT[0] SAM: source addressing mode (0: post-incremented; 1: constant)
- PARAM[LCH#].OPT[1] DAM: destination addressing mode (0: post-incremented; 1: constant)

---

**NOTE:** Constant addressing mode is supported only from/to IVA2.2 DSP megamodule memories, not from/to device memories and peripherals. This can be replaced by using a post-increment addressing mode and an index equal to 0.

Example:

```
/* -----
 *fills dstArray with cstValue values (w/o constant AM) */
/* ----- */

PARAM[LCH#].SRC = &cstValue;
PARAM[LCH#].DST = &dstArray[0];
PARAM[LCH#].ACNT = sizeof(int);
PARAM[LCH#].BCNT = sizeof(dstArray) / sizeof(int);
PARAM[LCH#].CCNT = 1;
PARAM[LCH#].SRCBIDX = 0;
PARAM[LCH#].DSTBIDX = sizeof(int);
PARAM[LCH#].OPT.SAM = 0;
PARAM[LCH#].OPT.DAM = 0;
```

#### 5.4.4.4.2 Controlling Submission Granularity

The logical channel (when triggered) can split a transfer into several requests submitted to one of the physical channels. The physical channel supports submitted requests of up to two dimensions, meaning that a 3-dimensional transfer is always split into (at least) 2-dimensional transfers. The user can also program the logical channel so that submitted requests are 1-dimensional transfers; for example:

- PARAM[LCH#].SYNCDIM = 0; // submitted transfers are maximum 1D.
- PARAM[LCH#].SYNCDIM = 1; // submitted transfers are maximum 2D.

#### 5.4.4.4.3 Linking to Another Logical Channel

A logical channel can be programmed so that on its completion another context is copied from another logical channel. This is useful because the logical channel is used as a working set during the DMA transfer, meaning that initial context configuration is lost after the associated transfer completes.

- PARAM[LCH#].LINK = linkLCH# << 5

The LINK value is the base address of the linked logical channel context.

When the LINK value is set to 0xFFFF, no context is loaded for that logical channel:

- PARAM[LCH#].LINK = -1

---

**NOTE:** Only the context is copied, and the logical channel is not automatically restarted on link. Restarting a logical channel that just received its new context occurs only after a trigger event associated with that logical channel is detected. See [Section 5.4.4.6.1, Assigning a Logical Channel to a Trigger Event](#).

---

#### 5.4.4.4 Chaining Logical Channel

A logical channel can be programmed so that on its total or partial completion, another logical channel is started. This is useful for defining a series of transfers with different contexts as a complete DMA transfer. The main advantage is that the overhead to program all the chained transfers is shared among all channels.

- Partial completion chaining

After the submitted section (see [Section 5.4.4.2, Controlling Submission Granularity](#)) of a logical channel is complete, a programmable completion code is returned. If partial completion chaining is enabled in the context of the logical channel, this completion code defines which trigger event is set. The logical channel associated with that trigger event is automatically submitted. See [Section 5.4.4.6.1, Assigning a Logical Channel to a Trigger Event](#).

To chain a logical channel LCH<sub>i</sub> to LCH<sub>j</sub>, so that LCH<sub>j</sub> is automatically started after each LCH<sub>i</sub> submission to a physical channel has completed:

- PARAM[LCH<sub>i</sub>].OPT.TCC = trigEvt<sub>x</sub>; // trigEvt<sub>x</sub>: trigger event number
- PARAM[LCH<sub>i</sub>].OPT.ITCCHEN = 1
- DCHMAP[trigEvt<sub>x</sub>] = LCH<sub>j</sub>

- Total completion chaining

After all submitted parts of a logical channel are complete, programmable completion code is returned. If total completion chaining is enabled in the context of the logical channel, this completion code defines which trigger event is set. The logical channel associated with that trigger event is automatically submitted. See [Section 5.4.4.6.1, Assigning a Logical Channel to a Trigger Event](#).

For example, to chain a logical channel LCH<sub>i</sub> to LCH<sub>j</sub> so that LCH<sub>j</sub> is automatically started after LCH<sub>i</sub> has completed:

- PARAM[LCH<sub>i</sub>].OPT.TCC = trigEvt<sub>x</sub>; // trigEvt<sub>x</sub>: trigger event number
- PARAM[LCH<sub>i</sub>].OPT.TCCHEN = 1
- DCHMAP[trigEvt<sub>x</sub>] = LCH<sub>j</sub>

### 5.4.4.5 Prioritizing Defined Transfers

#### 5.4.4.5.1 Mapping Between DMA/QDMA Events and Event Queues

The assignment of 64 DMA and 8 QDMA channels to two event queues of the channel controller is achieved by configuring the DMA queue number registers ([TPCC\\_DMAQNUM0](#) and [TPCC\\_DMAQNUM1](#)) and the QDMA queue number register ([IVA\\_TPCC.QDMAQNUM](#)). When an event is selected for submission, it is queued in the user-defined event queue. This typically defines a 2-level priority preemption scheme, as queues are usually mapped to different transfer controllers.

#### 5.4.4.5.2 Mapping a Queue to a Transfer Controller

Events at the head of an event queue define which logical channel (Param Entry) is selected for submission to the associated physical channel (transfer controller). The association between an event queue and a physical channel can be defined in the [TPCC\\_QUETCMAP](#) register. By default, TPTC0 is associated with event queue 0, and TPTC1 is associated with event queue 1. This mapping is a static decision; it does not change during DMA operation.

---

**NOTE:** TPTC0 and TPTC1 are not symmetrical; their numbers are just inverted, compared to the Davinci device. To improve compatibility with Davinci devices, invert the mapping of the event queue to the transfer controller, as shown below:

$$\text{QUETCMAP} = (\text{QUETCMAP} \& \sim 0xFF) | 0x10;$$

Typically, this is used to allow submission-time preemption, so that by example:

- Event queue 0 is used for background, potentially long, not very latency-sensitive, not very critical DMA transfers.
  - Event queue 1 is used for short, latency-sensitive, or critical (for example, hardware synchronized) DMA transfers.
- 

#### 5.4.4.5.3 Handling Priority

In IVA2.2 local interconnect arbitration, priority of individual bus requests for a DMA transfer over other DMA- or CPU-initiated bus requests is defined by the event queue to which the event associated with the transfer is submitted. This can be configured per event queue in the [TPCC\\_QUEPRI\[2:0\]](#) PRIQ0 and [TPCC\\_QUEPRI\[6:4\]](#) PRIQ1 bit fields. By default, event queues 0 and 1 have the same priority (highest possible priority is 0x0).

CPU bus-requests priority is defined in the IDMA.[MDMAARBE\[18:16\]](#) PRI bit field. By default, the CPU has the lowest possible priority (0x7).

Typically, this is used to allow transfer-time preemption, so that, for example, bus requests associated with event queue 1 are served ahead of event queue 0 or CPU requests.

Example:

- // DMA#0->0x7 (lowest), DMA#1->0x0 (highest), CPU->0x4 (mid)
- QUEPRI = (QUEPRI & ~0xFF) | 0x07;
- [MDMAARBE](#) = (QUEPRI & ~(0xF16)) | 0x4 16;

#### 5.4.4.5.4 Aged Priority

To prevent having a DMA request stalled for a very long time, the IVA2.2 implements an aged priority scheme (also referred to as an inversion priority scheme) on the DMA ports to change the priority defined in the [TPCC\\_QUEPRI](#) register. This is done by regularly decreasing the priority level (increasing priority in arbitration) of a stalled request. The interval between two consecutive updates of the priority level is defined in the [SYSC\\_LICFG1](#) register. By default, the aged priority scheme is disabled ([SYSC\\_LICFG1](#)=0x0), and arbitration priority is dictated by programmed values in QUEPRI and [MDMAARBE](#).

#### 5.4.4.5.5 Optimizing 2D Transfers

IVA2.2 EDMA can be configured so that DMA 2D transfers are optimized, allowing for large bursts to be generated to the SDRAM. This optimization has no effect on transfers issued as 1D transfers to the physical channels. This is recommended to enable that feature when the sources or destinations of the 2D transfers are the VRFB (SDRAM tiling structure).

To fully benefit from the optimization and disable MMU page-crossing checks:

- Large MMU page(s) are defined for the VRFB view(s) (typically 16MB supersection).
- The user software ensures that a 2D transfer does not span MMU large pages.

With the preceding conditions, use the following settings to use the IVA2.2 2D burst optimization:

- IVA\_SYSC.SYSC\_LICFG0.DMA2DOPTEN = 1
- IVA\_SYSC.SYSC\_LICFG0.PAGEARINGEN = 1

---

**NOTE:** The user software must ensure that a 2D transfer never spans MMU page boundaries. The reason for IVA\_SYSC.SYSC\_LICFG0.PAGEARINGEN = 1 is to remove the hardware check mechanism of 2D bursts crossing MMU pages. A 2D burst that spans these boundaries can lead to undefined behavior. PAGEARINGEN = 0 prevents such situations through hardware.

---

#### 5.4.4.6 Starting the Transfer

Before starting the transfer, a trigger event must be associated with the logical channel. Three modes trigger a DMA transfer:

- Manual trigger (software-synchronized transfers)
- Hardware trigger (hardware-synchronized transfers)
- Automatic trigger (automatic on-submission transfer start)

##### 5.4.4.6.1 Assigning a Logical Channel to a Trigger Event

The 64 DMA channels and the 8 QDMA channels can be flexibly mapped to any of the 128 available PaRAM entries (see [Figure 5-13](#)).

Any of the 64 DMA channels can be mapped to any of the 128 PaRAM entries through DMA channel-mapping registers [TPCC\\_DCHMAP<sub>i</sub>](#) ( $i = 0$  to 63).

Any of the 8 QDMA channels can be mapped to any of the 128 PaRAM entries through QDMA channel-mapping registers [TPCC\\_QCHMAP<sub>j</sub>](#) ( $j = 0$  to 7).

##### 5.4.4.6.2 Manual Trigger (Software-Synchronized Transfers)

When a logical channel is defined and prioritized, the user can assign the logical channel (or the first in the chained list) to a trigger event (from 0 to 63) by writing the number of the logical channel (PaRAMEntry #) to one of the DMA channel-mapping registers [TPCC\\_DCHMAP<sub>i</sub>](#) ( $i = 0$  to 63). Then, the user can manually start the transfer (one logical channel or a chained list of logical channels) by writing 1 to the bit in the [TPCC\\_ESR](#) or [TPCC\\_ESRH](#) register associated with the trigger event of the logical channel (or the first logical channel in the chained list).

---

**NOTE:** The event does not need to be enabled in the [TPCC\\_EER](#) register to be manually triggered.

---

Example:

```
/* ----- */  
/*To manually start defined logical channel #0x3, uses event #20 */  
/* ----- */  
DCHMAP[20] = (DCHMAP[20] & ~(0x1FF<<5)) | 0x3<<5;  
ESR = 1 << 20;
```

#### 5.4.4.6.3 Hardware Trigger (Hardware-Synchronized Transfers)

When a logical channel is defined and prioritized, the user can assign the logical channel (or the first in the chained list) to a trigger event (from 0 to 19) by writing the number of the logical channel (PaRAMEntry #) to one of the DMA channel-mapping registers [TPCC\\_DCHMAPi](#) (i = 0 to 19). The user can allow this logical channel to be triggered by an associated hardware DMA request by writing 1 in the associated bit of the EER register. The mapping of a hardware DMA request to DMA events is fixed. The mapping of DMA requests to device peripheral sources is listed in [Table 5-2](#).

Example:

```
/* -----
/* Associate defined logical channel #0x5 to UART3_DMA_TX*/
/* UART3_DMA_TX is DMA request #10 and associated to evt #10 */
/* -----
DCHMAP[10] = (DCHMAP[10] & ~(0x1FF<<5)) | 0x5<<5;
```

#### 5.4.4.6.4 Automatic Trigger (QDMA)

The user can specify a trigger word from among any of the eight 32-bit words of the logical channel context (PaRAM entry) for QDMA. Writing to the trigger word triggers the channel controller of QDMA to issue a transfer request. The trigger word field of the QDMA channel mapping register [TPCC\\_QCHMAPj](#) (where j = {0 to 7}) defines the trigger word for a particular QDMA channel, as shown in [Figure 5-13](#).

This flexibility enables the CPU to selectively modify only the PaRAM entry that requires modification, and thereby trigger the transfer. For example, after a transfer, if only count must change, QCHMAP can be configured so that count is the trigger word, and a write to it automatically triggers the transfer.

Example:

```
/* -----
/* Associate defined logical channel #0x5 to QDMA #1 */
/* -----
QCHMAP[1] = (QCHMAP[1] & ~(0x1FF<<5)) | 0x5<<5;
/* -----
/* Define DST parameter (0x3) to be trigger word of LCH */
/* -----
QCHMAP[1] = (QCHMAP[1] & ~(0x7<<2)) | 0x3<<2;
```

In addition, the IDMA can be used to offload the CPU of the DMA configuration. See [Section 5.4.4.6.5, Offloaded Configuration \(Using IDMA\)](#).

#### 5.4.4.6.5 Offloaded Configuration (Using IDMA)

The IVA2.2 allows quick programming of DMA transfers by offloading the CPU of most of the DMA transfer issue time. To do so, the user typically maintains a copy of the logical channel contexts (PaRAM entries) in L1D SRAM. A CPU update of a logical channel context is very fast in L1D SRAM. After completing a logical channel context update, the CPU can page the context from L1D to DMA PaRAM entries using another simple DMA, internal-to-DSP megamodule (IDMA). For example:

```
disable_interrupts();
while(IDMA0_STATUS & 0x3);// previous IDMA completion/*
----- */
/* Update of logical channels definition table in L1D */
/* -----
LCTable->OPT = opt;
LCTable->SRC = src;
LCTable->ACNT = num_bytes;
```

```
LCTable->BCNT = num_arrays;  
LCTable->DST = dst;  
LCTable->DSTBIDX = dbidx;  
LCTable->SRCBIDX = sbidx;  
LCTable->LINK = 0xFFFF;  
LCTable->BCNTRLD = bcntrld;  
LCTable->DSTCIDX = dcidx;  
LCTable->SRCCIDX = scidx;  
LCTable->CCNT = num_frames;  
/* ----- */  
/* initiate IDMA transfer */  
/* ----- */  
IDMA0_SOURCE = &LCTable[0];  
IDMA0_DEST = &PaRAM[0];  
IDMA0_MASK = 0xFFFFF00;  
IDMA0_COUNT = 0x0;  
enable_interrupts();
```

#### 5.4.4.6.6 Direct Configuration to Transfer Channel (Not Recommended)

The registers of the physical channels are memory-mapped, primarily to enable, clear, and read status for error interrupts generated by the physical channel. For more information, see [Section 5.4.11, Error Identification Process](#).

It is possible to write directly to other control registers of the physical channels and issue a transfer; however, this is not recommended and therefore is not described here.

---

**NOTE:** This can work safely only if the DMA controller is not used.

---

#### 5.4.4.6.7 DMA Completion Mode

The IVA2.2 EDMA defines when a DMA transfer is complete:

- Early completion: All associated transfers were submitted to the physical channel. Early completion does not ensure that transfer is complete in end memory.
  - **PARAM[LCHi].OPT.TCCMODE** = 1
- True completion: All associated transfers were submitted to the physical channel, and all those transfers are complete, from the physical channel standpoint. True completion ensures that transfer is complete in end memory.
  - **SYSC.SYSC\_LICFG0.DMATRUECOMPEN** = 1; // is statically set.
  - **PARAM[LCHi].OPT.TCCMODE** = 0

---

**NOTE:** TCCMODE = 0 does not ensure that transfer is complete in end memory if DMATRUECOMPEN = 0.

---

By default, DMATRUECOMPEN = 0. This is recommended to statically set DMATRUECOMPEN.

True completion is typically used when the IVA2.2 DMA is the producer of a buffer shared with another master processor or a DMA (consumer). A completion message is sent to the consumer only after the DMA transfer is complete.

Completion mode affects timing for the following actions:

- IPR/IPRH bit update (for polling scheme)
- Interrupt generation (for interrupt scheme)
- CER/CERH bit update (for chaining)

#### **5.4.4.6.8 Partial Versus Total Completion**

DMA can be programmed so that IPR bit update and interrupt generation occur:

- After each submission to the physical channel is complete
- After the last submission to the physical channel is complete

##### **Partial completion interrupt**

After the submitted section (see [Section 5.4.4.2, Controlling Submission Granularity](#)) of a logical channel is complete, a programmable completion code is returned. If a partial completion interrupt is enabled in the context of the logical channel, this completion code defines which IPR bit is set.

For example, to allow IPR to be updated (and possibly an interrupt to be generated) after each LCHi submission to a physical channel is complete:

- PARAM[LCHi].OPT.TCC = intEvt; // intEvt: IPR bit to be updated
- PARAM[LCHi].OPT.ITCINTEN = 1

##### **Total completion interrupt**

After all submitted parts of a logical channel are complete, a programmable completion code is returned. If a total completion interrupt is enabled in the context of the logical channel, this completion code defines which IPR bit is to be set.

For example, to allow IPR to be updated (and possibly an interrupt to be generated) after all LCHi submissions to a physical channel are complete:

- PARAM[LCHi].OPT.TCC = intEvt; // intEvt: IPR bit to be updated
- PARAM[LCHi].OPT.TCINTEN = 1
  - By polling
  - By interrupt

#### **5.4.4.6.9 Tracking DMA Completion**

There are two ways to track DMA completion:

- Polling the completion register when the estimated completion time has elapsed
- Enabling completion interrupts

##### **Polling example (total completion)**

- PARAM[myLCH].OPT.TCINTEN = 1; // total interrupt completion bit update
- PARAM[myLCH].OPT.ITCINTEN = 0; // no partial interrupt completion bit update
- PARAM[myLCH].OPT.TCC = myTCC
- // myTCC does not contribute to interrupt generation (polling mode)
- IER = (IER & ~(1<<myTCC)) | 0<<myTCC
- // start transfer
- DCHMAP[myEvt] = (DCHMAP[myEvt] & ~0x1FF<<5) | myLCH<<5
- ESR = 1 << myEvt
- // do something useful (that does not depend on DMA completion)
- // poll IPR bit
- while( !(IPR & (1<<myTCC)) ); // polls for completion

##### **Interrupt example (total completion)**

- disable\_interrupts()

- PARAM[myLCH].OPT.TCINTEN = 1; // total interrupt completion bit update
- PARAM[myLCH].OPT.ITCINTEN = 0; // no partial interrupt completion bit update
- PARAM[myLCH].OPT.TCC = myTCC
- // myTCC does contribute to interrupt generation (polling mode)
- IER = (IER & ~(1<<myTCC)) | 1<<myTCC
- INTMUX[0] = (INTMUX[0] & ~(0x7F)) | 0x1D; // map CPU it #4
- CPU.IER = (CPU.IER & (1<<4)) | 1<<4; // unmask CPU it #4
- enable\_interrupts()
- // start transfer
- DCHMAP[myEvt] = (DCHMAP[myEvt] & ~(0x1FF<<5)) | myLCH<<5
- ESR = 1 << myEvt
- // do something useful (that does not depend on DMA completion)
- // this code is interrupted when DMA completes

#### 5.4.4.6.10 DMA Interrupt Service Routine

The channel controller does not generate a new interrupt signal for new pending interrupts if the user did not clear previous pending interrupts. There are two options for constructing an ISR for DMA. The first is to poll all the bits during execution of the ISR, and to clear all enabled bits in an interrupt-pending register by writing to the interrupt-pending clear (ICR/ICRH) register before exiting any ISR. Pseudo-code for this option follows:

1. Enter ISR.
2. Read [TPCC\\_IPR](#).
3. For the condition set in [TPCC\\_IPR](#),
  - (a) Perform operation as needed.
  - (b) Clear bit for serviced INT.
4. Read IPR.
  - (a) If [TPCC\\_IPR](#) = 0, exit ISR.
  - (b) If [TPCC\\_IPR](#) = 1, go to Step 3.

The second option is to service the ISR and then, before exiting the ISR, to write to the EVAL bit of the IEVAL register. This forces the EDMA channel controller to generate a new interrupt signal if there are still pending interrupts in the interrupt-pending register (IPR/IPRH). Pseudo-code for this ISR option follows:

1. Enter ISR.
2. Read [TPCC\\_IPR](#).
3. For the condition set in [TPCC\\_IPR](#),
  - (a) Perform operation as needed.
  - (b) Clear bit for serviced INT.
4. Read IPR.
  - (a) If [TPCC\\_IPR](#)=0, exit ISR.
  - (b) If [TPCC\\_IPR](#)=1, set the [TPCC\\_IEVAL](#).EVAL bit to force triggering a new interrupt.

#### 5.4.4.6.11 Benchmarking

The DMA channel controller monitors the number of event entries in an event queue to determine whether they exceed the user-programmed threshold. The queue threshold for each event queue can be programmed in the [TPCC\\_QWMTHRA](#) and [TPCC\\_QWMTHR](#) registers. When the number of event entries in an event queue exceeds the user-programmed threshold, a queue threshold error occurs. This error is captured in the THRXC field of event-queue status register [TPCC\\_QSTATI](#) ( $I = 0$  or  $1$ ) and in the QTHRXC $D_n$  field in the [TPCC\\_CCERR](#) register.

## 5.4.5 IVA2.2 Extended Function Interface

This section describes the extended function interface (EFI) signals, timing, and associated instructions. The EFI runs at the CPU clock that allows the transfer of data between the CPU register file and registers at the CPU boundary that are attached to devices outside the CPU. The C64x CPU does not support an EFI. This section applies only to the C64x+ CPU. For information about other C64x+ instructions, see the *TMS320C64x/C64x+ DSP CPU and Instruction Set Reference Guide* (TI literature number SPRU732).

### 5.4.5.1 Overview

The EFI provides hardware support for data and command transfers to registers outside the CPU in multi-CPU devices.

### 5.4.5.2 C64x+ EFI Instructions

The following instruction can be used to transfer commands by using the EFI:

- EFCMD: Send 10-bit command code

The following instructions can be used to receive data by using the EFI:

- EFRW: Receive word
- EFRDW: Receive double word

The following instructions can be used to transfer data by using the EFI:

- EFSW: Send word
- EFSDW: Send double word

#### EFCMD *Send Command to EFI*

**Syntax:** EFCMD (.unit) ucst10  
.unit = .S1, .S2, .M1, .M2

**Compatibility:** C64x+ CPU only

**Opcode:** .S Unit

|   |  |   |   |   |  |  |   |   |  |  |   |   |  |  |   |   |   |  |  |   |   |   |   |   |   |   |
|---|--|---|---|---|--|--|---|---|--|--|---|---|--|--|---|---|---|--|--|---|---|---|---|---|---|---|
| 3 |  | 2 | 2 | 2 |  |  | 2 | 2 |  |  | 1 | 1 |  |  | 1 | 1 | 1 |  |  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1 |  | 9 | 8 | 7 |  |  | 3 | 2 |  |  | 8 | 7 |  |  | 3 | 2 | 1 |  |  | 0 | 1 | 0 | 1 | 0 | 1 | 0 |

| Opcode map field used... | For operand type... | Unit    |
|--------------------------|---------------------|---------|
| src2                     | ucst5               | .S1,.S2 |
| dst                      | ucst5               |         |

**Opcode:** .M Unit

|   |  |   |   |   |  |  |   |   |  |  |   |   |  |  |   |   |   |  |  |   |   |   |   |   |   |   |
|---|--|---|---|---|--|--|---|---|--|--|---|---|--|--|---|---|---|--|--|---|---|---|---|---|---|---|
| 3 |  | 2 | 2 | 2 |  |  | 2 | 2 |  |  | 1 | 1 |  |  | 1 | 1 | 1 |  |  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1 |  | 9 | 8 | 7 |  |  | 3 | 2 |  |  | 8 | 7 |  |  | 3 | 2 | 1 |  |  | 0 | 1 | 0 | 1 | 0 | 1 | 0 |

| Opcode map field used... | For operand type... | Unit    |
|--------------------------|---------------------|---------|
| src2                     | ucst5               | .M1,.M2 |
| dst                      | ucst5               |         |

**Description:** A 10-bit data value is sent to the EFI. The five most-significant bits (MSBs) of the 10-bit value are taken from dst; the five least-significant bits (LSBs) are taken from src2. There is an A-side EFI and a B-side EFI. The side used is determined by the S unit that is selected.

This instruction executes unconditionally; that is, it cannot be predicated. The EFCMD instruction does not use any data path resources. It is available for scheduling purposes on the S or M units. Only one EFCMD instruction can be scheduled per side; the S or M slot on a side can be used, but not both in the same execute packet. If used in an SPLOOP body, the EFCMD instruction occupies an execution slot corresponding to the unit specified.

The 10-bit command is output at the CPU boundary in E2. The ready signal is not sampled in conjunction with the EFCMD instruction.

**Execution:**

```
if(.S1)      ucst10 → A_EFI_Cmd[9:0]
else if(.S2)  ucst10 → B_EFI_Cmd[9:0]
else if(.M1)  ucst10 → A_EFI_Cmd[9:0]
else if(.M2)  ucst10 → B_EFI_Cmd[9:0]
```

**Instruction type:** Single-cycle

**Delay slots:** 0

**EFRDW** *Receive Double Word From EFI*

**Syntax:** EFRDW (.unit) dst\_o:dst\_e  
.unit = .S1, .S2

**Compatibility:** C64x+ CPU only

**Opcode:**

|   |   |   |   |   |     |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|-----|--|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3 |   | 2 | 2 | 2 |     |  | 2 | 2 |   |   | 1 | 1 |   |   | 1 | 1 | 1 |   |   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |
| 1 |   | 9 | 8 | 7 |     |  | 3 | 2 |   |   | 8 | 7 |   |   | 3 | 2 | 1 |   |   | 0 | 1 | 1 | 1 | 1 | 0 | 0 |   |
| 0 | 0 | 0 | 0 | 0 | dst |  | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | s | p |

| Opcode map field used... | For operand type... | Unit     |
|--------------------------|---------------------|----------|
| dst                      | dint                | .S1, .S2 |

**Description:** A 64-bit data value is read from the EFI and is written to the register pair dst\_o:dst\_e. There is an A-side EFI and a B-side EFI. The side used is determined by the S unit that is selected. There is no cross-path capability; A-side receives must go to an A-file register pair, and B-side receives must go to a B-file register pair. This instruction executes unconditionally; that is, it cannot be predicated.

The ready signal is sampled in the DS phase of the EFRDW instruction and will cause the CPU to stall before the EFRDW instruction reaches E1 if the data to be read has not yet been registered in the CPU.

**Execution:**

```
if(.S1)      A_EFI_Din[63:0] → dst_o:dst_e (A1:A0 – A31:A30)
else // .2    B_EFI_Din[63:0] → dst_o:dst_e (B1:B0 – B31:B30)
```

**Instruction type:** Single-cycle**Delay slots:** 0**See also:** EFRW**EFRW** *Receive Word From EFI***Syntax:** EFRW (.unit) dst

.unit = .S1, .S2

**Compatibility:** C64x+ CPU only**Opcode:**

|   |   |   |   |   |   |   |   |     |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|-----|--|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3 | 1 | 2 | 9 | 2 | 8 | 2 | 7 |     |  | 2 | 3 | 2 |   |   | 1 | 8 | 1 | 7 |   |   | 1 | 3 | 2 | 1 |   |   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 0 | 0 | 0 |   |   |   |   | dst |  | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | s | p |   |   |

| Opcode map field used... | For operand type... | Unit    |
|--------------------------|---------------------|---------|
| dst                      | int                 | .S1,.S2 |

**Description:** A 32-bit data value is read from the EFI and is written to dst. There is an A-side EFI and a B-side EFI. The side used is determined by the S unit that is selected. There is no cross-path capability; A-side receives must go to an A-file register pair, and B-side receives must go to a B-file register pair. This instruction executes unconditionally; that is, it cannot be predicated.

The ready signal is sampled in the DS phase of the EFRW instruction and will cause the CPU to stall before the EFSDW instruction reaches E1 if the data to be read has not yet been registered in the CPU.

**Execution:**

```
if(.S1)           A_EFI_Din[31:0] → dst (A0 – A31)
else // .2        B_EFI_Din[31:0] → dst (B0 – B31)
```

**Instruction type:** Single-cycle**Delay slots:** 0**See also:** EFRDW**EFSDW** *Send Double Word to EFI***Syntax:** EFSDW (.unit) src1, src2, dst

.unit = .L1, .L2

**Compatibility:** C64x+ CPU only**Opcode:**

|      |   |   |   |   |     |   |   |  |  |      |   |   |  |  |      |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|------|---|---|---|---|-----|---|---|--|--|------|---|---|--|--|------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3    | 1 | 2 | 9 | 2 | 8   | 2 | 7 |  |  | 2    | 3 | 2 |  |  | 1    | 8 | 1 | 7 |   |   | 1 | 3 | 2 | 1 |   |   |   |   | 5 | 4 | 3 | 2 | 1 | 0 |
| creg | z |   |   |   | dst |   |   |  |  | src2 |   |   |  |  | src1 |   | x | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | s | p |   |   |   |   |   |

| Opcode map field used... | For operand type... | Unit     |
|--------------------------|---------------------|----------|
| src1                     | int                 | .L1, .L2 |
| src2                     | xint                |          |
| dst                      | ucst5               |          |

**Description:** The registers src1 and src2 are read from the register file and combined to form a 64-bit value that is sent to the EFI with a 5-bit constant taken from dst. The src2 register provides the 32 LSBs, and the src1 register provides the 32 MSBs. There is an A-side EFI and a B-side EFI. The side used is determined by the L unit that is selected.

The data and constant are output at the CPU boundary in E2. The EFI ready signal is sampled in E2 of the EFSDW instruction and will cause the CPU to stall if the signal indicates the buffering external to the CPU is full.

**Execution:**

```

if(cond)
if(.L1)      src1:src2 → A_EFI_Dout[63:0]
              ucst5 → B_EFI_Scmd[4:0]
else // .L2  src1:src2 → B_EFI_Dout[63:0]
              ucst5 → B_EFI_Scmd[4:0]
else          nop

```

**Instruction type:** Single-cycle

**Delay slots:** 0

**See also:** EFSW

**EFSW**
***Send Word to EFI***

**Syntax:** EFSW (.unit) src1, dst

.unit = .L1, .L2

**Compatibility:** C64x+ CPU only

**Opcode:**

|   |  |   |   |   |  |  |   |   |  |  |   |   |  |  |   |   |   |  |  |   |   |   |   |   |   |
|---|--|---|---|---|--|--|---|---|--|--|---|---|--|--|---|---|---|--|--|---|---|---|---|---|---|
| 3 |  | 2 | 2 | 2 |  |  | 2 | 2 |  |  | 1 | 1 |  |  | 1 | 1 | 1 |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
| 1 |  | 9 | 8 | 7 |  |  | 3 | 2 |  |  | 8 | 7 |  |  | 3 | 2 | 1 |  |  | 0 | 1 | 1 | 1 | 1 | 0 |

creg      z      dst      src2      0 1 1 1 1 x 0 0 1 1 0 1 0 1 1 0 s p

| Opcode map field used... | For operand type... | Unit     |
|--------------------------|---------------------|----------|
| src2                     | xint                | .L1, .L2 |
| dst                      | ucst5               |          |

**Description:** The src2 register is read from the register file and sent to the EFI along with a 5-bit constant taken from dst. There is an A-side EFI and a B-side EFI. The side used is determined by the L unit that is selected.

The data and constant are output at the CPU boundary in E2. The EFI ready signal is sampled in E2 of the EFSW instruction and will cause the CPU to stall if the signal indicates the buffering external to the CPU is full.

**Execution:**

```

if(cond)
  if(.L1)          src2 → A_EFI_Dout[31:0]
                ucst5 → A_EFI_Scmd[4:0]
  else // .L2      src2 → B_EFI_Dout[31:0]
                ucst5 → B_EFI_Scmd[4:0]
else           nop

```

**Instruction type:** Single-cycle

**Delay slots:** 0

**See also:** EFSDW

### 5.4.5.3 C64x+ EFI Use in IVA2.2

The following programming model describes how to write and read a register using the EFI. In the context of IVA2.2, only the EFSW, EFRW, and EFSDW instructions are used.

#### 5.4.5.3.1 Read Registers Using the EFI Programming Model

To read a 32-bit value in a video accelerator register using the EFI, the following sequence must be used:

```

EFSW address_32b, opcode_5b
NOP N
EFRW cpu_reg

```

With:

- address\_32b is the video accelerator address of the register from which the value must be read.
- opcode\_5b is used to code the read operation: 0x02.
- N is the number of cycles to wait data is written in the EFI FIFO. In the context of IVA2.2 N = 0x22.
- Cpu\_reg is the 32-bit CPU register where the read value is stored.

---

**NOTE:** To avoid handling specific cases of successive read requests, interrupts are disabled between the time the EFSW is issued and the data is retrieved in the DSP register.

---

**NOTE:** When it is necessary to read a large number of registers, the two macros that correspond to the two instructions given previously can be used to allow issuing a read request while reading data:

- EFSW address\_32b, opcode\_5b: IME\_SendReadReq(unsigned ime\_addr\_reg)
- EFRW cpu\_reg: IME\_ReceiveData()

In that case, there is no need to insert a NOPs instruction between the two EFI commands.  
Read latency is under CPU control.

---

#### 5.4.5.3.2 Write Registers Using the EFI Programming Model

To write a 32 bit-value in a video accelerator register using the EFI, the following instruction must be used:  
EFSDW value\_32b, address\_32b, opcode\_5b

With:

- The value\_32b register contains the 32-bit word to write.
- address\_32b is the video accelerator address of the register in which value must be written.
- opcode\_5b is used to code the write operation: 0x01.

---

**NOTE:** The address is stored in the even 32-bit register of the 64-bit register pair, while value\_32b is stored in the odd register (that is, the MSB part).

---

## 5.4.6 iME and iLF Basic Programming Model

### 5.4.6.1 Typical Use

The iME and iLF coprocessors are parallel coprocessors, so they are partially autonomous and provide highly parallel video processing. To use the iME/iLF coprocessor in a video accelerator design, perform the following steps:

- Step 1. Initialize the module.
- Step 2. Prepare the data to be processed in the shared L2 memory.
- Step 3. Prepare the instructions for processing in the L2 memory.
- Step 4. Prepare the parameter stack in the L2 memory.
- Step 5. Configure the device to generate an interrupt on completion.
- Step 6. Write a LoadInstBuf() instruction in the program buffer register ([iME\\_PROGRAMBUFFERLINENLSBi](#) and [iME\\_PROGRAMBUFFERLINENMSBi](#) or [iLF\\_PROGRAMBUFFERLINENLSBi](#) and [iLF\\_PROGRAMBUFFERLINENMSBi](#)) with the address parameter pointing to the instruction in L2 shared memory.
- Step 7. Start the coprocessor by writing to START in the [iME\\_COMMANDREG](#) or [iLF\\_COMMANDREG](#) register.
- Step 8. Wait for the coprocessor interrupt (the DSP or sequencer is free to perform other tasks during coprocessor processing).

Steps 2, 3, and 4 can be performed with the help of the DSP EDMA, which can be configured by both the sequencer and the DSP megamodule.

Steps 5, 6, and 7 can be performed by both the sequencer and the DSP megamodule, but using the DSP megamodule for this task causes long DSP stalls because of high latency between the DSP megamodule and the iLF/iME module.

The DSP megamodule or the sequencer can prepare multiple sets of data in shared L2 memory (Steps 2, 3, and 4), then the sequencer can launch multiple processing with the coprocessor (Steps 6 and 7) until all prepared data sets in shared L2 memory are used. This way, the DSP and/or DSP EDMA is offloaded for a longer time. [Figure 5-27](#) is a flow chart of a typical use of iLF/iME in video processing. In the flow chart, the four units (DSP, EDMA, sequencer, and coprocessor) work in parallel.

**Figure 5-27. iME/iLF Typical Use Flow Chart**


iva2-038

#### 5.4.7 iVLCD Basic Programming Model

The iVLCD coprocessor is a parallel coprocessor where interrupt capabilities. It is partially autonomous, but unlike the iME/iLF, it does not retrieve information from shared L2 memory, so all data must be transferred to its memory through external means.

To accelerate transfer, the IVA EDMA has access to iVLCD local memories (see [Section 5.3.2.2, EDMA Access to Video Accelerator/Sequencer](#)). The EDMA can be programmed by the DSP megamodule or by the sequencer.

A typical use of iVLCD includes the 5 steps shown in [Figure 5-28](#).

**Figure 5-28. iVLCD Typical Use Flow hart**



iva2-039

### **5.4.7.1 Setting Up Registers for Q/IQ Operation**

Before starting to encode or decode a bitstream, the Q/IQ registers and memory in the iVLCD module must be correctly initialized. [Section 5.4.7.1.1, Q/IQ Matrix Setup - Inverse Quantizer Matrix](#), through [Section 5.4.7.1.4, Q/IQ Threshold](#), describe the details.

#### **5.4.7.1.1 Q/IQ Matrix Setup - Inverse Quantizer Matrix**

```
Inverse_quantizer_matrix[0] = (1<<15)/DC_scaler
Inverse_quantizer_matrix[i = 1...63] = (1<<15)/quant_matrix(i = 1...63);
```

Quantization matrix values are either standard or embedded in the bitstream.

The inverse quantizer and quantizer matrices are selected by registers IVA.[VLCD\\_QIQ\\_CONFIGj](#) (j = 0 to 5).

#### **5.4.7.1.2 Q/IQ Rounding**

IVA.[VLCD\\_MODE](#)[15] MPEGRND bit = 1 implies that a rounding term (114) is added to the coefficients during quantization. IVA.[VLCD\\_MODE](#)[15] MPEGRND bit = 0 implies that quantization of the coefficients other than DC intra is performed without rounding.

DC intracoeficients are always quantized with a rounding term (1<<14).

#### **5.4.7.1.3 Q/IQ Offset**

IVA.[VLCD\\_MPEG\\_DELTA\\_Q](#) and IVA.[VLCD\\_MPEG\\_DELTA\\_IQ](#) are used for H.263 and MPEG4 type 0 inverse quantization.

The IVA.[VLCD\\_MPEG\\_DELTA\\_IQ](#)[8:0] MDELIQ field is set as follows:

```
if ((qp&0x1)==0) delta_q = qp-1;
else delta_q = qp;
where qp is the quantizer scale
```

The IVA.[VLCD\\_MPEG\\_DELTA\\_Q](#)[8:0] MDELQ field is set to 0.

For MPEG1/2, the IVA.[VLCD\\_MPEG\\_DELTA\\_Q](#)[8:0] MDELQ and IVA.[VLCD\\_MPEG\\_DELTA\\_IQ](#)[8:0] MDELIQ fields are set to 0.

#### **5.4.7.1.4 Q/IQ Threshold**

The IVA.[VLCD\\_MPEG\\_THRED](#)[11:0] MTHRED field is the quantization threshold for intra AC coefficients and intercoefficients.

There is no register setting for inverse quantization saturation. The inverse quantization function internally saturates intra AC coefficients and intercoefficients to between -2048 and 2047.

### **5.4.7.2 Setting Up Registers for VLC Operation**

Before starting to encode a bitstream, the iVLCD must be initialized by initializing the coprocessor registers and setting up the VLC look-up tables. Some of those register initial values remain unchanged during a frame-encoding process, and others must be updated on a frame basis.

First, the VLC look-up tables must be loaded into the iVLCD table memory.

The VLC module operates on an N macroblocks basis. This means that when VLC is triggered, exactly N macroblocks of 64 elements are encoded. N must be specified to the encoder by setting the corresponding bits in the iVLCD control registers.

Programming the VLC involves two steps:

- Initialization: Parameters that remain constant throughout the encoding process are written into registers.
- Processing: The iVLCD is run as many times as necessary to encode the data. The VLC module operates on an N macroblocks basis. This means that each time VLC is triggered, exactly N blocks of 64 elements are encoded. N must be specified to the encoder by setting the corresponding bits in the iVLCD control registers. Because N generally remains constant during encoding, it is set during initialization. During processing, some registers set during initialization can be modified by the application or are modified by the VLC between the times it is run.

To perform the correct encoding operation, the IVA.[VLCD\\_MODE](#) register must have bits set to the correct values. By setting the following bits, the iVLCD coprocessor enables great flexibility, letting the programmer choose the type of encoded data format and the number of macroblocks encoded at a time:

- IVA.[VLCD\\_MODE](#)[2:0] FUNC field: Determines the VLC encode function: Value, 000 for Q, 001 for IQ, 010 for VLC, 011 for VLD, 100 for Q + IQ, 101 for Q + VLC, 110 for Q + IQ + VLC, 111 for VLD + IQ
- IVA.[VLCD\\_MODE](#)[7] MPEGINTRA bit: Determines whether the blocks to be encoded are intra macroblocks for MPEG encoding. For JPEG, this bit must be set to 1.
- IVA.[VLCD\\_MODE](#)[11] JPEGSYNC bit: Determines whether to insert the code 00 in the bitstream after getting a byte-aligned code of FF. Setting this bit to 1 activates 00 insertion. This bit must be set to 1 for JPEG.
- IVA.[VLCD\\_MODE](#)[14:12] NUMBLKS field: Specify the number of blocks of 64 elements to be processed each time the VLC coprocessor is triggered. Each block element is a 16-bit word and a maximum of 6 blocks can be encoded at once.
- IVA.[VLCD\\_MODE](#)[10] MPEGTYPe bit: Holds the value for MPEG picture coding type
- IVA.[VLCD\\_MODE](#)[8] INTRAVLC bit inMODE register: Specifies intra VLD decoding for MPEG modes: 0, use INTRA DC VLC table; 1, switch to INTRA AC VLC table.
- IVA.[VLCD\\_MODE](#)[6:4] MODESEL field: Tell the iVLCD what type of image coding is used: Value 000 for JPEG, 001 for MPEG1, 010 for MPEG2, 011 for H.263, 100 for MPEG4, 101 for MPEG4 data partition, 110 for MPEG4 RVLC/D, and value 111 is reserved.
- IVA.[VLCD\\_VLCDIN\\_ADDR](#) input address register:
- IVA.[VLCD\\_VLCDOUT\\_ADDR](#) output address register: Because the bit size of a codeword can be other than 16 bits, the bitstream buffer pointer register alone is not sufficient to determine the precise location of the next codeword to be written in the bitstream. To get the complete location, the next register must be used.
- IVA.[VLCD\\_BITS\\_BPTR](#) bits pointer register: Must contain a 4-bit value between 0 and 15 that is the bit position in the starting word of the bitstream. Because the VLC fills a codeword from the MSB to the LSB, this register is generally set to 15 at the beginning. After each run, the VLC updates the register by writing the bit position of the next codeword.
- IVA.[VLCD\\_RING\\_START](#) ring buffer start address register:
- IVA.[VLCD\\_RING\\_END](#) ring buffer end address register:
- IVA.[VLCD\\_HUFFTAB\\_DCY](#) Huffman DC Y table base address register: Holds the pointer to the Huffman table for luminance DC coefficients. The address is relative to the base address of the iVLCD Huffman table memory and must be 32-bit-aligned.
- IVA.[VLCD\\_HUFFTAB\\_DCUV](#) Huffman DC UV table base address register: Holds the pointer to the Huffman table for chrominance DC coefficients. The address is relative to the base address of the iVLCD Huffman table memory and must be 32-bit-aligned.
- IVA.[VLCD\\_HUFFTAB\\_ACi](#) (*i* = 0) Huffman AC0 table base address register: Holds the pointer to the Huffman table for luminance AC coefficients. The address is relative to the base address of the iVLCD Huffman table memory and must be 32-bit-aligned.
- IVA.[VLCD\\_HUFFTAB\\_ACi](#) (*i* = 1) Huffman AC1 table base address register: Holds the pointer to the Huffman table for chrominance AC coefficients. The address is relative to the base address of the iVLCD Huffman table memory and must be 32-bit-aligned.
- IVA.[VLCD\\_LUMA\\_VECTOR](#) LUMA bit-vector register: States which blocks must be treated as luminance blocks. This information is necessary because the Huffman table differs from luminance to chrominance data. For a complete description of this register, see [Section 5.5, IVA2.2 Subsystem Register Manual](#).

- IVA.[VLCD\\_MPEG\\_CBP](#) MPEG coded block pattern register: Specifies which 8x8 blocks of each macroblock must be coded. The Q/IQ module generates the CBP value after quantizing each macroblock.

---

**NOTE:** If VLC is performed separately from Q, the application must ensure that the CBP value corresponding to the macroblock is written to the [VLCD\\_MPEG\\_CBP](#) register before triggering the VLC. In JPEG mode, this register is ignored and every block is coded. (If iVLCD is configured to perform Q + VLC, this register contains the correct CBP value and is used for VLC.)

---

#### 5.4.7.3 Setting Up Registers for VLD Operation

Before starting to decode a bitstream, the iVLCD must be initialized correctly by initializing the iVLCD control registers and setting up the UVLD symbol and control tables. Some initial register values remain unchanged during a frame decoding process and others must be updated on a frame basis.

First, the UVLD symbol and control tables must be loaded into the iVLCD Huffman table memory.

The iVLCD coprocessor operates on an N macroblocks basis. This means that when the iVLCD is triggered, exactly N blocks of 64 elements are decoded. N must be specified to the decoder by setting the corresponding bits in the iVLCD control registers.

Programming the VLD involves two steps:

- Initialization: Parameters that remain constant throughout the decoding process are written into registers.
- Processing: The iVLCD is run as many times as necessary to decode the data. The VLD module operates on an N macroblocks basis. This means that each time the iVLCD is triggered, exactly N blocks of 64 elements are decoded. N must be specified to the decoder by setting the corresponding bits in the iVLCD control registers. Because N generally remains constant during decoding, it is set during initialization. During processing, some registers set during initialization can be modified by the programmer or are modified by the VLD between the times it is run.

To perform the correct decoding operation, the IVA.[VLCD\\_MODE](#) register must have bits set to the correct values. By setting the following bits, the iVLCD coprocessor enables great flexibility, letting the programmer choose the type of decoded data format and the number of macroblocks decoded at a time:

- IVA.[VLCD\\_MODE\[2:0\]](#) FUNC field: Determines the VLC encode function: Value, 000 for Q, 001 for IQ, 010 for VLC, 011 for VLD, 100 for Q + IQ, 101 for Q + VLC, 110 for Q + IQ + VLC, 111 for VLD + IQ
- IVA.[VLCD\\_MODE\[7\]](#) MPEGINTRA bit: Determines whether the blocks to be decoded are intra macroblocks for MPEG decoding. For JPEG, this bit must be set to 1.
- IVA.[VLCD\\_MODE\[11\]](#) JPEGSYNC bit: Determines whether to ignore the code 00 in the bitstream after getting a byte-aligned code of FF. Setting this bit to 1 activates ignoring of 00. This bit must be set to 1 for JPEG.
- IVA.[VLCD\\_MODE\[14:12\]](#) NUMBLKS field: Specify the number of blocks of 64 elements to be processed each time the iVLCD coprocessor is triggered. Each block element is a 16-bit word and a maximum of 6 macroblocks can be decoded at once.
- IVA.[VLCD\\_MODE\[10\]](#) MPEGTYPEn bit: Holds the value for Mpeg picture coding type
- IVA.[VLCD\\_MODE\[8\]](#) INTRAVLC bit: Specifies intra VLD decoding for MPEG modes
- IVA.[VLCD\\_MODE\[6:4\]](#) MODESEL field: Tell the iVLCD what type of image coding is used: Value 000 for JPEG, 001 for MPEG1, 010 for MPEG4, 011 for H.263, 100 for MPEG4, 101 for MPEG4 data partition, 110 for MPEG4 RVLC/D, and value 111 is reserved.
- IVA.[VLCD\\_VLCDOUT\\_ADDR](#) output address register: See , *Input and Output Data*.
- IVA.[VLCD\\_VLCDIN\\_ADDR](#) input address register: See , *Input and Output Data*. iVLCD updates this register each time it reads a codeword from the bitstream buffer. Because the bit size of a codeword can be other than 16 bits, the bitstream buffer pointer register alone is not sufficient to determine the precise location of the next codeword to be read from the bitstream. To get the complete location, the next register must be used.
- IVA.[VLCD\\_BITS\\_BPTR](#) bits pointer register: Must contain a 4-bit value between 0 and 15 that is the bit

position in the starting word of the bitstream. Because the iVLCD reads a codeword from the MSB to the LSB, this register is generally set to 15 at the beginning. After each run, the iVLCD updates the register by writing the bit position of the next codeword.

- IVA.[VLCD\\_RING\\_START](#) ring buffer start address register: See , *Input and Output Data*.
- IVA.[VLCD\\_RING\\_END](#) ring buffer end address register: See , *Input and Output Data*. The CTLTAB\_DCY Y control look-up table base address register holds the pointer to the UVLD control table for luminance DC coefficients. The address is relative to the base address of the iVLCD Huffman table memory buffer and must be 32-bit-aligned.
- IVA.[VLCD\\_CTLTAB\\_DCUV](#) control look-up table base address register: Holds the pointer to the UVLD control table for chrominance UV DC coefficients. The address is relative to the base address of the iVLCD Huffman table memory and must be 32-bit-aligned.
- IVA.[VLCD\\_CTLTAB\\_ACi](#) ( $i = 0$ ) control look-up table base address register: Holds the pointer to the UVLD control table for INTER AC coefficients. The address is relative to the base address of the iVLCD Huffman table memory and must be 32-bit-aligned.
- IVA.[VLCD\\_CTLTAB\\_ACi](#) ( $i = 1$ ) control look-up table base address register: Holds the pointer to the UVLD control table for INTRA AC coefficients. The address is relative to the base address of the iVLCD Huffman table memory and must be 32-bit-aligned.
- IVA.[VLCD\\_OFFSET\\_DCY](#) symbol look-up table address offset register holds the offset value used to address the symbol table DC Y table. The purpose of this offset is to avoid negative numbers being used in the control table.
- IVA.[VLCD\\_OFFSET\\_DCUV](#) symbol look-up table address offset register: Holds the offset value used to address the symbol table DC UV table. The purpose of this offset is to avoid negative numbers being used in the control table.
- IVA.[VLCD\\_OFFSET\\_ACi](#) ( $i = 0$ ) symbol look-up table address offset register: Holds the offset value used to address the INTER AC symbol table. The purpose of this offset is to avoid negative numbers being used in the control table.
- IVA.[VLCD\\_OFFSET\\_ACi](#) ( $i = 1$ ) symbol look-up table address offset register: Holds the offset value used to address the INTRA AC symbol table. The purpose of this offset is to avoid negative numbers being used in the control table.
- IVA.[VLCD\\_SYMTAB\\_DCY](#) symbol look-up table base address register: Holds the address pointer to the starting word of the UVLD symbol table DC Y. This address is relative to the base address of the iVLCD coefficient buffer and must be 32-bit-aligned.
- IVA.[VLCD\\_SYMTAB\\_ACi](#) ( $i = 0$ ) symbol look-up table base address register: Holds the address pointer to the starting word of the UVLD INTER AC symbol table. This address is relative to the base address of the iVLCD coefficient buffer and must be 32-bit-aligned.
- IVA.[VLCD\\_SYMTAB\\_ACi](#) ( $i = 1$ ) symbol look-up table base address register: Holds the address pointer to the starting word of the UVLD INTRA AC symbol table AC 1. This address is relative to the base address of the iVLCD coefficient buffer and must be 32-bit-aligned
- IVA.[VLCD\\_VLD\\_NRBIT\\_DC](#) number of bits register: Specifies the number of bits to test for the DC term as input to UVLD. It equals the maximum length of a Huffman codeword. Bits 0-4 are associated with the UV terms and bits 8-12 with the Y terms.
- IVA.[VLCD\\_VLD\\_NRBIT\\_AC](#) number of bits register: Specifies the number of bits to test for the AC term as input to UVLD. It equals the maximum length of a Huffman codeword. Bits 0-4 are associated with the AC-1 terms and bits 8-12 with the AC-0 terms. VLD\_CTL - iVLCD VLD control register controls:
  - Bits 4, 5, 6, and 7 specify whether UVLD tables for AC1, AC0, DCUV, DCY, respectively, are leading codeword bit 1 or leading codeword 0. For the first case, the bits must be set to 1, for the second case, the bits must be set to 0.
  - Bits 0, 1, 2, and 3 indicate the number of bits to represent the symbol in each entry of the UVLD symbol tables. Bit 0 is for AC1, bit 1 is for AC0, bit 2 is for DC UV, and bit 3 is for DC Y. If the bit is set to 0, the 11-bit symbol is used; otherwise, the 12-bit symbol is used.
- IVA.[VLCD\\_LUMA\\_VECTOR](#) bit-vector register: States which blocks are treated as luminance blocks. This information is necessary because the Huffman table differs from luminance to chrominance data. For a complete description of this register, see [Section 5.5, IVA2.2 Subsystem Register Manual](#).

- IVA.[VLCD\\_MPEG\\_CBP](#) coded block pattern register: MPEG mode; must be updated after each macroblock processing. It specifies which 8x8 blocks of each macroblock must be decoded. For each macroblock there is a corresponding CBP value, which is stored along the bitstream in a header section. In JPEG mode, this register is ignored and every block is decoded.

When using the UVLD tables corresponding to the MPEG-1, MPEG-2, MPEG-4, and H.263 standards, see [Table 5-19](#) for a list of register settings.

**Table 5-19. iVLCD List of Register Values for Standard Algorithms**

| VLCD Register                                      | MPEG1/2 | MPEG4/H.263 | JPEG |
|----------------------------------------------------|---------|-------------|------|
| VLD_NRBIT_DC, bits 12-8: NrBits DC Y               | 7       | 7           | 9    |
| VLD_NRBIT_DC, bits 4-0: NrBits DC UV               | 8       | 8           | 11   |
| VLD_NRBIT_AC, bits 12-8: NrBits AC 0               | 16      | 12          | 16   |
| VLD_NRBIT_AC, bits 4-0: NrBits AC 1                | 16      | 12          | 16   |
| VLD_CTL, bit 7: One leading DC Y                   | 1       | 0           | 1    |
| VLD_CTL, bit 6: One leading DC UV                  | 1       | 0           | 1    |
| VLD_CTL, bit 5: One leading AC 0                   | 0       | 0           | 1    |
| VLD_CTL, bit 4: One leading AC 1                   | 0       | 0           | 1    |
| VLD_CTL, bit 3: Symbol size 11 DC Y                | 11      | 11          | 11   |
| VLD_CTL, bit 2: Symbol size 11 DC UV               | 11      | 11          | 11   |
| VLD_CTL, bit 1: Symbol size 11 AC 0 (INTER AC)     | 11      | 12          | 11   |
| VLD_CTL, bit 0: Symbol size 11 AC 1 (INTER AC)     | 11      | 12          | 11   |
| OFFSET_DCY, bits 10-0: control table offset DC Y   | 0       | 0           | 0    |
| OFFSET_DCUV, bits 10-0: control table offset DC UV | 0       | 0           | 0    |
| OFFSET_AC0, bits 10-0: control table offset AC 0   | 0       | -40         | 0    |
| OFFSET_AC1, bits 10-0: control table offset AC 1   | 0       | -40         | 0    |

#### 5.4.7.4 Calculating the Number of Bits Processed During a VLD Run

To get the number of bits processed by the iVLCD during a VLD run, do the following:

1. Before VLD processing:
  - (a) bits1 = [VLCD\\_BITS\\_BPTR](#)[3:0] BPTR value before VLD start
  - (b) words1 = [VLCD\\_VLCDIN\\_ADDR](#)[12:0] ADDR value before VLD start
2. Start VLD processing:
3. After end of VLD processing
  - (a) bits2: [VLCD\\_BITS\\_BPTR](#)[3:0] BPTR value after VLD start
  - (b) words2: [VLCD\\_VLCDIN\\_ADDR](#)[12:0] ADDR value after VLD start
4. Number of bits processed. = (words2-wors1) \* 16 - bits1 + bits2

#### 5.4.7.5 Setting Up Registers for CAVLC Operation

Before starting to encode a bitstream, the iVLCD must be initialized correctly by initializing coprocessor registers and setting up the VLC look-up tables. Some initial register values remain unchanged during a frame encoding process and others must be updated on a frame basis.

First, the CAVLC look-up tables must be loaded into the iVLCD table memory.

Programming the CAVLC involves two steps:

- Initialization: Parameters that remain constant during the encoding process are written into registers.
- Processing: The iVLCD is run as many times as necessary to encode the data. During processing, some registers set during initialization can be modified by the application or are modified by the CAVLC between the times it is run.

Static registers need initialization only the first time:

- IVA.CAVLC\_RBTOP: Set the buffer top pointer in lbuf1/lbuf0.
- IVA.CAVLC\_RBEND: Set the buffer end pointer in lbuf1/lbuf0.
- IVA.CAVLC\_BUFPTR: Set the pointer inside lbuf1 from which the bitstream is written. The first time, IVA.CAVLC\_BUFPTR is set to the IVA.CAVLC\_RBTOP value (at the top of the lbuf1 buffer).
- IVA.CAVLC\_BITPTR: This register resets the first call of the CAVLC function. Set the number of MSB bits to be included in the valid bitstream in the stream word register.
- IVA.CAVLC\_STRMWDU: This register resets the first call of the CAVLC function. This includes the upper half of the 32-bit stream word register. The value is less than 32 bits and specifies how many remaining bits are not written in the bitstream after iVLCD completion.
- IVA.CAVLC\_STRMWDL: This register resets the first call of the CAVLC function. This includes the lower half of the 32-bit stream word register. The value is less than 32 bits and specifies how many remaining bits are not written in the bitstream after iVLCD completion.

Because the encoded bitstream does not always finish as a complete 32-bit word at the end of 1-MB encoding, IVA.CAVLC\_STRMWDU contains the upper short of the 32-bit word, IVA.CAVLC\_STRMWDL contains the lower short, and CAVLC\_BITPTR indicates how many bits are valid, starting from the MSB of IVA.CAVLC\_STRMWDU.

- IVA.CAVLC\_IBUFSEL: This register specifies input port, output port, and swapping configuration. If the CAVLC-generated bitstream is b0, b1... b15, b16... b31 ... (b0 is the first bit of the bitstream), and if the stream byte swap bit in IBUF\_SEL is 0, the first 32 bits of the bitstream are stored in a 32-bit memory word as:

|                       |                            |                      |                        |
|-----------------------|----------------------------|----------------------|------------------------|
| mem[31:24]<br> b16b23 | mem[23:16]<br> b24,...,b31 | mem[15:8]<br> b0,,b7 | mem[7:0]<br> b8,..,b15 |
|-----------------------|----------------------------|----------------------|------------------------|

If the stream byte swap bit is 1,

|                          |                            |                          |                        |
|--------------------------|----------------------------|--------------------------|------------------------|
| mem[31:24]<br> b24...b31 | mem[23:16]<br> b16,...,b23 | mem[15:8]<br> b8, ..,b15 | mem[7:0]<br> b0,...,b7 |
|--------------------------|----------------------------|--------------------------|------------------------|

Initialize these registers each time the CALVC function is run:

- IVA.CAVLC\_GO\_REG: Setting this bit starts the CAVLC module. It is the same as a Start\_sequence.
- IVA.CAVLC\_MBTYP: This register contains the MB type and the coded block pattern. The codec block pattern field has 6 bits. The cbp configuration is the same as that of the H.264 standard.
- IVA.CAVLC\_HDPT: Set a pointer on Hmem memory to read the MB header symbol and its length.
- IVA.CAVLC\_HDCOUNT: This register contains the number of MB header pairs. The range of this value is 0 to 1023.
- IVA.CAVLC\_NAPTR: Set a pointer on Hmem memory from which nA parameters are stored.
- IVA.CAVLC\_NBPT: Set a pointer on Hmem memory from which nB parameters are stored.
- IVA.CAVLC\_COEFFPT: Set a pointer on lbuf0 memory to read residual data.

The following registers do not need to be initialized; they contain only information about the encoded bitstream:

- IVA.CAVLC\_NUMTTL: This register specifies the total number of bits generated. This value considers remaining bits not yet written in the bitstream.
- IVA.CAVLC\_NUMHD: This register specifies how many bits are generated from the MB header.
- IVA.CAVLC\_NUMRESI: This register specifies how many bits are generated from residual data.

## 5.4.8 Interrupt Management

### 5.4.8.1 Interrupt Flow in IVA2.2 Subsystem

The DSP megamodule interrupt controller (IC) detects, combines, and routes up to 128 system events (internal and external) to the 12 DSP CPU interrupt lines. For more information about interrupt mapping of the IVA2.2 subsystem (internal and external interrupts), see [Table 5-3](#).

In addition to performing handshaking for chip-level wake-up sequencing for waking from static power-down, the DSP megamodule WUGEN module internally routes the interrupt request to the IC module. This occurs because the WUGEN module is the only DSP megamodule module in the CORE power domain to enable the powered-off DSP subsystem to be awakened after the DSP receives an interrupt from any device peripherals.

[Figure 5-29](#) shows the IVA2.2 subsystem interrupt flow with the main WUGEN and IC registers used for event generation.

**Figure 5-29. IVA2.2 Interrupt Flow**

iva2-040

**NOTE:** The CSR/TCR, IER, IFR, and ICR registers belong to the DSP CPU block (C64x+). For more information, see the C64x+ documentation ([Section 5.3.1.8](#)).

#### 5.4.8.2 Event Combined Programming Sequence

In addition to generating a combined interrupt based on programmable event combinations, the event combiner provides a masked view of the event flag registers. By reading the masked event flag (IVA\_IC.MEVTF<sub>i</sub> where  $i = \{0 \text{ to } 3\}$ ) registers, the DSP CPU sees only the event flags pertaining to the corresponding combined event (EVT<sub>x</sub> with  $x = \{0, 1, 2, 3\}$ ).

When servicing a combined interrupt, perform the following steps:

1. Read the IVA\_IC.MEVTF<sub>i</sub> register corresponding to the combined event EVT<sub>x</sub> (where  $i = \{0 \text{ to } 3\}$ ).
2. Check the pending events.
3. Write the value of the IVA\_IC.MEVTF<sub>i</sub> register into the IVA\_IC.EVTC<sub>i</sub> register (where  $i = \{0 \text{ to } 3\}$ ).
4. Service the received interrupts.
5. Repeat steps 1 through 4 until IVA\_IC.MEVTF<sub>i</sub> = 0x0 (where  $i = \{0 \text{ to } 3\}$ ).

This clears only those events combined on EVT<sub>x</sub>. Any events masked in the IVA\_IC.EVTM<sub>i</sub> register (where  $i = \{0 \text{ to } 3\}$ ) do not need to be cleared if set in the IVA\_IC.EVTF<sub>i</sub> register (where  $i = \{0 \text{ to } 3\}$ ) (they can generate an exception or are used as event outputs).

Before returning, the DSP CPU should repeat steps 1 through 4 until no pending events are found. This ensures that any events received during the ISR are captured. If an event EVT<sub>x</sub> is received at the same time that its flag is being cleared in the IVA\_IC.EVTC<sub>i</sub> register (where  $i = \{0 \text{ to } 3\}$ ), it does not clear. Repeating steps 1 through 4 ensures that no events are missed.

#### 5.4.8.3 Event <-> Interrupt Mapping Programming Sequence

The INTC allows programming independently which of the 128 inputs events is mapped to each DSP CPU interrupt by writing the event number in the bit field corresponding to the CPU interrupt in the IC.INTMUX<sub>j</sub> registers (where  $j = \{1 \text{ to } 3\}$ ).

Example:

```
/* ----- */
/*evtTable has the 12 evt <-> CPU interrupt mapping */
/* ----- */
evtTable[0] = 55; // Mailbox event highest priority
evtTable[1] = 61; // McBSP1TX event
[...]
evtTable[11] = 29; // EDMA3 gbl completion event lowest priority
for(I=0; i<12; I++) { // for each CPU maskeable interrupt
INTMUX(I >> 2 + 1) |= (evtTable[i] & 0x7F) << ((I & 0x3) << 3);
}
```

#### 5.4.8.4 Interrupt Exception Programming Sequence

The INTC can generate a system event (INTERR) that is internally routed to system event input EVT96. This event is generated when a DSP CPU interrupt is dropped (that is, when a DSP CPU interrupt is received while the interrupt flag is already set in the DSP CPU).

This can inform the user of possible problems in the software code, such as whether interrupts were disabled for an extended period of time, or whether pipelined (noninterruptible) code sections were too long.

---

**NOTE:** Because the interrupt drop detection logic is in the CPU, only interrupts sourced from a single system event can be detected. The dropping of individual combined events is not possible, although dropping the output of an event combiner is possible. Only the first dropped interrupt detected is reported by the INTERR event.

---

The IVA\_IC.[INTXSTAT](#) register holds the ID of the CPU interrupt and the system event number of the dropped event. By setting the IVA\_IC.[INTXCLR\[0\]](#) CLEAR bit to 1, the software user resets the IVA\_IC.[INTXSTAT](#) register to 0.

When servicing the interrupt exception, the CPU performs three steps:

1. Reads the IVA\_IC.[INTXSTAT](#) register
2. Checks the error condition
3. Clears the error through the IVA\_IC.[INTXCLR](#) register

The dropped events that generate the INTERR event (EVT96) can be qualified by a mask register. CPU interrupts that are to be ignored by the drop detection hardware can be masked in the IVA\_IC.[INTDMASK](#) register.

#### 5.4.8.5 Interrupt Controller Basic Programming Model for Power Down of IVA2.2 Subsystem

When going to a low-power state not involving IVA2.2 logic power off, there are no special software settings to perform. In particular, the noncombined interrupts can be used without any specific handling for that power transition. To run the procedure for a correct transition to power-down state not involving logic-off, the user must perform the following sequence:

1. Ensure that all wake-up events are correctly mapped to enabled DSP CPU interrupts, and are unmasked in combined event registers (if combined events are used).
2. Clear associated bits in the [WUGEN\\_MEVT0](#) and [WUGEN\\_MEVT1](#) register to unmask wake-up interrupts.

---

**NOTE:** Software must not unmask in the WUGEN module an event that is not correctly mapped to an enabled DSP CPU interrupt. If that event is triggered, the IVA2.2 subsystem exits the power-down state but does not wake up.

---

The user must program the following procedure when transitioning to the (logic) power-off state (OFF state for device):

1. Ensure that all wake-up events are correctly mapped to enabled DSP CPU interrupts, and are unmasked in combined event registers (if combined events are used).
2. Clear correct bits in the [WUGEN\\_MEVT0](#) and [WUGEN\\_MEVT1](#) registers to unmask wake-up interrupts.
3. Save necessary context (all except interrupt-related registers).

---

**NOTE:** Steps 3 through 5 are automatic, but interruptible. If a wake-up interrupt occurs at this stage, the transition to power down is canceled and the next transition restarts from the beginning. Software tip: A software variable (semaphore) can be set in Step 3, modified in all calls of the wake-up interrupt ISR routine, and checked before executing the IDLE instruction in Step 5. For a complete description of the DSP CPU ISR register, see the C64x+ documentation ([Section 5.3.1.8](#)).

---

4. Save the interrupt configuration in:
  - (a) IVA\_IC.[INTMUXj](#) register (where j = {1 to 3})
  - (b) IVA\_IC.[EVTMASKi](#) register (optional, where i = {0 to 3})
  - (c) IVA\_IC.[INTDMASK](#) register (optional)
  - (d) DSP CPU IER register. See the C64x+ documentation for IER register description ([Section 5.3.1.8](#)).
5. Execute the DSP IDLE instruction.

---

**NOTE:** Software must not unmask in the WUGEN module an event that is not correctly mapped to an enabled DSP CPU interrupt. If that event is triggered, the IVA2.2 subsystem exits the power-down state but does not wake up.

---

#### 5.4.8.6 Interrupt Controller Basic Programming Model for Power On of IVA2.2 Subsystem

Noncombined events can be lost after power on wakeup of the DSP megamodule module. To avoid this, one solution is to replay the DSP CPU interrupt after restoring the interrupt selector and event combiner context.

- Programming model at boot time

There is no specific software setting needed to use combined/noncombined events during normal operation. However, at boot time, the event can be captured in the event-combiner event flag and not propagated to DSP. For this purpose, the following sequence must be performed:

1. The IVA2.2 logic ensures that interrupts are only presented to DSP megamodule after:
  - (a) The DSP megamodule module has its clock.
  - (b) The DSP megamodule module is correctly reset.

**NOTE:** Steps a and b ensure that the DSP megamodule module cannot miss a dropped event.

2. From the time the pre-idle sequence is started to the time when the IVA2.2 context is fully restored and operational after wakeup, it is assumed that only external (from device peripherals) interrupts can occur. DSP megamodule internal interrupts can result only from an application software side-effect; the application is stopped when entering the pre-idle sequence and is restarted only after IVA2.2 context is fully restored and operational (with special attention to memory protection). EDMA interrupts are inactive at this stage, as the EDMA module is completely reset after power up, and a software action is required to make the EDMA interrupts active again.
3. All device peripheral interrupts are level and are kept asserted until the software acknowledges the interrupt by writing 1 to the interrupt status register (DSP CPU ISR) bit corresponding to the enabled asserted event(s). The device peripheral must keep an event flag to track missed interrupts. For a complete description of the DSP CPU ISR register, see the C64x+ documentation ([Section 5.3.1.8](#)).
4. There is no specific requirement to configure or restore interrupt mapping, except having the interrupts globally disabled during the sequence:
  - (a) Set the DSP CPU TSR[0] or CSR[0] GIE bit to 0 to disable all interrupts except the reset interrupt and NMI (nonmaskable interrupt). The GIE bit is the same physical bit in the TSR and CSR registers. For a complete description of these registers, see the C64x + documentation ([Section 5.3.1.8](#)).
  - (b) Remap interrupts by configuring the IVA\_IC.[INTMUXj](#) registers (where j = {1 to 3}).
  - (c) Set the DSP CPU TSR[0] or CSR[0] GIE bit to 1 to enable all DSP CPU interrupts.

The DSP CPU software recognizes which degree of power state the C64x reaches when executing the IDLE instruction, because the PRCM module is under C64x software control. Therefore, the DSP CPU software can correctly skip some unnecessary parts of the pre-idle routines.

- State after reset for DSP CPU and IVA2.2 IC registers:
  - The DSP CPU IER register value is 0x0.
  - The DSP CPU IFR register value is 0x0 because the interrupt selector default mapping is routing only emulation and unmapped events.
  - The IVA\_IC.[INTMUXj](#) registers (where j = {1 to 3}): The default mapping is to route EVT<sub>x</sub> (with x = {0 to 3}) on INT<sub>y</sub> (with y = {4 .. 15}), that is, emulation and nonmapped events.
  - The IVA\_IC.[EVTMASKi](#) registers (where i = {0 to 3}) value is 0x0 (all events are unmasked). These registers values are don't care values because of the default interrupt selector mapping (where IVA\_IC.[INTMUXj](#) registers where j = {1 to 3}).
  - The IVA\_IC.[EVTFLAGi](#) registers (where i = {0, 1, 2, 3}): These registers log the possible wake-up interrupt(s) (if more than one). At this stage, a new wake-up interrupt from device peripherals cannot be missed, because interrupts are level in the device, waiting for a software acknowledge (the user must clear the interrupt in the module to deassert the interrupt line).

For a complete description of the DSP CPU IER and IFR registers, see the C64x+ documentation ([Section 5.3.1.8](#)).

- State after reset for WUGEN registers: two cases depending on the reset type:

- In case of cold power-on reset (the CORE power domain was in OFF state), the IVA\_WUGEN.WUGEN\_MEVT0 register value is 0xFFFFFFFF and the IVA\_WUGEN.WUGEN\_MEVT1 register value is 0xFFFF, meaning that all interrupts are masked.
- In case of warm power-on reset (the CORE power domain was in ACTIVE state), the WUGEN\_MEVT0 and WUGEN\_MEVT1 registers value is the previous programmed one, enabling only wake-up interrupts.
- Programming model for a correct warm-reset:

The software user must replay the noncombined events required for wakeup (if any):

1. Globally mask interrupts by setting the DSP CPU TSR[0] or CSR[0] GIE bit to 0 (already done at boot time).
2. Restore the interrupt selector configuration:
  - (a) IVA\_IC.INTMUXj register (where j = {1 to 3})
  - (b) IVA\_IC.EVTMASKi register (optional, where i = {0 to 3})
  - (c) IVA\_IC.INTDMASK register (optional)
3. Replay the noncombined event captured in IVA\_IC.EVTFLAGi (where i = {0 to 3}):
 

For each DSP CPU interrupt I = (4 to 15)

```
{
  (a) Grab mapped event by setting the IVA_IC.INTMUXj INTSELi[6:0] field (where j = {1 to 3}).
  (b) Check if the event is combined (EVT0...3) or not combined (EVT4...127).
  (c) If combined, exit the loop and go to next loop iteration.
  (d) If noncombined:
    (i) Check whether the event is pending in the IVA_IC.EVTFLAGi EFy bit (where i = {0 to 3} and y = {0 to 127}).
    (ii) If not pending, exit the loop and go to the next loop iteration.
    (iii) If pending, set the associated IFi bit in the DSP CPU IFR register.
}
```

**NOTE:** Software must ensure that an event is enabled only once in the DSP megamodule interrupt selector/combiner: If a noncombined event is mapped to an enabled DSP CPU interrupt, the associated combined event is masked in the associated IVA\_IC.EVTMASKi (where i = {0 to 3}) register (and/or the combined event is not mapped to the DSP CPU interrupt). Reciprocally, if a combined event is mapped to a DSP CPU interrupt, all the unmasked events in the associated IVA\_IC.EVTMASKi (with i = {0, 1 to 3}) register are not mapped as noncombined events to an enabled DSP CPU interrupt (through the DSP CPU IER register).

Software program example for Step 3:

```

/* -----
   * Replays IFR bits associated to noncombined events */
   /* Assumes interrupts globally disabled (GIE bit set to 0)*/
   /* Assumes IVA_IC.INTMUXj() and IVA_IC.EVTFLAGi() are access macros to DSP megamodule IC
   registers */

/* -----
myIPR = IPR; // save IPR
for(I=0; i<12; I++) { // for each CPU maskable interrupt
  myEvt = ( INTMUX( I >> 2 + 1 ) >> ( (I & 0x3) << 3 ) ) & 0x7F;
  if(myEvt >= 4) { // noncombined event
    if( (EVTFLAG(myEvt >> 5) >> (myEvt & 0x1F) ) & 0x1 ) {
      myIPR |= (1<<(I+4));
    }
  }
}

```

```

    }
    IPR=myIPR; // update IPR register
    /* -----
    /* Interrupts can be globally re-enabled from that point*/
    /* -----

```

4. Restore the CPU interrupt configuration by setting the DSP CPU IER register accordingly.
5. Restore the IVA2.2 context (except saved return-PC).
6. Globally enable the interrupts by setting the DSP CPU TSR[0] or CSR[0] GIE bit to 1.
7. Branch to saved return-PC.

For a complete description of the DSP CPU TSR, CSR, IER, or IFR registers, see the C64x+ documentation ([Section 5.3.1.8](#)).

- Procedure for a correct cold reset
1. Globally mask interrupts by setting the DSP CPU TSR[0] or CSR[0] GIE bit to 0 (already done at boot time).
  2. Restore the interrupt selector configuration:
    - (a) IVA\_IC.[INTMUXj](#) register (where j = {1 to 3})
    - (b) IVA\_IC.[EVTMASKi](#) register (optional, with i = {0 to 3})
    - (c) IVA\_IC.[INTDMASK](#) register (optional)
  3. It is unnecessary to replay events, because they are masked in [WUGEN\\_MEVT0](#) and [WUGEN\\_MEVT1](#) registers (default WUGEN module configuration). This can be done to simplify the boot sequence without discriminating between cold and warm reset.
  4. Restore the CPU interrupt configuration by setting the DSP CPU IER REGISTER accordingly.
  5. Restore the WUGEN module context. This can be forced even in warm reset to simplify the boot sequence without discriminating between cold and warm reset.

---

**NOTE:** If Steps 3 and 5 are performed systematically, the boot code can be shared between warm and cold reset boot without programming two distinct software boot codes.

---

6. Restore the rest of the IVA2.2 subsystem context (except saved return-PC).
7. Globally enable the interrupts by setting the DSP CPU TSR[0] or CSR[0] GIE bit to 1.
8. Branch to saved return-PC.

#### 5.4.8.7 Video and Sequencer Module interrupt Handling

##### 5.4.8.7.1 Sequencer Interrupt

The sequencer uses a single FIQ interrupt. This single interrupt is driven by all the video accelerator interrupts, DSP EDMA interrupts, DSP megamodule soft interrupts, and error interrupts. Registers are available to manage these interrupts in the sequencer.

Before servicing an interrupt, the sequencer ISR must:

1. Identify the source event(s) for the interrupt line assertion
2. For each source event:
  - (a) Clear the interrupt at the source (in the module interrupt clear register)
  - (b) Clear the interrupt at the second-level (sequencer) interrupt controller
  - (c) Service the interrupt event

#### 5.4.8.7.2 DSP Megamodule Interrupt

A single interrupt line is used per processor to gather all events that might require an interrupt of the DSP megacell. This interrupt line is shared by all the modules responsible for generating an interrupt request to the associated processor (iME, iLF, iVLCD, DSP megacell initiator error, DMA initiator error, and sequencer soft interrupt). In turn, each of these modules has a single interrupt request output that is shared by all events internal to the module.

Before servicing an interrupt, the processor (DSP megacell) ISR must:

1. Identify the source event(s) for the interrupt line assertion
2. For each source event:
  - (a) Clear the interrupt at the source (in the module interrupt clear register)
  - (b) Clear the interrupt at the second-level interrupt controller
  - (c) Clear the interrupt at the DSP interrupt controller (if combined interrupt is used, see [Section 5.4.8.2, Event Combined Programming Sequence](#), for details)
  - (d) Service the interrupt event
3. Acknowledge the interrupt to the processor

Step 1 is done hierarchically through reading the IVA.[VIDEOSYSC\\_IRQSTATE](#) register and, depending on which bit is set, through reading of the IVA.module>\_IRQSTATUS registers (or equivalent) (see [Figure 5-30](#)). Step 2 is done hierarchically, as well, but in the reverse order, using IVA.module>\_IRQCLEAR (or equivalent) first and then IVA.[VIDEOSYSC\\_IRQCLR](#) (IVA.[SEQ\\_IRQCLR](#), respectively).

**Figure 5-30. Process of Identifying Source Event of an Interrupt**



iva2-041

## 5.4.9 Memory Management

### 5.4.9.1 External Memory

#### 5.4.9.1.1 Cacheability

The L1P, L1D, and L2 cache sizes are all 0K byte after reset.

- The user enables the L2 cache by writing 0x2 (maximum cache is 64K bytes) to the IVA\_XMC.L2CFG register.
- However, this is not sufficient, because the region external to the IVA2.2 is configured as a noncached area after reset. The user must configure the external area to be cached by setting the IVA\_XMC.MAR[i] PC bit to 1, i referring to the index of the related 16-MB page (starting from i = 16 for the first external page at address 0x1000 0000).

The MAR settings only control the L2 and L1D cache's response to CPU data and program fetches. L1P caches the memory range regardless of the values of the MAR bits.

#### 5.4.9.1.2 Virtual Addressing

The device embeds two instances of MMU: one instance is camera MMU (also named MMU1) dedicated to the camera subsystem; the other instance is IVA2.2 MMU (also named MMU2) used by the IVA2.2 subsystem. For more information about MMU2 software settings at IVA2.2 boot, see [Section 5.4.1.2, Example of IVA2.2 Boot](#).

For a complete programming guide of IVA2.2 MMU, see [Chapter 15, Memory Management Units](#).

### 5.4.9.2 Internal Memory

#### 5.4.9.2.1 Memory Protection

The DSP megacell memory protection divides the memory map into pages and defines a per-page permission structure. This permission structure is in the MPPA registers: IVA\_XMC.L1PMPPAk, IVA\_XMC.L1DMPPAk, IVA\_XMC.L2MPPAj for L1P, L1D, L2 memory protection, and TPCC\_MPPAG, TPCC\_MPPAJ for EDMA memory protection. [Figure 5-31](#), [Figure 5-32](#), and [Figure 5-33](#) show which register corresponds to each page permission structure.

**Figure 5-31. L1P Memory Protection Registers**



iva2-042

**Figure 5-32. L1D Memory Protection Registers**

iva2-043

**Figure 5-33. L2 Memory Protection Registers**

iva2-044

**NOTE:** When memory is used as cache, all its corresponding MPPA registers should be set to 0x0000.

**Table 5-20** shows which register corresponds to each memory address for megacell internal memory.

**Table 5-20. IVA2.2 Megamodule Memory Protection Page Registers**

| Register Number | L1PMPPAk, Address Range   | L1DMPPAk, Address Range   | L2MPPAj, Address Range    |
|-----------------|---------------------------|---------------------------|---------------------------|
| 0               | N/A <sup>(1)</sup>        | N/A                       | 0x0080 0000 - 0x0080 07FF |
| 1               | N/A                       | N/A                       | 0x0080 0800 - 0x0080 0FFF |
| 2               | N/A                       | N/A                       | 0x0080 1000 - 0x0080 17FF |
| 3               | N/A                       | N/A                       | 0x0080 1800 - 0x0080 1FFF |
| 4               | N/A                       | 0x00F0 4000 - 0x00F0 4FFF | 0x0080 2000 - 0x0080 27FF |
| 5               | N/A                       | 0x00F0 5000 - 0x00F0 5FFF | 0x0080 2800 - 0x0080 2FFF |
| 6               | N/A                       | 0x00F0 6000 - 0x00F0 6FFF | 0x0080 3000 - 0x0080 37FF |
| 7               | N/A                       | 0x00F0 7000 - 0x00F0 7FFF | 0x0080 3800 - 0x0080 3FFF |
| 8               | N/A                       | 0x00F0 8000 - 0x00F0 8FFF | 0x0080 4000 - 0x0080 47FF |
| 9               | N/A                       | 0x00F0 9000 - 0x00F0 9FFF | 0x0080 4800 - 0x0080 4FFF |
| 10              | N/A                       | 0x00F0 A000 - 0x00F0 AFFF | 0x0080 5000 - 0x0080 57FF |
| 11              | N/A                       | 0x00F0 B000 - 0x00F0 BFFF | 0x0080 5800 - 0x0080 5FFF |
| 12              | N/A                       | 0x00F0 C000 - 0x00F0 CFFF | 0x0080 6000 - 0x0080 67FF |
| 13              | N/A                       | 0x00F0 D000 - 0x00F0 DFFF | 0x0080 6800 - 0x0080 6FFF |
| 14              | N/A                       | 0x00F0 E000 - 0x00F0 EFFF | 0x0080 7000 - 0x0080 77FF |
| 15              | N/A                       | 0x00F0 F000 - 0x00F0 FFFF | 0x0080 7800 - 0x0080 7FFF |
| 16              | 0x00E0 0000 - 0x00E0 07FF | 0x00F1 0000 - 0x00F1 07FF | 0x0080 8000 - 0x0080 87FF |
| 17              | 0x00E0 0800 - 0x00E0 0FFF | 0x00F1 0800 - 0x00F1 0FFF | 0x0080 8800 - 0x0080 8FFF |
| 18              | 0x00E0 1000 - 0x00E0 17FF | 0x00F1 1000 - 0x00F1 17FF | 0x0080 9000 - 0x0080 97FF |
| 19              | 0x00E0 1800 - 0x00E0 1FFF | 0x00F1 1800 - 0x00F1 1FFF | 0x0080 9800 - 0x0080 9FFF |
| 20              | 0x00E0 2000 - 0x00E0 27FF | 0x00F1 2000 - 0x00F1 27FF | 0x0080 A000 - 0x0080 A7FF |
| 21              | 0x00E0 2800 - 0x00E0 2FFF | 0x00F1 2800 - 0x00F1 2FFF | 0x0080 A800 - 0x0080 AFFF |
| 22              | 0x00E0 3000 - 0x00E0 37FF | 0x00F1 3000 - 0x00F1 37FF | 0x0080 B000 - 0x0080 B7FF |
| 23              | 0x00E0 3800 - 0x00E0 3FFF | 0x00F1 3800 - 0x00F1 3FFF | 0x0080 B800 - 0x0080 BFFF |
| 24              | 0x00E0 4000 - 0x00E0 47FF | 0x00F1 4000 - 0x00F1 47FF | 0x0080 C000 - 0x0080 C7FF |
| 25              | 0x00E0 4800 - 0x00E0 4FFF | 0x00F1 4800 - 0x00F1 4FFF | 0x0080 C800 - 0x0080 CFFF |
| 26              | 0x00E0 5000 - 0x00E0 57FF | 0x00F1 5000 - 0x00F1 57FF | 0x0080 D000 - 0x0080 D7FF |
| 27              | 0x00E0 5800 - 0x00E0 5FFF | 0x00F1 5800 - 0x00F1 5FFF | 0x0080 D800 - 0x0080 DFFF |
| 28              | 0x00E0 6000 - 0x00E0 67FF | 0x00F1 6000 - 0x00F1 67FF | 0x0080 E000 - 0x0080 E7FF |
| 29              | 0x00E0 6800 - 0x00E0 6FFF | 0x00F1 6800 - 0x00F1 6FFF | 0x0080 E800 - 0x0080 EFFF |
| 30              | 0x00E0 7000 - 0x00E0 77FF | 0x00F1 7000 - 0x00F1 77FF | 0x0080 F000 - 0x0080 F7FF |
| 31              | 0x00E0 7800 - 0x00E0 7FFF | 0x00F1 7800 - 0x00F1 7FFF | 0x0080 F800 - 0x0080 FFFF |
| 32              | -                         | -                         | 0x007E 0000 - 0x007E 0FFF |
| 33              | -                         | -                         | 0x007E 1000 - 0x007E 1FFF |
| 34              | -                         | -                         | 0x007E 2000 - 0x007E 2FFF |
| 35              | -                         | -                         | 0x007E 3000 - 0x007E 3FFF |
| 36 - 55         | -                         | -                         | N/A                       |
| 56              | -                         | -                         | 0x007F 8000 - 0x007F 8FFF |
| 57              | -                         | -                         | 0x007F 9000 - 0x007F 9FFF |
| 58              | -                         | -                         | 0x007F A000 - 0x007F AFFF |
| 59              | -                         | -                         | 0x007F B000 - 0x007F BFFF |
| 60              | -                         | -                         | 0x007F C000 - 0x007F CFFF |
| 61              | -                         | -                         | 0x007F D000 - 0x007F DFFF |
| 62              | -                         | -                         | 0x007F E000 - 0x007F EFFF |

<sup>(1)</sup> N/A = nonmapped memory. All corresponding registers should be considered reserved.

**Table 5-20. IVA2.2 Megamodule Memory Protection Page Registers (continued)**

| Register Number | <a href="#">L1PMPPAK</a> , Address Range | <a href="#">L1DMPPAK</a> , Address Range | <a href="#">L2MPPAJ</a> , Address Range |
|-----------------|------------------------------------------|------------------------------------------|-----------------------------------------|
| 63              | -                                        | -                                        | 0x007F F000 - 0x007F FFFF               |

All these registers include three permission fields in a 16-bit permission entry in the memory protection page attribute MPPA register:

- Allowed ID field:

Each requestor on the device has an N-bit code associated with it that identifies it for privilege purposes. This code, referred to as the VBUS PrivID, accompanies all memory accesses and DMAs/IDMAs on behalf of that requestor. That is, when a requestor triggers a DMA/IDMA transfer directly, either by writing to IDMA registers or by triggering the execution of a set of EDMA parameters, the corresponding DMA engine captures the PrivID of the requestor and provides that PrivID with the transfer.

Each memory protection entry is associated with an 8-bit allowed-IDs field that indicates which requestors can access the given page. The memory protection hardware maps the PrivIDs of all possible requestors to bits in the allowed-IDs field in the memory protection entries. The allowed-IDs field discriminates among the various CPUs, non-CPU requestors, and the accesses of a given CPU to its own local memories:

- AID0 through AID5 map small-numbered VBUS PrivIDs to allowed ID bits.
- An additional allowed-ID bit, AIDX, captures accesses by higher-numbered PrivIDs.
- The LOCAL bit treats CPU accesses to its local L1s and L2 specially. Only the L1 and L2 memory controllers implement the LOCAL bit.

When set to 1, the AID bit grants access to the corresponding PrivID. When set to 0, the AID bit denies access to the corresponding requestor.

PrivID assignments for bits AID0 through AIDX apply to:

- CPU memory and IDMA memory: IVA\_XMC.[L1PMPPAK](#)[15:9] for L1P memory, IVA\_XMC.[L1DMPPAK](#)[15:9] for L1D memory, and IVA\_XMC.[L2MPPAJ](#)[15:9] for L2 memory
- EDMA memory: [TPCC\\_MPPAG](#)[15:9] and [TPCC\\_MPPAJ](#)[15:9] for EDMA block

The AIDX bit maps to PrivIDs that do not have dedicated AID bits associated with them. This bit refers to external mastering peripherals, especially on devices with a large number of CPUs. If a given device must discriminate among external mastering peripherals, it can assign lower-numbered PrivIDs to these peripherals.

For the EDMA module, the AIDX bit is the [TPCC\\_MPPAJ](#)[9] and [TPCC\\_MPPAJ](#)[9] EXT bits.

The LOCAL bit governs DSP CPU accesses to its own local L1 and L2 memories. It is defined in IVA\_XMC.[L1PMPPAK](#)[8] for L1P memory, in IVA\_XMC.[L1DMPPAK](#)[8] for L1D memory, and in IVA\_XMC.[L2MPPAJ](#)[8] for L2 memory. It is not defined for EDMA.

With respect to the allowed ID field, the DSP megamodule treats all remote CPU accesses to DSP megamodule memories identically to DMA accesses from that remote CPU. Therefore, DSP megamodule uses the PrivID to consult the corresponding AID bit when considering remote accesses.

However, the DPS megamodule module never compares local accesses to L1 and L2 memory against the AID bits in the allowed ID field. Instead, it consults the LOCAL bit to determine whether the CPU can access its local memory.

With this scheme, a software program can designate a page as direct CPU access only by setting the LOCAL bit to 1 and setting all other allowed IDs to 0. Conversely, a software program can designate a page as DMAs issued from this CPU only by setting its AID bit and clearing the LOCAL bit. Such a setting is limited, but it can be useful in a sensitive environment, or in the context of a device driver.

- Request-Type Based Permissions field:

The DPS megamodule memory protection model defines three fundamental functional access types: read, write, and execute. Read and write refer to data accesses originating through the load/store units on the DSP CPU or through the DMA/IDMA engines. Execute refers to accesses associated with program fetch.

The DSP megamodule memory protection model allows control of read, write, and execute permissions independently for both user and supervisor mode. This results in the 6-bit permission field shown in [Table 5-21](#).

**Table 5-21. Request-Type Access Controls**

| Bit Name | Description                           |
|----------|---------------------------------------|
| SR       | Supervisor can read                   |
| SW       | Supervisor can write                  |
| SX       | Supervisor can execute <sup>(1)</sup> |
| UR       | User can read                         |
| UW       | User can write                        |
| UX       | User can execute <sup>(1)</sup>       |

<sup>(1)</sup> IVA\_XMC.L1DMPPAXX do not implement these bits.

For each bit, writing 1 permits the access type, and writing 0 denies it. For instance, setting the UX bit to 1 means that user mode can execute from the given page. The DSP megamodule allows specifying all six of these bits separately. For L1P, L1D, and L2 memories, and for EDMA, these bits are defined in IVA\_XMC.L1PMPPAK[5:0], IVA\_XMC.L1DMPPAK[5:0], IVA\_XMC.L2MPPA][5:0], and TPCC\_MPPAG[5:0] and TPCC\_MPPAJ[5:0], respectively.

**NOTE:** IVA\_XMC.L1DMPPAK do not implement the SX and UX bit, because execution is not possible from L1D memory. Therefore, these bits are reserved and should not be used in these registers.

- Other registers

The memory protection block records the address of the fault in the peripheral memory protection fault address register (MPFAR). It records the rest of the information about the fault in the peripheral memory protection fault status register (MPFSR); this register is formatted similarly to the MPPA. Software can write to the memory protection fault command register (MPFCR).

The MPFAR corresponds to the following registers: IVA\_XMC.L1PMPFAR for L1P memory, IVA\_XMC.L1DMPFAR for L1D memory, IVA\_XMC.L2MPFAR for L2 memory, IVA\_IDMA.ICFGMPFAR for IDMA, and TPCC\_MP FAR for EDMA.

The MPFSR corresponds to the following registers: IVA\_XMC.L1PMPFSR for L1P memory, IVA\_XMC.L1DMPFSR for L1D memory, IVA\_XMC.L2MPFSR for L2 memory, IVA\_IDMA.ICFGMPFSR for IDMA, and TPCC\_MPFSR for EDMA.

Using the MPFSR register, a memory protection fault can be decoded as follows by software:

- If the LOCAL status bit is set to 1, the request was a local DSP CPU request to its own memories. Otherwise (if the LOCAL status bit is set to 0), the VBUS ID of the faulting requestor is in the MPFSR[15:9] field.
- The value of the access type field (SR, SW, SX, UR, UW, UX) indicates the type of access that was at fault.

The MPFAR and MPFSR store information for only one fault. The hardware block holds the fault information until the software clears it by writing to MPFCR.

The user clears the recorded fault by setting the MPFCR[0] MPFCLR bit to 1. Writing 1 to this bit clears both MPFAR and MPFSR registers. The MPFAR and MPFSR read-only registers do not respond to writes. Once the user clears the fault, the hardware records the next protection violation, and signals an exception when it occurs. Writing 1 to any other bit of the MPFCR has no effect on the memory protection registers. Writing 0 to the MPFCR[0] MPFCLR bit also has no effect.

The MPFCR corresponds to the following registers: IVA\_XMC.L1PMPFCR for L1P memory, IVA\_XMC.L1DMPFCR for L1D memory, IVA\_XMC.L2MPFCR for L2 memory, IVA\_IDMA.ICFGMPFCR for IDMA, and TPCC\_MPFCR for EDMA.

- Events generated to DSP megamodule IC block

Internal events are generated to inform the DSP megamodule module for memory protection:

- CCMPINT (EVT28) is generated for a TPCC memory protection interrupt.
- SYS\_CMPA (EVT 119) is generated in case of a SYS CPU memory protection fault.
- PMC\_CMPA (EVT120) and PMC\_DMMPA (EVT121) are generated in case of CPU and DMA memory protection faults, respectively, on PMC.
- DMC\_CMPA (EVT122) and DMC\_DMMPA (EVT123) are generated in case of CPU and DMA memory protection faults, respectively, on DMC.
- UMC\_CMPA (EVT124) and UMC\_DMMPA (EVT125) are generated in case of CPU and DMA memory protection faults, respectively, on UMC.
- PMC\_CMPA (EVT126) is generated in case of a CPU memory protection fault on EMC.

The AID of the DSP appears in the DNUM control register in the CPU. DNUM is the DSP core number register; it is used to identify which DSP subsystem accessed the shared resources. Because there is only one C64x+:

- GEM\_DNUM[7:4] always equals 0x0.
- GEM\_DNUM[3:0] equals 0x0 because DSP is labeled as CPU0 in the single core system.

Thus, the possible requestors are:

- C64x
- IDMA
- EDMA
- Any device L3 initiator (through the IVA2.2 slave port)

The PrivID (relative to the DNUM register) equals 0. The ID of IVA DMA accesses is always 0x0, because the IVA DMA inherits ID from DSP megamodule. All accesses on the IVA2 slave port to local memories are seen by DSP megamodule as accesses from an external (non-DSP megamodule) initiator.

Thus, the hard-mapped memory protection IDs are:

- AID0, used for IVA DMA
- AID1 to AID5 (not used)
- AIDX, used by the slave port (L3 initiators)
- LOCAL bit, used by DSP loads, stores, and program fetches to memory attached directly to DSP megamodule

#### **5.4.9.2.2 Bandwidth Management**

The bandwidth management scheme can be summarized as weighted-priority-driven bandwidth allocation. Each requestor (EDMA, IDMA, CPU, etc.) is assigned a priority level on a per-transfer basis. The programmable priority level has a single meaning throughout the system: there is a total of nine priority levels, where priority 0 is highest and priority 8 is lowest priority. When requests for a single resource contend, access is granted to the highest priority requestor. When contention occurs for multiple successive cycles, a contention counter ensures that the lower priority requestor gets access to the resource every one out of  $n$  arbitration cycles, where  $n$  is programmable through the MAXWAIT field. For each identified requestor, a corresponding MAXWAIT field controls the maximum number of cycles that a request can be blocked.

- CPUARB registers: CPU priority and MAXWAIT programming model

The DSP CPU-initiated transfers consist of two components:

1. Program fetch transfers are issued by the CPU to the PMC, and the resulting L1P cache coherency operations (such as alloc/evict) are then issued to the UMC.
2. Data load/store transfers are issued by the CPU to the DMC, and the resulting L1D cache coherency operations (such as alloc/evict/long distance accesses) are then issued to the UMC.

Both program and data requests use the CPUARB values to define the maximum wait time (CPUARB[5:0] MAXWAIT) and priority (CPUARB[18:16] PRI). The effect of the CPUARB values is not just local to PMC

or DMC. Priority/maxwait time applies to DMC/PMC cache transactions throughout the DSP megamodule and controls arbitration at each relevant subblock within DSP megamodule. The priority (PRI) and MAXWAIT field is programmed locally in the UMC, DMC, and EMC blocks, through the IVA\_UMC.CPUARBU, IVA\_DMC.CPUARBD, and IVA\_IDMA.CPUARBE PRI and MAXWAIT fields, respectively.

The default value of the CPUARB[18:16] PRI field is set so that CPU transactions are second to highest in the system. This should be a relatively typical value used in most systems, which results in the DSP CPU being granted highest priority most of the time, but a McBSP-type peripheral (typically programmed as the highest priority transfer for sDMA requests) can interrupt the DSP CPU transfers on a nearly immediate basis.

---

**NOTE:** CPU priority is software-programmable, but it is considered static (1-time-programmable) for bandwidth management. That is, during normal operation, all DSP CPU transactions are of the same priority. There is no concept of priority inheritance for CPU-initiated transfers as a result of CPU transfer A set at priority X and CPU transfer B set at priority Y. Because CPUARB must be programmed by the CPU, and is therefore a run-time programmation, the effect of the new CPUARB value must take effect for future CPU transfers.

---

- UCARB registers - User coherence operations

User coherence operations are broken into two types, block-oriented coherence and global coherence operations. The priority of these requests relative to other requests in the system varies as follows:

- Global user coherence: Always highest priority
- Block-oriented coherence: Always lowest priority

Because user coherence priority is fixed, the UCARB registers do not include a priority field. And because global user coherence operations are inherently highest priority, the MAXWAIT field programming applies only to block-oriented user coherence operations, not to global cache operations.

The UCARB[5:0] MAXWAIT field affects only the UMC (IVA\_UMC.UCARBU register) and the DMC (IVA\_DMC.UCARBD register). The priority values (being fixed) are assumed to be known at both the UMC and the DMC.

---

**NOTE:** The UCARB[5:0] MAXWAIT field (and the implied priorities) does not control the priority of coherence operations that result from DMA transactions or CPU transactions.

---

- IDMAARB registers - IDMA priority programming model

IDMA supports two active transfers at any time through IDMA channel 0 (used for memory to/from configuration bus transfers) and IDMA channel 1 (used for memory-to-memory transfers). The IDMAARB[5:0]MAXWAIT field is used to determine the maximum wait time for IDMA transactions. The priority level is not programmed through the IDMAARB register. Instead, the priority level is programmed directly through the IDMA control registers. In summary, IDMA transfer priority is:

- IDMA channel 0: Always highest priority
- IDMA channel 1: Programmable priority: the IVA\_IDMA.IDMA1\_COUNT[31:29] PRI field

For this reason, the IDMAARB registers do not include a priority field. The IDMAARB[5:0] MAXWAIT field affects not only the EMC (IVA\_IDMA.IDMAARBE register) but also the UMC (IVA\_UMC.IDMAARBU register) and the DMC (IVA\_DMC.IDMAARBD register).

---

**NOTE:** IDMA channel 0 has no need for priority inheritance, because it is always the highest priority transfer in the system.

However, if an IDMA channel 1 transfer and an IDMA channel 0 transfer are pending at the same instant, but the IDMA channel 1 queue is blocked because of contention with another requestor, the IDMA channel 1 transfer should briefly inherit the priority of the IDMA channel 0 transfer (which is always 0x0) so that the pending dataphase on IDMA channel 1 can complete and the normal priority mechanism can take control.

- 
- SDMAARB registers - Slave DMA priority programming model

The DSP megamodule slave DMA (SDMA) interface can support multiple active transfers at a time. The SDMAARB[5:0] MAXWAIT field controls the maximum wait time for all slave DMA transactions. The priority level is not programmed by the SDMAARB register. Instead, the priority level is dictated by the priority fields of the IVA\_TPCC.QUEPRI register.

The SDMAARB[5:0] MAXWAIT field does not affect only the EMC (IVA\_IDMA.[SDMAARBE](#) register), but also the UMC (IVA\_UMC.[SDMAARBU](#) register) and the DMC (IVA\_DMC.[SDMAARBD](#) register).

---

**NOTE:** Because of the pipelined nature of the VBUS interface, the DSP megamodule module can have multiple DMA transfers in flight at a time. To avoid priority inversion, the DSP megamodule must not only evaluate the priority of the transfer at the head of the EMC queue(s), but the priority of all transfers that have been accepted/queued on the VBUS interface(s), and of higher priority transfers that are queued in the device-level DMA infrastructure.

---

- [MDMAARBE](#) register - Master DMA priority programming model

The IVA\_IDMA.[MDMAARBE](#)[18:16] PRI field controls the submission priority for master DMA transactions (which are a result of cache misses or long-distance accesses to nonconfiguration space) and configuration bus transactions (long-distance accesses to configuration space or IDMA transfers to configuration space).

The IVA\_IDMA.[MDMAARBE](#) priority is different from other programmable priorities in the system, in that the priority value does not affect internal arbitration for resources. This PRI[3:0] value is simply used as the VBUS priority value for all transactions initiated by the DMA master interface or memory-mapped register configuration interface.

Arbitration for the internal half of the transfer depends on the initiator (which could be DSP CPU, PMC, or DMC) or user coherence (UMC), or IDMA, etc. Arbitration for the external half of the transfer is DMA-dependent, and should rely on the Vbus priority, which is copied from the IVA\_IDMA.[MDMAARBE](#)[18:16] PRI field.

---

**NOTE:** Because no internal arbitration results from the IVA\_IDMA.[MDMAARBE](#) register, there is no need for the MAXWAIT field in this register.

---

### 5.4.9.3 SL2 Memory Management

#### 5.4.9.3.1 SL2 Performance Optimizations

To limit the number of accesses through the SL2 interface and to optimize bandwidth, it is recommended that the user access SL2 using, as much as possible, bursts and aligned on burst boundaries. Optimum bandwidth savings can be obtained by doing bursts of 8x32 aligned on 32-byte boundaries.

This can be done using ARM968 (sequencer module) LDM or STM instructions. For details, see the ARM reference manual.

#### 5.4.9.3.2 SL2 Performance Limitations

Accesses through the SL2IF OCP interface to SL2 memory are not intended to be optimized for single reads, but only for bursts. Maximum bandwidth can be obtained using bursts of 8x32b bursts or larger (bursts larger than 8x32 are divided into 8x32 bursts). Generating single requests to the SL2IF interface has two disadvantages:

- Uses a large portion of the SL2 bandwidth, resulting in iME and iLF performance degradation
- Increases dynamic power consumption

In particular, ARM968 instruction fetches generate single requests on the local interconnect. SL2 is not optimized for ARM968 instruction direct fetching. If the ITCM is too small for an ARM968 program, an ARM968 program must be DMAed in from memory (possibly SL2, as DMA accesses are bursted).

#### 5.4.9.3.3 SL2 Illegal Accesses

It is illegal for the user to generate unaligned bursts that span SL2 address range boundaries.

## 5.4.10 IVA2.2 Power Management

### 5.4.10.1 Clock Management

#### 5.4.10.1.1 Clock Configuration

The IVA2.2 subsystem receives one single-clock signal from the PRCM, the DPLL2\_ALWON.FCLK.

From the DPLL2\_ALWON.FCLK functional clock provided by the PRCM, three internal clocks (CD0\_CLK, CD1\_CLK, and CD2\_CLK) are generated by the IVA2.2 DPLL and SYSC modules:

- The frequency of the CD0\_CLK clock can be software-tuned with a PRCM register by setting the PRCM.CM\_CLKSEL1\_PLL\_IVA2 and PRCM.CM\_CLKSEL2\_PLL\_IVA2 registers.
- The CD1\_CLK clock is always a divide-by-two of the CD0\_CLK clock and its frequency cannot be changed by software.
- The CD2\_CLK clock is always a divide-by-two of the CD0\_CLK clock and its frequency cannot be changed by software.

For a complete description of the PRCM registers discussed in this section, see [Chapter 3, Power, Reset, and Clock Management](#).

#### 5.4.10.1.2 Clock Gating

- IVA2.2 subsystem

The IVA2.2 internal clocks can be hardware-disabled by the PRCM when the MSTANDBY/WAIT handshake protocol occurs. To configure the PRCM so that IVA2.2 internal clocks are hardware-supervised, set the PRCM.CM\_AUTOIDLE\_PLL\_IVA2[2:0] AUTO\_IVA2\_DPLL field to 0x1.

When the IVA2.2 subsystem does not require its internal clocks, they can be disabled at the PRCM level by setting the PRCM.CM\_FCLKEN\_IVA2[0] EN\_IVA2 bit to 0.

For a complete description of these PRCM registers, see [Chapter 3, Power, Reset, and Clock Management](#).

- SYSC module

The IVA2.2 SYSC module implements automatic clock gating on internal hardware detection of the absence of activity. The transition from clock-gated to clock-nongated state is operated with no cycle latency penalty.

The automatic clock-gating feature is enabled by setting the IVA\_SYSC.[SYSConfig\[0\]](#) AUTOIDLE bit to 1 (default value). This feature can be disabled by setting the IVA\_SYSC.[SYSConfig\[0\]](#) AUTOIDLE bit to 0 and making the clock free-running.

- WUGEN module

The IVA2.2 WUGEN module implements automatic clock gating on internal hardware detection of the absence of activity. The transition from clock-gated to clock-nongated state operates with no cycle latency penalty.

Automatic clock gating is enabled by setting the IVA\_WUGEN.[WUGEN\\_SYSConfig\[0\]](#) AUTOIDLE bit to 1 (default mode). The clock can be made free-running by setting the IVA\_WUGEN.[WUGEN\\_SYSConfig\[0\]](#) AUTOIDLE bit to 0.

- TPCC from EDMA module

The EDMA (or TPCC) module implements automatic clock gating on internal hardware detection of the absence of activity. The transition from clock-nongated to clock-gated state operates with no cycle latency penalty.

### 5.4.10.2 Reset Management

In addition to hardware reset signals generated by the PRCM, the IVA2.2 subsystem can be reset by software control.

The three DSP power domain software resets (DSP\_RST1, DSP\_RST2, and DSP\_RST3) are partial warm-reset sources. These software resets map to the PRCM.RM\_RSTCTL\_IVA2[0] RST1\_IVA2 bit, the RM\_RSTCTRL\_IVA2[1] RST2\_IVA2 bit, and the PRCM.RM\_RSTCTL\_IVA2[2] RST3\_IVA2 bit, respectively, in the PRCM register RM\_RSTCTRL\_IVA2.

Setting these 3 bits to 1 performs a software reset to the IVA2.2 subsystem.

The reset status is logged in the PRCM.RM\_RSTST\_IVA2[8] IVA2\_SW\_RST1 read-only bit for IVA2\_RST1 software reset, the PRCM.RM\_RSTST\_IVA2[9] IVA2\_SW\_RST2 read-only bit for IVA2\_RST2 software reset, and the PRCM.RM\_RSTST\_IVA2[10] IVA2\_SW\_RST3 read-only bit for IVA2\_RST3 software reset.

For a complete description of these PRCM registers, see [Chapter 3, Power, Reset, and Clock Management](#).

---

**NOTE:** Software reset can be applied only while the IVA2.2 subsystem is in clock-off mode.

---

#### 5.4.10.3 Power-Down and Wake-Up Management

- DSP megamodule power-down controller (PDC)

The DSP megamodule embeds a PDC block that allows power-down management by software. Individual DSP megamodule blocks such as DSP CPU, PMC, DMC, EMC, and UMC can be powered off by the PDC.

- This software control is ensured by the IVA\_SYS.[PDCCMD](#) register:
  - By setting the IVA\_SYS.[PDCCMD](#)[16] GEMPD bit to 1, the user enables power-down management during idle mode.
  - By setting the IVA\_SYS.[PDCCMD](#) xMCLOG[1:0] and IVA\_SYS.[PDCCMD](#) xMCMEM[1:0] fields ( $x = \{P, D, U\}$ ), the user controls the XMC clock-gating and standby memory modes. For example, DMC is controlled with the IVA\_SYS.[PDCCMD](#)[5:4] DMCLOG and IVA\_SYS.[PDCCMD](#)[7:6] xMCMEM fields.
  - The programming sequence for transition to clock-off state is as follows:

Before executing the IDLE instruction, the user must perform the following sequence:

1. Write 1 to the IVA\_SYS.[PDCCMD](#)[16] GEMPD bit (standby state); by default, the IVA\_SYS.[PDCCMD](#) xMCLOG[1:0] and IVA\_SYS.[PDCCMD](#) xMCMEM[1:0] ( $x = \{P, D, U\}$ ) field values are all 0x1, so that module clock gating is enabled and standby mode of memories is statically activated after the IDLE instruction executes.
2. Mask all interrupts not intended to wake up the IVA2.2 subsystem.
3. Program the PRCM so that IVA2.2 clocks are cut on IVA2.2 standby. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).
4. Read back all the written registers to ensure write completion.

The user must also ensure that no other instruction is executed parallel to the IDLE instruction.

When a clock stop request is asserted, the PDC\_INT event (EVT118, see [Table 5-3](#)) is generated to the DSP megamodule IC module to inform the DSP CPU to initiate a power-down sequence. For more information about interrupt management, see [Section 5.4.8, Interrupt Management](#).

- Programming sequence for transition to power-off state:

Before executing the IDLE instruction, the user must perform the sequence shown in [Figure 5-34](#).

**Figure 5-34. IVA2 Power Off**

iva2-045

The user must also ensure that no other instruction is executed parallel to the IDLE instruction. When IVA2 is ready to go to off mode, there are two ways to completely shut down IVA2 subsystem (see [Figure 5-35](#)):

**Figure 5-35. IVA2 Power Down**


iva2-046

**CAUTION**

The IVA2 clock must not be stopped manually; otherwise, the WUGEN module inside the IVA2 has no functional clock and cannot wake up the IVA subsystem.

When the IVA2 is shut down, it can be waked up by an external event. The boot code executed after wakeup must include at least the following steps (see [Figure 5-36](#)):

**Figure 5-36. IVA2 Wake Up**

iva2-047

#### 5.4.10.4 Powering Down L2\$ Memory While IVA2 is Active

If the L2\$ is unused while the DSP is active, the IVA2.2 can completely switch off the 96-KB SRAM attached to the L2\$ controller. This typically happens when the DSP is running at a low frequency (for instance, at the same frequency as the SDRAM) where L2\$ is not justified. The alternative is to switch off L2\$ SRAM completely, losing all L2-cache content and memory-mapped SRAM (from 0x10800000 to 0x1080FFFF). It is impossible to put the SRAM in low-leakage mode and retain data/program while the DSP is active. Also, L2 cache SRAM is the only memory/cache that supports this off mode while DSP is active. L1D and L1P cache SRAM off modes are not supported while DSP is active.

The sequence to enter L2\$ off mode while DSP is active follows:

1. Save **L2CFG** and disable the L2\$ by converting L2-cache SRAM to memory-mapped SRAM only (96KB): **L2CFG.L2MODE = 0x0**.
2. Read back **L2CFG** to ensure that Step 1 is complete.
3. Save **L2MPPAj** ( $j = 0$  to 31) and write 0x0 to the **L2MPPAj** ( $j = 0$  to 31) registers to report access to L2 memory (for debug) and enable associated permission check interrupt and/or exception.
4. Configure the PRCM to switch off L2:  
**PRCM.PM\_PWSTCTRL\_IVA2.SHAREDL2CACHEFLATONSTATE = 0x0**.
5. Read back **PRCM.PM\_PWSTCTRL\_IVA2** to ensure that Step 4 is complete.

After this sequence, the user must not access the L2 memory. If this happens (typically in code under debug), a memory-protection interrupt and/or exception is taken.

The sequence to exit L2\$ off mode (while DSP is active) follows:

1. Configure the PRCM to switch on L2:  
`PRCM.PM_PWSTCTRL_IVA2.SHAREDL2CACHEFLATONSTATE = 0x3.`
2. Read back PRCM.PM\_PWSTCTRL\_IVA2 to ensure that Step 1 is complete.
3. Restore [L2MPPAj](#) ( $j = 0$  to 31).
4. Restore [L2CFG](#).
5. Read back PRCM.PM\_PWSTCTRL\_IVA2 to ensure that Step 4 is complete.

---

**NOTE:** After this sequence, L2\$ is empty and content in L2\$-SRAM configured as memory-mapped is lost.

---

---

**NOTE:** This mode does not provide large power savings, but is provided in IVA2.2 as an enabler for power-management software development, anticipating that leakage is a major contributor to power consumption, even in active mode.

---

#### 5.4.10.5 Video and Sequencer Module Management

##### 5.4.10.5.1 Module Dynamic Power Savings

The video accelerator/sequencer modules implement auto-clock gating to save dynamic power consumption when no activity is locally detected. For some modules (iME, iLF, iLCD, sequencer, video system controller), it is also possible to disable auto-gating by software. Auto-clock gating has no performance impact.

To optimize local power management, configure the following registers (default values):

- IVA.[iME\\_SYSCONFIG](#) Autoldle = 1
- IVA.[iLF\\_SYSCONFIG](#) Autoldle = 1
- IVA.[SEQ\\_SYSCONFIG](#) Autoldle = 1
- IVA.[VIDEOSYSC\\_SYSCONFIG](#) Autoldle = 1
- IVA.iLCD\_SYSCONFIG Autoldle = 1

##### 5.4.10.5.2 System Dynamic Power Savings

For further system dynamic power savings, a module root clock can be independently stopped when the module has no activity.

The root clock of a module can be stopped by writing 0 in the bit associated with that module in the IVA.[VIDEOSYSC\\_CLKCTL](#) register. The clock can be stopped, depending on whether the module is active when it is asked to be stopped. Reading the bit associated with the module in the IVA.[VIDEOSYSC\\_CLKST](#) register lets the user check whether the module clock has effectively been stopped.

Writing 1 in the bit associated with that module immediately restarts clocks if they are stopped, and makes the module operational.

When stopping the module root clock, take the following precautions:

- Synchronize with other CPUs/DMAs to determine whether another part of the system requires access to the module.
- Check whether the module has dependencies with other modules.
- Poll the status register in the module to determine whether the module is active.

#### CAUTION

Invalid configuration of [VIDEOSYSC\\_CLKCTL](#) causes unpredictable results.

For further system dynamic power savings, the sequencer CPU root clock can be independently divided when sequencer activity is reduced.

The root clock of the sequencer CPU can be divided by writing a value different from the value of the NOCLKDIV bit in the [VIDEOSYSC\\_CLKDIV](#) register. There is no software precaution to divide the sequencer CPU clock internally, in terms of traffic or idle conditions. However, this setting is static; that is, it is defined based on whether the sequencer MHz budget must run at full speed, based on a particular task or scenario. The [VIDEOSYSC\\_CLKDIV](#) value must not be changed twice within 16 sequencer clock cycles, or the second request can be ignored. This has no other side effect. Because of the requirement that the setting be static, it is acceptable to make this sequence uninterruptible, pad it with NOPs (or useful operations), or check for change effect, after changing the sequencer clock ratio.

The sequencer CPU clock can be independently divided by 2, 3, or 4, or not divided at all. By default, this clock is not divided.

#### 5.4.11 Error Identification Process

Several mechanisms are available in the IVA2.2 subsystem to report errors at different levels.

##### 5.4.11.1 Error Reporting for IDMA Module

The IDMA has its own error-reporting mechanism. The DSP megamodule implements an error register in EMC (IVA\_IDMA.[IBUSERR](#)) that latches errors for external invalid transactions on either the DMA (MDMA) bus or the configuration (CFG) bus. Errors are detected on the CFG and MDMA write status or read status interfaces. If an error is received and the corresponding command is an invalid transaction, the IVA\_IDMA.[IBUSERR](#)[31:29] ERR, IVA\_IDMA.[IBUSERR](#)[10:8] XID, and IVA\_IDMA.[IBUSERR](#)[2:0] STAT fields are updated accordingly. An error signaled through a non-0 read status is detected on the read data/status interface or a non-0 write status on the write status interface. Alternately, the EMC records an error if a read or write status response is detected for an unrecognized write ID.

---

**NOTE:** The user must ensure that the EMC detects/stores error information only for the first detected error on either the MDMA or CFG bus, regardless of whether it is a read or write status. In other words, a single error register (IVA\_IDMA.[IBUSERR](#)) is shared by read and write errors and by the MDMA bus and the CFG bus, and only the first error is stored. If a read error and a write error are detected at the same time, the write status error is given higher priority and is latched into the IVA\_IDMA.[IBUSERR](#) register.

---

When an error is detected and stored in the IVA\_IDMA.[IBUSERR](#) register, the EMC\_BUSERR event (EVT127, see [Table 5-3](#)) is available as a system event that can be selected as either a DSP CPU interrupt or an exception event.

The user can clear latched errors by writing 1 to the IVA\_IDMA.[IBUSERRCLR](#)[0] CLR bit.

##### 5.4.11.2 Error Reporting for EDMA Module

The TPTC and TPCC blocks of the EDMA module also contain registers to inform the user of a problem during IVA2.2 external DMA communication.

#### TPCC Block

The TPCC provides a single error interrupt output CCERRINT (EVT38, see [Table 5-3](#)) that consolidates the error conditions:

- QDMA missed events (stored in the [TPCC\\_QEMR](#) register)
- DMA missed events (stored in the [TPCC\\_EMR](#) register)
- Transfer completion code error (stored in the [TPCC\\_CCERR](#)[16] TCCERR bit)
- Queue threshold error events (stored in the [TPCC\\_CCERR](#)[n] QTHRXC<sub>Dn</sub> bit, n = {0,1})

When an error is detected, the CCERRINT event is asserted, because error events do not have enables.

---

**NOTE:** The CCERRINT event follows the same conventions as other TPCC interrupt outputs. When the error interrupt condition transitions from a no-errors-are-set state to at least one error set, the error output (CCERRINT) pulses high for one TPCC clock cycle. If additional errors are latched before the original error is cleared by the user, the TPCC does not generate additional interrupt pulses. The software must poll all bits during execution of the ISR, and clear all error conditions, so that subsequent error pulses can be generated by the TPCC block.

---

Error interrupts can be set and/or reevaluated by writes to the [TPCC\\_EEVAL](#) register.

### TPTC Block

The TPTC can also detect several error conditions:

- Read status or write status errors in the [TPTCj\\_ERRSTAT\[0\]](#) BUSERR status bit
- TR error in the [TPTCj\\_ERRSTAT\[2\]](#) TRERR status bit
- MMR address error in the [TPTCj\\_ERRSTAT\[3\]](#) MMRAERR status bit

Errors are recorded in the [TPTCj\\_ERRSTAT](#) register, regardless of whether they are enabled. They can be cleared from the [TPTCj\\_ERRSTAT](#) register only by writing 1 to the corresponding bit of the [IVA\\_TPTCj\\_ERRCLR](#) register.

The error details register ([IVA\\_TPTCj\\_ERRDET](#)) contains additional information about the first read status error or write status error detected. Future errors are bit-recorded until the [TPTCj\\_ERRDET](#) register is cleared.

If read status and write status are returned to the TPTC in the same cycle, the read or write status value that has an error (nonzero) is latched in the [TPTCj\\_ERRDET](#) register and the [TPTCj\\_ERRSTAT\[0\]](#) BUSERR bit is set. If both read and write status are nonzero, the write status is given priority for setting the [TPTCj\\_ERRDET](#) register. The [TPTCj\\_ERRDET](#) register is cleared by writing 1 to the [TPTCj\\_ERRCLR\[0\]](#) BUSERR bit.

If an error is enabled (by the [TPTCj\\_ERREN](#) register bits), the first occurrence of an enabled error generates a pulsed interrupt to the CPU by the TCERRINT event output (TCERRINT0 with EVT39 for TPTG0 and TCERRINT1 with EVT40 for TPTG1, respectively; see [Table 5-3](#)). Subsequent errors do not generate a new pulse until all accumulated errors are cleared by the CPU. The CPU clears bits in the [TPTCj\\_INTSTAT](#) register by writing 1 to the corresponding bit(s) of the [TPTCj\\_NTCLR](#) register.

#### 5.4.11.3 Error Reporting for the L3 Interconnect

L3 interconnect out-of-band errors are also reported by the external L3 interrupt signal (`I3_ia_iv2_initSError_o`). This signal corresponds to the EVT84 event and is directly connected to the [IVA2.2\\_nIRQ\[39\]](#) DSP CPU interrupt line. For more information about L3 interconnect error reporting, see [Chapter 9, Interconnect](#).

#### 5.4.12 Recommendations for Static Settings

The following static settings are recommended:

- `SYSC.SYSC_LICFG0.DMATRUECOMPEN = 1;` // DMA last write is nonposted.
- `SYSC.SYSC_LICFG0.GEMTRUECOMPEN = 1;` // DSP last write is nonposted.
- `SYSC.SYSC_LICFG0.GEMBURSTOPTEN = 1;` // DSP burst optimization

Ensure that the following setting is carefully set:

- All 2D DMA transfers source and/or destination are to a VRFB view (tiling structure):
  - // DMA 2D burst optimization
  - `SYSC.SYSC_LICFG0.DMA2DOPTEN = 1`

---

**NOTE:** If the preceding condition is not set accurately, setting the DMA2DOPTEN optimization can degrade performance.

---

**NOTE:**

1. A supersection type MMU page (16MB) must be defined for that VRFB view.
2. When the SYSC.SYSC\_LICFG0.PAGEXINGEN is set to 1, a 2D DMA should not cross a MMU page boundary. When this bit is set, it disables the hardware check mechanism for better performance (but the user should ensure that 2D DMA does not cross MMU pages).

Therefore, ensure that the following setting is carefully set:  
**SYSC.SYSC\_LICFG0.PAGEXINGEN = 1.**

---

**NOTE:** If the preceding condition is not set accurately, setting the PAGEXINGEN optimization can cause undefined results, including deadlock situations.

---

## 5.5 IVA2.2 Subsystem Register Manual

[Table 5-22](#) lists the IVA2.2 memory space mapping as seen by the IVA2.2 DSP megamodule.

**Table 5-22. Instance Summary**

| Module Name              | Base Address | Size      |
|--------------------------|--------------|-----------|
| IC                       | 0x0180 0000  | 64K bytes |
| SYS                      | 0x0181 0000  | 64K bytes |
| IDMA                     | 0x0182 0000  | 64K bytes |
| XMC                      | 0x0184 0000  | 64K bytes |
| TPCC                     | 0x01C0 0000  | 64K bytes |
| TPTC0                    | 0x01C1 0000  | 1K byte   |
| TPTC1                    | 0x01C1 0400  | 1K byte   |
| SYSC                     | 0x01C2 0000  | 4K bytes  |
| WUGEN                    | 0x01C2 1000  | 4K bytes  |
| iVLCD <sup>(1)</sup>     | 0x0008 0000  | 8K bytes  |
| SEQ <sup>(1)</sup>       | 0x0009 0000  | 2K bytes  |
| VIDEOSYSC <sup>(1)</sup> | 0x0009 C000  | 4K bytes  |
| iME <sup>(1)</sup>       | 0x000A 0000  | 4K bytes  |
| iLF <sup>(1)</sup>       | 0x000A 1000  | 4K bytes  |
| IA_GEM                   | 0x000F 8800  | 1K bytes  |
| IA_EDMA                  | 0x000F 8C00  | 1K bytes  |
| IA_SEQ                   | 0x000F 9000  | 1K bytes  |

<sup>(1)</sup> These modules are accessible through DSP EFI port, with EFI instruction only. See [Section 5.3.4, Video Accelerator/Sequencer Local Interconnect](#).

For more information on the IVA2.2 memory mapping, see [Chapter 2, Memory Mapping](#).

---

**NOTE:** The MMU2 (IVA2.2 MMU) registers are described in [Chapter 15, Memory Management Units](#). (The MMU base address is 0x5D00 0000 on the L3 interconnect.)

---

**CAUTION**

The IVA2.2 registers are limited to 32-bit data accesses. 16-bit and 8-bit are not allowed and can corrupt register content.

## 5.5.1 IC Registers

This section provides information about the IC Module. Each register in the module is described in [Table 5-24](#) through [Table 5-46](#).

### 5.5.1.1 IC Register Mapping Summary

**Table 5-23. IC Register Summary**

| Register Name            | Type | Register Width (Bits) | Address Offset | Physical Address        |
|--------------------------|------|-----------------------|----------------|-------------------------|
| EVTFLAGi <sup>(1)</sup>  | R    | 32                    | 0x0000 0000    | 0x0180 0000 + (0x4 * i) |
| EVTSETi <sup>(1)</sup>   | W    | 32                    | 0x0000 0020    | 0x0180 0020 + (0x4 * i) |
| EVTCLRI <sup>(1)</sup>   | W    | 32                    | 0x0000 0040    | 0x0180 0040 + (0x4 * i) |
| EVTMASKi <sup>(1)</sup>  | RW   | 32                    | 0x0000 0080    | 0x0180 0080 + (0x4 * i) |
| MEVTFLAGi <sup>(1)</sup> | R    | 32                    | 0x0000 00A0    | 0x0180 00A0 + (0x4 * i) |
| EXPMASKi <sup>(1)</sup>  | RW   | 32                    | 0x0000 00C0    | 0x0180 00C0 + (0x4 * i) |
| MEXPFLAGi <sup>(1)</sup> | R    | 32                    | 0x0000 00E0    | 0x0180 00E0 + (0x4 * i) |
| INTMUXj <sup>(2)</sup>   | RW   | 32                    | 0x0000 0104    | 0x0180 0104 + (0x4 * j) |
| INTXSTAT                 | R    | 32                    | 0x0000 0180    | 0x0180 0180             |
| INTXCLR                  | W    | 32                    | 0x0000 0184    | 0x0180 0184             |
| INTDMASK                 | RW   | 32                    | 0x0000 0188    | 0x0180 0188             |
| EVTASRT                  | W    | 32                    | 0x0000 01C0    | 0x0180 01C0             |

<sup>(1)</sup> i = 0 to 3

<sup>(2)</sup> j = 1 to 3

### 5.5.1.2 IC Register Descriptions

**Table 5-24. EVTFLAGi**

|                         |                       |                 |              |
|-------------------------|-----------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x0000 + (0x4*i)      | <b>Instance</b> | IVA2.2 GEMIC |
| <b>Physical address</b> | 0x0180 0000 + (0x4*i) |                 |              |
| <b>Description</b>      | Event Flag Register   |                 |              |
| <b>Type</b>             | R                     |                 |              |

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| EF |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                       | Type | Reset |
|------|------------|-------------------------------------------------------------------|------|-------|
| 31:0 | EF         | Event Flag status<br>0: No event occurred<br>1: An event occurred | R    | 0     |

**Table 5-25. Register Call Summary for Register EVTFLAGi**

IVA2.2 Subsystem Functional Description

- INTC: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10]

IVA2.2 Subsystem Basic Programming Model

- Event Combined Programming Sequence: [11]
- Interrupt Controller Basic Programming Model for Power On of IVA2.2 Subsystem: [12] [13] [14]

IVA2.2 Subsystem Register Manual

- IC Register Mapping Summary: [15]

**Table 5-26. EVTSETi**

|                         |                       |                 |                                                                   |
|-------------------------|-----------------------|-----------------|-------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0020 + (0x4*i)      |                 |                                                                   |
| <b>Physical address</b> | 0x0180 0020 + (0x4*i) | <b>Instance</b> | IVA2.2 GEMIC                                                      |
| <b>Description</b>      | Event Set Register    |                 |                                                                   |
| <b>Type</b>             | W                     |                 |                                                                   |
| 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 |
|                         |                       |                 | ES                                                                |

| Bits | Field Name | Description                                                              | Type | Reset |
|------|------------|--------------------------------------------------------------------------|------|-------|
| 31:0 | ES         | Event Set<br>Write 0: No action<br>Write 1: Set corresponding event flag | W    | 0     |

**Table 5-27. Register Call Summary for Register EVTSETi**

IVA2.2 Subsystem Functional Description

- [INTC: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [IC Register Mapping Summary: \[1\]](#)

**Table 5-28. EVTCLRI**

|                         |                       |                 |                                                                   |
|-------------------------|-----------------------|-----------------|-------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0040 + (0x4*i)      |                 |                                                                   |
| <b>Physical address</b> | 0x0180 0040 + (0x4*i) | <b>Instance</b> | IVA2.2 GEMIC                                                      |
| <b>Description</b>      | Event Clear Register  |                 |                                                                   |
| <b>Type</b>             | W                     |                 |                                                                   |
| 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 |
|                         |                       |                 | EC                                                                |

| Bits | Field Name | Description                                                                  | Type | Reset |
|------|------------|------------------------------------------------------------------------------|------|-------|
| 31:0 | EC         | Event Clear<br>Write 0: No action<br>Write 1: Clear corresponding event flag | W    | 0     |

**Table 5-29. Register Call Summary for Register EVTCLRI**

IVA2.2 Subsystem Functional Description

- [INTC: \[0\] \[1\]](#)

IVA2.2 Subsystem Basic Programming Model

- [Event Combined Programming Sequence: \[2\]](#)

IVA2.2 Subsystem Register Manual

- [IC Register Mapping Summary: \[3\]](#)

**Table 5-30. EVTMASKi**

| Bits | Field Name | Description                                                                                                                  | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:0 | EM         | Disables event from being used as input to the event combiner:<br>0: Will be combined<br>1: Is disabled from being combined. | RW   | 0     |

**Table 5-31. Register Call Summary for Register EVTMASKi**

---

IVA2.2 Subsystem Functional Description

- [INTC: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\]](#)

IVA2.2 Subsystem Basic Programming Model

- [Event Combined Programming Sequence: \[9\]](#)
- [Interrupt Controller Basic Programming Model for Power Down of IVA2.2 Subsystem: \[10\]](#)
- [Interrupt Controller Basic Programming Model for Power On of IVA2.2 Subsystem: \[11\] \[12\] \[13\] \[14\] \[15\]](#)

---

IVA2.2 Subsystem Register Manual

- [IC Register Mapping Summary: \[16\]](#)

**Table 5-32. MEVTFLAGi**

| Bits | Field Name | Description                                                                         | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------|------|-------|
| 31:0 | MEF        | Masked Event Flag<br>0: No unmasked event occurred<br>1: An unmasked event occurred | R    | 0     |

**Table 5-33. Register Call Summary for Register MEVTFLAGi**

---

IVA2.2 Subsystem Basic Programming Model

- Event Combined Programming Sequence: [0] [1] [2] [3]

---

IVA2.2 Subsystem Register Manual

- IC Register Mapping Summary: [4]

**Table 5-34. EXPMASKi**

|                         |                           |                       |                 |  |
|-------------------------|---------------------------|-----------------------|-----------------|--|
| <b>Address Offset</b>   | 0x00C0 + (0x4*i)          |                       |                 |  |
| <b>Physical address</b> | 0x0180 00C0 + (0x4*i)     | <b>Instance</b>       | IVA2.2 GEMIC    |  |
| <b>Description</b>      | Exception Mask Register 0 |                       |                 |  |
| <b>Type</b>             | RW                        |                       |                 |  |
| 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 |  |
|                         |                           |                       | XMX             |  |

| Bits | Field Name | Description                                                                                                           | Type | Reset       |
|------|------------|-----------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:0 | XM         | Enables event from being used in the exception combiner:<br>0: Will be combined<br>1: Is disabled from being combined | RW   | 0xFFFF FFFF |

**Table 5-35. Register Call Summary for Register EXPMASKi**

IVA2.2 Subsystem Functional Description

- INTC: [0]

IVA2.2 Subsystem Register Manual

- IC Register Mapping Summary: [1]

**Table 5-36. MEXPFLAGi**

|                         |                                  |                       |                 |  |
|-------------------------|----------------------------------|-----------------------|-----------------|--|
| <b>Address Offset</b>   | 0x00E0 + (0x4*i)                 |                       |                 |  |
| <b>Physical address</b> | 0x0180 00E0 + (0x4*i)            | <b>Instance</b>       | IVA2.2 GEMIC    |  |
| <b>Description</b>      | Masked Exception Flag Register 0 |                       |                 |  |
| <b>Type</b>             | R                                |                       |                 |  |
| 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 |  |
|                         |                                  |                       | MXF             |  |

| Bits | Field Name | Description                                                                                     | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------|------|-------|
| 31:0 | MXF        | Masked Exception Flag<br>0: No unmasked exception occurred<br>1: An unmasked exception occurred | R    | 0     |

**Table 5-37. Register Call Summary for Register MEXPFLAGi**

IVA2.2 Subsystem Register Manual

- IC Register Mapping Summary: [0]

**Table 5-38. INTMUXj**

|                         |                             |                       |                 |               |
|-------------------------|-----------------------------|-----------------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0104 + (0x4*j), j= 1 to 3 |                       |                 |               |
| <b>Physical address</b> | 0x0180 0104 + (0x4*i)       | <b>Instance</b>       | IVA2.2 GEMIC    |               |
| <b>Description</b>      | Interrupt Mux Register      |                       |                 |               |
| <b>Type</b>             | RW                          |                       |                 |               |
| 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 |               |
| Reserved                | INTSEL(j*4+3)               | Reserved              | INTSEL(j*4+2)   | Reserved      |
|                         |                             |                       |                 | INTSEL(j*4+1) |
|                         |                             |                       |                 | Reserved      |
|                         |                             |                       |                 | INTSEL(j*4)   |

| Bits  | Field Name    | Description                                           | Type | Reset |
|-------|---------------|-------------------------------------------------------|------|-------|
| 31    | Reserved      | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0x0   |
| 30:24 | INTSEL(j*4+3) | Source event number of the CPU interrupt #j*4+3       | RW   | i*4+3 |
| 23    | Reserved      | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0x0   |
| 22:16 | INTSEL(j*4+2) | Source event number of the CPU interrupt #j*4+2       | RW   | i*4+2 |
| 15    | Reserved      | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0x0   |
| 14:8  | INTSEL(j*4+1) | Source event number of the CPU interrupt #j*4+1       | RW   | i*4+1 |
| 7     | Reserved      | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0x0   |
| 6:0   | INTSEL(j*4)   | Source event number of the CPU interrupt #j*4         | RW   | i*4   |

**Table 5-39. Register Call Summary for Register INTMUXJ**

IVA2.2 Subsystem Functional Description

- [INTC: \[0\] \[1\]](#)

IVA2.2 Subsystem Basic Programming Model

- [Event <-> Interrupt Mapping Programming Sequence: \[2\]](#)
- [Interrupt Controller Basic Programming Model for Power Down of IVA2.2 Subsystem: \[3\]](#)
- [Interrupt Controller Basic Programming Model for Power On of IVA2.2 Subsystem: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)

IVA2.2 Subsystem Register Manual

- [IC Register Mapping Summary: \[10\]](#)

**Table 5-40. INTXSTAT**

|                         |                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0180                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0180 0180                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Interrupt Exception Status Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|--|--|
| 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 |  |  |  |  |
| SYSINT                  | CPUINT                  | RESERVED              |                 |  |  |  |  |

| Bits  | Field Name | Description                                                                                                  | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------|------|--------|
| 31:24 | SYSINT     | System Event number<br><br>00000000: EVT0<br><br>.....<br><br>01111111: EVT127<br><br>Others: Reserved       | R    | 0x00   |
| 23:16 | CPUINT     | CPU interrupt number<br><br>00000000: CPUINT0<br><br>.....<br><br>00001111: CPUINT15<br><br>Others: Reserved | R    | 0x00   |
| 15:1  | RESERVED   | Write 0s for future compatibility.<br>Read returns 0.                                                        | R    | 0x0000 |
| 0     | DROP       | Dropped event flag<br>0: No events dropped<br>1: Event was dropped by the CPU                                | R    | 0      |

**Table 5-41. Register Call Summary for Register INTXSTAT**

- 
- IVA2.2 Subsystem Basic Programming Model
- [Interrupt Exception Programming Sequence: \[0\] \[1\] \[2\]](#)
- 
- IVA2.2 Subsystem Register Manual
- [IC Register Mapping Summary: \[3\]](#)
- 

**Table 5-42. INTXCLR**

|                         |                                    |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |       |
|-------------------------|------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|-------|
| <b>Address Offset</b>   | 0x0000 0184                        |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |       |
| <b>Physical address</b> | 0x0180 0184                        |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |       |
| <b>Description</b>      | Interrupt Exception Clear Register |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |       |
| <b>Type</b>             | W                                  |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |       |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |       |
| Reserved                |                                    |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | CLEAR |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                          | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:1        | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                       | W           | 0x00000000   |
| 0           | CLEAR             | Interrupt exception status clear register:<br>Write 0: No effect<br>Write 1: Clears the Interrupt Exception Status register | W           | 0            |

**Table 5-43. Register Call Summary for Register INTXCLR**

- 
- IVA2.2 Subsystem Basic Programming Model
- [Interrupt Exception Programming Sequence: \[0\] \[1\]](#)
- 
- IVA2.2 Subsystem Register Manual
- [IC Register Mapping Summary: \[2\]](#)
- 

**Table 5-44. INTDMASK**

|                         |                                 |                       |                 |                                                                   |          |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------|-----------------------|-----------------|-------------------------------------------------------------------|----------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0188                     |                       |                 |                                                                   |          |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0180 0188                     |                       |                 |                                                                   |          |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Dropped Interrupt Mask Register |                       |                 |                                                                   |          |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                              |                       |                 |                                                                   |          |  |  |  |  |  |  |  |  |  |  |  |
| 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 | IDM15 IDM14 IDM13 IDM12 IDM11 IDM10 IDM9 IDM8 IDM7 IDM6 IDM5 IDM4 | Reserved |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                |                                 |                       |                 |                                                                   |          |  |  |  |  |  |  |  |  |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------|-------------|--------------|
| 31:16       | Reserved          | Write 0 for future compatibility<br>Read returns 0 | RW          | 0            |
| 15          | IDM15             | Dropped event mask for CPU interrupt #15           | RW          | 0            |
| 14          | IDM14             | Dropped event mask for CPU interrupt #14           | RW          | 0            |
| 13          | IDM13             | Dropped event mask for CPU interrupt #13           | RW          | 0            |
| 12          | IDM12             | Dropped event mask for CPU interrupt #12           | RW          | 0            |
| 11          | IDM11             | Dropped event mask for CPU interrupt #11           | RW          | 0            |
| 10          | IDM10             | Dropped event mask for CPU interrupt #10           | RW          | 0            |
| 9           | IDM9              | Dropped event mask for CPU interrupt #9            | RW          | 0            |

| Bits | Field Name | Description                                        | Type | Reset |
|------|------------|----------------------------------------------------|------|-------|
| 8    | IDM8       | Dropped event mask for CPU interrupt #8            | RW   | 0     |
| 7    | IDM7       | Dropped event mask for CPU interrupt #7            | RW   | 0     |
| 6    | IDM6       | Dropped event mask for CPU interrupt #6            | RW   | 0     |
| 5    | IDM5       | Dropped event mask for CPU interrupt #5            | RW   | 0     |
| 4    | IDM4       | Dropped event mask for CPU interrupt #4            | RW   | 0     |
| 3:0  | Reserved   | Write 0 for future compatibility<br>Read returns 0 | RW   | 0     |

**Table 5-45. Register Call Summary for Register INTDMASK**

IVA2.2 Subsystem Functional Description

- [INTC: \[0\]](#)

IVA2.2 Subsystem Basic Programming Model

- [Interrupt Exception Programming Sequence: \[1\]](#)
- [Interrupt Controller Basic Programming Model for Power Down of IVA2.2 Subsystem: \[2\]](#)
- [Interrupt Controller Basic Programming Model for Power On of IVA2.2 Subsystem: \[3\] \[4\]](#)

IVA2.2 Subsystem Register Manual

- [IC Register Mapping Summary: \[5\]](#)

**Table 5-46. EVTASRT**

|                                |                                |                                         |                              |                        |                 |              |
|--------------------------------|--------------------------------|-----------------------------------------|------------------------------|------------------------|-----------------|--------------|
| <b>Address Offset</b>          | 0x0000 01C0                    |                                         | <b>Physical address</b>      | 0x0180 01C0            | <b>Instance</b> | IVA2.2 GEMIC |
| <b>Description</b>             | Event Assert Register          |                                         | <b>Type</b>                  | W                      |                 |              |
| <b>31 30 29 28 27 26 25 24</b> | <b>23 22 21 20 19 18 17 16</b> |                                         | <b>15 14 13 12 11 10 9 8</b> | <b>7 6 5 4 3 2 1 0</b> |                 |              |
| Reserved                       |                                | MXF7 MXF6 MXF5 MXF4 MXF3 MXF2 MXF1 MXF0 |                              |                        |                 |              |

| Bits | Field Name | Description                                                                                               | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------|------|-------|
| 31:8 | Reserved   | write 0 for future compatibility                                                                          | W    | 0     |
| 7    | MXF7       | Event Assert output #7<br>EA7 = 0: No effect<br>EA7 = 1: EVTOUT7 pulsed high for 4 clk1 cycles, then low. | W    | 0     |
| 6    | MXF6       | Event Assert output #6<br>EA6 = 0: No effect<br>EA6 = 1: EVTOUT6 pulsed high for 4 clk1 cycles, then low. | W    | 0     |
| 5    | MXF5       | Event Assert output #5<br>EA5 = 0: No effect<br>EA5 = 1: EVTOUT5 pulsed high for 4 clk1 cycles, then low. | W    | 0     |
| 4    | MXF4       | Event Assert output #4<br>EA4 = 0: No effect<br>EA4 = 1: EVTOUT4 pulsed high for 4 clk1 cycles, then low. | W    | 0     |
| 3    | MXF3       | Event Assert output #3<br>EA3 = 0: No effect<br>EA3 = 1: EVTOUT3 pulsed high for 4 clk1 cycles, then low. | W    | 0     |
| 2    | MXF2       | Event Assert output #2<br>EA2 = 0: No effect<br>EA2 = 1: EVTOUT2 pulsed high for 4 clk1 cycles, then low. | W    | 0     |
| 1    | MXF1       | Event Assert output #1<br>EA1 = 0: No effect<br>EA1 = 1: EVTOUT1 pulsed high for 4 clk1 cycles, then low. | W    | 0     |
| 0    | MXF0       | Event Assert output #0<br>EA0 = 0: No effect<br>EA0 = 1: EVTOUT0 pulsed high for 4 clk1 cycles, then low. | W    | 0     |

---

**Table 5-47. Register Call Summary for Register EVTASRT**

---

IVA2.2 Subsystem Register Manual

- [IC Register Mapping Summary: \[0\]](#)
-

## 5.5.2 SYS Registers

This section provides information about the SYS Module. Each register in the module is described separately below.

### 5.5.2.1 SYS Register Mapping Summary

**Table 5-48. SYS Register Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | Physical Address |
|---------------|------|-----------------------|----------------|------------------|
| PDCCMD        | RW   | 32                    | 0x0000 0000    | 0x0181 0000      |
| REVID         | R    | 32                    | 0x0000 2000    | 0x0181 2000      |

### 5.5.2.2 SYS Register Descriptions

**Table 5-49. PDCCMD**

|                         |                             |                       |                 |          |               |        |        |        |        |
|-------------------------|-----------------------------|-----------------------|-----------------|----------|---------------|--------|--------|--------|--------|
| Address Offset          | 0x0000 0000                 | Physical address      | 0x0181 0000     | Instance | IVA2.2 GEMSYS |        |        |        |        |
| Description             | Power-Down Command Register |                       |                 |          |               |        |        |        |        |
| Type                    | RW                          |                       |                 |          |               |        |        |        |        |
| 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 |          |               |        |        |        |        |
| Reserved                | GEMPD                       | EMCMEM                | EMCLOG          | UMCMEM   | UMCLOG        | DMCMEM | DMCLOG | PMCMEM | PMCLOG |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                 | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:17 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                       | RW   | 0x0000 |
| 16    | GEMPD      | Power-down during IDLE:<br>GEMPD = 0: Normal operation. Do not power-down CPU or DSP megamodule when CPU is IDLE.<br>GEMPD = 1: Sleep mode. Power-down CPU and DSP megamodule when CPU enters IDLE state                                                                                                                                                    | RW   | 0      |
| 15:14 | EMCMEM     | SRAM Sleep Modes<br>Determines the RAM sleep modes used by the EMC for powering-down internal memories.<br><br>0x0: No sleep mode supported<br>0x1: Sleep mode 1<br>Write 0x2: Sleep mode 2 - equivalent to sleep mode 1<br>Write 0x3: Sleep mode 3 - equivalent to sleep mode 1                                                                            | RW   | 0x1    |
| 13:12 | EMCLOG     | Logic Clock Gating Modes.<br>Determines to what degree the EMC gates its clockinternally.<br><br>0x0: No clock gating supported beyond leaf clock gating.<br>0x1: Static clock gating of unused modulesregions when DSP megamodule is active(pmcm_pd_pdstat[1:0] = 00) and Static clock gating when DSP megamodule is in standby (pmcm_pd_pdstat[1:0] = 11) | RW   | 0x1    |
| 11:10 | UMCMEM     | SRAM Sleep Modes<br>Determines the RAM sleep modes used by the UMC for powering-down L2 pages.<br><br>0x0: No sleep mode supported<br>0x1: Sleep mode 1<br>Write 0x2: Sleep mode 2 - equivalent to sleep mode 1                                                                                                                                             | RW   | 0x1    |

| Bits | Field Name | Description                                                                                                                                                                                   | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | Write 0x3: Sleep mode 3 - equivalent to sleep mode 1                                                                                                                                          |      |       |
| 9:8  | UMCLOG     | Logic Clock Gating Modes.<br>Determines to what degree the UMC gates its clockinternally.                                                                                                     | RW   | 0x1   |
|      |            | 0x0: No clock gating supported beyond leaf clock gating.                                                                                                                                      |      |       |
|      |            | 0x1: Static clock gating of unused modulesregions when DSP megamodule is active(pmc_pd_pdstat[1:0] = 00) and Static clock gating when DSP megamodule is in standby (pmc_pd_pdstat[1:0] = 11)  |      |       |
| 7:6  | DMCMEM     | SRAM Sleep Modes<br>Determines the RAM sleep modes used by the DMC for powering-down L1D pages.                                                                                               | RW   | 0x1   |
|      |            | 0x0: No sleep mode supported                                                                                                                                                                  |      |       |
|      |            | 0x1: Sleep mode 1                                                                                                                                                                             |      |       |
|      |            | Write 0x2: Sleep mode 2 - equivalent to sleep mode 1                                                                                                                                          |      |       |
|      |            | Write 0x3: Sleep mode 3 - equivalent to sleep mode 1                                                                                                                                          |      |       |
| 5:4  | DMCLOG     | Logic Clock Gating Modes.<br>Determines to what degree the DMC gates its clockinternally.                                                                                                     | RW   | 0x1   |
|      |            | 0x0: No clock gating supported beyond leaf clock gating.                                                                                                                                      |      |       |
|      |            | 0x1: Static clock gating of unused modulesregions when DSP megamodule is active (pmc_pd_pdstat[1:0] = 00) and Static clock gating when DSP megamodule is in standby (pmc_pd_pdstat[1:0] = 11) |      |       |
| 3:2  | PMCMEM     | SRAM Sleep Modes<br>Determines the RAM sleep modes used by the PMC for powering-down L1P pages.                                                                                               | RW   | 0x1   |
|      |            | 0x0: No sleep mode supported                                                                                                                                                                  |      |       |
|      |            | 0x1: Sleep mode 1                                                                                                                                                                             |      |       |
|      |            | Write 0x2: Sleep mode 2 - equivalent to sleep mode 1                                                                                                                                          |      |       |
|      |            | Write 0x3: Sleep mode 3 - equivalent to sleep mode 1                                                                                                                                          |      |       |
| 1:0  | PMCLOG     | Logic Clock Gating Modes.<br>Determines to what degree the PMC gates its clockinternally.                                                                                                     | RW   | 0x1   |
|      |            | 0x0: No clock gating supported beyond leaf clock gating.                                                                                                                                      |      |       |
|      |            | 0x1: Static clock gating of unused modulesregions when DSP megamodule is active (pmc_pd_pdstat[1:0] = 00) and Static clock gating when DSP megamodule is in standby (pmc_pd_pdstat[1:0] = 11) |      |       |

**Table 5-50. Register Call Summary for Register PDCCMD**

IVA2.2 Subsystem Functional Description

- [INTC: \[0\]](#)

IVA2.2 Subsystem Basic Programming Model

- [IVA2.2 Boot Configuration: \[1\] \[2\] \[3\]](#)
- [Power-Down and Wake-Up Management: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\]](#)

IVA2.2 Subsystem Register Manual

- [SYS Register Mapping Summary: \[13\]](#)

**Table 5-51. REVID**

|                         |                                     |                 |               |
|-------------------------|-------------------------------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 2000                         |                 |               |
| <b>Physical address</b> | 0x0181 2000                         | <b>Instance</b> | IVA2.2 GEMSYS |
| <b>Description</b>      | DSP megamodule Revision ID Register |                 |               |
| <b>Type</b>             | R                                   |                 |               |

  

|         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| VERSION |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | REVISION |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                    | Type | Reset  |
|-------|------------|----------------------------------------------------------------|------|--------|
| 31:16 | VERSION    | Functional implementation of DSP megamodule<br>0x0002 : MidGEM | R    | 0x0002 |
| 15:0  | REVISION   | Physical implementation of DSP megamodule version              | R    | 0x0000 |

**Table 5-52. Register Call Summary for Register REVID**

IVA2.2 Subsystem Register Manual

- [SYS Register Mapping Summary: \[0\]](#)

### 5.5.3 IDMA Registers

This section provides information about the IDMA Module. Each register in the module is described separately below.

#### 5.5.3.1 IDMA Register Mapping Summary

**Table 5-53. IDMA Register Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | Physical Address |
|---------------|------|-----------------------|----------------|------------------|
| IDMA0_STAT    | R    | 32                    | 0x0000 0000    | 0x0182 0000      |
| IDMA0_MASK    | RW   | 32                    | 0x0000 0004    | 0x0182 0004      |
| IDMA0_SOURCE  | RW   | 32                    | 0x0000 0008    | 0x0182 0008      |
| IDMA0_DEST    | RW   | 32                    | 0x0000 000C    | 0x0182 000C      |
| IDMA0_COUNT   | RW   | 32                    | 0x0000 0010    | 0x0182 0010      |
| IDMA1_STAT    | R    | 32                    | 0x0000 0100    | 0x0182 0100      |
| IDMA1_SOURCE  | RW   | 32                    | 0x0000 0108    | 0x0182 0108      |
| IDMA1_DEST    | RW   | 32                    | 0x0000 010C    | 0x0182 010C      |
| IDMA1_COUNT   | RW   | 32                    | 0x0000 0110    | 0x0182 01100     |
| CPUARBE       | RW   | 32                    | 0x0000 0200    | 0x0182 0200      |
| IDMAARBE      | RW   | 32                    | 0x0000 0204    | 0x0182 0204      |
| SDMAARBE      | RW   | 32                    | 0x0000 0208    | 0x0182 0208      |
| MDMAARBE      | RW   | 32                    | 0x0000 020C    | 0x0182 020C      |
| ICFGMPFAR     | R    | 32                    | 0x0000 0300    | 0x0182 0300      |
| ICFGMPFSR     | R    | 32                    | 0x0000 0304    | 0x0182 0304      |
| ICFGMPFCR     | W    | 32                    | 0x0000 0308    | 0x0182 0308      |
| IBUSERR       | R    | 32                    | 0x0000 0400    | 0x0182 0400      |
| IBUSERRCLR    | W    | 32                    | 0x0000 0404    | 0x0182 0404      |

#### 5.5.3.2 IDMA Register Descriptions

**Table 5-54. IDMA0\_STAT**

|                         |                                |                         |                 |                 |                |
|-------------------------|--------------------------------|-------------------------|-----------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 0000                    | <b>Physical address</b> | 0x0182 0000     | <b>Instance</b> | IVA2.2 GEMIDMA |
| <b>Description</b>      | IDMA Channel 0 Status Register |                         |                 |                 |                |
| <b>Type</b>             | R                              |                         |                 |                 |                |
| 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 | Reserved        | PEND ACTV      |
|                         |                                |                         |                 |                 |                |

| Bits | Field Name | Description                                                                                                                                                                                                                                           | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:2 | Reserved   | Reads return 0s                                                                                                                                                                                                                                       | R    | 0     |
| 1    | PEND       | Pending transfer: Set when control registers are written to by the CPU and there is already an active transfer in progress (ACTV = 1) and cleared when the transfer becomes active.<br>PEND = 1: Transfer is pending<br>PEND = 0: No pending transfer | R    | 0     |

| Bits | Field Name | Description                                                                                                                                                                                                   | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | ACTV       | Active transfer: Set when channel 0 begins reading data from the source address and cleared following the last write to the destination address.<br>ACTV = 1: Active transfer<br>ACTV = 0: No active transfer | R    | 0     |

**Table 5-55. Register Call Summary for Register IDMA0\_STAT**

IVA2.2 Subsystem Register Manual

- [IDMA Register Mapping Summary: \[0\]](#)

**Table 5-56. IDMA0\_MASK**

|                       |                              |                         |             |                 |                |
|-----------------------|------------------------------|-------------------------|-------------|-----------------|----------------|
| <b>Address Offset</b> | 0x0000 0004                  | <b>Physical address</b> | 0x0182 0004 | <b>Instance</b> | Iva2.2 GEMIDMA |
| <b>Description</b>    | IDMA Channel 0 Mask Register |                         |             |                 |                |
| <b>Type</b>           | RW                           |                         |             |                 |                |

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| 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  |
| M31 | M30 | M29 | M28 | M27 | M26 | M25 | M24 | M23 | M22 | M21 | M20 | M19 | M18 | M17 | M16 | M15 | M14 | M13 | M12 | M11 | M10 | M9 | M8 | M7 | M6 | M5 | M4 | M3 | M2 | M1 | M0 |

| Bits | Field Name | Description                                                                                                        | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------|------|-------|
| 31   | M31        | Register Mask bit:<br>M31 = 1: Register access blocked (masked)<br>M31 = 0: Register access permitted (not masked) | RW   | 0     |
| 30   | M30        | Register Mask bit:<br>M30 = 1: Register access blocked (masked)<br>M30 = 0: Register access permitted (not masked) | RW   | 0     |
| 29   | M29        | Register Mask bit:<br>M29 = 1: Register access blocked (masked)<br>M29 = 0: Register access permitted (not masked) | RW   | 0     |
| 28   | M28        | Register Mask bit:<br>M28 = 1: Register access blocked (masked)<br>M28 = 0: Register access permitted (not masked) | RW   | 0     |
| 27   | M27        | Register Mask bit:<br>M27 = 1: Register access blocked (masked)<br>M27 = 0: Register access permitted (not masked) | RW   | 0     |
| 26   | M26        | Register Mask bit:<br>M26 = 1: Register access blocked (masked)<br>M26 = 0: Register access permitted (not masked) | RW   | 0     |
| 25   | M25        | Register Mask bit:<br>M25 = 1: Register access blocked (masked)<br>M25 = 0: Register access permitted (not masked) | RW   | 0     |
| 24   | M24        | Register Mask bit:<br>M24 = 1: Register access blocked (masked)<br>M24 = 0: Register access permitted (not masked) | RW   | 0     |
| 23   | M23        | Register Mask bit:<br>M23 = 1: Register access blocked (masked)<br>M23 = 0: Register access permitted (not masked) | RW   | 0     |
| 22   | M22        | Register Mask bit:<br>M22 = 1: Register access blocked (masked)<br>M22 = 0: Register access permitted (not masked) | RW   | 0     |
| 21   | M21        | Register Mask bit:<br>M21 = 1: Register access blocked (masked)<br>M21 = 0: Register access permitted (not masked) | RW   | 0     |
| 20   | M20        | Register Mask bit:<br>M20 = 1: Register access blocked (masked)<br>M20 = 0: Register access permitted (not masked) | RW   | 0     |

## IVA2.2 Subsystem Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                                        | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------|------|-------|
| 19   | M19        | Register Mask bit:<br>M19 = 1: Register access blocked (masked)<br>M19 = 0: Register access permitted (not masked) | RW   | 0     |
| 18   | M18        | Register Mask bit:<br>M18 = 1: Register access blocked (masked)<br>M18 = 0: Register access permitted (not masked) | RW   | 0     |
| 17   | M17        | Register Mask bit:<br>M17 = 1: Register access blocked (masked)<br>M17 = 0: Register access permitted (not masked) | RW   | 0     |
| 16   | M16        | Register Mask bit:<br>M16 = 1: Register access blocked (masked)<br>M16 = 0: Register access permitted (not masked) | RW   | 0     |
| 15   | M15        | Register Mask bit:<br>M15 = 1: Register access blocked (masked)<br>M15 = 0: Register access permitted (not masked) | RW   | 0     |
| 14   | M14        | Register Mask bit:<br>M14 = 1: Register access blocked (masked)<br>M14 = 0: Register access permitted (not masked) | RW   | 0     |
| 13   | M13        | Register Mask bit:<br>M13 = 1: Register access blocked (masked)<br>M13 = 0: Register access permitted (not masked) | RW   | 0     |
| 12   | M12        | Register Mask bit:<br>M12 = 1: Register access blocked (masked)<br>M12 = 0: Register access permitted (not masked) | RW   | 0     |
| 11   | M11        | Register Mask bit:<br>M11 = 1: Register access blocked (masked)<br>M11 = 0: Register access permitted (not masked) | RW   | 0     |
| 10   | M10        | Register Mask bit:<br>M10 = 1: Register access blocked (masked)<br>M10 = 0: Register access permitted (not masked) | RW   | 0     |
| 9    | M9         | Register Mask bit:<br>M9 = 1: Register access blocked (masked)<br>M9 = 0: Register access permitted (not masked)   | RW   | 0     |
| 8    | M8         | Register Mask bit:<br>M8 = 1: Register access blocked (masked)<br>M8 = 0: Register access permitted (not masked)   | RW   | 0     |
| 7    | M7         | Register Mask bit:<br>M7 = 1: Register access blocked (masked)<br>M7 = 0: Register access permitted (not masked)   | RW   | 0     |
| 6    | M6         | Register Mask bit:<br>M6 = 1: Register access blocked (masked)<br>M6 = 0: Register access permitted (not masked)   | RW   | 0     |
| 5    | M5         | Register Mask bit:<br>M5 = 1: Register access blocked (masked)<br>M5 = 0: Register access permitted (not masked)   | RW   | 0     |
| 4    | M4         | Register Mask bit:<br>M4 = 1: Register access blocked (masked)<br>M4 = 0: Register access permitted (not masked)   | RW   | 0     |
| 3    | M3         | Register Mask bit:<br>M3 = 1: Register access blocked (masked)<br>M3 = 0: Register access permitted (not masked)   | RW   | 0     |
| 2    | M2         | Register Mask bit:<br>M2 = 1: Register access blocked (masked)<br>M2 = 0: Register access permitted (not masked)   | RW   | 0     |
| 1    | M1         | Register Mask bit:<br>M1 = 1: Register access blocked (masked)<br>M1 = 0: Register access permitted (not masked)   | RW   | 0     |
| 0    | M0         | Register Mask bit:<br>M0 = 1: Register access blocked (masked)<br>M0 = 0: Register access permitted (not masked)   | RW   | 0     |

**Table 5-57. Register Call Summary for Register IDMA0\_MASK**


---

 I/VA2.2 Subsystem Basic Programming Model

- Starting the Transfer: [0]
- 

I/VA2.2 Subsystem Register Manual

- IDMA Register Mapping Summary: [1]
- 

**Table 5-58. IDMA0\_SOURCE**

|                         |                                        |                         |                 |                 |                 |
|-------------------------|----------------------------------------|-------------------------|-----------------|-----------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0008                            | <b>Physical address</b> | 0x0182 0008     | <b>Instance</b> | I/VA2.2 GEMIDMA |
| <b>Description</b>      | IDMA Channel 0 Source Address Register |                         |                 |                 |                 |
| <b>Type</b>             | RW                                     |                         |                 |                 |                 |
| 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 | SOURCEADDR      | Reserved        |

| Bits | Field Name | Description                                                                                                                                               | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:5 | SOURCEADDR | Source Address: Must point to a 32-byte-aligned (e.g. window-aligned) memory location local to DSP megamodule or to a valid configuration register space. | RW   | 0x00000000 |
| 4:0  | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                     | RW   | 0x00       |

**Table 5-59. Register Call Summary for Register IDMA0\_SOURCE**


---

 I/VA2.2 Subsystem Basic Programming Model

- Starting the Transfer: [0]
- 

I/VA2.2 Subsystem Register Manual

- IDMA Register Mapping Summary: [1]
- 

**Table 5-60. IDMA0\_DEST**

|                         |                                             |                         |                 |                 |                 |
|-------------------------|---------------------------------------------|-------------------------|-----------------|-----------------|-----------------|
| <b>Address Offset</b>   | 0x0000 000C                                 | <b>Physical address</b> | 0x0182 000C     | <b>Instance</b> | I/VA2.2 GEMIDMA |
| <b>Description</b>      | IDMA Channel 0 Destination Address Register |                         |                 |                 |                 |
| <b>Type</b>             | RW                                          |                         |                 |                 |                 |
| 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 | DESTADDR        | Reserved        |

| Bits | Field Name | Description                                                                                                                                                   | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:5 | DESTADDR   | Destination Address: Must point to a 32-byte-aligned (e.g. windowaligned) memory location local to DSP megamodule or to a valid configuration register space. | RW   | 0x00000000 |
| 4:0  | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                         | RW   | 0x00       |

**Table 5-61. Register Call Summary for Register IDMA0\_DEST**


---

 I/VA2.2 Subsystem Basic Programming Model

- Starting the Transfer: [0]
- 

I/VA2.2 Subsystem Register Manual

- IDMA Register Mapping Summary: [1]
-

**Table 5-62. IDMA0\_COUNT**

|                         |                               |                         |                 |                 |                |
|-------------------------|-------------------------------|-------------------------|-----------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 0010                   | <b>Physical address</b> | 0x0182 0010     | <b>Instance</b> | IVA2.2 GEMIDMA |
| <b>Description</b>      | IDMA Channel 0 Count Register |                         |                 |                 |                |
| <b>Type</b>             | RW                            |                         |                 |                 |                |
| 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 |                 |                |
| Reserved                | IN                            | Reserved                |                 | COUNT           |                |

| Bits  | Field Name | Description                                                                                                          | Type | Reset     |
|-------|------------|----------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:29 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                   | RW   | 0x0       |
| 28    | INT        | CPU interrupt enable INT = 1: Interrupt CPU (IDMA_INT0) on completion<br>INT = 0: Do not interrupt CPU on completion | RW   | 0         |
| 27:4  | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                   | RW   | 0x0000000 |
| 3:0   | COUNT      | Window count COUNT = 0000: Transfer to/from one 32-word window<br>COUNT = n: Transfer to/from n+1 32-word windows    | RW   | 0x0       |

**Table 5-63. Register Call Summary for Register IDMA0\_COUNT**

IVA2.2 Subsystem Basic Programming Model

- Starting the Transfer: [0]

IVA2.2 Subsystem Register Manual

- IDMA Register Mapping Summary: [1]

**Table 5-64. IDMA1\_STAT**

|                         |                                |                         |                 |                 |                |
|-------------------------|--------------------------------|-------------------------|-----------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 0100                    | <b>Physical address</b> | 0x0182 0100     | <b>Instance</b> | IVA2.2 GEMIDMA |
| <b>Description</b>      | IDMA Channel 1 Status Register |                         |                 |                 |                |
| <b>Type</b>             | R                              |                         |                 |                 |                |
| 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 |                 |                |
|                         |                                | Reserved                |                 | PEND            | ACTV           |

| Bits | Field Name | Description                                                                                                                                                                                                                                                 | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                       | R    | 0x00000000 |
| 1    | PEND       | Pending transfer: Set when control registers are written to by the<br>CPU and there is already an active transfer in progress (ACTV = 1)<br>and cleared when the transfer becomes active.<br>PEND = 1: Transfer is pending<br>PEND = 0: No pending transfer | R    | 0          |
| 0    | ACTV       | Active transfer: Set when channel 1 begins reading data from the<br>source address and cleared following the last write to the destination<br>address.<br>ACTV = 1: Active transfer<br>ACTV = 0: No active transfer                                         | R    | 0          |

**Table 5-65. Register Call Summary for Register IDMA1\_STAT**

IVA2.2 Subsystem Register Manual

- IDMA Register Mapping Summary: [0]

**Table 5-66. IDMA1\_SOURCE**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                        |                 |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|-----------------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x0000 0108                            | <b>Instance</b> | IVA2.2 GEMIDMA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0182 0108                            |                 |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | IDMA Channel 1 Source Address Register |                 |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW                                     |                 |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 25%;">31</td><td style="width: 25%;">30</td><td style="width: 25%;">29</td><td style="width: 25%;">28</td><td style="width: 25%;">27</td><td style="width: 25%;">26</td><td style="width: 25%;">25</td><td style="width: 25%;">24</td><td style="width: 25%;">23</td><td style="width: 25%;">22</td><td style="width: 25%;">21</td><td style="width: 25%;">20</td><td style="width: 25%;">19</td><td style="width: 25%;">18</td><td style="width: 25%;">17</td><td style="width: 25%;">16</td><td style="width: 25%;">15</td><td style="width: 25%;">14</td><td style="width: 25%;">13</td><td style="width: 25%;">12</td><td style="width: 25%;">11</td><td style="width: 25%;">10</td><td style="width: 25%;">9</td><td style="width: 25%;">8</td><td style="width: 25%;">7</td><td style="width: 25%;">6</td><td style="width: 25%;">5</td><td style="width: 25%;">4</td><td style="width: 25%;">3</td><td style="width: 25%;">2</td><td style="width: 25%;">1</td><td style="width: 25%;">0</td></tr> </table> |                                        |                 |                | 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 |
| 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 |   |   |   |   |
| SOURCEADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                        |                 |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                        | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | SOURCEADDR | Source Address: Must point to a word-aligned memory location local to GEM. When performing a block fill ( <b>IDMA1_COUNT.FILL</b> = 1) the source address is the fill value. Note that when performing a Fill Mode transfer all 32-bits of the SOURCEADDR are writeable and when performing a linear transfer the two LSBs are implemented as 00b. | RW   | 0x00000000 |

**Table 5-67. Register Call Summary for Register IDMA1\_SOURCE**

- IVA2.2 Subsystem Basic Programming Model
- Internal Memory-to-Memory Transfer (IDMA): [0] [1] [2] [3]
- IVA2.2 Subsystem Register Manual
- IDMA Register Mapping Summary: [4]

**Table 5-68. IDMA1\_DEST**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                             |                 |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-----------------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x0000 010C                                 | <b>Instance</b> | IVA2.2 GEMIDMA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0182 010C                                 |                 |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | IDMA Channel 1 Destination Address Register |                 |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW                                          |                 |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 25%;">31</td><td style="width: 25%;">30</td><td style="width: 25%;">29</td><td style="width: 25%;">28</td><td style="width: 25%;">27</td><td style="width: 25%;">26</td><td style="width: 25%;">25</td><td style="width: 25%;">24</td><td style="width: 25%;">23</td><td style="width: 25%;">22</td><td style="width: 25%;">21</td><td style="width: 25%;">20</td><td style="width: 25%;">19</td><td style="width: 25%;">18</td><td style="width: 25%;">17</td><td style="width: 25%;">16</td><td style="width: 25%;">15</td><td style="width: 25%;">14</td><td style="width: 25%;">13</td><td style="width: 25%;">12</td><td style="width: 25%;">11</td><td style="width: 25%;">10</td><td style="width: 25%;">9</td><td style="width: 25%;">8</td><td style="width: 25%;">7</td><td style="width: 25%;">6</td><td style="width: 25%;">5</td><td style="width: 25%;">4</td><td style="width: 25%;">3</td><td style="width: 25%;">2</td><td style="width: 25%;">1</td><td style="width: 25%;">0</td></tr> </table> |                                             |                 |                | 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 |
| 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 |   |   |   |   |
| DESTADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                             |                 |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                             |                 |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------|------|------------|
| 31:2 | DESTADDR   | Destination Address: Must point to a word-aligned memory location local to DSP megamodule. | RW   | 0x00000000 |
| 1:0  | Reserved   | Reads return 0s<br>Write 0 for further compatibility                                       | R    | 0x00       |

**Table 5-69. Register Call Summary for Register IDMA1\_DEST**

- IVA2.2 Subsystem Basic Programming Model
- Internal Memory-to-Memory Transfer (IDMA): [0] [1] [2] [3]
- IVA2.2 Subsystem Register Manual
- IDMA Register Mapping Summary: [4]

**Table 5-70. IDMA1\_COUNT**

|                         |                               |                       |                 |       |  |  |  |  |  |  |  |  |  |  |          |
|-------------------------|-------------------------------|-----------------------|-----------------|-------|--|--|--|--|--|--|--|--|--|--|----------|
| <b>Address Offset</b>   | 0x0000 0110                   |                       |                 |       |  |  |  |  |  |  |  |  |  |  |          |
| <b>Physical address</b> | 0x0182 0110                   |                       |                 |       |  |  |  |  |  |  |  |  |  |  |          |
| <b>Description</b>      | IDMA Channel 0 Count Register |                       |                 |       |  |  |  |  |  |  |  |  |  |  |          |
| <b>Type</b>             | RW                            |                       |                 |       |  |  |  |  |  |  |  |  |  |  |          |
| 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 |       |  |  |  |  |  |  |  |  |  |  |          |
| PRI                     | INT                           | Reserved              | FILL            | COUNT |  |  |  |  |  |  |  |  |  |  | Reserved |

| Bits  | Field Name | Description                                                                                                                                                                                                                                      | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:29 | PRI        | Transfer priority. Used for arbitration between CPU and DMA accesses when there are conflicts.<br>PRI = 111b: Low priority<br>PRI = 000b: High priority                                                                                          | RW   | 0x0    |
| 28    | INT        | CPU interrupt enable<br>INT = 1: Interrupt CPU (IDMA_INT1) on completion<br>INT = 0: Do not interrupt CPU on completion                                                                                                                          | RW   | 0      |
| 27:17 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                            | RW   | 0x000  |
| 16    | FILL       | Block fill:<br>FILL = 1: Perform a block fill using the Source address field as the fill value to the memory buffer pointed to by the Destination address field.<br>FILL = 0: Block transfer from the source address to the destination address. | RW   | 0      |
| 15:2  | COUNT      | 16-bit byte count. Must be a multiple of 4 bytes. A transfer count of zero will not transfer any data, but will generate an interrupt if requested in the INT field.                                                                             | RW   | 0x0000 |
| 1:0   | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                            | RW   | 0x0    |

**Table 5-71. Register Call Summary for Register IDMA1\_COUNT**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory-to-Memory Transfer (IDMA): [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22]
- Internal Memory: [23]

IVA2.2 Subsystem Register Manual

- IDMA Register Mapping Summary: [24]
- IDMA Register Descriptions: [25]

**Table 5-72. CPUARBE**

|                         |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |         |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|---------|
| <b>Address Offset</b>   | 0x0000 0200             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |         |
| <b>Physical address</b> | 0x0182 0200             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |         |
| <b>Description</b>      | CPU Arbitration Control |                       |                 |  |  |  |  |  |  |  |  |  |  |  |         |
| <b>Type</b>             | RW                      |                       |                 |  |  |  |  |  |  |  |  |  |  |  |         |
| 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 |  |  |  |  |  |  |  |  |  |  |  |         |
| Reserved                | PRI                     | Reserved              |                 |  |  |  |  |  |  |  |  |  |  |  | MAXWAIT |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                           | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:19       | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                                                                                        | RW          | 0x000        |
| 18:16       | PRI               | Priority<br><br>0x0: Highest priority<br>0x1: 2nd highest priority<br>0x2: 3rd highest priority<br>0x3: 4th highest priority<br>0x4: 5th highest priority<br>0x5: 6th highest priority<br>0x6: 7th highest priority<br>0x7: Lowest priority                                                                                                                                                                                  | RW          | 0x1          |
| 15:6        | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                                                                                        | RW          | 0x000        |
| 5:0         | MAXWAIT           | Maximum Wait time (in UMC/EMC cycles)<br><br>0x0: Always stalls due to higher priority requestor<br>0x1: Maximum wait of 1 cycles (1/2 = 50% access)<br>0x2: Maximum wait of 2 cycles (1/3 = 33% access)<br>0x4: Maximum wait of 4 cycles (1/5 = 20% access)<br>0x8: Maximum wait of 8 cycles (1/9 = 11% access)<br>0x10: Maximum wait of 16 cycles (1/17 = 6% access)<br>0x20: Maximum wait of 32 cycles (1/33 = 3% access) | RW          | 0x10         |

**Table 5-73. Register Call Summary for Register CPUARBE**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- IDMA Register Mapping Summary: [1]

**Table 5-74. IDMAARBE**

|                       |                          |                         |             |                 |                |
|-----------------------|--------------------------|-------------------------|-------------|-----------------|----------------|
| <b>Address Offset</b> | 0x0000 0204              | <b>Physical address</b> | 0x0182 0204 | <b>Instance</b> | IVA2.2 GEMIDMA |
| <b>Description</b>    | IDMA Arbitration control |                         |             |                 |                |
| <b>Type</b>           | RW                       |                         |             |                 |                |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---------|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | MAXWAIT |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                           | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:6        | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                                                                                        | RW          | 0x0000000    |
| 5:0         | MAXWAIT           | Maximum Wait time (in UMC/EMC cycles)<br><br>0x0: Always stalls due to higher priority requestor<br>0x1: Maximum wait of 1 cycles (1/2 = 50% access)<br>0x2: Maximum wait of 2 cycles (1/3 = 33% access)<br>0x4: Maximum wait of 4 cycles (1/5 = 20% access)<br>0x8: Maximum wait of 8 cycles (1/9 = 11% access)<br>0x10: Maximum wait of 16 cycles (1/17 = 6% access)<br>0x20: Maximum wait of 32 cycles (1/33 = 3% access) | RW          | 0x10         |

**Table 5-75. Register Call Summary for Register IDMAARBE**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- IDMA Register Mapping Summary: [1]

**Table 5-76. SDMAARBE**

|                         |             |                 |                |  |  |
|-------------------------|-------------|-----------------|----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0208 | <b>Instance</b> | IVA2.2 GEMIDMA |  |  |
| <b>Physical address</b> | 0x0182 0208 |                 |                |  |  |
| <b>Description</b>      |             |                 |                |  |  |
| <b>Type</b>             | RW          |                 |                |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---------|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | MAXWAIT |   |   |   |   |   |

| Bits | Field Name | Description                                           | Type | Reset |
|------|------------|-------------------------------------------------------|------|-------|
| 31:6 | Reserved   | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0x000 |
| 5:0  | MAXWAIT    | Maximum Wait time (in UMC/EMC cycles)                 | RW   | 0x01  |
|      | 0x0:       | Always stalls due to higher priority requestor        |      |       |
|      | 0x1:       | Maximum wait of 1 cycles (1/2 = 50% access)           |      |       |
|      | 0x2:       | Maximum wait of 2 cycles (1/3 = 33% access)           |      |       |
|      | 0x4:       | Maximum wait of 4 cycles (1/5 = 20% access)           |      |       |
|      | 0x8:       | Maximum wait of 8 cycles (1/9 = 11% access)           |      |       |
|      | 0x10:      | Maximum wait of 16 cycles (1/17 = 6% access)          |      |       |
|      | 0x20:      | Maximum wait of 32 cycles (1/33 = 3% access)          |      |       |

**Table 5-77. Register Call Summary for Register SDMAARBE**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- IDMA Register Mapping Summary: [1]

**Table 5-78. MDMAARBE**

|                         |             |                 |                |  |  |
|-------------------------|-------------|-----------------|----------------|--|--|
| <b>Address Offset</b>   | 0x0000 020C | <b>Instance</b> | IVA2.2 GEMIDMA |  |  |
| <b>Physical address</b> | 0x0182 020C |                 |                |  |  |
| <b>Description</b>      |             |                 |                |  |  |
| <b>Type</b>             | RW          |                 |                |  |  |

|          |    |    |    |    |    |    |    |    |    |     |          |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|-----|----------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    | PRI | Reserved |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                           | Type | Reset  |
|-------|------------|-------------------------------------------------------|------|--------|
| 31:19 | Reserved   | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0x0000 |
| 18:16 | PRI        | Priority                                              | RW   | 0x7    |
|       | 0x0:       | Highest priority                                      |      |        |
|       | 0x1:       | 2nd highest priority                                  |      |        |
|       | 0x2:       | 3rd highest priority                                  |      |        |

| Bits | Field Name | Description                                                                                                                              | Type | Reset   |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
|      |            | 0x3: 4th highest priority<br>0x4: 5th highest priority<br>0x5: 6th highest priority<br>0x6: 7th highest priority<br>0x7: Lowest priority |      |         |
| 15:0 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                    | RW   | 0x00000 |

**Table 5-79. Register Call Summary for Register MDMAARBE**

IVA2.2 Subsystem Basic Programming Model

- [Prioritizing Defined Transfers: \[0\]](#) [\[1\]](#) [\[2\]](#)
- [Internal Memory: \[3\]](#) [\[4\]](#) [\[5\]](#) [\[6\]](#) [\[7\]](#)

IVA2.2 Subsystem Register Manual

- [IDMA Register Mapping Summary: \[8\]](#)

**Table 5-80. ICFGMPFAR**

|                         |                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0300             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0182 0300             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Instance IVA2.2 GEMIDMA |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                       |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | ADDR |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description   | Type | Reset      |
|------|------------|---------------|------|------------|
| 31:0 | ADDR       | Fault Address | R    | 0x00000000 |

**Table 5-81. Register Call Summary for Register ICFGMPFAR**

IVA2.2 Subsystem Basic Programming Model

- [Internal Memory: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [IDMA Register Mapping Summary: \[1\]](#)

**Table 5-82. ICFGMPFSR**

|                         |                         |                       |                 |          |       |          |      |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|----------|-------|----------|------|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0304             |                       |                 |          |       |          |      |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0182 0304             |                       |                 |          |       |          |      |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Instance IVA2.2 GEMIDMA |                       |                 |          |       |          |      |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                       |                       |                 |          |       |          |      |  |  |  |  |  |  |  |  |  |
| 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 | Reserved | FLTID | Reserved | ATYP |  |  |  |  |  |  |  |  |  |

## IVA2.2 Subsystem Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                               | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                     | R    | 0x0000 |
| 15:8  | FLTID      | Faulted ID:<br>VBUS PrivID of faulting requestor. This field is valid only if LE is zero. | R    | 0x00   |
| 7:6   | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                     | R    | 0x0    |
| 5:0   | ATYP       | Access type                                                                               | R    | 0x00   |

**Table 5-83. Register Call Summary for Register ICFGMPFSR**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- IDMA Register Mapping Summary: [1]

**Table 5-84. ICFGMPFCR**

|                         |                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0308                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0182 0308                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | ICFG Memory Protection Fault Command Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                   | Type | Reset |
|------|------------|---------------------------------------------------------------|------|-------|
| 31:1 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.         | W    |       |
| 0    | MPFCLR     | Write 0: No effect<br>Write 1: Clear fault logged information | W    | 0     |

**Table 5-85. Register Call Summary for Register ICFGMPFCR**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- IDMA Register Mapping Summary: [1]

**Table 5-86. IBUSERR**

|                         |                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0400               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0182 0400               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Bus Access Error Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|     |          |    |    |    |    |    |     |          |    |    |    |    |    |      |          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|----------|----|----|----|----|----|-----|----------|----|----|----|----|----|------|----------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| ERR | Reserved |    |    |    |    |    | XID | Reserved |    |    |    |    |    | STAT | Reserved |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                | Type | Reset    |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:29 | ERR        | Error detected<br>0x0: No error<br>0x1: MDMA Read Status Error detected<br>0x2: MDMA Write Status Error detected<br>0x3: CFG Read Status Error detected<br>0x4: CFG Write Status Error detected                                                                                                                                                            | R    | 0x000000 |
| 28:11 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                      | R    | 0x00     |
| 10:8  | XID        | Transaction ID<br>Stores the Transaction ID when an error is detected on the response. Value should match the command id for the access that resulted in an error.                                                                                                                                                                                         | R    | 0x0      |
| 7:3   | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                      | R    | 0x00     |
| 2:0   | STAT       | Transaction Status<br>Stores the non-zero status/error code that wasdetected on the response to an access<br>0x0: Success (should not cause error to be latched), or unrecognized RID/WID (should cause error to be latched)<br>0x1: Addressing error<br>0x2: Privilege error<br>0x3: Timeout error<br>0x4: Data error<br>0x7: Exclusive-operation failure | R    | 0x0      |

**Table 5-87. Register Call Summary for Register IBUSERR**

IVA2.2 Subsystem Basic Programming Model  
 • [Error Reporting for IDMA Module: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\]](#)

IVA2.2 Subsystem Register Manual  
 • [IDMA Register Mapping Summary: \[7\]](#)

**Table 5-88. IBUSERRCLR**

|                         |                         |                       |                 |     |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|-----|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0404             |                       |                 |     |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0182 0404             |                       |                 |     |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Bus Access Error Clear  |                       |                 |     |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                       |                       |                 |     |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 | CLR |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                |                         |                       |                 |     |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                                                                                                                                           | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                 | W    | 0x00000000 |
| 0    | CLR        | Clear Error<br>CLR = 0: Writes of 0 have no effect.<br>CLR = 1: Write of 1 clears all bits in the IBUSERRregister. Once an error is detected, the MDMA Error register must be cleared before additional errors canbe detected/stored. | W    | 0          |

**Table 5-89. Register Call Summary for Register IBUSERRCLR**

IVA2.2 Subsystem Basic Programming Model

- Error Reporting for IDMA Module: [0]

IVA2.2 Subsystem Register Manual

- IDMA Register Mapping Summary: [1]

## 5.5.4 XMC Registers

This section provides information about the XMC module, which contains the registers related to the three memory controllers of DSP megamodule: UMC, PMC, and DMC. Each register in the module is described separately below.

### 5.5.4.1 XMC Register Mapping Summary

**Table 5-90. XMC Register Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | Physical Address |
|---------------|------|-----------------------|----------------|------------------|
| L2CFG         | RW   | 32                    | 0x0000 0000    | 0x0184 0000      |
| L1PCFG        | RW   | 32                    | 0x0000 0020    | 0x0184 0020      |
| L1PCC         | RW   | 32                    | 0x0000 0024    | 0x0184 0024      |
| L1DCFG        | RW   | 32                    | 0x0000 0040    | 0x0184 0040      |
| L1DCC         | RW   | 32                    | 0x0000 0044    | 0x0184 0044      |
| CPUARBU       | RW   | 32                    | 0x0000 1000    | 0x0184 1000      |
| IDMAARBU      | RW   | 32                    | 0x0000 1004    | 0x0184 1004      |
| SDMAARBU      | RW   | 32                    | 0x0000 1008    | 0x0184 1008      |
| UCARBU        | RW   | 32                    | 0x0000 100C    | 0x0184 100C      |
| CPUARBD       | RW   | 32                    | 0x0000 1040    | 0x0184 1040      |
| IDMAARBD      | RW   | 32                    | 0x0000 1044    | 0x0184 1044      |
| SDMAARBD      | RW   | 32                    | 0x0000 1048    | 0x0184 1048      |
| UCARBD        | RW   | 32                    | 0x0000 104C    | 0x0184 104C      |
| L2WBAR        | W    | 32                    | 0x0000 4000    | 0x0184 4000      |
| L2WWC         | RW   | 32                    | 0x0000 4004    | 0x0184 4004      |
| L2WIBAR       | W    | 32                    | 0x0000 4010    | 0x0184 4010      |
| L2WIWC        | RW   | 32                    | 0x0000 4014    | 0x0184 4014      |
| L2IBAR        | W    | 32                    | 0x0000 4018    | 0x0184 4018      |
| L2IWC         | RW   | 32                    | 0x0000 401C    | 0x0184 401C      |
| L1PIBAR       | W    | 32                    | 0x0000 4020    | 0x0184 4020      |
| L1PIWC        | RW   | 32                    | 0x0000 4024    | 0x0184 4024      |
| L1DWIBAR      | W    | 32                    | 0x0000 4030    | 0x0184 4030      |
| L1DWIWC       | RW   | 32                    | 0x0000 4034    | 0x0184 4034      |
| L1DWBAR       | W    | 32                    | 0x0000 4040    | 0x0184 4040      |
| L1DWWC        | RW   | 32                    | 0x0000 4044    | 0x0184 4044      |
| L1DIBAR       | W    | 32                    | 0x0000 4048    | 0x0184 4048      |
| L1DIWC        | RW   | 32                    | 0x0000 404C    | 0x0184 404C      |
| L2WB          | RW   | 32                    | 0x0000 5000    | 0x0184 5000      |
| L2WBINV       | RW   | 32                    | 0x0000 5004    | 0x0184 5004      |
| L2INV         | RW   | 32                    | 0x0000 5008    | 0x0184 5008      |
| L1PINV        | RW   | 32                    | 0x0000 5028    | 0x0184 5028      |
| L1DWB         | RW   | 32                    | 0x0000 5040    | 0x0184 5040      |
| L1DWBINV      | RW   | 32                    | 0x0000 5044    | 0x0184 5044      |

**Table 5-90. XMC Register Summary (continued)**

| Register Name                      | Type                  | Register Width (Bits) | Address Offset        | Physical Address      |
|------------------------------------|-----------------------|-----------------------|-----------------------|-----------------------|
| L1DINV                             | RW                    | 32                    | 0x0000 5048           | 0x0184 5048           |
| MARI <sup>(1)</sup>                | RW (RO if i = 0...15) | 32                    | 0x0000 8000 + (0x4*i) | 0x0184 8000 + (0x4*i) |
| L2MPFAR                            | R                     | 32                    | 0x0000 A000           | 0x0184 A000           |
| L2MPFSR                            | R                     | 32                    | 0x0000 A004           | 0x0184 A004           |
| L2MPFCR                            | W                     | 32                    | 0x0000 A008           | 0x0184 A008           |
| L2MPPA <sub>j</sub> <sup>(2)</sup> | RW                    | 32                    | 0x0000 A200 + (0x4*j) | 0x0184 A200 + (0x4*j) |
| L1PMPFAR                           | R                     | 32                    | 0x0000 A400           | 0x0184 A400           |
| L1PMPFSR                           | R                     | 32                    | 0x0000 A404           | 0x0184 A404           |
| L1PMPFCR                           | W                     | 32                    | 0x0000 A408           | 0x0184 A408           |
| L1PMPPAk <sup>(3)</sup>            | RW                    | 32                    | 0x0000 A600 + (0x4*k) | 0x0184 A600 + (0x4*k) |
| L1DMMPFAR                          | R                     | 32                    | 0x0000 AC00           | 0x0184 AC00           |
| L1DMPPFSR                          | R                     | 32                    | 0x0000 AC04           | 0x0184 AC04           |
| L1DMPFCCR                          | W                     | 32                    | 0x0000 AC08           | 0x0184 AC08           |
| L1DMPPAk <sup>(4)</sup>            | RW                    | 32                    | 0x0000 AE00 + (0x4*k) | 0x0184 AE00 + (0x4*k) |

<sup>(1)</sup> i = 0 to 255

<sup>(2)</sup> j = 0 to 64

<sup>(3)</sup> k = 0 to 32

<sup>(4)</sup> k = 0 to 32

#### 5.5.4.2 XMC Register Descriptions

**Table 5-91. L2CFG**

|                  |                                 |    |          |    |      |    |          |    |        |    |    |          |      |        |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------|---------------------------------|----|----------|----|------|----|----------|----|--------|----|----|----------|------|--------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Address Offset   | 0x0000 0000                     |    |          |    |      |    |          |    |        |    |    |          |      |        |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Physical address | 0x0184 0000                     |    |          |    |      |    |          |    |        |    |    |          |      |        |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Description      | L2 cache configuration register |    |          |    |      |    |          |    |        |    |    |          |      |        |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type             | RW                              |    |          |    |      |    |          |    |        |    |    |          |      |        |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| Reserved         | NUM_MM                          |    | Reserved |    | MMID |    | Reserved |    | NOINIT | IP | ID | Reserved | L2CC | L2MODE |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                         | R    | 0x0   |
| 27:24 | NUM_MM     | Number of megamodules -1 (always 0 for IVA2)                                                                                                                                                                                                                                                                                                                               | R    | 0x0   |
| 23:20 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                         | R    | 0x0   |
| 19:16 | MMID       | Megamodule ID (always 0x0 for IVA2)                                                                                                                                                                                                                                                                                                                                        | R    | 0x0   |
| 15:11 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                         | W    | 0x00  |
| 10    | NOINIT     | No init upon cache config: when written '1', cache config is restored without re-initializing cache context (tags, validity bits) (this is assumed here that the restored cache settings are the same as prior to the execution of the IDLE instruction) when written '0', cache context is re-initialized (cache content is indirectly lost) this bit is always read as 0 | W    | 0     |
| 9     | IP         | Global L1P invalidate (for backward compatibility,deprecated)                                                                                                                                                                                                                                                                                                              | W    | 0     |
| 8     | ID         | Global L1D invalidate (for backward compatibility,deprecated)                                                                                                                                                                                                                                                                                                              | W    | 0     |
| 7:5   | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                         | W    | 0x0   |
| 4:3   | L2CC       | L2 cache control                                                                                                                                                                                                                                                                                                                                                           | RW   | 0x0   |

| Bits | Field Name | Description                                                                                         | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x0: L2 cache operates normally<br>0x1: L2 Cache is frozen<br>0x2: L2 cache is bypassed             |      |       |
| 2:0  | L2MODE     | L2 Configuration Register<br>0x0: 0KB of L2 Cache<br>0x1: 32KB of L2 Cache<br>0x2: 64KB of L2 Cache | RW   | 0x0   |

**Table 5-92. Register Call Summary for Register L2CFG**

IVA2.2 Subsystem Basic Programming Model

- [IVA2.2 Boot Configuration: \[0\] \[1\] \[2\] \[3\] \[4\]](#)
- [Cache-Size Configuration: \[5\] \[6\] \[7\] \[8\]](#)
- [Cache Mode Configuration: \[9\] \[10\]](#)
- [External Memory: \[11\]](#)
- [Powering Down L2\\$ Memory While IVA2 is Active: \[12\] \[13\] \[14\] \[15\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[16\]](#)

**Table 5-93. L1PCFG**

|                         |                         |                         |                 |                 |               |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 0020             | <b>Physical address</b> | 0x0184 0020     | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Description</b>      |                         |                         |                 |                 |               |
| <b>Type</b>             | RW                      |                         |                 |                 |               |
| 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 | Reserved        | L1PMODE       |

| Bits | Field Name | Description                                                                                                                                                               | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | Reserved   | Write Os for future compatibility. Read returns 0.                                                                                                                        | RW   | 0x00000000 |
| 2:0  | L1PMODE    | L1P Configuration Register<br>0x0: 0KB of L1P Cache<br>0x1: 4KB of L1P Cache<br>0x2: 8KB of L1P Cache<br>0x3: 16KB of L1P Cache<br>0x4: Maximum cache (32KB of L1P Cache) | RW   | 0x0        |

**Table 5-94. Register Call Summary for Register L1PCFG**

IVA2.2 Subsystem Basic Programming Model

- [IVA2.2 Boot Configuration: \[0\] \[1\] \[2\] \[3\]](#)
- [Cache-Size Configuration: \[4\] \[5\] \[6\] \[7\] \[8\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[9\]](#)

**Table 5-95. L1PCC**

| <b>Address Offset</b>   | <b>0x0000 0024</b>         |                                                                                                                    |                 |  |  |  |  |       |          |  |  |  |  |  |      |        |  |  |  |  |  |  |
|-------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|-------|----------|--|--|--|--|--|------|--------|--|--|--|--|--|--|
| <b>Physical address</b> | 0x0184 0024                |                                                                                                                    |                 |  |  |  |  |       |          |  |  |  |  |  |      |        |  |  |  |  |  |  |
| <b>Description</b>      | L1P Configuration Register |                                                                                                                    |                 |  |  |  |  |       |          |  |  |  |  |  |      |        |  |  |  |  |  |  |
| <b>Type</b>             | RW                         |                                                                                                                    |                 |  |  |  |  |       |          |  |  |  |  |  |      |        |  |  |  |  |  |  |
| 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 |  |  |  |  |       |          |  |  |  |  |  |      |        |  |  |  |  |  |  |
| Reserved                |                            |                                                                                                                    |                 |  |  |  |  | POPER | Reserved |  |  |  |  |  |      |        |  |  |  |  |  |  |
| Bits                    | Field Name                 | Description                                                                                                        |                 |  |  |  |  |       |          |  |  |  |  |  | Type | Reset  |  |  |  |  |  |  |
| 31:19                   | Reserved                   | Write 0s for future compatibility. Read returns 0.                                                                 |                 |  |  |  |  |       |          |  |  |  |  |  | R    | 0x0000 |  |  |  |  |  |  |
| 18:16                   | POPER                      | Previous value of the OPER field<br><br>Read 0x0: L1P cache operates normally<br><br>Read 0x1: L1P Cache is frozen |                 |  |  |  |  |       |          |  |  |  |  |  | R    | 0x0    |  |  |  |  |  |  |
| 15:3                    | Reserved                   | Write 0s for future compatibility. Read returns 0.                                                                 |                 |  |  |  |  |       |          |  |  |  |  |  | RW   | 0x0000 |  |  |  |  |  |  |
| 2:0                     | OPER                       | DMC operation control<br><br>0x0: L1P cache operates normally<br><br>0x1: L1P Cache is frozen                      |                 |  |  |  |  |       |          |  |  |  |  |  | RW   | 0x0    |  |  |  |  |  |  |

**Table 5-96. Register Call Summary for Register L1PCC**

IVA2.2 Subsystem Basic Programming Model

- [Cache Mode Configuration: \[0\] \[1\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[2\]](#)

**Table 5-97. L1DCFG**

| <b>Address Offset</b>   | <b>0x0000 0040</b>                                                          |                                                                                                                                                                                                                                                   |                 |  |  |  |  |  |  |  |  |  |  |         |      |            |
|-------------------------|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|---------|------|------------|
| <b>Physical address</b> | 0x0184 0040                                                                 |                                                                                                                                                                                                                                                   |                 |  |  |  |  |  |  |  |  |  |  |         |      |            |
| <b>Description</b>      | L1D resets to Maximal cache mode using dmc_default_cachemode tie-off input. |                                                                                                                                                                                                                                                   |                 |  |  |  |  |  |  |  |  |  |  |         |      |            |
| <b>Type</b>             | RW                                                                          |                                                                                                                                                                                                                                                   |                 |  |  |  |  |  |  |  |  |  |  |         |      |            |
| 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 |  |  |  |  |  |  |  |  |  |  |         |      |            |
| Reserved                |                                                                             |                                                                                                                                                                                                                                                   |                 |  |  |  |  |  |  |  |  |  |  | L1DMODE |      |            |
| Bits                    | Field Name                                                                  | Description                                                                                                                                                                                                                                       |                 |  |  |  |  |  |  |  |  |  |  |         | Type | Reset      |
| 31:3                    | Reserved                                                                    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                |                 |  |  |  |  |  |  |  |  |  |  |         | RW   | 0x00000000 |
| 2:0                     | L1DMODE                                                                     | L1D Configuration Register<br><br>0x0: 0KB of L1D Cache<br>0x1: 4KB of L1D Cache<br>0x2: 8KB of L1D Cache<br>0x3: 16KB of L1D Cache<br>0x4: 32KB of L1D Cache<br>0x5: Not used<br>0x6: Not used<br>0x7: Maximum cache (maps to 32KB of L1D Cache) |                 |  |  |  |  |  |  |  |  |  |  |         | RW   | 0x0        |

**Table 5-98. Register Call Summary for Register L1DCFG**

IVA2.2 Subsystem Basic Programming Model

- [IVA2.2 Boot Configuration: \[0\] \[1\] \[2\] \[3\]](#)
- [Cache-Size Configuration: \[4\] \[5\] \[6\] \[7\] \[8\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[9\]](#)

**Table 5-99. L1DCC**

|                         |                            |                 |               |
|-------------------------|----------------------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 0044                | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Physical address</b> | 0x0184 0044                |                 |               |
| <b>Description</b>      | L1D Configuration Register |                 |               |
| <b>Type</b>             | RW                         |                 |               |

|          |    |    |    |    |    |    |    |    |    |       |          |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|-------|----------|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    | POPER | Reserved |    |    |    |    |    |    |    |    |    | OPER |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                    | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------|------|--------|
| 31:19 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                             | R    | 0x0000 |
| 18:16 | POPER      | Previous value of the OPER field<br><br>Read 0x0: L1D cache operates normally<br>Read 0x1: L1D Cache is frozen | R    | 0x0    |
| 15:3  | Reserved   | Write 0s for future compatibility. Read returns 0.                                                             | RW   | 0x0000 |
| 2:0   | OPER       | DMC operation control<br><br>0x0: L1D cache operates normally<br>0x1: L1D Cache is frozen                      | RW   | 0x0    |

**Table 5-100. Register Call Summary for Register L1DCC**

IVA2.2 Subsystem Basic Programming Model

- [Cache Mode Configuration: \[0\] \[1\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[2\]](#)

**Table 5-101. CPUARBU**

|                         |             |                 |               |
|-------------------------|-------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 1000 | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Physical address</b> | 0x0184 1000 |                 |               |
| <b>Description</b>      |             |                 |               |
| <b>Type</b>             | RW          |                 |               |

|          |    |    |    |    |    |    |    |    |    |     |          |    |    |    |    |    |    |    |    |    |         |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|-----|----------|----|----|----|----|----|----|----|----|----|---------|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    | PRI | Reserved |    |    |    |    |    |    |    |    |    | MAXWAIT |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                  | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:19 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                           | RW   | 0x0000 |
| 18:16 | PRI        | Priority<br><br>0x0: Highest priority<br>0x1: 2nd highest priority<br>0x2: 3rd highest priority<br>0x3: 4th highest priority | RW   | 0x1    |
| 15:3  | Reserved   |                                                                                                                              | RW   | 0x0000 |
| 2:0   | Reserved   |                                                                                                                              | RW   | 0x0    |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                     | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x4: 5th highest priority<br>0x5: 6th highest priority<br>0x6: 7th highest priority<br>0x7: Lowest priority                                                                                                                                                                                                                                                                     |      |       |
| 15:6 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                              | RW   | 0x000 |
| 5:0  | MAXWAIT    | Maximum Wait time (in UMC/EMC cycles)                                                                                                                                                                                                                                                                                                                                           | RW   | 0x10  |
|      |            | 0x0: Always stalls due to higher priority requestor<br>0x1: Maximum wait of 1 cycles (1/2 = 50% access)<br>0x2: Maximum wait of 2 cycles (1/3 = 33% access)<br>0x4: Maximum wait of 4 cycles (1/5 = 20% access)<br>0x8: Maximum wait of 8 cycles (1/9 = 11% access)<br>0x10: Maximum wait of 16 cycles (1/17 = 6% access)<br>0x20: Maximum wait of 32 cycles (1/33 = 3% access) |      |       |

**Table 5-102. Register Call Summary for Register CPUARBU**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-103. IDMAARBU**

|                       |             |                         |             |                 |               |
|-----------------------|-------------|-------------------------|-------------|-----------------|---------------|
| <b>Address Offset</b> | 0x0000 1004 | <b>Physical address</b> | 0x0184 1004 | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Description</b>    |             |                         |             |                 |               |
| <b>Type</b>           | RW          |                         |             |                 |               |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                     | Type | Reset     |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:6 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                              | RW   | 0x0000000 |
| 5:0  | MAXWAIT    | Maximum Wait time (in UMC/EMC cycles)                                                                                                                                                                                                                                                                                                                                           | RW   | 0x10      |
|      |            | 0x0: Always stalls due to higher priority requestor<br>0x1: Maximum wait of 1 cycles (1/2 = 50% access)<br>0x2: Maximum wait of 2 cycles (1/3 = 33% access)<br>0x4: Maximum wait of 4 cycles (1/5 = 20% access)<br>0x8: Maximum wait of 8 cycles (1/9 = 11% access)<br>0x10: Maximum wait of 16 cycles (1/17 = 6% access)<br>0x20: Maximum wait of 32 cycles (1/33 = 3% access) |      |           |

**Table 5-104. Register Call Summary for Register IDMAARBU**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-105. SDMAARBU**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |             |          |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0000 1008 |          |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| Physical address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0x0184 1008 | Instance | IVA2.2 GEMXMC |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |             |          |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW          |          |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="16">Reserved</td><td colspan="8">MAXWAIT</td></tr> </table> |             |          |               | 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 | Reserved |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | MAXWAIT |  |  |  |  |  |  |  |
| 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 |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |          |               |    |    |    |    |    |    |    |    |    |    |    |    | MAXWAIT |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |

**Table 5-106. Register Call Summary for Register SDMAARBU**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-107. UCARBU**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   |                                                     |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------------------------------------------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0000 100C       |                                                     |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| Physical address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0x0184 100C       | Instance                                            | IVA2.2 GEMXMC |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                                                     |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW                |                                                     |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="16">Reserved</td><td colspan="8">MAXWAIT</td></tr> </table> |                   |                                                     |               | 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 | Reserved |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | MAXWAIT |  |  |  |  |  |  |  |
| 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 |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                   |                                                     |               |    |    |    |    |    |    |    |    |    |    |    |    | MAXWAIT |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| <b>Bits</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <b>Field Name</b> | <b>Description</b>                                  | <b>Type</b>   |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 31:6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reserved          | Write 0s for future compatibility. Read returns 0.  | RW            |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 5:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | MAXWAIT           | Maximum Wait time (in UMC/EMC cycles)               | RW            |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   | 0x0: Always stalls due to higher priority requestor |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   | 0x1: Maximum wait of 1 cycles (1/2 = 50% access)    |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   | 0x2: Maximum wait of 2 cycles (1/3 = 33% access)    |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   | 0x4: Maximum wait of 4 cycles (1/5 = 20% access)    |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   | 0x8: Maximum wait of 8 cycles (1/9 = 11% access)    |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   | 0x10: Maximum wait of 16 cycles (1/17 = 6% access)  |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   | 0x20: Maximum wait of 32 cycles (1/33 = 3% access)  |               |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |

**Table 5-108. Register Call Summary for Register UCARBU**


---

 IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]
- 

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]
- 

**Table 5-109. CPUARBD**

|                         |                 |                 |               |
|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 1040     | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Physical address</b> | 0x0184 1040     |                 |               |
| <b>Description</b>      | CPU Arb Control |                 |               |
| <b>Type</b>             | RW              |                 |               |

|          |    |    |    |    |    |    |    |     |          |    |    |    |    |    |    |    |         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|-----|----------|----|----|----|----|----|----|----|---------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    | PRI | Reserved |    |    |    |    |    |    |    | MAXWAIT |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                         | Type | Reset  |
|-------|------------|-----------------------------------------------------|------|--------|
| 31:19 | Reserved   | Write 0s for future compatibility. Read returns 0.  | RW   | 0x0000 |
| 18:16 | PRI        | Priority                                            | RW   | 0x1    |
|       |            | 0x0: Highest priority                               |      |        |
|       |            | 0x1: 2nd highest priority                           |      |        |
|       |            | 0x2: 3rd highest priority                           |      |        |
|       |            | 0x3: 4th highest priority                           |      |        |
|       |            | 0x4: 5th highest priority                           |      |        |
|       |            | 0x5: 6th highest priority                           |      |        |
|       |            | 0x6: 7th highest priority                           |      |        |
|       |            | 0x7: Lowest priority                                |      |        |
| 15:6  | Reserved   | Write 0s for future compatibility. Read returns 0.  | RW   | 0x000  |
| 5:0   | MAXWAIT    | Maximum Wait time (in UMC/EMC cycles)               | RW   | 0x10   |
|       |            | 0x0: Always stalls due to higher priority requestor |      |        |
|       |            | 0x1: Maximum wait of 1 cycles (1/2 = 50% access)    |      |        |
|       |            | 0x2: Maximum wait of 2 cycles (1/3 = 33% access)    |      |        |
|       |            | 0x4: Maximum wait of 4 cycles (1/5 = 20% access)    |      |        |
|       |            | 0x8: Maximum wait of 8 cycles (1/9 = 11% access)    |      |        |
|       |            | 0x10: Maximum wait of 16 cycles (1/17 = 6% access)  |      |        |
|       |            | 0x20: Maximum wait of 32 cycles (1/33 = 3% access)  |      |        |

**Table 5-110. Register Call Summary for Register CPUARBD**


---

 IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]
- 

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]
-

**Table 5-111. IDMAARBD**

|                         |                         |                       |                 |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 1044             | <b>Instance</b>       | IVA2.2 GEMXMC   |  |  |
| <b>Physical address</b> | 0x0184 1044             |                       |                 |  |  |
| <b>Description</b>      |                         |                       |                 |  |  |
| <b>Type</b>             | RW                      |                       |                 |  |  |
| 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 |  |  |
| Reserved                |                         |                       | MAXWAIT         |  |  |

  

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------|-------------|--------------|
| 31:6        | Reserved          | Write 0s for future compatibility. Read returns 0.  | RW          | 0x0000000    |
| 5:0         | MAXWAIT           | Maximum Wait time (in UMC/EMC cycles)               | RW          | 0x10         |
|             |                   | 0x0: Always stalls due to higher priority requestor |             |              |
|             |                   | 0x1: Maximum wait of 1 cycles (1/2 = 50% access)    |             |              |
|             |                   | 0x2: Maximum wait of 2 cycles (1/3 = 33% access)    |             |              |
|             |                   | 0x4: Maximum wait of 4 cycles (1/5 = 20% access)    |             |              |
|             |                   | 0x8: Maximum wait of 8 cycles (1/9 = 11% access)    |             |              |
|             |                   | 0x10: Maximum wait of 16 cycles (1/17 = 6% access)  |             |              |
|             |                   | 0x20: Maximum wait of 32 cycles (1/33 = 3% access)  |             |              |

**Table 5-112. Register Call Summary for Register IDMAARBD**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-113. SDMAARBD**

|                         |                         |                       |                 |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 1048             | <b>Instance</b>       | IVA2.2 GEMXMC   |  |  |
| <b>Physical address</b> | 0x0184 1048             |                       |                 |  |  |
| <b>Description</b>      |                         |                       |                 |  |  |
| <b>Type</b>             | RW                      |                       |                 |  |  |
| 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 |  |  |
| Reserved                |                         |                       | MAXWAIT         |  |  |

  

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------|-------------|--------------|
| 31:6        | Reserved          | Write 0s for future compatibility. Read returns 0.  | RW          | 0x0000000    |
| 5:0         | MAXWAIT           | Maximum Wait time (in UMC/EMC cycles)               | RW          | 0x01         |
|             |                   | 0x0: Always stalls due to higher priority requestor |             |              |
|             |                   | 0x1: Maximum wait of 1 cycles (1/2 = 50% access)    |             |              |
|             |                   | 0x2: Maximum wait of 2 cycles (1/3 = 33% access)    |             |              |
|             |                   | 0x4: Maximum wait of 4 cycles (1/5 = 20% access)    |             |              |
|             |                   | 0x8: Maximum wait of 8 cycles (1/9 = 11% access)    |             |              |
|             |                   | 0x10: Maximum wait of 16 cycles (1/17 = 6% access)  |             |              |
|             |                   | 0x20: Maximum wait of 32 cycles (1/33 = 3% access)  |             |              |

**Table 5-114. Register Call Summary for Register SDMAARBD**


---

 I/VA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

---

 I/VA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]
- 

**Table 5-115. UCARBD**

|                         |                         |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                 |                |  |         |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|----------------|--|---------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 104C             |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | I/VA2.2 GEMXMC |  |         |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0184 104C             |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                 |                |  |         |  |  |  |  |  |  |  |
| <b>Description</b>      |                         |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                 |                |  |         |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                 |                |  |         |  |  |  |  |  |  |  |
| 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 | Reserved |  |  |  |  |  |  |  |  |  |  |  |  |                 |                |  | MAXWAIT |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset     |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:6 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0000000 |
| 5:0  | MAXWAIT    | Maximum Wait time (in UMC/EMC cycles)<br>0x0: Always stalls due to higher priority requestor<br>0x1: Maximum wait of 1 cycles (1/2 = 50% access)<br>0x2: max wait of 2 cycles (1/3 = 33% access)<br>0x4: Maximum wait of 4 cycles (1/5 = 20% access)<br>0x8: Maximum wait of 8 cycles (1/9 = 11% access)<br>0x10: Maximum wait of 16 cycles (1/17 = 6% access)<br>0x20: Maximum wait of 32 cycles (1/33 = 3% access) | RW   | 0x20      |

**Table 5-116. Register Call Summary for Register UCARBD**


---

 I/VA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

---

 I/VA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]
- 

**Table 5-117. L2WBAR**

|                         |                                 |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |                 |                |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|----------------|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 4000                     |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | I/VA2.2 GEMXMC |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0184 4000                     |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |                 |                |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | L2 block writeback base address |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |                 |                |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                               |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |                 |                |  |  |  |  |  |  |  |  |  |
| 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 | ADDR |  |  |  |  |  |  |  |  |  |  |  |  |                 |                |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description        | Type | Reset   |
|------|------------|--------------------|------|---------|
| 31:0 | ADDR       | Block base address | W    | 0x----- |

**Table 5-118. Register Call Summary for Register L2WBAR**

IVA2.2 Subsystem Basic Programming Model  
 • Coherence Maintenance: [0]

IVA2.2 Subsystem Register Manual  
 • XMC Register Mapping Summary: [1]

**Table 5-119. L2WWC**

|                         |                         |                       |                 |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 4004             | <b>Instance</b>       | IVA2.2 GEMXMC   |  |  |
| <b>Physical address</b> | 0x0184 4004             |                       |                 |  |  |
| <b>Description</b>      |                         |                       |                 |  |  |
| <b>Type</b>             | RW                      |                       |                 |  |  |
| 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 |  |  |
| Reserved                |                         | WC                    |                 |  |  |

| Bits  | Field Name | Description                                        | Type | Reset  |
|-------|------------|----------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write Os for future compatibility. Read returns 0. | RW   | 0x0000 |
| 15:0  | WC         | Number of 32-bit words in the block                | RW   | 0x0000 |

**Table 5-120. Register Call Summary for Register L2WWC**

IVA2.2 Subsystem Basic Programming Model  
 • Coherence Maintenance: [0]

IVA2.2 Subsystem Register Manual  
 • XMC Register Mapping Summary: [1]

**Table 5-121. L2WIBAR**

|                         |                             |                       |                 |  |  |
|-------------------------|-----------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 4010                 | <b>Instance</b>       | IVA2.2 GEMXMC   |  |  |
| <b>Physical address</b> | 0x0184 4010                 |                       |                 |  |  |
| <b>Description</b>      | L2 block wbinv base address |                       |                 |  |  |
| <b>Type</b>             | W                           |                       |                 |  |  |
| 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 |  |  |
| ADDR                    |                             |                       |                 |  |  |

| Bits | Field Name | Description        | Type | Reset   |
|------|------------|--------------------|------|---------|
| 31:0 | ADDR       | Block base address | W    | 0x----- |

**Table 5-122. Register Call Summary for Register L2WIBAR**

IVA2.2 Subsystem Basic Programming Model  
 • Coherence Maintenance: [0]

IVA2.2 Subsystem Register Manual  
 • XMC Register Mapping Summary: [1]

**Table 5-123. L2WIWC**

|                         |             |                 |               |  |  |
|-------------------------|-------------|-----------------|---------------|--|--|
| <b>Address Offset</b>   | 0x0000 4014 | <b>Instance</b> | IVA2.2 GEMXMC |  |  |
| <b>Physical address</b> | 0x0184 4014 |                 |               |  |  |
| <b>Description</b>      |             |                 |               |  |  |
| <b>Type</b>             | RW          |                 |               |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WC |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------|-------------|--------------|
| 31:16       | Reserved          | Write 0s for future compatibility. Read returns 0. | RW          | 0x0000       |
| 15:0        | WC                | Number of 32-bit words in the block                | RW          | 0x0000       |

**Table 5-124. Register Call Summary for Register L2WIWC**

IVA2.2 Subsystem Basic Programming Model

- [Coherence Maintenance: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[1\]](#)

**Table 5-125. L2IBAR**

|                         |             |                 |               |  |  |
|-------------------------|-------------|-----------------|---------------|--|--|
| <b>Address Offset</b>   | 0x0000 4018 | <b>Instance</b> | IVA2.2 GEMXMC |  |  |
| <b>Physical address</b> | 0x0184 4018 |                 |               |  |  |
| <b>Description</b>      |             |                 |               |  |  |
| <b>Type</b>             | W           |                 |               |  |  |

  

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 31:0        | ADDR              |                    | W           | 0x-----      |

**Table 5-126. Register Call Summary for Register L2IBAR**

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[0\]](#)

**Table 5-127. L2IWC**

|                         |             |                 |               |  |  |
|-------------------------|-------------|-----------------|---------------|--|--|
| <b>Address Offset</b>   | 0x0000 401C | <b>Instance</b> | IVA2.2 GEMXMC |  |  |
| <b>Physical address</b> | 0x0184 401C |                 |               |  |  |
| <b>Description</b>      |             |                 |               |  |  |
| <b>Type</b>             | RW          |                 |               |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WC |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------|-------------|--------------|
| 31:16       | Reserved          | Write 0s for future compatibility. Read returns 0. | RW          | 0x0000       |
| 15:0        | WC                | Number of 32-bit words in the block                | RW          | 0x0000       |

**Table 5-128. Register Call Summary for Register L2IWC**

IVA2.2 Subsystem Basic Programming Model

- Coherence Maintenance: [0] [1]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [2]

**Table 5-129. L1PIBAR**

|                         |                                            |                         |                 |                 |               |
|-------------------------|--------------------------------------------|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 4020                                | <b>Physical address</b> | 0x0184 4020     | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Description</b>      | L1P Block Invalidate Base Address Register | <b>Type</b>             | W               |                 |               |
| 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 | ADDR            |               |
|                         |                                            |                         |                 |                 |               |

| Bits | Field Name | Description        | Type | Reset   |
|------|------------|--------------------|------|---------|
| 31:0 | ADDR       | Block base address | W    | 0x----- |

**Table 5-130. Register Call Summary for Register L1PIBAR**

IVA2.2 Subsystem Basic Programming Model

- Coherence Maintenance: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-131. L1PIWC**

|                         |                                 |                         |                 |                 |               |
|-------------------------|---------------------------------|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 4024                     | <b>Physical address</b> | 0x0184 4024     | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Description</b>      | L1P Block Invalidate Word Count | <b>Type</b>             | RW              |                 |               |
| 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 | Reserved        |               |
|                         |                                 |                         |                 |                 | WC            |

| Bits  | Field Name | Description                                        | Type | Reset  |
|-------|------------|----------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write Os for future compatibility. Read returns 0. | RW   | 0x0000 |
| 15:0  | WC         | Number of 32-bit words in the block                | RW   | 0x0000 |

**Table 5-132. Register Call Summary for Register L1PIWC**

IVA2.2 Subsystem Basic Programming Model

- Coherence Maintenance: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-133. L1DWIBAR**

|                                                                                             |             |                 |               |  |  |  |  |  |
|---------------------------------------------------------------------------------------------|-------------|-----------------|---------------|--|--|--|--|--|
| <b>Address Offset</b>                                                                       | 0x0000 4030 | <b>Instance</b> | IVA2.2 GEMXMC |  |  |  |  |  |
| <b>Physical address</b>                                                                     | 0x0184 4030 |                 |               |  |  |  |  |  |
| <b>Description</b>                                                                          |             |                 |               |  |  |  |  |  |
| <b>Type</b>                                                                                 | W           |                 |               |  |  |  |  |  |
| 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 |             |                 |               |  |  |  |  |  |
| ADDR                                                                                        |             |                 |               |  |  |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 31:0        | ADDR              | Block base address | W           | 0x-----      |

**Table 5-134. Register Call Summary for Register L1DWIBAR**

IVA2.2 Subsystem Basic Programming Model

- Coherence Maintenance: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-135. L1DWIWC**

|                                                                                             |                             |                 |               |  |  |  |  |  |
|---------------------------------------------------------------------------------------------|-----------------------------|-----------------|---------------|--|--|--|--|--|
| <b>Address Offset</b>                                                                       | 0x0000 4034                 | <b>Instance</b> | IVA2.2 GEMXMC |  |  |  |  |  |
| <b>Physical address</b>                                                                     | 0x0184 4034                 |                 |               |  |  |  |  |  |
| <b>Description</b>                                                                          | L1D Block Wb-Inv Word Count |                 |               |  |  |  |  |  |
| <b>Type</b>                                                                                 | RW                          |                 |               |  |  |  |  |  |
| 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 |                             |                 |               |  |  |  |  |  |
| Reserved                                                                                    |                             |                 |               |  |  |  |  |  |
| WC                                                                                          |                             |                 |               |  |  |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------|-------------|--------------|
| 31:16       | Reserved          | Write 0s for future compatibility. Read returns 0. | RW          | 0x0000       |
| 15:0        | WC                | Number of 32-bit words in the block                | RW          | 0x0000       |

**Table 5-136. Register Call Summary for Register L1DWIWC**

IVA2.2 Subsystem Basic Programming Model

- Coherence Maintenance: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-137. L1DWBAR**

|                                                                                             |                                           |                 |               |  |  |  |  |  |
|---------------------------------------------------------------------------------------------|-------------------------------------------|-----------------|---------------|--|--|--|--|--|
| <b>Address Offset</b>                                                                       | 0x0000 4040                               | <b>Instance</b> | IVA2.2 GEMXMC |  |  |  |  |  |
| <b>Physical address</b>                                                                     | 0x0184 4040                               |                 |               |  |  |  |  |  |
| <b>Description</b>                                                                          | L1D Block Writeback Base Address Register |                 |               |  |  |  |  |  |
| <b>Type</b>                                                                                 | W                                         |                 |               |  |  |  |  |  |
| 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 |                                           |                 |               |  |  |  |  |  |
| ADDR                                                                                        |                                           |                 |               |  |  |  |  |  |

| Bits | Field Name | Description        | Type | Reset   |
|------|------------|--------------------|------|---------|
| 31:0 | ADDR       | Block base address | W    | 0x----- |

**Table 5-138. Register Call Summary for Register L1DWBAR**

IVA2.2 Subsystem Basic Programming Model

- Coherence Maintenance: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-139. L1DWWC**

|                         |                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 4044                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0184 4044                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | L1D Block Writeback Word Count |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WC |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                        | Type | Reset  |
|-------|------------|----------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility. Read returns 0. | RW   | 0x0000 |
| 15:0  | WC         | Number of 32-bit words in the block                | RW   | 0x0000 |

**Table 5-140. Register Call Summary for Register L1DWWC**

IVA2.2 Subsystem Basic Programming Model

- Coherence Maintenance: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-141. L1DIBAR**

|                         |                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 4048                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0184 4048                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | L1D Block Invalidate Base Address Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description        | Type | Reset   |
|------|------------|--------------------|------|---------|
| 31:0 | ADDR       | Block base address | W    | 0x----- |

**Table 5-142. Register Call Summary for Register L1DIBAR**

IVA2.2 Subsystem Basic Programming Model

- Coherence Maintenance: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-143. L1DIWC**

|                         |                                 |                       |                 |  |  |
|-------------------------|---------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 404C                     | <b>Instance</b>       | IVA2.2 GEMXMC   |  |  |
| <b>Physical address</b> | 0x0184 404C                     |                       |                 |  |  |
| <b>Description</b>      | L1D Block Invalidate Word Count |                       |                 |  |  |
| <b>Type</b>             | RW                              |                       |                 |  |  |
| 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 |  |  |
| Reserved                |                                 |                       | WC              |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------|-------------|--------------|
| 31:16       | Reserved          | Write 0s for future compatibility. Read returns 0. | RW          | 0x0000       |
| 15:0        | WC                | Number of 32-bit words in the block                | RW          | 0x0000       |

**Table 5-144. Register Call Summary for Register L1DIWC**

IVA2.2 Subsystem Basic Programming Model

- [Coherence Maintenance: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[1\]](#)

**Table 5-145. L2WB**

|                         |                         |                       |                 |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 5000             | <b>Instance</b>       | IVA2.2 GEMXMC   |  |  |
| <b>Physical address</b> | 0x0184 5000             |                       |                 |  |  |
| <b>Description</b>      | L2 global writeback     |                       |                 |  |  |
| <b>Type</b>             | RW                      |                       |                 |  |  |
| 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 |  |  |
| Reserved                |                         |                       | C               |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:1        | Reserved          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                      | RW          | 0x-----      |
| 0           | C                 | L2 global write-back control<br><br>Read 0x0: Read 0: Previous L2 global write-back has completed<br><br>Write 0x0: Write 0: No effect<br><br>Read 0x1: Read 1: Previous L2 global write-back has not completed<br><br>Write 0x1: Write 1: Initiates an L2 global write-back(L1P Effect: No effect. L1D Effect: All updated data written back to L2/external, but left valid in L1D. L2 Effect: All updated data written back externally, but left valid in L2 cache. ) | RW          | 0            |

**Table 5-146. Register Call Summary for Register L2WB**

IVA2.2 Subsystem Basic Programming Model

- [Coherence Maintenance: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[1\]](#)

**Table 5-147. L2WBINV**

|                         |                                |                         |                 |                 |               |
|-------------------------|--------------------------------|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 5004                    | <b>Physical address</b> | 0x0184 5004     | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Description</b>      | L2 global writeback invalidate |                         |                 |                 |               |
| <b>Type</b>             | RW                             |                         |                 |                 |               |
| 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 |                 |               |
|                         |                                | Reserved                |                 |                 | C             |

  

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset   |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x----- |
| 0    | C          | L2 global write-back/invalidate command:<br>Write 0: No effect<br>Write 1: Initiates an L2 global write-back/invalidate(L1P Effect: All lines invalidated in L1P. L1D Effect: All updated data written back to L2/external. All lines invalidated within L1D. L2 Effect: All updated data written back externally. All lines invalidated in L2).<br>Read 0: Previous L2 global write-back/invalidate has completed<br>Read 1: Previous L2 global write-back/invalidate has not completed | RW   | 0       |

**Table 5-148. Register Call Summary for Register L2WBINV**

IVA2.2 Subsystem Basic Programming Model

- [Coherence Maintenance: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[1\]](#)

**Table 5-149. L2INV**

|                         |                         |                         |                 |                 |               |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 500              | <b>Physical address</b> | 0x0184 5008     | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Description</b>      | L2 global invalidate    |                         |                 |                 |               |
| <b>Type</b>             | RW                      |                         |                 |                 |               |
| 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 |                 |               |
|                         |                         | Reserved                |                 |                 | I             |

  

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                        | Type | Reset   |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                 | RW   | 0x----- |
| 0    | I          | L2 global invalidate command:<br>Write 0: No effect<br>Write 1: Initiates an L2 global invalidate(L1P Effect: All lines invalidated in L1P. L1D Effect: All lines invalidated in L1D. Updated data is dropped. L2 Effect: All lines invalidated in L2. Updated data is dropped).<br>Read 0: Previous L2 global invalidate has completed<br>Read 1: Previous L2 global invalidate has not completed | RW   | 0       |

**Table 5-150. Register Call Summary for Register L2INV**

IVA2.2 Subsystem Basic Programming Model

- [Coherence Maintenance: \[0\] \[1\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[2\]](#)

**Table 5-151. L1PINV**

|                         |                       |                 |               |  |  |
|-------------------------|-----------------------|-----------------|---------------|--|--|
| <b>Address Offset</b>   | 0x0000 5028           | <b>Instance</b> | IVA2.2 GEMXMC |  |  |
| <b>Physical address</b> | 0x0184 5028           |                 |               |  |  |
| <b>Description</b>      | L1P Global Invalidate |                 |               |  |  |
| <b>Type</b>             | RW                    |                 |               |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | I |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                             | Type | Reset   |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                      | RW   | 0x----- |
| 0    | I          | L1P global invalidate command:<br><br>Write 0: No effect<br><br>Write 1: Initiates an L1P global invalidate<br><br>Read 0: Previous L1P global invalidate has completed<br><br>Read 1: Previous L1P global invalidate has not completed | RW   | 0       |

**Table 5-152. Register Call Summary for Register L1PINV**

IVA2.2 Subsystem Basic Programming Model

- [Coherence Maintenance: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[1\]](#)

**Table 5-153. L1DWB**

|                         |                      |                 |               |  |  |
|-------------------------|----------------------|-----------------|---------------|--|--|
| <b>Address Offset</b>   | 0x0000 5040          | <b>Instance</b> | IVA2.2 GEMXMC |  |  |
| <b>Physical address</b> | 0x0184 5040          |                 |               |  |  |
| <b>Description</b>      | L1D Global Writeback |                 |               |  |  |
| <b>Type</b>             | RW                   |                 |               |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | C |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                             | Type | Reset   |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                      | RW   | 0x----- |
| 0    | C          | L1D global write-back command:<br><br>Write 0: No effect<br><br>Write 1: Initiates an L1D global write-back<br><br>Read 0: Previous L1D global write-back has completed<br><br>Read 1: Previous L1D global write-back has not completed | RW   | 0       |

**Table 5-154. Register Call Summary for Register L1DWB**

IVA2.2 Subsystem Basic Programming Model

- [Coherence Maintenance: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[1\]](#)

**Table 5-155. L1DWBINV**

|                         |                                 |                                                                                                                                                                                                                                                                     |                 |                 |               |  |  |
|-------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|---------------|--|--|
| <b>Address Offset</b>   | 0x0000 5044                     | <b>Physical address</b>                                                                                                                                                                                                                                             | 0x0184 5044     | <b>Instance</b> | IVA2.2 GEMXMC |  |  |
| <b>Description</b>      | L1D Global Writeback Invalidate |                                                                                                                                                                                                                                                                     |                 |                 |               |  |  |
| <b>Type</b>             | RW                              |                                                                                                                                                                                                                                                                     |                 |                 |               |  |  |
| <hr/>                   |                                 |                                                                                                                                                                                                                                                                     |                 |                 |               |  |  |
| 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 |                 |               |  |  |
| Reserved                |                                 |                                                                                                                                                                                                                                                                     |                 |                 |               |  |  |
| C                       |                                 |                                                                                                                                                                                                                                                                     |                 |                 |               |  |  |
| <b>Bits</b>             | <b>Field Name</b>               | <b>Description</b>                                                                                                                                                                                                                                                  |                 | <b>Type</b>     | <b>Reset</b>  |  |  |
| 31:1                    | Reserved                        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                  |                 | RW              | 0x-----       |  |  |
| 0                       | C                               | L1D global write-back/invalidate command:<br>Write 0: No effect<br>Write 1: Initiates an L1D global write-back/invalidate<br>Read 0: Previous L1D global write-back/invalidate has completed<br>Read 1: Previous L1D global write-back/invalidate has not completed |                 | RW              | 0             |  |  |

**Table 5-156. Register Call Summary for Register L1DWBINV**

IVA2.2 Subsystem Basic Programming Model

- [Coherence Maintenance: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[1\]](#)

**Table 5-157. L1DINV**

|                         |                         |                                                                                                                                                                                                                         |                 |                 |               |  |  |
|-------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|---------------|--|--|
| <b>Address Offset</b>   | 0x0000 5048             | <b>Physical address</b>                                                                                                                                                                                                 | 0x0184 5048     | <b>Instance</b> | IVA2.2 GEMXMC |  |  |
| <b>Description</b>      | L1D Global Invalidate   |                                                                                                                                                                                                                         |                 |                 |               |  |  |
| <b>Type</b>             | RW                      |                                                                                                                                                                                                                         |                 |                 |               |  |  |
| <hr/>                   |                         |                                                                                                                                                                                                                         |                 |                 |               |  |  |
| 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 |                 |               |  |  |
| Reserved                |                         |                                                                                                                                                                                                                         |                 |                 |               |  |  |
| I                       |                         |                                                                                                                                                                                                                         |                 |                 |               |  |  |
| <b>Bits</b>             | <b>Field Name</b>       | <b>Description</b>                                                                                                                                                                                                      |                 | <b>Type</b>     | <b>Reset</b>  |  |  |
| 31:1                    | Reserved                | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                      |                 | RW              | 0x-----       |  |  |
| 0                       | I                       | L1D global invalidate command:<br>Write 0: No effect<br>Write 1: Initiates an L1D global invalidate<br>Read 0: Previous L1D global invalidate has completed<br>Read 1: Previous L1D global invalidate has not completed |                 | RW              | 0             |  |  |

**Table 5-158. Register Call Summary for Register L1DINV**

IVA2.2 Subsystem Basic Programming Model

- [Coherence Maintenance: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[1\]](#)

**Table 5-159. MARi**

|                         |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x8000 + (0x4*i)      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0184 8000 + (0x4*i) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Instance              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | IV A2.2 GEMXMC        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | PC |   |

| Bits | Field Name | Description                                                  | Type                | Reset         |
|------|------------|--------------------------------------------------------------|---------------------|---------------|
| 31:1 | Reserved   | Write 0s for future compatibility. Read returns 0.           | R                   | 0x-----       |
| 0    | PC         | Read 0x0: Region is not cached<br>Read 0x1: Region is cached | RW (R for i=0...15) | 0 (1 for i=0) |

**Table 5-160. Register Call Summary for Register MARi**

IVA2.2 Subsystem Basic Programming Model

- [IVA2.2 Boot Configuration: \[0\]](#) [\[1\]](#)
- [External Memory: \[2\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[3\]](#)

**Table 5-161. L2MPFAR**

|                         |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 A000    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0184 A000    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Instance       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | IV A2.2 GEMXMC |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description        | Type | Reset      |
|------|------------|--------------------|------|------------|
| 31:0 | ADDR       | Block base address | W    | 0x00000000 |

**Table 5-162. Register Call Summary for Register L2MPFAR**

IVA2.2 Subsystem Basic Programming Model

- [Internal Memory: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[1\]](#)

**Table 5-163. L2MPFSR**

|                         |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |       |          |      |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|-------|----------|------|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 A004             | <b>Instance</b>       | IVA2.2 GEMXMC   |  |  |  |  |  |  |  |  |  |  |  |       |          |      |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0184 A004             |                       | IVA2.2 GEMXMC   |  |  |  |  |  |  |  |  |  |  |  |       |          |      |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |       |          |      |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                       |                       |                 |  |  |  |  |  |  |  |  |  |  |  |       |          |      |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |       |          |      |  |  |  |  |  |  |  |  |  |  |
| Reserved                |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  | FLTID | Reserved | ATYP |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                               | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility. Read returns 0.                                        | R    | 0x0000 |
| 15:8  | FLTID      | Faulted ID:<br>VBUS PrivID of faulting requestor. This field is valid only if LE is zero. | R    | 0x00   |
| 7:6   | Reserved   | Write 0s for future compatibility. Read returns 0.                                        | R    | 0x0    |
| 5:0   | ATYP       | Access type                                                                               | R    | 0x00   |

**Table 5-164. Register Call Summary for Register L2MPFSR**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-165. L2MPFCR**

|                         |                                             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 A008                                 | <b>Instance</b>       | IVA2.2 GEMXMC   |  |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x0184 A008                                 |                       | IVA2.2 GEMXMC   |  |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | L2 Memory Protection Fault Command Register |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                           |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                |                                             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | MPFCLR |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                | Type | Reset      |
|------|------------|------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Write 0s for future compatibility. Read returns 0.         | W    | 0x00000000 |
| 0    | MPFCLR     | Write 0: No effect Write 1: Clear fault logged information | W    | 0          |

**Table 5-166. Register Call Summary for Register L2MPFCR**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-167. L2MPPAj**

|                         |                                                                              |                       |                 |      |      |      |      |      |      |      |       |          |    |    |    |    |    |    |
|-------------------------|------------------------------------------------------------------------------|-----------------------|-----------------|------|------|------|------|------|------|------|-------|----------|----|----|----|----|----|----|
| <b>Address Offset</b>   | 0x0000 A200 + (0x4*j) in 0x4 byte increments                                 |                       |                 |      |      |      |      |      |      |      |       |          |    |    |    |    |    |    |
| <b>Physical address</b> | 0x0184 A200 + (0x4*j)                                                        |                       |                 |      |      |      |      |      |      |      |       |          |    |    |    |    |    |    |
| <b>Description</b>      | Instance IVA2.2 GEMXMC                                                       |                       |                 |      |      |      |      |      |      |      |       |          |    |    |    |    |    |    |
| <b>Type</b>             | L2 Memory Protection Attribute Register Addresses for the 16MB page number i |                       |                 |      |      |      |      |      |      |      |       |          |    |    |    |    |    |    |
| 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 | AID5 | AID4 | AID3 | AID2 | AID1 | AID0 | AIDX | LOCAL | Reserved | SR | SW | SX | UR | UW | UX |
| Reserved                |                                                                              |                       |                 |      |      |      |      |      |      |      |       |          |    |    |    |    |    |    |

| Bits  | Field Name | Description                                                                                | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility. Read returns 0.                                         | RW   | 0x0000 |
| 15    | AID5       | 0: ID 5 does not have access permission<br>1: ID 5 has access permission                   | RW   | 1      |
| 14    | AID4       | 0: ID 4 does not have access permission<br>1: ID 4 has access permission                   | RW   | 1      |
| 13    | AID3       | 0: ID 3 does not have access permission<br>1: ID 3 has access permission                   | RW   | 1      |
| 12    | AID2       | 0: ID 2 does not have access permission<br>1: ID 2 has access permission                   | RW   | 1      |
| 11    | AID1       | 0: ID 1 does not have access permission<br>1: ID 1 has access permission                   | RW   | 1      |
| 10    | AID0       | 0: ID 0 does not have access permission<br>1: ID 0 has access permission                   | RW   | 1      |
| 9     | AIDX       | 0: External access is not permitted<br>1: External access is permitted                     | RW   | 1      |
| 8     | LOCAL      | 0: DSP megamodule access is not permitted<br>1: DSP megamodule access is permitted         | RW   | 1      |
| 7:6   | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                      | RW   | 0      |
| 5     | SR         | 0: Supervisor Read access is not permitted<br>1: Supervisor Read access is permitted       | RW   | 1      |
| 4     | SW         | 0: Supervisor Write access is not permitted<br>1: Supervisor Write access is permitted     | RW   | 1      |
| 3     | SX         | 0: Supervisor eXecute access is not permitted<br>1: Supervisor eXecute access is permitted | RW   | 1      |
| 2     | UR         | 0: User Read access is not permitted<br>1: User Read access is permitted                   | RW   | 1      |
| 1     | UW         | 0: User Write access is not permitted<br>1: User Write access is permitted                 | RW   | 1      |
| 0     | UX         | 0: User eXecute access is not permitted<br>1: User eXecute access is permitted             | RW   | 1      |

**Table 5-168. Register Call Summary for Register L2MPPAj**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0] [1] [2] [3] [4]
- Powering Down L2\$ Memory While IVA2 is Active: [5] [6] [7]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [8]

**Table 5-169. L1PMPFAR**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |             |                 |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x0000 A400 | <b>Instance</b> | IVA2.2 GEMXMC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0184 A400 |                 |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | PMC         |                 |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R           |                 |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="33" style="text-align:center;">ADDR</td></tr> </table> | 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 | ADDR |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |             |                 |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description   | Type | Reset      |
|------|------------|---------------|------|------------|
| 31:0 | ADDR       | Fault Address | R    | 0x00000000 |

**Table 5-170. Register Call Summary for Register L1PMPFAR**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-171. L1PMPFSR**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |             |                 |               |    |    |    |    |       |    |    |    |          |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |       |  |  |  |          |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------|---------------|----|----|----|----|-------|----|----|----|----------|------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|-------|--|--|--|----------|------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0000 A404 | <b>Instance</b> | IVA2.2 GEMXMC |    |    |    |    |       |    |    |    |          |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |       |  |  |  |          |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x0184 A404 |                 |               |    |    |    |    |       |    |    |    |          |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |       |  |  |  |          |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | PMC         |                 |               |    |    |    |    |       |    |    |    |          |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |       |  |  |  |          |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R           |                 |               |    |    |    |    |       |    |    |    |          |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |       |  |  |  |          |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="8" style="text-align:center;">Reserved</td><td colspan="4" style="text-align:center;">FLTID</td><td style="vertical-align: middle; text-align: center;">Reserved</td><td colspan="8" style="text-align:center;">ATYP</td><td colspan="4"></td><td colspan="4"></td></tr> </table> | 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 | Reserved |  |  |  |  |  |  |  | FLTID |  |  |  | Reserved | ATYP |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |   |   |   |          |  |  |  |  |  |  |  |       |  |  |  |          |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |             |                 |               |    |    |    |    | FLTID |    |    |    | Reserved | ATYP |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |       |  |  |  |          |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                         | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                  | R    | 0x0000 |
| 15:8  | FLTID      | Faulted ID:<br>VBUS PrivID of faulting requestor. This field is valid only if LE is zero.                                                                                                                                                                                                                                           | R    | 0x00   |
| 7:6   | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                  | R    | 0x0    |
| 5:0   | ATYP       | Access type<br><br>Read 0x1: Invalid user program fetch.<br>Read 0x2: Invalid user write<br>Read 0x4: Invalid user read<br>Read 0x8: Invalid supervisor program fetch<br>Read 0x10: Invalid supervisor read<br>Read 0x12: Invalid cache line writeback<br>Read 0x20: Invalid supervisor write<br>Read 0x3F: Invalid cache line fill | R    | 0x00   |

**Table 5-172. Register Call Summary for Register L1PMPFSR**

IVA2.2 Subsystem Basic Programming Model

- [Internal Memory: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[1\]](#)

**Table 5-173. L1PMPFCR**

|                         |                         |                         |                 |                 |               |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 A408             | <b>Physical address</b> | 0x0184 A408     | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Description</b>      | PMC                     |                         |                 |                 |               |
| <b>Type</b>             | W                       |                         |                 |                 |               |
| 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 |                 |               |
|                         |                         |                         |                 | Reserved        | MPFCLR        |

| Bits | Field Name | Description                                                | Type | Reset      |
|------|------------|------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Write Os for future compatibility. Read returns 0.         | W    | 0x00000000 |
| 0    | MPFCLR     | Write 0: No effect Write 1: Clear fault logged information | W    | 0          |

**Table 5-174. Register Call Summary for Register L1PMPFCR**

IVA2.2 Subsystem Basic Programming Model

- [Internal Memory: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [XMC Register Mapping Summary: \[1\]](#)

**Table 5-175. L1PMPPAk**

|                         |                                                                               |                         |                       |                 |                   |
|-------------------------|-------------------------------------------------------------------------------|-------------------------|-----------------------|-----------------|-------------------|
| <b>Address Offset</b>   | 0x0000 A600 + (0x4*k)                                                         | <b>Physical address</b> | 0x0184 A600 + (0x4*k) | <b>Instance</b> | IVA2.2 GEMXMC     |
| <b>Description</b>      | L1P Memory Protection Attribute Register Addresses for the 16MB page number i |                         |                       |                 |                   |
| <b>Type</b>             | RW                                                                            |                         |                       |                 |                   |
| 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       |                 |                   |
|                         |                                                                               |                         |                       | Reserved        | SR SW SX UR UW UX |

| Bits  | Field Name | Description                                                              | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write Os for future compatibility. Read returns 0.                       | RW   | 0x0000 |
| 15    | AID5       | 0: ID 5 does not have access permission<br>1: ID 5 has access permission | RW   | 1      |
| 14    | AID4       | 0: ID 4 does not have access permission<br>1: ID 4 has access permission | RW   | 1      |
| 13    | AID3       | 0: ID 3 does not have access permission<br>1: ID 3 has access permission | RW   | 1      |
| 12    | AID2       | 0: ID 2 does not have access permission<br>1: ID 2 has access permission | RW   | 1      |
| 11    | AID1       | 0: ID 1 does not have access permission<br>1: ID 1 has access permission | RW   | 1      |

## IVA2.2 Subsystem Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------|------|-------|
| 10   | AID0       | 0: ID 0 does not have access permission<br>1: ID 0 has access permission                   | RW   | 1     |
| 9    | AIDX       | 0: External access is not permitted<br>1: External access is permitted                     | RW   | 1     |
| 8    | LOCAL      | 0: DSP megamodule access is not permitted<br>1: DSP megamodule access is permitted         | RW   | 1     |
| 7:6  | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                      | RW   | 0     |
| 5    | SR         | 0: Supervisor Read access is not permitted<br>1: Supervisor Read access is permitted       | RW   | 1     |
| 4    | SW         | 0: Supervisor Write access is not permitted<br>1: Supervisor Write access is permitted     | RW   | 1     |
| 3    | SX         | 0: Supervisor eXecute access is not permitted<br>1: Supervisor eXecute access is permitted | RW   | 1     |
| 2    | UR         | 0: User Read access is not permitted<br>1: User Read access is permitted                   | RW   | 1     |
| 1    | UW         | 0: User Write access is not permitted<br>1: User Write access is permitted                 | RW   | 1     |
| 0    | UX         | 0: User eXecute access is not permitted<br>1: User eXecute access is permitted             | RW   | 1     |

**Table 5-176. Register Call Summary for Register L1PMPPAk**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0] [1] [2] [3] [4]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [5]

**Table 5-177. L1DMMPFAR**

|                         |                                              |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset          | 0x0000 AC00                                  |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| Physical address        | 0x0184 AC00                                  |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| Description             | L1D Memory Protection Fault Address Register |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| Type                    | R                                            |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description   | Type | Reset      |
|------|------------|---------------|------|------------|
| 31:0 | ADDR       | Fault Address | R    | 0x00000000 |

**Table 5-178. Register Call Summary for Register L1DMMPFAR**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-179. L1DMPFSR**

|                         |                                             |                         |                 |                 |               |
|-------------------------|---------------------------------------------|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 AC04                                 | <b>Physical address</b> | 0x0184 AC04     | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Description</b>      | L1D Memory Protection Fault Status Register |                         |                 |                 |               |
| <b>Type</b>             | R                                           |                         |                 |                 |               |
| 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 |                 |               |
| Reserved                |                                             | FLTID                   | Reserved        | ATYP            |               |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                     | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                              | R    | 0x0000 |
| 15:8  | FLTID      | Faulted ID:<br>VBUS PrivID of faulting requestor. This field is valid only if LE is zero.                                                                                                                                                                                                                                       | R    | 0x00   |
| 7:6   | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                              | R    | 0x0    |
| 5:0   | ATYP       | Access type<br>Read 0x1: Invalid user program fetch.<br>Read 0x2: Invalid user write<br>Read 0x4: Invalid user read<br>Read 0x8: Invalid supervisor program fetch<br>Read 0x10: Invalid supervisor read<br>Read 0x12: Invalid cache line writeback<br>Read 0x20: Invalid supervisor write<br>Read 0x3F: Invalid cache line fill | R    | 0x0    |

**Table 5-180. Register Call Summary for Register L1DMPFSR**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-181. L1DMPFCR**

|                         |                                              |                         |                 |                 |               |
|-------------------------|----------------------------------------------|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 AC08                                  | <b>Physical address</b> | 0x0184 AC08     | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Description</b>      | L1D Memory Protection Fault Command Register |                         |                 |                 |               |
| <b>Type</b>             | W                                            |                         |                 |                 |               |
| 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 |                 |               |
| Reserved                |                                              |                         | MPFCLR          |                 |               |

| Bits | Field Name | Description                                                   | Type | Reset      |
|------|------------|---------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.         | W    | 0x00000000 |
| 0    | MPFCLR     | Write 0: No effect<br>Write 1: Clear fault logged information | W    | 0          |

**Table 5-182. Register Call Summary for Register L1DMPPFCR**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [1]

**Table 5-183. L1DMPPAk**

|                       |                                                                               |                         |                       |                 |               |
|-----------------------|-------------------------------------------------------------------------------|-------------------------|-----------------------|-----------------|---------------|
| <b>Address Offset</b> | 0x0000 AE00 + (0x4*k)                                                         | <b>Physical address</b> | 0x0184 AE00 + (0x4*k) | <b>Instance</b> | IVA2.2 GEMXMC |
| <b>Description</b>    | L1D Memory Protection Attribute Register Addresses for the 16MB page number i |                         |                       |                 |               |
| <b>Type</b>           | RW                                                                            |                         |                       |                 |               |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|------|------|------|-------|----------|----|----|----------|----|----|----------|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | AID5 | AID4 | AID3 | AID2 | AID1 | AID0 | AIDX | LOCAL | Reserved | SR | SW | Reserved | UR | UW | Reserved |   |

| Bits  | Field Name | Description                                                                            | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility. Read returns 0.                                     | RW   | 0x0000 |
| 15    | AID5       | 0: ID 5 does not have access permission<br>1: ID 5 has access permission               | RW   | 1      |
| 14    | AID4       | 0: ID 4 does not have access permission<br>1: ID 4 has access permission               | RW   | 1      |
| 13    | AID3       | 0: ID 3 does not have access permission<br>1: ID 3 has access permission               | RW   | 1      |
| 12    | AID2       | 0: ID 2 does not have access permission<br>1: ID 2 has access permission               | RW   | 1      |
| 11    | AID1       | 0: ID 1 does not have access permission<br>1: ID 1 has access permission               | RW   | 1      |
| 10    | AID0       | 0: ID 0 does not have access permission<br>1: ID 0 has access permission               | RW   | 1      |
| 9     | AIDX       | 0: External access is not permitted<br>1: External access is permitted                 | RW   | 1      |
| 8     | LOCAL      | 0: DSP megamodule access is not permitted<br>1: DSP megamodule access is permitted     | RW   | 1      |
| 7:6   | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                  | RW   | 0      |
| 5     | SR         | 0: Supervisor Read access is not permitted<br>1: Supervisor Read access is permitted   | RW   | 1      |
| 4     | SW         | 0: Supervisor Write access is not permitted<br>1: Supervisor Write access is permitted | RW   | 1      |
| 3     | Reserved   | Write 0s for future compatibility. Read returns 0.                                     | RW   | 0      |
| 2     | UR         | 0: User Read access is not permitted<br>1: User Read access is permitted               | RW   | 1      |
| 1     | UW         | 0: User Write access is not permitted<br>1: User Write access is permitted             | RW   | 1      |
| 0     | Reserved   | Write 0s for future compatibility. Read returns 0.                                     | RW   | 0      |

**Table 5-184. Register Call Summary for Register L1DMPPAk**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0] [1] [2] [3] [4] [5]

IVA2.2 Subsystem Register Manual

- XMC Register Mapping Summary: [6]

## 5.5.5 TPCC Registers

This section provides information about the TPCC module. Each register in the module is described separately below.

### 5.5.5.1 TPCC Register Mapping Summary

**Table 5-185. TPCC Register Summary**

| Register Name               | Type | Register Width (Bits) | Address Offset   | Physical Address      |
|-----------------------------|------|-----------------------|------------------|-----------------------|
| TPCC_PID                    | R    | 32                    | 0x0000           | 0x01C0 0000           |
| TPCC_CCCFG                  | R    | 32                    | 0x0004           | 0x01C0 0004           |
| TPCC_DCHMAPi <sup>(1)</sup> | RW   | 32                    | 0x0100 + (0x4*i) | 0x01C0 0100 + (0x4*i) |
| TPCC_QCHMAPj <sup>(2)</sup> | RW   | 32                    | 0x0200 + (0x4*j) | 0x01C0 0200 + (0x4*j) |
| TPCC_DMAQNUM0               | RW   | 32                    | 0x0240           | 0x01C0 0240           |
| TPCC_DMAQNUM1               | RW   | 32                    | 0x0244           | 0x01C0 0244           |
| TPCC_DMAQNUM2               | RW   | 32                    | 0x0248           | 0x01C0 0248           |
| TPCC_DMAQNUM3               | RW   | 32                    | 0x024C           | 0x01C0 024C           |
| TPCC_DMAQNUM4               | RW   | 32                    | 0x0250           | 0x01C0 0250           |
| TPCC_DMAQNUM5               | RW   | 32                    | 0x0254           | 0x01C0 0254           |
| TPCC_DMAQNUM6               | RW   | 32                    | 0x0258           | 0x01C0 0258           |
| TPCC_DMAQNUM7               | RW   | 32                    | 0x025C           | 0x01C0 025C           |
| TPCC_QDMAQNUM               | RW   | 32                    | 0x0260           | 0x01C0 0260           |
| TPCC_QUETCMAP               | RW   | 32                    | 0x0280           | 0x01C0 0280           |
| TPCC_QUEPRI                 | RW   | 32                    | 0x0284           | 0x01C0 0284           |
| TPCC_EMR                    | R    | 32                    | 0x0300           | 0x01C0 0300           |
| TPCC_EMRH                   | R    | 32                    | 0x0304           | 0x01C0 0304           |
| TPCC_EMCR                   | W    | 32                    | 0x0308           | 0x01C0 0308           |
| TPCC_EMCRH                  | W    | 32                    | 0x030C           | 0x01C0 030C           |
| TPCC_QEMR                   | R    | 32                    | 0x0310           | 0x01C0 0310           |
| TPCC_QEMCR                  | W    | 32                    | 0x0314           | 0x01C0 0314           |
| TPCC_CCERR                  | R    | 32                    | 0x0318           | 0x01C0 0318           |
| TPCC_CCERRCLR               | W    | 32                    | 0x031C           | 0x01C0 031C           |
| TPCC_EEVAL                  | W    | 32                    | 0x0320           | 0x01C0 0320           |
| TPCC_DRAEj <sup>(2)</sup>   | RW   | 32                    | 0x0340 + (0x8*j) | 0x01C0 0340 + (0x8*j) |
| TPCC_DRAEHj <sup>(2)</sup>  | RW   | 32                    | 0x0344 + (0x8*j) | 0x01C0 0344 + (0x8*j) |
| TPCC_QRAEj <sup>(2)</sup>   | RW   | 32                    | 0x0380 + (0x4*j) | 0x01C0 0380 + (0x4*j) |
| TPCC_Q0Ek <sup>(3)</sup>    | R    | 32                    | 0x0400 + (0x4*k) | 0x01C0 0400 + (0x4*k) |
| TPCC_Q1Ek <sup>(3)</sup>    | R    | 32                    | 0x0440 + (0x4*k) | 0x01C0 0440 + (0x4*k) |
| TPCC_QSTATI <sup>(4)</sup>  | R    | 32                    | 0x0600 + (0x4*l) | 0x01C0 0600 + (0x4*l) |
| TPCC_QWMTHRA                | RW   | 32                    | 0x0620           | 0x01C0 0620           |
| TPCC_QWMTHRIB               | RW   | 32                    | 0x0624           | 0x01C0 0624           |
| TPCC_CCSTAT                 | R    | 32                    | 0x0640           | 0x01C0 0640           |
| TPCC_MP FAR                 | R    | 32                    | 0x0800           | 0x01C0 0800           |
| TPCC_MPFSR                  | R    | 32                    | 0x0804           | 0x01C0 0804           |
| TPCC_MPFCR                  | W    | 32                    | 0x0808           | 0x01C0 0808           |
| TPCC_MPPAG                  | RW   | 32                    | 0x080C           | 0x01C0 080C           |
| TPCC_MPPAj <sup>(2)</sup>   | RW   | 32                    | 0x0810 + (0x4*j) | 0x01C0 0810 + (0x4*j) |

<sup>(1)</sup> i = 0 to 63

<sup>(2)</sup> j = 0 to 7

<sup>(3)</sup> k = 0 to 15

<sup>(4)</sup> l = 0 to 1

**Table 5-185. TPCC Register Summary (continued)**

| Register Name                | Type | Register Width (Bits) | Address Offset     | Physical Address        |
|------------------------------|------|-----------------------|--------------------|-------------------------|
| TPCC_ER                      | R    | 32                    | 0x1000             | 0x01C0 1000             |
| TPCC_ECR                     | W    | 32                    | 0x1008             | 0x01C0 1008             |
| TPCC_ECRH                    | W    | 32                    | 0x100C             | 0x01C0 100C             |
| TPCC_ESR                     | W    | 32                    | 0x1010             | 0x01C0 1010             |
| TPCC_ESRH                    | W    | 32                    | 0x1014             | 0x01C0 1014             |
| TPCC_CER                     | R    | 32                    | 0x1018             | 0x01C0 1018             |
| TPCC_CERH                    | R    | 32                    | 0x101C             | 0x01C0 101C             |
| TPCC_EER                     | R    | 32                    | 0x1020             | 0x01C0 1020             |
| TPCC_EECR                    | W    | 32                    | 0x1028             | 0x01C0 1028             |
| TPCC_EESR                    | W    | 32                    | 0x1030             | 0x01C0 1030             |
| TPCC_SER                     | R    | 32                    | 0x1038             | 0x01C0 1038             |
| TPCC_SERH                    | R    | 32                    | 0x103C             | 0x01C0 103C             |
| TPCC_SECR                    | W    | 32                    | 0x1040             | 0x01C0 1040             |
| TPCC_SECRH                   | W    | 32                    | 0x1044             | 0x01C0 1044             |
| TPCC_IER                     | R    | 32                    | 0x1050             | 0x01C0 1050             |
| TPCC_IERH                    | R    | 32                    | 0x1054             | 0x01C0 1054             |
| TPCC_ICR                     | W    | 32                    | 0x1058             | 0x01C0 1058             |
| TPCC_ICRH                    | W    | 32                    | 0x105C             | 0x01C0 105C             |
| TPCC_IERS                    | W    | 32                    | 0x1060             | 0x01C0 1060             |
| TPCC_IERSH                   | W    | 32                    | 0x1064             | 0x01C0 1064             |
| TPCC_IPR                     | R    | 32                    | 0x1068             | 0x01C0 1068             |
| TPCC_IPRH                    | R    | 32                    | 0x106C             | 0x01C0 106C             |
| TPCC_ICR                     | W    | 32                    | 0x1070             | 0x01C0 1070             |
| TPCC_ICRH                    | W    | 32                    | 0x1074             | 0x01C0 1074             |
| TPCC_IEval                   | W    | 32                    | 0x1078             | 0x01C0 1078             |
| TPCC_QER                     | R    | 32                    | 0x1080             | 0x01C0 1080             |
| TPCC_QEER                    | R    | 32                    | 0x1084             | 0x01C0 1084             |
| TPCC_QEECR                   | W    | 32                    | 0x1088             | 0x01C0 1088             |
| TPCC_QEESR                   | W    | 32                    | 0x108C             | 0x01C0 108C             |
| TPCC_QSER                    | R    | 32                    | 0x1090             | 0x01C0 1090             |
| TPCC_QSECR                   | W    | 32                    | 0x1094             | 0x01C0 1094             |
| TPCC_ER_Rn <sup>(5)</sup>    | R    | 32                    | 0x2000 + (0x200*n) | 0x01C0 2000 + (0x200*n) |
| TPCC_ECR_Rn <sup>(5)</sup>   | W    | 32                    | 0x2008 + (0x200*n) | 0x01C0 2008 + (0x200*n) |
| TPCC_ECRH_Rn <sup>(5)</sup>  | W    | 32                    | 0x200C + (0x200*n) | 0x01C0 200C + (0x200*n) |
| TPCC_ESR_Rn <sup>(5)</sup>   | W    | 32                    | 0x2010 + (0x200*n) | 0x01C0 2010 + (0x200*n) |
| TPCC_ESRH_Rn <sup>(5)</sup>  | W    | 32                    | 0x2014 + (0x200*n) | 0x01C0 2014 + (0x200*n) |
| TPCC_CER_Rn <sup>(5)</sup>   | R    | 32                    | 0x2018 + (0x200*n) | 0x01C0 2018 + (0x200*n) |
| TPCC_CERH_Rn <sup>(5)</sup>  | R    | 32                    | 0x201C + (0x200*n) | 0x01C0 201C + (0x200*n) |
| TPCC_EER_Rn <sup>(5)</sup>   | R    | 32                    | 0x2020 + (0x200*n) | 0x01C0 2020 + (0x200*n) |
| TPCC_EECR_Rn <sup>(5)</sup>  | W    | 32                    | 0x2028 + (0x200*n) | 0x01C0 2028 + (0x200*n) |
| TPCC_EESR_Rn <sup>(5)</sup>  | W    | 32                    | 0x2030 + (0x200*n) | 0x01C0 2030 + (0x200*n) |
| TPCC_SER_Rn <sup>(5)</sup>   | R    | 32                    | 0x2038 + (0x200*n) | 0x01C0 2038 + (0x200*n) |
| TPCC_SERH_Rn <sup>(5)</sup>  | R    | 32                    | 0x203C + (0x200*n) | 0x01C0 203C + (0x200*n) |
| TPCC_SECR_Rn <sup>(5)</sup>  | W    | 32                    | 0x2040 + (0x200*n) | 0x01C0 2040 + (0x200*n) |
| TPCC_SECRH_Rn <sup>(5)</sup> | W    | 32                    | 0x2044 + (0x200*n) | 0x01C0 2044 + (0x200*n) |
| TPCC_IER_Rn <sup>(5)</sup>   | R    | 32                    | 0x2050 + (0x200*n) | 0x01C0 2050 + (0x200*n) |

<sup>(5)</sup> n = 0 to 7

**Table 5-185. TPCC Register Summary (continued)**

| Register Name                 | Type | Register Width (Bits) | Address Offset     | Physical Address        |
|-------------------------------|------|-----------------------|--------------------|-------------------------|
| TPCC_IERH_Rn <sup>(5)</sup>   | R    | 32                    | 0x2054 + (0x200*n) | 0x01C0 2054 + (0x200*n) |
| TPCC_IECR_Rn <sup>(5)</sup>   | W    | 32                    | 0x2058 + (0x200*n) | 0x01C0 2058 + (0x200*n) |
| TPCC_IECRH_Rn <sup>(5)</sup>  | W    | 32                    | 0x205C + (0x200*n) | 0x01C0 205C + (0x200*n) |
| TPCC_IESR_Rn <sup>(5)</sup>   | W    | 32                    | 0x2060 + (0x200*n) | 0x01C0 2060 + (0x200*n) |
| TPCC_IERSH_Rn <sup>(5)</sup>  | W    | 32                    | 0x2064 + (0x200*n) | 0x01C0 2064 + (0x200*n) |
| TPCC_IPR_Rn <sup>(5)</sup>    | R    | 32                    | 0x2068 + (0x200*n) | 0x01C0 2068 + (0x200*n) |
| TPCC_IPRH_Rn <sup>(5)</sup>   | R    | 32                    | 0x206C + (0x200*n) | 0x01C0 206C + (0x200*n) |
| TPCC_ICR_Rn <sup>(5)</sup>    | W    | 32                    | 0x2070 + (0x200*n) | 0x01C0 2070 + (0x200*n) |
| TPCC_ICRH_Rn <sup>(5)</sup>   | W    | 32                    | 0x2074 + (0x200*n) | 0x01C0 2074 + (0x200*n) |
| TPCC_IINVAL_Rn <sup>(5)</sup> | W    | 32                    | 0x2078 + (0x200*n) | 0x01C0 2078 + (0x200*n) |
| TPCC_QER_Rn <sup>(5)</sup>    | R    | 32                    | 0x2080 + (0x200*n) | 0x01C0 2080 + (0x200*n) |
| TPCC_QEER_Rn <sup>(5)</sup>   | R    | 32                    | 0x2084 + (0x200*n) | 0x01C0 2084 + (0x200*n) |
| TPCC_QEECR_Rn <sup>(5)</sup>  | W    | 32                    | 0x2088 + (0x200*n) | 0x01C0 2088 + (0x200*n) |
| TPCC_QEESR_Rn <sup>(5)</sup>  | W    | 32                    | 0x208C + (0x200*n) | 0x01C0 208C + (0x200*n) |
| TPCC_QSER_Rn <sup>(6)</sup>   | R    | 32                    | 0x2090 + (0x200*n) | 0x01C0 2090 + (0x200*n) |
| TPCC_QSECR_Rn <sup>(6)</sup>  | W    | 32                    | 0x2094 + (0x200*n) | 0x01C0 2094 + (0x200*n) |
| TPCC_OPTm <sup>(7)</sup>      | RW   | 32                    | 0x4000 + (0x20*m)  | 0x01C0 4000 + (0x20*m)  |
| TPCC_SRCm <sup>(7)</sup>      | RW   | 32                    | 0x4004 + (0x20*m)  | 0x01C0 4004 + (0x20*m)  |
| TPCC_ABCNTm <sup>(7)</sup>    | RW   | 32                    | 0x4008 + (0x20*m)  | 0x01C0 4008 + (0x20*m)  |
| TPCC_DSTm <sup>(7)</sup>      | RW   | 32                    | 0x400C + (0x20*m)  | 0x01C0 400C + (0x20*m)  |
| TPCC_BIDXm <sup>(7)</sup>     | RW   | 32                    | 0x4010 + (0x20*m)  | 0x01C0 4010 + (0x20*m)  |
| TPCC_LNKm <sup>(7)</sup>      | RW   | 32                    | 0x4014 + (0x20*m)  | 0x01C0 4014 + (0x20*m)  |
| TPCC_CIDXm <sup>(7)</sup>     | RW   | 32                    | 0x4018 + (0x20*m)  | 0x01C0 4018 + (0x20*m)  |
| TPCC_CCNTm <sup>(7)</sup>     | RW   | 32                    | 0x401C + (0x20*m)  | 0x01C0 401C + (0x20*m)  |

<sup>(6)</sup> n = 0 to 7

<sup>(7)</sup> m = 0 to 127

### 5.5.5.2 TPCC Register Descriptions

**Table 5-186. TPCC\_PID**

|                |                        |                  |             |          |              |
|----------------|------------------------|------------------|-------------|----------|--------------|
| Address Offset | 0x0000                 | Physical address | 0x01C0 0000 | Instance | I/VA2.2 TPCC |
| Description    | Peripheral ID Register | Type             | R           |          |              |

| 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 |  |
|--------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|-----|----|-------|----|--------|---|-------|---|---|---|---|---|---|---|--|
| SCHEME | RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FUNC |    | RTL |    | MAJOR |    | CUSTOM |   | MINOR |   |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                                                                                                                                                    | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | SCHEME     | PID scheme:<br>Used to distinguish between old ID scheme and current.<br>Spare bit to encode future schemes EDMA uses new scheme, indicated with value of 0x1. | R    | 0x1   |
| 29:28 | Reserved   | Read returns 0.                                                                                                                                                | R    | 0x0   |

| Bits  | Field Name | Description                                              | Type | Reset |
|-------|------------|----------------------------------------------------------|------|-------|
| 27:16 | FUNC       | Function indicates a software-compatible module family.  | R    | 0x001 |
| 15:11 | RTL        | RTL version                                              | R    | 0x--  |
| 10:8  | MAJOR      | Major revision                                           | R    | 0x3   |
| 7:6   | CUSTOM     | Custom revision field: Not used on this version of EDMA. | R    | 0x0   |
| 5:0   | MINOR      | Minor revision                                           | R    | 0x--  |

**Table 5-187. Register Call Summary for Register TPCC\_PID**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-188. TPCC\_CCCFG**

|                  |                           |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |             |
|------------------|---------------------------|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|-------------|
| Address Offset   | 0x0004                    |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |             |
| Physical address | 0x01C0 0004               |  |  |  |  |  |  |  |  |  | Instance |  |  |  |  |  |  |  |  |  | IVA2.2 TPCC |
| Description      | CC Configuration Register |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |             |
| Type             | R                         |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |             |

|          |    |    |    |    |         |            |          |         |          |       |          |            |          |          |          |           |          |          |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|---------|------------|----------|---------|----------|-------|----------|------------|----------|----------|----------|-----------|----------|----------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    | MPEXIST | CHMAPEXIST | Reserved | NUMREGN | Reserved | NUMTC | Reserved | NUMPAENTRY | Reserved | NUMINTCH | Reserved | NUMQDMACH | Reserved | NUMDMACH |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                        | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:26 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                    | R    | 0x00  |
| 25    | MPEXIST    | Memory Protection Existence<br>MPEXIST = 0: No memory protection.<br>MPEXIST = 1: Memory Protection logic included.                                                                                                                                                                | R    | 1     |
| 24    | CHMAPEXIST | Channel Mapping Existence<br>CHMAPEXIST = 0: No Channel mapping.<br>CHMAPEXIST = 1: Channel mapping logic included.                                                                                                                                                                | R    | 1     |
| 23:22 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                    | R    | 0x0   |
| 21:20 | NUMREGN    | Number of MP and Shadow regions<br><br>Read 0x0: 0 Regions<br>Read 0x1: 2 Regions<br>Read 0x2: 4 Regions<br>Read 0x3: 8 Regions                                                                                                                                                    | R    | 0x3   |
| 19    | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                    | R    | 0     |
| 18:16 | NUMTC      | Number of Queues/Number of TCs<br><br>Read 0x0: 1 TC/Event Queue<br>Read 0x1: 2 TC/Event Queue<br>Read 0x2: 3 TC/Event Queue<br>Read 0x3: 4 TC/Event Queue<br>Read 0x4: 5 TC/Event Queue<br>Read 0x5: 6 TC/Event Queue<br>Read 0x6: 7 TC/Event Queue<br>Read 0x7: 8 TC/Event Queue | R    | 0x1   |
| 15    | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                    | R    | 0     |
| 14:12 | NUMPAENTRY | Number of PaRAM entries<br><br>Read 0x0: 16 entries<br>Read 0x1: 32 entries (unsupported setting)<br>Read 0x2: 64 entries                                                                                                                                                          | R    | 0x3   |

| Bits | Field Name | Description                                                                                                                                                                                        | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | Read 0x3: 128 entries<br>Read 0x4: 256 entries<br>Read 0x5: 512 entries                                                                                                                            |      |       |
| 11   | Reserved   | Read returns 0.                                                                                                                                                                                    | R    | 0     |
| 10:8 | NUMINTCH   | Number of Interrupt Channels<br>Read 0x1: 8 Interrupt channels<br>Read 0x2: 16 Interrupt channels<br>Read 0x3: 32 Interrupt channels<br>Read 0x4: 64 Interrupt channels                            | R    | 0x4   |
| 7    | Reserved   | Read returns 0.                                                                                                                                                                                    | R    | 0     |
| 6:4  | NUMQDMACH  | Number of QDMA Channels<br>Read 0x0: No QDMA Channels<br>Read 0x1: 2 QDMA Channels<br>Read 0x2: 4 QDMA Channels<br>Read 0x3: 6 QDMA Channels<br>Read 0x4: 8 QDMA Channels                          | R    | 0x2   |
| 3    | Reserved   | Read returns 0.                                                                                                                                                                                    | R    | 0     |
| 2:0  | NUMDMACH   | Number of DMA Channels<br>Read 0x0: No DMA Channels<br>Read 0x1: 4 DMA Channels<br>Read 0x2: 8 DMA Channels<br>Read 0x3: 16 DMA Channels<br>Read 0x4: 32 DMA Channels<br>Read 0x5: 64 DMA Channels | R    | 0x5   |

**Table 5-189. Register Call Summary for Register TPCC\_CCCFG**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-190. TPCC\_DCHMAPi**

|                         |                                |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------|--|--|--|-----------------|-------------|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0100 + (0x4*i)               |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 0100 + (0x4*i)          |  |  |  | <b>Instance</b> | IVA2.2 TPCC |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | DMA Channel i Mapping Register |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                             |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    | PAENTRY |    |    |    |    |    |    |    |    |    | Reserved |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                           | Type | Reset   |
|-------|------------|-------------------------------------------------------|------|---------|
| 31:14 | Reserved   | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0x00000 |
| 13:5  | PAENTRY    | PaRAM Entry number for DMA Channel i.                 | RW   | 0x000   |
| 4:0   | Reserved   | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0x00    |

**Table 5-191. Register Call Summary for Register TPCC\_DCHMAPi**

IVA2.2 Subsystem Functional Description

- EDMA: [0] [1]

IVA2.2 Subsystem Basic Programming Model

- Starting the Transfer: [2] [3] [4]

**Table 5-191. Register Call Summary for Register TPCC\_DCHMAPi (continued)**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[5\]](#)

**Table 5-192. TPCC\_QCHMAPj**

|                         |                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0200 + (0x4*j)                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 0200 + (0x4*j)           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | QDMA Channel i Mapping Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |        |    |   |   |          |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|--------|----|---|---|----------|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PAENTRY |    |    |    | TRWORD |    |   |   | Reserved |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                             | Type | Reset   |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                   | RW   | 0x00000 |
| 13:5  | PAENTRY    | PaRAM Entry number for QDMA Channel i.                                                                                                                  | RW   | 0x000   |
| 4:2   | TRWORD     | TRWORD points to the specific trigger word of the PaRAM Entry defined by PAENTRY. A write to the trigger word results in a QDMA Event being recognized. | RW   | 0x0     |
| 1:0   | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                   | RW   | 0x0     |

**Table 5-193. Register Call Summary for Register TPCC\_QCHMAPj**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\] \[1\] \[2\] \[3\] \[4\]](#)

IVA2.2 Subsystem Basic Programming Model

- [Starting the Transfer: \[5\] \[6\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[7\]](#)

**Table 5-194. TPCC\_DMAQNUM0**

|                         |                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0240                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 0240                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | DMA Queue Number Register 0<br>Contains the Event queue number to be used for the corresponding DMA Channel. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved | E7 | Reserved | E6 | Reserved | E5 | Reserved | E4 | Reserved | E3 | Reserved | E2 | Reserved | E1 | Reserved | E0 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                           | Type | Reset |
|-------|------------|-------------------------------------------------------|------|-------|
| 31    | Reserved   | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0     |
| 30:28 | E7         | DMA Queue Number for event #7                         | RW   | 0x0   |
| 0x0:  |            | Event En is queued on Q0                              |      |       |

| Bits  | Field Name | Description                                                                                                                              | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|       |            | 0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2                                                                       |      |       |
| 27    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                    | RW   | 0     |
| 26:24 | E6         | DMA Queue Number for event #6<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 23    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                    | RW   | 0     |
| 22:20 | E5         | DMA Queue Number for event #5<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 19    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                    | RW   | 0     |
| 18:16 | E4         | DMA Queue Number for event #4<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 15    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                    | RW   | 0     |
| 14:12 | E3         | DMA Queue Number for event #3<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 11    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                    | RW   | 0     |
| 10:8  | E2         | DMA Queue Number for event #2<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 7     | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                    | RW   | 0     |
| 6:4   | E1         | DMA Queue Number for event #1<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 3     | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                    | RW   | 0     |
| 2:0   | E0         | DMA Queue Number for event #0<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |

**Table 5-195. Register Call Summary for Register TPCC\_DMAQNUM0**

IVA2.2 Subsystem Basic Programming Model

- [Prioritizing Defined Transfers: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[1\]](#)

**Table 5-196. TPCC\_DMAQNUM1**

|                         |                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0244                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 0244                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | DMA Queue Number Register 1<br>Contains the Event queue number to be used for the corresponding DMA Channel. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|----|-----|----------|----|-----|----------|----|-----|----------|-----|----------|----|-----|----------|-----|----------|----|----|----------|----|----|---|---|---|---|---|---|---|---|---|---|
| Reserved |    | E15 | Reserved |    | E14 | Reserved |    | E13 | Reserved | E12 | Reserved |    | E11 | Reserved | E10 | Reserved |    | E9 | Reserved |    | E8 |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                               | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 30:28 | E15        | DMA Queue Number for event #15<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 27    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 26:24 | E14        | DMA Queue Number for event #14<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 23    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 22:20 | E13        | DMA Queue Number for event #13<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 19    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 18:16 | E12        | DMA Queue Number for event #12<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 15    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 14:12 | E11        | DMA Queue Number for event #11<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 11    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 10:8  | E10        | DMA Queue Number for event #10<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 7     | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 6:4   | E9         | DMA Queue Number for event #9                                                                                                             | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                          | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2                                  |      |       |
| 3    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                | RW   | 0     |
| 2:0  | E8         | DMA Queue Number for event #8<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |

**Table 5-197. Register Call Summary for Register TPCC\_DMAQNUM1**

IVA2.2 Subsystem Basic Programming Model

- [Prioritizing Defined Transfers: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[1\]](#)

**Table 5-198. TPCC\_DMAQNUM2**

| Address Offset |    | 0x0248                                                                                                       | Physical address |    | 0x01C0 0248 | Instance |    | IVA2.2 TPCC |          |    |     |          |    |     |          |    |     |          |    |     |          |   |     |   |   |   |   |   |   |   |   |  |  |
|----------------|----|--------------------------------------------------------------------------------------------------------------|------------------|----|-------------|----------|----|-------------|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|---|-----|---|---|---|---|---|---|---|---|--|--|
| Description    |    | DMA Queue Number Register 2<br>Contains the Event queue number to be used for the corresponding DMA Channel. |                  |    |             |          |    |             |          |    |     |          |    |     |          |    |     |          |    |     |          |   |     |   |   |   |   |   |   |   |   |  |  |
| Type           |    | RW                                                                                                           |                  |    |             |          |    |             |          |    |     |          |    |     |          |    |     |          |    |     |          |   |     |   |   |   |   |   |   |   |   |  |  |
| 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 |  |  |
| Reserved       |    | E23                                                                                                          | Reserved         |    | E22         | Reserved |    | E21         | Reserved |    | E20 | Reserved |    | E19 | Reserved |    | E18 | Reserved |    | E17 | Reserved |   | E16 |   |   |   |   |   |   |   |   |  |  |

| Bits  | Field Name | Description                                                                                                                           | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW   | 0     |
| 30:28 | E23        | DMA Queue Number for event #23<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 27    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW   | 0     |
| 26:24 | E22        | DMA Queue Number for event #22<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 23    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW   | 0     |
| 22:20 | E21        | DMA Queue Number for event #21<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 19    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW   | 0     |
| 18:16 | E20        | DMA Queue Number for event #20                                                                                                        | RW   | 0x0   |

## IVA2.2 Subsystem Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|       |            | 0x0:<br>Event En is queued on Q0<br>0x1:<br>Event En is queued on Q1<br>Others:Not applicable for IVA2.2                                   |      |       |
| 15    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                      | RW   | 0     |
| 14:12 | E19        | DMA Queue Number for event #19<br>0x0:<br>Event En is queued on Q0<br>0x1:<br>Event En is queued on Q1<br>Others:Not applicable for IVA2.2 | RW   | 0x0   |
| 11    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                      | RW   | 0     |
| 10:8  | E18        | DMA Queue Number for event #18<br>0x0:<br>Event En is queued on Q0<br>0x1:<br>Event En is queued on Q1<br>Others:Not applicable for IVA2.2 | RW   | 0x0   |
| 7     | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                      | RW   | 0     |
| 6:4   | E17        | DMA Queue Number for event #17<br>0x0:<br>Event En is queued on Q0<br>0x1:<br>Event En is queued on Q1<br>Others:Not applicable for IVA2.2 | RW   | 0x0   |
| 3     | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                      | RW   | 0     |
| 2:0   | E16        | DMA Queue Number for event #16<br>0x0:<br>Event En is queued on Q0<br>0x1:<br>Event En is queued on Q1<br>Others:Not applicable for IVA2.2 | RW   | 0x0   |

**Table 5-199. Register Call Summary for Register TPCC\_DMAQNUM2**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-200. TPCC\_DMAQNUM3**

|                  |                                                                                                              |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x024C                                                                                                       |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |
| Physical address | 0x01C0 024C                                                                                                  |  |  |  |  |  |  |  |  |  | Instance |  |  |  |  |  |  |  |  |  |  |  |
| Description      | DMA Queue Number Register 3<br>Contains the Event queue number to be used for the corresponding DMA Channel. |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |
| Type             | RW                                                                                                           |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |

|          |     |    |          |     |    |          |     |    |          |     |    |          |     |    |          |     |    |          |     |    |          |     |   |   |   |   |   |   |   |   |   |
|----------|-----|----|----------|-----|----|----------|-----|----|----------|-----|----|----------|-----|----|----------|-----|----|----------|-----|----|----------|-----|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved | E31 |    | Reserved | E30 |    | Reserved | E29 |    | Reserved | E28 |    | Reserved | E27 |    | Reserved | E26 |    | Reserved | E25 |    | Reserved | E24 |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                            | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------|------|-------|
| 31    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                  | RW   | 0     |
| 30:28 | E31        | DMA Queue Number for event #31<br>0x0:<br>Event En is queued on Q0<br>0x1:<br>Event En is queued on Q1 | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
|             |                   | Others: Not applicable for IVA2.2                                                                                                         |             |              |
| 27          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 26:24       | E30               | DMA Queue Number for event #30<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 23          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 22:20       | E29               | DMA Queue Number for event #29<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 19          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 18:16       | E28               | DMA Queue Number for event #28<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 15          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 14:12       | E27               | DMA Queue Number for event #27<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 11          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 10:8        | E26               | DMA Queue Number for event #26<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 7           | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 6:4         | E25               | DMA Queue Number for event #25<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 3           | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 2:0         | E24               | DMA Queue Number for event #24<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |

**Table 5-201. Register Call Summary for Register TPCC\_DMAQNUM3**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-202. TPCC\_DMAQNUM4**

| Address Offset   |  | 0x0250                                                                                                       |  |          |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|--|--------------------------------------------------------------------------------------------------------------|--|----------|--|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Physical address |  | 0x01C0 0250                                                                                                  |  | Instance |  | IVA2.2 TPCC |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      |  | DMA Queue Number Register 4<br>Contains the Event queue number to be used for the corresponding DMA Channel. |  |          |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             |  | RW                                                                                                           |  |          |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|---|-----|----------|---|---|---|---|---|---|---|
| Reserved |    | E39 | Reserved |    | E38 | Reserved |    | E37 | Reserved |    | E36 | Reserved |    | E35 | Reserved |    | E34 | Reserved |    | E33 | Reserved |   | E32 | Reserved |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                               | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 30:28 | E39        | DMA Queue Number for event #39<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 27    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 26:24 | E38        | DMA Queue Number for event #38<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 23    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 22:20 | E37        | DMA Queue Number for event #37<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 19    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 18:16 | E36        | DMA Queue Number for event #36<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 15    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 14:12 | E35        | DMA Queue Number for event #35<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 11    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 10:8  | E34        | DMA Queue Number for event #34<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 7     | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 6:4   | E33        | DMA Queue Number for event #33                                                                                                            | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                           | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2                                   |      |       |
| 3    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW   | 0     |
| 2:0  | E32        | DMA Queue Number for event #32<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |

**Table 5-203. Register Call Summary for Register TPCC\_DMAQNUM4**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-204. TPCC\_DMAQNUM5**

|                         |                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------------|--|--|--|
| <b>Address Offset</b>   | 0x0254                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |
| <b>Physical address</b> | 0x01C0 0254                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | IVA2.2 TPCC |  |  |  |
| <b>Description</b>      | DMA Queue Number Register 5<br>Contains the Event queue number to be used for the corresponding DMA Channel. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |
| <b>Type</b>             | RW                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |

|          |    |     |          |    |     |          |    |     |          |    |     |          |    |     |          |    |     |          |    |     |          |   |     |   |   |   |   |   |   |   |   |
|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|---|-----|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    | E47 | Reserved |    | E46 | Reserved |    | E45 | Reserved |    | E44 | Reserved |    | E43 | Reserved |    | E42 | Reserved |    | E41 | Reserved |   | E40 |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                           | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW   | 0     |
| 30:28 | E47        | DMA Queue Number for event #47<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 27    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW   | 0     |
| 26:24 | E46        | DMA Queue Number for event #46<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 23    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW   | 0     |
| 22:20 | E45        | DMA Queue Number for event #45<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 19    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW   | 0     |
| 18:16 | E44        | DMA Queue Number for event #44<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1                                      | RW   | 0x0   |

## IVA2.2 Subsystem Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                               | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15    | Reserved   | Others: Not applicable for IVA2.2<br>Write 0s for future compatibility.<br>Read returns 0.                                                | RW   | 0     |
| 14:12 | E43        | DMA Queue Number for event #43<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 11    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 10:8  | E42        | DMA Queue Number for event #42<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 7     | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 6:4   | E41        | DMA Queue Number for event #41<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 3     | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 2:0   | E40        | DMA Queue Number for event #40<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |

**Table 5-205. Register Call Summary for Register TPCC\_DMAQNUM5**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-206. TPCC\_DMAQNUM6**

| Address Offset |    | 0x0258                                                                                                       | Physical address |    | 0x01C0 0258 | Instance |    | IVA2.2 TPCC |          |    |     |          |    |     |          |    |     |          |    |     |          |   |     |   |   |   |   |   |   |   |   |
|----------------|----|--------------------------------------------------------------------------------------------------------------|------------------|----|-------------|----------|----|-------------|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|---|-----|---|---|---|---|---|---|---|---|
| Description    |    | DMA Queue Number Register 6<br>Contains the Event queue number to be used for the corresponding DMA Channel. |                  |    |             |          |    |             |          |    |     |          |    |     |          |    |     |          |    |     |          |   |     |   |   |   |   |   |   |   |   |
| Type           |    | RW                                                                                                           |                  |    |             |          |    |             |          |    |     |          |    |     |          |    |     |          |    |     |          |   |     |   |   |   |   |   |   |   |   |
| 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 |
| Reserved       |    | E55                                                                                                          | Reserved         |    | E54         | Reserved |    | E53         | Reserved |    | E52 | Reserved |    | E51 | Reserved |    | E50 | Reserved |    | E49 | Reserved |   | E48 |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                               | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 30:28 | E55        | DMA Queue Number for event #55<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 27          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 26:24       | E54               | DMA Queue Number for event #54<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 23          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 22:20       | E53               | DMA Queue Number for event #53<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 19          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 18:16       | E52               | DMA Queue Number for event #52<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 15          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 14:12       | E51               | DMA Queue Number for event #51<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 11          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 10:8        | E50               | DMA Queue Number for event #50<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 7           | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 6:4         | E49               | DMA Queue Number for event #49<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 3           | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW          | 0            |
| 2:0         | E48               | DMA Queue Number for event #48<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |

**Table 5-207. Register Call Summary for Register TPCC\_DMAQNUM6**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-208. TPCC\_DMAQNUM7**

|                         |                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x025C                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 025C                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | DMA Queue Number Register 7<br>Contains the Event queue number to be used for the corresponding DMA Channel. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|----|-----|----------|---|-----|---|---|---|---|---|---|---|---|
| Reserved |    | E63 | Reserved |    | E62 | Reserved |    | E61 | Reserved |    | E60 | Reserved |    | E59 | Reserved |    | E58 | Reserved |    | E57 | Reserved |   | E56 |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                               | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 30:28 | E63        | DMA Queue Number for event #63<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 27    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 26:24 | E62        | DMA Queue Number for event #62<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 23    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 22:20 | E61        | DMA Queue Number for event #61<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 19    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 18:16 | E60        | DMA Queue Number for event #60<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 15    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 14:12 | E59        | DMA Queue Number for event #59<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 11    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 10:8  | E58        | DMA Queue Number for event #58<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 7     | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 6:4   | E57        | DMA Queue Number for event #57                                                                                                            | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                    | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
|             |                   | 0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2                                   |             |              |
| 3           | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW          | 0            |
| 2:0         | E56               | DMA Queue Number for event #56<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |

**Table 5-209. Register Call Summary for Register TPCC\_DMAQNUM7**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-210. TPCC\_QDMAQNUM**

|                         |                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------------|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0260                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 0260                                                                                                  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | IVA2.2 TPCC |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | QDMA Queue Number Register<br>Contains the Event queue number to be used for the corresponding QDMA Channel. |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |

|          |    |    |          |    |    |          |    |    |          |    |    |          |    |    |          |    |    |          |    |    |          |   |    |   |   |   |   |   |   |   |   |
|----------|----|----|----------|----|----|----------|----|----|----------|----|----|----------|----|----|----------|----|----|----------|----|----|----------|---|----|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    | E7 | Reserved |    | E6 | Reserved |    | E5 | Reserved |    | E4 | Reserved |    | E3 | Reserved |    | E2 | Reserved |    | E1 | Reserved |   | E0 |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                    | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW          | 0            |
| 30:28       | E7                | QDMA Queue Number for event #7<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 27          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW          | 0            |
| 26:24       | E6                | QDMA Queue Number for event #6<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 23          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW          | 0            |
| 22:20       | E5                | QDMA Queue Number for event #5<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW          | 0x0          |
| 19          | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                 | RW          | 0            |
| 18:16       | E4                | QDMA Queue Number for event #4<br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1                                      | RW          | 0x0          |

| Bits  | Field Name | Description                                                                                                                               | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|       |            | Others: Not applicable for IVA2.2                                                                                                         |      |       |
| 15    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 14:12 | E3         | QDMA Queue Number for event #3<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 11    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 10:8  | E2         | QDMA Queue Number for event #2<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 7     | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 6:4   | E1         | QDMA Queue Number for event #1<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |
| 3     | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                     | RW   | 0     |
| 2:0   | E0         | QDMA Queue Number for event #0<br><br>0x0: Event En is queued on Q0<br>0x1: Event En is queued on Q1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |

**Table 5-211. Register Call Summary for Register TPCC\_QDMAQNUM**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-212. TPCC\_QUETCMAP**

|                       |                     |                         |             |                 |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |          |         |   |   |   |   |   |   |   |   |
|-----------------------|---------------------|-------------------------|-------------|-----------------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----------|---------|---|---|---|---|---|---|---|---|
| <b>Address Offset</b> | 0x0280              | <b>Physical address</b> | 0x01C0 0280 | <b>Instance</b> | IVA2.2 TPCC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |          |         |   |   |   |   |   |   |   |   |
| <b>Description</b>    | Queue to TC Mapping |                         |             |                 |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |          |         |   |   |   |   |   |   |   |   |
| <b>Type</b>           | RW                  |                         |             |                 |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |          |         |   |   |   |   |   |   |   |   |
| 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 |
| Reserved              |                     |                         |             |                 |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | TCNUMQ1 |    | Reserved | TCNUMQ0 |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                     | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:7 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                           | RW   | 0x00  |
| 6:4  | TCNUMQ1    | TC Number for Queue 1:<br>Defines the TC number that Event Queue 1 TRs are written to.<br><br>0x0: TRs from this queue are routed to TPTC0<br>0x1: TRs from this queue are routed to TPTC1<br>Others: Not applicable for IVA2.2 | RW   | 0x1   |

| Bits | Field Name | Description                                                                                                                                                                                                                     | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                           | RW   | 0     |
| 2:0  | TCNUMQ0    | TC Number for Queue 0:<br>Defines the TC number that Event Queue 0 TRs are written to.<br><br>0x0: TRs from this queue are routed to TPTC0<br>0x1: TRs from this queue are routed to TPTC1<br>Others: Not applicable for IVA2.2 | RW   | 0x0   |

**Table 5-213. Register Call Summary for Register TPCC\_QUETCMAP**

IVA2.2 Subsystem Basic Programming Model

- [Prioritizing Defined Transfers: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[1\]](#)

**Table 5-214. TPCC\_QUEPRI**

|                       |                |                         |             |                 |             |
|-----------------------|----------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0284         | <b>Physical address</b> | 0x01C0 0284 | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>    | Queue Priority |                         |             |                 |             |
| <b>Type</b>           | RW             |                         |             |                 |             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |       |          |       |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------|----------|-------|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PRIQ1 | Reserved | PRIQ0 |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                            | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:7 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                                  | RW   | 0x00  |
| 6:4  | PRIQ1      | Priority Level for Queue 1<br>Dictates the priority level used for the OPTIONS field programmation for Qn TRs. Sets the priority used for TC read and write commands.<br><br>0x0: Priority 0 - Highest priority<br>0x1: Priority 1<br>0x2: Priority 2<br>0x3: Priority 3<br>0x4: Priority 4<br>0x5: Priority 5<br>0x6: Priority 6<br>0x7: Priority 7 - Lowest Priority | RW   | 0x0   |
| 3    | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                     | RW   | 0     |
| 2:0  | PRIQ0      | Priority Level for Queue 0 Dictates the priority level used for the OPTIONS field programmation for Qn TRs. Sets the priority used for TC read and write commands.<br><br>0x0: Priority 0 - Highest priority<br>0x1: Priority 1<br>0x2: Priority 2<br>0x3: Priority 3<br>0x4: Priority 4<br>0x5: Priority 5<br>0x6: Priority 6                                         | RW   | 0x0   |

| Bits | Field Name | Description                  | Type | Reset |
|------|------------|------------------------------|------|-------|
| 0x7: |            | Priority 7 - Lowest Priority |      |       |

**Table 5-215. Register Call Summary for Register TPCC\_QUEPRI**

IVA2.2 Subsystem Basic Programming Model

- [Prioritizing Defined Transfers: \[0\] \[1\] \[2\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[3\]](#)

**Table 5-216. TPCC\_EMR**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| <b>Address Offset</b>   | 0x0300                                                                                                                                                                                                                                                                                                                                                                                                         |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
| <b>Physical address</b> | 0x01C0 0300                                                                                                                                                                                                                                                                                                                                                                                                    |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
| <b>Description</b>      | Event Missed Register:<br>The Event Missed register is set if 2 events are received without the first event being cleared or if a Null TR is serviced. Chained events (CER), Set Events (ESR), and normal events (ER) are treated individually. If any bit in the EMR register is set (and all errors (including QEMR/CCERR) were previously clear), then an error will be signaled with TPCC error interrupt. |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                              |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
| 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  |
| E31                     | E30                                                                                                                                                                                                                                                                                                                                                                                                            | E29 | E28 | E27 | E26 | E25 | E24 | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description      | Type | Reset |
|------|------------|------------------|------|-------|
| 31   | E31        | Event Missed #31 | R    | 0     |
| 30   | E30        | Event Missed #30 | R    | 0     |
| 29   | E29        | Event Missed #29 | R    | 0     |
| 28   | E28        | Event Missed #28 | R    | 0     |
| 27   | E27        | Event Missed #27 | R    | 0     |
| 26   | E26        | Event Missed #26 | R    | 0     |
| 25   | E25        | Event Missed #25 | R    | 0     |
| 24   | E24        | Event Missed #24 | R    | 0     |
| 23   | E23        | Event Missed #23 | R    | 0     |
| 22   | E22        | Event Missed #22 | R    | 0     |
| 21   | E21        | Event Missed #21 | R    | 0     |
| 20   | E20        | Event Missed #20 | R    | 0     |
| 19   | E19        | Event Missed #19 | R    | 0     |
| 18   | E18        | Event Missed #18 | R    | 0     |
| 17   | E17        | Event Missed #17 | R    | 0     |
| 16   | E16        | Event Missed #16 | R    | 0     |
| 15   | E15        | Event Missed #15 | R    | 0     |
| 14   | E14        | Event Missed #14 | R    | 0     |
| 13   | E13        | Event Missed #13 | R    | 0     |
| 12   | E12        | Event Missed #12 | R    | 0     |
| 11   | E11        | Event Missed #11 | R    | 0     |
| 10   | E10        | Event Missed #10 | R    | 0     |
| 9    | E9         | Event Missed #9  | R    | 0     |
| 8    | E8         | Event Missed #8  | R    | 0     |
| 7    | E7         | Event Missed #7  | R    | 0     |
| 6    | E6         | Event Missed #6  | R    | 0     |
| 5    | E5         | Event Missed #5  | R    | 0     |

| Bits | Field Name | Description     | Type | Reset |
|------|------------|-----------------|------|-------|
| 4    | E4         | Event Missed #4 | R    | 0     |
| 3    | E3         | Event Missed #3 | R    | 0     |
| 2    | E2         | Event Missed #2 | R    | 0     |
| 1    | E1         | Event Missed #1 | R    | 0     |
| 0    | E0         | Event Missed #0 | R    | 0     |

**Table 5-217. Register Call Summary for Register TPCC\_EMR**

IVA2.2 Subsystem Basic Programming Model

- [Error Reporting for EDMA Module: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[1\]](#)

**Table 5-218. TPCC\_EMRH**

|                         |                                    |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |          |     |     |     |     |     |     |  |  |
|-------------------------|------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----------|-----|-----|-----|-----|-----|-----|--|--|
| <b>Address Offset</b>   | 0x0304                             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |          |     |     |     |     |     |     |  |  |
| <b>Physical address</b> | 0x01C0 0304                        |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     | Instance |     |     |     |     |     |     |  |  |
| <b>Description</b>      | Event Missed Register (High Part): |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |          |     |     |     |     |     |     |  |  |
| <b>Type</b>             | R                                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |          |     |     |     |     |     |     |  |  |
| 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   |  |  |
| E63                     | E62                                | E61 | E60 | E59 | E58 | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38      | E37 | E36 | E35 | E34 | E33 | E32 |  |  |

| Bits | Field Name | Description      | Type | Reset |
|------|------------|------------------|------|-------|
| 31   | E63        | Event Missed #63 | R    | 0     |
| 30   | E62        | Event Missed #62 | R    | 0     |
| 29   | E61        | Event Missed #61 | R    | 0     |
| 28   | E60        | Event Missed #60 | R    | 0     |
| 27   | E59        | Event Missed #59 | R    | 0     |
| 26   | E58        | Event Missed #58 | R    | 0     |
| 25   | E57        | Event Missed #57 | R    | 0     |
| 24   | E56        | Event Missed #56 | R    | 0     |
| 23   | E55        | Event Missed #55 | R    | 0     |
| 22   | E54        | Event Missed #54 | R    | 0     |
| 21   | E53        | Event Missed #53 | R    | 0     |
| 20   | E52        | Event Missed #52 | R    | 0     |
| 19   | E51        | Event Missed #51 | R    | 0     |
| 18   | E50        | Event Missed #50 | R    | 0     |
| 17   | E49        | Event Missed #49 | R    | 0     |
| 16   | E48        | Event Missed #48 | R    | 0     |
| 15   | E47        | Event Missed #47 | R    | 0     |
| 14   | E46        | Event Missed #46 | R    | 0     |
| 13   | E45        | Event Missed #45 | R    | 0     |
| 12   | E44        | Event Missed #44 | R    | 0     |
| 11   | E43        | Event Missed #43 | R    | 0     |
| 10   | E42        | Event Missed #42 | R    | 0     |
| 9    | E41        | Event Missed #41 | R    | 0     |

| Bits | Field Name | Description      | Type | Reset |
|------|------------|------------------|------|-------|
| 8    | E40        | Event Missed #40 | R    | 0     |
| 7    | E39        | Event Missed #39 | R    | 0     |
| 6    | E38        | Event Missed #38 | R    | 0     |
| 5    | E37        | Event Missed #37 | R    | 0     |
| 4    | E36        | Event Missed #36 | R    | 0     |
| 3    | E35        | Event Missed #35 | R    | 0     |
| 2    | E34        | Event Missed #34 | R    | 0     |
| 1    | E33        | Event Missed #33 | R    | 0     |
| 0    | E32        | Event Missed #32 | R    | 0     |

**Table 5-219. Register Call Summary for Register TPCC\_EMRH**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-220. TPCC\_EMCR**

|                         |  |             |                 |  |                                                                                                                                                                                                                                      |  |  |
|-------------------------|--|-------------|-----------------|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| <b>Address Offset</b>   |  | 0x0308      | <b>Instance</b> |  | IVA2.2 TPCC                                                                                                                                                                                                                          |  |  |
| <b>Physical address</b> |  | 0x01C0 0308 |                 |  |                                                                                                                                                                                                                                      |  |  |
| <b>Description</b>      |  |             |                 |  | Event Missed Clear Register:<br>CPU write of 1 to the EMCR.En bit causes the EMR.En bit to be cleared.<br>CPU write of 0 has no effect.<br>All error bits must be cleared before additional error interrupts will be asserted by CC. |  |  |
| <b>Type</b>             |  |             |                 |  | W                                                                                                                                                                                                                                    |  |  |

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| 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  |
| E31 | E30 | E29 | E28 | E27 | E26 | E25 | E24 | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description            | Type | Reset |
|------|------------|------------------------|------|-------|
| 31   | E31        | Event Missed Clear #31 | W    | 0     |
| 30   | E30        | Event Missed Clear #30 | W    | 0     |
| 29   | E29        | Event Missed Clear #29 | W    | 0     |
| 28   | E28        | Event Missed Clear #28 | W    | 0     |
| 27   | E27        | Event Missed Clear #27 | W    | 0     |
| 26   | E26        | Event Missed Clear #26 | W    | 0     |
| 25   | E25        | Event Missed Clear #25 | W    | 0     |
| 24   | E24        | Event Missed Clear #24 | W    | 0     |
| 23   | E23        | Event Missed Clear #23 | W    | 0     |
| 22   | E22        | Event Missed Clear #22 | W    | 0     |
| 21   | E21        | Event Missed Clear #21 | W    | 0     |
| 20   | E20        | Event Missed Clear #20 | W    | 0     |
| 19   | E19        | Event Missed Clear #19 | W    | 0     |
| 18   | E18        | Event Missed Clear #18 | W    | 0     |
| 17   | E17        | Event Missed Clear #17 | W    | 0     |
| 16   | E16        | Event Missed Clear #16 | W    | 0     |
| 15   | E15        | Event Missed Clear #15 | W    | 0     |
| 14   | E14        | Event Missed Clear #14 | W    | 0     |
| 13   | E13        | Event Missed Clear #13 | W    | 0     |
| 12   | E12        | Event Missed Clear #12 | W    | 0     |
| 11   | E11        | Event Missed Clear #11 | W    | 0     |

| Bits | Field Name | Description            | Type | Reset |
|------|------------|------------------------|------|-------|
| 10   | E10        | Event Missed Clear #10 | W    | 0     |
| 9    | E9         | Event Missed Clear #9  | W    | 0     |
| 8    | E8         | Event Missed Clear #8  | W    | 0     |
| 7    | E7         | Event Missed Clear #7  | W    | 0     |
| 6    | E6         | Event Missed Clear #6  | W    | 0     |
| 5    | E5         | Event Missed Clear #5  | W    | 0     |
| 4    | E4         | Event Missed Clear #4  | W    | 0     |
| 3    | E3         | Event Missed Clear #3  | W    | 0     |
| 2    | E2         | Event Missed Clear #2  | W    | 0     |
| 1    | E1         | Event Missed Clear #1  | W    | 0     |
| 0    | E0         | Event Missed Clear #0  | W    | 0     |

**Table 5-221. Register Call Summary for Register TPCC\_EMCR**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-222. TPCC\_EMCRH**

|                         |                                                                                                                                                                                                                                                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                 |     |     |     |     |     |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----------------|-----|-----|-----|-----|-----|--|--|
| <b>Address Offset</b>   | 0x030C                                                                                                                                                                                                                                           |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                 |     |     |     |     |     |  |  |
| <b>Physical address</b> | 0x01C0 030C                                                                                                                                                                                                                                      |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     | <b>Instance</b> |     |     |     |     |     |  |  |
| <b>Description</b>      | Event Missed Clear Register (High Part):<br>CPU write of 1 to the EMCR.En bit causes the EMR.En bit to be cleared.<br>CPU write of 0 has no effect.<br>All error bits must be cleared before additional error interrupts will be asserted by CC. |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                 |     |     |     |     |     |  |  |
| <b>Type</b>             | W                                                                                                                                                                                                                                                |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                 |     |     |     |     |     |  |  |
| 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   |  |  |
| E63                     | E62                                                                                                                                                                                                                                              | E61 | E60 | E59 | E58 | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38 | E37             | E36 | E35 | E34 | E33 | E32 |  |  |

| Bits | Field Name | Description            | Type | Reset |
|------|------------|------------------------|------|-------|
| 31   | E63        | Event Missed Clear #63 | W    | 0     |
| 30   | E62        | Event Missed Clear #62 | W    | 0     |
| 29   | E61        | Event Missed Clear #61 | W    | 0     |
| 28   | E60        | Event Missed Clear #60 | W    | 0     |
| 27   | E59        | Event Missed Clear #59 | W    | 0     |
| 26   | E58        | Event Missed Clear #58 | W    | 0     |
| 25   | E57        | Event Missed Clear #57 | W    | 0     |
| 24   | E56        | Event Missed Clear #56 | W    | 0     |
| 23   | E55        | Event Missed Clear #55 | W    | 0     |
| 22   | E54        | Event Missed Clear #54 | W    | 0     |
| 21   | E53        | Event Missed Clear #53 | W    | 0     |
| 20   | E52        | Event Missed Clear #52 | W    | 0     |
| 19   | E51        | Event Missed Clear #51 | W    | 0     |
| 18   | E50        | Event Missed Clear #50 | W    | 0     |
| 17   | E49        | Event Missed Clear #49 | W    | 0     |
| 16   | E48        | Event Missed Clear #48 | W    | 0     |
| 15   | E47        | Event Missed Clear #47 | W    | 0     |
| 14   | E46        | Event Missed Clear #46 | W    | 0     |
| 13   | E45        | Event Missed Clear #45 | W    | 0     |

| Bits | Field Name | Description            | Type | Reset |
|------|------------|------------------------|------|-------|
| 12   | E44        | Event Missed Clear #44 | W    | 0     |
| 11   | E43        | Event Missed Clear #43 | W    | 0     |
| 10   | E42        | Event Missed Clear #42 | W    | 0     |
| 9    | E41        | Event Missed Clear #41 | W    | 0     |
| 8    | E40        | Event Missed Clear #40 | W    | 0     |
| 7    | E39        | Event Missed Clear #39 | W    | 0     |
| 6    | E38        | Event Missed Clear #38 | W    | 0     |
| 5    | E37        | Event Missed Clear #37 | W    | 0     |
| 4    | E36        | Event Missed Clear #36 | W    | 0     |
| 3    | E35        | Event Missed Clear #35 | W    | 0     |
| 2    | E34        | Event Missed Clear #34 | W    | 0     |
| 1    | E33        | Event Missed Clear #33 | W    | 0     |
| 0    | E32        | Event Missed Clear #32 | W    | 0     |

**Table 5-223. Register Call Summary for Register TPCC\_EMCRH**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-224. TPCC\_QEMR**

|                         |                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0310                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 0310                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | QDMA Event Missed Register:<br>The QDMA Event Missed register is set if 2 QDMA events are detected without the first event being cleared or if a Null TR is serviced.. If any bit in the QEMR register is set (and all errors (including EMR/CCERR) were previously clear), then an error will be signaled with TPCC error interrupt. |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description     | Type | Reset    |
|------|------------|-----------------|------|----------|
| 31:8 | Reserved   | Read returns 0. | R    | 0x000000 |
| 7    | E7         | Event Missed #7 | R    | 0        |
| 6    | E6         | Event Missed #6 | R    | 0        |
| 5    | E5         | Event Missed #5 | R    | 0        |
| 4    | E4         | Event Missed #4 | R    | 0        |
| 3    | E3         | Event Missed #3 | R    | 0        |
| 2    | E2         | Event Missed #2 | R    | 0        |
| 1    | E1         | Event Missed #1 | R    | 0        |
| 0    | E0         | Event Missed #0 | R    | 0        |

**Table 5-225. Register Call Summary for Register TPCC\_QEMR**

IVA2.2 Subsystem Basic Programming Model

- [Error Reporting for EDMA Module: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[1\]](#)

**Table 5-226. TPCC\_QEMCR**

|                         |                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0314                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 0314                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | QDMA Event Missed Clear Register:<br>CPU write of 1 to the QEMCR.En bit causes the QEMR.En bit to be cleared.<br>CPU write of 0 has no effect.<br>All error bits must be cleared before additional error interrupts will be asserted by CC. |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------|-------------|--------------|
| 31:8        | Reserved          | Write 0s for future compatibility. | W           | 0x000000     |
| 7           | E7                | Event Missed Clear #7              | W           | 0            |
| 6           | E6                | Event Missed Clear #6              | W           | 0            |
| 5           | E5                | Event Missed Clear #5              | W           | 0            |
| 4           | E4                | Event Missed Clear #4              | W           | 0            |
| 3           | E3                | Event Missed Clear #3              | W           | 0            |
| 2           | E2                | Event Missed Clear #2              | W           | 0            |
| 1           | E1                | Event Missed Clear #1              | W           | 0            |
| 0           | E0                | Event Missed Clear #0              | W           | 0            |

**Table 5-227. Register Call Summary for Register TPCC\_QEMCR**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-228. TPCC\_CCERR**

|                         |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0318            |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 0318       |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | CC Error Register |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                 |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |          |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|----------|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Reserved |    |    |    |    |    |   |   |   |   |   |   |   |   | QTHRXCDO |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:17       | Reserved          | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                        | R           | 0x0000       |
| 16          | TCERR             | Transfer Completion Code Error:<br>TCCERR = 0: Total number of allowed TCCs outstanding has not been reached.<br>TCCERR = 1: Total number of allowed TCCs has been reached.<br>TCCERR can be cleared by writing 1 to corresponding bit in CCERRCLR register. If any bit in the CCERR register is set (and all errors were previously clear), then an error will be signaled with TPCC error interrupt. | R           | 0            |
| 15:2        | Reserved          | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                        | R           | 0x00         |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                      | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | QTHRXC0D1  | Queue Threshold Error for Q1:<br>QTHRXC0D1 = 0: Watermark/threshold has not been exceeded.<br>QTHRXC0D1 = 1: Watermark/threshold has been exceeded.<br>CCERR.QTHRXC0D1 can be cleared by writing 1 to corresponding bit in CCERRCLR register. If any bit in the CCERR register is set (and all errors (including EMR/QEMR) were previously clear), then an error will be signaled with the TPCC error interrupt. | R    | 0     |
| 0    | QTHRXC0D0  | Queue Threshold Error for Q0:<br>QTHRXC0D0 = 0: Watermark/threshold has not been exceeded.<br>QTHRXC0D0 = 1: Watermark/threshold has been exceeded.<br>CCERR.QTHRXC0D0 can be cleared by writing 1 to corresponding bit in CCERRCLR register. If any bit in the CCERR register is set (and all errors (including EMR/QEMR) were previously clear), then an error will be signaled with the TPCC error interrupt. | R    | 0     |

**Table 5-229. Register Call Summary for Register TPCC\_CCERR**

IVA2.2 Subsystem Basic Programming Model

- Starting the Transfer: [0]
- Error Reporting for EDMA Module: [1] [2]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [3]

**Table 5-230. TPCC\_CCERRCLR**

| Address Offset          | 0x031C                  |                       | Physical address | 0x01C0 031C | Instance  | IVA2.2 TPCC |
|-------------------------|-------------------------|-----------------------|------------------|-------------|-----------|-------------|
| Description             | CC Error Clear Register |                       | Type             | W           |           |             |
|                         |                         |                       |                  |             |           |             |
| 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  |             |           |             |
|                         | Reserved                | TCERR                 | Reserved         | QTHRXC0D1   | QTHRXC0D0 |             |

| Bits  | Field Name | Description                                                                                                                                     | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:17 | Reserved   | Write 0s for future compatibility.                                                                                                              | W    | 0x0000 |
| 16    | TCERR      | Clear Error for CCERR.TCERR:<br>Write of 1 clears the value of CCERR bit N.<br>Writes of 0 have no effect.                                      | W    | 0      |
| 15:2  | Reserved   | Write 0s for future compatibility.                                                                                                              | W    | 0x00   |
| 1     | QTHRXC0D1  | Clear error for CCERR.QTHRXC0D1:<br>Write of 1 clears the values of QSTAT1.WM, QSTAT1.THRXCD,<br>CCERR.QTHRXC0D1<br>Writes of 0 have no effect. | W    | 0      |
| 0     | QTHRXC0D0  | Clear error for CCERR.QTHRXC0D0:<br>Write of 1 clears the values of QSTAT0.WM, QSTAT0.THRXCD,<br>CCERR.QTHRXC0D0<br>Writes of 0 have no effect. | W    | 0      |

**Table 5-231. Register Call Summary for Register TPCC\_CCERRCLR**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-232. TPCC\_EEVAL**

|                         |                     |                 |             |
|-------------------------|---------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0320              |                 |             |
| <b>Physical address</b> | 0x01C0 0320         | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>      | Error Eval Register |                 |             |
| <b>Type</b>             | W                   |                 |             |

| Bits | Field Name | Description                                                                                                                                                                                                              | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | Reserved   | Write 0s for future compatibility.                                                                                                                                                                                       | W    | 0x00000000 |
| 1    | SET        | Error Interrupt Set:<br>CPU write of 1 to the SET bit causes the TPCC error interrupt to be pulsed regardless of state of any of the EMR/EMRH, QEMR, or CCERR registers.<br>CPU write of 0 has no effect.                | W    | 0          |
| 0    | EVAL       | Error Interrupt Evaluate:<br>CPU write of 1 to the EVAL bit causes the TPCC error interrupt to be pulsed if any errors have not been cleared in the EMR/EMRH, QEMR, or CCERR registers.<br>CPU write of 0 has no effect. | W    | 0          |

**Table 5-233. Register Call Summary for Register TPCC\_EEVAL**

- [Error Reporting for EDMA Module: \[0\]](#)

IVA2.2 Subsystem Register Manual

  - [TPCC Register Mapping Summary: \[1\]](#)

**Table 5-234. TPCC\_DRAEj**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |             |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------|
| <b>Address Offset</b>   | 0x0340 + (0x8*j)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |             |
| <b>Physical address</b> | 0x01C0 0340 + (0x8*j)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Instance | IVA2.2 TPCC |
| <b>Description</b>      | <p>DMA Region Access enable for bit N in Region i:</p> <p>En = 0: Accesses through Region i address space to Bit N in any DMA Channel Register are not allowed.</p> <p>Reads will return b0 on Bit N and writes will not modify the state of bit N. Enabled interrupt bits for bit N do not contribute to the generation of the TPCC region i interrupt.</p> <p>En = 1: Accesses through Region i address space to Bit N in any DMA Channel Register are allowed. Reads will return the value from Bit N and writes will modify the state of bit N. Enabled interrupt bits for bit N do contribute to the generation of the TPCC region i interrupt.</p> |          |             |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          |             |

| Bits | Field Name | Description                                    | Type | Reset |
|------|------------|------------------------------------------------|------|-------|
| 31   | E31        | DMA Region Access enable for Region i, bit #31 | RW   | 0     |
| 30   | E30        | DMA Region Access enable for Region i, bit #30 | RW   | 0     |
| 29   | E29        | DMA Region Access enable for Region i, bit #29 | RW   | 0     |
| 28   | E28        | DMA Region Access enable for Region i, bit #28 | RW   | 0     |
| 27   | E27        | DMA Region Access enable for Region i, bit #27 | RW   | 0     |
| 26   | E26        | DMA Region Access enable for Region i, bit #26 | RW   | 0     |
| 25   | E25        | DMA Region Access enable for Region i, bit #25 | RW   | 0     |
| 24   | E24        | DMA Region Access enable for Region i, bit #24 | RW   | 0     |

| Bits | Field Name | Description                                    | Type | Reset |
|------|------------|------------------------------------------------|------|-------|
| 23   | E23        | DMA Region Access enable for Region i, bit #23 | RW   | 0     |
| 22   | E22        | DMA Region Access enable for Region i, bit #22 | RW   | 0     |
| 21   | E21        | DMA Region Access enable for Region i, bit #21 | RW   | 0     |
| 20   | E20        | DMA Region Access enable for Region i, bit #20 | RW   | 0     |
| 19   | E19        | DMA Region Access enable for Region i, bit #19 | RW   | 0     |
| 18   | E18        | DMA Region Access enable for Region i, bit #18 | RW   | 0     |
| 17   | E17        | DMA Region Access enable for Region i, bit #17 | RW   | 0     |
| 16   | E16        | DMA Region Access enable for Region i, bit #16 | RW   | 0     |
| 15   | E15        | DMA Region Access enable for Region i, bit #15 | RW   | 0     |
| 14   | E14        | DMA Region Access enable for Region i, bit #14 | RW   | 0     |
| 13   | E13        | DMA Region Access enable for Region i, bit #13 | RW   | 0     |
| 12   | E12        | DMA Region Access enable for Region i, bit #12 | RW   | 0     |
| 11   | E11        | DMA Region Access enable for Region i, bit #11 | RW   | 0     |
| 10   | E10        | DMA Region Access enable for Region i, bit #10 | RW   | 0     |
| 9    | E9         | DMA Region Access enable for Region i, bit #9  | RW   | 0     |
| 8    | E8         | DMA Region Access enable for Region i, bit #8  | RW   | 0     |
| 7    | E7         | DMA Region Access enable for Region i, bit #7  | RW   | 0     |
| 6    | E6         | DMA Region Access enable for Region i, bit #6  | RW   | 0     |
| 5    | E5         | DMA Region Access enable for Region i, bit #5  | RW   | 0     |
| 4    | E4         | DMA Region Access enable for Region i, bit #4  | RW   | 0     |
| 3    | E3         | DMA Region Access enable for Region i, bit #3  | RW   | 0     |
| 2    | E2         | DMA Region Access enable for Region i, bit #2  | RW   | 0     |
| 1    | E1         | DMA Region Access enable for Region i, bit #1  | RW   | 0     |
| 0    | E0         | DMA Region Access enable for Region i, bit #0  | RW   | 0     |

**Table 5-235. Register Call Summary for Register TPCC\_DRAEj**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-236. TPCC\_DRAEHj**

|                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                         |                       |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------------|-----------------|-------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| <b>Address Offset</b> | 0x0344 + (0x8*j)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <b>Physical address</b> | 0x01C0 0344 + (0x8*j) | <b>Instance</b> | IVA2.2 TPCC |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| <b>Description</b>    | DMA Region Access enable for bit N in Region M:<br>En = 0: Accesses through Region i address space to Bit N in any DMA Channel Register are not allowed. Reads will return b0 on Bit N and writes will not modify the state of bit N. Enabled interrupt bits for bit N do not contribute to the generation of the TPCC region i interrupt.<br>En = 1: Accesses through Region i address space to Bit N in any DMA Channel Register are allowed. Reads will return the value from Bit N and writes will modify the state of bit N. Enabled interrupt bits for bit N do contribute to the generation of the TPCC region i interrupt. |                         |                       |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| <b>Type</b>           | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                         |                       |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 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   |
| E63                   | E62                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | E61                     | E60                   | E59             | E58         | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38 | E37 | E36 | E35 | E34 | E33 | E32 |

| Bits | Field Name | Description                                    | Type | Reset |
|------|------------|------------------------------------------------|------|-------|
| 31   | E63        | DMA Region Access enable for Region i, bit #63 | RW   | 0     |
| 30   | E62        | DMA Region Access enable for Region i, bit #62 | RW   | 0     |
| 29   | E61        | DMA Region Access enable for Region i, bit #61 | RW   | 0     |
| 28   | E60        | DMA Region Access enable for Region i, bit #60 | RW   | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                             | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------|-------------|--------------|
| 27          | E59               | DMA Region Access enable for Region i, bit #59 | RW          | 0            |
| 26          | E58               | DMA Region Access enable for Region i, bit #58 | RW          | 0            |
| 25          | E57               | DMA Region Access enable for Region i, bit #57 | RW          | 0            |
| 24          | E56               | DMA Region Access enable for Region i, bit #56 | RW          | 0            |
| 23          | E55               | DMA Region Access enable for Region i, bit #55 | RW          | 0            |
| 22          | E54               | DMA Region Access enable for Region i, bit #54 | RW          | 0            |
| 21          | E53               | DMA Region Access enable for Region i, bit #53 | RW          | 0            |
| 20          | E52               | DMA Region Access enable for Region i, bit #52 | RW          | 0            |
| 19          | E51               | DMA Region Access enable for Region i, bit #51 | RW          | 0            |
| 18          | E50               | DMA Region Access enable for Region i, bit #50 | RW          | 0            |
| 17          | E49               | DMA Region Access enable for Region i, bit #49 | RW          | 0            |
| 16          | E48               | DMA Region Access enable for Region i, bit #48 | RW          | 0            |
| 15          | E47               | DMA Region Access enable for Region i, bit #47 | RW          | 0            |
| 14          | E46               | DMA Region Access enable for Region i, bit #46 | RW          | 0            |
| 13          | E45               | DMA Region Access enable for Region i, bit #45 | RW          | 0            |
| 12          | E44               | DMA Region Access enable for Region i, bit #44 | RW          | 0            |
| 11          | E43               | DMA Region Access enable for Region i, bit #43 | RW          | 0            |
| 10          | E42               | DMA Region Access enable for Region i, bit #42 | RW          | 0            |
| 9           | E41               | DMA Region Access enable for Region i, bit #41 | RW          | 0            |
| 8           | E40               | DMA Region Access enable for Region i, bit #40 | RW          | 0            |
| 7           | E39               | DMA Region Access enable for Region i, bit #39 | RW          | 0            |
| 6           | E38               | DMA Region Access enable for Region i, bit #38 | RW          | 0            |
| 5           | E37               | DMA Region Access enable for Region i, bit #37 | RW          | 0            |
| 4           | E36               | DMA Region Access enable for Region i, bit #36 | RW          | 0            |
| 3           | E35               | DMA Region Access enable for Region i, bit #35 | RW          | 0            |
| 2           | E34               | DMA Region Access enable for Region i, bit #34 | RW          | 0            |
| 1           | E33               | DMA Region Access enable for Region i, bit #33 | RW          | 0            |
| 0           | E32               | DMA Region Access enable for Region i, bit #32 | RW          | 0            |

**Table 5-237. Register Call Summary for Register TPCC\_DRAEHj**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-238. TPCC\_QRAEj**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                       |                 |  |  |  |  |    |    |    |    |    |    |    |    |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|----|----|----|----|----|----|----|----|
| <b>Address Offset</b>   | 0x0380 + (0x4*j)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                       |                 |  |  |  |  |    |    |    |    |    |    |    |    |
| <b>Physical address</b> | 0x01C0 0380 + (0x4*j)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Instance              | IV A2.2 TPCC    |  |  |  |  |    |    |    |    |    |    |    |    |
| <b>Description</b>      | QDMA Region Access enable for bit N in Region i:<br>En = 0: Accesses through Region i address space to Bit N in any QDMA Channel Register are not allowed. Reads will return b0 on Bit N and writes will not modify the state of bit N. Enabled interrupt bits for bit N do not contribute to the generation of the TPCC region i interrupt.<br>En = 1: Accesses through Region i address space to Bit N in any QDMA Channel Register are allowed. Reads will return the value from Bit N and writes will modify the state of bit N. Enabled interrupt bits for bit N do contribute to the generation of the TPCC region i interrupt. |                       |                 |  |  |  |  |    |    |    |    |    |    |    |    |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                       |                 |  |  |  |  |    |    |    |    |    |    |    |    |
| 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 |  |  |  |  |    |    |    |    |    |    |    |    |
| Reserved                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                       |                 |  |  |  |  | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

## IVA2.2 Subsystem Register Manual

www.ti.com

| Bits | Field Name | Description                                           | Type | Reset    |
|------|------------|-------------------------------------------------------|------|----------|
| 31:8 | Reserved   | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0x000000 |
| 7    | E7         | QDMA Region Access enable for Region i, bit #7        | RW   | 0        |
| 6    | E6         | QDMA Region Access enable for Region i, bit #6        | RW   | 0        |
| 5    | E5         | QDMA Region Access enable for Region i, bit #5        | RW   | 0        |
| 4    | E4         | QDMA Region Access enable for Region i, bit #4        | RW   | 0        |
| 3    | E3         | QDMA Region Access enable for Region i, bit #3        | RW   | 0        |
| 2    | E2         | QDMA Region Access enable for Region i, bit #2        | RW   | 0        |
| 1    | E1         | QDMA Region Access enable for Region i, bit #1        | RW   | 0        |
| 0    | E0         | QDMA Region Access enable for Region i, bit #0        | RW   | 0        |

**Table 5-239. Register Call Summary for Register TPCC\_QRAEj**

## IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-240. TPCC\_Q0Ek**

|                         |                                                                          |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|-------------|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0400 + (0x4*k)                                                         |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 0400 + (0x4*k)                                                    |  |  |  |  |  |  |  |  |  | <b>Instance</b> | IVA2.2 TPCC |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Event Queue Entry Diagram for Queue j - Entry i (j =0 to1 and i=0 to 15) |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                        |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |       |   |      |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------|---|------|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | ETYPE |   | ENUM |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                              | Type | Reset    |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                          | R    | 0x000000 |
| 7:6  | ETYPE      | Event Type:<br>Specifies the specific Event Type for the given entry in the Event Queue.<br><br>Read 0x0: Event Triggered through ER<br>Read 0x1: Manual Triggered through ESR<br>Read 0x2: Chain Triggered through CER<br>Read 0x3: Auto-Triggered through QER          | R    | 0x-      |
| 5:0  | ENUM       | Event Number:<br>Specifies the specific Event Number for the given entry in the Event Queue. For DMA Channel events (ER/ESR/CER), ENUM will range between 0 and NUM_DMACH (up to 63). For QDMA Channel events (QER), ENUM will range between 0 and NUM_QDMACH (up to 7). | R    | 0x--     |

**Table 5-241. Register Call Summary for Register TPCC\_Q0Ek**

## IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-242. TPCC\_Q1Ek**

|                         |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |       |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|-------|
| <b>Address Offset</b>   | 0x0440 + (0x4*k)        |                       |                 |  |  |  |  |  |  |  |  |  |  |  |       |
| <b>Physical address</b> | 0x01C0 0440 + (0x4*k)   |                       |                 |  |  |  |  |  |  |  |  |  |  |  |       |
| <b>Description</b>      | Instance                |                       |                 |  |  |  |  |  |  |  |  |  |  |  |       |
| <b>Type</b>             | IV A2.2 TPCC            |                       |                 |  |  |  |  |  |  |  |  |  |  |  |       |
| 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 |  |  |  |  |  |  |  |  |  |  |  |       |
| Reserved                |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  | ETYPE |
|                         |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  | ENUM  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                              | Type | Reset    |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                          | R    | 0x000000 |
| 7:6  | ETYPE      | Event Type:<br>Specifies the specific Event Type for the given entry in the Event Queue.<br><br>Read 0x0: Event Triggered through ER<br>Read 0x1: Manual Triggered through ESR<br>Read 0x2: Chain Triggered through CER<br>Read 0x3: Auto-Triggered through QER          | R    | 0x-      |
| 5:0  | ENUM       | Event Number:<br>Specifies the specific Event Number for the given entry in the Event Queue. For DMA Channel events (ER/ESR/CER), ENUM will range between 0 and NUM_DMACH (up to 63). For QDMA Channel events (QER), ENUM will range between 0 and NUM_QDMACH (up to 7). | R    | 0x--     |

**Table 5-243. Register Call Summary for Register TPCC\_Q1Ek**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-244. TPCC\_QSTATI**

|                         |                         |                       |                 |          |        |          |         |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|----------|--------|----------|---------|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0600 + (0x4*I)        |                       |                 |          |        |          |         |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 0600 + (0x4*I)   |                       |                 |          |        |          |         |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Instance                |                       |                 |          |        |          |         |  |  |  |  |  |  |  |  |
| <b>Type</b>             | IV A2.2 TPCC            |                       |                 |          |        |          |         |  |  |  |  |  |  |  |  |
| 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 |          |        |          |         |  |  |  |  |  |  |  |  |
| Reserved                | THRXCD                  | Reserved              | WM              | Reserved | NUMVAL | Reserved | STRTPTR |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                               | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:25 | Reserved   | Read returns 0.                                                                                                                                                                                                           | R    | 0x00  |
| 24    | THRXCD     | Threshold Exceeded:<br>THRXCD = 0: Threshold specified by QWMTHR(A B).Qn has not been exceeded.<br>THRXCD = 1: Threshold specified by QWMTHR(A B).Qn has been exceeded.<br>QSTATn.THRXCD is cleared by CCERRCLR.QTHRXCDDn | R    | 0     |
| 23:21 | Reserved   | Read returns 0.                                                                                                                                                                                                           | R    | 0x0   |

## IVA2.2 Subsystem Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                                                             | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 20:16 | WM         | Watermark for Maximum Queue Usage:<br>Watermark tracks the most entries that have been in QueueN since reset or since the last time that the watermark (WM) was cleared.<br>QSTATn.WM is cleared through CCERR.WMCLRn bit.<br>Legal values = 0x0 (empty) to 0x10 (full) | R    | 0x00  |
| 15:13 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                         | R    | 0x0   |
| 12:8  | NUMVAL     | Number of Valid Entries in Queuei:<br>Represents the total number of entries residing in the Queue Manager FIFO at a given instant. Always enabled.<br>Legal values = 0x0 (empty) to 0x10 (full)                                                                        | R    | 0x00  |
| 7:4   | Reserved   | Read returns 0.                                                                                                                                                                                                                                                         | R    | 0x0   |
| 3:0   | STRTPTR    | Start Pointer:<br>Represents the offset to the head entry of Queuei, in units of *entries*. Always enabled.<br>Legal values = 0x0 (0th entry) to 0xF (15th entry)                                                                                                       | R    | 0x0   |

**Table 5-245. Register Call Summary for Register TPCC\_QSTATI**

IVA2.2 Subsystem Basic Programming Model

- Starting the Transfer: [0]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [1]

**Table 5-246. TPCC\_QWMTHRA**

|                         |                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|-------------|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0620                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 0620                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  | <b>Instance</b> | IVA2.2 TPCC |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Queue Threshold A, for Q[3:0]:<br>CCERR.QTHRXCn and QSTATn.THRXCD error bit is set when the number of Events in QueueN at an instant in time (visible through QSTATn.NUMVAL) equals or exceeds the value specified by QWMTHRA.Qn.<br>Legal values = 0x0 (ever used?) to 0x10 (ever full?)<br>A value of 0x11 disables threshold errors. |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Q1 |    | Reserved |    | Q0 |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                           | Type | Reset        |
|-------|------------|-------------------------------------------------------|------|--------------|
| 31:13 | Reserved   | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0x0010001000 |
| 12:8  | Q1         | Queue Threshold for Q1 value                          | RW   | 0x10         |
| 7:5   | Reserved   | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0x0          |
| 4:0   | Q0         | Queue Threshold for Q0 value                          | RW   | 0x10         |

**Table 5-247. Register Call Summary for Register TPCC\_QWMTHRA**

IVA2.2 Subsystem Basic Programming Model

- Starting the Transfer: [0]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [1]

**Table 5-248. TPCC\_QWMTHR**

|                         |                                                                                                                                                                                                                                                                                                                                           |                 |             |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0624                                                                                                                                                                                                                                                                                                                                    |                 |             |
| <b>Physical address</b> | 0x01C0 0624                                                                                                                                                                                                                                                                                                                               | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>      | Queue Threshold B, for Q[7:4]:<br>CCERR.QTHRXCnD and QSTATn.THRXCD error bit is set when the number of Events in QueueN at an instant in time (visible through QSTATn.NUMVAL) equals or exceeds the value specified by QWMTHR.B.Qn.<br>Legal values = 0x0 (ever used?) to 0x10 (ever full?)<br>A value of 0x11 disables threshold errors. |                 |             |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                        |                 |             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                           | Type | Reset              |
|------|------------|-------------------------------------------------------|------|--------------------|
| 31:0 | Reserved   | Write 0s for future compatibility.<br>Read returns 0. | RW   | 0x0010001000100010 |

**Table 5-249. Register Call Summary for Register TPCC\_QWMTHR**

IVA2.2 Subsystem Basic Programming Model

- Starting the Transfer: [0]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [1]

**Table 5-250. TPCC\_CCSTAT**

|                         |                    |                 |             |
|-------------------------|--------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0640             |                 |             |
| <b>Physical address</b> | 0x01C0 0640        | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>      | CC Status Register |                 |             |
| <b>Type</b>             | R                  |                 |             |

|          |    |    |    |    |    |    |    |          |          |          |          |          |          |          |          |          |          |    |    |    |    |          |      |          |        |          |      |   |   |   |   |
|----------|----|----|----|----|----|----|----|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----|----|----|----|----------|------|----------|--------|----------|------|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    | QUEACTV7 | QUEACTV6 | QUEACTV5 | QUEACTV4 | QUEACTV3 | QUEACTV2 | QUEACTV1 | QUEACTV0 | Reserved | COMPACTV |    |    |    |    | Reserved | ACTV | Reserved | TRACTV | QEVTACTV | EVTA |   |   |   |   |

| Bits  | Field Name | Description                                                                                                 | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | Reserved   | Read returns 0.                                                                                             | R    | 0x00  |
| 23    | QUEACTV7   | Queue 7 Active<br>QUEACTV7 = 0: No Evts are queued in Q7.<br>QUEACTV7 = 1: At least one TR is queued in Q7. | R    | 0     |
| 22    | QUEACTV6   | Queue 6 Active<br>QUEACTV6 = 0: No Evts are queued in Q6.<br>QUEACTV6 = 1: At least one TR is queued in Q6. | R    | 0     |
| 21    | QUEACTV5   | Queue 5 Active<br>QUEACTV5 = 0: No Evts are queued in Q5.<br>QUEACTV5 = 1: At least one TR is queued in Q5. | R    | 0     |
| 20    | QUEACTV4   | Queue 4 Active<br>QUEACTV4 = 0: No Evts are queued in Q4.<br>QUEACTV4 = 1: At least one TR is queued in Q4. | R    | 0     |
| 19    | QUEACTV3   | Queue 3 Active<br>QUEACTV3 = 0: No Evts are queued in Q3.<br>QUEACTV3 = 1: At least one TR is queued in Q3. | R    | 0     |

## IVA2.2 Subsystem Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 18    | QUEACTV2   | Queue 2 Active<br>QUEACTV2 = 0: No Evt are queued in Q2.<br>QUEACTV2 = 1: At least one TR is queued in Q2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R    | 0     |
| 17    | QUEACTV1   | Queue 1 Active<br>QUEACTV1 = 0: No Evt are queued in Q1.<br>QUEACTV1 = 1: At least one TR is queued in Q1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R    | 0     |
| 16    | QUEACTV0   | Queue 0 Active<br>QUEACTV0 = 0: No Evt are queued in Q0.<br>QUEACTV0 = 1: At least one TR is queued in Q0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R    | 0     |
| 15:14 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R    | 0x0   |
| 13:8  | COMPACTV   | Completion Request Active:<br>Counter that tracks the total number of completion requests submitted to the TC. The counter increments when a TR is submitted with TCINTEN or TCCHEN set to 1. The counter decrements for every valid completion code received from any of the external TCs. The CC will not service new TRs if COMPACTV count is already at the limit.<br>COMPACTV = 0: No completion requests outstanding.<br>COMPACTV = 1: Total of 1 completion request outstanding.<br>...<br>COMPACTV = 63 : Total of 63 completion requests are outstanding.<br>No additional TRs will be submitted until count is less than 63. | R    | 0x00  |
| 7:5   | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R    | 0x0   |
| 4     | ACTV       | Channel Controller Active:<br>Channel Controller Active is a logical-OR of each of the *ACTV signals. The ACTV bit must remain high through the life of a TR.<br>ACTV = 0: Channel is idle.<br>ACTV = 1: Channel is busy.                                                                                                                                                                                                                                                                                                                                                                                                              | R    | 0     |
| 3     | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R    | 0     |
| 2     | TRACTV     | Transfer Request Active:<br>TRACTV = 0: Transfer Request processing/submission logic is inactive.<br>TRACTV = 1: Transfer Request processing/submission logic is active.                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R    | 0     |
| 1     | QEVTACTV   | QDMA Event Active:<br>QEVTACTV = 0: No enabled QDMA Events are active within the CC.<br>QEVTACTV = 1: At least one enabled DMA Event(ER & EER, ESR, CER) is active within the CC.                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R    | 0     |
| 0     | EVTACTV    | DMA Event Active:<br>EVTACTV = 0: No enabled DMA Events are active within the CC.<br>EVTACTV = 1: At least one enabled DMA Event(ER & EER, ESR, CER) is active within the CC.                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0     |

**Table 5-251. Register Call Summary for Register TPCC\_CCSTAT**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-252. TPCC\_MP FAR**

|                         |                                 |                 |             |  |  |
|-------------------------|---------------------------------|-----------------|-------------|--|--|
| <b>Address Offset</b>   | 0x0800                          | <b>Instance</b> | IVA2.2 TPCC |  |  |
| <b>Physical address</b> | 0x01C0 0800                     |                 |             |  |  |
| <b>Description</b>      | Memory Protection Fault Address |                 |             |  |  |
| <b>Type</b>             | R                               |                 |             |  |  |

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| FADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                             | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | FADDR      | Fault Address:<br>32-bit read-only status register containing the faulting address when a memory protection violation is detected. This register can only be cleared through the MPFCR. | R    | 0x00000000 |

**Table 5-253. Register Call Summary for Register TPCC\_MP FAR**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [1]

**Table 5-254. TPCC\_MPFSR**

|                       |                                         |                         |             |                 |             |
|-----------------------|-----------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0804                                  | <b>Physical address</b> | 0x01C0 0804 | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>    | Memory Protection Fault Status Register | <b>Type</b>             | R           |                 |             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |          |    |                                     |                                     |                                     |                                     |                                     |                                     |                                     |                                     |                                     |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----------|----|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FID |    | Reserved |    | <input type="button" value="UR"/> 0 | <input type="button" value="SW"/> 0 | <input type="button" value="UX"/> 0 | <input type="button" value="UR"/> 1 | <input type="button" value="SW"/> 1 | <input type="button" value="UX"/> 1 | <input type="button" value="UR"/> 2 | <input type="button" value="SW"/> 2 | <input type="button" value="UX"/> 2 |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                           | Type | Reset   |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:13 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                       | R    | 0x00000 |
| 12:9  | FID        | Faulted ID:<br>FID register contains valid info if any of the MP error bits (UXE, UWE, URE, SXE, SWE, SRE) are non-zero (i.e., if an error has been detected.) The FID field contains the VBus PrivID for the specific request/requestor that resulted in a MP Error. | R    | 0x0     |
| 8:6   | Reserved   | Read returns 0.                                                                                                                                                                                                                                                       | R    | x0      |
| 5     | SRE        | Supervisor Read Error:<br>SRE = 0: No error detected.<br>SRE = 1: Supervisor level task attempted to Read from a MP Page without SR permissions.                                                                                                                      | R    | 0       |
| 4     | SWE        | Supervisor Write Error:<br>SWE = 0: No error detected.<br>SWE = 1: Supervisor level task attempted to Write to a MP Page without SW permissions.                                                                                                                      | R    | 0       |
| 3     | SXE        | Supervisor Execute Error:<br>SXE = 0: No error detected.<br>SXE = 1: Supervisor level task attempted to Execute from a MP Page without SX permissions.                                                                                                                | R    | 0       |
| 2     | URE        | User Read Error:<br>URE = 0: No error detected.<br>URE = 1: User level task attempted to Read from a MP Page without UR permissions.                                                                                                                                  | R    | 0       |
| 1     | UWE        | User Write Error:<br>UWE = 0: No error detected.<br>UWE = 1: User level task attempted to Write to a MP Page without UW permissions.                                                                                                                                  | R    | 0       |
| 0     | UXE        | User Execute Error:<br>UXE = 0: No error detected.<br>UXE = 1: User level task attempted to Execute from a MP Page without UX permissions.                                                                                                                            | R    | 0       |

**Table 5-255. Register Call Summary for Register TPCC\_MPFSR**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [1]

**Table 5-256. TPCC\_MPFCR**

|                         |                                          |                         |                 |                 |             |
|-------------------------|------------------------------------------|-------------------------|-----------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0808                                   | <b>Physical address</b> | 0x01C0 0808     | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>      | Memory Protection Fault Command Register |                         |                 |                 |             |
| <b>Type</b>             | W                                        |                         |                 |                 |             |
| 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 |                 |             |
|                         |                                          |                         |                 | Reserved        | MPFCLR      |

| Bits | Field Name | Description                                                                                                                                                               | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Write 0s for future compatibility.                                                                                                                                        | W    | 0x00000000 |
| 0    | MPFCLR     | Fault Clear register:<br>CPU write of 1 to the MPFCLR bit causes any error conditions stored in MPFAR and MPFSR registers to be cleared.<br>CPU write of 0 has no effect. | W    | 0          |

**Table 5-257. Register Call Summary for Register TPCC\_MPFCR**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [1]

**Table 5-258. TPCC\_MPPAG**

|                         |                                                       |                         |                 |                 |                                                              |
|-------------------------|-------------------------------------------------------|-------------------------|-----------------|-----------------|--------------------------------------------------------------|
| <b>Address Offset</b>   | 0x080C                                                | <b>Physical address</b> | 0x01C0 080C     | <b>Instance</b> | IVA2.2 TPCC                                                  |
| <b>Description</b>      | Memory Protection Page Attribute for Global registers |                         |                 |                 |                                                              |
| <b>Type</b>             | RW                                                    |                         |                 |                 |                                                              |
| 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 |                 |                                                              |
|                         |                                                       |                         |                 | Reserved        | AID5 AID4 AID3 AID2 AID1 AID0 EXT Reserved SR SW SX UR UW UX |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                           | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                 | RW   | 0x0000 |
| 15    | AID5       | Allowed ID 5:<br>AID5 = 0: VBus requests with PrivID == 5 are not allowed regardless of permission settings (UW, UR, SW, SR).<br>AID5 = 1: VBus requests with PrivID == 5 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR). | RW   | 1      |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                 | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 14   | AID4       | Allowed ID 4:<br>AID4 = 0: VBus requests with PrivID == 4 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AID4 = 1: VBus requests with PrivID == 4 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR).        | RW   | 1     |
| 13   | AID3       | Allowed ID 3:<br>AID3 = 0: VBus requests with PrivID == 3 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AID3 = 1: VBus requests with PrivID == 3 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR).        | RW   | 1     |
| 12   | AID2       | Allowed ID 2:<br>AID2 = 0: VBus requests with PrivID == 2 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AID2 = 1: VBus requests with PrivID == 2 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR).        | RW   | 1     |
| 11   | AID1       | Allowed ID 1:<br>AID1 = 0: VBus requests with PrivID == 1 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AID1 = 1: VBus requests with PrivID == 1 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR).        | RW   | 1     |
| 10   | AID0       | Allowed ID 0:<br>AID0 = 0: VBus requests with PrivID == 0 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AID0 = 1: VBus requests with PrivID == 0 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR).        | RW   | 1     |
| 9    | EXT        | External Allowed ID:<br>AIDm = 0: VBus requests with PrivID >= 6 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AIDm = 1: VBus requests with PrivID >= 6 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR). | RW   | 1     |
| 8:6  | Reserved   | Write reset value for future compatibility. Read returns reset value.                                                                                                                                                                                                       | RW   | 0x7   |
| 5    | SR         | Supervisor Read permission:<br>SR = 0: Supervisor read accesses are not allowed<br>SR = 1: Supervisor write accesses are allowed                                                                                                                                            | RW   | 1     |
| 4    | SW         | Supervisor Write permission:<br>SW = 0: Supervisor write accesses are not allowed<br>SW = 1: Supervisor write accesses are allowed                                                                                                                                          | RW   | 1     |
| 3    | SX         | Supervisor Execute permission:<br>SX = 0: Supervisor execute accesses are not allowed<br>SX = 1: Supervisor execute accesses are allowed                                                                                                                                    | RW   | 0     |
| 2    | UR         | User Read permission:<br>UR = 0: User read accesses are not allowed<br>UR = 1: User write accesses are allowed                                                                                                                                                              | RW   | 1     |
| 1    | UW         | User Write permission:<br>UW = 0: User write accesses are not allowed<br>UW = 1: User write accesses are allowed                                                                                                                                                            | RW   | 1     |
| 0    | UX         | User Execute permission:<br>UX = 0: User execute accesses are not allowed<br>UX = 1: User execute accesses are allowed                                                                                                                                                      | RW   | 0     |

**Table 5-259. Register Call Summary for Register TPCC\_MPPAG**

IVA2.2 Subsystem Basic Programming Model

- [Internal Memory: \[0\] \[1\] \[2\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[3\]](#)

**Table 5-260. TPCC\_MPPAj**

| <b>Address Offset</b>   | 0x0810 + (0x4*j)                         |                                                                                                                                                                                                                                                                             |                 |  |  |  |  |      |      |      |      |      |      |     |          |        |
|-------------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|------|------|------|------|------|------|-----|----------|--------|
| <b>Physical address</b> | 0x01C0 0810 + (0x4*j)                    |                                                                                                                                                                                                                                                                             |                 |  |  |  |  |      |      |      |      |      |      |     |          |        |
| <b>Description</b>      | MP Permission Attribute for DMA Region n |                                                                                                                                                                                                                                                                             |                 |  |  |  |  |      |      |      |      |      |      |     |          |        |
| <b>Type</b>             | RW                                       |                                                                                                                                                                                                                                                                             |                 |  |  |  |  |      |      |      |      |      |      |     |          |        |
| 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 |  |  |  |  |      |      |      |      |      |      |     |          |        |
| Reserved                |                                          |                                                                                                                                                                                                                                                                             |                 |  |  |  |  | AID5 | AID4 | AID3 | AID2 | AID1 | AID0 | EXT | Reserved |        |
|                         |                                          |                                                                                                                                                                                                                                                                             |                 |  |  |  |  | SR   | SW   | SX   | UR   | UW   | UX   |     |          |        |
| Bits                    | Field Name                               | Description                                                                                                                                                                                                                                                                 |                 |  |  |  |  |      |      |      |      |      |      |     | Type     | Reset  |
| 31:16                   | Reserved                                 | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                       |                 |  |  |  |  |      |      |      |      |      |      |     | RW       | 0x0000 |
| 15                      | AID5                                     | Allowed ID 5:<br>AID5 = 0: VBus requests with PrivID == 5 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AID5 = 1: VBus requests with PrivID == 5 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR).        |                 |  |  |  |  |      |      |      |      |      |      |     | RW       | 1      |
| 14                      | AID4                                     | Allowed ID 4:<br>AID4 = 0: VBus requests with PrivID == 4 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AID4 = 1: VBus requests with PrivID == 4 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR).        |                 |  |  |  |  |      |      |      |      |      |      |     | RW       | 1      |
| 13                      | AID3                                     | Allowed ID 3:<br>AID3 = 0: VBus requests with PrivID == 3 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AID3 = 1: VBus requests with PrivID == 3 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR).        |                 |  |  |  |  |      |      |      |      |      |      |     | RW       | 1      |
| 12                      | AID2                                     | Allowed ID 2:<br>AID2 = 0: VBus requests with PrivID == 2 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AID2 = 1: VBus requests with PrivID == 2 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR).        |                 |  |  |  |  |      |      |      |      |      |      |     | RW       | 1      |
| 11                      | AID1                                     | Allowed ID 1:<br>AID1 = 0: VBus requests with PrivID == 1 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AID1 = 1: VBus requests with PrivID == 1 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR).        |                 |  |  |  |  |      |      |      |      |      |      |     | RW       | 1      |
| 10                      | AID0                                     | Allowed ID 0:<br>AID0 = 0: VBus requests with PrivID == 0 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AID0 = 1: VBus requests with PrivID == 0 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR).        |                 |  |  |  |  |      |      |      |      |      |      |     | RW       | 1      |
| 9                       | EXT                                      | External Allowed ID:<br>AIDm = 0: VBus requests with PrivID >= 6 are notallowed regardless of permission settings (UW, UR, SW, SR).<br>AIDm = 1: VBus requests with PrivID >= 6 are permitted if access type is allowed as defined by permission settings (UW, UR, SW, SR). |                 |  |  |  |  |      |      |      |      |      |      |     | RW       | 1      |
| 8:6                     | Reserved                                 | Write reset value for future compatibility. Read returns reset value.                                                                                                                                                                                                       |                 |  |  |  |  |      |      |      |      |      |      |     | RW       | 0x3    |
| 5                       | SR                                       | Supervisor Read permission:<br>SR = 0: Supervisor read accesses are not allowed<br>SR = 1: Supervisor write accesses are allowed                                                                                                                                            |                 |  |  |  |  |      |      |      |      |      |      |     | RW       | 1      |
| 4                       | SW                                       | Supervisor Write permission:<br>SW = 0: Supervisor write accesses are not allowed<br>SW = 1: Supervisor write accesses are allowed                                                                                                                                          |                 |  |  |  |  |      |      |      |      |      |      |     | RW       | 1      |

| Bits | Field Name | Description                                                                                                                              | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3    | SX         | Supervisor Execute permission:<br>SX = 0: Supervisor execute accesses are not allowed<br>SX = 1: Supervisor execute accesses are allowed | RW   | 0     |
| 2    | UR         | User Read permission:<br>UR = 0: User read accesses are not allowed<br>UR = 1: User write accesses are allowed                           | RW   | 1     |
| 1    | UW         | User Write permission:<br>UW = 0: User write accesses are not allowed<br>UW = 1: User write accesses are allowed                         | RW   | 1     |
| 0    | UX         | User Execute permission:<br>UX = 0: User execute accesses are not allowed<br>UX = 1: User execute accesses are allowed                   | RW   | 0     |

**Table 5-261. Register Call Summary for Register TPCC\_MPPAj**

IVA2.2 Subsystem Basic Programming Model

- Internal Memory: [0] [1] [2] [3] [4]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [5]

**Table 5-262. TPCC\_ER**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 |             |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x1000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                 |             |
| <b>Physical address</b> | 0x01C0 1000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>      | Event Register:<br>If ER.En bit is set and the EER.En bit is also set, then the corresponding DMA channel is prioritized vs. other pending DMA events for submission to the TC. ER.En bit is set when the input event #n transitions from inactive (low) to active (high), regardless of the state of EER.En bit. ER.En bit is cleared when the corresponding event is prioritized and serviced. If the ER.En bit is already set and a new inactive to active transition is detected on the input event #n input AND the corresponding bit in the EER register is set, then the corresponding bit in the Event Missed Register is set. Event N can be cleared through sw by writing 1 to the ECR pseudo-register. |                 |             |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |             |

|          |    |    |    |    |    |    |    |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
|----------|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |

| Bits  | Field Name | Description | Type | Reset |
|-------|------------|-------------|------|-------|
| 31:20 | Reserved   | Reserved    | R    | 0     |
| 19    | E19        | Event #19   | R    | 0     |
| 18    | E18        | Event #18   | R    | 0     |
| 17    | E17        | Event #17   | R    | 0     |
| 16    | E16        | Event #16   | R    | 0     |
| 15    | E15        | Event #15   | R    | 0     |
| 14    | E14        | Event #14   | R    | 0     |
| 13    | E13        | Event #13   | R    | 0     |
| 12    | E12        | Event #12   | R    | 0     |
| 11    | E11        | Event #11   | R    | 0     |
| 10    | E10        | Event #10   | R    | 0     |
| 9     | E9         | Event #9    | R    | 0     |
| 8     | E8         | Event #8    | R    | 0     |
| 7     | E7         | Event #7    | R    | 0     |
| 6     | E6         | Event #6    | R    | 0     |
| 5     | E5         | Event #5    | R    | 0     |
| 4     | E4         | Event #4    | R    | 0     |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 3    | E3         | Event #3    | R    | 0     |
| 2    | E2         | Event #2    | R    | 0     |
| 1    | E1         | Event #1    | R    | 0     |
| 0    | E0         | Event #0    | R    | 0     |

**Table 5-263. Register Call Summary for Register TPCC\_ER**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\] \[1\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[2\]](#)

**Table 5-264. TPCC\_ECR**

|                       |                                                                                                                                |                         |             |                 |             |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x1008                                                                                                                         | <b>Physical address</b> | 0x01C0 1008 | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>    | Event Clear Register:<br>CPU write of 1 to the ECR.En bit causes the ER.En bit to be cleared.<br>CPU write of 0 has no effect. |                         |             |                 |             |
| <b>Type</b>           | W                                                                                                                              |                         |             |                 |             |

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| 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  |
| E31 | E30 | E29 | E28 | E27 | E26 | E25 | E24 | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E31        | Event #31   | W    | 0     |
| 30   | E30        | Event #30   | W    | 0     |
| 29   | E29        | Event #29   | W    | 0     |
| 28   | E28        | Event #28   | W    | 0     |
| 27   | E27        | Event #27   | W    | 0     |
| 26   | E26        | Event #26   | W    | 0     |
| 25   | E25        | Event #25   | W    | 0     |
| 24   | E24        | Event #24   | W    | 0     |
| 23   | E23        | Event #23   | W    | 0     |
| 22   | E22        | Event #22   | W    | 0     |
| 21   | E21        | Event #21   | W    | 0     |
| 20   | E20        | Event #20   | W    | 0     |
| 19   | E19        | Event #19   | W    | 0     |
| 18   | E18        | Event #18   | W    | 0     |
| 17   | E17        | Event #17   | W    | 0     |
| 16   | E16        | Event #16   | W    | 0     |
| 15   | E15        | Event #15   | W    | 0     |
| 14   | E14        | Event #14   | W    | 0     |
| 13   | E13        | Event #13   | W    | 0     |
| 12   | E12        | Event #12   | W    | 0     |
| 11   | E11        | Event #11   | W    | 0     |
| 10   | E10        | Event #10   | W    | 0     |
| 9    | E9         | Event #9    | W    | 0     |
| 8    | E8         | Event #8    | W    | 0     |
| 7    | E7         | Event #7    | W    | 0     |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 6    | E6         | Event #6    | W    | 0     |
| 5    | E5         | Event #5    | W    | 0     |
| 4    | E4         | Event #4    | W    | 0     |
| 3    | E3         | Event #3    | W    | 0     |
| 2    | E2         | Event #2    | W    | 0     |
| 1    | E1         | Event #1    | W    | 0     |
| 0    | E0         | Event #0    | W    | 0     |

**Table 5-265. Register Call Summary for Register TPCC\_ECR**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-266. TPCC\_ECRH**

|                         |                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x100C                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 100C                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Event Clear Register (High Part):<br>CPU write of 1 to the ECRH.En bit causes the ERH.En bit to be cleared.<br>CPU write of 0 has no effect. |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

  

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 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   |
| E63 | E62 | E61 | E60 | E59 | E58 | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38 | E37 | E36 | E35 | E34 | E33 | E32 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E63        | Event #63   | W    | 0     |
| 30   | E62        | Event #62   | W    | 0     |
| 29   | E61        | Event #61   | W    | 0     |
| 28   | E60        | Event #60   | W    | 0     |
| 27   | E59        | Event #59   | W    | 0     |
| 26   | E58        | Event #58   | W    | 0     |
| 25   | E57        | Event #57   | W    | 0     |
| 24   | E56        | Event #56   | W    | 0     |
| 23   | E55        | Event #55   | W    | 0     |
| 22   | E54        | Event #54   | W    | 0     |
| 21   | E53        | Event #53   | W    | 0     |
| 20   | E52        | Event #52   | W    | 0     |
| 19   | E51        | Event #51   | W    | 0     |
| 18   | E50        | Event #50   | W    | 0     |
| 17   | E49        | Event #49   | W    | 0     |
| 16   | E48        | Event #48   | W    | 0     |
| 15   | E47        | Event #47   | W    | 0     |
| 14   | E46        | Event #46   | W    | 0     |
| 13   | E45        | Event #45   | W    | 0     |
| 12   | E44        | Event #44   | W    | 0     |
| 11   | E43        | Event #43   | W    | 0     |
| 10   | E42        | Event #42   | W    | 0     |
| 9    | E41        | Event #41   | W    | 0     |
| 8    | E40        | Event #40   | W    | 0     |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 7    | E39        | Event #39   | W    | 0     |
| 6    | E38        | Event #38   | W    | 0     |
| 5    | E37        | Event #37   | W    | 0     |
| 4    | E36        | Event #36   | W    | 0     |
| 3    | E35        | Event #35   | W    | 0     |
| 2    | E34        | Event #34   | W    | 0     |
| 1    | E33        | Event #33   | W    | 0     |
| 0    | E32        | Event #32   | W    | 0     |

**Table 5-267. Register Call Summary for Register TPCC\_ECRH**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-268. TPCC\_ESR**

|                         |                                                                                                                          |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |          |    |    |    |    |    |    |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----------|----|----|----|----|----|----|--|--|
| <b>Address Offset</b>   | 0x1010                                                                                                                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |          |    |    |    |    |    |    |  |  |
| <b>Physical address</b> | 0x01C0 1010                                                                                                              |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    | Instance |    |    |    |    |    |    |  |  |
| <b>Description</b>      | Event Set Register:<br>CPU write of 1 to the ESR.En bit causes the ER.En bit to be set.<br>CPU write of 0 has no effect. |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |          |    |    |    |    |    |    |  |  |
| <b>Type</b>             | W                                                                                                                        |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |          |    |    |    |    |    |    |  |  |
| 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  |  |  |
| E31                     | E30                                                                                                                      | E29 | E28 | E27 | E26 | E25 | E24 | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6       | E5 | E4 | E3 | E2 | E1 | E0 |  |  |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E31        | Event #31   | W    | 0     |
| 30   | E30        | Event #30   | W    | 0     |
| 29   | E29        | Event #29   | W    | 0     |
| 28   | E28        | Event #28   | W    | 0     |
| 27   | E27        | Event #27   | W    | 0     |
| 26   | E26        | Event #26   | W    | 0     |
| 25   | E25        | Event #25   | W    | 0     |
| 24   | E24        | Event #24   | W    | 0     |
| 23   | E23        | Event #23   | W    | 0     |
| 22   | E22        | Event #22   | W    | 0     |
| 21   | E21        | Event #21   | W    | 0     |
| 20   | E20        | Event #20   | W    | 0     |
| 19   | E19        | Event #19   | W    | 0     |
| 18   | E18        | Event #18   | W    | 0     |
| 17   | E17        | Event #17   | W    | 0     |
| 16   | E16        | Event #16   | W    | 0     |
| 15   | E15        | Event #15   | W    | 0     |
| 14   | E14        | Event #14   | W    | 0     |
| 13   | E13        | Event #13   | W    | 0     |
| 12   | E12        | Event #12   | W    | 0     |
| 11   | E11        | Event #11   | W    | 0     |
| 10   | E10        | Event #10   | W    | 0     |
| 9    | E9         | Event #9    | W    | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 8           | E8                | Event #8           | W           | 0            |
| 7           | E7                | Event #7           | W           | 0            |
| 6           | E6                | Event #6           | W           | 0            |
| 5           | E5                | Event #5           | W           | 0            |
| 4           | E4                | Event #4           | W           | 0            |
| 3           | E3                | Event #3           | W           | 0            |
| 2           | E2                | Event #2           | W           | 0            |
| 1           | E1                | Event #1           | W           | 0            |
| 0           | E0                | Event #0           | W           | 0            |

**Table 5-269. Register Call Summary for Register TPCC\_ESR**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#) [\[1\]](#) [\[2\]](#)

IVA2.2 Subsystem Basic Programming Model

- [Starting the Transfer: \[3\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[4\]](#)

**Table 5-270. TPCC\_ESRH**

|                         |                                                                                                                                       |                 |  |  |  |  |  |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x1014                                                                                                                                |                 |  |  |  |  |  |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 1014                                                                                                                           | <b>Instance</b> |  |  |  |  |  |  |  |  |  | IVA2.2 TPCC |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Event Set Register (High Part)<br>CPU write of 1 to the ESRH.En bit causes the ERH.En bit to be set.<br>CPU write of 0 has no effect. |                 |  |  |  |  |  |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                                                                                                                     |                 |  |  |  |  |  |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 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   |
| E63 | E62 | E61 | E60 | E59 | E58 | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38 | E37 | E36 | E35 | E34 | E33 | E32 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 31          | E63               | Event #63          | W           | 0            |
| 30          | E62               | Event #62          | W           | 0            |
| 29          | E61               | Event #61          | W           | 0            |
| 28          | E60               | Event #60          | W           | 0            |
| 27          | E59               | Event #59          | W           | 0            |
| 26          | E58               | Event #58          | W           | 0            |
| 25          | E57               | Event #57          | W           | 0            |
| 24          | E56               | Event #56          | W           | 0            |
| 23          | E55               | Event #55          | W           | 0            |
| 22          | E54               | Event #54          | W           | 0            |
| 21          | E53               | Event #53          | W           | 0            |
| 20          | E52               | Event #52          | W           | 0            |
| 19          | E51               | Event #51          | W           | 0            |
| 18          | E50               | Event #50          | W           | 0            |
| 17          | E49               | Event #49          | W           | 0            |
| 16          | E48               | Event #48          | W           | 0            |
| 15          | E47               | Event #47          | W           | 0            |
| 14          | E46               | Event #46          | W           | 0            |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 13   | E45        | Event #45   | W    | 0     |
| 12   | E44        | Event #44   | W    | 0     |
| 11   | E43        | Event #43   | W    | 0     |
| 10   | E42        | Event #42   | W    | 0     |
| 9    | E41        | Event #41   | W    | 0     |
| 8    | E40        | Event #40   | W    | 0     |
| 7    | E39        | Event #39   | W    | 0     |
| 6    | E38        | Event #38   | W    | 0     |
| 5    | E37        | Event #37   | W    | 0     |
| 4    | E36        | Event #36   | W    | 0     |
| 3    | E35        | Event #35   | W    | 0     |
| 2    | E34        | Event #34   | W    | 0     |
| 1    | E33        | Event #33   | W    | 0     |
| 0    | E32        | Event #32   | W    | 0     |

**Table 5-271. Register Call Summary for Register TPCC\_ESRH**

IVA2.2 Subsystem Functional Description

- EDMA: [0] [1]

IVA2.2 Subsystem Basic Programming Model

- Starting the Transfer: [2]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [3]

**Table 5-272. TPCC\_CER**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| <b>Address Offset</b>   | 0x1018                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                 |
| <b>Physical address</b> | 0x01C0 1018                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <b>Instance</b> |
| <b>Description</b>      | Chained Event Register:<br>If CER.En bit is set (regardless of state of EER.En), then the corresponding DMA channel is prioritized vs. other pending DMA events for submission to the TC. CER.En bit is set when a chaining completion code is returned from one of the TPTCs through the completion interface, or is generated internally through Early Completion path. CER.En bit is cleared when the corresponding event is prioritized and serviced. If the CER.En bit is already set and the corresponding chaining completion code is returned from the TC, then the corresponding bit in the Event Missed Register is set. CER.En cannot be set or cleared through software. |                 |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                 |

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| 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  |
| E31 | E30 | E29 | E28 | E27 | E26 | E25 | E24 | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E31        | Event #31   | R    | 0     |
| 30   | E30        | Event #30   | R    | 0     |
| 29   | E29        | Event #29   | R    | 0     |
| 28   | E28        | Event #28   | R    | 0     |
| 27   | E27        | Event #27   | R    | 0     |
| 26   | E26        | Event #26   | R    | 0     |
| 25   | E25        | Event #25   | R    | 0     |
| 24   | E24        | Event #24   | R    | 0     |
| 23   | E23        | Event #23   | R    | 0     |
| 22   | E22        | Event #22   | R    | 0     |
| 21   | E21        | Event #21   | R    | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 20          | E20               | Event #20          | R           | 0            |
| 19          | E19               | Event #19          | R           | 0            |
| 18          | E18               | Event #18          | R           | 0            |
| 17          | E17               | Event #17          | R           | 0            |
| 16          | E16               | Event #16          | R           | 0            |
| 15          | E15               | Event #15          | R           | 0            |
| 14          | E14               | Event #14          | R           | 0            |
| 13          | E13               | Event #13          | R           | 0            |
| 12          | E12               | Event #12          | R           | 0            |
| 11          | E11               | Event #11          | R           | 0            |
| 10          | E10               | Event #10          | R           | 0            |
| 9           | E9                | Event #9           | R           | 0            |
| 8           | E8                | Event #8           | R           | 0            |
| 7           | E7                | Event #7           | R           | 0            |
| 6           | E6                | Event #6           | R           | 0            |
| 5           | E5                | Event #5           | R           | 0            |
| 4           | E4                | Event #4           | R           | 0            |
| 3           | E3                | Event #3           | R           | 0            |
| 2           | E2                | Event #2           | R           | 0            |
| 1           | E1                | Event #1           | R           | 0            |
| 0           | E0                | Event #0           | R           | 0            |

**Table 5-273. Register Call Summary for Register TPCC\_CER**

IVA2.2 Subsystem Functional Description

- EDMA: [0] [1]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [2]

**Table 5-274. TPCC\_CERH**

|                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                         |             |                 |             |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x101C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>Physical address</b> | 0x01C0 101C | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>    | Chained Event Register (High Part):<br>If CERH.En bit is set (regardless of state of EERH.En), then the corresponding DMA channel is prioritized vs. other pending DMA events for submission to the TC. CERH.En bit is set when a chaining completion code is returned from one of the TPTCs through the completion interface, or is generated internally through Early Completion path. CERH.En bit is cleared when the corresponding event is prioritized and serviced. If the CERH.En bit is already set and the corresponding chaining completion code is returned from the TC, then the corresponding bit in the Event Missed Register is set. CERH.En cannot be set or cleared through software. |                         |             |                 |             |
| <b>Type</b>           | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                         |             |                 |             |

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 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   |
| E63 | E62 | E61 | E60 | E59 | E58 | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38 | E37 | E36 | E35 | E34 | E33 | E32 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 31          | E63               | Event #63          | R           | 0            |
| 30          | E62               | Event #62          | R           | 0            |
| 29          | E61               | Event #61          | R           | 0            |
| 28          | E60               | Event #60          | R           | 0            |
| 27          | E59               | Event #59          | R           | 0            |
| 26          | E58               | Event #58          | R           | 0            |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 25   | E57        | Event #57   | R    | 0     |
| 24   | E56        | Event #56   | R    | 0     |
| 23   | E55        | Event #55   | R    | 0     |
| 22   | E54        | Event #54   | R    | 0     |
| 21   | E53        | Event #53   | R    | 0     |
| 20   | E52        | Event #52   | R    | 0     |
| 19   | E51        | Event #51   | R    | 0     |
| 18   | E50        | Event #50   | R    | 0     |
| 17   | E49        | Event #49   | R    | 0     |
| 16   | E48        | Event #48   | R    | 0     |
| 15   | E47        | Event #47   | R    | 0     |
| 14   | E46        | Event #46   | R    | 0     |
| 13   | E45        | Event #45   | R    | 0     |
| 12   | E44        | Event #44   | R    | 0     |
| 11   | E43        | Event #43   | R    | 0     |
| 10   | E42        | Event #42   | R    | 0     |
| 9    | E41        | Event #41   | R    | 0     |
| 8    | E40        | Event #40   | R    | 0     |
| 7    | E39        | Event #39   | R    | 0     |
| 6    | E38        | Event #38   | R    | 0     |
| 5    | E37        | Event #37   | R    | 0     |
| 4    | E36        | Event #36   | R    | 0     |
| 3    | E35        | Event #35   | R    | 0     |
| 2    | E34        | Event #34   | R    | 0     |
| 1    | E33        | Event #33   | R    | 0     |
| 0    | E32        | Event #32   | R    | 0     |

**Table 5-275. Register Call Summary for Register TPCC\_CERH**

IVA2.2 Subsystem Functional Description

- EDMA: [0]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [1]

**Table 5-276. TPCC\_EER**

|                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                         |             |                 |             |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x1020                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <b>Physical address</b> | 0x01C0 1020 | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>    | Event Enable Register:<br>Enables DMA transfers for ER.En pending events. ER.En is set based on externally asserted events (through tpcc_eventN_pi). This register has no effect on Chained Event Register (CER) or Event Set Register (ESR). Note that if a bit is set in ER.En while EER.En is disabled, no action is taken. If EER.En is enabled at a later point (and ER.En has not been cleared through SW) then the event will be recognized as a valid TR Sync EER.En is not directly writeable. Events can be enabled through writes to EESR and can be disabled through writes to EECR register.<br>EER.En = 0: ER.En is not enabled to trigger DMA transfers.<br>EER.En = 1: ER.En is enabled to trigger DMA transfers. |                         |             |                 |             |
| <b>Type</b>           | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                         |             |                 |             |

|          |    |    |    |    |    |    |    |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
|----------|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 31:20       | Reserved          | Reserved           | R           | 0            |
| 19          | E19               | Event #19          | R           | 0            |
| 18          | E18               | Event #18          | R           | 0            |
| 17          | E17               | Event #17          | R           | 0            |
| 16          | E16               | Event #16          | R           | 0            |
| 15          | E15               | Event #15          | R           | 0            |
| 14          | E14               | Event #14          | R           | 0            |
| 13          | E13               | Event #13          | R           | 0            |
| 12          | E12               | Event #12          | R           | 0            |
| 11          | E11               | Event #11          | R           | 0            |
| 10          | E10               | Event #10          | R           | 0            |
| 9           | E9                | Event #9           | R           | 0            |
| 8           | E8                | Event #8           | R           | 0            |
| 7           | E7                | Event #7           | R           | 0            |
| 6           | E6                | Event #6           | R           | 0            |
| 5           | E5                | Event #5           | R           | 0            |
| 4           | E4                | Event #4           | R           | 0            |
| 3           | E3                | Event #3           | R           | 0            |
| 2           | E2                | Event #2           | R           | 0            |
| 1           | E1                | Event #1           | R           | 0            |
| 0           | E0                | Event #0           | R           | 0            |

**Table 5-277. Register Call Summary for Register TPCC\_EER**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#) [\[1\]](#)

IVA2.2 Subsystem Basic Programming Model

- [Starting the Transfer: \[2\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[3\]](#)

**Table 5-278. TPCC\_EECR**

|                       |                                                                                                                                         |                         |             |                 |             |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|
| <b>Address Offset</b> | 0x1028                                                                                                                                  | <b>Physical address</b> | 0x01C0 1028 | <b>Instance</b> | IVA2.2 TPCC |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |
| <b>Description</b>    | Event Enable Clear Register:<br>CPU write of 1 to the EECR.En bit causes the EER.En bit to be cleared.<br>CPU write of 0 has no effect. |                         |             |                 |             |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |
| <b>Type</b>           | W                                                                                                                                       |                         |             |                 |             |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |
| 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 |
| Reserved              |                                                                                                                                         |                         |             |                 |             | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 31:20       | Reserved          | Reserved           | W           | 0            |
| 19          | E19               | Event #19          | W           | 0            |
| 18          | E18               | Event #18          | W           | 0            |
| 17          | E17               | Event #17          | W           | 0            |
| 16          | E16               | Event #16          | W           | 0            |
| 15          | E15               | Event #15          | W           | 0            |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 14   | E14        | Event #14   | W    | 0     |
| 13   | E13        | Event #13   | W    | 0     |
| 12   | E12        | Event #12   | W    | 0     |
| 11   | E11        | Event #11   | W    | 0     |
| 10   | E10        | Event #10   | W    | 0     |
| 9    | E9         | Event #9    | W    | 0     |
| 8    | E8         | Event #8    | W    | 0     |
| 7    | E7         | Event #7    | W    | 0     |
| 6    | E6         | Event #6    | W    | 0     |
| 5    | E5         | Event #5    | W    | 0     |
| 4    | E4         | Event #4    | W    | 0     |
| 3    | E3         | Event #3    | W    | 0     |
| 2    | E2         | Event #2    | W    | 0     |
| 1    | E1         | Event #1    | W    | 0     |
| 0    | E0         | Event #0    | W    | 0     |

**Table 5-279. Register Call Summary for Register TPCC\_EECR**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-280. TPCC\_EESR**

|                         |                                                                                                                                   |                                               |                         |                 |             |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|-------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x1030                                                                                                                            | <b>Physical address</b>                       | 0x01C0 1030             | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>      | Event Enable Set Register:<br>CPU write of 1 to the EESR.En bit causes the EER.En bit to be set.<br>CPU write of 0 has no effect. |                                               |                         |                 |             |
| <b>Type</b>             | W                                                                                                                                 |                                               |                         |                 |             |
| 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         |                 |             |
| Reserved                |                                                                                                                                   | E19 E18 E17 E16 E15 E14 E13 E12 E11 E10 E9 E8 | E7 E6 E5 E4 E3 E2 E1 E0 |                 |             |

| Bits  | Field Name | Description | Type | Reset |
|-------|------------|-------------|------|-------|
| 31:20 | Reserved   | Reserved    | W    | 0     |
| 19    | E19        | Event #19   | W    | 0     |
| 18    | E18        | Event #18   | W    | 0     |
| 17    | E17        | Event #17   | W    | 0     |
| 16    | E16        | Event #16   | W    | 0     |
| 15    | E15        | Event #15   | W    | 0     |
| 14    | E14        | Event #14   | W    | 0     |
| 13    | E13        | Event #13   | W    | 0     |
| 12    | E12        | Event #12   | W    | 0     |
| 11    | E11        | Event #11   | W    | 0     |
| 10    | E10        | Event #10   | W    | 0     |
| 9     | E9         | Event #9    | W    | 0     |
| 8     | E8         | Event #8    | W    | 0     |
| 7     | E7         | Event #7    | W    | 0     |
| 6     | E6         | Event #6    | W    | 0     |
| 5     | E5         | Event #5    | W    | 0     |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 4    | E4         | Event #4    | W    | 0     |
| 3    | E3         | Event #3    | W    | 0     |
| 2    | E2         | Event #2    | W    | 0     |
| 1    | E1         | Event #1    | W    | 0     |
| 0    | E0         | Event #0    | W    | 0     |

**Table 5-281. Register Call Summary for Register TPCC\_EESR**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-282. TPCC\_SER**

|                         |                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x1038                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 1038                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Secondary Event Register:<br>The secondary event register is used along with the Event Register (ER) to provide information on the state of an Event.<br>En = 0: Event is not currently in the Event Queue.<br>En = 1: Event is currently stored in Event Queue. Event arbiter will not prioritize additional events. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| 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  |
| E31 | E30 | E29 | E28 | E27 | E26 | E25 | E24 | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E31        | Event #31   | R    | 0     |
| 30   | E30        | Event #30   | R    | 0     |
| 29   | E29        | Event #29   | R    | 0     |
| 28   | E28        | Event #28   | R    | 0     |
| 27   | E27        | Event #27   | R    | 0     |
| 26   | E26        | Event #26   | R    | 0     |
| 25   | E25        | Event #25   | R    | 0     |
| 24   | E24        | Event #24   | R    | 0     |
| 23   | E23        | Event #23   | R    | 0     |
| 22   | E22        | Event #22   | R    | 0     |
| 21   | E21        | Event #21   | R    | 0     |
| 20   | E20        | Event #20   | R    | 0     |
| 19   | E19        | Event #19   | R    | 0     |
| 18   | E18        | Event #18   | R    | 0     |
| 17   | E17        | Event #17   | R    | 0     |
| 16   | E16        | Event #16   | R    | 0     |
| 15   | E15        | Event #15   | R    | 0     |
| 14   | E14        | Event #14   | R    | 0     |
| 13   | E13        | Event #13   | R    | 0     |
| 12   | E12        | Event #12   | R    | 0     |
| 11   | E11        | Event #11   | R    | 0     |
| 10   | E10        | Event #10   | R    | 0     |
| 9    | E9         | Event #9    | R    | 0     |
| 8    | E8         | Event #8    | R    | 0     |
| 7    | E7         | Event #7    | R    | 0     |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 6    | E6         | Event #6    | R    | 0     |
| 5    | E5         | Event #5    | R    | 0     |
| 4    | E4         | Event #4    | R    | 0     |
| 3    | E3         | Event #3    | R    | 0     |
| 2    | E2         | Event #2    | R    | 0     |
| 1    | E1         | Event #1    | R    | 0     |
| 0    | E0         | Event #0    | R    | 0     |

**Table 5-283. Register Call Summary for Register TPCC\_SER**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-284. TPCC\_SERH**

|                         |                                                                                                                                                                                                                                                                                                                                    |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                      |     |     |     |     |     |     |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----------------------|-----|-----|-----|-----|-----|-----|
| <b>Address Offset</b>   | 0x103C                                                                                                                                                                                                                                                                                                                             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                      |     |     |     |     |     |     |
| <b>Physical address</b> | 0x01C0 103C                                                                                                                                                                                                                                                                                                                        |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     | Instance IVA2.2 TPCC |     |     |     |     |     |     |
| <b>Description</b>      | Secondary Event Register (High Part):<br>The secondary event register is used along with the Event Register (ERH) to provide information on the state of an Event.<br>En = 0: Event is not currently in the Event Queue.<br>En = 1: Event is currently stored in Event Queue. Event arbiter will not prioritize additional events. |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                      |     |     |     |     |     |     |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                      |     |     |     |     |     |     |
| 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   |
| E63                     | E62                                                                                                                                                                                                                                                                                                                                | E61 | E60 | E59 | E58 | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38                  | E37 | E36 | E35 | E34 | E33 | E32 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E63        | Event #63   | R    | 0     |
| 30   | E62        | Event #62   | R    | 0     |
| 29   | E61        | Event #61   | R    | 0     |
| 28   | E60        | Event #60   | R    | 0     |
| 27   | E59        | Event #59   | R    | 0     |
| 26   | E58        | Event #58   | R    | 0     |
| 25   | E57        | Event #57   | R    | 0     |
| 24   | E56        | Event #56   | R    | 0     |
| 23   | E55        | Event #55   | R    | 0     |
| 22   | E54        | Event #54   | R    | 0     |
| 21   | E53        | Event #53   | R    | 0     |
| 20   | E52        | Event #52   | R    | 0     |
| 19   | E51        | Event #51   | R    | 0     |
| 18   | E50        | Event #50   | R    | 0     |
| 17   | E49        | Event #49   | R    | 0     |
| 16   | E48        | Event #48   | R    | 0     |
| 15   | E47        | Event #47   | R    | 0     |
| 14   | E46        | Event #46   | R    | 0     |
| 13   | E45        | Event #45   | R    | 0     |
| 12   | E44        | Event #44   | R    | 0     |
| 11   | E43        | Event #43   | R    | 0     |
| 10   | E42        | Event #42   | R    | 0     |
| 9    | E41        | Event #41   | R    | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 8           | E40               | Event #40          | R           | 0            |
| 7           | E39               | Event #39          | R           | 0            |
| 6           | E38               | Event #38          | R           | 0            |
| 5           | E37               | Event #37          | R           | 0            |
| 4           | E36               | Event #36          | R           | 0            |
| 3           | E35               | Event #35          | R           | 0            |
| 2           | E34               | Event #34          | R           | 0            |
| 1           | E33               | Event #33          | R           | 0            |
| 0           | E32               | Event #32          | R           | 0            |

**Table 5-285. Register Call Summary for Register TPCC\_SERH**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-286. TPCC\_SECR**

|                       |                                                                                                                                                                                                                        |                         |             |                 |             |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x1040                                                                                                                                                                                                                 | <b>Physical address</b> | 0x01C0 1040 | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>    | Secondary Event Clear Register:<br>The secondary event clear register is used to clear the status of the SER registers.<br>CPU write of 1 to the SECR.EN bit clears the SER register.<br>CPU write of 0 has no effect. |                         |             |                 |             |
| <b>Type</b>           | W                                                                                                                                                                                                                      |                         |             |                 |             |

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| 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  |
| E31 | E30 | E29 | E28 | E27 | E26 | E25 | E24 | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 31          | E31               | Event #31          | W           | 0            |
| 30          | E30               | Event #30          | W           | 0            |
| 29          | E29               | Event #29          | W           | 0            |
| 28          | E28               | Event #28          | W           | 0            |
| 27          | E27               | Event #27          | W           | 0            |
| 26          | E26               | Event #26          | W           | 0            |
| 25          | E25               | Event #25          | W           | 0            |
| 24          | E24               | Event #24          | W           | 0            |
| 23          | E23               | Event #23          | W           | 0            |
| 22          | E22               | Event #22          | W           | 0            |
| 21          | E21               | Event #21          | W           | 0            |
| 20          | E20               | Event #20          | W           | 0            |
| 19          | E19               | Event #19          | W           | 0            |
| 18          | E18               | Event #18          | W           | 0            |
| 17          | E17               | Event #17          | W           | 0            |
| 16          | E16               | Event #16          | W           | 0            |
| 15          | E15               | Event #15          | W           | 0            |
| 14          | E14               | Event #14          | W           | 0            |
| 13          | E13               | Event #13          | W           | 0            |
| 12          | E12               | Event #12          | W           | 0            |
| 11          | E11               | Event #11          | W           | 0            |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 10   | E10        | Event #10   | W    | 0     |
| 9    | E9         | Event #9    | W    | 0     |
| 8    | E8         | Event #8    | W    | 0     |
| 7    | E7         | Event #7    | W    | 0     |
| 6    | E6         | Event #6    | W    | 0     |
| 5    | E5         | Event #5    | W    | 0     |
| 4    | E4         | Event #4    | W    | 0     |
| 3    | E3         | Event #3    | W    | 0     |
| 2    | E2         | Event #2    | W    | 0     |
| 1    | E1         | Event #1    | W    | 0     |
| 0    | E0         | Event #0    | W    | 0     |

**Table 5-287. Register Call Summary for Register TPCC\_SECR**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-288. TPCC\_SECRH**

|                       |                                                                                                                                                                                                                                       |                         |             |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| <b>Address Offset</b> | 0x1044                                                                                                                                                                                                                                | <b>Physical address</b> | 0x01C0 1044 | <b>Instance</b> | IVA2.2 TPCC |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| <b>Description</b>    | Secondary Event Clear Register (High Part):<br>The secondary event clear register is used to clear the status of the SERH registers.<br>CPU write of 1 to the SECRH.EN bit clears the SERH register.<br>CPU write of 0 has no effect. |                         |             |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| <b>Type</b>           | W                                                                                                                                                                                                                                     |                         |             |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 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   |
| E63                   | E62                                                                                                                                                                                                                                   | E61                     | E60         | E59             | E58         | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38 | E37 | E36 | E35 | E34 | E33 | E32 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E63        | Event #63   | W    | 0     |
| 30   | E62        | Event #62   | W    | 0     |
| 29   | E61        | Event #61   | W    | 0     |
| 28   | E60        | Event #60   | W    | 0     |
| 27   | E59        | Event #59   | W    | 0     |
| 26   | E58        | Event #58   | W    | 0     |
| 25   | E57        | Event #57   | W    | 0     |
| 24   | E56        | Event #56   | W    | 0     |
| 23   | E55        | Event #55   | W    | 0     |
| 22   | E54        | Event #54   | W    | 0     |
| 21   | E53        | Event #53   | W    | 0     |
| 20   | E52        | Event #52   | W    | 0     |
| 19   | E51        | Event #51   | W    | 0     |
| 18   | E50        | Event #50   | W    | 0     |
| 17   | E49        | Event #49   | W    | 0     |
| 16   | E48        | Event #48   | W    | 0     |
| 15   | E47        | Event #47   | W    | 0     |
| 14   | E46        | Event #46   | W    | 0     |
| 13   | E45        | Event #45   | W    | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 12          | E44               | Event #44          | W           | 0            |
| 11          | E43               | Event #43          | W           | 0            |
| 10          | E42               | Event #42          | W           | 0            |
| 9           | E41               | Event #41          | W           | 0            |
| 8           | E40               | Event #40          | W           | 0            |
| 7           | E39               | Event #39          | W           | 0            |
| 6           | E38               | Event #38          | W           | 0            |
| 5           | E37               | Event #37          | W           | 0            |
| 4           | E36               | Event #36          | W           | 0            |
| 3           | E35               | Event #35          | W           | 0            |
| 2           | E34               | Event #34          | W           | 0            |
| 1           | E33               | Event #33          | W           | 0            |
| 0           | E32               | Event #32          | W           | 0            |

**Table 5-289. Register Call Summary for Register TPCC\_SECRH**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-290. TPCC\_IER**

|                         |                                                                                                                                                                                                                                                                       |                 |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| <b>Address Offset</b>   | 0x1050                                                                                                                                                                                                                                                                |                 |
| <b>Physical address</b> | 0x01C0 1050                                                                                                                                                                                                                                                           | <b>Instance</b> |
| <b>Description</b>      | Int Enable Register:<br>IER.In is not directly writeable. Interrupts can be enabled through writes to IESR and can be disabled through writes to IECR register.<br>IER.In = 0: IPR.In is NOT enabled for interrupts.<br>IER.In = 1: IPR.In IS enabled for interrupts. |                 |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                     |                 |

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| 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  |
| I31 | I30 | I29 | I28 | I27 | I26 | I25 | I24 | I23 | I22 | I21 | I20 | I19 | I18 | I17 | I16 | I15 | I14 | I13 | I12 | I11 | I10 | I9 | I8 | I7 | I6 | I5 | I4 | I3 | I2 | I1 | I0 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31          | I31               | Interrupt associated with TCC #31 | R           | 0            |
| 30          | I30               | Interrupt associated with TCC #30 | R           | 0            |
| 29          | I29               | Interrupt associated with TCC #29 | R           | 0            |
| 28          | I28               | Interrupt associated with TCC #28 | R           | 0            |
| 27          | I27               | Interrupt associated with TCC #27 | R           | 0            |
| 26          | I26               | Interrupt associated with TCC #26 | R           | 0            |
| 25          | I25               | Interrupt associated with TCC #25 | R           | 0            |
| 24          | I24               | Interrupt associated with TCC #24 | R           | 0            |
| 23          | I23               | Interrupt associated with TCC #23 | R           | 0            |
| 22          | I22               | Interrupt associated with TCC #22 | R           | 0            |
| 21          | I21               | Interrupt associated with TCC #21 | R           | 0            |
| 20          | I20               | Interrupt associated with TCC #20 | R           | 0            |
| 19          | I19               | Interrupt associated with TCC #19 | R           | 0            |
| 18          | I18               | Interrupt associated with TCC #18 | R           | 0            |
| 17          | I17               | Interrupt associated with TCC #17 | R           | 0            |
| 16          | I16               | Interrupt associated with TCC #16 | R           | 0            |
| 15          | I15               | Interrupt associated with TCC #15 | R           | 0            |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 14   | I14        | Interrupt associated with TCC #14 | R    | 0     |
| 13   | I13        | Interrupt associated with TCC #13 | R    | 0     |
| 12   | I12        | Interrupt associated with TCC #12 | R    | 0     |
| 11   | I11        | Interrupt associated with TCC #11 | R    | 0     |
| 10   | I10        | Interrupt associated with TCC #10 | R    | 0     |
| 9    | I9         | Interrupt associated with TCC #9  | R    | 0     |
| 8    | I8         | Interrupt associated with TCC #8  | R    | 0     |
| 7    | I7         | Interrupt associated with TCC #7  | R    | 0     |
| 6    | I6         | Interrupt associated with TCC #6  | R    | 0     |
| 5    | I5         | Interrupt associated with TCC #5  | R    | 0     |
| 4    | I4         | Interrupt associated with TCC #4  | R    | 0     |
| 3    | I3         | Interrupt associated with TCC #3  | R    | 0     |
| 2    | I2         | Interrupt associated with TCC #2  | R    | 0     |
| 1    | I1         | Interrupt associated with TCC #1  | R    | 0     |
| 0    | I0         | Interrupt associated with TCC #0  | R    | 0     |

**Table 5-291. Register Call Summary for Register TPCC\_IER**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-292. TPCC\_IERH**

|                                              |                                                                                                                                                                                                                                                                                          |                                            |                                      |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|--------------------------------------|-----------------|-------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| <b>Address Offset</b>                        | 0x1054                                                                                                                                                                                                                                                                                   | <b>Physical address</b>                    | 0x01C0 1054                          | <b>Instance</b> | IVA2.2 TPCC |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| <b>Description</b>                           | Int Enable Register (High Part):<br>IERH.In is not directly writeable. Interrupts can be enabled through writes to IESRH and can be disabled through writes to IECRH register.<br>IERH.In = 0: IPRH.In is NOT enabled for interrupts.<br>IERH.In = 1: IPRH.In IS enabled for interrupts. |                                            |                                      |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| <b>Type</b>                                  | R                                                                                                                                                                                                                                                                                        |                                            |                                      |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 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 |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| I63                                          | I62                                                                                                                                                                                                                                                                                      | I61                                        | I60                                  | I59             | I58         | I57 | I56 | I55 | I54 | I53 | I52 | I51 | I50 | I49 | I48 | I47 | I46 | I45 | I44 | I43 | I42 | I41 | I40 | I39 | I38 | I37 | I36 | I35 | I34 | I33 | I32 |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 31   | I63        | Interrupt associated with TCC #63 | R    | 0     |
| 30   | I62        | Interrupt associated with TCC #62 | R    | 0     |
| 29   | I61        | Interrupt associated with TCC #61 | R    | 0     |
| 28   | I60        | Interrupt associated with TCC #60 | R    | 0     |
| 27   | I59        | Interrupt associated with TCC #59 | R    | 0     |
| 26   | I58        | Interrupt associated with TCC #58 | R    | 0     |
| 25   | I57        | Interrupt associated with TCC #57 | R    | 0     |
| 24   | I56        | Interrupt associated with TCC #56 | R    | 0     |
| 23   | I55        | Interrupt associated with TCC #55 | R    | 0     |
| 22   | I54        | Interrupt associated with TCC #54 | R    | 0     |
| 21   | I53        | Interrupt associated with TCC #53 | R    | 0     |
| 20   | I52        | Interrupt associated with TCC #52 | R    | 0     |
| 19   | I51        | Interrupt associated with TCC #51 | R    | 0     |
| 18   | I50        | Interrupt associated with TCC #50 | R    | 0     |
| 17   | I49        | Interrupt associated with TCC #49 | R    | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 16          | I48               | Interrupt associated with TCC #48 | R           | 0            |
| 15          | I47               | Interrupt associated with TCC #47 | R           | 0            |
| 14          | I46               | Interrupt associated with TCC #46 | R           | 0            |
| 13          | I45               | Interrupt associated with TCC #45 | R           | 0            |
| 12          | I44               | Interrupt associated with TCC #44 | R           | 0            |
| 11          | I43               | Interrupt associated with TCC #43 | R           | 0            |
| 10          | I42               | Interrupt associated with TCC #42 | R           | 0            |
| 9           | I41               | Interrupt associated with TCC #41 | R           | 0            |
| 8           | I40               | Interrupt associated with TCC #40 | R           | 0            |
| 7           | I39               | Interrupt associated with TCC #39 | R           | 0            |
| 6           | I38               | Interrupt associated with TCC #38 | R           | 0            |
| 5           | I37               | Interrupt associated with TCC #37 | R           | 0            |
| 4           | I36               | Interrupt associated with TCC #36 | R           | 0            |
| 3           | I35               | Interrupt associated with TCC #35 | R           | 0            |
| 2           | I34               | Interrupt associated with TCC #34 | R           | 0            |
| 1           | I33               | Interrupt associated with TCC #33 | R           | 0            |
| 0           | I32               | Interrupt associated with TCC #32 | R           | 0            |

**Table 5-293. Register Call Summary for Register TPCC\_IERH**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-294. TPCC\_IECR**

|                       |                                                                                                                                       |                         |             |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| <b>Address Offset</b> | 0x1058                                                                                                                                | <b>Physical address</b> | 0x01C0 1058 | <b>Instance</b> | IVA2.2 TPCC |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
| <b>Description</b>    | Int Enable Clear Register:<br>CPU write of 1 to the IECR.In bit causes the IER.In bit to be cleared.<br>CPU write of 0 has no effect. |                         |             |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>           | W                                                                                                                                     |                         |             |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
| 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  |
| I31                   | I30                                                                                                                                   | I29                     | I28         | I27             | I26         | I25 | I24 | I23 | I22 | I21 | I20 | I19 | I18 | I17 | I16 | I15 | I14 | I13 | I12 | I11 | I10 | I9 | I8 | I7 | I6 | I5 | I4 | I3 | I2 | I1 | I0 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31          | I31               | Interrupt associated with TCC #31 | W           | 0            |
| 30          | I30               | Interrupt associated with TCC #30 | W           | 0            |
| 29          | I29               | Interrupt associated with TCC #29 | W           | 0            |
| 28          | I28               | Interrupt associated with TCC #28 | W           | 0            |
| 27          | I27               | Interrupt associated with TCC #27 | W           | 0            |
| 26          | I26               | Interrupt associated with TCC #26 | W           | 0            |
| 25          | I25               | Interrupt associated with TCC #25 | W           | 0            |
| 24          | I24               | Interrupt associated with TCC #24 | W           | 0            |
| 23          | I23               | Interrupt associated with TCC #23 | W           | 0            |
| 22          | I22               | Interrupt associated with TCC #22 | W           | 0            |
| 21          | I21               | Interrupt associated with TCC #21 | W           | 0            |
| 20          | I20               | Interrupt associated with TCC #20 | W           | 0            |
| 19          | I19               | Interrupt associated with TCC #19 | W           | 0            |
| 18          | I18               | Interrupt associated with TCC #18 | W           | 0            |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 17   | I17        | Interrupt associated with TCC #17 | W    | 0     |
| 16   | I16        | Interrupt associated with TCC #16 | W    | 0     |
| 15   | I15        | Interrupt associated with TCC #15 | W    | 0     |
| 14   | I14        | Interrupt associated with TCC #14 | W    | 0     |
| 13   | I13        | Interrupt associated with TCC #13 | W    | 0     |
| 12   | I12        | Interrupt associated with TCC #12 | W    | 0     |
| 11   | I11        | Interrupt associated with TCC #11 | W    | 0     |
| 10   | I10        | Interrupt associated with TCC #10 | W    | 0     |
| 9    | I9         | Interrupt associated with TCC #9  | W    | 0     |
| 8    | I8         | Interrupt associated with TCC #8  | W    | 0     |
| 7    | I7         | Interrupt associated with TCC #7  | W    | 0     |
| 6    | I6         | Interrupt associated with TCC #6  | W    | 0     |
| 5    | I5         | Interrupt associated with TCC #5  | W    | 0     |
| 4    | I4         | Interrupt associated with TCC #4  | W    | 0     |
| 3    | I3         | Interrupt associated with TCC #3  | W    | 0     |
| 2    | I2         | Interrupt associated with TCC #2  | W    | 0     |
| 1    | I1         | Interrupt associated with TCC #1  | W    | 0     |
| 0    | I0         | Interrupt associated with TCC #0  | W    | 0     |

**Table 5-295. Register Call Summary for Register TPCC\_IECR**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-296. TPCC\_IECRH**

|                         |                                                                                                                                                     |                 |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| <b>Address Offset</b>   | 0x105C                                                                                                                                              |                 |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| <b>Physical address</b> | 0x01C0 105C                                                                                                                                         | <b>Instance</b> |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| <b>Description</b>      | Int Enable Clear Register (High Part):<br>CPU write of 1 to the IECRH.In bit causes the IERH.In bit to be cleared.<br>CPU write of 0 has no effect. |                 |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| <b>Type</b>             | W                                                                                                                                                   |                 |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 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   |
| I63                     | I62                                                                                                                                                 | I61             | I60 | I59 | I58 | I57 | I56 | I55 | I54 | I53 | I52 | I51 | I50 | I49 | I48 | I47 | I46 | I45 | I44 | I43 | I42 | I41 | I40 | I39 | I38 | I37 | I36 | I35 | I34 | I33 | I32 |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 31   | I63        | Interrupt associated with TCC #63 | W    | 0     |
| 30   | I62        | Interrupt associated with TCC #62 | W    | 0     |
| 29   | I61        | Interrupt associated with TCC #61 | W    | 0     |
| 28   | I60        | Interrupt associated with TCC #60 | W    | 0     |
| 27   | I59        | Interrupt associated with TCC #59 | W    | 0     |
| 26   | I58        | Interrupt associated with TCC #58 | W    | 0     |
| 25   | I57        | Interrupt associated with TCC #57 | W    | 0     |
| 24   | I56        | Interrupt associated with TCC #56 | W    | 0     |
| 23   | I55        | Interrupt associated with TCC #55 | W    | 0     |
| 22   | I54        | Interrupt associated with TCC #54 | W    | 0     |
| 21   | I53        | Interrupt associated with TCC #53 | W    | 0     |
| 20   | I52        | Interrupt associated with TCC #52 | W    | 0     |
| 19   | I51        | Interrupt associated with TCC #51 | W    | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 18          | I50               | Interrupt associated with TCC #50 | W           | 0            |
| 17          | I49               | Interrupt associated with TCC #49 | W           | 0            |
| 16          | I48               | Interrupt associated with TCC #48 | W           | 0            |
| 15          | I47               | Interrupt associated with TCC #47 | W           | 0            |
| 14          | I46               | Interrupt associated with TCC #46 | W           | 0            |
| 13          | I45               | Interrupt associated with TCC #45 | W           | 0            |
| 12          | I44               | Interrupt associated with TCC #44 | W           | 0            |
| 11          | I43               | Interrupt associated with TCC #43 | W           | 0            |
| 10          | I42               | Interrupt associated with TCC #42 | W           | 0            |
| 9           | I41               | Interrupt associated with TCC #41 | W           | 0            |
| 8           | I40               | Interrupt associated with TCC #40 | W           | 0            |
| 7           | I39               | Interrupt associated with TCC #39 | W           | 0            |
| 6           | I38               | Interrupt associated with TCC #38 | W           | 0            |
| 5           | I37               | Interrupt associated with TCC #37 | W           | 0            |
| 4           | I36               | Interrupt associated with TCC #36 | W           | 0            |
| 3           | I35               | Interrupt associated with TCC #35 | W           | 0            |
| 2           | I34               | Interrupt associated with TCC #34 | W           | 0            |
| 1           | I33               | Interrupt associated with TCC #33 | W           | 0            |
| 0           | I32               | Interrupt associated with TCC #32 | W           | 0            |

**Table 5-297. Register Call Summary for Register TPCC\_IECRH**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-298. TPCCIESR**

|                                 |                                                                                                                                  |                         |                               |                         |             |
|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------------------------|-------------------------|-------------|
| <b>Address Offset</b>           | 0x1060                                                                                                                           | <b>Physical address</b> | 0x01C0 1060                   | <b>Instance</b>         | IVA2.2 TPCC |
| <b>Description</b>              | Int Enable Set Register:<br>CPU write of 1 to the IESR.In bit causes the IESR.In bit to be set.<br>CPU write of 0 has no effect. |                         |                               |                         |             |
| <b>Type</b>                     | W                                                                                                                                |                         |                               |                         |             |
| 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         |             |
| I31 I30 I29 I28 I27 I26 I25 I24 | I23 I22 I21 I20 I19 I18 I17 I16                                                                                                  |                         | I15 I14 I13 I12 I11 I10 I9 I8 | I7 I6 I5 I4 I3 I2 I1 I0 |             |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31          | I31               | Interrupt associated with TCC #31 | W           | 0            |
| 30          | I30               | Interrupt associated with TCC #30 | W           | 0            |
| 29          | I29               | Interrupt associated with TCC #29 | W           | 0            |
| 28          | I28               | Interrupt associated with TCC #28 | W           | 0            |
| 27          | I27               | Interrupt associated with TCC #27 | W           | 0            |
| 26          | I26               | Interrupt associated with TCC #26 | W           | 0            |
| 25          | I25               | Interrupt associated with TCC #25 | W           | 0            |
| 24          | I24               | Interrupt associated with TCC #24 | W           | 0            |
| 23          | I23               | Interrupt associated with TCC #23 | W           | 0            |
| 22          | I22               | Interrupt associated with TCC #22 | W           | 0            |
| 21          | I21               | Interrupt associated with TCC #21 | W           | 0            |
| 20          | I20               | Interrupt associated with TCC #20 | W           | 0            |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 19   | I19        | Interrupt associated with TCC #19 | W    | 0     |
| 18   | I18        | Interrupt associated with TCC #18 | W    | 0     |
| 17   | I17        | Interrupt associated with TCC #17 | W    | 0     |
| 16   | I16        | Interrupt associated with TCC #16 | W    | 0     |
| 15   | I15        | Interrupt associated with TCC #15 | W    | 0     |
| 14   | I14        | Interrupt associated with TCC #14 | W    | 0     |
| 13   | I13        | Interrupt associated with TCC #13 | W    | 0     |
| 12   | I12        | Interrupt associated with TCC #12 | W    | 0     |
| 11   | I11        | Interrupt associated with TCC #11 | W    | 0     |
| 10   | I10        | Interrupt associated with TCC #10 | W    | 0     |
| 9    | I9         | Interrupt associated with TCC #9  | W    | 0     |
| 8    | I8         | Interrupt associated with TCC #8  | W    | 0     |
| 7    | I7         | Interrupt associated with TCC #7  | W    | 0     |
| 6    | I6         | Interrupt associated with TCC #6  | W    | 0     |
| 5    | I5         | Interrupt associated with TCC #5  | W    | 0     |
| 4    | I4         | Interrupt associated with TCC #4  | W    | 0     |
| 3    | I3         | Interrupt associated with TCC #3  | W    | 0     |
| 2    | I2         | Interrupt associated with TCC #2  | W    | 0     |
| 1    | I1         | Interrupt associated with TCC #1  | W    | 0     |
| 0    | I0         | Interrupt associated with TCC #0  | W    | 0     |

**Table 5-299. Register Call Summary for Register TPCCIESR**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-300. TPCCIESRH**

|                         |                                                                                                                                                |          |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| <b>Address Offset</b>   | 0x1064                                                                                                                                         |          |
| <b>Physical address</b> | 0x01C0 1064                                                                                                                                    | Instance |
| <b>Description</b>      | Int Enable Set Register (High Part):<br>CPU write of 1 to the IESRH.In bit causes the IESRH.In bit to be set.<br>CPU write of 0 has no effect. |          |
| Type                    | W                                                                                                                                              |          |

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 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  |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 31   | I63        | Interrupt associated with TCC #63 | W    | 0     |
| 30   | I62        | Interrupt associated with TCC #62 | W    | 0     |
| 29   | I61        | Interrupt associated with TCC #61 | W    | 0     |
| 28   | I60        | Interrupt associated with TCC #60 | W    | 0     |
| 27   | I59        | Interrupt associated with TCC #59 | W    | 0     |
| 26   | I58        | Interrupt associated with TCC #58 | W    | 0     |
| 25   | I57        | Interrupt associated with TCC #57 | W    | 0     |
| 24   | I56        | Interrupt associated with TCC #56 | W    | 0     |
| 23   | I55        | Interrupt associated with TCC #55 | W    | 0     |
| 22   | I54        | Interrupt associated with TCC #54 | W    | 0     |
| 21   | I53        | Interrupt associated with TCC #53 | W    | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 20          | I52               | Interrupt associated with TCC #52 | W           | 0            |
| 19          | I51               | Interrupt associated with TCC #51 | W           | 0            |
| 18          | I50               | Interrupt associated with TCC #50 | W           | 0            |
| 17          | I49               | Interrupt associated with TCC #49 | W           | 0            |
| 16          | I48               | Interrupt associated with TCC #48 | W           | 0            |
| 15          | I47               | Interrupt associated with TCC #47 | W           | 0            |
| 14          | I46               | Interrupt associated with TCC #46 | W           | 0            |
| 13          | I45               | Interrupt associated with TCC #45 | W           | 0            |
| 12          | I44               | Interrupt associated with TCC #44 | W           | 0            |
| 11          | I43               | Interrupt associated with TCC #43 | W           | 0            |
| 10          | I42               | Interrupt associated with TCC #42 | W           | 0            |
| 9           | I41               | Interrupt associated with TCC #41 | W           | 0            |
| 8           | I40               | Interrupt associated with TCC #40 | W           | 0            |
| 7           | I39               | Interrupt associated with TCC #39 | W           | 0            |
| 6           | I38               | Interrupt associated with TCC #38 | W           | 0            |
| 5           | I37               | Interrupt associated with TCC #37 | W           | 0            |
| 4           | I36               | Interrupt associated with TCC #36 | W           | 0            |
| 3           | I35               | Interrupt associated with TCC #35 | W           | 0            |
| 2           | I34               | Interrupt associated with TCC #34 | W           | 0            |
| 1           | I33               | Interrupt associated with TCC #33 | W           | 0            |
| 0           | I32               | Interrupt associated with TCC #32 | W           | 0            |

**Table 5-301. Register Call Summary for Register TPCCIESRH**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-302. TPCC\_IPR**

|                       |                                                                                                                                                                                    |                         |             |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| <b>Address Offset</b> | 0x1068                                                                                                                                                                             | <b>Physical address</b> | 0x01C0 1068 | <b>Instance</b> | IVA2.2 TPCC |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
| <b>Description</b>    | Interrupt Pending Register:<br>IPR.In bit is set when a interrupt completion code with TCC of N is detected.<br>IPR.In bit is cleared through software by writing 1 to ICR.In bit. |                         |             |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>           | R                                                                                                                                                                                  |                         |             |                 |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
| 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  |
| I31                   | I30                                                                                                                                                                                | I29                     | I28         | I27             | I26         | I25 | I24 | I23 | I22 | I21 | I20 | I19 | I18 | I17 | I16 | I15 | I14 | I13 | I12 | I11 | I10 | I9 | I8 | I7 | I6 | I5 | I4 | I3 | I2 | I1 | I0 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31          | I31               | Interrupt associated with TCC #31 | R           | 0            |
| 30          | I30               | Interrupt associated with TCC #30 | R           | 0            |
| 29          | I29               | Interrupt associated with TCC #29 | R           | 0            |
| 28          | I28               | Interrupt associated with TCC #28 | R           | 0            |
| 27          | I27               | Interrupt associated with TCC #27 | R           | 0            |
| 26          | I26               | Interrupt associated with TCC #26 | R           | 0            |
| 25          | I25               | Interrupt associated with TCC #25 | R           | 0            |
| 24          | I24               | Interrupt associated with TCC #24 | R           | 0            |
| 23          | I23               | Interrupt associated with TCC #23 | R           | 0            |
| 22          | I22               | Interrupt associated with TCC #22 | R           | 0            |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 21   | I21        | Interrupt associated with TCC #21 | R    | 0     |
| 20   | I20        | Interrupt associated with TCC #20 | R    | 0     |
| 19   | I19        | Interrupt associated with TCC #19 | R    | 0     |
| 18   | I18        | Interrupt associated with TCC #18 | R    | 0     |
| 17   | I17        | Interrupt associated with TCC #17 | R    | 0     |
| 16   | I16        | Interrupt associated with TCC #16 | R    | 0     |
| 15   | I15        | Interrupt associated with TCC #15 | R    | 0     |
| 14   | I14        | Interrupt associated with TCC #14 | R    | 0     |
| 13   | I13        | Interrupt associated with TCC #13 | R    | 0     |
| 12   | I12        | Interrupt associated with TCC #12 | R    | 0     |
| 11   | I11        | Interrupt associated with TCC #11 | R    | 0     |
| 10   | I10        | Interrupt associated with TCC #10 | R    | 0     |
| 9    | I9         | Interrupt associated with TCC #9  | R    | 0     |
| 8    | I8         | Interrupt associated with TCC #8  | R    | 0     |
| 7    | I7         | Interrupt associated with TCC #7  | R    | 0     |
| 6    | I6         | Interrupt associated with TCC #6  | R    | 0     |
| 5    | I5         | Interrupt associated with TCC #5  | R    | 0     |
| 4    | I4         | Interrupt associated with TCC #4  | R    | 0     |
| 3    | I3         | Interrupt associated with TCC #3  | R    | 0     |
| 2    | I2         | Interrupt associated with TCC #2  | R    | 0     |
| 1    | I1         | Interrupt associated with TCC #1  | R    | 0     |
| 0    | I0         | Interrupt associated with TCC #0  | R    | 0     |

**Table 5-303. Register Call Summary for Register TPCC\_IPR**

IVA2.2 Subsystem Basic Programming Model

- Starting the Transfer: [0] [1] [2] [3] [4] [5] [6] [7]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [8]

**Table 5-304. TPCC\_IPRH**

|                       |                                                                                                                                                                                                   |     |                         |             |     |                 |             |                                                                                                 |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------------------|-------------|-----|-----------------|-------------|-------------------------------------------------------------------------------------------------|
| <b>Address Offset</b> | 0x106C                                                                                                                                                                                            |     | <b>Physical address</b> | 0x01C0 106C |     | <b>Instance</b> | IVA2.2 TPCC |                                                                                                 |
| <b>Description</b>    | Interrupt Pending Register (High Part):<br>IPRH.In bit is set when a interrupt completion code with TCC of N is detected.<br>IPRH.In bit is cleared through software by writing 1 to ICRH.In bit. |     |                         |             |     |                 |             |                                                                                                 |
| <b>Type</b>           | R                                                                                                                                                                                                 |     |                         |             |     |                 |             |                                                                                                 |
| 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                                   |
| I63                   | I62                                                                                                                                                                                               | I61 | I60                     | I59         | I58 | I57             | I56         | I55 I54 I53 I52 I51 I50 I49 I48 I47 I46 I45 I44 I43 I42 I41 I40 I39 I38 I37 I36 I35 I34 I33 I32 |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 31   | I63        | Interrupt associated with TCC #63 | R    | 0     |
| 30   | I62        | Interrupt associated with TCC #62 | R    | 0     |
| 29   | I61        | Interrupt associated with TCC #61 | R    | 0     |
| 28   | I60        | Interrupt associated with TCC #60 | R    | 0     |
| 27   | I59        | Interrupt associated with TCC #59 | R    | 0     |
| 26   | I58        | Interrupt associated with TCC #58 | R    | 0     |
| 25   | I57        | Interrupt associated with TCC #57 | R    | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 24          | I56               | Interrupt associated with TCC #56 | R           | 0            |
| 23          | I55               | Interrupt associated with TCC #55 | R           | 0            |
| 22          | I54               | Interrupt associated with TCC #54 | R           | 0            |
| 21          | I53               | Interrupt associated with TCC #53 | R           | 0            |
| 20          | I52               | Interrupt associated with TCC #52 | R           | 0            |
| 19          | I51               | Interrupt associated with TCC #51 | R           | 0            |
| 18          | I50               | Interrupt associated with TCC #50 | R           | 0            |
| 17          | I49               | Interrupt associated with TCC #49 | R           | 0            |
| 16          | I48               | Interrupt associated with TCC #48 | R           | 0            |
| 15          | I47               | Interrupt associated with TCC #47 | R           | 0            |
| 14          | I46               | Interrupt associated with TCC #46 | R           | 0            |
| 13          | I45               | Interrupt associated with TCC #45 | R           | 0            |
| 12          | I44               | Interrupt associated with TCC #44 | R           | 0            |
| 11          | I43               | Interrupt associated with TCC #43 | R           | 0            |
| 10          | I42               | Interrupt associated with TCC #42 | R           | 0            |
| 9           | I41               | Interrupt associated with TCC #41 | R           | 0            |
| 8           | I40               | Interrupt associated with TCC #40 | R           | 0            |
| 7           | I39               | Interrupt associated with TCC #39 | R           | 0            |
| 6           | I38               | Interrupt associated with TCC #38 | R           | 0            |
| 5           | I37               | Interrupt associated with TCC #37 | R           | 0            |
| 4           | I36               | Interrupt associated with TCC #36 | R           | 0            |
| 3           | I35               | Interrupt associated with TCC #35 | R           | 0            |
| 2           | I34               | Interrupt associated with TCC #34 | R           | 0            |
| 1           | I33               | Interrupt associated with TCC #33 | R           | 0            |
| 0           | I32               | Interrupt associated with TCC #32 | R           | 0            |

**Table 5-305. Register Call Summary for Register TPCC\_IPRH**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-306. TPCC\_ICR**

|                         |                                                                                                                                                                                                                             |          |             |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------|
| <b>Address Offset</b>   | 0x1070                                                                                                                                                                                                                      |          |             |
| <b>Physical address</b> | 0x01C0 1070                                                                                                                                                                                                                 | Instance | IVA2.2 TPCC |
| <b>Description</b>      | Interrupt Clear Register:<br>CPU write of 1 to the ICR.In bit causes the IPR.In bit to be cleared.<br>CPU write of 0 has no effect.<br>All IPR.In bits must be cleared before additional interrupts will be asserted by CC. |          |             |
| <b>Type</b>             | W                                                                                                                                                                                                                           |          |             |

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| 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  |
| I31 | I30 | I29 | I28 | I27 | I26 | I25 | I24 | I23 | I22 | I21 | I20 | I19 | I18 | I17 | I16 | I15 | I14 | I13 | I12 | I11 | I10 | I9 | I8 | I7 | I6 | I5 | I4 | I3 | I2 | I1 | I0 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31          | I31               | Interrupt associated with TCC #31 | W           | 0            |
| 30          | I30               | Interrupt associated with TCC #30 | W           | 0            |
| 29          | I29               | Interrupt associated with TCC #29 | W           | 0            |
| 28          | I28               | Interrupt associated with TCC #28 | W           | 0            |
| 27          | I27               | Interrupt associated with TCC #27 | W           | 0            |
| 26          | I26               | Interrupt associated with TCC #26 | W           | 0            |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 25   | I25        | Interrupt associated with TCC #25 | W    | 0     |
| 24   | I24        | Interrupt associated with TCC #24 | W    | 0     |
| 23   | I23        | Interrupt associated with TCC #23 | W    | 0     |
| 22   | I22        | Interrupt associated with TCC #22 | W    | 0     |
| 21   | I21        | Interrupt associated with TCC #21 | W    | 0     |
| 20   | I20        | Interrupt associated with TCC #20 | W    | 0     |
| 19   | I19        | Interrupt associated with TCC #19 | W    | 0     |
| 18   | I18        | Interrupt associated with TCC #18 | W    | 0     |
| 17   | I17        | Interrupt associated with TCC #17 | W    | 0     |
| 16   | I16        | Interrupt associated with TCC #16 | W    | 0     |
| 15   | I15        | Interrupt associated with TCC #15 | W    | 0     |
| 14   | I14        | Interrupt associated with TCC #14 | W    | 0     |
| 13   | I13        | Interrupt associated with TCC #13 | W    | 0     |
| 12   | I12        | Interrupt associated with TCC #12 | W    | 0     |
| 11   | I11        | Interrupt associated with TCC #11 | W    | 0     |
| 10   | I10        | Interrupt associated with TCC #10 | W    | 0     |
| 9    | I9         | Interrupt associated with TCC #9  | W    | 0     |
| 8    | I8         | Interrupt associated with TCC #8  | W    | 0     |
| 7    | I7         | Interrupt associated with TCC #7  | W    | 0     |
| 6    | I6         | Interrupt associated with TCC #6  | W    | 0     |
| 5    | I5         | Interrupt associated with TCC #5  | W    | 0     |
| 4    | I4         | Interrupt associated with TCC #4  | W    | 0     |
| 3    | I3         | Interrupt associated with TCC #3  | W    | 0     |
| 2    | I2         | Interrupt associated with TCC #2  | W    | 0     |
| 1    | I1         | Interrupt associated with TCC #1  | W    | 0     |
| 0    | I0         | Interrupt associated with TCC #0  | W    | 0     |

**Table 5-307. Register Call Summary for Register TPCC\_ICR**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-308. TPCC\_ICRH**

| Address Offset     | 0x1074 | Physical address                                                                                                                                                                                                                           | 0x01C0 1074 | Instance | IVA2.2 TPCC |
|--------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------|-------------|
| <b>Description</b> |        | Interrupt Clear Register (High Part):<br>CPU write of 1 to the ICRH.In bit causes the IPRH.In bit to be cleared.<br>CPU write of 0 has no effect.<br>All IPRH.In bits must be cleared before additional interrupts will be asserted by CC. |             |          |             |
| <b>Type</b>        |        | W                                                                                                                                                                                                                                          |             |          |             |

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 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   |
| I63 | I62 | I61 | I60 | I59 | I58 | I57 | I56 | I55 | I54 | I53 | I52 | I51 | I50 | I49 | I48 | I47 | I46 | I45 | I44 | I43 | I42 | I41 | I40 | I39 | I38 | I37 | I36 | I35 | I34 | I33 | I32 |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 31   | I63        | Interrupt associated with TCC #63 | W    | 0     |
| 30   | I62        | Interrupt associated with TCC #62 | W    | 0     |
| 29   | I61        | Interrupt associated with TCC #61 | W    | 0     |
| 28   | I60        | Interrupt associated with TCC #60 | W    | 0     |
| 27   | I59        | Interrupt associated with TCC #59 | W    | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 26          | I58               | Interrupt associated with TCC #58 | W           | 0            |
| 25          | I57               | Interrupt associated with TCC #57 | W           | 0            |
| 24          | I56               | Interrupt associated with TCC #56 | W           | 0            |
| 23          | I55               | Interrupt associated with TCC #55 | W           | 0            |
| 22          | I54               | Interrupt associated with TCC #54 | W           | 0            |
| 21          | I53               | Interrupt associated with TCC #53 | W           | 0            |
| 20          | I52               | Interrupt associated with TCC #52 | W           | 0            |
| 19          | I51               | Interrupt associated with TCC #51 | W           | 0            |
| 18          | I50               | Interrupt associated with TCC #50 | W           | 0            |
| 17          | I49               | Interrupt associated with TCC #49 | W           | 0            |
| 16          | I48               | Interrupt associated with TCC #48 | W           | 0            |
| 15          | I47               | Interrupt associated with TCC #47 | W           | 0            |
| 14          | I46               | Interrupt associated with TCC #46 | W           | 0            |
| 13          | I45               | Interrupt associated with TCC #45 | W           | 0            |
| 12          | I44               | Interrupt associated with TCC #44 | W           | 0            |
| 11          | I43               | Interrupt associated with TCC #43 | W           | 0            |
| 10          | I42               | Interrupt associated with TCC #42 | W           | 0            |
| 9           | I41               | Interrupt associated with TCC #41 | W           | 0            |
| 8           | I40               | Interrupt associated with TCC #40 | W           | 0            |
| 7           | I39               | Interrupt associated with TCC #39 | W           | 0            |
| 6           | I38               | Interrupt associated with TCC #38 | W           | 0            |
| 5           | I37               | Interrupt associated with TCC #37 | W           | 0            |
| 4           | I36               | Interrupt associated with TCC #36 | W           | 0            |
| 3           | I35               | Interrupt associated with TCC #35 | W           | 0            |
| 2           | I34               | Interrupt associated with TCC #34 | W           | 0            |
| 1           | I33               | Interrupt associated with TCC #33 | W           | 0            |
| 0           | I32               | Interrupt associated with TCC #32 | W           | 0            |

**Table 5-309. Register Call Summary for Register TPCC\_ICRH**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-310. TPCC\_Ieval**

|                       |                         |                         |             |                 |             |
|-----------------------|-------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x1078                  | <b>Physical address</b> | 0x01C0 1078 | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>    | Interrupt Eval Register |                         |             |                 |             |
| <b>Type</b>           | W                       |                         |             |                 |             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |      |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|------|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | SET | EVAL |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:2        | Reserved          | Write 0s for future compatibility.                                                                                                                                                                  | W           | 0x00000000   |
| 1           | SET               | Interrupt Set:<br>CPU write of 1 to the SETn bit causes the tpcc_intN output signal to be pulsed egardless of state of interrupts enable (IERn) and status (IPRn).<br>CPU write of 0 has no effect. | W           | 0            |

| Bits | Field Name | Description                                                                                                                                                                                        | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | EVAL       | Interrupt Evaluate:<br>CPU write of 1 to the EVALn bit causes the tpcc_intN output signal to be pulsed if any enabled interrupts (IERn) are still pending (IPRn).<br>CPU write of 0 has no effect. | W    | 0     |

**Table 5-311. Register Call Summary for Register TPCC\_I EVAL**

IVA2.2 Subsystem Basic Programming Model

- Starting the Transfer: [0]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [1]

**Table 5-312. TPCC\_QER**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x1080                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 1080                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | QDMA Event Register:<br>If QER.En bit is set, then the corresponding QDMA channel is prioritized vs. other qdma events for submission to the TC. QER.En bit is set when a vbus write byte matches the address defined in the QCHMAPn register. QER.En bit is cleared when the corresponding event is prioritized and serviced. QER.En is also cleared when user writes a 1 to the QSECR.En bit. If the QER.En bit is already set and a new QDMA event is detected due to user write to QDMA trigger location and QEER register is set, then the corresponding bit in the QDMA Event Missed Register is set. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |    |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|
| 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  |    |    |    |    |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description     | Type | Reset    |
|------|------------|-----------------|------|----------|
| 31:8 | Reserved   | Read returns 0. | R    | 0x000000 |
| 7    | E7         | Event #7        | R    | 0        |
| 6    | E6         | Event #6        | R    | 0        |
| 5    | E5         | Event #5        | R    | 0        |
| 4    | E4         | Event #4        | R    | 0        |
| 3    | E3         | Event #3        | R    | 0        |
| 2    | E2         | Event #2        | R    | 0        |
| 1    | E1         | Event #1        | R    | 0        |
| 0    | E0         | Event #0        | R    | 0        |

**Table 5-313. Register Call Summary for Register TPCC\_QER**

IVA2.2 Subsystem Functional Description

- EDMA: [0] [1] [2] [3] [4]

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [5]

**Table 5-314. TPCC\_QEER**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x1084                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 1084                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  | Instance |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | QDMA Event Enable Register:<br>Enabled/disabled QDMA address comparator for QDMA Channel N. QEER.En is not directly writeable. QDMA channels can be enabled through writes to QEESR and can be disabled through writes to QEECR register.<br>QEER.En = 1, The corresponding QDMA channel comparator is enabled and Events will be recognized and latched in QER.En.<br>QEER.En = 0, The corresponding QDMA channel comparator is disabled. Events will not be recognized/latched in QER.En. |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|----|----|----|----|----|----|----|
| 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  |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description     | Type | Reset    |
|------|------------|-----------------|------|----------|
| 31:8 | Reserved   | Read returns 0. | R    | 0x000000 |
| 7    | E7         | Event #7        | R    | 0        |
| 6    | E6         | Event #6        | R    | 0        |
| 5    | E5         | Event #5        | R    | 0        |
| 4    | E4         | Event #4        | R    | 0        |
| 3    | E3         | Event #3        | R    | 0        |
| 2    | E2         | Event #2        | R    | 0        |
| 1    | E1         | Event #1        | R    | 0        |
| 0    | E0         | Event #0        | R    | 0        |

**Table 5-315. Register Call Summary for Register TPCC\_QEER**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\] \[1\] \[2\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[3\]](#)

**Table 5-316. TPCC\_QEECR**

|                         |                                                                                                                                                |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x1088                                                                                                                                         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 1088                                                                                                                                    |  |  |  |  |  |  |  | Instance |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | QDMA Event Enable Clear Register:<br>CPU write of 1 to the QEECR.En bit causes the QEER.En bit to be cleared.<br>CPU write of 0 has no effect. |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                                                                                                                              |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|----|----|----|----|----|----|----|
| 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  |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description                        | Type | Reset    |
|------|------------|------------------------------------|------|----------|
| 31:8 | Reserved   | Write Os for future compatibility. | W    | 0x000000 |
| 7    | E7         | Event #7                           | W    | 0        |
| 6    | E6         | Event #6                           | W    | 0        |
| 5    | E5         | Event #5                           | W    | 0        |
| 4    | E4         | Event #4                           | W    | 0        |
| 3    | E3         | Event #3                           | W    | 0        |
| 2    | E2         | Event #2                           | W    | 0        |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 1    | E1         | Event #1    | W    | 0     |
| 0    | E0         | Event #0    | W    | 0     |

**Table 5-317. Register Call Summary for Register TPCC\_QEECR**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-318. TPCC\_QEESR**

|                         |                                                                                                                                           |                             |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| <b>Address Offset</b>   | 0x108C                                                                                                                                    |                             |
| <b>Physical address</b> | 0x01C0 108C                                                                                                                               | <b>Instance</b> IVA2.2 TPCC |
| <b>Description</b>      | QDMA Event Enable Set Register:<br>CPU write of 1 to the QEESR.En bit causes the QEESR.En bit to be set.<br>CPU write of 0 has no effect. |                             |
| <b>Type</b>             | W                                                                                                                                         |                             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|----|----|----|----|----|----|----|
| 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  |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description                        | Type | Reset    |
|------|------------|------------------------------------|------|----------|
| 31:8 | Reserved   | Write 0s for future compatibility. | W    | 0x000000 |
| 7    | E7         | Event #7                           | W    | 0        |
| 6    | E6         | Event #6                           | W    | 0        |
| 5    | E5         | Event #5                           | W    | 0        |
| 4    | E4         | Event #4                           | W    | 0        |
| 3    | E3         | Event #3                           | W    | 0        |
| 2    | E2         | Event #2                           | W    | 0        |
| 1    | E1         | Event #1                           | W    | 0        |
| 0    | E0         | Event #0                           | W    | 0        |

**Table 5-319. Register Call Summary for Register TPCC\_QEESR**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-320. TPCC\_QSER**

|                         |                                                                                                                                                                                                                                                                                                                                           |                             |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| <b>Address Offset</b>   | 0x1090                                                                                                                                                                                                                                                                                                                                    |                             |
| <b>Physical address</b> | 0x01C0 1090                                                                                                                                                                                                                                                                                                                               | <b>Instance</b> IVA2.2 TPCC |
| <b>Description</b>      | QDMA Secondary Event Register:<br>The QDMA secondary event register is used along with the QDMA Event Register (QER) to provide information on the state of a QDMA Event.<br>En = 0: Event is not currently in the Event Queue.<br>En = 1: Event is currently stored in Event Queue. Event arbiter will not prioritize additional events. |                             |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                         |                             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|----|----|----|----|----|----|----|
| 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  |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description                        | Type | Reset    |
|------|------------|------------------------------------|------|----------|
| 31:8 | Reserved   | Write Os for future compatibility. | W    | 0x000000 |
| 7    | E7         | Event #7                           | W    | 0        |
| 6    | E6         | Event #6                           | W    | 0        |
| 5    | E5         | Event #5                           | W    | 0        |
| 4    | E4         | Event #4                           | W    | 0        |
| 3    | E3         | Event #3                           | W    | 0        |
| 2    | E2         | Event #2                           | W    | 0        |
| 1    | E1         | Event #1                           | W    | 0        |
| 0    | E0         | Event #0                           | W    | 0        |

**Table 5-321. Register Call Summary for Register TPCC\_QSER**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-322. TPCC\_QSECR**

|                         |                                                                                                                                                                                                                                                                                                                                                                   |                         |                 |                 |                         |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-------------------------|
| <b>Address Offset</b>   | 0x1094                                                                                                                                                                                                                                                                                                                                                            | <b>Physical address</b> | 0x01C0 1094     | <b>Instance</b> | IVA2.2 TPCC             |
| <b>Description</b>      | QDMA Secondary Event Clear Register:<br>The secondary event clear register is used to clear the status of the QSER and QER register (note that this is slightly different than the SER operation, which does not clear the ER.En register).<br>CPU write of 1 to the QSECR.En bit clears the QSER.En and QER.En register fields.<br>CPU write of 0 has no effect. |                         |                 |                 |                         |
| <b>Type</b>             | W                                                                                                                                                                                                                                                                                                                                                                 |                         |                 |                 |                         |
| 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 | 7 6 5 4 3 2 1 0 | E7 E6 E5 E4 E3 E2 E1 E0 |
| Reserved                |                                                                                                                                                                                                                                                                                                                                                                   |                         |                 |                 |                         |

| Bits | Field Name | Description                        | Type | Reset    |
|------|------------|------------------------------------|------|----------|
| 31:8 | Reserved   | Write Os for future compatibility. | W    | 0x000000 |
| 7    | E7         | Event #7                           | W    | 0        |
| 6    | E6         | Event #6                           | W    | 0        |
| 5    | E5         | Event #5                           | W    | 0        |
| 4    | E4         | Event #4                           | W    | 0        |
| 3    | E3         | Event #3                           | W    | 0        |
| 2    | E2         | Event #2                           | W    | 0        |
| 1    | E1         | Event #1                           | W    | 0        |
| 0    | E0         | Event #0                           | W    | 0        |

**Table 5-323. Register Call Summary for Register TPCC\_QSECR**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-324. TPCC\_ER\_Rn**

|                         |                                    |                 |
|-------------------------|------------------------------------|-----------------|
| <b>Address Offset</b>   | 0x2000 + (0x200*n) n = 0 to 7      |                 |
| <b>Physical address</b> | 0x01C0 2000 + (0x200*n) n = 0 to 7 | <b>Instance</b> |
| <b>Description</b>      |                                    | IVA2.2 TPCC     |
| <b>Type</b>             |                                    | R               |

|          |    |    |    |    |    |    |    |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
|----------|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |

| Bits  | Field Name | Description | Type | Reset |
|-------|------------|-------------|------|-------|
| 31:20 | Reserved   | Reserved    | R    | 0     |
| 19    | E19        | Event #19   | R    | 0     |
| 18    | E18        | Event #18   | R    | 0     |
| 17    | E17        | Event #17   | R    | 0     |
| 16    | E16        | Event #16   | R    | 0     |
| 15    | E15        | Event #15   | R    | 0     |
| 14    | E14        | Event #14   | R    | 0     |
| 13    | E13        | Event #13   | R    | 0     |
| 12    | E12        | Event #12   | R    | 0     |
| 11    | E11        | Event #11   | R    | 0     |
| 10    | E10        | Event #10   | R    | 0     |
| 9     | E9         | Event #9    | R    | 0     |
| 8     | E8         | Event #8    | R    | 0     |
| 7     | E7         | Event #7    | R    | 0     |
| 6     | E6         | Event #6    | R    | 0     |
| 5     | E5         | Event #5    | R    | 0     |
| 4     | E4         | Event #4    | R    | 0     |
| 3     | E3         | Event #3    | R    | 0     |
| 2     | E2         | Event #2    | R    | 0     |
| 1     | E1         | Event #1    | R    | 0     |
| 0     | E0         | Event #0    | R    | 0     |

**Table 5-325. Register Call Summary for Register TPCC\_ER\_Rn**

**Table 5-326. TPCC\_ECR\_Rn**

|                         |                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x2008 + (0x200*n) n = 0 to 7                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 2008 + (0x200*n) n = 0 to 7                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Event Clear Register:<br>CPU write of 1 to the ECR.En bit causes the ER.En bit to be cleared.<br>CPU write of 0 has no effect. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| E31 | E30 | E29 | E28 | E27 | E26 | E25 | E24 | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E31        | Event #31   | W    | 0     |
| 30   | E30        | Event #30   | W    | 0     |
| 29   | E29        | Event #29   | W    | 0     |
| 28   | E28        | Event #28   | W    | 0     |
| 27   | E27        | Event #27   | W    | 0     |
| 26   | E26        | Event #26   | W    | 0     |
| 25   | E25        | Event #25   | W    | 0     |
| 24   | E24        | Event #24   | W    | 0     |
| 23   | E23        | Event #23   | W    | 0     |
| 22   | E22        | Event #22   | W    | 0     |
| 21   | E21        | Event #21   | W    | 0     |
| 20   | E20        | Event #20   | W    | 0     |
| 19   | E19        | Event #19   | W    | 0     |
| 18   | E18        | Event #18   | W    | 0     |
| 17   | E17        | Event #17   | W    | 0     |
| 16   | E16        | Event #16   | W    | 0     |
| 15   | E15        | Event #15   | W    | 0     |
| 14   | E14        | Event #14   | W    | 0     |
| 13   | E13        | Event #13   | W    | 0     |
| 12   | E12        | Event #12   | W    | 0     |
| 11   | E11        | Event #11   | W    | 0     |
| 10   | E10        | Event #10   | W    | 0     |
| 9    | E9         | Event #9    | W    | 0     |
| 8    | E8         | Event #8    | W    | 0     |
| 7    | E7         | Event #7    | W    | 0     |
| 6    | E6         | Event #6    | W    | 0     |
| 5    | E5         | Event #5    | W    | 0     |
| 4    | E4         | Event #4    | W    | 0     |
| 3    | E3         | Event #3    | W    | 0     |
| 2    | E2         | Event #2    | W    | 0     |
| 1    | E1         | Event #1    | W    | 0     |
| 0    | E0         | Event #0    | W    | 0     |

**Table 5-327. Register Call Summary for Register TPCC\_ECR\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-328. TPCC\_ECRH\_Rn**

|                         |                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x200C + (0x200*n) n = 0 to 7                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 200C + (0x200*n) n = 0 to 7                                                                                                           |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | IVA2.2 TPCC |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Event Clear Register (High Part):<br>CPU write of 1 to the ECRH.En bit causes the ERH.En bit to be cleared.<br>CPU write of 0 has no effect. |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| E63 | E62 | E61 | E60 | E59 | E58 | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38 | E37 | E36 | E35 | E34 | E33 | E32 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E63        | Event #63   | W    | 0     |
| 30   | E62        | Event #62   | W    | 0     |
| 29   | E61        | Event #61   | W    | 0     |
| 28   | E60        | Event #60   | W    | 0     |
| 27   | E59        | Event #59   | W    | 0     |
| 26   | E58        | Event #58   | W    | 0     |
| 25   | E57        | Event #57   | W    | 0     |
| 24   | E56        | Event #56   | W    | 0     |
| 23   | E55        | Event #55   | W    | 0     |
| 22   | E54        | Event #54   | W    | 0     |
| 21   | E53        | Event #53   | W    | 0     |
| 20   | E52        | Event #52   | W    | 0     |
| 19   | E51        | Event #51   | W    | 0     |
| 18   | E50        | Event #50   | W    | 0     |
| 17   | E49        | Event #49   | W    | 0     |
| 16   | E48        | Event #48   | W    | 0     |
| 15   | E47        | Event #47   | W    | 0     |
| 14   | E46        | Event #46   | W    | 0     |
| 13   | E45        | Event #45   | W    | 0     |
| 12   | E44        | Event #44   | W    | 0     |
| 11   | E43        | Event #43   | W    | 0     |
| 10   | E42        | Event #42   | W    | 0     |
| 9    | E41        | Event #41   | W    | 0     |
| 8    | E40        | Event #40   | W    | 0     |
| 7    | E39        | Event #39   | W    | 0     |
| 6    | E38        | Event #38   | W    | 0     |
| 5    | E37        | Event #37   | W    | 0     |
| 4    | E36        | Event #36   | W    | 0     |
| 3    | E35        | Event #35   | W    | 0     |
| 2    | E34        | Event #34   | W    | 0     |
| 1    | E33        | Event #33   | W    | 0     |
| 0    | E32        | Event #32   | W    | 0     |

**Table 5-329. Register Call Summary for Register TPCC\_ECRH\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-330. TPCC\_ESR\_Rn**

|                         |                                                                                                                          |                 |              |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x2010 + (0x200*n) n = 0 to 7                                                                                            |                 |              |
| <b>Physical address</b> | 0x01C0 2010 + (0x200*n) n = 0 to 7                                                                                       | <b>Instance</b> | IV A2.2 TPCC |
| <b>Description</b>      | Event Set Register:<br>CPU write of 1 to the ESR.En bit causes the ER.En bit to be set.<br>CPU write of 0 has no effect. |                 |              |
| <b>Type</b>             | W                                                                                                                        |                 |              |

| 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  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| E31 | E30 | E29 | E28 | E27 | E26 | E25 | E24 | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E31        | Event #31   | W    | 0     |
| 30   | E30        | Event #30   | W    | 0     |
| 29   | E29        | Event #29   | W    | 0     |
| 28   | E28        | Event #28   | W    | 0     |
| 27   | E27        | Event #27   | W    | 0     |
| 26   | E26        | Event #26   | W    | 0     |
| 25   | E25        | Event #25   | W    | 0     |
| 24   | E24        | Event #24   | W    | 0     |
| 23   | E23        | Event #23   | W    | 0     |
| 22   | E22        | Event #22   | W    | 0     |
| 21   | E21        | Event #21   | W    | 0     |
| 20   | E20        | Event #20   | W    | 0     |
| 19   | E19        | Event #19   | W    | 0     |
| 18   | E18        | Event #18   | W    | 0     |
| 17   | E17        | Event #17   | W    | 0     |
| 16   | E16        | Event #16   | W    | 0     |
| 15   | E15        | Event #15   | W    | 0     |
| 14   | E14        | Event #14   | W    | 0     |
| 13   | E13        | Event #13   | W    | 0     |
| 12   | E12        | Event #12   | W    | 0     |
| 11   | E11        | Event #11   | W    | 0     |
| 10   | E10        | Event #10   | W    | 0     |
| 9    | E9         | Event #9    | W    | 0     |
| 8    | E8         | Event #8    | W    | 0     |
| 7    | E7         | Event #7    | W    | 0     |
| 6    | E6         | Event #6    | W    | 0     |
| 5    | E5         | Event #5    | W    | 0     |
| 4    | E4         | Event #4    | W    | 0     |
| 3    | E3         | Event #3    | W    | 0     |
| 2    | E2         | Event #2    | W    | 0     |
| 1    | E1         | Event #1    | W    | 0     |
| 0    | E0         | Event #0    | W    | 0     |

**Table 5-331. Register Call Summary for Register TPCC\_ESR\_Rn**

IV A2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-332. TPCC\_ESRH\_Rn**

|                         |                                                                                                                                       |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x2014 + (0x200*n) n = 0 to 7                                                                                                         |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 2014 + (0x200*n) n = 0 to 7                                                                                                    |  |  |  |  |  |  |  |  |  | <b>Instance</b> | IVA2.2 TPCC |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Event Set Register (High Part)<br>CPU write of 1 to the ESRH.En bit causes the ERH.En bit to be set.<br>CPU write of 0 has no effect. |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                                                                                                                     |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| E63 | E62 | E61 | E60 | E59 | E58 | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38 | E37 | E36 | E35 | E34 | E33 | E32 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E63        | Event #63   | W    | 0     |
| 30   | E62        | Event #62   | W    | 0     |
| 29   | E61        | Event #61   | W    | 0     |
| 28   | E60        | Event #60   | W    | 0     |
| 27   | E59        | Event #59   | W    | 0     |
| 26   | E58        | Event #58   | W    | 0     |
| 25   | E57        | Event #57   | W    | 0     |
| 24   | E56        | Event #56   | W    | 0     |
| 23   | E55        | Event #55   | W    | 0     |
| 22   | E54        | Event #54   | W    | 0     |
| 21   | E53        | Event #53   | W    | 0     |
| 20   | E52        | Event #52   | W    | 0     |
| 19   | E51        | Event #51   | W    | 0     |
| 18   | E50        | Event #50   | W    | 0     |
| 17   | E49        | Event #49   | W    | 0     |
| 16   | E48        | Event #48   | W    | 0     |
| 15   | E47        | Event #47   | W    | 0     |
| 14   | E46        | Event #46   | W    | 0     |
| 13   | E45        | Event #45   | W    | 0     |
| 12   | E44        | Event #44   | W    | 0     |
| 11   | E43        | Event #43   | W    | 0     |
| 10   | E42        | Event #42   | W    | 0     |
| 9    | E41        | Event #41   | W    | 0     |
| 8    | E40        | Event #40   | W    | 0     |
| 7    | E39        | Event #39   | W    | 0     |
| 6    | E38        | Event #38   | W    | 0     |
| 5    | E37        | Event #37   | W    | 0     |
| 4    | E36        | Event #36   | W    | 0     |
| 3    | E35        | Event #35   | W    | 0     |
| 2    | E34        | Event #34   | W    | 0     |
| 1    | E33        | Event #33   | W    | 0     |
| 0    | E32        | Event #32   | W    | 0     |

**Table 5-333. Register Call Summary for Register TPCC\_ESRH\_Rn**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-334. TPCC\_CER\_Rn**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |              |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x2018 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |              |
| <b>Physical address</b> | 0x01C0 2018 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <b>Instance</b> | IV A2.2 TPCC |
| <b>Description</b>      | Chained Event Register:<br>If CER.En bit is set (regardless of state of EER.En), then the corresponding DMA channel is prioritized vs. other pending DMA events for submission to the TC. CER.En bit is set when a chaining completion code is returned from one of the TPTCs through the completion interface, or is generated internally through Early Completion path. CER.En bit is cleared when the corresponding event is prioritized and serviced. If the CER.En bit is already set and the corresponding chaining completion code is returned from the TC, then the corresponding bit in the Event Missed Register is set. CER.En cannot be set or cleared through software. |                 |              |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                 |              |

  

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| 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  |
| E31 | E30 | E29 | E28 | E27 | E26 | E25 | E24 | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 31          | E31               | Event #31          | R           | 0            |
| 30          | E30               | Event #30          | R           | 0            |
| 29          | E29               | Event #29          | R           | 0            |
| 28          | E28               | Event #28          | R           | 0            |
| 27          | E27               | Event #27          | R           | 0            |
| 26          | E26               | Event #26          | R           | 0            |
| 25          | E25               | Event #25          | R           | 0            |
| 24          | E24               | Event #24          | R           | 0            |
| 23          | E23               | Event #23          | R           | 0            |
| 22          | E22               | Event #22          | R           | 0            |
| 21          | E21               | Event #21          | R           | 0            |
| 20          | E20               | Event #20          | R           | 0            |
| 19          | E19               | Event #19          | R           | 0            |
| 18          | E18               | Event #18          | R           | 0            |
| 17          | E17               | Event #17          | R           | 0            |
| 16          | E16               | Event #16          | R           | 0            |
| 15          | E15               | Event #15          | R           | 0            |
| 14          | E14               | Event #14          | R           | 0            |
| 13          | E13               | Event #13          | R           | 0            |
| 12          | E12               | Event #12          | R           | 0            |
| 11          | E11               | Event #11          | R           | 0            |
| 10          | E10               | Event #10          | R           | 0            |
| 9           | E9                | Event #9           | R           | 0            |
| 8           | E8                | Event #8           | R           | 0            |
| 7           | E7                | Event #7           | R           | 0            |
| 6           | E6                | Event #6           | R           | 0            |
| 5           | E5                | Event #5           | R           | 0            |
| 4           | E4                | Event #4           | R           | 0            |
| 3           | E3                | Event #3           | R           | 0            |
| 2           | E2                | Event #2           | R           | 0            |
| 1           | E1                | Event #1           | R           | 0            |
| 0           | E0                | Event #0           | R           | 0            |

**Table 5-335. Register Call Summary for Register TPCC\_CER\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-336. TPCC\_CERH\_Rn**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x201C + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 201C + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Chained Event Register (High Part):<br>If CERH.En bit is set (regardless of state of EERH.En), then the corresponding DMA channel is prioritized vs. other pending DMA events for submission to the TC. CERH.En bit is set when a chaining completion code is returned from one of the TPTCs through the completion interface, or is generated internally through Early Completion path. CERH.En bit is cleared when the corresponding event is prioritized and serviced. If the CERH.En bit is already set and the corresponding chaining completion code is returned from the TC, then the corresponding bit in the Event Missed Register is set. CERH.En cannot be set or cleared through software. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| E63 | E62 | E61 | E60 | E59 | E58 | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38 | E37 | E36 | E35 | E34 | E33 | E32 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E63        | Event #63   | R    | 0     |
| 30   | E62        | Event #62   | R    | 0     |
| 29   | E61        | Event #61   | R    | 0     |
| 28   | E60        | Event #60   | R    | 0     |
| 27   | E59        | Event #59   | R    | 0     |
| 26   | E58        | Event #58   | R    | 0     |
| 25   | E57        | Event #57   | R    | 0     |
| 24   | E56        | Event #56   | R    | 0     |
| 23   | E55        | Event #55   | R    | 0     |
| 22   | E54        | Event #54   | R    | 0     |
| 21   | E53        | Event #53   | R    | 0     |
| 20   | E52        | Event #52   | R    | 0     |
| 19   | E51        | Event #51   | R    | 0     |
| 18   | E50        | Event #50   | R    | 0     |
| 17   | E49        | Event #49   | R    | 0     |
| 16   | E48        | Event #48   | R    | 0     |
| 15   | E47        | Event #47   | R    | 0     |
| 14   | E46        | Event #46   | R    | 0     |
| 13   | E45        | Event #45   | R    | 0     |
| 12   | E44        | Event #44   | R    | 0     |
| 11   | E43        | Event #43   | R    | 0     |
| 10   | E42        | Event #42   | R    | 0     |
| 9    | E41        | Event #41   | R    | 0     |
| 8    | E40        | Event #40   | R    | 0     |
| 7    | E39        | Event #39   | R    | 0     |
| 6    | E38        | Event #38   | R    | 0     |
| 5    | E37        | Event #37   | R    | 0     |
| 4    | E36        | Event #36   | R    | 0     |
| 3    | E35        | Event #35   | R    | 0     |
| 2    | E34        | Event #34   | R    | 0     |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 1    | E33        | Event #33   | R    | 0     |
| 0    | E32        | Event #32   | R    | 0     |

**Table 5-337. Register Call Summary for Register TPCC\_CERH\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-338. TPCC\_EER\_Rn**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 |             |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|--|
| <b>Address Offset</b>   | 0x2020 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |             |  |
| <b>Physical address</b> | 0x01C0 2020 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <b>Instance</b> | IVA2.2 TPCC |  |
| <b>Description</b>      | Event Enable Register:<br>Enables DMA transfers for ER.En pending events. ER.En is set based on externally asserted events (through tpcc_eventN_pi). This register has no effect on Chained Event Register (CER) or Event Set Register (ESR). Note that if a bit is set in ER.En while EER.En is disabled, no action is taken. If EER.En is enabled at a later point (and ER.En has not been cleared through SW) then the event will be recognized as a valid TR Sync EER.En is not directly writeable. Events can be enabled through writes to EESR and can be disabled through writes to EECR register.<br>EER.En = 0: ER.En is not enabled to trigger DMA transfers.<br>EER.En = 1: ER.En is enabled to trigger DMA transfers. |                 |             |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |             |  |

|          |    |    |    |    |    |    |    |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
|----------|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |

| Bits  | Field Name | Description | Type | Reset |
|-------|------------|-------------|------|-------|
| 31:20 | Reserved   | Reserved    | R    | 0     |
| 19    | E19        | Event #19   | R    | 0     |
| 18    | E18        | Event #18   | R    | 0     |
| 17    | E17        | Event #17   | R    | 0     |
| 16    | E16        | Event #16   | R    | 0     |
| 15    | E15        | Event #15   | R    | 0     |
| 14    | E14        | Event #14   | R    | 0     |
| 13    | E13        | Event #13   | R    | 0     |
| 12    | E12        | Event #12   | R    | 0     |
| 11    | E11        | Event #11   | R    | 0     |
| 10    | E10        | Event #10   | R    | 0     |
| 9     | E9         | Event #9    | R    | 0     |
| 8     | E8         | Event #8    | R    | 0     |
| 7     | E7         | Event #7    | R    | 0     |
| 6     | E6         | Event #6    | R    | 0     |
| 5     | E5         | Event #5    | R    | 0     |
| 4     | E4         | Event #4    | R    | 0     |
| 3     | E3         | Event #3    | R    | 0     |
| 2     | E2         | Event #2    | R    | 0     |
| 1     | E1         | Event #1    | R    | 0     |
| 0     | E0         | Event #0    | R    | 0     |

**Table 5-339. Register Call Summary for Register TPCC\_EER\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-340. TPCC\_EECR\_Rn**

|                         |                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x2028 + (0x200*n) n = 0 to 7                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 2028 + (0x200*n) n = 0 to 7                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Instance</b>         | IVA2.2 TPCC                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Event Enable Clear Register:<br>CPU write of 1 to the EECR.En bit causes the EER.En bit to be cleared.<br>CPU write of 0 has no effect. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

  

|          |    |    |    |    |    |    |    |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
|----------|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |

| Bits  | Field Name | Description | Type | Reset |
|-------|------------|-------------|------|-------|
| 31:20 | Reserved   | Reserved    | W    | 0     |
| 19    | E19        | Event #19   | W    | 0     |
| 18    | E18        | Event #18   | W    | 0     |
| 17    | E17        | Event #17   | W    | 0     |
| 16    | E16        | Event #16   | W    | 0     |
| 15    | E15        | Event #15   | W    | 0     |
| 14    | E14        | Event #14   | W    | 0     |
| 13    | E13        | Event #13   | W    | 0     |
| 12    | E12        | Event #12   | W    | 0     |
| 11    | E11        | Event #11   | W    | 0     |
| 10    | E10        | Event #10   | W    | 0     |
| 9     | E9         | Event #9    | W    | 0     |
| 8     | E8         | Event #8    | W    | 0     |
| 7     | E7         | Event #7    | W    | 0     |
| 6     | E6         | Event #6    | W    | 0     |
| 5     | E5         | Event #5    | W    | 0     |
| 4     | E4         | Event #4    | W    | 0     |
| 3     | E3         | Event #3    | W    | 0     |
| 2     | E2         | Event #2    | W    | 0     |
| 1     | E1         | Event #1    | W    | 0     |
| 0     | E0         | Event #0    | W    | 0     |

**Table 5-341. Register Call Summary for Register TPCC\_EECR\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-342. TPCC\_EESR\_Rn**

|                         |                                                                                                                                   |                 |             |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|--|
| <b>Address Offset</b>   | 0x2030 + (0x200*n) n = 0 to 7                                                                                                     |                 |             |  |
| <b>Physical address</b> | 0x01C0 2030 + (0x200*n) n = 0 to 7                                                                                                | <b>Instance</b> | IVA2.2 TPCC |  |
| <b>Description</b>      | Event Enable Set Register:<br>CPU write of 1 to the EESR.En bit causes the EER.En bit to be set.<br>CPU write of 0 has no effect. |                 |             |  |
| <b>Type</b>             | W                                                                                                                                 |                 |             |  |

| 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 |
|----------|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
| Reserved |    |    |    |    |    |    |    | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |

| Bits  | Field Name | Description | Type | Reset |
|-------|------------|-------------|------|-------|
| 31:20 | Reserved   | Reserved    | W    | 0     |
| 19    | E19        | Event #19   | W    | 0     |
| 18    | E18        | Event #18   | W    | 0     |
| 17    | E17        | Event #17   | W    | 0     |
| 16    | E16        | Event #16   | W    | 0     |
| 15    | E15        | Event #15   | W    | 0     |
| 14    | E14        | Event #14   | W    | 0     |
| 13    | E13        | Event #13   | W    | 0     |
| 12    | E12        | Event #12   | W    | 0     |
| 11    | E11        | Event #11   | W    | 0     |
| 10    | E10        | Event #10   | W    | 0     |
| 9     | E9         | Event #9    | W    | 0     |
| 8     | E8         | Event #8    | W    | 0     |
| 7     | E7         | Event #7    | W    | 0     |
| 6     | E6         | Event #6    | W    | 0     |
| 5     | E5         | Event #5    | W    | 0     |
| 4     | E4         | Event #4    | W    | 0     |
| 3     | E3         | Event #3    | W    | 0     |
| 2     | E2         | Event #2    | W    | 0     |
| 1     | E1         | Event #1    | W    | 0     |
| 0     | E0         | Event #0    | W    | 0     |

**Table 5-343. Register Call Summary for Register TPCC\_EESR\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-344. TPCC\_SER\_Rn**

|                         |                                                                                                                                                                                                                                                                                                                       |                 |             |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|--|
| <b>Address Offset</b>   | 0x2038 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                         |                 |             |  |
| <b>Physical address</b> | 0x01C0 2038 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                    | <b>Instance</b> | IVA2.2 TPCC |  |
| <b>Description</b>      | Secondary Event Register:<br>The secondary event register is used along with the Event Register (ER) to provide information on the state of an Event.<br>En = 0: Event is not currently in the Event Queue.<br>En = 1: Event is currently stored in Event Queue. Event arbiter will not prioritize additional events. |                 |             |  |
| Type                    | R                                                                                                                                                                                                                                                                                                                     |                 |             |  |

|          |    |    |    |    |    |    |    |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
|----------|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |

| Bits  | Field Name | Description | Type | Reset |
|-------|------------|-------------|------|-------|
| 31:20 | Reserved   | Reserved    | R    | 0     |
| 19    | E19        | Event #19   | R    | 0     |
| 18    | E18        | Event #18   | R    | 0     |
| 17    | E17        | Event #17   | R    | 0     |
| 16    | E16        | Event #16   | R    | 0     |
| 15    | E15        | Event #15   | R    | 0     |
| 14    | E14        | Event #14   | R    | 0     |
| 13    | E13        | Event #13   | R    | 0     |
| 12    | E12        | Event #12   | R    | 0     |
| 11    | E11        | Event #11   | R    | 0     |
| 10    | E10        | Event #10   | R    | 0     |
| 9     | E9         | Event #9    | R    | 0     |
| 8     | E8         | Event #8    | R    | 0     |
| 7     | E7         | Event #7    | R    | 0     |
| 6     | E6         | Event #6    | R    | 0     |
| 5     | E5         | Event #5    | R    | 0     |
| 4     | E4         | Event #4    | R    | 0     |
| 3     | E3         | Event #3    | R    | 0     |
| 2     | E2         | Event #2    | R    | 0     |
| 1     | E1         | Event #1    | R    | 0     |
| 0     | E0         | Event #0    | R    | 0     |

**Table 5-345. Register Call Summary for Register TPCC\_SER\_Rn**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-346. TPCC\_SERH\_Rn**

|                         |                                                                                                                                                                                                                                                                                                                                    |                 |             |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x203C + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                      |                 |             |
| <b>Physical address</b> | 0x01C0 203C + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                 | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>      | Secondary Event Register (High Part):<br>The secondary event register is used along with the Event Register (ERH) to provide information on the state of an Event.<br>En = 0: Event is not currently in the Event Queue.<br>En = 1: Event is currently stored in Event Queue. Event arbiter will not prioritize additional events. |                 |             |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                  |                 |             |

| 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   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| E63 | E62 | E61 | E60 | E59 | E58 | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38 | E37 | E36 | E35 | E34 | E33 | E32 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E63        | Event #63   | R    | 0     |
| 30   | E62        | Event #62   | R    | 0     |
| 29   | E61        | Event #61   | R    | 0     |
| 28   | E60        | Event #60   | R    | 0     |
| 27   | E59        | Event #59   | R    | 0     |
| 26   | E58        | Event #58   | R    | 0     |
| 25   | E57        | Event #57   | R    | 0     |
| 24   | E56        | Event #56   | R    | 0     |
| 23   | E55        | Event #55   | R    | 0     |
| 22   | E54        | Event #54   | R    | 0     |
| 21   | E53        | Event #53   | R    | 0     |
| 20   | E52        | Event #52   | R    | 0     |
| 19   | E51        | Event #51   | R    | 0     |
| 18   | E50        | Event #50   | R    | 0     |
| 17   | E49        | Event #49   | R    | 0     |
| 16   | E48        | Event #48   | R    | 0     |
| 15   | E47        | Event #47   | R    | 0     |
| 14   | E46        | Event #46   | R    | 0     |
| 13   | E45        | Event #45   | R    | 0     |
| 12   | E44        | Event #44   | R    | 0     |
| 11   | E43        | Event #43   | R    | 0     |
| 10   | E42        | Event #42   | R    | 0     |
| 9    | E41        | Event #41   | R    | 0     |
| 8    | E40        | Event #40   | R    | 0     |
| 7    | E39        | Event #39   | R    | 0     |
| 6    | E38        | Event #38   | R    | 0     |
| 5    | E37        | Event #37   | R    | 0     |
| 4    | E36        | Event #36   | R    | 0     |
| 3    | E35        | Event #35   | R    | 0     |
| 2    | E34        | Event #34   | R    | 0     |
| 1    | E33        | Event #33   | R    | 0     |
| 0    | E32        | Event #32   | R    | 0     |

**Table 5-347. Register Call Summary for Register TPCC\_SERH\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-348. TPCC\_SECR\_Rn**

|                         |                                                                                                                                                                                                                        |                 |             |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x2040 + (0x200*n) n = 0 to 7                                                                                                                                                                                          |                 |             |
| <b>Physical address</b> | 0x01C0 2040 + (0x200*n) n = 0 to 7                                                                                                                                                                                     | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>      | Secondary Event Clear Register:<br>The secondary event clear register is used to clear the status of the SER registers.<br>CPU write of 1 to the SECR.En bit clears the SER register.<br>CPU write of 0 has no effect. |                 |             |
| <b>Type</b>             | W                                                                                                                                                                                                                      |                 |             |

| 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  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| E31 | E30 | E29 | E28 | E27 | E26 | E25 | E24 | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E31        | Event #31   | W    | 0     |
| 30   | E30        | Event #30   | W    | 0     |
| 29   | E29        | Event #29   | W    | 0     |
| 28   | E28        | Event #28   | W    | 0     |
| 27   | E27        | Event #27   | W    | 0     |
| 26   | E26        | Event #26   | W    | 0     |
| 25   | E25        | Event #25   | W    | 0     |
| 24   | E24        | Event #24   | W    | 0     |
| 23   | E23        | Event #23   | W    | 0     |
| 22   | E22        | Event #22   | W    | 0     |
| 21   | E21        | Event #21   | W    | 0     |
| 20   | E20        | Event #20   | W    | 0     |
| 19   | E19        | Event #19   | W    | 0     |
| 18   | E18        | Event #18   | W    | 0     |
| 17   | E17        | Event #17   | W    | 0     |
| 16   | E16        | Event #16   | W    | 0     |
| 15   | E15        | Event #15   | W    | 0     |
| 14   | E14        | Event #14   | W    | 0     |
| 13   | E13        | Event #13   | W    | 0     |
| 12   | E12        | Event #12   | W    | 0     |
| 11   | E11        | Event #11   | W    | 0     |
| 10   | E10        | Event #10   | W    | 0     |
| 9    | E9         | Event #9    | W    | 0     |
| 8    | E8         | Event #8    | W    | 0     |
| 7    | E7         | Event #7    | W    | 0     |
| 6    | E6         | Event #6    | W    | 0     |
| 5    | E5         | Event #5    | W    | 0     |
| 4    | E4         | Event #4    | W    | 0     |
| 3    | E3         | Event #3    | W    | 0     |
| 2    | E2         | Event #2    | W    | 0     |
| 1    | E1         | Event #1    | W    | 0     |
| 0    | E0         | Event #0    | W    | 0     |

**Table 5-349. Register Call Summary for Register TPCC\_SECR\_Rn**

**Table 5-350. TPCC\_SECRH\_Rn**

|                         |                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x2044 + (0x200*n) n = 0 to 7                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 2044 + (0x200*n) n = 0 to 7                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Secondary Event Clear Register (High Part):<br>The secondary event clear register is used to clear the status of the SERH registers.<br>CPU write of 1 to the SECRRH.En bit clears the SERH register.<br>CPU write of 0 has no effect. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| E63 | E62 | E61 | E60 | E59 | E58 | E57 | E56 | E55 | E54 | E53 | E52 | E51 | E50 | E49 | E48 | E47 | E46 | E45 | E44 | E43 | E42 | E41 | E40 | E39 | E38 | E37 | E36 | E35 | E34 | E33 | E32 |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 31   | E63        | Event #63   | W    | 0     |
| 30   | E62        | Event #62   | W    | 0     |
| 29   | E61        | Event #61   | W    | 0     |
| 28   | E60        | Event #60   | W    | 0     |
| 27   | E59        | Event #59   | W    | 0     |
| 26   | E58        | Event #58   | W    | 0     |
| 25   | E57        | Event #57   | W    | 0     |
| 24   | E56        | Event #56   | W    | 0     |
| 23   | E55        | Event #55   | W    | 0     |
| 22   | E54        | Event #54   | W    | 0     |
| 21   | E53        | Event #53   | W    | 0     |
| 20   | E52        | Event #52   | W    | 0     |
| 19   | E51        | Event #51   | W    | 0     |
| 18   | E50        | Event #50   | W    | 0     |
| 17   | E49        | Event #49   | W    | 0     |
| 16   | E48        | Event #48   | W    | 0     |
| 15   | E47        | Event #47   | W    | 0     |
| 14   | E46        | Event #46   | W    | 0     |
| 13   | E45        | Event #45   | W    | 0     |
| 12   | E44        | Event #44   | W    | 0     |
| 11   | E43        | Event #43   | W    | 0     |
| 10   | E42        | Event #42   | W    | 0     |
| 9    | E41        | Event #41   | W    | 0     |
| 8    | E40        | Event #40   | W    | 0     |
| 7    | E39        | Event #39   | W    | 0     |
| 6    | E38        | Event #38   | W    | 0     |
| 5    | E37        | Event #37   | W    | 0     |
| 4    | E36        | Event #36   | W    | 0     |
| 3    | E35        | Event #35   | W    | 0     |
| 2    | E34        | Event #34   | W    | 0     |
| 1    | E33        | Event #33   | W    | 0     |
| 0    | E32        | Event #32   | W    | 0     |

**Table 5-351. Register Call Summary for Register TPCC\_SECRH\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-352. TPCC\_IER\_Rn**

|                         |                                                                                                                                                                                                                                                                       |                 |             |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|--|--|
| <b>Address Offset</b>   | 0x2050 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                         | <b>Instance</b> | IVA2.2 TPCC |  |  |
| <b>Physical address</b> | 0x01C0 2050 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                    |                 |             |  |  |
| <b>Description</b>      | Int Enable Register:<br>IER.In is not directly writeable. Interrupts can be enabled through writes to IESR and can be disabled through writes to IEGR register.<br>IER.In = 0: IPR.In is NOT enabled for interrupts.<br>IER.In = 1: IPR.In IS enabled for interrupts. |                 |             |  |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                     |                 |             |  |  |

| 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  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| I31 | I30 | I29 | I28 | I27 | I26 | I25 | I24 | I23 | I22 | I21 | I20 | I19 | I18 | I17 | I16 | I15 | I14 | I13 | I12 | I11 | I10 | I9 | I8 | I7 | I6 | I5 | I4 | I3 | I2 | I1 | I0 |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 31   | I31        | Interrupt associated with TCC #31 | R    | 0     |
| 30   | I30        | Interrupt associated with TCC #30 | R    | 0     |
| 29   | I29        | Interrupt associated with TCC #29 | R    | 0     |
| 28   | I28        | Interrupt associated with TCC #28 | R    | 0     |
| 27   | I27        | Interrupt associated with TCC #27 | R    | 0     |
| 26   | I26        | Interrupt associated with TCC #26 | R    | 0     |
| 25   | I25        | Interrupt associated with TCC #25 | R    | 0     |
| 24   | I24        | Interrupt associated with TCC #24 | R    | 0     |
| 23   | I23        | Interrupt associated with TCC #23 | R    | 0     |
| 22   | I22        | Interrupt associated with TCC #22 | R    | 0     |
| 21   | I21        | Interrupt associated with TCC #21 | R    | 0     |
| 20   | I20        | Interrupt associated with TCC #20 | R    | 0     |
| 19   | I19        | Interrupt associated with TCC #19 | R    | 0     |
| 18   | I18        | Interrupt associated with TCC #18 | R    | 0     |
| 17   | I17        | Interrupt associated with TCC #17 | R    | 0     |
| 16   | I16        | Interrupt associated with TCC #16 | R    | 0     |
| 15   | I15        | Interrupt associated with TCC #15 | R    | 0     |
| 14   | I14        | Interrupt associated with TCC #14 | R    | 0     |
| 13   | I13        | Interrupt associated with TCC #13 | R    | 0     |
| 12   | I12        | Interrupt associated with TCC #12 | R    | 0     |
| 11   | I11        | Interrupt associated with TCC #11 | R    | 0     |
| 10   | I10        | Interrupt associated with TCC #10 | R    | 0     |
| 9    | I9         | Interrupt associated with TCC #9  | R    | 0     |
| 8    | I8         | Interrupt associated with TCC #8  | R    | 0     |
| 7    | I7         | Interrupt associated with TCC #7  | R    | 0     |
| 6    | I6         | Interrupt associated with TCC #6  | R    | 0     |
| 5    | I5         | Interrupt associated with TCC #5  | R    | 0     |
| 4    | I4         | Interrupt associated with TCC #4  | R    | 0     |
| 3    | I3         | Interrupt associated with TCC #3  | R    | 0     |
| 2    | I2         | Interrupt associated with TCC #2  | R    | 0     |
| 1    | I1         | Interrupt associated with TCC #1  | R    | 0     |
| 0    | I0         | Interrupt associated with TCC #0  | R    | 0     |

**Table 5-353. Register Call Summary for Register TPCC\_IER\_Rn**

**Table 5-354. TPCC\_IERH\_Rn**

|                         |                                                                                                                                                                                                                                                                                          |                 |             |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x2054 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                            |                 |             |
| <b>Physical address</b> | 0x01C0 2054 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                       | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>      | Int Enable Register (High Part):<br>IERH.In is not directly writeable. Interrupts can be enabled through writes to IESRH and can be disabled through writes to IEGRH register.<br>IERH.In = 0: IPRH.In is NOT enabled for interrupts.<br>IERH.In = 1: IPRH.In IS enabled for interrupts. |                 |             |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                        |                 |             |

| 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   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| I63 | I62 | I61 | I60 | I59 | I58 | I57 | I56 | I55 | I54 | I53 | I52 | I51 | I50 | I49 | I48 | I47 | I46 | I45 | I44 | I43 | I42 | I41 | I40 | I39 | I38 | I37 | I36 | I35 | I34 | I33 | I32 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31          | I63               | Interrupt associated with TCC #63 | R           | 0            |
| 30          | I62               | Interrupt associated with TCC #62 | R           | 0            |
| 29          | I61               | Interrupt associated with TCC #61 | R           | 0            |
| 28          | I60               | Interrupt associated with TCC #60 | R           | 0            |
| 27          | I59               | Interrupt associated with TCC #59 | R           | 0            |
| 26          | I58               | Interrupt associated with TCC #58 | R           | 0            |
| 25          | I57               | Interrupt associated with TCC #57 | R           | 0            |
| 24          | I56               | Interrupt associated with TCC #56 | R           | 0            |
| 23          | I55               | Interrupt associated with TCC #55 | R           | 0            |
| 22          | I54               | Interrupt associated with TCC #54 | R           | 0            |
| 21          | I53               | Interrupt associated with TCC #53 | R           | 0            |
| 20          | I52               | Interrupt associated with TCC #52 | R           | 0            |
| 19          | I51               | Interrupt associated with TCC #51 | R           | 0            |
| 18          | I50               | Interrupt associated with TCC #50 | R           | 0            |
| 17          | I49               | Interrupt associated with TCC #49 | R           | 0            |
| 16          | I48               | Interrupt associated with TCC #48 | R           | 0            |
| 15          | I47               | Interrupt associated with TCC #47 | R           | 0            |
| 14          | I46               | Interrupt associated with TCC #46 | R           | 0            |
| 13          | I45               | Interrupt associated with TCC #45 | R           | 0            |
| 12          | I44               | Interrupt associated with TCC #44 | R           | 0            |
| 11          | I43               | Interrupt associated with TCC #43 | R           | 0            |
| 10          | I42               | Interrupt associated with TCC #42 | R           | 0            |
| 9           | I41               | Interrupt associated with TCC #41 | R           | 0            |
| 8           | I40               | Interrupt associated with TCC #40 | R           | 0            |
| 7           | I39               | Interrupt associated with TCC #39 | R           | 0            |
| 6           | I38               | Interrupt associated with TCC #38 | R           | 0            |
| 5           | I37               | Interrupt associated with TCC #37 | R           | 0            |
| 4           | I36               | Interrupt associated with TCC #36 | R           | 0            |
| 3           | I35               | Interrupt associated with TCC #35 | R           | 0            |
| 2           | I34               | Interrupt associated with TCC #34 | R           | 0            |
| 1           | I33               | Interrupt associated with TCC #33 | R           | 0            |
| 0           | I32               | Interrupt associated with TCC #32 | R           | 0            |

**Table 5-355. Register Call Summary for Register TPCC\_IERH\_Rn**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-356. TPCC\_IECR\_Rn**

|                         |                                                                                                                                       |                 |             |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x2058 + (0x200*n) n = 0 to 7                                                                                                         |                 |             |
| <b>Physical address</b> | 0x01C0 2058 + (0x200*n) n = 0 to 7                                                                                                    | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>      | Int Enable Clear Register:<br>CPU write of 1 to the IEGR.In bit causes the IER.In bit to be cleared.<br>CPU write of 0 has no effect. |                 |             |
| <b>Type</b>             | W                                                                                                                                     |                 |             |

| 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  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| I31 | I30 | I29 | I28 | I27 | I26 | I25 | I24 | I23 | I22 | I21 | I20 | I19 | I18 | I17 | I16 | I15 | I14 | I13 | I12 | I11 | I10 | I9 | I8 | I7 | I6 | I5 | I4 | I3 | I2 | I1 | I0 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31          | I31               | Interrupt associated with TCC #31 | W           | 0            |
| 30          | I30               | Interrupt associated with TCC #30 | W           | 0            |
| 29          | I29               | Interrupt associated with TCC #29 | W           | 0            |
| 28          | I28               | Interrupt associated with TCC #28 | W           | 0            |
| 27          | I27               | Interrupt associated with TCC #27 | W           | 0            |
| 26          | I26               | Interrupt associated with TCC #26 | W           | 0            |
| 25          | I25               | Interrupt associated with TCC #25 | W           | 0            |
| 24          | I24               | Interrupt associated with TCC #24 | W           | 0            |
| 23          | I23               | Interrupt associated with TCC #23 | W           | 0            |
| 22          | I22               | Interrupt associated with TCC #22 | W           | 0            |
| 21          | I21               | Interrupt associated with TCC #21 | W           | 0            |
| 20          | I20               | Interrupt associated with TCC #20 | W           | 0            |
| 19          | I19               | Interrupt associated with TCC #19 | W           | 0            |
| 18          | I18               | Interrupt associated with TCC #18 | W           | 0            |
| 17          | I17               | Interrupt associated with TCC #17 | W           | 0            |
| 16          | I16               | Interrupt associated with TCC #16 | W           | 0            |
| 15          | I15               | Interrupt associated with TCC #15 | W           | 0            |
| 14          | I14               | Interrupt associated with TCC #14 | W           | 0            |
| 13          | I13               | Interrupt associated with TCC #13 | W           | 0            |
| 12          | I12               | Interrupt associated with TCC #12 | W           | 0            |
| 11          | I11               | Interrupt associated with TCC #11 | W           | 0            |
| 10          | I10               | Interrupt associated with TCC #10 | W           | 0            |
| 9           | I9                | Interrupt associated with TCC #9  | W           | 0            |
| 8           | I8                | Interrupt associated with TCC #8  | W           | 0            |
| 7           | I7                | Interrupt associated with TCC #7  | W           | 0            |
| 6           | I6                | Interrupt associated with TCC #6  | W           | 0            |
| 5           | I5                | Interrupt associated with TCC #5  | W           | 0            |
| 4           | I4                | Interrupt associated with TCC #4  | W           | 0            |
| 3           | I3                | Interrupt associated with TCC #3  | W           | 0            |
| 2           | I2                | Interrupt associated with TCC #2  | W           | 0            |
| 1           | I1                | Interrupt associated with TCC #1  | W           | 0            |
| 0           | I0                | Interrupt associated with TCC #0  | W           | 0            |

**Table 5-357. Register Call Summary for Register TPCC\_IECR\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-358. TPCC\_IECRH\_Rn**

|                         |                                                                                                                                                     |                 |              |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x205C + (0x200*n) n = 0 to 7                                                                                                                       |                 |              |
| <b>Physical address</b> | 0x01C0 205C + (0x200*n) n = 0 to 7                                                                                                                  | <b>Instance</b> | IV A2.2 TPCC |
| <b>Description</b>      | Int Enable Clear Register (High Part):<br>CPU write of 1 to the IECRH.In bit causes the IERH.In bit to be cleared.<br>CPU write of 0 has no effect. |                 |              |
| <b>Type</b>             | W                                                                                                                                                   |                 |              |

| 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   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| I63 | I62 | I61 | I60 | I59 | I58 | I57 | I56 | I55 | I54 | I53 | I52 | I51 | I50 | I49 | I48 | I47 | I46 | I45 | I44 | I43 | I42 | I41 | I40 | I39 | I38 | I37 | I36 | I35 | I34 | I33 | I32 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31          | I63               | Interrupt associated with TCC #63 | W           | 0            |
| 30          | I62               | Interrupt associated with TCC #62 | W           | 0            |
| 29          | I61               | Interrupt associated with TCC #61 | W           | 0            |
| 28          | I60               | Interrupt associated with TCC #60 | W           | 0            |
| 27          | I59               | Interrupt associated with TCC #59 | W           | 0            |
| 26          | I58               | Interrupt associated with TCC #58 | W           | 0            |
| 25          | I57               | Interrupt associated with TCC #57 | W           | 0            |
| 24          | I56               | Interrupt associated with TCC #56 | W           | 0            |
| 23          | I55               | Interrupt associated with TCC #55 | W           | 0            |
| 22          | I54               | Interrupt associated with TCC #54 | W           | 0            |
| 21          | I53               | Interrupt associated with TCC #53 | W           | 0            |
| 20          | I52               | Interrupt associated with TCC #52 | W           | 0            |
| 19          | I51               | Interrupt associated with TCC #51 | W           | 0            |
| 18          | I50               | Interrupt associated with TCC #50 | W           | 0            |
| 17          | I49               | Interrupt associated with TCC #49 | W           | 0            |
| 16          | I48               | Interrupt associated with TCC #48 | W           | 0            |
| 15          | I47               | Interrupt associated with TCC #47 | W           | 0            |
| 14          | I46               | Interrupt associated with TCC #46 | W           | 0            |
| 13          | I45               | Interrupt associated with TCC #45 | W           | 0            |
| 12          | I44               | Interrupt associated with TCC #44 | W           | 0            |
| 11          | I43               | Interrupt associated with TCC #43 | W           | 0            |
| 10          | I42               | Interrupt associated with TCC #42 | W           | 0            |
| 9           | I41               | Interrupt associated with TCC #41 | W           | 0            |
| 8           | I40               | Interrupt associated with TCC #40 | W           | 0            |
| 7           | I39               | Interrupt associated with TCC #39 | W           | 0            |
| 6           | I38               | Interrupt associated with TCC #38 | W           | 0            |
| 5           | I37               | Interrupt associated with TCC #37 | W           | 0            |
| 4           | I36               | Interrupt associated with TCC #36 | W           | 0            |
| 3           | I35               | Interrupt associated with TCC #35 | W           | 0            |
| 2           | I34               | Interrupt associated with TCC #34 | W           | 0            |
| 1           | I33               | Interrupt associated with TCC #33 | W           | 0            |
| 0           | I32               | Interrupt associated with TCC #32 | W           | 0            |

**Table 5-359. Register Call Summary for Register TPCC\_IECRH\_Rn**

IV A2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-360. TPCCIESR\_Rn**

|                         |                                                                                                                                  |                 |             |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x2060 + (0x200*n) n = 0 to 7                                                                                                    |                 |             |
| <b>Physical address</b> | 0x01C0 2060 + (0x200*n) n = 0 to 7                                                                                               | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>      | Int Enable Set Register:<br>CPU write of 1 to the IESR.In bit causes the IESR.In bit to be set.<br>CPU write of 0 has no effect. |                 |             |
| <b>Type</b>             | W                                                                                                                                |                 |             |

| 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  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| I31 | I30 | I29 | I28 | I27 | I26 | I25 | I24 | I23 | I22 | I21 | I20 | I19 | I18 | I17 | I16 | I15 | I14 | I13 | I12 | I11 | I10 | I9 | I8 | I7 | I6 | I5 | I4 | I3 | I2 | I1 | I0 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31          | I31               | Interrupt associated with TCC #31 | W           | 0            |
| 30          | I30               | Interrupt associated with TCC #30 | W           | 0            |
| 29          | I29               | Interrupt associated with TCC #29 | W           | 0            |
| 28          | I28               | Interrupt associated with TCC #28 | W           | 0            |
| 27          | I27               | Interrupt associated with TCC #27 | W           | 0            |
| 26          | I26               | Interrupt associated with TCC #26 | W           | 0            |
| 25          | I25               | Interrupt associated with TCC #25 | W           | 0            |
| 24          | I24               | Interrupt associated with TCC #24 | W           | 0            |
| 23          | I23               | Interrupt associated with TCC #23 | W           | 0            |
| 22          | I22               | Interrupt associated with TCC #22 | W           | 0            |
| 21          | I21               | Interrupt associated with TCC #21 | W           | 0            |
| 20          | I20               | Interrupt associated with TCC #20 | W           | 0            |
| 19          | I19               | Interrupt associated with TCC #19 | W           | 0            |
| 18          | I18               | Interrupt associated with TCC #18 | W           | 0            |
| 17          | I17               | Interrupt associated with TCC #17 | W           | 0            |
| 16          | I16               | Interrupt associated with TCC #16 | W           | 0            |
| 15          | I15               | Interrupt associated with TCC #15 | W           | 0            |
| 14          | I14               | Interrupt associated with TCC #14 | W           | 0            |
| 13          | I13               | Interrupt associated with TCC #13 | W           | 0            |
| 12          | I12               | Interrupt associated with TCC #12 | W           | 0            |
| 11          | I11               | Interrupt associated with TCC #11 | W           | 0            |
| 10          | I10               | Interrupt associated with TCC #10 | W           | 0            |
| 9           | I9                | Interrupt associated with TCC #9  | W           | 0            |
| 8           | I8                | Interrupt associated with TCC #8  | W           | 0            |
| 7           | I7                | Interrupt associated with TCC #7  | W           | 0            |
| 6           | I6                | Interrupt associated with TCC #6  | W           | 0            |
| 5           | I5                | Interrupt associated with TCC #5  | W           | 0            |
| 4           | I4                | Interrupt associated with TCC #4  | W           | 0            |
| 3           | I3                | Interrupt associated with TCC #3  | W           | 0            |
| 2           | I2                | Interrupt associated with TCC #2  | W           | 0            |
| 1           | I1                | Interrupt associated with TCC #1  | W           | 0            |
| 0           | I0                | Interrupt associated with TCC #0  | W           | 0            |

**Table 5-361. Register Call Summary for Register TPCCIESR\_Rn**

**Table 5-362. TPCC\_IERSH\_Rn**

|                         |                                                                                                                                                |                 |              |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x2064 + (0x200*n) n = 0 to 7                                                                                                                  |                 |              |
| <b>Physical address</b> | 0x01C0 2064 + (0x200*n) n = 0 to 7                                                                                                             | <b>Instance</b> | IV A2.2 TPCC |
| <b>Description</b>      | Int Enable Set Register (High Part):<br>CPU write of 1 to the IESRH.In bit causes the IESRH.In bit to be set.<br>CPU write of 0 has no effect. |                 |              |
| <b>Type</b>             | W                                                                                                                                              |                 |              |

| 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   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| I63 | I62 | I61 | I60 | I59 | I58 | I57 | I56 | I55 | I54 | I53 | I52 | I51 | I50 | I49 | I48 | I47 | I46 | I45 | I44 | I43 | I42 | I41 | I40 | I39 | I38 | I37 | I36 | I35 | I34 | I33 | I32 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31          | I63               | Interrupt associated with TCC #63 | W           | 0            |
| 30          | I62               | Interrupt associated with TCC #62 | W           | 0            |
| 29          | I61               | Interrupt associated with TCC #61 | W           | 0            |
| 28          | I60               | Interrupt associated with TCC #60 | W           | 0            |
| 27          | I59               | Interrupt associated with TCC #59 | W           | 0            |
| 26          | I58               | Interrupt associated with TCC #58 | W           | 0            |
| 25          | I57               | Interrupt associated with TCC #57 | W           | 0            |
| 24          | I56               | Interrupt associated with TCC #56 | W           | 0            |
| 23          | I55               | Interrupt associated with TCC #55 | W           | 0            |
| 22          | I54               | Interrupt associated with TCC #54 | W           | 0            |
| 21          | I53               | Interrupt associated with TCC #53 | W           | 0            |
| 20          | I52               | Interrupt associated with TCC #52 | W           | 0            |
| 19          | I51               | Interrupt associated with TCC #51 | W           | 0            |
| 18          | I50               | Interrupt associated with TCC #50 | W           | 0            |
| 17          | I49               | Interrupt associated with TCC #49 | W           | 0            |
| 16          | I48               | Interrupt associated with TCC #48 | W           | 0            |
| 15          | I47               | Interrupt associated with TCC #47 | W           | 0            |
| 14          | I46               | Interrupt associated with TCC #46 | W           | 0            |
| 13          | I45               | Interrupt associated with TCC #45 | W           | 0            |
| 12          | I44               | Interrupt associated with TCC #44 | W           | 0            |
| 11          | I43               | Interrupt associated with TCC #43 | W           | 0            |
| 10          | I42               | Interrupt associated with TCC #42 | W           | 0            |
| 9           | I41               | Interrupt associated with TCC #41 | W           | 0            |
| 8           | I40               | Interrupt associated with TCC #40 | W           | 0            |
| 7           | I39               | Interrupt associated with TCC #39 | W           | 0            |
| 6           | I38               | Interrupt associated with TCC #38 | W           | 0            |
| 5           | I37               | Interrupt associated with TCC #37 | W           | 0            |
| 4           | I36               | Interrupt associated with TCC #36 | W           | 0            |
| 3           | I35               | Interrupt associated with TCC #35 | W           | 0            |
| 2           | I34               | Interrupt associated with TCC #34 | W           | 0            |
| 1           | I33               | Interrupt associated with TCC #33 | W           | 0            |
| 0           | I32               | Interrupt associated with TCC #32 | W           | 0            |

**Table 5-363. Register Call Summary for Register TPCC\_IERSH\_Rn**

IV A2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-364. TPCC\_IPR\_Rn**

|                         |                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x2068 + (0x200*n) n = 0 to 7                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 2068 + (0x200*n) n = 0 to 7                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Interrupt Pending Register:<br>IPR.In bit is set when a interrupt completion code with TCC of N is detected.<br>IPR.In bit is cleared through software by writing 1 to ICR.In bit. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| I31 | I30 | I29 | I28 | I27 | I26 | I25 | I24 | I23 | I22 | I21 | I20 | I19 | I18 | I17 | I16 | I15 | I14 | I13 | I12 | I11 | I10 | I9 | I8 | I7 | I6 | I5 | I4 | I3 | I2 | I1 | I0 |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 31   | I31        | Interrupt associated with TCC #31 | R    | 0     |
| 30   | I30        | Interrupt associated with TCC #30 | R    | 0     |
| 29   | I29        | Interrupt associated with TCC #29 | R    | 0     |
| 28   | I28        | Interrupt associated with TCC #28 | R    | 0     |
| 27   | I27        | Interrupt associated with TCC #27 | R    | 0     |
| 26   | I26        | Interrupt associated with TCC #26 | R    | 0     |
| 25   | I25        | Interrupt associated with TCC #25 | R    | 0     |
| 24   | I24        | Interrupt associated with TCC #24 | R    | 0     |
| 23   | I23        | Interrupt associated with TCC #23 | R    | 0     |
| 22   | I22        | Interrupt associated with TCC #22 | R    | 0     |
| 21   | I21        | Interrupt associated with TCC #21 | R    | 0     |
| 20   | I20        | Interrupt associated with TCC #20 | R    | 0     |
| 19   | I19        | Interrupt associated with TCC #19 | R    | 0     |
| 18   | I18        | Interrupt associated with TCC #18 | R    | 0     |
| 17   | I17        | Interrupt associated with TCC #17 | R    | 0     |
| 16   | I16        | Interrupt associated with TCC #16 | R    | 0     |
| 15   | I15        | Interrupt associated with TCC #15 | R    | 0     |
| 14   | I14        | Interrupt associated with TCC #14 | R    | 0     |
| 13   | I13        | Interrupt associated with TCC #13 | R    | 0     |
| 12   | I12        | Interrupt associated with TCC #12 | R    | 0     |
| 11   | I11        | Interrupt associated with TCC #11 | R    | 0     |
| 10   | I10        | Interrupt associated with TCC #10 | R    | 0     |
| 9    | I9         | Interrupt associated with TCC #9  | R    | 0     |
| 8    | I8         | Interrupt associated with TCC #8  | R    | 0     |
| 7    | I7         | Interrupt associated with TCC #7  | R    | 0     |
| 6    | I6         | Interrupt associated with TCC #6  | R    | 0     |
| 5    | I5         | Interrupt associated with TCC #5  | R    | 0     |
| 4    | I4         | Interrupt associated with TCC #4  | R    | 0     |
| 3    | I3         | Interrupt associated with TCC #3  | R    | 0     |
| 2    | I2         | Interrupt associated with TCC #2  | R    | 0     |
| 1    | I1         | Interrupt associated with TCC #1  | R    | 0     |
| 0    | I0         | Interrupt associated with TCC #0  | R    | 0     |

**Table 5-365. Register Call Summary for Register TPCC\_IPR\_Rn**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-366. TPCC\_IPRH\_Rn**

|                         |                                                                                                                                                                                                   |                 |              |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x206C + (0x200*n) n = 0 to 7                                                                                                                                                                     |                 |              |
| <b>Physical address</b> | 0x01C0 206C + (0x200*n) n = 0 to 7                                                                                                                                                                | <b>Instance</b> | IV A2.2 TPCC |
| <b>Description</b>      | Interrupt Pending Register (High Part):<br>IPRH.In bit is set when a interrupt completion code with TCC of N is detected.<br>IPRH.In bit is cleared through software by writing 1 to ICRH.In bit. |                 |              |
| <b>Type</b>             | R                                                                                                                                                                                                 |                 |              |

| 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   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| I63 | I62 | I61 | I60 | I59 | I58 | I57 | I56 | I55 | I54 | I53 | I52 | I51 | I50 | I49 | I48 | I47 | I46 | I45 | I44 | I43 | I42 | I41 | I40 | I39 | I38 | I37 | I36 | I35 | I34 | I33 | I32 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31          | I63               | Interrupt associated with TCC #63 | R           | 0            |
| 30          | I62               | Interrupt associated with TCC #62 | R           | 0            |
| 29          | I61               | Interrupt associated with TCC #61 | R           | 0            |
| 28          | I60               | Interrupt associated with TCC #60 | R           | 0            |
| 27          | I59               | Interrupt associated with TCC #59 | R           | 0            |
| 26          | I58               | Interrupt associated with TCC #58 | R           | 0            |
| 25          | I57               | Interrupt associated with TCC #57 | R           | 0            |
| 24          | I56               | Interrupt associated with TCC #56 | R           | 0            |
| 23          | I55               | Interrupt associated with TCC #55 | R           | 0            |
| 22          | I54               | Interrupt associated with TCC #54 | R           | 0            |
| 21          | I53               | Interrupt associated with TCC #53 | R           | 0            |
| 20          | I52               | Interrupt associated with TCC #52 | R           | 0            |
| 19          | I51               | Interrupt associated with TCC #51 | R           | 0            |
| 18          | I50               | Interrupt associated with TCC #50 | R           | 0            |
| 17          | I49               | Interrupt associated with TCC #49 | R           | 0            |
| 16          | I48               | Interrupt associated with TCC #48 | R           | 0            |
| 15          | I47               | Interrupt associated with TCC #47 | R           | 0            |
| 14          | I46               | Interrupt associated with TCC #46 | R           | 0            |
| 13          | I45               | Interrupt associated with TCC #45 | R           | 0            |
| 12          | I44               | Interrupt associated with TCC #44 | R           | 0            |
| 11          | I43               | Interrupt associated with TCC #43 | R           | 0            |
| 10          | I42               | Interrupt associated with TCC #42 | R           | 0            |
| 9           | I41               | Interrupt associated with TCC #41 | R           | 0            |
| 8           | I40               | Interrupt associated with TCC #40 | R           | 0            |
| 7           | I39               | Interrupt associated with TCC #39 | R           | 0            |
| 6           | I38               | Interrupt associated with TCC #38 | R           | 0            |
| 5           | I37               | Interrupt associated with TCC #37 | R           | 0            |
| 4           | I36               | Interrupt associated with TCC #36 | R           | 0            |
| 3           | I35               | Interrupt associated with TCC #35 | R           | 0            |
| 2           | I34               | Interrupt associated with TCC #34 | R           | 0            |
| 1           | I33               | Interrupt associated with TCC #33 | R           | 0            |
| 0           | I32               | Interrupt associated with TCC #32 | R           | 0            |

**Table 5-367. Register Call Summary for Register TPCC\_IPRH\_Rn**

IV A2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-368. TPCC\_ICR\_Rn**

|                         |                                                                                                                                                                                                                             |                 |             |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|--|--|
| <b>Address Offset</b>   | 0x2070 + (0x200*n) n = 0 to 7                                                                                                                                                                                               | <b>Instance</b> | IVA2.2 TPCC |  |  |
| <b>Physical address</b> | 0x01C0 2070 + (0x200*n) n = 0 to 7                                                                                                                                                                                          |                 |             |  |  |
| <b>Description</b>      | Interrupt Clear Register:<br>CPU write of 1 to the ICR.In bit causes the IPR.In bit to be cleared.<br>CPU write of 0 has no effect.<br>All IPR.In bits must be cleared before additional interrupts will be asserted by CC. |                 |             |  |  |
| <b>Type</b>             | W                                                                                                                                                                                                                           |                 |             |  |  |

| 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  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| I31 | I30 | I29 | I28 | I27 | I26 | I25 | I24 | I23 | I22 | I21 | I20 | I19 | I18 | I17 | I16 | I15 | I14 | I13 | I12 | I11 | I10 | I9 | I8 | I7 | I6 | I5 | I4 | I3 | I2 | I1 | I0 |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 31   | I31        | Interrupt associated with TCC #31 | W    | 0     |
| 30   | I30        | Interrupt associated with TCC #30 | W    | 0     |
| 29   | I29        | Interrupt associated with TCC #29 | W    | 0     |
| 28   | I28        | Interrupt associated with TCC #28 | W    | 0     |
| 27   | I27        | Interrupt associated with TCC #27 | W    | 0     |
| 26   | I26        | Interrupt associated with TCC #26 | W    | 0     |
| 25   | I25        | Interrupt associated with TCC #25 | W    | 0     |
| 24   | I24        | Interrupt associated with TCC #24 | W    | 0     |
| 23   | I23        | Interrupt associated with TCC #23 | W    | 0     |
| 22   | I22        | Interrupt associated with TCC #22 | W    | 0     |
| 21   | I21        | Interrupt associated with TCC #21 | W    | 0     |
| 20   | I20        | Interrupt associated with TCC #20 | W    | 0     |
| 19   | I19        | Interrupt associated with TCC #19 | W    | 0     |
| 18   | I18        | Interrupt associated with TCC #18 | W    | 0     |
| 17   | I17        | Interrupt associated with TCC #17 | W    | 0     |
| 16   | I16        | Interrupt associated with TCC #16 | W    | 0     |
| 15   | I15        | Interrupt associated with TCC #15 | W    | 0     |
| 14   | I14        | Interrupt associated with TCC #14 | W    | 0     |
| 13   | I13        | Interrupt associated with TCC #13 | W    | 0     |
| 12   | I12        | Interrupt associated with TCC #12 | W    | 0     |
| 11   | I11        | Interrupt associated with TCC #11 | W    | 0     |
| 10   | I10        | Interrupt associated with TCC #10 | W    | 0     |
| 9    | I9         | Interrupt associated with TCC #9  | W    | 0     |
| 8    | I8         | Interrupt associated with TCC #8  | W    | 0     |
| 7    | I7         | Interrupt associated with TCC #7  | W    | 0     |
| 6    | I6         | Interrupt associated with TCC #6  | W    | 0     |
| 5    | I5         | Interrupt associated with TCC #5  | W    | 0     |
| 4    | I4         | Interrupt associated with TCC #4  | W    | 0     |
| 3    | I3         | Interrupt associated with TCC #3  | W    | 0     |
| 2    | I2         | Interrupt associated with TCC #2  | W    | 0     |
| 1    | I1         | Interrupt associated with TCC #1  | W    | 0     |
| 0    | I0         | Interrupt associated with TCC #0  | W    | 0     |

**Table 5-369. Register Call Summary for Register TPCC\_ICR\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-370. TPCC\_ICRH\_Rn**

|                         |                                                                                                                                                                                                                                            |                 |             |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x2074 + (0x200*n) n = 0 to 7                                                                                                                                                                                                              |                 |             |
| <b>Physical address</b> | 0x01C0 2074 + (0x200*n) n = 0 to 7                                                                                                                                                                                                         | <b>Instance</b> | IVA2.2 TPCC |
| <b>Description</b>      | Interrupt Clear Register (High Part):<br>CPU write of 1 to the ICRH.In bit causes the IPRH.In bit to be cleared.<br>CPU write of 0 has no effect.<br>All IPRH.In bits must be cleared before additional interrupts will be asserted by CC. |                 |             |
| <b>Type</b>             | W                                                                                                                                                                                                                                          |                 |             |

| 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   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| I63 | I62 | I61 | I60 | I59 | I58 | I57 | I56 | I55 | I54 | I53 | I52 | I51 | I50 | I49 | I48 | I47 | I46 | I45 | I44 | I43 | I42 | I41 | I40 | I39 | I38 | I37 | I36 | I35 | I34 | I33 | I32 |

| Bits | Field Name | Description                       | Type | Reset |
|------|------------|-----------------------------------|------|-------|
| 31   | I63        | Interrupt associated with TCC #63 | W    | 0     |
| 30   | I62        | Interrupt associated with TCC #62 | W    | 0     |
| 29   | I61        | Interrupt associated with TCC #61 | W    | 0     |
| 28   | I60        | Interrupt associated with TCC #60 | W    | 0     |
| 27   | I59        | Interrupt associated with TCC #59 | W    | 0     |
| 26   | I58        | Interrupt associated with TCC #58 | W    | 0     |
| 25   | I57        | Interrupt associated with TCC #57 | W    | 0     |
| 24   | I56        | Interrupt associated with TCC #56 | W    | 0     |
| 23   | I55        | Interrupt associated with TCC #55 | W    | 0     |
| 22   | I54        | Interrupt associated with TCC #54 | W    | 0     |
| 21   | I53        | Interrupt associated with TCC #53 | W    | 0     |
| 20   | I52        | Interrupt associated with TCC #52 | W    | 0     |
| 19   | I51        | Interrupt associated with TCC #51 | W    | 0     |
| 18   | I50        | Interrupt associated with TCC #50 | W    | 0     |
| 17   | I49        | Interrupt associated with TCC #49 | W    | 0     |
| 16   | I48        | Interrupt associated with TCC #48 | W    | 0     |
| 15   | I47        | Interrupt associated with TCC #47 | W    | 0     |
| 14   | I46        | Interrupt associated with TCC #46 | W    | 0     |
| 13   | I45        | Interrupt associated with TCC #45 | W    | 0     |
| 12   | I44        | Interrupt associated with TCC #44 | W    | 0     |
| 11   | I43        | Interrupt associated with TCC #43 | W    | 0     |
| 10   | I42        | Interrupt associated with TCC #42 | W    | 0     |
| 9    | I41        | Interrupt associated with TCC #41 | W    | 0     |
| 8    | I40        | Interrupt associated with TCC #40 | W    | 0     |
| 7    | I39        | Interrupt associated with TCC #39 | W    | 0     |
| 6    | I38        | Interrupt associated with TCC #38 | W    | 0     |
| 5    | I37        | Interrupt associated with TCC #37 | W    | 0     |
| 4    | I36        | Interrupt associated with TCC #36 | W    | 0     |
| 3    | I35        | Interrupt associated with TCC #35 | W    | 0     |
| 2    | I34        | Interrupt associated with TCC #34 | W    | 0     |
| 1    | I33        | Interrupt associated with TCC #33 | W    | 0     |
| 0    | I32        | Interrupt associated with TCC #32 | W    | 0     |

**Table 5-371. Register Call Summary for Register TPCC\_ICRH\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-372. TPCC\_IEVAL\_Rn**

|                         |                                    |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |             |
|-------------------------|------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|-------------|
| <b>Address Offset</b>   | 0x2078 + (0x200*n) n = 0 to 7      |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |             |
| <b>Physical address</b> | 0x01C0 2078 + (0x200*n) n = 0 to 7 |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |             |
| <b>Description</b>      | Interrupt Eval Register            |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |             |
| <b>Type</b>             | W                                  |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |             |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |             |
| Reserved                |                                    |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | SET<br>EVAL |

| Bits | Field Name | Description                                                                                                                                                                                          | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | Reserved   | Write 0s for future compatibility.                                                                                                                                                                   | W    | 0x00000000 |
| 1    | SET        | Interrupt Set:<br>CPU write of 1 to the SETn bit causes the tpcc_intN output signal to be pulsed regardless of state of interrupts enable (IERn) and status (IPRn).<br>CPU write of 0 has no effect. | W    | 0          |
| 0    | EVAL       | Interrupt Evaluate:<br>CPU write of 1 to the EVALn bit causes the tpcc_intN output signal to be pulsed if any enabled interrupts (IERn) are still pending (IPRn).<br>CPU write of 0 has no effect.   | W    | 0          |

**Table 5-373. Register Call Summary for Register TPCC\_IEVAL\_Rn**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-374. TPCC\_QER\_Rn**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       |                 |    |    |    |    |    |    |    |    |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----|----|----|----|----|----|----|----|--|--|--|--|--|
| <b>Address Offset</b>   | 0x2080 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                       |                 |    |    |    |    |    |    |    |    |  |  |  |  |  |
| <b>Physical address</b> | 0x01C0 2080 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                       |                 |    |    |    |    |    |    |    |    |  |  |  |  |  |
| <b>Description</b>      | QDMA Event Register:<br>If QER.En bit is set, then the corresponding QDMA channel is prioritized vs. other qdma events for submission to the TC. QER.En bit is set when a vbus write byte matches the address defined in the QCHMAPn register. QER.En bit is cleared when the corresponding event is prioritized and serviced. QER.En is also cleared when user writes a 1 to the QECCR.En bit. If the QER.En bit is already set and a new QDMA event is detected due to user write to QDMA trigger location and QEER register is set, then the corresponding bit in the QDMA Event Missed Register is set. |                       |                 |    |    |    |    |    |    |    |    |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                       |                 |    |    |    |    |    |    |    |    |  |  |  |  |  |
| 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 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |  |  |  |  |  |
| Reserved                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       |                 |    |    |    |    |    |    |    |    |  |  |  |  |  |

| Bits | Field Name | Description     | Type | Reset    |
|------|------------|-----------------|------|----------|
| 31:8 | Reserved   | Read returns 0. | R    | 0x000000 |
| 7    | E7         | Event #7        | R    | 0        |
| 6    | E6         | Event #6        | R    | 0        |
| 5    | E5         | Event #5        | R    | 0        |
| 4    | E4         | Event #4        | R    | 0        |
| 3    | E3         | Event #3        | R    | 0        |
| 2    | E2         | Event #2        | R    | 0        |
| 1    | E1         | Event #1        | R    | 0        |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
| 0    | E0         | Event #0    | R    | 0     |

**Table 5-375. Register Call Summary for Register TPCC\_QER\_Rn**

I/VA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-376. TPCC\_QEER\_Rn**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                 |              |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x2084 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>Instance</b> | I/VA2.2 TPCC |
| <b>Physical address</b> | 0x01C0 2084 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                 |              |
| <b>Description</b>      | QDMA Event Enable Register:<br>Enabled/disabled QDMA address comparator for QDMA Channel N. QEER.En is not directly writeable. QDMA channels can be enabled through writes to QEESR and can be disabled through writes to QEECR register.<br>QEER.En = 1, The corresponding QDMA channel comparator is enabled and Events will be recognized and latched in QER.En.<br>QEER.En = 0, The corresponding QDMA channel comparator is disabled. Events will not be recognized/latched in QER.En. |                 |              |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                 |              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description     | Type | Reset    |
|------|------------|-----------------|------|----------|
| 31:8 | Reserved   | Read returns 0. | R    | 0x000000 |
| 7    | E7         | Event #7        | R    | 0        |
| 6    | E6         | Event #6        | R    | 0        |
| 5    | E5         | Event #5        | R    | 0        |
| 4    | E4         | Event #4        | R    | 0        |
| 3    | E3         | Event #3        | R    | 0        |
| 2    | E2         | Event #2        | R    | 0        |
| 1    | E1         | Event #1        | R    | 0        |
| 0    | E0         | Event #0        | R    | 0        |

**Table 5-377. Register Call Summary for Register TPCC\_QEER\_Rn**

I/VA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-378. TPCC\_QEECR\_Rn**

|                         |                                                                                                                                                |                 |              |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x2088 + (0x200*n) n = 0 to 7                                                                                                                  | <b>Instance</b> | I/VA2.2 TPCC |
| <b>Physical address</b> | 0x01C0 2088 + (0x200*n) n = 0 to 7                                                                                                             |                 |              |
| <b>Description</b>      | QDMA Event Enable Clear Register:<br>CPU write of 1 to the QEECR.En bit causes the QEER.En bit to be cleared.<br>CPU write of 0 has no effect. |                 |              |
| <b>Type</b>             | W                                                                                                                                              |                 |              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                        | Type | Reset    |
|------|------------|------------------------------------|------|----------|
| 31:8 | Reserved   | Write 0s for future compatibility. | W    | 0x000000 |
| 7    | E7         | Event #7                           | W    | 0        |
| 6    | E6         | Event #6                           | W    | 0        |
| 5    | E5         | Event #5                           | W    | 0        |
| 4    | E4         | Event #4                           | W    | 0        |
| 3    | E3         | Event #3                           | W    | 0        |
| 2    | E2         | Event #2                           | W    | 0        |
| 1    | E1         | Event #1                           | W    | 0        |
| 0    | E0         | Event #0                           | W    | 0        |

**Table 5-379. Register Call Summary for Register TPCC\_QEECR\_Rn**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-380. TPCC\_QEESR\_Rn**

|                  |                                                                                                                                           |          |             |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------|
| Address Offset   | 0x208C + (0x200*n) n = 0 to 7                                                                                                             | Instance | IVA2.2 TPCC |
| Physical address | 0x01C0 208C + (0x200*n) n = 0 to 7                                                                                                        | Instance | IVA2.2 TPCC |
| Description      | QDMA Event Enable Set Register:<br>CPU write of 1 to the QEESR.En bit causes the QEESR.En bit to be set.<br>CPU write of 0 has no effect. |          |             |
| Type             | W                                                                                                                                         |          |             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |    |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|
| 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  |    |    |    |    |    |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |

| Bits | Field Name | Description                        | Type | Reset    |
|------|------------|------------------------------------|------|----------|
| 31:8 | Reserved   | Write 0s for future compatibility. | W    | 0x000000 |
| 7    | E7         | Event #7                           | W    | 0        |
| 6    | E6         | Event #6                           | W    | 0        |
| 5    | E5         | Event #5                           | W    | 0        |
| 4    | E4         | Event #4                           | W    | 0        |
| 3    | E3         | Event #3                           | W    | 0        |
| 2    | E2         | Event #2                           | W    | 0        |
| 1    | E1         | Event #1                           | W    | 0        |
| 0    | E0         | Event #0                           | W    | 0        |

**Table 5-381. Register Call Summary for Register TPCC\_QEESR\_Rn**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-382. TPCC\_QSER\_Rn**

|                         |                                                                                                                                                                                                                                                                                                                                           |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <b>Address Offset</b>   | 0x2090 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                             |  |
| <b>Physical address</b> | 0x01C0 2090 + (0x200*n) n = 0 to 7 <b>Instance</b> IVA2.2 TPCC                                                                                                                                                                                                                                                                            |  |
| <b>Description</b>      | QDMA Secondary Event Register:<br>The QDMA secondary event register is used along with the QDMA Event Register (QER) to provide information on the state of a QDMA Event.<br>En = 0: Event is not currently in the Event Queue.<br>En = 1: Event is currently stored in Event Queue. Event arbiter will not prioritize additional events. |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                         |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description     | Type | Reset    |
|------|------------|-----------------|------|----------|
| 31:8 | Reserved   | Read returns 0. | R    | 0x000000 |
| 7    | E7         | Event #7        | R    | 0        |
| 6    | E6         | Event #6        | R    | 0        |
| 5    | E5         | Event #5        | R    | 0        |
| 4    | E4         | Event #4        | R    | 0        |
| 3    | E3         | Event #3        | R    | 0        |
| 2    | E2         | Event #2        | R    | 0        |
| 1    | E1         | Event #1        | R    | 0        |
| 0    | E0         | Event #0        | R    | 0        |

**Table 5-383. Register Call Summary for Register TPCC\_QSER\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-384. TPCC\_QSECR\_Rn**

|                         |                                                                                                                                                                                                                                                                                                                                                                   |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <b>Address Offset</b>   | 0x2094 + (0x200*n) n = 0 to 7                                                                                                                                                                                                                                                                                                                                     |  |
| <b>Physical address</b> | 0x01C0 2094 + (0x200*n) n = 0 to 7 <b>Instance</b> IVA2.2 TPCC                                                                                                                                                                                                                                                                                                    |  |
| <b>Description</b>      | QDMA Secondary Event Clear Register:<br>The secondary event clear register is used to clear the status of the QSER and QER register (note that this is slightly different than the SER operation, which does not clear the ER.En register).<br>CPU write of 1 to the QSECR.En bit clears the QSER.En and QER.En register fields.<br>CPU write of 0 has no effect. |  |
| <b>Type</b>             | W                                                                                                                                                                                                                                                                                                                                                                 |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                        | Type | Reset    |
|------|------------|------------------------------------|------|----------|
| 31:8 | Reserved   | Write 0s for future compatibility. | W    | 0x000000 |
| 7    | E7         | Event #7                           | W    | 0        |
| 6    | E6         | Event #6                           | W    | 0        |
| 5    | E5         | Event #5                           | W    | 0        |
| 4    | E4         | Event #4                           | W    | 0        |
| 3    | E3         | Event #3                           | W    | 0        |
| 2    | E2         | Event #2                           | W    | 0        |
| 1    | E1         | Event #1                           | W    | 0        |
| 0    | E0         | Event #0                           | W    | 0        |

**Table 5-385. Register Call Summary for Register TPCC\_QSECR\_Rn**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-386. TPCC\_OPTm**

|                  |          |                        |        |    |         |        |          |         |          |    |     |          |    |             |         |      |    |          |    |        |         |     |     |   |   |   |   |   |   |   |   |
|------------------|----------|------------------------|--------|----|---------|--------|----------|---------|----------|----|-----|----------|----|-------------|---------|------|----|----------|----|--------|---------|-----|-----|---|---|---|---|---|---|---|---|
| Address Offset   |          | 0x4000 + (0x20*m)      |        |    |         |        |          |         |          |    |     |          |    |             |         |      |    |          |    |        |         |     |     |   |   |   |   |   |   |   |   |
| Physical address |          | 0x01C0 4000 + (0x20*m) |        |    |         |        |          |         |          |    |     | Instance |    | IVA2.2 TPCC |         |      |    |          |    |        |         |     |     |   |   |   |   |   |   |   |   |
| Description      |          | Options Parameter      |        |    |         |        |          |         |          |    |     |          |    |             |         |      |    |          |    |        |         |     |     |   |   |   |   |   |   |   |   |
| Type             |          | RW                     |        |    |         |        |          |         |          |    |     |          |    |             |         |      |    |          |    |        |         |     |     |   |   |   |   |   |   |   |   |
| 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 |
| PRIV             | Reserved |                        | PRIVID |    | ITCCHEN | TCCHEN | ITCINTEN | TCINTEN | Reserved |    | TCC |          |    |             | TCCMODE | FWID |    | Reserved |    | STATIC | SYNCDIM | DAM | SAM |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | PRIV       | Privilege level:<br>Privilege level (supervisor vs. user) for the host/cpu/dma that programmed this PaRAM Entry. Value is set with the vbus priv value when any part of the PaRAM Entry is written. Not writeable through vbus wdata bus. Is readable through VBus rdata bus.<br>PRIV = 0: User level privilege<br>PRIV = 1: Supervisor level privilege                                                                                                      | R    | -     |
| 30:27 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0x-   |
| 26:24 | PRIVID     | Privilege ID:<br>Privilege ID for the external host/cpu/dma that programmed this PaRAM Entry. This value is set with the vbus privid value when any part of the PaRAM Entry is written. Not writeable through vbus wdata bus. Is readable through VBus rdata bus.                                                                                                                                                                                            | R    | 0x-   |
| 23    | ITCCHEN    | Intermediate transfer completion chaining enable:<br>0: Intermediate transfer complete chaining is disabled.<br>1: Intermediate transfer complete chaining is enabled.                                                                                                                                                                                                                                                                                       | RW   | -     |
| 22    | TCCHEN     | Transfer complete chaining enable:<br>0: Transfer complete chaining is disabled.<br>1: Transfer complete chaining is enabled.                                                                                                                                                                                                                                                                                                                                | RW   | -     |
| 21    | ITCINTEN   | Intermediate transfer completion interrupt enable:<br>0: Intermediate transfer complete interrupt is disabled.<br>1: Intermediate transfer complete interrupt is enabled (corresponding IER[TCC] bit must be set to 1 to generate interrupt)                                                                                                                                                                                                                 | RW   | -     |
| 20    | TCINTEN    | Transfer complete interrupt enable:<br>0: Transfer complete interrupt is disabled.<br>1: Transfer complete interrupt is enabled (corresponding IER[TCC] bit must be set to 1 to generate interrupt)                                                                                                                                                                                                                                                          | RW   | -     |
| 19:18 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0x-   |
| 17:12 | TCC        | Transfer Complete Code:<br>The 6-bit code is used to set the relevant bit in CER (bit CER[TCC]) for chaining or in IER (bit IER[TCC]) for interrupts.                                                                                                                                                                                                                                                                                                        | RW   | 0x--  |
| 11    | TCCMODE    | Transfer complete code mode:<br>Indicates the point at which a transfer is considered completed.<br>Applies to both chaining and interrupt.<br>0: Normal Completion, A transfer is considered completed after the transfer parameters are returned to the CC from the TC (which was returned from the peripheral).<br>1: Early Completion, A transfer is considered completed after the CC submits a TR to the TC. CC generates completion code internally . | RW   | -     |
| 10:8  | FWID       | FIFO width:<br>Applies if either SAM or DAM is set to FIFO mode. Pass-thru to TC.                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0x-   |

| Bits | Field Name | Description                                                                                                                                                                                                                                         | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x0: FIFO width is 8-bit<br>0x1: FIFO width is 16-bit<br>0x2: FIFO width is 32-bit<br>0x3: FIFO width is 64-bit<br>0x4: FIFO width is 128-bit<br>0x5: FIFO width is 256-bit                                                                         |      |       |
| 7:4  | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                               | RW   | 0x-   |
| 3    | STATIC     | Static Entry:<br>0: Entry is updated as normal<br>1: Entry is static, Count and Address updates are not updated after TRP is submitted. Linking is not performed.                                                                                   | RW   | -     |
| 2    | SYNCDIM    | Transfer Synchronization Dimension:<br>0: A-Sync, Each event triggers the transfer of ACNT elements.<br>1: AB-Sync, Each event triggers the transfer of BCNT arrays of ACNT elements                                                                | RW   | -     |
| 1    | DAM        | Destination Address Mode:<br>Destination Address Mode within an array. Pass-thru to TC.<br>0: INCR, Dst addressing within an array increments. Dst is not a FIFO.<br>1: FIFO, Dst addressing within an array wraps around upon reaching FIFO width. | RW   | -     |
| 0    | SAM        | Source Address Mode:<br>Source Address Mode within an array. Pass-thru to TC.<br>0: INCR, Src addressing within an array increments. Source is not a FIFO.<br>1: FIFO, Src addressing within an array wraps around upon reaching FIFO width.        | RW   | -     |

**Table 5-387. Register Call Summary for Register TPCC\_OPTm**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[1\]](#)

**Table 5-388. TPCC\_SRCm**

|                         |                         |                 |             |  |
|-------------------------|-------------------------|-----------------|-------------|--|
| <b>Address Offset</b>   | 0x4004 + (0x20*m)       | <b>Instance</b> | IVA2.2 TPCC |  |
| <b>Physical address</b> | 0x01C0 4004 + (0x20*m)4 |                 |             |  |
| <b>Description</b>      | Source Address          |                 |             |  |
| <b>Type</b>             | RW                      |                 |             |  |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 | SRC             |             |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                              | Type | Reset   |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:0 | SRC        | Source Address: The 32-bit source address parameters specify the starting byte address of the source. If SAM is set to FIFO mode then the user should program the Source address to be aligned to the value specified by the OPT.FWID field. No errors are recognized here but TC will assert error if this is not true. | RW   | 0x----- |

**Table 5-389. Register Call Summary for Register TPCC\_SRCm**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-390. TPCC\_ABCNTm**

|                         |                        |                 |             |  |  |
|-------------------------|------------------------|-----------------|-------------|--|--|
| <b>Address Offset</b>   | 0x4008 + (0x20*m)      | <b>Instance</b> | IVA2.2 TPCC |  |  |
| <b>Physical address</b> | 0x01C0 4008 + (0x20*m) |                 |             |  |  |
| <b>Description</b>      | A and B byte count     |                 |             |  |  |
| <b>Type</b>             | RW                     |                 |             |  |  |

  

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| BCNT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ACNT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:16       | BCNT              | BCNT : Count for 2nd Dimension:<br>BCNT is a 16-bit unsigned value that specifies the number of arrays of length ACNT. For normal operation, valid values for BCNT can be anywhere between 1 and 65535. Therefore, the maximum Number of arrays in a frame is 65535 (64K-1 arrays). BCNT=1 means 1 array in the frame, and BCNT=0 means 0 arrays in the frame.<br>In normal mode, a BCNT of 0 is considered as either a Null or Dummy transfer. A Dummy or Null transfer will generate a Completion code depending on the settings of the completion bit fields of the OPT field. | RW          | 0x----       |
| 15:0        | ACNT              | ACNT : number of bytes in 1st dimension:<br>ACNT represents the number of bytes within the first dimension of a transfer. ACNT is a 16-bit unsigned value with valid values between 0 and 65535. Therefore, the maximum number of bytes in an array is 65535 bytes (64K-1 bytes). ACNT must be greater than or equal to 1 for a TR to be submitted to TC. An ACNT of 0 is considered as either a null or dummy transfer. A Dummy or Null transfer will generate a Completion code depending on the settings of the completion bit fields of the OPT field.                        | RW          | 0x----       |

**Table 5-391. Register Call Summary for Register TPCC\_ABCNTm**

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-392. TPCC\_DSTm**

|                         |                        |                 |             |  |  |
|-------------------------|------------------------|-----------------|-------------|--|--|
| <b>Address Offset</b>   | 0x400C + (0x20*m)      | <b>Instance</b> | IVA2.2 TPCC |  |  |
| <b>Physical address</b> | 0x01C0 400C + (0x20*m) |                 |             |  |  |
| <b>Description</b>      | Destination Address    |                 |             |  |  |
| <b>Type</b>             | RW                     |                 |             |  |  |

  

|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| DST |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | DST               | Destination Address:<br>The 32-bit destination address parameters specify the starting byte address of the destination. If DAM is set to FIFO mode then the user should program the Destination address to be aligned to the value specified by the OPTi.FWID field. No errors are recognized here but TC will assert error if this is not true. | RW          | 0x-----      |

**Table 5-393. Register Call Summary for Register TPCC\_DSTm**

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-394. TPCC\_BIDXm**

|                         |                        |                 |             |  |  |
|-------------------------|------------------------|-----------------|-------------|--|--|
| <b>Address Offset</b>   | 0x4010 + (0x20*m)      | <b>Instance</b> | IVA2.2 TPCC |  |  |
| <b>Physical address</b> | 0x01C0 4010 + (0x20*m) |                 |             |  |  |
| <b>Description</b>      |                        |                 |             |  |  |
| <b>Type</b>             | RW                     |                 |             |  |  |

  

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| DBIDX |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SBIDX |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                              | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:16       | DBIDX             | Destination 2nd Dimension Index:<br>DBIDX is a 16-bit signed value (2s complement) used for destination address modification in between each array in the 2nd dimension. It is a signed value between -32768 and 32767. It provides a byte address offset from the beginning of the destination array to the beginning of the next destination array within the current frame. It applies to both A-Sync and AB-Sync transfers. | RW          | 0x---        |
| 15:0        | SBIDX             | Source 2nd Dimension Index:<br>SBIDX is a 16-bit signed value (2s complement) used for source address modification in between each array in the 2nd dimension. It is a signed value between -32768 and 32767. It provides a byte address offset from the beginning of the source array to the beginning of the next source array. It applies to both A-sync and AB-sync transfers.                                              | RW          | 0x---        |

**Table 5-395. Register Call Summary for Register TPCC\_BIDXm**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-396. TPCC\_LNKm**

|                         |                            |                 |             |  |  |
|-------------------------|----------------------------|-----------------|-------------|--|--|
| <b>Address Offset</b>   | 0x4014 + (0x20*m)          | <b>Instance</b> | IVA2.2 TPCC |  |  |
| <b>Physical address</b> | 0x01C0 4014 + (0x20*m)     |                 |             |  |  |
| <b>Description</b>      | Link and Reload parameters |                 |             |  |  |
| <b>Type</b>             | RW                         |                 |             |  |  |

  

|         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| BCNTRLD |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LINK |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:16       | BCNTRLD           | BCNT Reload:<br>BCNTRLD is a 16-bit unsigned value used to reload the BCNT field once the last array in the 2nd dimension is transferred. This field is only used for A-Synced transfers. In this case, the CC decrements the BCNT value by one on each TR submission. When BCNT (conceptually) reaches zero, then the CC decrements CCNT and uses the BCNTRLD value to reinitialize the BCNT value. For AB-synchronized transfers, the CC submits the BCNT in the TR and therefore the TC is responsible to keep track of BCNT, not CC-thus BCNTRLD is a dont care field. | RW          | 0x---        |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Type | Reset  |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 15:0 | LINK       | <p>Link Address:</p> <p>The CC provides a mechanism to reload the current PaRAM Entry upon its natural termination (i.e., after count fields are decremented to 0) with a new PaRAM Entry. This is called linking. The 16-bit parameter LINK specifies the byte address offset in the PaRAM from which the CC loads/reloads the next PaRAM entry in the link. The CC should disregard the value in the upper 2 bits of the LINK field as well as the lower 5-bits of the LINK field. The upper two bits are ignored such that the user can program either the literal byte address of the LINK parameter or the PaRAM base-relative address of the link field. Therefore, if the user uses the literal address with a range from 0x4000 to 0x7FFF, it will be treated as a PaRAM-base-relative value of 0x0000 to 0x3FFF. The lower-5 bits are ignored and treated as b00000, thereby guaranteeing that all Link pointers point to a 32-byte aligned PaRAM entry. In the latter case (5-lsbs), behavior is undefined for the user (i.e., dont have to test it). In the former case (2 msbs), user should be able to take advantage of this feature (i.e., do have to test it). If a Link Update is requested to a PaRAM address that is beyond the actual range of implemented PaRAM, then the Link will be treated as a Null Link and all 0s plus 0xFFFF will be written to the current entry location.</p> <p>A LINK value of 0xFFFF is referred to as a NULL link which should cause the CC to write 0x0 to all entries of the current PaRAM Entry except for the LINK field which is set to 0xFFFF. The Priv/Privid state is overwritten to 0x0 when linking. MSBs and LSBS should not be masked when comparing against the 0xFFFF value. I.e., a value of 0x3FE is a non-NUL PaRAM link field.</p> | RW   | 0x---- |

**Table 5-397. Register Call Summary for Register TPCC\_LNKm**

IVA2.2 Subsystem Register Manual

- TPCC Register Mapping Summary: [0]

**Table 5-398. TPCC\_CIDXm**

|                  |                        |          |             |
|------------------|------------------------|----------|-------------|
| Address Offset   | 0x4018 + (0x20*m)      | Instance | IVA2.2 TPCC |
| Physical address | 0x01C0 4018 + (0x20*m) |          |             |
| Description      |                        |          |             |
| Type             | RW                     |          |             |

  

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| DCIDX |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SCIDX |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | DCIDX      | <p>Destination Frame Index:</p> <p>DCIDX is a 16-bit signed value (2s complement) used for destination address modification for the 3rd dimension. It is a signed value between -32768 and 32767. It provides a byte address offset from the beginning of the current array (pointed to by DST address) to the beginning of the first destination array in the next frame. It applies to both A-sync and AB-sync transfers. Note that when DCIDX is applied, the current array in anA-sync transfer is the last array in the frame, while the current array in a ABsync transfer is the first array in the frame.</p> | RW   | 0x---- |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15:0 | SCIDX      | Source Frame Index:<br>SCIDX is a 16-bit signed value (2s complement) used for source address modification for the 3rd dimension. It is a signed value between -32768 and 32767. It provides a byte address offset from the beginning of the current array (pointed to by SRC address) to the beginning of the first source array in the next frame. It applies to both A-sync and AB-sync transfers. Note that when SCIDX is applied, the current array in an A-sync transfer is the last array in the frame, while the current array in a AB-sync transfer is the first array in the frame. | RW   | 0x--- |

**Table 5-399. Register Call Summary for Register TPCC\_CIDXm**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

**Table 5-400. TPCC\_CCNTm**

|                         |                        |                 |             |  |
|-------------------------|------------------------|-----------------|-------------|--|
| <b>Address Offset</b>   | 0x401C + (0x20*m)      | <b>Instance</b> | IVA2.2 TPCC |  |
| <b>Physical address</b> | 0x01C0 401C + (0x20*m) |                 |             |  |
| <b>Description</b>      | C byte count           |                 |             |  |
| <b>Type</b>             | RW                     |                 |             |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CCNT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0x0000 |
| 15:0  | CCNT       | CCNT Count for 3rd Dimension:<br>CCNT is a 16-bit unsigned value that specifies the number of frames in a block. Valid values for CCNT can be anywhere between 1 and 65535. Therefore, the maximum number of frames in a block is 65535 (64K-1 frames). CCNT of 1 means 1 frame in the block, and CCNT of 0 means 0 frames in the block. A CCNT value of 0 is considered as either a null or dummy transfer. A Dummy or Null transfer will generate a Completion code depending on the settings of the completion bit fields of the OPTi field. | RW   | 0x---  |

**Table 5-401. Register Call Summary for Register TPCC\_CCNTm**

IVA2.2 Subsystem Register Manual

- [TPCC Register Mapping Summary: \[0\]](#)

### 5.5.6 TPTC0 and TPTC1 Registers

This section provides information about the TPTC0 and TPTC1 Modules. Each register in the Modules is described separately below.

#### 5.5.6.1 TPTC0 and TPTC1 Register Mapping Summary

**Table 5-402. TPTC0 and TPTC1 Register Summary**

| Register Name (j = 0 or 1) | Type | RegisterWidth (Bits) | Address Offset | TPTC0 Physical Address | TPTC1 Physical Address |
|----------------------------|------|----------------------|----------------|------------------------|------------------------|
| TPTCj_PID                  | R    | 32                   | 0x000          | 0x01C1 0000            | 0x01C1 0400            |
| TPTCj_TCCFG                | R    | 32                   | 0x004          | 0x01C1 0004            | 0x01C1 0404            |
| TPTCj_TCSTAT               | R    | 32                   | 0x100          | 0x01C1 0100            | 0x01C1 0500            |

**Table 5-402. TPTC0 and TPTC1 Register Summary (continued)**

| Register Name (j = 0 or 1)                 | Type | RegisterWidth (Bits) | Address Offset   | TPTC0 Physical Address | TPTC1 Physical Address |
|--------------------------------------------|------|----------------------|------------------|------------------------|------------------------|
| TPTCj_INTSTAT                              | R    | 32                   | 0x104            | 0x01C1 0104            | 0x01C1 0504            |
| TPTCj_INTEN                                | RW   | 32                   | 0x108            | 0x01C1 0108            | 0x01C1 0508            |
| TPTCj_INTCLR                               | W    | 32                   | 0x10C            | 0x01C1 010C            | 0x01C1 050C            |
| TPTCj_INTCMD                               | W    | 32                   | 0x110            | 0x01C1 0110            | 0x01C1 0510            |
| TPTCj_ERRSTAT                              | R    | 32                   | 0x120            | 0x01C1 0120            | 0x01C1 0520            |
| TPTCj_ERRREN                               | RW   | 32                   | 0x124            | 0x01C1 0124            | 0x01C1 0524            |
| TPTCj_ERRCLR                               | W    | 32                   | 0x128            | 0x01C1 0128            | 0x01C1 0528            |
| TPTCj_ERRDET                               | R    | 32                   | 0x12C            | 0x01C1 012C            | 0x01C1 052C            |
| TPTCj_ERRCMD                               | W    | 32                   | 0x130            | 0x01C1 0130            | 0x01C1 0530            |
| TPTCj_RDRATE                               | RW   | 32                   | 0x140            | 0x01C1 0140            | 0x01C1 0540            |
| TPTCj_POPT                                 | RW   | 32                   | 0x200            | 0x01C1 0200            | 0x01C1 0600            |
| TPTCj_PSRC                                 | RW   | 32                   | 0x204            | 0x01C1 0204            | 0x01C1 0604            |
| TPTCj_PCNT                                 | RW   | 32                   | 0x208            | 0x01C1 0208            | 0x01C1 0608            |
| TPTCj_PDST                                 | RW   | 32                   | 0x20C            | 0x01C1 020C            | 0x01C1 060C            |
| TPTCj_PBIDX                                | RW   | 32                   | 0x210            | 0x01C1 0210            | 0x01C1 0610            |
| TPTCj_PMPPRXY                              | R    | 32                   | 0x214            | 0x01C1 0214            | 0x01C1 0614            |
| TPTCj_SAOPT                                | R    | 32                   | 0x240            | 0x01C1 0240            | 0x01C1 0640            |
| TPTCj_SASRC                                | R    | 32                   | 0x244            | 0x01C1 0244            | 0x01C1 0644            |
| TPTCj_SACNT                                | R    | 32                   | 0x248            | 0x01C1 0248            | 0x01C1 0648            |
| TPTCj_SADST                                | R    | 32                   | 0x24C            | 0x01C1 024C            | 0x01C1 064C            |
| TPTCj_SABIDX                               | R    | 32                   | 0x250            | 0x01C1 0250            | 0x01C1 0650            |
| TPTCj_SAMPPRXY                             | R    | 32                   | 0x254            | 0x01C1 0254            | 0x01C1 0654            |
| TPTCj_SACNTRLD                             | R    | 32                   | 0x258            | 0x01C1 0258            | 0x01C1 0658            |
| TPTCj_SASRCBREF                            | R    | 32                   | 0x25C            | 0x01C1 025C            | 0x01C1 065C            |
| TPTCj_SADSTBREF                            | R    | 32                   | 0x260            | 0x01C1 0260            | 0x01C1 0660            |
| TPTCj_DFCNTRLD                             | R    | 32                   | 0x280            | 0x01C1 0280            | 0x01C1 0680            |
| TPTCj_DFSRCBREF                            | R    | 32                   | 0x284            | 0x01C1 0284            | 0x01C1 0684            |
| TPTCj_DFDSTBREF                            | R    | 32                   | 0x288            | 0x01C1 0288            | 0x01C1 0688            |
| TPTCj_DFOPTi <sup>(1)</sup>                | R    | 32                   | 0x300 + (0x40*i) | 0x01C1 0300 + (0x40*i) | 0x01C1 0700 + (0x40*i) |
| TPTCj_DFSRCi <sup>(1)</sup>                | R    | 32                   | 0x304 + (0x40*i) | 0x01C1 0304 + (0x40*i) | 0x01C1 0704 + (0x40*i) |
| TPTCj_DFCNTi <sup>(1)</sup>                | R    | 32                   | 0x308 + (0x40*i) | 0x01C1 0308 + (0x40*i) | 0x01C1 0708 + (0x40*i) |
| TPTCj_DFDSTi <sup>(1)</sup>                | R    | 32                   | 0x30C + (0x40*i) | 0x01C1 030C + (0x40*i) | 0x01C1 070C + (0x40*i) |
| TPTCj_DFBIDX <sub>i</sub> <sup>(1)</sup>   | R    | 32                   | 0x310 + (0x40*i) | 0x01C1 0310 + (0x40*i) | 0x01C1 0710 + (0x40*i) |
| TPTCj_DFMPPRXY <sub>i</sub> <sup>(1)</sup> | R    | 32                   | 0x314 + (0x40*i) | 0x01C1 0314 + (0x40*i) | 0x01C1 0714 + (0x40*i) |

<sup>(1)</sup> i = 0 to 3 for TPTC0  
          i = 0 to 1 for TPTC1

### 5.5.6.2 TPTC0 and TPTC1 Register Descriptions

**Table 5-403. TPTCj\_PID**

|                         |                        |                         |             |                 |              |
|-------------------------|------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x000                  | <b>Physical address</b> | 0x01C1 0000 | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0400            | <b>Instance</b>         |             | IVA2.2 TPTC1    |              |
| <b>Description</b>      | Peripheral ID Register |                         |             |                 |              |
| <b>Type</b>             | R                      |                         |             |                 |              |

| 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 |  |  |  |
|--------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------|---|---|---|---|---|---|--|--|--|
| SCHEME | RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CUSTOM |   |   |   |   |   |   |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                        | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | SCHEME     | PID scheme:<br><br>Used to distinguish between old ID scheme and current.<br>Spare bit to encode future schemes EDMA uses new scheme, indicated with value of 0x1. | RW   | 0x1   |
| 29:28 | Reserved   | Read returns 0.                                                                                                                                                    | R    | 0x0   |
| 27:16 | FUNC       | Function indicates a software-compatible module family.                                                                                                            | RW   | 0x000 |
| 15:11 | RTL        | RTL version                                                                                                                                                        | RW   | 0x--  |
| 10:8  | MAJOR      | Major revision                                                                                                                                                     | RW   | 0x3   |
| 7:6   | CUSTOM     | Custom revision field: Not used on this version of EDMA.                                                                                                           | RW   | 0x0   |
| 5:0   | MINOR      | Minor revision                                                                                                                                                     | RW   | 0x--  |

**Table 5-404. Register Call Summary for Register TPTCj\_PID**

Iva2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[0\]](#)

**Table 5-405. TPTCj\_TCCFG**

|                         |                           |                         |             |                 |              |
|-------------------------|---------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x004                     | <b>Physical address</b> | 0x01C1 0004 | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0404               | <b>Instance</b>         |             | IVA2.2 TPTC1    |              |
| <b>Description</b>      | TC Configuration Register |                         |             |                 |              |
| <b>Type</b>             | R                         |                         |             |                 |              |

| 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 |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----------|----------|----------|----------|----------|---|---|---|--|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DREGDEPTH | Reserved | BUSWIDTH | Reserved | FIFOSIZE |   |   |   |  |

| Bits  | Field Name | Description                                                       | Type | Reset              |
|-------|------------|-------------------------------------------------------------------|------|--------------------|
| 31:10 | Reserved   | Read returns 0.                                                   | R    | 0x000000           |
| 9:8   | DREGDEPTH  | Dst Register FIFO Depth Parameterization<br><br>Read 0x0: 1 entry | R    | 0x- <sup>(1)</sup> |

<sup>(1)</sup> Depends on the hardware parameters of TPTC0 and TPTC1.

| Bits | Field Name | Description                                                                                                                                                     | Type | Reset                 |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------|
|      |            | Read 0x1: 2 entries<br>Read 0x2: 4 entries                                                                                                                      |      |                       |
| 7:6  | Reserved   | Read returns 0.                                                                                                                                                 | R    | 0x0                   |
| 5:4  | BUSWIDTH   | Bus Width Parameterization<br>Read 0x0: 32-bit<br>Read 0x1: 64-bit<br>Read 0x2: 128-bit                                                                         | R    | 0x1                   |
| 3    | Reserved   | Read returns 0.                                                                                                                                                 | R    | 0                     |
| 2:0  | FIFOSIZE   | Fifo Size Parameterization<br>Read 0x0: 32 byte FIFO<br>Read 0x1: 64 byte FIFO<br>Read 0x2: 128 byte FIFO<br>Read 0x3: 256 byte FIFO<br>Read 0x4: 512 byte FIFO | R    | 0x-( <sup>(1)</sup> ) |

**Table 5-406. Register Call Summary for Register TPTCj\_TCCFG**

---

IVA2.2 Subsystem Register Manual

- TPTC0 and TPTC1 Register Mapping Summary: [0]

**Table 5-407. TPTCj\_TCSTAT**

|                         |                    |                 |              |
|-------------------------|--------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x100              |                 |              |
| <b>Physical address</b> | 0x01C1 0100        | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0500        | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | TC Status Register |                 |              |
| <b>Type</b>             | R                  |                 |              |



| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                            | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:14       | Reserved          | Read returns 0.                                                                                                                                                                                                                                                                               | R           | 0x00000      |
| 13:12       | DFSTRTPTR         | Dst FIFO Start Pointer<br>Represents the offset to the head entry of Dst Register FIFO, in units of *entries*. Legal values = 0x0 to 0x3                                                                                                                                                      | R           | 0x0          |
| 11:9        | Reserved          | Read returns 0.                                                                                                                                                                                                                                                                               | R           | 0x0          |
| 8           | ACTV              | Channel Active<br>Channel Active is a logical-OR of each of the *BUSY/ACTV signals.<br>The ACTV bit must remain high through the life of a TR.<br>ACTV = 0: Channel is idle.<br>ACTV = 1: Channel is busy.                                                                                    | R           | 1            |
| 7           | Reserved          | Read returns 0.                                                                                                                                                                                                                                                                               | R           | 0            |
| 6:4         | DSTACTV           | Destination Active State<br>Specifies the number of TRs that are resident in the Dst Register FIFO at a given instant. Legal values are constrained by the DSTREGDEPTH parameter.<br><br>Read 0x0: FIFO set is empty.<br>Read 0x1: Dst FIFO contains 1 TR<br>Read 0x2: Dst FIFO contains 2 TR | R           | 0x0          |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                      | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | Read 0x3: Dst FIFO contains 3 TR<br>Read 0x4: Dst FIFO contains 4 TR                                                                                                                                                                                                                                                                             |      |       |
| 3    | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                  | R    | 0     |
| 2    | WSACTV     | Write Status Active<br>WSACTV = 0: Write status is not pending. Write status has been received for all previously issued write commands.<br>WSACTV = 1: Write Status is pending. Write status has not been received for all previously issued write commands.                                                                                    | R    | 0     |
| 1    | SRCACTV    | Source Active State<br>SRCACTV = 0: Source Active set is idle. Any TR written to Prog Set will immediately transition to Source Active set as long as the Dst FIFO Set is not full (DSTFULL == 1).<br>SRCACTV = 1: Source Active set is busy either performing read transfers or waiting to perform read transfers for current Transfer Request. | R    | 0     |
| 0    | PROGBUSY   | Program Register Set Busy<br>PROGBUSY = 0: Prog set idle and is available for programming.<br>PROGBUSY = 1: Prog set busy. User should poll for PROGBUSY equal to 0 prior to re-programming the Program Register set.                                                                                                                            | R    | 0     |

**Table 5-408. Register Call Summary for Register TPTCj\_TCSTAT**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-409. TPTCj\_INTSTAT**

|                         |                           |                       |                     |
|-------------------------|---------------------------|-----------------------|---------------------|
| <b>Address Offset</b>   | 0x104                     |                       |                     |
| <b>Physical address</b> | 0x01C1 0104               | <b>Instance</b>       | IVA2.2 TPTC0        |
| <b>Physical address</b> | 0x01C1 0504               | <b>Instance</b>       | IVA2.2 TPTC1        |
| <b>Description</b>      | Interrupt Status Register |                       |                     |
| <b>Type</b>             | R                         |                       |                     |
| 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     |
|                         |                           |                       |                     |
|                         |                           | Reserved              |                     |
|                         |                           |                       | TRDONE<br>PROGEMPTY |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                            | R    | 0x00000000 |
| 1    | TRDONE     | TR Done Event Status:<br>TRDONE = 0: Condition not detected.<br>TRDONE = 1: Set when TC has completed a Transfer Request.<br>TRDONE should be set when the write status is returned for the final write of a TR. Cleared when user writes 1 to INTCLR.TRDONE register bit. | R    | 0          |
| 0    | PROGEMPTY  | Program Set Empty Event Status:<br>PROGEMPTY = 0: Condition not detected.<br>PROGEMPTY = 1: Set when Program Register set transitions to empty state. Cleared when user writes 1 to INTCLR.PROGEMPTY register bit.                                                         | R    | 0          |

**Table 5-410. Register Call Summary for Register TPTCj\_INTSTAT**

---

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#) [\[1\]](#) [\[2\]](#)

---

IVA2.2 Subsystem Basic Programming Model

- [Error Reporting for EDMA Module: \[3\]](#)

---

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[4\]](#)

**Table 5-411. TPTCj\_INTEN**

|                         |                           |                 |              |
|-------------------------|---------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x108                     |                 |              |
| <b>Physical address</b> | 0x01C1 0108               | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0508               | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | Interrupt Enable Register |                 |              |
| <b>Type</b>             | RW                        |                 |              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |        |           |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|--------|-----------|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | TRDONE | PROGEMPTY |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:2        | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                            | RW          | 0x00000000   |
| 1           | TRDONE            | TR Done Event Enable:<br>INTEN.TRDONE = 0: TRDONE Event is disabled.<br>INTEN.TRDONE = 1: TRDONE Event is enabled, and contributes to interrupt generation                       | RW          | 0            |
| 0           | PROGEMPTY         | Program Set Empty Event Enable:<br>INTEN.PROGEMPTY = 0: PROGEMPTY Event is disabled.<br>INTEN.PROGEMPTY = 1: PROGEMPTY Event is enabled, and contributes to interrupt generation | RW          | 0            |

**Table 5-412. Register Call Summary for Register TPTCj\_INTEN**

- [EDMA: \[0\]](#)

---

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-413. TPTCj\_INTCLR**

|                         |                          |                 |              |
|-------------------------|--------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x10C                    |                 |              |
| <b>Physical address</b> | 0x01C1 010C              | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 050C              | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | Interrupt Clear Register |                 |              |
| <b>Type</b>             | W                        |                 |              |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---------------------|---|---|
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | TRDONE<br>PROGEMPTY |   |   |

| Bits | Field Name | Description                                                                                                                                          | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | Reserved   | Write 0s for future compatibility.                                                                                                                   | W    | 0x00000000 |
| 1    | TRDONE     | TR Done Event Clear:<br>INTCLR.TRDONE = 0: Writes of 0 have no effect.<br>INTCLR.TRDONE = 1: Write of 1 clears INTSTAT.TRDONE bit                    | W    | 0          |
| 0    | PROGEMPTY  | Program Set Empty Event Clear:<br>INTCLR.PROGEMPTY = 0: Writes of 0 have no effect.<br>INTCLR.PROGEMPTY = 1: Write of 1 clears INTSTAT.PROGEMPTY bit | W    | 0          |

**Table 5-414. Register Call Summary for Register TPTCj\_INTCLR**

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[0\]](#)

**Table 5-415. TPTCj\_INTCMD**

|                         |                            |                         |             |                 |              |
|-------------------------|----------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x110                      | <b>Physical address</b> | 0x01C1 0110 | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0510                | <b>Instance</b>         |             |                 | IVA2.2 TPTC1 |
| <b>Description</b>      | Interrupt Command Register |                         |             |                 |              |
| <b>Type</b>             | W                          |                         |             |                 |              |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-------------|---|---|---|
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | SET<br>EVAL |   |   |   |

| Bits | Field Name | Description                                                                                                                                                       | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | Reserved   | Write 0s for future compatibility.                                                                                                                                | W    | 0x00000000 |
| 1    | SET        | Set TPTC interrupt:<br>Write of 1 to SET causes TPTC interrupt to be pulsed unconditionally.<br>Writes of 0 have no effect.                                       | W    | 0          |
| 0    | EVAL       | Evaluate state of TPTC interrupt<br>Write of 1 to EVAL causes TPTC interrupt to be pulsed if any of the INTSTAT bits are set to 1.<br>Writes of 0 have no effect. | W    | 0          |

**Table 5-416. Register Call Summary for Register TPTCj\_INTCMD**

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[0\]](#)

**Table 5-417. TPTCj\_ERRSTAT**

|                         |                         |                         |                 |                 |              |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x120                   | <b>Physical address</b> | 0x01C1 0120     | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0520             | <b>Instance</b>         |                 | IVA2.2 TPTC1    |              |
| <b>Description</b>      | Error Status Register   |                         |                 |                 |              |
| <b>Type</b>             | R                       |                         |                 |                 |              |
| 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 | MMRAERR         | TRERR        |
| Reserved                |                         |                         |                 |                 | Reserved     |
|                         |                         |                         |                 |                 | BUSERR       |

  

| Bits | Field Name | Description                                                                                                                                                                                                                                       | Type | Reset     |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:4 | Reserved   | Read returns 0.                                                                                                                                                                                                                                   | R    | 0x0000000 |
| 3    | MMRAERR    | MMR Address Error:<br>MMRAERR = 0: Condition not detected.<br>MMRAERR = 1: User attempted to read or write to invalid address configuration memory map. (Is only be set for non-emulation accesses). No additional error information is recorded. | R    | 0         |
| 2    | TRERR      | TR Error:<br>TR detected that violates FIFO Mode transfer (SAM or DAM is 1) alignment rules or has ACNT or BCNT == 0. No additional error information is recorded.                                                                                | R    | 0         |
| 1    | Reserved   | Read returns 0.                                                                                                                                                                                                                                   | R    | 0         |
| 0    | BUSERR     | Bus Error Event:<br>BUSERR = 0: Condition not detected.<br>BUSERR = 1: TC has detected an error code on the write response bus or read response bus. Error information is stored in Error Details Register (ERREDET).                             | R    | 0         |

**Table 5-418. Register Call Summary for Register TPTCj\_ERRSTAT**

- IVA2.2 Subsystem Basic Programming Model
- [Error Reporting for EDMA Module: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\]](#)
- IVA2.2 Subsystem Register Manual
- [TPTC0 and TPTC1 Register Mapping Summary: \[6\]](#)

**Table 5-419. TPTCj\_ERREN**

|                         |                         |                         |                 |                 |              |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x124                   | <b>Physical address</b> | 0x01C1 0124     | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0524             | <b>Instance</b>         |                 | IVA2.2 TPTC1    |              |
| <b>Description</b>      | Error Enable Register   |                         |                 |                 |              |
| <b>Type</b>             | RW                      |                         |                 |                 |              |
| 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 | MMRAERR         | TRERR        |
| Reserved                |                         |                         |                 |                 | Reserved     |
|                         |                         |                         |                 |                 | BUSERR       |

| Bits | Field Name | Description                                                                                                                                                                       | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:4 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                             | RW   | 0x00000000 |
| 3    | MMRAERR    | Interrupt enable for ERRSTAT.MMRAERR:<br>ERREN.MMRAERR = 0: BUSERR is disabled.<br>ERREN.MMRAERR = 1: MMRAERR is enabled, and contributes to the TPTC error interrupt generation. | RW   | 0          |
| 2    | TRERR      | Interrupt enable for ERRSTAT.TRERR:<br>ERREN.TRERR = 0: BUSERR is disabled.<br>ERREN.TRERR = 1: TRERR is enabled, and contributes to the TPTC error interrupt generation.         | RW   | 0          |
| 1    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                             | RW   | 0          |
| 0    | BUSERR     | Interrupt enable for ERRSTAT.BUSERR:<br>ERREN.BUSERR = 0: BUSERR is disabled.<br>ERREN.BUSERR = 1: BUSERR is enabled, and contributes to the TPTC error interrupt generation.     | RW   | 0          |

**Table 5-420. Register Call Summary for Register TPTCj\_ERREN**

IVA2.2 Subsystem Basic Programming Model

- [Error Reporting for EDMA Module: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-421. TPTCj\_ERRCLR**

|                         |                      |                         |             |                 |              |
|-------------------------|----------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x128                | <b>Physical address</b> | 0x01C1 0128 | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0528          | <b>Physical address</b> | 0x01C1 0528 | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | Error Clear Register |                         |             |                 |              |
| <b>Type</b>             | W                    |                         |             |                 |              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                              | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:4 | Reserved   | Write 0s for future compatibility.                                                                                                                                                                                       | W    | 0x00000000 |
| 3    | MMRAERR    | Interrupt clear for ERRSTAT.MMRAERR:<br>ERRCLR.MMRAERR = 0: Writes of 0 have no effect.<br>ERRCLR.MMRAERR = 1: Write of 1 clearsERRSTAT.MMRAERR bit.<br>Write of 1 to ERRCLR.MMRAERR does not clear the ERRDET register. | W    | 0          |
| 2    | TRERR      | Interrupt clear for ERRSTAT.TRERR:<br>ERRCLR.TRERR = 0: Writes of 0 have no effect.<br>ERRCLR.TRERR = 1: Write of 1 clears ERRSTAT.TRERR bit.<br>Write of 1 to ERRCLR.TRERR does not clear the ERRDET register.          | W    | 0          |
| 1    | Reserved   | Write 0s for future compatibility.                                                                                                                                                                                       | W    | 0          |
| 0    | BUSERR     | Interrupt clear for ERRSTAT.BUSERR:<br>ERRCLR.BUSERR = 0: Writes of 0 have no effect.<br>ERRCLR.BUSERR = 1: Write of 1 clearsERRSTAT.BUSERR bit.<br>Write of 1 to ERRCLR.BUSERR clears the ERRDET register.              | W    | 0          |

**Table 5-422. Register Call Summary for Register TPTCj\_ERRCLR**

IVA2.2 Subsystem Basic Programming Model

- [Error Reporting for EDMA Module: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-423. TPTCj\_ERRDET**

|                         |                        |                 |              |
|-------------------------|------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x12C                  | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 012C            | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | Error Details Register |                 |              |
| <b>Type</b>             | R                      |                 |              |

| 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 |
|----------|----|----|----|----|----|----|----|--------|---------|----------|----|-----|----|----|----|----------|----|----|------|----|----|---|---|---|---|---|---|---|---|---|---|
| Reserved |    |    |    |    |    |    |    | TCCHEN | TCINTEN | Reserved |    | TCC |    |    |    | Reserved |    |    | STAT |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:18 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x0000 |
| 17    | TCCHEN     | Contains the OPT.TCCHEN value programmed by the user for the Read or Write transaction that resulted in an error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R    | 0      |
| 16    | TCINTEN    | Contains the OPT.TCINTEN value programmed by the user for the Read or Write transaction that resulted in an error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R    | 0      |
| 15:14 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x0    |
| 13:8  | TCC        | Transfer Complete Code:<br>Contains the OPT.TCC value programmed by the user for the Read or Write transaction that resulted in an error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R    | 0x00   |
| 7:4   | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x0    |
| 3:0   | STAT       | Transaction Status:<br>Stores the non-zero status/error code that was detected on the read status or write status bus. MS-bit effectively serves as the read vs. write error code. If read status and write status are returned on the same cycle, then the TC chooses non-zero version. If both are non-zero then write status is treated as higher priority.<br>Encoding of errors matches the CBA spec and is summarized here:<br>0xF =<br>Read 0x0: No Error (should not cause error to be latched)<br>Read 0x1: Read Addressing error<br>Read 0x2: Read Privilege error<br>Read 0x3: Read Timeout error<br>Read 0x4: Read Data error<br>Read 0x7: Read Exclusive-operation failure<br>Read 0x8: No Error (should not cause error to be latched)<br>Read 0x9: Write Addressing error<br>Read 0xA: Write Privilege error<br>Read 0xB: Write Timeout error<br>Read 0xC: Write Data error<br>Read 0xF: Write Exclusive-operation failure | R    | 0x0    |

**Table 5-424. Register Call Summary for Register TPTCj\_ERRDET**


---

 IVA2.2 Subsystem Basic Programming Model
 

- [Error Reporting for EDMA Module: \[0\] \[1\] \[2\] \[3\] \[4\]](#)

---

 IVA2.2 Subsystem Register Manual
 

- [TPTC0 and TPTC1 Register Mapping Summary: \[5\]](#)

---

**Table 5-425. TPTCj\_ERRCMD**

|                         |                        |                         |             |                 |              |
|-------------------------|------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x130                  | <b>Physical address</b> | 0x01C1 0130 | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0530            | <b>Instance</b>         |             |                 | IVA2.2 TPTC1 |
| <b>Description</b>      | Error Command Register |                         |             |                 |              |
| <b>Type</b>             | W                      |                         |             |                 |              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |      |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|------|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | SET | EVAL |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                            | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:2        | Reserved          | Write 0s for future compatibility.                                                                                                                                            | W           | 0x00000000   |
| 1           | SET               | Set TPTC error interrupt:<br>Write of 1 to SET causes TPTC error interrupt to be pulsed unconditionally.<br>Writes of 0 have no effect.                                       | W           | 0            |
| 0           | EVAL              | Evaluate state of TPTC error interrupt<br>Write of 1 to EVAL causes TPTC error interrupt to be pulsed if any of the ERRSTAT bits are set to 1.<br>Writes of 0 have no effect. | W           | 0            |

**Table 5-426. Register Call Summary for Register TPTCj\_ERRCMD**


---

 IVA2.2 Subsystem Register Manual
 

- [TPTC0 and TPTC1 Register Mapping Summary: \[0\]](#)

---

**Table 5-427. TPTCj\_RDRATE**

|                         |                    |                         |             |                 |              |
|-------------------------|--------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x140              | <b>Physical address</b> | 0x01C1 0140 | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0540        | <b>Instance</b>         |             |                 | IVA2.2 TPTC1 |
| <b>Description</b>      | Read Rate Register |                         |             |                 |              |
| <b>Type</b>             | RW                 |                         |             |                 |              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |        |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|--------|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RDRATE |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:3        | Reserved          | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                | RW          | 0x00000000   |
| 2:0         | RDRATE            | Read Rate Control:<br>Controls the number of cycles between read commands. This is a global setting that applies to all TRs for this TC.<br><br>0x0: Reads issued as fast as possible.<br>0x1: 4 cycles between reads<br>0x2: 8 cycles between reads | RW          | 0x0          |

| Bits | Field Name | Description             | Type | Reset |
|------|------------|-------------------------|------|-------|
| 0x3: |            | 16 cycles between reads |      |       |
| 0x4: |            | 32 cycles between reads |      |       |

**Table 5-428. Register Call Summary for Register TPTCj\_RDRATE**

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[0\]](#)

**Table 5-429. TPTCj\_POPT**

|                         |                  |                         |             |                 |              |
|-------------------------|------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x200            | <b>Physical address</b> | 0x01C1 0200 | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0600      |                         |             | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | Prog Set Options |                         |             |                 |              |
| <b>Type</b>             | RW               |                         |             |                 |              |

|          |    |    |    |    |    |    |    |        |          |         |          |     |    |    |    |    |          |      |    |          |     |   |          |     |   |     |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|--------|----------|---------|----------|-----|----|----|----|----|----------|------|----|----------|-----|---|----------|-----|---|-----|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    | TCCHEN | Reserved | TCINTEN | Reserved | TCC |    |    |    |    | Reserved | FWID |    | Reserved | PRI |   | Reserved | DAM |   | SAM |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                 | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:23 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                       | RW   | 0x000 |
| 22    | TCCHEN     | Transfer complete chaining enable:<br>0: Transfer complete chaining is disabled.<br>1: Transfer complete chaining is enabled.                                                                                                                               | RW   | 0     |
| 21    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                       | RW   | 0     |
| 20    | TCINTEN    | Transfer complete interrupt enable:<br>0: Transfer complete interrupt is disabled.<br>1: Transfer complete interrupt is enabled.                                                                                                                            | RW   | 0     |
| 19:18 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                       | RW   | 0x0   |
| 17:12 | TCC        | Transfer Complete Code:<br>The 6-bit code is used to set the relevant bit in CER or IPR of the TPCC module.                                                                                                                                                 | RW   | 0x00  |
| 11    | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                       | RW   | 0     |
| 10:8  | FWID       | FIFO width control:<br>Applies if either SAM or DAM is set to FIFO mode.<br><br>0x0: FIFO width is 8-bit<br>0x1: FIFO width is 16-bit<br>0x2: FIFO width is 32-bit<br>0x3: FIFO width is 64-bit<br>0x4: FIFO width is 128-bit<br>0x5: FIFO width is 256-bit | RW   | 0x0   |
| 7     | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                       | RW   | 0     |
| 6:4   | PRI        | Transfer Priority:<br>0: Priority 0 - Highest priority<br>1: Priority 1<br>...<br>7: Priority 7 - Lowest priority<br><br>0x0: Priority 0 - Highest priority                                                                                                 | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                                                                        | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x1: Priority 1<br>0x2: Priority 2<br>0x3: Priority 3<br>0x4: Priority 4<br>0x5: Priority 5<br>0x6: Priority 6<br>0x7: Priority 7 - Lowest Priority                                |      |       |
| 3:2  | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                              | RW   | 0x0   |
| 1    | DAM        | Destination Address Mode within an array:<br>0: INCR, Dst addressing within an array increments.<br>1: FIFO, Dst addressing within an array wraps around upon reaching FIFO width. | RW   | 0     |
| 0    | SAM        | Source Address Mode within an array:<br>0: INCR, Src addressing within an array increments.<br>1: FIFO, Src addressing within an array wraps around upon reaching FIFO width.      | RW   | 0     |

**Table 5-430. Register Call Summary for Register TPTCj\_POPT**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-431. TPTCj\_PSRC**

|                         |                         |                       |                 |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|
| <b>Address Offset</b>   | 0x204                   |                       |                 |  |
| <b>Physical address</b> | 0x01C1 0204             | <b>Instance</b>       | IVA2.2 TPTC0    |  |
| <b>Physical address</b> | 0x01C1 0604             | <b>Instance</b>       | IVA2.2 TPTC1    |  |
| <b>Description</b>      | Prog Set Src Address    |                       |                 |  |
| <b>Type</b>             | RW                      |                       |                 |  |
| 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 |  |
|                         |                         | SADDR                 |                 |  |

| Bits | Field Name | Description                             | Type | Reset      |
|------|------------|-----------------------------------------|------|------------|
| 31:0 | SADDR      | Source address for Program Register Set | RW   | 0x00000000 |

**Table 5-432. Register Call Summary for Register TPTCj\_PSRC**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-433. TPTCj\_PCNT**

|                         |                |                 |              |
|-------------------------|----------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x208          |                 |              |
| <b>Physical address</b> | 0x01C1 0208    | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0608    | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | Prog Set Count |                 |              |
| <b>Type</b>             | RW             |                 |              |

  

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| BCNT                    |                         |                       |                 |
| ACNT                    |                         |                       |                 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                         | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------|-------------|--------------|
| 31:16       | BCNT              | B-Dimension count. Number of arrays to be transferred, where each array is ACNT in length. | RW          | 0x0000       |
| 15:0        | ACNT              | A-Dimension count. Number of bytes to be transferred in first dimension.                   | RW          | 0x0000       |

**Table 5-434. Register Call Summary for Register TPTCj\_PCNT**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-435. TPTCj\_PDST**

|                         |                      |                 |              |
|-------------------------|----------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x20C                |                 |              |
| <b>Physical address</b> | 0x01C1 020C          | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 060C          | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | Prog Set Dst Address |                 |              |
| <b>Type</b>             | RW                   |                 |              |

  

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| DADDR                   |                         |                       |                 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                           | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------|-------------|--------------|
| 31:0        | DADDR             | Destination address for Program Register Set | RW          | 0x00000000   |

**Table 5-436. Register Call Summary for Register TPTCj\_PDST**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-437. TPTCj\_PBIDX**

|                         |                    |                 |               |
|-------------------------|--------------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x210              |                 |               |
| <b>Physical address</b> | 0x01C1 0210        | <b>Instance</b> | IV A2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0610        | <b>Instance</b> | IV A2.2 TPTC1 |
| <b>Description</b>      | Prog Set B-Dim Idx |                 |               |
| <b>Type</b>             | RW                 |                 |               |

  

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| DBIDX                   |                         |                       |                 |
| SBIDX                   |                         |                       |                 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                         | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:16       | DBIDX             | Dest B-Idx for Program Register Set:<br>B-Idx offset between Destination arrays:<br>Represents the offset in bytes between the starting address of each destination array (recall that there are BCNT arrays of ACNT elements). DBIDX is always used, regardless of whether DAM is Increment or FIFO mode. | RW          | 0x0000       |
| 15:0        | SBIDX             | Source B-Idx for Program Register Set:<br>B-Idx offset between Source arrays:<br>Represents the offset in bytes between the starting address of each source array (recall that there are BCNT arrays of ACNT elements). SBIDX is always used, regardless of whether SAM is Increment or FIFO mode.         | RW          | 0x0000       |

**Table 5-438. Register Call Summary for Register TPTCj\_PBIDX**

IV A2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IV A2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-439. TPTCj\_PMPRX**

|                         |                            |                 |               |
|-------------------------|----------------------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x214                      |                 |               |
| <b>Physical address</b> | 0x01C1 0214                | <b>Instance</b> | IV A2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0614                | <b>Instance</b> | IV A2.2 TPTC1 |
| <b>Description</b>      | Prog Set Mem Protect Proxy |                 |               |
| <b>Type</b>             | R                          |                 |               |

  

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                |                         |                       |                 |
| PRIV Reserved PRVID     |                         |                       |                 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:9        | Reserved          | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R           | 0x000000     |
| 8           | PRIV              | Privilege Level:<br>PRIV = 0: User level privilege<br>PRIV = 1: Supervisor level privilege<br>PMPPRXY.PRIV is always updated with the value from the configuration bus Privilege field on any/every write to Program Set BIDX Register (trigger register). The PRIV value for the SA Set and DF Set are copied from the value in the Program set along with the remainder of the parameter values. The privilege ID is issued on the VBusM read and write command bus such that the target endpoints can perform memory protection checks based on the PRIV of the external host that sets up the DMA transaction. | R           | 0            |
| 7:4         | Reserved          | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R           | 0x0          |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3:0  | PRIVID     | Privilege ID:<br>PMPPRXY.PRIVID is always updated with the value from configuration bus Privilege ID field on any/every write to Program Set BIDX Register (trigger register). The PRIVID value for the SA Set and DF Set are copied from the value in the Program set along with the remainder of the parameter values. The privilege ID is issued on the VBusM read and write command bus such that the target endpoints can perform memory protection checks based on the privid of the external host that sets up the DMA transaction. | R    | 0x0   |

**Table 5-440. Register Call Summary for Register TPTCj\_PMPPRXY**

IVA2.2 Subsystem Functional Description

- EDMA: [0]

IVA2.2 Subsystem Register Manual

- TPTC0 and TPTC1 Register Mapping Summary: [1]

**Table 5-441. TPTCj\_SAOPT**

|                  |                      |                  |             |              |              |
|------------------|----------------------|------------------|-------------|--------------|--------------|
| Address Offset   | 0x240                | Physical address | 0x01C1 0240 | Instance     | IVA2.2 TPTC0 |
| Physical address | 0x01C1 0640          | Instance         |             | IVA2.2 TPTC1 |              |
| Description      | Src Actv Set Options |                  |             |              |              |
| Type             | R                    |                  |             |              |              |

|          |    |    |    |    |    |    |    |        |          |         |          |          |          |          |          |     |          |      |          |          |     |          |     |     |   |   |   |   |   |   |   |  |
|----------|----|----|----|----|----|----|----|--------|----------|---------|----------|----------|----------|----------|----------|-----|----------|------|----------|----------|-----|----------|-----|-----|---|---|---|---|---|---|---|--|
| 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 |  |
| Reserved |    |    |    |    |    |    |    | TCCHEN | Reserved | TCINTEN | Reserved | Reserved | Reserved | Reserved | Reserved | TCC | Reserved | FWID | Reserved | Reserved | PRI | Reserved | DAM | SAM |   |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                               | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:23 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                           | R    | 0x000 |
| 22    | TCCHEN     | Transfer complete chaining enable:<br>0: Transfer complete chaining is disabled.<br>1: Transfer complete chaining is enabled.                                                                                                                                                             | R    | 0     |
| 21    | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                           | R    | 0     |
| 20    | TCINTEN    | Transfer complete interrupt enable:<br>0: Transfer complete interrupt is disabled.<br>1: Transfer complete interrupt is enabled.                                                                                                                                                          | R    | 0     |
| 19:18 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                           | R    | 0x0   |
| 17:12 | TCC        | Transfer Complete Code:<br>The 6-bit code is used to set the relevant bit in CER or IPR of the TPCC module.                                                                                                                                                                               | R    | 0x00  |
| 11    | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                           | R    | 0     |
| 10:8  | FWID       | FIFO width control:<br>Applies if either SAM or DAM is set to FIFO mode.<br><br>Read 0x0: FIFO width is 8-bit<br>Read 0x1: FIFO width is 16-bit<br>Read 0x2: FIFO width is 32-bit<br>Read 0x3: FIFO width is 64-bit<br>Read 0x4: FIFO width is 128-bit<br>Read 0x5: FIFO width is 256-bit | R    | 0x0   |
| 7     | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                           | R    | 0     |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 6:4  | PRI        | Transfer Priority:<br>0: Priority 0 - Highest priority<br>1: Priority 1<br>...<br>7: Priority 7 - Lowest priority<br><br>Read 0x0: Priority 0 - Highest priority<br>Read 0x1: Priority 1<br>Read 0x2: Priority 2<br>Read 0x3: Priority 3<br>Read 0x4: Priority 4<br>Read 0x5: Priority 5<br>Read 0x6: Priority 6<br>Read 0x7: Priority 7 - Lowest Priority | R    | 0x0   |
| 3:2  | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                            | R    | 0x0   |
| 1    | DAM        | Destination Address Mode within an array:<br>0: INCR, Dst addressing within an array increments.<br>1: FIFO, Dst addressing within an array wraps around upon reaching FIFO width.                                                                                                                                                                         | R    | 0     |
| 0    | SAM        | Source Address Mode within an array:<br>0: INCR, Src addressing within an array increments.<br>1: FIFO, Src addressing within an array wraps around upon reaching FIFO width.                                                                                                                                                                              | R    | 0     |

**Table 5-442. Register Call Summary for Register TPTCj\_SAOPT**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-443. TPTCj\_SASRC**

|                         |                          |                       |                 |
|-------------------------|--------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x244                    |                       |                 |
| <b>Physical address</b> | 0x01C1 0244              | <b>Instance</b>       | IVA2.2 TPTC0    |
| <b>Physical address</b> | 0x01C1 0644              | <b>Instance</b>       | IVA2.2 TPTC1    |
| <b>Description</b>      | Src Actv Set Src Address |                       |                 |
| <b>Type</b>             | R                        |                       |                 |
| 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 |
|                         |                          | SADDR                 |                 |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                          | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | SADDR      | Source address for Source Active Register Set:<br>Initial value is copied from PSRC.SADDR. TC updates value according to source addressing mode (OPT.SAM) and/or source index value (BIDX.SBIDX) after each read command is issued.<br>When a TR is complete, the final value should be the address of the last read command issued. | R    | 0x00000000 |

**Table 5-444. Register Call Summary for Register TPTCj\_SASRC**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-445. TPTCj\_SACNT**

|                                                                                             |                    |                 |              |
|---------------------------------------------------------------------------------------------|--------------------|-----------------|--------------|
| <b>Address Offset</b>                                                                       | 0x248              |                 |              |
| <b>Physical address</b>                                                                     | 0x01C1 0248        | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Description</b>                                                                          | Src Actv Set Count |                 |              |
| <b>Type</b>                                                                                 | R                  |                 |              |
| 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 |                    |                 |              |
| BCNT                                                                                        |                    |                 | ACNT         |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                   | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | BCNT       | B-Dimension count:<br>Number of arrays to be transferred, where each array is ACNT in length.<br>Count Remaining for Src Active Register Set. Represents the amount of data remaining to be read. Initial value is copied from PCNT. TC decrements ACNT and BCNT as necessary after each read command is issued. Final value should be 0 when TR is complete. | R    | 0x0000 |
| 15:0  | ACNT       | A-Dimension count:<br>Number of bytes to be transferred in first dimension.<br>Count Remaining for Src Active Register Set. Represents the amount of data remaining to be read. Initial value is copied from PCNT. TC decrements ACNT and BCNT as necessary after each read command is issued. Final value should be 0 when TR is complete.                   | R    | 0x0000 |

**Table 5-446. Register Call Summary for Register TPTCj\_SACNT**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-447. TPTCj\_SADST**

|                                                                                             |                             |                 |              |
|---------------------------------------------------------------------------------------------|-----------------------------|-----------------|--------------|
| <b>Address Offset</b>                                                                       | 0x24C                       |                 |              |
| <b>Physical address</b>                                                                     | 0x01C1 024C                 | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b>                                                                     | 0x01C1 064C                 | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>                                                                          | rsvd, return 0x0 w/o AERROR |                 |              |
| <b>Type</b>                                                                                 | R                           |                 |              |
| 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 |                             |                 |              |
| DADDR                                                                                       |                             |                 |              |

| Bits | Field Name | Description                                                                            | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------|------|------------|
| 31:0 | DADDR      | Destination address is not applicable for Src Active Register Set.<br>Reads return 0x0 | R    | 0x00000000 |

**Table 5-448. Register Call Summary for Register TPTCj\_SADST**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-449. TPTCj\_SABIDX**

|                         |                         |                 |              |
|-------------------------|-------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x250                   |                 |              |
| <b>Physical address</b> | 0x01C1 0250             | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0650             | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | Src Actv Set B-Dim Idx  |                 |              |
| <b>Type</b>             | R                       |                 |              |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 |                 |              |
| DBIDX                   |                         |                 | SBIDX        |
| 15 14 13 12 11 10 9 8   | 7 6 5 4 3 2 1 0         |                 |              |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:16       | DBIDX             | Dest B-Idx for Source Active Register Set. Value copied from PBIDX:<br>B-Idx offset between Destination arrays:<br>Represents the offset in bytes between the startingaddress of each destination array (recall that there are BCNT arrays of ACNT elements). DBIDX is always used, regardless of whether DAM is Increment or FIFO mode. | R           | 0x0000       |
| 15:0        | SBIDX             | Source B-Idx for Source Active Register Set. Value copied from PBIDX:<br>B-Idx offset between Source arrays:<br>Represents the offset in bytes between the startingaddress of each source array (recall that there are BCNT arrays of ACNT elements). SBIDX is always used, regardless of whether SAM is Increment or FIFO mode.         | R           | 0x0000       |

**Table 5-450. Register Call Summary for Register TPTCj\_SABIDX**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-451. TPTCj\_SAMPPRXY**

|                         |                                |                 |              |
|-------------------------|--------------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x254                          |                 |              |
| <b>Physical address</b> | 0x01C1 0254                    | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0654                    | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | Src Actv Set Mem Protect Proxy |                 |              |
| <b>Type</b>             | R                              |                 |              |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16        |                 |              |
| Reserved                |                                |                 | PRIV         |
|                         |                                |                 | Reserved     |
|                         |                                |                 | PRIVID       |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:9        | Reserved          | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R           | 0x000000     |
| 8           | PRIV              | Privilege Level:<br>PRIV = 0: User level privilege<br>PRIV = 1: Supervisor level privilege<br>SAMPPRXY.PRIV is always updated with the value from the configuration bus Privilege field on any/every write to Program Set BIDX Register (trigger register). The PRIV value for the SA Set and DF Set are copied from the value in the Program set along with the remainder of the parameter values. The privilege ID is issued on the VBusM read and write command bus such that the target endpoints can perform memory protection checks based on the PRIV of the external host that sets up the DMA transaction. | R           | 0            |

## IVA2.2 Subsystem Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:4  | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R    | 0x0   |
| 3:0  | PRIVID     | Privilege ID:<br>SAMPPRXY.PRIVID is always updated with the value from configuration bus Privilege ID field on any/every write to Program Set BIDX Register (trigger register). The PRIVID value for the SA Set and DF Set are copied from the value in the Program set along with the remainder of the parameter values. The privilege ID is issued on the VBusM read and write command bus such that the target endpoints can perform memory protection checks based on the privid of the external host that sets up the DMA transaction. | R    | 0x0   |

**Table 5-452. Register Call Summary for Register TPTCj\_SAMPPRXY**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-453. TPTCj\_SACNTRLD**

|                         |                         |                 |              |
|-------------------------|-------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x258                   |                 |              |
| <b>Physical address</b> | 0x01C1 0258             | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0658             | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | Src Actv Set Cnt Reload |                 |              |
| <b>Type</b>             | R                       |                 |              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ACNTRLD |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                                               | R    | 0x0000 |
| 15:0  | ACNTRLD    | A-Cnt Reload value for Source Active Register set. Value copied from PCNT.ACNT:<br>Represents the originally programmed value of ACNT. The Reload value is used to reinitialize ACNT after each array is serviced (i.e., ACNT decrements to 0) by the Src offset in bytes between the starting address of each source array (recall that there are BCNT arrays of ACNT bytes) | R    | 0x0000 |

**Table 5-454. Register Call Summary for Register TPTCj\_SACNTRLD**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-455. TPTCj\_SASRCBREF**

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                         | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | SADDRBREF         | Source address reference for Source Active Register Set:<br>Represents the starting address for the array currently being read.<br>The next arrays starting address is calculated as the reference<br>address plus the source b-idx value. | R           | 0x00000000   |

**Table 5-456. Register Call Summary for Register TPTCj\_SASRCBREF**

## IVA2.2 Subsystem Functional Description

- EDMA: [0]

---

IVA2.2 Subsystem Register Manual

- TPTC0 and TPTC1 Register Mapping Summary: [1]

**Table 5-457. TPTCj\_SADSTBREF**

|                         |                             |                 |              |  |
|-------------------------|-----------------------------|-----------------|--------------|--|
| <b>Address Offset</b>   | 0x260                       |                 |              |  |
| <b>Physical address</b> | 0x01C1 0260                 | <b>Instance</b> | IVA2.2 TPTC0 |  |
| <b>Physical address</b> | 0x01C1 0660                 | <b>Instance</b> | IVA2.2 TPTC1 |  |
| <b>Description</b>      | rsvd, return 0x0 w/o AERROR |                 |              |  |
| <b>Type</b>             | R                           |                 |              |  |

  

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

DADDRBREF

| Bits | Field Name | Description                                                                               | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------|------|------------|
| 31:0 | DADDRBREF  | Dst address reference is not applicable for Src Active Register Set.<br>Reads return 0x0. | R    | 0x00000000 |

**Table 5-458. Register Call Summary for Register TPTCj\_SADSTBREF**

---

IVA2.2 Subsystem Functional Description

- EDMA: [0]

IVA2.2 Subsystem Register Manual

- TPTC0 and TPTC1 Register Mapping Summary: [1]

**Table 5-459. TPTCj\_DFCNTRLD**

|                         |                         |                 |              |
|-------------------------|-------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x280                   |                 |              |
| <b>Physical address</b> | 0x01C1 0280             | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0680             | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | Dst FIFO Set Cnt Reload |                 |              |
| <b>Type</b>             | R                       |                 |              |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ACNTRLD |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                   | R    | 0x0000 |
| 15:0  | ACNTRLD    | A-Cnt Reload value for Destination FIFO Register set. Value copied from PCNT.ACNT:<br>Represents the originally programmed value of ACNT. The Reload value is used to reinitialize ACNT after each array is serviced (i.e., ACNT decrements to 0). by the Src offset in bytes between the starting address of each source array (recall that there are BCNT arrays of ACNT bytes) | R    | 0x0000 |

**Table 5-460. Register Call Summary for Register TPTCj\_DFCNTRLD**

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[0\]](#)

**Table 5-461. TPTCj\_DFSRCBREF**

|                         |                             |                 |              |
|-------------------------|-----------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x284                       |                 |              |
| <b>Physical address</b> | 0x01C1 0284                 | <b>Instance</b> | IVA2.2 TPTC0 |
| <b>Physical address</b> | 0x01C1 0684                 | <b>Instance</b> | IVA2.2 TPTC1 |
| <b>Description</b>      | rsvd, return 0x0 w/o AERROR |                 |              |
| <b>Type</b>             | R                           |                 |              |

  

|           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| SADDRBREF |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------|------|------------|
| 31:0 | SADDRBREF  | Source address reference is not applicable for Dst FIFO Register Set.<br>Reads return 0x0. | R    | 0x00000000 |

**Table 5-462. Register Call Summary for Register TPTCj\_DFSRCBREF**

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[0\]](#)

**Table 5-463. TPTCj\_DFDSTBREF**

| Bits | Field Name | Description                                                                                                                                                                                                                         | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | DADDRBREF  | Destination address reference for Dst FIFO Register Set:<br>Represents the starting address for the array currently being written. The next arrays starting address is calculated as the reference address plus the dest bidxvalue. | R    | 0x00000000 |

**Table 5-464. Register Call Summary for Register TPTCj\_DFDSTBREF**

IVA2.2 Subsystem Register Manual

- TPTC0 and TPTC1 Register Mapping Summary: [0]

**Table 5-465. TPTCj\_DFOPTi**

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:23       | Reserved          | Read returns 0.                                                                                                                                                                                                                                        | R           | 0x000        |
| 22          | TCCHEN            | Transfer complete chaining enable:<br>0: Transfer complete chaining is disabled.<br>1: Transfer complete chaining is enabled.                                                                                                                          | R           | 0            |
| 21          | Reserved          | Read returns 0.                                                                                                                                                                                                                                        | R           | 0            |
| 20          | TCINTEN           | Transfer complete interrupt enable:<br>0: Transfer complete interrupt is disabled.<br>1: Transfer complete interrupt is enabled.                                                                                                                       | R           | 0            |
| 19:18       | Reserved          | Read returns 0.                                                                                                                                                                                                                                        | R           | 0x0          |
| 17:12       | TCC               | Transfer Complete Code:<br>The 6-bit code is used to set the relevant bit in CER or IPR of the TPCC module.                                                                                                                                            | R           | 0x00         |
| 11          | Reserved          | Read returns 0.                                                                                                                                                                                                                                        | R           | 0            |
| 10:8        | FWID              | FIFO width control:<br>Applies if either SAM or DAM is set to FIFO mode.<br><br>Read 0x0: FIFO width is 8-bit<br>Read 0x1: FIFO width is 16-bit<br>Read 0x2: FIFO width is 32-bit<br>Read 0x3: FIFO width is 64-bit<br>Read 0x4: FIFO width is 128-bit | R           | 0x0          |

## IVA2.2 Subsystem Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                        | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | Read 0x5: FIFO width is 256-bit                                                                                                                                                    |      |       |
| 7    | Reserved   | Read returns 0.                                                                                                                                                                    | R    | 0     |
| 6:4  | PRI        | Transfer Priority:<br>0: Priority 0 - Highest priority<br>1: Priority 1<br>...<br>7: Priority 7 - Lowest priority                                                                  | R    | 0x0   |
|      |            | Read 0x0: Priority 0 - Highest priority                                                                                                                                            |      |       |
|      |            | Read 0x1: Priority 1                                                                                                                                                               |      |       |
|      |            | Read 0x2: Priority 2                                                                                                                                                               |      |       |
|      |            | Read 0x3: Priority 3                                                                                                                                                               |      |       |
|      |            | Read 0x4: Priority 4                                                                                                                                                               |      |       |
|      |            | Read 0x5: Priority 5                                                                                                                                                               |      |       |
|      |            | Read 0x6: Priority 6                                                                                                                                                               |      |       |
|      |            | Read 0x7: Priority 7 - Lowest Priority                                                                                                                                             |      |       |
| 3:2  | Reserved   | Read returns 0.                                                                                                                                                                    | R    | 0x0   |
| 1    | DAM        | Destination Address Mode within an array:<br>0: INCR, Dst addressing within an array increments.<br>1: FIFO, Dst addressing within an array wraps around upon reaching FIFO width. | R    | 0     |
| 0    | SAM        | Source Address Mode within an array:<br>0: INCR, Src addressing within an array increments.<br>1: FIFO, Src addressing within an array wraps around upon reaching FIFO width.      | R    | 0     |

**Table 5-466. Register Call Summary for Register TPTCj\_DFOPTi**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\] \[1\] \[2\] \[3\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[4\]](#)

**Table 5-467. TPTCj\_DFSRCi**

|                         |                             |                 |              |  |
|-------------------------|-----------------------------|-----------------|--------------|--|
| <b>Address Offset</b>   | 0x304 + (0x40*i)            |                 |              |  |
| <b>Physical address</b> | 0x01C1 0304 + (0x40*i)      | <b>Instance</b> | IVA2.2 TPTC0 |  |
| <b>Physical address</b> | 0x01C1 0704 + (0x40*i)      | <b>Instance</b> | IVA2.2 TPTC1 |  |
| <b>Description</b>      | rsvd, return 0x0 w/o AERROR |                 |              |  |
| <b>Type</b>             | R                           |                 |              |  |

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                     | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------|------|------------|
| 31:0 | SADDR      | Source address is not applicable for Dst FIFORegister Set:<br>Reads return 0x0. | R    | 0x00000000 |

**Table 5-468. Register Call Summary for Register TPTCj\_DFSRCi**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-469. TPTCj\_DFCNTi**

|                         |                         |  |  |  |  |  |  |  |                       |                 |      |  |  |  |  |  |  |  |
|-------------------------|-------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x308 + (0x40*i)        |  |  |  |  |  |  |  |                       |                 |      |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C1 0308 + (0x40*i)  |  |  |  |  |  |  |  | <b>Instance</b>       | IV A2.2 TPTC0   |      |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C1 0708 + (0x40*i)  |  |  |  |  |  |  |  | <b>Instance</b>       | IV A2.2 TPTC1   |      |  |  |  |  |  |  |  |
| <b>Description</b>      | Dst FIFO i Set Count    |  |  |  |  |  |  |  |                       |                 |      |  |  |  |  |  |  |  |
| <b>Type</b>             | R                       |  |  |  |  |  |  |  |                       |                 |      |  |  |  |  |  |  |  |
| 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 | ACNT |  |  |  |  |  |  |  |
|                         | BCNT                    |  |  |  |  |  |  |  |                       | ACNT            |      |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | BCNT       | B-Count Remaining for Dst Register Set:<br>Number of arrays to be transferred, where each array is ACNT in length.<br>Represents the amount of data remaining to be written. Initial value is copied from PCNT. TC decrements ACNT and BCNT as necessary after each write datapath is issued. Final value should be 0 when TR is complete. | R    | 0x0000 |
| 15:0  | ACNT       | A-Count Remaining for Dst Register Set:<br>Number of bytes to be transferred in first dimension.<br>Represents the amount of data remaining to be written. Initial value is copied from PCNT. TC decrements ACNT and BCNT as necessary after each write datapath is issued. Final value should be 0 when TR is complete.                   | R    | 0x0000 |

**Table 5-470. Register Call Summary for Register TPTCj\_DFCNTi**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-471. TPTCj\_DFDSTi**

|                         |                            |  |  |  |  |  |  |  |                       |                 |       |  |  |  |  |  |  |  |
|-------------------------|----------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|-------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x30C + (0x40*i)           |  |  |  |  |  |  |  |                       |                 |       |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C1 030C + (0x40*i)     |  |  |  |  |  |  |  | <b>Instance</b>       | IV A2.2 TPTC0   |       |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C1 070C + (0x40*i)     |  |  |  |  |  |  |  | <b>Instance</b>       | IV A2.2 TPTC1   |       |  |  |  |  |  |  |  |
| <b>Description</b>      | Dst FIFO i Set Dst Address |  |  |  |  |  |  |  |                       |                 |       |  |  |  |  |  |  |  |
| <b>Type</b>             | R                          |  |  |  |  |  |  |  |                       |                 |       |  |  |  |  |  |  |  |
| 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 | DADDR |  |  |  |  |  |  |  |
|                         | DADDR                      |  |  |  |  |  |  |  |                       | DADDR           |       |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                               | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | DADDR      | Destination address for Dst FIFO Register Set:<br>Initial value is copied from PDST.DADDR. TC updates value according to destination addressing mode (OPT.SAM) and/or dest index value (BIDX.DBIDX) after each write command is issued.<br>When a TR is complete, the final value should be the address of the last write command issued. | R    | 0x00000000 |

**Table 5-472. Register Call Summary for Register TPTCj\_DFDSTi**

IVA2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

**Table 5-473. TPTCj\_DFBIDX<sub>i</sub>**

|                         |                          |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
|-------------------------|--------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x310 + (0x40*i)         |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C1 0310 + (0x40*i)   |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C1 0710 + (0x40*i)   |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
| <b>Description</b>      | Dst FIFO i Set B-Dim Idx |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
| <b>Type</b>             | R                        |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |
|                         | DBIDX                    |  |  |  |  |  |  |  |                       | SBIDX           |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                        | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | DBIDX      | Dest B-Idx for Dest FIFO Register Set. Value copied from PBIDX:<br>B-Idx offset between Destination arrays:<br>Represents the offset in bytes between the starting address of each destination array (recall that there are BCNT arrays of ACNT elements). DBIDX <sub>i</sub> is always used, regardless of whether DAM is Increment or FIFO mode. | R    | 0x0000 |
| 15:0  | SBIDX      | Dest B-Idx for Dest FIFO Register Set. Value copied from PBIDX:<br>B-Idx offset between Source arrays:<br>Represents the offset in bytes between the starting address of each source array (recall that there are BCNT arrays of ACNT elements). SBIDX is always used, regardless of whether SAM is Increment or FIFO mode.                        | R    | 0x0000 |

**Table 5-474. Register Call Summary for Register TPTCj\_DFBIDX<sub>i</sub>**

IVA2.2 Subsystem Functional Description

- EDMA: [0]

IVA2.2 Subsystem Register Manual

- TPTC0 and TPTC1 Register Mapping Summary: [1]

**Table 5-475. TPTCj\_DFMPPRX<sub>i</sub>**

|                         |                              |  |  |  |  |  |  |  |                       |                 |  |  |  |      |          |        |  |
|-------------------------|------------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|--|--|--|------|----------|--------|--|
| <b>Address Offset</b>   | 0x314 + (0x40*i)             |  |  |  |  |  |  |  |                       |                 |  |  |  |      |          |        |  |
| <b>Physical address</b> | 0x01C1 0314 + (0x40*i)       |  |  |  |  |  |  |  |                       |                 |  |  |  |      |          |        |  |
| <b>Physical address</b> | 0x01C1 0714 + (0x40*i)       |  |  |  |  |  |  |  |                       |                 |  |  |  |      |          |        |  |
| <b>Description</b>      | Dst FIFO i Mem Protect Proxy |  |  |  |  |  |  |  |                       |                 |  |  |  |      |          |        |  |
| <b>Type</b>             | R                            |  |  |  |  |  |  |  |                       |                 |  |  |  |      |          |        |  |
| 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 |  |  |  |      |          |        |  |
|                         | Reserved                     |  |  |  |  |  |  |  |                       |                 |  |  |  |      |          |        |  |
|                         |                              |  |  |  |  |  |  |  |                       |                 |  |  |  | PRIV | Reserved | PRIVID |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Type | Reset    |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R    | 0x000000 |
| 8    | PRIV       | Privilege Level:<br>PRIV = 0: User level privilege<br>PRIV = 1: Supervisor level privilege<br>DFMPPRX <sub>i</sub> .PRIV is always updated with the value from the configuration bus Privilege field on any/every write to Program Set BIDX Register (trigger register). The PRIV value for the SA Set and DF Set are copied from the value in the Program set along with the remainder of the parameter values. The privilege ID is issued on the VBusM read and write command bus such that the target endpoints can perform memory protection checks based on the PRIV of the external host that sets up the DMA transaction. | R    | 0        |
| 7:4  | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R    | 0x0      |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3:0  | PRIVID     | Privilege ID:<br>DFMPPRXYi.PRIVID is always updated with the value from configuration bus Privilege ID field on any/every write to Program Set BIDX Register (trigger register). The PRIVID value for the SA Set and DF Set are copied from the value in the Program set along with the remainder of the parameter values. The privilege ID is issued on the VBusM read and write command bus such that the target endpoints can perform memory protection checks based on the privid of the external host that sets up the DMA transaction. | R    | 0x0   |

**Table 5-476. Register Call Summary for Register TPTCj\_DFMPPRXYi**

Iva2.2 Subsystem Functional Description

- [EDMA: \[0\]](#)

Iva2.2 Subsystem Register Manual

- [TPTC0 and TPTC1 Register Mapping Summary: \[1\]](#)

## 5.5.7 SYSC Registers

This section provides information about the IVA2\_SYSC Module. Each register in the Module is described separately below.

### 5.5.7.1 SYSC Register Mapping Summary

**Table 5-477. SYSC Register Summary**

| Register Name  | Type | Register Width (Bits) | Address Offset | Physical Address |
|----------------|------|-----------------------|----------------|------------------|
| SYSC_REVISION  | R    | 32                    | 0x000          | 0x01C2 0000      |
| SYSC_SYSCONFIG | RW   | 32                    | 0x008          | 0x01C2 0008      |
| SYSC_LICFG0    | RW   | 32                    | 0x040          | 0x01C2 0040      |
| SYSC_LICFG1    | RW   | 32                    | 0x048          | 0x01C2 0048      |
| SYSC_BOOTADDR  | R    | 32                    | 0x100          | 0x01C2 0100      |
| SYSC_BOOTMOD   | R    | 32                    | 0x104          | 0x01C2 0104      |

### 5.5.7.2 SYSC Register Descriptions

**Table 5-478. SYSC\_REVISION**

|                         |                                             |                 |             |
|-------------------------|---------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x000                                       |                 |             |
| <b>Physical address</b> | 0x01C2 0000                                 | <b>Instance</b> | IVA2.2 SYSC |
| <b>Description</b>      | This register contains the IP revision code |                 |             |
| <b>Type</b>             | R                                           |                 |             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REV |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                             | Type | Reset              |
|------|------------|---------------------------------------------------------|------|--------------------|
| 31:8 | Reserved   | Read returns 0.                                         | R    | 0x000000           |
| 7:0  | REV        | IP revision<br>3:0 Minor revision<br>7:4 Major revision | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 5-479. Register Call Summary for Register SYSC\_REVISION**

|                                                      |
|------------------------------------------------------|
| IVA2.2 Subsystem Register Manual                     |
| • <a href="#">SYSC Register Mapping Summary: [0]</a> |

**Table 5-480. SYSC\_SYSCONFIG**

|                         |                                                                        |                 |             |
|-------------------------|------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x008                                                                  |                 |             |
| <b>Physical address</b> | 0x01C2 0008                                                            | <b>Instance</b> | IVA2.2 SYSC |
| <b>Description</b>      | This register allows controlling various parameters of the SYSC module |                 |             |
| <b>Type</b>             | RW                                                                     |                 |             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----------|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | AUTOIDLE |   |   |

| Bits | Field Name | Description                                                                                                      | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                            | RW   | 0x00000000 |
| 0    | AUTOIDLE   | Internal auto-clock gating strategy<br>0: Clock is free running<br>1: Automatic clock gating strategy is applied | RW   | 1          |

**Table 5-481. Register Call Summary for Register SYSC\_SYSCONFIG**

|                                             |
|---------------------------------------------|
| IVA2.2 Subsystem Basic Programming Model    |
| • <a href="#">Clock Management: [0] [1]</a> |

|                                                      |
|------------------------------------------------------|
| IVA2.2 Subsystem Register Manual                     |
| • <a href="#">SYSC Register Mapping Summary: [2]</a> |

**Table 5-482. SYSC\_LICFG0**

|                         |                                                                                    |                         |                 |                 |             |
|-------------------------|------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x040                                                                              | <b>Physical address</b> | 0x01C2 0040     | <b>Instance</b> | IVA2.2 SYSC |
| <b>Description</b>      | This register controls various parameters of the IVA2.2 local interconnect network |                         |                 |                 |             |
| <b>Type</b>             | RW                                                                                 |                         |                 |                 |             |
| 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 |                 |             |
|                         |                                                                                    |                         |                 |                 |             |
|                         | Reserved                                                                           | GEMBURSTOPTEN           | Reserved        | DMA2DOPTEN      | Reserved    |
|                         |                                                                                    | GEMTRUECOMPEN           |                 | DMATRUECOMPEN   |             |
|                         |                                                                                    |                         |                 |                 | PAGEXINGEN  |
|                         |                                                                                    |                         |                 |                 | Reserved    |

  

| Bits  | Field Name    | Description                                                                                                                                                                                                                                           | Type | Reset  |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:17 | Reserved      | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                 | RW   | 0x0000 |
| 16    | GEMBURSTOPTEN | DSP megamodule cache-line operation transfers optimization control:<br>0: DSP megamodule cache operation transfers are not optimized<br>1: DSP megamodule cache operation transfers are optimized                                                     | RW   | 0      |
| 15    | GEMTRUECOMPEN | DSP megamodule program-initiated write-back transfer true completion control:<br>0: DSP megamodule program-initiated write-back transfer completion is not accurate<br>1: DSP megamodule program initiated write-back transfer completion is accurate | RW   | 0      |
| 14:10 | Reserved      | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                 | RW   | 0x00   |
| 9     | DMA2DOPTEN    | 2D transfers optimization control:<br>0: 2D DMA transfers optimization is disabled<br>1: 2D DMA transfers optimization is enabled                                                                                                                     | RW   | 0      |
| 8     | DMATRUECOMPEN | DMA write transfer true completion control:<br>0: DMA write transfer completion is not accurate<br>1: DMA write transfer completion is accurate                                                                                                       | RW   | 0      |
| 7:4   | Reserved      | Write 0xF for compatibility<br>Read returns 0xF                                                                                                                                                                                                       | RW   | 0xF    |
| 3:2   | Reserved      | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                 | RW   | 0x0    |
| 1     | PAGEXINGEN    | MMU page crossing enable:<br>0: Bursts are not allowed to cross 4KB page boundaries<br>1: Bursts are allowed to cross 4KB page boundaries                                                                                                             | RW   | 0      |
| 0     | Reserved      | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                 | RW   | 0      |

**Table 5-483. Register Call Summary for Register SYSC\_LICFG0**

IVA2.2 Subsystem Functional Description

- [Interconnect Optimization: \[0\]](#)

IVA2.2 Subsystem Basic Programming Model

- [Coherence Maintenance: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\]](#)
- [Prioritizing Defined Transfers: \[11\] \[12\] \[13\]](#)
- [Starting the Transfer: \[14\]](#)
- [Recommendations for Static Settings: \[15\] \[16\] \[17\] \[18\] \[19\] \[20\]](#)

IVA2.2 Subsystem Register Manual

- [SYSC Register Mapping Summary: \[21\]](#)

**Table 5-484. SYSC\_LICFG1**

|                         |                                                                                              |                       |                 |
|-------------------------|----------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x048                                                                                        |                       |                 |
| <b>Physical address</b> | 0x01C2 0048                                                                                  | <b>Instance</b>       | IVA2.2 SYSC     |
| <b>Description</b>      | This register allows controlling various parameters of the IVA2.2 local interconnect network |                       |                 |
| <b>Type</b>             | RW                                                                                           |                       |                 |
| 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 |
| Reserved                |                                                                                              |                       | APINTERVAL      |

  

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset     |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0x0000000 |
| 4:0  | APINTERVAL | Control of the Aged Priority (priority inversion) for DMA accesses:<br><br>When set to 0x0, the aged priority is disabled<br><br>When set to another value, this controls how often the priority is adjusted: every APInterval cycles, the priority of the port is decreased until the associated request is accepted or the priority of the port equals 0. The priority of the port is reinitialized to the transaction priority each time a new VBUS command is generated, i.e. the last one has been accepted.<br><br>0x0: Aged Priority Disabled:<br><br>There is no aged priority in SCR. DMA transaction keeps the fixed priority defined internally, and has to wait for the bus to be freed by higher priority initiators | RW   | 0x00      |

**Table 5-485. Register Call Summary for Register SYSC\_LICFG1**

IVA2.2 Subsystem Functional Description

- [Interconnect Optimization: \[0\]](#)

IVA2.2 Subsystem Basic Programming Model

- [Prioritizing Defined Transfers: \[1\] \[2\]](#)

IVA2.2 Subsystem Register Manual

- [SYSC Register Mapping Summary: \[3\]](#)

**Table 5-486. SYSC\_BOOTADDR**

|                         |                                                                                                                                                       |                       |                 |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x100                                                                                                                                                 |                       |                 |
| <b>Physical address</b> | 0x01C2 0100                                                                                                                                           | <b>Instance</b>       | IVA2.2 SYSC     |
| <b>Description</b>      | This register defines the physical address of the IVA2 boot loader. This is a copy of the CONTROL_IVA2_BOOTADDR when the IVA2 is released from reset. |                       |                 |
| <b>Type</b>             | R                                                                                                                                                     |                       |                 |
| 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 |
| BOOTLOADADDR            |                                                                                                                                                       |                       | Reserved        |

  

| Bits  | Field Name   | Description                                                                                                                                                                     | Type | Reset  |
|-------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:12 | BOOTLOADADDR | Physical address of the IVA2 boot loader:<br>This is the read-only copy of the CONTROL_IVA2_BOOTADDR when the IVA2 is released from reset<br>This is an index to a 4K-byte page | R    | 0x---- |
| 11:0  | Reserved     | Read returns 0.                                                                                                                                                                 | R    | 0x000  |

**Table 5-487. Register Call Summary for Register SYSC\_BOOTADDR**


---

 IVA2.2 Subsystem Functional Description

- [Boot Configuration: \[0\]](#) [\[1\]](#)

---

 IVA2.2 Subsystem Basic Programming Model

- [IVA2.2 Boot: \[2\]](#)

- [Example of IVA2.2 Boot: \[3\]](#)

---

 IVA2.2 Subsystem Register Manual

- [SYSC Register Mapping Summary: \[4\]](#)

**Table 5-488. SYSC\_BOOTMOD**

|                       |                                                                                                                            |                         |             |                 |             |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x104                                                                                                                      | <b>Physical address</b> | 0x01C2 0104 | <b>Instance</b> | IVA2.2 SYSC |
| <b>Description</b>    | This register defines the IVA2 boot mode. This is a copy of the CONTROL_IVA2_BOOTMOD when the IVA2 is released from reset. |                         |             |                 |             |
| <b>Type</b>           | R                                                                                                                          |                         |             |                 |             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----------|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | BOOTMODE |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                      | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:4        | Reserved          | Read returns 0.                                                                                                                                                         | R           | 0x0000000    |
| 3:0         | BOOTMODE          | Boot mode of the IVA2:<br>This is the read-only copy of the IVA2_BOOTMOD when the IVA2 is released from reset<br>The value meaning is defined by the IVA2 ROM boot code | R           | 0x-          |

**Table 5-489. Register Call Summary for Register SYSC\_BOOTMOD**


---

 IVA2.2 Subsystem Functional Description

- [Boot Configuration: \[0\]](#) [\[1\]](#)

---

 IVA2.2 Subsystem Basic Programming Model

- [IVA2.2 Boot: \[2\]](#)

---

 IVA2.2 Subsystem Register Manual

- [SYSC Register Mapping Summary: \[3\]](#)

## 5.5.8 WUGEN Registers

This section provides information about the WUGEN Module. Each register in the Module is described separately below.

### 5.5.8.1 WUGEN Register Mapping Summary

**Table 5-490. WUGEN Register Summary**

| Register Name     | Type | Register Width<br>(Bits) | Address Offset | Physical Address |
|-------------------|------|--------------------------|----------------|------------------|
| WUGEN_REVISION    | R    | 32                       | 0x000          | 0x01C2 1000      |
| WUGEN_SYSCONFIG   | RW   | 32                       | 0x008          | 0x01C2 1008      |
| WUGEN_MEVT0       | R    | 32                       | 0x060          | 0x01C2 1060      |
| WUGEN_MEVT1       | R    | 32                       | 0x064          | 0x01C2 1064      |
| WUGEN_MEVT2       | R    | 32                       | 0x068          | 0x01C2 1068      |
| WUGEN_MEVTCR0     | W    | 32                       | 0x070          | 0x01C2 1070      |
| WUGEN_MEVTCR1     | W    | 32                       | 0x074          | 0x01C2 1074      |
| WUGEN_MEVTCR2     | W    | 32                       | 0x078          | 0x01C2 1078      |
| WUGEN_MEVTSET0    | W    | 32                       | 0x080          | 0x01C2 1080      |
| WUGEN_MEVTSET1    | W    | 32                       | 0x084          | 0x01C2 1084      |
| WUGEN_MEVTSET2    | W    | 32                       | 0x088          | 0x01C2 1088      |
| WUGEN_PENDEVT0    | R    | 32                       | 0x090          | 0x01C2 1090      |
| WUGEN_PENDEVT1    | R    | 32                       | 0x094          | 0x01C2 1094      |
| WUGEN_PENDEVT2    | R    | 32                       | 0x098          | 0x01C2 1098      |
| WUGEN_PENDEVTCLR0 | W    | 32                       | 0x100          | 0x01C2 1100      |
| WUGEN_PENDEVTCLR1 | W    | 32                       | 0x104          | 0x01C2 1104      |
| WUGEN_PENDEVTCLR2 | W    | 32                       | 0x108          | 0x01C2 1108      |

### 5.5.8.2 WUGEN Register Descriptions

**Table 5-491. WUGEN\_REVISION**

|                         |                                             |                 |              |
|-------------------------|---------------------------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x000                                       |                 |              |
| <b>Physical address</b> | 0x01C2 1000                                 | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>      | This register contains the IP revision code |                 |              |
| <b>Type</b>             | R                                           |                 |              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REV |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                             | Type | Reset              |
|------|------------|---------------------------------------------------------|------|--------------------|
| 31:8 | Reserved   | Read returns 0.                                         | R    | 0x000000           |
| 7:0  | REV        | IP revision<br>3:0 Minor revision<br>7:4 Major revision | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 5-492. Register Call Summary for Register WUGEN\_REVISION**

|                                                       |
|-------------------------------------------------------|
| IVA2.2 Subsystem Register Manual                      |
| • <a href="#">WUGEN Register Mapping Summary: [0]</a> |

**Table 5-493. WUGEN\_SYSCONFIG**

|                         |                                                                         |                 |              |
|-------------------------|-------------------------------------------------------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x008                                                                   |                 |              |
| <b>Physical address</b> | 0x01C2 1008                                                             | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>      | This register allows controlling various parameters of the WUGEN module |                 |              |
| <b>Type</b>             | RW                                                                      |                 |              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----------|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | AUTOIDLE |   |   |

| Bits | Field Name | Description                                                                                                      | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Write Os for future compatibility.<br>Read returns 0.                                                            | RW   | 0x00000000 |
| 0    | AUTOIDLE   | Internal auto-clock gating strategy<br>0: Clock is free running<br>1: Automatic clock gating strategy is applied | RW   | 1          |

**Table 5-494. Register Call Summary for Register WUGEN\_SYSCONFIG**

|                                             |
|---------------------------------------------|
| IVA2.2 Subsystem Basic Programming Model    |
| • <a href="#">Clock Management: [0] [1]</a> |

|                                                       |
|-------------------------------------------------------|
| IVA2.2 Subsystem Register Manual                      |
| • <a href="#">WUGEN Register Mapping Summary: [2]</a> |

**Table 5-495. WUGEN\_MEVT0**

|                                              |                                                 |                                            |                                      |                 |              |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |       |       |       |       |       |       |       |       |       |       |
|----------------------------------------------|-------------------------------------------------|--------------------------------------------|--------------------------------------|-----------------|--------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| <b>Address Offset</b>                        | 0x060                                           | <b>Physical address</b>                    | 0x01C2 1060                          | <b>Instance</b> | IVA2.2 WUGEN |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |       |       |       |       |       |       |       |       |       |       |
| <b>Description</b>                           | This register contains the interrupt mask (LSB) |                                            |                                      |                 |              |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |       |       |       |       |       |       |       |       |       |       |
| <b>Type</b>                                  | R                                               |                                            |                                      |                 |              |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |       |       |       |       |       |       |       |       |       |       |
| 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 |                 |              |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |       |       |       |       |       |       |       |       |       |       |
| MIRQ31                                       | MIRQ30                                          | MIRQ29                                     | MIRQ28                               | MIRQ27          | MIRQ26       | MIRQ25 | MIRQ24 | MIRQ23 | MIRQ22 | MIRQ21 | MIRQ20 | MIRQ19 | MIRQ18 | MIRQ17 | MIRQ16 | MIRQ15 | MIRQ14 | MIRQ13 | MIRQ12 | MIRQ11 | MIRQ10 | MIRQ9 | MIRQ8 | MIRQ7 | MIRQ6 | MIRQ5 | MIRQ4 | MIRQ3 | MIRQ2 | MIRQ1 | MIRQ0 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------|-------------|--------------|
| 31          | MIRQ31            | Interrupt Mask bit #31 | R           | 1            |
| 30          | MIRQ30            | Interrupt Mask bit #30 | R           | 1            |
| 29          | MIRQ29            | Interrupt Mask bit #29 | R           | 1            |
| 28          | MIRQ28            | Interrupt Mask bit #28 | R           | 1            |
| 27          | MIRQ27            | Interrupt Mask bit #27 | R           | 1            |
| 26          | MIRQ26            | Interrupt Mask bit #26 | R           | 1            |
| 25          | MIRQ25            | Interrupt Mask bit #25 | R           | 1            |
| 24          | MIRQ24            | Interrupt Mask bit #24 | R           | 1            |
| 23          | MIRQ23            | Interrupt Mask bit #23 | R           | 1            |
| 22          | MIRQ22            | Interrupt Mask bit #22 | R           | 1            |
| 21          | MIRQ21            | Interrupt Mask bit #21 | R           | 1            |
| 20          | MIRQ20            | Interrupt Mask bit #20 | R           | 1            |
| 19          | MIRQ19            | Interrupt Mask bit #19 | R           | 1            |
| 18          | MIRQ18            | Interrupt Mask bit #18 | R           | 1            |
| 17          | MIRQ17            | Interrupt Mask bit #17 | R           | 1            |
| 16          | MIRQ16            | Interrupt Mask bit #16 | R           | 1            |
| 15          | MIRQ15            | Interrupt Mask bit #15 | R           | 1            |
| 14          | MIRQ14            | Interrupt Mask bit #14 | R           | 1            |
| 13          | MIRQ13            | Interrupt Mask bit #13 | R           | 1            |
| 12          | MIRQ12            | Interrupt Mask bit #12 | R           | 1            |
| 11          | MIRQ11            | Interrupt Mask bit #11 | R           | 1            |
| 10          | MIRQ10            | Interrupt Mask bit #10 | R           | 1            |
| 9           | MIRQ9             | Interrupt Mask bit #9  | R           | 1            |
| 8           | MIRQ8             | Interrupt Mask bit #8  | R           | 1            |
| 7           | MIRQ7             | Interrupt Mask bit #7  | R           | 1            |
| 6           | MIRQ6             | Interrupt Mask bit #6  | R           | 1            |
| 5           | MIRQ5             | Interrupt Mask bit #5  | R           | 1            |
| 4           | MIRQ4             | Interrupt Mask bit #4  | R           | 1            |
| 3           | MIRQ3             | Interrupt Mask bit #3  | R           | 1            |
| 2           | MIRQ2             | Interrupt Mask bit #2  | R           | 1            |
| 1           | MIRQ1             | Interrupt Mask bit #1  | R           | 1            |
| 0           | MIRQ0             | Interrupt Mask bit #0  | R           | 1            |

**Table 5-496. Register Call Summary for Register WUGEN\_MEVT0**

## IVA2.2 Subsystem Functional Description

- [Interrupts, DMA Requests, and Event Management: \[0\] \[1\]](#)

## IVA2.2 Subsystem Basic Programming Model

- [Interrupt Controller Basic Programming Model for Power Down of IVA2.2 Subsystem: \[2\] \[3\]](#)
- [Interrupt Controller Basic Programming Model for Power On of IVA2.2 Subsystem: \[4\] \[5\] \[6\]](#)

## IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[7\]](#)
- [WUGEN Register Descriptions: \[8\] \[9\]](#)

**Table 5-497. WUGEN\_MEVT1**

|                       |                                                 |                         |             |                 |              |
|-----------------------|-------------------------------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b> | 0x064                                           | <b>Physical address</b> | 0x01C2 1064 | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>    | This register contains the interrupt mask (MSB) |                         |             |                 |              |
| <b>Type</b>           | R                                               |                         |             |                 |              |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 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      |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MIRQ47 | MIRQ46 | MIRQ45 | MIRQ44 | MIRQ43 | MIRQ42 | MIRQ41 | MIRQ40 | MIRQ39 | MIRQ38 | MIRQ37 | MIRQ36 | MIRQ35 | MIRQ34 | MIRQ33 | MIRQ32 |

| Bits  | Field Name | Description            | Type | Reset  |
|-------|------------|------------------------|------|--------|
| 31:16 | Reserved   | Read returns 0.        | R    | 0x0000 |
| 15    | MIRQ47     | Interrupt Mask bit #47 | R    | 1      |
| 14    | MIRQ46     | Interrupt Mask bit #46 | R    | 1      |
| 13    | MIRQ45     | Interrupt Mask bit #45 | R    | 1      |
| 12    | MIRQ44     | Interrupt Mask bit #44 | R    | 1      |
| 11    | MIRQ43     | Interrupt Mask bit #43 | R    | 1      |
| 10    | MIRQ42     | Interrupt Mask bit #42 | R    | 1      |
| 9     | MIRQ41     | Interrupt Mask bit #41 | R    | 1      |
| 8     | MIRQ40     | Interrupt Mask bit #40 | R    | 1      |
| 7     | MIRQ39     | Interrupt Mask bit #39 | R    | 1      |
| 6     | MIRQ38     | Interrupt Mask bit #38 | R    | 1      |
| 5     | MIRQ37     | Interrupt Mask bit #37 | R    | 1      |
| 4     | MIRQ36     | Interrupt Mask bit #36 | R    | 1      |
| 3     | MIRQ35     | Interrupt Mask bit #35 | R    | 1      |
| 2     | MIRQ34     | Interrupt Mask bit #34 | R    | 1      |
| 1     | MIRQ33     | Interrupt Mask bit #33 | R    | 1      |
| 0     | MIRQ32     | Interrupt Mask bit #32 | R    | 1      |

**Table 5-498. Register Call Summary for Register WUGEN\_MEVT1**

## IVA2.2 Subsystem Functional Description

- [Interrupts, DMA Requests, and Event Management: \[0\]](#)

## IVA2.2 Subsystem Basic Programming Model

- [Interrupt Controller Basic Programming Model for Power Down of IVA2.2 Subsystem: \[1\] \[2\]](#)
- [Interrupt Controller Basic Programming Model for Power On of IVA2.2 Subsystem: \[3\] \[4\] \[5\]](#)

## IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[6\]](#)
- [WUGEN Register Descriptions: \[7\] \[8\]](#)

**Table 5-499. WUGEN\_MEVT2**

|                         |                                                                                                                                                                           |                         |                 |                 |              |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x068                                                                                                                                                                     | <b>Physical address</b> | 0x01C2 1068     | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>      | This register contains the dma request mask                                                                                                                               |                         |                 |                 |              |
| <b>Type</b>             | R                                                                                                                                                                         |                         |                 |                 |              |
| 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 |                 |              |
| Reserved                | MDMARQ19 MDMARQ18 MDMARQ17 MDMARQ16 MDMARQ15 MDMARQ14 MDMARQ13 MDMARQ12 MDMARQ11 MDMARQ10 MDMARQ9 MDMARQ8 MDMARQ7 MDMARQ6 MDMARQ5 MDMARQ4 MDMARQ3 MDMARQ2 MDMARQ1 MDMARQ0 |                         |                 |                 |              |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------|-------------|--------------|
| 31:20       | Reserved          | Read returns 0.          | R           | 0x000        |
| 19          | MDMARQ19          | DMA request Mask bit #19 | R           | 1            |
| 18          | MDMARQ18          | DMA request Mask bit #18 | R           | 1            |
| 17          | MDMARQ17          | DMA request Mask bit #17 | R           | 1            |
| 16          | MDMARQ16          | DMA request Mask bit #16 | R           | 1            |
| 15          | MDMARQ15          | DMA request Mask bit #15 | R           | 1            |
| 14          | MDMARQ14          | DMA request Mask bit #14 | R           | 1            |
| 13          | MDMARQ13          | DMA request Mask bit #13 | R           | 1            |
| 12          | MDMARQ12          | DMA request Mask bit #12 | R           | 1            |
| 11          | MDMARQ11          | DMA request Mask bit #11 | R           | 1            |
| 10          | MDMARQ10          | DMA request Mask bit #10 | R           | 1            |
| 9           | MDMARQ9           | DMA request Mask bit #9  | R           | 1            |
| 8           | MDMARQ8           | DMA request Mask bit #8  | R           | 1            |
| 7           | MDMARQ7           | DMA request Mask bit #7  | R           | 1            |
| 6           | MDMARQ6           | DMA request Mask bit #6  | R           | 1            |
| 5           | MDMARQ5           | DMA request Mask bit #5  | R           | 1            |
| 4           | MDMARQ4           | DMA request Mask bit #4  | R           | 1            |
| 3           | MDMARQ3           | DMA request Mask bit #3  | R           | 1            |
| 2           | MDMARQ2           | DMA request Mask bit #2  | R           | 1            |
| 1           | MDMARQ1           | DMA request Mask bit #1  | R           | 1            |
| 0           | MDMARQ0           | DMA request Mask bit #0  | R           | 1            |

**Table 5-500. Register Call Summary for Register WUGEN\_MEVT2**

## IVA2.2 Subsystem Functional Description

- [Interrupts, DMA Requests, and Event Management: \[0\] \[1\]](#)

## IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[2\]](#)
- [WUGEN Register Descriptions: \[3\] \[4\]](#)

**Table 5-501. WUGEN\_MEVTCLR0**

|                       |                                                                                                                                                                                                       |                         |             |                 |              |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b> | 0x070                                                                                                                                                                                                 | <b>Physical address</b> | 0x01C2 1070 | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>    | This register is used to clear the interrupt mask bits (LSB)<br>Write 0: No effect<br>Write 1: Clears the corresponding mask bit in the <a href="#">WUGEN_MEVTO</a> register<br>Reads always return 0 |                         |             |                 |              |
| <b>Type</b>           | W<br>1toSet                                                                                                                                                                                           |                         |             |                 |              |

| 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        |
|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| MIRQCLR31 | MIRQCLR30 | MIRQCLR29 | MIRQCLR28 | MIRQCLR27 | MIRQCLR26 | MIRQCLR25 | MIRQCLR24 | MIRQCLR23 | MIRQCLR22 | MIRQCLR21 | MIRQCLR20 | MIRQCLR19 | MIRQCLR18 | MIRQCLR17 | MIRQCLR16 | MIRQCLR15 | MIRQCLR14 | MIRQCLR13 | MIRQCLR12 | MIRQCLR11 | MIRQCLR10 | MIRQCLR9 | MIRQCLR8 | MIRQCLR7 | MIRQCLR6 | MIRQCLR5 | MIRQCLR4 | MIRQCLR3 | MIRQCLR2 | MIRQCLR1 | MIRQCLR0 |
|           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          |
|           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          |

| Bits | Field Name | Description    | Type        | Reset |
|------|------------|----------------|-------------|-------|
| 31   | MIRQCLR31  | MIRQ clear #31 | W<br>1toSet | 0     |
| 30   | MIRQCLR30  | MIRQ clear #30 | W<br>1toSet | 0     |
| 29   | MIRQCLR29  | MIRQ clear #29 | W<br>1toSet | 0     |
| 28   | MIRQCLR28  | MIRQ clear #28 | W<br>1toSet | 0     |
| 27   | MIRQCLR27  | MIRQ clear #27 | W<br>1toSet | 0     |
| 26   | MIRQCLR26  | MIRQ clear #26 | W<br>1toSet | 0     |
| 25   | MIRQCLR25  | MIRQ clear #25 | W<br>1toSet | 0     |
| 24   | MIRQCLR24  | MIRQ clear #24 | W<br>1toSet | 0     |
| 23   | MIRQCLR23  | MIRQ clear #23 | W<br>1toSet | 0     |
| 22   | MIRQCLR22  | MIRQ clear #22 | W<br>1toSet | 0     |
| 21   | MIRQCLR21  | MIRQ clear #21 | W<br>1toSet | 0     |
| 20   | MIRQCLR20  | MIRQ clear #20 | W<br>1toSet | 0     |
| 19   | MIRQCLR19  | MIRQ clear #19 | W<br>1toSet | 0     |
| 18   | MIRQCLR18  | MIRQ clear #18 | W<br>1toSet | 0     |
| 17   | MIRQCLR17  | MIRQ clear #17 | W<br>1toSet | 0     |
| 16   | MIRQCLR16  | MIRQ clear #16 | W<br>1toSet | 0     |
| 15   | MIRQCLR15  | MIRQ clear #15 | W<br>1toSet | 0     |
| 14   | MIRQCLR14  | MIRQ clear #14 | W<br>1toSet | 0     |
| 13   | MIRQCLR13  | MIRQ clear #13 | W<br>1toSet | 0     |
| 12   | MIRQCLR12  | MIRQ clear #12 | W<br>1toSet | 0     |

| Bits | Field Name | Description    | Type        | Reset |
|------|------------|----------------|-------------|-------|
| 11   | MIRQCLR11  | MIRQ clear #11 | W<br>1toSet | 0     |
| 10   | MIRQCLR10  | MIRQ clear #10 | W<br>1toSet | 0     |
| 9    | MIRQCLR9   | MIRQ clear #9  | W<br>1toSet | 0     |
| 8    | MIRQCLR8   | MIRQ clear #8  | W<br>1toSet | 0     |
| 7    | MIRQCLR7   | MIRQ clear #7  | W<br>1toSet | 0     |
| 6    | MIRQCLR6   | MIRQ clear #6  | W<br>1toSet | 0     |
| 5    | MIRQCLR5   | MIRQ clear #5  | W<br>1toSet | 0     |
| 4    | MIRQCLR4   | MIRQ clear #4  | W<br>1toSet | 0     |
| 3    | MIRQCLR3   | MIRQ clear #3  | W<br>1toSet | 0     |
| 2    | MIRQCLR2   | MIRQ clear #2  | W<br>1toSet | 0     |
| 1    | MIRQCLR1   | MIRQ clear #1  | W<br>1toSet | 0     |
| 0    | MIRQCLR0   | MIRQ clear #0  | W<br>1toSet | 0     |

**Table 5-502. Register Call Summary for Register WUGEN\_MEVTCLR0**

IVA2.2 Subsystem Integration

- [Interrupt Requests: \[0\]](#)

IVA2.2 Subsystem Functional Description

- [Interrupts, DMA Requests, and Event Management: \[1\] \[2\]](#)

IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[3\]](#)

**Table 5-503. WUGEN\_MEVTCLR1**

|                       |                                                                                                                                                                                                       |                         |             |                 |              |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b> | 0x074                                                                                                                                                                                                 | <b>Physical address</b> | 0x01C2 1074 | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>    | This register is used to clear the interrupt mask bits (MSB)<br>Write 0: No effect<br>Write 1: Clears the corresponding mask bit in the <a href="#">WUGEN_MEVT1</a> register<br>Reads always return 0 |                         |             |                 |              |
| <b>Type</b>           | W<br>1toSet                                                                                                                                                                                           |                         |             |                 |              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| 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         |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MIRQCLR47 | MIRQCLR46 | MIRQCLR45 | MIRQCLR44 | MIRQCLR43 | MIRQCLR42 | MIRQCLR41 | MIRQCLR40 | MIRQCLR39 | MIRQCLR38 | MIRQCLR37 | MIRQCLR36 | MIRQCLR35 | MIRQCLR34 | MIRQCLR33 | MIRQCLR32 |

| Bits  | Field Name | Description                        | Type        | Reset  |
|-------|------------|------------------------------------|-------------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility. | W           | 0x0000 |
| 15    | MIRQCLR47  | MIRQ clear #47                     | W<br>1toSet | 0      |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 14          | MIRQCLR46         | MIRQ clear #46     | W<br>1toSet | 0            |
| 13          | MIRQCLR45         | MIRQ clear #45     | W<br>1toSet | 0            |
| 12          | MIRQCLR44         | MIRQ clear #44     | W<br>1toSet | 0            |
| 11          | MIRQCLR43         | MIRQ clear #43     | W<br>1toSet | 0            |
| 10          | MIRQCLR42         | MIRQ clear #42     | W<br>1toSet | 0            |
| 9           | MIRQCLR41         | MIRQ clear #41     | W<br>1toSet | 0            |
| 8           | MIRQCLR40         | MIRQ clear #40     | W<br>1toSet | 0            |
| 7           | MIRQCLR39         | MIRQ clear #39     | W<br>1toSet | 0            |
| 6           | MIRQCLR38         | MIRQ clear #38     | W<br>1toSet | 0            |
| 5           | MIRQCLR37         | MIRQ clear #37     | W<br>1toSet | 0            |
| 4           | MIRQCLR36         | MIRQ clear #36     | W<br>1toSet | 0            |
| 3           | MIRQCLR35         | MIRQ clear #35     | W<br>1toSet | 0            |
| 2           | MIRQCLR34         | MIRQ clear #34     | W<br>1toSet | 0            |
| 1           | MIRQCLR33         | MIRQ clear #33     | W<br>1toSet | 0            |
| 0           | MIRQCLR32         | MIRQ clear #32     | W<br>1toSet | 0            |

**Table 5-504. Register Call Summary for Register WUGEN\_MEVTCLR1**

IVA2.2 Subsystem Integration

- [Interrupt Requests: \[0\]](#)

IVA2.2 Subsystem Functional Description

- [Interrupts, DMA Requests, and Event Management: \[1\] \[2\]](#)

IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[3\]](#)

**Table 5-505. WUGEN\_MEVTCLR2**

|                       |                                                                                                                                                                                                   |                         |             |                 |              |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b> | 0x078                                                                                                                                                                                             | <b>Physical address</b> | 0x01C2 1078 | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>    | This register is used to clear the dma request mask bits<br>Write 0: No effect<br>Write 1: Clears the corresponding mask bit in the <a href="#">WUGEN_MEVT2</a> register<br>Reads always return 0 |                         |             |                 |              |
| <b>Type</b>           | W<br>1toSet                                                                                                                                                                                       |                         |             |                 |              |

| 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 |
|----------|----|----|----|----|----|----|----|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|---|---|---|---|
| Reserved |    |    |    |    |    |    |    | MDMARQCLR19 | MDMARQCLR18 | MDMARQCLR17 | MDMARQCLR16 | MDMARQCLR15 | MDMARQCLR14 | MDMARQCLR13 | MDMARQCLR12 | MDMARQCLR11 | MDMARQCLR10 | MDMARQCLR9 | MDMARQCLR8 | MDMARQCLR7 | MDMARQCLR6 | MDMARQCLR5 | MDMARQCLR4 | MDMARQCLR3 | MDMARQCLR2 | MDMARQCLR1 | MDMARQCLR0 |   |   |   |   |

| Bits  | Field Name  | Description                        | Type        | Reset |
|-------|-------------|------------------------------------|-------------|-------|
| 31:20 | Reserved    | Write 0s for future compatibility. | W           | 0x000 |
| 19    | MDMARQCLR19 | MDMARQ clear #19                   | W<br>1toSet | 0     |
| 18    | MDMARQCLR18 | MDMARQ clear #18                   | W<br>1toSet | 0     |
| 17    | MDMARQCLR17 | MDMARQ clear #17                   | W<br>1toSet | 0     |
| 16    | MDMARQCLR16 | MDMARQ clear #16                   | W<br>1toSet | 0     |
| 15    | MDMARQCLR15 | MDMARQ clear #15                   | W<br>1toSet | 0     |
| 14    | MDMARQCLR14 | MDMARQ clear #14                   | W<br>1toSet | 0     |
| 13    | MDMARQCLR13 | MDMARQ clear #13                   | W<br>1toSet | 0     |
| 12    | MDMARQCLR12 | MDMARQ clear #12                   | W<br>1toSet | 0     |
| 11    | MDMARQCLR11 | MDMARQ clear #11                   | W<br>1toSet | 0     |
| 10    | MDMARQCLR10 | MDMARQ clear #10                   | W<br>1toSet | 0     |
| 9     | MDMARQCLR9  | MDMARQ clear #9                    | W<br>1toSet | 0     |
| 8     | MDMARQCLR8  | MDMARQ clear #8                    | W<br>1toSet | 0     |
| 7     | MDMARQCLR7  | MDMARQ clear #7                    | W<br>1toSet | 0     |
| 6     | MDMARQCLR6  | MDMARQ clear #6                    | W<br>1toSet | 0     |
| 5     | MDMARQCLR5  | MDMARQ clear #5                    | W<br>1toSet | 0     |
| 4     | MDMARQCLR4  | MDMARQ clear #4                    | W<br>1toSet | 0     |
| 3     | MDMARQCLR3  | MDMARQ clear #3                    | W<br>1toSet | 0     |
| 2     | MDMARQCLR2  | MDMARQ clear #2                    | W<br>1toSet | 0     |
| 1     | MDMARQCLR1  | MDMARQ clear #1                    | W<br>1toSet | 0     |
| 0     | MDMARQCLR0  | MDMARQ clear #0                    | W<br>1toSet | 0     |

**Table 5-506. Register Call Summary for Register WUGEN\_MEVTCLR2**

IVA2.2 Subsystem Functional Description

- [Interrupts, DMA Requests, and Event Management: \[0\] \[1\]](#)

IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[2\]](#)

**Table 5-507. WUGEN\_MEVTSET0**

|                       |                                                                                                                                                                                                   |                         |             |                 |              |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b> | 0x080                                                                                                                                                                                             | <b>Physical address</b> | 0x01C2 1080 | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>    | This register is used to set the interrupt mask bits (LSB)<br>Write 0: No effect<br>Write 1: Sets the corresponding mask bit in the <a href="#">WUGEN_MEVT0</a> register<br>Reads always return 0 |                         |             |                 |              |
| <b>Type</b>           | W<br>1toSet                                                                                                                                                                                       |                         |             |                 |              |

| 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        |
|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| MIRQSET31 | MIRQSET30 | MIRQSET29 | MIRQSET28 | MIRQSET27 | MIRQSET26 | MIRQSET25 | MIRQSET24 | MIRQSET23 | MIRQSET22 | MIRQSET21 | MIRQSET20 | MIRQSET19 | MIRQSET18 | MIRQSET17 | MIRQSET16 | MIRQSET15 | MIRQSET14 | MIRQSET13 | MIRQSET12 | MIRQSET11 | MIRQSET10 | MIRQSET9 | MIRQSET8 | MIRQSET7 | MIRQSET6 | MIRQSET5 | MIRQSET4 | MIRQSET3 | MIRQSET2 | MIRQSET1 | MIRQSET0 |
|           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          |
|           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          |

| Bits | Field Name | Description  | Type        | Reset |
|------|------------|--------------|-------------|-------|
| 31   | MIRQSET31  | MIRQ set #31 | W<br>1toSet | 0     |
| 30   | MIRQSET30  | MIRQ set #30 | W<br>1toSet | 0     |
| 29   | MIRQSET29  | MIRQ set #29 | W<br>1toSet | 0     |
| 28   | MIRQSET28  | MIRQ set #28 | W<br>1toSet | 0     |
| 27   | MIRQSET27  | MIRQ set #27 | W<br>1toSet | 0     |
| 26   | MIRQSET26  | MIRQ set #26 | W<br>1toSet | 0     |
| 25   | MIRQSET25  | MIRQ set #25 | W<br>1toSet | 0     |
| 24   | MIRQSET24  | MIRQ set #24 | W<br>1toSet | 0     |
| 23   | MIRQSET23  | MIRQ set #23 | W<br>1toSet | 0     |
| 22   | MIRQSET22  | MIRQ set #22 | W<br>1toSet | 0     |
| 21   | MIRQSET21  | MIRQ set #21 | W<br>1toSet | 0     |
| 20   | MIRQSET20  | MIRQ set #20 | W<br>1toSet | 0     |
| 19   | MIRQSET19  | MIRQ set #19 | W<br>1toSet | 0     |
| 18   | MIRQSET18  | MIRQ set #18 | W<br>1toSet | 0     |
| 17   | MIRQSET17  | MIRQ set #17 | W<br>1toSet | 0     |
| 16   | MIRQSET16  | MIRQ set #16 | W<br>1toSet | 0     |
| 15   | MIRQSET15  | MIRQ set #15 | W<br>1toSet | 0     |
| 14   | MIRQSET14  | MIRQ set #14 | W<br>1toSet | 0     |
| 13   | MIRQSET13  | MIRQ set #13 | W<br>1toSet | 0     |
| 12   | MIRQSET12  | MIRQ set #12 | W<br>1toSet | 0     |

| Bits | Field Name | Description  | Type        | Reset |
|------|------------|--------------|-------------|-------|
| 11   | MIRQSET11  | MIRQ set #11 | W<br>1toSet | 0     |
| 10   | MIRQSET10  | MIRQ set #10 | W<br>1toSet | 0     |
| 9    | MIRQSET9   | MIRQ set #9  | W<br>1toSet | 0     |
| 8    | MIRQSET8   | MIRQ set #8  | W<br>1toSet | 0     |
| 7    | MIRQSET7   | MIRQ set #7  | W<br>1toSet | 0     |
| 6    | MIRQSET6   | MIRQ set #6  | W<br>1toSet | 0     |
| 5    | MIRQSET5   | MIRQ set #5  | W<br>1toSet | 0     |
| 4    | MIRQSET4   | MIRQ set #4  | W<br>1toSet | 0     |
| 3    | MIRQSET3   | MIRQ set #3  | W<br>1toSet | 0     |
| 2    | MIRQSET2   | MIRQ set #2  | W<br>1toSet | 0     |
| 1    | MIRQSET1   | MIRQ set #1  | W<br>1toSet | 0     |
| 0    | MIRQSET0   | MIRQ set #0  | W<br>1toSet | 0     |

**Table 5-508. Register Call Summary for Register WUGEN\_MEVTSET0**

IVA2.2 Subsystem Integration

- [Interrupt Requests: \[0\]](#)

IVA2.2 Subsystem Functional Description

- [Interrupts, DMA Requests, and Event Management: \[1\] \[2\]](#)

IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[3\]](#)

**Table 5-509. WUGEN\_MEVTSET1**

|                       |                                                                                                                                                                                                   |                         |             |                 |              |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b> | 0x084                                                                                                                                                                                             | <b>Physical address</b> | 0x01C2 1084 | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>    | This register is used to set the interrupt mask bits (MSB)<br>Write 0: No effect<br>Write 1: Sets the corresponding mask bit in the <a href="#">WUGEN_MEVT1</a> register<br>Reads always return 0 |                         |             |                 |              |
| <b>Type</b>           | W<br>1toSet                                                                                                                                                                                       |                         |             |                 |              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| 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         |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MIRQSET47 | MIRQSET46 | MIRQSET45 | MIRQSET44 | MIRQSET43 | MIRQSET42 | MIRQSET41 | MIRQSET40 | MIRQSET39 | MIRQSET38 | MIRQSET37 | MIRQSET36 | MIRQSET35 | MIRQSET34 | MIRQSET33 | MIRQSET32 |

| Bits  | Field Name | Description                        | Type        | Reset  |
|-------|------------|------------------------------------|-------------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility. | W           | 0x0000 |
| 15    | MIRQSET47  | MIRQ set #47                       | W<br>1toSet | 0      |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 14          | MIRQSET46         | MIRQ set #46       | W<br>1toSet | 0            |
| 13          | MIRQSET45         | MIRQ set #45       | W<br>1toSet | 0            |
| 12          | MIRQSET44         | MIRQ set #44       | W<br>1toSet | 0            |
| 11          | MIRQSET43         | MIRQ set #43       | W<br>1toSet | 0            |
| 10          | MIRQSET42         | MIRQ set #42       | W<br>1toSet | 0            |
| 9           | MIRQSET41         | MIRQ set #41       | W<br>1toSet | 0            |
| 8           | MIRQSET40         | MIRQ set #40       | W<br>1toSet | 0            |
| 7           | MIRQSET39         | MIRQ set #39       | W<br>1toSet | 0            |
| 6           | MIRQSET38         | MIRQ set #38       | W<br>1toSet | 0            |
| 5           | MIRQSET37         | MIRQ set #37       | W<br>1toSet | 0            |
| 4           | MIRQSET36         | MIRQ set #36       | W<br>1toSet | 0            |
| 3           | MIRQSET35         | MIRQ set #35       | W<br>1toSet | 0            |
| 2           | MIRQSET34         | MIRQ set #34       | W<br>1toSet | 0            |
| 1           | MIRQSET33         | MIRQ set #33       | W<br>1toSet | 0            |
| 0           | MIRQSET32         | MIRQ set #32       | W<br>1toSet | 0            |

**Table 5-510. Register Call Summary for Register WUGEN\_MEVTSET1**

IVA2.2 Subsystem Integration

- [Interrupt Requests: \[0\]](#)

IVA2.2 Subsystem Functional Description

- [Interrupts, DMA Requests, and Event Management: \[1\] \[2\]](#)

IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[3\]](#)

**Table 5-511. WUGEN\_MEVTSET2**

|                       |                                                                                                                                                                                                |                         |             |                 |              |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b> | 0x088                                                                                                                                                                                          | <b>Physical address</b> | 0x01C2 1088 | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>    | This register is used to set the dma requests mask bits<br>Write 0: No effect<br>Write 1: Sets the corresponding mask bit in the <a href="#">WUGEN_MEVT2</a> register<br>Reads always return 0 |                         |             |                 |              |
| <b>Type</b>           | W<br>1toSet                                                                                                                                                                                    |                         |             |                 |              |

| 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 |
|----------|----|----|----|----|----|----|----|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|---|---|---|---|
| Reserved |    |    |    |    |    |    |    | MDMARQSET19 | MDMARQSET18 | MDMARQSET17 | MDMARQSET16 | MDMARQSET15 | MDMARQSET14 | MDMARQSET13 | MDMARQSET12 | MDMARQSET11 | MDMARQSET10 | MDMARQSET9 | MDMARQSET8 | MDMARQSET7 | MDMARQSET6 | MDMARQSET5 | MDMARQSET4 | MDMARQSET3 | MDMARQSET2 | MDMARQSET1 | MDMARQSET0 |   |   |   |   |

  

| Bits  | Field Name  | Description                        | Type        | Reset |
|-------|-------------|------------------------------------|-------------|-------|
| 31:20 | Reserved    | Write 0s for future compatibility. | W           | 0x000 |
| 19    | MDMARQSET19 | MDMARQ set #19                     | W<br>1toSet | 0     |
| 18    | MDMARQSET18 | MDMARQ set #18                     | W<br>1toSet | 0     |
| 17    | MDMARQSET17 | MDMARQ set #17                     | W<br>1toSet | 0     |
| 16    | MDMARQSET16 | MDMARQ set #16                     | W<br>1toSet | 0     |
| 15    | MDMARQSET15 | MDMARQ set #15                     | W<br>1toSet | 0     |
| 14    | MDMARQSET14 | MDMARQ set #14                     | W<br>1toSet | 0     |
| 13    | MDMARQSET13 | MDMARQ set #13                     | W<br>1toSet | 0     |
| 12    | MDMARQSET12 | MDMARQ set #12                     | W<br>1toSet | 0     |
| 11    | MDMARQSET11 | MDMARQ set #11                     | W<br>1toSet | 0     |
| 10    | MDMARQSET10 | MDMARQ set #10                     | W<br>1toSet | 0     |
| 9     | MDMARQSET9  | MDMARQ set #9                      | W<br>1toSet | 0     |
| 8     | MDMARQSET8  | MDMARQ set #8                      | W<br>1toSet | 0     |
| 7     | MDMARQSET7  | MDMARQ set #7                      | W<br>1toSet | 0     |
| 6     | MDMARQSET6  | MDMARQ set #6                      | W<br>1toSet | 0     |
| 5     | MDMARQSET5  | MDMARQ set #5                      | W<br>1toSet | 0     |
| 4     | MDMARQSET4  | MDMARQ set #4                      | W<br>1toSet | 0     |
| 3     | MDMARQSET3  | MDMARQ set #3                      | W<br>1toSet | 0     |
| 2     | MDMARQSET2  | MDMARQ set #2                      | W<br>1toSet | 0     |
| 1     | MDMARQSET1  | MDMARQ set #1                      | W<br>1toSet | 0     |
| 0     | MDMARQSET0  | MDMARQ set #0                      | W<br>1toSet | 0     |

**Table 5-512. Register Call Summary for Register WUGEN\_MEVTSET2**

## IVA2.2 Subsystem Functional Description

- [Interrupts, DMA Requests, and Event Management: \[0\]](#) [\[1\]](#)

## IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[2\]](#)

**Table 5-513. WUGEN\_PENDEVTO**

|                         |                                                         |
|-------------------------|---------------------------------------------------------|
| <b>Address Offset</b>   | 0x090                                                   |
| <b>Physical address</b> | 0x01C2 1090                                             |
| <b>Instance</b>         | IVA2.2 WUGEN                                            |
| <b>Description</b>      | This register holds the masked pending interrupts (LSB) |
| <b>Type</b>             | R                                                       |

  

|           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          |
|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| 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        |
| PENDIRQ31 | PENDIRQ30 | PENDIRQ29 | PENDIRQ28 | PENDIRQ27 | PENDIRQ26 | PENDIRQ25 | PENDIRQ24 | PENDIRQ23 | PENDIRQ22 | PENDIRQ21 | PENDIRQ20 | PENDIRQ19 | PENDIRQ18 | PENDIRQ17 | PENDIRQ16 | PENDIRQ15 | PENDIRQ14 | PENDIRQ13 | PENDIRQ12 | PENDIRQ11 | PENDIRQ10 | PENDIRQ9 | PENDIRQ8 | PENDIRQ7 | PENDIRQ6 | PENDIRQ5 | PENDIRQ4 | PENDIRQ3 | PENDIRQ2 | PENDIRQ1 | PENDIRQ0 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------|-------------|--------------|
| 31          | PENDIRQ31         | Masked pending interrupt number 31 | R           | 0            |
| 30          | PENDIRQ30         | Masked pending interrupt number 30 | R           | 0            |
| 29          | PENDIRQ29         | Masked pending interrupt number 29 | R           | 0            |
| 28          | PENDIRQ28         | Masked pending interrupt number 28 | R           | 0            |
| 27          | PENDIRQ27         | Masked pending interrupt number 27 | R           | 0            |
| 26          | PENDIRQ26         | Masked pending interrupt number 26 | R           | 0            |
| 25          | PENDIRQ25         | Masked pending interrupt number 25 | R           | 0            |
| 24          | PENDIRQ24         | Masked pending interrupt number 24 | R           | 0            |
| 23          | PENDIRQ23         | Masked pending interrupt number 23 | R           | 0            |
| 22          | PENDIRQ22         | Masked pending interrupt number 22 | R           | 0            |
| 21          | PENDIRQ21         | Masked pending interrupt number 21 | R           | 0            |
| 20          | PENDIRQ20         | Masked pending interrupt number 20 | R           | 0            |
| 19          | PENDIRQ19         | Masked pending interrupt number 19 | R           | 0            |
| 18          | PENDIRQ18         | Masked pending interrupt number 18 | R           | 0            |
| 17          | PENDIRQ17         | Masked pending interrupt number 17 | R           | 0            |
| 16          | PENDIRQ16         | Masked pending interrupt number 16 | R           | 0            |
| 15          | PENDIRQ15         | Masked pending interrupt number 15 | R           | 0            |
| 14          | PENDIRQ14         | Masked pending interrupt number 14 | R           | 0            |
| 13          | PENDIRQ13         | Masked pending interrupt number 13 | R           | 0            |
| 12          | PENDIRQ12         | Masked pending interrupt number 12 | R           | 0            |
| 11          | PENDIRQ11         | Masked pending interrupt number 11 | R           | 0            |
| 10          | PENDIRQ10         | Masked pending interrupt number 10 | R           | 0            |
| 9           | PENDIRQ9          | Masked pending interrupt number 9  | R           | 0            |
| 8           | PENDIRQ8          | Masked pending interrupt number 8  | R           | 0            |
| 7           | PENDIRQ7          | Masked pending interrupt number 7  | R           | 0            |
| 6           | PENDIRQ6          | Masked pending interrupt number 6  | R           | 0            |
| 5           | PENDIRQ5          | Masked pending interrupt number 5  | R           | 0            |
| 4           | PENDIRQ4          | Masked pending interrupt number 4  | R           | 0            |
| 3           | PENDIRQ3          | Masked pending interrupt number 3  | R           | 0            |
| 2           | PENDIRQ2          | Masked pending interrupt number 2  | R           | 0            |
| 1           | PENDIRQ1          | Masked pending interrupt number 1  | R           | 0            |
| 0           | PENDIRQ0          | Masked pending interrupt number 0  | R           | 0            |

**Table 5-514. Register Call Summary for Register WUGEN\_PENDEVT0**

## IVA2.2 Subsystem Functional Description

- [Interrupts, DMA Requests, and Event Management: \[0\]](#)

## IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[1\]](#)
- [WUGEN Register Descriptions: \[2\]](#)

**Table 5-515. WUGEN\_PENDEVT1**

|                       |                                                         |                         |             |                 |              |
|-----------------------|---------------------------------------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b> | 0x094                                                   | <b>Physical address</b> | 0x01C2 1094 | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>    | This register holds the masked pending interrupts (MSB) |                         |             |                 |              |
| <b>Type</b>           | R                                                       |                         |             |                 |              |

| 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         |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PENDIRQ47 | PENDIRQ46 | PENDIRQ45 | PENDIRQ44 | PENDIRQ43 | PENDIRQ42 | PENDIRQ41 | PENDIRQ40 | PENDIRQ39 | PENDIRQ38 | PENDIRQ37 | PENDIRQ36 | PENDIRQ35 | PENDIRQ34 | PENDIRQ33 | PENDIRQ32 |

| Bits  | Field Name | Description                        | Type | Reset  |
|-------|------------|------------------------------------|------|--------|
| 31:16 | Reserved   | Read returns 0.                    | R    | 0x0000 |
| 15    | PENDIRQ47  | Masked pending interrupt number 47 | R    | 0      |
| 14    | PENDIRQ46  | Masked pending interrupt number 46 | R    | 0      |
| 13    | PENDIRQ45  | Masked pending interrupt number 45 | R    | 0      |
| 12    | PENDIRQ44  | Masked pending interrupt number 44 | R    | 0      |
| 11    | PENDIRQ43  | Masked pending interrupt number 43 | R    | 0      |
| 10    | PENDIRQ42  | Masked pending interrupt number 42 | R    | 0      |
| 9     | PENDIRQ41  | Masked pending interrupt number 41 | R    | 0      |
| 8     | PENDIRQ40  | Masked pending interrupt number 40 | R    | 0      |
| 7     | PENDIRQ39  | Masked pending interrupt number 39 | R    | 0      |
| 6     | PENDIRQ38  | Masked pending interrupt number 38 | R    | 0      |
| 5     | PENDIRQ37  | Masked pending interrupt number 37 | R    | 0      |
| 4     | PENDIRQ36  | Masked pending interrupt number 36 | R    | 0      |
| 3     | PENDIRQ35  | Masked pending interrupt number 35 | R    | 0      |
| 2     | PENDIRQ34  | Masked pending interrupt number 34 | R    | 0      |
| 1     | PENDIRQ33  | Masked pending interrupt number 33 | R    | 0      |
| 0     | PENDIRQ32  | Masked pending interrupt number 32 | R    | 0      |

**Table 5-516. Register Call Summary for Register WUGEN\_PENDEVT1**

## IVA2.2 Subsystem Functional Description

- [Interrupts, DMA Requests, and Event Management: \[0\]](#)

## IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[1\]](#)
- [WUGEN Register Descriptions: \[2\]](#)

**Table 5-517. WUGEN\_PENDEVT2**

|                       |                                                     |                         |             |                 |              |
|-----------------------|-----------------------------------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b> | 0x098                                               | <b>Physical address</b> | 0x01C2 1098 | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>    | This register holds the masked pending dma requests |                         |             |                 |              |
| <b>Type</b>           | R                                                   |                         |             |                 |              |

| 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          |
|----|----|----|----|----|----|----|----|----|----|----|----|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|
|    |    |    |    |    |    |    |    |    |    |    |    | PENDDMARQ19 | PENDDMARQ18 | PENDDMARQ17 | PENDDMARQ16 | PENDDMARQ15 | PENDDMARQ14 | PENDDMARQ13 | PENDDMARQ12 | PENDDMARQ11 | PENDDMARQ10 | PENDDMARQ9 | PENDDMARQ8 | PENDDMARQ7 | PENDDMARQ6 | PENDDMARQ5 | PENDDMARQ4 | PENDDMARQ3 | PENDDMARQ2 | PENDDMARQ1 | PENDDMARQ0 |

| Bits  | Field Name  | Description                         | Type | Reset |
|-------|-------------|-------------------------------------|------|-------|
| 31:20 | Reserved    | Read returns 0.                     | R    | 0x000 |
| 19    | PENDDMARQ19 | Masked pending dma request number 0 | R    | 0     |
| 18    | PENDDMARQ18 | Masked pending dma request number 0 | R    | 0     |
| 17    | PENDDMARQ17 | Masked pending dma request number 0 | R    | 0     |
| 16    | PENDDMARQ16 | Masked pending dma request number 0 | R    | 0     |
| 15    | PENDDMARQ15 | Masked pending dma request number 0 | R    | 0     |
| 14    | PENDDMARQ14 | Masked pending dma request number 0 | R    | 0     |
| 13    | PENDDMARQ13 | Masked pending dma request number 0 | R    | 0     |
| 12    | PENDDMARQ12 | Masked pending dma request number 0 | R    | 0     |
| 11    | PENDDMARQ11 | Masked pending dma request number 0 | R    | 0     |
| 10    | PENDDMARQ10 | Masked pending dma request number 0 | R    | 0     |
| 9     | PENDDMARQ9  | Masked pending dma request number 0 | R    | 0     |
| 8     | PENDDMARQ8  | Masked pending dma request number 0 | R    | 0     |
| 7     | PENDDMARQ7  | Masked pending dma request number 0 | R    | 0     |
| 6     | PENDDMARQ6  | Masked pending dma request number 0 | R    | 0     |
| 5     | PENDDMARQ5  | Masked pending dma request number 0 | R    | 0     |
| 4     | PENDDMARQ4  | Masked pending dma request number 0 | R    | 0     |
| 3     | PENDDMARQ3  | Masked pending dma request number 0 | R    | 0     |
| 2     | PENDDMARQ2  | Masked pending dma request number 0 | R    | 0     |
| 1     | PENDDMARQ1  | Masked pending dma request number 0 | R    | 0     |
| 0     | PENDDMARQ0  | Masked pending dma request number 0 | R    | 0     |

**Table 5-518. Register Call Summary for Register WUGEN\_PENDEVT2**

IVA2.2 Subsystem Functional Description

- [Interrupts, DMA Requests, and Event Management: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[1\]](#)
- [WUGEN Register Descriptions: \[2\]](#)

**Table 5-519. WUGEN\_PENDEVTCCLR0**

|                         |                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x100                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x01C2 1100                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register clears the masked pending interrupts (LSB):<br>Write 0: No effect<br>Write 1: Clears the corresponding mask bit in the <a href="#">WUGEN_PENDEVTO</a> register<br>Reads always return 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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        |
|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| PENDIRQ31 | PENDIRQ30 | PENDIRQ29 | PENDIRQ28 | PENDIRQ27 | PENDIRQ26 | PENDIRQ25 | PENDIRQ24 | PENDIRQ23 | PENDIRQ22 | PENDIRQ21 | PENDIRQ20 | PENDIRQ19 | PENDIRQ18 | PENDIRQ17 | PENDIRQ16 | PENDIRQ15 | PENDIRQ14 | PENDIRQ13 | PENDIRQ12 | PENDIRQ11 | PENDIRQ10 | PENDIRQ9 | PENDIRQ8 | PENDIRQ7 | PENDIRQ6 | PENDIRQ5 | PENDIRQ4 | PENDIRQ3 | PENDIRQ2 | PENDIRQ1 | PENDIRQ0 |
|           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          |
|           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          |
|           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          |

| Bits | Field Name | Description                        | Type | Reset |
|------|------------|------------------------------------|------|-------|
| 31   | PENDIRQ31  | Masked pending interrupt number 31 | W    | 0     |
| 30   | PENDIRQ30  | Masked pending interrupt number 30 | W    | 0     |
| 29   | PENDIRQ29  | Masked pending interrupt number 29 | W    | 0     |
| 28   | PENDIRQ28  | Masked pending interrupt number 28 | W    | 0     |
| 27   | PENDIRQ27  | Masked pending interrupt number 27 | W    | 0     |
| 26   | PENDIRQ26  | Masked pending interrupt number 26 | W    | 0     |
| 25   | PENDIRQ25  | Masked pending interrupt number 25 | W    | 0     |
| 24   | PENDIRQ24  | Masked pending interrupt number 24 | W    | 0     |
| 23   | PENDIRQ23  | Masked pending interrupt number 23 | W    | 0     |
| 22   | PENDIRQ22  | Masked pending interrupt number 22 | W    | 0     |
| 21   | PENDIRQ21  | Masked pending interrupt number 21 | W    | 0     |
| 20   | PENDIRQ20  | Masked pending interrupt number 20 | W    | 0     |
| 19   | PENDIRQ19  | Masked pending interrupt number 19 | W    | 0     |
| 18   | PENDIRQ18  | Masked pending interrupt number 18 | W    | 0     |
| 17   | PENDIRQ17  | Masked pending interrupt number 17 | W    | 0     |
| 16   | PENDIRQ16  | Masked pending interrupt number 16 | W    | 0     |
| 15   | PENDIRQ15  | Masked pending interrupt number 15 | W    | 0     |
| 14   | PENDIRQ14  | Masked pending interrupt number 14 | W    | 0     |
| 13   | PENDIRQ13  | Masked pending interrupt number 13 | W    | 0     |
| 12   | PENDIRQ12  | Masked pending interrupt number 12 | W    | 0     |
| 11   | PENDIRQ11  | Masked pending interrupt number 11 | W    | 0     |
| 10   | PENDIRQ10  | Masked pending interrupt number 10 | W    | 0     |
| 9    | PENDIRQ9   | Masked pending interrupt number 9  | W    | 0     |
| 8    | PENDIRQ8   | Masked pending interrupt number 8  | W    | 0     |
| 7    | PENDIRQ7   | Masked pending interrupt number 7  | W    | 0     |
| 6    | PENDIRQ6   | Masked pending interrupt number 6  | W    | 0     |
| 5    | PENDIRQ5   | Masked pending interrupt number 5  | W    | 0     |
| 4    | PENDIRQ4   | Masked pending interrupt number 4  | W    | 0     |
| 3    | PENDIRQ3   | Masked pending interrupt number 3  | W    | 0     |
| 2    | PENDIRQ2   | Masked pending interrupt number 2  | W    | 0     |
| 1    | PENDIRQ1   | Masked pending interrupt number 1  | W    | 0     |
| 0    | PENDIRQ0   | Masked pending interrupt number 0  | W    | 0     |

**Table 5-520. Register Call Summary for Register WUGEN\_PENDEVTCLR0**

IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[0\]](#)

**Table 5-521. WUGEN\_PENDEVTCLR1**

|                       |                                                                                                                                                                                                        |                         |             |                 |              |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|--------------|
| <b>Address Offset</b> | 0x104                                                                                                                                                                                                  | <b>Physical address</b> | 0x01C2 1104 | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>    | This register clears the masked pending interrupts (MSB) :<br>Write 0: No effect<br>Write 1: Clears the corresponding mask bit in the <a href="#">WUGEN_PENDEVT1</a> register<br>Reads always return 0 |                         |             |                 |              |
| <b>Type</b>           | W                                                                                                                                                                                                      |                         |             |                 |              |
| 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                                                                                                                                                                                                      | PENDIRQ47               | PENDIRQ46   | PENDIRQ45       | PENDIRQ44    |
|                       |                                                                                                                                                                                                        | PENDIRQ43               | PENDIRQ42   | PENDIRQ41       | PENDIRQ40    |
|                       |                                                                                                                                                                                                        | PENDIRQ39               | PENDIRQ38   | PENDIRQ37       | PENDIRQ36    |
|                       |                                                                                                                                                                                                        | PENDIRQ35               | PENDIRQ34   | PENDIRQ33       | PENDIRQ32    |

Reserved

| Bits  | Field Name | Description                        | Type | Reset  |
|-------|------------|------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility. | W    | 0x0000 |
| 15    | PENDIRQ47  | Masked pending interrupt number 47 | W    | 0      |
| 14    | PENDIRQ46  | Masked pending interrupt number 46 | W    | 0      |
| 13    | PENDIRQ45  | Masked pending interrupt number 45 | W    | 0      |
| 12    | PENDIRQ44  | Masked pending interrupt number 44 | W    | 0      |
| 11    | PENDIRQ43  | Masked pending interrupt number 43 | W    | 0      |
| 10    | PENDIRQ42  | Masked pending interrupt number 42 | W    | 0      |
| 9     | PENDIRQ41  | Masked pending interrupt number 41 | W    | 0      |
| 8     | PENDIRQ40  | Masked pending interrupt number 40 | W    | 0      |
| 7     | PENDIRQ39  | Masked pending interrupt number 39 | W    | 0      |
| 6     | PENDIRQ38  | Masked pending interrupt number 38 | W    | 0      |
| 5     | PENDIRQ37  | Masked pending interrupt number 37 | W    | 0      |
| 4     | PENDIRQ36  | Masked pending interrupt number 36 | W    | 0      |
| 3     | PENDIRQ35  | Masked pending interrupt number 35 | W    | 0      |
| 2     | PENDIRQ34  | Masked pending interrupt number 34 | W    | 0      |
| 1     | PENDIRQ33  | Masked pending interrupt number 33 | W    | 0      |
| 0     | PENDIRQ32  | Masked pending interrupt number 32 | W    | 0      |

**Table 5-522. Register Call Summary for Register WUGEN\_PENDEVTCLR1**

IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[0\]](#)

**Table 5-523. WUGEN\_PENDEVTCLR2**

|                         |                                                                                                                                                                                                   |                 |              |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x108                                                                                                                                                                                             |                 |              |
| <b>Physical address</b> | 0x01C2 1108                                                                                                                                                                                       | <b>Instance</b> | IVA2.2 WUGEN |
| <b>Description</b>      | This register clears the masked pending dma_requests:<br>Write 0: No effect<br>Write 1: Clears the corresponding mask bit in the <a href="#">WUGEN_PENDEVT2</a> register<br>Reads always return 0 |                 |              |
| <b>Type</b>             | W                                                                                                                                                                                                 |                 |              |

| 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 |
|----------|----|----|----|----|----|----|----|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|---|---|---|---|
| Reserved |    |    |    |    |    |    |    | PENDDMARQ19 | PENDDMARQ18 | PENDDMARQ17 | PENDDMARQ16 | PENDDMARQ15 | PENDDMARQ14 | PENDDMARQ13 | PENDDMARQ12 | PENDDMARQ11 | PENDDMARQ10 | PENDDMARQ9 | PENDDMARQ8 | PENDDMARQ7 | PENDDMARQ6 | PENDDMARQ5 | PENDDMARQ4 | PENDDMARQ3 | PENDDMARQ2 | PENDDMARQ1 | PENDDMARQ0 |   |   |   |   |

| Bits  | Field Name  | Description                         | Type | Reset |
|-------|-------------|-------------------------------------|------|-------|
| 31:20 | Reserved    | Write 0s for future compatibility.  | W    | 0x000 |
| 19    | PENDDMARQ19 | Masked pending dma request number 0 | W    | 0     |
| 18    | PENDDMARQ18 | Masked pending dma request number 0 | W    | 0     |
| 17    | PENDDMARQ17 | Masked pending dma request number 0 | W    | 0     |
| 16    | PENDDMARQ16 | Masked pending dma request number 0 | W    | 0     |
| 15    | PENDDMARQ15 | Masked pending dma request number 0 | W    | 0     |
| 14    | PENDDMARQ14 | Masked pending dma request number 0 | W    | 0     |
| 13    | PENDDMARQ13 | Masked pending dma request number 0 | W    | 0     |
| 12    | PENDDMARQ12 | Masked pending dma request number 0 | W    | 0     |
| 11    | PENDDMARQ11 | Masked pending dma request number 0 | W    | 0     |
| 10    | PENDDMARQ10 | Masked pending dma request number 0 | W    | 0     |
| 9     | PENDDMARQ9  | Masked pending dma request number 0 | W    | 0     |
| 8     | PENDDMARQ8  | Masked pending dma request number 0 | W    | 0     |
| 7     | PENDDMARQ7  | Masked pending dma request number 0 | W    | 0     |
| 6     | PENDDMARQ6  | Masked pending dma request number 0 | W    | 0     |
| 5     | PENDDMARQ5  | Masked pending dma request number 0 | W    | 0     |
| 4     | PENDDMARQ4  | Masked pending dma request number 0 | W    | 0     |
| 3     | PENDDMARQ3  | Masked pending dma request number 0 | W    | 0     |
| 2     | PENDDMARQ2  | Masked pending dma request number 0 | W    | 0     |
| 1     | PENDDMARQ1  | Masked pending dma request number 0 | W    | 0     |
| 0     | PENDDMARQ0  | Masked pending dma request number 0 | W    | 0     |

**Table 5-524. Register Call Summary for Register WUGEN\_PENDEVTCLR2**

IVA2.2 Subsystem Register Manual

- [WUGEN Register Mapping Summary: \[0\]](#)

## 5.5.9 iVLCD Registers

This section provides information about the iVLCD Module. Each register in the module is described separately below.

### 5.5.9.1 iVLCD Register Mapping Summary

**Table 5-525. iVLCD Register Mapping Summary**

| Register Name                     | Type | Register Width (Bits) | Address Offset        | Physical Address      |
|-----------------------------------|------|-----------------------|-----------------------|-----------------------|
| IVLCD_REVISION                    | R    | 32                    | 0x0000 0000           | 0x0008 0000           |
| IVLCD_SYS CONFIG                  | RW   | 32                    | 0x0000 0010           | 0x0008 0010           |
| IVLCD_SYS STATUS                  | R    | 32                    | 0x0000 0014           | 0x0008 0014           |
| IVLCD_CPUTATUSREG                 | R    | 32                    | 0x0000 0AE8           | 0x0008 0AE8           |
| IVLCD_CONFIGREG                   | RW   | 32                    | 0x0000 0AF4           | 0x0008 0AF4           |
| IVLCD_COMMAND                     | RW   | 32                    | 0x0000 OFFC           | 0x0008 OFFC           |
| VLCD_START                        | RW   | 32                    | 0x0000 1000           | 0x0008 1000           |
| VLCD_MODE                         | RW   | 32                    | 0x0000 1004           | 0x0008 1004           |
| VLCD_QIN_ADDR                     | RW   | 32                    | 0x0000 1008           | 0x0008 1008           |
| VLCD_QOUT_ADDR                    | RW   | 32                    | 0x0000 100C           | 0x0008 100C           |
| VLCD_IQIN_ADDR                    | RW   | 32                    | 0x0000 1010           | 0x0008 1010           |
| VLCD_IQOUT_ADDR                   | RW   | 32                    | 0x0000 1014           | 0x0008 1014           |
| VLCD_VLCDIN_ADDR                  | RW   | 32                    | 0x0000 1018           | 0x0008 1018           |
| VLCD_VLCDOUT_ADDR                 | RW   | 32                    | 0x0000 101C           | 0x0008 101C           |
| VLCD_DC_PREDj <sup>(1)</sup>      | RW   | 32                    | 0x0000 1020 + (0x4*j) | 0x0008 1020 + (0x4*j) |
| VLCD_IDC_PREDj <sup>(1)</sup>     | RW   | 32                    | 0x0000 1038 + (0x4*j) | 0x0008 1038 + (0x4*j) |
| VLCD_MPEG_INVQ                    | RW   | 32                    | 0x0000 1050           | 0x0008 1050           |
| VLCD_MPEG_Q                       | RW   | 32                    | 0x0000 1054           | 0x0008 1054           |
| VLCD_MPEG_DELTA_Q                 | RW   | 32                    | 0x0000 1058           | 0x0008 1058           |
| VLCD_MPEG_DELTA_IQ                | RW   | 32                    | 0x0000 105C           | 0x0008 105C           |
| VLCD_MPEG_THRED                   | RW   | 32                    | 0x0000 1060           | 0x0008 1060           |
| VLCD_MPEG_CB_P                    | RW   | 32                    | 0x0000 1064           | 0x0008 1064           |
| VLCD_LUMA_VECTOR                  | RW   | 32                    | 0x0000 1068           | 0x0008 1068           |
| VLCD_HUFFTAB_DCY                  | RW   | 32                    | 0x0000 106C           | 0x0008 106C           |
| VLCD_HUFFTAB_DCUV                 | RW   | 32                    | 0x0000 1070           | 0x0008 1070           |
| VLCD_HUFFTAB_ACi <sup>(2)</sup>   | RW   | 32                    | 0x0000 1074 + (0x4*i) | 0x0008 1074 + (0x4*i) |
| VLCD_OFLEV_MAXITAB <sup>(2)</sup> | RW   | 32                    | 0x0000 107C + (0x4*i) | 0x0008 107C + (0x4*i) |
| VLCD_CTLTAB_DCY                   | RW   | 32                    | 0x0000 1084           | 0x0008 1084           |
| VLCD_CTLTAB_DCUV                  | RW   | 32                    | 0x0000 1088           | 0x0008 1088           |
| VLCD_CTLTAB_ACi <sup>(2)</sup>    | RW   | 32                    | 0x0000 108C + (0x4*i) | 0x0008 108C + (0x4*i) |
| VLCD_OFFSET_DCY                   | RW   | 32                    | 0x0000 1094           | 0x0008 1094           |
| VLCD_OFFSET_DCUV                  | RW   | 32                    | 0x0000 1098           | 0x0008 1098           |
| VLCD_OFFSET_ACi <sup>(2)</sup>    | RW   | 32                    | 0x0000 109C + (0x4*i) | 0x0008 109C + (0x4*i) |
| VLCD_SYMTAB_DCY                   | RW   | 32                    | 0x0000 10A4           | 0x0008 10A4           |
| VLCD_SYMTAB_DCUV                  | RW   | 32                    | 0x0000 10A8           | 0x0008 10A8           |
| VLCD_SYMTAB_ACi <sup>(2)</sup>    | RW   | 32                    | 0x0000 10AC + (0x4*i) | 0x0008 10AC + (0x4*i) |
| VLCD_VLD_CTL                      | RW   | 32                    | 0x0000 10B4           | 0x0008 10B4           |
| VLCD_VLD_NRBIT_DC                 | RW   | 32                    | 0x0000 10B8           | 0x0008 10B8           |
| VLCD_VLD_NRBIT_AC                 | RW   | 32                    | 0x0000 10BC           | 0x0008 10BC           |

<sup>(1)</sup> j = 0 to 5

<sup>(2)</sup> i = 0 to 1

**Table 5-525. iVLCD Register Mapping Summary (continued)**

| Register Name                  | Type | Register Width (Bits) | Address Offset        | Physical Address      |
|--------------------------------|------|-----------------------|-----------------------|-----------------------|
| VLCD_BITS_BPTR                 | RW   | 32                    | 0x0000 10C0           | 0x0008 10C0           |
| VLCD_BITS_WORD                 | RW   | 32                    | 0x0000 10C4           | 0x0008 10C4           |
| VLCD_BYTE_ALIGN                | RW   | 32                    | 0x0000 10C8           | 0x0008 10C8           |
| VLCD_HEAD_ADDR                 | RW   | 32                    | 0x0000 10CC           | 0x0008 10CC           |
| VLCD_HEAD_NUM                  | RW   | 32                    | 0x0000 10D0           | 0x0008 10D0           |
| VLCD_QIQ_CONFIG <sup>(1)</sup> | RW   | 32                    | 0x0000 10D4 + (0x4*j) | 0x0008 10D4 + (0x4*j) |
| VLCD_VLD_ERRCTL                | RW   | 32                    | 0x0000 10EC           | 0x0008 10EC           |
| VLCD_VLD_ERRSTAT               | R    | 32                    | 0x0000 10F0           | 0x0008 10F0           |
| VLCD_RING_START                | RW   | 32                    | 0x0000 10F4           | 0x0008 10F4           |
| VLCD_RING_END                  | RW   | 32                    | 0x0000 10F8           | 0x0008 10F8           |
| VLCD_CTRL                      | RW   | 32                    | 0x0000 10FC           | 0x0008 10FC           |
| VLCD_VLD_PREFIX_DC             | RW   | 32                    | 0x0000 1100           | 0x0008 1100           |
| VLCD_VLD_PREFIX_AC             | RW   | 32                    | 0x0000 1104           | 0x0008 1104           |
| VLCD_WMV9_CONFIG               | RW   | 32                    | 0x0000 1108           | 0x0008 1108           |
| VLCD_FIRST_FRAME               | RW   | 32                    | 0x0000 110C           | 0x0008 110C           |
| VLCD_H264_MODE                 | RW   | 32                    | 0x0000 1110           | 0x0008 1110           |
| VLCD_NRBITSTH                  | RW   | 32                    | 0x0000 1114           | 0x0008 1114           |
| CAVLC_GO_REG                   | RW   | 32                    | 0x0000 1140           | 0x0008 1140           |
| CAVLC_MBTYPE                   | RW   | 32                    | 0x0000 1144           | 0x0008 1144           |
| CAVLC_RBTOP                    | RW   | 32                    | 0x0000 1148           | 0x0008 1148           |
| CAVLC_RBEND                    | RW   | 32                    | 0x0000 114C           | 0x0008 114C           |
| CAVLC_BUFPTR                   | RW   | 32                    | 0x0000 1150           | 0x0008 1150           |
| CAVLC_BITPTR                   | RW   | 32                    | 0x0000 1154           | 0x0008 1154           |
| CAVLC_STRMWDU                  | RW   | 32                    | 0x0000 1158           | 0x0008 1158           |
| CAVLC_STRMWDL                  | RW   | 32                    | 0x0000 115C           | 0x0008 115C           |
| CAVLC_HDPTR                    | RW   | 32                    | 0x0000 1160           | 0x0008 1160           |
| CAVLC_HDCOUNT                  | RW   | 32                    | 0x0000 1164           | 0x0008 1164           |
| CAVLC_NAPTR                    | RW   | 32                    | 0x0000 1168           | 0x0008 1168           |
| CAVLC_NBPTR                    | RW   | 32                    | 0x0000 116C           | 0x0008 116C           |
| CAVLC_COEFFPTR                 | RW   | 32                    | 0x0000 1170           | 0x0008 1170           |
| CAVLC_IBUFSEL                  | RW   | 32                    | 0x0000 1174           | 0x0008 1174           |
| CAVLC_NUMTTL                   | R    | 32                    | 0x0000 1178           | 0x0008 1178           |
| CAVLC_NUMHD                    | R    | 32                    | 0x0000 117C           | 0x0008 117C           |
| CAVLC_NUMRESI                  | R    | 32                    | 0x0000 1180           | 0x0008 1180           |

### 5.5.9.2 iVLCD Register Descriptions

**Table 5-526. IVLCD\_REVISION**

|                         |                                                |                 |       |
|-------------------------|------------------------------------------------|-----------------|-------|
| <b>Address Offset</b>   | 0x0000 0000                                    | <b>Instance</b> | iVLCD |
| <b>Physical Address</b> | 0x0008 0000                                    |                 |       |
| <b>Description</b>      | This register contains the iVLCD revision code |                 |       |
| <b>Type</b>             | R                                              |                 |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REV |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                    | Type | Reset              |
|------|------------|----------------------------------------------------------------|------|--------------------|
| 31:8 | RESERVED   | Reads return 0                                                 | R    | 0x00               |
| 7:0  | REV        | iVLCD Revision<br>[3:0] Minor Revision<br>[7:4] Major Revision | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 5-527. Register Call Summary for Register IVLCD\_REVISION**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-528. IVLCD\_SYSCONFIG**

|                         |                                                                          |                 |       |
|-------------------------|--------------------------------------------------------------------------|-----------------|-------|
| <b>Address Offset</b>   | 0x0000 0010                                                              | <b>Instance</b> | iVLCD |
| <b>Physical Address</b> | 0x0008 0010                                                              |                 |       |
| <b>Description</b>      | This register allows controlling various parameters of the OCP interface |                 |       |
| <b>Type</b>             | RW                                                                       |                 |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |               |          |           |          |           |          |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------------|----------|-----------|----------|-----------|----------|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CLOCKACTIVITY | RESERVED | SIDLEMODE | RESERVED | SOFTRESET | AUTOIDLE |   |

| Bits | Field Name    | Description                                                                                                                                               | Type | Reset |
|------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:9 | RESERVED      | Read returns 0.<br>Write has no effect (write a 0 for forward compatibility)                                                                              | RW   | 0x0   |
| 8    | CLOCKACTIVITY | Clock activity during wake up mode period.<br>0 - OCP clock can be switched-off.                                                                          | R    | 0x0   |
| 7:5  | RESERVED      | Read returns 0.<br>Write has no effect (write a 0 for forward compatibility)                                                                              | RW   | 0x0   |
| 4:3  | SIDLEMODE     | Slave interface power management, req/ack control<br>"10" = Smart-idle. Acknowledgement to an idle request is given based on the internal activity of iME | R    | 0x2   |
| 2    | RESERVED      | read returns 0.<br>write has no effect (write a 0 for forward compatibility)                                                                              | RW   | 0x0   |
| 1    | SOFTRESET     | Software reset. Set this bit to 1 to trigger the iME reset.<br>The bit is automatically reset by the hardware. During reads, it always returns 0.         | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                                                  | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | AUTOIDLE   | Internal OCP clock gating strategy:<br>0: OCP clock is free running<br>1: Automatic OCP clock-gating strategy is applied based on the OCP interface activity | RW   | 0x1   |

**Table 5-529. Register Call Summary for Register IVLCD\_SYSCONFIG**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-530. IVLCD\_SYSSTATUS**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                 |          |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|----------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Address Offset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x0000 0014                                                                                     | Instance | iVLCD     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Physical Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0008 0014                                                                                     |          |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | The register provides status information about the module, excluding the interrupt information. |          |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R                                                                                               |          |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 20%;">31</td> <td style="width: 20%;">30</td> <td style="width: 20%;">29</td> <td style="width: 20%;">28</td> <td style="width: 20%;">27</td> <td style="width: 20%;">26</td> <td style="width: 20%;">25</td> <td style="width: 20%;">24</td> <td style="width: 20%;">23</td> <td style="width: 20%;">22</td> <td style="width: 20%;">21</td> <td style="width: 20%;">20</td> <td style="width: 20%;">19</td> <td style="width: 20%;">18</td> <td style="width: 20%;">17</td> <td style="width: 20%;">16</td> <td style="width: 20%;">15</td> <td style="width: 20%;">14</td> <td style="width: 20%;">13</td> <td style="width: 20%;">12</td> <td style="width: 20%;">11</td> <td style="width: 20%;">10</td> <td style="width: 20%;">9</td> <td style="width: 20%;">8</td> <td style="width: 20%;">7</td> <td style="width: 20%;">6</td> <td style="width: 20%;">5</td> <td style="width: 20%;">4</td> <td style="width: 20%;">3</td> <td style="width: 20%;">2</td> <td style="width: 20%;">1</td> <td style="width: 20%;">0</td> </tr> </table> |                                                                                                 |          |           | 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 |
| 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 |   |   |   |   |
| RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                 |          | RESETDONE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                           | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------|------|-------|
| 31:1 | RESERVED   | Reserved for OCP socket status information.<br>Read returns 0.                        | R    | 0x00  |
| 0    | RESETDONE  | Internal reset monitoring<br>0 Internal module reset is on-going<br>1 Reset completed | R    | 0x1   |

**Table 5-531. Register Call Summary for Register IVLCD\_SYSSTATUS**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-532. IVLCD\_CPUTATUSREG**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                  |          |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Address Offset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x0000 0AE8                                                                      | Instance | iVLCD     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Physical Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0008 0AE8                                                                      |          |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | CPU Status Register provides information about the progress of the CPU execution |          |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R                                                                                |          |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 20%;">31</td> <td style="width: 20%;">30</td> <td style="width: 20%;">29</td> <td style="width: 20%;">28</td> <td style="width: 20%;">27</td> <td style="width: 20%;">26</td> <td style="width: 20%;">25</td> <td style="width: 20%;">24</td> <td style="width: 20%;">23</td> <td style="width: 20%;">22</td> <td style="width: 20%;">21</td> <td style="width: 20%;">20</td> <td style="width: 20%;">19</td> <td style="width: 20%;">18</td> <td style="width: 20%;">17</td> <td style="width: 20%;">16</td> <td style="width: 20%;">15</td> <td style="width: 20%;">14</td> <td style="width: 20%;">13</td> <td style="width: 20%;">12</td> <td style="width: 20%;">11</td> <td style="width: 20%;">10</td> <td style="width: 20%;">9</td> <td style="width: 20%;">8</td> <td style="width: 20%;">7</td> <td style="width: 20%;">6</td> <td style="width: 20%;">5</td> <td style="width: 20%;">4</td> <td style="width: 20%;">3</td> <td style="width: 20%;">2</td> <td style="width: 20%;">1</td> <td style="width: 20%;">0</td> </tr> </table> |                                                                                  |          |           | 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 |
| 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 |   |   |   |   |
| RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                  |          | EXECSTATE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                  |          |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                  | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------|------|--------|
| 31:26 | RESERVED   | Read returns 0.                                                                              | R    | 0x00   |
| 25:24 | EXECSTATE  | Execution States:<br>00 = Initialized,<br>10 = Executing,<br>01 = Halted,<br>11 = Completed. | R    | 0x0    |
| 23:0  | RESERVED   | Read returns 0.                                                                              | R    | 0x0000 |

**Table 5-533. Register Call Summary for Register IVLCD\_CPUSTATUSREG**

IVA2.2 Subsystem Register Manual

- [IVLCD Register Mapping Summary: \[0\]](#)

**Table 5-534. IVLCD\_CONFIGREG**

|                         |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |       |  |  |  |  |  |  |
|-------------------------|------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0AF4            |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | iVLCD |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x0008 0AF4            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |       |  |  |  |  |  |  |
| <b>Description</b>      | Configuration Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |       |  |  |  |  |  |  |
| <b>Type</b>             | RW                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |       |  |  |  |  |  |  |

|          |          |           |            |            |          |      |      |       |        |        |          |          |          |          |          |      |          |          |          |          |          |          |          |          |          |          |          |          |          |          |   |
|----------|----------|-----------|------------|------------|----------|------|------|-------|--------|--------|----------|----------|----------|----------|----------|------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|---|
| 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 |
| RESERVED | HMEMSWAP | IBUF1SWAP | IBUF0BSWAP | IBUF0ASWAP | RESERVED | QMEM | HMEM | IBUF1 | IBUF0B | IBUF0A | RESERVED | RESERVED | RESERVED | RESERVED | RESERVED | OPER | RESERVED | ITENABLE |   |

| Bits  | Field Name | Description                                                                                                                                                          | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | read returns 0.                                                                                                                                                      | R    | 0x0   |
| 27    | HMEMSWAP   | Enable 2 byte swap for host OCP access to this memory. Bytes 0.1.2.3 are swapped to 1.0.3.2 for both reads and writes.<br>0 - Disabled (Native order)<br>1 - Swapped | RW   | 0x0   |
| 26    | IBUF1SWAP  | Enable 4 byte swap for host OCP access to this memory. Bytes 0.1.2.3 are swapped to 3.2.1.0 for both reads and writes.<br>0 - Disabled (Native order)<br>1 - Swapped | RW   | 0x0   |
| 25    | IBUF0BSWAP | IBUF0B 4 byte swap enable                                                                                                                                            | RW   | 0x0   |
| 24    | IBUF0ASWAP | IBUF0A 4 byte swap enable                                                                                                                                            | RW   | 0x0   |
| 23:21 | RESERVED   | read returns 0.                                                                                                                                                      | R    | 0x0   |
| 20    | QMEM       | QMEM ownership:<br>0: QMEM is owned by xVLCD<br>1: QMEM is owned by HOST                                                                                             | RW   | 0x1   |
| 19    | HMEM       | HMEM ownership:<br>0: HMEM is owned by xVLCD<br>1: HMEM is owned by HOST                                                                                             | RW   | 0x1   |
| 18    | IBUF1      | IBUF1 ownership:<br>0: IBFU1 is owned by xVLCD<br>1: IBFU1 is owned by HOST                                                                                          | RW   | 0x1   |
| 17    | IBUF0B     | IBUF0B ownership:<br>0: IBFU0B is owned by xVLCD<br>1: IBFU0B is owned by HOST                                                                                       | RW   | 0x1   |
| 16    | IBUF0A     | IBUF0A ownership:<br>0: IBFU0A is owned by xVLCD<br>1: IBFU0A is owned by HOST                                                                                       | RW   | 0x1   |
| 15:9  | RESERVED   | read returns 0.                                                                                                                                                      | R    | 0x00  |

## IVA2.2 Subsystem Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                                                           | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 8    | OPER       | Operation Type: Used to identify which start to issue to the xVLCD when a START command is set to the iVLCD.<br>0 - VLCD<br>1 - CAVLC | RW   | 0x0   |
| 7:1  | RESERVED   | Read returns 0.                                                                                                                       | R    | 0x00  |
| 0    | ITENABLE   | Interrupt Enable bit. Controls interrupt regardless of VLCD or CAVLC operation.                                                       | RW   | 0x1   |

**Table 5-535. Register Call Summary for Register IVLCD\_CONFIGREG**

## IVA2.2 Subsystem Register Manual

- [IVLCD Register Mapping Summary: \[0\]](#)

**Table 5-536. IVLCD\_COMMAND**

|                  |                           |          |       |
|------------------|---------------------------|----------|-------|
| Address Offset   | 0x0000 0FFC               | Instance | iVLCD |
| Physical Address | 0x0008 0FFC               |          |       |
| Description      | Initiate iVLCD operations |          |       |
| Type             | RW                        |          |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | CMD |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                                                        | RW   | 0x00000000 |
| 2:0  | CMD        | Triggers iVLCD operations<br>Reads of this register return the last command that was issued to the iVLCD<br><br>0x1: Start sequence<br>0x2: Stop sequence<br>0x3: Debug enable<br>0x4: Debug disable<br>0x5: Debug Step<br>0x6: Debug Halt | RW   | 0x0        |

**Table 5-537. Register Call Summary for Register IVLCD\_COMMAND**

## IVA2.2 Subsystem Register Manual

- [IVLCD Register Mapping Summary: \[0\]](#)

**Table 5-538. VLCD\_START**

|                  |                                                                           |          |       |
|------------------|---------------------------------------------------------------------------|----------|-------|
| Address Offset   | 0x0000 1000                                                               | Instance | iVLCD |
| Physical Address | 0x0008 1000                                                               |          |       |
| Description      | This register starts the VLCD and enables or disables the VLCD interrupt. |          |       |
| Type             | RW                                                                        |          |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |           |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----------|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | INTR   GO |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------|-------------|--------------|
| 31:2        | RESERVED          | Write 0s for future compatibility<br>Read returns 0                                    | RW          | 0x0000       |
| 1           | INTR              | Interrupt enable <sup>(1)</sup><br>0: Interrupt is disabled<br>1: Interrupt is enabled | RW          | 0x0          |
| 0           | GO                | VLCD start<br>Read<br>0: VLCD idle<br>1: VLCD busy.                                    | RW          | 0x0          |

<sup>(1)</sup> Enable/disable interrupt related only to VLCD operation.

**Table 5-539. Register Call Summary for Register VLCD\_START**

## IVA2.2 Subsystem Register Manual

- iVLCD Register Mapping Summary: [0]

**Table 5-540. VLCD\_MODE**

|                         |                                    |                 |       |  |  |
|-------------------------|------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 1004                        | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 1004                        |                 |       |  |  |
| <b>Description</b>      | This register sets the VLCD modes. |                 |       |  |  |
| <b>Type</b>             | RW                                 |                 |       |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |         |    |          |          |        |          |           |         |   |           |      |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|---------|----|----------|----------|--------|----------|-----------|---------|---|-----------|------|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MPEGRND | NUMBLKS |    | JPEGSYNC | MPEGTYPE | ESCAPE | INTRAVLC | MPEGINTRA | MODESEL |   | QMPEGTYPE | FUNC |   |   |   |   |

| Bits                                                                                       | Field Name | Description                                                                                                               | Type | Reset  |
|--------------------------------------------------------------------------------------------|------------|---------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16                                                                                      | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                       | RW   | 0x0000 |
| 15                                                                                         | MPEGRND    | Round control for the MPEG inverse quantization<br>0: Round off<br>1: Round on                                            | RW   | 0x0    |
| 14:12                                                                                      | NUMBLKS    | Sets the number of blocks<br>Range from 1 "001" to 6 "110"                                                                | RW   | 0x0    |
| 11                                                                                         | JPEGSYNC   | Sets the JPEG Sync Insertion<br>0: Off<br>1: On. Inserts 0x00 after 0xFF.                                                 | RW   | 0x0    |
| 10                                                                                         | MPEGTYPE   | Sets the MPEG picture coding type<br>0: I, P, B picture<br>1: D picture                                                   | RW   | 0x0    |
| 9                                                                                          | ESCAPE     | MPEG4 escape encoding<br>0: Escape3 only<br>1: Escape 1, 2 and 3                                                          | RW   | 0x0    |
| 8                                                                                          | INTRAVLC   | MPEG intra VLC format                                                                                                     | RW   | 0x0    |
| 7                                                                                          | MPEGINTRA  | Sets the macro block (MB) type<br>0: Non intra macro block<br>1: Intra macro block (JPEG uses only intra MB).             | RW   | 0x0    |
| 6:4                                                                                        | MODESEL    | Sets the CODEC type for the VLCD operations<br>000: JPEG<br>001: MPEG1<br>010: MPEG4<br>011: H.263<br>100 - 111: Reserved | RW   | 0x0    |
| See also <a href="#">VLCD_CTRL[5:4]</a> MPGMOD and <a href="#">VLCD_CTRL[2]</a> MP2ENCODEC |            |                                                                                                                           |      |        |

| Bits | Field Name | Description                                                                                                                                 | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3    | QMPEGTYPE  | Sets the quantization type use for encode and decode.<br>Used in MPEG4.                                                                     | RW   | 0x0   |
| 2:0  | FUNC       | Defines functionality of VLCD<br><br>0x0: Q<br>0x1: IQ<br>0x2: VLC<br>0x3: VLD<br>0x4: Q + IQ<br>0x5: Q+VLC<br>0x6: Q+IQ+VLC<br>0x7: VLD+IQ | RW   | 0x-   |

**Table 5-541. Register Call Summary for Register VLCD\_MODE**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for Q/IQ Operation: \[0\] \[1\]](#)
- [Setting Up Registers for VLC Operation: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [Setting Up Registers for VLD Operation: \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[18\]](#)
- [iVLCD Register Descriptions: \[19\] \[20\] \[21\] \[22\]](#)

**Table 5-542. VLCD\_QIN\_ADDR**

|                |                                                                        |                  |             |          |       |
|----------------|------------------------------------------------------------------------|------------------|-------------|----------|-------|
| Address Offset | 0x0000 1008                                                            | Physical Address | 0x0008 1008 | Instance | iVLCD |
| Description    | This register sets the input address for the quantization computation. |                  |             |          |       |
| Type           | RW                                                                     |                  |             |          |       |



| Bits  | Field Name | Description                                                               | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                       | RW   | 0x0000 |
| 15    | MEMSEL     | Sets the buffer used for the computation<br>0: IMG BUF A/B<br>1: IMG BUF1 | RW   | 0x0    |
| 14:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                       | RW   | 0x0    |
| 12:0  | ADDR       | Sets the start address for the computation                                | RW   | 0x0000 |

**Table 5-543. Register Call Summary for Register VLCD\_QIN\_ADDR**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-544. VLCD\_QOUT\_ADDR**

|                         |                                                                         |                         |                 |                 |       |
|-------------------------|-------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-------|
| <b>Address Offset</b>   | 0x0000 100C                                                             | <b>Physical Address</b> | 0x0008 100C     | <b>Instance</b> | iVLCD |
| <b>Description</b>      | This register sets the output address for the quantization computation. |                         |                 |                 |       |
| <b>Type</b>             | RW                                                                      |                         |                 |                 |       |
| 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 |                 |       |
| RESERVED                |                                                                         | MEMSEL                  | RESERVED        | ADDR            |       |

| Bits  | Field Name | Description                                                               | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                       | RW   | 0x0000 |
| 15    | MEMSEL     | Sets the buffer used for the computation<br>0: IMG BUF A/B<br>1: IMG BUF1 | RW   | 0x0    |
| 14:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                       | RW   | 0x0    |
| 12:0  | ADDR       | Sets the start address for the computation                                | RW   | 0x0000 |

**Table 5-545. Register Call Summary for Register VLCD\_QOUT\_ADDR**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-546. VLCD\_IQIN\_ADDR**

|                         |                                                                                |                         |                 |                 |       |
|-------------------------|--------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-------|
| <b>Address Offset</b>   | 0x0000 1010                                                                    | <b>Physical Address</b> | 0x0008 1010     | <b>Instance</b> | iVLCD |
| <b>Description</b>      | This register sets the input address for the inverse quantization computation. |                         |                 |                 |       |
| <b>Type</b>             | RW                                                                             |                         |                 |                 |       |
| 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 |                 |       |
| RESERVED                |                                                                                | MEMSEL                  | RESERVED        | ADDR            |       |

| Bits  | Field Name | Description                                                               | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                       | RW   | 0x0000 |
| 15    | MEMSEL     | Sets the buffer used for the computation<br>0: IMG BUF A/B<br>1: IMG BUF1 | RW   | 0x0    |
| 14:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                       | RW   | 0x0    |
| 12:0  | ADDR       | Sets the start address for the computation                                | RW   | 0x0000 |

**Table 5-547. Register Call Summary for Register VLCD\_IQIN\_ADDR**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-548. VLCD\_IQOUT\_ADDR**

|                         |                                                                                    |                         |                 |                 |       |
|-------------------------|------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-------|
| <b>Address Offset</b>   | 0x0000 1014                                                                        | <b>Physical Address</b> | 0x0008 1014     | <b>Instance</b> | iVLCD |
| <b>Description</b>      | This register sets the output address for the inverse quantization output address. |                         |                 |                 |       |
| <b>Type</b>             | RW                                                                                 |                         |                 |                 |       |
| 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 |                 |       |
| RESERVED                | MEMSEL                                                                             | RESERVED                | ADDR            |                 |       |

| Bits  | Field Name | Description                                                               | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                       | RW   | 0x0000 |
| 15    | MEMSEL     | Sets the buffer used for the computation<br>0: IMG BUF A/B<br>1: IMG BUF1 | RW   | 0x0    |
| 14:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                       | RW   | 0x0    |
| 12:0  | ADDR       | Sets the start address for the computation                                | RW   | 0x0000 |

**Table 5-549. Register Call Summary for Register VLCD\_IQOUT\_ADDR**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-550. VLCD\_VLCDIN\_ADDR**

|                         |                                                                                            |                         |                 |                 |       |
|-------------------------|--------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-------|
| <b>Address Offset</b>   | 0x0000 1018                                                                                | <b>Physical Address</b> | 0x0008 1018     | <b>Instance</b> | iVLCD |
| <b>Description</b>      | This register sets the input address for the variable length coder and decoder operations. |                         |                 |                 |       |
| <b>Type</b>             | RW                                                                                         |                         |                 |                 |       |
| 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 |                 |       |
| RESERVED                | MEMSELECT                                                                                  | RESERVED                | ADDR            |                 |       |

| Bits  | Field Name | Description                                                               | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                       | RW   | 0x0000 |
| 15    | MEMSELECT  | Sets the buffer used for the computation<br>0: IMG BUF A/B<br>1: IMG BUF1 | RW   | 0x0    |
| 14:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                       | RW   | 0x0    |
| 12:0  | ADDR       | Sets the start address for the computation                                | RW   | 0x0000 |

**Table 5-551. Register Call Summary for Register VLCD\_VLCDIN\_ADDR**

## IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for VLC Operation: \[0\]](#)
- [Setting Up Registers for VLD Operation: \[1\]](#)
- [Calculating the Number of Bits Processed During a VLD Run: \[2\] \[3\]](#)

## IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[4\]](#)

**Table 5-552. VLCD\_VLCDOUT\_ADDR**

|                         |                                                                                             |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 101C                                                                                 |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x0008 101C                                                                                 |  |  |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register sets the output address for the variable length coder and decoder operations. |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                          |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |



| Bits  | Field Name | Description                                                               | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                       | RW   | 0x0000 |
| 15    | MEMSELECT  | Sets the buffer used for the computation<br>0: IMG BUF A/B<br>1: IMG BUF1 | RW   | 0x0    |
| 14:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                       | RW   | 0x0    |
| 12:0  | ADDR       | Sets the start address for the computation                                | RW   | 0x0000 |

**Table 5-553. Register Call Summary for Register VLCD\_VLCDOUT\_ADDR**

## IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for VLC Operation: \[0\]](#)
- [Setting Up Registers for VLD Operation: \[1\]](#)

## IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[2\]](#)

**Table 5-554. VLCD\_DC\_PREDj**

|                         |                                                                     |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 1020 + (0x4*j)                                               |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x0008 1020 + (0x4*j)                                               |  |  |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register sets the initial/final DC predictors for Quantization |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |



| Bits  | Field Name | Description                                         | Type | Reset |
|-------|------------|-----------------------------------------------------|------|-------|
| 31:12 | RESERVED   | Write 0s for future compatibility<br>Read returns 0 | RW   | 0x0   |
| 11:0  | PRED       | Initial/ final DC predictor value                   | RW   | 0x000 |

**Table 5-555. Register Call Summary for Register VLCD\_DC\_PREDj**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-556. VLCD\_IDC\_PREDj**

|                         |                                                                             |                 |       |  |  |
|-------------------------|-----------------------------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 1038 + (0x4*j)                                                       | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 1038 + (0x4*j)                                                       |                 |       |  |  |
| <b>Description</b>      | This register sets the initial/final DC predictors for Inverse Quantization |                 |       |  |  |
| <b>Type</b>             | RW                                                                          |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IPRED |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                         | Type | Reset |
|-------|------------|-----------------------------------------------------|------|-------|
| 31:12 | RESERVED   | Write 0s for future compatibility<br>Read returns 0 | RW   | 0x0   |
| 11:0  | IPRED      | Initial/ final DC predictor value                   | RW   | 0x000 |

**Table 5-557. Register Call Summary for Register VLCD\_IDC\_PREDj**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-558. VLCD\_MPEG\_INVQ**

|                         |                                                                 |                 |       |  |  |
|-------------------------|-----------------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 1050                                                     | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 1050                                                     |                 |       |  |  |
| <b>Description</b>      | This register sets the inverse quantization value used in MPEG. |                 |       |  |  |
| <b>Type</b>             | RW                                                              |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MINVQ |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                         | Type | Reset  |
|-------|------------|-----------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility<br>Read returns 0 | RW   | 0x0000 |
| 15:0  | MINVQ      | $2^{15}$ /quant_scale                               | RW   | 0x0000 |

**Table 5-559. Register Call Summary for Register VLCD\_MPEG\_INVQ**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-560. VLCD\_MPEG\_Q**

|                         |                                                         |                 |       |  |  |
|-------------------------|---------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 1054                                             | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 1054                                             |                 |       |  |  |
| <b>Description</b>      | This register sets the quantization value used in MPEG. |                 |       |  |  |
| <b>Type</b>             | RW                                                      |                 |       |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MQ |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------|-------------|--------------|
| 31:8        | RESERVED          | Write 0s for future compatibility<br>Read returns 0 | RW          | 0x00         |
| 7:0         | MQ                | quant_scale                                         | RW          | 0x00         |

**Table 5-561. Register Call Summary for Register VLCD\_MPEG\_Q**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-562. VLCD\_MPEG\_DELTA\_Q**

|                         |                                                              |                 |       |  |  |
|-------------------------|--------------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 1058                                                  | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 1058                                                  |                 |       |  |  |
| <b>Description</b>      | This register sets the delta value used in MPEG quantization |                 |       |  |  |
| <b>Type</b>             | RW                                                           |                 |       |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MDELQ |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------|-------------|--------------|
| 31:9        | RESERVED          | Write 0s for future compatibility<br>Read returns 0 | RW          | 0x00         |
| 8:0         | MDELQ             | Number of delta values<br>2's complement            | RW          | 0x000        |

**Table 5-563. Register Call Summary for Register VLCD\_MPEG\_DELTA\_Q**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for Q/IQ Operation: \[0\] \[1\] \[2\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[3\]](#)

**Table 5-564. VLCD\_MPEG\_DELTA\_IQ**

|                         |                                                                      |                 |       |  |  |
|-------------------------|----------------------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 105C                                                          | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 105C                                                          |                 |       |  |  |
| <b>Description</b>      | This register sets the delta value used in MPEG inverse quantization |                 |       |  |  |
| <b>Type</b>             | RW                                                                   |                 |       |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MDELIQ |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                         | Type | Reset |
|------|------------|-----------------------------------------------------|------|-------|
| 31:9 | RESERVED   | Write 0s for future compatibility<br>Read returns 0 | RW   | 0x00  |
| 8:0  | MDELIQ     | Number of delta values<br>2's complement            | RW   | 0x000 |

**Table 5-565. Register Call Summary for Register VLCD\_MPEG\_DELTA\_IQ**

IVA2.2 Subsystem Basic Programming Model  
 • [Setting Up Registers for Q/IQ Operation: \[0\]](#) [\[1\]](#) [\[2\]](#)

IVA2.2 Subsystem Register Manual  
 • [iVLCD Register Mapping Summary: \[3\]](#)

**Table 5-566. VLCD\_MPEG\_THRED**

|                         |                                                                    |  |  |  |  |  |  |  |  |  |  |  |                 |       |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 1060                                                        |  |  |  |  |  |  |  |  |  |  |  |                 |       |  |  |  |  |  |
| <b>Physical Address</b> | 0x0008 1060                                                        |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | iVLCD |  |  |  |  |  |
| <b>Description</b>      | This register sets the number of threads used in MPEG quantization |  |  |  |  |  |  |  |  |  |  |  |                 |       |  |  |  |  |  |
| <b>Type</b>             | RW                                                                 |  |  |  |  |  |  |  |  |  |  |  |                 |       |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MTHRED |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                         | Type | Reset |
|-------|------------|-----------------------------------------------------|------|-------|
| 31:12 | RESERVED   | Write 0s for future compatibility<br>Read returns 0 | RW   | 0x0   |
| 11:0  | MTHRED     | Number of threads                                   | RW   | 0x000 |

**Table 5-567. Register Call Summary for Register VLCD\_MPEG\_THRED**

IVA2.2 Subsystem Basic Programming Model  
 • [Setting Up Registers for Q/IQ Operation: \[0\]](#)

IVA2.2 Subsystem Register Manual  
 • [iVLCD Register Mapping Summary: \[1\]](#)

**Table 5-568. VLCD\_MPEG\_CBP**

|                         |                                                                 |  |  |  |  |  |  |  |  |  |  |  |                 |       |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 1064                                                     |  |  |  |  |  |  |  |  |  |  |  |                 |       |  |  |  |  |  |
| <b>Physical Address</b> | 0x0008 1064                                                     |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | iVLCD |  |  |  |  |  |
| <b>Description</b>      | This register sets the coded block pattern (CBP) configuration. |  |  |  |  |  |  |  |  |  |  |  |                 |       |  |  |  |  |  |
| <b>Type</b>             | RW                                                              |  |  |  |  |  |  |  |  |  |  |  |                 |       |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |          |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----------|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CBPON | RESERVED | CBP |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                       | Type | Reset |
|------|------------|-------------------------------------------------------------------|------|-------|
| 31:9 | RESERVED   | Write 0s for future compatibility<br>Read returns 0               | RW   | 0x00  |
| 8    | CBPON      | CBP detect enable<br>0: CBP detect off (JPEG)<br>1: CBP detect on | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                                                                                                                                    | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:6  | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                                                            | RW   | 0x0   |
| 5:0  | CBP        | CBP indicating at least one nonzero in a block<br>1XXXXX: CBP of the 1st block<br>X1XXXX: CBP of the 2nd block<br>XX1XXX: CBP of the 3rd block<br>XXX1XX: CBP of the 4th block<br>XXXX1X: CBP of the 5th block<br>XXXXX1: CBP of the 6th block | RW   | 0x3F  |

**Table 5-569. Register Call Summary for Register VLCD\_MPEG\_CBP**

- IVA2.2 Subsystem Basic Programming Model
- [Setting Up Registers for VLC Operation: \[0\]](#) [1]
  - [Setting Up Registers for VLD Operation: \[2\]](#)

---

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[3\]](#)
- 

**Table 5-570. VLCD\_LUMA\_VECTOR**

|                       |                                        |                         |             |                 |       |
|-----------------------|----------------------------------------|-------------------------|-------------|-----------------|-------|
| <b>Address Offset</b> | 0x0000 1068                            | <b>Physical Address</b> | 0x0008 1068 | <b>Instance</b> | iVLCD |
| <b>Description</b>    | This register sets the luma bit vector |                         |             |                 |       |
| <b>Type</b>           | RW                                     |                         |             |                 |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---------|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | LUMVECT |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                               | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:6 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                                                                       | RW   | 0x000 |
| 5:0  | LUMVECT    | Luma bit vector<br>1XXXXX<br>Luma bit of the 1st block<br>X1XXXX<br>Luma bit of the 2nd block<br>XX1XXX<br>Luma bit of the 3rd block<br>XXX1XX<br>Luma bit of the 4th block<br>XXXX1X<br>Luma bit of the 5th block<br>XXXXX1<br>Luma bit of the 6th block | RW   | 0x00  |

**Table 5-571. Register Call Summary for Register VLCD\_LUMA\_VECTOR**

- IVA2.2 Subsystem Basic Programming Model
- [Setting Up Registers for VLC Operation: \[0\]](#) [1]
  - [Setting Up Registers for VLD Operation: \[1\]](#)

---

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[2\]](#)
-

**Table 5-572. VLCD\_HUFFTAB\_DCY**

|                       |                                                            |                         |             |                 |       |
|-----------------------|------------------------------------------------------------|-------------------------|-------------|-----------------|-------|
| <b>Address Offset</b> | 0x0000 106C                                                | <b>Physical Address</b> | 0x0008 106C | <b>Instance</b> | iVLCD |
| <b>Description</b>    | This register sets the base address for Huffman DC tables. |                         |             |                 |       |
| <b>Type</b>           | RW                                                         |                         |             |                 |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | HDCY |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                          | Type | Reset |
|-------|------------|------------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Write 0s for future compatibility<br>Read returns 0  | RW   | 0x00  |
| 10:0  | HDCY       | Start address.<br>Must be align on a 32-bit boundary | RW   | 0x000 |

**Table 5-573. Register Call Summary for Register VLCD\_HUFFTAB\_DCY**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for VLC Operation: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[1\]](#)

**Table 5-574. VLCD\_HUFFTAB\_DCUV**

|                       |                                                            |                         |             |                 |       |
|-----------------------|------------------------------------------------------------|-------------------------|-------------|-----------------|-------|
| <b>Address Offset</b> | 0x0000 1070                                                | <b>Physical Address</b> | 0x0008 1070 | <b>Instance</b> | iVLCD |
| <b>Description</b>    | This register sets the base address for Huffman DC tables. |                         |             |                 |       |
| <b>Type</b>           | RW                                                         |                         |             |                 |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | HDCUV |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                          | Type | Reset |
|-------|------------|------------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Write 0s for future compatibility<br>Read returns 0  | RW   | 0x00  |
| 10:0  | HDCUV      | Start address.<br>Must be align on a 32-bit boundary | RW   | 0x000 |

**Table 5-575. Register Call Summary for Register VLCD\_HUFFTAB\_DCUV**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for VLC Operation: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[1\]](#)

**Table 5-576. VLCD\_HUFFTAB\_ACi**

| <b>Address Offset</b>   | 0x0000 1074 + (0x4*i)                                      |                                                      |                 |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | iVLCD |              |  |  |  |  |  |
|-------------------------|------------------------------------------------------------|------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------|--------------|--|--|--|--|--|
| <b>Physical Address</b> | 0x0008 1074 + (0x4*i)                                      |                                                      |                 |  |  |  |  |  |  |  |  |  |  |  |                 | iVLCD |              |  |  |  |  |  |
| <b>Description</b>      | This register sets the base address for Huffman AC tables. |                                                      |                 |  |  |  |  |  |  |  |  |  |  |  |                 | iVLCD |              |  |  |  |  |  |
| <b>Type</b>             | RW                                                         |                                                      |                 |  |  |  |  |  |  |  |  |  |  |  |                 | iVLCD |              |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |                 |       |              |  |  |  |  |  |
| RESERVED                |                                                            |                                                      |                 |  |  |  |  |  |  |  |  |  |  |  | HAC             |       |              |  |  |  |  |  |
| Bits                    | Field Name                                                 | <b>Description</b>                                   |                 |  |  |  |  |  |  |  |  |  |  |  |                 | Type  | <b>Reset</b> |  |  |  |  |  |
| 31:11                   | RESERVED                                                   | Write 0s for future compatibility<br>Read returns 0  |                 |  |  |  |  |  |  |  |  |  |  |  |                 | RW    | 0x00         |  |  |  |  |  |
| 10:0                    | HAC                                                        | Start address.<br>Must be align on a 32-bit boundary |                 |  |  |  |  |  |  |  |  |  |  |  |                 | RW    | 0x000        |  |  |  |  |  |

**Table 5-577. Register Call Summary for Register VLCD\_HUFFTAB\_ACi**

- IV A2.2 Subsystem Basic Programming Model
- [Setting Up Registers for VLC Operation: \[0\] \[1\]](#)

- IV A2.2 Subsystem Register Manual
- [iVLCD Register Mapping Summary: \[2\]](#)

**Table 5-578. VLCD\_OFLEV\_MAXiTAB**

| <b>Address Offset</b>   | 0x0000 107C + (0x4*i)                                         |                                                      |                 |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | iVLCD |              |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------|------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------|--------------|--|--|--|--|--|
| <b>Physical Address</b> | 0x0008 107C + (0x4*i)                                         |                                                      |                 |  |  |  |  |  |  |  |  |  |  |  |                 | iVLCD |              |  |  |  |  |  |
| <b>Description</b>      | This register sets the base address for MPEG max level tables |                                                      |                 |  |  |  |  |  |  |  |  |  |  |  |                 | iVLCD |              |  |  |  |  |  |
| <b>Type</b>             | RW                                                            |                                                      |                 |  |  |  |  |  |  |  |  |  |  |  |                 | iVLCD |              |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |                 |       | MAX          |  |  |  |  |  |
|                         | RESERVED                                                      |                                                      |                 |  |  |  |  |  |  |  |  |  |  |  |                 | MAX   |              |  |  |  |  |  |
| Bits                    | Field Name                                                    | <b>Description</b>                                   |                 |  |  |  |  |  |  |  |  |  |  |  |                 | Type  | <b>Reset</b> |  |  |  |  |  |
| 31:11                   | RESERVED                                                      | Write 0s for future compatibility<br>Read returns 0  |                 |  |  |  |  |  |  |  |  |  |  |  |                 | RW    | 0x00         |  |  |  |  |  |
| 10:0                    | MAX                                                           | Start address.<br>Must be align on a 32-bit boundary |                 |  |  |  |  |  |  |  |  |  |  |  |                 | RW    | 0x000        |  |  |  |  |  |

**Table 5-579. Register Call Summary for Register VLCD\_OFLEV\_MAXiTAB**

- IV A2.2 Subsystem Register Manual
- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-580. VLCD\_CTLTAB\_DCY**

|                       |                                                                                     |                         |             |                 |       |
|-----------------------|-------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------|
| <b>Address Offset</b> | 0x0000 1084                                                                         | <b>Physical Address</b> | 0x0008 1084 | <b>Instance</b> | iVLCD |
| <b>Description</b>    | This register sets the base address of the control-table DC Y LUT used by the UVLD. |                         |             |                 |       |
| <b>Type</b>           | RW                                                                                  |                         |             |                 |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CDCY |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                          | Type | Reset |
|-------|------------|------------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Write 0s for future compatibility<br>Read returns 0  | RW   | 0x00  |
| 10:0  | CDCY       | Start address.<br>Must be align on a 32-bit boundary | RW   | 0x000 |

**Table 5-581. Register Call Summary for Register VLCD\_CTLTAB\_DCY**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-582. VLCD\_CTLTAB\_DCUV**

|                       |                                                                                      |                         |             |                 |       |
|-----------------------|--------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------|
| <b>Address Offset</b> | 0x0000 1088                                                                          | <b>Physical Address</b> | 0x0008 1088 | <b>Instance</b> | iVLCD |
| <b>Description</b>    | This register sets the base address of the control-table DC UV LUT used by the UVLD. |                         |             |                 |       |
| <b>Type</b>           | RW                                                                                   |                         |             |                 |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CDCUV |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                          | Type | Reset |
|-------|------------|------------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Write 0s for future compatibility<br>Read returns 0  | RW   | 0x00  |
| 10:0  | CDCUV      | Start address.<br>Must be align on a 32-bit boundary | RW   | 0x000 |

**Table 5-583. Register Call Summary for Register VLCD\_CTLTAB\_DCUV**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for VLD Operation: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[1\]](#)

**Table 5-584. VLCD\_CTLTAB\_ACi**

|                         |                                                                                    |                 |       |  |  |
|-------------------------|------------------------------------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 108C + (0x4*i)                                                              | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 108C + (0x4*i)                                                              |                 |       |  |  |
| <b>Description</b>      | This register sets the base address of the control-table ACi LUT used by the UVLD. |                 |       |  |  |
| <b>Type</b>             | RW                                                                                 |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CAC |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                          | Type | Reset |
|-------|------------|------------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Write 0s for future compatibility<br>Read returns 0  | RW   | 0x00  |
| 10:0  | CAC        | Start address.<br>Must be align on a 32-bit boundary | RW   | 0x000 |

**Table 5-585. Register Call Summary for Register VLCD\_CTLTAB\_ACi**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for VLD Operation: \[0\]](#) [\[1\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[2\]](#)

**Table 5-586. VLCD\_OFFSET\_DCY**

|                         |                                                                                |                 |       |  |  |
|-------------------------|--------------------------------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 1094                                                                    | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 1094                                                                    |                 |       |  |  |
| <b>Description</b>      | This register sets the offset value used to address the symbol-table DC Y LUT. |                 |       |  |  |
| <b>Type</b>             | RW                                                                             |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ODCY |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                         | Type | Reset |
|-------|------------|-----------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Write 0s for future compatibility<br>Read returns 0 | RW   | 0x00  |
| 10:0  | ODCY       | Offset value                                        | RW   | 0x000 |

**Table 5-587. Register Call Summary for Register VLCD\_OFFSET\_DCY**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for VLD Operation: \[0\]](#) [\[1\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[1\]](#)

**Table 5-588. VLCD\_OFFSET\_DCUV**

|                         |                         |                       |                                                                                 |
|-------------------------|-------------------------|-----------------------|---------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 1098             | <b>Instance</b>       | iVLCD                                                                           |
| <b>Physical Address</b> | 0x0008 1098             | <b>Description</b>    |                                                                                 |
| <b>Description</b>      |                         |                       | This register sets the offset value used to address the symbol-table DC UV LUT. |
| <b>Type</b>             |                         |                       | RW                                                                              |
| 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                                                                 |
| RESERVED                |                         |                       | ODCUV                                                                           |

| Bits  | Field Name | Description                                         | Type | Reset |
|-------|------------|-----------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Write 0s for future compatibility<br>Read returns 0 | RW   | 0x00  |
| 10:0  | ODCUV      | Offset value                                        | RW   | 0x000 |

**Table 5-589. Register Call Summary for Register VLCD\_OFFSET\_DCUV**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for VLD Operation: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[1\]](#)

**Table 5-590. VLCD\_OFFSET\_ACi**

|                         |                         |                       |                                                                               |
|-------------------------|-------------------------|-----------------------|-------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 109C + (0x4*i)   | <b>Instance</b>       | iVLCD                                                                         |
| <b>Physical Address</b> | 0x0008 109C + (0x4*i)   | <b>Description</b>    |                                                                               |
| <b>Description</b>      |                         |                       | This register sets the offset value used to address the symbol-table ACi LUT. |
| <b>Type</b>             |                         |                       | RW                                                                            |
| 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                                                               |
| RESERVED                |                         |                       | OAC                                                                           |

| Bits  | Field Name | Description                                         | Type | Reset |
|-------|------------|-----------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Write 0s for future compatibility<br>Read returns 0 | RW   | 0x00  |
| 10:0  | OAC        | Offset value                                        | RW   | 0x000 |

**Table 5-591. Register Call Summary for Register VLCD\_OFFSET\_ACi**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for VLD Operation: \[0\] \[1\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[2\]](#)

**Table 5-592. VLCD\_SYMTAB\_DCY**

|                         |                                                                   |                 |       |  |  |
|-------------------------|-------------------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 10A4                                                       | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 10A4                                                       |                 |       |  |  |
| <b>Description</b>      | This register sets the base address of the symbol-table DC Y LUT. |                 |       |  |  |
| <b>Type</b>             | RW                                                                |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SDCY |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                          | Type | Reset |
|-------|------------|------------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Write 0s for future compatibility<br>Read returns 0  | RW   | 0x00  |
| 10:0  | SDCY       | Start address.<br>Must be align on a 32-bit boundary | RW   | 0x000 |

**Table 5-593. Register Call Summary for Register VLCD\_SYMTAB\_DCY**

IV A2.2 Subsystem Basic Programming Model  
 • [Setting Up Registers for VLD Operation: \[0\]](#)

IV A2.2 Subsystem Register Manual  
 • [iVLCD Register Mapping Summary: \[1\]](#)

**Table 5-594. VLCD\_SYMTAB\_DCUV**

|                         |                                                                    |                 |       |  |  |
|-------------------------|--------------------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 10A8                                                        | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 10A8                                                        |                 |       |  |  |
| <b>Description</b>      | This register sets the base address of the symbol-table DC UV LUT. |                 |       |  |  |
| <b>Type</b>             | RW                                                                 |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SDCUV |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                          | Type | Reset |
|-------|------------|------------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Write 0s for future compatibility<br>Read returns 0  | RW   | 0x00  |
| 10:0  | SDCUV      | Start address.<br>Must be align on a 32-bit boundary | RW   | 0x000 |

**Table 5-595. Register Call Summary for Register VLCD\_SYMTAB\_DCUV**

IV A2.2 Subsystem Register Manual  
 • [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-596. VLCD\_SYMTAB\_ACi**

|                         |                                                                     |                 |       |  |  |
|-------------------------|---------------------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 10AC + (0x4*i)                                               | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 10AC + (0x4*i)                                               |                 |       |  |  |
| <b>Description</b>      | This register sets the base address of the symbol-table ACi UV LUT. |                 |       |  |  |
| <b>Type</b>             | RW                                                                  |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SAC |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                          | Type | Reset |
|-------|------------|------------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Write 0s for future compatibility<br>Read returns 0  | RW   | 0x00  |
| 10:0  | SAC        | Start address.<br>Must be align on a 32-bit boundary | RW   | 0x000 |

**Table 5-597. Register Call Summary for Register VLCD\_SYMTAB\_ACi**

- IVA2.2 Subsystem Basic Programming Model
  - [Setting Up Registers for VLD Operation: \[0\]](#) [\[1\]](#)

- IVA2.2 Subsystem Register Manual
  - [iVLCD Register Mapping Summary: \[2\]](#)

**Table 5-598. VLCD\_VLD\_CTL**

|                         |                                           |                 |       |  |  |
|-------------------------|-------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 10B4                               | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 10B4                               |                 |       |  |  |
| <b>Description</b>      | This register controls the VLD operations |                 |       |  |  |
| <b>Type</b>             | RW                                        |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DCYLEAD DCUVLEAD AC0LEAD AC1LEAD DCYSYMLEN DCUVSYMLEN AC0SYMLEN AC1SYMLEN |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                  | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------|------|-------|
| 31:8 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                          | RW   | 0x00  |
| 7    | DCYLEAD    | This bit signifies that the UVLD is expecting a 1 leading Huffman table for the DC Y table.  | RW   | 0x0   |
| 6    | DCUVLEAD   | This bit signifies that the UVLD is expecting a 1 leading Huffman table for the DC UV table. | RW   | 0x0   |
| 5    | AC0LEAD    | This bit signifies that the UVLD is expecting a 1 leading Huffman table for the AC0 table.   | RW   | 0x0   |
| 4    | AC1LEAD    | This bit signifies that the UVLD is expecting a 1 leading Huffman table for the AC1 table.   | RW   | 0x0   |
| 3    | DCYSYMLEN  | Decoded symbol bit length in DC Y table<br>0: 12-bit symbol<br>1: 11-bit symbol              | RW   | 0x0   |
| 2    | DCUVSYMLEN | Decoded symbol bit length in DC UV table<br>0: 12-bit symbol<br>1: 11-bit symbol             | RW   | 0x0   |

| Bits | Field Name | Description                                                                    | Type | Reset |
|------|------------|--------------------------------------------------------------------------------|------|-------|
| 1    | AC0SYMLEN  | Decoded symbol bit length in AC0 table<br>0: 12-bit symbol<br>1: 11-bit symbol | RW   | 0x-   |
| 0    | AC1SYMLEN  | Decoded symbol bit length in AC1 table<br>0: 12-bit symbol<br>1: 11-bit symbol | RW   | 0x-   |

**Table 5-599. Register Call Summary for Register VLCD\_VLD\_CTL**

I/VA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-600. VLCD\_VLD\_NRBIT\_DC**

| Address Offset     | 0x0000 10B8 |                                                             | Physical Address | 0x0008 10B8 | Instance | iVLCD |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------------|-------------|-------------------------------------------------------------|------------------|-------------|----------|-------|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Description</b> |             | This register controls the UVLD operations for the DC terms |                  |             |          |       |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>        |             | RW                                                          |                  |             |          |       |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                    |             |                                                             |                  |             |          |       |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED           |             |                                                             |                  |             |          |       |    |    |    |    |    |    |    |    |    | Y  |    | RESERVED |    | UV |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                | Type | Reset |
|-------|------------|------------------------------------------------------------|------|-------|
| 31:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0        | RW   | 0x0   |
| 12:8  | Y          | Number of bits to test for the DC Y term as input to UVLD  | RW   | 0x00  |
| 7:5   | RESERVED   | Write 0s for future compatibility<br>Read returns 0        | RW   | 0x0   |
| 4:0   | UV         | Number of bits to test for the DC UV term as input to UVLD | RW   | 0x00  |

**Table 5-601. Register Call Summary for Register VLCD\_VLD\_NRBIT\_DC**

I/VA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for VLD Operation: \[0\]](#)

I/VA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[1\]](#)

**Table 5-602. VLCD\_VLD\_NRBIT\_AC**

| Address Offset     | 0x0000 10BC |                                                             | Physical Address | 0x0008 10BC | Instance | iVLCD |    |    |    |    |    |    |    |    |    |     |    |          |    |     |    |   |   |   |   |   |   |   |   |   |   |
|--------------------|-------------|-------------------------------------------------------------|------------------|-------------|----------|-------|----|----|----|----|----|----|----|----|----|-----|----|----------|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Description</b> |             | This register controls the UVLD operations for the AC terms |                  |             |          |       |    |    |    |    |    |    |    |    |    |     |    |          |    |     |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>        |             | RW                                                          |                  |             |          |       |    |    |    |    |    |    |    |    |    |     |    |          |    |     |    |   |   |   |   |   |   |   |   |   |   |
|                    |             |                                                             |                  |             |          |       |    |    |    |    |    |    |    |    |    |     |    |          |    |     |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED           |             |                                                             |                  |             |          |       |    |    |    |    |    |    |    |    |    | AC0 |    | RESERVED |    | AC1 |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------|-------------|--------------|
| 31:13       | RESERVED          | Write 0s for future compatibility<br>Read returns 0      | RW          | 0x0          |
| 12:8        | AC0               | Number of bits to test for the AC0 term as input to UVLD | RW          | 0x00         |
| 7:5         | RESERVED          | Write 0s for future compatibility<br>Read returns 0      | RW          | 0x0          |
| 4:0         | AC1               | Number of bits to test for the AC1 term as input to UVLD | RW          | 0x00         |

**Table 5-603. Register Call Summary for Register VLCD\_VLD\_NRBIT\_AC**

IVA2.2 Subsystem Basic Programming Model

- Setting Up Registers for VLD Operation: [0]

---

IVA2.2 Subsystem Register Manual

- iVLCD Register Mapping Summary: [1]

**Table 5-604. VLCD BITS BPTR**

**Table 5-605. Register Call Summary for Register VLCD BITS BPTR**

---

IVA2.2 Subsystem Basic Programming Model

- Setting Up Registers for VLC Operation: [0]
  - Setting Up Registers for VLD Operation: [1]
  - Calculating the Number of Bits Processed During a VLD Run: [2] [3]

---

IVA2.2 Subsystem Register Manual

- iVLCD Register Mapping Summary: [4]

**Table 5-606. VLCD\_BITS\_WORD**

| Bits | Field Name | Description |
|------|------------|-------------|
|------|------------|-------------|

|       |          |                                                     |    |        |
|-------|----------|-----------------------------------------------------|----|--------|
| 31:16 | RESERVED | Write 0s for future compatibility<br>Read returns 0 | RW | 0x0000 |
| 15:0  | WORD     | Last bitstream                                      | RW | 0x0000 |

**Table 5-607. Register Call Summary for Register VLCD\_BITS\_WORD**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-608. VLCD\_BYTE\_ALIGN**

|                         |                |                 |       |  |  |
|-------------------------|----------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 10C8    | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 10C8    |                 |       |  |  |
| <b>Description</b>      | VLC byte align |                 |       |  |  |
| <b>Type</b>             | RW             |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                   | Type | Reset  |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:2 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                           | RW   | 0x0000 |
| 1    | ENABLE     | VLC: When set to '1' , it enable byte align in current processing macro block<br>VLD: When set to '1', it means current processing bitstream is byte aligned. | RW   | 0x0    |
| 0    | DEFAULT    | VLC: When byte-align is selected (ENABLE bit set to '1'), last byte is filled with this bit.<br>VLD: No meaning                                               | RW   | 0x0    |

**Table 5-609. Register Call Summary for Register VLCD\_BYTE\_ALIGN**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-610. VLCD\_HEAD\_ADDR**

|                         |                                                                     |                 |       |  |
|-------------------------|---------------------------------------------------------------------|-----------------|-------|--|
| <b>Address Offset</b>   | 0x0000 10CC                                                         | <b>Instance</b> | iVLCD |  |
| <b>Physical Address</b> | 0x0008 10CC                                                         |                 |       |  |
| <b>Description</b>      | This register sets the base address for header data to be inserted. |                 |       |  |
| <b>Type</b>             | RW                                                                  |                 |       |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |        |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | HDADDR |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                       | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                               | RW   | 0x00  |
| 10:0  | HDADDR     | Base address for header data to be inserted<br>Must be align on a 32-bit boundary | RW   | 0x000 |

**Table 5-611. Register Call Summary for Register VLCD\_HEAD\_ADDR**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-612. VLCD\_HEAD\_NUM**

|                         |                                                              |                 |       |  |  |
|-------------------------|--------------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 10D0                                                  | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 10D0                                                  |                 |       |  |  |
| <b>Description</b>      | This register sets the number of header data to be inserted. |                 |       |  |  |
| <b>Type</b>             | RW                                                           |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | HDNUM |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                         | Type | Reset |
|-------|------------|-----------------------------------------------------|------|-------|
| 31:10 | RESERVED   | Write 0s for future compatibility<br>Read returns 0 | RW   | 0x00  |
| 9:0   | HDNUM      | Number of header data to be inserted<br>1 to 1023   | RW   | 0x000 |

**Table 5-613. Register Call Summary for Register VLCD\_HEAD\_NUM**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-614. VLCD\_QIQ\_CONFIGj**

|                         |                                                |                 |       |  |  |
|-------------------------|------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 10D4 + (0x4*j)                          | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 10D4 + (0x4*j)                          |                 |       |  |  |
| <b>Description</b>      | This register sets the Q/IQ config for block i |                 |       |  |  |
| <b>Type</b>             | RW                                             |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |          |      |          |       |          |       |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----------|------|----------|-------|----------|-------|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SCANMODE | RESERVED | QSEL | RESERVED | IQSEL | RESERVED | DCSEL |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                     | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                             | RW   | 0x0000 |
| 15:12 | SCANMODE   | Sets the scan mode (VLC/VLD)<br>00 Linear scan<br>01 Zig-Zag scan<br>10 Alternate vertical scan<br>11 Alternate horizontal scan | RW   | 0x0    |
| 11    | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                             | RW   | 0x0    |
| 10:8  | QSEL       | Quantization matrix selector<br>1 of 8 banks                                                                                    | RW   | 0x0    |
| 7     | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                             | RW   | 0x0    |
| 6:4   | IQSEL      | Inverse quantization matrix selector<br>1 of 8 banks                                                                            | RW   | 0x0    |
| 3     | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                             | RW   | 0x0    |
| 2:0   | DCSEL      | DC predictor selector<br>1 of 6 banks                                                                                           | RW   | 0x0    |

**Table 5-615. Register Call Summary for Register VLCD\_QIQ\_CONFIGj**


---

 IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for Q/IQ Operation: \[0\]](#)
- 

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[1\]](#)
- 

**Table 5-616. VLCD\_VLD\_ERRCTL**

|                       |                                               |                         |             |                 |       |
|-----------------------|-----------------------------------------------|-------------------------|-------------|-----------------|-------|
| <b>Address Offset</b> | 0x0000 10EC                                   | <b>Physical Address</b> | 0x0008 10EC | <b>Instance</b> | iVLCD |
| <b>Description</b>    | This register control the VLCD error enables. |                         |             |                 |       |
| <b>Type</b>           | RW                                            |                         |             |                 |       |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                        | Type | Reset  |
|------|------------|----------------------------------------------------------------------------------------------------|------|--------|
| 31:3 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                | RW   | 0x0000 |
| 2    | EOBENABLE  | EOB error control<br>0: Off<br>1: On                                                               | RW   | 0x1    |
| 1    | VLDENABLE  | VLD error control. When JPEG or MPEG1/2 mode, thisbit should be set to 0 (off).<br>0: Off<br>1: On | RW   | 0x0    |
| 0    | UVLDENABLE | UVLD error control<br>0: Off<br>1: On                                                              | RW   | 0x0    |

**Table 5-617. Register Call Summary for Register VLCD\_VLD\_ERRCTL**


---

 IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)
- 

**Table 5-618. VLCD\_VLD\_ERRSTAT**

|                       |                                   |                         |             |                 |       |
|-----------------------|-----------------------------------|-------------------------|-------------|-----------------|-------|
| <b>Address Offset</b> | 0x0000 10F0                       | <b>Physical Address</b> | 0x0008 10F0 | <b>Instance</b> | iVLCD |
| <b>Description</b>    | This register reports VLCD errors |                         |             |                 |       |
| <b>Type</b>           | R                                 |                         |             |                 |       |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                        | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:4 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                | R    | 0x000 |
| 3    | RINGBUFF   | Ring buffer overflow status                                                                                        | R    | 0x0   |
| 2    | EOB        | EOB error                                                                                                          | R    | 0x0   |
| 1    | VLD        | VLD error<br>JPEG: Goes "1" when found FDX code at the end of MB<br>H.263, MPEG4: Goes "1" when found an FLC error | R    | 0x0   |
| 0    | UVLD       | UVLD error                                                                                                         | R    | 0x0   |

**Table 5-619. Register Call Summary for Register VLCD\_VLD\_ERRSTAT**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-620. VLCD\_RING\_START**

|                         |                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|---------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 10F4                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x0008 10F4                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | This register sets the ring buffer start address. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RSTART |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                         | Type | Reset  |
|-------|------------|-----------------------------------------------------|------|--------|
| 31:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0 | RW   | 0x0    |
| 12:0  | RSTART     | Ring buffer start address                           | RW   | 0x0000 |

**Table 5-621. Register Call Summary for Register VLCD\_RING\_START**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for VLC Operation: \[0\]](#)
- [Setting Up Registers for VLD Operation: \[1\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[2\]](#)

**Table 5-622. VLCD\_RING\_END**

|                         |                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|-------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 10F8                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x0008 10F8                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | This register sets the ring buffer end address. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | REND |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                  | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                                                          | RW   | 0x0    |
| 12:0  | REND       | Ring buffer end address<br><br>VLC:<br>When output pointer reaches the end address, pointer starts at start pointer automatically.<br><br>VLD:<br>When input pointer reaches the end address, pointer starts at start pointer automatically. | RW   | 0x1FFF |

**Table 5-623. Register Call Summary for Register VLCD\_RING\_END**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for VLC Operation: \[0\]](#)
- [Setting Up Registers for VLD Operation: \[1\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[2\]](#)

**Table 5-624. VLCD\_CTRL**

| Address Offset | 0x0000 10FC           |  | Physical Address | 0x0008 10FC | Instance | iVLCD |
|----------------|-----------------------|--|------------------|-------------|----------|-------|
| Description    | VLCD control register |  |                  |             | Type     | RW    |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|-----------|--------|----------|-----------|--------|-------|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ENDIAN | VLDALGSEL | MPGMOD | SCANTYPE | MP2ENCDEC | MP4ESC | CLKON |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                    | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:8 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                            | RW   | 0x00  |
| 7    | ENDIAN     | Endianism control<br>0: Big endian<br>1: Little endian                                                                                                                                                         | RW   | 0x0   |
| 6    | VLDALGSEL  | VLD algorithm selection<br>0: Same as DM270 or before (all except MPEG4 RVLC, H.264, and WMV9)<br>1: New algorithm for DM275 or after (must for MPEG4 RVLC, can also be used for others except H.264 and WMV9) | RW   | 0x0   |
| 5:4  | MPGMOD     | Additional MPEG mode<br>0: MPEG4 normal<br>1: MPEG4 data partitioning<br>2: MPEG4 RVLC<br>3: WMV9 (decode only)<br>Field active when <a href="#">VLCD_MODE(5:4) = MPEG4</a>                                    | RW   | 0x0   |
| 3    | SCANTYPE   | SCAN mode<br>0: SCAN type is selected by <a href="#">VLCD_MODE(9:8)</a><br>1: SCAN type is selected by Q/IQ_CONFIG1 to Q/IQ_CONFIG5                                                                            | RW   | 0x0   |
| 2    | MP2ENCDEC  | MPEG2 encode/decode<br>0: MPEG1 <a href="#">VLCD_MODE(5:4) = MPEG1</a><br>1: MPEG2 <a href="#">VLCD_MODE(5:4) = MPEG1</a>                                                                                      | RW   | 0x0   |
| 1    | MP4ESC     | MPEG4 escape encoding<br>0: Escape3 only(DSC25)<br>1: Escape1,2 and 3                                                                                                                                          | RW   | 0x0   |

| Bits | Field Name | Description                                     | Type | Reset |
|------|------------|-------------------------------------------------|------|-------|
| 0    | CLKON      | Dynamic clock on/off control<br>0: On<br>1: Off | RW   | 0x0   |

**Table 5-625. Register Call Summary for Register VLCD\_CTRL**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)
- [iVLCD Register Descriptions: \[1\] \[2\]](#)

**Table 5-626. VLCD\_VLD\_PREFIX\_DC**

|                         |                                                 |                       |                 |             |       |
|-------------------------|-------------------------------------------------|-----------------------|-----------------|-------------|-------|
| Address Offset          | 0x0000 1100                                     | Physical Address      | 0x0008 1100     | Instance    | iVLCD |
| Description             | This register sets the ring buffer end address. | Type                  | RW              |             |       |
|                         |                                                 |                       |                 |             |       |
| 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 |             |       |
|                         |                                                 |                       |                 |             |       |
|                         | RESERVED                                        | NBITS_DC_Y            | RESERVED        | NBITS_DC_UV |       |

| Bits  | Field Name  | Description                                                                             | Type | Reset |
|-------|-------------|-----------------------------------------------------------------------------------------|------|-------|
| 31:13 | RESERVED    | Write 0s for future compatibility<br>Read returns 0                                     | RW   | 0x0   |
| 12:8  | NBITS_DC_Y  | Sets the number of prefix bits of control table for the DCY term as input to the UVLD.  | RW   | 0x00  |
| 7:5   | RESERVED    | Write 0s for future compatibility<br>Read returns 0                                     | RW   | 0x0   |
| 4:0   | NBITS_DC_UV | Sets the number of prefix bits of control table for the DCUV term as input to the UVLD. | RW   | 0x00  |

**Table 5-627. Register Call Summary for Register VLCD\_VLD\_PREFIX\_DC**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-628. VLCD\_VLD\_PREFIX\_AC**

|                         |                                                 |                       |                 |           |       |
|-------------------------|-------------------------------------------------|-----------------------|-----------------|-----------|-------|
| Address Offset          | 0x0000 1104                                     | Physical Address      | 0x0008 1104     | Instance  | iVLCD |
| Description             | This register sets the ring buffer end address. | Type                  | RW              |           |       |
|                         |                                                 |                       |                 |           |       |
| 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 |           |       |
|                         |                                                 |                       |                 |           |       |
|                         | RESERVED                                        | NBITS_AC0             | RESERVED        | NBITS_AC1 |       |

| Bits  | Field Name | Description                                                                            | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------|------|-------|
| 31:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                    | RW   | 0x0   |
| 12:8  | NBITS_AC0  | Sets the number of prefix bits of control table for the AC0 term as input to the UVLD. | RW   | 0x00  |
| 7:5   | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                    | RW   | 0x0   |
| 4:0   | NBITS_AC1  | Sets the number of prefix bits of control table for the AC1 term as input to the UVLD. | RW   | 0x00  |

**Table 5-629. Register Call Summary for Register VLCD\_VLD\_PREFIX\_AC**

IVA2.2 Subsystem Register Manual

- [iLCD Register Mapping Summary: \[0\]](#)

**Table 5-630. VLCD\_WMV9\_CONFIG**

| Address Offset     | 0x0000 1108 |                                            | Physical Address | 0x0008 1108 | Instance | iLCD |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |   |          |   |        |   |        |   |          |   |          |  |
|--------------------|-------------|--------------------------------------------|------------------|-------------|----------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|---|----------|---|--------|---|--------|---|----------|---|----------|--|
| <b>Description</b> |             | This register controls the WMV9 parameters |                  |             |          |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |   |          |   |        |   |        |   |          |   |          |  |
| <b>Type</b>        |             | RW                                         |                  |             |          |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |   |          |   |        |   |        |   |          |   |          |  |
| 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        |  |
| RESERVED           |             |                                            |                  |             |          |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BLNSYM |   | RESERVED |   | PQUANT |   | QSCALE |   | INTRAFRT |   | INTERFRT |  |

| Bits  | Field Name | Description                                                                                         | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------------|------|-------|
| 31:10 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                 | RW   | 0x0   |
| 9:8   | BLNSYM     | Specifies the number of symbols in a block<br><br>0x0: 64<br>0x1: 32<br>0x2: 16<br>0x3: Reserved    | RW   | 0x0   |
| 7     | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                  | RW   | 0x0   |
| 6     | PQUANT     | Setting this bit to '1' specify: PQUANT>=8, I-Frame                                                 | RW   | 0x0   |
| 5:4   | QSCALE     | Quantization Scale                                                                                  | RW   | 0x0   |
| 3:2   | INTRAFRT   | Intra frame rate type<br><br>0x0: low motion<br>0x1: high motion<br>0x2: mid rate<br>0x3: high rate | RW   | 0x0   |
| 1:0   | INTERFRT   | Inter frame rate type<br><br>0x0: low motion<br>0x1: high motion<br>0x2: mid rate<br>0x3: high rate | RW   | 0x0   |

**Table 5-631. Register Call Summary for Register VLCD\_WMV9\_CONFIG**

IVA2.2 Subsystem Register Manual

- [iLCD Register Mapping Summary: \[0\]](#)

**Table 5-632. VLCD\_FIRST\_FRAME**

|                         |                                                                    |                         |                 |                 |            |
|-------------------------|--------------------------------------------------------------------|-------------------------|-----------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 110C                                                        | <b>Physical Address</b> | 0x0008 110C     | <b>Instance</b> | iVLCD      |
| <b>Description</b>      | This register specifies the first case of escape mode 3 in a frame |                         |                 |                 |            |
| <b>Type</b>             | RW                                                                 |                         |                 |                 |            |
| 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 |                 |            |
| RESERVED                |                                                                    |                         |                 |                 |            |
|                         |                                                                    |                         |                 |                 | FIRSTFRAME |

| Bits | Field Name | Description                                                                                                           | Type | Reset  |
|------|------------|-----------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:1 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0000 |
| 0    | FIRSTFRAME | Setting "1" specifies the first case of escape mode 3 in a frame, this register is cleared when found a ESCAPE3(WMV9) | RW   | 0x0    |

**Table 5-633. Register Call Summary for Register VLCD\_FIRST\_FRAME**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-634. VLCD\_H264\_MODE**

|                         |                                                 |                         |                 |                 |                         |
|-------------------------|-------------------------------------------------|-------------------------|-----------------|-----------------|-------------------------|
| <b>Address Offset</b>   | 0x0000 1110                                     | <b>Physical Address</b> | 0x0008 1110     | <b>Instance</b> | iVLCD                   |
| <b>Description</b>      | This register configures H264 mode of operation |                         |                 |                 |                         |
| <b>Type</b>             | RW                                              |                         |                 |                 |                         |
| 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 |                 |                         |
| RESERVED                |                                                 |                         |                 |                 |                         |
|                         |                                                 |                         |                 |                 | ISLUMA      H264SCANTAB |
|                         |                                                 |                         |                 |                 | H264CAVLCD              |

| Bits | Field Name  | Description                                                                                                                                  | Type | Reset  |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:3 | RESERVED    | Write 0s for future compatibility<br>Read returns 0                                                                                          | RW   | 0x0000 |
| 2    | ISLUMA      | 4x4, 4x8 subblock to 8x8 block conversion<br>0: linear order<br>1: stores the data as 8x8 block image<br>This register is for H.264 and WMV9 | RW   | 0x0    |
| 1    | H264SCANTAB | Setting 1 selects the H.264 SCAN table(IQ mode)                                                                                              | RW   | 0x0    |
| 0    | H264CAVLCD  | Setting 1 enables the H.264 CAVLC decoding                                                                                                   | RW   | 0x0    |

**Table 5-635. Register Call Summary for Register VLCD\_H264\_MODE**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-636. VLCD\_NRBITSTH**

|                         |                                                                              |                 |       |  |  |
|-------------------------|------------------------------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 1114                                                                  | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 1114                                                                  |                 |       |  |  |
| <b>Description</b>      | This register sets the threshold level of "nrbits" (number of bits) in WMV9. |                 |       |  |  |
| <b>Type</b>             | RW                                                                           |                 |       |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |          |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----------|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | NRBITSTH |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                               | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:4 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                                                                                       | RW   | 0x000 |
| 3:0  | NRBITSTH   | Threshold level of "nrbits" (number of bits) in WMV9 decoding.<br>When the "nrbits" gotten from the Huffman table is greater than this threshold value, UVLD error happens. Current VLD algorithm defines the maximum "nrbits" is 6. No need to modify the default value. | RW   | 0x6   |

**Table 5-637. Register Call Summary for Register VLCD\_NRBITSTH**

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[0\]](#)

**Table 5-638. CAVLC\_GO\_REG**

|                         |                       |                 |       |  |  |
|-------------------------|-----------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 1140           | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 1140           |                 |       |  |  |
| <b>Description</b>      | CAVLC enable register |                 |       |  |  |
| <b>Type</b>             | RW                    |                 |       |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CAVLC_GO |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                         | Type | Reset  |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:1 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                 | RW   | 0x0000 |
| 0    | CAVLC_GO   | Setting this bit will start CAVLC module. This bit is high while CAVLC module is running and cleared automatically after the completion of the job. | RW   | 0x0    |

**Table 5-639. Register Call Summary for Register CAVLC\_GO\_REG**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for CAVLC Operation: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[1\]](#)

**Table 5-640. CAVLC\_MBTYPE**

|                         |                                             |                         |                 |                 |           |
|-------------------------|---------------------------------------------|-------------------------|-----------------|-----------------|-----------|
| <b>Address Offset</b>   | 0x0000 1144                                 | <b>Physical Address</b> | 0x0008 1144     | <b>Instance</b> | iVLCD     |
| <b>Description</b>      | This register controls the macro-block type |                         |                 |                 |           |
| <b>Type</b>             | RW                                          |                         |                 |                 |           |
| 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 |                 |           |
|                         |                                             |                         |                 | RESERVED        | CODBLKPAT |
|                         |                                             |                         |                 | INTRA1616       | RESERVED  |

| Bits | Field Name | Description                                             | Type | Reset |
|------|------------|---------------------------------------------------------|------|-------|
| 31:9 | RESERVED   | Write 0s for future compatibility<br>Read returns 0     | RW   | 0x00  |
| 8    | INTRA1616  | Set high when intra16x16 macroblock                     | RW   | 0x0   |
| 7:6  | RESERVED   | Write 0s for future compatibility<br>Read returns 0     | RW   | 0x0   |
| 5:0  | CODBLKPAT  | Set coded block pattern as the H.264 standard describes | RW   | 0x00  |

**Table 5-641. Register Call Summary for Register CAVLC\_MBTYPE**

- IVA2.2 Subsystem Basic Programming Model
  - [Setting Up Registers for CAVLC Operation: \[0\]](#)

- IVA2.2 Subsystem Register Manual
  - [iVLCD Register Mapping Summary: \[1\]](#)

**Table 5-642. CAVLC\_RBTOP**

|                         |                                                |                         |                 |                 |       |
|-------------------------|------------------------------------------------|-------------------------|-----------------|-----------------|-------|
| <b>Address Offset</b>   | 0x0000 1148                                    | <b>Physical Address</b> | 0x0008 1148     | <b>Instance</b> | iVLCD |
| <b>Description</b>      | This register sets the Ring Buffer Top Pointer |                         |                 |                 |       |
| <b>Type</b>             | RW                                             |                         |                 |                 |       |
| 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 |                 |       |
|                         |                                                |                         |                 | RESERVED        | RBTOP |

| Bits  | Field Name | Description                                                                                                                                                                          | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                                                  | RW   | 0x0    |
| 12:0  | RBTOP      | Set Ring Buffer Top pointer in Image Buffer. The value must be even.<br>If IBUF0 is selected in <a href="#">CAVLC_IBUFSEL</a> , bit 12 select if IBUF0_A (0) or IBUF0_B (1) is used. | RW   | 0x0000 |

**Table 5-643. Register Call Summary for Register CAVLC\_RBTOP**

- IVA2.2 Subsystem Basic Programming Model
  - [Setting Up Registers for CAVLC Operation: \[0\] \[1\]](#)

- IVA2.2 Subsystem Register Manual
  - [iVLCD Register Mapping Summary: \[2\]](#)

**Table 5-644. CAVLC\_RBEND**

|                         |                                                |                 |       |  |  |
|-------------------------|------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 114C                                    | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 114C                                    |                 |       |  |  |
| <b>Description</b>      | This register sets the Ring Buffer End Pointer |                 |       |  |  |
| <b>Type</b>             | RW                                             |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RBEND |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                        | RW   | 0x0    |
| 12:0  | RBEND      | Set Ring Buffer End pointer in Image Buffer. The value must be even. RBEND+1 will be the final word address of Ring Buffer.<br><a href="#">CAVLC_RBEND</a> | RW   | 0x0000 |

**Table 5-645. Register Call Summary for Register CAVLC\_RBEND**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for CAVLC Operation: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[1\]](#)
- [iVLCD Register Descriptions: \[2\]](#)

**Table 5-646. CAVLC\_BUFPTR**

|                         |                                                |                 |       |  |  |
|-------------------------|------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 1150                                    | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 1150                                    |                 |       |  |  |
| <b>Description</b>      | This register sets the bitstream start pointer |                 |       |  |  |
| <b>Type</b>             | RW                                             |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BUFPTR |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                      | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:13 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                                                                              | RW   | 0x0    |
| 12:0  | BUFPTR     | Set a pointer inside Ring Buffer from which bitstream will be written.<br>After the completion, the final pointer is shown. Must be even number.<br>If IBUF0 is selected in <a href="#">CAVLC_IBUFSEL</a> , bit 12 select if IBUF0_A (0) or IBUF0_B (1) is used. | RW   | 0x0000 |

**Table 5-647. Register Call Summary for Register CAVLC\_BUFPTR**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for CAVLC Operation: \[0\] \[1\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[2\]](#)

**Table 5-648. CAVLC\_BITPTR**

|                         |                                                                       |                 |       |  |  |
|-------------------------|-----------------------------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 1154                                                           | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 1154                                                           |                 |       |  |  |
| <b>Description</b>      | This register sets the number of valid MSBs in stream word registers. |                 |       |  |  |
| <b>Type</b>             | RW                                                                    |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |        |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|--------|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | BITPTR |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                          | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:5 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                  | RW   | 0x000 |
| 4:0  | BITPTR     | Set the number of valid MSBs in stream word registers. The bitstream to be generated follows the valid bits. It shows the number of valid MSBs in stream word registers after completion of the job. | RW   | 0x00  |

**Table 5-649. Register Call Summary for Register CAVLC\_BITPTR**

- IVA2.2 Subsystem Basic Programming Model
- [Setting Up Registers for CAVLC Operation: \[0\] \[1\]](#)
- IVA2.2 Subsystem Register Manual
- [iVLCD Register Mapping Summary: \[2\]](#)

**Table 5-650. CAVLC\_STRMWDU**

|                         |                                           |                 |       |  |  |
|-------------------------|-------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 1158                               | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 1158                               |                 |       |  |  |
| <b>Description</b>      | Upper half of 32-bit Stream Word Register |                 |       |  |  |
| <b>Type</b>             | RW                                        |                 |       |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---------|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | STRMWDU |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                      | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                                              | RW   | 0x0000 |
| 15:0  | STRMWDU    | Upper half of 32-bit Stream Word Register. Write bits from MSB so that bitstream to be generated follows them. After the completion of the job, remaining bits, which is less than 32 and not written to Image Buffer, is shown. | RW   | 0x0000 |

**Table 5-651. Register Call Summary for Register CAVLC\_STRMWDU**

- IVA2.2 Subsystem Basic Programming Model
- [Setting Up Registers for CAVLC Operation: \[0\] \[1\] \[2\]](#)
- IVA2.2 Subsystem Register Manual
- [iVLCD Register Mapping Summary: \[3\]](#)

**Table 5-652. CAVLC\_STRMWDL**

|                         |                                           |                 |       |  |  |
|-------------------------|-------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 115C                               | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 115C                               |                 |       |  |  |
| <b>Description</b>      | Lower half of 32-bit Stream Word Register |                 |       |  |  |
| <b>Type</b>             | RW                                        |                 |       |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | STRMWDL |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:16       | RESERVED          | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                                              | RW          | 0x0000       |
| 15:0        | STRMWDL           | Lower half of 32-bit Stream Word Register. Write bits from MSB so that bitstream to be generated follows them. After the completion of the job, remaining bits, which is less than 32 and not written to Image Buffer, is shown. | RW          | 0x0000       |

**Table 5-653. Register Call Summary for Register CAVLC\_STRMWDL**

- 
- IV A2.2 Subsystem Basic Programming Model
- [Setting Up Registers for CAVLC Operation: \[0\]](#) [\[1\]](#)
- 
- IV A2.2 Subsystem Register Manual
- [iVLCD Register Mapping Summary: \[2\]](#)
- 

**Table 5-654. CAVLC\_HDPTTR**

|                         |                                                |                 |       |  |  |
|-------------------------|------------------------------------------------|-----------------|-------|--|--|
| <b>Address Offset</b>   | 0x0000 1160                                    | <b>Instance</b> | iVLCD |  |  |
| <b>Physical Address</b> | 0x0008 1160                                    |                 |       |  |  |
| <b>Description</b>      | This register sets Huffman memory read pointer |                 |       |  |  |
| <b>Type</b>             | RW                                             |                 |       |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | HDPTTR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:12       | RESERVED          | Write 0s for future compatibility<br>Read returns 0                                                                                                               | RW          | 0x0          |
| 11:0        | HDPTTR            | Set a pointer in Huffman memory from which CAVLC will read pairs of an MB header symbol and its length, and pack the symbols into bitstream. Must be even number. | RW          | 0x000        |

**Table 5-655. Register Call Summary for Register CAVLC\_HDPTTR**

- 
- IV A2.2 Subsystem Basic Programming Model
- [Setting Up Registers for CAVLC Operation: \[0\]](#)
- 
- IV A2.2 Subsystem Register Manual
- [iVLCD Register Mapping Summary: \[1\]](#)
-

**Table 5-656. CAVLC\_HDCOUNT**

| <b>Address Offset</b>                                                                       | 0x0000 1164                                                                  | <b>Instance</b>                                                                         | iVLCD   |
|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|---------|
| <b>Physical Address</b>                                                                     | 0x0008 1164                                                                  |                                                                                         |         |
| <b>Description</b>                                                                          | This register sets the number of MB header pairs to be inserted to bitstream |                                                                                         |         |
| <b>Type</b>                                                                                 | RW                                                                           |                                                                                         |         |
| 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 |                                                                              |                                                                                         |         |
| RESERVED                                                                                    |                                                                              |                                                                                         | HDCOUNT |
| Bits                                                                                        | Field Name                                                                   | Description                                                                             | Type    |
| 31:10                                                                                       | RESERVED                                                                     | Write 0s for future compatibility<br>Read returns 0                                     | RW      |
| 9:0                                                                                         | HDCOUNT                                                                      | Set the number of MB header pairs to be inserted to bitstream. The number is 0 to 1023. | RW      |
|                                                                                             |                                                                              |                                                                                         | 0x000   |

**Table 5-657. Register Call Summary for Register CAVLC\_HDCOUNT**

|                                                                 |  |
|-----------------------------------------------------------------|--|
| IVA2.2 Subsystem Basic Programming Model                        |  |
| • <a href="#">Setting Up Registers for CAVLC Operation: [0]</a> |  |
| IVA2.2 Subsystem Register Manual                                |  |
| • <a href="#">iVLCD Register Mapping Summary: [1]</a>           |  |

**Table 5-658. CAVLC\_NAPTR**

| <b>Address Offset</b>                                                                       | 0x0000 1168                                        | <b>Instance</b>                                                                                                                                                                                               | iVLCD |
|---------------------------------------------------------------------------------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| <b>Physical Address</b>                                                                     | 0x0008 1168                                        |                                                                                                                                                                                                               |       |
| <b>Description</b>                                                                          | This register sets Huffman memory write nA pointer |                                                                                                                                                                                                               |       |
| <b>Type</b>                                                                                 | RW                                                 |                                                                                                                                                                                                               |       |
| 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 |                                                    |                                                                                                                                                                                                               |       |
| RESERVED                                                                                    |                                                    |                                                                                                                                                                                                               | NAPTR |
| Bits                                                                                        | Field Name                                         | Description                                                                                                                                                                                                   | Type  |
| 31:12                                                                                       | RESERVED                                           | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                           | RW    |
| 11:0                                                                                        | NAPTR                                              | Set a pointer in Huffman memory from which nAs are stored. Must be even. After the completion of the job, the number of coefficients of 4x4-blocks in the most right column will be stored from this pointer. | RW    |
|                                                                                             |                                                    |                                                                                                                                                                                                               | 0x000 |

**Table 5-659. Register Call Summary for Register CAVLC\_NAPTR**

|                                                                 |  |
|-----------------------------------------------------------------|--|
| IVA2.2 Subsystem Basic Programming Model                        |  |
| • <a href="#">Setting Up Registers for CAVLC Operation: [0]</a> |  |
| IVA2.2 Subsystem Register Manual                                |  |
| • <a href="#">iVLCD Register Mapping Summary: [1]</a>           |  |

**Table 5-660. CAVLC\_NBPTR**

| <b>Address Offset</b>   | 0x0000 116C                                        | <b>Instance</b>                                                                                                                                                                                        | iVLCD           |  |  |
|-------------------------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|
| <b>Physical Address</b> | 0x0008 116C                                        |                                                                                                                                                                                                        |                 |  |  |
| <b>Description</b>      | This register sets Huffman memory write nB pointer |                                                                                                                                                                                                        |                 |  |  |
| <b>Type</b>             | RW                                                 |                                                                                                                                                                                                        |                 |  |  |
| 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 |  |  |
| RESERVED                |                                                    |                                                                                                                                                                                                        | NBPTR           |  |  |
| Bits                    | Field Name                                         | Description                                                                                                                                                                                            | Type            |  |  |
| 31:12                   | RESERVED                                           | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                    | RW<br>0x0       |  |  |
| 11:0                    | NBPTR                                              | Set a pointer in Huffman memory from which nBs are stored. Must be even. After the completion of the job, the number of coefficients of 4x4-blocks in the lowest row will be stored from this pointer. | RW<br>0x000     |  |  |

**Table 5-661. Register Call Summary for Register CAVLC\_NBPTR**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for CAVLC Operation: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[1\]](#)

**Table 5-662. CAVLC\_COEFFPTR**

| <b>Address Offset</b>   | 0x0000 1170                                    | <b>Instance</b>                                                                                                                                                                                          | iVLCD           |  |  |
|-------------------------|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|
| <b>Physical Address</b> | 0x0008 1170                                    |                                                                                                                                                                                                          |                 |  |  |
| <b>Description</b>      | This register sets coefficients memory pointer |                                                                                                                                                                                                          |                 |  |  |
| <b>Type</b>             | RW                                             |                                                                                                                                                                                                          |                 |  |  |
| 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 |  |  |
| RESERVED                |                                                |                                                                                                                                                                                                          | COEFFPTR        |  |  |
| Bits                    | Field Name                                     | Description                                                                                                                                                                                              | Type            |  |  |
| 31:13                   | RESERVED                                       | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                      | RW<br>0x0       |  |  |
| 12:0                    | COEFFPTR                                       | Set a pointer in Image Buffer from which residual coefficients are stored. Must be even.<br>If IBUF0 is selected in <a href="#">CAVLC_IBUFSEL</a> , bit 12 select if IBUF0_A (0) or IBUF0_B (1) is used. | RW<br>0x0000    |  |  |

**Table 5-663. Register Call Summary for Register CAVLC\_COEFFPTR**

IVA2.2 Subsystem Basic Programming Model

- [Setting Up Registers for CAVLC Operation: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [iVLCD Register Mapping Summary: \[1\]](#)

**Table 5-664. CAVLC\_IBUFSEL**

|                         |                                                                          |                         |                 |                 |                                              |
|-------------------------|--------------------------------------------------------------------------|-------------------------|-----------------|-----------------|----------------------------------------------|
| <b>Address Offset</b>   | 0x0000 1174                                                              | <b>Physical Address</b> | 0x0008 1174     | <b>Instance</b> | iVLCD                                        |
| <b>Description</b>      | This register controls selects IBUF0 or IBUF1 and controls byte swapping |                         |                 |                 |                                              |
| <b>Type</b>             | RW                                                                       |                         |                 |                 |                                              |
| 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 | RESERVED        | BYTESWP<br>RESERVED<br>INPRTSEL<br>OUTPRTSEL |
|                         |                                                                          |                         |                 |                 |                                              |

| Bits | Field Name | Description                                                                                                                        | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:5 | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                | RW   | 0x000 |
| 4    | BYTESWP    | Stream byte swap control bit.<br>0: Normal<br>1: Swap the two bytes in each 16-bit word.                                           | RW   | 0x0   |
| 3:2  | RESERVED   | Write 0s for future compatibility<br>Read returns 0                                                                                | RW   | 0x0   |
| 1    | INPRTSEL   | Select input port,<br>0: ibuf0 port,<br>1: ibuf1 port.<br>Input port and output port are allowed to be assigned to the same port.  | RW   | 0x0   |
| 0    | OUTPRTSEL  | Select output port,<br>0: ibuf0 port,<br>1: ibuf1 port.<br>Input port and output port are allowed to be assigned to the same port. | RW   | 0x0   |

**Table 5-665. Register Call Summary for Register CAVLC\_IBUFSEL**

- IVA2.2 Subsystem Basic Programming Model
- [Setting Up Registers for CAVLC Operation: \[0\]](#)

- IVA2.2 Subsystem Register Manual
- [iVLCD Register Mapping Summary: \[1\]](#)
  - [iVLCD Register Descriptions: \[2\] \[3\] \[4\]](#)

**Table 5-666. CAVLC\_NUMTTL**

|                         |                          |                         |                 |                 |        |
|-------------------------|--------------------------|-------------------------|-----------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 1178              | <b>Physical Address</b> | 0x0008 1178     | <b>Instance</b> | iVLCD  |
| <b>Description</b>      | number of bits generated |                         |                 |                 |        |
| <b>Type</b>             | R                        |                         |                 |                 |        |
| 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 | RESERVED        | NUMTTL |
|                         |                          |                         |                 |                 |        |

| Bits  | Field Name | Description                                                                              | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0                                                                           | R    | 0x0000 |
| 15:0  | NUMTTL     | Showing how many bits are generated in total. Automatically cleared when the job starts. | R    | 0x0000 |

**Table 5-667. Register Call Summary for Register CAVLC\_NUMTTL**


---

 IVA2.2 Subsystem Basic Programming Model
 

- [Setting Up Registers for CAVLC Operation: \[0\]](#)

---

 IVA2.2 Subsystem Register Manual
 

- [iVLCD Register Mapping Summary: \[1\]](#)

---

**Table 5-668. CAVLC\_NUMHD**

|                         |                         |                       |                 |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 117C             | <b>Instance</b>       | iVLCD           |  |  |
| <b>Physical Address</b> | 0x0008 117C             |                       |                 |  |  |
| <b>Description</b>      |                         |                       |                 |  |  |
| <b>Type</b>             | R                       |                       |                 |  |  |
| 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 |  |  |
| RESERVED                |                         |                       | NUMHD           |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:16       | RESERVED          | Read returns 0                                                                                     | R           | 0x0000       |
| 15:0        | NUMHD             | Showing how many bits are generated from MB headers.<br>Automatically cleared when the job starts. | R           | 0x0000       |

**Table 5-669. Register Call Summary for Register CAVLC\_NUMHD**


---

 IVA2.2 Subsystem Basic Programming Model
 

- [Setting Up Registers for CAVLC Operation: \[0\]](#)

---

 IVA2.2 Subsystem Register Manual
 

- [iVLCD Register Mapping Summary: \[1\]](#)

---

**Table 5-670. CAVLC\_NUMRESI**

|                         |                                                                                                            |                       |                 |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 1180                                                                                                | <b>Instance</b>       | iVLCD           |  |  |
| <b>Physical Address</b> | 0x0008 1180                                                                                                |                       |                 |  |  |
| <b>Description</b>      | Showing how many bits are generated from residual coefficients. Automatically cleared when the job starts. |                       |                 |  |  |
| <b>Type</b>             | R                                                                                                          |                       |                 |  |  |
| 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 |  |  |
| RESERVED                |                                                                                                            |                       | NUMRESI         |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:16       | RESERVED          | Read returns 0                                                                                     | R           | 0x0000       |
| 15:0        | NUMRESI           | Showing how many bits are generated from MB headers.<br>Automatically cleared when the job starts. | R           | 0x0000       |

**Table 5-671. Register Call Summary for Register CAVLC\_NUMRESI**


---

 IVA2.2 Subsystem Basic Programming Model
 

- [Setting Up Registers for CAVLC Operation: \[0\]](#)

---

 IVA2.2 Subsystem Register Manual
 

- [iVLCD Register Mapping Summary: \[1\]](#)

---

## 5.5.10 SEQ Registers

This section provides information about the SEQ Module. Each register in the module is described separately below.

### 5.5.10.1 SEQ Register Mapping Summary

**Table 5-672. SEQ Register Mapping Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | Physical Address |
|---------------|------|-----------------------|----------------|------------------|
| SEQ_REVISION  | R    | 32                    | 0x0000 0000    | 0x0009 0000      |
| SEQ_SYSCONFIG | RW   | 32                    | 0x0000 0008    | 0x0009 0008      |
| SEQ_IRQMASK   | RW   | 32                    | 0x0000 0040    | 0x0009 0040      |
| SEQ_IRQCLR    | W    | 32                    | 0x0000 0044    | 0x0009 0044      |
| SEQ_IRQSET    | W    | 32                    | 0x0000 0048    | 0x0009 0048      |
| SEQ_IRQSTATE  | R    | 32                    | 0x0000 004C    | 0x0009 004C      |
| SEQ_SWICLR    | W    | 32                    | 0x0000 0060    | 0x0009 0060      |
| SEQ_SWISET    | W    | 32                    | 0x0000 0064    | 0x0009 0064      |
| SEQ_SWISTATE  | R    | 32                    | 0x0000 0068    | 0x0009 0068      |

### 5.5.10.2 SEQ Register Descriptions

**Table 5-673. SEQ\_REVISION**

|                  |                                                                                                                       |          |     |
|------------------|-----------------------------------------------------------------------------------------------------------------------|----------|-----|
| Address Offset   | 0x0000 0000                                                                                                           | Instance | SEQ |
| Physical Address | 0x0009 0000                                                                                                           |          |     |
| Description      | This register contains the IP revision code (reset value to be defined by design team for each version of the module) |          |     |
| Type             | R                                                                                                                     |          |     |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REV |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                             | Type | Reset              |
|------|------------|---------------------------------------------------------|------|--------------------|
| 31:8 | RESERVED   | Reserved<br>Read returns 0                              | R    | 0x000000           |
| 7:0  | REV        | IP revision<br>3:0 Minor revision<br>7:4 Major revision | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 5-674. Register Call Summary for Register SEQ\_REVISION**

- IVA2.2 Subsystem Register Manual
- SEQ Register Mapping Summary: [0]

**Table 5-675. SEQ\_SYSCONFIG**

|                         |                         |                       |                                                                             |  |
|-------------------------|-------------------------|-----------------------|-----------------------------------------------------------------------------|--|
| <b>Address Offset</b>   | 0x0000 0008             | <b>Instance</b>       | SEQ                                                                         |  |
| <b>Physical Address</b> | 0x0009 0008             | <b>Description</b>    |                                                                             |  |
| <b>Description</b>      |                         |                       | This register allows controlling various parameters of the sequencer module |  |
| <b>Type</b>             |                         |                       | RW                                                                          |  |
| 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                                                             |  |
| RESERVED                |                         |                       | AUTOIDLE                                                                    |  |

| Bits | Field Name | Description                                                                                                      | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Reserved<br>Write 0s for future compatibility<br>Read returns 0                                                  | RW   | 0x00000000 |
| 0    | AUTOIDLE   | Internal auto-clock gating strategy<br>0: Clock is free running<br>1: Automatic clock gating strategy is applied | RW   | 0x1        |

**Table 5-676. Register Call Summary for Register SEQ\_SYSCONFIG**

- IVA2.2 Subsystem Basic Programming Model
- [Video and Sequencer Module Management: \[0\]](#)

- IVA2.2 Subsystem Register Manual
- [SEQ Register Mapping Summary: \[1\]](#)

**Table 5-677. SEQ\_IRQMASK**

|                                                                                                                                                                                                                                                                                           |             |                    |     |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|-----|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                     | 0x0000 0040 | <b>Instance</b>    | SEQ |  |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                   | 0x0009 0040 | <b>Description</b> |     |  |
| This register contains the interrupt mask bits: when <a href="#">SEQ_IRQMASK</a> .MirqN is set, input event N does not trigger the interrupt line to the sequencer (default) when <a href="#">SEQ_IRQMASK</a> .MirqN is clear, input event N triggers the interrupt line to the sequencer |             |                    |     |  |
| <b>Type</b>                                                                                                                                                                                                                                                                               | RW          |                    |     |  |

| Bits  | Field Name | Description                                                         | Type     | Reset |
|-------|------------|---------------------------------------------------------------------|----------|-------|
| 31:23 | RESERVED   | Reserved<br>Reads returns 0<br>Write 0 for SW forward compatibility | RW       | 0x07  |
| 22    | TCERRINT1  | TCERRINT1 IRQ mask                                                  | w/1toSet | 0x1   |
| 21    | TCERRINT0  | TCERRINT0 IRQ mask                                                  | w/1toSet | 0x1   |
| 20    | CCERRINT   | CCERRINT IRQ mask                                                   | w/1toSet | 0x1   |
| 19    | CCINT2     | CCINT2 IRQ mask                                                     | w/1toSet | 0x1   |
| 18    | CCINT1     | CCINT1 IRQ mask                                                     | w/1toSet | 0x1   |
| 17    | CCINT8     | CCINT8 IRQ mask                                                     | w/1toSet | 0x1   |
| 16    | CCINT7     | CCINT7 IRQ mask                                                     | w/1toSet | 0x1   |
| 15    | CCINT6     | CCINT6 IRQ mask                                                     | w/1toSet | 0x1   |
| 14    | CCINT5     | CCINT5 IRQ mask                                                     | w/1toSet | 0x1   |
| 13    | CCINT4     | CCINT4 IRQ mask                                                     | w/1toSet | 0x1   |
| 12    | CCINT3     | CCINT3 IRQ mask                                                     | w/1toSet | 0x1   |
| 11    | CCINTG     | CCINTG IRQ mask                                                     | w/1toSet | 0x1   |
| 10    | CCMPINT    | CCMPINT IRQ mask                                                    | w/1toSet | 0x1   |
| 9     | RESERVED   | Reserved                                                            | R        | 0x1   |

| Bits | Field Name | Description                                                                                                  | Type     | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------|----------|-------|
| 8    | HOST_MBX   | HOST_MBX IRQ mask                                                                                            | w/1toSet | 0x1   |
| 7    | SPARE_2    | Spare #2 interrupt mask (reserved for future use)<br>Reads returns 0<br>Write 0 for SW forward compatibility | w/1toSet | 0x1   |
| 6    | SPARE_1    | Spare #1 interrupt mask (reserved for future use)<br>Reads returns 0<br>Write 0 for SW forward compatibility | w/1toSet | 0x1   |
| 5    | SEQ_ERROR  | SEQ_ERROR IRQ mask                                                                                           | w/1toSet | 0x1   |
| 4    | DMA_ERROR  | DMA_ERROR IRQ mask                                                                                           | w/1toSet | 0x1   |
| 3    | SPARE_0    | Spare #0 interrupt mask (reserved for future use)<br>Reads returns 0<br>Write 0 for SW forward compatibility | w/1toSet | 0x1   |
| 2    | iVLCD      | iVLCD IRQ mask                                                                                               | w/1toSet | 0x1   |
| 1    | iLF        | iLF IRQ mask                                                                                                 | w/1toSet | 0x1   |
| 0    | iME        | iME IRQ mask                                                                                                 | w/1toSet | 0x1   |

**Table 5-678. Register Call Summary for Register SEQ\_IRQMASK**

IVA2.2 Subsystem Register Manual

- [SEQ Register Mapping Summary: \[0\]](#)
- [SEQ Register Descriptions: \[1\] \[2\] \[3\]](#)
- [Video System Controller Register Descriptions: \[4\]](#)

**Table 5-679. SEQ\_IRQCLR**

| Address Offset | Physical Address |                                                                                                               | Instance | SEQ   |
|----------------|------------------|---------------------------------------------------------------------------------------------------------------|----------|-------|
| Description    |                  |                                                                                                               |          |       |
| Type           |                  |                                                                                                               |          |       |
| Bits           | Field Name       | Description                                                                                                   | Type     | Reset |
| 31:23          | RESERVED         | Reserved<br>Reads returns 0<br>Write 0 for SW forward compatibility                                           | W        | 0x0   |
| 22             | TCERRINT1        | TCERRINT1 IRQ clear                                                                                           | w/1toSet | 0x0   |
| 21             | TCERRINT0        | TCERRINT0 IRQ clear                                                                                           | w/1toSet | 0x0   |
| 20             | CCERRINT         | CCERRINT IRQ clear                                                                                            | w/1toSet | 0x0   |
| 19             | CCINT2           | CCINT2 IRQ clear                                                                                              | w/1toSet | 0x0   |
| 18             | CCINT1           | CCINT1 IRQ clear                                                                                              | w/1toSet | 0x0   |
| 17             | CCINT8           | CCINT8 IRQ clear                                                                                              | w/1toSet | 0x0   |
| 16             | CCINT7           | CCINT7 IRQ clear                                                                                              | w/1toSet | 0x0   |
| 15             | CCINT6           | CCINT6 IRQ clear                                                                                              | w/1toSet | 0x0   |
| 14             | CCINT5           | CCINT5 IRQ clear                                                                                              | w/1toSet | 0x0   |
| 13             | CCINT4           | CCINT4 IRQ clear                                                                                              | w/1toSet | 0x0   |
| 12             | CCINT3           | CCINT3 IRQ clear                                                                                              | w/1toSet | 0x0   |
| 11             | CCINTG           | CCINTG IRQ clear                                                                                              | w/1toSet | 0x0   |
| 10             | CCMPINT          | CCMPINT IRQ clear                                                                                             | w/1toSet | 0x0   |
| 9              | RESERVED         | Reserved                                                                                                      | R        | 0x0   |
| 8              | HOST_MBX         | HOST_MBX IRQ clear                                                                                            | w/1toSet | 0x0   |
| 7              | SPARE_2          | Spare #2 interrupt clear (reserved for future use)<br>Reads returns 0<br>Write 0 for SW forward compatibility | w/1toSet | 0x0   |

| Bits | Field Name | Description                                                                                                   | Type     | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------|----------|-------|
| 6    | SPARE_1    | Spare #1 interrupt clear (reserved for future use)<br>Reads returns 0<br>Write 0 for SW forward compatibility | w/1toSet | 0x0   |
| 5    | SEQ_ERROR  | SEQ_ERROR IRQ clear                                                                                           | w/1toSet | 0x0   |
| 4    | DMA_ERROR  | DMA_ERROR IRQ clear                                                                                           | w/1toSet | 0x0   |
| 3    | SPARE_0    | Spare #0 interrupt clear (reserved for future use)<br>Reads returns 0<br>Write 0 for SW forward compatibility | w/1toSet | 0x0   |
| 2    | iVLCD      | iVLCD IRQ clear                                                                                               | w/1toSet | 0x0   |
| 1    | iLF        | iLF IRQ clear                                                                                                 | w/1toSet | 0x0   |
| 0    | iME        | iME IRQ clear                                                                                                 | w/1toSet | 0x0   |

**Table 5-680. Register Call Summary for Register SEQ\_IRQCLR**

IVA2.2 Subsystem Basic Programming Model  
 • [Video and Sequencer Module interrupt Handling: \[0\]](#)

IVA2.2 Subsystem Register Manual

• [SEQ Register Mapping Summary: \[1\]](#)

**Table 5-681. SEQ\_IRQSET**

| Address Offset     | Physical Address | Instance                                                                                                                                                                                                                                                                                                                      | SEQ      |
|--------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|                    | 0x0000 0048      |                                                                                                                                                                                                                                                                                                                               |          |
| <b>Description</b> |                  | This register is used to set the interrupt bits (used to test interrupt): write 0: no effect write 1: sets the corresponding bit in the <a href="#">SEQ_IRQSTATE</a> register, and triggers the interrupt line if not already active and the associated event is enabled in <a href="#">SEQ_IRQMASK</a> reads always return 0 |          |
| <b>Type</b>        | W                |                                                                                                                                                                                                                                                                                                                               |          |
| Bits               | Field Name       | Description                                                                                                                                                                                                                                                                                                                   | Type     |
| 31:23              | RESERVED         | Reserved<br>Reads returns 0<br>Write 0 for SW forward compatibility                                                                                                                                                                                                                                                           | W        |
| 22                 | TCERRINT1        | TCERRINT1 IRQ set                                                                                                                                                                                                                                                                                                             | w/1toSet |
| 21                 | TCERRINT0        | TCERRINT0 IRQ set                                                                                                                                                                                                                                                                                                             | w/1toSet |
| 20                 | CCERRINT         | CCERRINT IRQ set                                                                                                                                                                                                                                                                                                              | w/1toSet |
| 19                 | CCINT2           | CCINT2 IRQ set                                                                                                                                                                                                                                                                                                                | w/1toSet |
| 18                 | CCINT1           | CCINT1 IRQ set                                                                                                                                                                                                                                                                                                                | w/1toSet |
| 17                 | CCINT8           | CCINT8 IRQ set                                                                                                                                                                                                                                                                                                                | w/1toSet |
| 16                 | CCINT7           | CCINT7 IRQ set                                                                                                                                                                                                                                                                                                                | w/1toSet |
| 15                 | CCINT6           | CCINT6 IRQ set                                                                                                                                                                                                                                                                                                                | w/1toSet |
| 14                 | CCINT5           | CCINT5 IRQ set                                                                                                                                                                                                                                                                                                                | w/1toSet |
| 13                 | CCINT4           | CCINT4 IRQ set                                                                                                                                                                                                                                                                                                                | w/1toSet |
| 12                 | CCINT3           | CCINT3 IRQ set                                                                                                                                                                                                                                                                                                                | w/1toSet |
| 11                 | CCINTG           | CCINTG IRQ set                                                                                                                                                                                                                                                                                                                | w/1toSet |
| 10                 | CCMPINT          | CCMPINT IRQ set                                                                                                                                                                                                                                                                                                               | w/1toSet |
| 9                  | RESERVED         | Reserved                                                                                                                                                                                                                                                                                                                      | R        |
| 8                  | HOST_MBX         | HOST_MBX IRQ set                                                                                                                                                                                                                                                                                                              | w/1toSet |
| 7                  | SPARE_2          | Spare #2 interrupt set (reserved for future use)<br>Reads returns 0<br>Write 0 for SW forward compatibility                                                                                                                                                                                                                   | w/1toSet |
| 6                  | SPARE_1          | Spare #1 interrupt set (reserved for future use)<br>Reads returns 0<br>Write 0 for SW forward compatibility                                                                                                                                                                                                                   | w/1toSet |
| 5                  | SEQ_ERROR        | SEQ_ERROR IRQ set                                                                                                                                                                                                                                                                                                             | w/1toSet |

| Bits | Field Name | Description                                                                                                 | Type     | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------|----------|-------|
| 4    | DMA_ERROR  | DMA_ERROR IRQ set                                                                                           | w/1toSet | 0x0   |
| 3    | SPARE_0    | Spare #0 interrupt set (reserved for future use)<br>Reads returns 0<br>Write 0 for SW forward compatibility | w/1toSet | 0x0   |
| 2    | iVLCD      | iVLCD IRQ set                                                                                               | w/1toSet | 0x0   |
| 1    | iLF        | iLF IRQ set                                                                                                 | w/1toSet | 0x0   |
| 0    | iME        | iME IRQ set                                                                                                 | w/1toSet | 0x0   |

**Table 5-682. Register Call Summary for Register SEQ\_IRQSET**

IVA2.2 Subsystem Register Manual

- SEQ Register Mapping Summary: [0]

**Table 5-683. SEQ\_IRQSTATE**

| Address Offset     | Physical Address                              | Instance                                                            | SEQ  |
|--------------------|-----------------------------------------------|---------------------------------------------------------------------|------|
|                    | 0x0000 004C                                   |                                                                     |      |
| <b>Description</b> | This register holds the interrupt status bits |                                                                     |      |
| <b>Type</b>        | R                                             |                                                                     |      |
| Bits               | Field Name                                    | Description                                                         | Type |
| 31:23              | RESERVED                                      | Reserved<br>Reads returns 0                                         | R    |
| 22                 | TCERRINT1                                     | TCERRINT1 IRQ status                                                | R    |
| 21                 | TCERRINT0                                     | TCERRINT0 IRQ status                                                | R    |
| 20                 | CCERRINT                                      | CCERRINT IRQ status                                                 | R    |
| 19                 | CCINT2                                        | CCINT2 IRQ status                                                   | R    |
| 18                 | CCINT1                                        | CCINT1 IRQ status                                                   | R    |
| 17                 | CCINT8                                        | CCINT8 IRQ status                                                   | R    |
| 16                 | CCINT7                                        | CCINT7 IRQ status                                                   | R    |
| 15                 | CCINT6                                        | CCINT6 IRQ status                                                   | R    |
| 14                 | CCINT5                                        | CCINT5 IRQ status                                                   | R    |
| 13                 | CCINT4                                        | CCINT4 IRQ status                                                   | R    |
| 12                 | CCINT3                                        | CCINT3 IRQ status                                                   | R    |
| 11                 | CCINTG                                        | CCINTG IRQ status                                                   | R    |
| 10                 | CCMPINT                                       | CCMPINT IRQ status                                                  | R    |
| 9                  | RESERVED                                      | Reserved                                                            | R    |
| 8                  | HOST_MBX                                      | HOST_MBX IRQ status                                                 | R    |
| 7                  | SPARE_2                                       | Spare #2 interrupt set (reserved for future use)<br>Reads returns 0 | R    |
| 6                  | SPARE_1                                       | Spare #1 interrupt set (reserved for future use)<br>Reads returns 0 | R    |
| 5                  | SEQ_ERROR                                     | SEQ_ERROR IRQ status                                                | R    |
| 4                  | DMA_ERROR                                     | DMA_ERROR IRQ status                                                | R    |
| 3                  | SPARE_0                                       | Spare #0 interrupt set (reserved for future use)<br>Reads returns 0 | R    |
| 2                  | iVLCD                                         | iVLCD IRQ status                                                    | R    |
| 1                  | iLF                                           | iLF IRQ status                                                      | R    |
| 0                  | iME                                           | iME IRQ status                                                      | R    |

**Table 5-684. Register Call Summary for Register SEQ\_IRQSTATE**

---

IVA2.2 Subsystem Register Manual

- SEQ Register Mapping Summary: [0]
  - SEQ Register Descriptions: [1]

**Table 5-685. SEQ\_SWICLR**

|                         |                                                           |                 |     |
|-------------------------|-----------------------------------------------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 0060                                               |                 |     |
| <b>Physical Address</b> | 0x0009 0060                                               | <b>Instance</b> | SEQ |
| <b>Description</b>      | This register is used to clear the software interrupt bit |                 |     |
| <b>Type</b>             | W                                                         |                 |     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                            | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------|-------------|--------------|
| 31:1        | RESERVED          | Reserved<br>Write 0s for future compatibility | W           | 0x00000000   |
| 0           | SWICLR            | SW interrupt clear                            | w/1toSet    | 0x0          |

**Table 5-686. Register Call Summary for Register SEQ\_SWICLR**

IVA2.2 Subsystem Register Manual

- SEQ Register Mapping Summary: [0]

**Table 5-687. SEQ\_SWISET**

|                         |                                                         |                 |     |
|-------------------------|---------------------------------------------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 0064                                             | <b>Instance</b> | SEQ |
| <b>Physical Address</b> | 0x0009 0064                                             |                 |     |
| <b>Description</b>      | This register is used to set the software interrupt bit |                 |     |
| <b>Type</b>             | W                                                       |                 |     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                            | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------|-------------|--------------|
| 31:1        | RESERVED          | Reserved<br>Write 0s for future compatibility | W           | 0x00000000   |
| 0           | SWISET            | SW interrupt set                              | w/1toSet    | 0x0          |

**Table 5-688. Register Call Summary for Register SEQ\_SWISET**

---

IVA2.2 Subsystem Register Manual

- SEQ Register Mapping Summary: [0]

**Table 5-689. SEQ\_SWISTATE**

|                         |                                             |                       |                 |  |  |
|-------------------------|---------------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0068                                 | <b>Instance</b>       | SEQ             |  |  |
| <b>Physical Address</b> | 0x0009 0068                                 |                       |                 |  |  |
| <b>Description</b>      | This register holds the SW interrupt status |                       |                 |  |  |
| <b>Type</b>             | R                                           |                       |                 |  |  |
| 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 |  |  |
| RESERVED                |                                             |                       | SWISTATE        |  |  |

| Bits | Field Name | Description                | Type     | Reset      |
|------|------------|----------------------------|----------|------------|
| 31:1 | RESERVED   | Reserved<br>Read returns 0 | R        | 0x00000000 |
| 0    | SWISTATE   | SW interrupt status        | w/1toSet | 0x0        |

**Table 5-690. Register Call Summary for Register SEQ\_SWISTATE**

IVA2.2 Subsystem Register Manual

- SEQ Register Mapping Summary: [0]

## 5.5.11 Video System Controller Registers

This section provides information about the Video System Controller module. Each register in the module is described separately below.

### 5.5.11.1 Video System Controller Register Mapping Summary

**Table 5-691. VIDEOSYSC Register Mapping Summary**

| Register Name       | Type     | Register Width (Bits) | Address Offset | Physical Address |
|---------------------|----------|-----------------------|----------------|------------------|
| VIDEOSYSC_REVISION  | R        | 32                    | 0x0000 0000    | 0x0009 C000      |
| VIDEOSYSC_SYSCONFIG | RW       | 32                    | 0x0000 0008    | 0x0009 C008      |
| VIDEOSYSC_IRQMASK   | w/1toSet | 32                    | 0x0000 0040    | 0x0009 C040      |
| VIDEOSYSC_IRQCLR    | w/1toSet | 32                    | 0x0000 0044    | 0x0009 C044      |
| VIDEOSYSC IRQSET    | w/1toSet | 32                    | 0x0000 0048    | 0x0009 C048      |
| VIDEOSYSC_IRQSTATE  | w/1toSet | 32                    | 0x0000 004C    | 0x0009 C04C      |
| VIDEOSYSC_CLKCTL    | W        | 32                    | 0x0000 0060    | 0x0009 C060      |
| VIDEOSYSC_CLKDIV    | RW       | 32                    | 0x0000 0064    | 0x0009 C064      |
| VIDEOSYSC_CLKST     | R        | 32                    | 0x0000 0068    | 0x0009 C068      |

### 5.5.11.2 Video System Controller Register Descriptions

**Table 5-692. VIDEOSYSC\_REVISION**

|                                                                                             |                                                                                                                       |                  |             |          |           |
|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|------------------|-------------|----------|-----------|
| Address Offset                                                                              | 0x0000 0000                                                                                                           | Physical Address | 0x0009 C000 | Instance | VIDEOSYSC |
| Description                                                                                 | This register contains the IP revision code (reset value to be defined by design team for each version of the module) |                  |             |          |           |
| Type                                                                                        | R                                                                                                                     |                  |             |          |           |
| 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 | RESERVED                                                                                                              |                  |             |          | REV       |

| Bits | Field Name | Description                                             | Type | Reset              |
|------|------------|---------------------------------------------------------|------|--------------------|
| 31:8 | RESERVED   | Reserved<br>Read returns 0                              | R    | 0x000000           |
| 7:0  | REV        | IP revision<br>3:0 Minor revision<br>7:4 Major revision | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 5-693. Register Call Summary for Register VIDEOSYSC\_REVISION**

|                                                                         |
|-------------------------------------------------------------------------|
| IVA2.2 Subsystem Register Manual                                        |
| • <a href="#">Video System Controller Register Mapping Summary: [0]</a> |

**Table 5-694. VIDEOSYSC\_SYSCONFIG**

|                       |                                                                                           |                         |             |                 |           |
|-----------------------|-------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-----------|
| <b>Address Offset</b> | 0x0000 0008                                                                               | <b>Physical Address</b> | 0x0009 C008 | <b>Instance</b> | VIDEOSYSC |
| <b>Description</b>    | This register allows controlling various parameters of the video system controller module |                         |             |                 |           |
| <b>Type</b>           | RW                                                                                        |                         |             |                 |           |
| 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                                                                                         |                         |             |                 |           |

RESERVED

AUTOIDLE

| Bits | Field Name | Description                                                                                                      | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Reserved<br>Write 0s for future compatibility<br>Read returns 0                                                  | RW   | 0x00000000 |
| 0    | AUTOIDLE   | Internal auto-clock gating strategy<br>0: Clock is free running<br>1: Automatic clock gating strategy is applied | RW   | 0x1        |

**Table 5-695. Register Call Summary for Register VIDEOSYSC\_SYSCONFIG**

IVA2.2 Subsystem Basic Programming Model

- [Video and Sequencer Module Management: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [Video System Controller Register Mapping Summary: \[1\]](#)
- [Video System Controller Register Descriptions: \[2\]](#)

**Table 5-696. VIDEOSYSC\_IRQMASK**

|                       |                                                                                                                                                                                                                                                                                               |                                           |             |                 |           |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-------------|-----------------|-----------|
| <b>Address Offset</b> | 0x0000 0040                                                                                                                                                                                                                                                                                   | <b>Physical Address</b>                   | 0x0009 C040 | <b>Instance</b> | VIDEOSYSC |
| <b>Description</b>    | This register contains the interrupt mask bits: when <a href="#">VIDEOSYSC_IRQMASK.MirqN</a> is set, input event N does not trigger the interrupt line to the sequencer (default) when <a href="#">SEQ_IRQMASK.MirqN</a> is clear, input event N triggers the interrupt line to the sequencer |                                           |             |                 |           |
| <b>Type</b>           | w/1toSet                                                                                                                                                                                                                                                                                      |                                           |             |                 |           |
| Bits                  | Field Name                                                                                                                                                                                                                                                                                    | Description                               | Type        | Reset           |           |
| 31:8                  | RESERVED                                                                                                                                                                                                                                                                                      | Reserved (not implemented)                | w/1toSet    | 0x000000        |           |
| 7                     | SPARE_1                                                                                                                                                                                                                                                                                       | Spare interrupt (reserved for future use) | w/1toSet    | 0x1             |           |
| 6                     | SEQ_MBX                                                                                                                                                                                                                                                                                       | SEQ Mailbox IRQ mask                      | w/1toSet    | 0x1             |           |
| 5                     | DMA_ERROR                                                                                                                                                                                                                                                                                     | DMA error IRQ mask                        | w/1toSet    | 0x1             |           |
| 4                     | HOST_ERROR                                                                                                                                                                                                                                                                                    | HOST error IRQ mask                       | w/1toSet    | 0x1             |           |
| 3                     | SPARE_0                                                                                                                                                                                                                                                                                       | Spare interrupt (reserved for future use) | w/1toSet    | 0x1             |           |
| 2                     | IVLCD                                                                                                                                                                                                                                                                                         | iVLCD IRQ mask                            | w/1toSet    | 0x1             |           |
| 1                     | iLF                                                                                                                                                                                                                                                                                           | iLF IRQ mask                              | w/1toSet    | 0x1             |           |
| 0                     | iME                                                                                                                                                                                                                                                                                           | iME IRQ mask                              | w/1toSet    | 0x1             |           |

**Table 5-697. Register Call Summary for Register VIDEOSYSC\_IRQMASK**

IVA2.2 Subsystem Functional Description

- [Video Accelerator/Sequencer SYSC: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [Video System Controller Register Mapping Summary: \[1\]](#)
- [Video System Controller Register Descriptions: \[2\] \[3\] \[4\]](#)

**Table 5-698. VIDEOSYSC\_IRQCLR**

|                         |                                                                                                                                                                                                                                                                                                                                                               |                 |           |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------|--|--|
| <b>Address Offset</b>   | 0x0000 0044                                                                                                                                                                                                                                                                                                                                                   | <b>Instance</b> | VIDEOSYSC |  |  |
| <b>Physical Address</b> | 0x0009 C044                                                                                                                                                                                                                                                                                                                                                   |                 |           |  |  |
| <b>Description</b>      | This register is used to clear the interrupt bits in <a href="#">VIDEOSYSC_IRQSTATE</a> write 0: no effect write 1: clears the corresponding bit in the <a href="#">VIDEOSYSC_IRQSTATE</a> register and clears the interrupt line if this action clears last active and enabled (in <a href="#">VIDEOSYSC_IRQMASK</a> ) input event(s). reads always return 0 |                 |           |  |  |
| <b>Type</b>             | w/1toSet                                                                                                                                                                                                                                                                                                                                                      |                 |           |  |  |

  

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                        | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------|-------------|--------------|
| 31:8        | RESERVED          | Reserved (not implemented)                | w/1toSet    | 0x000000     |
| 7           | SPARE_1           | Spare interrupt (reserved for future use) | w/1toSet    | 0x0          |
| 6           | SEQ_MBX           | SEQ Mailbox IRQ clear                     | w/1toSet    | 0x0          |
| 5           | DMA_ERROR         | DMA error IRQ clear                       | w/1toSet    | 0x0          |
| 4           | HOST_ERROR        | HOST error IRQ clear                      | w/1toSet    | 0x0          |
| 3           | SPARE_0           | Spare interrupt (reserved for future use) | w/1toSet    | 0x0          |
| 2           | iVLCD             | iVLCD IRQ clear                           | w/1toSet    | 0x0          |
| 1           | iLF               | iLF IRQ clear                             | w/1toSet    | 0x0          |
| 0           | iME               | iME IRQ clear                             | w/1toSet    | 0x0          |

**Table 5-699. Register Call Summary for Register VIDEOSYSC\_IRQCLR**

- 
- IVA2.2 Subsystem Functional Description
- [Video Accelerator/Sequencer SYSC: \[0\]](#)
- 
- IVA2.2 Subsystem Basic Programming Model
- [Video and Sequencer Module interrupt Handling: \[1\]](#)
- 
- IVA2.2 Subsystem Register Manual
- [Video System Controller Register Mapping Summary: \[2\]](#)

**Table 5-700. VIDEOSYSC\_IRQSET**

|                         |                                                                                                                                                                                                                                                                                                                                           |                 |           |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------|--|--|
| <b>Address Offset</b>   | 0x0000 0048                                                                                                                                                                                                                                                                                                                               | <b>Instance</b> | VIDEOSYSC |  |  |
| <b>Physical Address</b> | 0x0009 C048                                                                                                                                                                                                                                                                                                                               |                 |           |  |  |
| <b>Description</b>      | This register is used to set the interrupt bits (used to test interrupt): write 0: no effect write 1: sets the corresponding bit in the <a href="#">VIDEOSYSC_IRQSTATE</a> register, and triggers the interrupt line if not already active and the associated event is enabled in <a href="#">VIDEOSYSC_IRQMASK</a> reads always return 0 |                 |           |  |  |
| <b>Type</b>             | w/1toSet                                                                                                                                                                                                                                                                                                                                  |                 |           |  |  |

  

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                        | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------|-------------|--------------|
| 31:8        | RESERVED          | Reserved (not implemented)                | w/1toSet    | 0x000000     |
| 7           | SPARE_1           | Spare interrupt (reserved for future use) | w/1toSet    | 0x0          |
| 6           | SEQ_MBX           | SEQ Mailbox IRQ set                       | w/1toSet    | 0x0          |
| 5           | DMA_ERROR         | DMA error IRQ set                         | w/1toSet    | 0x0          |
| 4           | HOST_ERROR        | HOST error IRQ set                        | w/1toSet    | 0x0          |
| 3           | SPARE_0           | Spare interrupt (reserved for future use) | w/1toSet    | 0x0          |
| 2           | iVLCD             | iVLCD IRQ set                             | w/1toSet    | 0x0          |
| 1           | iLF               | iLF IRQ set                               | w/1toSet    | 0x0          |
| 0           | iME               | iME IRQ set                               | w/1toSet    | 0x0          |

**Table 5-701. Register Call Summary for Register VIDEOSYSC\_IRQSET**

- 
- IVA2.2 Subsystem Functional Description
- [Video Accelerator/Sequencer SYSC: \[0\]](#)
- 
- IVA2.2 Subsystem Register Manual
- [Video System Controller Register Mapping Summary: \[1\]](#)

**Table 5-702. VIDEOSYSC\_IRQSTATE**

| <b>Address Offset</b>   | 0x0000 004C                                   | <b>Instance</b>                           | VIDEOSYSC         |
|-------------------------|-----------------------------------------------|-------------------------------------------|-------------------|
| <b>Physical Address</b> | 0x0009 C04C                                   |                                           |                   |
| <b>Description</b>      | This register holds the interrupt status bits |                                           |                   |
| <b>Type</b>             | w/1toSet                                      |                                           |                   |
| <hr/>                   |                                               |                                           |                   |
| <b>Bits</b>             | <b>Field Name</b>                             | <b>Description</b>                        | <b>Type</b>       |
| 31:8                    | RESERVED                                      | Reserved (not implemented)                | w/1toSet 0x000000 |
| 7                       | SPARE_1                                       | Spare interrupt (reserved for future use) | w/1toSet 0x0      |
| 6                       | SEQ_MBX                                       | SEQ Mailbox IRQ status                    | w/1toSet 0x0      |
| 5                       | DMA_ERROR                                     | DMA error IRQ status                      | w/1toSet 0x0      |
| 4                       | HOST_ERROR                                    | HOST error IRQ status                     | w/1toSet 0x0      |
| 3                       | SPARE_0                                       | Spare interrupt (reserved for future use) | w/1toSet 0x0      |
| 2                       | iVLCD                                         | iVLCD IRQ status                          | w/1toSet 0x0      |
| 1                       | iLF                                           | iLF IRQ status                            | w/1toSet 0x0      |
| 0                       | iME                                           | iME IRQ status                            | w/1toSet 0x0      |

**Table 5-703. Register Call Summary for Register VIDEOSYSC\_IRQSTATE**

|                                          |                                                                              |
|------------------------------------------|------------------------------------------------------------------------------|
| IVA2.2 Subsystem Functional Description  | <a href="#">• Video Accelerator/Sequencer SYSC: [0] [1] [2] [3]</a>          |
| IVA2.2 Subsystem Basic Programming Model | <a href="#">• Video and Sequencer Module interrupt Handling: [4]</a>         |
| IVA2.2 Subsystem Register Manual         | <a href="#">• Video System Controller Register Mapping Summary: [5]</a>      |
|                                          | <a href="#">• Video System Controller Register Descriptions: [6] [7] [8]</a> |

**Table 5-704. VIDEOSYSC\_CLKCTL**

| <b>Address Offset</b>   | 0x0000 0060                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>Instance</b>                                                                                                                                                                                                      | VIDEOSYSC   |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| <b>Physical Address</b> | 0x0009 C060                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                      |             |
| <b>Description</b>      | Video accelerator clock control: Writing a 0 forces the module to leave the idle state (modules input clock goes active) Writing a 1 requests the module enter the idle state when no request/commands pending for the module. (Allows module input clock to be stopped). Module automatically exits the idle state and clock starts each time new requests/commands are present. Clock status can be checked in <a href="#">VIDEOSYSC_CLKST</a> register |                                                                                                                                                                                                                      |             |
| <b>Type</b>             | W                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                      |             |
| <hr/>                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                      |             |
| <b>Bits</b>             | <b>Field Name</b>                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>Description</b>                                                                                                                                                                                                   | <b>Type</b> |
| 31:6                    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Reserved<br>Read returns 0                                                                                                                                                                                           | W 0x0       |
| 5                       | SL2IFCLKEN                                                                                                                                                                                                                                                                                                                                                                                                                                                | Clock control of the SL2IF module<br>(iLF and iME modules must be idled as well):<br>0: Exit idle state and start SL2IF clock<br>1: Request SL2IF logic to go to idle and stop SL2IF input clock                     | W 0x0       |
| 4                       | SEQMEMCLKEN                                                                                                                                                                                                                                                                                                                                                                                                                                               | Clock control of the sequencer memory and slave port module:<br>0: Exit idle state and start SEQ memory and slave port clock<br>1: Request SEQ slave port logic to go to idle and stop SEQ clock (if SEQ in standby) | W 0x0       |
| 3                       | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Reserved<br>Read returns 0                                                                                                                                                                                           | W 0x0       |
| 2                       | iVLCDCLKEN                                                                                                                                                                                                                                                                                                                                                                                                                                                | Clock control of the iVLCD module:<br>0: Exit idle state and start iVLCD clock<br>1: Request iVLCD logic to go to idle and stop iVLCD input clock                                                                    | W 0x0       |
| 1                       | iMECLKEN                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Clock control of the iME module:<br>0: Exit idle state and start iME clock<br>1: Request iME logic to go to idle and stop iME input clock                                                                            | W 0x0       |

| Bits | Field Name | Description                                                                                                                               | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | iLFCLKEN   | Clock control of the iLF module:<br>0: Exit idle state and start iLF clock<br>1: Request iLF logic to go to idle and stop iLF input clock | W    | 0x0   |

**Table 5-705. Register Call Summary for Register VIDEOSYSC\_CLKCTL**

IVA2.2 Subsystem Functional Description

- [Video Accelerator/Sequencer SYSC: \[0\]](#) [\[1\]](#) [\[2\]](#) [\[3\]](#) [\[4\]](#) [\[5\]](#)

IVA2.2 Subsystem Basic Programming Model

- [Video and Sequencer Module Management: \[6\]](#) [\[7\]](#)

IVA2.2 Subsystem Register Manual

- [Video System Controller Register Mapping Summary: \[8\]](#)

**Table 5-706. VIDEOSYSC\_CLKDIV**

|                         |                                            |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |
|-------------------------|--------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------|
| <b>Address Offset</b>   | 0x0000 0064                                |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |
| <b>Physical Address</b> | 0x0009 C064                                |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |
| <b>Description</b>      | Video accelerator sequencer clock division |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |
| <b>Type</b>             | RW                                         |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |
|                         |                                            |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  | SEQCLKDIV |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                     | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED   | Reserved<br>Read returns 0                                                                                                                                                                                                                                                                                                                                                                      | RW   | 0x00000000 |
| 1:0  | SEQCLKDIV  | Sequencer clock division control<br><br>0x0: No clock division - SEQ operates at the same clock as video accelerators<br><br>0x1: Clock divide by two - SEQ operates at half the video accelerators clock<br><br>0x2: Clock divide by three - SEQ operates at one third the video accelerators clock<br><br>0x3: Clock divide by four - SEQ operates at one fourth the video accelerators clock | RW   | 0x0        |

**Table 5-707. Register Call Summary for Register VIDEOSYSC\_CLKDIV**

IVA2.2 Subsystem Functional Description

- [Video Accelerator/Sequencer SYSC: \[0\]](#)

IVA2.2 Subsystem Basic Programming Model

- [Sequencer Boot/Reset: \[1\]](#)
- [Video and Sequencer Module Management: \[2\]](#) [\[3\]](#)

IVA2.2 Subsystem Register Manual

- [Video System Controller Register Mapping Summary: \[4\]](#)

**Table 5-708. VIDEOSYSC\_CLKST**

| <b>Address Offset</b>   | 0x0000 0068                                                                                                                                                                                                                                                                 | <b>Instance</b>                                                                                              | VIDEOSYSC |          |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|-----------|----------|--|--|
| <b>Physical Address</b> | 0x0009 C068                                                                                                                                                                                                                                                                 |                                                                                                              |           |          |  |  |
| <b>Description</b>      | Video accelerator clock status: 0: Logic is active and the input modules input clock is running 1: Logic is idled (Clock stopped if autoidle bit also 1) Clock is only automatically stopped when logic is idled if the autoidle bit in VIDEOSYSC_SYSConfig register is set |                                                                                                              |           |          |  |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                           |                                                                                                              |           |          |  |  |
| Bits                    | Field Name                                                                                                                                                                                                                                                                  | Description                                                                                                  | Type      | Reset    |  |  |
| 31:9                    | RESERVED                                                                                                                                                                                                                                                                    | Reserved<br>Read returns 0                                                                                   | R         | 0x000000 |  |  |
| 8                       | SEQSTANDBY                                                                                                                                                                                                                                                                  | SEQ is in Standby:<br>0: SEQ is not in standby<br>1: SEQ is in Standby                                       | R         | 0x0      |  |  |
| 7:6                     | RESERVED                                                                                                                                                                                                                                                                    | Reserved<br>Read returns 0                                                                                   | R         | 0x0      |  |  |
| 5                       | SL2IFCLKST                                                                                                                                                                                                                                                                  | Clock control of the SL2IF module<br>0: SL2IF logic is active<br>1: SL2IF logic is idled                     | R         | 0x0      |  |  |
| 4                       | SEQMEMCLKST                                                                                                                                                                                                                                                                 | Clock control of the SEQ memory and slave port:<br>0: SEQ Slave port is active<br>1: SEQ Slave port is Idled | R         | 0x0      |  |  |
| 3                       | RESERVED                                                                                                                                                                                                                                                                    | Reserved<br>Read returns 0                                                                                   | R         | 0x0      |  |  |
| 2                       | iLCDCLKST                                                                                                                                                                                                                                                                   | Clock control of the iLCD module:<br>0: iLCD logic is active<br>1: iLCD logic is idled                       | R         | 0x0      |  |  |
| 1                       | iMECLKST                                                                                                                                                                                                                                                                    | Clock control of the iME module:<br>0: iME logic is active<br>1: iME logic is idled                          | R         | 0x0      |  |  |
| 0                       | iLFCLKST                                                                                                                                                                                                                                                                    | Clock control of the iLF module:<br>0: iLF logic is active<br>1: iLF logic is idled                          | R         | 0x0      |  |  |

**Table 5-709. Register Call Summary for Register VIDEOSYSC\_CLKST**

IVA2.2 Subsystem Basic Programming Model

- [Video and Sequencer Module Management: \[0\]](#)

IVA2.2 Subsystem Register Manual

- [Video System Controller Register Mapping Summary: \[1\]](#)
- [Video System Controller Register Descriptions: \[2\]](#)

## 5.5.12 iME Registers

This section provides information about the improved Motion Estimation module. Each register in the module is described separately below.

### 5.5.12.1 iME Register Mapping Summary

**Table 5-710. iME Register Mapping Summary**

| Register Name                           | Type | Register Width (Bits) | Address Offset        | Physical Address      |
|-----------------------------------------|------|-----------------------|-----------------------|-----------------------|
| iME_REVISION                            | R    | 32                    | 0x0000 0000           | 0x000A 0000           |
| iME_SYSCONFIG                           | RW   | 32                    | 0x0000 0010           | 0x000A 0010           |
| iME_SYSSTATUS                           | R    | 32                    | 0x0000 0014           | 0x000A 0014           |
| iME_PROGRAMBUFFERLINENELSB <sup>i</sup> | RW   | 32                    | 0x0000 0040 + (0x8*i) | 0x000A 0040 + (0x8*i) |
| iME_PROGRAMBUFFERLINENMBS <sup>i</sup>  | RW   | 32                    | 0x0000 0044 + (0x8*i) | 0x000A 0044 + (0x8*i) |
| iME_ERRORTABLE <sup>j</sup>             | RW   | 32                    | 0x0000 0840 + (0x4*j) | 0x000A 0840 + (0x4*j) |
| iME_REFERENCEBLOCK <sup>k</sup>         | RW   | 32                    | 0x0000 0880 + (0x4*k) | 0x000A 0880 + (0x4*k) |
| iME_COEFFREGBANK <sup>l</sup>           | RW   | 32                    | 0x0000 0980 + (0x4*l) | 0x000A 0980 + (0x4*l) |
| iME_PARAMETERSTACKL <sup>j</sup>        | RW   | 32                    | 0x0000 0990 + (0x4*j) | 0x000A 0990 + (0x4*j) |
| iME_PARAMETERSTACKH <sup>j</sup>        | RW   | 32                    | 0x0000 09D0 + (0x4*j) | 0x000A 09D0 + (0x4*j) |
| iME_XMVCT <sup>m</sup>                  | RW   | 32                    | 0x0000 0AA0 + (0x4*m) | 0x000A 0AA0 + (0x4*m) |
| iME_YMVCT <sup>m</sup>                  | RW   | 32                    | 0x0000 0AC0 + (0x4*m) | 0x000A 0AC0 + (0x4*m) |
| iME_MINERRORTHRESHOLD                   | RW   | 32                    | 0x0000 0AE0           | 0x000A 0AE0           |
| iME_ABSMINREACHED                       | RW   | 32                    | 0x0000 0AE4           | 0x000A 0AE4           |
| iME_CPUTATUSREG                         | R    | 32                    | 0x0000 0AE8           | 0x000A 0AE8           |
| iME_IRQLOG                              | R    | 32                    | 0x0000 0AEC           | 0x000A 0AEC           |
| iME_LATESTERRORS                        | RW   | 32                    | 0x0000 0AF0           | 0x000A 0AF0           |
| iME_CONFIGREG                           | RW   | 32                    | 0x0000 0AF4           | 0x000A 0AF4           |
| iME_SL2INSTADDRESS                      | RW   | 32                    | 0x0000 0AF8           | 0x000A 0AF8           |
| iME_COMMANDREG                          | W    | 32                    | 0x0000 0FFC           | 0x000A 0FFC           |

(1) i = 0 to 255

(2) j = 0 to 15

(3) k = 0 to 63

(4) l = 0 to 3

(5) m = 0 to 7

### 5.5.12.2 iME Register Descriptions

**Table 5-711. iME\_REVISION**

|                         |                                              |                 |     |  |  |
|-------------------------|----------------------------------------------|-----------------|-----|--|--|
| <b>Address Offset</b>   | 0x0000 0000                                  | <b>Instance</b> | iME |  |  |
| <b>Physical Address</b> | 0x000A 0000                                  |                 |     |  |  |
| <b>Description</b>      | This register contains the iME revision code |                 |     |  |  |
| <b>Type</b>             | R                                            |                 |     |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REV |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                  | Type | Reset              |
|------|------------|--------------------------------------------------------------|------|--------------------|
| 31:8 | RESERVED   | Read returns 0                                               | R    | 0x000000           |
| 7:0  | REV        | iME Revision<br>[3:0] Minor Revision<br>[7:4] Major Revision | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 5-712. Register Call Summary for Register iME\_REVISION**

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-713. iME\_SYSCONFIG**

|                         |                                                                          |                 |     |  |  |
|-------------------------|--------------------------------------------------------------------------|-----------------|-----|--|--|
| <b>Address Offset</b>   | 0x0000 0010                                                              | <b>Instance</b> | iME |  |  |
| <b>Physical Address</b> | 0x000A 0010                                                              |                 |     |  |  |
| <b>Description</b>      | This register allows controlling various parameters of the OCP interface |                 |     |  |  |
| <b>Type</b>             | RW                                                                       |                 |     |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |               |          |           |          |           |          |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------------|----------|-----------|----------|-----------|----------|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CLOCKACTIVITY | RESERVED | SIDLEMODE | RESERVED | SOFTRESET | AUTOIDLE |   |

| Bits | Field Name    | Description                                                                                                                                                  | Type | Reset |
|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:9 | RESERVED      | Read returns 0.                                                                                                                                              | R    | 0x0   |
| 8    | CLOCKACTIVITY | Clock activity during wake up mode period.<br>0 - OCP clock can be switched-off.                                                                             | R    | 0x0   |
| 7:5  | RESERVED      | Read returns 0.                                                                                                                                              | R    | 0x0   |
| 4:3  | SIDLEMODE     | Slave interface power management, req/ack control<br>"10" = Smart-idle. Acknowledgement to an idle request is given based on the internal activity of iME    | R    | 0x2   |
| 2    | RESERVED      | Read returns 0.                                                                                                                                              | R    | 0x0   |
| 1    | SOFTRESET     | Software reset. Set this bit to 1 to trigger the iME reset.<br>The bit is automatically reset by the hardware. During reads, it always returns 0.            | RW   | 0x0   |
| 0    | AUTOIDLE      | Internal OCP clock gating strategy:<br>0: OCP clock is free running<br>1: Automatic OCP clock-gating strategy is applied based on the OCP interface activity | RW   | 0x1   |

**Table 5-714. Register Call Summary for Register iME\_SYSCONFIG**


---

 IVA2.2 Subsystem Basic Programming Model
 

- [Video and Sequencer Module Management: \[0\]](#)

---

 IVA2.2 Subsystem Register Manual
 

- [iME Register Mapping Summary: \[1\]](#)

---

**Table 5-715. iME\_SYSSTATUS**

|                         |                                                                                                 |                 |     |
|-------------------------|-------------------------------------------------------------------------------------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 0014                                                                                     | <b>Instance</b> | iME |
| <b>Physical Address</b> | 0x000A 0014                                                                                     |                 |     |
| <b>Description</b>      | The register provides status information about the module, excluding the interrupt information. |                 |     |
| <b>Type</b>             | R                                                                                               |                 |     |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                             | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------|------|-------|
| 31:1 | RESERVED   | Reserved for OCP socket status information.<br>Read returns 0.                          | R    | 0x00  |
| 0    | RESETDONE  | Internal reset monitoring<br>0: Internal module reset is on-going<br>1: Reset completed | R    | 0x-   |

**Table 5-716. Register Call Summary for Register iME\_SYSSTATUS**


---

 IVA2.2 Subsystem Register Manual
 

- [iME Register Mapping Summary: \[0\]](#)

---

**Table 5-717. iME\_PROGRAMBUFFERLINE[NLS]Bi**

|                         |                                                   |                 |     |
|-------------------------|---------------------------------------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 0040 + (0x8*i)                             | <b>Instance</b> | iME |
| <b>Physical Address</b> | 0x000A 0040 + (0x8*i)                             |                 |     |
| <b>Description</b>      | Lower part of the macro-instruction : bits [31:0] |                 |     |
| <b>Type</b>             | RW                                                |                 |     |

|               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| MACROINST_LSB |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name    | Description                                                      | Type | Reset   |
|------|---------------|------------------------------------------------------------------|------|---------|
| 31:0 | MACROINST_LSB | Line i of 256, Lower part of the macro-instruction : bits [31:0] | RW   | 0x----- |

**Table 5-718. Register Call Summary for Register iME\_PROGRAMBUFFERLINE[NLS]Bi**


---

 IVA2.2 Subsystem Basic Programming Model
 

- [Typical Use: \[0\]](#)

---

 IVA2.2 Subsystem Register Manual
 

- [iME Register Mapping Summary: \[1\]](#)

---

**Table 5-719. iME\_PROGRAMBUFFERLINE[N]MSBi**

|                         |                                                   |                       |                 |  |  |
|-------------------------|---------------------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0044 + (0x8*i)                             | <b>Instance</b>       | iME             |  |  |
| <b>Physical Address</b> | 0x000A 0044 + (0x8*i)                             |                       |                 |  |  |
| <b>Description</b>      | High part of the macro-instruction : bits [54:32] |                       |                 |  |  |
| <b>Type</b>             | RW                                                |                       |                 |  |  |
| 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 |  |  |
| Reserved                |                                                   | MACROINST_MSB         |                 |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------|-------------|--------------|
| 31:23       | Reserved          | Read returns 0                                                   | R           | 0x--         |
| 22:0        | MACROINST_MSB     | Line i of 256, high part of the macro-instruction : bits [54:32] | RW          | 0x-----      |

**Table 5-720. Register Call Summary for Register iME\_PROGRAMBUFFERLINE[N]MSBi**

IVA2.2 Subsystem Basic Programming Model

- Typical Use: [0]

IVA2.2 Subsystem Register Manual

- iME Register Mapping Summary: [1]

**Table 5-721. iME\_ERRORTABLEj**

|                         |                                                                                                                                                                |                       |                 |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0840 + (0x4*j)                                                                                                                                          | <b>Instance</b>       | iME             |  |  |
| <b>Physical Address</b> | 0x000A 0840 + (0x4*j)                                                                                                                                          |                       |                 |  |  |
| <b>Description</b>      | Register file (Error Table) for SAD computation containing final errors. Each entry in the register comprises a 16-bit Error field and a 16-bit Address field. |                       |                 |  |  |
| <b>Type</b>             | RW                                                                                                                                                             |                       |                 |  |  |
| 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 |  |  |
| ET_ADDRESSN             |                                                                                                                                                                | ET_ERRORN             |                 |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31:16       | ET_ADDRESSN       | Error Table line i, Address value | RW          | 0x---        |
| 15:0        | ET_ERRORN         | Error Table line i, Error value   | RW          | 0x----       |

**Table 5-722. Register Call Summary for Register iME\_ERRORTABLEj**

IVA2.2 Subsystem Register Manual

- iME Register Mapping Summary: [0]

**Table 5-723. iME\_REFERENCEBLOCKk**

|                         |                                                                                             |                       |                 |  |  |
|-------------------------|---------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0880 + (0x4*k)                                                                       | <b>Instance</b>       | iME             |  |  |
| <b>Physical Address</b> | 0x000A 0880 + (0x4*k)                                                                       |                       |                 |  |  |
| <b>Description</b>      | 16 lines of 16 bytes register file containing the reference block data for SAD computation. |                       |                 |  |  |
| <b>Type</b>             | RW                                                                                          |                       |                 |  |  |
| 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 |  |  |
| REFBLOCK_WORD           |                                                                                             |                       |                 |  |  |

| Bits | Field Name    | Description                  | Type | Reset   |
|------|---------------|------------------------------|------|---------|
| 31:0 | REFBLOCK_WORD | This word contains 4 pixels. | RW   | 0x----- |

**Table 5-724. Register Call Summary for Register iME\_REFERENCEBLOCKk**

I/VA2.2 Subsystem Register Manual

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-725. iME\_COEFFREGBANKI**

|                         |                                                                                                                                                                                                  |                         |                       |                 |     |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 0980 + (0x4*I)                                                                                                                                                                            | <b>Physical Address</b> | 0x000A 0980 + (0x4*I) | <b>Instance</b> | iME |
| <b>Description</b>      | Coefficients Register Bank: The coefficient is 7 bit wide and 2 coefficients are stored in one word in the following format: [31:23] = 0x00 [22:16] = Coeff_odd [15:7] = 0x00 [6:0] = Coeff_even |                         |                       |                 |     |
| <b>Type</b>             | RW                                                                                                                                                                                               |                         |                       |                 |     |
| 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       |                 |     |

|          |           |          |            |
|----------|-----------|----------|------------|
| RESERVED | COEFF_ODD | RESERVED | COEFF_EVEN |
|----------|-----------|----------|------------|

| Bits  | Field Name | Description              | Type | Reset |
|-------|------------|--------------------------|------|-------|
| 31:23 | RESERVED   | Read returns 0.          | RW   | 0x000 |
| 22:16 | COEFF_ODD  | Coefficient (odd index)  | RW   | 0x--  |
| 15:7  | RESERVED   | read returns 0.          | RW   | 0x000 |
| 6:0   | COEFF_EVEN | Coefficient (even index) | RW   | 0x--  |

**Table 5-726. Register Call Summary for Register iME\_COEFFREGBANKI**

I/VA2.2 Subsystem Register Manual

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-727. iME\_PARAMETERSTACKLj**

|                       |                                                                                                               |                         |                       |                 |     |
|-----------------------|---------------------------------------------------------------------------------------------------------------|-------------------------|-----------------------|-----------------|-----|
| <b>Address Offset</b> | 0x0000 0990 + (0x4*j)                                                                                         | <b>Physical Address</b> | 0x000A 0990 + (0x4*j) | <b>Instance</b> | iME |
| <b>Description</b>    | Parameter stack register 0 to 15 (16-bit wide). Contains parameters used by program to control the iME units. |                         |                       |                 |     |
| <b>Type</b>           | RW                                                                                                            |                         |                       |                 |     |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         |                       | PARAMSTACK      |

| Bits  | Field Name | Description          | Type | Reset  |
|-------|------------|----------------------|------|--------|
| 31:16 | RESERVED   | Read returns zero.   | R    | 0x0000 |
| 15:0  | PARAMSTACK | Parameter of 0 to 15 | RW   | 0x---  |

**Table 5-728. Register Call Summary for Register iME\_PARAMETERSTACKLj**

I/VA2.2 Subsystem Register Manual

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-729. iME\_PARAMETERSTACKHj**

|                         |                                                                                                                |                       |                 |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 09D0 + (0x4*j)                                                                                          | <b>Instance</b>       | iME             |  |  |
| <b>Physical Address</b> | 0x000A 09D0 + (0x4*j)                                                                                          |                       |                 |  |  |
| <b>Description</b>      | Parameter stack register 16 to 31 (32-bit wide). Contains parameters used by program to control the iME units. |                       |                 |  |  |
| <b>Type</b>             | RW                                                                                                             |                       |                 |  |  |
| 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 |  |  |
| PARAMSTACK              |                                                                                                                |                       |                 |  |  |

| Bits | Field Name | Description           | Type | Reset   |
|------|------------|-----------------------|------|---------|
| 31:0 | PARAMSTACK | Parameter of 16 to 31 | RW   | 0x----- |

**Table 5-730. Register Call Summary for Register iME\_PARAMETERSTACKHj**

IVA2.2 Subsystem Register Manual

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-731. iME\_XMVCTm**

|                         |                                                                            |                       |                 |  |  |
|-------------------------|----------------------------------------------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0AA0 + (0x4*m)                                                      | <b>Instance</b>       | iME             |  |  |
| <b>Physical Address</b> | 0x000A 0AA0 + (0x4*m)                                                      |                       |                 |  |  |
| <b>Description</b>      | Two Motion Vector Cost value (16-bits wide) are packed in one 32 bit word. |                       |                 |  |  |
| <b>Type</b>             | RW                                                                         |                       |                 |  |  |
| 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 |  |  |
| XMVCT_ODD               |                                                                            |                       |                 |  |  |
| XMVCT_EVEN              |                                                                            |                       |                 |  |  |

| Bits  | Field Name | Description                 | Type | Reset |
|-------|------------|-----------------------------|------|-------|
| 31:16 | XMVCT_ODD  | MV Cost value of odd index  | RW   | 0x--- |
| 15:0  | XMVCT_EVEN | MV Cost value of even index | RW   | 0x--- |

**Table 5-732. Register Call Summary for Register iME\_XMVCTm**

IVA2.2 Subsystem Register Manual

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-733. iME\_YMVCTm**

|                         |                                                                            |                       |                 |  |  |
|-------------------------|----------------------------------------------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0AC0 + (0x4*m)                                                      | <b>Instance</b>       | iME             |  |  |
| <b>Physical Address</b> | 0x000A 0AC0 + (0x4*m)                                                      |                       |                 |  |  |
| <b>Description</b>      | Two Motion Vector Cost value (16-bits wide) are packed in one 32 bit word. |                       |                 |  |  |
| <b>Type</b>             | RW                                                                         |                       |                 |  |  |
| 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 |  |  |
| YMVCT_ODD               |                                                                            |                       |                 |  |  |
| YMVCT_EVEN              |                                                                            |                       |                 |  |  |

| Bits  | Field Name | Description                 | Type | Reset  |
|-------|------------|-----------------------------|------|--------|
| 31:16 | YMVCT_ODD  | MV Cost value of odd index  | RW   | 0x---- |
| 15:0  | YMVCT_EVEN | MV Cost value of even index | RW   | 0x---- |

**Table 5-734. Register Call Summary for Register iME\_YMVCTm**

IVA2.2 Subsystem Register Manual

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-735. iME\_MINERRORTHRESHOLD**

|                         |                                                             |                 |     |  |  |
|-------------------------|-------------------------------------------------------------|-----------------|-----|--|--|
| <b>Address Offset</b>   | 0x0000 0AE0                                                 | <b>Instance</b> | iME |  |  |
| <b>Physical Address</b> | 0x000A 0AE0                                                 |                 |     |  |  |
| <b>Description</b>      | Minimum Error Threshold register, used in Mcomp() operator. |                 |     |  |  |
| <b>Type</b>             | RW                                                          |                 |     |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MINTHRESHOLD |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name   | Description                           | Type | Reset  |
|-------|--------------|---------------------------------------|------|--------|
| 31:16 | RESERVED     | Read returns 0.                       | R    | 0x0000 |
| 15:0  | MINTHRESHOLD | Min Threshold value in Mcomp() block. | RW   | 0x---  |

**Table 5-736. Register Call Summary for Register iME\_MINERRORTHRESHOLD**

IVA2.2 Subsystem Register Manual

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-737. iME\_ABSMINREACHED**

|                         |                                                                  |                 |     |  |  |
|-------------------------|------------------------------------------------------------------|-----------------|-----|--|--|
| <b>Address Offset</b>   | 0x0000 0AE4                                                      | <b>Instance</b> | iME |  |  |
| <b>Physical Address</b> | 0x000A 0AE4                                                      |                 |     |  |  |
| <b>Description</b>      | Absolute Minimum Reached bit register, used in Mcomp() operator. |                 |     |  |  |
| <b>Type</b>             | RW                                                               |                 |     |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ABSMINREACHED |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name    | Description                          | Type | Reset      |
|------|---------------|--------------------------------------|------|------------|
| 31:1 | RESERVED      | Read returns 0.                      | R    | 0x00000000 |
| 0    | ABSMINREACHED | Abs Min Reached bit, in Mcomp block. | RW   | 0x-        |

**Table 5-738. Register Call Summary for Register iME\_ABSMINREACHED**

IVA2.2 Subsystem Register Manual

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-739. iME\_CPUSTATUSREG**

|                         |                                                                                  |                 |             |             |               |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |   |   |   |   |   |   |   |   |   |   |  |  |  |
|-------------------------|----------------------------------------------------------------------------------|-----------------|-------------|-------------|---------------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|---|---|---|---|---|---|---|---|---|---|--|--|--|
| <b>Address Offset</b>   | 0x0000 0AE8                                                                      |                 |             |             |               |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |   |   |   |   |   |   |   |   |   |   |  |  |  |
| <b>Physical Address</b> | 0x000A 0AE8                                                                      |                 |             |             |               |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |   |   |   |   |   |   |   |   |   |   |  |  |  |
| <b>Description</b>      | CPU Status Register provides information about the progress of the CPU execution |                 |             |             |               |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |   |   |   |   |   |   |   |   |   |   |  |  |  |
| <b>Type</b>             | R                                                                                |                 |             |             |               |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |   |   |   |   |   |   |   |   |   |   |  |  |  |
| 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 |  |  |  |
| RESERVED                | DETECTEDENDOFPGM                                                                 | DETECTEDSTOPSEQ | ENDPGMERROR | OPCODEERROR | WRITEREGERROR | EXECSTATE | PC |    |    |    |    |    |    |    |    |    |    |    |    |    | CYCLECOUNT |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Bits  | Field Name       | Description                                                                                                                                                                                                               | Type | Reset  |
|-------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31    | RESERVED         | read returns 0.                                                                                                                                                                                                           | R    | 0x0    |
| 30    | DETECTEDENDOFPGM | This bit is set to '1' when in Debug mode, an EndOfPgm instruction or the last instruction of ProgramBuffer has been reached.                                                                                             | R    | 0x0    |
| 29    | DETECTEDSTOPSEQ  | This bit is set to '1' when a StopSeq() command has been issued and the iME is in Halted state.                                                                                                                           | R    | 0x0    |
| 28    | ENDPGMERROR      | This bit is set to '1' when the last instruction of the Program Buffer is reached, and no EndPgm() or LoadInstBuf() instruction have been detected in the program buffer.<br>This bit is cleared by a StartSeq() command. | R    | 0x0    |
| 27    | OPCODEERROR      | This bit is set to '1' when a unknown opcode is decoded from the main program.<br>This bit is cleared by StartSeq() command when in INITIALIZED state, or by a Stop() command.                                            | R    | 0x0    |
| 26    | WRITEREGERROR    | This bit is set to '1' when attempting to write to an internal register through an OCP Write, while in EXECUTING state.<br>This bit is cleared by StartSeq() command when in INITIALIZED state, or by a Stop() command.   | R    | 0x0    |
| 25:24 | EXECSTATE        | Execution States:<br>00 = Initialized,<br>10 = Executing,<br>01 = Halted,<br>11 = Completed.                                                                                                                              | R    | 0x0    |
| 23:16 | PC               | Number of instruction currently executing.                                                                                                                                                                                | R    | 0x00   |
| 15:0  | CYCLECOUNT       | Total number of cycles executed.                                                                                                                                                                                          | R    | 0x0000 |

**Table 5-740. Register Call Summary for Register iME\_CPUSTATUSREG**

**Table 5-741. iME\_IRQLOG**

|                         |                                                                                                                                                                                                                              |                         |                 |                 |     |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-----|--|
| <b>Address Offset</b>   | 0x0000 0AEC                                                                                                                                                                                                                  | <b>Physical Address</b> | 0x000A 0AEC     | <b>Instance</b> | iME |  |
| <b>Description</b>      | IRQ Log register captures a one on bit 0 if the endpgm() instruction has been executed and a one on bits 1 to 15 for the first 15 GenerateIT() instructions executed (beyond 15, GenerateIT() events are logged into bit 15) |                         |                 |                 |     |  |
| <b>Type</b>             | R                                                                                                                                                                                                                            |                         |                 |                 |     |  |
| 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 |                 |     |  |
| RESERVED                |                                                                                                                                                                                                                              | GENEITEVENTLOG          |                 |                 |     |  |
| ENDPGMEVENTLOG          |                                                                                                                                                                                                                              |                         |                 |                 |     |  |

| Bits  | Field Name     | Description                         | Type | Reset  |
|-------|----------------|-------------------------------------|------|--------|
| 31:16 | RESERVED       | Read returns 0.                     | R    | 0x0000 |
| 15:1  | GENEITEVENTLOG | GenerateIT() instructions event log | R    | 0x0000 |
| 0     | ENDPGMEVENTLOG | endpgm() instruction event log.     | R    | 0x0    |

**Table 5-742. Register Call Summary for Register iME\_IRQLOG**

IVA2.2 Subsystem Register Manual

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-743. iME\_LATESTERRORS**

|                         |                                                                                           |                         |                 |                 |     |  |
|-------------------------|-------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-----|--|
| <b>Address Offset</b>   | 0x0000 0AF0                                                                               | <b>Physical Address</b> | 0x000A 0AF0     | <b>Instance</b> | iME |  |
| <b>Description</b>      | Best Match Location ( minimum error) data and its address generated by Multi compare unit |                         |                 |                 |     |  |
| <b>Type</b>             | RW                                                                                        |                         |                 |                 |     |  |
| 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 |                 |     |  |
| BESTMATCHADDRESS        |                                                                                           | BESTMATCHERRORVALUE     |                 |                 |     |  |

| Bits  | Field Name          | Description              | Type | Reset |
|-------|---------------------|--------------------------|------|-------|
| 31:16 | BESTMATCHADDRESS    | Best Match Error Address | RW   | 0x--- |
| 15:0  | BESTMATCHERRORVALUE | Best Match Error Value   | RW   | 0x--- |

**Table 5-744. Register Call Summary for Register iME\_LATESTERRORS**

IVA2.2 Subsystem Register Manual

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-745. iME\_CONFIGREG**

|                         |                         |                       |                                                                                                         |  |  |
|-------------------------|-------------------------|-----------------------|---------------------------------------------------------------------------------------------------------|--|--|
| <b>Address Offset</b>   | 0x0000 0AF4             | <b>Instance</b>       | iME                                                                                                     |  |  |
| <b>Physical Address</b> | 0x000A 0AF4             |                       |                                                                                                         |  |  |
| <b>Description</b>      | Configuration Register  |                       |                                                                                                         |  |  |
| <b>Type</b>             | RW                      |                       |                                                                                                         |  |  |
| 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                                                                                         |  |  |
| RESERVED                |                         |                       | WAITING_FOR_SYNC_SIGNAL<br>SYNC_SIGNAL_SET<br>RESERVED<br>DEBUGMODESTATUS<br>MINTHRESHOLDEN<br>ITENABLE |  |  |

| Bits | Field Name              | Description                                                     | Type | Reset    |
|------|-------------------------|-----------------------------------------------------------------|------|----------|
| 31:7 | RESERVED                | read returns 0.                                                 | R    | 0x000000 |
| 6    | WAITING_FOR_SYNC_SIGNAL | Bit is set when the WaitForSignal instruction has been decoded. | R    | 0        |
| 5    | SYNC_SIGNAL_SET         | Bit is set when iME has received the synchronisation signal.    | R    | 0        |
| 4:3  | RESERVED                | read returns 0.                                                 | R    | 0x0      |
| 2    | DEBUGMODESTATUS         | "Debug Mode" status bit                                         | R    | 0x0      |
| 1    | MINTHRESHOLDEN          | Enable Min Threshold Comparison bit                             | RW   | 0x0      |
| 0    | ITENABLE                | Interrupt Enable bit                                            | RW   | 0x0      |

**Table 5-746. Register Call Summary for Register iME\_CONFIGREG**

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-747. iME\_SL2INSTADDRESS**

|                         |                                                                   |                       |                 |  |  |
|-------------------------|-------------------------------------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0AF8                                                       | <b>Instance</b>       | iME             |  |  |
| <b>Physical Address</b> | 0x000A 0AF8                                                       |                       |                 |  |  |
| <b>Description</b>      | This register contains the SL2 address passed in the instruction. |                       |                 |  |  |
| <b>Type</b>             | RW                                                                |                       |                 |  |  |
| 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 |  |  |
| RESERVED                |                                                                   |                       | SL2INSTADDRESS  |  |  |

| Bits  | Field Name     | Description                                                       | Type | Reset  |
|-------|----------------|-------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED       | Read returns 0.                                                   | R    | 0x0000 |
| 15:0  | SL2INSTADDRESS | This register contains the SL2 address passed in the instruction. | RW   | 0x0000 |

**Table 5-748. Register Call Summary for Register iME\_SL2INSTADDRESS**

- [iME Register Mapping Summary: \[0\]](#)

**Table 5-749. iME\_COMMANDREG**

|                         |                                                                                                                                                                                                        |                 |     |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----|--|--|
| <b>Address Offset</b>   | 0x0000 0FFC                                                                                                                                                                                            | <b>Instance</b> | iME |  |  |
| <b>Physical Address</b> | 0x000A 0FFC                                                                                                                                                                                            |                 |     |  |  |
| <b>Description</b>      | iME command register: a write to this register decodes a command, a read returns an error. 0x1 -> StartSeq()<br>0x2 -> StopSeq() 0x3 -> DbgEnable() 0x4 -> DbgDisable() 0x5 -> DbgStep() 0x6 -> Halt() |                 |     |  |  |
| <b>Type</b>             | W                                                                                                                                                                                                      |                 |     |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | CMD |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                              | Type | Reset   |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:3 | RESERVED   | Read returns an error                                                                                                                                    | W    | 0x----- |
| 2:0  | CMD        | DATA/COMMAND<br>0x1 -> StartSeq()<br>0x2 -> StopSeq()<br>0x3 -> DbgEnable()<br>0x4 -> DbgDisable()<br>0x5 -> DbgStep()<br>0x6 -> Halt()<br>0x7 -> Sync() | W    | 0x-     |

**Table 5-750. Register Call Summary for Register iME\_COMMANDREG**

I/VA2.2 Subsystem Basic Programming Model

- [Typical Use: \[0\]](#)

I/VA2.2 Subsystem Register Manual

- [iME Register Mapping Summary: \[1\]](#)

## 5.5.13 iLF Registers

This section provides information about the improved Loop Filter module. Each register in the module is described separately below.

### 5.5.13.1 iLF Register Mapping Summary

**Table 5-751. iLF Register Mapping Summary**

| Register Name                            | Type | Register Width (Bits) | Address Offset        | Physical Address      |
|------------------------------------------|------|-----------------------|-----------------------|-----------------------|
| iLF_REVISION                             | R    | 32                    | 0x0000 0000           | 0x000A 1000           |
| iLF_SYSCONFIG                            | RW   | 32                    | 0x0000 0010           | 0x000A 1010           |
| iLF_SYSSTATUS                            | R    | 32                    | 0x0000 0014           | 0x000A 1014           |
| iLF_PROGRAMBUFFERLINENLSB <sup>(1)</sup> | RW   | 32                    | 0x0000 0040 + (0x8*i) | 0x000A 1040 + (0x8*i) |
| iLF_PROGRAMBUFFERLINENM <sup>(1)</sup>   | RW   | 32                    | 0x0000 0044 + (0x8*i) | 0x000A 1044 + (0x8*i) |
| iLF_PARAMETERSTACKUP <sup>(2)</sup>      | RW   | 32                    | 0x0000 0440 + (0x4*j) | 0x000A 1440 + (0x4*j) |
| iLF_PARAMETERSTACKLWK <sup>(3)</sup>     | RW   | 32                    | 0x0000 0460 + (0x4*k) | 0x000A 1460 + (0x4*k) |
| iLF_EFPTABLEENTRYI <sup>(4)</sup>        | RW   | 32                    | 0x0000 04C0 + (0x4*l) | 0x000A 14C0 + (0x4*l) |
| iLF_INOUTBUFFERM <sup>(5)</sup>          | RW   | 32                    | 0x0000 0550 + (0x4*m) | 0x000A 1550 + (0x4*m) |
| iLF_CPUTATUSREG                          | R    | 32                    | 0x0000 05F0           | 0x000A 15F0           |
| iLF_IRQLOG                               | R    | 32                    | 0x0000 05F4           | 0x000A 15F4           |
| iLF_EFPTD                                | R    | 32                    | 0x0000 05F8           | 0x000A 15F8           |
| iLF_CONFIGREG                            | RW   | 32                    | 0x0000 05FC           | 0x000A 15FC           |
| iLF_PARSEDATAREG0                        | RW   | 32                    | 0x0000 0600           | 0x000A 1600           |
| iLF_PARSEDATAREG1                        | RW   | 32                    | 0x0000 0604           | 0x000A 1604           |
| iLF_PARSEDATAREG2                        | RW   | 32                    | 0x0000 0608           | 0x000A 1608           |
| iLF_INSTBUFFER_ADDRESS                   | RW   | 32                    | 0x0000 060C           | 0x000A 160C           |
| iLF_LINESFILTERPROTOTYPES                | R    | 32                    | 0x0000 0610           | 0x000A 1610           |
| iLF_CLIPLIMITSENTRYn <sup>(6)</sup>      | R    | 32                    | 0x0000 0614 + (0x4*n) | 0x000A 1614 + (0x4*n) |
| iLF_COMMANDREG                           | W    | 32                    | 0x0000 0FFC           | 0x000A 1FFC           |

<sup>(1)</sup> i = 0 to 127

<sup>(2)</sup> j = 0 to 7

<sup>(3)</sup> k = 0 to 23

<sup>(4)</sup> l = 0 to 35

<sup>(5)</sup> m = 0 to 39

<sup>(6)</sup> n = 0 to 3

### 5.5.13.2 iLF Register Descriptions

**Table 5-752. iLF\_REVISION**

|                         |                                              |                 |     |  |  |
|-------------------------|----------------------------------------------|-----------------|-----|--|--|
| <b>Address Offset</b>   | 0x0000 0000                                  | <b>Instance</b> | iLF |  |  |
| <b>Physical Address</b> | 0x000A 1000                                  |                 |     |  |  |
| <b>Description</b>      | This register contains the iLF revision code |                 |     |  |  |
| <b>Type</b>             | R                                            |                 |     |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REV |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                  | Type | Reset              |
|------|------------|--------------------------------------------------------------|------|--------------------|
| 31:8 | RESERVED   | Read returns 0                                               | R    | 0x000000           |
| 7:0  | REV        | iLF Revision<br>[3:0] Minor Revision<br>[7:4] Major Revision | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 5-753. Register Call Summary for Register iLF\_REVISION**

- [iLF Register Mapping Summary: \[0\]](#)

**Table 5-754. iLF\_SYSCONFIG**

|                         |                                                                          |                 |     |  |  |
|-------------------------|--------------------------------------------------------------------------|-----------------|-----|--|--|
| <b>Address Offset</b>   | 0x0000 0010                                                              | <b>Instance</b> | iLF |  |  |
| <b>Physical Address</b> | 0x000A 1010                                                              |                 |     |  |  |
| <b>Description</b>      | This register allows controlling various parameters of the OCP interface |                 |     |  |  |
| <b>Type</b>             | RW                                                                       |                 |     |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |               |          |   |           |          |   |           |          |  |          |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------------|----------|---|-----------|----------|---|-----------|----------|--|----------|
| 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         |          |  |          |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CLOCKACTIVITY | RESERVED |   | SIDLEMODE | RESERVED |   | SOFTRESET | RESERVED |  | AUTOIDLE |

| Bits | Field Name    | Description                                                                                                                                                  | Type | Reset |
|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:9 | RESERVED      | Read returns 0.                                                                                                                                              | R    | 0x0   |
| 8    | CLOCKACTIVITY | Clock activity during wake up mode period.<br>0 - OCP clock can be switched-off.                                                                             | R    | 0x0   |
| 7:5  | RESERVED      | read returns 0.                                                                                                                                              | R    | 0x0   |
| 4:3  | SIDLEMODE     | Slave interface power management, req/ack control<br>"10" = Smart-idle. Acknowledgement to an idle request is given based on the internal activity of iME    | R    | 0x2   |
| 2    | RESERVED      | read returns 0.                                                                                                                                              | R    | 0x0   |
| 1    | SOFTRESET     | Software reset. Set this bit to 1 to trigger the iME reset.<br>The bit is automatically reset by the hardware. During reads, it always returns 0.            | RW   | 0x0   |
| 0    | AUTOIDLE      | Internal OCP clock gating strategy:<br>0: OCP clock is free running<br>1: Automatic OCP clock-gating strategy is applied based on the OCP interface activity | RW   | 0x1   |

**Table 5-755. Register Call Summary for Register iLF\_SYSCONFIG**

IVA2.2 Subsystem Basic Programming Model  
 • [Video and Sequencer Module Management: \[0\]](#)

IVA2.2 Subsystem Register Manual  
 • [iLF Register Mapping Summary: \[1\]](#)

**Table 5-756. iLF\_SYSSTATUS**

|                         |                                                                                                 |                         |                 |                 |           |
|-------------------------|-------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-----------|
| <b>Address Offset</b>   | 0x0000 0014                                                                                     | <b>Physical Address</b> | 0x000A 1014     | <b>Instance</b> | iLF       |
| <b>Description</b>      | The register provides status information about the module, excluding the interrupt information. |                         |                 |                 |           |
| <b>Type</b>             | R                                                                                               |                         |                 |                 |           |
| 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 |                 |           |
|                         |                                                                                                 |                         |                 | RESERVED        | RESETDONE |

| Bits | Field Name | Description                                                                             | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------|------|-------|
| 31:1 | RESERVED   | Reserved for OCP socket status information.<br>Read returns 0.                          | R    | 0x00  |
| 0    | RESETDONE  | Internal reset monitoring<br>0: Internal module reset is on-going<br>1: Reset completed | R    | 0x-   |

**Table 5-757. Register Call Summary for Register iLF\_SYSSTATUS**

IVA2.2 Subsystem Register Manual  
 • [iLF Register Mapping Summary: \[0\]](#)

**Table 5-758. iLF\_PROGRAMBUFFERLINENLSBi**

|                         |                                                   |                         |                       |                 |     |
|-------------------------|---------------------------------------------------|-------------------------|-----------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 0040 + (0x8*i)                             | <b>Physical Address</b> | 0x000A 1040 + (0x8*i) | <b>Instance</b> | iLF |
| <b>Description</b>      | Lower part of the macro-instruction : bits [31:0] |                         |                       |                 |     |
| <b>Type</b>             | RW                                                |                         |                       |                 |     |
| 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       |                 |     |
|                         |                                                   |                         |                       | MACROINST_LSB   |     |

| Bits | Field Name    | Description                                                      | Type | Reset   |
|------|---------------|------------------------------------------------------------------|------|---------|
| 31:0 | MACROINST_LSB | Line i of 128, Lower part of the macro-instruction : bits [31:0] | RW   | 0x----- |

**Table 5-759. Register Call Summary for Register iLF\_PROGRAMBUFFERLINENLSBi**

IVA2.2 Subsystem Basic Programming Model  
 • [Typical Use: \[0\]](#)

IVA2.2 Subsystem Register Manual  
 • [iLF Register Mapping Summary: \[1\]](#)

**Table 5-760. iLF\_PROGRAMBUFFERLINENMSBi**

|                         |                                                   |                       |                 |  |  |
|-------------------------|---------------------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0044 + (0x8*i)                             | <b>Instance</b>       | iLF             |  |  |
| <b>Physical Address</b> | 0x000A 1040 + (0x8*i)                             |                       |                 |  |  |
| <b>Description</b>      | High part of the macro-instruction : bits [54:32] |                       |                 |  |  |
| <b>Type</b>             | RW                                                |                       |                 |  |  |
| 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 |  |  |
| Reserved                |                                                   | MACROINST_MSB         |                 |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------|-------------|--------------|
| 31:23       | Reserved          | Read returns 0                                                   | R           | 0x--         |
| 22:0        | MACROINST_MSB     | Line i of 128, high part of the macro-instruction : bits [54:32] | RW          | 0x-----      |

**Table 5-761. Register Call Summary for Register iLF\_PROGRAMBUFFERLINENMSBi**

IVA2.2 Subsystem Basic Programming Model

- Typical Use: [0]

IVA2.2 Subsystem Register Manual

- [iLF Register Mapping Summary: \[1\]](#)

**Table 5-762. iLF\_PARAMETERSTACKUPj**

|                         |                                                                                             |                       |                 |  |  |
|-------------------------|---------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0440 + (0x4*j)                                                                       | <b>Instance</b>       | iLF             |  |  |
| <b>Physical Address</b> | 0x000A 1440 + (0x4*j)                                                                       |                       |                 |  |  |
| <b>Description</b>      | parameter stack register file contains parameters used by program to control the iLF units. |                       |                 |  |  |
| <b>Type</b>             | RW                                                                                          |                       |                 |  |  |
| 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 |  |  |
| RESERVED                |                                                                                             | PARAMSTACK            |                 |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------|-------------|--------------|
| 31:16       | RESERVED          | Read returns 0.     | R           | 0x---        |
| 15:0        | PARAMSTACK        | Parameter of 0 to 7 | RW          | 0x----       |

**Table 5-763. Register Call Summary for Register iLF\_PARAMETERSTACKUPj**

IVA2.2 Subsystem Register Manual

- [iLF Register Mapping Summary: \[0\]](#)

**Table 5-764. iLF\_PARAMETERSTACKLWk**

|                         |                                                                                             |                       |                 |  |  |
|-------------------------|---------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0460 + (0x4*k)                                                                       | <b>Instance</b>       | iLF             |  |  |
| <b>Physical Address</b> | 0x000A 1460 + (0x4*k)                                                                       |                       |                 |  |  |
| <b>Description</b>      | parameter stack register file contains parameters used by program to control the iLF units. |                       |                 |  |  |
| <b>Type</b>             | RW                                                                                          |                       |                 |  |  |
| 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 |  |  |
| PARAMSTACK              |                                                                                             |                       |                 |  |  |

| Bits | Field Name | Description          | Type | Reset   |
|------|------------|----------------------|------|---------|
| 31:0 | PARAMSTACK | Parameter of 8 to 31 | RW   | 0x----- |

**Table 5-765. Register Call Summary for Register iLF\_PARAMETERSTACKLWk**

IVA2.2 Subsystem Register Manual

- [iLF Register Mapping Summary: \[0\]](#)

**Table 5-766. iLF\_EFPTABLEENTRYI**

|                       |                                                                                  |                         |                       |                 |     |
|-----------------------|----------------------------------------------------------------------------------|-------------------------|-----------------------|-----------------|-----|
| <b>Address Offset</b> | 0x0000 04C0 + (0x4*I)                                                            | <b>Physical Address</b> | 0x000A 14C0 + (0x4*I) | <b>Instance</b> | iLF |
| <b>Description</b>    | EFP Table entry: contains various data organizations, depending on the standard. |                         |                       |                 |     |
| <b>Type</b>           | RW                                                                               |                         |                       |                 |     |

|          |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED | TABLE_ENTRY |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name  | Description          | Type | Reset   |
|------|-------------|----------------------|------|---------|
| 31   | RESERVED    | Read returns 0.      | R    | 0x-     |
| 30:0 | TABLE_ENTRY | Entry i of the table | RW   | 0x----- |

**Table 5-767. Register Call Summary for Register iLF\_EFPTABLEENTRYI**

IVA2.2 Subsystem Register Manual

- [iLF Register Mapping Summary: \[0\]](#)

**Table 5-768. iLF\_INOUTBUFFERm**

|                       |                                                      |                         |                       |                 |     |
|-----------------------|------------------------------------------------------|-------------------------|-----------------------|-----------------|-----|
| <b>Address Offset</b> | 0x0000 0550 + (0x4*m)                                | <b>Physical Address</b> | 0x000A 1550 + (0x4*m) | <b>Instance</b> | iLF |
| <b>Description</b>    | 32-bit entry in the buffer. Contains 4 8-bit fields. |                         |                       |                 |     |
| <b>Type</b>           | RW                                                   |                         |                       |                 |     |

|            |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |            |    |    |    |    |    |   |   |            |   |   |   |   |   |   |   |
|------------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|------------|----|----|----|----|----|---|---|------------|---|---|---|---|---|---|---|
| 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 |
| IOFB_BYTE3 |    |    |    |    |    |    |    | IOFB_BYTE2 |    |    |    |    |    |    |    | IOFB_BYTE1 |    |    |    |    |    |   |   | IOFB_BYTE0 |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                              | Type | Reset |
|-------|------------|----------------------------------------------------------|------|-------|
| 31:24 | IOFB_BYTE3 | High order byte in each entry of the IO Filter buffer    | RW   | 0x--  |
| 23:16 | IOFB_BYTE2 | 3rd low order byte in each entry of the IO Filter buffer | RW   | 0x--  |
| 15:8  | IOFB_BYTE1 | 2nd low order byte in each entry of the IO Filter buffer | RW   | 0x--  |
| 7:0   | IOFB_BYTE0 | low order byte in each entry of the IO filter buffer     | RW   | 0x--  |

**Table 5-769. Register Call Summary for Register iLF\_INOUTBUFFERm**

IVA2.2 Subsystem Register Manual

- [iLF Register Mapping Summary: \[0\]](#)

**Table 5-770. iLF\_CPUSTATUSREG**

|                         |                                                                                  |                 |     |
|-------------------------|----------------------------------------------------------------------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 05F0                                                                      | <b>Instance</b> | iLF |
| <b>Physical Address</b> | 0x000A 15F0                                                                      |                 |     |
| <b>Description</b>      | CPU Status Register provides information about the progress of the CPU execution |                 |     |
| <b>Type</b>             | R                                                                                |                 |     |

| 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 |
|----------|------------------|-----------------|-------------|-------------|---------------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------------|---|---|---|---|---|---|---|
| RESERVED | DETECTEDENDOFPGM | DETECTEDSTOPSEQ | ENDPGMERROR | OPCODEERROR | WRITEREGERROR | EXECSTATE |    |    |    |    |    |    |    |    | PC |    |    |    |    |    |    |   |   | CYCLEDCOUNT |   |   |   |   |   |   |   |

| Bits  | Field Name       | Description                                                                                                                                                                                                                                                          | Type | Reset  |
|-------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31    | RESERVED         | Read returns 0.                                                                                                                                                                                                                                                      | R    | 0x0    |
| 30    | DETECTEDENDOFPGM | This bit is set to '1' when, in Debug mode, an EndPgm() instruction or the last instruction of the program buffer has been reached and it is not a LoadInstBuf() instruction.<br>This bit is cleared by a StartSeq() command when in INITIALIZED or COMPLETED state. | R    | 0x0    |
| 29    | DETECTEDSTOPSEQ  | This bit is set to '1' when a StopSeq() has been issued and the iME is in Halted state. Execution of StopSeq() is postponed to the time when the CPU gets out of the Halted state.<br>This bit is cleared when the StopSeq() command is effectively executed.        | R    | 0x0    |
| 28    | ENDPGMERROR      | This bit is set to '1' when the last instruction of the program buffer is reached and no EndPgm() or LoadInstBuf() instruction have been detected in the program buffer.<br>This bit is cleared by a StartSeq() command when in INITIALIZED or COMPLETED state.      | R    | 0x0    |
| 27    | OPCODEERROR      | This bit is set to '1' when an unknown opcode is decoded from the main program. The following instruction of the sequence is then executed.<br>This bit is cleared by a StartSeq() command when in INITIALIZED or COMPLETED state.                                   | R    | 0x0    |
| 26    | WRITEREGERROR    | This bit is set to '1' when attempting to write an internal register through an OCP write, while in EXECUTING state.<br>This bit is cleared by a StartSeq() command when in INITIALIZED or COMPLETED state.                                                          | R    | 0x0    |
| 25:24 | EXECSTATE        | Execution States:<br>00 = Initialized,<br>10 = Executing,<br>01 = Halted,<br>11 = Completed.                                                                                                                                                                         | R    | 0x0    |
| 23:16 | PC               | Number of instruction currently executing.<br>Bit #7 is always 0 (PC values range from 0x00 to 0x7f)                                                                                                                                                                 | R    | 0x00   |
| 15:0  | CYCLECOUNT       | Total number of cycles executed.                                                                                                                                                                                                                                     | R    | 0x0000 |

**Table 5-771. Register Call Summary for Register iLF\_CPUSTATUSREG**

**Table 5-772. iLF\_IRQLOG**

|                         |                                                                                                                                                                                                                              |                       |                 |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 05F4                                                                                                                                                                                                                  |                       |                 |
| <b>Physical Address</b> | 0x000A 15F4                                                                                                                                                                                                                  | <b>Instance</b>       | iLF             |
| <b>Description</b>      | IRQ Log register captures a one on bit 0 if the endpgm() instruction has been executed and a one on bits 1 to 15 for the first 15 GenerateIT() instructions executed (beyond 15, GenerateIT() events are logged into bit 15) |                       |                 |
| <b>Type</b>             | R                                                                                                                                                                                                                            |                       |                 |
| 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 |
| RESERVED                |                                                                                                                                                                                                                              |                       |                 |
| GENEITEVENTLOG          |                                                                                                                                                                                                                              |                       |                 |
| ENDPGMEVENTLOG          |                                                                                                                                                                                                                              |                       |                 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------|-------------|--------------|
| 31:16       | RESERVED          | Read returns 0.                     | R           | 0x0000       |
| 15:1        | GENEITEVENTLOG    | GenerateIT() instructions event log | R           | 0x0000       |
| 0           | ENDPGMEVENTLOG    | endpgm() instruction event log.     | R           | 0x0          |

**Table 5-773. Register Call Summary for Register iLF\_IRQLOG**

---

IVA2.2 Subsystem Register Manual

- iLF Register Mapping Summary: [0]

**Table 5-774. iLF EFPTD**

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                    | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------|-------------|--------------|
| 31          | RESERVED          | read returns 0.                                                       | R           | 0x-          |
| 30:25       | HIGHBITS          | 5 bit bitfield, extracted with a second address (EFP_A2), out of EFPT | R           | 0x--         |
| 24:0        | LOWBITS           | 25 bit bitfield, extracted with a first address (EFP_A1), out of EFPT | R           | 0x-----      |

**Table 5-775. Register Call Summary for Register iLF\_EFPTD**

---

IVA2.2 Subsystem Register Manual

- iLF Register Mapping Summary: [0]

**Table 5-776. iLF\_CONFIGREG**

|                         |             |                        |     |
|-------------------------|-------------|------------------------|-----|
| <b>Address Offset</b>   | 0x0000 05FC | <b>Instance</b>        | iLF |
| <b>Physical Address</b> | 0x000A 15FC |                        |     |
| <b>Description</b>      |             | Configuration Register |     |
| <b>Type</b>             |             | RW                     |     |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |             |          |          |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-------------|----------|----------|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | DEBUGHALTEN | RESERVED | ITENABLE |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------|-------------|--------------|
| 31:3        | RESERVED          | read returns 0.          | R           | 0x0000000    |
| 2           | DEBUGHALTEN       | "Debug Halt" control bit | R           | 0x0          |
| 1           | RESERVED          | read returns 0.          | R           | 0x0          |
| 0           | ITENABLE          | Interrupt Enable bit     | RW          | 0x0          |

**Table 5-777. Register Call Summary for Register iLF\_CONFIGREG**

IVA2.2 Subsystem Register Manual

- iLF Register Mapping Summary: [0]

**Table 5-778. iLF\_PARSEDDATAREG0**

|                         |                                              |                 |     |
|-------------------------|----------------------------------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 0600 in 0xc byte increments           |                 |     |
| <b>Physical Address</b> | 0x000A 1600                                  | <b>Instance</b> | iLF |
| <b>Description</b>      | Lower part of the Loop Filter parameters set |                 |     |
| <b>Type</b>             | RW                                           |                 |     |

|          |           |    |          |            |    |    |             |    |    |    |            |    |    |    |             |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|-----------|----|----------|------------|----|----|-------------|----|----|----|------------|----|----|----|-------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED | TC0_FIELD |    | RESERVED | TC0B_FIELD |    |    | BETA2_FIELD |    |    |    | BETA_FIELD |    |    |    | ALPHA_FIELD |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------|-------------|--------------|
| 31          | RESERVED          | read returns 0.                   | R           | 0x-          |
| 30:26       | TC0_FIELD         | Tc0 parameter, 5 bits, unsigned   | RW          | 0x--         |
| 25          | RESERVED          | read returns 0.                   | RW          | 0x--         |
| 24:20       | TC0B_FIELD        | Tc0B parameter, 5 bits, unsigned  | RW          | 0x--         |
| 19:13       | BETA2_FIELD       | Beta2 parameter, 7 bits, unsigned | RW          | 0x--         |
| 12:8        | BETA_FIELD        | Beta parameter, 5 bits, unsigned  | RW          | 0x--         |
| 7:0         | ALPHA_FIELD       | Alpha parameter, 8 bits, unsigned | RW          | 0x--         |

**Table 5-779. Register Call Summary for Register iLF\_PARSEDDATAREG0**

---

IVA2.2 Subsystem Register Manual

- iLF Register Mapping Summary: [0]

**Table 5-780. iLF\_PARSEDDATAREG1**

|                         |                                            |                       |                 |         |     |               |          |          |  |  |  |  |  |  |
|-------------------------|--------------------------------------------|-----------------------|-----------------|---------|-----|---------------|----------|----------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x604-0x604 in 0xC byte increments         |                       |                 |         |     |               |          |          |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x5E0A 1604-0x5E0A 1604                    |                       |                 |         |     |               |          |          |  |  |  |  |  |  |
| <b>Description</b>      | Mid part of the Loop Filter parameters set |                       |                 |         |     |               |          |          |  |  |  |  |  |  |
| <b>Type</b>             | RW                                         |                       |                 |         |     |               |          |          |  |  |  |  |  |  |
| 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 |         |     |               |          |          |  |  |  |  |  |  |
| RESERVED                | H264_BSB                                   | REAL9_FLT             | REAL9_STR       | H264_BS | CFG | EFFEDGE_FIELD | CR_FIELD | CL_FIELD |  |  |  |  |  |  |

| Bits  | Field Name    | Description                                                                                                                                            | Type | Reset |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:29 | RESERVED      | Read returns 0.                                                                                                                                        | R    | 0x--  |
| 28:26 | H264_BSB      | H264 Secondary Strength for Chroma                                                                                                                     | R    | 0x--  |
| 25    | REAL9_FLT     | Filter Flag for REAL9                                                                                                                                  | RW   | -     |
| 24    | REAL9_STR     | Strong bit for REAL9                                                                                                                                   | RW   | -     |
| 23:21 | H264_BS       | H264 Strength                                                                                                                                          | RW   | 0x-   |
| 20:13 | CFG           | Configuration data, 8 bits:<br>Bits 1:0: CMR (Condition Mode), unsigned<br>Bit 2: Luma, boolean (0,1)<br>Bits 7:3: Pquant, unsigned (WMV9/H263)        | RW   | 0x--  |
| 12:8  | EFFEDGE_FIELD | Effective Edge Number parameter, 5 bits:<br>Bit 4: Vertical/Horizontal orientation, boolean (0,1)<br>Bits 3 down to 0: Effective edge number, unsigned | RW   | 0x--  |
| 7:4   | CR_FIELD      | Clipping limit, right parameter, 4 bits, unsigned                                                                                                      | RW   | 0x-   |
| 3:0   | CL_FIELD      | Clipping limit, left parameter, 4 bits, unsigned                                                                                                       | RW   | 0x-   |

**Table 5-781. Register Call Summary for Register iLF\_PARSEDDATAREG1**

IVA2.2 Subsystem Register Manual

- [iLF Register Mapping Summary: \[0\]](#)

**Table 5-782. iLF\_PARSEDDATAREG2**

|                         |                                                                     |                       |                 |       |       |       |       |       |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------|-----------------------|-----------------|-------|-------|-------|-------|-------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x608-0x608 in 0xC byte increments                                  |                       |                 |       |       |       |       |       |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x5E0A 1608-0x5E0A 1608                                             |                       |                 |       |       |       |       |       |  |  |  |  |  |  |
| <b>Description</b>      | Higher part of the Loop Filter parameters set, used for REAL9 only. |                       |                 |       |       |       |       |       |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                  |                       |                 |       |       |       |       |       |  |  |  |  |  |  |
| 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 |       |       |       |       |       |  |  |  |  |  |  |
| RESERVED                | DTER3                                                               | DTER2                 | DTER1           | DTER0 | DTEL3 | DTEL2 | DTEL1 | DTEL0 |  |  |  |  |  |  |

| Bits  | Field Name | Description         | Type | Reset |
|-------|------------|---------------------|------|-------|
| 31:24 | RESERVED   | Read returns 0.     | R    | 0x--  |
| 23:21 | DTER3      | Dither right, set 3 | RW   | 0x-   |
| 20:18 | DTER2      | Dither right, set 2 | RW   | 0x-   |
| 17:15 | DTER1      | Dither right, set 1 | RW   | 0x-   |
| 14:12 | DTER0      | Dither right, set 0 | RW   | 0x-   |
| 11:9  | DTEL3      | Dither left, set 3  | RW   | 0x-   |
| 8:6   | DTEL2      | Dither left, set 2  | RW   | 0x-   |
| 5:3   | DTEL1      | Dither left, set 1  | RW   | 0x-   |

| Bits | Field Name | Description        | Type | Reset |
|------|------------|--------------------|------|-------|
| 2:0  | DTEL0      | Dither left, set 0 | RW   | 0x-   |

**Table 5-783. Register Call Summary for Register iLF\_PARSEDDATAREG2**

- IVA2.2 Subsystem Register Manual
- [iLF Register Mapping Summary: \[0\]](#)

**Table 5-784. iLF\_INSTBUFFER\_ADDRESS**

|                         |                                                                                                 |                         |                 |                      |     |
|-------------------------|-------------------------------------------------------------------------------------------------|-------------------------|-----------------|----------------------|-----|
| <b>Address Offset</b>   | 0x0000 060C                                                                                     | <b>Physical Address</b> | 0x000A 160C     | <b>Instance</b>      | iLF |
| <b>Description</b>      | The register provides status information about the module, excluding the interrupt information. |                         |                 |                      |     |
| <b>Type</b>             | RW                                                                                              |                         |                 |                      |     |
| 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 |                      |     |
| RESERVED                |                                                                                                 |                         |                 | SL2_BUFFPAGE_ADDRESS |     |

| Bits  | Field Name           | Description                                                  | Type | Reset  |
|-------|----------------------|--------------------------------------------------------------|------|--------|
| 31:16 | RESERVED             | Read returns 0.                                              | R    | 0x0000 |
| 15:0  | SL2_BUFFPAGE_ADDRESS | Page address of the Instruction buffer content in SL2 memory | RW   | 0x0000 |

**Table 5-785. Register Call Summary for Register iLF\_INSTBUFFER\_ADDRESS**

- IVA2.2 Subsystem Register Manual
- [iLF Register Mapping Summary: \[0\]](#)

**Table 5-786. iLF\_LINESFILTERPROTOTYPES**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                  |                         |                 |                 |         |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0610                                                                                                                                                                                                                                                                                                                                                                                      | <b>Physical Address</b> | 0x000A 1610     | <b>Instance</b> | iLF     |
| <b>Description</b>      | Lines Filter Prototypes : contains, for each line of pixel orthogonal to the edge, the filter prototype reference on Right and Left side of the edge: LFPC_Qi and LFPC_Pi. These references are indexes into the Filter tables of the parameter stack, to extract all filter parameters. Status register that can be used to reconstruct the filter structure used at any place, along the edge. |                         |                 |                 |         |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                |                         |                 |                 |         |
| 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 |                 |         |
| LFPC_Q3                 | LFPC_P3                                                                                                                                                                                                                                                                                                                                                                                          | LFPC_Q2                 | LFPC_P2         | LFPC_Q1         | LFPC_P1 |
| LFPC_Q0                 |                                                                                                                                                                                                                                                                                                                                                                                                  | LFPC_P0                 |                 | LFPC_Q0         |         |

| Bits  | Field Name | Description                  | Type | Reset |
|-------|------------|------------------------------|------|-------|
| 31:28 | LFPC_Q3    | Filter on the Q side, line 3 | R    | 0x0   |
| 27:24 | LFPC_P3    | Filter on the P side, line 3 | R    | 0x0   |
| 23:20 | LFPC_Q2    | Filter on the Q side, line 2 | R    | 0x0   |
| 19:16 | LFPC_P2    | Filter on the P side, line 2 | R    | 0x0   |
| 15:12 | LFPC_Q1    | Filter on the Q side, line 1 | R    | 0x0   |
| 11:8  | LFPC_P1    | Filter on the P side, line 1 | R    | 0x0   |
| 7:4   | LFPC_Q0    | Filter on the Q side, line 0 | R    | 0x0   |
| 3:0   | LFPC_P0    | Filter on the P side, line 0 | R    | 0x0   |

**Table 5-787. Register Call Summary for Register iLF\_LINESFILTERPROTOTYPES**

IVA2.2 Subsystem Register Manual

- [iLF Register Mapping Summary: \[0\]](#)

**Table 5-788. iLF\_CLIPLIMITSENTRYn**

|                         |                                                                                                                                                                       |                         |                       |                 |     |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 0614 + (0x4*n)                                                                                                                                                 | <b>Physical Address</b> | 0x000A 1614 + (0x4*n) | <b>Instance</b> | iLF |
| <b>Description</b>      | Clip limits entry: contains clip limits, organized in 3 fields, depending on the standard Clip_A: 9 bits, signed, Clip_B: 5 bits, unsigned, Clip_C: 4 bits, unsigned. |                         |                       |                 |     |
| <b>Type</b>             | R                                                                                                                                                                     |                         |                       |                 |     |
| 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       |                 |     |
| RESERVED                | SRUNQ<br>SRUNP                                                                                                                                                        | CLIP_C                  | CLIP_B                | CLIP_A          |     |

| Bits  | Field Name | Description                                                             | Type | Reset |
|-------|------------|-------------------------------------------------------------------------|------|-------|
| 31:20 | RESERVED   | read returns 0.                                                         | R    | 0x000 |
| 19    | SRUNQ      | 1 bit, unsigned<br>Value when not used (according to the standard): 0   | R    | 0x0   |
| 18    | SRUNP      | 1 bit, unsigned<br>Value when not used (according to the standard): 0   | R    | 0x0   |
| 17:14 | CLIP_C     | 4 bits, unsigned<br>Value when not used (according to the standard): 15 | R    | 0x0   |
| 13:9  | CLIP_B     | 5 bits, unsigned<br>Value when not used (according to the standard): 31 | R    | 0x00  |
| 8:0   | CLIP_A     | 9 bits, signed<br>Value when not used (according to the standard): 255  | R    | 0x000 |

**Table 5-789. Register Call Summary for Register iLF\_CLIPLIMITSENTRYn**

IVA2.2 Subsystem Register Manual

- [iLF Register Mapping Summary: \[0\]](#)

**Table 5-790. iLF\_COMMANDREG**

|                         |                                                                                                                                                                                                                                     |                         |                 |                 |     |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 0FFC                                                                                                                                                                                                                         | <b>Physical Address</b> | 0x000A 1FFC     | <b>Instance</b> | iLF |
| <b>Description</b>      | iLF command register:: a write to this register decodes a command, a read returns an error. DATA/COMMAND<br>0x1 -> StartSeq()<br>0x2 -> StopSeq()<br>0x3 -> DbgEnable()<br>0x4 -> DbgDisable()<br>0x5 -> DbgStep()<br>0x6 -> Halt() |                         |                 |                 |     |
| <b>Type</b>             | W                                                                                                                                                                                                                                   |                         |                 |                 |     |
| 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 | RESERVED        |     |

| Bits | Field Name | Description                                                                                                                             | Type | Reset   |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:3 | RESERVED   | Read returns an error                                                                                                                   | W    | 0x----- |
| 2:0  | CMD        | DATA/COMMAND<br>0x1 -> StartSeq()<br>0x2 -> StopSeq()<br>0x3 -> DbgEnable()<br>0x4 -> DbgDisable()<br>0x5 -> DbgStep()<br>0x6 -> Halt() | W    | 0x-     |

**Table 5-791. Register Call Summary for Register iLF\_COMMANDREG**


---

 IVA2.2 Subsystem Basic Programming Model

- Typical Use: [0]
- 

IVA2.2 Subsystem Register Manual

- iLF Register Mapping Summary: [1]
- 

### **5.5.14 IA\_GEM Registers**

This section provides information about the Initiator Agent for the DSP megamodule Module. Each register in the module is described separately below.

#### **5.5.14.1 IA\_GEM Register Mapping Summary**

**Table 5-792. IA\_GEM Register Mapping Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address |
|------------------|------|-----------------------|----------------|------------------|
| GEM_AGENT_STATUS | R    | 32                    | 0x0000 0028    | 0x000F 8828      |

#### **5.5.14.2 IA\_GEM Register Descriptions**

**Table 5-793. GEM\_AGENT\_STATUS**

| Address Offset | 0x0000 0028           | Physical Address | 0x000F 8828 | Instance | IA_GEM |
|----------------|-----------------------|------------------|-------------|----------|--------|
| Description    | Agent Status Register | Type             | R           |          |        |

| 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 |
|----------|----|------------------------|----|----------------------|----|----------|--------|----|----|----|----|----|----|----|---------------|----|----|----|----|----------|----------|---|--------------|---|---|---|---|---|---|------------|---|
| RESERVED |    | INBAND_ERROR_SECONDARY |    | INBAND_ERROR_PRIMARY |    | RESERVED | MIRROR |    |    |    |    |    |    |    | BURST_TIMEOUT |    |    |    |    | TIMEBASE | RESERVED |   | RESP_TIMEOUT |   |   |   |   |   |   | CORE_RESET |   |

| Bits  | Field Name             | Description                                                                                                                                                                                                         | Type | Reset |
|-------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED               | Reserved                                                                                                                                                                                                            | R    | 0x0   |
| 29    | INBAND_ERROR_SECONDARY | Error Status for in-band errors with MErrSteer indicating a secondary error.<br><br>Read 0x0: No in-band error received<br>Write 0x0: Ignored<br>Read 0x1: In-band error received<br>Write 0x1: Clear in-band error | RW   | 0x0   |

| Bits  | Field Name           | Description                                                                                                                                                                                                                | Type | Reset |
|-------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 28    | INBAND_ERROR_PRIMARY | Error Status for in-band errors with MErrSteer indicating Primary Error<br><br>Read 0x0: No in-band error received<br><br>Write 0x0: Ignored<br><br>Read 0x1: In-band error received<br><br>Write 0x1: Clear in-band error | RW   | 0x0   |
| 27:25 | RESERVED             | Reserved                                                                                                                                                                                                                   | R    | 0x0   |
| 24    | MERROR               | MError assertion detected                                                                                                                                                                                                  | R    | 0x0   |
| 23:17 | RESERVED             | Reserved                                                                                                                                                                                                                   | R    | 0x00  |
| 16    | BURST_TIMEOUT        | Status of open burst and                                                                                                                                                                                                   | R    | 0x0   |
| 15:12 | TIMEBASE             | Observation of timebase signals for internal verification                                                                                                                                                                  | R    | 0x0   |
| 11:9  | RESERVED             | Reserved                                                                                                                                                                                                                   | R    | 0x0   |
| 8     | RESP_TIMEOUT         | Response timeout status                                                                                                                                                                                                    | R    | 0x0   |
| 7     | READEX               | Status of ReadEx/Write                                                                                                                                                                                                     | R    | 0x0   |
| 6     | BURST                | Status of open burst                                                                                                                                                                                                       | R    | 0x0   |
| 5     | RESP_WAITING         | Responses waiting                                                                                                                                                                                                          | R    | 0x0   |
| 4     | REQ_ACTIVE           | Requests outstanding                                                                                                                                                                                                       | R    | 0x0   |
| 3:1   | RESERVED             | Reserved                                                                                                                                                                                                                   | R    | 0x0   |
| 0     | CORE_RESET           | Reset input from core interface                                                                                                                                                                                            | R    | 0x0   |

**Table 5-794. Register Call Summary for Register GEM\_AGENT\_STATUS**

IVA2.2 Subsystem Register Manual

- [IA\\_GEM Register Mapping Summary: \[0\]](#)

## 5.5.15 IA\_EDMA Registers

This section provides information about the Initiator Agent for the EDMA module. Each register in the module is described separately below.

### 5.5.15.1 IA\_EDMA Register Mapping Summary

**Table 5-795. IA\_EDMA Register Mapping Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address |
|-------------------|------|-----------------------|----------------|------------------|
| EDMA_AGENT_STATUS | R    | 32                    | 0x0000 0028    | 0x000F 8C28      |

### 5.5.15.2 IA\_EDMA Register Descriptions

**Table 5-796. EDMA\_AGENT\_STATUS**

|                  |                       |          |         |
|------------------|-----------------------|----------|---------|
| Address Offset   | 0x0000 0028           | Instance | IA_EDMA |
| Physical Address | 0x000F 8C28           |          |         |
| Description      | Agent Status Register |          |         |
| Type             | R                     |          |         |

| 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        |            |
|----------|----|------------------------|----|----------------------|----|----|----------|--------|----|----------|----|----|----|----|---------------|----|----------|----|----------|----|--------------|---|--------|---|-------|---|--------------|---|------------|---|----------|------------|
| RESERVED |    | INBAND_ERROR_SECONDARY |    | INBAND_ERROR_PRIMARY |    |    | RESERVED | MERROR |    | RESERVED |    |    |    |    | BURST_TIMEOUT |    | TIMEBASE |    | RESERVED |    | RESP_TIMEOUT |   | READEX |   | BURST |   | RESP_WAITING |   | REQ_ACTIVE |   | RESERVED | CORE_RESET |

| Bits  | Field Name             | Description                                                                                                                                                                                                         | Type | Reset |
|-------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED               | Reserved                                                                                                                                                                                                            | R    | 0x0   |
| 29    | INBAND_ERROR_SECONDARY | Error Status for in-band errors with MErrSteer indicating a secondary error.<br><br>Read 0x0: No in-band error received<br>Write 0x0: Ignored<br>Read 0x1: In-band error received<br>Write 0x1: Clear in-band error | RW   | 0x0   |
| 28    | INBAND_ERROR_PRIMARY   | Error Status for in-band errors with MErrSteer indicating Primary Error<br><br>Read 0x0: No in-band error received<br>Write 0x0: Ignored<br>Read 0x1: In-band error received<br>Write 0x1: Clear in-band error      | RW   | 0x0   |
| 27:25 | RESERVED               | Reserved                                                                                                                                                                                                            | R    | 0x0   |
| 24    | MERROR                 | MError assertion detected                                                                                                                                                                                           | R    | 0x0   |
| 23:17 | RESERVED               | Reserved                                                                                                                                                                                                            | R    | 0x00  |
| 16    | BURST_TIMEOUT          | Status of open burst and                                                                                                                                                                                            | R    | 0x0   |
| 15:12 | TIMEBASE               | Observation of timebase signals for internal verification                                                                                                                                                           | R    | 0x0   |
| 11:9  | RESERVED               | Reserved                                                                                                                                                                                                            | R    | 0x0   |
| 8     | RESP_TIMEOUT           | Response timeout status                                                                                                                                                                                             | R    | 0x0   |
| 7     | READEX                 | Status of ReadEx/Write                                                                                                                                                                                              | R    | 0x0   |
| 6     | BURST                  | Status of open burst                                                                                                                                                                                                | R    | 0x0   |
| 5     | RESP_WAITING           | Responses waiting                                                                                                                                                                                                   | R    | 0x0   |
| 4     | REQ_ACTIVE             | Requests outstanding                                                                                                                                                                                                | R    | 0x0   |
| 3:1   | RESERVED               | Reserved                                                                                                                                                                                                            | R    | 0x0   |
| 0     | CORE_RESET             | Reset input from core interface                                                                                                                                                                                     | R    | 0x0   |

**Table 5-797. Register Call Summary for Register EDMA\_AGENT\_STATUS**

I/VA2.2 Subsystem Register Manual

- [IA\\_EDMA Register Mapping Summary: \[0\]](#)

### 5.5.16 IA\_SEQ Registers

This section provides information about the Initiator Agent for the Sequencer module. Each register in the module is described separately below.

#### 5.5.16.1 IA\_SEQ Register Mapping Summary

**Table 5-798. IA\_SEQ Register Mapping Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address |
|------------------|------|-----------------------|----------------|------------------|
| SEQ_AGENT_STATUS | R    | 32                    | 0x0000 0028    | 0x000F 9028      |

**5.5.16.2 IA\_SEQ Register Descriptions****Table 5-799. SEQ\_AGENT\_STATUS**

|                  |                       |          |        |
|------------------|-----------------------|----------|--------|
| Address Offset   | 0x0000 0028           | Instance | IA_SEQ |
| Physical Address | 0x000F 9028           |          |        |
| Description      | Agent Status Register |          |        |
| Type             | R                     |          |        |



| Bits  | Field Name             | Description                                                                                                                                                                                                         | Type | Reset |
|-------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED               | Reserved                                                                                                                                                                                                            | R    | 0x0   |
| 29    | INBAND_ERROR_SECONDARY | Error Status for in-band errors with MErrSteer indicating a secondary error.<br><br>Read 0x0: No in-band error received<br>Write 0x0: Ignored<br>Read 0x1: In-band error received<br>Write 0x1: Clear in-band error | RW   | 0x0   |
| 28    | INBAND_ERROR_PRIMARY   | Error Status for in-band errors with MErrSteer indicating Primary Error<br><br>Read 0x0: No in-band error received<br>Write 0x0: Ignored<br>Read 0x1: In-band error received<br>Write 0x1: Clear in-band error      | RW   | 0x0   |
| 27:25 | RESERVED               | Reserved                                                                                                                                                                                                            | R    | 0x0   |
| 24    | MERROR                 | MError assertion detected                                                                                                                                                                                           | R    | 0x0   |
| 23:17 | RESERVED               | Reserved                                                                                                                                                                                                            | R    | 0x00  |
| 16    | BURST_TIMEOUT          | Status of open burst and                                                                                                                                                                                            | R    | 0x0   |
| 15:12 | TIMEBASE               | Observation of timebase signals for internal verification                                                                                                                                                           | R    | 0x0   |
| 11:9  | RESERVED               | Reserved                                                                                                                                                                                                            | R    | 0x0   |
| 8     | RESP_TIMEOUT           | Response timeout status                                                                                                                                                                                             | R    | 0x0   |
| 7     | READEX                 | Status of ReadEx/Write                                                                                                                                                                                              | R    | 0x0   |
| 6     | BURST                  | Status of open burst                                                                                                                                                                                                | R    | 0x0   |
| 5     | RESP_WAITING           | Responses waiting                                                                                                                                                                                                   | R    | 0x0   |
| 4     | REQ_ACTIVE             | Requests outstanding                                                                                                                                                                                                | R    | 0x0   |
| 3:1   | RESERVED               | Reserved                                                                                                                                                                                                            | R    | 0x0   |

| Bits | Field Name | Description                     | Type | Reset |
|------|------------|---------------------------------|------|-------|
| 0    | CORE_RESET | Reset input from core interface | R    | 0x0   |

**Table 5-800. Register Call Summary for Register SEQ\_AGENT\_STATUS**I<sup>A</sup>2.2 Subsystem Register Manual

- [IA\\_SEQ Register Mapping Summary: \[0\]](#)



## ***Camera Image Signal Processor***

This chapter describes the camera image signal processor (ISP2P) in the device. ISP2P is backward compatible with ISP2 that is in the legacy device. To facilitate reading in this chapter, ISP2P will be referred to as ISP.

---

**NOTE:** Some of the information in this chapter is © 2005-2008 MIPI Alliance, Inc. All rights reserved.

MIPI Alliance Member Confidential.

All rights reserved. This material is reprinted with the permission of the MIPI Alliance, Inc. No part(s) of this document may be disclosed, reproduced or used for any purpose other than as needed to support the use of the products of TI.

See [Device 37xx MIPI Disclaimer](#) for details.

---



---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#), and the device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                               | Page        |
|-----------------------------------------------------|-------------|
| <b>6.1 Camera ISP Overview .....</b>                | <b>1080</b> |
| <b>6.2 Camera ISP Environment .....</b>             | <b>1085</b> |
| <b>6.3 Camera ISP Integration .....</b>             | <b>1133</b> |
| <b>6.4 Camera ISP Functional Description .....</b>  | <b>1148</b> |
| <b>6.5 Camera ISP Basic Programming Model .....</b> | <b>1238</b> |
| <b>6.6 Camera ISP Register Manual .....</b>         | <b>1296</b> |

## 6.1 Camera ISP Overview

The camera ISP is a key component for imaging and video applications such as video preview, video record, and still-image capture with or without digital zooming.

The camera ISP provides the system interface and the processing capability to connect RAW image-sensor modules to the device.

The camera ISP implements three receivers which are named CSI2A, CSI1/CCP2B, and CSI2C. The CSI2A and CSI2C are MIPI® D-PHY CSI2 compatible. The CCP2B (compact camera port) is MIPI D-PHY CSI1 compatible if used in CSI1 mode. Moreover, on the outside boundaries of camera ISP before the mentioned above receivers, are located two MIPI D-PHY CSI2 compliant physical layers (CSIPHY1 and CSIPHY2). The two PHYs are MIPI CSI2 and MIPI CSI1/SMIA CCP2 compliant. Their purpose is to act as a physical connection between the outside pins for connecting external sensors and the internal receivers. By configuring the outside PHYs and feeding the receivers, the camera ISP supports up to two simultaneous pixel flows from external sensors. Only one of the data flow can use the Video processing hardware while the other must go to memory.

Figure 6-1 shows the camera ISP overview diagram.

**Figure 6-1. Camera ISP Overview Diagram**


- (1) The mode for each PHY can be selected from CSI2, CSI1/CCP2B, and GPI at SCM.CONTROL\_CAMERA\_PHY\_CTRL register. It can also control the connection between one of the PHY's and CSI1/CCP2B receiver via multiplexing.
- (2) There is no top-level muxmode (padconf SCM register) control bit for the different camera modes supported by the interfaces. If one or another of the interfaces is enabled, then the camera input signals will be automatically routed to the corresponding ISP receiver depending on the PHY operating mode settings (SCM.CONTROL\_CAMERA\_PHY\_CTRL register).

**NOTE:** For information about initializing and configuring the CSIPHY, see [Section 6.5.2, Programming the CSI1/CCP2B or CSI2 Receiver Associated PHY](#).

## 6.1.1 Camera ISP Features

The camera ISP can support the following features:

- **Image sensor:**
  - Interface with various image sensors:
    - R, G, B primary colors
    - Ye, Cy, Mg, G complementary colors
  - Support for electronic rolling shutter (ERS) and global-release reset shutters
- **CSI1/CCP2B serial interface:** The CSI1/CCP2B receiver is compatible with the SMIA CCP2 specification and the MIPI CSI1 specification. It supports the following features:
  - Image from sensor
    - Transfer of pixels and data received by the associated PHY to system memory or to the Video processing hardware
    - Unidirectional data link
    - 1D and 2D addressing mode
    - Maximum data rate of up to 650 Mbps in CCP2 mode and 208 Mbps in CSI1 mode
    - False synchronization code protection
    - Ping-pong mechanism for double-buffering
    - Support of RGB, RAW, YUV, and JPEG formats
    - DPCM decompression supported
  - Image read from memory
    - RAW formats supported
- **Two MIPI CSI2 serial interfaces:** The camera ISP implements two MIPI CSI2 serial interface receivers (CSI2A and CSI2C). The CSI2 receivers enables data transfer at up to 2Gbps. It is based on the MIPI CSI2 Specification 1.0.
  - Transfer pixels and data received by the CSIPHY1 or CSIPHY2 to the system memory or to the Video processing hardware
  - Uses unidirectional data link
  - Supports up to two data-configurable links, in addition to the clock signaling
  - Maximum data rate of up to 1000M bps per data lane
  - Data merger configuration for CSI2A two data lanes and CSI2C one data lane
  - Error detection and correction by the protocol engine
  - DMA engine integrated with dedicated FIFO
  - Streaming 1-D and 2-D addressing mode (rotation is not supported by the 2D mode)
  - Ping-pong mechanism for double buffering
  - Burst support
  - RAW frame transcoding. Including DPCM and A-law compression
  - JPEG support for unknown length transfer
  - RGB, RAW, and YUV formats supported
  - Storage in progressive mode for interlaced stream (using line numbering)
  - Conversion of the RGB formats
  - Configuration of the associated PHY through Serial Configuration Port (SCP)
  - Fully configurable interface of PHY: position of the clock and data and order of +/- differential signals for each pair.
  - Low power mode using PRCM protocols
- **Parallel interface:** The camera parallel interface (CPI) supports two modes:
  - **SYNC mode:** In this mode, the image-sensor module provides horizontal and vertical synchronization signals to the parallel interface, along with the pixel clock. This mode works with 8-,

10-, 11-, and 12-bit data (if using CCDC inside the Video processing hardware above 10 bit data must be internally converted to 10 bit by the Bridge lane shifter). SYNC mode supports progressive and interlaced image-sensor modules.

- **ITU mode:** In this mode, the image-sensor module provides an ITU-R BT 656-compatible data stream. The horizontal and vertical synchronization signals are not provided to the interface. Instead, the data stream embeds start-of-active video (SAV) and end-of-active video (EAV) synchronization code. This mode works in 8- and 10-bit configurations.
- **Video processing hardware:** The Video processing hardware removes the need for expensive camera modules to perform processing functions. It consists of parts: front end and back end:
  - **Video processing front end (VPFE):** Performs signal-processing operations on RAW image input data. The output data can go directly to memory for software processing, or to the video-processing back end for further processing. The Video processing front end is supported by the CCDC module. Signal-processing operations include:
    - Optical clamping
    - Black-level compensation
    - Look-up table (LUT) based faulty pixel correction
    - 2D lens-shading compensation
    - Data formatter
    - Output formatter

---

**NOTE:** Up to 12-bit data at 83 MHz can be transferred from the video port to the ISP submodules. The video processing ISP can treat one pixel every two interconnect clock cycles.

---

- **Video processing back end (VPBE):** Performs signal-processing operations on RAW image input data. Outputs YCbCr 4:2:2 data.
  - **Preview module:** Signal-processing operations include:
    - A-law decompression: transforms non-linear 8-bit data to 10-bit linear data. The CCDC module can perform A-law compression
    - Noise reduction and faulty pixel correction
      - Dark frame capture and subtraction
      - Horizontal median filter
      - Programmable filter: 3x3 kernel of the same color
      - Couple faulty pixel correction
    - Digital gain
    - White balance
    - Programmable color filter array (CFA) interpolation: 5x5 kernel
    - Black adjustment
    - Programmable color correction (RGB to RGB)
    - Programmable gamma correction: 1024 entries for each color
    - Programmable color conversion (RGB to YCbCr 4:4:4)
    - Color subsampling (YCbCr 4:4:4 to YCbCr 4:2:2)
    - Luminance enhancement (non-linear), chrominance suppression and offsetThe preview module can also work from memory to memory.
  - **Resizer module:** Performs on-the-fly upsampling (up to x4) and downsampling (down to x0.25) of YCbCr 4:2:2 data by applying high-quality horizontal and vertical filters. The horizontal and vertical resizer ratios are independent. Applicable ratios are 256/N, with N ranging from 64 to 1024. This feature enables digital zooming (upsampling) and video preview (downsampling).The resizer module can also work from memory to memory. Higher or lower ratios can be obtained by combining on-the-fly resizing followed by memory-to-memory resizing.

- **Statistic collection modules (SCM):** The host CPU uses statistics to adjust various parameters for processing image data.
  - **3A metrics:** Collects on-the-fly RAW image data metrics, which are required to perform the control loops for auto white balance (AWB), auto exposure (AE), and autofocus (AF). The MPU subsystem typically uses data metrics to adjust various parameters for processing image data.
  - **Histogram:** Performs on-the-fly pixel binning of RAW image, based on color value ranges and regions. Supports up to 4 regions and up to 256 bins per color. The MPU subsystem typically uses the histogram with 3A metrics to adjust various parameters for processing image data.  
The histogram module can also work from memory to memory.
- **Central-resource shared buffer logic (SBL):** Buffers and schedules memory accesses requested by camera ISP modules
- **Circular buffer:** Prevents storage of full image frames in memory when data must be postprocessed and/or preprocessed by software
- **Memory management unit (MMU):** Manages virtual-to-physical address translation for external addresses and solves the memory-fragmentation issue. Enables the camera driver to dynamically allocate and deallocate memory; the MMU handles memory fragmentation.
- **Clock generator:** Generates two independent clocks that can be used by two external image sensors
- **Timing control:**
  - Generation clocks passed to the clock generator
  - Generation of signals for strobe flash, mechanical shutter, and global reset. Support for red-eye removal.
- **Open core protocol (OCP) compliant:**
  - One 64-bit master interface connected to L3
  - One 32-bit slave interface connected to L4

## 6.2 Camera ISP Environment

### 6.2.1 Camera ISP Functions

[Table 6-1](#) describes the camera ISP functions and the corresponding application fields.

**Table 6-1. Camera ISP Functions**

| Function                                                                  | Description                                                                                                                                                                                                                                                                               |
|---------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parallel interface in generic configuration (SYNC mode)                   | The camera ISP supports up to 12 bits (If CCDC used inside the Video processing hardware, data must be converted to 10 bit by the Bridge lane shifter).<br>The camera ISP can interface with RAW interlaced or progressive image sensors using RGB or complementary color mosaic filters. |
| Parallel interface in ITU-R BT.656 configuration (ITU mode)               | The camera ISP can extract the synchronization signal start of active video and end of active video from the ITU-R BT.656 bit stream. 8-bit and 10-bit modes are supported.                                                                                                               |
| CSI1 / CCP2B serial interface configuration (serial mode)                 | The camera ISP supports one CCP2B serial interface, compatible MIPI CSI1.                                                                                                                                                                                                                 |
| MIPI CSI2 serial interfaces (CSI2A and CSI2C) configuration (serial mode) | The camera ISP supports two MIPI CSI2 serial interface.                                                                                                                                                                                                                                   |

---

**NOTE:** The two CSI2A and CSI2C receivers and the CSI1/CCP2B receiver can be active simultaneously. Either the CSIPHY1 or CSIPHY2 data can go through the selected interfaces to the video-processing hardware, while the other data are sent directly to memory by the receiver selected.

The parallel interface is limited to 10 bits when used simultaneously with the CSI2A or CSI2C receivers.

The parallel interface cannot be used simultaneously with the CSI1/CCP2B receiver.

---

## 6.2.2 Camera ISP Signal Descriptions

**Table 6-2. IO Description**

| Ball Name        | I/O <sup>(1)</sup> | Description                                                                          | Parallel SYNC Mode | Parallel ITU Mode | Serial Mode CSI\CCP2 | Serial Mode CSI2 |
|------------------|--------------------|--------------------------------------------------------------------------------------|--------------------|-------------------|----------------------|------------------|
| cam_hs           | I/O                | Line trigger input/output signal                                                     | +                  |                   |                      |                  |
| cam_vs           | I/O                | Frame trigger input/output signal                                                    | +                  |                   |                      |                  |
| cam_fld          | I/O                | Field identification input/output signal                                             | +                  |                   |                      |                  |
| cam_pclk         | I                  | Parallel interface pixel clock                                                       | +                  | +                 |                      |                  |
| cam_d[11:0]      | I                  | Parallel mode: input data bits 0 to 11                                               | +                  | +                 |                      |                  |
| cam_wen          | I                  | External write-enable signal                                                         | +                  |                   |                      |                  |
| cam_strobe       | O                  | Flash strobe control signal                                                          | +                  | +                 | +                    | +                |
| cam_shutter      | O                  | Mechanical shutter control signal                                                    | +                  | +                 | +                    | +                |
| cam_global_reset | I/O                | Global reset release shutter signal                                                  | +                  | +                 | +                    | +                |
| csi2_dx0         | I                  | Serial CSI2 mode: Fully configurable pair: clock or data, positive or negative       |                    |                   |                      | +                |
| csi2_dy0         | I                  | Serial CSI2 mode: Fully configurable pair: clock or data, positive or negative       |                    |                   |                      | +                |
| csi2_dx1         | I                  | Serial CSI2 mode: Fully configurable pair: clock or data, positive or negative       |                    |                   |                      | +                |
| csi2_dy1         | I                  | Serial CSI2 mode: Fully configurable pair: clock or data, positive or negative       |                    |                   |                      | +                |
| csi2_dx2         | I                  | Serial CSI2 mode: Fully configurable pair: clock or data, positive or negative       |                    |                   |                      | +                |
| csi2_dy2         | I                  | Serial CSI2 mode: Fully configurable pair: clock or data, positive or negative       |                    |                   |                      | +                |
| ccpv2_dx0        | I                  | Serial CSI/CCP2B mode: Fully configurable pair: strobe or data, positive or negative |                    |                   | +                    |                  |

<sup>(1)</sup> I = Input, O = Output, PWR = Power

**Table 6-2. IO Description (continued)**

| Ball Name | I/O <sup>(1)</sup> | Description                                                                           | Parallel SYNC Mode | Parallel ITU Mode | Serial Mode CSI\CCP2 | Serial Mode CSI2 |
|-----------|--------------------|---------------------------------------------------------------------------------------|--------------------|-------------------|----------------------|------------------|
| ccpv2_dy0 | I                  | Serial CSI/CCP2B mode: Fully configurable pair: strobe or data, positive or negative  |                    |                   | +                    |                  |
| ccpv2_dx1 | I                  | Serial CSI/CCP2B mode: Fully configurable pair: strobe or data, positive or negative  |                    |                   | +                    |                  |
| ccpv2_dy1 | I                  | Serial CSI1/CCP2B mode: Fully configurable pair: strobe or data, positive or negative |                    |                   | +                    |                  |
| cam_xclka | O                  | External clock for the image-sensor module                                            | +                  | +                 | +                    | +                |
| cam_xclkb | O                  | External clock for the image-sensor module                                            | +                  | +                 | +                    | +                |

### 6.2.3 Camera ISP Connectivity Schemes

The cam\_d[9:6] implements the CSIPHY1. The cam\_d[1:0] implements the CSIPHY2. Moreover, the PHY's can be configured in GPI, CCP, or D-PHY modes from the control module and the SCM.CONTROL\_CAMERA\_PHY\_CTRL control module register. Besides the mode set, from the SCM.CONTROL\_CAMERA\_PHY\_CTRL[4] CSI1\_RX\_sel sets which PHY will be hooked to the CSI1/ CCP2B receiver of the ISP. Some initialization and pad configuration must also be done. For information about initializing and configuring the CSIPHY, see [Section 6.5.2, Programming the CSI1/CCP2B or CSI2 Receiver Associated PHY](#).

- In GPI mode, the PHY can be connected to a parallel camera (CAM\_D[1:0] in CSIPHY1 and CAM\_D[9:6] in CSIPHY2)
- In CCP mode, the PHY can be connected to a CCPV2 camera (strobe/data pairs) or a CSI1 camera (clock/data pairs)
- In D-PHY mode, the PHY can be connected to a CSI2 camera (2 or 1 data lane in CSIPHY1 and 1 data lane only in CSIPHY2)

**Table 6-3. Camera ISP Connectivity Schemes**

| Receiver                   | Scheme 1               | Scheme 2              | Scheme 3                    | Scheme 4                    | Scheme 5               | Scheme 6                                    |
|----------------------------|------------------------|-----------------------|-----------------------------|-----------------------------|------------------------|---------------------------------------------|
|                            | Legacy                 | Legacy                | Addon                       | Legacy                      | Addon                  | Addon                                       |
| CPI                        | ON, up to 10-bit       | ON, 12-bit            | ON, 12-bit                  | OFF                         | OFF                    | OFF                                         |
| Serial CSI2A               | ON, CSI2A 2 data lanes | ON, CSI2A 1 data lane | OFF                         | ON, CSI2A 2 data lanes      | ON, CSI2A 2 data lanes | OFF                                         |
| Serial CSI1 / CCP2B        | OFF                    | OFF                   | ON, CSI1/ CCP2B 1 data lane | ON, CSI1/ CCP2B 1 data lane | OFF                    | ON, CSI1/CCP2B 1 data lane                  |
| Serial CSI2C               | OFF                    | OFF                   | OFF                         | OFF                         | ON, CSI2C 1 data lanes | OFF                                         |
| Data flows handling by ISP | Simultaneous           | Simultaneous          | Simultaneous                | Simultaneous                | Simultaneous           | Sequential through control module selection |

Table 6-3. Camera ISP Connectivity Schemes (continued)

| Receiver                  | Scheme 1                 | Scheme 2             | Scheme 3                               | Scheme 4                 | Scheme 5                | Scheme 6                |
|---------------------------|--------------------------|----------------------|----------------------------------------|--------------------------|-------------------------|-------------------------|
|                           | Legacy                   | Legacy               | Addon                                  | Legacy                   | Addon                   | Addon                   |
| cam_hs                    | CPI <sup>(1)</sup>       |                      |                                        |                          |                         |                         |
| cam_vs                    |                          |                      |                                        |                          |                         |                         |
| cam_xclka                 |                          |                      |                                        |                          |                         |                         |
| cam_polk                  |                          |                      |                                        |                          |                         |                         |
| cam_fld                   |                          |                      |                                        |                          |                         |                         |
| cam_d0/csi2_dx2           |                          |                      |                                        |                          |                         |                         |
| cam_d1/csi2_dy2           | CSI2A <sup>(2) (3)</sup> | CPI                  | CPI                                    | CSI2A <sup>(2)</sup>     | CSI2A <sup>(2)</sup>    |                         |
| cam_d2                    | CPI                      |                      |                                        |                          |                         |                         |
| cam_d3                    |                          |                      | CSI1/CCP2B with CSIPHY1 <sup>(4)</sup> | CSI2C <sup>(5) (6)</sup> | CSI1/CCP2B with CSIPHY1 |                         |
| cam_d4                    |                          |                      |                                        |                          |                         |                         |
| cam_d5                    |                          |                      |                                        |                          |                         |                         |
| cam_d6/ccpv2_dx0/csi2_dx0 |                          |                      |                                        |                          |                         |                         |
| cam_d7/ccpv2_dy0/csi2_dy0 |                          |                      |                                        |                          |                         |                         |
| cam_d8/ccpv2_dx1/csi2_dx1 |                          |                      |                                        |                          |                         |                         |
| cam_d9/ccpv2_dy1/csi2_dy1 |                          |                      |                                        |                          |                         |                         |
| vdda_csiphy1              | pwr rail VIO             | pwr rail VIO         | pwr rail VIO                           | pwr rail VIO             | pwr rail CCP            | pwr rail CCP            |
| cam_d10                   | CPI                      | CPI                  | CPI                                    |                          |                         |                         |
| cam_d11                   |                          |                      |                                        |                          |                         |                         |
| cam_xclkb                 |                          |                      |                                        |                          |                         |                         |
| cam_wen                   |                          |                      |                                        |                          |                         |                         |
| cam_strobe                |                          |                      |                                        |                          |                         |                         |
| csi2_dx0/ccpv2_dx0        | CSI2A <sup>(7)</sup>     | CSI2A <sup>(8)</sup> | CSI1/CCP2B with CSIPHY2                | CSI2A <sup>(7)</sup>     | CSI2A <sup>(7)</sup>    | CSI1/CCP2B with CSIPHY2 |
| csi2_dy0/ccpv2_dy0        |                          |                      |                                        |                          |                         |                         |
| csi2_dx1/ccpv2_dx1        |                          |                      |                                        |                          |                         |                         |
| csi2_dy1/ccpv2_dy1        |                          |                      |                                        |                          |                         |                         |
| vdda_csiphy2              | pwr rail CSI             | pwr rail CSI         | pwr rail CCP                           | pwr rail CSI             | pwr rail CSI            | pwr rail CSI            |

<sup>(1)</sup> CPI Interface in orange<sup>(2)</sup> Full: All data/clock lines connected<sup>(3)</sup> CSI2A Interface in green<sup>(4)</sup> CSI1/CCP2B Interface in blue<sup>(5)</sup> Limited: Some data/clock lines connected<sup>(6)</sup> CSI2C Interface in green<sup>(7)</sup> Full: All data/clock lines connected<sup>(8)</sup> Limited: Some data/clock lines connected

**NOTE:**

- If the parallel camera sensor is the only sensor connected to one CSIPHY, the SCM.CONTROL\_CAMERA0\_PHY\_CAMMOD and SCM.CONTROL\_CAMERA1\_PHY\_CAMMOD bits must be set to 0x11 (that is, GPI mode).
  - If the parallel camera sensor and the other camera sensor (CCP2 or CSI2) are connected to the same CSIPHY, the CONTROL\_CAMERA $x$ \_PHY\_CAMMOD bit must be set for CCP2 or CSI2 mode, respectively, (even if only one pair is used as GPI for CPI mode). In that case, the corresponding [CSI2\\_COMPLEXIO\\_CFG1](#).DAT $Ax$ \_POSITION bit must be set to 0x0 for the lane used in GPI mode.
-

## 6.2.4 Camera ISP Protocols and Data Formats

### 6.2.4.1 Camera ISP Parallel Generic Configuration Protocol and Data Format (8, 10, 11, 12 Bits)

The SYNC mode implements a generic parallel interface with the image sensor. The SYNC mode supports 8 to 12-bit-wide data signals.

In this configuration, no assumptions are made on the data format of pixels, but the dynamic range is limited to 8-, 10-, 12 bit (data can be pure luminance for black and white sensor, RGB444, Bayer RGB, etc.). The pixel data is presented on cam\_d, where one pixel is sampled for every cam\_pclk rising edge (or falling edge, depending on the configuration of cam\_pclk polarity). For more information, see [Section 6.4](#).

Additional pixel times between rows represent blanking periods. Active pixels are identified by a combination of two additional timing signals: horizontal synchronization (cam\_hs) and vertical synchronization (cam\_vs). During the image-sensor readout, these signals define when a row of valid data begins and ends, and when a frame starts and ends.

---

**NOTE:** For correct operation, the clock cam\_pclk must run during blanking periods (cam\_hs and cam\_vs inactive). cam\_pclk must start before sending cam\_d and start cam\_vs and cam\_hs.

---

[Figure 6-2](#) and [Figure 6-3](#) show the frame and data timing, respectively, based on synchronization signals in the parallel No BT configuration.

**Figure 6-2. Camera ISP Synchronization Signals and Frame Timing in SYNC Mode**



**Figure 6-3. Camera ISP Synchronization Signals and Data Timing in SYNC Mode**




---

**NOTE:** The pixel clock can be gated to qualify valid pixels. It can also be gated during blanking periods to reduce power consumption. However, at least 4 clock pulses are required before sending active image data and synchronization information; 8 clock pulses are required after the end of active video. Extra-clock pulses are allowed but not required during the line blanking periods.

---

[Figure 6-4](#) shows the timing diagram of the SYNC mode clock gating.

**Figure 6-4. Camera ISP SYNC Mode Clock Gating**


camisp-132

#### 6.2.4.2 Camera ISP Parallel Generic Configuration: JPEG Sensor Connection on the Parallel Interface

Some camera modules integrate an image-signal processor (ISP) and a JPEG encoder. The CCDC can interface with these camera modules and transfer the received JPEG stream to memory.

To use this mode, set the **ISP\_CTRL [30]** JPEG\_FLUSH bit.

Figure 6-5 shows timing diagrams for an JPEG stream.

**Figure 6-5. Camera ISP JPEG Stream Timing Diagrams**

**CAUTION**

The bridge cannot be used for JPEG sensor connections.

#### 6.2.4.3 Camera ISP ITU-R BT.656 Protocol and Data Formats (8, 10 Bits)

**CAUTION**

The ITU-R BT.656 mode cannot be used when the bridge is enabled.

The camera ISP interface supports data in ITU-R BT.656 format.

The ITU-R BT.656 standard specifies a method of transferring YUV422 data over an 8- or 10-bit video interface.

Figure 6-6 shows the data timing diagram with embedded synchronization signal.

**Figure 6-6. Camera ISP Data Timing With Embedded Synchronization Signals (8-Bit Case)**



In BT.656, the data words (8- or 10-bit) in which the eight most-significant bits (MSBs) are all set to 1, or all set to 0 are reserved. Only 254 of the possible 256 8-bit word values, and 1016 of the possible 1024 10-bit word values represent signal values.

The data is multiplexed in the following order: Cb0 Y0 Cr0 Y1 Cb2 Y2 Cr2 Y3, etc., where the byte sequence Cb2n Y2n Cr2n refers to interleaved luminance and chroma samples and the following byte Y2n + 1 corresponds to the next luminance sample.

The BT.656 protocol uses unique timing reference signals embedded in the video stream. The synchronization signals cam\_hs and cam\_vs are not needed. This reduces the number of wires required for a BT.656 video interface.

There are two timing reference codes: The start of active video (SAV) reference code precedes each video data block, and the end of active video (EAV) follows each video data block. Each timing reference signal consists of a 4-byte sequence in the following hexadecimal format: **FF 00 00 XY**. The first 3 bytes are a fixed preamble (see the ITU-R BT.656 specification). The fourth byte (XY) contains information defining field identification (F), blanking (V), and SAV/EAV information (H), and 4 parity bits calculated as a function of F, V, and H (see the ITU-R BT.656 specification).

Table 6-4 lists the video timing reference codes for SAV and EAV.

**Table 6-4. Camera ISP Video Timing Reference Codes for SAV and EAV**

| Data Bit Number | First Word (FF) | Second Word (00) | Third Word (00) | Fourth Word (XY) |
|-----------------|-----------------|------------------|-----------------|------------------|
| 9 (MSB)         | 1               | 0                | 0               | 1                |
| 8               | 1               | 0                | 0               | F                |
| 7               | 1               | 0                | 0               | V                |
| 6               | 1               | 0                | 0               | H                |
| 5               | 1               | 0                | 0               | P3               |
| 4               | 1               | 0                | 0               | P2               |
| 3               | 1               | 0                | 0               | P1               |
| 2               | 1               | 0                | 0               | P0               |
| 1               | 1               | 0                | 0               | 0                |
| 0               | 1               | 0                | 0               | 0                |

Table 6-5 contains a description of the F, V, and H signals.

**Table 6-5. Camera ISP F, V, H Signal Descriptions**

| Signal | Value | Command        |
|--------|-------|----------------|
| F      | 0     | Field 1        |
|        | 1     | Field 2        |
| V      | 0     | 0              |
|        | 1     | Vertical blank |
| H      | 0     | SAV            |
|        | 1     | EAV            |

The resulting Hamming distance between any two code words is four, allowing two error detections and one error correction. To enable or disable the error-correcting capability, configure the [CCDC\\_REC656IF \[1\]](#) ECCFVH bit.

---

**NOTE:** The 2-bit errors are detected, but not flagged or corrected. Errors of more than 2 bits are not corrected or flagged.

---

[Table 6-6](#) lists the F, V, and H protection (error-correction) bits.

**Table 6-6. Camera ISP F, V, H Protection (Error-Correction) Bits**

| F | V | H | P3 | P2 | P1 | P0 |
|---|---|---|----|----|----|----|
| 0 | 0 | 0 | 0  | 0  | 0  | 0  |
| 0 | 0 | 1 | 1  | 1  | 0  | 1  |
| 0 | 1 | 0 | 1  | 0  | 1  | 1  |
| 0 | 1 | 1 | 0  | 1  | 1  | 0  |
| 1 | 0 | 0 | 0  | 1  | 1  | 1  |
| 1 | 0 | 1 | 1  | 0  | 1  | 0  |
| 1 | 1 | 0 | 1  | 1  | 0  | 0  |
| 1 | 1 | 1 | 0  | 0  | 0  | 1  |

When operating in CCIR-656 mode, data is stored in SDRAM according to the format shown in [Table 6-7](#) when [CCDC\\_SYN\\_MODE \[11\]](#) PACK8 is enabled.

**Table 6-7. Camera ISP BT.656 Mode Data Format in SDRAM**

| 8 bit x 4 | Pixel3 (Y1/Cr0) | Pixel2 (Cr0/Y1) | Pixel1 (Y0/Cb0) | Pixel0 (Cb0/Y0) |
|-----------|-----------------|-----------------|-----------------|-----------------|
|           | Bit 31          |                 |                 | Bit 0           |

---

**NOTE:** The CCDC outputs the XY code in the SAV and EAV into memory. To eliminate this, users must set the SPH register field to +1. In addition, the NPH register field must be set to accurately represent the number of active pixels.

---

#### 6.2.4.4 Camera ISP CSI1/CCP2 Protocol and Data Formats

The CSI1/CCP2B receiver supports two protocols:

- MIPI CSI1 protocol
- CCP2 protocol

The MIPI CSI1 protocol is compatible with the CCP2 protocol with the following constraints:

- Class 0 CCP2 sensors are used: Data/clock
- No RAW6 or RAW7 data types
- No CRC code generation
- Only one logical channel: Channel 0
- No DPCM

This section describes CSI1/CCP2B protocol and data formats. [Table 6-8](#) describes the I/O for serial interface CSI1/CCP2B.

Moreover, the CSI1/CCP2B receiver is a serial interface to an image sensor. Data is taken from pins and through the configured associated PHY taken to the receiver (for information about initializing and configuring the CSIPHY, see [Section 6.5.2.2, Camera ISP CSIPHY Initialization for Work With CSI1/CCP2B Receiver](#)). The receiver on its side, can send data to the Video processing hardware or memory.

The CSI1/CCP2B receiver interface has several image-data operating modes, summarized in [Table 6-8](#).

**Table 6-8. Camera ISP CSI1/CCP2B Image Data Operating Modes and Alignment Constraints**

| <u>CCP2_LCx_CTRL[7:3]</u><br>Format | CCP2B Data Format        | OCP Bits per Pixel (bpp) (when sending data to memory, N/A when sending to VP) | Width Constraint: Must Be a Multiple of n Pixels | Storage Increase Versus Packed | 2D Mode Availability <sup>(1)</sup> | Comments                     |
|-------------------------------------|--------------------------|--------------------------------------------------------------------------------|--------------------------------------------------|--------------------------------|-------------------------------------|------------------------------|
| 0x0                                 | YUV422 big endian        | 16                                                                             | 8                                                | N/A                            | Yes                                 |                              |
| 0x1                                 | YUV422 little endian     | 16                                                                             | 8                                                | N/A                            | Yes                                 |                              |
| 0x2                                 | YUV420                   | 12                                                                             | 32                                               | N/A                            | No                                  |                              |
| 0x3                                 | YUV4:2:2 + VP            | N/A, data are sent to VP                                                       | 2                                                | N/A                            | N/A                                 |                              |
| 0x3                                 | RAW8 + VP                | N/A, data are sent to VP                                                       | 4                                                | N/A                            | N/A                                 |                              |
| 0x4                                 | RGB444 + EXP16           | 16                                                                             | 8                                                | N/A                            | Yes                                 |                              |
| 0x5                                 | RGB565                   | 16                                                                             | 8                                                | N/A                            | Yes                                 |                              |
| 0x6                                 | RGB888                   | 24                                                                             | 16                                               | N/A                            | No                                  |                              |
| 0x7                                 | RGB888 + EXP32           | 32                                                                             | 4                                                | N/A                            | Yes                                 |                              |
| 0x8                                 | RAW6 + EXP8              | 8                                                                              | 16                                               | 33%                            | No                                  | CCP2 only                    |
| 0x9                                 | RAW6 + DPCM10 + EXP16    | 16                                                                             | 8                                                | 167%                           | No                                  | DPCM decompression CCP2 only |
| 0xA                                 | RAW6 + DPCM10 + VP       | N/A, data are sent to VP                                                       | 16                                               | N/A                            | N/A                                 | DPCM decompression CCP2 only |
| 0xB                                 | RAW10 - RAW6 DPCM        | 6                                                                              | 64                                               | 40%                            | No                                  | DPCM compression CCP2 only   |
| 0xC                                 | RAW7 + EXP8              | 8                                                                              | 16                                               | 14%                            | No                                  | CCP2 only                    |
| 0xD                                 | RAW7 + DPCM10 + EXP16    | 16                                                                             | 8                                                | 129%                           | No                                  | DPCM decompression CCP2 only |
| 0xE                                 | RAW7 + DPCM10 + VP       | N/A, data are sent to VP                                                       | 32                                               | N/A                            | N/A                                 | DPCM decompression CCP2 only |
| 0xF                                 | RAW10 - RAW6 DPCM + EXP8 | 8                                                                              | 16                                               | 20%                            | No                                  | DPCM compression CCP2 only   |
| 0x10                                | RAW6                     | 6                                                                              | 64                                               | N/A                            | No                                  | CCP2 only                    |
| 0x10                                | RAW7                     | 7                                                                              | 128                                              | N/A                            | No                                  | CCP2 only                    |
| 0x10                                | RAW8                     | 8                                                                              | 16                                               | N/A                            | No                                  |                              |
| 0x11                                | RAW8 + DPCM10 + EXP16    | 16                                                                             | 8                                                | 100%                           | No                                  | DPCM decompression CCP2 only |
| 0x12                                | RAW8 + DPCM10 + VP       | N/A, data are sent to VP                                                       | 4                                                | N/A                            | N/A                                 | DPCM decompression CCP2 only |
| 0x13                                | RAW10 - RAW7 DPCM        | 7                                                                              | 128                                              | 30%                            | No                                  | DPCM compression CCP2 only   |
| 0x14                                | RAW10                    | 10                                                                             | 64                                               | N/A                            | No                                  |                              |
| 0x15                                | RAW10 + EXP16            | 16                                                                             | 8                                                | 60%                            | No                                  |                              |
| 0x16                                | RAW10 + VP               | N/A, data are sent to VP                                                       | 16                                               | N/A                            | N/A                                 |                              |

<sup>(1)</sup> If data bigger than 10 bits and meant to be used by the CCDC, Bridge lane shifter must be configured for internal conversion to 10 bits.

**Table 6-8. Camera ISP CSI1/CCP2B Image Data Operating Modes and Alignment Constraints (continued)**

| <b>CCP2_LCx_CTRL[7:3]<br/>Format</b> | <b>CCP2B Data Format</b>    | <b>OCP Bits per Pixel (bpp)<br/>(when sending data to memory,<br/>N/A when sending to VP)</b> | <b>Width Constraint:<br/>Must Be a Multiple of n Pixels</b> | <b>Storage Increase Versus Packed</b> | <b>2D Mode Availability <sup>(1)</sup></b> | <b>Comments</b>              |
|--------------------------------------|-----------------------------|-----------------------------------------------------------------------------------------------|-------------------------------------------------------------|---------------------------------------|--------------------------------------------|------------------------------|
| 0x17                                 | RAW10 - RAW7<br>DPCM + EXP8 | 8                                                                                             | 16                                                          | 20%                                   | No                                         | DPCM compression CCP2 only   |
| 0x18                                 | RAW12                       | 12                                                                                            | 32                                                          | N/A                                   | No                                         |                              |
| 0x19                                 | RAW12 + EXP16               | 16                                                                                            | 8                                                           | 33%                                   | No                                         |                              |
| 0x1A                                 | RAW12 + VP                  | N/A, data are sent to VP                                                                      | 8                                                           | N/A                                   | N/A                                        |                              |
| 0x1B                                 | RAW10 - RAW8<br>DPCM        | 8                                                                                             | 16                                                          | 20%                                   | No                                         | DPCM decompression CCP2 only |
| 0x1C                                 | JPEG, 8-bit data            | N/A                                                                                           | N/A                                                         | N/A                                   | No                                         |                              |
| 0x1D                                 | JPEG, 8-bit data + FSP      | N/A                                                                                           | N/A                                                         | N/A                                   | No                                         |                              |
| 0x1E                                 | RAW10 - RAW8                | 8                                                                                             | 16                                                          | 20%                                   | No                                         | Data right shift             |

**NOTE:**

- EXP8 = Data expansion to 8 bits, padding with zeros
- EXP16 = Data expansion to 16 bits, padding with alpha or zeros  
**CCP2\_LCx\_CTRL [15:8] ALPHA** can be used to set an alpha value.  
For RGB444 + EXP16:
  - data\_out[31:28] = ALPHA[3:0] and data\_out[27:16] = RGB444
  - data\_out[15:12] = ALPHA[3:0] and data\_out[11:0] = RGB444
- EXP32 = Data expansion to 32 bits, padding with alpha  
**CCP2\_LCx\_CTRL [15:8] ALPHA** can be used to set an alpha value.  
For RGB888 + EXP32: data\_out[31:24] = ALPHA[7:0] and data\_out[23:0] = RGB888
- FSP = False synchronization code protection decoding. Applies only to JPEG8 data format.
- VP = Output to the video processing hardware is enabled. The programmer must ensure that only one logical channel is enabled to the Video processing hardware. The behavior of the video processing hardware is unpredictable if several logical channels to it are enabled simultaneously.

The preamble 0xFF0000 is fixed by construction and must not be modified. However, the CSI1/CCP2B receiver programming model allows the synchronization code identifier to be overwritten: bits 0 to 3.

Every code is transmitted bytewise, least-significant bit (LSB) first. For example, the code 0xFF00:0002 transmitted from the image sensor corresponds to the following bitstream: 11111111 - 00000000 - 00000000 - 01000000. Every default code starts with a set of eight 1s and sixteen 0s that are never received in pixel data. This means that content having eight 1s and sixteen 0s is not allowed. [Figure 6-7](#) shows an example of 0xFF00 0002 transmission.

**Figure 6-7. Camera ISP Example of 0xFF00 0002 Transmission**

Every code is transmitted bytewise, LSB first.  
Example: code 0xFF00:0002



#### **6.2.4.4.1 Camera ISP CSI1/CCP2 Pixel Data Format**

This section summarizes how the CSI1/CCP2B pixel data formats are transmitted over the serial interface and how the pixels are reconstructed, stored in memory, or passed to the video port.

The CSI1/CCP2B receiver can cope with all data formats if the data line length sent through the associated PHY is a multiple of 32 bits. This condition is required for the CSI1/CCP2B receiver to work correctly.

However, some data formats impose stronger line-length constraints to correctly finish pixel reconstruction at the end of the lines. If the additional constraints are not respected:

- Only the last reconstructed pixels in every line are erroneous. The missing bits are replaced with 0s to perform pixel reconstruction.
  - The FW\_IRQ interrupt is triggered.

#### **6.2.4.4.1.1 Camera ISP CSI1/CCP2 YUV Pixel Data Formats**

The YUV422 data format can be stored to memory in little- or big-endian format. The line length sent through the associated PHY must be a multiple of 32 bits.

YUV422 data format can also be sent to the video port.

**YUV422 + VP** is used to output RAW8 data to the video port: YUV422 + VP is equivalent to RAW8 + VP. [Figure 6-8](#) and [Figure 6-9](#) show big-endian and little-endian YUV422 format, respectively.

**Figure 6-8. Camera ISP CSI1/CCP2 YUV422 Big Endian**

YUV422 big endian

## Transmitter



## Receiver



First two pixels of first odd line are:  $\{y_1, v_1, u_1\}$  and  $\{y_2, v_1, u_1\}$

First two pixels of first even line are:  $\{y_{n+1}, v_{n+1}, u_{n+1}\}$  and  $\{y_{n+2}, v_{n+1}, u_{n+1}\}$

```
t0: VP_DATA[7:0] = [u7 u6 u5 u4 u3 u2 u1 u0]
t1: VP_DATA[7:0] = [y7 y6 y5 y4 y3 y2 y1 y0]
t2: VP_DATA[7:0] = [v7 v6 v5 v4 v3 v2 v1 v0]
t3: VP_DATA[7:0] = [y7 y6 y5 y4 y3 y2 y1 y0]
```

YUV4:2:2 + VP

camisp-181

**Figure 6-9. Camera ISP CSI1/CCP2 YUV422 Little Endian**

## YUV422 little endian



```
t0: VP_DATA[7:0] = [u7 u6 u5 u4 u3 u2 u1 u0]
t1: VP_DATA[7:0] = [y7 y6 y5 y4 y3 y2 y1 y0]
t2: VP_DATA[7:0] = [v7 v6 v5 v4 v3 v2 v1 v0]
t3: VP_DATA[7:0] = [y7 y6 y5 y4 y3 y2 y1 y0]
```

YUV4:2:2 + VP

camisp-182

The line length sent through the associated configured PHY is a multiple of 32 bits. Furthermore, the line length is a multiple of  $3 \times 32$  bits and the number of lines is even to correctly finish the pixel reconstruction.

The line structure is different for odd and even lines. Odd lines transport the U component, while even lines contain the V component. This is shown in Figure 6-10.

**Figure 6-10. Camera ISP CSI1/CCP2 YUV420**

#### 6.2.4.4.1.2 Camera ISP CSI1/CCP2 RGB Pixel Data Formats

RGB888 data format can be output to memory in two formats: with no data expansion and with data expansion.

If data expansion is used, the value of the 8 upper bits is programmable and can be set with an alpha value for computer graphics applications. The line length sent through the associated PHY is a multiple of 32 bits. Furthermore, the line length is a multiple of 3 x 32 bits to correctly finish pixel reconstruction.

Figure 6-11 shows an example of RGB888 format.

**Figure 6-11. Camera ISP CSI1/CCP2 RGB888**
**RGB888**

Line width must be a multiple of three 32-bit words.

**Transmitter**

**Receiver**


camisp-184

 For RGB565, the line length sent through the associated PHY is a multiple of 32 bits (see [Figure 6-12](#)).

**Figure 6-12. Camera ISP CSI1/CCP2 RGB565**

RGB565 Line width must be a multiple of one 32-bit word.



RGB444 data format is output to memory with data expansion. If data expansion is used, the value of the 4 upper bits is programmable and can be set with an alpha value for computer graphics applications. The line length sent through the associated PHY is a multiple of 32 bits (see [Figure 6-13](#)).

**Figure 6-13. Camera ISP CSI1/CCP2 RGB444**

RGB444 Line width must be a multiple of one 32-bit word.



#### **6.2.4.4.1.3 Camera ISP CSI1/CCP2 RAW Bayer RGB Pixel Data Formats**

#### 6.2.4.4.1.3.1 Camera ISP CSI1/CCP2 RAW6 (CCP2 Only)

RAW6 data format can be output to memory in two formats: with no data expansion and with data expansion.

The line length sent through the associated PHY is a multiple of 32 bits. Furthermore, the line is a multiple of  $3 \times 32$  bits to correctly finish pixel reconstruction (the lowest common multiple of 32 and 6 is 96; that is  $3 \times 32$  bits).

Figure 6-14 shows RAW6 format.

**NOTE:** The RAW6 data format do not apply to the MIPI CSI1 compatible mode.

**Figure 6-14. Camera ISP CSI1/CCP2 RAW 6**


#### 6.2.4.4.1.3.2 Camera ISP CSI1/CCP2 RAW7 (CCP2 Only)

RAW7 data format can be output to memory in two formats: with no data expansion and with data expansion.

The line length sent through the associated PHY is a multiple of 32 bits. Furthermore, the line length is a multiple of  $7 \times 32$  bits to correctly finish the pixel reconstruction (the lowest common multiple of 32 and 7 is 224; that is,  $7 \times 32$  bits).

Figure 6-15 shows RAW7 format.

---

**NOTE:** The RAW7 data format do not apply to the MIPI CSI1 compatible mode.

---

**Figure 6-15. Camera ISP CSI1/CCP2 RAW 7**

#### 6.2.4.4.1.3.3 Camera ISP CSI1/CCP2 RAW8

RAW8 data format can be output to memory in two formats: with no data expansion and with data expansion.

The line length sent through the associated PHY is a multiple of 32 bits.

Figure 6-16 shows RAW8 format.

---

**NOTE:**

- Use RAW8 data format to output RAW6 and RAW7 data formats to memory.
  - Use YUV422 + VP to output RAW8 data to the video port: YUV422 + VP is equivalent to RAW8 + VP.
-

**Figure 6-16. Camera ISP CSI1/CCP2 RAW8**



t0: VP\_DATA[9:0] = [a7 a6 a5 a4 a3 a2 a1 a0]  
t1: VP\_DATA[9:0] = [b7 b6 b5 b4 b3 b2 b1 b0]  
t2: VP\_DATA[9:0] = [c7 c6 c5 c4 c3 c2 c1 c0]  
t3: VP\_DATA[9:0] = [d7 d6 d5 d4 d3 d2 d1 d0]

RAW8 + VP

camisp-189

#### 6.2.4.4.1.3.4 Camera ISP CSI1/CCP2 RAW10

RAW10 data format can be output to memory in two formats: with no data expansion and with data expansion.

If data expansion is used, the 10-bit data are padded with 0s on a 16-bit word.

The line length sent through the associated PHY is a multiple of 32 bits. Furthermore, the line length is a multiple of 5 x 32 bits to correctly finish pixel reconstruction (the lowest common multiple of 32 and 10 is 320: 10 x 32 bits).

RAW10 data format can be sent to the video port.

[Figure 6-17](#) shows RAW10 format.

**Figure 6-17. Camera ISP CSI1/CCP2 RAW10**

RAW10 Line width must be a multiple of five 32-bit words.

Transmitter



Receiver



t0: VP\_DATA[9:0] = [a9 a8 a7 a6 a5 a4 a3 a2 a1 a0]  
t1: VP\_DATA[9:0] = [b9 b8 b7 b6 b5 b4 b3 b2 b1 b0]  
t2: VP\_DATA[9:0] = [c9 c8 c7 c6 c5 c4 c3 c2 c1 c0]  
t3: VP\_DATA[9:0] = [d9 d8 d7 d6 d5 d4 d3 d2 d1 d0]

RAW10 + VP

camisp-190

**6.2.4.4.1.3.5 Camera ISP CSI1/CCP2 RAW12**

RAW12 data format can be output to memory in two formats: with no data expansion and with data expansion.

If data expansion is used, the 12-bit data are padded with 0s on a 16-bit word.

The line length sent through the PHY is a multiple of 32 bits. Furthermore, the line length is a multiple of 3 x 32 bits to correctly finish pixel reconstruction (the lowest common multiple of 32 and 12 is 96: 3 x 32 bits).

RAW12 data format can be sent to the video port.

[Figure 6-18](#) shows RAW12 format.

---

**NOTE:** The video processing hardware is 10-bit only. Typically, the data lane shifter must be used to perform 10-bit-only processing.

---

**Figure 6-18. Camera ISP CSI1/CCP2 RAW12**

RAW12

Line width must be a multiple of three 32-bit words.

Transmitter



Receiver



t0: VP\_DATA[9:0] = [a9 a8 a7 a6 a5 a4 a3 a2 a1 a0]  
t1: VP\_DATA[9:0] = [b9 b8 b7 b6 b5 b4 b3 b2 b1 b0]  
t2: VP\_DATA[9:0] = [c9 c8 c7 c6 c5 c4 c3 c2 c1 c0]  
t3: VP\_DATA[9:0] = [d9 d8 d7 d6 d5 d4 d3 d2 d1 d0]

RAW12 + VP

camisp-191

#### 6.2.4.4.1.4 Camera ISP CSI1/CCP2 JPEG8 Pixel Data Formats

The line length sent through the associated PHY is a multiple of 32 bits. The false synchronization protection (FSP) code insertion on the transmitter side automatically ensures this line length. It is impossible to know in advance the size of a compressed stream. [Figure 6-19](#) shows JPEG8 and JPEG8 FSP format.

**Figure 6-19. Camera ISP CSI1/CCP2 JPEG8 and JPEG8 FSP**



In JPEG8 mode, the JPEG encoder on the sensor side must avoid generating data equal to the synchronization code and must deliver a synchronization-code-free bitstream.

In JPEG8 FSP mode, the bitstream is a standard JPEG8 bitstream in which byte-stuffing is used to differentiate synchronization code from original data with the same value. Thus, the JPEG encoder can generate a standard bitstream, and a postprocessing stage (FSP encoder) is used to highlight natural bitstream data equal to synchronization codes, so that the other end can discard the false synchronization codes.

FSP decoding is performed for byte-aligned data and occurs after the frame-start synchronization code is received. If the byte  $n = 0x0$ , the FSP decoder looks for bytes 1 and 2. If the bytes are equal to an illegal combination (synchronization codes), the byte  $0xA5$  that comes after (byte  $n + 1$ ) is removed from the bitstream.

The  $0xA5$  padding bytes at the end of the frame are also removed by FSP decoding so that padding does not generate additional data in the FIFO. FSP decoding is then transparent to the software.

Normally, the module detects the illegal combination and then the  $0xA5$ . When the  $0xA5$  is corrupted or replaced by another code, the value is automatically removed from the bitstream and an interrupt is generated to signal that the code is corrupt and therefore the received data are suspicious. If the line is too noisy for FSP decoding, it is better to configure the subsystem in JPEG8 and use software postprocessing.

#### 6.2.4.5 Camera ISP CSI2 Protocol and Data Format

---

**NOTE:** The two CSI2 receivers (CSI2A and CSI2C) support MIPI CSI2.

---

##### 6.2.4.5.1 Camera ISP CSI2 Lane Merger

The layer consists of lane merger logic to merge the incoming serial stream into a byte stream. The bits are sent with the LSB first. The order of the lanes at the CSI2 receiver core depends on the lane configuration.

The number of lanes and their configuration can be changed only in ULPM or when all data lanes are in off mode.

The lane merger can merge up to four lanes into a single byte stream.

In case of a single lane, the lane merger is not used to merge byte streams.

[Figure 6-20](#) and [Figure 6-21](#) show an example of byte position into each serial link for 1 and 2 data lane configurations. The byte stream always starts from lane 1. It finishes on one of the lanes, depending on the number of bytes to receive and the number of lanes.

**Figure 6-20. Camera ISP CSI2 Two Data-Lane Merger Configuration**

The number of bytes, N, is an integer multiple of the number of lanes (2).



The number of bytes, N, is not an integer multiple of the number of lanes (2).



**Key:**

ULPM: Ultra-low power mode

SoT: Start of transmission

EoT: End of transmission

camisp-239

**Figure 6-21. Camera ISP CSI2 One Data-Lane Configuration**



**Key:**

ULPM: Ultra-low power mode

SoT: Start of transmission

EoT: End of transmission

camisp-240

#### 6.2.4.5.2 Camera ISP CSI2 Protocol Layer

The low-level protocol (LLP) is a byte-oriented protocol from the lane merger layer. It supports short and long packet formats.

The CSI2 protocol layer defines how image-sensor data is transported onto the physical layer.

The feature set of the protocol layer implemented by the CSI2 receiver is:

- Transport of arbitrary data (payload-independent)
- 8-bit word size
- Support for up to four interleaved virtual channels on the same link
- Special packets for frame-start, frame-end, line-start, and line-end information
- Descriptor for the type, pixel depth, and format of application-specific payload data
- Error-correction code (ECC) for 1-bit error correction or 2-bit error detection in the header
- 16-bit checksum code for payload error detection

Figure 6-22 shows the CSI2 protocol layer with short and long packets.

**Figure 6-22. Camera ISP CSI2 Protocol Layer With Short and Long Packets**

Two packets are always separated from each other with a sequence of a ULPM, an ET, and an ST.

#### 6.2.4.5.2.1 Camera ISP CSI2 Short Packet

A short packet is identified by data types 0x00 to 0x0F. A short packet can be used for frame or line synchronization or for generic data. [Figure 6-23](#) shows the structure of a short packet.

**Figure 6-23. Camera ISP CSI2 Short Packet Structure**

For frame-synchronization data types, the short packet data field is the frame number. For line-synchronization data types, the short packet data field is the line number. For generic short packet data types, the content of the short packet data field is user-defined.

The 16-bit frame number, when used, is always nonzero to distinguish it from the use case where the frame number is inoperative and remains set to 0. The behavior of the 16-bit frame number is one of the following:

- The frame number is always 0. The frame number is inoperative.
- The frame number increments by 1 for every FS packet with the same virtual channel and is periodically reset to 1 (1, 2, 1, 2, 1, 2, 1, 2 or 1, 2, 3, 4, 1, 2, 3, 4).

For line-start code (LSC) and line-end code (LEC) synchronization packets, the short packet data field contains a 16-bit line number. This line number is the same for the LS and LE packets corresponding to a given line. Line numbers are logical line numbers and do not necessarily equal physical line numbers. The 16-bit line number, when used, is always nonzero to distinguish it from the case where the line number is inoperative and remains set to 0.

The behavior of the 16-bit line number is one of the following:

- The line number is always 0. The line number is inoperative.
- The line number increments by one for every LS packet within the same virtual channel and the same data type. The line number is periodically reset to 1 for the first LS packet after an FS packet. The intended usage is for progressive scan (non-interlaced) video data streams. The line number must be a nonzero value.
- The line number increments by the same arbitrary step value greater than one for every LS packet within the same virtual channel and the same data type. The line number is periodically reset to a nonzero arbitrary start value for the first LS packet after an FS packet. The arbitrary start value can be

different between successive frames. The intended usage is for interlaced video data streams.

The ECC byte allows single-bit errors to be corrected and 2-bit errors to be detected in the short packet.

Short packets apply to all contexts using the same virtual channel ID (there are up to eight contexts to support eight dedicated configurations of virtual channel ID and data types). The data type associated with the context is not used to distinguish which context is used when receiving short packets.

#### 6.2.4.5.2.2 Camera ISP CSI2 Long Packet

A long packet is identified by data types 0x10 to 0x37. A long packet consists of three elements: a 32-bit packet header (PH), an application-specific data payload with a variable number of 8-bit data words, and a 16-bit packet footer (PF). The packet header is further composed of three elements: an 8-bit data identifier, a 16-bit word count field, and an 8-bit ECC. The packet footer has one element, a 16-bit checksum. [Figure 6-24](#) and [Table 6-9](#) show the structure of a long packet.

**Figure 6-24. Camera ISP CSI2 Long Packet Structure**



camisp-243

**Table 6-9. Camera ISP CSI2 Long Packet Structure Description**

| Packet Part | Field Name | Size (Bit) | Description                                                                          |
|-------------|------------|------------|--------------------------------------------------------------------------------------|
| Header      | Data ID    | 8          | Contains the virtual channel identifier and the data-type information                |
|             | Word count | 16         | Number of data words in the packet data. A word is 8 bits.                           |
|             | ECC        | 8          | ECC for data ID and WC field. Allows 1-bit error recovery and 2-bit error detection. |
| Data        | Data       | WC * 8     | Application-specific payload (WC words of 8 bits)                                    |
| Footer      | Checksum   | 16         | 16-bit cyclic redundancy check (CRC) for packet data                                 |

There are no restrictions on packet data size, but each data format can impose additional restrictions on the length of the payload data (for example, a multiple of 4 bytes).

#### 6.2.4.5.2.3 Camera ISP CSI2 Data Identifier

The data identifier byte contains the virtual channel identifier (VC) value and the data-type (DT) value, as shown in [Figure 6-25](#). The VC is in the 2 MSBs of the data identifier byte. The DT value is in the 6 LSBs of the data identifier byte.

[Figure 6-25](#) shows the data identifier structure.

**Figure 6-25. Camera ISP CSI2 Data Identifier Structure**

camisp-244

### Virtual Channel

The CSI2 protocol layer transports virtual channels. Virtual channels are built up of frames. A frame can comprise embedded data and image-sensor data. Two contexts are used to send the two types of data separately. Each frame is identified by unique mandatory synchronization codes: frame start and frame end. The following synchronization codes are optional for the transmitter: line start and line end. A set of registers is associated with each context defined by the virtual channel ID and the data type. [Figure 6-26](#) shows a virtual channel.

**Figure 6-26. Camera ISP CSI2 Virtual Channel**

camisp-245

### Pixel Formats

Image-sensor data can have multiple data types. [Table 6-10](#) summarizes the pixel formats supported by the CSI2 receiver interface.

**Table 6-10. Camera ISP CSI2 Pixel Format Modes**

| Mode                 | Description         |
|----------------------|---------------------|
| YUV420 8-bit         | YUV4:2:0 image data |
| YUV420 8-bit + VP    | YUV4:2:0 image data |
| YUV420 10-bit        | YUV4:2:0 image data |
| YUV420 8-bit legacy  | YUV4:2:0 image data |
| YUV420 8-bit + CSPS  | YUV4:2:0 image data |
| YUV420 10-bit + CSPS | YUV4:2:0 image data |
| YUV422 8-bit         | YUV4:2:2 image data |
| YUV422 10-bit        | YUV4:2:2 image data |
| RGB565               | RGB565 image data   |
| RGB888               | RGB888 image data   |
| RGB888 + EXP32       | RGB888 image data   |
| RGB666 + EXP32_24    | RGB666 image data   |

**Table 6-10. Camera ISP CSI2 Pixel Format Modes (continued)**

| Mode                  | Description                  |
|-----------------------|------------------------------|
| RGB666 + EXP32        | RGB666 image data            |
| RGB444 + EXP16        | RGB444 image data            |
| RGB555 + EXP16        | RGB555 image data            |
| RAW6 + EXP8           | RAW Bayer, 6-bit image data  |
| RAW6 + DPCM10 + EXP16 | RAW Bayer, 6-bit image data  |
| RAW6 + DPCM10 + VP    | RAW Bayer, 6-bit image data  |
| RAW7 + EXP8           | RAW Bayer, 7-bit image data  |
| RAW7 + DPCM10 + EXP16 | RAW Bayer, 7-bit image data  |
| RAW7 + DPCM10 + VP    | RAW Bayer, 7-bit image data  |
| RAW8                  | RAW Bayer, 8-bit image data  |
| RAW8 + VP             | RAW Bayer, 8-bit image data  |
| RAW8 + DPCM10 + EXP16 | RAW Bayer, 8-bit image data  |
| RAW8 + DPCM10 + VP    | RAW Bayer, 8-bit image data  |
| RAW10                 | RAW Bayer, 10-bit image data |
| RAW10 + EXP16         | RAW Bayer, 10-bit image data |
| RAW10 + VP            | RAW Bayer, 10-bit image data |
| RAW12                 | RAW Bayer, 12-bit image data |
| RAW12 + EXP16         | RAW Bayer, 12-bit image data |
| RAW12 + VP            | RAW Bayer, 12-bit image data |
| RAW14                 | RAW Bayer, 14-bit image data |
| RAW14 + EXP16         | RAW Bayer, 14-bit image data |
| RAW14 + VP            | RAW Bayer, 14-bit image data |
| JPEG, 8-bit data      | JPEG8                        |

For more information on how the data formats are transmitted and how the data are stored in memory, see [Section 6.2.4.5.3, Camera ISP CSI2 Pixel Data Format](#).

#### 6.2.4.5.2.4 Camera ISP CSI2 Synchronization Codes

Data reception from the image-sensor module uses four synchronization codes embedded in the serial bit-stream:

- FSC: Identifies the start of a new frame
- LSC: Identifies the start of a new line; received for every line
- LEC: Identifies the end of a line; received for every line
- FEC: Identifies the end of the current frame

[Table 6-11](#) summarizes the synchronization code values.

**Table 6-11. Camera ISP CSI2 Synchronization Codes**

| Synchronization Code | Value      | Comments  |
|----------------------|------------|-----------|
| FSC                  | 0x0        | Mandatory |
| FEC                  | 0x1        | Mandatory |
| LSC                  | 0x2        | Optional  |
| LEC                  | 0x3        | Optional  |
| Reserved             | 0x4 to 0x7 | Not used  |

#### **6.2.4.5.2.5 Camera ISP CSI2 Generic Short Packet Codes**

When the synchronization code value is between 0x8 and 0xF, the short packet is called a generic short packet. Short packets are not processed by the camera interface hardware. A generic short packet is stored in a register without the ECC and an interrupt can be generated. Therefore, generic short packets must be handled by software.

#### **6.2.4.5.2.6 Camera ISP CSI2 Generic Long Packet Codes**

The code value 0x10 indicates null packets, which can be received at any time. They are discarded by the protocol engine.

The code value 0x11 indicates blanking packets, which can be received at any time. They are discarded by the protocol engine.

The code value 0x12 indicates embedded 8-bit non-image data typically used for JPEG.

Code values from 0x13 to 0x17 are reserved.

#### **6.2.4.5.2.7 Camera ISP CSI2 Frame Structure**

Each frame consists of short packets to indicate start of frame and end of frame. Optional short packets for start of line and end of line can be sent by the image sensor.

Some information before and after the picture data can be sent as start-of-frame (SOF) and end-of-frame (EOF) information by the image sensor to the memory through the L3 port.

For each frame, the pixel data (arbitrary data or user-defined byte data) are valid only after an SOF short packet. If the data are invalid, they are discarded by the protocol engine.

A frame comprises embedded data and image-sensor data. [Figure 6-27](#) shows where the embedded data and image sensor data are in the frame. The following definitions apply:

- Zero or more SOF status lines (SOF lines) can be embedded at the beginning of a CSI2 frame.
- The image data comprises pixels of the same or different data formats.
- Zero or more EOF status lines (EOF lines) can be embedded at the end of a CSI2 frame.
- The SOF lines, pixel data, and EOF lines do not overlap.

The CSI2 receiver does not use the information in the status lines. However, it extracts it and stores it in memory for software use.

Because the data types are different, the CSI2 receiver uses a different context for embedded data and image-sensor data.

Embedded data is supported as a context by the CSI2 receiver; therefore, there is no specific hardware support for embedded data.

**Figure 6-27. Camera ISP CSI2 General Frame Structure (Informative)**



**Key:**

PH: Packet header  
FS: Frame start

PF: Packet footer  
FE: Frame end

camisp-246

Figure 6-28 shows the frame structure of a YUV422 interlaced video frame without embedded data.

**Figure 6-28. Camera ISP CSI2 Digital Interlaced Video Frame (Informative)****Key:**

PH: Packet header  
 FS: Frame start  
 LS: Line start

PF: Packet footer  
 FE: Frame end  
 LE: Line end

camisp-247

The period between the LEC and the new LSC is the line blanking period. The time between the FEC and the new FSC is the frame blanking period. The receiver works with the line blanking period set to 0.

**6.2.4.5.3 Camera ISP CSI2 Pixel Data Format****6.2.4.5.3.1 Camera ISP CSI2 YUV Pixel Data Format****6.2.4.5.3.1.1 Camera ISP CSI2 YUV420 8-Bit**

YUV420 8-bit data can be stored to memory in little-endian format. The line length sent through the CSI2 physical protocol is a multiple of 16 bits for odd lines and 32 bits for even lines.

For correct pixel reconstruction, the line length must be a multiple of 3\*32 bits and the number of lines must be even. [Figure 6-29](#) shows the storage format for YUV420 8-bit data.

**Figure 6-29. Camera ISP CSI2 YUV420 8-Bit**

YUV420 8-bit

Transmitter (odd line)



Receiver (odd line)


 FIFO data  
memory  
organization

Transmitter (even line)



Receiver (even line)


 FIFO data  
memory  
organization

t0: VP\_DATA = [0 0 0 0 0 a7 a6 a5 a4 a3 a2 a1 a0]  
 t1: VP\_DATA = [0 0 0 0 0 b7 b6 b5 b4 b3 b2 b1 b0]  
 t2: VP\_DATA = [0 0 0 0 0 c7 c6 c5 c4 c3 c2 c1 c0]  
 t3: VP\_DATA = [0 0 0 0 0 d7 d6 d5 d4 d3 d2 d1 d0]

camisp-210

#### **6.2.4.5.3.1.2 Camera ISP CSI2 YUV420 10-Bit**

YUV420 10-bit data can be stored to memory in little-endian format. The line length sent through the CSI physical protocol is a multiple of 40 bits for odd lines and 80 bits for even lines. [Figure 6-30](#) shows the storage format for YUV420 10-bit data.

**Figure 6-30. Camera ISP CSI2 YUV420 10-Bit**

YUV420 10-bit

Transmitter (odd line)



Receiver (odd line)



Transmitter (even line)



Receiver (odd line)



#### 6.2.4.5.3.1.3 Camera ISP CSI2 YUV420 8-Bit Legacy

YUV420 8-bit legacy data can be stored to memory in big-endian format. The line length sent through the CSI2 physical protocol is a multiple of 4 bytes. Figure 6-31 shows the storage format for YUV420 8-bit legacy data.

**Figure 6-31. Camera ISP CSI2 YUV420 8-Bit Legacy**

YUV420 8-bit legacy

Transmitter (odd line)



Receiver (odd line)



Transmitter (even line)



Receiver (even line)



camisp-212

#### 6.2.4.5.3.1.4 Camera ISP CSI2 YUV420 8-Bit + CSPS

YUV420 8-bit CSPS data can be stored to memory in little-endian format. The line length sent through the CSI2 physical protocol is a multiple of 16 bits for odd lines and 32 bits for even lines.

For correct pixel reconstruction, the line length must be a multiple of 3\*32 bits and the number of lines must be even. [Figure 6-32](#) shows the storage format for YUV420 8-bit + CSPS data.

**Figure 6-32. Camera ISP CSI2 YUV420 8-Bit + CSPS**

YUV420 8-bit + CSPS

Transmitter (odd line)



Receiver (odd line)



Transmitter (even line)



Receiver (even line)



camisp-213

#### 6.2.4.5.3.1.5 Camera ISP CSI2 YUV420 10-Bit + CSPS

YUV420 10-bit CSPS data can be stored to memory in little-endian format. The line length sent through the CSI2 physical protocol is a multiple of 40 bits for odd lines and 80 bits for even lines.

For correct pixel reconstruction, the line length must be a multiple of 3\*32 bits and the number of lines must be even. [Figure 6-33](#) shows the storage format for YUV420 10-bit + CSPS data.

**Figure 6-33. Camera ISP CSI2 YUV420 10-Bit + CSPS**

## YUV420 10-bit + CSPS



#### **6.2.4.5.3.1.6 Camera ISP CSI2 YUV422 8-Bit**

YUV422 data can be stored to memory in big-endian format. The line length sent through the CSI2 physical protocol is a multiple of 32 bits. Figure 6-34 shows the storage format for YUV422 8-bit data.

**Figure 6-34. Camera ISP CSI2 YUV422 8-Bit**

YUV422 8-bit

Transmitter



Receiver

FIFO data  
memory  
organization

camisp-215

**6.2.4.5.3.1.7 Camera ISP CSI2 YUV422 10-Bit**

YUV422 data can be stored to memory in little-endian format. The line length sent through the CSI2 physical protocol is a multiple of 40 bits. [Figure 6-35](#) shows the storage format for YUV422 10-bit data.

**Figure 6-35. Camera ISP CSI2 YUV422 10-Bit**

YUV422 10-bit

Transmitter

FIFO data  
memory  
organization

camisp-216

Receiver



### **6.2.4.5.3.2 Camera ISP CSI2 RGB Operating Modes**

#### **6.2.4.5.3.2.1 Camera ISP CSI2 RGB565**

RGB565 data is output to memory without data expansion. The line length sent through the CSI2 physical layer is always a multiple of 16 bits. [Figure 6-36](#) shows the storage format for RGB565 data.

**Figure 6-36. Camera ISP CSI2 RGB565**



#### **6.2.4.5.3.2.2 Camera ISP CSI2 RGB888**

RGB888 data can be output to memory in two formats: with or without data expansion. If data expansion is used, the value of the 8 upper bits is programmable and can be set with an alpha value for computer graphics applications (the [CSI2\\_CTx\\_CTRL3 \[29:16\] ALPHA](#) bit field). [Figure 6-37](#) shows the storage format for RGB888 data.

**Figure 6-37. Camera ISP CSI2 RGB888****RGB888**

Transmitter



Receiver



FIFO  
data memory  
organization  
without data  
expansion

Receiver



FIFO  
data memory  
organization  
with 32-bit data  
expansion

camisp-218

**6.2.4.5.3.2.3 Camera ISP CSI2 RGB666**

RGB666 data is always output to memory with data expansion. The value of the 14 upper bits is programmable and can be set with an alpha value for computer graphics applications (the [CSI2\\_CTx\\_CTRL3 \[29:16\] ALPHA](#) bit field). The line length sent through the CSI2 physical protocol is a multiple of 8 bits. Furthermore, the line length is a multiple of 9x8 bits to correctly finish the pixel reconstruction. [Figure 6-38](#) shows the storage format for RGB666 data.

**Figure 6-38. Camera ISP CSI2 RGB666**
**RGB666**
**Transmitter**

**Receiver**

**Receiver**


camisp-219

#### **6.2.4.5.3.2.4 Camera ISP CSI2 RGB444**

RGB444 data is output to memory with data expansion. When data expansion is used, the value of the 4 upper bits is programmable and can be set with an alpha value for computer graphics applications (the `CSI2_CTx_CTRL3[29:16]` ALPHA bit field). [Figure 6-39](#) shows the storage format for RGB444 data.

**Figure 6-39. Camera ISP CSI2 RGB444**

RGB444

Transmitter



Receiver



FIFO  
data memory  
organization  
with 16-bit data  
expansion

camisp-220

#### 6.2.4.5.3.2.5 Camera ISP CSI2 RGB555

RGB555 data is output to memory with data expansion. [Figure 6-40](#) shows the storage format for RGB555 data.

**Figure 6-40. Camera ISP CSI2 RGB555**

RGB555

Transmitter



Receiver



FIFO  
data memory  
organization  
with 16-bit data  
expansion

camisp-221

#### 6.2.4.5.3.3 Camera ISP CSI2 RAW Bayer RGB Operating Modes

##### 6.2.4.5.3.3.1 Camera ISP CSI2 RAW6

RAW6 data can be output only with data expansion. The line length sent through the CSI2 physical layer is a multiple of 8 bits. Furthermore, the line length is a multiple of 3x8 bits to correctly complete the pixel reconstruction (the lowest common multiple of 8 and 6 is 24, so 3x8 bits). [Figure 6-41](#) shows the storage format for RAW6 data.

**Figure 6-41. Camera ISP CSI2 RAW6**

RAW6

Transmitter



Receiver



Receiver



Receiver



t0: VP\_DATA = [0 0 0 0 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0]  
 t1: VP\_DATA = [0 0 0 0 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0]  
 t2: VP\_DATA = [0 0 0 0 c9 c8 c7 c6 c5 c4 c3 c2 c1 c0]  
 t3: VP\_DATA = [0 0 0 0 d9 d8 d7 d6 d5 d4 d3 d2 d1 d0]

$\text{CSI2\_CTX\_CTRL2 [9:0]}$   
 $\text{FORMAT}$   
 $=$   
 $\text{RAW6 + DPCM10 + VP}$

camisp-272

#### 6.2.4.5.3.3.2 Camera ISP CSI2 RAW7

RAW7 data can be output only with data expansion. The line length sent through the CSI2 physical layer is a multiple of 8 bits. Furthermore, the line length is a multiple of 7x8 bits to correctly complete the pixel reconstruction (the lowest common multiple of 8 and 7 is 56, so 7x8 bits). [Figure 6-42](#) shows the storage format for RAW7 data.

**Figure 6-42. Camera ISP CSI2 RAW7**

RAW7

Transmitter



Receiver



Receiver



Receiver



t0: VP\_DATA = [0 0 0 0 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0]  
 t1: VP\_DATA = [0 0 0 0 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0]  
 t2: VP\_DATA = [0 0 0 0 c9 c8 c7 c6 c5 c4 c3 c2 c1 c0]  
 t3: VP\_DATA = [0 0 0 0 d9 d8 d7 d6 d5 d4 d3 d2 d1 d0]

CSI2\_CTX\_CTRL2[9:0]  
FORMAT  
= RAW7 + DPCM10 + VP

camisp-273

#### 6.2.4.5.3.3.3 Camera ISP CSI2 RAW8

RAW8 data can be output only without data expansion. The line length sent through the CSI2 physical layer is always a multiple of 8 bits. [Figure 6-43](#) shows the storage format for RAW8 data.

**Figure 6-43. Camera ISP CSI2 RAW8**

RAW8

Transmitter



Receiver



Receiver



t0: VP\_DATA = [0 0 0 0 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0]  
 t1: VP\_DATA = [0 0 0 0 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0]  
 t2: VP\_DATA = [0 0 0 0 c9 c8 c7 c6 c5 c4 c3 c2 c1 c0]  
 t3: VP\_DATA = [0 0 0 0 d9 d8 d7 d6 d5 d4 d3 d2 d1 d0]

CSI2\_CTX\_CTRL2 [9:0]  
 FORMAT  
 =  
 RAW8 + DPCM10 + VP

t0: VP\_DATA = [0 0 0 0 0 a7 a6 a5 a4 a3 a2 a1 a0]  
 t1: VP\_DATA = [0 0 0 0 0 b7 b6 b5 b4 b3 b2 b1 b0]  
 t2: VP\_DATA = [0 0 0 0 0 c7 c6 c5 c4 c3 c2 c1 c0]  
 t3: VP\_DATA = [0 0 0 0 0 d7 d6 d5 d4 d3 d2 d1 d0]

CSI2\_CTX\_CTRL2 [9:0]  
 FORMAT  
 =  
 RAW8 + VP

camisp-274

#### 6.2.4.5.3.3.4 Camera ISP CSI2 RAW10

RAW10 data can be output memory in two formats: with or without data expansion. It can be sent to video port too. If data expansion is used, the 10-bit data are padded with 0s on a 16-bit word. The line length sent through the CSI2 physical layer is a multiple of 8 bits. Furthermore, the line length is a multiple of 5x8 bits to correctly complete the pixel reconstruction (the lowest common multiple of 8 and 10 is 40, so 5x8 bits). [Figure 6-44](#) shows the storage format for RAW10 data.

**Figure 6-44. Camera ISP CSI2 RAW10**

RAW10

Transmitter



Receiver



Receiver



t0: VP\_DATA = [0 0 0 0 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0]  
t1: VP\_DATA = [0 0 0 0 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0]  
t2: VP\_DATA = [0 0 0 0 c9 c8 c7 c6 c5 c4 c3 c2 c1 c0]  
t3: VP\_DATA = [0 0 0 0 d9 d8 d7 d6 d5 d4 d3 d2 d1 d0]

camisp-225

#### 6.2.4.5.3.3.5 Camera ISP CSI2 RAW12

RAW12 data can be output to memory in two formats: with or without data expansion. It can be sent to video port too. If data expansion is used, the 12-bit data are padded with 0s on a 16-bit word. The line length sent through the CSI2 physical layer is a multiple of 8 bits. Furthermore, the line length is a multiple of 3x8 bits to correctly complete the pixel reconstruction (the lowest common multiple of 8 and 12 is 24, so 3x8 bits). [Figure 6-45](#) shows the storage format for RAW12 data.

**Figure 6-45. Camera ISP CSI2 RAW12**

RAW12

Transmitter



Receiver



Receiver



t0: VP\_DATA = [0 0 a11 a10 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0]  
 t1: VP\_DATA = [0 0 b11 b10 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0]  
 t2: VP\_DATA = [0 0 c11 c10 c9 c8 c7 c6 c5 c4 c3 c2 c1 c0]  
 t3: VP\_DATA = [0 0 d11 d10 d9 d8 d7 d6 d5 d4 d3 d2 d1 d0]

camisp-226

#### 6.2.4.5.3.3.6 Camera ISP CSI2 RAW14

RAW14 data can be output to memory in two formats: with or without data expansion. It can be sent to video port too. If data expansion is used, the 14-bit data are padded with 0s on a 16-bit word. The line length sent through the CSI2 physical layer is a multiple of 8 bits. Furthermore, the line length is a multiple of 7x8 bits to correctly complete the pixel reconstruction (the lowest common multiple of 8 and 14 is 56, so 7x8 bits). [Figure 6-46](#) shows the storage format for RAW14 data.

**Figure 6-46. Camera ISP CSI2 RAW14**

RAW14

## Transmitter



## Receiver



## Receiver



t0: VP\_DATA = [a13 a12 a11 a10 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0]  
t1: VP\_DATA = [b13 b12 b11 b10 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0]  
t2: VP\_DATA = [c13 c12 c11 c10 c9 c8 c7 c6 c5 c4 c3 c2 c1 c0]  
t3: VP\_DATA = [d13 d12 d11 d10 d9 d8 d7 d6 d5 d4 d3 d2 d1 d0]

camisp-227

**6.2.4.5.3.4 Camera ISP CSI2 JPEG8 Operating Modes**

The size of a compressed stream can be known in advance. [Figure 6-47](#) shows the format for storing JPEG8 data.

**Figure 6-47. Camera ISP CSI2 JPEG8**

JPEG8 (Embedded 8-bit non-image data)

Transmitter



Receiver



#### 6.2.4.5.3.5 Camera ISP CSI2 Generic Format

The CSI2 receiver supports a generic format to send data to memory and/or the video port. The generic mode is entered by setting the [CSI2\\_CTX\\_CTRL1\[30\]](#) GENERIC bit. The [CSI2\\_CTX\\_CTRL2\[9:0\]](#) FORMAT register defines how the data stream is decoded. When generic mode is enabled (GENERIC = 1), MIPI data type code is ignored and data is decoded using the FORMAT bit. Whatever the MIPI data type code, it is ignored (the data stream is processed even if the FORMAT bit does not match the MIPI data type code). When generic mode is not used (GENERIC = 0), the data stream is processed only when the MIPI data type code matches the FORMAT setting of the enabled context. If it does not match, the data stream is not processed by the CSI2 engine. Only the virtual channel information is used to map a received data stream to a context. Software must ensure that a MIPI virtual channel used in generic mode is only mapped to a single context.

**Figure 6-48. Camera ISP CSI2 Generic**

ISS CSI2 Generic: [CSI2\\_CTX\\_CTRL1\\_i\[30\]](#) GENERIC = 0x1

Transmitter



Receiver when, for example, [CSI2\\_CTX\\_CTRL2\[9:0\]](#) FORMAT = RAW8



#### 6.2.4.5.3.6 Camera ISP CSI2 Byte-Swap

The CSI2 receiver incorporates a byte-swap function. Software can optionally enable byte-swapping of the payload data by setting the [CSI2\\_CTX\\_CTRL1\[31\]](#) BYTESWAP bit. This feature must only be used when the amount of payload data per packet is a multiple of 16 bits. The byte-swapping is performed before pixel reconstruction.

**Figure 6-49. Camera ISP CSI2 Byte-Swap**

ISS CSI2 byte-swap

For example, CSI2\_CTx\_CTRL2[9:0] FORMAT = RAW8

Transmitter



Receiver when CSI2\_CTx\_CTRL1[31] BYTESWAP = 0x0



Receiver when CSI2\_CTx\_CTRL1[31] BYTESWAP = 0x1



camss-228c

## 6.3 Camera ISP Integration

[Figure 6-50](#) shows the Camera ISP integration.

**Figure 6-50. Camera ISP Integration**



### 6.3.1 Camera ISP Clocking, Reset, and Power-Management Scheme

#### 6.3.1.1 Camera ISP Clocks

There are six clock domains in the camera ISP:

- Functional clock domain, this clock is from L3 interconnect along with Interface master write port clock. It is required to be 2x faster than the pixel clock.
- CSI1/CCP2B Serial interface clock domain. Only the parallel mode between the PHYs and the ISP is used.

- CSI2 serial interface clock domain
- CSI2 byte clock domain, whose frequency depends on the image sensor type and size, its frame rate and its blanking period. The clock is generated from the bit-clock from the sensor and converted into byte clock.
- Parallel interface clock domain. This frequency depends on the imaging sensor type and size, its frame rate and its blanking time. The functional clock is required to be at least 2x faster than the pixel clock when the bridge is disabled and a least equal when it is enabled.
- Slave interface clock domain, from L4 interconnect

### 6.3.1.1.1 Camera ISP Clock Tree

Figure 6-51 shows the clock tree for the camera ISP module.

**Figure 6-51. Camera ISP Clock Tree Diagram**



### 6.3.1.1.2 Camera ISP Clock Descriptions

Table 6-12 describes the camera ISP clocks.

**Table 6-12. Camera ISP Clock Descriptions**

| Signal Name             | IO     | Description                                                                                                                                                                                                                                                                                          |
|-------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CAM_FCLK                | Input  | Functional clock (L3 interconnect clock domain)                                                                                                                                                                                                                                                      |
| CAM_ICLK                | Input  | Interface clock (L4 interconnect clock domain)                                                                                                                                                                                                                                                       |
| CAM_MCLK <sup>(1)</sup> | Input  | Internal clock from PRCM at 216 MHz. The CAM_MCLK is used by the clock generator to generate cam_xclka and cam_xclkb. It is also used by the control Signal generator to generate cam_shutter, cam_strobe, and cam_global_reset. For more information, see Section 6.4.4, Camera ISP Timing Control. |
| cam_xclka               | Output | External clock for the image-sensor module. For serial or parallel sensor.                                                                                                                                                                                                                           |

<sup>(1)</sup> The CAM\_MCLK frequency can be less than, or equal to 216 MHz.

**Table 6-12. Camera ISP Clock Descriptions (continued)**

| Signal Name   | IO     | Description                                                                                                                                                                                       |
|---------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| cam_xclk      | Output | External clock for the image-sensor module. For serial or parallel sensor.                                                                                                                        |
| cam_pclk      | Input  | Parallel mode: pixel clock for parallel input data. The data on the parallel interface are presented on cam_d, one pixel for every cam_pclk rising or falling edge. Parallel sensor clock domain. |
| CSI2_96M_FCLK | Input  | CSI2 functional clock driven by PRCM.CM_FCLKEN_CAM[1] EN_CSI2.                                                                                                                                    |

#### 6.3.1.1.3 Camera ISP Clock Configuration

- CSI2\_96M\_FCLK is the CSI2 functional clock running at 96 MHz and enabled when PRCM.CM\_FCLKEN\_CAM[1] EN\_CSI2 = 1
- CAM\_FCLK control and settings

The CAM\_FCLK clock runs at the device L3 clock frequency.

The CAM\_FCLK source is the PRCM CAM\_L3\_ICLK output.

When the camera ISP no longer needs CAM\_FCLK, the software can disable it at PRCM level by setting the PRCM.CM\_ICLKEN\_CAM [0] EN\_CAM bit to 0x0. The clock is not effectively shut down until the camera ISP module has reached the IDLE state (that is, it does not generate anymore traffic on the device interconnect and is internally idled). For information, note that an automatic HW handshake protocol takes place between the camera ISP and the PRCM to prevent CAM\_FCLK from being cut while the module is processing or transferring data.

An autoidle mode can be activated for this clock (PRCM.CM\_AUTOIDLE\_CAM [0] AUTO\_CAM bit set to 1). This allows global management of the CAM\_FCLK clock along with the CAM power domain at PRCM level. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

- CAM\_ICLK control and settings:

CAM\_ICLK is the interface clock. It runs at device L4 interconnect clock speed and triggers access to the camera ISP L4 interface. Its source is the PRCM CAM\_L4\_ICLK output.

When the camera ISP no longer needs CAM\_ICLK, the software can disable it at PRCM level by setting to 0x0 the PRCM.CM\_ICLKEN\_CAM [0] EN\_CAM bit. The clock is not effectively shut down until the camera ISP module has reached the IDLE state (that is, It does not generate anymore traffic on the device interconnect and is internally idled). As information, note an automatic HW handshake protocol takes place between the camera ISP and the PRCM to prevent CAM\_ICLK from being cut while the module is processing or transferring data.

An autoidle mode can be activated for this clock (PRCM.CM\_AUTOIDLE\_CAM [0] AUTO\_CAM bit set to 1). This allows global management of the CAM\_ICLK clock along with the CAM power domain at PRCM level. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

- CAM\_MCLK control and settings:

The source for CAM\_MCLK is the PRCM CAM\_MCLK output. It is generated through a peripheral DPLL and its frequency can be adjusted using the PRCM.CM\_CLKSEL\_CAM[4:0] CLKSEL\_CAM bit field.

When the module no longer needs it, it can be disabled at PRCM level by setting the PRCM.CM\_FCLKEN\_CAM[0] EN\_CAM bit to 0x0. The PRCM register bit setting has a direct effect on the clock; in other terms, there is no HW handshake protocol to ensure whether the clock can be cut regarding the camera ISP activity: as soon as the bit is set to 0x0, CAM\_MCLK is shut down.

- cam\_xclka and cam\_xclk control and settings:

cam\_xclka and cam\_xclk are generated inside the camera ISP module from CAM\_MCLK clock input. [Table 6-13](#) and [Table 6-14](#) give the settings of the related bit fields.

**Table 6-13. Camera ISP cam\_xclka Configuration**

| ref_clk  | CAM.TCTRL_CTRL[4:0] DIVA field | cam_xclka                            |
|----------|--------------------------------|--------------------------------------|
| CAM_MCLK | 0x0                            | Stable low level. Divider disabled.  |
|          | 0x1                            | Stable high level. Divider disabled. |

**Table 6-13. Camera ISP cam\_xclka Configuration (continued)**

| ref_clk | CAM.TCTRL_CTRL[4:0] DIVA field | cam_xclka  |
|---------|--------------------------------|------------|
|         | 0x2                            | CAM_MCLK/2 |
|         | ...                            | ...        |
|         | 0x1F                           | CAM_MCLK   |

**Table 6-14. Camera ISP cam\_xclkb Configuration**

| ref_clk  | CAM.TCTRL_CTRL[9:5] DIVB field | cam_xclkb                            |
|----------|--------------------------------|--------------------------------------|
| CAM_MCLK | 0x0                            | Stable low level. Divider disabled.  |
|          | 0x1                            | Stable high level. Divider disabled. |
|          | 0x2                            | CAM_MCLK/2                           |
|          | ...                            | ...                                  |
|          | 0x1F                           | CAM_MCLK                             |

### 6.3.1.2 Camera ISP Power Management

Power consumption can be reduced at two different levels:

- A local power-management optimization
- A system power management

#### 6.3.1.2.1 Camera ISP Local Power Management

To optimize power consumption, a local autoidle feature is implemented on the CAM\_ICLK interface clock at camera ISP module level. By enabling this autoidle feature, CAM\_ICLK is automatically gated at the module boundary as soon as it is not required and restarted without any latency when needed again. This allows power saving when the module is not involved in any transfer from/to the device interconnect. This autoidle feature is enabled by setting:

- **ISP\_SYSCONFIG** [0] AUTO\_IDLE bit to 1
- **CCP2\_SYSCONFIG** [0] AUTO\_IDLE bit to 1
- **CSI2\_SYSCONFIG** [0] AUTO\_IDLE bit to 1
- **MMU.MMU\_SYSCONFIG** [0] AUTOIDLE bit to 1
- **ISP\_CTRL** [21] SBL\_AUTOIDLE bit to 1

The decision to gate the interconnect clock is based on interface activity, regardless of hardware handshake protocols.

After a reset, this mode is enabled, by default.

---

**NOTE:** It is recommended that this mode be enabled to reduce power consumption.

---

#### 6.3.1.2.2 Camera ISP System Power Management

As part of the system power management scheme, the camera ISP module interacts with the PRCM through an automatic standby hardware protocol that allows dynamic power savings at CAMERA power domain level.

Being an initiator on the L3 interconnect, the camera ISP module alerts the PRCM as soon as it is ready to switch to a lower power state. Prior to any power state change to the CAMERA power domain, the PRCM first shuts off the camera clocks, depending on the camera ISP behavior and the clock settings at PRCM level. Namely, as soon as the camera ISP is ready to go to STANDBY, it asserts an automatic HW STANDBY request to the PRCM, which shuts down the clocks if they have been previously disabled by software and then potentially change the CAMERA power domain state. Refer to [Chapter 3, Power, Reset, and Clock Management](#), for further details.

When it goes to standby, the camera ISP module alerts the PRCM differently, depending on the [ISP\\_SYSConfig \[13:12\] MIDLE\\_MODE](#) bit field settings. The entry conditions for the camera ISP to go into standby mode are:

- The module has finished any current transaction and does not generate any more traffic on the interconnect.
- The module is idle (on-going transactions are finished).

The MIDLE\_MODE bit field allows the following settings for the camera ISP module:

- Force standby

The camera ISP is set to force standby when MIDLE\_MODE is set to 0x0. In this mode, the camera ISP module asserts its HW standby request to the PRCM as soon as it is disabled. Namely, the camera ISP is disabled when the following bit fields are set to 0x0:

- [ISP\\_CTRL \[13\] RSZ\\_CLK\\_EN](#)
- [ISP\\_CTRL \[12\] PRV\\_CLK\\_EN](#)
- [ISP\\_CTRL \[11\] HIST\\_CLK\\_EN](#)
- [ISP\\_CTRL \[10\] H3A\\_CLK\\_EN](#)
- [ISP\\_CTRL \[8\] CCDC\\_CLK\\_EN](#)

Moreover, CSI2A and CSI2C receivers must also be disabled by setting the related [CSI2\\_CTRL\[0\] IF\\_EN](#) bits to 0x0 and CSI1/CCP2B must also be disabled by setting the related [CCP2\\_CTRL \[0\] IF\\_EN](#) bits to 0x0.

- No standby

The camera ISP is set to no standby when MIDLE\_MODE is set to 0x1. In this mode, the camera ISP module never asserts its standby request to the PRCM. This also prevents the CAMERA power domain from going to a lower power state. Refer to [Chapter 3, Power, Reset, and Clock Management](#), for further details.

- Smart standby

The camera ISP module is set to smart standby when MIDLE\_MODE is set to 0x2. In this mode, the camera ISP module asserts its HW standby request to the PRCM according with its internal activity (namely, when there is no more activity on the camera ISP master interface, that is, when there is no more data in the central resource buffer).

---

**NOTE:** The CSI1/CCP2B receiver must also be configured to smart standby mode when the camera ISP is set to smart standby ([CCP2\\_SYSConfig \[13:12\] MSTANDBY\\_MODE](#) set to 0x2).

CSI2A and CSI2C receivers must also be configured to smart standby mode when the camera ISP is set to smart standby ([CSI2\\_SYSConfig\[13:12\] MSTANDBY\\_MODE](#) set to 0x2).

---

A standby request asserted to the PRCM does not necessarily lead to CAM\_FCLK and CAM\_ICLK being cut. The PRCM must also be set correctly for that purpose.

The clocks are cut, allowing a CAMERA power state change if:

- PRCM.CM\_ICLKEN\_CAM[0] EN\_CAM = 0 and PRCM.CM\_FCLKEN\_CAM[0] EN\_CAM = 0
- PRCM.CM\_FCLKEN\_CAM[0] EN\_CAM = 0, (PRCM.CM\_ICLKEN\_CAM[0] EN\_CAM =1, PRCM.CM\_AUTOIDLE\_CAM[0] = 1, and a domain transition is required at PRCM level)

See [Chapter 3, Power, Reset, and Clock Management](#), for further details.

### 6.3.1.3 Camera ISP Power Domain

The camera ISP belongs to the CAMERA power domain. For more information about the CAMERA power domain, see [Chapter 3, Power, Reset, and Clock Management](#).

### 6.3.1.4 Camera ISP Resets

#### 6.3.1.4.1 Camera ISP Hardware Reset

Global reset of the camera ISP module is accomplished by activation of the CAM\_RST signal in the CAMERA domain (for more information, see [Chapter 3, Power, Reset, and Clock Management](#)).

#### 6.3.1.4.2 Camera ISP Software Reset

A global software reset can be accomplished by setting the camera ISP [ISP\\_SYSCONFIG \[1\]](#) SOFT\_RESET bit to 1. Setting this bit enables active software reset functionality equivalent to hardware reset for the entire module, including CSI1/CCP2B,CSI2A, and CSI2C receivers.

---

**NOTE:** The CSI1/CCP2B receiver accepts a general software reset, propagated through the hierarchy. This reset can be performed to initialize the module and has the same effect as a hardware reset.

The CSI1/CCP2B receiver can be reset by writing [CCP2\\_SYSCONFIG \[1\]](#) SOFT\_RESET bit to 1. The software can monitor the [CCP2\\_SYSSTATUS \[0\]](#) RESET\_DONE status bit to wait for the completion of the reset procedure.

If after five reads, [CCP2\\_SYSSTATUS \[0\]](#) RESET\_DONE still returns 0, it can be assumed that an error occurred during the reset stage.

The CSI2A and CSI2C receivers accept a general software reset, propagated through the hierarchy. This reset can be performed to initialize the module and has the same effect as a hardware reset.

The CSI2A and CSI2C receivers can be reset by writing [CSI2\\_SYSCONFIG \[1\]](#) SOFT\_RESET bit to 1. The software can monitor the [CSI2\\_SYSSTATUS \[0\]](#) RESET\_DONE status bit to wait for the completion of the reset procedure.

If after five reads, [CSI2\\_SYSSTATUS \[0\]](#) RESET\_DONE still returns 0, it can be assumed that an error occurred during the reset stage.

---

### 6.3.2 Camera ISP Hardware Requests

#### 6.3.2.1 Camera ISP Interrupt Requests

[Figure 6-52](#) shows the interrupt generation tree of the camera subsystem.

**Figure 6-52. Camera ISP Interrupt Generation Tree**


camisp-231

 (1)  $x = 0 \text{ to } 7$ 

The camera ISP can generate two interrupts:

- CAM\_IRQ0 is an interrupt to the MPU subsystem interrupt controller. It is mapped on M\_IRQ\_24.
- CAM\_IRQ1 is an interrupt to the IVA2.2 subsystem interrupt controller. It is mapped on IVA2\_IRQ[11].

[Table 6-15](#) summarizes events that cause interrupts.

**Table 6-15. Camera ISP Interrupts**

| Event                                                                            | Mask                                                   | Description                                                                                                                                                                                                                                                       |
|----------------------------------------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <a href="#"><b>ISP_IRQ0STATUS [31]</b></a> HS_VS_IRQ                             | <a href="#"><b>ISP_IRQ0ENABLE [31]</b></a> HS_VS_IRQ   | HS or VS synchronization event: triggered if a rising or falling edge is detected on the HS or VS signal. The rising or falling edge and the HS or VS signal selection are chosen with the <a href="#">ISP_CTRL [15:14] SYNC_DETECT</a> bit field. <sup>(1)</sup> |
| <a href="#"><b>ISP_IRQ0STATUS [28]</b></a><br><a href="#"><b>MMU_ERR_IRQ</b></a> | <a href="#"><b>ISP_IRQ0ENABLE [28]</b></a> MMU_ERR_IRQ | MMU error                                                                                                                                                                                                                                                         |

<sup>(1)</sup> This event is detected on the incoming HS/VS signals before the CCDC. Therefore, it cannot be used in BT656 mode.

**Table 6-15. Camera ISP Interrupts (continued)**

| Event                                                   | Mask                                                   | Description                                                                                                                                                                                                                                                                                                                             |
|---------------------------------------------------------|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ISP_IRQ0STATUS [25] OVF_IRQ</b>                      | <b>ISP_IRQ0ENABLE [25] OVF_IRQ</b>                     | Central-resource SBL overflow: triggered when one of the buffers in the central-resource SBL overflows                                                                                                                                                                                                                                  |
| <b>ISP_IRQ0STATUS [24] RSZ_DONE_IRQ</b>                 | <b>ISP_IRQ0ENABLE [24] RSZ_DONE_IRQ</b>                | RESIZER module. Resizer processing-done event:<br>Triggered at the end of the frame when processing is complete for the current frame. It applies to one-shot and continuous modes.                                                                                                                                                     |
| <b>ISP_IRQ0STATUS [21] CBUFF_IRQ</b>                    | <b>ISP_IRQ0ENABLE [24] CBUFF_IRQ</b>                   | CBUFF module event. See <a href="#">CBUFF_IRQSTATUS</a> to know which interrupt it is.                                                                                                                                                                                                                                                  |
| <b>ISP_IRQ0STATUS [20] PRV_DONE_IRQ</b>                 | <b>ISP_IRQ0ENABLE [20] PRV_DONE_IRQ</b>                | PREVIEW module: Processing-done event: triggered at the end of the frame when processing is complete for the current frame                                                                                                                                                                                                              |
| <b>ISP_IRQ0STATUS [19] CCDC_LSC_PREFETCH_ERROR</b>      | <b>ISP_IRQ0ENABLE [19] PRV_DONE_IRQ</b>                | CCDC module. The prefetch error indicates when the gain table was read too slowly from memory. When this event is pending, the module goes into transparent mode (output = input). Normal operation can be resumed at the start of the next frame after:<br><br>1) Clearing this event<br>2) Disabling the LSC module<br>3) Enabling it |
| <b>ISP_IRQ0STATUS [18] CCDC_LSC_PREFETCH_COMPLETE_D</b> | <b>ISP_IRQ0ENABLE [18] CCDC_LSC_PREFETCH_COMPLETED</b> | CCDC module. Indicates the current state of the prefetch buffer. Can be used to start sending the data once the buffer is full to minimize the risk of an underflow. This event is triggered when the buffer contains 3 full pixel rows. It can be used to minimize buffer underflow risks.                                             |
| <b>ISP_IRQ0STATUS [17] CCDC_LSC_DONE</b>                | <b>ISP_IRQ0ENABLE [17] CCDC_LSC_DONE</b>               | CCDC module. The event is triggered when the internal state of LSC toggles from BUSY to IDLE. This happens when the LSC module has completed processing the current frame.                                                                                                                                                              |
| <b>ISP_IRQ0STATUS [16] HIST_DONE_IRQ</b>                | <b>ISP_IRQ0ENABLE [16] HIST_DONE_IRQ</b>               | HIST module. Processing-done event: triggered at the end of the frame when processing is complete for the current frame                                                                                                                                                                                                                 |
| <b>ISP_IRQ0STATUS [13] H3A_AWB_DONE_IRQ</b>             | <b>ISP_IRQ0ENABLE [13] H3A_AWB_DONE_IRQ</b>            | H3A module. Auto exposure and auto white balance processing done event:<br><br>Triggered at the end of the frame when processing is complete for the current frame                                                                                                                                                                      |
| <b>ISP_IRQ0STATUS [12] H3A_AF_DONE_IRQ</b>              | <b>ISP_IRQ0ENABLE [12] H3A_AF_DONE_IRQ</b>             | H3A module. Autofocus processing-done event: triggered at the end of the frame when processing is complete for the current frame                                                                                                                                                                                                        |
| <b>ISP_IRQ0STATUS [11] CCDC_ERR_IRQ</b>                 | <b>ISP_IRQ0ENABLE [11] CCDC_ERR_IRQ</b>                | CCDC module. Faulty-pixel correction error: Faulty-pixel correction memory underflow. Triggered to signal an error in the faulty-pixel correction logic. The hardware did not have time to read the faulty-pixel LUT from external memory in time.                                                                                      |
| <b>ISP_IRQ0STATUS [10] CCDC_VD2_IRQ</b>                 | <b>ISP_IRQ0ENABLE [10] CCDC_VD2_IRQ</b>                | CCDC module. Programmable event 2: triggered by the falling edge on the cam_wen signal. This event is not programmable.                                                                                                                                                                                                                 |
| <b>ISP_IRQ0STATUS [9] CCDC_VD1_IRQ</b>                  | <b>ISP_IRQ0ENABLE [9] CCDC_VD1_IRQ</b>                 | CCDC module. Programmable event 1: triggered after a programmable number of horizontal lines is received after a VS pulse                                                                                                                                                                                                               |
| <b>ISP_IRQ0STATUS [8] CCDC_VD0_IRQ</b>                  | <b>ISP_IRQ0ENABLE [8] CCDC_VD0_IRQ</b>                 | CCDC module. Programmable event 0: triggered after a programmable number of horizontal lines is received after a VS pulse                                                                                                                                                                                                               |
| <b>ISP_IRQ0STATUS [7] CSI1_LC3_IRQ</b>                  | <b>ISP_IRQ0ENABLE [4] CSI1_LC3_IRQ</b>                 | CSI1/CCP2B receiver module event. See <a href="#">CCP2_LC23_IRQSTATUS</a> to know which interrupt it is.                                                                                                                                                                                                                                |

**Table 6-15. Camera ISP Interrupts (continued)**

| Event                                           | Mask                                            | Description                                                                                              |
|-------------------------------------------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| <a href="#">ISP_IRQ0STATUS [6] CSI1_LC2_IRQ</a> | <a href="#">ISP_IRQ0ENABLE [4] CSI1_LC2_IRQ</a> | CSI1/CCP2B receiver module event. See <a href="#">CCP2_LC23_IRQSTATUS</a> to know which interrupt it is. |
| <a href="#">ISP_IRQ0STATUS [5] CSI1_LC1_IRQ</a> | <a href="#">ISP_IRQ0ENABLE [4] CSI1_LC1_IRQ</a> | CSI1/CCP2B receiver module event. See <a href="#">CCP2_LC01_IRQSTATUS</a> to know which interrupt it is. |
| <a href="#">ISP_IRQ0STATUS [4] CSI1_LC0_IRQ</a> | <a href="#">ISP_IRQ0ENABLE [4] CSI1_LC0_IRQ</a> | CSI1/CCP2B receiver module event. See <a href="#">CCP2_LC01_IRQSTATUS</a> to know which interrupt it is. |
| <a href="#">ISP_IRQ0STATUS [3] CSI1_LCM_IRQ</a> | <a href="#">ISP_IRQ0ENABLE [3] CSI1_LCM_IRQ</a> | CSI1 receiver module event on memory channel.                                                            |
| <a href="#">ISP_IRQ0STATUS [1] CSI2C_IRQ</a>    | <a href="#">ISP_IRQ0ENABLE [1] CSI2C_IRQ</a>    | CSI2C receiver module event. See <a href="#">CSI2_IRQSTATUS</a> to know which interrupt it is.           |
| <a href="#">ISP_IRQ0STATUS [0] CSI2A_IRQ</a>    | <a href="#">ISP_IRQ0ENABLE [0] CSI2A_IRQ</a>    | CSI2A receiver module event. See <a href="#">CSI2_IRQSTATUS</a> to know which interrupt it is.           |

**NOTE:** n is equal to 0 or 1.

I is equal to 01 or 23.

Table 6-16 summarizes the CBUFF interrupts.

**Table 6-16. Camera ISP CBUFF Interrupt Details**

| Event                                                  | Mask                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------------------------------------|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <a href="#">CBUFF_IRQSTATUS [5] IRQ_CBUFF1_OVR</a>     | <a href="#">CBUFF_IRQENABLE [5] IRQ_CBUFF1_OVR</a>     | Buffer overflow event: The generation of this event depends on the <a href="#">CBUFFx_CTRL.ALLOW_NW_EQ_CR</a> flag and the circular buffer mode (read or write). This event indicates a bandwidth mismatch between data producer and data consumer. When it occurs, CBUFFx does NOT go into error state. However, the data in the physical buffer is very likely to be corrupted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <a href="#">CBUFF_IRQSTATUS [4] IRQ_CBUFF1_INVALID</a> | <a href="#">CBUFF_IRQENABLE [4] IRQ_CBUFF1_INVALID</a> | <p>Invalid access:</p> <ul style="list-style-type: none"> <li>• Camera controller writes the virtual space of CBUFFx in read mode.</li> <li>• Camera controller reads the virtual space of CBUFFx in write mode.</li> <li>• HW writes the virtual space of circular buffer x outside the CW or NW window in write mode.</li> <li>• HW reads the virtual space of circular buffer x outside the CW or NW window in read mode.</li> <li>• NW full</li> <li>• CPU write the DONE bit when physical buffers are not ready for the CPU.</li> </ul> <p>This event indicates a wrong configuration of the circular buffer, the camera ISP, or bogus software. When it occurs, CBUFFx goes into an error state. In this state all accesses to the virtual space of CBUFFx are cancelled: they are not forwarded to the physical space. The purpose is to prevent corruption of the physical memory.</p> <p>The error state can be left by disabling the CBUFFx and reenabling it. Before doing so, the SW must ensure that there are no more outstanding requests to the virtual space of CBUFFx.</p> |

**Table 6-16. Camera ISP CBUFF Interrupt Details (continued)**

| Event                                            | Mask                                             | Description                                                     |
|--------------------------------------------------|--------------------------------------------------|-----------------------------------------------------------------|
| <b>CBUFF IRQSTATUS [3]</b><br>IRQ_CBUFF1_READY   | <b>CBUFF IRQENABLE [3]</b><br>IRQ_CBUFF1_READY   | The CPUW1 physical buffer is ready to be accessed by the CPU.   |
| <b>CBUFF IRQSTATUS [2]</b><br>IRQ_CBUFF0_OVR     | <b>CBUFF IRQENABLE [2]</b> IRQ_CBUFF0_OVR        | Buffer overflow event. See description of IRQ_CBUFF1_OVR event. |
| <b>CBUFF IRQSTATUS [1]</b><br>IRQ_CBUFF0_INVALID | <b>CBUFF IRQENABLE [1]</b><br>IRQ_CBUFF0_INVALID | Invalid access. See description of IRQ_CBUFF1_INVALID event.    |
| <b>CBUFF IRQSTATUS [0]</b><br>IRQ_CBUFF0_READY   | <b>CBUFF IRQENABLE [0]</b><br>IRQ_CBUFF0_READY   | The CPUW1 physical buffer is ready to be accessed by the CPU    |

Table 6-17 describes the CSI1/CCP2B receiver interrupts.

**Table 6-17. Camera ISP CSI1/CCP2B Receiver Interrupt Details**

| Event                                              | Mask                                            | Description                                                                                                                                                                                                  |
|----------------------------------------------------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CCP2_LC01_IRQSTATUS[27]</b><br>LC1_FS_IRQ       | <b>CCP2_LC01_IRQENABLE[27]</b> LC1_FS_IRQ       | Frame-start synchronization code detection for logical channel 1:<br>This interrupt is triggered on the detection of a frame-start synchronization code into the CCP2 data stream.                           |
| <b>CCP2_LC01_IRQSTATUS[26]</b><br>LC1_LE_IRQ       | <b>CCP2_LC01_IRQENABLE[26]</b> LC1_LE_IRQ       | Line-end synchronization code detection for logical channel 1:<br>This interrupt is triggered on the detection of a line-end synchronization code into the CCP2 data stream.                                 |
| <b>CCP2_LC01_IRQSTATUS[25]</b><br>LC1_LS_IRQ       | <b>CCP2_LC01_IRQENABLE[25]</b> LC1_LS_IRQ       | Line-start synchronization code detection for logical channel 1:<br>This interrupt is triggered on the detection of a line-start synchronization code into the CCP2 data stream.                             |
| <b>CCP2_LC01_IRQSTATUS[24]</b><br>LC1_FE_IRQ       | <b>CCP2_LC01_IRQENABLE[24]</b> LC1_FE_IRQ       | Frame-end synchronization code detection for logical channel 1:<br>This interrupt is triggered on the detection of a frame-end synchronization code into the CCP2 data stream.                               |
| <b>CCP2_LC01_IRQSTATUS[23]</b><br>LC1_COUNT_IRQ    | <b>CCP2_LC01_IRQENABLE[23]</b> LC1_COUNT_IRQ    | Frame counter reached for logical channel 1:<br>This interrupt is triggered when the frame counter has reached its programmable target value.                                                                |
| <b>CCP2_LC01_IRQSTATUS[21]</b><br>LC1_FIFO_OVF_IRQ | <b>CCP2_LC01_IRQENABLE[21]</b> LC1_FIFO_OVF_IRQ | FIFO overflow error for logical channel 1:<br>This interrupt is triggered upon detection of a FIFO overflow. An overflow can occur if there is a mismatch between the data input and output rates.           |
| <b>CCP2_LC01_IRQSTATUS[20]</b><br>LC1_CRC_IRQ      | <b>CCP2_LC01_IRQENABLE[20]</b> LC1_CRC_IRQ      | CRC error for logical channel 1:<br>This interrupt is triggered upon detection of a mismatch between the transmitter and receiver checksums. This interrupt does not apply to the MIPI CSI1 compatible mode. |
| <b>CCP2_LC01_IRQSTATUS[19]</b><br>LC1_FSP_IRQ      | <b>CCP2_LC01_IRQENABLE[19]</b> LC1_FSP_IRQ      | False synchronization code protection error for logical channel 1:<br>This interrupt is triggered by the FSP decoder if an illegal combination is detected, but 0xA5 is not present in the bit stream.       |
| <b>CCP2_LC01_IRQSTATUS[18]</b><br>LC1_FW_IRQ       | <b>CCP2_LC01_IRQENABLE[18]</b> LC1_FW_IRQ       | Frame-width error for logical channel 1:<br>This interrupt is generated if the frame width constraints associated to the current data type is not respected.                                                 |
| <b>CCP2_LC01_IRQSTATUS[17]</b><br>LC1_FSC_IRQ      | <b>CCP2_LC01_IRQENABLE[17]</b> LC1_FSC_IRQ      | False synchronization code error for logical channel 1:<br>This interrupt is triggered if the synchronization code order is not respected. This state is shown in the CCP2 receiver finite state-machine.    |

**Table 6-17. Camera ISP CSI1/CCP2B Receiver Interrupt Details (continued)**

| Event                                              | Mask                                           | Description                                                                                                                                                                                                                                                                                                                 |
|----------------------------------------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CCP2_LC01_IRQSTATUS[16]<br/>LC1_SSC IRQ</b>     | <b>CCP2_LC01_IRQENABLE[16]LC1_SSC IRQ</b>      | Shifted synchronization code error for logical channel 1:<br>This interrupt is triggered if LEC or FEC are not aligned on a 32-bit boundary. This state is shown in the CCP2 receiver finite state-machine. The shifted synchronization code error is highlighted in the CCP2 receiver finite state-machine. <sup>(1)</sup> |
| <b>CCP2_LC01_IRQSTATUS[11]<br/>LC0_FS IRQ</b>      | <b>CCP2_LC01_IRQENABLE[11] LC0_FS IRQ</b>      | Frame-start synchronization code detection for logical channel 0:<br>This interrupt is triggered on the detection of a frame-start synchronization code into the CCP2 data stream.                                                                                                                                          |
| <b>CCP2_LC01_IRQSTATUS[10]<br/>LC0_LE IRQ</b>      | <b>CCP2_LC01_IRQENABLE[10] LC0_LE IRQ</b>      | Line-end synchronization code detection for logical channel 0:<br>This interrupt is triggered on the detection of a line-end synchronization code into the CCP2 data stream.                                                                                                                                                |
| <b>CCP2_LC01_IRQSTATUS[9]<br/>LC0_LS IRQ</b>       | <b>CCP2_LC01_IRQENABLE[9] LC0_LS IRQ</b>       | Line-start synchronization code detection for logical channel 0:<br>This interrupt is triggered on the detection of a line-start synchronization code into the CCP2 data stream.                                                                                                                                            |
| <b>CCP2_LC01_IRQSTATUS[8]<br/>LC0_FE IRQ</b>       | <b>CCP2_LC01_IRQENABLE[8] LC0_FE IRQ</b>       | Frame-end synchronization code detection for logical channel 0:<br>This interrupt is triggered on the detection of a frame-end synchronization code into the CCP2 data stream.                                                                                                                                              |
| <b>CCP2_LC01_IRQSTATUS[7]<br/>LC0_COUNT IRQ</b>    | <b>CCP2_LC01_IRQENABLE[7] LC0_COUNT IRQ</b>    | Frame counter reached for logical channel 0:<br>This interrupt is triggered on the frame counter reached into the CCP2 data stream.                                                                                                                                                                                         |
| <b>CCP2_LC01_IRQSTATUS[5]<br/>LC0_FIFO_OVF IRQ</b> | <b>CCP2_LC01_IRQENABLE[5] LC0_FIFO_OVF IRQ</b> | FIFO overflow error for logical channel 0:<br>This interrupt is triggered on the detection of a FIFO overflow error.                                                                                                                                                                                                        |
| <b>CCP2_LC01_IRQSTATUS[4]<br/>LC0_CRC IRQ</b>      | <b>CCP2_LC01_IRQENABLE[4] LC0_CRC IRQ</b>      | CRC error<br>This interrupt is triggered on the detection of a CRC error into the CCP2 data stream.                                                                                                                                                                                                                         |
| <b>CCP2_LC01_IRQSTATUS[3]<br/>LC0_FSP IRQ</b>      | <b>CCP2_LC01_IRQENABLE[3] LC0_FSP IRQ</b>      | False synchronization code protection error for logical channel 0:<br>This interrupt is triggered by the FSP decoder if an illegal combination is detected, but 0xA5 is not present in the bit stream.                                                                                                                      |
| <b>CCP2_LC01_IRQSTATUS[2]<br/>LC0_FW IRQ</b>       | <b>CCP2_LC01_IRQENABLE[2] LC0_FW IRQ</b>       | Frame-width error for logical channel 0:<br>This interrupt is triggered on the detection of a frame-width error into the CCP2 data stream.                                                                                                                                                                                  |
| <b>CCP2_LC01_IRQSTATUS[1]<br/>LC0_FSC IRQ</b>      | <b>CCP2_LC01_IRQENABLE[1] LC0_FSC IRQ</b>      | False synchronization code error for logical channel 0:<br>This interrupt is triggered on the detection of a false synchronization code error into the CCP2 data stream.                                                                                                                                                    |
| <b>CCP2_LC01_IRQSTATUS[0]<br/>LC0_SSC IRQ</b>      | <b>CCP2_LC01_IRQENABLE[0] LC0_SSC IRQ</b>      | Shifted synchronization code error for logical channel 0:<br>This interrupt is triggered if LEC or FEC are not aligned on a 32-bit boundary. This state is shown in the CCP2 receiver finite state-machine. The shifted synchronization code error is highlighted in the CCP2 receiver finite state-machine. <sup>(2)</sup> |
| <b>CCP2_LC23_IRQSTATUS[27]<br/>LC3_FS IRQ</b>      | <b>CCP2_LC23_IRQENABLE[27] LC3_FS IRQ</b>      | Frame-start synchronization code detection for logical channel 3:<br>This interrupt is triggered on the detection of a frame-start synchronization code into the CCP2 data stream                                                                                                                                           |

<sup>(1)</sup> This error can be triggered if the complex I/O cell is used in parallel output mode (CCP\_CTRL[2]IO\_OUT\_SEL=1).

<sup>(2)</sup> This error can be triggered if the complex I/O cell is used in parallel output mode (CCP\_CTRL[2]IO\_OUT\_SEL=1).

**Table 6-17. Camera ISP CSI1/CCP2B Receiver Interrupt Details (continued)**

| Event                                               | Mask                                            | Description                                                                                                                                                                                                                                                                                                                 |
|-----------------------------------------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CCP2_LC23_IRQSTATUS[26]<br/>LC3_LE_IRQ</b>       | <b>CCP2_LC23_IRQENABLE[26]</b> LC3_LE_IRQ       | Line-end synchronization code detection for logical channel 3:<br>This interrupt is triggered on the detection of a line-end synchronization code into the CCP2 data stream.                                                                                                                                                |
| <b>CCP2_LC23_IRQSTATUS[25]<br/>LC3_LS_IRQ</b>       | <b>CCP2_LC23_IRQENABLE[25]</b> LC3_LS_IRQ       | Line-start synchronization code detection for logical channel 3:<br>This interrupt is triggered on the detection of a line-start synchronization code into the CCP2 data stream.                                                                                                                                            |
| <b>CCP2_LC23_IRQSTATUS[24]<br/>LC3_FE_IRQ</b>       | <b>CCP2_LC23_IRQENABLE[24]</b> LC3_FE_IRQ       | Frame-end synchronization code detection for logical channel 3:<br>This interrupt is triggered on the detection of a frame-end synchronization code into the CCP2 data stream.                                                                                                                                              |
| <b>CCP2_LC23_IRQSTATUS[23]<br/>LC3_COUNT_IRQ</b>    | <b>CCP2_LC23_IRQENABLE[23]</b> LC3_COUNT_IRQ    | Frame counter reached for logical channel 3:<br>This interrupt is triggered when the frame counter has reached its programmable target value.                                                                                                                                                                               |
| <b>CCP2_LC23_IRQSTATUS[21]<br/>LC3_FIFO_OVF_IRQ</b> | <b>CCP2_LC23_IRQENABLE[21]</b> LC3_FIFO_OVF_IRQ | FIFO overflow error for logical channel 3:<br>This interrupt is triggered upon detection of a FIFO overflow. An overflow can occur if there is a mismatch between the data input and output rates.                                                                                                                          |
| <b>CCP2_LC23_IRQSTATUS[20]<br/>LC3_CRC_IRQ</b>      | <b>CCP2_LC23_IRQENABLE[20]</b> LC3_CRC_IRQ      | CRC error for logical channel 3:<br>This interrupt is triggered upon detection of a mismatch between the transmitter and receiver checksums. This interrupt does not apply to the MIPI CSI1 compatible mode.                                                                                                                |
| <b>CCP2_LC23_IRQSTATUS[19]<br/>LC3_FSP_IRQ</b>      | <b>CCP2_LC23_IRQENABLE[19]</b> LC3_FSP_IRQ      | False synchronization code protection error for logical channel 3:<br>This interrupt is triggered by the FSP decoder if an illegal combination is detected, but 0xA5 is not present in the bit stream.                                                                                                                      |
| <b>CCP2_LC23_IRQSTATUS[18]<br/>LC3_FW_IRQ</b>       | <b>CCP2_LC23_IRQENABLE[18]</b> LC3_FW_IRQ       | Frame-width error for logical channel 3:<br>This interrupt is generated if the frame width constraints associated to the current data type is not respected.                                                                                                                                                                |
| <b>CCP2_LC23_IRQSTATUS[17]<br/>LC3_FSC_IRQ</b>      | <b>CCP2_LC23_IRQENABLE[17]</b> LC3_FSC_IRQ      | False synchronization code error for logical channel 3:<br>This interrupt is triggered if the synchronization code order is not respected. This state is shown in the CCP2 receiver finite state machine.                                                                                                                   |
| <b>CCP2_LC23_IRQSTATUS[16]<br/>LC3_SSC_IRQ</b>      | <b>CCP2_LC23_IRQENABLE[16]</b> LC3_SSC_IRQ      | Shifted synchronization code error for logical channel 3:<br>This interrupt is triggered if LEC or FEC are not aligned on a 32-bit boundary. This state is shown in the CCP2 receiver finite state-machine. The shifted synchronization code error is highlighted in the CCP2 receiver finite state-machine. <sup>(3)</sup> |
| <b>CCP2_LC23_IRQSTATUS[11]<br/>LC2_FS_IRQ</b>       | <b>CCP2_LC23_IRQENABLE[11]</b> LC2_FS_IRQ       | Frame-start synchronization code detection for logical channel 2:<br>This interrupt is triggered on the detection of a frame-start synchronization code into the CCP2 data stream.                                                                                                                                          |
| <b>CCP2_LC23_IRQSTATUS[10]<br/>LC2_LE_IRQ</b>       | <b>CCP2_LC23_IRQENABLE[10]</b> LC2_LE_IRQ       | Line-end synchronization code detection for logical channel 2:<br>This interrupt is triggered on the detection of a line-end synchronization code into the CCP2 data stream.                                                                                                                                                |

<sup>(3)</sup> This error can be triggered if the complex I/O cell is used in parallel output mode (CCP\_CTRL[2]IO\_OUT\_SEL=1).

**Table 6-17. Camera ISP CSI1/CCP2B Receiver Interrupt Details (continued)**

| Event                                              | Mask                                           | Description                                                                                                                                                                                                                                                                                                                 |
|----------------------------------------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CCP2_LC23_IRQSTATUS[9]<br/>LC2_LS_IRQ</b>       | <b>CCP2_LC23_IRQENABLE[9] LC2_LS_IRQ</b>       | Line-start synchronization code detection for logical channel 2:<br>This interrupt is triggered on the detection of a line-start synchronization code into the CCP2 data stream.                                                                                                                                            |
| <b>CCP2_LC23_IRQSTATUS[8]<br/>LC2_FE_IRQ</b>       | <b>CCP2_LC23_IRQENABLE[8] LC2_FE_IRQ</b>       | Frame-end synchronization code detection for logical channel 2:<br>This interrupt is triggered on the detection of a frame-end synchronization code into the CCP2 data stream.                                                                                                                                              |
| <b>CCP2_LC23_IRQSTATUS[7]<br/>LC2_COUNT_IRQ</b>    | <b>CCP2_LC23_IRQENABLE[7] LC2_COUNT_IRQ</b>    | Frame counter reached for logical channel 2:<br>This interrupt is triggered on the frame counter reached into the CCP2 data stream.                                                                                                                                                                                         |
| <b>CCP2_LC23_IRQSTATUS[5]<br/>LC2_FIFO_OVF_IRQ</b> | <b>CCP2_LC23_IRQENABLE[5] LC2_FIFO_OVF_IRQ</b> | FIFO overflow error for logical channel 2:<br>This interrupt is triggered on the detection of a FIFO overflow error.                                                                                                                                                                                                        |
| <b>CCP2_LC23_IRQSTATUS[4]<br/>LC2_CRC_IRQ</b>      | <b>CCP2_LC23_IRQENABLE[4] LC2_CRC_IRQ</b>      | CRC error for logical channel 2:<br>This interrupt is triggered on the detection of a CRC error into the CCP2 data stream.                                                                                                                                                                                                  |
| <b>CCP2_LC23_IRQSTATUS[3]<br/>LC2_FSP_IRQ</b>      | <b>CCP2_LC23_IRQENABLE[3] LC2_FSP_IRQ</b>      | False synchronization code protection error for logical channel 2:<br>This interrupt is triggered by the FSP decoder if an illegal combination is detected, but 0xA5 is not present in the bit stream.                                                                                                                      |
| <b>CCP2_LC23_IRQSTATUS[2]<br/>LC2_FW_IRQ</b>       | <b>CCP2_LC23_IRQENABLE[2] LC2_FW_IRQ</b>       | Frame-width error for logical channel 2:<br>This interrupt is triggered on the detection of a frame-width error into the CCP2 data stream.                                                                                                                                                                                  |
| <b>CCP2_LC23_IRQSTATUS[1]<br/>LC2_FSC_IRQ</b>      | <b>CCP2_LC23_IRQENABLE[1] LC2_FSC_IRQ</b>      | False synchronization code error for logical channel 2:<br>This interrupt is triggered on the detection of a false synchronization code error into the CCP2 data stream.                                                                                                                                                    |
| <b>CCP2_LC23_IRQSTATUS[0]<br/>LC2_SSC_IRQ</b>      | <b>CCP2_LC23_IRQENABLE[0] LC2_SSC_IRQ</b>      | Shifted synchronization code error for logical channel 2:<br>This interrupt is triggered if LEC or FEC are not aligned on a 32-bit boundary. This state is shown in the CCP2 receiver finite state-machine. The shifted synchronization code error is highlighted in the CCP2 receiver finite state-machine. <sup>(4)</sup> |
| <b>CCP2_LCM_IRQSTATUS[1]<br/>LCM_OCPERROR</b>      | <b>CCP2_LCM_IRQENABLE[1] LCM_OCPERROR</b>      | An OCP error occurred on the master read port.<br>This interrupt is triggered on the detection of an OCP error on the master read port.                                                                                                                                                                                     |
| <b>CCP2_LCM_IRQSTATUS[0]<br/>LCM_EOF</b>           | <b>CCP2_LCM_IRQENABLE[0] LCM_EOF</b>           | Memory read channel end of frame:<br>This interrupt is triggered when a frame has been completely read from memory.                                                                                                                                                                                                         |

<sup>(4)</sup> This error can be triggered if the complex I/O cell is used in parallel output mode (CCP\_CTRL[2]IO\_OUT\_SEL=1).

**Table 6-18** shows CSI2A and CSI2C receivers event generation through the CSI2 interrupt status and interrupt enable registers.

**Table 6-18. Camera ISP CSI2A and CSI2C Receivers Event Generation**

| Event                             | Mask                              | Description                                                                                     |
|-----------------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------|
| <b>CSI2_IRQSTATUS[0] CONTEXT0</b> | <b>CSI2_IRQENABLE[0] CONTEXT0</b> | At least one interrupt event enabled from Context 0 occurred (see <a href="#">Table 6-20</a> ). |
| <b>CSI2_IRQSTATUS[1] CONTEXT1</b> | <b>CSI2_IRQENABLE[1] CONTEXT1</b> | At least one interrupt event enabled from Context 1 occurred (see <a href="#">Table 6-20</a> ). |
| <b>CSI2_IRQSTATUS[2] CONTEXT2</b> | <b>CSI2_IRQENABLE[2] CONTEXT2</b> | At least one interrupt event enabled from Context 1 occurred (see <a href="#">Table 6-20</a> ). |
| <b>CSI2_IRQSTATUS[3] CONTEXT3</b> | <b>CSI2_IRQENABLE[3] CONTEXT3</b> | At least one interrupt event enabled from Context 3 occurred (see <a href="#">Table 6-20</a> ). |

**Table 6-18. Camera ISP CSI2A and CSI2C Receivers Event Generation (continued)**

| Event                                                 | Mask                                                  | Description                                                                                                                                                                                                                     |
|-------------------------------------------------------|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>CSI2_IRQSTATUS[4] CONTEXT4</code>               | <code>CSI2_IRQENABLE[4] CONTEXT4</code>               | At least one interrupt event enabled from Context 4 occurred (see <a href="#">Table 6-20</a> ).                                                                                                                                 |
| <code>CSI2_IRQSTATUS[5] CONTEXT5</code>               | <code>CSI2_IRQENABLE[5] CONTEXT5</code>               | At least one interrupt event enabled from Context 5 occurred (see <a href="#">Table 6-20</a> ).                                                                                                                                 |
| <code>CSI2_IRQSTATUS[6] CONTEXT6</code>               | <code>CSI2_IRQENABLE[6] CONTEXT6</code>               | At least one interrupt event enabled from Context 6 occurred (see <a href="#">Table 6-20</a> ).                                                                                                                                 |
| <code>CSI2_IRQSTATUS[7] CONTEXT6</code>               | <code>CSI2_IRQENABLE[7] CONTEXT7</code>               | At least one interrupt event enabled from Context 7 occurred (see <a href="#">Table 6-20</a> ).                                                                                                                                 |
| <code>CSI2_IRQSTATUS[8] FIFO_OVF_IRQ</code>           | <code>CSI2_IRQENABLE[8] FIFO_OVF_IRQ</code>           | FIFO overflow error: This interrupt is triggered on detection of a FIFO overflow. An overflow can occur if there is a mismatch between the data input and output rates. A reset of the module is required to restart correctly. |
| <code>CSI2_IRQSTATUS[9] PHY_ERR_IRQ</code>            | <code>CSI2_IRQENABLE[9] PHT_ERR_IRQ</code>            | Error signaling from PHY: This interrupt is triggered when any error is received from the PHY (events are defined in <code>CSI2_COMPLEXIO1_IRQSTATUS</code> [see <a href="#">Table 6-19</a> ]).                                 |
| <code>CSI2_IRQSTATUS[11] ECC_NO_CORRECTION_IRQ</code> | <code>CSI2_IRQENABLE[11] ECC_NO_CORRECTION_IRQ</code> | ECC was not used to correct the header because the error is larger than 1 bit (short and long packets).                                                                                                                         |
| <code>CSI2_IRQSTATUS[12] ECC_CORRECTION_IRQ</code>    | <code>CSI2_IRQENABLE[12] ECC_CORRECTION_IRQ</code>    | ECC was used to correct a 1-bit error (short packet only).                                                                                                                                                                      |
| <code>CSI2_IRQSTATUS[13] SHORT_PACKET_IRQ</code>      | <code>CSI2_IRQENABLE[13] SHORT_PACKET_IRQ</code>      | Short packet reception (other than sync events: line start, line end, frame start, and frame end; only data types between 0x8 and 0xF are considered).                                                                          |
| <code>CSI2_IRQSTATUS[14] OCP_ERR_IRQ</code>           | <code>CSI2_IRQENABLE[14] OCP_ERR_IRQ</code>           | OCP error                                                                                                                                                                                                                       |

[Table 6-19](#) shows CSI2A and CSI2C receiver event generation interrupt status and interrupt enable registers receiving signals from the associated PHY.

**Table 6-19. Camera ISP CSI2A and CSI2C Receiver Event Generation from PHY**

| Event                                                   | Mask                                                    | Description                                 |
|---------------------------------------------------------|---------------------------------------------------------|---------------------------------------------|
| <code>CSI2_COMPLEXIO1_IRQSTATUS[0] ERRSOTHS1</code>     | <code>CSI2_COMPLEXIO1_IRQENABLE[0] ERRSOTHS1</code>     | Start of transmission error for lane 1      |
| <code>CSI2_COMPLEXIO1_IRQSTATUS[1] ERRSOTHS2</code>     | <code>CSI2_COMPLEXIO1_IRQENABLE[1] ERRSOTHS2</code>     | Start of transmission error for lane 2      |
| <code>CSI2_COMPLEXIO1_IRQSTATUS[2] ERRSOTHS3</code>     | <code>CSI2_COMPLEXIO1_IRQENABLE[2] ERRSOTHS3</code>     | Start of transmission error for lane 3      |
| <code>CSI2_COMPLEXIO1_IRQSTATUS[5] ERRSOTSYNCHS1</code> | <code>CSI2_COMPLEXIO1_IRQENABLE[5] ERRSOTSYNCHS1</code> | Start of transmission sync error for lane 1 |
| <code>CSI2_COMPLEXIO1_IRQSTATUS[6] ERRSOTSYNCHS2</code> | <code>CSI2_COMPLEXIO1_IRQENABLE[6] ERRSOTSYNCHS2</code> | Start of transmission sync error for lane 2 |
| <code>CSI2_COMPLEXIO1_IRQSTATUS[7] ERRSOTSYNCHS3</code> | <code>CSI2_COMPLEXIO1_IRQENABLE[7] ERRSOTSYNCHS3</code> | Start of transmission sync error for lane 3 |
| <code>CSI2_COMPLEXIO1_IRQSTATUS[10] ERRESC1</code>      | <code>CSI2_COMPLEXIO1_IRQENABLE[10] ERRESC1</code>      | Escape entry error for lane 1               |
| <code>CSI2_COMPLEXIO1_IRQSTATUS[11] ERRESC2</code>      | <code>CSI2_COMPLEXIO1_IRQENABLE[11] ERRESC2</code>      | Escape entry error for lane 2               |
| <code>CSI2_COMPLEXIO1_IRQSTATUS[12] ERRESC3</code>      | <code>CSI2_COMPLEXIO1_IRQENABLE[12] ERRESC3</code>      | Escape entry error for lane 3               |
| <code>CSI2_COMPLEXIO1_IRQSTATUS[15] ERRCONTROL1</code>  | <code>CSI2_COMPLEXIO1_IRQENABLE[15] ERRCONTROL1</code>  | Control error for lane 1                    |
| <code>CSI2_COMPLEXIO1_IRQSTATUS[16] ERRCONTROL2</code>  | <code>CSI2_COMPLEXIO1_IRQENABLE[16] ERRCONTROL2</code>  | Control error for lane 2                    |

**Table 6-19. Camera ISP CSI2A and CSI2C Receiver Event Generation from PHY (continued)**

| Event                                                                  | Mask                                                                   | Description                               |
|------------------------------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------|
| <a href="#"><b>CSI2_COMPLEXIO1_IRQSTATUS[17]</b></a> ERRCONTROL3       | <a href="#"><b>CSI2_COMPLEXIO1_IRQENABLE[17]</b></a> ERRCONTROL3       | Control error for lane 3                  |
| <a href="#"><b>CSI2_COMPLEXIO1_IRQSTATUS[20]</b></a> STATEULPM1        | <a href="#"><b>CSI2_COMPLEXIO1_IRQENABLE[20]</b></a> STATEULPM1        | Lane 1 in ULPM                            |
| <a href="#"><b>CSI2_COMPLEXIO1_IRQSTATUS[21]</b></a> STATEULPM2        | <a href="#"><b>CSI2_COMPLEXIO1_IRQENABLE[21]</b></a> STATEULPM2        | Lane 2 in ULPM                            |
| <a href="#"><b>CSI2_COMPLEXIO1_IRQSTATUS[22]</b></a> STATEULPM3        | <a href="#"><b>CSI2_COMPLEXIO1_IRQENABLE[22]</b></a> STATEULPM3        | Lane 3 in ULPM                            |
| <a href="#"><b>CSI2_COMPLEXIO1_IRQSTATUS[25]</b></a> STATEALLULPMENTER | <a href="#"><b>CSI2_COMPLEXIO1_IRQENABLE[25]</b></a> STATEALLULPMENTER | All active lanes are entering in ULPM.    |
| <a href="#"><b>CSI2_COMPLEXIO1_IRQSTATUS[26]</b></a> STATEALLULPMEXIT  | <a href="#"><b>CSI2_COMPLEXIO1_IRQENABLE[26]</b></a> STATEALLULPMEXIT  | At least one active lane exited the ULPM. |

As the CSI2A and CSI2C receivers supports eight contexts, the [\*\*CSI2\\_CTX\\_IRQSTATUS\*\*](#) and [\*\*CSI2\\_CTX\\_IRQENABLE\*\*](#) registers are present eight times (one time per context).

The events are generated only for the enabled context(s). **Table 6-20** describes the CSI2A and CSI2C receiver event generation through the CTx interrupt status and interrupt enable registers.

**Table 6-20. Camera ISP CSI2A and CSI2C CTx Receiver Event Generation**

| Event                                                           | Mask                                                            | Description                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------------------------------|-----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <a href="#"><b>CSI2_CTX_IRQSTATUS[0]</b></a> FS_IRQ             | <a href="#"><b>CSI2_CTX_IRQENABLE[0]</b></a> FS_IRQ             | Frame start: This interrupt is triggered on the detection of a frame-start synchronization code into the CSI2 data stream.                                                                                                                                                                                                                                                            |
| <a href="#"><b>CSI2_CTX_IRQSTATUS[1]</b></a> FE_IRQ             | <a href="#"><b>CSI2_CTX_IRQENABLE[1]</b></a> FE_IRQ             | Frame end: This interrupt is triggered on the detection of a frame-end synchronization code into the CSI2 data stream.                                                                                                                                                                                                                                                                |
| <a href="#"><b>CSI2_CTX_IRQSTATUS[2]</b></a> LS_IRQ             | <a href="#"><b>CSI2_CTX_IRQENABLE[2]</b></a> LS_IRQ             | Line start: This interrupt is triggered on the detection of a line-start synchronization code into the CSI2 data stream.                                                                                                                                                                                                                                                              |
| <a href="#"><b>CSI2_CTX_IRQSTATUS[3]</b></a> LE_IRQ             | <a href="#"><b>CSI2_CTX_IRQENABLE[3]</b></a> LE_IRQ             | Line end: This interrupt is triggered on the detection of a line-end synchronization code into the CSI2 data stream.                                                                                                                                                                                                                                                                  |
| <a href="#"><b>CSI2_CTX_IRQSTATUS[5]</b></a> CS_IRQ             | <a href="#"><b>CSI2_CTX_IRQENABLE[5]</b></a> CS_IRQ             | CS error: This interrupt is triggered upon detection of a mismatch between the transmitter and receiver checksums (payload).                                                                                                                                                                                                                                                          |
| <a href="#"><b>CSI2_CTX_IRQSTATUS[6]</b></a> FRAME_NUMBER_IRQ   | <a href="#"><b>CSI2_CTX_IRQENABLE[6]</b></a> FRAME_NUMBER_IRQ   | Frame counter reached: This interrupt is triggered when the frame counter reaches its programmable target value.                                                                                                                                                                                                                                                                      |
| <a href="#"><b>CSI2_CTX_IRQSTATUS[7]</b></a> LINE_NUMBER_IRQ    | <a href="#"><b>CSI2_CTX_IRQENABLE[7]</b></a> LINE_NUMBER_IRQ    | Line number reached: The programmable line number is received. The modulo feature can be selected ( <a href="#"><b>CSI2_CTX_CTRL1.LINE_MODULO</b></a> ). When selected, the interrupt is generated for each line number multiple of the programmed line number ( <a href="#"><b>CSI2_CTX_CTRL3.LINE_NUMBER</b></a> ); otherwise, the interrupt is generated only for the line number. |
| <a href="#"><b>CSI2_CTX_IRQSTATUS[8]</b></a> ECC_CORRECTION_IRQ | <a href="#"><b>CSI2_CTX_IRQENABLE[8]</b></a> ECC_CORRECTION_IRQ | ECC was used to correct a 1-bit error (long packets only).                                                                                                                                                                                                                                                                                                                            |

## 6.4 Camera ISP Functional Description

### 6.4.1 Camera ISP Block Diagram

Figure 6-53 is the camera ISP top-level block diagram. The camera ISP supports two simultaneous pixel flows, but only one of them can use the Video processing hardware at a time.

See [Section 6.2.3](#) for connectivity configurations and limitations details.

The camera ISP master port is connected to the L3 interconnect, and the slave port is connected to the L4 interconnect (from the camera ISP point of view, commands are output from the camera ISP to the L3 and data are input/output. From the camera ISP point of view, commands are input from the L4 to the camera ISP and data are input/output).

Figure 6-53 shows the camera ISP block diagram.

**Figure 6-53. Camera ISP Block Diagram**


The camera ISP module comprises the following blocks:

- Timing control: Includes a timing generator and a control-signal generator:
  - The timing generator allows the generation of two clocks that can be used by the external image sensors.

- The control-signal generator allows the generation of signals for strobe flash, mechanical shutter, and global reset.
- Three CSI receivers (one CCP2/MIPI CSI1 and two MIPI CSI2): The CSI receivers communicate with a serial camera through the PHY's and transfers received data to memory or to the Video processing hardware.
- Bridge-lane shifter:
  - The data-lane shifter gives flexibility to the parallel camera connection and permits dynamic reduction of pixel data.
  - The bridge allows higher transfer rates when data is captured from the parallel interface and sent to memory.
- Video-processing front end (VPFE): Comprises the CCDC. This module provides the camera ISP with a powerful and flexible front end interface. It directly affects the input image data:
  - The CCDC provides an interface to image sensors and digital video sources and processes image data.
- Video-processing back end (VPBE): Comprises preview and resizer modules:
  - The preview module is a parameterized hardwired image-processing block whose image-processing functions can be customized for each sensor type to realize good image quality and video frame rates for digital still camera preview displays and video-recording modes.
  - The resizer module provides a means of sizing the input image data to the desired display or video-encoding resolution. Zoom is limited to 4x in both vertical and horizontal directions for each pass. After one (on-the-fly) upscaling pass, the image can be sent to memory and then resent through the resizer.
- Statistics-collection modules (SCM): H3A and histogram modules that provide statistics on the incoming images to help designers of camera systems:
  - The hardware 3A module supports the control loops for AF, AWB, and AE by collecting metrics about RAW image data from the CCDC.
  - The histogram module bins input color pixels, depending on the amplitude, and provide statistics required to implement various 3A (AE/AF/AWB) algorithms and tune the final image/video output. The histogram module can operate on RAW image data from CCDC or memory.
- Central-resource shared buffer logic (CRSBL): Buffers and schedules memory accesses requested by the camera modules
- Circular buffer: Avoids storage of full image frames in the memory when the data must be post and/or preprocessed by software.
- MMU: Performs virtual-to-physical address translation between its interconnect slave and interconnect master access ports

#### 6.4.1.1 Camera ISP Possible Data Paths Inside the module

Data paths inside the camera ISP hardware depend on the image format sourced by the sensor (RAW RGB, YUV4:2:2, JPEG,...).

**Table 6-21** lists the modules used for the different data types. The formats described in the columns are the formats at the inputs of the CCDC. It is the internal parallel format.

**Table 6-21. Camera ISP Allowed Data Flows for Hardware**

| Module                       | 8/10 bit RAW from sensor | 11/12 bit RAW from sensor | BT 656 8/10 bit | YUV 8/10 bit |
|------------------------------|--------------------------|---------------------------|-----------------|--------------|
| CCDC Bridge lane shifter     |                          |                           |                 | X            |
| CCDC BT 656 decoder          |                          |                           | X               |              |
| CCDC DC subtract             | X                        | X                         | X               | X            |
| CCDC Optical Black clamp     | X                        | X                         |                 |              |
| CCDC Faulty pixel correction | X                        | X                         |                 |              |
| CCDC Data formatter          | X                        |                           |                 |              |

**Table 6-21. Camera ISP Allowed Data Flows for Hardware (continued)**

| Module                                  | 8/10 bit RAW from sensor | 11/12 bit RAW from sensor | BT 656 8/10 bit | YUV 8/10 bit |
|-----------------------------------------|--------------------------|---------------------------|-----------------|--------------|
| CCDC Preview, H3A, Histogram data paths | x                        |                           |                 |              |
| CCDC Output formatter                   | x                        | x                         | x               | x            |
| CCDC Low pass filter                    | x                        | x                         |                 |              |
| CCDC Culling                            | x                        | x                         | x               | x            |
| CCDC Alaw                               | x                        | x                         |                 |              |
| CCDC Resizer Datapath                   |                          |                           | x               | x            |
| CCDC Memory Datapath                    | x                        | x                         | x               | x            |
| CCDC Shading compensator                | x                        |                           |                 |              |
| Preview                                 | x                        |                           |                 |              |
| Resizer                                 | x                        |                           | x               | x            |
| H3A                                     | x                        |                           |                 |              |
| Histogram                               | x                        |                           |                 |              |

#### 6.4.1.1.1 Camera ISP RGB RAW Data

Figure 6-54 shows the data path of images in RAW format.

**Figure 6-54. Camera ISP/Data Path/RAW RGB Images**

camisp-103

RAW data are processed through the CCDC module and are directly pipelined to the preview engine(1). Another way is to output directly from the CCDC to memory (C) In the preview block; the format is converted from RAW data to YUV4:2:2. The data can be output to memory (4) or pipelined to the resizer (2). The rescaled YUV4:2:2 image is finally stored in memory (3).

In parallel, processed data in the CCDC are used by the H3A module (A), which writes tables of statistics in memory, and by the HIST module (B). The results of the HIST modules are stored in status registers in the HIST module.

**NOTE:**

- This data path is correct for RAW10 data.
- The data path for RAW8 data is similar to that for RAW10, except that the autofocus module in the H3A does not support RAW8.
- RAW11 data must be sent directly to memory (C).
- RAW12 data must be sent to memory (C) or pixel dynamic must be reduced RAW8 or RAW10 by the bridge-lane shifter module, before the CCDC.
- RAW14 data must be sent to memory (C) or pixel dynamic must be reduced to RAW8 or RAW10 by the bridge-lane shifter module, before the CCDC.

**6.4.1.1.2 Camera ISP YUV4:2:2 Data**

Figure 6-55 shows the data path of images in YUV4:2:2 format.

**Figure 6-55. Camera ISP / Data Path/YUV4:2:2 Images**



When the sensor-output format is YUV4:2:2, the CCDC block is directly pipelined to the resizer (1) or output directly to the memory (C). The rescaled YUV4:2:2 images are finally stored in memory (2).

The modules in red in Figure 6-55 are not used when the format is YUV4:2:2.

**6.4.1.1.3 JPEG Data**

Figure 6-56 shows the data path of images in JPEG format.

**Figure 6-56. Camera ISP/Data Path/JPEG Images**

When the sensor output format is JPEG, the CCDC block is directly output to the memory (C).

The modules in red in [Figure 6-56](#) are not used when the format is JPEG.

#### 6.4.2 Camera ISP CSI1/CCP2B Receiver

The CSI1 / CCP2B receiver is compatible with the CCP2 specification and the MIPI CSI1 specification.

##### 6.4.2.1 Camera ISP CSI1/CCP2B Receiver Features

The CSI1/CCP2B receiver features are listed below:

- Image from sensor
  - Transfer of pixels and data received by the associated PHY to system memory or to the Video processing hardware
  - Unidirectional data link
  - 1D and 2D addressing mode
  - False synchronization code protection
  - Ping-pong mechanism for double-buffering
  - Support of RGB, RAW, YUV, and JPEG formats
  - Support of DPCM compression and decompression
- Image read from memory
  - RAW formats supported

##### 6.4.2.2 Camera ISP CSI1/CCP2B Receiver Functional Description

###### 6.4.2.2.1 Camera ISP CSI1/CCP2B Overview

[Figure 6-57](#) is the CSI1/CCP2B receiver top-level block diagram. The CSI1/CCP2B receiver takes serial data from a CSI1/CCP2B-compatible image sensor through the selected PHY, converts it to parallel data, extracts the logical channels, detects and extracts the synchronization codes, reformats the data, and outputs it to the Video processing hardware or to memory.

The CSI1/CCP2B receiver video-port interface is connected to the Video processing hardware.

**Figure 6-57. Camera ISP CSI1/CCP2B Receiver Block Diagram**

#### 6.4.2.2.2 Camera ISP CSI1/CCP2B Associated PHY

The CSI1/CCP2B receiver's selected PHY is controlled by 2 bits of the [CCP2\\_CTRL](#) register:

- The [CCP2\\_CTRL\[2\]](#) IO\_OUT\_SEL bit selects the output mode of the PHY which must be set to 1 for parallel.

#### CAUTION

[CCP2\\_CTRL\[2\]](#) IO\_OUT\_SEL bit must be set to 1(parallel mode) after reset and at normal work flow. If not set, it could cause ISP functional stall.

- The [CCP2\\_CTRL\[10\]](#) INV bit selects the clock edge used to sample data:
  - If [CCP2\\_CTRL\[10\]](#) INV = 0x0, use the rising edge.
  - If [CCP2\\_CTRL\[10\]](#) INV = 0x1, use the falling edge.

The CSI1/CCP2B receiver associated configured PHY is controlled by a SCM registers:

SCM.CONTROL\_CAMERA\_PHY\_CTRL

- SCM.CONTROL\_CAMERA\_PHY\_CTRL[4] CSI1\_RX\_sel:
  - CSIPHY1 data is sent to ISP CSI1/ CCP2B if set to 0
  - CSIPHY2 data is sent to ISP CSI1/ CCP2B if set to 1

For information about initializing the CSIPHY associated with CSI1/CCP2B, see [Section 6.5.2.2, Camera ISP CSIPHY Initialization for Work With CSI1/CCP2B Receiver](#).

See [Section 6.2.3](#) for further connectivity schema details.

#### 6.4.2.2.3 Camera ISP CSI1/CCP2B Physical Layer

The CSI1/CCP2B serial interface is a unidirectional differential serial interface with two options for the physical layer: data/clock or data/strobe signals. The physical layer of the CSI1/CCP2B is based on SubLVDS signaling.

CCP2B defines three classes for data transfer between the transmitter and the receiver. [Table 6-22](#) summarizes the CSI1/CCP2B classifications. Class 1 and class 2 do not apply to the MIPI CSI1-compatible mode.

**Table 6-22. Camera ISP CSI1/CCP2B Transmitter Classification**

| Class               | Data Transfer Capacity | Signaling Method |
|---------------------|------------------------|------------------|
| Class 0 (CSI1/CCP2) | 208 Mbps               | Data/clock       |
| Class 1 (CCP2 only) | 208 Mbps to 416 Mbps   | Data/strobe      |

**Table 6-22. Camera ISP CSI1/CCP2B Transmitter Classification (continued)**

| Class               | Data Transfer Capacity | Signaling Method |
|---------------------|------------------------|------------------|
| Class 2 (CCP2 only) | 416 Mbps to 650 Mbps   | Data/strobe      |

#### 6.4.2.2.3.1 Camera ISP CSI1/CCP2B Data/Clock Signaling

Data/clock signaling consists of two parallel signals: data and clock.

- The data signal carries bit-serial data. The CSI1/CCP2B transmitter writes the data on each falling edge of the clock. The data are usually transmitted bytewise, LSB first.
- The data clock signal carries the clock signal. The CSI1/CCP2B transmitter writes the data on each falling edge of the clock. The CSI1/CCP2B receiver reads the data on the rising edge of the clock.

#### 6.4.2.2.3.2 Camera ISP CSI1/CCP2B Data/Strobe Signaling (CCP2 only)

Data/strobe signaling consists of two parallel signals: data and strobe.

- The data signal carries the bit-serial data.
- The data strobe signal carries the strobe signal. It toggles when the data signal does not change state. Either the data signal or the strobe signal changes between two data bits. The data and strobe signals may not change simultaneously. The data and strobe signals are used in the receiver to reconstruct the transmission clock. Both fronts of the reconstructed clock are used to sample the data.

#### 6.4.2.2.4 Camera ISP CSI1/CCP2B Protocol Layer

The CSI1/CCP2B protocol layer defines how image-sensor data are transported to the physical layer.

The CSI1/CCP2B protocol layer transports logical channels, which are composed of frames. A frame comprises embedded data and image-sensor data. Each frame is clearly identified by unique synchronization codes: frame start, frame end, line start, and line end. Image-sensor data can have multiple data types (select the data type in the [CCP2\\_LCx\\_CTRL \[7:2\] FORMAT](#) bit field [ $x = 0$  to  $3$ ]). For details about data types, synchronization code, and FSP encoding/decoding, see [Section 6.2.4.4, Camera ISP CSI1/CCP2 Protocol and Data Formats](#).

#### 6.4.2.2.4.1 Camera ISP CSI1/CCP2B Synchronization Finite State-Machine

[Figure 6-58](#) shows the CSI1/CCP2B receiver finite state-machine (FSM). The CSI1/CCP2B receiver synchronization operates bitwise.

The expected synchronization code order is FSC, LEC, LSC, and LEC...etc., LSC, LEC, LSC, FEC for all data types except JPEG8. For JPEG8, the expected synchronization code order is FSC, FEC.

If the synchronization code order is not respected, the state-machine goes to FalseSyncCode state. Because line length is always a multiple of 32 bits, the LEC and FEC codes are always aligned on a 32-bit boundary. If LEC or FEC is not aligned on a 32-bit boundary, the state-machine goes to LEShiftedSyncCode or FEShiftedSyncCode state. [Figure 6-58](#) shows the synchronization state-machine.

Figure 6-58. Camera ISP CSI1/CCP2B Synchronization State-Machine



camisp-194

In case of synchronization code errors, the CSI1/CCP2B receiver can reinitialize itself. No software intervention is required for most synchronization-code errors:

- Line-end shifted code: The receiver either removes the additional bits or adds dummy bits. The next LS synchronization code resynchronizes the state-machine to normal behavior. A shifted line-end (LE) synchronization code triggers an LE\_IRQ event.
- Frame-end shifted code: The receiver either removes the additional bits or adds dummy bits. The next FS synchronization code resynchronizes the state-machine to normal behavior. A shifted frame-end (FE) synchronization code triggers an FE\_IRQ event.
- False synchronization code: The current frame is lost. The receiver stops acquiring data, flushes its internal FIFO, and asserts the FSC\_IRQ event. The next FS synchronization code resynchronizes the state-machine to normal behavior.

#### 6.4.2.2.4.1.1 Camera ISP CSI1/CCP2B Frames

##### Structure

Figure 6-59 shows the generic (non-JPEG) description of a CSI1/CCP2B frame with synchronization codes. Each CSI1/CCP2B frame line is composed of a finite number of 32-bit words.

**Figure 6-59. Camera ISP CSI1/CCP2B Frame Structure: Non-JPEG Data Format**

camisp-195

The period between LEC and new is called the line-blanking period. The time between FEC and new FSC is called the frame-blanking period. The CSI1/CCP2B receiver works with line-blanking periods set to 0 or longer.

[Figure 6-60](#) shows CSI1/CCP2B frame structure for the JPEG8 case. The JPEG stream is composed of a finite number of 32-bit words. LSC and LEC synchronization codes are never used when the CSI1/CCP2B interface transports a JPEG bitstream; only FSC and FEC synchronization codes are used.

**Figure 6-60. Camera ISP CSI1/CCP2B Frame Structure: JPEG8 Data Format**

|     |                        |     |         |
|-----|------------------------|-----|---------|
| FSC | JPEG data (valid data) | FEC | CRC+pad |
|-----|------------------------|-----|---------|

camisp-196

### Data

A frame comprises embedded data and image-sensor data. [Figure 6-61](#) shows the location of embedded data and image-sensor data in the frame. The following definitions apply:

- 0 or more start-of-frame (SOF) status lines can be embedded at the beginning of a CSI1/CCP2B frame.
- Image data comprises pixels of the same data formats. It may contain visible or nonvisible pixels.
- 0 or more end-of-frame (EOF) status line(s) can be embedded at the end of a CSI1/CCP2B frame.
- SOF lines, pixel data, and EOF lines do not overlap.

The CSI1/CCP2B receiver does not use the information contained in the status lines. However, it extracts it and stores it in memory for use by the software. [Figure 6-61](#) shows the CSI1/CCP2B data structure.

**Figure 6-61. Camera ISP CSI1/CCP2B Data Structure**

camisp-197

#### Embedded information (SOF and EOF lines):

- Embedded information is never compressed (no DPCM).
- Embedded information covers full lines.
- Embedded information is not encoded in the same data format as pixel data. The CSI1/CCP2B receiver extracts embedded information, but does not modify the data format.
- False-synchronization-code protection is implemented; the receiver ensures that the embedded data contains no synchronization codes.

#### Pixel data:

- Pixel data can be compressed.
- Pixel data comprises pixels of the same data format.
- False-synchronization-code protection is implemented; the receiver ensures that the pixel data contains no synchronization codes.

#### 6.4.2.2.4.1.2 Camera ISP CSI1/CCP2B Logical Channels

##### Identification

The CCP2B protocol layer transports logical channels. The purpose of logical channels is to separate different data flows that are interleaved in the same data stream. Each logical channel is identified by a unique channel identification number.

The channel identification number is directly encoded in the 32-bit synchronization codes. Logical channels do apply to the MIPI CSI1 compatible mode; only one channel (channel 0) is used.

As shown in [Figure 6-57](#), the CCP2B receiver monitors the channel identification number and demultiplexes the interleaved data streams. The CCP2B receiver supports up to four concurrent logical channels.

The logical channel identifier is coded in the upper 4 bits (bits 4 to 7) of the last byte of the synchronization codes. [Table 6-23](#) summarizes the default logical channel values used for each channel. The CCP2B programming model allows these values to be overwritten.

**Table 6-23. Camera ISP CSI1/CCP2B Logical Channel Values in Synchronization Codes**

| Logical Channel   | Value |
|-------------------|-------|
| Logical channel 0 | 0x0   |
| Logical channel 1 | 0x1   |
| Logical channel 2 | 0x2   |
| Logical channel 3 | 0x3   |
| Logical channel 4 | 0x4   |
| Logical channel 5 | 0x5   |
| Logical channel 6 | 0x6   |
| Logical channel 7 | 0x7   |

### Muxing

The logical channels are interleaved at the line level or at the frame level. [Figure 6-62](#) shows the possible situations. Each logical channel can use different data formats.

**Figure 6-62. Camera ISP CSI1/CCP2B Muxing**

|         |                 |         |         |
|---------|-----------------|---------|---------|
| FSC_LC1 | Data log chan 1 | LEC_LC1 | CRC+pad |
| LSC_LC1 | Data log chan 1 | LEC_LC1 | CRC+pad |
| FSC_LC0 | Data log chan 0 | LEC_LC0 | CRC+pad |
| FSC_LC2 | Data log chan 2 | LEC_LC2 | CRC+pad |
| LSC_LC2 | Data log chan 2 | LEC_LC2 | CRC+pad |
| LSC_LC2 | Data log chan 2 | FEC_LC2 | CRC+pad |
| LSC_LC0 | Data log chan 0 | LEC_LC0 | CRC+pad |
| FSC_LC2 | Data log chan 2 | LEC_LC2 | CRC+pad |
| LSC_LC2 | Data log chan 2 | LEC_LC2 | CRC+pad |
| LSC_LC2 | Data log chan 2 | FEC_LC2 | CRC+pad |
| LSC_LC0 | Data log chan 0 | FEC_LC0 | CRC+pad |
| LSC_LC1 | Data log chan 1 | FEC_LC1 | CRC+pad |

camisp-198

#### 6.4.2.2.5 Camera ISP CSI1/CCP2B Memory Read Channel

The memory channel can perform the following operations:

- Reads data from memory. It is unpacked and DPCM decompressed if necessary.
- Can send the data to the Video processing hardware
- Can send the data back to memory. It can be DPCM compressed and packed before it is sent to memory.

It cannot receive its input data directly from the sensor, and the logical channels are disabled when the memory channel is enabled.

[Table 6-24](#) summarizes supported modes for memory-to-memory operations.

**Table 6-24. Camera ISP CSI1/CCP2B Memory-to-Memory Supported Operations**

| Memory Input          | Memory Output |             |             |                   |                 |                        |      |             |             |                   |                 |                        |      |             |        |              |        |              |        |
|-----------------------|---------------|-------------|-------------|-------------------|-----------------|------------------------|------|-------------|-------------|-------------------|-----------------|------------------------|------|-------------|--------|--------------|--------|--------------|--------|
|                       | RAW 6         | RAW6 +PAC K | RAW6 +DPC M | RAW6 +PAC K+DP CM | RAW6 +DPC M_AdV | RAW6 +PAC K+DP CM_A DV | RAW7 | RAW7 +PAC K | RAW7 +DPC M | RAW7 +PAC K+DP CM | RAW7 +DPC M_AdV | RAW7 +PAC K+DP CM_A DV | RAW8 | RAW8 +DPC M | RAW1 0 | RAW1 0+PAC K | RAW1 2 | RAW1 2+PAC K | RAW1 4 |
| RAW6                  |               |             |             |                   |                 |                        |      |             |             |                   |                 |                        |      |             |        |              |        |              |        |
| RAW6 +PACK            |               |             |             |                   |                 |                        |      |             |             |                   |                 |                        |      |             |        |              |        |              |        |
| RAW6 +DPCM            |               |             |             |                   |                 |                        |      |             |             |                   |                 |                        |      |             | X      | X            |        |              |        |
| RAW6 +PACK +DPCM      |               |             |             |                   |                 |                        |      |             |             |                   |                 |                        |      |             | X      | X            |        |              |        |
| RAW6 +DPCM -ADV       |               |             |             |                   |                 |                        |      |             |             |                   |                 |                        |      |             | X      | X            |        |              |        |
| RAW6 +PACK +DPMC -ADV |               |             |             |                   |                 |                        |      |             |             |                   |                 |                        |      |             | X      | X            |        |              |        |
| RAW7                  |               |             |             |                   |                 |                        |      |             |             |                   |                 |                        |      |             |        |              |        |              |        |
| RAW7 +PACK            |               |             |             |                   |                 |                        |      |             |             |                   |                 |                        |      |             |        |              |        |              |        |
| RAW7 +DPCM            |               |             |             |                   |                 |                        |      |             |             |                   |                 |                        |      |             | X      | X            |        |              |        |
| RAW7 +PACK +DPCM      |               |             |             |                   |                 |                        |      |             |             |                   |                 |                        |      |             | X      | X            |        |              |        |

**Table 6-24. Camera ISP CSI1/CCP2B Memory-to-Memory Supported Operations (continued)**

| Memory Input                      | Memory Output |             |             |                   |                 |      |             |             |                   |                 |      |             |        |              |        |              |        |        |  |
|-----------------------------------|---------------|-------------|-------------|-------------------|-----------------|------|-------------|-------------|-------------------|-----------------|------|-------------|--------|--------------|--------|--------------|--------|--------|--|
|                                   | RAW 6         | RAW6 +PAC K | RAW6 +DPC M | RAW6 +PAC K+DP CM | RAW6 +DPC M_AdV | RAW7 | RAW7 +PAC K | RAW7 +DPC M | RAW7 +PAC K+DP CM | RAW7 +DPC M_AdV | RAW8 | RAW8 +DPC M | RAW1 0 | RAW1 0+PAC K | RAW1 2 | RAW1 2+PAC K | RAW1 4 | RAW1 6 |  |
| RAW7 + DPCM<br>- ADV              |               |             |             |                   |                 |      |             |             |                   |                 |      |             | X      | X            |        |              |        |        |  |
| RAW7 +<br>PACK +<br>DPMC<br>- ADV |               |             |             |                   |                 |      |             |             |                   |                 |      |             | X      | X            |        |              |        |        |  |
| RAW8                              |               |             |             |                   |                 |      |             |             |                   |                 |      |             |        |              |        |              |        |        |  |
| RAW8 +<br>DPCM                    |               |             |             |                   |                 |      |             |             |                   |                 |      |             | X      | X            |        |              |        |        |  |
| RAW8 +<br>DPCM 12                 |               |             |             |                   |                 |      |             |             |                   |                 |      |             |        |              |        | X            | X      |        |  |
| RAW8 +<br>ALAW 10                 |               |             |             |                   |                 |      |             |             |                   |                 |      |             |        |              | X      | X            |        |        |  |
| RAW1 0                            |               |             | X           | X                 | X               | X    |             |             | X                 | X               | X    | X           |        | X            |        |              |        |        |  |
| RAW1 0 +<br>PACK                  |               |             | X           | X                 | X               | X    |             |             | X                 | X               | X    | X           |        | X            |        |              |        |        |  |

**Table 6-24. Camera ISP CSI1/CCP2B Memory-to-Memory Supported Operations (continued)**

| Memory Input  | Memory Output |             |             |                   |                 |      |             |             |                   |                 |      |                        |             |        |              |        |              |        |        |
|---------------|---------------|-------------|-------------|-------------------|-----------------|------|-------------|-------------|-------------------|-----------------|------|------------------------|-------------|--------|--------------|--------|--------------|--------|--------|
|               | RAW 6         | RAW6 +PAC K | RAW6 +DPC M | RAW6 +PAC K+DP CM | RAW6 +DPC M_AdV | RAW7 | RAW7 +PAC K | RAW7 +DPC M | RAW7 +PAC K+DP CM | RAW7 +DPC M_AdV | RAW8 | RAW8 +PAC K+DP CM_A DV | RAW8 +DPC M | RAW1 0 | RAW1 0+PAC K | RAW1 2 | RAW1 2+PAC K | RAW1 4 | RAW1 6 |
| RAW1 2        |               |             |             |                   |                 |      |             |             |                   |                 |      |                        |             |        |              |        |              |        |        |
| RAW1 2 + PACK |               |             |             |                   |                 |      |             |             |                   |                 |      |                        |             |        |              |        |              |        |        |
| RAW1 4        |               |             |             |                   |                 |      |             |             |                   |                 |      |                        |             |        |              |        |              |        |        |
| RAW1 6        |               |             |             |                   |                 |      |             |             |                   |                 |      |                        |             |        |              |        |              |        |        |

**NOTE:** Video processing hardware and memory destinations are mutually exclusive.

Table 6-25 summarizes supported modes for memory-to-video port operations.

**Table 6-25. Camera ISP CSI1/CCP2B Memory-to-Video Processing Hardware Supported Formats**

| Memory Input           | Video Port Output |      |      |       |       |       |       |
|------------------------|-------------------|------|------|-------|-------|-------|-------|
|                        | RAW6              | RAW7 | RAW8 | RAW10 | RAW12 | RAW14 | RAW16 |
| RAW6                   | x                 |      |      |       |       |       |       |
| RAW6 + PACK            | x                 |      |      |       |       |       |       |
| RAW6 + DPCM            |                   |      |      | x     |       |       |       |
| RAW6 + PACK + DPCM     |                   |      |      | x     |       |       |       |
| RAW6 + DPCM_ADV        |                   |      |      | x     |       |       |       |
| RAW6 + PACK + DPCM_ADV |                   |      |      | x     |       |       |       |
| RAW7                   |                   | x    |      |       |       |       |       |
| RAW7 + PACK            |                   | x    |      |       |       |       |       |
| RAW7 + DPCM            |                   |      |      | x     |       |       |       |
| RAW7 + PACK + DPCM     |                   |      |      | x     |       |       |       |
| RAW7 + DPCM_ADV        |                   |      |      | x     |       |       |       |

**Table 6-25. Camera ISP CSI1/CCP2B Memory-to-Video Processing Hardware Supported Formats (continued)**

| Memory Input           | Video Port Output |      |      |       |       |       |       |
|------------------------|-------------------|------|------|-------|-------|-------|-------|
|                        | RAW6              | RAW7 | RAW8 | RAW10 | RAW12 | RAW14 | RAW16 |
| RAW7 + PACK + DPCM_ADV |                   |      |      | X     |       |       |       |
| RAW8                   |                   |      | X    |       |       |       |       |
| RAW8 + DPCM            |                   |      |      | X     |       |       |       |
| RAW8 + DPCM12          |                   |      |      |       | X     |       |       |
| RAW8 + ALAW10          |                   |      |      | X     |       |       |       |
| RAW10                  |                   |      |      | X     |       |       |       |
| RAW10 + PACK           |                   |      |      | X     |       |       |       |
| RAW12                  |                   |      |      |       | X     |       |       |
| RAW12 + PACK           |                   |      |      |       | X     |       |       |
| RAW14                  |                   |      |      |       |       | X     |       |
| RAW16                  |                   |      |      |       |       |       | X     |

**NOTE:** The RAW6 and RAW7 data formats do not apply to the MIPI CSI1 compatible mode.

#### 6.4.2.2.5.1 Camera ISP CSI1/CCP2B Read Data From Memory

Figure 6-63 shows the data organization in memory.

**Figure 6-63. Camera ISP CSI1/CCP2B Data Organization in Memory**



The user chooses the start address and the line length using the [CCP2\\_LCM\\_SRC\\_ADDR](#) and [CCP2\\_LCM\\_SRC\\_OFST](#) registers. The image start address normally must point to the beginning of a line because of packing constraints. However it does not necessarily point to the first line of the frame in memory. The [CCP2\\_LCM\\_VSIZE](#) [27:16] COUNT bit field specifies the total line count to be read from memory.

It is also possible to skip a certain pixel count ([CCP2\\_LCM\\_HSIZE](#) [11:0] SKIP) from the start of the line. However, they are not sent to the video port or back to memory. The [CCP2\\_LCM\\_HSIZE](#) [27:16] COUNT bit field specifies the horizontal size of the image. The pixels after the right boundary of the image are not read from memory.

When data are sent to the video port, throughput is imposed by the selected video port clock. Otherwise, it is imposed by the selected interconnect read port clock. The interconnect read rate can be throttled (limiting the maximum data read speed for memory-to-memory operation) using the [CCP2\\_LCM\\_CTRL](#) [4:3] READ\_THROTTLE bit field. Therefore, it is possible to read the unused data at a higher rate than the used video port data rate. This provides better performance than framing the image in the Video processing hardware.

The data storage format in memory is defined by the [CCP2\\_LCM\\_CTRL](#) [18:16] SRC\_FORMAT, and [CCP2\\_LCM\\_CTRL](#) [23] SRC\_PACK registers.

Not all IO format combinations are valid. See [Table 6-24](#) and [Table 6-25](#) for more information.

Figure 6-64 shows how data are packed in memory. Pixel order (left to right in the image) is alphabetical (a,b,c). Therefore, data storage is little endian.

**Figure 6-64. Camera ISP CSI1/CCP2B Data Organization in Memory Continued**

camisp-206

**Table 6-26** summarizes the storage reduction and image width restrictions when data packing is used.

**Table 6-26. Camera ISP CSI1/CCP2B Data Packing Benefit and Constraints**

|       | Bits Per Pixel |          | Storage Reduction | Width Multiple <sup>(1)</sup> |
|-------|----------------|----------|-------------------|-------------------------------|
|       | Packed         | Unpacked |                   |                               |
| RAW6  | 6              | 8        | 25%               | 16                            |
| RAW7  | 7              | 8        | 13%               | 32                            |
| RAW8  | 8              | 8        | 0%                | 4                             |
| RAW10 | 10             | 16       | 38%               | 16                            |
| RAW12 | 12             | 16       | 25%               | 8                             |

<sup>(1)</sup> In continuous mode, lines must be multiples of 128 bits. In 2D mode, lines must start on 128-bit boundaries.

#### 6.4.2.2.5.2 Camera ISP CSI1/CCP2B Memory Read Port Burst Generation

The hardware always uses the largest possible burst size according to the setup. The amount of data read from memory can be higher than what is actually used by the CCP2B receiver. Only full 64-bit words are read. [Figure 6-65](#) shows the data organization in memory.

**Figure 6-65. Camera ISP CSI1/CCP2B Data Organization in Memory 3**

camisp-207

**NOTE:**

- A minimum burst size of 2 must be selected for correct operation.
- HWORDS must be paired for correct operation.

[Figure 6-64](#) shows the relationship between the different parameters controlling the burst generation. The

[CCP2\\_LCM\\_SRC\\_ADDR](#) register address of the first data to read is aligned to a 32-byte boundary. The read port fetches [CCP2\\_LCM\\_PREFETCH](#) [13:3] HWORDS of 64-bit words per line using the longest possible burst computed from the [CCP2\\_LCM\\_CTRL](#) [7:5] BURST register and the remaining data to be fetched. When the CCP2B receiver is configured to fetch more data than required, extra data are dropped internally.

#### 6.4.2.2.5.3 Camera ISP CSI1/CCP2B Video Port

The video port always receives unpacked data. It can be enabled using the [CCP2\\_LCM\\_CTRL](#) [2] DST\_PORT register. Its clock can be selected with the [CCP2\\_CTRL](#) [9:8] VP\_OUT\_CTRL register.

The data format used by the video port is defined by the [CCP2\\_LCM\\_CTRL](#) [26:24] DST\_FORMAT register. See [Table 6-25](#) for a list of supported modes.

#### 6.4.2.2.5.4 Camera ISP CSI1/CCP2B Encode, Pack, and Store Data

This stage is used only when data are sent to memory. Memory destination is selected using the [CCP2\\_LCM\\_CTRL](#) [2] DST\_PORT register. The output data format is defined by the [CCP2\\_LCM\\_CTRL](#) [26:24] DST\_FORMAT, and [CCP2\\_LCM\\_CTRL](#) [31] DST\_PACK registers. Not all possible combinations are supported. See [Table 6-24](#) for details.

The destination address and offset for the output data of the memory channel are set by the [CCP2\\_LCM\\_DST\\_ADDR](#) and [CCP2\\_LCM\\_DST\\_OFST](#) registers.

Because of alignment constraints on the interconnect port, the output image width restrictions in [Table 6-27](#) apply.

**Table 6-27. Camera ISP CSI1/CCP2B Output Width Restrictions in Memory-to-Memory Operation**

| Format     | Bits/pix | Width Multiple of <sup>(1)</sup> | Note                                                                                            |
|------------|----------|----------------------------------|-------------------------------------------------------------------------------------------------|
| RAW6       | 8        | 1                                | Full 32-bit words are written at the end of the line. This last word can eventually include 0s. |
| RAW6 PACK  | 6        | 1                                |                                                                                                 |
| RAW7       | 8        | 1                                |                                                                                                 |
| RAW7 PACK  | 7        | 1                                |                                                                                                 |
| RAW8       | 8        | 1                                |                                                                                                 |
| RAW10      | 16       | 1                                |                                                                                                 |
| RAW10 PACK | 10       | 16                               |                                                                                                 |
| RAW12      | 16       | 1                                | Same constraints as RAW8                                                                        |
| RAW12 PACK | 12       | 8                                |                                                                                                 |

<sup>(1)</sup> In continuous mode, lines must be multiples of 128 bits. In 2D mode, lines must start on 128-bit boundaries.

For example, when RAW6 packed data are written to memory, any output width is allowed. However, only full 32-bit words are written to memory. This eventually overwrites some data in memory at the end of a line.

The supported output width is restricted for packed RAW10 and RAW12 data because of the particular bit ordering in those formats (see [Figure 6-64](#)).

When the DST\_OFST is set to 0, start of lines will be aligned on 4-byte boundaries. When DST\_OFST != 0, data are aligned on 32-byte boundaries.

**NOTE:** The RAW6 and RAW7 data formats do not apply to the MIPI CSI1 compatible mode.

#### 6.4.2.2.6 Camera ISP CSI1/CCP2B Image Data Operating Modes and Alignment Constraints

The CCP2B receiver interface has several image-data operating modes, summarized in [Table 6-28](#). The EXPx formats ( $x = 8, 16$ , or  $32$ ) are used to expand data up to  $8, 16$ , or  $32$  bits by padding data with 0s. The Data Size Increase in the Memory column indicates memory overhead versus format without data expansion or/and DPCM compression.

**Table 6-28. Camera ISP CSI1/CCP2B Image Data Operating Modes and Alignment Constraints**

| CCP2_LCx_CT<br>RL[7:2] Format | CCP2 Data Format                                          | Bits per Pixel (bpp)<br>(when sending data<br>to memory, N/A<br>when sending to VP)        | Data Size Increase in<br>Memory<br>(when negative, data<br>compression<br>present) | 2D Mode Availability<br><sup>(1)</sup> | Comments           |
|-------------------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|----------------------------------------|--------------------|
| 0x0                           | YUV422 big endian                                         | 16                                                                                         | 0%                                                                                 | Yes                                    |                    |
| 0x1                           | YUV422 little endian                                      | 16                                                                                         | 0%                                                                                 | Yes                                    |                    |
| 0x2                           | YUV420                                                    | 12                                                                                         | 0%                                                                                 | Yes                                    |                    |
| 0x3                           | YUV422 + VP                                               | N/A, data are sent to<br>VP, YUV422 + VP =<br>RAW8 + VP                                    | N/A                                                                                | Yes                                    |                    |
| 0x3                           | RAW8 + VP                                                 | N/A, data are sent to<br>VP, YUV422 + VP<br>shall be used to output<br>RAW8 + VP to memory | N/A                                                                                | Yes                                    |                    |
| 0x4                           | RGB444 + EXP16                                            | 16                                                                                         | 50%                                                                                | Yes                                    |                    |
| 0x5                           | RGB565                                                    | 16                                                                                         | 0%                                                                                 | Yes                                    |                    |
| 0x6                           | RGB888                                                    | 24                                                                                         | 0%                                                                                 | Yes                                    |                    |
| 0x7                           | RGB888 + EXP32                                            | 32                                                                                         | 33%                                                                                | Yes                                    |                    |
| 0x8                           | RAW6 + EXP8                                               | 8                                                                                          | 33%                                                                                | Yes                                    |                    |
| 0x9                           | RAW6 + DPCM10 +<br>EXP16                                  | 16                                                                                         | 167%                                                                               | Yes                                    | DPCM decompression |
| 0xA                           | RAW6 + DPCM10 +<br>VP                                     | N/A, data are sent to<br>VP                                                                | N/A                                                                                | Yes                                    | DPCM decompression |
| 0xB                           | RAW10 - RAW6<br>DPCM                                      | 6                                                                                          | -40%                                                                               | Yes                                    | DPCM compression   |
| 0xC                           | RAW7 + EXP8                                               | 8                                                                                          | 14%                                                                                | Yes                                    |                    |
| 0xD                           | RAW7 + DPCM10 +<br>EXP16                                  | 16                                                                                         | 128%                                                                               | Yes                                    | DPCM decompression |
| 0xE                           | RAW7 + DPCM10 +<br>VP                                     | N/A, data are sent to<br>VP                                                                | N/A                                                                                | Yes                                    | DPCM decompression |
| 0xF                           | RAW10 - RAW6<br>DPCM + EXP8                               | 8                                                                                          | -25%                                                                               | Yes                                    | DPCM compression   |
| 0x10                          | RAW8, this mode can<br>be used to output<br>RAW6 and RAW7 | 8                                                                                          | 0%                                                                                 | Yes                                    |                    |
| 0x11                          | RAW8 + DPCM10 +<br>EXP16                                  | 16                                                                                         | 100%                                                                               | Yes                                    | DPCM decompression |
| 0x12                          | RAW8 + DPCM10 +<br>VP                                     | N/A, data are sent to<br>VP                                                                | N/A                                                                                | Yes                                    | DPCM decompression |
| 0x13                          | RAW10 - RAW7<br>DPCM                                      | 7                                                                                          | -30%                                                                               | Yes                                    | DPCM compression   |
| 0x14                          | RAW10                                                     | 10                                                                                         | 0%                                                                                 | Yes                                    |                    |
| 0x15                          | RAW10 + EXP16                                             | 16                                                                                         | 60%                                                                                | Yes                                    |                    |
| 0x16                          | RAW10 + VP                                                | N/A, data are sent to<br>VP                                                                | N/A                                                                                | Yes                                    |                    |
| 0x17                          | RAW10 - RAW7<br>DPCM + EXP8                               | 8                                                                                          | -20%                                                                               | Yes                                    |                    |
| 0x18                          | RAW12                                                     | 12                                                                                         | 0%                                                                                 | Yes                                    |                    |

<sup>(1)</sup> If 2D mode is available, there are no supplementary constraints on data width. 2D mode is not applicable when sending to video port (VP).

**Table 6-28. Camera ISP CSI1/CCP2B Image Data Operating Modes and Alignment Constraints  
(continued)**

| <b>CCP2_LCx_CTRL[7:2] Format</b> | <b>CCP2 Data Format</b> | <b>Bits per Pixel (bpp)<br/>(when sending data to memory, N/A when sending to VP)</b> | <b>Data Size Increase in Memory<br/>(when negative, data compression present)</b> | <b>2D Mode Availability<br/><small>(1)</small></b> | <b>Comments</b>    |
|----------------------------------|-------------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------------------------------------------------|--------------------|
| 0x19                             | RAW12 + EXP16           | 16                                                                                    | 33%                                                                               | Yes                                                |                    |
| 0x1A                             | RAW12 + VP              | N/A, data are sent to VP                                                              | N/A                                                                               | Yes                                                |                    |
| 0x1B                             | RAW10 - RAW8 DPCM       | 8                                                                                     | -20%                                                                              | Yes                                                | DPCM decompression |
| 0x1C                             | JPEG, 8-bit data        | N/A                                                                                   | 0%                                                                                | Yes                                                |                    |
| 0x1D                             | JPEG, 8-bit data + FSP  | N/A                                                                                   | 0%                                                                                | Yes                                                |                    |
| 0x1E                             | RAW10 - RAW8 DPCM       | 8                                                                                     | -20%                                                                              | Yes                                                | Data right shift   |
| 0x1F                             | RAW8 DPCM12-RAW12 + VP  | N/A, data are sent to VP                                                              | N/A                                                                               | Yes                                                |                    |
| 0x20                             | RAW10 - RAW8 ALAW       | 8                                                                                     | -20%                                                                              | Yes                                                |                    |
| 0x21                             | RAW8 DPCM10 - ALAW      | 8                                                                                     | -20%                                                                              | Yes                                                |                    |

---

**NOTE:**

- Padding data of a 32 bit pixel data stream is handled the same way regardless of the programmed format. Therefore, no storage increase/decrease because it is not compressed/decompressed.
  - EXP8 = Data expansion to 8 bits, padding with zeros
  - EXP16 = Data expansion to 16 bits, padding with alpha or zeros  
`CCP2_LCx_CTRL[15:8]` ALPHA can be used to set an alpha value.  
 For RGB444 + EXP16:
    - `data_out[31:28] = ALPHA [3:0]`
    - `data_out[15:12] = ALPHA [3:0]`
  - EXP32 = Data expansion to 32 bits, padding with alpha  
`CCP2_LCx_CTRL[15:8]` ALPHA can be used to set an alpha value.  
 For RGB888 + EXP32: `data_out [31:24] = ALPHA [7:0]`
  - FSP = False synchronization code protection decoding. Applies only to JPEG8 data format.
  - VP = Output to the video-preprocessing hardware is enabled. The programmer must ensure that only one logical channel is enabled to the video preprocessing hardware. The behavior of the hardware is unpredictable if several logical channels to the video preprocessing hardware are enabled simultaneously.
  - DPCM10 = Data decompression to 10 bits. Only applies to the RAW6, RAW7 and RAW8 data formats. Disabled if `CCP2_CTRL[4]` MODE = 0.
  - Padding is handled the same way regardless of the programmed format.
-

### 6.4.3 Camera ISP CSI2 Receiver

---

**NOTE:** There are two CSI2 receivers in the ISP with same functionality. For reading ease, the following section applies to both CSI2A and CSI2C receivers.

---

#### 6.4.3.1 Camera ISP CSI2 Receiver Features

The CSI2 receiver module is a master on the L3 interconnect for storing data in memory and a slave on the L4 interconnect for register access.

The main features of the CSI2 receiver module are:

- Transfer pixels and data received by the PHY to the system memory
- Unidirectional data link
- Minimum of one and maximum of two configurable data links in addition to clock signaling
- Maximum data rate of 1000 Mbps per data pair
- Data merger for 2-data lane configuration
- Error detection and correction by the protocol engine
- DMA engine integrated with dedicated FIFO
- Streaming 1D and 2D addressing modes
- Up to eight contexts to support eight dedicated configurations of virtual channel ID and data types
- Ping-pong mechanism for double-buffering
- JPEG support for unknown length transfer (no extraction of the thumbnail)
- All primary and secondary MIPI-defined formats are supported (RGB, RAW, and YUV)
- Storage in progressive mode for interlaced stream (using line numbering)
- Conversion of the RGB formats
- Decompression of the RAW formats
- RAW frame transcoding. Including DPCM and A-law compression
- Configuration of PHY
- Fully configurable interface of the PHY: position of the clock and data and order of  $\pm$  differential signals for each pair
- Support of DPCM decompression

#### 6.4.3.2 Camera ISP CSI2 Receiver Block Diagram

Figure 6-66 is the block diagram of the CSI2 receiver connected to the PHY.

**Figure 6-66. Camera ISP CSI2 Receiver Block Diagram**



camisp-238

#### 6.4.3.3 Camera ISP CSI2 Physical Layer Lane Configuration

The CSI2 serial interface is a unidirectional differential serial interface with data/clock for the physical layer. The CSI2 PHY is based on the MIPI DPHY Specification version 1.0.

The maximum CSI2 receiver data transfer capacity is 1000 Mbps per data lane.

Data-clock signaling consists of four to six signals: one or two data lanes and one clock lane:

- The data signal carries the bit-serial data. The CSI2 transmitter in the image sensor sends the data in-quadrature with the DDR clock in HS mode; otherwise, the clock is extracted from the received data in LS mode. Data is transmitted byte-wise, LSB first. The CSI2 PHY receives the data and sends the byte stream to the CSI2 receiver.
- The clock signal carries the DDR clock signal.

Each physical lane can be a data or a clock lane. The clock/data lane must be configured before transmission to indicate the byte order while merging the received bytes into a byte stream.

Lanes are configured through the [CSI2\\_COMPLEXIO\\_CFG1](#) register for the associated and configured to the receiver PHY. The CLOCK\_POSITION and CLOCK\_POL fields configure which lane transmits the clock and define its polarity.

---

**NOTE:** If the parallel camera sensor and other camera sensor (CCP2 or CSI2) are connected to the same CSIPHY, the CONTROL\_CAMERAx\_PHY\_CAMMOD bit must be set for CCP2 or CSI2 mode, respectively, (even if only one pair is used as GPI for CPI mode). In that case, the corresponding [CSI2\\_COMPLEXIO\\_CFG1](#).DATAx\_POSITION bit must be set to 0x0 for the lane used in GPI mode.

---

The [CSI2\\_COMPLEXIO\\_CFG1](#) register also contain a bit field affecting PHY power management.

For information about initializing the CSIPHY associated with CSI2, see [Section 6.5.2.2, Camera ISP CSIPHY Initialization for Work With CSI2 Receiver](#).

#### 6.4.3.4 Camera ISP CSI2 ECC and Checksum Generation

The CSI2 receiver includes an ECC in the packet header and a checksum in the packet footer for long-packet transmission. These two fields can be used to detect and/or correct errors in the received packet.

#### 6.4.3.4.1 Camera ISP CSI2 ECC

To detect and correct transmission errors of the header of short and long packets, an 8-bit ECC is included in the header of packets (short and long packet).

The ECC concerns all the fields for a short packet (data ID and short-packet data field) and the packet header for long packet (data ID and word count). The ECC can only correct one error. Additional errors cannot be repaired, but they are flagged.

The CSI2 receiver ECC is compared against the CSI2 transmitter ECC embedded in the bit stream. If the ECC does not match, an interrupt is triggered to the host CPU.

For both long and short packets, the correction is always done if there is only one error per packet.

An ECC error with or without correction can be reported at two levels, depending on the type of packet.

[Table 6-29](#) describes the field where events are logged. Logging cannot be disabled, but users can set the corresponding bit in the [CSI2\\_IRQENABLE](#) and [CSI2\\_CTX\\_IRQENABLE](#) registers to prevent event generation at a higher level.

**Table 6-29. Camera ISP CSI2 ECC Event Logging**

|                    | Short Packet                                                          | Long Packet                                                            |
|--------------------|-----------------------------------------------------------------------|------------------------------------------------------------------------|
| With correction    | Global<br><a href="#">CSI2_IRQSTATUS[12]</a> ECC_CORRECTION_IRQ       | Context<br><a href="#">CSI2_CTX_IRQSTATUS[8]</a><br>ECC_CORRECTION_IRQ |
| Without correction | Global<br><a href="#">CSI2_IRQSTATUS[11]</a><br>ECC_NO_CORRECTION_IRQ | Global<br><a href="#">CSI2_IRQSTATUS[11]</a><br>ECC_NO_CORRECTION_IRQ  |

The ECC check can be disabled (short and long packet) by writing 0 in the [CSI2\\_CTRL\[2\]](#) ECC\_EN bit field. Writing 1 enables the ECC check.

#### 6.4.3.4.2 Camera ISP CSI2 Checksum

To detect errors in transmission of the payload of long packets, a 16-bit CRC checksum is computed on the payload of the long packets in the transmitter. This CRC is stored in the packet footer. A CRC is also computed in the CSI2 receiver. If the checksums do not match, an event is triggered to the host CPU.

CRC errors are logged in the CS IRQ field of the corresponding context register, [CSI2\\_CTX\\_IRQSTATUS](#). Logging cannot be disabled, but users can set the corresponding bit in the [CSI2\\_CTX\\_IRQENABLE](#) register to prevent event generation at a higher level.

The CRC check can be disabled for a specific context by writing 0 in the [CSI2\\_CTX\\_CTRL1\[5\]](#) CS\_EN bit. Writing 1 enables the CRC check.

#### 6.4.3.5 Camera ISP CSI2 RAW Image Transcoding with DPCM and A-law Compression

The CSI2 receiver has a functionality to have an image in raw format transcoded. Transcoding is mainly used to reduce memory footprint and bandwidth when:

- The sensor does not support DPCM compression. So by transcoding A-law and DPCM compressed pixels only occupy 6, 7 or 8-bits/pixel of storage.
- Digital zoom is used. In fact:
  - Data that is not going to be used by further processing does not need to be stored in system memory.
  - Pixels cannot be accessed from random locations in a DPCM compressed frame. Therefore, transcoding avoids memory to memory processing of unused pixels.

[Figure 6-67](#) shows the logical representation of the image transcoding operation. Basically, the steps are as follow:

- Data is extracted from the CSI2 stream

- It is DPCM decompressed if necessary. That's the case when the received stream is DPCM compressed and transcoding has been enabled using the [CSI2\\_CTx\\_CTRL1\[27:24\]](#) TRANSCODE register.
- Data send to the video port cannot be compressed: it is intended to be processed by an HW ISP. Data send to system memory could be optionally compressed.
- Internal data is aligned on MSB when the enter the cropping stage:
  - 4 LSBs are 0s when RAW10 data is handled
  - 2 LSBs are 0s when RAW12 data is handled
  - etc...

**Figure 6-67. Camera ISP CSI2 RAW Image Transcoding Diagram**



[Table 6-30](#) shows the input format provided to the cropping engine for a given pixel format provided by the sensor. Formats not listed in the following table are not supported for transcoding.

**Table 6-30. Camera ISP Pixel Format Modes**

| <a href="#">CSI2_CTx_CTRL2<br/>[9:0]</a> Format | CSI2 Data Format                            | Cropping Engine Input | DPCM Decomp Enabled | Video Port Enabled |
|-------------------------------------------------|---------------------------------------------|-----------------------|---------------------|--------------------|
| 0x028                                           | RAW6                                        | RAW6                  |                     |                    |
| 0x068                                           | RAW6 + EXP8                                 |                       |                     |                    |
| 0x029                                           | RAW7                                        | RAW7                  |                     |                    |
| 0x069                                           | RAW7 + EXP8                                 |                       |                     |                    |
| 0x02A                                           | RAW8                                        | RAW8                  |                     |                    |
| 0x12A                                           | RAW8 + VP                                   |                       |                     | Yes                |
| 0x02B                                           | RAW10                                       | RAW10                 |                     |                    |
| 0x0AB                                           | RAW10 + EXP16                               |                       |                     |                    |
| 0x0E8                                           | RAW6 + DPCM10 + VP                          |                       | Yes                 | Yes                |
| 0x12F                                           | RAW10 + VP                                  |                       |                     | Yes                |
| 0x229                                           | RAW7 + DPCM10 + EXP16                       |                       | Yes                 |                    |
| 0x2A8                                           | RAW6 + DPCM10 + EXP16                       |                       | Yes                 |                    |
| 0x2AA                                           | RAW8 + DPCM10 + EXP16                       |                       | Yes                 |                    |
| 0x329                                           | RAW7 + DPCM10 + VP                          |                       | Yes                 | Yes                |
| 0x32A                                           | RAW8 + DPCM10 + VP                          |                       | Yes                 | Yes                |
| 0x2Cn                                           | USER_DEFINED_BYTEDI<br>ATA + DPCM10 + EXP16 |                       | Yes                 |                    |
| 0x34n                                           | USER_DEFINED_BYTEDI<br>ATA + DPCM10 + VP    |                       | Yes                 | Yes                |

**Table 6-30. Camera ISP Pixel Format Modes (continued)**

| <b>CSI2_CTX_CTRL2 [9:0] Format</b> | <b>CSI2 Data Format</b>                 | <b>Cropping Engine Input</b> | <b>DPCM Decomp Enabled</b> | <b>Video Port Enabled</b> |
|------------------------------------|-----------------------------------------|------------------------------|----------------------------|---------------------------|
| 0x02C                              | RAW12                                   | RAW12                        |                            |                           |
| 0x0AC                              | RAW12 + EXP16                           |                              |                            |                           |
| 0x12C                              | RAW12 + VP                              |                              |                            |                           |
| 0x36A                              | RAW8 + DPCM12 + EXP16                   |                              | Yes                        |                           |
| 0x3AA                              | RAW8 + DPCM12 + VP                      |                              | Yes                        | Yes                       |
| 0x1Cn                              | USER_DEFINED_BYTEDIATA + DPCM12 + EXP16 |                              | Yes                        |                           |
| 0x14n                              | USER_DEFINED_BYTEDIATA + DPCM12 + VP    |                              | Yes                        |                           |
| 0x3A8                              | RAW6 + DPCM12 + EXP16                   |                              | Yes                        |                           |
| 0x368                              | RAW6 + DPCM12 + VP                      |                              | Yes                        | Yes                       |
| 0x369                              | RAW7 + DPCM12 + EXP16                   |                              | Yes                        |                           |
| 0x3A9                              | RAW7 + DPCM12 + VP                      |                              | Yes                        | Yes                       |
| 0x02D                              | RAW14                                   | RAW14                        |                            |                           |
| 0x0AD                              | RAW14 + EXP16                           |                              |                            |                           |
| 0x12D                              | RAW14 + VP                              |                              |                            | Yes                       |

Image cropping parameters are controlled by software. [Figure 6-68](#) provides a graphical representation of the cropping operation.

**Figure 6-68. Camera ISP CSI2 Frame Cropping**

**NOTE:** Hardware does not check for validity of the settings. The following rules must be respected:

- [CSI2\\_CTX\\_TRANSCODEH\[12:0\]](#) HSKIP+ [CSI2\\_CTX\\_TRANSCODEH\[28:16\]](#) HCOUNT = image width
- [CSI2\\_CTX\\_TRANSCODEV\[12:0\]](#) VSKIP+ [CSI2\\_CTX\\_TRANSCODEV\[28:16\]](#) VCOUNT = image height

Furthermore, [CSI2\\_CTX\\_TRANSCODEV\[28:16\]](#) HCOUNT must comply with the following alignment constraints. Undefined behavior occurs otherwise. [Table 6-31](#) shows the ranscode alignment constraints

**Table 6-31. Camera ISP CSI2 Transcode Alignment Constraints**

| <b>CSI2_CTx_CTRL[27:24]</b><br><b>] TRANSCODE value</b> | <b>Transcode</b> | <b>HCOUNT must be multiple of</b> |
|---------------------------------------------------------|------------------|-----------------------------------|
| 0x0                                                     | Disabled         | 1                                 |
| 0x1                                                     | DPCM10 RAW8      | 1                                 |
| 0x2                                                     | DPCM12 RAW8      | 1                                 |
| 0x3                                                     | ALAW10 RAW8      | 1                                 |
| 0x4                                                     | RAW8             | 1                                 |
| 0x5                                                     | RAW10 + EXP16    | 1                                 |
| 0x6                                                     | RAW10            | 4                                 |
| 0x7                                                     | RAW12 + EXP16    | 1                                 |
| 0x8                                                     | RAW12            | 2                                 |
| 0x9                                                     | RAW10 + EXP16    | 4                                 |

**Table 6-32** shows the possible combinations between input and output formats supported by the transcoding engine. The Transcode column corresponds to the [CSI2\\_CTx\\_CTRL1\[27:24\]](#) TRANSCODE register of a context.

**Table 6-32. Camera ISP CSI2 Supported Transcoding Output Formats**

| <b>Cropping<br/>Engine<br/>Output</b> | <b>Transcode</b> |               | <b>Supported</b> | <b>Cropping<br/>Engine<br/>Output</b> | <b>Transcode</b> |               | <b>Supported</b> |
|---------------------------------------|------------------|---------------|------------------|---------------------------------------|------------------|---------------|------------------|
| RAW6                                  | 0                | Disabled      | Yes              | RAW10                                 | 0                | Disabled      | Yes              |
|                                       | 1                | DPCM10 RAW8   |                  |                                       | 1                | DPCM10 RAW8   | Yes              |
|                                       | 2                | DPCM12 RAW8   |                  |                                       | 2                | DPCM12 RAW8   |                  |
|                                       | 3                | ALAW10 RAW8   |                  |                                       | 3                | ALAW10 RAW8   | Yes              |
|                                       | 4                | RAW8          |                  |                                       | 4                | RAW8          |                  |
|                                       | 5                | RAW10 + EXP16 |                  |                                       | 5                | RAW10 + EXP16 | Yes              |
|                                       | 6                | RAW10         |                  |                                       | 6                | RAW10         | Yes              |
|                                       | 7                | RAW12 + EXP16 |                  |                                       | 7                | RAW12 + EXP16 |                  |
|                                       | 8                | RAW12         |                  |                                       | 8                | RAW12         |                  |
|                                       | 9                | RAW14         |                  |                                       | 9                | RAW14         |                  |
| RAW7                                  | 0                | Disabled      | Yes              | RAW12                                 | 0                | Disabled      | Yes              |
|                                       | 1                | DPCM10 RAW8   |                  |                                       | 1                | DPCM10 RAW8   |                  |
|                                       | 2                | DPCM12 RAW8   |                  |                                       | 2                | DPCM12 RAW8   | Yes              |
|                                       | 3                | ALAW10 RAW8   |                  |                                       | 3                | ALAW10 RAW8   |                  |
|                                       | 4                | RAW8          |                  |                                       | 4                | RAW8          |                  |
|                                       | 5                | RAW10 + EXP16 |                  |                                       | 5                | RAW10 + EXP16 |                  |
|                                       | 6                | RAW10         |                  |                                       | 6                | RAW10         |                  |
|                                       | 7                | RAW12 + EXP16 |                  |                                       | 7                | RAW12 + EXP16 | Yes              |
|                                       | 8                | RAW12         |                  |                                       | 8                | RAW12         | Yes              |
|                                       | 9                | RAW14         |                  |                                       | 9                | RAW14         |                  |
| RAW8                                  | 0                | Disabled      | Yes              | RAW14                                 | 0                | Disabled      | Yes              |
|                                       | 1                | DPCM10 RAW8   |                  |                                       | 1                | DPCM10 RAW8   |                  |
|                                       | 2                | DPCM12 RAW8   |                  |                                       | 2                | DPCM12 RAW8   |                  |
|                                       | 3                | ALAW10 RAW8   |                  |                                       | 3                | ALAW10 RAW8   |                  |
|                                       | 4                | RAW8          | Yes              |                                       | 4                | RAW8          |                  |
|                                       | 5                | RAW10 + EXP16 |                  |                                       | 5                | RAW10 + EXP16 |                  |
|                                       | 6                | RAW10         |                  |                                       | 6                | RAW10         |                  |
|                                       | 7                | RAW12 + EXP16 |                  |                                       | 7                | RAW12 + EXP16 |                  |
|                                       | 8                | RAW12         |                  |                                       | 8                | RAW12         |                  |

**Table 6-32. Camera ISP CSI2 Supported Transcoding Output Formats (continued)**

| Cropping Engine Output | Transcode | Supported | Cropping Engine Output | Transcode | Supported |
|------------------------|-----------|-----------|------------------------|-----------|-----------|
| 9                      | RAW14     |           |                        | 9         | RAW14     |

For RAW10 and RAW12, Software could choose among packed and non packed storage. A-law and DPCM compressed pixels are stored as RAW8 data: each RAW8 container holds a compressed data point. Similarly, RAW data is send over the video port . Enabling of the OCP / video port is controlled as usual by the [CSI2\\_CTX\\_CTRL2\[9:0\]](#) FORMAT and [CSI2\\_CTRL\[11\]](#) VP\_ONLY\_EN and [CSI2\\_CTX\\_CTRL1\[2\]](#) VPFORCE registers.

In order to enable transcoding, The software configures the context normally and in addition, configures the framing using the [CSI2\\_CTX\\_TRANSCODEV](#) and [CSI2\\_CTX\\_TRANSCODEH](#) registers. The software defines the after transcoding with the [CSI2\\_CTX\\_CTRL1\[27:24\]](#) TRANSCODE register.

#### 6.4.3.6 Camera ISP CSI2 Short Packet

There are two types of short packets in the CSI2 receiver:

- Synchronization short packet: Used by the protocol engine to synchronize frame and line (data ID from 0x0 to 0x7)
- Generic short packet: User-dependent; not treated by the protocol engine (data ID from 0x8 to 0xF)

When a generic short packet is received by the CSI2 receiver, the ECC check is performed if it is enabled (see [Section 6.4.3.4.1, ECC](#)). Then, the short packet is written in the [CSI2\\_SHORT\\_PACKET\[23:0\]](#) SHORT\_PACKET bit field. The ECC field is deleted from the short packet. [Figure 6-69](#) shows the SHORT\_PACKET field format.

**Figure 6-69. Camera ISP CSI2 SHORT\_PACKET Field Format**

An event is logged when a short packet is stored in the SHORT\_PACKET\_IRQ bit in the [CSI2\\_IRQSTATUS\[13\]](#) register. Logging cannot be disabled, but users can set the corresponding bit in the [CSI2\\_IRQENABLE](#) register to prevent event generation at a higher level.

The application reads the [CSI2\\_SHORT\\_PACKET](#) register before the next short packet with a code between 0x8 and 0xF. There is a single register for capturing the generic short packet, because no data type in it is associated with context.

#### 6.4.3.7 Camera ISP CSI2 Virtual Channel and Context

The CSI2 protocol layer transports virtual channels. The purpose of virtual channels is to separate different data flows interleaved in the same data stream. Each virtual channel is identified by a unique channel identification number in the packet header. This channel identification number is encoded in the 2-bit code.

The CSI2 receiver monitors the channel identifier number and demultiplexes the interleaved data streams. The CSI2 receiver supports up to four concurrent virtual channels.

The CSI2 receiver supports eight contexts to control the four possible virtual channels and the different data transmitted through them. A context is linked to a specific data type transported by a given virtual channel. The following two bit fields permit configuration of a context:

- [CSI2\\_CTX\\_CTRL2\[12:11\]](#) VIRTUAL\_ID: Configures the virtual ID linked to the current context
- [CSI2\\_CTX\\_CTRL2\[9:0\]](#) FORMAT: Configures the data format linked to the current context

[Figure 6-70](#) shows the relationships between virtual channels and contexts.

**Figure 6-70. Camera ISP CSI2 Virtual Channel to Context**

Each context consists of eight registers: six registers to control the corresponding context and two to log and enable events from the context. All registers in a context can be modified at any time; however, modifications apply only from the start of the following frame.

A context can be enabled independently by writing 1 in the [CSI2\\_CTX\\_CTRL1\[0\]](#) CTX\_EN bit field; writing 0 disables the corresponding context.

When acquiring frames on a context, users can write the number of frames to capture in the [CSI2\\_CTX\\_CTRL1\[15:8\]](#) COUNT bit field. Acceptable values are 0:255; 0 stands for infinite capture (no count). After each frame acquired, the count value is decremented by 1. When the count value reaches 0, the [CSI2\\_CTX\\_IRQSTATUS\[6\]](#) FRAME\_NUMBER\_IRQ event is set and the CTX\_EN bit is set to 0. To write a value in the COUNT bit field, the [CSI2\\_CTX\\_CTRL1\[4\]](#) COUNT\_UNLOCK bit must be set to 1. If the COUNT\_UNLOCK value is 0, a write in the COUNT bit field has no effect.

The [CSI2\\_CTX\\_CTRL3\[15:0\]](#) LINE\_NUMBER bit field configures the generation of the [CSI2\\_CTX\\_IRQSTATUS\[7\]](#) LINE\_NUMBER\_IRQ event. The [CSI2\\_CTX\\_CTRL1\[1\]](#) LINE\_MODULO bit configures how the LINE\_NUMBER event is generated:

- 0: The event is generated one time by frame.
- 1: The event is generated modulo LINE\_NUMBER (the event can be generated more than once in a frame).

During a frame capture, the [CSI2\\_CTX\\_CTRL2\[31:16\]](#) FRAME\_NUMBER bit field shows the number that identifies the frame received.

#### 6.4.3.8 Camera ISP CSI2 DMA Engine

The CSI2 receiver integrates its own DMA engine with dedicated FIFO.

Global DMA configuration (single access, non-streaming and posted writes) is common to the eight channels and is defined in the [CSI2\\_CTRL](#) register. Configuration of the ping-pong address and the offset between lines is specific for a given context; therefore, each context has its own DMA configuration registers.

The DMA engine supports the following requests:

- Single write

When an element (the size depends on the data type) is present in the FIFO, the DMA engine initiates a single write.

All single requests sent to the interconnect are back-to-back requests with no idle, if the FIFO has enough data to supply the DMA.

The DMA starts to write in memory using the [CSI2\\_CTX\\_DAT\\_PING\\_ADDR\[31:5\]](#) ADDR bit field for the first frame to be transferred and then uses the [CSI2\\_CTX\\_DAT\\_PONG\\_ADDR\[31:5\]](#) ADDR bit field and the ping address alternately. So, the first frame uses the ping address, the second frame uses the pong address, the third frame uses the ping address, and so on.

The **CSI2\_CTx\_CTRL1[3]** PING\_PONG status bit indicates whether the ping address (**CSI2\_CTx\_DAT\_PING\_ADDR**) or the pong address (**CSI2\_CTx\_DAT\_PONG\_ADDR**) was used to store the pixel data of the last frame. After reset or after a 0-to-1 edge transition in the **CSI2\_CTRL[0]** IF\_EN register, the pixel data is written in the ping buffer and **CSI2\_CTx\_CTRL1[3]** PING\_PONG = PONG. When the number of FECs received equals the value programmed in the **CSI2\_CTx\_CTRL1[23:16]** FEC\_NUMBER bit field, the pixel data are written in the pong buffer and **CSI2\_CTx\_CTRL1[3]** PING\_PONG = PING. **CSI2\_CTx\_CTRL1[3]** PING\_PONG toggles after the **CSI2\_CTx\_CTRL1[23:16]** FEC\_NUMBER FEC sync code with the virtual channel ID defined is received in the **CSI2\_CTx\_CTRL2[12:11]** VIRTUAL\_ID bit field.

The **CSI2\_CTx\_CTRL1[23:16]** FEC\_NUMBER bit field must be set as follows:

- In progressive mode, set to 1.
- In interlaced mode, set to the number of interlaced frames to recreate a progressive image in the PING\_PONG buffer.

#### **6.4.3.8.1 Camera ISP CSI2 Progressive Frame to Progressive Storage**

After each line, a new start line address is computed, depending on the value of the **CSI2\_CTx\_DAT\_OFST[15:5]** OFST bit field:

- If OFST = 0, the new line starts immediately after the last pixel (data are written contiguously in memory).
- Otherwise, the OFST value sets the offset between the first pixel of the previous line and the first pixel of the current line in memory.

For the ping frame:

```
@Line0 = CSI2_CTx_DAT_PING_ADDR @Line1 = @Line0 + CSI2_CTx_DAT_OFST
@Line2 = @Line1 + CSI2_CTx_DAT_OFST
```

For the pong frame:

```
@Line0 = CSI2_CTx_DAT_PONG_ADDR @Line1 = @Line0 + CSI2_CTx_DAT_OFST
@Line2 = @Line1 + CSI2_CTx_DAT_OFST
```

#### **6.4.3.8.2 Camera ISP CSI2 Interlaced Frame to Progressive Storage**

The mode is functional only when the line numbers are transmitted. It is automatically enabled without setting.

For the ping frame:

```
@LineX = CSI2_CTx_DAT_PING_ADDR + CSI2_CTx_DAT_OFST * Line_Number
```

For the pong frame:

```
@LineX = CSI2_CTx_DAT_PONG_ADDR + CSI2_CTx_DAT_OFST * Line_Number
```

[Figure 6-71](#) shows how data are stored in memory regarding DMA configuration.

**Figure 6-71. Camera ISP CSI2 Pixel Data Destination Setting in Progressive and Interlaced Mode**

#### 6.4.3.9 Camera ISP CSI2 PHYs

The two PHYs in the device act as the interface between the transmitter (camera sensor) and the receivers inside the camera ISP. The modules transform the bit stream divided into one or two serial data lanes into a bit stream compatible with the CSI2 receiver and one clock lane. The two CSIPHY1 and CSIPHY2 have identical functionality, only difference is that CSIPHY1 is limited to one data line. Figure 6-72 shows the CSIPHY overview diagram.

**Figure 6-72. Camera ISP CSI2 PHY Overview**

The **CSI2\_COMPLEXIO1\_IRQSTATUS** register logs the CSIPHY event. The events that occur are:

- Line power state change (all lanes in ULPM, at least one lane exits ULPM, etc.)
- Error on one lane

---

**NOTE:** For information about initializing the CSIPHY associated with CSI2, see [Section 6.5.2.2, Camera ISP CSIPHY Initialization for Work With CSI2 Receiver](#).

---

Both CSI2A and CSI2C receivers embed a registers to configure/read some PHY parameters:

- The **CSI2\_COMPLEXIO\_CFG1** register reports completion of reset on the different parts of the module and configures timing parameters.

The CSIPHYs have three power modes: on, off, and ULP (ultra-low power). These modes can reflect the ON or ULP power state of the three differential lines if the [CSI2\\_COMPLEXIO\\_CFG1\[24\]](#) PWR\_AUTO bit is set to 1. If the PWR\_AUTO bit is at reset value (0), the PHY power state is controlled by the [CSI2\\_COMPLEXIO\\_CFG1\[28:27\]](#) PWR\_CMD bit field, which directly defines the power state. [Figure 6-73](#) shows the PHY power finite state machine (FSM).

**Figure 6-73. Camera ISP CSIPHY Power FSM**



camisp-253

Another register, [CSI2\\_TIMING](#), is used to control the power state of the CSIPHY module with regards to the differential line state. This register is used to control the mode of the CSIPHY (RxMode or NoRxMode) and the delay between all the differential lines on STOP state and CSIPHY on NoRxMode. The [CSI2\\_TIMING\[15\]](#) FORCE\_RX\_MODE\_IO1 bit field sets the CSIPHY in RxMode or in NoRxMode (stopped mode). The FORCE\_RX\_MODE\_IO1 bit is automatically reset to 0 by hardware when the counter ends and the FSM returns to NoRxMode. Three bit fields ([CSI2\\_TIMING\[14\]](#) STOP\_STATE\_X16\_IO1, [CSI2\\_TIMING\[13\]](#) STOP\_STATE\_X4\_IO1, and [CSI2\\_TIMING\[12:0\]](#) STOP\_STATE\_COUNTER\_IO1) configure the delay between line stop mode and CSIPHY stop mode. The delay represents the number of functional clock (CAM\_FCLK) cycles and can be calculated as follows:

Total delay in CAM\_FCLK cycle = [CSI2\\_TIMING.STOP\\_STATE\\_COUNTER\\_IO1](#) x (1 + [CSI2\\_TIMING.STOP\\_STATE\\_X16\\_IO1](#) x 15) x (1 + [CSI2\\_TIMING.STOP\\_STATE\\_X4\\_IO1](#) x 3).

[Table 6-33](#) lists the possible values of the delay, in terms of the CAM\_FCLK cycles, depending on the values of the STOP\_STATE\_X16\_IO1 and STOP\_STATE\_X4\_IO1 bits.

**Table 6-33. Camera ISP CSI2 Possible Time-Out Value for RxMode Counter**

| STOP_STATE_X16_IO1 | STOP_STATE_X4_IO1 | Possible Delay Value (in Functional Clock Cycles) |
|--------------------|-------------------|---------------------------------------------------|
| 0x0                | 0x0               | 8191 (with step of 1)                             |
| 0x0                | 0x1               | 32764 (with step of 4)                            |
| 0x1                | 0x0               | 131056 (with step of 16)                          |
| 0x1                | 0x1               | 524224 (with step of 64)                          |

The state-machine controlling the RxMode is presented in [Figure 6-74](#).

**Figure 6-74. Camera ISP CSI2 RxMode and StopState FSM**



#### 6.4.3.10 Camera ISP CSI2 Data Decompression

The data compression technique used is differential pulse code modulation (DPCM) and pulse code modulation (PCM).

The CSI2 receiver performs on-the-fly decompression. The decompressed data is either passed to the Video processing hardware or stored in memory.

The data compression method is lossy and does not require any information outside the current encoded/decoded line. This means that all the image lines can be encoded/decoded separately.

There are two different predictors used:

- The simple predictor

This predictor uses only the previous same color component value as a prediction value. Therefore, only two-pixel memory is required.

- The advanced predictor

This predictor uses four previous pixel values, when the prediction value is evaluated. This means that also the other color component values are used, when the prediction value has been defined.

The preferable usage is that simple predictor is used with 10 bits to 8 bits conversion (10 8 10) and the advanced predictor is used with 10 bits to 7 bits and 10 bits to 6 bits conversions (10 7- 10 and 10 6 10). The advanced predictor gives slightly better prediction for pixel value and so the image quality can be improved with it. The simple predictor is very simple and so the processing power and the memory requirements are reduced with it, when the image quality anyway is high enough.

To select DPCM decompression predictor for CSI2 Interface, set the [CSI2\\_CTx\\_CTRL2\[10\]](#) DPCM\_PRED to 1 for simple predictor or to 0 for advanced predictor.

#### 6.4.3.11 Camera ISP CSI2 EndOfFrame and EndOfLine Pulses

The CSI2 receiver generates two signals to qualify the last pixel of a frame and the last pixel of a line.

Software can enable/disable generation of those signals for each context using the [CSI2\\_CTx\\_CTRL1\[7\]](#) EOF\_EN and [CSI2\\_CTx\\_CTRL1\[6\]](#) EOL\_EN registers.

## 6.4.4 Camera ISP Timing Control

### 6.4.4.1 Camera ISP Timing Control Features

The timing-control module provides two clocks (cam\_xclka and cam\_xclkb) that can be used by external camera modules. It also generates the control signals (cam\_strobe and cam\_shutter) for the flash pre-strobe, flash strobe, and mechanical shutters.

The timing-control module includes a timing generator and a control-signal generator.

### 6.4.4.2 Camera ISP Timing Control Overview

[Figure 6-75](#) shows a block diagram of the timing-control module.

**Figure 6-75. Camera ISP Timing Control block diagram**



#### 6.4.4.2.1 Camera ISP Timing Control Generator

The timing control generates the cam\_xclka and cam\_xclkb clocks based on the CAM\_MCLK frequency, which can be up to 216 MHz. The cam\_mclk is used only by the clock generator; the cam\_xclka and cam\_xclkb clocks are not used internally by the camera ISP. The clock divider is programmable.

The possible frequencies of cam\_xclka and cam\_xclkb and their respective configurations are described in [Section 6.3.1.1.3, Clock Configuration](#).

[Table 6-34](#) summarizes the possible frequencies as a function of the divisor values.

#### 6.4.4.2.2 Camera ISP Timing Control Control-Signal Generator

The control-signal generator generates the pre-strobe, strobe, and shutter signals: cam\_strobe and cam\_shutter. [Figure 6-76](#) shows the principle of control-signal generation.

**Figure 6-76. Camera ISP Timing Control Control-Signal Generation**


camisp-033

The control-signal generator gathers precise timings for the cam\_strobe and cam\_shutter signals, to assert and deassert the signals at known times. The timing-control-signal generator can be synchronized either on the vertical synchronization signal coming from the CSI2A (VP\_VS from CSI2A), CSI2C (VP\_VS from CSI2C), CSI1/CCP2B (VP\_VS from CSI1/CCP2B), or PARALLEL interface (cam\_vs), or on an externally-generated cam\_global\_reset signal.

A multiplexer controls which of the CSI2A, CSI1/CCP2B or CSI2C, and PARALLEL interface drives control-signal generation. This multiplexer can also select the externally-generated cam\_global\_reset signal as the trigger event. The [TCTRL\\_CTRL \[31\]](#) GRESETDIR register defines the direction of the cam\_global\_reset signal.

- The external generated cam\_global\_reset is used as a trigger when [TCTRL\\_CTRL \[31\]](#) GRESETDIR = 0 and [TCTRL\\_CTRL\[27:28\]](#) INSEL = 3.
- The internally generated cam\_global\_reset is used as a trigger when [TCTRL\\_CTRL \[31\]](#) GRESETDIR = 1 and [TCTRL\\_CTRL\[27:28\]](#) INSEL = 3.

- If the PARALLEL interface is selected, control-signal generation works for both ITU and SYNC modes and on both output ports: video port and shared-buffer-logic (SBL) port.
- If the CSI2A or CSI1/CCP2B/CSI2C interface is selected, control-signal generation works on both output ports: video port and interconnect port.

The cam\_global\_reset signal can also be generated internally by the control-signal generator under software control. In this case, the prestrobe and shutter signals are synchronized on the internally generated cam\_global\_reset signal. The multiplexer controls whether control-signal generation must be triggered by the internal or external cam\_global\_reset signal.

The prestrobe-, strobe-, and shutter-control signals can be individually enabled at any time. These signals must not be disabled by software.

The clock divider generates the CNTCLK clock based on the cam\_mclk clock. The clock divider is programmable. [Table 6-34](#) summarizes the possible frequencies as a function of the divisor values.

**Table 6-34. Camera ISP Timing Control Control-Signal Generator: CNTCLK Frequencies**

| Divisor Value TCTRL_CTRL [18:10] DIVC | CNTCLK Clock           |
|---------------------------------------|------------------------|
| 0 (default)                           | Clock gated. No clock. |
| 1                                     | 216 MHz, free-running. |
| 2                                     | 108 MHz                |
| 3                                     | 72 MHz                 |
| 4                                     | 54 MHz                 |
| ...                                   | ...                    |
| 510                                   | 0.424 MHz              |
| 511                                   | 0.423 MHz              |

There are three counters per control signal, for a total of nine counters. Each counter is programmable.

- The frame counter is decreased each time a full new frame is received, based on the EOF events from the CCDC or from receiver modules.
  - A new frame is detected in the CSI2A, CSI1/CCP2B, CSI2C receivers on detection of a frame-start code (FSC) followed by a frame-end code (FEC).
  - A new frame is detected in the CCDC module by using the falling edge of the vertical synchronization signal at the input of the CCDC module.

---

**NOTE:** The rising edge of the vertical synchronization signal and the vertical synchronization polarity settings inside the CCDC cannot be used. The modules have no effect on this detection.

---

- The frame counter determines how many whole frames must be ignored before the delay counter is triggered. The frame counters can be set to 0 to bypass them.
- The delay counter determines the control-signal activation delay. The counter is decreased at every CNTCLK clock cycle. When the counter reaches 0, the control signal is asserted. If the delay counter is set to 0, the control signal is asserted immediately.
- The activation-length counter determines the control-signal assertion length. The counter is decreased at every CNTCLK clock cycle. When the counter reaches 0, the signal is deasserted and the control-signal enable bit is disabled. If the activation length is set to 0, the control signal is not asserted and the control-signal enable bit is disabled.

The polarity of the following signals can be individually selected:

- [TCTRL\\_CTRL](#) [26] STRBPSTRBPOL for the prestrobe and strobe signals
- [TCTRL\\_CTRL](#) [24] SHUTPOL for the shutter signal
- [TCTRL\\_CTRL](#) [30] GRESETPOL for the cam\_global\_reset signal

The software can trigger the generation of the cam\_global\_reset signal to the camera module. The

signal-activation length is programmable. The counter is decreased at every CNTCLK clock cycle. When the counter reaches 0, the signal is deasserted and the global reset enable bit is disabled ([TCTRL\\_CTRL \[29\] GRESETEN](#) bit). If the activation length is set to 0, the control signal is not asserted and the control-signal enable bit is disabled. The polarity of the cam\_global\_reset signal can be selected ([TCTRL\\_CTRL \[30\] GRESETPOL](#) bit).

[Figure 6-77](#) shows the use of the cam\_global\_reset signal set as an input or output signal. cam\_global\_reset is asynchronous, edge-sensitive, and asserted for at least one interconnect clock cycle

**Figure 6-77. Camera ISP Timing Control Use of cam\_global\_reset With Global Reset Release Camera Modules**



camisp-034

There are two types of shutter mechanisms: mechanical and electronic. A mechanical shutter is used only for high-resolution sensors. The three control signals (cam\_global\_reset, cam\_shutter, and cam\_strobe) are useful with a mechanical shutter. High frame rates can be achieved only with an electronic shutter. When an electronic shutter is used, none of the three control signals is used.

Mechanical shutter mechanism:

- Reset: All pixels of the sensor are reset to their black value. When the sensor has a global reset feature, the mechanical shutter can be open during reset.
- Integration: The light received by the sensor is transformed into electrical charges that are stored inside pixels. At the end of the integration time, the shutter must be closed. Exposure time is defined by the time between reset release and shutter close.
- Readout: The charges accumulated in pixels are converted to digital values that are sent to the camera receiver.

Electronic rolling shutter mechanism (ERS):

- Each line of the sensor is reset separately and read after a fixed amount of time. Expose time is defined by the time between reset and read.

#### 6.4.5 Camera ISP Bridge-Lane Shifter

The bridge-lane shifter module contains a data-lane shifter and an optional bridge:

- The data-lane shifter routes data sent to physical pins to the proper inputs of the CCDC module. It is controlled by the [ISP\\_CTRL \[7:6\]](#) SHIFT register. [Table 6-35](#) describes the different configurations.

**Table 6-35. Camera ISP Bridge-Lane Shifter**

| Sensor  | Connected to | Data Lane Shifter 0 | Data Lane Shifter 1 | Data Lane Shifter 2 | Data Lane Shifter 3 | Note      |
|---------|--------------|---------------------|---------------------|---------------------|---------------------|-----------|
| 8 bits  | [7:0]        | 8 bits              | 6 bits              | 4 bits              | 2 bits              |           |
|         | [9:2]        | 10 bits             | 8 bits              | 6 bits              | 4 bits              |           |
|         | [11:4]       | 12 bits             | 10 bits             | 8 bits              | 6 bits              |           |
|         | [13:6]       | 14 bits             | 12 bits             | 10 bits             | 8 bits              | CSI2 only |
| 10 bits | [9:0]        | 10 bits             | 8 bits              | 6 bits              | 4 bits              |           |
|         | [11:2]       | 12 bits             | 10 bits             | 8 bits              | 6 bits              |           |
|         | [13:4]       | 14 bits             | 12 bits             | 10 bits             | 8 bits              | CSI2 only |
| 12 bits | [11:0]       | 12 bits             | 10 bits             | 8 bits              | 6 bits              |           |
|         | [13:2]       | 14 bits             | 12 bits             | 10 bits             | 8 bits              | CSI2 only |
| 14 bits | [13:0]       | 14 bits             | 12 bits             | 10 bits             | 8 bits              | CSI2 only |

Blue shading means that the data is too wide for the Video processing hardware: use IVA2.2.

Green shading means that precision is increased for intermediate results.

Orange shading means that precision is reduced.

Unshaded cells imply normal precision.

- An optional bridge allows the packing of bytes into 16-bit words. When it is used, the maximum data rate allowed is increased. The placement of 8-bit data inside 16-bit words is configurable through the [ISP\\_CTRL \[3:2\]](#) PAR\_BRIDGE register. This mode can be useful to transfer an YCbCr data stream or compressed stream to memory at very high speed:
  - A minimum line-blanking period of 2 pixels must be obeyed when the bridge is enabled.
  - Some CCDC modules cannot work with the bridge. For details, see [Figure 6-79](#).

#### 6.4.6 Camera ISP Video-Processing Front End

The video-processing front end (VPFE) comprises the CCDC and the lens-shading compensation.

## 6.4.6.1 Camera ISP CCDC

### 6.4.6.1.1 Camera ISP CCDC Features

The CCDC is responsible for accepting RAW (unprocessed) image/video data from a sensor. It can also accept YUV video data in numerous formats. For RAW inputs, the CCDC output requires additional image processing to transform the input image to a final processed image. This processing can be performed either on-the-fly in the preview engine, or in software on the IVA2.2 subsystem. In parallel, RAW data input to the CCDC can be used for computing statistics (H3A, histogram) to eventually control image/video tuning parameters. The CCDC module supports the following features:

- **Image sensors:** Supports most image sensors (resolutions up to 4096 x 4096).
- **CCDC interface:** The camera ISP module interface comes either from the external parallel interface or from the output of the CSI2A, CSI2C, CSI1/CCP2B receivers (through the video-port interface). It is a 16-bit interface. To raise this maximum 16-bit interface, the bridge data-lane shifter before the CCDC module allows the packing of 8-bit data into 16 bits (not supported with ITU mode):
  - Supports two synchronization modes:
    - **SYNC mode:** In this mode, the cam\_hs and cam\_vs signals use dedicated wires. Synchronization signals are provided by either the sensor or the camera ISP. This mode works with 8-, 10-, 11-, 12-, and 14-bit data. It supports both progressive and interlaced image-sensor modules.

---

**NOTE:** Input from CSI1/CCP2B is limited to 12 bits, and input from CSI2 is limited to 14 bits.

---

- **ITU mode:** In this mode, the image-sensor module provides an ITU-R BT 656-compatible data stream. Horizontal and vertical synchronization signals are not provided to the interface. Instead, the data stream embeds SAV and EAV synchronization code. This mode works in 8- and 10-bit configurations.
- **RAW data processing:** Output data can go directly to memory for software processing, or to the PREVIEW module for further processing. The operations include:
  - Optical clamp
  - Black-level compensation
  - Faulty-pixel correction
  - 2D map based lens-shading compensation (LSC)
  - Data formatter and video port
  - Output formatter and Culling
  - DC subtract
- **YUV data processing:** The output data can go directly to memory for software processing or to the Resizer module for further processing. The operations include:
  - Output formatter and Culling
  - DC subtract
- **Memory ports:** The CCDC module can access memory as a master through the CRSBL, so it does not require the assistance of the system DMA.

### 6.4.6.1.2 Camera ISP CCDC Block Diagram

Figure 6-78 shows the top-level block diagram of the CCDC module.

Figure 6-78. Camera ISP CCDC Block Diagram



The data flow through the module differs, depending on whether the input is RAW data or YUV data. It also depends on the application scenario. See [Table 6-21](#) for ISP and CCDC allowed data flows.

For RAW8/10 data ([CCDC\\_SYN\\_MODE](#) [13:12] INPMODE = 0 [CCDC\\_REC656IF](#) [0] REC656ON = 0), the following functions apply:

- Video-preview and video-capture data flows can pass through the optical-clamp, black-level compensation, faulty-pixel correction, lens-shading compensator, and data-reformatter submodules. Output is transmitted to the computing statistics (H3A, histogram) modules for further processing.
- JPEG still image capture data is not processed by the internal CCDC modules. The data flow is sent to memory through the SBL, Circular buffer, and MMU to be read by the external JPEG CODEC.
- RAW still-image-capture data flow typically passes through the optical clamp, black-level compensation, faulty-pixel correction, lens-shading compensator and output-formatter submodules.

For YUV data ([CCDC\\_SYN\\_MODE](#) [13:12] INPMODE = 1 or 2 [CCDC\\_REC656IF](#) [0] REC656ON = 1), the following functions apply:

- Data can be written to memory directly through the central-resource SBL module or sent to the Resizer module for upscaling or downscaling.

For JPEG data coming from the camera parallel interface (CPI), the following settings apply for proper CCDC configuration:

- [ISP\\_CTRL](#)[29] CCDC\_WEN\_POL = Depending on the JPEG sensor
- [CCDC\\_SYN\\_MODE](#)[5] EXWEN = 1
- [CCDC\\_SYN\\_MODE](#)[13:12] INPMOD = 0
- [CCDC\\_SYN\\_MODE](#)[11] PACK8 = 1
- [CCDC\\_SYN\\_MODE](#)[10:8] DATSIZ = 7

- [CCDC\\_CFG\[8\]](#) WENLOG = 1
- [CCDC\\_VERT\\_LINES\[14:0\]](#) NLV = 0
- [CCDC\\_HSIZE\\_OFF\[15:0\]](#) LNOFST = 0

#### 6.4.6.1.3 Camera ISP CCDC Functional Operations

##### 6.4.6.1.3.1 Camera ISP CCDC SYNC CTRL Module

The SYNC CTRL module receives the pixel-clock signal from the image sensor (PCLK). The module can be slave or master of the horizontal and vertical synchronization signals (HS and VS) and of the field-identification signal (FIELD).

The HS, VS, and FLD signals can be set as inputs or outputs. The polarity of the HS, VS, and FLD signals can be set as positive or negative. If the HS, VS, and FLD signals are output, the signal length can be set.

##### 6.4.6.1.3.2 Camera ISP CCDC Input Sampling and Formatting

- Data is latched by the pixel clock.
- Pixel-clock polarity can be either rising- or falling-edge. This is set through [ISP\\_CTRL \[4\]](#) PAR\_CLK\_POL.
- Data can be interpreted as normal or inverted ([CCDC\\_SYN\\_MODE\[6\]](#) DATAPOL).
- For RAW data:
  - Data is clipped to the number of LSBs specified in the [CCDC\\_SYN\\_MODE](#) [10:8] DATSIZ field. This also sets the maximum data size allowed in subsequent clipping/limiting operations and is the output data alignment if data is written to memory.
- For YUV data (BT656 or SYNC mode):
  - The MSB of the chroma signal can also be inverted ([CCDC\\_CFG](#) [13] MSBINVI). It adds 128 to chrominance signals, to be compatible with several sensors.
- BT656 decoder: Separates data and synchronization signals. This module outputs HS, VS, and FIELD signals.

##### 6.4.6.1.3.3 Camera ISP CCDC Initial Processing

###### Optical Clamp

The optical black clamping function provides a means of averaging the optically black pixels and subtracting that value from each input pixel as a first step. The goal is to remove an offset caused by the sensor technology.

The averaging circuit takes an average of masked (black) pixel values from the image sensor, averaging pixels at the start ([CCDC\\_CLAMP](#) [24:10] OBST) of each line ([CCDC\\_CLAMP](#) [30:28] OBSLEN) and for the number of indicated lines ([CCDC\\_CLAMP](#) [27:25] OBSLN), plus an optional gain adjustment ([CCDC\\_CLAMP](#) [4:0] OBGAIN), and subtracting this value from the image data at the succeeding line. Users can control the position of the black pixels, the number of pixels (1, 2, 4, 8, or 16) in each line averaged, and the averaged number of lines (1, 2, 4, 8, or 16).

Alternately, users can disable black clamp averaging ([CCDC\\_CLAMP](#) [31] CLAMPEN) and select a constant black value for subtraction ([CCDC\\_DCSUB](#) [13:0] DCSUB), instead of using the calculated average value.

---

**NOTE:** For YUV data, this operation subtracts a fixed value ([CCDC\\_DCSUB](#) [13:0] DCSUB) from the luminance sample. To disable this operation, set the subtraction value to zero. This function does not clip negative results to 0 for YUV 8 bit input or REC656 input modes ([CCDC\\_SYN\\_MODE](#) [13:12] INPMOD == 2 || [CCDC\\_REC656IF](#) [0] REC656ON == 1).

This function does not clip negative results to 0 for YUV 8 bit input or REC656 input modes ([CCDC\\_SYN\\_MODE](#) [13:12] INPMOD == 2 || [CCDC\\_REC656IF](#) [0] REC656ON == 1).

---

Figure 6-79 shows an optical clamp representation.

**Figure 6-79. Camera ISP CCDC Optical Clamp Representation**

### Black-Level Compensation

After the optical clamp, black-level compensation is applied to the data. In this operation, a fixed value, depending on the color (R/Ye, Gr/Cy, Gb/G, and B/Mg), can be subtracted from the data. The offset ([CCDC\\_BLKCMP](#) register, fields R\_YE, GR\_CY, GB\_G, B\_MG) applied to each data sample is selected according to the pixel position (0/1/2/3) and the color (0/1/2/3) specified for each pixel position ([CCDC\\_COLPTN](#)). The color pattern definition is flexible to accommodate different sensor types (such as Bayer CFA sampling, VGA Movie Mode).

### Faulty-Pixel Correction

Faulty-pixel correction in the CCDC module requires the camera driver to have information about the image-sensor faulty-pixel number and positions. This method leads to the best image quality. However, if the position of the faulty pixels is unavailable to the camera driver, it can apply another faulty-pixel correction algorithm in the preview module. This algorithm leads to lower-quality images.

The CCDC module implements an optional ([CCDC\\_FPC](#) [15] FPCEN) faulty-pixel correction operation using a look-up table stored in external memory, which contains information about the horizontal and vertical positions of the pixels to be corrected, as well as the type of operation to be performed on the pixels. The [CCDC\\_FPC\\_ADDR](#) register specifies the starting address in memory for the faulty-pixel correction table.

---

**NOTE:** The memory address must be 64-byte-aligned (6 LSBs are ignored).

---



---

**NOTE:** For YUV data, the faulty-pixel correction operation is not applicable and must be disabled/bypassed ([CCDC\\_FPC](#) [15] FPCEN).

---

#### 6.4.6.1.3.4 Camera ISP CCDC Data Formatter, Lens-Shading Compensation, and Video-Port Interface

---

**NOTE:** For YUV data, the data formatter, lens-shading compensation, and video-port interface must be bypassed ([CCDC\\_FMTCFG](#) [15] VPEN = 0x0 and [CCDC\\_SYN\\_MODE](#) [18] VP2SDR = 0x0).

---

The data-formatter module can be enabled to rearrange data after the faulty-pixel correction operation. It is intended to be used:

- When output data lines from the CCDC include pixels from multiple resolution lines. Internally, these sensors combine pixels from multiple horizontal lines into one output pseudoline.
- To smooth bandwidth. This helps reduce peak bandwidth when image cropping is used with the Resizer.

The reformatter module performs the decomposition before the remainder of the normal CCDC processing stages.

The lens-shading compensation (LSC) module can be placed at two different locations:

- Before the data reformatter. It can only be used for Bayer sensors. The H3A video port gets the shading corrected image.
- After the data reformatter. This setup is required for non-Bayer sensors. Histogram and preview modules get the shading corrected image; however, H3A receives a non-corrected image.

Video-port/data-formatter output can also be saved to memory (instead of the RAW data). When [CCDC\\_SYN\\_MODE](#) [18] VP2SDR is set to 1, video-port data is sent to the output formatter. In addition, the [CCDC\\_SYN\\_MODE](#) [17] WEN bit must be enabled to store the output to memory.

The data-formatter and video-port interfaces are only 10 bits wide; therefore, the input data must be adjusted as it enters these modules. For flexibility, the bits to be retained can be selected by [CCDC\\_FMTCFG](#) [14:12] VPIN.

The reformatter decomposes each input line into multiple output lines with new, internally generated HS/VS signals. The reformatter sends it to memory or to other camera ISP modules. These new HS/VS signals, rather than the original sensor HS/VS signals, then gate the downstream processing.

##### Conversion Area Select Parameters

When the data formatter is enabled, HS/VS signals are still generated as output ([CCDC\\_SYN\\_MODE](#) [16] VDHDEN = 0x1). The settings for these output signals are in the following fields:

- [CCDC\\_HD\\_VD\\_WID](#)[27:16] HDW
- [CCDC\\_HD\\_VD\\_WID](#)[11:0] VDW
- [CCDC\\_PIX\\_LINES](#)[31:16] PPLN
- [CCDC\\_PIX\\_LINES](#)[15:0] HLPRF

---

**NOTE:** These four registers are not used when HS/VS signals are input signals ([CCDC\\_SYN\\_MODE](#) [16] VDHDEN = 0x0).

---

---

**NOTE:** The settings reflect those for the sensor readout frame, not the resultant reformatted frame.

---

Registers [CCDC\\_FMT\\_HORZ](#) and [CCDC\\_FMT\\_VERT](#) affect the input framing even if data formatter is disabled.

Registers [CCDC\\_HORZ\\_INFO](#), [CCDC\\_VERT\\_START](#), and [CCDC\\_VERT\\_LINES](#) control the output formatter framing. It is used only when the CCDC output is sent to memory.

Figure 6-80 shows the data formatter conversion area selection.

**Figure 6-80. Camera ISP CCDC Data Formatter Conversion Area Selection**

### Line Decomposition

When enabled, the reformatter can be configured to operate in line-alternating mode or program mode ([CCDC\\_FMTCFG \[1\] LNALT](#)).

When line-alternating mode is enabled, the reformatter swaps even and odd lines. Basically, the 0<sup>th</sup> input line is output as the first line, the first input line is output as the 0<sup>th</sup> line, and so on. If this option is set, the start and number of lines for the formatter ([CCDC\\_VERT\\_START](#) and [CCDC\\_VERT\\_LINES](#)) must be even.

In program mode, or normal reformatter mode, the goal is to convert a single line of movie mode data to 1, 2, 3, or 4 lines of Bayer data. Each incoming line is decomposed according to the data-formatter settings and buffered into an internal line memory. The readout of the resultant multiple reformatted lines occurs as the next input line is being read from the sensor (and reformatted) to ensure that all output lines are fully constructed. The reformatter is subject to the restrictions listed in [Table 6-36](#).

**Table 6-36. Camera ISP CCDC Reformatter Output Limitations**

| Number of Output Lines/Input Line | Max Pixels/Output Line |
|-----------------------------------|------------------------|
| 1                                 | 4 * 1376               |
| 2                                 | 2 * 1376               |
| 3                                 | 1 * 1376               |
| 4                                 | 1 * 1376               |

The reformatter derives its flexibility from supporting up to 8 different addresses and a program that can contain up to 16 entries each for the odd and even lines. Each of the 8 addresses supports either auto increment or auto decrement. This capability is the key for supporting a multitude of readout patterns. The following examples show the programmability of the reformatter. Decomposition is controlled by defining the following parameters:

- [CCDC\\_FMTCFG \[3:2\] LNUM](#)  
Number of lines into which each input line is to be decomposed
- [CCDC\\_FMTCFG \[11:8\] PLEN\\_EVEN](#)  
Number of program entries on even line
- [CCDC\\_FMTCFG \[7:4\] PLEN\\_ODD](#)  
Number of program entries on odd line
- CCDC\_FMT\_ADDRx (x = 0:7)  
Output line in which the original pixel is to be placed, and initial address on the output line
- [CCDC\\_PRGEVEN0](#) or [CCDC\\_PRGEVEN1](#)  
Program to be run on the even input lines
- [CCDC\\_PRGODD0](#) or [CCDC\\_PRGODD1](#)  
Program to be run on the odd input lines

The CCDC\_FMT\_ADDRx registers define 8 address pointers (ADDR0 to ADDR7) that define which output line the input pixel belongs to, and the starting address (position) on that output line. Users can use up to 8 address pointers. The address pointer can be incremented or decremented, depending on the input pixel pattern. The address value computed should always follow the reformatter rules as formerly stated and should never be negative.

### Lens-Shading Compensation

- Overview

The purpose of the LSC function is lens-shading correction by multiplying an image with a gain factor 2-D map, pixel by pixel. The image must be in Bayer CFA format having a 2x2 color pattern. The gain factor map is stored in external memory downsampled, and is accessed and upsampled by the LSC module before being applied to the pixel data.

The LSC function is useful for lens-shading compensation and for scene- and image-dependent lighting adjustment. Downsampled gain map reduces memory requirements for storage and bandwidth requirements for access of the gain maps in external memory.

- Features supported

- The memory stored gain map is MxN downsampled, M being the horizontal sampling factor, N being the vertical sampling factor, M and N being {4, 8, 16, 32, 64} independently and N  $\leq$  M
- 8-bit entries in the gain map (in U8Q8, U8Q7, U8Q6, and U8Q5 format with optional base of 1.0)
- Up to 10-bit unsigned image data input/output
- Up to 4096 x 3072 image dimension

- Functional description

The lens-shading correction module multiplies an image by a gain map that is stored downsampled in memory. The gain map can be dependent on aperture, lens-shading characteristics, and other photographic settings. It is generally used to correct the dim corner effect, but can also be used to implement adaptive lighting adjustment.

Separate horizontal and vertical sampling factors allow the lens-shading correction to work with the normal 1:1 aspect ratio image pixels, as well as tall-and-skinny pixels typical in the sensors preview mode image data.

#### 6.4.6.1.3.5 Output Formatter

The output formatter starts with a framing selection to limit the processing area by setting [CCDC\\_HORZ\\_INFO](#), [CCDC\\_VERT\\_START](#), and [CCDC\\_VERT\\_LINES](#) registers. This framing selection is applied in addition to the framing applied at the beginning and at the end of the data formatter operation if the video-port path to memory is selected ([CCDC\\_SYN\\_MODE](#) [18] VP2SDR).

The option to send the CCDC output to the Resizer module ([CCDC\\_SYN\\_MODE](#) [19] SDR2RSZ) should not be used when in RAW data mode, because the Resizer operates only on YUV format data. Use the preview module when resizing is desired in RAW data mode.

#### Low-Pass Filter (LPF)

An optional horizontal low-pass antialiasing filter can be applied ([CCDC\\_SYN\\_MODE](#) [14] LPF) after reframing. The low-pass filter consists of a simple 3-tap (1/4, /12, and 1/4) filter. Two pixels on the left and two pixels on the right of each line are cropped if the filter is enabled. Use of the LPF is intended for bandwidth reduction if culling is enabled.

---

**NOTE:** For YUV data, the LPF must be disabled ([CCDC\\_SYN\\_MODE](#) [14] LPF = 0x0).

---

#### Culling

An optional culling operation can be enabled ([CCDC\\_CULLING](#) register). This operation allows selected pixel data to be culled (deleted) from a line ([CCDC\\_CULLING](#) [31:24] CULHEVN, [CCDC\\_CULLING](#) [23:16] CULHODD – 8-bit repeating mask, one per field) and selected lines to be culled from a frame ([CCDC\\_CULLING](#) [7:0] CULV).

[Figure 6-81](#) is an example of how register values apply the decimation pattern to the data. The red pixels are saved to memory and the white pixels are discarded. In this example, [CCDC\\_CULLING](#) = 0x239A0066:

- [CCDC\\_CULLING](#) [31:24] CULHEVN = 0x23
- [CCDC\\_CULLING](#) [23:16] CULHODD = 0x9A
- [CCDC\\_CULLING](#) [7:0] CULV = 0x66

---

**NOTE:** Culling can be used with YUV data, but care must be taken to preserve the YUV422 output format.

---

**Figure 6-81. Camera ISP CCDC/Culling: Example for Decimation Pattern**



## A-Law Compression

An optional 10-to-8-bit A-Law compression using a fixed A-Law table can be applied ([CCDC\\_ALAW](#) [3] CCDTBL) as the final processing stage. Using this causes data width to be reduced to 8 bits and allows packing to 8 bits/pixel when saving to memory. Because data resolution can be greater than 10 bits at this stage, the 10 bits for input to the A-Law operation must be selected ([CCDC\\_ALAW](#) [2:0] GWDI).

The preview module has an inverse A-Law table (A-Law decompression) option so that this nonlinear operation can be reversed if this saved data is to be read back in for further processing.

**NOTE:** A-Law compression must not be used ([CCDC\\_ALAW](#) [3] CCDTBL = 0) with YUV data.

Figure 6-82 show the A-Law table.

**Figure 6-82. Camera ISP CCDC A-Law Table**

### Line-Output Control

---

**NOTE:** Line-output control can be used with YUV data.

---

The CCDC final stage is line-output control, which controls how the input sensor lines are written to memory. The value of **CCDC\_SDR\_ADDR** [31:0] ADDR defines the starting address where the frame should be written in memory. The value of **CCDC\_HSIZE\_OFF** [15:0] LNOFST defines the distance between two lines for each output line to memory. The starting address and line-offset values should be aligned to 32-byte boundaries; that is, either 16 or 32 pixels, depending on the **CCDC\_SYN\_MODE** [11] PACK8 setting. Register **CCDC\_SDOFST** can be used to define additional offsets, depending on the field ID and even/odd line numbers. This provides a means to deinterlace an interlaced 2-field input and to invert an input image vertically. See [Table 6-37](#).

**Table 6-37. Camera ISP CCDC CCDC\_SDOFST Description**

| Register                         | Description                                                   |
|----------------------------------|---------------------------------------------------------------|
| <b>CCDC_SDOFST</b> [14] FIINV    | Invert interpretation of the field ID signal                  |
| <b>CCDC_SDOFST</b> [13:12] FOFST | Offset, in lines, of field = 1                                |
| <b>CCDC_SDOFST</b> [11:9] LOFTS0 | Offset, in lines, between even lines on even fields (field 0) |
| <b>CCDC_SDOFST</b> [8:6] LOFTS1  | Offset, in lines, between odd lines on even fields (field 0)  |
| <b>CCDC_SDOFST</b> [5:3] LOFTS2  | Offset, in lines, between even lines on odd fields (field 1)  |
| <b>CCDC_SDOFST</b> [2:0] LOFTS3  | Offset, in lines, between odd lines on odd fields (field 1)   |

### Line Output Control: 2D Addressing Example

The CCDC memory port can be configured to write a subimage into a bigger image buffer. This feature is useful for overlaying a video preview flow with the rest of the display. To use this feature, the **CCDC\_SDR\_ADDR** [31:0] ADDR register points to the first pixel to write and the **CCDC\_SDOFST** [13:12] FOFST is set to the size of one line of the destination buffer.

---

**NOTE:**

- This mode can be used only when the source and destination buffers use the same image format.
  - 2D addressing is also supported by other camera ISP modules.
-

### Line-Output Control: Examples

Figure 6-83 shows an example of sample formats of input and output images.

**Figure 6-83. Camera ISP CCDC/Line-Output Control: Sample Formats of Input and Output Images**



|                                |                                    |
|--------------------------------|------------------------------------|
| CCDC_SDOFST[14] FIINV = 0x0    | ;Non inverse                       |
| CCDC_SDOFST[13:12] FOFST = 0x0 | ;+1 line; first line, even field   |
| CCDC_SDOFST[11:9] LOFST0 = 0x1 | ;+2 lines; even lines, even fields |
| CCDC_SDOFST[8:6] LOFST1 = 0x1  | ;+2 lines; odd lines, even fields  |
| CCDC_SDOFST[5:3] LOFST2 = 0x1  | ;+2 lines; even lines, odd fields  |
| CCDC_SDOFST[2:0] LOFST3 = 0x1  | ;+2 lines; odd lines, odd fields   |



|                                |                                    |
|--------------------------------|------------------------------------|
| CCDC_SDOFST[14] FIINV = 0x1    | ;inverse                           |
| CCDC_SDOFST[13:12] FOFST = 0x0 | ;+1 line; first line, even field   |
| CCDC_SDOFST[11:9] LOFST0 = 0x5 | ;−2 lines; even lines, even fields |
| CCDC_SDOFST[8:6] LOFST1 = 0x5  | ;−2 lines; odd lines, even fields  |
| CCDC_SDOFST[5:3] LOFST2 = 0x5  | ;−2 lines; even lines, odd fields  |
| CCDC_SDOFST[2:0] LOFST3 = 0x5  | ;−2 lines; odd lines, odd fields   |

camisp-051

### Output Format

The data bits comprising each pixel are stored in the lower bits of a 16-bit memory word and the unused bits are zero-filled. The memory data format is shown in [Table 6-38](#). The format is determined by the [CCDC\\_SYN\\_MODE](#) [10:8] DATSIZ field.

If 8-bit data is input, or if A-Law compression is applied, the data can be packed through the [CCDC\\_SYN\\_MODE](#) [11] PACK8 setting so that a pixel occupies only 8 bits.

Data is output to memory only when enabled through the [CCDC\\_SYN\\_MODE](#) [17] WEN setting. The pixels are ordered in little-endian format.

**Table 6-38. Camera ISP CCDC Memory Output Format for RAW Data**

|              | Upper word |         | LSB(16) | Lower word |         | LSB(0) |
|--------------|------------|---------|---------|------------|---------|--------|
|              | MSB(31)    |         | MSB(15) |            |         |        |
| 16 bit       | Pixel 1    |         |         | Pixel 0    |         |        |
| 15 bit       | 0          | Pixel 1 |         | 0          | Pixel 0 |        |
| 14 bit       | 0          | Pixel 1 |         | 0          | Pixel 0 |        |
| 13 bit       | 0          | Pixel 1 |         | 0          | Pixel 0 |        |
| 12 bit       | 0          | Pixel 1 |         | 0          | Pixel 0 |        |
| 11 bit       | 0          | Pixel 1 |         | 0          | Pixel 0 |        |
| 10 bit       | 0          | Pixel 1 |         | 0          | Pixel 0 |        |
| 9 bit        | 0          | Pixel 1 |         | 0          | Pixel 0 |        |
| 8 bit        | 0          | Pixel 1 |         | 0          | Pixel 0 |        |
| 8-bit packed | Pixel 3    | Pixel 2 |         | Pixel 1    | Pixel 0 |        |

---

**NOTE:** YUV data is stored in memory in packed YUV422 mode, using two pixels per 32 bits, as shown in [Table 6-39](#).

---

**Table 6-39. Camera ISP CCDC Memory Output Format for YUV Data**

| <b>Memory Address</b> | <b>Upper Word</b> |                | <b>Lower Word</b> |               |
|-----------------------|-------------------|----------------|-------------------|---------------|
|                       | <b>MSB(31)</b>    | <b>LSB(16)</b> | <b>MSB(15)</b>    | <b>LSB(0)</b> |
| N                     | Y1                | Cr0            | Y0                | Cb0           |
| N + 1                 | Y3                | Cr1            | Y2                | Cb1           |
| N + 2                 | Y5                | Cr2            | Y4                | Cb2           |

#### 6.4.6.1.4 Camera ISP CCDC DMA

The CCDC module is a master. It has its own address generator and sends addresses and data to the central-resource shared-buffer logic. The central-resource shared-buffer logic arbitrates the data requests and generates the bursts to memory.

#### 6.4.6.1.5 Camera ISP CCDC Memories

The CCDC module has one memory:

- REFORMATTER BUFFER: 3 x 1376 x 40 bits
- LSC PREFETCH BUFFER: 1536 x 32 bits

#### 6.4.7 Camera ISP Video-Processing Back End

The video-processing back end (VPBE) comprises the preview and Resizer modules.

##### 6.4.7.1 Camera ISP VPBE Preview Engine Features

The preview module is responsible for transforming data from a RAW image sensor into YUV422 data that is amenable to still-image encoding, video encoding, or display. It supports the following features:

- Flexible input: Module input data can come from the RAW image sensor (10 bits) or from memory (8 or 10 bits).
- Flexible input formats: Bayer RGB color filter array, complementary-color filter array, Super CCD Honeycom® sensors
- Horizontal averaging by a factor of 1, 2, 4, or 8 in the horizontal direction. The preview module can output a maximum of only 4096 pixels horizontally due to fixed memory-line sizes.
- A-Law decompression: Transforms nonlinear 8-bit data to 10-bit linear data. The CCDC module can perform A-Law compression.
- Noise reduction and faulty-pixel correction:
  - Dark-frame capture and subtraction
  - Horizontal median filter
  - Programmable noise filter: 3x3 kernel of same color pixels
  - Couplet faulty-pixel correction
- Digital gain and white balance
- Programmable CFA interpolation that operates on a 5x5 grid
- Programmable RGB-to-RGB blending matrix: 9 coefficients for the 3x3 matrix
- Programmable gamma correction: 1024 entries for each color held in local memory
- Programmable RGB-to-YUV color conversion: 9 coefficients for the 3x3 matrix
- Luminance enhancement (nonlinear), chrominance suppression and offset

###### 6.4.7.1.1 Camera ISP VPBE Preview Block Diagram

[Figure 6-84](#) shows the preview engine block diagram.

**Figure 6-84. Camera ISP VPBE Preview Engine Block Diagram**


#### 6.4.7.1.2 Camera ISP VPBE Preview Input Interface

The preview engine receives RAW image/video data from the video port interface through the CCDC or from the read buffer interface through the memory (PRV\_PCR [2] SOURCE). When the source of input data is the CCDC, the input data is always 10 bits wide. When the source of input data is memory (read buffer interface), the data can be 8 or 10 bits wide. Use the PRV\_PCR[4] WIDTH field to set the input data width. The 8 bits can be linear or nonlinear (A-Law compressed).

In addition, the preview engine can fetch a dark frame from memory, with each pixel 8 bits wide.

The frame-input size is configured using the PRV\_HORZ\_INFO and PRV\_VERT\_INFO registers.

If the input source is the CCDC, the input height set in the preview engine must be less than or equal to the output height of the video-port output of the CCDC. The input width must be at least 4 pixels smaller than the CCDC output width (SPH = 2; EPH = 2 pixels before the last pixel sent from the CCDC).

The input memory address (PRV\_RSDR\_ADDR) and line offset (PRV\_RADR\_OFFSET) registers should be aligned on 32-byte boundaries when the input source is set to memory. The dark-frame input address (PRV\_DSDR\_ADDR) and line offset (PRV\_DRKF\_OFFSET) should also be aligned on 32-byte boundaries when the dark-frame subtract function is enabled.

When the input source is memory, the preview engine always operates in one-shot mode. After enabling the preview engine and processing a frame, the enable bit is turned off and it is up to firmware to reenable it to process the next frame from memory.

When the input source is the CCDC, the preview engine can be configured to operate in one-shot mode or continuous mode ([PRV\\_PCR](#) [3] ONESHOT).

The SBL image data read port is shared between the preview and CSI1/CCP2B receiver module. When the image is read from memory, the read port must be affected to the preview receiver module by writing 0 into the [ISP\\_CTRL\[27\]](#) SBL\_SHARED\_RPORTA. Programmers must ensure that the CSI1/CCP2B module does not use this port before switching to the preview module.

#### 6.4.7.1.3 Camera ISP VPBE Preview Input Formatter/Averager

Preview-engine output is limited to 4096 pixels per horizontal line to support 12 Mpix, due to line memory-width restrictions in the noise filter and CFA interpolation blocks. To support sensors that output more than 4096 pixels per line, an averager is incorporated to downsample by factors of 1 (no averaging), 2, 4, or 8 in the horizontal direction ([PRV\\_AVE](#) [1:0] COUNT). The horizontal distance between two consecutive pixels of the same color to be averaged is selectable from among 1, 2, 3, or 4 for both even ([PRV\\_AVE](#) [3:2] EVENDIST) and odd ([PRV\\_AVE](#) [5:4] ODDDIST) lines. This must be configured to match the input pattern type.

For example, a Bayer pattern has a horizontal distance of two pixels of the same color for both even and odd lines.

Valid output of the input formatter/averager is either 8 or 10 bits wide.

[Figure 6-85](#) shows the horizontal distances for different patterns.

**Figure 6-85. Camera ISP VPBE Preview Horizontal Distances for Different Patterns**



Bayer format with R/Gr and Gb/B in alternate lines  
Horizontal distance between same colors is 2

camisp-308

#### 6.4.7.1.4 Camera ISP VPBE Preview Dark-Frame Write

The preview engine is capable of capturing and saving a dark frame to memory instead of performing conventional processing steps ([PRV\\_PCR](#) [7] DRKFCAP).

This dark frame can later be subtracted from the RAW image data to eliminate the repeatable baseline noise level in the frame.

Each input pixel is written as an 8-bit value; if the input pixel value is greater than 255, it is saturated to 255. If a dark pixel is greater than 255, it is more likely to be faulty, and can be corrected by the faulty-pixel correction module in the CCDC. If properly corrected, the value must be less than 255 when it reaches the preview engine.

The [PRV\\_WSDR\\_ADDR](#) and [PRV\\_WADD\\_OFFSET](#) registers must be used to indicate the output address and line offset, respectively, of the dark-frame output in memory.

#### 6.4.7.1.5 Camera ISP VPBE Preview Inverse A-Law

To save memory capacity and bandwidth, the CCDC includes an option to apply 10-bit to 8-bit A-Law compression and to pack the sensor data to 1 byte per pixel. To process this data correctly, the inverse A-Law block is provided to decompress the 8-bit nonlinear data back to 10-bit linear data if enabled ([PRV\\_PCR](#) [5] INVALAW). Even if the inverse A-Law block is not enabled, but the input is still 8 bits ([PRV\\_PCR](#) [4] WIDTH), the data is-left shifted by 2 to make it 10-bit data. If the input is 10 bits wide, no operation is performed on the data.

---

**NOTE:** When A-Law compression in CCDC is enabled during dark-frame write, it must be enabled when the stored dark frame is used.

---

#### 6.4.7.1.6 Camera ISP VPBE Preview Dark-Frame Subtract or Shading Compensation

The preview engine can fetch a dark frame containing 8-bit values from memory (8 bits in input are converted internally to 10 bits by adding two zeros to the left) and subtracting it, pixel by pixel, from the incoming input frame ([PRV\\_PCR](#) [6] DRKFEN). This function removes pattern noise in the sensor. The output of the dark-frame subtract operation is 10 bits wide (U10Q0).

There must be adequate memory bandwidth if this feature is enabled. If the data fetched from memory arrives late, the [PRV\\_PCR](#) [31] DRK\_FAIL status bit is set to indicate a fail.

Instead of performing the dark-frame subtract, the preview engine can perform lens-shading compensation (if [PRV\\_PCR](#) [21] SCOMP\_EN is set along with [PRV\\_PCR](#) [6] DRKFEN). In this case, the 8-bit unsigned value fetched from memory is multiplied by the incoming pixel, and the result is right-shifted by the number of bits specified by the [PRV\\_PCR](#) [24:22] SCOMP\_SFT parameter (0-7 bits).

The SBL data read port is shared between the CCDC and preview module. The read port must be affected to the preview module by writing 0 into the [ISP\\_CTRL](#) [28] SBL\_SHARED\_RPORTB. Programmers must ensure that the CCDC module does not use this port before switching to the preview module.

#### 6.4.7.1.7 Camera ISP VPBE Preview Horizontal Median Filter

The preview engine contains a horizontal median filter that can help reduce temperature-induced noise effects. The input and output of the horizontal median filter are 10 bits wide (U10Q0).

---

**NOTE:** Line-width reduction: If the horizontal median filter is enabled, the preview engine reduces the length of the output line of this stage by 4 pixels (2 starting pixels -left edge and 2 ending pixels -right edge). For example, if the input size is 656 × 490 pixels, the output is 652 × 490 pixels. There is no truncation of input data line if this block is disabled.

---

#### 6.4.7.1.8 Camera ISP VPBE Preview Noise Filter and Faulty Pixel Correction

The noise filter and couplet defect correction (CDC) operate on the same 33 matrix of same color pixels. Both functions can be enabled separately using the [PRV\\_PCR](#) [27] DCOREN and [PRV\\_PCR](#) [9] NFEN bits.

The faulty pixel correction function replaces the central pixel (x0) with one of the neighbors (x1-x8) in the following cases:

- When it has been identified as faulty.
- When the feature is enabled.

The noise filter modifies the central pixel when it is enabled.

---

**NOTE:** Some details of these features are not available in public domain

---

#### 6.4.7.1.9 Camera ISP VPBE Preview White Balance

The white-balance module has a digital gain adjuster and a white-balance adjuster. In the digital gain adjuster ([PRV\\_WB\\_DGAIN](#) [9:0] DGAIN), RAW data is multiplied by a fixed-value gain, regardless of the color of the pixel to be processed.

In the white-balance gain adjuster ([PRV\\_WBGAIN](#)), RAW data is multiplied by a selected gain corresponding to the color of the processed pixel.

---

**NOTE:** Some details of this feature are not available in public domain

---

#### 6.4.7.1.10 Camera ISP VPBE Preview CFA Interpolation

The CFA function is responsible for providing full RGB data for each pixel. Depending on sensor type and configuration, interpolation and/or rephasing are required.

The CFA function can be enabled ([PRV\\_PCR](#) [10] CFAEN) and configured to different interpolation modes ([PRV\\_PCR](#) [14:11] CFAFMT).

---

**NOTE:** Some details of this feature are not available in the public domain.

---

##### 6.4.7.1.10.1 Camera ISP VPBE Preview CFA for Bayer Modes

In Bayer modes, the CFA interpolation block is responsible for populating the missing color pixels at a given location, resulting in a 3-color RGB pixel. It does this by interpolating data from neighboring pixels of the same color.

---

**NOTE:** Some details of this feature are not available in the public domain.

---

##### 6.4.7.1.10.2 Camera ISP VPBE Preview CFA Options

If the CFA interpolation block is disabled, the same input pixel is broadcast to all three output pixels.

---

**NOTE:** Image-size reduction: If CFA interpolation is enabled, the preview engine reduces the output of this stage. Two pixels/line in the left, right, top, and bottom edges are truncated in the Bayer/conventional and other modes.

---

If the CFA format is 2 downsampling in both horizontal and vertical directions, only 2 lines at the top and bottom of the image are truncated. The two left- and right-most pixels are processed.

#### 6.4.7.1.11 Camera ISP VPBE Preview Black Adjustment

The CFA interpolation output is three pixels (red, blue, and green values) and this is fed as input to the black-adjustment module, which performs the following calculation for an adjustment of each color level:

$$\text{data\_out} = \text{data\_in} + \text{bl\_offset}$$

The bl\_offset values for each color are programmable in the [PRV\\_BLKADJOFF](#) register and coded in S8Q0 format (-128..+127). A simple one addition and clip operation are processed in this module. The output data\_out [10..0] is signed.

---

**NOTE:** Some details of this feature are not available in the public domain.

---

#### 6.4.7.1.12 Camera ISP VPBE Preview RGB Blending

The RGB2RGB blending module has a general 3x3 square matrix and redefines the RGB data from the CFA interpolation module, which can be used as a function of a color correction. This is programmable ([PRV\\_RGB\\_MAT1](#), [PRV\\_RGB\\_MAT2](#), [PRV\\_RGB\\_MAT3](#), [PRV\\_RGB\\_MAT4](#), [PRV\\_RGB\\_MAT5](#), [PRV\\_RGB\\_OFF1](#), [PRV\\_RGB\\_OFF2](#)) so that the color spectrum of the sensor can be adjusted to the human color spectrum. The input is signed 11 bits and the output is unsigned 10 bits. The following calculation is performed in this module:

$$\begin{bmatrix} R_{out} \\ G_{out} \\ B_{out} \end{bmatrix} = \begin{bmatrix} MTX\_RR & MTX\_GR & MTX\_BR \\ MTX\_RG & MTX\_GG & MTX\_BG \\ MTX\_RB & MTX\_GB & MTX\_BB \end{bmatrix} \begin{bmatrix} R_{in} \\ G_{in} \\ B_{in} \end{bmatrix} + \begin{bmatrix} MTX\_OFFR \\ MTX\_OFFG \\ MTX\_OFFB \end{bmatrix}$$

camisp-E094

Gains are in S12Q8 format, and offsets are in S10Q0 format.

$$\begin{bmatrix} R_{out} \\ G_{out} \\ B_{out} \end{bmatrix} = \begin{bmatrix} 1 & 0 & 0 \\ 0 & 1 & 0 \\ 0 & 0 & 1 \end{bmatrix} \begin{bmatrix} R_{in} \\ G_{in} \\ B_{in} \end{bmatrix} + \begin{bmatrix} 0 \\ 0 \\ 0 \end{bmatrix}$$

camisp-E161

That leads to:

$$\begin{aligned} MTX\_RR &= MTX\_GG = MTX\_BB = 256 \\ others &= 0 \end{aligned}$$

camisp-E162

#### **6.4.7.1.13 Camera ISP VPBE Preview Gamma Correction**

Gamma correction is performed on each of the R, G, and B pixels separately by indexing programmable gamma look-up tables. Each table has 1024 8-bit entries. The input data value is used to index into the table and the table content is the output.

The gamma table can be bypassed ([PRV\\_PCR \[26\] GAMMA\\_BYPASS](#)). In this case, the output of the gamma correction is the 8 MSB of the 10-bit input. The gamma table can be written only while the preview engine is disabled.

#### **6.4.7.1.14 Camera ISP VPBE Preview RGB to YCbCr Conversion, Luminance Enhancement, Chrominance Suppression, Contrast and Brightness, and 4:2:2 Downsampling and Output Clipping**

##### **6.4.7.1.14.1 RGB-to-YCbCr Conversion**

The RGB-to-YCbCr conversion module has a 3x3 square matrix and converts the RGB color space of the image data into the YCbCr color space. In this module, the following calculation is performed using the contents of the [PRV\\_CSC0](#), [PRV\\_CSC1](#), [PRV\\_CSC2](#), and [PRV\\_CSC\\_OFFSET](#) registers:

$$\begin{bmatrix} Y \\ Cb \\ Cr \end{bmatrix} = \begin{bmatrix} CSCRY & CSCGY & CSCBY \\ CSCRCB & CSCGCB & CSCBCB \\ CSCRCR & CSCGCR & CSCBCR \end{bmatrix} \begin{bmatrix} R_{in} \\ G_{in} \\ B_{in} \end{bmatrix} + \begin{bmatrix} YOFST \\ OFSTCB \\ OFSTCR \end{bmatrix}$$

camisp-E095

Gains are in S10Q8 format, and offsets are in S8Q0 format for chroma and U10Q0 for luma.

---

**NOTE:** Program the following values after reset for correct color conversion:

- [PRV\\_CSC2 \[19:10\]](#) CSCGCR = 0x39E
  - [PRV\\_CSC2 \[9:0\]](#) CSCRCR = 0x080
- 

##### **6.4.7.1.14.2 Nonlinear Luminance Enhancement**

Nonlinear luminance enhancement functions as an edge enhancer (crossed in the horizontal direction). It can be enabled or disabled using the [PRV\\_PCR \[15\] YNENHEN](#) parameter. If it is enabled, a look-up table with 127 20-bit entries must be programmed. Each entry contains a 10-bit signed offset value in the MSBs, and a 10-bit signed slope in the LSBs.

---

**NOTE:** Some details of this feature are not available in the public domain.

---

#### 6.4.7.1.14.2.1 Chrominance Suppression

Occasionally, in very bright portions of an image, only one or two of the color channels are saturated, while the remaining channel(s) are not. This can lead to a false-color effect. One common example is the appearance of pink where white should be. Chrominance suppression can be used to correct this issue.

Chrominance suppression can be enabled or disabled using the [PRV\\_PCR \[16\]](#) SUPEN parameter.

---

**NOTE:** Some details of this feature are not available in the public domain.

---

#### 6.4.7.1.14.2.2 Contrast and Brightness

The luminance component can be adjusted for contrast (scaling/multiplication) and brightness (offset/addition). Contrast is set in the [PRV\\_CNT\\_BRT \[15:8\]](#) CNT field (U8Q4 precision), and brightness is set in the [PRV\\_CNT\\_BRT \[7:0\]](#) BRT field (U8Q0 precision).

#### 6.4.7.1.14.2.3 Downsampling and Output Clipping

The 4:2:2 conversion module converts image data to YCbCr-4:2:2 format by averaging every other Cb and Cr component in the horizontal direction. Before outputting the data, the preview engine performs clipping on the YCC components separately. The minimum and maximum threshold values for the Y and C values are specified using the [PRV\\_SETUP\\_YC](#) register. If no clipping is required, the register must be set to its reset values of 0xFF for the maximum Y and C values, and 0 for the minimum Y and C values.

#### 6.4.7.1.15 Camera ISP VPBE Preview Write-Buffer Interface

The output of the preview engine may be passed directly to the Resizer ([PRV\\_PCR \[19\]](#) RSZPORT) and/or written to memory ([PRV\\_PCR \[20\]](#) SDRPORT).

If the output is written to memory, the write address ([PRV\\_WSDR\\_ADDR](#)) and line offset ([PRV\\_WADD\\_OFFSET](#)) must be on 32-byte boundaries. The output format of the YCC data is programmable by setting the [PRV\\_PCR \[18:17\]](#) YCPOS parameter.

The final width and height of the output vary depending on which processing functions are enabled. [Table 6-40](#) indicates how many edge pixels/lines are truncated by enabling certain modules in the preview engine. These values must be subtracted from the input height and width after the averager to determine the size of preview-engine output.

**Table 6-40. Camera ISP VPBE Preview Image Cropping by Preview Functions**

| Image Cropping by Preview Functions        |          |       |
|--------------------------------------------|----------|-------|
| Function                                   | Pix/Line | Lines |
| Horizontal median filter                   | 4        | 0     |
| Noise filter                               | 4        | 4     |
| CFA (Bayer, Super CCD Honeycom or RGBE)    | 4        | 4     |
| Color suppression OR luminance enhancement | 2        | 0     |
| Maximum total                              | 14       | 8     |

---

**NOTE:** Different CFA modes are mutually exclusive.

---

#### 6.4.7.2 Camera ISP VPBE Resizer

##### 6.4.7.2.1 Camera ISP VPBE Resizer Features

The Resizer module enables image upsampling and downsampling, see [Table 6-41](#). The following features are supported:

- Flexible input sources:
  - Preview module: Enables on-the-fly processing

- Memory: Enables differed processing
- Memory: CCDC module: Enables on-the-fly processing
- Flexible input format:
  - YUV422 packed data (16 bits)
  - Color-separate data (8 bits). The data must be contiguous in memory. The input source for the data must be the memory: not available for on-the-fly processing.
  - Same output format as input
- Upsampling: Up to 4. Enables digital zoom:
  - General polyphase filter:
    - Ratio of 1 to 4: 4 taps (horizontal and vertical) and 8 phases
- Downsampling: Down to 0.25:
  - General polyphase filter:
    - Ratio of 0.25 to 0.5: 7 taps (horizontal and vertical) and 4 phases
    - Ratio of 0.5 to 1: 4 taps (horizontal and vertical) and 8 phases
- Constraints:
  - The following input width (IW) and output width (OW) constraints must be obeyed due to limited on-chip memory resources.

**Table 6-41. Camera ISP VPBE Resizer Use Constraints**

| Resizer Use Constraints |             |             | Horizontal Resizer Ratio |          |
|-------------------------|-------------|-------------|--------------------------|----------|
|                         |             | 0.25 to 0.5 |                          | 0.5 to 4 |
|                         |             | 7 taps      |                          | 4 taps   |
| Vertical Resizer ratio  | 0.25 to 0.5 | 7 taps      | OW=2048                  | OW=2048  |
|                         | 0.5 to 4    | 4 taps      | OW=4096                  | OW=4096  |

- The horizontal resizer output rate must not exceed half the functional clock; Moreover, the horizontal resizer output rate must not exceed 100M pixels/s. This limitation applies only for the on-the-fly processing input source.
- Flexible resizing ratios: Independent resizing factors for the horizontal and vertical directions. The applicable ratio is 256/N, with N ranging from 64 to 1024.
- Programmable luminance enhancer
- Continuous and one-shot operation

#### **6.4.7.2.2 Camera ISP VPBE Resizer Block Diagram**

The resizer module performs either upsampling (digital zoom) or downsampling on image/video data within a range of 0.25 to 4 resizing. The input source can be sent to either the preview engine/CCDC or memory, and the output is sent to memory.

The resizer module performs horizontal resizing, then vertical resizing, independently. Between them there is an optional edge-enhancement feature. This process is shown in [Figure 6-86](#).

**Figure 6-86. Camera ISP VPBE Resizer Process**

camisp-063

#### 6.4.7.2.3 Camera ISP VPBE Resizer Input and Output Interfaces

The input source can be sent to either the preview engine/CCDC or memory ([RSZ\\_CNT \[28\] INPSRC](#)). The input width ([RSZ\\_IN\\_SIZE \[12:0\] HORZ](#)) must be at least 32 pixels.

##### 6.4.7.2.3.1 Camera ISP VPBE Resizer Preview Engine/CCDC Input Mode

In the preview engine/CCDC input mode, internal hardware synchronization signals define input frames. The horizontal starting byte ([RSZ\\_IN\\_START \[12:0\] HORZ\\_ST](#)) and vertical starting line ([RSZ\\_IN\\_START \[28:16\] VERT\\_ST](#)) define a starting pixel with respect to the upper-left corner of an input image (signaled through horizontal and vertical synchronization signals). The input width and height in the [RSZ\\_IN\\_SIZE](#) register specify the exact input range (relative to the starting pixel) necessary to generate an output frame of specified width/height.

---

**NOTE:** Care must be taken to ensure that the input sizes specified by the [RSZ\\_IN\\_START](#) and [RSZ\\_IN\\_SIZE](#) registers are less than or equal to the output from the preview engine or CCDC; otherwise, incorrect hardware operation may occur.

---

[RSZ\\_SDR\\_INADD](#) and [RSZ\\_SDR\\_INOFF](#) must be programmed to be 0x0 in this mode.

Also, the output ports of the CCDC ([CCDC\\_SYN\\_MODE \[19\] SDR2RSZ](#)) and preview engine ([PRV\\_PCR \[19\] RSZPORT](#)) to the resizer must be configured so that only one of them is enabled. If both are enabled, the CCDC gains control of this interface.

If input is from the CCDC, the output of the CCDC must be in YUV422 format (the resizer does not support resizing RAW data from the CCDC).

##### 6.4.7.2.3.2 Camera ISP VPBE Resizer Memory-Input Mode

In memory-input mode, the memory address in [RSZ\\_SDR\\_INADD](#) points to the 32-byte-aligned memory address where the starting pixel resides.

The horizontal starting pixel ([RSZ\\_IN\\_START \[12:0\] HORZ\\_ST](#)) defines a starting pixel within that 32-byte alignment; HORZ\_ST is constrained to 0...15 for the YUV 422 format, and 0...31 for the color-separated format.

The vertical starting pixel ([RSZ\\_IN\\_START \[28:16\] VERT\\_ST](#)) must be zero in memory-input mode. The [RSZ\\_SDR\\_INOFF](#) register specifies the address offset between rows of input data. The input width and height in the [RSZ\\_IN\\_SIZE](#) register specify the exact input range (relative to the starting pixel) necessary to generate an output frame of specified width/height.

Figure 6-87 shows the resizer in memory-input mode.

**Figure 6-87. Camera ISP VPBE Resizer Resizer in Memory-Input Mode**

camisp-115

#### 6.4.7.2.3.3 Camera ISP VPBE Resizer Output Interface

In both input modes, the [RSZ\\_OUT\\_SIZE](#) register specifies output width/height, the [RSZ\\_SDR\\_OUTADD](#) register specifies output starting pixel (upper-left corner) memory address, and the [RSZ\\_SDR\\_OUTOFF](#) register specifies memory address offset between the beginning of output rows. The resizer output always goes to memory.

**NOTE:** [RSZ\\_SDR\\_INADD](#), [RSZ\\_SDR\\_OUTADD](#), [RSZ\\_SDR\\_INOFF](#), and [RSZ\\_SDR\\_OUTOFF](#) must be 32-byte-aligned; the lower 5 bits of the byte address are assumed to be zero.

Output-width constraints: The output width ([RSZ\\_OUT\\_SIZE](#) [11:0] HORZ) must be at least 16 pixels, and be even (so that the same number of Cb and Cr components is outputted). Due to the vertical memory size constraint, the output width ([RSZ\\_OUT\\_SIZE](#) [11:0] HORZ) cannot be greater than:

- 4096 pixels if the vertical resizing ratio is between 1/2 and 4 ([\(RSZ\\_CNT](#) [19:10] VRSZ + 1) = 512)
- 1650 pixels wide if the vertical resizing ratio is between 1/2 and 1/4 ([\(RSZ\\_CNT](#) [19:10] VRSZ + 1) 512)

#### 6.4.7.2.4 Camera ISP VPBE Resizer Horizontal and Vertical Resizing

In the rest of this section:

- HRSZ is used for [RSZ\\_CNT](#) [9:0] HRSZ + 1.
- VRSZ is used for [RSZ\\_CNT](#) [19:10] VRSZ + 1.

The resizer module can upsample or downsample image data with independent resizing factors in the horizontal and vertical directions. The HRSZ and VRSZ parameters can range from 64 to 1024 to give a resampling range from 4 to 0.25 (256/HRSZ or 256/VRSZ).

The resizer module uses the same resampling algorithm for the horizontal and vertical directions.

The resizing/resampling algorithm uses a programmable polyphase sample rate converter (resampler). The polyphase filter coefficients are programmable so that any user-specified filter can be implemented.

[Figure 6-88](#) shows a general sample-rate converter where the resampling rate is equal to L/M.

**Figure 6-88. Camera ISP VPBE Resizer Typical Sample-Rate Converter**



L phases are used in a typical polyphase implementation. The resizer module, however, fixes the number of phases to 8 for a resizing range of 1/2 ~ 4 (RSZ = 64 ~ 512), or 4 for a resizing range of 1/4 ~ 1/2 (RSZ = 513 ~ 1024). In this way, the upsampling value (L) is fixed to either 8 or 4, and the downsampling value (M) is based on RSZ. To achieve a resizing ratio of 256/RSZ, the downsampling value (M) is equal to (PxRSZ)/256, where P is the number of phases. [Figure 6-89](#) shows the resizer functionality.

**Figure 6-89. Camera ISP VPBE Resizer Functionality**



[Figure 6-90](#) shows a model of the resolution of the noninteger downsampling ratio. The interpolated output from the filter is upsampled and replicated 256/P times before it is downsampled by the RSZ factor.

**Figure 6-90. Camera ISP VPBE Resizer Approximation Scheme**



This implementation means that a resizing ratio with 256/RSZ times the input size can be obtained. However, each output pixel is rounded to the nearest interpolated output of 1/P input-pixel precision. The polyphase filter coefficients are programmable so that any user-specified filter can be implemented. It is recommended that coefficient sets be chosen to implement a sample rate converter where a low-pass filter is used, with a cutoff frequency as shown in [Figure 6-91](#).

**Figure 6-91. Camera ISP VPBE Resizer Cutoff Frequency for Low-Pass Filter**

$$\omega_c = \min\left(\frac{\pi}{P}, \frac{\pi}{\left(\frac{P \times RSZ}{256}\right)}\right)$$

camisp-E126

If polyphase resampling is used, all upsampling factors can share the same set of coefficients. However, a different coefficient set is required when changing between 8-phase and 4-phase modes, and with different downsampling factors.

32 programmable coefficients are available for the horizontal direction (registers [RSZ\\_HFILT10](#) to

[RSZ\\_HFILT3130](#)) and another 32 programmable coefficients are available for the vertical direction (registers [RSZ\\_VFILT10](#) to [RSZ\\_VFILT3130](#)). The 32 programmable coefficients are arranged as either 4 taps and 8 phases for the resizing range of 1/2 ~ 4 (RSZ = 64 ~ 512), or 7 taps and 4 phases for a resizing range of 1/4 ~ 1/2 (RSZ = 513 ~ 1024)(RSZ is either HRSZ or VRSZ). [Table 6-42](#) shows the arrangement of the 32 filter coefficients. Each tap is arranged in S10Q8 format.

**Table 6-42. Camera ISP VPBE Resizer Arrangement of the Filter Coefficients**

| Filter Coefficient | 0.5x to ~4x |     | 0.24x to ~0.5x |          |
|--------------------|-------------|-----|----------------|----------|
|                    | Phase       | Tap | Phase          | Tap      |
| 0                  | 0           | 0   | 0              | 0        |
| 1                  |             | 1   |                | 1        |
| 2                  |             | 2   |                | 2        |
| 3                  |             | 3   |                | 3        |
| 4                  | 1           | 0   | 1              | 4        |
| 5                  |             | 1   |                | 5        |
| 6                  |             | 2   |                | 6        |
| 7                  |             | 3   |                | Not used |
| 8                  | 2           | 0   | 1              | 0        |
| 9                  |             | 1   |                | 1        |
| 10                 |             | 2   |                | 2        |
| 11                 |             | 3   |                | 3        |
| 12                 | 3           | 0   | 1              | 4        |
| 13                 |             | 1   |                | 5        |
| 14                 |             | 2   |                | 6        |
| 15                 |             | 3   |                | Not used |
| 16                 | 4           | 0   | 3              |          |
| 17                 |             | 1   |                |          |
| 18                 |             | 2   |                |          |
| 19                 |             | 3   |                |          |
| 20                 | 5           | 0   | 3              | 0        |
| 21                 |             | 1   |                | 1        |
| 22                 |             | 2   |                | 2        |
| 23                 |             | 3   |                | 3        |
| 24                 | 6           | 0   | 3              | 4        |
| 25                 |             | 1   |                | 5        |
| 26                 |             | 2   |                | 6        |
| 27                 |             | 3   |                | Not used |
| 28                 | 7           | 0   | 3              | 0        |
| 29                 |             | 1   |                | 1        |
| 30                 |             | 2   |                | 2        |
| 31                 |             | 3   |                | 3        |

The indexing scheme of coefficients is oriented for dot-product (or inner product), rather than for impulse response. In other words, the first data point contributing to a particular output is multiplied by the coefficient associated with tap 0, and the last data point is multiplied by the coefficient associated with tap 3 or tap 6 (depending on whether it is 4-tap or 7-tap mode). The normal raster-scan order is used where the upper-left corner gets the (0, 0) coordinate. Pixel 0 is the left-most column of pixels for horizontal resizing, and the top-most row of pixels for vertical resizing. [Figure 6-92](#) shows an example of the alignment of input pixels to tap coefficients using a simple 1:1 resize case (4-tap mode). In this example, only one phase output is necessary.

[Figure 6-92](#) shows the alignment of input pixels to tap coefficients.

**Figure 6-92. Camera ISP VPBE Resizer Alignment of Input Pixels to Tap Coefficients**

camisp-116

Figure 6-92 also shows how the first output is computed when all taps are aligned with input pixels. To compute the last several pixels in each line/column, the filter requires more input pixels than the following equation calculates:

$$\text{input size} = \text{output size} * \text{RSZ}/256$$

In the former example, where the input size is X and the output size is Y, three extra input pixels are required to generate the correct number of output pixels:

$$X = Y * 256/256 + 3 \text{ (to account for the extra pixels required for filtering)}$$

The input size calculation depends on the starting phase and rounding issues in the algorithm. [Table 6-43](#) lists the input size calculations derived from the algorithm description in [Section 6.4.7.2.5](#). The input width and height parameters must be programmed strictly according to these equations; otherwise, incorrect hardware operation may occur.

**Table 6-43. Camera ISP VPBE Resizer Input Size Calculations**

|                                | 8-Phase, 4-Tap Mode                                             | 4-Phase, 7-Tap Mode                                             |
|--------------------------------|-----------------------------------------------------------------|-----------------------------------------------------------------|
| <b>RSZ_IN_SIZE[12:0] HORZ</b>  | $(32 * \text{sph} + (\text{ow} - 1) * \text{hrs} + 16) * 8 + 7$ | $(64 * \text{sph} + (\text{ow} - 1) * \text{hrs} + 32) * 8 + 7$ |
| <b>RSZ_IN_SIZE[28:16] VERT</b> | $(32 * \text{spv} + (\text{oh} - 1) * \text{vrs} + 16) * 8 + 4$ | $(64 * \text{spv} + (\text{oh} - 1) * \text{vrs} + 32) * 8 + 7$ |

Where:

sph = Start phase horizontal ([RSZ\\_CNT \[22:20\] HSTPH](#))

spv = Start phase vertical ([RSZ\\_CNT \[25:23\] VSTPH](#))

ow = Output width ([RSZ\\_OUT\\_SIZE \[11:0\] HORZ + extra](#))

oh = Output height ([RSZ\\_OUT\\_SIZE \[27:16\] VERT](#))

hrs = Horizontal resize value ([RSZ\\_CNT \[9:0\] HRSZ + 1](#))

vrs = Vertical resize value ([RSZ\\_CNT \[19:10\] VRSZ + 1](#))

extra = 0 when [RSZ\\_YENH \[17:16\] ALGO = 0](#) (edge enhancement disabled)

extra = 4 when [RSZ\\_YENH \[17:16\] ALGO != 0](#) (edge enhancement enabled)

The horizontal and vertical starting phases can be programmed in the **RSZ\_CNT** [22:20] HSTPH and **RSZ\_CNT** [25:23] VSTPH fields, respectively. The chrominance data can be resized using bilinear interpolation or the same algorithm as the luminance data (**RSZ\_CNT** [29] CBILIN).

The following section explains how these fields are used in the algorithm.

#### 6.4.7.2.5 Camera ISP VPBE Resizer Resampling Algorithm

The resizer module uses the same resampling algorithm for the horizontal and vertical directions. For the rest of this section, the horizontal direction is used in describing the resampling algorithm. The algorithm is described first for the 4-tap/8-phase mode, then for the 7-tap/4-phase mode.

[Section 6.4.7.2.5.1](#) and [Section 6.4.7.2.5.2](#) explain the generic algorithm without detailing the differences between color components. [Section 6.4.7.2.5.3](#) describes how interleaved chroma are processed when input is YUV422.

##### 6.4.7.2.5.1 Camera ISP VPBE Resizer 4-Tap/8-Phase Mode

In the 4-tap/8-phase mode, the coefficients for each of the 8 phases may be set to interpolate 8 intermediate pixels between input pixels. For each output pixel calculation, a fine-input pointer with 1/256 input-pixel precision is incremented by the **RSZ\_CNT** [9:0] HRSZ +1 value. A coarse-input pointer with 1/8 input-pixel precision (corresponds to one of the 8 phases) is calculated by rounding the fine-input pointer to the nearest 1/8 pixel. The output pixel is calculated by the dot product of the coefficients of the phase filter (selected by the coarse-input pointer) and the appropriate four input pixels. [Figure 6-93](#) shows a pseudo-code description of the resizer algorithm in the 4-tap/8-phase mode.

**Figure 6-93. Camera ISP VPBE Resizer Pseudo-Code Description of the Resizer Algorithm in the 4-Tap/8-Phase Mode**



camisp-064

- The starting input pixel location (in whole pixels) (see [Section 6.4.7.2.3, Camera ISP VPBE Resizer Input and Output Interfaces](#)) and the starting phase (in 1/8 pixel) (**RSZ\_CNT** [22:20] HSTPH) are programmed through the resizer registers.
- A fine-input pointer is maintained in 1/256-pixel precision.
- A coarse-input pointer and a pixel-input pointer are computed for each output, based on the fine-input pointer.
- The coarse-input pointer is in 1/8 pixel precision. The pixel-input pointer is in whole-pixel precision.
- Initially, fine-input pointer = 256\* starting input pixel + 32\* starting phase - 256. The fine-input pointer defines the starting 1/8 pixel location covered by the filter waveform.
- For each output pixel:

```

Coarse-input pointer = /* Rounded to the nearest phase */
(fine-input pointer + 16) 5
Pixel-input pointer = /* Rounded up to a whole pixel, when already on an
(coarse-input pointer 3) + 1 integer pixel, go to next one to simplify coefficient
                                         organization */
Coefficient phase = /* 3 LSBs = phase */
(coarse-input pointer 7)
Output = dot product of the 4 coefficients and the 4 inputs starting with pixel-input pointer
Clip output to 8-bit unsigned for luma, 8-bit signed for chroma

```

- ```

fine-input pointer = fine-input pointer
+ (RSZ_CNT [9:0] HRSZ + 1)
/* distance between outputs = 1/resize_factor = (RSZ_CNT [9:0] HRSZ + 1) /256 = (RSZ_CNT
[9:0] HRSZ + 1) in 1/256 precision */

• Same algorithm in the horizontal and vertical directions, except with separate initial pixel/phase values
and separate RSZ values.

```

#### 6.4.7.2.5.2 Camera ISP VPBE Resizer 7-Tap/4-Phase Mode

In the 7-tap/4-phase mode, the coefficients for each of the 4 phases may be set to interpolate 4 intermediate pixels between input pixels. For each output pixel calculation, a fine-input pointer with 1/56 input-pixel precision is incremented by the RSZ\_CNT [9:0] HRSZ + 1 value. A coarse-input pointer with 1/2 input-pixel precision (corresponds to one of the 4 phases) is calculated by rounding the fine-input pointer to the nearest 1/2 pixel. The output pixel is calculated by the dot product of the coefficients of the phase filter (selected by the coarse-input pointer) and the appropriate 7 input pixels. Figure 6-94 shows a pseudo-code description of the resizer algorithm in the 7-tap/4-phase mode.

**Figure 6-94. Camera ISP VPBE Resizer Pseudo-Code Description of the Resizer Algorithm in the 7-Tap/4-Phase Mode**



camisp-065

- The starting input-pixel location (in whole pixels) (see [Section 6.4.7.2.3, Camera ISP VPBE Resizer Input and Output Interfaces](#)) and the starting phase (in 1/2 pixel) (RSZ\_CNT [22:20] HSTPH) are programmed through the resizer registers.
- A fine-input pointer is maintained in 1/256 pixel precision.
- A coarse-input pointer and a pixel-input pointer are computed for each output based on the fine-input pointer.
- The coarse-input pointer is in 1/2 pixel precision. The pixel-input pointer is in whole-pixel precision.
- Initially, fine-input pointer = 256 \* starting input pixel + 64 \* starting phase - 256. The fine-input pointer defines the starting 1/2 pixel location covered by the filter waveform.
- For each output pixel:

```

Coarse-input pointer =           /* Round to the nearest phase */
(fine-input pointer + 32) 6
Pixel-input pointer =           /* Round up to a whole pixel; when already on an
(coarse-input pointer 2) + 1   integer pixel, go to next one to simplify coefficient
                             organization */
Coefficient phase =           /* 2 LSBs = phase */
(coarse-input pointer 3)
Output = Dot product of the 7 coefficients and the 7 inputs starting with the pixel-input
pointer
Clip output to 8-bit unsigned for luma, 8-bit signed for chroma
/* It is acceptable to require the 8th coefficients to be filled with zeros by firmware so that 8
coefficients and 8 inputs, the last input being don't care value, are multiply-added */
Fine-input pointer = Fine input pointer + (RSZ_CNT [9:0] HRSZ + 1)
/* Distance between outputs = 1/resize_factor = (RSZ_CNT [9:0] HRSZ + 1)/256 =
(RSZ_CNT [9:0] HRSZ + 1) in 1/256 precision */

```

- Same algorithm in both the horizontal and vertical directions, but with separate initial pixel/phase values and separate RSZ values.

**NOTE:** The pixel-input pointer (pip) in the algorithm description, points to pixels, not bytes or shorts in the memory. The fine-input pointer (fip) points to a 1/256 resolution sub-pixel position. The coarse-input point (cip) points to a 1/8 or 1/4 resolution sub-pixel location, depending on the number of phases.

#### 6.4.7.2.5.3 Camera ISP VPBE Resizer Horizontal Resizing With Interleaved Chroma

Chroma inputs, Cb and Cr, are 8-bit unsigned values that represent 128-biased 8-bit signed values (the signed chroma are called U and V instead of Cb and Cr). During the resizing computation, the chroma values have the 128 bias subtracted to convert to the 8-bit signed format. After vertical resizing, the 128 bias is added back to convert back to 8-bit unsigned format.

Chroma components, which are 2:1 horizontally downsampled with respect to luma, have two methods of horizontal resizing processing: filtering with luma, and bilinear interpolation.

The horizontal resizing with interleaved chroma option can be selected in the [RSZ\\_CNT \[29\]](#) CBILIN field independently of the [RSZ\\_CNT \[22:20\]](#) HSTPH parameters. However, filtering with luma is intended only for downsampling, and bilinear interpolation is intended only for upsampling.

For horizontal resizing of Y/Cb/Cr in a combined filtering flow, the algorithm is modified as shown in the following algorithm descriptions:

##### Filter Chroma With Luma (4-Tap/8-Phase Mode):

```
For (i=0; i<output_width; i++) { /* output width depends of input width and resizing factors*/
    Coarse-input pointer = (fine-input pointer + 16) 5          /* Round to nearest phase */
    Pixel-input pointer = (coarse-input pointer 3) + 1          /* Round up to a whole pixel */
    Coefficient phase = pixel-input pointer 7                  /* 3 LSB = phase */
    if (i 1 == 0) { /* even output pixel, generate YCbCr */
        Yout = dot product of the 4 coefficients and the 4 Y inputs starting with pixel-input pointer
        Cbout = dot product of the 4 coefficients and the 4 upsampled Cb inputs starting with
                pixel-input pointer
        Crout = dot product of the 4 coefficients and the 4 upsampled Cr inputs starting with
                pixel-input pointer
        Clip outputs to 8-bit unsigned for luma, 8-bit
                signed for chroma
    }
    Else /* odd output pixel, generate Y only */
        Yout = dot product of the 4 coefficients and the 4 Y inputs starting with pixel-input pointer
        Clip output to 8-bit unsigned
    }
    Fine-input pointer = fine-input pointer + (RSZ\_CNT \[9:0\] HRSZ + 1)
}
}
```

##### Filter Chroma With Luma (7-Tap/4-Phase Mode):

```

For (i=0; ioutput_width; i++) { /* output width depends of input width and resizing factors*/
    Coarse-input pointer = (fine-input pointer + 32) 5      /* Round to nearest phase */
    Pixel-input pointer = (coarse-input pointer 2) + 1       /* Round up to a whole pixel */
    Coefficient phase = pixel-input pointer 3                /* 2 LSB = phase */

    if (i 1 == 0) { /* Even output pixel, generate YCbCr */
        Yout = dot product of the 7 coefficients and the 7 Y inputs starting with pixel-input pointer
        Cbout = dot product of the 7 coefficients and the 7 upsampled Cb inputs starting with
        pixel-input pointer
        Crout = dot product of the 7 coefficients and the 7 upsampled Cr inputs starting with
        pixel-input pointer
        Clip outputs to 8-bit unsigned for luma, 8-bit
        signed for chroma
    }

    Else /* Odd output pixel, generate Y only */
        Yout = dot product of the 7 coefficients and the 7 Y inputs starting with pixel-input pointer
        Clip output to 8-bit unsigned
    }

    Fine-input pointer = fine-input pointer + (RSZ\_CNT [9:0] HRSZ + 1)
}
}

```

---

**NOTE:** The chroma input values are internally replicated to realize 1:2 upsampling to line up with luma input values. Only required chroma outputs are computed; they correspond to even luma outputs.

---

### Bilinear Interpolation (4-Tap or 7-Tap):

For the bilinear interpolation flow of chroma horizontal resizing, the algorithm is adapted as follows. For the bilinear interpolation option, it is not necessary to replicate chroma samples.

```

For (i=0; ioutput_width; i++) {
    if (i 1 == 0) { /* even output pixel, generate YCbCr */
        Coarse-input pointer = ... /*Calculation issued from 4 taps or 7
        taps*/
        Pixel-input pointer = ... /*Calculation issued from 4 taps or 7 taps*/
        Yout = dot product of ... /*Calculation issued from 4 taps or 7
        taps*/
        C_fine_input_pointer = fine_input_pointer + 128*ntaps           /* Points to center of filter
        kernel */
        Cidx = C_fine_input_pointer 9                                     /* Truncate to even pixel
        grid to find left value */

        Cbin[0] = Cb[Cidx]
        Cbin[1] = Cb[Cidx + 1]
        Crin[0] = Cr[Cidx]
        Crin[1] = Cr[Cidx + 1]
        frac = C_fine_input_pointer 511                                /* 9-bit fraction */
        Cbout = ((512 - frac) * Cbin[0] + frac * Cbin[1] + 256) 9
        Crout = ((512 - frac) * Crin[0] + frac * Crin[1] + 256) 9
        Clip outputs to 8-bit unsigned for luma, 8-bit signed for chroma
    }
}

```

```

        Fine-input pointer = fine-input pointer + (RSZ\_CNT [9:0] HRSZ + 1)
    }
    Else /* odd output pixel, generate Y only */
    ...
}

```

In the former algorithm, fixed-point arithmetic is used. The variable *frac* is an unsigned integer representing the fraction *f*. Thus,  $1 - f$  becomes  $512 - \text{frac}$ . After the sum of products, 256, representing 0.5 real-numbers, is added to the sum, and then the sum is right-shifted by 9 bits to get back to the integer chroma representation.

In both algorithm options, the chroma outputs computed are interleaved with luma values to generate the YCbYCr output format (or the alternate format specified in [RSZ\\_CNT](#) [26] YCPOS).

In the vertical resizing stage, the two chroma planes are processed interleaved as one separate image. Because there is no resolution issue vertically, and no horizontal dependency in vertical resizing, the vertical scheme is consistent with conventional processing, and is not analyzed here.

#### **6.4.7.2.5.4 Camera ISP VPBE Resizer Algorithm Functionality**

[Table 6-44](#) is an example of 1:2.56 (hrs = 100) horizontal resizing that illustrates the address calculation and chroma processing in 4:2:2 format (4-tap 8-phase mode). The starting pixel and phase are assumed to be zero.

**Table 6-44. Camera ISP VPBE Resizer Processing Example for 1:2:56 Horizontal Resize**

| Output                                                 | Y0      | Cb0 | Cr0 | Y1      | Y2  | Cb2 | Cr2     | Y3 | Y4  | Cb4     | Cr4 | Y5  |
|--------------------------------------------------------|---------|-----|-----|---------|-----|-----|---------|----|-----|---------|-----|-----|
| <b>fip (= hrsz)</b>                                    | -256    |     |     | -156    | -56 |     |         | 44 | 144 |         |     | 244 |
| <b>cip (= (fip+16)5)</b>                               | -8      |     |     | -5      | -2  |     |         | 1  | 5   |         |     | 8   |
| <b>pip (= (cip3) + 1)</b>                              | 0       |     |     | 0       | 0   |     |         | 1  | 1   |         |     | 2   |
| <b>coef ph (= cip 7)</b>                               | 0       |     |     | 3       | 6   |     |         | 1  | 5   |         |     | 0   |
| <b>Inputs needed (chroma filtered like luma)</b>       | Y0      | Cb0 | Cr0 | Y0      | Y0  | Cb0 | Cr0     | Y1 | Y1  | Cb0     | Cr0 | Y2  |
|                                                        | Y1      | Cb2 | Cr0 | Y1      | Y1  | Cb0 | Cr0     | Y2 | Y2  | Cb2     | Cr2 | Y3  |
|                                                        | Y2      | Cb2 | Cr2 | Y2      | Y2  | Cb2 | Cr2     | Y3 | Y3  | Cb2     | Cr2 | Y4  |
|                                                        | Y3      | Cb2 | Cr2 | Y3      | Y3  | Cb2 | Cr2     | Y4 | Y4  | Cb4     | Cr4 | Y5  |
| <b>Cfip (= fip+512)</b>                                | 256     |     |     | 488     |     |     | 720     |    |     |         |     |     |
| <b>Cidx (= Cfip 9)</b>                                 | 0       |     |     | 0       |     |     | 1       |    |     |         |     |     |
| <b>Inputs needed for chroma bilinear interpolation</b> | Cb0 Cr0 |     |     | Cb0 Cr0 |     |     | Cb2 Cr2 |    |     | Cb4 Cr4 |     |     |
|                                                        | Cb2 Cr2 |     |     | Cb2 Cr2 |     |     | Cb4 Cr4 |    |     |         |     |     |

Note the distinction between using {Cb0, Cb0, Cb2, Cb2} and {Cb0, Cb2, Cb2, Cb4} as input to the filter. The 4 filter taps are applied in order, so with the different chroma component repetition, the result is different (even when the coefficient phase is the same).

The Cidx of the chroma bilinear interpolation flow points to the chroma sample in linear array order, so Cidx = 1 means we Cb2 and Cb4 are being grabbed.

#### **6.4.7.2.6 Camera ISP VPBE Resizer Luma Edge Enhancement**

Edge enhancement can be applied to the horizontally resized luminance component before the output of the horizontal stage is sent to the line memories and the vertical stage. The [RSZ\\_YENH](#) [17:16] ALGO parameter can be set to disable edge enhancement, or to select a 3-tap or a 5-tap horizontal high-pass filter (HPF) for luminance enhancement. The edge enhancement algorithm is as follows:

If edge enhancement is selected, the two left-most and two right-most pixels in each line are not outputted to the line memories and the vertical stage. The **RSZ\_OUT\_SIZE [11:0]** HORZ register is the final output width, up to 1280 pixels when vertical 4-tap mode is used, and up to 640 pixels when vertical 7-tap mode is used. When edge enhancement is enabled, the horizontal resizer output width used to calculate the required input width must be **RSZ\_OUT\_SIZE [11:0]** HORZ + 4.

---

**NOTE:** Some details of this feature are not available in the public domain,

---

**RSZ\_YENH [7:0]** CORE is in U8Q0. **RSZ\_YENH [11:8]** SLOP is in U4Q4. **RSZ\_YENH [15:12]** GAIN is in U4Q4.

## 6.4.8 Camera ISP Statistics Collection Modules

The statistics-collection modules (SCMs) are the H3A and histogram modules that provide statistics on the incoming images to help designers of camera systems.

### 6.4.8.1 Camera ISP H3A

#### 6.4.8.1.1 Camera ISP H3A Features

The H3A module supports control loops for autofocus, auto white balance, and auto exposure by collecting metrics about the imaging/video data. The metrics are used to adjust parameters for processing the imaging/video data. There are two main blocks in the H3A module:

- Autofocus engine (AF):

The AF submodule extracts and filters the red, green, and blue data from input image data and provides the accumulation or peaks of the data in a specified region. The specified region is a two-dimensional block of data referred to as a paxel. The AF engine supports the following features:

- Peak mode in a paxel (a paxel is defined as a two dimensional block of pixels): Accumulate the maximum focus value of each line in a paxel.
- Accumulation of the maximum focus value of each line in a paxel
- Accumulation mode
- Accumulation/sum mode (instead of peak mode): Accumulation of focus value in a paxel
- Up to 36 pexels/windows in the horizontal direction and up to 128 pexels/windows in the vertical direction
- Programmable width and height for the paxel/window
- Programmable red, green, and blue position within a 2x2 matrix
- Separate horizontal start for paxel and filtering
- Programmable vertical line increments within a paxel
- Parallel IIR filters configured in a dual-biquad configuration with individual coefficients (2 filters with 11 coefficients each)

- Auto exposure and auto white balance engine (AE/AWB)

The AE/AWB engine accumulates values and checks for saturated values in a subsampling of the video data. In the case of the AE/AWB, the two-dimensional block of data is referred to as a window. Thus, other than having different names, pexels and windows are essentially the same. However, the numbers, dimensions, and starting positions of AF pexels and AE/AWB windows are programmable separately. AE/AWB supports the following features:

- Accumulation of clipped pixels along with all nonsaturated pixels
- Up to 36 horizontal windows/pixel and up to 128 vertical windows/pixel
- Separate vertical start coordination and height for a black row of pexels different from the remaining color pexels
- Programmable horizontal and vertical sampling points in a window

**NOTE:** Some details of this feature are not available in the public domain.

#### 6.4.8.1.2 Camera ISP H3A Autofocus Engine

The autofocus engine works by extracting each red, green, and blue pixel from the video stream and subtracting a fixed offset from the pixel value (128 when A-Law is enabled or 512 when A-Law is disabled). The offset value is then passed through two IIR filters, and the absolute values of the filter outputs are the focus values (FV). For each pixel, the pixel values and the two focus value outputs are accumulated for each color and sent to memory. The following sections describe this process in more detail.

Only RAW10 data is supported by the autofocus function. In some cases, RAW8 or RAW12 data can be converted to RAW10 using the data-lane shifter.

#### 6.4.8.1.3 Camera ISP H3A AE/AWB Engine

The AE/AWB engine starts by dividing the frames into windows and further subsampling each window into 2x2 blocks. Then, for each subsampled 2x2 block, each pixel is accumulated. Also, each pixel is compared to a limit set in a register. If any pixels in a 2x2 block are greater than or equal to the limit, the block is not counted in the unsaturated block counter. Pixels greater than the limit are replaced by the limit, and the value of the pixel is accumulated.

#### 6.4.8.2 Camera ISP Histogram

##### 6.4.8.2.1 Camera ISP Histogram Features

The histogram accepts RAW image/video data from either the video-port interface of the CCDC or from memory, performs a color-separate gain on each pixel (white/channel balance), and bins the pixels according to the amplitude, color, and region specified through the CCDC register settings. It can support 4 colors (Bayer), and up to 4 regions, simultaneously. [Figure 6-95](#) shows the processing of the histogram module.

The histogram module is typically used with 3A metrics by the host processor to adjust various parameters for processing image data. The following features are supported:

- Flexible input: Input data can come from the RAW image sensor (through the CCDC module) or from memory.
- Color-separate gain: A digital gain per color component can be applied before histogram computation.
- Histogram computation: The module performs pixel binning of the incoming RAW image data. Each bin collects the number of pixels with values in a range. If no saturation occurs, the sum of the values in every bin is equal to the total number of pixels in the input image. The histogram computation can occur over one frame or be accumulated over multiple frames. The computation occurs on rectangular regions. A histogram is computed for each color component in the image:
  - The RAW image data dynamic can be up to 10 bits (pixel values in the range 0 to 1023).
  - Range: Each bin covers a pixel range. Each bin can cover a maximum of 128 pixel values.
  - Programmable regions: There can be up to four regions. The region positions and horizontal and vertical sizes are programmable. When regions overlap, pixels from the overlapped area are accumulated into the highest-priority region only; region0 has the highest priority and region3 the lowest priority.
  - Programmable number of bins: There can be 32, 64, 128, or 256 bins per color and per region. The number of bins depends on the number of regions, because histogram memory size is fixed.
  - Color components: A histogram is computed for each color component in the RAW image. There are usually 4 color components in Bayer image sensors.
- Saturation: If the pixel count exceeds  $2^{20}-1$ , the pixel count is saturated.
- Memory clear: The histogram memory is cleared automatically when it is read.
- Output: The histogram result is stored in a local RAM read by a system initiator, typically the system DMA, to be written to memory.

#### 6.4.8.2.2 Camera ISP Histogram Block Diagram

**Figure 6-95. Camera ISP Histogram Process**



camisp-073

#### 6.4.8.2.3 Camera ISP Histogram Input Interface

The histogram receives RAW image/video data from the video port interface through the CCDC (which is interfaced to an external sensor) or from the read buffer interface through memory ([HIST\\_CNT \[3\] SOURCE](#)).

The input data is 10 bits wide if the source is the video-port interface. When the input source is from memory, data-bit width can range from 8 to 14 bits. If the input data is 8 bits packed (memory contains two 8-bit pixels for every 16 bits), the [HIST\\_CNT \[8\] DATSIZ](#) bit must be set. If memory contains one pixel for every 16 bits, the DATSIZ bit must be cleared.

Likewise, if memory contains one pixel for every 16 bits, the DATSIZ bit must be cleared. The input memory address ([HIST\\_RADD](#)) and line-offset ([HIST\\_RADD\\_OFF](#)) registers are used to specify the location of the input frame in memory. Both of these registers should be aligned on 32-byte boundaries.

The frame-input width and height are configured using the [HIST\\_H\\_V\\_INFO \[29:16\]](#) HSIZE and [HIST\\_H\\_V\\_INFO \[13:0\]](#) VSIZE register fields, respectively.

The histogram module supports 4-color Bayer color patterns. The [HIST\\_CNT \[6\]](#) CFA field is used to select the color pattern of the input data (Bayer).

#### 6.4.8.2.4 Camera ISP Histogram White Balance

A white-balance gain can be separately applied to each color channel by programming the fields in the [HIST\\_WB\\_GAIN](#) register. [Table 6-45](#) indicates which pixel index in the color pattern corresponds to each field in the WB\_GAIN register.

**Table 6-45. Camera ISP Histogram White Balance Field-to-Pattern Assignments**

| HIST_WB_GAIN fields | Bayer |
|---------------------|-------|
| WG00                | 0     |
| WG01                | 1     |
| WG02                | 2     |
| WG03                | 3     |

---

**NOTE:** There are four different physical locations, with one color per location for Bayer. See [Figure 6-96](#).

---

**Figure 6-96. Camera ISP Histogram Color Pattern Index**

| Bayer |   |
|-------|---|
| 0     | 1 |
| 2     | 3 |

camisp-309

Each gain constant is 8 bits wide with 5 bits of decimal precision (U8Q5).

#### 6.4.8.2.5 Camera ISP Histogram Binning

The histogram bins the input data by amplitude, color, and region (see [Figure 6-97](#)). Each bin is a counter, counting the number of pixels of a color in the range associated with the bin. The number of bins can be programmed to 32, 64, 128, or 256 bins in the **HIST\_CNT [5:4] BINS** field. However, due to limited histogram memory size (1024 words), the number of bins (times 4 colors) limits the number of regions that can be active, as shown in [Table 6-46](#).

**Table 6-46. Camera ISP Histogram Regions and Bins**

| Number of Bins | Number of Regions Allowed |
|----------------|---------------------------|
| 256            | 1                         |
| 128            | 2                         |
| 64             | 4                         |
| 32             | 4                         |

As indicated by [Table 6-46](#), up to four overlapping regions can be designated within the frame. Each region is defined by the horizontal starting (**HIST\_Rn\_HORZ [29:16]** HSTART) and ending (**HIST\_Rn\_HORZ [13:0]** HEND) pixels, and the vertical starting (**HIST\_Rn\_VERT [29:16]** VSTART) and ending (**HIST\_Rn\_VERT [13:0]** VEND) lines (where n is the region number 0...3).

---

**NOTE:** If the starting and ending pixels/lines are the same, the region size is treated as zero, and there is no binning for such a region.

---

##### 6.4.8.2.5.1 Camera ISP Histogram Region Priority

Up to four regions can be active at any time, but a pixel is binned into only one region. The priority is Region 0 Region 1 Region 2 Region 3. For example, the yellow pixel in [Figure 6-97](#) is binned only for Region 0, although it is present in all four regions.

**Figure 6-97. Camera ISP Histogram Region Priority**

#### 6.4.9 Camera ISP Central-Resource Shared Buffer Logic

The central-resource shared buffer logic (SBL) receives data read and write requests from the CCDC, preview, H3A, histogram, resizer, CSI2A, CSI2C, and CSI1/CCP2B modules. It arbitrates between requesters and constructs bursts to transfer data to and from memory.

The central-resource SBL performs the following functions:

- Interface to the CCDC module:
  - Collects output data from the CCDC in the write buffer (1 port)
  - Transfers faulty-pixel table data to the CCDC from the read buffer (2 ports)
  - Transfer lens-shading compensation to the CCDC engine from the read buffer. This port is shared with PREVIEW module dark frame subtract port.
- Interface to the CSI2A, CSI2C, and CSI1/CCP2B receivers:
  - Collects output from CSI2A in the write buffer (1 port)
  - Collects output from CSI1/CCP2B and CSI2C in the write buffer (1 port)
  - Transfer input data to the CSI1/CCP2B from the read buffer. This port is shared with the PREVIEW module input data read port.
- Interface to the preview module:
  - Collects output data from the preview engine in the write buffer (1 port)
  - Transfer input data to the PREVIEW engine from the read buffer (1 ports). This port is shared with CSI1/CCP2B data read port.
  - Transfer dark frame subtract data to the PREVIEW engine from the read buffer . This port is shared with CCDC lens-shading compensation read port.
- Interface to the H3A module:
  - Collects output data from the H3A in the write buffer (2 ports)
- Interface to the histogram module:
  - Transfers input data to the histogram from the read buffer (1 port)
- Interface to the resizer module:
  - Collects output data from the resizer in the write buffer (4 ports)
  - Transfers input data to the resizer from the read buffer (1 port)
- Requests arbitration between the different initiators. Based on fixed priorities.
- Performs throttle memory read requests for preview, resizer, and histogram to limit bandwidth in memory-to-memory operations

#### 6.4.9.1 Camera ISP Shared Buffer Logic Block Diagram

Figure 6-98 shows the central-resource SBL. It comprises WBL and RBL blocks, read and write buffers, and arbitration logic. The VBUSM data-width to the memory is 64 bits.

Figure 6-98. Camera ISP Shared Buffer Logic Block Diagram



camisp-078

NOTE: Red = Reads; Blue = Writes

**CAUTION**

Because some of the read ports are shared, software must enable the modules that will use the shared read port. For more information, see [Section 6.4.9.2.3, Camera ISP Shared Buffer Logic Read Buffer Logic \(RBL\) and Read Buffer](#).

### 6.4.9.2 Camera ISP Shared Buffer Logic Functional Operations

#### 6.4.9.2.1 Camera ISP Shared Buffer Logic Parameters

**Table 6-47** summarizes the central-resource SBL parameters. Those parameters are fixed at design time and cannot be changed by users. The functional operations of the central-resource SBL are based on a fixed data size of 256 bytes called a data unit (DU). P0 has the highest priority and P14 has the lowest priority.

**Table 6-47. Camera ISP Shared Buffer Logic Fixed Parameters**

| Port                 | Port Direction | Port Priority | Buffer Size Bytes | Description                                                                |
|----------------------|----------------|---------------|-------------------|----------------------------------------------------------------------------|
| CSI2A                | WRITE          | P3            | 1024 = 4DUs       | CSI2A output port                                                          |
| CSI1/CCP2B and CSI2C | WRITE          | P2            | 1024 = 4DUs       | CSI1/CCP2B output port or CSI2C output port                                |
| CCDC                 | WRITE          | P4            | 1024 = 4DUs       | CCDC output port                                                           |
|                      | READ           | P1            | 512 = 2DUs        | CCDC fault pixel correction input port                                     |
| PREVIEW              | WRITE          | P9            | 1024 = 4DUs       | PREVIEW output port                                                        |
|                      | READ           | P13           | 1024 = 4DUs       | PREVIEW input port<br>CSI1/CCP2B data input port                           |
|                      | READ           | P0            | 1024 = 4DUs       | PREVIEW dark-frame input port<br>CCDC lens-shading compensation input port |
| RESIZER              | WRITE          | P5            | 1024 = 4DUs       | RESIZER output line 1 port                                                 |
|                      | WRITE          | P6            | 1024 = 4DUs       | RESIZER output line 2 port                                                 |
|                      | WRITE          | P7            | 1024 = 4DUs       | RESIZER output line 3 port                                                 |
|                      | WRITE          | P8            | 1024 = 4DUs       | RESIZER output line 4 port                                                 |
|                      | READ           | P12           | 1024 = 4DUs       | RESIZER input port                                                         |
| H3A                  | WRITE          | P10           | 512 = 2DUs        | H3A output - AF port                                                       |
|                      | WRITE          | P11           | 512 = 2DUs        | H3A output - AE/AWB port                                                   |
| HIST                 | READ           | P14           | 512 = 2DUs        | HIST input port                                                            |

#### 6.4.9.2.2 Camera ISP Shared Buffer Logic Write-Buffer Logic (WBL) and Write Buffer

The central-resource SBL uses multiple WBL blocks to interface between the modules' write ports and the write-buffer memory.

- One WBL is instantiated for each module write port.
- Each WBL collects the module's write port output data and transfers the data to the write-buffer memory. Arbitration occurs between the WBL blocks to access the write-buffer memory.
- Each WBL is responsible for tracking all corresponding DUs in the write-buffer memory. There can be 2 or 4 DUs in the write buffer associated with a WBL.
- A WBL generates a command to memory when:
  - The write data crosses a DU boundary. At this point, the module starts filling a new DU. Also, the WBL generates a command to transfer the previous DU to memory.
  - An end-of-frame occurs. The DU (even if not full) is transferred to memory, and a command is

issued.

- An end-of-line occurs. The DU (even if not full) is transferred to the memory, and a command is issued.

#### **6.4.9.2.3 Camera ISP Shared Buffer Logic Read Buffer Logic (RBL) and Read Buffer**

The central resource SBL uses multiple RBL blocks to interface between the modules' read ports and the read-buffer memory.

- One RBL is instantiated for each module read port.
- Each RBL is responsible for accepting input data from the read-buffer memory and for sending the input data to the read port of the corresponding module.
- Each RBL is responsible for tracking all corresponding DUs in the read-buffer memory. There can be 2 or 4 DUs in the read buffer associated with a RBL.
- Unlike the WBL, the RBL is not responsible for issuing the commands to memory; each individual module is responsible for doing this.

Two read ports are shared:

- Between the PREVIEW module dark frame and the CCDC lens-shading compensation input
- Between the PREVIEW module and the CSI1/CCP2B module data read input

They can only be used by one module at a given time because there is no arbitration mechanism. Software must enable only one of the two possible features attached to a port and to select the correct multiplexer configuration using the [ISP\\_CTRL \[27\]](#) SBL\_SHARED\_RPORTA and [ISP\\_CTRL \[28\]](#) SBL\_SHARED\_RPORTB registers.

#### **6.4.9.2.4 Camera ISP Shared Buffer Logic Arbitration**

The central-resource SBL arbitrates between module requests, based on fixed priorities. Read and write requests are arbitrated independently.

A total of 8 commands can be active at a time. When a new slot opens, the highest-priority transfer enters the command queue.

RBLs/WBLs are ensured access to the read/write buffer memories at least once every other cycle.

---

**NOTE:** The hardware uses burst. All bursts are precise; the total number of transfers in the burst is known at the start of the burst. All writes are posted.

---

#### **6.4.9.3 Camera ISP Shared Buffer Logic Memories**

The central-resource shared-buffer module has three memories:

- READ BUFFER: Shared by all modules 256 x 128 bits.
- WRITE BUFFER 0: Used only by the resizer module 256 x 128 bits.
- WRITE BUFFER 1: Shared by all modules except RESIZER 256 x 128 bits.

#### **6.4.9.4 Camera ISP Shared Buffer Logic Debug Registers**

Some registers are available for debugging data transfers between a module and external memory. The read-only debug registers are divided into two categories:

- 8 global request registers to capture information about any of the 52 module request registers at a given time. Each register provides information about one DU. The number 16 corresponds to the maximum number of outstanding requests, according to the protocol. Each global request register provides the following information:
  - Individual module register command number. For modules with 2 individual requesters, this field displays either 0 or 1. For modules with 4 individual requesters, this field displays 0, 1, 2, or 3.
  - Source or destination module

- Data-flow direction
- Valid bit
- 52 individual module request registers (read or write information). Each register provides information about one DU. The number of request registers assigned (2 or 4) depends on memory bandwidth requirements; modules with lower requirements are assigned 2 request registers, while modules with higher bandwidths are assigned 4 request registers.

**Table 6-48. Camera ISP Shared Buffer Logic Number of Request Registers**

| Port                 | RD/WR | Nb Request Registers   | Description                       |
|----------------------|-------|------------------------|-----------------------------------|
| CSI2A                | WRITE | 4 WR request registers | CSI2A output                      |
| CSI1/CCP2B and CSI2C | WRITE | 4 WR request registers | CSI1/CCP2B or CSI2C output        |
| CCDC                 | WRITE | 4 WR request registers | CCDC output                       |
|                      | READ  | 2 RD request registers | CCDC fault pixel correction input |
| PREVIEW              | WRITE | 4 WR request registers | PREVIEW output                    |
|                      | READ  | 4 RD request registers | PREVIEW input                     |
|                      | READ  | 4 RD request registers | PREVIEW dark-frame input          |
| RESIZER              | WRITE | 4 WR request registers | RESIZER output line 1             |
|                      | WRITE | 4 WR request registers | RESIZER output line 2             |
|                      | WRITE | 4 WR request registers | RESIZER output line 3             |
|                      | WRITE | 4 WR request registers | RESIZER output line 4             |
|                      | READ  | 4 RD request registers | RESIZER input port                |
| H3A                  | WRITE | 2 WR request registers | H3A output - AF port              |
|                      | WRITE | 2 WR request registers | H3A output - AE/AWB port          |
| HIST                 | READ  | 2 RD request registers | HIST input                        |

Each write-request register provides the following information:

- Current byte count: Number of bytes in the block of data for this command, up to 256 bytes
- Data ready: Block of data confirmed by the module
- Data sent: Data sent to the destination and waiting for status
- Upper 20 bits of the address

Each read-request register provides the following information:

- Valid: Read requested from the module
- Waiting for data: Command accepted from the source
- Data available: Data received from the source and can be read by the module
- Byte count requested: Up to 256 bytes
- Upper 20 bits of the address

#### 6.4.10 Camera ISP Circular Buffer

The circular buffer (CBUFF) maps a virtual space to a physical space by address translation. It does not change the data or store it locally.

---

**NOTE:** Addresses can be further translated by the MMU.

---

##### 6.4.10.1 Camera ISP Circular Buffer Feature List

The features are listed below:

- Two independent circular buffers (CBUFF0 and CBUFF1)
- Linear address space (virtual) mapped into a circular space (physical)
- Fully transparent for accesses out of the configured virtual space

- Maximum physical buffer size of 16x16M bytes:
  - Physical space is composed by 2,4,8 or 16 windows
  - Maximum allowed window size is 16M bytes
- Support for multiline write patterns
  - Used together with the resizer in upscale mode. Each buffer must contain at least ceil (vertical zoom factor) images lines
- Support of 2D addressing modes
- Memory fragmentation support for CBUFF0
- VRFB context grouping support
- Strong error detection mechanisms
- Buffer addresses are 64-bit aligned, but window fill level managing is byte accurate.
- Read and write accesses are supported.
- Bandwidth Control Feedback loop connected to the CSI1/CCP2B receiver flexible input

#### 6.4.10.2 Camera ISP Circular Buffer Interrupts

All events generated (see [Table 6-16](#) for details) by the circular buffer are merged into a single event at camera ISP level. This event can be mapped to MPU SS by enabling the [ISP IRQ0ENABLE](#) [21] CBUFF\_IRQ bit or to IVA2.2 by enabling the [ISP IRQ1ENABLE](#) [21] CBUFF\_IRQ bit.

#### 6.4.10.3 Camera ISP Circular Buffer Functional Description

The CBUFF module maps a virtual address space to a physical space called circular buffer. The CBUFF module can handle up to 2 independent circular buffers CBUFF0 and CBUFF1.

This section gives an overview of typical uses of the module.

##### 6.4.10.3.1 Camera ISP Circular Buffer Bandwidth Control Feedback Loop

The bandwidth control feedback (BCF) feature can be used in memory to memory operation when the camera ISP reads data through the CS1b receivers flexible input.

At a given time a certain number of physical buffers are available for the processor. Depending, if the circular buffer is configured in read or write mode, the processor can, respectively, write or read those physical buffers.

When the number of physical buffers to be processed by the processor increases, the number of physical buffers available to the camera ISP decreases. When the number of physical buffers available for the camera ISP becomes too low, the corresponding BCF signal is asserted. This signal can be used to stall the data read flow.

The camera ISP supports two mechanisms to reduce the processing speed in memory to memory operation:

- Add a fixed delay between memory read requests. Delays can be added:
  - At SBL level for all image data read ports (histogram, preview, CSI1/CCP2B and resizer)
  - At CSI1/CCP2B module level by slowing down the video port clock
- Stall memory reads based on the level of the circular buffer. That is the purpose of the BCF feature described in this section.

##### 6.4.10.3.1.1 Camera ISP Circular Buffer Single Slice Mode

The camera ISP writes data with an incremental addressing scheme to the virtual space. The physical buffer is smaller than the virtual space. Therefore, the physical buffer locations is read or written multiple times. See [Figure 6-99](#).

**Figure 6-99. Camera ISP Circular Buffer Single Slice Buffer (Write Mode)**



Physically, this circular buffer is typically in the SDRAM. The virtual space is defined by a start and an end address. The physical buffer is defined by a start address, a window size, and a window count. It is contiguous in memory.

Figure 6-100 shows the buffer organization for a 4-window buffer.

**Figure 6-100. Camera ISP Circular Buffer Single Slice Buffer Example (Write Mode)**



camisp-165

The CBUFF module can manage two independent circular buffers in single slice mode.

In case of memory-to-memory operation, the module using the data (that is, JPEG CODEC) written by the ISP into the circular buffer may be slower than the camera ISP. That is especially the case when the resizer is used for upscaling.

In this section, it is assumed that the data to be read by the camera ISP is a full frame completely present in physical memory. Sliced buffer capability is only used the buffer data at the output of the camera ISP. Therefore, the circular buffer is configured in write mode.

The basic idea is to stall the read data flow at CSIb flexible input level. This is done by blocking the response phase of the CSIb interconnect read master port. Blocking the response phase rather than the request phase allows data prefetch at SBL level.

When the count of full windows is greater than or equal to the value defined in the **CBUFFx\_CTRL[7:4]** BCF register, the data flow between the SBL buffer and the CSI1/CCP2B data read port is stalled. Data transfers resume when the full window count falls below the defined limit.

Stalling the data flow at this level does not prevent the SBL from fetching data until its buffers are full. Therefore, when data transfer resumes, data are available quickly at the CSI1/CCP2B read port level, and ISP processing can resume.

Due to SBL buffering, some data may be sent out to the circular buffer when the stall command is activated. Firmware must allocate enough space in the circular buffer to avoid an overflow. The amount of buffered data depends on the ISP configuration:

- The camera ISP Video processing hardware can contain up to 10 pixels that are sent to the SBL after stall control is activated.
- The SBL can store up to four DUs at the output of the PREVIEW module. Therefore, when the circular buffer is filled from the PREVIEW module there must be enough space to store the extra 1K byte of data.
- The data path between the resizer and preview module goes through the SBL and data is internally buffered. The SBL can buffer up to 4 DUs between the PREVIEW and RESIZER module. In other words, when the input of the PREVIEW module is stalled, the RESIZER receives up to 2K bytes before it stalls.
- The SBL can store up to four DUs for each of the RESIZERS write ports. The count of ports used by the resizer depends on the vertical scaling factor; it uses  $\text{ceil}(\text{vscale})$  ports. Each port writes into one image line and can buffer up to 1K byte.
- Depending on the resizing factor, the next write window may already contain up to three full video lines.

The largest amount of buffering is required when all of the following occur:

- The PREVIEW module is used.
- The RESIZER is used with a rescaling factor of 4x in the horizontal and vertical direction.
- The window size is not a multiple of the vertical up scaling factor.

#### **Example 6-1. Camera ISP Circular Buffer Example of 4x Digital Zoom Use:**

This example shows how to calculate the minimum required window count when this feature is used.

It is assumed that the camera ISP reads a VGA RAW8 image from memory, processes it in the preview, and scales it up to 5M pix (2560x1920). The circular buffer is used for temporary storage between the JPEG CODEC and the camera ISP. Each window is configured to contain 8 video lines and the stall command is issued when at least two windows of the circular buffer are full.

Because the circular buffer window size is a multiple of the vertical upscaling factor, the next write window is empty when the stall command is issued. However, up to 1K byte = 512 pixels are stored for each write port of the resizer. This data is written as a 512x4 pixel bloc to the circular buffer by the SBL. Between the PREVIEW and RESIZER up to 1kbyte = 512 pixels are stored. This data expands to a block of 512x4x4 pixels written to the circular buffer by the SBL. In other words, up to 7 lines of the circular buffer may be filled after the stall command is issued. A minimum of four windows must be allocated to avoid an overflow of the circular buffer.

**Example 6-1. Camera ISP Circular Buffer Example of 4x Digital Zoom Use: (continued)**
**Figure 6-101. Camera ISP Circular Buffer Control Feedback Loop Example**


The CODEC reads data from the circular buffer and flag windows as done. In this example, the stall command is released when the CODEC has completed processing W0 and W1. The camera ISP resumes writing into W3.

---

**NOTE:** Software can control the minimum full window count to issue the stall command using the **CBUFFx\_CTRL[7:4]** BCF register. Setting this value to 1 or 2 in this example may negatively affect the performance, because only up to two or three windows can be used.

---

#### 6.4.10.3.1.2 Camera ISP Circular Buffer Extended Slice Mode

In extended slice mode, both circular buffers managed by the CBUFF module are used together. One provides address translation for the read data flow, and the other for a write data flow.

**Figure 6-102. Camera ISP Circular Buffer Extended Slice Buffer Example**

The camera ISP prefetches data and buffers it in the SBL. The CSI1/CCP2B flexible input pre-buffers up to 1K byte of data. In other words, the stall control for the CSI1/CCP2B interconnect read master port must be triggered in advance. Otherwise, the camera ISP may prefetch invalid data.

The last moment when the CSI1/CCP2B interconnect read master port can be safely stalled is when the physical read buffer still contains 1K byte of valid data. The camera ISP may or may not then read the remaining data into its internal SBL buffer.

The minimum amount of buffered data depends on the circular buffer configuration and the used data format.

When the processor filling the read buffer has no more data to write, the BCF feature must be disabled (clear [ISP\\_CTRL \[23:22\] CBUFF0\\_BCF\\_CTRL](#) or [ISP\\_CTRL\[25:24\] CBUFF1\\_BCF\\_CTRL](#)) for the CBUFF attached to the read data flow. This allows the camera ISP to prefetch the remaining data from the buffer without stalling.

#### 6.4.10.3.1.3 Camera ISP Circular Buffer Fragmentation Support

This mode is available only for context 0 and CBUFF0. The mapped physical space does not need to be contiguous in memory.

---

**NOTE:** Software must ensure proper configuration of the CBUFF0 specific fragmentation support feature. Thus, the [CBUFFx\\_ADDRy](#) register must be configured correctly even if functionality was not initially required when data was accepted from ISP.

---

Software defines the location of each physical window using CBUFF0\_ADDR0 through CBUFF0\_ADDR15 (see [CBUFFx\\_ADDRy](#)). Figure 6-103 shows the fragmentation support.

**Figure 6-103. Camera ISP Circular Buffer Fragmentation Support**

Table 6-49 provides the physical address of physical windows 0 to 15 for fragmentation functionality.

**Table 6-49. Camera ISP Circular Buffer Fragmentation Support Physical Window Addresses**

| Physical Window | Fragmentation ON Register |
|-----------------|---------------------------|
| 0               | CBUFF0_ADDR0              |
| 1               | CBUFF0_ADDR1              |
| 2               | CBUFF0_ADDR2              |
| 3               | CBUFF0_ADDR3              |
| 4               | CBUFF0_ADDR4              |
| 5               | CBUFF0_ADDR5              |
| 6               | CBUFF0_ADDR6              |
| 7               | CBUFF0_ADDR7              |
| 8               | CBUFF0_ADDR8              |
| 9               | CBUFF0_ADDR9              |
| 10              | CBUFF0_ADDR10             |
| 11              | CBUFF0_ADDR11             |
| 12              | CBUFF0_ADDR12             |
| 13              | CBUFF0_ADDR13             |
| 14              | CBUFF0_ADDR14             |
| 15              | CBUFF0_ADDR15             |

#### 6.4.10.3.1.4 Camera ISP Circular Buffer VRFB Context Grouping

The VRFB is part of the SMS module and provides support for image rotation by writing the data into SDRAM and reading it back. The VRFB can rotate frames of up to 2k \* 2k pixels per context. That is sufficient to rotate the following image sizes

**Table 6-50. Camera ISP Circular Buffer VRFB Maximum Supported Frame Size**

| Frame size     | Aspect ratio |
|----------------|--------------|
| 3.1 Mega Pixel | 4/3          |
| 2.8 Mega Pixel | 3/2          |
| 2.3 Mega Pixel | 16/9         |

The CBUFF module can optionally perform address translation to group 4 contexts together. This extends the maximum frame size than can be rotated to the following:

**Table 6-51. Camera ISP Circular Buffer VRFB Extended Supported Frame Size**

| Frame size      | Aspect ratio |
|-----------------|--------------|
| 12.5 Mega Pixel | 4/3          |
| 11.1 Mega Pixel | 3/2          |
| 9.4 Mega Pixel  | 16/9         |

---

**NOTE:** VRFB context grouping is a standalone feature. It cannot be combined with circular buffering or fragmentation.

---

The VRFB supports a total of 12 contexts. The CBUFF VRFB context grouping feature groups 4 contexts together to provide a larger virtual frame buffer. CBUFF can handle up to 3 groups or 4 VRFB contexts each.

The software chooses which VRFB contexts to use by defining the base address of the 1st of the 4 contexts using the **CBUFF\_VRFB\_CTRL.BASE<sub>x</sub>** register ( $x = 0, 1, \text{ or } 2$ ). Software must ensure that translated regions do not overlap.

Software also needs to define the data width (8, 16, or 32-bits) and the orientation (0, 90, 180, or 270 degrees) using the `CBUFF_VRFB_CTRL.WIDTHx` and `CBUFF_VRFB_CTRL.ORIENTATIONx` registers.

Translation is enabled by setting the `CBUFF_VRFB_CTRL.ENABLEx` bit. Software shall not change the translation configuration or enable/disable the translation while there is active traffic from ISP interface input port in the translated region (`CBUFF_VRFB_CTRL.BASEx*256M bytes` to `CBUFF_VRFB_CTRL.BASEx+1)*256M bytes`).

Figure 6-104 shows how the "large" virtual frame buffer seen in the address map of ISP interface input port is mapped to 4 "small" virtual frames accessed through interface output port.

**Figure 6-104. Camera ISP Circular VRFB Buffer Performed Translation**



camisp-410

#### 6.4.10.3.2 Camera ISP Circular Buffer Window Management

This section explains the internal address remapping and windows management algorithm. Internally the module maintains some variables in addition to the configuration registers.

The module manages two circular buffers in parallel. Those are called CBUFF0 and CBUFF1.

**Table 6-52. Camera ISP Circular Buffer Internal Variables**

| Quantity | Description                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CWx      | Current window index for buffer x (x = 0, 1). Possible values are 0 to allowed window count. The current value can be read using the <code>CBUFFx_STATUS[11:8]</code> CW register.                                                                                                                                                                                                                                  |
| NWx      | Next window index for buffer x (x = 0, 1). Possible values are 0 to allowed window count. The current value can be read using the <code>CBUFFx_STATUS[19:16]</code> NW register.                                                                                                                                                                                                                                    |
| CPUWx    | Window in the physical buffer that can be accessed by the CPU. Possible values are 0 to allowed window count. The current value can be read using the <code>CBUFFx_STATUS[3:0]</code> CPUW register.                                                                                                                                                                                                                |
| FCOx     | Start address, in the virtual space, of the current window. This is an internal quantity that cannot be accessed by software.                                                                                                                                                                                                                                                                                       |
| OFFSETy  | This is an internal quantity that cannot be accessed by software.<br>y = 0: Address offset used when the current window of buffer 0 is accessed<br>y = 1: Address offset used when the next window of buffer 0 is accessed<br>y = 2: Address offset used when the current window of buffer 1 is accessed<br>y = 3: Address offset used when the next window of buffer 1 is accessed                                 |
| LEVELy   | This is an internal quantity that cannot be accessed by software.<br>y = 0: Amount of data, in bytes, read or written in the current window of buffer 0<br>y = 1: Amount of data, in bytes, read or written in the next window of buffer 0<br>y = 2: Amount of data, in bytes, read or written in the current window of buffer 1<br>y = 3: Amount of data, in bytes, read or written in the next window of buffer 1 |

##### 6.4.10.3.2.1 Camera ISP Circular Buffer Startup

The status of a circular buffer (CBUFF0 or CBUFF1) is reset when it is disabled. This does not affect the configuration registers or the `CBUFF_IRQSTATUS` register. Table 6-53 shows the internal state after reset.

**Table 6-53. Camera ISP Circular Buffer Internal State After Reset**

| Quantity  | Description                  |
|-----------|------------------------------|
| CWx       | 0                            |
| NWx       | 1                            |
| CPUWx     | 0                            |
| FCOx      | <a href="#">CBUFFx_START</a> |
| OFFSET0   | 0                            |
| OFSFET1   | 0                            |
| OFFSET2,3 | 0                            |
| LEVELy    | 0                            |

#### 6.4.10.3.2.2 Camera ISP Circular Buffer Access Identification

For each access to the virtual space, the CBUFF module first checks the address (ADDR) to classify the transaction into one of the categories listed in [Table 6-54](#).

**Table 6-54. Camera ISP Circular Buffer Address Identification**

| ID | Label       | Condition                                                                                                                                                                                          |
|----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0  | CW_CBUFF0   | <a href="#">CBUFFx_CTRL[0]</a> ENABLE = 1 and ADDR=FC00 and ADDRFC00 + <a href="#">CBUFFx_WINDOWSIZE</a> and ADDR= <a href="#">CBUFFx_END</a> (x = 0)                                              |
| 1  | NW_CBUFF0   | <a href="#">CBUFFx_CTRL[0]</a> ENABLE=1 (x = 0) and ADDR=FC00 + <a href="#">CBUFFx_WINDOWSIZE</a> and ADDRFC00 + 2* <a href="#">CBUFFx_WINDOWSIZE</a> and ADDR= <a href="#">CBUFFx_END</a> (x = 0) |
| 2  | CW_CBUFF1   | <a href="#">CBUFFx_CTRL[0]</a> ENABLE=1 and ADDR=FC01 and ADDRFC01 + <a href="#">CBUFFx_WINDOWSIZE</a> and ADDR= <a href="#">CBUFFx_END</a> (x = 1)                                                |
| 3  | NW_CBUFF1   | <a href="#">CBUFFx_CTRL[0]</a> ENABLE=1 and ADDR=FC01 + <a href="#">CBUFFx_WINDOWSIZE</a> and ADDRFC01 + 2* <a href="#">CBUFFx_WINDOWSIZE</a> and ADDR= <a href="#">CBUFFx_END</a> (x = 1)         |
| 4  | ERR_CBUFF0  | <a href="#">CBUFFx_CTRL[0]</a> ENABLE=1 and ADDR= <a href="#">CBUFFx_START</a> and ADDR= <a href="#">CBUFFx_END</a> (x = 0)                                                                        |
| 5  | ERR_CBUFF1  | <a href="#">CBUFFx_CTRL[0]</a> ENABLE=1 and ADDR= <a href="#">CBUFFx_START</a> and ADDR= <a href="#">CBUFFx_END</a> (x = 1)                                                                        |
| 6  | TRANSPARENT | Always true                                                                                                                                                                                        |

Lower IDs correspond to higher priorities in case multiple conditions are true. For example, when the current virtual window of the circular buffer 0 is accessed, at least the tests for categories CW\_CBUFF0 and ERR\_CBUFF0 are true. The final category is CW\_CBUFF0, because it has a higher priority.

Further processing depends on the category:

- TRANSPARENT: Accesses flow through the module without changing its internal state or any translation.
- ERR\_CBUFF0 and ERR\_CBUFF1: The module goes into error state for the concerned buffer (CBUFF0 or CBUFF1) and set the [CBUFF\\_IRQSTATUS\[1\]](#) IRQ\_CBUFF0\_INVALID bit (or [CBUFF\\_IRQSTATUS\[4\]](#) IRQ\_CBUFF1\_INVALID). When the module is in error state for CBUFFx, all accesses to that buffer are cancelled. In other words, any access that has an address between [CBUFFx\\_START](#) and [CBUFFx\\_END](#) (x = 0) is not transmitted to the interconnect. There are two ways to leave the error state:
  - Hardware reset
  - Disable and re-enable the buffer (CBUFF0 or CBUFF1) in error state

Accesses outside of the virtual space from the circular buffer in error state are not affected.

- CW\_CBUFF0, NW\_CBUFF0, CW\_CBUFF1 and NW\_CBUFF1: The internal state is updated and address translation is performed when the performed access type (read or write) is compatible with the current mode (read or write). Otherwise, an IRQ\_CBUFFx\_INVALID event is set and CBUFFx goes into the error state.

#### 6.4.10.3.2.3 Camera ISP Circular Buffer Address Translation

An offset is selected depending on the access category (see [Section 6.4.10.3.2.1, Camera ISP Circular Buffer Startup](#)) and the internal state of the accessed buffer. [Table 6-55](#) lists possible cases.

**Table 6-55. Camera ISP Circular Buffer Address Translation**

| Condition                                                                                                                             | Address Translation      |
|---------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| CBUFFx_CTRL[0] ENABLE=1 and ADDR= <a href="#">CBUFFx_START</a> and ADDR= <a href="#">CBUFFx_END</a> and CBUFF0 in error state (x = 0) | Access cancelled         |
| CBUFFx_CTRL[0] ENABLE=1 and ADDR= <a href="#">CBUFFx_START</a> and ADDR= <a href="#">CBUFFx_END</a> and CBUFF1 in error state (x = 1) | Access cancelled         |
| Category = CW_CBUFF0                                                                                                                  | ADDROUT = ADDRIN-OFFSET0 |
| Category = NW_CBUFF0                                                                                                                  | ADDROUT = ADDRIN-OFFSET1 |
| Category = CW_CBUFF1                                                                                                                  | ADDROUT = ADDRIN-OFFSET2 |
| Category = NW_CBUFF1                                                                                                                  | ADDROUT = ADDRIN-OFFSET3 |
| Category = ERR_CBUFF0                                                                                                                 | Access cancelled         |
| Category = ERR_CBUFF1                                                                                                                 | Access cancelled         |
| Category = TRANSPARENT                                                                                                                | ADDROUT = ADDRIN         |

#### 6.4.10.3.2.4 Camera ISP Circular Buffer Window Fill Level

Each time an access is performed into an active window (CW\_CBUFF0, NW\_CBUFF0, CW\_CBUFF1 or NW\_CBUFF1) the window level is updated. The corresponding LEVELy is incremented according to the BYTEEN input of the interconnect port. All possible BYTEEN patterns are supported. [Table 6-56](#) shows some examples. The basic idea is to count the number of ones in the BYTEEN input.

**Table 6-56. Camera ISP Circular Buffer Window Level Increment**

| BYTEEN | LEVELy Increment | Comment       |
|--------|------------------|---------------|
| 0x00   | +0               | No access     |
| 0x01   | +1               | 8 bit access  |
| 0x02   | +1               | 8 bit access  |
| 0x03   | +2               | 16 bit access |
| ...    | ...              | ...           |
| 0x07   | +3               | 24 bit access |
| ...    | ...              | ...           |
| 0x0F   | +4               | 32 bit access |
| ...    | ...              | ...           |
| 0xF0   | +4               | 32 bit access |
| ...    | ...              | ...           |
| 0xFF   | +8               | 64 bit access |

The window level is compared to `CBUFFx_THRESHOLD`. As listed in [Table 6-57](#), the following situations may occur:

**Table 6-57. Camera ISP Circular Buffer Window Level Comparison**

| Condition                                         | Description                                                                                                               |
|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| LEVEL0= <code>CBUFFx_THRESHOLD</code> ( $x = 0$ ) | Current window of buffer 0 full.<br>Internal window indexes, levels, and offsets are updated.                             |
| LEVEL1= <code>CBUFFx_THRESHOLD</code> ( $x = 0$ ) | Next window of buffer 0 full.<br>An <code>IRQ_CBUFF0_INVALID</code> error event is set and CBUFF0 enters the error state. |
| LEVEL2= <code>CBUFFx_THRESHOLD</code> ( $x = 1$ ) | Current window of buffer 1 full                                                                                           |
| LEVEL3= <code>CBUFFx_THRESHOLD</code> ( $x = 1$ ) | Next window of buffer 1 full.<br>An <code>IRQ_CBUFF1_INVALID</code> error event is set and CBUFF1 enters the error state. |

#### 6.4.10.3.2.5 Camera ISP Circular Buffer Window Pointer and Offset Update

When the current window of a circular buffer (`CBUFFx`,  $x = 0$  or  $1$ ) is full:

- The "next window" becomes the "current window"
  - $CWx - NW$
  - $LEVEL(2*x) - LEVEL(2*x+1)$
  - $OFFSET(2*x) - OFFSET(2*x+1)$
  - $FCOx - FCOx + CBUFFx_WINDOWSIZE$
- A new "next window" if opened. The update is done in a circular manner: the first window in the physical space is reused after the last one
  - $NW - (NW+1)$  modulo  $WC$
  - $LEVEL(2*x+1) - 0$
  - $VPA - VPA + CBUFFx_WINDOWSIZE$
  - When fragmentation used for CBUFF0:
    - $OFFSET(2*x+1) - OFFSET(2*x+1) + VPA * CBUFFx_WINDOWSIZE - CBUFF0_ADDR[CBUFF0_STATUS[WA]]$
  - When the "next window" is moved from the last buffer to the first:
    - $OFFSET(2*x+1) - OFFSET(2*x+1) + WCx * CBUFFx_WINDOWSIZE$

---

**NOTE:**  $WC$  is the window count defined by the `CBUFFx_CTRL[9:8]` `WCOUNT` register.

---

#### 6.4.10.3.3 Camera ISP Circular Buffer CPU Interaction

The CBUFF module sets an `IRQ_CBUFFx_READY` event to inform the CPU that it can access the  $CPUx$  window in the physical buffer. The CBUFF module cannot monitor CPU accesses to the physical buffer. The CPU must indicate when it has completed the processing of the  $CPUWx$  window by writing the `CBUFFx_CTRL[2]` `DONE` bit. This increments the CPU window index  $CPUWx$  by one modulo the window count.

The behavior depends on whether read or write mode has been selected using the `CBUFFx_CTRL[1]` `RWMODE` bit.

---

**NOTE:** Some details of this feature are not available in the public domain.

---

## 6.4.11 Camera ISP MMU Logic

### 6.4.11.1 Camera ISP MMU Features

The camera ISP MMU contains a translation lookaside buffer (TLB) that holds translations and properties for current pages. This TLB can be managed statically through the configuration slave port, or by the internal hardware table-walking logic (TWL), which can autonomously traverse the page table on a TLB miss. The TWL can be enabled or disabled (MMU.MMU\_CNTL [2] TWLENABLE).

On a TLB miss, the initiator is stalled until a valid address translation is found. If no valid translation is found, a translation fault interrupt is generated to the processor. It is a nonrecoverable situation, which leads to the camera ISP being reset by the processor software.

The MMU provides up to 4G bytes of virtual memory.

### 6.4.11.2 Camera ISP MMU Functional Description

For a detailed description of the MMU, see [Chapter 15, Memory Management Units](#).

---

**NOTE:** In the camera ISP MMU, the endianess feature is available for write, but conversion for read is not possible.

---

## 6.5 Camera ISP Basic Programming Model

### 6.5.1 Programming the ISP PRCM Clocks Configuration

The camera subsystem clocks are provided by the PRCM module. The software must set the PRCM registers as follows:

1. To set the cam\_mclk:

The DPLL4\_ALWON\_FCLKOUT clock is sourced by the system clock (SYS\_CLK) at a X frequency and calculated as follows:

$$\text{DPLL4\_ALWON\_FLCKOUT} = [\text{SYS\_CLK (X frequency)} \times 2 \times M (0xE1)] / [N (0x9) + 1]$$

$$\text{cam\_mclk} = \text{DPLL4\_ALWON\_FCLKOUT} / \text{CLKSEL\_CAM (4)}$$

$$\text{PRCM.CM\_CLKSEL\_CAM.CLKSEL\_CAM} = x$$

2. Enable the cam\_fclk clock:

$$\text{PRCM.CM\_FLCKEN\_CAM [0] EN\_CAM} = 0x1$$

3. Enable the cam\_iclk clock:

$$\text{PRCM.CM\_ICLKEN\_CAM [0] EN\_CAM} = 0x1$$

[Table 6-58](#) lists the registers to configure the camera subsystem clock configuration step.

**Table 6-58. Camera ISP PRCM Registers Settings**

| Register Name      | Address     | Value Description        |
|--------------------|-------------|--------------------------|
| PRCM.CM_CLKSEL_CAM | 0x4800 4F40 | DPLL4 divisor set to 0x4 |
| PRCM.CM_FLCKEN_CAM | 0x4800 4F00 | Enable CAM_FCLK          |
| PRCM.CM_ICLKEN_CAM | 0x4800 4F10 | Enable CAM_ICLK          |

### 6.5.2 Programming the CSI1/CCP2B or CSI2 Receiver Associated PHY

#### 6.5.2.1 Camera ISP CSIPHY Initialization for Work With CSI2 Receiver

To fully initialize the CSIPHY, perform the following steps:

1. Configure all CSI2 receiver registers to receive signals/data from the CSIPHY:
  - (a) Configure all necessary CSI2 registers:
    - (i) Set [CSI2\\_COMPLEXIO\\_CFG1\[10:8\] DATA2\\_POSITION](#).

- (ii) Set [CSI2\\_COMPLEXIO\\_CFG1\[6:4\]](#) DATA1\_POSITION.
- (iii) Set [CSI2\\_COMPLEXIO\\_CFG1\[2:0\]](#) CLOCK\_POSITION.
- (iv) Set CONTROL\_CAMERA\_PHY\_CTRL[1:0] R\_CONTROL\_CAMERA2\_PHY\_CAMMODE or CONTROL\_CAMERA\_PHY\_CTRL[3:2] R\_CONTROL\_CAMERA1\_PHY\_CAMMODE.

**CAUTION**

This must be done before the CSIPHY is active.

## 2. CSIPHY and link initialization sequence:

### (a) Deassert the CSIPHY reset:

- (i) Set [CSI2\\_COMPLEXIO\\_CFG1\[30\]](#) RESET\_CTRL to 0x1.

### (b) The following registers can be set only after deasserting the CSIPHY reset, and before asserting the ForceRxMode signal:

- [CSIPHY\\_REG0](#)
- [CSIPHY\\_REG1](#)
- [CSIPHY\\_REG2](#)

### (c) Assert the ForceRxMode signal:

- (i) Set [CSI2\\_TIMING\[15\]](#) FORCE\_RX\_MODE\_IO1 to 0x1.

### (d) Connect the pulldown on the link (DP/DN) by asserting the respective PIPD\* signals (PIPDL\* = 0):

- For CSIPHY1: Pull down on signals through padconf registers:
  - cam\_d6:
    - CONTROL\_PADCONF\_CAM\_D5[24] INPUTENABLE1 = 0x1
    - CONTROL\_PADCONF\_CAM\_D5[20] PULLTYPESELECT1 = 0x0
    - CONTROL\_PADCONF\_CAM\_D5[19] PULLUDENABLE1 = 0x1
  - cam\_d7:
    - CONTROL\_PADCONF\_CAM\_D7[8] INPUTENABLE0 = 0x1
    - CONTROL\_PADCONF\_CAM\_D7[4] PULLTYPESELECT0 = 0x0
    - CONTROL\_PADCONF\_CAM\_D7[3] PULLUDENABLE0 = 0x1
  - cam\_d8:
    - CONTROL\_PADCONF\_CAM\_D7[24] INPUTENABLE1 = 0x1
    - CONTROL\_PADCONF\_CAM\_D7[20] PULLTYPESELECT1 = 0x0
    - CONTROL\_PADCONF\_CAM\_D7[19] PULLUDENABLE1 = 0x1
  - cam\_d9:
    - CONTROL\_PADCONF\_CAM\_D9[8] INPUTENABLE0 = 0x1
    - CONTROL\_PADCONF\_CAM\_D9[4] PULLTYPESELECT0 = 0x0
    - CONTROL\_PADCONF\_CAM\_D9[3] PULLUDENABLE0 = 0x1
- For CSIPHY2: Pull down on signals through padconf registers:
  - cam\_d0:
    - CONTROL\_PADCONF\_CAM\_FLD[24] INPUTENABLE1 = 0x1
    - CONTROL\_PADCONF\_CAM\_FLD[20] PULLTYPESELECT1 = 0x0
    - CONTROL\_PADCONF\_CAM\_FLD[19] PULLUDENABLE1 = 0x1
  - cam\_d1:
    - CONTROL\_PADCONF\_CAM\_D1[8] INPUTENABLE0 = 0x1
    - CONTROL\_PADCONF\_CAM\_D1[4] PULLTYPESELECT0 = 0x0
    - CONTROL\_PADCONF\_CAM\_D1[3] PULLUDENABLE0 = 0x1

- csi2\_dx0:
  - CONTROL\_PADCONF\_CSI2\_DX0[8] INPUTENABLE0 = 0x1
  - CONTROL\_PADCONF\_CSI2\_DX0[4] PULLTYPESELECT0 = 0x0
  - CONTROL\_PADCONF\_CSI2\_DX0[3] PULLUDENABLE0 = 0x1
- csi2\_dy0:
  - CONTROL\_PADCONF\_CSI2\_DX0[24] INPUTENABLE1 = 0x1
  - CONTROL\_PADCONF\_CSI2\_DX0[20] PULLTYPESELECT1 = 0x0
  - CONTROL\_PADCONF\_CSI2\_DX0[19] PULLUDENABLE1 = 0x1
- csi2\_dx1:
  - CONTROL\_PADCONF\_CSI2\_DX1[8] INPUTENABLE0 = 0x1
  - CONTROL\_PADCONF\_CSI2\_DX1[4] PULLTYPESELECT0 = 0x0
  - CONTROL\_PADCONF\_CSI2\_DX1[3] PULLUDENABLE0 = 0x1
- csi2\_dy1:
  - CONTROL\_PADCONF\_CSI2\_DX1[24] INPUTENABLE1 = 0x1
  - CONTROL\_PADCONF\_CSI2\_DX1[20] PULLTYPESELECT1 = 0x0
  - CONTROL\_PADCONF\_CSI2\_DX1[19] PULLUDENABLE1 = 0x1

## (e) Power up the CSIPHY:

- (i) Set **CSI2\_COMPLEXIO\_CFG1**[28:27] PWR\_CMD to 0x1.

## (f) Check that the state status reaches the ON state:

- **CSI2\_COMPLEXIO\_CFG1**[26:25] PWR\_STATUS = 0x1

## (g) Wait for STOPSTATE = 1 (for all enabled lane modules):

- (i) The timer is set through the **CSI2\_TIMING**[14:0] bit field. The reset value can be kept.
- (ii) Wait until **CSI2\_TIMING**[15] FORCE\_RX\_MODE\_IO1 = 0x0. It is automatically put at 0 when all enabled lanes are in STOPSTATE and the timer is finished.

## (h) Release PIPD\* (= 1):

- For CSIPHY1: Pull up on signals through padconf registers:
  - cam\_d6:
    - CONTROL\_PADCONF\_CAM\_D5[20] PULLTYPESELECT1 = 0x1
  - cam\_d7:
    - CONTROL\_PADCONF\_CAM\_D7[4] PULLTYPESELECT0 = 0x1
  - cam\_d8:
    - CONTROL\_PADCONF\_CAM\_D7[20] PULLTYPESELECT1 = 0x1
  - cam\_d9:
    - CONTROL\_PADCONF\_CAM\_D9[4] PULLTYPESELECT0 = 0x1
- For CSIPHY2: Pull up on signals through padconf registers:
  - cam\_d0:
    - CONTROL\_PADCONF\_CAM\_FLD[20] PULLTYPESELECT1 = 0x1
  - cam\_d1:
    - CONTROL\_PADCONF\_CAM\_D1[4] PULLTYPESELECT0 = 0x1
  - csi2\_dx0:
    - CONTROL\_PADCONF\_CSI2\_DX0[4] PULLTYPESELECT0 = 0x1
  - csi2\_dy0:
    - CONTROL\_PADCONF\_CSI2\_DX0[20] PULLTYPESELECT1 = 0x1
  - csi2\_dx1:
    - CONTROL\_PADCONF\_CSI2\_DX1[4] PULLTYPESELECT0 = 0x1
  - csi2\_dy1:
    - CONTROL\_PADCONF\_CSI2\_DX1[19] PULLTYPESELECT1 = 0x1

- CONTROL\_PADCONF\_CSI2\_DX1[20] PULLTYPESELECT1 = 0x1
  - (i) The CSIPHY is initialized and ready/active in CSI2 mode.

### 6.5.2.2 Camera ISP CSIPHY Initialization for Work With CSI1/CCP2B Receiver

To fully initialize the CSIPHY, perform the following steps:

1. Configure all CSI1/CCP2B receiver registers to receive signals/data from the CSIPHY:
  - (a) Configure all CSI1/CCP2B registers:
    - (i) Set **CSI2\_COMPLEXIO\_CFG1[10:8]** DATA2\_POSITION.  
CCP2 mode for work with CSIPHY1:  
0x0: Not used/connected  
CCP2 mode for work with CSIPHY2:  
0x0: Not used/connected
    - (ii) Set **CSI2\_COMPLEXIO\_CFG1[6:4]** DATA1\_POSITION.  
CCP2 mode for work with CSIPHY1:  
0x1: Data lane 1 is at position 2.  
0x2: Data lane 1 is at position 1.  
CCP2 mode for work with CSIPHY2:  
0x1: Data lane 1 is at position 2.  
0x2: Data lane 1 is at position 1.
    - (iii) Set **CSI2\_COMPLEXIO\_CFG1[2:0]** CLOCK\_POSITION.  
CCP2 mode for work with CSIPHY1:  
0x1: Clock lane is at position 2.  
0x5: Clock lane is at position 1.  
CCP2 mode for work with CSIPHY2:  
0x1: Clock lane is at position 2.  
0x5: Clock lane is at position 1.
    - (iv) Set CONTROL\_CAMERA\_PHY\_CTRL[1:0] R\_CONTROL\_CAMERA2\_PHY\_CAMMODE or  
CONTROL\_CAMERA\_PHY\_CTRL[3:2] R\_CONTROL\_CAMERA1\_PHY\_CAMMODE.

**CAUTION**

This must be done before the CSIPHY is active.

- (v) Set CONTROL\_CAMERA\_PHY\_CTRL[4] R\_CONTROL\_CSI1\_RX\_SEL.

**CAUTION**

This must be done before the CSIPHY is active.

2. CSIPHY and link initialization sequence:

- (a) Deassert the CSIPHY reset:
  - (i) Set **CSI2\_COMPLEXIO\_CFG1[30]** RESET\_CTRL to 0x1.
- (b) Assert the ForceRxMode signal:
  - (i) Set **CSI2\_TIMING[15]** FORCE\_RX\_MODE\_IO1 to 0x1.
- (c) Power up the CSIPHY:
  - (i) Set **CSI2\_COMPLEXIO\_CFG1[28:27]** PWR\_CMD to 0x1.
- (d) Check that the state status reaches the ON state:

- [CSI2\\_COMPLEXIO\\_CFG1\[26:25\]](#) PWR\_STATUS = 0x1.
- (e) Release the ForceRxMode signal:
  - (i) Set [CSI2\\_TIMING\[15\]](#) FORCE\_RX\_MODE\_IO1 to 0x0.
- (f) CSIPHY is initialized and ready/active in CSI1/CCP2B mode.

### 6.5.3 Programming the CSI1/CCP2B Receiver

This section describes the programming model of the CSI1/CCP2B receiver.

#### 6.5.3.1 Camera ISP CSI1/CCP2B Hardware Setup/Initialization

This section discusses the configuration of the CSI1/CCP2B receiver required before image capture can begin.

##### 6.5.3.1.1 Camera ISP CSI1/CCP2B Reset Behavior

On hardware or software reset of the camera ISP, all registers in the CSI1/CCP2B receiver are reset to their reset values.

#### 6.5.3.2 Camera ISP CSI1/CCP2B Event and Status Checking

When an event occurs, the corresponding bit in the [CCP2\\_LC01\\_IRQSTATUS](#) (or [CCP2\\_LC23\\_IRQSTATUS](#)) register is set. Each event can be individually masked using the [CCP2\\_LC01\\_IRQENABLE](#) register ([CCP2\\_LC23\\_IRQENABLE](#)). Masked events are not transmitted to the interrupt lane, but the [CCP2\\_LC01\\_IRQSTATUS](#) register (or [CCP2\\_LC23\\_IRQSTATUS](#)) is updated.

Events transmitted to the interrupt lane can be mapped to the ARM or DSP by unmasking the ISP\_CSIB bit in the ISP\_IRQxENABLE (x = 0, 1). Depending on whether the event is mapped to the ARM or DSP register, to clear an event, the following actions are required:

- Clear the event at the CSI1/CCP2B receiver level by writing 1 to the corresponding bit in the [CCP2\\_LC01\\_IRQSTATUS](#) register (or [CCP2\\_LC23\\_IRQSTATUS](#)).
- Clear the event at ISP level by writing 1 to the corresponding bit ISP\_CSI1 in the ISP\_IRQxENABLE (x = 0, 1) register.

#### 6.5.3.3 Camera ISP CSI1/CCP2B Register Accessibility During Frame Processing

There are two types of register accesses in the CSI1/CCP2B receiver:

- Shadowed registers:
  - These registers/fields can be read and written (if the field is writable) at any time. However, written values take effect only at the start of a frame. Reads return the most recent write, even though the settings are not used until the next start of frame.
  - The shadowed registers are:
    - [CCP2\\_LCx\\_CTRL](#)
    - [CCP2\\_LCx\\_CODE](#)
    - [CCP2\\_LCx\\_STAT\\_START](#)
    - [CCP2\\_LCx\\_STAT\\_SIZE](#)
    - [CCP2\\_LCx\\_SOF\\_ADDR](#)
    - [CCP2\\_LCx\\_EOF\\_ADDR](#)
    - [CCP2\\_LCx\\_DAT\\_SIZE](#)
    - [CCP2\\_LCx\\_DAT\\_PING\\_ADDR](#)
    - [CCP2\\_LCx\\_DAT\\_PONG\\_ADDR](#)
    - [CCP2\\_LCx\\_DAT\\_OFST](#)
- Busy-locked registers:
  - These registers/fields must not be written if the module is busy.

- All register fields not listed as shadowed are busy-writable registers.

#### 6.5.3.4 Camera ISP CSI1/CCP2B Enable/Disable the Hardware

The CSI1/CCP2B receiver is globally controlled by the [CCP2\\_CTRL](#) register. The bit fields in this register must not be modified when the CSI1/CCP2B interface is active (except [CCP2\\_CTRL](#) [0] IF\_EN):

- To activate the CSI1/CCP2B interface:
  - [CCP2\\_CTRL](#) [0] IF\_EN = 0x1
  - Data acquisition starts on the following FSC synchronization code. Writing [CCP2\\_CTRL](#) [0] IF\_EN = 0x1 resets the output FIFO of the module; the reset is caused by the 0-to-1 edge transition.
- To disable the CSI1/CCP2B interface:
  - [CCP2\\_CTRL](#) [0] IF\_EN = 0x0
  - The interface is disabled immediately if [CCP2\\_CTRL](#) [3] FRAME = 0x0.
  - If [CCP2\\_CTRL](#) [3] FRAME = 0x1 and [CCP2\\_LCx\\_CTRL](#)[19] CRC\_EN = 0x0, the interface is disabled after the FEC synchronization code is received.
  - If [CCP2\\_CTRL](#)[3] FRAME = 0x1 and [CCP2\\_LCx\\_CTRL](#)[19] CRC\_EN = 0x1, the interface is disabled only after the 16-bit CRC checksum and 16-bit pad data is received.
  - Before disabling the interface (IF\_EN=0) it is advised to disable all active channels by writing [CCP2\\_LCx\\_CTRL](#)[0] CHAN\_EN = 0x0. Otherwise, if IF\_EN = 0 is set during a vertical blanking period, the reception continues until the FEC synchronization code is received for all active channels.

#### 6.5.3.5 Camera ISP CSI1/CCP2B Select the Signaling Scheme

The [CCP2\\_CTRL](#)[1] PHY\_SEL bit selects whether the data/strobe or data/clock signaling scheme is used. See [Table 6-22](#) for the correct settings as a function of the image sensor class. Setting [CCP2\\_CTRL](#) [1] PHY\_SEL = 0x1 has no effect if [CCP2\\_CTRL](#) [4] MODE = 0x0.

#### 6.5.3.6 Camera ISP CSI1/CCP2B Control of the PHY

The [CCP2\\_CTRL](#) [2] IO\_OUT\_SEL bit selects the output mode of the CSI1/CCP2B receiver associated PHY(could be either CSIPHY1 or CSI2PHY2), which must be set to 1 for parallel only.

For information about initializing and configuring the CSIPHY that is associated with the CSI1/CCP2B receiver, see [Section 6.5.2.2, Camera ISP CSIPHY Initialization for Work With CSI1/CCP2B Receiver](#).

#### 6.5.3.7 Camera ISP CSI1/CCP2B Select the Mode: MIPI CSI1 or CCP2B

The [CCP2\\_CTRL](#)[4] MODE bit selects whether the CCP2B module works in MIPI CSI1 or CCP2-compatible mode. Setting [CCP2\\_CTRL](#)[4] MODE = 0x0 disables the CCP2-specific features: data/strobe, CRC, logical channels, RAW6 and RAW7 data formats. The following bits have no effect when [CCP2\\_CTRL](#)[4] MODE = 0x0: [CCP2\\_CTRL](#)[1] PHY\_SEL, [CCP2\\_LCx\\_CTRL](#)[19] CRC\_EN, [CCP2\\_LCx\\_CTRL](#)[0] CHAN\_EN (x = 1 to 3). Furthermore, [CCP2\\_LCx\\_CTRL](#)[7:2] FORMAT values 8, 9, 10, 12, 13, 14, 17, 18, 21, and 25 have no effect: no data are output. MIPI CSI1 is the default mode of the module.

#### 6.5.3.8 Camera ISP CSI1/CCP2B Burst Settings

The [CCP2\\_CTRL](#)[6:5] BURST bit field forces the burst behavior of the CSI1/CCP2B receiver. The module can be forced to perform single 64-bit requests or bursts of 2x, 4x, and 8x 64 bits. The burst size must never exceed the output FIFO size. The output FIFO size can be read by reading the [CCP2\\_GNQ](#)[4:2] FIFODEPTH bit field.

#### 6.5.3.9 Camera ISP CSI1/CCP2B Debug Mode

Use the [CCP2\\_CTRL](#) [7] DBG\_EN bit to enable the debug mode:

- During debug mode, the input comes from the [CCP2\\_DBG](#) register, not from the CSI1/CCP2B physical interface. The full CSI1/CCP2B receiver functionality can be debugged in debug mode. Full 32-bit values must always be written to the [CCP2\\_DBG](#) register.
- The following bits have no effect during debug mode:
  - [CCP2\\_CTRL](#) [0] IF\_EN
  - [CCP2\\_CTRL](#) [1] PHY\_SEL
  - [CCP2\\_CTRL](#) [2] IO\_OUT\_SEL
- The following examples apply to the [CCP2\\_DBG](#) register:
  - Synchronization codes: [CCP2\\_DBG](#) = 0xFF000000
  - To send the RAW12 pixels 0x673, 0x452, 0x01d, 0xe fc, 0xab0, 0x891, 0x326, and 0x547, write [CCP2\\_DBG](#) = 0x01234567 followed by [CCP2\\_DBG](#) = 0x89abcdef [CCP2\\_DBG](#) = 0x76543210.

---

**NOTE:** Each write to the [CCP2\\_DBG](#) register sends a full 32-bit word through the CSI1/CCP2B receiver hardware. When 8- or 16-bit writes are performed to the register, the previous 32-bit value is merged with the newly written one. When the driver writes, for example, 0x01234567 followed by 0x000000FF with BYTEEN = 0x1 (this write from the MPU subsystem informs that only 8 bits are written), the CSI1/CCP2B receiver pipeline gets 0x01234567 followed by 0x012345FF.

---

#### 6.5.3.10 Camera ISP CSI1/CCP2B Video Port

- Set the video-port output frequency:
  - [CCP2\\_CTRL](#) [9:8] VP\_OUT\_CTRL
  - The video-port output frequency varies from CAM\_ICLK to CAM\_ICLK/4 MHz. CAM\_ICLK is the CSI1/CCP2B receiver functional and interface clock. The reset value selects CAM\_ICLK/2.
- [CCP2\\_CTRL](#) [11] VP\_ONLY\_EN:
  - Controls whether the video-port output is the only output interface enabled and applies for all channels.
  - When [CCP2\\_CTRL](#) [11] VP\_ONLY\_EN = 0x1, the data are output only to the video port; the interface master port is not used. The two parts of the frame (embedded data and pixel data) are output to the video port (instead of pixel data to video port and embedded data to interconnect).
    - The video port outputs the embedded data defined by the [CCP2\\_LCx\\_STAT\\_START](#) and [CCP2\\_LCx\\_STAT\\_SIZE](#) registers without decompression.
    - The video port outputs the pixel data defined by the [CCP2\\_LCx\\_DAT\\_START](#) and [CCP2\\_LCx\\_DAT\\_SIZE](#) registers.
  - The pixel data are decompressed according to the settings of the [CCP2\\_LCx\\_CTRL](#) [7:2] FORMAT bit field. [Table 6-59](#) summarizes the behavior of the video port as a function of the [CCP2\\_LCx\\_CTRL](#) [7:2] FORMAT bit field.

**Table 6-59. Camera ISP CSI1/CCP2B CCP2\_LCx\_CTRL[7:2] FORMAT and CCP2\_CTRL[11] VP\_ONLY\_EN = 1 Settings**

| <a href="#">CCP2_LCx_CTRL</a> [7:2] Format | Video-Port Behavior                                                                                                                                                                                                                                                                                                     |
|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| YUV422 + VP or RAW8 + VP                   | The incoming data are 8 bits. The pixel data are not compressed.<br>The embedded data are transmitted to the CCDC module on 8 bits (DATA[7:0]). The pixel data are not decompressed.<br>The pixel data are transmitted to the CCDC module on 8 bits (DATA[7:0]).                                                        |
| RAW12 + VP                                 | The incoming data are 12 bits. The pixel data are not compressed.<br>The embedded data are transmitted to the CCDC module on 12 bits (DATA[11:0]). The pixel data are reconstructed in the receiver.<br>The pixel data are transmitted to the CCDC module on 12 bits (DATA[11:0]). The pixel data are not decompressed. |

- Control the video-port pixel clock polarity:
  - If **CCP2\_CTRL[12]** VP\_CLK\_POL = 0x0, the CSI1/CCP2B receiver module writes the data on the video port on the pixel-clock falling edge. The module connected to the VP samples the data on the pixel clock rising edge.
  - If **CCP2\_CTRL[12]** VP\_CLK\_POL = 0x1, the CSI1/CCP2B receiver module writes the data on the video port on the pixel-clock raising edge. The module connected to the VP samples the data on the pixel clock falling edge. [Figure 6-105](#) shows the **CCP2\_CTRL**.VP\_CLK\_POL settings.

**Figure 6-105. Camera ISP CSI1/CCP2B CCP2\_CTRL.VP\_CLK\_POL Settings**



#### 6.5.3.11 Camera ISP CSI1/CCP2B Logical Channels

The CCP2B receiver supports simultaneous logical channels. Each logical channel is controlled independently with its own set of registers. The four sets of registers are identical, but some reset values are different.

The same description applies to all other logical channels. Logical channel LC $x$  means LC0, LC1, LC2, or LC3.

All the registers in this section can be modified at any time. However, the modifications apply only from the start of the following frame.

#### 6.5.3.12 Camera ISP CSI1/CCP2B Controls

The logical channel is controlled by the CCP2\_LCx\_CTRL register.

The logical channel is enabled by setting CCP2\_LCx\_CTRL[0] CHAN\_EN = 0x1. By default, all logical channels except logical channel 0 are disabled. Only the pixel data of one logical channel can go to the Video processing hardware; the SOF and EOF lines are always sent to memory through the interconnect interface. Setting CCP2\_LCx\_CTRL[0] CHAN\_EN ( $x=1$ ), CCP2\_LCx\_CTRL[0] CHAN\_EN ( $x=2$ ), or CCP2\_LCx\_CTRL[0] CHAN\_EN = 0x1 ( $x=3$ ) has no effect if CCP2\_CTRL[4] MODE = 0x0.

#### 6.5.3.13 Camera ISP CSI1/CCP2B Region of Interest

The CCP2\_LCx\_CTRL[1] REGION\_EN bit enables the region-of-interest feature (SOF lines, pixel data, and EOF lines):

- If enabled, register settings set the position and size of each region; all data not in a region of interest are ignored.
- If disabled, all data in the frame are output. CCP2\_LCx\_CTRL[1] REGION\_EN is set to 0x0 for a JPEG bitstream.

#### 6.5.3.14 Camera ISP CSI1/CCP2B CRC

The CRC can be enabled or disabled with CCP2\_LCx\_CTRL[19] CRC\_EN. If the received checksum and the computed checksum do not match, an interrupt is triggered: the corresponding event is LC $x$ \_CRC\_IRQ. Setting CCP2\_LCx\_CTRL[19] CRC\_EN = 0x1 has no effect if CCP2\_CTRL[4] MODE = 0x0.

#### 6.5.3.15 Camera ISP CSI1/CCP2B Destination Format

- Control the destination format:
  - The CSI1/CCP2B receiver reformats received data to store it in memory or to send it to the Videp processing hardware.
  - CCP2\_LCx\_CTRL[7:2] FORMAT controls destination-data format:

- EXP8 = Data expansion to 8 bits, padding with zeros
- EXP16 = Data expansion to 16 bits, padding with alpha or zeros [CCP2\\_CTRL\[15:8\]](#) ALPHA can be used to set an alpha value. For RGB444 + EXP16:
  - data\_out[31:28]=ALPHA[3:0] and data\_out[27:16]=RGB444
  - data\_out[15:12]=ALPHA[3:0] and data\_out[11:0]=RGB444
- EXP32 = Data expansion to 32 bits, padding with alpha. [CCP2\\_CTRL\[15:8\]](#) ALPHA can be used to set an alpha value. For RGB888 + EXP32: data\_out[31:24]=ALPHA[7:0] and data\_out[23:0]=RGB888
- FSP = False synchronization code protection decoding. Applies only to JPEG8 data format.
- VP = Output to the Video processing hardware is enabled.

#### 6.5.3.16 Camera ISP CSI1/CCP2B Frame Acquisition

- Program the number of frames that the CSI1/CCP2B receiver acquires:
  - [CCP2\\_LCx\\_CTRL \[31:24\]](#) COUNT
  - Writes to the COUNT bit field are controlled by the [CCP2\\_LCx\\_CTRL \[16\]](#) COUNT\_UNLOCK bit.
  - If COUNT = 0x0, the counter is free-running; frame acquisition lasts until disabled by the programmer. It is the default value.
  - COUNT controls the number of frames to acquire. The values range between 1 and 255. The COUNT value is decremented after each frame received. The software can read this value to acquire the number of frames that remain to be acquired.

After the correct number of frames is received, acquisition is automatically disabled ([CCP2\\_LCx\\_CTRL \[0\]](#) CHAN\_EN = 0x0) and the COUNT\_IRQ interrupt is triggered. The programmer can reenable the acquisition by resetting [CCP2\\_LCx\\_CTRL \[0\]](#) CHAN\_EN to 0x1.

[CCP2\\_LCx\\_CTRL \[17\]](#) PING\_PONG indicates whether the PING address ([CCP2\\_LCx\\_DAT\\_PING\\_ADDR](#)) or PONG address ([CCP2\\_LCx\\_DAT\\_PONG\\_ADDR](#)) was used to store the pixel data of the last frame. After reset or after a 0-to-1 edge transition in [CCP2\\_CTRL \[0\]](#) IF\_EN, the pixel data are written in the PING buffer and [CCP2\\_LCx\\_CTRL \[17\]](#) PING\_PONG = 0x1 (PONG). After the first FEC synchronization code is received, the pixel data are written in the PONG buffer and [CCP2\\_LCx\\_CTRL \[17\]](#) PING\_PONG = 0x0 (PING). [CCP2\\_LCx\\_CTRL \[17\]](#) PING\_PONG toggles after every FEC synchronization code.

#### 6.5.3.17 Camera ISP CSI1/CCP2B Synchronization Codes

The FSC, FEC, LSC, and LEC synchronization codes have default values given by the CCP2B specification. Also, each logical channel is identified by a default identifier.

The [CCP2\\_LCx\\_CODE](#) register enables overwriting of the default values: [CCP2\\_LCx\\_CODE \[11:8\]](#) FSC, [CCP2\\_LCx\\_CODE \[15:12\]](#) FEC, [CCP2\\_LCx\\_CODE \[3:0\]](#) LSC, and [CCP2\\_LCx\\_CODE \[7:4\]](#) LEC overwrite the 4 LSBs of the 32-bit synchronization codes. The default values should not be modified.

#### 6.5.3.18 Camera ISP CSI1/CCP2B Status Data

The SOF and EOF status lines can be output to memory.

The SOF and EOF status lines always cover full lines. No register settings enable the setting of width.

The [CCP2\\_LCx\\_STAT\\_START](#) register enables the setting of the vertical start position of the SOF and EOF status lines. Because the SOF status line comes first in the CSI1/CCP2B frame, [CCP2\\_LCx\\_STAT\\_START \[11:0\]](#) SOF = 0x0.

The [CCP2\\_LCx\\_STAT\\_SIZE](#) register enables the setting of the numbers of SOF and EOF status lines. If [CCP2\\_LCx\\_STAT\\_SIZE \[11:0\]](#) SOF = 0x0 and [CCP2\\_LCx\\_STAT\\_SIZE \[27:16\]](#) EOF = 0x0, no status data are output.

Figure 6-106 shows the SOF and EOF region settings. The SOF and EOF status lines and the pixel data must not overlap, but can be consecutive. Figure 6-106 shows the SOF and EOF region settings.

**Figure 6-106. Camera ISP CSI1/CCP2B SOF and EOF Region Settings**

camisp-201

The 32-bit destination address of the SOF status lines is set by the [CCP2\\_LCx\\_SOF\\_ADDR](#) register.

**NOTE:** The destination address must be aligned on a 32-byte boundary; the address 5 LSBs are ignored. The SOF lines are packed together at the destination address.

The 32-bit destination addresses of the EOF status lines are set by the [CCP2\\_LCx\\_EOF\\_ADDR](#) register.

**NOTE:** The destination address must be aligned on a 32-byte boundary; the address 5 LSBs are ignored. The EOF lines are packed together at the destination address.

**NOTE:** The CSI1/CCP2B receiver does not modify the data in the SOF and EOF status lines. The data are received and written with no modifications.

#### 6.5.3.19 Camera ISP CSI1/CCP2B Pixel Data Region

Pixel data can be output to memory or to the Video processing hardware.

The pixel data region covers full lines. The [CCP2\\_LCx\\_DAT\\_SIZE](#) register sets the horizontal size of the pixel region. The vertical size is expressed in lines.

The [CCP2\\_LCx\\_DAT\\_START](#) register enables the setting of the vertical start position of the pixel data. The vertical start position is expressed in lines.

[Figure 6-107](#) shows the pixel region settings.

**Figure 6-107. Camera ISP CSI1/CCP2B Pixel Data Region Settings**



camisp-202

The 32-bit destination addresses of the pixel data are set by the `CCP2_LCx_DAT_PING_ADDR` and `CCP2_LCx_DAT_PONG_ADDR` registers.

**NOTE:** The destination address must be aligned on a 32-byte boundary; the address 5 LSBs are ignored. The pixel data lines are packed together at the destination address.

It is possible to perform double-buffering (ping-ponging) at the destination by setting different addresses in the [CCP2\\_LCx\\_DAT\\_PING\\_ADDR](#) and [CCP2\\_LCx\\_DAT\\_PONG\\_ADDR](#) registers. It is possible to disable double-buffering by setting up the same address in both registers. The [CCP2\\_LCx\\_CTRL](#) [17] PING\_PONG status bit must be used by the software to determine which address contains the latest frame.

A destination pitch controls the address jump between the address of the first pixel of the previous line and the address of the first pixel of the current line. The destination pitch is set in bytes with the [CCP2\\_LCx\\_DAT\\_OFST](#) register. It applies for [CCP2\\_LCx\\_DAT\\_PING\\_ADDR](#) and [CCP2\\_LCx\\_DAT\\_PONG\\_ADDR](#).

**NOTE:** The destination pitch must be a multiple of 32 bytes; the address 5 LSBs are ignored.

The use of [CCP2\\_LCx\\_DAT\\_OFST](#) is limited to the following destination data formats:

- YUV422 little endian
  - YUV422 big endian

- RGB444 + EXP16
- RGB565
- RGB888 + EXP32

For all other data formats, the [CCP2\\_LCx\\_DAT\\_OFST](#) register is ignored (equivalent to [CCP2\\_LCx\\_DAT\\_OFST](#) = 0x0).

The destination data format is set with the [CCP2\\_LCx\\_CTRL](#) [7:2] FORMAT bit field.

For the PING frame:

- @Line0 = [CCP2\\_LCx\\_DAT\\_PING\\_ADDR](#)
- @Line1 = @Line0 + [CCP2\\_LCx\\_DAT\\_OFST](#)
- @Line2 = @Line1 + [CCP2\\_LCx\\_DAT\\_OFST](#)

For the PONG frame:

- @Line0 = [CCP2\\_LCx\\_DAT\\_PONG\\_ADDR](#)
- @Line1 = @Line0 + [CCP2\\_LCx\\_DAT\\_OFST](#)
- @Line2 = @Line1 + [CCP2\\_LCx\\_DAT\\_OFST](#)

When [CCP2\\_LCx\\_DAT\\_OFST](#) = 0x0, the lines are written contiguously in memory. The destination pitch enables 2D transfers; it is required to write the pixel data directly in the frame buffer, for instance.

In such cases, [CCP2\\_LCx\\_DAT\\_OFST](#) = FRAME\_BUFFER\_WIDTH. Figure 6-108 shows the pixel data settings.

**Figure 6-108. Camera ISP CSI1/CCP2B Pixel Data Destination Settings**



camisp-203

### 6.5.3.20 Camera ISP CSI1/CCP2B Memory Read Channel

#### 6.5.3.20.1 Camera ISP CSI1/CCP2B Write Data From Sensor to Memory

Data can be captured from the sensor using any logical channel. To keep the native data format, the channel format must be set to YUV422 little-endian format.

### 6.5.3.20.2 Camera ISP CSI1/CCP2B Read Data from Memory

By default, the memory read channel is disabled. Before the memory read channel can be enabled ([CCP2\\_LCM\\_CTRL \[0\]](#) CHAN\_EN = 1), all logical channels must be disabled ([CCP2\\_CTRL \[0\]](#) IF\_EN = 0) and required registers must be configured.

When the [CCP2\\_CTRL \[3\]](#) FRAME bit is set, software must wait until disabling of the physical interface is effective before enabling the memory read channel.

The SBL image data read port is shared by the PREVIEW and CSI1/CCP2B receiver modules. The read port must be affected to the CSI1/CCP2B receiver module by writing 1 to the [ISP\\_CTRL\[27\]](#) SBL\_SHARED\_RPORTA bit. The programmer must ensure that the PREVIEW module does not use this port before switching to the CSI1/CCP2B module.

The burst size must be configured to 32 x 64-bit bursts, using the [CCP2\\_LCM\\_CTRL \[7:5\]](#) BURST\_SIZE register.

Firmware must then configure the source data format, location, and framing. In addition to the [CCP2\\_LCM\\_HSIZE \[11:0\]](#) SKIP and [CCP2\\_LCM\\_HSIZE \[27:16\]](#) COUNT registers, the firmware must specify the amount of data to be fetched from memory. This value is set in 64-bit word steps and must be a multiple of 32 bytes (four words of 64 bits). The value is computed with the following formula:

$$\text{HWORDS} = 4 \times \text{ceil}((\text{SKIP} + \text{COUNT}) \times \text{bits\_per\_pixel})/(8 \times 32)) \quad (3)$$

The [CCP2\\_LCM\\_SRC\\_ADDR](#) and [CCP2\\_LCM\\_SRC\\_OFST](#) registers must be aligned on 32-byte boundaries for correct operation. For best performance, both registers must be aligned on 256-byte boundaries.

Example:

- [CCP2\\_LCM\\_CTRL \[7:5\]](#) BURST\_SIZE is set to 32 x 64 bits
- [CCP2\\_LCM\\_HSIZE \[11:0\]](#) SKIP = 0
- [CCP2\\_LCM\\_HSIZE \[27:16\]](#) COUNT = 1000
- [CCP2\\_LCM\\_CTRL \[23\]](#) SRC\_PACK = YES
- [CCP2\\_LCM\\_CTRL \[18:16\]](#) SRC\_FORMAT = RAW6
- [CCP2\\_LCM\\_PREFETCH \[13:3\]](#) HWORDS = 96 (=94)

Setting the size to 94 produces the following burst sequence: 32, 32, 16, 8, and 4 (5 interconnect requests). However, when it is set to 96, the burst sequence is 32, 32, and 32 (3 interconnect requests).

By default, only MIPI CSI1 data formats are supported. To support CCP2 formats, [CCP2\\_CTRL \[4\]](#) MODE must be set by firmware.

Data is sent to memory when [CCP2\\_LCM\\_CTRL \[2\]](#) DST\_PORT = 1; otherwise, it is sent to the video port. It is not possible to send data to the video port and memory concurrently. If data are sent to the video port, its clock frequency is selected with the [CCP2\\_CTRL \[31:15\]](#) FRACDIV bit field. Otherwise, the [CCP2\\_CTRL \[31:15\]](#) FRACDIV bit field is ignored.

---

**NOTE:** In a given scenario where data is sent to the video port and further down to ISP (CCDC and/or RSZ) to be processed, it is possible for CCP2 to stall the image signal processor by feeding too much data to CCDC and/or RSZ. At that time, the CCDC/RSZ FIFO overflow interrupt is raised. To prevent the processor from stalling, the VP clock must be lowered from [CCP2\\_CTRL\[31:15\]](#) FRACDIV.

---

The [CCP2\\_LCM\\_CTRL \[4:3\]](#) READ\_THROTTLE register can be used to reduce the bandwidth in memory-to-memory operation to prevent system overload. It has no effect when data are sent to the video port.

If the memory write port is used, the destination format and address must be configured.

Then the memory channel is enabled by setting [CCP2\\_LCM\\_CTRL \[0\]](#) CHAN\_EN = 1. After processing a full frame, this bit is automatically cleared by hardware and an EOF event is triggered.

## 6.5.4 Programming the CSI2 Receiver

### 6.5.4.1 Camera ISP CSI2 Enabling the Interface

The CSI2 interface is clocked by CSI2\_96\_FCLK, which is enabled by setting the PRCM.CM\_FCLKEN\_CAM[1] EN\_CSI2 bit register to 1.

### 6.5.4.2 Camera ISP CSI2 Reset Management

The CSI2 receiver accepts a general software reset, propagated throughout the hierarchy. This reset can be done to initialize the CSI2 receiver and the PHY and has the same effect as a hardware reset.

Figure 6-109 shows how to reset the CSI2 globally.

Figure 6-109. Camera ISP CSI2 Receiver Global Reset Flow Chart



camisp-252

NOTE: CSI2\_PHY\_CFG.RESET\_DONE is set to 1 only after the CSI2 receiver, CSI2 PHYs, and external camera sensor are initialized.

**NOTE:** Before setting the software reset bit to 1 in the [CSI2\\_SYSCONFIG](#) register, the user must have access to a CSI2 receiver register.

**NOTE:** The CSI2 protocol engine provides only the configuration bus clock when PHY registers are accessed. However, the PHY needs at least three configuration bus clock cycles (L4 interconnect clock) to come out of the reset state. Therefore, software must perform a dummy read of a PHY register (32 configuration bus clock pulses) to complete the PHY reset sequence.

### 6.5.4.3 Camera ISP CSI2 Enable Video/Picture Acquisition

To start a video/picture acquisition, perform the following steps:

1. Reset the CSI2 receiver module (see [Section 6.5.4.2, Reset Management](#)).
2. Configure the module power management: Set the [CSI2\\_SYSConfig\[13:12\]](#) MSTANDBY\_MODE bit field to 0x2 so the module tries to enter smart-standby mode during the vertical blanking period. The [CSI2\\_SYSConfig\[0\]](#) AUTO\_IDLE bit field keeps its reset value; by default, an automatic port clock gating strategy is applied based on port interface activity
3. Configure the interrupt generation as required using the [CSI2\\_IRQSTATUS](#) and [CSI2\\_IRQENABLE](#) registers. To enable context and/or PHY event reporting, enable the corresponding bit field in the [CSI2\\_IRQENABLE](#) register. If the enable bit is at 0, logging is still effective if an event occurs but is not reported to a higher level.
4. Configure the PHY interrupt generation as required using the [CSI2A\\_PHY\\_IRQSTATUS](#) and [CSI2\\_COMPLEXIO1\\_IRQENABLE](#) registers. If the enable bit is at 0, logging is still effective if an event occurs but is not reported to a higher level.
5. Initialize the PHY (see [Section 6.5.2.1, Camera ISP CSIPHY Initialization for Work With CSI2 Receiver](#)).
6. Set the [CSI2\\_CTRL\[2\]](#) ECC\_EN bit to 1 to activate ECC correction and error detection on short packets and packet headers. The ECC check corrects the packet if there is one error and generates an error if there is more than one error (unrecoverable error).
7. Start the CSI2 receiver by setting the [CSI2\\_CTRL\[0\]](#) IF\_EN bit to 1.
8. Configure the different contexts to be used (up to eight):
  - (a) Link the context to a virtual channel and a data type (see [Section 6.5.4.7, Linking a Context to a Virtual Channel and a Data Type](#)).
  - (b) Set the [CSI2\\_CTx\\_CTRL1\[26:23\]](#) FEC\_NUMBER bit field to 0x1 for a progressive video and to 0x2 for an interlaced video. For more information, see [Section 6.4.3.8, DMA Engine](#).
  - (c) Keep the [CSI2\\_CTx\\_CTRL1\[15:8\]](#) COUNT bit field and the [CSI2\\_CTx\\_CTRL1\[4\]](#) COUNT\_UNLOCK bit at their reset values (0x0 and 0, respectively) to capture an infinite number of frames (until the interface or the context is disabled).
  - (d) Set the [CSI2\\_CTx\\_CTRL1\[5\]](#) CS\_EN bit to enable the CRC checksum on long packet payload. This allows detection of errors, but cannot correct errors like the ECC for header and short packet. On error detection, an event is triggered (the [CSI2\\_CTx\\_IRQSTATUS\[5\]](#) CS IRQ bit).
  - (e) Configure the DMA engine for the current channel:
    - Configure the [CSI2\\_CTx\\_DAT\\_PING\\_ADDR\[31:5\]](#) ADDR bit field to set the ping frame address in memory.
    - Configure the [CSI2\\_CTx\\_DAT\\_PONG\\_ADDR\[31:5\]](#) ADDR bit field to set the pong frame address in memory. If not using a double-buffer mechanism, the ping and pong addresses must be equal so that all frames are stored at the same memory address).
    - Set the [CSI2\\_CTx\\_DAT\\_OFST\[15:5\]](#) OFST bit field to 0x0, so consecutive lines are stored consecutively in memory (image width and frame-buffer width are equal).

**NOTE:** Addresses given for PING and PONG frames are virtual addresses. Address translations are made on the camera MMU and on the Circular Buffer. For more information about the camera MMU module, see [Chapter 15, Memory Management Units](#).

- (f) Keep the [CSI2\\_CTx\\_CTRL3\[29:16\]](#) ALPHA bit field at its reset value (0x0) for RGB padding.
9. Enable the contexts to be used by setting the [CSI2\\_CTx\\_CTRL1\[0\]](#) CTX\_EN bit to 1.

### 6.5.4.4 Camera ISP CSI2 Disable Video/Picture Acquisition

There are two ways to end picture acquisition:

- Disable the corresponding context by writing 0 to the [CSI2\\_CTx\\_CTRL1\[0\]](#) CTX\_EN bit. This stops the acquisition for the current context. Other enabled contexts are still capturing frames and writing them in memory.

- Disable the CSI2 receiver interface by writing 0 to the [CSI2\\_CTRL\[0\]](#) IF\_EN bit. This can have an immediate effect if the [CSI2\\_CTRL\[3\]](#) FRAME bit is 0, or it can be effective after all the enabled contexts receive the FEC if the [CSI2\\_CTRL\[3\]](#) FRAME bit is 1.

#### 6.5.4.5 Camera ISP CSI2 Capture a Finite Number of Frames

The CSI2 receiver module can be configured to capture a finite number of frames. To configure the CSI2 receiver in this mode, perform the following steps:

1. Write 1 to the [CSI2\\_CTX\\_CTRL1\[4\]](#) COUNT\_UNLOCK bit to enable a write to the COUNT bit field.
2. Set the bit field to the number of frames the CSI2 receiver must capture. Valid values are 0 to 255; 0 is infinite capture and 1 to 255 defines the number of frames to capture.
3. Write 0 to the [CSI2\\_CTX\\_CTRL1\[4\]](#) COUNT\_UNLOCK bit to disable a write to the COUNT bit field.

During frame capture, the COUNT bit field is decremented by 1 at each frame capture. The software reads the COUNT bit field to know how many frames still must be captured.

The COUNT bit can be updated during capture if the COUNT\_UNLOCK is set to 1.

#### 6.5.4.6 Camera ISP CSI2 Configure a Periodic Event During Frame Acquisition

The CSI2 receiver can generate a periodic event. This line number is defined in the [CSI2\\_CTX\\_CTRL3\[15:0\]](#) LINE\_NUMBER bit field. The event can be generated once or multiple times per frame, depending on the [CSI2\\_CTX\\_CTRL1\[1\]](#) LINE\_MODULO bit value:

- If the LINE\_MODULO bit = 0, the event is generated when the line number corresponding to the LINE\_NUMBER bit field is received.
- If the LINE\_MODULO bit = 1, the event is generated when the line number received corresponds to a multiple of the LINE\_NUMBER value (LINE\_NUMBER is used as a modulo).

#### 6.5.4.7 Camera ISP CSI2 Linking a Context to a Virtual Channel and a Data Type

The CSI2 receiver supports eight contexts and the CSI2 protocol defines four virtual channels. Therefore, a CSI2 receiver context can be associated with a virtual channel and a data type. Virtual channels are defined by a 2-bit field. Valid data types for the CSI2 receiver with their associated values are described in [Table 6-60](#).

**Table 6-60. Camera ISP CSI2 Receiver-Supported Data Types**

| Value | Data Type                    |
|-------|------------------------------|
| 0x0   | Others                       |
| 0x12  | Embedded 8-bit nonimage data |
| 0x18  | YUV420 8-bit                 |
| 0x19  | YUV420 10-bit                |
| 0x1A  | YUV420 8-bit legacy          |
| 0x1C  | YUV420 8-bit + CSPS          |
| 0x1D  | YUV420 10-bit + CSPS         |
| 0x1E  | YUV422 8-bit                 |
| 0x1F  | YUV422 10-bit                |
| 0x22  | RGB565                       |
| 0x24  | RGB888                       |
| 0x28  | RAW6                         |
| 0x29  | RWA7                         |
| 0x2A  | RAW8                         |
| 0x2B  | RAW10                        |
| 0x2C  | RAW12                        |
| 0x2D  | RAW14                        |
| 0x33  | RGB666 + EXP32_24            |

**Table 6-60. Camera ISP CSI2 Receiver-Supported Data Types (continued)**

| Value | Data Type                                       |
|-------|-------------------------------------------------|
| 0x40  | USER_DEFINED_8_BIT_DATA_TYPE_1                  |
| 0x41  | USER_DEFINED_8_BIT_DATA_TYPE_2                  |
| 0x42  | USER_DEFINED_8_BIT_DATA_TYPE_3                  |
| 0x43  | USER_DEFINED_8_BIT_DATA_TYPE_4                  |
| 0x44  | USER_DEFINED_8_BIT_DATA_TYPE_5                  |
| 0x45  | USER_DEFINED_8_BIT_DATA_TYPE_6                  |
| 0x46  | USER_DEFINED_8_BIT_DATA_TYPE_7                  |
| 0x47  | USER_DEFINED_8_BIT_DATA_TYPE_8                  |
| 0x68  | RAW6 + EXP8                                     |
| 0x69  | RAW7 + EXP8                                     |
| 0x80  | USER_DEFINED_8_BIT_DATA_TYPE_1 + EXP8           |
| 0x81  | USER_DEFINED_8_BIT_DATA_TYPE_2 + EXP8           |
| 0x82  | USER_DEFINED_8_BIT_DATA_TYPE_3 + EXP8           |
| 0x83  | USER_DEFINED_8_BIT_DATA_TYPE_4 + EXP8           |
| 0x84  | USER_DEFINED_8_BIT_DATA_TYPE_5 + EXP8           |
| 0x85  | USER_DEFINED_8_BIT_DATA_TYPE_6 + EXP8           |
| 0x86  | USER_DEFINED_8_BIT_DATA_TYPE_7 + EXP8           |
| 0x87  | USER_DEFINED_8_BIT_DATA_TYPE_8 + EXP8           |
| 0x9E  | YUV422 8bit + VP                                |
| 0xA0  | RGB444 + EXP16                                  |
| 0xA1  | RGB555 + EXP16                                  |
| 0xAB  | RAW10 + EXP16                                   |
| 0xAC  | RAW12 + EXP16                                   |
| 0xAD  | RAW14 + EXP16                                   |
| 0xE3  | RGB666 + EXP32                                  |
| 0xE4  | RGB888 + EXP32                                  |
| 0xE8  | RAW6 + DPCM10 + VP                              |
| 0x12A | RAW8 + VP                                       |
| 0x12C | RAW12 + VP                                      |
| 0x12D | RAW14 + VP                                      |
| 0x12F | RAW10 + VP                                      |
| 0x229 | RAW7 + DPCM10 + EXP16                           |
| 0x2A8 | RAW6 + DPCM10 + EXP16                           |
| 0x2AA | RAW8 + DPCM10 + EXP16                           |
| 0x2C0 | USER_DEFINED_8_BIT_DATA_TYPE_1 + DPCM10 + EXP16 |
| 0x2C1 | USER_DEFINED_8_BIT_DATA_TYPE_2 + DPCM10 + EXP16 |
| 0x2C2 | USER_DEFINED_8_BIT_DATA_TYPE_3 + DPCM10 + EXP16 |
| 0x2C3 | USER_DEFINED_8_BIT_DATA_TYPE_4 + DPCM10 + EXP16 |
| 0x2C4 | USER_DEFINED_8_BIT_DATA_TYPE_5 + DPCM10 + EXP16 |
| 0x2C5 | USER_DEFINED_8_BIT_DATA_TYPE_6 + DPCM10 + EXP16 |
| 0x2C6 | USER_DEFINED_8_BIT_DATA_TYPE_7 + DPCM10 + EXP16 |
| 0x2C7 | USER_DEFINED_8_BIT_DATA_TYPE_8 + DPCM10 + EXP16 |
| 0x329 | RAW7 + DPCM10 + VP                              |
| 0x32A | RAW8 + DPCM10 + VP                              |
| 0x340 | USER_DEFINED_8_BIT_DATA_TYPE_1 + DPCM10 + VP    |
| 0x341 | USER_DEFINED_8_BIT_DATA_TYPE_2 + DPCM10 + VP    |
| 0x342 | USER_DEFINED_8_BIT_DATA_TYPE_3 + DPCM10 + VP    |

**Table 6-60. Camera ISP CSI2 Receiver-Supported Data Types (continued)**

| Value | Data Type                                    |
|-------|----------------------------------------------|
| 0x343 | USER_DEFINED_8_BIT_DATA_TYPE_4 + DPCM10 + VP |
| 0x344 | USER_DEFINED_8_BIT_DATA_TYPE_5 + DPCM10 + VP |
| 0x345 | USER_DEFINED_8_BIT_DATA_TYPE_6 + DPCM10 + VP |
| 0x346 | USER_DEFINED_8_BIT_DATA_TYPE_7 + DPCM10 + VP |
| 0x347 | USER_DEFINED_8_BIT_DATA_TYPE_8 + DPCM10 + VP |
| 0x368 | RAW6 DPCM 12 + VP                            |
| 0x369 | RAW7 DPCM 12 + EXP 16                        |
| 0x36A | RAW8 DPCM 12 + EXP 16                        |
| 0x3A8 | RAW6 DPCM 12 + EXP 16                        |
| 0x3A9 | RAW7 DPCM 12 + VP                            |
| 0x3AA | RAW8 DPCM 12 + VP                            |

For each context, a [CSI2\\_CTX\\_CTRL2](#) register defines with which channel and data type the context is associated:

- The VIRTUAL\_ID field defines the associated virtual ID transported by the CSI2 protocol from the camera sensor.
- The FORMAT field defines the associated data type. The data type is a combination of the data type transported by the CSI2 protocol and the type of storage in memory. A given data type (RGB888) can be stored in memory in different ways (RGB888 or RGB888 + EXP32). Therefore, the FORMAT field also defines the way DMA stores data in memory.

For example, for the current context to capture a frame from virtual channel 2 and data type RAW12 with data expansion (RAW12 + EXP16), write the value 0x10AC (0x2 11 + 0xAC) in the 16 LSBs of the [CSI2\\_CTX\\_CTRL2](#) register.

#### 6.5.4.8 Camera ISP CSI2 Progressive and Interleaved Frame Configuration

The CSI2 receiver can treat both progressive and interlaced frames. There is no progressive or interleaved mode, but the [CSI2\\_CTX\\_CTRL1\[23:16\]](#) FEC\_NUMBER field controls the number of FECs before swapping to the other (ping or pong) buffer. Therefore, two modes are possible:

- FEC\_NUMBER = 1: This is equivalent to progressive mode. After a FEC on the context, the current buffer is switched (ping to pong or pong to ping). The image in the memory buffer consists of one transmitted frame.
- FEC\_NUMBER != 1: The current buffer is switched (ping to pong or pong to ping) after the FEC\_NUMBER FEC is received for the context. The image in the memory buffer consists of the FEC\_NUMBER transmitted frame.

For more information about how data is stored in memory through the DMA, see [Section 6.4.3.8, DMA Engine](#).

**NOTE:** If FEC\_NUMBER != 1, the camera sensor must send the line number information with the current line. Otherwise, the CSI2 receiver cannot calculate each line address.

#### 6.5.5 Programming the Timing CTRL Module

**NOTE:** All the following settings must be done before enabling the timing control module.

##### 6.5.5.1 Camera ISP Timing CTRL Timing Generator

The cam\_xclka clock frequency is set through the [TCTRL\\_CTRL\[4:0\]](#) DIVA bit field. The cam\_xclkb clock frequency is set through the [TCTRL\\_CTRL\[9:5\]](#) DIVB bit field. One can change the divisor values at any time.

For divisor values 0, 1, and 31, the divider is not enabled. For all other values:

- $\text{cam\_xclka} = \text{cam\_mclk}/\text{TCTRL\_CTRL}[4:0]$  DIVA
- $\text{cam\_xclkb} = \text{cam\_mclk}/\text{TCTRL\_CTRL}[9:5]$  DIVB

### 6.5.5.2 Camera ISP Timing CTRL Camera-Control Signal Generator

Enabling of the SHUTTER, PRESTROBE or STROBE signals generation and actives the counters:

- $\text{TCTRL\_CTRL}[21]$  SHUTEN = 1
- $\text{TCTRL\_CTRL}[22]$  PSTRBEN = 1
- $\text{TCTRL\_CTRL}[23]$  STRBEN = 1

Two configurations apply:

- The control signals are based on the vertical synchronization information coming from the camera module or from the externally generated `cam_global_reset` signal.
- The control signals are based on the internally generated `cam_global_reset`.

#### 6.5.5.2.1 Camera ISP Timing CTRL Vertical Synchro-Based Control-Signal Generation or Externally-Generated `cam_global_reset`

Before enabling the control-signal generation, the following registers must be set:

- Select the input that triggers the control signals. The trigger signal can come from the PARALLEL, CSI2A, CSI2C or CSI1/CCP2B interface, or the externally-generated `cam_global_reset` signal.
  - $\text{TCTRL\_CTRL}[28:27]$  INSEL
- The signal must be set to INPUT:
  - $\text{TCTRL\_CTRL}[31]$  GRESETDIR = 0x0
  - Writes to  $\text{TCTRL\_CTRL}[29]$  GRESETEN bit do not trigger the PRESTROBE, STROBE, and SHUTTER signals, and do not generate the `cam_global_reset` signal.
- The following bits are cleared automatically to 0 after the signal assertion:
  - $\text{TCTRL\_CTRL}[21]$  SHUTEN
  - $\text{TCTRL\_CTRL}[22]$  PSTRBEN
  - $\text{TCTRL\_CTRL}[23]$  STRBEN
- The following bits set the polarity of the SHUTTER, STROBE/PRESTROBE, and `cam_global_reset` signals. The signals can be active high or active low:
  - $\text{TCTRL\_CTRL}[24]$  SHUTPOL
  - $\text{TCTRL\_CTRL}[26]$  STRBPSTRBPOL
  - $\text{TCTRL\_CTRL}[30]$  GRESETPOL
- The following bit sets the clock divisor value, which generates the CNTCLK clock:
  - $\text{TCTRL\_CTRL}[18:10]$  DIVC

The clock is set by  $\text{CNTCLK} = \text{cam\_mclk}/\text{TCTRL\_CTRL}[18:10]$  DIVC. The possible values are 0 to 511. Setting DIVC = 0 disables the CNTCLK clock generation.

- The frame counters are set with (possible values are 0 to 63 frames):
  - $\text{TCTRL\_FRAME}[5:0]$  SHUT
  - $\text{TCTRL\_FRAME}[11:6]$  PSTRB
  - $\text{TCTRL\_FRAME}[17:12]$  STRB

---

**NOTE:** If the value is 0, the timing control module does not delay any frame in input.

---

- The delay counters are set with:
  - $\text{TCTRL\_SHUT\_DELAY}$
  - $\text{TCTRL\_PSTRB\_DELAY}$

- [TCTRL\\_STRB\\_DELAY](#)

The possible values are 0 to  $2^{25}$  - 1 cycles. The cycles are at the CNTCLK clock frequency. The maximum signal duration is  $(2^{25} - 1) \times 2.366 \text{ s} = 79 \text{ s}$  ([TCTRL\\_CTRL\[18:10\]](#) DIVC = 511).

- The signal durations are set with:

- [TCTRL\\_SHUT\\_LENGTH](#)

- [TCTRL\\_PSTRB\\_LENGTH](#)

- [TCTRL\\_STRB\\_LENGTH](#)

The possible values are 0 to  $2^{24}$  - 1 cycles. The cycles are at the CNTCLK clock frequency. The maximum signal duration is  $(2^{24} - 1) \times 2.366 \text{ s} = 39.69 \text{ s}$  ([TCTRL\\_CTRL\[18:10\]](#) DIVC = 511).

#### **6.5.5.2.2 Camera ISP Timing CTRL Internally-Generated cam\_global\_reset-Based Control-Signal Generation**

Before enabling the cam\_global\_reset control-signal generation by writing [TCTRL\\_CTRL\[29\]](#) GRESETEN = 1, the following registers must be set:

---

**NOTE:** Setting [TCTRL\\_CTRL\[21\]](#) SHUTEN, [TCTRL\\_CTRL\[22\]](#) PSTRBEN, [TCTRL\\_CTRL\[23\]](#) STRBEN, and [TCTRL\\_CTRL\[29\]](#) GRESETEN to 1 simultaneously leads to unpredictable behavior. The [TCTRL\\_CTRL\[21\]](#) SHUTEN, [TCTRL\\_CTRL\[22\]](#) PSTRBEN, [TCTRL\\_CTRL\[23\]](#) STRBEN must be set before [TCTRL\\_CTRL\[29\]](#) GRESETEN is enabled.

---

- The signal must be set to OUTPUT:
  - [TCTRL\\_CTRL\[31\]](#) GRESETDIR = 0x1
  - Vertical synchronization events do not trigger the PRESTROBE, STROBE, and SHUTTER signals.
- The following bits are cleared automatically to 0 after the signal assertion:
  - [TCTRL\\_CTRL\[21\]](#) SHUTEN
  - [TCTRL\\_CTRL\[22\]](#) PSTRBEN
  - [TCTRL\\_CTRL\[23\]](#) STRBEN
  - [TCTRL\\_CTRL\[29\]](#) GRESETEN
- The following bits set the polarity of the SHUTTER, STROBE/PRESTROBE, and cam\_global\_reset signals. The signals can be active high or active low:
  - [TCTRL\\_CTRL\[24\]](#) SHUTPOL
  - [TCTRL\\_CTRL\[26\]](#) STRBPSTRBPOL
  - [TCTRL\\_CTRL\[30\]](#) GRESETPOL
- The following bit sets the clock divisor value, which generates the CNTCLK clock:
  - [TCTRL\\_CTRL\[18:10\]](#) DIVC

The clock is set by CNTCLK = cam\_mclk/[TCTRL\\_CTRL\[18:10\]](#) DIVC. The possible values are 0 to 511. Setting DIVC = 0 disables the CNTCLK clock generation.
- The frame counters bit fields are ignored:
  - [TCTRL\\_FRAME\[5:0\]](#) SHUT
  - [TCTRL\\_FRAME\[11:6\]](#) PSTRB
  - [TCTRL\\_FRAME\[17:12\]](#) STRB
- The delay counters are set with:
  - [TCTRL\\_SHUT\\_DELAY](#)
  - [TCTRL\\_PSTRB\\_DELAY](#)
  - [TCTRL\\_STRB\\_DELAY](#)

The possible values are 0 to 225 - 1 cycle. The cycles are at the CNTCLK clock frequency. The maximum signal duration is  $(2^{25} - 1) \times 2.366 \text{ s} = 79 \text{ s}$  ([TCTRL\\_CTRL\[18:10\]](#) DIVC = 511).
- The signal durations are set with:
  - [TCTRL\\_SHUT\\_LENGTH](#)

- [TCTRL\\_PSTRB\\_LENGTH](#)
- [TCTRL\\_STRB\\_LENGTH](#)

The possible values are 0 to  $2^{24} - 1$  cycle. The cycles are at the CNTCLK clock frequency. The maximum signal duration is  $(2^{24} - 1) \times 2.366 \text{ s} = 39.69 \text{ s}$  ([TCTRL\\_CTRL\[18:11\]](#) DIVC = 511).

- The cam\_global\_reset assertion time is set by [TCTRL\\_GRESET\\_LENGTH](#). The possible values are 0 to  $2^{24} - 1$  cycle. The cycles are at the CNTCLK clock frequency. The maximum signal duration is  $(2^{24} - 1) \times 2.366 \text{ s} = 39.69 \text{ s}$  ([TCTRL\\_CTRL\[18:11\]](#) DIVC = 511).

#### 6.5.5.2.3 Camera ISP Timing CTRL STROBE and PRESTROBE Signal Generation for Red-Eye Removal

The STROBE and PRESTROBE signal generation enables a strobe flash for red eye removal. The process is shown in [Figure 6-110](#). The dotted line corresponds to known timings from which the delay counters start decreasing: cam\_global\_reset event.

**Figure 6-110. cam\_strobe Signal-Generation for Red-Eye Removal**



- t1: Set by the [TCTRL\\_PSTRB\\_DELAY](#) register
- t2: set by the [TCTRL\\_PSTRB\\_LENGTH](#) register
- t5: set by the [TCTRL\\_PSTRB\\_REPEAT\[24:0\]](#) DELAY bit field. The number of times the pulse is repeated is controlled by the [TCTRL\\_PSTRB\\_REPEAT\[31:25\]](#) COUNTER register.

In the former example, [TCTRL\\_PSTRB\\_REPEAT\[31:25\]](#) COUNTER = 2.

- The possible delay values are 0 to  $2^{25} - 1$  cycle. The cycles are at the CNTCLK clock frequency. The maximum signal duration is  $(2^{25} - 1) \times 2.366 \text{ s} = 79 \text{ s}$  ([TCTRL\\_CTRL\[18:11\]](#) DIVC = 511).
- The possible count values are 0 to 127 additional pulses.
- t3: Set by the [TCTRL\\_STRB\\_DELAY](#) register
- t4: Set by the [TCTRL\\_STRB\\_LENGTH](#) register

#### 6.5.6 Programming the CCDC

This section discusses issues related to the software control of the CCDC. It lists which registers are required to be programmed in different modes, and describes how to enable and disable the CCDC, how to check the status of the CCDC, the different register access types, and programming constraints.

##### 6.5.6.1 Camera ISP CCDC Hardware Setup/Initialization

This section discusses the configuration of the CCDC required before image processing can begin.

###### 6.5.6.1.1 Camera ISP CCDC Reset Behavior

On hardware reset of the camera ISP, all registers in the CCDC are reset to their reset values.

### **6.5.6.1.2 Camera ISP CCDC Register Setup**

Before enabling the CCDC, the hardware must be correctly configured through register writes. Table 6-61 identifies the register parameters that must be programmed before enabling the CCDC.

**Table 6-61. Camera ISP CCDC Required Configuration Parameters**

| Function                          | Configuration Required                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| External pin signal configuration | <code>CCDC_SYN_MODE[0]</code> VDHOUT<br><code>CCDC_SYN_MODE[16]</code> VDHDEN<br><code>CCDC_SYN_MODE[2]</code> VDPOL<br><code>CCDC_SYN_MODE[3]</code> HDPOL<br><code>CCDC_SYN_MODE[7]</code> FLDMODE<br><code>CCDC_SYN_MODE[1]</code> FLDOUT<br><code>CCDC_SYN_MODE[4]</code> FLDPOL<br><code>CCDC_SYN_MODE[5]</code> EXWEN<br><code>CCDC_SYN_MODE[6]</code> DATAPOL<br><code>CCDC_CFG[15]</code> VLDC = 1<br><code>ISP_CTRL[3:2]</code> PAR_BRIDGE<br><code>ISP_CTRL[7:6]</code> SHIFT<br><code>ISP_CTRL[4]</code> PAR_CLK_POL |
| Input mode                        | <code>CCDC_REC656IF[0]</code> R656ON<br><code>CCDC_SYN_MODE[13 :12]</code> INPMOD                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Color pattern                     | <code>CCDC_COLPTN</code>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Black compensation                | <code>CCDC_BLKCMP</code>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Faulty-pixel correction           | <code>CCDC_FPC[15]</code> FPCEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Data-path configuration           | <code>CCDC_FMTCFG[15]</code> VPEN<br><code>CCDC_SYN_MODE[18]</code> VP2SDR<br><code>CCDC_SYN_MODE[17]</code> WEN<br><code>CCDC_SYN_MODE[19]</code> SDR2RSZ                                                                                                                                                                                                                                                                                                                                                                      |
| Lens-shading compensation         | <code>CCDC_LSC_CONFIG[0]</code> ENABLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

Table 6-62 identifies additional configuration requirements depending on whether the corresponding condition is met.

Table 6-62 can be read as: if (**Condition** is TRUE), then **Configuration Required** parameters must be programmed.

**Table 6-62. Camera ISP CCDC Conditional Configuration Parameters**

| Function                 | Condition                                                                                                                                  | Configuration Required                                                         |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| VD/HD set as outputs     | <code>CCDC_SYN_MODE[0]</code> VDHOUT = 0x1                                                                                                 | <code>CCDC_HD_VD_WID</code><br><code>CCDC_PIX_LINES</code>                     |
| Interlaced fields        | <code>CCDC_SYN_MODE[7]</code> FLDMODE = 0x1                                                                                                | <code>CCDC_CFG[7:6]</code> FIDMD                                               |
| External WEN             | <code>CCDC_SYN_MODE[5]</code> EXWEN = 0x1                                                                                                  | <code>CCDC_CFG[8]</code> WENLOG                                                |
| REC656 input             | <code>CCDC_REC656IF[0]</code> R656ON = 0x1<br><code>ISP_CTRL[3:2]</code> PAR_BRIDGE = 0x0                                                  | <code>CCDC_REC656IF[1]</code> ECCFVH<br><code>CCDC_CFG[5]</code> BW656         |
| YCC input                | <code>CCDC_SYN_MODE[13:12]</code> INPMOD != 0<br><code>CCDC_REC656IF[0]</code> R656ON = 0x0                                                | <code>CCDC_CFG[13]</code> MSBINVI<br><code>CCDC_DCSUB</code>                   |
| 8bit YCC Input 90 MHz    | <code>ISP_CTRL[3:2]</code> PAR_BRIDGE = 0x0<br><code>CCDC_SYN_MODE[13:12]</code> INPMOD == 2<br><code>CCDC_REC656IF[0]</code> R656ON = 0x0 | <code>CCDC_CFG[11]</code> Y8POS                                                |
| 8bit YCC Input 148.5 MHz | <code>ISP_CTRL[3:2]</code> PAR_BRIDGE = 0x1   <br><code>ISP_CTRL[3:2]</code> PAR_BRIDGE = 0x2                                              |                                                                                |
| RAW input                | <code>CCDC_SYN_MODE[13:12]</code> INPMOD == 0<br><code>CCDC_REC656IF[0]</code> R656ON = 0x0                                                | <code>CCDC_SYN_MODE[10:8]</code> DATSIZ<br><code>CCDC_CLAMP[31]</code> CLAMPEN |

**Table 6-62. Camera ISP CCDC Conditional Configuration Parameters (continued)**

| Function                                               | Condition                                                                                   | Configuration Required                                                                                                                                                                                                                                                                     |
|--------------------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Optical black clamp enabled                            | <code>CCDC_CLAMP[31]</code> CLAMPEN = 0x1<br><code>CCDC_SYN_MODE[13:12]</code> INPMOD == 0  | <code>CCDC_CLAMP[4:0]</code> OBGAIN<br><code>CCDC_CLAMP[24:10]</code> OBST<br><code>CCDC_CLAMP[27:25]</code> OBSLN<br><code>CCDC_CLAMP[30:28]</code> OBSLEN                                                                                                                                |
| Optical black clamp disabled                           | <code>CCDC_CLAMP[31]</code> CLAMPEN = 0x0<br><code>CCDC_SYN_MODE[13:12]</code> INPMOD == 0  | <code>CCDC_DCSUB</code>                                                                                                                                                                                                                                                                    |
| Faulty-pixel correction                                | <code>CCDC_FPC[15]</code> FPCEN = 0x1                                                       | <code>CCDC_FPC[14:0]</code> FPNUM<br><code>CCDC_FPC_ADDR</code><br>Fault Pixel Table must be in memory                                                                                                                                                                                     |
| Video-port (data formatter) enabled                    | <code>CCDC_FMTCFG[15]</code> VPEN = 0x1                                                     | <code>CCDC_FMTCFG[14:12]</code> VPIN<br><code>CCDC_FMT_HORZ</code><br><code>CCDC_FMT_VERT</code><br><code>CCDC_FMTCFG[0]</code> FMTEN<br><code>CCDC_VP_OUT</code><br><code>CCDC_FMTCFG[21:16]</code> VPIF_FRQ                                                                              |
| Reformatter enabled                                    | <code>CCDC_FMTCFG[0]</code> FMTEN = 0x1                                                     | <code>CCDC_FMTCFG[1]</code> LNALT                                                                                                                                                                                                                                                          |
| Reformatter enabled and line-alternating mode disabled | <code>CCDC_FMTCFG[0]</code> FMTEN = 0x1<br><code>CCDC_FMTCFG[1]</code> LNALT = 0x0          | <code>CCDC_FMTCFG[3:2]</code> LNUM<br><code>CCDC_FMT_ADDRx</code> (x = 0 to 7)<br><code>CCDC_FMTCFG[11:8]</code> PLEN_EVEN<br><code>CCDC_FMTCFG[7:4]</code> PLEN_ODD<br><code>CCDC_PRGEVEN0</code> or <code>CCDC_PRGEVEN1</code><br><code>CCDC_PRGODD0</code> or <code>CCDC_PRGODD1</code> |
| Write to memory or resizer                             | <code>CCDC_SYN_MODE[17]</code> WEN = 0x1<br>   <code>CCDC_SYN_MODE[19]</code> SDR2RSZ = 0x1 | <code>CCDC_HORZ_INFO</code><br><code>CCDC_VERT_START</code><br><code>CCDC_VERT_LINES</code><br><code>CCDC_SYN_MODE[14]</code> LPF<br><code>CCDC_CULLING</code><br><code>CCDC_ALAW[3]</code> CCDTBL<br><code>CCDC_SYN_MODE[11]</code> PACK8<br><code>CCDC_CFG[12]</code> BSWD               |
| Write to memory                                        | <code>CCDC_SYN_MODE[17]</code> WEN = 0x1                                                    | <code>CCDC_SDR_ADDR</code><br><code>CCDC_HSIZE_OFF</code><br><code>CCDC_SDOFST</code>                                                                                                                                                                                                      |
| A-Law                                                  | <code>CCDC_ALAW[3]</code> CCDTBL = 0x1                                                      | <code>CCDC_ALAW[2:0]</code> GWDI                                                                                                                                                                                                                                                           |
| Interrupt usage                                        | VDINT[1:0] Interrupts are enabled                                                           | <code>CCDC_VDINT</code>                                                                                                                                                                                                                                                                    |
| Lens-shading compensation                              | <code>CCDC_LSC_CONFIG[0]</code> ENABLE                                                      | <code>CCDC_LSC_CONFIG</code><br><code>CCSC_LSC_INITIAL</code><br><code>CCDC_LSC_TABLE_BASE</code><br><code>CCDC_LSC_TABLE_OFFSET</code>                                                                                                                                                    |

#### 6.5.6.1.3 Camera ISP CCDC Pixel Selection (Framing) Register Dependencies

There are three locations in the data flow where the valid frame data can be defined:

- Data formatter input pixel selection
- Video port output pixel selection
- Output formatter pixel selection

Care must be taken to ensure that the frame definitions correspond to the output of the upstream frame definitions. When the video port is enabled, `CCDC_VP_OUT[30:17]` VERT\_NUM must be less than `CCDC_FMT_VERT[12:0]` FMTLNV.

Two data paths through the CCDC affect the programming of the pixel-selection registers, depending on the value of the `CCDC_SYN_MODE[18]` VP2SDR bit:

- VP2SDR = 0: The input data bypasses the data formatter/video port. In this case, only the memory output frame parameters apply. This data path is represented by the white arrow in [Figure 6-111](#).
- VP2SDR = 1: The input data passes through the data formatter/video port. In this case, both data formatter frame definitions apply to the video-port output, and all three frame definitions apply to the memory output. This data path is represented by the green shaded arrow in [Figure 6-111](#).

**Figure 6-111. Camera ISP CCDC Dependencies Among Framing Settings in Data Flow**



### 6.5.6.2 Camera ISP CCDC Enable/Disable Hardware

All required registers mentioned in the previous section must be programmed before setting the [CCDC\\_PCR\[0\]](#) ENABLE bit.

The CCDC always operates in continuous mode. In other words, after enabling the CCDC, it processes sequential frames until the ENABLE bit is cleared by software. When this happens, the frame being processed completes before the CCDC is disabled.

When the CCDC is in master mode (HS/VS signals set to outputs), fetching and processing of the frame begin immediately on setting the [CCDC\\_PCR\[0\]](#) ENABLE bit.

When the CCDC is in slave mode (HS/VS signals set to inputs), processing of the frame depends on the input timing of the external sensor/decoder. To ensure that data from the external device is not missed, the CCDC must be enabled before data transmission from the external device. In this way, the CCDC waits for data from the external device.

On setting the [CCDC\\_FPC\[15\]](#) FPCEN bit, the CCDC begins to fetch and buffer the faulty-pixel table from memory. If faulty-pixel correction is used, the [CCDC\\_FPC\[15\]](#) FPCEN bit must be set before the [CCDC\\_PCR\[0\]](#) ENABLE bit, but after the faulty-pixel table is placed in memory and the [CCDC\\_FPC\[14:0\]](#) FPNUM and [CCDC\\_FPC\\_ADDR](#) registers are set.

### 6.5.6.3 Camera ISP CCDC Events and Status Checking

The CCDC can generate three different interrupts: CCDC\_VD0\_IRQ, CCDC\_VD1\_IRQ, and CCDC\_VD2\_IRQ.

The [CCDC\\_SYN\\_MODE\[16\]](#) VDHDEN bit must be enabled to receive any of the CCDC CCDC\_VDx\_IRQ interrupts.

#### 6.5.6.3.1 Camera ISP CCDC Interrupts

The CCDC module has three programmable events: CCDC\_VD0\_IRQ, CCDC\_VD1\_IRQ, and CCDC\_VD2\_IRQ, and one error event CCDC\_ERR\_IRQ. Event generation is described in [Section 6.5.6.3.2, CCDC\\_VD0\\_IRQ and CCDC\\_VD1\\_IRQ Interrupts](#), and [Section 6.5.6.3.3, CCDC\\_VD2\\_IRQ Interrupt](#).

CCDC module events can be mapped to the ARM or the DSP:

- The CCDC\_VD0\_IRQ, CCDC\_VD1\_IRQ, CCDC\_VD2\_IRQ, and CCDC\_ERR\_IRQ bits in the [ISP IRQ0ENABLE](#) register control whether the CCDC module events trigger an interrupt to the ARM. The [ISP IRQ0STATUS](#) register indicates which event(s) triggered the interrupt. An event is cleared by writing a 1 in its corresponding bit in the [ISP IRQ0STATUS](#) register. To clear the CCDC\_ERR\_IRQ interrupt, clear the [CCDC\\_FPC\[16\]](#) FPERR bit before clearing the [ISP IRQ0STATUS\[11\]](#) CCDC\_ERR\_IRQ bit.
- The CCDC\_VD0\_IRQ, CCDC\_VD1\_IRQ, CCDC\_VD2\_IRQ, and CCDC\_ERR\_IRQ bits in the [ISP IRQ1ENABLE](#) register control whether the CCDC module events trigger an interrupt to the DSP. The [ISP IRQ1STATUS](#) register indicates which event(s) triggered the interrupt. An event is cleared by writing a 1 in its corresponding bit in the [ISP IRQ1STATUS](#) register. To clear the CCDC\_ERR\_IRQ interrupt, clear the [CCDC\\_FPC\[16\]](#) FPERR bit before clearing the [ISP IRQ1STATUS\[11\]](#) CCDC\_ERR\_IRQ bit.

#### 6.5.6.3.2 Camera ISP CCDC CCDC\_VD0\_IRQ and CCDC\_VD1\_IRQ Interrupts

As shown in [Figure 6-112](#), the CCDC\_VD0\_IRQ and CCDC\_VD1\_IRQ interrupts occur relative to the VS pulse. The trigger timing is selected by using the [CCDC\\_SYN\\_MODE\[2\]](#) VDPOL setting. CCDC\_VD0\_IRQ and CCDC\_VD1\_IRQ occur after receiving the number of horizontal lines (HS pulse signals) set in the [CCDC\\_VDINT\[30:16\]](#) VDINT0 and [CCDC\\_VDINT\[14:0\]](#) VDINT1 register fields, respectively.

---

**NOTE:** In the case of BT.656 input mode, there is VS at the beginning of each field. Therefore, there are two interrupts for each frame (one for each field).

---

If **CCDC\_SYN\_MODE[2]** VDPOL is 0, the CCDC\_VD0\_IRQ and CCDC\_VD1\_IRQ HS counters begin counting HS pulses from the rising edge of the external VS, as shown in [Figure 6-112](#).

**Figure 6-112. Camera ISP CCDC CCDC\_VD0\_IRQ/CCDC\_VD1\_IRQ Interrupt Behavior When VDPOL = 0**



If **CCDC\_SYN\_MODE[2]** VDPOL is 1, the CCDC\_VD0\_IRQ and CCDC\_VD1\_IRQ HS counters begin counting HS pulses from the falling edge of the external VS.

**Figure 6-113. Camera ISP CCDC CCDC\_VD0\_IRQ/CCDC\_VD1\_IRQ Interrupt Behavior When VDPOL = 1**



#### 6.5.6.3.3 Camera ISP CCDC CCDC\_VD2\_IRQ Interrupt

In addition to the CCDC\_VD0\_IRQ and CCDC\_VD1\_IRQ interrupts, the CCDC has an interrupt called CCDC\_VD2\_IRQ. This interrupt always occurs at the falling edge of the WEN signal (through external pin). There are no registers in the CCDC module to configure this interrupt (see [Figure 6-114](#)).

**Figure 6-114. Camera ISP CCDC CCDC\_VD2\_IRQ Interrupt Behavior**



#### 6.5.6.3.4 Camera ISP CCDC Status Checking

The **CCDC\_PCR[1]** BUSY status bit is set when the start of frame occurs (if the **CCDC\_PCR[0]** ENABLE bit is 1 at that time). It is automatically reset to 0 at the end of a frame. The **CCDC\_PCR[1]** BUSY status bit may be polled to determine end-of-frame status.

The **CCDC\_FPC[16]** FPERR status bit is set when faulty-pixel data fetched from memory arrives late. This bit can be reset by writing a 1 to the bit.

#### 6.5.6.4 Camera ISP CCDC Register Accessibility During Frame Processing

There are three types of register access in the CCDC:

- Shadowed registers: In the CCDC, two register fields are shadowed in different ways. Shadowed registers can be read and written at any time, but the written values take effect (are latched) only at certain times, based on some event. Reads return the most recent write, even though the settings are not used until the specific event occurs. The shadowed registers are:
  - **CCDC\_PCR[0]** ENABLE
    - Written values take effect only at the start of a frame event (rising edge of VD if **CCDC\_SYN\_MODE[2]** VDPOL is positive, or falling edge of VD if **CCDC\_SYN\_MODE[2]** VDPOL is negative).
  - **CCDC\_SDR\_ADDR**

- When **CCDC\_CFG[15]** VDLC is set to 0, written values take effect only at the start of a frame event (rising edge of VD if **CCDC\_SYN\_MODE[2]** VDPOL is positive, or falling edge of VD if **CCDC\_SYN\_MODE[2]** VDPOL is negative). When **CCDC\_CFG[15]** VDLC is set to 1, written values take effect only at the start of the frame being output to memory (when the input has reached the **CCDC\_HORZ\_INFO[30:16]** SPH pixel of the **CCDC\_VERT\_START[30:16]** SLV0 or **CCDC\_VERT\_START[14:0]** SLV1 line of each field).
- Busy-writable registers: These registers/fields can be read or written even if the module is busy. Changes to the underlying settings occur instantaneously.  
All register fields in the CCDC not formerly listed as shadowed or below as optionally shadowed/busy-writable are busy-writable registers.
- Optionally Shadowed/Busy-Writable registers: All registers/fields listed below can be set as either shadow registers or busy-writable registers:
  - When **CCDC\_CFG[15]** VDLC is 0, these registers are shadowed.
  - When **CCDC\_CFG[15]** VDLC is 1, these registers are busy-writable.

**NOTE:** **CCDC\_CFG[15]** VDLC must be set to 1 by software if the CCDC is to be used; therefore, these registers are busy-writable. If **CCDC\_CFG[15]** VDLC remains set to 0 (default), indeterminate results may occur for ANY register access in the CCDC, not just those listed in the following.

- Optionally shadowed or busy-writable registers
  - **CCDC\_SYN\_MODE[19]** SDR2RSZ
  - **CCDC\_SYN\_MODE[18]** VP2SDR
  - **CCDC\_SYN\_MODE[16]** VDHDEN
  - **CCDC\_SYN\_MODE[17]** WEN
  - **CCDC\_SYN\_MODE[14]** LPF
  - **CCDC\_HD\_VD\_WID**
  - **CCDC\_PIX\_LINES**
  - **CCDC\_HORZ\_INFO**
  - **CCDC\_VERT\_START**
  - **CCDC\_VERT\_LINES**
  - **CCDC\_CULLING**
  - **CCDC\_HSIZE\_OFF**
  - **CCDC\_SDOFST**
  - **CCDC\_CLAMP[31]** CLAMPEN
  - **CCDC\_FMTCFG[0]** FMTEN
  - **CCDC\_LSC\_CONFIG**
  - **CCDC\_LSC\_INITIAL**
  - **CCDC\_LSC\_TABLE\_BASE**
  - **CCDC\_LSC\_TABLE\_OFFSET**

#### 6.5.6.5 Camera ISP CCDC Interframe Operations

Between frames, it may be necessary to enable/disable functions or modify memory pointers. Because the **CCDC\_PCR** register and memory pointer registers are shadowed, these modifications can take place any time before the end of the frame, and the data is latched in for the next frame. The MPU subsystem can perform these changes on receiving an interrupt.

## 6.5.6.6 Camera ISP CCDC Operations

### 6.5.6.6.1 Camera ISP CCDC Image-Sensor Configuration

#### 6.5.6.6.1.1 Camera ISP CCDC Input-Mode Selection

The CCDC module supports two modes: SYNC mode and ITU-R BT.656 mode. Specific settings correspond to each mode.

- SYNC mode:
  - In this mode, the input data can be either raw data or YCbCr data. Setting `CCDC_SYN_MODE.INPMODE` = 0 selects raw data, and `CCDC_SYN_MODE[13:12]` INPMODE = 1 or 2 selects YCbCr data on 16 or 8 bits. If `CCDC_SYN_MODE[13:12]` INPMODE = 0, the `cam_d` signal width is selected through `CCDC_SYN_MODE[10:8]` DATSIZ: the possible values are 8, 10, 11, and 12 bits.
  - If `CCDC_SYN_MODE[13:12]` INPMODE = 1, the `cam_d` signal width is 8 bits, but the internal CCDC module data path is configured to 16 bits. It is mandatory to enable the 8- to 16-bit bridge by setting `ISP_CTRL[3:2]` PAR\_BRIDGE = 2 or 3. The `ISP_CTRL[3:2]` PAR\_BRIDGE bit also controls how the 8-bit data is mapped onto the 16-bit data.
  - The value set in `CCDC_SYN_MODE[10:8]` DATSIZ does not matter. The position of the Y component can be set with the `CCDC_CFG[11]` Y8POS bit.
  - If `CCDC_SYN_MODE[13:12]` INPMODE = 2, the `cam_d` signal width is 8 bits. The value set in `CCDC_SYN_MODE[10:8]` DATSIZ does not matter. The position of the Y component can be set with the `CCDC_CFG[11]` Y8POS bit.
  - The internal timing generator must be enabled with `CCDC_SYN_MODE[16]` VDHDEN = 1.
- ITU mode:
  - In this mode, the data follows the protocol set by the ITU-R BT.656 protocol. To select it, set `CCDC_REC656IF[0]` R656ON = 1. When this mode is selected, the values set in `CCDC_SYN_MODE[13:12]` INPMODE and `CCDC_SYN_MODE[10:8]` DATSIZ do not matter.
  - To select the 8-bit or 10-bit protocol, set the `CCDC_CFG[5]` BW656 bit field. Data line `cam_d` [7:0] are used for 8-bit YCbCr and `cam_d`[9:0] are used for 10-bit YCbCr.
  - FVH error correction is enabled by setting `CCDC_REC656IF[1]` ECCFVH = 1.
  - The internal timing generator must be enabled with `CCDC_SYN_MODE[16]` VDHDEN = 1.

#### 6.5.6.6.1.2 Camera ISP CCDC Timing Generator and Frame Settings

The polarities of the `cam_hs`, `cam_vs`, and `cam_fld` signals are controlled by the `CCDC_SYN_MODE[3]` HDPOL, `CCDC_SYN_MODE[2]` VDPOL, and `CCDC_SYN_MODE[4]` FLDPOL bit fields. The polarities can be positive or negative.

The pixel data is presented on `cam_d` one pixel for every `cam_pclk` rising edge or falling edge. It is controlled with the `ISP_CTRL[4]` PAR\_CLK\_POL bit.

The `CCDC_SYN_MODE[7]` FLDMODE bit fields set the image-sensor type to progressive or interlaced mode. When the sensor is interlaced, the `CCDC_SYN_MODE[15]` FLDSTAT status bit indicates whether the current frame is odd or even.

The polarity of the `cam_d` signal can also be controlled with the `CCDC_SYN_MODE[6]` DATAPOL bit field. The polarity can be normal mode or ones complement mode.

Furthermore, the directions of the `cam_fld` and `cam_hs/cam_vs` signals are controlled by the `CCDC_SYN_MODE[1]` FLDOOUT and `CCDC_SYN_MODE[0]` VDHDOOUT bits. If `CCDC_SYN_MODE[0]` VDHDOOUT is set as an output, the `CCDC_PIX_LINES` register controls the length of the `cam_hs` and `cam_vs` signals.

If `CCDC_SYN_MODE[0]` VDHDOOUT = 1:

- The HS sync pulse width is given by `CCDC_HD_VD_WID[27:16]` HDW. The VS sync pulse width is given by `CCDC_HD_VD_WID[11:0]` VDW.

- The HS period is given by `CCDC_PIX_LINES[31:16]` PPLN. The VS period is given by `CCDC_PIX_LINES[15:0]` HLPRF x 2.

Figure 6-115 shows the HS/VS sync pulse output timings.

**Figure 6-115. Camera ISP CCDC HS/VS Sync Pulse Output Timings**



camisp-117

#### 6.5.6.6.1.3 Camera ISP CCDC Mosaic Filter Settings

The CCDC module supports image sensors with R, G, and B primary color mosaic filters and Ye, Cy, Mg, and G complementary color mosaic filters. The mosaic filter layout pattern is controlled by the `CCDC_COLPTN` register. Each bit field in this register controls the color associated to one pixel in a 4x4 region area. The 4x4 area repeats horizontally and vertically.

Figure 6-116 shows configuration examples of the `CCDC_COLPTN` register. It is assumed that CP0LPC0 is the first pixel output and CP3LPC3 is the last pixel output during frame readout.

**Figure 6-116. Camera ISP CCDC Mosaic Filter - CCDC\_COLPTN Bit Field Settings**

|      | col0    | col1    | col2I   | col3    |
|------|---------|---------|---------|---------|
| row0 | CP0LPC0 | CP0LPC1 | CP0LPC2 | CP0LPC3 |
| row1 | CP1LPC0 | CP1LPC1 | CP1LPC2 | CP1LPC3 |
| row2 | CP2LPC0 | CP2LPC1 | CP2LPC2 | CP2LPC3 |
| row3 | CP3LPC0 | CP3LPC1 | CP3LPC2 | CP3LPC3 |

(a) R, G and B color mosaic filter

|      | col0    | col1    | col2    | col3    |
|------|---------|---------|---------|---------|
| row0 | CP0LPC0 | CP0LPC1 | CP0LPC2 | CP0LPC3 |
| row1 | CP1LPC0 | CP1LPC1 | CP1LPC2 | CP1LPC3 |
| row2 | CP2LPC0 | CP2LPC1 | CP2LPC2 | CP2LPC3 |
| row3 | CP3LPC0 | CP3LPC1 | CP3LPC2 | CP3LPC3 |

(b) Cy, Ye and B color mosaic filter

camisp-088

### 6.5.6.6.2 Camera ISP CCDC Image-Signal Processing

#### 6.5.6.6.2.1 Camera ISP CCDC Digital Clamp

Digital clamp is enabled only if optical black clamping is disabled: [CCDC\\_CLAMP\[31\]](#) CLAMPEN = 0. The digital clamp DC value to be subtracted from the raw image data ([CCDC\\_SYN\\_MODE\[13:12\]](#) INPMOD = 0) or from the luminance ([CCDC\\_SYN\\_MODE\[13:12\]](#) INPMOD = 0 or [CCDC\\_REC656IF\[0\]](#) R656ON = 1) is set with the [CCDC\\_DCSUB](#) register. The DC value can range from 0 to 212-1. The reset value is 0.

#### 6.5.6.6.2.2 Camera ISP CCDC Optical Black Clamping

Optical black clamping is enabled by setting [CCDC\\_CLAMP\[31\]](#) CLAMPEN to 1. When enabled, an average of black-pixel samples is computed over a window. If the height of the window is 2N, the average value multiplied by a programmable gain factor is subtracted from the raw image data for the following 2N lines. Every 2N lines, a new average value is computed. For the first 2N lines, 0 is subtracted.

The size of the window and horizontal position are controlled by the [CCDC\\_CLAMP](#) register. The vertical position of the window is set to line 0 and cannot be modified:

- [CCDC\\_CLAMP\[30:28\]](#) OBSLEN sets the horizontal size of the window (1, 2, 4 or 8 pixels).
- [CCDC\\_CLAMP\[27:25\]](#) OBSLN sets the vertical size of the window (2N = 1, 2, 4 or 8 lines).
- [CCDC\\_CLAMP\[24:10\]](#) OBST sets the horizontal start position of the upper-left corner of the window. It is specified from the start of the HS sync pulse in pixel clocks.

The gain factor is set by the [CCDC\\_CLAMP\[4:0\]](#) OBGAIN bit field. Its fixed-point representation is U5Q4; the range is 0 to 1.9375. The gain factor reset value is 1.

If optical-black clamping is disabled, digital clamp is enabled.

#### 6.5.6.6.2.3 Camera ISP CCDC Black Compensation

Black compensation applies an offset to the raw image data. The offset is applied according to the phase and color for each phase. The black compensation offsets are controlled by the [CCDC\\_BLKCMP](#) register. All offsets are coded in S8Q0 representation (two's complement); the range is -128 to +127.

#### 6.5.6.6.2.4 Camera ISP CCDC Faulty-Pixel Correction

Faulty-pixel correction is enabled by setting the [CCDC\\_FPC\[15\]](#) FPCEN bit to 1. Before activating faulty-pixel correction, set the number of faulty pixels to be corrected in a frame with the [CCDC\\_FPC\[14:0\]](#) FPNUM bit field, set the faulty-pixel LUT in memory, and set the [CCDC\\_FPC\\_ADDR](#) register to the LUT address. The address should be aligned to a 64-bit byte boundary; the 6 LSBs are ignored. Reading the register always shows the 6 LSBs as 0.

If the CCDC module cannot fetch the required faulty-pixel entry in time, an error is set in the [CCDC\\_FPC\[16\]](#) FPERR bit. After the bit is set, no more faulty pixels are corrected in the frame. The bit is automatically cleared on the end of the frame and the feature reenabled for the following frame.

#### 6.5.6.6.2.5 Camera ISP CCDC Data Formatter

The data formatter transforms movie mode readout patterns into Bayer readout patterns. It is enabled by setting [CCDC\\_FMTCFG\[0\]](#) FMTEN to 1.

The [CCDC\\_FMT\\_HORZ](#) and [CCDC\\_FMT\\_VERT](#) registers set a clip window at the input of the data reformatter.

The data formatter converts a single line of movie mode sensor into multiple Bayer lines; it is capable of transforming 1 input line into 1, 2, 3, or 4 output lines. The number of lines generated from one input line is set by the [CCDC\\_FMTCFG\[3:2\]](#) LNUM bit field. The following limitations apply:

- The maximum number of pixels that can be supported in an output line if the input line is transformed into 1 output line is 4x1376 (1376 is the limit of the line memory).
- The maximum number of pixels that can be supported in an output line if the input line is transformed into 2 output lines is 2x1376.
- The maximum number of pixels that can be supported in an output line if the input line is transformed into 3 output lines is 1376.
- The maximum number of pixels that can be supported in an output line if the input line is transformed into 4 output lines is 1376.

The data reformatter gets its flexibility from up to 8 different addresses and a program that can contain up to 16 entries each for the odd and even lines. The program length for even fields is set with the [CCDC\\_FMTCFG\[11:8\]](#) PLEN\_EVEN bit field. The program length for odd fields is set with the [CCDC\\_FMTCFG\[7:4\]](#) PLEN\_ODD bit fields. Each entry refers to one of the 8 addresses and supports autoincrement and autodecrement.

- The 8 addresses are controlled by the [CCDC\\_FMT\\_ADDRx](#) registers ( $x = 0$  to 7).
- The 16 program entries for even lines are controlled by the [CCDC\\_PRGEVEN0](#) and [CCDC\\_PRGEVEN1](#) registers. The 16 program entries for odd lines are controlled by the [CCDC\\_PRGODD0](#) and [CCDC\\_PRGODD1](#) registers.

Modulo addressing is used to access the program entries. Even input lines use the even program and odd input lines use the odd program. Each new pixel in a line uses one program entry.

The [CCDC\\_VP\\_OUT](#) register sets the frame size at the output of the video port.

#### Example 6-2. Conventional readout pattern: 1 input line = 1 output line

The following input-to-output mapping (see [Table 6-63](#)) corresponds to a conventional readout pattern. One input line corresponds to 1 output line; the output can be as large as 4x1376 pixels.

**Table 6-63. Camera ISP CCDC Conventional Readout Pattern 1 to 1**

| Input    | Pixels order in input line  |   |   |   |       |      |      |      |      |  |
|----------|-----------------------------|---|---|---|-------|------|------|------|------|--|
| Output   | Pixels order in output line |   |   |   |       |      |      |      |      |  |
| Line [i] | 0                           | 1 | 2 | 3 | [...] | 5500 | 5501 | 5502 | 5503 |  |

To obtain this mapping between the input and output pixels, the following settings apply:

- CCDC\_FMTCFG [3:2] LNUM = 0 Converts to 1 line
- CCDC\_FMTCFG [11:8] PLEN\_EVEN = 0 1 program entry
- CCDC\_FMTCFG [7:4] PLEN\_ODD = 0 1 program entry
- CCDC\_FMT\_ADDR\_i [25:24] LINE (i = 0) = 0 Init ADDR0 pointer to 0th line
- CCDC\_FMT\_ADDR\_i [12:0] INIT (i = 0) = 0 Init ADDR0 index to 0th pixel
- CCDC\_PRGEVEN0 [3:0] EVEN0 = 0 Even prog entry 0: ADDR0++
- CCDC\_PRGODDO [3:0] ODD0 = 0 Odd prog entry 0: ADDR0++
- CCDC\_VP\_OUT [3:0] HORZ\_ST = 0 Horizontal start
- CCDC\_VP\_OUT [16:4] HORZ\_NUM = 0 Horizontal size

The program for even and odd lines is executed as follows. Because there is only one program entry, this instruction is executed repeatedly.

```
ADDR0= (0, 0)
While not end_of_line
{
    Write incoming pixel to ADDR0
    ADDR0+=(1, 0)
}
```

#### **Example 6-3. Dual readout pattern: 1 input line = 1 output line**

The following input-to-output mapping (see [Table 6-64](#)) corresponds to a conventional dual readout pattern. One input line corresponds to 1 output line; the output can be as large as 4x1376 pixels.

**Table 6-64. Camera ISP CCDC Dual Readout Pattern 1 to 1**

| Input    | Pixels order in input line  |   |   |   |       |      |      |      |      |
|----------|-----------------------------|---|---|---|-------|------|------|------|------|
| Output   | Pixels order in output line |   |   |   |       |      |      |      |      |
| Line [i] | 0                           | 1 | 2 | 3 | [...] | 4092 | 4093 | 4094 | 4095 |
| Line [i] | 0                           | 2 | 4 | 6 | [...] | 7    | 5    | 3    | 1    |

To obtain this mapping between the input and output pixels, the following settings apply:

- CCDC\_FMTCFG [3:2] LNUM = 0 Converts to 1 line
- CCDC\_FMTCFG [11:8] PLEN\_EVEN = 1 2 program entry
- CCDC\_FMTCFG [7:4] PLEN\_ODD = 1 2 program entry
- CCDC\_FMT\_ADDR\_i [25:24] LINE (i = 0) = 0 Init ADDR0 pointer to 0th line
- CCDC\_FMT\_ADDR\_i [12:0] INIT (i = 0) = 0 Init ADDR0 index to 0th pixel
- CCDC\_FMT\_ADDR\_i [25:24] LINE (i = 1) = 0 Init ADDR1 pointer to 0th line
- CCDC\_FMT\_ADDR\_i [12:0] INIT (i = 1) = 4095 Init ADDR1 index to 4095th pixel
- CCDC\_PRGEVEN0 [3:0] EVEN0 = 0 Even prog entry 0: ADDR0++
- CCDC\_PRGEVEN0 [7:4] EVEN1 = 3 Even prog entry 1: ADDR1--
- CCDC\_PRGODDO [3:0] ODD0 = 0 Even prog entry 0: ADDR0++
- CCDC\_PRGODDO [7:4] ODD1 = 3 Even prog entry 1: ADDR1--
- CCDC\_VP\_OUT [3:0] HORZ\_ST = 0 Horizontal start
- CCDC\_VP\_OUT [16:4] HORZ\_NUM = 0 Horizontal size

```

ADDR0=(0,0)
ADDR1=(4095,0)
While not end_of_line
{
  Write incoming pixel to ADDR0
  ADDR0+=(1,0)
  Write incoming pixel to ADDR1
  ADDR1 -=(1,0)
}

```

**Example 6-4. Dual readout pattern: 1 input line = 3 output line**

The following input-to-output mapping (see [Table 6-65](#)) corresponds to a complex pattern. One input line corresponds to 3 output lines; the output can be as large as 1376 pixels.

**Table 6-65. Camera ISP CCDC Dual Readout Pattern 1 to 3**

| Input         | Pixels order in input line  |    |    |       |       |    |    |    |   |
|---------------|-----------------------------|----|----|-------|-------|----|----|----|---|
| Line [i]      | 0                           | 1  | 2  | 3     | 4     | 5  | 6  | 7  | 8 |
|               | 9                           | 10 | 11 | [...] |       |    |    |    |   |
| Output        | Pixels order in output line |    |    |       |       |    |    |    |   |
| Line [3i]     |                             |    | 0  | 6     | [...] | 23 | 17 | 11 | 5 |
| Line [3i + 1] |                             | 2  | 8  | 14    | [...] | 15 | 9  | 3  |   |
| Line [3i + 2] | 4                           | 10 | 16 | 22    | [...] | 7  | 1  |    |   |

To obtain this mapping between the input and output pixels, the following settings apply:

- CCDC\_FMTCFG [3:2] LNUM = 2 Converts to 3 lines
- CCDC\_FMTCFG [11:8] PLEN\_EVEN = 5 6 program entries
- CCDC\_FMTCFG [7:4] PLEN\_ODD = 5 6 program entries
- CCDC\_FMT\_ADDR\_i [25:24] LINE (i = 0) = 0 Init ADDR0 pointer to 0th line
- CCDC\_FMT\_ADDR\_i [12:0] INIT (i = 0) = 2 Init ADDR0 index to 2nd pixel
- CCDC\_FMT\_ADDR\_i [25:24] LINE (i = 1) = 2 Init ADDR1 pointer to 2nd line
- CCDC\_FMT\_ADDR\_i [12:0] INIT (i = 1) = 855 Init ADDR1 index to 855th pixel
- CCDC\_FMT\_ADDR\_i [25:24] LINE (i = 2) = 1 Init ADDR2 pointer to first line
- CCDC\_FMT\_ADDR\_i [12:0] INIT (i = 2) = 1 Init ADDR2 index to first pixel
- CCDC\_FMT\_ADDR\_i [25:24] LINE (i = 3) = 1 Init ADDR3 pointer to first line
- CCDC\_FMT\_ADDR\_i [12:0] INIT (i = 3) = 856 Init ADDR3 index to 856th pixel
- CCDC\_FMT\_ADDR\_i [25:24] LINE (i = 4) = 2 Init ADDR4 pointer to second line
- CCDC\_FMT\_ADDR\_i [12:0] INIT (i = 4) = 0 Init ADDR4 index to 0th pixel
- CCDC\_FMT\_ADDR\_i [25:24] LINE (i = 5) = 0 Init ADDR5 pointer to 0th line
- CCDC\_FMT\_ADDR\_i [12:0] INIT (i = 5) = 857 Init ADDR5 index to 857th pixel
- CCDC\_PRGEVEN0 [3:0] EVEN0 = 0 Even prog entry 0: ADDR0++
- CCDC\_PRGEVEN0 [7:4] EVEN1 = 3 Even prog entry 1: ADDR1--
- CCDC\_PRGEVEN0 [11:8] EVEN2 = 4 Even prog entry 2: ADDR2++
- CCDC\_PRGEVEN0 [15:12] EVEN3 = 7 Even prog entry 3: ADDR3--
- CCDC\_PRGEVEN0 [19:16] EVEN4 = 8 Even prog entry 4: ADDR4++
- CCDC\_PRGEVEN0 [23:20] EVEN5 = 11 Even prog entry 4: ADDR5--
- CCDC\_PRGODDO [3:0] ODD0 = 0 Even prog entry 0: ADDR0++
- CCDC\_PRGODDO [7:4] ODD1 = 3 Even prog entry 1: ADDR1--
- CCDC\_PRGODDO [11:8] ODD2 = 4 Even prog entry 2: ADDR2++

|                               |                                               |
|-------------------------------|-----------------------------------------------|
| - CCDC_PRGODD0 [15:12] ODD3   | = 7 Even prog entry 3: ADDR3- -               |
| - CCDC_PRGODD0 [19:16] ODD4   | = 8 Even prog entry 4: ADDR4++                |
| - CCDC_PRGODD0 [23:20] ODD5   | = 11 Even prog entry 4: ADDR5- -              |
| - CCDC_VP_OUT [3:0] HORZ_ST   | = 2 Horizontal start, excludes first 2 pixels |
| - CCDC_VP_OUT [16:4] HORZ_NUM | = 854 Horizontal size                         |

```

ADDR0=(2,0)
ADDR1=(855,2)
ADDR2=(1,1)
ADDR3=(856,1)
ADDR4=(0,2)
ADDR5=(857,0)
While not end_of_line
{
    Write incoming pixel to ADDR0
    ADDR0 += (1, 0)
    Write incoming pixel to ADDR1
    ADDR1 -= (1, 0)
    Write incoming pixel to ADDR2
    ADDR2 += (1, 0)
    Write incoming pixel to ADDR3
    ADDR3 -= (1, 0)
    Write incoming pixel to ADDR4
    ADDR4 += (1, 0)
    Write incoming pixel to ADDR5
    ADDR5 -= (1, 0)
}

```

### Video Port

The 10-bit video-port output is enabled with [CCDC\\_FMTCFG\[15\]](#) VPEN = 1. Because the input data can be up to 12 bits, one must select which 10 bits are selected with [CCDC\\_FMTCFG\[14:12\]](#) VPIN.

The output of the video port goes to the Preview module. At the output of the video port, the data rate is resynchronized; the [CCDC\\_FMTCFG\[21:16\]](#) VPIF\_FRQ bit field selects the video-output data rate as: L3 speed/([CCDC\\_FMTCFG\[21:16\]](#) VPIF\_FRQ + 2) (from L3 speed/ 2 MHz to L3 speed/8 MHz). If [CCDC\\_FMTCFG\[21:16\]](#) VPIF\_FRQ frequency is set too low compared to the input pixel clock, overflow can occur.

#### 6.5.6.6.2.6 Camera ISP CCDC Output Formatter

##### 6.5.6.6.2.6.1 Camera ISP CCDC Low-Pass Filter

The low-pass filter is enabled with the [CCDC\\_SYN\\_MODE\[14\]](#) LPF bit. When enabled, two pixels each in the left and right edges of each line are cropped from the output.

##### 6.5.6.6.2.6.2 Camera ISP CCDC A-Law Compression

A-Law compression is enabled by setting [CCDC\\_ALAW](#) [3] CCDTBL to 1. The A-Law table is fixed, so no setup is required. When the input is wider than 10 bits, the [CCDC\\_ALAW](#) [2:0] GWDI bit is used to select which 10 bits of the 12 possible bits are selected for compression. See [Table 6-66](#).

**Table 6-66. Camera ISP CCDC CCDC\_ALAW [2:0] GWDI**

| GWDI   | Description  |
|--------|--------------|
| 4      | Bits 11 to 2 |
| 5      | Bits 10 to 1 |
| 6      | Bits 9 to 0  |
| Others | Reserved     |

### 6.5.6.6.2.6.3 Camera ISP CCDC Culling

Culling performs a horizontal and vertical decimation function. The horizontal and vertical culling patterns are set by the [CCDC\\_CULLING](#) register.

- The 8-bit [CCDC\\_CULLING\[31:24\]](#) CULHEVN and [CCDC\\_CULLING\[23:16\]](#) CULHODD bit fields set the horizontal culling pattern for even and odd lines. A 1 means that the pixel is retained; a 0 means that the pixel is skipped. The same number of retained pixels must be set for even and odd lines.
- The 8-bit [CCDC\\_CULLING\[7:0\]](#) CULV bit field sets the vertical culling pattern. The LSB represents the top line and the MSB represents the bottom line. A 1 means that the line is retained; a 0 means that the line is skipped.

### 6.5.6.6.2.6.4 Camera ISP CCDC Data Packing

Pixel data are stored to memory in little-endian format (bytes at lower addresses have lower significance). By default, pixel data are stored in 16-bit words; unused bits are filled with zeros.

If the input data is 8 bits, or if A-Law compression is enabled, the data can be stored in 8-bit words by setting the [CCDC\\_SYN\\_MODE\[11\]](#) PACK8 bit to 1.

If the input data is 12, 11, 10, or 9 bits, and A-Law compression is not enabled, the 8 MSBs are stored to memory.

[Figure 6-117](#) shows data packing and pixel ordering.

**Figure 6-117. Camera ISP CCDC Data Packing - Pixel Ordering**

|               | 3    | 2     | 1     | 0     | 0     |
|---------------|------|-------|-------|-------|-------|
|               | 1    | 4     | 5     | 7     | 0     |
| 12 bits       | 0    | pix 1 |       | 0     | pix 0 |
| 11 bits       | 0    | pix 1 |       | 0     | pix 0 |
| 10 bits       | 0    | pix 1 |       | 0     | pix 0 |
| 9 bits        | 0    | pix 1 |       | 0     | pix 0 |
| 8 bits        | 0    | pix 1 |       | 0     | pix 0 |
| 8 bits packed | pix3 |       | pix 2 | pix 1 | pix 0 |

camisp-118

### 6.5.6.6.2.6.5 Camera ISP CCDC Clipping Window

Before data is stored in memory, a clipping window can be set; only a selected sensor area is stored to memory. [Figure 6-118](#) shows the settings; only the white area is stored to memory.

- The valid-data horizontal start position is controlled with the [CCDC\\_HORZ\\_INFO\[30:16\]](#) SPH bit field. The valid-data vertical start position is controlled with the [CCDC\\_VERT\\_START](#) register. If the sensor is interlaced, the vertical start position for even and odd fields can be configured independently with the [CCDC\\_VERT\\_START](#) register. If the sensor is progressive, the [CCDC\\_VERT\\_START\[14:0\]](#) SLV1 bit field is ignored.
- The valid-data horizontal size is controlled with the [CCDC\\_HORZ\\_INFO\[14:0\]](#) NPH bit field. The horizontal size must be a multiple of 16 pixels. The valid-data vertical size is controlled with the [CCDC\\_VERT\\_LINES\[14:0\]](#) NLV register.

**Figure 6-118. Camera ISP CCDC Clipping Window Before Output to Memory**

camisp-119

#### 6.5.6.6.2.6.6 Camera ISP CCDC Output to Memory

The output formatter memory write enable is controlled by the [CCDC\\_SYN\\_MODE\[17\]](#) WEN bit. The output of the data reformatter can be written to memory by setting [CCDC\\_SYN\\_MODE\[18\]](#) VP2SDR to 1.

The pixel data at the output of the output formatter is written to the address given by the [CCDC\\_SDR\\_ADDR](#) register. The address should be aligned on a 32-byte boundary. The 5 LSBs are ignored. Reading the register always shows the 5 LSBs as 0.

A destination pitch can be set with the [CCDC\\_HSIZE\\_OFF](#) register. The offset must be a multiple of 32 bytes. The 5 LSBs are ignored. Reading the register always shows the 5 LSBs as 0. It is required for the pixel line length to be a multiple of 32 bytes to be stored in memory without holes.

The [CCDC\\_SDOFST](#) register controls how the pixels are stored to memory.

Data to be written to memory can be qualified by the external cam\_wen signal. This feature can be enabled by setting the [CCDC\\_SYN\\_MODE\[5\]](#) EXWEN bit. The [CCDC\\_CFG \[8\]](#) WENLOG bit configures how the cam\_wen signal is used with the internally generated valid signal.

The data can be swapped on a byte basis with the [CCDC\\_CFG\[12\]](#) BSWD bit.

If [CCDC\\_SYN\\_MODE\[13:12\]](#) INPMOD = 1, the MSB of the 8-bit chroma component can be inverted by setting [CCDC\\_CFG\[13\]](#) MSBINVI to 1.

### 6.5.6.7 Camera ISP CCDC Summary of Constraints

The following is a list of register configuration constraints to adhere to when programming the CCDC. It can be used as a quick checklist. More detailed register setting constraints can be found in the individual register descriptions.

- If the memory output port is enabled, the memory output line offset and address should be on 32-byte boundaries.
- If faulty-pixel correction is enabled, the [CCDC\\_FPC\\_ADDR](#) address should be on a 64-byte boundary.
- External WEN cannot be used when the VP2SDR path is enabled.
- If the formatter is enabled, in line-alternating mode, the vertical start and end number should be even.
- The horizontal number for the video port must be =  $1376 \times 4$ .
- If the video port is enabled, [CCDC\\_VP\\_OUT\[30:17\]](#) VERT\_NUM must be [CCDC\\_FMT\\_VERT\[12:0\]](#) FMTLNV.
- The video port must be enabled if the formatter is enabled.
- In YCC input mode:
  - The [CCDC\\_COLPTN](#) must be set to 0s.
  - The [CCDC\\_BLKCMP](#) must be set to 0s.
  - Faulty-pixel correction must be disabled.
  - The video port must be disabled.
  - The formatter must be disabled.
  - The VP2SDR must be disabled.
  - The low-pass filter must be disabled.
  - The A-Law must be disabled.
- In RAW input mode, the resizer output path should not be enabled.

### 6.5.7 Programming the Preview Engine

This section discusses issues related to software control of the preview engine. It lists which registers are required to be programmed in different modes, how to enable and disable the preview engine, and how to check the status of the preview engine; discusses the different register access types; and enumerates programming constraints.

#### 6.5.7.1 Camera ISP Preview Setup/Initialization

This section discusses the configuration of the preview engine required before image processing can begin.

##### 6.5.7.1.1 Camera ISP Preview Reset Behavior

On hardware reset of the camera ISP, all registers in the preview engine are reset to their reset values. However, because the preview engine programmable tables (gamma, noise filter, luminance enhancer, and CFA coefficients) are stored in internal memory, their contents do not have reset values. If the reset is a chip-level power-on reset (reset after power is applied), the contents of these tables are unknown. If the reset is a camera ISP module reset (when power remains active), the contents of these tables remain the same as before the reset.

##### 6.5.7.1.2 Camera ISP Preview Register Setup

Before enabling the preview engine, the hardware must be correctly configured through register writes. [Table 6-67](#) identifies the register parameters that must be programmed before enabling the preview engine.

**Table 6-67. Camera ISP Preview Engine Required Configuration Parameters**

| <b>Function</b>         | <b>Configuration Required</b>                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function enable/disable | <a href="#">PRV_PCR[5]</a> INVALAW<br><a href="#">PRV_PCR[7]</a> DRKFCAP<br><a href="#">PRV_PCR[6]</a> DRKFEN<br><a href="#">PRV_PCR[21]</a> SCOMP_EN<br><a href="#">PRV_PCR[8]</a> HMEDEN<br><a href="#">PRV_PCR[9]</a> NFEN<br><a href="#">PRV_PCR[10]</a> CFAEN<br><a href="#">PRV_PCR[26]</a> GAMMA_BYPASS<br><a href="#">PRV_PCR[15]</a> YNENHEN<br><a href="#">PRV_PCR[16]</a> SUPEN<br><a href="#">PRV_PCR[27]</a> DCOREN |
| IO ports                | <a href="#">PRV_PCR[2]</a> SOURCE<br><a href="#">PRV_PCR[20]</a> SDRPORT<br><a href="#">PRV_PCR[19]</a> RSZPORT                                                                                                                                                                                                                                                                                                                  |
| Input size              | <a href="#">PRV_HORZ_INFO</a><br><a href="#">PRV_VERT_INFO</a>                                                                                                                                                                                                                                                                                                                                                                   |
| Averager                | <a href="#">PRV_AVE</a>                                                                                                                                                                                                                                                                                                                                                                                                          |
| White balance           | <a href="#">PRV_PCR[14:11]</a> CFAFMT<br><a href="#">PRV_WB_DGAIN</a><br><a href="#">PRV_WBGAIN</a><br><a href="#">PRV_WBSEL</a>                                                                                                                                                                                                                                                                                                 |
| Black adjustment        | <a href="#">PRV_BLKADJOFF</a>                                                                                                                                                                                                                                                                                                                                                                                                    |
| RGB-to-RGB blending     | <a href="#">PRV_RGB_MAT1</a> to <a href="#">PRV_RGB_MAT5</a><br><a href="#">PRV_RGB_OFF1</a> to <a href="#">PRV_RGB_OFF2</a>                                                                                                                                                                                                                                                                                                     |
| RGB-to-YCbCr conversion | <a href="#">PRV_CSC0</a> to <a href="#">PRV_CSC2</a>                                                                                                                                                                                                                                                                                                                                                                             |
| Contrast and brightness | <a href="#">PRV_CNT_BRT</a>                                                                                                                                                                                                                                                                                                                                                                                                      |
| YCC output format       | <a href="#">PRV_SETUP_YC</a><br><a href="#">PRV_PCR[18:17]</a> YCPOS                                                                                                                                                                                                                                                                                                                                                             |

The [PRV\\_PCR](#) register contains control bits that enable or disable optional functions and module IO ports. If an optional function or port is enabled, there may be more registers or configuration information required for the preview engine to operate correctly.

**Table 6-68** can be read as:

If (**Condition** is TRUE) then

**Configuration required** parameters must be programmed.

**Table 6-68. Camera ISP Preview Engine Conditional Configuration Parameters**

| <b>Function</b>     | <b>Condition</b>                         | <b>Configuration Required</b>                                                                                                                          |
|---------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read from CCDC      | <a href="#">PRV_PCR [2]</a> SOURCE = 0x0 | <a href="#">PRV_PCR[3]</a> ONESHOT                                                                                                                     |
| Read from memory    | <a href="#">PRV_PCR [2]</a> SOURCE = 0x1 | <a href="#">PRV_PCR[4]</a> WIDTH<br><a href="#">PRV_RSDR_ADDR</a><br><a href="#">PRV_RADR_OFFSET</a><br><a href="#">ISP_CTRL[27]</a> SBL_SHARED_RPORTA |
| Dark frame subtract | <a href="#">PRV_PCR [6]</a> DRKFEN = 0x1 | <a href="#">PRV_DSDR_ADDR</a><br><a href="#">PRV_DRKF_OFFSET</a><br><a href="#">ISP_CTRL[28]</a> SBL_SHARED_RPORTB<br>Dark frame must be in memory     |

**Table 6-68. Camera ISP Preview Engine Conditional Configuration Parameters (continued)**

| Function                 | Condition                                                                                  | Configuration Required                                                                                                                        |
|--------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Shading correction       | <a href="#">PRV_PCR</a> [21] SCOMP_EN = 0x1<br><a href="#">PRV_PCR</a> [6]<br>DRKFEN = 0x1 | <a href="#">PRV_PCR</a> [24:22] SCOMP_SFT<br><a href="#">PRV_DSDR_ADDR</a><br><a href="#">PRV_DRKF_OFFSET</a><br>Dark frame must be in memory |
| Horizontal median filter | <a href="#">PRV_PCR</a> [8] HMEDEN = 0x1                                                   | <a href="#">PRV_HMED</a>                                                                                                                      |
| Noise filter             | <a href="#">PRV_PCR</a> [9] NFEN = 0x1                                                     | <a href="#">PRV_NF</a> [1:0] SPR<br>Setup Noise Filter Tables                                                                                 |
| Defect correction        | <a href="#">PRV_PCR</a> [27] DCOREN = 0x1                                                  | <a href="#">PRV_PCR</a> [28] DCOR_METHOD<br><a href="#">PRV_CDC_THRx</a> (x = 0 to 3)                                                         |
| CFA interpolation        | <a href="#">PRV_PCR</a> [10] CFAEN = 0x1                                                   | <a href="#">PRV_CFA</a><br>Setup CFA Coefficient Table                                                                                        |
| Gamma correction         | <a href="#">PRV_PCR</a> [26] GAMMA_BYPASS = 0x0                                            | Setup Gamma Correction Tables                                                                                                                 |
| Luminance enhancement    | <a href="#">PRV_PCR</a> [15] YNENHEN = 0x1                                                 | Setup Luminance Enhancement Table                                                                                                             |
| Chrominance suppression  | <a href="#">PRV_PCR</a> [16] SUPEN = 0x1                                                   | <a href="#">PRV_CSUP</a>                                                                                                                      |
| Write to memory          | <a href="#">PRV_PCR</a> [20] SDRPORT = 0x1                                                 | <a href="#">PRV_WSDR_ADDR</a><br><a href="#">PRV_WADD_OFFSET</a>                                                                              |

#### 6.5.7.1.3 Camera ISP Preview Table Setup

The three gamma memories, noise filter threshold memory, noise filter strength memory, luminance enhancer memory, and the CFA coefficient memory must be filled in before the operation of the preview engine, if their respective functions are enabled.

Two registers allow memory contents to be read and written:

- The address register is used to select the specific table entry: [PRV\\_SET\\_TBL\\_ADDR](#).
- The data register contains the data to be written to the specified location: [PRV\\_SET\\_TBL\\_DATA](#).

While the data register is 20 bits wide, only the 8 LSB data is used for the gamma, noise filter, and CFA filter tap memories.

The preview engine supports linear increments on reads and writes automatically. The following examples show how the programmer can read/write the memory. If data is read/written, the address pointer is automatically incremented. For random/noncontiguous reads/writes, [PRV\\_SET\\_TBL\\_ADDR](#) register must be modified.

---

**NOTE:** The address is not autoincremented when the preview engine is busy and users try to read/write the tables.

---

#### Example:

##### Read/write all the entries of the CFA table (using linear increment):

- WRITE (SET\_TBL\_ADDR, 0x1400);
- READ (SET\_TBL\_DATA, 0xvalue1);
- WRITE (SET\_TBL\_DATA, 0xvalue2);
- READ (SET\_TBL\_DATA, 0xvalue3);
- Etc. . . .
- READ (SET\_TBL\_DATA, 0xvalue163F);

**Read/write selective entries of the tables (have to program the address separately for each read/write)**

- WRITE (SET\_TBL\_ADDR, 11);
- READ (SET\_TBL\_DATA, value11);
- WRITE (SET\_TBL\_ADDR, 564);
- WRITE (SET\_TBL\_DATA, value564);

#### 6.5.7.2 Camera ISP Preview Enable/Disable Hardware

Setting the [PRV\\_PCR\[0\]](#) ENABLE bit to 0x1 enables the preview engine. This must be done after all required registers and tables are programmed.

When the input source is the memory, the preview engine always operates in one-shot mode. In other words, after enabling the preview engine, the ENABLE bit is automatically turned off (set to 0) and only a single frame is processed from memory. In this mode, fetching and processing of the frame begin immediately on setting the ENABLE bit.

When the input source is the CCDC, the preview engine can be configured to operate in either one-shot mode or continuous mode ([PRV\\_PCR \[3\]](#) ONESHOT). Processing of the frame is depends on the timing of the CCDC. To ensure that data from the CCDC is not missed, the preview engine must be enabled before the CCDC so that it waits for CCDC data.

---

**NOTE:** In one-shot mode, on setting the ENABLE bit, the processing of the frame begins and the ENABLE, ONESHOT, and SOURCE bits are reset to their reset values.

---

When the preview engine is in continuous mode, it can be disabled by clearing the ENABLE bit during the processing of the last frame. The disable is latched in at the end of the frame in which it is written.

#### 6.5.7.3 Camera ISP Preview Events and Status Checking

The preview engine generates an interrupt at the end of each frame.

The status of this interrupt can be checked by reading the [ISP IRQ0STATUS](#) register (or [ISP IRQ1STATUS](#)). When the read of the register [ISP IRQ0STATUS](#) occurs (or [ISP IRQ1STATUS](#)), the register is not automatically reset. To reset the interrupt, a 1 must be written to the PRV\_DONE\_IRQ bit.

Each event that generates an interrupt can be individually mapped to ARM or DSP using the [ISP IRQ0ENABLE](#) register (or [ISP IRQ1ENABLE](#)). When a particular event is not enabled (for example [ISP IRQ0ENABLE\[x\] = 0](#)), the correspondent status ([ISP IRQ0STATUS \[x\] = 1](#)) bit is flagged if the correspondent event occurs. This has no effect on the interrupt line, but can be used by software to poll the status.

The [PRV\\_PCR\[1\]](#) BUSY status bit is set when the start of frame occurs (if the [PRV\\_PCR\[0\]](#) ENABLE bit is 1 at that time). It is automatically reset to 0 at the end of a frame. The [PRV\\_PCR\[1\]](#) BUSY status bit may be polled to determine end-of-frame status.

The [PRV\\_PCR\[31\]](#) DRK\_FAIL status bit is set when dark-frame data fetched from memory arrives late. This bit can be reset by writing a 1 to the bit.

#### 6.5.7.4 Camera ISP Preview Register Accessibility During Frame Processing

There are three types of register access in the preview engine.

- Shadow registers: These registers/fields can be read and written (if the field is writable) at any time. However, the written values take effect only at the start of a frame. Reads return the most recent write, even though the settings are not used until the next start of frame.

The shadowed registers are:

- [PRV\\_PCR](#)
- [PRV\\_RSDR\\_ADDR](#)

- [PRV\\_RADR\\_OFFSET](#)
- [PRV\\_DSDR\\_ADDR](#)
- [PRV\\_DRKF\\_OFFSET](#)
- [PRV\\_WSDR\\_ADDR](#)
- [PRV\\_WADD\\_OFFSET](#)
- Busy-writable registers: These registers/fields can be read or written even if the module is busy. Changes to the underlying settings occur instantaneously.  
The busy-writable registers are:
  - [PRV\\_WB\\_DGAIN](#)
  - [PRV\\_WBGAIN](#)
- Busy-lock registers:
  - All registers EXCEPT the shadow and busy-writable registers belong to this category. Busy-lock registers cannot be written when the module is busy. Writes are allowed, but no change occurs in the registers (blocked writes from hardware perspective, but allowed writes from software perspective).
  - After the [PRV\\_PCR\[1\]](#) BUSY bit is reset to 0, busy-lock registers can be written.
  - The [PRV\\_SET\\_TBL\\_DATA](#) register cannot be read when the preview engine is busy, because this register is mapped to memories internally. Such reads return indeterminate data. Byte enables are not implemented for reading preview engine memories.

The ideal procedure for changing the preview engine registers is:

```
IF (PRV\_PCR\[1\] BUSY == 0) OR IF
(EOF interrupt occurs)
  DISABLE PREVIEW ENGINE
  CHANGE REGISTERS
  ENABLE PREVIEW ENGINE
```

#### 6.5.7.5 Camera ISP Preview Interframe Operations

Between frames, it may be necessary to enable/disable functions or modify memory pointers. Because the [PRV\\_PCR](#) register and memory pointer registers are shadowed, these modifications can occur any time before the end of the frame, and the data is latched in for the next frame. The MPU subsystem can perform these changes on receiving an interrupt.

#### 6.5.7.6 Camera ISP Preview Summary of Constraints

The following is a list of register configuration constraints to adhere to when programming the preview engine. It can be used as a quick checklist. More detailed register setting constraints can be found in the individual register descriptions.

- A frame can only be read from memory when the SBL read port is affected to the PREVIEW module ([ISP\\_CTRL\[27\]](#) SBL\_SHARED\_RPORTA = 0)
- The shading compensation feature can only be used when the SBL read port is affected to the PREVIEW module ([ISP\\_CTRL\[28\]](#) SBL\_SHARED\_RPORTB = 0)
- If the memory output port is enabled, the memory output line offset and address should be on 32-byte boundaries.
- The output width must be less than or equal to 4096.
- The output width must be even.
- Input to the horizontal median filter must be even.
- Defect correction can only be used when noise filter is enabled
- Input height must be smaller than CCDC output height.
- The input width of the preview engine must be a multiple of the average count multiplied by the least

common multiple of the odd distance and even distance of the averager.

- $(\text{PRV\_HORZ\_INFO}[13:0] \text{ EPH} - \text{PRV\_HORZ\_INFO}[29:16] \text{ SPH} + 1) \bmod ((1 \text{ PRV\_AVE}[1:0] \text{ COUNT}) * \text{LeastCommonMultiple}(\text{PRV\_AVE}[5:4] \text{ ODDDIST}+1, \text{PRV\_AVE}[3:2] \text{ EVENDIST}+1)) = 0$
- Input width must be at least 4 pixels smaller than CCDC output width:
  - $\text{PRV\_HORZ\_INFO}[29:16] \text{ SPH}$  at least 2 pixels before last pixel from CCDC
  - $\text{PRV\_HORZ\_INFO}[13:0] \text{ EPH}$  at least 2 pixels before last pixel from CCDC

### **6.5.8 Programming the Resizer**

This section discusses issues related to software control of the resizer. It lists which registers are required to be programmed in different modes, how to enable and disable the resizer, and how to check the status of the resizer; discusses the different register access types; and enumerates programming constraints.

#### **6.5.8.1 Camera ISP Resizer Setup/Initialization**

This section discusses the configuration of the resizer required before image processing can begin.

##### **6.5.8.1.1 Camera ISP Resizer Reset Behavior**

On hardware reset of the camera ISP, all registers in the resizer are reset to their reset values.

##### **6.5.8.1.2 Camera ISP Resizer Register Setup**

Before enabling the resizer, the hardware must be correctly configured through register writes. [Table 6-69](#) identifies the register parameters that must be programmed before enabling the resizer.

**Table 6-69. Camera ISP Resizer Required Configuration Parameters**

| Function                   | Configuration Required                                                                                                             |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Resizer control parameters | <a href="#">RSZ_CNT</a>                                                                                                            |
| IO sizes                   | <a href="#">RSZ_OUT_SIZE</a><br><a href="#">RSZ_IN_START</a><br><a href="#">RSZ_IN_SIZE</a>                                        |
| Memory addresses           | <a href="#">RSZ_SDR_INADD</a><br><a href="#">RSZ_SDR_INOFF</a><br><a href="#">RSZ_SDR_OUTADD</a><br><a href="#">RSZ_SDR_OUTOFF</a> |
| Filter coefficients        | <a href="#">RSZ_HFILT10</a> to <a href="#">RSZ_HFILT3130</a><br><a href="#">RSZ_VFILT10</a> to <a href="#">RSZ_VFILT3130</a>       |
| Edge enhancement           | <a href="#">RSZ_YENH[17:16]</a> ALGO                                                                                               |

The edge-enhancement function is optional:

- If it is disabled, the rest of the [RSZ\\_YENH](#) register does not need to be programmed.
- If it is enabled, the edge-enhancement parameters in [Table 6-70](#) must be programmed so that the edge-enhancement function operates correctly.

[Table 6-70](#) can be read as:

If (**Condition** is TRUE) then

**Configuration required** parameters must be programmed.

**Table 6-70. Camera ISP Resizer Conditional Configuration Parameters**

| Function         | Condition                         | Configuration Required                                            |
|------------------|-----------------------------------|-------------------------------------------------------------------|
| Edge enhancement | RSZ_YENH[17:16] ALG0 = 0x1 or 0x2 | RSZ_YENH[15:12] GAIN<br>RSZ_YENH[11:8] SLOP<br>RSZ_YENH[7:0] CORE |

### 6.5.8.2 Camera ISP Resizer Enable/Disable Hardware

Setting the [RSZ\\_PCR\[0\]](#) ENABLE bit to 0x1 enables the resizer. This must be done after all required registers are programmed.

When the input source is memory, the resizer always operates in one-shot mode. In other words, after enabling the resizer, the [RSZ\\_PCR\[0\]](#) ENABLE bit is automatically turned off (set to 0) and only a single frame is processed from memory.

In this mode, fetching and processing of the frame begin immediately on setting the [RSZ\\_PCR\[0\]](#) ENABLE bit.

When the input source is the CCDC or preview engine, the resizer can be configured to operate in either one-shot mode, or continuous mode ([RSZ\\_PCR\[2\]](#) ONESHOT). Processing of the frame depends on the timing of the CCDC/Preview. To ensure that data from the CCDC or preview engine is not missed, the resizer must be enabled before these upstream modules, so it waits for data from the CCDC or the preview engine.

When the resizer is started during an ongoing frame the enable is latched at the end of the frame it was written in.

When the resizer is in continuous mode, it can be disabled by clearing the ENABLE bit during the processing of the last frame. The disable is latched in at the end of the frame in which it was written.

### 6.5.8.3 Camera ISP Resizer Events and Status Checking

The resizer generates an interrupt event at the end of each frame.

The status of this interrupt can be checked by reading the [ISP IRQ0STATUS](#) register (or [ISP IRQ1STATUS](#)). When the read of the register [ISP IRQ0STATUS](#) occurs (or [ISP IRQ1STATUS](#)), the register is not automatically reset. To reset the interrupt, a 1 must be written to the RSZ\_DONE\_IRQ bit.

Each event that generates an interrupt can be individually mapped to ARM or DSP using the [ISP IRQ0ENABLE](#) register (or [ISP IRQ1ENABLE](#)). When a particular event is not enabled (for example [ISP IRQ0ENABLE\[x\] = 0](#)), the correspondent status ([ISP IRQ0STATUS\[x\] = 1](#)) bit is flagged, if the correspondent event occurs. This has no effect on the interrupt line, but can be used by software to poll the status.

The [RSZ\\_PCR\[1\]](#) BUSY status bit is set when the start of frame occurs (if the [RSZ\\_PCR\[0\]](#) ENABLE bit is 1 at that time). It is automatically reset to 0 at the end of a frame. The [RSZ\\_PCR\[1\]](#) BUSY status bit may be polled to determine end-of-frame status in oneshot mode. [Figure 6-119](#) shows the firmware/hardware interaction. Configuration registers and filter coefficients are programmed in-between or before busy periods, before writing ENABLE to 0x1.

**Figure 6-119. Camera ISP Resizer Firmware Interactions for Memory-Input Resizing**

**NOTE:** The [SBL\\_SDR\\_REQ\\_EXP\[19:10\]](#) RSZ\_EXP bit field enables the spreading of non-real time read requests over time. It is useful to avoid overflow situations when the resizer module is programmed to work from memory to memory.

#### 6.5.8.4 Camera ISP Resizer Register Accessibility During Frame Processing

There are two types of register access in the resizer.

- Shadow registers: These registers/fields can be read and written (if the field is writable) at any time. However, the written values take effect only at the start of a frame. Reads return the most recent write, even though the settings are not used until the next start of frame.

The shadowed registers are:

- [RSZ\\_PCR](#)
- [RSZ\\_SDR\\_INADD](#)
- [RSZ\\_SDR\\_INOFF](#)
- [RSZ\\_SDR\\_OUTADD](#)
- [RSZ\\_SDR\\_OUTOFF](#)
- Busy-lock registers
  - All registers EXCEPT the shadowed registers belong to this category.
  - Busy-lock registers cannot be written when the module is busy. Writes are allowed, but no change occurs in the registers (blocked writes from hardware perspective; allowed write from software perspective).
  - After the [RSZ\\_PCR\[1\]](#) BUSY bit is reset to 0, the busy-lock registers can be written.

The ideal procedure for changing the resizer registers is:

```
IF (RSZ\_PCR\[1\] BUSY == 0) OR IF  
(EOF interrupt occurs)  
    DISABLE RESIZER  
    CHANGE REGISTERS  
    ENABLE RESIZER
```

#### 6.5.8.5 Camera ISP Resizer Inter-Frame Operations

Between frames, it may be necessary to modify the memory pointers before processing the next frame. Because the [RSZ\\_PCR\[0\]](#) ENABLE bit and memory pointer registers are shadowed, these modifications can occur any time before the end of the frame, and the data is get latched in for the next frame. The MPU subsystem can perform these changes on receiving an interrupt.

**NOTE:** The firmware must compute and upload the filter coefficients. If polyphase resampling is used, a different set is required when changing between 4-tap and 7-tap modes, and with different downsampling factors; all upsampling factors can share the same set of coefficients. Do not change any busy-lock registers while the resizer is operating. Specifically, when back-to-back resizes require changes in any busy-lock registers (such as the coefficients, resizing ratios, input and output sizes), users must wait for the first resize to complete. The following section describes some scenarios where this is required.

#### 6.5.8.5.1 Camera ISP Resizer Multiple Passes for Large Resizing Operations

The resizer supports multiple passes of processing for large resizing operations. "Large" has the following meanings:

- Wider output than 4096 pixels: This works only in memory input mode. Input can be partitioned into multiple resizer blocks, and each block is separately resized and stitched together. Having input/output memory line offsets, input starting pixel and starting phase are essential to make this work. The basic idea is to begin subsequent slices at exactly where previous images leave off. The starting phase and pixel registers can be programmed to this exact location.
- Larger than 4x upsampling: Resizing can be applied in multiple passes. For example, 10x upsampling can be realized by first a 4x upsampling, then a 2.5x upsampling. The first pass can be performed on-the-fly with the preview engine. The second pass can be performed only with input from memory, and for 10x digital zoom; there is time outside the active picture region to perform the second pass.
- Larger than 4:1 downsampling: Although it is rarely necessary to generate a very small image from a large image, this is supported by the hardware. For example, 10x downsampling can be realized first with 4x downsampling on-the-fly with the preview engine, then 2.5x downsampling in the memory-input path. There may not be much time outside the active data region for the second pass, but since the image is already reduced to 1/16 of its original size, not much time is necessary. Typically, sensor or video input has 10 ~ 20 % of usable vertical blanking.

For all these scenarios, the second pass can be configured and initiated from an interrupt service routine triggered by the resizer end-of-frame interrupt: [ISP IRQ0ENABLE\[24\]](#) RSZ\_DONE\_IRQ (or [ISP IRQ1ENABLE](#)).

#### 6.5.8.5.2 Camera ISP Resizer Processing Time Calculation

The time calculated below is the time it takes for all resizes where the input source is memory (second pass when doing a 10x resize in preview mode; in the case of a 10x resize in preview mode, the first pass is hidden behind the time it takes to capture and process the image from the sensor based on cam\_pclk and the number of lines resized).

The following equation can be used to determine the processing time of the resizer when the input is from memory and therefore how much time it takes before it can switch back to preview input mode:

$$\text{Time} = [W \times \text{bytes\_per\_pixel} \times H]/[L3/2] \quad (4)$$

Where:

/\* If the input is YUV422 and horizontal downsampling is performed: \*/

```
if ((RSZ_CNT[27] INPTYP ==0) ((RSZ_CNT[9:0] HRSZ + 1) 256))
```

W = average (input\_width, output width); /\* output width includes extra 4 pixels if edge enhancement is enabled\*/

else

W = max(input width, output width); /\*output width includes extra 4 pixels if edge enhancement is enabled\*/

$$\begin{aligned} \text{input\_width} &= \text{RSZ\_IN\_SIZE}[12:0]\text{HORZ} \\ \text{output\_width} &= \text{RSZ\_OUT\_SIZE}[11:0]\text{HORZ} \\ \text{input\_height} &= \text{RSZ\_IN\_SIZE}[28:16]\text{VERT} \\ \text{bytes\_per\_pixel} &= \begin{cases} 1, & \text{when RSZ\_CNT[27]INPTYP = 1 (color separate)} \\ 2, & \text{when RSZ\_CNT[27]INPTYP = 0 (YUV422)} \end{cases} \end{aligned}$$

camisp-E097

This time is the baseline steady state calculation of the hardware and does not include the time it takes for the hardware to fetch the first input and fill the Video processing hardware. It also does not include the time spent from the last output from the resizer to get back to memory when the resizer interrupt occurs.

However, these beginning and ending times are relatively negligible.

Depending on real-time constraints, this processing time may be much faster than is required. (data fetches can be delayed from memory to free more bandwidth for use by other system peripherals; see [Section 6.5.11.5.2, Input from Memory](#).

#### **6.5.8.6 Camera ISP Resizer Summary of Constraints**

The following is a list of register configuration constraints to adhere to when programming the resizer. It can be used as a quick checklist. More detailed register setting constraints can be found in the individual register descriptions.

- Vertical and horizontal resize ratio values must be within the following range: [64..1024].
- Output width:
  - Must be within the maximum limit:
    - width 4096 (if vertical resize value is in range:  $(\text{RSZ_CNT}[19:10] \text{ VRSZ} + 1) = [64..512]$ )
    - width 2048 (if vertical resize value is in range:  $(\text{RSZ_CNT}[19:10] \text{ VRSZ} + 1) = [513..1024]$ )
  - Must be even
  - Must be a multiple of 16 bytes (for vertical upsizing)
- When input is from preview engine/CCDC:
  - The input height and width must be = the output of the preview engine/CCDC.
  - The input address and offset must be zero.
  - The input cannot be color-separated data.
- If the source is memory:
  - The vertical start pixel must be zero.
  - The horizontal start pixel must be within the range: 0:15 for color interleaved, 0:31 for color separate data.
  - The memory output line offset and address must be on 32-byte boundaries.
- Input height and width MUST adhere to the equations in [Table 6-71](#).

**Table 6-71. Camera ISP Resizer How to Set Input Height and Width**

|                                          | 8-phase, 4-tap mode                                            | 4-phase, 7-tap mode                                            |
|------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------|
| <a href="#">RSZ_IN_SIZE</a> [12:0] HORZ  | $(32 * \text{sph} + (\text{ow} - 1) * \text{hrs}z + 16) 8 + 7$ | $(64 * \text{sph} + (\text{ow} - 1) * \text{hrs}z + 32) 8 + 7$ |
| <a href="#">RSZ_IN_SIZE</a> [28:16] VERT | $(32 * \text{spv} + (\text{oh} - 1) * \text{vrs}z + 16) 8 + 4$ | $(64 * \text{spv} + (\text{oh} - 1) * \text{vrs}z + 32) 8 + 7$ |

Where:

- sph = Start phase horizontal ([RSZ\\_CNT\[22:20\]](#) HSTPH)
- spv = Start phase vertical ([RSZ\\_CNT\[25:23\]](#) VSTPH)
- ow = Output width ([RSZ\\_OUT\\_SIZE\[11:0\]](#) HORZ + extra)
- oh = Output height ([RSZ\\_OUT\\_SIZE\[27:16\]](#) VERT)
- hrsz = Horizontal resize value ([RSZ\\_CNT\[9:0\]](#) HRSZ + 1)
- vrsz = Vertical resize value ([RSZ\\_CNT\[19:10\]](#) VRSZ +1)
- extra = 0 when [RSZ\\_YENH\[17:16\]](#) ALGO = 0 (edge enhancement disabled)
- extra = 4 when [RSZ\\_YENH\[17:16\]](#) ALGO != 0 (edge enhancement enabled)

**NOTE:** Normally, (for example, for a QVGA display or encoded PAL video), the output size, not the input size, matters. The image provided by preview/CCDC/memory must have an adequate output size: at least [RSZ\\_IN\\_SIZE\[12:0\]](#) HORZ x [RSZ\\_IN\\_SIZE\[28:16\]](#) VERT. If the image is bigger, the resizer can crop extra pixels.

The phase is usually computed to keep the center of the image at the same location. This permits a natural-looking continuous digital zoom.

For this reason, [Table 6-71](#) explains how to compute [RSZ\\_IN\\_SIZE\[12:0\]](#) HORZ , [RSZ\\_IN\\_SIZE\[28:16\]](#) VERT, not how to compute the output size.

## 6.5.9 Programming the H3A

This section discusses issues related to software control of the H3A module. It lists which registers are required to be programmed in different modes, how to enable and disable the H3A, and how to check the status of the H3A. It also discusses the different register access types and enumerates programming constraints.

### 6.5.9.1 Camera ISP H3A Setup/Initialization

This section discusses the configuration of the H3A required before image processing can begin.

#### 6.5.9.1.1 Camera ISP H3A Reset Behavior

On hardware reset of the camera ISP, all registers in the H3A are reset (set to their reset values).

#### 6.5.9.1.2 Camera ISP H3A Register Setup

For register configuration, the AF engine and the AEW engine of the H3A can be independently be configured. Because there are separate enable bits for each engine, so this section discusses the AF engine and the AEW engine separately.

##### 6.5.9.1.2.1 Camera ISP H3A AF Engine

Before enabling the AF engine, the hardware must be correctly configured through register writes.

[Table 6-72](#) identifies the register parameters that must be programmed before enabling the AF engine of the H3A.

**Table 6-72. Camera ISP H3A AF Engine Required Configuration Parameters**

| Function                  | Configuration Required                                                        |
|---------------------------|-------------------------------------------------------------------------------|
| AF optional preprocessing | <a href="#">H3A_PCR[2]</a> AF_MED_EN<br><a href="#">H3A_PCR[1]</a> AF_ALAW_EN |
| AF mode configuration     | <a href="#">H3A_PCR[13:11]</a> RGBPOS<br><a href="#">H3A_PCR[14]</a> FVMODE   |

**Table 6-72. Camera ISP H3A AF Engine Required Configuration Parameters (continued)**

| Function                         | Configuration Required                                                                                                   |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| Paxel start and size information | <a href="#">H3A_AFPAX1</a><br><a href="#">H3A_AFPAX2</a><br><a href="#">H3A_AFPAXSTART</a><br><a href="#">H3A_AFIRSH</a> |
| Memory address                   | <a href="#">H3A_AFBUFST</a>                                                                                              |
| Filter coefficients              | <a href="#">H3A_AFCOEF010</a> to <a href="#">H3A_AFCOEF1010</a>                                                          |

The horizontal median filter function is optional.

If it is disabled, the [H3A\\_PCR\[10:3\]](#) MED\_TH does not need to be programmed.

However, if it is enabled, the [H3A\\_PCR\[10:3\]](#) MED\_TH parameter must be programmed so that the horizontal median filter function operates correctly.

[Table 6-73](#) can be read as:

If (**Condition** is TRUE) then

**Configuration required** parameters must be programmed

**Table 6-73. Camera ISP H3A AF Engine Conditional Configuration Parameters**

| Function                 | Condition                            | Configuration Required               |
|--------------------------|--------------------------------------|--------------------------------------|
| Horizontal median filter | <a href="#">H3A_PCR[2]</a> AF_MED_EN | <a href="#">H3A_PCR[10:3]</a> MED_TH |

#### 6.5.9.1.2.2 Camera ISP H3A AEW Engine

Before enabling the AEW engine, the hardware must be correctly configured through register writes.

[Table 6-74](#) identifies the register parameters that must be programmed before enabling the AEW engine of the H3A.

**Table 6-74. Camera ISP H3A AEW Engine Required Configuration Parameters**

| Function                          | Configuration Required                                                                                                        |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| AEW optional preprocessing        | <a href="#">H3A_PCR[17]</a> AEW_ALAW_EN                                                                                       |
| Saturation limit                  | <a href="#">H3A_PCR[31:22]</a> AVE2LMT                                                                                        |
| Window start and size information | <a href="#">H3A_AEWIN1</a><br><a href="#">H3A_AEWINSTART</a><br><a href="#">H3A_AEWINBLK</a><br><a href="#">H3A_AEWSUBWIN</a> |
| Memory address                    | <a href="#">H3A_AEWBUFST</a>                                                                                                  |

#### 6.5.9.2 Camera ISP H3A Enable/Disable Hardware

Setting the [H3A\\_PCR\[0\]](#) AF\_EN bit enables the AF engine, and the [H3A\\_PCR\[16\]](#) AEW\_EN bit enables the AEW engine. This should be done after all required registers are programmed.

The H3A always operates in continuous mode. Because the input to the H3A module is the video-port interface of the CCDC, processing of the frame depends on the timing signals from the CCDC. To ensure that data from the CCDC is not missed, the H3A should be enabled before the CCDC so that it waits for CCDC data.

The AF engine or the AEW engine can be disabled by clearing the [H3A\\_PCR\[0\]](#) AF\_EN or [H3A\\_PCR\[16\]](#) AEW\_EN bit, respectively, during the processing of the last frame. The disable is latched in at the end of the frame in which it is written.

### 6.5.9.3 Camera ISP H3A Event and Status Checking

Both the AF engine and the AEW engine generate an interrupt at the end of processing each frame. These interrupt events can be sent to CAM IRQ0 or CAM IRQ1 by setting the H3A\_AWB\_DONE\_IRQ or H3A\_AF\_DONE\_IRQ bits in the [ISP\\_IRQ0ENABLE](#) enable register (or [ISP\\_IRQ1ENABLE](#)).

The status of these interrupts can be checked by reading the [ISP\\_IRQ0STATUS](#) register (or [ISP\\_IRQ1STATUS](#)). When the read of the register [ISP\\_IRQ0STATUS](#) occurs (or [ISP\\_IRQ1STATUS](#)), the register is not automatically reset. To reset the interrupt, a 1 must be written to the corresponding bit.

Each event that generates an interrupt can be individually mapped to ARM or DSP using the [ISP\\_IRQ0ENABLE](#) register (or [ISP\\_IRQ1ENABLE](#)). When a particular event is not enabled (for example [ISP\\_IRQ0ENABLE\[x\] = 0](#)), the correspondent status ([ISP\\_IRQ0STATUS \[x\] = 1](#)) bit is flagged if the correspondent event occurs. This has no effect on the interrupt line, but can be used by software to poll the status.

### 6.5.9.4 Camera ISP H3A Register Accessibility During Frame Processing

There are two types of register access in the H3A module:

- Shadow registers: These registers/fields can be read and written (if the field is writable) at any time. However, the written values take effect only at the start of a frame. Reads return the most recent write, even though the settings are not used until the next start of frame.
- The shadowed registers are:
  - [H3A\\_PCR](#)
  - [H3A\\_AFBUFST](#)
  - [H3A\\_AEWBUFST](#)
- Busy-lock registers:
  - All registers EXCEPT the shadowed registers belong to this category.
  - Busy-lock registers cannot be written when the module is busy. Writes are allowed, but no change occurs in the registers (blocked writes from hardware perspective, but allowed writes from software perspective).
  - After the busy bit in the PCR register is reset to 0, the busy-lock registers can be written ([H3A\\_PCR \[15\] BUSYAF](#) for AF registers and [H3A\\_PCR \[18\] BUSYAEAWB](#) for AE/AWB registers).

The ideal procedure for changing the H3A registers is:

```
IF (H3A\_PCR \[15\] BUSYAF == 0 OR H3A\_PCR \[18\] BUSYAEAWB == 0) OR IF (EOF interrupt occurs)
  DISABLE AF or AE/AWB
  CHANGE REGISTERS AF or AE/AWB
  ENABLE AF or AE/AWB
```

### 6.5.9.5 Camera ISP H3A Interframe Operations

Between frames, it may be necessary to modify the memory pointers before processing the next frame. Since the [H3A\\_PCR](#) and memory pointer registers are shadowed, these modifications can occur any time before the end of the frame, and the data is latched in for the next frame. The MPU subsystem can perform these changes on receiving an interrupt.

### 6.5.9.6 Camera ISP H3A Summary of Constraints

The following is a list of register configuration constraints to adhere to when programming the H3A. It can be used as a quick checklist. More detailed register setting constraints can be found in the individual register descriptions.

- The output addresses must be on 64-byte boundaries.
- AF Engine:
  - The pixel horizontal start value must be greater than or equal to the IIR horizontal start position.

- The width and height of the paxels must be even numbers.
- The minimum width of the autofocus paxel must be 16 pixels.
- Paxels cannot overlap the last pixel in a line.
- Paxels must be adjacent to one another.

AEW Engine:

- The width and height of the windows must be even numbers.
- Subsampling windows can only start on even numbers.
- The minimum width of the AE/AWB windows is 6 pixels.

### **6.5.10 Programming the Histogram**

This section discusses issues related to software control of the histogram module. It lists which registers are required to be programmed in different modes, how to enable and disable the histogram, and how to check the status of the histogram; discusses the different register access types; and enumerates programming constraints.

#### **6.5.10.1 Camera ISP Histogram Setup/Initialization**

This section discusses the configuration of the histogram required before image processing can begin.

##### **6.5.10.1.1 Camera ISP Histogram Reset Behavior**

On hardware reset of the camera ISP, all registers in the histogram are reset to their reset values. However, since the histogram output memory is stored in internal memory, its contents do not have reset values. If the reset is a chip-level power-on reset (reset after power is applied), the contents of this memory are unknown. If the reset is a camera ISP module reset (when power remains active), the contents of this memory remain the same as before the reset.

##### **6.5.10.1.2 Camera ISP Histogram Reset of Histogram Output Memory**

Clear the output memory before enabling the histogram. This can be done two ways:

- Writing zeros to the memory through software
- If the [HIST\\_CNT \[7\]](#) CLR bit is set, reading the memory causes it to be reset after the read.

Reads and writes to the output memory are blocked when the [HIST\\_PCR \[1\]](#) BUSY bit is 1.

##### **6.5.10.1.3 Camera ISP Histogram Register Setup**

Before enabling the histogram module, the hardware must be correctly configured through register writes. [Table 6-75](#) identifies the register parameters that must be programmed before enabling the histogram.

**Table 6-75. Camera ISP Histogram Required Configuration Parameters**

| Function                           | Configuration Required                                                                                                                                                                    |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Histogram Control Bits             | <a href="#">HIST_CNT [3]</a> SOURCE<br><a href="#">HIST_CNT[6]</a> CFA<br><a href="#">HIST_CNT [5:4]</a> BINS<br><a href="#">HIST_CNT [2:0]</a> SHIFT<br><a href="#">HIST_CNT [7]</a> CLR |
| White Balance Gain                 | <a href="#">HIST_WB_GAIN</a>                                                                                                                                                              |
| Region n Size and position (n = 0) | <a href="#">HIST_Rn_HORZ</a><br><a href="#">HIST_Rn_VERT</a>                                                                                                                              |

**Table 6-76** can be read as:

If (**Condition** is TRUE) then

**Configuration required** parameters should be programmed

**Table 6-76. Camera ISP Histogram Conditional Configuration Parameters**

| Function           | Condition                 | Configuration Required                                                                       |
|--------------------|---------------------------|----------------------------------------------------------------------------------------------|
| Input from memory  | HIST_CNT [3] SOURCE = 0x1 | HIST_CNT [8] DATSIZ<br>HIST_RADD<br>HIST_RADD_OFF<br>HIST_H_V_INFO                           |
| Less than 256 bins | HIST_CNT [5:4] BINS 3     | HIST_Rn_HORZ (n = 1)<br>HIST_Rn_VERT (n = 1)                                                 |
| Less than 128 bins | HIST_CNT [5:4] BINS 2     | HIST_Rn_HORZ (n = 2)<br>HIST_Rn_VERT (n = 2)<br>HIST_Rn_HORZ (n = 3)<br>HIST_Rn_VERT (n = 3) |

#### 6.5.10.2 Camera ISP Histogram Enable/Disable Hardware

Setting the **HIST\_PCR** [0] ENABLE bit enables the histogram module. This must be done after all required registers are programmed and the output memory has been cleared.

When the input source is the memory, the histogram module always operates in one-shot mode. In other words, after enabling the histogram, the ENABLE bit is automatically turned off (set to 0) and only a single frame is processed from memory. In this mode, fetching and processing of the frame begin immediately on setting the ENABLE bit.

When the input source is the CCDC, the histogram always operates in continuous mode. Processing of the frame depends on the timing of the CCDC. To ensure that data from the CCDC is not missed, the histogram must be enabled before CCDC so it waits for CCDC data..

When the histogram is in continuous mode, it can be disabled by clearing the ENABLE bit during the processing of the last frame. The disable is latched in at the end of the frame in which it is written.

#### 6.5.10.3 Camera ISP Histogram Event and Status Checking

The histogram generates an interrupt at the end of each frame.

The status of this interrupt can be checked by reading the **ISP IRQ0STATUS** register (or **ISP IRQ1STATUS**). When the read of the register **ISP IRQ0STATUS** occurs (or **ISP IRQ1STATUS**), the register is not automatically reset. To reset the interrupt, a 1 must be written to the **HIST\_DONE\_IRQ** bit.

Each event that generates an interrupt can be individually mapped to ARM or DSP using the **ISP IRQ0ENABLE** register (or **ISP IRQ1ENABLE**). When a particular event is not enabled (for example **ISP IRQ0ENABLE[x] = 0**), the corresponding status (**ISP IRQ0STATUS [x] = 1**) bit is flagged if the corresponding event occurs. This has no effect on the interrupt line, but can be used by software to poll the status.

The **HIST\_PCR** [1] BUSY status bit is set when the start of frame occurs (if the **HIST\_PCR** [0] ENABLE bit is 1 at that time). It is automatically reset to 0 at the end of a frame. The **HIST\_PCR** [1] BUSY status bit may be polled to determine the end-of-frame status.

#### 6.5.10.4 Camera ISP Histogram Register Accessibility During Frame Processing

There are two types of register access in the histogram module.

- Shadow registers: These registers/fields can be read and written (if the field is writable) at any time. However, the written values take effect only at the start of a frame. Reads return the most recent write, even though the settings are not used until the next start of frame.

The shadowed registers are:

- [HIST\\_PCR](#)
- [HIST\\_RADD](#)
- [HIST\\_RADD\\_OFF](#)
- Busy-lock registers
  - All registers EXCEPT the shadowed registers belong to this category.
  - Busy-lock registers cannot be written when the module is busy. Writes are allowed, but no change occurs in the registers (blocked writes from hardware perspective; allowed write from software perspective).
  - After the [HIST\\_PCR](#) [1] BUSY bit is reset to 0, the busy-lock registers can be written.
  - The [HIST\\_DATA](#) register cannot be read when the histogram is busy, because since this register is mapped to memories internally. Such reads return indeterminate data. Byte enables are not implemented for reading the histogram memory.

The ideal procedure for changing the histogram registers is:

```
IF (HIST\_PCR [1] BUSY == 0) OR IF (EOF interrupt occurs)
    DISABLE HISTOGRAM
    CHANGE REGISTERS
    ENABLE HISTOGRAM
```

#### 6.5.10.5 Camera ISP Histogram Interframe Operations

Between frames read from memory, it may be necessary to modify the input memory pointers before processing the next frame. Since the [H3A\\_PCR](#) and memory pointer registers are shadowed, these modifications can take place any time before the end of the frame, and the data is latched in for the next frame. The MPU Subsystem can perform these changes on receiving an interrupt.

If continuous frames are processed without clearing the histogram output memory, the bin counters contain the counts of however many images are processed since they were last cleared. To read the bin counters for each frame, the bin counters must be read after each frame is completed, but before the next frame begins (since the counters cannot be read while the [HIST\\_PCR](#) [1] BUSY bit is 1).

If the input source is memory (one-shot mode), the [HIST\\_PCR](#) [0] ENABLE bit must be set once for the frame, and after the frame is completed, the bin counters can be read/cleared before enabling the next frame.

When the input source is the video-port interface of the CCDC (continuous mode), the [HIST\\_PCR](#) [0] ENABLE bit must be set to enable processing of the frame, and cleared after the frame processing begins (the disable is latched in at the end of the frame). This procedure allows only one frame to be processed. After the frame is completed, the bin counters can be read/cleared before enabling the histogram for the next frame.

#### 6.5.10.6 Camera ISP Histogram Summary of Constraints

The following is a list of register configuration constraints to adhere to when programming the histogram. It can be used as a quick checklist. More detailed register setting constraints can be found in the individual register descriptions.

- The input address and line offset must be on 32-byte boundaries.
- A region dimension of 1 (horizontal or vertical or both) is not allowed.

#### 6.5.11 Programming the Central-Resource SBL

This section discusses issues related to the software control of the central-resource SBL. It lists which registers are required to be programmed in different modes, describes how to check the status of the central resource SBL overflow bits, and enumerates programming constraints.

The central-resource SBL controls data interactions between the camera ISP modules and the interface to memory. A small number of registers configure maximum data-read bandwidth in memory-to-memory operations.

### 6.5.11.1 Camera ISP Central-Resource SBL Setup/Initialization

This section discusses the configuration of the central-resource SBL required before image processing can begin.

#### 6.5.11.1.1 Camera ISP Central-Resource SBLReset Behavior

On hardware reset of the camera ISP, all registers in the SBL are reset to their reset values.

#### 6.5.11.1.2 Camera ISP Central-Resource SBLRegister Setup

Before enabling any of the camera ISP modules, the hardware must be correctly configured through register writes to the camera ISP registers. If the preview engine, resizer, or the histogram is reading from memory, the [SBL\\_SDR\\_REQ\\_EXP](#) register must be programmed. The values programmed in each of the three fields (PRV\_EXP, RSZ\_EXP, HIST\_EXP) determines the number of clock cycles required to allow two consecutive read requests from the module.

### 6.5.11.2 Camera ISP Central-Resource SBL Enable/Disable Hardware

The central-resource SBL functionality is always enabled, unless the PRCM idles the clocks to the camera ISP.

#### 6.5.11.3 Camera ISP Central-Resource SBL Event and Status Checking

The SBL generates one interrupt for the write buffer overflow events listed below. Software must check which overflow event has raised the interrupt request, by reading the [SBL\\_PCR](#) register.

See [Table 6-77](#).

**Table 6-77. Camera ISP Central-Resource SBL Write-Buffer Overflow Events**

| Bit                                                   | Event Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <a href="#">SBL_PCR</a> [26] CSI1_CCP2B_CSI2C_WBL_OVF | CSI1/ CCP2B or CSI2C write-buffer memory overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <a href="#">SBL_PCR</a> [25] CSI2A_WBL_OVF            | CSI2A write-buffer memory overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <a href="#">SBL_PCR</a> [24] CCDCPRV_2_RSZ_OVF        | CCDC/PREVIEW to RESIZER input overflow<br>This bit is set if the RESIZER input source is sent to CCDC/PREVIEW engine when the active data (to be resized) has already showed up at the resizer interface. In such a case, resizing for this frame cannot take place and the bit is set. This scenario can happen when a resize of 4x is required per frame. Therefore, the RESIZER must operate in two passes. In the first pass, the input data from CCDC/PREVIEW is directly resized and written to memory. In the second pass, the resized data from the first pass is resized again. The next frame from the CCDC/PREVIEW engine should start only after the second pass on the previous frame is complete. This bit indicates the failure status. |
| <a href="#">SBL_PCR</a> [23] CCDC_WBL_OVF             | CCDC write-buffer memory overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <a href="#">SBL_PCR</a> [22] PRV_WBL_OVF              | PREFVIEW write-buffer memory overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <a href="#">SBL_PCR</a> [21] RSZ1_WBL_OVF             | RESIZER line 1 write-buffer memory overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <a href="#">SBL_PCR</a> [20] RSZ2_WBL_OVF             | RESIZER line 2 write-buffer memory overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <a href="#">SBL_PCR</a> [19] RSZ3_WBL_OVF             | RESIZER line 3 write-buffer memory overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <a href="#">SBL_PCR</a> [18] RSZ4_WBL_OVF             | RESIZER line 4 write-buffer memory overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <a href="#">SBL_PCR</a> [17] H3A_AF_WBL_OVF           | H3A AF write-buffer memory overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <a href="#">SBL_PCR</a> [16] H3A_AEAWB_WBL_OVF        | H3A AE/AWB write-buffer memory overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

The status of this interrupt can be checked by reading the [ISP IRQ0STATUS](#) register (or [ISP IRQ1STATUS](#)). When the read of the register [ISP IRQ0STATUS](#) occurs (or [ISP IRQ1STATUS](#)), the register is not automatically reset. To reset the interrupt, a 1 must be written:

- To the corresponding bit(s) in the [SBL PCR](#) registers
- To the OVF\_IRQ bit in the [ISP IRQ0STATUS](#) register (or [ISP IRQ1STATUS](#))

Each event that generates an interrupt can be individually mapped to ARM or DSP using the [ISP IRQ0ENABLE](#) register (or [ISP IRQ1ENABLE](#)). When a particular event is not enabled (for example [ISP IRQ0ENABLE\[x\] = 0](#)), the correspondent status ([ISP IRQ0STATUS \[x\] = 1](#)) bit is flagged if the correspondent event occurs. This has no effect on the interrupt line, but can be used by software to poll the status.

The SBL flags no read buffer logic underflow events. These are signaled by the reading module. [Table 6-78](#) lists the read port and corresponding events if they exist.

**Table 6-78. Camera ISP Central-Resource SBL Read-Buffer Underflow Events**

| Read port                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CCDC faulty pixel              | When faulty-pixel correction is used, the pixel frequency is imposed by the camera clock. This imposes read-time constraints to the faulty-pixel table read. When the table read was too slow, the <a href="#">CCDC_FPC</a> [16] FPERR bit is set to 1 and no more faulty pixels are processed for that frame. This error generates an interrupt that can be mapped to DSP or ARM by setting the CCDC_ERR_IRQ bit in the <a href="#">ISP IRQ0ENABLE</a> register (or <a href="#">ISP IRQ1ENABLE</a> ). To clear this interrupt, clear the <a href="#">CCDC_FPC</a> [16] FPERR bit before clearing the <a href="#">ISP IRQ0STATUS</a> [11] CCDC_ERR_IRQ bit (or <a href="#">ISP IRQ1STATUS</a> ). |
| CCDC lens-shading compensation | There must be adequate memory bandwidth if this feature is enabled. If the data fetched from memory arrives late, then the <a href="#">CCDC_LSC_PREFETCH_ERROR</a> event is triggered and an interrupt generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Preview dark frame             | There must be adequate memory bandwidth if this feature is enabled. If the data fetched from memory arrives late, the <a href="#">PRV_PCR</a> [31] DRK_FAIL status bit is set to indicate a fail. No interrupt is generated by this event.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Preview image from memory      | No error can occur on this port because the preview module stops processing when no image data is ready.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Resizer image from memory      | No error can occur on this port because the resizer module stops processing when no image data is ready.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Histogram image from memory    | No error can occur on this port because the histogram module stops processing when no image data is ready.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| CSI1/CCP2B image from memory   | No error can occur on this port because the CSI1/CCP2B module stops processing when no image data is ready.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### 6.5.11.4 Camera ISP Central-Resource SBL Register Accessibility During Frame Processing

The central resource SBL registers are all busy-writable registers.

- Busy-writable registers
  - These registers/fields can be read or written even if the module is busy. Changes to the underlying settings occur instantaneously.

#### 6.5.11.5 Camera ISP Central-Resource SBL Camera ISP Bandwidth Adjustments

For memory-to-memory operation, the camera ISP processes data at the highest possible data rate. If this processing returns results long before real-time deadlines, the performance of other peripherals in the system may be negatively affected. The camera ISP offers two kinds of adjustments that can slow down data processing in this situation. One can be made when the sensor input to the CCDC is the input source, and the other can be made when the memory is the source of the input image.

### 6.5.11.5.1 Camera ISP Central-Resource SBL Input From CCDC Video-Port Interface

The video-port interface delivers data at a rate independent of the pixel clock when the data reformatter is enabled. By default, this rate is set to 100 MHz, which is fast enough to support a parallel interface clock of 90 MHz or a CSI/CCP2B /CSI2 clock of 100 MHz. When the pixel clock is at a lower frequency, it is unnecessary for the video-port interface to operate at such a high frequency. The [CCDC\\_FMTCFG \[21:16\]](#) VPIF\_FRQ field of the CCDC can be programmed to reduce the rate at which the video port delivers new data to the other modules (Preview, H3A, and histogram). In effect, this register indirectly controls the output bandwidth of the preview engine, resizer, and H3A. Depending on the input sensor clock, Users can set this field appropriately and balance the bandwidth requirements to memory. [Figure 6-120](#) demonstrates how this register can expand processing time per line for lower PCLK frequencies.

**Figure 6-120. Camera ISP Central-Resource SBL Video-Port Interface Bandwidth Balancing**



camisp-091

### 6.5.11.5.2 Camera ISP Central-Resource SBL Input From Memory

When the input image is from memory, data is fetched from memory and processed at a steady state rate of 200 MB/sec. Depending on the image size and real-time deadline for each frame, this may be much faster than necessary. Such activity can also starve other processes in the system. Internally, when a CAMERA ISP module receives input from memory, the CAMERA ISP makes a read request to the L3 interconnect whenever there is available memory in its internal buffers.

The [SBL\\_SDR\\_REQ\\_EXP](#) register can be programmed to control the rate at which a camera ISP module (Preview, resizer, or histogram) reads the input frame from memory. This indirectly controls the output bandwidth of the preview engine and resizer. Depending on the size of the images and the real-time deadlines, users can set this field appropriately and balance the bandwidth requirements to memory.

The minimum number of cycles (L3) in between read requests used to program the [SBL\\_SDR\\_REQ\\_EXP](#) register can be determined based on the frame size and real-time requirement using the following equation:

$$\text{Number of cycles/request} = (\text{DMA cycles/frame}) / (\text{DMA read requests/frame})$$

In the previous equation, (DMA cycles/frame) is based on a real-time requirement. For example, if the real-time requirement is a frame rate of 1/30 sec and the L3 clock equals the ISP clock, this can be calculated as:

$$(\text{DMA cycles/frame}) = \text{L3 clock} * \text{frame rate} = \text{ISP clock} * 1/30 = 5.53\text{M cycles}$$

The (DMA read requests/frame) is based on the frame size and the alignment in memory. Assuming a VGA (640 x 480) frame size and optimal alignment conditions:

$$(\text{DMA read requests/frame}) = \text{Transfers per line} * \text{number of lines} = 640 \text{ pix/line} * 2 \text{ bytes/pix} / 256 \text{ bytes/xfer} * 480 \text{ lines} = 2400 \text{ requests/frame}$$

In this example, the final equation can now be solved:

$$\text{Number of cycles/request} = 5.53\text{M cycles}/2400 \text{ requests} = 2306 \text{ cycles/request}$$

[Figure 6-121](#) demonstrates how this register can expand processing time for lower real-time requirements.

**Figure 6-121. Camera ISP Central-Resource SBL Memory Read Bandwidth Balancing**

The maximum values that can be written to the [SBL\\_SDR\\_REQ\\_EXP](#) register for the different read requesters is 1023. For the histogram and preview engine, this should be sufficient for the typical size of RAW data frames. However, because the resizer can read a variety of video frame sizes, the field for the resizer is internally multiplied by 32. Therefore, for this example, the [SBL\\_SDR\\_REQ\\_EXP\[19:10\]](#) RSZ\_EXP bit field can be programmed to FLOOR(2306/32) = 72.

The previous equations provide an estimate or a starting point for programming this register. Depending on the system loads and available bandwidth, it may be necessary to reduce this number to compensate for a heavily loaded system.

**NOTE:** The granularity for the resizer, HIST, and preview is 32.

## 6.5.12 Programming the Circular Buffer

### 6.5.12.1 Camera ISP CBUFF Setup/Initialization

This section discusses the configuration of the circular buffer required before address translation can begin.

### 6.5.12.2 Camera ISP CBUFF Reset Behavior

Upon hardware reset of the circular buffer, all of the registers in the circular buffer are reset to their reset values.

### 6.5.12.3 Camera ISP CBUFF Register Setup

All registers of the circular buffer to be used (CBUFFx, x=0 or 1) have to be initialized for correct operation.

The [CBUFFx\\_START](#) and [CBUFFx\\_END](#) register define the virtual address range managed by the circular buffer. It usually corresponds to the address region where one image frame is written by the camera ISP.

The window count and size are set through the [CBUFFx\\_CTRL \[9:8\]](#) WCOUNT and [CBUFFx\\_WINDOWSIZE](#) registers. The window size usually depends on the utilization of the buffer. 8 or 16 video lines correspond to a current size for JPEG video compression. A higher window count provides better latency related overflow protection.

When the camera ISP accesses data in an incremental addressing scheme, the next window is never used. In this case the overflow event generation, when the processor window falls into the "next window", can be disabled by setting the [CBUFFx\\_CTRL \[3\]](#) ALLOW\_NW\_EQ\_CPUW flag.

When the 2D addressing capability is not used the **CBUFFx\_THRESHOLD** register is set to the window size. Otherwise it is set to a smaller value depending on the buffer organization. For example, when each window corresponds to 8 lines by 4096 pixel but the camera ISP only send lines of 2560 pixels the **CBUFFx\_WINDOWSIZE**=8\*4096 and **CBUFFx\_THRESHOLD**=8\*2560.

When the register setup is completed the module is enabled using the **CBUFFx\_CTRL** [0] EN bit.

It can be disabled by clearing the **CBUFFx\_CTRL** [0] EN bit. This must only be done when there are no more outstanding requests to the virtual space managed by CBUFFx. All internal FSMs and counters of the circular buffer are reset when it is disabled. Pending interrupts are not affected.

#### 6.5.12.4 Camera ISP CBUFF Event and status Checking

##### 6.5.12.4.1 Camera ISP CBUFF Interrupts

All events generated by the circular buffer are mapped to an unique event at camera ISP level: CBUFF\_IRQ,

The CBUFF module event can be mapped to the MPU SS or to the IVA SS.

The CBUFF\_IRQ bit in the **ISP IRQ0ENABLE** [21] CBUFF\_IRQ register control whether the CBUFF module event triggers an interrupt to the MPU SS. The CBUFF\_IRQ bit in the **ISP IRQ0ENABLE** [21] CBUFF\_IRQ register control whether the CBUFF module event triggers an interrupt to the IVA2.2 SS.

When an event has been triggered the **ISP IRQ0STATUS** [21] CBUFF\_IRQ bit is set (or **ISP IRQ1STATUS**). SW must than read the **CBUFF IRQSTATUS** register to know which circular buffer event has triggered the interrupt. SW must clear the event first in the circular buffer module by writing 1 to the proper bit in **CBUFF IRQSTATUS** register and then clear the event at camera ISP level by writing 1 to the **ISP IRQ0STATUS** [21] CBUFF\_IRQ bit (or **ISP IRQ1STATUS**). If another event is pending at circular buffer level, the CBUFF\_IRQ interrupt is triggered again.

##### 6.5.12.4.2 Camera ISP CBUFF Status Checking

The event status can be checked through the CBUFFx\_READY\_IRQ, CBUFFx\_INVALID\_IRQ, and CBUFFx\_OVR\_IRQ bits in the **CBUFF IRQSTATUS** registers.

In addition to those status bits the circular buffer module provides read only access to the "current window", "next window" and "CPU windows" indexes through the **CBUFFx\_STATUS** register. The "CPU window" index can for example be used by the processor to compute the address of the physical buffer. Those indexes can also be used to evaluate latency margins.

#### 6.5.12.5 Camera ISP CBUFF Register Accessibility During Frame Processing

All registers are Busy-writeable registers. These registers/fields can be read or written even if the module is busy. Changes to the underlying settings takes place instantaneously. However the module behavior is unpredictable when registers are changed during processing.

For correct operation software must follow the following steps:

- Disable all accesses to the virtual space managed by CBUFFx. For example when the circular buffer relocates data provided by the CCDC module SW must disable the CCDC module and check SBL status registers to make sure there are no more outstanding transactions.
- Disable circular buffer x by clearing the **CBUFFx\_CTRL** [0] ENABLE bit.
- Change the configuration.
- Re-enable CBUFFx by setting the **CBUFFx\_CTRL** [0] ENABLE bit.

#### 6.5.12.6 Camera ISP CBUFF Operations

A CBUFFx\_READY\_IRQ event is generated each time processor can read data from the circular buffer. Processor can clear the event when it starts processing the data to avoid masking of other events. Processor can keep trace of the location on the data internally or use the circular buffer registers to compute it.

The formula used for CBUFF1 is:

$$\text{ADDR} = \text{CBUFFx\_STATUS}[3:0] \text{ CPUW} \times \text{CBUFFx\_WINDOWSIZE} + \text{CBUFFx\_START} \quad (5)$$

Because of the functionality of the fragment, the formula used for CBUFF0 is:

$$\text{ADDR} = \text{CBUFFx\_ADDRy}[\text{CBUFFx\_STATUS}[3:0] \text{ CPUW}] \quad (6)$$

When processor is done with processing, it must free the buffer by setting the **CBUFFx\_CTRL[2]** DONE bit. Otherwise an overflow event may occur.

The circular buffer does not keep trace of end of frame events. They must be managed by the processor using the end of frame event of the module that writes into the circular buffer. At the end of the frame there may remain data in the "current write" and "next write" windows. For example, when the window size is set to 8 lines and the image size is 20 lines only 2 window ready events are generated for a linear addressing scheme. The remaining 4 lines can be read after the end of frame event.

No automatic reset of the CBUFF FSM occurs at the end of the camera ISP frame. Software must reset the CBUFF by clearing the **CBUFFx\_CTRL[0]** ENABLE bit when the frame has been completely processed. A new frame can only start when **CBUFFx\_CTRL [0]** ENABLE has been set.

### 6.5.13 Programming the Camera ISP Software Reset

The flow chart in [Figure 6-122](#) describes the steps to perform a software reset.

**Figure 6-122. Camera ISP Software Reset Sequence**



camisp-404

[Table 6-79](#) lists the registers to configure for the camera subsystem software reset step.

**Table 6-79. Camera ISP Software Register Settings**

| Register Name | Address     | Value Description                                                                                    |
|---------------|-------------|------------------------------------------------------------------------------------------------------|
| ISP_SYSCONFIG | 0x480B C004 | Initiate a software reset. The <b>ISP_SYSCONFIG[1]</b> SOFTRESET is automatically reset by hardware. |
| ISP_SYSSTATUS | 0x480B C008 | The <b>ISP_SYSSTATUS[0]</b> RESETDONE is set to 1 when the reset sequence is done.                   |

## 6.6 Camera ISP Register Manual

### 6.6.1 Camera ISP Instance Summary

**Table 6-80. Camera ISP Instance Summary**

| Module Name      | L3 Base Address | Size     |
|------------------|-----------------|----------|
| ISP_TOP          | 0x480B C000     | 256Bytes |
| ISP_CBUFF        | 0x480B C100     | 256Bytes |
| ISP_CCP2B        | 0x480B C400     | 512Bytes |
| ISP_CCDC         | 0x480B C600     | 512Bytes |
| ISP_HIST         | 0x480B CA00     | 512Bytes |
| ISP_H3A          | 0x480B CC00     | 512Bytes |
| ISP_PREVIEW      | 0x480B CE00     | 512Bytes |
| ISP_RESIZER      | 0x480B D000     | 512Bytes |
| ISP_SBL          | 0x480B D200     | 512Bytes |
| ISP_CSIIA_REGS1  | 0x480B D800     | 368Bytes |
| ISP_CSIPHY2      | 0x480B D970     | 32Bytes  |
| ISP_CSIIA_REGS2  | 0x480B D9C0     | 64Bytes  |
| ISP_CSIC2C_REGS1 | 0x480B DC00     | 368Bytes |
| ISP_CSIPHY1      | 0x480B DD70     | 32Bytes  |
| ISP_CSIC2C_REGS2 | 0x480B DDC0     | 64Bytes  |

---

**NOTE:** The camera ISP instance CAMERA\_ISP\_MMU with L3 base address 0x480B D400 and size 256 bytes is within the camera ISP memory space. For a detailed description of the MMU and register description, see [Chapter 15, Memory Management Units](#).

---

#### 6.6.1.1 Camera ISP Registers Summary

**Table 6-81. ISP Register Mapping Summary**

| Register Name       | Type | Register Width (Bits) | Address Offset | ISP L3 Base Address |
|---------------------|------|-----------------------|----------------|---------------------|
| ISP_REVISION        | R    | 32                    | 0x0000 0000    | 0x480B C000         |
| ISP_SYSCONFIG       | RW   | 32                    | 0x0000 0004    | 0x480B C004         |
| ISP_SYSSTATUS       | R    | 32                    | 0x0000 0008    | 0x480B C008         |
| ISP_IRQ0ENABLE      | RW   | 32                    | 0x0000 000C    | 0x480B C00C         |
| ISP_IRQ0STATUS      | RW   | 32                    | 0x0000 0010    | 0x480B C010         |
| ISP_IRQ1ENABLE      | RW   | 32                    | 0x0000 0014    | 0x480B C014         |
| ISP_IRQ1STATUS      | RW   | 32                    | 0x0000 0018    | 0x480B C018         |
| TCTRL_GRESET_LENGTH | RW   | 32                    | 0x0000 0030    | 0x480B C030         |
| TCTRL_PSTRB_REPLY   | RW   | 32                    | 0x0000 0034    | 0x480B C034         |
| ISP_CTRL            | RW   | 32                    | 0x0000 0040    | 0x480B C040         |
| RESERVED            | RW   | 32                    | 0x0000 0044    | 0x480B C044         |
| TCTRL_CTRL          | RW   | 32                    | 0x0000 0050    | 0x480B C050         |
| TCTRL_FRAME         | RW   | 32                    | 0x0000 0054    | 0x480B C054         |
| TCTRL_PSTRB_DELAY   | RW   | 32                    | 0x0000 0058    | 0x480B C058         |
| TCTRL_STRB_DELAY    | RW   | 32                    | 0x0000 005C    | 0x480B C05C         |
| TCTRL_SHUT_DELAY    | RW   | 32                    | 0x0000 0060    | 0x480B C060         |
| TCTRL_PSTRB_LENGTH  | RW   | 32                    | 0x0000 0064    | 0x480B C064         |
| TCTRL_STRB_LENGTH   | RW   | 32                    | 0x0000 0068    | 0x480B C068         |

**Table 6-81. ISP Register Mapping Summary (continued)**

| Register Name     | Type | Register Width (Bits) | Address Offset | ISP L3 Base Address |
|-------------------|------|-----------------------|----------------|---------------------|
| TCTRL_SHUT_LENGTH | RW   | 32                    | 0x0000 006C    | 0x480B C06C         |

### 6.6.1.2 Camera ISP Register Description

**Table 6-82. ISP\_REVISION**

|                       |                                                                                                                                                               |                         |                                |                 |     |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------------------|-----------------|-----|
| <b>Address Offset</b> | 0x0000 0000                                                                                                                                                   | <b>Physical Address</b> | See <a href="#">Table 6-81</a> | <b>Instance</b> | ISP |
| <b>Description</b>    | Camera ISP Revision register<br>This register contains the IP revision code in binary coded digital. For example, 0x01 = revision 0.1 and 0x21 = revision 2.1 |                         |                                |                 |     |
| <b>Type</b>           | R                                                                                                                                                             |                         |                                |                 |     |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         |                       | REV             |

| Bits | Field Name | Description                                                  | Type | Reset            |
|------|------------|--------------------------------------------------------------|------|------------------|
| 31:8 | RESERVED   | Write 0s for future compatibility. Read returns 0.           | R    | 0x000000         |
| 7:0  | REV        | IP revision.<br>[7:4] major revision<br>[3:0] minor revision | R    | TI internal data |

**Table 6-83. Register Call Summary for Register ISP\_REVISION**

- Camera ISP Register Manual
- [Camera ISP Registers Summary: \[0\]](#)

**Table 6-84. ISP\_SYSCONFIG**

|                       |                                   |                         |                                |                 |     |
|-----------------------|-----------------------------------|-------------------------|--------------------------------|-----------------|-----|
| <b>Address Offset</b> | 0x0000 0004                       | <b>Physical Address</b> | See <a href="#">Table 6-81</a> | <b>Instance</b> | ISP |
| <b>Description</b>    | ISP system configuration register |                         |                                |                 |     |
| <b>Type</b>           | RW                                |                         |                                |                 |     |

|                         |                         |                       |                 |  |  |            |           |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|------------|-----------|
| 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 |  |  |            |           |
| RESERVED                |                         | MIDDLE_MODE           | RESERVED        |  |  | SOFT_RESET | AUTO_IDLE |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R    | 0x00000 |
| 13:12 | MIDLE_MODE | Master interface power management, MSTANDBY / WAIT protocol.<br><br>0x0: Force-standby: the MSTANDBY signal is only asserted to the power and reset clock manager when the module is disabled.<br><br>0x1: No-standby: the MSTANDBY signal is never asserted to the power and reset clock manager.<br><br>0x2: Smart-standby: the MSTANDBY signal is asserted to the power and reset clock manager based on the internal activity of the module. The ISP clocks are not disabled during smart standby. | RW   | 0x0     |
| 11:2  | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R    | 0x000   |
| 1     | SOFT_RESET | Software reset. Set the bit to 1 to trigger the module reset. The bit is automatically reset by the hw. During reads return 0.<br><br>0x0: Normal mode.<br><br>0x1: The module is reset.                                                                                                                                                                                                                                                                                                               | RW   | 0       |
| 0     | AUTO_IDLE  | Internal Interconnect functional clock gating strategy<br><br>0x0: Interconnect functional clocks are free-running<br><br>0x1: Automatic clock gating strategy is applied, based on the Interconnect interface activity for interface clock and on the functional activity for functional Clocks.                                                                                                                                                                                                      | RW   | 1       |

**Table 6-85. Register Call Summary for Register ISP\_SYSCONFIG**

## Camera ISP Integration

- Camera ISP Local Power Management: [0]
- Camera ISP System Power Management: [1]
- Camera ISP Software Reset: [2]

## Camera ISP Basic Programming Model

- [Programming the Camera ISP Software Reset: \[3\] \[4\]](#)

## Camera ISP Register Manual

- [Camera ISP Registers Summary: \[5\]](#)

**Table 6-86. ISP\_SYSSTATUS**

|                  |                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------|--------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Address Offset   | 0x0000 0008                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Physical Address | See <a href="#">Table 6-81</a> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Description      | ISP system status register     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type             | R                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED         |                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RESET_DONE |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                    | Type | Reset       |
|------|------------|----------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                             | R    | 0x0000 0000 |
| 0    | RESET_DONE | Internal reset monitoring<br><br>Read 0x0: Internal module reset is ongoing.<br><br>Read 0x1: Reset completed. | R    | 1           |

**Table 6-87. Register Call Summary for Register ISP\_SYSSTATUS**

Camera ISP Basic Programming Model

- [Programming the Camera ISP Software Reset: \[0\] \[1\]](#)

Camera ISP Register Manual

- [Camera ISP Registers Summary: \[2\]](#)

**Table 6-88. ISP\_IRQ0ENABLE**

|                         |                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----|
| <b>Address Offset</b>   | 0x0000 000C                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |
| <b>Physical Address</b> | See <a href="#">Table 6-81</a>                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | ISP |
| <b>Description</b>      | INTERRUPT ENABLE REGISTER TO MCU. IRQ0 STATUS LINE.<br>The same events are mapped in IRQ1. However, one event shall be mapped to only one target. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |
| <b>Type</b>             | RW                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0   |

| 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 |
|-----------|----------|-------------|-------------|----------|---------|--------------|----------|----------|-----------|--------------|-------------------------|-----------------------------|---------------|---------------|----------|----------|------------------|-----------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|----------|-----------|-----------|---|
| HS_VS_IRQ | RESERVED | OCP_ERR_IRQ | MMU_ERR_IRQ | RESERVED | OVF_IRQ | RSZ_DONE_IRQ | RESERVED | RESERVED | CBUFF_IRQ | PRV_DONE_IRQ | CCDC_LSC_PREFETCH_ERROR | CCDC_LSC_PREFETCH_COMPLETED | CCDC_LSC_DONE | HIST_DONE_IRQ | RESERVED | RESERVED | H3A_AWB_DONE_IRQ | H3A_AF_DONE_IRQ | CCDC_ERR_IRQ | CCDC_VD2_IRQ | CCDC_VD1_IRQ | CCDC_VD0_IRQ | CSIB_LC3_IRQ | CSIB_LC2_IRQ | CSIB_LC1_IRQ | CSIB_LC0_IRQ | CSIB_LCM_IRQ | RESERVED | CSI2C_IRQ | CSI2A_IRQ |   |

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                        | Type | Reset |
|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | HS_VS_IRQ   | HS or VS synchro event<br>This event is triggered if a rising or falling edge is detected on the HS or VS signal. The rising or falling edge and the HS or VS signal selection is chosen with the <a href="#">ISP_CTRL.SYNC_DETECT</a> bit field.<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs. | RW   | 0     |
| 30    | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                 | RW   | 0     |
| 29    | OCP_ERR_IRQ | ISP interconnect error.<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                                                                           | RW   | 0     |
| 28    | MMU_ERR_IRQ | MMU error.<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                                                                                        | RW   | 0     |
| 27:26 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                 | R    | 0x0   |
| 25    | OVF_IRQ     | Central Resource SBL overflow<br>This event is triggered when one of the buffer in the central resource SBL overflows.<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                            | RW   | 0     |

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name                      | Description                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|-------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 24    | RSZ_DONE_IRQ                    | RESIZER module - resizer processing done event.<br>This event is triggered at the end of the frame when the processing is completed for the current frame.<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                          | RW   | 0     |
| 23:22 | RESERVED                        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                   | R    | 0x0   |
| 21    | CBUFF_IRQ                       | Circular buffer interrupt<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 20    | PRV_DONE_IRQ                    | PREVIEW module - processing done event.<br>This event is triggered at the end of the frame when the processing is completed for the current frame.<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                  | RW   | 0     |
| 19    | CCDC_LSC_PREFETCH_ERRO<br>R     | The prefetch error indicates when the gain table was read to slowly from SDRAM. When this event is pending the module goes into transparent mode (output=input).<br>Normal operation can be resumed at the start of the next frame after<br>1) clearing this event<br>2) disabling the LSC module<br>3) enabling it<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs. | RW   | 0     |
| 18    | CCDC_LSC_PREFETCH_COMP<br>LETED | Indicates current state of the prefetch buffer. Could be used to start sending the data once the buffer is full to minimize the risk of an underflow. This event is triggered when the buffer contains 3 full pixel rows. It could be used to minimize buffer underflow risks.<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                      | RW   | 0     |
| 17    | CCDC_LSC_DONE                   | The event is triggered when the internal state of LSC toggles from BUSY to IDLE.<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                                                                                    | RW   | 0     |
| 16    | HIST_DONE_IRQ                   | HIST module - processing done event.<br>This event is triggered at the end of the frame when the processing is completed for the current frame.<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                     | RW   | 0     |
| 15    | RESERVED                        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                   | R    | 0     |
| 14    | RESERVED                        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                   | RW   | 0     |
| 13    | H3A_AWB_DONE_IRQ                | H3A module - auto exposure and auto white balance processing done event.<br>This event is triggered at the end of the frame when the processing is completed for the current frame.<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                 | RW   | 0     |
| 12    | H3A_AF_DONE_IRQ                 | H3A module - autofocus processing done event.<br>This event is triggered at the end of the frame when the processing is completed for the current frame.<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                            | RW   | 0     |
| 11    | CCDC_ERR_IRQ                    | CCDC module - faulty pixel correction memory underflow<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                                                                                                              | RW   | 0     |

| Bits | Field Name   | Description                                                                                                                                   | Type | Reset |
|------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 10   | CCDC_VD2_IRQ | CCDC module - programmable event 2<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                       | RW   | 0     |
| 9    | CCDC_VD1_IRQ | CCDC module - programmable event 1.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                      | RW   | 0     |
| 8    | CCDC_VD0_IRQ | CCDC module - programmable event 0.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                      | RW   | 0     |
| 7    | CSIB_LC3_IRQ | CSI1/CCP2B receiver module - event on logical channel 3.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs. | RW   | 0     |
| 6    | CSIB_LC2_IRQ | CSI1/CCP2B receiver module - event on logical channel 2.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs. | RW   | 0     |
| 5    | CSIB_LC1_IRQ | CSI1/CCP2B receiver module - event on logical channel 1.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs. | RW   | 0     |
| 4    | CSIB_LC0_IRQ | CSI1/CCP2B receiver module - event on logical channel 0.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs. | RW   | 0     |
| 3    | CSIB_LCM_IRQ | CSI1/CCP2B receiver module - event on memory channel.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.    | RW   | 0     |
| 2    | RESERVED     | Write Os for future compatibility. Read returns 0.                                                                                            | RW   | 0     |
| 1    | CSI2C_IRQ    | CSI2C module event.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                                      | RW   | 0     |
| 0    | CSI2A_IRQ    | CSI2A module event.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                                      | RW   | 0     |

**Table 6-89. Register Call Summary for Register ISP IRQ0ENABLE**
**Camera ISP Integration**

- [Camera ISP Interrupt Requests](#): [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22]

**Camera ISP Functional Description**

- [Camera ISP Circular Buffer Interrupts](#): [23]

**Camera ISP Basic Programming Model**

- [Camera ISP CCDC Interrupts](#): [24]
- [Camera ISP Preview Events and Status Checking](#): [25] [26]
- [Camera ISP Resizer Events and Status Checking](#): [27] [28]
- [Camera ISP Resizer Multiple Passes for Large Resizing Operations](#): [29]
- [Camera ISP H3A Event and Status Checking](#): [30] [31] [32]
- [Camera ISP Histogram Event and Status Checking](#): [33] [34]
- [Camera ISP Central-Resource SBL Event and Status Checking](#): [35] [36] [37]
- [Camera ISP CBUFF Interrupts](#): [38] [39]

**Table 6-89. Register Call Summary for Register ISP\_IRQ0ENABLE (continued)**

Camera ISP Register Manual

- Camera ISP Registers Summary: [40]
- Camera ISP Register Description: [41] [42]

**Table 6-90. ISP\_IRQ0STATUS**

|                       |                                                     |                         |                |                 |     |
|-----------------------|-----------------------------------------------------|-------------------------|----------------|-----------------|-----|
| <b>Address Offset</b> | 0x0000 0010                                         | <b>Physical Address</b> | See Table 6-81 | <b>Instance</b> | ISP |
| <b>Description</b>    | INTERRUPT STATUS REGISTER TO MCU. IRQ0 STATUS LINE. |                         |                |                 |     |
| <b>Type</b>           | RW                                                  |                         |                |                 |     |

| 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 |
|-----------|----------|-------------|-------------|----------|---------|--------------|----------|-----------|--------------|-------------------------|-----------------------------|---------------|---------------|----------|------------------|-----------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|----------|-----------|-----------|---|---|---|
| HS_VS_IRQ | RESERVED | OCP_ERR_IRQ | MMU_ERR_IRQ | RESERVED | OVF_IRQ | RSZ_DONE_IRQ | RESERVED | CBUFF_IRQ | PRV_DONE_IRQ | CCDC_LSC_PREFETCH_ERROR | CCDC_LSC_PREFETCH_COMPLETED | CCDC_LSC_DONE | HIST_DONE_IRQ | RESERVED | H3A_AWB_DONE_IRQ | H3A_AF_DONE_IRQ | CCDC_ERR_IRQ | CCDC_VD2_IRQ | CCDC_VD1_IRQ | CCDC_VD0_IRQ | CSIB_LC3_IRQ | CSIB_LC2_IRQ | CSIB_LC1_IRQ | CSIB_LCO_IRQ | CSIB_LCM_IRQ | RESERVED | CSI2C_IRQ | CSI2A_IRQ |   |   |   |

| Bits  | Field Name  | Description                                                                                                                                                                                        | Type           | Reset |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------|
| 31    | HS_VS_IRQ   | HS or VS synchro event <sup>(1)</sup><br>READS:<br>0: Event is false<br>1: Event is true<br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                               | R/W/1to<br>Clr | 0     |
| 30    | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                 | RW             | 0     |
| 29    | OCP_ERR_IRQ | ISP interconnect error.<br>READS:<br>0: Event is false<br>1: Event is true<br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                             | R/W/1to<br>Clr | 0     |
| 28    | MMU_ERR_IRQ | MMU error.<br>If event is true, one needs to read the MMU_IRQSTATUS register to know the event source. Write in MMU_IRQSTATUS to clear the bit.<br>READS:<br>0: Event is false<br>1: Event is true | R/W/1to<br>Clr | 0     |
| 27:26 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                 | R/W/1to<br>Clr | 0     |

<sup>(1)</sup> This event is detected on the incoming HS/VS signals before the CCDC. Therefore, it cannot be used in BT656 mode.

| Bits  | Field Name                      | Description                                                                                                                                                                                                                                                                                                                           | Type           | Reset |
|-------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------|
| 25    | OVF_IRQ                         | Central Resource SBL overflow<br>If event is true, one needs to check the <a href="#">SBL_PCR</a> register to know the source. One needs to clear the <a href="#">SBL_PCR</a> register first before clearing this bit.<br>READS:<br>0: Event is false<br>1: Event is true<br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset | R/W/1to<br>Clr | 0     |
| 24    | RSZ_DONE_IRQ                    | RESIZER module - resizer processing done event.<br>READS:<br>0: Event is false<br>1: Event is true<br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                                                                                                        | R/W/1to<br>Clr | 0     |
| 23:22 | RESERVED                        | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                    | R/W/1to<br>Clr | 0x0   |
| 21    | CBUFF_IRQ                       | A circular buffer event is pending. Check submodule's interrupt status register.<br>READS:<br>0: Event is false<br>1: Event is true<br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                                                                       | R/W/1to<br>Clr | 0     |
| 20    | PRV_DONE_IRQ                    | PREVIEW module - processing done event.<br>READS:<br>0: Event is false<br>1: Event is true<br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                                                                                                                | R/W/1to<br>Clr | 0     |
| 19    | CCDC_LSC_PREFETCH_ERRRO<br>R    | The prefetch error indicates when the gain table was read to slowly from SDRAM.<br>READS:<br>0: Event is false<br>1: Event is true<br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                                                                        | R/W/1to<br>Clr | 0     |
| 18    | CCDC_LSC_PREFETCH_COMP<br>LETED | Indicates current state of the prefetch buffer.<br>READS:<br>0: Event is false<br>1: Event is true<br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                                                                                                        | R/W/1to<br>Clr | 0     |
| 17    | CCDC_LSC_DONE                   | The event is triggered when the internal state of LSC toggles from BUSY to IDLE.<br>READS:<br>0: Event is false<br>1: Event is true<br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                                                                       | R/W/1to<br>Clr | 0     |
| 16    | HIST_DONE_IRQ                   | HIST module - processing done event.<br>READS:<br>0: Event is false<br>1: Event is true<br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                                                                                                                   | R/W/1to<br>Clr | 0     |
| 15:14 | RESERVED                        | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                    | R/W/1to<br>Clr | 0     |

## Camera ISP Register Manual

www.ti.com

| Bits | Field Name       | Description                                                                                                                                                                                                                                                        | Type           | Reset |
|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------|
| 13   | H3A_AWB_DONE_IRQ | H3A module - auto exposure and auto white balance processing done event.<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                    | R/W/1to<br>Clr | 0     |
| 12   | H3A_AF_DONE_IRQ  | H3A module - autofocus processing done event.<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                               | R/W/1to<br>Clr | 0     |
| 11   | CCDC_ERR_IRQ     | CCDC module - faulty pixel correction memory underflow<br>If event is true, one needs to clear the <a href="#">CCDC_FPC.FPERR</a> bit first<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset | R/W/1to<br>Clr | 0     |
| 10   | CCDC_VD2_IRQ     | CCDC module - programmable event 2<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                                          | R/W/1to<br>Clr | 0     |
| 9    | CCDC_VD1_IRQ     | CCDC module - programmable event 1.<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                                         | R/W/1to<br>Clr | 0     |
| 8    | CCDC_VD0_IRQ     | CCDC module - programmable event 0.<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                                         | R/W/1to<br>Clr | 0     |
| 7    | CSIB_LC3_IRQ     | CSI1/CCP2B receiver module - event on logical channel 3.<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                    | R/W/1to<br>Clr | 0     |
| 6    | CSIB_LC2_IRQ     | CSI1/CCP2B receiver module - event on logical channel 2.<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                    | R/W/1to<br>Clr | 0     |
| 5    | CSIB_LC1_IRQ     | CSI1/CCP2B receiver module - event on logical channel 1.<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                                                                    | R/W/1to<br>Clr | 0     |

| Bits | Field Name   | Description                                                                                                                                                                     | Type           | Reset |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------|
| 4    | CSIB_LC0_IRQ | CSI1/CCP2B receiver module - event on logical channel 0.<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset | R/W/1to<br>Clr | 0     |
| 3    | CSIB_LCM_IRQ | CSI1/CCP2B receiver module - event on memory channel.<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset    | R/W/1to<br>Clr | 0     |
| 2    | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                              | R/W/1to<br>Clr | 0     |
| 1    | CSI2C_IRQ    | CSI2C module event.<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                                      | R/W/1to<br>Clr | 0     |
| 0    | CSI2A_IRQ    | CSI2A receiver module event.<br><br>READS:<br>0: Event is false<br>1: Event is true<br><br>WRITES<br>0: Status bit unchanged<br>1: Status bit reset                             | R/W/1to<br>Clr | 0     |

**Table 6-91. Register Call Summary for Register ISP\_IRQ0STATUS**

## Camera ISP Integration

- [Camera ISP Interrupt Requests](#): [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22]

## Camera ISP Basic Programming Model

- [Camera ISP CCDC Interrupts](#): [23] [24] [25]
- [Camera ISP Preview Events and Status Checking](#): [26] [27] [28]
- [Camera ISP Resizer Events and Status Checking](#): [29] [30] [31]
- [Camera ISP H3A Event and Status Checking](#): [32] [33] [34]
- [Camera ISP Histogram Event and Status Checking](#): [35] [36] [37]
- [Camera ISP Central-Resource SBL Event and Status Checking](#): [38] [39] [40] [41] [42]
- [Camera ISP CBUFF Interrupts](#): [43] [44]

## Camera ISP Register Manual

- [Camera ISP Registers Summary](#): [45]

**Table 6-92. ISP\_IRQ1ENABLE**

|                         |                                                                                                                                                   |                 |     |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 0014                                                                                                                                       |                 |     |
| <b>Physical Address</b> | See <a href="#">Table 6-81</a>                                                                                                                    | <b>Instance</b> | ISP |
| <b>Description</b>      | INTERRUPT ENABLE REGISTER TO DSP. IRQ1 STATUS LINE.<br>The same events are mapped in IRQ0. However, one event shall be mapped to only one target. |                 |     |
| <b>Type</b>             | RW                                                                                                                                                |                 |     |

## Camera ISP Register Manual

www.ti.com

| 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 |
|-----------|----------|-------------|-------------|----------|---------|--------------|----------|-----------|--------------|-------------------------|-----------------------------|---------------|---------------|----------|----------|------------------|-----------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|----------|-----------|-----------|---|---|
| HS_VS_IRQ | RESERVED | OCP_ERR_IRQ | MMU_ERR_IRQ | RESERVED | OVF_IRQ | RSZ_DONE_IRQ | RESERVED | CBUFF IRQ | PRV_DONE IRQ | CCDC_LSC_PREFETCH_ERROR | CCDC_LSC_PREFETCH_COMPLETED | CCDC_LSC_DONE | HIST_DONE IRQ | RESERVED | RESERVED | H3A_AWB_DONE IRQ | H3A_AF_DONE IRQ | CCDC_ERR IRQ | CCDC_VD2 IRQ | CCDC_VD1 IRQ | CCDC_VD0 IRQ | CSIB_LC3 IRQ | CSIB_LC2 IRQ | CSIB_LC1 IRQ | CSIB_LCO IRQ | CSIB_LCM IRQ | RESERVED | CSI2C IRQ | CSI2A IRQ |   |   |

| Bits  | Field Name   | Description                                                                                                                                                                                                                                      | Type | Reset |
|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | HS_VS_IRQ    | HS or VS synchro event<br>This event is triggered if a rising or falling edge is detected on the HS or VS signal. The rising or falling edge and the HS or VS signal selection is chosen with the <a href="#">ISP_CTRL.SYNC_DTECT</a> bit field. | RW   | 0     |
| 30    | RESERVED     | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                               | RW   | 0     |
| 29    | OCP_ERR_IRQ  | ISP interconnect error.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                             | RW   | 0     |
| 28    | MMU_ERR_IRQ  | MMU error.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                          | RW   | 0     |
| 27:26 | RESERVED     | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                               | R    | 0x0   |
| 25    | OVF_IRQ      | Central Resource SBL overflow<br>This event is triggered when one of the buffer in the central resource SBL overflows.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                              | RW   | 0     |
| 24    | RSZ_DONE_IRQ | RESIZER module - resizer processing done event.<br>This event is triggered at the end of the frame when the processing is completed for the current frame.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.          | RW   | 0     |
| 23:22 | RESERVED     | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                               | R    | 0x0   |
| 21    | CBUFF IRQ    | Circular buffer interrupt<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                           | RW   | 0     |
| 20    | PRV_DONE IRQ | PREVIEW module - processing done event.<br>This event is triggered at the end of the frame when the processing is completed for the current frame.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                  | RW   | 0     |

| <b>Bits</b> | <b>Field Name</b>               | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 19          | CCDC_LSC_PREFETCH_ERRO<br>R     | The prefetch error indicates when the gain table was read too slowly from SDRAM. When this event is pending the module goes into transparent mode (output=input). Normal operation can be resumed at the start of the next frame after<br>1) clearing this event<br>2) disabling the LSC module<br>3) enabling it<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs. | RW          | 0            |
| 18          | CCDC_LSC_PREFETCH_COMP<br>LETED | Indicates current state of the prefetch buffer. Could be used to start sending the data once the buffer is full to minimize the risk of an underflow. This event is triggered when the buffer contains 3 full paxel rows. It could be used to minimize buffer underflow risks.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                                    | RW          | 0            |
| 17          | CCDC_LSC_DONE                   | The event is triggered when the internal state of LSC toggles from BUSY to IDLE.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                                                                                  | RW          | 0            |
| 16          | HIST_DONE_IRQ                   | HIST module - processing done event.<br>This event is triggered at the end of the frame when the processing is completed for the current frame.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                   | RW          | 0            |
| 15          | RESERVED                        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                     | R           | 0            |
| 14          | RESERVED                        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                     | RW          | 0            |
| 13          | H3A_AWB_DONE_IRQ                | H3A module - auto exposure and auto white balance processing done event.<br>This event is triggered at the end of the frame when the processing is completed for the current frame.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                                                                                                                               | RW          | 0            |
| 12          | H3A_AF_DONE_IRQ                 | H3A module - autofocus processing done event.<br>This event is triggered at the end of the frame when the processing is completed for the current frame.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                          | RW          | 0            |
| 11          | CCDC_ERR_IRQ                    | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                | RW          | 0            |
| 10          | CCDC_VD2_IRQ                    | CCDC module - programmable event 2<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                                                                                                                                | RW          | 0            |
| 9           | CCDC_VD1_IRQ                    | CCDC module - programmable event 1.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                                                                                                                               | RW          | 0            |
| 8           | CCDC_VD0_IRQ                    | CCDC module - programmable event 0.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                                                                                                                               | RW          | 0            |
| 7           | CSIB_LC3_IRQ                    | CSI1/CCP2B receiver module - event on logical channel 3.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                                                                                                          | RW          | 0            |
| 6           | CSIB_LC2_IRQ                    | CSI1/CCP2B receiver module - event on logical channel 2.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs.                                                                                                                                                                                                                                                          | RW          | 0            |

| Bits | Field Name   | Description                                                                                                                           | Type | Reset |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 5    | CSIB_LC1_IRQ | CSI1/CCP2B receiver module - event on logical channel 1.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs. | RW   | 0     |
| 4    | CSIB_LC0_IRQ | CSI1/CCP2B receiver module - event on logical channel 0.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs. | RW   | 0     |
| 3    | CSIB_LCM_IRQ | CSI1/CCP2B receiver module - event on memory channel.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.    | RW   | 0     |
| 2    | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                    | RW   | 0     |
| 1    | CSI2C_IRQ    | CSI2C module event.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                      | RW   | 0     |
| 0    | CSI2A_IRQ    | CSI2A module event.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs.                                      | RW   | 0     |

**Table 6-93. Register Call Summary for Register ISP\_IRQ1ENABLE**

## Camera ISP Functional Description

- Camera ISP Circular Buffer Interrupts: [0]

## Camera ISP Basic Programming Model

- Camera ISP CCDC Interrupts: [1]
- Camera ISP Preview Events and Status Checking: [2]
- Camera ISP Resizer Events and Status Checking: [3]
- Camera ISP Resizer Multiple Passes for Large Resizing Operations: [4]
- Camera ISP H3A Event and Status Checking: [5] [6]
- Camera ISP Histogram Event and Status Checking: [7]
- Camera ISP Central-Resource SBL Event and Status Checking: [8] [9]

## Camera ISP Register Manual

- Camera ISP Registers Summary: [10]

**Table 6-94. ISP\_IRQ1STATUS**

|                  |                                                     |          |     |
|------------------|-----------------------------------------------------|----------|-----|
| Address Offset   | 0x0000 0018                                         |          |     |
| Physical Address | See Table 6-81                                      | Instance | ISP |
| Description      | INTERRUPT STATUS REGISTER TO DSP. IRQ1 STATUS LINE. |          |     |
| Type             | RW                                                  |          |     |

| 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 |
|-----------|----------|-------------|-------------|----------|---------|--------------|----------|-----------|--------------|-------------------------|-----------------------------|---------------|---------------|----------|------------------|-----------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|----------|-----------|-----------|---|---|---|
| HS_VS_IRQ | RESERVED | OCP_ERR_IRQ | MMU_ERR_IRQ | RESERVED | CVF_IRQ | RSZ_DONE_IRQ | RESERVED | CBUFF_IRQ | PRV_DONE_IRQ | CCDC_LSC_PREFETCH_ERROR | CCDC_LSC_PREFETCH_COMPLETED | CCDC_LSC_DONE | HIST_DONE_IRQ | RESERVED | H3A_AVB_DONE_IRQ | H3A_AF_DONE_IRQ | CCDC_ERR_IRQ | CCDC_VD2_IRQ | CCDC_VD1_IRQ | CCDC_VD0_IRQ | CSIB_LC3_IRQ | CSIB_LC2_IRQ | CSIB_LC1_IRQ | CSIB_LC0_IRQ | CSIB_LCM_IRQ | RESERVED | CSI2C_IRQ | CSI2A_IRQ |   |   |   |

| Bits  | Field Name   | Description                                                                                                                                                                                                                                                                                                                           | Type           | Reset |
|-------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------|
| 31    | HS_VS_IRQ    | HS or VS synchro event <sup>(1)</sup><br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                                                                                                                                  | R/W/1to<br>Clr | 0     |
| 30    | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                    | RW             | 0     |
| 29    | OCP_ERR_IRQ  | ISP interconnect error.<br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                                                                                                                                                | R/W/1to<br>Clr | 0     |
| 28    | MMU_ERR_IRQ  | MMU error.<br>If event is true, one needs to read the MMU_IRQSTATUS register to know the event source.<br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                                                                 | R/W/1to<br>Clr | 0     |
| 27:26 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                    | R/W/1to<br>Clr | 0     |
| 25    | OVF_IRQ      | Central Resource SBL overflow<br>If event is true, one needs to check the <a href="#">SBL_PCR</a> register to know the source. One needs to clear the <a href="#">SBL_PCR</a> register first before clearing this bit.<br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset | R/W/1to<br>Clr | 0     |
| 24    | RSZ_DONE_IRQ | RESIZER module - resizer processing done event.<br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                                                                                                                        | R/W/1to<br>Clr | 0     |
| 23:22 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                    | R/W/1to<br>Clr | 0     |
| 21    | CBUFF_IRQ    | A circular buffer event is pending. Check submodule's interrupt status register.<br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                                                                                       | RW<br>W1toClr  | 0     |
| 20    | PRV_DONE_IRQ | PREVIEW module - processing done event.<br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                                                                                                                                | R/W/1to<br>Clr | 0     |

<sup>(1)</sup> This event is detected on the incoming HS/VS signals before the CCDC. Therefore, it cannot be used in BT656 mode.

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name                      | Description                                                                                                                                                                                                                                                              | Type           | Reset |
|-------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------|
| 19    | CCDC_LSC_PREFETCH_ERRO<br>R     | The prefetch error indicates when the gain table was read to slowly from SDRAM.<br><br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                       | R/W/1to<br>Clr | 0     |
| 18    | CCDC_LSC_PREFETCH_COMP<br>LETED | Indicates current state of the prefetch buffer.<br><br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                                                       | R/W/1to<br>Clr | 0     |
| 17    | CCDC_LSC_DONE                   | The event is triggered when the internal state of LSC toggles from BUSY to IDLE.<br><br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                      | R/W/1to<br>Clr | 0     |
| 16    | HIST_DONE_IRQ                   | HIST module - processing done event.<br><br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                                                                  | R/W/1to<br>Clr | 0     |
| 15:14 | RESERVED                        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                       | R/W/1to<br>Clr | 0     |
| 13    | H3A_AWB_DONE_IRQ                | H3A module - auto exposure and auto white balance processing done event.<br><br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                              | R/W/1to<br>Clr | 0     |
| 12    | H3A_AF_DONE_IRQ                 | H3A module - autofocus processing done event.<br><br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                                                         | R/W/1to<br>Clr | 0     |
| 11    | CCDC_ERR_IRQ                    | CCDC module - faulty pixel correction memory underflow<br>If event is true, one needs to clear the CCDC_FPC.FPERR bit first before clearing this bit.<br><br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset | R/W/1to<br>Clr | 0     |
| 10    | CCDC_VD2_IRQ                    | CCDC module - programmable event 2<br><br>READS:<br>0: event is false<br>1: event is true<br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                                                                                                    | R/W/1to<br>Clr | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                              | <b>Type</b>    | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------|
| 9           | CCDC_VD1_IRQ      | CCDC module - programmable event 1.<br><br>READS:<br>0: event is false<br>1: event is true<br><br>WRITES<br>0: status bit unchanged<br>1: status bit reset                      | R/W/1to<br>Clr | 0            |
| 8           | CCDC_VD0_IRQ      | CCDC module - programmable event 0.<br><br>READS:<br>0: event is false<br>1: event is true<br><br>WRITES<br>0: status bit unchanged<br>1: status bit reset                      | R/W/1to<br>Clr | 0            |
| 7           | CSIB_LC3_IRQ      | CSI1/CCP2B receiver module - event on logical channel 3.<br><br>READS:<br>0: event is false<br>1: event is true<br><br>WRITES<br>0: status bit unchanged<br>1: status bit reset | R/W/1to<br>Clr | 0            |
| 6           | CSIB_LC2_IRQ      | CSI1/CCP2B receiver module - event on logical channel 2.<br><br>READS:<br>0: event is false<br>1: event is true<br><br>WRITES<br>0: status bit unchanged<br>1: status bit reset | R/W/1to<br>Clr | 0            |
| 5           | CSIB_LC1_IRQ      | CSI1/CCP2B receiver module - event on logical channel 1.<br><br>READS:<br>0: event is false<br>1: event is true<br><br>WRITES<br>0: status bit unchanged<br>1: status bit reset | R/W/1to<br>Clr | 0            |
| 4           | CSIB_LC0_IRQ      | CSI1/CCP2B receiver module - event on logical channel 0.<br><br>READS:<br>0: event is false<br>1: event is true<br><br>WRITES<br>0: status bit unchanged<br>1: status bit reset | R/W/1to<br>Clr | 0            |
| 3           | CSIB_LCM_IRQ      | CSI1/CCP2B receiver module - event on memory channel.<br><br>READS:<br>0: event is false<br>1: event is true<br><br>WRITES<br>0: status bit unchanged<br>1: status bit reset    | R/W/1to<br>Clr | 0            |
| 2           | RESERVED          | Write Os for future compatibility. Read returns 0.                                                                                                                              | R/W/1to<br>Clr | 0            |
| 1           | CSI2C_IRQ         | CSI2C module event.<br><br>READS:<br>0: event is false<br>1: event is true<br><br>WRITES<br>0: status bit unchanged<br>1: status bit reset                                      | R/W/1to<br>Clr | 0            |

## Camera ISP Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                                                         | Type           | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------|----------------|-------|
| 0    | CSI2A_IRQ  | CSI2A module event.<br>READS:<br>0: event is false<br>1: event is true<br>WRITES:<br>0: status bit unchanged<br>1: status bit reset | R/W/1to<br>Clr | 0     |

**Table 6-95. Register Call Summary for Register ISP\_IRQ1STATUS**

## Camera ISP Basic Programming Model

- Camera ISP CCDC Interrupts: [0] [1] [2]
- Camera ISP Preview Events and Status Checking: [3] [4]
- Camera ISP Resizer Events and Status Checking: [5] [6]
- Camera ISP H3A Event and Status Checking: [7] [8]
- Camera ISP Histogram Event and Status Checking: [9] [10]
- Camera ISP Central-Resource SBL Event and Status Checking: [11] [12] [13] [14]
- Camera ISP CBUFF Interrupts: [15] [16]

## Camera ISP Register Manual

- Camera ISP Registers Summary: [17]

**Table 6-96. TCTRL\_GRESET\_LENGTH**

|                  |                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 0030                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | See Table 6-81                                                                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | TIMING CONTROL - GLOBAL SHUTTER LENGTH REGISTER<br>This register is used by the TIMING CTRL module to generate the CAM.GRESET signal. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | RW                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

  

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         | LENGTH                |                 |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset    |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:24 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                       | R    | 0x00     |
| 23:0  | LENGTH     | Sets the length of the CAM.GLOBAL_RESET signal assertion in cycles of the CNTCLK clock.<br>The CNTCLK frequency is generated with the TCTRL_CTRL.DIVC bit field. After signal assertion, the TCTRL_CTRL.GRESETEN bit is automatically cleared.<br>The possible values are 0 to $2^{24}-1$ cycles.<br>The polarity of the CAM.GLOBAL_RESET signal is set by the TCTRL_CTRL.GRESETPOL bit. | RW   | 0x000000 |

**Table 6-97. Register Call Summary for Register TCTRL\_GRESET\_LENGTH**

## Camera ISP Basic Programming Model

- Camera ISP Timing CTRL Internally-Generated cam\_global\_reset-Based Control-Signal Generation: [0]

## Camera ISP Register Manual

- Camera ISP Registers Summary: [1]
- Camera ISP Register Description: [2]

**Table 6-98. TCTRL\_PSTRB\_REPLY**

|                         |                                                                                                                                 |                         |                                |                 |     |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 0034                                                                                                                     | <b>Physical Address</b> | See <a href="#">Table 6-81</a> | <b>Instance</b> | ISP |
| <b>Description</b>      | TIMING CONTROL - PRESTROBE REPLAY REGISTER<br>This register is used by the TIMING CTRL module to generate the prestrobe signal. |                         |                                |                 |     |
| <b>Type</b>             | RW                                                                                                                              |                         |                                |                 |     |
| 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                |                 |     |
| COUNTER                 |                                                                                                                                 | DELAY                   |                                |                 |     |

  

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      | Type | Reset      |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:25 | COUNTER    | Sets the number of PRESTROBE pulses after the original pulse.<br>If this bit is set to 0, the PRESTROBE signal behavior is only controlled by <a href="#">TCTRL_FRAME_STRB</a> , <a href="#">TCTRL_PSTRB_DELAY</a> and <a href="#">TCTRL_PSTRB_LENGTH</a> .<br>If <a href="#">TCTRL_PSTRB_LENGTH</a> =0, there is no replay.<br>This bit is useful when one wants to enable red-eye removal.                                                     | RW   | 0x00       |
| 24:0  | DELAY      | Sets the delay for the PRESTROBE signal re-assertion in cycles of the CNTCLK clock. The CNTCLK frequency is generated with the <a href="#">TCTRL_CTRL.DIVC</a> bit field. The possible values are 0 to $2^{25}-1$ cycles.<br>If <a href="#">TCTRL_PSTRB_LENGTH</a> =0, there is no replay. This bit field shall not be set to 0 if the COUNTER is set to a value different of 0.<br>This bit is useful when one wants to enable red-eye removal. | RW   | 0x00000000 |

**Table 6-99. Register Call Summary for Register TCTRL\_PSTRB\_REPLY**

Camera ISP Basic Programming Model

- [Camera ISP Timing CTRL STROBE and PRESTROBE Signal Generation for Red-Eye Removal: \[0\] \[1\] \[2\]](#)

Camera ISP Register Manual

- [Camera ISP Registers Summary: \[3\]](#)

**Table 6-100. ISP\_CTRL**

|                         |                         |                         |                                |                   |                   |             |             |             |            |            |             |            |                  |             |       |          |             |            |                 |
|-------------------------|-------------------------|-------------------------|--------------------------------|-------------------|-------------------|-------------|-------------|-------------|------------|------------|-------------|------------|------------------|-------------|-------|----------|-------------|------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0040             | <b>Physical Address</b> | See <a href="#">Table 6-81</a> | <b>Instance</b>   | ISP               |             |             |             |            |            |             |            |                  |             |       |          |             |            |                 |
| <b>Description</b>      | CONTROL REGISTER        |                         |                                |                   |                   |             |             |             |            |            |             |            |                  |             |       |          |             |            |                 |
| <b>Type</b>             | RW                      |                         |                                |                   |                   |             |             |             |            |            |             |            |                  |             |       |          |             |            |                 |
| 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                |                   |                   |             |             |             |            |            |             |            |                  |             |       |          |             |            |                 |
| FLUSH                   | JPEG_FLUSH              | CCDC_VEN_POL            | SBL_SHARED_RPORTB              | SBL_SHARED_RPORTA | SBL_SHARED_WPORTC |             |             |             |            |            |             |            |                  |             |       |          |             |            |                 |
|                         | CBUFF0_BCF_CTRL         | SBL_AUTOIDLE            | SBL_WR0_RAM_EN                 | SBL_WR1_RAM_EN    | SBL_RD_RAM_EN     | PREV_RAM_EN | CCDC_RAM_EN | SYNC_DETECT | RSZ_CLK_EN | PRV_CLK_EN | HIST_CLK_EN | H3A_CLK_EN | CBUFF_AUTOGATING | CCDC_CLK_EN | SHIFT | RESERVED | PAR_CLK_POL | PAR_BRIDGE | PAR_SER_CLK_SEL |

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                             | Type | Reset |
|-------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | FLUSH             | CCDC memory flush<br>Writing '1' in this bit flushes the CCDC memories in the central resource SBL. The SBL memories are always flushed by the end of frame. However, there are cases where the end of frame cannot be detected.                                                                                                                                                                                        | RW   | 0     |
| 30    | JPEG_FLUSH        | JPEG flush<br>When a camera module outputs a JPEG bit stream, this bit needs to be set because the bitstream length may not be a multiple of 32 bits. Enabling this bit ensures that no data stay in the design internal FIFOs.                                                                                                                                                                                         | RW   | 0     |
| 29    | CCDC_WEN_POL      | Sets the polarity of the CCDC WEN bit.<br>0x0: Active low<br>0x1: Active high                                                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 28    | SBL_SHARED_RPORTB | Controls SBL shared read port B access<br>0x0: Read port used by preview module dark frame read<br>0x1: Read port used by CCDC module lens shading compensation data read                                                                                                                                                                                                                                               | RW   | 0     |
| 27    | SBL_SHARED_RPORTA | Controls SBL shared read port A access<br>0x0: Read port used by preview module data read<br>0x1: Read port used by CSI1 module data read                                                                                                                                                                                                                                                                               | RW   | 0     |
| 26    | SBL_SHARED_WPORTC | Controls SBL shared write port C access<br>0x0: CSI1/CCP2B : CCP2 protocol engine<br>0x1: CSI2C : CSI2C protocol engine                                                                                                                                                                                                                                                                                                 | RW   | 0     |
| 25:24 | CBUFF1_BCF_CTRL   | Bandwidth control feedback loop configuration register<br>0x0: Disabled.<br>0x1: The BCF signal of CBUFF1 stalls the response phase of the CSI1/CCP2B Interconnect read master port.<br>0x2: The BCF signal of CBUFF1 stalls the request phase of the CSI1/CCP2B Interconnect read master port.<br>0x3: The BCF signal of CBUFF1 stalls the request and response phase of the CSI1/CCP2B Interconnect read master port. | RW   | 0x0   |
| 23:22 | CBUFF0_BCF_CTRL   | Bandwidth control feedback loop configuration register<br>0x0: Disabled.<br>0x1: The BCF signal of CBUFF0 stalls the response phase of the CSI1/CCP2B Interconnect read master port.<br>0x2: The BCF signal of CBUFF0 stalls the request phase of the CSI1/CCP2B Interconnect read master port.<br>0x3: The BCF signal of CBUFF0 stalls the request and response phase of the CSI1/CCP2B Interconnect read master port. | RW   | 0x0   |
| 21    | SBL_AUTOIDLE      | Sets the SBL autoidle mode<br>0x0: Disabled<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                             | RW   | 1     |
| 20    | SBL_WR0_RAM_EN    | This bit controls the SBL module WRITE0 RAM used by the RESIZER module. If the RESIZER module is disabled, this bit shall be set to '0' to save power.<br>0x0: RAM is disabled<br>0x1: RAM is enabled                                                                                                                                                                                                                   | RW   | 0     |
| 19    | SBL_WR1_RAM_EN    | This bit controls the SBL module WRITE1 RAM. If the RESIZER module is the only module enabled to perform memory to memory resize operations, this bit shall be set to '0' to save power.<br>0x0: RAM is disabled<br>0x1: RAM is enabled                                                                                                                                                                                 | RW   | 0     |

| Bits  | Field Name       | Description                                                                                                                                                                                                                                                                                                                                                                                               | Type | Reset |
|-------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 18    | SBL_RD_RAM_EN    | This bit controls the SBL module READ RAM. If no read requests are generated, this bit shall be set to '0' to save power.<br><br>0x0: RAM is disabled<br>0x1: RAM is enabled                                                                                                                                                                                                                              | RW   | 0     |
| 17    | PREV_RAM_EN      | This bit controls the PREVIEW module RAM. If the PREVIEW module is not used, this bit shall be set to 0 to save power.<br><br>0x0: RAM is disabled<br>0x1: RAM is enabled                                                                                                                                                                                                                                 | RW   | 0     |
| 16    | CCDC_RAM_EN      | This bit controls the CCDC module RAM. If the CCDC module is not used, the bit shall be set to 0 to save power.<br><br>0x0: RAM is disabled<br>0x1: RAM is enabled                                                                                                                                                                                                                                        | RW   | 0     |
| 15:14 | SYNC_DETECT      | HS or VS synchronization signal detection<br>It is sometimes necessary to detect the rising or falling edge of the horizontal and vertical synchro signals. When such event is detected, an interrupt will be triggered if <b>ISP IRQ0ENABLE.HS_VS_IRQ = 1</b> or <b>ISP IRQ0ENABLE.HS_VS_IRQ = 1</b> .<br><br>0x0: HS falling edge<br>0x1: HS rising edge<br>0x2: VS falling edge<br>0x3: VS rising edge | RW   | 0x0   |
| 13    | RSZ_CLK_EN       | RSZ module clock enable.<br>This bit controls the clock distribution to the RSZ module.<br><br>0x0: Disable clock. The module is not active. However, accesses on the module slave port to configure it are still possible.<br><br>0x1: Enable clock. The module is fully functional.                                                                                                                     | RW   | 0     |
| 12    | PRV_CLK_EN       | PRV module clock enable.<br>This bit controls the clock distribution to the PRV module.<br><br>0x0: Disable clock. The module is not active. However, accesses on the module slave port to configure it are still possible.<br><br>0x1: Enable clock. The module is fully functional.                                                                                                                     | RW   | 0     |
| 11    | HIST_CLK_EN      | HIST module clock enable.<br>This bit controls the clock distribution to the HIST module.<br><br>0x0: Disable clock. The module is not active. However, accesses on the module slave port to configure it are still possible.<br><br>0x1: Enable clock. The module is fully functional.                                                                                                                   | RW   | 0     |
| 10    | H3A_CLK_EN       | H3A module clock enable.<br>This bit controls the clock distribution to the H3A module.<br><br>0x0: Disable clock. The module is not active. However, accesses on the module slave port to configure it are still possible.<br><br>0x1: Enable clock. The module is fully functional.                                                                                                                     | RW   | 0     |
| 9     | CBUFF_AUTOGATING | CBUFF module autogating feature control<br><br>0x0: CBUFF autogating feature is disabled.<br>The CBUFF internal clock is free running.<br><br>0x1: CBUFF autogating feature is enabled.<br>The CBUFF internal clock is only enabled when it is requested by the CBUFF module.                                                                                                                             | RW   | 1     |

## Camera ISP Register Manual

www.ti.com

| Bits | Field Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Type | Reset |
|------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 8    | CCDC_CLK_EN     | <p>CCDC module clock enable.<br/>           This bit controls the clock distribution to the CCDC module.</p> <p>0x0: Disable clock. The module is not active. However, accesses on the module slave port to configure it are still possible.</p> <p>0x1: Enable clock. The module is fully functional.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0     |
| 7:6  | SHIFT           | <p>Data lane shifter<br/>           The parallel interface is a 12-bit interface,<br/>           The video port of CSI1/CCP2B is a 12-bit interface,<br/>           The video port of CSI2A or CSI2C is a 14-bit interface.<br/>           The CAMERA ISP has 14 data lanes but the full imaging pipeline only supports 10 bits.<br/>           There are 2 main utilizations of the data lane shifter<br/>           1) Dynamic reduction: For example data from a 12 bit sensor could be converted into 10bit.<br/>           2) When a camera module has fewer than 12 data lanes, the ISP requires the pins to be connected on the least significant lanes. An issue occurs when a n-bit camera parallel interface can work in a m-bit mode with mn. The ISP expects the m bits to be on the least significant data lanes whereas it is not correct.<br/>           The data lane shifter takes place before the CCDC module</p> <p>0x0: No shift.<br/>           CAMEXT[13:0] - CAM [13:0]</p> <p>0x1: Shift by 2.<br/>           CAMEXT[13:2] - CAM [11:0]</p> <p>0x2: Shift by 4<br/>           CAMEXT[13:4] - CAM [9:0]</p> <p>0x3: Shift by 6<br/>           CAMEXT[13:6] - CAM [7:0]</p> | RW   | 0x0   |
| 5    | RESERVED        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R    | 0     |
| 4    | PAR_CLK_POL     | <p>This bit sets the pixel clock polarity on the parallel interface. The pixel clock is used for latching the pixel data into the CCDC module.</p> <p>0x0: Clock not inverted. The data are sampled on the rising edge of the clock.</p> <p>0x1: Clock inverted. The data are sampled on the falling edge of the clock.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0     |
| 3:2  | PAR_BRIDGE      | <p>This bit field controls the 8 to 16-bit bridge at the input of the CCDC module.</p> <p>0x0: The bridge is disabled: no conversion.</p> <p>0x1: Reserved</p> <p>0x2: The bridge is enabled. The first byte is written to CAM.DATA[7:0], the second byte is written to CAM.DATA[15:8]</p> <p>0x3: The bridge is enabled. The first byte is written to CAM.DATA[15:8], the second byte is written to CAM.DATA[7:0]</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0x0   |
| 1:0  | PAR_SER_CLK_SEL | <p>Selects the serial or parallel interface as the input to the preview hardware.</p> <p>0x0: Selects the 12-bit parallel interface as the input to the CCDC module.</p> <p>0x1: Selects the CSI2A as the input to the CCDC module.</p> <p>0x2: Selects the CSI1/CCP2B serial interface as the input to the CCDC module.</p> <p>0x3: Selects the CSI2C as the input to the CCDC module.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0x0   |

**Table 6-101. Register Call Summary for Register ISP\_CTRL**

|                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Camera ISP Environment             | <ul style="list-style-type: none"> <li>• Camera ISP Parallel Generic Configuration: JPEG Sensor Connection on the Parallel Interface: [0]</li> </ul>                                                                                                                                                                                                                                                                                                                                                                          |
| Camera ISP Integration             | <ul style="list-style-type: none"> <li>• Camera ISP Local Power Management: [1]</li> <li>• Camera ISP System Power Management: [2] [3] [4] [5] [6]</li> <li>• Camera ISP Interrupt Requests: [7]</li> </ul>                                                                                                                                                                                                                                                                                                                   |
| Camera ISP Functional Description  | <ul style="list-style-type: none"> <li>• Camera ISP Bridge-Lane Shifter: [8] [9]</li> <li>• Camera ISP CCDC Block Diagram: [10]</li> <li>• Camera ISP CCDC Functional Operations: [11]</li> <li>• Camera ISP VPBE Preview Input Interface: [12]</li> <li>• Camera ISP VPBE Preview Dark-Frame Subtract or Shading Compensation: [13]</li> <li>• Camera ISP Shared Buffer Logic Read Buffer Logic (RBL) and Read Buffer: [14] [15]</li> <li>• Camera ISP Circular Buffer Bandwidth Control Feedback Loop: [16] [17]</li> </ul> |
| Camera ISP Basic Programming Model | <ul style="list-style-type: none"> <li>• Camera ISP CSI1/CCP2B Read Data from Memory: [18]</li> <li>• Camera ISP CCDC Register Setup: [19] [20] [21] [22] [23] [24] [25]</li> <li>• Camera ISP CCDC Image-Sensor Configuration: [26] [27] [28]</li> <li>• Camera ISP CCDC Image-Signal Processing:</li> <li>• Camera ISP Preview Register Setup: [30] [31]</li> <li>• Camera ISP Preview Summary of Constraints: [32] [33]</li> </ul>                                                                                         |
| Camera ISP Register Manual         | <ul style="list-style-type: none"> <li>• Camera ISP Registers Summary: [34]</li> <li>• Camera ISP Register Description: [35] [36] [37]</li> <li>• Camera ISP CCDC Register Description: [38] [39]</li> </ul>                                                                                                                                                                                                                                                                                                                  |

**Table 6-102. TCTRL\_CTRL**

|                       |           |                                   |                         |              |                                |                 |          |
|-----------------------|-----------|-----------------------------------|-------------------------|--------------|--------------------------------|-----------------|----------|
| <b>Address Offset</b> |           | 0x0000 0050                       | <b>Physical Address</b> |              | See <a href="#">Table 6-81</a> | <b>Instance</b> | ISP      |
| <b>Description</b>    |           | TIMING CONTROL - CONTROL REGISTER |                         |              |                                |                 |          |
| <b>Type</b>           |           | RW                                |                         |              |                                |                 |          |
| 31                    | 30        | 29                                | 28                      | 27           | 26                             | 25              | 24       |
| GRESETDIR             | GRESETPOL | GRESETEN                          | INSEL                   | STRBPSTRBPOL | RESERVED                       | SHUTPOL         |          |
|                       |           |                                   |                         |              |                                | STRBEN          | PSTRBEN  |
|                       |           |                                   |                         |              |                                | SHUTEN          | RESERVED |
|                       |           |                                   |                         |              |                                |                 |          |
|                       |           |                                   |                         |              |                                | DIVC            | DIVB     |
|                       |           |                                   |                         |              |                                |                 | DIVA     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31          | GRESETDIR         | Sets the direction of the GLOBAL_RESET signal.<br>0x0: INPUT. GLOBAL_RESET is an input to the TIMING CONTROL module. GLOBAL_RESET is externally generated.<br>0x1: OUTPUT. GLOBAL_RESET is an output of the TIMING CONTROL module. GLOBAL_RESET is internally generated. If GRESETEN is set to 1, the internally generated GLOBAL_RESET will trigger the generation of the PRESTROBE, STROBE and SHUTTER signals. The frame counters are ignored. | RW          | 0            |

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 30    | GRESETPOL    | Sets the polarity of the global reset signal: CAM.GLOBAL_RESET. It applies whatever the direction of the GLOBAL_RESET signal: input or output.<br>0x0: active high<br>0x1: active low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0     |
| 29    | GRESETEN     | Triggers the generation of the CAM.GLOBAL_RESET signal. The signal is asserted immediately. If enabled, the CAM.GLOBAL_RESET signal will be asserted for <a href="#">TCTRL_GRESET_LENGTH</a> cycles. After the signal assertion, the enable bit is automatically cleared to 0. The polarity of the GLOBAL_RESET signal is set with <a href="#">TCTRL_CTRL.GRESETPOL</a> . Enabling this bit triggers the generation of the CAM.SHUTTER and CAM.STROBE signals (if previously enabled). The frame counters shall be set to 0 when this bit is set to 1 and GRESETDIR is set a OUTPUT.                                                                                                                                                                                                                                                                                                                         | RW   | 0     |
| 28:27 | INSEL        | Sets the mode that will trigger the SHUTTER, PRESTROBE and STROBE signals.<br><br>0x0: Video port.<br>The VS sync pulse at the input of the CCDC module is used to count the frames.<br>The source of the VS pulse is selected by the <a href="#">ISP_CTRL[1:0] PAR_SER_CLK_SEL</a> register.<br><br>0x1: CSI2A interface. The frame start code (FSC) and frame end code (FEC) sync codes are used to count the frames.<br><br>0x2: CSI1/CCP2B or CSI2C interface. The frame start code (FSC) and frame end code (FEC) sync codes are used to count the frames.<br><br>0x3: GRESET. The CAM.GLOBAL_RESET input signal will trigger the SHUTTER, PRESTROBE and STROBE signals. In this mode, there are no frame counters. The delay counters start decrementing as soon as the GLOBAL_RESET signal is asserted.<br>The polarity of the GLOBAL_RESET signal is set with <a href="#">TCTRL_CTRL.GRESETPOL</a> . | RW   | 0x0   |
| 26    | STRBPSTRBPOL | Sets the polarity of the strobe and prestrobe signals.<br><br>0x0: Active high<br>0x1: Active low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0     |
| 25    | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0     |
| 24    | SHUTPOL      | Sets the polarity of the mechanical shutter signal: CAM.SHUTTER<br><br>0x0: Active high<br>0x1: Active low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0     |
| 23    | STRBEN       | Flash strobe signal enable. If enabled, the STROBE signal will be asserted after <a href="#">TCTRL_FRAME.STRB</a> frames have been received and a delay of <a href="#">TCTRL_STRB_DELAY</a> cycles have passed. The STROBE signal is asserted for <a href="#">TCTRL_STRB_LENGTH</a> cycles. After the signal assertion, the enable bit is automatically cleared to 0.<br>This signal shall not be disabled by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW   | 0     |
| 22    | PSTRBEN      | Flash prestrobe signal enable. If enabled, the PRESTROBE signal will be asserted after <a href="#">TCTRL_FRAME.PSTRB</a> frames have been received and a delay of <a href="#">TCTRL_PSTRB_DELAY</a> cycles have passed. The PRESTROBE signal is asserted for <a href="#">TCTRL_PSTRB_LENGTH</a> cycles. After the signal assertion, the enable bit is automatically cleared to 0.<br>This signal shall not be disabled by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0     |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 21    | SHUTEN     | Mechanical shutter signal enable. If enabled, the SHUTTER signal will be asserted after <a href="#">TCTRL_FRAME.SHUT</a> frames have been received and a delay of <a href="#">TCTRL_SHUT_DELAY</a> cycles have passed. The SHUTTER signal is asserted for <a href="#">TCTRL_SHUT_LENGTH</a> cycles. After the signal assertion, the enable bit is automatically cleared to 0.<br><br>This signal shall not be disabled by software.                                                                           | RW   | 0     |
| 20:19 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R    | 0x0   |
| 18:10 | DIVC       | Sets the clock divisor value for the CNTCLK clock generation based on the CAM.MCLK input clock. CNTCLK is an internal clock used by the TIMING CTRL module counters. Usually, CNTCLK = CAM.MCLK / DIVC, except for some particular values shown hereafter.<br><br>0x0: No clock. CNTCLK is gated.                                                                                                                                                                                                             | RW   | 0x000 |
| 9:5   | DIVB       | Sets the clock divisor value for the CAM.XCLKB clock generation based on the CAM.MCLK input clock. Usually, CAM.XCLKB = CAM.MCLK / DIVB, except for some particular values shown hereafter.<br><br>This bit field is not reset by a soft reset; a hard reset is required. It enables to keep the clock configuration stable through a soft reset.<br><br>0x0: CAM.XCLKB = stable low level. Divider disabled.<br>0x1: CAM.XCLKB = stable high level. Divider disabled.<br>0x1F: CAM.XCLKB = CAM.XCLK. Bypass. | RW   | 0x00  |
| 4:0   | DIVA       | Sets the clock divisor value for the CAM.XCLKA clock generation based on the CAM.MCLK input clock. Usually, CAM.XCLKA = CAM.MCLK / DIVA, except for some particular values shown hereafter.<br><br>This bit field is not reset by a soft reset; a hard reset is required. It enables to keep the clock configuration stable through a soft reset.<br><br>0x0: CAM.XCLKA = stable low level. Divider disabled.<br>0x1: CAM.XCLKA = stable high level. Divider disabled.<br>0x1F: CAM.XCLKA = CAM.XCLK. Bypass. | RW   | 0x00  |

**Table 6-103. Register Call Summary for Register TCTRL\_CTRL**
**Camera ISP Integration**

- [Camera ISP Clock Configuration: \[0\] \[1\]](#)

**Camera ISP Functional Description**

- [Camera ISP Timing Control Control-Signal Generator: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\]](#)

**Camera ISP Basic Programming Model**

- [Camera ISP Timing CTRL Timing Generator: \[13\] \[14\] \[15\] \[16\]](#)
- [Camera ISP Timing CTRL Camera-Control Signal Generator: \[17\] \[18\] \[19\]](#)
- [Camera ISP Timing CTRL Vertical Synchro-Based Control-Signal Generation or Externally-Generated cam\\_global\\_reset: \[20\] \[21\] \[22\] \[23\] \[24\] \[25\] \[26\] \[27\] \[28\] \[29\] \[30\] \[31\] \[32\]](#)
- [Camera ISP Timing CTRL Internally-Generated cam\\_global\\_reset-Based Control-Signal Generation: \[33\] \[34\] \[35\] \[36\] \[37\] \[38\] \[39\] \[40\] \[41\] \[42\] \[43\] \[44\] \[45\] \[46\] \[47\] \[48\] \[49\] \[50\] \[51\] \[52\] \[53\] \[54\]](#)
- [Camera ISP Timing CTRL STROBE and PRESTROBE Signal Generation for Red-Eye Removal: \[55\]](#)

**Camera ISP Register Manual**

- [Camera ISP Registers Summary: \[56\]](#)
- [Camera ISP Register Description: \[57\] \[58\] \[59\] \[60\] \[61\] \[62\] \[63\] \[64\] \[65\] \[66\] \[67\] \[68\] \[69\] \[70\] \[71\]](#)

**Table 6-104. TCTRL\_FRAME**

|                       |                                                                                                                                           |                         |                                |                 |     |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------------------|-----------------|-----|
| <b>Address Offset</b> | 0x0000 0054                                                                                                                               | <b>Physical Address</b> | See <a href="#">Table 6-81</a> | <b>Instance</b> | ISP |
| <b>Description</b>    | TIMING CONTROL - FRAME REGISTER<br>This register is used by the TIMING CTRL module to generate the SHUTTER, PRESTROBE and STROBE signals. |                         |                                |                 |     |
| <b>Type</b>           | RW                                                                                                                                        |                         |                                |                 |     |



| Bits  | Field Name       | Description                                                                                                                                                                                                                                           | Type | Reset |
|-------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:20 | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                    | R    | 0x000 |
| 19    | CCP2B_EOL_ENABLE | Don't flush SBL between lines when this bit is cleared.<br>Used to 32-byte overcome alignment constraints when data is send continuously by CCP2.<br>EOF generation is not affected.<br><br>0x0: Disable EOL generation<br>0x1: Enable EOL generation | RW   | 1     |
| 18    | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                    | R    | 1     |
| 17:12 | STRB             | Frame counter for the STROBE signal generation. From 0 to 63 frames.<br>This bit field is ignored if TCTRL.INSEL=GRESET.                                                                                                                              | RW   | 0x00  |
| 11:6  | PSTRB            | Frame counter for the PRESTROBE signal generation. From 0 to 63 frames.<br>This bit field is ignored if TCTRL.INSEL=GRESET.                                                                                                                           | RW   | 0x00  |
| 5:0   | SHUT             | Frame counter for the SHUTTER signal generation. From 0 to 63 frames.<br>This bit field is ignored if TCTRL.INSEL=GRESET.                                                                                                                             | RW   | 0x00  |

**Table 6-105. Register Call Summary for Register TCTRL\_FRAME**

## Camera ISP Basic Programming Model

- [Camera ISP Timing CTRL Vertical Synchro-Based Control-Signal Generation or Externally-Generated cam\\_global\\_reset: \[0\] \[1\] \[2\]](#)
- [Camera ISP Timing CTRL Internally-Generated cam\\_global\\_reset-Based Control-Signal Generation: \[3\] \[4\] \[5\]](#)

## Camera ISP Register Manual

- [Camera ISP Registers Summary: \[6\]](#)
- [Camera ISP Register Description: \[7\] \[8\] \[9\] \[10\]](#)

**Table 6-106. TCTRL\_PSTRB\_DELAY**

| <b>Address Offset</b>   | 0x0000 0058                                                                                                                     |                                                                                                                                                                                                                          |      |            |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| <b>Physical Address</b> | See <a href="#">Table 6-81</a>                                                                                                  | <b>Instance</b>                                                                                                                                                                                                          |      |            |
| <b>Description</b>      | TIMING CONTROL - PRE STROBE DELAY REGISTER<br>This register is used by the TIMING CTRL module to generate the PRESTROBE signal. |                                                                                                                                                                                                                          |      |            |
| <b>Type</b>             | RW                                                                                                                              |                                                                                                                                                                                                                          |      |            |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16                                                                                                         | 15 14 13 12 11 10 9 8                                                                                                                                                                                                    |      |            |
| RESERVED                |                                                                                                                                 | DELAY                                                                                                                                                                                                                    |      |            |
| Bits                    | Field Name                                                                                                                      | Description                                                                                                                                                                                                              | Type | Reset      |
| 31:25                   | RESERVED                                                                                                                        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                       | R    | 0x00       |
| 24:0                    | DELAY                                                                                                                           | Sets the delay for the CAM.PSTROBE signal assertion in cycles of the CNTCLK clock. The CNTCLK frequency is generated with the <a href="#">TCTRL_CTRL.DIVC</a> bit field. The possible values are 0 to $2^{25}-1$ cycles. | RW   | 0x00000000 |

**Table 6-107. Register Call Summary for Register TCTRL\_PSTRB\_DELAY**

Camera ISP Basic Programming Model

- [Camera ISP Timing CTRL Vertical Synchro-Based Control-Signal Generation or Externally-Generated cam\\_global\\_reset: \[0\]](#)
- [Camera ISP Timing CTRL Internally-Generated cam\\_global\\_reset-Based Control-Signal Generation: \[1\]](#)
- [Camera ISP Timing CTRL STROBE and PRESTROBE Signal Generation for Red-Eye Removal: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP Registers Summary: \[3\]](#)
- [Camera ISP Register Description: \[4\] \[5\]](#)

**Table 6-108. TCTRL\_STRB\_DELAY**

| <b>Address Offset</b>   | 0x0000 005C                                                                                                              |                                                                                                                                                                                                                         |      |            |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| <b>Physical Address</b> | See <a href="#">Table 6-81</a>                                                                                           | <b>Instance</b>                                                                                                                                                                                                         |      |            |
| <b>Description</b>      | TIMING CONTROL - STROBE DELAY REGISTER<br>This register is used by the TIMING CTRL module to generate the STROBE signal. |                                                                                                                                                                                                                         |      |            |
| <b>Type</b>             | RW                                                                                                                       |                                                                                                                                                                                                                         |      |            |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16                                                                                                  | 15 14 13 12 11 10 9 8                                                                                                                                                                                                   |      |            |
| RESERVED                |                                                                                                                          | DELAY                                                                                                                                                                                                                   |      |            |
| Bits                    | Field Name                                                                                                               | Description                                                                                                                                                                                                             | Type | Reset      |
| 31:25                   | RESERVED                                                                                                                 | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                      | R    | 0x00       |
| 24:0                    | DELAY                                                                                                                    | Sets the delay for the CAM.STROBE signal assertion in cycles of the CNTCLK clock. The CNTCLK frequency is generated with the <a href="#">TCTRL_CTRL.DIVC</a> bit field. The possible values are 0 to $2^{25}-1$ cycles. | RW   | 0x00000000 |

**Table 6-109. Register Call Summary for Register TCTRL\_STRB\_DELAY**

Camera ISP Basic Programming Model

- [Camera ISP Timing CTRL Vertical Synchro-Based Control-Signal Generation or Externally-Generated cam\\_global\\_reset: \[0\]](#)
- [Camera ISP Timing CTRL Internally-Generated cam\\_global\\_reset-Based Control-Signal Generation: \[1\]](#)
- [Camera ISP Timing CTRL STROBE and PRESTROBE Signal Generation for Red-Eye Removal: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP Registers Summary: \[3\]](#)
- [Camera ISP Register Description: \[4\]](#)

**Table 6-110. TCTRL\_SHUT\_DELAY**

| <b>Address Offset</b>   | 0x0000 0060                                                                                                                |                                                                                                                                                                                                                          |      |            |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| <b>Physical Address</b> | See <a href="#">Table 6-81</a>                                                                                             | <b>Instance</b>                                                                                                                                                                                                          |      |            |
| <b>Description</b>      | TIMING CONTROL - SHUTTER DELAY REGISTER<br>This register is used by the TIMING CTRL module to generate the SHUTTER signal. |                                                                                                                                                                                                                          |      |            |
| <b>Type</b>             | RW                                                                                                                         |                                                                                                                                                                                                                          |      |            |
| 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                                                                                                                                                                                    |      |            |
| RESERVED                |                                                                                                                            | DELAY                                                                                                                                                                                                                    |      |            |
| Bits                    | Field Name                                                                                                                 | Description                                                                                                                                                                                                              | Type | Reset      |
| 31:25                   | RESERVED                                                                                                                   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                       | R    | 0x00       |
| 24:0                    | DELAY                                                                                                                      | Sets the delay for the CAM.SHUTTER signal assertion in cycles of the CNTCLK clock. The CNTCLK frequency is generated with the <a href="#">TCTRL_CTRL.DIVC</a> bit field. The possible values are 0 to $2^{25}-1$ cycles. | RW   | 0x00000000 |

**Table 6-111. Register Call Summary for Register TCTRL\_SHUT\_DELAY**

Camera ISP Basic Programming Model

- [Camera ISP Timing CTRL Vertical Synchro-Based Control-Signal Generation or Externally-Generated cam\\_global\\_reset: \[0\]](#)
- [Camera ISP Timing CTRL Internally-Generated cam\\_global\\_reset-Based Control-Signal Generation: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP Registers Summary: \[2\]](#)
- [Camera ISP Register Description: \[3\]](#)

**Table 6-112. TCTRL\_PSTRB\_LENGTH**

| <b>Address Offset</b>   | 0x0000 0064                                                                                                                     |                                                                                                                                                                                                                                                                                                                         |      |            |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| <b>Physical Address</b> | See <a href="#">Table 6-81</a>                                                                                                  | <b>Instance</b>                                                                                                                                                                                                                                                                                                         |      |            |
| <b>Description</b>      | TIMING CONTROL - PRESTROBE LENGTH REGISTER<br>This register is used by the TIMING CTRL module to generate the PRESTROBE signal. |                                                                                                                                                                                                                                                                                                                         |      |            |
| <b>Type</b>             | RW                                                                                                                              |                                                                                                                                                                                                                                                                                                                         |      |            |
| 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                                                                                                                                                                                                                                                                                   |      |            |
| RESERVED                |                                                                                                                                 | LENGTH                                                                                                                                                                                                                                                                                                                  |      |            |
| Bits                    | Field Name                                                                                                                      | Description                                                                                                                                                                                                                                                                                                             | Type | Reset      |
| 31:24                   | RESERVED                                                                                                                        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                      | R    | 0x00       |
| 23:0                    | LENGTH                                                                                                                          | Sets the length of the CAM.PRESTROBE signal assertion in cycles of the CNTCLK clock. The CNTCLK frequency is generated with the <a href="#">TCTRL_CTRL.DIVC</a> bit field. After signal assertion, the <a href="#">TCTRL_CTRL.PSTRBEN</a> bit is automatically cleared. The possible values are 0 to $2^{24}-1$ cycles. | RW   | 0x00000000 |

**Table 6-113. Register Call Summary for Register TCTRL\_PSTRB\_LENGTH**

Camera ISP Basic Programming Model

- [Camera ISP Timing CTRL Vertical Synchro-Based Control-Signal Generation or Externally-Generated cam\\_global\\_reset: \[0\]](#)
- [Camera ISP Timing CTRL Internally-Generated cam\\_global\\_reset-Based Control-Signal Generation: \[1\]](#)
- [Camera ISP Timing CTRL STROBE and PRESTROBE Signal Generation for Red-Eye Removal: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP Registers Summary: \[3\]](#)
- [Camera ISP Register Description: \[4\] \[5\] \[6\] \[7\]](#)

**Table 6-114. TCTRL\_STRB\_LENGTH**

| <b>Address Offset</b>   | 0x0000 0068                                                                                                               |                                                                                                                                                                                                                                                                                                                     |                 |        |  |  |  |        |  |  |  |  |  |  |  |  |      |          |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------|--|--|--|--------|--|--|--|--|--|--|--|--|------|----------|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | See <a href="#">Table 6-81</a>                                                                                            |                                                                                                                                                                                                                                                                                                                     |                 |        |  |  |  |        |  |  |  |  |  |  |  |  |      |          |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | TIMING CONTROL - STROBE LENGTH REGISTER<br>This register is used by the TIMING CTRL module to generate the STROBE signal. |                                                                                                                                                                                                                                                                                                                     |                 |        |  |  |  |        |  |  |  |  |  |  |  |  |      |          |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                        |                                                                                                                                                                                                                                                                                                                     |                 |        |  |  |  |        |  |  |  |  |  |  |  |  |      |          |  |  |  |  |  |  |  |  |  |
| 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 | LENGTH |  |  |  |        |  |  |  |  |  |  |  |  |      |          |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                                                                                                           |                                                                                                                                                                                                                                                                                                                     |                 |        |  |  |  | LENGTH |  |  |  |  |  |  |  |  |      |          |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                                                                                | Description                                                                                                                                                                                                                                                                                                         |                 |        |  |  |  |        |  |  |  |  |  |  |  |  | Type | Reset    |  |  |  |  |  |  |  |  |  |
| 31:24                   | RESERVED                                                                                                                  | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                  |                 |        |  |  |  |        |  |  |  |  |  |  |  |  | R    | 0x00     |  |  |  |  |  |  |  |  |  |
| 23:0                    | LENGTH                                                                                                                    | Sets the length of the CAM.STROBE signal assertion in cycles of the CNTCLK clock. The CNTCLK frequency is generated with the <a href="#">TCTRL_CTRL.DIVC</a> bit field. After signal assertion, the <a href="#">TCTRL_CTRL.STRBEN</a> bit is automatically cleared. The possible values are 0 to $2^{24}-1$ cycles. |                 |        |  |  |  |        |  |  |  |  |  |  |  |  | RW   | 0x000000 |  |  |  |  |  |  |  |  |  |

**Table 6-115. Register Call Summary for Register TCTRL\_STRB\_LENGTH**

Camera ISP Basic Programming Model

- [Camera ISP Timing CTRL Vertical Synchro-Based Control-Signal Generation or Externally-Generated cam\\_global\\_reset: \[0\]](#)
- [Camera ISP Timing CTRL Internally-Generated cam\\_global\\_reset-Based Control-Signal Generation: \[1\]](#)
- [Camera ISP Timing CTRL STROBE and PRESTROBE Signal Generation for Red-Eye Removal: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP Registers Summary: \[3\]](#)
- [Camera ISP Register Description: \[4\]](#)

**Table 6-116. TCTRL\_SHUT\_LENGTH**

| <b>Address Offset</b>   | 0x0000 006C                                                                                                                 |                                                                                                                                                                                                                                                                                                                      |                 |        |  |  |  |        |  |  |  |  |  |  |  |  |      |          |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------|--|--|--|--------|--|--|--|--|--|--|--|--|------|----------|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | See <a href="#">Table 6-81</a>                                                                                              |                                                                                                                                                                                                                                                                                                                      |                 |        |  |  |  |        |  |  |  |  |  |  |  |  |      |          |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | TIMING CONTROL - SHUTTER LENGTH REGISTER<br>This register is used by the TIMING CTRL module to generate the SHUTTER signal. |                                                                                                                                                                                                                                                                                                                      |                 |        |  |  |  |        |  |  |  |  |  |  |  |  |      |          |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                          |                                                                                                                                                                                                                                                                                                                      |                 |        |  |  |  |        |  |  |  |  |  |  |  |  |      |          |  |  |  |  |  |  |  |  |  |
| 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 | LENGTH |  |  |  |        |  |  |  |  |  |  |  |  |      |          |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                                                                                                             |                                                                                                                                                                                                                                                                                                                      |                 |        |  |  |  | LENGTH |  |  |  |  |  |  |  |  |      |          |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                                                                                  | Description                                                                                                                                                                                                                                                                                                          |                 |        |  |  |  |        |  |  |  |  |  |  |  |  | Type | Reset    |  |  |  |  |  |  |  |  |  |
| 31:24                   | RESERVED                                                                                                                    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                   |                 |        |  |  |  |        |  |  |  |  |  |  |  |  | R    | 0x00     |  |  |  |  |  |  |  |  |  |
| 23:0                    | LENGTH                                                                                                                      | Sets the length of the CAM.SHUTTER signal assertion in cycles of the CNTCLK clock. The CNTCLK frequency is generated with the <a href="#">TCTRL_CTRL.DIVC</a> bit field. After signal assertion, the <a href="#">TCTRL_CTRL.SHUTEN</a> bit is automatically cleared. The possible values are 0 to $2^{24}-1$ cycles. |                 |        |  |  |  |        |  |  |  |  |  |  |  |  | RW   | 0x000000 |  |  |  |  |  |  |  |  |  |

**Table 6-117. Register Call Summary for Register TCTRL\_SHUT\_LENGTH**

Camera ISP Basic Programming Model

- [Camera ISP Timing CTRL Vertical Synchro-Based Control-Signal Generation or Externally-Generated cam\\_global\\_reset: \[0\]](#)
- [Camera ISP Timing CTRL Internally-Generated cam\\_global\\_reset-Based Control-Signal Generation: \[1\]](#)

**Table 6-117. Register Call Summary for Register TCTRL\_SHUT\_LENGTH (continued)**

Camera ISP Register Manual

- Camera ISP Registers Summary: [2]
- Camera ISP Register Description: [3]

## 6.6.2 Camera ISP CBUFF Registers

### 6.6.2.1 Camera ISP CBUFF Register Summary

**Table 6-118. ISP\_CBUFF Register Summary**

| Register Name                    | Type | Register Width (Bits) | Address Offset                         | Physical Address                       |
|----------------------------------|------|-----------------------|----------------------------------------|----------------------------------------|
| CBUFF_REVISION                   | R    | 32                    | 0x0000 0000                            | 0x480B C100                            |
| CBUFF_SYSCONFIG                  | RW   | 32                    | 0x0000 0010                            | 0x480B C110                            |
| CBUFF_SYSSTATUS                  | R    | 32                    | 0x0000 0014                            | 0x480B C114                            |
| CBUFF_IRQSTATUS                  | RW   | 32                    | 0x0000 0018                            | 0x480B C118                            |
| CBUFF IRQENABLE                  | RW   | 32                    | 0x0000 001C                            | 0x480B C11C                            |
| CBUFFx_CTRL <sup>(1)</sup>       | RW   | 32                    | 0x0000 0020 + (x * 0x4)                | 0x480B C120 + (x * 0x4)                |
| CBUFFx_STATUS <sup>(1)</sup>     | R    | 32                    | 0x0000 0030 + (x * 0x4)                | 0x480B C130 + (x * 0x4)                |
| CBUFFx_START <sup>(1)</sup>      | RW   | 32                    | 0x0000 0040 + (x * 0x4)                | 0x480B C140 + (x * 0x4)                |
| CBUFFx_END <sup>(1)</sup>        | RW   | 32                    | 0x0000 0050 + (x * 0x4)                | 0x480B C150 + (x * 0x4)                |
| CBUFFx_WINDOWSIZE <sup>(1)</sup> | RW   | 32                    | 0x0000 0060 + (x * 0x4)                | 0x480B C160 + (x * 0x4)                |
| CBUFFx_THRESHOLD <sup>(1)</sup>  | RW   | 32                    | 0x0000 0070 + (x * 0x4)                | 0x480B C170 + (x * 0x4)                |
| CBUFFx_ADDRy <sup>(1) (2)</sup>  | RW   | 32                    | 0x0000 0080 + (x * 0x4) +<br>(y * 0x4) | 0x480B C180 + (x * 0x4)<br>+ (y * 0x4) |
| CBUFF_VRFB_CTRL                  | RW   | 32                    | 0x0000 00C0                            | 0x480B C1C0                            |

<sup>(1)</sup> x= 0 to 1<sup>(2)</sup> y= 0 to 15

### 6.6.2.2 Camera ISP CBUF Register Description

**Table 6-119. CBUFF\_REVISION**

|                  |                                             |          |           |
|------------------|---------------------------------------------|----------|-----------|
| Address Offset   | 0x0000 0000                                 | Instance | ISP_CBUFF |
| Physical Address | 0x480B C100                                 |          |           |
| Description      | This register contains the IP revision code |          |           |
| Type             | R                                           |          |           |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | REV |   |   |   |   |   |   |

| Bits | Field Name | Description                                                 | Type | Reset            |
|------|------------|-------------------------------------------------------------|------|------------------|
| 31:8 | RESERVED   | Write 0s for future compatibility. Read returns 0.          | R    | 0x000000         |
| 7:0  | REV        | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision | R    | TI internal data |

**Table 6-120. Register Call Summary for Register CBUFF\_REVISION**

- Camera ISP Register Manual
- [Camera ISP CBUFF Register Summary: \[0\]](#)

**Table 6-121. CBUFF\_SYSCONFIG**

|                       |                                                                                    |                         |             |                 |           |
|-----------------------|------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-----------|
| <b>Address Offset</b> | 0x0000 0010                                                                        | <b>Physical Address</b> | 0x480B C110 | <b>Instance</b> | ISP_CBUFF |
| <b>Description</b>    | This register allows controlling various parameters of the Interconnect interface. |                         |             |                 |           |
| <b>Type</b>           | RW                                                                                 |                         |             |                 |           |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                           | Type | Reset      |
|------|------------|-------------------------------------------------------|------|------------|
| 31:0 | RESERVED   | Write 0s for future compatibility. Reads return zero. | RW   | 0x00000000 |

**Table 6-122. Register Call Summary for Register CBUFF\_SYSCONFIG**

- Camera ISP Register Manual
- [Camera ISP CBUFF Register Summary: \[0\]](#)

**Table 6-123. CBUFF\_SYSSTATUS**

|                       |                                                                                                       |                         |             |                 |           |
|-----------------------|-------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-----------|
| <b>Address Offset</b> | 0x0000 0014                                                                                           | <b>Physical Address</b> | 0x480B C114 | <b>Instance</b> | ISP_CBUFF |
| <b>Description</b>    | The register provides status information about the module, excluding the interrupt status information |                         |             |                 |           |
| <b>Type</b>           | R                                                                                                     |                         |             |                 |           |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                     | Type | Reset      |
|------|------------|-----------------------------------------------------------------|------|------------|
| 31:0 | RESERVED   | Reserved for module-specific status information. Reads return 0 | R    | 0x00000000 |

**Table 6-124. Register Call Summary for Register CBUFF\_SYSSTATUS**

- Camera ISP Register Manual
- [Camera ISP CBUFF Register Summary: \[0\]](#)

**Table 6-125. CBUFF\_IRQSTATUS**

|                       |                                                                                                                     |                         |             |                 |           |
|-----------------------|---------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-----------|
| <b>Address Offset</b> | 0x0000 0018                                                                                                         | <b>Physical Address</b> | 0x480B C118 | <b>Instance</b> | ISP_CBUFF |
| <b>Description</b>    | The interrupt status register regroups all the status of the module internal events that can generate an interrupt. |                         |             |                 |           |
| <b>Type</b>           | RW                                                                                                                  |                         |             |                 |           |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                |                    |                  |                |                    |                  |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------------|--------------------|------------------|----------------|--------------------|------------------|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | IRQ_CBUFF1_OVR | IRQ_CBUFF1_INVALID | IRQ_CBUFF1_READY | IRQ_CBUFF0_OVR | IRQ_CBUFF0_INVALID | IRQ_CBUFF0_READY |   |

| Bits | Field Name         | Description                                                                                                                                                                            | Type           | Reset     |
|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------|
| 31:6 | RESERVED           | Write 0s for future compatibility. Reads return zero.                                                                                                                                  | RW             | 0x0000000 |
| 5    | IRQ_CBUFF1_OVR     | Buffer overflow event.<br>0x0: No done interrupt pending (r); Status unchanged (w).<br>0x1: Done interrupt pending (r); Status bit cleared (w).                                        | R/W/1to<br>Clr | 0x0       |
| 4    | IRQ_CBUFF1_INVALID | Invalid access.<br>0x0: No done interrupt pending (r); Status unchanged (w).<br>0x1: Done interrupt pending (r); Status bit cleared (w).                                               | R/W/1to<br>Clr | 0x0       |
| 3    | IRQ_CBUFF1_READY   | The CPUW1 physical buffer is ready to be accessed by the CPU.<br>0x0: No done interrupt pending (r); Status unchanged (w).<br>0x1: Done interrupt pending (r); Status bit cleared (w). | R/W/1to<br>Clr | 0x0       |
| 2    | IRQ_CBUFF0_OVR     | Buffer overflow event.<br>0x0: No done interrupt pending (r); Status unchanged (w).<br>0x1: Done interrupt pending (r); Status bit cleared (w).                                        | R/W/1to<br>Clr | 0x0       |
| 1    | IRQ_CBUFF0_INVALID | Invalid access.<br>0x0: No YUV buffer done interrupt pending (r); Status unchanged (w).<br>0x1: YUV buffer done interrupt pending (r); Status bit cleared (w).                         | R/W/1to<br>Clr | 0x0       |
| 0    | IRQ_CBUFF0_READY   | The CPUW0 physical buffer is ready to be accessed by the CPU.<br>0x0: No done interrupt pending (r); Status unchanged (w).<br>0x1: Done interrupt pending (r); Status bit cleared (w). | R/W/1to<br>Clr | 0x0       |

**Table 6-126. Register Call Summary for Register CBUFF\_IRQSTATUS**

## Camera ISP Integration

- Camera ISP Interrupt Requests: [0] [1] [2] [3] [4] [5] [6]

## Camera ISP Functional Description

- Camera ISP Circular Buffer Window Management: [7] [8] [9]

## Camera ISP Basic Programming Model

- Camera ISP CBUFF Interrupts: [10] [11]
- Camera ISP CBUFF Status Checking: [12]

## Camera ISP Register Manual

- Camera ISP CBUFF Register Summary: [13]

**Table 6-127. CBUFF\_IRQENABLE**

|                         |                                                                                                                              |                       |                 |  |  |                |                    |                  |                |                    |                  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|----------------|--------------------|------------------|----------------|--------------------|------------------|
| <b>Address Offset</b>   | 0x0000 001C                                                                                                                  |                       |                 |  |  |                |                    |                  |                |                    |                  |
| <b>Physical Address</b> | 0x480B C11C                                                                                                                  | <b>Instance</b>       | ISP_CBUFF       |  |  |                |                    |                  |                |                    |                  |
| <b>Description</b>      | The interrupt enable register allows to enable/disable the module internal sources of interrupt, on an event-by-event basis. |                       |                 |  |  |                |                    |                  |                |                    |                  |
| <b>Type</b>             | RW                                                                                                                           |                       |                 |  |  |                |                    |                  |                |                    |                  |
| 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 |  |  |                |                    |                  |                |                    |                  |
| RESERVED                |                                                                                                                              |                       |                 |  |  |                |                    |                  |                |                    |                  |
|                         |                                                                                                                              |                       |                 |  |  | IRQ_CBUFF1_OVR | IRQ_CBUFF1_INVALID | IRQ_CBUFF1_READY | IRQ_CBUFF0_OVR | IRQ_CBUFF0_INVALID | IRQ_CBUFF0_READY |

| <b>Bits</b> | <b>Field Name</b>  | <b>Description</b>                                                                                                             | <b>Type</b> | <b>Reset</b> |
|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:6        | RESERVED           | Write 0s for future compatibility. Reads return zero.                                                                          | RW          | 0x00000000   |
| 5           | IRQ_CBUFF1_OVR     | Buffer overflow event.<br><br>0x0: interrupt is masked<br><br>0x1: Interrupt is enabled                                        | RW          | 0x0          |
| 4           | IRQ_CBUFF1_INVALID | Invalid access.<br><br>0x0: interrupt is masked<br><br>0x1: Interrupt is enabled                                               | RW          | 0x0          |
| 3           | IRQ_CBUFF1_READY   | The CPUW1 physical buffer is ready to be accessed by the CPU.<br><br>0x0: interrupt is masked<br><br>0x1: Interrupt is enabled | RW          | 0x0          |
| 2           | IRQ_CBUFF0_OVR     | Buffer overflow event.<br><br>0x0: interrupt is masked<br><br>0x1: Interrupt is enabled                                        | RW          | 0x0          |
| 1           | IRQ_CBUFF0_INVALID | Invalid access.<br><br>0x0: interrupt is masked<br><br>0x1: Interrupt is enabled                                               | RW          | 0x0          |
| 0           | IRQ_CBUFF0_READY   | The CPUW0 physical buffer is ready to be accessed by the CPU.<br><br>0x0: interrupt is masked<br><br>0x1: Interrupt is enabled | RW          | 0x0          |

**Table 6-128. Register Call Summary for Register CBUFF\_IRQENABLE**

- Camera ISP Interrupt Requests: [0] [1] [2] [3] [4] [5]

- Camera ISP Register Manual

**Table 6-129. CBUFFx\_CTRL**

|                         |                                    |                 |            |
|-------------------------|------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0020 + (x * 0x4)            | <b>Index</b>    | x = 0 to 1 |
| <b>Physical Address</b> | 0x480B C120 + (x * 0x4)            | <b>Instance</b> | ISP_CBUFF  |
| <b>Description</b>      | Circular buffer x control register |                 |            |
| <b>Type</b>             | RW                                 |                 |            |



| Bits  | Field Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset    |
|-------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:10 | RESERVED         | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0x000000 |
| 9:8   | WCOUNT           | Window count<br><br>0x0: 2 windows<br>0x1: 4 windows<br>0x2: 8 windows<br>0x3: 16 windows                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0x0      |
| 7:4   | BCF              | This register controls the bandwidth control feedback loop output.<br>Functionality depends on subsystem integration.<br>0: Control loop disabled. Data read from memory is free running.<br>1-15: The control feedback loop signal is asserted when the window count available for ISP is below () the threshold.<br>In other words at least (=) BCF windows are available for ISP access when this signal is released.                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x0      |
| 3     | ALLOW_NW_EQ_CPUW | Allow NW=CPUW. Better buffer utilization when ISP does not use the next write window.<br><br>0x0: When the CPUW and the NW pointers designate the same window and accesses are effectively performed to those windows an overflow event occurs.<br>This happens when<br>- the CPU has received an READY IRQ for that window indicating that it can be accessed and<br>- the ISP performs an access to that window. ISP accesses are tracked based on OCPI activity.<br><br>0x1: When the CPUW and the CW pointers designate the same window and accesses are effectively performed to those windows an overflow event occurs.<br>This happens when<br>- the CPU has received an READY IRQ for that window indicating that it can be accessed and<br>- the ISP performs an access to that window. ISP accesses are tracked based on OCPI activity. | RW   | 0x0      |
| 2     | DONE             | Write this bit to 1 to indicate the CPU has finished processing its physical buffer.<br>This bit is automatically cleared by hardware, reads always return 0.<br><br>0x0: No effect.<br>0x1: The CPU has completely processed the CPUW physical buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | W    | 0x0      |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | RWMODE     | Selects read or write mode<br><br>0x0: Write mode. HW writes and CPU reads the physical space. CPU accesses are out of CBUFF module's scope, therefore only writes are permitted between CBUFF0_START and CBUFF0_END.<br><br>0x1: Read mode. HW reads and CPU writes the physical space. CPU accesses are out of CBUFF module's scope; therefore only reads are permitted between CBUFF0_START and CBUFF0_END.                                                                                                           | RW   | 0x0   |
| 0    | ENABLE     | Enable/disable<br><br>0x0: Disables the circular buffer 0; this resets the internal state of circular buffer 0. All accesses received on OCPI are transmitted to OCPO without modification. Disabling the module takes effect immediately. It is SW responsibility to ensure that no more accesses to CBUFF0 are outstanding before disabling the module. Otherwise memory corruption may occur.<br><br>0x1: Enable the circular buffer 0. All accesses between CBUFF0_START and CBUFF0_END are processed by the module. | RW   | 0x0   |

**Table 6-130. Register Call Summary for Register CBUFFx\_CTRL**
**Camera ISP Integration**

- [Camera ISP Interrupt Requests: \[0\]](#)

**Camera ISP Functional Description**

- [Camera ISP Circular Buffer Bandwidth Control Feedback Loop: \[1\] \[2\]](#)
- [Camera ISP Circular Buffer Window Management: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\]](#)
- [Camera ISP Circular Buffer CPU Interaction: \[12\] \[13\]](#)

**Camera ISP Basic Programming Model**

- [Camera ISP CBUFF Register Setup: \[18\] \[19\] \[20\] \[21\]](#)
- [Camera ISP CBUFF Register Accessibility During Frame Processing: \[22\] \[23\]](#)
- [Camera ISP CBUFF Operations: \[24\] \[25\] \[26\]](#)

**Camera ISP Register Manual**

- [Camera ISP CBUFF Register Summary: \[27\]](#)

**Table 6-131. CBUFFx\_STATUS**

|                         |                                                                 |                       |                           |
|-------------------------|-----------------------------------------------------------------|-----------------------|---------------------------|
| <b>Address Offset</b>   | 0x0000 0030 + (x * 0x4)                                         | <b>Index</b>          | x = 0 to 1                |
| <b>Physical Address</b> | 0x480B C130 + (x * 0x4)                                         | <b>Instance</b>       | ISP_CBUFF                 |
| <b>Description</b>      | Threshold value used to check if the CW or NW windows are full. |                       |                           |
| <b>Type</b>             | R                                                               |                       |                           |
| 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           |
| RESERVED                | RESERVED                                                        | NW                    | RESERVED CW RESERVED CPUW |

| Bits  | Field Name | Description                                                                      | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------|------|-------|
| 31:24 | RESERVED   | Write 0s for future compatibility. Read returns 0.                               | R    | 0x00  |
| 23:20 | RESERVED   | Write 0s for future compatibility. Read returns 0.                               | R    | 0x0   |
| 19:16 | NW         | Next window number.<br>Valid values depend on the CBUFF_CTRL.WCOUNT register.    | R    | 0x1   |
| 15:12 | RESERVED   | Write 0s for future compatibility. Read returns 0.                               | R    | 0x0   |
| 11:8  | CW         | Current window number.<br>Valid values depend on the CBUFF_CTRL.WCOUNT register. | R    | 0x0   |
| 7:4   | RESERVED   | Write 0s for future compatibility. Read returns 0.                               | R    | 0x0   |

| Bits | Field Name | Description                                                                          | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------|------|-------|
| 3:0  | CPUW       | Current CPU window number.<br>Valid values depend on the CBUFF_CTRL.WCOUNT register. | R    | 0x0   |

**Table 6-132. Register Call Summary for Register CBUFFx\_STATUS**

Camera ISP Functional Description

- Camera ISP Circular Buffer Window Management: [0] [1] [2]

Camera ISP Basic Programming Model

- Camera ISP CBUFF Status Checking: [3]
- Camera ISP CBUFF Operations: [4] [5]

Camera ISP Register Manual

- Camera ISP CBUFF Register Summary: [6]

**Table 6-133. CBUFFx\_START**

|                         |                                                                                                                                         |                       |                 |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0040 + (x * 0x4)                                                                                                                 | <b>Index</b>          | x = 0 to 1      |
| <b>Physical Address</b> | 0x480B C140 + (x * 0x4)                                                                                                                 | <b>Instance</b>       | ISP_CBUFF       |
| <b>Description</b>      | Start address of the virtual space managed by circular buffer x. Start address of the 1st physical buffer managed by circular buffer x. |                       |                 |
| <b>Type</b>             | RW                                                                                                                                      |                       |                 |
| 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 |
| ADDR                    |                                                                                                                                         |                       | RESERVED        |

| Bits | Field Name | Description                                            | Type | Reset      |
|------|------------|--------------------------------------------------------|------|------------|
| 31:3 | ADDR       | Address, in 64 bit words.                              | RW   | 0x00000000 |
| 2:0  | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x0        |

**Table 6-134. Register Call Summary for Register CBUFFx\_START**

Camera ISP Functional Description

- Camera ISP Circular Buffer Window Management: [0] [1] [2] [3] [4] [5]

Camera ISP Basic Programming Model

- Camera ISP CBUFF Register Setup: [6]
- Camera ISP CBUFF Operations: [7]

Camera ISP Register Manual

- Camera ISP CBUFF Register Summary: [8]

**Table 6-135. CBUFFx\_END**

|                         |                                                                |                 |            |
|-------------------------|----------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0050 + (x * 0x4)                                        | <b>Index</b>    | x = 0 to 1 |
| <b>Physical Address</b> | 0x480B C150 + (x * 0x4)                                        | <b>Instance</b> | ISP_CBUFF  |
| <b>Description</b>      | End address of the virtual space managed by circular buffer x. |                 |            |
| <b>Type</b>             | RW                                                             |                 |            |

  

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| ADDR                    |                         |                       | RESERVED        |

| Bits | Field Name | Description                                            | Type | Reset      |
|------|------------|--------------------------------------------------------|------|------------|
| 31:3 | ADDR       | Address, in 64 bit words.                              | RW   | 0x00000000 |
| 2:0  | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x0        |

**Table 6-136. Register Call Summary for Register CBUFFx\_END**

Camera ISP Functional Description

- [Camera ISP Circular Buffer Window Management: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CBUFF Register Setup: \[9\]](#)

Camera ISP Register Manual

- [Camera ISP CBUFF Register Summary: \[10\]](#)

**Table 6-137. CBUFFx\_WINDOWSIZE**

|                         |                          |                 |            |
|-------------------------|--------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0060 + (x * 0x4)  | <b>Index</b>    | x = 0 to 1 |
| <b>Physical Address</b> | 0x480B C160 + (x * 0x4)  | <b>Instance</b> | ISP_CBUFF  |
| <b>Description</b>      | Defines the window size. |                 |            |
| <b>Type</b>             | RW                       |                 |            |

  

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | SIZE                    |                       |                 |

| Bits  | Field Name | Description                                            | Type | Reset    |
|-------|------------|--------------------------------------------------------|------|----------|
| 31:24 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x00     |
| 23:3  | SIZE       | Size, in 64 bit words.                                 | RW   | 0x000000 |
| 2:0   | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x0      |

**Table 6-138. Register Call Summary for Register CBUFFx\_WINDOWSIZE**

Camera ISP Functional Description

- [Camera ISP Circular Buffer Window Management: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CBUFF Register Setup: \[10\] \[11\]](#)
- [Camera ISP CBUFF Operations: \[12\]](#)

**Table 6-138. Register Call Summary for Register CBUFFx\_WINDOWSIZE (continued)**

Camera ISP Register Manual

- Camera ISP CBUFF Register Summary: [13]

**Table 6-139. CBUFFx\_THRESHOLD**

|                         |                                                          |                 |            |
|-------------------------|----------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0070 + (x * 0x4)                                  | <b>Index</b>    | x = 0 to 1 |
| <b>Physical Address</b> | 0x480B C170 + (x * 0x4)                                  | <b>Instance</b> | ISP_CBUFF  |
| <b>Description</b>      | Threshold value used to check if a write window is full. |                 |            |
| <b>Type</b>             | RW                                                       |                 |            |

|                         |                         |                       |                 |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|
| 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 |  |
| RESERVED                |                         | THRESHOLD             |                 |  |

| Bits  | Field Name | Description                                            | Type | Reset    |
|-------|------------|--------------------------------------------------------|------|----------|
| 31:24 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x00     |
| 23:0  | THRESHOLD  | Threshold value, in bytes.                             | RW   | 0x000000 |

**Table 6-140. Register Call Summary for Register CBUFFx\_THRESHOLD**

Camera ISP Functional Description

- Camera ISP Circular Buffer Window Management: [0] [1] [2] [3] [4]

Camera ISP Basic Programming Model

- Camera ISP CBUFF Register Setup: [5] [6]

Camera ISP Register Manual

- Camera ISP CBUFF Register Summary: [7]

**Table 6-141. CBUFFx\_ADDRy**

|                         |                                                                                                                                                                                                   |                 |                        |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------|
| <b>Address Offset</b>   | 0x0000 0080 + (x * 0x4) + (y * 0x4)                                                                                                                                                               | <b>Index</b>    | x = 0 to 1 y = 0 to 15 |
| <b>Physical Address</b> | 0x480B C180 + (x * 0x4) + (y * 0x4)                                                                                                                                                               | <b>Instance</b> | ISP_CBUFF              |
| <b>Description</b>      | Start address of the physical buffer of the circular buffer context 0. This register only exists as RW for CBUFF 0. Fragmentation support is enabled for only CBUFF0_ADDR0 through CBUFF0_ADDR15. |                 |                        |
| <b>Type</b>             | RW                                                                                                                                                                                                |                 |                        |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| ADDR                    |                         |                       | RESERVED        |

| Bits | Field Name | Description                                        | Type | Reset      |
|------|------------|----------------------------------------------------|------|------------|
| 31:4 | ADDR       | Address, in 128 bit words.                         | RW   | 0x00000000 |
| 3:0  | RESERVED   | Write 0s for future compatibility. Read returns 0. | R    | 0x0        |

**Table 6-142. Register Call Summary for Register CBUFFx\_ADDRy**

Camera ISP Functional Description

- Camera ISP Circular Buffer Bandwidth Control Feedback Loop: [0] [1]

Camera ISP Basic Programming Model

- Camera ISP CBUFF Operations: [2]

Camera ISP Register Manual

- Camera ISP CBUFF Register Summary: [3]

**Table 6-143. CBUFF\_VRFB\_CTRL**

| <b>Address Offset</b>   | 0x0000 00C0                            |                                                                                                                                                                              |                 |         |          |              |        |       |         |          |              |        |       |         |      |       |
|-------------------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------|----------|--------------|--------|-------|---------|----------|--------------|--------|-------|---------|------|-------|
| <b>Physical Address</b> | 0x480B C1C0                            |                                                                                                                                                                              |                 |         |          |              |        |       |         |          |              |        |       |         |      |       |
| <b>Description</b>      | VRFB context grouping control register |                                                                                                                                                                              |                 |         |          |              |        |       |         |          |              |        |       |         |      |       |
| <b>Type</b>             | RW                                     |                                                                                                                                                                              |                 |         |          |              |        |       |         |          |              |        |       |         |      |       |
| 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 |         |          |              |        |       |         |          |              |        |       |         |      |       |
| RESERVED                | ORIENTATION2                           | WIDTH2                                                                                                                                                                       | BASE2           | ENABLE2 | RESERVED | ORIENTATION1 | WIDTH1 | BASE1 | ENABLE1 | RESERVED | ORIENTATION0 | WIDTH0 | BASE0 | ENABLE0 |      |       |
| Bits                    | Field Name                             | Description                                                                                                                                                                  |                 |         |          |              |        |       |         |          |              |        |       |         | Type | Reset |
| 31:29                   | RESERVED                               | Write 0s for future compatibility. Read returns 0.                                                                                                                           |                 |         |          |              |        |       |         |          |              |        |       |         | R    | 0x0   |
| 28:27                   | ORIENTATION2                           | Orientation<br>0x0: 0 degrees<br>0x1: 90 degrees<br>0x2: 180 degrees<br>0x3: 270 degrees                                                                                     |                 |         |          |              |        |       |         |          |              |        |       |         | RW   | 0x0   |
| 26:25                   | WIDTH2                                 | Data width<br>0x0: 8 bits<br>0x1: 16 bits<br>0x2: 32 bits<br>0x3: Reserved                                                                                                   |                 |         |          |              |        |       |         |          |              |        |       |         | RW   | 0x0   |
| 24:21                   | BASE2                                  | Region being translated when translation is enabled.<br><a href="#">CBUFF_VRFB_CTRL.BASEEx*256 Mega Bytes to</a><br><a href="#">CBUFF_VRFB_CTRL.BASEEx+1)*256 Mega Bytes</a> |                 |         |          |              |        |       |         |          |              |        |       |         | RW   | 0x0   |
| 20                      | ENABLE2                                | Enable / disable VRFB context grouping.<br>Sw shall not change this register when there's active traffic to the translated region<br>0x0: Disabled<br>0x1: Enabled           |                 |         |          |              |        |       |         |          |              |        |       |         | RW   | 0     |
| 19                      | RESERVED                               | Write 0s for future compatibility. Read returns 0.                                                                                                                           |                 |         |          |              |        |       |         |          |              |        |       |         | R    | 0     |
| 18:17                   | ORIENTATION1                           | Orientation<br>0x0: 0 degrees<br>0x1: 90 degrees<br>0x2: 180 degrees<br>0x3: 270 degrees                                                                                     |                 |         |          |              |        |       |         |          |              |        |       |         | RW   | 0x0   |
| 16:15                   | WIDTH1                                 | Data width<br>0x0: 8 bits<br>0x1: 16 bits<br>0x2: 32 bits<br>0x3: Reserved                                                                                                   |                 |         |          |              |        |       |         |          |              |        |       |         | RW   | 0x0   |
| 14:11                   | BASE1                                  | Region being translated when translation is enabled.<br><a href="#">CBUFF_VRFB_CTRL.BASEEx*256 Mega Bytes to</a><br><a href="#">CBUFF_VRFB_CTRL.BASEEx+1)*256 Mega Bytes</a> |                 |         |          |              |        |       |         |          |              |        |       |         | RW   | 0x0   |
| 10                      | ENABLE1                                | Enable / disable VRFB context grouping.<br>Sw shall not change this register when there's active traffic to the translated region<br>0x0: Disabled<br>0x1: Enabled           |                 |         |          |              |        |       |         |          |              |        |       |         | RW   | 0     |

| Bits | Field Name   | Description                                                                                                                                                        | Type | Reset |
|------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 9    | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                 | R    | 0     |
| 8:7  | ORIENTATION0 | Orientation<br>0x0: 0 degrees<br>0x1: 90 degrees<br>0x2: 180 degrees<br>0x3: 270 degrees                                                                           | RW   | 0x0   |
| 6:5  | WIDTH0       | 0x0: 8 bits<br>0x1: 16 bits<br>0x2: 32 bits<br>0x3: Reserved                                                                                                       | RW   | 0x0   |
| 4:1  | BASE0        | Region being translated when translation is enabled.<br><b>CBUFF_VRFB_CTRL.BASEEx*256 Mega Bytes to<br/>CBUFF_VRFB_CTRL.BASEEx+1)*256 Mega Bytes</b>               | RW   | 0x0   |
| 0    | ENABLE0      | Enable / disable VRFB context grouping.<br>Sw shall not change this register when there's active traffic to the translated region<br>0x0: Disabled<br>0x1: Enabled | RW   | 0     |

**Table 6-144. Register Call Summary for Register CBUFF\_VRFB\_CTRL**

Camera ISP Functional Description

- Camera ISP Circular Buffer Bandwidth Control Feedback Loop: [0] [1] [2] [3] [4] [5]

Camera ISP Register Manual

- Camera ISP CBUFF Register Summary: [6]
- Camera ISP CBUF Register Description: [7] [8] [9] [10] [11] [12]

### 6.6.3 Camera ISP CCP2 Registers

#### 6.6.3.1 Camera ISP CCP2 Register Summary

**Table 6-145. ISP\_CCP2 Register Summary**

| Register Name       | Type      | Register Width (Bits) | Address Offset           | Physical Address         |
|---------------------|-----------|-----------------------|--------------------------|--------------------------|
| CCP2_REVISION       | R         | 32                    | 0x0000 0000              | 0x480B C400              |
| CCP2_SYSCONFIG      | RW        | 32                    | 0x0000 0004              | 0x480B C404              |
| CCP2_SYSSTATUS      | R         | 32                    | 0x0000 0008              | 0x480B C408              |
| CCP2_LC01_IRQENABLE | RW        | 32                    | 0x0000 000C              | 0x480B C40C              |
| CCP2_LC01_IRQSTATUS | RW 1toClr | 32                    | 0x0000 0010              | 0x480B C410              |
| CCP2_LC23_IRQENABLE | RW        | 32                    | 0x0000 0014              | 0x480B C414              |
| CCP2_LC23_IRQSTATUS | RW 1toClr | 32                    | 0x0000 0018              | 0x480B C418              |
| CCP2_LCM_IRQENABLE  | RW        | 32                    | 0x0000 002C              | 0x480B C42C              |
| CCP2_LCM_IRQSTATUS  | RW 1toClr | 32                    | 0x0000 0030              | 0x480B C430              |
| CCP2_CTRL           | RW        | 32                    | 0x0000 0040              | 0x480B C440              |
| CCP2_DBG            | W         | 32                    | 0x0000 0044              | 0x480B C444              |
| CCP2_GNQ            | R         | 32                    | 0x0000 0048              | 0x480B C448              |
| CCP2_CTRL1          | R         | 32                    | 0x0000 004C              | 0x480B C44C              |
| CCP2_LCx_CTRL       | RW        | 32                    | 0x0000 0050 + (x * 0x30) | 0x480B C450 + (x * 0x30) |
| CCP2_LCx_CODE       | RW        | 32                    | 0x0000 0054 + (x * 0x30) | 0x480B C454 + (x * 0x30) |
| CCP2_LCx_STAT_START | RW        | 32                    | 0x0000 0058 + (x * 0x30) | 0x480B C458 + (x * 0x30) |
| CCP2_LCx_STAT_SIZE  | RW        | 32                    | 0x0000 005C + (x * 0x30) | 0x480B C45C + (x * 0x30) |

**Table 6-145. ISP\_CCP2 Register Summary (continued)**

| Register Name          | Type | Register Width (Bits) | Address Offset           | Physical Address         |
|------------------------|------|-----------------------|--------------------------|--------------------------|
| CCP2_LCx_SOF_ADDR      | RW   | 32                    | 0x0000 0060 + (x * 0x30) | 0x480B C460 + (x * 0x30) |
| CCP2_LCx_EOF_ADDR      | RW   | 32                    | 0x0000 0064 + (x * 0x30) | 0x480B C464 + (x * 0x30) |
| CCP2_LCx_DAT_START     | RW   | 32                    | 0x0000 0068 + (x * 0x30) | 0x480B C468 + (x * 0x30) |
| CCP2_LCx_DAT_SIZE      | RW   | 32                    | 0x0000 006C + (x * 0x30) | 0x480B C46C + (x * 0x30) |
| CCP2_LCx_DAT_PING_ADDR | RW   | 32                    | 0x0000 0070 + (x * 0x30) | 0x480B C470 + (x * 0x30) |
| CCP2_LCx_DAT_PONG_ADDR | RW   | 32                    | 0x0000 0074 + (x * 0x30) | 0x480B C474 + (x * 0x30) |
| CCP2_LCx_DAT_OFST      | RW   | 32                    | 0x0000 0078 + (x * 0x30) | 0x480B C478 + (x * 0x30) |
| CCP2_LCM_CTRL          | RW   | 32                    | 0x0000 01D0              | 0x480B C5D0              |
| CCP2_LCM_VSIZE         | RW   | 32                    | 0x0000 01D4              | 0x480B C5D4              |
| CCP2_LCM_HSIZE         | RW   | 32                    | 0x0000 01D8              | 0x480B C5D8              |
| CCP2_LCM_PREFETCH      | RW   | 32                    | 0x0000 01DC              | 0x480B C5DC              |
| CCP2_LCM_SRC_ADDR      | RW   | 32                    | 0x0000 01E0              | 0x480B C5E0              |
| CCP2_LCM_SRC_OFST      | RW   | 32                    | 0x0000 01E4              | 0x480B C5E4              |
| CCP2_LCM_DST_ADDR      | RW   | 32                    | 0x0000 01E8              | 0x480B C5E8              |
| CCP2_LCM_DST_OFST      | RW   | 32                    | 0x0000 01EC              | 0x480B C5EC              |

### 6.6.3.2 Camera ISP CCP2 Register Description

**Table 6-146. CCP2\_REVISION**

|                         |                                                                                                                                                  |                 |          |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 0000                                                                                                                                      | <b>Instance</b> | ISP_CCP2 |
| <b>Physical Address</b> | See <a href="#">Table 6-145</a>                                                                                                                  |                 |          |
| <b>Description</b>      | MODULE REVISION<br>This register contains the IP revision code in binary coded digital. For example, 0x01 = revision 0.1 and 0x21 = revision 2.1 |                 |          |
| <b>Type</b>             | R                                                                                                                                                |                 |          |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REV |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                 | Type | Reset            |
|------|------------|-------------------------------------------------------------|------|------------------|
| 31:8 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.     | R    | 0x000000         |
| 7:0  | REV        | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision | R    | TI internal data |

**Table 6-147. Register Call Summary for Register CCP2\_REVISION**

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[0\]](#)

**Table 6-148. CCP2\_SYSCONFIG**

|                                                                                    |                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                        |             |              |
|------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| <b>Address Offset</b>                                                              | 0x0000 0004                                                                                              | <b>Instance</b>                                                                                                                                                                                                                                                                                                                                                        | ISP_CCP2    |              |
| <b>Physical Address</b>                                                            | 0x480B C404                                                                                              |                                                                                                                                                                                                                                                                                                                                                                        |             |              |
| <b>Description</b>                                                                 | SYSTEM CONFIGURATION REGISTER<br>This register is the Interconnect-socket system configuration register. |                                                                                                                                                                                                                                                                                                                                                                        |             |              |
| <b>Type</b>                                                                        | RW                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                        |             |              |
|  |                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                        |             |              |
| <b>Bits</b>                                                                        | <b>Field Name</b>                                                                                        | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
| 31:14                                                                              | RESERVED                                                                                                 | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                     | RW          | 0x00000      |
| 13:12                                                                              | MSTANDBY_MODE                                                                                            | <p>Sets the behavior of the master port power management signals</p> <p>0x0: Force-standby. MStandby is asserted only when the module is disabled.</p> <p>0x1: No-standby. MStandby is never asserted.</p> <p>0x2: Smart-standby: MStandby is asserted based on the activity of the module. The module tries to go to standby during the vertical blanking period.</p> | RW          | 0x0          |
| 11:2                                                                               | RESERVED                                                                                                 | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                     | RW          | 0x000        |
| 1                                                                                  | SOFT_RESET                                                                                               | <p>Software reset. Set the bit to 1 to trigger a module reset. The bit is automatically reset by the hardware. Read returns 0.</p> <p>0x0: Normal mode</p> <p>0x1: The module is reset.</p>                                                                                                                                                                            | RW          | 0x0          |
| 0                                                                                  | AUTO_IDLE                                                                                                | <p>Internal Interconnect clock-gating strategy</p> <p>0x0: Interconnect clock is free-running.</p> <p>0x1: Automatic Interconnect clock-gating strategy is applied based on Interconnect interface activity.</p>                                                                                                                                                       | RW          | 0x1          |

**Table 6-149. Register Call Summary for Register CCP2\_SYSCONFIG**

## Camera ISP Integration

- Camera ISP Local Power Management: [0]
- Camera ISP System Power Management: [1]
- Camera ISP Software Reset: [2]

## Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [3]

**Table 6-150. CCP2\_SYSSTATUS**

|                         |                                                                                                                            |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|------------|
| <b>Address Offset</b>   | 0x0000 0008                                                                                                                |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |
| <b>Physical Address</b> | 0x480B C408                                                                                                                |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |
| <b>Description</b>      | SYSTEM STATUS REGISTER This register provides status information about the module, excluding interrupt status information. |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |
| <b>Type</b>             | R                                                                                                                          |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RESET_DONE |

| Bits | Field Name | Description                                                                                        | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Write Os for future compatibility. Read returns 0.                                                 | R    | 0x00000000 |
| 0    | RESET_DONE | Internal reset monitoring<br><br>0x0: Internal module reset is ongoing.<br><br>0x1: Reset complete | R    | 0x1        |
|      |            |                                                                                                    |      |            |

**Table 6-151. Register Call Summary for Register CCP2\_SYSSTATUS**

Camera ISP Integration

- [Camera ISP Software Reset: \[0\] \[1\]](#)

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[2\]](#)

**Table 6-152. CCP2\_LC01\_IRQENABLE**

|                         |                                                                                                                                                                                                                                                                                                                                                   |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|
| <b>Address Offset</b>   | 0x0000 000C                                                                                                                                                                                                                                                                                                                                       |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |
| <b>Physical Address</b> | 0x480B C40C                                                                                                                                                                                                                                                                                                                                       |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |
| <b>Description</b>      | INTERRUPT ENABLE REGISTER - LOGICAL CHANNELS 0 and 1 This register regroups all the events related to logical channel 0 and logical channel 1. The events related to logical channel 0 trigger SINTERRUPTN[0]. The events related to logical channel 1 trigger SINTERRUPTN[1]. The channel is enabled for events to be generated on that channel. |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RESERVED |

|                         |            |            |            |            |               |          |                  |             |             |            |             |             |          |  |            |            |            |            |               |          |                  |             |             |            |             |             |
|-------------------------|------------|------------|------------|------------|---------------|----------|------------------|-------------|-------------|------------|-------------|-------------|----------|--|------------|------------|------------|------------|---------------|----------|------------------|-------------|-------------|------------|-------------|-------------|
| 31 30 29 28 27 26 25 24 | LC1_FS IRQ | LC1_LE IRQ | LC1_LS IRQ | LC1_FE IRQ | LC1_COUNT IRQ | RESERVED | LC1_FIFO_OVF IRQ | LC1_CRC IRQ | LC1_FSP IRQ | LC1_FW IRQ | LC1_FSC IRQ | LC1_SSC IRQ | RESERVED |  | LC0_FS IRQ | LC0_LE IRQ | LC0_LS IRQ | LC0_FE IRQ | LC0_COUNT IRQ | RESERVED | LC0_FIFO_OVF IRQ | LC0_CRC IRQ | LC0_FSP IRQ | LC0_FW IRQ | LC0_FSC IRQ | LC0_SSC IRQ |
| RESERVED                |            |            |            |            |               |          |                  |             |             |            |             |             | RESERVED |  |            |            |            |            |               |          |                  |             |             |            |             |             |

| Bits  | Field Name | Description                                                                                                                                          | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                                                   | RW   | 0x0   |
| 27    | LC1_FS IRQ | Logical channel 1 - Frame start synchronization code detection<br><br>0x0: Event is masked.<br><br>0x1: Event generates an interrupt when it occurs. | RW   | 0x0   |

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name       | Description                                                                                                                                                                                                                                                 | Type | Reset |
|-------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 26    | LC1_LE_IRQ       | Logical channel 1 - Line end synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                               | RW   | 0x0   |
| 25    | LC1_LS_IRQ       | Logical channel 1 - Line start synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                             | RW   | 0x0   |
| 24    | LC1_FE_IRQ       | Logical channel 1 - Frame end synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                              | RW   | 0x0   |
| 23    | LC1_COUNT_IRQ    | Logical channel 1 - Frame counter reached<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                 | RW   | 0x0   |
| 22    | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                          | RW   | 0x0   |
| 21    | LC1_FIFO_OVF_IRQ | Logical channel 1 - FIFO overflow error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                   | RW   | 0x0   |
| 20    | LC1_CRC_IRQ      | Logical channel 1 - CRC error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                             | RW   | 0x0   |
| 19    | LC1_FSP_IRQ      | Logical channel 1 - FSP error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                             | RW   | 0x0   |
| 18    | LC1_FW_IRQ       | Logical channel 1 - Frame width error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                     | RW   | 0x0   |
| 17    | LC1_FSC_IRQ      | Logical channel 1 - False synchronization code error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                      | RW   | 0x0   |
| 16    | LC1_SSC_IRQ      | Logical channel 1 - Shifted synchronization code error.\nThis interrupt can be triggered if the PHY is set in parallel mode ( <a href="#">CCP2_CTRL.IO_OUT_SEL = 1</a> ).<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs. | RW   | 0x0   |
| 15:12 | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                          | RW   | 0x0   |
| 11    | LC0_FS_IRQ       | Logical channel 0 - Frame start synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                            | RW   | 0x0   |
| 10    | LC0_LE_IRQ       | Logical channel 0 - Line end synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                               | RW   | 0x0   |
| 9     | LC0_LS_IRQ       | Logical channel 0 - Line start synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                             | RW   | 0x0   |

| Bits | Field Name       | Description                                                                                                                                                                                                                                                  | Type | Reset |
|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 8    | LC0_FE_IRQ       | Logical channel 0 - Frame end synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                               | RW   | 0x0   |
| 7    | LC0_COUNT_IRQ    | Logical channel 0 - Frame counter reached<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                  | RW   | 0x0   |
| 6    | RESERVED         | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                                           | RW   | 0x0   |
| 5    | LC0_FIFO_OVF_IRQ | Logical channel 0 - FIFO overflow error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                    | RW   | 0x0   |
| 4    | LC0_CRC_IRQ      | Logical channel 0 - CRC error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                              | RW   | 0x0   |
| 3    | LC0_FSP_IRQ      | Logical channel 0 - FSP error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                              | RW   | 0x0   |
| 2    | LC0_FW_IRQ       | Logical channel 0 - Frame width error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                      | RW   | 0x0   |
| 1    | LC0_FSC_IRQ      | Logical channel 0 - False synchronization code error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                       | RW   | 0x0   |
| 0    | LC0_SSC_IRQ      | Logical channel 0 - Shifted synchronization code error<br>This interrupt can be triggered if the PHY is set in parallel mode ( <a href="#">CCP2_CTRL.IO_OUT_SEL = 1</a> ).<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs. | RW   | 0x0   |

**Table 6-153. Register Call Summary for Register CCP2\_LC01\_IRQENABLE**

## Camera ISP Integration

- [Camera ISP Interrupt Requests: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP CSI1/CCP2B Event and Status Checking: \[22\]](#)

## Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[23\]](#)

**Table 6-154. CCP2\_LC01\_IRQSTATUS**

|                         |                                                                                                                                                                                                                                                                                                                                                   |                 |          |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 0010                                                                                                                                                                                                                                                                                                                                       |                 |          |
| <b>Physical Address</b> | 0x480B C410                                                                                                                                                                                                                                                                                                                                       | <b>Instance</b> | ISP_CCP2 |
| <b>Description</b>      | INTERRUPT STATUS REGISTER - LOGICAL CHANNELS 0 and 1 This register regroups all the events related to logical channel 0 and logical channel 1. The events related to logical channel 0 trigger SINTERRUPTN[0]. The events related to logical channel 1 trigger SINTERRUPTN[1]. The channel is enabled for events to be generated on that channel. |                 |          |
| <b>Type</b>             | RW 1toClr                                                                                                                                                                                                                                                                                                                                         |                 |          |

|          |    |            |            |            |            |               |          |                  |             |             |            |             |             |          |            |            |            |            |               |          |                  |             |             |            |             |             |   |   |   |   |   |
|----------|----|------------|------------|------------|------------|---------------|----------|------------------|-------------|-------------|------------|-------------|-------------|----------|------------|------------|------------|------------|---------------|----------|------------------|-------------|-------------|------------|-------------|-------------|---|---|---|---|---|
| 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 |
| RESERVED |    | LC1_FS_IRQ | LC1_LE_IRQ | LC1_LS_IRQ | LC1_FE_IRQ | LC1_COUNT_IRQ | RESERVED | LC1_FIFO_OVF_IRQ | LC1_CRC_IRQ | LC1_FSP_IRQ | LC1_FW_IRQ | LC1_FSC_IRQ | LC1_SSC_IRQ | RESERVED | LC0_FS_IRQ | LC0_LE_IRQ | LC0_LS_IRQ | LC0_FE_IRQ | LC0_COUNT_IRQ | RESERVED | LC0_FIFO_OVF_IRQ | LC0_CRC_IRQ | LC0_FSP_IRQ | LC0_FW_IRQ | LC0_FSC_IRQ | LC0_SSC_IRQ |   |   |   |   |   |

| Bits  | Field Name       | Description                                                                                                                                                                                                    | Type         | Reset |
|-------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------|
| 31:28 | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                             | RW           | 0x0   |
| 27    | LC1_FS_IRQ       | Logical channel 1 - Frame start synchronization code detection status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset. | RW<br>1toClr | 0x0   |
| 26    | LC1_LE_IRQ       | Logical channel 1 - Line end synchronization code detection status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.    | RW<br>1toClr | 0x0   |
| 25    | LC1_LS_IRQ       | Logical channel 1 - Line start synchronization code detection status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.  | RW<br>1toClr | 0x0   |
| 24    | LC1_FE_IRQ       | Logical channel 1 - Frame end synchronization code detection status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.   | RW<br>1toClr | 0x0   |
| 23    | LC1_COUNT_IRQ    | Logical channel 1 - Frame counter reached status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                      | RW<br>1toClr | 0x0   |
| 22    | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                             | RW           | 0x0   |
| 21    | LC1_FIFO_OVF_IRQ | Logical channel 1 - FIFO overflow error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                        | RW<br>1toClr | 0x0   |
| 20    | LC1_CRC_IRQ      | Logical channel 1 - CRC error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                                  | RW<br>1toClr | 0x0   |
| 19    | LC1_FSP_IRQ      | Logical channel 1 - FSP error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                                  | RW<br>1toClr | 0x0   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                             | <b>Type</b>  | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|
| 18          | LC1_FW_IRQ        | Logical channel 1 - Frame width error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                          | RW<br>1toClr | 0x0          |
| 17          | LC1_FSC_IRQ       | Logical channel 1 - False synchronization code error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.           | RW<br>1toClr | 0x0          |
| 16          | LC1_SSC_IRQ       | Logical channel 1 - Shifted synchronization code error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.         | RW<br>1toClr | 0x0          |
| 15:12       | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                             | RW           | 0x0          |
| 11          | LC0_FS_IRQ        | Logical channel 0 - Frame start synchronization code detection status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset. | RW<br>1toClr | 0x0          |
| 10          | LC0_LE_IRQ        | Logical channel 0 - Line end synchronization code detection status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.    | RW<br>1toClr | 0x0          |
| 9           | LC0_LS_IRQ        | Logical channel 0 - Line start synchronization code detection status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.  | RW<br>1toClr | 0x0          |
| 8           | LC0_FE_IRQ        | Logical channel 0 - Frame end synchronization code detection status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.   | RW<br>1toClr | 0x0          |
| 7           | LC0_COUNT_IRQ     | Logical channel 0 - Frame counter reached status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                      | RW<br>1toClr | 0x0          |
| 6           | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                             | RW           | 0x0          |
| 5           | LC0_FIFO_OVF_IRQ  | Logical channel 0 - FIFO overflow error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                        | RW<br>1toClr | 0x0          |

| Bits | Field Name  | Description                                                                                                                                                                                    | Type         | Reset |
|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------|
| 4    | LC0_CRC_IRQ | Logical channel 0 - CRC error status<br>0x0: READS: Event is false. WRITES: Status bit unchanged<br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                          | RW<br>1toClr | 0x0   |
| 3    | LC0_FSP_IRQ | Logical channel 0 - FSP error status<br>0x0: READS: Event is false. WRITES: Status bit unchanged<br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                          | RW<br>1toClr | 0x0   |
| 2    | LC0_FW_IRQ  | Logical channel 0 - Frame width error status<br>0x0: READS: Event is false. WRITES: Status bit unchanged<br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                  | RW<br>1toClr | 0x0   |
| 1    | LC0_FSC_IRQ | Logical channel 0 - False synchronization code error status<br>0x0: READS: Event is false. WRITES: Status bit unchanged<br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.   | RW<br>1toClr | 0x0   |
| 0    | LC0_SSC_IRQ | Logical channel 0 - Shifted synchronization code error status<br>0x0: READS: Event is false. WRITES: Status bit unchanged<br>0x1: READS: Event is true (pending). WRITES: Status bit is reset. | RW<br>1toClr | 0x0   |

**Table 6-155. Register Call Summary for Register CCP2\_LC01\_IRQSTATUS**

Camera ISP Integration

- Camera ISP Interrupt Requests: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23]

Camera ISP Basic Programming Model

- Camera ISP CSI1/CCP2B Event and Status Checking: [24] [25] [26]

Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [27]

**Table 6-156. CCP2\_LC23\_IRQENABLE**

|                  |                                                                                                                                                                                                                                                                                                                                                   |            |            |            |               |          |                  |             |             |            |             |             |          |            |            |            |            |               |          |                  |             |             |            |             |             |   |   |   |   |   |   |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------------|------------|---------------|----------|------------------|-------------|-------------|------------|-------------|-------------|----------|------------|------------|------------|------------|---------------|----------|------------------|-------------|-------------|------------|-------------|-------------|---|---|---|---|---|---|--|--|--|--|
| Address Offset   | 0x0000 0014                                                                                                                                                                                                                                                                                                                                       |            |            |            |               |          |                  |             |             |            |             |             |          |            |            |            |            |               |          |                  |             |             |            |             |             |   |   |   |   |   |   |  |  |  |  |
| Physical Address | 0x480B C414                                                                                                                                                                                                                                                                                                                                       |            |            |            |               |          |                  |             |             |            |             |             | Instance | ISP_CCP2   |            |            |            |               |          |                  |             |             |            |             |             |   |   |   |   |   |   |  |  |  |  |
| Description      | INTERRUPT ENABLE REGISTER - LOGICAL CHANNELS 2 and 3 This register regroups all the events related to logical channel 2 and logical channel 3. The events related to logical channel 2 trigger SINTERRUPTN[2]. The events related to logical channel 3 trigger SINTERRUPTN[3]. The channel is enabled for events to be generated on that channel. |            |            |            |               |          |                  |             |             |            |             |             |          |            |            |            |            |               |          |                  |             |             |            |             |             |   |   |   |   |   |   |  |  |  |  |
| Type             | RW                                                                                                                                                                                                                                                                                                                                                |            |            |            |               |          |                  |             |             |            |             |             |          |            |            |            |            |               |          |                  |             |             |            |             |             |   |   |   |   |   |   |  |  |  |  |
| 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 |  |  |  |  |
| RESERVED         | LC3_FS IRQ                                                                                                                                                                                                                                                                                                                                        | LC3_LE IRQ | LC3_LS IRQ | LC3_FE IRQ | LC3_COUNT IRQ | RESERVED | LC3_FIFO_OVF IRQ | LC3_CRC IRQ | LC3_FSP IRQ | LC3_FW IRQ | LC3_FSC IRQ | LC3_SSC IRQ | RESERVED | LC2_FS IRQ | LC2_LE IRQ | LC2_LS IRQ | LC2_FE IRQ | LC2_COUNT IRQ | RESERVED | LC2_FIFO_OVF IRQ | LC2_CRC IRQ | LC2_FSP IRQ | LC2_FW IRQ | LC2_FSC IRQ | LC2_SSC IRQ |   |   |   |   |   |   |  |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                           | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:28       | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                           | RW          | 0x0          |
| 27          | LC3_FS_IRQ        | Logical channel 3 - Frame start synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                             | RW          | 0x0          |
| 26          | LC3_LE_IRQ        | Logical channel 3 - Line end synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                | RW          | 0x0          |
| 25          | LC3_LS_IRQ        | Logical channel 3 - Line start synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                              | RW          | 0x0          |
| 24          | LC3_FE_IRQ        | Logical channel 3 - Frame end synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                               | RW          | 0x0          |
| 23          | LC3_COUNT_IRQ     | Logical channel 3 - Frame counter reached<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                  | RW          | 0x0          |
| 22          | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                           | RW          | 0x0          |
| 21          | LC3_FIFO_OVF_IRQ  | Logical channel 3 - FIFO overflow error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                    | RW          | 0x0          |
| 20          | LC3_CRC_IRQ       | Logical channel 3 - CRC error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                              | RW          | 0x0          |
| 19          | LC3_FSP_IRQ       | Logical channel 3 - FSP error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                              | RW          | 0x0          |
| 18          | LC3_FW_IRQ        | Logical channel 3 - Frame width error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                      | RW          | 0x0          |
| 17          | LC3_FSC_IRQ       | Logical channel 3 - False synchronization code error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                       | RW          | 0x0          |
| 16          | LC3_SSC_IRQ       | Logical channel 3 - Shifted synchronization code error<br>This interrupt can be triggered if the PHY is set in parallel mode ( <a href="#">CCP2_CTRL.IO_OUT_SEL = 1</a> ).<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs. | RW          | 0x0          |
| 15:12       | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                           | RW          | 0x0          |
| 11          | LC2_FS_IRQ        | Logical channel 2 - Frame start synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                             | RW          | 0x0          |
| 10          | LC2_LE_IRQ        | Logical channel 2 - Line end synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                | RW          | 0x0          |

| Bits | Field Name       | Description                                                                                                                                                                                                                                                  | Type | Reset |
|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 9    | LC2_LS_IRQ       | Logical channel 2 - Line start synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                              | RW   | 0x0   |
| 8    | LC2_FE_IRQ       | Logical channel 2 - Frame end synchronization code detection<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                               | RW   | 0x0   |
| 7    | LC2_COUNT_IRQ    | Logical channel 2 - Frame counter reached<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                  | RW   | 0x0   |
| 6    | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                           | RW   | 0x0   |
| 5    | LC2_FIFO_OVF_IRQ | Logical channel 2 - FIFO overflow error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                    | RW   | 0x0   |
| 4    | LC2_CRC_IRQ      | Logical channel 2 - CRC error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                              | RW   | 0x0   |
| 3    | LC2_FSP_IRQ      | Logical channel 2 - FSP error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                              | RW   | 0x0   |
| 2    | LC2_FW_IRQ       | Logical channel 2 - Frame width error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                                      | RW   | 0x0   |
| 1    | LC2_FSC_IRQ      | Logical channel 2 - False synchronization code error<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs.                                                                                                                       | RW   | 0x0   |
| 0    | LC2_SSC_IRQ      | Logical channel 2 - Shifted synchronization code error<br>This interrupt can be triggered if the PHY is set in parallel mode ( <a href="#">CCP2_CTRL.IO_OUT_SEL = 1</a> ).<br><br>0x0: Event is masked.<br>0x1: Event generates an interrupt when it occurs. | RW   | 0x0   |

**Table 6-157. Register Call Summary for Register CCP2\_LC23\_IRQENABLE**

## Camera ISP Integration

- Camera ISP Interrupt Requests: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21]

## Camera ISP Basic Programming Model

- Camera ISP CSI1/CCP2B Event and Status Checking: [22]

## Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [23]

**Table 6-158. CCP2\_LC23\_IRQSTATUS**

|                       |                                                                                                                                                                                                                                                                                                                                                   |                         |             |                 |          |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|----------|
| <b>Address Offset</b> | 0x0000 0018                                                                                                                                                                                                                                                                                                                                       | <b>Physical Address</b> | 0x480B C418 | <b>Instance</b> | ISP_CCP2 |
| <b>Description</b>    | INTERRUPT STATUS REGISTER - LOGICAL CHANNELS 2 and 3 This register regroups all the events related to logical channel 2 and logical channel 3. The events related to logical channel 2 trigger SINTERRUPTN[2]. The events related to logical channel 3 trigger SINTERRUPTN[3]. The channel is enabled for events to be generated on that channel. |                         |             |                 |          |
| <b>Type</b>           | RW 1toClr                                                                                                                                                                                                                                                                                                                                         |                         |             |                 |          |

| 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 |
|----------|----|----|----|------------|------------|------------|------------|---------------|----------|------------------|-------------|-------------|------------|-------------|-------------|----------|------------|------------|------------|------------|---------------|----------|------------------|-------------|-------------|------------|-------------|-------------|---|---|---|
| RESERVED |    |    |    | LC3_FS IRQ | LC3_LE IRQ | LC3_LS IRQ | LC3_FE IRQ | LC3_COUNT IRQ | RESERVED | LC3_FIFO_OVF IRQ | LC3_CRC IRQ | LC3_FSP IRQ | LC3_FW IRQ | LC3_FSC IRQ | LC3_SSC IRQ | RESERVED | LC2_FS IRQ | LC2_LE IRQ | LC2_LS IRQ | LC2_FE IRQ | LC2_COUNT IRQ | RESERVED | LC2_FIFO_OVF IRQ | LC2_CRC IRQ | LC2_FSP IRQ | LC2_FW IRQ | LC2_FSC IRQ | LC2_SSC IRQ |   |   |   |

| Bits  | Field Name       | Description                                                                                                                                                                                                    | Type         | Reset |
|-------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------|
| 31:28 | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                             | RW           | 0x0   |
| 27    | LC3_FS IRQ       | Logical channel 3 - Frame start synchronization code detection status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset. | RW<br>1toClr | 0x0   |
| 26    | LC3_LE IRQ       | Logical channel 3 - Line end synchronization code detection status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.    | RW<br>1toClr | 0x0   |
| 25    | LC3_LS IRQ       | Logical channel 3 - Line start synchronization code detection status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.  | RW<br>1toClr | 0x0   |
| 24    | LC3_FE IRQ       | Logical channel 3 - Frame end synchronization code detection status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.   | RW<br>1toClr | 0x0   |
| 23    | LC3_COUNT IRQ    | Logical channel 3 - Frame counter reached status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                      | RW<br>1toClr | 0x0   |
| 22    | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                             | RW           | 0x0   |
| 21    | LC3_FIFO_OVF IRQ | Logical channel 3 - FIFO overflow error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                        | RW<br>1toClr | 0x0   |

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name    | Description                                                                                                                                                                                                  | Type         | Reset |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------|
| 20    | LC3_CRC_IRQ   | Logical channel 3 - CRC error status<br><br>0x0:READS: Event is false. WRITES: Status bit unchanged<br><br>0x1:READS: Event is true (pending). WRITES: Status bit is reset.                                  | RW<br>1toClr | 0x0   |
| 19    | LC3_FSP_IRQ   | Logical channel 3 - FSP error status<br><br>0x0:READS: Event is false. WRITES: Status bit unchanged<br><br>0x1:READS: Event is true (pending). WRITES: Status bit is reset.                                  | RW<br>1toClr | 0x0   |
| 18    | LC3_FW_IRQ    | Logical channel 3 - Frame width error status<br><br>0x0:READS: Event is false. WRITES: Status bit unchanged<br><br>0x1:READS: Event is true (pending). WRITES: Status bit is reset.                          | RW<br>1toClr | 0x0   |
| 17    | LC3_FSC_IRQ   | Logical channel 3 - False synchronization code error status<br><br>0x0:READS: Event is false. WRITES: Status bit unchanged<br><br>0x1:READS: Event is true (pending). WRITES: Status bit is reset.           | RW<br>1toClr | 0x0   |
| 16    | LC3_SSC_IRQ   | Logical channel 3 - Shifted synchronization code error status<br><br>0x0:READS: Event is false. WRITES: Status bit unchanged<br><br>0x1:READS: Event is true (pending). WRITES: Status bit is reset.         | RW<br>1toClr | 0x0   |
| 15:12 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                           | RW           | 0x0   |
| 11    | LC2_FS_IRQ    | Logical channel 2 - Frame start synchronization code detection status<br><br>0x0:READS: Event is false. WRITES: Status bit unchanged<br><br>0x1:READS: Event is true (pending). WRITES: Status bit is reset. | RW<br>1toClr | 0x0   |
| 10    | LC2_LE_IRQ    | Logical channel 2 - Line end synchronization code detection status<br><br>0x0:READS: Event is false. WRITES: Status bit unchanged<br><br>0x1:READS: Event is true (pending). WRITES: Status bit is reset.    | RW<br>1toClr | 0x0   |
| 9     | LC2_LS_IRQ    | Logical channel 2 - Line start synchronization code detection status<br><br>0x0:READS: Event is false. WRITES: Status bit unchanged<br><br>0x1:READS: Event is true (pending). WRITES: Status bit is reset.  | RW<br>1toClr | 0x0   |
| 8     | LC2_FE_IRQ    | Logical channel 2 - Frame end synchronization code detection status<br><br>0x0:READS: Event is false. WRITES: Status bit unchanged<br><br>0x1:READS: Event is true (pending). WRITES: Status bit is reset.   | RW<br>1toClr | 0x0   |
| 7     | LC2_COUNT_IRQ | Logical channel 2 - Frame counter reached status<br><br>0x0:READS: Event is false. WRITES: Status bit unchanged<br><br>0x1:READS: Event is true (pending). WRITES: Status bit is reset.                      | RW<br>1toClr | 0x0   |

| Bits | Field Name       | Description                                                                                                                                                                                            | Type         | Reset |
|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------|
| 6    | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                     | RW           | 0x0   |
| 5    | LC2_FIFO_OVF_IRQ | Logical channel 2 - FIFO overflow error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                | RW<br>1toClr | 0x0   |
| 4    | LC2_CRC_IRQ      | Logical channel 2 - CRC error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                          | RW<br>1toClr | 0x0   |
| 3    | LC2_FSP_IRQ      | Logical channel 2 - FSP error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                          | RW<br>1toClr | 0x0   |
| 2    | LC2_FW_IRQ       | Logical channel 2 - Frame width error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                  | RW<br>1toClr | 0x0   |
| 1    | LC2_FSC_IRQ      | Logical channel 2 - False synchronization code error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.   | RW<br>1toClr | 0x0   |
| 0    | LC2_SSC_IRQ      | Logical channel 2 - Shifted synchronization code error status<br><br>0x0: READS: Event is false. WRITES: Status bit unchanged<br><br>0x1: READS: Event is true (pending). WRITES: Status bit is reset. | RW<br>1toClr | 0x0   |

**Table 6-159. Register Call Summary for Register CCP2\_LC23\_IRQSTATUS**

## Camera ISP Integration

- [Camera ISP Interrupt Requests](#): [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23]

## Camera ISP Basic Programming Model

- [Camera ISP CSI1/CCP2B Event and Status Checking](#): [24] [25] [26]

## Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary](#): [27]

**Table 6-160. CCP2\_LCM\_IRQENABLE**

|                         |                                                                                                                                                                                                                                                    |                         |                 |                 |                                                                                                                                                                            |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 002C                                                                                                                                                                                                                                        | <b>Physical Address</b> | 0x480B C42C     | <b>Instance</b> | ISP_CCP2                                                                                                                                                                   |
| <b>Description</b>      | INTERRUPT ENABLE REGISTER - Memory channel. This register regroups all the events related to memory channel 2. The events related to the memory channel trigger SINTERRUPTN[8]. The channel is enabled for events to be generated on that channel. |                         |                 |                 |                                                                                                                                                                            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                 |                         |                 |                 |                                                                                                                                                                            |
| 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 |                 |                                                                                                                                                                            |
| RESERVED                |                                                                                                                                                                                                                                                    |                         |                 |                 | <br> |

| Bits | Field Name   | Description                                                                                                                                   | Type | Reset      |
|------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED     | Write Os for future compatibility. Read returns 0.                                                                                            | RW   | 0x00000000 |
| 1    | LCM_OCPERROR | An Interconnect error occurred on the master read port.<br><br>0x0: Event is masked.<br><br>0x1: Event generates an interrupt when it occurs. | RW   | 0x0        |
| 0    | LCM_EOF      | Memory read channel - End of frame<br><br>0x0: Event is masked.<br><br>0x1: Event generates an interrupt when it occurs.                      | RW   | 0x0        |

**Table 6-161. Register Call Summary for Register CCP2\_LCM\_IRQENABLE**

Camera ISP Integration

- Camera ISP Interrupt Requests: [0] [1]

Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [2]

**Table 6-162. CCP2\_LCM\_IRQSTATUS**

|                         |                                                                                                                                                                                                                                                  |                         |                 |                 |                                                                                                                                                                                |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0030                                                                                                                                                                                                                                      | <b>Physical Address</b> | 0x480B C430     | <b>Instance</b> | ISP_CCP2                                                                                                                                                                       |
| <b>Description</b>      | INTERRUPT STATUS REGISTER - Memory channel. This register regroups all the events related to memory channel. The events related to the memory channel trigger SINTERRUPTN[8]. The channel is enabled for events to be generated on that channel. |                         |                 |                 |                                                                                                                                                                                |
| <b>Type</b>             | RW 1toClr                                                                                                                                                                                                                                        |                         |                 |                 |                                                                                                                                                                                |
| 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 |                 |                                                                                                                                                                                |
| RESERVED                |                                                                                                                                                                                                                                                  |                         |                 |                 | <br> |

| Bits | Field Name   | Description                                                                                                                                                                              | Type         | Reset      |
|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------|
| 31:2 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                       | RW           | 0x00000000 |
| 1    | LCM_OCPERROR | An Interconnect error occurred on the master read port.<br>0x0: READS: Event is false. WRITES: Status bit unchanged<br>0x1: READS: Event is true (pending). WRITES: Status bit is reset. | RW<br>1toClr | 0x0        |
| 0    | LCM_EOF      | Memory read channel - End of frame<br>0x0: READS: Event is false. WRITES: Status bit unchanged<br>0x1: READS: Event is true (pending). WRITES: Status bit is reset.                      | RW<br>1toClr | 0x0        |

**Table 6-163. Register Call Summary for Register CCP2\_LCM\_IRQSTATUS**

Camera ISP Integration

- [Camera ISP Interrupt Requests: \[0\] \[1\]](#)

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[2\]](#)

**Table 6-164. CCP2\_CTRL**

| Address Offset     | 0x0000 0040 |                                                                                                                                                | Physical Address | 0x480B C440 | Instance | ISP_CCP2 |    |    |    |    |    |    |    |    |    |        |        |            |            |     |                 |          |       |      |       |            |         |       |   |   |   |  |
|--------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------|----------|----------|----|----|----|----|----|----|----|----|----|--------|--------|------------|------------|-----|-----------------|----------|-------|------|-------|------------|---------|-------|---|---|---|--|
| <b>Description</b> |             | GLOBAL CONTROL REGISTER. This register controls the CCP2B RECEIVER module. This register is not modified dynamically (except IF_EN bit field). |                  |             |          |          |    |    |    |    |    |    |    |    |    |        |        |            |            |     |                 |          |       |      |       |            |         |       |   |   |   |  |
| <b>Type</b>        |             | RW                                                                                                                                             |                  |             |          |          |    |    |    |    |    |    |    |    |    |        |        |            |            |     |                 |          |       |      |       |            |         |       |   |   |   |  |
| 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 |  |
| FRACDIV            |             |                                                                                                                                                |                  |             |          |          |    |    |    |    |    |    |    |    |    | POSTED | DBG_EN | VP_CLK_POL | VP_ONLY_EN | INV | VP_CLK_FORCE_ON | RESERVED | BURST | MODE | FRAME | IO_OUT_SEL | PHY_SEL | IF_EN |   |   |   |  |

| Bits  | Field Name | Description                                                                                                        | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:15 | FRACDIV    | Fractional clock divider control for the video port.<br>The means video port clock is VPBASECLOCK * FRACDIV/65536. | RW   | 0x10000 |
| 14    | POSTED     | Selects between posted and nonposted writes<br>0x0: Nonposted<br>0x1: Posted                                       | RW   | 0x0     |
| 13    | DBG_EN     | Enables the debug mode<br>0x0: Disable<br>0x1: Enable                                                              |      | 0x0     |

## Camera ISP Register Manual

www.ti.com

| Bits | Field Name      | Description                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 12   | VP_CLK_POL      | VP clock polarity<br>0x0: The CCP2B RECEIVER module writes the data on the VP on the pixel clock falling edge. The module connected to the VP samples the data on the pixel clock rising edge.<br>0x1: The CCP2B RECEIVER module writes the data on the VP on the pixel clock raising edge. The module connected to the VP samples the data on the pixel clock falling edge. | RW   | 0x0   |
| 11   | VP_ONLY_EN      | VP only enable<br>0x0: The VP is enabled and the Interconnect master port is enabled.<br>0x1: The VP is enabled and the Interconnect master port is disabled. The embedded data and pixel data are output on the VP.                                                                                                                                                         | RW   | 0x0   |
| 10   | INV             | Strobe/clock inversion control signal<br>0x0: Not inverted<br>0x1: Inverted                                                                                                                                                                                                                                                                                                  | RW   | 0x0   |
| 9    | VP_CLK_FORCE_ON | Controls video port clock gating during frame blanking periods.<br>0x0: The video port clock is gated during vertical blanking periods.<br>0x1: The video port clock is free-running during vertical blanking periods.                                                                                                                                                       | RW   | 0x1   |
| 8    | RESERVED        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                           | R    | 0x0   |
| 7:5  | BURST           | Forces the write burst size used by the module<br>The write burst size must never exceed the output FIFO size. The output FIFO size can be read with the <a href="#">CCP2_GNQ.FIFODEPTH</a> bit field.<br>0x0: 1 x 64-bit burst = single request<br>0x1: 2 x 64-bit bursts<br>0x2: 4 x 64-bit bursts<br>0x3: 8 x 64-bit bursts<br>0x4: 16 x 64-bit bursts                    | RW   | 0x0   |
| 4    | MODE            | Selects the receiver operating mode<br>0x0: MIPI CSI1-compatible mode. When this bit is set, all CCP2B settings are ignored. If the settings are not set correctly to MIPI CSI1 values, the behavior of the receiver is unpredictable.<br>0x1: CCP2B compatible mode                                                                                                         | RW   | 0x0   |
| 3    | FRAME           | Set the modality in which IF_EN works.<br>0x0: When SW writes IF_EN = 0, the interface is disabled immediately.<br>0x1: When SW writes IF_EN = 0, the interface is disabled after the next FEC synchronization code.                                                                                                                                                         | RW   | 0x0   |
| 2    | IO_OUT_SEL      | IO cell output mode selection<br>0x0: RESERVED<br>0x1: MUST BE SET TO 1, IO output is parallel: DATA32, DATATOG, SYNTOG. The SSC_IRQ error can be triggered in this configuration.                                                                                                                                                                                           | RW   | 0x0   |
| 1    | PHY_SEL         | Physical layer protocol selection. Applies for all logical channels<br>0x0: Data/clock physical layer<br>0x1: Data/strobe physical layer                                                                                                                                                                                                                                     | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | IF_EN      | <p>Enables the physical interface to the module</p> <p>0x0: The interface is disabled. If FRAME = 0, it is disabled immediately. If FRAME = 1, it is disabled on the next FEC synchronization code. If FRAME=1, it is advised to disable the logical channels (CCP2_LCX_CTRL.CHAN_EN = 0) before writing IF_EN = 0.</p> <p>0x1: The interface is enabled immediately, the data acquisition starts on the next FSC synchronization code. Writing 1 to this register when the current value is 0 clears the output FIFO. The pixel data of the following frame is written in the PING buffer; that is, the CCP2_LCX_CTRL.PING_PONG bits are also reset to 1.</p> | RW   | 0x0   |

**Table 6-165. Register Call Summary for Register CCP2\_CTRL**
**Camera ISP Environment**

- [Camera ISP CSI1/CCP2 Protocol and Data Formats](#):

**Camera ISP Integration**

- [Camera ISP System Power Management](#): [1]

**Camera ISP Functional Description**

- [Camera ISP CSI1/CCP2B Associated PHY](#): [2] [3] [4] [5] [6] [7]
- [Camera ISP CSI1/CCP2B Memory Read Channel](#): [8]
- [Camera ISP CSI1/CCP2B Image Data Operating Modes and Alignment Constraints](#): [9]

**Camera ISP Basic Programming Model**

- [Camera ISP CSI1/CCP2B Enable/Disable the Hardware](#): [10] [11] [12] [13] [14] [15] [16] [17]
- [Camera ISP CSI1/CCP2B Select the Signaling Scheme](#): [18] [19] [20]
- [Camera ISP CSI1/CCP2B Control of the PHY](#): [21]
- [Camera ISP CSI1/CCP2B Select the Mode](#): MIPI CSI1 or CCP2B: [22] [23] [24] [25]
- [Camera ISP CSI1/CCP2B Burst Settings](#): [26]
- [Camera ISP CSI1/CCP2B Debug Mode](#): [27] [28] [29] [30]
- [Camera ISP CSI1/CCP2B Video Port](#): [31] [32] [33] [34] [35] [36]
- [Camera ISP CSI1/CCP2B CRC](#): [37]
- [Camera ISP CSI1/CCP2B Destination Format](#): [38] [39]
- [Camera ISP CSI1/CCP2B Frame Acquisition](#): [40]
- [Camera ISP CSI1/CCP2B Read Data from Memory](#): [41] [42] [43] [44] [45] [46]

**Camera ISP Register Manual**

- [Camera ISP CCP2 Register Summary](#): [47]
- [Camera ISP CCP2 Register Description](#): [48] [49] [50] [51] [52]

**Table 6-166. CCP2\_DBG**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                       |                 |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0044                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                       |                 |
| <b>Physical Address</b> | 0x480B C444                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <b>Instance</b>       | ISP_CCP2        |
| <b>Description</b>      | DEBUG REGISTER This register provides a way to debug the CCP2B RECEIVER module with no image sensor connected to the module. The debug mode is enabled by <a href="#">CCP2_CTRL.DBG_EN</a> . Each write to this register provides a full 32-bit word to the CCP2B RECEIVER, even when only 8 or 16 bits are written. The newly written value is merged with the previous value (check the example in <a href="#">Section 6.5.3, CCP2 Receiver Basic Programming Model</a> ). |                       |                 |
| <b>Type</b>             | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                       |                 |
| 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 |
| DBG                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                       |                 |

| Bits | Field Name | Description                                                 | Type | Reset      |
|------|------------|-------------------------------------------------------------|------|------------|
| 31:0 | DBG        | 32-bit input value.<br>Write-only register. Read returns 0. | W    | 0x00000000 |

**Table 6-167. Register Call Summary for Register CCP2\_DBG**

Camera ISP Basic Programming Model

- Camera ISP CSI1/CCP2B Debug Mode: [0] [1] [2] [3] [4] [5] [6] [7]

Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [8]

**Table 6-168. CCP2\_GNQ**

|                         |                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0048                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C448                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | GENERIC PARAMETER REGISTER<br>This register provide a way to read the generic parameters used in the design. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



| Bits | Field Name  | Description                                                                                                                                                                                     | Type | Reset      |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:6 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                              | R    | 0x00000000 |
| 5    | OCPREADPORT | The Interconnect master read port, the DPCM encoder and ALAW decompression are only present when this bit is set.                                                                               | R    | 1          |
| 4:2  | FIFODEPTH   | Output FIFO size in multiple of 64 bits.<br><br>Read 0x0: 2x 64 bits<br>Read 0x1: 4x 64 bits<br>Read 0x2: 8x 64 bits<br>Read 0x3: 16x 64 bits<br>Read 0x4: 32x 64 bits<br>Read 0x5: 64x 64 bits | R    | 0x2        |
| 1:0  | NBCHANNELS  | Number of logical channels supported by the module.<br><br>Read 0x0: 1 logical channel<br>Read 0x1: 2 logical channels<br>Read 0x2: 4 logical channels<br>Read 0x3: 8 logical channels          | R    | 0x2        |

**Table 6-169. Register Call Summary for Register CCP2\_GNQ**

Camera ISP Basic Programming Model

- Camera ISP CSI1/CCP2B Burst Settings: [0]

Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [1]
- Camera ISP CCP2 Register Description: [2]

**Table 6-170. CCP2\_CTRL1**

|                         |                                                                                                               |                 |          |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------|-----------------|----------|--|--|
| <b>Address Offset</b>   | 0x0000 004C                                                                                                   | <b>Instance</b> | ISP_CCP2 |  |  |
| <b>Physical Address</b> | 0x480B C44C                                                                                                   |                 |          |  |  |
| <b>Description</b>      | Global control register (2)<br>This register provide a way to read the generic parameters used in the design. |                 |          |  |  |
| <b>Type</b>             | RW                                                                                                            |                 |          |  |  |

| 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 |
|----------|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----------|---|
| RESERVED |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | BLANKING |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31    | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x0    |
| 30:24 | LEVH       | Controls generation of MFlag[1:0]:<br>00: FIFO_LEV=LEVL<br>01: Unused<br>10: LEVLFIFO_LEV and FIFO_LEV=LEVH<br>11: LEVHFIFO_LEV<br>Allowed values 0..FIFO_SIZE                                                                                                                                                                                                                                                                                                               | RW   | 0x00   |
| 23    | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x0    |
| 22:16 | LEVL       | Controls generation of MFlag[1:0]:<br>00: FIFO_LEV=LEVL<br>01: Unused<br>10: LEVLFIFO_LEV and FIFO_LEV=LEVH<br>11: LEVHFIFO_LEV<br>Allowed values 0..FIFO_SIZE                                                                                                                                                                                                                                                                                                               | RW   | 0x00   |
| 15:2  | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x0000 |
| 1:0   | BLANKING   | Controls the number of clock pulses provided during vertical and horizontal clock periods<br><br>When the blanking period provided by the camera is lower than the value set here, the blanking period is shortened by the CCP2_RECEIVER to prevent internal FIFO overflow. Software must increase the sensor blanking period in that case.<br><br>0x0: 4 video port clock cycles<br>0x1: 16 video port clock cycles<br>0x2: 64 video port clock cycles<br>0x3: Free-running | RW   | 0x0    |

**Table 6-171. Register Call Summary for Register CCP2\_CTRL1**

Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [0]

**Table 6-172. CCP2\_LCx\_CTRL**

|                         |                                                                                                                                                                                          |                 |            |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0050 + (x * 0x30)                                                                                                                                                                 | <b>Index</b>    | x = 0 to 3 |
| <b>Physical Address</b> | 0x480B C450 + (x * 0x30)                                                                                                                                                                 | <b>Instance</b> | ISP_CCP2   |
| <b>Description</b>      | CONTROL REGISTER - LOGICAL CHANNEL x. This register controls logical channel x. This register is shadowed; modifications are taken into account after the next FSC synchronization code. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                       |                 |            |



| Bits  | Field Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | COUNT        | Sets the number of frame to acquire. Once the frame acquisition starts, the COUNT value is decremented after every frame. When COUNT reaches 0, the COUNT_IRQ interrupt is triggered and CHAN_EN is set to '0'. Writes to this bit field are controlled by the COUNT_UNLOCK bit. COUNT can be overwritten dynamically with a new count value.<br>0: Infinite number of frames (no count).<br>1: 1 frame to acquire<br>...<br>255: 255 frames to acquire. | RW   | 0x00  |
| 23:20 | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                       | R    | 0x0   |
| 19    | CRC_EN       | Enables the cyclic redundancy check.<br>0x0: Disabled<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0     |
| 18    | DPCM_PRED    | Selects the DPCM predictor to be used for the RAW6+DPCM10, RAW7+DPCM10 and RAW8+DPCM12 data formats.<br>The RAW8+DPCM10 data format always use the simple predictor.<br>0x0: The advanced predictor is used<br>0x1: The simple predictor is used.                                                                                                                                                                                                        | RW   | 0     |
| 17    | PING_PONG    | Indicates whether the PING or PONG destination address (CCP2_LC0_DAT_PING_ADDR or CCP2_LC0_DAT_PONG_ADDR) was used to write the last frame. This bit field toggles after every FEC sync code.<br>Read 0x0: PING buffer<br>Read 0x1: PONG buffer                                                                                                                                                                                                          | R    | 1     |
| 16    | COUNT_UNLOCK | Unlock writes to the COUNT bit field.<br>Write 0x0: COUNT bit field is locked. Writes have no effect<br>Write 0x1: COUNT bit field is unlocked. Writes are possible.                                                                                                                                                                                                                                                                                     | W    | 0     |
| 15:8  | ALPHA        | Alpha value for RGB888 and RBG444.                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x00  |
| 7:2   | FORMAT       | Data format selection.<br>0x0: YUV422 BIG ENDIAN<br>0x1: YUV422 LITTLE ENDIAN<br>0x2: YUV420<br>0x3: YUV422 + VP or RAW8 + VP<br>0x4: RGB444 + EXP16                                                                                                                                                                                                                                                                                                     | RW   | 0x00  |

| <b>Bits</b> | <b>Field Name</b>        | <b>Description</b>                                                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 0x5:        | RGB565                   |                                                                                                                                     |             |              |
| 0x6:        | RGB888                   |                                                                                                                                     |             |              |
| 0x7:        | RGB888 + EXP32           |                                                                                                                                     |             |              |
| 0x8:        | RAW6 + EXP8              |                                                                                                                                     |             |              |
| 0x9:        | RAW6 + DPCM10 + EXP16    |                                                                                                                                     |             |              |
| 0xA:        | RAW6 + DPCM10 + VP       |                                                                                                                                     |             |              |
| 0xB:        | RAW10 - RAW6 DPCM        | RAW10 data from sensor is DPCM compressed into RAW6 before it is send to memory.                                                    |             |              |
|             |                          | Used predictor is selected by the DPCM_PRED bit.                                                                                    |             |              |
| 0xC:        | RAW7 + EXP8              |                                                                                                                                     |             |              |
| 0xD:        | RAW7 + DPCM10 + EXP16    |                                                                                                                                     |             |              |
| 0xE:        | RAW7 + DPCM10 + VP       |                                                                                                                                     |             |              |
| 0xF:        | RAW10 - RAW6 DPCM + EXP8 | RAW10 data from sensor is DPCM compressed into RAW6 and expanded to 8 bits before it is send to memory.                             |             |              |
|             |                          | Used predictor is selected by the DPCM_PRED bit.                                                                                    |             |              |
| 0x10:       | RAW8                     | This mode can be used to output RAW6 and RAW7 as well.                                                                              |             |              |
| 0x11:       | RAW8 + DPCM10 + EXP16    |                                                                                                                                     |             |              |
| 0x12:       | RAW8 + DPCM10 + VP       |                                                                                                                                     |             |              |
| 0x13:       | RAW10 - RAW7 DPCM        | RAW10 data from sensor is DPCM compressed into RAW7 before it is send to memory.                                                    |             |              |
|             |                          | Used predictor is selected by the DPCM_PRED bit.                                                                                    |             |              |
| 0x14:       | RAW10                    |                                                                                                                                     |             |              |
| 0x15:       | RAW10 + EXP16            |                                                                                                                                     |             |              |
| 0x16:       | RAW10 + VP               |                                                                                                                                     |             |              |
| 0x17:       | RAW10 - RAW7 DPCM + EXP8 | RAW10 data from sensor is DPCM compressed into RAW7 and expanded to 8 bits before it is send to memory.                             |             |              |
|             |                          | Used predictor is selected by the DPCM_PRED bit.                                                                                    |             |              |
| 0x18:       | RAW12                    |                                                                                                                                     |             |              |
| 0x19:       | RAW12 + EXP16            |                                                                                                                                     |             |              |
| 0x1A:       | RAW12 + VP               |                                                                                                                                     |             |              |
| 0x1B:       | RAW10 - RAW8 DPCM        | RAW10 data from sensor is DPCM compressed into RAW8 before it is send to memory.                                                    |             |              |
|             |                          |                                                                                                                                     |             |              |
| 0x1C:       | JPEG8 + FSP              |                                                                                                                                     |             |              |
| 0x1D:       | JPEG8                    |                                                                                                                                     |             |              |
| 0x1E:       | RAW10 - RAW8             | RAW10 data from sensor is right shifted to produce RAW8 before it is send to memory                                                 |             |              |
| 0x1F:       | RAW8 DPCM12 - RAW12 + VP | Used predictor is selected by the DPCM_PRED bit.                                                                                    |             |              |
| 0x20:       | RAW10 - RAW8 ALAW        |                                                                                                                                     |             |              |
| 0x21:       | RAW8 DPCM10 - ALAW       |                                                                                                                                     |             |              |
| 1           | REGION_EN                | Enables the setting of regions of interest in the frame:<br>SOF region, EOF region and DAT region.<br>0x0: Disabled<br>0x1: Enabled | RW          | 0            |

| Bits | Field Name | Description                 | Type | Reset                      |
|------|------------|-----------------------------|------|----------------------------|
| 0    | CHAN_EN    | Enables the logical channel | RW   | 0x1 for LC0<br>0x0 for LC1 |
|      |            | 0x0: Disabled               |      | 0x0 for LC2                |
|      |            | 0x1: Enabled                |      | 0x0 for LC3                |

**Table 6-173. Register Call Summary for Register CCP2\_LCx\_CTRL**

## Camera ISP Environment

- Camera ISP CSI1/CCP2 Protocol and Data Formats: [0] [1] [2]

## Camera ISP Functional Description

- Camera ISP CSI1/CCP2B Protocol Layer: [3]
- Camera ISP CSI1/CCP2B Image Data Operating Modes and Alignment Constraints: [4] [5] [6]

## Camera ISP Basic Programming Model

- Camera ISP CSI1/CCP2B Register Accessibility During Frame Processing: [7]
- Camera ISP CSI1/CCP2B Enable/Disable the Hardware: [8] [9] [10]
- Camera ISP CSI1/CCP2B Select the Mode: MIPI CSI1 or CCP2B: [11] [12] [13]
- Camera ISP CSI1/CCP2B Video Port: [14] [15] [16]
- Camera ISP CSI1/CCP2B Region of Interest: [17] [18]
- Camera ISP CSI1/CCP2B CRC: [19] [20]
- Camera ISP CSI1/CCP2B Destination Format: [21]
- Camera ISP CSI1/CCP2B Frame Acquisition: [22] [23] [24] [25] [26] [27] [28] [29]
- Camera ISP CSI1/CCP2B Pixel Data Region: [30] [31]

## Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [32]

**Table 6-174. CCP2\_LCx\_CODE**

| Address Offset          | 0x0000 0054 + (x * 0x30)                                                                                                                                                                                                                                                                                                                                                                                                      | Index                 | x = 0 to 3      |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| Physical Address        | 0x480B C454 + (x * 0x30)                                                                                                                                                                                                                                                                                                                                                                                                      | Instance              | ISP_CCP2        |
| Description             | CODE REGISTER - LOGICAL CHANNEL x. This register sets the codes that are used in the 32-bit synchronization codes to recognize the logical channel, frame start, frame end, line start, and line end codes. This register applies for logical channel x only. The default values should not be modified. Updating this register with new codes under a flowing serial transmission on that channel causes unexpected results. |                       |                 |
| Type                    | RW                                                                                                                                                                                                                                                                                                                                                                                                                            |                       |                 |
| 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 |
| RESERVED                |                                                                                                                                                                                                                                                                                                                                                                                                                               | CHAN_ID               | FEC FSC LEC LSC |

| Bits  | Field Name | Description                                                                                                                                                      | Type | Reset                                                    |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------------------------------------------------------|
| 31:20 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                               | RW   | 0x000                                                    |
| 19:16 | CHAN_ID    | Logical channel x identifier<br>The channel identifier is located between bits 4 to 7 in the 32-bit synchronization codes.                                       | RW   | 0x0 for LC0<br>0x1 for LC1<br>0x2 for LC2<br>0x3 for LC3 |
| 15:12 | FEC        | Logical channel x frame end synchronization code identifier<br>The synchronization code identifier is between bits 0 to 3 in the 32-bit synchronization codes.   | RW   | 0x3                                                      |
| 11:8  | FSC        | Logical channel x frame start synchronization code identifier<br>The synchronization code identifier is between bits 0 to 3 in the 32-bit synchronization codes. | RW   | 0x2                                                      |
| 7:4   | LEC        | Logical channel x line end synchronization code identifier<br>The synchronization code identifier is between bits 0 to 3 in the 32-bit synchronization codes.    | RW   | 0x1                                                      |

| Bits | Field Name | Description                                                                                                                                                     | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3:0  | LSC        | Logical channel x line start synchronization code identifier<br>The synchronization code identifier is between bits 0 to 3 in the 32-bit synchronization codes. | RW   | 0x0   |

**Table 6-175. Register Call Summary for Register CCP2\_LCx\_CODE**

Camera ISP Basic Programming Model

- [Camera ISP CSI1/CCP2B Register Accessibility During Frame Processing: \[0\]](#)
- [Camera ISP CSI1/CCP2B Synchronization Codes: \[1\] \[2\] \[3\] \[4\] \[5\]](#)

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[6\]](#)

**Table 6-176. CCP2\_LCx\_STAT\_START**

|                         |                                                                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |            |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|------------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0058 + (x * 0x30)                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Index</b>    | x = 0 to 3 |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C458 + (x * 0x30)                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_CCP2   |  |  |  |  |  |  |
| <b>Description</b>      | STATUS LINE START REGISTER - LOGICAL CHANNEL x. This register is shadowed; modifications are taken into account after the next FSC synchronization code. |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |            |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |            |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | EOF                     | RESERVED              | SOF             |

| Bits  | Field Name | Description                                                                                                          | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                   | RW   | 0x0   |
| 27:16 | EOF        | Sets the vertical position of the EOF status lines in reference to the FSC synchronization code. From 0 to 4095.     | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                   | RW   | 0x0   |
| 11:0  | SOF        | Sets the vertical position of the EOF status lines in reference to the FSC synchronization code. Should always be 0. | RW   | 0x000 |

**Table 6-177. Register Call Summary for Register CCP2\_LCx\_STAT\_START**

Camera ISP Basic Programming Model

- [Camera ISP CSI1/CCP2B Register Accessibility During Frame Processing: \[0\]](#)
- [Camera ISP CSI1/CCP2B Video Port: \[1\]](#)
- [Camera ISP CSI1/CCP2B Status Data: \[2\] \[3\]](#)

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[4\]](#)

**Table 6-178. CCP2\_LCx\_STAT\_SIZE**

|                         |                                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |            |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|------------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 005C + (x * 0x30)                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Index</b>    | x = 0 to 3 |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C45C + (x * 0x30)                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_CCP2   |  |  |  |  |  |  |
| <b>Description</b>      | STATUS LINE SIZE REGISTER - LOGICAL CHANNEL x. This register is shadowed; modifications are taken into account after the next FSC synchronization code. |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |            |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |            |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | EOF                     | RESERVED              | SOF             |

| Bits  | Field Name | Description                                             | Type | Reset |
|-------|------------|---------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility. Read returns 0.      | RW   | 0x0   |
| 27:16 | EOF        | Sets the number of EOF status lines<br>From 0 to 4095   | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility. Read returns 0.      | RW   | 0x0   |
| 11:0  | SOF        | Sets the number of SOF status line(s)<br>From 0 to 4095 | RW   | 0x000 |

**Table 6-179. Register Call Summary for Register CCP2\_LCx\_STAT\_SIZE**

Camera ISP Basic Programming Model

- Camera ISP CSI1/CCP2B Register Accessibility During Frame Processing: [0]
- Camera ISP CSI1/CCP2B Video Port: [1]
- Camera ISP CSI1/CCP2B Status Data: [2] [3] [4]

Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [5]

**Table 6-180. CCP2\_LCx\_SOF\_ADDR**

|                         |                                                                                                                                                                                                                                                                                                                         |                       |                 |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| Address Offset          | 0x0000 0060 + (x * 0x30)                                                                                                                                                                                                                                                                                                | Index                 | x = 0 to 3      |
| Physical Address        | 0x480B C460 + (x * 0x30)                                                                                                                                                                                                                                                                                                | Instance              | ISP_CCP2        |
| Description             | SOF STATUS LINE MEMORY ADDRESS REGISTER - LOGICAL CHANNEL x. This register sets the 32-bit memory address where the SOF data are stored. The 5 LSBs are ignored; the address is aligned on a 32-byte boundary. This register is shadowed; modifications are taken into account after the next FSC synchronization code. |                       |                 |
| Type                    | RW                                                                                                                                                                                                                                                                                                                      |                       |                 |
| 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 |
| ADDR                    |                                                                                                                                                                                                                                                                                                                         |                       | RESERVED        |

| Bits | Field Name | Description                                                                        | Type | Reset     |
|------|------------|------------------------------------------------------------------------------------|------|-----------|
| 31:5 | ADDR       | 27 MSBs of the 32-bit address                                                      | RW   | 0x0000000 |
| 4:0  | RESERVED   | 5 LSBs of the 32-bit address<br>Write 0s for future compatibility. Read returns 0. | RW   | 0x0       |

**Table 6-181. Register Call Summary for Register CCP2\_LCx\_SOF\_ADDR**

Camera ISP Basic Programming Model

- Camera ISP CSI1/CCP2B Register Accessibility During Frame Processing: [0]
- Camera ISP CSI1/CCP2B Status Data: [1]

Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [2]

**Table 6-182. CCP2\_LCx\_EOF\_ADDR**

|                         |                                                                                                                                                                                                                                                                                                                         |                 |            |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0064 + (x * 0x30)                                                                                                                                                                                                                                                                                                | <b>Index</b>    | x = 0 to 3 |
| <b>Physical Address</b> | 0x480B C464 + (x * 0x30)                                                                                                                                                                                                                                                                                                | <b>Instance</b> | ISP_CCP2   |
| <b>Description</b>      | EOF STATUS LINE MEMORY ADDRESS REGISTER - LOGICAL CHANNEL x. This register sets the 32-bit memory address where the EOF data are stored. The 5 LSBs are ignored; the address is aligned on a 32-byte boundary. This register is shadowed; modifications are taken into account after the next FSC synchronization code. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                      |                 |            |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |          |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----------|---|---|---|---|---|
| 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 |
| ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | RESERVED |   |   |   |   |   |

| Bits | Field Name | Description                                                                        | Type | Reset     |
|------|------------|------------------------------------------------------------------------------------|------|-----------|
| 31:5 | ADDR       | 27 MSBs of the 32-bit address                                                      | RW   | 0x0000000 |
| 4:0  | RESERVED   | 5 LSBs of the 32-bit address<br>Write 0s for future compatibility. Read returns 0. | RW   | 0x00      |

**Table 6-183. Register Call Summary for Register CCP2\_LCx\_EOF\_ADDR**

Camera ISP Basic Programming Model

- [Camera ISP CSI1/CCP2B Register Accessibility During Frame Processing: \[0\]](#)
- [Camera ISP CSI1/CCP2B Status Data: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[2\]](#)

**Table 6-184. CCP2\_LCx\_DAT\_START**

|                         |                                                                                                                                                   |                 |            |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0068 + (x * 0x30)                                                                                                                          | <b>Index</b>    | x = 0 to 3 |
| <b>Physical Address</b> | 0x480B C468 + (x * 0x30)                                                                                                                          | <b>Instance</b> | ISP_CCP2   |
| <b>Description</b>      | DATA START REGISTER - LOGICAL CHANNEL x. This register is shadowed; modifications are taken into account after the next FSC synchronization code. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                |                 |            |

|          |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    | VERT |    |    |    |    |    |    |    |    |    | RESERVED |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------|------|--------|
| 31:28 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                         | RW   | 0x0    |
| 27:16 | VERT       | Sets the vertical position of the data in reference to the FSC synchronization code. From 0 to 4095 lines. | RW   | 0x000  |
| 15:0  | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                         | RW   | 0x0000 |

**Table 6-185. Register Call Summary for Register CCP2\_LCx\_DAT\_START**

Camera ISP Basic Programming Model

- [Camera ISP CSI1/CCP2B Video Port: \[0\]](#)
- [Camera ISP CSI1/CCP2B Pixel Data Region: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[2\]](#)

**Table 6-186. CCP2\_LCx\_DAT\_SIZE**

|                         |                                                                                                                                                  |                       |                 |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 006C + (x * 0x30)                                                                                                                         | <b>Index</b>          | x = 0 to 3      |
| <b>Physical Address</b> | 0x480B C46C + (x * 0x30)                                                                                                                         | <b>Instance</b>       | ISP_CCP2        |
| <b>Description</b>      | DATA SIZE REGISTER - LOGICAL CHANNEL x. This register is shadowed; modifications are taken into account after the next FSC synchronization code. |                       |                 |
| <b>Type</b>             | RW                                                                                                                                               |                       |                 |
| 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 |
| RESERVED                | VERT                                                                                                                                             |                       | RESERVED        |

| Bits  | Field Name | Description                                                                                         | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------|------|--------|
| 31:28 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                  | RW   | 0x0    |
| 27:16 | VERT       | Sets the vertical size of the data window<br>From 0 to 4095 lines. If VERT = 0, no data are output. | RW   | 0x000  |
| 15:0  | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                  | RW   | 0x0000 |

**Table 6-187. Register Call Summary for Register CCP2\_LCx\_DAT\_SIZE**

Camera ISP Basic Programming Model

- Camera ISP CSI1/CCP2B Register Accessibility During Frame Processing: [0]
- Camera ISP CSI1/CCP2B Video Port: [1]
- Camera ISP CSI1/CCP2B Pixel Data Region: [2]

Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [3]

**Table 6-188. CCP2\_LCx\_DAT\_PING\_ADDR**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                       |                 |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0070 + (x * 0x30)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Index</b>          | x = 0 to 3      |
| <b>Physical Address</b> | 0x480B C470 + (x * 0x30)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Instance</b>       | ISP_CCP2        |
| <b>Description</b>      | DATA MEMORY PING ADDRESS REGISTER - LOGICAL CHANNEL x. This register sets the 32-bit memory address where the pixel data are stored. The destination is double-buffered; this register sets the PING address. Double-buffering is enabled when the addresses CCP2_LC0_DAT_PING_ADDR and CCP2_LC0_DAT_PONG_ADDR are different. The 5 LSBs are ignored; the address is aligned on a 32-byte boundary. This register is shadowed; modifications are taken into account after the next FSC synchronization code. |                       |                 |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                       |                 |
| 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 |
| ADDR                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                       | RESERVED        |

| Bits | Field Name | Description                                                                        | Type | Reset     |
|------|------------|------------------------------------------------------------------------------------|------|-----------|
| 31:5 | ADDR       | 27 MSBs of the 32-bit address                                                      | RW   | 0x0000000 |
| 4:0  | RESERVED   | 5 LSBs of the 32-bit address<br>Write 0s for future compatibility. Read returns 0. | RW   | 0x00      |

**Table 6-189. Register Call Summary for Register CCP2\_LCx\_DAT\_PING\_ADDR**

Camera ISP Basic Programming Model

- Camera ISP CSI1/CCP2B Register Accessibility During Frame Processing: [0]
- Camera ISP CSI1/CCP2B Frame Acquisition: [1]
- Camera ISP CSI1/CCP2B Pixel Data Region: [2] [3] [4] [5]

Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [6]
- Camera ISP CCP2 Register Description: [7]

**Table 6-190. CCP2\_LCx\_DAT\_PONG\_ADDR**

| <b>Address Offset</b>   | 0x0000 0074 + (x * 0x30)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Index</b>                                                                       | x = 0 to 3      |           |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------|-----------|
| <b>Physical Address</b> | 0x480B C474 + (x * 0x30)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Instance</b>                                                                    | ISP_CCP2        |           |
| <b>Description</b>      | DATA MEMORY PONG ADDRESS REGISTER - LOGICAL CHANNEL x. This register sets the 32-bit memory address where the pixel data are stored. The destination is double-buffered; this register sets the PONG address. Double-buffering is enabled when the addresses CCP2_LC0_DAT_PING_ADDR and CCP2_LC0_DAT_PONG_ADDR are different. The 5 LSBs are ignored; the address is aligned on a 32-byte boundary. This register is shadowed; modifications are taken into account after the next FSC synchronization code. |                                                                                    |                 |           |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                    |                 |           |
| 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 |           |
| ADDR                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                    | RESERVED        |           |
| Bits                    | Field Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Description                                                                        | Type            | Reset     |
| 31:5                    | ADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 27 MSBs of the 32-bit address                                                      | RW              | 0x0000000 |
| 4:0                     | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 5 LSBs of the 32-bit address<br>Write Os for future compatibility. Read returns 0. | RW              | 0x00      |

**Table 6-191. Register Call Summary for Register CCP2\_LCx\_DAT\_PONG\_ADDR**

Camera ISP Basic Programming Model

- Camera ISP CSI1/CCP2B Register Accessibility During Frame Processing: [0]
- Camera ISP CSI1/CCP2B Frame Acquisition: [1]
- Camera ISP CSI1/CCP2B Pixel Data Region: [2] [3] [4] [5]

Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [6]
- Camera ISP CCP2 Register Description: [7]

**Table 6-192. CCP2\_LCx\_DAT\_OFST**

| <b>Address Offset</b>   | 0x0000 0078 + (x * 0x30)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <b>Index</b>                                                                                                                                                                                                                                     | x = 0 to 3      |           |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------|
| <b>Physical Address</b> | 0x480B C478 + (x * 0x30)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <b>Instance</b>                                                                                                                                                                                                                                  | ISP_CCP2        |           |
| <b>Description</b>      | DATA MEMORY ADDRESS OFFSET REGISTER - LOGICAL CHANNEL x. This register sets the offset, which is applied on the destination address after each line is written to memory. This register applies for both CCP2_LCx_DAT_PING_ADDR and CCP2_LCx_DAT_PONG_ADDR. For example, it enables 2D data transfers of the pixel data into a frame buffer. In such case, the pixel data and frame buffer data have the same data format. Note that the 5 LSBs are ignored: the offset shall be a multiple of 32 bytes. The use of this register is limited to the following data formats: YUV422 little-endian, YUV422 big-endian, RGB565, RGB444 + EXP16, RGB888 + EXP32. This register is shadowed; modifications are taken into account after the next FSC synchronization code. |                                                                                                                                                                                                                                                  |                 |           |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                  |                 |           |
| 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 |           |
| OFST                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                  | RESERVED        |           |
| Bits                    | Field Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Description                                                                                                                                                                                                                                      | Type            | Reset     |
| 31:5                    | OFST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Line offset programmed in bytes<br>If OFST = 0, the data are written contiguously in memory.<br>Otherwise, OFST sets the destination offset between the first pixel of the previous line and the first pixel of the current line. <sup>(1)</sup> | RW              | 0x0000000 |
| 4:0                     | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                               | RW              | 0x00      |

<sup>(1)</sup> An Interconnect access (read/write) is required to properly update the CCP2\_LCx\_DAT\_OFST register.

**Table 6-193. Register Call Summary for Register CCP2\_LCx\_DAT\_OFST**

Camera ISP Basic Programming Model

- Camera ISP CSI1/CCP2B Register Accessibility During Frame Processing: [0]
  - Camera ISP CSI1/CCP2B Pixel Data Region: [1] [2] [3] [4] [5] [6] [7] [8] [9] [10]

Camera ISP Register Manual

- Camera ISP CCP2 Register Summary: [11]

**Table 6-194. CCP2\_LCM\_CTRL**

|                         |                                                                                                                                           |                 |          |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 01D0                                                                                                                               |                 |          |
| <b>Physical Address</b> | 0x480B C5D0                                                                                                                               | <b>Instance</b> | ISP_CCP2 |
| <b>Description</b>      | Control register for the memory channel. It defines the data format of the source frame stored in memory and how this frame is processed. |                 |          |
| <b>Type</b>             | RW                                                                                                                                        |                 |          |

|          |          |          |          |          |            |          |          |          |          |          |          |            |          |    |    |    |    |    |    |    |            |               |          |          |         |   |   |   |   |   |   |
|----------|----------|----------|----------|----------|------------|----------|----------|----------|----------|----------|----------|------------|----------|----|----|----|----|----|----|----|------------|---------------|----------|----------|---------|---|---|---|---|---|---|
| 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 |
| DST_PACK | RESERVED | RESERVED | RESERVED | RESERVED | DST_FORMAT | SRC_PACK | RESERVED | RESERVED | RESERVED | RESERVED | RESERVED | SRC_FORMAT | RESERVED |    |    |    |    |    |    |    | BURST_SIZE | READ_THROTTLE | DST_PORT | RESERVED | CHAN_EN |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                          | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | DST_PACK   | Data is packed before it is sent to memory.<br>Applies to RAW6, RAW7, RAW10, and RAW12 only.<br>0x0: Disabled<br>0x1: Enabled                                                                                                                                                                        | RW   | 0x0   |
| 30    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 39    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 27    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 26:24 | DST_FORMAT | Output format selection<br>Not every combination of input and output formats is possible. See <a href="#">Table 6-25, Camera ISP CSI1/CCP2B Memory-to-Video Processing Hardware Supported Formats</a><br>0x0: RAW6<br>0x1: RAW7<br>0x2: RAW8<br>0x3: RAW10<br>0x4: RAW12<br>0x5: RAW14<br>0x6: RAW16 | RW   | 0x0   |
| 23    | SRC_PACK   | Data stored in memory is packed and must be unpacked.<br>0x0: Disabled<br>0x1: Enabled                                                                                                                                                                                                               | RW   | 0x0   |
| 22    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 21    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 19    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                   | RW   | 0x0   |

| Bits  | Field Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset |
|-------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 18:16 | SRC_FORMAT    | Data format of the data stored in memory<br>Because there is no header embedded in the data sent to memory, the user is responsible for choosing the correct format.<br>0x0: RAW6<br>0x1: RAW7<br>0x2: RAW8<br>0x3: RAW10<br>0x4: RAW12<br>0x5: RAW14<br>0x6: RAW16                                                                                                                                                                                                                               | RW   | 0x0   |
| 15:8  | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW   | 0x00  |
| 7:5   | BURST_SIZE    | Defines the burst size of the master read port<br>0x0: 1x 64-bit burst = single request<br>0x1: 2x 64-bit bursts<br>0x2: 4x 64-bit bursts<br>0x3: 8x 64-bit bursts<br>0x4: 16x 64-bit bursts<br>0x5: 32x 64-bit bursts                                                                                                                                                                                                                                                                            | RW   | 0x0   |
| 4:3   | READ_THROTTLE | Limit maximum data read speed for memory-to-memory operation.<br>0x0: Full speed. Throughput is limited by internal processing capabilities.<br>0x1: 1/2 speed<br>0x2: 1/4 speed<br>0x3: 1/8 speed                                                                                                                                                                                                                                                                                                | RW   | 0x0   |
| 2     | DST_PORT      | Select the destination port.<br>0x0: Data is sent to video port; it is always sent without compression or packing. The CCP2_LCM_CTRL.DST_PACK, CCP2_LCM_DST_ADDR and CCP2_LCM_DST_OFST registers have no effect.<br>0x1: Data is sent to memory.                                                                                                                                                                                                                                                  | RW   | 0x0   |
| 1     | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW   | 0x0   |
| 0     | CHAN_EN       | Enables the read from the memory channel<br>Before enabling the memory read channel, the software must:<br>- Disable the physical interface using the IF_EN bit<br>- Wait until disabling of the physical interface is effective (depends on the FRAME bit)<br>Read from memory starts when this bit is set; therefore, all CCP2_LCM_x registers must be configured correctly before the bit is set.<br>This bit is cleared by hardware at the end of the frame.<br>0x0: Disabled<br>0x1: Enabled | RW   | 0x0   |

**Table 6-195. Register Call Summary for Register CCP2\_LCM\_CTRL**

Camera ISP Functional Description

- [Camera ISP CSI1/CCP2B Memory Read Channel: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CSI1/CCP2B Read Data from Memory: \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\]](#)

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[21\]](#)
- [Camera ISP CCP2 Register Description: \[22\]](#)

**Table 6-196. CCP2\_LCM\_VSIZE**

|                         |                                          |                         |                 |                 |          |
|-------------------------|------------------------------------------|-------------------------|-----------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 01D4                              | <b>Physical Address</b> | 0x480B C5D4     | <b>Instance</b> | ISP_CCP2 |
| <b>Description</b>      | Memory channel vertical framing register |                         |                 |                 |          |
| <b>Type</b>             | RW                                       |                         |                 |                 |          |
| 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 |                 |          |
| RESERVED                | COUNT                                    |                         |                 | RESERVED        |          |

| Bits  | Field Name | Description                                                            | Type | Reset  |
|-------|------------|------------------------------------------------------------------------|------|--------|
| 31:29 | RESERVED   | Write 0s for future compatibility. Read returns 0.                     | RW   | 0x0    |
| 28:16 | COUNT      | Defines the line count to be read from memory<br>From 1 to 8191 lines. | RW   | 0x001  |
| 15:0  | RESERVED   | Write 0s for future compatibility. Read returns 0.                     | RW   | 0x0000 |

**Table 6-197. Register Call Summary for Register CCP2\_LCM\_VSIZE**

Camera ISP Functional Description

- [Camera ISP CSI1/CCP2B Memory Read Channel: \[0\]](#)

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[1\]](#)

**Table 6-198. CCP2\_LCM\_HSIZE**

|                         |                                                 |                         |                 |                 |          |
|-------------------------|-------------------------------------------------|-------------------------|-----------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 01D8                                     | <b>Physical Address</b> | 0x480B C5D8     | <b>Instance</b> | ISP_CCP2 |
| <b>Description</b>      | Memory read channel horizontal framing register |                         |                 |                 |          |
| <b>Type</b>             | RW                                              |                         |                 |                 |          |
| 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 |                 |          |
| RESERVED                | COUNT                                           | RESERVED                |                 | SKIP            |          |

| Bits  | Field Name | Description                                                                                                          | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:29 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                   | RW   | 0x0   |
| 28:16 | COUNT      | Horizontal count of pixels to output after the skipped pixels<br>Valid values: 1–8191                                | RW   | 0x001 |
| 15:13 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                   | RW   | 0x0   |
| 12:0  | SKIP       | Horizontal count of pixels to skip after the start of the line.<br>Valid values: 0–8191<br>0 disables pixel skipping | RW   | 0x000 |

**Table 6-199. Register Call Summary for Register CCP2\_LCM\_HSIZE**

Camera ISP Functional Description

- [Camera ISP CSI1/CCP2B Memory Read Channel: \[0\] \[1\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CSI1/CCP2B Read Data from Memory: \[2\] \[3\] \[4\] \[5\]](#)

**Table 6-199. Register Call Summary for Register CCP2\_LCM\_HSIZE (continued)**

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[6\]](#)
- [Camera ISP CCP2 Register Description: \[7\]](#)

**Table 6-200. CCP2\_LCM\_PREFETCH**

|                         |                                                                                                                                                                                                                         |                       |                 |          |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 01DC                                                                                                                                                                                                             |                       |                 |          |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C5DC                                                                                                                                                                                                             | <b>Instance</b>       | ISP_CCP2        |          |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register defines the amount of data to be fetched from memory. It must be consistent with the <a href="#">CCP2_LCM_HSIZE</a> register (see <a href="#">Section 6.5.3, CCP2 Receiver Basic Programming Model</a> ). |                       |                 |          |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                      |                       |                 |          |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED | HWORDS |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                               | Type | Reset   |
|-------|------------|-------------------------------------------------------------------------------------------|------|---------|
| 31:15 | RESERVED   | Write Os for future compatibility. Read returns 0.                                        | RW   | 0x00000 |
| 14:3  | HWORDS     | 64-bit words to read from memory for each line of the image<br>Possible values: 1 to 4095 | RW   | 0x001   |
| 2:0   | RESERVED   | Write Os for future compatibility. Read returns 0.                                        | RW   | 0x0     |

**Table 6-201. Register Call Summary for Register CCP2\_LCM\_PREFETCH**

Camera ISP Functional Description

- [Camera ISP CSI1/CCP2B Memory Read Channel: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CSI1/CCP2B Read Data from Memory: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[2\]](#)

**Table 6-202. CCP2\_LCM\_SRC\_ADDR**

|                         |                                                                                                                                                                                            |                       |                 |      |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 01E0                                                                                                                                                                                |                       |                 |      |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C5E0                                                                                                                                                                                | <b>Instance</b>       | ISP_CCP2        |      |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Memory channel source address register This register sets the 32-bit memory address where the pixel data are stored. The 5 LSBs are ignored; the address is aligned on a 32-byte boundary. |                       |                 |      |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                         |                       |                 |      |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | ADDR | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                        | Type | Reset     |
|------|------------|------------------------------------------------------------------------------------|------|-----------|
| 31:5 | ADDR       | 27 MSBs of the 32-bit address                                                      | RW   | 0x0000000 |
| 4:0  | RESERVED   | 5 LSBs of the 32-bit address<br>Write Os for future compatibility. Read returns 0. | RW   | 0x00      |

**Table 6-203. Register Call Summary for Register CCP2\_LCM\_SRC\_ADDR**

Camera ISP Functional Description

- [Camera ISP CSI1/CCP2B Memory Read Channel: \[0\] \[1\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CSI1/CCP2B Read Data from Memory: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[3\]](#)

**Table 6-204. CCP2\_LCM\_SRC\_OFST**

|                         |                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 01E4                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C5E4                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_CCP2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Memory channel source offset register. This register sets the offset, which is applied on the source address after each line is read from memory. For example, it enables 2D data transfers of the pixel data from a frame buffer. In such case, the pixel data and frame buffer data have the same data format. The 5 LSBs are ignored; the offset is a multiple of 32 bytes. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |  |  |          |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|----------|--|
| 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 |  |  |          |  |
| OFST                    |                         |                       |                 |  |  | RESERVED |  |

| Bits | Field Name | Description                                                                                                                                                                                                              | Type | Reset     |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | OFST       | Line offset programmed in bytes<br>If OFST = 0, the data are read contiguously from memory. Otherwise, OFST sets the source offset between the first pixel of the previous line and the first pixel of the current line. | RW   | 0x0000000 |
| 4:0  | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                       | RW   | 0x00      |

**Table 6-205. Register Call Summary for Register CCP2\_LCM\_SRC\_OFST**

Camera ISP Functional Description

- [Camera ISP CSI1/CCP2B Memory Read Channel: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CSI1/CCP2B Read Data from Memory: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP CCP2 Register Summary: \[2\]](#)

**Table 6-206. CCP2\_LCM\_DST\_ADDR**

|                         |                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 01E8                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C5E8                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_CCP2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Memory channel destination address. This register sets the 32-bit memory address where the pixel data are stored. The 5 LSBs are ignored; the address is aligned on a 32-byte boundary. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |  |  |          |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|----------|--|
| 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 |  |  |          |  |
| ADDR                    |                         |                       |                 |  |  | RESERVED |  |

| Bits | Field Name | Description                                                                                          | Type | Reset     |
|------|------------|------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | ADDR       | 27 MSBs of the 32-bit address.                                                                       | RW   | 0x0000000 |
| 4:0  | RESERVED   | 5 least significant bits of the 32-bit address<br>Write 0s for future compatibility. Read returns 0. | RW   | 0x00      |

**Table 6-207. Register Call Summary for Register CCP2\_LCM\_DST\_ADDR**
**Camera ISP Functional Description**

- [Camera ISP CSI1/CCP2B Memory Read Channel: \[0\]](#)

**Camera ISP Register Manual**

- [Camera ISP CCP2 Register Summary: \[1\]](#)
- [Camera ISP CCP2 Register Description: \[2\]](#)

**Table 6-208. CCP2\_LCM\_DST\_OFST**

| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0000 01EC                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |      |            |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x480B C5EC                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |      |            |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Memory channel destination offset register. This register sets the offset, which is applied on the destination address after each line is written to memory. For example, it enables 2D data transfers of the pixel data into a frame buffer. In such case, the pixel data and frame buffer data have the same data format. The 5 LSBs are ignored; the offset is a multiple of 32 bytes. |                                                                                                                                                                                                                                                                                                                                                       |      |            |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                       |      |            |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 20px;">31</td><td style="width: 20px;">30</td><td style="width: 20px;">29</td><td style="width: 20px;">28</td><td style="width: 20px;">27</td><td style="width: 20px;">26</td><td style="width: 20px;">25</td><td style="width: 20px;">24</td><td style="width: 20px;">23</td><td style="width: 20px;">22</td><td style="width: 20px;">21</td><td style="width: 20px;">20</td><td style="width: 20px;">19</td><td style="width: 20px;">18</td><td style="width: 20px;">17</td><td style="width: 20px;">16</td><td style="width: 20px;">15</td><td style="width: 20px;">14</td><td style="width: 20px;">13</td><td style="width: 20px;">12</td><td style="width: 20px;">11</td><td style="width: 20px;">10</td><td style="width: 20px;">9</td><td style="width: 20px;">8</td><td style="width: 20px;">7</td><td style="width: 20px;">6</td><td style="width: 20px;">5</td><td style="width: 20px;">4</td><td style="width: 20px;">3</td><td style="width: 20px;">2</td><td style="width: 20px;">1</td><td style="width: 20px;">0</td></tr> <tr> <td colspan="16" style="text-align: center;">OFST</td><td colspan="3" style="text-align: center;">RESERVED</td></tr> </table> |                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                       |      |            |    |    |    |    |    |    |    |    |    |    |    | 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 | OFST |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RESERVED |  |  |
| 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  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |
| OFST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                       |      |            |    |    |    |    |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |
| Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Field Name                                                                                                                                                                                                                                                                                                                                                                                | Description                                                                                                                                                                                                                                                                                                                                           | Type | Reset      |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |
| 31:5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | OFST                                                                                                                                                                                                                                                                                                                                                                                      | Line offset programmed in bytes<br>If OFST = 0, the data are written contiguously to memory if possible. At the end of a line, only full 32-bit words are written, eventually creating gaps at the end of lines.<br>Otherwise, OFST sets the destination offset between the first pixel of the previous line and the first pixel of the current line. | RW   | 0x00000000 |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |
| 4:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                  | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                    | RW   | 0x00       |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |

**Table 6-209. Register Call Summary for Register CCP2\_LCM\_DST\_OFST**
**Camera ISP Functional Description**

- [Camera ISP CSI1/CCP2B Memory Read Channel: \[0\]](#)

**Camera ISP Register Manual**

- [Camera ISP CCP2 Register Summary: \[1\]](#)
- [Camera ISP CCP2 Register Description: \[2\]](#)

## 6.6.4 Camera ISP CCDC Registers

### 6.6.4.1 Camera ISP CCDC Register Summary

**Table 6-210. ISP\_CCDC Register Summary**

| Register Name   | Type | Register Width (Bits) | Address Offset | Physical Address |
|-----------------|------|-----------------------|----------------|------------------|
| CCDC_PID        | R    | 32                    | 0x0000 0000    | 0x480B C600      |
| CCDC_PCR        | RW   | 32                    | 0x0000 0004    | 0x480B C604      |
| CCDC_SYN_MODE   | RW   | 32                    | 0x0000 0008    | 0x480B C608      |
| CCDC_HD_VD_WID  | RW   | 32                    | 0x0000 000C    | 0x480B C60C      |
| CCDC_PIX_LINES  | RW   | 32                    | 0x0000 0010    | 0x480B C610      |
| CCDC_HORZ_INFO  | RW   | 32                    | 0x0000 0014    | 0x480B C614      |
| CCDC_VERT_START | RW   | 32                    | 0x0000 0018    | 0x480B C618      |
| CCDC_VERT_LINES | RW   | 32                    | 0x0000 001C    | 0x480B C61C      |
| CCDC_CULLING    | RW   | 32                    | 0x0000 0020    | 0x480B C620      |
| CCDC_HSIZE_OFF  | RW   | 32                    | 0x0000 0024    | 0x480B C624      |

**Table 6-210. ISP\_CCDC Register Summary (continued)**

| Register Name                  | Type | Register Width (Bits) | Address Offset          | Physical Address        |
|--------------------------------|------|-----------------------|-------------------------|-------------------------|
| CCDC_SDOFST                    | RW   | 32                    | 0x0000 0028             | 0x480B C628             |
| CCDC_SDR_ADDR                  | RW   | 32                    | 0x0000 002C             | 0x480B C62C             |
| CCDC_CLAMP                     | RW   | 32                    | 0x0000 0030             | 0x480B C630             |
| CCDC_DCSUB                     | RW   | 32                    | 0x0000 0034             | 0x480B C634             |
| CCDC_COLPTN                    | RW   | 32                    | 0x0000 0038             | 0x480B C638             |
| CCDC_BLKCMPP                   | RW   | 32                    | 0x0000 003C             | 0x480B C63C             |
| CCDC_FPC                       | RW   | 32                    | 0x0000 0040             | 0x480B C640             |
| CCDC_FPC_ADDR                  | RW   | 32                    | 0x0000 0044             | 0x480B C644             |
| CCDC_VDINT                     | RW   | 32                    | 0x0000 0048             | 0x480B C648             |
| CCDC_ALAW                      | RW   | 32                    | 0x0000 004C             | 0x480B C64C             |
| CCDC_REC656IF                  | RW   | 32                    | 0x0000 0050             | 0x480B C650             |
| CCDC_CFG                       | RW   | 32                    | 0x0000 0054             | 0x480B C654             |
| CCDC_FMTCFG                    | RW   | 32                    | 0x0000 0058             | 0x480B C658             |
| CCDC_FMT_HORZ                  | RW   | 32                    | 0x0000 005C             | 0x480B C65C             |
| CCDC_FMT_VERT                  | RW   | 32                    | 0x0000 0060             | 0x480B C660             |
| CCDC_FMT_ADDR_i <sup>(1)</sup> | RW   | 32                    | 0x0000 0064 + (i * 0x4) | 0x480B C664 + (i * 0x4) |
| CCDC_PRGEVEN0                  | RW   | 32                    | 0x0000 0084             | 0x480B C684             |
| CCDC_PRGEVEN1                  | RW   | 32                    | 0x0000 0088             | 0x480B C688             |
| CCDC_PRGODD0                   | RW   | 32                    | 0x0000 008C             | 0x480B C68C             |
| CCDC_PRGODD1                   | RW   | 32                    | 0x0000 0090             | 0x480B C690             |
| CCDC_VP_OUT                    | RW   | 32                    | 0x0000 0094             | 0x480B C694             |
| CCDC_LSC_CONFIG                | RW   | 32                    | 0x0000 0098             | 0x480B C698             |
| CCDC_LSC_INITIAL               | RW   | 32                    | 0x0000 009C             | 0x480B C69C             |
| CCDC_LSC_TABLE_BASE            | RW   | 32                    | 0x0000 00A0             | 0x480B C6A0             |
| CCDC_LSC_TABLE_OFFSET          | RW   | 32                    | 0x0000 00A4             | 0x480B C6A4             |

<sup>(1)</sup> i = 0 to 7

#### 6.6.4.2 Camera ISP CCDC Register Description

**Table 6-211. CCDC\_PID**

|                         |                         |                       |                 |          |     |     |      |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|----------|-----|-----|------|--|--|--|--|--|--|--|
| Address Offset          | 0x0000 0000             |                       |                 |          |     |     |      |  |  |  |  |  |  |  |
| Physical Address        | 0x480B C600             |                       |                 |          |     |     |      |  |  |  |  |  |  |  |
| Description             | PERIPHERAL ID REGISTER  |                       |                 |          |     |     |      |  |  |  |  |  |  |  |
| Type                    | R                       |                       |                 |          |     |     |      |  |  |  |  |  |  |  |
| 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 | RESERVED | TID | CID | PREV |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                         | Type | Reset            |
|-------|------------|-----------------------------------------------------|------|------------------|
| 31:24 | RESERVED   | Write 0s for future compatibility. Reads returns 0. | R    | 0x00             |
| 23:16 | TID        | Peripheral identification: CCDC module              | R    | 0x01             |
| 15:8  | CID        | Class identification: Camera ISP                    | R    | 0xFE             |
| 7:0   | PREV       | Peripheral revision number                          | R    | TI internal data |

**Table 6-212. Register Call Summary for Register CCDC\_PID**

Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[0\]](#)

**Table 6-213. CCDC\_PCR**

|                       |                             |                         |             |                 |          |
|-----------------------|-----------------------------|-------------------------|-------------|-----------------|----------|
| <b>Address Offset</b> | 0x0000 0004                 | <b>Physical Address</b> | 0x480B C604 | <b>Instance</b> | ISP_CCDC |
| <b>Description</b>    | PERIPHERAL CONTROL REGISTER |                         |             |                 |          |
| <b>Type</b>           | RW                          |                         |             |                 |          |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                          | Type | Reset     |
|------|------------|----------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:4 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                               | RW   | 0x0000000 |
| 3    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                   | RW   | 0x0       |
| 2    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                   | RW   | 0x0       |
| 1    | BUSY       | CCDC module busy.<br>0x0: Module is not busy.<br>0x1: Module is busy.                                                | R    | 0x0       |
| 0    | ENABLE     | CCDC module enable.<br>This bit is latched by VD (start of frame)<br><br>0x0: Disable module.<br>0x1: Enable module. | RW   | 0x0       |

**Table 6-214. Register Call Summary for Register CCDC\_PCR**

Camera ISP Basic Programming Model

- [Camera ISP CCDC Enable/Disable Hardware: \[0\] \[1\] \[2\]](#)
- [Camera ISP CCDC Status Checking: \[3\] \[4\] \[5\]](#)
- [Camera ISP CCDC Register Accessibility During Frame Processing: \[6\]](#)
- [Camera ISP CCDC Interframe Operations: \[7\]](#)

Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[8\]](#)

**Table 6-215. CCDC\_SYN\_MODE**

|                       |                            |                         |             |                 |          |
|-----------------------|----------------------------|-------------------------|-------------|-----------------|----------|
| <b>Address Offset</b> | 0x0000 0008                | <b>Physical Address</b> | 0x480B C608 | <b>Instance</b> | ISP_CCDC |
| <b>Description</b>    | SYNC and mode set register |                         |             |                 |          |
| <b>Type</b>           | RW                         |                         |             |                 |          |

|          |    |    |    |    |    |    |    |         |        |     |        |         |     |        |       |         |         |         |       |        |       |       |         |         |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|---------|--------|-----|--------|---------|-----|--------|-------|---------|---------|---------|-------|--------|-------|-------|---------|---------|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    | SDR2RSZ | VP2SDR | WEN | VDHDEN | FLDSTAT | LPF | INPMOD | PACK8 | DATASIZ | FLDMODE | DATAPOL | EXWEN | FLDPOL | HDPOL | VDPOL | FLDDOUT | VDHDOUT |   |   |   |   |   |   |   |

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:20 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x000 |
| 19    | SDR2RSZ    | Memory port output into the RESIZER input.<br>Controls whether or not the memory port output data are forwarded to the RESIZER module input port. This does not depend on the state of the <a href="#">CCDC_SYN_MODE.WEN</a> bit.<br><br>This bit must only be set if the CCDC module receives directly YUV422 data. The input frame size to the RESIZER module is the same as the output frame size to the memory port.<br>The data are simultaneously written to memory if the WEN bit is set while sending the same data to the RESIZER module.<br>The PREVIEW module can also write to the RESIZER module: this bit takes precedence over the PREVIEW module settings.<br>This bit is latched by the VS sync pulse.<br><br>0x0: Disable<br>0x1: Enable | RW   | 0x0   |
| 18    | VP2SDR     | Video port output enable to the output formatter..<br>Controls whether the video port data is forwarded to the output formatter or not. If <a href="#">CCDC_SYN_MODE .WEN= 1</a> , the video port data is written to memory.<br>Note that if field is set, then SDRAM line (VERT_START.SLVx) and pixel start (HORZ_INFO.SPH) are with respect to the video port output (and not the original input)<br>This bit field is latched by the VS sync pulse.<br><br>0x0: Disable<br>0x1: Enable                                                                                                                                                                                                                                                                  | RW   | 0x0   |
| 17    | WEN        | Data write enable.<br>Controls whether the CCDC module output data are written to memory or not.<br>This bit field is latched by the VS sync pulse.<br><br>0x0: Disable<br>0x1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0   |
| 16    | VDHDEN     | Timing generator enable.<br>If HS/VS sync pulses are defined as output signals, activates the internal timing generator. If HS/VS sync pulses are defined as input signals, activates internal timing generator to synchronize with HS/VS. This bit must be set to 1 when HS and VS signals are used.<br><br>0x0: Disable<br>0x1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 15    | FLDSTAT    | cam_fld signal status.<br>This bit field applies only if the CCDC module is configured to work in interlaced mode:<br><a href="#">CCDC_SYN_MODE.FLDMODE</a> = "interlaced". It indicates the status of the current field.<br><br>0x0: Odd field<br>0x1: Even field                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R    | 0x0   |
| 14    | LPF        | Three-tap low pass (antialiasing) filter enable.<br>This bit field is latched by the VS sync pulse.<br><br>0x0: Filter is disabled.<br>0x1: Filter is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 13:12       | INPMOD            | cam_d format in SYNC mode.<br>Sets the data input format.<br><br>0x0: Raw data<br>0x1: YCbCr data on 16 bits. It is required to enable the 8 to 16-bit bridge in the <a href="#">ISP_CTRL</a> register.<br>0x2: YCbCr data on 8 bits.                                                                                  | RW          | 0x0          |
| 11          | PACK8             | Data packing.<br>Sets the data packing configuration when the data is written to memory.<br><br>0x0: Normal mode: 16 bits/pixel.<br>0x1: Pack mode: 8 bits/pixel.                                                                                                                                                      | RW          | 0x0          |
| 10:8        | DATOSIZ           | cam_d signal width in SYNC mode.<br>Valid only when <a href="#">CCDC_SYN_MODE</a> .INPMOD = "raw data".<br><br>0x0: cam_d is 8 bits but the 8 to 16-bit bridge is enabled in the <a href="#">ISP_CTRL</a> register.<br>0x4: cam_d is 12 bits<br>0x5: cam_d is 11 bits<br>0x6: cam_d is 10 bits<br>0x7: cam_d is 8 bits | RW          | 0x0          |
| 7           | FLDMODE           | cam_fld signal mode.<br><br>0x0: Progressive mode. cam_fld not used.<br>0x1: Interlaced mode. cam_fld used.                                                                                                                                                                                                            | RW          | 0x0          |
| 6           | DATAPOL           | cam_d signal polarity.<br><br>0x0: Normal<br>0x1: One's complement                                                                                                                                                                                                                                                     | RW          | 0x0          |
| 5           | EXWEN             | External write enable selection.<br>The cam_wen signal can be used as an external memory write-enable signal. The data is stored to memory only if cam_hs, cam_vs and cam_wen signals are asserted.<br><br>0x0: cam_wen is not used.<br>0x1: cam_wen is used                                                           | RW          | 0x0          |
| 4           | FLDPOL            | cam_fld signal polarity.<br><br>0x0: Positive<br>0x1: Negative                                                                                                                                                                                                                                                         | RW          | 0x0          |
| 3           | HDPOL             | Sets the cam_hs signal polarity.<br><br>0x0: Positive<br>0x1: Negative                                                                                                                                                                                                                                                 | RW          | 0x0          |
| 2           | VDPOL             | cam_vs signal polarity<br><br>0x0: Positive<br>0x1: Negative                                                                                                                                                                                                                                                           | RW          | 0x0          |
| 1           | FLDOUT            | cam_fld signal direction.<br><br>0x0: Input<br>0x1: Output                                                                                                                                                                                                                                                             | RW          | 0x0          |
| 0           | VDHDOUT           | cam_hs and cam_vs signal directions.<br><br>0x0: Input<br>0x1: Output                                                                                                                                                                                                                                                  | RW          | 0x0          |

**Table 6-216. Register Call Summary for Register CCDC\_SYN\_MODE**

|                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Camera ISP Environment             | <ul style="list-style-type: none"> <li><a href="#">Camera ISP ITU-R BT.656 Protocol and Data Formats (8, 10 Bits): [0]</a></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Camera ISP Functional Description  | <ul style="list-style-type: none"> <li><a href="#">Camera ISP CCDC Block Diagram: [1] [2] [3] [4] [5] [6]</a></li> <li><a href="#">Camera ISP CCDC Functional Operations: [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23]</a></li> <li><a href="#">Camera ISP VPBE Resizer Input and Output Interfaces: [24]</a></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Camera ISP Basic Programming Model | <ul style="list-style-type: none"> <li><a href="#">Camera ISP CCDC Register Setup: [25] [26] [27] [28] [29] [30] [31] [32] [33] [34] [35] [36] [37] [38] [39] [40] [41] [42] [43] [44] [45] [46] [47] [48] [49] [50] [51]</a></li> <li><a href="#">Camera ISP CCDC Pixel Selection (Framing) Register Dependencies: [52]</a></li> <li><a href="#">Camera ISP CCDC Events and Status Checking: [53]</a></li> <li><a href="#">Camera ISP CCDC CCDC_VD0_IRQ and CCDC_VD1_IRQ Interrupts: [54] [55] [56]</a></li> <li><a href="#">Camera ISP CCDC Register Accessibility During Frame Processing: [57] [58] [59] [60] [61] [62] [63] [64] [65]</a></li> <li><a href="#">Camera ISP CCDC Image-Sensor Configuration: [66] [67] [68] [69] [70] [71] [72] [73] [74] [75] [76] [77] [78] [79] [80] [81] [82] [83] [84] [85] [86] [87]</a></li> <li><a href="#">Camera ISP CCDC Image-Signal Processing: [88] [89] [90] [91] [92] [93] [94] [95]</a></li> </ul> |
| Camera ISP Register Manual         | <ul style="list-style-type: none"> <li><a href="#">Camera ISP CCDC Register Summary: [96]</a></li> <li><a href="#">Camera ISP CCDC Register Description: [97] [98] [99] [100] [101] [102] [103] [104] [105] [106]</a></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

**Table 6-217. CCDC\_HD\_VD\_WID**

|                         |                             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 000C                 |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C60C                 |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | SYNC WIDTH CONTROL REGISTER |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                          |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | HDW                         | RESERVED              | VDW             |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                   | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                        | RW   | 0x0   |
| 27:16 | HDW        | Sets the width of the HS sync pulse if set as output.<br>The width of the pulse is (HDW+1) pixel clocks. Not used when HS/VS sync pulses are input signals ( <a href="#">CCDC_SYN_MODE.VDHDOOUT = 0</a> ).<br>This bit field is latched by the VS sync pulse. | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                        | RW   | 0x0   |
| 11:0  | VDW        | Sets the width of the VS sync pulse is set as output.<br>The width of the pulse is (VDW+1) lines. Not used when HS/VS sync pulses are input signals ( <a href="#">CCDC_SYN_MODE.VDHDOOUT = 0</a> ).<br>This bit field is latched by the VS sync pulse.        | RW   | 0x000 |

**Table 6-218. Register Call Summary for Register CCDC\_HD\_VD\_WID**

|                                    |                                                                                                                                                                                                                                                                                 |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Camera ISP Functional Description  | <ul style="list-style-type: none"> <li><a href="#">Camera ISP CCDC Functional Operations: [0] [1]</a></li> </ul>                                                                                                                                                                |
| Camera ISP Basic Programming Model | <ul style="list-style-type: none"> <li><a href="#">Camera ISP CCDC Register Setup: [2]</a></li> <li><a href="#">Camera ISP CCDC Register Accessibility During Frame Processing: [3]</a></li> <li><a href="#">Camera ISP CCDC Image-Sensor Configuration: [4] [5]</a></li> </ul> |
| Camera ISP Register Manual         | <ul style="list-style-type: none"> <li><a href="#">Camera ISP CCDC Register Summary: [6]</a></li> </ul>                                                                                                                                                                         |

**Table 6-219. CCDC\_PIX\_LINES**

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0010             | <b>Instance</b>       | ISP_CCDC        |
| <b>Physical Address</b> | 0x480B C610             |                       |                 |
| <b>Description</b>      | SIZE CONTROL REGISTER   |                       |                 |
| <b>Type</b>             | RW                      |                       |                 |
| 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 |
|                         | PPLN                    |                       | HLPFR           |

  

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | PPLN       | Pixels per line<br>Sets the number of pixel clock periods in one line. HD period = (PPLN + 1) pixel clocks. Not used when HS/VS sync pulses are input signals ( <a href="#">CCDC_SYN_MODE.VDHDOOUT = 0</a> ).<br>This bit field is latched by the VS sync pulse.                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x0000 |
| 15:0  | HLPFR      | Half line per field or frame<br>Sets the number of half lines per frame or field. VD period = (HLPFR + 1)/2 lines. Not used when HS/VS sync pulses are input signals ( <a href="#">CCDC_SYN_MODE.VDHDOOUT = 0</a> ).<br>Sets the internal timing generator to generate the correct number of HS pulses in between two VS pulses. If the sensor is interlaced, with a total of N lines, then this field must be set to N. This means that N half lines are written for each field. If the sensor is progressive, then this register must be set to be twice the number of lines to be written. For example, if sensor outputs N lines, this field must be set to 2N.<br>This bit field is latched by the VS sync pulse. | RW   | 0x0000 |

**Table 6-220. Register Call Summary for Register CCDC\_PIX\_LINES**

Camera ISP Functional Description
 

- [Camera ISP CCDC Functional Operations: \[0\] \[1\]](#)

Camera ISP Basic Programming Model
 

- [Camera ISP CCDC Register Setup: \[2\]](#)
- [Camera ISP CCDC Register Accessibility During Frame Processing: \[3\]](#)
- [Camera ISP CCDC Image-Sensor Configuration: \[4\] \[5\] \[6\]](#)

Camera ISP Register Manual
 

- [Camera ISP CCDC Register Summary: \[7\]](#)

**Table 6-221. CCDC\_HORZ\_INFO**

|                         |                                |                       |                 |
|-------------------------|--------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0014                    | <b>Instance</b>       | ISP_CCDC        |
| <b>Physical Address</b> | 0x480B C614                    |                       |                 |
| <b>Description</b>      | HORIZONTAL PIXEL INFO REGISTER |                       |                 |
| <b>Type</b>             | RW                             |                       |                 |
| 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 |
| RESERVED                | SPH                            | RESERVED              | NPH             |

| Bits  | Field Name | Description                                                                                                                                                                           | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31    | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                | RW   | 0x0    |
| 30:16 | SPH        | Start pixel horizontal<br>Sets the pixel clock position at which data output to memory begins. It is measured from the start of HS. This bit field is latched by the VS sync pulse.   | RW   | 0x0000 |
| 15    | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                | RW   | 0x0    |
| 14:0  | NPH        | Number of pixels horizontal<br>Sets the number of horizontal pixels output to memory.<br>The number of pixels output is (NPH + 1).<br>This bit field is latched by the VS sync pulse. | RW   | 0x0100 |

**Table 6-222. Register Call Summary for Register CCDC\_HORZ\_INFO**

Camera ISP Functional Description

- Camera ISP CCDC Functional Operations: [0] [1]

Camera ISP Basic Programming Model

- Camera ISP CCDC Register Setup: [2]
- Camera ISP CCDC Register Accessibility During Frame Processing: [3] [4]
- Camera ISP CCDC Image-Signal Processing: [5] [6]

Camera ISP Register Manual

- Camera ISP CCDC Register Summary: [7]

**Table 6-223. CCDC\_VERT\_START**

|                  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 0018 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | 0x480B C618 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | INSTANCE    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | ISP_CCDC    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| 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 |  |  |  |  |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                      | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31    | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                           | RW   | 0x0    |
| 30:16 | SLV0       | Start line vertical - field0<br>Sets the line at which data output to memory begins. It is measured from the start of the VS sync pulse.<br>This bit field is latched by the VS sync pulse.                                                      | RW   | 0x0000 |
| 15    | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                           | RW   | 0x0    |
| 14:0  | SLV1       | Start line vertical - field1<br>Sets the line at which data output to memory begins. It is measured from the start of the VS sync pulse. For a progressive sensor, this bit field is ignored.<br>This bit field is latched by the VS sync pulse. | RW   | 0x0000 |

**Table 6-224. Register Call Summary for Register CCDC\_VERT\_START**

## Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations: \[0\] \[1\] \[2\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[3\]](#)
- [Camera ISP CCDC Register Accessibility During Frame Processing: \[4\] \[5\] \[6\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[7\] \[8\] \[9\]](#)

## Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[10\]](#)

**Table 6-225. CCDC\_VERT\_LINES**

|                         |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |
|-------------------------|-------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 001C                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |
| <b>Physical Address</b> | 0x480B C61C                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_CCDC |
| <b>Description</b>      | VERTICAL LINE NUMBER REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |
| <b>Type</b>             | RW                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | NLV |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:15       | RESERVED          | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                            | RW          | 0x00000      |
| 14:0        | NLV               | Number of lines - vertical direction<br>Sets the number of vertical lines output to memory. The number of lines output is (NLV + 1).<br>This bit is latched by the VS sync pulse. | RW          | 0x0000       |

**Table 6-226. Register Call Summary for Register CCDC\_VERT\_LINES**

## Camera ISP Functional Description

- [Camera ISP CCDC Block Diagram: \[0\]](#)
- [Camera ISP CCDC Functional Operations: \[1\] \[2\] \[3\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[4\]](#)
- [Camera ISP CCDC Register Accessibility During Frame Processing: \[5\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[6\]](#)

## Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[7\]](#)

**Table 6-227. CCDC\_CULLING**

|                         |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |
|-------------------------|-----------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 0020           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |
| <b>Physical Address</b> | 0x480B C620           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_CCDC |
| <b>Description</b>      | CULL CONTROL REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |
| <b>Type</b>             | RW                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |

|         |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|---------|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 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 |
| CULHEVN |    |    |    |    |    |    |    | CULHODD |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |   |   | CULV |   |   |   |   |   |   |   |

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | CULHEVN    | Horizontal culling patterns for even lines.<br>Sets an 8-bit mask (0:cull, 1:retain). The LSB is the 1st pixel and the MSB is the 8th pixel. Then, the pattern repeats.<br>This bit field is latched by the VS sync pulse. | RW   | 0xFF  |
| 23:16 | CULHODD    | Horizontal culling patterns for odd lines.<br>Sets an 8-bit mask (0:cull, 1:retain). The LSB is the 1st pixel and the MSB is the 8th pixel. Then, the pattern repeats.<br>This bit field is latched by the VS sync pulse.  | RW   | 0xFF  |
| 15:8  | RESERVED   | Write Os for future compatibility.<br>Reads returns 0.                                                                                                                                                                     | RW   | 0x00  |
| 7:0   | CULV       | Vertical culling pattern.<br>Sets an 8-bit mask (0:cull, 1:retain). The LSB is the 1st line and the MSB is the 8th line. Then, the pattern repeats.<br>This bit field is latched by the VS sync pulse.                     | RW   | 0xFF  |

**Table 6-228. Register Call Summary for Register CCDC\_CULLING**

## Camera ISP Functional Description

- Camera ISP CCDC Functional Operations: [0] [1] [2] [3] [4] [5] [6] [7]

## Camera ISP Basic Programming Model

- Camera ISP CCDC Register Setup: [8]
- Camera ISP CCDC Register Accessibility During Frame Processing: [9]
- Camera ISP CCDC Image-Signal Processing: [10] [11] [12] [13]

## Camera ISP Register Manual

- Camera ISP CCDC Register Summary: [14]

**Table 6-229. CCDC\_HSIZE\_OFF**

|                         |                          |  |  |  |  |  |  |  |                       |                 |          |  |  |  |  |          |  |  |  |  |  |  |
|-------------------------|--------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|----------|--|--|--|--|----------|--|--|--|--|--|--|
| Address Offset          | 0x0000 0024              |  |  |  |  |  |  |  |                       |                 |          |  |  |  |  |          |  |  |  |  |  |  |
| Physical Address        | 0x480B C624              |  |  |  |  |  |  |  |                       |                 | Instance |  |  |  |  | ISP_CCDC |  |  |  |  |  |  |
| Description             | HORIZONTAL SIZE REGISTER |  |  |  |  |  |  |  |                       |                 |          |  |  |  |  |          |  |  |  |  |  |  |
| Type                    | RW                       |  |  |  |  |  |  |  |                       |                 |          |  |  |  |  |          |  |  |  |  |  |  |
| 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 |          |  |  |  |  |          |  |  |  |  |  |  |
| RESERVED                |                          |  |  |  |  |  |  |  |                       |                 |          |  |  |  |  | LNOFST   |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write Os for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0x0000 |
| 15:0  | LNOFST     | Line offset.<br>Sets the offset for each output line to memory. The offset must be a multiple of 32 bytes: the 5 least significant bits are ignored. Usually the line offset is equal to the line length in bytes, that is, the line length must be a multiple of 32 bytes. If LNOFST = 0, the data is written again and again over the same line.<br>For optimal performance in the system, the address offset must be on a 256-byte boundary.<br>This bit field is latched by the VS sync pulse. | RW   | 0x0000 |

**Table 6-230. Register Call Summary for Register CCDC\_HSIZE\_OFF**

## Camera ISP Functional Description

- Camera ISP CCDC Block Diagram: [0]
- Camera ISP CCDC Functional Operations: [1]

**Table 6-230. Register Call Summary for Register CCDC\_HSIZE\_OFF (continued)**

Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[2\]](#)
- [Camera ISP CCDC Register Accessibility During Frame Processing: \[3\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[4\]](#)

Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[5\]](#)

**Table 6-231. CCDC\_SDOFST**

|                       |                        |                         |             |                 |          |
|-----------------------|------------------------|-------------------------|-------------|-----------------|----------|
| <b>Address Offset</b> | 0x0000 0028            | <b>Physical Address</b> | 0x480B C628 | <b>Instance</b> | ISP_CCDC |
| <b>Description</b>    | MEMORY OFFSET REGISTER |                         |             |                 |          |
| <b>Type</b>           | RW                     |                         |             |                 |          |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |       |        |        |        |        |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-------|--------|--------|--------|--------|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FIINV | FOFST | LOFST0 | LOFST1 | LOFST2 | LOFST3 |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                      | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:15 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                           | RW   | 0x00000 |
| 14    | FIINV      | Field identification signal inverse<br>This bit field is latched by the VS sync pulse.<br><br>0x0: Non inverse<br>0x1: Inverse                                                                                                                                   | RW   | 0x0     |
| 13:12 | FOFST      | Line offset value<br>This bit field is latched by the VS sync pulse.<br><br>0x0: +1 line<br>0x1: +2 lines<br>0x2: +3 lines<br>0x3: +4 lines                                                                                                                      | RW   | 0x0     |
| 11:9  | LOFST0     | Line offset values of even lines and even fields<br>(field id = 0).<br>This bit field is latched by the VS sync pulse.<br><br>0x0: +1 line<br>0x1: +2 lines<br>0x2: +3 lines<br>0x3: +4 lines<br>0x4: -1 line<br>0x5: -2 lines<br>0x6: -3 lines<br>0x7: -4 lines | RW   | 0x0     |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                         | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 8:6  | LOFST1     | <p>Line offset values of odd lines and even fields (field id = 0).<br/>           This bit field is latched by the VS sync pulse.</p> <p>0x0: +1 line<br/>           0x1: +2 lines<br/>           0x2: +3 lines<br/>           0x3: +4 lines<br/>           0x4: -1 line<br/>           0x5: -2 lines<br/>           0x6: -3 lines<br/>           0x7: -4 lines</p> | RW   | 0x0   |
| 5:3  | LOFST2     | <p>Line offset values of even lines and odd fields (field id = 1).<br/>           This bit field is latched by the VS sync pulse.</p> <p>0x0: +1 line<br/>           0x1: +2 lines<br/>           0x2: +3 lines<br/>           0x3: +4 lines<br/>           0x4: -1 line<br/>           0x5: -2 lines<br/>           0x6: -3 lines<br/>           0x7: -4 lines</p> | RW   | 0x0   |
| 2:0  | LOFST3     | <p>Line offset values of odd lines and odd fields (field id = 1).<br/>           This bit field is latched by the VS sync pulse.</p> <p>0x0: +1 line<br/>           0x1: +2 lines<br/>           0x2: +3 lines<br/>           0x3: +4 lines<br/>           0x4: -1 line<br/>           0x5: -2 lines<br/>           0x6: -3 lines<br/>           0x7: -4 lines</p>  | RW   | 0x0   |

**Table 6-232. Register Call Summary for Register CCDC\_SDOFST**

## Camera ISP Functional Description

- Camera ISP CCDC Functional Operations: [0] [1] [2] [3] [4] [5] [6] [7]

## Camera ISP Basic Programming Model

- Camera ISP CCDC Register Setup: [8]
- Camera ISP CCDC Register Accessibility During Frame Processing: [9]
- Camera ISP CCDC Image-Signal Processing: [10]

## Camera ISP Register Manual

- Camera ISP CCDC Register Summary: [11]

**Table 6-233. CCDC\_SDR\_ADDR**

|                         |                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 002C             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C62C             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | MEMORY ADDRESS REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | ADDR |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                    | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | ADDR       | Memory address<br>Sets the CCDC module output address. The address should be aligned on a 32-byte boundary: the 5 least significant bits are ignored.<br>For optimal performance in the system, the address must be on a 256-byte boundary.<br>This bit field is latched by the VS sync pulse. | RW   | 0x00000000 |

**Table 6-234. Register Call Summary for Register CCDC\_SDR\_ADDR**

Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations: \[0\]](#) [\[1\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[2\]](#)
- [Camera ISP CCDC Register Accessibility During Frame Processing: \[3\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[4\]](#)

Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[5\]](#)

**Table 6-235. CCDC\_CLAMP**

|                         |                         |                       |                 |         |        |       |      |  |  |  |  |          |  |  |        |  |
|-------------------------|-------------------------|-----------------------|-----------------|---------|--------|-------|------|--|--|--|--|----------|--|--|--------|--|
| <b>Address Offset</b>   | 0x0000 0030             |                       |                 |         |        |       |      |  |  |  |  |          |  |  |        |  |
| <b>Physical Address</b> | 0x480B C630             |                       |                 |         |        |       |      |  |  |  |  |          |  |  |        |  |
| <b>Description</b>      | CLAMP CONTROL REGISTER  |                       |                 |         |        |       |      |  |  |  |  |          |  |  |        |  |
| <b>Type</b>             | RW                      |                       |                 |         |        |       |      |  |  |  |  |          |  |  |        |  |
| 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 | CLAMPEN | OBSLEN | OBSLN | OBST |  |  |  |  | RESERVED |  |  | OBGAIN |  |

| Bits | Field Name | Description                                                                                                                                                           | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31   | CLAMPEN    | Clamp enable<br>Enables clamping based on the calculated average of optical black sample.<br>This bit is latched by the VS sync pulse.<br>0x0: Disable<br>0x1: Enable | RW   | 0x0   |

| Bits  | Field Name | Description                                                                                                                                                                                                            | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 30:28 | OBSLEN     | Optical black sample length<br>Sets the number of optical black sample pixels per line to include in the average calculation.<br><br>0x0: 1 pixel<br>0x1: 2 pixels<br>0x2: 4 pixels<br>0x3: 8 pixels<br>0x4: 16 pixels | RW   | 0x0    |
| 27:25 | OBSLN      | Optical black sample lines<br>Sets the number of optical black sample lines to include in the average calculation.<br><br>0x0: 1 line<br>0x1: 2 lines<br>0x2: 4 lines<br>0x3: 8 lines<br>0x4: 16 lines                 | RW   | 0x0    |
| 24:10 | OBST       | Start pixel of optical black samples<br>Start pixel position of optical black samples specified from the start of HS in pixel clocks.                                                                                  | RW   | 0x0000 |
| 9:5   | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                 | RW   | 0x00   |
| 4:0   | OBGAIN     | Gain to apply to the optical black average<br>The gain value is in U5Q4 fixed point representation (0 to 1.9375).                                                                                                      | RW   | 0x10   |

**Table 6-236. Register Call Summary for Register CCDC\_CLAMP**

## Camera ISP Functional Description

- Camera ISP CCDC Functional Operations: [0] [1] [2] [3] [4]

## Camera ISP Basic Programming Model

- Camera ISP CCDC Register Setup: [5] [6] [7] [8] [9] [10] [11]
- Camera ISP CCDC Register Accessibility During Frame Processing: [12]
- Camera ISP CCDC Image-Signal Processing: [13] [14] [15] [16] [17] [18] [19]

## Camera ISP Register Manual

- Camera ISP CCDC Register Summary: [20]
- Camera ISP CCDC Register Description: [21]

**Table 6-237. CCDC\_DCSUB**

|                                                                                             |                   |                 |          |
|---------------------------------------------------------------------------------------------|-------------------|-----------------|----------|
| <b>Address Offset</b>                                                                       | 0x0000 0034       | <b>Instance</b> | ISP_CCDC |
| <b>Physical Address</b>                                                                     | 0x480B C634       |                 |          |
| <b>Description</b>                                                                          | DC CLAMP REGISTER |                 |          |
| <b>Type</b>                                                                                 | RW                |                 |          |
| 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 |                   |                 |          |
| RESERVED                                                                                    |                   |                 | DCSUB    |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                       | RW   | 0x00000 |
| 13:0  | DCSUB      | DC value to subtract from the data.<br>Sets the DC value to be subtracted from the data when optical black sampling is disabled:<br><b>CCDC_CLAMP.CLAMPEN = 0</b><br>NOTE: In ISP2 this is the legacy device, this function does not clip negative results to 0 for YUV 8 bit input or REC656 input modes ( <b>CCDC_SYN_MODE.INPMOD == 2    CCDC_REC656IF.R656ON == 1</b> ). | RW   | 0x0000  |

**Table 6-238. Register Call Summary for Register CCDC\_DCSUB**

Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations: \[0\] \[1\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[2\] \[3\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[4\]](#)

Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[5\]](#)

**Table 6-239. CCDC\_COLPTN**

|                         |                         |                       |                 |         |         |         |         |         |         |         |         |         |         |         |          |          |         |         |         |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|----------|----------|---------|---------|---------|--|--|--|
| Address Offset          | 0x0000 0038             |                       |                 |         |         |         |         |         |         |         |         |         |         |         | Instance | ISP_CCDC |         |         |         |  |  |  |
| Physical Address        | 0x480B C638             |                       |                 |         |         |         |         |         |         |         |         |         |         |         |          |          |         |         |         |  |  |  |
| Description             | COLOR PATTERN REGISTER  |                       |                 |         |         |         |         |         |         |         |         |         |         |         |          |          |         |         |         |  |  |  |
| Type                    | RW                      |                       |                 |         |         |         |         |         |         |         |         |         |         |         |          |          |         |         |         |  |  |  |
| 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 | CP3LPC3 | CP3LPC2 | CP3LPC1 | CP3LPC0 | CP2PLC3 | CP2PLC2 | CP2PLC1 | CP2PLC0 | CP1PLC3 | CP1PLC2 | CP1PLC1 | CP1PLC0  | CP0PLC3  | CP0PLC2 | CP0PLC1 | CP0PLC0 |  |  |  |

| Bits  | Field Name | Description                                                                                     | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | CP3LPC3    | Color pattern, 3rd line, pixel counter = 0<br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW   | 0x0   |
| 29:28 | CP3LPC2    | Color pattern, 3rd line, pixel counter = 2<br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW   | 0x0   |
| 27:26 | CP3LPC1    | Color pattern, 3rd line, pixel counter = 1<br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW   | 0x0   |

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                     | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------|------|-------|
| 25:24 | CP3LPC0    | Color pattern, 3rd line, pixel counter = 0<br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW   | 0x0   |
| 23:22 | CP2PLC3    | Color pattern, 2nd line, pixel counter = 3<br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW   | 0x0   |
| 21:20 | CP2PLC2    | Color pattern, 2nd line, pixel counter = 2<br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW   | 0x0   |
| 19:18 | CP2PLC1    | Color pattern, 2nd line, pixel counter = 1<br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW   | 0x0   |
| 17:16 | CP2PLC0    | Color pattern, 2nd line, pixel counter = 0<br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW   | 0x0   |
| 15:14 | CP1PLC3    | Color pattern, 1st line, pixel counter = 3<br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW   | 0x0   |
| 13:12 | CP1PLC2    | Color pattern, 1st line, pixel counter = 2<br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW   | 0x0   |
| 11:10 | CP1PLC1    | Color pattern, 1st line, pixel counter = 1<br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW   | 0x0   |
| 9:8   | CP1PLC0    | Color pattern, 1st line, pixel counter = 0<br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------|-------------|--------------|
| 7:6         | CP0PLC3           | Color pattern, 0th line, pixel counter = 3<br><br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW          | 0x0          |
| 5:4         | CP0PLC2           | Color pattern, 0th line, pixel counter = 2<br><br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW          | 0x0          |
| 3:2         | CP0PLC1           | Color pattern, 0th line, pixel counter = 1<br><br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW          | 0x0          |
| 1:0         | CP0PLC0           | Color pattern, 0th line, pixel counter = 0<br><br>0x0: R/Ye<br>0x1: Gr/Cy<br>0x2: Gb/G<br>0x3: B/Mg | RW          | 0x0          |

**Table 6-240. Register Call Summary for Register CCDC\_COLPTN**

Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[1\]](#)
- [Camera ISP CCDC Image-Sensor Configuration: \[2\] \[3\]](#)
- [Camera ISP CCDC Summary of Constraints: \[4\]](#)

Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[5\]](#)

**Table 6-241. CCDC\_BLKCMP**

|                         |                             |  |  |       |             |             |           |         |         |  |                 |      |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------|--|--|-------|-------------|-------------|-----------|---------|---------|--|-----------------|------|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 003C                 |  |  |       |             |             |           |         |         |  |                 |      |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C63C                 |  |  |       |             |             |           |         |         |  | <b>Instance</b> |      |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | BLACK COMPENSATION REGISTER |  |  |       |             |             |           |         |         |  |                 |      |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                          |  |  |       |             |             |           |         |         |  |                 |      |  |  |  |  |  |  |  |  |  |  |
| 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_YE                    |                             |  |  | GR_CY |             |             |           | GB_G    |         |  |                 | B_MG |  |  |  |  |  |  |  |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:24       | R_YE              | Black-level compensation, R/Ye pixels.<br>2's complement, MSB is sign bit. The range is -128 to +127.  | RW          | 0x00         |
| 23:16       | GR_CY             | Black-level compensation, Gr/Cy pixels.<br>2's complement, MSB is sign bit. The range is -128 to +127. | RW          | 0x00         |
| 15:8        | GB_G              | Black-level compensation, Gb/G pixels.<br>2's complement, MSB is sign bit. The range is -128 to +127.  | RW          | 0x00         |

| Bits | Field Name | Description                                                                                           | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------|------|-------|
| 7:0  | B_MG       | Black-level compensation, B/Mg pixels.<br>2's complement, MSB is sign bit. The range is -128 to +127. | RW   | 0x00  |

**Table 6-242. Register Call Summary for Register CCDC\_BLKCMPP**

Camera ISP Functional Description

- Camera ISP CCDC Functional Operations: [0]

Camera ISP Basic Programming Model

- Camera ISP CCDC Register Setup: [2]
- Camera ISP CCDC Image-Signal Processing: [3]
- Camera ISP CCDC Summary of Constraints: [4]

Camera ISP Register Manual

- Camera ISP CCDC Register Summary: [5]

**Table 6-243. CCDC\_FPC**

|                         |                                 |                       |                 |  |  |  |  |       |       |       |  |  |  |  |  |
|-------------------------|---------------------------------|-----------------------|-----------------|--|--|--|--|-------|-------|-------|--|--|--|--|--|
| Address Offset          | 0x0000 0040                     |                       |                 |  |  |  |  |       |       |       |  |  |  |  |  |
| Physical Address        | 0x480B C640                     |                       |                 |  |  |  |  |       |       |       |  |  |  |  |  |
| Description             | FAULT PIXEL CORRECTION REGISTER |                       |                 |  |  |  |  |       |       |       |  |  |  |  |  |
| Type                    | RW                              |                       |                 |  |  |  |  |       |       |       |  |  |  |  |  |
| 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 |  |  |  |  |       |       |       |  |  |  |  |  |
| RESERVED                |                                 |                       |                 |  |  |  |  | FPERR | FPCEN | FPNUM |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:17 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0x0000 |
| 16    | FPERR      | <p>Fault pixel correction error<br/>           This bit is set when the CCDC module is unable to fetch the required fault pixel table entry in time. Write 1 to clear the error or end_of_frame clears it automatically for the next frame.</p> <p>For example, the current pixel being processed has coordinates of 256/512 (256th line and 512th pixel in that line) and it must be corrected. If the entry in the fault pixel table that must be used has coordinates 256/256, then the current pixel cannot be corrected since the correct entry is not loaded in time.</p> <p>Note that there is no error recovery mechanism in the CCDC; if this bit is set at anytime in a frame, there are no more fault pixels corrected in that frame. Firmware is responsible for making sure that there is enough bandwidth in the system to allow for loading of the fault pixel table. Alternately, decreasing the frequency of the fault pixels to be corrected enhances the chances of this bit not being set.</p> <p>0x0: No error<br/>           0x1: Error</p> | RW   | 0x0    |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset  |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 15   | FPCEN      | <p>Fault pixel correction enable.<br/> Upon setting this bit, and as long as it remains enabled, the fault pixel logic continues to request data and just start over for next frame once the last data of current frame has been received. As soon as the register is set the data are fetched. To disable fault pixel correction, users can write a 0 at any time. However, the disabling only applies after the current frame is processed (busy bit for current frame is 0)<br/> This bit should only be written after the FPC_ADDR register below has been set. Also, the other fields in this register have to be set prior to enabling this bit. The required process is:<br/> Write(FPC_ADDR)<br/> Write(FPC) with this bit (FPC.FPCEN) turned off<br/> Write(FPC) with this bit (FPC.FPCEN) turned on while other fields are same as previous write</p> <p>0x0: Disable<br/> 0x1: Enable</p> | RW   | 0x0    |
| 14:0 | FPNUM      | <p>Number of fault pixels to be corrected in the frame<br/> This field should not be changed when the FPCEN is enabled at any time</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW   | 0x0000 |

**Table 6-244. Register Call Summary for Register CCDC\_FPC**
**Camera ISP Functional Description**

- [Camera ISP CCDC Functional Operations: \[0\] \[3\]](#)

**Camera ISP Basic Programming Model**

- [Camera ISP CCDC Register Setup: \[4\] \[5\] \[6\]](#)
- [Camera ISP CCDC Enable/Disable Hardware: \[7\] \[8\] \[9\]](#)
- [Camera ISP CCDC Interrupts: \[10\] \[11\]](#)
- [Camera ISP CCDC Status Checking: \[12\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[13\] \[14\] \[15\]](#)
- [Camera ISP Central-Resource SBL Event and Status Checking: \[16\] \[17\]](#)

**Camera ISP Register Manual**

- [Camera ISP Register Description: \[18\] \[19\]](#)
- [Camera ISP CCDC Register Summary: \[20\]](#)

**Table 6-245. CCDC\_FPC\_ADDR**

|                         |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0044                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | <a href="#">0x480B C644</a>           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | FAULT PIXEL CORRECTION MEMORY ADDRESS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ADDR                    |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                       | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | ADDR       | <p>Memory address<br/> Set the memory address of the fault pixel correction table. The address should be aligned to a 64-byte boundary: the 6 LSBs are ignored. Each of the 32-bit table entry contains a 13-bit vertical position, a 14-bit horizontal position and a 5-bit operation field.</p> | RW   | 0x00000000 |

**Table 6-246. Register Call Summary for Register CCDC\_FPC\_ADDR**

## Camera ISP Functional Description

- Camera ISP CCDC Functional Operations: [0]

## Camera ISP Basic Programming Model

- Camera ISP CCDC Register Setup: [1]
- Camera ISP CCDC Enable/Disable Hardware: [2]
- Camera ISP CCDC Image-Signal Processing: [3]
- Camera ISP CCDC Summary of Constraints: [4]

## Camera ISP Register Manual

- Camera ISP CCDC Register Summary: [5]

**Table 6-247. CCDC\_VDINT**

|                         |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |                       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|-----------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 0048 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b>    | ISP_CCDC              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x480B C648 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Description</b> | VD INTERRUPT REGISTER |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |                       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         | 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 |

|          |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------|--------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| RESERVED | VDINT0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RESERVED | VDINT1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|          |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                           | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31    | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                | RW   | 0x0    |
| 30:16 | VDINT0     | VD0 interrupt timing<br>Specified VDINT0 in units of horizontal lines from the start of the VS sync pulse. The resulting value is VDINT0+1. Note that if the rising edge (or falling edge if programmed) of the HS sync pulse lines up with the rising edge (or falling edge if programmed) of VS sync pulse, the first HS sync pulse is not counted. | RW   | 0x0000 |
| 15    | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                | RW   | 0x0    |
| 14:0  | VDINT1     | VD1 interrupt timing<br>Specifies VDINT1 in units of horizontal lines from the start of the VS sync pulse. The resulting value is VDINT1+1. Note that if the rising edge (or falling edge if programmed) of the HS sync pulse lines up with the rising edge (or falling edge if programmed) of VS sync pulse, the first HS sync pulse is not counted. | RW   | 0x0000 |

**Table 6-248. Register Call Summary for Register CCDC\_VDINT**

## Camera ISP Basic Programming Model

- Camera ISP CCDC Register Setup: [0]
- Camera ISP CCDC CCDC\_VD0\_IRQ and CCDC\_VD1\_IRQ Interrupts: [1] [2]

## Camera ISP Register Manual

- Camera ISP CCDC Register Summary: [3]

**Table 6-249. CCDC\_ALAW**

|                         |                         |                       |                 |        |      |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--------|------|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 004C             |                       |                 |        |      |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C64C             |                       |                 |        |      |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | ALAW SETTINGS REGISTER  |                       |                 |        |      |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |                       |                 |        |      |  |  |  |  |  |  |  |  |  |
| 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 | CCDTBL | GWDI |  |  |  |  |  |  |  |  |  |
| RESERVED                |                         |                       |                 |        |      |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                          | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------|------|------------|
| 31:4 | RESERVED   | Write Os for future compatibility.<br>Reads returns 0.                                               | RW   | 0x00000000 |
| 3    | CCDTBL     | Apply A-Law compression to data saved to memory.<br>0x0: Disable<br>0x1: Enable                      | RW   | 0x0        |
| 2:0  | GWDI       | A-Law input width<br>0x3: Bits 12 to 3<br>0x4: Bits 11 to 2<br>0x5: Bits 10 to 1<br>0x6: Bits 9 to 0 | RW   | 0x4        |

**Table 6-250. Register Call Summary for Register CCDC\_ALAW**

## Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations: \[0\]](#) [\[1\]](#) [\[2\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[3\]](#) [\[4\]](#) [\[5\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[6\]](#) [\[7\]](#)

## Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[8\]](#)

**Table 6-251. CCDC\_REC656IF**

|                         |                                     |                       |                 |        |        |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------|-----------------------|-----------------|--------|--------|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0050                         |                       |                 |        |        |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C650                         |                       |                 |        |        |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | ITU-R BT.656 CONFIGURATION REGISTER |                       |                 |        |        |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                  |                       |                 |        |        |  |  |  |  |  |  |  |  |  |
| 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 | ECCFVH | R656ON |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                     |                       |                 |        |        |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                | Type | Reset      |
|------|------------|------------------------------------------------------------|------|------------|
| 31:2 | RESERVED   | Write Os for future compatibility.<br>Reads returns 0.     | RW   | 0x00000000 |
| 1    | ECCFVH     | FVH error correction enable<br>0x0: Disable<br>0x1: Enable | RW   | 0x0        |

| Bits | Field Name | Description                                                 | Type | Reset |
|------|------------|-------------------------------------------------------------|------|-------|
| 0    | R656ON     | ITU-R BT656 interface enable<br>0x0: Disable<br>0x1: Enable | RW   | 0x0   |

**Table 6-252. Register Call Summary for Register CCDC\_REC656IF**

## Camera ISP Environment

- Camera ISP ITU-R BT.656 Protocol and Data Formats (8, 10 Bits): [0]

## Camera ISP Functional Description

- Camera ISP CCDC Block Diagram: [1] [2]
- Camera ISP CCDC Functional Operations: [3] [4]

## Camera ISP Basic Programming Model

- Camera ISP CCDC Register Setup: [5] [6] [7] [8] [9] [10]
- Camera ISP CCDC Image-Sensor Configuration: [11] [12]
- Camera ISP CCDC Image-Signal Processing: [13]

## Camera ISP Register Manual

- Camera ISP CCDC Register Summary: [14]
- Camera ISP CCDC Register Description: [15] [16]

**Table 6-253. CCDC\_CFG**

|                |                        |                  |             |          |          |
|----------------|------------------------|------------------|-------------|----------|----------|
| Address Offset | 0x0000 0054            | Physical Address | 0x480B C654 | Instance | ISP_CCDC |
| Description    | CONFIGURATION REGISTER |                  |             |          |          |
| Type           | RW                     |                  |             |          |          |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |          |         |      |       |          |        |       |       |          |          |          |          |          |          |          |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----------|---------|------|-------|----------|--------|-------|-------|----------|----------|----------|----------|----------|----------|----------|
| 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        |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | VDLC | RESERVED | MSBINVI | BSWD | Y8POS | RESERVED | WENLOG | FIDMD | BW656 | RESERVED |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x0000 |
| 15    | VDLC       | Enable latching function registers on the internal VS sync pulse.<br><br>If this bit is set, all the register fields that are VS pulse latched take on new values immediately. Care should be taken not to alter fields that can cause undesired behavior to the output data<br><br>NOTE: In ISP2 that is in the legacy device, this bit must be set to 1 by software if the CCDC is to be used. If CCDCFG.VDLC remains set to 0 (default), indeterminate results may occur for ANY register access in the CCDC. For details, see <a href="#">Section 6.5, Basic Programming Model</a> .<br><br>0x0: Latched on VS<br>0x1: Not latched on VS | RW   | 0x0    |
| 14    | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x0    |
| 13    | MSBINVI    | MSB of chroma input signal stored to memory inverted.<br>0x0: Normal<br>0x1: MSB inverted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0x0    |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 12   | BSWD       | Byte swap data stored to memory.<br>0x0: Normal<br>0x1: Swap bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x0   |
| 11   | Y8POS      | Location of Y color component when YCbCr 8-bit data is input.<br>0x0: Even pixel<br>0x1: Odd pixel                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x0   |
| 10:9 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 8    | WENLOG     | Valid area settings<br>0x0: Internal valid signal and WEN signal are ANDed logically.<br>0x1: Internal valid signal and WEN signal are ORed logically.                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 7:6  | FIDMD      | Settings of field identification detection function.<br>0x0: FLD signal is latched at the VS timing. The external Field signal is latched when the VD is active and the active edge of the HD signal<br>0x1: FLD signal is not latched. The field signal is not latched at all<br>0x2: FLD signal is latched at edge of VS. The field signal is latched on the active edge of the VD signal<br>0x3: FLD signal is latched on phase of VS and HS. The field signal is latched when the VD signal is active and the HD signal is inactive (opposite phase) | RW   | 0x0   |
| 5    | BW656      | The data width in ITU-R BT656 input mode.<br>This bit field takes precedence over the <a href="#">CCDC_SYN_MODE.INPMOD</a> and <a href="#">CCDC_DATSIZ</a> bit fields if the ITU mode is enabled with <a href="#">CCDC_REC656IF.R656ON</a> = 1.<br>0x0: 8 bits<br>0x1: 10 bits                                                                                                                                                                                                                                                                           | RW   | 0x0   |
| 4    | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 3    | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 2    | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 1:0  | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |

**Table 6-254. Register Call Summary for Register CCDC\_CFG**

## Camera ISP Functional Description

- [Camera ISP CCDC Block Diagram: \[0\]](#)
- [Camera ISP CCDC Functional Operations: \[1\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\]](#)
- [Camera ISP CCDC Register Accessibility During Frame Processing: \[9\] \[10\] \[11\] \[12\] \[13\] \[14\]](#)
- [Camera ISP CCDC Image-Sensor Configuration: \[15\] \[16\] \[17\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[18\] \[19\] \[20\]](#)

## Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[21\]](#)

**Table 6-255. CCDC\_FMTCFG**

|                         |                                           |                 |          |
|-------------------------|-------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 0058                               |                 |          |
| <b>Physical Address</b> | <a href="#">0x480B C658</a>               | <b>Instance</b> | ISP_CCDC |
| <b>Description</b>      | DATA REFORMATTER/VIDEO IF CONFIG REGISTER |                 |          |
| <b>Type</b>             | RW                                        |                 |          |

|          |    |    |    |    |    |    |    |          |    |    |    |       |      |    |           |    |    |          |    |      |    |       |       |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----------|----|----|----|-------|------|----|-----------|----|----|----------|----|------|----|-------|-------|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    | VPIF_FRQ |    |    |    | VOPEN | VPIN |    | PLEN_EVEN |    |    | PLEN_ODD |    | LNUM |    | LNALT | FMTEN |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:22 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R    | 0x000 |
| 21:16 | VPIF_FRQ   | <p>Video port data ready frequency.</p> <p>This field allows the firmware to control the rate at which the video port delivers new data to the other modules (PREVIEW, H3A, and HIST modules).</p> <p>In effect, this register controls the raw output bandwidth of the PREVIEW, H3A, and HIST.</p> <p>Depending on the input sensor clock, the user can set this field appropriately and balance the bandwidth requirements to memory.</p> <p>Given a pixel clock, one shall set this bit field with the higher divisor value to lower the memory bandwidth requirement.</p> <p>The video port clock is Interconnect/(VPIF_FRQ+2).</p> <p>The valid range for VPIF_FRQ is 0..62</p> | RW   | 0x00  |
| 15    | VPEN       | <p>Video port enable. This bit shall be enabled to send data to the PREVIEW, H3A and HIST modules.</p> <p>0x0: Disable<br/>0x1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 14:12 | VPIN       | <p>10-bit input select for video port.</p> <p>0x3: bits 12-3<br/>0x4: bits 11-2<br/>0x5: bits 10-1<br/>0x6: bits 9-0</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0x4   |
| 11:8  | PLEN_EVEN  | Number of program entries in even line minus 1.<br>If the desired number of program entries is 8, then the value shall be set to 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0x0   |
| 7:4   | PLEN_ODD   | Number of program entries in odd line minus 1.<br>If the desired number of program entries is 8, then the value shall be set to 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 3:2   | LNUM       | <p>Number of output lines from 1 input line</p> <p>0x0: 1 line<br/>0x1: 2 lines<br/>0x2: 3 lines<br/>0x3: 4 lines</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW   | 0x0   |
| 1     | LNALT      | <p>Line alternating mode enable.</p> <p>In Line Alternating Mode, even and odd lines are swapped. 0th line output as 1st line and 1st line output as 0th line, and so on. If this bit field is set, the start and number of lines for the formatter (FMTVERT below) should be even.</p> <p>The FMTEN field below should be set in addition for this field to function</p> <p>0x0: Enable. Normal mode<br/>0x1: Disable. Line alternating mode</p>                                                                                                                                                                                                                                    | RW   | 0     |

| Bits | Field Name | Description                                                                                       | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------|------|-------|
| 0    | FMTEN      | Formatter enable.<br>This bit is latched by the VS sync pulse.<br><br>0x0: Disable<br>0x1: Enable | RW   | 0     |

**Table 6-256. Register Call Summary for Register CCDC\_FMTCFG**

## Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\]](#)
- [Camera ISP CCDC Register Accessibility During Frame Processing: \[18\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[19\] \[20\] \[21\] \[22\] \[23\] \[24\] \[25\] \[26\] \[27\] \[28\] \[29\] \[30\] \[31\] \[32\] \[33\] \[34\] \[35\] \[36\]](#)
- [Camera ISP Central-Resource SBL Input From CCDC Video-Port Interface: \[37\]](#)

## Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[38\]](#)
- [Camera ISP CCDC Register Description: \[39\] \[40\] \[41\] \[42\] \[43\]](#)

**Table 6-257. CCDC\_FMT\_HORZ**

|                         |                                      |                       |                 |  |  |  |  |  |          |        |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------|-----------------------|-----------------|--|--|--|--|--|----------|--------|--|--|--|--|--|--|--|
| Address Offset          | 0x0000 005C                          |                       |                 |  |  |  |  |  |          |        |  |  |  |  |  |  |  |
| Physical Address        | <a href="#">0x480B C65C</a>          |                       |                 |  |  |  |  |  |          |        |  |  |  |  |  |  |  |
| Description             | DATA REFORMATTER HORIZ INFO REGISTER |                       |                 |  |  |  |  |  |          |        |  |  |  |  |  |  |  |
| Type                    | RW                                   |                       |                 |  |  |  |  |  |          |        |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |          |        |  |  |  |  |  |  |  |
| RESERVED                | FMTSPH                               |                       |                 |  |  |  |  |  | RESERVED | FMTLNH |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                     | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------|------|--------|
| 31:29 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                          | RW   | 0x0    |
| 28:16 | FMTSPH     | Start pixel horizontal from start of the HS sync pulse.                                         | RW   | 0x0000 |
| 15:13 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                          | RW   | 0x0    |
| 12:0  | FMTLNH     | Number of pixels in horizontal direction to use for the data reformatter (minimum is 2 pixels). | RW   | 0x0000 |

**Table 6-258. Register Call Summary for Register CCDC\_FMT\_HORZ**

## Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations: \[0\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[1\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[6\]](#)

## Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[7\]](#)

**Table 6-259. CCDC\_FMT\_VERT**

|                         |                                     |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|----------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0060                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_CCDC |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C660                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 | ISP_CCDC |  |  |  |  |  |  |  |
| <b>Description</b>      | DATA REFORMATTER VERT INFO REGISTER |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 | ISP_CCDC |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                  |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 | ISP_CCDC |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |
| RESERVED                | FMTSLV                              |                       |                 |  |  |  |  |  |  |  |  |  |  |  | RESERVED        | FMTLNV   |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                      | Type | Reset  |
|-------|------------|------------------------------------------------------------------|------|--------|
| 31:29 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.           | RW   | 0x0    |
| 28:16 | FMTSLV     | Start line from start of VS sync pulse for the data reformatter. | RW   | 0x0000 |
| 15:13 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.           | RW   | 0x0    |
| 12:0  | FMTLNV     | Number of lines in vertical direction for the data reformatter   | RW   | 0x0000 |

**Table 6-260. Register Call Summary for Register CCDC\_FMT\_VERT**

Camera ISP Functional Description

- Camera ISP CCDC Functional Operations: [0]

Camera ISP Basic Programming Model

- Camera ISP CCDC Register Setup: [1]
- Camera ISP CCDC Pixel Selection (Framing) Register Dependencies: [2]
- Camera ISP CCDC Image-Signal Processing: [7]
- Camera ISP CCDC Summary of Constraints: [8]

Camera ISP Register Manual

- Camera ISP CCDC Register Summary: [9]
- Camera ISP CCDC Register Description: [10]

**Table 6-261. CCDC\_FMT\_ADDR\_i**

|                         |                                            |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 |            |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|------------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0064 + (i * 0x4)                    |                       |                 |  |  |  |  |  |  |  |  |  |  |  | <b>Index</b>    | i = 0 to 7 |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C664 + (i * 0x4)                    |                       |                 |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_CCDC   |  |  |  |  |  |  |  |
| <b>Description</b>      | DATA REFORMATTER ADDR PTR x SETUP REGISTER |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 | ISP_CCDC   |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 | ISP_CCDC   |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |                 |            |  |  |  |  |  |  |  |
| RESERVED                | LINE                                       | RESERVED              |                 |  |  |  |  |  |  |  |  |  |  |  |                 | INIT       |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x00   |
| 25:24 | LINE       | The output line the address belongs to is the 1st, 2nd, 3rd or 4th line.<br><br>0x0: 1st line<br>0x1: 2nd line<br>0x2: 3rd line<br>0x3: 4th line                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0x0    |
| 23:13 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x000  |
| 12:0  | INIT       | Initial address value<br><br>If <a href="#">CCDC_FMTCFG.LNUM</a> = 0 (1 line), the max value of the address must not exceed (4x1376 - 1) including the updates on it during processing.<br>If <a href="#">CCDC_FMTCFG.LNUM</a> = 1 (2 lines), the max value of the address must not exceed (3x1376 - 1) including the updates on it during processing.<br>If <a href="#">CCDC_FMTCFG.LNUM</a> = 2 (3 lines), the max value of the address must not exceed (2x1376 - 1) including the updates on it during processing.<br>If <a href="#">CCDC_FMTCFG.LNUM</a> = 3 (4 lines), the max value of the address must not exceed (1x1376 - 1) including the updates on it during processing.<br><br>The address must always be a positive number during the updates. | RW   | 0x0000 |

**Table 6-262. Register Call Summary for Register CCDC\_FMT\_ADDR\_i**

Camera ISP Basic Programming Model

- Camera ISP CCDC Image-Signal Processing: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17]

## Camera ISP Register Manual

- Camera ISP CCDC Register Summary: [18]

**Table 6-263. CCDC\_PRGEVEN0**

|                         |                                                                                                                                                                                                                                                                                                                                          |                 |          |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 0084                                                                                                                                                                                                                                                                                                                              |                 |          |
| <b>Physical Address</b> | 0x480B C684                                                                                                                                                                                                                                                                                                                              | <b>Instance</b> | ISP_CCDC |
| <b>Description</b>      | PROGRAM ENTRIES 0-7 FOR EVEN LINES REGISTER Each bit field in this register is programmed in the same way. The following definition applies, where n ranges from 0 to 8. Bits [4*n+3:4*n+1] 000:<br>ADDR0 001: ADDR1 010: ADDR2 011: ADDR3 100: ADDR4 101: ADDR5 110: ADDR6 111: ADDR7 Bit<br>[4*n]: 0: Auto increment 1: Auto decrement |                 |          |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                       |                 |          |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                        | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------|-------------|--------------|
| 31:28       | EVEN7             | Address update. See register description. | RW          | 0x0          |
| 27:24       | EVEN6             | Address update. See register description. | RW          | 0x0          |
| 23:20       | EVEN5             | Address update. See register description. | RW          | 0x0          |
| 19:16       | EVEN4             | Address update. See register description. | RW          | 0x0          |
| 15:12       | EVEN3             | Address update. See register description. | RW          | 0x0          |
| 11:8        | EVEN2             | Address update. See register description. | RW          | 0x0          |
| 7:4         | EVEN1             | Address update. See register description. | RW          | 0x0          |
| 3:0         | EVEN0             | Address update. See register description. | RW          | 0x0          |

**Table 6-264. Register Call Summary for Register CCDC\_PRGEVEN0**

Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[1\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\]](#)

Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[12\]](#)

**Table 6-265. CCDC\_PRGEVEN1**

|                         |                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 0088                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |
| <b>Physical Address</b> | 0x480B C688                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_CCDC |
| <b>Description</b>      | PROGRAM ENTRIES 8-15 FOR EVEN LINES REGISTER Each bit field in this register is programmed in the same way. The following definition applies, where n ranges from 0 to 8. Bits [4*n+3:4*n+1] 000: ADDR0 001: ADDR1 010: ADDR2 011: ADDR3 100: ADDR4 101: ADDR5 110: ADDR6 111: ADDR7 Bit [4*n]: 0: Auto increment 1: Auto decrement |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |          |

|                         |                         |                       |                 |        |        |       |       |
|-------------------------|-------------------------|-----------------------|-----------------|--------|--------|-------|-------|
| 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 |        |        |       |       |
| EVEN15                  | EVEN14                  | EVEN13                | EVEN12          | EVEN11 | EVEN10 | EVEN9 | EVEN8 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                        | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------|-------------|--------------|
| 31:28       | EVEN15            | Address update. See register description. | RW          | 0x0          |
| 27:24       | EVEN14            | Address update. See register description. | RW          | 0x0          |
| 23:20       | EVEN13            | Address update. See register description. | RW          | 0x0          |
| 19:16       | EVEN12            | Address update. See register description. | RW          | 0x0          |
| 15:12       | EVEN11            | Address update. See register description. | RW          | 0x0          |
| 11:8        | EVEN10            | Address update. See register description. | RW          | 0x0          |
| 7:4         | EVEN9             | Address update. See register description. | RW          | 0x0          |
| 3:0         | EVEN8             | Address update. See register description. | RW          | 0x0          |

**Table 6-266. Register Call Summary for Register CCDC\_PRGEVEN1**

Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[1\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[3\]](#)

**Table 6-267. CCDC\_PRGODD0**

|                         |                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 008C                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C68C                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | PROGRAM ENTRIES 0-7 FOR ODD LINES REGISTER Each bit field in this register is programmed in the same way. The following definition applies, where n ranges from 0 to 8. Bits [4*n+3:4*n+1] 000:<br>ADDR0 001: ADDR1 010: ADDR2 011: ADDR3 100: ADDR4 101: ADDR5 110: ADDR6 111: ADDR7 Bit [4*n]: 0: Auto increment 1: Auto decrement |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |

|      |    |      |    |      |    |      |    |      |    |      |    |      |    |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|------|----|------|----|------|----|------|----|------|----|------|----|------|----|------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| ODD7 |    | ODD6 |    | ODD5 |    | ODD4 |    | ODD3 |    | ODD2 |    | ODD1 |    | ODD0 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                               | Type | Reset |
|-------|------------|-------------------------------------------|------|-------|
| 31:28 | ODD7       | Address update. See register description. | RW   | 0x0   |
| 27:24 | ODD6       | Address update. See register description. | RW   | 0x0   |
| 23:20 | ODD5       | Address update. See register description. | RW   | 0x0   |
| 19:16 | ODD4       | Address update. See register description. | RW   | 0x0   |
| 15:12 | ODD3       | Address update. See register description. | RW   | 0x0   |
| 11:8  | ODD2       | Address update. See register description. | RW   | 0x0   |
| 7:4   | ODD1       | Address update. See register description. | RW   | 0x0   |
| 3:0   | ODD0       | Address update. See register description. | RW   | 0x0   |

**Table 6-268. Register Call Summary for Register CCDC\_PRGODD0**

## Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations: \[0\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[1\]](#)
- [Camera ISP CCDC Image-Signal Processing: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\]](#)

## Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[12\]](#)

**Table 6-269. CCDC\_PRGODD1**

|                         |                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0090                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C690                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | PROGRAM ENTRIES 8-15 FOR ODD LINES REGISTER Each bit field in this register is programmed in the same way. The following definition applies, where n ranges from 0 to 8. Bits [4*n+3:4*n+1] 000:<br>ADDR0 001: ADDR1 010: ADDR2 011: ADDR3 100: ADDR4 101: ADDR5 110: ADDR6 111: ADDR7 Bit [4*n]: 0: Auto increment 1: Auto decrement |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |

|       |    |       |    |       |    |       |    |       |    |       |    |      |    |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|-------|----|-------|----|-------|----|-------|----|-------|----|-------|----|------|----|------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| ODD15 |    | ODD14 |    | ODD13 |    | ODD12 |    | ODD11 |    | ODD10 |    | ODD9 |    | ODD8 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                               | Type | Reset |
|-------|------------|-------------------------------------------|------|-------|
| 31:28 | ODD15      | Address update. See register description. | RW   | 0x0   |
| 27:24 | ODD14      | Address update. See register description. | RW   | 0x0   |
| 23:20 | ODD13      | Address update. See register description. | RW   | 0x0   |
| 19:16 | ODD12      | Address update. See register description. | RW   | 0x0   |
| 15:12 | ODD11      | Address update. See register description. | RW   | 0x0   |
| 11:8  | ODD10      | Address update. See register description. | RW   | 0x0   |
| 7:4   | ODD9       | Address update. See register description. | RW   | 0x0   |

| Bits | Field Name | Description                               | Type | Reset |
|------|------------|-------------------------------------------|------|-------|
| 3:0  | ODD8       | Address update. See register description. | RW   | 0x0   |

**Table 6-270. Register Call Summary for Register CCDC\_PRGODD1**

Camera ISP Functional Description

- Camera ISP CCDC Functional Operations: [0]

Camera ISP Basic Programming Model

- Camera ISP CCDC Register Setup: [1]
- Camera ISP CCDC Image-Signal Processing: [2]

Camera ISP Register Manual

- Camera ISP CCDC Register Summary: [3]

**Table 6-271. CCDC\_VP\_OUT**

|                  |                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |          |  |  |  |
|------------------|----------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|----------|--|--|--|
| Address Offset   | 0x0000 0094                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Instance | ISP_CCDC |  |  |  |
| Physical Address | 0x480B C694                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | ISP_CCDC |          |  |  |  |
| Description      | VIDEO PORT OUTPUT REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |          |  |  |  |
| Type             | RW                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |          |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31    | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0x0    |
| 30:17 | VERT_NUM   | Number of vertical lines to clock out the video.<br>If the data reformatter is turned off, then the number of lines that can be clocked out of the video port must be at least 1 line less than the number of lines input from the sensor.<br>If the data reformatter is turned on, then the number of lines that can be clocked out of the video port must be less than<br>$(CCDC\_FMT\_VERT.FMTLNV - 1)$ *<br>$(CCDC\_FMTCFG.LNUM + 1)$<br>The video port output VS pulse is generated right from the first video port input VS itself. | RW   | 0x0000 |
| 16:4  | HORZ_NUM   | Number of horizontal pixel to clock out the video port.<br>The minimum value allowed is 2 pixels. The maximum offset allowed is 1376 if original input is broken down to 4 lines. The maximum offset allowed is 1376 if original input is broken down to 3 lines. The maximum offset allowed is $2 \times 1376$ if original input is broken down to 2 lines. The maximum offset allowed is $4 \times 1376$ if original input is broken down to 1 line.                                                                                    | RW   | 0x0000 |
| 3:0   | HORZ_ST    | Horizontal start pixel in each output line.<br>The maximum value allowed is 15. The video port output HSYNC pulse is generated from this position on for each line. To be able to select an offset higher than 15, the input settings to the data reformatter must be configured appropriately.<br>The purpose of this parameter is to allow for sensors that can read out a parallelogram image rather than a rectangular image.                                                                                                         | RW   | 0x0    |

**Table 6-272. Register Call Summary for Register CCDC\_VP\_OUT**

## Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations](#):

## Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup](#): [1]
- [Camera ISP CCDC Pixel Selection \(Framing\) Register Dependencies](#): [2]
- [Camera ISP CCDC Image-Signal Processing](#): [6] [7] [8] [9] [10] [11] [12]
- [Camera ISP CCDC Summary of Constraints](#): [13]

## Camera ISP Register Manual

- [Camera ISP CCDC Register Summary](#): [14]

**Table 6-273. CCDC\_LSC\_CONFIG**

|                         |                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0098                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B C698                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | LENS SHADING COMPENSATION CONTROL AND STATUS REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                     | Type | Reset   |
|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:15 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                              | RW   | 0x00000 |
| 14:12 | GAIN_MODE_M | Define the horizontal dimension of a paxel. Possible values are listed below<br><br>0x2: Pixel is 4 pixels tall (M=4)<br>0x3: Pixel is 8 pixels tall (M=8)<br>0x4: Pixel is 16 pixels tall (M=16)<br>0x5: Pixel is 32 pixels tall (M=32)<br>0x6: Pixel is 64 pixels tall (M=64) | RW   | 0x6     |
| 11    | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                              | R    | 0x0     |
| 10:8  | GAIN_MODE_N | Define the vertical dimension of a paxel. Possible values are listed below<br><br>0x2: Pixel is 4 pixels tall (N=4)<br>0x3: Pixel is 8 pixels tall (N=8)<br>0x4: Pixel is 16 pixels tall (N=16)<br>0x5: Pixel is 32 pixels tall (N=32)<br>0x6: Pixel is 64 pixels tall (N=64)   | RW   | 0x6     |
| 7     | BUSY        | Module busy or idle<br><br>0x0: The module is idle<br>0x1: The module is busy                                                                                                                                                                                                   | R    | 0x0     |

| Bits | Field Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset |
|------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 6    | AFTER_REFORMATTER | Chooses if lens-shading compensation is done before or after data reformatting<br><br>0x0: Lens-shading is done before data reformatting. H3A, HIST and PREVIEW receives shading compensated data<br><br>0x1: Data received by H3A is not compensated. Data received by PREVIEW and HIST is compensated.                                                                                                                                                                                                                                                                                                                                                 | RW   | 0x0   |
| 5:4  | RESERVED          | Write 0s for future compatibility. Reads return 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x0   |
| 3:1  | GAIN_FORMAT       | Sets gain table format<br><br>0x0: Coded as 8-bit fraction Range from 0 to 255/256<br><br>0x1: Coded as 8-bit fraction + 1.0 of base. Range from 1 to 1+255/256<br><br>0x2: Coded as 1-bit integer, 7-bit fraction. Range from 0 to 1+127/128<br><br>0x3: Coded as 1-bit integer, 7-bit fraction + 1.0 Range from 1 to 2+127/128<br><br>0x4: Coded as 2-bit integer, 6-bit fraction Range from 0 to 3+63/64<br><br>0x5: Coded as 2-bit integer, 6-bit fraction + 1.0 Range from 1 to 4+63/64<br><br>0x6: Coded as 3-bit integer, 5-bit fraction Range from 0 to 7+31/32<br><br>0x7: Coded as 3-bit integer, 5-bit fraction + 1.0 Range from 1 to 8+31/32 | RW   | 0x0   |
| 0    | ENABLE            | Enables/disables LSC<br><br>0x0: Disables the module at the end of the current frame. Video data is transmitted without modification when LSC is disabled. The BUSY bit can be used to poll when access to SBL buffer can be used by the preview module.<br><br>0x1: Enables the module. Module starts fetching the gain table as soon it is started. Firmware has to make sure it has been correctly initialized before starting the module. Data processing is only effective at the start of the next frame. Note that preview module dark frame subtract must be disabled because there is only one shared read port.                                | RW   | 0x0   |

**Table 6-274. Register Call Summary for Register CCDC\_LSC\_CONFIG**

## Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations](#):

## Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup](#): [2] [3] [4]
- [Camera ISP CCDC Register Accessibility During Frame Processing](#): [5]
- [Camera ISP CCDC Image-Signal Processing](#):

## Camera ISP Register Manual

- [Camera ISP CCDC Register Summary](#): [23]

**Table 6-275. CCDC\_LSC\_INITIAL**

| <b>Address Offset</b>   | 0x0000 009C                                    |                                                                                                                  |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
|-------------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|------|-------|
| <b>Physical Address</b> | 0x480B C69C                                    |                                                                                                                  |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Description</b>      | LENS SHADING COMPENSATION INITIAL X/Y REGISTER |                                                                                                                  |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Type</b>             | RW                                             |                                                                                                                  |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| 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 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| RESERVED                | Y                                              | RESERVED                                                                                                         | X               |  |  |  |  |  |  |  |  |  |  |  |      |       |
| Bits                    | Field Name                                     | <b>Description</b>                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  | Type | Reset |
| 31:22                   | RESERVED                                       | Write 0s for future compatibility. Reads return 0.                                                               |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x000 |
| 21:16                   | Y                                              | Y position, in pixels, of the first active pixel in reference to the first active pixel. Must be an even number. |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 15:6                    | RESERVED                                       | Write 0s for future compatibility. Reads return 0.                                                               |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x000 |
| 5:0                     | X                                              | X position, in pixels, of the first active pixel in reference to the first active pixel. Must be an even number. |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |

**Table 6-276. Register Call Summary for Register CCDC\_LSC\_INITIAL**

|                                    |                                                                                                                                                                                                          |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Camera ISP Functional Description  | <ul style="list-style-type: none"> <li><a href="#">Camera ISP CCDC Functional Operations:</a></li> </ul>                                                                                                 |
| Camera ISP Basic Programming Model | <ul style="list-style-type: none"> <li><a href="#">Camera ISP CCDC Register Accessibility During Frame Processing: [10]</a></li> <li><a href="#">Camera ISP CCDC Image-Signal Processing:</a></li> </ul> |
| Camera ISP Register Manual         | <ul style="list-style-type: none"> <li><a href="#">Camera ISP CCDC Register Summary: [15]</a></li> </ul>                                                                                                 |

**Table 6-277. CCDC\_LSC\_TABLE\_BASE**

| <b>Address Offset</b>   | 0x0000 00A0                                           |                                                                                                                                                           |                 |  |  |  |  |  |  |  |  |  |  |  |      |            |
|-------------------------|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|------|------------|
| <b>Physical Address</b> | 0x480B C6A0                                           |                                                                                                                                                           |                 |  |  |  |  |  |  |  |  |  |  |  |      |            |
| <b>Description</b>      | LENS SHADING COMPENSATION TABLE BASE ADDRESS REGISTER |                                                                                                                                                           |                 |  |  |  |  |  |  |  |  |  |  |  |      |            |
| <b>Type</b>             | RW                                                    |                                                                                                                                                           |                 |  |  |  |  |  |  |  |  |  |  |  |      |            |
| 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 |  |  |  |  |  |  |  |  |  |  |  |      |            |
|                         |                                                       | BASE                                                                                                                                                      |                 |  |  |  |  |  |  |  |  |  |  |  |      |            |
| Bits                    | Field Name                                            | <b>Description</b>                                                                                                                                        |                 |  |  |  |  |  |  |  |  |  |  |  | Type | Reset      |
| 31:0                    | BASE                                                  | Table address in bytes. Table is 32-bit aligned so this register must be a multiple of 4.<br>This bit field sets the address of the gain table in memory. |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00000000 |

**Table 6-278. Register Call Summary for Register CCDC\_LSC\_TABLE\_BASE**

|                                    |                                                                                                                                                                                                                                                                      |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Camera ISP Functional Description  | <ul style="list-style-type: none"> <li><a href="#">Camera ISP CCDC Functional Operations:</a></li> </ul>                                                                                                                                                             |
| Camera ISP Basic Programming Model | <ul style="list-style-type: none"> <li><a href="#">Camera ISP CCDC Register Setup: [3]</a></li> <li><a href="#">Camera ISP CCDC Register Accessibility During Frame Processing: [4]</a></li> <li><a href="#">Camera ISP CCDC Image-Signal Processing:</a></li> </ul> |
| Camera ISP Register Manual         | <ul style="list-style-type: none"> <li><a href="#">Camera ISP CCDC Register Summary: [6]</a></li> </ul>                                                                                                                                                              |

**Table 6-279. CCDC\_LSC\_TABLE\_OFFSET**

|                         |                                                 |                         |                 |                 |          |
|-------------------------|-------------------------------------------------|-------------------------|-----------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 00A4                                     | <b>Physical Address</b> | 0x480B C6A4     | <b>Instance</b> | ISP_CCDC |
| <b>Description</b>      | LENS SHADING COMPENSATION TABLE OFFSET REGISTER |                         |                 |                 |          |
| <b>Type</b>             | RW                                              |                         |                 |                 |          |
| 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 |                 |          |
| RESERVED                |                                                 |                         | OFFSET          |                 |          |

| Bits  | Field Name | Description                                                                                                                                                                                               | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                        | RW   | 0x0000 |
| 15:0  | OFFSET     | Defines the length, in bytes, of one row of the gain table. Gain table is 32-bit aligned, so this value must be a multiple of 4.<br>Note that the row in memory must be longer or equal to what LSC uses. | RW   | 0x0000 |

**Table 6-280. Register Call Summary for Register CCDC\_LSC\_TABLE\_OFFSET**

Camera ISP Functional Description

- [Camera ISP CCDC Functional Operations:](#)

Camera ISP Basic Programming Model

- [Camera ISP CCDC Register Setup: \[4\]](#)
- [Camera ISP CCDC Register Accessibility During Frame Processing: \[5\]](#)
- [Camera ISP CCDC Image-Signal Processing:](#)

Camera ISP Register Manual

- [Camera ISP CCDC Register Summary: \[7\]](#)

## 6.6.5 Camera ISP HIST Registers

### 6.6.5.1 Camera ISP HIST Register Summary

**Table 6-281. ISP\_HIST Register Summary**

| Register Name               | Type | Register Width (Bits) | Address Offset        | Physical Address      |
|-----------------------------|------|-----------------------|-----------------------|-----------------------|
| HIST_PID                    | R    | 32                    | 0x0000 0000           | 0x480B CA00           |
| HIST_PCR                    | RW   | 32                    | 0x0000 0004           | 0x480B CA04           |
| HIST_CNT                    | RW   | 32                    | 0x0000 0008           | 0x480B CA08           |
| HIST_WB_GAIN                | RW   | 32                    | 0x0000 000C           | 0x480B CA0C           |
| HIST_Rn_HORZ <sup>(1)</sup> | RW   | 32                    | 0x0000 0010 + (n*0x8) | 0x480B CA10 + (n*0x8) |
| HIST_Rn_VERT <sup>(1)</sup> | RW   | 32                    | 0x0000 0014 + (n*0x8) | 0x480B CA14 + (n*0x8) |
| HIST_ADDR                   | RW   | 32                    | 0x0000 0030           | 0x480B CA30           |
| HIST_DATA                   | RW   | 32                    | 0x0000 0034           | 0x480B CA34           |
| HIST_RADD                   | RW   | 32                    | 0x0000 0038           | 0x480B CA38           |
| HIST_RADD_OFF               | RW   | 32                    | 0x0000 003C           | 0x480B CA3C           |
| HIST_H_V_INFO               | RW   | 32                    | 0x0000 0040           | 0x480B CA40           |

<sup>(1)</sup> n = 0 to 3

### 6.6.5.2 Camera ISP HIST Register Description

**Table 6-282. HIST\_PID**

| <b>Address Offset</b>   | 0x0000 0000             | <b>Physical Address</b>                             | 0x480B CA00     | <b>Instance</b>  | ISP_HIST |
|-------------------------|-------------------------|-----------------------------------------------------|-----------------|------------------|----------|
| <b>Description</b>      | PERIPHERAL ID REGISTER  |                                                     |                 |                  |          |
| <b>Type</b>             | R                       |                                                     |                 |                  |          |
| 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 |                  |          |
| RESERVED                | TID                     | CID                                                 | PREV            |                  |          |
| Bits                    | Field Name              | Description                                         | Type            | Reset            |          |
| 31:24                   | RESERVED                | Write 0s for future compatibility. Reads returns 0. | R               | 0x00             |          |
| 23:16                   | TID                     | Peripheral identification: HIST module              | R               | 0x08             |          |
| 15:8                    | CID                     | Class identification: Camera ISP                    | R               | 0xFE             |          |
| 7:0                     | PREV                    | Peripheral revision number                          | R               | TI internal data |          |

**Table 6-283. Register Call Summary for Register HIST\_PID**

Camera ISP Register Manual

- [Camera ISP HIST Register Summary: \[0\]](#)

**Table 6-284. HIST\_PCR**

| <b>Address Offset</b>   | 0x0000 0004                 | <b>Physical Address</b>                                               | 0x480B CA04     | <b>Instance</b> | ISP_HIST |
|-------------------------|-----------------------------|-----------------------------------------------------------------------|-----------------|-----------------|----------|
| <b>Description</b>      | PERIPHERAL CONTROL REGISTER |                                                                       |                 |                 |          |
| <b>Type</b>             | RW                          |                                                                       |                 |                 |          |
| 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 |                 |          |
| RESERVED                |                             |                                                                       |                 | BUSY            | ENABLE   |
| Bits                    | Field Name                  | Description                                                           | Type            | Reset           |          |
| 31:2                    | RESERVED                    | Write 0s for future compatibility.<br>Reads returns 0.                | RW              | 0x00000000      |          |
| 1                       | BUSY                        | HIST module busy.<br>0x0: Module is not busy.<br>0x1: Module is busy. | RW              | 0x0             |          |
| 0                       | ENABLE                      | HIST module enable.<br>0x0: Disable module<br>0x1: Enable module      | RW              | 0x0             |          |

**Table 6-285. Register Call Summary for Register HIST\_PCR**

Camera ISP Functional Description

Camera ISP Basic Programming Model

- [Camera ISP Histogram Reset of Histogram Output Memory: \[2\]](#)
- [Camera ISP Histogram Enable/Disable Hardware: \[3\]](#)
- [Camera ISP Histogram Event and Status Checking: \[4\] \[5\] \[6\]](#)
- [Camera ISP Histogram Register Accessibility During Frame Processing: \[7\] \[8\] \[9\]](#)
- [Camera ISP Histogram Interframe Operations: \[10\] \[11\] \[12\]](#)

Camera ISP Register Manual

- [Camera ISP HIST Register Summary: \[13\]](#)

**Table 6-286. HIST\_CNT**

|                         |                            |                 |          |
|-------------------------|----------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 0008                |                 |          |
| <b>Physical Address</b> | 0x480B CA08                | <b>Instance</b> | ISP_HIST |
| <b>Description</b>      | HISTOGRAM CONTROL REGISTER |                 |          |
| <b>Type</b>             | RW                         |                 |          |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |     |     |      |    |        |       |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|-----|-----|------|----|--------|-------|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DATASIZ | CLR | CFA | BINS |    | SOURCE | SHIFT |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:9        | RESERVED          | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                    | RW          | 0x000000     |
| 8           | DATASIZ           | Input data width<br>0x0: The pixels are coded on more than 8 bits.<br>0x1: The pixels are coded on 8 bits.                                                                                                | RW          | 0x0          |
| 7           | CLR               | Clear histogram data after read.<br>0x0: Don't clear the data after read.<br>0x1: Clear the data after read.                                                                                              | RW          | 0x0          |
| 6           | CFA               | CFA pattern.<br>0x0: Bayer pattern.<br>0x1: Reserved.                                                                                                                                                     | RW          | 0x0          |
| 5:4         | BINS              | Number of bins.<br>0x0: 32 bins, REGIONS 0, 1, 2 and 3 are active.<br>0x1: 64 bins, REGIONS 0, 1, 2 and 3 are active.<br>0x2: 128 bins, REGIONS 0 and 1 are active.<br>0x3: 256 bins, REGION 0 is active. | RW          | 0x0          |
| 3           | SOURCE            | Input source.<br>0x0: The input data comes from the CCDC module.<br>0x1: The input data comes from memory.                                                                                                | RW          | 0x0          |
| 2:0         | SHIFT             | Shift value.<br>The pixel data is right shifted before the binning operation. The shift value can vary from 0 to 7.                                                                                       | RW          | 0x0          |

**Table 6-287. Register Call Summary for Register HIST\_CNT**

- ## Camera ISP Functional Description

- Camera ISP Histogram Reset of Histogram Output Memory: [7]
  - Camera ISP Histogram Register Setup: [8] [9] [10] [11] [12] [13] [14] [15] [16]

- ## Camera ISP Histogram Register Setup [1-1]

**Table 6-288. HIST\_WB\_GAIN**

|                         |                                       |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|----------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 000C                           |                       |                 |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_HIST |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CA0C                           |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 | ISP_HIST |  |  |  |  |  |  |  |
| <b>Description</b>      | HISTOGRAM WHITE BALANCE GAIN REGISTER |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 | ISP_HIST |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                    |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 | ISP_HIST |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |
| WG00                    | WG01                                  | WG02                  | WG03            |  |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |

  

| Bits  | Field Name | Description                                                                                                  | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | WG00       | White balance gain 00.<br>The gain value is unsigned and in 3Q5 representation. It varies from 0 to 7.96875. | RW   | 0x20  |
| 23:16 | WG01       | White balance gain 01.<br>The gain value is unsigned and in 3Q5 representation. It varies from 0 to 7.96875. | RW   | 0x20  |
| 15:8  | WG02       | White balance gain 02.<br>The gain value is unsigned and in 3Q5 representation. It varies from 0 to 7.96875. | RW   | 0x20  |
| 7:0   | WG03       | White balance gain 03.<br>The gain value is unsigned and in 3Q5 representation. It varies from 0 to 7.96875. | RW   | 0x20  |

**Table 6-289. Register Call Summary for Register HIST\_WB\_GAIN**

- Camera ISP Functional Description
  - [Camera ISP Histogram White Balance: \[0\] \[2\]](#)
- Camera ISP Basic Programming Model
  - [Camera ISP Histogram Register Setup: \[3\]](#)
- Camera ISP Register Manual
  - [Camera ISP HIST Register Summary: \[4\]](#)

**Table 6-290. HIST\_Rn\_HORZ**

|                         |                              |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 |            |  |  |  |  |  |  |  |
|-------------------------|------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|------------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0010 + (n*0x8)        |                       |                 |  |  |  |  |  |  |  |  |  |  |  | <b>Index</b>    | n = 0 to 3 |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CA10 + (n*0x8)        |                       |                 |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_HIST   |  |  |  |  |  |  |  |
| <b>Description</b>      | REGION n HORIZONTAL REGISTER |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 | ISP_HIST   |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                           |                       |                 |  |  |  |  |  |  |  |  |  |  |  |                 | ISP_HIST   |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |                 |            |  |  |  |  |  |  |  |
| RESERVED                | HSTART                       |                       |                 |  |  |  |  |  |  |  |  |  |  |  | RESERVED        | HEND       |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                 | Type | Reset  |
|-------|------------|-------------------------------------------------------------|------|--------|
| 31:30 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.      | RW   | 0x0    |
| 29:16 | HSTART     | Horizontal start position for REGION n.<br>From 0 to 16383. | RW   | 0x0000 |
| 15:14 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.      | RW   | 0x0    |
| 13:0  | HEND       | Horizontal end position for REGION n.<br>From 0 to 16383.   | RW   | 0x0000 |

**Table 6-291. Register Call Summary for Register HIST\_Rn\_HORZ**

Camera ISP Functional Description

- Camera ISP Histogram Binning: [0] [1]

Camera ISP Basic Programming Model

- Camera ISP Histogram Register Setup: [2] [3] [4] [5]

Camera ISP Register Manual

- Camera ISP HIST Register Summary: [6]

**Table 6-292. HIST\_Rn\_VERT**

|                         |                            |                 |            |
|-------------------------|----------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0014 + (n*0x8)      | <b>Index</b>    | n = 0 to 3 |
| <b>Physical Address</b> | 0x480B CA14 + (n*0x8)      | <b>Instance</b> | ISP_HIST   |
| <b>Description</b>      | REGION n VERTICAL REGISTER |                 |            |
| <b>Type</b>             | RW                         |                 |            |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | VSTART                  | RESERVED              | VEND            |

| Bits  | Field Name | Description                                               | Type | Reset  |
|-------|------------|-----------------------------------------------------------|------|--------|
| 31:30 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.    | RW   | 0x0    |
| 29:16 | VSTART     | Vertical start position for REGION n.<br>From 0 to 16383. | RW   | 0x0000 |
| 15:14 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.    | RW   | 0x0    |
| 13:0  | VEND       | Vertical end position for REGION n.<br>From 0 to 16383.   | RW   | 0x0000 |

**Table 6-293. Register Call Summary for Register HIST\_Rn\_VERT**

Camera ISP Functional Description

- Camera ISP Histogram Binning: [0] [1]

Camera ISP Basic Programming Model

- Camera ISP Histogram Register Setup: [2] [3] [4] [5]

Camera ISP Register Manual

- Camera ISP HIST Register Summary: [6]

**Table 6-294. HIST\_ADDR**

|                         |                         |                       |                            |
|-------------------------|-------------------------|-----------------------|----------------------------|
| <b>Address Offset</b>   | 0x0000 0030             | <b>Instance</b>       | ISP_HIST                   |
| <b>Physical Address</b> | 0x480B CA30             | <b>Description</b>    | HISTOGRAM ADDRESS REGISTER |
| <b>Type</b>             | RW                      |                       |                            |
| 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            |

|          |      |
|----------|------|
| RESERVED | ADDR |
|----------|------|

| Bits  | Field Name | Description                                                                                         | Type | Reset     |
|-------|------------|-----------------------------------------------------------------------------------------------------|------|-----------|
| 31:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                              | RW   | 0x0000000 |
| 9:0   | ADDR       | Histogram memory address.<br>The histogram memory has 1024 entries. Each entry is coded on 20 bits. | RW   | 0x000     |

**Table 6-295. Register Call Summary for Register HIST\_ADDR**

- Camera ISP Functional Description  
 Camera ISP Register Manual  
     • [Camera ISP HIST Register Summary: \[4\]](#)

**Table 6-296. HIST\_DATA**

|                         |                             |                       |                 |          |       |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |
|-------------------------|-----------------------------|-----------------------|-----------------|----------|-------|--|--|--|--|--|--|--|--|--|-----------------|----------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0034                 |                       |                 |          |       |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_HIST |  |  |  |  |  |  |
| <b>Physical Address</b> | <a href="#">0x480B CA34</a> |                       |                 |          |       |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |
| <b>Description</b>      |                             |                       |                 |          |       |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |
| <b>Type</b>             | RW                          |                       |                 |          |       |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |
| 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 | RESERVED | RDATA |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |

  

| Bits  | Field Name | Description                                                                               | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------|------|--------|
| 31:20 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                    | RW   | 0x000  |
| 19:0  | RDATA      | Histogram data.<br>The histogram memory has 1024 entries. Each entry is coded on 20 bits. | RW   | 0x---- |

**Table 6-297. Register Call Summary for Register HIST\_DATA**

- Camera ISP Functional Description  
 Camera ISP Basic Programming Model  
     • [Camera ISP Histogram Register Accessibility During Frame Processing: \[3\]](#)  
 Camera ISP Register Manual  
     • [Camera ISP HIST Register Summary: \[4\]](#)

**Table 6-298. HIST\_RADD**

|                         |                                                                                                                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|-----------------|----------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0038                                                                                                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_HIST |  |  |  |  |  |  |
| <b>Physical Address</b> | <a href="#">0x480B CA38</a>                                                                                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |
| <b>Description</b>      | ADDRESS REGISTER This register is used only if the HIST module input data comes from memory instead of the CCDC module. |                       |                 |      |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                      |                       |                 |      |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |
| 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 | RADD |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |

  

| Bits | Field Name | Description                                                                                              | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | RADD       | 32-bit address.<br>The 5 LSBs are ignored: the starting address should be aligned on a 32-byte boundary. | RW   | 0x00000000 |

**Table 6-299. Register Call Summary for Register HIST\_RADD**

Camera ISP Functional Description

- Camera ISP Histogram Input Interface: [0]

Camera ISP Basic Programming Model

- Camera ISP Histogram Register Setup: [1]
- Camera ISP Histogram Register Accessibility During Frame Processing: [2]

Camera ISP Register Manual

- Camera ISP HIST Register Summary: [3]

**Table 6-300. HIST\_RADD\_OFF**

|                         |                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 003C                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CA3C                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | ADDRESS OFFSET REGISTER This register is used only if the HIST module input data comes from memory instead of the CCDC module. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | OFFSET |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                         | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                              | RW   | 0x0000 |
| 15:0  | OFFSET     | Offset value.<br>The 5 LSBs are ignored: the offset must be a multiple of 32-bytes. | RW   | 0x0000 |

**Table 6-301. Register Call Summary for Register HIST\_RADD\_OFF**

Camera ISP Functional Description

- Camera ISP Histogram Input Interface: [0]

Camera ISP Basic Programming Model

- Camera ISP Histogram Register Setup: [1]
- Camera ISP Histogram Register Accessibility During Frame Processing: [2]

Camera ISP Register Manual

- Camera ISP HIST Register Summary: [3]

**Table 6-302. HIST\_H\_V\_INFO**

|                         |                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0040                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CA40                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | IMAGE SIZE REGISTER This register is used only if the HIST module input data comes from memory instead of the CCDC module. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |       |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|-------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED | HSIZE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RESERVED | VSIZE |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                            | Type | Reset  |
|-------|------------|--------------------------------------------------------|------|--------|
| 31:30 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x0    |
| 29:16 | HSIZE      | Horizontal size                                        | RW   | 0x0000 |
| 15:14 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x0    |
| 13:0  | VSIZE      | Vertical size                                          | RW   | 0x0000 |

**Table 6-303. Register Call Summary for Register HIST\_H\_V\_INFO**

Camera ISP Functional Description

- [Camera ISP Histogram Input Interface: \[0\] \[1\]](#)

Camera ISP Basic Programming Model

- [Camera ISP Histogram Register Setup: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP HIST Register Summary: \[3\]](#)

## 6.6.6 Camera ISP H3A Registers

### 6.6.6.1 Camera ISP H3A Register Summary

**Table 6-304. ISP\_H3A Register Summary**

| Register Name   | Type | Register Width (Bits) | Address Offset | Physical Address |
|-----------------|------|-----------------------|----------------|------------------|
| H3A_PID         | R    | 32                    | 0x0000 0000    | 0x480B CC00      |
| H3A_PCR         | RW   | 32                    | 0x0000 0004    | 0x480B CC04      |
| H3A_AFPAX1      | RW   | 32                    | 0x0000 0008    | 0x480B CC08      |
| H3A_AFPAX2      | RW   | 32                    | 0x0000 000C    | 0x480B CC0C      |
| H3A_AFPAXSTART  | RW   | 32                    | 0x0000 0010    | 0x480B CC10      |
| H3A_AFIIRSH     | RW   | 32                    | 0x0000 0014    | 0x480B CC14      |
| H3A_AFBUFST     | RW   | 32                    | 0x0000 0018    | 0x480B CC18      |
| H3A_AFCEOEF010  | RW   | 32                    | 0x0000 001C    | 0x480B CC1C      |
| H3A_AFCEOEF032  | RW   | 32                    | 0x0000 0020    | 0x480B CC20      |
| H3A_AFCEOEF054  | RW   | 32                    | 0x0000 0024    | 0x480B CC24      |
| H3A_AFCEOEF076  | RW   | 32                    | 0x0000 0028    | 0x480B CC28      |
| H3A_AFCEOEF098  | RW   | 32                    | 0x0000 002C    | 0x480B CC2C      |
| H3A_AFCEOEF0010 | RW   | 32                    | 0x0000 0030    | 0x480B CC30      |
| H3A_AFCEOEF110  | RW   | 32                    | 0x0000 0034    | 0x480B CC34      |
| H3A_AFCEOEF132  | RW   | 32                    | 0x0000 0038    | 0x480B CC38      |
| H3A_AFCEOEF154  | RW   | 32                    | 0x0000 003C    | 0x480B CC3C      |
| H3A_AFCEOEF176  | RW   | 32                    | 0x0000 0040    | 0x480B CC40      |
| H3A_AFCEOEF198  | RW   | 32                    | 0x0000 0044    | 0x480B CC44      |
| H3A_AFCEOEF1010 | RW   | 32                    | 0x0000 0048    | 0x480B CC48      |
| H3A_AEWWIN1     | RW   | 32                    | 0x0000 004C    | 0x480B CC4C      |
| H3A_AEWINSTART  | RW   | 32                    | 0x0000 0050    | 0x480B CC50      |
| H3A_AEWINBLK    | RW   | 32                    | 0x0000 0054    | 0x480B CC54      |
| H3A_AEWSUBWIN   | RW   | 32                    | 0x0000 0058    | 0x480B CC58      |
| H3A_AEWBUFST    | RW   | 32                    | 0x0000 005C    | 0x480B CC5C      |

## 6.6.6.2 Camera ISP H3A Register Description

**Table 6-305. H3A\_PID**

|                       |                        |                         |             |                 |         |
|-----------------------|------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 0000            | <b>Physical Address</b> | 0x480B CC00 | <b>Instance</b> | ISP_H3A |
| <b>Description</b>    | PERIPHERAL ID REGISTER |                         |             |                 |         |
| <b>Type</b>           | R                      |                         |             |                 |         |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | TID                     | CID                   | PREV            |

| Bits  | Field Name | Description                                         | Type | Reset            |
|-------|------------|-----------------------------------------------------|------|------------------|
| 31:24 | RESERVED   | Write 0s for future compatibility. Reads returns 0. | R    | 0x00             |
| 23:16 | TID        | Peripheral identification: H3A module               | R    | 0x08             |
| 15:8  | CID        | Class identification: Camera ISP                    | R    | 0xFE             |
| 7:0   | PREV       | Peripheral revision number                          | R    | TI internal data |

**Table 6-306. Register Call Summary for Register H3A\_PID**

Camera ISP Register Manual

- [Camera ISP H3A Register Summary: \[0\]](#)

**Table 6-307. H3A\_PCR**

|                       |                             |                         |             |                 |         |
|-----------------------|-----------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 0004                 | <b>Physical Address</b> | 0x480B CC04 | <b>Instance</b> | ISP_H3A |
| <b>Description</b>    | PERIPHERAL CONTROL REGISTER |                         |             |                 |         |
| <b>Type</b>           | RW                          |                         |             |                 |         |

|                         |                                       |                       |                                   |
|-------------------------|---------------------------------------|-----------------------|-----------------------------------|
| 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                   |
| AVE2LMT                 | RESERVED BUSYAEAWB AEW_ALAW_EN AEW_EN | BUSYAF FVMODE RGBPOS  | MED_TH AF_MED_EN AF_ALAW_EN AF_EN |

| Bits  | Field Name  | Description                                                                                                                                       | Type | Reset |
|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:22 | AVE2LMT     | AE AWB saturation limit.<br>All pixels in a block are compared to this limit. If one pixel is above the limit, the block is considered saturated. | RW   | 0x3FF |
| 21:19 | RESERVED    | Write 0s for future compatibility.<br>Reads returns 0.                                                                                            | RW   | 0x0   |
| 18    | BUSYAEAWB   | AE AWB busy<br>0x0: AE AWB not busy<br>0x1: AE AWB busy                                                                                           | R    | 0x0   |
| 17    | AEW_ALAW_EN | AE AWB A-Law enable<br>0x0: Disable AE AWB A-Law table.<br>0x1: Disable AE AWB A-Law table.                                                       | RW   | 0x0   |
| 16    | AEW_EN      | AE AWB enable<br>0x0: Disable AE AWB.<br>0x1: Enable AE AWB.                                                                                      | RW   | 0x0   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                  | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15    | BUSYAF     | AF busy<br>0x0: AF not busy.<br>0x1: AF busy.                                                                                                                                                                                                                | R    | 0x0   |
| 14    | FVMODE     | Focus value accumulation mode<br>0x0: Sum mode.<br>0x1: Peak mode.                                                                                                                                                                                           | RW   | 0x0   |
| 13:11 | RGBPOS     | RGB pixel position in the AF windows<br>0x0: GR and GB as Bayer pattern.<br>0x1: RG and GB as Bayer pattern.<br>0x2: GR and BG as Bayer pattern.<br>0x3: RG and BG as Bayer pattern.<br>0x4: GG and RB as Bayer pattern.<br>0x5: RB and GG as Bayer pattern. | RW   | 0x0   |
| 10:3  | MED_TH     | Median filter threshold                                                                                                                                                                                                                                      | RW   | 0xFF  |
| 2     | AF_MED_EN  | AF median filter enable<br>0x0: Disable autofocus median filter<br>0x1: Enable autofocus median filter                                                                                                                                                       | RW   | 0x0   |
| 1     | AF_ALAW_EN | AF A-Law table enable<br>0x0: Disable autofocus A-Law table.<br>0x1: Enable autofocus A-Law table.                                                                                                                                                           | RW   | 0x0   |
| 0     | AF_EN      | AF enable<br>0x0: Disable autofocus<br>0x1: Enable autofocus                                                                                                                                                                                                 | RW   | 0x0   |

**Table 6-308. Register Call Summary for Register H3A\_PCR**
**Camera ISP Functional Description**

- [Camera ISP H3A Autofocus Engine](#):
- [Camera ISP H3A AE/AWB Engine](#):

**Camera ISP Basic Programming Model**

- [Camera ISP H3A Register Setup](#): [7] [8] [9] [10] [11] [12] [13] [14] [15] [16]
- [Camera ISP H3A Enable/Disable Hardware](#): [17] [18] [19] [20]
- [Camera ISP H3A Register Accessibility During Frame Processing](#): [21] [22] [23] [24] [25]
- [Camera ISP H3A Interframe Operations](#): [26]
- [Camera ISP Histogram Interframe Operations](#): [27]

**Camera ISP Register Manual**

- [Camera ISP H3A Register Summary](#): [28]

**Table 6-309. H3A\_AFPAX1**

|                         |                         |                       |                 |          |      |          |      |  |  |  |                 |  |  |  |         |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|----------|------|----------|------|--|--|--|-----------------|--|--|--|---------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0008             |                       |                 |          |      |          |      |  |  |  |                 |  |  |  |         |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CC08             |                       |                 |          |      |          |      |  |  |  | <b>Instance</b> |  |  |  | ISP_H3A |  |  |  |  |  |  |  |
| <b>Description</b>      | AF PAXEL CONFIGURATION  |                       |                 |          |      |          |      |  |  |  |                 |  |  |  |         |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |                       |                 |          |      |          |      |  |  |  |                 |  |  |  |         |  |  |  |  |  |  |  |
| 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 | RESERVED | PAXW | RESERVED | PAXH |  |  |  |                 |  |  |  |         |  |  |  |  |  |  |  |

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                        | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:23 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                             | RW   | 0x000 |
| 22:16 | PAXW       | Paxel width.<br>The paxel width is set by $2 \times (\text{PAXW}+1)$ . The paxel-width range varies from 2 to 256.<br>The paxel width must be set to a minimum value of 16 pixels. | RW   | 0x00  |
| 15:7  | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                             | RW   | 0x000 |
| 6:0   | PAXH       | Paxel height.<br>The paxel height is set by $2 \times (\text{PAXH}+1)$ . The paxel-height range varies from 2 to 256.                                                              | RW   | 0x00  |

**Table 6-310. Register Call Summary for Register H3A\_AFPAX1**

Camera ISP Functional Description

- Camera ISP H3A Autofocus Engine:

Camera ISP Basic Programming Model

- Camera ISP H3A Register Setup: [2]

Camera ISP Register Manual

- Camera ISP H3A Register Summary: [3]

**Table 6-311. H3A\_AFPAX2**

|                         |                         |                       |                 |          |        |       |       |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|----------|--------|-------|-------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 000C             |                       |                 |          |        |       |       |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CC0C             |                       |                 |          |        |       |       |  |  |  |  |  |  |  |
| <b>Description</b>      | AF PAXEL CONFIGURATION  |                       |                 |          |        |       |       |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |                       |                 |          |        |       |       |  |  |  |  |  |  |  |
| 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 | RESERVED | AFINCV | PAXVC | PAXHC |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                         | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:17 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                              | RW   | 0x0000 |
| 16:13 | AFINCV     | AF line increments.<br>The number of lines to skip in a paxel is set by $2 \times (\text{AFINCV}+1)$ .                                                                                                                              | RW   | 0x0    |
| 12:6  | PAXVC      | Paxel count in the vertical direction.<br>The number of paxels in the vertical direction is set by $\text{PAXVC}+1$ . It is illegal to have more than 128 paxels in the vertical direction. We have: $0 = \text{PAXVC} = 127$ .     | RW   | 0x00   |
| 5:0   | PAXHC      | Paxel count in the horizontal direction.<br>The number of paxels in the horizontal direction is set by $\text{PAXHC}+1$ . It is illegal to have more than 36 paxels in the horizontal direction. We have: $0 = \text{PAXHC} = 35$ . | RW   | 0x00   |

**Table 6-312. Register Call Summary for Register H3A\_AFPAX2**

Camera ISP Functional Description

- Camera ISP H3A Autofocus Engine:

Camera ISP Basic Programming Model

- Camera ISP H3A Register Setup: [3]

Camera ISP Register Manual

- Camera ISP H3A Register Summary: [4]

**Table 6-313. H3A\_AFPAXSTART**

|                         |                                  |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0010                      |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CC10                      |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | AF PAXEL START POSITION REGISTER |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                               |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | PAXSH                            | RESERVED              | PAXSV           |  |  |  |  |  |  |  |  |  |  |  |

  

| Bits  | Field Name | Description                                                                                                                                                                      | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                           | RW   | 0x0   |
| 27:16 | PAXSH      | AF pixel horizontal start position.<br>Sets the horizontal position for the first pixel. The range is 1 to 4095. PAXSH must be equal to or greater than (H3A_AFIRSH.AFIRSH + 1). | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                           | RW   | 0x0   |
| 11:0  | PAXSV      | AF pixel vertical start position.<br>Sets the vertical position for the first pixel. The range is 0 to 4095.                                                                     | RW   | 0x000 |

**Table 6-314. Register Call Summary for Register H3A\_AFPAXSTART**

Camera ISP Functional Description

- [Camera ISP H3A Autofocus Engine](#):

Camera ISP Basic Programming Model

- [Camera ISP H3A Register Setup](#): [2]

Camera ISP Register Manual

- [Camera ISP H3A Register Summary](#): [3]

**Table 6-315. H3A\_AFIRSH**

|                         |                                           |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0014                               |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CC14                               |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | AF IIR HORIZONTAL START POSITION REGISTER |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                        |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                           |                       | IIRSH           |  |  |  |  |  |  |  |  |  |  |  |

  

| Bits  | Field Name | Description                                                                                                                                                              | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                   | RW   | 0x00000 |
| 11:0  | IIRSH      | AF IIR horizontal start position.<br>The range is 0 to 4095. When the horizontal position of a line equals this value the shift registers are cleared on the next pixel. | RW   | 0x000   |

**Table 6-316. Register Call Summary for Register H3A\_AFIRSH**

Camera ISP Functional Description

- [Camera ISP H3A Autofocus Engine](#):

Camera ISP Basic Programming Model

- [Camera ISP H3A Register Setup](#): [2]

**Table 6-316. Register Call Summary for Register H3A\_AFIIRSH (continued)**

Camera ISP Register Manual

- Camera ISP H3A Register Summary: [3]
- Camera ISP H3A Register Description: [4]

**Table 6-317. H3A\_AFBUFST**

|                         |                         |                         |                 |                 |          |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 0018             | <b>Physical Address</b> | 0x480B CC18     | <b>Instance</b> | ISP_H3A  |
| <b>Description</b>      | AF MEMORY ADDRESS       |                         |                 |                 |          |
| <b>Type</b>             | RW                      |                         |                 |                 |          |
| 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 | AFBUFST         |          |
| AFBUFST                 |                         |                         |                 |                 | RESERVED |

| Bits | Field Name | Description                                            | Type | Reset     |
|------|------------|--------------------------------------------------------|------|-----------|
| 31:5 | AFBUFST    | Address                                                | RW   | 0x0000000 |
| 4:0  | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x00      |

**Table 6-318. Register Call Summary for Register H3A\_AFBUFST**

Camera ISP Functional Description

- Camera ISP H3A Autofocus Engine:

Camera ISP Basic Programming Model

- Camera ISP H3A Register Setup: [1]
- Camera ISP H3A Register Accessibility During Frame Processing: [2]

Camera ISP Register Manual

- Camera ISP H3A Register Summary: [3]

**Table 6-319. H3A\_AFCOEF010**

|                         |                                       |                         |                 |                 |         |  |
|-------------------------|---------------------------------------|-------------------------|-----------------|-----------------|---------|--|
| <b>Address Offset</b>   | 0x0000 001C                           | <b>Physical Address</b> | 0x480B CC1C     | <b>Instance</b> | ISP_H3A |  |
| <b>Description</b>      | IIR FILTER COEF DATA REGISTER - SET 0 |                         |                 |                 |         |  |
| <b>Type</b>             | RW                                    |                         |                 |                 |         |  |
| 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 | COEFF1          |         |  |
| RESERVED                | COEFF1                                |                         |                 | RESERVED        | COEFF0  |  |

| Bits  | Field Name | Description                                                                                                                            | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 27:16 | COEFF1     | AF IIR filter coefficient 1 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 11:0  | COEFF0     | AF IIR filter coefficient 0 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |

**Table 6-320. Register Call Summary for Register H3A\_AFCOEF010**

Camera ISP Functional Description

- [Camera ISP H3A Autofocus Engine:](#)

Camera ISP Basic Programming Model

- [Camera ISP H3A Register Setup: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP H3A Register Summary: \[2\]](#)

**Table 6-321. H3A\_AFCOEF032**

|                         |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0020                           |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CC20                           |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | IIR FILTER COEF DATA REGISTER - SET 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEFF3                  | RESERVED              | COEFF2          |

| Bits  | Field Name | Description                                                                                                                            | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 27:16 | COEFF3     | AF IIR filter coefficient 3 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 11:0  | COEFF2     | AF IIR filter coefficient 2 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |

**Table 6-322. Register Call Summary for Register H3A\_AFCOEF032**

Camera ISP Register Manual

- [Camera ISP H3A Register Summary: \[0\]](#)

**Table 6-323. H3A\_AFCOEF054**

|                         |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0024                           |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CC24                           |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | IIR FILTER COEF DATA REGISTER - SET 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEFF5                  | RESERVED              | COEFF4          |

| Bits  | Field Name | Description                                                                                                                            | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 27:16 | COEFF5     | AF IIR filter coefficient 5 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                            | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 11:0 | COEFF4     | AF IIR filter coefficient 4 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |

**Table 6-324. Register Call Summary for Register H3A\_AFCOEF054**

Camera ISP Register Manual

- Camera ISP H3A Register Summary: [0]

**Table 6-325. H3A\_AFCOEF076**

|                  |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 0028                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | 0x480B CC28                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | IIR FILTER COEF DATA REGISTER - SET 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEFF7                  | RESERVED              | COEFF6          |

| Bits  | Field Name | Description                                                                                                                            | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 27:16 | COEFF7     | AF IIR filter coefficient 7 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 11:0  | COEFF6     | AF IIR filter coefficient 6 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |

**Table 6-326. Register Call Summary for Register H3A\_AFCOEF076**

Camera ISP Register Manual

- Camera ISP H3A Register Summary: [0]

**Table 6-327. H3A\_AFCOEF098**

|                  |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 002C                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | 0x480B CC2C                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | IIR FILTER COEF DATA REGISTER - SET 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEFF9                  | RESERVED              | COEFF8          |

| Bits  | Field Name | Description                                                                                                                            | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 27:16 | COEFF9     | AF IIR filter coefficient 8 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                            | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 11:0 | COEFF8     | AF IIR filter coefficient 9 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |

**Table 6-328. Register Call Summary for Register H3A\_AFCOEF098**

Camera ISP Register Manual

- [Camera ISP H3A Register Summary: \[0\]](#)

**Table 6-329. H3A\_AFCOEF0010**

|                         |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |
|-------------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|---------|--|--|--|
| <b>Address Offset</b>   | 0x0000 0030                           |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_H3A |  |  |  |
| <b>Physical Address</b> | 0x480B CC30                           |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |
| <b>Description</b>      | IIR FILTER COEF DATA REGISTER - SET 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |
| <b>Type</b>             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         |                       | COEFF10         |

| Bits  | Field Name | Description                                                                                                                             | Type | Reset   |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED   | Write Os for future compatibility.<br>Reads returns 0.                                                                                  | RW   | 0x00000 |
| 11:0  | COEFF10    | AF IIR filter coefficient 10 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000   |

**Table 6-330. Register Call Summary for Register H3A\_AFCOEF0010**

Camera ISP Functional Description

- [Camera ISP H3A Autofocus Engine:](#)

Camera ISP Register Manual

- [Camera ISP H3A Register Summary: \[1\]](#)

**Table 6-331. H3A\_AFCOEF110**

|                         |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |
|-------------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|---------|--|--|--|
| <b>Address Offset</b>   | 0x0000 0034                           |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_H3A |  |  |  |
| <b>Physical Address</b> | 0x480B CC34                           |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |
| <b>Description</b>      | IIR FILTER COEF DATA REGISTER - SET 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |
| <b>Type</b>             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEFF1                  |                       |                 |

| Bits  | Field Name | Description                                                                                                                            | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write Os for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 27:16 | COEFF1     | AF IIR filter coefficient 1 (set1)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |
| 15:12 | RESERVED   | Write Os for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 11:0  | COEFF0     | AF IIR filter coefficient 0 (set1)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |

**Table 6-332. Register Call Summary for Register H3A\_AFCOEF110**

Camera ISP Functional Description  
 • Camera ISP H3A Autofocus Engine:

Camera ISP Register Manual  
 • Camera ISP H3A Register Summary: [1]

**Table 6-333. H3A\_AFCOEF132**

|                         |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |         |
|-------------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|---------|
| <b>Address Offset</b>   | 0x0000 0038                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |         |
| <b>Physical Address</b> | 0x480B CC38                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Instance | ISP_H3A |
| <b>Description</b>      | IIR FILTER COEF DATA REGISTER - SET 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |         |
| <b>Type</b>             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |         |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEFF3                  | RESERVED              | COEFF2          |

| Bits  | Field Name | Description                                                                                                                            | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 27:16 | COEFF3     | AF IIR filter coefficient 3 (set1)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 11:0  | COEFF2     | AF IIR filter coefficient 2 (set1)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |

**Table 6-334. Register Call Summary for Register H3A\_AFCOEF132**

Camera ISP Register Manual  
 • Camera ISP H3A Register Summary: [0]

**Table 6-335. H3A\_AFCOEF154**

|                         |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |         |
|-------------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|---------|
| <b>Address Offset</b>   | 0x0000 003C                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |         |
| <b>Physical Address</b> | 0x480B CC3C                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Instance | ISP_H3A |
| <b>Description</b>      | IIR FILTER COEF DATA REGISTER - SET 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |         |
| <b>Type</b>             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |         |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEFF5                  | RESERVED              | COEFF4          |

| Bits  | Field Name | Description                                                                                                                            | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 27:16 | COEFF5     | AF IIR filter coefficient 5 (set1)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 11:0  | COEFF4     | AF IIR filter coefficient 4 (set1)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |

**Table 6-336. Register Call Summary for Register H3A\_AFCOEF154**

Camera ISP Register Manual

- [Camera ISP H3A Register Summary: \[0\]](#)

**Table 6-337. H3A\_AFCOEF176**

|                         |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0040                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CC40                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | IIR FILTER COEF DATA REGISTER - SET 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| 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 |  |  |  |  |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                            | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 27:16 | COEFF7     | AF IIR filter coefficient 7 (set1)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 11:0  | COEFF6     | AF IIR filter coefficient 6 (set1)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |

**Table 6-338. Register Call Summary for Register H3A\_AFCOEF176**

Camera ISP Register Manual

- [Camera ISP H3A Register Summary: \[0\]](#)

**Table 6-339. H3A\_AFCOEF198**

|                         |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0044                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CC44                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | IIR FILTER COEF DATA REGISTER - SET 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| 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 |  |  |  |  |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                            | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 27:16 | COEFF9     | AF IIR filter coefficient 9 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                 | RW   | 0x0   |
| 11:0  | COEFF8     | AF IIR filter coefficient 8 (set0)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000 |

**Table 6-340. Register Call Summary for Register H3A\_AFCOEF198**

- Camera ISP Register Manual
- [Camera ISP H3A Register Summary: \[0\]](#)

**Table 6-341. H3A\_AFCOEF1010**

|                         |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0048                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CC48                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | IIR FILTER COEF DATA REGISTER - SET 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | COEFF10 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                             | Type | Reset   |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                  | RW   | 0x00000 |
| 11:0  | COEFF10    | AF IIR filter coefficient 10 (set1)<br>The coefficient value is signed in S12Q6 representation.<br>The range is -32 = coeff = 31.96875. | RW   | 0x000   |

**Table 6-342. Register Call Summary for Register H3A\_AFCOEF1010**

- Camera ISP Functional Description
- [Camera ISP H3A Autofocus Engine: \[1\]](#)
- Camera ISP Basic Programming Model
- [Camera ISP H3A Register Setup: \[1\]](#)
- Camera ISP Register Manual
- [Camera ISP H3A Register Summary: \[2\]](#)

**Table 6-343. H3A\_AEWWIN1**

|                         |                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 004C             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CC4C             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | AE AWB CONTROL REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |      |    |          |    |      |    |       |    |       |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|------|----|----------|----|------|----|-------|----|-------|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED | WINH |    | RESERVED |    | WINW |    | WINVC |    | WINHC |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                      | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                           | RW   | 0x0   |
| 30:24 | WINH       | AE AWB window height.<br>The window height is given by 2 x (WINH+1). The final value ranges between 2 to 256 (even values only). | RW   | 0x00  |
| 23:20 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                           | RW   | 0x0   |
| 19:13 | WINW       | AE AWB window width.<br>The window width is given by 2 x (WINW+1). The final value ranges between 2 to 256 (even values only).   | RW   | 0x00  |

| Bits | Field Name | Description                                                                                                                                                                 | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 12:6 | WINVC      | AE AWB vertical window count<br>The number of windows in the vertical direction is set by WINVC + 1. The maximum number of vertical windows in a frame must not exceed 128. | RW   | 0x00  |
| 5:0  | WINHC      | AE AWB horizontal window count.<br>The number of horizontal windows is set by WINHC + 1. The maximum number of horizontal windows in a frame must not exceed 36.            | RW   | 0x00  |

**Table 6-344. Register Call Summary for Register H3A\_AEWWIN1**

Camera ISP Functional Description

- [Camera ISP H3A AE/AWB Engine](#):

Camera ISP Basic Programming Model

- [Camera ISP H3A Register Setup: \[4\]](#)

Camera ISP Register Manual

- [Camera ISP H3A Register Summary: \[5\]](#)

**Table 6-345. H3A\_AEWINSTART**

|                  |                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|--------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 0050                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | 0x480B CC50                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | AE AWB START POSITION REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | RW                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | WINSV                   | RESERVED              | WINSH           |

| Bits  | Field Name | Description                                                                                                                         | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                              | RW   | 0x0   |
| 27:16 | WINSV      | AE AWB vertical window start position.<br>Sets the first line for the first window. The range is 0 to 4095.                         | RW   | 0x000 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                              | RW   | 0x0   |
| 11:0  | WINSH      | AE AWB horizontal window start position.<br>Sets the horizontal position for the first window on each line. The range is 0 to 4095. | RW   | 0x000 |

**Table 6-346. Register Call Summary for Register H3A\_AEWINSTART**

Camera ISP Functional Description

- [Camera ISP H3A AE/AWB Engine](#):

Camera ISP Basic Programming Model

- [Camera ISP H3A Register Setup: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP H3A Register Summary: \[3\]](#)

**Table 6-347. H3A\_AEWINBLK**

| <b>Address Offset</b>   | 0x0000 0054             |                                                                                                                                                                                                                                                                         |                 |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_H3A |       |  |  |  |  |  |
|-------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|---------|-------|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B CC54             |                                                                                                                                                                                                                                                                         |                 |  |  |  |  |  |  |  |  |  |  |  |                 |         |       |  |  |  |  |  |
| <b>Description</b>      | BLACK LINE REGISTER     |                                                                                                                                                                                                                                                                         |                 |  |  |  |  |  |  |  |  |  |  |  |                 |         |       |  |  |  |  |  |
| <b>Type</b>             | RW                      |                                                                                                                                                                                                                                                                         |                 |  |  |  |  |  |  |  |  |  |  |  |                 |         |       |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |                 |         |       |  |  |  |  |  |
| RESERVED                | WINSV                   |                                                                                                                                                                                                                                                                         |                 |  |  |  |  |  |  |  |  |  |  |  | RESERVED        | WINH    |       |  |  |  |  |  |
| Bits                    | Field Name              | Description                                                                                                                                                                                                                                                             |                 |  |  |  |  |  |  |  |  |  |  |  |                 | Type    | Reset |  |  |  |  |  |
| 31:28                   | RESERVED                | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                  |                 |  |  |  |  |  |  |  |  |  |  |  |                 | RW      | 0x0   |  |  |  |  |  |
| 27:16                   | WINSV                   | AE AWB vertical window start position for the single black line of windows.<br>Sets the first line for the single black line of windows. The range is 0 to 4095. Note that the horizontal start and the horizontal number of windows is similar to the regular windows. |                 |  |  |  |  |  |  |  |  |  |  |  |                 | RW      | 0x000 |  |  |  |  |  |
| 15:7                    | RESERVED                | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                  |                 |  |  |  |  |  |  |  |  |  |  |  |                 | RW      | 0x000 |  |  |  |  |  |
| 6:0                     | WINH                    | AE AWB window height for the single black line of windows.<br>The window height is set by 2 x (WINH + 1). The range is 2 to 256 (even values only).                                                                                                                     |                 |  |  |  |  |  |  |  |  |  |  |  |                 | RW      | 0x00  |  |  |  |  |  |

**Table 6-348. Register Call Summary for Register H3A\_AEWINBLK**

Camera ISP Functional Description

- [Camera ISP H3A AE/AWB Engine](#):

Camera ISP Basic Programming Model

- [Camera ISP H3A Register Setup](#): [2]

Camera ISP Register Manual

- [Camera ISP H3A Register Summary](#): [3]

**Table 6-349. H3A\_AEWSUBWIN**

| <b>Address Offset</b>   | 0x0000 0058             |                                                                                                                                                                                   |                 |  |          |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_H3A |         |  |         |          |         |  |  |  |
|-------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|----------|--|--|--|--|--|--|--|--|--|-----------------|---------|---------|--|---------|----------|---------|--|--|--|
| <b>Physical Address</b> | 0x480B CC58             |                                                                                                                                                                                   |                 |  |          |  |  |  |  |  |  |  |  |  |                 |         |         |  |         |          |         |  |  |  |
| <b>Description</b>      | AE AWB REGISTER         |                                                                                                                                                                                   |                 |  |          |  |  |  |  |  |  |  |  |  |                 |         |         |  |         |          |         |  |  |  |
| <b>Type</b>             | RW                      |                                                                                                                                                                                   |                 |  |          |  |  |  |  |  |  |  |  |  |                 |         |         |  |         |          |         |  |  |  |
| 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 |  | RESERVED |  |  |  |  |  |  |  |  |  |                 |         |         |  | AEWINCV | RESERVED | AEWINCH |  |  |  |
| Bits                    | Field Name              | Description                                                                                                                                                                       |                 |  |          |  |  |  |  |  |  |  |  |  |                 | Type    | Reset   |  |         |          |         |  |  |  |
| 31:12                   | RESERVED                | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                            |                 |  |          |  |  |  |  |  |  |  |  |  |                 | RW      | 0x00000 |  |         |          |         |  |  |  |
| 11:8                    | AEWINCV                 | AE AWB vertical sampling point increment.<br>Sets the vertical distance between subsamples. The increment is set by 2 x (AEWINCV+1). The range is 2 to 32 (even values only).     |                 |  |          |  |  |  |  |  |  |  |  |  |                 | RW      | 0x0     |  |         |          |         |  |  |  |
| 7:4                     | RESERVED                | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                            |                 |  |          |  |  |  |  |  |  |  |  |  |                 | RW      | 0x0     |  |         |          |         |  |  |  |
| 3:0                     | AEWINCH                 | AE AWB horizontal sampling point increment.<br>Sets the horizontal distance between subsamples. The increment is set by 2 x (AEWINCH+1). The range is 2 to 32 (even values only). |                 |  |          |  |  |  |  |  |  |  |  |  |                 | RW      | 0x0     |  |         |          |         |  |  |  |

**Table 6-350. Register Call Summary for Register H3A\_AEWSUBWIN**

Camera ISP Functional Description

- [Camera ISP H3A AE/AWB Engine](#):

Camera ISP Basic Programming Model

- [Camera ISP H3A Register Setup: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP H3A Register Summary: \[3\]](#)

**Table 6-351. H3A\_AEWBUFST**

|                       |                       |                         |             |                 |         |
|-----------------------|-----------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 005C           | <b>Physical Address</b> | 0x480B CC5C | <b>Instance</b> | ISP_H3A |
| <b>Description</b>    | AE AWB MEMORY ADDRESS |                         |             |                 |         |
| <b>Type</b>           | RW                    |                         |             |                 |         |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |          |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----------|---|---|---|---|---|
| 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 |
| AEWBUFST |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | RESERVED |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                               | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:5 | AEWBUFST   | AE AWB memory start address<br>The start address in memory where the AE/AWB data are written.<br>This field can be modified even when the AE/AWB submodule is busy. The change takes place only for the next frame. However, register reads always give the latest value. | RW   | 0x00000000 |
| 4:0  | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                    | RW   | 0x00       |

**Table 6-352. Register Call Summary for Register H3A\_AEWBUFST**

Camera ISP Functional Description

- [Camera ISP H3A AE/AWB Engine](#):

Camera ISP Basic Programming Model

- [Camera ISP H3A Register Setup: \[1\]](#)
- [Camera ISP H3A Register Accessibility During Frame Processing: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP H3A Register Summary: \[3\]](#)

## 6.6.7 Camera ISP PREVIEW Registers

### 6.6.7.1 Camera ISP PREVIEW Register Summary

**Table 6-353. ISP\_PREVIEW Register Summary**

| Register Name   | Type | Register Width (Bits) | Address Offset | Physical Address |
|-----------------|------|-----------------------|----------------|------------------|
| PRV_PID         | R    | 32                    | 0x0000 0000    | 0x480B CE00      |
| PRV_PCR         | RW   | 32                    | 0x0000 0004    | 0x480B CE04      |
| PRV_HORZ_INFO   | RW   | 32                    | 0x0000 0008    | 0x480B CE08      |
| PRV_VERT_INFO   | RW   | 32                    | 0x0000 000C    | 0x480B CE0C      |
| PRV_RSDR_ADDR   | RW   | 32                    | 0x0000 0010    | 0x480B CE10      |
| PRV_RADR_OFFSET | RW   | 32                    | 0x0000 0014    | 0x480B CE14      |
| PRV_DSDR_ADDR   | RW   | 32                    | 0x0000 0018    | 0x480B CE18      |
| PRV_DRKF_OFFSET | RW   | 32                    | 0x0000 001C    | 0x480B CE1C      |

**Table 6-353. ISP\_PREVIEW Register Summary (continued)**

| Register Name               | Type | Register Width (Bits) | Address Offset          | Physical Address        |
|-----------------------------|------|-----------------------|-------------------------|-------------------------|
| PRV_WSDR_ADDR               | RW   | 32                    | 0x0000 0020             | 0x480B CE20             |
| PRV_WADD_OFFSET             | RW   | 32                    | 0x0000 0024             | 0x480B CE24             |
| PRV_AVE                     | RW   | 32                    | 0x0000 0028             | 0x480B CE28             |
| PRV_HMED                    | RW   | 32                    | 0x0000 002C             | 0x480B CE2C             |
| PRV_NF                      | RW   | 32                    | 0x0000 0030             | 0x480B CE30             |
| PRV_WB_DGAIN                | RW   | 32                    | 0x0000 0034             | 0x480B CE34             |
| PRV_WBGAIN                  | RW   | 32                    | 0x0000 0038             | 0x480B CE38             |
| PRV_WBSEL                   | RW   | 32                    | 0x0000 003C             | 0x480B CE3C             |
| PRV_CFA                     | RW   | 32                    | 0x0000 0040             | 0x480B CE40             |
| PRV_BLKADJOFF               | RW   | 32                    | 0x0000 0044             | 0x480B CE44             |
| PRV_RGB_MAT1                | RW   | 32                    | 0x0000 0048             | 0x480B CE48             |
| PRV_RGB_MAT2                | RW   | 32                    | 0x0000 004C             | 0x480B CE4C             |
| PRV_RGB_MAT3                | RW   | 32                    | 0x0000 0050             | 0x480B CE50             |
| PRV_RGB_MAT4                | RW   | 32                    | 0x0000 0054             | 0x480B CE54             |
| PRV_RGB_MAT5                | RW   | 32                    | 0x0000 0058             | 0x480B CE58             |
| PRV_RGB_OFF1                | RW   | 32                    | 0x0000 005C             | 0x480B CE5C             |
| PRV_RGB_OFF2                | RW   | 32                    | 0x0000 0060             | 0x480B CE60             |
| PRV_CSC0                    | RW   | 32                    | 0x0000 0064             | 0x480B CE64             |
| PRV_CSC1                    | RW   | 32                    | 0x0000 0068             | 0x480B CE68             |
| PRV_CSC2                    | RW   | 32                    | 0x0000 006C             | 0x480B CE6C             |
| PRV_CSC_OFFSET              | RW   | 32                    | 0x0000 0070             | 0x480B CE70             |
| PRV_CNT_BRT                 | RW   | 32                    | 0x0000 0074             | 0x480B CE74             |
| PRV_CSUP                    | RW   | 32                    | 0x0000 0078             | 0x480B CE78             |
| PRV_SETUP_YC                | RW   | 32                    | 0x0000 007C             | 0x480B CE7C             |
| PRV_SET_TBL_ADDR            | RW   | 32                    | 0x0000 0080             | 0x480B CE80             |
| PRV_SET_TBL_DATA            | RW   | 32                    | 0x0000 0084             | 0x480B CE84             |
| PRV_CDC_THRx <sup>(1)</sup> | RW   | 32                    | 0x0000 0090 + (x * 0x4) | 0x480B CE90 + (x * 0x4) |

<sup>(1)</sup> x = 0 to 3

### 6.6.7.2 Camera ISP PREVIEW Register Description

**Table 6-354. PRV\_PID**

|                  |                        |          |             |
|------------------|------------------------|----------|-------------|
| Address Offset   | 0x0000 0000            | Instance | ISP_PREVIEW |
| Physical Address | 0x480B CE00            |          |             |
| Description      | PERIPHERAL ID REGISTER |          |             |
| Type             | R                      |          |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | TID                     | CID                   | PREV            |

| Bits  | Field Name | Description                                         | Type | Reset            |
|-------|------------|-----------------------------------------------------|------|------------------|
| 31:24 | RESERVED   | Write 0s for future compatibility. Reads returns 0. | R    | 0x00             |
| 23:16 | TID        | Peripheral identification: PRV module               | R    | 0x02             |
| 15:8  | CID        | Class identification: Camera ISP                    | R    | 0xFE             |
| 7:0   | PREV       | Peripheral revision number                          | R    | TI internal data |

**Table 6-355. Register Call Summary for Register PRV\_PID**

Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[0\]](#)

**Table 6-356. PRV\_PCR**

|                         |                                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0004                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_PREVIEW |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE04                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |
| <b>Description</b>      | PERIPHERAL CONTROL REGISTER All the fields in this register can be altered even when the PREVIEW module is busy. Changes take place only for the next frame. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |  |

| 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 |
|----------|----------|-------------|--------|--------------|----------|-----------|----------|---------|---------|------|-------|---------|--------|-------|-------|--------|---------|--------|---------|-------|---------|--------|------|--------|---|---|---|---|---|---|---|
| DRK_FAIL | RESERVED | DCOR_METHOD | DCOREN | GAMMA_BYPASS | RESERVED | SCOMP_SFT | SCOMP_EN | SDRPORT | RSZPORT | YPOS | SUPEN | YNENHEN | CFAFMT | CFAEN | NIFEN | HMEDEN | DRKFCAP | DRKFEN | INVALAW | WIDTH | ONESHOT | SOURCE | BUSY | ENABLE |   |   |   |   |   |   |   |

| Bits  | Field Name   | Description                                                                                                                                                                                                                                                                                                                                                                                      | Type | Reset |
|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | DRK_FAIL     | Dark frame subtract fail status.<br>Write 1 to clear this bit.<br><br>Reset to zero for the next frame. When the error is triggered, dark frame subtract is abandoned for the current frame, dark frame subtract resumes for next frame (but bit is not cleared unless explicitly done by firmware).<br><br>0x0: No error<br>0x1: Error                                                          | RW   | 0x0   |
| 30:29 | RESERVED     | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                           | RW   | 0x0   |
| 28    | DCOR_METHOD  | Defect correction method.<br><br>0x0: MinMax<br>0x1: MinMax2 (Couplet defect correction)                                                                                                                                                                                                                                                                                                         | RW   | 0x0   |
| 27    | DCOREN       | Defect correction enable<br><br>This bit enables or disables the defect correction. The <a href="#">PRV_PCR.DCOR_METHOD</a> and <a href="#">PRV_CDC_THRx</a> registers must be configured for correct operation.<br><br>0x0: Disable defect correction<br>0x1: Enable defect correction                                                                                                          | RW   | 0x0   |
| 26    | GAMMA_BYPASS | Bypass, the output is set to the 8 MSB of the 10-bit input.<br><br>0x0: No bypass.<br><br>0x1: Bypass, the output is set to the 8 MSB of the 10-bit input.                                                                                                                                                                                                                                       | RW   | 0x0   |
| 25    | RESERVED     | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                           | RW   | 0x0   |
| 24:22 | SCOMP_SFT    | Shading compensation shift value after multiplication.<br>The right-shift range is 0 to 7.                                                                                                                                                                                                                                                                                                       | RW   | 0x0   |
| 21    | SCOMP_EN     | Shading compensation enable instead of dark frame<br>The 8-bit value loaded from memory is multiplied by the current pixel instead of subtracting it. Note that the dark frame subtract (DRKFEN) must be enabled in addition to this bit being active to perform shading compensation.<br><br>0x0: Disable. Dark frame subtract can be used.<br>0x1: Enable. Dark frame subtract cannot be used. | RW   | 0x0   |

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 20    | SDRPORT    | PREVIEW module memory output port enable.<br>This bit enables or disables the data transfer from the PREVIEW module to the memory.<br><br>0x0: Disable<br>0x1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x1   |
| 19    | RSZPORT    | RESIZER module output port enable.<br>This bit enables or disables the data transfer between the PREVIEW and RESIZER modules.<br>Controls whether or not SDRAM output data is forwarded to the resizer input port. This control bit does not depend on the state of the former SDRPORT bit.<br>Data is simultaneously written to SDRAM (if SDRPORT bit is set) while sending the same data to the resizer as input.<br>Note that the CCDC is also capable or directly writing to the resizer input port. The CCDC setting takes precedence over the preview engine setting.<br><br>0x0: Disable<br>0x1: Enable | RW   | 0x0   |
| 18:17 | YCPoS      | (CRYCBY) Cr0(31:24) Y1(23:16) Cb0(15:8) Y0(7:0)<br>0x0: (YCRYCB) Y1(31:24) Cr0(23:16) Y0(15:8) Cb0(7:0)<br>0x1: (YCBYCR) Y1(31:24) Cb0(23:16) Y0(15:8) Cr0(7:0)<br>0x2: (CBYCRY) Cb0(31:24) Y1(23:16) Cr(15:8) Y0(7:0)<br>0x3: (CRYCBY) Cr0(31:24) Y1(23:16) Cb0(15:8) Y0(7:0)                                                                                                                                                                                                                                                                                                                                 | RW   | 0x0   |
| 16    | SUPEN      | Color suppression.<br><br>0x0: Disable<br>0x1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x0   |
| 15    | YNENHEN    | Non-linear enhancer<br><br>0x0: Disable<br>0x1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0x0   |
| 14:11 | CFAFMT     | CFA format<br><br>0x0: Mode 0: conventional Bayer.<br>0x1: Mode 1: horizontal 2x downsample.<br>0x2: Mode 2: bypass CFA stage<br>0x3: Mode 3: horizontal and vertical 2x downsample.<br>0x4: Mode 4: Super CCD Honeycom movie mode sensor.<br>0x5: Mode5: bypass CFA stage .                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 10    | CFAEN      | CFA enable<br><br>0x0: Disable<br>0x1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0x0   |
| 9     | NFEN       | Noise filter enable<br><br>0x0: Disable<br>0x1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0x0   |
| 8     | HMEDEN     | Horizontal median filter enable.<br><br>0x0: Disable<br>0x1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0x0   |
| 7     | DRKFCAP    | Dark frame capture enable.<br><br>0x0: Normal processing.<br>0x1: Capture dark frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x0   |
| 6     | DRKFEN     | Subtract dark frame enable.<br><br>0x0: Disable<br>0x1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                                                                      | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 5    | INVALAW    | Inverse A-Law enable.<br>0x0: Disable<br>0x1: Enable                                                                                                                             | RW   | 0x0   |
| 4    | WIDTH      | Input data width selection.<br>0x0: 10-bit mode<br>0x1: 8-bit mode                                                                                                               | RW   | 0x0   |
| 3    | ONESHOT    | One-shot mode selection.<br>If this bit is set to 1, it is reset to 0 after the ENABLE bit is asserted.<br>0x0: Continuous mode (through the video port).<br>0x1: One shot mode. | RW   | 0x0   |
| 2    | SOURCE     | Input source selection.<br>If this bit is set to 1, it is reset to 0 after the ENABLE bit is asserted.<br>0x0: Video port (through the CCDC)<br>0x1: Memory.                     | RW   | 0x0   |
| 1    | BUSY       | Busy bit.<br>0x0: PREVIEW module not busy.<br>0x1: PREVIEW module busy.                                                                                                          | R    | 0x0   |
| 0    | ENABLE     | Enable bit.<br>If the ONESHOT or SOURCE bit is 1, this bit is reset to 0 after it is asserted<br>0x0: PREVIEW module disabled.<br>0x1: PREVIEW module enabled.                   | RW   | 0x0   |

**Table 6-357. Register Call Summary for Register PRV\_PCR**
**Camera ISP Functional Description**

- Camera ISP VPBE Preview Input Interface: [0] [1] [2]
- Camera ISP VPBE Preview Dark-Frame Write: [3]
- Camera ISP VPBE Preview Inverse A-Law: [4] [5]
- Camera ISP VPBE Preview Dark-Frame Subtract or Shading Compensation: [6] [7] [8] [9] [10]
- Camera ISP VPBE Preview Horizontal Median Filter:
- Camera ISP VPBE Preview Noise Filter and Faulty Pixel Correction: [18] [19]
- Camera ISP VPBE Preview White Balance:
- Camera ISP VPBE Preview CFA Interpolation: [22] [23]
- Camera ISP VPBE Preview Gamma Correction: [25]
- Camera ISP VPBE Preview RGB to YCbCr Conversion, Luminance Enhancement, Chrominance Suppression, Contrast and Brightness, and 4:2:2 Downsampling and Output Clipping: [26] [27]
- Camera ISP VPBE Preview Write-Buffer Interface: [28] [29] [30]
- Camera ISP VPBE Resizer Input and Output Interfaces: [31]

**Camera ISP Basic Programming Model**

- Camera ISP Preview Register Setup: [32] [33] [34] [35] [36] [37] [38] [39] [40] [41] [42] [43] [44] [45] [46] [47] [48] [49] [50] [51] [52] [53] [54] [55] [56] [57] [58] [59] [60] [61] [62] [63] [64] [65]
- Camera ISP Preview Enable/Disable Hardware: [66] [67]
- Camera ISP Preview Events and Status Checking: [68] [69] [70] [71]
- Camera ISP Preview Register Accessibility During Frame Processing: [72] [73] [74]
- Camera ISP Preview Interframe Operations: [75]
- Camera ISP Central-Resource SBL Event and Status Checking: [76]

**Camera ISP Register Manual**

- Camera ISP PREVIEW Register Summary: [77]
- Camera ISP PREVIEW Register Description: [78] [79] [80] [81]

**Table 6-358. PRV\_HORZ\_INFO**

|                       |                           |                         |             |                 |             |
|-----------------------|---------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 0008               | <b>Physical Address</b> | 0x480B CE08 | <b>Instance</b> | ISP_PREVIEW |
| <b>Description</b>    | HORIZONTAL SETUP REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                        |                         |             |                 |             |

| 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 |  |  |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:30 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x0    |
| 29:16 | SPH        | Start pixel horizontal.<br>If <a href="#">PRV_PCR.SOURCE == 0</a> (CCDC input) SPH must be = 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW   | 0x0000 |
| 15:14 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x0    |
| 13:0  | EPH        | End pixel horizontal.<br>The input width of the preview engine must be a multiple of the average count multiplied by the least common multiple of the odd distance and even distance of the AVE register settings.<br>If <a href="#">PRV_PCR.SOURCE == 0</a> (CCDC input) EPH must be = 2 pixels before the last pixel sent from the CCDC.<br><a href="#">PRV_HORZ_INFO.EPH - PRV_HORZ_INFO.SPH + 1</a><br>MOD ((1 <a href="#">PRV_AVE.COUNT</a> ) *<br>LeastCommonMultiple( <a href="#">PRV_AVE.ODDDIST+1</a> ,<br><a href="#">PRV_AVE.EVENDIST+1</a> ) = 0 | RW   | 0x0000 |

**Table 6-359. Register Call Summary for Register PRV\_HORZ\_INFO**

## Camera ISP Functional Description

- [Camera ISP VPBE Preview Input Interface: \[0\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP Preview Register Setup: \[1\]](#)
- [Camera ISP Preview Summary of Constraints: \[2\] \[3\] \[4\] \[5\]](#)

## Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[6\]](#)
- [Camera ISP PREVIEW Register Description: \[7\] \[8\]](#)

**Table 6-360. PRV\_VERT\_INFO**

|                       |                         |                         |             |                 |             |
|-----------------------|-------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 000C             | <b>Physical Address</b> | 0x480B CE0C | <b>Instance</b> | ISP_PREVIEW |
| <b>Description</b>    | VERTICAL SETUP REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                      |                         |             |                 |             |

| 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 |  |  |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Bits  | Field Name | Description                                            | Type | Reset  |
|-------|------------|--------------------------------------------------------|------|--------|
| 31:30 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x0    |
| 29:16 | SLV        | Start line vertical                                    | RW   | 0x0000 |
| 15:14 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x0    |
| 13:0  | ELV        | End line vertical                                      | RW   | 0x0000 |

**Table 6-361. Register Call Summary for Register PRV\_VERT\_INFO**

Camera ISP Functional Description

- [Camera ISP VPBE Preview Input Interface: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP Preview Register Setup: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[2\]](#)

**Table 6-362. PRV\_RSDR\_ADDR**

|                         |                              |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |
|-------------------------|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|
| <b>Address Offset</b>   | 0x0000 0010                  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |
| <b>Physical Address</b> | 0x480B CE10                  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |
| <b>Description</b>      | MEMORY READ ADDRESS REGISTER |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |
| <b>Type</b>             | RW                           |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |
| 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  |    |    |    |    |    |    |   |   |
|                         | RADR                         |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | RADR       | 32-bit read address.<br>Specifies the 32-bit address in memory of the input frame. The lower 5 bits of this register are always treated as 0s. The offset should be aligned on a 32-byte boundary.<br>This field can be altered even when the PREVIEW module is busy. The change takes place only for the next frame (next VS pulse). However, note that reading this register always gives the latest value. | RW   | 0x00000000 |

**Table 6-363. Register Call Summary for Register PRV\_RSDR\_ADDR**

Camera ISP Functional Description

- [Camera ISP VPBE Preview Input Interface: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP Preview Register Setup: \[1\]](#)
- [Camera ISP Preview Register Accessibility During Frame Processing: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[3\]](#)

**Table 6-364. PRV\_RADR\_OFFSET**

|                         |                                     |                       |                 |  |  |  |  |        |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------|-----------------------|-----------------|--|--|--|--|--------|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0014                         |                       |                 |  |  |  |  |        |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE14                         |                       |                 |  |  |  |  |        |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | MEMORY READ ADDRESS OFFSET REGISTER |                       |                 |  |  |  |  |        |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                  |                       |                 |  |  |  |  |        |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |        |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                     |                       |                 |  |  |  |  | OFFSET |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |

  

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                         | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                              | RW   | 0x0000 |
| 15:0  | OFFSET     | Line offset.<br>Specifies the offset for each line relatively to the previous line. The lower 5 bits of this register are always treated as 0s. The offset should be aligned on a 32-byte boundary.<br>This field can be altered even when the PREVIEW module is busy. The change takes place only for the next frame (next VS sync pulse). However, note that reading this register always gives the latest value. | RW   | 0x0000 |

**Table 6-365. Register Call Summary for Register PRV\_RADR\_OFFSET**

Camera ISP Functional Description

- [Camera ISP VPBE Preview Input Interface: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP Preview Register Setup: \[1\]](#)
- [Camera ISP Preview Register Accessibility During Frame Processing: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[3\]](#)

**Table 6-366. PRV\_DSDR\_ADDR**

|                         |                                    |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0018                        |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE18                        |                       |                 |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | DARK FRAME MEMORY ADDRESS REGISTER |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                 |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| DRKF                    |                                    |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |

  

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | DRKF       | Dark frame address.<br>Specifies the dark frame start address in memory. The lower 5 bits of this register are always treated as 0s. The offset should be aligned on a 32-byte boundary.<br>This field can be altered even when the PREVIEW module is busy. The change takes place only for the next frame (next VS sync pulse). However, note that reading this register always gives the latest value. | RW   | 0x00000000 |

**Table 6-367. Register Call Summary for Register PRV\_DSDR\_ADDR**

## Camera ISP Functional Description

- [Camera ISP VPBE Preview Input Interface: \[0\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP Preview Register Setup: \[1\] \[2\]](#)
- [Camera ISP Preview Register Accessibility During Frame Processing: \[3\]](#)

## Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[4\]](#)

**Table 6-368. PRV\_DRKF\_OFFSET**

|                       |                                   |                         |             |                 |             |
|-----------------------|-----------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 001C                       | <b>Physical Address</b> | 0x480B CE1C | <b>Instance</b> | ISP_PREVIEW |
| <b>Description</b>    | DARK FRAME MEMORY OFFSET REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                                |                         |             |                 |             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | OFFSET |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                               | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write Os for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0x0000 |
| 15:0  | OFFSET     | Dark frame line offset.<br>Specifies the offset for each line relatively to the previous line. The lower 5 bits of this register are always treated as 0s. The offset should be aligned on a 32-byte boundary.<br>This field can be altered even when the PREVIEW module is busy. The change takes place only for the next frame (next VS pulse). However, note that reading this register always gives the latest value. | RW   | 0x0000 |

**Table 6-369. Register Call Summary for Register PRV\_DRKF\_OFFSET**

## Camera ISP Functional Description

- [Camera ISP VPBE Preview Input Interface: \[0\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP Preview Register Setup: \[1\] \[2\]](#)
- [Camera ISP Preview Register Accessibility During Frame Processing: \[3\]](#)

## Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[4\]](#)

**Table 6-370. PRV\_WSDR\_ADDR**

|                       |                               |                         |             |                 |             |
|-----------------------|-------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 0020                   | <b>Physical Address</b> | 0x480B CE20 | <b>Instance</b> | ISP_PREVIEW |
| <b>Description</b>    | MEMORY WRITE ADDRESS REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                            |                         |             |                 |             |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | ADDR       | <p>Write address.</p> <p>Specifies the 32-bit address in memory of the output frame. The lower 5 bits of this register are always treated as 0s. The offset should be aligned on a 32-byte boundary.</p> <p>For optimum performance in the system, the starting address must be on a 256-byte boundary</p> <p>This field can be altered even when the PREVIEW module is busy. The change takes place only for the next frame (next VS pulse). However, note that reading this register always gives the latest value.</p> | RW   | 0x00000000 |

**Table 6-371. Register Call Summary for Register PRV\_WSDR\_ADDR**

Camera ISP Functional Description

- Camera ISP VPBE Preview Dark-Frame Write: [0]
- Camera ISP VPBE Preview Write-Buffer Interface: [1]

Camera ISP Basic Programming Model

- Camera ISP Preview Register Setup: [2]
- Camera ISP Preview Register Accessibility During Frame Processing: [3]

Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [4]

**Table 6-372. PRV\_WADD\_OFFSET**

|                         |                              |  |  |  |  |  |  |  |                       |                 |                 |  |  |  |  |  |             |  |  |  |  |  |
|-------------------------|------------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|-----------------|--|--|--|--|--|-------------|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0024                  |  |  |  |  |  |  |  |                       |                 |                 |  |  |  |  |  |             |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE24                  |  |  |  |  |  |  |  |                       |                 | <b>Instance</b> |  |  |  |  |  | ISP_PREVIEW |  |  |  |  |  |
| <b>Description</b>      | MEMORY WRITE OFFSET REGISTER |  |  |  |  |  |  |  |                       |                 |                 |  |  |  |  |  |             |  |  |  |  |  |
| <b>Type</b>             | RW                           |  |  |  |  |  |  |  |                       |                 |                 |  |  |  |  |  |             |  |  |  |  |  |
| 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 | RESERVED        |  |  |  |  |  | OFFSET      |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | <p>Write 0s for future compatibility.</p> <p>Reads returns 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0x0000 |
| 15:0  | OFFSET     | <p>Line offset.</p> <p>The lower 5 bits of this register are always treated as 0s.</p> <p>The offset should be aligned on a 32-byte boundary.</p> <p>For optimum performance in the system, the starting address must be on a 256-byte boundary</p> <p>This field can be altered even when the PREVIEW module is busy. The change takes place only for the next frame (next VS pulse). However, note that reading this register always gives the latest value.</p> | RW   | 0x0000 |

**Table 6-373. Register Call Summary for Register PRV\_WADD\_OFFSET**

Camera ISP Functional Description

- Camera ISP VPBE Preview Dark-Frame Write: [0]
- Camera ISP VPBE Preview Write-Buffer Interface: [1]

Camera ISP Basic Programming Model

- Camera ISP Preview Register Setup: [2]
- Camera ISP Preview Register Accessibility During Frame Processing: [3]

Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [4]

**Table 6-374. PRV\_AVE**

|                         |                          |                         |                 |                 |             |
|-------------------------|--------------------------|-------------------------|-----------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 0028              | <b>Physical Address</b> | 0x480B CE28     | <b>Instance</b> | ISP_PREVIEW |
| <b>Description</b>      | INPUT FORMATTER REGISTER |                         |                 |                 |             |
| <b>Type</b>             | RW                       |                         |                 |                 |             |
| 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 |                 |             |
|                         |                          |                         |                 | RESERVED        |             |
|                         |                          |                         |                 |                 | ODDDIST     |
|                         |                          |                         |                 |                 | EVENDIST    |
|                         |                          |                         |                 |                 | COUNT       |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:6        | RESERVED          | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                             | RW          | 0x0000000    |
| 5:4         | ODDDIST           | Distance between consecutive pixels of the same color in the odd line.<br><br>0x0: 1<br>0x1: 2<br>0x2: 3<br>0x3: 4                                                                                                                                                                                                                                                                                                 | RW          | 0x0          |
| 3:2         | EVENDIST          | Distance between consecutive pixels of the same color in the even line.<br><br>0x0: 1<br>0x1: 2<br>0x2: 3<br>0x3: 4                                                                                                                                                                                                                                                                                                | RW          | 0x0          |
| 1:0         | COUNT             | Number of horizontal pixels to average.<br>This field should not be changed when the "PRV_PCR.DRKFEN bit is set to 1<br>The input width must be divisible by the number of horizontal pixels to average indicated by this field ( if 4 pixel average is selected, then the input width must be a multiple of 4).<br><br>0x0: No averaging.<br>0x1: 2-pixel average<br>0x2: 4-pixel average<br>0x3: 8-pixel average | RW          | 0x0          |

**Table 6-375. Register Call Summary for Register PRV\_AVE**
**Camera ISP Functional Description**

- [Camera ISP VPBE Preview Input Formatter/Averager: \[0\] \[1\] \[2\]](#)

**Camera ISP Basic Programming Model**

- [Camera ISP Preview Register Setup: \[3\]](#)
- [Camera ISP Preview Summary of Constraints: \[4\] \[5\] \[6\]](#)

**Camera ISP Register Manual**

- [Camera ISP PREVIEW Register Summary: \[7\]](#)
- [Camera ISP PREVIEW Register Description: \[8\] \[9\] \[10\]](#)

**Table 6-376. PRV\_HMED**

|                         |                                   |                       |                 |  |  |  |  |  |  |  |  |  |  |          |
|-------------------------|-----------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|----------|
| <b>Address Offset</b>   | 0x0000 002C                       |                       |                 |  |  |  |  |  |  |  |  |  |  |          |
| <b>Physical Address</b> | 0x480B CE2C                       |                       |                 |  |  |  |  |  |  |  |  |  |  |          |
| <b>Description</b>      | HORIZONTAL MEDIAN FILTER REGISTER |                       |                 |  |  |  |  |  |  |  |  |  |  |          |
| <b>Type</b>             | RW                                |                       |                 |  |  |  |  |  |  |  |  |  |  |          |
| 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 |  |  |  |  |  |  |  |  |  |  |          |
| RESERVED                |                                   |                       |                 |  |  |  |  |  |  |  |  |  |  | ODDDIST  |
| THRESHOLD               |                                   |                       |                 |  |  |  |  |  |  |  |  |  |  | EVENDIST |

| Bits  | Field Name | Description                                                                                    | Type | Reset    |
|-------|------------|------------------------------------------------------------------------------------------------|------|----------|
| 31:10 | RESERVED   | Reserved for module specific status information.<br>Reads returns 0                            | RW   | 0x000000 |
| 9     | ODDDIST    | Distance between consecutive pixels of the same color in the odd line.<br><br>0x0: 1<br>0x1: 2 | RW   | 0x0      |
| 8     | EVENDIST   | Distance between consecutive pixels of the same color in even line.<br><br>0x0: 1<br>0x1: 2    | RW   | 0x0      |
| 7:0   | THRESHOLD  | Horizontal median filter threshold.                                                            | RW   | 0x00     |

**Table 6-377. Register Call Summary for Register PRV\_HMED**

## Camera ISP Functional Description

- Camera ISP VPBE Preview Horizontal Median Filter:

## Camera ISP Basic Programming Model

- Camera ISP Preview Register Setup: [3]

## Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [4]

**Table 6-378. PRV\_NF**

|                         |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |     |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|-----|
| <b>Address Offset</b>   | 0x0000 0030             |                       |                 |  |  |  |  |  |  |  |  |  |  |     |
| <b>Physical Address</b> | 0x480B CE30             |                       |                 |  |  |  |  |  |  |  |  |  |  |     |
| <b>Description</b>      | NOISE FILTER REGISTER   |                       |                 |  |  |  |  |  |  |  |  |  |  |     |
| <b>Type</b>             | RW                      |                       |                 |  |  |  |  |  |  |  |  |  |  |     |
| 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 |  |  |  |  |  |  |  |  |  |  | SPR |
| RESERVED                |                         |                       |                 |  |  |  |  |  |  |  |  |  |  |     |

| Bits | Field Name | Description                                            | Type | Reset      |
|------|------------|--------------------------------------------------------|------|------------|
| 31:2 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x00000000 |
| 1:0  | SPR        | The spread value in noise filter algorithm             | RW   | 0x0        |

**Table 6-379. Register Call Summary for Register PRV\_NF**

## Camera ISP Functional Description

## Camera ISP Basic Programming Model

- Camera ISP Preview Register Setup: [1]

**Table 6-379. Register Call Summary for Register PRV\_NF (continued)**

Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[2\]](#)

**Table 6-380. PRV\_WB\_DGAIN**

|                         |                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0034                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE34                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | WHITE BALANCE COEF REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |       |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | DGAIN |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                              | Type | Reset    |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                   | RW   | 0x000000 |
| 9:0   | DGAIN      | Digital gain for the white balance. The data is in U10Q8 representation.<br>The value can change anytime following the start of a frame. | RW   | 0x100    |

**Table 6-381. Register Call Summary for Register PRV\_WB\_DGAIN**

Camera ISP Functional Description

- [Camera ISP VPBE Preview White Balance: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP Preview Register Setup: \[1\]](#)
- [Camera ISP Preview Register Accessibility During Frame Processing: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[3\]](#)

**Table 6-382. PRV\_WBGAIN**

|                         |                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0038                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE38                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | WHITE BALANCE COEF REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|       |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |       |    |    |    |    |    |   |   |        |   |   |   |   |   |   |   |
|-------|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|-------|----|----|----|----|----|---|---|--------|---|---|---|---|---|---|---|
| 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 |
| COEF3 |    |    |    |    |    |    |    | COEF2 |    |    |    |    |    |    |    | COEF1 |    |    |    |    |    |   |   | COEOF0 |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                     | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | COEF3      | White balance gain - COEF3. The data is in U8Q5 representation.<br>The value can change anytime following the start of a frame. | RW   | 0x20  |
| 23:16 | COEF2      | White balance gain - COEF2. The data is in U8Q5 representation.<br>The value can change anytime following the start of a frame. | RW   | 0x20  |
| 15:8  | COEF1      | White balance gain - COEF1. The data is in U8Q5 representation.<br>The value can change anytime following the start of a frame. | RW   | 0x20  |

| Bits | Field Name | Description                                                                                                                     | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:0  | COEF0      | White balance gain - COEF0. The data is in U8Q5 representation.<br>The value can change anytime following the start of a frame. | RW   | 0x20  |

**Table 6-383. Register Call Summary for Register PRV\_WBGAIN**

Camera ISP Functional Description

- Camera ISP VPBE Preview White Balance: [0]

Camera ISP Basic Programming Model

- Camera ISP Preview Register Setup: [2]
- Camera ISP Preview Register Accessibility During Frame Processing: [3]

Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [4]

**Table 6-384. PRV\_WBSEL**

|                         |                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 003C                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE3C                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Instance |  |  |  |  |  |  |  |
| <b>Description</b>      | WHITE BALANCE COEF SELECTION REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |

|                         |                         |                       |                 |      |      |      |      |      |      |      |      |      |      |      |      |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|------|------|------|------|------|------|------|------|------|------|------|------|--|--|--|--|--|--|--|
| 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 |      |      |      |      |      |      |      |      |      |      |      |      |  |  |  |  |  |  |  |
| N3_3                    | N3_2                    | N3_1                  | N3_0            | N2_3 | N2_2 | N2_1 | N2_0 | N1_3 | N1_2 | N1_1 | N1_0 | N0_3 | N0_2 | N0_1 | N0_0 |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                            | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | N3_3       | Coefficient selection for 3rd line, 3rd pixel.<br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW   | 0x3   |
| 29:28 | N3_2       | Coefficient selection for 3rd line, 2nd pixel.<br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW   | 0x2   |
| 27:26 | N3_1       | Coefficient selection for 3rd line, 1st pixel.<br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW   | 0x3   |
| 25:24 | N3_0       | Coefficient selection for 3rd line, 0th pixel.<br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW   | 0x2   |
| 23:22 | N2_3       | Coefficient selection for 2nd line, 3rd pixel.<br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW   | 0x1   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                         | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 21:20       | N2_2              | Coefficient selection for 2nd line, 2nd pixel.<br><br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW          | 0x0          |
| 19:18       | N2_1              | Coefficient selection for 2nd line, 1st pixel.<br><br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW          | 0x1          |
| 17:16       | N2_0              | Coefficient selection for 2nd line, 0th pixel.<br><br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW          | 0x0          |
| 15:14       | N1_3              | Coefficient selection for 1st line, 3rd pixel.<br><br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW          | 0x3          |
| 13:12       | N1_2              | Coefficient selection for 1st line, 2nd pixel.<br><br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW          | 0x2          |
| 11:10       | N1_1              | Coefficient selection for 1st line, 1st pixel.<br><br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW          | 0x3          |
| 9:8         | N1_0              | Coefficient selection for 1st line, 0th pixel.<br><br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW          | 0x2          |
| 7:6         | N0_3              | Coefficient selection for 0th line, 3rd pixel.<br><br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW          | 0x1          |
| 5:4         | N0_2              | Coefficient selection for 0th line, 2nd pixel.<br><br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW          | 0x0          |

## Camera ISP Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                            | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------|------|-------|
| 3:2  | N0_1       | Coefficient selection for 0th line, 1st pixel.<br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW   | 0x1   |
| 1:0  | N0_0       | Coefficient selection for 0th line, 0th pixel.<br>0x0: COEF0<br>0x1: COEF1<br>0x2: COEF2<br>0x3: COEF3 | RW   | 0x0   |

**Table 6-385. Register Call Summary for Register PRV\_WBSEL**

## Camera ISP Functional Description

- Camera ISP VPBE Preview White Balance:

## Camera ISP Basic Programming Model

- Camera ISP Preview Register Setup: [1]

## Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [2]

**Table 6-386. PRV\_CFA**

|                         |                             |  |  |  |  |  |  |  |                       |                 |  |  |  |            |  |  |  |
|-------------------------|-----------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|--|--|--|------------|--|--|--|
| <b>Address Offset</b>   | 0x0000 0040                 |  |  |  |  |  |  |  |                       |                 |  |  |  |            |  |  |  |
| <b>Physical Address</b> | 0x480B CE40                 |  |  |  |  |  |  |  |                       |                 |  |  |  |            |  |  |  |
| <b>Description</b>      | COLOR FILTER ARRAY REGISTER |  |  |  |  |  |  |  |                       |                 |  |  |  |            |  |  |  |
| <b>Type</b>             | RW                          |  |  |  |  |  |  |  |                       |                 |  |  |  |            |  |  |  |
| 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 |  |  |  |            |  |  |  |
| RESERVED                |                             |  |  |  |  |  |  |  |                       | GRADTH_VER      |  |  |  | GRADTH_HOR |  |  |  |

| Bits  | Field Name | Description                                            | Type | Reset  |
|-------|------------|--------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x0000 |
| 15:8  | GRADTH_VER | Gradient threshold vertical.                           | RW   | 0x00   |
| 7:0   | GRADTH_HOR | Gradient threshold horizontal.                         | RW   | 0x00   |

**Table 6-387. Register Call Summary for Register PRV\_CFA**

## Camera ISP Functional Description

- Camera ISP VPBE Preview CFA Interpolation:

## Camera ISP Basic Programming Model

- Camera ISP Preview Register Setup: [2]

## Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [3]

**Table 6-388. PRV\_BLKADJOFF**

| <b>Address Offset</b>   | 0x0000 0044                      |                                                                                |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
|-------------------------|----------------------------------|--------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|------|-------|
| <b>Physical Address</b> | 0x480B CE44                      |                                                                                |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Description</b>      | BLACK ADJUSTMENT OFFSET REGISTER |                                                                                |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Type</b>             | RW                               |                                                                                |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| 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 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| RESERVED                | R                                | G                                                                              | B               |  |  |  |  |  |  |  |  |  |  |  |      |       |
| Bits                    | Field Name                       | <b>Description</b>                                                             |                 |  |  |  |  |  |  |  |  |  |  |  | Type | Reset |
| 31:24                   | RESERVED                         | Write 0s for future compatibility.<br>Reads returns 0.                         |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 23:16                   | R                                | Black-level offset adjustment for RED. The data is in 2's complement format.   |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 15:8                    | G                                | Black-level offset adjustment for GREEN. The data is in 2's complement format. |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 7:0                     | B                                | Black-level offset adjustment for BLUE. The data is in 2's complement format.  |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |

**Table 6-389. Register Call Summary for Register PRV\_BLKADJOFF**

- Camera ISP Functional Description
- [Camera ISP VPBE Preview Black Adjustment: \[0\]](#)
- Camera ISP Basic Programming Model
- [Camera ISP Preview Register Setup: \[1\]](#)
- Camera ISP Register Manual
- [Camera ISP PREVIEW Register Summary: \[2\]](#)

**Table 6-390. PRV\_RGB\_MAT1**

| <b>Address Offset</b>   | 0x0000 0048                     |                                                                           |                 |  |  |  |          |        |  |  |  |  |  |  |      |       |  |  |  |  |  |  |  |
|-------------------------|---------------------------------|---------------------------------------------------------------------------|-----------------|--|--|--|----------|--------|--|--|--|--|--|--|------|-------|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B CE48                     |                                                                           |                 |  |  |  |          |        |  |  |  |  |  |  |      |       |  |  |  |  |  |  |  |
| <b>Description</b>      | RGB TO RGB MATRIX COEF REGISTER |                                                                           |                 |  |  |  |          |        |  |  |  |  |  |  |      |       |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                              |                                                                           |                 |  |  |  |          |        |  |  |  |  |  |  |      |       |  |  |  |  |  |  |  |
| 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 |  |  |  |          |        |  |  |  |  |  |  |      |       |  |  |  |  |  |  |  |
| RESERVED                | MTX_GR                          |                                                                           |                 |  |  |  | RESERVED | MTX_RR |  |  |  |  |  |  |      |       |  |  |  |  |  |  |  |
| Bits                    | Field Name                      | <b>Description</b>                                                        |                 |  |  |  |          |        |  |  |  |  |  |  | Type | Reset |  |  |  |  |  |  |  |
| 31:28                   | RESERVED                        | Write 0s for future compatibility.<br>Reads returns 0.                    |                 |  |  |  |          |        |  |  |  |  |  |  | RW   | 0x0   |  |  |  |  |  |  |  |
| 27:16                   | MTX_GR                          | Blending value for GR position.<br>The format is in S12Q8 representation. |                 |  |  |  |          |        |  |  |  |  |  |  | RW   | 0x100 |  |  |  |  |  |  |  |
| 15:12                   | RESERVED                        | Write 0s for future compatibility.<br>Reads returns 0.                    |                 |  |  |  |          |        |  |  |  |  |  |  | RW   | 0x0   |  |  |  |  |  |  |  |
| 11:0                    | MTX_RR                          | Blending value for RR position.<br>The format is in S12Q8 representation. |                 |  |  |  |          |        |  |  |  |  |  |  | RW   | 0x100 |  |  |  |  |  |  |  |

**Table 6-391. Register Call Summary for Register PRV\_RGB\_MAT1**

- Camera ISP Functional Description
- [Camera ISP VPBE Preview RGB Blending: \[0\]](#)
- Camera ISP Basic Programming Model
- [Camera ISP Preview Register Setup: \[1\]](#)

**Table 6-391. Register Call Summary for Register PRV\_RGB\_MAT1 (continued)**

Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [2]

**Table 6-392. PRV\_RGB\_MAT2**

|                       |                                 |                         |             |                 |             |
|-----------------------|---------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 004C                     | <b>Physical Address</b> | 0x480B CE4C | <b>Instance</b> | ISP_PREVIEW |
| <b>Description</b>    | RGB TO RGB MATRIX COEF REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                              |                         |             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | MTX_RG                  | RESERVED              | MTX_BR          |

| Bits  | Field Name | Description                                                               | Type | Reset |
|-------|------------|---------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                    | RW   | 0x0   |
| 27:16 | MTX_RG     | Blending value for RG position.<br>The format is in S12Q8 representation. | RW   | 0x100 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                    | RW   | 0x0   |
| 11:0  | MTX_BR     | Blending value for BR position.<br>The format is in S12Q8 representation. | RW   | 0x100 |

**Table 6-393. Register Call Summary for Register PRV\_RGB\_MAT2**

Camera ISP Functional Description

- Camera ISP VPBE Preview RGB Blending: [0]

Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [1]

**Table 6-394. PRV\_RGB\_MAT3**

|                       |                                 |                         |             |                 |             |
|-----------------------|---------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 0050                     | <b>Physical Address</b> | 0x480B CE50 | <b>Instance</b> | ISP_PREVIEW |
| <b>Description</b>    | RGB TO RGB MATRIX COEF REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                              |                         |             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | MTX_BG                  | RESERVED              | MTX_GG          |

| Bits  | Field Name | Description                                                               | Type | Reset |
|-------|------------|---------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                    | RW   | 0x0   |
| 27:16 | MTX_BG     | Blending value for BG position.<br>The format is in S12Q8 representation. | RW   | 0x100 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                    | RW   | 0x0   |
| 11:0  | MTX_GG     | Blending value for GG position.<br>The format is in S12Q8 representation. | RW   | 0x100 |

**Table 6-395. Register Call Summary for Register PRV\_RGB\_MAT3**

Camera ISP Functional Description

- [Camera ISP VPBE Preview RGB Blending: \[0\]](#)

Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[1\]](#)

**Table 6-396. PRV\_RGB\_MAT4**

|                         |                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0054                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE54                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RGB TO RGB MATRIX COEF REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | MTX_GB                  | RESERVED              | MTX_RB          |

| Bits  | Field Name | Description                                                               | Type | Reset |
|-------|------------|---------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                    | RW   | 0x0   |
| 27:16 | MTX_GB     | Blending value for GB position.<br>The format is in S12Q8 representation. | RW   | 0x100 |
| 15:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                    | RW   | 0x0   |
| 11:0  | MTX_RB     | Blending value for RB position.<br>The format is in S12Q8 representation. | RW   | 0x100 |

**Table 6-397. Register Call Summary for Register PRV\_RGB\_MAT4**

Camera ISP Functional Description

- [Camera ISP VPBE Preview RGB Blending: \[0\]](#)

Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[1\]](#)

**Table 6-398. PRV\_RGB\_MAT5**

|                         |                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0058                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE58                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RGB TO RGB MATRIX COEF REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         |                       | MTX_BB          |

| Bits  | Field Name | Description                                                               | Type | Reset   |
|-------|------------|---------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                    | RW   | 0x00000 |
| 11:0  | MTX_BB     | Blending value for BB position.<br>The format is in S12Q8 representation. | RW   | 0x100   |

**Table 6-399. Register Call Summary for Register PRV\_RGB\_MAT5**

Camera ISP Functional Description

- [Camera ISP VPBE Preview RGB Blending: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP Preview Register Setup: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[2\]](#)

**Table 6-400. PRV\_RGB\_OFF1**

|                         |                         |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |                    |                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|--|--|--|--|--|--|--------------------|-----------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 005C             |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  | <b>Instance</b>    | ISP_PREVIEW                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE5C             |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  | <b>Description</b> | RGB TO RGB MATRIX OFFSET REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |                    |                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |                    |                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |          |          |          |
|----------|----------|----------|----------|
| RESERVED | MTX_OFFR | RESERVED | MTX_OFFG |
|----------|----------|----------|----------|

| Bits  | Field Name | Description                                                            | Type | Reset |
|-------|------------|------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                 | RW   | 0x00  |
| 25:16 | MTX_OFFR   | Blending offset value for RED. The data is in 2's complement format.   | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                 | RW   | 0x00  |
| 9:0   | MTX_OFFG   | Blending offset value for GREEN. The data is in 2's complement format. | RW   | 0x000 |

**Table 6-401. Register Call Summary for Register PRV\_RGB\_OFF1**

Camera ISP Functional Description

- [Camera ISP VPBE Preview RGB Blending: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP Preview Register Setup: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[2\]](#)

**Table 6-402. PRV\_RGB\_OFF2**

|                         |                         |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |                    |                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|--|--|--|--|--|--|--------------------|-----------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0060             |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  | <b>Instance</b>    | ISP_PREVIEW                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE60             |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  | <b>Description</b> | RGB TO RGB MATRIX OFFSET REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |                    |                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |                    |                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |          |
|----------|----------|
| RESERVED | MTX_OFFB |
|----------|----------|

| Bits  | Field Name | Description                                                          | Type | Reset      |
|-------|------------|----------------------------------------------------------------------|------|------------|
| 31:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.               | RW   | 0x00000000 |
| 9:0   | MTX_OFFB   | Blending offset value for BLUE (in 2's complemented representation). | RW   | 0x000      |

**Table 6-403. Register Call Summary for Register PRV\_RGB\_OFF2**

Camera ISP Functional Description

- [Camera ISP VPBE Preview RGB Blending: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP Preview Register Setup: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[2\]](#)

**Table 6-404. PRV\_CSC0**

|                         |                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0064                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE64                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | COLOR SPACE CONVERSION COEF REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | CSCBY                   | CSCGY                 | CSCRY           |

| Bits  | Field Name | Description                                                                                            | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                 | RW   | 0x0   |
| 29:20 | CSCBY      | Color space conversion coefficient of BLUE for computing Y.<br>The format is in S10Q8 representation.  | RW   | 0x01C |
| 19:10 | CSCGY      | Color space conversion coefficient of GREEN for computing Y.<br>The format is in S10Q8 representation. | RW   | 0x098 |
| 9:0   | CSCRY      | Color space conversion coefficient of RED for computing Y.<br>The format is in S10Q8 representation.   | RW   | 0x04C |

**Table 6-405. Register Call Summary for Register PRV\_CSC0**

Camera ISP Functional Description

- [Camera ISP VPBE Preview RGB to YCbCr Conversion, Luminance Enhancement, Chrominance Suppression, Contrast and Brightness, and 4:2:2 Downsampling and Output Clipping: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP Preview Register Setup: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP PREVIEW Register Summary: \[2\]](#)

**Table 6-406. PRV\_CSC1**

|                         |                                      |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0068                          |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE68                          |                       |                 |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | COLOR SPACE CONVERSION COEF REGISTER |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                   |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | CSCBCB                               | CSCGCB                | CSCRBC          |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                            | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                 | RW   | 0x0   |
| 29:20 | CSCBCB     | Color space conversion coefficient of BLUE for computing Y.<br>The format is in S10Q8 representation.  | RW   | 0x080 |
| 19:10 | CSCGCB     | Color space conversion coefficient of GREEN for computing Y.<br>The format is in S10Q8 representation. | RW   | 0x3AC |
| 9:0   | CSCRBC     | Color space conversion coefficient of RED for computing Cb.<br>The format is in S10Q8 representation.  | RW   | 0x3D4 |

**Table 6-407. Register Call Summary for Register PRV\_CSC1**

## Camera ISP Functional Description

- Camera ISP VPBE Preview RGB to YCbCr Conversion, Luminance Enhancement, Chrominance Suppression, Contrast and Brightness, and 4:2:2 Downsampling and Output Clipping: [0]

## Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [1]

**Table 6-408. PRV\_CSC2**

|                         |                                      |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 006C                          |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE6C                          |                       |                 |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | COLOR SPACE CONVERSION COEF REGISTER |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                   |                       |                 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | CSCBCR                               | CSCGCR                | CSCRCR          |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                             | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                  | RW   | 0x0   |
| 29:20 | CSCBCR     | Color space conversion coefficient of BLUE for computing Cr.<br>The format is in S10Q8 representation.  | RW   | 0x3EC |
| 19:10 | CSCGCR     | Color space conversion coefficient of GREEN for computing Cr.<br>The format is in S10Q8 representation. | RW   | 0x080 |

| Bits | Field Name | Description                                                                                           | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------|------|-------|
| 9:0  | CSCRCR     | Color space conversion coefficient of RED for computing Cr.<br>The format is in S10Q8 representation. | RW   | 0x39E |

**Table 6-409. Register Call Summary for Register PRV\_CSC2**

Camera ISP Functional Description

- Camera ISP VPBE Preview RGB to YCbCr Conversion, Luminance Enhancement, Chrominance Suppression, Contrast and Brightness, and 4:2:2 Downsampling and Output Clipping: [0] [1] [2]

Camera ISP Basic Programming Model

- Camera ISP Preview Register Setup: [3]

Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [4]

**Table 6-410. PRV\_CSC\_OFFSET**

|                         |                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0070                            |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE70                            |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | COLOR SPACE CONVERSION OFFSET REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |        |
|-------------------------|-------------------------|-----------------------|-----------------|--------|
| 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 |        |
| RESERVED                | RESERVED                | YOFST                 | OFSTCB          | OFSTCR |

| Bits  | Field Name | Description                                                                                          | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                               | RW   | 0x00  |
| 25:24 | RESERVED   | Write 0s for future compatibility.<br>Reads returns written value.                                   | RW   | 0x0   |
| 23:16 | YOFST      | DC offset value for Y component. The data is in S8Q0 representation.<br>$Y_{out} = Y_{in} + YOFST$   | RW   | 0x00  |
| 15:8  | OFSTCB     | DC offset value for Cb component. The data is in S8Q0 representation.<br>$C_{out} = C_{in} + OFSTCB$ | RW   | 0x00  |
| 7:0   | OFSTCR     | DC offset value for Cr component. The data is in S8Q0 representation.<br>$C_{out} = C_{in} + OFSTCR$ | RW   | 0x00  |

**Table 6-411. Register Call Summary for Register PRV\_CSC\_OFFSET**

Camera ISP Functional Description

- Camera ISP VPBE Preview RGB to YCbCr Conversion, Luminance Enhancement, Chrominance Suppression, Contrast and Brightness, and 4:2:2 Downsampling and Output Clipping: [0]

Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [1]

**Table 6-412. PRV\_CNT\_BRT**

|                       |                       |                         |             |                 |             |
|-----------------------|-----------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 0074           | <b>Physical Address</b> | 0x480B CE74 | <b>Instance</b> | ISP_PREVIEW |
| <b>Description</b>    | CONTRAST SET REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                    |                         |             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         | CNT                   | BRT             |

| Bits  | Field Name | Description                                                                                                                                       | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                            | RW   | 0x0000 |
| 15:8  | CNT        | Contrast adjustment.<br>Sets the contrast of the Y data. The data is in U8Q4 representation i.e (0 to 15.9375).. Applied after offset adjustment. | RW   | 0x10   |
| 7:0   | BRT        | Brightness adjustment.<br>Sets the brightness of Y data. The data is in U8Q0 representation (0 to 255).. Applied after contrast adjustment.       | RW   | 0x00   |

**Table 6-413. Register Call Summary for Register PRV\_CNT\_BRT**

## Camera ISP Functional Description

- Camera ISP VPBE Preview RGB to YCbCr Conversion, Luminance Enhancement, Chrominance Suppression, Contrast and Brightness, and 4:2:2 Downsampling and Output Clipping: [0] [1]

## Camera ISP Basic Programming Model

- Camera ISP Preview Register Setup: [2]

## Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [3]

**Table 6-414. PRV\_CSUP**

|                       |                                      |                         |             |                 |             |
|-----------------------|--------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 0078                          | <b>Physical Address</b> | 0x480B CE78 | <b>Instance</b> | ISP_PREVIEW |
| <b>Description</b>    | CHROMINANCE SUPPRESSION SET REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                                   |                         |             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         | HPYF                  | CSUPTH CSUPG    |

| Bits  | Field Name | Description                                                                                                                      | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:17 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                           | RW   | 0x0000 |
| 16    | HPYF       | Use high-pass filter of luminance for chroma suppression<br>0x0: Disable. Use luminance without high-pass filter.<br>0x1: Enable | RW   | 0x0    |
| 15:8  | CSUPTH     | Chroma suppression threshold.                                                                                                    | RW   | 0x00   |
| 7:0   | CSUPG      | Gain value for chroma suppression function.<br>The data format is in U8Q8 representation.                                        | RW   | 0x00   |

**Table 6-415. Register Call Summary for Register PRV\_CSUP**

## Camera ISP Functional Description

- Camera ISP VPBE Preview RGB to YCbCr Conversion, Luminance Enhancement, Chrominance Suppression, Contrast and Brightness, and 4:2:2 Downsampling and Output Clipping:

## Camera ISP Basic Programming Model

- Camera ISP Preview Register Setup: [4]

## Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [5]

**Table 6-416. PRV\_SETUP\_YC**

|                         |                      |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |
|-------------------------|----------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 007C          |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_PREVIEW |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE7C          |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |
| <b>Description</b>      | Y AND C SET REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |
| <b>Type</b>             | RW                   |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| MAXY                    | MINY                    | MAXC                  | MINC            |

| Bits  | Field Name | Description                                                                 | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------|------|-------|
| 31:24 | MAXY       | Maximum Y value. The values greater than MAXY are clipped to MAXY.          | RW   | 0xFF  |
| 23:16 | MINY       | Minimum Y value. The values smaller than MINY are clipped to MINY.          | RW   | 0x00  |
| 15:8  | MAXC       | Maximum Cb and Cr values. The values greater than MAXC are clipped to MAXC. | RW   | 0xFF  |
| 7:0   | MINC       | Minimum Cb and Cr values. The values smaller than MINC are clipped to MINC. | RW   | 0x00  |

**Table 6-417. Register Call Summary for Register PRV\_SETUP\_YC**

## Camera ISP Functional Description

- Camera ISP VPBE Preview RGB to YCbCr Conversion, Luminance Enhancement, Chrominance Suppression, Contrast and Brightness, and 4:2:2 Downsampling and Output Clipping: [0]

## Camera ISP Basic Programming Model

- Camera ISP Preview Register Setup: [1]

## Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [2]

**Table 6-418. PRV\_SET\_TBL\_ADDR**

|                         |                            |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |
|-------------------------|----------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0080                |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_PREVIEW |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE80                |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |
| <b>Description</b>      | SET TABLE ADDRESS REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |
| <b>Type</b>             | RW                         |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         |                       | ADDR            |

| Bits  | Field Name | Description                                            | Type | Reset   |
|-------|------------|--------------------------------------------------------|------|---------|
| 31:13 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x00000 |
| 12:0  | ADDR       | 13-bit address.                                        | RW   | 0x0000  |

**Table 6-419. Register Call Summary for Register PRV\_SET\_TBL\_ADDR**

Camera ISP Basic Programming Model

- Camera ISP Preview Table Setup: [0] [1]

Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [2]

**Table 6-420. PRV\_SET\_TBL\_DATA**

|                         |                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0084               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE84               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | SETUP TABLE DATA REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    | DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                               | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:20 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                    | RW   | 0x000  |
| 19:0  | DATA       | Data to be written.<br>All 20 bits are valid to set up the non-linear enhancer table. Only 8 LSBs are valid to set up the gamma, noise filter and CFA coefficient tables. | RW   | 0x---- |

**Table 6-421. Register Call Summary for Register PRV\_SET\_TBL\_DATA**

Camera ISP Basic Programming Model

- Camera ISP Preview Table Setup: [0]
- Camera ISP Preview Register Accessibility During Frame Processing: [1]

Camera ISP Register Manual

- Camera ISP PREVIEW Register Summary: [2]

**Table 6-422. PRV\_CDC\_THRx**

|                         |                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0090 + (x * 0x4)                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | x = 0 to 4  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B CE90 + (x * 0x4)                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | ISP_PREVIEW |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | COUPLET DEFECT CORRECTION THRESHOLD REGISTER FOR COLORx |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |         |    |    |    |    |    |    |    |          |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|---------|----|----|----|----|----|----|----|----------|----|----|----|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    | CORRECT |    |    |    |    |    |    |    | RESERVED |    |    |    | DETECT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                           | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                | RW   | 0x00  |
| 25:16 | CORRECT    | Correction threshold when couplet defect correction is selected. It must be set to 1023 for single defect correction. | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                | RW   | 0x00  |
| 9:0   | DETECT     | Detection threshold when couplet defect correction is selected. It must be set to 0 for single defect correction.     | RW   | 0x000 |

**Table 6-423. Register Call Summary for Register PRV\_CDC\_THRx**

|                                                                                                                                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Camera ISP Functional Description                                                                                                                      |
| Camera ISP Basic Programming Model                                                                                                                     |
| <ul style="list-style-type: none"> <li>• Camera ISP Preview Register Setup: [9]</li> </ul>                                                             |
| Camera ISP Register Manual                                                                                                                             |
| <ul style="list-style-type: none"> <li>• Camera ISP PREVIEW Register Summary: [10]</li> <li>• Camera ISP PREVIEW Register Description: [11]</li> </ul> |

## 6.6.8 Camera ISP RESIZER Registers

### 6.6.8.1 Camera ISP RESIZER Register Summary

**Table 6-424. ISP\_RESIZER Register Summary**

| Register Name  | Type | Register Width (Bits) | Address Offset | Physical Address |
|----------------|------|-----------------------|----------------|------------------|
| RSZ_PID        | R    | 32                    | 0x0000 0000    | 0x480B D000      |
| RSZ_PCR        | RW   | 32                    | 0x0000 0004    | 0x480B D004      |
| RSZ_CNT        | RW   | 32                    | 0x0000 0008    | 0x480B D008      |
| RSZ_OUT_SIZE   | RW   | 32                    | 0x0000 000C    | 0x480B D00C      |
| RSZ_IN_START   | RW   | 32                    | 0x0000 0010    | 0x480B D010      |
| RSZ_IN_SIZE    | RW   | 32                    | 0x0000 0014    | 0x480B D014      |
| RSZ_SDR_INADD  | RW   | 32                    | 0x0000 0018    | 0x480B D018      |
| RSZ_SDR_INOFF  | RW   | 32                    | 0x0000 001C    | 0x480B D01C      |
| RSZ_SDR_OUTADD | RW   | 32                    | 0x0000 0020    | 0x480B D020      |
| RSZ_SDR_OUTOFF | RW   | 32                    | 0x0000 0024    | 0x480B D024      |
| RSZ_HFILT10    | RW   | 32                    | 0x0000 0028    | 0x480B D028      |
| RSZ_HFILT32    | RW   | 32                    | 0x0000 002C    | 0x480B D02C      |
| RSZ_HFILT54    | RW   | 32                    | 0x0000 0030    | 0x480B D030      |
| RSZ_HFILT76    | RW   | 32                    | 0x0000 0034    | 0x480B D034      |
| RSZ_HFILT98    | RW   | 32                    | 0x0000 0038    | 0x480B D038      |
| RSZ_HFILT110   | RW   | 32                    | 0x0000 003C    | 0x480B D03C      |
| RSZ_HFILT1312  | RW   | 32                    | 0x0000 0040    | 0x480B D040      |
| RSZ_HFILT1514  | RW   | 32                    | 0x0000 0044    | 0x480B D044      |
| RSZ_HFILT1716  | RW   | 32                    | 0x0000 0048    | 0x480B D048      |
| RSZ_HFILT1918  | RW   | 32                    | 0x0000 004C    | 0x480B D04C      |
| RSZ_HFILT2120  | RW   | 32                    | 0x0000 0050    | 0x480B D050      |
| RSZ_HFILT2322  | RW   | 32                    | 0x0000 0054    | 0x480B D054      |
| RSZ_HFILT2524  | RW   | 32                    | 0x0000 0058    | 0x480B D058      |
| RSZ_HFILT2726  | RW   | 32                    | 0x0000 005C    | 0x480B D05C      |
| RSZ_HFILT2928  | RW   | 32                    | 0x0000 0060    | 0x480B D060      |
| RSZ_HFILT3130  | RW   | 32                    | 0x0000 0064    | 0x480B D064      |
| RSZ_VFILT10    | RW   | 32                    | 0x0000 0068    | 0x480B D068      |
| RSZ_VFILT32    | RW   | 32                    | 0x0000 006C    | 0x480B D06C      |
| RSZ_VFILT54    | RW   | 32                    | 0x0000 0070    | 0x480B D070      |
| RSZ_VFILT76    | RW   | 32                    | 0x0000 0074    | 0x480B D074      |
| RSZ_VFILT98    | RW   | 32                    | 0x0000 0078    | 0x480B D078      |
| RSZ_VFILT1110  | RW   | 32                    | 0x0000 007C    | 0x480B D07C      |
| RSZ_VFILT1312  | RW   | 32                    | 0x0000 0080    | 0x480B D080      |
| RSZ_VFILT1514  | RW   | 32                    | 0x0000 0084    | 0x480B D084      |
| RSZ_VFILT1716  | RW   | 32                    | 0x0000 0088    | 0x480B D088      |

**Table 6-424. ISP\_RESIZER Register Summary (continued)**

| Register Name | Type | Register Width (Bits) | Address Offset | Physical Address |
|---------------|------|-----------------------|----------------|------------------|
| RSZ_VFILT1918 | RW   | 32                    | 0x0000 008C    | 0x480B D08C      |
| RSZ_VFILT2120 | RW   | 32                    | 0x0000 0090    | 0x480B D090      |
| RSZ_VFILT2322 | RW   | 32                    | 0x0000 0094    | 0x480B D094      |
| RSZ_VFILT2524 | RW   | 32                    | 0x0000 0098    | 0x480B D098      |
| RSZ_VFILT2726 | RW   | 32                    | 0x0000 009C    | 0x480B D09C      |
| RSZ_VFILT2928 | RW   | 32                    | 0x0000 00A0    | 0x480B D0A0      |
| RSZ_VFILT3130 | RW   | 32                    | 0x0000 00A4    | 0x480B D0A4      |
| RSZ_YENH      | RW   | 32                    | 0x0000 00A8    | 0x480B D0A8      |

### 6.6.8.2 Camera ISP RESIZER Register Description

**Table 6-425. RSZ\_PID**

|                  |                        |          |             |
|------------------|------------------------|----------|-------------|
| Address Offset   | 0x0000 0000            | Instance | ISP_RESIZER |
| Physical Address | 0x480B D000            |          |             |
| Description      | PERIPHERAL ID REGISTER |          |             |
| Type             | R                      |          |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | TID                     | CID                   | PREV            |

| Bits  | Field Name | Description                                         | Type | Reset            |
|-------|------------|-----------------------------------------------------|------|------------------|
| 31:24 | RESERVED   | Write 0s for future compatibility. Reads returns 0. | R    | 0x00             |
| 23:16 | TID        | Peripheral identification: RESIZER module           | R    | 0x10             |
| 15:8  | CID        | Class identification: Camera ISP                    | R    | 0xFE             |
| 7:0   | PREV       | Peripheral revision number                          | R    | TI internal data |

**Table 6-426. Register Call Summary for Register RSZ\_PID**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-427. RSZ\_PCR**

|                  |                             |          |             |
|------------------|-----------------------------|----------|-------------|
| Address Offset   | 0x0000 0004                 | Instance | ISP_RESIZER |
| Physical Address | 0x480B D004                 |          |             |
| Description      | PERIPHERAL CONTROL REGISTER |          |             |
| Type             | RW                          |          |             |

|                         |                         |                       |                           |
|-------------------------|-------------------------|-----------------------|---------------------------|
| 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           |
| RESERVED                |                         |                       | ONESHOT<br>BUSY<br>ENABLE |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RW   | 0x00000000 |
| 2    | ONESHOT    | One-shot or continuous mode selection.<br>This bit only applies when the image source is CCDC or PREVIEW ( <a href="#">RSZ_CNT INPSRC =0</a> )<br><br>0x0: Continuous mode. The module must be disabled by software. The disable module is latched at the end of the frame it was written in.<br><br>0x1: One shot mode. Enable bit is reset to 0 once the busy bit turns to 1.                                                                                                                                                                                        | RW   | 0x1        |
| 1    | BUSY       | RESIZER module busy.<br><br>0x0: RESIZER module not busy.<br><br>0x1: RESIZER module busy.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R    | 0x0        |
| 0    | ENABLE     | RESIZER module enable.<br>Memory to memory operation: Resizer always operates in one-shot mode in memory to memory operation.<br>Enable bit is reset to 0 once the busy bit turns to 1.<br>CCDC/PREVIEW to memory operation: The resizer operates either in one-shot or continuous mode. The behavior is defined by the <a href="#">RSZ_PCR [2] ONESHOT</a> bit.<br>The enable bit MUST be the last field written to resize a frame.<br>The enable bit can be written when the resizer is busy.<br><br>0x0: Disable RESIZER module.<br><br>0x1: Enable RESIZER module. | RW   | 0x0        |

**Table 6-428. Register Call Summary for Register RSZ\_PCR**

Camera ISP Basic Programming Model

- [Camera ISP Resizer Enable/Disable Hardware](#): [0] [1] [2] [3]
- [Camera ISP Resizer Events and Status Checking](#): [4] [5] [6]
- [Camera ISP Resizer Register Accessibility During Frame Processing](#): [7] [8] [9]
- [Camera ISP Resizer Inter-Frame Operations](#): [10]

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary](#): [11]
- [Camera ISP RESIZER Register Description](#): [12]

**Table 6-429. RSZ\_CNT**

|                         |       |        |        |       |       |       |      |    |    |                          |    |    |    |    |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|-------|--------|--------|-------|-------|-------|------|----|----|--------------------------|----|----|----|----|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   |       |        |        |       |       |       |      |    |    | 0x0000 0008              |    |    |    |    |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> |       |        |        |       |       |       |      |    |    | 0x480B D008              |    |    |    |    |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      |       |        |        |       |       |       |      |    |    | RESIZER CONTROL REGISTER |    |    |    |    |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             |       |        |        |       |       |       |      |    |    | RW                       |    |    |    |    |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                | CBLIN | INPSRC | INPTYP | YCPOS | VSTPH | HSTPH | VRSZ |    |    |                          |    |    |    |    | HRSZ |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                      | RW   | 0x0   |
| 29    | CBILIN     | Chrominance horizontal algorithm select.<br>Filtering that is same as luminance processing is intended only for downsampling, and bilinear interpolation is intended only for upsampling.<br><br>0x0: The chrominance uses the same processing as the luminance.<br><br>0x1: The chrominance uses bilinear interpolation processing.                                                                                        | RW   | 0x0   |
| 28    | INPSRC     | Input source select.<br>NOTE: If this field is set to zero, the resizer input is fed from either the preview engine or the CCDC, but not both. The CCDC and preview engine modules have individual control to feed their output to the resizer input. If both the CCDC and preview engine modules are set to drive the resizer input, the CCDC output takes precedence.<br><br>0x0: PREVIEW or CCDC module.<br>0x1: Memory. | RW   | 0x0   |
| 27    | INPTYP     | Input type select.<br>0x0: YUV422 color is interleaved<br>0x1: Color separate data on 8 bits.                                                                                                                                                                                                                                                                                                                               | RW   | 0x0   |
| 26    | YCPOS      | Luminance and chrominance position in 16-bit word<br>0x0: YC<br>0x1: CY                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0   |
| 25:23 | VSTPH      | Vertical starting phase.<br>The phase range is 0 to 7.                                                                                                                                                                                                                                                                                                                                                                      | RW   | 0x0   |
| 22:20 | HSTPH      | Horizontal starting phase.<br>The phase range is 0 to 7.                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0x0   |
| 19:10 | VRSZ       | Vertical resizing value.<br>(range from 64 - 1024) plus 1<br>Vertical resizing ratio is 256/(VRSZ+1)<br>For have the correct functionality, must enter the desired value minus 1. For example for a ratio of 1, must enter 255                                                                                                                                                                                              | RW   | 0xFF  |
| 9:0   | HRSZ       | Horizontal resizing value.<br>(range from 64 - 1024) plus 1<br>Horizontal resizing ratio is 256/(HRSZ+1)<br>For have the correct functionality, must enter the desired value minus 1. For example for a ratio of 1, must enter 255                                                                                                                                                                                          | RW   | 0xFF  |

**Table 6-430. Register Call Summary for Register RSZ\_CNT**

## Camera ISP Functional Description

- Camera ISP VPBE Resizer Input and Output Interfaces: [0] [1] [2]
- Camera ISP VPBE Resizer Horizontal and Vertical Resizing: [3] [4] [5] [6] [7] [8] [9] [10] [11]
- Camera ISP VPBE Resizer Resampling Algorithm: [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23] [24] [25] [26] [27]

## Camera ISP Basic Programming Model

- Camera ISP Resizer Register Setup: [28]
- Camera ISP Resizer Processing Time Calculation: [29] [30]
- Camera ISP Resizer Summary of Constraints: [31] [32] [33] [34] [35] [36]

## Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [37]
- Camera ISP RESIZER Register Description: [38]
- Camera ISP SBL Register Description: [39]

**Table 6-431. RSZ\_OUT\_SIZE**

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 000C             | <b>Instance</b>       | ISP_RESIZER     |
| <b>Physical Address</b> | 0x480B D00C             |                       |                 |
| <b>Description</b>      | OUTPUT SIZE REGISTER    |                       |                 |
| <b>Type</b>             | RW                      |                       |                 |
| 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 |
| RESERVED                | VERT                    | RESERVED              | HORZ            |

  

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                      | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                           | RW   | 0x00  |
| 27:16 | VERT       | Output height.                                                                                                                                                                                                                                                                                                                                   | RW   | 0x000 |
| 15:13 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                           | RW   | 0x00  |
| 12:0  | HORZ       | Output (width in the horizontal direction)<br>The maximum output width cannot be greater than 4096 pixels wide (2048 if downsampling greater than 2 is used with 7 filter taps)<br>This value must be EVEN and the number of bytes written to SDRAM must be a multiple of 16-bytes if the vertical resizing factor is greater than 1x (upsizing) | RW   | 0x000 |

**Table 6-432. Register Call Summary for Register RSZ\_OUT\_SIZE**

## Camera ISP Functional Description

- [Camera ISP VPBE Resizer Input and Output Interfaces: \[0\] \[1\] \[2\]](#)
- [Camera ISP VPBE Resizer Horizontal and Vertical Resizing: \[3\] \[4\]](#)
- [Camera ISP VPBE Resizer Luma Edge Enhancement: \[5\] \[6\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP Resizer Register Setup: \[7\]](#)
- [Camera ISP Resizer Summary of Constraints: \[8\] \[9\]](#)

## Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[10\]](#)

**Table 6-433. RSZ\_IN\_START**

|                         |                                                                                                                                                                              |                       |                 |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0010                                                                                                                                                                  | <b>Instance</b>       | ISP_RESIZER     |
| <b>Physical Address</b> | 0x480B D010                                                                                                                                                                  |                       |                 |
| <b>Description</b>      | INPUT CONFIGURATION REGISTER This register must be used when the input pixel data comes from the PREVIEW module. must be set to 0 is the input pixel data comes from memory. |                       |                 |
| <b>Type</b>             | RW                                                                                                                                                                           |                       |                 |
| 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 |
| RESERVED                | VERT_ST                                                                                                                                                                      | RESERVED              | HORZ_ST         |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:29 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0    |
| 28:16 | VERT_ST    | Vertical start line.<br>This field makes sense when the resizer obtains its input from the preview engine/CCDC<br>When the resizer gets its input from SDRAM, this field must be set to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW   | 0x0000 |
| 15:13 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0    |
| 12:0  | HORZ_ST    | Horizontal start pixel. Pixels are coded on 16 bits for YUV and 8 bits for color separate data.<br>When the resizer gets its input from SDRAM, this field must be set to = 15 for YUV 16-bit data and = 31 for 8-bit color separate data<br>Horizontal starting pixel value is in number of pixels if input is from SDRAM.<br>If the input to the resizer is from CCDC/preview engine, this field must be programmed as follows:<br>(1) Program this field using number of bytes (twice number of pixels).<br>(2) Change the lowest bit to reflect start position in pixels (effectively change from a value 0 to a value 1 if required) | RW   | 0x0000 |

**Table 6-434. Register Call Summary for Register RSZ\_IN\_START**

Camera ISP Functional Description

- Camera ISP VPBE Resizer Input and Output Interfaces: [0] [1] [2] [3] [4]

Camera ISP Basic Programming Model

- Camera ISP Resizer Register Setup: [5]

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [6]

**Table 6-435. RSZ\_IN\_SIZE**

|                         |                         |                       |                 |  |  |  |  |  |          |      |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|--|--|--|----------|------|--|--|--|--|--|--|--|
| Address Offset          | 0x0000 0014             |                       |                 |  |  |  |  |  |          |      |  |  |  |  |  |  |  |
| Physical Address        | 0x480B D014             |                       |                 |  |  |  |  |  |          |      |  |  |  |  |  |  |  |
| Description             | INPUT SIZE REGISTER     |                       |                 |  |  |  |  |  |          |      |  |  |  |  |  |  |  |
| Type                    | RW                      |                       |                 |  |  |  |  |  |          |      |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |          |      |  |  |  |  |  |  |  |
| RESERVED                | VERT                    |                       |                 |  |  |  |  |  | RESERVED | HORZ |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                            | Type | Reset  |
|-------|------------|--------------------------------------------------------|------|--------|
| 31:29 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x0    |
| 28:16 | VERT       | Input height.<br>The range is 0 to 4095 lines.         | RW   | 0x0000 |
| 15:13 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0. | RW   | 0x0    |
| 12:0  | HORZ       | Input width.<br>The range is 0 to 4095 pixels.         | RW   | 0x0000 |

**Table 6-436. Register Call Summary for Register RSZ\_IN\_SIZE**

## Camera ISP Functional Description

- Camera ISP VPBE Resizer Input and Output Interfaces: [0] [1] [2] [3]
- Camera ISP VPBE Resizer Horizontal and Vertical Resizing: [4] [5]

## Camera ISP Basic Programming Model

- Camera ISP Resizer Register Setup: [6]
- Camera ISP Resizer Summary of Constraints: [7] [8] [9] [10] [11] [12]

## Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [13]

**Table 6-437. RSZ\_SDR\_INADD**

|                         |                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0018                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D018                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | INPUT ADDRESS REGISTER This register must be set only if the input pixel data comes from memory. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | ADDR       | 32-bit input memory address.<br>The 5 LSBs are forced to be zeros by the hardware to align on a 32-byte boundary; the 5 LSBs are read-only. This field must be programmed to be 0x0 if the resizer input is from preview engine/CCDC.<br>* This field can be altered even when the resizer is busy. The change takes place only for the next frame. However, note that reading this register always gives the latest value. | RW   | 0x00000000 |

**Table 6-438. Register Call Summary for Register RSZ\_SDR\_INADD**

## Camera ISP Functional Description

- Camera ISP VPBE Resizer Input and Output Interfaces: [0] [1] [2]

## Camera ISP Basic Programming Model

- Camera ISP Resizer Register Setup: [3]
- Camera ISP Resizer Register Accessibility During Frame Processing: [4]

## Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [5]

**Table 6-439. RSZ\_SDR\_INOFF**

|                         |                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 001C                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D01C                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | INPUT OFFSET REGISTER This register must be set only if the input pixel data comes from memory. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | OFFSET |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0000 |
| 15:0  | OFFSET     | Memory offset for the input lines.<br>The 5 LSBs are forced to be zeros by the hardware to align on a 32-byte boundary; the 5 LSBs are read-only.<br>This field must be programmed to be 0x0 if the resizer input is from preview engine/CCDC.<br>* This field can be altered even when the resizer is busy.<br>The change takes place only for the next frame.<br>However, note that reading this register always gives the latest value. | RW   | 0x0000 |

**Table 6-440. Register Call Summary for Register RSZ\_SDR\_INOFF**

Camera ISP Functional Description

- Camera ISP VPBE Resizer Input and Output Interfaces: [0] [1] [2]

Camera ISP Basic Programming Model

- Camera ISP Resizer Register Setup: [3]
- Camera ISP Resizer Register Accessibility During Frame Processing: [4]

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [5]

**Table 6-441. RSZ\_SDR\_OUTADD**

|                                                                                             |                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------|-------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset                                                                              | 0x0000 0020             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address                                                                            | 0x480B D020             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description                                                                                 | OUTPUT ADDRESS REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                                                                                        | RW                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ADDR                                                                                        |                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | ADDR       | 32-bit output memory address.<br>The 5 LSBs are forced to be zeros by the hardware to align on a 32-byte boundary; the 5 LSBs are read-only.<br>For optimal use of SDRAM bandwidth, the SDRAM address must be set on a 256-byte boundary.<br>* This field can be altered even when the resizer is busy.<br>The change takes place only for the next frame.<br>However, note that reading this register always gives the latest value. | RW   | 0x00000000 |

**Table 6-442. Register Call Summary for Register RSZ\_SDR\_OUTADD**

Camera ISP Functional Description

- Camera ISP VPBE Resizer Input and Output Interfaces: [0] [1]

Camera ISP Basic Programming Model

- Camera ISP Resizer Register Setup: [2]
- Camera ISP Resizer Register Accessibility During Frame Processing: [3]

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [4]

**Table 6-443. RSZ\_SDR\_OUTOFF**

| <b>Address Offset</b>   | 0x0000 0024             |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |  |  |  |  |        |  |  |  |  |  |  |  |  |      |        |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--------|--|--|--|--|--|--|--|--|------|--------|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B D024             |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |  |  |  |  |        |  |  |  |  |  |  |  |  |      |        |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | OUTPUT OFFSET REGISTER  |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |  |  |  |  |        |  |  |  |  |  |  |  |  |      |        |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |  |  |  |  |        |  |  |  |  |  |  |  |  |      |        |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |        |  |  |  |  |  |  |  |  |      |        |  |  |  |  |  |  |  |  |  |
| RESERVED                |                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |  |  |  |  | OFFSET |  |  |  |  |  |  |  |  |      |        |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name              | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |  |  |  |  |        |  |  |  |  |  |  |  |  | Type | Reset  |  |  |  |  |  |  |  |  |  |
| 31:16                   | RESERVED                | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                          |                 |  |  |  |  |        |  |  |  |  |  |  |  |  | RW   | 0x0000 |  |  |  |  |  |  |  |  |  |
| 15:0                    | OFFSET                  | Memory offset for the output lines.<br>The 5 LSBs are forced to be zeros by the hardware to align on a 32-byte boundary; the 5 LSBs are read-only.<br>For optimal use of SDRAM bandwidth, the SDRAM line offset must be set on a 256-byte boundary.<br>* This field can be altered even when the resizer is busy.<br>The change takes place only for the next frame.<br>However, note that reading this register always gives the latest value. |                 |  |  |  |  |        |  |  |  |  |  |  |  |  | RW   | 0x0000 |  |  |  |  |  |  |  |  |  |

**Table 6-444. Register Call Summary for Register RSZ\_SDR\_OUTOFF**

|                                                                                          |
|------------------------------------------------------------------------------------------|
| Camera ISP Functional Description                                                        |
| • <a href="#">Camera ISP VPBE Resizer Input and Output Interfaces: [0] [1]</a>           |
| Camera ISP Basic Programming Model                                                       |
| • <a href="#">Camera ISP Resizer Register Setup: [2]</a>                                 |
| • <a href="#">Camera ISP Resizer Register Accessibility During Frame Processing: [3]</a> |
| Camera ISP Register Manual                                                               |
| • <a href="#">Camera ISP RESIZER Register Summary: [4]</a>                               |

**Table 6-445. RSZ\_HFILT10**

| <b>Address Offset</b>   | 0x0000 0028                                     |                                                                                           |                 |  |  |  |  |  |          |       |  |  |  |  |  |  |      |       |  |
|-------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|----------|-------|--|--|--|--|--|--|------|-------|--|
| <b>Physical Address</b> | 0x480B D028                                     |                                                                                           |                 |  |  |  |  |  |          |       |  |  |  |  |  |  |      |       |  |
| <b>Description</b>      | HORIZONTAL FILTER COEFFICIENTS 0 AND 1 REGISTER |                                                                                           |                 |  |  |  |  |  |          |       |  |  |  |  |  |  |      |       |  |
| <b>Type</b>             | RW                                              |                                                                                           |                 |  |  |  |  |  |          |       |  |  |  |  |  |  |      |       |  |
| 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 |  |  |  |  |  |          |       |  |  |  |  |  |  |      |       |  |
| RESERVED                | COEF1                                           |                                                                                           |                 |  |  |  |  |  | RESERVED | COEF0 |  |  |  |  |  |  |      |       |  |
| Bits                    | Field Name                                      | <b>Description</b>                                                                        |                 |  |  |  |  |  |          |       |  |  |  |  |  |  | Type | Reset |  |
| 31:26                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                    |                 |  |  |  |  |  |          |       |  |  |  |  |  |  | RW   | 0x00  |  |
| 25:16                   | COEF1                                           | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0, tap 1 |                 |  |  |  |  |  |          |       |  |  |  |  |  |  | RW   | 0x000 |  |
| 15:10                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                    |                 |  |  |  |  |  |          |       |  |  |  |  |  |  | RW   | 0x00  |  |
| 9:0                     | COEF0                                           | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0, tap 0 |                 |  |  |  |  |  |          |       |  |  |  |  |  |  | RW   | 0x000 |  |

**Table 6-446. Register Call Summary for Register RSZ\_HFILT10**

Camera ISP Functional Description

- [Camera ISP VPBE Resizer Horizontal and Vertical Resizing: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP Resizer Register Setup: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[2\]](#)

**Table 6-447. RSZ\_HFILT32**

|                         |                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 002C                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D02C                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | HORIZONTAL FILTER COEFFICIENTS 2 AND 3 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF3                   | RESERVED              | COEF2           |

| Bits  | Field Name | Description                                                                               | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                    | RW   | 0x00  |
| 25:16 | COEF3      | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0, tap 3 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                    | RW   | 0x00  |
| 9:0   | COEF2      | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0, tap 2 | RW   | 0x000 |

**Table 6-448. Register Call Summary for Register RSZ\_HFILT32**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-449. RSZ\_HFILT54**

|                         |                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0030                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D030                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | HORIZONTAL FILTER COEFFICIENTS 4 AND 5 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF5                   | RESERVED              | COEF4           |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF5      | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0/1, tap 5/1 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF4      | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0/1, tap 4/0 | RW   | 0x000 |

**Table 6-450. Register Call Summary for Register RSZ\_HFILT54**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-451. RSZ\_HFILT76**

|                         |                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0034                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | <b>0x480B D034</b>                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | HORIZONTAL FILTER COEFFICIENTS 6 AND 37REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF7                   | RESERVED              | COEF6           |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF7      | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0/1, tap 7/3 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF6      | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0/1, tap 6/2 | RW   | 0x000 |

**Table 6-452. Register Call Summary for Register RSZ\_HFILT76**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-453. RSZ\_HFILT98**

|                         |                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0038                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | <b>0x480B D038</b>                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | HORIZONTAL FILTER COEFFICIENTS 8 AND 9 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF9                   | RESERVED              | COEF8           |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF9      | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/2, tap 1/1 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF8      | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/2, tap 0/0 | RW   | 0x000 |

**Table 6-454. Register Call Summary for Register RSZ\_HFILT98**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-455. RSZ\_HFILT1110**

|                       |                                                   |                         |             |                 |             |
|-----------------------|---------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 003C                                       | <b>Physical Address</b> | 0x480B D03C | <b>Instance</b> | ISP_RESIZER |
| <b>Description</b>    | HORIZONTAL FILTER COEFFICIENTS 10 AND 11 REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                                                |                         |             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF11                  | RESERVED              | COEF10          |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF11     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/2, tap 3/3 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF10     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/2, tap 2/2 | RW   | 0x000 |

**Table 6-456. Register Call Summary for Register RSZ\_HFILT1110**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [\[0\]](#)

**Table 6-457. RSZ\_HFILT1312**

|                       |                                                   |                         |             |                 |             |
|-----------------------|---------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 0040                                       | <b>Physical Address</b> | 0x480B D040 | <b>Instance</b> | ISP_RESIZER |
| <b>Description</b>    | HORIZONTAL FILTER COEFFICIENTS 12 AND 13 REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                                                |                         |             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF13                  | RESERVED              | COEF12          |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF13     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/3, tap 5/1 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF12     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/3, tap 4/0 | RW   | 0x000 |

**Table 6-458. Register Call Summary for Register RSZ\_HFILT1312**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [\[0\]](#)

**Table 6-459. RSZ\_HFILT1514**

|                       |                                                   |                         |             |                 |             |
|-----------------------|---------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 0044                                       | <b>Physical Address</b> | 0x480B D044 | <b>Instance</b> | ISP_RESIZER |
| <b>Description</b>    | HORIZONTAL FILTER COEFFICIENTS 14 AND 15 REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                                                |                         |             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF15                  | RESERVED              | COEF14          |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF15     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/3, tap 7/3 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF14     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/3, tap 6/2 | RW   | 0x000 |

**Table 6-460. Register Call Summary for Register RSZ\_HFILT1514**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-461. RSZ\_HFILT1716**

|                       |                                                   |                         |             |                 |             |
|-----------------------|---------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 0048                                       | <b>Physical Address</b> | 0x480B D048 | <b>Instance</b> | ISP_RESIZER |
| <b>Description</b>    | HORIZONTAL FILTER COEFFICIENTS 17 AND 16 REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                                                |                         |             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF17                  | RESERVED              | COEF16          |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF17     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/4, tap 1/1 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF16     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/4, tap 0/0 | RW   | 0x000 |

**Table 6-462. Register Call Summary for Register RSZ\_HFILT1716**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-463. RSZ\_HFILT1918**

|                       |                                                   |                         |             |                 |             |
|-----------------------|---------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 004C                                       | <b>Physical Address</b> | 0x480B D04C | <b>Instance</b> | ISP_RESIZER |
| <b>Description</b>    | HORIZONTAL FILTER COEFFICIENTS 18 AND 19 REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                                                |                         |             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF19                  | RESERVED              | COEF18          |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF19     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/4, tap 3/3 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF18     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/4, tap 2/2 | RW   | 0x000 |

**Table 6-464. Register Call Summary for Register RSZ\_HFILT1918**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [\[0\]](#)

**Table 6-465. RSZ\_HFILT2120**

|                       |                                                   |                         |             |                 |             |
|-----------------------|---------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 0050                                       | <b>Physical Address</b> | 0x480B D050 | <b>Instance</b> | ISP_RESIZER |
| <b>Description</b>    | HORIZONTAL FILTER COEFFICIENTS 20 AND 21 REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                                                |                         |             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF21                  | RESERVED              | COEF20          |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF21     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/5, tap 5/1 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF20     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/5, tap 4/0 | RW   | 0x000 |

**Table 6-466. Register Call Summary for Register RSZ\_HFILT2120**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [\[0\]](#)

**Table 6-467. RSZ\_HFILT2322**

| <b>Address Offset</b>   | 0x0000 0054                                       |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
|-------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|------|-------|
| <b>Physical Address</b> | 0x480B D054                                       |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Description</b>      | HORIZONTAL FILTER COEFFICIENTS 22 AND 23 REGISTER |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Type</b>             | RW                                                |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| 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 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| RESERVED                | COEF23                                            | RESERVED                                                                                      | COEF22          |  |  |  |  |  |  |  |  |  |  |  |      |       |
| Bits                    | Field Name                                        | <b>Description</b>                                                                            |                 |  |  |  |  |  |  |  |  |  |  |  | Type | Reset |
| 31:26                   | RESERVED                                          | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 25:16                   | COEF23                                            | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/5, tap 7/3 |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x000 |
| 15:10                   | RESERVED                                          | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 9:0                     | COEF22                                            | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/5, tap 6/2 |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x000 |

**Table 6-468. Register Call Summary for Register RSZ\_HFILT2322**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-469. RSZ\_HFILT2524**

| <b>Address Offset</b>   | 0x0000 0058                                       |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
|-------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|------|-------|
| <b>Physical Address</b> | 0x480B D058                                       |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Description</b>      | HORIZONTAL FILTER COEFFICIENTS 24 AND 25 REGISTER |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Type</b>             | RW                                                |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| 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 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| RESERVED                | COEF25                                            | RESERVED                                                                                      | COEF24          |  |  |  |  |  |  |  |  |  |  |  |      |       |
| Bits                    | Field Name                                        | <b>Description</b>                                                                            |                 |  |  |  |  |  |  |  |  |  |  |  | Type | Reset |
| 31:26                   | RESERVED                                          | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 25:16                   | COEF25                                            | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/6, tap 1/1 |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x000 |
| 15:10                   | RESERVED                                          | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 9:0                     | COEF24                                            | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/6, tap 0/0 |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x000 |

**Table 6-470. Register Call Summary for Register RSZ\_HFILT2524**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-471. RSZ\_HFILT2726**

| <b>Address Offset</b>   | 0x0000 005C                                       |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B D05C                                       |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | HORIZONTAL FILTER COEFFICIENTS 26 AND 27 REGISTER |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | COEF27                                            | RESERVED                                                                                      | COEF26          |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                        | Description                                                                                   |                 |  |  |  |  |  |  |  |  |  |  |  |
| 31:26                   | RESERVED                                          | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  |
| 25:16                   | COEF27                                            | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/6, tap 3/3 |                 |  |  |  |  |  |  |  |  |  |  |  |
| 15:10                   | RESERVED                                          | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  |
| 9:0                     | COEF26                                            | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/6, tap 2/2 |                 |  |  |  |  |  |  |  |  |  |  |  |

**Table 6-472. Register Call Summary for Register RSZ\_HFILT2726**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [0]

**Table 6-473. RSZ\_HFILT2928**

| <b>Address Offset</b>   | 0x0000 0060                                       |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B D060                                       |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | HORIZONTAL FILTER COEFFICIENTS 28 AND 29 REGISTER |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | COEF29                                            | RESERVED                                                                                      | COEF28          |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                        | Description                                                                                   |                 |  |  |  |  |  |  |  |  |  |  |  |
| 31:26                   | RESERVED                                          | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  |
| 25:16                   | COEF29                                            | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/7, tap 5/1 |                 |  |  |  |  |  |  |  |  |  |  |  |
| 15:10                   | RESERVED                                          | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  |
| 9:0                     | COEF28                                            | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/7, tap 4/0 |                 |  |  |  |  |  |  |  |  |  |  |  |

**Table 6-474. Register Call Summary for Register RSZ\_HFILT2928**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [0]

**Table 6-475. RSZ\_HFILT3130**

| <b>Address Offset</b>   | 0x0000 0064                                       |                                                                                               |                 |  |  |  |  |  |          |        |                 |  |  |  |      |       |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|----------|--------|-----------------|--|--|--|------|-------|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B D064                                       |                                                                                               |                 |  |  |  |  |  |          |        | <b>Instance</b> |  |  |  |      |       |  |  |  |  |  |  |
| <b>Description</b>      | HORIZONTAL FILTER COEFFICIENTS 30 AND 31 REGISTER |                                                                                               |                 |  |  |  |  |  |          |        |                 |  |  |  |      |       |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                |                                                                                               |                 |  |  |  |  |  |          |        |                 |  |  |  |      |       |  |  |  |  |  |  |
| 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 |  |  |  |  |  |          |        |                 |  |  |  |      |       |  |  |  |  |  |  |
| RESERVED                | COEF31                                            |                                                                                               |                 |  |  |  |  |  | RESERVED | COEF30 |                 |  |  |  |      |       |  |  |  |  |  |  |
| Bits                    | Field Name                                        | <b>Description</b>                                                                            |                 |  |  |  |  |  |          |        |                 |  |  |  | Type | Reset |  |  |  |  |  |  |
| 31:26                   | RESERVED                                          | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |          |        |                 |  |  |  | RW   | 0x00  |  |  |  |  |  |  |
| 25:16                   | COEF31                                            | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/7, tap 7/3 |                 |  |  |  |  |  |          |        |                 |  |  |  | RW   | 0x000 |  |  |  |  |  |  |
| 15:10                   | RESERVED                                          | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |          |        |                 |  |  |  | RW   | 0x00  |  |  |  |  |  |  |
| 9:0                     | COEF30                                            | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/7, tap 6/2 |                 |  |  |  |  |  |          |        |                 |  |  |  | RW   | 0x000 |  |  |  |  |  |  |

**Table 6-476. Register Call Summary for Register RSZ\_HFILT3130**

|                                    |                                                                                                                                 |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Camera ISP Functional Description  | <ul style="list-style-type: none"> <li><a href="#">Camera ISP VPBE Resizer Horizontal and Vertical Resizing: [0]</a></li> </ul> |
| Camera ISP Basic Programming Model | <ul style="list-style-type: none"> <li><a href="#">Camera ISP Resizer Register Setup: [1]</a></li> </ul>                        |
| Camera ISP Register Manual         | <ul style="list-style-type: none"> <li><a href="#">Camera ISP RESIZER Register Summary: [2]</a></li> </ul>                      |

**Table 6-477. RSZ\_VFILT10**

| <b>Address Offset</b>   | 0x0000 0068                                   |                                                                                           |                 |  |  |  |  |  |          |       |                 |  |  |  |      |       |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|----------|-------|-----------------|--|--|--|------|-------|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B D068                                   |                                                                                           |                 |  |  |  |  |  |          |       | <b>Instance</b> |  |  |  |      |       |  |  |  |  |  |  |
| <b>Description</b>      | VERTICAL FILTER COEFFICIENTS 0 AND 1 REGISTER |                                                                                           |                 |  |  |  |  |  |          |       |                 |  |  |  |      |       |  |  |  |  |  |  |
| <b>Type</b>             | RW                                            |                                                                                           |                 |  |  |  |  |  |          |       |                 |  |  |  |      |       |  |  |  |  |  |  |
| 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 |  |  |  |  |  |          |       |                 |  |  |  |      |       |  |  |  |  |  |  |
| RESERVED                | COEF1                                         |                                                                                           |                 |  |  |  |  |  | RESERVED | COEF0 |                 |  |  |  |      |       |  |  |  |  |  |  |
| Bits                    | Field Name                                    | <b>Description</b>                                                                        |                 |  |  |  |  |  |          |       |                 |  |  |  | Type | Reset |  |  |  |  |  |  |
| 31:26                   | RESERVED                                      | Write 0s for future compatibility.<br>Reads returns 0.                                    |                 |  |  |  |  |  |          |       |                 |  |  |  | RW   | 0x00  |  |  |  |  |  |  |
| 25:16                   | COEF1                                         | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0, tap 1 |                 |  |  |  |  |  |          |       |                 |  |  |  | RW   | 0x000 |  |  |  |  |  |  |
| 15:10                   | RESERVED                                      | Write 0s for future compatibility.<br>Reads returns 0.                                    |                 |  |  |  |  |  |          |       |                 |  |  |  | RW   | 0x00  |  |  |  |  |  |  |
| 9:0                     | COEF0                                         | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0, tap 0 |                 |  |  |  |  |  |          |       |                 |  |  |  | RW   | 0x000 |  |  |  |  |  |  |

**Table 6-478. Register Call Summary for Register RSZ\_VFILT10**

|                                    |                                                                                                                                 |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Camera ISP Functional Description  | <ul style="list-style-type: none"> <li><a href="#">Camera ISP VPBE Resizer Horizontal and Vertical Resizing: [0]</a></li> </ul> |
| Camera ISP Basic Programming Model | <ul style="list-style-type: none"> <li><a href="#">Camera ISP Resizer Register Setup: [1]</a></li> </ul>                        |

**Table 6-478. Register Call Summary for Register RSZ\_VFILT10 (continued)**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [2]

**Table 6-479. RSZ\_VFILT32**

|                         |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 006C |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D06C |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | INSTANCE    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | ISP_RESIZER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF3                   | RESERVED              | COEF2           |

| Bits  | Field Name | Description                                                                               | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                    | RW   | 0x00  |
| 25:16 | COEF3      | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0, tap 3 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                    | RW   | 0x00  |
| 9:0   | COEF2      | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0, tap 2 | RW   | 0x000 |

**Table 6-480. Register Call Summary for Register RSZ\_VFILT32**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [0]

**Table 6-481. RSZ\_VFILT54**

|                         |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0070 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D070 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | INSTANCE    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | ISP_RESIZER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF5                   | RESERVED              | COEF4           |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF5      | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0/1, tap 5/1 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF4      | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0/1, tap 4/0 | RW   | 0x000 |

**Table 6-482. Register Call Summary for Register RSZ\_VFILT54**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [0]

**Table 6-483. RSZ\_VFILT76**

| <b>Address Offset</b>   | 0x0000 0074                                   |                                                                                               |                 |  |  |  |  |          |       |  |  |  |  |  | <b>Instance</b> | ISP_RESIZER |              |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|----------|-------|--|--|--|--|--|-----------------|-------------|--------------|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B D074                                   |                                                                                               |                 |  |  |  |  |          |       |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VERTICAL FILTER COEFFICIENTS 6 AND 7 REGISTER |                                                                                               |                 |  |  |  |  |          |       |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                            |                                                                                               |                 |  |  |  |  |          |       |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |          |       |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | COEF7                                         |                                                                                               |                 |  |  |  |  | RESERVED | COEF6 |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                    | <b>Description</b>                                                                            |                 |  |  |  |  |          |       |  |  |  |  |  |                 | Type        | <b>Reset</b> |  |  |  |  |  |  |  |  |  |  |
| 31:26                   | RESERVED                                      | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |          |       |  |  |  |  |  |                 | RW          | 0x00         |  |  |  |  |  |  |  |  |  |  |
| 25:16                   | COEF7                                         | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0/1, tap 7/3 |                 |  |  |  |  |          |       |  |  |  |  |  |                 | RW          | 0x000        |  |  |  |  |  |  |  |  |  |  |
| 15:10                   | RESERVED                                      | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |          |       |  |  |  |  |  |                 | RW          | 0x00         |  |  |  |  |  |  |  |  |  |  |
| 9:0                     | COEF6                                         | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 0/1, tap 6/2 |                 |  |  |  |  |          |       |  |  |  |  |  |                 | RW          | 0x000        |  |  |  |  |  |  |  |  |  |  |

**Table 6-484. Register Call Summary for Register RSZ\_VFILT76**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-485. RSZ\_VFILT98**

| <b>Address Offset</b>   | 0x0000 0078                                   |                                                                                               |                 |  |  |  |  |          |       |  |  |  |  |  | <b>Instance</b> | ISP_RESIZER |              |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|----------|-------|--|--|--|--|--|-----------------|-------------|--------------|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B D078                                   |                                                                                               |                 |  |  |  |  |          |       |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VERTICAL FILTER COEFFICIENTS 8 AND 9 REGISTER |                                                                                               |                 |  |  |  |  |          |       |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                            |                                                                                               |                 |  |  |  |  |          |       |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |          |       |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | COEF9                                         |                                                                                               |                 |  |  |  |  | RESERVED | COEF8 |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                    | <b>Description</b>                                                                            |                 |  |  |  |  |          |       |  |  |  |  |  |                 | Type        | <b>Reset</b> |  |  |  |  |  |  |  |  |  |  |
| 31:26                   | RESERVED                                      | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |          |       |  |  |  |  |  |                 | RW          | 0x00         |  |  |  |  |  |  |  |  |  |  |
| 25:16                   | COEF9                                         | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/2, tap 1/1 |                 |  |  |  |  |          |       |  |  |  |  |  |                 | RW          | 0x000        |  |  |  |  |  |  |  |  |  |  |
| 15:10                   | RESERVED                                      | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |          |       |  |  |  |  |  |                 | RW          | 0x00         |  |  |  |  |  |  |  |  |  |  |
| 9:0                     | COEF8                                         | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/2, tap 0/0 |                 |  |  |  |  |          |       |  |  |  |  |  |                 | RW          | 0x000        |  |  |  |  |  |  |  |  |  |  |

**Table 6-486. Register Call Summary for Register RSZ\_VFILT98**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-487. RSZ\_VFILT1110**

| <b>Address Offset</b>   | 0x0000 007C                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B D07C                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VERTICAL FILTER COEFFICIENTS 10 AND 11 REGISTER |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                              |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | COEF11                                          | RESERVED                                                                                      | COEF10          |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                      | Description                                                                                   |                 |  |  |  |  |  |  |  |  |  |  |  |
| 31:26                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  |
| 25:16                   | COEF11                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/2, tap 3/3 |                 |  |  |  |  |  |  |  |  |  |  |  |
| 15:10                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  |
| 9:0                     | COEF10                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/2, tap 2/2 |                 |  |  |  |  |  |  |  |  |  |  |  |

**Table 6-488. Register Call Summary for Register RSZ\_VFILT1110**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [0]

**Table 6-489. RSZ\_VFILT1312**

| <b>Address Offset</b>   | 0x0000 0080                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B D080                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VERTICAL FILTER COEFFICIENTS 12 AND 13 REGISTER |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                              |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | COEF13                                          | RESERVED                                                                                      | COEF12          |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                      | Description                                                                                   |                 |  |  |  |  |  |  |  |  |  |  |  |
| 31:26                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  |
| 25:16                   | COEF13                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/3, tap 5/1 |                 |  |  |  |  |  |  |  |  |  |  |  |
| 15:10                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  |
| 9:0                     | COEF12                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/3, tap 4/0 |                 |  |  |  |  |  |  |  |  |  |  |  |

**Table 6-490. Register Call Summary for Register RSZ\_VFILT1312**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [0]

**Table 6-491. RSZ\_VFILT1514**

| <b>Address Offset</b>   | 0x0000 0084                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
|-------------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|------|-------|
| <b>Physical Address</b> | 0x480B D084                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Description</b>      | VERTICAL FILTER COEFFICIENTS 14 AND 15 REGISTER |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Type</b>             | RW                                              |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| 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 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| RESERVED                | COEF15                                          | RESERVED                                                                                      | COEF14          |  |  |  |  |  |  |  |  |  |  |  |      |       |
| Bits                    | Field Name                                      | <b>Description</b>                                                                            |                 |  |  |  |  |  |  |  |  |  |  |  | Type | Reset |
| 31:26                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 25:16                   | COEF15                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/3, tap 7/3 |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x000 |
| 15:10                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 9:0                     | COEF14                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 1/3, tap 6/2 |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x000 |

**Table 6-492. Register Call Summary for Register RSZ\_VFILT1514**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-493. RSZ\_VFILT1716**

| <b>Address Offset</b>   | 0x0000 0088                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
|-------------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|------|-------|
| <b>Physical Address</b> | 0x480B D088                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Description</b>      | VERTICAL FILTER COEFFICIENTS 16 AND 17 REGISTER |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Type</b>             | RW                                              |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| 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 |  |  |  |  |  |  |  |  |  |  |  |      |       |
| RESERVED                | COEF17                                          | RESERVED                                                                                      | COEF16          |  |  |  |  |  |  |  |  |  |  |  |      |       |
| Bits                    | Field Name                                      | <b>Description</b>                                                                            |                 |  |  |  |  |  |  |  |  |  |  |  | Type | Reset |
| 31:26                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 25:16                   | COEF17                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/4, tap 1/1 |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x000 |
| 15:10                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 9:0                     | COEF16                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/4, tap 0/0 |                 |  |  |  |  |  |  |  |  |  |  |  | RW   | 0x000 |

**Table 6-494. Register Call Summary for Register RSZ\_VFILT1716**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-495. RSZ\_VFILT1918**

|                       |                                                 |                         |             |                 |             |
|-----------------------|-------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 008C                                     | <b>Physical Address</b> | 0x480B D08C | <b>Instance</b> | ISP_RESIZER |
| <b>Description</b>    | VERTICAL FILTER COEFFICIENTS 18 AND 19 REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                                              |                         |             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF19                  | RESERVED              | COEF18          |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF19     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/4, tap 3/3 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF18     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/4, tap 2/2 | RW   | 0x000 |

**Table 6-496. Register Call Summary for Register RSZ\_VFILT1918**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [\[0\]](#)

**Table 6-497. RSZ\_VFILT2120**

|                       |                                                 |                         |             |                 |             |
|-----------------------|-------------------------------------------------|-------------------------|-------------|-----------------|-------------|
| <b>Address Offset</b> | 0x0000 0090                                     | <b>Physical Address</b> | 0x480B D090 | <b>Instance</b> | ISP_RESIZER |
| <b>Description</b>    | VERTICAL FILTER COEFFICIENTS 20 AND 21 REGISTER |                         |             |                 |             |
| <b>Type</b>           | RW                                              |                         |             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF21                  | RESERVED              | COEF20          |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF21     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/5, tap 5/1 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF20     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/5, tap 4/0 | RW   | 0x000 |

**Table 6-498. Register Call Summary for Register RSZ\_VFILT2120**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [\[0\]](#)

**Table 6-499. RSZ\_VFILT2322**

|                         |             |                    |                                                 |
|-------------------------|-------------|--------------------|-------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0094 | <b>Instance</b>    | ISP_RESIZER                                     |
| <b>Physical Address</b> | 0x480B D094 | <b>Description</b> | VERTICAL FILTER COEFFICIENTS 22 AND 23 REGISTER |
| <b>Type</b>             | RW          |                    |                                                 |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF23                  | RESERVED              | COEF22          |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF23     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/5, tap 7/3 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF22     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 2/5, tap 6/2 | RW   | 0x000 |

**Table 6-500. Register Call Summary for Register RSZ\_VFILT2322**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-501. RSZ\_VFILT2524**

|                         |             |                    |                                                 |
|-------------------------|-------------|--------------------|-------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0098 | <b>Instance</b>    | ISP_RESIZER                                     |
| <b>Physical Address</b> | 0x480B D098 | <b>Description</b> | VERTICAL FILTER COEFFICIENTS 24 AND 25 REGISTER |
| <b>Type</b>             | RW          |                    |                                                 |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | COEF25                  | RESERVED              | COEF24          |

| Bits  | Field Name | Description                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 25:16 | COEF25     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/6, tap 1/1 | RW   | 0x000 |
| 15:10 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                        | RW   | 0x00  |
| 9:0   | COEF24     | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/6, tap 0/0 | RW   | 0x000 |

**Table 6-502. Register Call Summary for Register RSZ\_VFILT2524**

Camera ISP Register Manual

- [Camera ISP RESIZER Register Summary: \[0\]](#)

**Table 6-503. RSZ\_VFILT2726**

| <b>Address Offset</b>   | 0x0000 009C                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B D09C                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VERTICAL FILTER COEFFICIENTS 26 AND 27 REGISTER |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                              |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | COEF27                                          | RESERVED                                                                                      | COEF26          |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                      | Description                                                                                   |                 |  |  |  |  |  |  |  |  |  |  |  |
| 31:26                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  |
| 25:16                   | COEF27                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/6, tap 3/3 |                 |  |  |  |  |  |  |  |  |  |  |  |
| 15:10                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  |
| 9:0                     | COEF26                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/6, tap 2/2 |                 |  |  |  |  |  |  |  |  |  |  |  |

**Table 6-504. Register Call Summary for Register RSZ\_VFILT2726**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [\[0\]](#)

**Table 6-505. RSZ\_VFILT2928**

| <b>Address Offset</b>   | 0x0000 00A0                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x480B D0A0                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VERTICAL FILTER COEFFICIENTS 28 AND 29 REGISTER |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                              |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | COEF29                                          | RESERVED                                                                                      | COEF28          |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                      | Description                                                                                   |                 |  |  |  |  |  |  |  |  |  |  |  |
| 31:26                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  |
| 25:16                   | COEF29                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/7, tap 5/1 |                 |  |  |  |  |  |  |  |  |  |  |  |
| 15:10                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  |  |
| 9:0                     | COEF28                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/7, tap 4/0 |                 |  |  |  |  |  |  |  |  |  |  |  |

**Table 6-506. Register Call Summary for Register RSZ\_VFILT2928**

Camera ISP Register Manual

- Camera ISP RESIZER Register Summary: [\[0\]](#)

**Table 6-507. RSZ\_VFILT3130**

| <b>Address Offset</b>   | 0x0000 00A4                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |      |       |
|-------------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|------|-------|
| <b>Physical Address</b> | 0x480B D0A4                                     |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Description</b>      | VERTICAL FILTER COEFFICIENTS 30 AND 31 REGISTER |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |      |       |
| <b>Type</b>             | RW                                              |                                                                                               |                 |  |  |  |  |  |  |  |  |  |  |      |       |
| 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 |  |  |  |  |  |  |  |  |  |  |      |       |
| RESERVED                | COEF31                                          | RESERVED                                                                                      | COEF30          |  |  |  |  |  |  |  |  |  |  |      |       |
| Bits                    | Field Name                                      | <b>Description</b>                                                                            |                 |  |  |  |  |  |  |  |  |  |  | Type | Reset |
| 31:26                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 25:16                   | COEF31                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/7, tap 7/3 |                 |  |  |  |  |  |  |  |  |  |  | RW   | 0x000 |
| 15:10                   | RESERVED                                        | Write 0s for future compatibility.<br>Reads returns 0.                                        |                 |  |  |  |  |  |  |  |  |  |  | RW   | 0x00  |
| 9:0                     | COEF30                                          | 10-bit coefficient (S10Q8 format - range of -2 to 1.255/256, 1 is 0x100) - Phase 3/7, tap 6/2 |                 |  |  |  |  |  |  |  |  |  |  | RW   | 0x000 |

**Table 6-508. Register Call Summary for Register RSZ\_VFILT3130**

|                                    |                                                                                 |
|------------------------------------|---------------------------------------------------------------------------------|
| Camera ISP Functional Description  | <a href="#">• Camera ISP VPBE Resizer Horizontal and Vertical Resizing: [0]</a> |
| Camera ISP Basic Programming Model | <a href="#">• Camera ISP Resizer Register Setup: [1]</a>                        |
| Camera ISP Register Manual         | <a href="#">• Camera ISP RESIZER Register Summary: [2]</a>                      |

**Table 6-509. RSZ\_YENH**

| <b>Address Offset</b>   | 0x0000 00A8                                                                                                                    |                                                                                                                      |                 |  |  |  |  |  |  |  |  |  |  |      |        |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|------|--------|
| <b>Physical Address</b> | 0x480B D0A8                                                                                                                    |                                                                                                                      |                 |  |  |  |  |  |  |  |  |  |  |      |        |
| <b>Description</b>      | LUMINANCE ENHANCER REGISTER The new luminance value is computed as: Y += HPF(Y) x max(GAIN, ( HPF(Y) - CORE ) x SLOP + 8) / 4. |                                                                                                                      |                 |  |  |  |  |  |  |  |  |  |  |      |        |
| <b>Type</b>             | RW                                                                                                                             |                                                                                                                      |                 |  |  |  |  |  |  |  |  |  |  |      |        |
| 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 |  |  |  |  |  |  |  |  |  |  |      |        |
| RESERVED                | ALGO                                                                                                                           | GAIN                                                                                                                 | SLOP            |  |  |  |  |  |  |  |  |  |  | CORE |        |
| Bits                    | Field Name                                                                                                                     | <b>Description</b>                                                                                                   |                 |  |  |  |  |  |  |  |  |  |  | Type | Reset  |
| 31:18                   | RESERVED                                                                                                                       | Write 0s for future compatibility.<br>Reads returns 0.                                                               |                 |  |  |  |  |  |  |  |  |  |  | RW   | 0x0000 |
| 17:16                   | ALGO                                                                                                                           | Algorithm select.<br>0x0: Disable.<br>0x1: [-1 2 -1]/2 high-pass filter.<br>0x2: [-1 -2 6 -2 -1]/4 high-pass filter. |                 |  |  |  |  |  |  |  |  |  |  | RW   | 0x0    |
| 15:12                   | GAIN                                                                                                                           | Maximum gain.<br>The data is coded in U4Q4 representation.                                                           |                 |  |  |  |  |  |  |  |  |  |  | RW   | 0x0    |
| 11:8                    | SLOP                                                                                                                           | Slope.<br>The data is coded in U4Q4 representation.                                                                  |                 |  |  |  |  |  |  |  |  |  |  | RW   | 0x0    |
| 7:0                     | CORE                                                                                                                           | Coring offset.<br>The data is coded in U8Q0 representation.                                                          |                 |  |  |  |  |  |  |  |  |  |  | RW   | 0x00   |

**Table 6-510. Register Call Summary for Register RSZ\_YENH**

|                                                                                                                                                                                                 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Camera ISP Functional Description                                                                                                                                                               |
| <ul style="list-style-type: none"> <li>• Camera ISP VPBE Resizer Horizontal and Vertical Resizing: [0] [1]</li> <li>• Camera ISP VPBE Resizer Luma Edge Enhancement: [2] [3] [4] [5]</li> </ul> |
| Camera ISP Basic Programming Model                                                                                                                                                              |
| <ul style="list-style-type: none"> <li>• Camera ISP Resizer Register Setup: [6] [7] [8] [9] [10] [11]</li> <li>• Camera ISP Resizer Summary of Constraints: [12] [13]</li> </ul>                |
| Camera ISP Register Manual                                                                                                                                                                      |
| <ul style="list-style-type: none"> <li>• Camera ISP RESIZER Register Summary: [14]</li> </ul>                                                                                                   |

## 6.6.9 Camera ISP SBL Registers

### 6.6.9.1 Camera ISP SBL Register Summary

**Table 6-511. ISP\_SBL Register Mapping Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | ISP_SBL Base Address |
|------------------|------|-----------------------|----------------|----------------------|
| SBL_PID          | R    | 32                    | 0x0000 0000    | 0x480B D200          |
| SBL_PCR          | RW   | 32                    | 0x0000 0004    | 0x480B D204          |
| SBL_GLB_REG_0    | R    | 32                    | 0x0000 0008    | 0x480B D208          |
| SBL_GLB_REG_1    | R    | 32                    | 0x0000 000C    | 0x480B D20C          |
| SBL_GLB_REG_2    | R    | 32                    | 0x0000 0010    | 0x480B D210          |
| SBL_GLB_REG_3    | R    | 32                    | 0x0000 0014    | 0x480B D214          |
| SBL_GLB_REG_4    | R    | 32                    | 0x0000 0018    | 0x480B D218          |
| SBL_GLB_REG_5    | R    | 32                    | 0x0000 001C    | 0x480B D21C          |
| SBL_GLB_REG_6    | R    | 32                    | 0x0000 0020    | 0x480B D220          |
| SBL_GLB_REG_7    | R    | 32                    | 0x0000 0024    | 0x480B D224          |
| SBL_CCDC_WR_0    | R    | 32                    | 0x0000 0028    | 0x480B D228          |
| SBL_CCDC_WR_1    | R    | 32                    | 0x0000 002C    | 0x480B D22C          |
| SBL_CCDC_WR_2    | R    | 32                    | 0x0000 0030    | 0x480B D230          |
| SBL_CCDC_WR_3    | R    | 32                    | 0x0000 0034    | 0x480B D234          |
| SBL_CCDC_FP_RD_0 | R    | 32                    | 0x0000 0038    | 0x480B D238          |
| SBL_CCDC_FP_RD_1 | R    | 32                    | 0x0000 003C    | 0x480B D23C          |
| SBL_PRV_RD_0     | R    | 32                    | 0x0000 0040    | 0x480B D240          |
| SBL_PRV_RD_1     | R    | 32                    | 0x0000 0044    | 0x480B D244          |
| SBL_PRV_RD_2     | R    | 32                    | 0x0000 0048    | 0x480B D248          |
| SBL_PRV_RD_3     | R    | 32                    | 0x0000 004C    | 0x480B D24C          |
| SBL_PRV_WR_0     | R    | 32                    | 0x0000 0050    | 0x480B D250          |
| SBL_PRV_WR_1     | R    | 32                    | 0x0000 0054    | 0x480B D254          |
| SBL_PRV_WR_2     | R    | 32                    | 0x0000 0058    | 0x480B D258          |
| SBL_PRV_WR_3     | R    | 32                    | 0x0000 005C    | 0x480B D25C          |
| SBL_PRV_DK_RD_0  | R    | 32                    | 0x0000 0060    | 0x480B D260          |
| SBL_PRV_DK_RD_1  | R    | 32                    | 0x0000 0064    | 0x480B D264          |
| SBL_PRV_DK_RD_2  | R    | 32                    | 0x0000 0068    | 0x480B D268          |
| SBL_PRV_DK_RD_3  | R    | 32                    | 0x0000 006C    | 0x480B D26C          |
| SBL_RSZ_RD_0     | R    | 32                    | 0x0000 0070    | 0x480B D270          |
| SBL_RSZ_RD_1     | R    | 32                    | 0x0000 0074    | 0x480B D274          |
| SBL_RSZ_RD_2     | R    | 32                    | 0x0000 0078    | 0x480B D278          |
| SBL_RSZ_RD_3     | R    | 32                    | 0x0000 007C    | 0x480B D27C          |
| SBL_RSZ1_WR_0    | R    | 32                    | 0x0000 0080    | 0x480B D280          |

**Table 6-511. ISP\_SBL Register Mapping Summary (continued)**

| Register Name      | Type | Register Width (Bits) | Address Offset | ISP_SBL Base Address |
|--------------------|------|-----------------------|----------------|----------------------|
| SBL_RSZ1_WR_1      | R    | 32                    | 0x0000 0084    | 0x480B D284          |
| SBL_RSZ1_WR_2      | R    | 32                    | 0x0000 0088    | 0x480B D288          |
| SBL_RSZ1_WR_3      | R    | 32                    | 0x0000 008C    | 0x480B D28C          |
| SBL_RSZ2_WR_0      | R    | 32                    | 0x0000 0090    | 0x480B D290          |
| SBL_RSZ2_WR_1      | R    | 32                    | 0x0000 0094    | 0x480B D294          |
| SBL_RSZ2_WR_2      | R    | 32                    | 0x0000 0098    | 0x480B D298          |
| SBL_RSZ2_WR_3      | R    | 32                    | 0x0000 009C    | 0x480B D29C          |
| SBL_RSZ3_WR_0      | R    | 32                    | 0x0000 00A0    | 0x480B D2A0          |
| SBL_RSZ3_WR_1      | R    | 32                    | 0x0000 00A4    | 0x480B D2A4          |
| SBL_RSZ3_WR_2      | R    | 32                    | 0x0000 00A8    | 0x480B D2A8          |
| SBL_RSZ3_WR_3      | R    | 32                    | 0x0000 00AC    | 0x480B D2AC          |
| SBL_RSZ4_WR_0      | R    | 32                    | 0x0000 00B0    | 0x480B D2B0          |
| SBL_RSZ4_WR_1      | R    | 32                    | 0x0000 00B4    | 0x480B D2B4          |
| SBL_RSZ4_WR_2      | R    | 32                    | 0x0000 00B8    | 0x480B D2B8          |
| SBL_RSZ4_WR_3      | R    | 32                    | 0x0000 00BC    | 0x480B D2BC          |
| SBL_HIST_RD_0      | R    | 32                    | 0x0000 00C0    | 0x480B D2C0          |
| SBL_HIST_RD_1      | R    | 32                    | 0x0000 00C4    | 0x480B D2C4          |
| SBL_H3A_AF_WR_0    | R    | 32                    | 0x0000 00C8    | 0x480B D2C8          |
| SBL_H3A_AF_WR_1    | R    | 32                    | 0x0000 00CC    | 0x480B D2CC          |
| SBL_H3A_AEAWB_WR_0 | R    | 32                    | 0x0000 00D0    | 0x480B D2D0          |
| SBL_H3A_AEAWB_WR_1 | R    | 32                    | 0x0000 00D4    | 0x480B D2D4          |
| SBL_CSIA_WR_0      | R    | 32                    | 0x0000 00D8    | 0x480B D2D8          |
| SBL_CSIA_WR_1      | R    | 32                    | 0x0000 00DC    | 0x480B D2DC          |
| SBL_CSIA_WR_2      | R    | 32                    | 0x0000 00E0    | 0x480B D2E0          |
| SBL_CSIA_WR_3      | R    | 32                    | 0x0000 00E4    | 0x480B D2E4          |
| SBL_CSIB_WR_0      | R    | 32                    | 0x0000 00E8    | 0x480B D2E8          |
| SBL_CSIB_WR_1      | R    | 32                    | 0x0000 00EC    | 0x480B D2EC          |
| SBL_CSIB_WR_2      | R    | 32                    | 0x0000 00F0    | 0x480B D2F0          |
| SBL_CSIB_WR_3      | R    | 32                    | 0x0000 00F4    | 0x480B D2F4          |
| SBL_SDR_REQ_EXP    | RW   | 32                    | 0x0000 00F8    | 0x480B D2F8          |

### 6.6.9.2 Camera ISP SBL Register Description

**Table 6-512. SBL\_PID**

|                         |                                    |                       |                 |
|-------------------------|------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0000                        | <b>Instance</b>       | ISP_SBL         |
| <b>Physical Address</b> | 0x480B D200                        |                       |                 |
| <b>Description</b>      | PERIPHERAL IDENTIFICATION REGISTER |                       |                 |
| <b>Type</b>             | R                                  |                       |                 |
| 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 |
| RESERVED                | TID                                | CID                   | PREV            |

| Bits  | Field Name | Description                                         | Type | Reset            |
|-------|------------|-----------------------------------------------------|------|------------------|
| 31:24 | RESERVED   | Write 0s for future compatibility. Reads returns 0. | R    | 0x00             |
| 23:16 | TID        | Peripheral identification: SBL module               | R    | 0x01             |
| 15:8  | CID        | Class identification: Camera ISP                    | R    | 0xFB             |
| 7:0   | PREV       | Peripheral revision number                          | R    | TI internal data |

**Table 6-513. Register Call Summary for Register SBL\_PID**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-514. SBL\_PCR**

| Address Offset          | 0x0000 0004              |               |                   |              |             |              |              |              |              |                |                   |          |  |  | Instance                                                                                                                                                                                                                                                                                                                                                                                        | ISP_SBL |   |   |   |   |   |   |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------|---------------|-------------------|--------------|-------------|--------------|--------------|--------------|--------------|----------------|-------------------|----------|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---|---|---|---|---|---|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|
| Physical Address        | 0x480B D204              |               |                   |              |             |              |              |              |              |                |                   |          |  |  | PERIPHERAL CONTROL REGISTER                                                                                                                                                                                                                                                                                                                                                                     |         |   |   |   |   |   |   |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |
| Description             |                          |               |                   |              |             |              |              |              |              |                |                   |          |  |  | Note on the overflow bits: the overflow does not prevent the modules to make further requests. The only way to clear the overflow is to reset the bit. After an overflow, the data will be corrupted and the application layer should disregard the data. No software reset is required after an overflow. If the overflow condition is cleared the data will continue to be acquired normally. |         |   |   |   |   |   |   |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                    | RW                       |               |                   |              |             |              |              |              |              |                |                   |          |  |  | 7                                                                                                                                                                                                                                                                                                                                                                                               | 6       | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 30 29 28 27 26 25 24 | CSI1_CCP2B_CSI2C_WBL_OVF | CSI2A_WBL_OVF | CCDCPRV_2_RSZ_OVF | CCDC_WBL_OVF | PRV_WBL_OVF | RSZ1_WBL_OVF | RSZ2_WBL_OVF | RSZ3_WBL_OVF | RSZ4_WBL_OVF | H3A_AF_WBL_OVF | H3A_AEAWB_WBL_OVF | RESERVED |  |  |                                                                                                                                                                                                                                                                                                                                                                                                 |         |   |   |   |   |   |   |  |  |  | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name               | Description                                                                                                                                                                             | Type | Reset |
|-------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | RESERVED                 | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                                 | RW   | 0x00  |
| 26    | CSI1_CCP2B_CSI2C_WBL_OVF | CSI1/CCP2B or CSI2C Write buffer memory overflow<br>All DUs have been filled up: overflow. Software has to write 1 to clear the bit.<br><br>Read 0x0: No overflow<br>Read 0x1: Overflow | RW   | 0     |
| 25    | CSI2A_WBL_OVF            | CSI2A Write buffer memory overflow<br>All DUs have been filled up: overflow. Software has to write 1 to clear the bit.<br><br>Read 0x0: No overflow<br>Read 0x1: Overflow               | RW   | 0     |

| Bits | Field Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Type | Reset |
|------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 24   | CCDCPRV_2_RSZ_OVF | CCDC/PRV to RESIZER input overflow<br>This bit is set if the RESIZER input source is set to CCDC/PREVIEW engine when the active data (to be resized) has already showed up at the resizer interface. In such a case, resizing for this frame cannot take place and the bit is set. This scenario can happen when a resize of 4x is required per frame. Therefore, the RESIZER needs to operate in two passes. In the first pass the input data from CCDC/PREVIEW is directly resized and written to memory. In the second pass, the resized data from the first pass is resized again. The next frame from the CCDC/PREVIEW engine should only start after the second pass on the previous frame is complete. This bit indicates the failure status.<br>Software has to write 1 to clear the bit.<br><b>Note:</b> Ignore the behavior of this field when RSZ_CNT[28] INPSRC = 0x1 (when data comes from memory).<br>Read 0x0: No overflow<br>Read 0x1: Overflow | RW   | 0     |
| 23   | CCDC_WBL_OVF      | CCDC Write buffer memory overflow<br>All DUs have been filled up: overflow. Software has to write 1 to clear the bit.<br>Read 0x0: No overflow<br>Read 0x1: Overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0     |
| 22   | PRV_WBL_OVF       | PREVIEW Write buffer memory overflow<br>All DUs have been filled up: overflow. Software has to write 1 to clear the bit.<br>Read 0x0: No overflow<br>Read 0x1: Overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0     |
| 21   | RSZ1_WBL_OVF      | RESIZER line 1 Write buffer memory overflow<br>All DUs have been filled up: overflow. Software has to write 1 to clear the bit.<br>Read 0x0: No overflow<br>Read 0x1: Overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0     |
| 20   | RSZ2_WBL_OVF      | RESIZER line 2 Write buffer memory overflow<br>All DUs have been filled up: overflow. Software has to write 1 to clear the bit.<br>Read 0x0: No overflow<br>Read 0x1: Overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0     |
| 19   | RSZ3_WBL_OVF      | RESIZER line 3 Write buffer memory overflow<br>All DUs have been filled up: overflow. Software has to write 1 to clear the bit.<br>Read 0x0: No overflow<br>Read 0x1: Overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0     |
| 18   | RSZ4_WBL_OVF      | RESIZER line 4 Write buffer memory overflow<br>All DUs have been filled up: overflow. Software has to write 1 to clear the bit.<br>Read 0x0: No overflow<br>Read 0x1: Overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0     |
| 17   | H3A_AF_WBL_OVF    | H3A AF Write buffer memory overflow<br>All DUs have been filled up: overflow. Software has to write 1 to clear the bit.<br>Read 0x0: No overflow<br>Read 0x1: Overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0     |

| Bits | Field Name        | Description                                                                                                                                                                    | Type | Reset  |
|------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 16   | H3A_AEAWB_WBL_OVF | H3A AE AWB Write buffer memory overflow<br>All DUs have been filled up: overflow. Software has to write 1 to clear the bit.<br><br>Read 0x0: No overflow<br>Read 0x1: Overflow | RW   | 0      |
| 15:3 | RESERVED          | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                        | RW   | 0x0000 |
| 2:0  | RESERVED          | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                        | RW   | 0x0    |

**Table 6-515. Register Call Summary for Register SBL\_PCR**

Camera ISP Basic Programming Model

- Camera ISP Central-Resource SBL Event and Status Checking: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12]

Camera ISP Register Manual

- Camera ISP Register Description: [13] [14] [15] [16]
- Camera ISP SBL Register Summary: [17]

**Table 6-516. SBL\_GLB\_REG\_0**

|                  |                   |          |         |
|------------------|-------------------|----------|---------|
| Address Offset   | 0x0000 0008       | Instance | ISP_SBL |
| Physical Address | 0x480B D208       |          |         |
| Description      | GLOBAL REGISTER 0 |          |         |
| Type             | R                 |          |         |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |            |           |   |           |       |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------------|-----------|---|-----------|-------|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SRC_DST_ID | SRC_DST_M |   | DIRECTION | VALID |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                        | Type | Reset    |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                            | R    | 0x000000 |
| 8:7  | SRC_DST_ID | Individual module register command number.<br>For the modules that only have 2 individual requestors, this field will only display either 0 or 1. For modules that have 4 individual requestors, this field will display 0, 1, 2 or 3.<br><br>Read 0x0: Read / write module requestor #1<br>Read 0x1: Read / write module requestor #2<br>Read 0x2: Read / write module requestor #3<br>Read 0x3: Read / write module requestor #4 | R    | 0x0      |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 6:2  | SRC_DST_M  | Source or destination module<br>Read 0x0: CCDC module output<br>Read 0x1: CCDC module fault pixel correction input<br>Read 0x2: PREVIEW module input<br>Read 0x3: PREVIEW module output<br>Read 0x4: PREVIEW module dark frame subtract input<br>Read 0x5: RESIZER module input<br>Read 0x6: RESIZER module output line 1<br>Read 0x7: RESIZER module output line 2<br>Read 0x8: RESIZER module output line 3<br>Read 0x9: RESIZER module output line 4<br>Read 0xA: HISTOGRAM module input<br>Read 0xB: H3A module output - auto focus<br>Read 0xC: H3A module output - auto exposure and auto white balance<br>Read 0xD: CSI2A module output<br>Read 0xE: CSI1/CCP2B or CSI2C module output | R    | 0x00  |
| 1    | DIRECTION  | Direction<br>Read 0x0: Read<br>Read 0x1: Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0     |
| 0    | VALID      | Valid bit<br>Read 0x0: Not valid.<br>Read 0x1: Valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0     |

**Table 6-517. Register Call Summary for Register SBL\_GLB\_REG\_0**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-518. SBL\_GLB\_REG\_1**

|                         |                         |                         |                 |                 |                    |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|--------------------|
| <b>Address Offset</b>   | 0x0000 000C             | <b>Physical Address</b> | 0x480B D20C     | <b>Instance</b> | ISP_SBL            |
| <b>Description</b>      | GLOBAL REGISTER 1       |                         |                 |                 |                    |
| <b>Type</b>             | R                       |                         |                 |                 |                    |
| 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 |                 |                    |
|                         | RESERVED                |                         | SRC_DST_ID      | SRC_DST_M       | DIRECTION<br>VALID |

## Camera ISP Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset    |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x000000 |
| 8:7  | SRC_DST_ID | Individual module register command number.<br>For the modules that only have 2 individual requestors, this field will only display either 0 or 1. For modules that have 4 individual requestors, this field will display 0, 1, 2 or 3.<br><br>Read 0x0: Read / write module requestor #1<br>Read 0x1: Read / write module requestor #2<br>Read 0x2: Read / write module requestor #3<br>Read 0x3: Read / write module requestor #4                                                                                                                                                                                                                                                                | R    | 0x0      |
| 6:2  | SRC_DST_M  | Source or destination module<br><br>Read 0x0: CCDC module output<br>Read 0x1: CCDC module fault pixel correction input<br>Read 0x2: PREVIEW module input<br>Read 0x3: PREVIEW module output<br>Read 0x4: PREVIEW module dark frame subtract input<br>Read 0x5: RESIZER module input<br>Read 0x6: RESIZER module output line 1<br>Read 0x7: RESIZER module output line 2<br>Read 0x8: RESIZER module output line 3<br>Read 0x9: RESIZER module output line 4<br>Read 0xA: HISTOGRAM module input<br>Read 0xB: H3A module output - auto focus<br>Read 0xC: H3A module output - auto exposure and auto white balance<br>Read 0xD: CSI2A module output<br>Read 0xE: CSI1/CCP2B or CSI2C module output | R    | 0x00     |
| 1    | DIRECTION  | Direction<br><br>Read 0x0: Read<br>Read 0x1: Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0        |
| 0    | VALID      | Valid bit<br><br>Read 0x0: Not valid.<br>Read 0x1: Valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0        |

**Table 6-519. Register Call Summary for Register SBL\_GLB\_REG\_1**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-520. SBL\_GLB\_REG\_2**

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| Address Offset          | 0x0000 0010             | Instance              | ISP_SBL         |
| Physical Address        | 0x480B D210             |                       |                 |
| Description             | GLOBAL REGISTER 2       |                       |                 |
| Type                    | R                       |                       |                 |
| 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 |
| RESERVED                |                         | SRC_DST_ID            | SRC_DST_M       |
|                         |                         | DIRECTION             | VALID           |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset    |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x000000 |
| 8:7  | SRC_DST_ID | Individual module register command number.<br>For the modules that only have 2 individual requestors, this field will only display either 0 or 1. For modules that have 4 individual requestors, this field will display 0, 1, 2 or 3.<br><br>Read 0x0: Read / write module requestor #1<br>Read 0x1: Read / write module requestor #2<br>Read 0x2: Read / write module requestor #3<br>Read 0x3: Read / write module requestor #4                                                                                                                                                                                                                                                                | R    | 0x0      |
| 6:2  | SRC_DST_M  | Source or destination module<br><br>Read 0x0: CCDC module output<br>Read 0x1: CCDC module fault pixel correction input<br>Read 0x2: PREVIEW module input<br>Read 0x3: PREVIEW module output<br>Read 0x4: PREVIEW module dark frame subtract input<br>Read 0x5: RESIZER module input<br>Read 0x6: RESIZER module output line 1<br>Read 0x7: RESIZER module output line 2<br>Read 0x8: RESIZER module output line 3<br>Read 0x9: RESIZER module output line 4<br>Read 0xA: HISTOGRAM module input<br>Read 0xB: H3A module output - auto focus<br>Read 0xC: H3A module output - auto exposure and auto white balance<br>Read 0xD: CSI2A module output<br>Read 0xE: CSI1/CCP2B or CSI2C module output | R    | 0x00     |
| 1    | DIRECTION  | Direction<br><br>Read 0x0: Read<br>Read 0x1: Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0        |
| 0    | VALID      | Valid bit<br><br>Read 0x0: Not valid.<br>Read 0x1: Valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0        |

**Table 6-521. Register Call Summary for Register SBL\_GLB\_REG\_2**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-522. SBL\_GLB\_REG\_3**

|                         |                         |                         |                 |                 |                    |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|--------------------|
| <b>Address Offset</b>   | 0x0000 0014             | <b>Physical Address</b> | 0x480B D214     | <b>Instance</b> | ISP_SBL            |
| <b>Description</b>      | GLOBAL REGISTER 3       |                         |                 |                 |                    |
| <b>Type</b>             | R                       |                         |                 |                 |                    |
| 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 |                 |                    |
| RESERVED                |                         |                         | SRC_DST_ID      | SRC_DST_M       | DIRECTION<br>VALID |

## Camera ISP Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset    |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x000000 |
| 8:7  | SRC_DST_ID | Individual module register command number.<br>For the modules that only have 2 individual requestors, this field will only display either 0 or 1. For modules that have 4 individual requestors, this field will display 0, 1, 2 or 3.<br><br>Read 0x0: Read / write module requestor #1<br>Read 0x1: Read / write module requestor #2<br>Read 0x2: Read / write module requestor #3<br>Read 0x3: Read / write module requestor #4                                                                                                                                                                                                                                                                | R    | 0x0      |
| 6:2  | SRC_DST_M  | Source or destination module<br><br>Read 0x0: CCDC module output<br>Read 0x1: CCDC module fault pixel correction input<br>Read 0x2: PREVIEW module input<br>Read 0x3: PREVIEW module output<br>Read 0x4: PREVIEW module dark frame subtract input<br>Read 0x5: RESIZER module input<br>Read 0x6: RESIZER module output line 1<br>Read 0x7: RESIZER module output line 2<br>Read 0x8: RESIZER module output line 3<br>Read 0x9: RESIZER module output line 4<br>Read 0xA: HISTOGRAM module input<br>Read 0xB: H3A module output - auto focus<br>Read 0xC: H3A module output - auto exposure and auto white balance<br>Read 0xD: CSI2A module output<br>Read 0xE: CSI1/CCP2B or CSI2C module output | R    | 0x00     |
| 1    | DIRECTION  | Direction<br><br>Read 0x0: Read<br>Read 0x1: Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0        |
| 0    | VALID      | Valid bit<br><br>Read 0x0: Not valid.<br>Read 0x1: Valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0        |

**Table 6-523. Register Call Summary for Register SBL\_GLB\_REG\_3**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-524. SBL\_GLB\_REG\_4**

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| Address Offset          | 0x0000 0018             | Instance              | ISP_SBL         |
| Physical Address        | 0x480B D218             |                       |                 |
| Description             | GLOBAL REGISTER 4       |                       |                 |
| Type                    | R                       |                       |                 |
| 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 |
| RESERVED                |                         | SRC_DST_ID            | SRC_DST_M       |
|                         |                         | DIRECTION             | VALID           |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset    |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x000000 |
| 8:7  | SRC_DST_ID | Individual module register command number.<br>For the modules that only have 2 individual requestors, this field will only display either 0 or 1. For modules that have 4 individual requestors, this field will display 0, 1, 2 or 3.<br><br>Read 0x0: Read / write module requestor #1<br>Read 0x1: Read / write module requestor #2<br>Read 0x2: Read / write module requestor #3<br>Read 0x3: Read / write module requestor #4                                                                                                                                                                                                                                                                | R    | 0x0      |
| 6:2  | SRC_DST_M  | Source or destination module<br><br>Read 0x0: CCDC module output<br>Read 0x1: CCDC module fault pixel correction input<br>Read 0x2: PREVIEW module input<br>Read 0x3: PREVIEW module output<br>Read 0x4: PREVIEW module dark frame subtract input<br>Read 0x5: RESIZER module input<br>Read 0x6: RESIZER module output line 1<br>Read 0x7: RESIZER module output line 2<br>Read 0x8: RESIZER module output line 3<br>Read 0x9: RESIZER module output line 4<br>Read 0xA: HISTOGRAM module input<br>Read 0xB: H3A module output - auto focus<br>Read 0xC: H3A module output - auto exposure and auto white balance<br>Read 0xD: CSI2A module output<br>Read 0xE: CSI1/CCP2B or CSI2C module output | R    | 0x00     |
| 1    | DIRECTION  | Direction<br><br>Read 0x0: Read<br>Read 0x1: Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0        |
| 0    | VALID      | Valid bit<br><br>Read 0x0: Not valid.<br>Read 0x1: Valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0        |

**Table 6-525. Register Call Summary for Register SBL\_GLB\_REG\_4**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-526. SBL\_GLB\_REG\_5**

|                         |                         |                         |                 |                 |           |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|-----------|
| <b>Address Offset</b>   | 0x0000 001C             | <b>Physical Address</b> | 0x480B D21C     | <b>Instance</b> | ISP_SBL   |
| <b>Description</b>      | GLOBAL REGISTER 5       |                         |                 |                 |           |
| <b>Type</b>             | R                       |                         |                 |                 |           |
| 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 | SRC_DST_ID      | SRC_DST_M |
| RESERVED                |                         |                         |                 | DIRECTION       | VALID     |

## Camera ISP Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset    |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x000000 |
| 8:7  | SRC_DST_ID | Individual module register command number.<br>For the modules that only have 2 individual requestors, this field will only display either 0 or 1. For modules that have 4 individual requestors, this field will display 0, 1, 2 or 3.<br><br>Read 0x0: Read / write module requestor #1<br>Read 0x1: Read / write module requestor #2<br>Read 0x2: Read / write module requestor #3<br>Read 0x3: Read / write module requestor #4                                                                                                                                                                                                                                                                | R    | 0x0      |
| 6:2  | SRC_DST_M  | Source or destination module<br><br>Read 0x0: CCDC module output<br>Read 0x1: CCDC module fault pixel correction input<br>Read 0x2: PREVIEW module input<br>Read 0x3: PREVIEW module output<br>Read 0x4: PREVIEW module dark frame subtract input<br>Read 0x5: RESIZER module input<br>Read 0x6: RESIZER module output line 1<br>Read 0x7: RESIZER module output line 2<br>Read 0x8: RESIZER module output line 3<br>Read 0x9: RESIZER module output line 4<br>Read 0xA: HISTOGRAM module input<br>Read 0xB: H3A module output - auto focus<br>Read 0xC: H3A module output - auto exposure and auto white balance<br>Read 0xD: CSI2A module output<br>Read 0xE: CSI1/CCP2B or CSI2C module output | R    | 0x00     |
| 1    | DIRECTION  | Direction<br><br>Read 0x0: Read<br>Read 0x1: Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0        |
| 0    | VALID      | Valid bit<br><br>Read 0x0: Not valid.<br>Read 0x1: Valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0        |

**Table 6-527. Register Call Summary for Register SBL\_GLB\_REG\_5**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-528. SBL\_GLB\_REG\_6**

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| Address Offset          | 0x0000 0020             | Instance              | ISP_SBL         |
| Physical Address        | 0x480B D220             |                       |                 |
| Description             | GLOBAL REGISTER 6       |                       |                 |
| Type                    | R                       |                       |                 |
| 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 |
| RESERVED                |                         | SRC_DST_ID            | SRC_DST_M       |
|                         |                         | DIRECTION             | VALID           |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset    |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x000000 |
| 8:7  | SRC_DST_ID | Individual module register command number.<br>For the modules that only have 2 individual requestors, this field will only display either 0 or 1. For modules that have 4 individual requestors, this field will display 0, 1, 2 or 3.<br><br>Read 0x0: Read / write module requestor #1<br>Read 0x1: Read / write module requestor #2<br>Read 0x2: Read / write module requestor #3<br>Read 0x3: Read / write module requestor #4                                                                                                                                                                                                                                                                | R    | 0x0      |
| 6:2  | SRC_DST_M  | Source or destination module<br><br>Read 0x0: CCDC module output<br>Read 0x1: CCDC module fault pixel correction input<br>Read 0x2: PREVIEW module input<br>Read 0x3: PREVIEW module output<br>Read 0x4: PREVIEW module dark frame subtract input<br>Read 0x5: RESIZER module input<br>Read 0x6: RESIZER module output line 1<br>Read 0x7: RESIZER module output line 2<br>Read 0x8: RESIZER module output line 3<br>Read 0x9: RESIZER module output line 4<br>Read 0xA: HISTOGRAM module input<br>Read 0xB: H3A module output - auto focus<br>Read 0xC: H3A module output - auto exposure and auto white balance<br>Read 0xD: CSI2A module output<br>Read 0xE: CSI1/CCP2B or CSI2C module output | R    | 0x00     |
| 1    | DIRECTION  | Direction<br><br>Read 0x0: Read<br>Read 0x1: Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0        |
| 0    | VALID      | Valid bit<br><br>Read 0x0: Not valid.<br>Read 0x1: Valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0        |

**Table 6-529. Register Call Summary for Register SBL\_GLB\_REG\_6**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-530. SBL\_GLB\_REG\_7**

|                         |                         |                         |                 |                 |           |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|-----------|
| <b>Address Offset</b>   | 0x0000 0024             | <b>Physical Address</b> | 0x480B D224     | <b>Instance</b> | ISP_SBL   |
| <b>Description</b>      | GLOBAL REGISTER 7       |                         |                 |                 |           |
| <b>Type</b>             | R                       |                         |                 |                 |           |
| 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 | SRC_DST_ID      | SRC_DST_M |
| RESERVED                |                         |                         |                 | DIRECTION       | VALID     |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset    |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x000000 |
| 8:7  | SRC_DST_ID | Individual module register command number.<br>For the modules that only have 2 individual requestors, this field will only display either 0 or 1. For modules that have 4 individual requestors, this field will display 0, 1, 2 or 3.<br><br>Read 0x0: Read / write module requestor #1<br>Read 0x1: Read / write module requestor #2<br>Read 0x2: Read / write module requestor #3<br>Read 0x3: Read / write module requestor #4                                                                                                                                                                                                                                                                | R    | 0x0      |
| 6:2  | SRC_DST_M  | Source or destination module<br><br>Read 0x0: CCDC module output<br>Read 0x1: CCDC module fault pixel correction input<br>Read 0x2: PREVIEW module input<br>Read 0x3: PREVIEW module output<br>Read 0x4: PREVIEW module dark frame subtract input<br>Read 0x5: RESIZER module input<br>Read 0x6: RESIZER module output line 1<br>Read 0x7: RESIZER module output line 2<br>Read 0x8: RESIZER module output line 3<br>Read 0x9: RESIZER module output line 4<br>Read 0xA: HISTOGRAM module input<br>Read 0xB: H3A module output - auto focus<br>Read 0xC: H3A module output - auto exposure and auto white balance<br>Read 0xD: CSI2A module output<br>Read 0xE: CSI1/CCP2B or CSI2C module output | R    | 0x00     |
| 1    | DIRECTION  | Direction<br><br>Read 0x0: Read<br>Read 0x1: Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0        |
| 0    | VALID      | Valid bit<br><br>Read 0x0: Not valid.<br>Read 0x1: Valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0        |

**Table 6-531. Register Call Summary for Register SBL\_GLB\_REG\_7**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-532. SBL\_CCDC\_WR\_0**

|                         |                               |                       |                 |            |           |          |      |          |  |  |          |  |  |  |         |  |  |  |  |  |  |  |
|-------------------------|-------------------------------|-----------------------|-----------------|------------|-----------|----------|------|----------|--|--|----------|--|--|--|---------|--|--|--|--|--|--|--|
| Address Offset          | 0x0000 0028                   |                       |                 |            |           |          |      |          |  |  |          |  |  |  |         |  |  |  |  |  |  |  |
| Physical Address        | 0x480B D228                   |                       |                 |            |           |          |      |          |  |  | Instance |  |  |  | ISP_SBL |  |  |  |  |  |  |  |
| Description             | CCDC WRITE REQUEST 1 REGISTER |                       |                 |            |           |          |      |          |  |  |          |  |  |  |         |  |  |  |  |  |  |  |
| Type                    | R                             |                       |                 |            |           |          |      |          |  |  |          |  |  |  |         |  |  |  |  |  |  |  |
| 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 | DATA_READY | DATA_SENT | BYTE_CNT | ADDR | RESERVED |  |  |          |  |  |  |         |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                    | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                        | R    | 0x00    |
| 21    | DATA_READY | Data ready<br><br>Read 0x0: No<br><br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br><br>Read 0x0: No<br><br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                        | R    | 0x00000 |

**Table 6-533. Register Call Summary for Register SBL\_CCDC\_WR\_0**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-534. SBL\_CCDC\_WR\_1**

|                         |                               |                         |                 |         |
|-------------------------|-------------------------------|-------------------------|-----------------|---------|
| Address Offset          | 0x0000 002C                   |                         | Instance        | ISP_SBL |
| Physical Address        | <a href="#">0x480B D22C</a>   |                         |                 |         |
| Description             | CCDC WRITE REQUEST 2 REGISTER |                         |                 |         |
| Type                    | R                             |                         |                 |         |
| 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 |         |
| RESERVED                | BYTE_CNT                      | DATA_READY<br>DATA_SENT | ADDR            |         |

| Bits  | Field Name | Description                                                                                | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                    | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                        | R    | 0x00    |
| 21    | DATA_READY | Data ready<br><br>Read 0x0: No<br><br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br><br>Read 0x0: No<br><br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                        | R    | 0x00000 |

**Table 6-535. Register Call Summary for Register SBL\_CCDC\_WR\_1**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-536. SBL\_CCDC\_WR\_2**

|                         |                               |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0030                   |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D230                   |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | CCDC WRITE REQUEST 3 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                      | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-537. Register Call Summary for Register SBL\_CCDC\_WR\_2**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-538. SBL\_CCDC\_WR\_3**

|                         |                               |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0034                   |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D234                   |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | CCDC WRITE REQUEST 4 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                      | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                             | Type | Reset |
|-------|------------|---------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0x0   |
| 29:22 | BYTE_CNT   | Current byte count.                                     | R    | 0x00  |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes             | R    | 0     |

| Bits | Field Name | Description                                                                        | Type | Reset   |
|------|------------|------------------------------------------------------------------------------------|------|---------|
| 20   | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0 | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-539. Register Call Summary for Register SBL\_CCDC\_WR\_3**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-540. SBL\_CCDC\_FP\_RD\_0**

|                         |       |                                                     |          |                 |         |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|-------|-----------------------------------------------------|----------|-----------------|---------|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   |       | 0x0000 0038                                         |          | <b>Instance</b> | ISP_SBL |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> |       | 0x480B D238                                         |          |                 |         |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      |       | CCDC FAULT PIXEL CORRECTION READ REQUEST 1 REGISTER |          |                 |         |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             |       | R                                                   |          |                 |         |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                | VALID | DATA_WAIT                                           | DATA_AVL | BYTE_CNT        |         |    |    |    |    |    |    | ADDR |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                          | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------|------|---------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                              | R    | 0       |
| 30    | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes                                                           | R    | 0       |
| 29    | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0       |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                   | R    | 0x00000 |

**Table 6-541. Register Call Summary for Register SBL\_CCDC\_FP\_RD\_0**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-542. SBL\_CCDC\_FP\_RD\_1**

|                  |       |           |          |          |    |    |    |    |    |    |    |                                                     |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
|------------------|-------|-----------|----------|----------|----|----|----|----|----|----|----|-----------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---------|---|---|---|---|---|---|--|
| Address Offset   |       |           |          |          |    |    |    |    |    |    |    | 0x0000 003C                                         |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
| Physical Address |       |           |          |          |    |    |    |    |    |    |    | 0x480B D23C                                         |    |    |    |    |    |    |    |    |    |   |   | Instance | ISP_SBL |   |   |   |   |   |   |  |
| Description      |       |           |          |          |    |    |    |    |    |    |    | CCDC FAULT PIXEL CORRECTION READ REQUEST 2 REGISTER |    |    |    |    |    |    |    |    |    |   |   | Type     | R       |   |   |   |   |   |   |  |
| Type             |       |           |          |          |    |    |    |    |    |    |    | R                                                   |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
| 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 |  |
| RESERVED         | VALID | DATA_WAIT | DATA_AVL | BYTE_CNT |    |    |    |    |    |    |    | ADDR                                                |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                                                                                          | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------|------|---------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                              | R    | 0       |
| 30    | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes                                                           | R    | 0       |
| 29    | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0       |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                   | R    | 0x00000 |

**Table 6-543. Register Call Summary for Register SBL\_CCDC\_FP\_RD\_1**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-544. SBL\_PRV\_RD\_0**

|                  |       |           |          |          |    |    |    |    |    |    |    |                                 |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
|------------------|-------|-----------|----------|----------|----|----|----|----|----|----|----|---------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---------|---|---|---|---|---|---|--|
| Address Offset   |       |           |          |          |    |    |    |    |    |    |    | 0x0000 0040                     |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
| Physical Address |       |           |          |          |    |    |    |    |    |    |    | 0x480B D240                     |    |    |    |    |    |    |    |    |    |   |   | Instance | ISP_SBL |   |   |   |   |   |   |  |
| Description      |       |           |          |          |    |    |    |    |    |    |    | PREVIEW READ REQUEST 1 REGISTER |    |    |    |    |    |    |    |    |    |   |   | Type     | R       |   |   |   |   |   |   |  |
| Type             |       |           |          |          |    |    |    |    |    |    |    | R                               |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
| 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 |  |
| RESERVED         | VALID | DATA_WAIT | DATA_AVL | BYTE_CNT |    |    |    |    |    |    |    | ADDR                            |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |

| Bits | Field Name | Description                                                                                          | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------|------|-------|
| 31   | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                              | R    | 0     |
| 30   | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes                                                           | R    | 0     |
| 29   | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0     |
| 28   | DATA_AVL   | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------|-------------|--------------|
| 29          | DATA_WAIT         | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R           | 0            |
| 28          | DATA_AVL          | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R           | 0            |
| 27:20       | BYTE_CNT          | Byte count requested.                                                                                | R           | 0x00         |
| 19:0        | ADDR              | Upper 20 bits of the read address.                                                                   | R           | 0x000000     |

**Table 6-545. Register Call Summary for Register SBL\_PRV\_RD\_0**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-546. SBL\_PRV\_RD\_1**

| Bits  | Field Name | Description                                                                                                  | Type | Reset    |
|-------|------------|--------------------------------------------------------------------------------------------------------------|------|----------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                                      | R    | 0        |
| 30    | VALID      | Valid bit<br><br>Read 0x0: No<br><br>Read 0x1: Yes                                                           | R    | 0        |
| 29    | DATA_WAIT  | Waiting for data<br><br>Read 0x0: No<br><br>Read 0x1: Yes                                                    | R    | 0        |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br><br>Read 0x0: No<br><br>Read 0x1: Yes | R    | 0        |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                        | R    | 0x00     |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                           | R    | 0x000000 |

**Table 6-547. Register Call Summary for Register SBL\_PRV\_RD\_1**

---

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-548. SBL\_PRV\_RD\_2**

|                  |       |           |          |          |    |    |    |    |    |    |    |                                 |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
|------------------|-------|-----------|----------|----------|----|----|----|----|----|----|----|---------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|--|
| Address Offset   |       |           |          |          |    |    |    |    |    |    |    | 0x0000 0048                     |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
| Physical Address |       |           |          |          |    |    |    |    |    |    |    | 0x480B D248                     |    |    |    |    |    |    |    |    |    |   |   | Instance |   |   |   |   |   |   |   |  |
| Description      |       |           |          |          |    |    |    |    |    |    |    | PREVIEW READ REQUEST 3 REGISTER |    |    |    |    |    |    |    |    |    |   |   | ISP_SBL  |   |   |   |   |   |   |   |  |
| Type             |       |           |          |          |    |    |    |    |    |    |    | R                               |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
| 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 |  |
| RESERVED         | VALID | DATA_WAIT | DATA_AVL | BYTE_CNT |    |    |    |    |    |    |    | ADDR                            |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                                                                                          | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------|------|---------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                              | R    | 0       |
| 30    | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes                                                           | R    | 0       |
| 29    | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0       |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                   | R    | 0x00000 |

**Table 6-549. Register Call Summary for Register SBL\_PRV\_RD\_2**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-550. SBL\_PRV\_RD\_3**

|                  |       |           |          |          |    |    |    |    |    |    |    |                                 |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
|------------------|-------|-----------|----------|----------|----|----|----|----|----|----|----|---------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|--|
| Address Offset   |       |           |          |          |    |    |    |    |    |    |    | 0x0000 004C                     |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
| Physical Address |       |           |          |          |    |    |    |    |    |    |    | 0x480B D24C                     |    |    |    |    |    |    |    |    |    |   |   | Instance |   |   |   |   |   |   |   |  |
| Description      |       |           |          |          |    |    |    |    |    |    |    | PREVIEW READ REQUEST 4 REGISTER |    |    |    |    |    |    |    |    |    |   |   | ISP_SBL  |   |   |   |   |   |   |   |  |
| Type             |       |           |          |          |    |    |    |    |    |    |    | R                               |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
| 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 |  |
| RESERVED         | VALID | DATA_WAIT | DATA_AVL | BYTE_CNT |    |    |    |    |    |    |    | ADDR                            |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                                             | Type | Reset   |
|-------|------------|---------------------------------------------------------|------|---------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0       |
| 30    | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes              | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                   | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                      | R    | 0x00000 |

| Bits  | Field Name | Description                                                                                          | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------|------|---------|
| 29    | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0       |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                   | R    | 0x00000 |

**Table 6-551. Register Call Summary for Register SBL\_PRV\_RD\_3**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-552. SBL\_PRV\_WR\_0**

|                         |                                  |                         |                 |         |
|-------------------------|----------------------------------|-------------------------|-----------------|---------|
| Address Offset          | 0x0000 0050                      |                         | Instance        | ISP_SBL |
| Physical Address        | 0x480B D250                      |                         |                 |         |
| Description             | PREVIEW WRITE REQUEST 1 REGISTER |                         |                 |         |
| Type                    | R                                |                         |                 |         |
| 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 |         |
| RESERVED                | BYTE_CNT                         | DATA_READY<br>DATA_SENT | ADDR            |         |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-553. Register Call Summary for Register SBL\_PRV\_WR\_0**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-554. SBL\_PRV\_WR\_1**

|                         |                                  |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0054                      |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D254                      |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | PREVIEW WRITE REQUEST 2 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                         | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-555. Register Call Summary for Register SBL\_PRV\_WR\_1**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-556. SBL\_PRV\_WR\_2**

|                         |                                  |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0058                      |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D258                      |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | PREVIEW WRITE REQUEST 3 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                         | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                             | Type | Reset |
|-------|------------|---------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0x0   |
| 29:22 | BYTE_CNT   | Current byte count.                                     | R    | 0x00  |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes             | R    | 0     |

| Bits | Field Name | Description                                                                            | Type | Reset   |
|------|------------|----------------------------------------------------------------------------------------|------|---------|
| 20   | DATA_SENT  | Data sent to the destination, waiting for status.<br><br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0 | ADDR       | Upper 20 bits of the write address.                                                    | R    | 0x00000 |

**Table 6-557. Register Call Summary for Register SBL\_PRV\_WR\_2**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-558. SBL\_PRV\_WR\_3**

|                         |                                  |                         |                 |         |
|-------------------------|----------------------------------|-------------------------|-----------------|---------|
| Address Offset          | 0x0000 005C                      |                         | Instance        | ISP_SBL |
| Physical Address        | 0x480B D25C                      |                         |                 |         |
| Description             | PREVIEW WRITE REQUEST 4 REGISTER |                         |                 |         |
| Type                    | R                                |                         |                 |         |
| 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 |         |
| RESERVED                | BYTE_CNT                         | DATA_READY<br>DATA_SENT | ADDR            |         |

| Bits  | Field Name | Description                                                                            | Type | Reset   |
|-------|------------|----------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                    | R    | 0x00    |
| 21    | DATA_READY | Data ready<br><br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br><br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                    | R    | 0x00000 |

**Table 6-559. Register Call Summary for Register SBL\_PRV\_WR\_3**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-560. SBL\_PRV\_DK\_RD\_0**

|                  |                                            |  |          |         |
|------------------|--------------------------------------------|--|----------|---------|
| Address Offset   | 0x0000 0060                                |  | Instance | ISP_SBL |
| Physical Address | 0x480B D260                                |  |          |         |
| Description      | PREVIEW DARK FRAME READ REQUEST 1 REGISTER |  |          |         |
| Type             | R                                          |  |          |         |

| 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 |  |  |  |  |  |  |  |
|-------------------------|-------|-----------|----------|----------|--|--|--|-------------------------|--|--|--|------|--|--|--|-----------------------|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|
| RESERVED                | VALID | DATA_WAIT | DATA_AVL | BYTE_CNT |  |  |  |                         |  |  |  | ADDR |  |  |  |                       |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                          | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------|------|---------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                              | R    | 0       |
| 30    | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes                                                           | R    | 0       |
| 29    | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0       |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                   | R    | 0x00000 |

**Table 6-561. Register Call Summary for Register SBL\_PRV\_DK\_RD\_0**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-562. SBL\_PRV\_DK\_RD\_1**

|                  |                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|--------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 0064                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | 0x480B D264                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | PREVIEW DARK FRAME READ REQUEST 2 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | R                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |  |  |  |  |  |  |  |
|-------------------------|-------|-----------|----------|----------|--|--|--|-------------------------|--|--|--|------|--|--|--|-----------------------|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|
| RESERVED                | VALID | DATA_WAIT | DATA_AVL | BYTE_CNT |  |  |  |                         |  |  |  | ADDR |  |  |  |                       |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                             | Type | Reset |
|------|------------|---------------------------------------------------------|------|-------|
| 31   | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0     |
| 30   | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes              | R    | 0     |
| 29   | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes       | R    | 0     |

| Bits  | Field Name | Description                                                                                              | Type | Reset   |
|-------|------------|----------------------------------------------------------------------------------------------------------|------|---------|
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br><br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                    | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                       | R    | 0x00000 |

**Table 6-563. Register Call Summary for Register SBL\_PRV\_DK\_RD\_1**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-564. SBL\_PRV\_DK\_RD\_2**

|                  |                                            |           |          |          |    |    |    |    |    |    |    |      |    |    |    |    |    |    |          |    |    |   |   |   |         |   |   |   |   |   |   |
|------------------|--------------------------------------------|-----------|----------|----------|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----------|----|----|---|---|---|---------|---|---|---|---|---|---|
| Address Offset   | 0x0000 0068                                |           |          |          |    |    |    |    |    |    |    |      |    |    |    |    |    |    |          |    |    |   |   |   |         |   |   |   |   |   |   |
| Physical Address | 0x480B D268                                |           |          |          |    |    |    |    |    |    |    |      |    |    |    |    |    |    | Instance |    |    |   |   |   | ISP_SBL |   |   |   |   |   |   |
| Description      | PREVIEW DARK FRAME READ REQUEST 3 REGISTER |           |          |          |    |    |    |    |    |    |    |      |    |    |    |    |    |    |          |    |    |   |   |   |         |   |   |   |   |   |   |
| Type             | R                                          |           |          |          |    |    |    |    |    |    |    |      |    |    |    |    |    |    |          |    |    |   |   |   |         |   |   |   |   |   |   |
| 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 |
| RESERVED         | VALID                                      | DATA_WAIT | DATA_AVL | BYTE_CNT |    |    |    |    |    |    |    | ADDR |    |    |    |    |    |    |          |    |    |   |   |   |         |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                              | Type | Reset   |
|-------|------------|----------------------------------------------------------------------------------------------------------|------|---------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                                  | R    | 0       |
| 30    | VALID      | Valid bit<br><br>Read 0x0: No<br>Read 0x1: Yes                                                           | R    | 0       |
| 29    | DATA_WAIT  | Waiting for data<br><br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0       |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br><br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                    | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                       | R    | 0x00000 |

**Table 6-565. Register Call Summary for Register SBL\_PRV\_DK\_RD\_2**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-566. SBL\_PRV\_DK\_RD\_3**

|                  |       |           |          |          |    |    |    |    |    |    |    |                                            |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
|------------------|-------|-----------|----------|----------|----|----|----|----|----|----|----|--------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|--|
| Address Offset   |       |           |          |          |    |    |    |    |    |    |    | 0x0000 006C                                |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
| Physical Address |       |           |          |          |    |    |    |    |    |    |    | 0x480B D26C                                |    |    |    |    |    |    |    |    |    |   |   | Instance |   |   |   |   |   |   |   |  |
| Description      |       |           |          |          |    |    |    |    |    |    |    | PREVIEW DARK FRAME READ REQUEST 4 REGISTER |    |    |    |    |    |    |    |    |    |   |   | ISP_SBL  |   |   |   |   |   |   |   |  |
| Type             |       |           |          |          |    |    |    |    |    |    |    | R                                          |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
| 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 |  |
| RESERVED         | VALID | DATA_WAIT | DATA_AVL | BYTE_CNT |    |    |    |    |    |    |    | ADDR                                       |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                                                                                          | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------|------|---------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                              | R    | 0       |
| 30    | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes                                                           | R    | 0       |
| 29    | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0       |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                   | R    | 0x00000 |

**Table 6-567. Register Call Summary for Register SBL\_PRV\_DK\_RD\_3**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-568. SBL\_RSZ\_RD\_0**

|                  |       |           |          |          |    |    |    |    |    |    |    |                                 |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
|------------------|-------|-----------|----------|----------|----|----|----|----|----|----|----|---------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|--|
| Address Offset   |       |           |          |          |    |    |    |    |    |    |    | 0x0000 0070                     |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
| Physical Address |       |           |          |          |    |    |    |    |    |    |    | 0x480B D270                     |    |    |    |    |    |    |    |    |    |   |   | Instance |   |   |   |   |   |   |   |  |
| Description      |       |           |          |          |    |    |    |    |    |    |    | RESIZER READ REQUEST 1 REGISTER |    |    |    |    |    |    |    |    |    |   |   | ISP_SBL  |   |   |   |   |   |   |   |  |
| Type             |       |           |          |          |    |    |    |    |    |    |    | R                               |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
| 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 |  |
| RESERVED         | VALID | DATA_WAIT | DATA_AVL | BYTE_CNT |    |    |    |    |    |    |    | ADDR                            |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                                             | Type | Reset   |
|-------|------------|---------------------------------------------------------|------|---------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0       |
| 30    | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes              | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                   | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                      | R    | 0x00000 |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------|-------------|--------------|
| 29          | DATA_WAIT         | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R           | 0            |
| 28          | DATA_AVL          | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R           | 0            |
| 27:20       | BYTE_CNT          | Byte count requested.                                                                                | R           | 0x00         |
| 19:0        | ADDR              | Upper 20 bits of the read address.                                                                   | R           | 0x000000     |

**Table 6-569. Register Call Summary for Register SBL\_RSZ\_RD\_0**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-570. SBL\_RSZ\_RD\_1**

| Bits  | Field Name | Description                                                                                                  | Type | Reset    |
|-------|------------|--------------------------------------------------------------------------------------------------------------|------|----------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                                      | R    | 0        |
| 30    | VALID      | Valid bit<br><br>Read 0x0: No<br><br>Read 0x1: Yes                                                           | R    | 0        |
| 29    | DATA_WAIT  | Waiting for data<br><br>Read 0x0: No<br><br>Read 0x1: Yes                                                    | R    | 0        |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br><br>Read 0x0: No<br><br>Read 0x1: Yes | R    | 0        |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                        | R    | 0x00     |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                           | R    | 0x000000 |

**Table 6-571. Register Call Summary for Register SBL\_RSZ\_RD\_1**

---

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-572. SBL\_RSZ\_RD\_2**

|                  |       |           |          |          |    |    |    |    |    |    |    |                                 |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
|------------------|-------|-----------|----------|----------|----|----|----|----|----|----|----|---------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---------|---|---|---|---|---|---|--|
| Address Offset   |       |           |          |          |    |    |    |    |    |    |    | 0x0000 0078                     |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
| Physical Address |       |           |          |          |    |    |    |    |    |    |    | 0x480B D278                     |    |    |    |    |    |    |    |    |    |   |   | Instance | ISP_SBL |   |   |   |   |   |   |  |
| Description      |       |           |          |          |    |    |    |    |    |    |    | RESIZER READ REQUEST 3 REGISTER |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
| Type             |       |           |          |          |    |    |    |    |    |    |    | R                               |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
| 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 |  |
| RESERVED         | VALID | DATA_WAIT | DATA_AVL | BYTE_CNT |    |    |    |    |    |    |    | ADDR                            |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                                                                                          | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------|------|---------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                              | R    | 0       |
| 30    | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes                                                           | R    | 0       |
| 29    | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0       |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                   | R    | 0x00000 |

**Table 6-573. Register Call Summary for Register SBL\_RSZ\_RD\_2**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-574. SBL\_RSZ\_RD\_3**

|                  |       |           |          |          |    |    |    |    |    |    |    |                                 |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
|------------------|-------|-----------|----------|----------|----|----|----|----|----|----|----|---------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---------|---|---|---|---|---|---|--|
| Address Offset   |       |           |          |          |    |    |    |    |    |    |    | 0x0000 007C                     |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
| Physical Address |       |           |          |          |    |    |    |    |    |    |    | 0x480B D27C                     |    |    |    |    |    |    |    |    |    |   |   | Instance | ISP_SBL |   |   |   |   |   |   |  |
| Description      |       |           |          |          |    |    |    |    |    |    |    | RESIZER READ REQUEST 4 REGISTER |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
| Type             |       |           |          |          |    |    |    |    |    |    |    | R                               |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |
| 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 |  |
| RESERVED         | VALID | DATA_WAIT | DATA_AVL | BYTE_CNT |    |    |    |    |    |    |    | ADDR                            |    |    |    |    |    |    |    |    |    |   |   |          |         |   |   |   |   |   |   |  |

| Bits | Field Name | Description                                                                                          | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------|------|-------|
| 31   | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                              | R    | 0     |
| 30   | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes                                                           | R    | 0     |
| 29   | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0     |
| 28   | DATA_AVL   | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0     |

| Bits  | Field Name | Description                                                                                          | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------|------|---------|
| 29    | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0       |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                   | R    | 0x00000 |

**Table 6-575. Register Call Summary for Register SBL\_RSZ\_RD\_3**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-576. SBL\_RSZ1\_WR\_0**

|                  |                         |                         |                       |                                         |
|------------------|-------------------------|-------------------------|-----------------------|-----------------------------------------|
| Address Offset   | 0x0000 0080             |                         | Instance              | ISP_SBL                                 |
| Physical Address | 0x480B D280             |                         | Description           | RESIZER LINE 1 WRITE REQUEST 1 REGISTER |
| Type             | R                       |                         |                       |                                         |
|                  | 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                         |
| RESERVED         | BYTE_CNT                | DATA_READY<br>DATA_SENT | ADDR                  |                                         |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-577. Register Call Summary for Register SBL\_RSZ1\_WR\_0**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-578. SBL\_RSZ1\_WR\_1**

|                         |                                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0084                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D284                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RESIZER LINE 1 WRITE REQUEST 2 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                       |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                                | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-579. Register Call Summary for Register SBL\_RSZ1\_WR\_1**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-580. SBL\_RSZ1\_WR\_2**

|                         |                                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0088                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D288                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RESIZER LINE 1 WRITE REQUEST 3 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                       |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                                | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                             | Type | Reset |
|-------|------------|---------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0x0   |
| 29:22 | BYTE_CNT   | Current byte count.                                     | R    | 0x00  |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes             | R    | 0     |

| Bits | Field Name | Description                                                                            | Type | Reset   |
|------|------------|----------------------------------------------------------------------------------------|------|---------|
| 20   | DATA_SENT  | Data sent to the destination, waiting for status.<br><br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0 | ADDR       | Upper 20 bits of the write address.                                                    | R    | 0x00000 |

**Table 6-581. Register Call Summary for Register SBL\_RSZ1\_WR\_2**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-582. SBL\_RSZ1\_WR\_3**

|                         |                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 008C                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D28C                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RESIZER LINE 1 WRITE REQUEST 4 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                         |                 |
|-------------------------|-------------------------|-------------------------|-----------------|
| 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 |
| RESERVED                | BYTE_CNT                | DATA_READY<br>DATA_SENT | ADDR            |

| Bits  | Field Name | Description                                                                            | Type | Reset   |
|-------|------------|----------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                    | R    | 0x00    |
| 21    | DATA_READY | Data ready<br><br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br><br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                    | R    | 0x00000 |

**Table 6-583. Register Call Summary for Register SBL\_RSZ1\_WR\_3**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-584. SBL\_RSZ2\_WR\_0**

|                         |                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0090                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D290                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RESIZER LINE 2 WRITE REQUEST 1 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-585. Register Call Summary for Register SBL\_RSZ2\_WR\_0**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-586. SBL\_RSZ2\_WR\_1**

|                         |                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0094                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D294                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RESIZER LINE 2 WRITE REQUEST 2 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-587. Register Call Summary for Register SBL\_RSZ2\_WR\_1**

- Camera ISP Register Manual
- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-588. SBL\_RSZ2\_WR\_2**

|                         |                                         |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|---------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0098                             |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D298                             |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_SBL |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RESIZER LINE 2 WRITE REQUEST 3 REGISTER |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                       |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                    | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                        | R    | 0x00    |
| 21    | DATA_READY | Data ready<br><br>Read 0x0: No<br><br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br><br>Read 0x0: No<br><br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                        | R    | 0x00000 |

**Table 6-589. Register Call Summary for Register SBL\_RSZ2\_WR\_2**

- Camera ISP Register Manual
- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-590. SBL\_RSZ2\_WR\_3**

|                         |                                         |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|---------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 009C                             |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D29C                             |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | ISP_SBL |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RESIZER LINE 2 WRITE REQUEST 4 REGISTER |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                       |  |  |  |  |  |  |  |  |  |  |  |                 |         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                             | Type | Reset |
|-------|------------|---------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0x0   |
| 29:22 | BYTE_CNT   | Current byte count.                                     | R    | 0x00  |

## Camera ISP Register Manual

www.ti.com

| Bits | Field Name | Description                                                                        | Type | Reset   |
|------|------------|------------------------------------------------------------------------------------|------|---------|
| 21   | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20   | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0 | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-591. Register Call Summary for Register SBL\_RSZ2\_WR\_3**

## Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-592. SBL\_RSZ3\_WR\_0**

|                         |                                         |                         |                 |         |
|-------------------------|-----------------------------------------|-------------------------|-----------------|---------|
| Address Offset          | 0x0000 00A0                             |                         |                 |         |
| Physical Address        | 0x480B D2A0                             |                         | Instance        | ISP_SBL |
| Description             | RESIZER LINE 3 WRITE REQUEST 1 REGISTER |                         |                 |         |
| Type                    | R                                       |                         |                 |         |
| 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 |         |
| RESERVED                | BYTE_CNT                                | DATA_READY<br>DATA_SENT | ADDR            |         |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-593. Register Call Summary for Register SBL\_RSZ3\_WR\_0**

## Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-594. SBL\_RSZ3\_WR\_1**

|                         |                                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00A4                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D2A4                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RESIZER LINE 3 WRITE REQUEST 2 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                       |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                                | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-595. Register Call Summary for Register SBL\_RSZ3\_WR\_1**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-596. SBL\_RSZ3\_WR\_2**

|                         |                                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00A8                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D2A8                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RESIZER LINE 3 WRITE REQUEST 3 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                       |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                                | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                             | Type | Reset |
|-------|------------|---------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0x0   |
| 29:22 | BYTE_CNT   | Current byte count.                                     | R    | 0x00  |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes             | R    | 0     |

| Bits | Field Name | Description                                                                        | Type | Reset   |
|------|------------|------------------------------------------------------------------------------------|------|---------|
| 20   | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0 | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-597. Register Call Summary for Register SBL\_RSZ3\_WR\_2**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-598. SBL\_RSZ3\_WR\_3**

|                  |                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 00AC                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | 0x480B D2AC                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | RESIZER LINE 3 WRITE REQUEST 4 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | R                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                         |                 |
|-------------------------|-------------------------|-------------------------|-----------------|
| 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 |
| RESERVED                | BYTE_CNT                | DATA_READY<br>DATA_SENT | ADDR            |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-599. Register Call Summary for Register SBL\_RSZ3\_WR\_3**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-600. SBL\_RSZ4\_WR\_0**

|                  |                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 00B0                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | 0x480B D2B0                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | RESIZER LINE 4 WRITE REQUEST 1 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | R                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |          |            |           |      |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------|----------|------------|-----------|------|--|--|--|--|--|--|--|--|--|--|--|--|
| RESERVED                                                                                    | BYTE_CNT | DATA_READY | DATA_SENT | ADDR |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                             |          |            |           |      |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-601. Register Call Summary for Register SBL\_RSZ4\_WR\_0**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-602. SBL\_RSZ4\_WR\_1**

|                |                                         |                  |             |          |         |
|----------------|-----------------------------------------|------------------|-------------|----------|---------|
| Address Offset | 0x0000 00B4                             | Physical Address | 0x480B D2B4 | Instance | ISP_SBL |
| Description    | RESIZER LINE 4 WRITE REQUEST 2 REGISTER |                  |             |          |         |
| Type           | R                                       |                  |             |          |         |

| 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 |          |            |           |      |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------|----------|------------|-----------|------|--|--|--|--|--|--|--|--|--|--|--|--|
| RESERVED                                                                                    | BYTE_CNT | DATA_READY | DATA_SENT | ADDR |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                             |          |            |           |      |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-603. Register Call Summary for Register SBL\_RSZ4\_WR\_1**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-604. SBL\_RSZ4\_WR\_2**

|                         |                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00B8                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D2B8                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RESIZER LINE 4 WRITE REQUEST 3 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                    | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                        | R    | 0x00    |
| 21    | DATA_READY | Data ready<br><br>Read 0x0: No<br><br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br><br>Read 0x0: No<br><br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                        | R    | 0x00000 |

**Table 6-605. Register Call Summary for Register SBL\_RSZ4\_WR\_2**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-606. SBL\_RSZ4\_WR\_3**

|                         |                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00BC                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D2BC                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | RESIZER LINE 4 WRITE REQUEST 4 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                             | Type | Reset |
|-------|------------|---------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0x0   |
| 29:22 | BYTE_CNT   | Current byte count.                                     | R    | 0x00  |

| Bits | Field Name | Description                                                                        | Type | Reset   |
|------|------------|------------------------------------------------------------------------------------|------|---------|
| 21   | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20   | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0 | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-607. Register Call Summary for Register SBL\_RSZ4\_WR\_3**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-608. SBL\_HIST\_RD\_0**

|                         |       |             |          |                                                                                 |  |  |
|-------------------------|-------|-------------|----------|---------------------------------------------------------------------------------|--|--|
| <b>Address Offset</b>   |       | 0x0000 00C0 |          |                                                                                 |  |  |
| <b>Physical Address</b> |       | 0x480B D2C0 |          | <b>Instance</b>                                                                 |  |  |
| <b>Description</b>      |       |             |          | ISP_SBL                                                                         |  |  |
| <b>Type</b>             |       |             |          | R                                                                               |  |  |
| 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 |  |  |
| RESERVED                | VALID | DATA_WAIT   | DATA_AVL | BYTE_CNT ADDR                                                                   |  |  |

| Bits  | Field Name | Description                                                                                          | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------|------|---------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                              | R    | 0       |
| 30    | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes                                                           | R    | 0       |
| 29    | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0       |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                   | R    | 0x00000 |

**Table 6-609. Register Call Summary for Register SBL\_HIST\_RD\_0**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-610. SBL\_HIST\_RD\_1**

|                  |       |           |          |          |    |    |    |    |    |    |    |                                   |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
|------------------|-------|-----------|----------|----------|----|----|----|----|----|----|----|-----------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|--|
| Address Offset   |       |           |          |          |    |    |    |    |    |    |    | 0x0000 00C4                       |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
| Physical Address |       |           |          |          |    |    |    |    |    |    |    | 0x480B D2C4                       |    |    |    |    |    |    |    |    |    |   |   | Instance |   |   |   |   |   |   |   |  |
| Description      |       |           |          |          |    |    |    |    |    |    |    | HISTOGRAM READ REQUEST 2 REGISTER |    |    |    |    |    |    |    |    |    |   |   | ISP_SBL  |   |   |   |   |   |   |   |  |
| Type             |       |           |          |          |    |    |    |    |    |    |    | R                                 |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
| 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 |  |
| RESERVED         | VALID | DATA_WAIT | DATA_AVL | BYTE_CNT |    |    |    |    |    |    |    | ADDR                              |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                                                                                          | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------|------|---------|
| 31    | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                              | R    | 0       |
| 30    | VALID      | Valid bit<br>Read 0x0: No<br>Read 0x1: Yes                                                           | R    | 0       |
| 29    | DATA_WAIT  | Waiting for data<br>Read 0x0: No<br>Read 0x1: Yes                                                    | R    | 0       |
| 28    | DATA_AVL   | Data available. Received from source and can be read by the module.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 27:20 | BYTE_CNT   | Byte count requested.                                                                                | R    | 0x00    |
| 19:0  | ADDR       | Upper 20 bits of the read address.                                                                   | R    | 0x00000 |

**Table 6-611. Register Call Summary for Register SBL\_HIST\_RD\_1**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-612. SBL\_H3A\_AF\_WR\_0**

|                  |          |    |    |    |    |    |    |    |            |           |      |                                 |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
|------------------|----------|----|----|----|----|----|----|----|------------|-----------|------|---------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|
| Address Offset   |          |    |    |    |    |    |    |    |            |           |      | 0x0000 00C8                     |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
| Physical Address |          |    |    |    |    |    |    |    |            |           |      | 0x480B D2C8                     |    |    |    |    |    |    |    |    |    |   |   | Instance |   |   |   |   |   |   |   |
| Description      |          |    |    |    |    |    |    |    |            |           |      | H3A AF WRITE REQUEST 1 REGISTER |    |    |    |    |    |    |    |    |    |   |   | ISP_SBL  |   |   |   |   |   |   |   |
| Type             |          |    |    |    |    |    |    |    |            |           |      | R                               |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
| 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 |
| RESERVED         | BYTE_CNT |    |    |    |    |    |    |    | DATA_READY | DATA_SENT | ADDR |                                 |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                             | Type | Reset |
|-------|------------|---------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0x0   |
| 29:22 | BYTE_CNT   | Current byte count.                                     | R    | 0x00  |

| Bits | Field Name | Description                                                                        | Type | Reset   |
|------|------------|------------------------------------------------------------------------------------|------|---------|
| 21   | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20   | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0 | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-613. Register Call Summary for Register SBL\_H3A\_AF\_WR\_0**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-614. SBL\_H3A\_AF\_WR\_1**

|                         |                                 |                         |                 |         |
|-------------------------|---------------------------------|-------------------------|-----------------|---------|
| Address Offset          | 0x0000 00CC                     |                         | Instance        | ISP_SBL |
| Physical Address        | 0x480B D2CC                     |                         |                 |         |
| Description             | H3A AF WRITE REQUEST 2 REGISTER |                         |                 |         |
| Type                    | R                               |                         |                 |         |
| 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 |         |
| RESERVED                | BYTE_CNT                        | DATA_READY<br>DATA_SENT | ADDR            |         |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-615. Register Call Summary for Register SBL\_H3A\_AF\_WR\_1**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-616. SBL\_H3A\_AEAWB\_WR\_0**

|                         |                                     |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00D0                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D2D0                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | H3A AE AWB WRITE REQUEST 1 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                   |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                            | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-617. Register Call Summary for Register SBL\_H3A\_AEAWB\_WR\_0**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-618. SBL\_H3A\_AEAWB\_WR\_1**

|                         |                                     |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00D4                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D2D4                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | H3A AE AWB WRITE REQUEST 2 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                   |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                            | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                             | Type | Reset |
|-------|------------|---------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0x0   |
| 29:22 | BYTE_CNT   | Current byte count.                                     | R    | 0x00  |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes             | R    | 0     |

| Bits | Field Name | Description                                                                                | Type | Reset   |
|------|------------|--------------------------------------------------------------------------------------------|------|---------|
| 20   | DATA_SENT  | Data sent to the destination, waiting for status.<br><br>Read 0x0: No<br><br>Read 0x1: Yes | R    | 0       |
| 19:0 | ADDR       | Upper 20 bits of the write address.                                                        | R    | 0x00000 |

**Table 6-619. Register Call Summary for Register SBL\_H3A\_AEAWB\_WR\_1**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-620. SBL\_CSIA\_WR\_0**

|                         |                               |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset          | 0x0000 00D8                   |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address        | 0x480B D2D8                   |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| Description             | CSIA WRITE REQUEST 1 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                    | R                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                      | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                    | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                        | R    | 0x00    |
| 21    | DATA_READY | Data ready<br><br>Read 0x0: No<br><br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br><br>Read 0x0: No<br><br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                        | R    | 0x00000 |

**Table 6-621. Register Call Summary for Register SBL\_CSIA\_WR\_0**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-622. SBL\_CSIA\_WR\_1**

|                  |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|-------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 00DC                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | 0x480B D2DC                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | CSIA WRITE REQUEST 2 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | R                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-623. Register Call Summary for Register SBL\_CSIA\_WR\_1**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-624. SBL\_CSIA\_WR\_2**

|                         |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00E0                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D2E0                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | CSIA WRITE REQUEST 3 REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-625. Register Call Summary for Register SBL\_CSIA\_WR\_2**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-626. SBL\_CSIA\_WR\_3**

|                       |                               |  |                         |             |                 |         |
|-----------------------|-------------------------------|--|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 00E4                   |  | <b>Physical Address</b> | 0x480B D2E4 | <b>Instance</b> | ISP_SBL |
| <b>Description</b>    | CSIA WRITE REQUEST 4 REGISTER |  | <b>Type</b>             | R           |                 |         |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                    | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                        | R    | 0x00    |
| 21    | DATA_READY | Data ready<br><br>Read 0x0: No<br><br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br><br>Read 0x0: No<br><br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                        | R    | 0x00000 |

**Table 6-627. Register Call Summary for Register SBL\_CSIA\_WR\_3**

Camera ISP Register Manual

- [Camera ISP SBL Register Summary: \[0\]](#)

**Table 6-628. SBL\_CSIB\_WR\_0**

|                       |                               |  |                         |             |                 |         |
|-----------------------|-------------------------------|--|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 00E8                   |  | <b>Physical Address</b> | 0x480B D2E8 | <b>Instance</b> | ISP_SBL |
| <b>Description</b>    | CSIB WRITE REQUEST 1 REGISTER |  | <b>Type</b>             | R           |                 |         |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                             | Type | Reset |
|-------|------------|---------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0x0   |
| 29:22 | BYTE_CNT   | Current byte count.                                     | R    | 0x00  |

## Camera ISP Register Manual

www.ti.com

| Bits | Field Name | Description                                                                        | Type | Reset   |
|------|------------|------------------------------------------------------------------------------------|------|---------|
| 21   | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20   | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0 | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-629. Register Call Summary for Register SBL\_CSIB\_WR\_0**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-630. SBL\_CSIB\_WR\_1**

|                         |                               |                       |                 |          |
|-------------------------|-------------------------------|-----------------------|-----------------|----------|
| Address Offset          | 0x0000 00EC                   |                       | Instance        | ISP_SBL  |
| Physical Address        | 0x480B D2EC                   |                       | Instance        | ISP_SBL  |
| Description             | CSIB WRITE REQUEST 2 REGISTER |                       | Type            | R        |
| Type                    |                               |                       | RESERVED        | BYTE_CNT |
| 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 |          |
|                         |                               | DATA_READY            | DATA_SENT       | ADDR     |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-631. Register Call Summary for Register SBL\_CSIB\_WR\_1**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-632. SBL\_CSIB\_WR\_2**

|                         |                               |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00F0                   |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D2F0                   |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | CSIB WRITE REQUEST 3 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                      | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                            | R    | 0x0     |
| 29:22 | BYTE_CNT   | Current byte count.                                                                | R    | 0x00    |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes                                        | R    | 0       |
| 20    | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0  | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-633. Register Call Summary for Register SBL\_CSIB\_WR\_2**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-634. SBL\_CSIB\_WR\_3**

|                         |                               |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00F4                   |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x480B D2F4                   |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | CSIB WRITE REQUEST 4 REGISTER |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |
| 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 |      |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | BYTE_CNT                      | DATA_READY            | DATA_SENT       | ADDR |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                             | Type | Reset |
|-------|------------|---------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0. | R    | 0x0   |
| 29:22 | BYTE_CNT   | Current byte count.                                     | R    | 0x00  |
| 21    | DATA_READY | Data ready<br>Read 0x0: No<br>Read 0x1: Yes             | R    | 0     |

| Bits | Field Name | Description                                                                        | Type | Reset   |
|------|------------|------------------------------------------------------------------------------------|------|---------|
| 20   | DATA_SENT  | Data sent to the destination, waiting for status.<br>Read 0x0: No<br>Read 0x1: Yes | R    | 0       |
| 19:0 | ADDR       | Upper 20 bits of the write address.                                                | R    | 0x00000 |

**Table 6-635. Register Call Summary for Register SBL\_CSIB\_WR\_3**

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [0]

**Table 6-636. SBL\_SDR\_REQ\_EXP**

|                                                                                                                                                                                                                                                   |                                          |                       |                 |         |                         |                         |                       |                 |          |         |         |          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-----------------------|-----------------|---------|-------------------------|-------------------------|-----------------------|-----------------|----------|---------|---------|----------|
| Address Offset                                                                                                                                                                                                                                    | 0x0000 00F8                              |                       | Instance        | ISP_SBL |                         |                         |                       |                 |          |         |         |          |
| Physical Address                                                                                                                                                                                                                                  | 0x480B D2F8                              |                       |                 |         |                         |                         |                       |                 |          |         |         |          |
| Description                                                                                                                                                                                                                                       | MEMORY NON REAL TIME READ REQUEST EXPAND |                       |                 |         |                         |                         |                       |                 |          |         |         |          |
| Type                                                                                                                                                                                                                                              | RW                                       |                       |                 |         |                         |                         |                       |                 |          |         |         |          |
| <table border="1"> <tr> <td>31 30 29 28 27 26 25 24</td> <td>23 22 21 20 19 18 17 16</td> <td>15 14 13 12 11 10 9 8</td> <td>7 6 5 4 3 2 1 0</td> </tr> <tr> <td>RESERVED</td> <td>PRV_EXP</td> <td>RSZ_EXP</td> <td>HIST_EXP</td> </tr> </table> |                                          |                       |                 |         | 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 | RESERVED | PRV_EXP | RSZ_EXP | HIST_EXP |
| 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 |         |                         |                         |                       |                 |          |         |         |          |
| RESERVED                                                                                                                                                                                                                                          | PRV_EXP                                  | RSZ_EXP               | HIST_EXP        |         |                         |                         |                       |                 |          |         |         |          |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                         | RW   | 0x0   |
| 29:20 | PRV_EXP    | PREVIEW module READ request expand<br>Sets the number of clock cycles (func clock cycles) to allow btw two consecutive READ requests from the module.<br>It spreads non-real time read requests over time.<br>It enables less priority in the system not to be locked out.<br>At maximum, the PRV and CCP2_RD can read 256 bytes every 32*PRV_EXP functional clock cycles. | RW   | 0x000 |
| 19:10 | RSZ_EXP    | RESIZER module READ request expand<br>Sets the number of clock cycles (func clock cycles) to allow btw two consecutive READ requests from the module.<br>It spreads non-real time read requests over time.<br>It enables less priority in the system not to be locked out.<br>At maximum, the RSZ can read 256 bytes every 32*RSZ_EXP functional clock cycles.             | RW   | 0x000 |
| 9:0   | HIST_EXP   | HISTOGRAM module READ request expand<br>Sets the number of clock cycles to allow btw two consecutive READ requests from the module.<br>It spreads non-real time read requests over time.<br>It enables less priority in the system not to be locked out.<br>At maximum, the HIST can read 256 bytes every HIST_EXP functional clock cycles.                                | RW   | 0x000 |

**Table 6-637. Register Call Summary for Register SBL\_SDR\_REQ\_EXP**

Camera ISP Basic Programming Model

- Camera ISP Resizer Events and Status Checking: [0]
- Camera ISP Central-Resource SBLRegister Setup: [1]
- Camera ISP Central-Resource SBL Input From Memory: [2] [3] [4] [5]

Camera ISP Register Manual

- Camera ISP SBL Register Summary: [6]

## 6.6.10 Camera ISP CSI2 Registers

### 6.6.10.1 Camera ISP CSI2 REGS1 Register Summary

**Table 6-638. CAMERA\_ISP\_CSI2\_REGS1 Register Summary**

| Register Name                 | Type | Register Width (Bits) | Address Offset           | CAMERA_ISP_CSI 2A_REGS1 L3 Base Address | CAMERA_ISP_CSI 2C_REGS1 L3 Base Address |
|-------------------------------|------|-----------------------|--------------------------|-----------------------------------------|-----------------------------------------|
| CSI2_REVISION                 | R    | 32                    | 0x0000 0000              | 0x480B D800                             | 0x480B DC00                             |
| CSI2_SYSCONFIG                | RW   | 32                    | 0x0000 0010              | 0x480B D810                             | 0x480B DC10                             |
| CSI2_SYSSTATUS                | R    | 32                    | 0x0000 0014              | 0x480B D814                             | 0x480B DC14                             |
| CSI2_IRQSTATUS                | RW   | 32                    | 0x0000 0018              | 0x480B D818                             | 0x480B DC18                             |
| CSI2_IRQENABLE                | RW   | 32                    | 0x0000 001C              | 0x480B D81C                             | 0x480B DC1C                             |
| CSI2_CTRL                     | RW   | 32                    | 0x0000 0040              | 0x480B D840                             | 0x480B DC40                             |
| CSI2_DBG_H                    | W    | 32                    | 0x0000 0044              | 0x480B D844                             | 0x480B DC44                             |
| CSI2_GNQ                      | R    | 32                    | 0x0000 0048              | 0x480B D848                             | 0x480B DC48                             |
| RESERVED                      | RW   | 32                    | 0x0000 004C              | 0x480B D84C                             | 0x480B DC4C                             |
| CSI2_COMPLEXIO_CFG1           | RW   | 32                    | 0x0000 0050              | 0x480B D850                             | 0x480B DC50                             |
| CSI2_COMPLEXIO1_IRQSTATUS     | RW   | 32                    | 0x0000 0054              | 0x480B D854                             | 0x480B DC54                             |
| RESERVED                      | RW   | 32                    | 0x0000 0058              | 0x480B D858                             | 0x480B DC58                             |
| CSI2_SHORT_PACKET             | R    | 32                    | 0x0000 005C              | 0x480B D85C                             | 0x480B DC5C                             |
| CSI2_COMPLEXIO1_IRQENABLE     | RW   | 32                    | 0x0000 0060              | 0x480B D860                             | 0x480B DC60                             |
| RESERVED                      | RW   | 32                    | 0x0000 0064              | 0x480B D864                             | 0x480B DC64                             |
| CSI2_DBG_P                    | W    | 32                    | 0x0000 0068              | 0x480B D868                             | 0x480B DC68                             |
| CSI2_TIMING                   | RW   | 32                    | 0x0000 006C              | 0x480B D86C                             | 0x480B DC6C                             |
| CSI2_CTx_CTRL1 <sup>(1)</sup> | RW   | 32                    | 0x0000 0070 + (x * 0x20) | 0x480B D870 + (x * 0x20)                | 0x480B DC00 + (x * 0x20)                |
| CSI2_CTx_CTRL2                | RW   | 32                    | 0x0000 0074 + (x * 0x20) | 0x480B D874 + (x * 0x20)                | 0x480B DC00 + (x * 0x20)                |
| CSI2_CTx_DAT_OFST             | RW   | 32                    | 0x0000 0078 + (x * 0x20) | 0x480B D878 + (x * 0x20)                | 0x480B DC00 + (x * 0x20)                |
| CSI2_CTx_DAT_PING_ADDR        | RW   | 32                    | 0x0000 007C + (x * 0x20) | 0x480B D87C + (x * 0x20)                | 0x480B DC00 + (x * 0x20)                |
| CSI2_CTx_DAT_PONG_ADDR        | RW   | 32                    | 0x0000 0080 + (x * 0x20) | 0x480B D880 + (x * 0x20)                | 0x480B DC00 + (x * 0x20)                |
| CSI2_CTx_IRQENABLE            | RW   | 32                    | 0x0000 0084 + (x * 0x20) | 0x480B D884 + (x * 0x20)                | 0x480B DC00 + (x * 0x20)                |
| CSI2_CTx_IRQSTATUS            | RW   | 32                    | 0x0000 0088 + (x * 0x20) | 0x480B D888 + (x * 0x20)                | 0x480B DC00 + (x * 0x20)                |
| CSI2_CTx_CTRL3                | RW   | 32                    | 0x0000 008C + (x * 0x20) | 0x480B D88C + (x * 0x20)                | 0x480B DC00 + (x * 0x20)                |

<sup>(1)</sup> x = 0 to 7

### 6.6.10.2 Camera ISP CSI2 REGS1 Register Description

**Table 6-639. CSI2\_REVISION**

|                       |                                                                                                                                                   |                         |                                 |                 |                                |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|---------------------------------|-----------------|--------------------------------|
| <b>Address Offset</b> | 0x0000 0000                                                                                                                                       | <b>Physical Address</b> | See <a href="#">Table 6-638</a> | <b>Instance</b> | See <a href="#">Table 6-80</a> |
| <b>Description</b>    | MODULE REVISION<br>This register contains the IP revision code in binary coded digital. For example, 0x01 = revision 0.1 and 0x21 = revision 2.1. |                         |                                 |                 |                                |
| <b>Type</b>           | R                                                                                                                                                 |                         |                                 |                 |                                |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         |                       | REV             |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                          | <b>Type</b> | <b>Reset</b>     |
|-------------|-------------------|-------------------------------------------------------------|-------------|------------------|
| 31:8        | RESERVED          | Write 0's for future compatibility.<br>Reads returns 0.     | R           | 0x000000         |
| 7:0         | REV               | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision | R           | TI internal data |

**Table 6-640. Register Call Summary for Register CSI2\_REVISION**

Camera ISP Register Manual

- [Camera ISP CSI2 REGS1 Register Summary: \[0\]](#)

**Table 6-641. CSI2\_SYSCONFIG**

|                       |                                                                                                          |                         |                                 |                 |                                |
|-----------------------|----------------------------------------------------------------------------------------------------------|-------------------------|---------------------------------|-----------------|--------------------------------|
| <b>Address Offset</b> | 0x0000 0010                                                                                              | <b>Physical Address</b> | See <a href="#">Table 6-638</a> | <b>Instance</b> | See <a href="#">Table 6-80</a> |
| <b>Description</b>    | SYSTEM CONFIGURATION REGISTER<br>This register is the Interconnect-socket system configuration register. |                         |                                 |                 |                                |
| <b>Type</b>           | RW                                                                                                       |                         |                                 |                 |                                |

|                         |                         |                       |                 |               |          |            |           |
|-------------------------|-------------------------|-----------------------|-----------------|---------------|----------|------------|-----------|
| 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 |               |          |            |           |
| RESERVED                |                         |                       |                 | MSTANDBY_MODE | RESERVED | SOFT_RESET | AUTO_IDLE |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:14       | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                  | R           | 0x00000      |
| 13:12       | MSTANDBY_MODE     | Sets the behavior of the master port power management signals.<br><br>0x0: Force-standby. MStandby is only asserted when the module is disabled.<br><br>0x1: No-standby. MStandby is never asserted.<br><br>0x2: Smart-standby: MStandby is asserted based on the activity of the module. The module will try to go to standby during the vertical blanking period. | RW          | 0x0          |
| 11:2        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                  | R           | 0x000        |

| Bits | Field Name | Description                                                                                                                                                                                         | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | SOFT_RESET | Software reset. Set the bit to 1 to trigger a module reset. The bit is automatically reset by the hw. During reads return 0.<br><br>0x0: Normal mode.<br>0x1: The module is reset                   | RW   | 0     |
| 0    | AUTO_IDLE  | Internal Interconnect gating strategy<br><br>0x0: Interconnect clock is free-running.<br>0x1: Automatic Interconnect clock gating strategy is applied based on the Interconnect interface activity. | RW   | 1     |

**Table 6-642. Register Call Summary for Register CSI2\_SYSCONFIG**

## Camera ISP Integration

- [Camera ISP Local Power Management: \[0\]](#)
- [Camera ISP System Power Management: \[1\]](#)
- [Camera ISP Software Reset: \[2\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP CSI2 Reset Management: \[3\]](#)
- [Camera ISP CSI2 Enable Video/Picture Acquisition: \[4\] \[5\]](#)

## Camera ISP Register Manual

- [Camera ISP CSI2 REGS1 Register Summary: \[6\]](#)

**Table 6-643. CSI2\_SYSSTATUS**

|                         |                                                                                                                                |                       |                 |            |          |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |            |                                |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|------------|----------|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|------------|--------------------------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0014                                                                                                                    |                       |                 |            |          |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |            |                                |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | See <a href="#">Table 6-638</a>                                                                                                |                       |                 |            |          |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |            | See <a href="#">Table 6-80</a> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | SYSTEM STATUS REGISTER<br>This register provides status information about the module, excluding the interrupt status register. |                       |                 |            |          |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |            |                                |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                              |                       |                 |            |          |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |            |                                |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESET_DONE | RESERVED |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  | RESET_DONE |                                |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                 | Type | Reset       |
|------|------------|-------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED   | Write 0s for future compatibility. Read returns 0..                                                         | R    | 0x0000 0000 |
| 0    | RESET_DONE | Internal reset monitoring<br><br>Read 0x0: Internal module reset is on going.<br>Read 0x1: Reset completed. | R    | 1           |

**Table 6-644. Register Call Summary for Register CSI2\_SYSSTATUS**

## Camera ISP Integration

- [Camera ISP Software Reset: \[0\] \[1\]](#)

## Camera ISP Register Manual

- [Camera ISP CSI2 REGS1 Register Summary: \[2\]](#)

**Table 6-645. CSI2\_IRQSTATUS**

|                       |                                                                                                                                                                                                                                                                                                        |                         |                                 |                 |                                |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|---------------------------------|-----------------|--------------------------------|
| <b>Address Offset</b> | 0x0000 0018                                                                                                                                                                                                                                                                                            | <b>Physical Address</b> | See <a href="#">Table 6-638</a> | <b>Instance</b> | See <a href="#">Table 6-80</a> |
| <b>Description</b>    | INTERRUPT STATUS REGISTER - All contexts<br>This register associates one bit for each context in order to determine which context has generated the interrupt. The context shall be enabled for events to be generated on that context.<br>If the context is disabled, the interrupt is not generated. |                         |                                 |                 |                                |
| <b>Type</b>           | RW                                                                                                                                                                                                                                                                                                     |                         |                                 |                 |                                |



| Bits  | Field Name            | Description                                                                                                                                                                                                                                                                                                           | Type          | Reset   |
|-------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------|
| 31:15 | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                    | R             | 0x00000 |
| 14    | OCP_ERR_IRQ           | Interconnect Error Interrupt<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                                          | RW<br>W1toClr | 0       |
| 13    | SHORT_PACKET_IRQ      | Short packet reception status (other than synch events:<br>Line Start, Line End, Frame Start, and Frame End: data type between 0x8 and x0F only shall be considered).<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0       |
| 12    | ECC_CORRECTION_IRQ    | ECC has been used to do the correction of the only 1-bit error status (short packet only).<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                            | RW<br>W1toClr | 0       |
| 11    | ECC_NO_CORRECTION_IRQ | ECC error status (short and long packets). No correction of the header because of more than 1-bit error.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                              | RW<br>W1toClr | 0       |
| 10    | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                    | R             | 0x00000 |
| 9     | COMPLEXIO1_ERR_IRQ    | Error signaling from Complex I/O #1: status of the PHY errors received from Complex I/O #1 (events are defined in <a href="#">CSI2_COMPLEXIO1_IRQSTATUS</a> for the first complex I/O).<br><br>Read 0x0: READS: Event is false.<br>Read 0x1: READS: Event is true (pending).                                          | R             | 0       |

| Bits | Field Name   | Description                                                                                                                                                                 | Type          | Reset |
|------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------|
| 8    | FIFO_OVF_IRQ | FIFO overflow error status.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0     |
| 7    | CONTEXT7     | Context 7<br><br>Read 0x0: READS: Event is false.<br>Read 0x1: READS: Event is true (pending).                                                                              | R             | 0     |
| 6    | CONTEXT6     | Context 6<br><br>Read 0x0: READS: Event is false.<br>Read 0x1: READS: Event is true (pending).                                                                              | R             | 0     |
| 5    | CONTEXT5     | Context 5<br><br>Read 0x0: READS: Event is false.<br>Read 0x1: READS: Event is true (pending).                                                                              | R             | 0     |
| 4    | CONTEXT4     | Context 4<br><br>Read 0x0: READS: Event is false.<br>Read 0x1: READS: Event is true (pending).                                                                              | R             | 0     |
| 3    | CONTEXT3     | Context 3<br><br>Read 0x0: READS: Event is false.<br>Read 0x1: READS: Event is true (pending).                                                                              | R             | 0     |
| 2    | CONTEXT2     | Context 2<br><br>Read 0x0: READS: Event is false.<br>Read 0x1: READS: Event is true (pending).                                                                              | R             | 0     |
| 1    | CONTEXT1     | Context 1<br><br>Read 0x0: READS: Event is false.<br>Read 0x1: READS: Event is true (pending).                                                                              | R             | 0     |
| 0    | CONTEXT0     | Context 0<br><br>Read 0x0: READS: Event is false.<br>Read 0x1: READS: Event is true (pending).                                                                              | R             | 0     |

**Table 6-646. Register Call Summary for Register CSI2\_IRQSTATUS**

## Camera ISP Integration

- [Camera ISP Interrupt Requests: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\]](#)

## Camera ISP Functional Description

- [Camera ISP CSI2 ECC: \[16\] \[17\] \[18\]](#)
- [Camera ISP CSI2 Short Packet: \[19\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP CSI2 Enable Video/Picture Acquisition: \[20\]](#)

## Camera ISP Register Manual

- [Camera ISP CSI2 REGS1 Register Summary: \[21\]](#)

**Table 6-647. CSI2\_IRQENABLE**

|                         |                                                                                                                                                     |                 |                                |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------|
| <b>Address Offset</b>   | 0x0000 001C                                                                                                                                         |                 |                                |
| <b>Physical Address</b> | See <a href="#">Table 6-638</a>                                                                                                                     | <b>Instance</b> | See <a href="#">Table 6-80</a> |
| <b>Description</b>      | INTERRUPT ENABLE REGISTER - All contexts<br>This register associates one bit for each context in order to enable/disable each context individually. |                 |                                |
| <b>Type</b>             | RW                                                                                                                                                  |                 |                                |



| Bits  | Field Name            | Description                                                                                                                                                                                                                                                                             | Type | Reset   |
|-------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:15 | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                      | R    | 0x00000 |
| 14    | OCP_ERR_IRQ           | Interconnect Error Interrupt<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                                                                                                                                                | RW   | 0       |
| 13    | SHORT_PACKET_IRQ      | Short packet reception (other than synch events: Line Start, Line End, Frame Start, and Frame End: data type between 0x8 and x0F only shall be considered).<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                 | RW   | 0       |
| 12    | ECC_CORRECTION_IRQ    | ECC has been used to correct the only 1-bit error (short packet only).<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                                                                                                      | RW   | 0       |
| 11    | ECC_NO_CORRECTION_IRQ | ECC error (short and long packets). No correction of the header because of more than 1-bit error.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                                                                           | RW   | 0       |
| 10    | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                      | R    | 0x00000 |
| 9     | COMPLEXIO1_ERR_IRQ    | Error signaling from Complex I/O #1: the interrupt is triggered when any error is received from Complex I/O #1 (events are defined in <a href="#">CSI2_COMPLEXIO1_IRQSTATUS</a> for the first complex I/O).<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0       |
| 8     | FIFO_OVF_IRQ          | FIFO overflow enable<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                                                                                                                                                        | RW   | 0       |
| 7     | CONTEXT7              | Context 7<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                                                                                                                                                                   | RW   | 0       |
| 6     | CONTEXT6              | Context 6<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                                                                                                                                                                   | RW   | 0       |

| Bits | Field Name | Description                                                                           | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------|------|-------|
| 5    | CONTEXT5   | Context 5<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0     |
| 4    | CONTEXT4   | Context 4<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0     |
| 3    | CONTEXT3   | Context 3<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0     |
| 2    | CONTEXT2   | Context 2<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0     |
| 1    | CONTEXT1   | Context 1<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0     |
| 0    | CONTEXT0   | Context 0<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0     |

**Table 6-648. Register Call Summary for Register CSI2\_IRQENABLE**

- Camera ISP Interrupt Requests: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13]

- ## Camera ISP Functional Description

- ## Camera ISP Basic Programming Model

- Camera ISP Register Manual

**Table 6-649 CSI2 CTRI**

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:16 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R    | 0x000 |
| 15    | VP_CLK_EN   | VP clock enable.<br><br>0x0: The VP clock is disabled.<br><br>0x1: The VP clock is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW   | 0     |
| 14:12 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0     |
| 11    | VP_ONLY_EN  | VP only enable.<br><br>0x0: The VP is enabled and the Interconnect master port is enabled.<br><br>0x1: The VP is enabled and the Interconnect master port is disabled.                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0     |
| 10    | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R    | 0x000 |
| 9:8   | VP_OUT_CTRL | Video port output clock control.<br>Sets the video port output clock as a function of the interface clock (OCPCLK).<br><br>0x0: RESERVED<br><br>0x1: Division by 2: video port clock = OCPCLK / 2.<br><br>0x2: Division by 3: video port clock = OCPCLK / 3.<br><br>0x3: Division by 4: video port clock = OCPCLK / 4.<br><b>Note:</b> Software must change the reset value that is not appropriate.                                                                                                                                                                     | RW   | 0x0   |
| 7     | DBG_EN      | Enables the debug mode.<br><br>0x0: Disable<br><br>0x1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 6:5   | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R    | 0x000 |
| 4     | ENDIANNES   | Select endianness for YUV422 8 bit and YUV420 legacy formats.<br><br>0x0: Use native MIPI CSI2 endianness:<br>Little endian for all formats except for YUV422 8b and YUV420 Legacy which a big endian.<br><br>0x1: Store all pixel formats little endian.                                                                                                                                                                                                                                                                                                                | RW   | 0     |
| 3     | FRAME       | Set the modality in which IF_EN works.<br><br>0x0: If IF_EN = 0 the interface is disabled immediately.<br><br>0x1: If IF_EN = 1 the interface is disabled after all FEC sync code have been received for the active contexts.                                                                                                                                                                                                                                                                                                                                            | RW   | 0     |
| 2     | ECC_EN      | Enables the Error Correction Code check for the received header (short and long packets for all virtual channel ids).<br><br>0x0: Disabled<br><br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 1     | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R    | 0x000 |
| 0     | IF_EN       | Enables the physical interface to the module.<br><br>0x0: The interface is disabled. If FRAME = 0, it is disabled immediately. If FRAME = 1, it is disabled when each context has received the FEC sync code.<br><br>0x1: The interface is enabled immediately, the data acquisition starts on the next FSC sync code.<br>Writing '1' to this register when the current value is '0' has the effect to clear the output FIFO. The pixel data of the following frame will be written in the PING buffer, i.e., the CSI2_CTX_CTRL.PING_PONG bits are reset to '0' as well. | RW   | 0     |

**Table 6-650. Register Call Summary for Register CSI2\_CTRL**

|                                                                              |  |
|------------------------------------------------------------------------------|--|
| Camera ISP Integration                                                       |  |
| • Camera ISP System Power Management: [0]                                    |  |
| Camera ISP Functional Description                                            |  |
| • Camera ISP CSI2 ECC: [1]                                                   |  |
| • Camera ISP CSI2 RAW Image Transcoding with DPCM and A-law Compression: [2] |  |
| • Camera ISP CSI2 DMA Engine: [3] [4]                                        |  |
| Camera ISP Basic Programming Model                                           |  |
| • Camera ISP CSI2 Enable Video/Picture Acquisition: [5] [6]                  |  |
| • Camera ISP CSI2 Disable Video/Picture Acquisition: [7] [8] [9]             |  |
| Camera ISP Register Manual                                                   |  |
| • Camera ISP CSI2 REGS1 Register Summary: [10]                               |  |
| • Camera ISP CSI2 REGS1 Register Description: [11] [12] [13]                 |  |

**Table 6-651. CSI2\_DBG\_H**

| <b>Address Offset</b>   | 0x0000 0044                                                                                                                                                                                                                                                                                                               |                       |                                |             |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--------------------------------|-------------|
| <b>Physical Address</b> | See <a href="#">Table 6-638</a>                                                                                                                                                                                                                                                                                           | <b>Instance</b>       | See <a href="#">Table 6-80</a> |             |
| <b>Description</b>      | DEBUG REGISTER (Header)<br>This register provides a way to debug the CSI2 RECEIVER module with no image sensor connected to the module. The debug mode is enabled by <a href="#">CSI2_CTRL.DBG_EN</a> . Only full 32-bit values shall be written. The register is used to write short packets and header of long packets. |                       |                                |             |
| <b>Type</b>             | W                                                                                                                                                                                                                                                                                                                         |                       |                                |             |
| 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                |             |
| DBG                     |                                                                                                                                                                                                                                                                                                                           |                       |                                |             |
| Bits                    | Field Name                                                                                                                                                                                                                                                                                                                | Description           | Type                           | Reset       |
| 31:0                    | DBG                                                                                                                                                                                                                                                                                                                       | 32-bit input value.   | W                              | 0x0000 0000 |

**Table 6-652. Register Call Summary for Register CSI2\_DBG\_H**

|                                               |  |
|-----------------------------------------------|--|
| Camera ISP Register Manual                    |  |
| • Camera ISP CSI2 REGS1 Register Summary: [0] |  |

**Table 6-653. CSI2\_GNQ**

|                         |                                                                                                              |                       |                                |
|-------------------------|--------------------------------------------------------------------------------------------------------------|-----------------------|--------------------------------|
| <b>Address Offset</b>   | 0x0000 0048                                                                                                  |                       |                                |
| <b>Physical Address</b> | See <a href="#">Table 6-638</a>                                                                              | <b>Instance</b>       | See <a href="#">Table 6-80</a> |
| <b>Description</b>      | GENERIC PARAMETER REGISTER<br>This register provide a way to read the generic parameters used in the design. |                       |                                |
| <b>Type</b>             | R                                                                                                            |                       |                                |
| 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                |
| RESERVED                |                                                                                                              | FIFODEPTH             | NBCONTEXTS                     |

| Bits | Field Name | Description                                                                                                                                                                                           | Type | Reset     |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:6 | RESERVED   | Write 0's for future compatibility.<br>Reads returns 0.                                                                                                                                               | R    | 0x0000000 |
| 5:2  | FIFODEPTH  | Output FIFO size in multiple of 68 bits.<br><br>Read 0x2: 8x 68 bits<br>Read 0x3: 16x 68 bits<br>Read 0x4: 32x 68 bits<br>Read 0x5: 64x 68 bits<br>Read 0x6: 128 x 68 bits<br>Read 0x7: 256 x 68 bits | R    | 0x6       |
| 1:0  | NBCONTEXTS | Number of contexts supported by the module.<br><br>Read 0x0: 1 Context<br>Read 0x1: 2 Contexts<br>Read 0x2: 4 Contexts<br>Read 0x3: 8 Contexts                                                        | R    | 0x3       |

**Table 6-654. Register Call Summary for Register CSI2\_GNQ**

Camera ISP Register Manual

- Camera ISP CSI2\_REGS1 Register Summary: [0]

**Table 6-655. CSI2\_COMPLEXIO\_CFG1**

|                |            |                                                                                                                                                                                                                                                                                                          |         |                  |          |                 |    |          |    |                |    |    |    |           |                |           |                |           |                |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------------------|----------|-----------------|----|----------|----|----------------|----|----|----|-----------|----------------|-----------|----------------|-----------|----------------|----|----|---|---|---|---|---|---|---|---|---|---|
| Address Offset |            | 0x0000 0050                                                                                                                                                                                                                                                                                              |         | Physical Address |          | See Table 6-638 |    | Instance |    | See Table 6-80 |    |    |    |           |                |           |                |           |                |    |    |   |   |   |   |   |   |   |   |   |   |
| Description    |            | PHY configuration register for the PHY associated to the receiver<br><br>This register contains the lane configuration for the order and position of the lanes (clock and data) and the polarity order for the control of the PHY differential signals in addition to the control bit for the power FSM. |         |                  |          |                 |    |          |    |                |    |    |    |           |                |           |                |           |                |    |    |   |   |   |   |   |   |   |   |   |   |
| Type           |            | RW                                                                                                                                                                                                                                                                                                       |         |                  |          |                 |    |          |    |                |    |    |    |           |                |           |                |           |                |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED       | RESET_CTRL | RESET_DONE                                                                                                                                                                                                                                                                                               | PWR_CMD | PWR_STATUS       | PWR_AUTO | RESERVED        |    |          |    |                |    |    |    | DATA2_POL | DATA2_POSITION | DATA1_POL | DATA1_POSITION | CLOCK_POL | CLOCK_POSITION |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                              | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                       | R    | 0     |
| 30    | RESET_CTRL | Controls the reset of the PHY<br><br>0x0: PHY reset active.<br>0x1: PHY reset de-asserted.                                                                               | RW   | 0     |
| 29    | RESET_DONE | Internal reset monitoring of the power domain using the PPI byte clock from the PHY<br><br>Read 0x0: Internal module reset is on going.<br>Read 0x1: Reset completed.    | R    | 0     |
| 28:27 | PWR_CMD    | Command for power control of the PHY<br><br>0x0: Command to change to OFF state<br>0x1: Command to change to ON state<br>0x2: Command to change to Ultra Low Power state | RW   | 0x0   |

| Bits  | Field Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset |
|-------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 26:25 | PWR_STATUS     | Status of the power control of the PHY<br><br>Read 0x0: PHY in OFF state<br><br>Read 0x1: PHY in ON state<br><br>Read 0x2: PHY in Ultra Low Power state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R    | 0x0   |
| 24    | PWR_AUTO       | Automatic switch between ULP and ON states based on ULP signals from PHY<br><br>0x0: Disable<br>0x1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 23:12 | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R    | 0x0   |
| 11    | DATA2_POL      | +/- differential pin order of DATA lane 2.<br><br>0x0: +/- pin order<br>0x1: -/+ pin order                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0     |
| 10:8  | DATA2_POSITION | Position and order of the DATA lane 2.<br><br>0x0: Not used/connected<br>0x1: Data lane 2 is at position 1.<br>0x2: Data lane 2 is at position 2.<br>0x3: Data lane 2 is at position 3.<br><br><b>Note:</b> If the parallel camera sensor and the other camera sensor (CCP2 or CSI2) are connected to the same CSIPHY, the SCM.CONTROL_CAMERAx_PHY_CAMMOD bit must be set for CCP2 or CSI2mode, respectively, (even if only one pair is used as GPI for CPI mode). The corresponding DATAx_POSITION bit must be set to 0x0 for the lane in GPI mode.                                                                                                                                                                                                                                  | RW   | 0x0   |
| 7     | DATA1_POL      | +/- differential pin order of DATA lane 1.<br><br>0x0: +/- pin order<br>0x1: -/+ pin order                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0     |
| 6:4   | DATA1_POSITION | Position and order of the DATA lane 1.<br><br>The data lane 1 is always present.<br><br>0x0: Not used/connected<br>0x1: Data lane 1 is at position 1.<br>0x2: Data lane 1 is at position 2.<br>0x3: Data lane 1 is at position 3.<br><br><b>Note:</b> If the parallel camera sensor and the other camera sensor (CCP2 or CSI2) are connected to the same CSIPHY, the SCM.CONTROL_CAMERAx_PHY_CAMMOD bit must be set for CCP2 or CSI2mode, respectively, (even if only one pair is used as GPI for CPI mode). The corresponding DATAx_POSITION bit must be set to 0x0 for the lane in GPI mode.<br><br><b>Note:</b> The settings differ when using CSIPHY1/CSIPHY2 and CCP2. See <a href="#">Section 6.5.2.2, Camera ISP CSIPHY Initialization for Work With CSI1/CCP2B Receiver</a> . | RW   | 0x0   |
| 3     | CLOCK_POL      | $\pm$ differential pin order of CLOCK lane.<br><br>0x0: $\pm$ pin order<br>0x1: $\pm$ pin order                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0     |

| Bits | Field Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Type | Reset |
|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 2:0  | CLOCK_POSITION | <p>Position and order of the CLOCK lane. The clock lane is always present.</p> <p>0x0: Not used/connected</p> <p>0x1: Clock lane is at position 1.</p> <p>0x2: Clock lane is at position 2.</p> <p>0x3: Clock lane is at position 3.</p> <p>0x5: Clock lane is at position 2 (using CSIPHY1) or 1 (using CSIPHY2). This setting is valid for CCP2 receiver mode only.</p> <p><b>Note:</b> The settings differ when using CSIPHY1/CSIPHY2 and CCP2. See <a href="#">Section 6.5.2.2, Camera ISP CSIPHY Initialization for Work With CSI1/CCP2B Receiver</a>.</p> | RW   | 0x0   |

**Table 6-656. Register Call Summary for Register CSI2\_COMPLEXIO\_CFG1**

Camera ISP Environment

- [Camera ISP Connectivity Schemes: \[0\]](#)

Camera ISP Functional Description

- [Camera ISP CSI2 Physical Layer Lane Configuration: \[1\] \[2\] \[3\]](#)
- [Camera ISP CSI2 PHYs: \[4\] \[5\] \[6\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CSIPHY Initialization for Work With CSI2 Receiver: \[7\] \[8\] \[9\] \[10\] \[11\] \[12\]](#)
- [Camera ISP CSIPHY Initialization for Work With CSI1/CCP2B Receiver: \[13\] \[14\] \[15\] \[16\] \[17\] \[18\]](#)

Camera ISP Register Manual

- [Camera ISP CSI2 REGS1 Register Summary: \[19\]](#)

**Table 6-657. CSI2\_COMPLEXIO1\_IRQSTATUS**

|                  |                                                                         |                  |                   |            |            |            |            |            |             |             |             |             |             |        |        |        |        |        |               |               |               |               |               |          |          |          |          |          |   |   |   |
|------------------|-------------------------------------------------------------------------|------------------|-------------------|------------|------------|------------|------------|------------|-------------|-------------|-------------|-------------|-------------|--------|--------|--------|--------|--------|---------------|---------------|---------------|---------------|---------------|----------|----------|----------|----------|----------|---|---|---|
| Address Offset   | 0x0000 0054                                                             |                  |                   |            |            |            |            |            |             |             |             |             |             |        |        |        |        |        |               |               |               |               |               |          |          |          |          |          |   |   |   |
| Physical Address | See <a href="#">Table 6-638</a>                                         |                  |                   |            |            |            |            |            |             |             |             |             |             |        |        |        |        |        |               |               |               |               |               |          |          |          |          |          |   |   |   |
| Description      | INSTANCE INTERRUPT STATUS REGISTER - All errors from the associated PHY |                  |                   |            |            |            |            |            |             |             |             |             |             |        |        |        |        |        |               |               |               |               |               |          |          |          |          |          |   |   |   |
| Type             | RW                                                                      |                  |                   |            |            |            |            |            |             |             |             |             |             |        |        |        |        |        |               |               |               |               |               |          |          |          |          |          |   |   |   |
| 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 |
| RESERVED         |                                                                         | STATEALLULPMEXIT | STATEALLULPMENTER | STATEULPM5 | STATEULPM4 | STATEULPM3 | STATEULPM2 | STATEULPM1 | ERRCONTROL5 | ERRCONTROL4 | ERRCONTROL3 | ERRCONTROL2 | ERRCONTROL1 | ERESC5 | ERESC4 | ERESC3 | ERESC2 | ERESC1 | ERRSOTSYNCHS5 | ERRSOTSYNCHS4 | ERRSOTSYNCHS3 | ERRSOTSYNCHS2 | ERRSOTSYNCHS1 | ERRSOTH5 | ERRSOTH4 | ERRSOTH3 | ERRSOTH2 | ERRSOTH1 |   |   |   |

| Bits  | Field Name       | Description                                                                                                                                                                                                 | Type          | Reset |
|-------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------|
| 31:27 | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                                                          | R             | 0x00  |
| 26    | STATEALLULPMEXIT | <p>At least one of the active lanes has exit the ULPM</p> <p>0x0: READS: Event is false.<br/>WRITES: Status bit unchanged.</p> <p>0x1: READS: Event is true (pending).<br/>WRITES: Status bit is reset.</p> | RW<br>W1toClr | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                     | <b>Type</b>   | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------|
| 25          | STATEALLULPMENTER | All active lanes are entering in ULPM.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0            |
| 24          | STATEULPM5        | Lane #5 in Ultra Low Power Mode<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.        | RW<br>W1toClr | 0            |
| 23          | STATEULPM4        | Lane #4 in Ultra Low Power Mode<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.        | RW<br>W1toClr | 0            |
| 22          | STATEULPM3        | Lane #3 in Ultra Low Power Mode<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.        | RW<br>W1toClr | 0            |
| 21          | STATEULPM2        | Lane #2 in Ultra Low Power Mode<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.        | RW<br>W1toClr | 0            |
| 20          | STATEULPM1        | Lane #1 in Ultra Low Power Mode<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.        | RW<br>W1toClr | 0            |
| 19          | ERRCONTROL5       | Control error for lane #5<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.              | RW<br>W1toClr | 0            |
| 18          | ERRCONTROL4       | Control error for lane #4<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.              | RW<br>W1toClr | 0            |
| 17          | ERRCONTROL3       | Control error for lane #3<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.              | RW<br>W1toClr | 0            |
| 16          | ERRCONTROL2       | Control error for lane #2<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.              | RW<br>W1toClr | 0            |
| 15          | ERRCONTROL1       | Control error for lane #1<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.              | RW<br>W1toClr | 0            |

## Camera ISP Register Manual

www.ti.com

| Bits | Field Name    | Description                                                                                                                                                                                  | Type          | Reset |
|------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------|
| 14   | ERRESC5       | Escape entry error for lane #5<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.               | RW<br>W1toClr | 0     |
| 13   | ERRESC4       | Escape entry error for lane #4<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.               | RW<br>W1toClr | 0     |
| 12   | ERRESC3       | Escape entry error for lane #3<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.               | RW<br>W1toClr | 0     |
| 11   | ERRESC2       | Escape entry error for lane #2<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.               | RW<br>W1toClr | 0     |
| 10   | ERRESC1       | Escape entry error for lane #1<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.               | RW<br>W1toClr | 0     |
| 9    | ERRSOTSYNCHS5 | Start of transmission sync error for lane #5<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0     |
| 8    | ERRSOTSYNCHS4 | Start of transmission sync error for lane #4<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0     |
| 7    | ERRSOTSYNCHS3 | Start of transmission sync error for lane #3<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0     |
| 6    | ERRSOTSYNCHS2 | Start of transmission sync error for lane #2<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0     |
| 5    | ERRSOTSYNCHS1 | Start of transmission sync error for lane #1<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0     |
| 4    | ERRSOTHS5     | Start of transmission error for lane #5<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.      | RW<br>W1toClr | 0     |

| Bits | Field Name | Description                                                                                                                                                                             | Type          | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------|
| 3    | ERRSOTHS4  | Start of transmission error for lane #4<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0     |
| 2    | ERRSOTHS3  | Start of transmission error for lane #3<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0     |
| 1    | ERRSOTHS2  | Start of transmission error for lane #2<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0     |
| 0    | ERRSOTHS1  | Start of transmission error for lane #1<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0     |

**Table 6-658. Register Call Summary for Register CSI2\_COMPLEXIO1\_IRQSTATUS**

Camera ISP Integration

- [Camera ISP Interrupt Requests: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\]](#)

Camera ISP Functional Description

- [Camera ISP CSI2 PHYs: \[18\]](#)

Camera ISP Register Manual

- [Camera ISP CSI2 REGS1 Register Summary: \[19\]](#)
- [Camera ISP CSI2 REGS1 Register Description: \[20\] \[21\]](#)

**Table 6-659. CSI2\_SHORT\_PACKET**

|                         |                                                                                                                                         |                       |                 |          |  |  |  |  |  |  |                 |  |  |              |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|-----------------|--|--|--------------|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 005C                                                                                                                             |                       |                 |          |  |  |  |  |  |  |                 |  |  |              |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | See <a href="#">Table 6-638</a>                                                                                                         |                       |                 |          |  |  |  |  |  |  | <b>Instance</b> |  |  |              |  |  |  |  |  |  |  |  |
| <b>Description</b>      | SHORT PACKET INFORMATION -<br>This register sets the 24-bit DATA_ID + Short Packet Data Field when the data type is between 0x8 and x0F |                       |                 |          |  |  |  |  |  |  |                 |  |  |              |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                       |                       |                 |          |  |  |  |  |  |  |                 |  |  |              |  |  |  |  |  |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |                 |  |  | SHORT_PACKET |  |  |  |  |  |  |  |  |

| Bits  | Field Name   | Description                                        | Type | Reset    |
|-------|--------------|----------------------------------------------------|------|----------|
| 31:24 | RESERVED     | Write Os for future compatibility. Read returns 0. | R    | 0x00     |
| 23:0  | SHORT_PACKET | Short Packet information: DATA ID + DATA FIELD     | R    | 0x000000 |

**Table 6-660. Register Call Summary for Register CSI2\_SHORT\_PACKET**

Camera ISP Functional Description

- [Camera ISP CSI2 Short Packet: \[0\] \[1\]](#)

Camera ISP Register Manual

- [Camera ISP CSI2 REGS1 Register Summary: \[2\]](#)

**Table 6-661. CSI2\_COMPLEXIO1\_IRQENABLE**

|                         |                                                            |                                                                                                                                |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               |             |          |              |          |          |   |   |   |
|-------------------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------|------------|------------|------------|------------|------------|-------------|-------------|-------------|-------------|-------------|---------|---------|---------|---------|---------|---------------|---------------|---------------|---------------|---------------|-------------|----------|--------------|----------|----------|---|---|---|
| <b>Address Offset</b>   | 0x0000 0060                                                |                                                                                                                                |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               |             |          |              |          |          |   |   |   |
| <b>Physical Address</b> | See <a href="#">Table 6-638</a>                            |                                                                                                                                |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               |             |          |              |          |          |   |   |   |
| <b>Description</b>      | INTERRUPT ENABLE REGISTER - All errors from associated PHY |                                                                                                                                |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               |             |          |              |          |          |   |   |   |
| <b>Type</b>             | RW                                                         |                                                                                                                                |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               |             |          |              |          |          |   |   |   |
| 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 |
| RESERVED                |                                                            | STATEALLULPMEXIT                                                                                                               | STATEALLULPMENTER | STATEULPM5 | STATEULPM4 | STATEULPM3 | STATEULPM2 | STATEULPM1 | ERRCONTROL5 | ERRCONTROL4 | ERRCONTROL3 | ERRCONTROL2 | ERRCONTROL1 | ERRESC5 | ERRESC4 | ERRESC3 | ERRESC2 | ERRESC1 | ERRSOTSYNCHS5 | ERRSOTSYNCHS4 | ERRSOTSYNCHS3 | ERRSOTSYNCHS2 | ERRSOTSYNCHS1 | ERRSOTH5    | ERRSOTH4 | ERRSOTH3     | ERRSOTH2 | ERRSOTH1 |   |   |   |
| <b>Bits</b>             | <b>Field Name</b>                                          | <b>Description</b>                                                                                                             |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               | <b>Type</b> |          | <b>Reset</b> |          |          |   |   |   |
| 31:27                   | RESERVED                                                   | Write 0s for future compatibility. Read returns 0.                                                                             |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               | R           |          | 0x00         |          |          |   |   |   |
| 26                      | STATEALLULPMEXIT                                           | At least one of the active lanes has exit the ULPM<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               | RW          |          | 0            |          |          |   |   |   |
| 25                      | STATEALLULPMENTER                                          | All active lanes are entering in ULPM.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs             |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               | RW          |          | 0            |          |          |   |   |   |
| 24                      | STATEULPM5                                                 | Lane #5 in Ultra Low Power Mode<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                    |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               | RW          |          | 0            |          |          |   |   |   |
| 23                      | STATEULPM4                                                 | Lane #4 in Ultra Low Power Mode<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                    |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               | RW          |          | 0            |          |          |   |   |   |
| 22                      | STATEULPM3                                                 | Lane #3 in Ultra Low Power Mode<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                    |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               | RW          |          | 0            |          |          |   |   |   |
| 21                      | STATEULPM2                                                 | Lane #2 in Ultra Low Power Mode<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                    |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               | RW          |          | 0            |          |          |   |   |   |
| 20                      | STATEULPM1                                                 | Lane #1 in Ultra Low Power Mode<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                    |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               | RW          |          | 0            |          |          |   |   |   |
| 19                      | ERRCONTROL5                                                | Control error for lane #5<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                          |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               | RW          |          | 0            |          |          |   |   |   |
| 18                      | ERRCONTROL4                                                | Control error for lane #4<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                          |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               | RW          |          | 0            |          |          |   |   |   |
| 17                      | ERRCONTROL3                                                | Control error for lane #3<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                          |                   |            |            |            |            |            |             |             |             |             |             |         |         |         |         |         |               |               |               |               |               | RW          |          | 0            |          |          |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 16          | ERRCONTROL2       | Control error for lane #2<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                    | RW          | 0            |
| 15          | ERRCONTROL1       | Control error for lane #1<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                    | RW          | 0            |
| 14          | ERRESC5           | Escape entry error for lane #5<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs               | RW          | 0            |
| 13          | ERRESC4           | Escape entry error for lane #4<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs               | RW          | 0            |
| 12          | ERRESC3           | Escape entry error for lane #3<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs               | RW          | 0            |
| 11          | ERRESC2           | Escape entry error for lane #2<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs               | RW          | 0            |
| 10          | ERRESC1           | Escape entry error for lane #1<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs               | RW          | 0            |
| 9           | ERRSOTSYNCHS5     | Start of transmission sync error for lane #5<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs | RW          | 0            |
| 8           | ERRSOTSYNCHS4     | Start of transmission sync error for lane #4<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs | RW          | 0            |
| 7           | ERRSOTSYNCHS3     | Start of transmission sync error for lane #3<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs | RW          | 0            |
| 6           | ERRSOTSYNCHS2     | Start of transmission sync error for lane #2<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs | RW          | 0            |
| 5           | ERRSOTSYNCHS1     | Start of transmission sync error for lane #1<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs | RW          | 0            |
| 4           | ERRSOTHS5         | Start of transmission error for lane #5<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs      | RW          | 0            |
| 3           | ERRSOTHS4         | Start of transmission error for lane #4<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs      | RW          | 0            |
| 2           | ERRSOTHS3         | Start of transmission error for lane #3<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs      | RW          | 0            |
| 1           | ERRSOTHS2         | Start of transmission error for lane #2<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs      | RW          | 0            |

| Bits | Field Name | Description                                                                                                         | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | ERRSOTHS1  | Start of transmission error for lane #1<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0     |

**Table 6-662. Register Call Summary for Register CSI2\_COMPLEXIO1\_IRQENABLE**

Camera ISP Integration

- Camera ISP Interrupt Requests: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16]

Camera ISP Basic Programming Model

- Camera ISP CSI2 Enable Video/Picture Acquisition: [17]

Camera ISP Register Manual

- Camera ISP CSI2 REGS1 Register Summary: [18]

**Table 6-663. CSI2\_DBG\_P**

|                         |                                                                                                                                                                                                                                                                                                           |                       |                 |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|-----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0068                                                                                                                                                                                                                                                                                               |                       |                 |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | See Table 6-638                                                                                                                                                                                                                                                                                           |                       |                 |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | DEBUG REGISTER (Payload)<br>This register provides a way to debug the CSI2 RECEIVER module with no image sensor connected to the module. The debug mode is enabled by <a href="#">CSI2_CTRL.DBG_EN</a> . Only full 32-bit values shall be written. The register is used to write payload of long packets. |                       |                 |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                                                                                                                                                                                                                                                                                         |                       |                 |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | DBG |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description         | Type | Reset       |
|------|------------|---------------------|------|-------------|
| 31:0 | DBG        | 32-bit input value. | W    | 0x0000 0000 |

**Table 6-664. Register Call Summary for Register CSI2\_DBG\_P**

Camera ISP Register Manual

- Camera ISP CSI2 REGS1 Register Summary: [0]

**Table 6-665. CSI2\_TIMING**

|                         |                                                                                                                                                                                                                                            |                       |                 |          |                   |                    |                   |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|-------------------|--------------------|-------------------|------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 006C                                                                                                                                                                                                                                |                       |                 |          |                   |                    |                   |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | See Table 6-638                                                                                                                                                                                                                            |                       |                 |          |                   |                    |                   |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | TIMING REGISTER<br>This register controls the CSI2 RECEIVER module. This register shall not be modified while <a href="#">CSI2_CTRL.IF_EN</a> is set to '1'. It is used to indicate the number of L3 cycles for the Stop State monitoring. |                       |                 |          |                   |                    |                   |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                         |                       |                 |          |                   |                    |                   |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED | FORCE_RX_MODE_IO1 | STOP_STATE_X16_IO1 | STOP_STATE_X4_IO1 | STOP_STATE_COUNTER_IO1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name             | Description                                                                                                                                                                                                                                                                                                        | Type | Reset  |
|-------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED               | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                 | RW   | 0x0    |
| 15    | FORCE_RX_MODE_IO1      | <p>Control of ForceRxMode signal</p> <p>0x0: De-assertion of ForceRxMode. The HW reset the bit at the end of the Force RX Mode assertion.</p> <p>The SW can reset the bit in order to stop the assertion of the ForceRXMode signal prior to the completion of the period.</p> <p>0x1: Assertion of ForceRxMode</p> | RW   | 0      |
| 14    | STOP_STATE_X16_IO1     | <p>Multiplication factor for the number of L3 cycles defined in STOP_STATE_COUNTER_IO1 bit-field</p> <p>0x0: The number of L3 cycles defined in STOP_STATE_COUNTER_IO1 is multiplied by 1x</p> <p>0x1: The number of L3 cycles defined in STOP_STATE_COUNTER_IO1 is multiplied by 16x</p>                          | RW   | 1      |
| 13    | STOP_STATE_X4_IO1      | <p>Multiplication factor for the number of L3 cycles defined in STOP_STATE_COUNTER_IO1 bit-field</p> <p>0x0: The number of L3 cycles defined in STOP_STATE_COUNTER_IO1 is multiplied by 1x</p> <p>0x1: The number of L3 cycles defined in STOP_STATE_COUNTER_IO1 is multiplied by 4x</p>                           | RW   | 1      |
| 12:0  | STOP_STATE_COUNTER_IO1 | <p>Stop State counter for monitoring. It indicates the number of L3 to monitor for Stop State before de-asserting ForceRxMode (Complex I/O #1).</p> <p>The value is from 0 to 8191.</p>                                                                                                                            | RW   | 0xFFFF |

**Table 6-666. Register Call Summary for Register CSI2\_TIMING**

- ## Camera ISP Functional Description

- Camera ISP CSIPHY Initialization for Work With CSI2 Receiver: [8] [9] [10]
  - Camera ISP CSIPHY Initialization for Work With CSI1/CCP2B Receiver: [11] [12]

- ## Camera ISP Register Manual

  - Camera ISP CSI2 REGS1 Register Summary: [13]

Table 6-667. CSI2 CTx CTRL1

|                         |                                                                                                                                                                 |                 |                                |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------|
| <b>Address Offset</b>   | 0x0000 0070 + (x * 0x20)                                                                                                                                        | <b>Index</b>    | x = 0 to 7                     |
| <b>Physical Address</b> | See <a href="#">Table 6-638</a>                                                                                                                                 | <b>Instance</b> | See <a href="#">Table 6-80</a> |
| <b>Description</b>      | CONTROL REGISTER - Context<br>This register controls the Context. This register is shadowed: modifications are taken into account after the next FSC sync code. |                 |                                |
| <b>Type</b>             | RW                                                                                                                                                              |                 |                                |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16                                                                                                                                         |                 |                                |
| 31 30 29 28 27 26 25 24 | 15 14 13 12 11 10 9 8                                                                                                                                           |                 |                                |
| BYTESWAP                | GENERIC                                                                                                                                                         | RESERVED        | 7 6 5 4 3 2 1 0                |
|                         |                                                                                                                                                                 | TRANSCODE       | FEC_NUMBER                     |
|                         |                                                                                                                                                                 |                 | COUNT                          |
|                         |                                                                                                                                                                 |                 | EOF_EN                         |
|                         |                                                                                                                                                                 |                 | EOL_EN                         |
|                         |                                                                                                                                                                 |                 | CS_EN                          |
|                         |                                                                                                                                                                 |                 | COUNT_UNLOCK                   |
|                         |                                                                                                                                                                 |                 | PING_PONG                      |
|                         |                                                                                                                                                                 |                 | VP_FORCE                       |
|                         |                                                                                                                                                                 |                 | LINE_MODULO                    |
|                         |                                                                                                                                                                 |                 | CTX_EN                         |

## Camera ISP Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | BYTE_SWAP  | <p>Allows swapping bytes two by two in the payload data.<br/> It doesn't affect<br/> - short packets<br/> - long packet header or footers<br/> - CRC calculation<br/> The purpose is to swap data send to the Interconnect port and/or video port</p> <p>0x0: Disabled<br/> 0x1: Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 30    | GENERIC    | <p>Enables the generic mode.</p> <p>0x0: Disabled.<br/> Data is received according to CSI2_CTX_CTRL1.FORMAT and the long packet code transmitted in the MIPI stream is used.</p> <p>0x1: Enabled.<br/> Data is received according to CSI2_CTX_CTRL1.FORMAT and the long packet code transmitted in the MIPI stream is ignored.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0     |
| 29:28 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R    | 0x0   |
| 27:24 | TRANSCODE  | <p>Enables image transcoding.<br/> When this feature is enabled:<br/> - the data format from the camera is defined by the FORMAT register<br/> - the format after transcode is defined by the TRANSCODE register. The memory storage / video port formats is defined by the TRANSCODE register</p> <p>0x0: Feature disabled.<br/> 0x1: Outputs DPCM compressed RAW10 data.<br/> After compression, pixels are coded on 8 bits.<br/> Data in memory is organized as regular RAW8 data</p> <p>0x2: Outputs DPCM compressed RAW12 data.<br/> After compression, pixels are coded on 8 bits.<br/> Data in memory is organized as regular RAW8 data</p> <p>0x3: Outputs ALAW compressed RAW10 data.<br/> After compression, pixels are coded on 8 bits.<br/> Data in memory is organized as regular RAW8 data.</p> <p>0x4: Outputs uncompressed RAW8 data.<br/> Data in memory is organized as regular RAW8 data</p> <p>0x5: Outputs uncompressed RAW10 data.<br/> Data in memory is organized as regular RAW10+EXP16 data</p> <p>0x6: Outputs uncompressed RAW10 data.<br/> Data in memory is organized as regular packed RAW10 data</p> <p>0x7: Outputs uncompressed RAW12 data.<br/> Data in memory is organized as regular RAW12+EXP16 data</p> <p>0x8: Outputs uncompressed RAW12 data.<br/> Data in memory is organized as regular packed RAW12 data</p> <p>0x9: Outputs uncompressed RAW14 data.</p> | RW   | 0x0   |
| 23:16 | FEC_NUMBER | Number of FEC to receive between using swap of CSI2_CTX_DAT_PING_ADDR and CSI2_CTX_DAT_PONG_ADDR for the calculation of the address in memory. (shall be used only in interlace mode, otherwise set to '1')                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0x01  |

| Bits | Field Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset |
|------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15:8 | COUNT        | <p>Sets the number of frame to acquire. Once the frame acquisition starts, the COUNT value is decremented after every frame. When COUNT reaches 0, the FRAME_NUMBER_IRQ interrupt is triggered and CTX_EN is set to '0'.</p> <p>Writes to this bit field are controlled by the COUNT_UNLOCK bit. During the same Interconnect write access , the bit-field COUNT_UNLOCK shall be written in addition to COUNT bit-field in order to change the COUNT value. COUNT can be overwritten dynamically with a new count value."</p> <p>0: Infinite number of frames (no count).</p> <p>1: 1 frame to acquire</p> <p>...</p> <p>255: 255 frames to acquire.</p> | RW   | 0x00  |
| 7    | EOF_EN       | <p>Indicates if the end of frame signal shall be asserted at the end of the line.</p> <p>Read 0x0: The end of frame signal is not asserted at the end of each frame.</p> <p>Read 0x1: The end of frame signal is asserted at the end of each frame.</p>                                                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0     |
| 6    | EOL_EN       | <p>Indicates if the end of line signal shall be asserted at the end of the line.</p> <p>Read 0x0: The end of line signal is not asserted at the end of each frame.</p> <p>Read 0x1: The end of line signal is asserted at the end of each frame.</p>                                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0     |
| 5    | CS_EN        | <p>Enables the checksum check for the received payload (long packet only).</p> <p>0x0: Disabled</p> <p>0x1: Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0     |
| 4    | COUNT_UNLOCK | <p>Unlock writes to the COUNT bit field.</p> <p>Write 0x0: COUNT bit field is locked. Writes have no effect</p> <p>Write 0x1: COUNT bit field is unlocked. Writes are possible.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | W    | 0     |
| 3    | PING_PONG    | <p>Indicates whether the PING or PONG destination address (CSI2_CTX_DAT_PING_ADDR or CSI2_CTX_DAT_PONG_ADDR) was used to write the last frame.</p> <p>This bit field toggles after every FEC_NUMBER FEC sync code received for the current context.</p> <p>Read 0x0: PING buffer</p> <p>Read 0x1: PONG buffer</p>                                                                                                                                                                                                                                                                                                                                        | R    | 1     |
| 2    | VP_FORCE     | <p>Forces sending of the data to both VPORT and Interconnect.</p> <p>Only applies to formats that exist in 2 versions:</p> <ul style="list-style-type: none"> <li>- one sending data to Interconnect port only</li> <li>- one sending data to VPORTonly (tagged with the +VP extension)</li> </ul> <p>The format version sending data only to Interconnect should be chosen.</p> <p>0x0: Disabled</p> <p>0x1: Enabled</p>                                                                                                                                                                                                                                | RW   | 0     |
| 1    | LINE_MODULO  | <p>Line modulo configuration</p> <p>0x0: CSI2_CTX_CTRL3.LINE_NUMBER is used once per frame for the generation of the LINE_NUMBER_IRQ.</p> <p>0x1: CSI2_CTX_CTRL3.LINE_NUMBER is used as a modulo number for the generation of the LINE_NUMBER_IRQ (multiple times the interrupt can be generated for each frame)</p>                                                                                                                                                                                                                                                                                                                                     | RW   | 0     |

| Bits | Field Name | Description                                          | Type | Reset |
|------|------------|------------------------------------------------------|------|-------|
| 0    | CTX_EN     | Enables the Context<br>0x0: Disabled<br>0x1: Enabled | RW   | 0     |

**Table 6-668. Register Call Summary for Register CSI2\_CTx\_CTRL1**

|                                                                                          |
|------------------------------------------------------------------------------------------|
| Camera ISP Environment                                                                   |
| • Camera ISP CSI2 Pixel Data Format: [0] [1]                                             |
| Camera ISP Integration                                                                   |
| • Camera ISP Interrupt Requests: [2]                                                     |
| Camera ISP Functional Description                                                        |
| • Camera ISP CSI2 Checksum: [3]                                                          |
| • Camera ISP CSI2 RAW Image Transcoding with DPCM and A-law Compression: [4] [5] [6] [7] |
| • Camera ISP CSI2 Virtual Channel and Context: [8] [9] [10] [11]                         |
| • Camera ISP CSI2 DMA Engine: [12] [13] [14] [15] [16] [17] [18]                         |
| • Camera ISP CSI2 EndOfFrame and EndOfLine Pulses: [19] [20]                             |
| Camera ISP Basic Programming Model                                                       |
| • Camera ISP CSI2 Enable Video/Picture Acquisition: [21] [22] [23] [24] [25]             |
| • Camera ISP CSI2 Disable Video/Picture Acquisition: [26]                                |
| • Camera ISP CSI2 Capture a Finite Number of Frames: [27] [28]                           |
| • Camera ISP CSI2 Configure a Periodic Event During Frame Acquisition: [29]              |
| • Camera ISP CSI2 Progressive and Interleaved Frame Configuration: [30]                  |
| Camera ISP Register Manual                                                               |
| • Camera ISP CSI2 REGS1 Register Summary: [31]                                           |

**Table 6-669. CSI2\_CTx\_CTRL2**

|                         |                                                                                                                                                                                                                                                                                                                       |                       |                 |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| Address Offset          | 0x0000 0074 + (x * 0x20)                                                                                                                                                                                                                                                                                              | Index                 | x = 0 to 7      |
| Physical Address        | See Table 6-638                                                                                                                                                                                                                                                                                                       | Instance              | See Table 6-80  |
| Description             | CONTROL REGISTER - Context<br>This register controls the Context. This register is shadowed: modifications are taken into account after the next FSC sync code (except for VIRTUAL_ID and FORMAT fields). The change of VIRTUAL_ID and FORMAT has to occur only when the context is disabled (CSI2_CTx_CTRL1.CTX_EN). |                       |                 |
| Type                    | RW                                                                                                                                                                                                                                                                                                                    |                       |                 |
| 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 |
| FRAME                   |                                                                                                                                                                                                                                                                                                                       |                       | FORMAT          |
| RESERVED                |                                                                                                                                                                                                                                                                                                                       |                       | DPCM_PRED       |
| USER_DEF_MAPPING        |                                                                                                                                                                                                                                                                                                                       |                       | VIRTUAL_ID      |

| Bits  | Field Name       | Description                                                                                                                                                               | Type | Reset  |
|-------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | FRAME            | Frame number received                                                                                                                                                     | R    | 0x0000 |
| 15    | RESERVED         | Write 0s for future compatibility. Read returns 0.                                                                                                                        | R    | 0      |
| 14:13 | USER_DEF_MAPPING | Selects the pixel format of USER_DEFINED in FORMAT<br>0x0: RAW6<br>0x1: RAW7<br>0x2: RAW8 (not valid if FORMAT is USER_DEFINED_8_BIT_DATA_TYPE_x_EXP8 with x from 1 to 8) | RW   | 0x0    |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 12:11       | VIRTUAL_ID        | Virtual channel ID<br>0x0: Virtual Channel ID 0<br>0x1: Virtual Channel ID 1<br>0x2: Virtual Channel ID 2<br>0x3: Virtual Channel ID 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW          | 0x0          |
| 10          | DPCM_PRED         | Selects the DPCM predictor.<br>0x0: The advanced predictor is used.<br>Not supported for 10 - 8 - 10 algorithm.<br>Performance limited to 1 pixel/cycle.<br>0x1: The simple predictor is used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW          | 0            |
| 9:0         | FORMAT            | Data format selection.<br>0x0: OTHERS (except NULL and BLANKING packets)<br>0x12: Embedded 8-bit non-image data (e.g. JPEG)<br>0x18: YUV420 8bit<br>0x19: YUV420 10bit<br>0x1A: YUV420 8bit legacy<br>0x1C: YUV420 8bit + CSPS<br>0x1D: YUV420 10bit + CSPS<br>0x1E: YUV422 8bit<br>0x1F: YUV422 10bit<br>0x22: RGB565<br>0x24: RGB888<br>0x28: RAW6<br>0x29: RAW7<br>0x2A: RAW8<br>0x2B: RAW10<br>0x2C: RAW12<br>0x2D: RAW14<br>0x33: RGB666 + EXP32_24<br>0x40: USER_DEFINED_8_BIT_DATA_TYPE_1<br>0x41: USER_DEFINED_8_BIT_DATA_TYPE_2<br>0x42: USER_DEFINED_8_BIT_DATA_TYPE_3<br>0x43: USER_DEFINED_8_BIT_DATA_TYPE_4<br>0x44: USER_DEFINED_8_BIT_DATA_TYPE_5<br>0x45: USER_DEFINED_8_BIT_DATA_TYPE_6<br>0x46: USER_DEFINED_8_BIT_DATA_TYPE_7<br>0x47: USER_DEFINED_8_BIT_DATA_TYPE_8<br>0x68: RAW6 + EXP8<br>0x69: RAW7 + EXP8<br>0x80: USER_DEFINED_8_BIT_DATA_TYPE_1 + EXP8<br>0x81: USER_DEFINED_8_BIT_DATA_TYPE_2 + EXP8<br>0x82: USER_DEFINED_8_BIT_DATA_TYPE_3 + EXP8<br>0x83: USER_DEFINED_8_BIT_DATA_TYPE_4 + EXP8<br>0x84: USER_DEFINED_8_BIT_DATA_TYPE_5 + EXP8<br>0x85: USER_DEFINED_8_BIT_DATA_TYPE_6 + EXP8<br>0x86: USER_DEFINED_8_BIT_DATA_TYPE_7 + EXP8<br>0x87: USER_DEFINED_8_BIT_DATA_TYPE_8 + EXP8<br>0x9E: YUV422 8bit + VP<br>0xA0: RGB444 + EXP16<br>0xA1: RGB555 + EXP16 | RW          | 0x000        |

| Bits | Field Name | Description                                                                                                                                          | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0xAB: RAW10 + EXP16                                                                                                                                  |      |       |
|      |            | 0xAC: RAW12 + EXP16                                                                                                                                  |      |       |
|      |            | 0xAD: RAW14 + EXP16                                                                                                                                  |      |       |
|      |            | 0xDE: Same as YUV422 8bit + VP but data is send as 16-bit wide words to video port.<br>Could be used together with the GENERIC and BYTESWAP features |      |       |
|      |            | 0xE3: RGB666 + EXP32                                                                                                                                 |      |       |
|      |            | 0xE4: RGB888 + EXP32                                                                                                                                 |      |       |
|      |            | 0xE8: RAW6 + DPCM10 + VP                                                                                                                             |      |       |
|      |            | 0x12A: RAW8 + VP                                                                                                                                     |      |       |
|      |            | 0x12C: RAW12 + VP                                                                                                                                    |      |       |
|      |            | 0x12D: RAW14 + VP                                                                                                                                    |      |       |
|      |            | 0x12F: RAW10 + VP                                                                                                                                    |      |       |
|      |            | 0x140:<br>USER_DEFINED_8_BIT_DATA_TYPE_1_DPCM12_VP                                                                                                   |      |       |
|      |            | 0x141:<br>USER_DEFINED_8_BIT_DATA_TYPE_2_DPCM12_VP                                                                                                   |      |       |
|      |            | 0x142:<br>USER_DEFINED_8_BIT_DATA_TYPE_3_DPCM12_VP                                                                                                   |      |       |
|      |            | 0x143:<br>USER_DEFINED_8_BIT_DATA_TYPE_4_DPCM12_VP                                                                                                   |      |       |
|      |            | 0x144:<br>USER_DEFINED_8_BIT_DATA_TYPE_5_DPCM12_VP                                                                                                   |      |       |
|      |            | 0x145:<br>USER_DEFINED_8_BIT_DATA_TYPE_6_DPCM12_VP                                                                                                   |      |       |
|      |            | 0x146:<br>USER_DEFINED_8_BIT_DATA_TYPE_7_DPCM12_VP                                                                                                   |      |       |
|      |            | 0x147:<br>USER_DEFINED_8_BIT_DATA_TYPE_8_DPCM12_VP                                                                                                   |      |       |
|      |            | 0x1C0:<br>USER_DEFINED_8_BIT_DATA_TYPE_1_DPCM12_EXP<br>16                                                                                            |      |       |
|      |            | 0x1C1:<br>USER_DEFINED_8_BIT_DATA_TYPE_2_DPCM12_EXP<br>16                                                                                            |      |       |
|      |            | 0x1C2:<br>USER_DEFINED_8_BIT_DATA_TYPE_3_DPCM12_EXP<br>16                                                                                            |      |       |
|      |            | 0x1C3:<br>USER_DEFINED_8_BIT_DATA_TYPE_4_DPCM12_EXP<br>16                                                                                            |      |       |
|      |            | 0x1C4:<br>USER_DEFINED_8_BIT_DATA_TYPE_5_DPCM12_EXP<br>16                                                                                            |      |       |
|      |            | 0x1C5:<br>USER_DEFINED_8_BIT_DATA_TYPE_6_DPCM12_EXP<br>16                                                                                            |      |       |
|      |            | 0x1C6:<br>USER_DEFINED_8_BIT_DATA_TYPE_7_DPCM12_EXP<br>16                                                                                            |      |       |
|      |            | 0x1C7:<br>USER_DEFINED_8_BIT_DATA_TYPE_8_DPCM12_EXP<br>16                                                                                            |      |       |
|      |            | 0x229: RAW7 + DPCM10 + EXP16                                                                                                                         |      |       |
|      |            | 0x2A8: RAW6 + DPCM10 + EXP16                                                                                                                         |      |       |
|      |            | 0x2AA: RAW8 + DPCM10 + EXP16                                                                                                                         |      |       |

| Bits | Field Name                                             | Description | Type | Reset |
|------|--------------------------------------------------------|-------------|------|-------|
|      | 0x2C0: USER_DEFINED_8_BIT_DATA_TYPE_1 + DPCM10 + EXP16 |             |      |       |
|      | 0x2C1: USER_DEFINED_8_BIT_DATA_TYPE_2 + DPCM10 + EXP16 |             |      |       |
|      | 0x2C2: USER_DEFINED_8_BIT_DATA_TYPE_3 + DPCM10 + EXP16 |             |      |       |
|      | 0x2C3: USER_DEFINED_8_BIT_DATA_TYPE_4 + DPCM10 + EXP16 |             |      |       |
|      | 0x2C4: USER_DEFINED_8_BIT_DATA_TYPE_5 + DPCM10 + EXP16 |             |      |       |
|      | 0x2C5: USER_DEFINED_8_BIT_DATA_TYPE_6 + DPCM10 + EXP16 |             |      |       |
|      | 0x2C6: USER_DEFINED_8_BIT_DATA_TYPE_7 + DPCM10 + EXP16 |             |      |       |
|      | 0x2C7: USER_DEFINED_8_BIT_DATA_TYPE_8 + DPCM10 + EXP16 |             |      |       |
|      | 0x329: RAW7 + DPCM10 + VP                              |             |      |       |
|      | 0x32A: RAW8 + DPCM10 + VP                              |             |      |       |
|      | 0x340: USER_DEFINED_8_BIT_DATA_TYPE_1 + DPCM10 + VP    |             |      |       |
|      | 0x341: USER_DEFINED_8_BIT_DATA_TYPE_2 + DPCM10 + VP    |             |      |       |
|      | 0x342: USER_DEFINED_8_BIT_DATA_TYPE_3 + DPCM10 + VP    |             |      |       |
|      | 0x343: USER_DEFINED_8_BIT_DATA_TYPE_4 + DPCM10 + VP    |             |      |       |
|      | 0x344: USER_DEFINED_8_BIT_DATA_TYPE_5 + DPCM10 + VP    |             |      |       |
|      | 0x345: USER_DEFINED_8_BIT_DATA_TYPE_6 + DPCM10 + VP    |             |      |       |
|      | 0x346: USER_DEFINED_8_BIT_DATA_TYPE_7 + DPCM10 + VP    |             |      |       |
|      | 0x347: USER_DEFINED_8_BIT_DATA_TYPE_8 + DPCM10 + VP    |             |      |       |
|      | 0x368: RAW6 DPCM12 + VP                                |             |      |       |
|      | 0x369: RAW7 DPCM12 + EXP16                             |             |      |       |
|      | 0x36A: RAW8 DPCM12 + EXP16                             |             |      |       |
|      | 0x3A8: RAW6 DPCM12 + EXP16                             |             |      |       |
|      | 0x3A9: RAW7 DPCM12 + VP                                |             |      |       |
|      | 0x3AA: RAW8 DPCM12 + VP                                |             |      |       |

**Table 6-670. Register Call Summary for Register CSI2\_CTx\_CTRL2**

## Camera ISP Environment

- [Camera ISP CSI2 Pixel Data Format: \[0\]](#)

## Camera ISP Functional Description

- [Camera ISP CSI2 RAW Image Transcoding with DPCM and A-law Compression: \[1\] \[2\]](#)
- [Camera ISP CSI2 Virtual Channel and Context: \[3\] \[4\] \[5\]](#)
- [Camera ISP CSI2 DMA Engine: \[6\]](#)
- [Camera ISP CSI2 Data Decompression: \[7\]](#)

## Camera ISP Basic Programming Model

- [Camera ISP CSI2 Linking a Context to a Virtual Channel and a Data Type: \[8\] \[9\]](#)

## Camera ISP Register Manual

- [Camera ISP CSI2 REGS1 Register Summary: \[10\]](#)

**Table 6-671. CSI2\_CTX\_DAT\_OFST**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |                                |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------|
| <b>Address Offset</b>   | 0x0000 0078 + (x * 0x20)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>Index</b>    | x = 0 to 7                     |
| <b>Physical Address</b> | See <a href="#">Table 6-638</a>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <b>Instance</b> | See <a href="#">Table 6-80</a> |
| <b>Description</b>      | <p>DATA MEM ADDRESS OFFSET REGISTER - Context</p> <p>This register sets the offset, which is applied on the destination address after each line is written to memory. This register applies for both <a href="#">CSI2_CTX_DAT_PING_ADDR</a> and <a href="#">CSI2_CTX_DAT_PONG_ADDR</a>.</p> <p>For example, it enables to perform 2D data transfers of the pixel data into a frame buffer. In such case, the pixel data and frame buffer data shall have the same data format.</p> <p>Note that the 5 LSBs are ignored: the offset shall be a multiple of 32 bytes.</p> <p>This register is shadowed: modifications are taken into account after the next FSC sync code. Only full 32-bit values shall be written.</p> |                 |                                |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |                                |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         | OFST                  | RESERVED        |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                     | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:17 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                              | R    | 0x0000 |
| 16:5  | OFST       | Line offset programmed in bytes (signed value 2's complement).<br>If OFST = 0, the data is written contiguously in memory.<br>Otherwise, OFST sets the destination offset between the first pixel of the previous line and the first pixel of the current line. | RW   | 0x000  |
| 4:0   | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                              | R    | 0x00   |

**Table 6-672. Register Call Summary for Register CSI2\_CTX\_DAT\_OFST**

Camera ISP Functional Description

- [Camera ISP CSI2 Progressive Frame to Progressive Storage: \[0\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CSI2 Enable Video/Picture Acquisition: \[1\]](#)

Camera ISP Register Manual

- [Camera ISP CSI2 REGS1 Register Summary: \[2\]](#)

**Table 6-673. CSI2\_CTX\_DAT\_PING\_ADDR**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                 |                                |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------|
| <b>Address Offset</b>   | 0x0000 007C + (x * 0x20)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <b>Index</b>    | x = 0 to 7                     |
| <b>Physical Address</b> | See <a href="#">Table 6-638</a>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>Instance</b> | See <a href="#">Table 6-80</a> |
| <b>Description</b>      | <p>DATA MEM PING ADDRESS REGISTER - Context</p> <p>This register sets the 32-bit memory address where the pixel data are stored. The destination is double buffered: this register sets the PING address. Double buffering is enabled when the addresses <a href="#">CSI2_CTX_DAT_PING_ADDR</a> and <a href="#">CSI2_CTX_DAT_PONG_ADDR</a> are different.</p> <p>Note that the 5 LSBs are ignored: the address shall be aligned on a 32-byte boundary.</p> <p>This register is shadowed: modifications are taken into account after the next FSC sync code. Only full 32-bit values shall be written.</p> |                 |                                |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |                                |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| ADDR                    |                         |                       | RESERVED        |

| Bits | Field Name | Description                                        | Type | Reset     |
|------|------------|----------------------------------------------------|------|-----------|
| 31:5 | ADDR       | 27 most significant bits of the 32-bit address.    | RW   | 0x0000000 |
| 4:0  | RESERVED   | Write 0s for future compatibility. Read returns 0. | R    | 0x00      |

**Table 6-674. Register Call Summary for Register CSI2\_CTx\_DAT\_PING\_ADDR**

Camera ISP Functional Description

- [Camera ISP CSI2 DMA Engine: \[0\] \[1\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CSI2 Enable Video/Picture Acquisition: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP CSI2 REGS1 Register Summary: \[3\]](#)
- [Camera ISP CSI2 REGS1 Register Description: \[4\] \[5\]](#)

**Table 6-675. CSI2\_CTx\_DAT\_PONG\_ADDR**

| <b>Address Offset</b>   | 0x0000 0080 + (x * 0x20)        | <b>Index</b>                                       | x = 0 to 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |
|-------------------------|---------------------------------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| <b>Physical Address</b> | See <a href="#">Table 6-638</a> | <b>Instance</b>                                    | See <a href="#">Table 6-80</a>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |           |
| <b>Description</b>      |                                 |                                                    | DATA MEM PONG ADDRESS REGISTER - Context<br>This register sets the 32-bit memory address where the pixel data are stored. The destination is double buffered: this register sets the PONG address. Double buffering is enabled when the addresses CSI2_CTX_DAT_PING_ADDR and CSI2_CTX_DAT_PONG_ADDR are different.<br>Note that the 5 LSBs are ignored: the address shall be aligned on a 32-byte boundary.<br>This register is shadowed: modifications are taken into account after the next FSC sync code. Only full 32-bit values shall be written. |           |
| <b>Type</b>             | RW                              |                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |
| ADDR                    |                                 |                                                    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |
| Bits                    | Field Name                      | Description                                        | Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset     |
| 31:5                    | ADDR                            | 27 most significant bits of the 32-bit address.    | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0000000 |
| 4:0                     | RESERVED                        | Write Os for future compatibility. Read returns 0. | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x00      |

**Table 6-676. Register Call Summary for Register CSI2\_CTx\_DAT\_PONG\_ADDR**

Camera ISP Functional Description

- [Camera ISP CSI2 DMA Engine: \[0\] \[1\]](#)

Camera ISP Basic Programming Model

- [Camera ISP CSI2 Enable Video/Picture Acquisition: \[2\]](#)

Camera ISP Register Manual

- [Camera ISP CSI2 REGS1 Register Summary: \[3\]](#)
- [Camera ISP CSI2 REGS1 Register Description: \[4\] \[5\]](#)

**Table 6-677. CSI2\_CTx\_IRQENABLE**

|                         |                                 |                 |                                                                                                  |
|-------------------------|---------------------------------|-----------------|--------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0084 + (x * 0x20)        | <b>Index</b>    | x = 0 to 7                                                                                       |
| <b>Physical Address</b> | See <a href="#">Table 6-638</a> | <b>Instance</b> | See <a href="#">Table 6-80</a>                                                                   |
| <b>Description</b>      |                                 |                 | INTERRUPT ENABLE REGISTER - Context<br>This register regroups all the events related to Context. |
| <b>Type</b>             |                                 |                 | RW                                                                                               |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

RESERVED

| Bits | Field Name         | Description                                                                                                                                                 | Type | Reset    |
|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                          | R    | 0x000000 |
| 8    | ECC_CORRECTION_IRQ | Context - ECC has been used to correct the only 1-bit error (long packet only).<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0        |
| 7    | LINE_NUMBER_IRQ    | Context - Line number is reached.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                               | RW   | 0        |
| 6    | FRAME_NUMBER_IRQ   | Context - Frame counter reached.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                | RW   | 0        |
| 5    | CS_IRQ             | Context - Check-Sum of the payload mismatch detection<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                           | RW   | 0        |
| 4    | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                          | R    | 0        |
| 3    | LE_IRQ             | Context - Line end sync code detection.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                         | RW   | 0        |
| 2    | LS_IRQ             | Context - Line start sync code detection.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                       | RW   | 0        |
| 1    | FE_IRQ             | Context - Frame end sync code detection.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                        | RW   | 0        |
| 0    | FS_IRQ             | Context - Frame start sync code detection.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                      | RW   | 0        |

**Table 6-678. Register Call Summary for Register CSI2\_CTx\_IRQENABLE**

## Camera ISP Integration

- Camera ISP Interrupt Requests: [0] [1] [2] [3] [4] [5] [6] [7] [8]

## Camera ISP Functional Description

- Camera ISP CSI2 ECC: [9]
- Camera ISP CSI2 Checksum: [10]

## Camera ISP Register Manual

- Camera ISP CSI2 REGS1 Register Summary: [11]

**Table 6-679. CSI2\_CTx\_IRQSTATUS**

|                         |                                                                                                  |                 |                                |
|-------------------------|--------------------------------------------------------------------------------------------------|-----------------|--------------------------------|
| <b>Address Offset</b>   | 0x0000 0088 + (x * 0x20)                                                                         | <b>Index</b>    | x = 0 to 7                     |
| <b>Physical Address</b> | See <a href="#">Table 6-638</a>                                                                  | <b>Instance</b> | See <a href="#">Table 6-80</a> |
| <b>Description</b>      | INTERRUPT STATUS REGISTER - Context<br>This register regroups all the events related to Context. |                 |                                |
| <b>Type</b>             | RW                                                                                               |                 |                                |



| Bits | Field Name         | Description                                                                                                                                                                                                                                         | Type          | Reset     |
|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------|
| 31:9 | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                  | R             | 0x0000000 |
| 8    | ECC_CORRECTION_IRQ | Context - ECC has been used to do the correction of the only 1-bit error status (long packet only).<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0         |
| 7    | LINE_NUMBER_IRQ    | Context - Line number reached status.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                               | RW<br>W1toClr | 0         |
| 6    | FRAME_NUMBER_IRQ   | Context - Frame counter reached status<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                              | RW<br>W1toClr | 0         |
| 5    | CS IRQ             | Context - Check-Sum mismatch status.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                | RW<br>W1toClr | 0         |
| 4    | RESERVED           | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                  | R             | 0         |
| 3    | LE IRQ             | Context - Line end sync code detection status.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                      | RW<br>W1toClr | 0         |
| 2    | LS IRQ             | Context - Line start sync code detection status.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                    | RW<br>W1toClr | 0         |

| Bits | Field Name | Description                                                                                                                                                                                       | Type          | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------|
| 1    | FE_IRQ     | Context - Frame end sync code detection status.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.   | RW<br>W1toClr | 0     |
| 0    | FS_IRQ     | Context - Frame start sync code detection status.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW<br>W1toClr | 0     |

**Table 6-680. Register Call Summary for Register CSI2\_CTLx\_IRQSTATUS**

## Camera ISP Integration

- Camera ISP Interrupt Requests: [0] [1] [2] [3] [4] [5] [6] [7] [8]

## Camera ISP Functional Description

- Camera ISP CSI2 ECC: [9]
- Camera ISP CSI2 Checksum: [10]
- Camera ISP CSI2 Virtual Channel and Context: [11] [12]

## Camera ISP Basic Programming Model

- Camera ISP CSI2 Enable Video/Picture Acquisition: [13]

## Camera ISP Register Manual

- Camera ISP CSI2 REGS1 Register Summary: [14]

**Table 6-681. CSI2\_CTLx\_CTRL3**

| Address Offset          | 0x0000 008C + (x * 0x20)                                                                                                                                        | Index                 | x = 0 to 7      |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| Physical Address        | See Table 6-638                                                                                                                                                 | Instance              | See Table 6-80  |
| Description             | CONTROL REGISTER - Context<br>This register controls the Context. This register is shadowed: modifications are taken into account after the next FSC sync code. |                       |                 |
| Type                    | RW                                                                                                                                                              |                       |                 |
| 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 |
| RESERVED                | ALPHA                                                                                                                                                           | LINE_NUMBER           |                 |

| Bits  | Field Name  | Description                                        | Type | Reset  |
|-------|-------------|----------------------------------------------------|------|--------|
| 31:30 | RESERVED    | Write 0s for future compatibility. Read returns 0. | R    | 0x0    |
| 29:16 | ALPHA       | Alpha value for RGB888, RGB666 and RGB444.         | RW   | 0x0000 |
| 15:0  | LINE_NUMBER | Line number for the interrupt generation           | RW   | 0x0000 |

**Table 6-682. Register Call Summary for Register CSI2\_CTLx\_CTRL3**

## Camera ISP Environment

- Camera ISP CSI2 Pixel Data Format: [0] [1] [2]

## Camera ISP Integration

- Camera ISP Interrupt Requests: [3]

## Camera ISP Functional Description

- Camera ISP CSI2 Virtual Channel and Context: [4]

**Table 6-682. Register Call Summary for Register CSI2\_CTLx\_CTRL3 (continued)**

Camera ISP Basic Programming Model

- [Camera ISP CSI2 Enable Video/Picture Acquisition: \[5\]](#)
- [Camera ISP CSI2 Configure a Periodic Event During Frame Acquisition: \[6\]](#)

Camera ISP Register Manual

- [Camera ISP CSI2 REGS1 Register Summary: \[7\]](#)

### 6.6.10.3 Camera ISP CSI2 REGS2 Register Summary

**Table 6-683. CAMERA\_ISP\_CSI2\_REGS2 Registers Mapping Summary**

| Register Name         | Type | Register Width (Bits) | Address Offset          | CAMERA_ISP_CSI2A_REGS2 L3 Base Address | CAMERA_ISP_CSI2C_REGS2 L3 Base Address |
|-----------------------|------|-----------------------|-------------------------|----------------------------------------|----------------------------------------|
| CSI2_CTLx_TRANS_CODEH | RW   | 32                    | 0x0000 0000 + (x * 0x8) | 0x480B D9C0 + (x * 0x8)                | 0x480B DDC0 + (x * 0x8)                |
| CSI2_CTLx_TRANS_CODEV | RW   | 32                    | 0x0000 0004 + (x * 0x8) | 0x480B D9C4 + (x * 0x8)                | 0x480B DDC4 + (x * 0x8)                |

### 6.6.10.4 Camera ISP CSI2 REGS2 Register Description

**Table 6-684. CSI2\_CTLx\_TRANSCODEH**

|                         |                                                                     |                       |                 |
|-------------------------|---------------------------------------------------------------------|-----------------------|-----------------|
| Address Offset          | 0x0000 0000 + (x * 0x8)                                             | Index                 | x = 0 to 7      |
| Physical Address        | See <a href="#">Table 6-683</a>                                     |                       |                 |
| Description             | Transcode configuration register: defines horizontal frame cropping |                       |                 |
| Type                    | RW                                                                  |                       |                 |
| 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 |
| RESERVED                | HCOUNT                                                              | RESERVED              | HSKIP           |

| Bits  | Field Name | Description                                                                                                                                                                             | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:29 | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                                                                                      | R    | 0x0    |
| 28:16 | HCOUNT     | Pixels to output per line when the values is between 1 and 8191.<br>Pixels HSKIP-WIDTH pixels are output when HCOUNT=0.<br>WIDTH corresponds to the image width provided by the sensor. | RW   | 0x0000 |
| 15:13 | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                                                                                      | R    | 0x0    |
| 12:0  | HSKIP      | Pixel to skip horizontally.<br>Valid values: 0-8191                                                                                                                                     | RW   | 0x0000 |

**Table 6-685. Register Call Summary for Register CSI2\_CTLx\_TRANSCODEH**

Camera ISP Functional Description

- [Camera ISP CSI2 RAW Image Transcoding with DPCM and A-law Compression: \[0\] \[1\] \[2\]](#)

Camera ISP Register Manual

- [Camera ISP CSI2 REGS2 Register Summary: \[3\]](#)

**Table 6-686. CSI2\_CTx\_TRANSCODEV**

|                         |                                                                   |                       |                 |
|-------------------------|-------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0004 + (x * 0x8)                                           | <b>Index</b>          | x = 0 to 7      |
| <b>Physical Address</b> | See <a href="#">Table 6-683</a>                                   |                       |                 |
| <b>Description</b>      | Transcode configuration register: defines vertical frame cropping |                       |                 |
| <b>Type</b>             | RW                                                                |                       |                 |
| 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 |
| RESERVED                | VCOUNT                                                            | RESERVED              | VSKIP           |

| Bits  | Field Name | Description                                                                                                                                                                                | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:29 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                         | R    | 0x0    |
| 28:16 | VCOUNT     | Lines to output per frame when the values is between 1 and 8191.<br>Pixels VSKIP-HEIGHT pixels are output when VCOUNT=0.<br>HEIGHT corresponds to the image height provided by the sensor. | RW   | 0x0000 |
| 15:13 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                         | R    | 0x0    |
| 12:0  | VSKIP      | Pixel to skip vertically<br>Valid values: 0-8191                                                                                                                                           | RW   | 0x0000 |

**Table 6-687. Register Call Summary for Register CSI2\_CTx\_TRANSCODEV**

Camera ISP Functional Description

- Camera ISP CSI2 RAW Image Transcoding with DPCM and A-law Compression: [\[0\]](#) [\[1\]](#) [\[2\]](#) [\[3\]](#)

Camera ISP Register Manual

- Camera ISP CSI2 REGS2 Register Summary: [\[4\]](#)

## 6.6.11 Camera ISP CSIPHY Registers

### 6.6.11.1 Camera ISP CSIPHY Register Summary

**Table 6-688. CAMERA\_ISP\_CSIPHY Registers Mapping Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | CAMERA_ISP_CSI PHY2 L3 Base Address | CAMERA_ISP_CSI PHY1 L3 Base Address |
|---------------|------|-----------------------|----------------|-------------------------------------|-------------------------------------|
| CSIPHY_REG0   | RW   | 32                    | 0x0000 0000    | 0x480B D970                         | 0x480B DD70                         |
| CSIPHY_REG1   | RW   | 32                    | 0x0000 0004    | 0x480B D974                         | 0x480B DD74                         |
| CSIPHY_REG2   | RW   | 32                    | 0x0000 0008    | 0x480B D978                         | 0x480B DD78                         |

### 6.6.11.2 Camera ISP CSIPHY Register Description

**Table 6-689. CSIPHY\_REG0**

| <b>Address Offset</b>   | 0x0000 0000                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |       |            |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------|------------|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | See <a href="#">Table 6-688</a> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |       |            |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | First Register                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |       |            |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |       |            |  |  |  |  |  |  |  |  |  |
| 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 |       |            |  |  |  |  |  |  |  |  |  |
| RESERVED                | HSCLOCKCONFIG                   | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | THS_TERM        |       | THS_SETTLE |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Type            | Reset |            |  |  |  |  |  |  |  |  |  |
| 31:25                   | RESERVED                        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | NA              | 0x00  |            |  |  |  |  |  |  |  |  |  |
| 24                      | HSCLOCKCONFIG                   | Disable clock missing detector                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW              | 0     |            |  |  |  |  |  |  |  |  |  |
| 23:16                   | RESERVED                        | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R               | 0x00  |            |  |  |  |  |  |  |  |  |  |
| 15:8                    | THS_TERM                        | Ths-term timing parameter in multiples of CSI2_96M_FCLK period.<br>Requirement from DSI_PHY spec = (Dn Voltage 450 mV) –35 ns + 4 UI.<br>Effective time for enabling termination = synchronizer delay + timer delay + LPRx delay + combinatorial routing delay ~ (1–2)*DDRCLK + Ths-term + ~ (1–15) ns.<br>Programmed value = ceil(12.5 ns/DDRClk period)–1.<br>Default value: 4 for 400 MHz.<br><b>Note:</b> 20 percent clock frequency tolerance.                                                                                                                                                                                              | RW              | 0x04  |            |  |  |  |  |  |  |  |  |  |
| 7:0                     | THS_SETTLE                      | Ths-settle timing parameter in multiples of DDR clock period.<br>Derived requirement from DSI_PHY spec = (90 ns + 6 UI) – (145 ns + 10 UI).<br>Effective Ths-settle seen on the line (starting to look for sync pattern) = synchronizer delay + timer delay + LPRx delay + combinatorial routing delay – pipeline delay in HS data path.<br>~ (1–2)*DDRCLK + Ths-settle + ~ (1–15) ns – 1*DDRClk<br>Programmed value = ceil(90 ns/DDR clock period)+3.<br>Default value: 39 for 400 MHz.<br><b>Note:</b><br>1. Minimum supported Ths-settle preprogrammed value = 3.<br>2. One clock delay in datapath from HSRx must be compensated. Hence + 3. | RW              | 0x27  |            |  |  |  |  |  |  |  |  |  |

**Table 6-690. Register Call Summary for Register CSIPHY\_REG0**

## Camera ISP Basic Programming Model

- [Camera ISP CSIPHY Initialization for Work With CSI2 Receiver: \[0\]](#)

## Camera ISP Register Manual

- [Camera ISP CSIPHY Register Summary: \[1\]](#)

**Table 6-691. CSIPHY\_REG1**

|                       |                 |                         |                                 |                 |                                |
|-----------------------|-----------------|-------------------------|---------------------------------|-----------------|--------------------------------|
| <b>Address Offset</b> | 0x0000 0004     | <b>Physical Address</b> | See <a href="#">Table 6-688</a> | <b>Instance</b> | See <a href="#">Table 6-80</a> |
| <b>Description</b>    | Second Register |                         |                                 |                 |                                |
| <b>Type</b>           | RW              |                         |                                 |                 |                                |

| 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 |
|----------|------------------------|--------------------|----------|----------------------------|-----------|----------------------|-----------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED | RESETDONECSI2_96M_FCLK | RESETDONERXBYTECLK | RESERVED | CLOCK_MISS_DETECTOR_STATUS | TCLK_TERM | DPHY_HS_SYNC_PATTERN | TCLK_MISS | TCLK_SETTLE |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset |
|-------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED                   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                            | R    | 0x0   |
| 29    | RESETDONECSI2_96M_FCLK     | Reset Done flag for the CSI2_96M_FCLK domain<br>Read 0x0: Reset in progress<br>Read 0x1: Reset completed                                                                                                                                                                                                                                                                                                                                                      | R    | 0x-   |
| 28    | RESETDONERXBYTECLK         | Reset Done flag for the RxByteClkHS clock domain<br>Read 0x0: Reset in progress<br>Read 0x1: Reset completed                                                                                                                                                                                                                                                                                                                                                  | R    | 0x-   |
| 27:26 | RESERVED                   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0x0   |
| 25    | CLOCK_MISS_DETECTOR_STATUS | 1:Error in clock missing detector. 0:Clock missing detector successful                                                                                                                                                                                                                                                                                                                                                                                        | R    | 0     |
| 24:18 | TCLK_TERM                  | Tclk-term timing parameter in multiples of CSI2_96M_FCLK period.<br>Requirement from DSI_PHY spec = (Dn Voltage 450 mV) -55 ns.<br>Effective time for enabling termination = synchronizer delay + timer delay + LPRx delay + combinatorial routing delay<br>~ (1-2)*CSI2_96M_FCLK + Tclk-term + ~ (1-15) ns.<br>Programmed value = ceil(9.5 ns/CSI2_96M_FCLK period)-1).<br>Default value: 0 for 96 MHz.<br><b>Note:</b> 5 percent clock frequency tolerance. | RW   | 0x00  |
| 17:10 | DPHY_HS_SYNC_PATTERN       | DPHY mode HS sync pattern in byte order(reverse of received order)                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0xB8  |
| 9:8   | TCLK_MISS                  | Tclk-miss timing parameter in multiples of CSI2_96M_FCLK period<br>Programmed value = ceil(15 ns/CSI2_96M_FCLK period)-1<br>Default value: 1 for 96 MHz                                                                                                                                                                                                                                                                                                       | RW   | 0x1   |

| Bits | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Type | Reset |
|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:0  | TCLK_SETTLE | <p>Tclk-settle timing parameter in multiples of CSI2_96M_FCLK period.<br/>           Derived requirement from DSI_PHY spec = 145 ns –435 ns.<br/>           Effective Ths-settle = synchronizer delay + timer delay + LPRx delay + combinatorial routing delay ~ (1–2)*CSI2_96M_FCLK + Tclk-settle + ~ (1–15) ns.<br/>           Programmed value = max(3, ceil(155 ns/CSI2_96M_FCLK period)–1).<br/>           Default value: 14 for 96 MHz.<br/> <b>Note:</b> 5 percent clock frequency tolerance</p> | RW   | 0x0E  |

**Table 6-692. Register Call Summary for Register CSIPHY\_REG1**

Camera ISP Basic Programming Model

- [Camera ISP CSIPHY Initialization for Work With CSI2 Receiver: \[0\]](#)

Camera ISP Register Manual

- [Camera ISP CSIPHY Register Summary: \[1\]](#)

**Table 6-693. CSIPHY\_REG2**

|                         |                         |                        |                        |                                 |                   |                                |
|-------------------------|-------------------------|------------------------|------------------------|---------------------------------|-------------------|--------------------------------|
| Address Offset          | 0x0000 0008             |                        | Physical Address       | See <a href="#">Table 6-688</a> | Instance          | See <a href="#">Table 6-80</a> |
| Description             | Third register          |                        | Type                   | RW                              |                   |                                |
|                         |                         |                        |                        |                                 |                   |                                |
| 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        |                                 |                   |                                |
| TRIGGER_CMD_RXTRIGESC0  | TRIGGER_CMD_RXTRIGESC1  | TRIGGER_CMD_RXTRIGESC2 | TRIGGER_CMD_RXTRIGESC3 |                                 | CCP2_SYNC_PATTERN |                                |

| Bits  | Field Name             | Description                                                         | Type | Reset    |
|-------|------------------------|---------------------------------------------------------------------|------|----------|
| 31:30 | TRIGGER_CMD_RXTRIGESC0 | Mapping of Trigger escape entry command to PPI output RXTRIGGERESC0 | RW   | 0x0      |
| 29:28 | TRIGGER_CMD_RXTRIGESC1 | Mapping of Trigger escape entry command to PPI output RXTRIGGERESC1 | RW   | 0x0      |
| 27:26 | TRIGGER_CMD_RXTRIGESC2 | Mapping of Trigger escape entry command to PPI output RXTRIGGERESC2 | RW   | 0x0      |
| 25:24 | TRIGGER_CMD_RXTRIGESC3 | Mapping of Trigger escape entry command to PPI output RXTRIGGERESC3 | RW   | 0x0      |
| 23:0  | CCP2_SYNC_PATTERN      | CCP2 mode sync pattern in byte order                                | R    | 0x0000FF |

**Table 6-694. Register Call Summary for Register CSIPHY\_REG2**

Camera ISP Basic Programming Model

- [Camera ISP CSIPHY Initialization for Work With CSI2 Receiver: \[0\]](#)

Camera ISP Register Manual

- [Camera ISP CSIPHY Register Summary: \[1\]](#)



## Display Subsystem

This chapter describes the Display Subsystem for the device.

---

**NOTE:** This document is strictly for wireless/cellular software developers using AM/DM37x application processors, which are not available for the broad market through authorized distributors.

---

**NOTE:** This chapter contains information that is ©2005-2008 MIPI Alliance, Inc. All rights reserved. MIPI Alliance Member Confidential.

All rights reserved. This material is reprinted with the permission of the MIPI Alliance, Inc. No part(s) of this document may be disclosed, reproduced or used for any purpose other than as needed to support the use of the products of TI.

See [Device 37xx MIPI Disclaimer](#) for details.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                                         | Page        |
|---------------------------------------------------------------|-------------|
| <b>7.1    Display Subsystem Overview .....</b>                | <b>1556</b> |
| <b>7.2    Display Subsystem Environment .....</b>             | <b>1561</b> |
| <b>7.3    Display Subsystem Integration .....</b>             | <b>1613</b> |
| <b>7.4    Display Subsystem Functional Description .....</b>  | <b>1630</b> |
| <b>7.5    Display Subsystem Basic Programming Model .....</b> | <b>1705</b> |
| <b>7.6    Display Subsystem Use Cases and Tips .....</b>      | <b>1777</b> |
| <b>7.7    Display Subsystem Register Manual .....</b>         | <b>1813</b> |

## 7.1 Display Subsystem Overview

The display subsystem provides the logic to display a video frame from the memory frame buffer (either SDRAM or SRAM) on a liquid-crystal display (LCD) panel or a TV set. The display subsystem integrates the following elements:

- Display controller (DISPC) module
- Remote frame buffer interface (RFBI) module
- Display serial interface (DSI) complex I/O module and a DSI protocol engine
- DSI PLL controller that drives a DSI PLL and high-speed (HS) divider.
- NTSC/PAL video encoder

The display controller and the DSI protocol engine are connected to the L3 and L4 interconnect; the RFBI and the TV out encoder modules are connected to the L4 interconnect.

---

**NOTE:** The DSI complex I/O module, and the DSI PLL controller are not connected to an L3 or L4 interconnect. Specific display subsystem registers manage their programmable features.

---

Figure 7-1 shows a block diagram of the display subsystem.

**Figure 7-1. Display Subsystem Highlight**


**NOTE:** For more information about connecting the LOCK, RECAL, and TVINT signals through the GPIO2 and GPIO3 modules, see [Chapter 25, GPIO](#).

The display subsystem includes the following main features:

- Display controller
  - Display modes
    - Programmable pixel display modes (1, 2, 4, 8, 12, 16, and 24 bits-per-pixel [BPP] modes)
    - Programmable display size supported:

- XGA - 1024 x 768 VESA timings at 60 fps (pixel clock = 63.5 MHz)
- WXGA - 1280 x 800 VESA timings at 59.91 fps (pixel clock = 71 MHz)
- SXGA+ - 1400 x 1050 direct drive of LCD with minimal blanking at 50 fps (pixel clock = 75 MHz)
- HD 720p - 1280 x 720 at 60 fps (pixel clock = 74.25 MHz)
- 256 x 24-bit entries palette in red, green, and blue (RGB)
- Programmable pixel rate up to 75 MHz

---

**NOTE:** The panel size is programmable and can be any width that is a multiple of 8 pixels (line length) in the range [1:2048] pixels (in the case of the RFBI mode, the minimum transfer size is a byte). The maximum resolution is 2048 (lines) x 2048 (pixels).

---

- Display support
  - Four types of displays are supported: Passive (super-twist nematic [STN]) and active (thin-film transistor [TFT]) colors, passive (STN), and active (TFT) monochromes.
  - 4-/8-bit monochrome passive matrix panel interface support (15 grayscale levels supported using dithering block)
  - 8-bit color passive matrix panel interface support (3375 colors supported for a color panel using dithering block)
  - 12-/16-/18-/24-bit active matrix panel interface support (replicated or dithered encoded pixel values)
  - Remote frame buffer support through the RFBI module
  - Partial display through the RFBI module
  - Second 24-bit digital output
  - Multiple-cycle output format on 8-/9-/12-/16-bit interface time division multiplexing (TDM)
  - HDMI through external bridge
- Signal processing
  - Overlay support for graphics (ARGB, RGBA, RGB, or Color Look-Up Table (CLUT)) and video1 (YCbCr 4:2:2, RGB), video2 (YCbCr 4:2:2, or ARGB, RGBA, RGB)
  - Programmable video resizer independent horizontal and vertical resampling: Upsampling (up to x8) and downsampling (down to 1/4), maximum input width of 1024 pixels in 5-tap mode, and 2048 pixels in 3-tap configurations; no limitation on input height
  - Rotation 90-, 180-, and 270-degrees with DISPC DMA engine
  - Transparency color key (source and destination)
  - Synchronized buffer update
  - Programmable video color space conversion YCbCr 4:2:2 into RGB
  - Hardware cursor
  - Gamma curve support on LCD output
  - Multiple-buffer support
  - Mirroring support
  - Programmable color phase rotation (CPR)
  - Alpha blending support (no rescaling in ARGB or RGBA formats), with pre-multiplied alpha control
- Advanced
  - Self-refresh using the DMA FIFO
  - Arbitration between high/low priority (graphics video1 and video2)
  - FIFO handcheck in STALL mode
  - Power modes: Low-power saving modes
  - RFBI (MIPI® DBI protocol)

- Access to remote frame buffer (RFB) direct microprocessor unit (MPU) interface
  - Sends commands to the RFB panel through the L4 interconnect
  - Sends data, received from the display controller or from the MPU through the DISPC pixel data bus, to the RFB panel
  - Reads data/status from the RFB to the L4 interconnect
- RFB interface
  - 8-/9-/12-/16-bit 8086-series parallel interface
  - Two programmable configurations for two devices connected to the RFBI module
- Data formats
  - Programmable pixel modes (12-/16-/18-/24-BPP modes in RGB format)
  - Programmable output formats on one/multiple cycles per pixel (data from the display controller and from the L4 interconnect)
- Interconnect/FIFO
  - One slave port with DMA request and interconnect FIFO of 24x32-bit depth (for write access to DSS.[RFBI\\_DATA](#) register only)
  - One video port FIFO of 8 × 24-bit depth receiving data from the display controller
- MIPI DSI
  - Transfer pixels and data received on the video port or L4 interconnect to the display through the DSI DSI\_PHY
  - The maximum resolution supported on the video port is XGA at 60 fps with 24-bit pixels (maximum pixel clock of 67 MHz) for low voltage.
  - Supports video mode and command mode
  - Bidirectional data link support (only one data lane is used in reverse direction in command mode)
  - Supports up to two data-configurable lanes, in addition to the clock signaling (minimum of one data link and maximum of two, depending on speed, signal integrity requirements, and number of displays)
  - Maximum data rate of up to 900 Mbps per data pair
  - Data splitter for 2-data lane configuration
  - Error-correction code (ECC) and check-sum generation
  - Burst support for the video mode
  - RGB16, RGB18 packed and nonpacked, and RGB24 formats supported for video mode
  - Serial configuration port (SCP) for the DSI\_PHY complex I/O and DSI PLL
  - Connection to the DSI\_PHY complex I/O through PPI
  - Data interleaving support for one synchronous stream (video mode) from the display controller and up to three interleaved asynchronous streams (command mode) from the interconnect concurrently
  - Data interleaving supports up to four interleaved asynchronous streams (command mode) from the interconnect or video port when there is no video mode
  - MIPI DCS support (transparent to the protocol engine, no decoding and interpretation of the information from and to the peripheral)
  - Supports selection between low-power state and HS mode between HS packet transfers
  - Generic data type (DT) support

---

**NOTE:** The DSI pins are multiplexed with LCD parallel outputs.

---

- Video encoder
  - NTSC/PAL encoder outputs with the following standards:
    - NTSC-J, M
    - PAL-B, D, G, H, I

- PAL-M
- CGMS-A as described in the CEA-608-x Standard.
- Input data interface compatible with the following protocols:
  - 24-bit input bus compatible with external sync
  - RGB 4:4:4
- Dual output data 10-bit interface for two internal digital-to-analog converters (DACs) that support:
  - Composite video (CVBS)
  - Separate video (S-video)
- TV output data supports ITU-R BT 470-7 recommendation standard for consumer market
- Master clock input 13.5 MHz, 27 MHz (supports ITU-R 601 sampling for NTSC/PAL), and 54 MHz
- Programmable horizontal sync, vertical timing, and waveforms
- Programmable subcarrier frequency and SCH
- Internal test pattern generation (color bar, flat field, color burst)
- 2x/4x oversampling
- Supports square pixel sampling (NTSC: 12.27 MHz, 24.54 MHz, 49.09 MHz PAL: 14.75 MHz, 29.5 MHz, 59 MHz)

**CAUTION**

In square pixel mode, an external clock generator is required to provide sampling frequencies.

- TV detection gating pulse generation

## 7.2 Display Subsystem Environment

This section describes the two main functions handled by the display subsystem:

- LCD support
- TV display support

### 7.2.1 LCD Support

LCD panels can be connected to the display subsystem of the device using parallel and/or serial interfaces.

[Table 7-1](#) provides more details on the supported interfaces to LCD panels, and the respective pad and signal configurations.

Table 7-1. LCD Interface Signals and Configurations

|                                     |                   | Pads and Signals Configuration    |                                |                        |                                        |                                | Possible Operational Interfaces                                                        |                                                                                        |                                                                                          |
|-------------------------------------|-------------------|-----------------------------------|--------------------------------|------------------------|----------------------------------------|--------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| Pad names at device level boundary. | Pads Property     | Basic signal multiplexing on pads |                                |                        | Additional signal multiplexing on pads |                                | Simultaneous                                                                           |                                                                                        | Sequential                                                                               |
|                                     |                   | Parallel Interface, Bypass Mode.  | Parallel Interface, RFBI mode. | Serial Interface, DSI. | Parallel Interface, Bypass Mode.       | Parallel Interface, RFBI mode. | "1. Parallel Interface, Bypass mode 24-bit<br>2. Serial Interface, DSI (2 data lanes)" | "1. Parallel Interface, RFBI-0 mode 16-bit<br>2. Serial Interface, DSI (2 data lanes)" | "1. Parallel Interface, RFBI-0 mode 16-bit<br>2. Parallel Interface, RFBI-1 mode 16-bit" |
| dss_hsync                           | Display subsystem | DISPC_HSYNC                       | RFBI_CS0                       |                        |                                        |                                | DISPC                                                                                  | RFBI (CS0)                                                                             | RFBI (CS0)                                                                               |
| dss_vsync                           |                   | DISPC_VSYNC                       | RFBI_WR                        |                        |                                        |                                |                                                                                        | RFBI                                                                                   | RFBI                                                                                     |
| dss_pclk                            |                   | DISPC_PCLK                        | RFBI_RD                        |                        |                                        |                                |                                                                                        | DSI                                                                                    | DSI                                                                                      |
| dss_acbias                          |                   | DISPC_ACBIAS                      | RFBI_A0                        |                        |                                        |                                |                                                                                        |                                                                                        |                                                                                          |
| dss_data0                           |                   | DISPC_DATA_L_CD0                  | RFBI_DA0                       |                        | DSI_DX0                                |                                |                                                                                        |                                                                                        |                                                                                          |
| dss_data1                           |                   | DISPC_DATA_L_CD1                  | RFBI_DA1                       |                        | DSI_DY0                                |                                |                                                                                        |                                                                                        |                                                                                          |
| dss_data2                           |                   | DISPC_DATA_L_CD2                  | RFBI_DA2                       |                        | DSI_DX1                                |                                |                                                                                        |                                                                                        |                                                                                          |
| dss_data3                           |                   | DISPC_DATA_L_CD3                  | RFBI_DA3                       |                        | DSI_DY1                                |                                |                                                                                        |                                                                                        |                                                                                          |
| dss_data4                           |                   | DISPC_DATA_L_CD4                  | RFBI_DA4                       |                        | DSI_DX2                                |                                |                                                                                        |                                                                                        |                                                                                          |
| dss_data5                           |                   | DISPC_DATA_L_CD5                  | RFBI_DA5                       |                        | DSI_DY2                                |                                |                                                                                        |                                                                                        |                                                                                          |
| dss_data6                           |                   | DISPC_DATA_L_CD6                  | RFBI_DA6                       |                        |                                        |                                | DISPC_DATA_L_CD [6-17]                                                                 | RFBI_DA [6-15]                                                                         | RFBI_DA [6-15]                                                                           |
| dss_data7                           |                   | DISPC_DATA_L_CD7                  | RFBI_DA7                       |                        |                                        |                                |                                                                                        |                                                                                        |                                                                                          |
| dss_data8                           |                   | DISPC_DATA_L_CD8                  | RFBI_DA8                       |                        |                                        |                                |                                                                                        |                                                                                        |                                                                                          |
| dss_data9                           |                   | DISPC_DATA_L_CD9                  | RFBI_DA9                       |                        |                                        |                                |                                                                                        |                                                                                        |                                                                                          |
| dss_data10                          |                   | DISPC_DATA_L_CD10                 | RFBI_DA10                      |                        |                                        |                                |                                                                                        |                                                                                        |                                                                                          |
| dss_data11                          |                   | DISPC_DATA_L_CD11                 | RFBI_DA11                      |                        |                                        |                                |                                                                                        |                                                                                        |                                                                                          |
| dss_data12                          |                   | DISPC_DATA_L_CD12                 | RFBI_DA12                      |                        |                                        |                                |                                                                                        |                                                                                        |                                                                                          |

**Table 7-1. LCD Interface Signals and Configurations (continued)**

| Pad names at device level boundary. | Pads Property     | Pads and Signals Configuration    |                                |                                        |                                  | Possible Operational Interfaces |                                                                                        |                                                                                        |                                                                                          |
|-------------------------------------|-------------------|-----------------------------------|--------------------------------|----------------------------------------|----------------------------------|---------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
|                                     |                   | Basic signal multiplexing on pads |                                | Additional signal multiplexing on pads |                                  | Simultaneous                    |                                                                                        | Sequential                                                                             |                                                                                          |
|                                     |                   | Parallel Interface, Bypass Mode.  | Parallel Interface, RFBI mode. | Serial Interface, DSI.                 | Parallel Interface, Bypass Mode. | Parallel Interface, RFBI mode.  | "1. Parallel Interface, Bypass mode 24-bit<br>2. Serial Interface, DSI (2 data lanes)" | "1. Parallel Interface, RFBI-0 mode 16-bit<br>2. Serial Interface, DSI (2 data lanes)" | "1. Parallel Interface, RFBI-0 mode 16-bit<br>2. Parallel Interface, RFBI-1 mode 16-bit" |
| dss_data13                          | Display subsystem | DISPC_DATA_L_CD13                 | RFBI_DA13                      |                                        |                                  |                                 | DISPC_DATA_L_CD [6-17]                                                                 | RFBI_DA [6-15]                                                                         | RFBI_DA [6-15]                                                                           |
| dss_data14                          |                   | DISPC_DATA_L_CD14                 | RFBI_DA14                      |                                        |                                  |                                 |                                                                                        |                                                                                        |                                                                                          |
| dss_data15                          |                   | DISPC_DATA_L_CD15                 | RFBI_DA15                      |                                        |                                  |                                 |                                                                                        |                                                                                        |                                                                                          |
| dss_data16                          |                   | DISPC_DATA_L_CD16                 | RFBI_TE_VSYN_C0                |                                        |                                  |                                 |                                                                                        | "RFBI(sync0)"                                                                          | "RFBI(sync0)"                                                                            |
| dss_data17                          |                   | DISPC_DATA_L_CD17                 | RFBI_HSYNC0                    |                                        |                                  |                                 |                                                                                        |                                                                                        |                                                                                          |
| dss_data18                          |                   | DISPC_DATA_L_CD18                 | RFBI_TE_VSYN_C1                |                                        |                                  |                                 |                                                                                        | RFBI_DA [0-5]                                                                          | "RFBI(sync1)"                                                                            |
| dss_data19                          |                   | DISPC_DATA_L_CD19                 | RFBI_HSYNC1                    |                                        |                                  |                                 |                                                                                        |                                                                                        |                                                                                          |
| dss_data20                          |                   | DISPC_DATA_L_CD20                 | RFBI_CS1                       |                                        |                                  |                                 |                                                                                        |                                                                                        |                                                                                          |
| dss_data21                          |                   | DISPC_DATA_L_CD21                 |                                |                                        |                                  |                                 |                                                                                        |                                                                                        |                                                                                          |
| dss_data22                          |                   | DISPC_DATA_L_CD22                 |                                |                                        |                                  |                                 |                                                                                        | RFBI (CS1)                                                                             |                                                                                          |
| dss_data23                          |                   | DISPC_DATA_L_CD23                 |                                |                                        |                                  |                                 |                                                                                        |                                                                                        |                                                                                          |

**Table 7-1. LCD Interface Signals and Configurations (continued)**

| Pad names at device level boundary. | Pads Property         | Pads and Signals Configuration   |                                |                        |                                  | Possible Operational Interfaces |                                                                                        |                                                                                        |                                                                                          |
|-------------------------------------|-----------------------|----------------------------------|--------------------------------|------------------------|----------------------------------|---------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
|                                     |                       | Parallel Interface, Bypass Mode. | Parallel Interface, RFBI mode. | Serial Interface, DSI. | Parallel Interface, Bypass Mode. | Parallel Interface, RFBI mode.  | "1. Parallel Interface, Bypass mode 24-bit<br>2. Serial Interface, DSI (2 data lanes)" | "1. Parallel Interface, RFBI-0 mode 16-bit<br>2. Serial Interface, DSI (2 data lanes)" | "1. Parallel Interface, RFBI-0 mode 16-bit<br>2. Parallel Interface, RFBI-1 mode 16-bit" |
| sys_boot0                           | System control module |                                  |                                |                        | DISPC_DATA_L_CD18                |                                 | DISPC_DATA_L_CD [18-23]                                                                |                                                                                        |                                                                                          |
| sys_boot1                           |                       |                                  |                                |                        | DISPC_DATA_L_CD19                |                                 |                                                                                        |                                                                                        |                                                                                          |
| sys_boot3                           |                       |                                  |                                |                        | DISPC_DATA_L_CD20                |                                 |                                                                                        |                                                                                        |                                                                                          |
| sys_boot4                           |                       |                                  |                                |                        | DISPC_DATA_L_CD21                |                                 |                                                                                        |                                                                                        |                                                                                          |
| sys_boot5                           |                       |                                  |                                |                        | DISPC_DATA_L_CD22                |                                 |                                                                                        |                                                                                        |                                                                                          |
| sys_boot6                           |                       |                                  |                                |                        | DISPC_DATA_L_CD23                |                                 |                                                                                        |                                                                                        |                                                                                          |

The DISPC\_DATA\_LCD[23:18] data is additionally multiplexed on the sys\_boot device pads to allow simultaneous availability of the DSI interface and the complete parallel 24-bit DSS interface.

---

**NOTE:** The DISPC\_DATA\_LCD[5:0] data multiplexed with the DSI signals on dss\_data[5:0] pads is limited to up to 60 MHz pixel clock frequency. If the parallel 18/24-bit interface in bypass mode with a pixel clock above 60 MHz is required, the DISPC\_DATA\_LCD[5:0] multiplexed on dss\_data[23:18] pads, and DISPC\_DATA\_LCD[23:18] multiplexed on sys\_boot pads must be used.

---



---

**NOTE:** Table 7-1 shows only the DSS capabilities of supporting simultaneous and sequential LCD interfaces due to the additional signal multiplexing, without describing explicitly all possible configurations.

---

For more information on signals multiplexing, see [Chapter 13, System Control Module](#). The parallel interface connectivity is detailed in [Section 7.2.1.1, Parallel Interface](#). For more details on the serial interface, see [Section 7.2.1.2, DSI Serial Interface](#).

### 7.2.1.1 Parallel Interface

In parallel interface, the paths of the display subsystem modules are the display controller and the RFBI.

The display controller provides the required control signals to interface the memory frame buffer (SDRAM or SRAM) directly to the external displays. The display controller is connected to the memory through the L3 interconnect and has its own DMA (with embedded FIFOs) to read data from the system memory. The L3 interconnect is the master port, while the L4 interconnect is the slave port of the display subsystem.

The display controller has two I/O pad modes at the module level:

- RFBI mode (RFBI enabled), which implements the MIPI DBI 2.0 protocol
- Bypass mode (RFBI disabled), which implements the MIPI DPI 1.0 protocol

The DSS.[DISPC\\_CONTROL\[16:15\]](#) GPOUT[1:0] bits control selection of the display subsystem modules (see [Table 7-2](#)).

**Table 7-2. I/O Pad Mode Selection**

| DSS. <a href="#">DISPC_CONTROL[16]</a> GPOUT1 | DSS. <a href="#">DISPC_CONTROL[15]</a> GPOUT0 | Mode        |
|-----------------------------------------------|-----------------------------------------------|-------------|
| 0                                             | 0                                             | Reset       |
| 0                                             | 1                                             | RFBI mode   |
| 1                                             | 0                                             | Invalid     |
| 1                                             | 1                                             | Bypass mode |

The RFB of the LCD panel is connected directly to the RFBI module of the device. The RFBI controls the reads/writes from/to the RFB. The RFBI receives the output from the DISPC (which takes data from the memory) and generates the signals to control the LCD panel. Through the RFBI, the MPU can send commands or parameter/display data to the LCD panel and directly set the DISPC registers to read/write the data from/to the memory in the LCD panel. The RFBI can manage up to two LCD panels when the serial interface is not used.

#### 7.2.1.1.1 Parallel Interface in RFBI Mode (MIPI DBI Protocol)

[Figure 7-2](#) shows the LCD support parallel interface in RFBI mode (example for 16-bit data interface).

Figure 7-2. LCD Support Parallel Interface (RFBI Mode)



**NOTE:** Configure the DSS.RFBI\_CONTROL[3:2] CONFIGSELECT bit field to drive signals for LCD 1 only, LCD 2 only, or both LCD 1 and LCD 2.

Table 7-3 describes the interface signals to/from the LCD panel in RFBI mode.

Table 7-3. LCD Interface Signals (RFBI Mode)

| Signal Name    | Type <sup>(1)</sup> | Description                                                              |
|----------------|---------------------|--------------------------------------------------------------------------|
| RFBI_DA[15:0]  | I/O                 | RFBI I/O data                                                            |
| RFBI_RD        | O                   | Read access signal                                                       |
| RFBI_WR        | O                   | Write access signal                                                      |
| RFBI_A0        | O                   | Command/data selection signal                                            |
| RFBI_CS0       | O                   | Chip-select (CS) signal for LCD 1                                        |
| RFBI_CS1       | O                   | CS signal for LCD 2                                                      |
| RFBI_TE_VSYNC0 | I                   | Tearing effect (TE) synchronization signal (TE or VSYNC for LCD panel 1) |
| RFBI_HSYNC0    | I                   | HSYNC from LCD panel 1                                                   |
| RFBI_TE_VSYNC1 | I                   | TE synchronization signal (TE or VSYNC for LCD panel 2)                  |
| RFBI_HSYNC1    | I                   | HSYNC from LCD panel 2                                                   |

<sup>(1)</sup> I = Input, O = Output

- RFBI\_DA[15:0]: The pixel data comprises the RFBI pixel data (bits 15:0). A write/read command must be sent to the LCD panel to send/read the data.  
Before any data access, the application must send commands and parameters when it is necessary to configure an LCD panel. The data is used as input in read operations during production test and also to read the status of the registers in the LCD panel and pixels from the embedded frame buffer in the LCD panel module. RFBI\_DA is multiplexed at the chip-level boundary with dss\_data [15:0].
- RFBI\_RD: This is the read-enable signal used to indicate when a read from the embedded memory in the LCD panel is ongoing. The RFBI registers describe the behavior of the read signal (off/on/cycle).

time). The polarity of the read-enable signal is programmable. This signal is multiplexed at the chip-level boundary with dss\_pclk. The read is used to get status/data information from the LCD panel.

- RFBI\_WR: The write-enable signal is used to indicate when a write is ongoing. The RFBI registers describe the behavior of the write signal (off/on/cycle time). The polarity of the write-enable signal is programmable. This signal is multiplexed at the chip-level boundary with dss\_vsync.
- RFBI\_A0: The signal is asserted to indicate its status: Command or data. The polarity is programmable and the status of the signal depends on the RFBI registers written by the application (CMD/READ/STATUS/PARAM/PIXEL). The register in use by the hardware defines the status of RFBI\_A0. The order of the writes/reads to the RFBI registers CMD/READ/STATUS/PARAM/PIXEL defines the transitions of A0. This signal is multiplexed at the chip-level boundary with dss\_acbias.
- RFBI\_CSx: The signal is the chip-select (CSx) asserted to indicate which LCD panel is selected and must be ready to receive/transmit commands and data. When RE or WE is on, CSx must not be changed ( $x = 0$  for LCD panel 1;  $x = 1$  for LCD panel 2). CS0 is multiplexed at the chip-level boundary with dss\_hsync, and CS1 is multiplexed at the chip-level boundary with dss\_data[20].
- RFBI\_TE\_VSYNCx: Based on the trigger mode selected, the signal is the TE pulse signal or the LCD panel VSYNC (vertical synchronization) pulse signal. RFBI\_TE\_VSYNCx is used by the TE logic as the synchronization signal to send the pixel to the LCD panel.

To select the trigger mode, configure the DSS.[RFBI\\_CONFIG\[3:2\]](#) TRIGGERMODE bit field (0x0: Internal trigger mode with the DSS.[RFBI\\_CONTROL\[4\]](#) ITE bit, 0x1: External trigger mode with the TE signal RFBI\_TE\_VSYNCx, 0x2: External trigger mode with the RFBI\_TE\_VSYNCx, and RFBI\_HSYNCx signals with the programmable line counter).

These signals are multiplexed at the chip-level boundary with dss\_data[16] (RFBI\_TE\_VSYNC0) and dss\_data[18] (RFBI\_TE\_VSYNC1) (LCD panel 1:  $x = 0$ ; LCD panel 2:  $x = 1$ ).

- RFBI\_HSYNCx: The HSYNC pulse signals indicate to the RFBI module when horizontal synchronization occurs. The polarity of the HSYNC signals is programmable. The minimum pulse width of the signal is two L4 cycles. RFBI\_HSYNC is used by the TE logic as a synchronization signal to send the pixel to the LCD panel. These signals are multiplexed at the chip-level boundary with dss\_data[17] (RFBI\_HSYNC0) and dss\_data[19] (RFBI\_HSYNC1) (LCD panel 1:  $x = 0$ ; LCD panel 2:  $x = 1$ ).

#### 7.2.1.1.1 Description of the TE Pulse Signal

The externally-generated TE synchronization signal is a logical OR or AND operation between the HSYNC and VSYNC signals (see [Figure 7-3](#)). The logical operation (OR or AND) depends on the HSYNC and VSYNC signals polarity. The VSYNC signal indicates to the RFBI module when vertical synchronization occurs; the HSYNC signal indicates to the RFBI module when horizontal synchronization occurs.

**Figure 7-3. External Generation of TE Signal Based on Logical OR Operation Between HSYNC and VSYNC (Active-High)**



The RFBI module detects the VSYNC and HSYNC pulses embedded in the received signal. VSYNC is detected based on the minimum pulse width defined by the DSS.[RFBI\\_VSYNC\\_WIDTH](#) register.

HSYNC is detected based on the minimum pulse width defined by the DSS.[RFBI\\_HSYNC\\_WIDTH](#) register.

The signal is generated from external logic based on the VSYNC/HSYNC of the LCD panel. The automatic trigger can be programmed based on the RFBI\_TE signal or use a bit field in the RFBI registers to start data capture.

The polarity of the TE signal is programmable. The HSYNC and VSYNC pulses embedded in the TE signal have the same polarity, which is active high for an ORed signal and active low for an ANDed signal. The minimum pulse width of the signal is two L4 cycles. Hardware resets the line counter when the VSYNC occurs and increments it at every HSYNC. Transfer to the LCD panel begins when the line counter reaches the programmable line number.

#### 7.2.1.1.2 Parallel Interface in Bypass Mode (MIPI DPI Protocol)

When bypass mode is enabled, the display controller must be set to use it.

[Figure 7-4](#) shows the LCD support parallel interface in bypass mode.

**Figure 7-4. LCD Support Parallel Interface (Bypass Mode)**



[Table 7-4](#) describes the interface signals to/from the LCD panel in bypass mode.

**Table 7-4. LCD Interface Signals (Bypass Mode)**

| Signal Name          | Type <sup>(1)</sup> | Description                                  |
|----------------------|---------------------|----------------------------------------------|
| DISPC_DATA_LCD[23:0] | O                   | LCD data from the display controller module  |
| DISPC_PCLK           | O                   | Pixel CLK from the display controller module |
| DISPC_VSYNC          | O                   | VSYNC from the display controller module     |
| DISPC_HSYNC          | O                   | HSYNC from the display controller module     |
| DISPC_ACBIAS         | O                   | ACBIAS from the display controller module    |

<sup>(1)</sup> I = Input, O = Output, I/O = Input/Output

- DISPC\_DATA\_LCD[23:0]: The panel pixel data comes directly from the display controller module. DISPC\_DATA\_LCD is connected at the chip-level boundary with dss\_data[23:0].
- DISPC\_PCLK: This signal is the pixel clock that comes directly from the display controller. This signal is multiplexed at the chip-level boundary with dss\_pclk.
- DISPC\_VSYNC: Uses the vertical synchronization signal from the display controller. The LCD frame clock (VSYNC) toggles after all the lines in a frame are transmitted to the LCD panel and a programmable number of line clock cycles has elapsed both at the beginning and at the end of each frame. This signal is multiplexed with dss\_vsync at the chip-level boundary.
- DISPC\_HSYNC: Uses the horizontal synchronization signal from the display controller. The LCD line clock (HSYNC) toggles after all pixels in a line are transmitted to the LCD panel and a programmable number of pixel clock wait-states elapse, both at the beginning and at the end of each line. This signal is multiplexed on the chip-level boundary with dss\_hsync.
- DISPC\_ACBIAS: Uses the ac-bias signal from the display controller.

- In passive matrix technology, the ac-bias signal is configured to transition each time a programmable number of line clocks occurs. To prevent a dc charge within the screen pixels, the power and ground supplies of the panel are periodically switched. The DISPC signals the panel to switch the polarity by toggling the ac-bias pin.
- In active matrix technology, the ac-bias signal acts as an output-enable signal to indicate when data must be latched using the pixel clock. This signal is multiplexed on the chip-level boundary with dss\_acbias.

#### 7.2.1.1.3 LCD Output and Data Format for the Parallel Interface

This section describes the pixel data bus and shows timing diagrams of transactions and synchronizations in both RFBI and bypass modes.

Figure 7-5 through Figure 7-11 show the pixel data bus for bypass mode, depending on the use of 4-, 8-, 12-, 16-, 18-, or 24-pixel data output pins. In RFBI mode, the pixel data bus is reformatted in accordance with the input and output data bus width.

Table 7-5 lists the number of displayed pixels per pixel clock cycle based on the type of display panel.

**Table 7-5. Number of Displayed Pixels per Pixel Clock Cycle Based on Display Type**

| Display Panel        | Number of Displayed Pixels per Pixel Clock Cycle |
|----------------------|--------------------------------------------------|
| Monochrome 4-bit     | 4                                                |
| Monochrome 8-bit     | 8                                                |
| Passive matrix color | 8/3                                              |
| Active matrix        | 1                                                |

- Passive matrix technology, Monochrome mode

Monochrome displays use either a 4-bit or 8-bit interface. Each bit represents one pixel (on or off), which means that either 4 or 8 pixels are sent to the LCD at each pixel clock.

Figure 7-5 and Figure 7-6 show 4- and 8-bit monochrome displays, respectively.

**Figure 7-5. LCD Pixel Data Monochrome4 Passive Matrix**



**Figure 7-6. LCD Pixel Data Monochrome8 Passive Matrix**

- Passive matrix technology, color mode

Color passive displays use 8-bit data input lines. In a given pixel clock cycle, each line represents one color component (red, green, or blue).

[Figure 7-7](#) shows an 8-bit color passive matrix display.

**Figure 7-7. LCD Pixel Data Color Passive Matrix**

- Active matrix technology

Active matrix displays bypass the STN dithering logic block and the output FIFO. Each line represents one pixel.

[Figure 7-8](#) through [Figure 7-11](#) show 12-, 16-, 18-, and 24-active matrix displays, respectively.

**Figure 7-8. LCD Pixel Data Color12 Active Matrix**


**Figure 7-9. LCD Pixel Data Color16 Active Matrix****Figure 7-10. LCD Pixel Data Color18 Active Matrix**

**Figure 7-11. LCD Pixel Data Color24 Active Matrix**


dss-011

#### 7.2.1.1.4 Transaction Timing Diagrams

- Timing diagrams in flow control mode
  - Stall signal

The stall signal is used in RFBI and DSI modes. In the case of RFBI mode, it is used to indicate when the display controller must stop sending data over the LCD output interface. The RFBI module asserts the stall signal to stop data output by the display controller. It is deasserted to indicate when new data must be outputted by the display controller.

**Figure 7-12. RFBI Data Stall Signal Diagram**


dss-134

To avoid underflow of the DMA FIFO, the FIFO handcheck feature can be enabled by setting the DSS.DISPC\_CONFIG[16] FIFOHANDCHECK bit to 1. The fullness of the FIFOs associated with the pipelines used for the LCD output is checked when the STALL signal is inactive before providing data to the pipeline. This prevents emptying the FIFO when the RFBI module requests data and there is not enough data in the display controller DMA FIFO. This feature must be enabled only when the STALL mode is used (DSS.DISPC\_CONTROL[11] STALLMODE bit set to 1).

When the FIFO handcheck feature is activated, the pixel transfer to the RFBI module during STALL inactivity period can be stopped (no DISPC\_PCLK pulse) and restarted when there is enough data in the FIFO. The FIFO handcheck ensures that underflow cannot occur for the pipelines associated with the LCD output in RFBI mode. Figure 7-13 details the RFBI data stall with FIFO handcheck mode activated.

**Figure 7-13. RFBI Data Stall Signal Diagram With Handcheck**

- RFBI timing diagrams

Table 7-6 lists the programmable timing fields. Figure 7-14 through Figure 7-16 show timing diagrams of read/write transactions to the LCD panel for the RFBI mode.

**Table 7-6. Programmable Timing Fields in RFBI Mode**

| Timing Name  | Register Field                                                     | Description                                                 |
|--------------|--------------------------------------------------------------------|-------------------------------------------------------------|
| CSOnTime     | DSS.RFB1_ONOFF_TIMEi[3:0]<br>CSONTIME (with $i = 0$ or $1$ )       | CS assertion time from start access time                    |
| CSOffTime    | DSS.RFB1_ONOFF_TIMEi[9:4]<br>CSOFFTIME (with $i = 0$ or $1$ )      | CS deassertion time from start access time                  |
| WeCycleTime  | DSS.RFB1_CYCLE_TIMEi[5:0]<br>WECYCLETIME (with $i = 0$ or $1$ )    | The time when A0 becomes valid until write cycle completion |
| WEOnTime     | DSS.RFB1_ONOFF_TIMEi[13:10]<br>WEONTIME (with $i = 0$ or $1$ )     | WE assertion delay time from start access time              |
| WEOffTime    | DSS.RFB1_ONOFF_TIMEi[19:14]<br>WEOFFTIME (with $i = 0$ or $1$ )    | WE deassertion delay time from start access time            |
| RECycleTime  | DSS.RFB1_CYCLE_TIMEi[11:6]<br>RECYCLETIME (with $i = 0$ or $1$ )   | The time when A0 becomes valid until read cycle completion  |
| REOnTime     | DSS.RFB1_ONOFF_TIMEi[23:20]<br>REONTIME (with $i = 0$ or $1$ )     | RE assertion delay time from start access time              |
| REOffTime    | DSS.RFB1_ONOFF_TIMEi[29:24]<br>REOFFTIME (with $i = 0$ or $1$ )    | RE assertion delay time from start access time              |
| CSPulseWidth | DSS.RFB1_CYCLE_TIMEi[17:12]<br>CSPULSEWIDTH (with $i = 0$ or $1$ ) | The time when write cycle time or read cycle time completes |

**Figure 7-14. Command Data Write**

**Figure 7-15. Display Data Read**

**Figure 7-16. Read to Write and Write to Read**


- Timing diagrams in bypass mode

[Figure 7-17](#) through [Figure 7-32](#) show timing diagrams of synchronization signals and pixel clock in bypass mode for both passive matrix and active matrix panels. The display controller directly drives these signals, which are related to the programmable fields described in [Table 7-7](#).

**Table 7-7. Programmable Fields in Bypass Mode**

| Name | Register                  | Description                                                       |
|------|---------------------------|-------------------------------------------------------------------|
| PPL  | DSS.DISPC_SIZE_LCD[10:0]  | PPL bit field value + 1<br>Pixels per line (PPL)                  |
| LPP  | DSS.DISPC_SIZE_LCD[26:16] | LPP bit field value + 1<br>Lines per panel                        |
| HBP  | DSS.DISPC_TIMING_H[31:20] | HBP bit field value + 1<br>Horizontal back porch                  |
| HFP  | DSS.DISPC_TIMING_H[19:8]  | HFP bit field value + 1<br>Horizontal front porch                 |
| HSW  | DSS.DISPC_TIMING_H[7:0]   | HSW bit field value + 1<br>Horizontal synchronization pulse width |

**Table 7-7. Programmable Fields in Bypass Mode (continued)**

| Name  | Register                  | Description                                                    |
|-------|---------------------------|----------------------------------------------------------------|
| VBP   | DSS.DISPC_TIMING_V[31:20] | Vertical back porch                                            |
| VFP   | DSS.DISPC_TIMING_V[19:8]  | Vertical front porch                                           |
| VSW   | DSS.DISPC_TIMING_V[7:0]   | Vertical synchronization pulse width                           |
| ONOFF | DSS.DISPC_POL_FREQ[17]    | ONOFF bit<br>DISPC_HSYNC and DISPC_VSYNC pixel clock control   |
| RF    | DSS.DISPC_POL_FREQ[16]    | RF bit<br>DISPC_HSYNC and DISPC_VSYNC pixel clock edge control |
| IEO   | DSS.DISPC_POL_FREQ[15]    | Invert DISPC_ACBIAS                                            |
| IPC   | DSS.DISPC_POL_FREQ[14]    | Invert DISPC_PCLK                                              |
| IHS   | DSS.DISPC_POL_FREQ[13]    | Invert DISPC_HSYNC                                             |
| IVS   | DSS.DISPC_POL_FREQ[12]    | Invert DISPC_VSYNC                                             |

- Active matrix timing configuration 1
  - DSS.DISPC\_POL\_FREQ[17] ONOFF bit = 0
  - DSS.DISPC\_POL\_FREQ[16] RF bit = 0
 

The DISPC\_HSYNC and DISPC\_VSYNC signals are driven on the opposite edge of DISPC\_PCLK from the pixel data.
  - DSS.DISPC\_POL\_FREQ[15] IEO = 0
 

The DISPC\_ACBIAS signal is active high.
  - DSS.DISPC\_POL\_FREQ[14] IPC = 0
 

The pixel data are driven on the rising edge of DISPC\_PCLK.
  - DSS.DISPC\_POL\_FREQ[13] IHS = 0
 

The DISPC\_HSYNC signal is active high.
  - DSS.DISPC\_POL\_FREQ[12] IVS = 0
 

The DISPC\_VSYNC signal is active high.

**Figure 7-17. Active Matrix Timing Diagram of Configuration 1 (Start of Frame)****Figure 7-18. Active Matrix Timing Diagram of Configuration 1 (Between Lines)**

**Figure 7-19. Active Matrix Timing Diagram of Configuration 1 (Between Frames)**



dss-017

**Figure 7-20. Active Matrix Timing Diagram of Configuration 1 (End of Frame)**



dss-018

- Active matrix timing configuration 2
  - DSS.[DISPC\\_POL\\_FREQ\[17\]](#) ONOFF bit = 1
  - DSS.[DISPC\\_POL\\_FREQ\[16\]](#) RF bit = 1  
The DISPC\_HSYNC and DISPC\_VSYNC signals are driven on the rising edge of DISPC\_PCLK.
  - DSS.[DISPC\\_POL\\_FREQ\[15\]](#) IEO = 1  
The DISPC\_ACBIAS signal is active low.
  - DSS.[DISPC\\_POL\\_FREQ\[14\]](#) IPC = 1  
The pixel data is driven on the falling edge of DISPC\_PCLK.
  - DSS.[DISPC\\_POL\\_FREQ\[13\]](#) IHS = 1  
The DISPC\_HSYNC signal is active low.
  - DSS.[DISPC\\_POL\\_FREQ\[12\]](#) IVS = 1  
The DISPC\_VSYNC signal is active low.

**Figure 7-21. Active Matrix Timing Diagram of Configuration 2 (Start of Frame)**



dss-019

\* Active Low signals

**Figure 7-22. Active Matrix Timing Diagram of Configuration 2 (Between Lines)****Figure 7-23. Active Matrix Timing Diagram of Configuration 2 (Between Frames)****Figure 7-24. Active Matrix Timing Diagram of Configuration 2 (End of Frame)**

- Active matrix timing configuration 3
  - DSS.**DISPC\_POL\_FREQ[17]** ONOFF bit = 1
  - DSS.**DISPC\_POL\_FREQ[16]** RF bit = 1
    - The DISPC\_HSYNC and DISPC\_VSYNC signals are driven on the rising edge of DISPC\_PCLK.
  - DSS.**DISPC\_POL\_FREQ[15]** IEO = 0
    - The DISPC\_ACBIAS signal is active high.
  - DSS.**DISPC\_POL\_FREQ[14]** IPC = 0
    - The pixel data are driven on the rising edge of DISPC\_PCLK.
  - DSS.**DISPC\_POL\_FREQ[13]** IHS = 0
    - The DISPC\_HSYNC signal is active high.
  - DSS.**DISPC\_POL\_FREQ[12]** IVS = 0
    - The DISPC\_VSYNC signal is active high.

**Figure 7-25. Active Matrix Timing Diagram of Configuration 3 (Start of Frame)**



dss-023

**Figure 7-26. Active Matrix Timing Diagram of Configuration 3 (Between Lines)**



dss-024

**Figure 7-27. Active Matrix Timing Diagram of Configuration 3 (Between Frames)**



dss-025

**Figure 7-28. Active Matrix Timing Diagram of Configuration 3 (End of Frame)**



dss-026

- Passive matrix timing configuration
    - DSS.[DISPC\\_POL\\_FREQ\[17\]](#) ONOFF bit = 0
    - DSS.[DISPC\\_POL\\_FREQ\[16\]](#) RF bit = 0
- The DISPC\_HSYNC and DISPC\_VSYNC signals are driven on the opposite edge of DISPC\_PCLK from the pixel data.

- DSS.DISPC\_POL\_FREQ[15] IEO = 0  
The DISPC\_ACBIAS signal is active high.
- DSS.DISPC\_POL\_FREQ[14] IPC = 0  
The pixel data are driven on the rising edge of DISPC\_PCLK.
- DSS.DISPC\_POL\_FREQ[13] IHS = 0  
The DISPC\_HSYNC signal is active high.
- DSS.DISPC\_POL\_FREQ[12] IVS = 0  
The DISPC\_VSYNC signal is active high.

**Figure 7-29. Passive Matrix Timing Diagram (Start of Frame)**

dss-027

**Figure 7-30. Passive Matrix Timing Diagram (Between Lines)**

dss-028

**Figure 7-31. Passive Matrix Timing Diagram (Between Frames)**

dss-029

**Figure 7-32. Passive Matrix Timing Diagram (End of Frame)**

dss-030

### 7.2.1.2 DSI Serial Interface

Figure 7-33 shows a typical connection between the DSI modules and a compliant panel display.

**Figure 7-33. Typical DSI Connection**



dss-194

---

**NOTE:** The DSI pins are multiplexed in mode 1 with some LCD parallel pins. See [Chapter 13, System Control Module](#), for more details on pad multiplexing.

---

### 7.2.2 LCD Support With MIPI DSI 1.0 Protocol and Data Format

This section summarizes the MIPI® DSI1.0 protocol and data format.

---

**NOTE:** Copyright ©2005-2008 MIPI Alliance, Inc. All rights reserved. MIPI Alliance Member Confidential.

---

#### 7.2.2.1 Physical Layer

[Table 7-8](#) lists the DSI interface I/O.

**Table 7-8. I/O Description for DSI Serial Interface**

| Signal Name | I/O <sup>(1)</sup> | Description | Value at Reset                 |     |
|-------------|--------------------|-------------|--------------------------------|-----|
| dsi_dx0     | line 1             | I/O         | Serial data/clock input/output | N/A |
| dsi_dy0     |                    |             |                                |     |
| dsi_dx1     | line 2             | I/O         | Serial data/clock input/output | N/A |
| dsi_dy1     |                    |             |                                |     |
| dsi_dx2     | line 3             | I/O         | Serial data/clock input/output | N/A |

<sup>(1)</sup> I/O = Input/Output

**Table 7-8. I/O Description for DSI Serial Interface (continued)**

| Signal Name | I/O <sup>(1)</sup> | Description | Value at Reset |  |
|-------------|--------------------|-------------|----------------|--|
| dsi_dy2     |                    |             |                |  |

**NOTE:** Each serial line (line 1, line 2, and line 3) can be used as clock lane or data lane. All polarities are supported. The MIPI DSI 1.0 protocol requires at least one clock line and one data lane.

Lanes support four operating modes:

- HS mode: High-speed transmit mode
- LP mode: Low-power transmit mode (also called low-power state [LPS])
- ULPS: Ultra-low power state used between two transmissions
- Off mode: Lane is off.

#### 7.2.2.1.1 Data/Clock Configuration

From the device point of view, the DSI interface consists of six input/output signals representing three differential signals: The serial clock and one or two serial data. The minimum configuration is one data pair and one clock pair.

- The data signal carries the bit-serial data. The DSI transmitter in the host sends the data in-quadrature with the DDR clock in high speed mode; otherwise, the clock is extracted from the received data in low-speed mode. The data is transmitted byte-wise least significant bit (LSB) first.
- The clock signal carries the DDR clock signal in high speed transmission.
- Software users must configure the order of the data lanes to indicate the byte order while splitting the byte stream for each DSI\_PHY into bytes.

Table 7-9 details all the DSI lanes configuration.

**Table 7-9. DSI Lane Configuration**

| DSI DSI_PHY Lane Configuration | Data/Clock Lane Position |          |          | Description      |
|--------------------------------|--------------------------|----------|----------|------------------|
|                                | 1                        | 2        | 3        |                  |
| Mode CLK + DATA1               | CLK                      | DATA1    | Not used | Single data lane |
|                                | CLK                      | Not used | DATA1    |                  |
|                                | DATA1                    | CLK      | Not used |                  |
|                                | Not used                 | CLK      | DATA1    |                  |
|                                | DATA1                    | Not used | CLK      |                  |
|                                | Not used                 | DATA1    | CLK      |                  |
| Mode CLK + DATA1 + DATA2       | CLK                      | DATA1    | DATA2    | Two data lanes   |
|                                | CLK                      | DATA2    | DATA1    |                  |
|                                | DATA1                    | CLK      | DATA2    |                  |
|                                | DATA2                    | CLK      | DATA1    |                  |
|                                | DATA1                    | DATA2    | CLK      |                  |
|                                | DATA2                    | DATA1    | CLK      |                  |

**NOTE:**

- The byte on D<sub>n</sub> is sent before the byte on D<sub>n+1</sub>, all the combinations of data and clock are supported through programming of the DSS.[DSI\\_COMPLEXIO\\_CFG1](#) register. The CLOCK\_POSITION and CLOCK\_POL bit fields configure which lane transmits the clock and define its polarity. Four bit fields (DATA1\_POSITION, DATA1\_POL, DATA2\_POSITION, and DATA2\_POL) configure the data lanes and their polarity. The DATA2\_POSITION bit field can be set to 0; in this case, only the data lane defined in the DATA1\_POSITION bit field is used, and data is transmitted on only one clock lane and one data lane.
- The configuration of the DSI complex I/O (number of data lanes, position, differential order) must not be changed while DSS.[DSI\\_CLK\\_CTRL\[20\]](#) LP\_CLK\_ENABLE bit is set to 1. For the hardware to recognize a new configuration of the complex I/O (done in DSS.[DSI\\_COMPLEXIO\\_CFG1](#) register), it is recommended to follow this sequence: First set the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit to 1, next reset the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN to 0, then set DSS.[DSI\\_CLK\\_CTRL\[20\]](#) LP\_CLK\_ENABLE to 1, and finally, set again the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit to 1. If the sequence is not followed, the DSI complex I/O configuration is undetermined.
- Only DATA1 is bidirectional in command mode. The low-power received information is always sent by the display panel using DATA1. Since any lane of the DSI complex I/O can be configured as data lane DATA1, all lanes of the complex I/O are bidirectional

### 7.2.2.1.2 ULPS

Each lane can be put in ultra-low power state (ULPS) by software configuration. The ULPS mode requires all the following conditions:

- The lane must be in stop state.
- For data lanes, no data must be pending in the DSI module.
- For data lane 1, no BTA should have been sent. The DSI module should have control of the bus.

The control of each lane is independently controlled by the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) register.

### 7.2.2.2 Video Port (VP) Interface

**NOTE:** The signals described in this section are internal and not bounded outside the device. This section aims at helping software users understand the internal connections between the display controller (DISPC) and the DSI protocol engine.

[Table 7-10](#) summarizes the video interface signals. This interface is used to connect the display controller to the DSI protocol engine to send real time data streams. Note that only the active matrix timings are supported by DSI protocol engine. The HSYNC/VSYNC/DE/DATA signals are driven on the rising or falling edge of the pixel clock (VP\_PCLK).

**Table 7-10. Video Interface for DSI Protocol Engine**

| Signal Name   | Type <sup>(1)</sup> | Description                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VP_HSYNC      | I                   | Horizontal sync signal                                                                                                                                                                                                                                                                                                                                                                                                                |
| VP_VSYNC      | I                   | Vertical sync signal                                                                                                                                                                                                                                                                                                                                                                                                                  |
| VP_DATA[23:0] | I                   | Parallel output data: Bits 0 to 23                                                                                                                                                                                                                                                                                                                                                                                                    |
| VP_PCLK       | I                   | Pixel clock. In case of STALL configuration, it is used to indicate when new data is on the data bus during the clock period of VP_CLK. The VP_PCLK is generated from VP_CLK through division. The clock ratio is defined in the DSS. <a href="#">DSI_CTRL[4]</a> VP_CLK_RATIO bit and must be aligned with the configuration of the clock divisor in the display controller (DSS. <a href="#">DISPC_DIVISOR[7:0]</a> PCD bit field). |
| VP_DE         | I                   | Data enable                                                                                                                                                                                                                                                                                                                                                                                                                           |

<sup>(1)</sup> I = Input, O = Output

**Table 7-10. Video Interface for DSI Protocol Engine (continued)**

| Signal Name | Type <sup>(1)</sup> | Description                                                                                                                                                                                                                 |
|-------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VP_STALL    | O                   | The stall signal must be deasserted to receive pixel and asserted to stop receiving pixel. (It can be used only while the display controller is configured in STALL mode; in that mode, HSYNC and VSYNC are not generated). |
| VP_CLK      | I                   | Display controller internal clock. It is a free-running clock.                                                                                                                                                              |

**NOTE:**

- The polarities of VP\_HSYNC and VP\_VSYNC are programmable by setting the DSS.DSI\_CTRL register.
- The maximum frequency for VP\_CLK is 173 MHz at nominal voltage, and 96 MHz at low voltage.
- Clocks VP\_CLK and VP\_PCLK can have the same frequency.
- The number of bits to be captured on the video port is defined in the DSS.DSI\_CTRL[7:6] VP\_DATA\_BUS\_WIDTH bit field.
- VP\_DE is connected to the dss\_acbias signal in the display controller, and its polarity can be controlled by setting the DISPC\_POL\_FREQ[15] IEO bit.

The data received on the video port can be stored into the line buffer memories or sent directly on the DSI interface in two cases:

- The line buffer size is too small compared to the line from the display controller.
- There is no line buffer instantiated. If there is no line buffer, the burst mode, defined as frequency burst mode, cannot be used. Only the transparency burst mode is supported.

**NOTE:** The DSS.DSI\_CTRL[13:12] LINE\_BUFFER bit field defines the number of lines to be used for transferring data from the video port to the DSI link.

**7.2.2.2.1 Video Port Used for Video Mode**

If the video port is used for video mode, the VP\_STALL is not used. **Table 7-11** lists the active signals on the video port.

**Table 7-11. Video Interface in the Context of Video Mode**

| Signal Name   | Type <sup>(1)</sup> | Description                                                                                                                                                 |
|---------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VP_HSYNC      | I                   | Horizontal sync signal                                                                                                                                      |
| VP_VSYNC      | I                   | Vertical sync signal                                                                                                                                        |
| VP_DATA[23:0] | I                   | Parallel output data: bits 0 to 23                                                                                                                          |
| VP_PCLK       | I                   | Pixel clock.                                                                                                                                                |
| VP_DE         | I                   | Data enable                                                                                                                                                 |
| VP_CLK        | I                   | It is a free running clock used as the display controller functional clock. The maximum frequency is 173 MHz at nominal voltage, and 96 MHz at low voltage. |

<sup>(1)</sup> I = Input, O = Output

Three video modes are available:

- No line buffer: The data received on the video port are directly output of the DSI port without buffering. The ratio of VP\_CLK and the DSI high-speed (HS) clock period must ensure identical throughput on the two ports (the two clocks must be generated using the same PLL; the subsystem must provide such configuration).
- One line buffer:
  - The data are first stored in the line buffer; once all the data for one line are received, the DSI protocol engine sends the whole line. The software must adjust timings to allow for the storage of all line data into the line buffer before sending to DSI outputs. The synchronization packets are never stored into the line buffer.

- Two line buffers:
  - One line is stored when the second line is output on the DSI port. It allows burst capability. While receiving the first line of the frame, there is no RGB packets sent because the line buffers are empty. To send the last line of the frame, a dummy line must be provided by the display controller to flush the line buffers. The synchronization packets are never stored into the line buffer.

---

**NOTE:** If more active lines are received on the video port than the number defined in the DSS.DSI\_VM\_TIMING3[15:0] VACT bit field, the extra lines are discarded by the DSI protocol engine. These lines are treated as blanking lines.

---

Figure 7-34, Figure 7-35, and Figure 7-36 show these three video modes.

**Figure 7-34. DSI Video Mode Without Burst (No-Line Buffer)**

**Figure 7-35. DSI Video Mode Without Burst (One-Line Buffer)**



dss-137

**Figure 7-36. DSI Video Mode With Burst (Two-Line Buffers)**

dss-138

**NOTE:** In [Figure 7-34](#), [Figure 7-35](#), and [Figure 7-36](#):

- When HSync start and Hsync end short packets are not generated (HSA does not exist), HBP signal must be different from 0.
- The software must ensure that VBP is always defined so that there is at least one HSYNC during VBP.
- In blanking low-power mode (BL-LP), two options are possible
  - The lane remains in ULPS, and the [DSI\\_CTRL\[20\]](#) BLANKING\_MODE bit is set to 0x0.
  - Dummy bytes are sent during LP with the [DSI\\_CTRL\[20\]](#) BLANKING\_MODE bit set to 0x1; the number of sent bytes is determined by the [DSI\\_VM\\_TIMING6\[15:0\]](#) BL\_LP\_INTERLEAVING bit field.

If the signal VP\_DE is not asserted during enough VP\_PCLK cycles to be able to capture the number of bytes defined in the word count of the header, the module must send the valid data received on the video port followed by bytes of 0s to match the required number of bytes to transmit. The VP\_PCLK must be present during all extra cycles where the DSI protocol engine is expecting pixels.

If the VP\_DE signal is asserted for too many VP\_PCLK cycles, the module should stop capturing the data on the video port while the number of bytes to capture, as defined in the word count field of the header, is reached.

The HS must check that the received synchronization events on the video port (VSYNC and HSYNC) are within the synchronization window based on expected timings. If the timings (internal and received) are out of sync, the interrupt for out-of-sync must be generated and the interface must be disabled ([DSS.DSI\\_CTRL\[0\]](#) IF\_EN bit is automatically reset by hardware). The unsynchronization window is defined by the [DSS.DSI\\_VM\\_TIMING2\[27:24\]](#) WINDOW\_SYNC bit field.

#### 7.2.2.2 Video Port Used on Command Mode

If the video port is used for command mode, the VP\_HSYNC, VP\_VSYNC, and VP\_DE signals are not used. [Table 7-12](#) describes the active signals on the video port.

**Table 7-12. Video Interface in the Context of Command Mode**

| Signal Name   | Type <sup>(1)</sup> | Description                                                                                                                                                                                                                 |
|---------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VP_DATA[23:0] | I                   | Parallel output data: bits 0 to 23                                                                                                                                                                                          |
| VP_PCLK       | I                   | One pulse is generated every time new data is output on the data bus                                                                                                                                                        |
| VP_STALL      | O                   | The stall signal must be deasserted to receive pixel and asserted to stop receiving pixel. (It can be used only while the display controller is configured in STALL mode; in that mode, HSYNC and VSYNC are not generated). |
| VP_CLK        | I                   | Display controller internal clock: It is a free running clock used as the display controller functional clock. The maximum frequency is 173 MHz at nominal voltage and 96 MHz at low voltage.                               |

<sup>(1)</sup> I = Input, O = Output

**NOTE:** The stall signal must be deasserted to receive pixels and asserted to stop receiving pixels.

[Figure 7-37](#) and [Figure 7-38](#) show the VP\_STALL signal assertion and deassertion on rising and falling edges, respectively.

**NOTE:** In DSI command mode, the display controller must be configured in stall mode by setting the [DSS.DISPC\\_CONTROL\[11\]](#) STALLMODE bit to 1.

**Figure 7-37. Stall Timing With Pixel on Rising Edge**

dss-187

**Figure 7-38. Stall Timing With Pixel on Falling Edge**

dss-188

To stop the transfer, the VP\_STALL signal must be asserted when the last data is output. The data can be output on the rising or falling edge of the VP\_PCLK through registers in the display controller module. The case with data output on falling edge of VP\_PCLK is supported by the DSI protocol engine.

The VP\_PCLK clock is generated from VP\_CLK; these two clocks are balanced. Assertion and deassertion of VP\_PCLK is done on the rising edge of VP\_CLK. The width of the VP\_PCLK pulse depends on the configuration of the clock divisor in the display controller (DSS.DISPC\_DIVISOR[7:0] PCD bit field). In the DSI protocol engine, the information is defined in the DSS.DSI\_CTRL[4] VP\_CLK\_RATIO bit and must be aligned with the display controller configuration.

Deassertion of the VP\_STALL signal must occur at least 4 VP\_CLK cycles before assertion of VP\_PCLK. Assertion of VP\_STALL must occur one cycle VP\_CLK after deassertion of VP\_PCLK for the last pixel to be transferred. The VP\_CLK clock is generated by the display controller under software control. It can be kept running between assertion and deassertion of VP\_STALL.

The word count (WC) defined in the DSS.DSI\_VCn\_LONG\_PACKET\_HEADER register for the virtual channel (VC) associated with the video port, indicates the number of bytes to receive (one line or two lines can be used, depending on the WC and size of the line buffer). The total size defined in the WC of the header register cannot exceed the size of the line buffer multiplied by the number of buffer lines.

The stall assertion/deassertion depends on the number of bytes to be received considering the size of the video port bus defined in the DSS.DSI\_CTRL[7:6] VP\_DATA\_BUS\_WIDTH bit field.

Figure 7-39 shows the data flow in command mode using the video port.

**Figure 7-39. Data Flow in Command Mode Using the Video Port**



dss-139

Two command modes are available:

- One line buffer: The data are stored in the line buffer before being sent.
- Two line buffers: The two lines are used if the word count defined in the [DSS.DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) register is bigger than the line size; otherwise, one line buffer is used.

---

**NOTE:** In command mode, the video port can only be used in one or two line buffer configuration. The no-line buffer configuration is not allowed.

---

The packets can be sent using high-speed or low-speed.

---

**NOTE:** The DCS command in the payload can be inserted automatically using the [DSI\\_CTRL\[24\]](#) DCS\_CMD\_ENABLE bit. If TE is used, hardware automatically inserts the DCS Write Start command for the first packet of the frame transfer and the DCS Write Continue command for all subsequent packets.

---

#### 7.2.2.2.3 Burst Mode

When the burst mode is enabled, the video port receives data from the display controller at the pixel clock. The DSI protocol engine buffers the data in its own line FIFO (double-line buffer of 1024 x 24-bit pixels maximum). The read speed of the line can be twice the pixel clock to increase the blanking time of the video mode and to allow command mode traffic to be interleaved during the blanking period. The burst mode uses a dual-line buffer.

The DSI port can output data from one line buffer while the second one is accessed by the video port. The two processes are concurrent but they do not access the same line at the same time. The DSI transfer can start only when the whole video port line is transferred into a line buffer. The switch is controlled by the VP\_HS signal on the video port side and by internal signal on the DSI port indicating that the last data for the current line has been written into the line buffer.

---

**NOTE:** The line buffers are used to store the pixels only. The synchronization codes are not stored in the line buffers. They must be sent according to the video port timings.

---

### 7.2.2.3 Multilane Layer

Peripherals do not typically have high bandwidth requirements for returning data to the host processor. To keep designs simple and improve interoperability, all DSI-compliant systems must use only Lane 1 in LP mode for returning data from a peripheral to the host processor.

#### 7.2.2.3.1 SoT and EoT in Multilane Configurations

Since a HS transmission is composed of an arbitrary number of bytes that may not be an integer multiple of the number of lanes, some lanes may run out of data before others. Therefore, the lane management layer, as it buffers up the final set of less-than-N bytes, deasserts its valid data signal into all lanes for which there is no further data. Although all lanes start simultaneously with parallel SoTs, each lane operates independently and may complete the HS transmission before the other lanes, sending an EoT one cycle (byte) earlier.

#### 7.2.2.3.2 Lane Splitter

The lane splitter can split the byte stream into 2 lanes (for 1 lane, the splitter is bypassed). Figure 7-40 and Figure 7-41 show the byte position into each serial link for 1 and 2 data lane configurations. The byte stream always starts from lane 1. It finishes on one of the lanes, depending on the number of bytes to send and the number of lanes. The splitter module is only used when packets are sent using high-speed mode (HS). In low-power mode (LP), only one data lane is used (Lane 1).

**Figure 7-40. Two Data Lane Configuration**



ds-140

**Figure 7-41. One Data Lane Configuration**



ds-329

In case of back-to-back packets, the byte stream is considered as a single packet by the splitter module. Figure 7-42 shows the example of two packets sent back to back. N bytes for the first packet and M bytes for the second one.

**Figure 7-42. Two Packets Using Two-Data Lane Configuration (Example)**


dss-142

#### 7.2.2.4 Protocol Layer

The low level protocol (LLP) is a byte-oriented protocol. It supports short and long packet formats. The DSI protocol layer defines how the display data is transported onto the physical layer. Packets can be sent using high-speed or low-speed mode. LLP is selected through DSI registers. The features of the DSI protocol layer are:

- Transport of arbitrary data (payload independent)
- 8-bit word size
- Support for up to four interleaved VCs on the same link
- Special packets for frame start, frame end, line start, and line end information
- Descriptor for the type, pixel depth, and format of application-specific payload data
- ECC for 1-bit or 2-bit error detection in the header
- 16-bit checksum code for error detection

Figure 7-43 shows the protocol layer with short and long packets.

**Figure 7-43. Protocol Layer With Short and Long Packets**



**Key:**

|                           |                         |
|---------------------------|-------------------------|
| ST: Start of transmission | ET: End of transmission |
| PH: Packet header         | PF: Packet footer       |
| LPS: Low-power state      | SP: Short packet        |

dss-143

##### 7.2.2.4.1 Short Packet

Figure 7-44 shows the structure of the short packet. A short packet must contain an 8-bit data ID followed by two command or data bytes and an 8-bit ECC; a packet footer must not be present. Short packets must be 4 bytes in length. The ECC byte allows correction of single-bit errors and detection of 2-bit errors in the short packet.

**Figure 7-44. Short Packet Structure**

**NOTE:** The short packets can be sent in low-power mode or in high-speed mode.

#### 7.2.2.4.2 Long Packet

Figure 7-45 shows the structure of the low-level protocol long packet. A long packet must consist of three elements: A 32-bit packet header (PH), an application-specific data payload with a variable number of bytes, and a 16-bit packet footer (PF). The packet header is further composed of three elements: An 8-bit data identifier, a 16-bit word count, and 8-bit ECC. The packet footer has one element, a 16-bit checksum. Long packets can be from 6 to 65,541 bytes in length.

**Figure 7-45. Long Packet Structure**

- The data identifier defines the VC for the data and the DT for the application-specific payload data.
- The word count defines the number of bytes in the data payload between the end of the packet header and the start of the packet footer. Neither the packet header nor the packet footer must be included in the word count.
- The ECC byte allows single-bit errors to be corrected and 2-bit errors to be detected in the packet header. This includes the data identifier and the word count fields.

After the end of the packet header, the receiver reads the next word count \* bytes of the data payload. There are no limitations on the value of a data word within the data payload block, that is, no embedded codes are used. Once the receiver has read the data payload, it reads the checksum in the packet footer. Peripherals are not required to calculate a checksum. Also note the special case of zero-byte data payload: If the payload has length 0, then the checksum calculation results in (0xFFFF). If the checksum is not calculated, the packet footer must consist of 2 bytes of all zeros (0x0000). In the generic case, the length of the data payload must be a multiple of bytes. In addition, each data format may impose additional restrictions on the length of the payload data, that is, multiple of 4 bytes. Each byte is transmitted LSB first. Payload data may be transmitted in any byte order, restricted only by data format requirements. Multibyte elements such as word count and checksum must be transmitted least-significant byte first.

**NOTE:** The long packets can be sent in low-power mode or high-speed mode.

#### 7.2.2.4.3 Data Identifier

The data identifier byte contains the virtual VC ID value and the DT value, as shown in [Figure 7-46](#). The VC ID is contained in the 2 MSBs of the data identifier byte. The DT value is contained in the 6 LSBs of the data identifier byte. DI[7:6]: These 2 bits identify the data as directed to one of four VCs. DI[5:0]: These six bits specify the DT.

**Figure 7-46. Data Identifier Structure**



dss-146

#### 7.2.2.4.4 Virtual Channel ID - VC Field, DI[7:6]

The host can service up to four peripherals with tagged commands or blocks of data using the VC ID field of the header for packets targeted at different peripherals. The VC ID enables one serial stream to service two or more virtual peripherals by multiplexing packets onto a common transmission channel. Note that each packet sent in a single transmission have its own VC assignment and can be directed to different peripherals. The VC ID is defined in the DSS.[DSI\\_VCn\\_SHORT\\_PACKET\\_HEADER](#) and DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) registers for short and long packets, respectively. It should not be modified by hardware. There is one set of registers for each VC. Each set of registers defines the characteristics of the traffic between the host and the display associated with the VC.

[Figure 7-47](#) shows the VC controller.

**Figure 7-47. Virtual Channel Controller**



dss-147

#### 7.2.2.4.5 Data Type Field DT[5:0]

The DT field specifies whether the packet is a long or short packet type and the packet format. The DT field, along with the word count field for long packets, informs the receiver on how many bytes to expect in the remainder of the packet. This is necessary because there are no special packet start/end sync codes to indicate the beginning and end of a packet. This permits packets to convey arbitrary data, but it also requires the packet header to explicitly specify the size of the packet.

#### 7.2.2.4.6 Pixel Data Formats in Video Mode

The host can send different pixel formats in video mode. [Table 7-13](#) summarizes the pixel formats supported by the DSI interface in video mode.

**Table 7-13. Pixel Data Format in Video Mode**

| Mode                                          | Description   |
|-----------------------------------------------|---------------|
| RGB888 (using 24-bit container)               | RGB888        |
| RGB666 (using 24-bit container)               | RGB666        |
| RGB666 (18-bit packet using 18-bit container) | RGB666_PACKET |
| RGB565 (using 16-bit container)               | RGB565        |

#### 7.2.2.4.7 Synchronization Codes

Each frame can be identified by two synchronization codes: One for the start of vertical synchronization pulse (VSSC) and one for the end of the vertical synchronization pulse (VSEC). Each line can be identified by two synchronization codes: One for the start of horizontal synchronization pulse (HSSC) and one for the end of the horizontal synchronization pulse (HSEC). The synchronization events may not be required by the display (peripheral): They are optional. Users can program which sync events are generated to the display from the timings received from the display controller in video mode. When data are received on the L4 interconnect slave port, the synchronization codes are not automatically generated by the protocol engine. They can be provided on the L4 interconnect port by writing to the registers with limited timing control. It is highly recommended to use the video port from the display controller to receive the synchronization events to automatically generate the short synchronization packets to the peripheral. When the DSI protocol engine detects that the VSYNC signal from the display controller transitions from inactive to active state, the VSSC short packet replaces the following HSSC corresponding to the following HSYNC synchronization short packet (if the generation is enabled). When the transition from active to inactive state is detected, the VSEC short packet is generated (if the generation is enabled) replacing the HSSC synchronization packet corresponding to the following HSYNC. When the DSI protocol engine detects that the HSYNC signal from the display controller transition from inactive to active state, the HSSC short packet is generated (if the generation is enabled). When the transition from active to inactive state is detected, the HSEC short packet is generated (if the generation is enabled). For the first frame, any HSYNC and data received on the video port before the first VSYNC should be ignored. Because the first VSYNC sent to the display is also recognized as a HSYNC for the first line, there should be no HSYNC sent for the first line. To send the synchronization codes, the DSI protocol engine uses the short packets. [Table 7-14](#) summarizes the 6-bit DT synchronization code values.

**Table 7-14. Synchronization Codes**

| Synchronization Code     | Value | Comments |
|--------------------------|-------|----------|
| V sync start code (VSSC) | 0x1   | Optional |
| V sync end code (VSEC)   | 0x11  | Optional |
| H sync start code (HSSC) | 0x21  | Optional |
| H sync end code (HSEC)   | 0x31  | Optional |

#### 7.2.2.4.8 Blanking

To keep the DSI link in HS state while using the video mode, during blanking periods, the long blanking packets are sent to the display. The DSS.DSI\_VM\_TIMINGi (i between 1 and 7) registers define the size of the long blanking packets after:

- Horizontal sync start code (short packet)
- Horizontal sync end code (short packet)
- Vertical sync start code (short packet)
- Vertical sync end code (short packet)
- Pixels (long packet)

[Table 7-15](#) defines the short packet values for the synchronization packets:

**Table 7-15. Sync Short Packet Values**

| Virtual Channel ID | Sync Code | Header (1st Byte) | Header (2nd Byte): Data Field LSB | Header (3rd Byte): Data Field MSB | Header (ECC)                  |
|--------------------|-----------|-------------------|-----------------------------------|-----------------------------------|-------------------------------|
| 0x0                | 0x1       | 0x1               | 0x0                               | 0x0                               | See note following this table |
|                    | 0x11      | 0x11              |                                   |                                   |                               |
|                    | 0x21      | 0x21              |                                   |                                   |                               |
|                    | 0x31      | 0x31              |                                   |                                   |                               |
| 0x1                | 0x1       | 0x41              |                                   |                                   |                               |
|                    | 0x11      | 0x51              |                                   |                                   |                               |
|                    | 0x21      | 0x61              |                                   |                                   |                               |
|                    | 0x31      | 0x91              |                                   |                                   |                               |
| 0x2                | 0x1       | 0x81              |                                   |                                   |                               |
|                    | 0x11      | 0x81              |                                   |                                   |                               |
|                    | 0x21      | 0xA1              |                                   |                                   |                               |
|                    | 0x31      | 0xB1              |                                   |                                   |                               |
| 0x3                | 0x1       | 0xC1              |                                   |                                   |                               |
|                    | 0x11      | 0xD1              |                                   |                                   |                               |
|                    | 0x21      | 0xC1              |                                   |                                   |                               |
|                    | 0x31      | 0xF1              |                                   |                                   |                               |

**NOTE:**

- If the ECC is enabled by setting the DSS.DSI\_VCn\_CTRL[8] ECC\_TX\_EN bit to 1 for the VC in video mode, the ECC value is calculated; otherwise, 0x00 is used for the blanking long packets and sync short packets. If the CRC is enabled by setting the DSS.DSI\_VCn\_CTRL[7] CS\_TX\_EN bit to 1 for the VC in video mode, the check-sum value is calculated; otherwise, 0x00 is used for the blanking long packets.
- In other cases, when the DSS.DSI\_VCn\_CTRL[7] CS\_TX\_EN bit is set to 0, the value 0x00 is always used for the CRC (long packets). When the DSS.DSI\_VCn\_CTRL[8] ECC\_TX\_EN bit is set to 0, the value 0x00 is used for the ECC for short and long packets, except when the header is provided by the register, since the ECC field is available in the register. It can be used to generate invalid ECC values when the header is provided by the register.

The link [lane(s) and clock separately] can be put in ULPS mode. While using the blanking values formerly defined, the packets (short and long) are considered in HS mode.

Timing parameters VSA, VBP, VFP, HSA, HBP, HFP, VACT, and  $t_L$  are defined in the DSS.DSI\_VM\_TIMINGx (x between 1 and 7) register. HSA, HBP, HFP, and  $t_L$  are defined using the byte clock unit (TxByteClkHS) and also in low-power clock cycles (TxClkEsc). VSA, VBP, VFP, and VACT are defined in term of number of lines. When the HS blanking packets are sent during the blanking periods, the parameters are used to determine the blanking packet payload size (taking into account the 4-byte header and the 2-byte check sum).

The configuration of the display controller timing generator must be used when the display controller timings are used to generate the DSI HS video mode transfer.

Special care must be taken in the case of the last line of the frame. The LPS transition is required when the link is in HS mode for the whole frame.

When BTA is sent for the data packets, the following blanking period cannot be used for sending any data from the TX FIFO. When the blanking period starts with one HS packet from one VC, it can only be followed by another HS packet from the same VC, or by trigger (BTA for example). When there is no more HS data to send for this VC, the lane is in LPS. When the blanking period starts with one LP packet from one VC, it can only be followed by another LP packet from the same VC, by another VC, by trigger (BTA

for example), or by extra LP NULL packets. If the trigger has been sent, it is not possible to send any more data. When there is no more data from the TX FIFO to send in LP mode or the trigger has been sent, the lane is put into LPS. If the lanes must be kept in HS mode during blanking periods (except for the last blanking period of the frame), the HS blanking packets must be used. In case one trigger is sent at the beginning of the blanking period, the rest of the blanking period is in ULPS.

Figure 7-48 and Figure 7-49 show a nonburst transfer in DSI video mode with, and without VE and HE, respectively.

**Figure 7-48. DSI Video Mode: Nonburst Transfer With VE and HE**



dss-148

**Figure 7-49. DSI Video Mode: Nonburst Transfer Without VE and HE**


dss-149

**NOTE:** HSA timing is not used and does not have to be programmed when HE short packet is not generated.

**Figure 7-50. DSI Video Mode: Burst Transfer Without VE and HE**

dss-150

**NOTE:** HSA timing is not used and does not have to be programmed when HE short packet is not generated.

In [Figure 7-49](#) and [Figure 7-50](#), if HSync end short packet is not generated (HSA does not exist), HBP must be other than 0.

#### 7.2.2.4.9 Frame Structures

[Figure 7-51](#) shows the general DSI frame structure.

**Figure 7-51. DSI General Frame Structure**

**Key:**

PH – Packet header

FS – Frame start

LS – Line start

**Video mode**

PF – Packet footer

FE – Frame end

LE – Line end

dss-151

[Figure 7-52](#) shows the general frame structure using burst mode.

**Figure 7-52. DSI General Frame Structure Using Burst Mode**

Figure 7-53 shows the general frame structure using burst mode and interleaving.

**Figure 7-53. DSi General Frame Structure Using Burst Mode and Interleaving**



**Key:**

PH – Packet header  
 FS – Frame start  
 LS – Line start

PF – Packet footer  
 FE – Frame end  
 LE – Line end

Video mode

Command mode

dss-153

#### 7.2.2.4.10 Virtual Channels

The DSI protocol layer transports VCs. The purpose of VCs is to separate different data flows, which are interleaved in a same data stream. Each VC is identified by a unique channel identification number in the packet header. The channel identification number is encoded in 2-bits. The DSI protocol engine determines the channel identifier number to be used for generating the packet header and multiplexes the interleaved data streams. The DSI protocol engine supports multiple concurrent VCs: Up to 4. [Table 7-16](#) summarizes the VC values used for each channel.

**Table 7-16. Virtual Channel Values**

| Virtual Channel Number | Value |
|------------------------|-------|
| Virtual channel 0      | 0x0   |
| Virtual channel 1      | 0x1   |
| Virtual channel 2      | 0x2   |
| Virtual channel 3      | 0x3   |

In the case of multiple displays connected to the single DSI port on the host, a hub may be used to root the data stream to the appropriate display based on the VC ID. Typically, VC ID 0x0 is used for the primary display and 0x1 for the secondary. The hub may have its own VC ID to provide communication capability between the host and the hub.

#### 7.2.2.5 Pixel Data Formats

This section summarizes how the DSI supported pixel data formats in video mode are transmitted over the serial interface. For pixel formats in command mode. The DSI protocol engine can cope with all data formats given that the data line length sent through the DSI physical protocol is a multiple of a pixel. This condition is required for the DSI protocol engine to work properly.

##### 7.2.2.5.1 24 Bits per Pixel - RGB Color Format, Long Packet

[Figure 7-54](#) shows the RGB888 format.

**Figure 7-54. 24 Bits per Pixel RGB Color Format, Long Packet**


dss-154

Packed pixel stream 24-bit format is a long packet used to transmit image data formatted as 24-bit pixels to a video mode display module. The packet consists of the DI byte, a two-byte WC, an ECC byte, a payload of length WC bytes, and a two-byte checksum. The pixel format is red (8 bits), green (8 bits), and blue (8 bits), in that order. Each color component occupies one byte in the pixel stream; no components are split across byte boundaries. Within a color component, the LSB is sent first, the MSB last.

#### 7.2.2.5.2 18 Bits per Pixel (Loosely Packed) - RGB Color Format, Long Packet

Figure 7-55 details the RGB666 format.

**Figure 7-55. 18 Bits per Pixel (Loosely Packed) RGB Color Format, Long Packet**

dss-155

In the 18-bit pixel loosely-packed format, each R, G, or B color component is six bits but is shifted to the upper bits of the byte, such that the valid pixel bits occupy bits [7:2] of each byte. Bits [1:0] of each payload byte representing active pixels are ignored. As a result, each pixel requires three bytes as it is transmitted across the link. This requires more bandwidth than the packed format, but requires less shifting and multiplexing logic in the packing and unpacking functions on each end of the link. This format is used to transmit RGB image data formatted as pixels to a video mode display module that displays 18-bit pixels. The packet consists of the DI byte, a two-byte WC, an ECC byte, a payload of length WC bytes, and a two-byte checksum. The pixel format is red (6 bits), green (6 bits), and blue (6 bits) in that order. Within a color component, the LSB is sent first, the MSB last.

#### 7.2.2.5.3 18 Bits per Pixel (Packed) - RGB Color Format, Long Packet

Figure 7-56 details the RGB666\_PACKED format.

**Figure 7-56. 18 Bits per Pixel (Packed) RGB Color Format, Long Packet**


dss-156

Packed pixel stream 18-bit format (packed) is a long packet. It is used to transmit RGB image data formatted as pixels to a video mode display module that displays 18-bit pixels. The packet consists of the DI byte, a two-byte WC, an ECC byte, a payload of length WC bytes, and a two-byte checksum. Pixel format is red (6 bits), green (6 bits), and blue (6 bits), in that order. Within a color component, the LSB is sent first, the MSB last. With this format, it is strongly recommended that the total line width be a multiple of four pixels (nine bytes).

#### 7.2.2.5.4 16 Bits per Pixel - RGB Color Format, Long Packet

Figure 7-57 details the RGB565 format.

**Figure 7-57. 16 Bits per Pixel RGB Color Format, Long Packet**

Packed pixel stream 16-bit format is a long packet used to transmit image data formatted as 16-bit pixels to a video mode display module. The packet consists of the DI byte, a two-byte WC, an ECC byte, a payload of length WC bytes, and a two-byte checksum. Pixel format is five bits red, six bits green, five bits blue, in that order. Note that the *green* component is split across two bytes. Within a color component, the LSB is sent first, the MSB last.

### 7.2.3 TV Display Support

The TV display path includes the following modules:

- Display controller
- Video encoder
- Video DAC stage comprising two single 10-bit DACs (AVDAC1 and AVDAC2) with video amplifiers

The display controller module receives synchronization signals from the video encoder and synchronously sends pixel data to the video encoder with these signals. The digital output of the display controller is always a 24-bit RGB value based on a pixel request from the video encoder.

The video encoder converts RGB video signals to conform to the NTSC/PAL standard analog video. The video encoder includes an integrated synchronization signal generator and two single channel video digital-to-analog converters (DACs) with video amplifiers, data manager, luma stage, chroma stage, modulator, and a control interface.

The video encoder also provides the synchronization signals to the display controller: VSYNC, active VIDeo (AVID), and field ID (FID).

**Figure 7-58** is a block diagram of the TV display interface (S-video mode, DC coupled, High Full Scale Swing).

**Figure 7-58. TV Display Interface (S-video mode, DC coupled, High FS Swing)**



camdss\_GN3-001

Figure 7-59 is a block diagram of the TV display interface (Composite mode, DC coupled, High Full Scale Swing).

**Figure 7-59. TV Display Interface (Composite Mode, DC coupled, High FS Swing)**



dss-191

Figure 7-60 is a block diagram of the TV display interface (Composite mode, AC coupled, Low Full Scale Swing).

**Figure 7-60. TV Display Interface (Composite Mode, AC coupled, Low FS Swing)**

dss-401

**NOTE:** In composite video mode, the video DAC2 chroma output must be disabled by setting the DSS.VENC\_OUTPUT\_CONTROL[2] CHROMA\_ENABLE bit to 0.

Figure 7-61 is a block diagram of the TV display interface (Bypass mode, Dual Channel).

**Figure 7-61. TV Display Interface (Bypass Mode, Dual Channel)**

dss-402

Table 7-17 describes the interface signals to/from the TV set for TV display support.

**Table 7-17. TV Display Interface Pins**

| Pin Name     | Type <sup>(1)</sup> | Description                                                                                                                                                                                                        |
|--------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| cvideo1_out  | O                   | Analog luma or composite video output. An external resistor Rout1 is connected between this node and the cvideo1_vfb pin. Note that this is the output node that drives the load (75 Ω).                           |
| cvideo2_out  | O                   | Analog chroma video output. An external resistor Rout2 is connected between this node and the cvideo2_vfb pin. This is the output node that drives the load (75 Ω).                                                |
| cvideo1_vfb  | O                   | Amplifier feedback node. An external resistor Rout1 is connected between this node and cvideo1_out.                                                                                                                |
| cvideo2_vfb  | O                   | Amplifier feedback node. An external resistor Rout2 is connected between this node and cvideo2_out.                                                                                                                |
| cvideo1_rset | I/O                 | External resistor pin to set the reference current of the AVDAC1. The value of the resistor (Rset) depends on the mode of operation. Refer to <a href="#">Table 7-18, Typical values for Rout, Rset and Cout</a> . |
| vdda_dac     | Power               | Analog supply voltage for the video DAC stage                                                                                                                                                                      |
| vssa_dac     | Power               | Analog ground for the video DAC stage                                                                                                                                                                              |

<sup>(1)</sup> O = Output, Power = Power pin

[Table 7-18](#) lists the typical values for the Rout1/2 and Rset resistors and the Cout capacitor, for different modes of the TV display interface.

**Table 7-18. Typical values for Rout, Rset and Cout**

|        | S-video, DC coupled, High FS Swing | Composite, DC coupled, High FS Swing | Composite, AC coupled, Low FS Swing | Bypass, Dual channel | Unit |
|--------|------------------------------------|--------------------------------------|-------------------------------------|----------------------|------|
| Rout 1 | 2700                               | 2700                                 | 2700                                | 1500                 | Ohm  |
| Rout 2 | 2700                               | N/A                                  | N/A                                 | 1500                 | Ohm  |
| Rset   | 4700                               | 4700                                 | 6800                                | 10000                | Ohm  |
| Cout   | N/A                                | N/A                                  | 220                                 | N/A                  | μF   |

**CAUTION**

- High full-scale swing is the default mode. Low-swing mode does not comply with the NTSC and PAL video standards. It must be used only for backward compatibility to the OMAP35x.
- All resistor values in [Table 7-18](#) must be within  $\pm 1\%$  tolerance range.
- cvideo1\_out and cvideo2\_out are very high-frequency analog signals and must be routed with extreme care. As a result, the path of these signals must be as short as possible, and as isolated as possible from other interfering signals.
- During board design, the onboard traces and parasites must be matched for the two channels. cvideo1\_vfb and cvideo2\_vfb pins are the most sensitive pins in the TV out system. The onboard parasitic capacitance associated with these two pins must be less than 0.5 pF. Low onboard resistance is required for the traces that connect the Rout1/Rout2 to the cvideo1\_vfb/cvideo2\_vfb and TV OUT pins (cvideo1\_out and cvideo2\_out). The resistance on those trace affects output impedance matching. Therefore, Rout1 and Rout2 resistors are suggested to be placed as close as possible to the device pins. The onboard traces lead to the TV OUT pins must have a characteristic impedance of  $75 \Omega$  starting from the closest possible place to the device pin output.
- If the TV output is not used, the following configurations for the AVDACs pins must be applied:
  - Configuration 1
    - cvideo1\_out must be grounded.
    - cvideo1\_vfb must be grounded.
    - cvideo2\_out must be grounded.
    - cvideo2\_vfb must be grounded.
    - cvideo1\_rset must be grounded.
    - vdda\_dac must be grounded.
    - vssa\_dac must be grounded.
  - Configuration 2
    - cvideo1\_out must be floating, left unconnected.
    - cvideo1\_vfb must be floating, left unconnected.
    - cvideo2\_out must be floating, left unconnected.
    - cvideo2\_vfb must be floating, left unconnected.
    - cvideo1\_rset must be floating, left unconnected.
    - vdda\_dac must be grounded.
    - vssa\_dac must be grounded.
- To avoid current leakage, the following bits must be set to 0:
  - DSS.[DSS\\_CONTROL\[5\]](#) DAC\_POWERDN\_BGZ
  - DSS.[VENC\\_OUTPUT\\_CONTROL\[2:0\]](#)
  - PRCM.CM\_FCLKEN\_DSS[2] EN\_TV
  - CONTROL.CONTROL\_DEVCONF[18] TVOUTBYPASS

**7.2.3.1 TV Output and Data Format**

The output data to the TV set are the analog composite data from the video DAC stage. The following video standards are supported:

- NTSC-J, M

- PAL-B, D, G, H, I
- PAL-M

### 7.2.3.2 Digital-to-Analog Converters

The video DAC stage includes the following main features:

- 1.1-V digital power supply, 1.8-V analog power supply
- 10-bit resolution
- DNL within 1 LSB and INL within 1 LSB (in bypass mode)
- Sample rate of up to 60 mega samples per second (MSPS)
- Support composite/S-video DC or AC coupled output
- Support TVOUT buffer bypass mode (DAC-only mode)
- Full-scale voltage output: minimum 1.2 Vpp with a 75- $\Omega$  load
- Internal TV detect feature
- Signal-to-noise ratio (SNR) is 54 dB (taking into account the ac coupling)
- Suitable for low-power consumer video applications
- Power-down mode with less than 12- $\mu$ A standby current
- Differential gain error and differential phase error: within 3 percent and 1 degree, respectively

---

**NOTE:** To enhance the TV color display, it is highly recommended to set the DSS.DSS\_CONTROL[4] DAC\_DEMEN bit.

For more information about the video DAC stage architecture and configuration, see [Section 7.4.7.7, Video DAC Stage – Architecture and Control](#).

---

## 7.3 Display Subsystem Integration

This section describes the integration of the display subsystem and details clocks, resets, hardware requests, and power modes.

[Figure 7-62](#) shows the integration of the display subsystem in the device.

Figure 7-62. Display Subsystem Integration



camdss-036

### 7.3.1 Clocking, Reset, and Power-Management Scheme

#### 7.3.1.1 Clocks

The power, reset, and clock management (PRCM) module provides six clock signals to the display subsystem: The L3 interface clock (DSS\_L3\_ICLK) and the L4 interface clock (DSS\_L4\_ICLK), with frequencies equal to the L3 interconnect clock and the L4 interconnect clock, respectively; two configurable functional clocks (DSS1\_ALWON\_FCLK and DSS2\_ALWON\_FCLK); and one other functional clock (DSS\_TV\_FCLK).

The DSI PLL provides two functional clock signals to the display subsystem: DSI1\_PLL\_FCLK and DSI2\_PLL\_FCLK.

[Figure 7-63](#) details the clock tree for the display subsystem.

**Figure 7-63. Display Subsystem Clock Tree**



camdss-158

**NOTE:** A synchronization signal is sent by the display controller (DISPC) to the DSI protocol engine. This signal, named DISPC\_UPDATE\_SYNC, is used to inform the DSI protocol engine that it must be unsynchronized with the display controller.

Table 7-19 describes the different clocks with their possible frequency values.

**Table 7-19. Display Subsystem Clocks**

| Clock Signal    | Attribute          | Module                     | Frequency                                                                           | Comment                                                                                                                                  |
|-----------------|--------------------|----------------------------|-------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| DSS_L3_ICLK     | L3 interface clock | DSS                        | (See <a href="#">Chapter 3, Power, Reset, and Clock Management</a> )                | L3 interface clock from PRCM                                                                                                             |
| DSS_L4_ICLK     | L4 interface clock | DSS                        | (See <a href="#">Chapter 3, Power, Reset, and Clock Management</a> )                | L4 interface clock from PRCM                                                                                                             |
| DSS1_ALWON_FCLK | Functional clock   | DISPC, DSI protocol engine | Up to 173 MHz at nominal voltage (OPP100), and up to 100 MHz at low voltage (OPP50) | From PRCM: DPLL4 (source: DPLL4_ALWON_FCLK)                                                                                              |
| DSS2_ALWON_FCLK | Functional clock   | DSI PLL                    | 12/13/16.8/19.2/26/38.4 MHz                                                         | From PRCM: SYS_CLK                                                                                                                       |
| DSI1_PLL_FCLK   | Functional clock   | DISPC                      | Up to 173 MHz at nominal voltage (OPP100), and up to 100 MHz at low voltage (OPP50) | From DSI PLL and HS divider                                                                                                              |
| DSI2_PLL_FCLK   | Functional clock   | DSI protocol engine        | Up to 173 MHz at nominal voltage (OPP100), and up to 100 MHz at low voltage (OPP50) | From DSI PLL and HS divider                                                                                                              |
| DSS_TV_FCLK     | Functional clock   | DSS, video mode DAC        | 54 MHz or sys_alt_clk (up to 59 MHz)                                                | From PRCM: DPLL4 (source: DPLL4_ALWON_FCLK) or External input clock (See <a href="#">Chapter 3, Power, Reset, and Clock Management</a> ) |

To enable or disable each functional clock, set the following bit (1: Enable, 0: Disable):

- PRCM.CM\_FCLKEN\_DSS[0] EN\_DSS1 bit to enable DSS1\_ALWON\_FCLK
- PRCM.CM\_FCLKEN\_DSS[1] EN\_DSS2 bit to enable DSS2\_ALWON\_FCLK
- PRCM.CM\_FCLKEN\_DSS[2] EN\_TV bit to enable DSS\_TV\_FCLK

To enable or disable the DSS\_L3\_ICLK and DSS\_L4\_ICLK interface clocks, write (1: Enable, 0: Disable) to the PRCM.CM\_ICLKEN\_DSS[0] EN\_DSS bit.

**NOTE:** Note that it is not possible to gate/stop L3 clock and keep L4 clock running.

- L3 and L4 interface clock

The DSS\_L3\_ICLK clock is only used by the display controller interface to fetch the pixel data. The DSS\_L4\_ICLK is used to access the L4 interconnect for configuring all the display subsystem registers.

**NOTE:** A clock generated internally from the L3 interface clock allows the submodules to be configured and is the functional clock for the RFBI. All the display subsystem registers are configured through the display subsystem register.

- Display controller functional clocks

The display controller can use either the DSS1\_ALWON\_FCLK or the DSI1\_PLL\_FCLK functional

clock.

To select the DSS1\_ALWON\_FCLK functional clock (the default clock selected after reset), write 0 in the DSS.[DSS\\_CONTROL\[0\]](#) DISPC\_CLK\_SWITCH bit; to select the DS1\_PLL\_FCLK functional clock, write 1 in the DSS.[DSS\\_CONTROL\[0\]](#) DISPC\_CLK\_SWITCH bit.

---

**NOTE:** The DSS1\_ALWON\_FCLK and DS1\_PLL\_FCLK functional clocks must be active (the PRCM.CM\_FCLKEN\_DSS[0] EN\_DSS1 and DS1 PLL programmed correctly) to switch from one functional clock to another. The new functional clock is effective when the next vertical blanking interval occurs. This is true only if the DSS.[DISPC\\_CONTROL\[5\]](#) GOLCD bit is set to 1.

---

Depending on the DLL4 input clock frequency, the DSS1\_ALWON\_FCLK can be adjusted by setting the PRCM.CM\_CLKSEL\_DSS[4:0] CLKSEL\_DSS1 bit field.

- DS1 PLL functional clock (DSI\_PLL\_REFCLK)

The DS1 PLL controller module can use either the DSS2\_ALWON\_FCLK (from PRCM) or the PCLKFREE (from DISPC) functional clock. To select the DSS2\_ALWON\_FCLK functional clock (default clock selected after reset), write 0 in the DSS.[DSI\\_PLL\\_CONFIGURATION2\[11\]](#) DS1\_PLL\_CLKSEL bit; to select the PCLKFREE functional clock, write 1 in the DSS.[DSI\\_PLL\\_CONFIGURATION2\[11\]](#) DS1\_PLL\_CLKSEL bit.

- DS1 protocol engine functional clocks (DSI\_FCLK)

The DS1 protocol engine can use either the DSS1\_ALWON\_FCLK (from PRCM) or the DS12\_PLL\_FCLK (from DS1 PLL) functional clock. To select the DSS1\_ALWON\_FCLK functional clock (default clock selected after reset), write 0 in the DSS.[DSS\\_CONTROL\[1\]](#) DS1\_CLK\_SWITCH bit; to select the DS12\_PLL\_FCLK functional clock, write 1 in the DSS.[DSS\\_CONTROL\[1\]](#) DS1\_CLK\_SWITCH bit.

---

**NOTE:** It is possible to switch between these two clocks, even when both of them are not active.

---

- There are five clock domains in the DS1 module:

- Byte clock domain:

TxByteClkHS is generated from the bit clock and converted into a byte clock. The maximum frequency is 112.5 MHz at nominal voltage (OPP100), and 100 MHz at low voltage (OPP50). It is generated by the DS1 complex I/O.

- Functional clock domain

The DS1\_FCLK is the functional clock for the DS1 protocol engine module. The maximum frequency is 173 MHz (nominal voltage) and 100 MHz (low voltage). It must always be equal to or higher than the byte (TxByteClkHS), L4 interconnect (DSS\_L4\_ICLK), and video port (VP\_CLK) clocks. The software must configure the clocks correctly.

- L4 interface clock domain

The DSS\_L4\_ICLK is used in the L4 interconnect port domain. The maximum frequency is 100 MHz at nominal voltage.

- The video port domain

The pixel clock (PCLK) on the video port is used by the video port domain to capture the pixels from the display controller. The maximum frequency of VP\_CLK used as the functional clock for the video port domain is 173 MHz at nominal voltage and 96 MHz at low voltage.

- Serial Configuration Port (SCP) and Power Control (PWR) interfaces

The DSS\_L4\_ICLK is the functional clock.

**NOTE:**

- There is no clock domain for RxClkEsc because it is used as an enable and not as a clock by the DSI protocol engine module
- The clock domains are asynchronous (except for L4 interconnect port and SCP/PWR because both of them use DSS\_L4\_ICLK). The clocks used for the L4 interconnect port and SCP/PWR interface must be balanced.
- If video mode is used, the display controller functional clock must be generated using a clock from the DSI PLL.

- 
- Video encoder functional clock

The DSS\_TV\_FCLK is divided into three balanced clocks, depending on the clock mode selected (see [Table 7-20](#)).

**Table 7-20. Possible Digital Clock Division for the Video Encoder**

| Clock Output           | Clock Mode    |                          |
|------------------------|---------------|--------------------------|
|                        | Clock Mode 0  | Clock Mode 1             |
| Video encoder clock 4x | DSS_TV_FCLK   | DSS_TV_FCLK or 0 (gated) |
| Video encoder clock 2x | DSS_TV_FCLK/2 | DSS_TV_FCLK              |
| Video encoder clock 1x | DSS_TV_FCLK/4 | DSS_TV_FCLK/2            |

The clock mode is defined by the [DSS\\_CONTROL\[2\]](#) VENC\_CLOCK\_MODE register bit:

- In the case of clock mode 1, the [DSS\\_CONTROL\[3\]](#) VENC\_CLOCK\_4X\_ENABLE bit is used to control clock gating.
- In the case of clock mode 0, the VENC\_CLOCK\_4X\_ENABLE bit must be set to 0x1 by software.

---

**NOTE:** After reset, clock mode 0 is selected by default, and the DSS\_TV\_CLK clock is disabled. The DSS\_TV\_CLK / 4 in mode 0, or the DSS\_TV\_CLK / 2 in mode 1, is used in the DISPC module to send data to the video encoder.

---

**NOTE:** Clock mode 1 can be used for power-saving purposes, or if a 27-MHz external clock is provided to the video encoder.

---

DSS\_TV\_FCLK can be adjusted depending on the DPLL4 input clock frequency by setting the PRCM.CM\_CLKSEL\_DSS[12:8] CLKSEL\_TV bit field. If the DPLL4 is selected, the DSS\_TV\_FCLK is provided by the DPLL4\_ALWON\_FCLKOUTM3X2 clock.

---

**NOTE:** If the DSS\_TV\_FCLK is not provided by DPLL4 but rather by the sys\_alt\_clk pin, an external clock generator must be connected to this pin. In this case, a 54-MHz clock is needed for PAL or NTSC 601, a 49.09-MHz clock is needed for NTSC square pixel, and a 59-MHz clock is needed for PAL square pixel.

---

- Video DAC stage clocks

The video DAC stage uses one distinct clock: The DSS\_TV\_FCLK. The video data are latched on the positive edge of the DSS\_TV\_FCLK clock.

### 7.3.1.2 Resets

#### 7.3.1.2.1 Hardware Reset

The display subsystem receives its reset signal DSS\_RST (the reset signal of the display subsystem [DSS] power domain) from the PRCM module.

### 7.3.1.2.2 Software Reset

The display subsystem can receive a software reset propagated through all of the submodules and used to initialize the display subsystem. To apply the reset, write to the DSS.[DSS\\_SYSCONFIG\[1\]](#) SOFTRESET bit (1: Reset; 0: Normal). The DSS.[DSS\\_SYSSTATUS\[0\]](#) RESETDONE bit indicates that the software reset is complete when its value is 1.

**NOTE:** The display controller, the DSI protocol engine, and the RFBI modules also have their own software reset functionality. To access this reset, access the DSS.[DISPC\\_SYSCONFIG\[1\]](#) SOFTRESET bit for the display controller, the DSS.[DSI\\_SYSCONFIG\[1\]](#) SOFTRESET bit for the DSI protocol engine, and the DSS.[RFBI\\_SYSCONFIG\[1\]](#) SOFTRESET bit for the RFBI module.

To properly reset these modules, 0x2 is the only valid value to write to these registers.

#### CAUTION

All the interface and functional clocks, even for the TV output, must be provided to the display subsystem to update the RESETDONE status bit correctly.

### 7.3.1.3 Power Domain

The display subsystem modules are on the display subsystem (DSS) power domain and on the VDD2 voltage domain, except for the video DAC stage, which are on the analog vdda\_dac voltage domain.

### 7.3.1.4 Power Management

#### 7.3.1.4.1 Clock Activity Mode

The display controller clocks can be configured in one of the following clock activity modes:

- DSS.[DISPC\\_SYSCONFIG\[9:8\]](#) CLOCKACTIVITY bit field set to 0x0 (reset value): The interface and functional clocks can be switched off.
- DSS.[DISPC\\_SYSCONFIG\[9:8\]](#) CLOCKACTIVITY bit field set to 0x1: The functional clocks can be can be switched off and the interface clocks are maintained during the wake-up period.
- DSS.[DISPC\\_SYSCONFIG\[9:8\]](#) CLOCKACTIVITY bit field set to 0x2: The interface clocks can be can be switched off and the functional clocks are maintained during the wake-up period.
- DSS.[DISPC\\_SYSCONFIG\[9:8\]](#) CLOCKACTIVITY bit field set to 0x3: The interface and functional clocks are maintained during the wake-up period.

The DSI protocol engine clocks can be configured in one of the following clock activity modes:

- DSS.[DSI\\_SYSCONFIG\[9:8\]](#) CLOCKACTIVITY bit field set to 0x0 (reset value): The interface and functional clocks can be switched off.
- DSS.[DSI\\_SYSCONFIG\[9:8\]](#) CLOCKACTIVITY bit field set to 0x1: The functional clocks can be switched off and the interface clocks are maintained during the wake-up period.
- DSS.[DSI\\_SYSCONFIG\[9:8\]](#) CLOCKACTIVITY bit field set to 0x2: The interface clocks can be switched off and the functional clocks are maintained during the wake-up period.
- DSS.[DISPC\\_SYSCONFIG\[9:8\]](#) CLOCKACTIVITY bit field set to 0x3: The interface and functional clocks are maintained during the wake-up period.

The DSS power domain clock activity status is logged in the PRCM.CM\_CLKSTST\_DSS[0] CLKACTIVITY\_DSS status bit. When set to 0, there is no domain clock activity. When set to 1, the DSS power domain clock is active.

- NOTE:** The display subsystem interface clock can be dependent on the DSS power domain state. This is configured with PRCM.CM\_AUTOIDLE\_DSS[0] AUTO\_DSS bit:
- When the AUTO\_DSS bit is set to 0 (reset value): The display subsystem interface clock is not related to the DSS power domain state transition.
  - When the AUTO\_DSS bit is set to 1: The display subsystem interface clock is automatically enabled or disabled along with the DSS power domain state transition.

#### 7.3.1.4.2 Autoidle Mode

The RFBI, display controller, DSI protocol engine, and L4 interfaces can internally gate their clocks to decrease power consumption if no transaction is present on the related bus. The following bits must be set to enable this functionality:

- DSS.[DSS\\_SYSCONFIG](#)[0] AUTOIDLE bit (1: Autoidle; 0: Clock free-running) for the display subsystem
- DSS.[RFBI\\_SYSCONFIG](#)[0] AUTOIDLE bit (1: Autoidle; 0: Clock free-running) for the RFBI
- DSS.[DISPC\\_SYSCONFIG](#)[0] AUTOIDLE bit (1: Autoidle; 0: Clock free-running) for the display controller
- DSS.[DSI\\_SYSCONFIG](#)[0] AUTOIDLE bit (1: Autoidle; 0: Clock free-running) for the DSI protocol engine
- DSS.[DISPC\\_CONFIG](#)[9] FUNCATED bit (1: Functional clocks gated enabled; 0: Functional clocks gated disabled) for the display controller

- NOTE:** All the bits listed above (except for the FUNCATED bit) are set to 1 by default. It is highly recommended to set all the bits to 1 to save power.

#### 7.3.1.4.3 Idle Mode

The display controller, DSI protocol engine, and RFBI can be configured into one of the following acknowledgment modes:

- Force-idle mode: The module immediately enters the idle state on receiving a low-power mode request from the PRCM module. In this mode, the software must ensure that there are no asserted output interrupts before requesting this mode to go into the idle state. Set the DSS.[DISPC\\_SYSCONFIG](#)[4:3] SIDLEMODE bit field to 0x0 (reset value) for display controller, set the DSS.[DSI\\_SYSCONFIG](#)[4:3] SIDLEMODE bit field to 0x0 (reset value) for DSI protocol engine, and, finally, the DSS.[RFBI\\_SYSCONFIG](#)[4:3] SIDLEMODE bit field to 0x0 (reset value) for RFBI.
- No-idle mode: The module never enters the idle state. Set the DSS.[DISPC\\_SYSCONFIG](#)[4:3] SIDLEMODE bit field to 0x1 for display controller, set the DSS.[DSI\\_SYSCONFIG](#)[4:3] SIDLEMODE bit field to 0x1 for DSI protocol engine, and, finally, the DSS.[RFBI\\_SYSCONFIG](#)[4:3] SIDLEMODE bit field to 0x1 for RFBI.
- Smart-idle mode:
  - Display controller: After receiving a low-power-mode request from the PRCM module, the display controller module enters the idle state when all the following conditions are satisfied:
    - All asserted output interrupts are acknowledged (no interrupt pending).
    - The display controller does not use anymore the L4 interface clock (DSS\_L4\_ICLK).
  - DSI protocol engine: After receiving a low-power-mode request from the PRCM module, the DSI protocol engine enters the idle state when all the following conditions are satisfied:
    - All asserted output interrupts are acknowledged (no interrupt pending).
    - The DSI protocol engine does not use the L4 interface clock (DSS\_L4\_ICLK) anymore.
    - The SCP and PWR transactions are complete.
    - No data remains in the TX FIFO (data waiting in the FIFO to be sent to the peripheral).

To configure the display subsystem in smart-idle mode, set the DSS.[DISPC\\_SYSCONFIG](#)[4:3] SIDLEMODE bit field to 0x2 for display controller, set the DSS.[DSI\\_SYSCONFIG](#)[4:3] SIDLEMODE bit field to 0x2 for DSI protocol engine, and, finally, the DSS.[RFBI\\_SYSCONFIG](#)[4:3] SIDLEMODE bit field to 0x2 for RFBI.

Once the idle handshake protocol is over:

- The DSS L4 interface clock (DSS\_L4\_ICLK) can be shutdown at any time.
- Any transaction on the L4 configuration port is ignored.

#### 7.3.1.4.4 Wake-Up Mode

The Display Controller (DISPC) supports the wake-up protocol. The mode is selected by programming the appropriate value in the DSS.[DISPC\\_SYSConfig\[2\]](#) ENWAKEUP bit. The wake-up signal is asserted when the DISPC is in idle mode and when anyone of the following events occur:

- Graphics pipe is enabled and data fetch is not completed for graphics window, and the number of data bytes in FIFO is less than the low threshold programmed value.
- Video1 pipe is enabled and data fetch is not completed for video1 window, and the number of data bytes in FIFO is less than the low threshold programmed value.
- Video2 pipe is enabled and data fetch is not completed for video2 window, and the number of data bytes in FIFO is less than the low threshold programmed value.
- The current pixel is the last pixel displayed on the LCD panel if it is not the last frame.
- The current pixel is the last pixel displayed on the digital panel if it is not the last frame.

If software users set the DSS.[DISPC\\_CONFIG\[17\]](#) FIFOFILLING bit, when one of the active pipe reaches the low threshold and should refill the FIFO for the current frame, the other pipes also refill their own FIFOs, even if the low threshold has not been reached. This is used to improve the probability of increasing the time when there is no access to the L3 interconnect (MStandby asserted, affects power savings).

Once the wake-up signal is asserted, the WAKEUP interrupt request is generated. The wake-up signal is deasserted when the idle request is no longer activated.

#### 7.3.1.4.5 Standby Mode

As part of the system-wide power-management scheme, the display controller can enter standby mode.

To configure the display controller, write the DSS.[DISPC\\_SYSConfig\[13:12\]](#) MIDLEMODE bit field (00: Forced standby; 01: No standby; 10: Smart standby) in one of the following standby modes:

- Forced standby mode (default mode): The module enters standby mode when the module is disabled.
- No standby mode: The module never enters standby mode.
- Smart standby mode: The module enters standby state when the DISPC module is disabled or when all the three following events occur:
  - Graphics pipe is disabled or graphics pipe is enabled but data fetch completed for graphics window, or graphics pipe is enabled and data fetch is not completed and number of data bytes in FIFO is greater than the high threshold programmed value.
  - Video1 pipe is disabled or video1 pipe is enabled but data fetch completed for video1 window, or video1 pipe is enabled and data fetch is not completed and number of data bytes in FIFO is greater than the high threshold programmed value.
  - Video2 pipe is disabled or video2 pipe is enabled but data fetch completed for video2 window, or video2 pipe is enabled and data fetch is not completed and number of data bytes in FIFO is greater than the high threshold programmed value.

When in standby mode, the display controller does not generate transactions on the L3 master port. Standby is active when the PRCM module confirms this mode.

The display subsystem standby mode activity can be monitored with the PRCM.CM\_IDLEST\_DSS[0] ST\_DSS status register. When this register is read to 0, the display subsystem is accessible and the interface clock running; when it is read to 1, the display subsystem is in standby mode.

##### 7.3.1.4.5.1 Conditions to Exit Standby Mode

The following conditions allow the subsystem to exit standby mode:

- Forced standby mode: Standby mode is exited when the display controller is enabled.
- Smart standby mode: Standby mode is exited when any one of the following events occurs:

- Graphics pipe is enabled and data fetch is not completed for graphics window, and number of data bytes in FIFO is less than the low threshold programmed value.
- Video1 pipe is enabled and data fetch is not completed for video1 window, and number of data bytes in FIFO is less than the low threshold programmed value.
- Video2 pipe is enabled and data fetch is not completed for video2 window, and number of data bytes in FIFO is less than the low threshold programmed value.

#### 7.3.1.4.5.2 Standby Transition Dependency

The sleep transition of the DSS power domain can be dependent or not with respect to MPU domain. This is configured by PRCM.CM\_SLEEPDEP\_DSS[1] EN\_MPU bit:

- When the EN\_MPU bit is set to 0 (reset value): The DSS power domain sleep dependency with the MPU power domain is disabled. The DSS power domain will not enter idle unless the MPU power has previously entered idle.
- When the EN\_MPU bit is set to 1: The DSS power domain sleep dependency with the MPU power domain is enabled. The DSS power domain will enter idle regardless of the power domain state of the MPU.

The sleep transition of the DSS power domain may, or may not depend on the IVA2.2 domain, depending on the configuration of the PRCM.CM\_SLEEPDEP\_DSS[2] EN\_IVA2 bit:

- When the EN\_IVA2 bit is set to 0 (reset value): The DSS power domain sleep dependency on the IVA2.2 power domain is disabled.
- When the EN\_IVA2 bit is set to 1: The DSS power domain sleep dependency on the IVA2.2 power domain is enabled.

#### 7.3.1.4.5.3 Standby Procedure Description

When the display subsystem initiates a standby procedure, it also initiates an standby/wait handshake protocol with the PRCM module that lets the PRCM cut the display subsystem clocks. Depending on the PRCM setting, two modes are available:

- Manual mode
  - DSS1\_ALWON\_FCLK is shut down when the PRCM.CM\_FCLKEN\_DSS[0] EN\_DSS1 bit is set to 0 and the display subsystem is in standby mode.
  - DSS2\_ALWON\_FCLK is shut down when the PRCM.CM\_FCLKEN\_DSS[1] EN\_DSS2 bit is set to 0 and the display subsystem is in standby mode.
  - DSS\_L3\_ICLK and DSS\_L4\_ICLK are controlled together. They are shut down when the PRCM.CM\_ICLKEN\_DSS[0] EN\_DSS bit is set to 0 and the display subsystem is in standby mode.

##### CAUTION

Do not stop DSS1\_ALWON\_FCLK, or DSS2\_ALWON\_FCLK clock (if used) if the display subsystem is not disabled.

##### CAUTION

DSS\_TV\_FCLK does not depend on the display subsystem standby state. Ensure correct clock management for DSS\_TV\_FCLK.

The clocks are reactivated when the related bits are set to 1 and the display subsystem exits from standby. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

- Hardware- or software-supervised mode

The DSS-power state-transition between active and inactive states can be either hardware or software supervised. This is programmed with the PRCM.CM\_CLKSTCTRL\_DSS[1:0] CLKTRCTRL\_DSS bit field:

- When the CLKTRCTRL\_DSS bit field is set to 0x0 (reset value), the automatic transition is disabled.
- When the CLKTRCTRL\_DSS bit field is set to 0x1, the software-supervised sleep transition is started on the DSS power domain.
- When the CLKTRCTRL\_DSS bit field is set to 0x2, the software-supervised wake-up transition is started on the DSS power domain.
- When the CLKTRCTRL\_DSS bit field is set to 0x3, the automatic transition is enabled. Any transition on the DSS power domain is supervised by the hardware.

#### 7.3.1.4.5.4 Display Subsystem Standby Mode, Power-Saving Use Cases

- Setup
  - Set the display subsystem in smart standby mode.
  - Manually enable DSS\_L3\_ICLK and DSS\_L4\_ICLK.
  - Manually enable DSS1\_ALWON\_FCLK or DSS2\_ALWON\_FCLK.
  - Manually enable DSS\_TV\_FCLK if the video encoder is used.
  - Set the PRCM.CM\_CLKSTCTRL\_DSS[1:0] CLKTRCTRL\_DSS bit field to 0x3 (autocontrol mode supervised by hardware).
- Shut down the display subsystem.
  - Disable the display subsystem.
  - Manually disable DSS1\_ALWON\_FCLK, DSS2\_ALWON\_FCLK, DSS\_TV\_FCLK, DSS\_L3\_ICLK, and DSS\_L4\_ICLK.

For more details on low-power programming settings, see [Section 7.6.2](#).

## 7.3.2 Hardware Requests

### 7.3.2.1 DMA Requests

The display controller, the DSI protocol engine, and the RFBI generate some DMA requests to the sDMA. Figure 7-64 details the DMA tree.

**Figure 7-64. Display Subsystem DMA Tree**



**Table 7-21. DSS DMA Requests Description**

| DMA Request Name | DSS Module          | Mapping  | Description                           |
|------------------|---------------------|----------|---------------------------------------|
| DSS_LINE_TRIGGER | DISPC               | S_DMA_5  | See <a href="#">Section 7.3.2.1.1</a> |
| DSI_DMA_REQ0     | DSI protocol engine | S_DMA_71 | See <a href="#">Section 7.3.2.1.2</a> |
| DSI_DMA_REQ1     | DSI protocol engine | S_DMA_72 | See <a href="#">Section 7.3.2.1.2</a> |
| DSI_DMA_REQ2     | DSI protocol engine | S_DMA_73 | See <a href="#">Section 7.3.2.1.2</a> |
| DSI_DMA_REQ3     | DSI protocol engine | S_DMA_74 | See <a href="#">Section 7.3.2.1.2</a> |
| RFBI_DMA_REQ     | RFBI                | S_DMA_74 | See <a href="#">Section 7.3.2.1.3</a> |

**NOTE:** The DMA requests from the RFBI module (RFBI\_DMA\_REQ) and the DSI protocol engine (DSI\_DMA\_REQ3) are merged on line DSS\_DMA3. The software must only use DSS\_DMA3 on one module at a time (RFBI or DSI protocol engine).

### 7.3.2.1.1 Display Controller DMA Request (Line Trigger)

One DMA synchronization line (DSS\_LINE\_TRIGGER) is connected to the sDMA by the sDMA controller (S\_DMA\_5) input line. This DMA request is not a classical one but a synchronization signal from the display subsystem to the sDMA informing the sDMA that a programmable number of lines are output to the LCD, and that the system memory can be updated. This request is related to an interrupt event described in [Section 7.3.2.2, Interrupt Requests](#). This allows the sDMA channel to be synchronized with the display subsystem internal DMA controller. In other words, it allows to synchronize a memory to memory frame buffer update based on the scan line of the frame buffer in system memory (SDRAM or SRAM) by the display controller. The DSS\_LINE\_TRIGGER DMA request is generated at a programmable line number defined in DSS.DISPC\_LINE\_NUMBER[10:0] LINENUMBER bit field.

### 7.3.2.1.2 DSI Protocol Engine DMA Request

The DSI DMA requests are used to allow automatic transfer by the sDMA or MPU (with less efficiency and through-put capability) from the DSI RX FIFO to the system memory and from the system memory to the DSI TX FIFO. Two independent DMA requests for RX FIFO and TX FIFO for the same VC are supported.

### 7.3.2.1.3 RFBI DMA Request

The RFBI\_DMA\_REQ is used to receive data into the RFBI FIFO. The DMA request is always generated when there is enough room in the FIFO to accept the full burst.

### 7.3.2.2 Interrupt Requests

The DSI protocol engine, the DSI complex I/O (DSI\_IRQ), and the display controller (DISPC IRQ) generate one interrupt request each. The DSI\_IRQ and DISPC IRQ lines are merged together in a single interrupt line.

One interrupt line (DSS\_IRQ) is connected to two interrupt controllers:

- MPU interrupt controller (M\_IRQ\_25 input line)
- IVA interrupt handler (IVA2\_IRQ[13] input line)

[Figure 7-65](#) shows the interrupt tree for the DSI protocol engine and DSI complex I/O in detail.

**Figure 7-65. DSI Interrupt Tree**



dss-160

Figure 7-66 details the interrupt tree for the DISPC and the display subsystem.

**Figure 7-66. DISPC and DSS Interrupts Tree**



dss-161

### 7.3.2.2.1 DISPC Interrupt Request

The interrupt line indicates when one or more events are detected by the hardware. Each event is independently maskable by setting the DSS.[DISPC\\_IRQENABLE](#) register.

To check when a particular interrupt event occurs and to reset a particular event, the DSS.[DISPC\\_IRQSTATUS](#) register must be accessed. This register regroups all the status of the module internal events that generate an interrupt (read 0: No interrupt occurred; read 1: Interrupt occurred; write 1: Status bit reset). See [Section 7.7, Display Subsystem Register Manual](#), for more information on checking and clearing interrupt events.

[Table 7-22](#) lists the display subsystem interrupt events.

**Table 7-22. Display Subsystem Interrupts**

| Interrupt Name             | Description                                                                                                                              |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| FRAMEDONE                  | Active frame is complete and LCD output is disabled.                                                                                     |
| VSYNC                      | VSYNC interrupt occurred at the end of the frame.                                                                                        |
| EVSYNC_EVEN <sup>(1)</sup> | EVSYNC_EVEN interrupt occurred at the end of the frame. (EVSYNC is received and the field polarity is even.)                             |
| EVSYNC_ODD <sup>(1)</sup>  | EVSYNC_ODD interrupt occurred at the end of the frame. (EVSYNC is received and the field polarity is odd.)                               |
| ACBIASCOUNTSTATUS          | The ac-bias transition counter decremented to 0.                                                                                         |
| PROGRAMMEDLINENUMBER       | The LCD reached the user-programmed line number.                                                                                         |
| GFXFIFOUNDERFLOW           | The input graphics FIFO goes underflow.                                                                                                  |
| GFXENDWINDOW               | The screen reached the end of the graphics window. All data for the graphics window are fetched from memory and displayed on the screen. |
| PALETTEGAMMALOADING        | The palette/gamma table is loaded.                                                                                                       |
| OCPERROR                   | L3 interconnect sent SResp = ERR.                                                                                                        |
| VID1FIFOUNDERFLOW          | The input video1 FIFO goes underflow.                                                                                                    |

<sup>(1)</sup> EVYNC interrupts (EVSYNC\_EVEN and EVSYNC\_ODD) are external interrupts received by the display controller and generated by the video encoder (VENC) module.

**Table 7-22. Display Subsystem Interrupts (continued)**

| Interrupt Name    | Description                                                                                                                                                                                          |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VID1ENDWINDOW     | The screen reached the end of video1 window. All data for the video window are fetched from the memory and displayed on the screen.                                                                  |
| VID2FIFOUNDERFLOW | The input video2 FIFO goes underflow.                                                                                                                                                                |
| VID2ENDWINDOW     | The screen reached the end of video2 window. All data for the video window are fetched from the memory and displayed on the screen.                                                                  |
| SYNCLOST          | Interrupt occurs when VSYNC width/front or back porches are not wide enough to load the pipelines with data (LCD output).                                                                            |
| SYNCLOSTDIGITAL   | Interrupt occurs when the display controller is not ready to output data when a digital request occurs. This interrupt informs that the timings of the NTSC/PAL video encoder are not set correctly. |
| WAKEUP            | Occurs when the wakeup signal is asserted                                                                                                                                                            |

**NOTE:** To clear a synchronization lost interrupt, follow this sequence:

1. Clear the DSS.DISPC\_CONTROL[0] LCDENABLE (LCD: SYNCLOST interrupt) or DSS.DISPC\_CONTROL[1] DIGITALENABLE (TV: SYNCLOSTDIGITAL interrupt) bits.  
Check the interrupts.  
LCD: Verify that a FRAMEDONE interrupt occurs.  
TV : Verify that EVSYNC\_EVEN or EVSYNC\_ODD interrupts occur.
2. Set the DSS.DSS\_SYSCONFIG[1] SOFTRESET bit to reset the display subsystem.
3. Set the display subsystem registers again.

**NOTE:** The SYNCLOSTDIGITAL interrupts, which occur before the first VSYNC pulse signal (from the video encoder), must not be considered.

After the first VSYNC pulse signal, the SYNCLOSTDIGITAL interrupt status bit must be cleared by writing 1 in the DSS.DISPC\_IRQSTATUS[15] SYNCLOSTDIGITAL bit; then the SYNCLOSTDIGITAL interrupt can be enabled by setting the DSS.DISPC\_IRQENABLE[15] SYNCLOSTDIGITAL bit.

### 7.3.2.2 DSI Interrupt Request

The DSI protocol engine requires a single interrupt line, DSI\_IRQ. The DSS.DSI\_IRQSTATUS register indicates the general interrupt events. See [Table 7-23](#). Each VC and complex I/O has a dedicated interrupt register: DSS.DSI\_VCn\_IRQSTATUS and DSS.DSI\_COMPLEXIO\_IRQSTATUS respectively. See [Table 7-24](#) and [Table 7-25](#).

[Table 7-23](#) indicates the DSI global interrupt events.

**Table 7-23. DSI Global Interrupts**

| Interrupt Name        | Description                                                                                                      |
|-----------------------|------------------------------------------------------------------------------------------------------------------|
| RESYNCHRONIZATION_IRQ | Resynchronization in video mode                                                                                  |
| TA_TO_IRQ             | Turn-around timer expired                                                                                        |
| LDO_POWER_GOOD_IRQ    | Signal LDOPWRGOOD from the DSI_PHY changes its state for the supply VDDALDODSIPLL from up to down or down to up. |
| SYNC_LOST_IRQ         | Synchronization with video mode port is lost (video mode only)                                                   |
| ACK_TRIGGER_IRQ       | Acknowledge trigger is received                                                                                  |
| TE_TRIGGER_IRQ        | Tearing effect trigger is received                                                                               |
| WAKEUP_IRQ            | Occurs when the SWakeUp signal is asserted                                                                       |
| HS_TX_TO_IRQ          | High speed TX Time-out Interrupt                                                                                 |
| LP_RX_TO_IRQ          | Low speed RX Time-out Interrupt                                                                                  |

**Table 7-23. DSI Global Interrupts (continued)**

| Interrupt Name       | Description                                                                                                                                                                                                 |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| COMPLEXIO_ERR_IRQ    | Error signaling from complex I/O: The interrupt is triggered when any error is received from the complex I/O (events are defined in <a href="#">DSI_COMPLEXIO_IRQSTATUS</a> ).                              |
| PLL_RECAL_IRQ        | PLL recal event (assertion of DSIRECAL signal from the DSI PLL Control module)                                                                                                                              |
| PLL_UNLOCK_IRQ       | PLL unlock event (deassertion of DSILock signal from the DSI PLL Control module)                                                                                                                            |
| PLL_LOCK_IRQ         | PLL lock event (assertion of DSILock signal from the DSI PLL Control module)                                                                                                                                |
| VIRTUAL_CHANNEL3_IRQ | Virtual channel #3<br>Error signaling from DSI Virtual Channel3: The interrupt is triggered when an error is received from DSI Virtual Channel3 (events are defined in <a href="#">DSI_VC3_IRQENABLE</a> ). |
| VIRTUAL_CHANNEL2_IRQ | Virtual channel #2<br>Error signaling from DSI Virtual Channel2: The interrupt is triggered when an error is received from DSI Virtual Channel2 (events are defined in <a href="#">DSI_VC2_IRQENABLE</a> ). |
| VIRTUAL_CHANNEL1_IRQ | Virtual channel #1<br>Error signaling from DSI Virtual Channel1: The interrupt is triggered when an error is received from DSI Virtual Channel1 (events are defined in <a href="#">DSI_VC1_IRQENABLE</a> ). |
| VIRTUAL_CHANNEL0_IRQ | Virtual channel #0<br>Error signaling from DSI Virtual Channel0: The interrupt is triggered when an error is received from DSI Virtual Channel0 (events are defined in <a href="#">DSI_VC0_IRQENABLE</a> ). |

[Table 7-24](#) indicates the DSI complex I/O interrupt events.

**Table 7-24. DSI Complex I/O Interrupts**

| Interrupt Name         | Description                                                                                  |
|------------------------|----------------------------------------------------------------------------------------------|
| ULPSActiveNot_ALL0_IRQ | All signals ULPSActiveNOT are 0                                                              |
| ULPSActiveNot_ALL1_IRQ | All the ULPSActiveNOT signals corresponding to the lanes with TXULPSExit being high are high |
| STATEULPS3_IRQ         | Lane #3 in ultralow-power state                                                              |
| STATEULPS2_IRQ         | Lane #2 in ultralow-power state                                                              |
| STATEULPS1_IRQ         | Lane #1 in ultralow-power state                                                              |
| ERRCONTROL3_IRQ        | Control error for lane #3                                                                    |
| ERRCONTROL2_IRQ        | Control error for lane #2                                                                    |
| ERRCONTROL1_IRQ        | Control error for lane #1                                                                    |
| ERRESC3_IRQ            | Escape entry error for lane #3(edge trigger interrupt)                                       |
| ERRESC2_IRQ            | Escape entry error for lane #2 (edge trigger interrupt)                                      |
| ERRESC1_IRQ            | Escape entry error for lane #1 (edge trigger interrupt)                                      |
| ERRCONTENTIONLP1_1_IRQ | Contention LP1 error for lane #1                                                             |
| ERRCONTENTIONLP0_1_IRQ | Contention LP0 error for lane #1                                                             |
| ERRCONTENTIONLP1_2_IRQ | Contention LP1 error for lane #2                                                             |
| ERRCONTENTIONLP0_2_IRQ | Contention LP0 error for lane #2                                                             |
| ERRCONTENTIONLP1_3_IRQ | Contention LP1 error for lane #3                                                             |
| ERRCONTENTIONLP0_3_IRQ | Contention LP0 error for lane #3                                                             |
| ERRSYNCESC3_IRQ        | Low power Data transmission synchronization error for lane #3                                |
| ERRSYNCESC2_IRQ        | Low power Data transmission synchronization error for lane #2                                |
| ERRSYNCESC1_IRQ        | Low power Data transmission synchronization error for lane #1                                |

**NOTE:** The error contention signals for DX and DY signals of each lane are ORed together.

**Table 7-25** indicates the DSI VCs interrupt events

**Table 7-25. DSI Virtual Channel Interrupts**

| Interrupt Name        | Description                                                                                                                                                                     |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ECC_CORRECTION_IRQ    | Indicates if a 1-bit error correction occurred using the ECC                                                                                                                    |
| PACKET_SENT_IRQ       | Indicates that a packet has been sent. It is used when BTA manual mode is used                                                                                                  |
| CS_IRQ                | Virtual channel - Check-Sum of the payload mismatch detection                                                                                                                   |
| FIFO_RX_OVF_IRQ       | RX FIFO overflow. The FIFO used on the L4 interconnect slave port for buffering the data received on the DSI link has overflowed                                                |
| FIFO_TX_OVF_IRQ       | TX FIFO overflow. The FIFO used on the L4 interconnect slave port for buffering the data received on the L4 interconnect slave port has overflowed                              |
| BTA_IRQ               | Bus turnaround is received from the peripheral (the VC ID used for the last BTA request transfer to the peripheral is used to determine which VC is used to flag the interrupt) |
| ECC_NO_CORRECTION_IRQ | ECC error (short and long packets). No correction of the header because of more than 1-bit error                                                                                |
| FIFO_TX_UDF_IRQ       | TX FIFO underflow. The FIFO used on the slave port for buffering the data received on the L4 interconnect port has under-flowed in the middle of a packet transfer              |

## 7.4 Display Subsystem Functional Description

This section describes the functions of the LCD and TV display supports by describing the following modules: display controller, DSI protocol engine, DSI PLL controller, DSI complex I/O, RFBI and video encoder.

The functions of the display controller are common to both LCD and TV data paths; the RFBI are LCD-specific; and the video encoder functions are specific to the TV set.

### 7.4.1 Block Diagram

[Figure 7-67](#) is a schematic of the display subsystem.

**Figure 7-67. Display Subsystem Full Schematic**



dss-037

### 7.4.2 Display Controller Functionalities

The display controller can read and display the encoded pixel data stored in memory (see [Figure 7-68](#)).

**Figure 7-68. Display Controller Architecture Overview**


dss-038

Several processes can be configured to manage the graphics pipeline (palette, gamma table correction) and video pipeline (color space conversion, upsampling, downsampling, overlay, and transparency features).

The internal timing generator logic generates the LCD input signals. The external timing generator generates the appropriated signals to drive the digital output. The data from the two overlay managers are sent on the two concurrent 24-bit buses outside the display controller module. The memory accessed by the display controller is either the SDRAM memory or the SRAM memory.

## 7.4.2.1 Display Modes

### 7.4.2.1.1 LCD Output

The display subsystem supports two types of display technologies (both monochrome and color modes):

- Passive matrix displays
- Active matrix displays

The passive matrix display mode supports 3375 possible colors, allowing 16, 256, or 3375 colors to be displayed in each frame, depending on the color depth. The monochrome LCD has 15 grayscale levels available.

In active matrix display mode, the configuration of colors depends on the color depth:

- 24 BPP supports 16,777,216 colors.
- 18 BPP supports 262,144 colors.
- 16 BPP supports 65,536 colors.
- 12 BPP supports 4096 colors.

### 7.4.2.1.2 Digital Output

The digital output is always a 24-bit RGB value based on an external pixel request.

## 7.4.2.2 Graphics Pipeline

The graphics pipeline is connected to the graphics FIFO controller for the input port and to the two overlay managers (LCD and digital). It consists of one 256-entry palette and some programmable replication logic. The replication logic is used to convert the RGB pixels, excluding the RGB24 format, into RGB24 format based on user programming (replication of the most-significant bits [MSBs] for the RGB24 LSBs or use of 0s). The first unit connected to the input port of the graphics pipeline is the replication logic used for RGB pixels, then the second unit is the palette for concerned pixels.

### 7.4.2.2.1 Graphics Memory Format

The supported formats for the graphics layer are CLUT bitmaps (1-, 2-, 4-, and 8-BPP) and true color bitmaps in RGB formats (12-, 16-, and 24-BPP [packet and nonpacket RGB24]) and in ARGB or RGBA formats (ARGB 16-, and 32-BPP, and RGBA 32-BPP) as follows:

- BITMAP 1-BPP data memory organization (CLUT) (little endian)



- BITMAP 1-BPP data memory organization (CLUT) (little endian + nibble mode)



- BITMAP 1-BPP data memory organization (CLUT) (big endian)



- BITMAP 1-BPP data memory organization (CLUT) (big endian + nibble mode)



- BITMAP 2-BPP data memory organization (CLUT) (little endian)



dss-T041

- BITMAP 2-BPP data memory organization (CLUT) (little endian + nibble mode)



dss-T042

- BITMAP 2-BPP data memory organization (CLUT) (big endian)



dss-T062

- BITMAP 2-BPP data memory organization (CLUT) (big endian + nibble mode)



dss-T063

- BITMAP 4-BPP data memory organization (CLUT) (little endian)



dss-T043

- BITMAP 4-BPP data memory organization (CLUT) (little endian + nibble mode)



dss-T044

- BITMAP 4-BPP data memory organization (CLUT) (big endian)



dss-T064

- BITMAP 4-BPP data memory organization (CLUT) (big endian + nibble mode)



dss-T065

- BITMAP 8-BPP data memory organization (CLUT) (little endian)



dss-T045

- BITMAP 8-BPP data memory organization (CLUT) (big endian)



dss-T066

- RGB 12-BPP data memory organization (little endian)



dss-T046

- RGB 12-BPP data memory organization (big endian)



dss-T067

- RGB 16-BPP data memory organization (little endian)

## Display Subsystem Functional Description

www.ti.com



- RGB 16-BPP data memory organization (big endian)



- ARGB 16-BPP data memory organization (little endian)



- ARGB 16-BPP data memory organization (big endian)



- RGB 24-BPP data memory organization (little or big endian)



- ARGB 32-BPP data memory organization (little or big endian)



- RGBA 32-BPP data memory organization (little or big endian)



- RGB 24-BPP packet data memory organization (little or big endian)



+0x0

+0x4

+0x8

dss-T053

**7.4.2.2.2 Color Look-Up Table/Gamma Table**

The graphics path supports the palette/gamma table. [Figure 7-69](#) shows the internal architecture of the color look-up/gamma table.

The palette is split into three memories of 256-bit x 8-bit entries. For bitmap (CLUT) indexes, the same value (1-, 2-, 4-, or 8-BPP) indexes the three memories. For gamma curve correction, each R, G, and B component indexes the corresponding memory to combine the three gamma curve values into a 24-bit value. The table can be reloaded every frame, once or never (at the beginning of the frame before fetching the pixels for the graphics and/or video windows).

**Figure 7-69. Palette/Gamma Correction Architecture**


#### 7.4.2.2.2.1 Color Look-Up Table

The palette mode uses the encoded pixel values from the input graphics FIFO as pointers to index the 24-bit-wide palette: 1-BPP pixels address 2 palette entries, 2-BPP pixels address 4 palette entries, 4-BPP pixels address 16 palette entries, and 8-BPP pixels address 256 palette entries.

When a palette entry is selected by the encoded pixel value, the content of the entry is sent to the color/grayscale space/time base passive matrix dithering circuit, or to the color time base active matrix dithering circuit.

In color mode, the value within the palette is made up of three 8-bit fields, one for each color component (red, green, and blue). For color operation, an individual frame is limited to a selection of 256 colors (the number of palette entries). The format of one of the palette values in the memory is as follows:

- 24-BPP Data Memory Organization (Little Endian or Nibble)

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Unused                  | R                       | G                     | B               |

In monochrome mode, only one 8-bit value is present.

- 24-BPP Data Memory Organization (Little Endian or Nibble)

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Unused                  | Unused                  | Unused                | Gray            |

After passing through the palette, 256 gray scales and 16,777,216 colors are numbers obtained. A redundancy introduced in the dithering logic step reduces these numbers when displaying. For passive matrix panels, the colors are limited to 15 gray scales and 3375 colors.

- Passive matrix technology  
The palette is bypassed in 12, 16, and 24 BPP. The palette is not used.
- Active matrix technology

The palette is bypassed in 12, 16, and 24 BPP, allowing up to  $2^{24} = 16,777,216$  colors to be displayed.

#### 7.4.2.2.2.2 Gamma Table

In the gamma curve mode, the selected encoded pixel values based on the color keys from the video or graphics paths are sent to the gamma curve table. The mode is available only if the color look-up palette is not used for graphics. The output of the gamma curve processing is always sent to the LCD output. It is not available on digital output.

Each component of encoded pixel value is used as a pointer to index 1 out of 256 24-bit gamma curve entries in the table. Each 8-bit component is replaced with the 8-bit table value corresponding to an R, G, or B component. The format of one of the gamma curve values in the memory is as follows:

- 24-BPP Data Memory Organization (Little or Big Endian)

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Unused                  | Gamma-R                 | Gamma-G               | Gamma-B         |

#### 7.4.2.2.2.2.1 Replication Logic

The replication logic increases the color depth of the graphics and video encoded pixels (from true color RGB 12-, and 16-BPP to 24-BPP). The encoded value is shifted to the 24-bit alignment. The MSB bits are copied to the LSB missing ones. Then the graphics are merged with the video data based on the transparency color keys. When the replication logic is not selected, the encoded pixel values are shifted to the MSB boundary of the 24-bit format. The missing bit values are filled up with 0s.

This is an example for RGB16 extension:

- Original 16-BPP data:

|                                                     |
|-----------------------------------------------------|
| 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0               |
| R4 R3 R2 R1 R0   G5 G4 G3 G2 G1 G0   B4 B3 B2 B1 B0 |

dss-T055

- If replication logic is ON:

|                                                                                   |                                       |
|-----------------------------------------------------------------------------------|---------------------------------------|
| 23 22 21 20 19 18 17 16                                                           | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
| R4 R3 R2 R1 R0 R4 R3 R2   G5 G4 G3 G2 G1 G0 G5 G4   B4 B3 B2 B1 B0 B4 B3 B2 B1 B0 |                                       |

dss-T056

- If replication logic is OFF:

|                                                                     |                                       |
|---------------------------------------------------------------------|---------------------------------------|
| 23 22 21 20 19 18 17 16                                             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
| R4 R3 R2 R1 R0 0 0 0   G5 G4 G3 G2 G1 G0 0 0   B4 B3 B2 B1 B0 0 0 0 |                                       |

dss-T057

#### 7.4.2.3 Video Pipeline

The video pipeline is connected to the video FIFO controller for the input port and to the two overlay managers (LCD and digital). It consists of the Re-Sampling unit, the Color Space Conversion Unit, and some programmable replication logic. The replication logic is used to convert the RGB pixels, excluding the RGB24 format, into RGB24 format based on user programming (replication of the MSBs for the RGB24 LSBs or use of 0s). The first unit connected to the input port of the video pipeline is the Re-Sampling Unit, then the replication logic used for RGB pixels, then the Color Space Conversion Unit for YUV4:2:2 pixels.

#### 7.4.2.3.1 Video Memory Formats

The display subsystem supports the following formats for the video layer: YUV2, UYVY, RGB12, RGB16, RGB24 (non-packed and packed formats), ARGB16 (video channel 2 only), ARGB32 (video channel 2 only), and RGBA32 (video channel 2 only).

- RGB 12-BPP data memory organization (little endian)



- RGB 12-BPP data memory organization (big endian)



- RGB 16-BPP data memory organization (little endian)



- RGB 16-BPP data memory organization (big endian)



- ARGB 16-BPP data memory organization (little endian + video 2 channel only)



- ARGB 16-BPP data memory organization (big endian + video 2 channel only)



- RGB 24-BPP data memory organization (little or big endian)



- RGB 24-BPP packet data memory organization (little or big endian)



- ARGB 32-BPP data memory organization (little or big endian + video 2 channel only)



- RGBA 32-BPP data memory organization (little or big endian + video 2 channel only)



- UYVY 4:2:2 data memory organization (little endian)



- UYVY 4:2:2 data memory organization (big endian)



- YUV2 4:2:2 data memory organization (little endian)



- YUV2 4:2:2 data memory organization (big endian)



#### 7.4.2.3.2 Color Space Conversion

The color space conversion module converts the video-encoded pixel values from YCbCr 4:2:2 format into RGB24. [Figure 7-70](#) and [Figure 7-71](#) detail the YCbCr 4:2:2 conversion to YCbCr 4:4:4 depending on the rotation parameters.

**Figure 7-70. YCbCr 4:2:2 to YCbCr 4:4:4 (0- or 180-Degree Rotation)**



**Figure 7-71. YCbCr 4:2:2 to YCbCr 4:4:4 (90- or 270-Degree Rotation)**



The interpolation of the missing chrominance component is given by the equation in [Figure 7-72](#).

**Figure 7-72. Interpolation of the Missing Chrominance Component**

$$C_{b,n}(\text{YCbCr 444}) = \frac{C_{b,n-1}(\text{YCbCr 422}) + C_{b,n+1}(\text{YCbCr 422})}{2} \quad (\text{n odd})$$

$$C_{r,n}(\text{YCbCr 444}) = \frac{C_{r,n-1}(\text{YCbCr 422}) + C_{r,n+1}(\text{YCbCr 422})}{2} \quad (\text{n odd})$$

dss-E062

First, to convert the YCbCr 4:2:2 encoded pixel values into YCbCr 4:4:4 format, the missing chrominance samples (Cb and Cr) are interpolated using the average values of the two closest values on the same line (1/2, 1/2) or are repeated from the second pixel in the same 32-bit container.

- In case of rotation 0-degree, for the last pixel, the chrominance samples are duplicated using the values from the previous pixel; otherwise, the chrominance samples are averaged using the two adjacent values.

- In case of 180-degree rotation, for the first pixel the chrominance samples missing are duplicated from the adjacent pixel; otherwise, the chrominance samples are averaged using the two adjacent values.
- In case of rotation 90- and 270-degree, the missing chrominance components are duplicated from the adjacent pixel in the same 32-bit container.

In case of 5-tap configuration for the vertical filtering, the missing chrominance samples are always duplicated using the second chrominance samples in the same 32-bit value.

Then the pixels are converted from YCbCr color space into the RGB color space, because the output format of the color space conversion is RGB24 (8-bit value per component: Red, green, and blue). The following matrices show the 11-bit coefficients registers used to convert from YCbCr 4:4:4 into RGB24. Users set the coefficients according to the standard used to encode the pixel data in YCbCr color space.

In case of resampling, the YUV4:2:2 format is converted into YUV4:4:4. The YUV4:2:2-to-YUV4:4:4 processing is bypassed in the color space conversion unit.

If the active range for the luminance samples (Y) is [16:235] and [16:240] for the chrominance samples (Cb and Cr), the values of R, G, and B output components are clipped to the range [0:255]. The equation shown in [Figure 7-73](#) gives the 11-bit coefficients of the YCbCr to RGB color space conversion.

**Figure 7-73. YCbCr to RGB Registers (VIDFULLRANGE = 0)**

$$\begin{bmatrix} R \\ G \\ B \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} RY & RCr & RCb \\ GY & GCr & GCb \\ BY & BCr & BCb \end{bmatrix} * \begin{bmatrix} Y - 16 \\ Cr - 128 \\ Cb - 128 \end{bmatrix}$$

dss-E063

If the active range for the luminance samples (Y) and chrominance samples (Cb and Cr) is [0:255], the values of R, G, and B output components are clipped to the range [0:255]. The equation shown in [Figure 7-74](#) gives the 11-bit coefficients of the YCbCr-to-RGB color space conversion.

**Figure 7-74. YCbCr to RGB Registers (VIDFULLRANGE = 1)**

$$\begin{bmatrix} R \\ G \\ B \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} RY & RCr & RCb \\ GY & GCr & GCb \\ BY & BCr & BCb \end{bmatrix} * \begin{bmatrix} Y \\ Cr - 128 \\ Cb - 128 \end{bmatrix}$$

dss-E064

[Figure 7-75](#) describes the computation for the calculation of the R component. The same computation applies for the G and B components:

**Figure 7-75. Color Space Conversion Macro-Architecture**

dss-065

#### 7.4.2.3.3 Hardware Cursor

The video layer can be used to display the hardware cursor. The encoded pixel data for the cursor image are in RGB12, RGB16 or RGB24 formats and the color space conversion block is bypassed. The transparency color key can be used when a non rectangle shape is used.

The alpha blending can be used to show a partial transparent cursor. When the alpha blender is enabled, the graphics layer is on top of the video layers. The cursor uses the graphics layer. The pixel alpha blending or the transparency color key can be used.

#### 7.4.2.3.4 Up-/Down-Sampling

The video layer has a dedicated resizing block to upsample and downsample the video-encoded pixels. The supported input formats from memory are RGB24, RGB16, and YUV4:2:2

(RGB12 and all the alpha formats like ARGB and RGBA are not supported)

Users must set the right size and position of the original video before resizing for the upsampled/downsampled video to be inside the display screen boundaries.

The filtering applies on each component independently R, G, and B).

For the horizontal up/downsampling, the equation is R component with five taps):

$$R_{out}(n) = \left( \sum_{i=-2}^{i=2} C_i(\Phi) \times R_{in}(n+i) \right) \gg 7 \quad (7)$$

dsse-066

For the vertical up/downsampling, the equation is R component with three taps):

$$Rout(n) = \left( \sum_{i=-1}^{i=1} C_i(\Phi) \times Rin(n+i) \right) \gg 7 \quad (8)$$

dss-E067

For the vertical up/downsampling, the equation is R component with five taps:

$$Rout(n) = \left( \sum_{i=-2}^{i=2} C_i(\Phi) \times Rin(n+i) \right) \gg 7 \quad (9)$$

dss-E068

*Rout*: R component output

*Ci*( $\Phi$ )  
dss-E069 : FIR filter coefficients

*Rin*: R component input

The pixel (n + 1) is older than pixel (n). The line (n + 1) is older than line (n).

---

**NOTE:** The coefficients Ci() depend on the phase between input and output pixels.

---

**NOTE:** If the 5-tap resizer is used for RGB16 and YUV4:2:2 picture formats, the width of the input picture must be a multiple of 2 pixels and more than 5 pixels:

[DISPC\\_VIDn\\_ATTRIBUTES\[21\]](#) VIDVERTICALTAPS == 1

[DISPC\\_VIDn\\_PICTURE\\_SIZE\[10:0\]](#) VIDORGSIZEX 4 and even

---

Figure 7-76 shows an example of video upsampling.

**Figure 7-76. Video Upsampling**



dss-070

### **Filter Description**

The up/downsampling filter is a poly-phase filter with five taps and eight phases for the horizontal filter and a programmable number of taps (three or five) and eight phases for vertical filter. The upsampling ratio is up to x8. The downsampling ratio using 3-tap configuration is 2. The downsampling ratio using 5-tap configuration is 4. The vertical filter is first applied to the encoded input pixel data; and then the horizontal filter is applied on the resulting pixel values to generate the output pixel values. [Figure 7-77](#) shows the computation for the R component in the case of three coefficients (vertical filtering). The same computation applies to the G and B components.

**Figure 7-77. Resampling Macro-Architecture (3-Coefficient Processing)**

dss-071

To determine if the minimum functional clock matches the down sampling ratio and the desired Pixel clock, the following formula must be used in conjunction with [Table 7-26](#) and [Table 7-27](#).

#### Ratio V when performing a vertical down-sampling only

$$h\_ratio = \frac{DISPC\_SIZE\_LCD.PPL}{DISPC\_VID\_SIZE.VidSizeX}$$

$$v\_ratio = \frac{DISPC\_VID\_PICTURE\_SIZE.VidOrgSizeY}{DISPC\_VID\_SIZE.VidSizeY}$$

$$Ratio = \frac{v\_ratio}{2 \times h\_ratio} \quad If \quad 1 < v\_ratio \leq 2$$

$$Ratio = \max\left(\frac{v\_ratio}{2 \times h\_ratio}, \frac{v\_ratio - 2}{2 \times (h\_ratio - 1)}\right) \quad If \quad 2 < v\_ratio \leq 4$$

dss\_swpu108-E135

**NOTE:** For frequency ratio calculation on the TV output, it is correct to replace [DISPC\\_SIZE\\_LCD](#) with [DISPC\\_SIZE\\_DIG](#).

When the down-sampling ratio is below 0.5, it is not possible to use a video in full screen.

#### Ratio H when performing a horizontal down-sampling only

$$Ratio = \frac{DISPC\_VID\_PICTURE\_SIZE.VidOrgSizeX}{DISPC\_VID\_SIZE.VidSizeX}$$

dss\_swpu108-E136

#### Ratio H+V when performing a horizontal and vertical down-sampling

Ratio = max (horizontal Ratio, vertical Ratio) as previously defined.

**Table 7-26. Functional Clock Frequency Requirement in RGB16 YUV4:2:2—Active Matrix Display**

| Minimum Functional Clock (MHz) |                  | Horizontal Resampling |            |            |            |            |
|--------------------------------|------------------|-----------------------|------------|------------|------------|------------|
|                                |                  | Off                   | Up         | 1:1 – 1:2  | 1:2 – 1:3  | 1:3 – 1:4  |
| Vertical Resampling            | Off              | AxPCLK                | AxPCLK     | 2xPCLK     | 3xPCLK     | 4xPCLK     |
|                                | Up               | AxPCLK                | AxPCLK     | 2xPCLK     | 3xPCLK     | 4xPCLK     |
|                                | 3-tap 1:1 to 1:2 | 2xPCLK                | 2xPCLK     | 4xPCLK     | 6xPCLK     | 8xPCLK     |
|                                | 5-tap 1:1 to 1:4 | RatioxPCLK            | RatioxPCLK | RatioxPCLK | RatioxPCLK | RatioxPCLK |

With A = 1 in case all the data and synchronization signals are asserted and deasserted on the rising edge of the PCLK; otherwise, A = 2.

**Table 7-27. Functional Clock Frequency Requirement in RGB24—Active Matrix Display**

| Minimum Functional Clock (MHz) |                  | Horizontal Resampling |            |              |              |              |
|--------------------------------|------------------|-----------------------|------------|--------------|--------------|--------------|
|                                |                  | Off                   | Up         | 1:1 – 1:2    | 1:2 – 1:3    | 1:3 – 1:4    |
| Vertical Resampling            | Off              | AxPCLK                | AxPCLK     | 2xPCLK       | 3xPCLK       | 4xPCLK       |
|                                | Up               | AxPCLK                | AxPCLK     | 2xPCLK       | 3xPCLK       | 4xPCLK       |
|                                | 3-tap 1:1 to 1:2 | 2xPCLK                | 2xPCLK     | 4xPCLK       | 6xPCLK       | 8xPCLK       |
|                                | 5-tap 1:1 to 1:4 | RatioxPCLK            | RatioxPCLK | 2xRatioxPCLK | 2xRatioxPCLK | 2xRatioxPCLK |

With A = 1 in case all the data and synchronization signals are asserted and deasserted on the rising edge of the PCLK; otherwise, A = 2.

**Use case example:**

An input picture of 1024\*768 is scaled to an output picture of size of 800\*600 and displayed onto a LCD of resolution 1280\*768 at a PCLK of 74.25 MHz with a DSS functional clock of 133 MHz.

In this example, a H+V down-sampling is done on the input picture. Firstly the Ratio V and H are determined and the resulting maximum value is taken to calculate the functional clock frequency required.

**Ratio V:** h\_ratio = 1.6 and v\_ratio = 1.28 then Ratio = 0.4

**Ratio H:** Ratio = 1.28

**Ratio H+V:** Ratio = max (1.28, 0.4) = 1.28

In this use case, the horizontal and vertical down sampling range are 1:1–1:2. The 3-tap or 5-tap configuration can be taken into consideration. Therefore, from [Table 7-26](#) and [Table 7-27](#), If in RGB16-YUV4:2:2:

- 3-taps → DSS functional clock = 4 \* PCLK = 297 MHz
- 5-taps → DSS functional clock = Ratio \* PCLK = 95.36 MHz

If in RGB24,

- 3-taps → DSS functional clock = 4 \* PCLK = 297 MHz
- 5-taps → DSS functional clock = 2 \* Ratio \* PCLK = 190.72 MHz

In this use case, the pixel format supported is RGB16-YUV4:2:2 in a 5-tap configuration.

#### 7.4.2.4 Overlay Support

**CAUTION**

Enabling overlay optimization (setting the DSS.DISPC\_CONTROL [12] OVERLAYOPTIMIZATION bit) if no overlay region effectively exists (the DSS.DISPC\_VIDn\_ATTRIBUTES [0] VIDENABLE bit is cleared, with n = 1, 2) leads to unpredictable behavior. The overlay optimization feature must be enabled only when an overlay area exists. Before enabling the overlay optimization, the DSS.DISPC\_GFX\_WINDOW\_SKIP[31:0] GFXWINDOWSKIP bit field must be first set according to the video1 and graphics windows overlap.

The overlay mechanism consists of displaying more than one layer (graphics and video layers) using rules based on priority and transparency color keys.

When the pixel format is ARGB or RGBA, the color key match logic uses only the RGB value defined by ARGB or RGBA. The alpha blending factor is ignored.

The overlay managers are based on the same rules for priority and transparency color keys (see [Figure 7-80](#)).

Each data pipeline is assigned a single overlay related to a single display controller output.

The overlay manager is connected to all three outputs of the pipelines (graphics, video1 and video2). The output of the LCD overlay manager is connected to the Spatial/Temporal Dithering, and Passive Matrix units and back to the palette unit in the case of Gamma correction.

##### 7.4.2.4.1 Priority Rule

The overlay manager can be configured in two distinct modes:

- Alpha mode (only source color key with the graphics layer)
- Normal mode (no alpha support)

The following rules apply in normal mode:

The video1 layer is always on top of the graphics layer. The video2 layer is always on top of the video1 and graphics. The display controller reads the data for each buffer from the system memory and, depending on the transparency color key values, displays either the pixels in the video layer, the pixels in the graphics layer, or the solid background color.

Each layer can have any size up to full-display screen. If there are no graphics or video-encoded pixels at a specific position, the programmable, solid background color appears (see [Figure 7-82](#)).

**Figure 7-78. Overlay Manager in Normal Mode**


dss-072

**Figure 7-79. Display Attributes in Normal Mode**


dss-073

The following rules apply in alpha mode:

The video2 layer is always on top of the video1 layer. The graphics layer is always on top of the video1 and video2. The display controller reads the data for each buffer from the system memory and, depending on the transparency color key values, displays either the pixels in the video layer, the pixels in the graphics layer, or the solid background color.

Each layer can have any size up to full-display screen. If there are no graphics or video-encoded pixels at a specific position, the programmable, solid background color appears (see Figure 7-82).

**Figure 7-80. Overlay Manager in Alpha Mode**



dss-163

**Figure 7-81. Display Attributes in Alpha Mode**


dss-164

Figure 7-82 shows the alpha blending processing in detail.

**Figure 7-82. Alpha Blending Macro Architecture with Pre-multiplied Alpha Support**

**NOTE:** "1-alpha" operator corresponds to the basic 1's complement operation.

The pre-multiplied alpha option is accessible through DSS.[DISPC\\_GFX\\_ATTRIBUTES\[28\]](#) PREMULTIPLYALPHA and DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[28\]](#) PREMULTIPLYALPHA registers bits. The following settings are available:

- PREMULTIPLYALPHA bit = '0' : Source is not pre-multiplied with alpha. Full blending is done in the DISPC.
- PREMULTIPLYALPHA bit = '1' : Source is pre-multiplied with alpha. Partial blending is done.

---

**NOTE:** The pre-multiplied alpha option is only valid when bit fields DSS.DISPC\_GFX\_ATTRIBUTES[4:1] GFXFORMAT and DSS.DISPC\_VIDn\_ATTRIBUTES[4:1] VIDFORMAT, respectively, are set to ARGB or RGBA formats. Otherwise, the PREMULTIPLYALPHA bit fields are ignored by the hardware.

---

The alpha blending value is defined by the pixel value (ARGB or RGBA formats). A global alpha blending value can be defined and used in combination with the pixel alpha blending value. If the pixel format contains no alpha blending value, the pixel alpha value is considered to be 0xFF.

In case of ARGB-444, the alpha blending is defined using a 4-bit value. It is converted into an 8-bit value by duplicating the 4-bit value. [Table 7-28](#) details the alpha blending 4-bit values and the corresponding blending percentage.

**Table 7-28. Alpha Blending 4-Bit Values**

| Alpha Blending 4-Bit Value (ARGB-444) | Alpha Blending 8-Bit Value<br>(Converted Value) | % Blending         |
|---------------------------------------|-------------------------------------------------|--------------------|
| 0x0                                   | 0x00                                            | 100% (transparent) |
| 0x1                                   | 0x11                                            | 93.33%             |
| 0x2                                   | 0x22                                            | 86.6%              |
| ...                                   | ...                                             | ...                |
| 0xE                                   | 0xEE                                            | 6.6%               |
| 0xF                                   | 0xFF                                            | 0% (opaque)        |

#### 7.4.2.4.2 Transparency Color Keys

##### 7.4.2.4.2.1 Normal Mode

This section describes the features available in normal mode.

The two transparency color keys are the video source transparency color key and the graphics destination transparency color key. The encoded pixel color value is compared to the transparency color key. For CLUT bitmaps, the palette index is compared to the transparency color key and not to the palette value pointed out by the palette index.

---

**NOTE:** The video source transparency color key and graphics destination transparency color key cannot be active at the same time.

---

- Video source transparency color key value:

The video source transparency color key value defines the encoded pixel data considered as the transparent pixel. The encoded pixel values with the source color key value are pixels not visible on the screen, and the underlayer encoded pixel values or solid background color are visible.

The video source transparency color key can be used only if the color space conversion and the up/down-scaling modules are disabled. The format of the data is RGB 16. (This feature handles the hardware cursor displayed by one of the video layers.)

To enable the video source transparency color key, set to 0x1 the DSS.DISPC\_CONFIG[11] TCKLCDSELECTION bit for LCD output or the DSS.DISPC\_CONFIG[13] TCKDIGSELECTION bit for digital output. Program the DSS.DISPC\_CONFIG[10] TCKLCDENABLE bit (LCD output) or the DSS.DISPC\_CONFIG[12] TCKDGENABLE bit (digital output) to enable or disable the transparency color key.

An example is shown in [Figure 7-83](#): The video source transparency is applied on video1 (VID1) and video2 (VID2) layers. The pixels with the transparency color key are not displayed; instead, underlying

layers are shown.

**Figure 7-83. Video Source Transparency Example**



dss-074

- Graphics destination transparency color key value:

The graphics destination transparency color key value defines the encoded pixels in the video layers to be displayed. The encoded pixel values with the destination color key value are pixels not visible on the screen and the pixels different from the transparency color key are displayed over the video layers. The destination transparency color key is applicable only in the graphics region when graphics and video overlap; otherwise, the destination transparency color key is ignored.

To enable the graphics destination transparency color key, set to 0x0 the DSS.[DISPC\\_CONFIG\[11\]](#) TCKLCDSELECTION bit for LCD output or the DSS.[DISPC\\_CONFIG\[13\]](#) TCKDIGSELECTION bit for digital output. Program the DSS.[DISPC\\_CONFIG\[10\]](#) TCKLCDENABLE bit (LCD output) or the DSS.[DISPC\\_CONFIG\[12\]](#) TCKDIGINABLE bit (digital output) to enable or disable the transparency color key.

An example is shown in [Figure 7-84](#): The destination transparency is applied on graphics (GFX) layer and the pixels without the transparency color key are displayed over the overlying layers.

**Figure 7-84. Graphics Destination Transparency Example**

dss-075

#### 7.4.2.4.2.2 Alpha Mode

This section describes the features available in alpha mode.

Only the graphics source transparency color key is available. The encoded graphics pixel color value is compared to the transparency color key. The encoded pixel values with the source transparency key are not visible and the under-layer encoded pixel values or solid background color are visible. To enable the graphics source transparency color key, set to 0x0 the DSS.[DISPC\\_CONFIG\[11\]](#) TCKLCDSELECTION bit for LCD output or the DSS.[DISPC\\_CONFIG\[13\]](#) TCKDIGSELECTION bit for digital output. Program the DSS.[DISPC\\_CONFIG\[10\]](#) TCKLCENABLE bit (LCD output) or the DSS.[DISPC\\_CONFIG\[12\]](#) TCKDGENABLE bit (digital output) to enable or disable the transparency color key. In the case of CLUT bit maps, the palette index is compared to the transparency color key and not the palette value pointed out by the palette index.

#### 7.4.2.4.3 Overlay Optimization (Only Available in Normal Mode)

The display controller can be configured to take advantage of the fact that the graphics pixels under video window 1 are not visible when the transparency color key is not used. The optimization can be selected to reduce the bandwidth used to fetch the pixels for graphics. The color key must be disabled. The graphics pixels under the video window 1 are not fetched from system memory. At least the video window 1 and the graphics window must be enabled. The following graphic formats are supported: RGB (RGB16 and RGB24 packed and unpacked), YUV4:2:2, and BITMAP 8. The formats BITMAP 1, 2, and 4 are not supported. The video format can be RGB (RGB16, RGB24 packed and unpacked, and YUV4:2:2 formats). The DMA engine does not fetch the unnecessary graphics pixels to avoid extra bandwidth use. Only visible pixels from graphics and video buffers in system memory are fetched and displayed by the display controller.

#### 7.4.2.5 Active/Passive Matrix Display Data Path

For active matrix display data path, the following blocks are serial and each of them can be bypassed:

- Color phase rotation
- Spatial/temporal dithering
- Multiple cycle data format

For passive matrix display data path, the following blocks are serial and each of them can be bypassed:

- Color phase rotation

- Spatial/temporal dithering
- Passive matrix technology

#### 7.4.2.5.1 Color Phase Rotation

The Color Phase Rotation (CPR) can be used to correct the LCD output colorimetry in case of non pure white backlight.

The color phase rotation can be selected for passive matrix and active matrix panel. The logic is integrated after the LCD overlay manager or the palette while using the gamma correction and before the spatial/temporal dithering. The color phase rotation can be selected to correct the nonpure white backlight of the LCD module by using a programmable matrix to convert the 24-bit RGB pixel value into a new 24-bit RGB pixel value. The matrix is programmed through a set of nine 10-bit signed coefficients. The output of the calculation is clipped to [0:255]. The color phase rotation is processed by the equation shown in [Figure 7-85](#).

**Figure 7-85. Color Phase Rotation Matrix**

$$\begin{bmatrix} Rout \\ Gout \\ Bout \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} RR & RG & RB \\ GR & GG & GB \\ BR & BG & BB \end{bmatrix} * \begin{bmatrix} Rin \\ Gin \\ Bin \end{bmatrix}$$

dss-E076

[Figure 7-86](#) shows the color phase rotation macro-architecture.

**Figure 7-86. Color Phase Rotation Macro Architecture**



#### 7.4.2.5.1.1 Spatial/Temporal Dithering

The spatial/temporal dithering logic can be selected for passive matrix and active matrix panel. The dithering logic is integrated after the color phase rotation and before the TDM and passive matrix units. The spatial/temporal dithering logic can be selected to enhance the quality of the passive matrix and active matrix outputs. The dithering logic can process the pixels over a single frame, two frames, or four frames. In the case of a single frame, only spatial processing is applied. In the case of multiple frames, spatial and temporal processing is applied to the pixels.

- Passive Matrix Technology: The passive matrix display dithering logic path is used. The spatial/temporal dithering logic can be selected. When selected, the pixels are preprocessed by the spatial/temporal dithering logic before the passive matrix display dithering logic. The output format of the spatial/temporal dithering logic is RGB 12-bit (not configurable).

- Active Matrix Technology: The encoded pixel values are used by spatial/temporal dithering logic to display the data in a lower color depth on the LCD panel. The spatial/temporal dithering algorithm is based on the (x,y) pixel position, the value of removed bits and the frame number. The picture quality is improved when enabling the spatial/temporal dithering logic. When spatial/temporal dithering is not enabled, the three MSBs of the pixel color components are output on the interface data bus if the interface data bus is smaller than the pixel format size. If the interface data bus is wider than the pixel format size, by programming the pixel components replication active/inactive, the MSB is replicated to the LSB of the interface data bus or the LSB is filled with 0s.

#### 7.4.2.5.2 Passive Matrix Display Dithering Logic

- Passive matrix technology

After the graphics data are merged with the video data from the video layers depending on the transparency status, the result is sent to the color/grayscale space-/time-based dither generator. The monochrome data and each RGB color component are encoded on 4 bits, which are the 4 MSBs of the pixel-encoded component 8-bit value defined by the merge of the graphics data and the video data.

These 4-bit values are used to select on the 16 intensity levels. The gray/color intensity is controlled by turning individual pixels on and off at varying period rates, making the average time the pixel is off longer than the average time the pixel is on, thus producing more intense grays/colors. The dithering generator also uses the intensity of adjacent pixels in the calculation to give the screen image a smooth appearance. The proprietary dither algorithm is optimized to provide a range of intensity values that matches the visual perception of color/gray graduations.

- Active matrix technology

The passive matrix dithering logic is always bypassed in active displays.

---

**NOTE:** If the interface data bus is smaller than the pixel format size, dithering logic can be enabled. If the interface data bus is wider than the pixel format size, the dithering logic cannot be enabled and replication feature can be used.

---

#### 7.4.2.5.3 Passive Matrix Display Output FIFO

- Passive matrix technology

The display controller contains a 2-entry by 8-bit-wide output FIFO used to store pixel data before it is driven out to the LCD pins. Each time a modulated pixel value is output from the dither generator, it is placed into a serial shifter. The shifter can be configured to be 4 or 8 bits wide. Single-panel monochrome screens use either four or eight data lines; single-panel color screens use eight data pins.

- Active matrix technology

The output FIFO is bypassed in active matrix mode.

#### 7.4.2.5.4 Multiple Cycle Output Format

The pixels after the active matrix display processing are formatted on one or multiple cycles (from one to three cycles). The interface width can be 8-, 9-, 12-, or 16-bit. On three cycles, two pixels can concatenate and send to the panel. When the TDM is disabled, the display controller outputs the pixels using the conventional formats: Passive matrix display/active matrix display monochrome/color.

The following example shows an output configuration based on the interface width (8-bit) and the pixel format output (24-bit) (also see [Table 7-29](#)):

- The DSS.[DISPC\\_CONTROL](#)[24:23] TDMCYCLEFORMAT bit field is set to 0x2 (three cycles for one pixel).
- The DSS.[DISPC\\_DATA\\_CYCLEk](#) (k=0) register is set to 0x00000008 (8 bits from pixel 1 for the first cycle).
- The DSS.[DISPC\\_DATA\\_CYCLEk](#) (k=1) register is set to 0x00000008 (8 bits from pixel 1 for the second cycle).
- The DSS.[DISPC\\_DATA\\_CYCLEk](#) (k=2) register is set to 0x00000008 (8 bits from pixel 1 for the third cycle).

cycle).

**Table 7-29. 8-Bit Interface Configuration/24-Bit Mode**

|         | 24-Bit Mode |           |           |
|---------|-------------|-----------|-----------|
|         | 1st Cycle   | 2nd Cycle | 3rd Cycle |
| Data[7] | R0[7]       | G0[7]     | B0[7]     |
| Data[6] | R0[6]       | G0[6]     | B0[6]     |
| Data[5] | R0[5]       | G0[5]     | B0[5]     |
| Data[4] | R0[4]       | G0[4]     | B0[4]     |
| Data[3] | R0[3]       | G0[3]     | B0[3]     |
| Data[2] | R0[2]       | G0[2]     | B0[2]     |
| Data[1] | R0[1]       | G0[1]     | B0[1]     |
| Data[0] | R0[0]       | G0[0]     | B0[0]     |

#### 7.4.2.6 Video Line Buffer

The line buffer size is 1024 x 24-bit. There are six line buffers (1024 x 24-bit) that can be merged into three lines (2048 x 24-bit). [Table 7-30](#) lists the maximum width depending on the TAP configuration and the pixel format.

**Table 7-30. Maximum Width Allowed**

| Vertical Tap | Pixel Format | Maximum Width (Pixels) |
|--------------|--------------|------------------------|
| 3            | RGB16        | 2048                   |
|              | RGB24        |                        |
|              | YUV4:2:2     |                        |
| 5            | RGB16        | 1024                   |
|              | RGB24        |                        |
|              | YUV4:2:2     |                        |

#### 7.4.2.7 Synchronized Buffer Update

A synchronization mismatch between the frame buffer and the display refreshes, named tearing effect, can lead to images that appear to be stretched on the screen. To avoid this, a synchronization mechanism is needed between the display controller and the process that updates the buffer. An interrupt is generated when the display reaches a predefined line number. This PROGRAMMEDLINENUMBER interrupt is a level signal and stays active during the programmed line of the display.

#### 7.4.2.8 Rotation

In case of SDRAM buffer, the display controller accesses the encoded pixels in burst, always considering the consecutive data in memory. The rotation engine (VRFB) in the SDRAM scheduler (SDRC) is in charge of translating the addresses from virtual to physical SDRAM addresses (see [Chapter 10, Memory Subsystem](#)).

Rotation using the SMS-VRFB rotation engine is supported for BITMAP8, RGB12 (16-bit container), ARGB16, RGB16, RGB24 (using 32-bit container), ARGB32, RGBA32, and YUV4:2:2 (YUV2 and YUYV). The BITMAP1, BITMAP2, BITMAP4, and RGB24 (using 24-bit container) formats are not supported.

---

**NOTE:** For good performance in the L3 interconnect and for SDRAM efficiency, it is highly recommended to use the VRFB rotation engine when possible and not the display subsystem DMA engine to rotate the frame buffer.

---

A VID DMA optimization is available to optimize the memory traffic (DDR memory) when 90- and 270-degree rotation is required. This optimization consists of reconstructing the RGB16 and YUV line pixels using the cache capability of the DISPC scaler line buffers.

The pixel formats that can take advantage of the reduction in memory traffic are:

- YUV4:2:2
- RGB16 (no reduction is possible for RGB24 packed and unpacked formats)

The benefits of the video DMA optimization, when the feature is enabled, are:

- The L3 interconnect traffic is reduced by a factor of 2x (only for YUV4:2:2 pixel format)
- The DDR memory traffic is reduced by a factor of 2x (for YUV4:2:2 and RGB16 pixel formats)

For more information about the configuration settings for video DMA optimization, see [Section 7.5.3.4.5, Video DMA Optimization](#).

---

**NOTE:** The DMA optimization feature must be used only for YUV and RGB16 formats when 90- or 270-degree rotation is required. In all other configurations, the [DISPC\\_VIDn\\_ATTRIBUTES\[20\]](#) VIDDMAOPTIMIZATION bit must be kept at reset value (0x0).

---

#### 7.4.2.9 Multiple Buffer Support

Users update the base address of the buffer when the update of the working buffer has finished and is ready to be displayed. The register that contains the base address of the buffer is a shadow register that is read by the hardware at the next Vertical Front Porch (VFP).

#### 7.4.3 DS1 Protocol Engine Functionalities

---

**NOTE:** Copyright ©2005-2008 MIPI Alliance, Inc. All rights reserved. MIPI Alliance Member Confidential.

---

The DS1 protocol engine integrates DS1 interface to the display through the DS1 DS1\_PHY module, L4 interconnect interface and video interface from the display controller. The DS1 DS1\_PHY or complex I/O module is detailed in [Section 7.4.5](#). The DS1 transmitter (protocol engine + PHY) port can be connected to multiple displays using a single DS1 host port. The DS1 protocol engine controls the DS1 PLL control module detailed in [Section 7.4.4](#). The DS1 transmitter port can be used in video mode or/and command mode.

##### 7.4.3.1 DS1 Protocol Architecture

The DS1 protocol engine receives data from the video port and/or the L4 interconnect slave port, encapsulates them with the VC ID, generates the ECC and check-sum, and splits the data into byte stream to the DS1\_PHY to be sent using the low-speed (LS) or high-speed (HS) protocol. The DS1 protocol engine receives data and acknowledge from the display using the same DS1 link in case of bidirectional display. Multiple data streams can be interleaved to support multiple panels connected to the same host DS1 port. [Figure 7-87](#) details the DS1 protocol engine architecture.

Figure 7-87. DSI Protocol Engine



dss-166

**NOTE:** The order of the PHY pairs (clock and data lanes) is informative. Each PHY pair can be Clock or Data. The DSI complex I/O receives the configuration for pin order and the differential +/- in a pair from the settings in DSS.[DSI\\_COMPLEXIO\\_CFG1](#) register.

The DSI serial interface is a bidirectional differential serial interface with data/clock for the physical layer (configured in unidirectional link in case the display module is only unidirectional). The maximum DSI data transfer capacity is 900 Mbps per channel. The speed of the link can be software configured only when the DSI\_PHY is in stop state or in ULPS.

Figure 7-88 shows the DSI transmitter/receiver high-level data flow.

**Figure 7-88. DSI Transmitter/Receiver Data Flow**


dss-167

#### 7.4.3.2 Clock Requirements

The serial clock generated by the DSI host and sent to the display can be a continuous clock. The clock lane supports clock transmission even there is no data to send for displays that require continuous clock. It is software programmed through the DSS.[DSI\\_CLK\\_CTRL\[13\]](#) DDR\_CLK\_ALWAYS\_ON bit: This bit can be programmed only when the interface is disabled (that is, DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit set to 0).

The peripheral can use two different kinds of clocks. The first one is the DDR clock provided on the clock lane. The second clock is some transitions on the data lane 1 even if there is no valid data to send using low power mode.

The LP clock (TxClkEsc) frequency provided to the DSI complex I/O is in the range of 67% to 150% of the peripheral Low-Power (LP) clock frequency. It is generated internally by the DSI protocol engine module using the DSI functional clock. The DSI functional clock is divided by 1, 2, 3, up to 8191 using the value programmed in the DSS.[DSI\\_CLK\\_CTRL\[12:0\]](#) LP\_CLK\_DIVISOR bit field. The LP clock generated from DSI functional clock must be in the range of 20 MHz down to 32 KHz. The duty cycle must be 50/50 (tolerance of 45/55 for maximum value). LP clock frequency visible on the pads (DP xor DN) is half the frequency of TxClkEsc.

The DSS.[DSI\\_CLK\\_CTRL\[20\]](#) LP\_CLK\_ENABLE bit is used to enable or disable the clock. When disabled, the value of DSS.[DSI\\_CLK\\_CTRL\[12:0\]](#) LP\_CLK\_DIVISOR bit field is ignored and does not have to be programmed by software users.

#### 7.4.3.2.1 Timing Parameters for an LP to HS Transaction

Figure 7-89 shows the timing requirement when switching the data and clock lane state from LP to HS. Table 7-31 lists the LP to HS timing parameters.

**Figure 7-89. LP to HS Timing**



dss-325

**Table 7-31. LP to HS Timing Parameters**

| Timing                   | Description                                                                     | Registers/Associated Bit Fields                                                                                | Register Settings                | Timing Seen on the Line                                                                                                     |
|--------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| T <sub>LPX</sub>         | Length of any low-power state period                                            | DSI_PHY_REGISTER1[20:16]<br>REG_TLPXBY2<br><br>The value set in this bit field is half of the T <sub>LPX</sub> | CEIL (25 ns / DDR_Clock_Period)  | CEIL (2 * REG_TLPXBY2/4) * 4 * DDR_Clock_Period                                                                             |
| T <sub>CLK-PREPARE</sub> | Time to drive the CLK lane to LP-00 state, to prepare for HS clock transmission | DSI_PHY_REGISTER2[7:0]<br>REG_TCLKPREPARE                                                                      | CEIL (65 ns / DDR_Clock_Period)  | REG_TCLKPREPARE * DDR_Clock_Period + (~25 ns - +5 ns)                                                                       |
| T <sub>CLK-ZERO</sub>    | Time to drive the CLK lane to HS-0 state, before starting the clock             | DSI_PHY_REGISTER1[7:0]<br>REG_TCLKZERO                                                                         | CEIL (265 ns / DDR_Clock_Period) | {CEIL [(REG_TCLKZERO + 3)/4] * 4 + CEIL (REG_TCLKPREPARE/4) * 4 - REG_TCLKPREPARE + 2} * DDR_Clock_Period + (~0 ns - +5 ns) |

**Table 7-31. LP to HS Timing Parameters (continued)**

| Timing                         | Description                                                                                                    | Registers/Associated Bit Fields                                                 | Register Settings                                                                            | Timing Seen on the Line                                                                                                                                                                                          |
|--------------------------------|----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $T_{CLK-PRE}$                  | Time that the HS clock must be driven before any associated data lane begins the transition from LP to HS mode | N/A                                                                             | N/A                                                                                          | $DDR\_CLK\_PRE - T_{LPX} - T_{CLK-PREPARE} - T_{CLK-ZERO}$                                                                                                                                                       |
| $T_{HS-PREPARE}$               | Time to drive the data lane to LP-00 state, to prepare for HS packet transmission                              | <a href="#">DSI_PHY_REGISTER0[31:24]</a><br><a href="#">REG_THSPREPARE</a>      | CEIL (70 ns / DDR_Clock_Period) + 2                                                          | $REG\_THSPREPARE * DDR\_Clock\_Period + (-26.5 \text{ ns} - +4 \text{ ns})$                                                                                                                                      |
| $T_{HS-ZERO} + T_{HS-PREPARE}$ | $T_{HS-ZERO}$ : Time to drive the data lane to HS-0 state before the synchronous sequence                      | <a href="#">DSI_PHY_REGISTER0[23:16]</a><br><a href="#">REG_THSPRPR_THSZERO</a> | CEIL (175 ns / DDR_Clock_Period) + 2                                                         | {CEIL [(N + 3)/4] * 4 + CEIL (M/4) * 4 + 3} * DDR_Clock_Period + (~ 29 ns - 0 ns).<br>Where<br>N = <a href="#">REG_THSPREPARE_THSZERO</a> - <a href="#">REG_THSPREPARE</a><br>M = <a href="#">REG_THSPREPARE</a> |
| $T_{DDR\_CLK\_PRE}$            | Time between the CLK lane request assertion and the data request assertion to switch the data lanes to HS      | <a href="#">DSI_CLK_TIMING[15:8]</a><br><a href="#">DDR_CLK_PRE</a>             | CEIL $[(T_{LPX} + T_{CLK-PREPARE} + T_{CLK-ZERO} + T_{CLK-PRE}) / T_{TXBYTECLKHS}]^{(1)(2)}$ |                                                                                                                                                                                                                  |
| $T_{ENTER\_HS\_MODE\_LATENCY}$ | <sup>(3)</sup> Time to enter data lane into HS mode                                                            | <a href="#">DSI_VM_TIMING7[31:16]</a><br><a href="#">ENTER_HS_MODE_LATENCY</a>  | CEIL $[(T_{LPX} + T_{HS-PREPARE} + T_{HS-ZERO}) / T_{TXBYTECLKHS}]^{(1)}$                    |                                                                                                                                                                                                                  |

(1) The timings seen on the line should be used to determine the register value.

(2) See the MIPI D-PHY specification for the  $T_{CLK-PRE}$  value.

(3)  $ENTER\_HS\_MODE\_LATENCY$  timing applies only to video mode. It does not need to be programmed in command mode.

In the example in [Table 7-32](#), the DDR clock = 400 MHz; TxByteClkHS = 100 MHz.

**Table 7-32. LP to HS Timing Parameters Example for 400-MHz DDR Clock**

| Timing                         | Registers/Associated Bit Fields                                                 | Default Register Settings (Programmed at Reset)                                                            | Timing Seen on the Line |
|--------------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-------------------------|
| $T_{LPX}$                      | <a href="#">DSI_PHY_REGISTER1[20:16]</a><br><a href="#">REG_TLPXBY2</a>         | 10                                                                                                         | 50 ns                   |
| $T_{CLK-PREPARE}$              | <a href="#">DSI_PHY_REGISTER2[7:0]</a><br><a href="#">REG_TCLKPREPARE</a>       | 26                                                                                                         | 40–70 ns                |
| $T_{CLK-ZERO}$                 | <a href="#">DSI_PHY_REGISTER1[7:0]</a><br><a href="#">REG_TCLKZERO</a>          | 106                                                                                                        | 280–285 ns              |
| $T_{CLK-PRE}^{(1)}$            | N/A                                                                             | N/A                                                                                                        | 80 ns                   |
| $T_{HS-PREPARE}$               | <a href="#">DSI_PHY_REGISTER0[31:24]</a><br><a href="#">REG_THSPREPARE</a>      | 30                                                                                                         | 48.5–79 ns              |
| $T_{HS-ZERO}$                  | <a href="#">DSI_PHY_REGISTER0[23:16]</a><br><a href="#">REG_THSPRPR_THSZERO</a> | 72                                                                                                         | 178.5–207.5 ns          |
| $T_{DDR\_CLK\_PRE}$            | <a href="#">DSI_CLK_TIMING[15:8]</a><br><a href="#">DDR_CLK_PRE</a>             | 45–49 <sup>(2)</sup>                                                                                       | 450–490 ns              |
| $T_{ENTER\_HS\_MODE\_LATENCY}$ | <a href="#">DSI_VM_TIMING7[31:16]</a><br><a href="#">ENTER_HS_MODE_LATENCY</a>  | 24 * $T_{TXBYTECLKHS}$ or 96 * $DDR\_CLOCK$<br>34 * $T_{TXBYTECLKHS}$ or 136 * $DDR\_CLOCK$ <sup>(2)</sup> | 277–336.5 ns            |

(1) See the MIPI D-PHY specification for the  $T_{CLK-PRE}$  value.

(2) The register setting is calculated based on the values in the Timing Seen on the Line column.

#### 7.4.3.2.2 Timing Parameters for an HS to LP Transaction

Figure 7-90 shows the timing requirement when switching the state of the data and clock lanes from HS to LP. Table 7-33 lists the HS to LP timing parameters.

**Figure 7-90. HS to LP Timing**



**Table 7-33. HS to LP Timing Parameters**

| Timing                           | Description                                                                                                                                                                                                                         | Registers/Associated Bit Fields                             | Register Settings                                                                           | Timing Seen on the Line                                                                                          |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| $T_{HS-EOT}$                     | If EoT is enabled, a delay is added to EXIT_HS_MODE_LATENCY to send the EoT packet. The EoT period depends on the number of data lanes.                                                                                             | N/A                                                         | N/A                                                                                         | DIVROUNDUP (4, NB_DATA_LANES)<br><br>Thus:<br>One data lane = Four DDR clocks<br>Two data lanes = Two DDR clocks |
| $T_{HS-TRAIL}$                   | Time to drive flipped differential state after last payload data bit of an HS transmission burst                                                                                                                                    | <a href="#">DSI_PHY_REGISTER0[15:8]</a><br>REG_THSTRAIL     | CEIL (60 ns / DDR_Clock_Period) + 5                                                         | {CEIL [(REG_THSTRAIL + 3)/4] * 4 - 2.75} * DDR_Clock_Period + (~ 0 ns - 5 ns)                                    |
| $T_{HS-EXIT}$                    | Time to drive data lane to LP-11 state, after HS burst                                                                                                                                                                              | <a href="#">DSI_PHY_REGISTER0[7:0]</a><br>REG_THSEXIT       | CEIL (145 ns / DDR_Clock_Period)                                                            | [CEIL (REG_THSEXIT/4 * 4) * DDR_Clock_Period - (~ 3 ns - 45 ns)]                                                 |
| $T_{CLK-POST}$                   | Time that the transmitter must continue sending HS clock after the last associated data lane has transitioned to LP mode                                                                                                            | N/A                                                         | N/A                                                                                         | DDR_CLK_POST - $T_{HS-EOT}^{(1)} - T_{HS-TRAIL}$                                                                 |
| $T_{CLK-TRAIL}$                  | Time to drive HS differential state after last payload clock bit of a HS transmission burst                                                                                                                                         | <a href="#">DSI_PHY_REGISTER1[15:8]</a><br>REG_TCLKTRAIL    | CEIL (60 ns / DDR_Clock_Period) + 2                                                         | {CEIL [(REG_TCLKTRAIL + 3)/4] * 4 - 1.5} * DDR_Clock_Period + (~ 0 ns - 5 ns)                                    |
| $T_{DDR_CLK_POST}$               | Time between the data lane request deassertion and the CLK request deassertion to switch the data lanes into LP mode. The DDR_CLK_POST value must follow the rule: $T_{DDR_CLK_POST} \geq T_{HS-TRAIL} + T_{HS-EOT} + T_{CLK-POST}$ | <a href="#">DSI_CLK_TIMING[7:0]</a><br>DDR_CLK_POST         | CEIL [( $T_{HS-TRAIL} + T_{HS-EOT}^{(1)}$ + $T_{CLK-POST}$ ) / $T_{TXBYTECLKHS}^{(2)(3)}$ ] |                                                                                                                  |
| $T_{EXIT_HS_MODE_LATENCY}^{(4)}$ | Time to exit HS mode                                                                                                                                                                                                                | <a href="#">DSI_VMTIMING7[15:0]</a><br>EXIT_HS_MODE_LATENCY | CEIL [( $T_{HS-TRAIL} + T_{HS-EXIT} + T_{HS-EOT}^{(1)}$ ) / $T_{TXBYTECLKHS}^{(2)}$ ]       |                                                                                                                  |

(1) If  $T_{HS-EOT}$  is enabled

(2) The timings seen on the line should be used to determine the register value.

(3) See the MIPI D-PHY specification for the  $T_{CLK-POST}$  value.

(4) EXIT\_HS\_MODE\_LATENCY timing applies only to video mode. It does not need to be programmed in command mode.

In the example in [Table 7-34](#), the DDR clock = 400 MHz; TxByteClkHS = 100 MHz; two data lanes.

**Table 7-34. HS to LP Timing Parameters Example for 400-MHz DDR Clock and Two Data Lanes**

| Timing       | Registers/Associated Bit Fields | Default Register Settings (Programmed at Reset) | Timing Seen on the Line ( $T_{HS-EOT}$ Enabled) | Timing Seen on the Line ( $T_{HS-EOT}$ Disabled) |
|--------------|---------------------------------|-------------------------------------------------|-------------------------------------------------|--------------------------------------------------|
| $T_{HS-EOT}$ | N/A                             | N/A                                             | 5 ns                                            | N/A                                              |

**Table 7-34. HS to LP Timing Parameters Example for 400-MHz DDR Clock and Two Data Lanes (continued)**

| Timing                        | Registers/Associated Bit Fields              | Default Register Settings (Programmed at Reset)                                          | Timing Seen on the Line ( $T_{HS-EOT}$ Enabled) | Timing Seen on the Line ( $T_{HS-EOT}$ Disabled) |
|-------------------------------|----------------------------------------------|------------------------------------------------------------------------------------------|-------------------------------------------------|--------------------------------------------------|
| $T_{HS-TRAIL}$                | DSI_PHY_REGISTER0[15:8]<br>REG_THSTRAIL      | 29                                                                                       | 73.125–78.125 ns                                | 73.125–78.125 ns                                 |
| $T_{HS-EXIT}$                 | DSI_PHY_REGISTER0[7:0]<br>REG_THSEXIT        | 58                                                                                       | 105–147 ns                                      | 105–147 ns                                       |
| $T_{CLK-POST}$ <sup>(1)</sup> | N/A                                          | N/A                                                                                      | 585 ns                                          | 580 ns                                           |
| $T_{CLK-TRAIL}$               | DSI_PHY_REGISTER1[15:8]<br>REG_TCLKTRAIL     | 26                                                                                       | 76.25–81.25 ns                                  | 76.25–81.25 ns                                   |
| DDR_CLK_POST                  | DSI_CLK_TIMING[7:0]<br>DDR_CLK_POST          | 66 * TxByteClkHS or 264 * DDR_CLOCK – 67 * TxByteClkHS or 268 * DDR_CLOCK <sup>(2)</sup> | 658.125–663.125 ns                              | 653.125–658.125 ns                               |
| EXIT_HS_MODE_LATENCY          | DSI_VM_TIMING7[15:0]<br>EXIT_HS_MODE_LATENCY | 19 * TxByteClkHS or 76 * DDR_CLOCK – 24 * TxByteClkHS or 96 * DDR_CLOCK <sup>(2)</sup>   | 183.125–230.125 ns                              | 178.125–225.125 ns                               |

<sup>(1)</sup> See the MIPI D-PHY specification.

<sup>(2)</sup> The register setting is calculated based on the values in the Timing Seen on the Line ( $T_{HS-EOT}$  Enabled) column.

#### 7.4.3.2.3 Extra LP Transitions

Some DSI receivers require extra clock cycles in LP mode to process the data. The DSI protocol engine can be programmed to send automatically one NULL long packet. It applies only when no more data are ready to be sent from the internal FIFO to the peripheral on the last low speed transfer. The same value is used for all the VCs sending packets in low speed mode.

The size of the payload is defined by the DSS.DSI\_CLK\_CTRL[17:16] LP\_CLK\_NULL\_PACKET\_SIZE bit field. The header value depends on the VC ID and the size of the payload as detailed in [Table 7-35](#) and [Table 7-36](#).

**Table 7-35. Extra NULL Packet Header**

| Virtual Channel ID | Payload size (DSI_CLK_CTRL[17:16] LP_CLK_NULL_PACKET_SIZE) | Header (1st Byte) | Header (2nd Byte): WC LSB | Header (3rd Byte): WC MSB | Header (ECC) |
|--------------------|------------------------------------------------------------|-------------------|---------------------------|---------------------------|--------------|
| 0x0                | 0                                                          | 0x9               | 0x0                       | 0x0                       | 0x9          |
|                    | 1                                                          |                   | 0x1                       |                           | 0x13         |
|                    | 2                                                          |                   | 0x2                       |                           | 0x2F         |
|                    | 3                                                          |                   | 0x3                       |                           | 0x35         |
| 0x1                | 0                                                          | 0x49              | 0x0                       | 0x0                       | 0x1F         |
|                    | 1                                                          |                   | 0x1                       |                           | 0x05         |
|                    | 2                                                          |                   | 0x2                       |                           | 0x39         |
|                    | 3                                                          |                   | 0x3                       |                           | 0x23         |
| 0x2                | 0                                                          | 0x89              | 0x0                       | 0x0                       | 0x10         |
|                    | 1                                                          |                   | 0x1                       |                           | 0x0A         |
|                    | 2                                                          |                   | 0x2                       |                           | 0x36         |
|                    | 3                                                          |                   | 0x3                       |                           | 0x2C         |
| 0x3                | 0                                                          | 0xC9              | 0x0                       | 0x0                       | 0x06         |
|                    | 1                                                          |                   | 0x1                       |                           | 0x1C         |
|                    | 2                                                          |                   | 0x2                       |                           | 0x20         |
|                    | 3                                                          |                   | 0x3                       |                           | 0x3A         |

**Table 7-36. Extra NULL Packet Payload**

| Payload size<br>(DSI_CLK_CTRL[17:16]<br>LP_CLK_NULL_PACKET_SIZE) | Payload (1st byte) | Payload (2nd byte) | Payload (3rd byte) | Payload (CRC) LSB | Payload (CRC) MSB |
|------------------------------------------------------------------|--------------------|--------------------|--------------------|-------------------|-------------------|
| 0                                                                | NA                 | NA                 | NA                 | 0xFF              | 0xFF              |
| 1                                                                | 0                  | NA                 | NA                 | 0x87              | 0x0F              |
| 2                                                                | 0                  | 0                  | NA                 | 0xB8              | 0xF0              |
| 3                                                                | 0                  | 0                  | 0                  | 0x33              | 0x39              |

**NOTE:**

- In [Table 7-35](#) and [Table 7-36](#), both ECC and checksum are enabled.
- NA means not available.

**7.4.3.3 DSI Transfer Modes**

There are two transfer modes supported by the DSI module:

- Video mode (VM): Pixels are received from the video port, there are some real time constraints (pixels must be sent at the pixel frequency required by the display module) for sending the data to the display;
- Command mode (CM): Pixels can be received from the video port or from the L4 interconnect, there are no real time constraints except that TE must be avoided by starting the transfer at the right time during scan of the display and should be fast enough.

**7.4.3.3.1 Video Mode**

The video mode refers to the MIPI DPI 1.0 standard. The sync events and pixels must be sent according to the display mode timings. Data are received from the video port. The display controller is in charge of fetching the data from the system memory and providing the data to the DSI protocol engine using the video port. The short packets used for the sync event are using precalculated 32-bit values. The long packets are constructed using the header defined in [DSS.DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) registers.

**7.4.3.3.2 Command Mode**

The command mode refers to the MIPI DCS standard. The commands, parameters and pixels are sent to the display module with limited real time constraints (as defined in [Section 7.4.3.3.1](#)). The pixels can be provided on the video port by the display controller or on the L4 interconnect port.

---

**NOTE:** In DSI command mode, the display controller must be configured in stall mode by setting the [DSS.DISPC\\_CONTROL\[11\]](#) STALLMODE bit to 1.

---

The [DSS.DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) registers are used for the header of long packets, the [DSS.DSI\\_VCn\\_SHORT\\_PACKET\\_HEADER](#) registers are used for the short packets.

The error correction code (ECC) can be provided while writing the ECC value directly into the [DSS.DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) and [DSS.DSI\\_VCn\\_SHORT\\_PACKET\\_HEADER](#) registers. The [DSS.DSI\\_VCn\\_CTRL\[8\]](#) ECC\_TX\_EN bit indicates if the ECC value should be calculated or if the value written in the register should be used instead for command and video modes. In case of synchronization short packets for video mode, since the hardware generates the short packets without using [DSS.DSI\\_VCn\\_SHORT\\_PACKET\\_HEADER](#) registers. If the [DSS.DSI\\_VCn\\_CTRL\[8\]](#) ECC\_TX\_EN bit is set to 1, the ECC is calculated; otherwise, the value zero is used. The feature is used to generate incorrect ECC for debug purpose and to ease the check for the link and peripheral error detection and correction.

For the payload, the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_PAYLOAD](#) registers are used. Each 32-bit PAYLOAD data is written into the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_PAYLOAD](#) register from the MPU subsystem or system DMA. It is buffered to be able to send packets with higher rate than the L4 interconnect frequency can provide. The word count defined in the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) registers is used to determine the number of bytes to be sent using the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_PAYLOAD](#) registers. The write into the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) registers is required before accessing the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_PAYLOAD](#) register. The hardware must be able to extract the length of the payload and be able to discard extra data sent using the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_PAYLOAD](#) register. The hardware takes into account the write into the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) register only if the VC is enabled otherwise the write is ignored by hardware.

In the case of pixels received on the video port, only the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) register is used. The video port pixels are used for the payload. When the pixel data is coming from the display controller video port, the DSI protocol can add a DCS command byte between the packet header and pixel data by setting the DSS.[DSI\\_CTRL\[24\]](#) DCS\_CMD\_ENABLE bit to 0x1. The value will be either 0x2c (write\_memory\_start) by setting the DSS.[DSI\\_CTRL\[25\]](#) DCS\_CMD\_CODE bit to 0x1, or 0x3c (write\_memory\_continue) by setting the DSS.[DSI\\_CTRL\[25\]](#) DCS\_CMD\_CODE bit to 0x0.

When transmitting RGB 16-BPP data, the DSS.[DSI\\_CTRL\[26\]](#) RGB565\_ORDER bit must be set to 0x1 to maintain the pixel byte order as in video mode .

A 2-line ping-pong buffer is implemented to allow the DSI protocol engine to store incoming pixels from the display controller through the video port while sending the DSI formatted frame to the DSI\_PHY. The ping-pong buffer is supported in command mode, provided the size of the packet defined in the header register is less than the size of each line buffer (768 \*32 bits). If the size of the packet is greater than the size of the line buffer, the ping-pong mechanism cannot be used (both lines are used as a single line).

The ping-pong buffer status can be checked by the [DSI\\_VCn\\_CTRL\[14\]](#) PP\_BUSY bit.

- When PP\_BUSY equals 1, the ping-pong buffer is active and the line buffers are not ready to receive data; therefore, the user cannot update a new header.
- When PP\_BUSY equals 0, at least one line buffer is empty; therefore, the user can update a new header. PP-BUSY is then set to 0x1. If both line buffers are empty, the user can write two headers, one following the other. PP\_BUSY remains at 0x0 after the first header is written, and is set to 0x1 after second header is written.

An IRQ is available to allow software to update header on events. The IRQ is enabled by setting the [DSI\\_VCn\\_IRQENABLE\[8\]](#) PP\_BUSY\_CHANGE\_IRQ bit to 0x1, and its status is accessible on the [DSI\\_VCn\\_IRQSTATUS\[8\]](#) PP\_BUSY\_CHANGE\_IRQ bit.

#### 7.4.3.3.3 Video + Command Modes

The two modes can be interlaced to send two DSI streams to two types of panels: Video or command types. The number of concurrent video stream is limited to a single one. The number of concurrent command mode streams is limited to 4 when there is no video stream and 3 otherwise. In case there is one DSI stream using video mode, the command mode pixels must be provided only on the L4 interconnect.

#### 7.4.3.3.4 Burst Modes

- Frequency-burst mode The frequency-burst mode is used to reduce the high-speed (HS) period by increasing the clock frequency on the DSI link. It allows in some case, the power consumption reduction of the link. The non-HS period used typically to drive the main panel can be used to send data to the secondary panel or to allow feedback (acknowledge) from the primary and secondary panels. The DSI protocol engine needs to buffer a full line before sending the HS packets for the line. A double buffering mechanism is required to be able to send a line while the following one is being received on the video port.
- Transparent-burst mode The transparent-burst mode is used by increasing the pixel clock frequency generated by the display controller with in addition an increase of the horizontal blanking period.

#### 7.4.3.3.5 Interleaving Mode

Video mode can output command mode packets, which are provided to DSI through the L4 interconnect, during the blanking periods of the video stream sequence on the PPI link. These command mode packets can be programmed as high-speed packets or low-power packets.

During a video stream sequence on the PPI link, four types of gap exist:

- BLLP gap: Blanking period during VSA, VBP, and VFP lines
- HSA gap: Blanking period during VACT lines; always between HS and HE short packet
- HBP gap: Blanking period during VACT lines; always between HS/HE short packet and data pixel long packet
- HFP gap: Blanking period during VACT lines; always between data pixel long packet and the end of the current VACT line

To perform interleaving in a particular gap, video mode must be set to go into low-power state during the blanking gap. Each type of gap has separate configurable register bits that determine whether a blanking long packet will be sent or the link will go into low-power state during the gap on the PPI link. If low-power state is set during a gap, the DSI module performs interleaving during that period.

Two set of registers are available for:

- High-speed interleaving (when high-speed command mode packets must be sent during a video stream on the PPI link)
- Low-power interleaving (when low-power command mode packets must be sent during a video stream on the PPI link)

##### 7.4.3.3.5.1 HS Command Mode Interleaving Programming Model

Figure 7-91 shows the various HS mode scenarios in interleaving mode during a blanking gap. For each type of blanking gap, a dedicated bit field determines the number of TxByteClkHS clock cycles used for interleaving in HS command mode packets.

- The BL\_HS\_INTERLEAVING[31:16] [DSI\\_VM\\_TIMING6](#) bit field defines the number of TxByteClkHS clock cycles used to interleave HS command mode packets during a BLLP gap.
- The HBP\_HS\_INTERLEAVING[7:0] [DSI\\_VM\\_TIMING4](#) bit field defines the number of TxByteClkHS clock cycles used to interleave HS command mode packets during an HBP gap.
- The HFP\_HS\_INTERLEAVING[15:8] [DSI\\_VM\\_TIMING4](#) bit field defines the number of TxByteClkHS clock cycles used to interleave HS command mode packets during an HFP gap.
- The HSA\_HS\_INTERLEAVING[23:16] [DSI\\_VM\\_TIMING4](#) bit field defines the number of TxByteClkHS clock cycles used to interleave HS command mode packets during an HSA gap.

These programmable values must be programmed to satisfy the timings for the clock and data lane to enter and exit HS mode latency. According to the scenario, different equations must be considered when calculating the register values.

**Figure 7-91. HS Command Mode Interleaving**

dss-327

**NOTE:** For calculations and equations, the following abbreviations are used: EXIT\_CLK\_HS\_MODE represents the exit HS mode latency for the clock lane. There is no dedicated register for this value but the programmer must know this value for further calculations.

$$\text{EXIT_CLK_HS_MODE} = T_{\text{CLK-TRAIL}} + T_{\text{H-S-EXIT}}$$

For the following equations, BLANKING\_PERIOD represents the BLLP, HSA, HBP, or HFP blanking periods. The HS\_INTERLEAVING period represents the maximal period HS command mode packets. Its value is set in the BL\_HS\_INTERLEAVING, HSA\_HS\_INTERLEAVING, HBP\_HS\_INTERLEAVING, or HFP\_HS\_INTERLEAVING registers, depending on the blanking type.

In each scenario, two calculations are present, depending on the value of ddr\_clk\_always\_on.

- $\text{ddr\_clk\_always\_on} = 1$ : Clock lane is always active.
- $\text{ddr\_clk\_always\_on} = 0$ : Clock lane is activated only when there are HS packets to be sent on the PPI link.
- Scenario 1: The gap for interleaving starts and ends with a regular video stream HS packet.
  - $\text{ddr\_clk\_always\_on} = 1$
$$\text{HS\_INTERLEAVING} = \text{BLANKING\_PERIOD} - (\text{EXIT\_HS\_MODE\_LATENCY} + \max\{\text{ENTER\_HS\_MODE\_LATENCY}, 2\} + 1)$$
  - $\text{ddr\_clk\_always\_on} = 0$
$$\text{HS\_INTER1} = \text{BLANKING\_PERIOD} - (\text{EXIT\_HS\_MODE\_LATENCY} + \max\{$$

- ```
ENTER_HS_MODE_LATENCY, 2} + 1)
HS_INTER2 = BLANKING_PERIOD - (DDR_CLK_POST + EXIT_CLK_HS_MODE +
DDR_CLK_PRE+ ENTER_HS_MODE_LATENCY + 1)
HS_INTERLEAVING = min{ HS_INTER1, HS_INTER2}

• Scenario 2: The gap for interleaving starts with a regular video stream HS packet and ends in LP state.
– ddr_clk_always_on = 1
    HS_INTERLEAVING = BLANKING_PERIOD - (EXIT_HS_MODE_LATENCY + 3)
– ddr_clk_always_on = 0
    HS_INTER1 = BLANKING_PERIOD - (EXIT_HS_MODE_LATENCY + 3)
    HS_INTER1 = BLANKING_PERIOD - (DDR_CLK_POST + EXIT_CLK_HS_MODE + 3)
    HS_INTERLEAVING = min{ HS_INTER1, HS_INTER2}
• Scenario 3: The gap for interleaving starts with the LP state and ends with a regular video stream HS packet.
– ddr_clk_always_on = 1
    HS_INTERLEAVING = BLANKING_PERIOD - (ENTER_HS_MODE_LATENCY +
    EXIT_HS_MODE_LATENCY + max{ ENTER_HS_MODE_LATENCY, 2} + 1)
– ddr_clk_always_on = 0
    HS_INTER1 = BLANKING_PERIOD - (DDR_CLK_PRE + ENTER_HS_MODE_LATENCY +
    EXIT_HS_MODE_LATENCY + max{ ENTER_HS_MODE_LATENCY, 2} + 1)
    HS_INTER2 = BLANKING_PERIOD - (DDR_CLK_PRE + ENTER_HS_MODE_LATENCY +
    DDR_CLK_POST + EXIT_CLK_HS_MODE + DDR_CLK_PRE+ ENTER_HS_MODE_LATENCY +
    1)
    HS_INTERLEAVING = min{ HS_INTER1, HS_INTER2}
• Scenario 4: The gap for interleaving starts with the LP state and ends with a regular video stream HS packet.
– ddr_clk_always_on = 1
    HS_INTERLEAVING = BLANKING_PERIOD - (ENTER_HS_MODE_LATENCY +
    EXIT_HS_MODE_LATENCY + 3)
– ddr_clk_always_on = 0
    HS_INTER1 = BLANKING_PERIOD - (DDR_CLK_PRE+ ENTER_HS_MODE_LATENCY +
    EXIT_HS_MODE_LATENCY + 3)
    HS_INTER2 = BLANKING_PERIOD - (DDR_CLK_PRE+ ENTER_HS_MODE_LATENCY +
    DDR_CLK_POST + EXIT_CLK_HS_MODE + 1)
    HS_INTERLEAVING = min{ HS_INTER1, HS_INTER2}
```

#### 7.4.3.3.5.2 LP Command Mode Interleaving Programming Model

Figure 7-92 shows the various LP mode scenarios in interleaving mode during a blanking gap. For each type of blanking gap, a dedicated bit field determines the number of bytes of LP command mode packets that can be sent during a blanking period.

- BL\_LP\_INTERLEAVING bit field [DSI\\_VM\\_TIMING6\[15:0\]](#) defines the number of bytes of LP command mode packets that can be sent during a BLLP gap.
- HBP\_LP\_INTERLEAVING bit field [DSI\\_VM\\_TIMING5\[7:0\]](#) defines the number of bytes of LP command mode packets that can be sent during a HBP gap.
- HFP\_LP\_INTERLEAVING bit field [DSI\\_VM\\_TIMING5\[15:8\]](#) defines the number of bytes of LP command mode packets that can be sent during a HFP gap.
- HSA\_LP\_INTERLEAVING bit field [DSI\\_VM\\_TIMING5\[23:16\]](#) defines the number of bytes of LP command mode packets that can be sent during a HSA gap.

These programmable values must be programmed to satisfy the timings for clock and data lane enter and exit LP mode latency. Clock lane timings do not affect LP command mode interleaving, because the clock lane can be controlled separately, compared with the data lane high-speed and low-power mutually exclusive control. Clock lanes can be in high-speed mode while the data lanes are in high-speed data transfer mode, low-power data transfer mode, or in low-power state.

According to this scenario, different equations must be considered for calculating register values.

**Figure 7-92. LP Command Mode Interleaving**



dss-328

For the following equations, BLANKING\_PERIOD represents the BLLP, HSA, HBP, or HFP blanking periods. The LP\_INTERLEAVING period represents the maximal period in LP command mode packets. Its value is set in the BL\_LP\_INTERLEAVING, HSA\_LP\_INTERLEAVING, HBP\_LP\_INTERLEAVING, or HFP\_LP\_INTERLEAVING registers, depending on the blanking type.

ALLOWED\_HSBYTE\_CLOCKS\_FOR\_LP represents the number of TxByteClkHS clock cycles during which LP interleaving can appear.

To calculate the LP\_INTERLEAVING value:

1. Calculate how many TxByteClkHS clock cycles can be reserved for LP interleaving during the appropriate blanking video mode gap.
2. Calculate the LP\_INTERLEAVING value according to the results of Step 1.

#### Step 1:

- Scenario 1: The gap for interleaving starts and ends with a regular video stream HS packet.

- $\text{ALLOWED\_HSBYTE\_CLOCKS\_FOR\_LP} = \text{BLANKING\_PERIOD} - (\text{EXIT\_HS\_MODE\_LATENCY} + \max\{\text{ENTER\_HS\_MODE\_LATENCY}, 2\} + 1)$
- Scenario 2: The gap for interleaving starts with a regular video stream HS packet and ends in LP state.  
 $\text{ALLOWED\_HSBYTE\_CLOCKS\_FOR\_LP} = \text{BLANKING\_PERIOD} - (\text{EXIT\_HS\_MODE\_LATENCY} + 1)$
  - Scenario 3: The gap for interleaving starts with the LP state and ends with a regular video stream HS packet.  
 $\text{ALLOWED\_HSBYTE\_CLOCKS\_FOR\_LP} = \text{BLANKING\_PERIOD} - (\max\{\text{ENTER\_HS\_MODE\_LATENCY}, 2\} + 1)$
  - Scenario 4: The gap for interleaving starts with the LP state and ends with a regular video stream HS packet.  
 $\text{ALLOWED\_HSBYTE\_CLOCKS\_FOR\_LP} = \text{BLANKING\_PERIOD} - 1$

After finishing Step 1, the time period available for LP interleaving is known:

$$T_{lp\_available} = \text{ALLOWED\_HSBYTE\_CLOCKS\_FOR\_LP} * T_{TxByteClkHS}$$

### Step 2:

The resulting value must be programmed in the appropriate video mode register for LP interleaving.

$$\text{LP\_INTERLEAVING} < \left[ \frac{T_{lp\_available} - 8*T_{hsbyte\_clk} - 5*T_{dsif\_clk} - 26}{T_{txclkesc}} \right]_{16}$$

dss-E124

$T_{TxByteClkHS}$ : Period of HS byte clock of DSI\_PHY module

$T_{dsif\_clk}$ : Period of DSI functional clock

$T_{txclkesc}$ : Period of LP transmit escape clock

#### 7.4.3.4 Power Management

The DSI protocol engine implements an handshake protocol on its L4 interconnect port with the PRCM. The DSI protocol engine provides a clock gating signal CIO\_CLK\_ICG to gate the L3 interface clock (L3\_ICLK) provided by the PRCM to the DSI complex I/O. It allows reduction of the power consumption of the DSI complex I/O while the DSI link is not in used. To gate the L3\_ICLK clock at DSI complex I/O level, set the DSS.[DSI\\_CLK\\_CTRL\[14\]](#) CIO\_CLK\_ICG bit to 1.

#### 7.4.3.5 Serial Configuration Port (SCP) Interface

The SCP interface is used to transfer register values from the DSI protocol engine to the DSI PLL Control module and to the DSI complex I/O. It spends several cycles to serialize the data to be sent. Software users must consider the delay in processing the transfer of the data from/to the slave port to/from the module.

##### 7.4.3.5.1 Shadowing Register

The two first SCP registers for the DSI complex I/O address map must be implemented as shadow registers. The shadowing mechanism is enabled/disabled using the DSS.[DSI\\_COMPLEXIO\\_CFG1\[31\]](#) SHADOWING bit:

- When setting the DSS.[DSI\\_COMPLEXIO\\_CFG1\[31\]](#) SHADOWING bit to 1, the transfer of the values from the two first L4 interconnect port registers into the two first registers of the DSI complex I/O ([DSS.DSI\\_PHY\\_REGISTER0](#) and [DSS.DSI\\_PHY\\_REGISTER1](#)) is done only when the DISPC\_UPDATE\_SYNC signal from the display controller is active and the DSS.[DSI\\_COMPLEXIO\\_CFG1\[30\]](#) GOBIT is set to 1. If there is no pending update for the two registers, when the DISPC\_UPDATE\_SYNC signal is asserted, the DSS.[DSI\\_COMPLEXIO\\_CFG1\[30\]](#) GObit is reset by hardware and there is no SCP transfer.
  - If there is only one register to update, only the corresponding new value is transferred. The second register in the DSI complex I/O is not updated. When the transfer is completed, the

DSS.DSI\_COMPLEXIO\_CFG1[30] GOBIT is reset by hardware.

- If the two registers need to be updated, the order of the transfer is first the register with lower address and then the second one. When the transfers are completed, the DSS.DSI\_COMPLEXIO\_CFG1[30] GOBIT is reset by hardware.
- When there is an on-going transfer (read or write) to any SCP register, the transfer must complete before starting the update of shadowing registers.
- When unsetting the DSS.DSI\_COMPLEXIO\_CFG1[31] SHADOWING bit to 0, if the transfer into the two first DSI complex I/O registers has already started, it should be finished.

---

**NOTE:** When reading the shadow registers, the local value stored in the DSI protocol engine is returned if the update is pending; otherwise, the values stored in the DSI complex I/O are returned.

---

#### 7.4.3.5.2 Busy Signal

The signal SCPBusy indicates that there is still some activity using the SCPClk provided by the PRCM. The SCPClk clock is the DSS\_L3\_ICLK clock.

#### 7.4.3.6 Power Control

The DSI protocol engine can control and send power commands for both DSI complex I/O and DSI PLL controller modules.

##### 7.4.3.6.1 Complex I/O Power Control Commands

The DSI complex I/O can be set into three modes:

- OFF: In this power state, the complete DSI\_PHY circuit is powered down. The internal LDO is OFF.
- ON: In this power state, the complete DSI\_PHY circuit is powered on and functional.
- ULPS: In this power state, the ULPS exit detection circuit power switch is ON for the lanes which are in receive ULPS mode. For the lanes which are in transmit ULPS mode, the circuitry for weak pull-down is ON. The ultralow-power state should only be used when all the three lanes are in ULPS (transmit or receive).

#### 7.4.3.6.1.2 Complex I/O Power FSM

Figure 7-93 describes the power control FSM to control the power state of the complex I/O.

**Figure 7-93. Complex I/O Power FSM**



dss-169

The PwrCmdOff, PwrCmdUlP and PwrCmdOn commands control the state transition of the DSI complex I/O. Software users must set the DSS.[DSI\\_COMPLEXIO\\_CFG1\[28:27\]](#) PWR\_CMD bit field to ask for a state change. The allowed transitions are: OFF - ON and ON - ULP and ULP - OFF. The DSS.[DSI\\_COMPLEXIO\\_CFG1\[26:25\]](#) PWR\_STATUS bit field gives a status on the current state of the DSI complex I/O.

**CAUTION**

- In automatic mode, software must ensure that the DSI complex I/O in the ON mode (that is, ON command already sent) before sending requests to the complex I/O.
- In a command request to change to a state which is the current one (acknowledge has been received), the command is ignored (nothing is sent to the DSI complex I/O).
- To change state to ULP state, users must ensure that all the three ULPSActiveNot signals are low. The ULPSActiveNot\_ALL0\_IRQ interrupt can be used by software users to determine the state of the ULPSActiveNot signals. The change from ULP to ON state is required before starting the ULP status exit sequence (see [Section 7.4.3.7.1](#) for details).

#### 7.4.3.6.2 DSI PLL Power Control Commands

The DSI PLL controller module can be set into four modes:

- OFF: The DSI PLL and HSDIVIDER are OFF.
- ON ALL: Both DSI PLL and HSDIVIDER are ON. The HS\_CLK clock is provided to the DSI complex I/O and the second clock output is provided to the HSDIVIDER.
- ON HSCLK: The DSI PLL is ON. The HSDIVIDER is OFF. The HS\_CLK clock is provided to the DSI complex I/O but the second clock output is not provided to the HSDIVIDER.
- ON DIV: Both DSI PLL and HSDIVIDER are ON. The HS\_CLK clock is not provided to the DSI complex I/O but the second clock output is provided to the HSDIVIDER.

#### 7.4.3.6.2.1 DSI-PLL Power FSM

Figure 7-94 shows the DSI PLL power FSM.

**Figure 7-94. DSI PLL Power FSM**

- 1 = DSI\_CLK\_CTRL[31:30] PLL\_PWR\_CMD = 0x0 (STATE\_OFF)
- 2 = DSI\_CLK\_CTRL[31:30] PLL\_PWR\_CMD = 0x1 (STATE\_ON\_HSCLK)
- 3 = DSI\_CLK\_CTRL[31:30] PLL\_PWR\_CMD = 0x2 (STATE\_ON\_ALL)
- 4 = DSI\_CLK\_CTRL[31:30] PLL\_PWR\_CMD = 0x3 (STATE\_ON\_DIV)



dss-170

The commands PLLPwrCmdOff, PLLPwrCmdOnAll, PLLPwrCmdOnDIV and PLLPwrCmdOnHSCLK controls the state transition of the DSI PLL control module. Software users must set the DSS.DSI\_CLK\_CTRL[31:30] PLL\_PWR\_CMD bit field to ask for a state change. The DSS.DSI\_CLK\_CTRL[29:28] PLL\_PWR\_STATUS bit field gives a status on the current state of the DSI PLL controller.

**NOTE:** In a command requests to change to a state which is the current one (acknowledge has been received), the command is ignored (nothing is sent to the DSI PLL Control module).

All the DSI PLL power is controlled by the DSI protocol engine except the LDO power of the PLL and HSDIVIDER that can be controlled by the DSI PLL controller module. Indeed, the HSDIVIDER and PLL SYSRESET signals can be forced by the DSI PLL controller module by setting DSS.DSI\_PLL\_CONTROL[4] DSI\_HSDIV\_SYSRESET and DSS.DSI\_PLL\_CONTROL[3] DSI\_PLL\_SYSRESET bits, respectively. By setting these bits to 1, the SYSRESET signal is forced active (module is forced to reset state). When these bits are set to 0 (reset value), the SYSRESET signals are controlled by the DSI PLL power FSM.

##### 7.4.3.6.2.1.1 DSI-PLL HS Clock Signals

The DSIStopClk signal is provided to the DSI PLL control module. It indicates when the DSI Protocol engine does not need to use the high-speed transfer mode (HS mode) and PLL HS output (HS\_CLK clock) can be stopped. The following conditions must also be met when DISPC\_UPDATE\_SYNC may be generated by the display controller, as that may also result in the PLL HS output being stopped.

When the interface is disabled (that is, DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit set to 0), the signal DSIStopClk is asserted.

The assertion of the DSIStopClk depends on the following conditions:

- Clock lane TxRequestHS is deasserted (the DDR clock on the clock lane is not required anymore). The get TxRequestHS deassertion, all of the following conditions are required:
  - The DSS.[DSI\\_CLK\\_CTRL\[13\]](#) DDR\_CLK\_ALWAYS\_ON bit must be reset to 0 and no HS data transfer should be ongoing or already scheduled.
  - No VC active in video mode. No VC using the video mode is enabled; if the VC is enabled, the mode is command mode only (that is, DSS.[DSI\\_VCn\\_CTRL\[0\]](#) VC\_EN bit set to 1 and DSS.[DSI\\_VCn\\_CTRL\[4\]](#) MODE bit set to 0).
  - No command mode requiring high-speed transfer (one or more VCs using command mode can be active)
  - Or DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit reset to 0 (if all previous conditions are not required)

The deassertion of the DSIStopClk depends on one of the following conditions (the DSI interface is enabled by setting the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit to 1):

- Clock lane TxRequestHS must be asserted (the DDR clock on the clock lane is required anymore).
- One video mode VC active
- At least one VC in command mode requiring high-speed transfer
- The DSS.[DSI\\_CLK\\_CTRL\[13\]](#) DDR\_CLK\_ALWAYS\_ON bit is set to 1 by software users (the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit must be reset to 0 to update the DDR\_CLK\_ALWAYS\_ON bit value)

Automatic assertion/deassertion is enabled by using the DSS.[DSI\\_CLK\\_CTRL\[18\]](#) HS\_AUTO\_STOP\_ENABLE bit.

Manual mode can be used by setting/resetting the DSS.[DSI\\_CLK\\_CTRL\[19\]](#) HS\_MANUAL\_STOP\_CTRL bit to assert/deassert the DSIStopClk signal.

#### **7.4.3.6.2.1.2 DSI-PLL HS Clock FSM**

Figure 7-95 shows the DSI PLL HS clock FSM.

**Figure 7-95. DSI PLL HS Clock FSM**



dss-171

When DSIStopClk is used there is a latency through other modules (DSI PLL controller and DSI\_PHY)

before TxByteClkHS is stopped. This latency must be accounted for to prevent any issue when DSIStopClk is deasserted soon after being asserted. This is done using a hardware timer programmed using the DSS.[DSI\\_STOPCLK\\_TIMING\[7:0\]](#) DSIStopclk\_Latency bit field. This timer is programmed in number of periods of the DSIS Protocol functional clock (DSI\_FCLK). At reset value, the timer is programmed with 0x80 (128) value.

#### CAUTION

The programmed value in the DSS.[DSI\\_STOPCLK\\_TIMING\[7:0\]](#) DSIStopclk\_Latency bit field must be greater than ((3 x L3\_ICLK period) + (5 x CLKIN4DDR period))/(DSI\_FCLK period).

### 7.4.3.7 Timers

---

**NOTE:** Among the timers described in this section, only the HS TX, LP RX and turnRequests timers generates interrupts immediately when the timer value is null. For ForceTxStopMode timer, it ends counting instantly and ForceTxStopMode is not asserted.

---

#### 7.4.3.7.1 Twakeup Timer

The  $T_{\text{WakeUp}}$  timer is not implemented in the DSIS protocol engine. The software must use a general-purpose (GP) timer to handle this. This timer is used for existing ULP status mode for the active lanes (clock and/or data lanes). The sequence to exit ULP state is:

1. Change the state of TxULPSExit for each lane to ACTIVE.
2. Wait for the interrupt indicating that all lanes with TxULPSExit active have acknowledged by asserting ULPSActiveNot. This is done by reading the DSS.[DSI\\_COMPLEXIO\\_IRQSTATUS](#) ULPSACTIVENOT\_ALLi\_IRQ bit fields ( $i = 0, 1$ ).
3. Start the application wake-up timer (GP timer).
4. Wait for the time-out.
5. Change the TxUlpsClk signals to INACTIVE state for the clock lane and/or TxRequestEsc INACTIVE state for the data lane(s).

---

**NOTE:** The minimum time for the wake-up period is 1 ms.

---

To enter ULPS mode for clock lane, TxUlpsClk state must be changed to active state. To enter ULPS mode for data lane, TxRequestEsc state must be changed to active state (TxUlpsEsc as well if it is not already in active state).

#### 7.4.3.7.2 ForceTxStopMode FSM

The signal ForceTxStopMode is used at initialization time (DSI complex I/O). [Figure 7-96](#) describes the ForceTxStopMode FSM to assert/deassert ForceTxStopMode signal.

**Figure 7-96. ForceTxStopMode FSM**

dss-172

The DSI protocol engine asserts ForceTxStopMode by setting the DSS.[DSI\\_TIMING1\[15\]](#) FORCE\_TX\_STOP\_MODE\_IO bit to 1. Asserting the FORCE\_TX\_STOP\_MODE\_IO bit allows to initialize the lanes. The lanes are in the Stop State when ForceTxStopMode signal is high.

No data can be sent before the ForceTxStopMode signal is deasserted. The deassertion time is defined by the STOP\_STATE\_COUNTER\_IO, Stop\_State\_x4\_IO, Stop\_State\_x16\_IO field [DSI\\_TIMING1\[15:0\]](#). The FORCE\_TX\_STOP\_MODE\_IO bit is reset by hardware when the time is reached.

This bit can be reset by software.

The calculation of the number of DSI\_FCLK cycles assertion period is defined by:

Total period in DSI\_FCLK cycles = [DSI\\_TIMING1\[12:0\]](#) STOP\_STATE\_COUNTER\_IO x (([DSI\\_TIMING1\[14\]](#) STOP\_STATE\_X16\_IO x 15) + 1) x (([DSI\\_TIMING1\[13\]](#) STOP\_STATE\_X4\_IO x 3) + 1)

#### 7.4.3.7.3 TurnRequest FSM

The signal TurnRequest is used to request turnaround. It is only valid for the data lane #1 since the other data lanes cannot be used in the reverse direction to receive data from the DSI receiver. [Figure 7-97](#) describes the TurnRequest FSM to assert/deassert TurnRequest signal.

Figure 7-97. TurnRequest FSM



The DSI protocol engine asserts TurnRequest signal during one TxClkEsc cycle when the turn-around is enabled through the DSS.[DSI\\_VCh\\_CTRL\[6\]](#) BTA\_EN bit (for more information, see [Section 7.4.3.8, Bus Turnaround](#)). The DSS.[DSI\\_TIMING1\[31\]](#) TA\_TO bit is set/reset by software to respectively enable/disable the timer for turnaround procedure failure. It can be reset by software or automatically by hardware when the time out occurs.

The timer is loaded with the value in number of DSI\_FCLK cycles:

$$\text{DSI\_TIMING1[28:16] TA\_TO\_COUNTER} \times ((\text{DSI\_TIMING1[30] TA\_TO\_X16} \times 15) + 1) \times ((\text{DSI\_TIMING1[29] TA\_TO\_X8} \times 7) + 1).$$

When the TA\_TO\_IRQ interrupt is generated (turn-around timer expired, and procedure failed), the hardware automatically asserts ForceTXStopMode in order for the DSI\_PHY to drive LP-11 stop state. The ForceTXStopMode timer is used to define the minimum duration of LP-11 state. The Stop State can be longer if there is no activity.

The hardware resets the ForceTXStopMode bit, followed by an internal logic reset except all register values and TX FIFO content, then resets the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit. The software should take action to recover by resetting the peripheral, for example, if it is not responding. It should wait for DSS.[DSI\\_TIMING1\[15\]](#) FORCE\_TX\_STOP\_MODE\_IO and DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bits to be reset to 0 before starting the recovery sequence.

#### 7.4.3.7.4 Peripheral Reset Timer

The peripheral reset timer is not implemented in the DSI protocol engine module. Such as the Twakeup timer, a general-purpose timer (GPTimer)should be used in case of reset of the peripheral to determine when the peripheral is ready again for operation.

#### 7.4.3.7.5 HS TX Timer

The HS TX timer is used to detect when the host has been in TX mode for too long. When time-out occurs, the EOT is forced. The timer is reloaded when a start of high speed transmission occurs. It is enabled/disabled by software through the DSS.[DSI\\_TIMING2\[31\]](#) HS\_TX\_TO bit. The interrupt HS\_TX\_TO\_IRQ is generated when the timer expires. The DSS.[DSI\\_IRQSTATUS\[14\]](#) HS\_TX\_TO\_IRQ bit is set to 1 when the HS TX time-out occurs.

The maximum time to be supported is 20 ms. It can be used to determine that at least once a frame in video mode, the HS mode is stopped to enter ULPS. Since the refresh rate can be up to 50 frames per second in video mode, the maximum time in HS is 20 ms.

The timer is loaded with the value in number of TxByteClkHS:

$DSI\_TIMING2[28:16] \text{ HS\_TX\_TO\_COUNTER} \times ((DSI\_TIMING2[30] \text{ HS\_TX\_TO\_X16} \times 15) + 1) \times ((DSI\_TIMING2[29] \text{ HS\_TX\_TO\_X8} \times 7) + 1)$

**Figure 7-98. High-Speed TX Timer FSM**



dss-174

When the time-out occurs, the hardware should sent EOT request in order for the DSI complex I/O to drive LP-11 stop state. This is followed by the generation of the interrupt. The hardware will perform an internal logic reset including the TX FIFO content, but excluding the register values and then resets the DSS.DSI\_CTRL[0] IF\_EN bit.

The software should wait for the DSS.DSI\_CTRL[0] IF\_EN bit to be reset to 0 before taking any recovery action by resetting for example the peripheral if it is not responding.

#### 7.4.3.7.6 LP RX Timer

When the host is in Low power Receive mode after a bus turn-around, the LP RX timer is loaded. When the timer expires, the host requests the DSI complex I/O to drive LP-11. The interrupt LP\_RX\_TO\_IRQ is generated when the timer expires. The DSS.DSI IRQSTATUS[15] LP\_RX\_TO\_IRQ bit is set to 1 when the LP RX time-out occurs.

The DSS.DSI\_TIMING2[15] LP\_RX\_TO bit is set/reset by the software to respectively enable/disable the timer.

The timer is loaded with the value in number of DSI\_FCLK cycles:

$DSI\_TIMING2[12:0] \text{ LP\_RX\_TO\_COUNTER} \times ((DSI\_TIMING2[14] \text{ LP\_RX\_TO\_X16} \times 15) + 1) \times ((DSI\_TIMING2[13] \text{ LP\_RX\_TO\_X4} \times 3) + 1)$

**Figure 7-99. Low-Power RX Timer FSM**

When the interrupt is generated, the hardware should automatically reset the DSS.[DSI\\_TIMING2\[15\]](#) LP\_RX\_TO bit and then assert ForceTxStopMode in order for the DSI complex I/O to drive LP-11 stop state. The ForceTxStopMode timer is used to define the minimum duration of LP-11 state. The Stop State can be longer if there is no activity.

The hardware resets the ForceTxStopMode bit, followed by an internal logic reset except all register values and TX FIFO content, then resets the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit. The software should take action to recover by resetting the peripheral, for example, if it is not responding. It should wait for the DSS.[DSI\\_TIMING1\[15\]](#) FORCE\_TX\_STOP\_MODE\_IO and DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bits to be reset before starting the recovery sequence. The TX FIFO is not flushed (the FIFO is flushed only when DSS.[DSI\\_VCh\\_CTRL\[0\]](#) VC\_EN is set to 1).

#### 7.4.3.8 Bus Turnaround

The bus turn-around (BTA) is not automatically sent by default after each packet sent to the display(s). It is programmable independently for each VC ID. The VC can be enabled when DSS.[DSI\\_VCh\\_CTRL\[6\]](#) BTA\_EN bit is set to 1 by software. The software should ensure that, when the BTA is sent to the peripheral, there is enough time allocated for the response and the BTA from the peripheral to host. For more information about possible DSI PHY timing adjustments during the turn-around procedure, see [Section 7.5.6.4.3, Turn-Around Request in Transmit Mode](#), and [Section 7.5.6.4.4, Turn-Around Request in Receive Mode](#). When setting the DSS.[DSI\\_VCh\\_CTRL\[6\]](#) BTA\_EN bit to 1, one BTA is sent manually to the peripheral. This manual mode can be used for packets in command or video mode.

Acknowledgment from the peripheral for successful BTA is indicated by asserting the BTA\_IRQ interrupt, if it is enabled in the DSS.[DSI\\_VCh\\_IRQENABLE\[5\]](#) BTA\_IRQ\_EN bit. To monitor the BTA interrupt, the user should read the DSS.[DSI\\_VCh\\_IRQSTATUS\[5\]](#) BTA\_IRQ status bit.

#### CAUTION

The BTA should not be sent when the RX FIFO is not empty. Users should take care of emptying the RX FIFO before sending BTA to the peripheral. It is to ensure that when receiving new data from peripheral, all the allocated spaces for all the VCs are empty.

In automatic mode, the BTA is sent automatically at the end of short or long packets when respectively the DSS.[DSI\\_VCn\\_CTRL\[2\]](#) BTA\_SHORT\_EN or the DSS.[DSI\\_VCn\\_CTRL\[3\]](#) BTA\_LONG\_EN bits are set to 1.

---

**NOTE:** If the DSS.[DSI\\_VCn\\_CTRL\[2\]](#) BTA\_SHORT\_EN bit is enabled, users can still set the DSS.[DSI\\_VCn\\_CTRL\[6\]](#) BTA\_EN bit. Only one BTA is sent to the peripheral and the DSS.[DSI\\_VCn\\_CTRL\[6\]](#) BTA\_EN bit is reset by hardware.

If the DSS.[DSI\\_VCn\\_CTRL\[3\]](#) BTA\_LONG\_EN bit is enabled, users can still set the DSS.[DSI\\_VCn\\_CTRL\[6\]](#) BTA\_EN bit. Only one BTA is sent to the peripheral and the DSS.[DSI\\_VCn\\_CTRL\[6\]](#) BTA\_EN bit is reset by hardware.

If the DSS.[DSI\\_VCn\\_CTRL\[2\]](#) BTA\_SHORT\_EN and DSS.[DSI\\_VCn\\_CTRL\[3\]](#) BTA\_LONG\_EN bits are both enabled, users can still set the DSS.[DSI\\_VCn\\_CTRL\[6\]](#) BTA\_EN bit to send a BTA. Only one BTA is sent and the DSS.[DSI\\_VCn\\_CTRL\[6\]](#) BTA\_EN bit is reset by hardware.

---

As explained previously, two modes can be used for each VC ID:

- Automatic: After each packet, a bus turn-around is sent. To determine the size of the long packet, the protocol engine on the host side should read the word count defined in the header (in DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) register) and use it to determine the last data to be sent on the DSI link. For short packets, the size is always 4 bytes. Then the bus turn-around is sent to the peripheral. The word count is also used to determine how many bytes should be transferred from the 32-bit writes access to the payload register (DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_PAYLOAD](#) register).
- Manual: In case of data transfer using the L4 interconnect port, while all data have been provided to the DSI protocol engine, users can select bus turn-around for the last packet provided to the L4 interconnect port only by setting the bus turn-around enable bit (DSS.[DSI\\_VCn\\_CTRL\[6\]](#) BTA\_EN) or for last packets and following ones by setting the automatic mode; in case of data transfer using the video port, the bus turnaround enable bit (DSS.[DSI\\_VCn\\_CTRL\[6\]](#) BTA\_EN) can be selected at any time during the transfer of the packet. In case of video mode packets (data and synchronization events) users cannot determine when the BTA is sent relatively the video mode packets, so it is highly recommended to use manual BTA mode only for packets generated in command mode but it is possible to use BTA when for a VC in video mode. In case of data provided on the video port, an interrupt for end of packet transfer (PACKET\_SENT\_IRQ) is provided to indicate users when the packet has been completely sent by the DSI complex I/O. The PACKET\_SENT\_IRQ can be monitored in [DSI\\_VCn IRQSTATUS\[2\]](#) PACKET\_SENT\_IRQ status bit. Users can request BTA even if the space allocated in the TX FIFO for the corresponding VC is empty. It can be sent later on even if there was no packet sent before BTA request. The DSS.[DSI\\_VCn\\_CTRL\[6\]](#) BTA\_EN bit should be reset by hardware if the BTA request has been sent even if the automatic mode for this specific type of packets is enabled.

The bus turnaround is supported for video mode packets and for command mode packets. It is not possible to send BTA during the blanking periods of the video mode when HS blanking packets should be sent, that is, when one of the following bits is set to 1:

- DSS.[DSI\\_CTRL\[20\]](#) BLANKING\_MODE
- DSS.[DSI\\_CTRL\[21\]](#) HFP\_BLANKING\_MODE
- DSS.[DSI\\_CTRL\[22\]](#) HBP\_BLANKING\_MODE
- DSS.[DSI\\_CTRL\[23\]](#) HSA\_BLANKING\_MODE

Therefore, in video mode, the BTA request is delayed until there is a blanking period without HS blanking packets.

### TA Timer

When TurnRequest signal is asserted (always only for data lane #1), the TA\_TO timer is started. If the direction signal is not changed according to the turn-around request, the TA\_TO interrupt is generated. When the Direction signal is in output mode, any data on the input data bus should be ignored since the DSI is in transmission mode (data and triggers should be ignored). See [Section 7.4.3.7.3](#) for more details on the TA\_TO timer.

### 7.4.3.9 PHY Triggers

The DSI protocol engine uses three triggers, which are supported only for data lane 1:

- Reset from host to display
- Tearing effect (TE) from display to host
- Acknowledge from display to host

#### CAUTION

Each trigger is associated with a dedicated user-configurable receive or transmit pattern, loaded in [DSI\\_PHY\\_REGISTER3](#) or [DSI\\_PHY\\_REGISTER4](#) bit fields. The default (reset) values of the bit fields are aligned with the MIPI D-PHY specification v0.92. If the user needs to change any of these values, the following must be considered:

- If any of the bit fields are written with a nondefault value, the other bit fields in the same register must also be configured with different values. This is to ensure that two different trigger bit fields are not programmed with the same pattern.
- If two or more bit fields are written with equal values, this may lead to unpredictable behavior of the DSI PHY module.

#### 7.4.3.9.1 Reset

The DSI protocol engine can use one of the triggers of the DSI\_PHY to send a reset to the display. The reset trigger pattern is configurable through the [DSI\\_PHY\\_REGISTER3\[31:24\]](#) REG\_TXTRIGGERESC3 bit field. To send the reset pattern to the peripheral, the DSS.[DSI\\_CTRL\[5\]](#) TRIGGER\_RESET bit must be set to 1. When the software requires the trigger reset pattern to be sent, the DSI protocol engine resets its own logic but not the registers. The software can select between two reset modes:

- Immediate reset: All pending requests in TX FIFO not already taken into account for transfer scheduling, the RX FIFO requests, and the data from video port are ignored. Only the current transfer on DSI link and already scheduled ones are transmitted. All the other transfers are discarded.
- Synchronized reset: The mode is only valid if there is VC using the video mode and if it is active. The principle is to wait for the current video frame to be transferred on the link. Any data on VP after the current frame are ignored.

To select the reset mode, software users must program the DSS.[DSI\\_CTRL\[14\]](#) TRIGGER\_RESET\_MODE.

#### CAUTION

For both reset modes, the hardware should flush the FIFOs, synchronization buffers, and line buffers before resetting the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit.

#### 7.4.3.9.2 Tearing Effect

The TE on the display is avoided by having synchronization information from the display. It is used only in command mode. In case of video mode, it is not functional. Users are responsible for selecting the command mode for the VC using the TE feature.

The software must set and send the appropriate sequence to receive the TE trigger pattern from the peripheral. The value of the expected TE trigger pattern can be configured through the [DSI\\_PHY\\_REGISTER4\[23:16\]](#) REG\_RXTRIGGERESC2 bit field. When the TE trigger pattern is received, the DSI protocol engine generates the TE\_TRIGGER\_IRQ interrupt with TE event if the interrupt is enabled. To enable the interrupt, set to 1 the DSS.[DSI\\_IRQENABLE\[16\]](#) TE\_TRIGGER\_IRQ\_EN bit. The DSS.[DSI\\_IRQSTATUS\[16\]](#) TE\_TRIGGER\_IRQ status bit indicates if the interrupt event has been generated.

One or multiple VCs can be synchronized using the same TE trigger. The DSS.[DSI\\_VCn\\_TE\[30\]](#) TE\_EN bit should be set to indicate that the hardware should use the following TE trigger to start the transfer of the data from the related VC. This bit is reset when all the data have been sent to the peripheral. The DSS.[DSI\\_VCn\\_TE\[31\]](#) TE\_START bit should be used when the automatic mode enabled by setting the DSS.[DSI\\_VCn\\_TE\[30\]](#) TE\_EN bit is not used. It allows users to start the transfer manually based on application events or based on the TE trigger interrupt (TE\_TRIGGER\_IRQ).

The number of bytes to be transferred is defined by using the DSS.[DSI\\_VCn\\_TE\[15:0\]](#) TE\_SIZE bit field. The TE\_SIZE bit field is decremented for each payload byte (it does not include Check-sum) sent on the DSI link. The register content should not be modified by software during a transfer. The DSS.[DSI\\_VCn\\_TE\[15:0\]](#) TE\_SIZE bit field should be set first to indicate that the following accesses to DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) register should be used for TE transfer.

The data can be provided from two sources (selection by setting the DSS.[DSI\\_VCn\\_CTRL\[1\]](#) SOURCE bit):

- L4 interconnect port using DMA request: The DMA request DSI\_DMA\_REQ*i* (*i*=0 to 3) to should be asserted only when TE trigger is received or when the DSS.[DSI\\_VCn\\_TE\[31\]](#) TE\_START bit is set by user and should not be asserted anymore when all the bytes defined in DSS.[DSI\\_VCn\\_TE\[15:0\]](#) TE\_SIZE bit field have been sent on the DSI link. The VC is associated with a DMA request (from DSI\_DMA\_REQ0 to DSI\_DMA\_REQ3) by programming the number in the DSS.[DSI\\_VCn\\_CTRL\[23:21\]](#) DMA\_TX\_REQ\_NB bit field. The DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_PAYLOAD](#) register is used to provide the number of bytes defined by the DSS.[DSI\\_VCn\\_TE\[15:0\]](#) TE\_SIZE bit field (the check-sum value is not provided in the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_PAYLOAD](#) register). The size of the header is not taken into account in the number of bytes to transfer. The DSS.[DSI\\_VCn\\_SHORT\\_PACKET\\_HEADER](#) register is not used.
- Video port: The DMA request is not asserted. The data are captured in the line buffer using the STALL mechanism. In case there is no line buffer instantiated (that is, DSS.[DSI\\_CTRL\[13:12\]](#) LINE\_BUFFER bit field set to 0), it is not possible to use the video port to provide data. The line buffer should be filled up according to the word count defined in the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) register header. The value should be written before the TE trigger event is received or before the DSS.[DSI\\_VCn\\_TE\[31\]](#) TE\_START bit is set to 1 by software. In case the total number of bytes defined by the DSS.[DSI\\_VCn\\_TE\[15:0\]](#) TE\_SIZE bit field is not a multiple of the word count defined in the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) register, all the packets have the same size defined by the WC of the header except the last transfer. The size of the last transfer is defined by the remaining bytes to send. Since the DSS.[DSI\\_VCn\\_TE\[15:0\]](#) TE\_SIZE bit field is modified after each packet transfer, the size of the last packet is equal to the value of DSS.[DSI\\_VCn\\_TE\[15:0\]](#) TE\_SIZE bit field just before the last transfer (the header and the payload check-sum sizes are not included in DSS.[DSI\\_VCn\\_TE\[15:0\]](#) TE\_SIZE bit field).

When the transfer is completed, the value of the DSS.[DSI\\_VCn\\_TE\[15:0\]](#) TE\_SIZE bit field is equal to 0. The software must ensure that the pending data in the TX FIFO for the corresponding VC using TE are related to TE transfer. Any data in the TX FIFO that should be sent before reception of TE trigger should be sent before TE. This is done by not enabling TE trigger until all data for the corresponding VC have been sent to the peripheral. The software can check that the space allocated for the VC in the TX FIFO is empty by reading the DSS.[DSI\\_VCn\\_CTRL\[5\]](#) TX\_FIFO\_NOT\_EMPTY status bit.

#### 7.4.3.9.3 Acknowledge

The corresponding Acknowledge interrupt (ACK\_TRIGGER\_IRQ ) is generated upon reception of the acknowledge trigger. The value of the expected acknowledge trigger pattern can be configured through the [DSI\\_PHY\\_REGISTER4\[15:8\]](#) REG\_RXTRIGGERESC1 bit field. To enable the acknowledge interrupt, set the DSS.[DSI\\_IRQENABLE\[17\]](#) ACK\_TRIGGER\_IRQ\_EN bit to 1. When the interrupt is generated, the DSS.[DSI\\_IRQSTATUS\[17\]](#) ACK\_TRIGGER\_IRQ status bit is set to 1.

#### 7.4.3.10 ECC Generation

The DSI protocol uses a four-byte packet header. Since ECC generation requires a fixed word length of 64-bits, the packet headers should be padded with additional bits to form a full eight-byte value for ECC generation and checking. The packet header less the ECC byte should occupy bits D[23:0] and the pad bits should occupy bits D[63:24]. All padding bits should be zero for the purpose of generating the ECC byte. ECC can be generated using a parallel approach as illustrated in [Figure 7-100](#).

**Figure 7-100. 64-Bit ECC Generation on TX Side**



dss-176

The ECC generation/check can be enabled and disabled by software. It is defined by a common bit for all the VCs:

- The DSS.[DSI\\_CTRL\[2\]](#) ECC\_RX\_EN bit enables/disables the ECC generation in the receive direction.
- The DSS.[DSI\\_VCn\\_CTRL\[8\]](#) ECC\_TX\_EN bit enables/disables the ECC generation in the transmit direction

#### 7.4.3.11 Checksum Generation for Long Packet Payloads

Long packets are comprised of a packet header protected by an ECC byte and a payload of 0 to  $2^{16} - 1$  bytes. To detect the errors during the transmission of long packets, a checksum is calculated over the payload portion of the data packet. Note that, for the special case of a zero-length payload, the 2-byte checksum is set to 0xFFFF. The checksum can only indicate the presence of one or more errors in the payload. Unlike ECC, the checksum does not enable error correction. For this reason, checksum calculation is not useful for some unidirectional DSI implementations since the peripheral has no way for reporting errors to the host processor. Checksum generation and transmission is mandatory for host processors sending long packets to peripherals. It is optional for peripherals transmitting long packets to the host processor. However, the format of long packets is fixed; the peripherals that do not support checksum generation should transmit two bytes having value 0x0000 in place of the checksum bytes when sending long packets to the host processor. The host processor should disable checksum checking for received long packets from peripherals that do not support checksum generation.

The checksum should be realized as a 16-bit CRC with a generator polynomial of  $x^{16}+x^{12}+x^5+x^0$ . The LS byte is sent first, followed by the MS byte. Note that within the byte, the LS bit is sent first.

**Figure 7-101. Checksum Transmission**



dss-177

The CRC implementation is presented in [Figure 7-102](#). The CRC shift register is initialized to 0xFFFF

before packet data enters. Packet data not including the packet header then enters as a bitwise data stream from the left, LS bit first. Each bit is fed through the CRC shift register before it is passed to the output for transmission to the peripheral. After all bytes in the packet payload have passed through the CRC shift register, the shift register contains the checksum. C15 contains the checksums MSB and C0 the LSB of the 16-bit checksum. The checksum is then appended to the data stream and sent to the receiver.

**Figure 7-102. 16 Bit CRC Generation Using a Shift Register**



The check-sum generation/check can be enabled and disabled by software. It is defined by a common bit for all the VCs:

- The DSS.[DSI\\_CTRL\[1\]](#) CS\_RX\_EN bit enables/disables the check-sum generation in the receive direction.
- The DSS.[DSI\\_VCn\\_CTRL\[7\]](#) CS\_TX\_EN bit enables/disables the check-sum generation in the transmit direction

#### 7.4.3.12 End of Transfer Packet

To allow the DSI protocol (rather than the DSI\_PHY) at the display to detect the HS End Of Transfer (EOT), an EOT packet type is added. It is a fixed short packet (4 bytes) that is added at every HS-to-LP transition. This function is enabled by the [DSI\\_CTRL\[19\]](#) EOT\_ENABLE bit.

The EOT packet has a fixed format:

- Data Type = DI [5:0] = 0b001000
- Virtual Channel = DI [7:6] = 0b00
- Payload Data [15:0] = 0x0F0F
- ECC [7:0] = 0x01

When more than one data lane is used, the bytes in the EOT packet are distributed across multiple lanes. EOT packet generation is supported only for the end of HS transmissions. No EOT packet is added at the end of LP transmissions. For LP reception, any EOT packet received is simply passed through the same as any other packet, but no internal decode or use is made of the EOT information.

#### 7.4.4 DSI PLL Controller Functionalities

##### 7.4.4.1 DSI PLL Controller Overview

The DSI PLL controller module forms part of the display sub-system. Nevertheless, it uses the SCP (Serial Configuration Port) and PMP (Power Management Port) ports as the primary interfaces to the DSI protocol engine. The SCP interface is used to set the configuration of the DPPLL and HSDIVIDER modules, primarily the various counter values. The PMP port is used to control the power state of the DPPLL and HSDIVIDER modules. [Figure 7-103](#) provides an overview of the DSI PLL controller module inside the display subsystem.

The DSI PLL is also used to generate the 74.25-MHz frequency used for HDTV applications.

**Figure 7-103. DSI PLL Controller Overview**

dss-179

**NOTE:** The DSI PLL controller module does not have an interface to L4 interconnect. The programmable features are managed by registers mapped into the DSI protocol engine.

#### 7.4.4.2 DSI PLL Controller Architecture

The DSI PLL is an ADPLL module. The pixel clock (PCLK) frequency range is 2 to 68.25 MHz. This may be divided by 2. This is performed by setting the DSS.DSI\_PLL\_CONFIGURATION2[12] DSI\_PLL\_HIGHFREQ bit to 1.

Figure 7-104 shows the internal DSI PLL reference diagram.

**Figure 7-104. DSI PLL Reference Diagram**


camdss-180

NOTE: PCLK is inverted as the falling edge is the reference edge and ADPLL uses positive edge as reference (F/F should be positive edge clock also).

The DSI PLL clock output corresponds to the CLKIN4DDR clock of the DSI complex I/O module.

The DSI PLL reference clock is the DSI\_PLL\_REFCLK clock. Depending on the setting in DSS.DSI\_PLL\_CONFIGURATION2[11] DSI\_PLL\_CLKSEL bit, the reference clock can be either the DSS2\_ALWON\_FCLK provided by the PRCM or the PCLKFREE provided by the DISPC module.

#### 7.4.4.3 DSI PLL Operations

The signals of the DSI PLL configuration operate according to [Table 7-37](#). The values in the table indicate the operation when the PLL is not locked.

**Table 7-37. DSI PLL Operation Modes When Not Locked**

| DSI PLL Operation Mode                            | Stop mode Low power <sup>(1)</sup>         | Stop mode Fast Relock <sup>(1)</sup>        | Idle bypass                                           |
|---------------------------------------------------|--------------------------------------------|---------------------------------------------|-------------------------------------------------------|
| Mode Description                                  | Output clocks stopped Lowest power standby | Output clocks stopped Fastest start-up time | Selects when PLL and HSDIVIDER bypass clocks are used |
| DSS.DSI_PLL_CONFIGURATION2[0] DSI_PLL_IDLE        | 0                                          | 0                                           | 1                                                     |
| DSS.DSI_PLL_CONFIGURATION2[6] DSI_PLL_LOWCURRSTBY | 1                                          | 0                                           | 1                                                     |
| DSS.DSI_PLL_CONFIGURATION1[0] DSI_PLL_STOPMODE    | 1                                          | 1                                           | X                                                     |

<sup>(1)</sup> Recommended

When locked, the PLL output frequency is:  $[(2x\text{REGM})/(\text{REGN} + 1)] \times [\text{CLKin}(MHz)/(HIGHFREQ + 1)]$  where:

- M multiplier is programmed in DSS.DSI\_PLL\_CONFIGURATION1[18:8] DSI\_PLL\_REGM bit field.
- N divider is programmed in DSS.DSI\_PLL\_CONFIGURATION1[7:1] DSI\_PLL\_REGN bit field.
- HIGHFREQ divider by 2 is enabled by setting the DSS.DSI\_PLL\_CONFIGURATION2[12]

DSI\_PLL\_HIGHFREQ bit to 1.

#### 7.4.4.4 DSI PLL Controller Shadowing Mechanism

The configuration registers are accessed through the DSI protocol engine register space using SCP port. This includes all the configuration signals and the returning status signals.

**CAUTION**

All writes must be 32-bit operations as the SCP always transfers 32 bits. Any 16-bit or 8-bit operations may lead to unpredictable errors.

A shadow mechanism is implemented for appropriate register values so that configurations may optionally be updated in synchronism with the display controller (DISPC) and DSI protocol engine. The front porch time from the DISPC indicates the time when making the update of the value. All the required updated values must have been written before this signal is asserted. See [Section 7.4.3.5.1](#) for more details.

#### 7.4.4.5 Error Handling

The PLL lock and recalibration signals may be monitored to detect loss of lock or requirement to recalibrate (due to large temperature change since the last lock request):

- The DSS.[DSI\\_PLL\\_STATUS](#)[1] DSI\_PLL\_LOCK status bit gives the DSI PLL lock state.
- The DSS.[DSI\\_PLL\\_STATUS](#)[2] DSI\_PLL\_RECAL status bit informs if the PLL must be uncalibrated

These signals can also generate interrupts at DSI protocol engine level:

- The PLL\_LOCK\_IRQ interrupt indicates that the DSI PLL control module has sent a lock request to the DSI PLL. To monitor this event, read the DSS.[DSI\\_IRQSTATUS](#)[7] PLL\_LOCK\_IRQ bit. Set this bit to 1 to clear the status bit.
- The PLL\_UNLOCK\_IRQ interrupt indicates that the DSI PLL control module has sent an unlock request to the DSI PLL. To monitor this event, read the DSS.[DSI\\_IRQSTATUS](#)[8] PLL\_UNLOCK\_IRQ bit. Set this bit to 1 to clear the status bit.
- The PLL\_RECAL\_IRQ interrupt indicates that the DSI PLL control module has sent a recalibration request to the DSI PLL. To monitor this event, read the DSS.[DSI\\_IRQSTATUS](#)[9] PLL\_RECAL\_IRQ bit. Set this bit to 1 to clear the status bit.

### 7.4.5 DSI Complex I/O Functionalities

#### 7.4.5.1 DSI Complex I/O Overview

DSI\_PHY is a complex I/O with 3 unidirectional (HS) Lane Modules. This includes 2 data lane modules and 1 clock lane module. Each lane module has 2 data pads (DX, DY). These data pads are connected with a complementary lane module on the DSI receiver device using point to point interconnect.

Lane modules support high-speed burst mode. Forward direction and reverse direction escape modes are also supported. Escape modes maybe used for Low Power Data Transmission, among other things.

The maximum data rate supported is 900 Mbps per data lane. The lane module function and position is configurable, that is, any lane module can be chosen as clock lane module, and DX/DY data pad for each lane module can be configured as either DP or DN pins defined by DSI\_PHY spec.

DSI\_PHY interacts with the higher layers of the DSI link through the PHY-Protocol Interface (PPI). DSI\_PHY does not include a PLL; a high frequency clock input is expected in HS mode (CLKIN4DDR). DSI\_PHY supports also Serial Configuration Protocol (SCP) to set various configuration and control registers. The DSI\_PHY supports GPIO operation on each of the six data pins.

## 7.4.6 RFBI Functionalities

The RFBI module can capture the output pixel from the display controller and send the data to the RFB in the LCD panel. The application configures the RFBI module, sends commands, reads data, and configures the display controller to send data fetched from the system memory by the display controller DMA engine. The commands/data are sent using an 8-, 9-, 12-, or 16-bit parallel interface.

The display controller is configured to send the data in 12-, 16-, 18-, or 24-BPP format. In the video port FIFO, the encoded pixel values are in an LSB alignment independently of the endianness in system memory.

[Figure 7-105](#) shows an overview of the RFBI architecture.

**Figure 7-105. RFBI Architecture Overview**



dss-053

### 7.4.6.1 RFBI FIFO

The input video port FIFO receives data from the display controller at the pixel clock. The data in the video port FIFO are read by the RFBI and are sent to the LCD panel. The video port FIFO is 24 bits wide and each pixel in 12-, 16-, 18-, and 24-BPP format is stored in the video port FIFO using one 24-bit value aligned on the 24-bit LSB. [Section 7.4.6.4, Output Parallel Modes](#), shows an example of an output configuration based on the interface width (16 bits) and the pixel format output (24 bits).

### 7.4.6.2 RFBI Interconnect FIFO

The interconnect FIFO receives the data from [RFBI\\_DATA](#) write requests to the L4 interconnect slave port. The data in the interconnect FIFO are read by the RFBI and sent to the LCD panel. The width of the interconnect FIFO is 32 bits. The size of the interconnect FIFO is 24 words of 32 bits (that is, 24 words of [RFBI\\_DATA](#)).

### 7.4.6.3 Input Pixel Formats

The supported pixel formats in the RFBI module are: RGB24-888, RGB18-666, RGB16-565, and RGB12-444 as output from the display controller and from the L4 (for writing parameters). In both cases, the pixels are formatted in accordance with the configuration of the output interfaces (multiple cycles).

#### 7.4.6.4 Output Parallel Modes

The RFBI output modes are 8-, 9-, 12-, and 16-bit interfaces. Any mode can be selected regardless of the pixel format. Set the right configuration in the cycle registers to define a valid configuration for each output cycle.

The following example is an output configuration based on the 16-bit interface width and the 24-bit pixel format ( $i = 0$  or  $1$ ) (see also [Table 7-38](#)):

- The DSS.[RFBI\\_CONFIG\[10:9\]](#) CYCLEFORMAT bit field is set to  $0x3$  (three cycles for two pixels).
- The DSS.[RFBI\\_DATA\\_CYCLE1\\_i](#) register is set to  $0x00000010$  (16 bits from pixel 1 for the first cycle).
- The DSS.[RFBI\\_DATA\\_CYCLE2\\_i](#) register is set to  $0x00080808$  (8 bits from pixel 1 and pixel 2 and alignment of 8 bits from pixel 2 for the second cycle).
- The DSS.[RFBI\\_DATA\\_CYCLE3\\_i](#) register is set to  $0x00100000$  (16 bits from pixel 2 for the third cycle).

**Table 7-38. 16-Bit Interface Configuration/24-Bit Mode**

|          | 24-Bit Mode |           |           |
|----------|-------------|-----------|-----------|
|          | 1st Cycle   | 2nd Cycle | 3rd Cycle |
| Data[15] | R0[7]       | B0[7]     | G1[7]     |
| Data[14] | R0[6]       | B0[6]     | G1[6]     |
| Data[13] | R0[5]       | B0[5]     | G1[5]     |
| Data[12] | R0[4]       | B0[4]     | G1[4]     |
| Data[11] | R0[3]       | B0[3]     | G1[3]     |
| Data[10] | R0[2]       | B0[2]     | G1[2]     |
| Data[9]  | R0[1]       | B0[1]     | G1[1]     |
| Data[8]  | R0[0]       | B0[0]     | G1[0]     |
| Data[7]  | G0[7]       | R1[7]     | B1[7]     |
| Data[6]  | G0[6]       | R1[6]     | B1[6]     |
| Data[5]  | G0[5]       | R1[5]     | B1[5]     |
| Data[4]  | G0[4]       | R1[4]     | B1[4]     |
| Data[3]  | G0[3]       | R1[3]     | B1[3]     |
| Data[2]  | G0[2]       | R1[2]     | B1[2]     |
| Data[1]  | G0[1]       | R1[1]     | B1[1]     |
| Data[0]  | G0[0]       | R1[0]     | B1[0]     |

#### 7.4.6.5 Unmodified Bits

In a cycle, if every bit in the interface does not have a pixel value, the status of the unused bits can be programmed to be 0, 1, or the previous value (I/O power consumption optimization).

#### 7.4.6.6 Bypass Mode

In bypass mode, the RFBI path is bypassed and the display controller data and signals are sent directly to the output interface of the RFBI.

#### 7.4.6.7 Send Commands

The commands are written through the L4 interconnect and into the DSS.[RFBI\\_CMD](#) register. After a command is sent, another one can be accepted by the module and set. If the processing of a command is not complete, the MPU access to change the command stalls.

#### 7.4.6.8 Read/Write

Depending on the status of A0, WE, and RE, the commands and display/parameter data are written to the panel (handled by the state-machine for the commands/parameter data and stored in memory for the display data), or the display data/status values are read from the LCD panel (status and display data in the LCD panel memory). The polarity of A0 (RFBI\_A0 signal), WE (RFBI\_WR signal), RE (RFBI\_RD signal), and CSx (RFBI\_CSx signal, with x = 0, 1) is programmable.

[Table 7-39](#) describes the read/write function.

**Table 7-39. Read/Write Function Description**

| A0 (RFBI_A0) | WE (RFBI_WR) | RE (RFBI_RD) | Function Description                     |
|--------------|--------------|--------------|------------------------------------------|
| 1            | 0            | 1            | Display data write, parameter data write |
| 1            | 1            | 0            | Display data read                        |
| 0            | 1            | 0            | Status read                              |
| 0            | 0            | 1            | Command data write                       |

A minimum of RFBI\_Cs cycle time, as defined in [Table 7-40](#), is required to keep the RFBI\_CSx signal asserted between write transfers of multiple pixels.

[Table 7-40](#) indicates the minimum cycle time for RFBI\_CSx, depending on the source of pixels (display controller or L4 interconnect slave port) and the cycle format (1pixel/cycle, 1 pixel/2 cycles, 1 pixel/3 cycles, or 2 pixels/3 cycles).

**Table 7-40. Minimum Cycle Time for CSx/WE Always Asserted**

| RFBI Performance   | RFBI_CONFIG[10:9]<br>CYCLEFORMAT | RFBI_CONFIG[8:7]<br>L4FORMAT | Minimum Cycle Time (in Number of L4 Cycles) |
|--------------------|----------------------------------|------------------------------|---------------------------------------------|
| L4 interconnect    | 1 pixel/cycle                    | 1 pixel                      | 5                                           |
|                    | 1 pixel/2 cycles                 | 1 pixel                      | 4                                           |
|                    | 1 pixel/3 cycles                 | 1 pixel                      | 4                                           |
|                    | 2 pixels/3 cycles                | 1 pixel                      | 6                                           |
|                    | 1 pixel/cycle                    | 2 pixels                     | 4                                           |
|                    | 1 pixel/2 cycles                 | 2 pixels                     | 4                                           |
|                    | 1 pixel/3 cycles                 | 2 pixels                     | 4                                           |
|                    | 2 pixels/3 cycles                | 2 pixels                     | 6                                           |
| Display Controller | 1 pixel/cycle                    | N/A                          | 4                                           |
|                    | 1 pixel/2 cycles                 | N/A                          | 3                                           |
|                    | 1 pixel/3 cycles                 | N/A                          | 3                                           |
|                    | 2 pixels/3 cycles                | N/A                          | 6                                           |

#### 7.4.7 Video Encoder Functionalities

The input formats supported by the encoders are 24-bit 4:4:4 RGB. The encoder output is the DAC stage (for more information, see [Section 7.2, Display Subsystem Environment](#)). In the display subsystem, the input format from the display controller is always 24-bit RGB. The RGB-to-YCbCr color space converter converts the 24-bit RGB pixel data to 24-bit YCbCr data.

The remaining Cb and Cr color components enter the 2-to-1 chrominance decimation, which reduces by half the chrominance bandwidth and the amount of chrominance data. After the data manager, the encoder processes in 4:2:2 data path up to the 2x interpolation. A luma delay synchronizes luma to chrominance data.

[Figure 7-106](#) shows an overview of the video encoder architecture.

Figure 7-106. Video Encoder Architecture Overview



camdss\_swpu176-public-079

**NOTE:** Output video mode can be either composite video (CVBS output) or separate video (S-video: Luma and Chroma outputs):

- Composite video: only AVDAC1 is used
- Separate video (Luma/Chroma): Both AVDAC1 (Luma) and AVDAC2 (Chroma) are used. The selection is programmed with DSS.[DSS\\_CONTROL\[6\]](#) VENC\_OUT\_SEL bit. Composite video is the default selection.

#### 7.4.7.1 Test Pattern Generation

For diagnostic purposes, the data manager can be forced to output 100/100 color bar RGB/YCbCr data by setting the SVDS field [VENC\\_F\\_CONTROL\[7:6\]](#) register to 0x1.

Table 7-41. 100/100 Color Bar Table

| COLOR   | R   | G   | B   | Y   | Cb  | Cr  |
|---------|-----|-----|-----|-----|-----|-----|
| White   | 255 | 255 | 255 | 235 | 128 | 128 |
| Yellow  | 255 | 255 | 0   | 210 | 16  | 146 |
| Cyan    | 0   | 255 | 255 | 170 | 166 | 16  |
| Green   | 0   | 255 | 0   | 145 | 54  | 34  |
| Magenta | 255 | 0   | 255 | 106 | 202 | 222 |
| Red     | 255 | 0   | 0   | 81  | 90  | 240 |
| Blue    | 0   | 0   | 255 | 41  | 240 | 110 |
| Black   | 0   | 0   | 0   | 16  | 128 | 128 |

### 7.4.7.2 Luma Stage

The luma stage includes a luma pipeline delay, luma shaping, 2x interpolation filter, and luma variable delay. The luma pipeline delay block is used to match luma path length to chroma path length. In the luma gain shaper, a programmable gain is first applied to the luminance data output. The luminance gain is defined by the DSS.[VENC\\_GAIN\\_Y](#) register. Horizontal sync, vertical sync, and setup insertion are then performed.

Black level and blank level are programmable through the DSS.[VENC\\_BLACK\\_LEVEL](#) and DSS.[VENC\\_BLANK\\_LEVEL](#) registers. All the transition edges of the luminance signal, such as sync edges and active video edges, are properly shaped and filtered to keep the bandwidth within the standards.

After all required components of the luminance signal are added, the resulting signal is low-passed and interpolated to 2x-pixel rate. This 2x interpolation simplifies the external analog reconstruction filter design and improves the signal-to-noise ratio.

### 7.4.7.3 Chroma Stage

The chroma stage includes a low-pass filter, first-stage 2x interpolation, chroma gain shaper, and second-stage 2x interpolation. A pair of programmable gains adjusts the time-multiplexed U/V signal. The gains for U and V are independently controlled by the DSS.[VENC\\_GAIN\\_U](#) and DSS.[VENC\\_GAIN\\_V](#) register bits.

### 7.4.7.4 Subcarrier and Burst Generation

The encoder uses a 32-bit subcarrier increment to synthesize the subcarrier. The value of the subcarrier increments required to generate the desired subcarrier frequency for NTSC and PAL format is found by:

$$S\_CARR = \text{ROUND} \left( [F_{sc}/F_{clkenc}] \times 2^{32} \right)$$

where:

$F_{sc}$  = Frequency of the subcarrier

$F_{clkenc}$  = Frequency of the internal video encoder

The DSS.[VENC\\_S\\_CARR](#) register controls the subcarrier frequency. The DSS.[VENC\\_C\\_PHASE](#) register controls the phase of the subcarrier. The phase of the color subcarrier is reset to DSS.[VENC\\_C\\_PHASE](#). Table 7-42 presents the [VENC\\_S\\_CARR](#) register values depending the standard and pixel type used.

**Table 7-42. VENC\_S\_CARR Register Recommended Values**

| Standard          | Pixel Type   | Subcarrier Frequency ( $F_{sc}$ ) (MHz) | $F_{clkenc}$ (MHz) | <a href="#">VENC_S_CARR</a> register value (hexa) |
|-------------------|--------------|-----------------------------------------|--------------------|---------------------------------------------------|
| NTSC-M, J         | ITU-R601     | 3.579545                                | 27                 | 0x21F07C1F                                        |
| PAL-M             | ITU-R601     | 3.5756083125                            | 27                 | 0x21E6EEF3                                        |
| PAL-B, D, G, H, I | ITU-R601     | 4.43361875                              | 27                 | 0x2A098ACB                                        |
| NTSC-M, J         | Square pixel | 3.579545                                | 24.5454            | 0x25555555                                        |
| PAL-M             | Square pixel | 3.579561149                             | 24.5454            | 0x1F15C01E                                        |
| PAL-B, D, G, H, I | Square pixel | 4.43361875                              | 29.50              | 0x26798C0C                                        |

#### CAUTION

In square pixel mode, an external clock generator is needed to provide sampling frequencies (49.09 MHz for NTSC square pixel or 59 MHz for PAL square pixel).

The color subcarrier reset has four modes:

- No reset

- Reset every two lines
- Reset every two fields
- Reset every eight fields

The DSS.VENC\_C\_PHASE register can be used to adjust the SCH (subcarrier to horizontal sync phase). The DSS.VENC\_BSTAMP\_WSS\_DATA[6:0] BSTAP bit field sets the amplitude of the color burst. The DSS.VENC\_M\_CONTROL[1] PAL bit enables phase alternation line encoding.

A phase switching subcarrier is generated to encode the chrominance signal when the DSS.VENC\_M\_CONTROL[1] PAL bit is set to 1. Otherwise, a normal subcarrier is generated. Phase alternation line refers to the encoding scheme in which the subcarrier alternates between two phases every scan line. Two possible alternation sequences are possible, and the DSS.VENC\_M\_CONTROL[5] PALPHS bit selects one of these sequences.

#### 7.4.7.5 Closed Caption Encoding

The encoder can be programmed to encode closed-caption data and extended data in the selected line. The closed-caption data are sent to the encoder through the L4 interconnect. The data stream consists of 7-bit US-ASCII code and 1 odd-parity bit (see [Table 7-43](#)).

**Table 7-43. Closed-Caption Data Format**

| MSB  | LSB   |       |       |       |       |       |            |
|------|-------|-------|-------|-------|-------|-------|------------|
| Bit6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Odd parity |

The standard service encodes closed caption in both fields; the extended service encodes closed caption in even fields. When set to 1, the DSS.VENC\_L21 wc\_CTL L21EN[0] bit enables closed-caption encoding in odd fields. When set to 1, the DSS.VENC\_L21 wc\_CTL L21EN[1] bit enables closed-caption encoding in even fields.

To select the scan line where the CC data are encoded, program the [VENC\\_LN\\_SEL\[4:0\]](#) SLINE bit field.

**CAUTION**

The setting of the value of the SLINE[4:0] bit field depends on the video standard:

- PAL mode: Because there is a one-line offset, program the desired line number – 1. To activate the closed caption on line 21 (0x15), program the value  $0x15 - 1 = 0x14$ . The default value is  $0x15 + 1 = 0x16$  (line 22).
- NTSC mode: Because there is a four-line offset, program the desired line number – 4. To activate the closed caption on line 21 (0x15), program the value  $0x15 - 4 = 0x11$ . The default value is  $0x15 + 4 = 0x19$  (line 25).

The DSS.VENC\_LN\_SEL[25:16] LN21\_RUNIN bit field should be kept at reset value (0x10B). Four closed-caption data registers contain the data to be encoded. The DSS.VENC\_LINE21[15:8] L21O and DSS.VENC\_LINE21[7:0] L21O bit fields contain the first and the second bytes, respectively, of closed-caption data to be encoded in the odd field. The DSS.VENC\_LINE21[31:24] L21E and DSS.VENC\_LINE21[23:16] L21E bit fields contain the first and the second bytes, respectively, of data to be encoded in the even field.

Immediately after the closed-caption data is written to the registers, in either the odd field or even field, the corresponding closed-caption status bit (DSS.VENC\_STATUS[4] CCE or DSS.VENC\_STATUS[3] CCO) is reset to 0 to indicate that the closed-caption data is available in the closed-caption data registers and yet to be encoded.

Immediately after the closed-caption data is encoded, the DSS.VENC\_STATUS[4] CCE bit or the DSS.VENC\_STATUS[3] CCO bit is set to 1 to indicate that the closed-caption data has been encoded and is ready to accept new data. As seen in [Figure 7-107](#), a null character is automatically inserted if the closed-caption data is not written to the closed-caption data registers in time for encoding.

The running clock frequency is controlled by the DSS.[VENC\\_CC\\_CARR\\_WSS\\_CARR\[15:0\]](#) FCC bit field which should be kept at reset value (0x2631) to get 5034960.5Hz (32xline) for NTSC-601. The closed-caption running clock common frequencies are detailed in [Table 7-44](#).

**Table 7-44. Closed-Caption Run Clock Frequency Settings**

|                                                 | NTSC-601 | PAL-601 | NTSC Square Pixel | PAL Square Pixel |
|-------------------------------------------------|----------|---------|-------------------|------------------|
| VENC_CC_CARR_WSS_CARR[15:0] FCC bit field value | 0x2631   | 0x25ED  | 0x2A03            | 0x22B6           |

The closed-caption data is encoded in nonreturn-to-zero (NRZ) format. Additionally, the data translates to the IRE scale as follows: 0 = 0 IRE; 1 = 50 IRE.

[Figure 7-107](#) shows the parameters of closed-caption line data implemented in different standards.

**Figure 7-107. Closed Captioning Timing**



dss-080

**NOTE:**

- The interval A is controlled by the DSS.[VENC\\_LN\\_SEL\[25:16\]](#) LN21\_RUNIN bit field.
- The interval B is controlled by DSS.[VENC\\_CC\\_CARR\\_WSS\\_CARR\[15:0\]](#) FCC bit field.

**Table 7-45. Closed-Caption Standard Timing Values**

| Intervals | Description                      | Timing Values for Encoding |                |                | Timing Values for Decoding |                |                |
|-----------|----------------------------------|----------------------------|----------------|----------------|----------------------------|----------------|----------------|
|           |                                  | Minimal                    | Nominal        | Maximal        | Lower Bound                | Nominal        | Upper Bound    |
| A         | HSYNC to clock running           | 10.250 $\mu$ s             | 10.500 $\mu$ s | 10.750 $\mu$ s | 10.000 $\mu$ s             | 10.500 $\mu$ s | 11.000 $\mu$ s |
| B         | Clock running                    |                            | 12.910 $\mu$ s |                |                            | 12.910 $\mu$ s |                |
| C         | Clock running to third start bit |                            | 3.972 $\mu$ s  |                |                            | 3.972 $\mu$ s  |                |
| D         | Start bit                        |                            | 1.986 $\mu$ s  |                |                            | 1.986 $\mu$ s  |                |
| E         | Data characters                  |                            | 31.778 $\mu$ s |                |                            | 31.778 $\mu$ s |                |

**NOTE:** All timing values listed in [Table 7-45](#) are measured from the mid-point (half amplitude) on all edges.

For a complete description of copy protection including CGMS-A, please refer to CEA-608-x standard

#### 7.4.7.6 Wide-Screen Signaling (WSS) Encoding

The encoder can embed data, encoded in accordance with the IEC61880 and ITU-R 1119 data insertion standard, within the vertical blanking interval.

The encoder supports WSS data insertion on line 20 of every frame in the NTSC format. WSS data insertion is enabled by activating the DSS.[VENC\\_L21\\_WC\\_CTL](#)[14:13] EVEN\_ODD\_EN bit and by programming the [VENC\\_BSTAMP\\_WSS\\_DATA](#)[27:8] WSS\_DATA bit field.

The running clock frequency is controlled by the DSS.[VENC\\_CC\\_CARR\\_WSS\\_CARR](#)[31:16] FWSS bit field. The wide-screen signaling running clock common frequencies are detailed in [Table 7-46](#)

**Table 7-46. Wide-Screen Signaling Run Clock Frequency Settings**

|                                                                    | NTSC-601 | PAL-601 | NTSC Square Pixel | PAL Square Pixel |
|--------------------------------------------------------------------|----------|---------|-------------------|------------------|
| <a href="#">VENC_CC_CARR_WSS_CARR</a> [31:16] FWSS bit field value | 0x043F   | 0x2F72  | 0x04AC            | 0x2B6D           |

To select the line where the WSS data are encoded, program the DSS.[VENC\\_L21\\_WC\\_CTL](#)[12:8] LINE bit field.

**CAUTION**

The setting of the LINE[12:8] bit field value depends on the video standard:

- PAL mode: There is an one line offset, so program the wanted line number - 1. The recommended value is line  $0x16 + 1 = 0x17$  (23rd line). Note that the default value is  $0x14 + 1 = 0x15$  (21st line).
- NTSC mode: There is a four line offset, so program the wanted line number - 4. The recommended value is line  $0x10 + 4 = 0x14$  (20th line). Note that the default value is  $0x14 + 4 = 0x18$  (24th line).

The WSS encoding block assumes that a full 10-bit video range is used to determine the 70 percent of peak-white amplitude of a logic-1 bit. The encoder also supports WSS data insertion on line 23 in the PAL format. Both waveforms are shown in [Figure 7-108](#).

**Figure 7-108. WSS Timing**


dss-081

#### 7.4.7.7 Video DAC Stage – Architecture and Control

[Figure 7-109](#) shows the architecture of the video DAC stage, comprising two 10-bit video DACs (AVDAC1 and AVDAC2) instances.

Figure 7-109. Video DAC Stage Architecture



dss-082

The display subsystem provides the necessary control signals to interface the memory frame buffer directly to external displays (TV sets). Two (one per channel) 10-bit current steering AVDAs are used to generate the video analog signal:

- AVDAC1: Carries either the CVBS (composite) or S-Video Luma (Y) analog TV outputs; it provides also the TV detection/disconnection and power-down mode features.
- AVDAC2 : Carries only the S-Video Chroma (C) analog TV output.

The device system control module provides two dedicated AVDAC registers, CONTROL.CONTROL\_AVDAC1 and CONTROL.CONTROL\_AVDAC2, to configure the respective channels through the following bit field:

- CONTROL.CONTROL\_AVDACx [20:16] AVDACx\_COMP\_EN: Allows direct control over the configuration of the analog TV output. See [Table 7-47](#), [Section 7.5.8, Video Encoder Basic Programming Model](#), and [Chapter 13, System Control Module](#).

Table 7-47. Analog TV Output Control

| Register CONTROL.CONTROL_AVDACx [x=1, 2] | Description                                                                                                                                                                                    |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [19] AVDACx_COMP_EN                      | Single or dual channel operation<br>0: Single channel (default)<br>1: Dual channel                                                                                                             |
| [18] AVDACx_COMP_EN                      | Channel role<br>0: Luma video channel (dual-channel configuration) or Composite video channel (single-channel configuration) (default)<br>1: Chroma video channel (dual-channel configuration) |

**Table 7-47. Analog TV Output Control (continued)**

| Register CONTROL.CONTROL_AVDACx [x=1, 2] | Description                                                                                                                                                      |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [17] AVDACx_COMP_EN                      | Full scale swing selection<br>0: High full-scale output swing: 1.3 V (default)<br>1: Low full-scale output swing: 0.88 V                                         |
| [16] AVDACx_COMP_EN                      | Current reference selection<br>0: External current reference (set by external resistor connected to cvideo1_rset pin) (default)<br>1: Internal current reference |

**CAUTION**

Any change to the control register must be done only when the respective VDAC is off.

High full-swing mode is the default mode. Low-swing mode does not comply with the NTSC and PAL video standards. It must be used only for backward compatibility to the OMAP35x.

**7.4.7.8 Video DC/AC Coupled TV Load**

The 10-bit video DAC stage supports both DC-coupled and AC-coupled TV loads. The CONTROL.CONTROL\_DEVCONF1[11] TVACEN bit is used to define which output coupling is used (0: DC coupling; 1: AC coupling). This bit is the first one to be programmed according to the TV load on the PCB board.

---

**NOTE:** In high-swing mode, when DC coupling is used, there is a 180-mV DC offset at the TVOUT output (cvideo1\_out for AVDAC1 and cvideo2\_out for AVDAC2).

In low-swing mode, when DC coupling is used, the DC offset at the maximum DAC code (@Max DAC current ~500  $\mu$ A) is 300 mV.

---

**7.4.7.9 TV Detection/Disconnection Pulse Generation and Usage****7.4.7.9.1 TV Detection/Disconnection Pulse Generation**

The TV detect block is an integral part of the video DAC stage.

---

**NOTE:**

- The TV detection/disconnection feature is supported only for AVDAC1.
  - The TV disconnection feature is recommended to save power. The TV detection/disconnection is operational only when video out is active. Therefore, to detect cable connection automatically, it is necessary to periodically activate the video out to test for cable presence.
- 

This block compares the output of AVDAC1 (cvideo1\_out) to a reference, to sense the condition of the load. To operate, the TV detect requires two digital signals, TVACEN and TVDET. The TVACEN signal indicates to both TVOUT buffer and the TV detect circuit if the load is AC or DC coupled to adjust accordingly. To enable the detection of the load, the video encoder generates a negative TVDET pulse aligned with the TV sync pulses. The operation of the circuit is based on the difference in voltage levels in the output of the buffer depending on the load status. The TV detect block compares the output against a couple of references and the result is latched at the start of every sync pulse. The status, given by the TVINT output bit, is read later with the TVDET pulse rising edge. The TVINT signal of AVDAC1 is internally connected to channel 1 of the GPIO2 module, mapped as the TV detector interruption.

The following registers are used to set the TV detection/disconnection pulse:

- The DSS.[VENC\\_TVDETGP\\_INT\\_START\\_STOP\\_X](#) register defines which pixels are used to start and stop the pulse inside their respective line.
- The DSS.[VENC\\_TVDETGP\\_INT\\_START\\_STOP\\_Y](#) register defines which lines are used to start and stop the pulse.
- The DSS.[VENC\\_GEN\\_CTRL\[0\]](#) EN bit enables or disables the TVDET pulse (0: Disable; 1: Enable).
- The DSS.[VENC\\_GEN\\_CTRL\[16\]](#) TVDP bit sets the TVDET pulse polarity (0: Active low; 1: Active high).

#### 7.4.7.9.2 TV Detection Procedure

The TV detection procedure is the following:

1. Initial setup:
  - Program the DSS.[VENC\\_TVDETGP\\_INT\\_START\\_STOP\\_X](#) and DSS.[VENC\\_TVDETGP\\_INT\\_START\\_STOP\\_Y](#) registers to define on which pixels and lines, respectively, the TVDET pulse will start and stop.
  - Set the DSS.[VENC\\_GEN\\_CTRL\[16\]](#) TVDP bit to 1 (reset value) for a TVDET pulse active high polarity.
  - Set the DSS.[VENC\\_GEN\\_CTRL\[0\]](#) EN bit to 1 to enable the TVDET pulse generation.
2. The TVDET signal is set to low by hardware according to the settings in the DSS.[VENC\\_TVDETGP\\_INT\\_START\\_STOP\\_X](#) and DSS.[VENC\\_TVDETGP\\_INT\\_START\\_STOP\\_Y](#) registers.
3. Set the [VENC\\_OUTPUT\\_CONTROL\[0\]](#) LUMA\_ENABLE bit (in s-video mode) or the [VENC\\_OUTPUT\\_CONTROL\[1\]](#) COMPOSITE\_ENABLE (in composite video mode) to 1 to enable the video DAC1 output.
4. Power up the vdda\_dac voltage for the DAC stage and the TVOUT buffer (repeat every TV field during the horizontal synchronization). This is software controlled through an I<sup>2</sup>C interface connected to the power IC.
5. The TVDET pulse is set high by hardware according to the settings in the DSS.[VENC\\_TVDETGP\\_INT\\_START\\_STOP\\_X](#) and DSS.[VENC\\_TVDETGP\\_INT\\_START\\_STOP\\_Y](#) registers.
6. Check the TVINT output signal: When TVINT is set to 1, the load is connected.

#### CAUTION

- If AC coupling is selected, two TVDET pulses are required to set high the TVINT signal. Due to the internal logic of the video DAC1, the TVINT signal is generated after the next positive edge of the TVDET signal that happens during the next VSYNC timing.
- If DC coupling is selected, only one TVDET pulse is required to set high the TVINT signal.

#### 7.4.7.9.3 TV Disconnection Procedure

The TV disconnection procedure is the following:

1. Initial setup:
  - Program the DSS.[VENC\\_TVDETGP\\_INT\\_START\\_STOP\\_X](#) and DSS.[VENC\\_TVDETGP\\_INT\\_START\\_STOP\\_Y](#) registers to define on which pixels and lines, respectively, the TVDET pulse will start and stop.
  - Set the DSS.[VENC\\_GEN\\_CTRL\[16\]](#) TVDP bit to 1 (reset value) for a TVDET pulse active high polarity.
  - Set the DSS.[VENC\\_GEN\\_CTRL\[0\]](#) EN bit to 1 to enable the TVDET pulse generation.
2. The TVDET signal is set to low by hardware according to the settings in the DSS.[VENC\\_TVDETGP\\_INT\\_START\\_STOP\\_X](#) and DSS.[VENC\\_TVDETGP\\_INT\\_START\\_STOP\\_Y](#)

registers.

3. The TVDET pulse is set high by hardware according to the settings in the DSS.VENC\_TVDETGP\_INT\_START\_STOP\_X and DSS.VENC\_TVDETGP\_INT\_START\_STOP\_Y registers.
4. Check the TVINT output signal: When TVINT is reset to 0, the load is disconnected.
5. Reset the VENC\_OUTPUT\_CONTROL[0] LUMA\_ENABLE bit (in s-video mode) or the VENC\_OUTPUT\_CONTROL[1] COMPOSITE\_ENABLE (in composite video mode) to 0 to disable the video DAC1 output.
6. Power-down the vdda\_dac voltage for the DAC stage and the TVOUT buffer (repeat every TV field during the horizontal synchronization). This is software controlled through an I<sup>2</sup>C interface connected to the power IC.

#### CAUTION

- If DC coupling is selected, two TVDET pulses are required to set low the TVINT signal. Due to the internal logic of the video DAC1, the TVINT signal is generated after the next positive edge of the TVDET signal that happens during the next VSYNC timing.
- If AC coupling is selected, only one TVDET pulse is required to set low the TVINT signal.

#### 7.4.7.9.4 Recommended TV Detection/Disconnection Pulse Waveform

To enable the detection/disconnection of the load, the circuit requires that the TVDET pulse resembles the following waveform. As explained in [Section 7.4.7.9.2, TV Detection Procedure](#), and in [Section 7.4.7.9.3, TV Disconnection Procedure](#) by using the video encoder registers, the TVDET pulse polarity, start and stop is programmable. The only critical parameter is Tdm, which should be longer than the delay through the AVDAC and TVOUT buffer, which is at least 750 ns.

If DC-coupling is selected, the TVINT output signal for TV detection is latched at the rising edge of the first TVDET signal but the TVINT output signal for TV disconnection is latched after the next rising edge of the TVDET signal that happens during the next VSYNC timing. [Figure 7-110](#) shows the waveforms for the DC-coupling TV detect pulse (TVDET) when load is connected and disconnected.

**Figure 7-110. DC-Coupling TV Detect Waveforms for TV Connected and Disconnected**



dss-083

If AC-coupling is selected, the TVINT output signal for TV detection is latched after the next rising edge of the TVDET signal that happens during the next VSYNC timing but the TVINT output signal for TV disconnection is latched at the rising edge of the first TVDET signal. [Figure 7-111](#) shows the waveforms for the AC-coupling TV detect pulse (TVDET) when load is connected and disconnected.

**Figure 7-111. AC-Coupling TV Detect Waveforms for TV Connected and Disconnected****NOTE:**

- When setting the DSS.VENC\_TVDETGP\_INT\_START\_STOP\_X register, software users must ensure that the TVDET signal is in the active area. To avoid any problem, the TVDET signal must not be longer than one line.
- The activation of the TVDET signal will not have a visual impact on the cvideo1\_out output signal.

**7.4.7.9.5 TV Detection/Disconnection Usage**

The TV-detection/TV-disconnection is based on the difference in voltage levels in the output of the TV buffer depending on the load status. The operation is slightly different for ac and for dc operation. For DC operation, the cvideo1\_out voltage is compared against a voltage reference that makes the comparator trigger in each sync pulse while the load is connected. For AC operation, the cvideo1\_out voltage is compared against a voltage reference that makes the comparator trigger in each sync pulse while the load is disconnected. In both cases, the TVINT output signal produces a logic 1 when a load is connected and a logic 0 when a load is disconnected.

For DC-coupling mode, see [Figure 7-112](#) and for AC-coupling mode, see [Figure 7-113](#).

---

**NOTE:** Because the video DAC stage and the video encoder must be awake for connection detection, consider that the video DAC stage can take up to 10  $\mu$ s to wake up.

---

**Figure 7-112. GPIO Signal Waveform Proposal for TV Detection/Disconnection in DC-Coupling Mode**

**Figure 7-113. GPIO Signal Waveform Proposal for TV Detection/Disconnection in AC-Coupling Mode**


#### 7.4.7.10 Video DAC Stage Bypass Mode

The 10-bit video DAC stage has a TVOUT buffer bypass mode that turns off the TVOUT buffers and redirects directly the outputs of the DACs to the VFB pins (cvideo1\_vfb for AVDAC1 and cvideo2\_vfb for AVDAC2).

This bypass mode is activated by setting the CONTROL.CONTROL\_DEVCONF1[18] TVOUTBYPASS bit to 1. The reset value of the CONTROL.CONTROL\_DEVCONF1[18] TVOUTBYPASS bit is 0 (that is, the TVOUT buffer is not bypassed).

**NOTE:** In bypass mode:

- The cvideo1\_rset pin requires a Rset resistor connected to the ground. The typical value of the Rset resistor is 10K.
- Both cvideo1\_vfb and cvideo2\_vfb pins require a Rout resistors connected to the ground. The typical values of Rout1 and Rout2 resistors are 1,5K.

**CAUTION**

- The TV detect feature is not available in bypass mode.
- In bypass mode, an external amplifier is needed on the cvideo1\_vfb and cvideo2\_vfb pins.

**7.4.7.11 Video DAC Stage Test Mode**

The DAC stage can be tested for debug using either 10-bit external data or 10-bit internal register values directly connected to the DACs. See [Figure 7-114](#) for video DAC test in composite video mode, and see [Figure 7-115](#) for video DAC test in separate video mode.

**Figure 7-114. DAC Test Mode in Composite Video Mode**

dss-087

**Figure 7-115. DAC Test Mode in Separate video Mode**


dss-088

- Use the DSS.VENC\_OUTPUT\_CONTROL[4] TEST\_MODE bit to select between DAC normal mode (0x0) and DAC test mode (0x1).
- Use the DSS.VENC\_OUTPUT\_CONTROL[7] CHROMA\_SOURCE bit for AVDAC2 and either the DSS.VENC\_OUTPUT\_CONTROL[6] COMPOSITE\_SOURCE bit (in composite video mode) or the DSS.VENC\_OUTPUT\_CONTROL[5] LUMA\_SOURCE bit (in s-video mode) for AVDAC1 to select the test mode:
  - 0x0: From the internal register DSS.VENC\_OUTPUT\_TEST[25:16] CHROMA\_TEST bit field for AVDAC2 and either DSS.VENC\_OUTPUT\_TEST[9:0] COMPOSITE\_TEST bit field (composite video) or DSS.VENC\_OUTPUT\_CONTROL[25:16] LUMA\_TEST (s-video mode) for AVDAC1
  - 0x1: From the video port G[1:0], B[7:0]

**NOTE:** In the external data test mode (bypass mode), the display controller must provide the data (G[1:0], B[7:0]) externally. To do this, configure the video encoder to generate correct timing signals, without which the display controller cannot operate (even if the encoder core is bypassed from the data path perspective).

#### 7.4.7.12 Video DAC Stage Power Management

After device reset, the DSS\_CONTROL[5] DAC\_POWERDN\_BGZ register bit is set to 0, and the video DAC stage is powered down.

Table 7-48 shows possible power management configurations and the corresponding register settings.

**Table 7-48. Video DAC Stage Power Management**

| Power Management Controls          |                                                   |                                                              |                                           |                                         |                                    |                                                     |
|------------------------------------|---------------------------------------------------|--------------------------------------------------------------|-------------------------------------------|-----------------------------------------|------------------------------------|-----------------------------------------------------|
| DSS_CONTROL[5]<br>DAC_POWERD_N_BGZ | AVDAC2<br>VENC_OUTPUT_CONTROL[2]<br>CHROMA_ENABLE | AVDAC1<br>VENC_OUTPUT_C<br>ONTROL[1]<br>COMPOSITE_ENA<br>BLE | VENC_OUTPUT<br>_CONTROL[0]<br>LUMA_ENABLE | CONTROL_DEV<br>CONF1[18]<br>TVOUTBYPASS | CONTROL_D<br>EVCONF1[11]<br>TVACEN | Description                                         |
| 0                                  | x                                                 | x                                                            | x                                         | x                                       | x                                  | Total power down.<br>Bandgaps powered down.         |
| 1                                  | 0                                                 | 0                                                            | 0                                         | x                                       | x                                  | Standby (analog in power down except bandgaps/LDOs) |
| 1                                  | 1                                                 | 1                                                            | 1                                         | 0                                       | 0                                  | Full power up in DC mode                            |
| 1                                  | 1                                                 | 1                                                            | 1                                         | 0                                       | 1                                  | Full power up in AC mode                            |
| 1                                  | 1                                                 | 1                                                            | 1                                         | 1                                       | x                                  | Full power up in TVOUT bypass mode (DAC-only mode)  |

## 7.5 Display Subsystem Basic Programming Model

This section describes how to configure the display subsystem for the desired functionalities and also describes the programming models of the display controller, the RFBI and the video encoder.

The main configuration scenarios are:

- LCD panel support (bypass or RFBI mode)

Configure the RFBI module (only if in RFBI mode; otherwise, the default values must remain), and then configure the display controller to the desired functionalities before the activities start.

- TV set support

Configure the video encoder and then the display controller.

- Both LCD panel support (bypass or RFBI mode) and TV set support

Configure the RFBI module (only if in RFBI mode; otherwise, leave the default values), configure the video encoder, and then configure the display controller.

### 7.5.1 Display Subsystem Reset

The display subsystem can receive a software reset that is propagated through all of the submodules to initialize the subsystem. The following procedure describes a possible sequence:

1. If the LCD is on, stop the LCD by setting the DSS.[DISPC\\_CONTROL\[0\]](#) LCDENABLE bit to 0.
  - (a) Reset the frame done status bit by writing 1 in the DSS.[DISPC\\_IRQSTATUS\[0\]](#) FRAMEDONE bit.
  - (b) Wait until the DSS.[DISPC\\_IRQSTATUS\[0\]](#) FRAMEDONE bit is set to 1. This shows that the end of frame has taken place and the LCD stop is complete.
2. To take the display subsystem out of reset, all clocks related to the display subsystem must be enabled and the DPLL4 must be enabled. The following clocks must be enabled to take the display subsystem out of reset:
  - PRCM.CM\_FCLKEN\_DSS[0] EN\_DSS1 bit set to 1
  - PRCM.CM\_FCLKEN\_DSS[1] EN\_DSS2 bit set to 1
  - PRCM.CM\_FCLKEN\_DSS[2] EN\_TV bit set to 1
  - PRCM.CM\_ICLKEN\_DSS[0] EN\_DSS bit set to 1Once the clocks are enabled as shown, the display subsystem can be taken out of reset.
3. Write 1 in the DSS.[DSS\\_SYSCONFIG\[1\]](#) SOFTRESET bit to apply the soft reset to the subsystem.
4. Read the DSS.[DSS\\_SYSSTATUS\[0\]](#) RESETDONE bit. If this bit is 1, the reset sequence is complete; otherwise, read this bit again (the reset sequence is not completed).

### 7.5.2 Display Subsystem Configuration Phase

The display subsystem configuration phase is important to configure the data flow for using the LCD panel or the TV set. Use the following flow:

1. To configure the top level of the functional clock of the display controller clock, set the DSS.[DSS\\_CONTROL\[0\]](#) DSS\_CLK\_SWITCH bit.
2. To configure the top level of the video encoder, set the DSS.[DSS\\_CONTROL\[2\]](#) VENC\_CLOCK\_MODE bit and the DSS.[DSS\\_CONTROL\[3\]](#) VENC\_CLOCK\_X4 bit for TV set support.
3. To configure the top level of the DAC stage, set the DSS.[DSS\\_CONTROL\[4\]](#) DAC\_DEMEN bit for TV set support (if required).
4. Configure the RFBI module and/or the video encoder as needed.
5. Configure the display controller.

### 7.5.3 Display Controller Basic Programming Model

Some display controller registers are termed *shadow registers*, which are associated with the digital output and/or the LCD output. A shadow register change has no direct effect on the configuration of the display controller unless the DSS.[DISPC\\_CONTROL\[5\]](#) GOLCD bit is set for the LCD output and/or the DSS.[DISPC\\_CONTROL\[6\]](#) GODIGITAL bit is set for the digital output.

In the case of the digital output, after programming the shadow registers, the DSS.[DISPC\\_CONTROL](#)[6] GODIGITAL bit must be set to 1. If this bit is not set, the configuration of the display controller will have no effect. This setting indicates that all display controller shadow registers are programmed and that hardware can update the internal registers at the external EVSYNC.

In the case of the LCD output, after programming the shadow registers, the DSS.[DISPC\\_CONTROL](#)[5] GOLCD bit must be set to 1. If this bit is not set, the configuration of the display controller will have no effect. This setting indicates that all display controller shadow registers are programmed and that hardware can update the internal registers at the VFP start period.

Before setting either the DSS.[DISPC\\_CONTROL](#)[5] GOLCD or DSS.[DISPC\\_CONTROL](#)[6] GODIGITAL bit, ensure that the bit is cleared.

[Table 7-49](#) lists the shadow registers.

**Table 7-49. Shadow Registers**

| Shadow Register Name                               | Updated on VFP Start Period<br>(LCD output) | Updated on External VSYNC<br>(Digital output) |
|----------------------------------------------------|---------------------------------------------|-----------------------------------------------|
| DSS. <a href="#">DISPC_CONTROL</a>                 | X <sup>(1)</sup>                            | X <sup>(1)</sup>                              |
| DSS. <a href="#">DISPC_CONFIG</a>                  | X                                           | X                                             |
| DSS. <a href="#">DISPC_DEFAULT_COLOR_m</a> (m = 0) | X                                           |                                               |
| DSS. <a href="#">DISPC_DEFAULT_COLOR_m</a> (m = 1) |                                             | X                                             |
| DSS. <a href="#">DISPC_TRANS_COLOR_m</a> (m = 0)   | X                                           |                                               |
| DSS. <a href="#">DISPC_TRANS_COLOR_m</a> (m = 1)   |                                             | X                                             |
| DSS. <a href="#">DISPC_LINE_NUMBER</a>             | X                                           |                                               |
| DSS. <a href="#">DISPC_TIMING_H</a>                | X                                           |                                               |
| DSS. <a href="#">DISPC_TIMING_V</a>                | X                                           |                                               |
| DSS. <a href="#">DISPC_POL_FREQ</a>                | X                                           |                                               |
| DSS. <a href="#">DISPC_DIVISOR</a>                 | X                                           |                                               |
| DSS. <a href="#">DISPC_SIZE_DIG</a>                |                                             | X                                             |
| DSS. <a href="#">DISPC_SIZE_LCD</a>                | X                                           |                                               |
| DSS. <a href="#">DISPC_GFX_BAj</a> (j = 0,1)       | X                                           | X                                             |
| DSS. <a href="#">DISPC_GFX_POSITION</a>            | X                                           | X                                             |
| DSS. <a href="#">DISPC_GFX_SIZE</a>                | X                                           | X                                             |
| DSS. <a href="#">DISPC_GFX_ATTRIBUTES</a>          | X                                           | X                                             |
| DSS. <a href="#">DISPC_GFX_FIFO_THRESHOLD</a>      | X                                           | X                                             |
| DSS. <a href="#">DISPC_GFX_ROW_INC</a>             | X                                           | X                                             |
| DSS. <a href="#">DISPC_GFX_PIXEL_INC</a>           | X                                           | X                                             |
| DSS. <a href="#">DISPC_GFX_WINDOW_SKIP</a>         | X                                           | X                                             |
| DSS. <a href="#">DISPC_GFX_TABLE_BA</a>            | X                                           | X                                             |
| DSS. <a href="#">DISPC_GFX_PRELOAD</a>             | X                                           | X                                             |
| DSS. <a href="#">DISPC_CPR_COEF_R</a>              | X                                           |                                               |
| DSS. <a href="#">DISPC_CPR_COEF_G</a>              | X                                           |                                               |
| DSS. <a href="#">DISPC_CPR_COEF_B</a>              | X                                           |                                               |
| DSS. <a href="#">DISPC_VIDn_BAj</a> (j= 0,1)       | X                                           | X                                             |
| DSS. <a href="#">DISPC_VIDn_POSITION</a>           | X                                           | X                                             |
| DSS. <a href="#">DISPC_VIDn_SIZE</a>               | X                                           | X                                             |
| DSS. <a href="#">DISPC_VIDn_ATTRIBUTES</a>         | X                                           | X                                             |
| DSS. <a href="#">DISPC_VIDn_FIFO_THRESHOLD</a>     | X                                           | X                                             |
| DSS. <a href="#">DISPC_VIDn_ROW_INC</a>            | X                                           | X                                             |
| DSS. <a href="#">DISPC_VIDn_PIXEL_INC</a>          | X                                           | X                                             |
| DSS. <a href="#">DISPC_VIDn_FIR</a>                | X                                           | X                                             |
| DSS. <a href="#">DISPC_VIDn_PICTURE_SIZE</a>       | X                                           | X                                             |

<sup>(1)</sup> Some of the register bit fields are shadow bits. For more information, see [Section 7.7, Display Subsystem Register Manual](#).

**Table 7-49. Shadow Registers (continued)**

| Shadow Register Name                     | Updated on VFP Start Period<br>(LCD output) | Updated on External VSYNC<br>(Digital output) |
|------------------------------------------|---------------------------------------------|-----------------------------------------------|
| DSS.DISPC_VIDn_ACCUI (l = 0,1)           | X                                           | X                                             |
| DSS.DISPC_VIDn_FIR_COEF_Hi (i = 0 to 7)  | X                                           | X                                             |
| DSS.DISPC_VIDn_FIR_COEF_HVi (i = 0 to 7) | X                                           | X                                             |
| DSS.DISPC_VIDn_FIR_COEF_Vi (i = 0 to 7)  | X                                           | X                                             |
| DSS.DISPC_VIDn_CONV_COEFi (i = 0 to 4)   | X                                           | X                                             |
| DSS.DISPC_VIDn_PRELOAD                   | X                                           | X                                             |
| DSS.DISPC_DATA_CYCLEk (k = 0 to 3)       | X                                           |                                               |

### 7.5.3.1 Display Controller Configuration

The following registers define the display controller configuration:

- DSS.DISPC\_SYSCONFIG
- DSS.DISPC\_SYSSTATUS
- DSS.DISPC\_IRQSTATUS
- DSS.DISPC\_IRQENABLE

### 7.5.3.2 Graphics Layer Configuration

The graphics layer configuration is common to the LCD and the TV set.

#### 7.5.3.2.1 Graphics DMA Registers

The following registers define the graphics DMA engine configuration:

- DSS.DISPC\_CONTROL
- DSS.DISPC\_GFX\_BA<sub>j</sub>
- DSS.DISPC\_GFX\_ATTRIBUTES
- DSS.DISPC\_GFX\_ROW\_INC
- DSS.DISPC\_GFX\_PIXEL\_INC
- DSS.DISPC\_GFX\_FIFO\_THRESHOLD
- DSS.DISPC\_GFX\_TABLE\_BA

The following fields define the attributes of the graphics DMA engine:

- Graphics layer enable (DSS.DISPC\_GFX\_ATTRIBUTES[0] GFXENABLE bit): The default value of this bit at reset time is 0x0 (Disabled). The graphics DMA engine fetches encoded pixels from the system memory only when the graphics layer is enabled (a valid configuration is programmed for the graphics layer). The graphics window is present and the graphics pipeline is active.
- Burst size (DSS.DISPC\_GFX\_ATTRIBUTES[7:6] GFXBURTSIZE field): The default burst size at reset time is 4 x 32 bytes. The possible values are 4 x 32, 8 x 32, and 16 x 32 bytes. The burst size is initialized at boot time by the software and never changes as long as the display controller is enabled. This field indicates the maximum burst size for the specific pipeline. In case of misalignment, the DMA engine may issue single and/or smaller burst requests because the burst size must be aligned to the burst boundary.
- Preload configuration (DSS.DISPC\_GFX\_ATTRIBUTES[11] GFXFIFOPRELOAD bit): The default preload configuration uses the DSS.DISPC\_GFX\_PRELOAD register value (the reset value is 256 bytes) to define the number of bytes to be fetched from system memory into the display controller graphics FIFO. By programming the DSS.DISPC\_GFX\_ATTRIBUTES[11] GFXFIFOPRELOAD bit, software users select between preload register (with 256 bytes as the reset value) and the high threshold value for preload of the encoded pixels. For best performance, the configuration of thresholds is defined using the FIFO size (in bytes) minus 1 for the high threshold, and the FIFO size (in bytes) minus the burst size (in bytes) for the low threshold, which provides 960, 992, and 1008,

respectively, for burst sizes 16x32, 8x32, and 4x32. Note also that the preload value is defined based on the following display types:

- Active matrix (TFT) display: DSS.DISPC\_GFX\_PRELOAD[11:0] PRELOAD = 0x60 (value is 96)
- Color passive matrix (STN) display: DSS.DISPC\_GFX\_PRELOAD[11:0] PRELOAD = 0x72 (value is 114)
- Monochrome passive matrix (STN) display: DSS.DISPC\_GFX\_PRELOAD[11:0] PRELOAD = 0xE0 (value is 224)
- Base address of the graphics buffer in system memory (DSS.DISPC\_GFX\_BAj registers): The default value of these two registers at reset time is 0x0. The horizontal resolution is one pixel because the base address is aligned on a pixel size boundary. In case of 4 BPP, the resolution is two pixels; for 2 BPP, resolution is four pixels; for 1 BPP, resolution is eight pixels; and for RGB24 packed format, the resolution is four pixels. The vertical resolution is one line. The register DSS.DISPC\_GFX\_BA0 defines the base address of the even field; and DSS.DISPC\_GFX\_BA1 defines the base of the odd field in the case of an external synchronization and based on the value of the input signal DISPC\_FID and the polarity. To improve system throughput, the base address should be aligned on the burst size boundary.
- Graphics FIFO threshold (DSS.DISPC\_GFX\_FIFO\_THRESHOLD register): The low threshold (DSS.DISPC\_GFX\_FIFO\_THRESHOLD[11:0] GFXFIFOLOWTHRESHOLD) and the high threshold (DSS.DISPC\_GFX\_FIFO\_THRESHOLD[27:16] GFXFIFOHIGHTHRESHOLD) values define the FIFO DMA behavior. When the low level is reached, one or more requests are issued to the L3-based interconnect to fill up the FIFO to reach the high threshold. A request is issued as long as the FIFO has enough space available to accept a burst. The DMA engine then waits until the low level is reached to restart the requests. By setting the DSS.DISPC\_CONFIG[14] FIFOERGE bit to 1, users merge the three FIFOs (GFX, VID1, and VID2). In this case, the low threshold (the DSS.DISPC\_GFX\_FIFO\_THRESHOLD[11:0] GFXFIFOLOWTHRESHOLD bit field) and the high threshold (DSS.DISPC\_GFX\_FIFO\_THRESHOLD[27:16] GFXFIFOHIGHTHRESHOLD bit field) values must be programmed with a multiplier factor of three (3 x value). By default, the FIFOs are not merged (the DSS.DISPC\_CONFIG[14] FIFOERGE bit reset value is 0).
- Palette/gamma table used (DSS.DISPC\_CONFIG[3] PALETTEGAMMABLE bit): The bit indicates if the palette must be loaded before the graphics data for the following frame. The bit is set by software and reset by hardware.
- Base address of the palette/gamma table buffer in system memory (DSS.DISPC\_GFX\_TABLE\_BA register): The default value of this register at reset time is 0x0. The base address is aligned on a 32-bit address. Depending on the pixel size of graphics data (1, 2, 4, or 8 BPP), 16 (1, 2, or 4 BPP), or 256 (8 BPP) x 32-bit values are loaded from system memory into the internal table memory. To load the table when using the memory as a gamma table, the graphics pipeline is enabled and then disabled by the software when the palette loaded interrupt is generated. The overlay manager ignores the graphics pipe when the table is used as a gamma table.

---

**NOTE:** In case of RGB16 format and optimization enabled, the base address is aligned on a 32-bit boundary and the number of bytes to skip is a multiple of 4 bytes.

---

- Graphics Priority (DSS.DISPC\_GFX\_ATTRIBUTES[14] GFXARBITRATION): The default value at reset time is 0x0. It is used to change between normal priority (value of 0) to high priority (value of 1) to change priority for the graphics channel vs. video channels. It can be used to give higher priority to the pipelines with real time constraint vs. non real time pipelines. For that is, pipelines associated to the LCD output in RFBI mode should have lower priority than pipelines associated to TV output.
- Graphics Self-Refresh (DSS.DISPC\_GFX\_ATTRIBUTES[15] GFXSELFREFRESH): The default value at reset time is 0x0. It is used to use the DMA FIFO without accessing the interconnect for multiple frames. Once, the data have been loaded to the DMA FIFO for displaying the frame, they are used for the following frames.

The sequence to activate the self-refresh is the following:

- Frame t: The bit field should be set at anytime during frame
- Frame t+1: Fetch of the data in the DMA FIFO and display of the frame
- Frame t+2: No access to the L3 interconnect, DMA FIFO uses to provide the pixels

The sequence to deactivate the self-refresh is the following:

- Frame t: No access to the L3 interconnect, DMA FIFO uses to provide the pixels, bit field can be changed at any time during the frame
- Frame t+1: Fetch of the data from system memory using the L3 interconnect

### 7.5.3.2.2 Graphics Layer Configuration Registers

The following registers define the graphics layer configuration:

- DSS.[DISPC\\_CONFIG](#)
- DSS.[DISPC\\_GFX\\_POSITION](#)
- DSS.[DISPC\\_GFX\\_SIZE](#)
- DSS.[DISPC\\_GFX\\_ATTRIBUTES](#)

The graphics layer is enabled/disabled by setting/resetting the DSS.[DISPC\\_GFX\\_ATTRIBUTES](#)[0] GFXENABLE bit. When the graphics layer is disabled, the graphics window does not exist on the screen and the graphics pipeline and DMA are inactive.

Set a valid configuration before enabling the graphics layer. After a register change, either the DSS.[DISPC\\_CONTROL](#)[6] GODIGITAL or DSS.[DISPC\\_CONTROL](#)[5] GOLCD bit must be set. The software must wait for the hardware to reset the bit before setting it. The software reset is not recommended because the application cannot ensure that the bit is reset before the hardware reset.

### 7.5.3.2.3 Graphics Window Attributes

The following fields define the attributes of the graphics window:

- Graphics format (DSS.[DISPC\\_GFX\\_ATTRIBUTES](#)[4:1] GFXFORMAT bit field): The default value of this bit field at reset time is 0x0 (BITMAP 1-BPP). The graphics format can be either: BITMAP1, BITMAP2, BITMAP4, or BITMAP8 (CLUT) or RGB12, RGB16, or RGB24 (true-color formats).
- Graphics window X-position (DSS.[DISPC\\_GFX\\_POSITION](#)[10:0] GFXPOSX bit field): The default value at reset time is 0x0. The window X-position is from 0 to 2047 columns. All integer values in the range [0:2047] are allowed.
- Graphics window Y-position (DSS.[DISPC\\_GFX\\_POSITION](#)[26:16] GFXPOSY bit field): The default value of this bit field at reset time is 0x0. The window Y-position is from 0 to 2047 rows. All integer values in the range [0:2047] are allowed.
- Graphics window width (DSS.[DISPC\\_GFX\\_SIZE](#)[10:0] GFXSIZEX bit field): The default value at reset time is 0x0 (1 pixel). The window width is from 1 to 2048 pixels. All integer values in the range [1:2048] are allowed for the following formats: 8 BPP, RGB12, RGB16, and RGB24. The width must be a multiple of eight pixels for 1 BPP, four pixels for 2 BPP, and two pixels for 4 BPP. The maximum bandwidth efficiency for accessing the pixels in system memory is reached when the width of the graphics window (in bytes) is a multiple of the graphics burst size defined in the DSS.[DISPC\\_GFX\\_ATTRIBUTES](#)[7:6] GFXBURSTSIZE bit field (in bytes).

**NOTE:** When the RGB24 packed format is selected, the width must be a multiple of 12 bytes when the DSS.[DISPC\\_GFX\\_ROW\\_INC](#) register is not 1. When DSS.[DISPC\\_GFX\\_ROW\\_INC](#) register is 1, the width can be any size from 1 to 2048 pixels.

The entire pixels of the graphics window must be inside the LCD screen. Depending on the width of the buffer to be displayed in the graphics layer and the position, the width should be adjusted by software to limit the right edge of the window inside the screen.

- Graphics window height (DSS.[DISPC\\_GFX\\_SIZE](#)[26:16] GFXSIZEY bit field): The default value at reset time is 0x0 (1 pixel). The window height is from 1 to 2048 pixels. All integer values in the range [1:2048] are allowed. The entire pixels of the graphics window must be inside the LCD screen. Depending on the height of the buffer to be displayed in the graphics layer and the position, the height should be adjusted by software to limit the bottom edge of the window inside the screen
- Graphics data endianness (DSS.[DISPC\\_GFX\\_ATTRIBUTES](#)[10] GFXENDIANNESS bit): This bit indicates the endianness (little or big) of the graphics pixels. The default value at reset time is 0x0 (little endian).
- Graphics data nibble mode (DSS.[DISPC\\_GFX\\_ATTRIBUTES](#)[9] GFXNIBBLEMODE bit): This bit

indicates the nibble mode of the graphics pixels. The default value at reset time is 0x0 (Disable).

- Graphics replication logic enable (DSS.[DISPC\\_GFX\\_ATTRIBUTES](#)[5] GFXREPLICATIONENABLE bit): The default value at reset time is 0x0 (Disable). The encoded pixel data in RGB format (RGB16) can be extended to 24-bit format with or without replication of the MSB part to fill up the LSB due to the 24-bit left alignment. If the replication logic is turned off, the LSB part is filled up with 0s.
- Graphics window skip enable (DSS.[DISPC\\_CONTROL](#)[12] OVERLAYOPTIMIZATION bit): By setting/resetting the bit, the overlay optimization is enabled or disabled. Before enabling the overlay optimization, the DSS.[DISPC\\_GFX\\_WINDOW\\_SKIP](#)[31:0] GFXWINDOWSKIP bit field must be set according to the video1 and graphics windows overlap. The default value at reset time is 0x0 (Disable). When video1 is not present, the DSS.[DISPC\\_GFX\\_WINDOW\\_SKIP](#)[31:0] GFXWINDOWSKIP bit field should be reset. When the color key is used, the DSS.[DISPC\\_GFX\\_WINDOW\\_SKIP](#)[31:0] GFXWINDOWSKIP bit field should be reset.
- Graphics window skip (DSS.[DISPC\\_GFX\\_WINDOW\\_SKIP](#)[31:0] GFXWINDOWSKIP bit field): The bit field represents the number of bytes to skip while fetching the graphics-encoded pixels when reaching the beginning of the video window. The optimization allows fetching only the visible graphics pixels. The color key cannot be selected because the graphics pixels under the video window are not present. The default value at reset time is 0x0 (0 byte).

[Figure 7-116](#) through [Figure 7-119](#) give examples of how to program the GFXWINDOWSKIP field for overlay optimization:

**Figure 7-116. Overlay Optimization: Case 1**



dss-090

**Figure 7-117. Overlay Optimization: Case 2**


dss-091

**Figure 7-118. Overlay Optimization: Case 3**


dss-092

**Figure 7-119. Overlay Optimization: Case 4**

camdss-093

### 7.5.3.3 Video Layer Configuration

The video layer configuration is common to the LCD and the TV set.

#### 7.5.3.3.1 Video DMA Registers

The following registers define the video DMA engine configuration:

- DSS.[DISPC\\_CONTROL](#)
- DSS.[DISPC\\_VIDn\\_BAj](#)
- DSS.[DISPC\\_VIDn\\_ATTRIBUTES](#)
- DSS.[DISPC\\_VIDn\\_ROW\\_INC](#)
- DSS.[DISPC\\_VIDn\\_PIXEL\\_INC](#)
- DSS.[DISPC\\_VIDn\\_FIFO\\_THRESHOLD](#)
- DSS.[DISPC\\_VIDn\\_PICTURE\\_SIZE](#)

The following fields define the attributes of the graphics DMA engine:

- Video layer enable (DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[0\]](#) VIDENABLE bit): The default value of this bit at reset time is 0x0 (Disabled). The video DMA engine fetches encoded pixels from the system memory only when the video layer is enabled (a valid configuration is programmed for the video layer). The video window is present and the video pipeline is active.
- Burst size (DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[15:14\]](#) VIDBURSTSIZEx bit field): The default burst size at reset time is 4 x 32 bytes. The possible values are 4 x 32, 8 x 32, and 16 x 32 bytes. The burst size is initialized at boot time by the software and never changes as long as the display controller is enabled. This bit field indicates the maximum burst size for the specific pipeline. In case of misalignment, the DMA engine may issue single and/or smaller burst requests, because the burst size must be aligned to the burst boundary.
- Preload configuration (DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[19\]](#) VIDFIFOPRELOAD bit): The default preload configuration uses the DSS.[DISPC\\_VIDn\\_PRELOAD](#) register value (the reset value is 256 bytes) to define the number of bytes to be fetched from system memory into the display controller graphics FIFO. By programming the DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[19\]](#) VIDFIFOPRELOAD bit, software users select between preload register (with 256 bytes as the reset value) and the high threshold value for preload of the encoded pixels. For best performance, the configuration of thresholds is defined using the FIFO size (in bytes) minus 1 for the high threshold, and the FIFO size (in bytes) minus the burst size (in bytes) for the low threshold, which provides 960, 992, and 1008, respectively, for burst sizes 16x32, 8x32, and 4x32. Note also that the preload value is defined based on the following display types:
  - Active matrix (TFT) display: DSS.[DISPC\\_VIDn\\_PRELOAD\[11:0\]](#) PRELOAD = 0xB0 (value is 176)
  - Color passive matrix (STN) display: DSS.[DISPC\\_VIDn\\_PRELOAD\[11:0\]](#) PRELOAD = 0x110 (value is 272)
  - Monochrome passive matrix (STN) display: DSS.[DISPC\\_VIDn\\_PRELOAD\[11:0\]](#) PRELOAD = 0x1B0 (value is 432)

- Base address of the video buffer in system memory (DSS.[DISPC\\_VIDn\\_BAj](#) registers): The default value at reset time is 0x0. The horizontal resolution is one pixel because the base address is aligned on pixel size boundary. In case of YCbCr 4:2:2 formats, the resolution is 2 pixels. In case of RGB24 packed format, the resolution is 4 pixels. The vertical resolution is one line. The register DSS.[DISPC\\_VIDn\\_BA0](#) defines the base address of the even field, and DSS.[DISPC\\_VIDn\\_BA1](#) defines the base of the odd field in the case of an external synchronization and based on the value of the input signal [DISPC\\_FID](#) and the polarity. To improve system throughput, the base address should be aligned on the burst size boundary.
- Video FIFO threshold (DSS.[DISPC\\_VIDn\\_FIFO\\_THRESHOLD](#) register): The low threshold (DSS.[DISPC\\_VIDn\\_FIFO\\_THRESHOLD\[11:0\]](#) VIDFIFOLOWTHRESHOLD) and the high threshold (DSS.[DISPC\\_VIDn\\_FIFO\\_THRESHOLD\[27:16\]](#) VIDFIFOHIGHTHRESHOLD) values define the FIFO DMA behavior. When the low level is reached, one or more requests are issued to the L3-based interconnect to fill up the FIFO to reach the high threshold. A request is issued as long as the FIFO has enough space available to accept a burst. The DMA engine then waits until the low level is reached to restart the requests. By setting the DSS.[DISPC\\_CONFIG\[14\]](#) FIFOMERGE bit to 1, users merge the three FIFOs (GFX, VID1, and VID2). In this case, the low threshold (the DSS.[DISPC\\_VIDn\\_FIFO\\_THRESHOLD\[11:0\]](#) VIDFIFOLOWTHRESHOLD bit field with n corresponding to the active video channel 1 or 2) and the high threshold (DSS.[DISPC\\_VIDn\\_FIFO\\_THRESHOLD\[27:16\]](#) VIDFIFOHIGHTHRESHOLD bit field with n corresponding to the active video channel 1 or 2) values must be programmed with a multiplier factor of three (3 x value). By default, the FIFOs are not merged (the DSS.[DISPC\\_CONFIG\[14\]](#) FIFOMERGE bit reset value is 0).
- Video buffer width (DSS.[DISPC\\_VIDn\\_PICTURE\\_SIZE\[10:0\]](#) VIDORGSIZEX): The default value at reset time is 0x0 (1 pixel). The buffer width in system memory is from 1 up to 2048 pixels. All the integer values in the range [1:2048] are allowed. Software users must program this bit field to the value minus 1.
- Video buffer height (DSS.[DISPC\\_VIDn\\_PICTURE\\_SIZE\[26:16\]](#) VIDORGSIZEY): The default value at reset time is 0x0 (1 pixel). The buffer height in system memory is from 1 up to 2048 pixels. All the integer values in the range [1:2048] are allowed. Software users must program this field to the value minus 1.
- Video data endianness (DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[17\]](#) VIDENDIANNESS bit, with n=1 or 2): This bit indicates the endianness (little or big) of the video pixels. The default value at reset time is 0x0 (little endian).

#### **7.5.3.3.2 Video Configuration Register**

The following shadow registers define video layer n (with n = 1 or 2) configuration:

- DSS.[DISPC\\_CONFIG](#)
- DSS.[DISPC\\_VIDn\\_POSITION](#)
- DSS.[DISPC\\_VIDn\\_SIZE](#)
- DSS.[DISPC\\_VIDn\\_ATTRIBUTES](#)
- DSS.[DISPC\\_VIDn\\_FIR](#)
- DSS.[DISPC\\_VIDn\\_PICTURE\\_SIZE](#)
- DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_Hi](#) (with i = 0 to 7)
- DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_HVi](#) (with i = 0 to 7)
- DSS.[DISPC\\_VIDn\\_CONV\\_COEFi](#) (with i = 0 to 4)
- The video layer n (with n = 1 or 2) is enabled/disabled by setting/resetting the DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[0\]](#) VIDENABLE field. If the video layer is disabled, the video window does not exist on the screen and the whole video pipeline and DMA are inactive. Before enabling the video layer, a valid configuration must be set. After a register change, either the DSS.[DISPC\\_CONTROL\[6\]](#) GODIGITAL or DSS.[DISPC\\_CONTROL\[5\]](#) GOLCD bit must be set. The software must wait for the hardware to reset the bit before setting this bit. The software reset is not recommended because the application cannot ensure that the bit is reset before the hardware reset.

### 7.5.3.3.3 Video Window Attributes

The following fields define the attributes of video window n:

- Video format (DSS.DISPC\_VIDn\_ATTRIBUTES[4:1] VIDFORMAT bit field, with n = 1 or 2): The default value at reset time is 0x0 (BITMAP 1 BPP, non-supported format by the video pipeline). The video format can be RGB16, RGB24, YUV2 4:2:2 co-DSS sited, and UYVY 4:2:2 co-sited.
- Video window X-position (DSS.DISPC\_VIDn\_POSITION[10:0] VIDPOSX bit field, with n = 1 or 2): The default value at reset time is 0x0 (first column starting on the left edge of the screen). The window X-position is from 0 to 2047 columns. All integer values in the range [0:2047] are allowed.
- Video window Y-position (DSS.DISPC\_VIDn\_POSITION[26:16] VIDPOSY bit field, with n = 1 or 2): The default value at reset time is 0x0 (first row starting at the top of the screen). The window Y-position is from 0 to 2047 rows. All integer values in the range [0:2047] are allowed.
- Video window width (DSS.DISPC\_VIDn\_SIZE[10:0] VIDSIZEX bit field, with n = 1 or 2): The default value at reset time is 0x0 (1 pixel). The window width is from 1 to 2048 pixels. All integer values in the range [1:2048] are allowed. The maximum bandwidth efficiency for accessing the pixels in system memory is reached when the width (in bytes) of the video window is a multiple of the video burst size defined in the DSS.DISPC\_VIDn\_ATTRIBUTES[15:14] VIDBURSTSIZEx bit field (in bytes).

---

**NOTE:** When the RGB24 packed format is selected, the width must be a multiple of 12 bytes when the DSS.DISPC\_VIDn\_ROW\_INC register is not 1. When the DSS.DISPC\_VIDn\_ROW\_INC register is 1, the width can be any size from 1 to 2048 pixels.

The entire pixels of the video window must be inside the LCD screen. Depending on the width of the buffer to be displayed in the video layer and the position, the width should be adjusted by software to limit the right edge of the window inside the screen.

- Video window height (DSS.DISPC\_VIDn\_SIZE[26:16] VIDSIZEY bit field, with n = 1 or 2): The default value at reset time is 0x0 (1 pixel). The window height is from 1 to 2048 pixels. All integer values in the range [1:2048] are allowed. The entire pixels of the video window must be inside the LCD screen. Depending on the height of the buffer to be displayed in the video layer and the position, the height should be adjusted by software to limit the bottom edge of the window inside the screen.
- Video picture width in system memory (DSS.DISPC\_VIDn\_PICTURE\_SIZE[10:0] VIDORGSIZEX bit field, with n = 1 or 2): The default value at reset time is 0x0 (1 pixel). The window width is from 1 to 2048 pixels. All integer values in the range [1:2048] are allowed with RGB16 and RGB24 video data. For YUV2 4:2:2 and UYVY 4:2:2 formats, the width must be a multiple of two pixels. The maximum bandwidth efficiency for accessing the pixels in system memory is reached when the width (in bytes) of the video picture is a multiple of the video burst size defined in the DSS.DISPC\_VIDn\_ATTRIBUTES[15:14] VIDBURSTSIZEx bit field (in bytes).
- Video picture height in system memory (the DSS.DISPC\_VIDn\_PICTURE\_SIZE[26:16] VIDORGSIZEY bit field, with n = 1 or 2): The default value at reset time is 0x0 (1 pixel). The window width is from 1 to 2048 pixels. All integer values in the range [1:2048] are allowed.
- Video Priority (DSS.DISPC\_VIDn\_ATTRIBUTES[23] VIDARBITRATION): The default value at reset time is 0x0. It is used to change between normal priority (value of 0) to high priority (value of 1) to change priority for the video channel vs. other channels. It can be used to give higher priority to the pipelines with real time constraint vs. non real time pipelines. For that is, pipelines associated to the LCD output in RFBI mode should have lower priority than pipelines associated to TV output.
- Video Self-Refresh (DSS.DISPC\_VIDn\_ATTRIBUTES[24] VIDSELFREFRESH): The default value at reset time is 0x0. It is used to use the DMA FIFO without accessing the interconnect for multiple frames. Once, the data have been loaded to the DMA FIFO for displaying the frame, they are used for the following frames.

The sequence to activate the self-refresh is the following:

- Frame t: The bit field should be set at anytime during frame
  - Frame t+1: Fetch of the data in the DMA FIFO and display of the frame
  - Frame t+2: No access to the L3 interconnect, DMA FIFO uses to provide the pixels
- The sequence to deactivate the self-refresh is the following:
- Frame t: No access to the L3 interconnect, DMA FIFO uses to provide the pixels, bit field can be changed at any time during the frame

- Frame t+1: Fetch of the data from system memory using the L3 interconnect

#### **7.5.3.3.4 Video Up-/Down-Sampling Configuration**

The video horizontal up/downsampling block for video pipeline n (with n = 1 or 2) is enabled/disabled by setting/resetting the DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[5\]](#) VIDRESIZEENABLE bit.

The video vertical up/downsampling block for video pipeline n is enabled/disabled by setting/resetting the DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[6\]](#) VIDRESIZEENABLE bit.

Set a valid configuration before enabling the video up/downsampling block.

---

**NOTE:** Vertical and horizontal downsampling are limited to a 1/4 resize factor.

---

After a register change, either the DSS.[DISPC\\_CONTROL\[6\]](#) GODIGITAL or DSS.[DISPC\\_CONTROL\[5\]](#) GOLCD bit must be set. The software must wait until the hardware resets this bit before setting it. The software reset is not recommended because the application cannot ensure that the bit is reset before the hardware reset.

The following fields define the configuration of the video up/downsampling block for video pipeline n:

- Vertical up/downsampling increment value (DSS.[DISPC\\_VIDn\\_FIR\[27:16\]](#) VIDFIRVINC bit field, with n = 1 or 2): The unsigned integer value range is [1:4096]. The software calculates the value using the following equation:

$$\text{VIDFIRVINC}[12:0] = 1024 \times \left( \frac{\text{VIDORGSIZEY}[10:0]}{\text{VIDSIZEY}[10:0]} \right)$$

dss-E093

(10)

---

**NOTE:**

- If the VIDFIRVINC[11:0] bit field value is greater than 4096, it is clipped to 4096. If VIDSIZEY[10:0] equals 0x1, VIDSIZEY[10:0] is replaced by 0x2 in the previous equation.
- The VIDORGSIZEY[10:0] and VIDSIZEY[10:0] bit field values must be programmed with the value desired minus 1.
- Horizontal up/downsampling increment value (DSS.[DISPC\\_VIDn\\_FIR\[11:0\]](#) VIDFIRHINC bit field, with n = 1 or 2): The unsigned integer value range is [1:4096]. The software calculates the value using the following equation:

$$\text{VIDFIRHINC}[12:0] = 1024 \times \left( \frac{\text{VIDORGSIZEX}[10:0]}{\text{VIDSIZEX}[10:0]} \right)$$

dss-E094

(11)

---

**NOTE:**

- If the VIDFIRHINC[11:0] bit field value is greater than 4096, it is clipped to 4096. If VIDSIZEX[10:0] equals 1, VIDSIZEX[10:0] is replaced by 2 in the previous equation.
- The VIDORGSIZEX[10:0] and VIDSIZEX[10:0] bit field values must be programmed with the value desired minus 1.
- Vertical up/downsampling accumulator value (DSS.[DISPC\\_VIDn\\_ACCUI\[25:16\]](#) VIDVERTICALACCU bit field): The unsigned integer value range is [0:1023]. The accumulator value indicates in which phase the vertical filtering starts. The value 0 indicates that 0 is the first phase used by the hardware to generate the first data (see [Table 7-50](#)).
- Vertical up/downsampling line buffer configuration (DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[22\]](#) VIDLINEBUFFERSPLIT bit): The default value at reset time is 0x0 (line buffers are not split). The backward compatibility is maintained versus OMAP2420 and OMAP2430 devices. When the bit field is set, each line buffer is split into two line buffers to be able to use six line buffers instead of three.
- Vertical up/downsampling line buffer configuration (DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[21\]](#) VIDVERTICALTAPS bit): The default value at reset time is 0x0 (3-tap configuration is used). If the bit field is reset, the 3-tap configuration is used. The backward compatibility is maintained versus

OMAP2420 and OMAP2430 devices. When the bit field is set, the 5-tap configuration is used and the DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[22\]](#) VIDLINEBUFFERSPLIT bit must be set to 1.

- Vertical up/downsampling line buffer configuration (DSS.[DISPC\\_VIDn\\_ATTRIBUTES\[20\]](#) VIDDMAOPTIMIZATION bit): The default value at reset time is 0x0 (no optimization). If the bit is set, the DMA engine fetches two pixels for each 32-bit OCP request (RGB16 and YUV4:2:2) while doing 90- and 270-degree rotation. If the bit is clear, the DMA engine fetches one pixel for each 32-bit OCP request (RGB16 and YUV4:2:2) while doing 90- and 270-degree rotation. The width and height of picture should be even to use the optimization. Even width is required for the input picture when the 5-tap configuration is used.

**NOTE:** If the 5-tap resizer is used for RGB16 and YUV4:2:2 picture formats, the width of the input picture must be a multiple of 2 pixels and more than 5 pixels. This leads to the following register configuration:

[DISPC\\_VIDn\\_ATTRIBUTES\[21\]](#) VIDVERTICALTAPS == 1

[DISPC\\_VIDn\\_PICTURE\\_SIZE\[10:0\]](#) VIDORGSIZEX 4 and even

For more information about the configuration of video DMA optimization, see [Section 7.5.3.4.5, Video DMA Optimization](#).

- Horizontal up/downsampling accumulator value (DSS.[DISPC\\_VIDn\\_ACCU\[9:0\]](#) VIDHORIZONTALACCU bit field): The unsigned integer value range is [0:1023]. The accumulator value indicates in which phase the horizontal filtering starts. The value 0 indicates that 0 is the first phase used by the hardware to generate the first data (see [Table 7-50](#)).

**Table 7-50. Vertical/Horizontal Accumulator Phase**

| Accumulator Value | Phases f |
|-------------------|----------|
| 0                 | 0        |
| 128               | 1        |
| 256               | 2        |
| 384               | 3        |
| 512               | 4        |
| 640               | 5        |
| 768               | 6        |
| 896               | 7        |

- Vertical up/downsampling coefficients (DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_HVi](#) registers, with n = 1 or 2, i = 0 to 7): The 3-tap vertical up/downsampling coefficients are defined in these registers. There are eight registers for the eight phases with three coefficients for each, or a total of 24 programmable coefficients for the vertical up/downsampling block. Each register contains two 8-bit signed coefficients and one 8-bit unsigned coefficient (the central one).

In addition, there are 2-tap vertical up/downsampling coefficients defined in DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_Vi](#) registers. There are 8 registers for the 8 phases with 2 coefficients for each of them so a total of 16 programmable coefficients for the vertical up/downsampling block used in addition of the 3-tap registers defined above. Each register contains two 8-bit signed coefficients. In case of 5-tap configuration, both sets of registers DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_HVi](#) and DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_Vi](#) are used. In case of 3-tap configuration, only one set of registers DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_HVi](#) is used.

- Horizontal up/downsampling coefficients (DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_Hi](#) and [DISPC\\_VIDn\\_FIR\\_COEF\\_HVi](#) registers, with n = 1 or 2, i = 0 to 7): The DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_Hi](#) register and the DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_HVi](#) register define the 5-tap horizontal up/downsampling coefficients. There are eight registers for the eight phases with five coefficients for each register, or a total of 40 programmable coefficients for the horizontal up/downsampling block.

Each DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_Hi](#) register contains three 8-bit signed coefficients and one 8-bit unsigned coefficient (the central one). Each DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_HVi](#) register contains one 8-bit signed coefficient.

The programmable coefficient for the FIR up/downsampling method must be adjusted based on application needs. For more details on scaling programming settings, see [Section 7.6.1](#).

#### **7.5.3.3.5 Video Color Space Conversion Configuration**

The DSS.DISPC\_VIDn\_CONV\_COEFi registers (with i = 0 to 4) has nine 11-bit coefficients defined for the programmable color space conversion block for video pipeline n (with n = 1 or 2).

The standard register coefficients are:

##### **YCbCr-to-RGB Registers (VidFullRange=0)**

$$\begin{bmatrix} R \\ G \\ B \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} RY & RCr & RCb \\ GY & GCr & GCb \\ BY & BCr & BCb \end{bmatrix} * \begin{bmatrix} Y - 16 \\ Cr - 128 \\ Cb - 128 \end{bmatrix}$$

dssE095 (12)

##### **YCbCr to RGB Registers (VidFullRange=1)**

$$\begin{bmatrix} R \\ G \\ B \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} RY & RCr & RCb \\ GY & GCr & GCb \\ BY & BCr & BCb \end{bmatrix} * \begin{bmatrix} Y \\ Cr - 128 \\ Cb - 128 \end{bmatrix}$$

dss-E096 (13)

[Table 7-51](#) lists the color space conversion register values.

**Table 7-51. Color Space Conversion Register Values**

| Coefficients | BT.601-5 | BT.601-5<br>Range [0:255] | BT.709 | BT.709 Range<br>[0:255] |
|--------------|----------|---------------------------|--------|-------------------------|
| RY           | 298      | 256                       | 298    | 256                     |
| RCr          | 409      | 351                       | 459    | 394                     |
| RCb          | 0        | 0                         | 0      | 0                       |
| GY           | 298      | 256                       | 298    | 256                     |
| GCr          | -208     | -179                      | -137   | -118                    |
| GCb          | -100     | -86                       | -55    | -47                     |
| BY           | 298      | 256                       | 298    | 256                     |
| BCr          | 0        | 0                         | 0      | 0                       |
| BCb          | 517      | 443                       | 541    | 465                     |
| VidFullRange | 0        | 1                         | 0      | 1                       |

#### **7.5.3.4 Rotation/Mirroring Display Subsystem Settings**

This section describes rotation/mirroring settings. The device provides flexible mechanisms for an efficient implementation of rotation using the display-subsystem, its DMA engine, and the rotation engine of the SMS module. Depending on whether the image data is located in on-chip SRAM or external SDRAM, either a DMA rotation or a VRFB rotation is used. When configuring the rotation, the image data format (RGB or YUV) must also be taken into account. The video pipelines also perform the interpolation of YUV image data and the color conversion from YUV into RGB format for displaying the images on an LCD screen.

#### 7.5.3.4.1 Image Data Formats

To understand the programming of the rotation mechanisms described underneath, the supported representations of the image data in memory must also be considered. Differences exist between the supported formats on the graphics and video pipelines. The graphics pipeline supports RGB and RGB with a color look-up table (CLUT), whereas the video pipelines support two versions of YUV 4:2:2 and RGB16. In the case of YUV, the interpolation and color conversion hardware in the video pipelines converts the image data to the RGB format suitable for the LCD screen.

The graphics pipeline supports:

- 1-, 2-, .4-, and 8-bits-per-pixel color look-up table
- 12-, 16-, and 24-bits-per-pixel RGB

The video pipelines support the following data formats (always 2 bytes/pixel):

- RGB16
- YUV2
- UYVY

For more information on the graphics data formats, please refer to [Section 7.4.2.2, Graphics Pipeline](#).

For more information on the video data formats, please refer to [Section 7.4.2.3, Video Pipeline](#).

In the video pipeline, the YUV 4:2:2 format is converted into a full YUV 4:4:4 format by interpolation of the chrominance values from neighboring pixels. After this interpolation is completed, the conversion to the RGB format (suitable for displaying the image on the LCD screen) is performed.

For more information on YUV 4:2:2 to RGB conversion, please refer to [Section 7.4.2.3.2, Color Space Conversion](#).

#### 7.5.3.4.2 Image Data from On-Chip SRAM

For image data located in the on-chip SRAM, the DSS DMA is used to perform 90-degree, 180-degree, and 270-degree rotation. This is done by using the double-indexed addressing mode of the DMA. This addressing mode allows a pixel and a row increment to be specified. These address increments are used after each pixel or each row (line), respectively. [Figure 7-120](#) illustrates the principle steps for a 90-degree rotation.

**Figure 7-120. 90° DMA Rotation Example**



dss-097

**Table 7-52. 90-degree DMA Rotation Example Description**

| Parameter | Description                   | Additional parameters for formulas |
|-----------|-------------------------------|------------------------------------|
| ba        | Buffer Base Address in Memory |                                    |
| IW        | Image Width in pixels         | iw = IW-1                          |
| IH        | Image Height in pixels        | ih = IH-1                          |
| ps        | Pixel Size (in bytes)         |                                    |

Figure 7-120 shows how the image is stored in memory and how it is read out to achieve a 90-degree rotated orientation. The first pixel for the 0-degree orientation is located at the buffer base address (ba). If the image is to be shown on an LCD screen with a 90-degree rotation, the readout starts at the 90-degree base address (1). To proceed from one pixel to the next in the same line in the rotated orientation, the pixel increment (2) must be applied. At the end of each line of the rotated view, the row increment (3) is the offset to advance to the beginning of the next line in the memory buffer.

Hence, by setting the three DMA parameters (base address, pixel increment, and row increment), a 90-degree rotation can be achieved, as can 180-degree and 270-degree rotation. Each of the parameters can also be combined with an optional mirroring on the vertical axis.

Following there is a description the setup required to perform the rotation via the DSS DMA. This rotation mechanism is used when the image data is stored in internal SRAM.

#### 7.5.3.4.2.1 Rotation/Mirroring Registers

To set up the rotation and/or mirroring, the following registers must be programmed:

- Graphics pipeline (GFX):
  - DSS.[DISPC\\_GFX\\_BAj](#)
  - DSS.[DISPC\\_GFX\\_PIXEL\\_INC](#)
  - DSS.[DISPC\\_GFX\\_ROW\\_INC](#)
  - DSS.[DISPC\\_GFX\\_ATTRIBUTES](#)
  - DSS.[DISPC\\_GFX\\_POSITION](#)
  - DSS.[DISPC\\_GFX\\_SIZE](#)
  - DSS.[DISPC\\_GFX\\_FIFO\\_THRESHOLD](#)
- Video pipelines (VID) 1 and 2:
  - DSS.[DISPC\\_VIDn\\_BAj](#)
  - DSS.[DISPC\\_VIDn\\_PIXEL\\_INC](#)
  - DSS.[DISPC\\_VIDn\\_ROW\\_INC](#)
  - DSS.[DISPC\\_VIDn\\_ATTRIBUTES](#)
  - DSS.[DISPC\\_VIDn\\_POSITION](#)
  - DSS.[DISPC\\_VIDn\\_SIZE](#)
  - DSS.[DISPC\\_VIDn\\_CONV\\_COEF0](#) to DSS.[DISPC\\_VIDn\\_CONV\\_COEF4](#)
  - DSS.[DISPC\\_VIDn\\_FIFO\\_THRESHOLD](#)
- DSS.DISPC\_xxx\_BAj: These registers contain the base address of the image data at which the DSS DMA transfer of the image starts. The register values depend on the rotation chosen (see [Table 7-53](#) for the formulas). When using the LCD interface, the registers DISPC\_xxx\_BA0 are used. The registers DISPC\_xxx\_BA1 are only used for the TV output.
- DSS.DISPC\_xxx\_PIXEL\_INC[15:0]: This bit field contains the DMA addressing increment after each pixel. This bit field is used to perform the DSS DMA rotation (see [Table 7-53](#) for the formula).

---

**NOTE:** When the RGB24 packet format is selected, the only valid value is 1.

---

- DSS.DISPC\_xxx\_ROW\_INC[31:0]: This bit field contains the DMA addressing increment after each row (line) of pixels. This bit field is used to perform the DSS DMA rotation (see [Table 7-53](#) for the formula).

---

**NOTE:** When the RGB24 packet format is selected, the valid values are 1 and any value multiples of 12 bytes (4x32 bit). When the value is a multiple of 12 bytes, the width must be a multiple of 12 bytes. When the value is 1, the width can be any size from 1 to 2048 pixels.

---

- DSS.DISPC\_xxx\_ATTRIBUTES: These registers contain the main settings for the pipeline, such as the image data format, the rotation value, and the enable bit for the pipeline. The bit fields of these registers play a role in the rotation and in the image data format setup.
  - The following bit fields are used by the graphics pipeline to set up the image format:
    - GFXENABLE: Set this field to activate the hardware path in use.
    - GFXFORMAT: Use this field to specify the format of the graphic frame.
    - GFXROTATION: Set this field to the value corresponding to the rotation angle desired only if the frame contains RGB24 pixel data; otherwise, set it to 0x0 regardless of the degree of rotation.
    - GFXREPLICATIONENABLE: Use this bit to determine whether the encoded pixel data in RGB formats (RGB12 and RGB16) is extended to 24-bit format with or without replication of the MSB to fill the LSBs of each color component. If the replication logic is turned off, the LSB parts are filled with 0s. It is recommended to always enable this feature.
    - GFXCHANNELOUT: Set this field based on whether the frame is to be rendered on the LCD or on the TV set.
  - The following bit fields for the two video pipelines:
    - VIDENABLE: Set this field to activate the hardware path in use.
    - VIDFORMAT: Use this field to specify the format of the video frame (RGB16 or YUV4:2:2).
    - VIDCOLORCONVENABLE: If the video is in YUV4:2:2 format, set this field to enabled.
    - VIDROTATION: Set this field to the value corresponding to the rotation angle desired only if the frame contains non-RGB pixel data; otherwise, set it to 0x0 regardless of the degree of rotation. See [Section 7.5.3.4.4](#) for more information.
    - VIDROWREPEATENABLE: Set this field to enabled only if the frame contains YUV pixel data and the rotation is 90-degree or 270-degree so that the row pixel data are fetched twice to extract both Y components. See [Section 7.5.3.4.4](#) for more information.
    - VIDCHANNELOUT: Set this field based on whether the frame is to be rendered on the LCD or on the TV set.
  - DSS.DISPC\_xxx\_POSITION: Use this register to configure the position of the window.
  - DSS.DISPC\_xxx\_SIZE: Use this register to configure the size of the window.
  - DSS.[DISPC\\_VIDn\\_CONV\\_COEF0](#), DSS.[DISPC\\_VIDn\\_CONV\\_COEF1](#),  
DSS.[DISPC\\_VIDn\\_CONV\\_COEF2](#), DSS.[DISPC\\_VIDn\\_CONV\\_COEF3](#), and  
DSS.[DISPC\\_VIDn\\_CONV\\_COEF4](#): These registers contain the conversion coefficients required for YUV-to-RGB color conversion.
  - DSS.DISPC\_xxx\_FIFO\_THRESHOLD: Set the low threshold (DSS.[DISPC\\_GFX\\_FIFO\\_THRESHOLD](#)[11:0] GFXFIFOLOWTHRESHOLD) and the high threshold (DSS.[DISPC\\_GFX\\_FIFO\\_THRESHOLD](#)[27:16] GFXFIFOHIGHTHRESHOLD) values to define the FIFO DMA behavior. When the low level is reached, one or more requests are issued to the L3-based interconnect to fill up the FIFO to reach the high threshold. The DMA engine then waits until the low level is reached to restart the requests.

#### 7.5.3.4.2.2 DMA Register Settings

To configure the display controller for rotation and/or mirroring, use the following settings:

**Figure 7-121. Rotation/Mirroring Settings**


**NOTE:** These registers are shadow registers. To take into account the new values, software users must set the DSS.[DISPC\\_CONTROL](#)[5] GOLCD bit to 1.

[Table 7-53](#) details the base address, the row and pixel increment values to access the buffer in memory (contiguous pixels) except for the RGB24 packet format. [Table 7-54](#) lists the rotation register settings for RGB24 packet format (only for the two video pipelines).

**Table 7-53. DMA Rotation Register Settings**

| Rotation    | Registers                                                             | GFX/VIDx <sup>(1)</sup>                                             |
|-------------|-----------------------------------------------------------------------|---------------------------------------------------------------------|
| 0 degree    | DSS.DISPC_xxx_BAj<br>DSS.DISPC_xxx_PIXEL_INC<br>DSS.DISPC_xxx_ROW_INC | ba<br>1<br>1                                                        |
| 90 degrees  | DSS.DISPC_xxx_BAj<br>DSS.DISPC_xxx_PIXEL_INC<br>DSS.DISPC_xxx_ROW_INC | ba + (iw x (ih-1) x ps)<br>-(iw x ps) - 1<br>(iw x (ih-1)) x ps + 1 |
| 180 degrees | DSS.DISPC_xxx_BAj<br>DSS.DISPC_xxx_PIXEL_INC<br>DSS.DISPC_xxx_ROW_INC | ba + (iw x ih-1) x ps<br>-2 x ps<br>-2 x ps                         |

<sup>(1)</sup>

- ba = start address of image buffer in memory
- iw = image width in pixels per row - 1 (for YUV: pixels per row divided by 2)
- ih = image height - 1 (number of rows)
- ps = pixel size in bytes (RGB: 2 bytes per pixel, YUV: 4 bytes per pixel)

See [Table 7-52](#) for more information of these parameters.

**Table 7-53. DMA Rotation Register Settings (continued)**

| Rotation    | Registers                                                             | GFX/VIDx <sup>(1)</sup>                                                 |
|-------------|-----------------------------------------------------------------------|-------------------------------------------------------------------------|
| 270 degrees | DSS.DISPC_xxx_BAj<br>DSS.DISPC_xxx_PIXEL_INC<br>DSS.DISPC_xxx_ROW_INC | ba + (iw - 1) x ps<br>(iw - 1) x ps + 1<br>-(iw x (ih-1)) x ps - ps + 1 |

**NOTE:** In case of RGB16 format and optimization enabled, the base address is aligned on a 32-bit boundary and the number of bytes to skip is a multiple of 4 bytes.

**Table 7-54. Video Rotation Register Settings (With RGB24 Packet Format)**

| Rotation    | Registers<br>(with n = 1 or 2) | SDRAM Direct Access <sup>(1)</sup> |
|-------------|--------------------------------|------------------------------------|
| 0 degree    | DSS.DISPC_VIDn_BAj             | ba                                 |
|             | DSS.DISPC_VIDn_PIXEL_INC       | 1                                  |
|             | DSS.DISPC_VIDn_ROW_INC         | 1                                  |
| 180 degrees | DSS.DISPC_VIDn_BAj             | ba+(iw*ih*3)-4                     |
|             | DSS.DISPC_VIDn_PIXEL_INC       | -7                                 |
|             | DSS.DISPC_VIDn_ROW_INC         | -7                                 |

<sup>(1)</sup>

- ba = physical base address of the buffer in the system memory (top-left corner of the picture)
- iw = number of pixels per row - 1 (original picture in system memory) for BITMAP and RGB formats and number of pixels per row divided by 2 for YUB422 formats
- h = number of lines - 1 (original picture in system memory)
- ps = pixel size in bytes (BITMAP8: 1 byte; RGB16: 2 bytes; YUV4:2:2: 4 bytes)

See [Table 7-52](#) for more information of these parameters.

The DMA rotation described above can be also combined with an optional mirroring on the vertical axis (see [Figure 7-122](#)). The only settings that must be changed to achieve this mirroring are the registers described above: DISPC\_xxx\_BAj, DISPC\_xxx\_PIXEL\_INC, and DISPC\_xxx\_ROW\_INC. [Table 7-55](#) provides the DMA setup formulas for rotation with mirroring to access the buffer in memory (contiguous pixels) except for the RGB24 packet format.

**Figure 7-122. 90° Rotation With Mirroring**

**Table 7-55. Register Settings for DMA Rotation With Mirroring**

| <b>Rotation</b> | <b>Registers</b>                                                      | <b>GFX/VIDx <sup>(1)</sup></b>                                                |
|-----------------|-----------------------------------------------------------------------|-------------------------------------------------------------------------------|
| 0 degree        | DSS.DISPC_xxx_BAj<br>DSS.DISPC_xxx_PIXEL_INC<br>DSS.DISPC_xxx_ROW_INC | ba + (iw-1) x ps<br>-2 x ps + 1<br>2 x (iw-1) x ps + 1                        |
| 90 degrees      | DSS.DISPC_xxx_BAj<br>DSS.DISPC_xxx_PIXEL_INC<br>DSS.DISPC_xxx_ROW_INC | ba<br>(iw-1) x ps<br>(-iw x (ih-1)) x ps                                      |
| 180 degrees     | DSS.DISPC_xxx_BAj<br>DSS.DISPC_xxx_PIXEL_INC<br>DSS.DISPC_xxx_ROW_INC | ba + iw x (ih-1) x ps<br>1<br>-2 x iw x ps                                    |
| 270 degrees     | DSS.DISPC_xxx_BAj<br>DSS.DISPC_xxx_PIXEL_INC<br>DSS.DISPC_xxx_ROW_INC | ba + (iw x ih - 1) x ps<br>(iw - 1) x ps + 1<br>- (iw x (ih-1)) x ps - ps + 1 |

<sup>(1)</sup>

- ba = start address of image buffer in memory
- iw = image width in pixels per row - 1 (for YUV: pixels per row divided by 2)
- ih = image height - 1 (number of rows)
- ps = pixel size in bytes (RGB: 2 bytes per pixel, YUV: 4 bytes per pixel)

See [Table 7-52](#) for more information of these parameters.

#### 7.5.3.4.3 Image Data From External SRAM

The device offers a rotation engine in the SMS called the VRFB. This rotation method must be used for maximum efficiency when the image data is located in SDRAM. To use the VRFB rotation, both the SMS module and the DSS DMA must be configured.

In the DSS, the same registers must be set up as described for DMA rotation (see [Section 7.5.3.4.2, Image Data from On-Chip SRAM](#)). The differences are in the setup of the following registers:

- DISPC\_xxx\_ROW\_INC: This field contains the DMA addressing increment after each row (line) of pixels. This field is used to add the remaining delta at the end of each line, to reach the 2048-pixel line size of the VRFB (see [Table 7-56](#) for the formula).
- DISPC\_xxx\_PIXEL\_INC: This field contains the DMA addressing increment after each pixel. For VRFB rotation, this value is set always to 1 (see [Table 7-56](#)).

**Table 7-56. VRFB Rotation - DMA Settings**

| <b>Rotation</b> | <b>Registers</b>                                                      | <b>GFX/VIDx <sup>(1)</sup></b>               |
|-----------------|-----------------------------------------------------------------------|----------------------------------------------|
| 0 degree        | DSS.DISPC_xxx_BAj<br>DSS.DISPC_xxx_PIXEL_INC<br>DSS.DISPC_xxx_ROW_INC | VBA0<br>1<br>(2048 - iw) x ps + 1            |
| 90 degrees      | DSS.DISPC_xxx_BAj<br>DSS.DISPC_xxx_PIXEL_INC<br>DSS.DISPC_xxx_ROW_INC | VBA90 + offset<br>1<br>(2048 - ih) x ps + 1  |
| 180 degrees     | DSS.DISPC_xxx_BAj<br>DSS.DISPC_xxx_PIXEL_INC<br>DSS.DISPC_xxx_ROW_INC | VBA180 + offset<br>1<br>(2048 - iw) x ps + 1 |
| 270 degrees     | DSS.DISPC_xxx_BAj<br>DSS.DISPC_xxx_PIXEL_INC<br>DSS.DISPC_xxx_ROW_INC | VBA270 + offset<br>1<br>(2048 - ih) x ps + 1 |

<sup>(1)</sup>

- VBAx = virtual address of the chosen VRFB context and orientation
- iw = image width (width in pixels for RGB, width in pixels divided by 2 for YUV)
- ih = image height
- ps = pixel size in bytes (2 bytes per pixel for RGB, 4 bytes per pixel for YUV)
- Offset = see below

Figure 7-123 provides the offset values that must be added to the virtual base addresses for 90-degree, 180-degree, and 270-degree rotation. This offset is applicable only when the defined image size in the VRFB module is greater than the actual image size, because it must be a multiple of the page width and height. In the example discussed above, the image height was set to 256 lines, instead of 240, because the page height was 32 lines. This offset must be added to the virtual base addresses, because the VRFB module is not aware of the actual image size. Figure 7-123 illustrates why this occurs and how the offset is calculated.

**Figure 7-123. Offset for VRFB Rotation**



dss-099

$\Delta_{iw}$  = Image width delta between the actual image width and the programmed image width because of the page width

$\Delta_{ih}$  = Image height delta between the actual image height and the programmed image height because of the page height:

- Offset 90-degree:  $\Delta_{ih}$  pixels =  $\Delta_{ih} \times ps$  bytes
- Offset 180-degree:  $2048 \times \Delta_{ih} + \Delta_{iw}$  pixels =  $2048 \times \Delta_{ih} \times ps + \Delta_{iw} \times ps$  bytes
- Offset 270-degree:  $2048 \times \Delta_{iw}$  pixels =  $2048 \times \Delta_{iw} \times ps$  bytes

In the example given above, the delta in the image height is  $256 - 240 = 16$  lines ( $\Delta_{ih} = 16$ ), whereas the exact value of the width can be programmed ( $\Delta_{iw} = 0$ ). In that case, the resulting offset values are:

- YUV:
  - Offset 90-degree:  $16 \times 4$  bytes
  - Offset 180-degree:  $2048 \times 16 \times 4$  bytes
  - Offset 270-degree: 0 bytes
- RGB:
  - Offset 90-degree:  $16 \times 2$  bytes

- Offset 180-degree: 2048 x 16 x 2 bytes
- Offset 270-degree: 0 bytes

As with DMA rotation, mirroring along the vertical axis can be added on top of the rotation when using the VRFB. This mirroring is achieved by combining an appropriate VRFB rotation with a readout of the VRFB by the DSS DMA, going backwards from the last line to the first line of the rotated image. [Table 7-57](#) provides the DMA settings for VRFB rotation with mirroring.

**Table 7-57. VRFB Rotation With Mirroring - DMA Settings**

| Rotation    | Registers               | GFX/VIDx <sup>(1)</sup>                |
|-------------|-------------------------|----------------------------------------|
| 0 degree    | DSS.DISPC_xxx_BAj       | VBA180 + 2048 x (ih - 1) x ps + offset |
|             | DSS.DISPC_xxx_PIXEL_INC | 1                                      |
|             | DSS.DISPC_xxx_ROW_INC   | -(2048 + iw) x ps + 1                  |
| 90 degrees  | DSS.DISPC_xxx_BAj       | VBA270 + 2048 x (iw - 1) x ps + offset |
|             | DSS.DISPC_xxx_PIXEL_INC | 1                                      |
|             | DSS.DISPC_xxx_ROW_INC   | -(2048 + ih) x ps + 1                  |
| 180 degrees | DSS.DISPC_xxx_BAj       | VBA0 + 2048 x (ih - 1) x ps            |
|             | DSS.DISPC_xxx_PIXEL_INC | 1                                      |
|             | DSS.DISPC_xxx_ROW_INC   | -(2048 + iw) x ps + 1                  |
| 270 degrees | DSS.DISPC_xxx_BAj       | VBA90 + 2048 x (iw - 1) x ps + offset  |
|             | DSS.DISPC_xxx_PIXEL_INC | 1                                      |
|             | DSS.DISPC_xxx_ROW_INC   | -(2048 + ih) x ps + 1                  |

<sup>(1)</sup>

- VBAx = virtual address of the chosen VRFB context and orientation
- iw = image width (width in pixels for RGB, width in pixels divided by 2 for YUV)
- ih = image height
- ps = pixel size in bytes (2 bytes per pixel for RGB, 4 bytes per pixel for YUV)
- Offset = see below

Some offsets are required if there is a delta between the programmed image size in the VRFB and the actual image size. As shown in [Figure 7-124](#), this applies to 0-degree rotation with mirroring (using VBA 180-degree), 90-degree rotation with mirroring (VBA 270-degree), and 270-degree rotation with mirroring (VBA 90-degree). The offsets are calculated in this manner:

- Offset 0-degree (mirroring):  $2048 \times \Delta ih + \Delta iw$  pixels =  $2048 \times \Delta ih \times ps + \Delta iw \times ps$  bytes
- Offset 90-degree (mirroring):  $2048 \times \Delta iw$  pixels =  $2048 \times \Delta iw \times ps$  bytes
- Offset 270-degree (mirroring):  $\Delta ih$  pixels =  $\Delta ih \times ps$  bytes

**Figure 7-124. Offset for VRFB Rotation With Mirroring**

dss-101

#### 7.5.3.4.4 Additional Configuration When Using YUV Format

The rotation flag (DSS.DISPC\_VIDn\_ATTRIBUTES[13] VIDROTATION bit , with n = 1 or 2) and the repeat flag (DSS.DISPC\_VIDn\_ATTRIBUTES[18] VIDROWREPEATENABLE) indicate the rotation to apply to the video-encoded pixels from the SDRAM and SRAM. The 2D addressing mode is used, but even when accessing the SDRAM buffer, some post-processing must be performed on the YUV 4:2:2 data depending on the rotation. These bits are set only when the video format is not RGB; otherwise, the bit field is reset to 0. Table 7-58 and Table 7-59 describe the configuration of these registers.

**Table 7-58. Video Rotation Register Settings (YUV Only)**

| Rotation    | Registers (with n = 1 or 2)                      | SDRAM + Rotation engine |
|-------------|--------------------------------------------------|-------------------------|
| 0 degree    | DSS.DISPC_VIDn_ATTRIBUTES[13] VIDROTATION        | 0x0                     |
|             | DSS.DISPC_VIDn_ATTRIBUTES[18] VIDROWREPEATENABLE | 0x0                     |
| 90 degrees  | DSS.DISPC_VIDn_ATTRIBUTES[13] VIDROTATION        | 0x1                     |
|             | DSS.DISPC_VIDn_ATTRIBUTES[18] VIDROWREPEATENABLE | 0x1                     |
| 180 degrees | DSS.DISPC_VIDn_ATTRIBUTES[13] VIDROTATION        | 0x2                     |
|             | DSS.DISPC_VIDn_ATTRIBUTES[18] VIDROWREPEATENABLE | 0x0                     |

**Table 7-58. Video Rotation Register Settings (YUV Only) (continued)**

| Rotation   | Registers (with n = 1 or 2)                      | SDRAM + Rotation engine |
|------------|--------------------------------------------------|-------------------------|
| 270 degree | DSS.DISPC_VIDn_ATTRIBUTES[13] VIDROTATION        | 0x3                     |
|            | DSS.DISPC_VIDn_ATTRIBUTES[18] VIDROWREPEATENABLE | 0x1                     |

**Table 7-59. Video Rotation With Mirroring Register Settings (YUV only)**

| Rotation    | Registers (with n = 1 or 2)                      | SDRAM + Rotation engine |
|-------------|--------------------------------------------------|-------------------------|
| 0 degree    | DSS.DISPC_VIDn_ATTRIBUTES[13] VIDROTATION        | 0x2                     |
|             | DSS.DISPC_VIDn_ATTRIBUTES[18] VIDROWREPEATENABLE | 0x0                     |
| 90 degrees  | DSS.DISPC_VIDn_ATTRIBUTES[13] VIDROTATION        | 0x1                     |
|             | DSS.DISPC_VIDn_ATTRIBUTES[18] VIDROWREPEATENABLE | 0x1                     |
| 180 degrees | DSS.DISPC_VIDn_ATTRIBUTES[13] VIDROTATION        | 0x0                     |
|             | DSS.DISPC_VIDn_ATTRIBUTES[18] VIDROWREPEATENABLE | 0x0                     |
| 270 degree  | DSS.DISPC_VIDn_ATTRIBUTES[13] VIDROTATION        | 0x3                     |
|             | DSS.DISPC_VIDn_ATTRIBUTES[18] VIDROWREPEATENABLE | 0x1                     |

**NOTE:** For YUV4:2:2 video-encoded pixels, the hardware must always fetch a 32-bit value from the system memory to generate a YUV4:4:4 value before YUV-to-RGB conversion.

- For 90- and 270-degree rotation, the missing chrominance samples for the odd pixels are generated by duplicating the chrominance samples of the previous even pixels.
- For 0- and 180-degree rotation, the missing chrominance samples for the odd pixels are generated by averaging the contiguous chrominance samples.

#### 7.5.3.4.5 Video DMA Optimization

When a rotation of 90 or 270 degrees is required, the memory traffic can be reduced as described in [Section 7.4.2.8, Rotation](#).

1. Enable DMA optimization for the video pipelines VID1 and VID2 by applying the following settings to the DISPC:
  - (a) Enable DISPC DMA optimization by setting:
    - DISPC\_VIDn\_ATTRIBUTES[20] VIDDMAOPTIMIZATION = 1
    - DISPC\_VIDn\_ATTRIBUTES[18] VIDROWREPEATENABLE = 0
    - DISPC\_VIDn\_ATTRIBUTES[13:12] VIDROTATION = 0x1 or 0x3
  - (b) Configure DISPC for the following format:
    - DISPC\_VIDn\_ATTRIBUTES[4:1] VIDFORMAT = 0x6, 0xA, or 0xB
    - DISPC\_VIDn\_ATTRIBUTES[9] VIDCOLORCONVENABLE = 0x1 (only for YUV format)
  - (c) Configure DISPC scaler in 5-tap mode by setting:
    - DISPC\_VIDn\_ATTRIBUTES[21] VIDVERTICALTAPS = 0x1
    - DISPC\_VIDn\_ATTRIBUTES[6:5] VIDRESIZEENABLE = 0x2 (vertical resize only, minimum setting) or 0x3 (vertical + horizontal resize)
    - DISPC\_VIDn\_ATTRIBUTES[22] VIDLINEBUFFERSPLIT = 0x1
2. Configure the rotation engine (VRFB) inside the SDRAM memory scheduler (SMS) as follows:
  - (a) Set the SMS-VRFB context pixel size to 32 bits by setting:
    - For RGB16 pixel format:
      - Writing context: SMS.SMS\_ROT\_CONTROLn[1:0] PS = 1
      - Reading context: SMS.SMS\_ROT\_CONTROLn[1:0] PS = 2

- For YUV pixel format:
  - Writing and reading context: SMS.SMS\_ROT\_CONTROLn[1:0] PS = 2
- (b) Set the SMS-VRFB context width to one half of the original width:
  - SMS.SMS\_ROT\_SIZEn[10:0] IMAGEWIDTH = Picture width in pixels /2 (because 2 pixels are present in each 32-bit container)

For more information about the VRFB module, see [Section 10.2.4.1.5, Rotation Engine](#), in [Section 10.2, SDRAM Controller \(SDRC\) Subsystem](#).

---

**NOTE:** When 5-tap mode is used, the scaling coefficients must be set even, if 1:1 scaling is required.

Matrix color space coefficients must be set for YUV format inside [DISPC\\_VIDn\\_CONV\\_COEF0](#) through the [DISPC\\_VIDn\\_CONV\\_COEF4](#) registers.

The width of the input original picture must be even (for YUV4:2:2 and RGB16 formats).

The DMA optimization feature must be used only for YUV and RGB16 formats when 90- or 270-degree rotation is required. In all other configurations, the [DISPC\\_VIDn\\_ATTRIBUTES\[20\]](#) VIDDMAOPTIMIZATION bit must be kept at reset value (0x0).

---

### 7.5.3.5 LCD-Specific Control Registers

The following registers define the LCD output configuration:

- DSS.[DISPC\\_CONTROL](#)
- DSS.[DISPC\\_CONFIG](#)
- DSS.[DISPC\\_DEFAULT\\_COLOR\\_m](#) (m=0)
- DSS.[DISPC\\_TRANS\\_COLOR\\_m](#) (m=0)
- DSS.[DISPC\\_TIMING\\_H](#)
- DSS.[DISPC\\_TIMING\\_V](#)
- DSS.[DISPC\\_POL\\_FREQ](#)
- DSS.[DISPC\\_DIVISOR](#)
- DSS.[DISPC\\_SIZE\\_LCD](#)
- DSS.[DISPC\\_DATA\\_CYCLEK](#)
- DSS.[DISPC\\_CPR\\_COEF\\_R](#), DSS.[DISPC\\_CPR\\_COEF\\_G](#), DSS.[DISPC\\_CPR\\_COEF\\_B](#)

Setting/resetting the DSS.[DISPC\\_CONTROL\[0\]](#) LCDENABLE bit enables/disables the LCD output. A valid configuration must be set before enabling the LCD output.

#### 7.5.3.5.1 LCD Attributes

The following fields define the attributes of the panel connected to the display controller:

- Monochrome or color panel (the DSS.[DISPC\\_CONTROL\[2\]](#)MONOCOLOR bit)
- Passive Matrix or active Matrix panel (the DSS.[DISPC\\_CONTROL\[3\]](#) STNTFT bit)
- Color depth (the DSS.[DISPC\\_CONTROL\[9:8\]](#) TFTDATALINES bit field)
- Number of lines per panel (the DSS.[DISPC\\_SIZE\\_LCD\[26:16\]](#) LPP bit field)
- Number of pixels per line (the DSS.[DISPC\\_SIZE\\_LCD\[10:0\]](#) PPL bit field)
- 4- or 8-bit interface for Passive Matrix monochrome panel (the DSS.[DISPC\\_CONTROL\[4\]](#) M8B bit)

#### 7.5.3.5.2 LCD Timings

The following bit fields define the timing generation of HSYNC/VSYNC:

- Horizontal front porch (the DSS.[DISPC\\_TIMING\\_H\[19:8\]](#) HFP bit field)

- Horizontal back porch (the DSS.DISPC\_TIMING\_H[31:20] HBP bit field)
- Horizontal synchronization pulse width (the DSS.DISPC\_TIMING\_H[7:0] HSW bit field)
- Vertical front porch (the DSS.DISPC\_TIMING\_V[19:8] VFP bit field)
- Vertical back porch (the DSS.DISPC\_TIMING\_V[31:20] VBP bit field)
- Vertical synchronization pulse width (the DSS.DISPC\_TIMING\_V[7:0] VSW bit field)
- On/Off control of HSYNC/VSYNC pixel clock (the DSS.DISPC\_POL\_FREQ[17] ONOFF bit)
- Program HSYNC/VSYNC rise or fall (the DSS.DISPC\_POL\_FREQ[16] RF bit)
- Invert HSYNC (the DSS.DISPC\_POL\_FREQ[13] IHS bit)
- Invert VSYNC (the DSS.DISPC\_POL\_FREQ[12] IVS bit)
- HSYNC gated (the DSS.DISPC\_CONFIG[6] HSYNCGATED bit)
- VSYNC gated (the DSS.DISPC\_CONFIG[7] VSYNCGATED bit)

Table 7-60 describes the programming rules for LCD timing.

**Table 7-60. Programming Rules**

|                         | No<br>Downsampling | Downsampling<br>H or V | Downsampling<br>H + V |
|-------------------------|--------------------|------------------------|-----------------------|
| (HBP + HSW + HFP) * PCD | 8                  | 10                     | 20                    |

Figure 7-125 shows the timing values description in the case of an active matrix display.

**Figure 7-125. Timing Values Description (Active Matrix Display)**



dss-102

The following bit fields define the timing generation of ac-bias (output enable in active matrix mode):

- Invert output enable (DSS.DISPC\_POL\_FREQ[15] IEO bit)
- ac-bias pin frequency (DSS.DISPC\_POL\_FREQ[7:0] ACB bit field)
- ac-bias pin transitions per interrupt (DSS.DISPC\_POL\_FREQ[11:8] ACBI bit field)
- ac-bias gated (DSS.DISPC\_CONFIG[8] ACBIASGATED)

The following bit fields define the timing generation of the pixel clock:

- Pixel clock divisor (DSS.DISPC\_DIVISOR[7:0] PCD bit field)
- Invert pixel clock (DSS.DISPC\_POL\_FREQ[14] IPC bit)

- Pixel clock gated (DSS.DISPC\_CONFIG[5] PIXELCLOCKGATED bit)

The 8-bit pixel clock divider (the DSS.DISPC\_DIVISOR[7:0] PCD bit field) selects the pixel clock frequency. This bit field generates a range of pixel clock frequencies from LC/1 to LC/255, where LC is the logic clock from the divided functional clock of the display controller by the DSS.DISPC\_DIVISOR[23:16] LCD bit field.

The pixel clock is defined by the following equation:

$$\text{Pixel Clock} = (\text{FunctionalClock}/\text{LCD}[7:0])/\text{PCD}[7:0]$$

**Table 7-61** through **Table 7-64** show the pixel clock frequency limitations depending the panel type (active or passive matrix) and the mode (color or monochrome).

**Table 7-61. Pixel Clock Frequency Limitations - RGB16 and YUV4:2:2 Active Matrix Display**

| Min PCD Values      |           | Horizontal Resampling |        |           |           |           |
|---------------------|-----------|-----------------------|--------|-----------|-----------|-----------|
|                     |           | Off                   | Up     | 1:1 - 1:2 | 1:2 - 1:3 | 1:3 - 1:4 |
| Vertical Resampling | Off       | 2 (1) <sup>(1)</sup>  | 2 (1)  | 2         | 3         | 4         |
|                     | Up        | 2 (1)                 | 2 (1)  | 2         | 3         | 4         |
|                     | 1:1 - 1:2 | 3-tap                 | 2      | 2         | 4         | 6         |
|                     |           | 5-tap                 | PCDmin | PCDmin    | PCDmin    | PCDmin    |
|                     | 1:2 - 1:4 |                       | PCDmin | PCDmin    | PCDmin    | PCDmin    |

<sup>(1)</sup> The PCD value can be 1 in case all the data and synchronization signals are asserted and deasserted on the rising edge of the pixel clock.

**Table 7-62. Pixel Clock Frequency Limitations - RGB16 and YUV4:2:2 Passive Matrix Display - Mono4**

| Min PCD Values      |           | Horizontal Resampling |          |           |           |           |
|---------------------|-----------|-----------------------|----------|-----------|-----------|-----------|
|                     |           | Off                   | Up       | 1:1 - 1:2 | 1:2 - 1:3 | 1:3 - 1:4 |
| Vertical Resampling | Off       | 4                     | 4        | 8         | 12        | 16        |
|                     | Up        | 4                     | 4        | 8         | 12        | 16        |
|                     | 1:1 - 1:2 | 3-tap                 | 8        | 8         | 16        | 24        |
|                     |           | 5-tap                 | 4xPCDmin | 4xPCDmin  | 4xPCDmin  | 4xPCDmin  |
|                     | 1:2 - 1:4 |                       | 4xPCDmin | 4xPCDmin  | 4xPCDmin  | 4xPCDmin  |

**Table 7-63. Pixel Clock Frequency Limitations - RGB16 and YUV4:2:2 Passive Matrix Display - Mono8**

| Min PCD Values      |           | Horizontal Resampling |          |           |           |           |
|---------------------|-----------|-----------------------|----------|-----------|-----------|-----------|
|                     |           | Off                   | Up       | 1:1 - 1:2 | 1:2 - 1:3 | 1:3 - 1:4 |
| Vertical Resampling | Off       | 8                     | 8        | 16        | 24        | 32        |
|                     | Up        | 8                     | 8        | 16        | 24        | 32        |
|                     | 1:1 - 1:2 | 3-tap                 | 16       | 16        | 32        | 48        |
|                     |           | 5-tap                 | 8xPCDmin | 8xPCDmin  | 8xPCDmin  | 8xPCDmin  |
|                     | 1:2 - 1:4 |                       | 8xPCDmin | 8xPCDmin  | 8xPCDmin  | 8xPCDmin  |

**Table 7-64. Pixel Clock Frequency Limitations - RGB16 and YUV4:2:2 Passive Matrix Display - Color**

| Min PCD Values      |           | Horizontal Resampling |          |           |           |           |
|---------------------|-----------|-----------------------|----------|-----------|-----------|-----------|
|                     |           | Off                   | Up       | 1:1 - 1:2 | 1:2 - 1:3 | 1:3 - 1:4 |
| Vertical Resampling | Off       | 3                     | 3        | 6         | 9         | 12        |
|                     | Up        | 3                     | 3        | 6         | 9         | 12        |
|                     | 1:1 - 1:2 | 3-tap                 | 6        | 12        | 18        | 24        |
|                     |           | 5-tap                 | 3xPCDmin | 3xPCDmin  | 3xPCDmin  | 3xPCDmin  |
|                     | 1:2 - 1:4 |                       | 3xPCDmin | 3xPCDmin  | 3xPCDmin  | 3xPCDmin  |

**NOTE:** In case of RGB24 format, [Figure 7-126](#) is still valid, except the PCDmin values which must be multiplied by two.

The PCDmin for vertical downsampling only is defined by the following equations:

**Figure 7-126. PCDmin Formulas (V Down-Sampling Only)**

$$h\_ratio = \frac{DISPC\_SIZE\_LCD[10:0]PLL}{DISPC\_VIDn\_SIZE[10:0]VIDZSIZEX}$$

$$v\_ratio = \frac{DISPC\_VIDn\_PICTURE\_SIZE[10:0]VIDORGSIZEY}{DISPC\_VIDn\_SIZE[10:0]VIDSIZEY}$$

$$PCD\ min = \frac{v\_ratio}{2 \times h\_ratio} \quad 1 < v\_ratio \leq 2$$

$$PCD\ min = \max\left(\frac{v\_ratio}{2 \times h\_ratio}, \frac{v\_ratio - 2}{2 \times (h\_ratio - 1)}\right) \quad 2 < v\_ratio \leq 4$$

dss-E103

The PCDmin for horizontal downsampling only is defined by the following formula:

While downsampling by n,  $PCDmin = n$

For H+V downsampling, the formula is the following:

$PCDmin = \max(PCODEmin\ H\ only, PCDmin\ V\ only)$  as defined above

The refresh rate depends on the following parameters:

- Horizontal front porch (the DSS.[DISPC\\_TIMING\\_H](#)[19:8] HFP bit field)
- Horizontal back porch (the DSS.[DISPC\\_TIMING\\_H](#)[31:20] HBP bit field)
- Horizontal synchronization pulse width (the DSS.[DISPC\\_TIMING\\_H](#)[7:0] HSW bit field)
- Vertical front porch (the DSS.[DISPC\\_TIMING\\_V](#)[19:8] VFP bit field)
- Vertical back porch (the DSS.[DISPC\\_TIMING\\_V](#)[31:20] VBP bit field)
- Vertical synchronization pulse width (the DSS.[DISPC\\_TIMING\\_V](#)[7:0] VSW bit field)
- Number of lines per panel (the DSS.[DISPC\\_SIZE\\_LCD](#)[26:16] LPP bit field)
- Number of pixels per line (the DSS.[DISPC\\_SIZE\\_LCD](#)[10:0] PPL bit field)
- 4- or 8-bit interface for the passive matrix monochrome panel (the DSS.[DISPC\\_CONTROL](#)[4] M8B bit)

The following bit fields define the behavior of the internal blocks:

- Spatial/temporal dithering logic enabled (DSS.[DISPC\\_CONTROL](#)[7] SPATIALTEMPORALDITHERENABLE bit)
- Spatial/temporal dithering logic number of frames (DSS.[DISPC\\_CONTROL](#)[31:30] SPATIALTEMPORALDITHERFRAMES bit field). The default value of this bit field at reset time is 0x0, which is 1 frame only (spatial processing without temporal dithering). The possible values are 0x0 (one frame), 0x1 (two frames), and 0x2 (four frames). The number of frames is initialized before enabling the spatial/temporal dithering unit. The software must not change this bit field value while the spatial/temporal unit is enabled.

The following bit field defines the clock gating strategy:

- In active matrix mode, the pixel clock is always gated or only when valid data are present (the DSS.[DISPC\\_CONFIG](#)[0] PIXELGATED bit).

### 7.5.3.5.3 LCD Overlay

The following bit fields define the overlay attributes of the LCD output:

- Transparency color key (the DSS.[DISPC\\_TRANS\\_COLOR0i](#) register (i = 0))
- Transparency color key enable (the DSS.[DISPC\\_CONFIG](#)[10] TCKLCDENABLE bit)
- Transparency color key selection between the destination graphics transparency color key and the source video transparency color key (the DSS.[DISPC\\_CONFIG](#)[11] TCKLCDSELECTION bit)

- The default solid background color is defined in the DSS.[DISPC\\_DEFAULT\\_COLOR\\_m](#)[23:0] DEFAULTCOLOR bit field (i=0).
- Alpha blender Enable (DSS.[DISPC\\_CONFIG](#)[18] LCDALPHABLENDERENABLE)
- Global alpha blending values (DSS.[DISPC\\_GLOBAL\\_ALPHA](#)[23:16] VID2GLOBALALPHA and DSS.[DISPC\\_GLOBAL\\_ALPHA](#)[7:0] GFXGLOBALALPHA). The value 0xFF corresponds to 100% opaque and 0 to 100% transparent

---

**NOTE:** The destination graphics transparency color key is available only to the overlay with which the graphics pipeline is connected. The software must set the correct configuration of the LCD and digital overlays.

---

**NOTE:** When the alpha blender is enabled, the destination transparency color key is not available and the source transparency color key applies to the graphics pixels and not the video pixels.

---

When all of these fields are set to the appropriate values, set the DSS.[DISPC\\_CONTROL](#)[5] GOLCD bit to indicate that all shadow registers of the pipelines connected to the LCD output are latched by the hardware (only if the DSS.[DISPC\\_CONTROL](#)[0] LCDENABLE bit is already set to 1). If the LCD output is disabled, the new values will be updated when the DSS.[DISPC\\_CONTROL](#)[0] LCDENABLE bit will be set to 1.

#### 7.5.3.5.4 LCD TDM

The following fields define the multiple cycle output configuration:

- First cycle (the DSS.[DISPC\\_DATA\\_CYCLEk](#) (k=0) register)
- Second cycle (the DSS.[DISPC\\_DATA\\_CYCLEk](#) (k=1) register)
- Third cycle (the DSS.[DISPC\\_DATA\\_CYCLEk](#) (k=2) register)
- Enable (the DSS.[DISPC\\_CONTROL](#)[20] TDMENABLE bit)
- Parallel mode (the DSS.[DISPC\\_CONTROL](#)[22:21] TDMPARALLELMODE field)
- Cycle format (the DSS.[DISPC\\_CONTROL](#)[24:23] TDMCYCLEFORMAT field)
- Unused bits (the DSS.[DISPC\\_CONTROL](#)[26:25] TDMUNUSEDBITS field)

When all of these bit fields are set to the appropriate values, set the DSS.[DISPC\\_CONTROL](#)[5] GOLCD bit to indicate that all shadow registers of the pipelines connected to the LCD output are latched by the hardware (only if the DSS.[DISPC\\_CONTROL](#)[0] LCDENABLE bit is already set to 1). If the LCD output is disabled, the new values will be updated when the DSS.[DISPC\\_CONTROL](#)[0] LCDENABLE bit will be set to 1.

#### 7.5.3.5.5 LCD Spatial/Temporal Dithering

The following bit fields define the LCD spatial/temporal dithering configuration:

- Number of frames (the DSS.[DISPC\\_CONTROL](#)[31:30] SPATIALTEMPORALDITHERINGFRAMES bit field) with:
  - 0x0 Spatial only (default value)
  - 0x1 Spatial + Temporal over two frames
  - 0x2 Spatial + Temporal over four frames
  - 0x3 Reserved
- Enable (the DSS.[DISPC\\_CONTROL](#)[7] SPATIALTEMPORALDITHERENABLE bit)
  - 0x0 Disabled (default value)
  - 0x1 Enabled

When all of these bit fields are set to the appropriate values, set the DSS.DISPC\_CONTROL[5] GOLCD bit to indicate that all shadow registers of the pipelines connected to the LCD output are latched by the hardware (only if the DSS.DISPC\_CONTROL[0] LCDENABLE bit is already set to 1). If the LCD output is disabled, the new values will be updated when the DSS.DISPC\_CONTROL[0] LCDENABLE bit will be set to 1.

#### 7.5.3.5.6 LCD Color Phase Rotation

The following bit fields define the color phase rotation configuration:

- Enable (the DSS.DISPC\_CONFIG[15] CPR bit)
  - 0x0 Disabled (default value)
  - 0x1 Enabled
- Red 10-bit signed coefficients used by the color phase rotation matrix (the DSS.DISPC\_CPR\_COEF\_R register)
- Green 10-bit signed coefficients used by the color phase rotation matrix (the DSS.DISPC\_CPR\_COEF\_G register)
- Blue 10-bit signed coefficients used by the color phase rotation matrix (the DSS.DISPC\_CPR\_COEF\_B register)

The programmable color phase rotation block for the LCD output has nine 10-bit coefficients defined in the DSS.DISPC\_CPR\_COEF\_R, DSS.DISPC\_CPR\_COEF\_G, and DSS.DISPC\_CPR\_COEF\_B, as described in Figure 7-127 through Figure 7-130.

**Figure 7-127. Color Phase Rotation Matrix**

$$\begin{bmatrix} R_{out} \\ G_{out} \\ B_{out} \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} RR & RG & RB \\ GR & GG & GB \\ BR & BG & BB \end{bmatrix} * \begin{bmatrix} R_{in} \\ G_{in} \\ B_{in} \end{bmatrix}$$

dss-E105

**Figure 7-128. Color Phase Rotation Matrix (R Component Only)**

$$R_{out} = \frac{1}{256} * (RR * R_{in} + RG * G_{in} + RB * B_{in})$$

dss-E106

**Figure 7-129. Color Phase Rotation Matrix (G Component Only)**

$$G_{out} = \frac{1}{256} * (GR * R_{in} + GG * G_{in} + GB * B_{in})$$

dss-E107

**Figure 7-130. Color Phase Rotation Matrix (B Component Only)**

$$B_{out} = \frac{1}{256} * (BR * R_{in} + BG * G_{in} + BB * B_{in})$$

dss-E104

When all of these bit fields are set to the appropriate values, set the DSS.DISPC\_CONTROL[5] GOLCD bit to indicate that all shadow registers of the pipelines connected to the LCD output are latched by the hardware (only if the DSS.DISPC\_CONTROL[0] LCDENABLE bit is already set to 1). If the LCD output is disabled, the new values will be updated when the DSS.DISPC\_CONTROL[0] LCDENABLE bit will be set to 1.

##### 7.5.3.5.6.1 Color Phase Rotation - Diagonal Matrix

The Color Phase Rotation feature is useful when using an LCD backlight that is not white. By using a correct configuration of the R, G and B coefficients of CPR, the color bias of the screen can be corrected. The following paragraphs give an example of configuration of the CPR feature.

The easiest example of CPR configuration is a diagonal matrix. This way, the output colors depends on one input color only. [Figure 7-131](#) gives the example of a diagonal matrix and the corresponding equation of the output components.

**Figure 7-131. Diagonal Matrix Configuration**

$$\begin{bmatrix} Rout \\ Gout \\ Bout \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} RR & 0 & 0 \\ 0 & GG & 0 \\ 0 & 0 & BB \end{bmatrix} * \begin{bmatrix} Rin \\ Gin \\ Bin \end{bmatrix}$$

$$\rightarrow Rout = \frac{1}{256} * (RR * Rin)$$

$$\rightarrow Gout = \frac{1}{256} * (GG * Gin)$$

$$\rightarrow Bout = \frac{1}{256} * (BB * Bin)$$

dss-200

According to these 3 new equations, each output component only depends on the corresponding input color. The coefficients can easily be used to reduce the impact of a non-white backlight.

Let's take the example of a "blue" backlight. In this case, users have the feeling that a blue film has been added on the screen, and then each color seems to be "too much blue". The goal is then to reduce the "Blue" component and to keep the "Red" and "Green" ones unchanged. The following matrix can be used for a reduction by a half of the blue component. [Figure 7-132](#) gives the corresponding matrix and equations for each component.

**Figure 7-132. Example - Diagonal Matrix Configuration**

$$\begin{bmatrix} Rout \\ Gout \\ Bout \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} 256 & 0 & 0 \\ 0 & 256 & 0 \\ 0 & 0 & 128 \end{bmatrix} * \begin{bmatrix} Rin \\ Gin \\ Bin \end{bmatrix}$$

$$\rightarrow Rout = \frac{1}{256} * (256 * Rin) \Rightarrow Rout = Rin$$

$$\rightarrow Gout = \frac{1}{256} * (256 * Gin) \Rightarrow Gout = Gin$$

$$\rightarrow Bout = \frac{1}{256} * (128 * Bin) \Rightarrow Bout = 0.5 * Bin$$

dss-201

[Figure 7-133](#) shows the result of an image on a "blue" backlight screen with and without CPR.

**Figure 7-133. Image With and Without CPR (Diagonal Matrix)**

dss-202

A drawback of this diagonal matrix is that the color reduction is linear. The contrast is then different from the initial image. It is then necessary to use the 6 other coefficients of the CPR matrix to better correct a non-white backlight. The goal is to find the correct coefficients that remove the color offset added by the non-white backlight.

#### 7.5.3.5.6.2 Color Phase Rotation - Standard Matrix

In the following example, the LCD backlight adds an offset of 128 (B\_offset) to the Blue component. [Figure 7-134](#) shows an example of matrix that reduces the offset of the screen, the corresponding equations and the resulting output colors.

**Figure 7-134. Example - Image With and Without CPR (Standard Matrix)**

$$\begin{bmatrix} Rout \\ Gout \\ Bout \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} 256 & 0 & 0 \\ 0 & 256 & 0 \\ -129 & -129 & 370 \end{bmatrix} * \begin{bmatrix} Rin \\ Gin \\ Bin \end{bmatrix}$$

$$\rightarrow Rout = \frac{1}{256} * (256 * Rin)$$

$$\rightarrow Gout = \frac{1}{256} * (256 * Gin)$$

$$\rightarrow Bout = \frac{1}{256} * (-129 * Rin + -129 * Gin + 370 * Bin) + B\_offset$$



dss-203

This CPR matrix gives inputs and outputs very close. However, black cannot be corrected because of it's zero-components. No matter which coefficients are used in the matrix, the result will always be equal to the offset added by the LCD backlight.

### 7.5.3.6 TV Set-Specific Control Registers

The following registers define the digital output configuration:

- DSS.[DISPC\\_CONTROL](#)
- DSS.[DISPC\\_CONFIG](#)
- DSS.[DISPC\\_DEFAULT\\_COLOR\\_m](#) (m=1)
- DSS.[DISPC\\_TRANS\\_COLOR\\_m](#) (m=1)
- DSS.[DISPC\\_SIZE\\_DIG](#)

The digital output is enabled/disabled by setting/resetting the DSS.[DISPC\\_CONTROL\[1\]](#) DIGITALENABLE bit. A valid configuration must be set before the digital output can be enabled.

Perform the initialization sequence as follows:

1. Initialize the video encoder and the display controller configuration registers.
2. Set the DSS.[DISPC\\_CONTROL\[6\]](#) GODIGITAL bit and the DSS.[DISPC\\_CONTROL\[1\]](#) DIGITALENABLE bit to 1.
3. Wait for the first VSYNC pulse signal.
4. Clear the SYNCLOSTDIGITAL interrupt by setting the DSS.[DISPC\\_IRQSTATUS\[15\]](#) SYNCLOSTDIGITAL bit to 1.
5. Enable the SYNCLOSTDIGITAL interrupt by setting the DSS.[DISPC\\_IRQENABLE\[15\]](#)

SYNCLOSTDIGITAL bit to 1.

#### 7.5.3.6.1 Digital Timings

The following bit fields define the timing information:

- Data hold time (the DSS.DISPC\_CONTROL[19:17] HT bit field)
- Logic clock divisor (the DSS.DISPC\_DIVISOR[23:16] LCD bit field)

The 8-bit pixel clock divider (DSS.DISPC\_DIVISOR[23:16]) bit field is used to select the logic clock frequency. The LCD generates a range of pixel clock frequencies from FCK/1 to FCK/255, where FCK is the input functional clock of the display controller.

#### 7.5.3.6.2 Digital Frame/Field Size

The following bit fields define the field size (frame if progressive mode):

- Number of lines per panel (the DSS.DISPC\_SIZE\_DIG[26:16] LPP bit field)
- Number of pixels per line (the DSS.DISPC\_SIZE\_DIG[10:0] PPL bit field)

#### 7.5.3.6.3 Digital Overlay

The following bit fields define the overlay attributes of the digital output:

- Transparency color key (the DSS.DISPC\_TRANS\_COLOR\_m register (m=1))
- Transparency color key enable (the DSS.DISPC\_CONFIG[12] TCKDIGENABLE bit)
- Transparency color key selection between the destination graphics transparency color key and the source video transparency color key (the DSS.DISPC\_CONFIG[13] TCKDIGSELECTION bit)
- The default solid background color is defined in the DSS.DISPC\_DEFAULT\_COLOR\_m[23:0] DEFAULTCOLOR bit field (i=1).
- Alpha blender Enable (DSS.DISPC\_CONFIG[19] TVALPHABLENDERENABLE)
- Global alpha blending values (DSS.DISPC\_GLOBAL\_ALPHA[23:16] VID2GLOBALALPHA and DSS.DISPC\_GLOBAL\_ALPHA[7:0] GFXGLOBALALPHA). The value 0xFF corresponds to 100% opaque and 0 to 100% transparent

---

**NOTE:** The destination graphics transparency color key is available only to the overlay with which the graphics pipeline is connected. The software must set the correct configuration of the LCD and digital overlays.

---

---

**NOTE:** When the alpha blender is enabled, the destination transparency color key is not available and the source transparency color key applies to the graphics pixels and not the video pixels.

---

When this bit field is set to the appropriate values, set the DSS.DISPC\_CONTROL[6] GODIGITAL bit to indicate that all shadow registers of the pipelines connected to the digital output are latched by the hardware (only if the DSS.DISPC\_CONTROL[1] DIGITALENABLE bit is already set to 1). If the digital output is disabled, the new values will be updated when the DSS.DISPC\_CONTROL[1] DIGITALENABLE bit will be set to 1.

### 7.5.4 DSI Protocol Engine Basic Programming Model

This section describes the programming model of the DSI protocol engine.

#### 7.5.4.1 Software Reset

The DSI protocol engine can be reset by software. This reset can be done for debug purposes or after a

protocol error and has the same effect as the hardware reset. The DSI protocol engine can be reset by setting the DSS.DSI\_SYSCONFIG[1] SOFT\_RESET bit to 1. The software can monitor the DSS.DSI\_SYSSTATUS[0] RESET\_DONE status bit to wait for the completion of the reset procedure. If after 5 reads, the DSS.DSI\_SYSSTATUS[0] RESET\_DONE status bit still returns 0, it can be assumed that an error occurred during the reset stage.

---

**NOTE:** This software reset is optional as an hardware reset is always performed on the DSI protocol engine at device reset.

---

#### 7.5.4.2 Power Management

The power management behavior of the DSI protocol engine is controlled by the DSS.DSI\_SYSCONFIG register. This register completely controls the way the module interferes with the PRCM module. The DSS.DSI\_SYSCONFIG[0] AUTO\_IDLE bit should be set to 1 (default value) to enable automatic clock gating in the module.

#### 7.5.4.3 Interrupts

There is a single interrupt request: DSI\_IRQ. This interrupt line is merged with another interrupt line from the DISPC\_IRQ in a single interrupt request DSS\_IRQ. The DSI\_IRQ events are generated only for the enabled VC(s). Two registers are used to enable and monitor the DSI interrupt events:

- DSS.DSI\_IRQENABLE register: This register indicates the enabled/disabled event for the VCs. Each event for the VC is configured in the DSS.DSI\_VCn\_IRQENABLE register dedicated to the VC number. In addition, it includes one bit for the enable of error reporting for the complex I/O: Error signaling from the complex I/O: The interrupt is triggered when any error is received from the complex I/O (ErrSyncEsc[4:0], ErrEsc[4:0] (edge trigger interrupt), ErrControl[4:0] and ErrContentionLP0[4:0], ErrContentionLP1[4:0] from the complex I/O).
- DSS.DSI\_IRQSTATUS register : The register DSI\_IRQSTATUS flags which VC(s) is/have generated an interrupt. Based on the VC number, the register DSI\_VCn\_IRQSTATUS indicates the event generating the interrupt. In addition, it includes one bit for the status of error reporting for the complex I/O.

#### 7.5.4.4 Global Register Controls

Prior to receive data from the DSI complex I/O, the DSI\_PHY\_SCP registers in the DSI complex I/O must be configured. Refer to [Section 7.5.6](#) for more details. [Table 7-65](#) details the register access width limitations for all the DSI modules.

**Table 7-65. Register Access Width Limitations**

| Register Name                              | Register Access Width    |
|--------------------------------------------|--------------------------|
| All DSI complex I/O register (DSI_PHY_SCP) | 32-bit only              |
| All DSI PLL control module registers       | 32-bit only              |
| DSI_VCn_LONG_PACKET_HEADER                 | 32-bit only              |
| DSI_VCn_SHORT_PACKET_HEADER                | 32-bit only              |
| DSI_VCn_LONG_PACKET_PAYLOAD                | 16-bit, 32-bit           |
| All others DSI protocol engine registers   | 8-bit, 16-bit and 32-bit |

#### CAUTION

In case of different access width detailed in [Table 7-65](#), an OCP error is generated in response to the write using SResp=ERR.

The DSI protocol engine is globally controlled by the DSS.DSI\_CTRL register. The interface to the

complex I/O is enabled by setting the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit. When the interface is disabled, it is possible to provide data to the TX FIFO and read pending data in the RX FIFO. When the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit is set to 1, the pending packets should be sent to the DSI complex I/O, the data transfer from the video port should be ignored only when received the next Vertical Sync Event which is received but not send to the DSI complex I/O.

When the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit is reset by software, the hardware should finish the transfer of the pending data in the TX FIFO and wait for response if BTA has been sent (Protocol engine is receive mode), then the hardware resets the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit. When using the video mode, the VC associated with the video port should be enabled prior to enable the interface according to the following sequence:

- DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit is equal to 0
- Enable the VC associated with video mode by setting the DSS.[DSI\\_VCn\\_CTRL\[0\]](#) VC\_EN
- Set the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit to 1

#### 7.5.4.5 Virtual Channels

There is one set of registers for each VC. The attributes of the VC define the following characteristics:

- Transfer mode (DSS.[DSI\\_VCn\\_CTRL\[4\]](#) MODE bit):
  - Video mode
  - Command mode
- Data type
- Source (DSS.[DSI\\_VCn\\_CTRL\[1\]](#) SOURCE bit)
  - Video port
  - L4 interconnect port
- HS or LP forward transmission
- Automatic bus turn-around generation
  - Short packets (DSS.[DSI\\_VCn\\_CTRL\[2\]](#) BTA\_SHORT\_EN bit)
  - Long packets (DSS.[DSI\\_VCn\\_CTRL\[3\]](#) BTA\_LONG\_EN bit)
- DMA request configurations for RX and TX
  - DMA request number (DSS.[DSI\\_VCn\\_CTRL\[29:27\]](#) DMA\_RX\_REQ\_NB bit field for RX FIFO and DSS.[DSI\\_VCn\\_CTRL\[23:21\]](#) DMA\_TX\_REQ\_NB bit field for TX FIFO)
  - DMA threshold (DSS.[DSI\\_VCn\\_CTRL\[26:24\]](#) DMA\_RX\_THRESHOLD bit field for RX FIFO and DSS.[DSI\\_VCn\\_CTRL\[19:17\]](#) DMA\_TX\_THRESHOLD bit field for TX FIFO)
- Mode speed (DSS.[DSI\\_VCn\\_CTRL\[9\]](#) MODE\_SPEED bit)
- ECC transmission (DSS.[DSI\\_VCn\\_CTRL\[8\]](#) ECC\_TX\_EN bit)
- CS transmission (DSS.[DSI\\_VCn\\_CTRL\[7\]](#) CS\_TX\_EN bit)

The VC ID not calculated by the DSI module but provided while writing into the registers [DSI\\_VCn\\_SHORT\\_PACKET\\_HEADER](#) and [DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#).

#### 7.5.4.6 Packets

The DSS.[DSI\\_VCn\\_SHORT\\_PACKET\\_HEADER](#) register is used to send only short packets (ECC can be calculated by hardware or by software user for debug purpose). The register is not used for video mode data since the short packets are generated by the hardware using the following information:

- synchronization events received on the video port (assertion/deassertion of the HSYNC and VSYNC input signals)
- DSS.[DSI\\_CTRL\[18\]](#) VP\_HSYNC\_END
- DSS.[DSI\\_CTRL\[17\]](#) VP\_HSYNC\_START
- DSS.[DSI\\_CTRL\[16\]](#) VP\_VSYNC\_END
- DSS.[DSI\\_CTRL\[15\]](#) VP\_VSYNC\_START
- DSS.[DSI\\_CTRL\[10\]](#) VP\_HSYNC\_POL

- DSS.DSI\_CTRL[11] VP\_VSYNC\_POL
- DSS.DSI\_VCn\_CTRL[1] SOURCE

The DSS.DSI\_VCn\_LONG\_PACKET\_HEADER register is used to provide header for long packets (ECC is always calculated by hardware). The register is used for video mode and command mode. If the video mode is enabled for the VC, it is not possible to transfer concurrently (interleaved in a frame) data using long packets received on the video port and on the L4 interconnect port since the DSS.DSI\_VCn\_LONG\_PACKET\_HEADER register is used by the video mode. The register can be unprogrammed by users to send long packets received on the L4 interconnect port only when software users know that there is no expected data on the video port. The software should correctly program the register to send sequentially long packets in video and command modes.

The DSS.DSI\_VCn\_LONG\_PACKET\_PAYLOAD register is used to provide payload data for long packets (Check-sum is calculated by hardware when DSS.DSI\_VCn\_CTRL[7] CS\_TX\_EN is set to 1 otherwise the value 0x00 is used). The register is not used in video mode since payload data are provided by the video port. The software should ensure that the following sequence for write accesses to the header and payload registers (DSS.DSI\_VCn\_LONG\_PACKET\_HEADER and DSS.DSI\_VCn\_LONG\_PACKET\_PAYLOAD, respectively) is followed:

- A long packet header value with WC=0 written in DSS.DSI\_VCn\_LONG\_PACKET\_HEADER register can be followed by any access.
- A long packet header value with WC0 written in DSS.DSI\_VCn\_LONG\_PACKET\_HEADER register should be followed by one or more writes to the DSS.DSI\_VCn\_LONG\_PACKET\_PAYLOAD register defined by the WC value before writing again to the same DSS.DSI\_VCn\_LONG\_PACKET\_HEADER register.

#### CAUTION

If this sequence is not followed, no error is generated. The access to other DSI registers during this sequence is allowed.

#### 7.5.4.7 DSI Complex I/O

Prior to send/receive any data from the complex I/O, the DSI complex I/O timings should be set according to the display module timings. The DSI complex I/O pads must also be configured first. See [Section 7.5.6, DSI Complex I/O Basic Programming Model](#).

#### 7.5.4.8 Video Mode

The DSS.DSI\_VM\_TIMING1, DSS.DSI\_VM\_TIMING2, DSS.DSI\_VM\_TIMING3, DSS.DSI\_VM\_TIMING4, DSS.DSI\_VM\_TIMING5, DSS.DSI\_VM\_TIMING6, and DSS.DSI\_VM\_TIMING7 registers define the timings of the video mode.

The DSS.DSI\_CTRL[20] BLANKING\_MODE bit defines if the long blanking packets or LPS state are used during the blanking periods (except HFP, HBP, HSA defined by other bits) when there is no pending data in TX FIFO ready to be sent. The software should ensure that there is no data in the TX FIFO, no BTA, no RESET trigger sent, and the DSS.DSI\_VCn\_CTRL[9] MODE\_SPEED bit is set to 1 (High-Speed mode) to keep the video mode transfer in HS mode during blanking periods (except for the last blanking period since it is required to go LPS at least once per frame).

The DSS.DSI\_CTRL[21] HFP\_BLANKING\_MODE, DSS.DSI\_CTRL[22] HBP\_BLANKING\_MODE and DSS.DSI\_CTRL[23] HSA\_BLANKING\_MODE define if these blanking can send packets from the TX FIFO or should be kept in HS mode using only long blanking packets.

To ensure that the writes to the register DSS.DSI\_VCn\_LONG\_PACKET\_HEADER are correctly handled as header information for video mode long packets, the following registers should be programmed:

- DSS.DSI\_VCn\_CTRL[0] VC\_EN bit set to 1
- DSS.DSI\_VCn\_CTRL[4] MODE bit set to 1
- DSS.DSI\_VCn\_LONG\_PACKET\_HEADER register access
- DSS.DSI\_VCn\_CTRL[0] VC\_EN bit set to 1

**NOTE:** The DSS.DSI\_VCn\_CTRL[1] SOURCE and DSS.DSI\_VCn\_CTRL[9] MODE\_SPEED bits are ignored by hardware when the video mode is selected (DSS.DSI\_VCn\_CTRL[4] MODE bit set to 1)

The interrupt events SYNC\_LOST\_IRQ and RESYNCHRONIZATION\_IRQ indicates if the DSI protocol engine has not been able to resynchronize the video port timing to its own timing base or if it has been done. The RESYNCHRONIZATION\_IRQ indicates software users that the video port works but the configuration of the timings for the display controller (DISPC) and for DSI Protocol engine may need to be modified to avoid the resynchronization to occur. The SYNC\_LOST\_IRQ and RESYNCHRONIZATION\_IRQ events can be respectively monitored in DSS.DSI\_IRQSTATUS[18] SYNC\_LOST\_IRQ and DSS.DSI\_IRQSTATUS[5] RESYNCHRONIZATION\_IRQ status bits.

The DSS.DSI\_VM\_TIMING2[27:24] WINDOW\_SYNC bit field defines the synchronization period. The recommended value is 0x4 based on the implementation of the resynchronization scheme.

#### 7.5.4.9 Video Port Data Bus

The DSS.DSI\_CTRL[7:6] VP\_DATA\_BUS\_WIDTH bit field is used to determine the width of the data bus on the video port. The supported formats are 16-bit, 18-bit and 24-bits.

#### 7.5.4.10 Command Mode

##### 7.5.4.10.1 Command Mode TX FIFO

The single TX FIFO is used on the L4 interconnect port to receive the data to be sent to the peripheral. The configuration of the FIFO for a specific VC should be done only when the VC is disabled.

Users should not enable the VC if there is still some pending data in the TX FIFO for the corresponding space allocated for the VC from previous active period. When the VC space in the TX FIFO is empty, the VC can be enabled.

For each VC, two dedicated DSS.DSI\_VCn\_LONG\_PACKET\_HEADER and DSS.DSI\_VCn\_LONG\_PACKET\_PAYLOAD registers are used to provide data for long packets. The register DSS.DSI\_VCn\_SHORT\_PACKET\_HEADER is used to provide data for short packets (32-bit long).

For each long packet, the DSS.DSI\_VCn\_LONG\_PACKET\_HEADER register should be written first and then the DSS.DSI\_VCn\_LONG\_PACKET\_PAYLOAD register. The only exception is when the word count defined in the header is equal to 0. In that case, it is not required to write into the payload register. For consecutive long packets, the header should be written into the DSS.DSI\_VCn\_LONG\_PACKET\_HEADER register even if the value remains the same.

The TX FIFO stores all the pending bytes to be sent to the peripheral(s). Multiple receivers can be addressed using the VC capability.

The 32-bit write requests only for each VC to the TX FIFO should be kept in order while sending the data to the DSI\_PHY inside the VC requests. The only exception is in the case of last 32-bit write for the last bytes of the payload data since it could be 1, 2, 3, or 4 bytes.

Also in case the last transfer is a 32-bit write but the number of valid bytes is 1, 2, or 3 only (calculated using the header word count and the number of bytes are received for the payload), the hardware should store the 32-bit value into the TX FIFO but the invalid bytes are not sent, and are discarded.

When the word count defined in DSS.DSI\_VCn\_LONG\_PACKET\_HEADER register is not a multiple of the request threshold value defined in DSS.DSI\_VCn\_CTRL[19:17] DMA\_TX\_THRESHOLD bit field, 32-bit requests and/or bytes should be discarded by the hardware to store in FIFO only the exact number of valid bytes.

The DSI protocol module should be able to determine if the bytes in the TX FIFO correspond to a short or long packet without decoder the DT field. When the bytes are written into the DSS.DSI\_VCn\_SHORT\_PACKET\_HEADER, DSS.DSI\_VCn\_LONG\_PACKET\_HEADER, and DSS.DSI\_VCn\_LONG\_PACKET\_PAYLOAD registers, the hardware should store the information concerning long or short packet. A 1-bit flag should be used for each entry of the TX FIFO.

When the VC is disabled, the remaining bytes in the FIFO should be sent to the DSI link. The start event to send data to the DSI link one of the following events:

- All bytes have been received in the FIFO (header + payload).
- The space of the FIFO allocated for the VC is full.
- The space of the FIFO allocated for the VC is not enough to request more data using DMA request (threshold value bigger than space left in the TX FIFO for the VC).

---

**NOTE:** In case the video mode is active, the blanking period should be large enough to allow the transfer of the packet(s).

Sequential arbitration must be set (TX\_FIFO\_ARBITRATION[3] [DSI\\_CTRL](#) bit = 0x1) if only one VC is used to send multiple packets during the same blanking period.

---

When consecutive packets should be sent in HS mode, to ensure that there is no LP transition between them at least one of the following condition should be valid:

- Packets from the same VC
- Short packets or long packets with a payload size multiple of 4 bytes

To flush the FIFO (discard of the data) for some pending bytes, the software should change the allocated size of the chuck FIFO by:

- First disabling the VC resetting DSS.[DSI\\_VCn\\_CTRL](#)[0] VC\_EN bit to 0
- Second change the size of the space of FIFO to 0 by writing the DSS.[DSI\\_TX\\_FIFO\\_VC\\_SIZE](#) VCn\_FIFO\_SIZE (n is the VC value between 0 and 3)

If there is an on-going packet transfer from the TX FIFO to DSI\_PHY, the flush of the FIFO should stop immediately the transfer. Because the FIFO is accessible to users, it must ensure that there are no bytes left in the FIFO before starting the flush operation. But it can be required in dead-lock situation to flush the FIFO even if there are still bytes in the FIFO, in that case, the software should also take care of having a known state of the whole DSI protocol engine module (software reset may be required) To start of new transfer through the TX FIFO.

Users can check that there is no pending request before changing the size of the allocated FIFO for the VC by reading the relevant DSS.[DSI\\_VCn\\_CTRL](#)[15] VC\_BUSY bit or by using the interrupt

PACKET\_SENT\_IRQ: All the packets have been sent by counting the transferred requests to the L4 interconnect port and the number of requests sent to the DSI complex I/O. This interrupt can be monitoring by reading the DSS.[DSI\\_VCn\\_IRQSTATUS](#)[2] PACKET\_SENT\_IRQ status bit.

The DSS.[DSI\\_CTRL](#)[3] TX\_FIFO\_ARBITRATION bit defines if the arbitration scheme is:

- Round-robin between enabled VCs with pending ready requests (pending ready request means that all bytes for the packets are in the FIFO or the space of the FIFO for the VC is full) starting from the VC which has the least VC ID number.
- Sequential: All the pending ready requests for one VC are sent before moving to another VC. The condition of "space of the FIFO is full" should be evaluated after the end of each packet.

If users want to use sequential arbitration for all requests for all channels, a single VC should be used. (the VC ID defined in the header provided to the hardware using either the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) or DSS.[DSI\\_VCn\\_SHORT\\_PACKET\\_HEADER](#) register is not used and not modified by the DSI protocol engine).

The register DSS.[DSI\\_TX\\_FIFO\\_VC\\_SIZE](#) defines the allocated number of 33-bit values for each VC in the TX FIFO and the start address for each VC. The size of the space allocated in the TX FIFO defined by DSS.[DSI\\_TX\\_FIFO\\_VC\\_SIZE](#) VCn\_FIFO\_SIZE (n corresponds to the VC number n) bit fields should be a multiple of the threshold defined in DSS.[DSI\\_VCn\\_CTRL](#)[19:17] DMA\_TX\_THRESHOLD bit field. Only the enabled VCs should be taken into account. To change the size of the space of the memory allocated for a specific VC, the VC should be disabled by setting the DSS.[DSI\\_VCn\\_CTRL](#)[0] VC\_EN bit to 0. The whole FIFO may not be used by all the VCs at a given time since a VC can be disabled to change one or multiple parameters. Software users are responsible for correctly configuring the start address and the size for each VC.

[Table 7-66](#) indicates the corresponding values for the size of the space allocated in the FIFO.

**Table 7-66. Virtual Channel TX FIFO Size Values**

| <b>DSI_TX_FIFO_VC_SIZE.VCn_FIFO_SIZE[n = 0, 3]</b> | <b>Space Size (up to the size of the FIFO)</b> |
|----------------------------------------------------|------------------------------------------------|
| 0                                                  | 0 x 33 bits                                    |
| 1                                                  | 32 x 33 bits                                   |
| 2                                                  | 64 x 33 bits                                   |
| 3                                                  | 96 x 33 bits                                   |
| 4                                                  | 128 x 33 bits                                  |

The total size of TX FIFO is 128\*33 bits. Therefore, the sum of all virtual channel FIFO allocation cannot exceed 128\*33 bits.

Table 7-67 indicates the start address of the space in the FIFO.

**Table 7-67. Virtual Channel TX FIFO Start Address**

| <b>DSI_TX_FIFO_VC_SIZE.VCx_FIFO_ADD[x = 0, 2]</b> | <b>Start Address</b> |
|---------------------------------------------------|----------------------|
| 0                                                 | 0                    |
| 1                                                 | 32                   |
| 2                                                 | 64                   |
| 3                                                 | 96                   |
| 4                                                 | 128                  |

### CAUTION

There must be no overlap of different VCs spaces.

When the TX FIFO is full:

- the overflow interrupt (FIFO\_TX\_OVF\_IRQ) is generated. To monitor this interrupt request, users can read the DSS.[DSI\\_VCn IRQSTATUS\[3\]](#) FIFO\_TX\_OVF\_IRQ status bit.
- there is no L4 interconnect error generated
- the commands are accepted but the data are not written into the FIFO

To ensure that all writes are correctly stored in the TX FIFO, the FIFO should not be full. The software must read the room in the space allocated for the VC in the TX FIFO by reading the DSS.[DSI\\_TX\\_FIFO\\_VC\\_EMPTINESS](#) register. In case there is no space allocated in the TX FIFO for the VC, the DSS.[DSI\\_TX\\_FIFO\\_VC\\_EMPTINESS](#) register indicates a value of 0 for the VC space emptiness.

When waiting to receive the first VSYNC event on the video port to start the video mode on DSI link no command data from TX FIFO should be sent on the interface. It is required to ensure that when receiving the VSYNC event, there is no on-going command mode transfer that could delay the start of video mode on the DSI link.

#### 7.5.4.10.2 Command Mode RX FIFO

The RX FIFO is used to store the data received from the DSI complex I/O. The data are always packed in the RX FIFO (single or multiple packets receiving during a single or multiple BTA periods).

The read requests access to corresponding VC locations to transfer data for a specific VC. The logic managing the FIFO must be able to extract 32-bit values in-order for a specific VC upon read requests. The byte enable of the read access is ignored. Each read returns one 32-bit value from the RX FIFO. If the application accesses the RX FIFO should extract always 32-bit values. Only in the case of 1, 2, or 3 bytes are remaining in the RX FIFO.

The read requests (single or burst) can be less, equal or greater than the packet size. If the packet size is smaller than the read request, the following packet(s) is also transferred. If the packet size is longer than the read request, only part of the packet is transfer. In that case, the logic should keep the VC information to provide the rest of the data during the next read request(s).

The register DSS.[DSI\\_RX\\_FIFO\\_VC\\_SIZE](#) defines the allocated number of 33-bit values for each VC in the RX FIFO and the start address for each VC. Only the enabled VCs should be taken into account. To change the size of the space of the memory allocated for a specific VC, the VC should be disabled by resetting the DSS.[DSI\\_VCn\\_CTRL\[0\]](#) VC\_EN bit to 0. The whole FIFO may not be used by the entire VC at a given time since a VC can be disabled to change one or multiple parameters. Software users are responsible for correctly configuring the start address and the size for each VC.

[Table 7-68](#) indicates the corresponding values for the size of the space allocated in the FIFO:

**Table 7-68. Virtual Channel RX FIFO Size Values**

| <a href="#">DSI_RX_FIFO_VC_SIZE.VCx_FIFO_SIZE[x = 0, 3]</a> | Space Size (up to the size of the FIFO) |
|-------------------------------------------------------------|-----------------------------------------|
| 0                                                           | 0 x 33 bits                             |
| 1                                                           | 32 x 33 bits                            |
| 2                                                           | 64 x 33 bits                            |
| 3                                                           | 96 x 33 bits                            |
| 4                                                           | 128 x 33 bits                           |

The total size of RX FIFO is 128\*33 bits. Therefore, the sum of all virtual channel FIFO allocation cannot exceed 128\*33 bits.

[Table 7-69](#) indicates the start address of the space in the FIFO.

**Table 7-69. Virtual Channel RX FIFO Start Address**

| <a href="#">DSI_RX_FIFO_VC_SIZE.VCx_FIFO_ADD[x = 0, 2]</a> | Start Address |
|------------------------------------------------------------|---------------|
| 0                                                          | 0             |
| 1                                                          | 32            |
| 2                                                          | 64            |
| 3                                                          | 96            |
| 4                                                          | 128           |

#### CAUTION

There must be no overlap of different VCs spaces.

While reading the received bytes in the RX FIFO, only the DSS.[DSI\\_VCn\\_SHORT\\_PACKET\\_HEADER](#) register is used since the hardware does not keep track of the header position for long packets and start/end of each packet. The software must extract the information from the bytes read from the RX FIFO. There is no specific hardware to track the received bytes in the RX FIFO. The DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) and DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_PAYLOAD](#) registers are not used.

The ECC is only used by the first header when receiving multiple packets during the same LP RX transfer from the peripheral since the DSI Protocol engine does not parse the header to identify the length of the packets. In case of multiple packets, the Check-sum does not be enabled since the hardware checks the check-sum considering a single packet. The ECC in the first header is used to correct and check the header. For the following headers in the same LP RX transfer, the hardware does not detect any header and cannot check or/and detect errors in the headers of the packets except for the first packet.

When the RX FIFO is empty:

- there is no OCP error generated
- the commands are accepted and the data for the responses are 0s

#### 7.5.4.10.3 Command Mode DMA Requests

The DMA requests (DSI\_DMA\_REQ) are used to allow automatic transfer by the system DMA or MPU (with less efficiency and through-put capability) from the DSI RX FIFO to the system memory and from the

system memory to the DSI TX FIFO. Two independent DMA requests for RX FIFO and TX FIFO for the same VC are supported. The read and write accesses can use burst structure. The DSI protocol engine should access each write request in a burst without any IDLE between. For read OCP request in a burst to RX FIFO, the acceptance is sent immediately and the response is delayed by at least four L4 interface clock (DSS\_L4\_ICLK) cycles. In case of register reads, the response is returned in the first clock cycle.

The thresholds used for requests for the TX FIFO and RX FIFO are programmable by software. Users program the DSS.[DSI\\_VCn\\_CTRL\[19:17\]](#) DMA\_TX\_THRESHOLD and DSS.[DSI\\_VCn\\_CTRL\[26:24\]](#) DMA\_RX\_THRESHOLD bit fields for TX FIFO and RX FIFO, respectively. Hardware asserts the DMA request based on the threshold value. The size of the space allocated in TX FIFO for each VC must be a multiple of the DSS.[DSI\\_VCn\\_CTRL\[19:17\]](#) DMA\_TX\_THRESHOLD bit field value.

The only exception is in the case of the RX FIFO when the LP data transfer finishes and the threshold value is not reached. In that case the DMA request must be asserted. Therefore, the drain of the FIFO is supported in that configuration to empty the FIFO even if the number of data received is not a multiple of the threshold value.

In case of TX FIFO, if all the bytes defined by the word count field in the DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) header register have been received, the DMA request is no longer asserted even during the last transfer less than DMA\_TX\_THRESHOLD number of bytes have been received because of the word count being not a multiple of the DMA\_TX\_THRESHOLD value.

In case of RX FIFO, while the DMA request is used to transfer the data from the RX FIFO to the system memory, the system DMA must be programmed to read the number of received bytes in the FIFO. If users do not know the size of the received bytes, the direct access of the RX FIFO through the DSS.[DSI\\_VCn\\_SHORT\\_PACKET\\_HEADER](#) register is performed until the DSS.[DSI\\_VCn\\_CTRL\[20\]](#) RX\_FIFO\_NOT\_EMPTY bit goes to 0.

The use of each DMA request is programmable by software. The DSS.[DSI\\_VCn\\_CTRL\[23:21\]](#) DMA\_TX\_REQ\_NB is dedicated to DMA request numbering for the TX FIFO. The DSS.[DSI\\_VCn\\_CTRL\[29:27\]](#) DMA\_RX\_REQ\_NB is dedicated to DMA request numbering for the RX FIFO.

When the DMA request is used to indicate the number of 32-bit values ready in the RX FIFO or BTA has been received from peripheral indicating end of the transfer from peripheral to host for a transfer to the system memory, the DMA request corresponding to the VC ID is generated.

The system DMA transfers the number of 32-bit values defined in the threshold register or the exact number of bytes received from the peripheral (user should know the number of expected received bytes to program correctly the system DMA). When the system DMA transfers a multiple number of threshold value, the DSI protocol engine should send 0s for the data when there is no more received data in the RX FIFO for the VC. Software users must parse the data and determine the valid bytes.

Software users can decide to determine the number of data received in the RX FIFO to read the information in the DSS.[DSI\\_RX\\_FIFO\\_VC\\_FULLNESS](#) register. Then the system DMA can be programmed to read the number of bytes from the RX FIFO. The BTA interrupt (BTA\_IRQ) must be used to know when to read the number of received bytes. To monitor the BTA interrupt, the user must read the DSS.[DSI\\_VCn\\_IRQSTATUS\[5\]](#) BTA\_IRQ status bit. The DMA request must not be selected until the system DMA is programmed with the correct number of data to read from RX FIFO.

If the RX FIFO space for the VC is expected to be overflow because the number of data to be received is greater than the space allocated for the VC, the previous programming model must be used. In place, the DMA request must be asserted as soon as the threshold is reached or when BTA is received.

When the DMA request is used to indicate the number of 33-bit entries empty in the TX FIFO for a transfer from the system memory, the DMA request corresponding to the VC ID is generated.

---

**NOTE:** To obtain best efficiency of the transfer the size of the request (read or write, single or burst) must be aligned with the threshold value.

---

Concurrent access using interlaced requests (read/write) to the TX and RX FIFO is supported for the same VC ID or different VC IDs.

### 7.5.4.11 Ultra-Low Power State

This section describes how to enter/exit to/from ultralow-power state (ULPS).

---

**NOTE:** The DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIGy bits (x range is 1 to 3 corresponding to lane #1 to lane #3, and y range is 1 to 2) must be read back after writing to verify that the write operations are effective before proceeding to the next step. This is to take latency at low TxClkEsc frequencies into account.

---

#### 7.5.4.11.1 Entering ULPS

To enter into ULPS for a clock lane, the following sequence is required:

1. Wait for DSS.[DSI\\_COMPLEXIO\\_CFG2\[16\]](#) HS\_BUSY and DSS.[DSI\\_COMPLEXIO\\_CFG2\[17\]](#) LP\_BUSY bits to be reset to 0 and ensure that the DSS.[DSI\\_CLK\\_CTRL\[13\]](#) DDR\_CLK\_ALWAYS\_ON bit is 0.
2. TxUlpsClk state changes from inactive to active by setting the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG2 (x range is 1 to 3 corresponding to lane #1 to lane #3) bit to 1.

To enter into ULPS for a data lane, the following sequence is required:

1. Wait for all TX\_FIFOs for all VCs working in HS are empty, for video mode is not active, and for DSS.[DSI\\_COMPLEXIO\\_CFG2\[16\]](#) HS\_BUSY bit is reset to 0 (in addition for data lane #1, DSS.[DSI\\_COMPLEXIO\\_CFG2\[17\]](#) LP\_BUSY bit is reset to 0)
2. TxRequestEsc state changes from inactive to active by setting the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG2 (x range is 1 to 3 corresponding to lane #1 to lane #3) bit to 1.

---

**NOTE:** When the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG2 and DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG1 bits are both being written to 0, they can be combined into one write. Both bits must be read back to confirm they are effective before proceeding.

---

#### 7.5.4.11.2 Exiting ULPS

To exit from ULPS for a clock lane, the following sequence is required:

1. Change the state of TxUlpsExit for each lane to ACTIVE by setting the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG1 (x range is 1 to 3 corresponding to lane #1 to lane #3) bit to 1.
2. Wait for the ULPSCACTIVENOT\_ALL1\_IRQ interrupt indicating that all lanes with TxUlpsExit active have acknowledged by asserting UlpsActiveNot. This is performed by monitoring the DSS.[DSI\\_COMPLEXIO\\_IRQSTATUS\[31\]](#) ULPSCACTIVENOT\_ALL1\_IRQ status bit.
3. Start the wake-up timer (GPTimer).
4. Wait for the time-out.
5. Change TxUlpsClk signals to INACTIVE state for the clock lane by resetting the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG2 (x range is 1 to 3 corresponding to lane #1 to lane #3) bit to 0.
6. Reset the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG1 (x range is 1 to 3 corresponding to lane #1 to lane #3) bit to 0.

---

**NOTE:** When the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG2 and DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG1 bits are both being written to 0, they can be combined into one write. Both bits must be read back to confirm they are effective before proceeding.

---

To exit from ULPS for a clock lane, in case ComplexIO is in OFF state (the DSI protocol engine sends ComplexIO to OFF state by setting DSS.[DSI\\_COMPLEXIO\\_CFG1\[28:27\]](#) PWROFF = 0x0), the sequence is:

1. Change TxUlpsClk signals to INACTIVE state for the clock lane by resetting the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG2 (x range is 1 to 3 corresponding to lane #1 to lane #3) bit to 0.
2. Change the state of TxUlpsExit for clock lane to INACTIVE state by resetting the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG1 (x range is 1 to 3 corresponding to lane #1 to lane #3) bit to 0. This step is necessary only in case a PWROFF command (the command for power control of the complex I/O) is issued while the sequence for exiting is in progress (TxUlpsExit signal is already in ACTIVE state).

---

**NOTE:** When the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG2 and DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG1 bits are both being written to 0, they can be combined into one write. Both bits must be read back to confirm they are effective before proceeding.

---

To exit from ULPS for a data lane, the following sequence is required:

1. Change the state of TxUlpsExit for each lane to ACTIVE by setting the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG1 (x range is 1 to 3 corresponding to lane #1 to lane #3) bit to 1.
2. Wait for the ULPSACTIVENOT\_ALL1\_IRQ interrupt indicating that all lanes with TxUlpsExit active have acknowledged by asserting UlpsActiveNot. This is performed by monitoring the DSS.[DSI\\_COMPLEXIO\\_IRQSTATUS\[31\]](#) ULPSACTIVENOT\_ALL1\_IRQ status bit.
3. Start the application wake-up timer (GPtimer).
4. Wait for the time-out.
5. Change TxRequestEsc signals to INACTIVE state for the data lane by resetting the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG2 (x range is 1 to 3 corresponding to lane #1 to lane #3) bit to 0.
6. Reset the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG1 (x range is 1 to 3 corresponding to lane #1 to lane #3) bit to 0.

---

**NOTE:** When the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG2 and DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG1 bits are both being written to 0, they can be combined into one write. Both bits must be read back to confirm they are effective before proceeding.

---

To exit from ULPS for a data lane, in case ComplexIO is in OFF state (the DSI protocol engine sends ComplexIO into OFF state by setting DSS.[DSI\\_COMPLEXIO\\_CFG1\[28:27\]](#) PWROFF = 0x0), the sequence is:

1. Change TxRequestEsc signals to INACTIVE state by resetting the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG2 (x range is 1 to 3 corresponding to lane #1 to lane #3) bit to 0.
2. Change the state of TxUlpsExit to INACTIVE state by resetting the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG1 (x range is 1 to 3 corresponding to lane #1 to lane #3) bit to 0. This step is necessary only in case a PWROFF command is issued while the sequence for exiting is in progress (TxUlpsExit signal is already in ACTIVE state).

---

**NOTE:** When the DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG2 and DSS.[DSI\\_COMPLEXIO\\_CFG2](#) LANEx\_ULPS\_SIG1 bits are both being written to 0, they can be combined into one write. Both bits must be read back to confirm they are effective before proceeding.

---

When the sequence for entering/exiting into/from ULP state is started for specific lanes, users must wait for the sequence to complete before changing the state of the same or other lanes.

#### 7.5.4.12 DSI Programming Sequence Example

This section describes distinct configurations of the DSI protocol engine to support different type of traffics.

**NOTE:** When the VC is used to send video mode data from the video port, the DSS.DSI\_VCn\_CTRL[9] MODE\_SPEED and the DSS.DSI\_VCn\_CTRL[1] SOURCE bits are ignored.

#### 7.5.4.12.1 Video Mode Transfer

Description: One channel, video mode, no DMA requests, no bus turn-around.

1. Configure the display controller with the timing parameters.
2. Configure the DSS.DSI\_VCn\_CTRL register as follows:
  - SOURCE bit is ignored by hardware
  - BTA\_LONG\_EN bit is set to 0: No BTA on long packet
  - BTA\_SHORT\_EN bit is set to 0: No BTA on short packet
  - MODE bit set to 1: The video mode is selected
  - MODE\_SPEED bit is ignored by hardware
3. Configure the DSS.DSI\_VM\_TIMING1 to DSS.DSI\_VM\_TIMING7 registers.
4. Set the ForceTxStopMode bit to 1 in the DSS.DSI\_TIMING1 register.
5. Enable the channel by setting the DSS.DSI\_VCn\_CTRL[0] VC\_EN bit to 1
6. Enable the module by setting the DSS.DSI\_CTRL[0] IF\_EN bit to 1.
7. Poll the ForceTxStopMode bit to 0 in the DSS.DSI\_TIMING1 register.
8. Enable the LCD video output by setting the DSS.DISPC\_CONTROL[0] LCDENABLE bit to 1

#### CAUTION

The restriction for stopping the video mode is that no frame must be sent by the display controller (DISPC) after disabling video mode in DSI.

#### 7.5.4.12.2 Command Mode Transfer Example 1

#### CAUTION

In DSI command mode, the display controller must be configured in stall mode by setting the DSS.DISPC\_CONTROL[11] STALLMODE bit to 1.

Description: One channel, command mode, no DMA requests, manual bus turn-around

1. Configure the DSS.DSI\_VCn\_CTRL register as follows:
    - SOURCE bit set to 0: The source is the L4 interconnect port
    - BTA\_LONG\_EN bit is set to 0: No automatic BTA on long packet
    - BTA\_SHORT\_EN bit is set to 0: No automatic BTA on short packet
    - MODE bit set to 0: The command mode is selected
  2. Enable the packet sent interrupt by setting the DSS.DSI\_VCn\_IRQENABLE[2] PACKET\_SENT\_IRQ\_EN bit to 1
  3. Set the ForceTxStopMode bit to 1 in the DSS.DSI\_TIMING1 register.
  4. Enable the channel by setting the DSS.DSI\_VCn\_CTRL[0] VC\_EN bit to 1
  5. Enable the module by setting the DSS.DSI\_CTRL[0] IF\_EN bit to 1
  6. Poll the ForceTxStopMode bit to 0 in the DSS.DSI\_TIMING1 register.
- For long packet:
- Write the header value into the DSS.DSI\_VCn\_LONG\_PACKET\_HEADER register
  - Write the data into the DSS.DSI\_VCn\_LONG\_PACKET\_PAYLOAD register for the full payload.

Repeat step until WC is reached (see [DSI\\_VCh\\_LONG\\_PACKET\\_HEADER](#))

For short packet:

- Send short packets through the L4 interconnect: Write the header value into the DSS.[DSI\\_VCn\\_SHORT\\_PACKET\\_HEADER](#) register. Repeat step for each short packet.

7. Send one or more packets through L4 interconnect:

- Write the header value into DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) register
- Write the data into DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_PAYLOAD](#) register for the full payload.
- Repeat step 5 for all the long packets

8. Send short packets through L4 interconnect:

- Write the header value into DSS.[DSI\\_VCn\\_SHORT\\_PACKET\\_HEADER](#) register
- Repeat step 6 for all the short packets

9. Interrupt routine: Wait for PACKET\_SENT\_IRQ interrupt generation by polling the DSS.[DSI\\_VCn\\_IRQSTATUS\[2\]](#) PACKET\_SENT\_IRQ status bit and notify the application software when received.

10. The applicative software forces the bus turn-around:

- Wait until the PACKET\_SENT\_IRQ has happened as many times as the number of sent packets
- Set the DSS.[DSI\\_VCn\\_CTRL\[6\]](#) BTA\_EN bit to 1 to send manually a BTA
- Wait until the DSS.[DSI\\_VCn\\_CTRL\[6\]](#) BTA\_EN bit is reset to 0 by hardware

11. Receive the packets from the peripheral

- Start polling the DSS.[DSI\\_VCn\\_CTRL\[20\]](#) RX\_FIFO\_NOT\_EMPTY status bit
- Whenever the RX\_FIFO\_NOT\_EMPTY bit equals to 1, read one word in the RX FIFO

#### 7.5.4.12.3 Command Mode Transfer Example 2

##### CAUTION

In DSI command mode, the display controller must be configured in stall mode by setting the DSS.[DISPC\\_CONTROL\[11\]](#) STALLMODE bit to 1.

Description: One channel, command mode, DMA request, automatic bus turn-around

1. Configure the DSS.[DSI\\_VCn\\_CTRL](#) register as follows:

- SOURCE bit set to 0: The source is the L4 interconnect port
- BTA\_LONG\_EN bit is set to 1: Automatic BTA on long packet
- BTA\_SHORT\_EN bit is set to 1: Automatic BTA on short packet
- MODE bit set to 0: The command mode is selected

2. Enable the packet sent interrupt by setting the DSS.[DSI\\_VCn\\_IRQENABLE\[2\]](#) PACKET\_SENT\_IRQ\_EN bit to 1

3. Set the ForceTxStopMode bit to 1 in DSS.[DSI\\_TIMING1](#) register.

4. Enable the channel by setting the DSS.[DSI\\_VCn\\_CTRL\[0\]](#) VC\_EN bit to 1

5. Configure the TX FIFO threshold and DMA requests parameters:

- Program the DSS.[DSI\\_VCn\\_CTRL\[19:17\]](#) DMA\_TX\_THRESHOLD bit field
- Program the DSS.[DSI\\_VCn\\_CTRL\[23:21\]](#) DMA\_TX\_REQ\_NB bit field

6. Program the system DMA to be ready to send data to the L4 interconnect port

7. Enable the module by setting the DSS.[DSI\\_CTRL\[0\]](#) IF\_EN bit to 1

8. Poll the ForceTxStopMode bit to 0 in DSS.[DSI\\_TIMING1](#) register.

9. Write the header value into DSS.[DSI\\_VCn\\_LONG\\_PACKET\\_HEADER](#) register

10. Interrupt routine: Wait for PACKET\_SENT\_IRQ interrupt generation by polling the DSS.[DSI\\_VCn\\_IRQSTATUS\[2\]](#) PACKET\_SENT\_IRQ status bit and notify the application software

when received.

11. Receive the packets from the peripheral
  - Start polling the DSS.DSI\_VCn\_CTRL[20] RX\_FIFO\_NOT\_EMPTY status bit
  - Whenever the RX\_FIFO\_NOT\_EMPTY bit equals to 1, read one 32-bit word in the RX FIFO
12. Repeat the steps 7 for all long packets.

### 7.5.5 DSI PLL Controller Basic Programming Model

#### 7.5.5.1 Software Reset

The DSI PLL control module does not have its own software reset. It is reset by the DSI protocol engine. Nevertheless, software users can monitor the reset status of the DSI PLL control module by reading the DSS.DSI\_PLL\_STATUS[0] DSPLLCTRL\_RESET\_DONE status bit.

#### 7.5.5.2 DSI PLL Programming Blocks

Figure 7-135 shows the DSI PLL programming blocks.

**Figure 7-135. DSI PLL Programming Blocks**

dss-181

### 7.5.5.3 DSI PLL Go Sequence

In Manual Mode (DSS.DSI\_PLL\_CONTROL[0] DSI\_PLL\_AUTOMODE bit set to 0), the DPLL requires a sequence on TINITZ, TENABLE and TENABLEDIV to update the configuration values and start the locking sequence.

Once all the configuration values have been programmed into the registers, the GO bit must be set. The appropriate sequence should then be sent on the TINITZ, TENABLE, and TENABLEDIV pins, respecting the timing requirements of the ADPLLM. The DSS.DSI\_PLL\_GO[0] **DSI\_PLL\_GO** bit are cleared to 0 at the end of the sequence.

Because the TENABLEDIV signal is shared with the HSDIVIDER module, it is programmed at the same time. In this mode, software must deassert CLKINEN by unsetting the DSS.DSI\_PLL\_CONFIGURATION2[14] DS1\_PHY\_CLKINEN to 0 and assert HSDIVBYPASS correctly by setting the DSS.DSI\_PLL\_CONFIGURATION2[20] DS1\_HSDIVBYPASS bit to 1 to prevent uncontrolled frequencies affecting the DS1\_PHY and display subsystem during PLL locking. In manual mode the shadow register must be updated anyway so that valid values are present when later selecting automatic mode.

Figure 7-136 shows the DS1 PLL Go flow chart in manual mode (DSS.DSI\_PLL\_CONTROL[0] DS1\_PLL\_AUTOMODE bit set to 0).

**Figure 7-136. DS1 PLL Go Sequence (Manual Mode)**



dss-182

NOTE: All thick-outlined blocks show operations performed by software. Other blocks show operations performed by hardware.

In automatic mode (DSS.DSI\_PLL\_CONTROL[0] DS1\_PLL\_AUTOMODE bit set to 1), the TINITZ, TENABLE and TENABLEDIV sequence and the update of the PLL configuration from the DS1\_PLL\_CONFIGURATION2 register are deferred until the time of the front porch time signal sent by the DISPC module. This is intended to simplify the software to implement a configuration change (such as a frequency change to support a different link bandwidth). In this mode CLKINEN, HSDIVBYPASS and REFEN are controlled automatically and the register value is overridden.

Figure 7-137 shows the DS1 PLL Go flow chart in automatic mode (DSS.DSI\_PLL\_CONTROL[0] DS1\_PLL\_AUTOMODE bit set to 1).

**Figure 7-137. DSI PLL Go Sequence (Automatic Mode)**

dss-183

NOTE: All thick-outlined blocks show operations performed by software. Other blocks show operations performed by hardware.

#### 7.5.5.4 DSI PLL Clock Gating Sequence

Clock gating can be used to reduce system power consumption when the DSI protocol engine indicates that it does not need the clock. If the HSDIVIDER is not used, the PLL can also be stopped (at the cost of additional unstarting latency).

The DSI protocol engine can verify when the PLL has unstarted by inspecting the LOCK signal (DSS.DSI\_PLL\_STATUS[1] DSI\_PLL\_LOCK status bit). Because TxByteClkHS is stopped when the CLKIN4DDR is stopped, this should obviate the need for any explicit feedback that the clock has been unstarted in the other case. This flow chart should run even if the DSS.DSI\_PLL\_GO[0] DSI\_PLL\_GO bit has not been set.

[Figure 7-138](#) shows the DSI PLL gated mode sequence.

**Figure 7-138. Gated Mode Sequence**

dss-184

NOTE: All thick-outlined blocks show operations performed by software.

#### 7.5.5.5 DSI PLL Lock Sequence

The DSI PLL (ADPLLM) generates the CLKIN4DDR clock. The HSDIVIDER generates two clocks: DSI1\_PLL\_FCLK connected to the display controller (DISPC) and the DSI2\_PLL\_FCLK connected to the DSI protocol engine. If these two clocks are not used, the HSDIVIDER functions are not required.

The CLKIN4DDR is twice the data rate, and is four times the DSI output clock frequency. The DSI PLL factors need to be calculated based on the required input and output frequencies, keeping the PLL internal reference frequency in the appropriate range:

- REGM factor is programed by DSS.DSI\_PLL\_CONFIGURATION1[18:8] DS1\_PLL\_REGM bit field
- REGN factor is programed by DSS.DSI\_PLL\_CONFIGURATION1[7:1] DS1\_PLL\_REGN bit field
- REGM3 factor is programed by DSS.DSI\_PLL\_CONFIGURATION1[22:19] DS1\_CLOCK\_DIV bit field
- REGM4 factor is programed by DSS.DSI\_PLL\_CONFIGURATION1[26:23] DSIPROTO\_CLOCK\_DIV bit field

Figure 7-139 shows the programming sequence.

**Figure 7-139. DS1 PLL Programming Sequence**



camdss-190

**NOTE:**

- The REGM3 and REGM4 factors must according with the following conditions:
  - The DSI1\_PLL\_FCLK and DSI2\_PLL\_FCLK frequencies must be a multiple of the PCLK frequency (for proper settings of PCD and LCD factors in the DISPC).
  - The DSI1\_PLL\_FCLK and DSI2\_PLL\_FCLK frequencies must be lower than 173 MHz at nominal voltage (OPP100), and lower than 100 MHz at low voltage (OPP50).
- Most of the other DS1 PLL programming values are available for software flexibility but it is not recommended to update the values in normal use. See [Section 7.5.5.7](#) for details on DS1 PLL recommended values.

DSI PLL programming examples:

- WVGA Display on one data pair: Pixel clock (PCLK) = 30 MHz with 18-BPP pixel format

The data rate is  $30 \times 18 = 540$  Mbps on one data lane. Therefore, the frequency on the data lane is twice the data rate: 1080 MHz.

The frequency on the clock lane is 270 MHz (1080 divided by 4).

The SYS\_CLK at 26 MHz is selected as the clock reference by setting the DSS.[DSI\\_PLL\\_CONFIGURATION2\[11\]](#) DS1\_PLL\_CLKSEL to 0b0.

Set the DSS.[DSI\\_PLL\\_CONFIGURATION2\[12\]](#) DS1\_PLL\_HIGHFREQ to 0b0 as PCLK is lower than 32 MHz.

Set Fint to 2 MHz as PLL internal reference frequency: Set REGN to 12 (divide by 13) by setting the DSS.[DSI\\_PLL\\_CONFIGURATION1\[7:1\]](#) DS1\_PLL\_REGN bit field to 0xC.

To get the CLKIN4DDR to 1080 MHz, set the REGM factor to 270 by setting the DSS.[DSI\\_PLL\\_CONFIGURATION1\[18:8\]](#) DS1\_PLL\_REGM to 0x10E.

$$\text{DSI\_PHY} = 2 \times 270/13 \times 26/1 = 1080 \text{ MHz}$$

Because DSI1\_PLL\_FCLK and DSI2\_PLL\_FCLK (REGM3 and REGM4 factors) must be multiples of PCLK and also lower than 173 MHz at nominal voltage (OPP100), and lower than 100 MHz at low voltage (OPP50), program these frequencies to 90 MHz by setting the REGM3 and REGM4 factors to 11 (divide by 12). This is done by setting the DSS.[DSI\\_PLL\\_CONFIGURATION1\[22:19\]](#) DSS\_CLOCK\_DIV bit field and DSS.[DSI\\_PLL\\_CONFIGURATION1\[26:23\]](#) DSIPROTO\_CLOCK\_DIV to 0xB:

$$\text{DSI1\_PLL\_FCLK} = \text{DSI2\_PLL\_FCLK} = 1080/12 = 90 \text{ MHz}$$

- XGA Display on two data pairs: Pixel clock (PCLK) = 60 MHz with 16-BPP pixel format

The data rate is  $(60 \times 16)/2 = 480$  Mbps on each data lane. Therefore, the frequency on the data lane is twice the data rate: 960 MHz.

The frequency on the clock lane is 240 MHz (960 divided by 4).

The SYS\_CLK at 26 MHz is selected as the clock reference by setting the DSS.[DSI\\_PLL\\_CONFIGURATION2\[11\]](#) DS1\_PLL\_CLKSEL bit to 0b0.

Set the DSS.[DSI\\_PLL\\_CONFIGURATION2\[12\]](#) DS1\_PLL\_HIGHFREQ bit to 0b0 as the source clock frequency (SYS\_CLK in this example) is lower than 32 MHz.

Set Fint to 2 MHz as PLL internal reference frequency: Set REGN to 12 (divide by 13) by setting the DSS.[DSI\\_PLL\\_CONFIGURATION1\[7:1\]](#) DS1\_PLL\_REGN bit field to 0xC.

To get the CLKIN4DDR to 960 MHz, set the REGM factor to 240 by setting the DSS.[DSI\\_PLL\\_CONFIGURATION1\[18:8\]](#) DS1\_PLL\_REGM to 0x0F0.

$$\text{DSI\_PHY} = 2 \times 240/13 \times 26/1 = 960 \text{ MHz}$$

Because DSI1\_PLL\_FCLK and DSI2\_PLL\_FCLK (REGM3 and REGM4 factors) must be multiples of PCLK and also lower than 173 MHz at nominal voltage (OPP100), program these frequencies to 120 MHz by setting the REGM3 and REGM4 factors to 7 (divide by 8). This is done by setting the DSS.[DSI\\_PLL\\_CONFIGURATION1\[22:19\]](#) DSS\_CLOCK\_DIV bit field and DSS.[DSI\\_PLL\\_CONFIGURATION1\[26:23\]](#) DSIPROTO\_CLOCK\_DIV to 0x7:

$DSI1\_PLL\_FCLK = DSI2\_PLL\_FCLK = 960/8 = 120 \text{ MHz}$

#### 7.5.5.6 DSI PLL Error Handling

The PLL lock and recalibration signals may be monitored to detect loss of lock or requirement to recalibrate (due to large temperature change since the last lock request):

- The DSS.[DSI\\_PLL\\_STATUS\[1\]](#) DSI\_PLL\_LOCK status bit gives the DSI PLL lock state.
- The DSS.[DSI\\_PLL\\_STATUS\[2\]](#) DSI\_PLL\_RECAL status bit informs if the PLL must be uncalibrated

These signals can also generate interrupts at DSI protocol engine level:

- DSS.[DSI\\_IRQSTATUS\[9\]](#) PLL\_RECAL\_IRQ bit
- DSS.[DSI\\_IRQSTATUS\[8\]](#) PLL\_UNLOCK\_IRQ
- DSS.[DSI\\_IRQSTATUS\[7\]](#) PLL\_LOCK\_IRQ

The PLL\_LOCK\_IRQ interrupt indicates that the DSI PLL is locked. To monitor this event, read the DSS.[DSI\\_IRQSTATUS\[7\]](#) PLL\_LOCK\_IRQ bit. Set this bit to 1 to clear the status bit.

The PLL\_UNLOCK\_IRQ interrupt indicates that the DSI PLL is unlocked. To monitor this event, read the DSS.[DSI\\_IRQSTATUS\[8\]](#) PLL\_UNLOCK\_IRQ bit. Set this bit to 1 to clear the status bit.

The PLL\_RECAL\_IRQ interrupt indicates that the DSI PLL must be recalibrated. To monitor this event, read the DSS.[DSI\\_IRQSTATUS\[9\]](#) PLL\_RECAL\_IRQ bit. Set this bit to 1 to clear the status bit.

The PLL reference loss and limp status signals can also be monitored:

- The DSS.[DSI\\_PLL\\_STATUS\[3\]](#) DSI\_PLL\_LOSSREF status bit informs if the DSI PLL has lost the reference.
- The DSS.[DSI\\_PLL\\_STATUS\[4\]](#) DSI\_PLL\_LIMP status bit informs about the DSI PLL limp status.

#### 7.5.5.7 DSI PLL Recommended Values

[Table 7-70](#) shows the DSI PLL recommended values.

**Table 7-70. Recommended Programming Values**

| Field Name           | Value              | Description                                                                                                                     |
|----------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| DSI_HSDIV_SYSRESET   | 0                  | Allow power FSM to control                                                                                                      |
| DSI_PLL_SYSRESET     | 0                  | Allow power FSM to control                                                                                                      |
| DSI_PLL_HALTMODE     | -                  | See <a href="#">Section 7.5.5.4</a> for details                                                                                 |
| DSI_PLL_GATEMODE     | -                  | See <a href="#">Section 7.5.5.4</a> for details                                                                                 |
| DSI_PLL_AUTOMODE     | -                  | See <a href="#">Section 7.5.5.4</a> for details                                                                                 |
| DSI_PLL_GO           | 1-0                | Write a 1 when PLL is to be (re-)locked with new parameters. This bit is cleared by hardware when the PLL request has completed |
| DSIPROTO_CLOCK_DIV   | See <sup>(1)</sup> | DSI protocol engine clock divider                                                                                               |
| DSS_CLOCK_DIV        | See <sup>(1)</sup> | DSS clock divider                                                                                                               |
| DSI_PLL_REGM         | See <sup>(1)</sup> | Feedback clock divider                                                                                                          |
| DSI_PLL_REGN         | See <sup>(1)</sup> | Reference clock divider                                                                                                         |
| DSI_PLL_STOPMODE     | 1                  | Required to use GATEMODE bit                                                                                                    |
| DSI_HSDIVBYPASS      | 0                  | PLL is controlling HSDIVIDER bypass                                                                                             |
| DSI_PROTO_CLOCK_PWDN | 0                  | If PLL/HSDIVIDER is used as the DSI protocol clock source                                                                       |
| DSI_PROTO_CLOCK_EN   | 1                  | If PLL/HSDIVIDER is used as the DSI protocol clock source                                                                       |
| DSS_CLOCK_PWDN       | 0                  | If PLL/HSDIVIDER is used as the DSS clock source                                                                                |
| DSS_CLOCK_EN         | 1                  | If PLL/HSDIVIDER is used as the DSS clock source                                                                                |

<sup>(1)</sup> The bit field value must be set according to the desired clock frequency.

**Table 7-70. Recommended Programming Values (continued)**

| Field Name             | Value | Description                                                                                                                                                  |
|------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DSI_BYPASSEN           | 0     | To use PLL as the clock source. For small displays it may be possible to use the DSS functional clock, in which case this bit must be set to 1               |
| DSI_PHY_CLKINEN        | 1     | Enable CLKIN4DDR                                                                                                                                             |
| DSI_PLL_REFEN          | 1     | Enable PLL reference                                                                                                                                         |
| DSI_PLL_HIGHFREQ       | 0/1   | Set to 1 if the clock reference is higher than 32 MHz (21 MHz if DSS.DSI_PLL_CONFIGURATION1[7:1] DSI_PLL_REGN = 0)                                           |
| DSI_PLL_CLKSEL         | 0/1   | Set to 0 to use DSS2_ALWON_FCLK as the PLL reference or set to 1 to use PCLKFREE as the PLL reference, in this case the DISPC must be using DSS1_ALWON_FCLK. |
| DSI_PLL_LOCKSEL        | 0x0   | Phase lock criteria to lock the PLL                                                                                                                          |
| DSI_PLL_DRIFTGUARDEN   | 0x0   | The RECAL status/interrupt must be used to decide when to perform a PLL uncalibration No automatic uncalibration is performed                                |
| DSI_PLL_TIGHTPHASELOCK | 0     | Normal criteria                                                                                                                                              |
| DSI_LOWCURRSTDBY       | 0/1   | Set to 0 for fast PLL unlock, but higher standby current Set to 1 for leakage level standby current, but longer unlock time                                  |
| DSI_PLL_PLLLPMODE      | 0     | Normal operation For smaller display sizes may be possible to set to 1                                                                                       |
| DSI_PLL_IDLE           | 0     | PLL active                                                                                                                                                   |

## 7.5.6 DSI Complex I/O Basic Programming Model

### 7.5.6.1 Software Reset

The clock domain using the TxByteClkHS from the DSI complex I/O has a dedicated reset done information in the DSS.DSI\_COMPLEXIO\_CFG1[29] RESET\_DONE bit. The DSS.DSI\_SYSCONFIG[1] SOFT\_RESET bit is used to reset the TxByteClkHS power domain. A dummy read using the SCP interface to any DSI\_PHY register is required after DSI\_PHY reset to complete the reset of the DSI complex I/O.

### 7.5.6.2 Reset-Done Bits

The DSI complex I/O has several clock domains. The reset status for each clock domain is provided in DSS.DSI\_PHY\_REGISTER5 register:

- DSS.DSI\_PHY\_REGISTER5 [31] RESETDONETXBYTECLK bit : Reset done for the TXBYTECLK domain.
- DSS.DSI\_PHY\_REGISTER5 [26:24] RESETDONETXCLKESCi bits: Reset done for the TXCLKESC domain for lane i (i between 0 and 2).
- DSS.DSI\_PHY\_REGISTER5 [30] RESETDONESCPCLK bit: Reset done for the SCP clock domain. Software users must perform a dummy read on this bit to initiate the reset sequence of the SCP finite state machine. When the reset sequence is complete, the RESETDONESCPCLK signal goes high and software users can read again the DSS.DSI\_PHY\_REGISTER5 [30] RESETDONESCPCLK bit to ensure that the value is now 1.

**NOTE:** Software must not write in the DSI\_PHY\_SCP registers before the DSS.DSI\_PHY\_REGISTER5 [30] RESETDONESCPCLK bit is set to 1.

- DSS.[DSI\\_PHY\\_REGISTER5](#) [29] RESETDONEPWRCLK bit: Reset done for the PWR clock domain. The reset sequence of the PWR finite state-machine is complete when the RESETDONEPWRCLK signal goes high.

### 7.5.6.3 Pad Configuration

The number of lanes is configurable through the DSS.[DSI\\_COMPLEXIO\\_CFG1](#) register.

It is not allowed to change on the fly the position (by modifying the DATA $i$ \_POSITION with  $i = 1$  or  $2$  and CLOCK\_POSITION bit fields), P/N order (Positive/Negative order of the differential pair by modifying the DATA $i$ \_POL with  $i = 1$  or  $2$  and CLOCK\_POL) or number of active data lanes (by modifying the DSS.[DSI\\_COMPLEXIO\\_CFG1\[10:8\]](#) DATA2\_POSITION bit). To add or remove the lane #2, it is required to be in OFF mode for the DSI complex I/O.

The minimum requirement for the number of lanes is one clock lane and one data lane. Note that by default, the data lane 2 is not connected (the DSS.[DSI\\_COMPLEXIO\\_CFG1\[10:8\]](#) DATA2\_POSITION bit reset value is 0).

### 7.5.6.4 Display Timing Configuration

---

**NOTE:** Copyright © 2005-2008 MIPI Alliance, Inc. All rights reserved. MIPI Alliance Member Confidential.

---

Depending on the CLKIN4DDR frequency settings programmed with the DSI PLL control module, software users must program accordingly the timing parameters in the DSI complex I/O registers.

#### 7.5.6.4.1 High-Speed Clock Transmission

Figure 7-140 shows an example of high-speed Clock Transmission.

**Figure 7-140. High-Speed Clock Transmission**



dss-185

TXByteClkHS is an output clock which is derived by dividing CLKIN4DDR by 16.

To begin transmission, the protocol drives TXREQUESTHS high on a rising edge of TXByteClkHS. The PHY detects this signal on the next rising edge, following which it initiates the LP Start of Transmission (SoT) procedure.

During a high-speed Clock Transmission, these parameters are defined in multiples of CLKIN4DDR and programmed by the following register bit fields:

- TLPX timing is programmed by the DSS.[DSI\\_PHY\\_REGISTER1\[20:16\]](#) REG\_TLPXBY2 bit field.
- THS-PREPARE timing is programmed by the DSS.[DSI\\_PHY\\_REGISTER0\[31:24\]](#) REG\_THSPREPARE bit field.
- TCLK-ZERO timing is programmed by the DSS.[DSI\\_PHY\\_REGISTER1\[7:0\]](#) REG\_TCLKZERO bit field. TCLK-ZERO is extended, if required, so that the entire LP SoT procedure lasts an integer number of TXByteClkHS cycles.

At the end of the SoT procedure, HS clock transmission begins. At the same time, TXREADYHS is made high.

To stop clock transmission, the protocol drives TXREQUESTHS low on a rising edge of TXByteClkHS. The DSI\_PHY detects this change in TXREQUESTHS on the next edge and stops clock transmission. TXREADYHS is made low.

The DSI\_PHY then goes through the LP End of Transmission (EoT) procedure. TCLK-TRAIL and THS-EXIT parameters are also multiples of CLKIN4DDR and programmed by the following register fields:

- TCLK-TRAIL timing is programmed by the DSS.[DSI\\_PHY\\_REGISTER1\[15:8\]](#) REG\_TCLKTRAIL bit field.
- THS-EXIT timing is programmed by the DSS.[DSI\\_PHY\\_REGISTER0\[7:0\]](#) REG\_THSEXIT bit field.

The DSI\_PHY completes the SoT and EoT procedures, once begun, irrespective of any change in PPI signals. If TXREQUESTHS goes low during the SoT procedure, the PHY start the EoT procedure immediately after finishing the SoT procedure and no clock is transmitted.

STOPSTATE is high whenever the line is in LP-11 state, as determined by the outputs of the Low Power Receivers. This signal is not synchronized with TXByteClkHS.

It is requires that the high speed clock be present for some time before (TCLK-PRE) and some time after (TCLK-POST) high speed data transmission. The protocol must ensure that these timings are met by asserting and deasserting TXREQUESTHS appropriately.

The PHY ensures that the clock signal has a quadrature-phase with respect to a toggling bit sequence on any Data Lane, and a rising edge in the center of the first transmitted bit of every Data byte. These relations are not described in the timing diagram.

CLKIN4DDR can be shut off 300ns after the clock lane goes to STOPSTATE. Alternatively, CLKIN4DDR can be shut down after TCLK-Trail + THS-Exit + 2 Txbyteclk periods after TxRequestHS falling edge is received by DSI\_PHY.

The DSI protocol engine must ensure that TXREQUESTESC, TXULPSCLK, and TURNREQUEST are low whenever TXREQUESTHS is asserted.

#### **7.5.6.4.2 High-Speed Data Transmission**

[Figure 7-141](#) shows an example of high-speed Data Transmission.

**Figure 7-141. High-Speed Data Transmission**


dss-186

TXByteClkHS is an output clock which is derived by dividing CLKIN4DDR by 16.

To begin transmission, the protocol drives TXDATAHS with the first byte of data on a rising edge of TXByteClkHS. It also makes TXREQUESTHS high the same rising edge. The PHY detects TXREQUESTHS going high on the next rising edge of TXByteClkHS, following which it initiates the LP Start of Transmission (SoT) procedure.

During a high-speed Data Transmission, these timings are multiple of CLKIN4DDR and programmed by the following register bit fields:

- TLPX timing is programmed by the DSS.[DSI\\_PHY\\_REGISTER1\[20:16\]](#) REG\_TLPXBY2 bit field.
- THS-PREPARE + THS-ZERO timing is programmed by the DSS.[DSI\\_PHY\\_REGISTER0\[23:16\]](#) REG\_THSPRPR\_THSZERO bit field.

THS-ZERO will be extended, if required, so that the entire LP SoT procedure lasts an integer number of TXByteClkHS cycles. THS-SYNC corresponds to the length of the sync pattern which is 8 high-speed bits, and can be configured through the [DSI\\_PHY\\_REGISTER2\[31:24\]](#) HSSYNCPATTERN bit field.

Towards the end of the SoT procedure, the PHY makes TXREADYHS high on a positive edge of TXByteClkHS and then start accepting data from TXDATAHS from the next positive edge onwards. The protocol is expected to provide (new) valid data on TXDATAHS on every positive edge of TXByteClkHS if TXREADYHS is high.

At the end of the SoT procedure, HS data transmission begins. HS Data Transmission happens LSB first.

To stop data transmission, the protocol drives TXREQUESTHS low on a rising edge of TXByteClkHS. The PHY detects this change in TXREQUESTHS on the next edge and stops data transmission. TXREADYHS is made low and data on TXDATAHS, from that point, is ignored.

The PHY then goes through the LP End of Transmission (EoT) procedure. THS-TRAIL and THS-EXIT are also multiples of CLKIN4DDR and programmed by the following register bit fields:

- THS-TRAIL timing is programmed by the DSS.[DSI\\_PHY\\_REGISTER0\[15:8\]](#) REG\_THSTRAIL bit field.
- THS-EXIT timing is programmed by the DSS.[DSI\\_PHY\\_REGISTER0\[7:0\]](#) REG\_THSEXIT bit field.

The PHY completes the SoT and EoT procedures, once begun, irrespective of any change in PPI signals. If TXREQUESTHS goes low during the SoT procedure, the PHY starts the EoT procedure immediately after finishing the SoT procedure and no data is transmitted.

STOPSTATE is high whenever the line is in LP-11 state, as determined by the outputs of the low power receivers. This signal is not synchronized with TXByteClkHS.

The protocol must ensure that TXREQUESTESC, TXULPSCLK, and TURNREQUEST are low whenever TXREQUESTHS is asserted.

#### 7.5.6.4.3 Turn-Around Request in Transmit Mode

When the DSI PHY is in transmit mode, the DSI protocol engine can request a turnaround by making the TurnRequest signal high for at least one clock cycle of TxClkEsc (see [Section 7.4.3.7.3, TurnRequest FSM](#)).

The DSI PHY transmits the turn-around request pattern (LP 11-10-00-10-00-00-00-00) (see [Figure 7-142](#)). The number of 00 states in the end of the pattern is defined by  $T_{TA\_GO}$  timing parameter and is programmable through the DSS.[DSI\\_PHY\\_REGISTER1\[31:29\]](#) REG\_TTAGO bit field, in number of TxClkEsc clocks. Following the transmission of the pattern, the DSI PHY disables its LP transmitters and waits for an acknowledgment from the remote device. The remote device detects the turn-around request and acknowledges it by driving LP-10, followed by the STOP state. When this acknowledgment is received (BTA\_IRQ is asserted, as described in [Section 7.4.3.8, Bus Turnaround](#)), DSI PHY switches to receive mode and indicates the completion of the turn-around procedure by changing the direction (BTA\_EN = 0).

**Figure 7-142. Turn-Around Request in Transmit Mode**



The DSI protocol engine must not stop TxClkEsc after the turn-around process completes (the DSS.[DSI\\_CLK\\_CTRL\[20\]](#) LP\_CLK\_ENABLE bit must be kept at 1), because TxClkEsc is also used in handling a turn-around request transmitted by a remote slave device (see [Section 7.5.6.4.4, Turn-Around Request in Receive Mode](#)).

#### 7.5.6.4.4 Turn-Around Request in Receive Mode

When the DSI PHY is in receive mode, an LP pattern of 11-10-00-10-00 indicates a turn-around request from the remote device (see [Figure 7-143](#)).

**Figure 7-143. Turn-Around Request in Receive Mode**



If the line stays in LP-00 for a time  $T_{TA-SURE}$ , DSI PHY accepts the turn-around request, changes the direction, transmits LP-00 for a time  $T_{TA-GET}$ , and then transmits the acknowledgment pattern LP-10, followed by the STOP state.

This completes the turn-around procedure (`BTA_IRQ` is asserted, as described in [Section 7.4.3.8, Bus Turnaround](#)). The  $T_{TA-SURE}$  and  $T_{TA-GET}$  timing parameters are programmable through `DSS.DSI_PHY_REGISTER1` in number of TxClkEsc clocks:

- $T_{TA-SURE}$  can be configured in the [28:27] `REG_TTASURE` bit field.
- $T_{TA-GET}$  can be configured in the [26:24] `REG_TTAGET` bit field.

#### 7.5.6.4.5 Other DSI\_PHY Transmission and Reception

The timing of the following sequences defined in the DSI\_PHY protocol cannot be programmed by users:

- Low-power data transmission
- Escape mode trigger command transmission
- ULP state command transmission on data lanes
- ULP state transmission on clock lane
- Low-power data in receive mode
- Low-power trigger in receive mode
- ULP state command on clock lane in receive mode
- ULP state command on data lane in receive mode

#### 7.5.6.5 Error Handling

A dedicated register for the DSI complex I/O, `DSS.DSI_COMPLEXIO_IRQSTATUS`, indicates the state of each error provided by the DSI complex I/O error signals. The DSI\_PHY reports the following errors:

- `DSS.DSI_COMPLEXIO_IRQSTATUS[7:5]` `ERR_ESCi_IRQ`: ERRESC is asserted if an unrecognized Escape entry command is received. This remains high until the next change in the line state.
- `DSS.DSI_COMPLEXIO_IRQSTATUS[2:0]` `ERRSYNCESCi_IRQ`: If the number of bits received during a low-power data transmission is not a multiple of eight when the transmission ends, ERRSYNCESC is made high and remains high until the next change in line state.
- `DSS.DSI_COMPLEXIO_IRQSTATUS[12:10]` `ERRCONTROLi_IRQ`: ERRCONTROL is asserted if an incorrect line state sequence is detected. For example, if a turn-around request or escape mode request is immediately followed by a Stop state instead of the required Bridge state, this signal is asserted and remains asserted until the next change in the line state.

- DSS.[DSI\\_COMPLEXIO\\_IRQSTATUS](#) ERRCONTENTIONLP0\_i\_IRQ: ERRCONTENTION0LPDX and ERRCONTENTION0LPDY are asserted when the Lane module detects a contention situation on lines DX and DY respectively while trying to drive the lines low. Contention is detected only if it lasts at least 50ns
- DSS.[DSI\\_COMPLEXIO\\_IRQSTATUS](#) ERRCONTENTIONLP1\_i\_IRQ: ERRCONTENTION1LPDX and ERRCONTENTION1LPDY are asserted when the Lane module detects a contention situation on lines DX and DY respectively while trying to drive the lines high. Contention is detected only if it lasts at least 50ns

The ULPSACTIVENOT signal goes low which indicates to the protocol that the PHY has entered ULP state. When all the ULPSActiveNot signals are low, the DSS.[DSI\\_COMPLEXIO\\_IRQSTATUS](#)[30] ULPSACTIVENOT\_ALL0\_IRQ event is generated. When all the ULPSActiveNot signals are high, the DSS.[DSI\\_COMPLEXIO\\_IRQSTATUS](#)[31] ULPSACTIVENOT\_ALL1\_IRQ event is generated.

When any of the events defined in DSS.[DSI\\_COMPLEXIO\\_IRQSTATUS](#) register happened, the DSS.[DSI\\_IRQSTATUS](#)[10] COMPLEXIO\_ERR\_IRQ bit is set to 1 at DSI protocol engine level.

The software must take appropriate action when receiving the interrupt indicating the error from the complex I/O. The action can be:

- Reset of the DSI protocol engine module
- Reset of the peripheral though reset trigger or directly driving the hardware reset pin of the display module
- Ignore the error

### 7.5.7 RFBI Basic Programming Model

The RFBI programming model must be used for LCD display support only.

#### 7.5.7.1 DISPC Control Registers

The following DISPC registers are used in RFBI mode:

- The STALL mode is selected by setting the DSS.[DISPC\\_CONTROL](#)[11] STALLMODE bit. The DSS.[DISPC\\_CONTROL](#)[5] GOLCD bit must not be set to 1, but the display controller configuration (DMA engine, pipelines associated to the LCD output,...) must be set before enabling the LCD output by setting the DSS.[DISPC\\_CONTROL](#)[0] LCDENABLE bit to 1.
- To enable the hardware handcheck to avoid underflow, the DSS.[DISPC\\_CONTROL](#)[16] FIFOHANDCHECK must be set to 1. The reset value of this bit is 0. The handcheck applies to the pipelines connected to the LCD output. It must be disabled before resetting the DSS.[DISPC\\_CONTROL](#)[11] STALLMODE bit to 0. The new setting for the FIFO handcheck is used for the following frames.

---

**NOTE:** The LCD output is disabled at the end of the transfer of the frame. The software must reenable the LCD output to generate a new frame by setting the DSS.[DISPC\\_CONTROL](#)[0] LCDENABLE to 1. See [Figure 7-144](#).

---

#### 7.5.7.2 RFBI Control Registers

The following registers define the RFBI control registers:

- DSS.[RFBI\\_CONTROL](#)
- DSS.[RFBI\\_PIXEL\\_CNT](#)
- DSS.[RFBI\\_LINE\\_NUMBER](#)

##### 7.5.7.2.1 High Threshold

The DSS.[RFBI\\_CONTROL](#)[6:5] HIGHTHRESHOLD bit field is used to define the threshold to be used for the generation of the DMA request to receive data into the interconnect FIFO (24 x 32 FIFO depth) through the address of the register [RFBI\\_DATA](#). It must be the size of the burst. The supported values are

4x32, 8x32 and 16x32. The system DMA receives the DMA request and is in charge of providing the correct number of bytes. If the DSS.[RFBI\\_CONTROL\[7\]](#) DISABLE\_DMA\_REQ bit is reset, the DMA request is generated when there is enough room in the interconnect FIFO to accept the full burst. In case the RFBI receives writes L4 requests to the [RFBI\\_DATA](#) location when the interconnect FIFO is full, the request is not accepted. The RFBI waits for a free entry in the interconnect FIFO to accept the L4 request.

If the DSS.[RFBI\\_CONTROL\[7\]](#) DISABLE\_DMA\_REQ bit is set, the DMA request is not generated. The threshold value is ignored.

---

**NOTE:** Software users can access the [RFBI\\_DATA](#) location without using the DMA request and without programming the high threshold value (backward mode).

---

#### 7.5.7.2.2 Bypass Mode

Setting the DSS.[RFBI\\_CONTROL\[1\]](#) BYPASSMODE bit directly outputs the LCD controller output to the LCD panel. Resetting this bit directs the MPU module to send commands/parameters and data from the input video port FIFO.

#### 7.5.7.2.3 Enable

Setting/resetting the DSS.[RFBI\\_CONTROL\[0\]](#) ENABLE bit enables/disables the RFBI module. The hardware resets the enable bit after all of the pixels are sent to the panel. The DSS.[RFBI\\_PIXEL\\_CNT\[31:0\]](#) PIXELEMNT bit field value defines the number of pixels to send to the LCD panel. When the transfer is finished, the configuration used can be modified.

Table 7-71. RFBI Behavior

| RFBI_CONTROL[1] BYPASSMODE bit value | RFBI_CONTROL[0] ENABLE bit value | RFBI Behavior                                                                                                                                                            |
|--------------------------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                                    | 0                                | L4 interconnect can write command/param/data and read data/status from the Remote Frame Buffer (RFB). L4 interconnect access can only be done to the CSx actually active |
| 0                                    | 1                                | The DISPC sends pixels to the RFB.                                                                                                                                       |

The stall signal is asserted when the module is disabled. Through the L4 port, pixels can be sent to the LCD panel only when the pixel count has reach the value 0x0

---

**NOTE:** The LCD output is disabled at the end of the transfer of the frame. The software must reenable the LCD output to generate a new frame by setting the DSS.[DISPC\\_CONTROL\[0\]](#) LCDENABLE to 1. See [Figure 7-144](#).

---

#### 7.5.7.2.4 Configuration Selection

Setting the DSS.[RFBI\\_CONTROL\[3:2\]](#) CONFIGSELECT bit field selects the configuration number (1 or 0 if bits are set or reset). The registers associated with the configuration output the data to the LCD panel.

If both chip-selects are selected, the configuration for the first chip-select is used (except for the polarity of the RFBI\_CS1 signal defined by the second configuration) and both devices connected to the CS signals are driven in parallel. In read mode, if both chip-selects are set, only RFBI\_CS0 is asserted to read data from the device connected on RFBI\_CS0. In write mode with two chip-selects selected, the RFBI can write to the two devices simultaneously.

### 7.5.7.2.5 ITE Bit

Set the DSS.[RFBI\\_CONTROL\[4\]](#) ITE bit to start capturing the data from the display controller. This bit has no effect if the trigger mode is set to external. The display controller must be configured in the STALL mode to account for the RFBI\_DISPC\_STALL signal. Setting the trigger mode to external (DSS.[RFBI\\_CONFIG\[3:2\]](#) TRIGGERMODE bit field set to 0x1 or 0x2) causes the DSS.[RFBI\\_CONTROL\[4\]](#) ITE bit to be ignored. The corresponding chip-select must be selected when this bit is set by users.

The RFBI\_DISPC\_STALL signal is asserted when at least one of the following cases occur:

- Default status when no data to capture from the display controller
- High FIFO threshold reached
- End of the transfer (number of data to output)
- Reset of the RFBI module
- DSS.[RFBI\\_CONTROL\[0\]](#) ENABLE bit reset to 0x0

The RFBI\_DISPC\_STALL signal is deasserted when the DSS.[RFBI\\_CONTROL\[0\]](#) ENABLE bit is set to 0x1 and at least one of the following cases occur:

- Low FIFO threshold reached
- External TE occurs and the DSS.[RFBI\\_CONFIG\[3:2\]](#) TRIGGERMODE bit field is set to 0x1 or 0x2 for automatic external trigger (start of the transfer, the FIFO pointers are reset, the FIFO is empty).
- DSS.[RFBI\\_CONTROL\[4\]](#) ITE bit set to 0x1 by users (start of the transfer, the FIFO pointers are reset, the FIFO is empty).

### 7.5.7.2.6 Number of Pixels to Transfer

Setting the DSS.[RFBI\\_PIXEL\\_CNT\[31:0\]](#) PIXELCNT bit field value directs the application to indicate the number of pixels to be transferred to the LCD panel. The value can be changed only when the DSS.[RFBI\\_CONTROL\[0\]](#) ENABLE is reset.

During the transfer, the hardware decrements the register when a pixel is sent to the remote frame buffer. When the DSS.[RFBI\\_CONTROL\[0\]](#) ENABLE bit is set and a new value is written in the DSS.[RFBI\\_PIXEL\\_CNT](#) register when the current value in the register is a non-zero (the remaining number of pixels to transfer), the ongoing transfer is aborted.

From the L4 interconnect side, if the DSS.[RFBI\\_CONFIG\[10:9\]](#) CYCLEFORMAT bit field is equal to 0x3 and the DSS.[RFBI\\_CONFIG\[8:7\]](#) L4FORMAT bit field is equal to 0x0, an even number of write accesses to the data register must be performed before accessing any other register (CMD/PARAM/STATUS/READ).

When the DSS.[RFBI\\_CONFIG\[10:9\]](#) CYCLEFORMAT bit field is 0x3 (2 pixels are sent over 3 cycles), the number of pixels to be programmed in the DSS.[RFBI\\_PIXEL\\_CNT\[31:0\]](#) PIXELCNT bit field must be a multiple of 2. If another CYCLEFORMAT is used, the value for PIXELCNT can be odd or even. This constraint is valid for data provided on the L4 interconnect port and from the display controller.

If the DSS.[RFBI\\_CONFIG\[10:9\]](#) CYCLEFORMAT bit field is equal to 0x3, the DSS.[RFBI\\_CONFIG\[8:7\]](#) L4FORMAT bit field is equal to 0, and back-to-back register write is processed. The following registers should be written after the first data: [RFBI\\_CMD](#), [RFBI\\_PARAM](#), [RFBI\\_READ](#), and [RFBI\\_STATUS](#). The whole data transfer must first be performed before being able to write to any other registers ([RFBI\\_CMD](#), [RFBI\\_PARAM](#), [RFBI\\_READ](#), and [RFBI\\_STATUS](#)).

### 7.5.7.2.7 Programmable Line Number

When the trigger mode is set to external trigger mode with HSYNC and VSYNC or the TE, hardware resets the line counter when the VSYNC occurs and, after a programmable number of lines (the HSYNC pulse occurs for every line), the transfer to the LCD panel begins. When the programmable line number is 0, only the VSYNC pulse indicates the beginning of the transfer in both modes: HSYNC/VSYNC and TE (logical OR operation between HSYNC and VSYNC).

### 7.5.7.3 RFBI Configuration

The following registers define the RFBI configuration:

- DSS.RFBI\_SYSCONFIG
- DSS.RFBI\_SYSSTATUS
- DSS.RFBI\_CONFIG0 (configuration 0) and DSS.RFBI\_CONFIG1 (configuration 1)
- DSS.RFBI\_VSYNC\_WIDTH
- DSS.RFBI\_HSYNC\_WIDTH

The configuration register for one configuration can be accessed only when the configuration is not in use (based on the value of the [RFBI\\_CONTROL\[3:2\]](#) CONFIGSELECT bit field).

#### 7.5.7.3.1 Parallel Mode

The DSS.RFBI\_CONFIG*i*[1:0]PARALLELMODE bit field (where *i* = 0, 1) defines the width of the interface (8-, 9-, 12-, or 16-bit parallel).

#### 7.5.7.3.2 Trigger Mode

Setting the DSS.RFBI\_CONFIG[3:2]TRIGGERMODE bit field configures the trigger on the external TE signal (RFBI\_TE\_VSYNC), or external with VSYNC/HSYNC with the programmable number of HSyncs to begin the transfer in both cases or the internal programmable DSS.RFBI\_CONTROL[4] ITE bit.

#### 7.5.7.3.3 VSYNC Pulse Width (Minimum Value)

The DSS.RFBI\_VSYNC\_WIDTH[15:0] MINVSYNCPULSEWIDTH bit field defines the minimum number of L4 clock cycles of the VSYNC pulse for detection on VSYNC. It allows differentiation between VSYNC and HSYNC, which are ORed on the same signal and is also used in the VSYNC/HSYNC mode on the two separate input lines.

- The VSYNC pulse width must be at least equal to two L4 cycles when HSYNC is not present.
- The VSYNC pulse width must be at least equal to four L4 cycles when HSYNC is present.

#### 7.5.7.3.4 HSYNC Pulse Width (Minimum Value)

The DSS.RFBI\_HSYNC\_WIDTH[15:0] MINHSYNCPULSEWIDTH bit field defines the minimum number of L4 clock cycles of the HSYNC pulse for detection on HSYNC. It allows differentiation between VSYNC and HSYNC, which are ORed on the same signal, and is also used in the VSYNC/HSYNC mode on the two separate two input lines. The HSYNC pulse width must always be at least equal to two L4 cycles to be detected.

#### 7.5.7.3.5 Cycle Format

Setting the DSS.RFBI\_CONFIG*i*[10:9] CYCLEFORMAT bit field (with *i* = 0, 1) defines which registers are used to format the data in the interconnect FIFO with the appropriate number of bits (starting from the LSB) and with the alignment on the interface as follows:

- DSS.RFBI\_DATA\_CYCLE\_*i* (if DSS.RFBI\_CONFIG[10:9] CYCLEFORMAT bit field = 00) only or
- DSS.RFBI\_DATA\_CYCLE1\_*i* and DSS.RFBI\_DATA\_CYCLE2\_*i* (if DSS.RFBI\_CONFIG[10:9] CYCLEFORMAT bit field = 01)  
or
- DSS.RFBI\_DATA\_CYCLE1\_*i*, DSS.RFBI\_DATA\_CYCLE2\_*i*, and DSS.RFBI\_DATA\_CYCLE3\_*i* (if DSS.RFBI\_CONFIG[10:9] CYCLEFORMAT bit field = 10)

The data from the display controller and from the L4 interconnect are formatted based on the configuration of the DSS.RFBI\_DATA\_CYCLE\_*i* registers.

### 7.5.7.3.6 Unused Bits

Based on the configuration, the undefined bits for each cycle are defined with the previous values of the bits at the same position in the previous cycle, 0s, or 1s (the unused bits can be at any position). The DSS.RFB<sub>i</sub>\_CONFIG[12:11] UNUSEDBITS bit field (with  $i = 0, 1$ ) is used.

### 7.5.7.3.7 RFBI Timings

The timing registers for one configuration can be accessed only when the configuration is not in use (based on the value of the DSS.RFB<sub>i</sub>\_CONTROL[3:2] CONFIGSELECT bit field). Granularity is defined using the DSS.RFB<sub>i</sub>\_CONFIG[4] TIMEGRANULARITY bit. This feature allows the extension of programmable ranges of timing parameters for the RFBI interface. Refer to [Table 7-72](#) for the bits configuration values.

- Chip-select assertion/deassertion time

RFBI\_A0 setup time to chip-select assertion is assured by the programmable chip-select assertion time from the start access time:

DSS.RFB<sub>i</sub>\_ONOFF\_TIME[3:0] CSONTIME bit field (with  $i = 0, 1$ ).

The chip-select deassertion time from the start access time is programmable:

DSS.RFB<sub>i</sub>\_ONOFF\_TIME[9:4] CSOFTTIME bit field (with  $i = 0, 1$ )

#### CAUTION

Configuring DSS.RFB<sub>i</sub>\_ONOFF\_TIME[3:0] CSONTIME = DSS.RFB<sub>i</sub>\_ONOFF\_TIME[9:4] CSOFTTIME = 0 (with  $i = 0, 1$ ) is not supported and must be avoided. This configuration creates contention on the bus and progressively damages the LCD panel.

- Chip-select pulse width

The total chip-select pulse width is the time when write cycle time or read cycle time has completed and is programmable:

DSS.RFB<sub>i</sub>\_CYCLE\_TIME[17:12] CSPULSEWIDTH bit field (with  $i = 0, 1$ )

It applies on the read-to-write, write-to-read, read-to-read, and write-to-write access based on:

- The DSS.RFB<sub>i</sub>\_CYCLE\_TIME[19] RRENABLE bit: Read-to-read access
- The DSS.RFB<sub>i</sub>\_CYCLE\_TIME[20] WWENABLE bit: Write-to-write access
- The DSS.RFB<sub>i</sub>\_CYCLE\_TIME[18] RWENABLE bit: Read-to-write access
- The DSS.RFB<sub>i</sub>\_CYCLE\_TIME[21] WRENABLE bit: Write-to-read access

By default, it applies to any access (read-to-read, read-to-write, write-to-read, write-to-write) when the chip-select changes.

- Access time

The total access time is the time from when A0 becomes valid until data are sampled before deasserting the RE signal; access time is programmable:

DSS.RFB<sub>i</sub>\_CYCLE\_TIME[27:22] ACESSTIME bit field (with  $i = 0, 1$ )

When reading the data on the bus, the data are sampled at the end of the access time, which occurs before the end of the read off time (DSS.RFB<sub>i</sub>\_ONOFF\_TIME[29:24] REOFFTIME, with  $i = 0, 1$ ).

- Write enable cycle time

The total write enable cycle time is the time from when A0 becomes valid until write cycle completion; the write enable cycle time is programmable:

The DSS.RFB<sub>i</sub>\_CYCLE\_TIME[5:0] WECYCLETIME bit field (with  $i = 0, 1$ )

- Write enable assertion/deassertion time

The WE assertion delay time from start access time is programmable:

DSS.RFB<sub>i</sub>\_ONOFF\_TIME[13:10] WEONTIME bit field (with  $i = 0, 1$ )

The WE deassertion delay time from the start access time is programmable:

DSS.RFB<sub>i</sub>\_ONOFF\_TIME[19:14] WEOFETIME bit field (with  $i = 0, 1$ )

- Read enable cycle

The total read enable cycle time is the time when A0 becomes valid until read cycle completion; the read enable cycle time is programmable:

The DSS.RFBI\_CYCLE\_TIME<sub>i</sub>[11:6] RECYCLETIME bit field (with i = 0, 1)

- Read enable assertion/deassertion time

The RE assertion delay time from the start access time is programmable:

DSS.RFBI\_ONOFF\_TIME<sub>i</sub>[23:20] REONTIME bit field (with i = 0, 1)

The RE deassertion delay time from the start access time is programmable:

DSS.RFBI\_ONOFF\_TIME<sub>i</sub>[29:24] REOFFTIME bit field (with i = 0, 1)

At cycle time completion (read access or write access) all control signals (RFBI\_CS<sub>i</sub>, RFBI\_WR, and RFBI\_RD, with i = 0, 1) are deasserted regardless of their deassertion time parameter values, if they are not deasserted already.

However, an exception to this forced deassertion exists when a pipelined request to the same chip-select or to a different chip-select is pending. Also, a control signal with deassertion time parameters equal to the cycle time parameter is not necessarily deasserted when a pipelined request to the same chip-select or different chip-select is pending. This prevents any unnecessary glitch transitions.

If no inactive cycles are required between successive accesses to the same chip-select (the DSS.RFBI\_CYCLE\_TIME<sub>i</sub>[17:12] CSPULSEWIDTH bit field = 0, with i = 0, 1), and if assertion time parameters associated with the following access equal 0, the asserted control signals (RFBI\_CS<sub>i</sub>, RFBI\_WR, and RFBI\_RD, with i = 0, 1) stay asserted. This is applicable to any read/write-to-read/write access combination.

[Table 7-72](#) summarizes the configurations values for each timing bit.

**Table 7-72. RFBI Timings Configuration**

| Configuration bits <sup>(1)</sup>                     | Granularity <sup>(2)</sup> |          |
|-------------------------------------------------------|----------------------------|----------|
|                                                       | one                        | two      |
| DSS.RFBI_ONOFF_TIME <sub>i</sub> [3:0] CSONTIME       | 0 to 15                    | 0 to 30  |
| DSS.RFBI_ONOFF_TIME <sub>i</sub> [9:4] CSOFTTIME      | 0 to 63                    | 0 to 126 |
| DSS.RFBI_CYCLE_TIME <sub>i</sub> [17:12] CSPULSEWIDTH | 0 to 63                    | 0 to 126 |
| DSS.RFBI_CYCLE_TIME <sub>i</sub> [27:22] ACESSTIME    | 0 to 63                    | 0 to 126 |
| DSS.RFBI_CYCLE_TIME <sub>i</sub> [5:0] WECYCLETIME    | 0 to 63                    | 0 to 126 |
| DSS.RFBI_ONOFF_TIME <sub>i</sub> [13:10] WEONTIME     | 0 to 15                    | 0 to 30  |
| DSS.RFBI_ONOFF_TIME <sub>i</sub> [19:14] WEOFETIME    | 0 to 63                    | 0 to 126 |
| DSS.RFBI_CYCLE_TIME <sub>i</sub> [11:6] RECYCLETIME   | 0 to 63                    | 0 to 126 |
| DSS.RFBI_ONOFF_TIME <sub>i</sub> [23:20] REONTIME     | 0 to 15                    | 0 to 30  |
| DSS.RFBI_ONOFF_TIME <sub>i</sub> [29:24] REOFFTIME    | 0 to 63                    | 0 to 126 |

<sup>(1)</sup> Where i = 0 or 1.

<sup>(2)</sup> Number of L4Clk cycles. The granularity can be configured using the DSS.RFBI\_CONFIG[4] TIMEGRANULARITY bit.

#### 7.5.7.3.8 RFBI State-Machine

Referring to [Table 7-39](#), the signals RFBI\_A0, RFBI\_RD, and RFBI\_WR are asserted/deasserted based on the register accessed (DSS.RFBI\_CMD, DSS.RFBI\_PARAM, DSS.RFBI\_DATA, DSS.RFBI\_READ, and DSS.RFBI\_STATUS). When the DSS.RFBI\_SYSSTATUS[8] BUSY bit is set by hardware, any access to the registers is stalled, except for the [RFBI\\_DATA](#) register.

The DSS.RFBI\_SYSSTATUS[9] BUSYRFBIDATA bit indicates whether there are still pending data in the interconnect FIFO associated with the register [RFBI\\_DATA](#) only.

- Command register

Write a command at a time by writing in the DSS.RFBI\_CMD register. If the previous command is not processed, the DSS.RFBI\_SYSSTATUS[8] BUSY bit is set by hardware and the access to writing a new command is stalled.

- Parameter register

Write a parameter at a time by writing in the DSS.[RFBI\\_PARAM](#) register.

If the previous parameter is not processed, the DSS.[RFBI\\_SYSSTATUS\[8\]](#) BUSY bit is set by hardware and the access to writing a new parameter is stalled.

- Data register

Write one or two pixels at a time by writing in the [RFBI\\_DATA](#) register (when DSS.[RFBI\\_CONFIG\[i\]\[10:9\]](#) CYCLEFORMAT = 0x3 with i = 0, 1, two pixels must be written contiguously, no other access to RFBI registers except DSS.[RFBI\\_DATA](#) is allowed).

The pixels are formatted based on the specified cycle format. If two pixels are written into the 32-data register, the DSS.[RFBI\\_CONFIG\[i\]\[8:7\]](#) L4FORMAT bit field indicates the number of pixels for each L4 access to the register and the order of the pixels

If the previous data are not processed, the DSS.[RFBI\\_SYSSTATUS\[8\]](#) BUSY bit is set by hardware and any access for writing new data is stalled. When the DSS.[RFBI\\_SYSSTATUS\[8\]](#) BUSY bit is reset by hardware, the access is not stalled.

- Read/status register

Send through the command and parameter registers the correct information to receive data in the data or status register. The read data from the LCD panel is initiated by writing into the DSS.[RFBI\\_READ](#) or DSS.[RFBI\\_STATUS](#) registers. In this case, the DSS.[RFBI\\_SYSSTATUS\[8\]](#) BUSY bit is set until the data are available in the register.

When the DSS.[RFBI\\_SYSSTATUS\[8\]](#) BUSY bit is set by hardware, the read or write access is stalled until the register is updated with a new value from the LCD panel. To avoid the stall, the software can poll the DSS.[RFBI\\_SYSSTATUS\[8\]](#) BUSY bit until it is reset by hardware. To receive the data, send the appropriate command/parameters.

#### 7.5.7.3.9 RFBI Configuration Flow Charts

The RFBI configuration depends on the trigger mode used by the application. The available trigger modes are:

- Internal trigger mode when setting the DSS.[RFBI\\_CONFIG\[i\]\[3:2\]](#) TRIGGERMODE bit field to 0x0
- External trigger mode:
  - TE external trigger mode when setting the DSS.[RFBI\\_CONFIG\[i\]\[3:2\]](#) TRIGGERMODE bit field to 0x1
  - HSYNC/VSYNC external trigger mode when setting the DSS.[RFBI\\_CONFIG\[i\]\[3:2\]](#) TRIGGERMODE bit field to 0x2

[Figure 7-144](#) gives an example of how to program and use the RFBI module:

**Figure 7-144. How to Use RFBI**


dss-192

[Figure 7-145](#) details how to configure the RFBI registers:

**Figure 7-145. RFBI Initial Configuration**

dss-193

**Figure 7-146 describes how to enable the RFBI module.**

**Figure 7-146. RFBI Output Enable**

dss-324

## 7.5.8 Video Encoder Basic Programming Model

### 7.5.8.1 Video Encoder Software Reset

By setting the DSS.VENC\_F\_CONTROL[8] RESET bit to 1, the video encoder is reset. This bit is automatically cleared by hardware when the reset is done.

**NOTE:** Before changing the standard (NTSC or PAL) and all the related registers, a software reset is required to properly initialize the VENC module.

### 7.5.8.2 Video DAC Stage Settings

The video output format can be either:

- one composite video (CVBS) output signal with video DAC1 or

- two separated luma/chroma output signals with both video DAC1(luma analog signal) and DAC2(chroma analog signal)

Selection is performed with DSS.DSS\_CONTROL[6] VENC\_OUT\_SEL bit:

- When VENC\_OUT\_SEL bit is set to 0 (reset value), video DAC1 is selected for composite video (CVBS) signal
- When VENC\_OUT\_SEL bit is set to 1, video DAC1 is selected for luma signal

One of the first VENC settings is to enable the outputs of the video DACs. This setting depends on the video output format:

- CVBS video output format: Enable video DAC1 composite output by setting the DSS.VENC\_OUTPUT\_CONTROL[1] COMPOSITE\_ENABLE bit to 1
- Separated luma/chroma output format: Enable video DAC1 luma output by setting the DSS.VENC\_OUTPUT\_CONTROL[0] LUMA\_ENABLE bit to 1 and enable video DAC2 chroma output by setting the DSS.VENC\_OUTPUT\_CONTROL[2] CHROMA\_ENABLE bit to 1

**Table 7-73** shows different configurations for the analog TV output, along with the respective values to be set in the dedicated registers inside the device system control module.

**Table 7-73. Analog TV Output Modes**

| Analog TV output modes                        |                                            |                                           |                                          |                               |
|-----------------------------------------------|--------------------------------------------|-------------------------------------------|------------------------------------------|-------------------------------|
| Control Register                              | Composite DC-coupled mode, high full scale | Composite AC-coupled mode, low full scale | S-Video DC-coupled mode, high full scale | Bypass mode, dual channels    |
| CONTROL.CONTROL_DEVCONF1[18]<br>TVOUTBYPASS   | 0: Buffer Mode                             | 0: Buffer mode                            | 0: Buffer mode                           | 1: Bypass mode                |
| CONTROL.CONTROL_DEVCONF1[11]<br>TVACEN        | 0: DC-coupling                             | 1: AC-coupling                            | 0: DC-coupling                           | 0: DC-coupling                |
| <b>AVDAC1</b>                                 |                                            |                                           |                                          |                               |
| CONTROL.CONTROL_AVDAC1 [20]<br>AVDAC1_COMP_EN | 0: Don't care                              | 0: Don't care                             | 0: Don't care                            | 0: Don't care                 |
| CONTROL.CONTROL_AVDAC1 [19]<br>AVDAC1_COMP_EN | 0: Single channel                          | 0: Single channel                         | 1: Dual channel                          | 1: Dual channel               |
| CONTROL.CONTROL_AVDAC1 [18]<br>AVDAC1_COMP_EN | 0: Composite                               | 0: Composite                              | 0: Luma                                  | 0: Luma                       |
| CONTROL.CONTROL_AVDAC1 [17]<br>AVDAC1_COMP_EN | 0: Full scale (1.3V)                       | 1: Full scale (0.88V)                     | 0: Full scale (1.3V)                     | 0: Full scale (1.3V)          |
| CONTROL.CONTROL_AVDAC1 [16]<br>AVDAC1_COMP_EN | 0: External current reference              | 0: External current reference             | 0: External current reference            | 0: External current reference |
| <b>AVDAC2</b>                                 |                                            |                                           |                                          |                               |
| CONTROL.CONTROL_AVDAC2 [20]<br>AVDAC2_COMP_EN | 0: Don't care                              | 0: Don't care                             | 0: Don't care                            | 0: Don't care                 |
| CONTROL.CONTROL_AVDAC2 [19]<br>AVDAC2_COMP_EN | 0: Single channel                          | 0: Single channel                         | 1: Dual channel                          | 1: Dual channel               |
| CONTROL.CONTROL_AVDAC2 [18]<br>AVDAC2_COMP_EN | 1: Chroma                                  | 1: Chroma                                 | 1: Chroma                                | 1: Chroma                     |
| CONTROL.CONTROL_AVDAC2 [17]<br>AVDAC2_COMP_EN | 0: Full scale (1.3V)                       | 0: Full scale (1.3V)                      | 0: Full scale (1.3V)                     | 0: Full scale (1.3V)          |
| CONTROL.CONTROL_AVDAC2 [16]<br>AVDAC2_COMP_EN | 0: External current reference              | 0: External current reference             | 0: External current reference            | 0: External current reference |

### 7.5.8.3 Video Encoder Programming Sequence

1. Set the DSS.VENC\_F\_CONTROL[8] RESET bit to 1 to perform a software reset of the VENC module.
2. Before any configuration change, save the DSS.DISPC\_IRQENABLE register value (DSS interrupts context), and then disable the display subsystem interrupts by setting the DSS.DISPC\_IRQENABLE register to 0x0000.
3. Configure the video encoder registers as described in [Table 7-74](#), depending on the video standard used (PAL or NTSC). The DSS.VENC\_F\_CONTROL and DSS.VENC\_SYNC\_CTRL registers must be the last ones to be changed by software.
4. Set the DSS.DISPC\_CONTROL[6] GODIGITAL bit and the DSS.DISPC\_CONTROL[1] DIGITALENABLE bit to 1.
5. Wait for the first VSYNC pulse signal.
6. Clear the SYNCLOSTDIGITAL interrupt by setting the DSS.DISPC\_IRQSTATUS[15] SYNCLOSTDIGITAL bit to 1.
7. Set the DSS.DISPC\_IRQENABLE register to the value saved in step 2 (restore the DSS interrupts context).

### 7.5.8.4 Video Encoder Register Settings

For video encoder programming, see [Table 7-74](#). This table lists the register values to use in standard applications. These values are validated programming values only for the TV display support (NTSC 601 and PAL 601 standards).

**Table 7-74. Video Encoder Register Programming Values**

| Register Name            | NTSC 601   | PAL 601    |
|--------------------------|------------|------------|
| VENC_F_CONTROL           | 0x00000000 | 0x00000000 |
| VENC_VIDOUT_CTRL         | 0x00000001 | 0x00000001 |
| VENC_SYNC_CTRL           | 0x00008040 | 0x00000040 |
| VENC_LLEN                | 0x00000359 | 0x0000035F |
| VENC_FLENS               | 0x0000020C | 0x00000270 |
| VENC_HFLTR_CTRL          | 0x00000000 | 0x00000000 |
| VENC_CC_CARR_WSS_CARR    | 0x043F2631 | 0x2F7225ED |
| VENC_C_PHASE             | 0x00000000 | 0x00000000 |
| VENC_GAIN_U              | 0x00000102 | 0x00000111 |
| VENC_GAIN_V              | 0x0000016C | 0x00000181 |
| VENC_GAIN_Y              | 0x0000012F | 0x00000140 |
| VENC_BLACK_LEVEL         | 0x00000043 | 0x0000003B |
| VENC_BLANK_LEVEL         | 0x00000038 | 0x0000003B |
| VENC_X_COLOR             | 0x00000007 | 0x00000007 |
| VENC_M_CONTROL           | 0x00000001 | 0x00000002 |
| VENC_BSTAMP_WSS_DATA     | 0x00000038 | 0x0000003F |
| VENC_S_CARR              | 0x21F07C1F | 0x2A098ACB |
| VENC_LINE21              | 0x00000000 | 0x00000000 |
| VENC_LN_SEL              | 0x01310011 | 0x01290015 |
| VENC_L21_WC_CTL          | 0x0000F003 | 0x0000F603 |
| VENC_HTRIGGER_Vtrigger   | 0x00000000 | 0x00000000 |
| VENC_SAVID_EAVID         | 0x069300F4 | 0x06A70108 |
| VENC_FLEN_FAL            | 0x0016020C | 0x00180270 |
| VENC_LAL_PHASE_RESET     | 0x00060107 | 0x00040135 |
| VENC_HS_INT_START_STOP_X | 0x008E0350 | 0x00880358 |
| VENC_HS_EXT_START_STOP_X | 0x000F0359 | 0x000F035F |
| VENC_VS_INT_START_X      | 0x01A00000 | 0x01A70000 |

**Table 7-74. Video Encoder Register Programming Values (continued)**

| Register Name                         | NTSC 601                                                              | PAL 601                                                               |
|---------------------------------------|-----------------------------------------------------------------------|-----------------------------------------------------------------------|
| VENC_VS_INT_STOP_X_VS_INT_START_Y     | 0x020701A0                                                            | 0x0000001A7                                                           |
| VENC_VS_INT_STOP_Y_VS_EXT_START_X     | 0x01AC0024                                                            | 0x01AF0000                                                            |
| VENC_VS_EXT_STOP_X_VS_EXT_START_Y     | 0x020D01AC                                                            | 0x000101AF                                                            |
| VENC_VS_EXT_STOP_Y                    | 0x00000006                                                            | 0x00000025                                                            |
| VENC_AVID_START_STOP_X                | 0x03480078                                                            | 0x03530083                                                            |
| VENC_AVID_START_STOP_Y                | 0x02060024                                                            | 0x026C002E                                                            |
| VENC_FID_INT_START_X_FID_INT_START_Y  | 0x0001008A                                                            | 0x0001008A                                                            |
| VENC_FID_INT_OFFSET_Y_FID_EXT_START_X | 0x01AC0106                                                            | 0x002E0138                                                            |
| VENC_FID_EXT_START_Y_FID_EXT_OFFSET_Y | 0x01060006                                                            | 0x01380001                                                            |
| VENC_TVDETGP_INT_START_STOP_X         | 0x00140001                                                            | 0x00140001                                                            |
| VENC_TVDETGP_INT_START_STOP_Y         | 0x00010001                                                            | 0x00010001                                                            |
| VENC_GEN_CTRL                         | 0x00F90000                                                            | 0x00FF0000                                                            |
| VENC_OUTPUT_CONTROL                   | 0x0000000A (composite video CVBS)<br>0x0000000D (split video S-video) | 0x0000000A (composite video CVBS)<br>0x0000000D (split video S-video) |
| VENC_OUTPUT_TEST                      | 0x00000000                                                            | 0x00000000                                                            |

**NOTE:** The following display controller registers must be programmed to the NTSC 601 video standard:

DSS.DISPC\_SIZE\_DIG[10:0] PPL =  $720 - 1 = 719 = 0x2CF$

DSS.DISPC\_SIZE\_DIG[26:16] LPP =  $(482/2) - 1 = 240 = 0xF0$

DSS.DISPC\_GFX\_BA0 or DSS.DISPC\_VIDn\_BA0 = Base address of even bit field data

DSS.DISPC\_GFX\_BA1 or DSS.DISPC\_VIDn\_BA1 = Base address of odd bit field data

## 7.6 Display Subsystem Use Cases and Tips

This section gives some generic use cases and tips for setting the modules of the display subsystem.

### 7.6.1 How to Configure the Scaling Unit in the DISPC Module

This section describes the scaling capability of the display controller (DISPC). The scaling unit is a part of the video pipeline used when transferring pixels from the system memory (SDRAM or on-chip SRAM) to the LCD panel or the TV set. The scaling unit consists of two scaling blocks: The vertical scaling block followed by the horizontal scaling block. The input pixel format is RGB24. In case the pixel format in system memory is not RGB, the color space conversion unit in front of the scaling unit converts the YUV pixels into RGB pixels. The two scaling units are independent: Neither of them, only one, or both can be used simultaneously.

#### 7.6.1.1 Filtering

The scaling is used to down-scale, up-scale, or process the image while keeping the same size. It is applied independently horizontally and vertically. The same filtering applies for each color component (R, G, or B).

##### 7.6.1.1.1 Vertical Filtering

The vertical filtering unit is based on a poly-phase rotation architecture with eight phases and three taps. That means that 24 coefficients are programmable.

The vertical 3-tap filtering macro architecture is shown in Figure 7-147.

**Figure 7-147. Vertical Filtering Macro Architecture (Three Taps)**



dss-112

For the 3-tap vertical up/downsampling the equation is (with the example of R component):

$$Rout(n) = \left( \sum_{i=-1}^{i=1} C_i(\Phi) \times Rin(n+i) \right) >> 7 \quad (14)$$

ds-E067

## Legend:

Rout: R component output  
 $C_i()$ :Vertical FIR coefficients  
 Rin: R component input  
 The line (n+1) is older than line (n).

**NOTE:** If the 5-tap resizer is used for RGB16 and YUV4:2:2 picture formats, the width of the input picture must be a multiple of 2 pixels and more than 5 pixels. This leads to the following register configuration:

**DISPC\_VIDn\_ATTRIBUTES[21]** VIDVERTICALTAPS == 1

**DISPC\_VIDn\_PICTURE\_SIZE[10:0]** VIDORGSIZEX 4 and even

The programmable three coefficients of the poly-phase filters are signed 8-bit values (except for the central coefficient  $C_0()$ , which is unsigned).

The vertical filtering unit can be configured to support five taps.

The vertical 5-tap filtering macro architecture is shown in [Figure 7-148](#).

**Figure 7-148. Vertical Filtering Macro Architecture (Five Taps)**



dss-113

For the 5-tap vertical up/downsampling the equation is (with the example of R component):

$$\text{Rout}(n) = \left( \sum_{i=-2}^{i=2} C_i(\Phi) \times \text{Rin}(n+i) \right) \gg 7 \quad (15)$$

dss-E066

## Legend:

Rout: R component output  
 $C_i()$ :Vertical FIR coefficients with  $C_{+2}()=C_{00}()$  and  $C_{-2}()=C_{22}()$   
 Rin: R component input  
 The line (n+1) is older than line (n).

The programmable five coefficients of the poly-phase filters are signed 8-bit values (except for the central coefficient  $C_0()$ , which is unsigned).

In case of three taps, the memory lines are merged into three lines instead of six lines (one line is used as a cache line).

The first line is duplicated to fill up the two first lines (3-tap configuration) and the three first lines (5-tap configuration).

The last line is duplicated if the scaling logic requires loading of more lines and the last line has been reached

#### **7.6.1.1.2 Horizontal Filtering**

The horizontal filtering unit is based on a poly-phase rotation architecture with eight phases and five taps. That means that 40 coefficients are programmable.

The horizontal filtering macro architecture is shown in [Figure 7-149](#).

**Figure 7-149. Horizontal Filtering Macro Architecture (Five Taps)**



dss-114

For the 5-tap horizontal up/downsampling, the equation is (with the example of R component):

$$Rout(n) = \left( \sum_{i=-3}^{i=3} C_i(\Phi) \times Rin(n+i) \right) \gg 7$$

dss-E115 (16)

Legend:

Rout: R component output

Ci(): Vertical FIR coefficients

Rin: R component input

The line (n+1) is older than line (n).

To horizontally and vertically filter the video layer, the phase is calculated separately. The programmable coefficients of the poly-phase filters are signed 8-bit values (except for the central coefficient  $C_0()$ , which is unsigned).

The first pixel is duplicated to fill up the three first pixel-buffers (5-tap configuration). The last pixel is duplicated if the scaling logic requires loading of more pixels and the last pixel has been reached

#### **7.6.1.2 Scaling Algorithms**

The up/downsampling finite state machines (FSM) below are detailed in this section.

[Figure 7-150](#) presents the vertical up/downsampling FSM.

**Figure 7-150. Vertical Up-/Down-Sampling Algorithm**

dss-116

Figure 7-151 presents the horizontal up/downsampling FSM.

**Figure 7-151. Horizontal Up-/Down-Sampling Algorithm**


dss-117

### 7.6.1.3 Scaling Settings

**NOTE:**

- In this section, the screen word refers to LCD panel or TV set.
- n indicates pipeline 0 or 1 because there are two video pipelines in the DISPC.

#### 7.6.1.3.1 Register List

The following registers define the scaling registers for the video layer n configuration:

- DSS.DISPC\_VIDn\_BAj
- DSS.DISPC\_VIDn\_ATTRIBUTES
- DSS.DISPC\_VIDn\_FIR
- DSS.DISPC\_VIDn\_ACCUI
- DSS.DISPC\_VIDn\_FIR\_COEF\_Hi
- DSS.DISPC\_VIDn\_FIR\_COEF\_HVi
- DSS.DISPC\_VIDn\_FIR\_COEF\_Vi

Table 7-75 lists the registers for programming the vertical FIR coefficients (3-tap configuration).

**Table 7-75. Vertical FIR Coefficients Corresponding Table (3-Tap Configuration)**

| $C_x()$    | VidFIRVC <sub>x</sub> () |
|------------|--------------------------|
| $C_{-1}()$ | VidFIRVC <sub>2</sub> () |
| $C_0()$    | VidFIRVC <sub>1</sub> () |

**Table 7-75. Vertical FIR Coefficients Corresponding Table (3-Tap Configuration) (continued)**

|         |                       |
|---------|-----------------------|
| $C_x()$ | $\text{VidFIRVC}_x()$ |
| $C_1()$ | $\text{VidFIRVC}_1()$ |

The corresponding registers for programming the vertical FIR coefficients (3-tap configuration) are:

- $\text{VidFIRVC}_2() = \text{DSS.DISPC_VIDn_FIR_COEF_HVi}[31:24]$  VIDFIRVC2
- $\text{VidFIRVC}_1() = \text{DSS.DISPC_VIDn_FIR_COEF_HVi}[23:16]$  VIDFIRVC1
- $\text{VidFIRVC}_0() = \text{DSS.DISPC_VIDn_FIR_COEF_HVi}[15:8]$  VIDFIRVC0

Table 7-76 lists the registers for programming the vertical FIR coefficients (5-tap configuration).

**Table 7-76. Vertical FIR Coefficients Corresponding Table (5-Tap Configuration)**

|            |                          |
|------------|--------------------------|
| $C_x()$    | $\text{VidFIRVC}_x()$    |
| $C_{22}()$ | $\text{VidFIRVC}_{22}()$ |
| $C_{-1}()$ | $\text{VidFIRVC}_{-1}()$ |
| $C_0()$    | $\text{VidFIRVC}_0()$    |
| $C_1()$    | $\text{VidFIRVC}_1()$    |
| $C_{00}()$ | $\text{VidFIRVC}_{00}()$ |

The corresponding registers for programming the vertical FIR coefficients (5-tap configuration) are:

- $\text{VidFIRVC}_{22}() = \text{DSS.DISPC_VIDn_FIR_COEF_Vi}[15:8]$  VIDFIRVC22
- $\text{VidFIRVC}_2() = \text{DSS.DISPC_VIDn_FIR_COEF_HVi}[31:24]$  VIDFIRVC2
- $\text{VidFIRVC}_1() = \text{DSS.DISPC_VIDn_FIR_COEF_HVi}[23:16]$  VIDFIRVC1
- $\text{VidFIRVC}_0() = \text{DSS.DISPC_VIDn_FIR_COEF_HVi}[15:8]$  VIDFIRVC0
- $\text{VidFIRVC}_{00}() = \text{DSS.DISPC_VIDn_FIR_COEF_Vi}[7:0]$  VIDFIRVC00

Table 7-77 lists the registers for programming the horizontal FIR coefficients (5-tap configuration).

**Table 7-77. Horizontal FIR Coefficients Corresponding Table (5-Tap Configuration)**

|            |                          |
|------------|--------------------------|
| $C_x()$    | $\text{VidFIRHC}_x()$    |
| $C_{-2}()$ | $\text{VidFIRHC}_{-4}()$ |
| $C_{-1}()$ | $\text{VidFIRHC}_{-3}()$ |
| $C_0()$    | $\text{VidFIRHC}_2()$    |
| $C_1()$    | $\text{VidFIRHC}_1()$    |
| $C_2()$    | $\text{VidFIRHC}_0()$    |

The corresponding registers for programming the vertical FIR coefficients (3-tap configuration) are:

- $\text{VidFIRHC}_4() = \text{DSS.DISPC_VIDn_FIR_COEF_HVi}[7:0]$  VIDFIRHC4
- $\text{VidFIRHC}_3() = \text{DSS.DISPC_VIDn_FIR_COEF_HVi}[31:24]$  VIDFIRHC3
- $\text{VidFIRHC}_2() = \text{DSS.DISPC_VIDn_FIR_COEF_HVi}[23:16]$  VIDFIRHC2
- $\text{VidFIRHC}_1() = \text{DSS.DISPC_VIDn_FIR_COEF_HVi}[15:8]$  VIDFIRHC1
- $\text{VidFIRHC}_0() = \text{DSS.DISPC_VIDn_FIR_COEF_HVi}[7:0]$  VIDFIRHC0

### 7.6.1.3.2 Enabling

The video pipeline #n is enabled/disabled by setting/resetting the  $\text{DSS.DISPC_VIDn_ATTRIBUTES}[0].\text{VIDENABLE}$  bit. While the video pipeline is enabled/disabled, the video layer is visible/not visible on the screen (LCD panel or TV set).

The video up/downsampling block for the video pipeline #n is programmed by setting the DSS.DISPC\_VIDn\_ATTRIBUTES[6:5] VIDRESIZEENABLE bit field:

- When the VIDRESIZEENABLE[1] bit is set to 1, the video vertical up/downsampling block is enabled. When set to 0, the vertical resize processing is disabled.
- When the VIDRESIZEENABLE[0] bit is set to 1, the video horizontal up/downsampling block is enabled. When set to 0, the horizontal resize processing is disabled.
- When the VIDRESIZEENABLE[1:0] is set to 0x3, both horizontal and vertical resize processing are enabled.

---

**NOTE:**

- Set a valid configuration before enabling the video up/downsampling block.
  - Vertical and horizontal downsampling are limited to a 0.25 resize factor. When processing a down-scaling with a vertical factor between 0.5 and 0.25, a 5-tap filter configuration must be used. See [Section 7.6.1.3.5](#) for more information concerning the filter coefficients.
- 

#### 7.6.1.3.3 Factor

The following register bit fields define the increment value of the video up/downsampling block for video pipeline n:

- Vertical up/downsampling increment value (DSS.DISPC\_VIDn\_FIR[27:16] VIDFIRVINC bit field, with n = 1 or 2): The unsigned integer value range is [1:4096]. The software calculates the value using the following equation:

$$\text{VIDFIRVINC}[11:0] = 1024 \times \frac{\text{VIDORGSIZEY}[10:0]}{\text{VIDSIZEY}[10:0]} \quad \text{dss-E118} \quad (17)$$

---

**NOTE:**

- If the VIDFIRVINC[11:0] bit field value is greater than 4096, it is clipped to 4096. If VIDSIZEY[10:0] equals 0x1, VIDSIZEY[10:0] is replaced by 0x2 in the previous equation.
- The VIDORGSIZEY[10:0] and VIDSIZEY[10:0] bit field values must be programmed with the value desired minus 1.
- Horizontal up/downsampling increment value (the DSS.DISPC\_VIDn\_FIR[11:0] VIDFIRHINC bit field, with n = 1 or 2): The unsigned integer value range is [1:4096]. The software calculates the value using the following equation:

$$\text{VIDFIRHINC}[11:0] = 1024 \times \frac{\text{VIDORGSIZEX}[10:0]}{\text{VIDSIZEX}[10:0]} \quad \text{dss-E119} \quad (18)$$

---

**NOTE:**

- If the VIDFIRHINC[11:0] bit field value is greater than 4096, it is clipped to 4096. If VIDSIZEX[10:0] equals 1, VIDSIZEX[10:0] is replaced by 2 in the previous equation.
  - The VIDORGSIZEX[10:0] and VIDSIZEX[10:0] bit field values must be programmed with the value desired minus 1.
- 

#### 7.6.1.3.4 Initial Phase

- Vertical up/downsampling accumulator value DSS.DISPC\_VIDn\_ACCU[25:16] VIDVERTICALACCU bit fields

The unsigned integer value range is [0:1023]. The accumulator value indicates on which phase the vertical filtering starts. The value 0 indicates that the phase 0 is the first phase used by the hardware to generate the first data.

- Vertical up/downsampling accumulator value DSS.DISPC\_VIDn\_ACCU[9:0] VIDHORIZONTALACCU

bit fields

The unsigned integer value range is [0:1023]. The accumulator value indicates on which phase the horizontal filtering starts. The value 0 indicates that the phase 0 is the first phase used by the hardware to generate the first data

Table 7-78 lists the vertical/horizontal accumulator values and phases

**Table 7-78. Vertical/Horizontal Accumulator Phase**

| Accumulator Value | Phases |
|-------------------|--------|
| 0                 | 0      |
| 128               | 1      |
| 256               | 2      |
| 384               | 3      |
| 512               | 4      |
| 640               | 5      |
| 768               | 6      |
| 896               | 7      |

---

**NOTE:** For LCD output, the initial phase is always 0 (horizontal and vertical.) For TV output, the vertical phases (odd and even) can be nonzero values.

---

#### 7.6.1.3.5 Coefficients

- Vertical up/downsampling coefficients ([DSS.DISPC\\_VIDn\\_FIR\\_COEF\\_HVi](#) and [DSS.DISPC\\_VIDn\\_FIR\\_COEF\\_V](#))

The 3-tap vertical up/downsampling coefficients are defined in DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_HVi](#) registers. There are eight registers for the eight phases with three coefficients for each of them so a total of 24 programmable coefficients for the vertical up/downsampling block. Each register contains two 8-bit signed coefficients and one 8-bit unsigned coefficient (central one).

In addition, there are 2-tap vertical up/downsampling coefficients defined in DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_Vi](#) registers. There are eight registers for the eight phases with two coefficients for each of them so a total of 16 programmable coefficients for the vertical up/downsampling block used in addition of the 3-tap registers defined above. Each register contains two 8-bit signed coefficients ( $C_{22}()$  and  $C_{00}()$ ).

In case of 5-tap configuration, both sets of registers, DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_HVi](#) and DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_V](#), are used. In case of 3-tap configuration, only one set of registers, DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_HV](#), is used.

- Horizontal up/downsampling coefficients ([DSS.DISPC\\_VIDn\\_FIR\\_COEF\\_Hi](#) and [DSS.DISPC\\_VIDn\\_FIR\\_COEF\\_HV](#))

The 5-tap horizontal up/downsampling coefficients are defined in DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_Hi](#) and DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_HVi](#) registers. There are eight registers for the eight phases with five coefficients for each register, for a total of 40 programmable coefficients for the horizontal up/downsampling block.

Each DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_Hi](#) register contains three 8-bit signed coefficients and one 8-bit unsigned coefficient (central one), and each DSS.[DISPC\\_VIDn\\_FIR\\_COEF\\_HVi](#) contains one 8-bit signed coefficient.

Table 7-79 through Table 7-84 give the programmable coefficients for the FIR up/downsampling filters (Max-Fauque-Berthier method).

##### 7.6.1.3.5.1 Up-Sampling

Table 7-79 gives the 24 coefficients to program the vertical upsampling (3-tap configuration).

**Table 7-79. Up-Sampling Vertical Filter Coefficients (Three Taps)**

| Phases | VidFIRVC <sub>2</sub> () | VidFIRVC <sub>1</sub> () | VidFIRVC <sub>0</sub> () |
|--------|--------------------------|--------------------------|--------------------------|
| 0      | 0                        | 128                      | 0                        |
| 1      | 3                        | 123                      | 2                        |
| 2      | 12                       | 111                      | 5                        |
| 3      | 32                       | 89                       | 7                        |
| 4      | 0                        | 64                       | 64                       |
| 5      | 7                        | 89                       | 32                       |
| 6      | 5                        | 111                      | 12                       |
| 7      | 2                        | 123                      | 3                        |

Table 7-80 gives the 40 coefficients to program the vertical upsampling (5-tap configuration).

**Table 7-80. Up-Sampling Vertical Filter Coefficients (Five Taps)**

| Phases | VidFIRVC <sub>22</sub> () | VidFIRVC <sub>2</sub> () | VidFIRVC <sub>1</sub> () | VidFIRVC <sub>0</sub> () | VidFIRVC <sub>00</sub> () |
|--------|---------------------------|--------------------------|--------------------------|--------------------------|---------------------------|
| 0      | 0                         | 0                        | 128                      | 0                        | 0                         |
| 1      | -1                        | 13                       | 124                      | -8                       | 0                         |
| 2      | -2                        | 30                       | 112                      | -11                      | -1                        |
| 3      | -5                        | 51                       | 95                       | -11                      | -2                        |
| 4      | 0                         | -9                       | 73                       | 73                       | -9                        |
| 5      | -2                        | -11                      | 95                       | 51                       | -5                        |
| 6      | -1                        | -11                      | 112                      | 30                       | -2                        |
| 7      | 0                         | -8                       | 124                      | 13                       | -1                        |

Table 7-81 gives the 40 coefficients to program the horizontal upsampling (5-tap configuration).

**Table 7-81. Up-Sampling Horizontal Filter Coefficients (Five Taps)**

| Phases | VidFIRHC <sub>4</sub> () | VidFIRHC <sub>3</sub> () | VidFIRHC <sub>2</sub> () | VidFIRHC <sub>1</sub> () | VidFIRHC <sub>0</sub> () |
|--------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|
| 0      | 0                        | 0                        | 128                      | 0                        | 0                        |
| 1      | -1                       | 13                       | 124                      | -8                       | 0                        |
| 2      | -2                       | 30                       | 112                      | -11                      | -1                       |
| 3      | -5                       | 51                       | 95                       | -11                      | -2                       |
| 4      | 0                        | -9                       | 73                       | 73                       | -9                       |
| 5      | -2                       | -11                      | 95                       | 51                       | -5                       |
| 6      | -1                       | -11                      | 112                      | 30                       | -2                       |
| 7      | 0                        | -8                       | 124                      | 13                       | -1                       |

The upsampling coefficients register configuration (vertical three taps and horizontal five taps) is the following:

- DSS.DISPC\_VIDn\_FIR\_COEF\_H0 = 0x00800000
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV0 = 0x00800000
- DSS.DISPC\_VIDn\_FIR\_COEF\_H1 = 0x0D7CF800
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV1 = 0x037B02FF
- DSS.DISPC\_VIDn\_FIR\_COEF\_H2 = 0x1E70F5FF
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV2 = 0x0C6F05FE
- DSS.DISPC\_VIDn\_FIR\_COEF\_H3 = 0x335FF5FE
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV3 = 0x205907FB
- DSS.DISPC\_VIDn\_FIR\_COEF\_H4 = 0xF74949F7
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV4 = 0x00404000

- DSS.DISPC\_VIDn\_FIR\_COEF\_H5 = 0xF55F33FB
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV5 = 0x075920FE
- DSS.DISPC\_VIDn\_FIR\_COEF\_H6 = 0xF5701EFE
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV6 = 0x056F0CFF
- DSS.DISPC\_VIDn\_FIR\_COEF\_H7 = 0xF87C0DFF
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV7 = 0x027B0300

---

**NOTE:** In this case, the DSS.DISPC\_VIDn\_FIR\_COEF\_Vi registers are not used.

---

The upsampling coefficients register configuration (both vertical and horizontal five taps) is the following:

- DSS.DISPC\_VIDn\_FIR\_COEF\_H0 = 0x00800000
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV0 = 0x00800000
- DSS.DISPC\_VIDn\_FIR\_COEF\_V0 = 0x00000000
- DSS.DISPC\_VIDn\_FIR\_COEF\_H1 = 0x0D7CF800
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV1 = 0x0D7CF8FF
- DSS.DISPC\_VIDn\_FIR\_COEF\_V1 = 0x0000FF00
- DSS.DISPC\_VIDn\_FIR\_COEF\_H2 = 0x1E70F5FF
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV2 = 0x1E70F5FE
- DSS.DISPC\_VIDn\_FIR\_COEF\_V2 = 0x0000FEFF
- DSS.DISPC\_VIDn\_FIR\_COEF\_H3 = 0x335FF5FE
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV3 = 0x335FF5FB
- DSS.DISPC\_VIDn\_FIR\_COEF\_V3 = 0x0000FBFE
- DSS.DISPC\_VIDn\_FIR\_COEF\_H4 = 0xF74949F7
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV4 = 0xF7404000
- DSS.DISPC\_VIDn\_FIR\_COEF\_V4 = 0x000000F7
- DSS.DISPC\_VIDn\_FIR\_COEF\_H5 = 0xF55F33FB
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV5 = 0xF55F33FE
- DSS.DISPC\_VIDn\_FIR\_COEF\_V5 = 0x0000FEFB
- DSS.DISPC\_VIDn\_FIR\_COEF\_H6 = 0xF5701EFE
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV6 = 0xF5701EFF
- DSS.DISPC\_VIDn\_FIR\_COEF\_V6 = 0x0000FFFE
- DSS.DISPC\_VIDn\_FIR\_COEF\_H7 = 0xF87C0DFF
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV7 = 0xF87C0D00
- DSS.DISPC\_VIDn\_FIR\_COEF\_V7 = 0x000000FF

#### 7.6.1.3.5.2 Down-Sampling

Table 7-82 gives the 24 coefficients to program the vertical downsampling (3-tap configuration).

**Table 7-82. Down-Sampling Vertical Filter Coefficients (Three Taps)**

| Phases | VidFIRVC <sub>2</sub> () | VidFIRVC <sub>1</sub> () | VidFIRVC <sub>0</sub> () |
|--------|--------------------------|--------------------------|--------------------------|
| 0      | 36                       | 56                       | 36                       |
| 1      | 40                       | 57                       | 31                       |
| 2      | 45                       | 56                       | 27                       |
| 3      | 50                       | 55                       | 23                       |
| 4      | 18                       | 55                       | 55                       |
| 5      | 23                       | 55                       | 50                       |
| 6      | 27                       | 56                       | 45                       |

**Table 7-82. Down-Sampling Vertical Filter Coefficients (Three Taps) (continued)**

| Phases | VidFIRVC <sub>2</sub> () | VidFIRVC <sub>1</sub> () | VidFIRVC <sub>0</sub> () |
|--------|--------------------------|--------------------------|--------------------------|
| 7      | 31                       | 57                       | 40                       |

Table 7-83 gives the 40 coefficients to program the vertical downsampling (5-tap configuration).

**Table 7-83. Down-Sampling Vertical Filter Coefficients (Five Taps)**

| Phases | VidFIRVC <sub>22</sub> () | VidFIRVC <sub>2</sub> () | VidFIRVC <sub>1</sub> () | VidFIRVC <sub>0</sub> () | VidFIRVC <sub>00</sub> () |
|--------|---------------------------|--------------------------|--------------------------|--------------------------|---------------------------|
| 0      | 0                         | 36                       | 56                       | 36                       | 0                         |
| 1      | 4                         | 40                       | 55                       | 31                       | -2                        |
| 2      | 8                         | 44                       | 54                       | 27                       | -5                        |
| 3      | -12                       | 48                       | 53                       | 22                       | -7                        |
| 4      | -9                        | 17                       | 52                       | 51                       | 17                        |
| 5      | -7                        | 22                       | 53                       | 48                       | 12                        |
| 6      | -5                        | 27                       | 54                       | 44                       | 8                         |
| 7      | -2                        | 31                       | 55                       | 40                       | 4                         |

Table 7-84 gives the 40 coefficients to program the horizontal downsampling (5-tap configuration).

**Table 7-84. Down-Sampling Horizontal Filter Coefficients (Five Taps)**

| Phases | VidFIRHC <sub>4</sub> () | VidFIRHC <sub>3</sub> () | VidFIRHC <sub>2</sub> () | VidFIRHC <sub>1</sub> () | VidFIRHC <sub>0</sub> () |
|--------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|
| 0      | 0                        | 36                       | 56                       | 36                       | 0                        |
| 1      | 4                        | 40                       | 55                       | 31                       | -2                       |
| 2      | 8                        | 44                       | 54                       | 27                       | -5                       |
| 3      | -12                      | 48                       | 53                       | 22                       | -7                       |
| 4      | -9                       | 17                       | 52                       | 51                       | 17                       |
| 5      | -7                       | 22                       | 53                       | 48                       | 12                       |
| 6      | -5                       | 27                       | 54                       | 44                       | 8                        |
| 7      | -2                       | 31                       | 55                       | 40                       | 4                        |

The downsampling coefficients register configuration (vertical three taps and horizontal five taps) is the following:

- DSS.DISPC\_VIDn\_FIR\_COEF\_H0 = 0x24382400
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV0 = 0x24382400
- DSS.DISPC\_VIDn\_FIR\_COEF\_H1 = 0x28371FFE
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV1 = 0x28391F04
- DSS.DISPC\_VIDn\_FIR\_COEF\_H2 = 0x2C361BFB
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV2 = 0x2D381B08
- DSS.DISPC\_VIDn\_FIR\_COEF\_H3 = 0x303516F9
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV3 = 0x3237170C
- DSS.DISPC\_VIDn\_FIR\_COEF\_H4 = 0x11343311
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV4 = 0x123737F7
- DSS.DISPC\_VIDn\_FIR\_COEF\_H5 = 0x1635300C
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV5 = 0x173732F9
- DSS.DISPC\_VIDn\_FIR\_COEF\_H6 = 0x1B362C08
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV6 = 0x1B382DFB
- DSS.DISPC\_VIDn\_FIR\_COEF\_H7 = 0x1F372804

- 
- DSS.DISPC\_VIDn\_FIR\_COEF\_HV7 = 0x1F3928FE
- 

**NOTE:**

- In this case, the DSS.DISPC\_VIDn\_FIR\_COEF\_Vi registers are not used.
  - In this case, the downsampling factor must be higher than 1/2.
- 

The downsampling coefficients register configuration (both the vertical and the horizontal five taps) is the following:

- DSS.DISPC\_VIDn\_FIR\_COEF\_H0 = 0x24382400
  - DSS.DISPC\_VIDn\_FIR\_COEF\_HV0 = 0x24382400
  - DSS.DISPC\_VIDn\_FIR\_COEF\_V0 = 0x00000000
  - DSS.DISPC\_VIDn\_FIR\_COEF\_H1 = 0x28371FFE
  - DSS.DISPC\_VIDn\_FIR\_COEF\_HV1 = 0x28371F04
  - DSS.DISPC\_VIDn\_FIR\_COEF\_V1 = 0x000004FE
  - DSS.DISPC\_VIDn\_FIR\_COEF\_H2 = 0x2C361BFB
  - DSS.DISPC\_VIDn\_FIR\_COEF\_HV2 = 0x2C361B08
  - DSS.DISPC\_VIDn\_FIR\_COEF\_V2 = 0x000008FB
  - DSS.DISPC\_VIDn\_FIR\_COEF\_H3 = 0x303516F9
  - DSS.DISPC\_VIDn\_FIR\_COEF\_HV3 = 0x3035160C
  - DSS.DISPC\_VIDn\_FIR\_COEF\_V3 = 0x00000CF9
  - DSS.DISPC\_VIDn\_FIR\_COEF\_H4 = 0x11343311
  - DSS.DISPC\_VIDn\_FIR\_COEF\_HV4 = 0x113433F7
  - DSS.DISPC\_VIDn\_FIR\_COEF\_V4 = 0x0000F711
  - DSS.DISPC\_VIDn\_FIR\_COEF\_H5 = 0x1635300C
  - DSS.DISPC\_VIDn\_FIR\_COEF\_HV5 = 0x163530F9
  - DSS.DISPC\_VIDn\_FIR\_COEF\_V5 = 0x0000F90C
  - DSS.DISPC\_VIDn\_FIR\_COEF\_H6 = 0x1B362C08
  - DSS.DISPC\_VIDn\_FIR\_COEF\_HV6 = 0x1B362CFB
  - DSS.DISPC\_VIDn\_FIR\_COEF\_V6 = 0x0000FB08
  - DSS.DISPC\_VIDn\_FIR\_COEF\_H7 = 0x1F372804
  - DSS.DISPC\_VIDn\_FIR\_COEF\_HV7 = 0x1F3728FE
  - DSS.DISPC\_VIDn\_FIR\_COEF\_V7 = 0x0000FE04
- 

**NOTE:** This configuration must be used for vertical downsampling factors between 1/2 and 1/4

---

### 7.6.2 Display Low-Power Refresh Settings

This section describes the display low-power refresh application on the device. The display subsystem remains active while saving power by putting unused power domains and unused modules into idle mode. This process can be expanded to include the screen saver mode in which the MPU subsystem wakes up to update the frame buffer and then returns to idle mode. On the device platform, where power consumption is of high importance, the display modes must be configured properly to achieve optimal power savings

The display low-power refresh mode can be used in the following scenarios:

- During the period of time when there is no application running and the backlight turns off.
- Once the backlight turns off, the LCD display can be shut off or can be refreshed showing the time and date. The screen saver mode can be used to update the time every minute.

This section discusses the methodology for finding optimal power savings. These settings are detailed for a 16-bit, 240 x 320 pixel QVGA LCD.

### 7.6.2.1 Display Low-Power Refresh Overview

When the device is not in idle mode, meaning all clocks are on and the power is applied to all power domains, the following activity typically occurs with respect to the display subsystem:

- The MPU subsystem is processing
- The display subsystem DMA controller is moving data from the SDRAM frame buffer location to the display subsystem internal FIFO.
- The LCD data is being sent from the internal FIFO to the display panel.

When the MPU goes into idle mode, the following activity occurs:

- The display subsystem DMA controller remains active, moving data from the SDRAM frame buffer to the internal FIFO.
- The SDRAM will go in and out of self-refresh between transfers.
- The display subsystem internal FIFO will continue to send LCD data to the display panel.

This procedure is named as the display low-power refresh scenario.

---

**NOTE:** In the device, the display subsystem has its own power domain (the DSS power domain).

---

### 7.6.2.2 Display Subsystem Clock

#### 7.6.2.2.1 Display Subsystem Clock Configuration

The display subsystem contains two possible functional clock sources, DSS functional clock 1 (DSS1\_ALWON\_FCLK) and DSI PLL functional clock 1 (DSI1\_PLL\_FCLK):

- DSS1\_ALWON\_FCLK is sourced from DPLL4 (DPLL4\_ALWON\_FCLK), with several multipliers available and is configured in the PRCM.CM\_CLKSEL\_DSS[4:0] CLKSEL\_DSS1 bit field.
- DSI1\_PLL\_FCLK is one of the two output clocks from the DSI PLL.

The pixel clock is set as either DSS1\_ALWON\_FCLK or DSI1\_PLL\_FCLK by configuring the DSS.[DSS\\_CONTROL\[0\]](#) DISPC\_CLK\_SWITCH bit

---

**NOTE:** When the DSI PLL is in bypass mode, the DSI1\_PLL\_FCLK clock is the DSS2\_ALWON\_FCLK clock. This ensures the backward compatibility with OMAP2 devices.

---

The LCD logic clock is determined by the DSS.[DISPC\\_DIVISOR\[23:16\]](#) LCD bit field. This divisor is used on the DSS functional clock that is selected in the [DSS\\_CONTROL](#) register (either DSS1\_ALWON\_FCLK or DSS2\_ALWON\_FCLK). This LCD divisor selects the logical clock frequency which is used to clock the logic in the display subsystem. For some applications there is a required minimum logical clock frequency. The lower the logical clock frequency then the lower the power consumption.

The pixel clock is determined by setting the DSS.[DISPC\\_DIVISOR\[7:0\]](#) PCD bit field. This divisor is used on the LCD logic clock.

In the following example, the DPLL4 clock (DPLL4\_ALWON\_FCLK) is enabled and running at 266 MHz:

The PRCM.CM\_CLKSEL2\_PLL[19:8] PERIPH\_DPLL\_MULT bit field is set to 0x4 and the PRCM.CM\_CLKSEL2\_PLL[6:0] PERIPH\_DPLL\_DIV bit field is set to 0x1 (DPLL4 x 4/(1+1)):

$$\text{DPLL4\_ALWON\_FCLKOUT} = \text{DPLL4\_ALWON\_FCLK}(266\text{MHz}) \times 4/2 = 532 \text{ MHz}$$

---

**NOTE:** The DPLL4\_ALWON\_FCLOUT clock is an internal clock in DPLL4 module after the DPLL\_MULT and DPLL\_DIV stages. The DPLL4\_M4\_CLK clock is one of the DPLL4 output clocks and is the clock source for DSS1\_ALWON\_FCLK.

---

The DSS.DSS\_CONTROL[0] DSS\_CLK\_SWITCH bit is set to 0x0 to select DSS1\_ALWON\_FCLK as the display subsystem functional clock:

$$\text{DSS1\_ALWON\_FCLK} = \text{DPLL4\_M4\_CLK}$$

The PRCM.CM\_CLKSEL\_DSS[4:0] CLKSEL\_DSS1 bit field is set to 0x08:

$$\text{DSS1\_ALWON\_FCLK} = \frac{\text{DPLL4\_ALWON\_FCLKOUT (532MHz)}}{8} = 66.5 \text{ MHz}$$

dss-E120 (19)

The DSS.DISPC\_DIVISOR[23:16] LCD bit field is set to 0x01:

$$\text{LogicClock} = \frac{\text{DSS1\_ALWON\_FCLK(66.5MHz)}}{1} = 66.5 \text{ Mhz}$$

dss-E121 (20)

The DSS.DISPC\_DIVISOR[6:0] PCD bit field is set to 0x0C:

$$\text{PixelClock} = \frac{\text{LogicClock(66.5MHz)}}{12} = 5.54 \text{ Mhz}$$

dss-E122 (21)

#### 7.6.2.2.1.1 Pixel Clock Frequency Settings to Reduce Power Consumption

Power consumption is reduced when a low pixel clock frequency is used. If the clock frequency is set too low, however, the frames-per-second (FPS) are reduced. This can result in visible flickering on the screen each time the screen is refreshed. To avoid electrical polarization problems, refer to the appropriate LCD panel datasheet to determine the maximum range of pixel clock frequency variation. To save power, therefore, the pixel clock frequency during low-power mode must be set as low as possible, but high enough to eliminate visible flickering

#### 7.6.2.2.1.2 Display Subsystem Divider Settings to Reduce Power Consumption

The pixel clock is determined by the DSS.DISPC\_DIVISOR[7:0] PCD and DSS.DISPC\_DIVISOR[23:16] LCD settings. In most cases, the LCD[7:0] bit field is set to 0x1 and the PCD[7:0] bit field is used as the main divider. To reduce power consumption, software users should investigate if the DSS.DISPC\_DIVISOR[23:16] LCD bit field can be set to a value other than 0x1 and then decrease DSS.DISPC\_DIVISOR[7:0] PCD bit field value. For example, if the desired pixel clock is 1.625 MHz with a 13-MHz functional clock, then this pixel clock can be achieved by setting DSS.DISPC\_DIVISOR[23:16] LCD to 0x1 and DSS.DISPC\_DIVISOR[7:0] PCD to 0x8. The same pixel clock can be achieved by setting DSS.DISPC\_DIVISOR[23:16] LCD to 0x2 and DSS.DISPC\_DIVISOR[7:0] PCD to 0x4.

#### 7.6.2.2.2 Display Subsystem Clock Enable

To take the DSS out of reset, all DSS-related clocks must be enabled, and the DPLL4 clock must be enabled. After taking the DSS out of reset, these clocks can be disabled if they are not used. The following clocks must be enabled before the DSS can come out of reset:

- PRCM.CM\_FCLKEN\_DSS[0] EN\_DSS1 = 0x1
- PRCM.CM\_FCLKEN\_DSS[1] EN\_DSS2 = 0x1
- PRCM.CM\_FCLKEN\_DSS[2] EN\_TV = 0x1
- PRCM.CM\_ICLKEN\_DSS[0] EN\_DSS = 0x1
- PRCM.CM\_CLKEN\_PLL[18:16] EN\_PERIPH\_DPLL = 0x7

Once these clocks are enabled, the display subsystem can be taken out of reset.

The following sections explain the display low-power mode configuration options, which are determined by product requirements (LCD panel type).

### 7.6.2.3 DPLL4 in Low-Power Mode

For optimal power savings in low-power mode, DPLL4 can be put into low-power stop mode. Thus the DSS1\_ALWON\_FCLK clock cut when DPLL4 is in low-power stop mode. Software users must switch from DSS1\_ALWON\_FCLK to DS1\_PLL\_FCLK by setting the DSS.[DSS\\_CONTROL\[0\]](#) DISPC\_CLK\_SWITCH bit to 0x1.

---

**NOTE:** Before switching to DS1\_PLL\_FCLK, the DSI PLL and the HS divider must be programmed and the DSI PLL must be locked.

---

DPLL4 can be put in low-power stop mode in either of the following methods:

- Manually: When setting the PRCM.CM\_CLKEN\_PLL[18:16] EN\_PERIPH\_DPLL bit to 0x1.
- Automatically: When setting the PRCM.CM\_AUTOIDLE\_PLL[5:3] AUTO\_PERIPH\_DPLL bit field to 0x1. DPLL4 is automatically put in low-power stop mode when none of the 96- MHz and 54- MHz clocks are required anymore. DPLL4 is also restarted automatically.

Software users must remember to change the clock configuration after enabling DPLL4 when leaving low-power mode by setting the DSS.[DSS\\_CONTROL\[0\]](#) DISPC\_CLK\_SWITCH bit to 0x0. The DSS1\_ALWON\_FCLK clock will be selected.

Lock time must be considered before disabling the DSS1\_ALWON\_FCLK clock.

### 7.6.2.4 Autoidle and Smart Idle

#### 7.6.2.4.1 Autoidle

To further save power consumption, the autoidle feature at the module can be enabled for the active modules. For example, the PRCM and the system control modules are active during this mode. By enabling the autoidle feature, the clocks at the module level are gated when they are not needed.

The RFBI, display controller, and L4 interfaces can internally gate their clocks to decrease power consumption if no transaction is present on the related bus. The following bits must be set to enable this functionality:

- DSS.[DSS\\_SYSCONFIG\[0\]](#) AUTOIDLE bit (1: Autoidle; 0: Clock free-running) for the display subsystem
- DSS.[RFBI\\_SYSCONFIG\[0\]](#) AUTOIDLE bit (1: Autoidle; 0: Clock free-running) for the RFBI
- DSS.[DISPC\\_SYSCONFIG\[0\]](#) AUTOIDLE bit (1: Autoidle; 0: Clock free-running) for the display controller
- DSS.[DISPC\\_CONFIG\[9\]](#) FUNCATED bit (1: Functional clocks gated enabled, 0: Functional clocks gated disabled) for the display controller

#### 7.6.2.4.2 Smart-Idle

The smart-idle feature can be enabled to allow the module to enter idle when the clocks are not needed. The smart-idle feature can be enabled for the display subsystem submodules to further save power consumption:

- Display subsystem: DSS.[DSS\\_SYSCONFIG\[4:3\]](#) SIDLEMODE
- Display controller: DSS.[DISPC\\_SYSCONFIG\[4:3\]](#) SIDLEMODE
- RFBI: DSS.[RFBI\\_SYSCONFIG\[4:3\]](#) SIDLEMODE

### 7.6.2.5 FIFO Thresholds

The display subsystem internal FIFO is used to move data to the LCD panel. This FIFO is filled by the display subsystem DMA controller. The DMA controller is triggered to start and stop based on two thresholds:

- DSS.[DISPC\\_GFX\\_FIFO\\_THRESHOLD\[11:0\]](#) GFXFIFOLOWTHRESHOLD
- DSS.[DISPC\\_GFX\\_FIFO\\_THRESHOLD\[27:16\]](#) GFXFIFOHIGHTHRESHOLD

When the level of the FIFO reaches the low threshold, the internal DMA controller begins to fill the FIFO With the data in the frame buffer. Once the amount of pixel data reaches the high threshold, the internal DMA controller stops.

#### 7.6.2.5.1 FIFO Threshold Settings to Reduce Power Consumption

Power consumption is reduced by increasing the difference between the high and low FIFO threshold levels, thereby leaving the SDRAM in self-refresh for a longer period of time. To perform this reduction, consider the following:

- The low FIFO threshold level must be as low as possible, but not low enough to cause any underflow.
- The high FIFO threshold level must not exceed the FIFO size minus one burst. A value above this limit results in the DMA controller trying to fill the FIFO to a level that cannot be reached, which will increase power consumption.
- The difference between high and low FIFO threshold levels must not be less than one burst size. These settings do not reduce power consumption because the SDRAM never goes into self-refresh, but they will avoid underflow.

#### 7.6.2.6 Vertical and Horizontal Timings

The vertical and horizontal timings and the pixel clock speed determine the number of frames updated per second. [Figure 7-152](#) shows the timings for a 240 x 320 pixel QVGA LCD panel. If the pulse width (also called blanking) and the front porch parameters are increased, more setup time is added before the data is transferred. This additional time is beneficial for delaying the data transfer if the data is not ready because of bandwidth limitations. Care must be taken to determine the fps when modifying these parameters.

Use the following formula to determine the fps for a 240 x 320 QVGA LCD:

$$f_{ps} = \frac{1}{[(Hsw + 1) + (Hfp + 1) + 240 + (Hbp + 1)] \times [(Vsw + 1) + Vfp + 320 + Vbp] \times (PCLK)}$$
dss-E123 (22)

With:

- Hsw: DSS.[DISPC\\_TIMING\\_H](#)[7:0] HSW bit field value
- Hfp: DSS.[DISPC\\_TIMING\\_H](#)[19:8] HFP bit field value
- Hbp: DSS.[DISPC\\_TIMING\\_H](#)[31:20] HBP bit field value
- Vsw: DSS.[DISPC\\_TIMING\\_V](#)[7:0] VSW bit field value
- Vfp: DSS.[DISPC\\_TIMING\\_V](#)[19:8] VFP bit field value
- Vbp: DSS.[DISPC\\_TIMING\\_V](#)[31:20] VBP bit field value
- PCLK: Pixel clock period

The horizontal (Hsw) and vertical (Vsw) pulse widths and the horizontal front (Hfp) and back (Hbp) porches are increased by 1 because the value is programmed as the desired value minus 1.

**Figure 7-152. QVGA LCD Timings**


dss-124

The fps for the example of 6-MHz pixel clock with the setting shown in [Figure 7-152](#) is as follows:

$$fps = \frac{1}{[(2+1) + 4 + 240 + 2] \times [(2+1) + 9 + 320 + 6] \times 166.67 \times 10^{-9}}$$

dss-E125

$$fps = 71.57\text{Hz}$$

(23)

#### 7.6.2.6.1 Horizontal and Vertical Timing Settings to Reduce Power Consumption

The number of fps that the screen is refreshed is also determined by the vertical and horizontal timings. Consequently, longer timings between frames (blanking periods) reduce the fps and reduce average power consumption. Shorter blanking periods increase fps and increases power consumption. If the blanking between frames is too small, a FIFO underflow may occur.

#### 7.6.3 How to Configure the DSI PLL in Video Mode

[Figure 7-153](#) shows a global overview of the DSI clock tree when used in video mode.

**Figure 7-153. DSI Clock Tree in Video Mode**


dss-300

The settings of the DSI PLL registers can be summarized by the following equations.

**Equation 1**

$$N * T_{VP\_CLK} = T_L * T_{TxByteClkHS} \quad (24)$$

dss-301

where

$$T_L = T_{HS} + HSA_{DSI} + T_{HE} + HFP_{DSI} + (WC + 6)/NDL + HBP_{DSI}$$

$N$  is an integer

$NDL$ : Number of data lane

$WC$ : Word count or payload in bytes

$T_{HS}$  and  $T_{HE}$  are equal to  $4/NDL$  and 0 if they are disabled.

$HSA_{DSI}$  is HSA period in video mode.

$T_{HS}$  is the length of HSYNC start short packet in number of byte clock cycles (TxByteClkHS).

$T_{HE}$  is the length of HSYNC end short packet in number of byte clock cycles (TxByteClkHS).

$HBP_{DSI}$  is HBP period in video mode.

$HFP_{DSI}$  is HFP period in video mode.

---

**NOTE:**  $HSA_{DSI}$  timing is not used and does not have to be programmed when HE short packet is not generated.

---

**Equation 2**

$$R = T_{TxByteClkHS} / T_{VP\_PCLK} \quad (25)$$

dss-302

To synchronize DISPC and DSI Protocol Engine, users should follow the ratio  $R$  between TxByteClkHS and VP\_PCLK as listed in [Table 7-85](#).

**Table 7-85. Ratio R**

| Number of data lanes | Pixel format  | Ratio R |
|----------------------|---------------|---------|
| 1                    | 16-bits pixel | 1/2     |
| 1                    | 18-bits pixel | 4/9     |
| 1                    | 24-bits pixel | 1/3     |
| 2                    | 16-bits pixel | 1       |
| 2                    | 18-bits pixel | 8/9     |
| 2                    | 24-bits pixel | 2/3     |

All cases are covered by:

$$F_{VP\_PCLK} * bits\_per\_pixel = F_{TxByteClkHS} * NDL * 8 \quad (26)$$

dss-310

**Equation 3**

$$(HSA_{DISPC} + HFP_{DISPC} + PPL + HBP_{DISPC}) * T_{VP\_PCLK} = (4/NDL + HFP_{DSI} + (WC + 6)/NDL + HBP_{DSI}) * T_{TxByteClkHS} \quad (26)$$

dss-303

**Equation 4**

$$HFP_{DSI} = ((HFP_{DISPC} * bits\_per\_pixel) / (NDL * 8)) - (2 / NDL) \quad (27)$$

dss-309

**Example**

The desired performances are:

- Clock lane at 150 MHz
- RGB24-888

- 1-data lane
- LCD size 480\*640 with  $HSA_{DISP} = HFP_{DISP} = HBP_{DISP} = 20$ ,  $VSA_{DISP} = VFP_{DISP} = VBP_{DISP} = 2$

**Step 1. Determine REGM and REGN**

To obtain correct stability, Fint must be kept between 0.032 MHz and 52 MHz . In this case, Fint is maintained at 2 MHz. For more information, see the DSI PLL programming model.

$$\text{REGN} = \left( \frac{F_{\text{DSI\_PLL\_REFCLK}}}{F_{\text{int}}} \right) - 1$$

$$\text{REGN} = 12$$

$$\text{REGM} = (\text{REGN} + 1) * F_{\text{CLKIN4DDR}} / (2 * F_{\text{DSI\_PLL\_REFCLK}})$$

$$\text{REGM} = 150$$

dss-318

Where  $DSS2\_ALWON\_FCLK= 26$  MHz is used as a reference clock for  $F_{\text{DSI\_PLL\_REFCLK}}$

**Step 2. Determine VP\_PCLK and TxByteClkHS clocks.**

$TxByteClkHS$  frequency is equal to 37.5 MHz. With ratio R equal to 1/3,  $VP\_PCLK$  frequency is equal to 12.5 MHz. The frame rate can be estimated by:

$$\text{Frame rate} = F_{\text{VP\_PCLK}} / (HSA_{\text{DISPC}} + HFP_{\text{DISPC}} + PPL + HBP_{\text{DISPC}}) * (VSA_{\text{DISPC}} + VFP_{\text{DISPC}} + LPP + VBP_{\text{DISPC}})$$

$$\text{Frame rate} = 12.5 \text{ MHz} / (540) * (646)$$

$$\text{Frame rate} = 35.83 \text{ frame/sec}$$

dss-323

**Step 3. Determine LCD, PCD and REGM3**

$$T_{\text{CLKIN4DDR}} = T_{\text{TxByteClkHS}} / 16 = T_{\text{VP\_PCLK}} / ((\text{REGM3} + 1) * \text{LCD} * \text{PCD})$$

$$((\text{REGM3} + 1) * \text{LCD} * \text{PCD}) = 16 * 3$$

dss-315

If LCD and PCD are set to 1 and 3 respectively, REGM3 is equal to 15.

**Step 4. Verify N as integer**

Firstly, TL must be determined

$$(HSA_{\text{DISPC}} + HFP_{\text{DISPC}} + PPL + HBP_{\text{DISPC}}) * T_{\text{VP\_PCLK}} / T_{\text{TxByteClkHS}} = T_L = 1620$$

dss-316

From **Equation 1**,

$$N * T_{\text{VP\_CLK}} = T_L * T_{\text{TxByteClkHS}}$$

$$N = T_{\text{TxByteClkHS}} * T_L / T_{\text{VP\_CLK}} = T_L / (R * \text{PCD})$$

$$N = 14580$$

N is an integer.

**Step 5. Determine HFP and HBP of the DSI protocol engine**

From **Equation 3**,

$$(HSA_{\text{DISPC}} + HFP_{\text{DISPC}} + PPL + HBP_{\text{DISPC}}) * T_{\text{VP\_PCLK}} / T_{\text{TxByteClkHS}} - (4/\text{NDL} + (\text{WC} + 6)/\text{NDL}) = HFP_{\text{DSI}} + HBP_{\text{DSI}}$$

$$HFP_{\text{DSI}} + HBP_{\text{DSI}} = 170$$

dss-317

From **Equation 4**,

$$HFP_{\text{DSI}} = ((HFP_{\text{DISPC}} * \text{bits\_per\_pixel}) / \text{NDL} * 8) - (2 / \text{NDL})$$

$$HFP_{\text{DSI}} = 58$$

$$HBP_{\text{DSI}} = 170 - 58 = 112$$

dss-321

### 7.6.4 DSI Video Mode Using the DISPC Video Port

This section details the basic programming model of video mode using the DISPC video port.

The DSI interface is connected to an external MIPI display controller and the following parameters are used:

- 1 data lane: NDL = 1
- Clock lane at 150 MHz (DSI\_DDR\_CLK)
- LCD size is 640 x 480:
  - 480 pixels per line (PPL)
  - 680 lines per panel (LPP)
- Display controller input format: YUV
- Display controller output format: RGB888, that is 24 bits per pixel (BPP)
- Word Count: WC = 3 x PPL
- DSS2\_ALWON\_FLCK=26 MHz is used as a reference clock for DSI PLL
- Virtual channel 0 (VC0) is used for video mode.
- Interleaving is not used.
- It is assumed that all modules used in these programming models are in after-POR state.

[Figure 7-154](#) is an overview of the connections in the display subsystem.

**Figure 7-154. Overview**


dss-330

The steps listed in [Table 7-86](#) are described in the following sections.

**Table 7-86. Main Steps**

| Steps                                          | Section                                                                                 |
|------------------------------------------------|-----------------------------------------------------------------------------------------|
| Configure DSS clocks                           | <a href="#">Section 7.6.4.1, Display Subsystem Clock Configuration</a>                  |
| Configure the DSI and DSI PLL                  | <a href="#">Section 7.6.4.2, Configure DSI, DSI PLL and Complex I/O</a>                 |
| Configure the external MIPI display controller | <a href="#">Section 7.6.4.3, Initialization of the External MIPI Display Controller</a> |
| Configure the DISPC                            | <a href="#">Section 7.6.4.4, Configure the DISPC</a>                                    |
| Enable video mode using the DISPC video port   | <a href="#">Section 7.6.4.5, Enable Video Mode Using the DISPC Video Port</a>           |

The programming model must be followed in the order of the following sections.

#### 7.6.4.1 Display Subsystem Clock Configuration

[Table 7-87](#) lists the steps required to enable the clocks.

**Table 7-87. PRCM Registers**

| Steps                                                                                                                | Registers                      | Value |
|----------------------------------------------------------------------------------------------------------------------|--------------------------------|-------|
| Set the divided DPLL value for DSS1.                                                                                 | CM_CLKSEL_DSS[4:0] CLKSEL_DSS1 | 0x9   |
| Disable autoidle mode.                                                                                               | CM_AUTOIDLE_DSS[31:0]          | 0x0   |
| Domain sleep is disabled.                                                                                            | CM_SLEEPDEP_DSS[31:0]          | 0x0   |
| Automatic transition between active and inactive are disabled.                                                       | CM_CLKSTCTRL_DSS[31:0]         | 0x0   |
| Enable DSS1, DSS2 and TV clock (DSS1_ALWON_FCLK, DSS2_ALWON_FCLK and TV_CLK). TV_CLK is only need for correct Reset. | CM_FCLKEN_DSS[31:0]            | 0x7   |
| Enable the subsystem interface clock (DSS_L3_ICLK and DSS_L4_ICLK).                                                  | CM_ICLKEN_DSS[31:0]            | 0x1   |

#### 7.6.4.2 Configure DSI, DSI PLL and Complex I/O

##### 7.6.4.2.1 Reset DSI Modules

Table 7-88 lists the steps required to reset the DSI modules.

**Table 7-88. Resets**

| Steps                                                                             | Registers                   | Value    |
|-----------------------------------------------------------------------------------|-----------------------------|----------|
| Reset IRQ status.                                                                 | DSI_IRQSTATUS[31:0]         | 0x0      |
| OCP and functional clock are maintained during wakeup, smart idle, and reset DSI. | DSI_SYSCONFIG[31:0]         | 0x312    |
| Wait until RESET_DONE ≠ 0.                                                        | DSI_SYSSTATUS[0] RESET_DONE | Read 0x1 |

##### 7.6.4.2.2 Set Up DSI DPLL

Table 7-89 lists the steps required to configure DSI PLL.

**Table 7-89. DSI PLL Configuration Registers**

| Steps                                                                                                                                                                                                                     | Registers                                         | Value       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|-------------|
| Turn on PLL and HSDIVIDER.                                                                                                                                                                                                | DSI_CLK_CTRL[31:30] PLL_PWR_CTRL                  | 0x2         |
| Wait until PLL_PWR_STATUS = 0x2.                                                                                                                                                                                          | DSI_CLK_CTRL[29:28] PLL_PWR_STATUS                | Read 0x2    |
| See the calculation following this table.                                                                                                                                                                                 | DSI_PLL_CONFIGURATION1[26:23]<br>DSIPROTO_CLK_DIV | 5           |
| See the calculation following this table.                                                                                                                                                                                 | DSI_PLL_CONFIGURATION1[22:19]<br>DSS_CLOCK_DIV    | 15          |
| See the calculation following this table.                                                                                                                                                                                 | DSI_PLL_CONFIGURATION1[18:8]<br>DSI_PLL_REGM      | 150         |
| See calculation following this table.                                                                                                                                                                                     | DSI_PLL_CONFIGURATION1[7:1]<br>DSI_PLL_REGN       | 12          |
| Enable PLLStopMode.                                                                                                                                                                                                       | DSI_PLL_CONFIGURATION1[0]                         | 0x1         |
| The DSI protocol engine clock divider, DSS clock divider, CLKIN4DDR, and PLL reference clock are enabled. PLL internal reference frequency is between 0.032 MHz and 52 MHz.                                               | DSI_PLL_CONFIGURATION2[31:0]                      | 0x5600E     |
| Manual mode                                                                                                                                                                                                               | DSI_PLL_CONTROL[31:0]                             | 0x0         |
| Request PLL locking sequence.                                                                                                                                                                                             | DSI_PLL_GO[0] DSI_PLL_GO                          | 0x1         |
| Read until DSI_PLL_GO = 0                                                                                                                                                                                                 | DSI_PLL_GO[0] DSI_PLL_GO                          | Read 0x0    |
| PLL is locked.                                                                                                                                                                                                            | DSI_PLL_STATUS[1] DSI_PLL_LOCK                    | Read 0x1    |
| Turn on PLL and HSDIVIDER; the DSI functional clock 30-MHz sync is rising/rising; the DSIStopClk signal is automatically asserted/deasserted; the L3_ICLK clock to the DSI complex I/O is not gated; and LPCLKDIVISOR = 8 | DSI_CLK_CTRL[31:0]                                | 0x8024 4008 |

- Calculate the divider value for the DSI protocol engine clock source:

$$\text{RegM4} = \text{FCLKIN4DDR}/\text{DSI2\_PLL\_FCLK} - 1$$

$$\text{FCLKIN4DDR} = 4 \times \text{FCLKIN}$$

$$\text{RegM4} = 5$$

- Determine LCD, PCD, and REGM3:

Calculate the divider value for DSS clock source: Same as Step 3.

$$\text{RegM3} = ((\text{BPP} \times 2)/(\text{DISPC\_LCD} \times \text{DISPC\_PCD} \times \text{NDL})) - 1$$

$$\text{RegM3} = 15$$

dss-E127

- Calculate N Divider for PLL:

$$\text{FCLKIN4DDR} = \text{FCLKIN} \times 4$$

$$\text{RegN} = (\text{FDSI\_PLL\_REFCLK}/\text{FINT}) - 1$$

$$\text{FDSI\_PLL\_REFCLK} = 26 \text{ MHz (system clock)}$$

$$\text{Fint} = 2 \text{ MHz (reduce PLL lock time)}$$

$$\text{RegN} = 12$$

dss-E128

- Calculate M divider for PLL:

$$\text{RegM} = ((\text{RegN} + 1) \times (\text{FCLKIN4DDR} / (2 \times \text{FDSI\_PLL\_REFCLK})))$$

$$\text{FCLKIN4DDR} = 4 \times 150 \text{ MHz}$$

$$\text{RegM} = 150$$

dss-E129

#### **7.6.4.2.3 Switch to DSI PLL Clock Source**

Select the DSI\_PLL1 clock as the DISPC functional clock, and select the DSI\_PLL2 clock as the DSI functional clock: Set [DSS\\_CONTROL](#) to 0x3.

#### **7.6.4.2.4 Set Up DSI Protocol Engine**

##### **7.6.4.2.4.1 Set Up DSI Control Registers**

[Table 7-90](#) lists the steps to set up the DSI control registers. [Table 7-91](#) lists the steps to set up the DSI complex I/O registers.

**Table 7-90. DSI Control Registers**

| Steps                                                                                          | Registers                                       | Value    |
|------------------------------------------------------------------------------------------------|-------------------------------------------------|----------|
| Enable SYNCLOST event.                                                                         | <a href="#">DSI IRQENABLE[31:0]</a>             | 0x4 0000 |
| Set PACKET_SENT_IRQ_EN.                                                                        | <a href="#">DSI_VCO_IRQENABLE[31:0]</a>         | 0x4      |
| While the HSYNC START pulse is detected, the associated short packet HSYNC START is generated. | <a href="#">DSI_CTRL[17]</a> VP_HSYNC_START     | 0x1      |
| While the VSYNC START pulse is detected, the associated short packet VSYNC START is generated. | <a href="#">DSI_CTRL[15]</a> VP_VSYNC_START     | 0x1      |
| Set the trigger reset mode to <i>immediate</i> .                                               | <a href="#">DSI_CTRL[14]</a> TRIGGER_RESET_MODE | 0x1      |
| Activate two line buffers.                                                                     | <a href="#">DSI_CTRL[13:12]</a> LINE_BUFFER     | 0x2      |
| HSYNC signal on the video port is active high.                                                 | <a href="#">DSI_CTRL[10]</a> VP_HSYNC_POL       | 0x1      |
| VSYNC on the video port is active high.                                                        | <a href="#">DSI_CTRL[11]</a> VP_VSYNC_POL       | 0x1      |
| Set the Data Enable signal on the video port as active high.                                   | <a href="#">DSI_CTRL[9]</a> VP_DE_POL           | 0x1      |
| Set the size of the video port data bus for the RGB format: 0x2 for RGB 888.                   | <a href="#">DSI_CTRL[7:6]</a> VP_DATA_BUS_WIDTH | 0x2      |
| VP_CLK_RATIO is not used if video port is used to provide data in video mode                   | <a href="#">DSI_CTRL[4]</a> VP_CLK_RATIO        | 0x0      |

**Table 7-90. DSI Control Registers (continued)**

| Steps                                                                                                      | Registers                       | Value |
|------------------------------------------------------------------------------------------------------------|---------------------------------|-------|
| Set the arbitration scheme for granting the VC pending ready requests in the TX FIFO as Sequential Scheme. | DSI_CTRL[3] TX_FIFO_ARBITRATION | 0x1   |
| Enable the ECC check for the received header.                                                              | DSI_CTRL[2] ECC_RX_EN           | 0x1   |

**Table 7-91. DSI Complex I/O Registers**

| Steps                                                        | Registers                            | Value       |
|--------------------------------------------------------------|--------------------------------------|-------------|
| GOBIT, complex I/O power ON, select data, and clock position | DSI_COMPLEXIO_CFG1                   | 0x4800 0032 |
| Clear Reg                                                    | DSI_COMPLEXIO_IRQSTATUS              | 0xC3F39CE7  |
| Disable IRQ                                                  | DSI_COMPLEXIO_IRQENABLE              | 0x0         |
| Enable I/F                                                   | DSI_CTRL[0] IF_EN                    | 0x1         |
| Disable I/F                                                  | DSI_CTRL[0] IF_EN                    | 0x0         |
| Wait until IF_EN = 0                                         | DSI_CTRL[0] IF_EN                    | Read 0x0    |
| Enable Low Power clock                                       | DSI_CLK_CTRL[20] LP_CLK_ENABLE       | 0x1         |
| Reset is done.                                               | DSI_COMPLEXIO_CFG1[29] RESET_DONE    | Read 0x1    |
| Power control is on.                                         | DSI_COMPLEXIO_CFG1[26:25] PWR_STATUS | Read 0x1    |
| Reset is complete.                                           | DSI_SYSSTATUS[0] RESETDONE           | Read 0x1    |

#### 7.6.4.2.4.2 Configure DSI Timing and Virtual Channels

Table 7-92 lists the steps to configure DSI timing and the virtual channels.

**Table 7-92. DSI Timing Registers**

| Steps                                                                                  | Registers            | Value        |
|----------------------------------------------------------------------------------------|----------------------|--------------|
| STOP_STATE_COUNTER_IO = 0x999                                                          | DSI_TIMING1[31:0]    | 0x0000 0999  |
| HS_TX_TO_X8, HS_TX_TO_COUNTER = 0x0FD2,<br>LP_RX_TO_X16, LP_RX_TO_COUNTER = 0x00CD     | DSI_TIMING2[31:0]    | 0x2FD2 40CD  |
| (HSA24) (HFP12) HBP                                                                    | DSI_VM_TIMING1[31:0] | 0x0000 700A  |
| (WINDOW_SYNC24) (VSA16) (DSI_VFP8) VBP                                                 | DSI_VM_TIMING2[31:0] | 0x0401 0101  |
| (TL16) DSI_VACT                                                                        | DSI_VM_TIMING3[31:0] | 0x05BB 0280  |
| (ENTER_HS_MODE_LATENCY16) EXIT_HS_MODE_LATENCY                                         | DSI_VM_TIMING7[31:0] | 0x0000 C000A |
| DDR_CLK_PRE8 DDR_CLK_POST                                                              | DSI_CLK_TIMING[31:0] | 0x0000 0F0B  |
| HS speed, ECC generation for the Transmit, Enable CheckSum generation for the Payload. | DSI_VC0_CTRL[31:0]   | 0x2080 0390  |

- Freq TxByteClkHS:

$$\text{FHSB} = \text{FCLKIN4DDR}/16$$

$$\text{FVPP} = \text{FCLKIN4DDR}/((\text{RegM3} + 1) \times \text{DISPC_LCD} * \text{DISPC_PCD})$$

$$\text{FVP} = \text{FCLKIN4DDR}/(\text{RegM3} + 1) \quad (28)$$

- Length of the line in video mode in Nb of byte clock cycles (TxByteClkHS):

$$TL = FHSB/FVPP \times (DISPC_HSA + DISPC_HFP + PPL + DISPC_HBP)$$

$$TL1f = (BPP/(8 \times NDL)) \times (DISPC_HSA + DISPC_HFP + PPL + DISPC_HBP) \quad (29)$$

- Blanking periods (HBP + HFP) in DSI are calculated based on the following formula:

$$(DISPC_HSA + DISPC_HBP + PPL + DISPC_HFP) \times Fppi = (HS + HBP + ((WC + 6)/NDL) + HFP) \times Fvp$$

$$HBP + HFP = (TVPP/THSB) \times (DISPC_HSA + DISPC_HFP + PPL + DISPC_HBP - (HS + (WC + 6)/NDL))$$

$$HBPplusHFP = (FHSB/FVPP) \times (DISPC_HSA + DISPC_HFP + PPL + DISPC_HBP) - (HS + WC + 6)/NDL)$$

$$HBPplusHFPf = ((FHSB/FVPP) \times (DISPC_HSA + DISPC_HFP + PPL + DISPC_HBP)) - ((HS + WC + 6)/NDL)$$

$$HFP = (DISPC_HFP \times BPP)/(NDL \times 8) - (2/NDL)$$

$$HBP = HBPplusHFP - HFP \quad (30)$$

#### **7.6.4.2.5 Configure DSI\_PHY**

Calculate the timing in the functions of DDR\_CLK\_P (see [Table 7-93](#)). In the example, DDR\_CLK\_P = 1000/DSI\_DDR\_CLK. See [Section 7.4.3.2, Clock Requirements](#), for details on timing calculation.

**Table 7-93. Calculate DSI\_PHY Timing**

| Steps                                    | Registers                                                    | Value                             |
|------------------------------------------|--------------------------------------------------------------|-----------------------------------|
| Refer to <a href="#">Section 7.4.3.2</a> | <a href="#">DSI_PHY_REGISTER0[31:24] REG_THSPREPARE</a>      | CEIL(70 ns/DDR clock period) + 2  |
|                                          | <a href="#">DSI_PHY_REGISTER0[23:16] REG_THSPRPR_THSZERO</a> | ceil(175 ns/DDR clock period) + 2 |
|                                          | <a href="#">DSI_PHY_REGISTER0[7:0] REG_THSEXIT</a>           | ceil(145 ns/DDR clock period)     |
|                                          | <a href="#">DSI_PHY_REGISTER0[15:8] REG_THSTRAIL</a>         | ceil(60 ns/DDR clock period) + 5  |
|                                          | <a href="#">DSI_PHY_REGISTER2[7:0] REG_TCLKPREPARE</a>       | ceil(65 ns/DDR clock period)      |
|                                          | <a href="#">DSI_PHY_REGISTER1[7:0] REG_TCLKZERO</a>          | ceil(265 ns/DDR clock period)     |
|                                          | <a href="#">DSI_PHY_REGISTER1[15:8] REG_TCLKTRAIL</a>        | ceil(60 ns/DDR clock period) + 2  |
|                                          | <a href="#">DSI_PHY_REGISTER1[20:16] REG_TLPXBY2</a>         | ceil(25ns/DDR clock period)       |

---

**NOTE:** Keep Reserved bits at reset value in the [DSI\\_PHY\\_REGISTER1](#) and [DSI\\_PHY\\_REGISTER2](#) registers.

---

#### **7.6.4.2.6 Drive Stop State**

[Table 7-94](#) lists the steps to Drive Stop State.

**Table 7-94. Drive Stop State**

| Steps                                | Registers                                             | Value    |
|--------------------------------------|-------------------------------------------------------|----------|
| Force TX stop mode                   | <a href="#">DSI_TIMING1[15] FORCE_TX_STOP_MODE_IO</a> | 0x1      |
| Wait until FORCE_TX_STOP_MODE_IO = 0 | <a href="#">DSI_TIMING1[15] FORCE_TX_STOP_MODE_IO</a> | Read 0x0 |

### 7.6.4.3 Initialization of the External MIPI Display Controller

1. Wait for the external MIPI display controller initialization after power up.  
In this example, the external MIPI display controller is reset using GPIO 87.
2. Configure the external MIPI display controller.

### 7.6.4.4 Configure the DISPC

#### 7.6.4.4.1 Reset DISPC

[Table 7-95](#) lists the step sequence to reset the DISPC.

**Table 7-95. Reset DISPC**

| Steps                                   | Registers                                         | Value    |
|-----------------------------------------|---------------------------------------------------|----------|
| Reset the DISPC.                        | <a href="#">DISPC_SYSCONFIG[1] SOFTRESET</a>      | 0x1      |
| DISPC is reset.                         | <a href="#">DISPC_SYSCONFIG[0] RESETDONE</a>      | Read 0x1 |
| No standby: MStandby is never asserted. | <a href="#">DISPC_SYSCONFIG [13:12] MIDLEMODE</a> | 0x1      |
| Disable idle mode.                      | <a href="#">DISPC_SYSCONFIG [4:3] SIDLEMODE</a>   | 0x1      |
| Disable all interrupts.                 | <a href="#">DISPC_IRQENABLE[31:0]</a>             | 0x0      |

#### 7.6.4.4.2 Configure DISPC Timing, Window, and Color

[Table 7-96](#) lists the steps to configure the DISPC registers. [Table 7-97](#) lists the steps to configure the color space coefficient registers.

[Table 7-98](#) lists the steps to configure [DISPC\\_CONTROL](#).

**Table 7-96. Configure DISPC Registers**

| Steps                                                                          | Registers                                 | Value                           |
|--------------------------------------------------------------------------------|-------------------------------------------|---------------------------------|
| Set horizontal timings.                                                        | <a href="#">DISPC_TIMING_H</a>            | (HBP – 120) (HFP – 18) HSA – 1  |
| Set vertical timing.                                                           | <a href="#">DISPC_TIMING_V</a>            | (HBP – 120) (HFP – 18) HSA – 1  |
| Set LCD – PCD display controller and pixel clock divisor.                      | <a href="#">DISPC_DIVISOR</a>             | LDC = %1 PXLCLK = %4            |
| Set the size of the LCD – 1.                                                   | <a href="#">DISPC_SIZE_LCD</a>            | (LPP – 1 + DS1_VFP)16 (PPL – 1) |
| Set default RGB value when there is no data.                                   | <a href="#">DISPC_DEFAULT_COLOR0</a>      | 0xFF                            |
| Set video FIFO height and low threshold.                                       | <a href="#">DISPC_VID1_FIFO_THRESHOLD</a> | 0xfc00c0                        |
| Set the X Y location of the upper left pixel (0 = 0) to the upper left corner. | <a href="#">DISPC_VID1_POSITION</a>       | 0x0                             |
| Set size of the window.                                                        | <a href="#">DISPC_VID1_SIZE</a>           | (LPP – 1) 16 (PPL – 1)          |
| Set the size of the picture.                                                   | <a href="#">DISPC_VID1_PICTURE_SIZE</a>   | (LPP – 1) 16 (PPL – 1)          |
| Set the input address picture.                                                 | <a href="#">DISPC_VID1_BA0</a>            | 0x–                             |

**Table 7-97. Configure Color Space Coefficient Registers**

| Comments                 | Registers                             | Value      |
|--------------------------|---------------------------------------|------------|
| RCR and RY coefficients  | <a href="#">DISPC_VID1_CONV_COEF0</a> | 0X0199012A |
| GY and RCB coefficients  | <a href="#">DISPC_VID1_CONV_COEF1</a> | 0X012A0000 |
| GCB and GCR coefficients | <a href="#">DISPC_VID1_CONV_COEF2</a> | 0X079C0730 |
| BCR and BY coefficients  | <a href="#">DISPC_VID1_CONV_COEF3</a> | 0X0000012A |
| BCB coefficient          | <a href="#">DISPC_VID1_CONV_COEF4</a> | 0X00000205 |

**Table 7-98. Configure DISPC\_CONTROL**

| Comments                                                                                                                                                                                      | Registers                        | Value |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-------|
| Enable pixel clock free-running.                                                                                                                                                              | DISPC_CONTROL[27] PCLKFREEENABLE | 0x1   |
| I/O pad mode selection: Bypass                                                                                                                                                                | DISPC_CONTROL[16] GPOUT1         | 0x1   |
| I/O pad mode selection: Bypass                                                                                                                                                                | DISPC_CONTROL[15] GPOUT0         | 0x1   |
| Normal mode selected                                                                                                                                                                          | DISPC_CONTROL[11] STALLMODE      | 0x0   |
| 3 for RGB888                                                                                                                                                                                  | DISPC_CONTROL[9:8] TFTDATALINES  | 0x3   |
| The hardware has finished updating the internal shadow registers of the pipeline(s) connected to the LCD output using the user values. The hardware resets the bit when the update completes. | DISPC_CONTROL[5] GOLCD           | 0x0   |
| Active matrix display operation mode                                                                                                                                                          | DISPC_CONTROL[3] STNTFT          | 0x1   |
| LCD interface is disabled.                                                                                                                                                                    | DISPC_CONTROL[0] LCDENABLE       | 0x0   |

The input image is converted from UYVY into RGB (see [Table 7-99](#)) :

**Table 7-99. Configure DISPC\_VID1\_ATTRIBUTES**

| Comments                                                                  | Registers                                    | Value |
|---------------------------------------------------------------------------|----------------------------------------------|-------|
| Row of VIDn will not be read twice.                                       | DISPC_VID1_ATTRIBUTES[18] VIDROWREPEATENABLE | 0x0   |
| 8 x 32-bit bursts                                                         | DISPC_VID1_ATTRIBUTES[15:14] VIDBURSTSIZE    | 0x1   |
| Full range selected: Y is not modified before the color space conversion. | DISPC_VID1_ATTRIBUTES[11] VIDFULLRANGE       | 0x1   |
| Enable color space conversion CbYCr to RGB.                               | DISPC_VID1_ATTRIBUTES[9] VIDCOLORCONVENABLE  | 0x1   |
| UYVY                                                                      | DISPC_VID1_ATTRIBUTES[4:1] VIDFORMAT         | 0xB   |
| Video disabled                                                            | DISPC_VID1_ATTRIBUTES[0] VIDENABLE           | 0x0   |

#### 7.6.4.5 Enable Video Mode Using the DISPC Video Port

[Table 7-100](#) lists the steps to enable DISPC to send frames continuously.

**Table 7-100. Enable DISPC**

| Steps                     | Registers                          | Value       |
|---------------------------|------------------------------------|-------------|
| Set up long packet header | DSI_VC0_LONG_PACKET_HEADER[31:0]   | 0x0005 A03E |
| Enable VC0.               | DSI_VC0_CTRL[1] VC_EN              | 0x1         |
| Enable IF.                | DSI_CTRL[0] IF_EN                  | 0x1         |
| Wait until IF_EN ≠ 0.     | DSI_CTRL[0] IF_EN                  | Read 0x0    |
| Enable VID1.              | DISPC_VID1_ATTRIBUTES[0] VIDENABLE | 0x1         |
| Enable LCD interface.     | DISPC_CONTROL[0] LCDENABLE         | 0x1         |
| Enable GOLCD.             | DISPC_CONTROL[5] GOLCD             | 0x1         |
| Wait until GOLCD = 0.     | DISPC_CONTROL[5] GOLCD             | Read 0x0    |

#### 7.6.5 DSI Command Mode Using the DISPC Video Port

This section presents some generic use cases and tips for setting the modules of the display subsystem.

##### 7.6.5.1 Display Subsystem Use Cases and Tips

This section explains the basic programming model of command mode using the DISPC video port.

The DSI interface is connected to an external MIPI DISPC using the following parameters:

- One data lane: NDL = 1
- Clock lane at 150 MHz (DSI\_DDR\_CLK)
- LCD size is 640 x 480:

- 480 PPL
- 680 LPP
- DISPC input format: YUV
- DISPC output format: RGB888 (24 BPP)
- Word Count: WC = 3 x PPL
- DSS2\_ALWON\_FLCK = 26 MHz used as a reference clock for DSI PLL
- Virtual channel 1 (VC1) used for command mode to configure the eternal DISPC, and virtual channel 0 (VC0) used to send data
- Automatic TE used for synchronization
- Interleaving not used
- It is assumed that all modules used in these programming models are in after-POR state.

Figure 7-155 is an overview of the connections in the display subsystem.

**Figure 7-155. Overview**



dss-330

**Table 7-101** lists the steps of the main sequence and the sections that describe them.

**Table 7-101. Main Sequence**

| Steps                                              | Register/Bit Field/Programming Model                                                       |
|----------------------------------------------------|--------------------------------------------------------------------------------------------|
| Configure DSS clocks.                              | <a href="#">Section 7.6.5.1.1, Configure DSS Clocks at the PRCM Module</a>                 |
| Configure the DSI protocol engine and DSI PLL.     | <a href="#">Section 7.6.5.1.2, Configure DSI Protocol Engine, DSI PLL, and Complex I/O</a> |
| Configure the external MIPI display controller.    | <a href="#">Section 7.6.5.1.3, Initialization of the External MIPI Display Controller</a>  |
| Configure the DISPC.                               | <a href="#">Section 7.6.5.1.4, Configure the DISPC</a>                                     |
| Enable command mode using the DISPC video port.    | <a href="#">Section 7.6.5.1.5, Enable Command Mode Using the DISPC Video Port</a>          |
| Send a frame data to LCD panel using automatic TE. | <a href="#">Section 7.6.5.1.6, Send Frame Data to LCD Panel Using Automatic TE</a>         |

The programming model must follow the step sequence.

#### **7.6.5.1.1 Configure DSS Clocks at the PRCM Module**

**Table 7-102** lists the steps required to enable the clocks.

**Table 7-102. Configure DSS Clocks at the PRCM Module**

| Steps                                                                                     | Register/Bit Field/Programming Model          | Value |
|-------------------------------------------------------------------------------------------|-----------------------------------------------|-------|
| Set the divided DPLL value for DSS1.                                                      | CM_CLKSEL_DSS[4:0] CLKSEL_DSS1                | 0x9   |
| Disable autoidle mode.                                                                    | CM_AUTOIDLE_DSS[0] AUTO_DSS                   | 0x0   |
| Domain sleep is disabled.                                                                 | CM_SLEEPDEP_DSS[2:0] EN_IVA2, EN_MPU, EN_CORE | 0x0   |
| Disable automatic transition.                                                             | CM_CLKSTCTRL_DSS[1:0] CLKTRCTRL_DSS           | 0x0   |
| Enable the DSS1_ALWON_FCLK, DSS2_ALWON_FCLK, and TV_CLK functional clocks. <sup>(1)</sup> | CM_FCLKEN_DSS[2:0] EN_TV, EN_DSS2, EN_DSS1    | 0x7   |
| Enable the DSS_L3_ICLK and DSS_L4_ICLK interface clocks.                                  | CM_ICLKEN_DSS[0] EN_DSS                       | 0x1   |

<sup>(1)</sup> TV\_CLK is required only for a correct reset.

#### **7.6.5.1.2 Configure DSI Protocol Engine, DSI PLL, and Complex I/O**

**Table 7-103** lists the steps to configure the DSI protocol engine, DSI PLL, and complex I/O and the sections that describe the sequence.

**Table 7-103. Configure DSI Protocol Engine, DSI PLL, and Complex I/O**

| Steps                           | Register/Bit Field/Programming Model                                |
|---------------------------------|---------------------------------------------------------------------|
| Reset DSI modules.              | <a href="#">Section 7.6.5.1.2.1, Reset DSI Modules</a>              |
| Configure DSI DPLL.             | <a href="#">Section 7.6.5.1.2.2, Configure DSI PLL</a>              |
| Switch to DSI PLL clock source. | <a href="#">Section 7.6.5.1.2.3, Switch to DSI PLL Clock Source</a> |
| Configure DSI protocol engine.  | <a href="#">Section 7.6.5.1.2.4, Configure DSI Protocol Engine</a>  |
| Configure DSI_PHY.              | <a href="#">Section 7.6.5.1.2.5, Configure DSI_PHY</a>              |
| Drive stop state.               | <a href="#">Section 7.6.5.1.2.6, Drive Stop State</a>               |

#### **7.6.5.1.2.1 Reset DSI Modules**

**Table 7-104** lists the steps required to reset the DSI modules.

**Table 7-104. Reset DSI Modules**

| Steps                                                  | Register/Bit Field/Programming   | Value |
|--------------------------------------------------------|----------------------------------|-------|
| Clear DSI IRQ status.                                  | DSI_IRQSTATUS[31:0]              | 0x0   |
| Maintain interface and functional clock during wakeup. | DSI_SYSCONFIG[9:8] CLOCKACTIVITY | 0x3   |
| Enable smart-idle for power management.                | DSI_SYSCONFIG[4:3] SIDLEMODE     | 0x2   |
| Set DSI reset.                                         | DSI_SYSCONFIG[1] SOFT_RESET      | 0x1   |
| Wait until RESET_DONE = 1.                             | DSI_SYSSTATUS[0] RESET_DONE      |       |

#### 7.6.5.1.2.2 Configure DSI PLL

Table 7-105 lists the steps required to configure the DSI PLL.

**Table 7-105. Configure DSI PLL**

| Steps                                                                                             | Register/Bit Field/Programming                   | Value |
|---------------------------------------------------------------------------------------------------|--------------------------------------------------|-------|
| Enable PLL and HSDIVIDER.                                                                         | DSI_CLK_CTRL[31:30] PLL_PWR_CMD                  | 0x2   |
| Wait until PLL_PWR_STATUS = 0x2.                                                                  | DSI_CLK_CTRL[29:28] PLL_PWR_STATUS               |       |
| Set the REGM4 value (see (1)).                                                                    | DSI_PLL_CONFIGURATION1[26:23] DSIPROTO_CLK_DIV   | 5     |
| Set the REGM3 value (see (2)).                                                                    | DSI_PLL_CONFIGURATION1[22:19] DSS_CLOCK_DIV      | 15    |
| Set the REGN value (see (3)).                                                                     | DSI_PLL_CONFIGURATION1[7:1] DSI_PLL_REGN         | 12    |
| Set the REGM value (see (4)).                                                                     | DSI_PLL_CONFIGURATION1[18:8] DSI_PLL_REGM        | 150   |
| Enable PLL STOPMODE.                                                                              | DSI_PLL_CONFIGURATION1[0] DSI_PLL_STOPMODE       | 0x1   |
| Enable PLL reference clock control.                                                               | DSI_PLL_CONFIGURATION2[13] DSI_PLL_REFEN         | 0x1   |
| Enable CLKIN4DDR control.                                                                         | DSI_PLL_CONFIGURATION2[14] DSI_PHY_CLKINEN       | 0x1   |
| Enable DSS clock divider.                                                                         | DSI_PLL_CONFIGURATION2[16] DSS_CLOCK_EN          | 0x1   |
| Enable DSI protocol engine clock divider.                                                         | DSI_PLL_CONFIGURATION2[18]<br>DSI_PROTO_CLOCK_EN | 0x1   |
| Enable DSI configuration update with DISPC_UPDATE_SYNC.                                           | DSI_PLL_CONTROL[0] DSI_PLL_AUTOMODE              | 0x0   |
| Start PLL locking sequence.                                                                       | DSI_PLL_GO[0] DSI_PLL_GO                         | 0x1   |
| Wait until DSI_PLL_GO = 0.                                                                        | DSI_PLL_GO[0] DSI_PLL_GO                         |       |
| Check whether PLL is locked.                                                                      | DSI_PLL_STATUS[1] DSI_PLL_LOCK                   | 0x1   |
| Set the LP mode clock ratio.                                                                      | DSI_CLK_CTRL[12:0] LP_CLK_DIVISOR                | 0x8   |
| Set L3_ICLK clock to the DSI complex I/O to not gated.                                            | DSI_CLK_CTRL[14] CIO_CLK_ICG                     | 0x1   |
| Enable the automatic assertion/deassertion of the DSISStopClk signal.                             | DSI_CLK_CTRL[18] HS_AUTO_STOP_ENABLE             | 0x1   |
| Specify that the DSI functional clock is higher than 30 MHz with a synchronization rising/rising. | DSI_CLK_CTRL[21] LP_RX_SYNCHRO_ENABLE            | 0x1   |
| Turn on PLL and HSDIVIDER.                                                                        | DSI_CLK_CTRL[31:30] PLL_PWR_CMD                  | 0x2   |

(1) Calculate the divider value for the DSI protocol engine clock source:

$$\text{RegM4} = \text{FCLKIN4DDR/FDSI\_PLL\_REFCLK} - 1$$

$$\text{FCLKIN4DDR} = 4 \times \text{FCLKIN}$$

$$\text{RegM4} = 5$$

dss-E126

(2) Determine LCD, PCD, and REGM3:

Calculate the divider value for the DSS clock source: Same as Step 3.

$$\text{RegM3} = ((\text{BPP} \times 2) / (\text{DISPC\_LCD} \times \text{DISPC\_PCD} \times \text{NDL})) - 1$$

$$\text{RegM3} = 15$$

dss-E127

(3) Calculate N divider for PLL:

$FCLKIN4DDR = FCLKIN \times 4$   
 $RegN = (FDSI\_PLL\_REFCLK/F INT) - 1$   
 $FDSI\_PLL\_REFCLK = 26 \text{ MHz} \text{ (system clock)}$   
 $Fint = 2 \text{ MHz} \text{ (reduce PLL lock time)}$   
 $RegN = 12$

dss-E128

(4) Calculate M divider for PLL:

$RegM = ((RegN + 1) \times (FCLKIN4DDR / (2 \times FDSI\_PLL\_REFCLK)))$   
 $FCLKIN4DDR = 4 \times 150 \text{ MHz}$   
 $RegM = 150$

dss-E129

#### 7.6.5.1.2.3 Switch to DSI PLL Clock Source

Table 7-106 lists the sequence to switch the DSI and DISPC module clocks to DSI PLL clock source.

**Table 7-106. Switch to DSI PLL Clock Source**

| Steps                                | Register/Bit Field/Programming  | Value |
|--------------------------------------|---------------------------------|-------|
| Switch DISPC clock to DSI1_PLL_FCLK. | DSS_CONTROL[0] DISPC_CLK_SWITCH | 0x1   |
| Switch DSI clock to DSI2_PLL_FCLK.   | DSS_CONTROL[1] DSI_CLK_SWITCH   | 0x1   |

#### 7.6.5.1.2.4 Configure DSI Protocol Engine

##### 7.6.5.1.2.4.1 Set Up DSI Control Registers

Table 7-107 lists the steps required to set up the DSI control registers. Table 7-108 lists the steps to set up the DSI complex I/O registers.

**Table 7-107. DSI Control Registers**

| Steps                                                                                                      | Register/Bit Field/Programming       | Value |
|------------------------------------------------------------------------------------------------------------|--------------------------------------|-------|
| Enable SYNCLOST event.                                                                                     | DSI_IRQENABLE[18] SYNC_LOST_IRQ_EN   | 0x1   |
| Enable IRQ to indicate that packet has been sent on VC1.                                                   | DSI_VC1_IRQENABLE[2] PACKET_SENT_IRQ | 0x1   |
| Enable IRQ to indicate that packet has been sent on VC0.                                                   | DSI_VC0_IRQENABLE[2] PACKET_SENT_IRQ | 0x1   |
| Set the trigger reset mode to <i>immediate</i> .                                                           | DSI_CTRL[14] TRIGGER_RESET_MODE      | 0x1   |
| Activate the two line buffers.                                                                             | DSI_CTRL[13:12] LINE_BUFFER          | 0x2   |
| Set the size of the video port data bus to 24 bits (RGB 888).                                              | DSI_CTRL[7:6] VP_DATA_BUS_WIDTH      | 0x2   |
| Define the ratio between VP_CLK and VP_PCLK.                                                               | DSI_CTRL[4] VP_CLK_RATIO             | 0x1   |
| Set the arbitration scheme for granting the VC pending ready requests in the TX FIFO as sequential scheme. | DSI_CTRL[3] TX_FIFO_ARBITRATION      | 0x1   |
| Enable the ECC check for the received header.                                                              | DSI_CTRL[2] ECC_RX_EN                | 0x1   |

**Table 7-108. DSI Complex I/O Registers**

| Steps                                     | Register/Bit Field/Programming         | Value |
|-------------------------------------------|----------------------------------------|-------|
| Determine the position of the clock lane. | DSI_COMPLEXIO_CFG1[2:0] CLOCK_POSITION | 0x2   |
| Determine the position of data 1 lane.    | DSI_COMPLEXIO_CFG1[6:4] DATA1_POSITION | 0x3   |
| Turn on COMPLEXIO.                        | DSI_COMPLEXIO_CFG1[28:27] PWR_CMD      | 0x1   |

**Table 7-108. DSI Complex I/O Registers (continued)**

| Steps                                                                      | Register/Bit Field/Programming       | Value      |
|----------------------------------------------------------------------------|--------------------------------------|------------|
| Enable the synchronization of the shadow registers with DISPC_UPDATE_SYNC. | DSI_COMPLEXIO_CFG1[30] GOBIT         | 0x1        |
| Clear all COMPLEXIO IRQ status.                                            | DSI_COMPLEXIO_IRQSTATUS              | 0xC3F39CE7 |
| Disable all COMPLEXIO IRQs.                                                | DSI_COMPLEXIO_IRQENABLE              | 0x0        |
| Enable interface.                                                          | DSI_CTRL[0] IF_EN                    | 0x1        |
| Disable interface.                                                         | DSI_CTRL[0] IF_EN                    | 0x0        |
| Wait until IF_EN = 0.                                                      | DSI_CTRL[0] IF_EN                    |            |
| Enable the LP clock.                                                       | DSI_CLK_CTRL[20] LP_CLK_ENABLE       | 0x1        |
| Check whether reset is complete.                                           | DSI_COMPLEXIO_CFG1[29] RESET_DONE    | 0x1        |
| Check whether power control is on.                                         | DSI_COMPLEXIO_CFG1[26:25] PWR_STATUS | 0x1        |
| Check whether reset is complete.                                           | DSI_SYSSTATUS[0] RESETDONE           | 0x1        |

#### 7.6.5.1.2.4.2 Configure DSI Timing and Virtual Channels

Table 7-109 lists the steps to configure DSI timing and the virtual channels.

**Table 7-109. DSI Timing Registers**

| Steps                                                                                                       | Register/Bit Field/Programming             | Value       |
|-------------------------------------------------------------------------------------------------------------|--------------------------------------------|-------------|
| Determine the number of DSI_FCLK clock cycles for the STOP-STATE counter.                                   | DSI_TIMING1[12:0]<br>STOP_STATE_COUNTER_IO | 0x999       |
| Disable the multiplication factor of 4 for the number of DSI_FCLK clock cycles for the STOP-STATE counter.  | DSI_TIMING1[13] STOP_STATE_X4_IO           | 0x0         |
| Disable the multiplication factor of 16 for the number of DSI_FCLK clock cycles for the STOP-STATE counter. | DSI_TIMING1[14] STOP_STATE_X16_IO          | 0x0         |
| Clear turn-around timer settings.                                                                           | DSI_TIMING1[30:16]                         | 0x0000      |
| Determine the number of DSI_FCLK clock cycles for the LP RX timer.                                          | DSI_TIMING2[12:0] LP_RX_TO_COUNTER         | 0x0CD       |
| Disable the multiplication factor of 4 for the number of DSI_FCLK clock cycles for the LP RX timer.         | DSI_TIMING2[13] LP_RX_TO_X4                | 0x0         |
| Enable the multiplication factor of 16 for the number of DSI_FCLK clock cycles for the LP RX timer.         | DSI_TIMING2[14] LP_RX_TO_X16               | 0x1         |
| Determine the number of TxByteClkHS clock cycles for the HS RX timer.                                       | DSI_TIMING2[12:0] HS_TX_TO_COUNTER         | 0xFD2       |
| Disable the multiplication factor of 8 for the number of TxByteClkHS clock cycles for the HS TX timer.      | DSI_TIMING2[13] HS_TX_TO_X8                | 0x0         |
| Enable the multiplication factor of 16 for the number of TxByteClkHS clock cycles for the HS TX timer.      | DSI_TIMING2[14] HS_TX_TO_X16               | 0x1         |
| DDR_CLK_PRE8 DDR_CLK_POST                                                                                   | DSI_CLK_TIMING[31:0]                       | 0x0000 0F0B |
| Configuration of VC1                                                                                        |                                            |             |
| Enable the checksum generation for the transmit payload.                                                    | DSI_VC1_CTRL[7] CS_TX_EN                   | 0x1         |
| Enable the ECC generation for the transmit header.                                                          | DSI_VC1_CTRL[8] ECC_TX_EN                  | 0x1         |
| Disable DMA request for TX FIFO.                                                                            | DSI_VC1_CTRL[23:21] DMA_TX_REQ_NB          | 0x4         |
| Disable DMA request for RX FIFO.                                                                            | DSI_VC1_CTRL[29:27] DMA_RX_REQ_NB          | 0x4         |
| Configuration of VC0                                                                                        |                                            |             |
| Selects source of data and enable VP_STALL.                                                                 | DSI_VC0_CTRL[1] SOURCE                     | 0x1         |

**Table 7-109. DSI Timing Registers (continued)**

| Steps                                                                    | Register/Bit Field/Programming              | Value |
|--------------------------------------------------------------------------|---------------------------------------------|-------|
| Enable the checksum generation for the transmit payload.                 | DSI_VC0_CTRL[7] CS_TX_EN                    | 0x1   |
| Enable the ECC generation for the transmit header.                       | DSI_VC0_CTRL[8] ECC_TX_EN                   | 0x1   |
| Enable high-speed mode to send short and long packets to the peripheral. | DSI_VC0_CTRL[9] MODE_SPEED                  | 0x1   |
| Disable DMA request for TX FIFO.                                         | DSI_VC0_CTRL[23:21] DMA_TX_REQ_NB           | 0x4   |
| Disable DMA request for RX FIFO.                                         | DSI_VC0_CTRL[29:27] DMA_RX_REQ_NB           | 0x4   |
| <b>Configuration TX and RX FIFO</b>                                      |                                             |       |
| Set size of the RX FIFO allocated for VC1 to 32 x 33 bits.               | DSI_RX_FIFO_VC_SIZE[15:12]<br>VC1_FIFO_SIZE | 0x1   |
| Set size of the TX and RX FIFO allocated for VC1 to 96 x 33 bits.        | DSI_TX_FIFO_VC_SIZE[15:12]<br>VC1_FIFO_SIZE | 0x3   |

- Freq TxByteClkHS:

$$\text{FHSB} = \text{FCLKIN4DDR}/16$$

$$\text{FVPP} = \text{FCLKIN4DDR}/((\text{RegM3} + 1) \times \text{DISPC_LCD} * \text{DISPC_PCD})$$

$$\text{FVP} = \text{FCLKIN4DDR}/(\text{RegM3} + 1)$$

dss-E130

- Length of the line in video mode in number of byte clock cycles (TxByteClkHS):

$$\text{TL} = \text{FHSB}/\text{FVPP} \times (\text{DISPC_HSA} + \text{DISPC_HFP} + \text{PPL} + \text{DISPC_HBP})$$

$$\text{TL1f} = (\text{BPP}/(8 \times \text{NDL})) \times (\text{DISPC_HSA} + \text{DISPC_HFP} + \text{PPL} + \text{DISPC_HBP})$$

dss-E131

- Blanking periods (HBP + HFP) in DSI are calculated based on the following formula:

$$(\text{DISPC_HSA} + \text{DISPC_HBP} + \text{PPL} + \text{DISPC_HFP}) \times \text{Fppi} = (\text{HS} + \text{HBP} + ((\text{WC} + 6)/\text{NDL}) + \text{HFP}) \times \text{Fvp}$$

$$\text{HBP} + \text{HFP} = (\text{TVPP}/\text{THSB}) \times (\text{DISPC_HSA} + \text{DISPC_HFP} + \text{PPL} + \text{DISPC_HBP}) - (\text{HS} + (\text{WC} + 6)/\text{NDL})$$

$$\text{HBPplusHFP} = (\text{FHSB}/\text{FVPP}) \times (\text{DISPC_HSA} + \text{DISPC_HFP} + \text{PPL} + \text{DISPC_HBP}) - (\text{HS} + \text{WC} + 6)/\text{NDL}$$

$$\text{HBPplusHFPf} = ((\text{FHSB}/\text{FVPP}) \times (\text{DISPC_HSA} + \text{DISPC_HFP} + \text{PPL} + \text{DISPC_HBP})) - ((\text{HS} + \text{WC} + 6)/\text{NDL})$$

$$\text{HFP} = (\text{DISPC_HFP} \times \text{BPP})/(\text{NDL} \times 8) - (2/\text{NDL})$$

$$\text{HBP} = \text{HBPplusHFP} - \text{HFP}$$

dss-E132

#### 7.6.5.1.2.5 Configure DSI\_PHY Timing

Table 7-110 summarizes DSI\_PHY timing in the functions of DDR\_CLK\_P with DDR\_CLK\_P = 1000/DSI\_DDR\_CLK. For more details on timing calculation, see [Section 7.4.3.2, Clock Requirements](#).

**Table 7-110. Configure DSI\_PHY Timing**

| Steps                                                                                                                                               | Register/Bit Field/Programming                  | Value                             |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|-----------------------------------|
| Settings of the DSI protocol timing. For a complete description of timing specifications, see <a href="#">Section 7.4.3.2, Clock Requirements</a> . | DSI_PHY_REGISTER0[31:24] REG_THSPREPARE         | CEIL(70 ns/DDR clock period) + 2  |
|                                                                                                                                                     | DSI_PHY_REGISTER0[23:16]<br>REG_THSPRPR_THSZERO | ceil(175 ns/DDR clock period) + 2 |
|                                                                                                                                                     | DSI_PHY_REGISTER0[7:0] REG_THSEXIT              | ceil(145 ns/DDR clock period)     |

**Table 7-110. Configure DSI\_PHY Timing (continued)**

| Steps | Register/Bit Field/Programming         | Value                            |
|-------|----------------------------------------|----------------------------------|
|       | DSI_PHY_REGISTER0[15:8] REG_THSTRAIL   | ceil(60 ns/DDR clock period) + 5 |
|       | DSI_PHY_REGISTER2[7:0] REG_TCLKPREPARE | ceil(65 ns/DDR clock period)     |
|       | DSI_PHY_REGISTER1[7:0] REG_TCLKZERO    | ceil(265 ns/DDR clock period)    |
|       | DSI_PHY_REGISTER1[15:8] REG_TCLKTRAIL  | ceil(60 ns/DDR clock period) + 2 |
|       | DSI_PHY_REGISTER1[20:16] REG_TLPXBY2   | ceil(25ns/DDR clock period)      |

**NOTE:** Keep Reserved bits at reset value in the [DSI\\_PHY\\_REGISTER1](#) and [DSI\\_PHY\\_REGISTER2](#) registers.

#### 7.6.5.1.2.6 Drive Stop State

[Table 7-111](#) lists the steps to drive the stop state.

**Table 7-111. Drive Stop State**

| Steps                                 | Register/Bit Field/Programming        | Value |
|---------------------------------------|---------------------------------------|-------|
| Force TX stop mode.                   | DSI_TIMING1[15] FORCE_TX_STOP_MODE_IO | 0x1   |
| Wait until FORCE_TX_STOP_MODE_IO = 0. | DSI_TIMING1[15] FORCE_TX_STOP_MODE_IO |       |

#### 7.6.5.1.3 Initialization of the External MIPI LCD Controller

[Table 7-112](#) lists the steps to initialize the external MIPI LCD controller.

**Table 7-112. Initialization of the External MIPI LCD Controller**

| Steps                                                                                     | Register/Bit Field/Programming | Value |
|-------------------------------------------------------------------------------------------|--------------------------------|-------|
| Reset the MIPI LCD controller using GPIO87.                                               | –                              | 0x1   |
| Wait until initialization of the external MIPI LCD controller is finished after power up. | –                              | –     |
| Configure the external MIPI LCD controller.                                               | –                              | –     |

#### 7.6.5.1.4 Configure the DISPC

##### 7.6.5.1.4.1 Reset DISPC

[Table 7-113](#) lists the steps to reset the DISPC.

**Table 7-113. Reset DISPC**

| Steps                                      | Register/Bit Field/Programming    | Value |
|--------------------------------------------|-----------------------------------|-------|
| Reset the DISPC.                           | DISPC_SYSCONFIG[1] SOFTRESET      | 0x1   |
| Wait until RESETDONE = 1.                  | DISPC_SYSCONFIG[0] RESETDONE      |       |
| Disable master interface power management. | DISPC_SYSCONFIG [13:12] MIDLEMODE | 0x1   |
| Disable slave interface power management.  | DISPC_SYSCONFIG [4:3] SIDLEMODE   | 0x1   |
| Disable all DISPC interrupts.              | DISPC_IRQENABLE[31:0]             | 0x0   |

#### **7.6.5.1.4.2 Configure DISPC Timing, Window, and Color**

[Table 7-114](#) lists the steps to configure the DISPC registers. [Table 7-97](#) lists the steps to configure the color space coefficient registers.

[Table 7-115](#) lists the steps to configure [DISPC\\_CONTROL](#).

**Table 7-114. Configure DISPC Registers**

| Steps                                             | Register/Bit Field/Programming                                                           | Value |
|---------------------------------------------------|------------------------------------------------------------------------------------------|-------|
| <b>Configure LCD output</b>                       |                                                                                          |       |
| Set the logic clock divisor (LCD).                | <a href="#">DISPC_DIVISOR[23:16]</a> LCD                                                 | 0x1   |
| Set the pixel clock divisor (PCD).                | <a href="#">DISPC_DIVISOR[7:0]</a> PCD                                                   | 0x4   |
| Set the number of lines on the LCD panel.         | <a href="#">DISPC_SIZE_LCD[26:16]</a> LPP                                                | 0x2A7 |
| Set the number of PPL on the LCD panel.           | <a href="#">DISPC_SIZE_LCD[10:0]</a> PPL                                                 | 0x1DF |
| Set solid background color.                       | <a href="#">DISPC_DEFAULT_COLOR0</a>                                                     | 0xFF  |
| <b>Configure VIDEO pipeline VID1.</b>             |                                                                                          |       |
| Set VID1 FIFO low threshold.                      | <a href="#">DISPC_VID1_FIFO_THRESHOLD[11:0]</a><br><a href="#">VIDFIFOLOWTHRESHOLD</a>   | 0x0C0 |
| Set VID1 FIFO high threshold.                     | <a href="#">DISPC_VID1_FIFO_THRESHOLD[27:16]</a><br><a href="#">VIDFIFOHIGHTHRESHOLD</a> | 0xFC0 |
| Set the X position of the VID1 window.            | <a href="#">DISPC_VID1_POSITION[10:0]</a> VIDPOSX                                        | 0x0   |
| Set the Y position of the VID1 window.            | <a href="#">DISPC_VID1_POSITION[26:16]</a> VIDPOSY                                       | 0x0   |
| Set the number of lines of the VID1 window.       | <a href="#">DISPC_VID1_SIZE[26:16]</a> VIDSIZEY                                          | 0x2A7 |
| Set the number of pixels of the VID1 window.      | <a href="#">DISPC_VID1_SIZE[10:0]</a> VIDSIZEX                                           | 0x1DF |
| Define the base address of the VID1 frame buffer. | <a href="#">DISPC_VID1_BA0</a>                                                           | 0x-   |

**Table 7-115. Configure DISPC\_CONTROL**

| Comments                                     | Register/Bit Field/Programming                   | Value |
|----------------------------------------------|--------------------------------------------------|-------|
| Enable pixel clock free-running.             | <a href="#">DISPC_CONTROL[27]</a> PCLKFREEENABLE | 0x1   |
| Disable RFBI.                                | <a href="#">DISPC_CONTROL[16]</a> GPOUT1         | 0x1   |
| Disable the stall mode.                      | <a href="#">DISPC_CONTROL[15]</a> GPOUT0         | 0x1   |
| Select size of DATALINES.                    | <a href="#">DISPC_CONTROL[9:8]</a> TFTDATALINES  | 0x3   |
| Select active matrix display operation mode. | <a href="#">DISPC_CONTROL[3]</a> STNTFT          | 0x1   |
| Disable LCD output interface.                | <a href="#">DISPC_CONTROL[0]</a> LCDENABLE       | 0x0   |
| Update the internal DISPC registers.         | <a href="#">DISPC_CONTROL[5]</a> GOLCD           | 0x1   |

#### **7.6.5.1.5 Enable Command Mode Using DISPC Video Port**

[Table 7-116](#) lists the steps to enable DISPC to send frames continuously. Two bus turnarounds (BTA) must be generated:

- The first BTA gives bus possession to the display module.
- The second BTA obtains the TE trigger.

**Table 7-116. Enable Command Mode and Automatic TE**

| Steps                                                                                   | Register/Bit Field/Programming              | Value |
|-----------------------------------------------------------------------------------------|---------------------------------------------|-------|
| Insert DCS write memory continue code.                                                  | <a href="#">DSI_CTRL[25]</a> DCS_CMD_CODE   | 0x0   |
| Enable automatic insertion of DCS command codes when data is sourced by the video port. | <a href="#">DSI_CTRL[24]</a> DCS_CMD_ENABLE | 0x1   |
| Enable VC1.                                                                             | <a href="#">DSI_VC1_CTRL[0]</a> VC_EN       | 0x1   |

**Table 7-116. Enable Command Mode and Automatic TE (continued)**

| Steps                                                                                                                                                         | Register/Bit Field/Programming           | Value       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-------------|
| Enable VC0.                                                                                                                                                   | DSI_VC0_CTRL[0] VC_EN                    | 0x1         |
| Enable the interface.                                                                                                                                         | DSI_CTRL[0] IF_EN                        | 0x1         |
| Wait until IF_EN = 1.                                                                                                                                         | DSI_CTRL[0] IF_EN                        |             |
| Send the sequence to receive the TE trigger from the peripheral. In this use case, code 0x35 + 1 parameter VC = 0, data type = 0x15, DCS write + 1 parameter. | DSI_VC1_SHORT_PACKET_HEADER[31:0] HEADER | 0x0000 3515 |
| Wait until PACKET_SENT_IRQ = 1.                                                                                                                               | DSI_VC1_IRQSTATUS[2] PACKET_SENT_IRQ     |             |
| Write 1 to clear PACKET_SENT_IRQ.                                                                                                                             | DSI_VC1_IRQSTATUS[2] PACKET_SENT_IRQ     | 0x1         |

#### 7.6.5.1.6 Send Frame Data to LCD Panel Using Automatic TE

Table 7-117 summarizes the steps to send a frame data to the LCD panel using automatic TE.

**Table 7-117. Send Frame Data to LCD Panel Using Automatic TE**

| Steps                                                                                                                                                      | Register/Bit Field/Programming          | Value           |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------|
| Enable the transfer between DISPC and DSI. Reset after the transfer is done.                                                                               | DISPC_CONTROL[0] LCDENABLE              | 0x1             |
| Specify the number of bytes to send. When DCS insertions is used, word count (WC) must include this one DCS byte.                                          | DSI_VC0_TE[23:0] TE_SIZE                | (WC+1)*LPP      |
| Set up long packet header. Send 0x39 DCS long write/write_LUT command packet used to send larger blocks of data to a display module that implements a DCS. | DSI_VC0_LONG_PACKET_HEADER[31:0] HEADER | (WC+1) 8 + 0x39 |
| Enable TE control.                                                                                                                                         | DSI_VC0_TE[30] TE_EN                    | 0x1             |
| Wait until RX FIFO is empty, RX_FIFO_NOT_EMPTY = 0.                                                                                                        | DSI_VC1_CTRL[20] RX_FIFO_NOT_EMPTY      | 0x0             |
| Wait until TX FIFO is not full. TX_FIFO_FULL = 0.                                                                                                          | DSI_VC1_CTRL[16] TX_FIFO_FULL           | 0x0             |
| Enable first BTA to give bus possession to the display module.                                                                                             | DSI_VC1_CTRL[6] BTA_EN                  | 0x1             |
| Wait until BTA IRQ.                                                                                                                                        | DSI_VC1_IRQSTATUS[5] BTA_IRQ            | 0x1             |
| Write 1 to clear BTA IRQ.                                                                                                                                  | DSI_VC1_IRQSTATUS[5] BTA_IRQ            | 0x1             |
| Enable second BTA to get the TE trigger.                                                                                                                   | DSI_VC1_CTRL[6] BTA_EN                  | 0x1             |
| Wait until BTA IRQ.                                                                                                                                        | DSI_VC1_IRQSTATUS[5] BTA_IRQ            | 0x1             |
| Write 1 to clear BTA IRQ.                                                                                                                                  | DSI_VC1_IRQSTATUS[5] BTA_IRQ            | 0x1             |
| Wait until transfer is complete.                                                                                                                           | DSI_VC0_TE[30] TE_EN                    | Read 0x0        |

## 7.7 Display Subsystem Register Manual

### CAUTION

- The DISS, DISPC, RFBI, and VENC registers have no register data width access restriction and can be accessed in 8-bit, 16-bit and 32-bit access.
- The DSI complex I/O and DSI PLL control module registers are limited to 32-bit data access; 16-bit and 8-bit data accesses are not allowed and can corrupt register content.
- The DSI protocol engine DSS.DSI\_VCn\_LONG\_PACKET\_HEADER and DSS.DSI\_VCn\_SHORT\_PACKET\_HEADER registers are limited to 32-bit data access; 16-bit and 8-bit data accesses are not allowed and can corrupt register content.
- The DSI protocol engine DSS.DSI\_VCn\_LONG\_PACKET\_PAYLOAD register is limited to 32-bit and 16-bit data access; 8-bit data accesses are not allowed and can corrupt register content.
- All other DSI protocol engine registers have no register data width access restriction and can be accessed in 8-bit, 16-bit and 32-bit access.

Table 7-118 summarizes the display subsystem instance.

**Table 7-118. Display Subsystem Instance Summary**

| Module Name             | Base Address | Size      |
|-------------------------|--------------|-----------|
| DSI Protocol Engine     | 0x4804 FC00  | 512 bytes |
| DSI_PHY                 | 0x4804 FE00  | 64 bytes  |
| DSI PLL Controller      | 0x4804 FF00  | 32 bytes  |
| Display Subsystem       | 0x4805 0000  | 512 bytes |
| Display Controller      | 0x4805 0400  | 1KB       |
| Display Controller VID1 | 0x4805 0400  | 1KB       |
| Display Controller VID2 | 0x4805 0400  | 1KB       |
| RFBI                    | 0x4805 0800  | 256 bytes |
| Video Encoder           | 0x4805 0C00  | 256 bytes |

### 7.7.1 Display Subsystem Register Mapping Summary

#### 7.7.1.1 Display Subsystem Register Mapping Summary

**Table 7-119. Display Subsystem Register Mapping Summary**

| Register Name      | Type | Register Width (Bits) | Address Offset | Physical Address |
|--------------------|------|-----------------------|----------------|------------------|
| DSS_REVISIONNUMBER | R    | 32                    | 0x000          | 0x4805 0000      |
| DSS_SYSCONFIG      | RW   | 32                    | 0x010          | 0x4805 0010      |
| DSS_SYSSTATUS      | R    | 32                    | 0x014          | 0x4805 0014      |
| DSS_IRQSTATUS      | R    | 32                    | 0x018          | 0x4805 0018      |
| DSS_CONTROL        | RW   | 32                    | 0x040          | 0x4805 0040      |
| DSS_CLK_STATUS     | R    | 32                    | 0x05C          | 0x4805 005C      |

### 7.7.1.2 Display Controller Register Mapping Summary

**Table 7-120. Display Controller Register Mapping Summary**

| Register Name              | Type | Register Width (Bits) | Address Offset                  | Physical Address                      |
|----------------------------|------|-----------------------|---------------------------------|---------------------------------------|
| DISPC_REVISION             | R    | 32                    | 0x000                           | 0x4805 0400                           |
| DISPC_SYSCONFIG            | RW   | 32                    | 0x010                           | 0x4805 0410                           |
| DISPC_SYSSTATUS            | R    | 32                    | 0x014                           | 0x4805 0414                           |
| DISPC_IRQSTATUS            | RW   | 32                    | 0x018                           | 0x4805 0418                           |
| DISPC_IRQENABLE            | RW   | 32                    | 0x01C                           | 0x4805 041C                           |
| DISPC_CONTROL              | RW   | 32                    | 0x040                           | 0x4805 0440                           |
| DISPC_CONFIG               | RW   | 32                    | 0x044                           | 0x4805 0444                           |
| DISPC_DEFAULT_COLOR_m      | RW   | 32                    | 0x04C+(m * 0x04) <sup>(1)</sup> | 0x4805 044C+(m * 0x04) <sup>(1)</sup> |
| DISPC_TRANS_COLOR_m        | RW   | 32                    | 0x054+(m * 0x04) <sup>(1)</sup> | 0x4805 0454+(m * 0x04) <sup>(1)</sup> |
| DISPC_LINE_STATUS          | R    | 32                    | 0x05C                           | 0x4805 045C                           |
| DISPC_LINE_NUMBER          | RW   | 32                    | 0x060                           | 0x4805 0460                           |
| DISPC_TIMING_H             | RW   | 32                    | 0x064                           | 0x4805 0464                           |
| DISPC_TIMING_V             | RW   | 32                    | 0x068                           | 0x4805 0468                           |
| DISPC_POL_FREQ             | RW   | 32                    | 0x06C                           | 0x4805 046C                           |
| DISPC_DIVISOR              | RW   | 32                    | 0x070                           | 0x4805 0470                           |
| DISPC_GLOBAL_ALPHA         | RW   | 32                    | 0x074                           | 0x4805 0474                           |
| DISPC_SIZE_DIG             | RW   | 32                    | 0x078                           | 0x4805 0478                           |
| DISPC_SIZE_LCD             | RW   | 32                    | 0x07C                           | 0x4805 047C                           |
| DISPC_GFX_BAj              | RW   | 32                    | 0x080+(j * 0x04) <sup>(2)</sup> | 0x4805 0480+(j * 0x04) <sup>(2)</sup> |
| DISPC_GFX_POSITION         | RW   | 32                    | 0x088                           | 0x4805 0488                           |
| DISPC_GFX_SIZE             | RW   | 32                    | 0x08C                           | 0x4805 048C                           |
| DISPC_GFX_ATTRIBUTES       | RW   | 32                    | 0x0A0                           | 0x4805 04A0                           |
| DISPC_GFX_FIFO_THRESHOLD   | RW   | 32                    | 0x0A4                           | 0x4805 04A4                           |
| DISPC_GFX_FIFO_SIZE_STATUS | R    | 32                    | 0x0A8                           | 0x4805 04A8                           |
| DISPC_GFX_ROW_INC          | RW   | 32                    | 0x0AC                           | 0x4805 04AC                           |
| DISPC_GFX_PIXEL_INC        | RW   | 32                    | 0x0B0                           | 0x4805 04B0                           |
| DISPC_GFX_WINDOW_SKIP      | RW   | 32                    | 0x0B4                           | 0x4805 04B4                           |
| DISPC_GFX_TABLE_BA         | RW   | 32                    | 0x0B8                           | 0x4805 04B8                           |
| DISPC_DATA_CYCLEk          | RW   | 32                    | 0x1D4+(k * 0x04) <sup>(3)</sup> | 0x4805 05D4+(k * 0x04) <sup>(3)</sup> |
| DISPC_CPR_COEF_R           | RW   | 32                    | 0x220                           | 0x4805 0620                           |
| DISPC_CPR_COEF_G           | RW   | 32                    | 0x224                           | 0x4805 0624                           |
| DISPC_CPR_COEF_B           | RW   | 32                    | 0x228                           | 0x4805 0628                           |
| DISPC_GFX_PRELOAD          | RW   | 32                    | 0x22C                           | 0x4805 062C                           |

<sup>(1)</sup> m = 0 to 1<sup>(2)</sup> j = 0 to 1<sup>(3)</sup> k = 0 to 2

### 7.7.1.3 Display Controller VID1 Register Mapping Summary

**Table 7-121. Display Controller VID1 Register Mapping Summary**

| Register Name (n=1 for VID1) | Type | Register Width (Bits) | Address Offset                                   | Display controller VID1 Physical Address |
|------------------------------|------|-----------------------|--------------------------------------------------|------------------------------------------|
| DISPC_VIDn_BAj               | RW   | 32                    | 0x0BC+((n-1)* 0x90) + (j * 0x04) <sup>(1)</sup>  | 0x4805 04BC + (j * 0x04) <sup>(1)</sup>  |
| DISPC_VIDn_POSITION          | RW   | 32                    | 0x0C4+((n-1)* 0x90)                              | 0x4805 04C4                              |
| DISPC_VIDn_SIZE              | RW   | 32                    | 0x0C8+((n-1)* 0x90)                              | 0x4805 04C8                              |
| DISPC_VIDn_ATTRIBUTES        | RW   | 32                    | 0x0CC+((n-1)* 0x90)                              | 0x4805 04CC                              |
| DISPC_VIDn_FIFO_THRESHOLD    | RW   | 32                    | 0x0D0+((n-1)* 0x90)                              | 0x4805 04D0                              |
| DISPC_VIDn_FIFO_SIZE_STATUS  | R    | 32                    | 0x0D4+((n-1)* 0x90)                              | 0x4805 04D4                              |
| DISPC_VIDn_ROW_INC           | RW   | 32                    | 0x0D8+((n-1)* 0x90)                              | 0x4805 04D8                              |
| DISPC_VIDn_PIXEL_INC         | RW   | 32                    | 0x0DC+((n-1)* 0x90)                              | 0x4805 04DC                              |
| DISPC_VIDn_FIR               | RW   | 32                    | 0x0E0+((n-1)* 0x90)                              | 0x4805 04E0                              |
| DISPC_VIDn_PICTURE_SIZE      | RW   | 32                    | 0x0E4+((n-1)* 0x90)                              | 0x4805 04E4                              |
| DISPC_VIDn_ACCUI             | RW   | 32                    | 0x0E8 + ((n-1)* 0x90) + (l* 0x04) <sup>(2)</sup> | 0x4805 04E8 + (l* 0x04) <sup>(2)</sup>   |
| DISPC_VIDn_FIR_COEF_Hi       | RW   | 32                    | 0x0F0+ ((n-1)* 0x90) + (i* 0x08) <sup>(3)</sup>  | 0x4805 04F0+ (i* 0x08) <sup>(3)</sup>    |
| DISPC_VIDn_FIR_COEF_HVi      | RW   | 32                    | 0x0F4+ ((n-1)* 0x90) + (i* 0x08) <sup>(4)</sup>  | 0x4805 04F4 + (i* 0x08) <sup>(4)</sup>   |
| DISPC_VIDn_CONV_COEF0        | RW   | 32                    | 0x130+((n-1)* 0x90)                              | 0x4805 0530                              |
| DISPC_VIDn_CONV_COEF1        | RW   | 32                    | 0x134+((n-1)* 0x90)                              | 0x4805 0534                              |
| DISPC_VIDn_CONV_COEF2        | RW   | 32                    | 0x138+((n-1)* 0x90)                              | 0x4805 0538                              |
| DISPC_VIDn_CONV_COEF3        | RW   | 32                    | 0x13C+((n-1)* 0x90)                              | 0x4805 053C                              |
| DISPC_VIDn_CONV_COEF4        | RW   | 32                    | 0x140+((n-1)* 0x90)                              | 0x4805 0540                              |
| DISPC_VIDn_FIR_COEF_Vi       | RW   | 32                    | 0x1E0+ ((n-1)*0x20) + (i* 0x04) <sup>(4)</sup>   | 0x4805 05E0 + (i* 0x04) <sup>(4)</sup>   |
| DISPC_VIDn_PRELOAD           | RW   | 32                    | 0x230+((n-1)* 0x04)                              | 0x4805 0630                              |

<sup>(1)</sup> j = 0 to 1

<sup>(2)</sup> l = 0 to 1

<sup>(3)</sup> i = 0 to 7

<sup>(4)</sup> i = 0 to 7

#### 7.7.1.4 Display Controller VID2 Register Mapping Summary

**Table 7-122. Display Controller VID2 Register Mapping Summary**

| Register Name (n=2 for VID2) | Type | Register Width (Bits) | Address Offset                                  | Display controller VID2 Physical Address |
|------------------------------|------|-----------------------|-------------------------------------------------|------------------------------------------|
| DISPC_VIDn_BAj               | RW   | 32                    | 0x0BC+((n-1)* 0x90) + (j * 0x04) <sup>(1)</sup> | 0x4805 054C+ (j *0x04) <sup>(1)</sup>    |
| DISPC_VIDn_POSITION          | RW   | 32                    | 0x0C4+((n-1)* 0x90)                             | 0x4805 0554                              |
| DISPC_VIDn_SIZE              | RW   | 32                    | 0x0C8+((n-1)* 0x90)                             | 0x4805 0558                              |
| DISPC_VIDn_ATTRIBUTES        | RW   | 32                    | 0x0CC+((n-1)* 0x90)                             | 0x4805 055C                              |
| DISPC_VIDn_FIFO_THRESHOLD    | RW   | 32                    | 0x0D0+((n-1)* 0x90)                             | 0x4805 0560                              |
| DISPC_VIDn_FIFO_SIZE_STATUS  | R    | 32                    | 0x0D4+((n-1)* 0x90)                             | 0x4805 0564                              |
| DISPC_VIDn_ROW_INC           | RW   | 32                    | 0x0D8+((n-1)* 0x90)                             | 0x4805 0568                              |
| DISPC_VIDn_PIXEL_INC         | RW   | 32                    | 0x0DC+((n-1)* 0x90)                             | 0x4805 056C                              |
| DISPC_VIDn_FIR               | RW   | 32                    | 0x0E0+((n-1)* 0x90)                             | 0x4805 0570                              |
| DISPC_VIDn_PICTURE_SIZE      | RW   | 32                    | 0x0E4+((n-1)* 0x90)                             | 0x4805 0574                              |

<sup>(1)</sup> j = 0 to 1

**Table 7-122. Display Controller VID2 Register Mapping Summary (continued)**

| Register Name (n=2 for VID2) | Type | Register Width (Bits) | Address Offset                                   | Display controller VID2 Physical Address |
|------------------------------|------|-----------------------|--------------------------------------------------|------------------------------------------|
| DISPC_VIDn_ACCUI             | RW   | 32                    | 0x0E8 + ((n-1)* 0x90) + (i* 0x04) <sup>(2)</sup> | 0x4805 0578 + (i* 0x04) <sup>(2)</sup>   |
| DISPC_VIDn_FIR_COEF_Hi       | RW   | 32                    | 0x0F0+ ((n-1)* 0x90) + (i* 0x08) <sup>(3)</sup>  | 0x4805 0580 + (i* 0x08) <sup>(3)</sup>   |
| DISPC_VIDn_FIR_COEF_HVi      | RW   | 32                    | 0x0F4+ ((n-1)* 0x90) + (i* 0x08) <sup>(3)</sup>  | 0x4805 0584 + (i* 0x08) <sup>(3)</sup>   |
| DISPC_VIDn_CONV_COEF0        | RW   | 32                    | 0x130+((n-1)* 0x90)                              | 0x4805 05C0                              |
| DISPC_VIDn_CONV_COEF1        | RW   | 32                    | 0x134+((n-1)* 0x90)                              | 0x4805 05C4                              |
| DISPC_VIDn_CONV_COEF2        | RW   | 32                    | 0x138+((n-1)* 0x90)                              | 0x4805 05C8                              |
| DISPC_VIDn_CONV_COEF3        | RW   | 32                    | 0x13C+((n-1)* 0x90)                              | 0x4805 05CC                              |
| DISPC_VIDn_CONV_COEF4        | RW   | 32                    | 0x140+((n-1)* 0x90)                              | 0x4805 05D0                              |
| DISPC_VIDn_FIR_COEF_Vi       | RW   | 32                    | 0x1E0+ ((n-1)*0x20) + (i* 0x04) <sup>(3)</sup>   | 0x4805 0670 + (i* 0x04) <sup>(3)</sup>   |
| DISPC_VIDn_PRELOAD           | RW   | 32                    | 0x230+((n-1)* 0x04)                              | 0x4805 0634                              |

<sup>(2)</sup> I = 0 to 1<sup>(3)</sup> i = 0 to 7

### 7.7.1.5 RFBI Register Mapping Summary

**Table 7-123. RFBI Register Mapping Summary**

| Register Name      | Type | Register Width (Bits) | Address Offset                 | Physical Address                      |
|--------------------|------|-----------------------|--------------------------------|---------------------------------------|
| RFBI_REVISION      | R    | 32                    | 0x00                           | 0x4805 0800                           |
| RFBI_SYSCONFIG     | RW   | 32                    | 0x10                           | 0x4805 0810                           |
| RFBI_SYSSTATUS     | R    | 32                    | 0x14                           | 0x4805 0814                           |
| RFBI_CONTROL       | RW   | 32                    | 0x40                           | 0x4805 0840                           |
| RFBI_PIXEL_CNT     | RW   | 32                    | 0x44                           | 0x4805 0844                           |
| RFBI_LINE_NUMBER   | RW   | 32                    | 0x48                           | 0x4805 0848                           |
| RFBI_CMD           | W    | 32                    | 0x4C                           | 0x4805 084C                           |
| RFBI_PARAM         | W    | 32                    | 0x50                           | 0x4805 0850                           |
| RFBI_DATA          | W    | 32                    | 0x54                           | 0x4805 0854                           |
| RFBI_READ          | RW   | 32                    | 0x58                           | 0x4805 0858                           |
| RFBI_STATUS        | RW   | 32                    | 0x5C                           | 0x4805 085C                           |
| RFBI_CONFIGi       | RW   | 32                    | 0x60+ (i* 0x18) <sup>(1)</sup> | 0x4805 0860+ (i* 0x18) <sup>(1)</sup> |
| RFBI_ONOFF_TIMEi   | RW   | 32                    | 0x64+ (i* 0x18) <sup>(1)</sup> | 0x4805 0864+ (i* 0x18) <sup>(1)</sup> |
| RFBI_CYCLE_TIMEi   | RW   | 32                    | 0x68+ (i* 0x18) <sup>(1)</sup> | 0x4805 0868+ (i* 0x18) <sup>(1)</sup> |
| RFBI_DATA_CYCLE1_i | RW   | 32                    | 0x6C+ (i* 0x18) <sup>(1)</sup> | 0x4805 086C+ (i* 0x18) <sup>(1)</sup> |
| RFBI_DATA_CYCLE2_i | RW   | 32                    | 0x70+ (i* 0x18) <sup>(1)</sup> | 0x4805 0870+ (i* 0x18) <sup>(1)</sup> |
| RFBI_DATA_CYCLE3_i | RW   | 32                    | 0x74+ (i* 0x18) <sup>(1)</sup> | 0x4805 0874+ (i* 0x18) <sup>(1)</sup> |
| RFBI_VSYNC_WIDTH   | RW   | 32                    | 0x90                           | 0x4805 0890                           |
| RFBI_HSYNC_WIDTH   | RW   | 32                    | 0x94                           | 0x4805 0894                           |

<sup>(1)</sup> i = 0 to 1

### 7.7.1.6 Video Encoder Register Mapping Summary

**Table 7-124. Video Encoder Register Mapping Summary**

| Register Name                         | Type | Register Width (Bits) | Address Offset | Physical Address |
|---------------------------------------|------|-----------------------|----------------|------------------|
| VENC_REV_ID                           | R    | 32                    | 0x00           | 0x4805 0C00      |
| VENC_STATUS                           | R    | 32                    | 0x04           | 0x4805 0C04      |
| VENC_F_CONTROL                        | RW   | 32                    | 0x08           | 0x4805 0C08      |
| VENC_VIDOUT_CTRL                      | RW   | 32                    | 0x10           | 0x4805 0C10      |
| VENC_SYNC_CTRL                        | RW   | 32                    | 0x14           | 0x4805 0C14      |
| VENC_LLEN                             | RW   | 32                    | 0x1C           | 0x4805 0C1C      |
| VENC_FLENS                            | RW   | 32                    | 0x20           | 0x4805 0C20      |
| VENC_HFLTR_CTRL                       | RW   | 32                    | 0x24           | 0x4805 0C24      |
| VENC_CC_CARR_WSS_CARR                 | RW   | 32                    | 0x28           | 0x4805 0C28      |
| VENC_C_PHASE                          | RW   | 32                    | 0x2C           | 0x4805 0C2C      |
| VENC_GAIN_U                           | RW   | 32                    | 0x30           | 0x4805 0C30      |
| VENC_GAIN_V                           | RW   | 32                    | 0x34           | 0x4805 0C34      |
| VENC_GAIN_Y                           | RW   | 32                    | 0x38           | 0x4805 0C38      |
| VENC_BLACK_LEVEL                      | RW   | 32                    | 0x3C           | 0x4805 0C3C      |
| VENC_BLANK_LEVEL                      | RW   | 32                    | 0x40           | 0x4805 0C40      |
| VENC_X_COLOR                          | RW   | 32                    | 0x44           | 0x4805 0C44      |
| VENC_M_CONTROL                        | RW   | 32                    | 0x48           | 0x4805 0C48      |
| VENC_BSTAMP_WSS_DATA                  | RW   | 32                    | 0x4C           | 0x4805 0C4C      |
| VENC_S_CARR                           | RW   | 32                    | 0x50           | 0x4805 0C50      |
| VENC_LINE21                           | RW   | 32                    | 0x54           | 0x4805 0C54      |
| VENC_LN_SEL                           | RW   | 32                    | 0x58           | 0x4805 0C58      |
| VENC_L21_WC_CTL                       | RW   | 32                    | 0x5C           | 0x4805 0C5C      |
| VENC_HTRIGGER_VTRIGGER                | RW   | 32                    | 0x60           | 0x4805 0C60      |
| VENC_SAVID_EAVID                      | RW   | 32                    | 0x64           | 0x4805 0C64      |
| VENC_FLEN_FAL                         | RW   | 32                    | 0x68           | 0x4805 0C68      |
| VENC_LAL_PHASE_RESET                  | RW   | 32                    | 0x6C           | 0x4805 0C6C      |
| VENC_HS_INT_START_STOP_X              | RW   | 32                    | 0x70           | 0x4805 0C70      |
| VENC_HS_EXT_START_STOP_X              | RW   | 32                    | 0x74           | 0x4805 0C74      |
| VENC_VS_INT_START_X                   | RW   | 32                    | 0x78           | 0x4805 0C78      |
| VENC_VS_INT_STOP_X_VS_INT_START_Y     | RW   | 32                    | 0x7C           | 0x4805 0C7C      |
| VENC_VS_INT_STOP_Y_VS_EXT_START_X     | RW   | 32                    | 0x80           | 0x4805 0C80      |
| VENC_VS_EXT_STOP_X_VS_EXT_START_Y     | RW   | 32                    | 0x84           | 0x4805 0C84      |
| VENC_VS_EXT_STOP_Y                    | RW   | 32                    | 0x88           | 0x4805 0C88      |
| VENC_AVID_START_STOP_X                | RW   | 32                    | 0x90           | 0x4805 0C90      |
| VENC_AVID_START_STOP_Y                | RW   | 32                    | 0x94           | 0x4805 0C94      |
| VENC_FID_INT_START_X_FID_INT_START_Y  | RW   | 32                    | 0xA0           | 0x4805 0CA0      |
| VENC_FID_INT_OFFSET_Y_FID_EXT_START_X | RW   | 32                    | 0xA4           | 0x4805 0CA4      |
| VENC_FID_EXT_START_Y_FID_EXT_OFFSET_Y | RW   | 32                    | 0xA8           | 0x4805 0CA8      |
| VENC_TVDETGP_INT_START_STOP_X         | RW   | 32                    | 0xB0           | 0x4805 0CB0      |
| VENC_TVDETGP_INT_START_STOP_Y         | RW   | 32                    | 0xB4           | 0x4805 0CB4      |
| VENC_GEN_CTRL                         | RW   | 32                    | 0xB8           | 0x4805 0CB8      |
| VENC_OUTPUT_CONTROL                   | RW   | 32                    | 0xC4           | 0x4805 0CC4      |
| VENC_OUTPUT_TEST                      | RW   | 32                    | 0xC8           | 0x4805 0CC8      |

### 7.7.1.7 DSI Protocol Engine Register Mapping Summary

**Table 7-125. DSI Protocol Engine Register Mapping Summary**

| Register Name               | Type | Register Width (Bits) | Address Offset                  | Physical Address                      |
|-----------------------------|------|-----------------------|---------------------------------|---------------------------------------|
| DSI_REVISION                | R    | 32                    | 0x000                           | 0x4804 FC00                           |
| DSI_SYSCONFIG               | RW   | 32                    | 0x010                           | 0x4804 FC10                           |
| DSI_SYSSTATUS               | R    | 32                    | 0x014                           | 0x4804 FC14                           |
| DSI_IRQSTATUS               | RW   | 32                    | 0x018                           | 0x4804 FC18                           |
| DSI_IRQENABLE               | RW   | 32                    | 0x01C                           | 0x4804 FC1C                           |
| DSI_CTRL                    | RW   | 32                    | 0x040                           | 0x4804 FC40                           |
| DSI_COMPLEXIO_CFG_1         | RW   | 32                    | 0x048                           | 0x4804 FC48                           |
| DSI_COMPLEXIO_IRQ_STATUS    | RW   | 32                    | 0x04C                           | 0x4804 FC4C                           |
| DSI_COMPLEXIO_IRQ_ENABLE    | RW   | 32                    | 0x050                           | 0x4804 FC50                           |
| DSI_CLK_CTRL                | RW   | 32                    | 0x054                           | 0x4804 FC54                           |
| DSI_TIMING1                 | RW   | 32                    | 0x058                           | 0x4804 FC58                           |
| DSI_TIMING2                 | RW   | 32                    | 0x05C                           | 0x4804 FC5C                           |
| DSI_VM_TIMING1              | RW   | 32                    | 0x060                           | 0x4804 FC60                           |
| DSI_VM_TIMING2              | RW   | 32                    | 0x064                           | 0x4804 FC64                           |
| DSI_VM_TIMING3              | RW   | 32                    | 0x068                           | 0x4804 FC68                           |
| DSI_CLK_TIMING              | RW   | 32                    | 0x06C                           | 0x4804 FC6C                           |
| DSI_TX_FIFO_VC_SIZE         | RW   | 32                    | 0x070                           | 0x4804 FC70                           |
| DSI_RX_FIFO_VC_SIZE         | RW   | 32                    | 0x074                           | 0x4804 FC74                           |
| DSI_COMPLEXIO_CFG_2         | RW   | 32                    | 0x078                           | 0x4804 FC78                           |
| DSI_RX_FIFO_VC_FULNESS      | R    | 32                    | 0x07C                           | 0x4804 FC7C                           |
| DSI_VM_TIMING4              | RW   | 32                    | 0x080                           | 0x4804 FC80                           |
| DSI_TX_FIFO_VC_EMP_TINESS   | R    | 32                    | 0x084                           | 0x4804 FC84                           |
| DSI_VM_TIMING5              | RW   | 32                    | 0x088                           | 0x4804 FC88                           |
| DSI_VM_TIMING6              | RW   | 32                    | 0x08C                           | 0x4804 FC8C                           |
| DSI_VM_TIMING7              | RW   | 32                    | 0x090                           | 0x4804 FC90                           |
| DSI_STOPCLK_TIMING          | RW   | 32                    | 0x094                           | 0x4804 FC94                           |
| DSI_VCn_CTRL                | RW   | 32                    | 0x100+ (n* 0x20) <sup>(1)</sup> | 0x4804 FD00+ (n* 0x20) <sup>(1)</sup> |
| DSI_VCn_TE                  | RW   | 32                    | 0x104+ (n* 0x20) <sup>(1)</sup> | 0x4804 FD04+ (n* 0x20) <sup>(1)</sup> |
| DSI_VCn_LONG_PACKET_HEADER  | W    | 32                    | 0x108+ (n* 0x20) <sup>(1)</sup> | 0x4804 FD08+ (n* 0x20) <sup>(1)</sup> |
| DSI_VCn_LONG_PACKET_PAYLOAD | W    | 32                    | 0x10C+ (n* 0x20) <sup>(1)</sup> | 0x4804 FD0C+ (n* 0x20) <sup>(1)</sup> |
| DSI_VCn_SHORT_PACKET_HEADER | RW   | 32                    | 0x110+ (n* 0x20) <sup>(1)</sup> | 0x4804 FD10+ (n* 0x20) <sup>(1)</sup> |
| DSI_VCn_IRQSTATUS           | RW   | 32                    | 0x118+ (n* 0x20) <sup>(1)</sup> | 0x4804 FD18+ (n* 0x20) <sup>(1)</sup> |
| DSI_VCn_IRQENABLE           | RW   | 32                    | 0x11C+ (n* 0x20) <sup>(1)</sup> | 0x4804 FD1C+ (n* 0x20) <sup>(1)</sup> |

<sup>(1)</sup> n = 0 to 3

### 7.7.1.8 DSI\_PHY Register Mapping Summary

**Table 7-126. DSI\_PHY Register Mapping Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address |
|-------------------|------|-----------------------|----------------|------------------|
| DSI_PHY_REGISTER0 | RW   | 32                    | 0x0000 0000    | 0x4804 FE00      |
| DSI_PHY_REGISTER1 | RW   | 32                    | 0x0000 0004    | 0x4804 FE04      |
| DSI_PHY_REGISTER2 | RW   | 32                    | 0x0000 0008    | 0x4804 FE08      |
| DSI_PHY_REGISTER3 | RW   | 32                    | 0x0000 000C    | 0x4804 FE0C      |
| DSI_PHY_REGISTER4 | RW   | 32                    | 0x0000 0010    | 0x4804 FE10      |
| DSI_PHY_REGISTER5 | R    | 32                    | 0x0000 0014    | 0x4804 FE14      |

### 7.7.1.9 DSI PLL Controller Register Mapping Summary

**Table 7-127. DSI PLL Controller Register Mapping Summary**

| Register Name          | Type | Register Width (Bits) | Address Offset | Physical Address |
|------------------------|------|-----------------------|----------------|------------------|
| DSI_PLL_CONTROL        | RW   | 32                    | 0x0000 0000    | 0x4804 FF00      |
| DSI_PLL_STATUS         | R    | 32                    | 0x0000 0004    | 0x4804 FF04      |
| DSI_PLL_GO             | RW   | 32                    | 0x0000 0008    | 0x4804 FF08      |
| DSI_PLL_CONFIGURATION1 | RW   | 32                    | 0x0000 000C    | 0x4804 FF0C      |
| DSI_PLL_CONFIGURATION2 | RW   | 32                    | 0x0000 0010    | 0x4804 FF10      |

## 7.7.2 Display Subsystem Register Descriptions

### 7.7.2.1 Display Subsystem Registers

**Table 7-128. DSS\_REVISIONNUMBER**

|                |                                                               |                  |             |          |      |
|----------------|---------------------------------------------------------------|------------------|-------------|----------|------|
| Address Offset | 0x000                                                         | Physical address | 0x4805 0000 | Instance | DISS |
| Description    | This register contains the display subsystem revision number. |                  |             |          |      |
| Type           | R                                                             |                  |             |          |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | REV |   |   |

| Bits | Field Name | Description                                                     | Type | Reset            |
|------|------------|-----------------------------------------------------------------|------|------------------|
| 31:8 | Reserved   | Read returns 0.                                                 | R    | 0x0000000        |
| 7:0  | REV        | Revision number<br>[7:4] Major revision<br>[3:0] Minor revision | R    | TI internal data |

**Table 7-129. Register Call Summary for Register DSS\_REVISIONNUMBER**

Display Subsystem Register Manual

- [Display Subsystem Register Mapping Summary: \[0\]](#)

**Table 7-130. DSS\_SYSCONFIG**

|                         |                                                                              |
|-------------------------|------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x010                                                                        |
| <b>Physical address</b> | 0x4805 0010                                                                  |
| <b>Instance</b>         | DISS                                                                         |
| <b>Description</b>      | This register controls the various parameters of the interconnect interface. |
| <b>Type</b>             | RW                                                                           |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          |          |           |          |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|----------|-----------|----------|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Reserved | Reserved | SOFTRESET | AUTOIDLE |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                         | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:5 | Reserved   | Write 0s for future compatibility. Reads return zero.                                                                                                                                               | RW   | 0x00000000 |
| 4:3  | Reserved   | Reserved. Keep at reset value.                                                                                                                                                                      | RW   | 0x0        |
| 2    | Reserved   | Write 0s for future compatibility . Reads return zero.                                                                                                                                              | RW   | 0          |
| 1    | SOFTRESET  | Software reset. Set this bit to 1 to trigger a module reset. The bit is automatically reset by the hardware. During reads, it always returns 0.<br><br>0x0: Normal mode<br>0x1: The module is reset | RW   | 0          |
| 0    | AUTOIDLE   | Enable power management capability<br><br>0x0: OCP clock is free-running<br>0x1: Automatic OCP clock gating strategy is applied based on the OCP interface activity                                 | RW   | 1          |

**Table 7-131. Register Call Summary for Register DSS\_SYSCONFIG**

- ## Display Subsystem Integration

- Software Reset: [0]
  - Autoidle Mode: [1]
  - DISPC Interrupt Request: [2]

- Display Subsystem Basic Programming Model

- Display Subsystem Reset: [3]

- ## Display Subsystem Use Cases and Tips

- Autoidle: [4]
  - Smart-Idle: [5]

- Display Subsystem Register Manual

- Display Subsystem Register Mapping Summary: [6]

**Table 7-132. DSS\_SYSSTATUS**

| Bits | Field Name | Description                                 | Type | Reset      |
|------|------------|---------------------------------------------|------|------------|
| 31:1 | Reserved   | Read returns 0.                             | R    | 0x00000000 |
| 0    | RESETDONE  | Internal reset monitoring                   | R    | 1          |
|      |            | Read 0x0: Internal module reset is ongoing. |      |            |
|      |            | Read 0x1: Reset completed                   |      |            |

**Table 7-133. Register Call Summary for Register DSS\_SYSSTATUS**

Display Subsystem Integration

- [Software Reset: \[0\]](#)

Display Subsystem Basic Programming Model

- [Display Subsystem Reset: \[1\]](#)

Display Subsystem Register Manual

- [Display Subsystem Register Mapping Summary: \[2\]](#)

**Table 7-134. DSS\_IRQSTATUS**

|                         |                                                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |           |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|-----------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 0018                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |           |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x4805 0018                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |           |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | The register indicates the source of the interrupt and the status of the interrupt line. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |           |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | R                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |           |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DSI IRQ |    | DISPC IRQ |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                          | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | RESERVED   | Reads returns 0.                                                                                                                     | R    | 0x00000000 |
| 1    | DSI_IRQ    | DSI interrupt status (related to <a href="#">DSI_IRQSTATUS</a> )<br>0x0: DSI interrupt inactive<br>0x1: DSI interrupt active         | R    | 0x0        |
| 0    | DISPC_IRQ  | DISPC interrupt status (related to <a href="#">DISPC_IRQSTATUS</a> )<br>0x0: DISPC interrupt inactive<br>0x1: DISPC interrupt active | R    | 0x0        |

**Table 7-135. Register Call Summary for Register DSS\_IRQSTATUS**

Display Subsystem Register Manual

- [Display Subsystem Register Mapping Summary: \[0\]](#)

**Table 7-136. DSS\_CONTROL**

|                         |                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x040                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x4805 0040                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register contains the display subsystem control bits. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------------|-----------------|-----------|----------------------|-----------------|----------------|------------------|---|
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | VENC_OUT_SEL | DAC_POWERDN_BGZ | DAC_DEMEN | VENC_CLOCK_4X_ENABLE | VENC_CLOCK_MODE | DSI_CLK_SWITCH | DISPC_CLK_SWITCH |   |

| Bits | Field Name           | Description                                                                                                                                                                                                                                                                                                                                                     | Type | Reset     |
|------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:7 | Reserved             | Reserved for future DAC use                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0000000 |
| 6    | VENC_OUT_SEL         | Video DAC1 input selection:<br>0x0: CVBS VENC output selected for composite video mode<br>0x1: Luminance VENC output selected for s-video mode                                                                                                                                                                                                                  | RW   | 0         |
| 5    | DAC_POWERDN_BGZ      | DAC Power-Down Control<br>0x0: DAC Power-Down Band Gap powered down<br>0x1: DAC Power-Down Band Gap powered up                                                                                                                                                                                                                                                  | RW   | 0         |
| 4    | DAC_DEMEN            | DAC dynamic element matching enable<br>0x0: DAC Dynamic Element Matching Disabled<br>0x1: DAC Dynamic Element Matching Enabled                                                                                                                                                                                                                                  | RW   | 0         |
| 3    | VENC_CLOCK_4X_ENABLE | VENC clock 4x enable<br>0x0: Disable<br>0x1: Enable                                                                                                                                                                                                                                                                                                             | RW   | 0         |
| 2    | VENC_CLOCK_MODE      | VENC clock mode. See <a href="#">Table 7-20, Possible Digital Clock Division for the Video Encoder</a> .<br>0x0: Mode 0. All three balanced clocks, derived from the DSS_TV_CLK clock, are provided to the VENC, if the VENC_CLOCK_4X_ENABLE bit [3] is set to 1 by software.<br>0x1: Mode 1. The VENC_CLOCK_4X_ENABLE bit [3] is used to control clock gating. | RW   | 0         |
| 1    | DSI_CLK_SWITCH       | Selects the clock source for the DSI functional clock<br>0x0: DSS1_ALWON_FCLK clock is selected (from PRCM)<br>0x1: DSI2_PLL_FCLK clock is selected (from DSI PLL)                                                                                                                                                                                              | RW   | 0         |
| 0    | DISPC_CLK_SWITCH     | Selects the clock source for the DISPC functional clock<br>0x0: DSS1_ALWON_FCLK clock is selected (from PRCM)<br>0x1: DSI1_PLL_FCLK clock is selected (from DSI PLL)                                                                                                                                                                                            | RW   | 0         |

**Table 7-137. Register Call Summary for Register DSS\_CONTROL**

## Display Subsystem Environment

- [TV Display Support: \[0\]](#)
- [Digital-to-Analog Converters: \[1\]](#)

## Display Subsystem Integration

- [Clocks: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\]](#)

## Display Subsystem Functional Description

- [Video Encoder Functionalities: \[8\]](#)
- [Video DAC Stage Power Management: \[9\] \[10\]](#)

## Display Subsystem Basic Programming Model

- [Display Subsystem Configuration Phase: \[11\] \[12\] \[13\] \[14\]](#)
- [Video DAC Stage Settings: \[15\]](#)

**Table 7-137. Register Call Summary for Register DSS\_CONTROL (continued)**

## Display Subsystem Use Cases and Tips

- [Display Subsystem Clock Configuration: \[16\] \[17\] \[18\]](#)
- [DPLL4 in Low-Power Mode: \[19\] \[20\]](#)
- [Switch to DSI PLL Clock Source: \[21\]](#)
- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O: \[22\] \[23\]](#)

## Display Subsystem Register Manual

- [Display Subsystem Register Mapping Summary: \[24\]](#)

**Table 7-138. DSS\_CLK\_STATUS**

|                       |                                                        |                         |             |                 |      |
|-----------------------|--------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x05C                                                  | <b>Physical address</b> | 0x4805 005C | <b>Instance</b> | DISS |
| <b>Description</b>    | This register contains the display subsystem register. |                         |             |                 |      |
| <b>Type</b>           | R                                                      |                         |             |                 |      |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name            | Description                                                                                                                                                                                                                                              | Type | Reset     |
|------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:9 | RESERVED              | RESERVED                                                                                                                                                                                                                                                 | R    | 0x0000000 |
| 8    | DSI_PLL_CLK2_STATUS   | DSI2_PLL_FCLK clock selection status (DSI mux) Indicates if the DSI protocol engine is running from the DS1_PLL_FCLK clock<br>Read 0: DS1_PLL_FCLK is not selected (unused by DSI).<br>Read 1: DS1_PLL_FCLK is selected (used by DSI).                   | R    | 0         |
| 7    | DSS_DSI_CLK1_STATUS   | DSS1_ALWON_FCLK clock selection status (DSI mux)<br>Indicates if the DSI protocol engine is running from the DS1_ALWON_FCLK clock<br>Read 0: DSS1_ALWON_FCLK is not selected (unused by DSI).<br>Read 1: DSS1_ALWON_FCLK is selected (used by DSI).      | R    | 0         |
| 6:2  | RESERVED              | RESERVED                                                                                                                                                                                                                                                 | R    | 0         |
| 1    | DSI_PLL_CLK1_STATUS   | DSI1_PLL_FCLK clock selection status (DISPC mux) Indicates if the display controller is running from the DS1_PLL_FCLK clock<br>Read 0: DS1_PLL_FCLK is not selected (unused by DISPC).<br>Read 1: DS1_PLL_FCLK is selected (used by DISPC).              | R    | 0         |
| 0    | DSS_DISPC_CLK1_STATUS | DSS1_ALWON_FCLK clock selection status (DISPC mux)<br>Indicates if the display controller is running from the DS1_ALWON_FCLK clock<br>Read 0: DSS1_ALWON_FCLK is not selected (unused by DISPC).<br>Read 1: DSS1_ALWON_FCLK is selected (used by DISPC). | R    | 1         |

**Table 7-139. Register Call Summary for Register DSS\_CLK\_STATUS**

## Display Subsystem Register Manual

- [Display Subsystem Register Mapping Summary: \[0\]](#)

### 7.7.2.2 Display Controller Registers

**Table 7-140. DISPC\_REVISION**

|                         |                                              |                 |      |
|-------------------------|----------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x000                                        |                 |      |
| <b>Physical address</b> | 0x4805 0400                                  | <b>Instance</b> | DISC |
| <b>Description</b>      | This register contains the IP revision code. |                 |      |
| <b>Type</b>             | R                                            |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REV |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                 | Type | Reset            |
|------|------------|-------------------------------------------------------------|------|------------------|
| 31:8 | Reserved   | Write 0s for future compatibility. Read returns 0.          | R    | 0x000000         |
| 7:0  | REV        | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision | R    | TI internal data |

**Table 7-141. Register Call Summary for Register DISPC\_REVISION**

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[0\]](#)

**Table 7-142. DISPC\_SYSCONFIG**

|                         |                                                                                       |                 |      |
|-------------------------|---------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x010                                                                                 |                 |      |
| <b>Physical address</b> | 0x4805 0410                                                                           | <b>Instance</b> | DISC |
| <b>Description</b>      | This register allows the control of various parameters of the interconnect interface. |                 |      |
| <b>Type</b>             | RW                                                                                    |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                                                                       |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----------------------------------------------------------------------|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | MIDLEMODE Reserved CLOCKACTIVITY SIDEMODE ENWAKEUP SOFTRESET AUTOIDLE |   |   |   |   |   |   |

| Bits  | Field Name    | Description                                                                                                                                                                                                                                                                                                               | Type | Reset   |
|-------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | Reserved      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                        | RW   | 0x00000 |
| 13:12 | MIDLEMODE     | Master interface power management, standby/waitcontrol<br><br>0x0: Force standby. MStandby is asserted only when the module is disabled.<br>0x1: No standby: MStandby is never asserted.<br>0x2: Smart Standby. MStandby is asserted based on the internal activity of the module.<br>0x3: Reserved                       | RW   | 0x0     |
| 11:10 | Reserved      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                        | RW   | 0x00    |
| 9:8   | CLOCKACTIVITY | Clock activity during wakeup mode period<br><br>0x0: Interface and functional clocks can be switched off.<br>0x1: Functional clocks can be switched off and interface clocks are maintained during wakeup period.<br>0x2: Interface clocks can be switched off and functional clocks are maintained during wakeup period. | RW   | 0x0     |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                             | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x3: Interface and functional clocks are maintained during wakeup period.                                                                                                                                                                                                                               |      |       |
| 7:5  | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                      | RW   | 0x0   |
| 4:3  | SIDLEMODE  | Slave interface power management, idle req/ack control<br><br>0x0: Force idle. An idle request is acknowledged unconditionally.<br>0x1: No idle. An idle request is never acknowledged.<br>0x2: Smart idle. Idle request is acknowledged based on the internal activity of the module.<br>0x3: Reserved | RW   | 0x0   |
| 2    | ENWAKEUP   | Wakeup feature control<br><br>0x0: Wakeup is disabled.<br>0x1: Wakeup is enabled.                                                                                                                                                                                                                       | RW   | 0     |
| 1    | SOFTRESET  | Software reset. Set this bit to 1 to trigger a module reset. The bit is automatically reset by the hardware. During reads, it always returns 0.<br><br>0x0: Normal mode<br>0x1: The module is reset.                                                                                                    | RW   | 0     |
| 0    | AUTOIDLE   | Internal interface clock gating strategy<br><br>0x0: Interface clock is free-running.<br>0x1: Automatic L3 and L4 interface clock gating strategy is applied based on interface activity.                                                                                                               | RW   | 1     |

**Table 7-143. Register Call Summary for Register DISPC\_SYSCONFIG**

## Display Subsystem Integration

- [Software Reset: \[0\]](#)
- [Clock Activity Mode: \[1\] \[2\] \[3\] \[4\] \[5\]](#)
- [Autoidle Mode: \[6\]](#)
- [Idle Mode: \[7\] \[8\] \[9\]](#)
- [Wake-Up Mode: \[10\]](#)
- [Standby Mode: \[11\]](#)

## Display Subsystem Basic Programming Model

- [Display Controller Configuration: \[12\]](#)

## Display Subsystem Use Cases and Tips

- [Autoidle: \[13\]](#)
- [Smart-Idle: \[14\]](#)
- [Reset DISPC: \[15\] \[16\] \[17\] \[18\]](#)
- [Configure the DISPC: \[19\] \[20\] \[21\] \[22\]](#)

## Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[23\]](#)

**Table 7-144. DISPC\_SYSSTATUS**

|                         |                                                                                                     |                 |      |
|-------------------------|-----------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x014                                                                                               |                 |      |
| <b>Physical address</b> | 0x4805 0414                                                                                         | <b>Instance</b> | DISC |
| <b>Description</b>      | This register provides status information about the module, excluding interrupt status information. |                 |      |
| <b>Type</b>             | R                                                                                                   |                 |      |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|---|---|---|---|---|---|---|-----------|---|---|
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Reserved |    |    |    |    |    |    |   |   |   |   |   |   |   | RESETDONE |   |   |

| Bits | Field Name | Description                                                                                                  | Type | Reset    |
|------|------------|--------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                           | R    | 0x000000 |
| 7:1  | Reserved   | Reserved. Read returns 0.                                                                                    | R    | 0x00     |
| 0    | RESETDONE  | Internal reset monitoring<br><br>Read 0x0: Internal module reset is ongoing.<br><br>Read 0x1: Reset complete | R    | 0        |

**Table 7-145. Register Call Summary for Register DISPC\_SYSSTATUS**

Display Subsystem Basic Programming Model

- [Display Controller Configuration: \[0\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[1\]](#)

**Table 7-146. DISPC\_IRQSTATUS**

| Address Offset | 0x018 | Physical address | 0x4805 0418 | Instance | DISC                                                                                                                                                                                                                                            | Description | This register regroups all the status of module internal events that generate an interrupt. A write of 1 to a given bit resets the bit. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------|-------|------------------|-------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Type           | RW    |                  |             |          | <th></th> |             |                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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         |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|-----------------|----------|---------------|-------------------|---------------|-------------------|----------|---------------------|---------------|------------------|----------------------|-------------------|------------|-------------|-------|-----------|
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WAKEUP | SYNCLOSTDIGITAL | SYNCLOST | VID2ENDWINDOW | VID2FIFOUNDERFLOW | VID1ENDWINDOW | VID1FIFOUNDERFLOW | OCVERROR | PALETTEGAMMALOADING | GFXTENDWINDOW | GFXFIFOUNDERFLOW | PROGRAMMEDLINENUMBER | ACBIASCOUNTSTATUS | EVSYNC_ODD | EVSYNC_EVEN | VSYNC | FRAMEDONE |

| Bits  | Field Name      | Description                                                                                                                                                      | Type | Reset  |
|-------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:17 | Reserved        | Write 0s for future compatibility.<br>Read returns 0                                                                                                             | RW   | 0x0000 |
| 16    | WAKEUP          | Wakeups<br><br>Read 0x0: Wakeup is false.<br>Write 0x0: Wakeup status bit unchanged<br>Read 0x1: Wakeup is true (pending).<br>Write 0x1: Wakeup status bit reset | RW   | 0      |
| 15    | SYNCLOSTDIGITAL | SyncLostDigital<br><br>Read 0x0: SyncLostDigital is false.<br>Write 0x0: SyncLostDigital status bit unchanged<br>Read 0x1: SyncLostDigital is true (pending).    | RW   | 0      |

| <b>Bits</b> | <b>Field Name</b>        | <b>Description</b>                                                                                                                                                                                                           | <b>Type</b> | <b>Reset</b> |
|-------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
|             |                          | Write 0x1: SyncLostDigital status bit reset                                                                                                                                                                                  |             |              |
| 14          | SYNCLOST                 | SyncLost<br>Read 0x0: SyncLost is false.<br>Write 0x0: SyncLost status bit unchanged<br>Read 0x1: SyncLost is true (pending).<br>Write 0x1: SyncLost status bit reset                                                        | RW          | 0            |
| 13          | VID2ENDWINDOW            | Vid2EndWindow<br>Read 0x0: Vid2EndWindow is false.<br>Write 0x0: Vid2EndWindow status bit unchanged<br>Read 0x1: Vid2EndWindow is true (pending).<br>Write 0x1: Vid2EndWindow status bit reset                               | RW          | 0            |
| 12          | VID2FIFOUNDERFLOW        | Vid2FIFOUnderflow<br>Read 0x0: Vid2FIFOUnderflow is false.<br>Write 0x0: Vid2FIFOUnderflow status bit unchanged<br>Read 0x1: Vid2FIFOUnderflow is true (pending).<br>Write 0x1: Vid2FIFOUnderflow status bit reset           | RW          | 0            |
| 11          | VID1ENDWINDOW            | Vid1EndWindow<br>Read 0x0: Vid1EndWindow is false.<br>Write 0x0: Vid1EndWindow status bit unchanged<br>Read 0x1: Vid1EndWindow is true (pending).<br>Write 0x1: Vid1EndWindow status bit reset                               | RW          | 0            |
| 10          | VID1FIFOUNDERFLOW        | Vid1FIFOUnderflow<br>Read 0x0: Vid1FIFOUnderflow is false.<br>Write 0x0: Vid1FIFOUnderflow status bit unchanged<br>Read 0x1: Vid1FIFOUnderflow is true (pending).<br>Write 0x1: Vid1FIFOUnderflow status bit reset           | RW          | 0            |
| 9           | OCPERROR                 | OCPError<br>Read 0x0: OCPError is false.<br>Write 0x0: OCPError status bit unchanged<br>Read 0x1: OCPError is true (pending).<br>Write 0x1: OCPError status bit reset                                                        | RW          | 0            |
| 8           | PALETTEGAMMA<br>LOADING  | PaletteGammaLoading<br>Read 0x0: PaletteGammaLoading is false.<br>Write 0x0: PaletteGammaLoading status bit unchanged<br>Read 0x1: PaletteGammaLoading is true (pending).<br>Write 0x1: PaletteGammaLoading status bit reset | RW          | 0            |
| 7           | GFXENDWINDOW             | GfxEndWindow<br>Read 0x0: GfxEndWindow is false.<br>Write 0x0: GfxEndWindow status bit unchanged<br>Read 0x1: GfxEndWindow is true (pending).<br>Write 0x1: GfxEndWindow status bit reset                                    | RW          | 0            |
| 6           | GFXFIFOUNDERFLOW         | GfxFIFOUnderflow<br>Read 0x0: GfxFIFOUnderflow is false.<br>Write 0x0: GfxFIFOUnderflow status bit unchanged<br>Read 0x1: GfxFIFOUnderflow is true (pending).<br>Write 0x1: GfxFIFOUnderflow status bit reset                | RW          | 0            |
| 5           | PROGRAMMEDLINE<br>NUMBER | ProgrammedLineNumber<br>Read 0x0: ProgrammedLineNumber is false.                                                                                                                                                             | RW          | 0            |

| Bits | Field Name        | Description                                                                                                                                                                                                        | Type | Reset |
|------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |                   | Write 0x0: ProgrammedLineNumber status bit unchanged<br>Read 0x1: ProgrammedLineNumber is true (pending).<br>Write 0x1: ProgrammedLineNumber status bit reset                                                      |      |       |
| 4    | ACBIASCOUNTSTATUS | ACBiasCountStatus<br>Read 0x0: ACBiasCountStatus is false.<br>Write 0x0: ACBiasCountStatus status bit unchanged<br>Read 0x1: ACBiasCountStatus is true (pending).<br>Write 0x1: ACBiasCountStatus status bit reset | RW   | 0     |
| 3    | EVSYNC_ODD        | EVSYNC_ODD<br>Read 0x0: EVSYNC_ODD is false.<br>Write 0x0: EVSYNC_ODD status bit unchanged<br>Read 0x1: EVSYNC_ODD is true (pending).<br>Write 0x1: EVSYNC_ODD status bit reset                                    | RW   | 0     |
| 2    | EVSYNC_EVEN       | EVSYNC_EVEN<br>Read 0x0: EVSYNC_EVEN is false.<br>Write 0x0: EVSYNC_EVEN status bit unchanged<br>Read 0x1: EVSYNC_EVEN is true (pending).<br>Write 0x1: EVSYNC_EVEN status bit reset                               | RW   | 0     |
| 1    | VSYNC             | VSYNC<br>Read 0x0: VSYNC is false.<br>Write 0x0: VSYNC status bit unchanged<br>Read 0x1: VSYNC is true (pending).<br>Write 0x1: VSYNC status bit reset                                                             | RW   | 0     |
| 0    | FRAMEDONE         | FrameDone<br>Read 0x0: FrameDone is false.<br>Write 0x0: FrameDone status bit unchanged<br>Read 0x1: FrameDone is true (pending).<br>Write 0x1: FrameDone status bit reset                                         | RW   | 0     |

**Table 7-147. Register Call Summary for Register DISPC\_IRQSTATUS**

## Display Subsystem Integration

- [DISPC Interrupt Request: \[0\] \[1\]](#)

## Display Subsystem Basic Programming Model

- [Display Subsystem Reset: \[2\] \[3\]](#)
- [Display Controller Configuration: \[4\]](#)
- [TV Set-Specific Control Registers: \[5\]](#)
- [Video Encoder Programming Sequence: \[6\]](#)

## Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[7\]](#)
- [Display Subsystem Registers: \[8\]](#)

**Table 7-148. DISPC\_IRQENABLE**

|                       |                                                                                                              |                         |             |                 |      |
|-----------------------|--------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x01C                                                                                                        | <b>Physical address</b> | 0x4805 041C | <b>Instance</b> | DISC |
| <b>Description</b>    | This register allows the masking/unmasking of module internal interrupt sources, on an event-by-event basis. |                         |             |                 |      |
| <b>Type</b>           | RW                                                                                                           |                         |             |                 |      |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name        | Description                                                                                                             | Type | Reset  |
|-------|-------------------|-------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:17 | Reserved          | Write 0s for future compatibility. Read returns 0.                                                                      | RW   | 0x0000 |
| 16    | WAKEUP            | Wakeups mask<br>0x0: Wakeup is masked.<br>0x1: Wakeup generates an interrupt when it occurs.                            | RW   | 0      |
| 15    | SYNCLOSTDIGITAL   | SyncLostDigital<br>0x0: SyncLostDigital is masked.<br>0x1: SyncLostDigital generates an interrupt when it occurs.       | RW   | 0      |
| 14    | SYNCLOST          | SyncLost<br>0x0: SyncLost is masked.<br>0x1: SyncLost generates an interrupt when it occurs.                            | RW   | 0      |
| 13    | VID2ENDWINDOW     | Vid2EndWindow<br>0x0: Vid2EndWindow is masked.<br>0x1: Vid2EndWindow generates an interrupt when it occurs.             | RW   | 0      |
| 12    | VID2FIFOUNDERFLOW | Vid2FIFOUnderflow<br>0x0: Vid2FIFOUnderflow is masked.<br>0x1: Vid2FIFOUnderflow generates an interrupt when it occurs. | RW   | 0      |
| 11    | ENDVID1WINDOW     | EndVid1Window<br>0x0: EndVid1Window is masked.<br>0x1: EndVid1Window generates an interrupt when it occurs.             | RW   | 0      |
| 10    | VID1FIFOUNDERFLOW | Vid1FIFOUnderflow<br>0x0: Vid1FIFOUnderflow is masked.<br>0x1: Vid1FIFOUnderflow generates an interrupt when it occurs. | RW   | 0      |
| 9     | OCPERROR          | OCPError<br>0x0: OCPError is masked.<br>0x1: OCPError generates an interrupt when it occurs.                            | RW   | 0      |
| 8     | PALETTEGAMMAMASK  | PaletteGammaMask<br>0x0: PaletteGammaMask is masked.<br>0x1: PaletteGammaMask generates an interrupt when it occurs.    | RW   | 0      |
| 7     | GFXENDWINDOW      | GfxEndWindow                                                                                                            | RW   | 0      |

| Bits | Field Name            | Description                                                                                                                      | Type | Reset |
|------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |                       | 0x0: GfxEndWindow is masked.<br>0x1: GfxEndWindow generates an interrupt when it occurs.                                         |      |       |
| 6    | GFXFIFOUNDERFLOW      | GfxFIFOUnderflow<br>0x0: GfxFIFOUnderflow is masked.<br>0x1: GfxFIFOUnderflow generates an interrupt when it occurs.             | RW   | 0     |
| 5    | PROGRAMMEDLINE NUMBER | ProgrammedLineNumber<br>0x0: ProgrammedLineNumber is masked.<br>0x1: ProgrammedLineNumber generates an interrupt when it occurs. | RW   | 0     |
| 4    | ACBIASCOUNTSTATUS     | ACBiasCountStatus<br>0x0: ACBiasCountStatus is masked.<br>0x1: ACBiasCountStatus generates an interrupt when it occurs.          | RW   | 0     |
| 3    | EVSYNC_ODD            | EVSYNC_ODD<br>0x0: EVSYNC_ODD is masked.<br>0x1: EVSYNC_ODD generates an interrupt when it occurs.                               | RW   | 0     |
| 2    | EVSYNC_EVEN           | EVSYNC_EVEN<br>0x0: EVSYNC_EVEN is masked.<br>0x1: EVSYNC_EVEN generates an interrupt when it occurs.                            | RW   | 0     |
| 1    | VSYNC                 | VSYNC<br>0x0: VSYNC is masked.<br>0x1: VSYNC generates an interrupt when it occurs.                                              | RW   | 0     |
| 0    | FRAMEMASK             | FrameMask<br>0x0: FrameMask is masked.<br>0x1: FrameMask generates an interrupt when it occurs.                                  | RW   | 0     |

**Table 7-149. Register Call Summary for Register DISPC\_IRQENABLE**

## Display Subsystem Integration

- [DISPC Interrupt Request: \[0\] \[1\]](#)

## Display Subsystem Basic Programming Model

- [Display Controller Configuration: \[2\]](#)
- [TV Set-Specific Control Registers: \[3\]](#)
- [Video Encoder Programming Sequence: \[4\] \[5\] \[6\]](#)

## Display Subsystem Use Cases and Tips

- [Reset DISPC: \[7\]](#)
- [Configure the DISPC: \[8\]](#)

## Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[9\]](#)

**Table 7-150. DISPC\_CONTROL**

|                       |                                                                |                         |             |                 |      |
|-----------------------|----------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x040                                                          | <b>Physical address</b> | 0x4805 0440 | <b>Instance</b> | DISC |
| <b>Description</b>    | The control register configures the display controller module. |                         |             |                 |      |
| <b>Type</b>           | RW                                                             |                         |             |                 |      |

| 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 |
|--------------------------------|----|--------------|-----------------|---------------|---------------|----------------|-----------------|-----------|----|----|----|--------|--------|-------|-------|---------------------|-----------|----------|--------------|--------------|----------|-------|-----|--------|-----------|----------------|-----------|---|---|---|---|
| SPATIALTEMPORALDITHERINGFRAMES |    | LCDENABLEPOL | LCDENABLESIGNAL | PCKFREEENABLE | TDMUNUSEDBITS | TDMCYCLEFORMAT | TDMPARALLELMODE | TDMENABLE |    | HT |    | GPOUT1 | GPOUT0 | GPIN1 | GPIN0 | OVERLAYOPTIMIZATION | STALLMODE | Reserved | TFTDATA1INES | STDITHENABLE | GDIGITAL | GOLCD | M8B | STNTFT | MONOCOLOR | DIGITABLENABLE | LCDENABLE |   |   |   |   |

| Bits  | Field Name                      | Description                                                                                                                                                                                 | Type | Reset |
|-------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | SPATIALTEMPORAL DITHERINGFRAMES | Spatial/Temporal dithering number of frames<br>wr: VFP<br><br>0x0: Spatial only<br>0x1: Spatial and temporal over two frames<br>0x2: Spatial and temporal over four frames<br>0x3: Reserved | RW   | 0x0   |
| 29    | LCDENABLEPOL                    | LCD Enable Signal Polarity<br><br>0x0: Active low<br>0x1: Active high                                                                                                                       | RW   | 0     |
| 28    | LCDENABLESIGNAL                 | LCD Enable Signal: LCD interface active/inactive<br><br>0x0: Signal disabled<br>0x1: Signal enabled                                                                                         | RW   | 0     |
| 27    | PCKFREEENABLE                   | Pixel clock free-running enabled/disabled<br><br>0x0: Clock disabled<br>0x1: Clock enabled                                                                                                  | RW   | 0     |
| 26:25 | TDMUNUSEDBITS                   | State of unused bits (TDM mode only)<br>WR: VFP<br><br>0x0: Low level (0)<br>0x1: High level (1)<br>0x2: Unchanged from previous state<br>0x3: Reserved                                     | RW   | 0x0   |
| 24:23 | TDMCYCLEFORMAT                  | Cycle format (TDM mode only)<br>WR: VFP<br><br>0x0: 1 cycle for 1 pixel<br>0x1: 2 cycles for 1 pixel<br>0x2: 3 cycles for 1 pixel<br>0x3: 3 cycles for 2 pixels                             | RW   | 0x0   |
| 22:21 | TDMPARALLELMODE                 | Output Interface width (TDM mode only)<br>WR: VFP<br><br>0x0: 8-bit parallel output interface selected                                                                                      | RW   | 0x0   |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name          | Description                                                                                                                                                                                                                                                                                                                                                              | Type | Reset |
|-------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|       |                     | 0x1: 9-bit parallel output interface selected<br>0x2: 12-bit parallel output interface selected<br>0x3: 16-bit parallel output interface selected                                                                                                                                                                                                                        |      |       |
| 20    | TDMENABLE           | Enable the multiple cycle format (TDM mode used only for Active Matrix mode with the RFBI enable bit off).<br>WR: VFP<br>0x0: TDM disabled<br>0x1: TDM enabled                                                                                                                                                                                                           | RW   | 0     |
| 19:17 | HT                  | Hold Time for digital output<br>WR: EVSYNC<br>Encoded value (from 0 to 7) holds time for digital output. The data will be held for (HT + 1) external digital clock periods.                                                                                                                                                                                              | RW   | 0x0   |
| 16    | GPOUT1              | General Purpose Output Signal<br>0x0: The GPout1 is reset.<br>0x1: The GPout1 is set.                                                                                                                                                                                                                                                                                    | RW   | 0     |
| 15    | GPOUT0              | General Purpose Output Signal<br>0x0: The GPout0 is reset.<br>0x1: The GPout0 is set.                                                                                                                                                                                                                                                                                    | RW   | 0     |
| 14    | GPIN1               | General Purpose Input Signal<br>WR: VFP<br>Read: The GPin1 has been reset.<br>0x0:<br>Read: The GPin1 has been set.<br>0x1:                                                                                                                                                                                                                                              | R    | 0     |
| 13    | GPIN0               | General Purpose Input Signal<br>WR: VFP<br>Read: The GPin0 has been reset.<br>0x0:<br>Read: The GPin0 has been set.<br>0x1:                                                                                                                                                                                                                                              | R    | 0     |
| 12    | OVERLAYOPTIMIZATION | Overlay Optimization (available when graphics format is NOT is 1-, 2, and 4-BPP)<br>WR: VFP or EVSYNC<br>0x0: Graphics data below video1 window fetched from memory or no overlap between graphics and video1 windows.<br>0x1: Graphics data below video1 window not fetched from memory.                                                                                | RW   | 0     |
| 11    | STALLMODE           | Stall mode for the LCD output<br>wr: VFP<br>0x0: Normal mode selected<br>0x1: Stall mode selected. The Display Controller sends the data without considering the VSYNC/HSYNC. The LCD output is disabled at the end of the transfer of the frame. The S/W has to re-enable the LCD output to generate a new frame. The stall mode is used in RFBI and DSI command modes. | RW   | 0     |
| 10    | Reserved            | Reserved for non-GP devices                                                                                                                                                                                                                                                                                                                                              | RW   | 0     |
| 9:8   | TFTDATALINES        | Number of lines of the LCD interface<br>WR: VFP<br>0x0: 12-bit output aligned on the LSB of the pixel data interface<br>0x1: 16-bit output aligned on the LSB of the pixel data interface<br>0x2: 18-bit output aligned on the LSB of the pixel data interface<br>0x3: 24-bit output aligned on the LSB of the pixel data interface                                      | RW   | 0x0   |

| Bits | Field Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                             | Type | Reset |
|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7    | STDITHERENABLE | Spatial temporal dithering enable<br>WR: VFP<br><br>0x0: Spatial/temporal dithering logic disabled<br>0x1: Spatial/temporal dithering logic enabled                                                                                                                                                                                                                                                                                     | RW   | 0     |
| 6    | GODIGITAL      | Digital GO Command<br><br>0x0: The hardware has finished updating the internal shadow registers of the pipeline(s) associated with the digital output using the user values. The hardware resets the bit when the update is completed.<br><br>0x1: Users have finished programming the shadow registers of the pipeline(s) associated with the digital output and the hardware can update the internal registers at the external VSYNC. | RW   | 0     |
| 5    | GOLCD          | LCD GO Command<br><br>0x0: The hardware has finished updating the internal shadow registers of the pipeline(s) connected to the LCD output using the user values. The hardware resets the bit when the update is completed.<br><br>0x1: Users have finished programming the shadow registers of the pipeline(s) associated with the LCD output and the hardware can update the internal registers at the VFP start period.              | RW   | 0     |
| 4    | M8B            | Mono 8-bit mode<br>WR: VFP<br><br>0x0: Pixel data [3:0] is used to output four pixel values to the panel at each pixel clock transition (only in Passive Mono 8-bit mode).<br><br>0x1: Pixel data [7:0] is used to output eight pixel values to the panel each pixel clock transition (only in Passive Mono 8-bit mode).                                                                                                                | RW   | 0     |
| 3    | STNTFT         | LCD display type<br>WR: VFP<br><br>0x0: Passive or Passive Matrix display operation enabled. Passive Matrix dither logic enabled.<br><br>0x1: Active Matrix display operation enabled. Passive Matrix Dither logic and output FIFO bypassed.                                                                                                                                                                                            | RW   | 0     |
| 2    | MONOCOLOR      | Monochrome/Color<br>WR: VFP<br><br>0x0: Color operation enabled (Passive Matrix mode only)<br><br>0x1: Monochrome operation enabled (Passive Matrix mode only)                                                                                                                                                                                                                                                                          | RW   | 0     |
| 1    | DIGITALENABLE  | Digital enable<br><br>0x0: Digital output disabled (at the end of the current field if interlace output when the bit is reset)<br><br>0x1: Digital output enabled                                                                                                                                                                                                                                                                       | RW   | 0     |
| 0    | LCDENABLE      | LCD enable<br><br>0x0: LCD output disabled (at the end of the frame when the bit is reset)<br><br>0x1: LCD output enabled                                                                                                                                                                                                                                                                                                               | RW   | 0     |

**Table 7-151. Register Call Summary for Register DISPC\_CONTROL**
**Display Subsystem Environment**

- [Parallel Interface: \[0\]](#) [\[1\]](#) [\[2\]](#)
- [Transaction Timing Diagrams: \[3\]](#)
- [Video Port Used on Command Mode: \[4\]](#)

**Table 7-151. Register Call Summary for Register DISPC\_CONTROL (continued)**

## Display Subsystem Integration

- [Clocks](#): [5]
- [DISPC Interrupt Request](#): [6] [7]

## Display Subsystem Functional Description

- [Overlay Support](#): [8]
- [Multiple Cycle Output Format](#): [9]
- [Command Mode](#): [10]

## Display Subsystem Basic Programming Model

- [Display Subsystem Reset](#): [11]
- [Display Controller Basic Programming Model](#): [12] [13] [14] [15] [16] [17] [18]
- [Graphics DMA Registers](#): [19]
- [Graphics Layer Configuration Registers](#): [20] [21]
- [Graphics Window Attributes](#): [22]
- [Video DMA Registers](#): [23]
- [Video Configuration Register](#): [24] [25]
- [Video Up-/Down-Sampling Configuration](#): [26] [27]
- [Image Data from On-Chip SRAM](#): [28]
- [LCD-Specific Control Registers](#): [29] [30]
- [LCD Attributes](#): [31] [32] [33] [34]
- [LCD Timings](#): [35] [36] [37]
- [LCD Overlay](#): [38] [39] [40]
- [LCD TDM](#): [41] [42] [43] [44] [45] [46] [47]
- [LCD Spatial/Temporal Dithering](#): [48] [49] [50] [51] [52]
- [LCD Color Phase Rotation](#): [53] [54] [55]
- [TV Set-Specific Control Registers](#): [56] [57] [58] [59]
- [Digital Timings](#): [60]
- [Digital Overlay](#): [61] [62] [63]
- [Video Mode Transfer](#): [64]
- [Command Mode Transfer Example 1](#): [65]
- [Command Mode Transfer Example 2](#): [66]
- [DISPC Control Registers](#): [67] [68] [69] [70] [71] [72]
- [Enable](#): [73]
- [Video Encoder Programming Sequence](#): [74] [75]

## Display Subsystem Use Cases and Tips

- [Configure DISPC Timing, Window, and Color](#): [76] [77] [78] [79] [80] [81] [82] [83] [84]
- [Enable Video Mode Using the DISPC Video Port](#): [85] [86] [87]
- [Configure the DISPC](#): [88] [89] [90] [91] [92] [93] [94] [95] [96]
- [Send Frame Data to LCD Panel Using Automatic TE](#): [97]

## Display Subsystem Register Manual

- [Display Controller Register Mapping Summary](#): [98]
- [Display Controller Registers](#): [99]

**Table 7-152. DISPC\_CONFIG**

|                         |                                                                                                                        |                         |                 |                 |      |           |                  |              |                 |              |          |             |            |           |                 |                |                   |          |            |
|-------------------------|------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|------|-----------|------------------|--------------|-----------------|--------------|----------|-------------|------------|-----------|-----------------|----------------|-------------------|----------|------------|
| <b>Address Offset</b>   | 0x044                                                                                                                  | <b>Physical address</b> | 0x4805 0444     | <b>Instance</b> | DISC |           |                  |              |                 |              |          |             |            |           |                 |                |                   |          |            |
| <b>Description</b>      | This control register configures the display controller module. Shadow register, updated on VFP start period or EVSYNC |                         |                 |                 |      |           |                  |              |                 |              |          |             |            |           |                 |                |                   |          |            |
| <b>Type</b>             | RW                                                                                                                     |                         |                 |                 |      |           |                  |              |                 |              |          |             |            |           |                 |                |                   |          |            |
| 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 |                 |      |           |                  |              |                 |              |          |             |            |           |                 |                |                   |          |            |
| RESERVED                |                                                                                                                        |                         |                 |                 |      |           |                  |              |                 |              |          |             |            |           |                 |                |                   |          |            |
|                         | TVALPHABLENDERENABLE                                                                                                   | LCDALPHABLENDERENABLE   | FIFOFILLING     | FIFOHANDCHECK   | CPR  | FIFOMERGE | TCKDIGISELECTION | TCKDIGENABLE | TCKLCDSELECTION | TCKLCDENABLE | FUNCATED | ACBIASGATED | VSYNCGATED | HSGNCATED | PIXELCLOCKGATED | PIXELDATAGATED | PALETTEGAMMATABLE | LOADMODE | PIXELGATED |

| Bits   | Field Name            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset   |
|--------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31: 20 | Reserved              | Write 0s for future compatibility. Read returns 0                                                                                                                                                                                                                                                                                                                                                                                                                                 | RW   | 0x00000 |
| 19     | TVALPHABLENDERENABLE  | Selects the alpha blender (TV output)<br><br>0x0: Alpha blender is disabled.<br>0x1: The alpha blender is enabled.                                                                                                                                                                                                                                                                                                                                                                | RW   | 0       |
| 18     | LCDALPHABLENDERENABLE | Selects the alpha blender (LCD output)<br><br>0x0: Alpha blender is disabled.<br>0x1: The alpha blender is enabled.                                                                                                                                                                                                                                                                                                                                                               | RW   | 0       |
| 17     | FIFOFILLING           | Controls if the FIFO are refilled only when the LOW threshold is reached or if all FIFO are refilled when at least one of them reaches the LOW threshold.<br><br>0x0: Each FIFO is refilled when it reaches LOW threshold.<br>0x1: All FIFOs are refilled up to high threshold when at least one of them reaches the LOW threshold. (only active FIFOs should be considered and when reaching the end of the frame the FIFO goes to empty condition so no need to fill it again). | RW   | 0       |
| 16     | FIFOHANDCHECK         | Controls the handshake between FIFO and RFBI STALL to prevent from underflow. The bit should be set to 0 when the module is not in STALL mode.<br><br>0x0: Only the STALL signal from RFBI is used regardless of the FIFO fullness information to provide data to the RFBI module.<br>0x1: The STALL signal from RFBI is used in combination with the FIFO fullness information to provide data to the RFBI module only when it does not generated FIFO underflow.                | RW   | 0       |
| 15     | CPR                   | Color phase rotation control wr: VFP<br><br>0x0: Color phase rotation disabled<br>0x1: Color phase rotation enabled                                                                                                                                                                                                                                                                                                                                                               | RW   | 0       |
| 14     | FIFOMERGE             | FIFO merge control wr: EVSYNC or VFP<br><br>0x0: FIFO merge disabled<br>Each FIFO is dedicated to one pipeline.                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0       |

## Display Subsystem Register Manual

www.ti.com

| Bits | Field Name        | Description                                                                                                                                                                                                                                                                              | Type | Reset |
|------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |                   | 0x1: FIFO merge enabled<br>All the FIFOs are merged into a single one to be used by the single active pipeline.                                                                                                                                                                          |      |       |
| 13   | TCKDIGSELECTION   | Transparency color key selection (digital output)<br>wr: EVSYNC<br><br>0x0: Graphics destination transparency color key selected in normal mode or graphics source transparency color key selected in alpha mode<br><br>0x1: Video source transparency color key selected in normal mode | RW   | 0     |
| 12   | TCKDIGENABLE      | Transparency color key enabled (digital output)<br>wr: EVSYNC<br><br>0x0: Disable the transparency color key for digital output<br>0x1: Enable the transparency color key for digital output                                                                                             | RW   | 0     |
| 11   | TCKLCDSELECTION   | Transparency color key selection (LCD output)<br>WR: VFP<br><br>0x0: Graphics destination transparency color key selected in normal mode or graphics source transparency color key selected in alpha mode<br><br>0x1: Video source transparency color key selected in normal mode        | RW   | 0     |
| 10   | TCKLCDENABLE      | Transparency color key enabled (LCD output)<br>WR: VFP *<br><br>0x0: Disable the transparency color key for the LCD<br>0x1: Enable the transparency color key for the LCD                                                                                                                | RW   | 0     |
| 9    | FUNCGATED         | Functional clocks gated enabled<br>WR: immediate<br><br>0x0: Functional clocks gated disabled<br>0x1: Functional clocks gated enabled                                                                                                                                                    | RW   | 0     |
| 8    | ACBIASGATED       | ACBias Gated Enabled<br>WR: VFP<br><br>0x0: AcBias Gated Disabled<br>0x1: AcBias Gated Enabled                                                                                                                                                                                           | RW   | 0     |
| 7    | VSYNCGATED        | VSYNC Gated Enabled<br>WR: VFP<br><br>0x0: VSYNC Gated Disabled<br>0x1: VSYNC Gated Enabled                                                                                                                                                                                              | RW   | 0     |
| 6    | HSGNGATED         | HSGNGATED Enabled<br>WR: VFP<br><br>0x0: HSGNGATED Disabled<br>0x1: HSGNGATED Enabled                                                                                                                                                                                                    | RW   | 0     |
| 5    | PIXELCLOCKGATED   | Pixel Clock Gated Enabled<br>WR: VFP<br><br>0x0: Pixel Clock Gated Disabled<br>0x1: Pixel Clock Gated Enabled                                                                                                                                                                            | RW   | 0     |
| 4    | PIXELDATAGATED    | Pixel Data Gated Enabled<br>WR: VFP<br><br>0x0: Pixel Data Gated Disabled<br>0x1: Pixel Data Gated Enabled                                                                                                                                                                               | RW   | 0     |
| 3    | PALETTEGAMMATABLE | Palette/Gamma Table selection<br>WR: EVSYNC or VFP<br><br>0x0: LUT used as palette (only if graphics format is BITMAP1, 2, 4, and 8)<br>0x1: LUT used as gamma table (only if graphics format is NOT BITMAP1, 2, 4, and 8 or no graphics window present)                                 | RW   | 0     |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 2:1  | LOADMODE   | Loading Mode for the Palette/Gamma Table<br>WR: EVSYNC or VFP<br>0x0: Palette/Gamma Table and data are loaded every frame.<br>0x1: Palette/Gamma Table to be loaded. Users set the bit when the palette/gamma table has to be loaded. H/W resets the bit when table has been loaded.<br><code>(DISPC_GFX_ATTRIBUTES.GfxEnable</code> has to be set to 1).<br>0x2: Frame data only loaded every frame<br>0x3: Palette/Gamma Table and frame data loaded on first frame then switch to 10 (H/W). | RW   | 0x0   |
| 0    | PIXELGATED | Pixel Gated Enable (only for Active Matrix Display)<br>WR: VFP<br>0x0: Pixel clock always toggles (only in Active Matrix mode)<br>0x1: Pixel clock only toggles when there is valid data to display. (only in Active Matrix mode)                                                                                                                                                                                                                                                              | RW   | 0     |

**Table 7-153. Register Call Summary for Register DISPC\_CONFIG**

Display Subsystem Environment

- [Transaction Timing Diagrams: \[0\]](#)

Display Subsystem Integration

- [Autoidle Mode: \[1\]](#)
- [Wake-Up Mode: \[2\]](#)

Display Subsystem Functional Description

- [Transparency Color Keys: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\]](#)

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[15\]](#)
- [Graphics DMA Registers: \[16\] \[17\] \[18\]](#)
- [Graphics Layer Configuration Registers: \[19\]](#)
- [Video DMA Registers: \[20\] \[21\]](#)
- [Video Configuration Register: \[22\]](#)
- [LCD-Specific Control Registers: \[23\]](#)
- [LCD Timings: \[24\] \[25\] \[26\] \[27\] \[28\]](#)
- [LCD Overlay: \[29\] \[30\] \[31\]](#)
- [LCD Color Phase Rotation: \[32\]](#)
- [TV Set-Specific Control Registers: \[33\]](#)
- [Digital Overlay: \[34\] \[35\] \[36\]](#)

Display Subsystem Use Cases and Tips

- [Autoidle: \[37\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[38\]](#)

**Table 7-154. DISPC DEFAULT COLOR m**

|                         |                                                                                                                                                                                                                                                                                    |                 |            |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x04C + m * 0x04                                                                                                                                                                                                                                                                   | <b>Indexm</b>   | m = 0 to 1 |
| <b>Physical address</b> | 0x4805 044C + m * 0x04                                                                                                                                                                                                                                                             | <b>Instance</b> | DISPC      |
| <b>Description</b>      | The control register allows to configure the default solid background color for the LCD (DISPC_DEFAULT_COLOR_0) and for 24-bit digital output (DISPC_DEFAULT_COLOR_1). Shadow register, updated on VFP start period for DISPC_DEFAULT_COLOR_0 and EVSYNC for DISPC_DEFAULT_COLOR_1 |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                 |                 |            |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | DEFAULT COLOR           |                       |                 |

| Bits  | Field Name   | Description                                                                                                   | Type | Reset    |
|-------|--------------|---------------------------------------------------------------------------------------------------------------|------|----------|
| 31:24 | Reserved     | Write 0s for future compatibility.<br>Read returns 0                                                          | RW   | 0x00     |
| 23:0  | DEFAULTCOLOR | 24-bit RGB color value to specify the default solid color to display when there is no data from the overlays. | RW   | 0x000000 |

**Table 7-155. Register Call Summary for Register DISPC\_DEFAULT\_COLOR\_m**

---

Display Subsystem Basic Programming Model

- Display Controller Basic Programming Model: [0] [1]
  - LCD-Specific Control Registers: [2]
  - LCD Overlay: [3]
  - TV Set-Specific Control Registers: [4]
  - Digital Overlay: [5]

Display Subsystem Register Manual

- #### • Display Controller Register Mapping Summary: [6]

Table 7-156. DISPC TRANS COLOR m

|                         |                                                                                                                                                                                                                                                                                    |                 |            |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x054 + m * 0x04                                                                                                                                                                                                                                                                   | <b>Index</b>    | m = 0 to 1 |
| <b>Physical address</b> | 0x4805 0454 + m * 0x04                                                                                                                                                                                                                                                             | <b>Instance</b> | DISPC      |
| <b>Description</b>      | The register sets the transparency color value for the video/graphics overlays for the LCD output (DISPC_TRANS_COLOR_0) for 24-bit digital output(DISPC_TRANS_COLOR_1).<br>Shadow register, updated on VFP start period for DISPC_TRANS_COLOR_0 and EVSYNC for DISPC_TRANS_COLOR_1 |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                 |                 |            |

|          |    |    |    |    |    |    |    |               |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    | TRANSCOLORKEY |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                              | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:24       | Reserved          | Write 0s for future compatibility.<br>Read returns 0                                                                                                                                                                                                                                                            | RW          | 0x00         |
| 23:0        | TRANSCOLORKEY     | Transparency Color Key Value in RGB format<br>[0:0] BITMAP 1 (CLUT), [23,1] set to 0s<br>[1:0] BITMAP 2 (CLUT), [23,2] set to 0s<br>[3:0] BITMAP 4 (CLUT), [23,4] set to 0s<br>[7:0] BITMAP 8 (CLUT), [23,8] set to 0s<br>[11:0] RGB 12, [23,12] set to 0s<br>[15:0] RGB 16, [23,16] set to 0s<br>[23:0] RGB 24 | RW          | 0x000000     |

**Table 7-157. Register Call Summary for Register DISPC\_TRANS\_COLOR\_m**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#) [\[1\]](#)
- [LCD-Specific Control Registers: \[2\]](#)
- [TV Set-Specific Control Registers: \[3\]](#)
- [Digital Overlay: \[4\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[5\]](#)

**Table 7-158. DISPC\_LINE\_STATUS**

|                       |                                                                           |                         |             |                 |      |
|-----------------------|---------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x05C                                                                     | <b>Physical address</b> | 0x4805 045C | <b>Instance</b> | DISC |
| <b>Description</b>    | The control register indicates the current LCD panel display line number. |                         |             |                 |      |
| <b>Type</b>           | R                                                                         |                         |             |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |            |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | LINENUMBER |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:11       | Reserved          | Write 0s for future compatibility.<br>Read returns 0                                                                                                              | R           | 0x000000     |
| 10:0        | LINENUMBER        | Current LCD panel line number<br>Current display line number. The first active line has the value 0.<br>During blanking lines the line number is not incremented. | R           | 0x7FF        |

**Table 7-159. Register Call Summary for Register DISPC\_LINE\_STATUS**

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[0\]](#)

**Table 7-160. DISPC\_LINE\_NUMBER**

|                       |                                                                                                                                                          |                         |             |                 |      |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x060                                                                                                                                                    | <b>Physical address</b> | 0x4805 0460 | <b>Instance</b> | DISC |
| <b>Description</b>    | The control register indicates the LCD panel display line number for the interrupt and the DMA request.<br>Shadow register, updated on VFP start period. |                         |             |                 |      |
| <b>Type</b>           | RW                                                                                                                                                       |                         |             |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |            |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | LINENUMBER |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                    | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:11       | Reserved          | Write 0s for future compatibility.<br>Read returns 0                                                                                                  | RW          | 0x000000     |
| 10:0        | LINENUMBER        | LCD panel line number programming<br>LCD line number defines the line on which the programmable<br>interrupt is generated and the DMA request occurs. | RW          | 0x000        |

**Table 7-161. Register Call Summary for Register DISPC\_LINE\_NUMBER**

Display Subsystem Integration

- [Display Controller DMA Request \(Line Trigger\): \[0\]](#)

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[1\]](#)

**Table 7-161. Register Call Summary for Register DISPC\_LINE\_NUMBER (continued)**

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[2\]](#)

**Table 7-162. DISPC\_TIMING\_H**

|                       |                                                                                                             |                         |             |                 |      |
|-----------------------|-------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x064                                                                                                       | <b>Physical address</b> | 0x4805 0464 | <b>Instance</b> | DISC |
| <b>Description</b>    | The register configures the timing logic for the HSYNC signal. Shadow register, updated on VFP start period |                         |             |                 |      |
| <b>Type</b>           | RW                                                                                                          |                         |             |                 |      |

|     |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
|-----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| HBP |    |    |    |    |    |    |    |    |    | HFP |    |    |    |    |    |    |    |    |    | HSW |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:20       | HBP               | Horizontal Back Porch.<br>Encoded value (from 1 to 4096) to specify the number of pixel clock periods to add to the beginning of a line transmission before the first set of pixels is output to the display (program to value minus 1). | RW          | 0x00         |
| 19:8        | HFP               | Horizontal front porch.<br>Encoded value (from 1 to 4096) to specify the number of pixel clock periods to add to the end of a line transmission before line clock is asserted (program to value minus 1).                                | RW          | 0x00         |
| 7:0         | HSW               | Horizontal synchronization pulse width<br>Encoded value (from 1 to 256) to specify the number of pixel clock periods to pulse the line clock at the end of each line (program to value minus 1).                                         | RW          | 0x00         |

**Table 7-163. Register Call Summary for Register DISPC\_TIMING\_H**

Display Subsystem Environment

- [Transaction Timing Diagrams: \[0\] \[1\] \[2\]](#)

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[3\]](#)
- [LCD-Specific Control Registers: \[4\]](#)
- [LCD Timings: \[5\] \[6\] \[7\] \[8\] \[9\] \[10\]](#)

Display Subsystem Use Cases and Tips

- [Vertical and Horizontal Timings: \[11\] \[12\] \[13\]](#)
- [Configure DISPC Timing, Window, and Color: \[14\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[15\]](#)

**Table 7-164. DISPC\_TIMING\_V**

|                       |                                                                                                             |                         |             |                 |      |
|-----------------------|-------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x068                                                                                                       | <b>Physical address</b> | 0x4805 0468 | <b>Instance</b> | DISC |
| <b>Description</b>    | The register configures the timing logic for the VSYNC signal. Shadow register, updated on VFP start period |                         |             |                 |      |
| <b>Type</b>           | RW                                                                                                          |                         |             |                 |      |

|     |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
|-----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| VBP |    |    |    |    |    |    |    |    |    | VFP |    |    |    |    |    |    |    |    |    | VSW |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:20 | VBP        | Vertical back porch<br>Encoded value (from 0 to 4095) to specify the number of line clock periods to add to the beginning of a frame before the first set of pixels is output to the display.                                                                                                                                                                                                                                                                                                                                    | RW   | 0x00  |
| 19:8  | VFP        | Vertical front porch<br>Encoded value (from 0 to 4095) to specify the number of line clock periods to add to the end of each frame.                                                                                                                                                                                                                                                                                                                                                                                              | RW   | 0x00  |
| 7:0   | VSW        | Vertical synchronization pulse width<br>In active mode, encoded value (from 1 to 256) to specify the number of line clock periods (program to value minus one) to pulse the frame clock (VSYNC) pin at the end of each frame after the end of frame wait (VFP) period elapses. Frame clock uses VSYNC signal in active mode.<br>In passive mode, encoded value (from 1 to 256) to specify the number of extra line clock periods (program to value minus one) to insert after the vertical front porch (VFP) period has elapsed. | RW   | 0x00  |

**Table 7-165. Register Call Summary for Register DISPC\_TIMING\_V**

Display Subsystem Environment

- [Transaction Timing Diagrams: \[0\] \[1\] \[2\]](#)

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[3\]](#)
- [LCD-Specific Control Registers: \[4\]](#)
- [LCD Timings: \[5\] \[6\] \[7\] \[8\] \[9\] \[10\]](#)

Display Subsystem Use Cases and Tips

- [Vertical and Horizontal Timings: \[11\] \[12\] \[13\]](#)
- [Configure DISPC Timing, Window, and Color: \[14\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[15\]](#)

**Table 7-166. DISPC\_POL\_FREQ**

|                         |                                                                                                   |                         |                 |                 |      |
|-------------------------|---------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|------|
| <b>Address Offset</b>   | 0x06C                                                                                             | <b>Physical address</b> | 0x4805 046C     | <b>Instance</b> | DISC |
| <b>Description</b>      | The register configures the signal configuration.<br>Shadow register, updated on VFP start period |                         |                 |                 |      |
| <b>Type</b>             | RW                                                                                                |                         |                 |                 |      |
| 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 |                 |      |
| Reserved                | ONOFF RF IEO IPC IHS IVS                                                                          | ACBI                    | ACB             |                 |      |

| Bits  | Field Name | Description                                                                                                                                                                                                       | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:18 | Reserved   | Write 0s for future compatibility.<br>Read returns 0                                                                                                                                                              | RW   | 0x0000 |
| 17    | ONOFF      | Hsync/Vsync Pixel clock Control On/Off<br>0x0: Hsync and vsync are driven on opposite edges of pixel clock than pixel data<br>0x1: Hsync and vsync are driven according to bit 16                                 | RW   | 0      |
| 16    | RF         | Program Hsync/Vsync Rise or Fall<br>0x0: Hsync and vsync are driven on falling edge of pixel clock (if bit 17 set to 1)<br>0x1: Hsync and vsync are driven on the rising edge of pixel clock (if bit 17 set to 1) | RW   | 0      |
| 15    | IEO        | Invert output enable<br>0x0: Ac-bias is active high (active display mode)                                                                                                                                         | RW   | 0      |

## Display Subsystem Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                        | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x1: Ac-bias is active low (active display mode)                                                                                                                                                                                                                   |      |       |
| 14   | IPC        | Invert pixel clock<br>0x0: Data is driven on the LCD data lines on the rising-edge of the pixel clock<br>0x1: Data is driven on the LCD data lines on the falling-edge of the pixel clock                                                                          | RW   | 0     |
| 13   | IHS        | Invert HSYNC<br>0x0: Line clock pin is active high and inactive low<br>0x1: Line clock pin is active low and inactive high                                                                                                                                         | RW   | 0     |
| 12   | IVS        | Invert VSYNC<br>0x0: Frame clock pin is active high and inactive low<br>0x1: Frame clock pin is active low and inactive high                                                                                                                                       | RW   | 0     |
| 11:8 | ACBI       | AC-bias pin transitions per interrupt<br>Value (from 0 to 15) used to specify the number of AC Bias pin transitions                                                                                                                                                | RW   | 0x0   |
| 7:0  | ACB        | AC-bias pin frequency<br>Value (from 0 to 255) used to specify the number of line clocks to count before transitioning the ac-bias pin. This pin is used to periodically invert the polarity of the power supply to prevent DC charge build-up within the display. | RW   | 0x00  |

**Table 7-167. Register Call Summary for Register DISPC\_POL\_FREQ**

## Display Subsystem Environment

- Transaction Timing Diagrams: [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]
- Video Port (VP) Interface: [30]

## Display Subsystem Basic Programming Model

- Display Controller Basic Programming Model: [31]
- LCD-Specific Control Registers: [32]
- LCD Timings: [33] [34] [35] [36] [37] [38] [39] [40]

## Display Subsystem Register Manual

- Display Controller Register Mapping Summary: [41]

**Table 7-168. DISPC\_DIVISOR**

|                         |                                                                                       |  |  |     |             |             |           |          |         |  |                 |     |  |  |      |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------|--|--|-----|-------------|-------------|-----------|----------|---------|--|-----------------|-----|--|--|------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x070                                                                                 |  |  |     |             |             |           |          |         |  |                 |     |  |  |      |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x4805 0470                                                                           |  |  |     |             |             |           |          |         |  | <b>Instance</b> |     |  |  | DISC |  |  |  |  |  |  |  |
| <b>Description</b>      | The register configures the divisors.<br>Shadow register, updated on VFP start period |  |  |     |             |             |           |          |         |  |                 |     |  |  |      |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                    |  |  |     |             |             |           |          |         |  |                 |     |  |  |      |  |  |  |  |  |  |  |
| 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 |  |                 |     |  |  |      |  |  |  |  |  |  |  |
| Reserved                |                                                                                       |  |  | LCD |             |             |           | Reserved |         |  |                 | PCD |  |  |      |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                     | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | Reserved   | Write 0s for future compatibility.<br>Read returns 0                                                                                                                                            | RW   | 0x00  |
| 23:16 | LCD        | Display Controller Logic Clock Divisor<br>Value (from 1 to 255) to specify the frequency of the display controller logic clock based on the function clock. The value 0 is invalid.             | RW   | 0x01  |
| 15:8  | Reserved   | Write 0s for future compatibility.<br>Read returns 0                                                                                                                                            | RW   | 0x00  |
| 7:0   | PCD        | Pixel Clock Divisor<br>Value (from 1 to 255) to specify the frequency of the pixel clock based on the Logic clock which is the functional clock divided by LCD. The values 0 and 1 are invalid. | RW   | 0x02  |

**Table 7-169. Register Call Summary for Register DISPC\_DIVISOR**

## Display Subsystem Environment

- [Video Port \(VP\) Interface: \[0\]](#)
- [Video Port Used on Command Mode: \[1\]](#)

## Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[2\]](#)
- [LCD-Specific Control Registers: \[3\]](#)
- [LCD Timings: \[4\] \[5\] \[6\]](#)
- [Digital Timings: \[7\] \[8\]](#)

## Display Subsystem Use Cases and Tips

- [Display Subsystem Clock Configuration: \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\]](#)
- [Configure DISPC Timing, Window, and Color: \[21\]](#)
- [Configure the DISPC: \[22\] \[23\]](#)

## Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[24\]](#)

**Table 7-170. DISPC\_GLOBAL\_ALPHA**

|                         |                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|------|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0074                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | DISC |  |  |  |  |
| <b>Physical Address</b> | 0x4805 0474                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |
| <b>Description</b>      | The register defines the global alpha value for the graphics and video 2 pipelines. Shadow register, updated on VFP start period or EVSYNC for each bit field depending on the association of the each pipeline with the LCD or TV output. |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |

|          |    |    |    |    |    |    |                 |    |    |    |    |    |    |          |    |    |    |    |    |    |                |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|----------|----|----|----|----|----|----|----------------|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    | VID2GLOBALALPHA |    |    |    |    |    |    | RESERVED |    |    |    |    |    |    | GFXGLOBALALPHA |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                            | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------|-------------|--------------|
| 31:24       | RESERVED          | Write 0s for future compatibility.<br>Reads return 0                                          | RW          | 0x00         |
| 23:16       | VID2GLOBALALPHA   | Global alpha value from 0 to 255. 0 corresponds to fully transparent and 255 to fully opaque. | RW          | 0x00         |
| 15:8        | RESERVED          | Write 0s for future compatibility.<br>Reads return 0                                          | RW          | 0x00         |
| 7:0         | GFXGLOBALALPHA    | Global alpha value from 0 to 255. 0 corresponds to fully transparent and 255 to fully opaque. | RW          | 0x00         |

**Table 7-171. Register Call Summary for Register DISPC\_GLOBAL\_ALPHA**

## Display Subsystem Basic Programming Model

- [LCD Overlay: \[0\] \[1\]](#)
- [Digital Overlay: \[2\] \[3\]](#)

## Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[4\]](#)

**Table 7-172. DISPC\_SIZE\_DIG**

| <b>Address Offset</b>   | 0x078                                                                                                                                                        |                                                                                                                                                          |                 |  |  |  |  |  |  |  |                 |     |  |  |  |      |       |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|-----------------|-----|--|--|--|------|-------|--|--|--|--|--|
| <b>Physical address</b> | 0x4805 0478                                                                                                                                                  |                                                                                                                                                          |                 |  |  |  |  |  |  |  | <b>Instance</b> |     |  |  |  |      |       |  |  |  |  |  |
| <b>Description</b>      | The register configures the size of the digital output field (interlace), frame (progressive) (horizontal and vertical). Shadow register, updated on EVSYNC. |                                                                                                                                                          |                 |  |  |  |  |  |  |  |                 |     |  |  |  |      |       |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                           |                                                                                                                                                          |                 |  |  |  |  |  |  |  |                 |     |  |  |  |      |       |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |                 |     |  |  |  |      |       |  |  |  |  |  |
| Reserved                | LPP                                                                                                                                                          |                                                                                                                                                          |                 |  |  |  |  |  |  |  | Reserved        | PPL |  |  |  |      |       |  |  |  |  |  |
| Bits                    | Field Name                                                                                                                                                   | <b>Description</b>                                                                                                                                       |                 |  |  |  |  |  |  |  |                 |     |  |  |  | Type | Reset |  |  |  |  |  |
| 31:27                   | Reserved                                                                                                                                                     | Write 0s for future compatibility.<br>Read returns 0                                                                                                     |                 |  |  |  |  |  |  |  |                 |     |  |  |  | RW   | 0x00  |  |  |  |  |  |
| 26:16                   | LPP                                                                                                                                                          | Lines per panel<br>Encoded value (from 1 to 2048) to specify the number of lines per panel (program to value minus one).                                 |                 |  |  |  |  |  |  |  |                 |     |  |  |  | RW   | 0x000 |  |  |  |  |  |
| 15:11                   | Reserved                                                                                                                                                     | Write 0s for future compatibility.<br>Read returns 0                                                                                                     |                 |  |  |  |  |  |  |  |                 |     |  |  |  | RW   | 0x00  |  |  |  |  |  |
| 10:0                    | PPL                                                                                                                                                          | Pixels per line<br>Encoded value (from 1 to 2048) to specify the number of pixels contained within each line on the display (program to value minus one) |                 |  |  |  |  |  |  |  |                 |     |  |  |  | RW   | 0x000 |  |  |  |  |  |

**Table 7-173. Register Call Summary for Register DISPC\_SIZE\_DIG**

Display Subsystem Functional Description

- [Up-/Down-Sampling: \[0\]](#)

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[1\]](#)
- [TV Set-Specific Control Registers: \[2\]](#)
- [Digital Frame/Field Size: \[3\] \[4\]](#)
- [Video Encoder Register Settings: \[5\] \[6\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[7\]](#)

**Table 7-174. DISPC\_SIZE\_LCD**

| <b>Address Offset</b>   | 0x07C                                                                                                          |                                                                                                                          |                 |  |  |  |  |  |  |  |                 |     |  |  |  |      |       |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|-----------------|-----|--|--|--|------|-------|--|--|--|--|--|
| <b>Physical address</b> | 0x4805 047C                                                                                                    |                                                                                                                          |                 |  |  |  |  |  |  |  | <b>Instance</b> |     |  |  |  |      |       |  |  |  |  |  |
| <b>Description</b>      | The register configures the panel size (horizontal and vertical). Shadow register, updated on VFP start period |                                                                                                                          |                 |  |  |  |  |  |  |  |                 |     |  |  |  |      |       |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                             |                                                                                                                          |                 |  |  |  |  |  |  |  |                 |     |  |  |  |      |       |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |                 |     |  |  |  |      |       |  |  |  |  |  |
| Reserved                | LPP                                                                                                            |                                                                                                                          |                 |  |  |  |  |  |  |  | Reserved        | PPL |  |  |  |      |       |  |  |  |  |  |
| Bits                    | Field Name                                                                                                     | <b>Description</b>                                                                                                       |                 |  |  |  |  |  |  |  |                 |     |  |  |  | Type | Reset |  |  |  |  |  |
| 31:27                   | Reserved                                                                                                       | Write 0s for future compatibility.<br>Read returns 0                                                                     |                 |  |  |  |  |  |  |  |                 |     |  |  |  | RW   | 0x00  |  |  |  |  |  |
| 26:16                   | LPP                                                                                                            | Lines per panel<br>Encoded value (from 1 to 2048) to specify the number of lines per panel (program to value minus one). |                 |  |  |  |  |  |  |  |                 |     |  |  |  | RW   | 0x000 |  |  |  |  |  |
| 15:11                   | Reserved                                                                                                       | Write 0s for future compatibility.<br>Read returns 0                                                                     |                 |  |  |  |  |  |  |  |                 |     |  |  |  | RW   | 0x00  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 10:0 | PPL        | Pixels per line<br>Encoded value (from 1 to 2048) to specify the number of pixels contains within each line on the display (program to value minus one). When running in normal mode (stall mode is bypassed by setting DSS.DISPC_CONTROL[11] STALLMODE =0) the line width must be set to a value multiple of 8 pixels (ex: PPL=0x7) | RW   | 0x000 |

**Table 7-175. Register Call Summary for Register DISPC\_SIZE\_LCD**

Display Subsystem Environment

- [Transaction Timing Diagrams: \[0\]](#) [\[1\]](#)

Display Subsystem Functional Description

- [Up-/Down-Sampling: \[2\]](#)

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[3\]](#)
- [LCD-Specific Control Registers: \[4\]](#)
- [LCD Attributes: \[5\]](#) [\[6\]](#)
- [LCD Timings: \[7\]](#) [\[8\]](#)

Display Subsystem Use Cases and Tips

- [Configure DISPC Timing, Window, and Color: \[9\]](#)
- [Configure the DISPC: \[10\]](#) [\[11\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[12\]](#)

**Table 7-176. DISPC\_GFX\_BA<sub>j</sub>**

|                         |                                                                                                                                                                                                                                                                                                                                                |                       |                 |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x080 + j * 0x04                                                                                                                                                                                                                                                                                                                               | <b>Index</b>          | j = 0 to 1      |
| <b>Physical address</b> | 0x4805 0480+ j * 0x04                                                                                                                                                                                                                                                                                                                          | <b>Instance</b>       | DISC            |
| <b>Description</b>      | The register configures the base address of the graphics buffer displayed in the graphics window (0 1 :for ping-pong mechanism with external trigger, based on the field polarity, 0 only used when graphics pipeline on the LCD output and 0 1 when on the 24-bit digital output).<br>Shadow register, updated on VFP start period or EVSYNC. |                       |                 |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                             |                       |                 |
| 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 |
| GFXBA                   |                                                                                                                                                                                                                                                                                                                                                |                       |                 |

| Bits | Field Name | Description                                                                                                                                              | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | GFXBA      | Graphics base address<br>Base address of the graphics buffer (aligned on pixel size boundary)<br>(in case 1-, 2-, and 4-BPP, byte alignment is required) | RW   | 0x00000000 |

**Table 7-177. Register Call Summary for Register DISPC\_GFX\_BA<sub>j</sub>**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Graphics DMA Registers: \[1\]](#) [\[2\]](#)
- [Image Data from On-Chip SRAM: \[3\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[4\]](#)

**Table 7-178. DISPC\_GFX\_POSITION**

|                         |                                                                                                                      |                         |                 |                 |      |
|-------------------------|----------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|------|
| <b>Address Offset</b>   | 0x088                                                                                                                | <b>Physical address</b> | 0x4805 0488     | <b>Instance</b> | DISC |
| <b>Description</b>      | The register configures the position of the graphics window. Shadow register, updated on VFP start period or EVSYNC. |                         |                 |                 |      |
| <b>Type</b>             | RW                                                                                                                   |                         |                 |                 |      |
| 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 |                 |      |
| Reserved                | GFXPOSY                                                                                                              | Reserved                | GFXPOSX         |                 |      |

  

| Bits  | Field Name | Description                                                                                                                                                                                          | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | Reserved   | Write 0s for future compatibility.<br>Read returns 0                                                                                                                                                 | RW   | 0x00  |
| 26:16 | GFXPOSY    | Y position of the graphics window.<br>Encoded value (from 0 to 2047) to specify the Y position of the graphics window on the screen. The line at the top has the Y-position 0.                       | RW   | 0x000 |
| 15:11 | Reserved   | Write 0s for future compatibility.<br>Read returns 0                                                                                                                                                 | RW   | 0x00  |
| 10:0  | GFXPOSX    | X position of the graphics window.<br>Encoded value (from 0 to 2047) to specify the X position of the graphics window on the screen. The first pixel on the left of the screen has the X-position 0. | RW   | 0x000 |

**Table 7-179. Register Call Summary for Register DISPC\_GFX\_POSITION**

Display Subsystem Basic Programming Model

- Display Controller Basic Programming Model: [0]
- Graphics Layer Configuration Registers: [1]
- Graphics Window Attributes: [2] [3]
- Image Data from On-Chip SRAM: [4]

Display Subsystem Register Manual

- Display Controller Register Mapping Summary: [5]

**Table 7-180. DISPC\_GFX\_SIZE**

|                         |                                                                                                                  |                         |                 |                 |      |
|-------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|------|
| <b>Address Offset</b>   | 0x08C                                                                                                            | <b>Physical address</b> | 0x4805 048C     | <b>Instance</b> | DISC |
| <b>Description</b>      | The register configures the size of the graphics window. Shadow register, updated on VFP start period or EVSYNC. |                         |                 |                 |      |
| <b>Type</b>             | RW                                                                                                               |                         |                 |                 |      |
| 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 |                 |      |
| Reserved                | GFXSIZEY                                                                                                         | Reserved                | GFXSIZEX        |                 |      |

  

| Bits  | Field Name | Description                                                                                                                                                              | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                       | RW   | 0x00  |
| 26:16 | GFXSIZEY   | Number of lines of the graphics window.<br>Encoded value (from 1 to 2048) to specify the number of lines of the graphics window (program to value minus one).            | RW   | 0x000 |
| 15:11 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                       | RW   | 0x00  |
| 10:0  | GFXSIZEX   | Number of pixels of the graphics window.<br>Encoded value (from 1 to 2048) to specify the number of pixels per line of the graphics window (program to value minus one). | RW   | 0x000 |

**Table 7-181. Register Call Summary for Register DISPC\_GFX\_SIZE**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Graphics Layer Configuration Registers: \[1\]](#)
- [Graphics Window Attributes: \[2\] \[3\]](#)
- [Image Data from On-Chip SRAM: \[4\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[5\]](#)

**Table 7-182. DISPC\_GFX\_ATTRIBUTES**

|                       |                                                                                                             |                         |             |                 |      |
|-----------------------|-------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0A0                                                                                                       | <b>Physical address</b> | 0x4805 04A0 | <b>Instance</b> | DISC |
| <b>Description</b>    | The register configures the graphics attributes.<br>Shadow register, updated on VFP start period or EVSYNC. |                         |             |                 |      |
| <b>Type</b>           | RW                                                                                                          |                         |             |                 |      |

| 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 |
|----------|------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----------------|----------------|-------------|----------------|---------------|---------------|---------------|--------------|----------------------|-----------|-----------|---|---|---|---|---|---|---|
| RESERVED | PREMULTIPLYALPHA | RESERVED |    |    |    |    |    |    |    |    |    |    |    | GFXSELFREFRESH | GFXARBITRATION | GFXROTATION | GFXFIFOPRELOAD | GFXENDIANNESS | GFXNIBBLEMODE | GFXCHANNELOUT | GFXBURSTSIZE | GFXREPLICATIONENABLE | GFXFORMAT | GFXENABLE |   |   |   |   |   |   |   |

| Bits                                                                                                                                                                                            | Field Name       | Description                                                                                                                                                                                                                                                                                                                                             | Type | Reset    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:29                                                                                                                                                                                           | Reserved         | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                   | RW   | 0x000000 |
| 28                                                                                                                                                                                              | PREMULTIPLYALPHA | The field configures the DISPC GFX to process incoming data as pre-multiplied alpha data or non premultiplied alpha data.<br>Default setting is non pre-multiplied alpha data.<br>0x0: Non pre-multiplyalpha data color component<br>0x1: Pre-multiplyalpha data color component                                                                        | RW   | 0        |
| <hr/>                                                                                                                                                                                           |                  |                                                                                                                                                                                                                                                                                                                                                         |      |          |
| <b>NOTE:</b> The pre-multiplied alpha option is only valid when bit field [4:1] GFXFORMAT is set to ARGB or RGBA formats. Otherwise, the PREMULTIPLYALPHA bit field is ignored by the hardware. |                  |                                                                                                                                                                                                                                                                                                                                                         |      |          |
| 27:16                                                                                                                                                                                           | Reserved         | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                   | RW   | 0x000000 |
| 15                                                                                                                                                                                              | GFXSELFREFRESH   | Enables the self refresh of the graphics window from its own FIFO only.<br><br>0x0: The graphics pipeline accesses the interconnect to fetch data from the system memory<br><br>0x1: The graphics pipeline does not need anymore to fetch data from memory. Only the graphics FIFO is used. It takes effect after the frame has been loaded in the FIFO | RW   | 0        |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset |
|-------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 14    | GFXARBITRATION           | Determines the priority of the graphics pipeline. The graphics pipeline is one of the high priority pipeline. The arbitration wheel gives always the priority first to the high priority pipelines using round-robin between them. When there is only normal priority pipelines sending requests, the round-robin applies between them.<br><br>0x0: The graphics pipeline is one of the normal priority pipeline.<br>0x1: The graphics pipeline is one of the high priority pipeline. | RW   | 0     |
| 13:12 | GFXROTATION              | Graphics rotation flag (used only in case of RGB24 packed format)<br><br>0x0: No rotation<br>0x1: Rotation by 90 degrees<br>0x2: Rotation by 180 degrees<br>0x3: Rotation by 270 degrees                                                                                                                                                                                                                                                                                              | RW   | 0x0   |
| 11    | GFXFIFOPRELOAD           | Graphics preload value<br><br>0x0: H/W prefetches pixels up to the preload value defined in the preload register.<br>0x1: H/W prefetches pixels up to high threshold value.                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 10    | GFXENDIANNESS            | Graphics endianness<br><br>0x0: Little endian operation is selected.<br>0x1: Big endian operation is selected.                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0     |
| 9     | GFXNIBBLEMODE            | Graphics Nibble Mode (only for 1-, 2- and 4-BPP)<br><br>0x0: Nibble mode is disabled<br>0x1: Nibble mode is enabled                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0     |
| 8     | GFXCHANNELOUT            | Graphics Channel Out configuration<br>wr: immediate<br><br>0x0: LCD output selected<br>0x1: 24-bit output selected                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0     |
| 7:6   | GFXBURSTSIZE             | Graphics DMA Burst Size<br><br>0x0: 4x32bit bursts<br>0x1: 8x32bit bursts<br>0x2: 16x32bit bursts<br>0x3: Reserved                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0x0   |
| 5     | GFXREPLICATION<br>ENABLE | GfxReplicationEnable<br><br>0x0: Disable Graphics replication logic<br>0x1: Enable Graphics replication logic                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0     |
| 4:1   | GFXFORMAT                | Graphics format; Other enums: Reserved (0x7, 0xA, 0xB and 0xF)<br><br>0x0: BITMAP 1 (CLUT)<br>0x1: BITMAP 2 (CLUT)<br>0x2: BITMAP 4 (CLUT)<br>0x3: BITMAP 8 (CLUT)<br>0x4: RGB 12 (un-packed in 16-bit container)<br>0x5: ARGB16<br>0x6: RGB 16<br>0x8: RGB 24 (un-packed in 32-bit container)<br>0x9: RGB 24 (packed in 24-bit container)<br>0xC: ARGB32<br>0xD: RGBA32<br>0xE: RGBx 32 (24-bit RGB aligned on MSB of the 32-bit container)                                          | RW   | 0x0   |
| 0     | GFXENABLE                | GfxEnable                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0     |

| Bits | Field Name | Description                                                                           | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------|------|-------|
|      | 0x0:       | Graphics disabled (graphics pipeline inactive and graphics window not present)        |      |       |
|      | 0x1:       | Graphics enabled (graphics pipeline active and graphics window present on the screen) |      |       |

**Table 7-183. Register Call Summary for Register DISPC\_GFX\_ATTRIBUTES**

Display Subsystem Functional Description

- [Priority Rule: \[0\] \[1\]](#)

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[2\]](#)
- [Graphics DMA Registers: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [Graphics Layer Configuration Registers: \[10\] \[11\]](#)
- [Graphics Window Attributes: \[12\] \[13\] \[14\] \[15\] \[16\]](#)
- [Image Data from On-Chip SRAM: \[17\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[18\]](#)
- [Display Controller Registers: \[19\]](#)

**Table 7-184. DISPC\_GFX\_FIFO\_THRESHOLD**

|                         |                                                                                                    |                       |                     |          |      |
|-------------------------|----------------------------------------------------------------------------------------------------|-----------------------|---------------------|----------|------|
| Address Offset          | 0x0A4                                                                                              | Physical address      | 0x4805 04A4         | Instance | DISC |
| Description             | The register configures the graphics FIFO. Shadow register, updated on VFP start period or EVSYNC. |                       |                     |          |      |
| Type                    | RW                                                                                                 |                       |                     |          |      |
| 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     |          |      |
| Reserved                | GFXFIFOHIGHTHRESHOLD                                                                               | Reserved              | GFXFIFOLOWTHRESHOLD |          |      |

| Bits  | Field Name            | Description                                                                | Type | Reset |
|-------|-----------------------|----------------------------------------------------------------------------|------|-------|
| 31:28 | Reserved              | Write 0s for future compatibility. Read returns 0.                         | RW   | 0x00  |
| 27:16 | GFXFIFOHIGH THRESHOLD | Graphics FIFO High Threshold Number of bytes defining the threshold value. | RW   | 0x3FF |
| 15:12 | Reserved              | Write 0s for future compatibility. Read returns 0                          | RW   | 0x00  |
| 11:0  | GFXFIFOLOW THRESHOLD  | Graphics FIFO Low Threshold Number of bytes defining the threshold value   | RW   | 0x3C0 |

**Table 7-185. Register Call Summary for Register DISPC\_GFX\_FIFO\_THRESHOLD**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Graphics DMA Registers: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\]](#)
- [Image Data from On-Chip SRAM: \[7\] \[8\] \[9\]](#)

Display Subsystem Use Cases and Tips

- [FIFO Thresholds: \[10\] \[11\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[12\]](#)

**Table 7-186. DISPC\_GFX\_FIFO\_SIZE\_STATUS**

|                         |                                               |                         |                 |                 |             |
|-------------------------|-----------------------------------------------|-------------------------|-----------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0A8                                         | <b>Physical address</b> | 0x4805 04A8     | <b>Instance</b> | DISC        |
| <b>Description</b>      | This register defines the graphics FIFO size. |                         |                 |                 |             |
| <b>Type</b>             | R                                             |                         |                 |                 |             |
| 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 |                 |             |
| Reserved                |                                               |                         |                 |                 | GFXFIFOSIZE |

  

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                             | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------|-------------|--------------|
| 31:11       | Reserved          | Write 0s for future compatibility.<br>Read returns 0           | R           | 0x0000000    |
| 10:0        | GFXFIFOSIZE       | Graphics FIFO Size<br>Number of bytes defining the FIFO value. | R           | 0x400        |

**Table 7-187. Register Call Summary for Register DISPC\_GFX\_FIFO\_SIZE\_STATUS**

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[0\]](#)

**Table 7-188. DISPC\_GFX\_ROW\_INC**

|                         |                                                                                                                                            |                         |                 |                 |      |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|------|
| <b>Address Offset</b>   | 0x0AC                                                                                                                                      | <b>Physical address</b> | 0x4805 04AC     | <b>Instance</b> | DISC |
| <b>Description</b>      | The register configures the number of bytes to increment at the end of the row.<br>Shadow register, updated on VFP start period or EVSYNC. |                         |                 |                 |      |
| <b>Type</b>             | RW                                                                                                                                         |                         |                 |                 |      |
| 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 |                 |      |
| GFXROWINC               |                                                                                                                                            |                         |                 |                 |      |

  

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | GFXROWINC         | Number of bytes to increment at the end of the row<br>Encoded signed value (from $-2^{31}$ - 1 to $2^{31}$ ) to specify the number of bytes to increment at the end of the row in the graphics buffer.<br>The value 0 is invalid. The value 1 means next pixel. The value $1+n \cdot BPP$ means increment of n pixels. The value $1-(n+1) \cdot BPP$ means decrement of n pixels. | RW          | 0x00000001   |

**Table 7-189. Register Call Summary for Register DISPC\_GFX\_ROW\_INC**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Graphics DMA Registers: \[1\]](#)
- [Graphics Window Attributes: \[2\] \[3\]](#)
- [Image Data from On-Chip SRAM: \[4\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[5\]](#)

**Table 7-190. DISPC\_GFX\_PIXEL\_INC**

|                         |                                                                                                                                         |                 |      |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0B0                                                                                                                                   |                 |      |
| <b>Physical address</b> | 0x4805 04B0                                                                                                                             | <b>Instance</b> | DISC |
| <b>Description</b>      | The register configures the number of bytes to increment between two pixels.<br>Shadow register, updated on VFP start period or EVSYNC. |                 |      |
| <b>Type</b>             | RW                                                                                                                                      |                 |      |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16                                                                                                                 |                 |      |
| Reserved                | GFXPIXELINC                                                                                                                             |                 |      |

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                   | Type | Reset  |
|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved    | Write 0s for future compatibility.<br>Read returns 0                                                                                                                                                                                                                                                                                                          | RW   | 0x0000 |
| 15:0  | GFXPIXELINC | Number of bytes to increment between two pixels<br>Encoded signed value (from -2 <sup>15</sup> - 1 to 2 <sup>15</sup> ) to specify the number of bytes between two pixels in the graphics buffer.<br>The value 0 is invalid. The value 1 means next pixel. The value 1+n*BPP means increment of n pixels. The value 1- (n+1)*BPP means decrement of n pixels. | RW   | 0x0001 |

**Table 7-191. Register Call Summary for Register DISPC\_GFX\_PIXEL\_INC**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Graphics DMA Registers: \[1\]](#)
- [Image Data from On-Chip SRAM: \[2\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[3\]](#)

**Table 7-192. DISPC\_GFX\_WINDOW\_SKIP**

|                         |                                                                                                                                             |                 |      |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------|--|--|--|--|
| <b>Address Offset</b>   | 0x0B4                                                                                                                                       |                 |      |  |  |  |  |
| <b>Physical address</b> | 0x4805 04B4                                                                                                                                 | <b>Instance</b> | DISC |  |  |  |  |
| <b>Description</b>      | The register configures the number of bytes to skip during video window display.<br>Shadow register, updated on VFP start period or EVSYNC. |                 |      |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                          |                 |      |  |  |  |  |
| 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                                                                                                                             |                 |      |  |  |  |  |
| GFXWINDOWSKIP           |                                                                                                                                             |                 |      |  |  |  |  |

| Bits | Field Name    | Description                                                                                                                                                                                                                                                                          | Type | Reset      |
|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | GFXWINDOWSKIP | Number of bytes to skip during video window #1.<br>Encoded signed value (from -2 <sup>31</sup> - 1 to 2 <sup>31</sup> ) to specify the number of bytes to skip in the graphics buffer when video window #1 is displayed on top of the graphics and no transparency color is enabled. | RW   | 0x00000000 |

**Table 7-193. Register Call Summary for Register DISPC\_GFX\_WINDOW\_SKIP**

Display Subsystem Functional Description

- [Overlay Support: \[0\]](#)

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[1\]](#)
- [Graphics Window Attributes: \[2\] \[3\] \[4\] \[5\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[6\]](#)

**Table 7-194. DISPC\_GFX\_TABLE\_BA**

|                                                                                             |                                                                                                                                                   |                 |      |
|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>                                                                       | 0x0B8                                                                                                                                             |                 |      |
| <b>Physical address</b>                                                                     | 0x4805 04B8                                                                                                                                       | <b>Instance</b> | DISC |
| <b>Description</b>                                                                          | The register configures the base address of the palette buffer or the gamma table buffer. Shadow register, updated on VFP start period or EVSYNC. |                 |      |
| <b>Type</b>                                                                                 | RW                                                                                                                                                |                 |      |
| 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 |                                                                                                                                                   |                 |      |
| GFXTABLEBA                                                                                  |                                                                                                                                                   |                 |      |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | GFXTABLEBA        | Base address of the palette/gamma table buffer (24-bit entries in 32-bit containers, aligned on 32-bit boundary). | RW          | 0x00000000   |

**Table 7-195. Register Call Summary for Register DISPC\_GFX\_TABLE\_BA**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Graphics DMA Registers: \[1\] \[2\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[3\]](#)

**Table 7-196. DISPC\_VIDn\_BAj**

|                                                                                             |                                                                                                                                                                                                                                                                  |                 |                                                                                                |  |  |  |
|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|--|--|--|
| <b>Address Offset</b>                                                                       | 0x0BC + ((n-1)* 0x90) + (j* 0x04)                                                                                                                                                                                                                                | <b>Index</b>    | n = 1 for VID1 or 2 for VID2<br>j = 0 to 1                                                     |  |  |  |
| <b>Physical address</b>                                                                     | 0x4805 04BC + (j *0x04)<br>0x4805 04BC + (j *0x04)<br>0x4805 054C+ (j *0x04)<br>0x4805 054C+ (j *0x04)                                                                                                                                                           | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |  |  |  |
| <b>Description</b>                                                                          | The register configures the base address of the video buffer for video window #n(# for ping-pong mechanism with external trigger, based on the field polarity: 0 for even field and 1 for odd field).<br>Shadow register, updated on VFP start period or EVSYNC. |                 |                                                                                                |  |  |  |
| <b>Type</b>                                                                                 | RW                                                                                                                                                                                                                                                               |                 |                                                                                                |  |  |  |
| 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 |                                                                                                                                                                                                                                                                  |                 |                                                                                                |  |  |  |
| VIDBA                                                                                       |                                                                                                                                                                                                                                                                  |                 |                                                                                                |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                      | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | VIDBA             | Video base address<br>Base address of the video buffer (aligned on pixel size boundary) | RW          | 0x00000000   |

**Table 7-197. Register Call Summary for Register DISPC\_VIDn\_BAj**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Video DMA Registers: \[1\] \[2\]](#)
- [Image Data from On-Chip SRAM: \[3\] \[4\] \[5\]](#)

Display Subsystem Use Cases and Tips

- [Register List: \[6\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[7\]](#)
- [Display Controller VID2 Register Mapping Summary: \[8\]](#)

**Table 7-198. DISPC\_VIDn\_POSITION**

|                         |                                                                                                                          |                 |                                                                                                |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0C4 + ((-1) *0x90)                                                                                                     | <b>Index</b>    | n = 1 for VID1 or 2 for VID2                                                                   |
| <b>Physical address</b> | <a href="#">0x4805 04C4</a><br><a href="#">0x4805 04C4</a><br><a href="#">0x4805 0554</a><br><a href="#">0x4805 0554</a> | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register configures the position of video window #n.<br>Shadow register, updated on VFP start period or EVSYNC.      |                 |                                                                                                |
| <b>Type</b>             | RW                                                                                                                       |                 |                                                                                                |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | VIDPOSY                 | Reserved              | VIDPOSX         |

| Bits  | Field Name | Description                                                                                                                                                                           | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | Reserved   | Write 0s for future compatibility.<br>Read returns 0                                                                                                                                  | RW   | 0x00  |
| 26:16 | VIDPOSY    | Y position of video window #n<br>Encoded value (from 0 to 2047) to specify the Y position of video window #n. The line at the top has the Y-position 0.                               | RW   | 0x000 |
| 15:11 | Reserved   | Write 0s for future compatibility.<br>Read returns 0                                                                                                                                  | RW   | 0x00  |
| 10:0  | VIDPOSX    | X position of video window #n<br>Encoded value (from 0 to 2047) to specify the X position of video window #n. The first pixel on the left of the display screen has the X-position 0. | RW   | 0x000 |

**Table 7-199. Register Call Summary for Register DISPC\_VIDn\_POSITION**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Video Configuration Register: \[1\]](#)
- [Video Window Attributes: \[2\] \[3\]](#)
- [Image Data from On-Chip SRAM: \[4\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[5\]](#)
- [Display Controller VID2 Register Mapping Summary: \[6\]](#)

**Table 7-200. DISPC\_VIDn\_SIZE**

|                         |                                                                                                                          |                 |                                                                                                |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0C8+((-1)* 0x90)                                                                                                       | <b>Index</b>    | n = 1 for VID1 or 2 for VID2                                                                   |
| <b>Physical address</b> | <a href="#">0x4805 04C8</a><br><a href="#">0x4805 04C8</a><br><a href="#">0x4805 0558</a><br><a href="#">0x4805 0558</a> | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register configures the size of video window #n.<br>Shadow register, updated on VFP start period or EVSYNC.          |                 |                                                                                                |
| <b>Type</b>             | RW                                                                                                                       |                 |                                                                                                |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | VIDSIZEY                | Reserved              | VIDSIZEX        |

| Bits  | Field Name | Description                                                                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | Reserved   | Write 0s for future compatibility.<br>Read returns 0                                                                                          | RW   | 0x00  |
| 26:16 | VIDSIZEY   | Number of lines of video #n<br>Encoded value (from 1 to 2048) to specify the number of lines of video window #n (program to value minus one). | RW   | 0x000 |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                            | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15:11 | Reserved   | Write 0s for future compatibility.<br>Read returns 0                                                                                                   | RW   | 0x00  |
| 10:0  | VIDSIZEX   | Number of pixels of video window #n<br>Encoded value (from 1 to 2048) to specify the number of pixels of video window #n (program to value minus one). | RW   | 0x000 |

**Table 7-201. Register Call Summary for Register DISPC\_VIDn\_SIZE**

Display Subsystem Basic Programming Model

- Display Controller Basic Programming Model: [0]
- Video Configuration Register: [1]
- Video Window Attributes: [2] [3]
- Image Data from On-Chip SRAM: [4]

Display Subsystem Register Manual

- Display Controller VID1 Register Mapping Summary: [5]
- Display Controller VID2 Register Mapping Summary: [6]

**Table 7-202. DISPC\_VIDn\_ATTRIBUTES**

|                  |                                                                                                                                                |          |                                                                                                |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------------------------------------------------------------------------------------|
| Address Offset   | 0x0CC+ ((-1)* 0x90)                                                                                                                            | Index    | n = 1 for VID1 or 2 for VID2                                                                   |
| Physical address | 0x4805 04CC<br>0x4805 04CC<br>0x4805 055C<br>0x4805 055C                                                                                       | Instance | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| Description      | The register configures the attributes of video window #n such as format, resizeable, shadow register, updated on VFP start period, or EVSYNC. |          |                                                                                                |
| Type             | RW                                                                                                                                             |          |                                                                                                |

| 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 |
|----------|------------------|----------|----------------|----------------|--------------------|-----------------|--------------------|-------------|-------------------|---------------|-------------|--------------|-------------|--------------|----------------------|--------------------|----------------|----------------|-----------------|-----------|-----------|---|---|---|---|---|---|---|---|---|---|
| RESERVED | PREMULTIPLYALPHA | RESERVED | VIDSELFREFRESH | VIDARBITRATION | VIDLINEBUFFERSPLIT | VIDVERTICALTAPS | VIDDMAOPTIMIZATION | VIDFIFOLOAD | VIDROWREPATENABLE | VIDCHANNELOUT | VIDDIANNESS | VIDBURSTSIZE | VIDROTATION | VIDFULLRANGE | VIDREPLICATIONENABLE | VIDCOLORCONVENABLE | VIDVRESIZECONF | VIDHRESIZECONF | VIDRESIZEENABLE | VIDFORMAT | VIDENABLE |   |   |   |   |   |   |   |   |   |   |

| Bits                                                                                                                                                                                                                                                                                                           | Field Name          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31: 29                                                                                                                                                                                                                                                                                                         | RESERVED            | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0000 |
| 28                                                                                                                                                                                                                                                                                                             | PREMULTIPLYALPHA    | The field configures the DISPC VID2 to process incoming data as pre-multiplied alpha data or non pre-multiplied alpha data.<br>Default setting is non pre-multiplied alpha data.<br>0x0: Non pre-multiplyalpha data color component<br>0x1: Premultiplyalpha data color component                                                                                                                                                                                                                                                                                                                                                                      | RW   | 0      |
| <p><b>NOTE:</b> The pre-multiplied alpha control is supported only on VID2.<br/>For VID1 this bitfield is RESERVED.<br/>The pre-multiplied alpha option is only valid when bit field [4:1] VIDFORMAT is set to ARGB or RGBA formats. Otherwise, the PREMULTIPLYALPHA bit field is ignored by the hardware.</p> |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |        |
| 27: 25                                                                                                                                                                                                                                                                                                         | RESERVED            | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0000 |
| 24                                                                                                                                                                                                                                                                                                             | VIDSELFREFRESH      | Enables the self refresh of the video window from its own FIFO only.<br><br>0x0: The video pipeline accesses the interconnect to fetch data from the system memory<br><br>0x1: The video pipeline does not need anymore to fetch data from memory. Only the video FIFO is used. It takes effect after the frame has been loaded in the FIFO                                                                                                                                                                                                                                                                                                            | RW   | 0      |
| 23                                                                                                                                                                                                                                                                                                             | VIDARBITRATION      | Determines the priority of the video pipeline. The video pipeline is one of the high priority pipeline. The arbitration wheel gives always the priority first to the high priority pipelines using round-robin between them. When there is only normal priority pipelines sending requests, the round-robin applies between them.<br><br>0x0: The video pipeline is one of the normal priority pipeline.<br><br>0x1: The video pipeline is one of the high priority pipeline.                                                                                                                                                                          | RW   | 0      |
| 22                                                                                                                                                                                                                                                                                                             | VIDLINEBUFFER SPLIT | Video vertical line buffer split<br><br>0x0: Vertical line buffers are not split.<br>0x1: Vertical line buffers are split into two.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0      |
| 21                                                                                                                                                                                                                                                                                                             | VIDVERTICALTAPS     | Video vertical resize tap number<br><br>0x0: Three taps are used for the vertical filtering logic. The other two taps are not used.<br><br>0x1: Five taps are used for the vertical filtering logic.                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0      |
| 20                                                                                                                                                                                                                                                                                                             | VIDDMAOPTIMIZATION  | Video optimization in case of<br><br>0x0: The DMA engine fetches one pixel for each 32-bit OCP request (RGB16 and YUV422) while doing 90- and 270-degree rotation (accessing on-chip memory and off-chip memory).<br><br>0x1: The DMA engine fetches two pixels for each 32-bit OCP request (RGB16 and YUV422) while doing 90- and 270-degree rotation (accessing on-chip memory and off-chip memory).<br>The bit field [21] VIDVERTICALTAPS shall be set to 0x1, bit field [22] VIDLINEBUFFERSPLIT to 0x1, and all scaler registers shall be configured even for 1:1 ratio.<br><br>Even width is required for the input picture when 5 taps are used. | RW   | 0      |
| 19                                                                                                                                                                                                                                                                                                             | VIDFIFOPRELOAD      | Video preload value<br><br>0x0: H/W prefetches pixels up to the preload value defined in the preload register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0      |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name                     | Description                                                                                                                                                                                                                           | Type | Reset |
|-------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|       |                                | 0x1: H/W prefetches pixels up to the high threshold value.                                                                                                                                                                            |      |       |
| 18    | VIDROWREPEAT<br>ENABLE         | Video Row Repeat (YUV case only when rotating 90 or 270-degree)<br><br>0x0: Row of VIDn won't be read twice.<br><br>0x1: The Row data are fetched twice to extract both the Y components                                              | RW   | 0     |
| 17    | VIDENDIANNESS                  | Video Endianness<br><br>0x0: Little endian operation is selected.<br><br>0x1: Big endian operation is selected.                                                                                                                       | RW   | 0     |
| 16    | VIDCHANNELOUT                  | Video Channel Out configuration<br>wr: Immediate<br><br>0x0: LCD output selected<br><br>0x1: 24 bit output selected                                                                                                                   | RW   | 0     |
| 15:14 | VIDBURSTSIZE                   | Video DMA Burst Size<br><br>0x0: 4x32bit bursts<br><br>0x1: 8x32bit bursts<br><br>0x2: 16x32bit bursts<br><br>0x3: Reserved                                                                                                           | RW   | 0x0   |
| 13:12 | VIDROTATION                    | Video Rotation Flag<br><br>0x0: No rotation or VidFormat is RGB<br><br>0x1: Rotation by 90 degrees<br><br>0x2: Rotation by 180 degrees<br><br>0x3: Rotation by 270 degrees                                                            | RW   | 0x0   |
| 11    | VIDFULLRANGE                   | VidFullRange<br><br>0x0: Limited range selected: 16 subtracted from Y before color space conversion<br><br>0x1: Full range selected: Y is not modified before the color space conversion                                              | RW   | 0     |
| 10    | VIDREPLICATION<br>ENABLE       | VidReplicationEnable<br><br>0x0: Disable Video replication logic<br><br>0x1: Enable Video replication logic                                                                                                                           | RW   | 0     |
| 9     | VIDCOLORCONV<br>ENABLE         | VidColorConvEnable<br><br>0x0: Disable Color Space Conversion CbYCr to RGB<br><br>0x1: Enable Color Space Conversion CbYCr to RGB                                                                                                     | RW   | 0     |
| 8     | VIDVRESIZECONF                 | Video Vertical Resize Configuration<br><br>0x0: Up-sampling selected<br><br>0x1: Down-sampling selected                                                                                                                               | RW   | 0     |
| 7     | VIDHRESIZECONF                 | Video Horizontal Resize Configuration<br><br>0x0: Up-sampling selected<br><br>0x1: Down-sampling selected                                                                                                                             | RW   | 0     |
| 6:5   | VIDRESIZEENABLE                | Video Resize Enable<br><br>0x0: Disable the resize processing<br><br>0x1: Enable the horizontal resize processing<br><br>0x2: Enable the vertical resize processing<br><br>0x3: Enable both horizontal and vertical resize processing | RW   | 0x0   |
| 4:1   | VIDFORMAT<br>(Video 1 channel) | Video1 channel Format; Other enums: Reserved (all other values between 0x0 and 0x3, 0x5, 0x7, and between 0xC and 0xF)<br><br>0x4: RGB12 (16-bit container)<br><br>0x6: RGB 16<br><br>0x8: RGB 24 (unpacked in 32-bit container)      | RW   | 0x0   |

| Bits | Field Name                     | Description                                                                                                                                                                                                                                                                                                                                                                                                               | Type | Reset |
|------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |                                | 0x9: RGB 24 (packed in 24-bit container)<br>0xA: YUV2 4:2:2 co-sited<br>0xB: UYVY 4:2:2 co-sited                                                                                                                                                                                                                                                                                                                          |      |       |
|      | VIDFORMAT<br>(Video 2 channel) | Video2 channel Format; Other enums: Reserved (all other values:<br>0x0 and 0x3, 0x7, and 0xF)<br><br>0x4: RGB 12 (16-bit container)<br>0x5: ARGB 16<br>0x6: RGB 16<br>0x8: RGB 24 (un-packed in 32-bit container)<br>0x9: RGB 24 (packed in 24-bit container)<br>0xA: YUV2 4:2:2 co-sited<br>0xB: UYVY 4:2:2 co-sited<br>0xC: ARGB 32<br>0xD: RGBA 32<br>0xE: RGBx 32 (24-bit RGB aligned on MSB of the 32-bit container) | RW   | 0x0   |
| 0    | VIDENABLE                      | VidEnable<br><br>0x0: Video disabled (video pipeline inactive and window not present)<br>0x1: Video enabled (video pipeline active and window present on the screen)                                                                                                                                                                                                                                                      | RW   | 0     |

**Table 7-203. Register Call Summary for Register DISPC\_VIDn\_ATTRIBUTES**

Display Subsystem Functional Description

- [Up-/Down-Sampling: \[0\]](#)
- [Overlay Support: \[1\]](#)
- [Priority Rule: \[2\] \[3\]](#)
- [Rotation: \[4\]](#)

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[5\]](#)
- [Video DMA Registers: \[6\] \[7\] \[8\] \[9\] \[10\] \[11\]](#)
- [Video Configuration Register: \[12\] \[13\]](#)
- [Video Window Attributes: \[14\] \[15\] \[16\] \[17\] \[18\]](#)
- [Video Up-/Down-Sampling Configuration: \[19\] \[20\] \[21\] \[22\] \[23\] \[24\] \[25\]](#)
- [Image Data from On-Chip SRAM: \[26\]](#)
- [Additional Configuration When Using YUV Format: \[27\] \[28\] \[29\] \[30\] \[31\] \[32\] \[33\] \[34\] \[35\] \[36\] \[37\] \[38\] \[39\] \[40\] \[41\] \[42\] \[43\] \[44\]](#)
- [Video DMA Optimization: \[45\] \[46\] \[47\] \[48\] \[49\] \[50\] \[51\] \[52\] \[53\]](#)

Display Subsystem Use Cases and Tips

- [Vertical Filtering: \[54\]](#)
- [Register List: \[55\]](#)
- [Enabling: \[56\] \[57\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[58\]](#)
- [Display Controller VID2 Register Mapping Summary: \[59\]](#)
- [Display Controller Registers: \[60\]](#)

**Table 7-204. DISPC\_VIDn\_FIFO\_THRESHOLD**

|                         |                                                                                                                                      |                 |                                                                                                |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0D0+ ((-1)* 0x90)                                                                                                                  | <b>Index</b>    | n = 1 for VID1 or 2 for VID2                                                                   |
| <b>Physical address</b> | 0x4805 04D0<br>0x4805 04D0<br>0x4805 0560<br>0x4805 0560                                                                             | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register configures the video FIFO associated with video pipeline #n.<br>Shadow register, updated on VFP start period or EVSYNC. |                 |                                                                                                |
| <b>Type</b>             | RW                                                                                                                                   |                 |                                                                                                |

|                         |                         |                       |                     |
|-------------------------|-------------------------|-----------------------|---------------------|
| 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     |
| Reserved                | VIDFIFOHIGHTHRESHOLD    | Reserved              | VIDFIFOLOWTHRESHOLD |

| Bits  | Field Name           | Description                                                               | Type | Reset |
|-------|----------------------|---------------------------------------------------------------------------|------|-------|
| 31:28 | Reserved             | Write Os for future compatibility. Read returns 0.                        | RW   | 0x00  |
| 27:16 | VIDFIFOHIGHTHRESHOLD | Video FIFO high threshold<br>Number of bytes defining the threshold value | RW   | 0x3FF |
| 15:12 | Reserved             | Write Os for future compatibility. Read returns 0.                        | RW   | 0x00  |
| 11:0  | VIDFIFOLOWTHRESHOLD  | Video FIFO low threshold<br>Number of bytes defining the threshold value  | RW   | 0x3C0 |

**Table 7-205. Register Call Summary for Register DISPC\_VIDn\_FIFO\_THRESHOLD**

Display Subsystem Basic Programming Model

- Display Controller Basic Programming Model: [0]
- Video DMA Registers: [1] [2] [3] [4] [5] [6]
- Image Data from On-Chip SRAM: [7]

Display Subsystem Register Manual

- Display Controller VID1 Register Mapping Summary: [8]
- Display Controller VID2 Register Mapping Summary: [9]

**Table 7-206. DISPC\_VIDn\_FIFO\_SIZE\_STATUS**

|                         |                                                                 |                 |                                                                                                |
|-------------------------|-----------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0D4+ ((-1)* 0x90)                                             | <b>Index</b>    | n = 1 for VID1 or 2 for VID2                                                                   |
| <b>Physical address</b> | 0x4805 04D4<br>0x4805 04D4<br>0x4805 0564<br>0x4805 0564        | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register defines the video FIFO size for video pipeline #n. |                 |                                                                                                |
| <b>Type</b>             | R                                                               |                 |                                                                                                |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                |                         |                       | VIDFIFOSIZE     |

| Bits  | Field Name  | Description                                                | Type | Reset    |
|-------|-------------|------------------------------------------------------------|------|----------|
| 31:11 | Reserved    | Write Os for future compatibility. Read returns 0.         | R    | 0x000000 |
| 10:0  | VIDFIFOSIZE | Video FIFO Size<br>Number of bytes defining the FIFO value | R    | 0x400    |

**Table 7-207. Register Call Summary for Register DISPC\_VIDn\_FIFO\_SIZE\_STATUS**

Display Subsystem Register Manual

- Display Controller VID1 Register Mapping Summary: [0]
- Display Controller VID2 Register Mapping Summary: [1]

**Table 7-208. DISPC\_VIDn\_ROW\_INC**

|                         |                                                                                                                                                                                           |                 |                              |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------|
| <b>Address Offset</b>   | 0x0D8+ ((-1)* 0x90)                                                                                                                                                                       | <b>Index</b>    | n = 1 for VID1 or 2 for VID2 |
| <b>Physical address</b> | 0x4805 04D8<br>0x4805 04D8<br>0x4805 0568<br>0x4805 0568                                                                                                                                  | <b>Instance</b> | DISC                         |
| <b>Description</b>      | The register configures the number of bytes to increment at the end of the row for the buffer associated with video window #n.<br>Shadow register, updated on VFP start period or EVSYNC. |                 |                              |
| <b>Type</b>             | RW                                                                                                                                                                                        |                 |                              |

|           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| VIDROWINC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | VIDROWINC  | Number of bytes to increment at the end of the row<br>Encoded signed value (from -2 <sup>31</sup> - 1 to 2 <sup>31</sup> ) to specify the number of bytes to increment at the end of the row in the video buffer.<br>The value 0 is invalid. The value 1 means next pixel. The value 1+n*BPP means increment of n pixels. The value 1- (n+1)*BPP means decrement of n pixels. | RW   | 0x00000001 |

**Table 7-209. Register Call Summary for Register DISPC\_VIDn\_ROW\_INC**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Video DMA Registers: \[1\]](#)
- [Video Window Attributes: \[2\] \[3\]](#)
- [Image Data from On-Chip SRAM: \[4\] \[5\] \[6\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[7\]](#)
- [Display Controller VID2 Register Mapping Summary: \[8\]](#)

**Table 7-210. DISPC\_VIDn\_PIXEL\_INC**

|                         |                                                                                                                                                                                        |                 |                                                                                                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0DC+ ((-1)* 0x90)                                                                                                                                                                    | <b>Index</b>    | n = 1 for VID1 or 2 for VID2                                                                   |
| <b>Physical address</b> | 0x4805 04DC<br>0x4805 04DC<br>0x4805 056C<br>0x4805 056C                                                                                                                               | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register configures the number of bytes to increment between two pixels for the buffer associated with video window #n.<br>Shadow register, updated on VFP start period or EVSYNC. |                 |                                                                                                |
| <b>Type</b>             | RW                                                                                                                                                                                     |                 |                                                                                                |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | VIDPIXELINC |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                  | Type | Reset  |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved    | Write 0s for future compatibility.<br>Read returns 0                                                                                                                                                                                                                                                                                                         | RW   | 0x0000 |
| 15:0  | VIDPIXELINC | Number of bytes to increment at the end of the row<br>Encoded signed value (from -2 <sup>15</sup> - 1 to 2 <sup>15</sup> ) to specify the number of bytes between two pixels in the video buffer.<br>The value 0 is invalid. The value 1 means next pixel. The value 1+n*BPP means increment of n pixels. The value 1- (n+1)*BPP means decrement of n pixels | RW   | 0x0001 |

**Table 7-211. Register Call Summary for Register DISPC\_VIDn\_PIXEL\_INC**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Video DMA Registers: \[1\]](#)
- [Image Data from On-Chip SRAM: \[2\] \[3\] \[4\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[5\]](#)
- [Display Controller VID2 Register Mapping Summary: \[6\]](#)

**Table 7-212. DISPC\_VIDn\_FIR**

|                         |                                                                                                                                                                      |                 |                                                                                                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0E0+ ((-1)* 0x90)                                                                                                                                                  | <b>Index</b>    | n = 1 for VID1 or 2 for VID2                                                                   |
| <b>Physical address</b> | 0x4805 04E0<br>0x4805 04E0<br>0x4805 0570<br>0x4805 0570                                                                                                             | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register configures the resize factors for horizontal and vertical up-/down-sampling of video window #n. Shadow register, updated on VFP start period or EVSYNC. |                 |                                                                                                |
| <b>Type</b>             | RW                                                                                                                                                                   |                 |                                                                                                |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Reserved |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                                                                                                                                           | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:29 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                    | RW   | 0x0    |
| 28:16 | VIDFIRVINC | Vertical increment of the up-/down-sampling filter<br>Encoded value (from 1 to 4096). The value 0 is invalid. Values greater than 4096 are invalid.   | RW   | 0x0000 |
| 15:13 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                    | RW   | 0x0    |
| 12:0  | VIDFIRHINC | Horizontal increment of the up-/down-sampling filter<br>Encoded value (from 1 to 4096). The value 0 is invalid. Values greater than 4096 are invalid. | RW   | 0x0000 |

**Table 7-213. Register Call Summary for Register DISPC\_VIDn\_FIR**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Video Configuration Register: \[1\]](#)
- [Video Up-/Down-Sampling Configuration: \[2\] \[3\]](#)

Display Subsystem Use Cases and Tips

- [Register List: \[4\]](#)
- [Factor: \[5\] \[6\]](#)
- [Coefficients: \[7\] \[8\] \[9\] \[10\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[11\]](#)
- [Display Controller VID2 Register Mapping Summary: \[12\]](#)

**Table 7-214. DISPC\_VIDn\_PICTURE\_SIZE**

|                         |                                                                                                                                                                         |                 |                                                                                                |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0E4+ ((-1)* 0x90)                                                                                                                                                     | <b>Index</b>    | n = 1 for VID1 or 2 for VID2                                                                   |
| <b>Physical address</b> | <a href="#">0x4805 04E4</a><br><a href="#">0x4805 04E4</a><br><a href="#">0x4805 0574</a><br><a href="#">0x4805 0574</a>                                                | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register configures the size of the video picture associated with video layer #nbefore up-/down-scaling.<br>Shadow register, updated on VFP start period or EVSYNC. |                 |                                                                                                |
| <b>Type</b>             | RW                                                                                                                                                                      |                 |                                                                                                |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | VIDORGSIZEY             | Reserved              | VIDORGSIZEX     |

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | Reserved    | Write 0s for future compatibility.<br>Read returns 0                                                                                                                                                                                                                                                                                         | RW   | 0x00  |
| 26:16 | VIDORGSIZEY | Number of lines of the video picture<br>Encoded value (from 1 to 2048) to specify the number of lines of the video picture in memory (program to value minus one).                                                                                                                                                                           | RW   | 0x000 |
| 15:11 | Reserved    | Write 0s for future compatibility.<br>Read returns 0                                                                                                                                                                                                                                                                                         | RW   | 0x00  |
| 10:0  | VIDORGSIZEX | Number of pixels of the video picture<br>Encoded value (from 1 to 2048) to specify the number of pixels of the video picture in memory (program to value minus one). The size is limited to the size of the line buffer of the vertical sampling block in case the video picture is processed by the vertical filtering unit. <sup>(1)</sup> | RW   | 0x000 |

- <sup>(1)</sup> For 5-tap RGB16 and YUV422 picture formats, the width of the input picture must be a multiple of 2 pixels and more than 5 pixels. This leads to the following register configuration:
- [DISPC\\_VIDn\\_ATTRIBUTES\[21\]](#) VIDVERTICALTAPS is set to 1.
  - [DISPC\\_VIDn\\_PICTURE\\_SIZE\[10:0\]](#) VIDORGSIZEX must be even and more than 4.

**Table 7-215. Register Call Summary for Register DISPC\_VIDn\_PICTURE\_SIZE**

Display Subsystem Functional Description

- [Up-/Down-Sampling: \[0\]](#)

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[1\]](#)
- [Video DMA Registers: \[2\] \[3\] \[4\]](#)
- [Video Configuration Register: \[5\]](#)
- [Video Window Attributes: \[6\] \[7\]](#)
- [Video Up-/Down-Sampling Configuration: \[8\]](#)

Display Subsystem Use Cases and Tips

- [Vertical Filtering: \[9\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[10\]](#)
- [Display Controller VID2 Register Mapping Summary: \[11\]](#)
- [Display Controller Registers: \[12\]](#)

**Table 7-216. DISPC\_VIDn\_ACCUI**

|                         |                                                                                                                                                                                                                                                                        |                 |                                                                                                |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0E8+ ((-1)* 0x90) + (I* 0x04)                                                                                                                                                                                                                                        | <b>Index</b>    | n = 1 for VID1 or 2 for VID2<br>I = 0 to 1                                                     |
| <b>Physical address</b> | 0x4805 04E8 + (I* 0x04)<br>0x4805 04E8 + (I* 0x04)<br>0x4805 0578 + (I* 0x04)<br>0x4805 0578 + (I* 0x04)                                                                                                                                                               | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register configures the resize accumulator init values for horizontal and vertical up-/down-sampling of video window #n (#I for ping-pong mechanism with external trigger, based on the field polarity)<br>Shadow register, updated on VFP start period or EVSYNC. |                 |                                                                                                |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                     |                 |                                                                                                |

|          |    |    |    |                 |    |    |    |    |    |    |          |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|-----------------|----|----|----|----|----|----|----------|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    | VIDVERTICALACCU |    |    |    |    |    |    | Reserved |    |    |    | VIDHORIZONTALACCU |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name            | Description                                                           | Type | Reset |
|-------|-----------------------|-----------------------------------------------------------------------|------|-------|
| 31:26 | Reserved              | Write 0s for future compatibility.<br>Read returns 0                  | RW   | 0x00  |
| 25:16 | VIDVERTICAL<br>ACCU   | Vertical initialization accu value. Encoded value (from 0 to 1023).   | RW   | 0x000 |
| 15:10 | Reserved              | Write 0s for future compatibility.<br>Read returns 0                  | RW   | 0x00  |
| 9:0   | VIDHORIZONTAL<br>ACCU | Horizontal initialization accu value. Encoded value (from 0 to 1023). | RW   | 0x000 |

**Table 7-217. Register Call Summary for Register DISPC\_VIDn\_ACCUI**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Video Up-/Down-Sampling Configuration: \[1\] \[2\]](#)

Display Subsystem Use Cases and Tips

- [Register List: \[3\]](#)
- [Initial Phase: \[4\] \[5\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[6\]](#)
- [Display Controller VID2 Register Mapping Summary: \[7\]](#)

**Table 7-218. DISPC\_VIDn\_FIR\_COEF\_Hi**

|                         |                                                                                                                                                                                                                                                      |                 |                                                                                                |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0F0+ ((-1)* 0x90) + (I* 0x08)                                                                                                                                                                                                                      | <b>Index</b>    | n = 1 for VID1 or 2 for VID2<br>i = 0 to 7                                                     |
| <b>Physical address</b> | 0x4805 04F0+ (I* 0x08)<br>0x4805 04F0+ (I* 0x08)<br>0x4805 0580 + (I* 0x08)<br>0x4805 0580 + (I* 0x08)                                                                                                                                               | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The bank of registers configure the up-/down-scaling coefficients for the vertical and horizontal resize of the video picture associated with video window #n for the phases from 0 to 7.<br>Shadow register, updated on VFP start period or EVSYNC. |                 |                                                                                                |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                   |                 |                                                                                                |

|           |    |    |    |           |    |    |    |    |    |    |           |    |    |    |           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------|----|----|----|-----------|----|----|----|----|----|----|-----------|----|----|----|-----------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| VIDFIRHC3 |    |    |    | VIDFIRHC2 |    |    |    |    |    |    | VIDFIRHC1 |    |    |    | VIDFIRHC0 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                  | Type | Reset |
|-------|------------|------------------------------------------------------------------------------|------|-------|
| 31:24 | VIDFIRHC3  | Signed coefficient C3 for the horizontal up-/down-scaling with the phase n   | RW   | 0x00  |
| 23:16 | VIDFIRHC2  | Unsigned coefficient C2 for the horizontal up-/down-scaling with the phase n | RW   | 0x00  |

| Bits | Field Name | Description                                                                | Type | Reset |
|------|------------|----------------------------------------------------------------------------|------|-------|
| 15:8 | VIDFIRHC1  | Signed coefficient C1 for the horizontal up-/down-scaling with the phase n | RW   | 0x00  |
| 7:0  | VIDFIRHC0  | Signed coefficient C0 for the horizontal up-/down-scaling with the phase n | RW   | 0x00  |

**Table 7-219. Register Call Summary for Register DISPC\_VIDn\_FIR\_COEF\_Hi**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Video Configuration Register: \[1\]](#)
- [Video Up-/Down-Sampling Configuration: \[2\] \[3\] \[4\]](#)

Display Subsystem Use Cases and Tips

- [Register List: \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [Coefficients: \[10\] \[11\] \[12\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[13\]](#)
- [Display Controller VID2 Register Mapping Summary: \[14\]](#)

**Table 7-220. DISPC\_VIDn\_FIR\_COEF\_HVi**

|                         |                                                                                                                                                                                                                                                           |                       |                                                                                                |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0F4+ ((-1)* 0x90) + (i* 0x08)                                                                                                                                                                                                                           | <b>Index</b>          | n = 1 for VID1 or 2 for VID2<br>i = 0 to 7                                                     |
| <b>Physical address</b> | 0x4805 04F4 + (i*0x08)<br>0x4805 04F4 + (i*0x08)<br>0x4805 0584 + (i*0x08)<br>0x4805 0584 + (i*0x08)                                                                                                                                                      | <b>Instance</b>       | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The bank of registers configure the down/up-/down-scaling coefficients for the vertical and horizontal resize of the video picture associated with video window #n for the phases from 0 to 7.<br>Shadow register, updated on VFP start period or EVSYNC. |                       |                                                                                                |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                        |                       |                                                                                                |
| 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                                                                                |
| VIDFIRVC2               | VIDFIRVC1                                                                                                                                                                                                                                                 | VIDFIRVC0             | VIDFIRHC4                                                                                      |

| Bits  | Field Name | Description                                                                | Type | Reset |
|-------|------------|----------------------------------------------------------------------------|------|-------|
| 31:24 | VIDFIRVC2  | Signed coefficient C2 for the vertical up-/down-scaling with the phase n   | RW   | 0x00  |
| 23:16 | VIDFIRVC1  | Unsigned coefficient C1 for the vertical up-/down-scaling with the phase n | RW   | 0x00  |
| 15:8  | VIDFIRVC0  | Signed coefficient C0 for the vertical up-/down-scaling with the phase n   | RW   | 0x00  |
| 7:0   | VIDFIRHC4  | Signed coefficient C4 for the horizontal up-/down-scaling with the phase n | RW   | 0x00  |

**Table 7-221. Register Call Summary for Register DISPC\_VIDn\_FIR\_COEF\_HVi**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Video Configuration Register: \[1\]](#)
- [Video Up-/Down-Sampling Configuration: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\]](#)

Display Subsystem Use Cases and Tips

- [Register List: \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\]](#)
- [Coefficients: \[16\] \[17\] \[18\] \[19\] \[20\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[21\]](#)
- [Display Controller VID2 Register Mapping Summary: \[22\]](#)

**Table 7-222. DISPC\_VIDn\_CONV\_COEF0**

|                         |                                                                                                                                                          |                 |                                                                                                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x130+((-1)* 0x90)                                                                                                                                       | <b>Index</b>    | n = 1 for VID1 or 2 for VID2                                                                   |
| <b>Physical address</b> | 0x4805 0530<br>0x4805 0530<br>0x4805 05C0<br>0x4805 05C0                                                                                                 | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register configures the color space conversion matrix coefficients for video pipeline #n.<br>Shadow register, updated on VFP start period or EVSYNC. |                 |                                                                                                |
| <b>Type</b>             | RW                                                                                                                                                       |                 |                                                                                                |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | RCR                     | Reserved              | RY              |

| Bits  | Field Name | Description                                                   | Type | Reset |
|-------|------------|---------------------------------------------------------------|------|-------|
| 31:27 | Reserved   | Write 0s for future compatibility.<br>Read returns 0          | RW   | 0x00  |
| 26:16 | RCR        | RCr Coefficient<br>Encoded signed value (from -1024 to 1023). | RW   | 0x000 |
| 15:11 | Reserved   | Write 0s for future compatibility.<br>Read returns 0          | RW   | 0x00  |
| 10:0  | RY         | RY Coefficient<br>Encoded signed value (from -1024 to 1023).  | RW   | 0x000 |

**Table 7-223. Register Call Summary for Register DISPC\_VIDn\_CONV\_COEF0**

Display Subsystem Basic Programming Model

- Image Data from On-Chip SRAM: [0] [1]
- Video DMA Optimization: [2]

Display Subsystem Register Manual

- Display Controller VID1 Register Mapping Summary: [3]
- Display Controller VID2 Register Mapping Summary: [4]

**Table 7-224. DISPC\_VIDn\_CONV\_COEF1**

|                         |                                                                                                                                                          |                 |                                                                                                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x134+((-1)* 0x90)                                                                                                                                       | <b>Index</b>    | n = 1 for VID1 or 2 for VID2                                                                   |
| <b>Physical address</b> | 0x4805 0534<br>0x4805 0534<br>0x4805 05C4<br>0x4805 05C4                                                                                                 | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register configures the color space conversion matrix coefficients for video pipeline #n.<br>Shadow register, updated on VFP start period or EVSYNC. |                 |                                                                                                |
| <b>Type</b>             | RW                                                                                                                                                       |                 |                                                                                                |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | GY                      | Reserved              | RCB             |

| Bits  | Field Name | Description                                                   | Type | Reset |
|-------|------------|---------------------------------------------------------------|------|-------|
| 31:27 | Reserved   | Write 0s for future compatibility.<br>Read returns 0          | RW   | 0x00  |
| 26:16 | GY         | GY Coefficient<br>Encoded signed value (from -1024 to 1023).  | RW   | 0x000 |
| 15:11 | Reserved   | Write 0s for future compatibility.<br>Read returns 0          | RW   | 0x00  |
| 10:0  | RCB        | RCb Coefficient<br>Encoded signed value (from -1024 to 1023). | RW   | 0x000 |

**Table 7-225. Register Call Summary for Register DISPC\_VIDn\_CONV\_COEF1**

Display Subsystem Basic Programming Model

- [Image Data from On-Chip SRAM: \[0\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[1\]](#)
- [Display Controller VID2 Register Mapping Summary: \[2\]](#)

**Table 7-226. DISPC\_VIDn\_CONV\_COEF2**

|                         |                                                                                                                                                          |                 |                                                                                                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x138+ ((-1)* 0x90)                                                                                                                                      | <b>Index</b>    | n = 1 for VID1 or 2 for VID2                                                                   |
| <b>Physical address</b> | <b>0x4805 0538</b><br><b>0x4805 0538</b><br><b>0x4805 05C8</b><br><b>0x4805 05C8</b>                                                                     | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register configures the color space conversion matrix coefficients for video pipeline #n.<br>Shadow register, updated on VFP start period or EVSYNC. |                 |                                                                                                |
| <b>Type</b>             | RW                                                                                                                                                       |                 |                                                                                                |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | GCB                     | Reserved              | GCR             |

| Bits  | Field Name | Description                                                   | Type | Reset |
|-------|------------|---------------------------------------------------------------|------|-------|
| 31:27 | Reserved   | Write 0s for future compatibility.<br>Read returns 0          | RW   | 0x00  |
| 26:16 | GCB        | GCb Coefficient<br>Encoded signed value (from -1024 to 1023). | RW   | 0x000 |
| 15:11 | Reserved   | Write 0s for future compatibility.<br>Read returns 0          | RW   | 0x00  |
| 10:0  | GCR        | GCr Coefficient<br>Encoded signed value (from -1024 to 1023). | RW   | 0x000 |

**Table 7-227. Register Call Summary for Register DISPC\_VIDn\_CONV\_COEF2**

Display Subsystem Basic Programming Model

- [Image Data from On-Chip SRAM: \[0\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[1\]](#)
- [Display Controller VID2 Register Mapping Summary: \[2\]](#)

**Table 7-228. DISPC\_VIDn\_CONV\_COEF3**

|                         |                                                                                                                                                          |                 |                                                                                                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x13C+ ((-1)* 0x90)                                                                                                                                      | <b>Index</b>    | n = 1 for VID1 or 2 for VID2                                                                   |
| <b>Physical address</b> | <b>0x4805 053C</b><br><b>0x4805 053C</b><br><b>0x4805 05CC</b><br><b>0x4805 05CC</b>                                                                     | <b>Instance</b> | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register configures the color space conversion matrix coefficients for video pipeline #n.<br>Shadow register, updated on VFP start period or EVSYNC. |                 |                                                                                                |
| <b>Type</b>             | RW                                                                                                                                                       |                 |                                                                                                |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | BCR                     | Reserved              | BY              |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name | Description                                                   | Type | Reset |
|-------|------------|---------------------------------------------------------------|------|-------|
| 31:27 | Reserved   | Write 0s for future compatibility.<br>Read returns 0          | RW   | 0x00  |
| 26:16 | BCR        | BCr coefficient<br>Encoded signed value (from -1024 to 1023). | RW   | 0x000 |
| 15:11 | Reserved   | Write 0s for future compatibility.<br>Read returns 0          | RW   | 0x00  |
| 10:0  | BY         | BY coefficient<br>Encoded signed value (from -1024 to 1023).  | RW   | 0x000 |

**Table 7-229. Register Call Summary for Register DISPC\_VIDn\_CONV\_COEF3**

Display Subsystem Basic Programming Model

- [Image Data from On-Chip SRAM: \[0\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[1\]](#)
- [Display Controller VID2 Register Mapping Summary: \[2\]](#)

**Table 7-230. DISPC\_VIDn\_CONV\_COEF4**

|                         |                                                                                                                                                          |                       |                                                                                                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x140+ ((-1)* 0x90)                                                                                                                                      | <b>Index</b>          | n = 1 for VID1 or 2 for VID2                                                                   |
| <b>Physical address</b> | 0x4805 0540<br>0x4805 0540<br>0x4805 05D0<br>0x4805 05D0                                                                                                 | <b>Instance</b>       | Display Controller<br>Display Controller VID1<br>Display Controller<br>Display Controller VID2 |
| <b>Description</b>      | The register configures the color space conversion matrix coefficients for video pipeline #n.<br>Shadow register, updated on VFP start period or EVSYNC. |                       |                                                                                                |
| <b>Type</b>             | RW                                                                                                                                                       |                       |                                                                                                |
| 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                                                                                |
| Reserved                |                                                                                                                                                          |                       |                                                                                                |
| BCB                     |                                                                                                                                                          |                       |                                                                                                |

| Bits  | Field Name | Description                                                   | Type | Reset    |
|-------|------------|---------------------------------------------------------------|------|----------|
| 31:11 | Reserved   | Write 0s for future compatibility.<br>Read returns 0          | RW   | 0x000000 |
| 10:0  | BCB        | BCb Coefficient<br>Encoded signed value (from -1024 to 1023). | RW   | 0x000    |

**Table 7-231. Register Call Summary for Register DISPC\_VIDn\_CONV\_COEF4**

Display Subsystem Basic Programming Model

- [Image Data from On-Chip SRAM: \[0\] \[1\]](#)
- [Video DMA Optimization: \[2\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[3\]](#)
- [Display Controller VID2 Register Mapping Summary: \[4\]](#)

**Table 7-232. DISPC\_DATA\_CYCLEk**

|                         |                                                                                                                                          |                                |                                          |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|------------------------------------------|
| <b>Address Offset</b>   | 0x1D4 + (k* 0x04)                                                                                                                        | <b>Index</b>                   | k = 0 to 2                               |
| <b>Physical address</b> | 0x4805 05D4+ (k * 0x04)                                                                                                                  | <b>Instance</b>                | DISPC                                    |
| <b>Description</b>      | The control register configures the output data format for ith (1st, 2nd or 3rd) cycle.<br>Shadow register, updated on VFP start period. |                                |                                          |
| <b>Type</b>             | RW                                                                                                                                       |                                |                                          |
| 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                          |
| Reserved                | BITALIGNMENTPIXEL2                                                                                                                       | Reserved NBBITSPIXEL2 Reserved | BITALIGNMENTPIXEL1 Reserved NBBITSPIXEL1 |

| Bits  | Field Name             | Description                                                                                                         | Type | Reset |
|-------|------------------------|---------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | Reserved               | Write 0s for future compatibility.<br>Read returns 0                                                                | RW   | 0x0   |
| 27:24 | BITALIGNMENT<br>PIXEL2 | Bit alignment<br>Alignment of the bits from pixel#2 on the output interface                                         | RW   | 0x0   |
| 23:21 | Reserved               | Write 0s for future compatibility. Read returns 0.                                                                  | RW   | 0x0   |
| 20:16 | NBBITSPIXEL2           | Number of bits<br>Number of bits from the pixel #2 (value from 0 to 16 bits). The values from 17 to 31 are invalid. | RW   | 0x00  |
| 15:12 | Reserved               | Write 0s for future compatibility. Read returns 0.                                                                  | RW   | 0x0   |
| 11:8  | BITALIGNMENT<br>PIXEL1 | Bit alignment<br>Alignment of the bits from pixel#1 on the output interface                                         | RW   | 0x0   |
| 7:5   | Reserved               | Write 0s for future compatibility. Read returns 0.                                                                  | RW   | 0x0   |
| 4:0   | NBBITSPIXEL1           | Number of bits<br>Number of bits from the pixel #1 (value from 0 to 16 bits). The values from 17 to 31 are invalid. | RW   | 0x00  |

**Table 7-233. Register Call Summary for Register DISPC\_DATA\_CYCLEk**

Display Subsystem Functional Description

- [Multiple Cycle Output Format: \[0\] \[1\] \[2\]](#)

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[3\]](#)
- [LCD-Specific Control Registers: \[4\]](#)
- [LCD TDM: \[5\] \[6\] \[7\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[8\]](#)

**Table 7-234. DISPC\_VIDn\_FIR\_COEF\_Vi**

|                         |                                                                                                                                                                                                                                 |                 |                                            |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------|
| <b>Address Offset</b>   | 0x1E0+ ((-1)* 0x20) + (i* 0x04)                                                                                                                                                                                                 | <b>Index</b>    | n = 1 for VID1 or 2 for VID2<br>i = 0 to 7 |
| <b>Physical address</b> | 0x4805 05E0 + (i* 0x04)<br>0x4805 05E0 + (i* 0x04)<br>0x4805 0670 + (i* 0x04)<br>0x4805 0670 + (i* 0x04)                                                                                                                        | <b>Instance</b> | DISC                                       |
| <b>Description</b>      | This bank of registers configures the down/up/down-scaling coefficients for the vertical resize of the video picture associated with video window #n for phases 0 to 7. Shadow register, updated on VFP start period or EVSYNC. |                 |                                            |
| <b>Type</b>             | RW                                                                                                                                                                                                                              |                 |                                            |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |            |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|------------|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | VIDFIRVC22 |    |    |    |    | VIDFIRVC00 |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                      | Type | Reset  |
|-------|------------|------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility. Read returns 0.               | RW   | 0x0000 |
| 15:8  | VIDFIRVC22 | Signed coefficient C22 for vertical up/down-scaling with phase n | RW   | 0x00   |
| 7:0   | VIDFIRVC00 | Signed coefficient C00 for vertical up/down-scaling with phase n | RW   | 0x00   |

**Table 7-235. Register Call Summary for Register DISPC\_VIDn\_FIR\_COEF\_Vi**

## Display Subsystem Basic Programming Model

- Display Controller Basic Programming Model: [0]
- Video Up-/Down-Sampling Configuration: [1] [2]

## Display Subsystem Use Cases and Tips

- Register List: [3] [4] [5]
- Coefficients: [6] [7] [8]

## Display Subsystem Register Manual

- Display Controller VID1 Register Mapping Summary: [9]
- Display Controller VID2 Register Mapping Summary: [10]

**Table 7-236. DISPC\_CPR\_COEF\_R**

|                       |                                                                                                                                            |                         |             |                 |      |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x220                                                                                                                                      | <b>Physical address</b> | 0x4805 0620 | <b>Instance</b> | DISC |
| <b>Description</b>    | This register configures the color phase rotation matrix coefficients for the red component. Shadow register, updated on VFP start period. |                         |             |                 |      |
| <b>Type</b>           | RW                                                                                                                                         |                         |             |                 |      |

|    |    |    |    |    |    |          |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----------|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RR |    |    |    |    |    | Reserved | RG |    |    |    |    |    | Reserved | RB |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                               | Type | Reset |
|-------|------------|-----------------------------------------------------------|------|-------|
| 31:22 | RR         | RR coefficient<br>Encoded signed value (from -512 to 511) | RW   | 0x000 |
| 21    | Reserved   | Write 0s for future compatibility. Read returns 0.        | RW   | 0     |
| 20:11 | RG         | RG coefficient<br>Encoded signed value (from -512 to 511) | RW   | 0x000 |
| 10    | Reserved   | Write 0s for future compatibility. Read returns 0.        | RW   | 0     |
| 9:0   | RB         | RB coefficient<br>Encoded signed value (from -512 to 511) | RW   | 0x000 |

**Table 7-237. Register Call Summary for Register DISPC\_CPR\_COEF\_R**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [LCD-Specific Control Registers: \[1\]](#)
- [LCD Color Phase Rotation: \[2\] \[3\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[4\]](#)

**Table 7-238. DISPC\_CPR\_COEF\_G**

|                       |                                                                                                                                              |                         |             |                 |      |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x224                                                                                                                                        | <b>Physical address</b> | 0x4805 0624 | <b>Instance</b> | DISC |
| <b>Description</b>    | This register configures the color phase rotation matrix coefficients for the green component. Shadow register, updated on VFP start period. |                         |             |                 |      |
| <b>Type</b>           | RW                                                                                                                                           |                         |             |                 |      |



| Bits  | Field Name | Description                                               | Type | Reset |
|-------|------------|-----------------------------------------------------------|------|-------|
| 31:22 | GR         | GR coefficient<br>Encoded signed value (from -512 to 511) | RW   | 0x000 |
| 21    | Reserved   | Write 0s for future compatibility. Read returns 0.        | RW   | 0     |
| 20:11 | GG         | GG coefficient<br>Encoded signed value (from -512 to 511) | RW   | 0x000 |
| 10    | Reserved   | Write 0s for future compatibility. Read returns 0.        | RW   | 0     |
| 9:0   | GB         | GB coefficient<br>Encoded signed value (from -512 to 511) | RW   | 0x000 |

**Table 7-239. Register Call Summary for Register DISPC\_CPR\_COEF\_G**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [LCD-Specific Control Registers: \[1\]](#)
- [LCD Color Phase Rotation: \[2\] \[3\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[4\]](#)

**Table 7-240. DISPC\_CPR\_COEF\_B**

|                       |                                                                                                                                             |                         |             |                 |      |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x228                                                                                                                                       | <b>Physical address</b> | 0x4805 0628 | <b>Instance</b> | DISC |
| <b>Description</b>    | This register configures the color phase rotation matrix coefficients for the blue component. Shadow register, updated on VFP start period. |                         |             |                 |      |
| <b>Type</b>           | RW                                                                                                                                          |                         |             |                 |      |



## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name | Description                                               | Type | Reset |
|-------|------------|-----------------------------------------------------------|------|-------|
| 31:22 | BR         | BR coefficient<br>Encoded signed value (from -512 to 511) | RW   | 0x000 |
| 21    | Reserved   | Write 0s for future compatibility. Read returns 0.        | RW   | 0     |
| 20:11 | BG         | BG coefficient<br>Encoded signed value (from -512 to 511) | RW   | 0x000 |
| 10    | Reserved   | Write 0s for future compatibility. Read returns 0.        | RW   | 0     |
| 9:0   | BB         | BB coefficient<br>Encoded signed value (from -512 to 511) | RW   | 0x000 |

**Table 7-241. Register Call Summary for Register DISPC\_CPR\_COEF\_B**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [LCD-Specific Control Registers: \[1\]](#)
- [LCD Color Phase Rotation: \[2\] \[3\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[4\]](#)

**Table 7-242. DISPC\_GFX\_PRELOAD**

|                       |                                                                                                     |                         |             |                 |      |
|-----------------------|-----------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x22C                                                                                               | <b>Physical address</b> | 0x4805 062C | <b>Instance</b> | DISC |
| <b>Description</b>    | This register configures the graphics FIFO. Shadow register, updated on VFP start period or EVSYNC. |                         |             |                 |      |
| <b>Type</b>           | RW                                                                                                  |                         |             |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PRELOAD |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                         | RW   | 0x00000 |
| 11:0  | PRELOAD    | Graphics preload value: Number of bytes defining the preload value.<br>Constraint: Maximum value is (FIFO size - DMA burst size - 8) bytes | RW   | 0x100   |

**Table 7-243. Register Call Summary for Register DISPC\_GFX\_PRELOAD**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Graphics DMA Registers: \[1\] \[2\] \[3\] \[4\]](#)

Display Subsystem Register Manual

- [Display Controller Register Mapping Summary: \[5\]](#)

**Table 7-244. DISPC\_VIDn\_PRELOAD**

|                         |                                                                                                  |                 |                              |
|-------------------------|--------------------------------------------------------------------------------------------------|-----------------|------------------------------|
| <b>Address Offset</b>   | 0x230+ ((-1)* 0x04)                                                                              | <b>Index</b>    | n = 1 for VID1 or 2 for VID2 |
| <b>Physical address</b> | 0x4805 0630<br>0x4805 0630<br>0x4805 0634<br>0x4805 0634                                         | <b>Instance</b> | DISC                         |
| <b>Description</b>      | This register configures the video FIFO. Shadow register, updated on VFP start period or EVSYNC. |                 |                              |
| <b>Type</b>             | RW                                                                                               |                 |                              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PRELOAD |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                             | Type | Reset   |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                      | RW   | 0x00000 |
| 11:0  | PRELOAD    | Video preload value: Number of bytes defining the preload value.<br>Constraint: Maximum value is (FIFO size - DMA burst size - 8) bytes | RW   | 0x100   |

**Table 7-245. Register Call Summary for Register DISPC\_VIDn\_PRELOAD**

Display Subsystem Basic Programming Model

- [Display Controller Basic Programming Model: \[0\]](#)
- [Video DMA Registers: \[1\] \[2\] \[3\] \[4\]](#)

Display Subsystem Register Manual

- [Display Controller VID1 Register Mapping Summary: \[5\]](#)
- [Display Controller VID2 Register Mapping Summary: \[6\]](#)

### 7.7.2.3 RFBI Registers

**Table 7-246. RFBI\_REVISION**

|                       |                                              |                         |             |                 |      |
|-----------------------|----------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x00                                         | <b>Physical address</b> | 0x4805 0800 | <b>Instance</b> | RFBI |
| <b>Description</b>    | This register contains the IP revision code. |                         |             |                 |      |
| <b>Type</b>           | R                                            |                         |             |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | REV |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                 | Type | Reset            |
|------|------------|-------------------------------------------------------------|------|------------------|
| 31:8 | Reserved   | Read returns 0.                                             | R    | 0x000000         |
| 7:0  | REV        | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision | R    | TI internal data |

**Table 7-247. Register Call Summary for Register RFBI\_REVISION**

Display Subsystem Register Manual

- [RFBI Register Mapping Summary: \[0\]](#)

**Table 7-248. RFBI\_SYSCONFIG**

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                     | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:7 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                              | RW   | 0x00000000 |
| 6    | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                              | RW   | 0          |
| 5    | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                              | RW   | 0          |
| 4:3  | SIDLEMODE  | Slave interface power management, Idle req/ack control<br>00: Force-idle: Idle request is acknowledged unconditionally.<br>01: No idle: An idle request is never acknowledged<br>10: Smart idle: Idle request is acknowledged based on the internal activity of the module.<br>11: Reserved                                     | RW   | 0x0        |
| 2    | Reserved   | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                                                                                                                                             | RW   | 0          |
| 1    | SOFTRESET  | Software reset<br>Sets this bit to 1 to trigger a module reset. The bit is automatically reset by the hardware. During reads, it always returns 0.<br>0: Normal mode<br>1: The module is reset                                                                                                                                  | RW   | 0          |
| 0    | AUTOIDLE   | Internal clock gating strategy (interconnectL4 and display controller clock)<br>0: Interconnect L4 clock and display controller clock are free-running.<br>1: Automatic clock gating strategy is applied for the interconnect L4 clock and display controller clock, based on the interconnect interface and internal activity. | RW   | 1          |

**Table 7-249. Register Call Summary for Register RFBI\_SYSCONFIG**

- ## Display Subsystem Integration

- Software Reset: [0]
  - Autoidle Mode: [1]
  - Idle Mode: [2] [3] [4]

- ## Display Subsystem Basic Programming Model

- RFBI Configuration: [5]

- ## Display Subsystem Use Cases and Tips

- Autoidle: [6]
  - Smart-Idle: [7]

- Display Subsystem Register Manual

- RFBI Register Mapping Summary: [8]

**Table 7-250. RFBI\_SYSSTATUS**

|                         |                                                                                                         |                         |                 |                 |              |
|-------------------------|---------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x14                                                                                                    | <b>Physical address</b> | 0x4805 0814     | <b>Instance</b> | RFBI         |
| <b>Description</b>      | This register provides status information about the module, excluding the interrupt status information. |                         |                 |                 |              |
| <b>Type</b>             | R                                                                                                       |                         |                 |                 |              |
| 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 |                 |              |
| RESERVED                |                                                                                                         |                         |                 |                 | RESETDONE    |
|                         |                                                                                                         |                         |                 |                 | BUSY         |
| RESERVED                |                                                                                                         |                         |                 |                 | BUSYRFBIDATA |

  

| Bits   | Field Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset    |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31: 10 | Reserved     | Reserved. Read returns 0                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R    | 0x000000 |
| 9      | BUSYRFBIDATA | Data are pending to be processed from interconnect FIFO.<br>Read 0x0: No data pending<br>Read 0x1: Some data are pending                                                                                                                                                                                                                                                                                                                                                     | R    | 0        |
| 8      | BUSY         | L4 Interface busy status bit<br>Read 0x0: The access to the following register is not stalled:<br><a href="#">RFBI_CMD</a> , <a href="#">RFBI_DATA</a> , <a href="#">RFBI_STATUS</a> , <a href="#">RFBI_PARAM</a> ,<br><a href="#">RFBI_READ</a> .<br>Read 0x1: The access to any of the following registers is stalled:<br><a href="#">RFBI_CMD</a> , <a href="#">RFBI_DATA</a> , <a href="#">RFBI_STATUS</a> , <a href="#">RFBI_PARAM</a> ,<br><a href="#">RFBI_READ</a> . | R    | 0        |
| 7:1    | Reserved     | Reserved. Read returns 0                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R    | 0x00     |
| 0      | RESETDONE    | Internal reset monitoring<br>0: Internal module reset is on-going<br>1: Reset completed                                                                                                                                                                                                                                                                                                                                                                                      | R    | 1        |

**Table 7-251. Register Call Summary for Register RFBI\_SYSSTATUS**

- Display Subsystem Basic Programming Model
- [RFBI Configuration: \[0\]](#)
  - [RFBI State-Machine: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)

- Display Subsystem Register Manual
- [RFBI Register Mapping Summary: \[10\]](#)

**Table 7-252. RFBI\_CONTROL**

|                         |                                                               |                         |                 |                 |                 |
|-------------------------|---------------------------------------------------------------|-------------------------|-----------------|-----------------|-----------------|
| <b>Address Offset</b>   | 0x40                                                          | <b>Physical address</b> | 0x4805 0840     | <b>Instance</b> | RFBI            |
| <b>Description</b>      | The control register allows configuration of the RFBI module. |                         |                 |                 |                 |
| <b>Type</b>             | RW                                                            |                         |                 |                 |                 |
| 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 |                 |                 |
| RESERVED                |                                                               |                         |                 |                 | ENABLE          |
|                         |                                                               |                         |                 |                 | CONFIGSELECT    |
|                         |                                                               |                         |                 |                 | BYPASSMODE      |
|                         |                                                               |                         |                 |                 | ITE             |
|                         |                                                               |                         |                 |                 | HIGHTHRESHOLD   |
|                         |                                                               |                         |                 |                 | DISABLE_DMA_REQ |
|                         |                                                               |                         |                 |                 | SMART_DMA_REQ   |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset      |
|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31: 9 | Reserved        | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0x00000000 |
| 8     | SMART_DMA_REQ   | Smart DMA request<br><br>0x0: The dmareq is asserted and de-asserted depending on the interconnect FIFO space even if Mldlereq is high in smart idle/no-idle mode and the entire burst gets error responses from the module.<br><br>0x1: The dmareq is de-asserted after 2 clk cycles if it has been asserted for more than or equal to 2 clk cycles and Mldlereq is high in smart idle or no idle mode. No more burst requests will be given even if the space is available in the interconnect FIFO. | RW   | 0x0        |
| 7     | DISABLE_DMA_REQ | Disable DMA request<br><br>0x0: The dmareq is enabled and the signal is generated based on the space available and the request coming into the data register.<br><br>0x1: The dmareq is disabled and the signal is not generated at all based on space in the interconnect FIFO. It stays high until the DISABLE DMAREQ is high even if there is space in the interconnect FIFO to take requests.                                                                                                      | RW   | 0x0        |
| 6:5   | HIGHTHRESHOLD   | Defines the interconnect FIFO high threshold used by HW to assert DMA request. Used only if data written to RFBI_DATA are sent using system DMA.<br><br>0x0: Size of the transfer of 4 words of 32-bit wide<br>0x1: Size of the transfer of 8 words of 32-bit wide<br>0x2: Size of the transfer of 16 words of 32-bit wide                                                                                                                                                                             | RW   | 0x0        |
| 4     | ITE             | Internal Trigger<br>0: H/W waits for ITE bit to be set if in internal trigger mode for the configuration in use.<br>1: User sets the ITE bit to start the transfer, when H/W takes into account the bit, the H/W resets it.                                                                                                                                                                                                                                                                            | RW   | 0          |
| 3:2   | CONFIGSELECT    | Select the CS and configuration<br>00: No CS selected<br>01: CS0 selected and configuration #0<br>10: CS1 selected and configuration #1<br>11: CS0 and CS1 both selected (only the configuration for CS0 is used)                                                                                                                                                                                                                                                                                      | RW   | 0x0        |
| 1     | BYPASSMODE      | Bypass Mode<br>0: The bypass mode not selected<br>1: The bypass mode is selected                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 1          |
| 0     | ENABLE          | Enable/Disable flag<br>0: Disable the RFBI module<br>1: Enable the RFBI module                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0          |

**Table 7-253. Register Call Summary for Register RFBI\_CONTROL**

## Display Subsystem Environment

- Parallel Interface in RFBI Mode (MIPI DBI Protocol): [0] [1]

## Display Subsystem Basic Programming Model

- RFBI Control Registers: [2]
- High Threshold: [3] [4] [5]
- Bypass Mode: [6]
- Enable: [7] [8] [9]
- Configuration Selection: [10]
- ITE Bit: [11] [12] [13] [14] [15]
- Number of Pixels to Transfer: [16] [17]
- RFBI Configuration: [18]
- Trigger Mode: [19]
- RFBI Timings: [20]

## Display Subsystem Register Manual

- RFBI Register Mapping Summary: [21]

**Table 7-254. RFBI\_PIXEL\_CNT**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x44                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <a href="#">0x4805 0844</a>                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                             | The control register configures the RFBI pixel count value. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="36">PIXELCNT</td></tr> </table> |                                                             | 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 | PIXELCNT |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PIXELCNT                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                      | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | PIXELCNT   | Pixel counter value<br>The S/W indicates the number of pixels to transfer to the LCD panel frame buffer. The value is set when the module is disabled. During the transfer the HW decrements the register when a pixel has been sent to the RFB. | RW   | 0x00000000 |

**Table 7-255. Register Call Summary for Register RFBI\_PIXEL\_CNT**

Display Subsystem Basic Programming Model

- [RFBI Control Registers: \[0\]](#)
- [Enable: \[1\]](#)
- [Number of Pixels to Transfer: \[2\] \[3\] \[4\]](#)

Display Subsystem Register Manual

- [RFBI Register Mapping Summary: \[5\]](#)

**Table 7-256. RFBI\_LINE\_NUMBER**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|------------|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x48                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |  |  |  |  |  |  |  |
| <b>Physical address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | <a href="#">0x4805 0848</a>                                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | The control register configures the number of lines to synchronize the beginning of the transfer. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW                                                                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="16">Reserved</td><td colspan="8">LINENUMBER</td></tr> </table> |                                                                                                   | 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 | Reserved |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | LINENUMBER |  |  |  |  |  |  |  |
| 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 |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LINENUMBER |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                 | Type | Reset    |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:11 | Reserved   | Write 0s for future compatibility<br>Read returns 0                                                                                         | RW   | 0x000000 |
| 10:0  | LINENUMBER | Programmable line number<br>Line number from 0 to $2^{11}-1$ . Number of HSYNC after the VSYNC occurs before the beginning of the transfer. | RW   | 0x000    |

**Table 7-257. Register Call Summary for Register RFBI\_LINE\_NUMBER**

Display Subsystem Basic Programming Model

- [RFBI Control Registers: \[0\]](#)

Display Subsystem Register Manual

- [RFBI Register Mapping Summary: \[1\]](#)

**Table 7-258. RFBI\_CMD**

|                         |                                                  |
|-------------------------|--------------------------------------------------|
| <b>Address Offset</b>   | 0x4C                                             |
| <b>Physical address</b> | <a href="#">0x4805 084C</a>                      |
| <b>Description</b>      | The control register configures the RFBI command |
| <b>Type</b>             | W                                                |
| <b>Write Latency</b>    | 1                                                |

  

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                |                         |                       |                 |
| CMD                     |                         |                       |                 |

| Bits  | Field Name | Description                                                                                                                                                          | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility<br>Read returns 0                                                                                                                  | W    | 0x0000 |
| 15:0  | CMD        | Command Value<br>8/9/12/16 bit value depending on the parallel mode<br>[7:0] 8-bit DT<br>[8:0] 9-bit Data type<br>[11:0] 12-bit Data type<br>[15:0] 16-bit Data type | W    | 0x0000 |

**Table 7-259. Register Call Summary for Register RFBI\_CMD**

Display Subsystem Functional Description

- [Send Commands: \[0\]](#)

Display Subsystem Basic Programming Model

- [Number of Pixels to Transfer: \[1\] \[2\]](#)
- [RFBI State-Machine: \[3\] \[4\]](#)

Display Subsystem Register Manual

- [RFBI Register Mapping Summary: \[5\]](#)
- [RFBI Registers: \[6\] \[7\]](#)

**Table 7-260. RFBI\_PARAM**

|                         |                                                     |
|-------------------------|-----------------------------------------------------|
| <b>Address Offset</b>   | 0x50                                                |
| <b>Physical address</b> | <a href="#">0x4805 0850</a>                         |
| <b>Description</b>      | The control register configures the RFBI parameter. |
| <b>Type</b>             | W                                                   |

  

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                |                         |                       |                 |
| PARAM                   |                         |                       |                 |

| Bits  | Field Name | Description                                                                                                                                                               | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility<br>Read returns 0                                                                                                                       | W    | 0x0000 |
| 15:0  | PARAM      | Param Value<br>8/9/12/16 bit value depending on the parallel mode<br>[7:0] 8-bit Data type<br>[8:0] 9-bit Data type<br>[11:0] 12-bit Data type<br>[15:0] 16-bit Data type | W    | 0x0000 |

**Table 7-261. Register Call Summary for Register RFBI\_PARAM**

Display Subsystem Basic Programming Model

- [Number of Pixels to Transfer: \[0\] \[1\]](#)
- [RFBI State-Machine: \[2\] \[3\]](#)

**Table 7-261. Register Call Summary for Register RFBI\_PARAM (continued)**

Display Subsystem Register Manual

- RFBI Register Mapping Summary: [4]
- RFBI Registers: [5] [6]

**Table 7-262. RFBI\_DATA**

|                         |                                                |                         |                 |                 |      |
|-------------------------|------------------------------------------------|-------------------------|-----------------|-----------------|------|
| <b>Address Offset</b>   | 0x54                                           | <b>Physical address</b> | 0x4805 0854     | <b>Instance</b> | RFBI |
| <b>Description</b>      | The control register configures the RFBI data. |                         |                 |                 |      |
| <b>Type</b>             | W                                              |                         |                 |                 |      |
| 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 | DATA            |      |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                           | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | DATA              | Data value<br>12/16/18/24/2x16 bit value depending on the Data type<br>[11:0] 12-bit Data type<br>[15:0] 16-bit Data type<br>[17:0] 18-bit Data type<br>[23:0] 24-bit Data type<br>[31:0] 2x16-bit Data type | W           | 0x00000000   |

**Table 7-263. Register Call Summary for Register RFBI\_DATA**

Display Subsystem Overview

- [Display Subsystem Overview: \[0\]](#)

Display Subsystem Functional Description

- [RFBI Interconnect FIFO: \[1\] \[2\]](#)

Display Subsystem Basic Programming Model

- [High Threshold: \[3\] \[4\] \[5\]](#)
- [RFBI State-Machine: \[6\] \[7\] \[8\] \[9\] \[10\]](#)

Display Subsystem Register Manual

- [RFBI Register Mapping Summary: \[11\]](#)
- [RFBI Registers: \[12\] \[13\] \[14\]](#)

**Table 7-264. RFBI\_READ**

|                         |                                               |                         |                 |                 |      |
|-------------------------|-----------------------------------------------|-------------------------|-----------------|-----------------|------|
| <b>Address Offset</b>   | 0x58                                          | <b>Physical address</b> | 0x4805 0858     | <b>Instance</b> | RFBI |
| <b>Description</b>      | The control register configures the RFBI read |                         |                 |                 |      |
| <b>Type</b>             | RW                                            |                         |                 |                 |      |
| 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 | Reserved        |      |
|                         |                                               |                         |                 | READ            |      |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                              | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility<br>Read returns 0                                                                                                                      | RW   | 0x0000 |
| 15:0  | READ       | Read Value<br>8/9/12/16 bit value depending on the parallel mode<br>[7:0] 8-bit Data type<br>[8:0] 9-bit Data type<br>[11:0] 12-bit Data type<br>[15:0] 16-bit Data type | RW   | 0x0000 |

**Table 7-265. Register Call Summary for Register RFBI\_READ**

Display Subsystem Basic Programming Model

- Number of Pixels to Transfer: [0] [1]
- RFBI State-Machine: [2] [3]

Display Subsystem Register Manual

- RFBI Register Mapping Summary: [4]
- RFBI Registers: [5] [6]

**Table 7-266. RFBI\_STATUS**

|                |                                                  |                  |             |          |      |
|----------------|--------------------------------------------------|------------------|-------------|----------|------|
| Address Offset | 0x5C                                             | Physical address | 0x4805 085C | Instance | RFBI |
| Description    | The control register configures the RFBI status. |                  |             |          |      |
| Type           | RW                                               |                  |             |          |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | STATUS |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Write 0s for future compatibility<br>Read returns 0                                                                                                                        | RW   | 0x0000 |
| 15:0  | STATUS     | Status value<br>8/9/12/16 bit value depending on the parallel mode<br>[7:0] 8-bit Data type<br>[8:0] 9-bit Data type<br>[11:0] 12-bit Data type<br>[15:0] 16-bit Data type | RW   | 0x0000 |

**Table 7-267. Register Call Summary for Register RFBI\_STATUS**

Display Subsystem Basic Programming Model

- Number of Pixels to Transfer: [0] [1]
- RFBI State-Machine: [2] [3]

Display Subsystem Register Manual

- RFBI Register Mapping Summary: [4]
- RFBI Registers: [5] [6]

**Table 7-268. RFBI\_CONFIG**

|                         |                                                                  |                 |            |
|-------------------------|------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x60+ (i* 0x18)                                                  | <b>Index</b>    | i = 0 to 1 |
| <b>Physical address</b> | 0x4805 0860+ (i* 0x18)                                           | <b>Instance</b> | RFBI       |
| <b>Description</b>      | The control register allows configuration #I of the RFBI module. |                 |            |
| <b>Type</b>             | RW                                                               |                 |            |



| Bits  | Field Name        | Description                                                                                                                                                                                                                                                                 | Type | Reset |
|-------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:22 | Reserved          | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                                                                                         | RW   | 0x000 |
| 21    | HSYNCPOLARITY     | HSYNC polarity<br>0: HSYNC active low<br>1: HSYNC active high                                                                                                                                                                                                               | RW   | 1     |
| 20    | TE_VSYNC_POLARITY | TE or VSYNC Polarity<br>0: TE or VSYNC active low<br>1: TE or SYNC active high                                                                                                                                                                                              | RW   | 1     |
| 19    | CSPOLARITY        | CS Polarity<br>0: CS active low defined at reset time<br>1: CS active high defined at reset time                                                                                                                                                                            | RW   | 0     |
| 18    | WEPOLARITY        | WE Polarity<br>0: WE active low<br>1: WE active high                                                                                                                                                                                                                        | RW   | 0     |
| 17    | REPOLARITY        | RE Polarity<br>0: RE active low<br>1: RE active high                                                                                                                                                                                                                        | RW   | 0     |
| 16    | A0POLARITY        | A0 Polarity<br>0: A0 active low<br>1: A0 active high                                                                                                                                                                                                                        | RW   | 1     |
| 15:13 | Reserved          | Write 0s for future compatibility<br>Read returns 0                                                                                                                                                                                                                         | RW   | 0x0   |
| 12:11 | UNUSEDBITS        | State of unused bits<br>00: Low level (0)<br>01: High level (1)<br>10: Unchanged from previous state<br>11: Reserved                                                                                                                                                        | RW   | 0x0   |
| 10:9  | CYCLEFORMAT       | Cycle format<br>00: 1 cycle for 1 pixel<br>01: 2 cycles for 1 pixel<br>10: 3 cycles for 1 pixel<br>11: 3 cycles for 2 pixels                                                                                                                                                | RW   | 0x0   |
| 8:7   | L4FORMAT          | L4 Write Access format<br>00: 1 pixel per L4 access to the register data<br>01: Reserved<br>10: 2 pixels per L4 access to the register data with 1st pixel at the position [15:0]<br>11: 2 pixels per L4 access to the register data with 1st pixel at the position [31:16] | RW   | 0x0   |
| 6:5   | DATA TYPE         | Data type from the display controller and L4<br>00: 12-bit<br>01: 16-bit<br>10: 18-bit<br>11: 24-bit                                                                                                                                                                        | RW   | 0x0   |

| Bits | Field Name      | Description                                                                                                                                                                                                     | Type | Reset |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4    | TIMEGRANULARITY | Multiplies signal timing latencies by two<br>0: x2 latencies disabled<br>1: x2 latencies enabled                                                                                                                | RW   | 0     |
| 3:2  | TRIGGERMODE     | Trigger Mode<br>00: Internal trigger mode (ITE bit mode)<br>01: External trigger mode (TE signal)<br>10: External trigger mode (VSYNC/HSYNC signals)<br>11: Reserved                                            | RW   | 0x0   |
| 1:0  | PARALLELMODE    | Parallel Mode<br>00: 8-bit parallel output interface selected<br>01: 9-bit parallel output interface selected<br>10: 12-bit parallel output interface selected<br>11: 16-bit parallel output interface selected | RW   | 0x0   |

**Table 7-269. Register Call Summary for Register RFBI\_CONFIGi**

## Display Subsystem Environment

- Parallel Interface in RFBI Mode (MIPI DBI Protocol): [0]

## Display Subsystem Functional Description

- Output Parallel Modes: [1]
- Read/Write: [2] [3]

## Display Subsystem Basic Programming Model

- ITE Bit: [4] [5]
- Number of Pixels to Transfer: [6] [7] [8] [9] [10]
- Parallel Mode: [11]
- Cycle Format: [12]
- Unused Bits: [13]
- RFBI Timings: [14]
- RFBI State-Machine: [15] [16]
- RFBI Configuration Flow Charts: [17] [18] [19]

## Display Subsystem Register Manual

- RFBI Register Mapping Summary: [20]

**Table 7-270. RFBI\_ONOFF\_TIMEi**

| Address Offset   | 0x64+ (i* 0x18)                                               | Index    | i = 0 to 1 |
|------------------|---------------------------------------------------------------|----------|------------|
| Physical address | 0x4805 0864+ (i* 0x18)                                        | Instance | RFBI       |
| Description      | The control register allows configuration of the RFBI timing. |          |            |
| Type             | RW                                                            |          |            |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                    | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------|------|-------|
| 31:30 | Reserved   | Write 0s for future compatibility.<br>Read returns 0.                          | RW   | 0x0   |
| 29:24 | REOFFTIME  | Read Enable deassertion time from start access time<br>Number of L4Clk cycles  | RW   | 0x00  |
| 23:20 | REONTIME   | Read Enable assertion time from start access time<br>Number of L4Clk cycles    | RW   | 0x0   |
| 19:14 | WEOFFTIME  | Write Enable deassertion time from start access time<br>Number of L4Clk cycles | RW   | 0x00  |
| 13:10 | WEONTIME   | Write Enable assertion time from start access time<br>Number of L4Clk cycles   | RW   | 0x0   |

| Bits | Field Name | Description                                                          | Type | Reset |
|------|------------|----------------------------------------------------------------------|------|-------|
| 9:4  | CSOFFTIME  | CS deassertion time from start access time<br>Number of L4Clk cycles | RW   | 0x00  |
| 3:0  | CSONTIME   | CS assertion time from start access time<br>Number of L4Clk cycles   | RW   | 0x0   |

**Table 7-271. Register Call Summary for Register RFBI\_ONOFF\_TIMEi**

Display Subsystem Environment

- [Transaction Timing Diagrams: \[0\] \[1\] \[2\]](#)

Display Subsystem Basic Programming Model

- [RFBI Timings: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\]](#)

Display Subsystem Register Manual

- [RFBI Register Mapping Summary: \[18\]](#)

**Table 7-272. RFBI\_CYCLE\_TIMEi**

|                         |                                                               |                                     |                                      |
|-------------------------|---------------------------------------------------------------|-------------------------------------|--------------------------------------|
| <b>Address Offset</b>   | 0x68+ (i* 0x18)                                               | <b>Index</b>                        | i = 0 to 1                           |
| <b>Physical address</b> | 0x4805 0868+ (i* 0x18)                                        | <b>Instance</b>                     | RFBI                                 |
| <b>Description</b>      | The control register allows configuration of the RFBI timing. |                                     |                                      |
| <b>Type</b>             | RW                                                            |                                     |                                      |
| 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                      |
| Reserved                | ACCESSTIME                                                    | WRENABLE WWENABLE RRENABLE RWENABLE | CSPULSEWIDTH RECYCLETIME WECYCLETIME |

| Bits  | Field Name   | Description                                                                                                                                                | Type | Reset |
|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | Reserved     | Write 0s for future compatibility<br>Read returns 0                                                                                                        | RW   | 0x0   |
| 27:22 | ACCESSTIME   | Access Time<br>Number of L4Clk cycles                                                                                                                      | RW   | 0x00  |
| 21    | WRENABLE     | Write to Read Pulse Width Enable (same CS)<br>0: CSPulseWidth does not apply on Write to Read access<br>1: CSPulseWidth applies on Write to Read access    | RW   | 0     |
| 20    | WWENABLE     | Write to Write Pulse Width Enable (same CS)<br>0: CSPulseWidth does not apply on Write to Write access<br>1: CSPulseWidth applies on Write to Write access | RW   | 0     |
| 19    | RRENABLE     | Read to Read Pulse Width Enable (same CS)<br>0: CSPulseWidth does not apply on Read to Read access<br>1: CSPulseWidth applies on Read to Read access       | RW   | 0     |
| 18    | RWENABLE     | Read to Write Pulse Width Enable (same CS)<br>0: CSPulseWidth does not apply on Read to Write access<br>1: CSPulseWidth applies on Read to Write access    | RW   | 0     |
| 17:12 | CSPULSEWIDTH | CS Pulse Width<br>Number of L4Clk cycles                                                                                                                   | RW   | 0x00  |
| 11:6  | RECYCLETIME  | RE Cycle Time<br>Number of L4Clk cycles                                                                                                                    | RW   | 0x00  |
| 5:0   | WECYCLETIME  | WE Cycle Time<br>Number of L4Clk cycles                                                                                                                    | RW   | 0x00  |

**Table 7-273. Register Call Summary for Register RFBI\_CYCLE\_TIMEi**

Display Subsystem Environment

- [Transaction Timing Diagrams: \[0\] \[1\] \[2\]](#)

Display Subsystem Basic Programming Model

- [RFBI Timings: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\]](#)

Display Subsystem Register Manual

- [RFBI Register Mapping Summary: \[16\]](#)

**Table 7-274. RFBI\_DATA\_CYCLE1\_i**

|                         |                                                                     |                 |            |
|-------------------------|---------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x6C+ (i* 0x18)                                                     | <b>Index</b>    | i = 0 to 1 |
| <b>Physical address</b> | 0x4805 086C+ (i* 0x18)                                              | <b>Instance</b> | RFBI       |
| <b>Description</b>      | The control register configures the RFBI data format for 1st cycle. |                 |            |
| <b>Type</b>             | RW                                                                  |                 |            |

| 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 |
|----------|----|--------------------|----|----------|----|--------------|----|----------|----|----|----|----|----|----|----|--------------------|----|----------|----|--------------|----|---|---|---|---|---|---|---|---|---|---|
| Reserved |    | BITALIGNMENTPIXEL2 |    | Reserved |    | NBBITSPIXEL2 |    | Reserved |    |    |    |    |    |    |    | BITALIGNMENTPIXEL1 |    | Reserved |    | NBBITSPIXEL1 |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name         | Description                                                                                                           | Type | Reset |
|-------|--------------------|-----------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0   |
| 27:24 | BITALIGNMENTPIXEL2 | Bit alignment<br>Alignment of the bits from pixel#2 on the output interface                                           | RW   | 0x0   |
| 23:21 | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0   |
| 20:16 | NBBITSPIXEL2       | Number of bits<br>Number of bits from the pixel #2 (value from 0 to16 bits).<br>The values from 17 to 31 are invalid. | RW   | 0x00  |
| 15:12 | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0   |
| 11:8  | BITALIGNMENTPIXEL1 | Bit alignment<br>Alignment of the bits from pixel#1 on the output interface                                           | RW   | 0x0   |
| 7:5   | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0   |
| 4:0   | NBBITSPIXEL1       | Number of bits<br>Number of bits from the pixel #1 (value from 0 to16 bits).<br>The values from 17 to 31 are invalid. | RW   | 0x00  |

**Table 7-275. Register Call Summary for Register RFBI\_DATA\_CYCLE1\_i**

Display Subsystem Functional Description

- [Output Parallel Modes: \[0\]](#)

Display Subsystem Basic Programming Model

- [Cycle Format: \[1\] \[2\]](#)

Display Subsystem Register Manual

- [RFBI Register Mapping Summary: \[3\]](#)

**Table 7-276. RFBI DATA CYCLE2 i**

|                         |                                                                     |                 |            |
|-------------------------|---------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x70+ (i* 0x18)                                                     | <b>Index</b>    | i = 0 to 1 |
| <b>Physical address</b> | 0x4805 0870+ (i* 0x18)                                              | <b>Instance</b> | RFBI       |
| <b>Description</b>      | The control register configures the RFBI data format for 2nd cycle. |                 |            |
| <b>Type</b>             | RW                                                                  |                 |            |

| Bits  | Field Name         | Description                                                                                                           | Type | Reset |
|-------|--------------------|-----------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0   |
| 27:24 | BITALIGNMENTPIXEL2 | Bit alignment<br>Alignment of the bits from pixel#2 on the output interface                                           | RW   | 0x0   |
| 23:21 | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0   |
| 20:16 | NBBITSPIXEL2       | Number of bits<br>Number of bits from the pixel #2 (value from 0 to16 bits).<br>The values from 17 to 31 are invalid. | RW   | 0x00  |
| 15:12 | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0   |
| 11:8  | BITALIGNMENTPIXEL1 | Bit alignment<br>Alignment of the bits from pixel#1 on the output interface                                           | RW   | 0x0   |
| 7:5   | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0   |
| 4:0   | NBBITSPIXEL1       | Number of bits<br>Number of bits from the pixel #1 (value from 0 to16 bits).<br>The values from 17 to 31 are invalid. | RW   | 0x00  |

**Table 7-277. Register Call Summary for Register RFBI\_DATA\_CYCLE2\_i**

- ## Display Subsystem Functional Description

- Output Parallel Modes: [0]

- ## Display Subsystem Basic Programming Model

- Cycle Format: [1] [2]

- Display Subsystem Register Manual

- RFBI Register Mapping Summary: [3]

**Table 7-278. RFBI\_DATA\_CYCLE3\_i**

|                         |                                                                     |                 |            |
|-------------------------|---------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x74+ (i* 0x18)                                                     | <b>Index</b>    | i = 0 to 1 |
| <b>Physical address</b> | 0x4805 0874+ (i* 0x18)                                              | <b>Instance</b> | RFBI       |
| <b>Description</b>      | The control register configures the RFBI data format for 3rd cycle. |                 |            |
| <b>Type</b>             | RW                                                                  |                 |            |

| 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 |
|----------|----|----|----|----|----|----|----|----------|----|----|----|--------------|----|----|----|----------|----|----|----|----|----|---|---|--------------------|---|---|---|----------|---|--------------|---|
| Reserved |    |    |    |    |    |    |    | Reserved |    |    |    | NBBITSPIXEL2 |    |    |    | Reserved |    |    |    |    |    |   |   | BITALIGNMENTPIXEL1 |   |   |   | Reserved |   | NBBITSPIXEL1 |   |

| Bits  | Field Name         | Description                                                                                                           | Type | Reset |
|-------|--------------------|-----------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0   |
| 27:24 | BITALIGNMENTPIXEL2 | Bit alignment<br>Alignment of the bits from pixel#2 on the output interface                                           | RW   | 0x0   |
| 23:21 | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0   |
| 20:16 | NBBITSPIXEL2       | Number of bits<br>Number of bits from the pixel #2 (value from 0 to16 bits).<br>The values from 17 to 31 are invalid. | RW   | 0x00  |
| 15:12 | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0   |
| 11:8  | BITALIGNMENTPIXEL1 | Bit alignment<br>Alignment of the bits from pixel#1 on the output interface                                           | RW   | 0x0   |
| 7:5   | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                   | RW   | 0x0   |
| 4:0   | NBBITSPIXEL1       | Number of bits<br>Number of bits from the pixel #1 (value from 0 to16 bits).<br>The values from 17 to 31 are invalid. | RW   | 0x00  |

**Table 7-279. Register Call Summary for Register RFBI\_DATA\_CYCLE3\_i**

Display Subsystem Functional Description

- [Output Parallel Modes: \[0\]](#)

Display Subsystem Basic Programming Model

- [Cycle Format: \[1\]](#)

Display Subsystem Register Manual

- [RFBI Register Mapping Summary: \[2\]](#)

**Table 7-280. RFBI\_VSYNC\_WIDTH**

|                         |                                                                    |
|-------------------------|--------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x90                                                               |
| <b>Physical address</b> | <a href="#">0x4805 0890</a>                                        |
| <b>Instance</b>         | RFBI                                                               |
| <b>Description</b>      | The control register configures the RFBI VSYNC minimum pulse width |
| <b>Type</b>             | RW                                                                 |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16                                            |
| Reserved                | MINVSYNCPULSEWIDTH                                                 |

| Bits  | Field Name         | Description                                                                                                                                                                      | Type | Reset  |
|-------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved           | Write 0s for future compatibility<br>Read returns 0                                                                                                                              | RW   | 0x0000 |
| 15:0  | MINVSYNCPULSEWIDTH | Programmable min VSYNC pulse width<br>Minimum VSYNC pulse width from 0 to 65535. Number of L4 clock cycles to determine when VSYNC pulse occurs. The values 0 and 1 are invalid. | RW   | 0x0000 |

**Table 7-281. Register Call Summary for Register RFBI\_VSYNC\_WIDTH**

|                                                                            |  |
|----------------------------------------------------------------------------|--|
| Display Subsystem Environment                                              |  |
| • <a href="#">Parallel Interface in RFBI Mode (MIPI DBI Protocol): [0]</a> |  |
| Display Subsystem Basic Programming Model                                  |  |
| • <a href="#">RFBI Configuration: [1]</a>                                  |  |
| • <a href="#">VSYNC Pulse Width (Minimum Value): [2]</a>                   |  |
| Display Subsystem Register Manual                                          |  |
| • <a href="#">RFBI Register Mapping Summary: [3]</a>                       |  |

**Table 7-282. RFBI\_HSYNC\_WIDTH**

|                         |                                                                     |
|-------------------------|---------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x94                                                                |
| <b>Physical address</b> | <a href="#">0x4805 0894</a>                                         |
| <b>Instance</b>         | RFBI                                                                |
| <b>Description</b>      | The control register configures the RFBI HSYNC minimum pulse width. |
| <b>Type</b>             | RW                                                                  |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16                                             |
| Reserved                | MINHHSYNCPULSEWIDTH                                                 |

| Bits  | Field Name           | Description                                                                                                                                                                      | Type | Reset  |
|-------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved             | Write 0s for future compatibility<br>Read returns 0                                                                                                                              | RW   | 0x0000 |
| 15:0  | MINHHSYNC PULSEWIDTH | Programmable min HSYNC pulse width<br>Minimum HSYNC pulse width from 0 to 65535. Number of L4 clock cycles to determine when HSYNC pulse occurs. The values 0 and 1 are invalid. | RW   | 0x0000 |

**Table 7-283. Register Call Summary for Register RFBI\_HSYNC\_WIDTH**

|                                                                            |  |
|----------------------------------------------------------------------------|--|
| Display Subsystem Environment                                              |  |
| • <a href="#">Parallel Interface in RFBI Mode (MIPI DBI Protocol): [0]</a> |  |
| Display Subsystem Basic Programming Model                                  |  |
| • <a href="#">RFBI Configuration: [1]</a>                                  |  |
| • <a href="#">HSYNC Pulse Width (Minimum Value): [2]</a>                   |  |
| Display Subsystem Register Manual                                          |  |
| • <a href="#">RFBI Register Mapping Summary: [3]</a>                       |  |

### 7.7.2.4 Video Encoder Registers

**Table 7-284. VENC\_REV\_ID**

|                         |                             |                 |      |
|-------------------------|-----------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x00                        |                 |      |
| <b>Physical address</b> | 0x4805 0C00                 | <b>Instance</b> | VENC |
| <b>Description</b>      | Revision ID for the encoder |                 |      |
| <b>Type</b>             | R                           |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |        |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REV_ID |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                    | Type | Reset            |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------|------|------------------|
| 31:8 | Reserved   | Reserved. Read returns 0s.                                                                                                     | R    | 0x000000         |
| 7:0  | REV_ID     | This read-only register contains the revision ID for the encoder. The revision ID will identify different revisions of the IP. | R    | TI internal data |

**Table 7-285. Register Call Summary for Register VENC\_REV\_ID**

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[0\]](#)

**Table 7-286. VENC\_STATUS**

|                         |                             |                 |      |
|-------------------------|-----------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x04                        |                 |      |
| <b>Physical address</b> | 0x4805 0C04                 | <b>Instance</b> | VENC |
| <b>Description</b>      | <a href="#">VENC_STATUS</a> |                 |      |
| <b>Type</b>             | R                           |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |     |     |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|-----|-----|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CCE | CCO | FSQ |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:5 | Reserved   | Reserved. Read returns 0s.                                                                                                                                                                                                                 | R    | 0x00000000 |
| 4    | CCE        | Closed caption status for even Field.<br>This bit is set immediately after the data in registers LINE21_E0 and LINE21_E1 have been encoded to closed caption. This bit is reset when both of these registers are written.                  | R    | 0          |
| 3    | CCO        | Closed Caption Status for Odd Field.<br>This bit is set immediately after the data in registers LINE21_O0 and LINE21_O1 have been encoded to closed caption. This bit is reset when both of these registers are written.                   | R    | 0          |
| 2:0  | FSQ        | Field Sequence ID.<br>For PAL, all three FSQ[2:0] are used whereas for NTSC only FSQ[1:0] is meaningful. Furthermore, FSQ[0] represents odd field when it is 0 and even field when it is 1.<br>Read 0x0: Odd field<br>Read 0x1: Even field | R    | 0x0        |

**Table 7-287. Register Call Summary for Register VENC\_STATUS**

Display Subsystem Functional Description

- [Closed Caption Encoding: \[0\]](#) [\[1\]](#) [\[2\]](#) [\[3\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[4\]](#)
- [Video Encoder Registers: \[5\]](#)

**Table 7-288. VENC\_F\_CONTROL**

|                       |                                                           |                         |             |                 |      |
|-----------------------|-----------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x08                                                      | <b>Physical address</b> | 0x4805 0C08 | <b>Instance</b> | VENC |
| <b>Description</b>    | This register specifies the input video source and format |                         |             |                 |      |
| <b>Type</b>           | RW                                                        |                         |             |                 |      |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------|------|------|--------|-----|---|---|
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RESET | SVDS | RGBF | BCOLOR | FMT |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                            | Type | Reset    |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | Reserved   | Reserved. Read returns 0s.                                                                                                                                                                                                                                                                                                             | RW   | 0x000000 |
| 8    | RESET      | RESET the encoder<br><br>0x0: No effect<br><br>0x1: Reset the encoder, after reset, this bit is automatically set to zero.                                                                                                                                                                                                             | RW   | 0        |
| 7:6  | SVDS       | Select Video Data Source.<br><br>0x0: Use external video source<br>0x1: Use internal Color BAR<br>0x2: Use background color<br>0x3: Reserved                                                                                                                                                                                           | RW   | 0x2      |
| 5    | RGBF       | RGB/YCrCb input coding range<br><br>0x0: The input RGB data are in binary format with coding range 0-255<br>The input YCrCb data are in binary format with coding range 0-255<br><br>0x1: The input RGB data are in binary format with coding range 16-235<br>The input YCrCb data are in binary format conforming to ITU-601 standard | RW   | 0        |
| 4:2  | BCOLOR     | Background color select<br><br>0x0: black<br>0x1: blue<br>0x2: red<br>0x3: magenta<br>0x4: green<br>0x5: cyan<br>0x6: yellow<br>0x7: white                                                                                                                                                                                             | RW   | 0x1      |
| 1:0  | FMT        | These two bits specify the video input data stream format and timing<br><br>0x0: 24-bit 4:4:4 RGB<br>0x1: 24-bit 4:4:4<br>0x2: 16-bit 4:2:2<br>0x3: 8-bit ITU-R 656 4:2:2                                                                                                                                                              | RW   | 0x3      |

**Table 7-289. Register Call Summary for Register VENC\_F\_CONTROL**

Display Subsystem Functional Description

- [Test Pattern Generation: \[0\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Software Reset: \[1\]](#)
- [Video Encoder Programming Sequence: \[2\] \[3\]](#)
- [Video Encoder Register Settings: \[4\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[5\]](#)

**Table 7-290. VENC\_VIDOUT\_CTRL**

|                       |      |                         |             |                      |      |
|-----------------------|------|-------------------------|-------------|----------------------|------|
| <b>Address Offset</b> | 0x10 | <b>Physical address</b> | 0x4805 0C10 | <b>Instance</b>      | VENC |
| <b>Description</b>    |      |                         |             | Encoder output clock |      |
| <b>Type</b>           | RW   |                         |             |                      |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |       |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-------|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 27_54 |   |   |

| Bits | Field Name | Description                                                            | Type | Reset      |
|------|------------|------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Reserved. Read returns 0s.                                             | RW   | 0x00000000 |
| 0    | 27_54      | Encoder output clock                                                   | RW   | 0          |
|      |            | 0x0: 54 MHz, 4x oversampling                                           |      |            |
|      |            | 0x1: 27 MHz, 2x oversampling, the last 2x oversampling filter bypassed |      |            |

**Table 7-291. Register Call Summary for Register VENC\_VIDOUT\_CTRL**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)

**Table 7-292. VENC\_SYNC\_CTRL**

|                       |      |                         |             |                       |      |
|-----------------------|------|-------------------------|-------------|-----------------------|------|
| <b>Address Offset</b> | 0x14 | <b>Physical address</b> | 0x4805 0C14 | <b>Instance</b>       | VENC |
| <b>Description</b>    |      |                         |             | Sync Control Register |      |
| <b>Type</b>           | RW   |                         |             |                       |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |        |       |       |          |         |          |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|--------|-------|-------|----------|---------|----------|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FREE | ESAV | IGNP | NBLNKS | VBLKM | HBLKM | Reserved | FID_POL | Reserved |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                            | Type | Reset  |
|-------|------------|--------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Reserved. Read returns 0s.                             | RW   | 0x0000 |
| 15    | FREE       | Free running                                           | RW   | 1      |
|       |            | 0x0: Free running disabled                             |      |        |
|       |            | 0x1: Free running enabled. HSYNC and VSYNC are ignored |      |        |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 14          | ESAV              | Enable to detect F and V bits only on EAV in ITU-R 656 input mode<br><br>0x0: Detection of F and V bits on both EAV and SAV<br><br>0x1: Detection of F and V bits only on EAV                                                                                                                                                                                                                                                       | RW          | 0            |
| 13          | IGNP              | Ignore protection bits in ITU-R 656 input mode<br><br>0x0: Protection bits are not ignored<br><br>0x1: Protection bits are ignored                                                                                                                                                                                                                                                                                                  | RW          | 0            |
| 12          | NBLNKS            | Blank shaping<br><br>0x0: Blank shaping enabled<br><br>0x1: Blank shaping disabled                                                                                                                                                                                                                                                                                                                                                  | RW          | 0            |
| 11:10       | VBLKM             | Vertical blanking mode<br><br>0x0: Internal default blanking<br><br>0x1: Internal default blanking AND internal programmable blanking defined by <a href="#">VENC_FLEN_FAL</a> [24:16]FAL and <a href="#">VENC_LAL_PHASE_RESET</a> [8:0] LAL bit fields.<br>Note: in this mode, the <a href="#">VENC_LAL_PHASE_RESET</a> [16] SBLANK bit must be '0b1' to active the VBLKM functionality.<br><br>0x2: Reserved<br><br>0x3: Reserved | RW          | 0x0          |
| 9:8         | HBLKM             | Horizontal blanking mode<br><br>0x0: Internal default blanking<br><br>0x1: Internal programmable blanking defined by <a href="#">VENC_SAVID_EAVID</a> [26:16] SAVID and <a href="#">VENC_SAVID_EAVID</a> [10:0] EAVID bit fields.<br><br>0x2: External blanking defined by <a href="#">VENC_AVID_START_STOP_X</a> and <a href="#">VENC_AVID_START_STOP_Y</a> registers.<br><br>0x3: Reserved                                        | RW          | 0x0          |
| 7           | Reserved          | Reserved. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                           | RW          | 0            |
| 6           | FID_POL           | FID output polarity<br><br>0x0: Odd field = 0<br>Even field = 1<br><br>0x1: Odd field = 1<br>Even field = 0                                                                                                                                                                                                                                                                                                                         | RW          | 0            |
| 5:0         | Reserved          | Reserved. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                           | RW          | 0x00         |

**Table 7-293. Register Call Summary for Register VENC\_SYNC\_CTRL**

Display Subsystem Basic Programming Model

- [Video Encoder Programming Sequence: \[0\]](#)
- [Video Encoder Register Settings: \[1\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[2\]](#)
- [Video Encoder Registers: \[3\]](#)

**Table 7-294. VENC\_LLLEN**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |                 |      |    |    |    |    |          |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |          |  |  |  |      |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------|------|----|----|----|----|----------|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|----------|--|--|--|------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x1C        |                 |      |    |    |    |    |          |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |          |  |  |  |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x4805 0C1C | <b>Instance</b> | VENC |    |    |    |    |          |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |          |  |  |  |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | VENC_LLLEN  |                 |      |    |    |    |    |          |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |          |  |  |  |      |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW          |                 |      |    |    |    |    |          |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |          |  |  |  |      |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="8">Reserved</td><td colspan="4">Reserved</td><td colspan="12">LLEN</td></tr> </table> |             |                 |      | 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 | Reserved |  |  |  |  |  |  |  | Reserved |  |  |  | LLEN |  |  |  |  |  |  |  |  |  |  |  |
| 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 |   |   |   |   |          |  |  |  |  |  |  |  |          |  |  |  |      |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |             |                 |      |    |    |    |    | Reserved |    |    |    | LLEN |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |          |  |  |  |      |  |  |  |  |  |  |  |  |  |  |  |

**Table 7-295. Register Call Summary for Register VENC\_LLLEN**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)
- [Video Encoder Registers: \[2\] \[3\]](#)

**Table 7-296. VENC\_FLENS**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |                 |      |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------|------|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|--|--|--|--|-------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x20        |                 |      |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x4805 0C20 | <b>Instance</b> | VENC |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | VENC_FLENS  |                 |      |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW          |                 |      |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="12">Reserved</td><td colspan="12">FLENS</td></tr> </table> |             |                 |      | 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 | Reserved |  |  |  |  |  |  |  |  |  |  |  | FLENS |  |  |  |  |  |  |  |  |  |  |  |
| 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 |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |             |                 |      |    |    |    |    |    |    |    |    | FLENS |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |

**Table 7-297. Register Call Summary for Register VENC\_FLENS**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)
- [Video Encoder Registers: \[2\]](#)

**Table 7-298. VENC\_HFLTR\_CTRL**

|                         |                         |                       |                 |             |
|-------------------------|-------------------------|-----------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x24                    |                       |                 |             |
| <b>Physical address</b> | 0x4805 0C24             | <b>Instance</b>       | VENC            |             |
| <b>Description</b>      | VENC_HFLTR_CTRL         |                       |                 |             |
| <b>Type</b>             | RW                      |                       |                 |             |
| 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 |             |
|                         |                         |                       | Reserved        | CINTP YINTP |

| Bits | Field Name | Description                                                            | Type | Reset      |
|------|------------|------------------------------------------------------------------------|------|------------|
| 31:3 | Reserved   | Reserved. Read returns 0s.                                             | RW   | 0x00000000 |
| 2:1  | CINTP      | Chrominance interpolation filter control                               | RW   | 0x0        |
|      | 0x0:       | The chrominance interpolation filter is enabled                        |      |            |
|      | 0x1:       | The first section of the chrominance interpolation filter is bypassed  |      |            |
|      | 0x2:       | The second section of the chrominance interpolation filter is bypassed |      |            |
|      | 0x3:       | Both sections of the filter are bypassed                               |      |            |
| 0    | YINTP      | Luminance interpolation filter control                                 | RW   | 0          |
|      | 0x0:       | The luminance interpolation filter is enabled                          |      |            |
|      | 0x1:       | The luminance interpolation filter is bypassed                         |      |            |

**Table 7-299. Register Call Summary for Register VENC\_HFLTR\_CTRL**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)
- [Video Encoder Registers: \[2\]](#)

**Table 7-300. VENC\_CC\_CARR\_WSS\_CARR**

|                         |                         |                       |                 |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|
| <b>Address Offset</b>   | 0x28                    |                       |                 |  |
| <b>Physical address</b> | 0x4805 0C28             | <b>Instance</b>       | VENC            |  |
| <b>Description</b>      | Frequency code control  |                       |                 |  |
| <b>Type</b>             | RW                      |                       |                 |  |
| 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 |  |
|                         | FWSS                    |                       | FCC             |  |

| Bits  | Field Name | Description                                                                                                                                                                    | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | FWSS       | Wide screen signaling run-in code frequency control<br>For common values for FWSS[15:0] bit field, refer to <a href="#">Table 7-46</a><br>Reset value is for NTSC-601 standard | RW   | 0x043F |
| 15:0  | FCC        | Close caption run-in code frequency control<br>For common values for FCC[15:0] bit field refer to <a href="#">Table 7-44</a> . Reset value is for NTSC-601 standard            | RW   | 0x2631 |

**Table 7-301. Register Call Summary for Register VENC\_CC\_CARR\_WSS\_CARR**

Display Subsystem Functional Description

- [Closed Caption Encoding: \[0\] \[1\] \[2\]](#)
- [Wide-Screen Signaling \(WSS\) Encoding: \[3\] \[4\]](#)

**Table 7-301. Register Call Summary for Register VENC\_CC\_CARR\_WSS\_CARR (continued)**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[5\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[6\]](#)

**Table 7-302. VENC\_C\_PHASE**

|                         |                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x2C                    |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x4805 0C2C             |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VENC_C_PHASE            |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | CPHS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                |                         |                       |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                                         | Type | Reset    |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved   | Reserved. Read returns 0.                                                                                                           | RW   | 0x000000 |
| 7:0  | CPHS       | Phase of the encoded video color subcarrier (including the color burst) relative to H-sync. The adjustable step is 360/256 degrees. | RW   | 0x00     |

**Table 7-303. Register Call Summary for Register VENC\_C\_PHASE**

Display Subsystem Functional Description

- [Subcarrier and Burst Generation: \[0\] \[1\] \[2\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[3\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[4\]](#)
- [Video Encoder Registers: \[5\]](#)

**Table 7-304. VENC\_GAIN\_U**

|                         |                            |                       |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------|-----------------------|-----------------|----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x30                       |                       |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x4805 0C30                |                       |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Gain control for Cb signal |                       |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                         |                       |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | GU |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                |                            |                       |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                        | Type | Reset    |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | Reserved   | Reserved. Read returns 0s.                                                                                                                                                                                                                                                                         | RW   | 0x000000 |
| 8:0  | GU         | Gain control for Cb signal. Following are typical programming examples for NTSC and PAL standards.<br><br>NTSC with 7.5 IRE pedestal: WHITE - BLACK = 92.5 IRE GU = 0x102<br>NTSC with no pedestal: WHITE - BLACK = 100 IRE GU = 0x117<br>PAL with no pedestal: WHITE - BLACK = 100 IRE GU = 0x111 | RW   | 0x102    |

**Table 7-305. Register Call Summary for Register VENC\_GAIN\_U**

Display Subsystem Functional Description

- [Chroma Stage: \[0\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[1\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[2\]](#)

**Table 7-306. VENC\_GAIN\_V**

|                         |                           |                 |      |
|-------------------------|---------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x34                      |                 |      |
| <b>Physical address</b> | 0x4805 0C34               | <b>Instance</b> | VENC |
| <b>Description</b>      | Gain control of Cr signal |                 |      |
| <b>Type</b>             | RW                        |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                   | Type | Reset    |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | Reserved   | Reserved. Read returns 0s.                                                                                                                                                                                                                                                                    | RW   | 0x000000 |
| 8:0  | GV         | Gain control of Cr signal. Following are typical programming examples for NTSC and PAL standards.<br>NTSC with 7.5 IRE pedestal: WHITE - BLACK = 92.5 IRE GV = 0x16C<br>NTSC with no pedestal: WHITE - BLACK = 100 IRE GV = 0x189<br>PAL with no pedestal: WHITE - BLACK = 100 IRE GV = 0x181 | RW   | 0x16C    |

**Table 7-307. Register Call Summary for Register VENC\_GAIN\_V**

Display Subsystem Functional Description

- [Chroma Stage: \[0\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[1\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[2\]](#)

**Table 7-308. VENC\_GAIN\_Y**

|                         |                          |                 |      |
|-------------------------|--------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x38                     |                 |      |
| <b>Physical address</b> | 0x4805 0C38              | <b>Instance</b> | VENC |
| <b>Description</b>      | Gain control of Y signal |                 |      |
| <b>Type</b>             | RW                       |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                              | Type | Reset    |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | Reserved   | Reserved. Read returns 0s.                                                                                                                                                                                                                                                               | RW   | 0x000000 |
| 8:0  | GY         | Gain control of Y signal. Following are typical programming examples for NTSC/PAL standards.<br>NTSC with 7.5 IRE pedestal: WHITE - BLACK = 92.5 IRE GY = 0x12F<br>NTSC with no pedestal: WHITE - BLACK = 100 IRE GY = 0x147<br>PAL with no pedestal: WHITE - BLACK = 100 IRE GY = 0x140 | RW   | 0x12F    |

**Table 7-309. Register Call Summary for Register VENC\_GAIN\_Y**

Display Subsystem Functional Description

- [Luma Stage: \[0\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[1\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[2\]](#)

**Table 7-310. VENC\_BLACK\_LEVEL**

|                       |      |                         |                           |                 |      |
|-----------------------|------|-------------------------|---------------------------|-----------------|------|
| <b>Address Offset</b> | 0x3C | <b>Physical address</b> | 0x4805 0C3C               | <b>Instance</b> | VENC |
| <b>Description</b>    |      |                         | Video Encoder BLACK LEVEL |                 |      |
| <b>Type</b>           | RW   |                         |                           |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |       |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-------|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | BLACK |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                 | Type | Reset     |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:7 | Reserved   | Reserved. Read returns 0.                                                                                                                                                                                                                                                                                   | RW   | 0x0000000 |
| 6:0  | BLACK      | Black level setting. Following are typical programming examples for NTSC/PAL standards.<br>NTSC with 7.5 IRE pedestal: WHITE - BLACK = 92.5 IRE BLACK_LEVEL = 0x43<br>NTSC with no pedestal: WHITE - BLACK = 100 IRE BLACK_LEVEL = 0x38<br>PAL with no pedestal: WHITE - BLACK = 100 IRE BLACK_LEVEL = 0x3B | RW   | 0x43      |

**Table 7-311. Register Call Summary for Register VENC\_BLACK\_LEVEL**

Display Subsystem Functional Description

- [Luma Stage: \[0\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[1\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[2\]](#)

**Table 7-312. VENC\_BLANK\_LEVEL**

|                       |      |                         |                           |                 |      |
|-----------------------|------|-------------------------|---------------------------|-----------------|------|
| <b>Address Offset</b> | 0x40 | <b>Physical address</b> | 0x4805 0C40               | <b>Instance</b> | VENC |
| <b>Description</b>    |      |                         | Video Encoder BLANK LEVEL |                 |      |
| <b>Type</b>           | RW   |                         |                           |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |       |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-------|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | BLANK |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                 | Type | Reset     |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:7 | Reserved   | Reserved. Read returns 0s.                                                                                                                                                                                                                                                                                  | RW   | 0x0000000 |
| 6:0  | BLANK      | Blank level setting. Following are typical programming examples for NTSC/PAL standards.<br>NTSC with 7.5 IRE pedestal: WHITE - BLACK = 92.5 IRE BLANK_LEVEL = 0x38<br>NTSC with no pedestal: WHITE - BLACK = 100 IRE BLANK_LEVEL = 0x38<br>PAL with no pedestal: WHITE - BLACK = 100 IRE BLANK_LEVEL = 0x3B | RW   | 0x38      |

**Table 7-313. Register Call Summary for Register VENC\_BLANK\_LEVEL**

Display Subsystem Functional Description

- Luma Stage: [0]

Display Subsystem Basic Programming Model

- Video Encoder Register Settings: [1]

Display Subsystem Register Manual

- Video Encoder Register Mapping Summary: [2]

**Table 7-314. VENC\_X\_COLOR**

|                       |      |                              |             |                 |      |
|-----------------------|------|------------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x44 | <b>Physical address</b>      | 0x4805 0C44 | <b>Instance</b> | VENC |
| <b>Description</b>    |      | Cross-Color Control Register |             |                 |      |
| <b>Type</b>           | RW   |                              |             |                 |      |



| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                | Type | Reset     |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:7 | Reserved   | Reserved. Read returns 0s.                                                                                                                                                                                                                                                                                                                                 | RW   | 0x0000000 |
| 6    | XCE        | Cross color reduction enable for composite video output. Cross color does not affect S-video output<br><br>0x0: Cross color reduction is disabled<br>0x1: Cross color is enabled                                                                                                                                                                           | RW   | 0         |
| 5    | Reserved   | Reserved. Read returns 0.                                                                                                                                                                                                                                                                                                                                  | RW   | 0         |
| 4:3  | XCBW       | Cross color reduction filter selection<br><br>0x0: The notch is at 32.8 % of the frequency of the encoding pixel clock<br>0x1: The notch is at 26.5 % of the frequency of the encoding pixel clock<br>0x2: The notch is at 30.0 % of the frequency of the encoding pixel clock<br>0x3: The notch is at 29.2 % of the frequency of the encoding pixel clock | RW   | 0x0       |
| 2:0  | LCD        | These three bits can be used for chroma channel delay compensation.<br>Delay on Luma channel.<br><br>0x0: 0<br>0x1: 0.5 pixel clock period<br>0x2: 1.0 pixel clock period<br>0x3: 1.5 pixel clock period<br>0x4: -2.0 pixel clock period<br>0x5: -1.5 pixel clock period<br>0x6: -1.0 pixel clock period<br>0x7: -0.5 pixel clock period                   | RW   | 0x0       |

**Table 7-315. Register Call Summary for Register VENC\_X\_COLOR**

Display Subsystem Basic Programming Model

- Video Encoder Register Settings: [0]

Display Subsystem Register Manual

- Video Encoder Register Mapping Summary: [1]

**Table 7-316. VENC\_M\_CONTROL**

|                         |                                |                         |                 |                                              |      |  |  |
|-------------------------|--------------------------------|-------------------------|-----------------|----------------------------------------------|------|--|--|
| <b>Address Offset</b>   | 0x48                           | <b>Physical address</b> | 0x4805 0C48     | <b>Instance</b>                              | VENC |  |  |
| <b>Description</b>      | <a href="#">VENC_M_CONTROL</a> |                         |                 |                                              |      |  |  |
| <b>Type</b>             | RW                             |                         |                 |                                              |      |  |  |
| 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 | PALI<br>PALN<br>PALPHS<br>CBW<br>PAL<br>FFRQ |      |  |  |
| Reserved                |                                |                         |                 |                                              |      |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:8        | Reserved          | Reserved. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW          | 0x0000000    |
| 7           | PALI              | PAL I enable<br><br>0x0: Normal operation<br>0x1: PAL I enable                                                                                                                                                                                                                                                                                                                                                                                                                  | RW          | 0            |
| 6           | PALN              | PAL N enable<br><br>0x0: Normal operation<br>0x1: PAL N enable                                                                                                                                                                                                                                                                                                                                                                                                                  | RW          | 0            |
| 5           | PALPHS            | PAL switch phase setting<br><br>0x0: PAL switch phase is nominal<br>0x1: PAL switch phase is inverted compared to nominal                                                                                                                                                                                                                                                                                                                                                       | RW          | 0            |
| 4:2         | CBW               | Chrominance lowpass filter bandwidth control<br><br>0x0: -6db at 21.8 % of encoding pixel clock frequency<br>0x1: -6db at 19.8 % of encoding pixel clock frequency<br>0x2: -6db at 18.0 % of encoding pixel clock frequency<br>0x3: Reserved<br>0x4: Reserved<br>0x5: -6db at 23.7 % of encoding pixel clock frequency<br>0x6: -6db at 26.8 % of encoding pixel clock frequency<br>0x7: Chrominance lowpass filter bypass                                                       | RW          | 0x0          |
| 1           | PAL               | Phase alternation line encoding selection<br><br>0x0: Phase alternation line encoding disabled<br>0x1: Phase alternation line encoding enabled                                                                                                                                                                                                                                                                                                                                  | RW          | 0            |
| 0           | FFRQ              | The value of this field and the SQP bit in the <a href="#">VENC_BSTAMP_WSS_DATA</a> [7] SQP bit control the number of horizontal pixels displayed per scan line<br><br>Mode: Configuration:<br>ITU-R 601 NTSC SQP = 0, FFRQ = 1, Number of pixels by line = 858<br>Square pixel NTSC SQP = 1, FFRQ = 1, Number of pixels by line = 780<br>ITU-R 601 PAL SQP = 0, FFRQ = 0, Number of pixels by line = 864<br>Square pixel PAL SQP = 1, FFRQ = 0, Number of pixels by line = 944 | RW          | 1            |

**Table 7-317. Register Call Summary for Register VENC\_M\_CONTROL**

Display Subsystem Functional Description

- [Subcarrier and Burst Generation: \[0\]](#) [\[1\]](#) [\[2\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[3\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[4\]](#)
- [Video Encoder Registers: \[5\]](#) [\[6\]](#)

**Table 7-318. VENC\_BSTAMP\_WSS\_DATA**

| <b>Address Offset</b>   | 0x4C                     |                                                                                                                                                                                                                                                                                                 |                 |  |  |  |  |  |  |  |  |  |  |             |       |      |         |
|-------------------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|-------------|-------|------|---------|
| <b>Physical address</b> | 0x4805 0C4C              |                                                                                                                                                                                                                                                                                                 |                 |  |  |  |  |  |  |  |  |  |  |             |       |      |         |
| <b>Description</b>      | VENC BSTAMP and WSS_DATA |                                                                                                                                                                                                                                                                                                 |                 |  |  |  |  |  |  |  |  |  |  |             |       |      |         |
| <b>Type</b>             | RW                       |                                                                                                                                                                                                                                                                                                 |                 |  |  |  |  |  |  |  |  |  |  |             |       |      |         |
| 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 |  |  |  |  |  |  |  |  |  |  |             |       |      |         |
| Reserved                | WSS_DATA                 |                                                                                                                                                                                                                                                                                                 |                 |  |  |  |  |  |  |  |  |  |  |             |       |      |         |
|                         |                          |                                                                                                                                                                                                                                                                                                 |                 |  |  |  |  |  |  |  |  |  |  | P<br>Q<br>S |       |      |         |
|                         |                          |                                                                                                                                                                                                                                                                                                 |                 |  |  |  |  |  |  |  |  |  |  |             | BSTAP |      |         |
| Bits                    | Field Name               | Description                                                                                                                                                                                                                                                                                     |                 |  |  |  |  |  |  |  |  |  |  |             |       | Type | Reset   |
| 31:28                   | Reserved                 | Reserved. Read returns 0s.                                                                                                                                                                                                                                                                      |                 |  |  |  |  |  |  |  |  |  |  |             |       | RW   | 0x0     |
| 27:8                    | WSS_DATA                 | WSS data [19:0]: Wide Screen Signaling data<br><br>NTSC: WORD 0      WSS_D1, WSS_D0<br>WORD 1      WSS_D5, WSS_D4, WSS_D3, WSS_D2<br>WORD 2      WSS_D13, WSS_D12, WSS_D11, WSS_D10,<br>WSS_D9, WSS_D8, WSS_D7, WSS_D6<br>CRC           WSS_D19, WSS_D18, WSS_D17, WSS_D16,<br>WSS_D15, WSS_D14 |                 |  |  |  |  |  |  |  |  |  |  |             |       | RW   | 0x00000 |
|                         |                          | PAL:<br>GROUP A      WSS_D3, WSS_D2, WSS_D1, WSS_D0<br>GROUP B      WSS_D7, WSS_D6, WSS_D5, WSS_D4<br>GROUP C      WSS_D10, WSS_D9, WSS_D8<br>GROUP D      WSS_D13, WSS_D12, WSS_D11                                                                                                            |                 |  |  |  |  |  |  |  |  |  |  |             |       |      |         |
| 7                       | SQP                      | Square-pixel sampling rate. Please refer to <a href="#">VENC_M_CONTROL[0] FFRQ</a> bit description for programming information.<br><br>0x0: ITU-R 601 sampling rate<br>0x1: Square-pixel sampling rate                                                                                          |                 |  |  |  |  |  |  |  |  |  |  |             |       | RW   | 0       |
| 6:0                     | BSTAP                    | Setting of amplitude of color burst.                                                                                                                                                                                                                                                            |                 |  |  |  |  |  |  |  |  |  |  |             |       | RW   | 0x38    |

**Table 7-319. Register Call Summary for Register VENC\_BSTAMP\_WSS\_DATA**

Display Subsystem Functional Description

- [Subcarrier and Burst Generation: \[0\]](#)
- [Wide-Screen Signaling \(WSS\) Encoding: \[1\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[2\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[3\]](#)
- [Video Encoder Registers: \[4\]](#)

**Table 7-320. VENC\_S\_CARR**

|                         |                                       |                       |                 |  |  |  |  |  |  |  |  |  |  |  |     |  |
|-------------------------|---------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|-----|--|
| <b>Address Offset</b>   | 0x50                                  |                       |                 |  |  |  |  |  |  |  |  |  |  |  |     |  |
| <b>Physical address</b> | 0x4805 0C50                           |                       |                 |  |  |  |  |  |  |  |  |  |  |  |     |  |
| <b>Description</b>      | Color Subcarrier Frequency Registers. |                       |                 |  |  |  |  |  |  |  |  |  |  |  |     |  |
| <b>Type</b>             | RW                                    |                       |                 |  |  |  |  |  |  |  |  |  |  |  |     |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |     |  |
|                         |                                       |                       |                 |  |  |  |  |  |  |  |  |  |  |  | FSC |  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | FSC        | <p>These four bytes' data program the color subcarrier frequency and are determined by the following formula.</p> $S\_CARR = \text{ROUND}((Fsc/Fclkenc) * 2^{32})$ <p>Where: Fsc = Frequency of the subcarrier</p> <p>Fclkenc = Frequency of the internal video encoding clock = <math>2^{*LLEN} * Fh</math></p> <p>LLEN = Number of pixels in a scan line. For LLEN setting, please refer to the description of <a href="#">VENC_LLEN</a> register (offset 0x1C).</p> <p>Fh = Line frequency</p> <p>For typical setting of the FSC field, refer to <a href="#">Table 7-42</a>.</p> | RW   | 0x21F07C1F |

**Table 7-321. Register Call Summary for Register VENC\_S\_CARR**

Display Subsystem Functional Description

- [Subcarrier and Burst Generation: \[0\] \[1\] \[2\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[3\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[4\]](#)

**Table 7-322. VENC\_LINE21**

|                                                                                             |              |                         |             |                 |      |
|---------------------------------------------------------------------------------------------|--------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b>                                                                       | 0x54         | <b>Physical address</b> | 0x4805 0C54 | <b>Instance</b> | VENC |
| <b>Description</b>                                                                          | VENC LINE 21 |                         |             |                 |      |
| <b>Type</b>                                                                                 | RW           |                         |             |                 |      |
| 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 | L21E         |                         |             |                 | L21O |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                 | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | L21E       | <p>The two bytes of the closed-caption data in the even field. For a complete field description, refer to CEA-608-x standard. For data stream content, see <a href="#">Table 7-43, Closed-Caption Data Format</a>.</p> <p>[31:24] First byte of data</p> <p>[23:16] Second byte of data</p> | RW   | 0x0000 |
| 15:0  | L21O       | <p>The two bytes of the closed caption data in the odd field. For a complete field description, refer to CEA-608-x standard. For data stream content, see <a href="#">Table 7-43, Closed-Caption Data Format</a>.</p> <p>[15:8] First byte of data</p> <p>[7:0] Second byte of data</p>     | RW   | 0x0000 |

**Table 7-323. Register Call Summary for Register VENC\_LINE21**

Display Subsystem Functional Description

- [Closed Caption Encoding: \[0\] \[1\] \[2\] \[3\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[4\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[5\]](#)

**Table 7-324. VENC\_LN\_SEL**

| <b>Address Offset</b>   | 0x58                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |  |  |  |  |          |  |  |  |       |  |  |      |       |  |  |  |  |  |  |  |
|-------------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|----------|--|--|--|-------|--|--|------|-------|--|--|--|--|--|--|--|
| <b>Physical address</b> | 0x4805 0C58                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |  |  |  |  |          |  |  |  |       |  |  |      |       |  |  |  |  |  |  |  |
| <b>Description</b>      | <a href="#">VENC_LN_SEL</a> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |  |  |  |  |          |  |  |  |       |  |  |      |       |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |  |  |  |  |          |  |  |  |       |  |  |      |       |  |  |  |  |  |  |  |
| 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 |  |  |  |  |          |  |  |  |       |  |  |      |       |  |  |  |  |  |  |  |
| Reserved                | LN21_RUNIN                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |  |  |  |  | Reserved |  |  |  | SLINE |  |  |      |       |  |  |  |  |  |  |  |
| Bits                    | Field Name                  | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                 |  |  |  |  |          |  |  |  |       |  |  | Type | Reset |  |  |  |  |  |  |  |
| 31:26                   | Reserved                    | Reserved. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |  |  |  |  |          |  |  |  |       |  |  | RW   | 0x00  |  |  |  |  |  |  |  |
| 25:16                   | LN21_RUNIN                  | The two bytes of the closed caption run in code position from the HSYNC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 |  |  |  |  |          |  |  |  |       |  |  | RW   | 0x10B |  |  |  |  |  |  |  |
| 15:5                    | Reserved                    | Reserved. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |  |  |  |  |          |  |  |  |       |  |  | RW   | 0x000 |  |  |  |  |  |  |  |
| 4:0                     | SLINE                       | Selects the line where closed caption or extended service data are encoded. The value of the SLINE[4:0] bit field depends on the video standard:<br><br>PAL mode: Because there is a one-line offset, program the desired line number – 1.<br><br>To activate the closed caption on line 21 (0x15), program the value 0x15 – 1 = 0x14. The default value is 0x15 + 1 = 0x16 (line 22).<br><br>NTSC mode: Because there is a four-line offset, program the desired line number – 4.<br><br>To activate the closed caption on line 21 (0x15), program the value 0x15 – 4 = 0x11. The default value is 0x15 + 4 = 0x19 (line 25). |                 |  |  |  |  |          |  |  |  |       |  |  | RW   | 0x15  |  |  |  |  |  |  |  |

**Table 7-325. Register Call Summary for Register VENC\_LN\_SEL**

Display Subsystem Functional Description

- [Closed Caption Encoding: \[0\] \[1\] \[2\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[3\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[4\]](#)
- [Video Encoder Registers: \[5\]](#)

**Table 7-326. VENC\_L21\_WC\_CTL**

|                         |                           |                       |                 |  |  |  |  |     |             |      |          |  |  |  |       |
|-------------------------|---------------------------|-----------------------|-----------------|--|--|--|--|-----|-------------|------|----------|--|--|--|-------|
| <b>Address Offset</b>   | 0x5C                      |                       |                 |  |  |  |  |     |             |      |          |  |  |  |       |
| <b>Physical address</b> | 0x4805 0C5C               |                       |                 |  |  |  |  |     |             |      |          |  |  |  |       |
| <b>Description</b>      | VENC L21 WC_CTL registers |                       |                 |  |  |  |  |     |             |      |          |  |  |  |       |
| <b>Type</b>             | RW                        |                       |                 |  |  |  |  |     |             |      |          |  |  |  |       |
| 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 |  |  |  |  |     |             |      |          |  |  |  |       |
| Reserved                |                           |                       |                 |  |  |  |  | INV | EVEN_ODD_EN | LINE | Reserved |  |  |  | L21EN |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Type | Reset  |
|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved    | Reserved. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x0000 |
| 15    | INV         | WSS inverter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0      |
|       |             | 0x0: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |        |
|       |             | 0x1: Invert WSS data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |        |
| 14:13 | EVEN_ODD_EN | This bit controls the WSS encoding.<br>0x0: WSS encoding OFF<br>0x1: Enables encoding in 1 <sup>st</sup> field (odd field)<br>0x2: Enables encoding in 2 <sup>nd</sup> field (even field)<br>0x3: Enables encoding in both fields                                                                                                                                                                                                                                                                   | RW   | 0x0    |
| 12:8  | LINE        | Selects the line where WSS data are encoded. The LINE[12:8] bit field value depends on the video standard:<br>PAL mode: There is an one line offset, so program the wanted line number - 1. The recommended value is line 0x16 + 1 = 0x17 (23rd line). The default value is 0x14 + 1 = 0x15 (line 21).<br>NTSC mode: There is a four line offset, so program the wanted line number - 4. The recommended value is line 0x10 + 4 = 0x14 (20th line). The default value is 0x14 + 4 = 0x18 (line 24). | RW   | 0x14   |
| 7:2   | Reserved    | Reserved. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x00   |
| 1:0   | L21EN       | Those bits controls the Line21 closed caption encoding according to the mode.<br>0x0: Line21 encoding OFF<br>0x1: Enables encoding in 1st field (odd field)<br>0x2: Enables encoding in 2d field (even field)<br>0x3: Enables encoding in both fields                                                                                                                                                                                                                                               | RW   | 0x0    |

**Table 7-327. Register Call Summary for Register VENC\_L21\_WC\_CTL**

Display Subsystem Functional Description

- [Closed Caption Encoding: \[0\]](#) [\[1\]](#)
- [Wide-Screen Signaling \(WSS\) Encoding: \[2\]](#) [\[3\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[4\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[5\]](#)

**Table 7-328. VENC\_HTRIGGER\_VTRIGGER**

|                         |                            |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x60                       |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x4805 0C60                |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VENC HTRIGGER and VTRIGGER |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                | VTRIG                      | Reserved              | HTRIG           |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                          | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:26 | Reserved   | Reserved. Read returns 0s.                                                                                                                                           | RW   | 0x00  |
| 25:16 | VTRIG      | Vertical trigger reference for VSYNC. These bits specify the phase between VSYNC input and the lines in a field. The VTRIG field is expressed in units of half-line. | RW   | 0x000 |
| 15:11 | Reserved   | Reserved. Read returns 0s.                                                                                                                                           | RW   | 0x00  |
| 10:0  | HTRIG      | Horizontal trigger phase, which sets HSYNC. HTRIG is expressed in half-pixels or clk2x (27 MHz) periods                                                              | RW   | 0x000 |

**Table 7-329. Register Call Summary for Register VENC\_HTRIGGER\_Vtrigger**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)

**Table 7-330. VENC\_SAVID\_EAVID**

|                         |                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x64                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x4805 0C64          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VENC SAVID and EAVID |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | EAVID                   | Reserved              | SAVID           |

| Bits  | Field Name | Description                                                                                                                         | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | Reserved   | Reserved. Read returns 0s.                                                                                                          | RW   | 0x00  |
| 26:16 | EAVID      | End of active video. These bits define the ending pixel position on a horizontal display line where active video will be displayed. | RW   | 0x693 |
| 15:11 | Reserved   | Reserved. Read returns 0s.                                                                                                          | RW   | 0x00  |
| 10:0  | SAVID      | Start of active video. These bits define the starting pixel position on a horizontal line where active video will be displayed.     | RW   | 0x0F4 |

**Table 7-331. Register Call Summary for Register VENC\_SAVID\_EAVID**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)
- [Video Encoder Registers: \[2\] \[3\]](#)

**Table 7-332. VENC\_FLEN\_FAL**

|                         |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x68              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x4805 0C68       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VENC FLEN and FAL |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | FAL                     | Reserved              | FLEN            |

| Bits  | Field Name | Description                                                                                                        | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:25 | Reserved   | Reserved. Read returns 0s.                                                                                         | RW   | 0x00  |
| 24:16 | FAL        | First Active Line of Field. These bits define the first active line of a field                                     | RW   | 0x016 |
| 15:10 | Reserved   | Reserved. Read returns 0s.                                                                                         | RW   | 0x00  |
| 9:0   | FLEN       | Field length. These bits define the number of half_lines in each field.<br>Length of field = (FLEN + 1) half_lines | RW   | 0x20C |

**Table 7-333. Register Call Summary for Register VENC\_FLEN\_FAL**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)
- [Video Encoder Registers: \[2\]](#)

**Table 7-334. VENC\_LAL\_PHASE\_RESET**

|                       |      |                         |                          |                 |      |
|-----------------------|------|-------------------------|--------------------------|-----------------|------|
| <b>Address Offset</b> | 0x6C | <b>Physical address</b> | 0x4805 0C6C              | <b>Instance</b> | VENC |
| <b>Description</b>    |      |                         | VENC LAL and PHASE_RESET |                 |      |
| <b>Type</b>           | RW   |                         |                          |                 |      |

|          |    |    |    |    |    |    |    |      |        |          |    |    |    |    |    |    |    |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|------|--------|----------|----|----|----|----|----|----|----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    | PRES | SBLANK | Reserved |    |    |    |    |    |    |    | LAL |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                     | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:19 | Reserved   | Reserved. Read returns 0s.                                                                                                                                      | RW   | 0x0000 |
| 18:17 | PRES       | Phase reset mode.                                                                                                                                               | RW   | 0x3    |
|       | 0x0:       | No reset                                                                                                                                                        |      |        |
|       | 0x1:       | Reset every two lines                                                                                                                                           |      |        |
|       | 0x2:       | Reset every eight fields. Color subcarrier phase is reset to VENC_CPHASE[7:0] CPHS field value (offset 0x2C) upon reset                                         |      |        |
|       | 0x3:       | Reset every four fields. Color subcarrier phase is reset to VENC_CPHASE[7:0] CPHS bit field value (offset 0x2C) upon reset                                      |      |        |
| 16    | SBLANK     | Data output enable                                                                                                                                              | RW   | 0      |
|       | 0x0:       | No functionality                                                                                                                                                |      |        |
|       | 0x1:       | Enables the output of data when <a href="#">VENC_SYNC_CTRL[10]</a> VBLMK bit is '0b1'.                                                                          |      |        |
| 15:9  | Reserved   | Reserved. Read returns 0s.                                                                                                                                      | RW   | 0x00   |
| 8:0   | LAL        | Last Active Line of Field. These bits define the last active line of a field. The LAL[8:0] bit field value must be set to a value lower than the active window. | RW   | 0x107  |

**Table 7-335. Register Call Summary for Register VENC\_LAL\_PHASE\_RESET**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)
- [Video Encoder Registers: \[2\] \[3\]](#)

**Table 7-336. VENC\_HS\_INT\_START\_STOP\_X**

|                         |                                          |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x70                                     |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x4805 0C70                              |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | <a href="#">VENC_HS_INT_START_STOP_X</a> |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                       |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                | HS_INT_STOP_X                            | Reserved              | HS_INT_START_X  |  |  |  |  |  |  |  |  |  |  |  |

  

| Bits  | Field Name     | Description                                                               | Type | Reset |
|-------|----------------|---------------------------------------------------------------------------|------|-------|
| 31:26 | Reserved       | Reserved. Read returns 0s.                                                | RW   | 0x00  |
| 25:16 | HS_INT_STOP_X  | H SYNC internal stop. These bits define HSYNC internal stop pixel value   | RW   | 0x07E |
| 15:10 | Reserved       | Reserved. Read returns 0s.                                                | RW   | 0x00  |
| 9:0   | HS_INT_START_X | H SYNC internal start. These bits define HSYNC INTERNAL start pixel value | RW   | 0x34E |

**Table 7-337. Register Call Summary for Register VENC\_HS\_INT\_START\_STOP\_X**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)
- [Video Encoder Registers: \[2\]](#)

**Table 7-338. VENC\_HS\_EXT\_START\_STOP\_X**

|                         |                                          |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x74                                     |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x4805 0C74                              |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | <a href="#">VENC_HS_EXT_START_STOP_X</a> |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                       |                       |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                | HS_EXT_STOP_X                            | Reserved              | HS_EXT_START_X  |  |  |  |  |  |  |  |  |  |  |  |

  

| Bits  | Field Name     | Description                                                               | Type | Reset |
|-------|----------------|---------------------------------------------------------------------------|------|-------|
| 31:26 | Reserved       | Reserved. Read returns 0s.                                                | RW   | 0x00  |
| 25:16 | HS_EXT_STOP_X  | H SYNC external stop. These bits define HSYNC external stop pixel value   | RW   | 0x00F |
| 15:10 | Reserved       | Reserved. Read returns 0s.                                                | RW   | 0x00  |
| 9:0   | HS_EXT_START_X | H SYNC external start. These bits define HSYNC EXTERNAL start pixel value | RW   | 0x359 |

**Table 7-339. Register Call Summary for Register VENC\_HS\_EXT\_START\_STOP\_X**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)
- [Video Encoder Registers: \[2\]](#)

**Table 7-340. VENC\_VS\_INT\_START\_X**

| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x78                | <b>Physical address</b>                                                   | 0x4805 0C78 | <b>Instance</b> | VENC |    |    |    |    |    |    |    |    |    |    |          |    |    |    |      |        |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------------------------------------------------------------------|-------------|-----------------|------|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|------|--------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | VENC_VS_INT_START_X |                                                                           |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    |      |        |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW                  |                                                                           |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    |      |        |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 20%;">31</td><td style="width: 20%;">30</td><td style="width: 20%;">29</td><td style="width: 20%;">28</td><td style="width: 20%;">27</td><td style="width: 20%;">26</td><td style="width: 20%;">25</td><td style="width: 20%;">24</td><td style="width: 20%;">23</td><td style="width: 20%;">22</td><td style="width: 20%;">21</td><td style="width: 20%;">20</td><td style="width: 20%;">19</td><td style="width: 20%;">18</td><td style="width: 20%;">17</td><td style="width: 20%;">16</td><td style="width: 20%;">15</td><td style="width: 20%;">14</td><td style="width: 20%;">13</td><td style="width: 20%;">12</td><td style="width: 20%;">11</td><td style="width: 20%;">10</td><td style="width: 20%;">9</td><td style="width: 20%;">8</td><td style="width: 20%;">7</td><td style="width: 20%;">6</td><td style="width: 20%;">5</td><td style="width: 20%;">4</td><td style="width: 20%;">3</td><td style="width: 20%;">2</td><td style="width: 20%;">1</td><td style="width: 20%;">0</td></tr> <tr> <td>Reserved</td><td colspan="15">VS_INT_START_X</td><td colspan="8">Reserved</td></tr> </table> |                     |                                                                           |             |                 |      |    |    | 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 | Reserved | VS_INT_START_X |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Reserved |  |  |  |  |  |  |  |
| 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 |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | VS_INT_START_X      |                                                                           |             |                 |      |    |    |    |    |    |    |    |    |    |    | Reserved |    |    |    |      |        |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Field Name          | Description                                                               |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    | Type | Reset  |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 31:26                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Reserved            | Reserved. Read returns 0s.                                                |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    | RW   | 0x00   |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 25:16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | VS_INT_START_X      | VSYNC internal start. These bits define VSYNC internal start pixel value. |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    | RW   | 0x1A0  |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 15:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Reserved            | Reserved. Read returns 0s.                                                |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    | RW   | 0x0000 |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |

**Table 7-341. Register Call Summary for Register VENC\_VS\_INT\_START\_X**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)
- [Video Encoder Registers: \[2\]](#)

**Table 7-342. VENC\_VS\_INT\_STOP\_X\_VS\_INT\_START\_Y**

| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x7C                                  | <b>Physical address</b>                                                 | 0x4805 0C7C | <b>Instance</b> | VENC |    |    |    |    |    |    |    |    |    |    |          |    |    |    |      |       |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |               |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-------------------------------------------------------------------------|-------------|-----------------|------|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|------|-------|----|----|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|---------------|--|--|--|--|--|--|--|
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | VENC VS_INT_STOP_X and VS_INT_START_Y |                                                                         |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    |      |       |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |               |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RW                                    |                                                                         |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    |      |       |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |               |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 20%;">31</td><td style="width: 20%;">30</td><td style="width: 20%;">29</td><td style="width: 20%;">28</td><td style="width: 20%;">27</td><td style="width: 20%;">26</td><td style="width: 20%;">25</td><td style="width: 20%;">24</td><td style="width: 20%;">23</td><td style="width: 20%;">22</td><td style="width: 20%;">21</td><td style="width: 20%;">20</td><td style="width: 20%;">19</td><td style="width: 20%;">18</td><td style="width: 20%;">17</td><td style="width: 20%;">16</td><td style="width: 20%;">15</td><td style="width: 20%;">14</td><td style="width: 20%;">13</td><td style="width: 20%;">12</td><td style="width: 20%;">11</td><td style="width: 20%;">10</td><td style="width: 20%;">9</td><td style="width: 20%;">8</td><td style="width: 20%;">7</td><td style="width: 20%;">6</td><td style="width: 20%;">5</td><td style="width: 20%;">4</td><td style="width: 20%;">3</td><td style="width: 20%;">2</td><td style="width: 20%;">1</td><td style="width: 20%;">0</td></tr> <tr> <td>Reserved</td><td colspan="15">VS_INT_START_Y</td><td colspan="8">Reserved</td><td colspan="8">VS_INT_STOP_X</td></tr> </table> |                                       |                                                                         |             |                 |      |    |    | 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 | Reserved | VS_INT_START_Y |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Reserved |  |  |  |  |  |  |  | VS_INT_STOP_X |  |  |  |  |  |  |  |
| 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 |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |               |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | VS_INT_START_Y                        |                                                                         |             |                 |      |    |    |    |    |    |    |    |    |    |    | Reserved |    |    |    |      |       |    |    | VS_INT_STOP_X |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |               |  |  |  |  |  |  |  |
| Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Field Name                            | Description                                                             |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    | Type | Reset |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |               |  |  |  |  |  |  |  |
| 31:26                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reserved                              | Reserved. Read returns 0s.                                              |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    | RW   | 0x00  |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |               |  |  |  |  |  |  |  |
| 25:16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | VS_INT_START_Y                        | VSYNC internal start. These bits define VSYNC INTERNAL start line value |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    | RW   | 0x209 |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |               |  |  |  |  |  |  |  |
| 15:10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reserved                              | Reserved. Read returns 0s.                                              |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    | RW   | 0x00  |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |               |  |  |  |  |  |  |  |
| 9:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | VS_INT_STOP_X                         | VSYNC internal stop. These bits define VSYNC internal stop pixel value  |             |                 |      |    |    |    |    |    |    |    |    |    |    |          |    |    |    | RW   | 0x1A0 |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |               |  |  |  |  |  |  |  |

**Table 7-343. Register Call Summary for Register VENC\_VS\_INT\_STOP\_X\_VS\_INT\_START\_Y**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)

**Table 7-344. VENC\_VS\_INT\_STOP\_Y\_VS\_EXT\_START\_X**

| <b>Address Offset</b>   | 0x80                                  |                                                                           |                 |  |  |  |  |  |          |               |  |      |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------|---------------------------------------------------------------------------|-----------------|--|--|--|--|--|----------|---------------|--|------|--|--|--|-------------|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical address</b> | 0x4805 0C80                           | <b>Instance</b>                                                           |                 |  |  |  |  |  |          |               |  | VENC |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VENC VS_INT_STOP_Y and VS_EXT_START_X |                                                                           |                 |  |  |  |  |  |          |               |  |      |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                    |                                                                           |                 |  |  |  |  |  |          |               |  |      |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |          |               |  |      |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                | VS_EXT_START_X                        |                                                                           |                 |  |  |  |  |  | Reserved | VS_INT_STOP_Y |  |      |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                            | <b>Description</b>                                                        |                 |  |  |  |  |  |          |               |  |      |  |  |  | <b>Type</b> | <b>Reset</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:26                   | Reserved                              | Reserved. Read returns 0s.                                                |                 |  |  |  |  |  |          |               |  |      |  |  |  | RW          | 0x00         |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25:16                   | VS_EXT_START_X                        | VSYNC external start. These bits define VSYNC external start pixel value. |                 |  |  |  |  |  |          |               |  |      |  |  |  | RW          | 0x1AC        |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15:10                   | Reserved                              | Reserved. Read returns 0s.                                                |                 |  |  |  |  |  |          |               |  |      |  |  |  | RW          | 0x00         |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9:0                     | VS_INT_STOP_Y                         | VSYNC internal stop. These bits define VSYNC INTERNAL stop line value.    |                 |  |  |  |  |  |          |               |  |      |  |  |  | RW          | 0x022        |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 7-345. Register Call Summary for Register VENC\_VS\_INT\_STOP\_Y\_VS\_EXT\_START\_X**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)

**Table 7-346. VENC\_VS\_EXT\_STOP\_X\_VS\_EXT\_START\_Y**

| <b>Address Offset</b>   | 0x84                                  |                                                                          |                 |  |  |  |  |  |          |               |  |      |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------|--------------------------------------------------------------------------|-----------------|--|--|--|--|--|----------|---------------|--|------|--|--|--|-------------|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical address</b> | 0x4805 0C84                           | <b>Instance</b>                                                          |                 |  |  |  |  |  |          |               |  | VENC |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VENC VS_EXT_STOP_X and VS_EXT_START_Y |                                                                          |                 |  |  |  |  |  |          |               |  |      |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                    |                                                                          |                 |  |  |  |  |  |          |               |  |      |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |          |               |  |      |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                | VS_EXT_START_Y                        |                                                                          |                 |  |  |  |  |  | Reserved | VS_EXT_STOP_X |  |      |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                            | <b>Description</b>                                                       |                 |  |  |  |  |  |          |               |  |      |  |  |  | <b>Type</b> | <b>Reset</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:26                   | Reserved                              | Reserved. Read returns 0s.                                               |                 |  |  |  |  |  |          |               |  |      |  |  |  | RW          | 0x00         |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25:16                   | VS_EXT_START_Y                        | VSYNC external start. These bits define VSYNC EXTERNAL start line value. |                 |  |  |  |  |  |          |               |  |      |  |  |  | RW          | 0x20D        |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15:10                   | Reserved                              | Reserved. Read returns 0s.                                               |                 |  |  |  |  |  |          |               |  |      |  |  |  | RW          | 0x00         |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9:0                     | VS_EXT_STOP_X                         | VSYNC external stop. These bits define VSYNC EXTERNAL stop pixel value.  |                 |  |  |  |  |  |          |               |  |      |  |  |  | RW          | 0x1AC        |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 7-347. Register Call Summary for Register VENC\_VS\_EXT\_STOP\_X\_VS\_EXT\_START\_Y**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)

**Table 7-348. VENC\_VS\_EXT\_STOP\_Y**

| <b>Address Offset</b>   | 0x88                    | <b>Physical address</b>                                                | 0x4805 0C88     | <b>Instance</b> | VENC |  |  |      |          |
|-------------------------|-------------------------|------------------------------------------------------------------------|-----------------|-----------------|------|--|--|------|----------|
| <b>Description</b>      | VENC VS_EXT_STOP_Y      |                                                                        |                 |                 |      |  |  |      |          |
| <b>Type</b>             | RW                      |                                                                        |                 |                 |      |  |  |      |          |
| 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 | Reserved        |      |  |  |      |          |
| VS_EXT_STOP_Y           |                         |                                                                        |                 |                 |      |  |  |      |          |
| Bits                    | Field Name              | Description                                                            |                 |                 |      |  |  | Type | Reset    |
| 31:10                   | Reserved                | Reserved. Read returns 0s.                                             |                 |                 |      |  |  | RW   | 0x000000 |
| 9:0                     | VS_EXT_STOP_Y           | VSYNC external stop. These bits define VSYNC EXTERNAL stop line value. |                 |                 |      |  |  | RW   | 0x006    |

**Table 7-349. Register Call Summary for Register VENC\_VS\_EXT\_STOP\_Y**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)

**Table 7-350. VENC\_AVID\_START\_STOP\_X**

| <b>Address Offset</b>   | 0x90                    | <b>Physical address</b>                              | 0x4805 0C90     | <b>Instance</b> | VENC |  |  |      |       |
|-------------------------|-------------------------|------------------------------------------------------|-----------------|-----------------|------|--|--|------|-------|
| <b>Description</b>      | VENC_AVID_START_STOP_X  |                                                      |                 |                 |      |  |  |      |       |
| <b>Type</b>             | RW                      |                                                      |                 |                 |      |  |  |      |       |
| 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 | Reserved        |      |  |  |      |       |
| AVID_STOP_X             |                         |                                                      |                 |                 |      |  |  |      |       |
| Bits                    | Field Name              | Description                                          |                 |                 |      |  |  | Type | Reset |
| 31:26                   | Reserved                | Reserved. Read returns 0s.                           |                 |                 |      |  |  | RW   | 0x00  |
| 25:16                   | AVID_STOP_X             | AVID stop. These bits define AVID stop pixel value   |                 |                 |      |  |  | RW   | 0x348 |
| 15:10                   | Reserved                | Reserved. Read returns 0s.                           |                 |                 |      |  |  | RW   | 0x00  |
| 9:0                     | AVID_START_X            | AVID start. These bits define AVID start pixel value |                 |                 |      |  |  | RW   | 0x078 |

**Table 7-351. Register Call Summary for Register VENC\_AVID\_START\_STOP\_X**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)
- [Video Encoder Registers: \[2\] \[3\]](#)

**Table 7-352. VENC\_AVID\_START\_STOP\_Y**

|                       |                                        |                         |             |                 |      |
|-----------------------|----------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x94                                   | <b>Physical address</b> | 0x4805 0C94 | <b>Instance</b> | VENC |
| <b>Description</b>    | <a href="#">VENC_AVID_START_STOP_Y</a> |                         |             |                 |      |
| <b>Type</b>           | RW                                     |                         |             |                 |      |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | AVID_STOP_Y             | Reserved              | AVID_START_Y    |

| Bits  | Field Name   | Description                                         | Type | Reset |
|-------|--------------|-----------------------------------------------------|------|-------|
| 31:26 | Reserved     | Reserved. Read returns 0s.                          | RW   | 0x00  |
| 25:16 | AVID_STOP_Y  | AVID stop. These bits define AVID stop line value.  | RW   | 0x206 |
| 15:10 | Reserved     | Reserved. Read returns 0s.                          | RW   | 0x00  |
| 9:0   | AVID_START_Y | AVID start. These bits define AVID start line value | RW   | 0x026 |

**Table 7-353. Register Call Summary for Register VENC\_AVID\_START\_STOP\_Y**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)
- [Video Encoder Registers: \[2\] \[3\]](#)

**Table 7-354. VENC\_FID\_INT\_START\_X\_FID\_INT\_START\_Y**

|                       |                                          |                         |             |                 |      |
|-----------------------|------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0xA0                                     | <b>Physical address</b> | 0x4805 0CA0 | <b>Instance</b> | VENC |
| <b>Description</b>    | VENC_FID_INT_START_X and FID_INT_START_Y |                         |             |                 |      |
| <b>Type</b>           | RW                                       |                         |             |                 |      |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | FID_INT_START_Y         | Reserved              | FID_INT_START_X |

| Bits  | Field Name      | Description                                                          | Type | Reset |
|-------|-----------------|----------------------------------------------------------------------|------|-------|
| 31:26 | Reserved        | Reserved. Read returns 0s.                                           | RW   | 0x00  |
| 25:16 | FID_INT_START_Y | FID internal start. These bits define FID internal start line value  | RW   | 0x001 |
| 15:10 | Reserved        | Reserved. Read returns 0s.                                           | RW   | 0x00  |
| 9:0   | FID_INT_START_X | FID internal start. These bits define FID internal start pixel value | RW   | 0x08A |

**Table 7-355. Register Call Summary for Register VENC\_FID\_INT\_START\_X\_FID\_INT\_START\_Y**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)

**Table 7-356. VENC\_FID\_INT\_OFFSET\_Y\_FID\_EXT\_START\_X**

|                         |                                           |
|-------------------------|-------------------------------------------|
| <b>Address Offset</b>   | 0xA4                                      |
| <b>Physical address</b> | 0x4805 0CA4                               |
| <b>Instance</b>         | VENC                                      |
| <b>Description</b>      | VENC FID_INT_OFFSET_Y and FID_EXT_START_X |
| <b>Type</b>             | RW                                        |

|                         |                         |                       |                  |
|-------------------------|-------------------------|-----------------------|------------------|
| 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  |
| Reserved                | FID_EXT_START_X         | Reserved              | FID_INT_OFFSET_Y |

| Bits  | Field Name       | Description                                                           | Type | Reset |
|-------|------------------|-----------------------------------------------------------------------|------|-------|
| 31:26 | Reserved         | Reserved. Read returns 0s.                                            | RW   | 0x00  |
| 25:16 | FID_EXT_START_X  | FID external start. These bits define FID external start pixel value  | RW   | 0x1AC |
| 15:10 | Reserved         | Reserved. Read returns 0s.                                            | RW   | 0x00  |
| 9:0   | FID_INT_OFFSET_Y | FID internal offset. These bits define FID internal offset line value | RW   | 0x106 |

**Table 7-357. Register Call Summary for Register VENC\_FID\_INT\_OFFSET\_Y\_FID\_EXT\_START\_X**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)

**Table 7-358. VENC\_FID\_EXT\_START\_Y\_FID\_EXT\_OFFSET\_Y**

|                         |                                           |
|-------------------------|-------------------------------------------|
| <b>Address Offset</b>   | 0xA8                                      |
| <b>Physical address</b> | 0x4805 0CA8                               |
| <b>Instance</b>         | VENC                                      |
| <b>Description</b>      | VENC FID_EXT_START_Y and FID_EXT_OFFSET_Y |
| <b>Type</b>             | RW                                        |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | FID_EXT_OFFSET_Y        | Reserved              | FID_EXT_START_Y |

| Bits  | Field Name       | Description                                                           | Type | Reset |
|-------|------------------|-----------------------------------------------------------------------|------|-------|
| 31:26 | Reserved         | Reserved. Read returns 0s.                                            | RW   | 0x00  |
| 25:16 | FID_EXT_OFFSET_Y | FID external offset. These bits define FID external offset line value | RW   | 0x106 |
| 15:10 | Reserved         | Reserved. Read returns 0s.                                            | RW   | 0x00  |
| 9:0   | FID_EXT_START_Y  | FID external start. These bits define FID external start line value.  | RW   | 0x006 |

**Table 7-359. Register Call Summary for Register VENC\_FID\_EXT\_START\_Y\_FID\_EXT\_OFFSET\_Y**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[0\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[1\]](#)

**Table 7-360. VENC\_TVDETGP\_INT\_START\_STOP\_X**

| <b>Address Offset</b>   | 0xB0                                     |                                                                              |                 |  |  |  |  |  |          |                     |                 |  |  |  |  |      |       |  |  |  |  |  |
|-------------------------|------------------------------------------|------------------------------------------------------------------------------|-----------------|--|--|--|--|--|----------|---------------------|-----------------|--|--|--|--|------|-------|--|--|--|--|--|
| <b>Physical address</b> | 0x4805 0CB0                              |                                                                              |                 |  |  |  |  |  |          |                     | <b>Instance</b> |  |  |  |  |      |       |  |  |  |  |  |
| <b>Description</b>      | TV Detection Start and Stop pixel values |                                                                              |                 |  |  |  |  |  |          |                     |                 |  |  |  |  |      |       |  |  |  |  |  |
| <b>Type</b>             | RW                                       |                                                                              |                 |  |  |  |  |  |          |                     |                 |  |  |  |  |      |       |  |  |  |  |  |
| 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 |  |  |  |  |  |          |                     |                 |  |  |  |  |      |       |  |  |  |  |  |
| Reserved                | TVDETGP_INT_STOP_X                       |                                                                              |                 |  |  |  |  |  | Reserved | TVDETGP_INT_START_X |                 |  |  |  |  |      |       |  |  |  |  |  |
| Bits                    | Field Name                               | <b>Description</b>                                                           |                 |  |  |  |  |  |          |                     |                 |  |  |  |  | Type | Reset |  |  |  |  |  |
| 31:26                   | Reserved                                 | Reserved. Read returns 0s.                                                   |                 |  |  |  |  |  |          |                     |                 |  |  |  |  | RW   | 0x00  |  |  |  |  |  |
| 25:16                   | TVDETGP_INT_STOP_X                       | TVDETGP internal stop. These bits define TVDETGP internal stop pixel value.  |                 |  |  |  |  |  |          |                     |                 |  |  |  |  | RW   | 0x014 |  |  |  |  |  |
| 15:10                   | Reserved                                 | Reserved. Read returns 0s.                                                   |                 |  |  |  |  |  |          |                     |                 |  |  |  |  | RW   | 0x00  |  |  |  |  |  |
| 9:0                     | TVDETGP_INT_START_X                      | TVDETGP internal start. These bits define TVDETGP internal start pixel value |                 |  |  |  |  |  |          |                     |                 |  |  |  |  | RW   | 0x001 |  |  |  |  |  |

**Table 7-361. Register Call Summary for Register VENC\_TVDETGP\_INT\_START\_STOP\_X**

|                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Display Subsystem Functional Description                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| • <a href="#">TV Detection/Disconnection Pulse Generation: [0]</a>           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| • <a href="#">TV Detection Procedure: [1] [2] [3]</a>                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| • <a href="#">TV Disconnection Procedure: [4] [5] [6]</a>                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| • <a href="#">Recommended TV Detection/Disconnection Pulse Waveform: [7]</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Display Subsystem Basic Programming Model                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| • <a href="#">Video Encoder Register Settings: [8]</a>                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Display Subsystem Register Manual                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| • <a href="#">Video Encoder Register Mapping Summary: [9]</a>                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 7-362. VENC\_TVDETGP\_INT\_START\_STOP\_Y**

| <b>Address Offset</b>   | 0xB4                                    |                                                                              |                 |  |  |  |  |  |          |                     |                 |  |  |  |  |      |       |  |  |  |  |  |
|-------------------------|-----------------------------------------|------------------------------------------------------------------------------|-----------------|--|--|--|--|--|----------|---------------------|-----------------|--|--|--|--|------|-------|--|--|--|--|--|
| <b>Physical address</b> | 0x4805 0CB4                             |                                                                              |                 |  |  |  |  |  |          |                     | <b>Instance</b> |  |  |  |  |      |       |  |  |  |  |  |
| <b>Description</b>      | TV detection Start and Stop line values |                                                                              |                 |  |  |  |  |  |          |                     |                 |  |  |  |  |      |       |  |  |  |  |  |
| <b>Type</b>             | RW                                      |                                                                              |                 |  |  |  |  |  |          |                     |                 |  |  |  |  |      |       |  |  |  |  |  |
| 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 |  |  |  |  |  |          |                     |                 |  |  |  |  |      |       |  |  |  |  |  |
| Reserved                | TVDETGP_INT_STOP_Y                      |                                                                              |                 |  |  |  |  |  | Reserved | TVDETGP_INT_START_Y |                 |  |  |  |  |      |       |  |  |  |  |  |
| Bits                    | Field Name                              | <b>Description</b>                                                           |                 |  |  |  |  |  |          |                     |                 |  |  |  |  | Type | Reset |  |  |  |  |  |
| 31:26                   | Reserved                                | Reserved. Read returns 0s.                                                   |                 |  |  |  |  |  |          |                     |                 |  |  |  |  | RW   | 0x00  |  |  |  |  |  |
| 25:16                   | TVDETGP_INT_STOP_Y                      | TVDETGP internal stop. These bits define TVDETGP internal stop line value.   |                 |  |  |  |  |  |          |                     |                 |  |  |  |  | RW   | 0x001 |  |  |  |  |  |
| 15:10                   | Reserved                                | Reserved. Read returns 0s.                                                   |                 |  |  |  |  |  |          |                     |                 |  |  |  |  | RW   | 0x00  |  |  |  |  |  |
| 9:0                     | TVDETGP_INT_START_Y                     | TVDETGP internal start. These bits define TVDETGP internal start line value. |                 |  |  |  |  |  |          |                     |                 |  |  |  |  | RW   | 0x001 |  |  |  |  |  |

**Table 7-363. Register Call Summary for Register VENC\_TVDETGP\_INT\_START\_STOP\_Y**

|                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Display Subsystem Functional Description                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| • <a href="#">TV Detection/Disconnection Pulse Generation: [0]</a>           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| • <a href="#">TV Detection Procedure: [1] [2] [3]</a>                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| • <a href="#">TV Disconnection Procedure: [4] [5] [6]</a>                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| • <a href="#">Recommended TV Detection/Disconnection Pulse Waveform: [7]</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 7-363. Register Call Summary for Register VENC\_TVDETGP\_INT\_START\_STOP\_Y  
(continued)**

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[7\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[8\]](#)

**Table 7-364. VENC\_GEN\_CTRL**

|                         |                                                  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0xB8                                             |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x4805 0CB8                                      |  |  |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | TVDETGP enable and SYNC_POLARITY and UVPHASE_POL |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                               |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|----|-----|------|-----|-----|-----|-----|-------|-----|-----|------|----------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|----|---|---|---|
| Reserved | MS | 656 | CBAR | HIP | VIP | HEP | VEP | AVIDP | FIP | FEP | TVDP | Reserved |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | EN |   |   |   |

| Bits  | Field Name | Description                         | Type | Reset  |
|-------|------------|-------------------------------------|------|--------|
| 31:27 | Reserved   | Reserved. Read returns 0s.          | RW   | 0x0000 |
| 26    | MS         | UVPHASE_POL MS mode UV phase        | RW   | 0      |
|       |            | 0x0: CbCr                           |      |        |
|       |            | 0x1: CrCb                           |      |        |
| 25    | 656        | UVPHASE_POL 656 input mode UV phase | RW   | 0      |
|       |            | 0x0: CbCr                           |      |        |
|       |            | 0x1: CrCb                           |      |        |
| 24    | CBAR       | UVPHASE_POL CBAR mode UV phase      | RW   | 0      |
|       |            | 0x0: CbCr                           |      |        |
|       |            | 0x1: CrCb                           |      |        |
| 23    | HIP        | HSYNC internal polarity             | RW   | 1      |
|       |            | 0x0: Active low                     |      |        |
|       |            | 0x1: Active high                    |      |        |
| 22    | VIP        | VSYNC internal polarity             | RW   | 1      |
|       |            | 0x0: Active low                     |      |        |
|       |            | 0x1: Active high                    |      |        |
| 21    | HEP        | Hsync external polarity             | RW   | 1      |
|       |            | 0x0: Active low                     |      |        |
|       |            | 0x1: Active high                    |      |        |
| 20    | VEP        | Vsync external polarity             | RW   | 1      |
|       |            | 0x0: Active low                     |      |        |
|       |            | 0x1: Active high                    |      |        |
| 19    | AVIDP      | AVID polarity                       | RW   | 1      |
|       |            | 0x0: Active low                     |      |        |
|       |            | 0x1: Active high                    |      |        |
| 18    | FIP        | FID internal polarity               | RW   | 1      |
|       |            | 0x0: Active low                     |      |        |
|       |            | 0x1: Active high                    |      |        |
| 17    | FEP        | FID external polarity               | RW   | 1      |
|       |            | 0x0: Active low                     |      |        |

| Bits | Field Name | Description                | Type | Reset |
|------|------------|----------------------------|------|-------|
|      |            | 0x1: Active high           |      |       |
| 16   | TVDP       | TVDETGP polarity           | RW   | 1     |
|      |            | 0x0: Active low            |      |       |
|      |            | 0x1: Active high           |      |       |
| 15:1 | Reserved   | Reserved. Read returns 0s. | RW   | 0x00  |
| 0    | EN         | TVDETGP generation enable  | RW   | 0     |
|      |            | 0x0: Disabled              |      |       |
|      |            | 0x1: Enabled               |      |       |

**Table 7-365. Register Call Summary for Register VENC\_GEN\_CTRL**

## Display Subsystem Functional Description

- [TV Detection/Disconnection Pulse Generation: \[0\] \[1\]](#)
- [TV Detection Procedure: \[2\] \[3\]](#)
- [TV Disconnection Procedure: \[4\] \[5\]](#)

## Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[6\]](#)

## Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[7\]](#)

**Table 7-366. VENC\_OUTPUT\_CONTROL**

| Address Offset          | 0x0000 00C4                                                              | Physical Address      | 0x4805 0CC4 <th>Instance</th> <td>VENC</td>                                                                                       | Instance | VENC |
|-------------------------|--------------------------------------------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------|----------|------|
| Description             | Output channel control register Also contains some test control features |                       |                                                                                                                                   |          |      |
| Type                    | RW                                                                       |                       |                                                                                                                                   |          |      |
| 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                                                                                                                   |          |      |
| RESERVED                | LUMA_TEST                                                                | RESERVED              | CHROMA_SOURCE<br>COMPOSITE_SOURCE<br>LUMA_SOURCE<br>TEST_MODE<br>VIDEO_INVERT<br>CHROMA_ENABLE<br>COMPOSITE_ENABLE<br>LUMA_ENABLE |          |      |

| Bits  | Field Name       | Description                                                                                                                                                                                                             | Type | Reset |
|-------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED         | Reserved. Read returns 0s.                                                                                                                                                                                              | RW   | 0x00  |
| 25:16 | LUMA_TEST        | In test mode, DAC 1 input value<br>(if s-video video mode is selected)                                                                                                                                                  | RW   | 0x000 |
| 15:8  | RESERVED         | Reserved. Read returns 0s.                                                                                                                                                                                              | RW   | 0x00  |
| 7     | CHROMA_SOURCE    | Source of chroma video data in test mode<br><br>0x0: Chroma test data comes from internal register<br>OUTPUT_TEST[25:16]<br><br>0x1: Chroma test data comes from display controller video port<br>G[1:0], B[7:0]        | RW   | 0x0   |
| 6     | COMPOSITE_SOURCE | Source of composite video data in test mode<br><br>0x0: Composite test data comes from internal register<br>OUTPUT_TEST[9:0]<br><br>0x1: Composite test data comes from display controller video port<br>G[1:0], B[7:0] | RW   | 0x0   |

| Bits | Field Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                         | Type | Reset |
|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 5    | LUMA_SOURCE      | Source of luminance video data in test mode<br>0x0: Luma test data comes from internal register OUTPUT_CONTROL[25:16]<br>0x1: Luma test data comes from display controller video port G[1:0], B[7:0]                                                                                                                                                                                                                                | RW   | 0x0   |
| 4    | TEST_MODE        | This enables the video DACs to be tested. The values sent to the DACs comes from a register for each output channel (Luma, Composite or Chroma) or from the display controller video port bits G[1:0], B[7:0], depending on the setting of the Source bits<br>0x0: Video outputs are in normal operation<br>0x1: Test mode. Video outputs are directly connected to either internal registers or the display controller video port. | RW   | 0x0   |
| 3    | VIDEO_INVERT     | Controls the video output polarity. This may be used to correct for inversion in an external video amplifier.<br>0x0: Video outputs are inverted<br>0x1: Video outputs are normal polarity                                                                                                                                                                                                                                          | RW   | 0x1   |
| 2    | CHROMA_ENABLE    | Enable the Chrominance output channel<br>0x0: Chroma output is disabled<br>0x1: Chroma output is enabled                                                                                                                                                                                                                                                                                                                            | RW   | 0x0   |
| 1    | COMPOSITE_ENABLE | Enable the Composite output channel<br>0x0: Composite output is disabled<br>0x1: Composite output is enabled                                                                                                                                                                                                                                                                                                                        | RW   | 0x0   |
| 0    | LUMA_ENABLE      | Enable the Luminance output channel<br>0x0: Luma output is disabled<br>0x1: Luma output is enabled                                                                                                                                                                                                                                                                                                                                  | RW   | 0x0   |

**Table 7-367. Register Call Summary for Register VENC\_OUTPUT\_CONTROL**

## Display Subsystem Environment

- [TV Display Support: \[0\] \[1\]](#)

## Display Subsystem Functional Description

- [TV Detection Procedure: \[2\] \[3\]](#)
- [TV Disconnection Procedure: \[4\] \[5\]](#)
- [Video DAC Stage Test Mode: \[6\] \[7\] \[8\] \[9\] \[10\]](#)
- [Video DAC Stage Power Management: \[11\] \[12\] \[13\]](#)

## Display Subsystem Basic Programming Model

- [Video DAC Stage Settings: \[14\] \[15\] \[16\]](#)
- [Video Encoder Register Settings: \[17\]](#)

## Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[18\]](#)

**Table 7-368. VENC\_OUTPUT\_TEST**

|                         |                                                                                                          |                       |                 |          |             |  |  |  |          |                |          |  |  |      |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|-------------|--|--|--|----------|----------------|----------|--|--|------|--|--|--|--|--|--|--|--|
| Address Offset          | 0x0000 00C8                                                                                              |                       |                 |          |             |  |  |  |          |                |          |  |  |      |  |  |  |  |  |  |  |  |
| Physical Address        | 0x4805 0CC8                                                                                              |                       |                 |          |             |  |  |  |          |                | Instance |  |  | VENC |  |  |  |  |  |  |  |  |
| Description             | Test values for the Luma/Composite Video DAC1 (if composite video is selected) and the Chroma Video DAC2 |                       |                 |          |             |  |  |  |          |                |          |  |  |      |  |  |  |  |  |  |  |  |
| Type                    | RW                                                                                                       |                       |                 |          |             |  |  |  |          |                |          |  |  |      |  |  |  |  |  |  |  |  |
| 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 | RESERVED | CHROMA_TEST |  |  |  | RESERVED | COMPOSITE_TEST |          |  |  |      |  |  |  |  |  |  |  |  |

| Bits  | Field Name     | Description                                                      | Type | Reset |
|-------|----------------|------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED       | Reserved. Read returns 0s.                                       | RW   | 0x00  |
| 25:16 | CHROMA_TEST    | In test mode, DAC 2 input value                                  | RW   | 0x000 |
| 15:10 | RESERVED       | Reserved. Read returns 0s.                                       | RW   | 0x00  |
| 9:0   | COMPOSITE_TEST | In test mode, DAC 1 input value (if composite video is selected) | RW   | 0x000 |

**Table 7-369. Register Call Summary for Register VENC\_OUTPUT\_TEST**

Display Subsystem Functional Description

- [Video DAC Stage Test Mode: \[0\] \[1\]](#)

Display Subsystem Basic Programming Model

- [Video Encoder Register Settings: \[2\]](#)

Display Subsystem Register Manual

- [Video Encoder Register Mapping Summary: \[3\]](#)

### 7.7.2.5 DSI Protocol Engine Registers

**Table 7-370. DSI\_REVISION**

| <b>Address Offset</b>   | 0x0000 0000                                                                                                                                            |                                                             |                 |                  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | DSI_PROTOCOL_ENGINE |  |     |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-----------------|------------------|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|---------------------|--|-----|--|--|--|--|
| <b>Description</b>      | MODULE REVISION This register contains the IP revision code in binary coded digital. For example, we have: 0x01 = revision 0.1 and 0x21 = revision 2.1 |                                                             |                 |                  |  |  |  |  |  |  |  |  |  |  |  |  |                 |                     |  |     |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                      |                                                             |                 |                  |  |  |  |  |  |  |  |  |  |  |  |  |                 |                     |  |     |  |  |  |  |
| 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 | RESERVED         |  |  |  |  |  |  |  |  |  |  |  |  |                 |                     |  | REV |  |  |  |  |
| Bits                    | Field Name                                                                                                                                             | Description                                                 | Type            | Reset            |  |  |  |  |  |  |  |  |  |  |  |  |                 |                     |  |     |  |  |  |  |
| 31:8                    | RESERVED                                                                                                                                               | Write 0s for future compatibility.<br>Reads returns 0.      | R               | 0x000000         |  |  |  |  |  |  |  |  |  |  |  |  |                 |                     |  |     |  |  |  |  |
| 7:0                     | REV                                                                                                                                                    | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision | R               | TI internal data |  |  |  |  |  |  |  |  |  |  |  |  |                 |                     |  |     |  |  |  |  |

**Table 7-371. Register Call Summary for Register DSI\_REVISION**

Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[0\]](#)

**Table 7-372. DSI\_SYSCONFIG**

| <b>Address Offset</b>   | 0x0000 0010                                                                       |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | DSI_PROTOCOL_ENGINE |  |               |          |          |          |            |           |
|-------------------------|-----------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|---------------------|--|---------------|----------|----------|----------|------------|-----------|
| <b>Description</b>      | SYSTEM CONFIGURATION REGISTER This register is the system configuration register. |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                 |                     |  |               |          |          |          |            |           |
| <b>Type</b>             | RW                                                                                |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                 |                     |  |               |          |          |          |            |           |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |                 |                     |  | CLOCKACTIVITY | RESERVED | RESERVED | ENWAKEUP | SOFT_RESET | AUTO_IDLE |
| Bits                    | Field Name                                                                        | Description           | Type            | Reset    |  |  |  |  |  |  |  |  |  |  |  |  |                 |                     |  |               |          |          |          |            |           |

| Bits  | Field Name    | Description                                                                                                                                                                                                                                                                                                                                                                                             | Type | Reset   |
|-------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | RESERVED      | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                  | RW   | 0x00000 |
| 13:10 | RESERVED      | Write 0s for future compatibility.                                                                                                                                                                                                                                                                                                                                                                      | RW   | 0x0     |
| 9:8   | CLOCKACTIVITY | Clocks activity during wake up mode period<br><br>0x0: Interface and Functional clocks can be switched off<br>0x1: Functional clocks can be switched off and Interface clocks are maintained during wake up period<br>0x2: Interface clocks can be switched off and Functional clocks are maintained during wake up period<br>0x3: Interface and Functional clocks are maintained during wake up period | RW   | 0x0     |
| 7:5   | RESERVED      | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                  | RW   | 0x0     |
| 4:3   | SIDLEMODE     | Slave interface power management, Idle req/ack control<br><br>0x0: Force-idle. An idle request is acknowledged unconditionally<br>0x1: No-idle. An idle request is never acknowledged<br>0x2: Smart-idle. Acknowledgement to an idle request is given based on the internal activity of the module.<br>0x3: Reserved                                                                                    | RW   | 0x2     |
| 2     | ENWAKEUP      | Wake-up mode enable bit<br><br>0x0: Wakeup is disabled.<br>0x1: Wakeup is enabled,                                                                                                                                                                                                                                                                                                                      | RW   | 0x0     |
| 1     | SOFT_RESET    | Software reset. Set the bit to 1 to trigger a module reset. The bit is automatically reset by the hw. During reads return 0.<br><br>0x0: Normal mode.<br>0x1: The module is reset                                                                                                                                                                                                                       | RW   | 0x0     |
| 0     | AUTO_IDLE     | Internal interface clock gating strategy<br><br>0x0: Interface clock is free-running.<br>0x1: Automatic Interface clock gating strategy is applied based on the module interface activity.                                                                                                                                                                                                              | RW   | 0x1     |

**Table 7-373. Register Call Summary for Register DSI\_SYSCONFIG**

## Display Subsystem Integration

- [Software Reset: \[0\]](#)
- [Clock Activity Mode: \[1\] \[2\] \[3\]](#)
- [Autoidle Mode: \[4\]](#)
- [Idle Mode: \[5\] \[6\] \[7\]](#)

## Display Subsystem Basic Programming Model

- [Software Reset: \[8\]](#)
- [Power Management: \[9\] \[10\]](#)
- [Software Reset: \[11\]](#)

## Display Subsystem Use Cases and Tips

- [Reset DSI Modules: \[12\]](#)
- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O: \[13\] \[14\] \[15\]](#)

## Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[16\]](#)

**Table 7-374. DSI\_SYSSTATUS**

|                         |                                                                                                                             |                         |                 |                 |                     |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|---------------------|
| <b>Address Offset</b>   | 0x0000 0014                                                                                                                 | <b>Physical Address</b> | 0x4804 FC14     | <b>Instance</b> | DSI_PROTOCOL_ENGINE |
| <b>Description</b>      | SYSTEM STATUS REGISTER This register provides status information about the module, excluding the interrupt status register. |                         |                 |                 |                     |
| <b>Type</b>             | R                                                                                                                           |                         |                 |                 |                     |
| 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 |                 |                     |
| RESERVED                |                                                                                                                             |                         |                 |                 | RESET_DONE          |

| Bits | Field Name | Description                                                                                           | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Reads returns 0.                                                                                      | R    | 0x00000000 |
| 0    | RESET_DONE | Internal reset monitoring<br><br>0x0: Internal module reset is on going.<br><br>0x1: Reset completed. | R    | 0x1        |

**Table 7-375. Register Call Summary for Register DSI\_SYSSTATUS**

Display Subsystem Basic Programming Model

- Software Reset: [0] [1]

Display Subsystem Use Cases and Tips

- Reset DSI Modules: [2]
- Set Up DSI Protocol Engine: [3]
- Configure DSI Protocol Engine, DSI PLL, and Complex I/O: [4] [5]

Display Subsystem Register Manual

- DSI Protocol Engine Register Mapping Summary: [6]

**Table 7-376. DSI\_IRQSTATUS**

|                         |                                                                                                                                                                                                                                                                                |                         |                 |                 |                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0018                                                                                                                                                                                                                                                                    | <b>Physical Address</b> | 0x4804 FC18     | <b>Instance</b> | DSI_PROTOCOL_ENGINE                                                                                                                                                                                                                                                                                                                                                      |
| <b>Description</b>      | INTERRUPT STATUS REGISTER - All VCs + complex I/O + PLL This register associates one bit for each VC to determine which VC has generated the interrupt. The VC should be enabled for events to be generated on that VC. If the VC is disabled, the interrupt is not generated. |                         |                 |                 |                                                                                                                                                                                                                                                                                                                                                                          |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                             |                         |                 |                 |                                                                                                                                                                                                                                                                                                                                                                          |
| 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 |                 |                                                                                                                                                                                                                                                                                                                                                                          |
| RESERVED                |                                                                                                                                                                                                                                                                                |                         |                 |                 | TA_TO_IRQ<br>LDO_POWER_GOOD_IRQ<br>SYNC_LOST_IRQ<br>ACK_TRIGGER_IRQ<br>TE_TRIGGER_IRQ<br>LP_RX_TO_IRQ<br>HS_TX_TO_IRQ<br>RESERVED<br>RESERVED<br>COMPLEXIO_ERR_IRQ<br>PLL_RECAL_IRQ<br>PLL_UNLOCK_IRQ<br>PLL_LOCK_IRQ<br>RESERVED<br>RESYNCHRONIZATION_IRQ<br>WAKEUP_IRQ<br>VIRTUAL_CHANNEL3_IRQ<br>VIRTUAL_CHANNEL2_IRQ<br>VIRTUAL_CHANNEL1_IRQ<br>VIRTUAL_CHANNEL0_IRQ |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name         | Description                                                                                                                                                                                                                                                                                       | Type | Reset |
|-------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED           | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                            | RW   | 0x000 |
| 20    | TA_TO_IRQ          | Turn-around Time out.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                             | RW   | 0x0   |
| 19    | LDO_POWER_GOOD_IRQ | Transition of the status signal LDOPWRGOOD from the DSI_PHY indicating a state change for the supply VDDALDODSIPLL from up to down or down to up.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW   | 0x0   |
| 18    | SYNC_LOST_IRQ      | Synchronization with Video port is lost (Video mode only)<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                         | RW   | 0x0   |
| 17    | ACK_TRIGGER_IRQ    | Acknowledge Trigger<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                               | RW   | 0x0   |
| 16    | TE_TRIGGER_IRQ     | Tearing Effect Trigger<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                            | RW   | 0x0   |
| 15    | LP_RX_TO_IRQ       | Interrupt for Low Power Rx Time out<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                               | RW   | 0x0   |
| 14    | HS_TX_TO_IRQ       | Interrupt for high-speed Tx Time out.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                             | RW   | 0x0   |
| 13    | RESERVED           | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                            | RW   | 0x0   |
| 12:11 | RESERVED           | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                            | RW   | 0x0   |
| 10    | COMPLEXIO_ERR_IRQ  | Error signaling from complex I/O: status of the complex I/O errors received from the complex I/O(events are defined in <a href="#">DSI_COMPLEXIO_IRQSTATUS</a> ).<br><br>0x0: READS: Event is false.<br><br>0x1: READS: Event is true (pending).                                                  | R    | 0x0   |
| 9     | PLL_RECAL_IRQ      | PLL recalibration event (assertion of recalibration signal from the DSI PLL Control module)<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                       | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b>     | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                             | <b>Type</b> | <b>Reset</b> |
|-------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 8           | PLL_UNLOCK_IRQ        | PLL un-lock event (de-assertion of lock signal from the DSI PLL Control module)<br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                                                        | RW          | 0x0          |
| 7           | PLL_LOCK_IRQ          | PLL lock event (assertion of lock signal from the DSI PLL Control module)<br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                                                              | RW          | 0x0          |
| 6           | RESERVED              | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                         | RW          | 0x0          |
| 5           | RESYNCHRONIZATION_IRQ | Video mode resynchronization<br><br>Indicates that the video port works but the configuration of the timings for the display controller (DISPC) and for DSI protocol engine may have to be modified to avoid the resynchronization to occur.<br>0x0: READS: Event is false. WRITES: Status bit unchanged.<br>0x1: READS: Event is true (pending). WRITES: Status bit is reset. | RW          | 0x0          |
| 4           | WAKEUP_IRQ            | Wakeup<br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                                                                                                                                 | RW          | 0x0          |
| 3           | VIRTUAL_CHANNEL3_IRQ  | Virtual channel #3<br><br>Error signaling from DSI Virtual Channel3: Status of DSI Virtual Channel3 errors received from DSI Virtual Channel3 (events are defined in DSI_VC3_IRQSTATUS).<br>0x0: READS: Event is false.<br>0x1: READS: Event is true (pending).                                                                                                                | R           | 0x0          |
| 2           | VIRTUAL_CHANNEL2_IRQ  | Virtual channel #2<br><br>Error signaling from DSI Virtual Channel2: Status of DSI Virtual Channel2 errors received from DSI Virtual Channel2 (events are defined in DSI_VC2_IRQSTATUS).<br>0x0: READS: Event is false.<br>0x1: READS: Event is true (pending).                                                                                                                | R           | 0x0          |
| 1           | VIRTUAL_CHANNEL1_IRQ  | Virtual channel #1<br><br>Error signaling from DSI Virtual Channel1: Status of DSI Virtual Channel1 errors received from DSI Virtual Channel1 (events are defined in DSI_VC1_IRQSTATUS).<br>0x0: READS: Event is false.<br>0x1: READS: Event is true (pending).                                                                                                                | R           | 0x0          |
| 0           | VIRTUAL_CHANNEL0_IRQ  | Virtual channel #0<br><br>Error signaling from DSI Virtual Channel0: Status of the DSI Virtual Channel0 errors received from DSI Virtual Channel0 (events are defined in DSI_VC0_IRQSTATUS).<br>0x0: READS: Event is false.<br>0x1: READS: Event is true (pending).                                                                                                            | R           | 0x0          |

**Table 7-377. Register Call Summary for Register DSI\_IRQSTATUS**

Display Subsystem Integration

- DSI Interrupt Request: [0]

Display Subsystem Functional Description

- HS TX Timer: [1]
- LP RX Timer: [2]
- Tearing Effect: [3]
- Acknowledge: [4]
- Error Handling: [5] [6] [7]

Display Subsystem Basic Programming Model

- Interrupts: [8] [9]
- Video Mode: [10] [11]
- DSI PLL Error Handling: [12] [13] [14] [15] [16] [17]
- Error Handling: [18]

Display Subsystem Use Cases and Tips

- Reset DSI Modules: [19]
- Configure DSI Protocol Engine, DSI PLL, and Complex I/O: [20]

Display Subsystem Register Manual

- DSI Protocol Engine Register Mapping Summary: [21]
- Display Subsystem Registers: [22]

**Table 7-378. DSI\_IRQENABLE**

| Address Offset |    | 0x0000 001C                                                                                                      |    | Physical Address |    | 0x4804 FC1C |    | Instance |    | DSI_PROTOCOL_ENGINE |                       |                  |                    |                   |                 |                 |          |          |          |                  |                   |                 |                          |               |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|----------------|----|------------------------------------------------------------------------------------------------------------------|----|------------------|----|-------------|----|----------|----|---------------------|-----------------------|------------------|--------------------|-------------------|-----------------|-----------------|----------|----------|----------|------------------|-------------------|-----------------|--------------------------|---------------|----------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| Description    |    | INTERRUPT ENABLE REGISTER - This register associates one bit for each VC to enable/disable each VC individually. |    |                  |    |             |    |          |    |                     |                       |                  |                    |                   |                 |                 |          |          |          |                  |                   |                 |                          |               |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| Type           |    | RW                                                                                                               |    |                  |    |             |    |          |    |                     |                       |                  |                    |                   |                 |                 |          |          |          |                  |                   |                 |                          |               |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |
| RESERVED       |    |                                                                                                                  |    |                  |    |             |    |          |    | TA_TO_IRQ_EN        | LDO_POWER_GOOD_IRQ_EN | SYNC_LOST_IRQ_EN | ACK_TRIGGER_IRQ_EN | TE_TRIGGER_IRQ_EN | LP_RX_TO_IRQ_EN | HS_TX_TO_IRQ_EN | RESERVED | RESERVED | RESERVED | PLL_RECAL_IRQ_EN | PLL_UNLOCK_IRQ_EN | PLL_LOCK_IRQ_EN | RESYNCHRONIZATION_IRQ_EN | WAKEUP_IRQ_EN | RESERVED |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

| Bits  | Field Name            | Description                                                                                                                                                                                                                           | Type | Reset |
|-------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED              | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                | RW   | 0x000 |
| 20    | TA_TO_IRQ_EN          | Turn-around Time out.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                                                                                                                             | RW   | 0x0   |
| 19    | LDO_POWER_GOOD_IRQ_EN | Transition of the status signal LDOPWRGOOD from the DSI_PHY indicating a state change for the supply VDDALDODSIPLL from up to down or down to up.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs | RW   | 0x0   |

| Bits  | Field Name               | Description                                                                                                                                                             | Type | Reset |
|-------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 18    | SYNC_LOST_IRQ_EN         | Synchronization with Video port is lost (Video mode only)<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                   | RW   | 0x0   |
| 17    | ACK_TRIGGER_IRQ_EN       | Acknowledge trigger<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                                         | RW   | 0x0   |
| 16    | TE_TRIGGER_IRQ_EN        | Tearing Effect trigger<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                                      | RW   | 0x0   |
| 15    | LP_RX_TO_IRQ_EN          | Interrupt for Low Power Rx Time out.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                        | RW   | 0x0   |
| 14    | HS_TX_TO_IRQ_EN          | Interrupt for high-speed Tx Time out.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                       | RW   | 0x0   |
| 13    | RESERVED                 | Write Os for future compatibility.<br>Reads returns 0.                                                                                                                  | RW   | 0x0   |
| 12:11 | RESERVED                 | Write Os for future compatibility.<br>Reads returns 0.                                                                                                                  | RW   | 0x0   |
| 10    | RESERVED                 | Write Os for future compatibility.<br>Reads returns 0.                                                                                                                  | RW   | 0x0   |
| 9     | PLL_RECAL_IRQ_EN         | PLL recalibration event (assertion of recalibration signal from the DSI PLL Control module)<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0x0   |
| 8     | PLL_UNLOCK_IRQ_EN        | PLL un-lock event (de-assertion of lock signal from the DSI PLL Control module)<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs             | RW   | 0x0   |
| 7     | PLL_LOCK_IRQ_EN          | PLL lock event (assertion of lock signal from the DSI PLL Control module)<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                   | RW   | 0x0   |
| 6     | RESERVED                 | Write Os for future compatibility.<br>Reads returns 0.                                                                                                                  | RW   | 0x0   |
| 5     | RESYNCHRONIZATION_IRQ_EN | Resynchronization<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                                           | RW   | 0x0   |
| 4     | WAKEUP_IRQ_EN            | Wakeup<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs                                                                                      | RW   | 0x0   |
| 3:0   | RESERVED                 | Write Os for future compatibility.<br>Reads returns 0.                                                                                                                  | RW   | 0x0   |

**Table 7-379. Register Call Summary for Register DSI\_IRQENABLE**

Display Subsystem Functional Description

- [Tearing Effect: \[0\]](#)
- [Acknowledge: \[1\]](#)

Display Subsystem Basic Programming Model

- [Interrupts: \[2\]](#)

**Table 7-379. Register Call Summary for Register DSI\_IRQENABLE (continued)**

## Display Subsystem Use Cases and Tips

- Set Up DSI Protocol Engine: [3]
- Configure DSI Protocol Engine, DSI PLL, and Complex I/O: [4]

## Display Subsystem Register Manual

- DSI Protocol Engine Register Mapping Summary: [5]

**Table 7-380. DSI\_CTRL**

|                       |                                                                                                                                                           |  |                         |             |  |                 |                     |  |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--|-------------------------|-------------|--|-----------------|---------------------|--|
| <b>Address Offset</b> | 0x0000 0040                                                                                                                                               |  | <b>Physical Address</b> | 0x4804 FC40 |  | <b>Instance</b> | DSI_PROTOCOL_ENGINE |  |
| <b>Description</b>    | GLOBAL CONTROL REGISTER This register controls the DSI Protocol Engine module. This register should not be modified dynamically (except IF_EN bit field). |  |                         |             |  |                 |                     |  |
| <b>Type</b>           | RW                                                                                                                                                        |  |                         |             |  |                 |                     |  |

| 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 |                    |  |             |  |              |  |              |  |           |  |            |  |                   |  |               |  |              |  |                     |  |           |  |          |  |       |  |
|----|----|----|----|----|----------|----|----|--------------|----|--------------|----|----------------|----|-------------------|----|-------------------|----|-------------------|----|---------------|----|------------|---|--------------|---|----------------|---|--------------|---|----------------|---|--------------------|--|-------------|--|--------------|--|--------------|--|-----------|--|------------|--|-------------------|--|---------------|--|--------------|--|---------------------|--|-----------|--|----------|--|-------|--|
|    |    |    |    |    | RESERVED |    |    | RGB565_ORDER |    | DCS_CMD_CODE |    | DCS_CMD_ENABLE |    | HSA_BLANKING_MODE |    | HBP_BLANKING_MODE |    | HFP_BLANKING_MODE |    | BLANKING_MODE |    | EOT_ENABLE |   | VP_HSYNC_END |   | VP_HSYNC_START |   | VP_VSYNC_END |   | VP_VSYNC_START |   | TRIGGER_RESET_MODE |  | LINE_BUFFER |  | VP_VSYNC_POL |  | VP_HSYNC_POL |  | VP_DE_POL |  | VP_CLK_POL |  | VP_DATA_BUS_WIDTH |  | TRIGGER_RESET |  | VP_CLK_RATIO |  | TX_FIFO_ARBITRATION |  | ECC_RX_EN |  | CS_RX_EN |  | IF_EN |  |

| Bits  | Field Name        | Description                                                                                                                                                                                                                                                                                                    | Type | Reset |
|-------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | RESERVED          | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                         | RW   | 0x00  |
| 26    | RGB565_ORDER      | Byte order for RGB565 command mode from video port<br><br>0x0:<br><br>0x1: Byte order as for video mode                                                                                                                                                                                                        | RW   | 0     |
| 25    | DCS_CMD_CODE      | DCS command code value to insert between header and video port data when enabled by DCS_CMD_ENABLE<br><br>0x0: DCS write memory continue code is inserted.<br><br>0x1: DCS write memory start code is inserted.                                                                                                | RW   | 0     |
| 24    | DCS_CMD_ENABLE    | Enables automatic insertion of DCS command codes when data is sourced by the video port.<br><br>0x0: DCS command code is not inserted when command mode traffic is coming from the Video Port.<br><br>0x1: DCS command code is inserted automatically when command mode traffic is coming from the Video Port. | RW   | 0     |
| 23    | HSA_BLANKING_MODE | Blanking mode<br><br>0x0: Packets in TX FIFO are sent during HSA blanking period of video mode or LPS is used.<br><br>0x1: LONG BLANKING PACKETS only are used during HSA blanking period of video mode.                                                                                                       | RW   | 0x0   |
| 22    | HBP_BLANKING_MODE | Blanking mode<br><br>0x0: Packets in TX FIFO are sent during HBP blanking period of video mode or LPS is used.<br><br>0x1: LONG BLANKING PACKETS only are used during HBP blanking period of video mode.                                                                                                       | RW   | 0x0   |

| Bits  | Field Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset |
|-------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 21    | HFP_BLANKING_MODE  | Blanking mode<br><br>0x0: Packets in TX FIFO are sent during HFP blanking period of video mode or LPS is used.<br><br>0x1: LONG BLANKING PACKETS only are used during HFP blanking period of video mode.                                                                                                                                                                                                                                                                                                                                                                                                                 | RW   | 0x0   |
| 20    | BLANKING_MODE      | Blanking mode<br><br>0x0: LPS is used during blanking periods of video mode (except HSA, HBP, HFP defined in HSA_BLANKING_MODE, HBP_BLANKING_MODE and HFP_BLANKING_MODE bit fields respectively) when there is no command mode data in TX FIFO ready to be sent. So blanking periods can be different during the frame depending on the TX FIFO.<br><br>0x1: LONG BLANKING PACKETS are used during blanking periods of video mode (except HSA, HBP, HFP defined in HSA_BLANKING_MODE, HBP_BLANKING_MODE and HFP_BLANKING_MODE bit fields respectively) regardless of the packets present in the TX FIFO ready to be sent | RW   | 0x0   |
| 19    | EOT_ENABLE         | Enable EOT packets at the end of HS transmission.<br><br>0x0: No EOT packets<br><br>0x1: EOT packet is sent at all HS to LP transitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0     |
| 18    | VP_HSYNC_END       | Hsync end pulse.<br><br>0x0: Disabled. No HSYNC END short packet is generated.<br><br>0x1: Enabled. While the HSYNC END pulse is detected, the associated short packet HSYNC END is generated.                                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0x0   |
| 17    | VP_HSYNC_START     | Hsync start pulse.<br><br>0x0: Disabled. No HSYNC START short packet is generated.<br><br>0x1: Enabled. While the HSYNC start pulse is detected, the associated short packet HSYNC START is generated.                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 16    | VP_VSYNC_END       | Vsync end pulse.<br><br>0x0: Disabled. No VSYNC END short packet is generated.<br><br>0x1: Enabled. While the VSYNC END pulse is detected, the associated short packet VSYNC END is generated.                                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0x0   |
| 15    | VP_VSYNC_START     | Vsync start pulse.<br><br>0x0: Disabled. No VSYNC START short packet is generated.<br><br>0x1: Enabled. While the VSYNC START pulse is detected, the associated short packet VSYNC START is generated.                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 14    | TRIGGER_RESET_MODE | Selection of the trigger reset mode<br><br>0x0: Synchronized: the mode is only valid if there is VC using the video mode and it is active. The principle is to wait for the current video frame to be transferred on the link. Any data received after the VSYNC are ignored.<br><br>0x1: Immediate: all pending requests in TX FIFO are taken into account for transfer scheduling, the RX FIFO is ignored, and the data from video port are ignored as soon as possible. Only the current transfer on DSI link and already scheduled ones are transmitted. All the other transfers are discarded.                      | RW   | 0x0   |
| 13:12 | LINE_BUFFER        | Number of line buffers to be used while receiving data on the video port.<br><br>0x0: No line buffer<br><br>0x1: 1 line buffer<br><br>0x2: 2 line buffers                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW   | 0x0   |
| 11    | VP_VSYNC_POL       | VP vertical synchronization signal polarity<br><br>0x0: VSYNC signal on the video port is active low.<br><br>0x1: VSYNC signal on the video port is active high.                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0x0   |

## Display Subsystem Register Manual

www.ti.com

| Bits | Field Name          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset |
|------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 10   | VP_HSYNC_POL        | VP horizontal synchronization signal polarity<br>0x0: HSYNC signal on the video port is active low.<br>0x1: HSYNC signal on the video port is active high.                                                                                                                                                                                                                                                                                                                                                        | RW   | 0x0   |
| 9    | VP_DE_POL           | VP data enable signal polarity<br>0x0: DE signal on the video port is active low.<br>0x1: DE signal on the video port is active high.                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0x0   |
| 8    | VP_CLK_POL          | VP pixel clock polarity<br>0x0: The DSI Protocol Engine module captures the data on the VP on the pixel clock falling edge. The module connected to the VP must drive the data on the pixel clock rising edge.<br>0x1: The DSI Protocol Engine module captures the data on the VP on the pixel clock raising edge. The module connected to the VP must drive the data on the pixel clock falling edge.                                                                                                            | RW   | 0x1   |
| 7:6  | VP_DATA_BUS_WIDTH   | Defines the size of the video port data bus<br>0x0: 16-bits data width (LSB of the 24-bit video port data bus)<br>0x1: 18-bits data width (LSB of the 24-bit video port data bus)<br>0x2: 24-bits data width (LSB of the 24-bit video port data bus)                                                                                                                                                                                                                                                              | RW   | 0x0   |
| 5    | TRIGGER_RESET       | Send the reset trigger to the peripheral.<br>0x0: READS: Reset trigger generation is completed. It is reset by HW when it is completed.<br>WRITES: Cancellation of the request for Reset trigger generation (maybe too late since it is already on going)<br>0x1: READS: Generation of the reset trigger has been requested by user (could be on going but not completed yet).<br>WRITES: Request for Reset trigger to be sent to the peripheral.                                                                 | RW   | 0x0   |
| 4    | VP_CLK_RATIO        | This bit indicates the clock ratio between VP_CLK and VP_PCLK. The clock VP_PCLK is generated from VP_CLK. It is divided down. The information is only used when the video port is used to provide data in command mode. In the case of video mode, it is not used.<br>0x0: The clock VP_PCLK is the clock VP_CLK divided by 2. The duty cycle of VP_PCLK is 50/50.<br>0x1: The clock VP_PCLK is the clock VP_CLK divided by 3 or more. The duty cycle of VP_PCLK is not 50/50 for odd ratio numbers (3,5,7,...). | RW   | 0x0   |
| 3    | TX_FIFO_ARBITRATION | Defines the arbitration scheme for granting the VC pending ready requests in the TX FIFO<br>0x0: Round-Robin Scheme is used<br>0x1: Sequential Scheme is used                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0   |
| 2    | ECC_RX_EN           | Enables the ECC check for the received header (short and long packets for all VC IDs).<br>0x0: Disabled<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0x0   |
| 1    | CS_RX_EN            | Enables the checksum check for the received payload (long packet only for all VC IDs).<br>0x0: Disabled<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | IF_EN      | <p>Enables the module. When the module is disabled the signals from the complex I/O are gated (no updates of the interrupt status register).</p> <p>It is not possible to change the bit fields in the <a href="#">DSI_CTRL</a> register, except IF_EN when it is enabled. All the other registers can be changed except the ones that require <a href="#">DSI_VCn_CTRL[0]</a> VC_EN to be equal to 0 to be modified.</p> <p>0x0: The interface is disabled. If one of the VC uses the video mode with the video port to receive the data, the DSI protocol engines is disabled when the next VSYNC is received and all the data in the FIFO for the other VCs in command mode are sent to the peripherals (if BTA_EN bit is enabled, the DSI protocol engine needs to wait for the response and BTA from the peripheral before disabling all the internal logic since an acknowledgement is requested).</p> <p>0x1: The interface is enabled immediately, the data acquisition on the video port starts on the next VSYNC (video mode) or first data received in the Slave port FIFO (command mode).</p> | RW   | 0x0   |

**Table 7-381. Register Call Summary for Register DSI\_CTRL**
**Display Subsystem Environment**

- [Data/Clock Configuration](#): [0] [1] [2]
- [Video Port \(VP\) Interface](#): [3] [4] [5] [6]
- [Video Port Used for Video Mode](#): [7] [8] [9]
- [Video Port Used on Command Mode](#): [10] [11] [12]

**Display Subsystem Functional Description**

- [Clock Requirements](#): [13]
- [Command Mode](#): [14] [15] [16] [17]
- [DSI PLL Power Control Commands](#): [18] [19] [20] [21]
- [TurnRequest FSM](#): [22] [23]
- [HS TX Timer](#): [24] [25]
- [LP RX Timer](#): [26] [27]
- [Bus Turnaround](#): [28] [29] [30] [31]
- [Reset](#): [32] [33] [34]
- [Tearing Effect](#): [35]
- [ECC Generation](#): [36]
- [Checksum Generation for Long Packet Payloads](#): [37]
- [End of Transfer Packet](#): [38]

**Display Subsystem Basic Programming Model**

- [Global Register Controls](#): [39] [40] [41] [42] [43] [44] [45]
- [Packets](#): [46] [47] [48] [49] [50] [51]
- [Video Mode](#): [52] [53] [54] [55]
- [Video Port Data Bus](#): [56]
- [Command Mode TX FIFO](#): [57] [58]
- [Video Mode Transfer](#): [59]
- [Command Mode Transfer Example 1](#): [60]
- [Command Mode Transfer Example 2](#): [61]

**Display Subsystem Use Cases and Tips**

- [Set Up DSI Protocol Engine](#): [62] [63] [64] [65] [66] [67] [68] [69] [70] [71] [72] [73] [74] [75]
- [Enable Video Mode Using the DISPC Video Port](#): [76] [77]
- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O](#): [78] [79] [80] [81] [82] [83] [84] [85] [86]
- [Enable Command Mode Using DISPC Video Port](#): [87] [88] [89] [90]

**Display Subsystem Register Manual**

- [DSI Protocol Engine Register Mapping Summary](#): [91]
- [DSI Protocol Engine Registers](#): [92] [93] [94] [95] [96] [97] [98] [99]

**Table 7-382. DSI\_COMPLEXIO\_CFG1**

|                         |                   |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |    |    |    |                      |                  |          |          |          |                    |                                                                                                                                                                                                                                                                                      |           |                |           |                |           |                |   |    |             |              |   |   |   |   |   |  |  |  |  |  |  |  |
|-------------------------|-------------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----------------------|------------------|----------|----------|----------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------|-----------|----------------|-----------|----------------|---|----|-------------|--------------|---|---|---|---|---|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0048       |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |    |    |    |                      |                  |          |          |          | <b>Instance</b>    | DSI_PROTOCOL_ENGINE                                                                                                                                                                                                                                                                  |           |                |           |                |           |                |   |    |             |              |   |   |   |   |   |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4804 FC48       |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |    |    |    |                      |                  |          |          |          | <b>Description</b> | COMPLEXIO CONFIGURATION REGISTER for the complex I/O This register contains the lane configuration for the order and position of the lanes (clock and data) and the polarity order for the control of the PHY differential signals in addition to the control bit for the power FSM. |           |                |           |                |           |                |   |    |             |              |   |   |   |   |   |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |    |    |    |                      |                  |          |          |          |                    |                                                                                                                                                                                                                                                                                      |           |                |           |                |           |                |   |    |             |              |   |   |   |   |   |  |  |  |  |  |  |  |
|                         | 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 |  |  |  |  |  |  |  |
| SHADOWING               |                   |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |    |    |    | LDO_POWER_GOOD_STATE | USE_LDO_EXTERNAL | RESERVED | RESERVED | RESERVED | RESERVED           | RESERVED                                                                                                                                                                                                                                                                             | DATA2_POL | DATA2_POSITION | DATA1_POL | DATA1_POSITION | CLOCK_POL | CLOCK_POSITION |   |    |             |              |   |   |   |   |   |  |  |  |  |  |  |  |
| <b>Bits</b>             | <b>Field Name</b> |    | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |    |    |    |    |    |    |                      |                  |          |          |          |                    |                                                                                                                                                                                                                                                                                      |           |                |           |                |           |                |   |    | <b>Type</b> | <b>Reset</b> |   |   |   |   |   |  |  |  |  |  |  |  |
| 31                      | SHADOWING         |    | Shadowing configuration.<br><br>0x0: Disabled. The writes to the DSIPHY_CFG0 and DSIPHY_CFG1 registers are done like the other SCP registers.<br><br>0x1: Enabled. The writes to the DSIPHY_CFG0 and DSIPHY_CFG1 registers are done only when the GO bit is set and when the signal DISPC_UPDATE_SYNC from the display controller module is active.                                                                                                                                                                                                                                                                                                                                                                                                  |    |    |    |    |    |    |    |                      |                  |          |          |          |                    |                                                                                                                                                                                                                                                                                      |           |                |           |                |           |                |   |    | RW          | 0x0          |   |   |   |   |   |  |  |  |  |  |  |  |
| 30                      | GOBIT             |    | Allows the synchronized update of the shadow registers when the signal DISPC_UPDATE_SYNC is active.<br><br>0x0: Resets the Gobit. The hardware has finished the update of the shadow SCP registers. The bit is reset by Hardware. The software can reset the bit in case users decide to abort it. There is no guarantee that the software reset is done before the transfer of the values to the complex I/O.<br><br>0x1: Set the Gobit. Only when the transfer of the new values for the two first registers is completed (2, 1, or 0 transfers are performed based on the number of registers to update), the GObit is reset. The DISPC_UPDATE_SYNC signal is used to synchronize the update. The bit must be set only when it is in reset state. |    |    |    |    |    |    |    |                      |                  |          |          |          |                    |                                                                                                                                                                                                                                                                                      |           |                |           |                |           |                |   | RW | 0           |              |   |   |   |   |   |  |  |  |  |  |  |  |
| 29                      | RESET_DONE        |    | Internal reset monitoring of the power domain using the TxByteClkHS from the complex I/O<br><br>0x0: Internal module reset is on going.<br>0x1: Reset completed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |    |    |    |    |    |    |                      |                  |          |          |          |                    |                                                                                                                                                                                                                                                                                      |           |                |           |                |           |                |   | R  | 1           |              |   |   |   |   |   |  |  |  |  |  |  |  |
| 28:27                   | PWR_CMD           |    | Command for power control of the complex I/O<br><br>0x0: Command to change to OFF state<br>0x1: Command to change to ON state<br>0x2: Command to change to ultralow-power state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |    |    |    |                      |                  |          |          |          |                    |                                                                                                                                                                                                                                                                                      |           |                |           |                |           |                |   | RW | 0x0         |              |   |   |   |   |   |  |  |  |  |  |  |  |
| 26:25                   | PWR_STATUS        |    | Status of the power control of the complex I/O<br><br>0x0: complex I/O in OFF state<br>0x1: complex I/O in ON state<br>0x2: complex I/O in ultralow-power state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |    |    |    |                      |                  |          |          |          |                    |                                                                                                                                                                                                                                                                                      |           |                |           |                |           |                |   | R  | 0x0         |              |   |   |   |   |   |  |  |  |  |  |  |  |
| 24:22                   | RESERVED          |    | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |    |    |    |    |                      |                  |          |          |          |                    |                                                                                                                                                                                                                                                                                      |           |                |           |                |           |                |   | RW | 0x0         |              |   |   |   |   |   |  |  |  |  |  |  |  |

| Bits  | Field Name           | Description                                                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|-------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 21    | LDO_POWER_GOOD_STATE | Indicates the state of the signal LDOPWRGOOD. VDDALDODSIPLL: 1.2-V power supply for the PLL. The voltage is supplied by the internal or external LDO. The interrupt LDO_POWER_GOOD_IRQ is generated when a transition is detected on the signal LDOPWRGOOD from the DSI_PHY.<br><br>0x0: VDDALDODSIPLL power supply is down<br>0x1: VDDALDODSIPLL power supply is up | R    | 0x0   |
| 20    | USE_LDO_EXTERNAL     | Select the external LDO for the DSI_PHY.<br><br>0x0: DSI_PHY internal LDO is used.<br>0x1: External LDO is used. DSI_PHY LDO is tri-stated.                                                                                                                                                                                                                          | RW   | 0x0   |
| 19    | RESERVED             | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                               | RW   | 0x0   |
| 18:16 | RESERVED             | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                               | RW   | 0x0   |
| 15    | RESERVED             | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                               | RW   | 0x0   |
| 14:12 | RESERVED             | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                               | RW   | 0x0   |
| 11    | DATA2_POL            | +/- differential pin order of DATA lane 2.<br><br>0x0: +/- pin order (dsi_dx=+ and dsi_dy=-)<br>0x1: -/+ pin order (dsi_dx=- and dsi_dy=+)                                                                                                                                                                                                                           | RW   | 0x0   |
| 10:8  | DATA2_POSITION       | Position and order of the DATA lane 2.<br><br>0x0: Not used/connected<br>0x1: Data lane 2 is at the position 1 (line 1).<br>0x2: Data lane 2 is at the position 2 (line 2).<br>0x3: Data lane 2 is at the position 3 (line 3).<br>Other values: reserved                                                                                                             | RW   | 0x0   |
| 7     | DATA1_POL            | +/- differential pin order of DATA lane 1<br><br>0x0: +/- pin order (dsi_dx=+ and dsi_dy=-)<br>0x1: -/+ pin order (dsi_dx=- and dsi_dy=+)                                                                                                                                                                                                                            | RW   | 0x0   |
| 6:4   | DATA1_POSITION       | Position and order of the DATA lane 1.<br><br>0x1: Data lane 1 is at the position 1 (line 1).<br>0x2: Data lane 1 is at the position 2 (line 2).<br>0x3: Data lane 1 is at the position 3 (line 3).<br>Other values: reserved                                                                                                                                        | RW   | 0x0   |
| 3     | CLOCK_POL            | +/- differential pin order of CLOCK lane.<br><br>0x0: +/- pin order (dsi_dx=+ and dsi_dy=-)<br>0x1: -/+ pin order (dsi_dx=- and dsi_dy=+)                                                                                                                                                                                                                            | RW   | 0x0   |
| 2:0   | CLOCK_POSITION       | Position and order of the CLOCK lane.<br>The clock lane is always present.<br><br>0x1: Clock lane is at the position 1 (line 1).<br>0x2: Clock lane is at the position 2 (line 2).<br>0x3: Clock lane is at the position 3 (line 3).<br>Other values: reserved                                                                                                       | RW   | 0x0   |

**Table 7-383. Register Call Summary for Register DSI\_COMPLEXIO\_CFG1**

## Display Subsystem Environment

- [Data/Clock Configuration: \[0\] \[1\]](#)

## Display Subsystem Functional Description

- [DSI Protocol Architecture: \[2\]](#)
- [Shadowing Register: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [Complex I/O Power Control Commands: \[10\] \[11\]](#)

**Table 7-383. Register Call Summary for Register DSI\_COMPLEXIO\_CFG1 (continued)**

Display Subsystem Basic Programming Model

- Exiting ULPs: [12] [13]
- Software Reset: [14]
- Pad Configuration: [15] [16] [17]

Display Subsystem Use Cases and Tips

- Set Up DSI Protocol Engine: [18] [19] [20]
- Configure DSI Protocol Engine, DSI PLL, and Complex I/O: [21] [22] [23] [24] [25] [26]

Display Subsystem Register Manual

- DSI Protocol Engine Register Mapping Summary: [27]

**Table 7-384. DSI\_COMPLEXIO\_IRQSTATUS**

|                         |                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 004C                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4804 FC4C                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | INTERRUPT STATUS REGISTER - All errors from complex I/O |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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               |
|------------------------|------------------------|----------|----------|----------|----------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|----------|----------|----------------|----------------|----------------|----------|----------|-----------------|-----------------|-----------------|----------|----------|-------------|-------------|-------------|----------|----------|-----------------|-----------------|-----------------|
| ULPSACTIVENOT_ALL1 IRQ | ULPSACTIVENOT_ALL0 IRQ | RESERVED | RESERVED | RESERVED | RESERVED | ERRCONTENTIONLP1_3 IRQ | ERRCONTENTIONLP0_3 IRQ | ERRCONTENTIONLP1_2 IRQ | ERRCONTENTIONLP0_2 IRQ | ERRCONTENTIONLP1_1 IRQ | ERRCONTENTIONLP0_1 IRQ | RESERVED | RESERVED | STATEULPS3 IRQ | STATEULPS2 IRQ | STATEULPS1 IRQ | RESERVED | RESERVED | ERRCONTROL3 IRQ | ERRCONTROL2 IRQ | ERRCONTROL1 IRQ | RESERVED | RESERVED | ERRESC3 IRQ | ERRESC2 IRQ | ERRESC1 IRQ | RESERVED | RESERVED | ERRSYNCESC3 IRQ | ERRSYNCESC2 IRQ | ERRSYNCESC1 IRQ |
|                        |                        |          |          |          |          |                        |                        |                        |                        |                        |                        |          |          |                |                |                |          |          |                 |                 |                 |          |          |             |             |             |          |          |                 |                 |                 |
|                        |                        |          |          |          |          |                        |                        |                        |                        |                        |                        |          |          |                |                |                |          |          |                 |                 |                 |          |          |             |             |             |          |          |                 |                 |                 |
|                        |                        |          |          |          |          |                        |                        |                        |                        |                        |                        |          |          |                |                |                |          |          |                 |                 |                 |          |          |             |             |             |          |          |                 |                 |                 |

| Bits | Field Name             | Description                                                                                                                                                                                                                                   | Type | Reset |
|------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31   | ULPSACTIVENOT_ALL1 IRQ | All the ULPSActiveNOT signals corresponding to the lanes with TXULPSExit being high are high.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW   | 0x0   |
| 30   | ULPSACTIVENOT_ALL0 IRQ | All signals ULPSActiveNOT are 0<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                               | RW   | 0x0   |
| 29   | RESERVED               | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                        | RW   | 0x0   |
| 28   | RESERVED               | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                        | RW   | 0x0   |
| 27   | RESERVED               | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                        | RW   | 0x0   |
| 26   | RESERVED               | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                        | RW   | 0x0   |
| 25   | ERRCONTENTIONLP1_3 IRQ | Contention LP1 error for lane #3<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                              | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b>      | <b>Description</b>                                                                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 24          | ERRCONTENTIONLP0_3_IRQ | Contention LP0 error for lane #3<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW          | 0x0          |
| 23          | ERRCONTENTIONLP1_2_IRQ | Contention LP1 error for lane #2<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW          | 0x0          |
| 22          | ERRCONTENTIONLP0_2_IRQ | Contention LP0 error for lane #2<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW          | 0x0          |
| 21          | ERRCONTENTIONLP1_1_IRQ | Contention LP1 error for lane #1<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW          | 0x0          |
| 20          | ERRCONTENTIONLP0_1_IRQ | Contention LP0 error for lane #1<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW          | 0x0          |
| 19          | RESERVED               | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                           | RW          | 0x0          |
| 18          | RESERVED               | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                           | RW          | 0x0          |
| 17          | STATEULPS3_IRQ         | Lane #3 in ultralow-power state<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.  | RW          | 0x0          |
| 16          | STATEULPS2_IRQ         | Lane #2 in ultralow-power state<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.  | RW          | 0x0          |
| 15          | STATEULPS1_IRQ         | Lane #1 in ultralow-power state<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.  | RW          | 0x0          |
| 14          | RESERVED               | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                           | RW          | 0x0          |
| 13          | RESERVED               | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                           | RW          | 0x0          |
| 12          | ERRCONTROL3_IRQ        | Control error for lane #3<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.        | RW          | 0x0          |

## Display Subsystem Register Manual

www.ti.com

| Bits | Field Name      | Description                                                                                                                                                                                                   | Type | Reset |
|------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 11   | ERRCONTROL2_IRQ | Control error for lane #2<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                     | RW   | 0x0   |
| 10   | ERRCONTROL1_IRQ | Control error for lane #1<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                     | RW   | 0x0   |
| 9    | RESERVED        | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                        | RW   | 0x0   |
| 8    | RESERVED        | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                        | RW   | 0x0   |
| 7    | ERRESC3_IRQ     | Escape entry error for lane #3<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                | RW   | 0x0   |
| 6    | ERRESC2_IRQ     | Escape entry error for lane #2<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                | RW   | 0x0   |
| 5    | ERRESC1_IRQ     | Escape entry error for lane #1<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                | RW   | 0x0   |
| 4    | RESERVED        | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                        | RW   | 0x0   |
| 3    | RESERVED        | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                        | RW   | 0x0   |
| 2    | ERRSYNCESC3_IRQ | Low power Data transmission synchronization error for lane #3<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW   | 0x0   |
| 1    | ERRSYNCESC2_IRQ | Low power Data transmission synchronization error for lane #2<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW   | 0x0   |
| 0    | ERRSYNCESC1_IRQ | Low power Data transmission synchronization error for lane #1<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW   | 0x0   |

**Table 7-385. Register Call Summary for Register DSI\_COMPLEXIO\_IRQSTATUS**

Display Subsystem Integration

- DSI Interrupt Request: [0] [1]

Display Subsystem Functional Description

- Twakeup Timer: [2]

**Table 7-385. Register Call Summary for Register DSI\_COMPLEXIO\_IRQSTATUS (continued)**

Display Subsystem Basic Programming Model

- [Exiting ULPs: \[3\] \[4\]](#)
- [Error Handling: \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\]](#)

Display Subsystem Use Cases and Tips

- [Set Up DSI Protocol Engine: \[14\]](#)
- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O: \[15\]](#)

Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[16\]](#)
- [DSI Protocol Engine Registers: \[17\]](#)

**Table 7-386. DSI\_COMPLEXIO\_IRQENABLE**

|                         |                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0050                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4804 FC50                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | INTERRUPT ENABLE REGISTER - All errors from complex I/O |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|---------------------------|----------|----------|----------|----------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|----------|----------|-------------------|-------------------|-------------------|----------|----------|--------------------|--------------------|--------------------|----------|----------|-----------------|-----------------|--------------------|--------------------|--------------------|---|---|---|---|
| ULPSACTIVENOT_ALL1_IRQ_EN | RESERVED | RESERVED | RESERVED | RESERVED | ERRCONTENTIONLP1_3_IRQ_EN | ERRCONTENTIONLP0_3_IRQ_EN | ERRCONTENTIONLP1_2_IRQ_EN | ERRCONTENTIONLP0_2_IRQ_EN | ERRCONTENTIONLP1_1_IRQ_EN | ERRCONTENTIONLP0_1_IRQ_EN | RESERVED | RESERVED | STATEULPS3_IRQ_EN | STATEULPS2_IRQ_EN | STATEULPS1_IRQ_EN | RESERVED | RESERVED | ERRCONTROL3_IRQ_EN | ERRCONTROL2_IRQ_EN | ERRCONTROL1_IRQ_EN | RESERVED | RESERVED | ERRDESC1_IRQ_EN | ERRDESC2_IRQ_EN | ERRSYNCESC3_IRQ_EN | ERRSYNCESC2_IRQ_EN | ERRSYNCESC1_IRQ_EN |   |   |   |   |
| ULPSACTIVENOT_ALLO_IRQ_EN |          |          |          |          |                           |                           |                           |                           |                           |                           |          |          |                   |                   |                   |          |          |                    |                    |                    |          |          |                 |                 |                    |                    |                    |   |   |   |   |
| ULPSACTIVENOT_ALL1_IRQ_EN |          |          |          |          |                           |                           |                           |                           |                           |                           |          |          |                   |                   |                   |          |          |                    |                    |                    |          |          |                 |                 |                    |                    |                    |   |   |   |   |
| ULPSACTIVENOT_ALLO_IRQ_EN |          |          |          |          |                           |                           |                           |                           |                           |                           |          |          |                   |                   |                   |          |          |                    |                    |                    |          |          |                 |                 |                    |                    |                    |   |   |   |   |

| Bits | Field Name                | Description                                                                                                                                                                       | Type | Reset |
|------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31   | ULPSACTIVENOT_ALL1_IRQ_EN | All the ULPSActiveNOT signals corresponding to the lanes with TXULPSExit being high are high.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs | RW   | 0x0   |
| 30   | ULPSACTIVENOT_ALLO_IRQ_EN | All signals ULPSActiveNOT are 0<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                                                               | RW   | 0x0   |
| 29   | RESERVED                  | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                            | RW   | 0x0   |
| 28   | RESERVED                  | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                            | RW   | 0x0   |
| 27   | RESERVED                  | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                            | RW   | 0x0   |
| 26   | RESERVED                  | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                            | RW   | 0x0   |
| 25   | ERRCONTENTIONLP1_3_IRQ_EN | Contention LP1 error for lane #3<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                                                              | RW   | 0x0   |
| 24   | ERRCONTENTIONLP0_3_IRQ_EN | Contention LP0 error for lane #3<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                                                              | RW   | 0x0   |

## Display Subsystem Register Manual

www.ti.com

| Bits | Field Name                | Description                                                                                                  | Type | Reset |
|------|---------------------------|--------------------------------------------------------------------------------------------------------------|------|-------|
| 23   | ERRCONTENTIONLP1_2_IRQ_EN | Contention LP1 error for lane #2<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0x0   |
| 22   | ERRCONTENTIONLP0_2_IRQ_EN | Contention LP0 error for lane #2<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0x0   |
| 21   | ERRCONTENTIONLP1_1_IRQ_EN | Contention LP1 error for lane #1<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0x0   |
| 20   | ERRCONTENTIONLP0_1_IRQ_EN | Contention LP0 error for lane #1<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0x0   |
| 19   | RESERVED                  | Write 0s for future compatibility.<br>Reads returns 0.                                                       | RW   | 0x0   |
| 18   | RESERVED                  | Write 0s for future compatibility.<br>Reads returns 0.                                                       | RW   | 0x0   |
| 17   | STATEULPS3_IRQ_EN         | Lane #3 in ultralow-power state<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs  | RW   | 0x0   |
| 16   | STATEULPS2_IRQ_EN         | Lane #2 in ultralow-power state<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs  | RW   | 0x0   |
| 15   | STATEULPS1_IRQ_EN         | Lane #1 in ultralow-power state<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs  | RW   | 0x0   |
| 14   | RESERVED                  | Write 0s for future compatibility.<br>Reads returns 0.                                                       | RW   | 0x0   |
| 13   | RESERVED                  | Write 0s for future compatibility.<br>Reads returns 0.                                                       | RW   | 0x0   |
| 12   | ERRCONTROL3_IRQ_EN        | Control error for lane #3<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs        | RW   | 0x0   |
| 11   | ERRCONTROL2_IRQ_EN        | Control error for lane #2<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs        | RW   | 0x0   |
| 10   | ERRCONTROL1_IRQ_EN        | Control error for lane #1<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs        | RW   | 0x0   |
| 9    | RESERVED                  | Write 0s for future compatibility.<br>Reads returns 0.                                                       | RW   | 0x0   |
| 8    | RESERVED                  | Write 0s for future compatibility.<br>Reads returns 0.                                                       | RW   | 0x0   |
| 7    | ERRESC3_IRQ_EN            | Escape entry error for lane #3<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs   | RW   | 0x0   |
| 6    | ERRESC2_IRQ_EN            | Escape entry error for lane #2<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs   | RW   | 0x0   |
| 5    | ERRESC1_IRQ_EN            | Escape entry error for lane #1<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs   | RW   | 0x0   |

| Bits | Field Name         | Description                                                                                                                                   | Type | Reset |
|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4    | RESERVED           | Write 0s for future compatibility.<br>Reads returns 0.                                                                                        | RW   | 0x0   |
| 3    | RESERVED           | Write 0s for future compatibility.<br>Reads returns 0.                                                                                        | RW   | 0x0   |
| 2    | ERRSYNCESC3_IRQ_EN | Low power Data transmission synchronization error for lane #3<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0x0   |
| 1    | ERRSYNCESC2_IRQ_EN | Low power Data transmission synchronization error for lane #2<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0x0   |
| 0    | ERRSYNCESC1_IRQ_EN | Low power Data transmission synchronization error for lane #1<br><br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0x0   |

**Table 7-387. Register Call Summary for Register DSI\_COMPLEXIO\_IRQENABLE**

## Display Subsystem Use Cases and Tips

- Set Up DSI Protocol Engine: [0]
- Configure DSI Protocol Engine, DSI PLL, and Complex I/O: [1]

## Display Subsystem Register Manual

- DSI Protocol Engine Register Mapping Summary: [2]

**Table 7-388. DSI\_CLK\_CTRL**

| Address Offset   | 0x0000 0054                                                                                                       |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Instance | DSI_PROTOCOL_ENGINE |    |    |    |   |   |   |  |
|------------------|-------------------------------------------------------------------------------------------------------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|---------------------|----|----|----|---|---|---|--|
| Physical Address | 0x4804 FC54                                                                                                       |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |                     |    |    |    |   |   |   |  |
| Description      | CLOCK CONTROL This register controls the CLOCK GENERATION. The register can be modified only when IF_EN is reset. |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |                     |    |    |    |   |   |   |  |
| Type             | RW                                                                                                                |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7        | 6                   | 5  | 4  | 3  | 2 | 1 | 0 |  |
| 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 |  |
| PLL_PWR_CMD      | PLL_PWR_STATUS                                                                                                    | RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          | LP_CLK_DIVISOR      |    |    |    |   |   |   |  |
|                  |                                                                                                                   |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |                     |    |    |    |   |   |   |  |
|                  |                                                                                                                   |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |                     |    |    |    |   |   |   |  |
|                  |                                                                                                                   |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |                     |    |    |    |   |   |   |  |
|                  |                                                                                                                   |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |                     |    |    |    |   |   |   |  |
|                  |                                                                                                                   |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |                     |    |    |    |   |   |   |  |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name                | Description                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|-------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | PLL_PWR_CMD               | <p>Command for power control of the DSI PLL Control module</p> <p>0x0: Command to change to OFF state</p> <p>0x1: Command to change to ON state for PLL only (HSDIVISER is OFF)</p> <p>0x2: Command to change to ON state for both PLL and HSDIVISER</p> <p>0x3: Command to change to ON state for both PLL and HSDIVISER (no clock output to the DSI complex I/O)</p>                       | RW   | 0x0   |
| 29:28 | PLL_PWR_STATUS            | <p>Status of the power control of the DSI PLL Control module</p> <p>0x0: DSI PLL Control module in OFF state</p> <p>0x1: DSI PLL Control module in ON state for PLL only (HSDIVISER is OFF)</p> <p>0x2: DSI PLL Control module in ON state for both PLL and HSDIVISER</p> <p>0x3: DSI PLL Control module in ON state for both PLL and HSDIVISER (no clock output to the DSI complex I/O)</p> | R    | 0x0   |
| 27:22 | RESERVED                  | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                       | RW   | 0x00  |
| 21    | LP_RX_SYNCHRO_ENABLE      | <p>Defines if the DSI functional clock is higher or lower than 30 MHz. The information is used to define synchronization to be used for RxValidEsc.</p> <p>0x0: The DSI functional clock is equal or slower than 30 MHz. The synchronization is falling/rising.</p> <p>0x1: The DSI functional clock is higher than 30 MHz. The synchronization is rising/rising.</p>                        | RW   | 0x0   |
| 20    | LP_CLK_ENABLE             | <p>Controls the gating of the TXCLKESC clock.</p> <p>0x0: Disabled. The clock is not generated. The value of LP_CLK_DIVISOR[12:0] bit field is not used and does not have to be programmed.</p> <p>0x1: Enabled. The clock is generated. The value of LP_CLK_DIVISOR[12:0] bit field is used and must be programmed.</p>                                                                     | RW   | 0x0   |
| 19    | HS_MANUAL_STOP_CTRL       | <p>In case HS_AUTO_STOP_ENABLE bit is set to 0 (reset value), the bit field allows manual control of the assertion/de-assertion of the signal DSIStrtClk by users.</p> <p>0x0: DSIStrtClk de-assertion unconditionally.</p> <p>0x1: DSIStrtClk assertion unconditionally.</p>                                                                                                                | RW   | 0x0   |
| 18    | HS_AUTO_STOP_ENABLE       | <p>Enables the automatic assertion/de-assertion of DSIStrtClk signal.</p> <p>0x0: Auto mode disabled.</p> <p>0x1: Auto mode enabled.</p>                                                                                                                                                                                                                                                     | RW   | 0x0   |
| 17:16 | LP_CLK_NULL_PACKET_SIZE   | Indicates the size of LP NULL Packets to be sent automatically when after the last LP packet transfer. It is used by the receiver to drain its internal pipeline. The valid values are from 0 to 3 bytes for the payload size.                                                                                                                                                               | RW   | 0x0   |
| 15    | LP_CLK_NULL_PACKET_ENABLE | <p>Enables the generation of NULL packet in low speed.</p> <p>0x0: Disabled. The NULL packet is not sent in LP mode after the last LP packet.</p> <p>0x1: Enabled. The NULL packet is sent in LP mode after the last LP packet.</p>                                                                                                                                                          | RW   | 0x0   |
| 14    | CIO_CLK_ICG               | <p>Controls the signal for gating the L3_ICLK clock provided to the complex I/O</p> <p>0x0: Disabled. The L3_ICLK clock to the DSI complex I/O is gated.</p> <p>0x1: Enabled. The L3_ICLK clock to the DSI complex I/O is not gated.</p>                                                                                                                                                     | RW   | 0x0   |

| Bits | Field Name        | Description                                                                                                                                                                                                                                                                                                                                                                         | Type | Reset  |
|------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 13   | DDR_CLK_ALWAYS_ON | <p>Defines if the DDR clock is also sent when there is no HS packets sent to the peripheral (low power mode). So TXRequest for the clock lane is not de-asserted.</p> <p>0x0: Disabled. The DDR clock is only provided when HS packets are sent.</p> <p>0x1: Enabled. The DDR clock is always sent to the peripheral regardless of the state of the data lanes (HS or LP mode).</p> | RW   | 0x0    |
| 12:0 | LP_CLK_DIVISOR    | <p>Defines the ratio to be used for the generation of the low-power mode clock from DSI functional clock.</p> <p>The supported values are from 1 to 8191(the value 0 is invalid). The output frequency must be in the range between 20 MHz and 32 kHz.</p>                                                                                                                          | RW   | 0x0001 |

**Table 7-389. Register Call Summary for Register DSI\_CLK\_CTRL**

## Display Subsystem Environment

- [Data/Clock Configuration: \[0\]](#) [\[1\]](#)

## Display Subsystem Functional Description

- [Clock Requirements: \[2\]](#) [\[3\]](#) [\[4\]](#) [\[5\]](#)
- [Extra LP Transitions: \[6\]](#) [\[7\]](#) [\[8\]](#)
- [Power Management: \[9\]](#)
- [DSI PLL Power Control Commands: \[10\]](#) [\[11\]](#) [\[12\]](#) [\[13\]](#) [\[14\]](#) [\[15\]](#)

## Display Subsystem Basic Programming Model

- [Entering ULPS: \[16\]](#)
- [Turn-Around Request in Transmit Mode: \[17\]](#)

## Display Subsystem Use Cases and Tips

- [Set Up DSI DLL: \[18\]](#) [\[19\]](#) [\[20\]](#)
- [Set Up DSI Protocol Engine: \[21\]](#)
- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O: \[22\]](#) [\[23\]](#) [\[24\]](#) [\[25\]](#) [\[26\]](#) [\[27\]](#) [\[28\]](#) [\[29\]](#)

## Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[30\]](#)
- [DSI Protocol Engine Registers: \[31\]](#) [\[32\]](#)

**Table 7-390. DSI\_TIMING1**

|                         |                                                                                                                                                                                                                                                                              |          |               |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |                     |                       |                   |                  |                       |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|---------------------|-----------------------|-------------------|------------------|-----------------------|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0058                                                                                                                                                                                                                                                                  |          |               |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |                     |                       |                   |                  |                       |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4804 FC58                                                                                                                                                                                                                                                                  |          |               |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b> | DSI_PROTOCOL_ENGINE |                       |                   |                  |                       |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
| <b>Description</b>      | TIMING1 REGISTER This register controls the DSI Protocol Engine module timers. Any bit field can be modified while <a href="#">DSI_CTRL.IF_EN</a> is set to 1. It is used to indicate the number of DSI_FCLK clock cycles for the timers FORCE_TX_STOP_TIMER and TA_TO_TIMER |          |               |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |                     |                       |                   |                  |                       |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                           |          |               |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |                     |                       |                   |                  |                       |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |
| TA_TO                   | TA_TO_X16                                                                                                                                                                                                                                                                    | TA_TO_X8 | TA_TO_COUNTER |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |                     | FORCE_TX_STOP_MODE_IO | STOP_STATE_X16_IO | STOP_STATE_X4_IO | STOP_STATE_COUNTER_IO |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name            | Description                                                                                                                                                                                                                                                                                                         | Type | Reset  |
|-------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31    | TA_TO                 | Enables the turn-around timer<br><br>0x0: Turn-around counter is disabled.<br><br>0x1: Turn-around counter is enabled (required to receive TA interrupt in case the turn-around procedure is not successful).                                                                                                       | RW   | 0x0    |
| 30    | TA_TO_X16             | Multiplication factor for the number of DSI_FCLK clock cycles defined in TA_TO_COUNTER bit field<br><br>0x0: The number of DSI_FCLK clock cycles defined in TA_TO_COUNTER is multiplied by 1x<br><br>0x1: The number of DSI_FCLK clock cycles defined in TA_TO_COUNTER is multiplied by 16x                         | RW   | 0x1    |
| 29    | TA_TO_X8              | Multiplication factor for the number of DSI_FCLK clock cycles defined in TA_TO_COUNTER bit field<br><br>0x0: The number of DSI_FCLK clock cycles defined in TA_TO_COUNTER is multiplied by 1x<br><br>0x1: The number of DSI_FCLK clock cycles defined in TA_TO_COUNTER is multiplied by 8x                          | RW   | 0x1    |
| 28:16 | TA_TO_COUNTER         | Turn around counter. It indicates the number of DSI_FCLK clock cycles to wait for the change of the Direction PPI signal according to the TurnRequest signal<br><br>The value is from 0 to 8191.                                                                                                                    | RW   | 0x1FFF |
| 15    | FORCE_TX_STOP_MODE_IO | Control of ForceTxStopMode signal<br><br>0x0: De-assertion of ForceTxStopMode. The hardware reset the bit at the end of the ForceTXStopMode assertion. The SW can reset the bit to stop the assertion of the ForceTXStopMode signal prior to the completion of the period.<br><br>0x1: Assertion of ForceTxStopMode | RW   | 0x0    |
| 14    | STOP_STATE_X16_IO     | Multiplication factor for the number of DSI_FCLK clock cycles defined in STOP_STATE_COUNTER_IO bit field<br><br>0x0: The number of DSI_FCLK clock cycles defined in STOP_STATE_COUNTER_IO is multiplied by 1x<br><br>0x1: The number of DSI_FCLK clock cycles defined in STOP_STATE_COUNTER_IO is multiplied by 16x | RW   | 0x1    |
| 13    | STOP_STATE_X4_IO      | Multiplication factor for the number of DSI_FCLK clock cycles defined in STOP_STATE_COUNTER_IO bit field<br><br>0x0: The number of DSI_FCLK clock cycles defined in STOP_STATE_COUNTER_IO is multiplied by 1x<br><br>0x1: The number of DSI_FCLK clock cycles defined in STOP_STATE_COUNTER_IO is multiplied by 4x  | RW   | 0x1    |
| 12:0  | STOP_STATE_COUNTER_IO | Stop state counter. It indicates the number of DSI_FCLK clock cycles to assert ForceTXStopMode signal. The value is from 0 to 8191.                                                                                                                                                                                 | RW   | 0x1FFF |

**Table 7-391. Register Call Summary for Register DSI\_TIMING1**

## Display Subsystem Functional Description

- [ForceTxStopMode FSM](#): [0] [1] [2] [3] [4]
- [TurnRequest FSM](#): [5] [6] [7] [8] [9]
- [LP RX Timer](#): [10]

## Display Subsystem Basic Programming Model

- [Video Mode Transfer](#): [11] [12]
- [Command Mode Transfer Example 1](#): [13] [14]
- [Command Mode Transfer Example 2](#): [15] [16]

## Display Subsystem Use Cases and Tips

- [Set Up DSI Protocol Engine](#): [17]
- [Drive Stop State](#): [18] [19]
- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O](#): [20] [21] [22] [23] [24] [25]

## Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary](#): [26]

**Table 7-392. DSI\_TIMING2**

|                         |                                                                                                                                                                                                                                                                          |                 |                     |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------------------|
| <b>Address Offset</b>   | 0x0000 005C                                                                                                                                                                                                                                                              |                 |                     |
| <b>Physical Address</b> | 0x4804 FC5C                                                                                                                                                                                                                                                              | <b>Instance</b> | DSI_PROTOCOL_ENGINE |
| <b>Description</b>      | TIMING2 REGISTER This register controls the DSI Protocol Engine module timers. Any bit field can be modified while <a href="#">DSI_CTRL(IF_EN)</a> is set to 1. It is used to indicate the number of TxByteClkHS clock cycles for the timers HS_TX_TIMER and LP_RX_TIMER |                 |                     |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                       |                 |                     |



| Bits  | Field Name       | Description                                                                                                                                                                                                                                                                                                                                        | Type | Reset  |
|-------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31    | HS_TX_TO         | <p>Enables the HS TX timer.</p> <p>0x0: Turn-around counter is disabled.</p> <p>0x1: Turn-around counter is enabled (required to receive TA interrupt in case the turn-around procedure is not successful).</p>                                                                                                                                    | RW   | 0x0    |
| 30    | HS_TX_TO_X16     | <p>Multiplication factor for the number of TxByteClkHS functional clock cycles defined in HS_TX_COUNTER bit field</p> <p>0x0: The number of TxByteClkHS functional clock cycles defined in HS_TX_TO_COUNTER is multiplied by 1x</p> <p>0x1: The number of TxByteClkHS functional clock cycles defined in HS_TX_TO_COUNTER is multiplied by 16x</p> | RW   | 0x1    |
| 29    | HS_TX_TO_X8      | <p>Multiplication factor for the number of TxByteClkHS functional clock cycles defined in HS_TX_COUNTER bit</p> <p>0x0: The number of TxByteClkHS functional clock cycles defined in HS_TX_TO_COUNTER is multiplied by 1x</p> <p>0x1: The number of TxByteClkHS functional clock cycles defined in HS_TX_TO_COUNTER is multiplied by 8x</p>        | RW   | 0x1    |
| 28:16 | HS_TX_TO_COUNTER | HS_TX_TIMER counter. It indicates the number of TxByteClkHS function clock cycles for the HS TX timer.<br>The value is from 0 to 8191.                                                                                                                                                                                                             | RW   | 0x1FFF |
| 15    | LP_RX_TO         | <p>Enables the LP RX timer.</p> <p>0x0: Turn-around counter is disabled.</p> <p>0x1: Turn-around counter is enabled (required to receive TA interrupt in case the turn-around procedure is not successful).</p>                                                                                                                                    | RW   | 0x0    |
| 14    | LP_RX_TO_X16     | <p>Multiplication factor for the number of DSI_FCLK clock cycles defined in LP_RX_COUNTER bit field</p> <p>0x0: The number of DSI_FCLK clock cycles defined in LP_RX_TO_COUNTER is multiplied by 1x</p> <p>0x1: The number of DSI_FCLK clock cycles defined in LP_RX_TO_COUNTER is multiplied by 16x</p>                                           | RW   | 0x1    |
| 13    | LP_RX_TO_X4      | <p>Multiplication factor for the number of DSI_FCLK clock cycles defined in LP_RX_COUNTER bit</p> <p>0x0: The number of DSI_FCLK clock cycles defined in LP_RX_TO_COUNTER is multiplied by 1x</p> <p>0x1: The number of DSI_FCLK clock cycles defined in LP_RX_TO_COUNTER is multiplied by 4x</p>                                                  | RW   | 0x1    |
| 12:0  | LP_RX_TO_COUNTER | LP_RX_TIMER counter. It indicates the number of DSI_FCLK clock cycles for the LP RX timer.<br>The value is from 0 to 8191.                                                                                                                                                                                                                         | RW   | 0x1FFF |

**Table 7-393. Register Call Summary for Register DSI\_TIMING2**

## Display Subsystem Functional Description

- HS TX Timer: [0]
- LP RX Timer: [1] [2] [3] [4] [5]

## Display Subsystem Use Cases and Tips

- Set Up DSI Protocol Engine: [6]
- Configure DSI Protocol Engine, DSI PLL, and Complex I/O: [7] [8] [9] [10] [11] [12]

## Display Subsystem Register Manual

- DSI Protocol Engine Register Mapping Summary: [13]

**Table 7-394. DSI\_VM\_TIMING1**

|                         |                                                                         |                 |                     |
|-------------------------|-------------------------------------------------------------------------|-----------------|---------------------|
| <b>Address Offset</b>   | 0x0000 0060                                                             | <b>Instance</b> | DSI_PROTOCOL_ENGINE |
| <b>Physical Address</b> | 0x4804 FC60                                                             |                 |                     |
| <b>Description</b>      | VIDEO MODE TIMING REGISTER This register defines the video mode timing. |                 |                     |
| <b>Type</b>             | RW                                                                      |                 |                     |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| HSA                     | HFP                     |                       | HBP             |

| Bits  | Field Name | Description                                                                                                                                          | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | HSA        | Defines the horizontal Sync active period used in video mode in number of byte clock cycles (TxByteClkHS)<br>The supported values are from 0 to 255. | RW   | 0x00  |
| 23:12 | HFP        | Defines the horizontal front porch used in video mode in number of byte clock cycles (TxByteClkHS)<br>The supported values are from 0 to 255         | RW   | 0x000 |
| 11:0  | HBP        | Defines the horizontal back porch used in video mode in number of byte clock cycles (TxByteClkHS)<br>The supported values are from 0 to 255          | RW   | 0x000 |

**Table 7-395. Register Call Summary for Register DSI\_VM\_TIMING1**

## Display Subsystem Basic Programming Model

- Video Mode: [0]
- Video Mode Transfer: [1]

## Display Subsystem Use Cases and Tips

- Set Up DSI Protocol Engine: [2]

## Display Subsystem Register Manual

- DSI Protocol Engine Register Mapping Summary: [3]

**Table 7-396. DSI\_VM\_TIMING2**

|                         |                                                                         |                 |                     |
|-------------------------|-------------------------------------------------------------------------|-----------------|---------------------|
| <b>Address Offset</b>   | 0x0000 0064                                                             | <b>Instance</b> | DSI_PROTOCOL_ENGINE |
| <b>Physical Address</b> | 0x4804 FC64                                                             |                 |                     |
| <b>Description</b>      | VIDEO MODE TIMING REGISTER This register defines the video mode timing. |                 |                     |
| <b>Type</b>             | RW                                                                      |                 |                     |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | WINDOW_SYNC             | VSA                   | VFP             |

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                   | Type | Reset |
|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED    | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                        | RW   | 0x0   |
| 27:24 | WINDOW_SYNC | Number of TxByteClkHS clock cycles for the synchronization window. An interrupt for synchronization lost is generated when the received synchronization on video port is not inside the window. The DSI protocol engine does not change its own timings if the synch is inside the window. The valid values are from 0 to 15. | RW   | 0x0   |
| 23:16 | VSA         | Defines the vertical Sync active period used in video mode in number of lines.<br>The supported values are from 0 to 255 It is used to generate the short packet for End of Vertical synchronization.                                                                                                                         | RW   | 0x00  |
| 15:8  | VFP         | Defines the vertical front porch used in video mode in number of lines.<br>The supported values are from 0 to 255                                                                                                                                                                                                             | RW   | 0x00  |
| 7:0   | VBP         | Defines the vertical back porch used in video mode in number of lines.<br>The supported values are from 0 to 255                                                                                                                                                                                                              | RW   | 0x00  |

**Table 7-397. Register Call Summary for Register DSI\_VM\_TIMING2**

Display Subsystem Environment

- [Video Port Used for Video Mode: \[0\]](#)

Display Subsystem Basic Programming Model

- [Video Mode: \[1\] \[2\]](#)

Display Subsystem Use Cases and Tips

- [Set Up DSI Protocol Engine: \[3\]](#)

Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[4\]](#)

**Table 7-398. DSI\_VM\_TIMING3**

|                         |                                                                         |  |  |  |  |  |  |  |                       |                 |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0068                                                             |  |  |  |  |  |  |  |                       |                 |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4804 FC68                                                             |  |  |  |  |  |  |  |                       |                 | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VIDEO MODE TIMING REGISTER This register defines the video mode timing. |  |  |  |  |  |  |  |                       |                 |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                      |  |  |  |  |  |  |  |                       |                 |                 |  |  |  |  |  |  |  |  |  |  |  |
| 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 |                 |  |  |  |  |  |  |  |  |  |  |  |
|                         | TL                                                                      |  |  |  |  |  |  |  |                       | VACT            |                 |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                      | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | TL         | Defines the number of length of the line in video mode in number of byte clock cycles (TxByteClkHS)<br>The supported values are from 0 to 8192. The values from 8193 to 65535 are not supported. | RW   | 0x0000 |
| 15:0  | VACT       | Defines the number of active lines used in video mode.<br>The supported values are from 0 to 65535                                                                                               | RW   | 0x0000 |

**Table 7-399. Register Call Summary for Register DSI\_VM\_TIMING3**

Display Subsystem Environment

- [Video Port Used for Video Mode: \[0\]](#)

Display Subsystem Basic Programming Model

- [Video Mode: \[1\]](#)

Display Subsystem Use Cases and Tips

- [Set Up DSI Protocol Engine: \[2\]](#)

Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[3\]](#)

**Table 7-400. DSI\_CLK\_TIMING**

| <b>Address Offset</b>   | 0x0000 006C                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                         |                 |  |  |  |  |             |  |  |  |              |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|-------------|--|--|--|--------------|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x4804 FC6C                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                         |                 |  |  |  |  |             |  |  |  |              |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | CLOCK TIMING REGISTER This register controls the DSI Protocol Engine module timers. This register should not be modified while <a href="#">DSI_CTRL.IF_EN</a> is set to 1. |                                                                                                                                                                                                                                                                                                                         |                 |  |  |  |  |             |  |  |  |              |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                         |                 |  |  |  |  |             |  |  |  |              |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |             |  |  |  |              |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                         |                 |  |  |  |  | DDR_CLK_PRE |  |  |  | DDR_CLK_POST |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                                                                                                                                 | Description                                                                                                                                                                                                                                                                                                             |                 |  |  |  |  |             |  |  |  |              |  |  |  |  |  |  |  |  |  |
| 31:16                   | RESERVED                                                                                                                                                                   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                  |                 |  |  |  |  |             |  |  |  |              |  |  |  |  |  |  |  |  |  |
| 15:8                    | DDR_CLK_PRE                                                                                                                                                                | Indicates the number of TxByteClkHS cycles between the start of the DDR clock and the assertion of the data request signal. The values from 1 to 255 are valid. The value 0 is reserved. The value is not used if <a href="#">DSI_CLK_CTRL[13]</a> DDR_CLK_ALWAYS_ON is set to 1 since the DDR clock is always present. |                 |  |  |  |  |             |  |  |  |              |  |  |  |  |  |  |  |  |  |
| 7:0                     | DDR_CLK_POST                                                                                                                                                               | Indicates the number of TxByteClkHS cycles after the de-assertion of the data request signal and the stop of the DDR clock. The values from 1 to 255 are valid. The value 0 is reserved. The value is not used if <a href="#">DSI_CLK_CTRL[13]</a> DDR_CLK_ALWAYS_ON is set to 1 since the DDR clock is always present. |                 |  |  |  |  |             |  |  |  |              |  |  |  |  |  |  |  |  |  |

**Table 7-401. Register Call Summary for Register DSI\_CLK\_TIMING**

## Display Subsystem Functional Description

- Timing Parameters for an LP to HS Transaction: [0] [1]
- Timing Parameters for an HS to LP Transaction: [2] [3]

## Display Subsystem Use Cases and Tips

- Set Up DSI Protocol Engine: [4]
- Configure DSI Protocol Engine, DSI PLL, and Complex I/O: [5]

## Display Subsystem Register Manual

- DSI Protocol Engine Register Mapping Summary: [6]

**Table 7-402. DSI\_TX\_FIFO\_VC\_SIZE**

|                         |                                                                                                                                              |                       |                 |          |              |               |          |              |               |          |              |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--------------|---------------|----------|--------------|---------------|----------|--------------|--|--|--|
| <b>Address Offset</b>   | 0x0000 0070                                                                                                                                  |                       |                 |          |              |               |          |              |               |          |              |  |  |  |
| <b>Physical Address</b> | 0x4804 FC70                                                                                                                                  |                       |                 |          |              |               |          |              |               |          |              |  |  |  |
| <b>Description</b>      | Defines the corresponding memory entries allocated for each VC. The VC must be disabled to allocate/un-allocate some entries in the TX FIFO. |                       |                 |          |              |               |          |              |               |          |              |  |  |  |
| <b>Type</b>             | RW                                                                                                                                           |                       |                 |          |              |               |          |              |               |          |              |  |  |  |
| 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 |          |              |               |          |              |               |          |              |  |  |  |
| VC3_FIFO_SIZE           | RESERVED                                                                                                                                     | VC3_FIFO_ADD          | VC2_FIFO_SIZE   | RESERVED | VC2_FIFO_ADD | VC1_FIFO_SIZE | RESERVED | VC1_FIFO_ADD | VC0_FIFO_SIZE | RESERVED | VC0_FIFO_ADD |  |  |  |

| Bits  | Field Name    | Description                                                                                            | Type | Reset |
|-------|---------------|--------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | VC3_FIFO_SIZE | Size of the FIFO allocated for VC 3. For a complete description, refer to <a href="#">Table 7-68</a> . | RW   | 0x0   |
| 27    | RESERVED      | Write 0s for future compatibility.<br>Reads returns 0.                                                 | RW   | 0x0   |

| Bits  | Field Name    | Description                                                                                                            | Type | Reset |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------|------|-------|
| 26:24 | VC3_FIFO_ADD  | Address of the space allocated in the FIFO for VC 3. For a complete description, refer to <a href="#">Table 7-69</a> . | RW   | 0x0   |
| 23:20 | VC2_FIFO_SIZE | Size of the FIFO allocated for VC 2. For a complete description, refer to <a href="#">Table 7-68</a> .                 | RW   | 0x0   |
| 19    | RESERVED      | Write 0s for future compatibility.<br>Reads returns 0.                                                                 | RW   | 0x0   |
| 18:16 | VC2_FIFO_ADD  | Address of the space allocated in the FIFO for VC 2. For a complete description, refer to <a href="#">Table 7-69</a> . | RW   | 0x0   |
| 15:12 | VC1_FIFO_SIZE | Size of the FIFO allocated for VC 1. For a complete description, refer to <a href="#">Table 7-68</a> .                 | RW   | 0x0   |
| 11    | RESERVED      | Write 0s for future compatibility.<br>Reads returns 0.                                                                 | RW   | 0x0   |
| 10:8  | VC1_FIFO_ADD  | Address of the space allocated in the FIFO for VC 1. For a complete description, refer to <a href="#">Table 7-69</a> . | RW   | 0x0   |
| 7:4   | VC0_FIFO_SIZE | Size of the FIFO allocated for VC 0. For a complete description, refer to <a href="#">Table 7-68</a> .                 | RW   | 0x0   |
| 3     | RESERVED      | Write 0s for future compatibility.<br>Reads returns 0.                                                                 | RW   | 0x0   |
| 2:0   | VC0_FIFO_ADD  | Address of the space allocated in the FIFO for VC 0. For a complete description, refer to <a href="#">Table 7-69</a> . | RW   | 0x0   |

**Table 7-403. Register Call Summary for Register DSI\_TX\_FIFO\_VC\_SIZE**

Display Subsystem Basic Programming Model

- [Command Mode TX FIFO: \[0\] \[1\] \[2\] \[3\] \[4\]](#)

Display Subsystem Use Cases and Tips

- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O: \[5\]](#)

Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[6\]](#)

**Table 7-404. DSI\_RX\_FIFO\_VC\_SIZE**

| Address Offset          |                         | 0x0000 0074                                                                                                                                                    | Instance        |          | DSI_PROTOCOL_ENGINE |               |          |              |               |          |              |
|-------------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------|---------------------|---------------|----------|--------------|---------------|----------|--------------|
| Physical Address        |                         | 0x4804 FC74                                                                                                                                                    |                 |          |                     |               |          |              |               |          |              |
| Description             |                         | Defines the corresponding memory entries allocated for each VC and the addresses. The VC must be disabled to allocate/un-allocate some entries in the RX FIFO. |                 |          |                     |               |          |              |               |          |              |
| Type                    | RW                      |                                                                                                                                                                |                 |          |                     |               |          |              |               |          |              |
| 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 |          |                     |               |          |              |               |          |              |
| VC3_FIFO_SIZE           | RESERVED                | VC3_FIFO_ADD                                                                                                                                                   | VC2_FIFO_SIZE   | RESERVED | VC2_FIFO_ADD        | VC1_FIFO_SIZE | RESERVED | VC1_FIFO_ADD | VCO_FIFO_SIZE | RESERVED | VCO_FIFO_ADD |

| Bits  | Field Name    | Description                                                                                                            | Type | Reset |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | VC3_FIFO_SIZE | Size of the FIFO allocated for VC 3. For a complete description, refer to <a href="#">Table 7-68</a> .                 | RW   | 0x0   |
| 27    | RESERVED      | Write 0s for future compatibility.<br>Reads returns 0.                                                                 | RW   | 0x0   |
| 26:24 | VC3_FIFO_ADD  | Address of the space allocated in the FIFO for VC 3. For a complete description, refer to <a href="#">Table 7-69</a> . | RW   | 0x0   |
| 23:20 | VC2_FIFO_SIZE | Size of the FIFO allocated for VC 2. For a complete description, refer to <a href="#">Table 7-68</a> .                 | RW   | 0x0   |

| Bits  | Field Name    | Description                                                                                                            | Type | Reset |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------|------|-------|
| 19    | RESERVED      | Write 0s for future compatibility.<br>Reads returns 0.                                                                 | RW   | 0x0   |
| 18:16 | VC2_FIFO_ADD  | Address of the space allocated in the FIFO for VC 2. For a complete description, refer to <a href="#">Table 7-69</a> . | RW   | 0x0   |
| 15:12 | VC1_FIFO_SIZE | Size of the FIFO allocated for VC 1. For a complete description, refer to <a href="#">Table 7-68</a> .                 | RW   | 0x0   |
| 11    | RESERVED      | Write 0s for future compatibility.<br>Reads returns 0.                                                                 | RW   | 0x0   |
| 10:8  | VC1_FIFO_ADD  | Address of the space allocated in the FIFO for VC 1. For a complete description, refer to <a href="#">Table 7-69</a> . | RW   | 0x0   |
| 7:4   | VC0_FIFO_SIZE | Size of the FIFO allocated for VC 0. For a complete description, refer to <a href="#">Table 7-68</a> .                 | RW   | 0x0   |
| 3     | RESERVED      | Write 0s for future compatibility.<br>Reads returns 0.                                                                 | RW   | 0x0   |
| 2:0   | VC0_FIFO_ADD  | Address of the space allocated in the FIFO for VC 0. For a complete description, refer to <a href="#">Table 7-69</a> . | RW   | 0x0   |

**Table 7-405. Register Call Summary for Register DSI\_RX\_FIFO\_VC\_SIZE**

Display Subsystem Basic Programming Model

- [Command Mode RX FIFO: \[0\] \[1\] \[2\]](#)

Display Subsystem Use Cases and Tips

- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O: \[3\]](#)

Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[4\]](#)

**Table 7-406. DSI\_COMPLEXIO\_CFG2**

| Address Offset          | 0x0000 0078                                                                                                                    |  |         |         |                       |  |                 |  |          |  |          |  |          |  |          | Instance | DSI_PROTOCOL_ENGINE |  |                 |  |                 |  |          |  |          |  |                 |  |                 |  |                 |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|--|---------|---------|-----------------------|--|-----------------|--|----------|--|----------|--|----------|--|----------|----------|---------------------|--|-----------------|--|-----------------|--|----------|--|----------|--|-----------------|--|-----------------|--|-----------------|--|
| Physical Address        | 0x4804 FC78                                                                                                                    |  |         |         |                       |  |                 |  |          |  |          |  |          |  |          |          |                     |  |                 |  |                 |  |          |  |          |  |                 |  |                 |  |                 |  |
| Description             | COMPLEXIO CONFIGURATION REGISTER for the complex I/O This register contains the lane configuration for the ULPS for each lane. |  |         |         |                       |  |                 |  |          |  |          |  |          |  |          |          |                     |  |                 |  |                 |  |          |  |          |  |                 |  |                 |  |                 |  |
| Type                    | RW                                                                                                                             |  |         |         |                       |  |                 |  |          |  |          |  |          |  |          |          |                     |  |                 |  |                 |  |          |  |          |  |                 |  |                 |  |                 |  |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16                                                                                                        |  | LP_BUSY | HS_BUSY | 15 14 13 12 11 10 9 8 |  | 7 6 5 4 3 2 1 0 |  | RESERVED |  | RESERVED |  | RESERVED |  | RESERVED |          | LANE3_ULPS_SIG2     |  | LANE2_ULPS_SIG2 |  | LANE1_ULPS_SIG2 |  | RESERVED |  | RESERVED |  | LANE3_ULPS_SIG1 |  | LANE2_ULPS_SIG1 |  | LANE1_ULPS_SIG1 |  |
| RESERVED                |                                                                                                                                |  |         |         |                       |  |                 |  |          |  |          |  |          |  |          |          |                     |  |                 |  |                 |  |          |  |          |  |                 |  |                 |  |                 |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                 | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:18 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                      | RW   | 0x0000 |
| 17    | LP_BUSY    | Indicates when there are still pending operations for VCs configured for LP mode. Forced to 1 when at least one VC is enabled and configured for LP mode.<br><br>Read 0x0: LP logic is idle<br>Read 0x1: LP logic is active | R    | 0x0    |
| 16    | HS_BUSY    | Indicates when there are still pending operations for VCs configured for HS mode. Forced to 1 when at least one VC is enabled and configured for HS mode<br><br>Read 0x0: HS logic is idle<br>Read 0x1: HS logic is active  | R    | 0x0    |

| <b>Bits</b> | <b>Field Name</b>   | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <b>Type</b> | <b>Reset</b> |
|-------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 15:10       | RESERVED            | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW          | 0x00         |
| 9           | RESERVED            | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW          | 0x0          |
| 8           | RESERVED            | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW          | 0x0          |
| 7           | LANE3_ULPS_<br>SIG2 | Enables the ULPS for the lane #3. The HW should change the state of the lane to ULPS only when it is in stop state and there is no data pending inside the DSI protocol engine and the DSI protocol engine has control of the bus (BTA has not been sent).<br><br>The state of the signal TxRequestEsc is change if lane #3 is a data lane.<br>The state of the signal TxUlpsClk is change if lane #3 is a clock lane.<br>There will be a latency depending on the frequency of TxClkExc. This bit should be read back to confirm a write has been effective.<br><br>0x0: READ: Inactive state effective<br>WRITE: Request to change to inactive state<br><br>0x1: READ: Active state effective<br>WRITE: Change request to active. If the lane is a data lane,<br>TxRequestEsc is asserted and synchronously TxUlpsEsc is asserted for one period of TxClkEsc. | RW          | 0x0          |
| 6           | LANE2_ULPS_<br>SIG2 | Enables the ULPS for the lane #2. The HW should change the state of the lane to ULPS only when it is in stop state and there is no data pending inside the DSI protocol engine and the DSI protocol engine has control of the bus (BTA has not been sent).<br><br>The state of the signal TxRequestEsc is change if lane #2 is a data lane.<br>The state of the signal TxUlpsClk is change if lane #2 is a clock lane.<br>There will be a latency depending on the frequency of TxClkExc. This bit should be read back to confirm a write has been effective.<br><br>0x0: READ: Inactive state effective<br>WRITE: Request to change to inactive state<br><br>0x1: READ: ACTIVE state effective<br>WRITE: Change request to active. If the lane is a data lane,<br>TxRequestEsc is asserted and synchronously TxUlpsEsc is asserted for one period of TxClkEsc. | RW          | 0x0          |
| 5           | LANE1_ULPS_<br>SIG2 | Enables the ULPS for the lane #1. The HW should change the state of the lane to ULPS only when it is in stop state and there is no data pending inside the DSI protocol engine and the DSI protocol engine has control of the bus (BTA has not been sent).<br><br>The state of the signal TxRequestEsc is change if lane #1 is a data lane.<br>The state of the signal TxUlpsClk is change if lane #1 is a clock lane.<br>There will be a latency depending on the frequency of TxClkExc. This bit should be read back to confirm a write has been effective.<br><br>0x0: READ: Inactive state effective<br>WRITE: Request to change to inactive state<br><br>0x1: READ: ACTIVE state effective<br>WRITE: Change request to active. If the lane is a data lane,<br>TxRequestEsc is asserted and synchronously TxUlpsEsc is asserted for one period of TxClkEsc. | RW          | 0x0          |
| 4           | RESERVED            | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW          | 0x0          |
| 3           | RESERVED            | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW          | 0x0          |

| Bits | Field Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Type | Reset |
|------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 2    | LANE3_ULPS_SIG1 | <p>Enables the ULPS for the lane #3. The HW should change the state of the lane to ULPS only when it is in stop state and there is no data pending inside the DSI protocol engine and the DSI protocol engine has control of the bus (BTA has not been sent).</p> <p>The state of the signal TxULPSExit is changed if lane #3 is a clock lane. There will be a latency depending on the frequency of TxClkExc.</p> <p>This bit should be read back to confirm a write has been effective.</p> <p>0x0: READ: Inactive state effective<br/>WRITE: Request to change to inactive state</p> <p>0x1: READ: ACTIVE state effective<br/>WRITE: Change request to active. If the lane is a data lane, TxRequestEsc is asserted and synchronously TxUlpsEsc is asserted for one period of TxClkEsc.</p> | RW   | 0x0   |
| 1    | LANE2_ULPS_SIG1 | <p>Enables the ULPS for the lane #2. The HW must change the state of the lane to ULPS only when it is in stop state and there is no data pending inside the DSI protocol engine and the DSI protocol engine has control of the bus (BTA has not been sent).</p> <p>The state of the signal TxULPSExit is changed if lane #3 is a clock lane. There will be a latency depending on the frequency of TxClkExc. This bit should be read back to confirm a write has been effective.</p> <p>0x0: READ: Inactive state effective<br/>WRITE: Request to change to inactive state</p> <p>0x1: READ: ACTIVE state effective<br/>WRITE: Change request to active. If the lane is a data lane, TxRequestEsc is asserted and synchronously TxUlpsEsc is asserted for one period of TxClkEsc.</p>          | RW   | 0x0   |
| 0    | LANE1_ULPS_SIG1 | <p>Enables the ULPS for the lane #1. The HW must change the state of the lane to ULPS only when it is in stop state and there is no data pending inside the DSI protocol engine and the DSI protocol engine has control of the bus (BTA has not been sent).</p> <p>The state of the signal TxULPSExit is changed if lane #3 is a clock lane. There will be a latency depending on the frequency of TxClkExc. This bit should be read back to confirm a write has been effective.</p> <p>0x0: READ: Inactive state effective<br/>WRITE: Request to change to inactive state</p> <p>0x1: READ: ACTIVE state effective<br/>WRITE: Change request to active. If the lane is a data lane, TxRequestEsc is asserted and synchronously TxUlpsEsc is asserted for one period of TxClkEsc.</p>          | RW   | 0x0   |

**Table 7-407. Register Call Summary for Register DSI\_COMPLEXIO\_CFG2**

## Display Subsystem Environment

- [ULPS: \[0\]](#)

## Display Subsystem Basic Programming Model

- [Ultra-Low Power State: \[1\]](#)
- [Entering ULPS: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [Exiting ULPS: \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\] \[22\] \[23\] \[24\] \[25\] \[26\] \[27\]](#)

## Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[28\]](#)

**Table 7-408. DSI\_RX\_FIFO\_VC\_FULLNESS**

|                         |                                                           |                       |                     |
|-------------------------|-----------------------------------------------------------|-----------------------|---------------------|
| <b>Address Offset</b>   | 0x0000 007C                                               | <b>Instance</b>       | DSI_PROTOCOL_ENGINE |
| <b>Physical Address</b> | 0x4804 FC7C                                               |                       |                     |
| <b>Description</b>      | Defines the fullness of each space allocated for each VC. |                       |                     |
| <b>Type</b>             | R                                                         |                       |                     |
| 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     |
| VC3_FIFO_FULLNESS       | VC2_FIFO_FULLNESS                                         | VC1_FIFO_FULLNESS     | VC0_FIFO_FULLNESS   |

| Bits  | Field Name        | Description                                                                                                               | Type | Reset |
|-------|-------------------|---------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | VC3_FIFO_FULLNESS | Fullness of the FIFO allocated for VC 3.The valid values are from 0 to 127 corresponding to 1x33-bit,...up to 128x33-bit. | R    | 0x00  |
| 23:16 | VC2_FIFO_FULLNESS | Fullness of the FIFO allocated for VC 2.The valid values are from 0 to 127 corresponding to 1x33-bit,...up to 128x33-bit. | R    | 0x00  |
| 15:8  | VC1_FIFO_FULLNESS | Fullness of the FIFO allocated for VC 1.The valid values are from 0 to 127 corresponding to 1x33-bit,...up to 128x33-bit. | R    | 0x00  |
| 7:0   | VC0_FIFO_FULLNESS | Fullness of the FIFO allocated for VC 0.The valid values are from 0 to 127 corresponding to 1x33-bit,...up to 128x33-bit. | R    | 0x00  |

**Table 7-409. Register Call Summary for Register DSI\_RX\_FIFO\_VC\_FULLNESS**

- Display Subsystem Basic Programming Model
- [Command Mode DMA Requests: \[0\]](#)
- Display Subsystem Register Manual
- [DSI Protocol Engine Register Mapping Summary: \[1\]](#)

**Table 7-410. DSI\_VM\_TIMING4**

|                         |                                                                         |                       |                     |
|-------------------------|-------------------------------------------------------------------------|-----------------------|---------------------|
| <b>Address Offset</b>   | 0x0000 0080                                                             | <b>Instance</b>       | DSI_PROTOCOL_ENGINE |
| <b>Physical Address</b> | 0x4804 FC80                                                             |                       |                     |
| <b>Description</b>      | VIDEO MODE TIMING REGISTER This register defines the video mode timing. |                       |                     |
| <b>Type</b>             | RW                                                                      |                       |                     |
| 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     |
| RESERVED                | HSA_HS_INTERLEAVING                                                     | HFP_HS_INTERLEAVING   | HBP_HS_INTERLEAVING |

| Bits  | Field Name          | Description                                                                                                                                                                                             | Type | Reset |
|-------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | RESERVED            | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                  | RW   | 0x00  |
| 23:16 | HSA_HS_INTERLEAVING | Defines the number of TxByteClkHS cycles that can be used for interleaving high-speed command mode packet into Video Mode stream during HSA blanking period.<br>The supported values are from 0 to 255. | RW   | 0x00  |
| 15:8  | HFP_HS_INTERLEAVING | Defines the number of TxByteClkHS cycles that can be used for interleaving high-speed command mode packet into Video Mode stream during HFP blanking period.<br>The supported values are from 0 to 255  | RW   | 0x00  |
| 7:0   | HBP_HS_INTERLEAVING | Defines the number of TxByteClkHS cycles that can be used for interleaving high-speed command mode packet into Video Mode stream during HBP blanking period.<br>The supported values are from 0 to 255  | RW   | 0x00  |

**Table 7-411. Register Call Summary for Register DSI\_VM\_TIMING4**

Display Subsystem Functional Description

- [Interleaving Mode: \[0\] \[1\] \[2\]](#)

Display Subsystem Basic Programming Model

- [Video Mode: \[3\]](#)

Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[4\]](#)

**Table 7-412. DSI\_TX\_FIFO\_VC\_EMPTINESS**

|                         |                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0084                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4804 FC84                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Defines the emptiness of each space allocated for each VC. |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                    |
|-------------------------|-------------------------|-----------------------|--------------------|
| 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    |
| VC3_FIFO_EMPTINESS      | VC2_FIFO_EMPTINESS      | VC1_FIFO_EMPTINESS    | VC0_FIFO_EMPTINESS |

| Bits  | Field Name         | Description                                                                                                                | Type | Reset |
|-------|--------------------|----------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | VC3_FIFO_EMPTINESS | Emptiness of the FIFO allocated for VC 3.The valid values are from 0 to 127 corresponding to 1x33-bit,...up to 128x33-bit. | R    | 0x00  |
| 23:16 | VC2_FIFO_EMPTINESS | Emptiness of the FIFO allocated for VC 2.The valid values are from 0 to 127 corresponding to 1x33-bit,...up to 128x33-bit. | R    | 0x00  |
| 15:8  | VC1_FIFO_EMPTINESS | Emptiness of the FIFO allocated for VC 1.The valid values are from 0 to 127 corresponding to 1x33-bit,...up to 128x33-bit. | R    | 0x00  |
| 7:0   | VC0_FIFO_EMPTINESS | Emptiness of the FIFO allocated for VC 0.The valid values are from 0 to 127 corresponding to 1x33-bit,...up to 128x33-bit. | R    | 0x00  |

**Table 7-413. Register Call Summary for Register DSI\_TX\_FIFO\_VC\_EMPTINESS**

Display Subsystem Basic Programming Model

- [Command Mode TX FIFO: \[0\] \[1\]](#)

Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[2\]](#)

**Table 7-414. DSI\_VM\_TIMING5**

|                         |                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0088                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4804 FC88                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | VIDEO MODE TIMING REGISTER This register defines the video mode timing. |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                     |
|-------------------------|-------------------------|-----------------------|---------------------|
| 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     |
| RESERVED                | HSA_LP_INTERLEAVING     | HFP_LP_INTERLEAVING   | HBP_LP_INTERLEAVING |

| Bits  | Field Name          | Description                                                                                                                                                        | Type | Reset |
|-------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | RESERVED            | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                             | RW   | 0x00  |
| 23:16 | HSA_LP_INTERLEAVING | Defines the number of bytes for Low Power command mode packets that can be sent on PPI link during HSA blanking period.<br>The supported values are from 0 to 255. | RW   | 0x00  |
| 15:8  | HFP_LP_INTERLEAVING | Defines the number of bytes for Low Power command mode packets that can be sent on PPI link during HFP blanking period.<br>The supported values are from 0 to 255  | RW   | 0x00  |
| 7:0   | HBP_LP_INTERLEAVING | Defines the number of bytes for Low Power command mode packets that can be sent on PPI link during HBP blanking period.<br>The supported values are from 0 to 255  | RW   | 0x00  |

**Table 7-415. Register Call Summary for Register DSI\_VM\_TIMING5**

Display Subsystem Functional Description

- [Interleaving Mode: \[0\] \[1\] \[2\]](#)

Display Subsystem Basic Programming Model

- [Video Mode: \[3\]](#)

Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[4\]](#)

**Table 7-416. DSI\_VM\_TIMING6**

|                       |                                                                         |                         |             |                 |                     |
|-----------------------|-------------------------------------------------------------------------|-------------------------|-------------|-----------------|---------------------|
| <b>Address Offset</b> | 0x0000 008C                                                             | <b>Physical Address</b> | 0x4804 FC8C | <b>Instance</b> | DSI_PROTOCOL_ENGINE |
| <b>Description</b>    | VIDEO MODE TIMING REGISTER This register defines the video mode timing. |                         |             |                 |                     |
| <b>Type</b>           | RW                                                                      |                         |             |                 |                     |

|                                                                                             |                    |                    |
|---------------------------------------------------------------------------------------------|--------------------|--------------------|
| 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 | BL_HS_INTERLEAVING | BL_LP_INTERLEAVING |
|---------------------------------------------------------------------------------------------|--------------------|--------------------|

| Bits  | Field Name         | Description                                                                                                                                                                                                                                                                  | Type | Reset  |
|-------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | BL_HS_INTERLEAVING | Defines the number of TxByteClkHS clock cycles that can be used for interleaving high-speed command mode packet into Video Mode stream during blanking periods during VSA, VBP, VFP periods inside one video frame on PPI link.<br>The supported values are from 0 to 65535. | RW   | 0x0000 |
| 15:0  | BL_LP_INTERLEAVING | Defines the maximum number of bytes for Low Power command mode packets that can be sent on PPI link during blanking periods during VSA, VBP or VFP periods inside one video frame on PPI link.<br>The supported values are from 0 to 65535                                   | RW   | 0x0000 |

**Table 7-417. Register Call Summary for Register DSI\_VM\_TIMING6**

Display Subsystem Environment

- [Video Port Used for Video Mode: \[0\]](#)

Display Subsystem Functional Description

- [Interleaving Mode: \[1\] \[2\]](#)

Display Subsystem Basic Programming Model

- [Video Mode: \[3\]](#)

Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[4\]](#)

**Table 7-418. DSI\_VM\_TIMING7**

|                         |                                                                                                                                                                                                                                        |                 |                     |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------------------|--|--|
| <b>Address Offset</b>   | 0x0000 0090                                                                                                                                                                                                                            | <b>Instance</b> | DSI_PROTOCOL_ENGINE |  |  |
| <b>Physical Address</b> | 0x4804 FC90                                                                                                                                                                                                                            |                 |                     |  |  |
| <b>Description</b>      | Defines the maximum number of bytes of Low Power command mode packets that can be sent on PPI link during blanking periods during VSA, VBP or VFP periods inside one video frame on PPI link. The supported values are from 0 to 65535 |                 |                     |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                     |                 |                     |  |  |

  

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| ENTER_HS_MODE_LATENCY   |                         |                       |                 |
| EXIT_HS_MODE_LATENCY    |                         |                       |                 |

| <b>Bits</b> | <b>Field Name</b>     | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:16       | ENTER_HS_MODE_LATENCY | Defines the number of TxByteClkHS clock cycles necessary for entering to HS mode. It corresponds to the delay in number of HS clock cycles from assertion of TxRequestHS signal to 1 until assertion of TxReadyHS signal to 1. The supported values are from 0 to 65535 .                                                                                                                 | RW          | 0x0000       |
| 15:0        | EXIT_HS_MODE_LATENCY  | Defines the number of TxByteClkHS clock cycles necessary for exiting from HS mode. It corresponds to the maximum delay in number of TxByteClkHS from de-assertion of TxRequestHS signal until PPI link is in LP-11 state from which a new entrance to HS mode can be initiated which does not take more than ENTER_HS_MODE_LATENCY clock cycles. The supported values are from 0 to 65535 | RW          | 0x0000       |

**Table 7-419. Register Call Summary for Register DSI\_VM\_TIMING7**

## Display Subsystem Functional Description

- Timing Parameters for an LP to HS Transaction: [0] [1]
- Timing Parameters for an HS to LP Transaction: [2] [3]

## Display Subsystem Basic Programming Model

- Video Mode: [4]
- Video Mode Transfer: [5]

## Display Subsystem Use Cases and Tips

- Set Up DSI Protocol Engine: [6]

## Display Subsystem Register Manual

- DSI Protocol Engine Register Mapping Summary: [7]

**Table 7-420. DSI\_STOPCLK\_TIMING**

|                         |                                                                                                           |                 |                     |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------|-----------------|---------------------|--|--|
| <b>Address Offset</b>   | 0x0000 0094                                                                                               | <b>Instance</b> | DSI_PROTOCOL_ENGINE |  |  |
| <b>Physical Address</b> | 0x4804 FC94                                                                                               |                 |                     |  |  |
| <b>Description</b>      | Number of functional clock cycles to wait for TxByteClock to stop/start after change in DSIStopClk signal |                 |                     |  |  |
| <b>Type</b>             | RW                                                                                                        |                 |                     |  |  |

  

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         |                       |                 |
| DSI_STOPCLK_LATENCY     |                         |                       |                 |

| <b>Bits</b> | <b>Field Name</b>   | <b>Description</b>                                           | <b>Type</b> | <b>Reset</b> |
|-------------|---------------------|--------------------------------------------------------------|-------------|--------------|
| 31:8        | RESERVED            | Write 0s for future compatibility. Reads returns 0.          | R           | 0x000000     |
| 7:0         | DSI_STOPCLK_LATENCY | Clock gating latency from DSI Protocol engine to TxByteClkHS | RW          | 0x80         |

**Table 7-421. Register Call Summary for Register DSI\_STOPCLK\_TIMING**

Display Subsystem Functional Description

- DSI PLL Power Control Commands: [0] [1]

Display Subsystem Register Manual

- DSI Protocol Engine Register Mapping Summary: [2]

**Table 7-422. DSI\_VCn\_CTRL**

|                         |                                                                   |                 |                     |
|-------------------------|-------------------------------------------------------------------|-----------------|---------------------|
| <b>Address Offset</b>   | 0x0000 0100+ (n* 0x20)                                            | <b>Index</b>    | n = 0 to 3          |
| <b>Physical Address</b> | 0x4804 FD00+ (n* 0x20)                                            | <b>Instance</b> | DSI_PROTOCOL_ENGINE |
| <b>Description</b>      | CONTROL REGISTER - Virtual channel This register controls the VC. |                 |                     |
| <b>Type</b>             | RW                                                                |                 |                     |

| 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 |
|----------|---------------|------------------|---------------|-------------------|------------------|--------------|---------|---------|----------|----------|------------|-----------|----------|--------|-------------------|------|-------------|--------------|--------|-------|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED | DMA_RX_REQ_NB | DMA_RX_THRESHOLD | DMA_TX_REQ_NB | RX_FIFO_NOT_EMPTY | DMA_TX_THRESHOLD | TX_FIFO_FULL | VC_BUSY | PP_BUSY | RESERVED | RESERVED | MODE_SPEED | ECC_TX_EN | CS_TX_EN | BTA_EN | TX_FIFO_NOT_EMPTY | MODE | BTA_LONG_EN | BTA_SHORT_EN | SOURCE | VC_EN |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name       | Description                                                                                                                                                                                                                             | Type | Reset |
|-------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED         | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                  | RW   | 0x0   |
| 29:27 | DMA_RX_REQ_NB    | Selection of the use of the DMA request (associated to the RX FIFO)<br><br>0x0: DSI_DMA_REQ0 is selected<br>0x1: DSI_DMA_REQ1 is selected<br>0x2: DSI_DMA_REQ2 is selected<br>0x3: DSI_DMA_REQ3 is selected<br>0x4: No DMA req selected | RW   | 0x0   |
| 26:24 | DMA_RX_THRESHOLD | Defines the threshold value for the DMA request (associated to the RX FIFO)<br><br>0x0: 1x 32 bits<br>0x1: 2 x 32 bits<br>0x2: 4 x 32 bits<br>0x3: 8 x 32 bits<br>0x4: 16 x 32 bits<br>0x5: 32 x 32 bits                                | RW   | 0x0   |
| 23:21 | DMA_TX_REQ_NB    | Selection of the use of the DMA request (associated to the TX FIFO)<br><br>0x0: DSI_DMA_REQ0 is selected<br>0x1: DSI_DMA_REQ1 is selected<br>0x2: DSI_DMA_REQ2 is selected<br>0x3: DSI_DMA_REQ3 is selected<br>0x4: No DMA req selected | RW   | 0x0   |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name        | Description                                                                                                                                                                                                                                                                                      | Type | Reset |
|-------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 20    | RX_FIFO_NOT_EMPTY | FIFO status in command mode. Otherwise, this bit can be ignored.<br><br>0x0: The RX FIFO is empty (the FIFO does not contain any data for the VC)<br><br>0x1: The RX FIFO is not empty (the FIFO contains at least one byte for the VC)                                                          | R    | 0x0   |
| 19:17 | DMA_TX_THRESHOLD  | Defines the threshold value for the DMA request (associated to the TX FIFO)<br><br>0x0: 1x 32 bits<br>0x1: 2 x 32 bits<br>0x2: 4 x 32 bits<br>0x3: 8 x 32 bits<br>0x4: 16 x 32 bits<br>0x5: 32 x 32 bits                                                                                         | RW   | 0x0   |
| 16    | TX_FIFO_FULL      | FIFO status in command mode. Otherwise, this bit can be ignored.<br><br>0x0: The TX FIFO is not full (the FIFO can accept at least one more 32-bit value)<br><br>0x1: The TX FIFO is full                                                                                                        | R    | 0x0   |
| 15    | VC_BUSY           | Indicates if previously scheduled activities (packets, BTA) are still being processed. Forced to 1 by hardware if VC is enabled. Software should check this bit is 0 before changing channel configuration.<br><br>0x0: No pending operations for this VC<br>0x1: Pending operations for this VC | R    | 0x0   |
| 14    | PP_BUSY           | Line buffer busy status.<br><br>0x0: Software is permitted to write a new header for VP command mode traffic.<br><br>0x1: Software is NOT permitted to write a new header for VP command mode traffic.                                                                                           | R    | 0     |
| 13:10 | RESERVED          | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                           | RW   | 0x00  |
| 9     | MODE_SPEED        | Selection of the mode. This bit is ignored by hardware when video mode is selected.<br><br>0x0: Low-power mode (CMOS) is used to send short and long packets to the peripheral.<br><br>0x1: High speed mode (SLVS) is used to send short and long packets to the peripheral.                     | RW   | 0x0   |
| 8     | ECC_TX_EN         | Enables the ECC generation for the transmit header (short and long packets).<br><br>0x0: Disabled<br>0x1: Enabled                                                                                                                                                                                | RW   | 0x0   |
| 7     | CS_TX_EN          | Enables the checksum generation for the transmit payload (long packet only).<br><br>0x0: Disabled. The value 0x00 is used.<br><br>0x1: Enabled. The Check-sum value is calculated by HW.                                                                                                         | RW   | 0x0   |

| Bits | Field Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Type | Reset |
|------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 6    | BTA_EN            | <p>Send the bus turn around to the peripheral. It can be used when the automatic mode is enabled (BTA_SHORT_EN=1 or/and BTA_LONG_EN=1). In that case only one BTA is sent to the peripheral. The manual mode allows users to define for which packets, the turn around is required for example getting acknowledge from the peripheral.</p> <p>0x0: READS: BTA generation is completed. It is reset by HW when it is completed.<br/>WRITES: Cancellation of the BTA generation (not guarantee since it could already be on going, must not be used).</p> <p>0x1: READS: BTA generation has been requested by user (it could be on going but not completed).<br/>WRITES: Request for BTA generation.</p>                                                                                                                                                                                                                                                                                                                                                 | RW   | 0x0   |
| 5    | TX_FIFO_NOT_EMPTY | <p>FIFO status</p> <p>0x0: The TX FIFO is empty (the FIFO does not contain any data for the VC)</p> <p>0x1: The TX FIFO is not empty (the FIFO contains at least one byte for the VC)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R    | 0x0   |
| 4    | MODE              | <p>Selection of the mode</p> <p>0x0: Command mode.</p> <p>0x1: Video mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x0   |
| 3    | BTA_LONG_EN       | <p>Enables the automatic bus turn-around after completion of each long packet transmission.</p> <p>0x0: Disabled</p> <p>0x1: Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW   | 0x0   |
| 2    | BTA_SHORT_EN      | <p>Enables the automatic bus turn-around after completion of each short packet transmission.</p> <p>0x0: Disabled</p> <p>0x1: Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW   | 0x0   |
| 1    | SOURCE            | <p>Selection of the source between L4 interconnect slave port and video port. This bit is ignored by hardware when video mode is selected.</p> <p>0x0: All the data are provided by the L4 interconnect slave port. Any transfer on the video port is ignored for this VC.</p> <p>0x1: If MODE=VIDEO_MODE, any data received on the video port (pixels and enabled synchronization events using <a href="#">DSI_CTRL[17]</a> VP_HSYNC_START, <a href="#">DSI_CTRL[18]</a> VP_HSYNC_END, <a href="#">DSI_CTRL[15]</a> VP_VSYNC_START, <a href="#">DSI_CTRL[16]</a> VP_VSYNC_END,) are sent on the VC (only one VC can be associated with the video port, the software must ensure that no more than one VC is enabled with the video port as the main source for data). If MODE=COMMAND_MODE, the VP_STALL signal is used by the protocol engine to indicate when new data are required. The synchronization signals are not generated by the display controller. Regardless of the MODE, no data can be provided on the L4 interconnect slave port.</p> | RW   | 0x0   |
| 0    | VC_EN             | <p>Enables the VC.</p> <p>0x0: Disabled. The VC must be disabled for any register change in the DSI_VCn_XXX registers the corresponding VC ID.</p> <p>0x1: Enabled. No change is allowed to the VC registers (except for setting the bit fields/registers: <a href="#">DSI_VCn_CTRL[6]</a> BTA_EN, <a href="#">DSI_VCn_TE[15:0]</a> TE_SIZE, <a href="#">DSI_VCn_TE[31]</a> TE_START, DSI_VCn_LONG_XXX, DSI_VCn_SHORT_XXX, DSI_VCn_IRQXXX registers).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW   | 0x0   |

**Table 7-423. Register Call Summary for Register DSI\_VCn\_CTRL**

## Display Subsystem Environment

- Blanking: [0] [1] [2] [3]

## Display Subsystem Functional Description

- Command Mode: [4] [5] [6]
- DSI PLL Power Control Commands: [7] [8]
- TurnRequest FSM: [9]
- LP RX Timer: [10]
- Bus Turnaround: [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23] [24] [25] [26] [27]
- Tearing Effect: [28] [29] [30]
- ECC Generation: [31]
- Checksum Generation for Long Packet Payloads: [32]

## Display Subsystem Basic Programming Model

- Global Register Controls: [33]
- Virtual Channels: [34] [35] [36] [37] [38] [39] [40] [41] [42] [43] [44]
- Packets: [45] [46]
- Video Mode: [47] [48] [49] [50] [51] [52] [53]
- Command Mode TX FIFO: [54] [55] [56] [57] [58]
- Command Mode RX FIFO: [59]
- Command Mode DMA Requests: [60] [61] [62] [63] [64] [65]
- DSI Programming Sequence Example: [66] [67]
- Video Mode Transfer: [68] [69]
- Command Mode Transfer Example 1: [70] [71] [72] [73] [74]
- Command Mode Transfer Example 2: [75] [76] [77] [78] [79]

## Display Subsystem Register Manual

- DSI Protocol Engine Register Mapping Summary: [80]
- DSI Protocol Engine Registers: [81] [82]

**Table 7-424. DSI\_VCn\_TE**

| Address Offset          | 0x0000 0104+ (n* 0x20)                                                                                                                                                    | Index                 | n = 0 to 3          |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|---------------------|
| Physical Address        | 0x4804 FD04+ (n* 0x20)                                                                                                                                                    | Instance              | DSI_PROTOCOL_ENGINE |
| Description             | CONTROL REGISTER - Virtual channel This register controls the tearing effect logic. It defines the size of the transfer when TE occurs and enables the automatic TE mode. |                       |                     |
| Type                    | RW                                                                                                                                                                        |                       |                     |
| 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     |
| TE_START<br>TE_EN       | RESERVED                                                                                                                                                                  | TE_SIZE               |                     |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31   | TE_START   | <p>Manual control of the start of the transfer. Users can use the TE interrupt to determine that the TE trigger has been received before setting the TE_START bit field. It is not mandatory to use the TE interrupt.</p> <p>0x0: Indicates the end of the transfer. The bit can be used to cancel the transfer if not already started. The FIFO must be flushed by software to ensure it contains no remaining data.</p> <p>0x1: Starts the transfer of the data. The size is defined in TE_SIZE. The bit field is set until the transfer completes. It is reset by hardware when the transfer completes.</p> | RW   | 0     |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset    |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 30    | TE_EN      | <p>Tearing effect control</p> <p>0x0: Disables the automatic transfer of the data using the TE trigger as a synchronization event. The interruption is used to know when the TE trigger is received. The hardware resets the bit field when the transfer completes(TE_SIZE=0).</p> <p>0x1: Enables the automatic transfer of the data using the TE trigger as a synchronization event.</p>                                                                                                                                                                                                                    | RW   | 0        |
| 29:24 | RESERVED   | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0x0000   |
| 23:0  | TE_SIZE    | Defines the number of bytes (payload data excluding the check-sum) to be sent. Users must perform the write into the <a href="#">DSI_VCn_LONG_PACKET_HEADER</a> register before sending data from the <a href="#">DSI_VCn_LONG_PACKET_PAYLOAD</a> register. The register value is decremented for every byte of the DSI link that is sent. At the end of the transfer (TE_SIZE = 0), the TE_EN bit field is reset by hardware. The DMA_request is asserted when the trigger is received in order to receive data in the TX FIFO. It must not be used until all data (TE_SIZE) have been received in the FIFO. | RW   | 0x000000 |

**Table 7-425. Register Call Summary for Register DSI\_VCn\_TE**

Display Subsystem Functional Description

- [Tearing Effect: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\]](#)

Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[14\]](#)
- [DSI Protocol Engine Registers: \[15\] \[16\]](#)

**Table 7-426. DSI\_VCn\_LONG\_PACKET\_HEADER**

|                         |                                                                                                                                                           |                       |                     |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|---------------------|
| <b>Address Offset</b>   | 0x0000 0108+ (n* 0x20)                                                                                                                                    | <b>Index</b>          | n = 0 to 3          |
| <b>Physical Address</b> | 0x4804 FD08+ (n* 0x20)                                                                                                                                    | <b>Instance</b>       | DSI_PROTOCOL_ENGINE |
| <b>Description</b>      | LONG PACKET HEADER INFORMATION - virtual channel. This register sets the 32-bit DATA_ID + Word count + ECC. The ECC is computed if ECC_TX_EN is set to 1. |                       |                     |
|                         | DATA_ID is located at bit[7:0].                                                                                                                           |                       |                     |
|                         | WC is located at bit[23:8].                                                                                                                               |                       |                     |
|                         | ECC is located at bit[31:24] (least-significant byte first and least significant bit first).                                                              |                       |                     |
| <b>Type</b>             | W                                                                                                                                                         |                       |                     |
| 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     |
| HEADER                  |                                                                                                                                                           |                       |                     |

| Bits | Field Name | Description                                          | Type | Reset      |
|------|------------|------------------------------------------------------|------|------------|
| 31:0 | HEADER     | Packet header information: DATA ID + DATA FIELD +ECC | W    | 0x00000000 |

**Table 7-427. Register Call Summary for Register DSI\_VCn\_LONG\_PACKET\_HEADER**

Display Subsystem Environment

- [Video Port Used on Command Mode: \[0\] \[1\]](#)
- [Virtual Channel ID - VC Field, DI\[7:6\]: \[2\]](#)

Display Subsystem Functional Description

- [Video Mode: \[3\]](#)
- [Command Mode: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [Bus Turnaround: \[10\]](#)
- [Tearing Effect: \[11\] \[12\] \[13\]](#)

**Table 7-427. Register Call Summary for Register DSI\_VCn\_LONG\_PACKET\_HEADER (continued)**

Display Subsystem Basic Programming Model

- [Global Register Controls](#): [14]
- [Virtual Channels](#): [15]
- [Packets](#): [16] [17] [18] [19] [20] [21]
- [Video Mode](#): [22] [23]
- [Command Mode TX FIFO](#): [24] [25] [26] [27] [28] [29]
- [Command Mode RX FIFO](#): [30]
- [Command Mode DMA Requests](#): [31]
- [Command Mode Transfer Example 1](#): [32] [33] [34]
- [Command Mode Transfer Example 2](#): [35]

Display Subsystem Register Manual

- [Display Subsystem Register Manual](#): [36]
- [DSI Protocol Engine Register Mapping Summary](#): [37]
- [DSI Protocol Engine Registers](#): [38] [39]

**Table 7-428. DSI\_VCn\_LONG\_PACKET\_PAYLOAD**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                       |                     |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|---------------------|
| <b>Address Offset</b>   | 0x0000 010C+ (n* 0x20)                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>Index</b>          | n = 0 to 3          |
| <b>Physical Address</b> | 0x4804 FD0C+ (n* 0x20)                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>Instance</b>       | DSI_PROTOCOL_ENGINE |
| <b>Description</b>      | LONG PACKET PAYLOAD INFORMATION - virtual channel. This register sets the payload information (excluding Check-sum). Hardware must capture the word count in the packet header (in <a href="#">DSI_VCn_LONG_PACKET_HEADER</a> register) to determine the last valid data (the VC ID can be different from VC). Byte1 is bit[7:0]; Byte2 is bit[15:8]; Byte3 is bit[23:16]; Byte4 is bit[31:24]; and Byten is sent before Byten+1 (least-significant byte first and least significant bit first). |                       |                     |
| <b>Type</b>             | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                       |                     |
| 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     |
| PAYLOAD                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                       |                     |

| Bits | Field Name | Description                                      | Type | Reset      |
|------|------------|--------------------------------------------------|------|------------|
| 31:0 | PAYLOAD    | Packet payload information (excluding check-sum) | W    | 0x00000000 |

**Table 7-429. Register Call Summary for Register DSI\_VCn\_LONG\_PACKET\_PAYLOAD**

Display Subsystem Functional Description

- [Command Mode](#): [0] [1] [2] [3] [4]
- [Bus Turnaround](#): [5]
- [Tearing Effect](#): [6] [7]

Display Subsystem Basic Programming Model

- [Global Register Controls](#): [8]
- [Packets](#): [9] [10] [11]
- [Command Mode TX FIFO](#): [12] [13] [14]
- [Command Mode RX FIFO](#): [15]
- [Command Mode Transfer Example 1](#): [16] [17]

Display Subsystem Register Manual

- [Display Subsystem Register Manual](#): [18]
- [DSI Protocol Engine Register Mapping Summary](#): [19]
- [DSI Protocol Engine Registers](#): [20]

**Table 7-430. DSI\_VCn\_SHORT\_PACKET\_HEADER**

|                         |                                                                                                                                                                                                                                                                                                                                         |                 |                     |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------------------|
| <b>Address Offset</b>   | 0x0000 0110+ (n* 0x20)                                                                                                                                                                                                                                                                                                                  | <b>Index</b>    | n = 0 to 3          |
| <b>Physical Address</b> | 0x4804 FD10+ (n* 0x20)                                                                                                                                                                                                                                                                                                                  | <b>Instance</b> | DSI_PROTOCOL_ENGINE |
| <b>Description</b>      | SHORT PACKET HEADER INFORMATION - Virtual channel This register sets the 24-bit DATA_ID + Short packet data field + ECC (the VC ID can be different than VC) DATA_ID is located at bit[7:0] short packet data field is located at bit[23:8] ECC is located at bit[31:24] (least-significant byte first and least significant bit first) |                 |                     |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                      |                 |                     |

  

|        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| HEADER |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits | Field Name | Description                                                                                                                         | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | HEADER     | WRITES: Packet header information: DATA ID + DATA FIELD +ECC written into the TX FIFO<br>READS: 32-bit values read from the RX FIFO | RW   | 0x00000000 |

**Table 7-431. Register Call Summary for Register DSI\_VCn\_SHORT\_PACKET\_HEADER**

Display Subsystem Environment

- Virtual Channel ID - VC Field, DI[7:6]: [0]

Display Subsystem Functional Description

- Command Mode: [1] [2] [3]
- Tearing Effect: [4]

Display Subsystem Basic Programming Model

- Global Register Controls: [5]
- Virtual Channels: [6]
- Packets: [7]
- Command Mode TX FIFO: [8] [9] [10]
- Command Mode RX FIFO: [11]
- Command Mode DMA Requests: [12]
- Command Mode Transfer Example 1: [13] [14]

Display Subsystem Register Manual

- Display Subsystem Register Manual: [15]
- DSI Protocol Engine Register Mapping Summary: [16]

**Table 7-432. DSI\_VCn\_IRQSTATUS**

|                         |                                                                                                      |                 |                     |
|-------------------------|------------------------------------------------------------------------------------------------------|-----------------|---------------------|
| <b>Address Offset</b>   | 0x0000 0118+ (n* 0x20)                                                                               | <b>Index</b>    | n = 0 to 3          |
| <b>Physical Address</b> | 0x4804 FD18+ (n* 0x20)                                                                               | <b>Instance</b> | DSI_PROTOCOL_ENGINE |
| <b>Description</b>      | INTERRUPT STATUS REGISTER - Virtual channel This register regroups all the events related to the VC. |                 |                     |
| <b>Type</b>             | RW                                                                                                   |                 |                     |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## Display Subsystem Register Manual

www.ti.com

| Bits | Field Name            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset    |
|------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED              | Write 0s for future compatibility.<br>Reads returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0x000000 |
| 8    | PP_BUSY_CHANGE_IRQ    | Video port ping-pong buffer busy status.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                                                                                                                                                                                                                          | RW   | 0        |
| 7    | FIFO_TX_UDF_IRQ       | FIFO underflow status. The FIFO used on the slave port for buffering the data received on the OCP slave port for the VC has underflowed which means that the data for the current packet have not been received in time since the transfer of the packet are already started (transfer started since the packet size is bigger than space allocated in the FIFO).<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW   | 0x0      |
| 6    | ECC_NO_CORRECTION_IRQ | ECC error status (short and long packets). No correction of the header because of more than 1-bit error.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                                                                                                                                                          | RW   | 0x0      |
| 5    | BTA_IRQ               | Virtual channel - BTA status.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0      |
| 4    | FIFO_RX_OVF_IRQ       | FIFO overflow error status. The FIFO used on the slave port for buffering the data received on the DSI link for the VC has overflowed.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                                                                                                                            | RW   | 0x0      |
| 3    | FIFO_TX_OVF_IRQ       | FIFO overflow error status. The FIFO used on the slave port for buffering the data received on the OCP slave port for the VC has overflowed.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                                                                                                                      | RW   | 0x0      |
| 2    | PACKET_SENT_IRQ       | Indicates that a packet has been sent. It is used when BTA manual mode is used.<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                                                                                                                                                                                   | RW   | 0x0      |
| 1    | ECC_CORRECTION_IRQ    | Virtual channel - ECC has been used to do the correction of the only 1-bit error status (short and long packet only).<br><br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br><br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset.                                                                                                                                                                                                                                             | RW   | 0x0      |

| Bits | Field Name | Description                                                                                                                                                                          | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | CS_IRQ     | Virtual channel - Check-Sum mismatch status.<br>0x0: READS: Event is false.<br>WRITES: Status bit unchanged.<br>0x1: READS: Event is true (pending).<br>WRITES: Status bit is reset. | RW   | 0x0   |

**Table 7-433. Register Call Summary for Register DSI\_VCn\_IRQSTATUS**

Display Subsystem Integration

- DSI Interrupt Request: [0]

Display Subsystem Functional Description

- Command Mode: [1]
- Bus Turnaround: [2] [3]

Display Subsystem Basic Programming Model

- Interrupts: [4]
- Command Mode TX FIFO: [5] [6]
- Command Mode DMA Requests: [7]
- Command Mode Transfer Example 1: [8]
- Command Mode Transfer Example 2: [9]

Display Subsystem Register Manual

- DSI Protocol Engine Register Mapping Summary: [10]

**Table 7-434. DSI\_VCn\_IRQENABLE**

| Address Offset   | 0x0000 011C+ (n* 0x20)                                                                           | Index    | n = 0 to 3          |
|------------------|--------------------------------------------------------------------------------------------------|----------|---------------------|
| Physical Address | 0x4804 FD1C + (n* 0x20)                                                                          | Instance | DSI_PROTOCOL_ENGINE |
| Description      | INTERRUPT ENABLE REGISTER - Virtual channel This register regroups all the events related to VC. |          |                     |
| Type             | RW                                                                                               |          |                     |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                       |                    |                          |            |                    |                    |                    |                       |           |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----------------------|--------------------|--------------------------|------------|--------------------|--------------------|--------------------|-----------------------|-----------|
| 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                  |                       |           |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PP_BUSY_CHANGE_IRQ_EN | FIFO_TX_UDF_IRQ_EN | ECC_NO_CORRECTION_IRQ_EN | BTA_IRQ_EN | FIFO_RX_OVF_IRQ_EN | FIFO_TX_OVF_IRQ_EN | PACKET_SENT_IRQ_EN | ECC_CORRECTION_IRQ_EN | CS_IRQ_EN |

| Bits | Field Name            | Description                                                                                                   | Type | Reset    |
|------|-----------------------|---------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED              | Write 0s for future compatibility.<br>Reads returns 0.                                                        | RW   | 0x000000 |
| 8    | PP_BUSY_CHANGE_IRQ_EN | Video port ping-pong buffer busy.<br>0x0: Event is masked<br>0x1: Event generates an interrupt when it occurs | RW   | 0        |

| Bits | Field Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset |
|------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7    | FIFO_TX_UDF_IRQ_EN       | FIFO underflow enable. The FIFO used on the slave port for buffering the data received on the OCP slave port for the VC has underflowed which means that the data for the current packet have not been received in time since the transfer of the packet are already started (transfer started since the packet size is bigger than space allocated in the FIFO).<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs | RW   | 0x0   |
| 6    | ECC_NO_CORRECTION_IRQ_EN | ECC error (short and long packets). No correction of the header because of more than 1-bit error.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                                                                                                                                                                                                                                                                 | RW   | 0x0   |
| 5    | BTA_IRQ_EN               | Virtual channel -Bus turn around reception<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                                                                                                                                                                                                                                                                                                                        | RW   | 0x0   |
| 4    | FIFO_RX_OVF_IRQ_EN       | FIFO overflow enable. The FIFO used on the slave port for buffering the data received on the DSI link for the VC has overflowed.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                                                                                                                                                                                                                                  | RW   | 0x0   |
| 3    | FIFO_TX_OVF_IRQ_EN       | FIFO overflow enable. The FIFO used on the slave port for buffering the data received on the OCP slave port for the VC has overflowed.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                                                                                                                                                                                                                            | RW   | 0x0   |
| 2    | PACKET_SENT_IRQ_EN       | Indicates that a packet has been sent. It is used when BTA manual mode is used.<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                                                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 1    | ECC_CORRECTION_IRQ_EN    | Virtual channel - ECC has been used to correct the only 1-bit error (short and long packet).<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                                                                                                                                                                                                                                                                      | RW   | 0x0   |
| 0    | CS IRQ_EN                | Virtual channel - Check-Sum of the payload mismatch detection<br><br>0x0: Event is masked<br><br>0x1: Event generates an interrupt when it occurs                                                                                                                                                                                                                                                                                                     | RW   | 0x0   |

**Table 7-435. Register Call Summary for Register DSI\_VCn\_IRQENABLE**

Display Subsystem Functional Description

- [Command Mode: \[0\]](#)
- [Bus Turnaround: \[1\]](#)

Display Subsystem Basic Programming Model

- [Interrupts: \[2\]](#)
- [Command Mode Transfer Example 1: \[3\]](#)
- [Command Mode Transfer Example 2: \[4\]](#)

Display Subsystem Register Manual

- [DSI Protocol Engine Register Mapping Summary: \[5\]](#)

### 7.7.2.6 DSI Complex I/O Registers

**NOTE:** Copyright 2005-2008 MIPI Alliance, Inc. All rights reserved. MIPI Alliance Member Confidential.

**Table 7-436. DSI\_PHY\_REGISTER0**

|                         |                                            |                         |                 |                 |         |
|-------------------------|--------------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0000                                | <b>Physical Address</b> | 0x4804 FE00     | <b>Instance</b> | DSI_PHY |
| <b>Description</b>      | Configuration register for HS mode timings |                         |                 |                 |         |
| <b>Type</b>             | RW                                         |                         |                 |                 |         |
| 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 |                 |         |
| REG_THSPREPARE          | REG_THSPRPR_THSZERO                        | REG_THSTRAIL            | REG_THSEXIT     |                 |         |

  

| <b>Bits</b> | <b>Field Name</b>   | <b>Description</b>                                                                                                                                                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:24       | REG_THSPREPARE      | REG_THSPREPARE timing parameter in multiples of DDR clock period. DDR clock = CLKIN4DDR/4.<br><br>D-PHY specification: 40 ns + 4*UI ÷ 85 ns + 6*UI.<br><br>UI = Unit Interval, equal to the duration of any HS state on the clock lane<br><br>Default value is programmed for 400 MHz. | RW          | 0x1E         |
| 23:16       | REG_THSPRPR_THSZERO | REG_THSPRPR_THSZERO timing parameter in multiples of DDR clock period. DDR clock = CLKIN4DDR/4.<br><br>D-PHY specification: 145 ns + 10*UI<br><br>Default value is programmed for 400 MHz.                                                                                             | RW          | 0x48         |
| 15:8        | REG_THSTRAIL        | REG_THSTRAIL timing parameter in multiples of DDR clock period. DDR clock = CLKIN4DDR/4.<br><br>D-PHY specification: 60 ns + 4*UI<br><br>Default value is programmed for 400 MHz.                                                                                                      | RW          | 0x1D         |
| 7:0         | REG_THSEXIT         | REG_THSEXIT timing parameter in multiples of DDR clock period. DDR clock = CLKIN4DDR/4)<br><br>D-PHY specification: 100 ns<br><br>Default value is programmed for 400 MHz.                                                                                                             | RW          | 0x3A         |

**Table 7-437. Register Call Summary for Register DSI\_PHY\_REGISTER0**

## Display Subsystem Functional Description

- [Timing Parameters for an LP to HS Transaction: \[0\] \[1\] \[2\] \[3\]](#)
- [Timing Parameters for an HS to LP Transaction: \[4\] \[5\] \[6\] \[7\]](#)
- [Shadowing Register: \[8\]](#)

## Display Subsystem Basic Programming Model

- [High-Speed Clock Transmission: \[9\] \[10\]](#)
- [High-Speed Data Transmission: \[11\] \[12\] \[13\]](#)

## Display Subsystem Use Cases and Tips

- [Configure DSI\\_PHY: \[14\] \[15\] \[16\] \[17\]](#)
- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O: \[18\] \[19\] \[20\] \[21\]](#)

## Display Subsystem Register Manual

- [DSI\\_PHY Register Mapping Summary: \[22\]](#)

**Table 7-438. DSI\_PHY\_REGISTER1**

|                         |                                                        |                 |         |
|-------------------------|--------------------------------------------------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0004                                            |                 |         |
| <b>Physical Address</b> | 0x4804 FE04                                            | <b>Instance</b> | DSI_PHY |
| <b>Description</b>      | Configuration register for LP mode and HS mode timings |                 |         |
| <b>Type</b>             | RW                                                     |                 |         |

| 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 |
|-----------|---------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|-------------|----|----|----|---------------|----|----|----|---------------|----|------|-------|----|----|------|---|---|---|---|---|---|---|---|---|---|
| REG_TTAGO | REG_TTASURE   | REG_TTAGET | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |    |    | REG_TLPXBY2 |    |    |    | REG_TCLKTRAIL |    |    |    | REG_TCLK_ZERO |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
| Bits      | Field Name    |            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |             |    |    |    |               |    |    |    |               |    | Type | Reset |    |    |      |   |   |   |   |   |   |   |   |   |   |
| 31:29     | REG_TTAGO     |            | TTA-GO timing in terms of number of TXCLKESC clocks                                                                                                                                                                                                                                                                                                                                                                                                         |    |    |    |             |    |    |    |               |    |    |    |               |    | RW   |       |    |    | 0x2  |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x0: 2 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x1: 3 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x2: 4 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x3: 5 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x4: 6 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x5: 7 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x6: 8 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x7: 9 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | Default value: 4 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
| 28:27     | REG_TTASURE   |            | TTA-SURE timing in terms of number of TXCLKESC clocks                                                                                                                                                                                                                                                                                                                                                                                                       |    |    |    |             |    |    |    |               |    |    |    |               |    | RW   |       |    |    | 0x0  |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x0: 2 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x1: 1 cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x2: 3 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x3: 4 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | Default value: 2 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
| 26:24     | REG_TTAGET    |            | TTA-GET timing in terms of number of TXCLKESC clocks                                                                                                                                                                                                                                                                                                                                                                                                        |    |    |    |             |    |    |    |               |    |    |    |               |    | RW   |       |    |    | 0x2  |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x0: 3 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x1: 4 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x2: 5 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x3: 6 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x4: 7 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x5: 8 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x6: 9 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | 0x7: 10 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
|           |               |            | Default value: 5 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |    |    |             |    |    |    |               |    |    |    |               |    |      |       |    |    |      |   |   |   |   |   |   |   |   |   |   |
| 23:21     | RESERVED      |            | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |    |    |             |    |    |    |               |    |    |    |               |    | R    |       |    |    | 0x0  |   |   |   |   |   |   |   |   |   |   |
| 20:16     | REG_TLPXBY2   |            | (TLPX)/2 timing parameter in multiples of DDR clock frequency. DDR clock = CLKIN4DDR/4.<br>Default value is programmed for 400 MHz<br>This is the internal timer value. The value seen on line will have variance due to rise/fall mismatch effects.<br><b>Note:</b> TLPX is used to define the length of LP-01 state in HS Start of Transmission sequences on clock and data lanes. For all other purposes TLPX is defined by the period of TxLPEsc clock. |    |    |    |             |    |    |    |               |    |    |    |               |    | RW   |       |    |    | 0x0A |   |   |   |   |   |   |   |   |   |   |
| 15:8      | REG_TCLKTRAIL |            | REG_TCLKTRAIL timing parameter in multiples of DDR clock frequency.<br>DDR clock = CLKIN4DDR/4.                                                                                                                                                                                                                                                                                                                                                             |    |    |    |             |    |    |    |               |    |    |    |               |    | RW   |       |    |    | 0x1A |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name   | Description                                                                                                                                                                                                                                                                                                   | Type | Reset |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |              | D-PHY specification: 60 ns<br>Default value is programmed for 400 MHz.                                                                                                                                                                                                                                        |      |       |
| 7:0  | REG_TCLKZERO | REG_TCLKZERO timing parameter in multiples of DDR clock period. DDR clock = CLKIN4DDR/4.<br><br>D-PHY specification: (REG_TCLKPREPARE + REG_TCLKZERO) 300 ns<br><br>Derived specification for REG_TCLKZERO (Min REG_TCLKPREPARE = 38 ns): REG_TCLKZERO 262 ns<br><br>Default value is programmed for 400 MHz. | RW   | 0x6A  |

**Table 7-439. Register Call Summary for Register DSI\_PHY\_REGISTER1**

## Display Subsystem Functional Description

- [Timing Parameters for an LP to HS Transaction](#): [0] [1] [2] [3]
- [Timing Parameters for an HS to LP Transaction](#): [4] [5]
- [Shadowing Register](#): [6]

## Display Subsystem Basic Programming Model

- [High-Speed Clock Transmission](#): [7] [8] [9]
- [High-Speed Data Transmission](#): [10]
- [Turn-Around Request in Transmit Mode](#): [11]
- [Turn-Around Request in Receive Mode](#): [12]

## Display Subsystem Use Cases and Tips

- [Configure DSI\\_PHY](#): [13] [14] [15] [16]
- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O](#): [17] [18] [19] [20]

## Display Subsystem Register Manual

- [DSI\\_PHY Register Mapping Summary](#): [21]

**Table 7-440. DSI\_PHY\_REGISTER2**

|                         |                                |                       |                 |          |                 |
|-------------------------|--------------------------------|-----------------------|-----------------|----------|-----------------|
| Address Offset          | 0x0000 0008                    | Physical Address      | 0x4804 FE08     | Instance | DSI_PHY         |
| Description             | Sync pattern and reserved bits |                       |                 |          |                 |
| Type                    | RW                             |                       |                 |          |                 |
| 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 |          |                 |
| HSSYNCPATTERN           | RESERVED                       | OVRRDULPMTX           | REGULPMTX       | RESERVED | REG_TCLKPREPARE |

| Bits  | Field Name    | Description                                                                                                                                                                                                       | Type | Reset |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | HSSYNCPATTERN | Default : 184 (10111000). MSB (last received bit of sync pattern), LSB (first received bit of sync pattern).                                                                                                      | RW   | 0xB8  |
| 23:17 | RESERVED      | Reserved. Read returns zero. Write only zero for future compatibility.                                                                                                                                            | R    | 0x00  |
| 16    | OVRRDULPMTX   | Global enable of the weak pulldown on the DSI lanes, configured through the REGULPMTX [15:11] bit field:<br><br>1: Enable weak pulldown on the DSI lanes.<br>0: Disable weak pulldown on the DSI lanes (default). | RW   | 0     |
| 15:11 | REGULPMTX     | Configuration of the weak pulldowns on the DSI lanes.<br><br>For each bit, the following settings are applicable:<br><br>1: Enable weak pulldown on the lane.<br>0: Disable weak pulldown on the lane (default).  | RW   | 0x00  |

## Display Subsystem Register Manual

www.ti.com

| Bits | Field Name      | Description                                                                                                                                                                            | Type | Reset |
|------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |                 | Bit [15]: Reserved<br>Bit [14]: Reserved<br>Bit [13]: DSI lane 2<br>Bit [12]: DSI lane 1<br>Bit [11]: DSI lane 0                                                                       |      |       |
| 10:8 | RESERVED        | Reserved                                                                                                                                                                               | RW   | 0x0   |
| 7:0  | REG_TCLKPREPARE | REG_TCLKPREPARE timing parameter in multiples of DDR clock period. DDR clock = CCLKIN4DDR/4.<br><br>D-PHY specification: 38 ns ± 95 ns<br><br>Default value is programmed for 400 MHz. | RW   | 0x1A  |

**Table 7-441. Register Call Summary for Register DSI\_PHY\_REGISTER2**

## Display Subsystem Functional Description

- Timing Parameters for an LP to HS Transaction: [0] [1]

## Display Subsystem Basic Programming Model

- High-Speed Data Transmission: [2]

## Display Subsystem Use Cases and Tips

- Configure DSI\_PHY: [3] [4]
- Configure DSI Protocol Engine, DSI PLL, and Complex I/O: [5] [6]

## Display Subsystem Register Manual

- DSI\_PHY Register Mapping Summary: [7]

**Table 7-442. DSI\_PHY\_REGISTER3**

|                         |                                                                         |  |  |  |                       |                   |  |  |         |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------|--|--|--|-----------------------|-------------------|--|--|---------|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset          | 0x0000 000C                                                             |  |  |  |                       |                   |  |  |         |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address        | 0x4804 FE0C                                                             |  |  |  | Instance              |                   |  |  | DSI_PHY |  |  |  |  |  |  |  |  |  |  |  |
| Description             | Transmitted pattern in case of escape mode trigger command transmission |  |  |  |                       |                   |  |  |         |  |  |  |  |  |  |  |  |  |  |  |
| Type                    | RW                                                                      |  |  |  |                       |                   |  |  |         |  |  |  |  |  |  |  |  |  |  |  |
| 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   |  |  |         |  |  |  |  |  |  |  |  |  |  |  |
| REG_TXTRIGGERESC3       | REG_TXTRIGGERESC2                                                       |  |  |  | REG_TXTRIGGERESC1     | REG_TXTRIGGERESC0 |  |  |         |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name         | Description                                                                                                                     | Type | Reset |
|-------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | REG_TXTRIGGERES C3 | Transmitted pattern when REG_TXTRIGGERESC3 is asserted (first bit transmitted to last bit transmitted)<br><br>Default: 01100010 | RW   | 0x62  |
| 23:16 | REG_TXTRIGGERES C2 | Default: 01011101                                                                                                               | RW   | 0x5D  |
| 15:8  | REG_TXTRIGGERES C1 | Default: 00100001                                                                                                               | RW   | 0x21  |
| 7:0   | REG_TXTRIGGERES C0 | Default: 10100000                                                                                                               | RW   | 0xA0  |

**Table 7-443. Register Call Summary for Register DSI\_PHY\_REGISTER3**

## Display Subsystem Functional Description

- PHY Triggers: [0]
- Reset: [1]

## Display Subsystem Register Manual

- DSI\_PHY Register Mapping Summary: [2]

**Table 7-444. DSI\_PHY\_REGISTER4**

| <b>Address Offset</b>   | 0x0000 0010                                      |                                                                                                                          |                   |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-------------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x4804 FE10                                      |                                                                                                                          |                   |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Received pattern for low-power trigger reception |                                                                                                                          |                   |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                               |                                                                                                                          |                   |  |  |  |  |  |  |  |  |  |  |  |
| 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   |  |  |  |  |  |  |  |  |  |  |  |
| REG_RXTRIGGERESC3       | REG_RXTRIGGERESC2                                | REG_RXTRIGGERESC1                                                                                                        | REG_RXTRIGGERESC0 |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                       | <b>Description</b>                                                                                                       |                   |  |  |  |  |  |  |  |  |  |  |  |
| 31:24                   | REG_RXTRIGGERES C3                               | Received pattern when REG_RXTRIGGERESC3 is asserted (first bit transmitted to last bit transmitted)<br>Default: 01100010 |                   |  |  |  |  |  |  |  |  |  |  |  |
| 23:16                   | REG_RXTRIGGERES C2                               | Default: 01011101                                                                                                        |                   |  |  |  |  |  |  |  |  |  |  |  |
| 15:8                    | REG_RXTRIGGERES C1                               | Default: 00100001                                                                                                        |                   |  |  |  |  |  |  |  |  |  |  |  |
| 7:0                     | REG_RXTRIGGERES C0                               | Default: 10100000                                                                                                        |                   |  |  |  |  |  |  |  |  |  |  |  |

**Table 7-445. Register Call Summary for Register DSI\_PHY\_REGISTER4**

Display Subsystem Functional Description

- [PHY Triggers: \[0\]](#)
- [Tearing Effect: \[1\]](#)
- [Acknowledge: \[2\]](#)

Display Subsystem Register Manual

- [DSI\\_PHY Register Mapping Summary: \[3\]](#)

**Table 7-446. DSI\_PHY\_REGISTER5**

|                         |                         |                       |                 |                    |                    |                    |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--------------------|--------------------|--------------------|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0014             |                       |                 |                    |                    |                    |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4804 FE14             |                       |                 |                    |                    |                    |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Reset done bits         |                       |                 |                    |                    |                    |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                       |                       |                 |                    |                    |                    |  |  |  |  |  |  |  |  |
| 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 |                    |                    |                    |  |  |  |  |  |  |  |  |
| RESETDONETXBYTECLK      | RESETDONECPCLK          | RESETDONEPWRCCLK      | RESERVED        | RESETDONETXCLKESC2 | RESETDONETXCLKESC1 | RESETDONETXCLKESCO |  |  |  |  |  |  |  |  |

RESERVED

| Bits | Field Name          | Description                                               | Type | Reset |
|------|---------------------|-----------------------------------------------------------|------|-------|
| 31   | RESETDONETXBYT ECLK | RESETDONETXBYTECLK                                        | R    | 0     |
|      |                     | 0x0: No reset<br>0x1: Reset done for the TXBYTECLK domain |      |       |
| 30   | RESETDONECPCLK K    | RESETDONECPCLK                                            | R    | 0     |

| Bits  | Field Name         | Description                                                         | Type | Reset    |
|-------|--------------------|---------------------------------------------------------------------|------|----------|
|       |                    | 0x0: No reset<br>0x1: Reset done for the SCP clock domain           |      |          |
| 29    | RESETDONEPWRCLOCK  | RESETDONEPWRCLOCK                                                   | R    | 0        |
|       |                    | 0x0: No reset<br>0x1: Reset done for the PWR clock domain           |      |          |
| 28:27 | RESERVED           | Read-only register. Read returns 0.                                 | R    | 0        |
| 26    | RESETDONETXCLKESC2 | RESETDONETXCLKESC2                                                  | R    | 0        |
|       |                    | 0x0: No reset<br>0x1: Reset done for the TXCLKESC domain for lane 2 |      |          |
| 25    | RESETDONETXCLKESC1 | RESETDONETXCLKESC1                                                  | R    | 0        |
|       |                    | 0x0: No reset<br>0x1: Reset done for the TXCLKESC domain for lane 1 |      |          |
| 24    | RESETDONETXCLKESC0 | RESETDONETXCLKESC0                                                  | R    | 0        |
|       |                    | 0x0: No reset<br>0x1: Reset done for the TXCLKESC domain for lane 0 |      |          |
| 23:0  | RESERVED           | Read-only register. Read returns 0.                                 | R    | 0x000000 |

**Table 7-447. Register Call Summary for Register DSI\_PHY\_REGISTER5**

---

Display Subsystem Basic Programming Model

- Reset-Done Bits: [0] [1] [2] [3] [4] [5] [6]

---

Display Subsystem Register Manual

- DSI\_PHY Register Mapping Summary: [7]

#### **7.7.2.7 DSI PLL Control Module Registers**

**Table 7-448. DSI\_PLL\_CONTROL**

| Bits | Field Name         | Description                                                                                                                                                                                                                               | Type | Reset     |
|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | RESERVED           | Reserved. Write only zero for future compatibility. Reads return zero.                                                                                                                                                                    | R    | 0x0000000 |
| 4    | DSI_HSDIV_SYSRESET | Force HSDIVIDER SYSRESET<br>0x0: HSDIVIDER SYSRESET controlled by power FSM<br>0x1: HSDIVIDER SYSRESET forced active                                                                                                                      | RW   | 0x0       |
| 3    | DSI_PLL_SYSRESET   | Force ADPLL M SYSRESET<br>0x0: PLL SYSRESET controlled by power FSM<br>0x1: PLL SYSRESET forced active                                                                                                                                    | RW   | 0x0       |
| 2    | DSI_PLL_HALTMODE   | Allow PLL to be halted if no activity<br>0x0: PLL will not be halted<br>0x1: PLL will be halted based on activity                                                                                                                         | RW   | 0x0       |
| 1    | DSI_PLL_GATEMODE   | Allow PLL clock gating for power saving<br>0x0: CLKIN4DDR on<br>0x1: CLKIN4DDR gated by DSI Protocol Engine activity                                                                                                                      | RW   | 0x0       |
| 0    | DSI_PLL_AUTOMODE   | Automatic update mode.<br>If this bit is set then the configuration updates will be synchronized to DISPC_UPDATE_SYNC.<br>If this bit is clear configuration updates will be done immediately.<br>0x0: Manual mode<br>0x1: Automatic mode | RW   | 0x0       |

**Table 7-449. Register Call Summary for Register DSI\_PLL\_CONTROL**

Display Subsystem Functional Description

- [DSI PLL Power Control Commands: \[0\] \[1\]](#)

Display Subsystem Basic Programming Model

- [DSI PLL Go Sequence: \[2\] \[3\] \[4\] \[5\]](#)

Display Subsystem Use Cases and Tips

- [Set Up DSI DPLL: \[6\]](#)
- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O: \[7\]](#)

Display Subsystem Register Manual

- [DSI PLL Controller Register Mapping Summary: \[8\]](#)

**Table 7-450. DSI\_PLL\_STATUS**

| Address Offset     | 0x0000 0004 |                                               | Physical Address | 0x4804 FF04 | Instance | DSI_PLL_CTRL |    |    |    |    |    |    |    |    |    |    |    |    |    |                |                     |               |                |                    |              |                 |               |              |                       |   |   |
|--------------------|-------------|-----------------------------------------------|------------------|-------------|----------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------|---------------------|---------------|----------------|--------------------|--------------|-----------------|---------------|--------------|-----------------------|---|---|
| <b>Description</b> |             | This register contains the status information |                  |             |          |              |    |    |    |    |    |    |    |    |    |    |    |    |    |                |                     |               |                |                    |              |                 |               |              |                       |   |   |
| <b>Type</b>        |             | R                                             |                  |             |          |              |    |    |    |    |    |    |    |    |    |    |    |    |    |                |                     |               |                |                    |              |                 |               |              |                       |   |   |
| 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 |
| RESERVED           |             |                                               |                  |             |          |              |    |    |    |    |    |    |    |    |    |    |    |    |    | DSI_BYPASSACKZ | DSI_PROTO_CLOCK_ACK | DSS_CLOCK_ACK | DSI_PLL_BYPASS | DSI_PLL_HIGHJITTER | DSI_PLL_LIMP | DSI_PLL_LOSSREF | DSI_PLL_RECAL | DSI_PLL_LOCK | DSI_PLCTRL_RESET_DONE |   |   |

## Display Subsystem Register Manual

www.ti.com

| Bits  | Field Name             | Description                                                                                                                                                                                                                        | Type | Reset    |
|-------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:10 | RESERVED               | Reserved. Reads return zero.                                                                                                                                                                                                       | R    | 0x000000 |
| 9     | DSI_BYPASSACKZ         | State of bypass mode on PHY and HSDIVIDER<br><br>0x0: DSI_PHY and HSDIVIDER have switched to using the bypass clocks.<br><br>0x1: PLL outputs are still being used by DSI_PHY or HSDIVIDER                                         | R    | 0x0      |
| 8     | DSIPROTO_CLOCK_ACK     | Acknowledge for enable of DSI Protocol Engine clock<br>Verify the status before selecting this source in the DSI Protocol Engine clock mux<br><br>0x0: DSI Protocol Engine clock inactive<br>0x1: DSI Protocol Engine clock active | R    | 0x0      |
| 7     | DSS_CLOCK_ACK          | Acknowledge for enable of DSS clock<br>Verify the status before selecting this source in the DSS clock multiplexer<br><br>0x0: DSS clock inactive<br>0x1: DSS clock active                                                         | R    | 0x0      |
| 6     | DSI_PLL_BYPASS         | DSI PLL Bypass status<br><br>0x0: PLL not bypassing<br>0x1: PLL bypass                                                                                                                                                             | R    | 0x0      |
| 5     | DSI_PLL_HIGHJITTER     | DSI PLL High Jitter status<br><br>0x0: PLL in normal jitter condition<br>0x1: PLL in high jitter condition: Phase error 24% (TIGHTPHASELOCK = 0) Phase error 12% (TIGHTPHASELOCK = 1)                                              | R    | 0x0      |
| 4     | DSI_PLL_LIMP           | DSI PLL Limp status<br><br>0x0: LIMP mode inactive<br>0x1: LIMP mode active                                                                                                                                                        | R    | 0x0      |
| 3     | DSI_PLL_LOSSREF        | DSI PLL Reference Loss status<br><br>0x0: Reference input active<br>0x1: Reference input inactive                                                                                                                                  | R    | 0x0      |
| 2     | DSI_PLL_RECAL          | DSI PLL re-calibration status<br>If this bit is active, the PLL must be recalibrated<br><br>0x0: Recalibration is not required<br>0x1: Recalibration is required                                                                   | R    | 0x0      |
| 1     | DSI_PLL_LOCK           | DSI PLL Lock status<br>See the programming guide for the use of this bit<br><br>0x0: PLL is not locked<br>0x1: PLL is locked                                                                                                       | R    | 0x0      |
| 0     | DSI_PLLCTRL_RESET_DONE | DSI PLL Controller reset done status<br><br>0x0: Reset is in progress<br>0x1: Reset has completed                                                                                                                                  | R    | 0x0      |

**Table 7-451. Register Call Summary for Register DSI\_PLL\_STATUS**

## Display Subsystem Functional Description

- [Error Handling: \[0\] \[1\]](#)

## Display Subsystem Basic Programming Model

- [Software Reset: \[2\]](#)
- [DSI PLL Clock Gating Sequence: \[3\]](#)
- [DSI PLL Error Handling: \[4\] \[5\] \[6\] \[7\]](#)

## Display Subsystem Use Cases and Tips

- [Set Up DSI DLL: \[8\]](#)
- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O: \[9\]](#)

## Display Subsystem Register Manual

- [DSI PLL Controller Register Mapping Summary: \[10\]](#)

**Table 7-452. DSI\_PLL\_GO**

|                         |                                   |                         |                 |                 |              |
|-------------------------|-----------------------------------|-------------------------|-----------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x0000 0008                       | <b>Physical Address</b> | 0x4804 FF08     | <b>Instance</b> | DSI_PLL_CTRL |
| <b>Description</b>      | This register contains the GO bit |                         |                 |                 |              |
| <b>Type</b>             | RW                                |                         |                 |                 |              |
| 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 |                 |              |
| RESERVED                |                                   |                         |                 |                 | DSI_PLL_GO   |

| Bits | Field Name | Description                                                                                                                                                                                                            | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Reserved. Write only zero for future compatibility. Reads return zero.                                                                                                                                                 | R    | 0x00000000 |
| 0    | DSI_PLL_GO | Request (re-)locking sequence of the PLL.<br>If the AutoMode bit is set, then this will be deferred until DISPC_UPDATE_SYNC goes active<br><br>0x0: No pending action<br>0x1: Request PLL (re-)locking/locking pending | RW   | 0x0        |

**Table 7-453. Register Call Summary for Register DSI\_PLL\_GO**

Display Subsystem Basic Programming Model

- [DSI PLL Go Sequence: \[0\] \[1\]](#)
- [DSI PLL Clock Gating Sequence: \[2\] \[3\]](#)
- [DSI PLL Recommended Values: \[4\]](#)

Display Subsystem Use Cases and Tips

- [Set Up DSI DPLL: \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O: \[10\] \[11\] \[12\] \[13\] \[14\]](#)

Display Subsystem Register Manual

- [DSI PLL Controller Register Mapping Summary: \[15\]](#)
- [DSI PLL Control Module Registers: \[16\]](#)

**Table 7-454. DSI\_PLL\_CONFIGURATION1**

|                         |                                                                        |                         |                 |                 |                  |
|-------------------------|------------------------------------------------------------------------|-------------------------|-----------------|-----------------|------------------|
| <b>Address Offset</b>   | 0x0000 000C                                                            | <b>Physical Address</b> | 0x4804 FF0C     | <b>Instance</b> | DSI_PLL_CTRL     |
| <b>Description</b>      | This register contains the latched PLL and HSDIVDER configuration bits |                         |                 |                 |                  |
| <b>Type</b>             | RW                                                                     |                         |                 |                 |                  |
| 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 |                 |                  |
| RESERVED                | DSIPROTO_CLOCK_DIV                                                     | DSS_CLOCK_DIV           | DSI_PLL_REGM    | DSI_PLL_REGN    | DSI_PLL_STOPMODE |

| Bits  | Field Name         | Description                                                                    | Type | Reset |
|-------|--------------------|--------------------------------------------------------------------------------|------|-------|
| 31:27 | RESERVED           | Reserved. Write only zero for future compatibility. Reads return zero.         | R    | 0x00  |
| 26:23 | DSIPROTO_CLOCK_DIV | Divider value for DSI Protocol Engine clock source REGM4                       | RW   | 0x0   |
| 22:19 | DSS_CLOCK_DIV      | Divider value for DSS clock source REGM3                                       | RW   | 0x0   |
| 18:8  | DSI_PLL_REGM       | M Divider for PLL                                                              | RW   | 0x000 |
| 7:1   | DSI_PLL_REGN       | N Divider for PLL (Reference)                                                  | RW   | 0x00  |
| 0     | DSI_PLL_STOPMODE   | DSI PLL STOPMODE<br>0x0: STOPMODE is not selected<br>0x1: STOPMODE is selected | RW   | 0x0   |

**Table 7-455. Register Call Summary for Register DSI\_PLL\_CONFIGURATION1**

Display Subsystem Functional Description

- [DSI PLL Operations](#): [0] [1] [2]

Display Subsystem Basic Programming Model

- [DSI PLL Lock Sequence](#): [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14]
- [DSI PLL Recommended Values](#): [15]

Display Subsystem Use Cases and Tips

- [Set Up DSI DLL](#): [16] [17] [18] [19] [20]
- [Configure DSI Protocol Engine, DSI PLL, and Complex I/O](#): [21] [22] [23] [24] [25]

Display Subsystem Register Manual

- [DSI PLL Controller Register Mapping Summary](#): [26]

**Table 7-456. DSI\_PLL\_CONFIGURATION2**

| Address Offset     | 0x0000 0010 |                                                                                                                                     | Physical Address | 0x4804 FF10          |    | Instance           | DSI_PLL_CTRL |                |    |              |    |              |    |                 |    |               |    |                  |    |                |    |                 |    |                      |   |                        |   |                     |   |                  |   |          |   |              |  |
|--------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------------|----|--------------------|--------------|----------------|----|--------------|----|--------------|----|-----------------|----|---------------|----|------------------|----|----------------|----|-----------------|----|----------------------|---|------------------------|---|---------------------|---|------------------|---|----------|---|--------------|--|
| <b>Description</b> |             | This register contains the unlatched PLL and HSDIVIDER configuration bits These bits are "shadowed" when automatic mode is selected |                  |                      |    |                    |              |                |    |              |    |              |    |                 |    |               |    |                  |    |                |    |                 |    |                      |   |                        |   |                     |   |                  |   |          |   |              |  |
| Type               | RW          |                                                                                                                                     | 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            |  |
| RESERVED           |             | DSI_HSDIVBYPASS                                                                                                                     |                  | DSI_PROTO_CLOCK_PWDN |    | DSI_PROTO_CLOCK_EN |              | DSS_CLOCK_PWDN |    | DSS_CLOCK_EN |    | DSI_BYPASSEN |    | DSI_PHY_CLKINEN |    | DSI_PLL_REFEN |    | DSI_PLL_HIGHFREQ |    | DSI_PLL_CLKSEL |    | DSI_PLL_LOCKSEL |    | DSI_PLL_DRIFTGUARDEN |   | DSI_PLL_TIGHTPHASELOCK |   | DSI_PLL_LOWCURRSTBY |   | DSI_PLL_PLLPMODE |   | RESERVED |   | DSI_PLL_IDLE |  |

| Bits  | Field Name           | Description                                                                                                                                                   | Type | Reset |
|-------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED             | Reserved. Write only zero for future compatibility. Reads return zero.                                                                                        | R    | 0x000 |
| 20    | DSI_HSDIVBYPASS      | Forces HSDIVIDER to bypass mode<br>0x0: HSDIVIDER in normal operation. Bypass controlled by PLL.<br>0x1: HSDIVIDER forced to bypass mode.                     | RW   | 0x0   |
| 19    | DSI_PROTO_CLOCK_PWDN | Power down for DSI Protocol Engine clock source<br>0x0: DSI Protocol Engine clock divider is active<br>0x1: DSI Protocol Engine clock divider is powered-down | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b>      | <b>Description</b>                                                                                                                                                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 18          | DSI_PROTO_CLOCK_EN     | Enable for DSI Protocol Engine clock source<br><br>0x0: DSI Protocol Engine clock divider is disabled<br><br>0x1: DSI Protocol Engine clock divider is enabled                                                                                                            | RW          | 0x0          |
| 17          | DSS_CLOCK_PWDN         | Power down for DSS clock source<br><br>0x0: DSS clock divider is active<br><br>0x1: DSS clock divider is powered-down                                                                                                                                                     | RW          | 0x0          |
| 16          | DSS_CLOCK_EN           | Enable for DSS clock source<br><br>0x0: DSS clock divider is disabled<br><br>0x1: DSS clock divider is enabled                                                                                                                                                            | RW          | 0x0          |
| 15          | DSI_BYPASSEN           | Selects DSS functional clock as CLKIN4DDR source<br><br>0x0: PLL controls CLKIN4DDR source: PLL DCO if PLL is locked<br>DSS functional clock if not locked<br><br>0x1: Force DSS functional clock to be used as CLKIN4DDR source                                          | RW          | 0x0          |
| 14          | DSI_PHY_CLKINEN        | CLKIN4DDR control<br><br>0x0: CLKIN4DDR is disabled<br><br>0x1: CLKIN4DDR is enabled                                                                                                                                                                                      | RW          | 0x0          |
| 13          | DSI_PLL_REFEN          | PLL reference clock control<br><br>0x0: PLL reference clock disabled<br><br>0x1: PLL reference clock enabled                                                                                                                                                              | RW          | 0x0          |
| 12          | DSI_PLL_HIGHFREQ       | Enables a division of pixel clock by 2 before input to the PLL<br>Required for pixel clock frequencies above 32 MHz (21 MHZ if N = 0)<br><br>0x0: Pixel clock is not divided<br><br>0x1: Pixel clock is divided by 2                                                      | RW          | 0x0          |
| 11          | DSI_PLL_CLKSEL         | Reference clock selection<br><br>0x0: Selects DSS2_ALWON_FCLK as PLL reference clock<br><br>0x1: Selects Pixel Clock (PCLKFREE) as PLL reference clock                                                                                                                    | RW          | 0x0          |
| 10:9        | DSI_PLL_LOCKSEL        | Selects the lock criteria for the PLL<br><br>0x0: Phase Lock criteria depends on setting of<br>DSI_PLL_TIGHTPHASELOCK bit<br><br>0x1: Frequency lock<br><br>0x2: Spare                                                                                                    | RW          | 0x0          |
| 8           | DSI_PLL_DRIFTGUARDEN   | DSI PLL DRIFTGUARDEN<br><br>0x0: Only RECAL flag is asserted in case of temperature drift.<br>The programmer should take appropriate action.<br><br>0x1: Temperature drift will initiate automatic recalibration. RECAL flag will be asserted while this is taking place. | RW          | 0x0          |
| 7           | DSI_PLL_TIGHTPHASELOCK | DSI PLL Phase Lock criteria<br>If this bit is set, the phase lock tolerance is reduced<br><br>0x0: Normal phase lock criteria Phase error lower than 6.4 %<br><br>0x1: Tightened phase lock criteria Phase error lower than 3.2 %                                         | RW          | 0x0          |
| 6           | DSI_PLL_LOWCURRSTBY    | PLL LOW CURRENT STANDBY<br><br>0x0: LOWCURRSTBY is not selected<br><br>0x1: LOWCURRSTBY is selected                                                                                                                                                                       | RW          | 0x0          |
| 5           | DSI_PLL_PLLPMODE       | Select the power/performance of the PLL<br><br>0x0: Full performance, minimized jitter<br><br>0x1: Reduced power, increased jitter                                                                                                                                        | RW          | 0x0          |
| 4:1         | RESERVED               | Reserved                                                                                                                                                                                                                                                                  | R           | 0x0          |
| 0           | DSI_PLL_IDLE           | DSI PLL IDLE:<br><br>0x0: IDLE is not selected<br><br>0x1: IDLE is selected                                                                                                                                                                                               | RW          | 0x0          |

**Table 7-457. Register Call Summary for Register DSI\_PLL\_CONFIGURATION2**

---

Display Subsystem Integration

- [Clocks](#): [0] [1]
- 

Display Subsystem Functional Description

- [DSI PLL Controller Architecture](#): [2] [3]
  - [DSI PLL Operations](#): [4] [5] [6]
- 

Display Subsystem Basic Programming Model

- [DSI PLL Go Sequence](#): [7] [8] [9]
  - [DSI PLL Lock Sequence](#): [10] [11] [12] [13]
- 

Display Subsystem Use Cases and Tips

- [Set Up DSI DPLL](#): [14]
  - [Configure DSI Protocol Engine, DSI PLL, and Complex I/O](#): [15] [16] [17] [18]
- 

Display Subsystem Register Manual

- [DSI PLL Controller Register Mapping Summary](#): [19]
-

## **2D/3D Graphics Accelerator**

This chapter describes the 2D/3D graphics accelerator (SGX) for the device.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

**NOTE:** The SGX subsystem is a Texas Instruments instantiation of the POWERVR® SGX530 core from Imagination Technologies Ltd.

This document contains materials that are ©2003-2007 Imagination Technologies Ltd.

POWERVR® and USSE™ are trademarks or registered trademarks of Imagination Technologies Ltd.

---

| Topic                                       | Page        |
|---------------------------------------------|-------------|
| <b>8.1 SGX Overview .....</b>               | <b>1970</b> |
| <b>8.2 SGX Integration .....</b>            | <b>1973</b> |
| <b>8.3 SGX Functional Description .....</b> | <b>1975</b> |
| <b>8.4 SGX Register Manual .....</b>        | <b>1977</b> |

---

## 8.1 SGX Overview

The 2D/3D graphics accelerator (SGX) subsystem accelerates 2-dimensional (2D) and 3-dimensional (3D) graphics applications. The SGX subsystem is based on the POWERVR® SGX core from Imagination Technologies. SGX is a new generation of programmable POWERVR graphic cores. The POWERVR SGX530 v1.2.5 architecture is scalable and can target all market segments from mainstream mobile devices to high-end desktop graphics. Targeted applications include feature phone, PDA, and hand-held games.

[Figure 8-1](#) shows the SGX subsystem in the device.

**Figure 8-1. Graphics Accelerator Highlight**



sgx-001

The SGX graphics accelerator can simultaneously process various multimedia data types:

- Pixel data
- Vertex data
- Video data
- General-purpose processing

This is achieved through a multithreaded architecture using two levels of scheduling and data partitioning enabling zero-overhead task switching.

The SGX subsystem is connected to the L3 interconnect by a 128-bit master and a 32-bit slave interface.

### 8.1.1 POWERVR SGX Main Features

- 2D graphics, 3D graphics, vector graphics, and programming support for GP-GPU functions
- Tile-based architecture
- Universal scalable shader engine ( USSE™) – multithreaded engine incorporating pixel and vertex shader functionality
- Advanced shader feature set – in excess of Microsoft VS3.0, PS3.0, and OpenGL2.0

- Industry-standard API support – Direct3D Mobile, OpenGL ES 1.1 and 2.0, OpenVG v1.0.1
- Fine-grained task switching, load balancing, and power management
- Advanced geometry direct memory access (DMA) driven operation for minimum CPU interaction
- Programmable high-quality image anti-aliasing
- POWERVR SGX core MMU for address translation from the core virtual address to the external physical address (up to 4GB address range)
- Fully virtualized memory addressing for OS operation in a unified memory architecture
- Advanced and standard 2D operations [e.g., vector graphics, BLTs (block level transfers), ROPs (raster operations)]
- 32K stride support

### 8.1.2 SGX 3D Features

- Deferred pixel shading
- On-chip tile floating point depth buffer
- 8-bit stencil with on-chip tile stencil buffer
- 8 parallel depth/stencil tests per clock
- Scissor test
- Texture support:
  - Cube map
  - Projected textures
  - 2D textures
  - Nonsquare textures
- Texture formats:
  - RGBA 8888, 565, 1555
  - Monochromatic 8, 16, 16f, 32f, 32int
  - Dual channel, 8:8, 16:16, 16f:16f
  - Compressed textures PVR-TC1, PVR-TC2, ETC1
  - Programmable support for all YUV formats
- Resolution support:
  - Frame buffer maximum size = 2048 x 2048
  - Texture maximum size = 2048 x 2048
- Texture filtering:
  - Bilinear, trilinear
  - Independent minimum and maximum control
- Antialiasing:
  - 4x multisampling
  - Up to 16x full scene anti-aliasing
  - Programmable sample positions
- Indexed primitive list support
  - Bus mastered
- Programmable vertex DMA
- Render to texture:
  - Including twiddled formats
  - Auto MipMap generation
- Multiple on-chip render targets (MRT).

**Note:** Performance is limited when the on-chip memory is not available.

### 8.1.3 Universal Scalable Shader Engine (USSE) – Key Features

The USSE is the engine core of the POWERVR SGX architecture and supports a broad range of instructions.

- Single programming model:
  - Multithreaded with 16 simultaneous execution threads and up to 64 simultaneous data instances
  - Zero-cost swapping in, and out, of threads
  - Cached program execution model
  - Dedicated pixel processing instructions
  - Dedicated video encode/decode instructions
- SIMD execution unit supporting operations in:
  - 32-bit IEEE float
  - 2-way 16-bit fixed point
  - 4-way 8-bit integer
  - 32-bit bit-wise (logical only)
- Static and dynamic flow control:
  - Subroutine calls
  - Loops
  - Conditional branches
  - Zero-cost instruction predication
- Procedural geometry:
  - Allows generation of primitives
  - Effective geometry compression
  - High-order surface support
- External data access:
  - Permits reads from main memory using cache
  - Permits writes to main memory
  - Data fence facility
  - Dependent texture reads

## 8.2 SGX Integration

Figure 8-2 highlights the SGX subsystem integration in the device.

**Figure 8-2. SGX Subsystem Integration**



sgx-002

### 8.2.1 Clocking, Reset, and Power-Management Scheme

#### 8.2.1.1 Clocks

The SGX subsystem operates from two clocks: an interface clock (SGX\_ICLK) and a functional clock (SGX\_FCLK). The power, reset, and clock management (PRCM) module generates and distributes both clocks inside the device. The SGX clock tree is depicted in the *SGX Power Domain Clocking Scheme* figure in [Chapter 3, Power, Reset, and Clock Management](#).

**Table 8-1. Clock Descriptions**

| Signal Name | I/O <sup>(1)</sup> | Description                                                             |
|-------------|--------------------|-------------------------------------------------------------------------|
| SGX_FCLK    | I                  | Functional clock (two possible clock sources) → Functional clock domain |
| SGX_ICLK    | I                  | Interface clock (L3 interconnect clock domain) → Interface clock domain |

<sup>(1)</sup> I =Input; O=Output

- The SGX\_ICLK interface clock manages the data transfer on the L3 master and slave ports. The source of SGX\_ICLK is the PRCM clock (SGX\_ICLK), which belongs to the SGX clock domain and runs at the L3 interconnect clock speed. The SGX\_ICLK frequency is selected based on the whole device L3 interconnect clock frequency. For more information on the interface clock, see [Chapter 3, Power, Reset, and Clock Management](#).

When no longer required by the SGX subsystem, SGX\_ICLK can be disabled by software at the PRCM level by setting the PRCM.CM\_ICLKEN\_SGX[0] EN\_SGX bit to 0. For more information, see

the SGX Power Domain Clock Controls section in [Chapter 3, Power, Reset, and Clock Management](#).

---

**NOTE:** SGX\_ICLK is cut only if the SGX is ready to go into idle state. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

---

- SGX\_FCLK is the functional clock and is used inside the SGX subsystem to generate SGX 2D and 3D domain clock signals.

The source of SGX\_FCLK is shown in the SGX Power Domain Clock Controls section of the [Chapter 3, Power, Reset, and Clock Management](#) chapter. Selection is made at the PRCM level by setting the PRCM.CM\_CLKSEL\_SGX[2:0] CLKSEL\_SGX bit field (see the *GFX Functional Clock Ratio Settings* table in [Chapter 3, Power, Reset, and Clock Management](#)).

Depending on the clock source selection and DPLL settings, SGX\_FCLK can support a frequency up to 200 MHz.

SGX\_FCLK gating depends on the PRCM.CM\_FCLKEN\_SGX[1] EN\_SGX bit. Clearing this bit to 0 indicates that both SGX clocks are no longer needed and can be cut at the PRCM level if the module is ready to enter the idle state. For more information, see the SGX Power Domain section in [Chapter 3, Power, Reset, and Clock Management](#).

### 8.2.1.2 Resets

The SGX subsystem has its own reset domain. Global reset of the SGX is performed by activating the SGX\_RST signal in the SGX\_RST domain. Software controls the release of SGX\_RST using the PRCM.RM\_RSTCTRL\_SGX[0] SGX\_RST bit.

### 8.2.1.3 Power Management

The SGX subsystem has its own power domain (SGX power domain). See [Chapter 3, Power, Reset, and Clock Management](#), for additional information about the SGX power domain.

As described in [Section 8.2, SGX Integration](#), the SGX subsystem receives two clock signals from the PRCM module. The functional clock is used inside the SGX to generate clock signals to the multiple internal module SGX clock domains. The division ratio depends on the PRCM registers setting. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

Three power-management modes are defined:

- Deep power sleep (All clocks are gated.)
- Idle (2D and 3D clocks are gated.)
- 3D (No clock is gated.)

The SGX handles the automatic clock gating performed on the multiple internal module clock domains.

## 8.2.2 Hardware Requests

### 8.2.2.1 Interrupt Request

The SGX subsystem can generate one interrupt (SGX\_IRQ) to the MPU subsystem interrupt controller mapped on M\_IRQ\_21.

## 8.3 SGX Functional Description

### 8.3.1 SGX Block Diagram

The SGX subsystem is based on the POWERVR® SGX530 core from Imagination Technologies. The architecture uses programmable and hard coded pipelines to perform various processing tasks required in 2D, 3D, and video processing. The SGX architecture comprises the following elements:

- Coarse grain scheduler
  - Programmable data sequencer (PDS)
  - Data master selector (DMS)
- Vertex data master (VDM)
- Pixel data master (PDM)
- General-purpose data master
- USSE
- Tiling coprocessor
- Pixel coprocessor
- Texturing coprocessor
- Multilevel cache

Figure 8-3 shows a block diagram of the SGX cores.

**Figure 8-3. SGX Block Diagram**



### 8.3.2 SGX Elements Description

The coarse grain scheduler (CGS) is the main system controller for the POWERVR SGX architecture. It consists of two stages, the DMS and the PDS. The DMS processes requests from the data masters and determines which tasks can be executed given the resource requirements. The PDS then controls the loading and processing of data on the USSE.

There are three data masters in the SGX core:

- The VDM is the initiator of transform and lighting processing within the system. The VDM reads an input control stream, which contains triangle index data and state data. The state data indicates the PDS program, size of the vertices, and the amount of USSE output buffer resource available to the VDM. The triangle data is parsed to determine unique indices that must be processed by the USSE. These are grouped together according to the configuration provided by the driver and presented to the DMS.
- The PDM is the initiator of rasterization processing within the system. Each pixel pipeline processes pixels for a different half of a given tile, which allows for optimum efficiency within each pipe due to locality of data. It determines the amount of resource required within the USSE for each task. It merges this with the state address and issues a request to the DMS for execution on the USSE.
- The general-purpose data master responds to events within the system (such as end of a pass of triangles from the ISP, end of a tile from the ISP, end of render, or parameter stream breakpoint event). Each event causes either an interrupt to the host or synchronized execution of a program on the PDS. The program may, or may not cause a subsequent task to be executed on the USSE.

The USSE is a user-programmable processing unit. Although general in nature, its instructions and features are optimized for three types of task: processing vertices (vertex shading), processing pixels (pixel shading), and video/imaging processing.

The multilevel cache is a 2-level cache consisting of two modules: the main cache and the mux/arbiter/demux/decompression unit (MADD). The MADD is a wrapper around the main cache module designed to manage and format requests to and from the cache, as well as providing Level 0 caching for texture and USSE requests. The MADD can accept requests from the PDS, USSE, and texture address generator modules. Arbitration, as well as any required texture decompression, are performed between the three data streams.

The texturing coprocessor performs texture address generation and formatting of texture data. It receives requests from either the iterators or USSE modules and translates these into requests in the multilevel cache. Data returned from the cache are then formatted according to the texture format selected, and sent to the USSE for pixel-shading operations.

To process pixels in a tiled manner, the screen is divided into tiles and arranged as groups of tiles by the tiling coprocessor. An inherent advantage of tiling architecture is that a large amount of vertex data can be rejected at this stage, thus reducing the memory storage requirements and the amount of pixel processing to be performed.

The pixel coprocessor is the final stage of the pixel-processing pipeline and controls the format of the final pixel data sent to the memory. It supplies the USSE with an address into the output buffer and then USSE returns the relevant pixel data. The address order is determined by the frame buffer mode. The pixel coprocessor contains a dithering and packing function.

## 8.4 SGX Register Manual

### CAUTION

All SGX registers are limited to 32-bit data accesses, 8- and 16-bit accesses are not allowed because they can corrupt register content.

### 8.4.1 SGX Instance Summary

Table 8-2. SGX Instance Summary

| Module Name | Base Address | Size      |
|-------------|--------------|-----------|
| SGX         | 0x5000 0000  | 64 Kbytes |

### 8.4.2 SGX OCP Registers

#### 8.4.2.1 SGX OCP Register Summary

Table 8-3. SGX Registers Mapping Summary

| Register Name           | Type | Register Width (Bits) | Address Offset | SGX Physical Address |
|-------------------------|------|-----------------------|----------------|----------------------|
| OCP_REVISION            | R    | 32                    | 0x0000 FE00    | 0x5000 FE00          |
| OCP_HWINFO              | R    | 32                    | 0x0000 FE04    | 0x5000 FE04          |
| OCP_SYSCONFIG           | RW   | 32                    | 0x0000 FE10    | 0x5000 FE10          |
| OCP_IRQSTATUS_RA<br>W_0 | RW   | 32                    | 0x0000 FE24    | 0x5000 FE24          |
| OCP_IRQSTATUS_RA<br>W_1 | RW   | 32                    | 0x0000 FE28    | 0x5000 FE28          |
| OCP_IRQSTATUS_RA<br>W_2 | RW   | 32                    | 0x0000 FE2C    | 0x5000 FE2C          |
| OCP_IRQSTATUS_0         | RW   | 32                    | 0x0000 FE30    | 0x5000 FE30          |
| OCP_IRQSTATUS_1         | RW   | 32                    | 0x0000 FE34    | 0x5000 FE34          |
| OCP_IRQSTATUS_2         | RW   | 32                    | 0x0000 FE38    | 0x5000 FE38          |
| OCP_IRQENABLE_SET<br>_0 | RW   | 32                    | 0x0000 FE3C    | 0x5000 FE3C          |
| OCP_IRQENABLE_SET<br>_1 | RW   | 32                    | 0x0000 FE40    | 0x5000 FE40          |
| OCP_IRQENABLE_SET<br>_2 | RW   | 32                    | 0x0000 FE44    | 0x5000 FE44          |
| OCP_IRQENABLE_CLR<br>_0 | RW   | 32                    | 0x0000 FE48    | 0x5000 FE48          |
| OCP_IRQENABLE_CLR<br>_1 | RW   | 32                    | 0x0000 FE4C    | 0x5000 FE4C          |
| OCP_IRQENABLE_CLR<br>_2 | RW   | 32                    | 0x0000 FE50    | 0x5000 FE50          |
| OCP_PAGE_CONFIG         | RW   | 32                    | 0x0000 FF00    | 0x5000 FF00          |
| OCP_INTERRUPT_EVE<br>NT | RW   | 32                    | 0x0000 FF04    | 0x5000 FF04          |
| OCP_DEBUG_CONFIG        | RW   | 32                    | 0x0000 FF08    | 0x5000 FF08          |
| OCP_DEBUG_STATUS        | RW   | 32                    | 0x0000 FF0C    | 0x5000 FF0C          |

### 8.4.2.2 SGX OCP Register Description

**Table 8-4. OCP\_REVISION**

|                                                                                             |                                           |                 |     |
|---------------------------------------------------------------------------------------------|-------------------------------------------|-----------------|-----|
| <b>Address Offset</b>                                                                       | 0x0000 FE00                               |                 |     |
| <b>Physical Address</b>                                                                     | Please refer to <a href="#">Table 8-3</a> | <b>Instance</b> | SGX |
| <b>Description</b>                                                                          | OCP Revision Register.                    |                 |     |
| <b>Type</b>                                                                                 | R                                         |                 |     |
| 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 |                                           |                 |     |
| REVISIONID                                                                                  |                                           |                 |     |

| Bits | Field Name | Description     | Type | Reset              |
|------|------------|-----------------|------|--------------------|
| 31:0 | REVISIONID | Revision value. | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 8-5. Register Call Summary for Register OCP\_REVISION**

- SGX Register Manual
- [SGX OCP Register Summary: \[0\]](#)

**Table 8-6. OCP\_HWINFO**

|                                                                                             |                                           |                 |               |
|---------------------------------------------------------------------------------------------|-------------------------------------------|-----------------|---------------|
| <b>Address Offset</b>                                                                       | 0x0000 FE04                               |                 |               |
| <b>Physical Address</b>                                                                     | Please refer to <a href="#">Table 8-3</a> | <b>Instance</b> | SGX           |
| <b>Description</b>                                                                          | Hardware implementation information       |                 |               |
| <b>Type</b>                                                                                 | R                                         |                 |               |
| 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 |                                           |                 |               |
| RESERVED                                                                                    |                                           |                 |               |
|                                                                                             |                                           |                 | MEM_BUS_WIDTH |
|                                                                                             |                                           |                 | SYS_BUS_WIDTH |

| Bits | Field Name    | Description                                                                                                                                                         | Type | Reset       |
|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:3 | RESERVED      |                                                                                                                                                                     | R    | 0x0000 0000 |
| 2    | MEM_BUS_WIDTH | Memory bus width:<br>Read 0x0: Memory bus width is 64 bits<br>Read 0x1: Memory bus width is 128 bits                                                                | R    | -           |
| 1:0  | SYS_BUS_WIDTH | System bus width:<br>Read 0x0: System bus width is 32 bits<br>Read 0x1: System bus width is 64 bits<br>Read 0x2: System bus width is 128 bits<br>Read 0x3: Reserved | R    | 0x-         |

**Table 8-7. Register Call Summary for Register OCP\_HWINFO**

- SGX Register Manual
- [SGX OCP Register Summary: \[0\]](#)

**Table 8-8. OCP\_SYSCONFIG**

| <b>Address Offset</b>   | 0x0000 FE10                               | <b>Instance</b>                                                                                        | SGX                             |
|-------------------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------|---------------------------------|
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a> |                                                                                                        |                                 |
| <b>Description</b>      | System Configuration register             |                                                                                                        |                                 |
| <b>Type</b>             | RW                                        |                                                                                                        |                                 |
| 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                 |
|                         | RESERVED                                  |                                                                                                        | STANDBY_MODE IDLE_MODE RESERVED |
| Bits                    | Field Name                                | Description                                                                                            | Type                            |
| 31:6                    | RESERVED                                  |                                                                                                        | R 0x0000000                     |
| 5:4                     | STANDBY_MODE                              | Clock standby mode:<br>0x0: Force Standby mode<br>0x1: No Standby mode<br>0x2, 0x3: Smart Standby mode | RW 0x2                          |
| 3:2                     | IDLE_MODE                                 | Clock Idle mode:<br>0x0: Force Idle mode<br>0x1: No idle mode<br>0x2, 0x3: Smart Idle mode             | RW 0x2                          |
| 1:0                     | RESERVED                                  |                                                                                                        | R 0x0                           |

**Table 8-9. Register Call Summary for Register OCP\_SYSCONFIG**

SGX Register Manual

- [SGX OCP Register Summary: \[0\]](#)

**Table 8-10. OCP\_IRQSTATUS\_RAW\_0**

|                         |                                           |                       |                    |
|-------------------------|-------------------------------------------|-----------------------|--------------------|
| <b>Address Offset</b>   | 0x0000 FE24                               | <b>Instance</b>       | SGX                |
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a> |                       |                    |
| <b>Description</b>      | Raw IRQ 0 Status                          |                       |                    |
| <b>Type</b>             | RW                                        |                       |                    |
| 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    |
|                         | RESERVED                                  |                       | INIT_INTERRUPT_RAW |

| Bits | Field Name          | Description                                                                                                                                                        | Type | Reset       |
|------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED            |                                                                                                                                                                    | R    | 0x0000 0000 |
| 0    | INIT_MINTERRUPT_RAW | Interrupt 0 - master port raw event:<br>Write 0x0: no action.<br>Read 0x0: no event pending.<br>Read 0x1: event pending.<br>Write 0x1: set event (used for debug). | RW   | 0           |

**Table 8-11. Register Call Summary for Register OCP\_IRQSTATUS\_RAW\_0**

SGX Register Manual

- SGX OCP Register Summary: [0]

**Table 8-12. OCP\_IRQSTATUS\_RAW\_1**

|                         |                                           |                 |     |
|-------------------------|-------------------------------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 FE28                               |                 |     |
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a> | <b>Instance</b> | SGX |
| <b>Description</b>      | Raw IRQ 1 Status . Slave port interrupt.  |                 |     |
| <b>Type</b>             | RW                                        |                 |     |

|                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| TARGET_SINTERRUPT_RAW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b>     | <b>Description</b>                                                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:1        | RESERVED              |                                                                                                                                                                                        | R           | 0x0000 0000  |
| 0           | TARGET_SINTERRUPT_RAW | <p>Interrupt 1- slave port raw event</p> <p>Write 0x0: no action.</p> <p>Read 0x0: no event pending.</p> <p>Read 0x1: event pending.</p> <p>Write 0x1: set event (used for debug).</p> | RW          | 0            |

**Table 8-13. Register Call Summary for Register OCP\_IRQSTATUS\_RAW\_1**

SGX Register Manual

- SGX OCP Register Summary: [0]

**Table 8-14. OCP\_IRQSTATUS\_RAW\_2**

|                         |                                           |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 FE2C                               |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a> |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Raw IRQ 2 Status. Thalia interrupt.       |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                        |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

THALIA\_IRQ\_RAW

| Bits | Field Name     | Description                                                                                                                                                  | Type | Reset       |
|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED       |                                                                                                                                                              | R    | 0x0000 0000 |
| 0    | THALIA_IRQ_RAW | Interrupt 2 - Thalia raw event<br>Write 0x0: no action.<br>Read 0x0: no event pending.<br>Read 0x1: event pending.<br>Write 0x1: set event (used for debug). | RW   | 0           |

**Table 8-15. Register Call Summary for Register OCP\_IRQSTATUS\_RAW\_2**

SGX Register Manual

- [SGX OCP Register Summary: \[0\]](#)

**Table 8-16. OCP\_IRQSTATUS\_0**

|                         |                                                  |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 FE30                                      |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a>        |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Interrupt 0 Status event. Master port interrupt. |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                               |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

INIT\_INTERRUPT\_STATUS

| Bits | Field Name             | Description                                                                                                                                                                                        | Type | Reset       |
|------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED               |                                                                                                                                                                                                    | R    | 0x0000 0000 |
| 0    | INIT_MINTERRUPT_STATUS | <p>Interrupt 0 - Master port status event</p> <p>Write 0x0: no action.</p> <p>Read 0x0: no event pending.</p> <p>Read 0x1: event pending and interrupt enabled.</p> <p>Write 0x1: clear event.</p> | RW   | 0           |

**Table 8-17. Register Call Summary for Register OCP\_IRQSTATUS\_0**

SGX Register Manual

- SGX OCP Register Summary: [0]

**Table 8-18. OCP\_IRQSTATUS\_1**

|                         |                                           |                 |     |
|-------------------------|-------------------------------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x0000 FE34                               |                 |     |
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a> | <b>Instance</b> | SGX |
| <b>Description</b>      | Interrupt 1 - slave port status event     |                 |     |
| <b>Type</b>             | RW                                        |                 |     |

|                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| TARGET_SINTERRUPT_STATUS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b>        | <b>Description</b>                                                                                                                                                                                      | <b>Type</b> | <b>Reset</b> |
|-------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:1        | RESERVED                 |                                                                                                                                                                                                         | R           | 0x0000 0000  |
| 0           | TARGET_SINTERRUPT_STATUS | <p>Interrupt 1 - slave port status event</p> <p>S<br/>Write 0x0: no action.</p> <p>Read 0x0: no event pending.</p> <p>Read 0x1: event pending and interrupt enabled.</p> <p>Write 0x1: clear event.</p> | RW          | 0            |

**Table 8-19. Register Call Summary for Register OCP\_IRQSTATUS\_1**

---

SGX Register Manual

- SGX OCP Register Summary: [0]

**Table 8-20. OCP\_IRQSTATUS\_2**

|                         |                                   |                         |                                           |                 |                   |
|-------------------------|-----------------------------------|-------------------------|-------------------------------------------|-----------------|-------------------|
| <b>Address Offset</b>   | 0x0000 FE38                       | <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a> | <b>Instance</b> | SGX               |
| <b>Description</b>      | Interrupt 2 - Thalia status event | <b>Type</b>             | RW                                        |                 |                   |
|                         |                                   |                         |                                           |                 |                   |
| 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                           | RESERVED        |                   |
|                         |                                   |                         |                                           |                 | THALIA_IRQ_STATUS |

| Bits | Field Name        | Description                                                                                                                                                                                   | Type | Reset       |
|------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED          |                                                                                                                                                                                               | R    | 0x0000 0000 |
| 0    | THALIA_IRQ_STATUS | Interrupt 2 - Thalia (core) status event<br><br>Write 0x0: no action.<br><br>Read 0x0: no event pending.<br><br>Read 0x1: event pending and interrupt enabled.<br><br>Write 0x1: clear event. | RW   | 0           |

**Table 8-21. Register Call Summary for Register OCP\_IRQSTATUS\_2**

SGX Register Manual

- [SGX OCP Register Summary: \[0\]](#)

**Table 8-22. OCP\_IRQENABLE\_SET\_0**

|                         |                                  |                         |                                           |                 |                       |
|-------------------------|----------------------------------|-------------------------|-------------------------------------------|-----------------|-----------------------|
| <b>Address Offset</b>   | 0x0000 FE3C                      | <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a> | <b>Instance</b> | SGX                   |
| <b>Description</b>      | Enable Interrupt 0 - Master port | <b>Type</b>             | RW                                        |                 |                       |
|                         |                                  |                         |                                           |                 |                       |
| 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                           | RESERVED        |                       |
|                         |                                  |                         |                                           |                 | INIT_INTERRUPT_ENABLE |

| Bits | Field Name             | Description                                                                                                                                                                      | Type | Reset       |
|------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED               |                                                                                                                                                                                  | R    | 0x0000 0000 |
| 0    | INIT_MINTERRUPT_ENABLE | Enable interrupt 0 - master port<br><br>Write 0x0: no action.<br><br>Read 0x0: interrupt is enabled.<br><br>Read 0x1: interrupt is disabled.<br><br>Write 0x1: enable interrupt. | RW   | 0           |

**Table 8-23. Register Call Summary for Register OCP\_IRQENABLE\_SET\_0**

SGX Register Manual

- SGX OCP Register Summary: [0]

**Table 8-24. OCP\_IRQENABLE\_SET\_1**

|                         |                                            |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 FE40                                |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a>  |  |  |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Enable Interrupt 1. Target port interrupt. |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                         |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits | Field Name               | Description                                                                                                                                                                               | Type | Reset       |
|------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED                 |                                                                                                                                                                                           | R    | 0x0000 0000 |
| 0    | TARGET_SINTERRUPT_ENABLE | Enable interrupt 1 - slave port interrupt<br><br>Write 0x0: no action.<br><br>Read 0x0: interrupt is enabled.<br><br>Read 0x1: interrupt is disabled.<br><br>Write 0x1: enable interrupt. | RW   | 0           |

**Table 8-25. Register Call Summary for Register OCP\_IRQENABLE\_SET\_1**

SGX Register Manual

- SGX OCP Register Summary: [0]

**Table 8-26. OCP\_IRQENABLE\_SET\_2**

|                         |                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 FE44                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a>                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Enable Interrupt 2. Thalia (core) interrupt.                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name        | Description                                                                                                                                                                  | Type | Reset       |
|------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED          |                                                                                                                                                                              | R    | 0x0000 0000 |
| 0    | THALIA_IRQ_ENABLE | Enable interrupt 2 - Thalia (core) interrupt<br>Write 0x0: no action.<br>Read 0x0: interrupt is enabled.<br>Read 0x1: interrupt is disabled.<br>Write 0x1: enable interrupt. | RW   | 0           |

**Table 8-27. Register Call Summary for Register OCP\_IRQENABLE\_SET\_2**

SGX Register Manual

- [SGX OCP Register Summary: \[0\]](#)

**Table 8-28. OCP\_IRQENABLE\_CLR\_0**

|                         |                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 FE48                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a>                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Disable Interrupt 0 - Master port                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name              | Description                                                                                                                                                                               | Type | Reset       |
|------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED                |                                                                                                                                                                                           | R    | 0x0000 0000 |
| 0    | INIT_MINTERRUPT_DISABLE | <p>Disable interrupt 0 - master port</p> <p>Write 0x0: no action.</p> <p>Read 0x0: interrupt is enabled.</p> <p>Read 0x1: interrupt is disabled.</p> <p>Write 0x1: disable interrupt.</p> | RW   | 0           |

**Table 8-29. Register Call Summary for Register OCP\_IRQENABLE\_CLR\_0**

SGX Register Manual

- SGX OCP Register Summary: [0]

**Table 8-30. OCP\_IRQENABLE\_CLR\_1**

|                         |                                           |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|-----|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 FE4C                               |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a> |  |  |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  | SGX |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Disable Interrupt 1 - slave port          |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                        |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                           |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---------------------------|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | TARGET_SINTERRUPT_DISABLE |   |

| Bits | Field Name                | Description                                                                                                                                                                              | Type | Reset       |
|------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED                  |                                                                                                                                                                                          | R    | 0x0000 0000 |
| 0    | TARGET_SINTERRUPT_DISABLE | <p>Disable interrupt 1 - slave port</p> <p>Write 0x0: no action.</p> <p>Read 0x0: interrupt is enabled.</p> <p>Read 0x1: interrupt is disabled.</p> <p>Write 0x1: disable interrupt.</p> | RW   | 0           |

**Table 8-31. Register Call Summary for Register OCP\_IRQENABLE\_CLR\_1**

SGX Register Manual

- SGX OCP Register Summary: [0]

**Table 8-32. OCP\_IRQENABLE\_CLR\_2**

|                         |                                              |                       |                 |                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------|-----------------------|-----------------|--------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 FE50                                  |                       |                 |                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a>    |                       |                 |                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Disable Interrupt 2 -Thalia (core) interrupt |                       |                 |                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                           |                       |                 |                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                              |                       |                 | THALIA_IRQ_DISABLE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

  

| Bits | Field Name         | Description                                                                                                                                                                                           | Type | Reset       |
|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED           |                                                                                                                                                                                                       | R    | 0x0000 0000 |
| 0    | THALIA_IRQ_DISABLE | <p>Disable interrupt 2 - Thalia (core) interrupt</p> <p>Write 0x0: no action.</p> <p>Read 0x0: interrupt is enabled.</p> <p>Read 0x1: interrupt is disabled.</p> <p>Write 0x1: disable interrupt.</p> | RW   | 0           |

**Table 8-33. Register Call Summary for Register OCP\_IRQENABLE\_CLR\_2**

SGX Register Manual

- [SGX OCP Register Summary: \[0\]](#)

**Table 8-34. OCP\_PAGE\_CONFIG**

|                         |                                           |                       |                 |                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------|-----------------------|-----------------|---------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 FF00                               |                       |                 |                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a> |                       |                 |                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Configure memory pages..                  |                       |                 |                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                        |                       |                 |                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                           |                       |                 | OCP_PAGE_SIZE      MEM_PAGE_CHECK_EN      MEM_PAGE_SIZE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name        | Description                                                                                                                                                     | Type | Reset     |
|------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | RESERVED          |                                                                                                                                                                 | R    | 0x0000000 |
| 4:3  | OCP_PAGE_SIZE     | Defines the page size on OCP memory interface<br><br>0x0: Page size is 4 KB.<br>0x1: Page size is 2KB<br>0x2: Page size is 1KB.<br>0x3: Page size is 512B.      | RW   | 0x2       |
| 2    | MEM_PAGE_CHECK_EN | Enable page boundary checking.<br><br>0x0: Page boundary checking disabled.<br>0x1: Page boundary checking enabled.                                             | RW   | 1         |
| 1:0  | MEM_PAGE_SIZE     | Defines the page size on internal memory interface<br><br>0x0: Page size is 4 KB.<br>0x1: Page size is 2KB<br>0x2: Page size is 1KB.<br>0x3: Page size is 512B. | RW   | 0x0       |

**Table 8-35. Register Call Summary for Register OCP\_PAGE\_CONFIG**

SGX Register Manual

- SGX OCP Register Summary: [0]

**Table 8-36. OCP\_INTERRUPT\_EVENT**

|                       |                  |                         |                                          |                 |     |
|-----------------------|------------------|-------------------------|------------------------------------------|-----------------|-----|
| <b>Address Offset</b> | 0x0000 FF04      | <b>Physical Address</b> | Plese refer to <a href="#">Table 8-3</a> | <b>Instance</b> | SGX |
| <b>Description</b>    | Interrupt events |                         |                                          |                 |     |
| <b>Type</b>           | RW               |                         |                                          |                 |     |

|                        |          |                           |                            |                       |                 |                      |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|------------------------|----------|---------------------------|----------------------------|-----------------------|-----------------|----------------------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| RESERVED               |          |                           |                            |                       |                 |                      |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| TARGET_INVALID_OCP_CMD | RESERVED | INIT_MEM_REQ_FIFO_OVERRUN | INIT_READ_TAG_FIFO_OVERRUN | INIT_PAGE_CROSS_ERROR | INIT_RESP_ERROR | INIT_RESP_UNUSED_TAG | INIT_RESP_UNEXPECTED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits  | Field Name             | Description                                                                                                                                                                           | Type | Reset     |
|-------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:11 | RESERVED               |                                                                                                                                                                                       | R    | 0x0000000 |
| 10    | TARGET_INVALID_OCP_CMD | Invalid command from OCP<br><br>Write 0x0: clear the event.<br>Read 0x0: no event pending.<br>Read 0x1: event pending.<br>Write 0x1: set event and interrupt if enabled (debug only). | RW   | 0         |

| Bits | Field Name                 | Description                                                                                                                                                                                                                                      | Type | Reset |
|------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 9    | TARGET_CMD_FIFO_FULL       | Command FIFO full<br><br>Write 0x0: Write 0 to clear the event.<br><br>Read 0x0: Read 0 implies no event pending.<br><br>Read 0x1: Read 1 indicates event pending.<br><br>Write 0x1: Write 1 to set event and interrupt if enabled (debug only). | RW   | 0     |
| 8    | TARGET_RESP_FIFO_FULL      | Response FIFO full<br><br>Write 0x0: clear the event.<br><br>Read 0x0: no event pending.<br><br>Read 0x1: event pending.<br><br>Write 0x1: set event and interrupt if enabled (debug only).                                                      | RW   | 0     |
| 7:6  | RESERVED                   |                                                                                                                                                                                                                                                  | R    | 0x0   |
| 5    | INIT_MEM_REQ_FIFO_OVERRUN  | Memory request FIFO overrun.<br><br>Write 0x0: clear the event.<br><br>Read 0x0: no event pending.<br><br>Read 0x1: event pending.<br><br>Write 0x1: set event and interrupt if enabled (debug only).                                            | RW   | 0     |
| 4    | INIT_READ_TAG_FIFO_OVERRUN | Read tag FIFO overrun.<br><br>Write 0x0: clear the event.<br><br>Read 0x0: no event pending.<br><br>Read 0x1: event pending.<br><br>Write 0x1: set event and interrupt if enabled (debug only).                                                  | RW   | 0     |
| 3    | INIT_PAGE_CROSS_ERROR      | Memory page had been crossed during a burst.<br><br>Write 0x0: clear the event.<br><br>Read 0x0: no event pending.<br><br>Read 0x1: event pending.<br><br>Write 0x1: set event and interrupt if enabled (debug only).                            | RW   | 0     |
| 2    | INIT_RESP_ERROR            | Receiving error response.<br><br>Write 0x0: clear the event.<br><br>Read 0x0: no event pending.<br><br>Read 0x1: event pending.<br><br>Write 0x1: set event and interrupt if enabled (debug only).                                               | RW   | 0     |
| 1    | INIT_RESP_UNUSED_TAG       | Receiving response on an unused tag.<br><br>Write 0x0: clear the event.<br><br>Read 0x0: no event pending.<br><br>Read 0x1: event pending.<br><br>Write 0x1: set event and interrupt if enabled (debug only).                                    | RW   | 0     |
| 0    | INIT_RESP_UNEXPECTED       | Receiving response when not expected<br><br>Write 0x0: clear the event.<br><br>Read 0x0: no event pending.<br><br>Read 0x1: event pending.<br><br>Write 0x1: set event and interrupt if enabled (debug only).                                    | RW   | 0     |

**Table 8-37. Register Call Summary for Register OCP\_INTERRUPT\_EVENT**
**SGX Register Manual**

- [SGX OCP Register Summary: \[0\]](#)

**Table 8-38. OCP\_DEBUG\_CONFIG**

|                         |                               |                         |                                           |                                                                       |     |
|-------------------------|-------------------------------|-------------------------|-------------------------------------------|-----------------------------------------------------------------------|-----|
| <b>Address Offset</b>   | 0x0000 FF08                   | <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a> | <b>Instance</b>                                                       | SGX |
| <b>Description</b>      | Configuration of debug modes. |                         |                                           |                                                                       |     |
| <b>Type</b>             | RW                            |                         |                                           |                                                                       |     |
|                         |                               |                         |                                           |                                                                       |     |
| 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                           |                                                                       |     |
| THALIA_INT_BYPASS       | RESERVED                      |                         |                                           | SELECT_INIT_IDLE<br>FORCEPASSDATA<br>FORCEINITIDLE<br>FORCETARGETIDLE |     |

| Bits | Field Name        | Description                                                                                                                                                                                                   | Type | Reset     |
|------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31   | THALIA_INT_BYPASS | Bypass OCP IPG interrupt logic.<br><br>0x0: Don't Bypass.<br><br>0x1: Bypass core interrupt to IO pin, ie disregard the interrupt enable setting in IPG register.                                             | RW   | 0         |
| 30:6 | RESERVED          |                                                                                                                                                                                                               | R    | 0x0000000 |
| 5    | SELECT_INIT_IDLE  | To select which idle the disconnect protocol should act on 0<br><br>0x0: Whole SGX Idle.<br><br>0x1: OCP initiator idle only.                                                                                 | RW   | 0         |
| 4    | FORCE_PASS_DATA   | Forces the initiator to pass data independent of disconnect protocol<br><br>0x0: Normal mode. Don't force.<br><br>0x1: Never fence request to OCP.                                                            | RW   | 0         |
| 3:2  | FORCE_INIT_IDLE   | Forces the OCP master port to Idle.<br><br>0x0: Normal mode - no force.<br><br>0x1: Force port to be always Idle.<br><br>0x2: Forces target port to never be in Idle mode.<br><br>0x3: Normal mode. No force. | RW   | 0x0       |
| 1:0  | FORCE_TARGET_IDLE | Forces the OCP target port to Idle.<br><br>0x0: Normal mode - no force.<br><br>0x1: Force port to be always Idle.<br><br>0x2: Forces target port to never be in Idle mode.<br><br>0x3: Normal mode. No force. | RW   | 0x0       |

**Table 8-39. Register Call Summary for Register OCP\_DEBUG\_CONFIG**

SGX Register Manual

- [SGX OCP Register Summary: \[0\]](#)

**Table 8-40. OCP\_DEBUG\_STATUS**

|                         |                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 FF0C                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | Please refer to <a href="#">Table 8-3</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Status of debug.                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------------|----------------------|-------------|----------------|---------------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| CMD_DEBUG_STATE | CMD_RESP_DEBUG_STATE | TARGET_IDLE | RESP_FIFO_FULL | CMD_FIFO_FULL | RESP_ERROR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                 |                      |             |                |               |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name      | Description                                                                                                                                                                                   | Type | Reset |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 13   | INIT_MDISCACK   | Memory request FIFO full<br>Write 0x0: clear the event.<br>Read 0x0: no event pending<br>Read 0x1: event pending<br>Write 0x1: set the event and interrupt if enabled (debug only)            | RW   | -     |
| 12   | INIT_SCONNECT2  | Defines whether to wait in M_WAIT state for MConnect FSM<br>Read 0x0: Skip M_WAIT state.<br>Read 0x1: Wait in M_WAIT state.                                                                   | R    | -     |
| 11   | INIT_SCONNECT1  | Defines the busy-ness state of the slave<br>Read 0x0: Slave is drained<br>Read 0x1: Slave is loaded                                                                                           | R    | -     |
| 10   | INIT_SCONNECT0  | Disconnect from slave<br>Read 0x0: Disconnect request from slave.<br>Read 0x1: Connect request from slave.                                                                                    | R    | -     |
| 9:8  | INIT_MCONNECT   | Initiator MConnect state<br>Read 0x0: State is M_OFF.<br>Read 0x1: State is M_WAIT.<br>Read 0x2: State is M_DISC.<br>Read 0x3: State is M_CON                                                 | R    | 0bxx  |
| 7:6  | TARGET_SIDLEACK | Acknowledge the SIdleAck state machine<br>Read 0x0: State is FUNCT<br>Read 0x1: State is SLEEP TRANS<br>Read 0x2: Reserved<br>Read 0x3: State is IDLE.                                        | R    | 0bxx  |
| 5:4  | TARGET_SDISCACK | Acknowledge the SDiscAck state machine<br>Read 0x0: State is FUNCT<br>Read 0x1: State is TRANS<br>Read 0x2: Reserved<br>Read 0x3: State is IDLE.                                              | R    | 0bxx  |
| 3    | TARGET_SIDLEREQ | Request the target to go idle.<br>Read 0x0: Don't go idle, or go active.<br>Read 0x1: Go idle.                                                                                                | R    | -     |
| 2    | TARGET_SCONNECT | Target SConnect state<br>Read 0x0: Disconnect interface.<br>Read 0x1: Connect OCP interface.                                                                                                  | R    | -     |
| 1:0  | TARGET_MCONNECT | Target MConnect state<br>Read 0x0: Target is in M_OFF state<br>Read 0x1: Target is in M_WAIT disconnect state.<br>Read 0x2: Target is in M_DISC state.<br>Read 0x3: Target is in M_CON state. | R    | 0bxx  |

**Table 8-41. Register Call Summary for Register OCP\_DEBUG\_STATUS**

## ***Interconnect***

---



---



---

This chapter describes the Interconnect.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

**NOTE:**

- The L3 interconnect is an instantiation of the **SonicsMX®** interconnect from Sonics, Inc.
- The L4 interconnects are instantiations of the **Sonics3220** interconnect from Sonics, Inc.

This document contains materials that are ©2003-2009 Sonics, Inc., and that constitute proprietary information of Sonics, Inc.

SonicsMX and Sonics3220, are trademarks or registered trademarks of Sonics, Inc. All such materials and trademarks are used under license from Sonics, Inc. For additional information, see the SonicsMX or Sonics3220 Reference manuals, or contact Sonics, Inc.

SMX is an abbreviation for SonicsMX.

---



---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To flag interconnect response being blocked, the time-out of target agents attached to unavailable modules can be enabled with the lowest setting.

---

| Topic                                  | Page |
|----------------------------------------|------|
| 9.1 <b>Interconnect Overview</b> ..... | 1994 |
| 9.2 <b>L3 Interconnect</b> .....       | 2003 |
| 9.3 <b>L4 Interconnects</b> .....      | 2059 |

## 9.1 Interconnect Overview

### 9.1.1 Terminology

The following terminology is critical to understanding the interconnect:

- Initiator: Module able to initiate read and write requests to the chip interconnect (typically: processors, DMA, etc.).
- Target: Unlike an initiator, a target module cannot generate read/write requests to the chip interconnect, but it can respond to these requests. However, it may generate interrupts or a DMA request to the system (typically: peripherals, memory controllers).

---

**NOTE:** A module can have several separate ports; therefore, a module can be both an initiator and a target.

---

- Agent: Each connection of one module to one interconnect is done using an agent, which is an adaptation (sometimes configurable) between the module and the interconnect. A target module is connected by a target agent (TA), and an initiator module is connected by an initiator agent (IA).
- OCP: Open-core protocol ([www.ocpip.org](http://www.ocpip.org)) is point-to-point standard protocol between one master port and one slave port.
- OCP master port: Port that can generate OCP commands. An initiator includes at least one master port.
- OCP slave port: Port that responds to OCP commands. A target includes one slave port.
- Interconnect: The decoding, routing, and arbitration logic that enables the connection between multiple initiator modules and multiple target modules connected on it.
- Register target (RT): Special TA used to access the interconnect internal configuration registers
- Dataflow signal: Any OCP signal that is part of a clearly identified OCP transfer or dataflow (typically: command, address, byte enables, etc.). The signal behavior is defined by the OCP protocol semantics.
- Sideband signal: Any OCP signal whose behavior is not associated to a precise OCP transaction or dataflow. The OCP standard does not define specific semantics for these signals.
- Out-of-band error: Any OCP signal whose behavior is associated to an error-reporting scheme of the device, as opposed to in-band errors.

---

**NOTE:** Interrupt requests and DMA requests are not routed by the interconnect in the device.

---

- Firewall: A programmable feature integrated in a target agent or L4 interconnect to prevent unauthorized access to or from a module. A firewall can be configured using three criteria:
  - Initiator requesting access
  - Address space access
  - Type of access
- Thread: Logical entities that allow to have separate independent data flows on a single port.
- Multithreaded ports: A physical port able to simultaneously handle several outstanding transactions. On a multithreaded port, one physical channel (port) is used concurrently for several logical channels (threads). The transfer in each thread must remain in order with respect to each other, but the order between threads can change between requests and responses. Thread management is used for performance optimization purposes and is automatically handled by the system.
- ConnID: Any transaction in the system interconnect is tagged by an in-band qualifier ConnID, which uniquely identifies the initiator at a given interconnect point. A ConnID is transmitted inband with the request and is used for firewall and error-logging mechanism.
- Firewall comparison mechanism: A comparison made in the firewall between access in-band qualifiers and access permissions that are programmed in the firewall configuration registers. If the comparison is successful, access is allowed; otherwise, access is denied.
- MCmd qualifier: Command bus that indicates the type of transfer requested. [Table 9-1](#) lists the commands encoded.

**Table 9-1. MCmd Qualifier Description**

| MCmd[2:0] | Transaction Type |
|-----------|------------------|
| 0 0 0     | Idle             |
| 0 0 1     | Write            |
| 0 1 0     | Read             |
| 0 1 1     | ReadEx           |
| 1 0 0     | Not used         |
| 1 0 1     | Write nonposted  |
| 1 1 0     | Not used         |
| 1 1 1     | Not used         |

- MReqInfo qualifier: Four MReqInfo qualifiers describe the access during the use of the firewall comparison mechanism, as described in [Table 9-2](#).

**Table 9-2. MReqInfo Qualifier Description**

| Qualifiers     | Description          |
|----------------|----------------------|
| MReqType       | 0: Data access       |
|                | 1: Opcode fetch      |
| MReqSupervisor | 0: User mode         |
|                | 1: Supervisor mode   |
| MReqDebug      | 0: Functional access |
|                | 1: Debug access      |

- [L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#): Register that configures the combination of the MReqInfo, allowing access permission to the TM based on the MReqInfo in-band qualifier values.
- SError: Target that indicates an error condition to the initiator.
- SResp qualifier: Response from the target to the initiator concerning the transaction.

**Table 9-3. SResp Qualifier Description**

| SResp[1:0] | Description       |
|------------|-------------------|
| 0 0        | No response       |
| 0 1        | Data valid/accept |
| 1 0        | Not used          |
| 1 1        | Error             |

### 9.1.2 Architecture Overview

The device memory hierarchy includes four levels:

- L1 is internal to the CPUs. It concerns data exchange with the internal Level1 cache memory subsystem, and it is the closest memory to the microprocessor unit (MPU) core and the IVA2.2 core.
- L2 is included in the IVA2.2 subsystem and the MPU subsystem.
- The chip-level interconnect consists of one L3 interconnect and four L4 interconnects. It enables communication among the modules and subsystems in the device.

[Figure 9-1](#) shows an overview of the L3 and L4 interconnect architecture.

- L3 handles many types of data transfers, especially exchanges with system-on-chip/external memories. L3 transfers data with a maximum width of 64 bits from the initiator to the target. The L3 interconnect is a little-endian platform
- L4 is composed of the L4-Core, L4-Per, L4-Wakeup, and L4-Emu interconnects and handles data transfers to peripherals. It supports 32-bit data width transfer and is optimized to support the interconnection of many peripheral targets. These backplanes assume little-endian transactions for narrower targets (8-bit, 16-bit) when doing data packing and unpacking.

**Figure 9-1. Interconnect Architecture Overview**


Modules are connected to the interconnect through an IA for the initiator module and a TA for target modules. Each module/subsystem connection is statically configured to tune the access depending on the characteristics of the module.

To unauthorized a module or L4 interconnect access, some TAs include configurable firewalls (FWs). A firewall restricts or filters the accesses allowed to an initiator according to different access criteria. The firewalls can usually be configured by software.

The L3 and L4 interconnect default setting is fully functional; it enables all possible functional data paths and a minimal default protection setting. However, it is possible to modify the interconnect parameters to fit user expectations.

### 9.1.3 Module Distribution

IAs and TAs provide the interface to connect the different modules and the interconnect.

[Table 9-4](#) through [Table 9-13](#) list the device modules, subsystems, and associated agents. The agents are listed for each interconnect domain:

- L3 initiator and target agents
- L4-Core initiator and target agents
- L4-Per initiator and target agents
- L4-Emu initiator and target agents
- L4-Wakeup initiator and target agents

#### 9.1.3.1 L3 Interconnect Agents

[Table 9-4](#) and [Table 9-5](#) list the IAs and TAs, respectively, of the L3 interconnect.

**Table 9-4. L3 Initiator Agents**

| Module Name              | Description                                                   |
|--------------------------|---------------------------------------------------------------|
| MPU SS                   | MPU subsystem port                                            |
| Display SS               | Display subsystem port                                        |
| IVA2.2 SS                | IVA2.2 subsystem port                                         |
| SGX SS                   | Graphics subsystem port                                       |
| CAMERA SS                | Camera subsystem port                                         |
| SAD2D                    | Die-to-die port                                               |
| sDMA read                | System DMA read port                                          |
| sDMA write               | System DMA write port                                         |
| High-Speed (HS) USB OTG  | Universal Serial Bus High-Speed port OTG controller           |
| High-Speed (HS) USB Host | Universal serial bus High-Speed port host controller          |
| DAP                      | Debug access port (JTAG/Emulation access to system resources) |

**Table 9-5. L3 Target Agents**

| Module Name    | Description                                                                 |
|----------------|-----------------------------------------------------------------------------|
| SMS            | SDRAM memory scheduler port                                                 |
| GPMC           | General-purpose memory controller (for flash memory, SRAM, SROM, etc.) port |
| OCM-ROM        | On-chip memory ROM port                                                     |
| OCM-RAM        | On-chip memory RAM port                                                     |
| SGX            | Graphics subsystem port                                                     |
| IVA2.2         | Image video and audio accelerator subsystem port                            |
| RT             | Register target port to configure L3                                        |
| L4-Core        | Port for L4-Core interconnect                                               |
| L4-Peripherals | Port for L4-Per interconnect                                                |

**Table 9-5. L3 Target Agents (continued)**

| Module Name | Description                  |
|-------------|------------------------------|
| L4-Emu      | Port for L4-Emu interconnect |

For more details on the register target module, see [Section 9.2.3.2, Register Target](#).

### 9.1.3.2 L4-Core Agents

**Table 9-6. L4-Core Initiator Agent**

| Module Name     | Description          |
|-----------------|----------------------|
| L3 interconnect | L3 interconnect port |

**NOTE:** A unique L3 port is used for communication with the L4-Core. For the list of initiators allowed to access the L4 Core peripherals, see [Table 9-14](#).

**Table 9-7. L4-Core Target Agents**

| Module Name              | Description                                          |
|--------------------------|------------------------------------------------------|
| Display subsystem        | Display subsystem configuration port                 |
| Camera subsystem         | Camera subsystem port                                |
| High-Speed (HS) USB OTG  | Universal serial bus High-speed port OTG             |
| High-Speed (FS) USB Host | Universal serial bus High-Speed port Host controller |
| UART1                    | Universal asynchronous receiver transmitter port 1   |
| UART2                    | Universal asynchronous receiver transmitter port 2   |
| I2C1                     | Multimaster interintegrated circuit 1                |
| I2C2                     | Multimaster interintegrated circuit 2                |
| I2C3                     | Multimaster interintegrated circuit 3                |
| McBSP1                   | Multichannel buffered serial port 1                  |
| McBSP5                   | Multichannel buffered serial port 5                  |
| GPTIMER10                | General-purpose timer 10                             |
| GPTIMER11                | General-purpose timer 11                             |
| MMC1                     | Multimedia memory controller SDIO 1                  |
| MMC2                     | Multimedia memory controller SDIO 2                  |
| MMC3                     | Multimedia memory controller SDIO 3                  |
| HDQ/1-Wire               | Single wire serial link low rate                     |
| MLB (Mailbox)            | Mailbox                                              |
| MCSPI1                   | Serial peripheral interface 1                        |
| MCSPI2                   | Serial peripheral interface 2                        |
| MCSPI3                   | Serial peripheral interface 3                        |
| MCSPI4                   | Serial peripheral interface 4                        |
| SR1                      | SmartReflex1                                         |
| SR2                      | SmartReflex2                                         |
| sDMA                     | System DMA controller                                |
| L4-Wakeup                | L4-Wakeup interconnect                               |
| CM                       | Clock manager                                        |
| SCM                      | System control module                                |

### 9.1.3.3 L4-Per Agents

**Table 9-8. L4-Per Initiator Agent**

| Module Name     | Description          |
|-----------------|----------------------|
| L3 interconnect | L3 interconnect port |

**NOTE:** A unique L3 port is used for communication with L4-Per. For the list of initiators allowed to access the L4-Per peripherals, see [Table 9-14](#).

**Table 9-9. L4-Per Target Agents**

| Module Name | Description                                                                    |
|-------------|--------------------------------------------------------------------------------|
| UART3       | Universal asynchronous receiver/transmitter and infrared data association port |
| UART4       | Universal asynchronous receiver transmitter port 4                             |
| McBSP2      | Multichannel buffered serial port 2                                            |
| McBSP3      | Multichannel buffered serial port 3                                            |
| GPTIMER2    | General-purpose timer 2                                                        |
| GPTIMER3    | General-purpose timer 3                                                        |
| GPTIMER4    | General-purpose timer 4                                                        |
| GPTIMER5    | General-purpose timer 5                                                        |
| GPTIMER6    | General-purpose timer 6                                                        |
| GPTIMER7    | General-purpose timer 7                                                        |
| GPTIMER8    | General-purpose timer 8                                                        |
| GPTIMER9    | General-purpose timer 9                                                        |
| GPIO2       | General-purpose I/O 2                                                          |
| GPIO3       | General-purpose I/O 3                                                          |
| GPIO4       | General-purpose I/O 4                                                          |
| GPIO5       | General-purpose I/O 5                                                          |
| GPIO6       | General-purpose I/O 6                                                          |

### 9.1.3.4 L4-Emu Agents

**Table 9-10. L4-Emu Initiator Agents**

| Module Name     | Description          |
|-----------------|----------------------|
| L3 interconnect | L3 interconnect port |
| DAP             | DAP port             |

**NOTE:** The L3 and DAP ports are used for communication with L4-Emu. For the list of initiators allowed to access the L4-Emu peripherals, see [Table 9-14](#).

**Table 9-11. L4-Emu Target Agents**

| Module Name | Description                  |
|-------------|------------------------------|
| L4-Wakeup   | L4 wake-up interconnect      |
| SDTI        | System debug trace interface |
| ETB         | Embedded trace buffer        |
| TPIU        | Trace port interface unit    |

**Table 9-11. L4-Emu Target Agents (continued)**

| Module Name | Description       |
|-------------|-------------------|
| MPU         | ARM9™             |
| DAP         | Debug access port |

### 9.1.3.5 L4-Wakeup Agents

**Table 9-12. L4-Wakeup Initiator Agent**

| Module Name          | Description                    |
|----------------------|--------------------------------|
| L4-Core interconnect | L4-Core interconnect port      |
| L4-Emu interconnect  | L4-Emulation interconnect port |

**NOTE:** The L4-Emu and L4-Core ports are used to communicate with the L4-Wakeup. For the list of initiators allowed to access the L4-Wakeup peripherals, see [Table 9-14](#).

**Table 9-13. L4-Wakeup Target Agents**

| Module Name | Description                  |
|-------------|------------------------------|
| PRM         | Power reset management       |
| GPIO1       | General-purpose I/O 1        |
| GPTIMER1    | General-purpose timer 1      |
| WDTIMER2    | MPU subsystem watchdog timer |
| 32KTIMER    | 32-kHz timer                 |

### 9.1.4 Connectivity Matrix

[Table 9-14](#) lists the functional paths between the L3 interconnect initiator modules and the L3 and L4 TAs. The functional paths are indicated by the use of the following:

- Cell contains a + sign when a functional path exists.
- Cell is blank when no functional path exists.

**Table 9-14. Connectivity Matrix**

| Initiator Ports | L4-Core Target<br><sup>(1)</sup> | L4-Per Target<br><sup>(1)</sup> | L4-Emu Target<br><sup>(1)</sup> | L4-Wakeu p Target<br><sup>(1)</sup> | SMS Target | GPMC Target | OCM RAM Target | OCM ROM Target | RT Target | IVA2.2 Target | SGX Target | MAD2D |
|-----------------|----------------------------------|---------------------------------|---------------------------------|-------------------------------------|------------|-------------|----------------|----------------|-----------|---------------|------------|-------|
| MPU IA          | +                                | +                               | +                               | +                                   | +          | +           | +              | +              | +         | +             | +          | +     |
| SGX IA          |                                  |                                 |                                 |                                     | +          | +           | +              |                |           |               |            | +     |
| IVA2.2 IA       | +                                | +                               | +                               | +                                   | +          | +           | +              |                | +         | +             |            | +     |
| DSS IA          |                                  |                                 |                                 |                                     | +          |             | +              |                |           |               |            | +     |
| CAM IA          |                                  |                                 |                                 |                                     | +          |             | +              |                |           |               |            | +     |
| HS USB Host IA  |                                  |                                 |                                 |                                     | +          | +           | +              |                |           |               |            | +     |
| HS USB OTG IA   |                                  |                                 |                                 |                                     | +          | +           | +              |                |           |               |            | +     |
| sDMA RD IA      | +                                | +                               | +                               | +                                   | +          | +           | +              |                |           | +             | +          | +     |
| sDMA WR IA      | +                                | +                               | +                               | +                                   | +          | +           | +              |                |           | +             | +          | +     |

<sup>(1)</sup> A functional data path always exists from L4 IAs (Core, Per, Emu, and Wakeup) to any L4 target module (Core, Per, Emu, and Wakeup). As a consequence, all L3 initiator modules for which a data path exists to an L4 TA can access L4 peripherals. Restrictions on peripheral access depend on L4 protection mechanism. For more details, see [Section 9.3.3.3](#).

**Table 9-14. Connectivity Matrix (continued)**

| Initiator Ports | L4-Core Target<br><sup>(1)</sup> | L4-Per Target<br><sup>(1)</sup> | L4-Emu Target<br><sup>(1)</sup> | L4-Wakeup Target<br><sup>(1)</sup> | SMS Target | GPMC Target | OCM RAM Target | OCM ROM Target | RT Target | IVA2.2 Target | SGX Target | MAD2D |
|-----------------|----------------------------------|---------------------------------|---------------------------------|------------------------------------|------------|-------------|----------------|----------------|-----------|---------------|------------|-------|
| DAP IA          | +                                | +                               | +                               | +                                  | +          | +           | +              | +              | +         | +             | +          | +     |
| SAD2D IA        | +                                | +                               | +                               | +                                  | +          | +           | +              |                |           |               |            |       |

## 9.2 L3 Interconnect

This section describes the L3 interconnect and its components. With the exception of register points, each component includes functionality for both the request and response network.

### 9.2.1 Overview

The L3 interconnect links cores in a flexible topology that couples low power with high performance. Innovative physical structures and advanced protocols ensure bandwidth and latency to individual IP cores, providing dedicated connections between IP cores and logical connections over a shared interconnect.

[Figure 9-2](#) shows the L3 interconnect.

**Figure 9-2. L3 Interconnect Overview**



The following are the main features of the L3 interconnect:

- 64-bit multipath interconnect to eliminate on-chip bottlenecks
- Special internal target for access to L3 registers (RT)
- Guaranteed quality of service for real-time hardware operators, while maintaining optimal memory latency for MPU accesses to memory resources
- True little-endian platform
- Transaction error tracking and logging
- Built-in protection features:
  - Allow access only to authorized initiator
  - Distributed region-based firewalls for system resource sharing and protection management
- Signaling support for chip-level power management infrastructure
- Two interrupt line signaling transaction error

## 9.2.2 L3 Interconnect Integration

### 9.2.2.1 Clocking, Reset, and Power-Management Scheme

#### 9.2.2.1.1 Clocks

The power, reset, and clock management (PRCM) module provides the L3\_ICLK as the main clock to the L3 interconnect.

In addition to L3\_ICLK, two additional sample signals are provided to module agents to allow internal synchronization. The modules are as follows:

- L4-Core
- L4-Per

For more details on the L3 clock and its setting, see [Chapter 3, Power, Reset, and Clock Management](#).

**Table 9-15. L3 Interconnect Clocks**

| Type                 | Name    | Source | Description                    |
|----------------------|---------|--------|--------------------------------|
| Interface/functional | L3_ICLK | PRCM   | Main clock for L3 interconnect |

#### 9.2.2.1.2 Resets

The L3 interconnect receives a single reset signal, CORE\_RST, from the PRCM module. CORE\_RST is the reset signal to the core power domain. (For more details see [Power, Reset, and Clock Management](#).) When asserted, CORE\_RST resets the L3 internal registers. There is no software reset for the L3 interconnect.

**Table 9-16. L3 Interconnect Reset**

| Type     | Reset Domain | Source | Description                                    |
|----------|--------------|--------|------------------------------------------------|
| Hardware | CORE_RST     | PRCM   | Asynchronous reset for the entire interconnect |

#### 9.2.2.1.3 Power Domain

The L3 interconnect connects into the CORE power domain, which can dynamically switch between supported OPPs. For more details on power voltage scaling, see [Power, Reset, and Clock Management](#).

**Table 9-17. L3 Interconnect Power Domain**

| Interconnect    | Power Domain |
|-----------------|--------------|
| L3 interconnect | CORE         |

#### 9.2.2.1.4 Power Management

As part of the system-wide power-management scheme, the L3 interconnect enters an idle state at the request of the PRCM module. (For more details, see [Chapter 3, Power, Reset, and Clock Management](#).) The L3 interconnect is always in smart-idle mode; that is, it goes into idle state after receiving the request from the PRCM module once all transfer requests are serviced. This functionality is handled by hardware. The L3 interconnect sends an acknowledge signal back to the PRCM module when it enters the idle state.

## 9.2.2.2 Hardware Requests

### 9.2.2.2.1 Interrupt Requests

Three interrupt lines are present at the boundary of the L3 interconnect (see [Table 9-18](#)). They are used for hardware error management.

**Table 9-18. L3 Interconnect Hardware Requests**

| Type      | Name         | Destination                                        | Description                                                                                                                                         |
|-----------|--------------|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Interrupt | M_IRQ_9      | MPU interrupt controller for debug errors          | L3 interconnect provides a mechanism to group core-detected and internal interconnect errors. See <a href="#">Section 9.3.3.4, Error Handling</a> . |
| Interrupt | M_IRQ_10     | MPU interrupt controller for application errors    |                                                                                                                                                     |
| Interrupt | IVA2_IRQ[39] | IVA2.2 interrupt controller for application errors |                                                                                                                                                     |

## 9.2.3 L3 Interconnect Functional Description

### 9.2.3.1 Initiator Identification

An InitiatorID is assigned to every thread on every initiator socket. The ID uniquely identifies the initiator and thread for an interconnect transfer see [Table 9-19](#). The interconnect uses InitiatorIDs for a number of purposes, including the following:

- Initiator source identification for the protection mechanism (see [Section 9.2.3.3, L3 Protection and Firewalls](#))
- Response route generation (performed internally to the TAs)
- Firewall error logging
- L3 interconnect error logging

**Table 9-19. InitiatorID Definition**

| Initiator     | InitiatorID            |
|---------------|------------------------|
| HS USB Host   | 0                      |
| HS USB OTG    | 2                      |
| sDMA rd       | 3 , 4 , 5, 6           |
| sDMA wr       | 7, 8                   |
| DAP           | 9                      |
| CAM           | 10, 11, 12             |
| SGX           | 13                     |
| IVA2.2 SS DMA | 14, 15, 16, 17, 18, 19 |
| IVA2.2 SS     | 20, 21, 22             |
| MPU SS        | 23, 24, 25, 26, 27     |
| SAD2D         | 28                     |
| DSS           | 29                     |

### 9.2.3.2 Register Target

An RT is a specialized TA used to access L3 interconnect internal configuration registers.

RT configuration options are a subset of those available for TAs. For more details, see [Section 9.2.5.3](#).

### 9.2.3.3 L3 Protection and Firewalls

Protection in the device relies heavily on L3 firewalls and their configuration. Nine targets are protected through the use of firewalls. The number of protected regions varies on the target, with a maximum of eight regions. [Table 9-20](#) lists the protection type and the number of protected regions for each target.

**Table 9-20. Target Firewall and Region Configuration**

| Target        | Firewall                   | Number of Regions                                   |
|---------------|----------------------------|-----------------------------------------------------|
| SMS           | Included in the SMS module | See <i>Memory Subsystem</i> .                       |
| GPMC          | Yes                        | 8                                                   |
| OCM-RAM       | Yes                        | 8                                                   |
| OCM-ROM       | Yes                        | 3                                                   |
| MAD2D         | Yes                        | 8                                                   |
| SGX Target    | No                         | 0                                                   |
| IVA2.2 target | Yes                        | 4                                                   |
| L4-Core       | Included in the L4 module  | See <a href="#">Section 9.3, L4 Interconnects</a> . |
| L4-Wakeup     | Included in the L4 module  | See <a href="#">Section 9.3, L4 Interconnects</a> . |
| L4-Emu        | Included in the L4 module  | See <a href="#">Section 9.3, L4 Interconnects</a> . |
| RT            | Yes                        | 2                                                   |

The protection mechanism designates protection regions within the address space of certain targets. Access to these regions is granted only for certain initiators, based on transaction attributes (transmitted through MReqInfo). Each protection region is characterized with several configurable attributes (base address, size, specific access rights, and priority setting).

The protection mechanism uses the following attributes of a request:

- The address field and the address space field are used to determine which region has been hit. The region ID selects one table entry of the firewall look-up table.
- The region ID points to a unique set of permission registers: Read\_Permission, Write\_Permission, ReqInfo\_Permission.
- The Initiator ID is used to determine the permission of the initiator (read/write permission) with respect to the concerned region.
- The access types (read or write) and the transaction attributes (MReqInfo in-band qualifiers) are used to grant or reject the access.

The first check determines whether the type of incoming request (read or write) is allowed, according to the Initiator MCConnID and its read and write permissions. The second check determines whether the MReqInfo bits of the incoming request are within the allowed pattern established by the MReqInfo permission bits. If both check results are positive, the request is allowed to access the target. Otherwise, the access is denied, the request is not forwarded to the target, an out-of-band error indication is reported, and an in-band error response is returned to the initiator (except for writes that were posted at the IA). [Figure 9-3](#) shows the flow used to identify and accept a new request.

**Figure 9-3. Flow Chart of the Protection Mechanism**



intc-014

To summarize, firewalls accept or reject a request depending on the following:

- Initiator originating the request
  - Command (read or write) requested
  - MReqInfo bus state
  - Region access in the target memory space

Software must configure the L3 firewalls properly to allow the right initiators, with the right MReqInfo access, on the well-defined size region. All the registers relative to the L3 firewalls are grouped in the protection mechanism (PM) register block.

**NOTE:** The PM qualifies the protection mechanism register associated with a firewall target. The targets protected by a firewall are listed in [Table 9-20](#). These PM registers do not exist if no firewall is associated with the target.

#### **9.2.3.3.1 Protection Region**

Two types of regions are distinguished in a target firewall (see Figure 9-4):

- Default region: Available in all targets; spans the entire target address range
  - Normal region: Number varies in a target; they have identical capabilities

Each region has the following characteristics:

- A base address, relative to the target address itself, and an address space

- A size
- Specific access rights, as defined through the MReqInfo qualifiers
- A priority level, from 0 (lowest) to 3 (highest)

**Figure 9-4. L3 Firewall Implementation**

#### 9.2.3.3.1.1 Default Region/Region0

Region 0 is the default region of a whole target; it spans the entire target address space.

The default region is always the lowest priority. This region is systematically overlapped when other regions are set.

The [L3\\_PM\\_ADDR\\_MATCH\\_k](#) register is not accessible. Its configuration corresponds to all the possible addresses for the target, including all of ADDR\_SPACE. It is not possible to program multiple ADDR\_SPACE addresses in a normal region.

#### 9.2.3.3.1.2 Normal Regions

Normal regions have identical features.

A given request either maps into a specific protection region or is considered to have hit the default protection region if no normal region is hit.

The protection regions can only be configured for a memory space that is power-of-two in size and size-aligned using the SIZE bit field [L3\\_PM\\_ADDR\\_MATCH\\_k](#) [7:3] (as listed in [Table 9-21](#)). When the SIZE bit field [L3\\_PM\\_ADDR\\_MATCH\\_k](#) [7:3] is set to 0, the region is disabled.

---

**NOTE:** k denotes the region number. Depending on the target, n varies from 0 to 7.

---

[Table 9-21](#) lists the size encoding for each value set in the SIZE bit field.

**Table 9-21. L3 Firewall Size Parameter Definition**

| Possible Configuration |                     |                          |
|------------------------|---------------------|--------------------------|
| Size <sup>(1)</sup>    | Region Size         | Base_Addr <sup>(2)</sup> |
| 0x0                    | Region disabled     | Any (nonsignificant)     |
| 0x1                    | 1K-byte             | 0x0000000                |
|                        |                     | 0x0000400                |
|                        |                     | 0x0000800                |
|                        |                     | ...                      |
| 0x2                    | 2K-byte             | 0x0000000                |
|                        |                     | 0x0000800                |
|                        |                     | 0x0001000                |
|                        |                     | ...                      |
| ...                    | ...                 | ...                      |
| 0x17                   | $2^{(17-1)}K$ -byte |                          |
| Others                 | Not allowed         | -                        |

<sup>(1)</sup> When the size parameter is set to 0, the region is disabled.

<sup>(2)</sup> The base address depends on user settings.

#### 9.2.3.3.2 Priority Level Overview

Each L3 firewall region is prioritized. Depending on its priority level, a region can override the settings of another region.

- Region 0 is the only allowed priority 0 region (lowest priority).
- Region 1 is the only allowed priority 3 region (highest priority).
- Others regions are defined as priority 1 or 2.

**CAUTION**

LEVEL bitfield value of ADDR\_MATCH\_1 register (Region 1 firewall configuration) must be kept to his default reset value and must not be changed; otherwise, the result will be unpredictable and can create unexpected protection holes or denial of service.

Protection level is defined by the LEVEL bit [L3\\_PM\\_ADDR\\_MATCH\\_k](#), where n is greater than 2. [Figure 9-5](#) represents the priority level with associated regions.

When an address hits two or more regions with different priority levels, the highest priority region protections are applied. The overlay region can overlap all or a part of a nonoverlap region.

**CAUTION**

Configuring two overlapping protection regions with the same priority level leads to undefined behavior.

Hardware behavior in the case of overlapping protection regions is undefined. A region with higher priority must be used to mask a region that is being reprogrammed, and any protection holes must be avoided during this reconfiguration.

To change the protection settings of a region, follow this procedure:

1. Ensure that a free region is available to be used as a high-priority region.

2. Program this region as a high-priority region so its parameters match the region to be changed. The final programming must be the [L3\\_PM\\_ADDR\\_MATCH\\_K](#) register, which includes the priority attribute and the size parameter to enable the region.
3. Disable the region to be configured or reconfigure it by setting the SIZE bit field to 0.
4. Set up all region control registers with the new configuration. The final programming must be the [L3\\_PM\\_ADDR\\_MATCH\\_K](#) register, which includes the size parameter to enable the region.
5. Disable the high-priority region by setting its size to 0.

This procedure must be used each time there is an overlap between the originally defined region and the newly defined region. The use of a high-priority region is required to keep protection active during programming.

**Figure 9-5. L3 Region Overlay and Priority Level Overview**

intc-001

#### 9.2.3.3.3 Read and Write Permission

Read permission and write permission are configured using two registers:

- [L3\\_PM\\_READ\\_PERMISSION\\_i](#)
- [L3\\_PM\\_WRITE\\_PERMISSION\\_i](#)

The [L3\\_PM\\_READ\\_PERMISSION\\_i](#) and [L3\\_PM\\_WRITE\\_PERMISSION\\_i](#) registers allow the setting of read and write permission to one or more initiators. To grant read or write access, set the bit associated with the initiator to 1.

#### 9.2.3.3.4 REQ\_INFO\_PERMISSION Configuration

The firewall comparison mechanism enables access to a protected target only when a correct combination of four MReqInfo in-band parameters is transmitted.

MReqInfo is a combination of a fixed 3-bit pattern that corresponds to a combination of the parameters MReqDebug, MReqType, and MReqSupervisor.

Different valid MReqInfo combinations can be defined for each L3 firewall region based on the [L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#) value, which is programmed by software.

For each region, [L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#) lists the possible MReqInfo combinations. Setting a Reqbit in this register determines the type of access authorized to the initiator.

[Table 9-22](#) lists the MReqInfo combinations available and the Reqbit associated with it.

**Table 9-22. MReqInfo Parameter Combinations**

| Reqbit | MReqInfo       |                             |          |
|--------|----------------|-----------------------------|----------|
|        | MReqSupervisor | MReqDebug                   | MReqType |
| 0      | User           | Functional                  | Data     |
| 1      | User           | Functional                  | Code     |
| 2      | User           | Debug                       | Data     |
| 3      | User           | Debug                       | Code     |
| 4      |                | Reserved for non-GP devices |          |
| 5      |                | Reserved for non-GP devices |          |
| 6      |                | Reserved for non-GP devices |          |
| 7      |                | Reserved for non-GP devices |          |
| 8      | Supervisor     | Functional                  | Data     |
| 9      | Supervisor     | Functional                  | Code     |
| 10     | Supervisor     | Debug                       | Data     |
| 11     | Supervisor     | Debug                       | Code     |
| 12     |                | Reserved for non-GP devices |          |
| 13     |                | Reserved for non-GP devices |          |
| 14     |                | Reserved for non-GP devices |          |
| 15     |                | Reserved for non-GP devices |          |

[Figure 9-6](#) shows an example of the [L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#) setting. In this example, [L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#) is set to 0x0C05 (16'b0000\_1100\_0001\_0101) for a specific region, which will grant access only if the request:

- User + Functional + Data
- User + Debug + Data
- Supervisor + Debug + Data
- Supervisor + Debug + Code

**Figure 9-6. Example of REQ\_INFO\_PERMISSION Register**


As another example, to configure a target accessible only for data and in a user mode, Reqbit 0, 1, 2 and 3 must be set. Therefore, the [L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#) register must be set to 0x000F.

#### 9.2.3.3.5 L3 Firewall Registers Overview

[Table 9-23](#) lists the L3 firewall permission-setting registers. [L3\\_PM\\_ADDR\\_MATCH\\_k](#), which is shown in this table, is not an accessible register.

**Table 9-23. L3 Firewall Permission-Setting Registers**

| Register Name                                        | Register Field Name    | Field Modifiability | Parameter Comments                                                                     | Region Comments                                                                                                             |
|------------------------------------------------------|------------------------|---------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| Region 0                                             |                        |                     |                                                                                        |                                                                                                                             |
| <a href="#">L3_PM_ADDR_MATCH_k</a><br>(k=0)          | ADDR_SPACE[2:0]        | Hard coded          | Corresponds to all the target memory space                                             | This region is the default region. The default setting can be changed only with correct access according to L3 RT register. |
|                                                      | SIZE[7:3]              | Hard coded          | Corresponds to all the target memory space                                             |                                                                                                                             |
|                                                      | Reserved               |                     | Default region: Level 0                                                                |                                                                                                                             |
|                                                      | BASE_ADDR[63:10]       | Hard coded          | Target-dependent                                                                       |                                                                                                                             |
| <a href="#">L3_PM_REQ_INFO_PERMISSION_i</a><br>(i=0) | REQ_INFO[15 :0]        | Yes                 | Type of access permitted. See <a href="#">Table 9-22</a> .                             |                                                                                                                             |
| <a href="#">L3_PM_READ_PERMISSION_i</a><br>(i=0)     | READ_PERMISSION[15:0]  | Yes                 | Initiator read permission, depending on connections. See <a href="#">Table 9-14</a> .  |                                                                                                                             |
| <a href="#">L3_PM_WRITE_PERMISSION_i</a><br>(i=0)    | WRITE_PERMISSION[15:0] | Yes                 | Initiator write permission, depending on connections. See <a href="#">Table 9-14</a> . |                                                                                                                             |

**Table 9-23. L3 Firewall Permission-Setting Registers (continued)**

| Register Name               | Register Field Name    | Field Modifiability | Parameter Comments                                                                                                            | Region Comments                                                                           |
|-----------------------------|------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| Region 1-7                  |                        |                     |                                                                                                                               |                                                                                           |
| L3_PM_ADDR_MATCH_K          | ADDR_SPACE[2:0]        | Yes                 |                                                                                                                               | The default settings can be changed only with correct access based on the L3 RT register. |
|                             | SIZE [7:3]             | Yes                 | The regions are power-of-two in size and size-aligned with Base_Addr reference. When Size = 0x0, the firewall is deactivated. |                                                                                           |
|                             | LEVEL[9]               | Yes                 | Protection region level<br>0x0: Level 1<br>0x1: Level 2<br>Region 1 is always Level 3.                                        |                                                                                           |
|                             | BASE_ADDR[63:10]       | Yes                 | Target-dependent                                                                                                              |                                                                                           |
| L3_PM_REQ_INFO_PERMISSION_i | REQ_INFO[15 :0]        | Yes                 | Type of access permitted. See <a href="#">Table 9-22</a> .                                                                    |                                                                                           |
| L3_PM_READ_PERMISSION_i     | READ_PERMISSION[15:0]  | Yes                 | Initiators read permission ,depending on connections. See <a href="#">Table 9-14</a> .                                        |                                                                                           |
| L3_PM_WRITE_PERMISSION_i    | WRITE_PERMISSION[15:0] | Yes                 | Initiators write permission, depending on connections. See <a href="#">Table 9-14</a> .                                       |                                                                                           |

#### 9.2.3.3.6 L3 Firewall Error-Logging Registers

[Table 9-24](#) lists the L3 firewall error-logging registers.

**Table 9-24. L3 Firewall Error Logging Registers**

| Register Name   | Register Field Name | Field Modifiability | Parameter Comments                                                                                                                                                                                                                                                                                         |
|-----------------|---------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L3_PM_ERROR_LOG | CMD[2:0]            | Read only           | Log the OCP command of the request that caused a protection violation. See <a href="#">Table 9-1</a> .                                                                                                                                                                                                     |
|                 | REGION[6:4]         | Read only           | Log the region number targeted by the request that caused the protection violation.                                                                                                                                                                                                                        |
|                 | INITIATOR_ID[15:8]  | Read only           | Log the InitiatorID request that caused the protection violation. See <a href="#">Table 9-19</a>                                                                                                                                                                                                           |
|                 | REQ_INFO[20:16]     | Read only           | Log the MReqInfo bits of the request that caused the protection violation. See <a href="#">Table 9-22</a> .                                                                                                                                                                                                |
|                 | CODE[27:24]         | Read/write          | Log the error that occurred. See <a href="#">Table 9-26</a> .                                                                                                                                                                                                                                              |
|                 | MULT[31]            | Read/write          | If a second error is detected before the first is cleared, the MULT bit is set. Once set by hardware, the CODE and MULT bits can be cleared only by software or a full hardware reset. Software clears the CODE and MULT bits by writing a non-zero value to the CODE field and writing 1 to the MULT bit. |

#### 9.2.3.3.7 L3 Firewall and System Control Module

When a protection violation occurs, an interrupt is sent to the MPU and IVA2.2 interrupt controller (if enabled). An in-band error is sent back, and an out-band error is logged in the CONTROL.CONTROL\_PROT\_ERR\_STATUS register. Two logging registers are used, depending on the functional mode:

- In application mode:
  - CONTROL.CONTROL\_PROT\_ERR\_STATUS [00]: OCM-ROM protection violation
  - CONTROL.CONTROL\_PROT\_ERR\_STATUS [01]: OCM-RAM protection violation

- CONTROL.CONTROL\_PROT\_ERR\_STATUS [02]: GPMC protection violation
- CONTROL.CONTROL\_PROT\_ERR\_STATUS [04]: SMS protection violation
- CONTROL.CONTROL\_PROT\_ERR\_STATUS [05]: MAD2D protection violation
- CONTROL.CONTROL\_PROT\_ERR\_STATUS [06]: IVA2.2 protection violation
- CONTROL.CONTROL\_PROT\_ERR\_STATUS [07]: L4-Core protection violation
- CONTROL.CONTROL\_PROT\_ERR\_STATUS [12]: L3 RT protection violation
- CONTROL.CONTROL\_PROT\_ERR\_STATUS [15]: SAD2D protection violation
- CONTROL.CONTROL\_PROT\_ERR\_STATUS [16]: L4-Per protection violation
- CONTROL.CONTROL\_PROT\_ERR\_STATUS [17]: L4-Emu protection violation
- In debug mode:
  - CONTROL.CONTROL\_PROT\_ERR\_STATUS\_DEBUG [00]: OCM-ROM protection violation
  - CONTROL.CONTROL\_PROT\_ERR\_STATUS\_DEBUG [01]: OCM-RAM protection violation
  - CONTROL.CONTROL\_PROT\_ERR\_STATUS\_DEBUG [02]: GPMC protection violation
  - CONTROL.CONTROL\_PROT\_ERR\_STATUS\_DEBUG [03]: SMS protection violation
  - CONTROL.CONTROL\_PROT\_ERR\_STATUS\_DEBUG [05]: MAD2D protection violation
  - CONTROL.CONTROL\_PROT\_ERR\_STATUS\_DEBUG [06]: IVA2.2 protection violation
  - CONTROL.CONTROL\_PROT\_ERR\_STATUS\_DEBUG [12]: L3 RT protection violation
  - CONTROL.CONTROL\_PROT\_ERR\_STATUS\_DEBUG[16]: L4-Per protection violation
  - CONTROL.CONTROL\_PROT\_ERR\_STATUS\_DEBUG[17]: L4-Emu protection violation

When a violation occurs, these bits are cleared when the L3 or L4 firewall embedded error log registers are cleared.

### 9.2.3.4 Error Handling

#### 9.2.3.4.1 Error Detection and Logging

The L3 interconnect provides mechanisms for the detection, logging, and distribution of module-detected and internal interconnect errors. Hardware support is provided to assist in logging errors and cleaning up the state to allow error recovery software to run.

Two types of errors are identified by the L3 interconnect:

- Errors detected by modules and passed along by the interconnect:
  - SResp error: Using the SResp in-band qualifier from the target, the initiator is informed that its request was unsuccessful (see [Table 9-3](#)). This error is nonspecific and further analysis is required to find its cause.
  - SError: This out-of-band qualifier reports that the target is denied service due to an internal cause. No further analysis can be done in the L3 itself.
- Errors detected by the L3 interconnect:
  - Unsupported command: This error reports that the initiator sent a command that cannot be processed, because the target cannot accept it and no conversion to another command is possible. This error is detected only once per burst.
  - Address hole: This error reports an unknown address for a request. The address map is local to each IA; therefore, an address hole error is reported each time an initiator requests an access to a target it is not logically connected to, even if this address exists in the global L3 address map. This error is detected only once per burst.
  - Protection violation: This error indicates a request was rejected by a firewall.
  - Requests time-out: This error reports that the target did not accept (if no response expected) or did not respond to the request presented by the interconnect TA. In this case, all new requests to this TA will be answered with SResp = ERR.
  - Response time-out: This error reports that the initiator did not accept response from the interconnect IA in the correct time interval (applies only to masters that have response flow control

capabilities). In this case, the IA sends burst close transactions to TAs that have open transactions from this IA. Any new request from this initiator is refused.

- Burst open time-out: This error reports that a burst or ReadEx/Write pair has been started to the interconnect IA by the initiator but did not finish in the correct time interval. If the time interval for any command exceeds the time-out period, a time-out occurs. The initiator does not complete a burst or ReadEx/Write pair. The interconnect IA then closes the transaction by a burst close transaction, to allow traffic from other initiators to resume. Burst close is logged in the interconnect TA when received.

[Figure 9-7](#) shows a global view of the register link to the error reporting structure in an initiator and the target agents.

**Figure 9-7. L3 Error Reporting Structure**


intc-023

Most errors are reported to the IA that originated the request, except for the following:

- Initiator time-outs are reported only out-of-band. Any time-out in the IA results in flagging it as unavailable. A software reset of the agent is required to accept any new requests from the attached core.

- Posted write request, because the IA immediately generates a valid response to the initiator core. This error is only in out-of-band.

[Table 9-25](#) lists where the errors are detected and logged.

**Table 9-25. Error Types**

| Error                        | Detection   | Logging                       | In-Band Report     | Out-of-Band Report |
|------------------------------|-------------|-------------------------------|--------------------|--------------------|
| SResp error                  | None needed | At IA                         | Yes <sup>(1)</sup> | Yes                |
| SError assertion from target | None needed | At TA                         | No                 | Yes                |
| Unsupported command          | At IA       | At IA                         | Yes                | Yes                |
| Address hole                 | At IA       | At IA                         | Yes                | Yes                |
| Protection violation         | At TA       | At protection mechanism agent | Yes <sup>(1)</sup> | Yes                |
| Response time out            | At IA       | At TA                         | No                 | Yes                |
| Request time-out             | At TA       | At IA                         | No                 | Yes                |
| Burst time-out               | At IA       | At IA                         | No                 | Yes                |

<sup>(1)</sup> In case of a posted write, errors cannot be reported in-band.

The time-out errors (request/response and burst) are persistent and require the software to reset both the module and the agent. No request can be processed in the agent until the reset is performed.

Other errors affect only the current request. Subsequent requests are treated normally. Errors are logged, however, and the information about the error used for debugging is kept until the software acknowledges the error.

[Table 9-26](#) lists the information logged for each error code. Information logged in the two error-logging registers ([L3\\_IA\\_ERROR\\_LOG](#), [L3\\_IA\\_ERROR\\_LOG\\_ADDR](#), [L3\\_TA\\_ERROR\\_LOG](#) and [L3\\_TA\\_ERROR\\_LOG\\_ADDR](#) for each IA and TA) depends on the error itself. The CODE field ERROR\_LOG[27:24] identifies the type of error occurring for the IA and TA.

**Table 9-26. CODE Field Definition**

| CODE[3:0] | Error Type                    | Type of Agent |    |    | Information Logged |           |             |     |         |  |
|-----------|-------------------------------|---------------|----|----|--------------------|-----------|-------------|-----|---------|--|
|           |                               | IA            | TA | PM | REQ_INFO           | Secondary | InitiatorID | CMD | Address |  |
| 0         | No error                      | x             | x  |    |                    |           |             |     |         |  |
| 1         | Unsupported command           | x             |    |    | x                  | x         | x           | x   | x       |  |
| 2         | Address hole                  | x             |    |    | x                  | x         | x           | x   | x       |  |
| 3         | Protection violation          |               |    | x  | x                  |           | x           | x   |         |  |
| 4         | In-band error                 | x             |    |    |                    | x         | x           |     |         |  |
| 5         |                               | Not used      |    |    |                    |           |             |     |         |  |
| 6         |                               | Not used      |    |    |                    |           |             |     |         |  |
| 7         | Request time-out not accepted |               | x  |    | x                  |           | x           | x   | x       |  |
| 8         | Request time-out, no response |               | x  |    |                    |           | x           |     |         |  |
| 9-15      |                               | Not used      |    |    |                    |           |             |     |         |  |

#### 9.2.3.4.2 Time-Out

A time-out mechanism can be enabled in the target agent and initiator agent register. When the mechanism is enabled for a target agent or initiator agent and commands are not accepted or responses are not returned within the expected delay, the L3 interconnect generates an error event.

The error is logged in the target agent REQ\_TIMEOUT bit [L3\\_TA\\_AGENT\\_STATUS](#)[8] for a target agent time-out, the BURST\_TIMEOUT bit [L3\\_IA\\_AGENT\\_STATUS](#)[16] bit for an initiator burst time-out, and the RESP\_TIMEOUT bit [L3\\_IA\\_AGENT\\_STATUS](#)[8] for an initiator response time-out. The affected agent enters an error state that causes it to send error responses to any new request. To recover from this state, the target agent must be reset by system software.

The time-out is counted starting from the moment a command is presented to the target, whatever the target response to this command is. The L3 interconnect implements a centralized time-base circuit that broadcasts a set of four periodic pulse signals to all connected target agents. These four signals are referred to as 1x time-base, 4x time-base, 16x time-base, and 64x time-base.

The time-base circuit offers four possible sets of four time-base signals selected by programming the TIMEOUT\_BASE field [L3\\_RT\\_NETWORK\\_CONTROL](#)[10:8]. [Table 9-27](#) lists all of the values in the number of L3 clock cycles.

Each target agent can be programmed to refer to one of the four time-base signals. A time-out condition is detected when either the command acceptance or the response is not received after a delay of between one and three time-base periods. After the time-out is detected and logged, the behavior of the attached module is ignored. A new request to the module arriving at the timed-out target agent receives an error response. If the request is addressed to the agent internal registers, it is processed normally.

To recover from a time-out error, the software is assumed to reset first the faulty module using its internal soft-reset bit, and then the agent using software reset.

**Table 9-27. L3 Timeout Register Target and Agent Programming**

| REQ_TIMEOUT[2:0], BURST_TIMEOUT[2:0], and RESP_TIMEOUT[2:0] |                                        |      |       |       |        |
|-------------------------------------------------------------|----------------------------------------|------|-------|-------|--------|
| TIMEOUT_BASE[2:0]                                           | 0                                      | 1    | 2     | 3     | 4      |
| 0                                                           | All L3 time-out features are disabled. |      |       |       |        |
| 1                                                           | Locally disabled                       | 64   | 256   | 1024  | 4096   |
| 2                                                           |                                        | 256  | 1024  | 4096  | 16384  |
| 3                                                           |                                        | 1024 | 4096  | 16384 | 65536  |
| 4                                                           |                                        | 4096 | 16384 | 65536 | 262144 |

#### 9.2.3.4.3 Error Steering

The error reporting structure consist of errors logged individually in the initiator or TAs. Some errors can be enabled and reported out-of-band by setting the following bits to 1:

- [L3\\_IA\\_AGENT\\_CONTROL.BURST\\_TIMEOUT REP](#) bit for burst time-out
- [L3\\_IA\\_AGENT\\_CONTROL.RESP\\_TIMEOUT REP](#) bit for response time-out
- [L3\\_TA\\_AGENT\\_CONTROL.REQ\\_TIMEOUT REP](#) bit for request time-out
- [L3\\_TA\\_AGENT\\_CONTROL.SERROR REP](#) bit for request time-out

Setting the [L3\\_IA\\_AGENT\\_CONTROL.ALL\\_INBAND\\_ERROR REP](#) bit causes all in-band errors returned to the IA to be reported out-of-band.

IAs connected to processors capable of generating the debug-flagged requests (the MPU and IVA2.2 subsystems) use error steering. Any error linked to an application (nondebug) request is qualified as primary; any error linked to a debug request is qualified as secondary. Setting the IA.INBAND\_ERROR\_PRIMARY REP or INBAND\_ERROR\_SECONDARY REP bit to 1 allows the reporting of in-band to out-of-band primary and secondary errors.

The level of the current error is indicated in SECONDARY bit [L3\\_IA\\_ERROR\\_LOG](#)[30]. If an error occurs while another error is pending, the following occurs:

- If the pending error is primary, the new error is discarded at the IA level. MULTI bit [L3\\_IA\\_ERROR\\_LOG](#)[31] is set in the initiator error log register to indicate that another error has been detected; no further information can be stored.
- If both the pending error and the new error are secondary, the latest error is discarded and MULTI bit [L3\\_IA\\_ERROR\\_LOG](#)[31] is set.

- If the pending error is secondary and the incoming error is primary, MULTI bit [L3\\_IA\\_ERROR\\_LOG\[31\]](#) is set and all useful information about the new error (MCmd, MAddr, MReqInfo, etc.) is stored. All information relative to the secondary error is discarded.

For protection violation, errors are detected at the TA and steered to the control module (see [Section 9.2.3.3.7, L3 Firewall and System Control Module](#)).

#### 9.2.3.4.4 Global Error Reporting

An out-of-band error refers to any flag output from the L3. It is not a formal error in the sense that it is not processed directly by the interconnect module; however, it is interpreted as such by one or several processors, typically by mapping it to an interrupt controller. All L3 out-of-band errors are ORed together and the result is transmitted to one or several interrupt controllers. All out-of-band errors are active high and must be acknowledged through a register access to be deasserted.

Out-of-band errors are reported through error or flag signals, asynchronously to any other data flow, but synchronously to the clock.

All errors are reported out-of-band to the IVA2.2 and MPU subsystems simultaneously. The processors must check whether an error is relevant to the subsystems. These errors are routed not only to the IVA2.2 and MPU subsystem interrupt controllers, but also to their emulation logic (see [Figure 9-8](#)). Two composite flags help in asserting the error origin and criticality:

- The L3 application error flag reports application or nonattributable (not related to a request such as a time-out, SError) errors.
- The L3 debug error flag reports debug errors.

**Figure 9-8. Global Error Routing**


intc-011

In addition to the SResp qualifier error reporting, some external targets use an SError signal to indicate that an internal error has occurred. Some resetting action may be required before any new request can be accepted, depending on the module and on the error itself. These signals are routed as flags internally to the L3. [Table 9-28](#) lists the possible errors reported through an SError, propagated externally to the L3 application error flag.

**Table 9-28. L3 External Input Flags**

| Target     | Flag   | Description                                 | Software Visible?                                                     |
|------------|--------|---------------------------------------------|-----------------------------------------------------------------------|
| GPMC       | SError | General-purpose error occurs in GPMC module | Yes, in FLAG_STATUS register and in L3 TA SERROR bit AGENT_STATUS[24] |
| SGX master | MError | General-purpose error occurs in SGX master  | Yes, in FLAG_STATUS register and in L3 IA MERROR bit AGENT_STATUS[24] |
| SGX target | SError | General-purpose error occurs in SGX target  | Yes, in FLAG_STATUS register and in L3 TA SERROR bit AGENT_STATUS[24] |

**NOTE:** The user must ensure that the corresponding IRQ lines are set correctly in the interrupt controllers of the MPU and IVA2.2 subsystems.

Figure 9-9 shows the routing of errors to the application and debug error composite flags. Because both debug capable processors, the MPU and IVA2.2 subsystems have access to the full error report mechanism; they can be debugged independently of one another.

**Figure 9-9. L3 Error Routing**



Table 9-29 lists the bit and source for the STATUS bit field [L3\\_SI\\_FLAG\\_STATUS\\_0\[63:0\]](#) for an application error, and Table 9-30 lists the bit and source for the STATUS bit field [L3\\_SI\\_FLAG\\_STATUS\\_1\[63:0\]](#) for an application error for a debug error.

Protection errors are reported in-band to the IA when possible. This may not be possible for posted writes, however. These errors are also reported asynchronously to the module.

Additionally, all protection errors (even posted writes) are seen by the in-band-to-out-of-band conversion logic in the IAs. Therefore, all protection errors feed into the L3 application error and L3 debug error composite flags, and hence back to the MPU and IVA2.2 subsystems.

The SMS, L4-Core, L4 Per, and L4-Emu interconnects have internal firewalls that use the same reporting scheme. These errors are not routed directly to the L3 interconnect but are reported in-band to the initiator, which routes them to the composite flags. The SMS, L4-Core, L4-Per, and L4-Emu interconnects always provide an error on the in-band SResp qualifier for protection violations.

**Table 9-29. L3\_SI\_FLAG\_STATUS\_0 for Application Error**

| Flag Bit Number | Source   |                         | Flag Bit Number | Source   |                   |
|-----------------|----------|-------------------------|-----------------|----------|-------------------|
|                 | Agent    | Error                   |                 | Agent    | Error             |
| 0               | MPU IA   | Burst time-out          | 32              | Reserved |                   |
| 1               | MPU IA   | Response time-out       | 33              | SAD2D IA | Burst time-out    |
| 2               | MPU IA   | Functional Inband error | 34              | SAD2D IA | Response time-out |
| 3               | Reserved |                         | 35              | SAD2D IA | SError            |
| 4               |          |                         | 36              | Reserved |                   |
| 5               |          |                         | 37              | Reserved |                   |

**Table 9-29. L3\_SI\_FLAG\_STATUS\_0 for Application Error (continued)**

| Flag Bit Number | Source         |                         | Flag Bit Number | Source     |                  |  |  |  |
|-----------------|----------------|-------------------------|-----------------|------------|------------------|--|--|--|
|                 | Agent          | Error                   |                 | Agent      | Error            |  |  |  |
| 6               | IVA2.2 IA      | Burst time-out          | 38              | Reserved   |                  |  |  |  |
| 7               | IVA2.2 IA      | Response time-out       |                 |            |                  |  |  |  |
| 8               | IVA2.2 IA      | Functional Inband error |                 |            |                  |  |  |  |
| 9               | SGX IA         | Burst time-out          |                 |            |                  |  |  |  |
| 10              | SGX IA         | Functional Inband error |                 |            |                  |  |  |  |
| 11              | SGX IA         | MError                  |                 |            |                  |  |  |  |
| 12              | CAMERA IA      | Burst time-out          |                 |            |                  |  |  |  |
| 13              | CAMERA IA      | Response time-out       |                 |            |                  |  |  |  |
| 14              | CAMERA IA      | Functional Inband error |                 |            |                  |  |  |  |
| 15              | Display SS IA  | Burst time-out          |                 |            |                  |  |  |  |
| 16              | Display SS IA  | Functional Inband error |                 |            |                  |  |  |  |
| 17              | Reserved       |                         |                 |            |                  |  |  |  |
| 18              | sDMA Rd IA     | Burst time-out          |                 |            |                  |  |  |  |
| 19              | sDMA Rd IA     | Functional Inband error |                 |            |                  |  |  |  |
| 20              | Reserved       | Reserved                | 52              | Reserved   |                  |  |  |  |
| 21              | sDMA Wr IA     | Burst time-out          |                 | Reserved   |                  |  |  |  |
| 22              | sDMA Wr IA     | Functional Inband error |                 | IVA2.2 TA  | Request time-out |  |  |  |
| 23              | Reserved       |                         | 55              |            |                  |  |  |  |
| 24              | HS USB OTG IA  | Burst time-out          |                 |            |                  |  |  |  |
| 25              | HS USB OTG IA  | Response time-out       | 56              | SGX TA     | Request time-out |  |  |  |
| 26              | HS USB OTG IA  | Functional Inband error | 57              | SGX TA     | SError assertion |  |  |  |
| 27              | HS USB Host IA | Burst time-out          | 58              | GPMC TA    | SError assertion |  |  |  |
| 28              | HS USB Host IA | Functional Inband error | 59              | L4-Core TA | Request time-out |  |  |  |
| 29              | Reserved       |                         | 60              | L4-Per TA  | Request time-out |  |  |  |
| 30              |                |                         | 61              | L4-Emu     | Request time-out |  |  |  |
| 31              |                |                         | 62              | Reserved   |                  |  |  |  |
|                 |                |                         | 63              |            |                  |  |  |  |

**Table 9-30. L3\_SI\_FLAG\_STATUS\_1 for Debug Error**

| Flag Bit Number | Source      |             | Flag Bit Number | Source   |       |  |  |  |
|-----------------|-------------|-------------|-----------------|----------|-------|--|--|--|
|                 | Agent       | Error       |                 | Agent    | Error |  |  |  |
| 0               | MPU DATA IA | Debug error | 32              | Reserved |       |  |  |  |
| 1               |             |             |                 |          |       |  |  |  |
| 2               |             |             |                 |          |       |  |  |  |
| 3               | DAP IA      | Debug error |                 |          |       |  |  |  |
| 4               | DAP IA      | Debug error |                 |          |       |  |  |  |
| 5               |             |             |                 |          |       |  |  |  |
| 6               | IVA2.2 IA   | Debug error |                 |          |       |  |  |  |
| 7               |             |             |                 |          |       |  |  |  |
| 8               |             |             |                 |          |       |  |  |  |
| 9               |             |             |                 |          |       |  |  |  |
|                 |             |             | 37              |          |       |  |  |  |
|                 |             |             | 38              |          |       |  |  |  |
|                 |             |             | 39              |          |       |  |  |  |
|                 |             |             | 40              |          |       |  |  |  |
|                 |             |             | 41              |          |       |  |  |  |

**Table 9-30. L3\_SI\_FLAG\_STATUS\_1 for Debug Error (continued)**

| Flag Bit Number | Source   |          | Flag Bit Number | Source   |          |
|-----------------|----------|----------|-----------------|----------|----------|
|                 | Agent    | Error    |                 | Agent    | Error    |
| 10              | Reserved | Reserved | 42              | Reserved | Reserved |
| 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              |          |          |

## 9.2.4 L3 Interconnect Basic Programming Model

### 9.2.4.1 General Recommendation

The L3 interconnect registers must be read or written with little-endian attributes; otherwise, the result is undefined.

#### CAUTION

Overlapping between protection regions with the same priority level leads to unpredictable behavior and must be avoided.

### 9.2.4.2 Initialization

At the release of power on reset, the L3 firewall default configuration enables all accesses to target modules, except for a section of the OCM ROM.

Generally, software must configure the firewall properly to avoid poor use of the hardware resources.

L3 time-out capabilities are also disabled at reset.

### 9.2.4.3 Error Analysis

The information required to analyze an error source is logged in several registers (see [Table 9-26](#)). The number of registers to access depends on the error source. When investigating the origin of an error, software reads a set of error log registers. At each stage, the register either states the current error or points to the next agent in which the error is logged. [Figure 9-10](#) shows the software sequence required in most cases.

**Figure 9-10. Typical Error Analysis Sequence**



intc-012

Errors that do not result from an in-band to out-of-band conversion can be extracted immediately from the application or debug error flag by reading the STATUS field [L3\\_SI\\_FLAG\\_STATUS\\_0\[63:0\]](#) and [L3\\_SI\\_FLAG\\_STATUS\\_1\[63:0\]](#) register; therefore, they do not require the whole analysis sequence shown in [Table 9-26](#).

When analysis leads to a TA error, software must read the initiator agent ADDR field [L3\\_IA\\_ERROR\\_LOG\\_ADDR\[39:0\]](#) to extract the TA address causing the error.

#### 9.2.4.3.1 Time-Out Handling

This section gives information about all modules and features in the high-tier device. To flag interconnect response being blocked, the time-out of target agents attached to unavailable modules can be enabled with the lowest setting.

##### Example 1

In this example, the MPU interrupt handler detects an error from the L3 interconnect. A read access from the [L3\\_SI\\_FLAG\\_STATUS\\_0](#) register reports a value of 0x40000. As described in [Table 9-29](#), the error detected is a burst time-out from the sDMA read port.

As with any time-out error, the affected module is now considered to be out-of-service. If necessary, the error can be cleared by sending a soft reset command to the agent (set CORE\_RESET bit [L3\\_IA\\_AGENT\\_CONTROL\[0\]](#) to 1, and then to 0). During this time the initiator is off-line. Although the rest of the system still behaves normally, a time-out error is usually severe enough to require a complete reset of the chip.

Before resetting the agent or the system, the error log registers can learn the status of the interconnect and determine the type of failure. Reading the [IA\\_SDMA\\_RD.L3\\_IA\\_AGENT\\_STATUS](#) register shows whether the time-out was detected during a burst or during a read/write sequence.

##### Example 2

In this example, the MPU interrupt controller detects an error from the L3 interconnect. A read access from the [L3\\_SI\\_FLAG\\_STATUS\\_0](#) register reports a value of 0x100. This is a functional error from the IVA2.2 subsystem initiator.

The [IA\\_IVA2.2.L3\\_IA\\_ERROR\\_LOG](#) register should be read next. The value stored in it is 0x12\_0400\_1302.

- CMD field [IA\\_IVA2.2.L3\\_IA\\_ERROR\\_LOG\[2:0\]](#): Value 0x2. Not applicable for an in-band error.
- INITID field [IA\\_IVA2.2.L3\\_IA\\_ERROR\\_LOG\[15:8\]](#): Value 0x13. The origin of the error is the IVA2.2 subsystem sDMA.
- CODE field [IA\\_IVA2.2.L3\\_IA\\_ERROR\\_LOG\[27:24\]](#): Value 0x4. Error is an in-band error.
- SECONDARY bit [IA\\_IVA2.2.L3\\_IA\\_ERROR\\_LOG\[30\]](#): Value 0x0. The error is functional.
- MULTI bit [IA\\_IVA2.2.L3\\_IA\\_ERROR\\_LOG\[31\]](#): Value 0x0. No additional error has been detected.
- REQ\_INFO field [IA\\_IVA2.2.L3\\_IA\\_ERROR\\_LOG\[43:32\]](#): Value 0x12. Not applicable for an in-band error.

There is no simple way to determine which target originated the in-band error. An SError assertion or a request time-out would have been detected and logged in the [L3\\_SI\\_FLAG\\_STATUS\\_0](#) register. Because no such error is asserted (bits 60:48 are still 0), the error can only be a firewall error or have originated in the target itself. The user must read all of the [PM\\_xxx.L3\\_PM\\_ERROR\\_LOG](#) registers.

#### CAUTION

The PM register blocks are sensitive registers and are usually protected. Ensure that the processor used to debug the error is allowed to access these registers. If not, the access will be rejected and another error will be generated.

All [PM\\_xxx.L3\\_PM\\_ERROR\\_LOG](#) registers are clear (bits 27:24 equal 0x0) except for [PM\\_OCMRAM.L3\\_PM\\_ERROR\\_LOG](#), which reads 0x0302\_1301. The error occurred while trying to access the OCM RAM.

---

**NOTE:** If all [PM\\_xxx.L3\\_PM\\_ERROR\\_LOG](#) registers are clear, the error is unrelated to the interconnect. Further analysis must be done in the targets.

---

- Bits 27:24: Value 0x3. There is a protection error.
- Bits 2:0: Value 0x1. The command was a posted write.
- Bits 6:4: Value 0x0. The address is protected by Region 0 (default region) of the firewall.
- Bits 15:8: Value 0x13. The origin of the error is the IVA2.2, thread 2. This is consistent with the error log on the initiator side, and confirms this error report is the correct one.
- Bits 20:16: Value 0x2. The protection parameters were data, debug, and user.
- Bit 31: Value 0x0. This is the only error detected.

A check on the protection configuration confirms that this access was not allowed, either because the initiator was not given write access or because the protection access parameters were not compatible with the PM\_OCMRAM.REQINFO\_PERMISSIONS\_0 settings.

A protection violation is not terminal from the interconnect point of view. If the module responsible for the global chip protection do not reset the system (including the IVA2.2 subsystem and the OCM RAM), it continues to run normally. A simple clearing of the error on both the IA and PM sides is required to return to a clean status.

#### 9.2.4.3.2 Acknowledging Errors

Time-out errors can never be acknowledged. To return to a normal operation after an error, the faulty agent must be reset. An agent can be reset by asserting CORE\_RESET bit [L3\\_IA\\_AGENT\\_CONTROL\[0\]](#) or [L3\\_TA\\_AGENT\\_CONTROL\[0\]](#), or by resetting the L3 interconnect through the PRCM.

Functional errors, including an in-band signal reporting a protection error, must be inactivated through software. Setting the INBAND\_ERROR\_PRIMARY and INBAND\_ERROR\_SECONDARY bits [L3\\_IA\\_AGENT\\_STATUS\[28:29\]](#) in an IA, or setting the SERROR bit [L3\\_IA\\_AGENT\\_STATUS\[24\]](#) in a TA clears the reported error. [Table 9-31](#) lists the bit to clear and the associated type of error.

The [L3\\_IA\\_ERROR\\_LOG](#) or [L3\\_TA\\_ERROR\\_LOG](#) register must also be cleared by writing a nonzero value simultaneously to the CODE bit field and the values currently stored in the MULTI and SECONDARY fields.

**Table 9-31. Error Clearing**

| Agent Type | Error                               | Register Field         |
|------------|-------------------------------------|------------------------|
| Initiator  | In-band primary (application) error | INBAND_ERROR_PRIMARY   |
|            | In-band secondary (debug) error     | INBAND_ERROR_SECONDARY |
| Target     | Target asserts SError               | SERROR                 |

The procedure to clear protection errors depends on the system protection configuration:

- Write a nonzero value simultaneously into CODE bit field [L3\\_PM\\_ERROR\\_LOG\[27:24\]](#) and the value currently stored in the MULTI bit [L3\\_PM\\_ERROR\\_LOG\[31\]](#) of the corresponding PM register block.
- Alternately, read either [L3\\_PM\\_ERROR\\_CLEAR\\_SINGLE](#) or [L3\\_PM\\_ERROR\\_CLEAR\\_MULTI](#), depending on the current value of the MULTI field in the [L3\\_PM\\_ERROR\\_LOG](#) register. This solution, which allows the clearing of protection errors without having a write access on other protection registers, preserves protection.

[L3\\_SI\\_FLAG\\_STATUS\\_0](#) or [L3\\_SI\\_FLAG\\_STATUS\\_1](#) must be checked at the end of any error acknowledging sequence to confirm that the acknowledgement was successful and that no other error is pending.

#### 9.2.4.4 Typical Example of Firewall Programming Example

All four regions in the IVA2.2 target firewall can be configured with no restrictions. However, protection is required for a 14K-byte region starting at address 0x0 in address space 2, and it must accept any access from any initiator for the rest of the target. The protection restricts allowed accesses as follows:

- Only the IVA2.2 and the MPU can read from this memory.
- Only the MPU can write to this memory.
- The protection parameters must include supervisor and functional.

Only accesses declared as supervisor and functional are allowed to pass through the protected region of the firewall. There is no restriction on other attributes.

[Table 9-32](#) lists the possible parameter combinations, whether they are allowed to pass or not, and why they are rejected.

**Table 9-32. MReqInfo Parameter Example**

| Reqbit | MReqInfo       |                             |          |                |                      |
|--------|----------------|-----------------------------|----------|----------------|----------------------|
|        | MReqSupervisor | MReqDebug                   | MReqType | Access Allowed | Reason for Rejection |
| 0      | User           | Functional                  | Data     | No             | Not supervisor       |
| 1      | User           | Functional                  | Code     | No             | Not supervisor       |
| 2      | User           | Debug                       | Data     | No             | Not supervisor       |
| 3      | User           | Debug                       | Code     | No             | Not supervisor       |
| 4      |                | Reserved for non-GP devices |          | No             |                      |
| 5      |                | Reserved for non-GP devices |          | No             |                      |
| 6      |                | Reserved for non-GP devices |          | No             |                      |
| 7      |                | Reserved for non-GP devices |          | No             |                      |
| 8      | Supervisor     | Functional                  | Data     | Yes            |                      |
| 9      | Supervisor     | Functional                  | Code     | Yes            |                      |
| 10     | Supervisor     | Debug                       | Data     | No             | Not functional       |
| 11     | Supervisor     | Debug                       | Code     | No             | Not functional       |
| 12     |                | Reserved for non-GP devices |          | No             |                      |
| 13     |                | Reserved for non-GP devices |          | No             |                      |
| 14     |                | Reserved for non-GP devices |          | No             |                      |
| 15     |                | Reserved for non-GP devices |          | No             |                      |

Only combinations with codes 8 and 9 are allowed to access a target. REQ\_INFO field PM\_IVA2.2.[L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#)[15:0] for the protected region must be set to (0x8) | (0x9); that is, 0x0300.

### Solution 1

Set Region 0 to accept all accesses:

- PM\_IVA2.2.[L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#) (i=0)= 0xFFFF
- PM\_IVA2.2.[L3\\_PM\\_READ\\_PERMISSION\\_i](#) (i=0)= 0x140E
- PM\_IVA2.2.[L3\\_PM\\_WRITE\\_PERMISSION\\_i](#) (i=0)= 0x140E

Set Region 1 to cover the first 8K bytes of the protected region:

- PM\_IVA2.2.[L3\\_PM\\_ADDR\\_MATCH\\_k](#) (k=1) = 0x22 (start address 0x0, size 8K bytes, address space 2)
- PM\_IVA2.2.[L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#) (i=1) = 0x0300
- PM\_IVA2.2.[L3\\_PM\\_READ\\_PERMISSION\\_i](#) (i=1) = 0x0406 (IVA2.2 DMA and MMU and MPU are allowed)
- PM\_IVA2.2.[L3\\_PM\\_WRITE\\_PERMISSION\\_i](#) (i=1) = 0x0002 (only MPU is allowed to write)

Set Region 2 to cover the next 4K bytes:

- PM\_IVA2.2.[L3\\_PM\\_ADDR\\_MATCH\\_k](#) (k=2) = 0x201A (start address 0x2000, level 1, size 4K bytes, address space 2)
- PM\_IVA2.2.[L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#) (i=2) = 0x0300
- PM\_IVA2.2.[L3\\_PM\\_READ\\_PERMISSION\\_i](#) (i=2) = 0x0406
- PM\_IVA2.2.[L3\\_PM\\_WRITE\\_PERMISSION\\_i](#) (i=2) = 0x0002

Set Region 3 to cover the last 2K bytes:

- PM\_IVA2.2.[L3\\_PM\\_ADDR\\_MATCH\\_K](#) (k=3)= 0x3012 (start address 0x3000, level 1, size 2K bytes, address space 2)
- PM\_IVA2.2.[L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#) (i=3) = 0x0300
- PM\_IVA2.2.[L3\\_PM\\_READ\\_PERMISSION\\_i](#) (i=3) = 0x0406
- PM\_IVA2.2.[L3\\_PM\\_WRITE\\_PERMISSION\\_i](#) (i=3) = 0x0002

[Figure 9-11](#) shows the firewall configuration for Solution 1.

**Figure 9-11. Firewall Configuration Solution 1**



## Solution 2

Set Region 0 to accept all accesses:

- PM\_IVA2.2.[L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#) (i=0) = 0xFFFF
- PM\_IVA2.2.[L3\\_PM\\_READ\\_PERMISSION\\_i](#) (i=0) = 0x140E
- PM\_IVA2.2.[L3\\_PM\\_WRITE\\_PERMISSION\\_i](#) (i=0) = 0x140E

Set Region 2 to cover 16K bytes:

- PM\_IVA2.2.[L3\\_PM\\_ADDR\\_MATCH\\_K](#) (k=2) = 0x2A (start address 0x0, level 1, size 16K bytes, address space 2)
- PM\_IVA2.2.[L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#) (i=2) = 0x0300
- PM\_IVA2.2.[L3\\_PM\\_READ\\_PERMISSION\\_i](#) (i=2) = 0x0406 (IVA2.2 DMA and MMU and MPU are allowed)
- PM\_IVA2.2.[L3\\_PM\\_WRITE\\_PERMISSION\\_i](#) (i=2) = 0x0002 (only MPU is allowed to write)

Set Region 1 to mask the last 2K bytes:

- PM\_IVA2.2.[L3\\_PM\\_ADDR\\_MATCH\\_K](#) (k=2) = 0x3812 (start address 0x3800, size 2K bytes, address space 2)
- PM\_IVA2.2.[L3\\_PM\\_REQ\\_INFO\\_PERMISSION\\_i](#) (i=1) = 0xFFFF
- PM\_IVA2.2.[L3\\_PM\\_READ\\_PERMISSION\\_i](#) (i=1) = 0x042E
- PM\_IVA2.2.[L3\\_PM\\_WRITE\\_PERMISSION\\_i](#) (i=1) = 0x042E

[Figure 9-12](#) shows the firewall configuration for Solution 2.

**Figure 9-12. Firewall Configuration Solution 2**

## **9.2.5 L3 Interconnect Register Manual**

Table 9-33 lists the base address and address space for all L3 register blocks.

**Table 9-33. Instance Summary**

| Module Name    | Base Address | Size    |
|----------------|--------------|---------|
| RT             | 0x6800 0000  | 1K byte |
| SI             | 0x6800 0400  | 1K byte |
| IA_MPUS        | 0x6800 1400  | 1K byte |
| IA_IVA2.2      | 0x6800 1800  | 1K byte |
| IA_SGX         | 0x6800 1C00  | 1K byte |
| TA_SMS         | 0x6800 2000  | 1K byte |
| TA_GPMC        | 0x6800 2400  | 1K byte |
| TA_OCM_RAM     | 0x6800 2800  | 1K byte |
| TA_OCM_ROM     | 0x6800 2C00  | 1K byte |
| IA_SAD2D       | 0x6800 3000  | 1K byte |
| TA_MAD2D       | 0x6800 3400  | 1K byte |
| IA_USB_HS_Host | 0x6800 4000  | 1K byte |
| IA_USB_HS_OTG  | 0x6800 4400  | 1K byte |
| IA_sDMA_RD     | 0x6800 4C00  | 1K byte |
| IA_sDMA_WR     | 0x6800 5000  | 1K byte |
| IA_DSS         | 0x6800 5400  | 1K byte |
| IA_CAM         | 0x6800 5800  | 1K byte |
| IA_DAP         | 0x6800 5C00  | 1K byte |
| TA_IVA2.2      | 0x6800 6000  | 1K byte |
| TA_SGX         | 0x6800 6400  | 1K byte |
| TA_L4_CORE     | 0x6800 6800  | 1K byte |
| TA_L4_PER      | 0x6800 6C00  | 1K byte |
| TA_L4_EMU      | 0x6800 7000  | 1K byte |
| PM_RT          | 0x6801 0000  | 1K byte |
| PM_GPMC        | 0x6801 2400  | 1K byte |
| PM_OCM_RAM     | 0x6801 2800  | 1K byte |
| PM_OCM_ROM     | 0x6801 2C00  | 1K byte |
| PM_IVA2.2      | 0x6801 4000  | 1K byte |

### **9.2.5.1 L3 Initiator Agent (L3 IA)**

This section describes the IA register block. Each IA in L3 interconnect has its own IA register block.

The following are the IA registers:

- MPU subsystem port
- IVA2.2 subsystem port
- SGX subsystem port
- High-Speed USB Host
- High-Speed USB OTG
- System DMA read port
- System DMA write port
- Display subsystem port
- Camera subsystem port
- DAP port

- Die-to-die

[Table 9-34](#) through [Table 9-37](#) list the IA registers and their physical addresses, depending on the module instance.

**Table 9-34. Initiator Agent Common Register Summary**

| Register Name        | Type | Register Width (Bits) | Address Offset | IA_MPUSS Physical Address | IA_IVA2.2 Physical Address | IA_SGX Physical Address |
|----------------------|------|-----------------------|----------------|---------------------------|----------------------------|-------------------------|
| L3_IA_COMPONENT      | R    | 64                    | 0x000          | 0x6800 1400               | 0x6800 1800                | 0x6800 1C00             |
| L3_IA_CORE           | R    | 64                    | 0x018          | 0x6800 1418               | 0x6800 1818                | 0x6800 1C18             |
| L3_IA_AGENT_CONTROL  | RW   | 64                    | 0x020          | 0x6800 1420               | 0x6800 1820                | 0x6800 1C20             |
| L3_IA_AGENT_STATUS   | RW   | 64                    | 0x028          | 0x6800 1428               | 0x6800 1828                | 0x6800 1C28             |
| L3_IA_ERROR_LOG      | RW   | 64                    | 0x058          | 0x6800 1458               | 0x6800 1858                | 0x6800 1C58             |
| L3_IA_ERROR_LOG_ADDR | R    | 64                    | 0x060          | 0x6800 1460               | 0x6800 1860                | 0x6800 1C60             |

**Table 9-35. Initiator Agent Common Register Summary**

| Register Name        | Type | Register Width (Bits) | Address Offset | IA_USB_HS_Host Physical Address | IA_USB_HS_OTG Physical Address | IA_SAD2D Physical Address |
|----------------------|------|-----------------------|----------------|---------------------------------|--------------------------------|---------------------------|
| L3_IA_COMPONENT      | R    | 64                    | 0x000          | 0x6800 4000                     | 0x6800 4400                    | 0x6800 3000               |
| L3_IA_CORE           | R    | 64                    | 0x018          | 0x6800 4018                     | 0x6800 4418                    | 0x6800 3018               |
| L3_IA_AGENT_CONTROL  | RW   | 64                    | 0x020          | 0x6800 4020                     | 0x6800 4420                    | 0x6800 3020               |
| L3_IA_AGENT_STATUS   | RW   | 64                    | 0x028          | 0x6800 4028                     | 0x6800 4428                    | 0x6800 3028               |
| L3_IA_ERROR_LOG      | RW   | 64                    | 0x058          | 0x6800 4058                     | 0x6800 4458                    | 0x6800 3058               |
| L3_IA_ERROR_LOG_ADDR | R    | 64                    | 0x060          | 0x6800 4060                     | 0x6800 4460                    | 0x6800 3060               |

**Table 9-36. Initiator Agent Common Register Summary**

| Register Name        | Type | Register Width (Bits) | Address Offset | IA_sDMA_RD Physical Address | IA_sDMA_WR Physical Address |
|----------------------|------|-----------------------|----------------|-----------------------------|-----------------------------|
| L3_IA_COMPONENT      | R    | 64                    | 0x000          | 0x6800 4C00                 | 0x6800 5000                 |
| L3_IA_CORE           | R    | 64                    | 0x018          | 0x6800 4C18                 | 0x6800 5018                 |
| L3_IA_AGENT_CONTROL  | RW   | 64                    | 0x020          | 0x6800 4C20                 | 0x6800 5020                 |
| L3_IA_AGENT_STATUS   | RW   | 64                    | 0x028          | 0x6800 4C28                 | 0x6800 5028                 |
| L3_IA_ERROR_LOG      | RW   | 64                    | 0x058          | 0x6800 4C58                 | 0x6800 5058                 |
| L3_IA_ERROR_LOG_ADDR | R    | 64                    | 0x060          | 0x6800 4C60                 | 0x6800 5060                 |

**Table 9-37. Initiator Agent Common Register Summary**

| Register Name        | Type | Register Width (Bits) | Address Offset | IA_DSS Physical Address | IA_CAM Physical Address | IA_DAP Physical Address |
|----------------------|------|-----------------------|----------------|-------------------------|-------------------------|-------------------------|
| L3_IA_COMPONENT      | R    | 64                    | 0x000          | 0x6800 5400             | 0x6800 5800             | 0x6800 5C00             |
| L3_IA_CORE           | R    | 64                    | 0x018          | 0x6800 5418             | 0x6800 5818             | 0x6800 5C18             |
| L3_IA_AGENT_CONTROL  | RW   | 64                    | 0x020          | 0x6800 5420             | 0x6800 5820             | 0x6800 5C20             |
| L3_IA_AGENT_STATUS   | RW   | 64                    | 0x028          | 0x6800 5428             | 0x6800 5828             | 0x6800 5C28             |
| L3_IA_ERROR_LOG      | RW   | 64                    | 0x058          | 0x6800 5458             | 0x6800 5858             | 0x6800 5C58             |
| L3_IA_ERROR_LOG_ADDR | R    | 64                    | 0x060          | 0x6800 5460             | 0x6800 5860             | 0x6800 5C60             |

### **9.2.5.1.1 L3 Initiator Agent (L3 IA) Registers Description**

**Table 9-38. L3\_IA\_COMPONENT**

|                         |                                                              |
|-------------------------|--------------------------------------------------------------|
| <b>Address Offset</b>   | 0x000                                                        |
| <b>Physical Address</b> | See <a href="#">Table 9-34</a> to <a href="#">Table 9-37</a> |
| <b>Description</b>      | Component register of IA                                     |
| <b>Type</b>             | RW                                                           |

|                         |                         |                         |                         |
|-------------------------|-------------------------|-------------------------|-------------------------|
| 63 62 61 60 59 58 57 56 | 55 54 53 52 51 50 49 48 | 47 46 45 44 43 42 41 40 | 39 38 37 36 35 34 33 32 |
| Reserved                |                         |                         |                         |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| CODE                    |                         | REV                   |                 |

| Bits  | Field Name | Description               | Type | Reset                     |
|-------|------------|---------------------------|------|---------------------------|
| 63:32 | Reserved   | Reserved                  | R    | 0x00000000                |
| 31:16 | CODE       | Component code            | R    | See <a href="#">(1)</a> . |
| 15:0  | REV        | Revision of the component | R    | See <a href="#">(1)</a> . |

<sup>(1)</sup> TI internal data

**Table 9-39. Register Call Summary for Register L3\_IA\_COMPONENT**

L3 Interconnect

- [L3 Initiator Agent \(L3 IA\): \[0\] \[1\] \[2\] \[3\]](#)

**Table 9-40. L3\_IA\_CORE**

|                         |                                                              |
|-------------------------|--------------------------------------------------------------|
| <b>Address Offset</b>   | 0x018                                                        |
| <b>Physical Address</b> | See <a href="#">Table 9-34</a> to <a href="#">Table 9-37</a> |
| <b>Description</b>      | Core register of L3 IA block                                 |
| <b>Type</b>             | R                                                            |

|                         |                         |                         |                         |
|-------------------------|-------------------------|-------------------------|-------------------------|
| 63 62 61 60 59 58 57 56 | 55 54 53 52 51 50 49 48 | 47 46 45 44 43 42 41 40 | 39 38 37 36 35 34 33 32 |
| Reserved                |                         | VENDOR_CODE             |                         |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| CORE_CODE               |                         | REV_CODE              |                 |

| Bits  | Field Name  | Description   | Type | Reset                     |
|-------|-------------|---------------|------|---------------------------|
| 63:48 | Reserved    | Reserved      | R    | 0x0000                    |
| 47:32 | VENDOR_CODE | Vendor code   | R    | See <a href="#">(1)</a> . |
| 31:16 | CORE_CODE   | Core code     | R    | See <a href="#">(1)</a> . |
| 15:0  | REV_CODE    | Revision code | R    | See <a href="#">(1)</a> . |

<sup>(1)</sup> TI internal data

**Table 9-41. Register Call Summary for Register L3\_IA\_CORE**

L3 Interconnect

- [L3 Initiator Agent \(L3 IA\): \[0\] \[1\] \[2\] \[3\]](#)

**Table 9-42. L3\_IA\_AGENT\_CONTROL**

|                         |                                                              |
|-------------------------|--------------------------------------------------------------|
| <b>Address Offset</b>   | 0x020                                                        |
| <b>Physical Address</b> | See <a href="#">Table 9-34</a> to <a href="#">Table 9-37</a> |
| <b>Description</b>      | Agent control register of IA block                           |
| <b>Type</b>             | RW                                                           |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 63       | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|          |                            |                          |                      |                   |                  |            |          |               |          |          |          |          |          |          |              |          |        |          |            |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----------------------------|--------------------------|----------------------|-------------------|------------------|------------|----------|---------------|----------|----------|----------|----------|----------|----------|--------------|----------|--------|----------|------------|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved | INBAND_ERROR_SECONDARY REP | INBAND_ERROR_PRIMARY REP | ALL_INBAND_ERROR REP | BURST_TIMEOUT REP | RESP_TIMEOUT REP | MERROR REP | Reserved | BURST_TIMEOUT | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | RESP_TIMEOUT | Reserved | REJECT | Reserved | CORE_RESET |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name                                 | Description                                                                                                                | Type | Reset        |
|-------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|------|--------------|
| 63:30 | Reserved                                   | Reserved                                                                                                                   | R    | 0x0000000000 |
| 29    | INBAND_ERROR_SECONDARY REP                 | Reporting of in-band errors indicating debug error.                                                                        | RW   | 1            |
|       |                                            | 0x0:No special reporting<br>0x1:Report error                                                                               |      |              |
|       | Reserved for instances 3 to 12             | Reserved                                                                                                                   | R    | 0x0          |
| 28    | INBAND_ERROR_PRIMARY REP                   | Reporting of in-band errors indicating application error.<br>0x0:No special reporting<br>0x1:Report error                  | RW   | 1            |
| 27    | ALL_INBAND_ERROR REP                       | Reporting of all in-band errors<br>0x0:Only report errors that cannot be reported in-band<br>0x1:Report all in-band errors | RW   | 1            |
| 26    | BURST_TIMEOUT REP                          | Open burst and ReadEx/Write timeout reporting<br>0x0:No special reporting<br>0x1:Report out of band                        | RW   | 1            |
| 25    | RESP_TIMEOUT REP                           | Response timeout reporting<br>0x0:No special reporting<br>0x1:Report out-of-band                                           | RW   | 1            |
|       | Reserved for instances 3, 6 to 10 and 12   | Reserved                                                                                                                   | R    | 0x00         |
| 24    | MERROR REP                                 | MError reporting<br>0x0: Suppress MError reporting<br>0x1: Report MError                                                   | RW   | 1            |
|       | Reserved for all instances except 14 (SGX) | Reserved                                                                                                                   | R    | 0x0000       |
| 23:19 | Reserved                                   | Reserved                                                                                                                   | R    | 0x0000       |
| 18:16 | BURST_TIMEOUT                              | Response Timeout Bound:                                                                                                    | RW   | 0x00         |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
|             |                   | 0x0: No timeout<br>0x1: 1x base cycles<br>0x2: 4x base cycles<br>0x3: 16x base cycles<br>0x4: 64x base cycles                            |             |              |
| 15:11       | Reserved          | Reserved                                                                                                                                 | R           | 0x00         |
| 10:8        | RESP_TIMEOUT      | Response Timeout Bound:<br>0x0: No timeout<br>0x1: 1x base cycles<br>0x2: 4x base cycles<br>0x3: 16x base cycles<br>0x4: 64x base cycles | RW          | 0x0          |
| 7:5         | Reserved          | Reserved                                                                                                                                 | R           | 0x0          |
| 4           | REJECT            | Request rejection control<br>0x0:Normal operation<br>0x1:Block requests from the initiator.                                              | RW          | 0            |
| 3:1         | Reserved          | Reserved                                                                                                                                 | R           | 0x0          |
| 0           | CORE_RESET        | Reset control for agent and reset control on core<br>0x0:Core reset control inactive<br>0x1:Core reset control active                    | RW          | 0            |

**Table 9-43. Register Call Summary for Register L3\_IA\_AGENT\_CONTROL**

## L3 Interconnect

- [Error Steering: \[0\] \[1\] \[2\]](#)
- [Time-Out Handling: \[3\]](#)
- [Acknowledging Errors: \[4\]](#)
- [L3 Initiator Agent \(L3 IA\): \[5\] \[6\] \[7\] \[8\]](#)

**Table 9-44. L3\_IA\_AGENT\_STATUS**

|                                                                                                       |                                                              |
|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|
| <b>Address Offset</b>                                                                                 | 0x028                                                        |
| <b>Physical Address</b>                                                                               | See <a href="#">Table 9-34</a> to <a href="#">Table 9-37</a> |
| <b>Description</b>                                                                                    | Agent Status Register                                        |
| <b>Type</b>                                                                                           | RW                                                           |
| 63 62 61 60 59 58 57 56   55 54 53 52 51 50 49 48   47 46 45 44 43 42 41 40   39 38 37 36 35 34 33 32 |                                                              |
| Reserved                                                                                              |                                                              |

## L3 Interconnect

www.ti.com



| Bits  | Field Name                               | Description                                                                                                                                                                                                                           | Type | Reset        |
|-------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------|
| 63:30 | Reserved                                 | Reserved                                                                                                                                                                                                                              | R    | 0x0000000000 |
| 29    | INBAND_ERROR_SECONDARY                   | Error Status for in-band errors indicating a debug error.<br><br>Read 0x0:No in-band error received<br>Write 0x0:Ignored<br>Read 0x1:In-band error received<br>Write 0x1:Clear in-band error                                          | RW   | 0            |
| 28    | INBAND_ERROR_PRIMARY                     | Reserved for instances 3 to 12<br><br>Error Status for in-band errors indicating application Error<br><br>Read 0x0:No in-band error received<br>Write 0x0:Ignored<br>Read 0x1:In-band error received<br>Write 0x1:Clear in-band error | RW   | 0            |
| 27:25 | Reserved                                 | Reserved                                                                                                                                                                                                                              | R    | 0x0          |
| 24    | MERROR                                   | MError<br><br>0x0: No Merror reported<br>0x1: Merror asserted<br><br>Reserved for all instances except 14 (SGX)                                                                                                                       | R    | 0            |
| 23:17 | Reserved                                 | Reserved                                                                                                                                                                                                                              | R    | 0x0          |
| 16    | BURST_TIMEOUT                            | Status of open burst and                                                                                                                                                                                                              | R    | 0            |
| 15:12 | TIMEBASE                                 | Observation of timebase signals for internal verification                                                                                                                                                                             | R    | 0x0          |
| 11:9  | Reserved                                 | Reserved                                                                                                                                                                                                                              | R    | 0x0          |
| 8     | RESP_TIMEOUT                             | Response timeout status                                                                                                                                                                                                               | R    | 0            |
|       | Reserved for instances 3, 6 to 10 and 12 | Reserved                                                                                                                                                                                                                              | R    | 0            |
| 7     | READEX                                   | Status of ReadEx/Write                                                                                                                                                                                                                | R    | 0            |
| 6     | BURST                                    | Status of open burst                                                                                                                                                                                                                  | R    | 0            |
| 5     | RESP_WAITING                             | Response Waiting                                                                                                                                                                                                                      | R    | 0            |
|       | Reserved for instance 3,5,7 and 8        | Reserved                                                                                                                                                                                                                              | R    | 0            |
| 4     | REQ_ACTIVE                               | Requests outstanding                                                                                                                                                                                                                  | R    | 0            |
| 3:1   | Reserved                                 | Reserved                                                                                                                                                                                                                              | R    | 0x0          |
| 0     | CORE_RESET                               | Reset input from core interface                                                                                                                                                                                                       | R    | 0            |

**Table 9-45. Register Call Summary for Register L3\_IA\_AGENT\_STATUS**
**L3 Interconnect**

- [Time-Out: \[0\] \[1\]](#)
- [Time-Out Handling: \[2\]](#)
- [Acknowledging Errors: \[3\] \[4\]](#)
- [L3 Initiator Agent \(L3 IA\): \[5\] \[6\] \[7\] \[8\]](#)

**Table 9-46. L3\_IA\_ERROR\_LOG**

| <b>Address Offset</b>                                                                                 | 0x058                                                        |                                                                                                                                                                                    |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |      |          |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--|--|--|--|--|--|--|--|--|--|--|--------|--|--|--|--|------|----------|--|--|--|-----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b>                                                                               | See <a href="#">Table 9-34</a> to <a href="#">Table 9-37</a> |                                                                                                                                                                                    |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |      |          |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                    | Error log register of IA block                               |                                                                                                                                                                                    |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |      |          |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                           | RW                                                           |                                                                                                                                                                                    |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |      |          |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 63 62 61 60 59 58 57 56   55 54 53 52 51 50 49 48   47 46 45 44 43 42 41 40   39 38 37 36 35 34 33 32 |                                                              |                                                                                                                                                                                    |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |      |          |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                                                                                              |                                                              |                                                                                                                                                                                    |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |      |          |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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           |                                                              |                                                                                                                                                                                    |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |      |          |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| MULTI<br>SECONDARY                                                                                    | Reserved                                                     | CODE                                                                                                                                                                               | Reserved |  |  |  |  |  |  |  |  |  |  |  | INITID |  |  |  |  |      | Reserved |  |  |  | CMD |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits                                                                                                  | Field Name                                                   | Description                                                                                                                                                                        |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  | Type | Reset    |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 63:48                                                                                                 | Reserved                                                     | Reserved                                                                                                                                                                           |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  | R    | 0x0000   |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 47:32                                                                                                 | REQ_INFO                                                     | MReqInfo bits of command that caused the error                                                                                                                                     |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  | R    | 0x0000   |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31                                                                                                    | MULTI                                                        | Multiple Errors<br><br>Write 0x0: Ignored<br><br>Read 0x0: Multiple error not seen<br><br>Write 0x1: Clear MULTI flag<br><br>Read 0x1: Multiple error seen                         |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  | RW   | 0        |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30                                                                                                    | SECONDARY                                                    | Indicates whether error was primary or secondary<br><br>Write 0x0: Ignored<br><br>Read 0x0: Primary Error<br><br>Write 0x1: Reset SECONDARY field<br><br>Read 0x1: Secondary Error |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  | RW   | 0        |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 29:28                                                                                                 | Reserved                                                     | Reserved                                                                                                                                                                           |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  | R    | 0x0      |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 27:24                                                                                                 | CODE                                                         | Error code                                                                                                                                                                         |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  | RW   | 0x0      |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23:16                                                                                                 | Reserved                                                     | Reserved                                                                                                                                                                           |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  | R    | 0x0      |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15:8                                                                                                  | INITID                                                       | Initiator ID from which the command was launched. See <a href="#">Table 9-19</a> .                                                                                                 |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  | R    | 0x0      |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7:3                                                                                                   | Reserved                                                     | Reserved                                                                                                                                                                           |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  | R    | 0x0      |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2:0                                                                                                   | CMD                                                          | Command that caused the error                                                                                                                                                      |          |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  | R    | 0x0      |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 9-47. Register Call Summary for Register L3\_IA\_ERROR\_LOG**

## L3 Interconnect

- Error Detection and Logging: [0]
- Error Steering: [1] [2] [3] [4]
- Time-Out Handling: [5] [6] [7] [8] [9] [10] [11]
- Acknowledging Errors: [12]
- L3 Initiator Agent (L3 IA): [13] [14] [15] [16]

**Table 9-48. L3\_IA\_ERROR\_LOG\_ADDR**

|                         |                                                              |
|-------------------------|--------------------------------------------------------------|
| <b>Address Offset</b>   | 0x060                                                        |
| <b>Physical Address</b> | See <a href="#">Table 9-34</a> to <a href="#">Table 9-37</a> |
| <b>Description</b>      | Error log address register of IA block                       |
| <b>Type</b>             | R                                                            |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 63       | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                  | Type | Reset          |
|-------|------------|----------------------------------------------|------|----------------|
| 63:32 | Reserved   | Reserved                                     | R    | 0x000000       |
| 31:0  | ADDR       | Address of the command that caused the error | R    | 0x000000000000 |

**Table 9-49. Register Call Summary for Register L3\_IA\_ERROR\_LOG\_ADDR**

## L3 Interconnect

- Error Detection and Logging: [0]
- Error Analysis: [1]
- L3 Initiator Agent (L3 IA): [2] [3] [4] [5]

**9.2.5.2 L3 Target Agent (L3 TA)**

This section describes the TA register block. Each TA in L3 interconnect has its own register block.

The following are the TA registers:

- SDRAM memory scheduler (TA\_SMS module)
- General-purpose memory controller (TA\_GPMC module)
- On-chip memory RAM (TA\_OCM\_RAM module)
- On-chip memory ROM (TA\_OCM\_ROM module)
- Master D2D (TA\_MAD2D module)
- IVA2.2 subsystem (TA\_IVA2.2 module)
- SGX subsystem (TA\_SGX module)
- L4-Core interconnect (TA\_L4\_CORE module)
- L4-Per interconnect (TA\_L4\_PER module)
- L4-Emu interconnect (TA\_L4\_EMU module)

[Table 9-50](#) through [Table 9-53](#) lists all initiator target registers and their physical addresses depending on the module instance.

[Table 9-54](#) through [Table 9-64](#) describe the individual common registers in the module instance.

**Table 9-50. Target Agent Common Register Summary**

| Register Name        | Type | Register Width (Bits) | TA_SMS Physical Address | TA_GPMC Physical Address | TA_OCM_RAM Physical Address |
|----------------------|------|-----------------------|-------------------------|--------------------------|-----------------------------|
| L3_TA_COMPONENT      | R    | 64                    | 0x6800 2000             | 0x6800 2400              | 0x6800 2800                 |
| L3_TA_CORE           | R    | 64                    | 0x6800 2018             | 0x6800 2418              | 0x6800 2818                 |
| L3_TA_AGENT_CONTROL  | RW   | 64                    | 0x6800 2020             | 0x6800 2420              | 0x6800 2820                 |
| L3_TA_AGENT_STATUS   | R    | 64                    | 0x6800 2028             | 0x6800 2428              | 0x6800 2828                 |
| L3_TA_ERROR_LOG      | RW   | 64                    | 0x6800 2058             | 0x6800 2458              | 0x6800 2858                 |
| L3_TA_ERROR_LOG_ADDR | R    | 64                    | 0x6800 2060             | 0x6800 2460              | 0x6800 2860                 |

**Table 9-51. Target Agent Common Register Summary**

| Register Name        | Type | Register Width (Bits) | TA_OCM_ROM Physical Address | TA_MAD2D Physical Address |
|----------------------|------|-----------------------|-----------------------------|---------------------------|
| L3_TA_COMPONENT      | R    | 64                    | 0x6800 2C00                 | 0x6800 3400               |
| L3_TA_CORE           | R    | 64                    | 0x6800 2C18                 | 0x6800 3418               |
| L3_TA_AGENT_CONTROL  | RW   | 64                    | 0x6800 2C20                 | 0x6800 3420               |
| L3_TA_AGENT_STATUS   | R    | 64                    | 0x6800 2C28                 | 0x6800 3428               |
| L3_TA_ERROR_LOG      | RW   | 64                    | 0x6800 2C58                 | 0x6800 3458               |
| L3_TA_ERROR_LOG_ADDR | R    | 64                    | 0x6800 2C60                 | 0x6800 3460               |

**Table 9-52. Target Agent Common Register Summary**

| Register Name        | Type | Register Width (Bits) | TA_IVA2.2 Physical Address | TA_SGX Physical Address |
|----------------------|------|-----------------------|----------------------------|-------------------------|
| L3_TA_COMPONENT      | R    | 64                    | 0x6800 6000                | 0x6800 6400             |
| L3_TA_CORE           | R    | 64                    | 0x6800 6018                | 0x6800 6418             |
| L3_TA_AGENT_CONTROL  | RW   | 64                    | 0x6800 6020                | 0x6800 6420             |
| L3_TA_AGENT_STATUS   | R    | 64                    | 0x6800 6028                | 0x6800 6428             |
| L3_TA_ERROR_LOG      | RW   | 64                    | 0x6800 6058                | 0x6800 6458             |
| L3_TA_ERROR_LOG_ADDR | R    | 64                    | 0x6800 6060                | 0x6800 6460             |

**Table 9-53. Target Agent Common Register Summary**

| Register Name        | Type | Register Width (Bits) | TA_L4_CORE Physical Address | TA_L4_PER Physical Address | TA_L4_EMU Physical Address |
|----------------------|------|-----------------------|-----------------------------|----------------------------|----------------------------|
| L3_TA_COMPONENT      | R    | 64                    | 0x6800 6800                 | 0x6800 6C00                | 0x6800 7000                |
| L3_TA_CORE           | R    | 64                    | 0x6800 6818                 | 0x6800 6C18                | 0x6800 7018                |
| L3_TA_AGENT_CONTROL  | RW   | 64                    | 0x6800 6820                 | 0x6800 6C20                | 0x6800 7020                |
| L3_TA_AGENT_STATUS   | RW   | 64                    | 0x6800 6828                 | 0x6800 6C28                | 0x6800 7028                |
| L3_TA_ERROR_LOG      | RW   | 64                    | 0x6800 6858                 | 0x6800 6C58                | 0x6800 7058                |
| L3_TA_ERROR_LOG_ADDR | R    | 64                    | 0x6800 6860                 | 0x6800 6C60                | 0x6800 7060                |

### 9.2.5.2.1 L3 Target Agent (L3 TA) Registers Description

**Table 9-54. L3\_TA\_COMPONENT**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                              |                           |             |                           |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------|-------------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x000                                                        |                           |             |                           |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | See <a href="#">Table 9-50</a> to <a href="#">Table 9-53</a> |                           |             |                           |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Component register of target agent                           |                           |             |                           |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R                                                            |                           |             |                           |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 10%;">63</td><td style="width: 10%;">62</td><td style="width: 10%;">61</td><td style="width: 10%;">60</td><td style="width: 10%;">59</td><td style="width: 10%;">58</td><td style="width: 10%;">57</td><td style="width: 10%;">56</td><td style="width: 10%;">55</td><td style="width: 10%;">54</td><td style="width: 10%;">53</td><td style="width: 10%;">52</td><td style="width: 10%;">51</td><td style="width: 10%;">50</td><td style="width: 10%;">49</td><td style="width: 10%;">48</td><td style="width: 10%;">47</td><td style="width: 10%;">46</td><td style="width: 10%;">45</td><td style="width: 10%;">44</td><td style="width: 10%;">43</td><td style="width: 10%;">42</td><td style="width: 10%;">41</td><td style="width: 10%;">40</td><td style="width: 10%;">39</td><td style="width: 10%;">38</td><td style="width: 10%;">37</td><td style="width: 10%;">36</td><td style="width: 10%;">35</td><td style="width: 10%;">34</td><td style="width: 10%;">33</td><td style="width: 10%;">32</td></tr> <tr> <td colspan="29" style="text-align: center;">Reserved</td></tr> </table>                                                            |                                                              | 63                        | 62          | 61                        | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49  | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 | Reserved |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 62                                                           | 61                        | 60          | 59                        | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47  | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                              |                           |             |                           |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 10%;">31</td><td style="width: 10%;">30</td><td style="width: 10%;">29</td><td style="width: 10%;">28</td><td style="width: 10%;">27</td><td style="width: 10%;">26</td><td style="width: 10%;">25</td><td style="width: 10%;">24</td><td style="width: 10%;">23</td><td style="width: 10%;">22</td><td style="width: 10%;">21</td><td style="width: 10%;">20</td><td style="width: 10%;">19</td><td style="width: 10%;">18</td><td style="width: 10%;">17</td><td style="width: 10%;">16</td><td style="width: 10%;">15</td><td style="width: 10%;">14</td><td style="width: 10%;">13</td><td style="width: 10%;">12</td><td style="width: 10%;">11</td><td style="width: 10%;">10</td><td style="width: 10%;">9</td><td style="width: 10%;">8</td><td style="width: 10%;">7</td><td style="width: 10%;">6</td><td style="width: 10%;">5</td><td style="width: 10%;">4</td><td style="width: 10%;">3</td><td style="width: 10%;">2</td><td style="width: 10%;">1</td><td style="width: 10%;">0</td></tr> <tr> <td colspan="16" style="text-align: center;">CODE</td><td colspan="8" style="text-align: center;">REV</td><td colspan="8"></td></tr> </table> |                                                              | 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  | CODE     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | REV |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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  |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| CODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                              |                           |             |                           |    |    |    |    |    |    |    |    |    |    |    | REV |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bits</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <b>Field Name</b>                                            | <b>Description</b>        | <b>Type</b> | <b>Reset</b>              |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 63:32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Reserved                                                     | Reserved                  | R           | 0x00000000                |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | CODE                                                         | Component Code            | R           | See <a href="#">(1)</a> . |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | REV                                                          | Revision of the component | R           | See <a href="#">(1)</a> . |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

<sup>(1)</sup> TI Internal Data

**Table 9-55. Register Call Summary for Register L3\_TA\_COMPONENT**

L3 Interconnect

- [L3 Target Agent \(L3 TA\): \[0\] \[1\] \[2\] \[3\]](#)

**Table 9-56. L3\_TA\_CORE**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                              |                    |             |                           |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--------------------|-------------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x018                                                        |                    |             |                           |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | See <a href="#">Table 9-50</a> to <a href="#">Table 9-53</a> |                    |             |                           |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Core register of Target Agent                                |                    |             |                           |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW                                                           |                    |             |                           |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 10%;">63</td><td style="width: 10%;">62</td><td style="width: 10%;">61</td><td style="width: 10%;">60</td><td style="width: 10%;">59</td><td style="width: 10%;">58</td><td style="width: 10%;">57</td><td style="width: 10%;">56</td><td style="width: 10%;">55</td><td style="width: 10%;">54</td><td style="width: 10%;">53</td><td style="width: 10%;">52</td><td style="width: 10%;">51</td><td style="width: 10%;">50</td><td style="width: 10%;">49</td><td style="width: 10%;">48</td><td style="width: 10%;">47</td><td style="width: 10%;">46</td><td style="width: 10%;">45</td><td style="width: 10%;">44</td><td style="width: 10%;">43</td><td style="width: 10%;">42</td><td style="width: 10%;">41</td><td style="width: 10%;">40</td><td style="width: 10%;">39</td><td style="width: 10%;">38</td><td style="width: 10%;">37</td><td style="width: 10%;">36</td><td style="width: 10%;">35</td><td style="width: 10%;">34</td><td style="width: 10%;">33</td><td style="width: 10%;">32</td></tr> <tr> <td colspan="16" style="text-align: center;">Reserved</td><td colspan="8" style="text-align: center;">VEND_CODE</td><td colspan="8"></td></tr> </table> |                                                              | 63                 | 62          | 61                        | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49        | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 | Reserved  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | VEND_CODE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 62                                                           | 61                 | 60          | 59                        | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47        | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                              |                    |             |                           |    |    |    |    |    |    |    |    |    |    |    | VEND_CODE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 10%;">31</td><td style="width: 10%;">30</td><td style="width: 10%;">29</td><td style="width: 10%;">28</td><td style="width: 10%;">27</td><td style="width: 10%;">26</td><td style="width: 10%;">25</td><td style="width: 10%;">24</td><td style="width: 10%;">23</td><td style="width: 10%;">22</td><td style="width: 10%;">21</td><td style="width: 10%;">20</td><td style="width: 10%;">19</td><td style="width: 10%;">18</td><td style="width: 10%;">17</td><td style="width: 10%;">16</td><td style="width: 10%;">15</td><td style="width: 10%;">14</td><td style="width: 10%;">13</td><td style="width: 10%;">12</td><td style="width: 10%;">11</td><td style="width: 10%;">10</td><td style="width: 10%;">9</td><td style="width: 10%;">8</td><td style="width: 10%;">7</td><td style="width: 10%;">6</td><td style="width: 10%;">5</td><td style="width: 10%;">4</td><td style="width: 10%;">3</td><td style="width: 10%;">2</td><td style="width: 10%;">1</td><td style="width: 10%;">0</td></tr> <tr> <td colspan="16" style="text-align: center;">CORE_CODE</td><td colspan="8" style="text-align: center;">REV_CODE</td><td colspan="8"></td></tr> </table>           |                                                              | 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  | CORE_CODE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | REV_CODE  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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  |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| CORE_CODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                              |                    |             |                           |    |    |    |    |    |    |    |    |    |    |    | REV_CODE  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bits</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <b>Field Name</b>                                            | <b>Description</b> | <b>Type</b> | <b>Reset</b>              |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 63:48                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Reserved                                                     | Reserved           | R           | 0x0000                    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 47:32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | VEND_CODE                                                    | Vendor Code        | R           | See <a href="#">(1)</a> . |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | CORE_CODE                                                    | Core code          | R           | See <a href="#">(1)</a> . |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | REV_CODE                                                     | Revision Code      | R           | See <a href="#">(1)</a> . |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

<sup>(1)</sup> TI Internal Data

**Table 9-57. Register Call Summary for Register L3\_TA\_CORE**

L3 Interconnect

- [L3 Target Agent \(L3 TA\): \[0\] \[1\] \[2\] \[3\]](#)

**Table 9-58. L3\_TA\_AGENT\_CONTROL**

|                         |                                                              |
|-------------------------|--------------------------------------------------------------|
| <b>Address Offset</b>   | 0x020                                                        |
| <b>Physical Address</b> | See <a href="#">Table 9-50</a> to <a href="#">Table 9-53</a> |
| <b>Description</b>      | Agent control register of TA block.                          |
| <b>Type</b>             | RW                                                           |

63 62 61 60 59 58 57 56 | 55 54 53 52 51 50 49 48 | 47 46 45 44 43 42 41 40 | 39 38 37 36 35 34 33 32  
Reserved

| Bits  | Field Name                                             | Description                                                                                                                             | Type | Reset        |
|-------|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|------|--------------|
| 63:26 | Reserved                                               | Reserved                                                                                                                                | R    | 0x0000000000 |
| 25    | REQ_TIMEOUT REP                                        | Request Timeout Reporting<br>0x0: No special reporting<br>0x1: Report out of band                                                       | RW   | 1            |
| 24    | SERROR REP                                             | SError reporting<br>0x0: Suppress Serror reporting<br>0x1: Report Serror                                                                | RW   | 1            |
|       | Reserved for all instances except 2 (GPMC) and 6 (SGX) | Reserved                                                                                                                                | R    | 0x0000       |
| 23:11 | Reserved                                               | Reserved                                                                                                                                | R    | 0x0000       |
| 10:8  | REQ_TIMEOUT                                            | Request Timeout Bound:<br>0x0: No timeout<br>0x1: 1x base cycles<br>0x2: 4x base cycles<br>0x3: 16x base cycles<br>0x4: 64x base cycles | RW   | 0x0          |
| 7:5   | Reserved                                               | Reserved                                                                                                                                | R    | 0x0          |
| 4     | REJECT                                                 | Request rejection control<br>0x0: Request rejection control<br>0x1: Block requests to this target                                       | RW   | 0            |
| 3:1   | Reserved                                               | Reserved                                                                                                                                | R    | 0x0          |
| 0     | CORE_RESET                                             | Reset output on core<br>0x0: Inactive<br>0x1: Reset control active                                                                      | RW   | 0            |

**Table 9-59. Register Call Summary for Register L3\_TA\_AGENT\_CONTROL**

L3 Interconnect

- Error Steering: [0] [1]
  - Acknowledging Errors: [2]
  - L3 Target Agent (L3 TA): [3] [4] [5] [6]

**Table 9-60. L3 TA AGENT STATUS**

|                         |                                                              |
|-------------------------|--------------------------------------------------------------|
| <b>Address Offset</b>   | 0x028                                                        |
| <b>Physical Address</b> | See <a href="#">Table 9-50</a> to <a href="#">Table 9-53</a> |
| <b>Description</b>      | Agent Status Register.                                       |
| <b>Type</b>             | RW                                                           |

63 62 61 60 59 58 57 56 | 55 54 53 52 51 50 49 48 | 47 46 45 44 43 42 41 40 | 39 38 37 36 35 34 33 32  
Reserved

|          |        |          |             |          |          |             |        |       |             |             |          |            |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|--------|----------|-------------|----------|----------|-------------|--------|-------|-------------|-------------|----------|------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved | SERROR | Reserved | BURST_CLOSE | TIMEBASE | Reserved | REQ_TIMEOUT | READEX | BURST | RESP_ACTIVE | REQ_WAITING | Reserved | CORE_RESET |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name                                             | Description                                                                                                                     | Type | Reset          |
|-------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|------|----------------|
| 63:25 | Reserved                                               | Reserved                                                                                                                        | R    | 0x000000000000 |
| 24    | SERROR                                                 | Serror assertion detected                                                                                                       | RW   | 0              |
|       | Reserved for all instances except 2 (GPMC) and 6 (SGX) | Reserved                                                                                                                        | R    | 0              |
| 23:17 | Reserved                                               | Reserved                                                                                                                        | R    | 0x00           |
| 16    | BURST_CLOSE                                            | Forced burst close status<br><br>Read 0x0: Normal operation<br><br>Read 0x1: Burst close command                                | R    | 0              |
| 15:12 | TIMEBASE                                               | Observation of timebase signals.                                                                                                | R    | 0x0            |
| 11:9  | Reserved                                               | Reserved                                                                                                                        | R    | 0x0            |
| 8     | REQ_TIMEOUT                                            | Request timeout status<br><br>Read 0x0: Normal operation<br><br>Read 0x1: Request timed out, responding ERR to all the requests | R    | 0              |
| 7     | READEX                                                 | Status of readEx/Write<br><br>Read 0x0: No pending ReadEx<br><br>Read 0x1: ReadEx pending on at least one thread                | R    | 0              |
| 6     | BURST                                                  | Status of open burst<br><br>Read 0x0: No open burst<br><br>Read 0x1: Open burst on at least one thread                          | R    | 0              |
| 5     | RESP_ACTIVE                                            | Responses outstanding<br><br>Read 0x0: No responses outstanding<br><br>Read 0x1: Response outstanding in the target             | R    | 0              |
| 4     | REQ_WAITING                                            | Requests waiting<br><br>Read 0x0: No request waiting<br><br>Read 0x1: Request waiting for acceptance by target                  | R    | 0              |
| 3:1   | Reserved                                               | Reserved                                                                                                                        | R    | 0x0            |
| 0     | CORE_RESET                                             | Reset input from core interface<br><br>Read 0x0: Reset inactive<br><br>Read 0x1: Reset active                                   | R    | 0              |

**Table 9-61. Register Call Summary for Register L3\_TA\_AGENT\_STATUS**

## L3 Interconnect

- [Time-Out: \[0\]](#)
- [L3 Target Agent \(L3 TA\): \[1\] \[2\] \[3\] \[4\]](#)

**Table 9-62. L3\_TA\_ERROR\_LOG**

| <b>Address Offset</b>   | 0x058                                                                   |                                                                                                                                                            |      |        |
|-------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| <b>Physical Address</b> | See <a href="#">Table 9-50</a> to <a href="#">Table 9-53</a>            |                                                                                                                                                            |      |        |
| <b>Description</b>      | Error log register of TA block - logs error detected by a target agent. |                                                                                                                                                            |      |        |
| <b>Type</b>             | RW                                                                      |                                                                                                                                                            |      |        |
|                         |                                                                         |                                                                                                                                                            |      |        |
| 63 62 61 60 59 58 57 56 | 55 54 53 52 51 50 49 48                                                 |                                                                                                                                                            |      |        |
| 47 46 45 44 43 42 41 40 | 39 38 37 36 35 34 33 32                                                 |                                                                                                                                                            |      |        |
| Reserved                |                                                                         |                                                                                                                                                            |      |        |
| REQ_INFO                |                                                                         |                                                                                                                                                            |      |        |
| 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                                                         |                                                                                                                                                            |      |        |
| MULTI                   | Reserved                                                                |                                                                                                                                                            |      |        |
| CODE                    | Reserved                                                                |                                                                                                                                                            |      |        |
|                         | INITID                                                                  |                                                                                                                                                            |      |        |
|                         | Reserved                                                                |                                                                                                                                                            |      |        |
|                         | CMD                                                                     |                                                                                                                                                            |      |        |
|                         |                                                                         |                                                                                                                                                            |      |        |
| Bits                    | Field Name                                                              | Description                                                                                                                                                | Type | Reset  |
| 63:42                   | Reserved                                                                | Reserved                                                                                                                                                   | R    | 0x0000 |
| 41:32                   | REQ_INFO                                                                | MReqInfo bits of command that caused the error                                                                                                             | R    | 0x0000 |
| 31                      | MULTI                                                                   | Multiple Errors<br><br>Write 0x0: Ignored<br><br>Read 0x0: Multiple error not seen<br><br>Write 0x1: Clear MULTI flag<br><br>Read 0x1: Multiple error seen | RW   | 0      |
| 30:28                   | Reserved                                                                | Reserved                                                                                                                                                   | R    | 0x0    |
| 27:24                   | CODE                                                                    | Error code                                                                                                                                                 | RW   | 0x0    |
| 23:16                   | Reserved                                                                | Reserved                                                                                                                                                   | R    | 0x00   |
| 15:8                    | INITID                                                                  | Initiator ID from which command was launched. . See <a href="#">Table 9-19</a> .                                                                           | R    | 0x00   |
| 7:3                     | Reserved                                                                | Reserved                                                                                                                                                   | R    | 0x00   |
| 2:0                     | CMD                                                                     | Command that caused the error                                                                                                                              | R    | 0x0    |

**Table 9-63. Register Call Summary for Register L3\_TA\_ERROR\_LOG**

## L3 Interconnect

- [Error Detection and Logging: \[0\]](#)
- [Acknowledging Errors: \[1\]](#)
- [L3 Target Agent \(L3 TA\): \[2\] \[3\] \[4\] \[5\]](#)

**Table 9-64. L3\_TA\_ERROR\_LOG\_ADDR**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                              |                                              |             |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|----------------------------------------------|-------------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x060                                                        |                                              |             |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | See <a href="#">Table 9-50</a> to <a href="#">Table 9-53</a> |                                              |             |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Error log address register of TA block                       |                                              |             |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RW                                                           |                                              |             |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 10%;">63</td><td style="width: 10%;">62</td><td style="width: 10%;">61</td><td style="width: 10%;">60</td><td style="width: 10%;">59</td><td style="width: 10%;">58</td><td style="width: 10%;">57</td><td style="width: 10%;">56</td><td style="width: 10%;">55</td><td style="width: 10%;">54</td><td style="width: 10%;">53</td><td style="width: 10%;">52</td><td style="width: 10%;">51</td><td style="width: 10%;">50</td><td style="width: 10%;">49</td><td style="width: 10%;">48</td><td style="width: 10%;">47</td><td style="width: 10%;">46</td><td style="width: 10%;">45</td><td style="width: 10%;">44</td><td style="width: 10%;">43</td><td style="width: 10%;">42</td><td style="width: 10%;">41</td><td style="width: 10%;">40</td><td style="width: 10%;">39</td><td style="width: 10%;">38</td><td style="width: 10%;">37</td><td style="width: 10%;">36</td><td style="width: 10%;">35</td><td style="width: 10%;">34</td><td style="width: 10%;">33</td><td style="width: 10%;">32</td></tr> <tr> <td colspan="29" style="text-align: center;">Reserved</td></tr> </table> |                                                              | 63                                           | 62          | 61             | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 | Reserved |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 62                                                           | 61                                           | 60          | 59             | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                              |                                              |             |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 10%;">31</td><td style="width: 10%;">30</td><td style="width: 10%;">29</td><td style="width: 10%;">28</td><td style="width: 10%;">27</td><td style="width: 10%;">26</td><td style="width: 10%;">25</td><td style="width: 10%;">24</td><td style="width: 10%;">23</td><td style="width: 10%;">22</td><td style="width: 10%;">21</td><td style="width: 10%;">20</td><td style="width: 10%;">19</td><td style="width: 10%;">18</td><td style="width: 10%;">17</td><td style="width: 10%;">16</td><td style="width: 10%;">15</td><td style="width: 10%;">14</td><td style="width: 10%;">13</td><td style="width: 10%;">12</td><td style="width: 10%;">11</td><td style="width: 10%;">10</td><td style="width: 10%;">9</td><td style="width: 10%;">8</td><td style="width: 10%;">7</td><td style="width: 10%;">6</td><td style="width: 10%;">5</td><td style="width: 10%;">4</td><td style="width: 10%;">3</td><td style="width: 10%;">2</td><td style="width: 10%;">1</td><td style="width: 10%;">0</td></tr> <tr> <td colspan="29" style="text-align: center;">ADDR</td></tr> </table>               |                                                              | 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  | ADDR     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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  |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                              |                                              |             |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bits</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>Field Name</b>                                            | <b>Description</b>                           | <b>Type</b> | <b>Reset</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 63:32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reserved                                                     | Reserved                                     | R           | 0x00000000     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ADDR                                                         | Address of the command that caused the error | R           | 0x000000000000 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 9-65. Register Call Summary for Register L3\_TA\_ERROR\_LOG\_ADDR**

L3 Interconnect

- [Error Detection and Logging: \[0\]](#)
- [L3 Target Agent \(L3 TA\): \[1\] \[2\] \[3\] \[4\]](#)

### 9.2.5.3 Register Target (RT)

This section describes the RT module.

[Table 9-66](#) lists the RT registers and their physical addresses.

[Table 9-67](#) through [Table 9-73](#) describe the individual registers in the module instance.

**Table 9-66. RT Register Summary**

| Register Name         | Type | Register Width (Bits) | Address Offset | Physical Address |
|-----------------------|------|-----------------------|----------------|------------------|
| L3_RT_COMPONENT       | R    | 64                    | 0x000          | 0x6800 0000      |
| L3_RT_NETWORK         | R    | 64                    | 0x010          | 0x6800 0010      |
| L3_RT_INITID_READBACK | R    | 64                    | 0x070          | 0x6800 0070      |
| L3_RT_NETWORK_CONTROL | RW   | 64                    | 0x078          | 0x6800 0078      |

#### 9.2.5.3.1 Register Target (RT) Registers Description

**Table 9-67. L3\_RT\_COMPONENT**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x000                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x6800 0000                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | This register identifies the component to which this register block belongs. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R                                                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 10%;">63</td><td style="width: 10%;">62</td><td style="width: 10%;">61</td><td style="width: 10%;">60</td><td style="width: 10%;">59</td><td style="width: 10%;">58</td><td style="width: 10%;">57</td><td style="width: 10%;">56</td><td style="width: 10%;">55</td><td style="width: 10%;">54</td><td style="width: 10%;">53</td><td style="width: 10%;">52</td><td style="width: 10%;">51</td><td style="width: 10%;">50</td><td style="width: 10%;">49</td><td style="width: 10%;">48</td><td style="width: 10%;">47</td><td style="width: 10%;">46</td><td style="width: 10%;">45</td><td style="width: 10%;">44</td><td style="width: 10%;">43</td><td style="width: 10%;">42</td><td style="width: 10%;">41</td><td style="width: 10%;">40</td><td style="width: 10%;">39</td><td style="width: 10%;">38</td><td style="width: 10%;">37</td><td style="width: 10%;">36</td><td style="width: 10%;">35</td><td style="width: 10%;">34</td><td style="width: 10%;">33</td><td style="width: 10%;">32</td></tr> <tr> <td colspan="29" style="text-align: center;">Reserved</td></tr> </table> |                                                                              | 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 | Reserved |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 62                                                                           | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| CODE |    |    |    |    |    |    |    |    |    |    |    |    |    |    | REV |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description               | Type | Reset                |
|-------|------------|---------------------------|------|----------------------|
| 63:32 | Reserved   | Reserved                  | R    | 0x00000000           |
| 31:16 | CODE       | Component Code            | R    | See <sup>(1)</sup> . |
| 15:0  | REV        | Revision of the component | R    | See <sup>(1)</sup> . |

<sup>(1)</sup> TI Internal Data

**Table 9-68. Register Call Summary for Register L3\_RT\_COMPONENT**

L3 Interconnect

- Register Target (RT): [0]

**Table 9-69. L3\_RT\_NETWORK**

|                         |                                                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |  |  |
|-------------------------|---------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|--|--|
| <b>Address Offset</b>   | 0x010                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |  |  |
| <b>Physical Address</b> | 0x6800 0010                                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b> |    |    |    | RT |    |    |  |  |
| <b>Description</b>      | This register identifies the interconnect and is present only in the register target. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |  |  |
| <b>Type</b>             | R                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |  |  |
| 63                      | 62                                                                                    | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38              | 37 | 36 | 35 | 34 | 33 | 32 |  |  |

ID

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Reserved

| Bits  | Field Name | Description            | Type | Reset      |
|-------|------------|------------------------|------|------------|
| 63:32 | ID         | Unique Interconnect ID | R    | 0x00000000 |
| 31:0  | Reserved   | Reserved               | R    | 0x00000000 |

**Table 9-70. Register Call Summary for Register L3\_RT\_NETWORK**

L3 Interconnect

- Register Target (RT): [0]

**Table 9-71. L3\_RT\_INITID\_READBACK**

|                         |                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |  |  |
|-------------------------|---------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|--|--|
| <b>Address Offset</b>   | 0x070                                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |  |  |
| <b>Physical Address</b> | 0x6800 0070                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b> |    |    |    | RT |    |    |  |  |
| <b>Description</b>      | This register is used by initiators to discover their own identity. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |  |  |
| <b>Type</b>             | R                                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |  |  |
| 63                      | 62                                                                  | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38              | 37 | 36 | 35 | 34 | 33 | 32 |  |  |

Reserved

|        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| INITID |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                 | Type | Reset              |
|------|------------|-------------------------------------------------------------|------|--------------------|
| 63:8 | Reserved   | Reserved                                                    | R    | 0x0000000000000000 |
| 7:0  | INITID     | Returns initiator ID of core thread that initiated the read | R    | 0x18               |

**Table 9-72. Register Call Summary for Register L3\_RT\_INITID\_READBACK**

L3 Interconnect

- Register Target (RT): [0]

**Table 9-73. L3\_RT\_NETWORK\_CONTROL**

|                |                                                                                                                                 |                  |             |          |    |
|----------------|---------------------------------------------------------------------------------------------------------------------------------|------------------|-------------|----------|----|
| Address Offset | 0x068                                                                                                                           | Physical Address | 0x6800 0078 | Instance | RT |
| Description    | It controls such interconnect wide functions as the timeout base scale and the disabling of fine grained hardware clock gating. |                  |             |          |    |
| Type           | RW                                                                                                                              |                  |             |          |    |

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Reserved      |CLOCK\_GATE\_DISABLE|      Reserved

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Reserved      |TIMEOUT\_BASE|      Reserved

| Bits  | Field Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset              |
|-------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------------|
| 63:57 | Reserved           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R    | 0x00               |
| 56    | CLOCK_GATE_DISABLE | Overrides fine grained hardware clock gating                                                                                                                                                                                                                                                                                                                                                                                                                 | RW   | 0                  |
| 55:11 | Reserved           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R    | 0x0000000000000000 |
| 10:8  | TIMEOUT_BASE       | Timeout base period in register target clock cycles<br><br>Program the timeout base period. Each of the agent timeout features is programmed as a multiple of the timeout base period.<br>These timeout bases are:<br>0x0: Timeout disabled<br>0x1: L3 interconnect clock cycles divided by 64<br>0x2: L3 interconnect clock cycles divided by 256<br>0x3: L3 interconnect clock cycles divided by 1024<br>0x4: L3 interconnect clock cycles divided by 4096 | RW   | 0x0                |
| 7:0   | Reserved           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R    | 0x00               |

**Table 9-74. Register Call Summary for Register L3\_RT\_NETWORK\_CONTROL**

## L3 Interconnect

- Time-Out: [0]
- Register Target (RT): [1]

### 9.2.5.4 Protection Mechanism (PM)

This section describes the protection mechanism register block.

The following are the protection mechanism registers:

- Register target (PM\_RT module)
- General-purpose memory controller (PM\_GPMC module)
- On-chip RAM (PM\_OCM\_RAM module)
- On-chip ROM (PM\_OCM\_ROM module)
- IVA2.2 subsystem (PM\_IVA2.2 module)

[Table 9-75](#) and [Table 9-77](#) list the protection registers and their physical addresses, depending on the module instance.

[Table 9-78](#) through [Table 9-88](#) describe the individual common registers in the module instance.

**Table 9-75. Protection Mechanism Common Register Summary**

| Register Name                                              | Type | Register Width (Bits) | PM_RT Physical Address | PM_GPMC Physical Address |
|------------------------------------------------------------|------|-----------------------|------------------------|--------------------------|
| <a href="#">L3_PM_ERROR_LOG</a>                            | RW   | 64                    | 0x6801 0020            | 0x6801 2420              |
| <a href="#">L3_PM_CONTROL</a>                              | RW   | 64                    | 0x6801 0028            | 0x6801 2428              |
| <a href="#">L3_PM_ERROR_CLEAR_SINGLE</a>                   | R    | 64                    | 0x6801 0030            | 0x6801 2430              |
| <a href="#">L3_PM_ERROR_CLEAR_MULTI</a>                    | R    | 64                    | 0x6801 0038            | 0x6801 2438              |
| <a href="#">L3_PM_REQ_INFO_PERMISSION_i</a> <sup>(1)</sup> | RW   | 64                    | 0x6801 0048 + (0x20*i) | 0x6801 2448 + (0x20*i)   |
| <a href="#">L3_PM_READ_PERMISSION_i</a> <sup>(1)</sup>     | RW   | 64                    | 0x6801 0050 + (0x20*i) | 0x6801 2450 + (0x20*i)   |
| <a href="#">L3_PM_WRITE_PERMISSION_i</a> <sup>(1)</sup>    | RW   | 64                    | 0x6801 0058 + (0x20*i) | 0x6801 2458 + (0x20*i)   |
| <a href="#">L3_PM_ADDR_MATCH_K</a> <sup>(2)</sup>          | RW   | 64                    | 0x6801 0060 + (0x20*k) | 0x6801 2460 + (0x20*k)   |

<sup>(1)</sup> i = 0 to 1 for PM\_RT  
i = 0 to 7 for PM\_GPMC

<sup>(2)</sup> k = 1 to 1 for PM\_RT  
k = 1 to 7 for PM\_GPMC

**Table 9-76. Protection Mechanism Common Register Summary**

| Register Name                                              | Type | Register Width (Bits) | PM_OCM_RAM Physical Address | PM_OCM_ROM Physical Address |
|------------------------------------------------------------|------|-----------------------|-----------------------------|-----------------------------|
| <a href="#">L3_PM_ERROR_LOG</a>                            | RW   | 64                    | 0x6801 2820                 | 0x6801 2C20                 |
| <a href="#">L3_PM_CONTROL</a>                              | RW   | 64                    | 0x6801 2828                 | 0x6801 2C28                 |
| <a href="#">L3_PM_ERROR_CLEAR_SINGLE</a>                   | R    | 64                    | 0x6801 2830                 | 0x6801 2C30                 |
| <a href="#">L3_PM_ERROR_CLEAR_MULTI</a>                    | R    | 64                    | 0x6801 2838                 | 0x6801 2C38                 |
| <a href="#">L3_PM_REQ_INFO_PERMISSION_i</a> <sup>(1)</sup> | RW   | 64                    | 0x6801 2848 + (0x20*i)      | 0x6801 2C48 + (0x20*i)      |
| <a href="#">L3_PM_READ_PERMISSION_i</a> <sup>(1)</sup>     | RW   | 64                    | 0x6801 2850 + (0x20*i)      | 0x6801 2C50 + (0x20*i)      |
| <a href="#">L3_PM_WRITE_PERMISSION_i</a> <sup>(1)</sup>    | RW   | 64                    | 0x6801 2858 + (0x20*i)      | 0x6801 2C58 + (0x20*i)      |

<sup>(1)</sup> i = 0 to 1 for PM\_OCM\_ROM  
i = 0 to 7 for PM\_OCM\_RAM

**Table 9-76. Protection Mechanism Common Register Summary (continued)**

| Register Name                     | Type | Register Width (Bits) | PM_OCM_RAM Physical Address | PM_OCM_ROM Physical Address |
|-----------------------------------|------|-----------------------|-----------------------------|-----------------------------|
| L3_PM_ADDR_MATCH_K <sup>(2)</sup> | RW   | 64                    | 0x6801 2860 + (0x20*k)      | 0x6801 2C60 + (0x20*k)      |

(2) k = 1 to 1 for PM\_OCM\_ROM  
k = 1 to 7 for PM\_OCM\_RAM

**Table 9-77. Protection Mechanism Common Register Summary**

| Register Name                              | Type | Register Width (Bits) | PM_MAD2D Physical Address | PM_IVA2.2 Physical Address |
|--------------------------------------------|------|-----------------------|---------------------------|----------------------------|
| L3_PM_ERROR_LOG                            | RW   | 64                    | 0x6801 3020               | 0x6801 4020                |
| L3_PM_CONTROL                              | RW   | 64                    | 0x6801 3028               | 0x6801 4028                |
| L3_PM_ERROR_CLEAR_SINGLE                   | R    | 64                    | 0x6801 3030               | 0x6801 4030                |
| L3_PM_ERROR_CLEAR_MULTI                    | R    | 64                    | 0x6801 3038               | 0x6801 4038                |
| L3_PM_REQ_INFO_PERMISSION_i <sup>(1)</sup> | RW   | 64                    | 0x6801 3048 + (0x20*i)    | 0x6801 4048 + (0x20*i)     |
| L3_PM_READ_PERMISSION_i <sup>(1)</sup>     | RW   | 64                    | 0x6801 3050 + (0x20*i)    | 0x6801 4050 + (0x20*i)     |
| L3_PM_WRITE_PERMISSION_i <sup>(1)</sup>    | RW   | 64                    | 0x6801 3058 + (0x20*i)    | 0x6801 4058 + (0x20*i)     |
| L3_PM_ADDR_MATCH_K <sup>(2)</sup>          | RW   | 64                    | 0x6801 3060 + (0x20*k)    | 0x6801 4060 + (0x20*k)     |

(1) i = 0 to 7 for PM\_MAD2D  
i = 0 to 3 for PM\_IVA2.2

(2) k = 1 to 7 for PM\_MAD2D  
k = 1 to 3 for PM\_IVA2.2

#### 9.2.5.4.1 Protection Mechanism (PM) Registers Description

**Table 9-78. L3\_PM\_ERROR\_LOG**

|                  |                                                                 |
|------------------|-----------------------------------------------------------------|
| Address Offset   | 0x20                                                            |
| Physical Address | See Table 9-75 to Table 9-77                                    |
| Description      | This register logs errors detected by the protection mechanism. |
| Type             | RW                                                              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 63       | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|       |           |          |      |          |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |        |          |     |   |   |   |
|-------|-----------|----------|------|----------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------|--------|----------|-----|---|---|---|
| 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 |
| MULTI | SECONDARY | Reserved | CODE | Reserved | REQ_INFO |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Reserved | REGION | Reserved | CMD |   |   |   |

| Bits  | Field Name | Description                                                                 | Type     | Reset      |
|-------|------------|-----------------------------------------------------------------------------|----------|------------|
| 63:32 | Reserved   | Reserved                                                                    | R        | 0x00000000 |
| 31    | MULTI      | Multiple errors<br>0x0:Multiple errors not seen<br>0x1:Multiple errors seen | RW1toClr | 0          |
| 30    | SECONDARY  | Secondary error present                                                     | RW1toClr | 0          |
| 29:28 | Reserved   | Reserved                                                                    | R        | 0x0        |

| Bits  | Field Name | Description                                                                              | Type     | Reset |
|-------|------------|------------------------------------------------------------------------------------------|----------|-------|
| 27:24 | CODE       | Error Code see <a href="#">Table 9-26</a>                                                | RW1toClr | 0x0   |
| 23:21 | Reserved   | Reserved                                                                                 | R        | 0x0   |
| 20:16 | REQ_INFO   | MReqInfo bits of command selected for protection checking see <a href="#">Table 9-22</a> | R        | 0x00  |
| 15:8  | INITID     | Initiator ID from which the command was launched see <a href="#">Table 9-19</a>          | R        | 0x00  |
| 7     | Reserved   | Reserved                                                                                 | R        | 0     |
| 6:4   | REGION     | Protection region number that command mapped to                                          | R        | 0x0   |
| 3     | Reserved   | Reserved                                                                                 | R        | 0     |
| 2:0   | CMD        | Command that caused the error see <a href="#">Table 9-1</a>                              | R        | 0x0   |

**Table 9-79. Register Call Summary for Register L3\_PM\_ERROR\_LOG**

## L3 Interconnect

- [L3 Firewall Error-Logging Registers: \[0\]](#)
- [Time-Out Handling: \[1\] \[2\] \[3\] \[4\]](#)
- [Acknowledging Errors: \[5\] \[6\] \[7\]](#)
- [Protection Mechanism \(PM\): \[8\] \[9\] \[10\]](#)

**Table 9-80. L3\_PM\_CONTROL**

|                         |                                                                                |  |  |  |  |  |  |           |                       |                 |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------|--|--|--|--|--|--|-----------|-----------------------|-----------------|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset          | 0x28                                                                           |  |  |  |  |  |  |           |                       |                 |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address        | See <a href="#">Table 9-75</a> to <a href="#">Table 9-77</a>                   |  |  |  |  |  |  |           |                       |                 |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description             | This register controls protection mechanism functions such as error reporting. |  |  |  |  |  |  |           |                       |                 |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                    | RW                                                                             |  |  |  |  |  |  |           |                       |                 |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                |                                                                                |  |  |  |  |  |  |           |                       |                 |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                |                                                                                |  |  |  |  |  |  | Reserved  |                       |                 |  |  |  |  |  | Reserved |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ERROR_SECONDARY REP     |                                                                                |  |  |  |  |  |  | ERROR REP |                       |                 |  |  |  |  |  | Reserved |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name          | Description                                                                                               | Type | Reset          |
|-------|---------------------|-----------------------------------------------------------------------------------------------------------|------|----------------|
| 63:26 | Reserved            | Reserved                                                                                                  | R    | 0x000000000000 |
| 25    | ERROR_SECONDARY REP | Out of band error reporting<br>0x0: Out of band error reporting suppress<br>0x1: Out of band error report | RW   | 1              |
| 24    | ERROR REP           | Out of band error reporting<br>0x0: Out of band error reporting suppress<br>0x1: Out of band error report | RW   | 1              |
| 23:0  | Reserved            | Reserved                                                                                                  | R    | 0x0000000      |

**Table 9-81. Register Call Summary for Register L3\_PM\_CONTROL**

L3 Interconnect

- Protection Mechanism (PM): [0] [1] [2]

**Table 9-82. L3\_PM\_ERROR\_CLEAR\_SINGLE**

|                         |                                                              |
|-------------------------|--------------------------------------------------------------|
| <b>Address Offset</b>   | 0x30                                                         |
| <b>Physical Address</b> | See <a href="#">Table 9-75</a> to <a href="#">Table 9-77</a> |
| <b>Description</b>      | Read to clear single errors from error log                   |
| <b>Type</b>             | R                                                            |

|                         |                         |                         |                         |
|-------------------------|-------------------------|-------------------------|-------------------------|
| 63 62 61 60 59 58 57 56 | 55 54 53 52 51 50 49 48 | 47 46 45 44 43 42 41 40 | 39 38 37 36 35 34 33 32 |
| Reserved                |                         |                         |                         |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                |                         |                       |                 |

| Bits | Field Name | Description                 | Type | Reset              |
|------|------------|-----------------------------|------|--------------------|
| 63:1 | Reserved   | Reserved                    | R    | 0x0000000000000000 |
| 0    | CLEAR      | Clear single error from log | R    | 0                  |

**Table 9-83. Register Call Summary for Register L3\_PM\_ERROR\_CLEAR\_SINGLE**

L3 Interconnect

- Acknowledging Errors: [0]
- Protection Mechanism (PM): [1] [2] [3]

**Table 9-84. L3\_PM\_ERROR\_CLEAR\_MULTI**

|                         |                                                              |
|-------------------------|--------------------------------------------------------------|
| <b>Address Offset</b>   | 0x38                                                         |
| <b>Physical Address</b> | See <a href="#">Table 9-75</a> to <a href="#">Table 9-77</a> |
| <b>Description</b>      | Read to clear multiple errors from error log                 |
| <b>Type</b>             | R                                                            |

|                         |                         |                         |                         |
|-------------------------|-------------------------|-------------------------|-------------------------|
| 63 62 61 60 59 58 57 56 | 55 54 53 52 51 50 49 48 | 47 46 45 44 43 42 41 40 | 39 38 37 36 35 34 33 32 |
| Reserved                |                         |                         |                         |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                |                         |                       |                 |

| Bits | Field Name | Description                   | Type | Reset              |
|------|------------|-------------------------------|------|--------------------|
| 63:1 | Reserved   | Reserved                      | R    | 0x0000000000000000 |
| 0    | CLEAR      | Clear multiple error from log | R    | 0                  |

**Table 9-85. Register Call Summary for Register L3\_PM\_ERROR\_CLEAR\_MULTI**

## L3 Interconnect

- Acknowledging Errors: [0]
- Protection Mechanism (PM): [1] [2] [3]

**Table 9-86. L3\_PM\_REQ\_INFO\_PERMISSION\_i**

| <b>Address Offset</b>                                                                                 | 0x38                                                                                                                         |                                                                                                     |      |                                  |
|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|------|----------------------------------|
| <b>Physical Address</b>                                                                               | See <a href="#">Table 9-75</a> to <a href="#">Table 9-77</a>                                                                 |                                                                                                     |      |                                  |
| <b>Description</b>                                                                                    | It configures a protection region's permissions using the MReqInfo bits selected for the PM by the structural configuration. |                                                                                                     |      |                                  |
| <b>Type</b>                                                                                           | R/W                                                                                                                          |                                                                                                     |      |                                  |
| 63 62 61 60 59 58 57 56   55 54 53 52 51 50 49 48   47 46 45 44 43 42 41 40   39 38 37 36 35 34 33 32 |                                                                                                                              |                                                                                                     |      |                                  |
| Reserved                                                                                              |                                                                                                                              |                                                                                                     |      |                                  |
| 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           |                                                                                                                              |                                                                                                     |      |                                  |
| Reserved                                                                                              |                                                                                                                              |                                                                                                     |      |                                  |
| REQ_INFO                                                                                              |                                                                                                                              |                                                                                                     |      |                                  |
| Bits                                                                                                  | Field Name                                                                                                                   | Description                                                                                         | Type | Reset                            |
| 63:16                                                                                                 | Reserved                                                                                                                     | Reserved                                                                                            | R    | 0x000000000000                   |
| 15:0                                                                                                  | REQ_INFO                                                                                                                     | Request info permission bits for region i, see <a href="#">Table 9-22</a> for bitfield description. | RW   | See <a href="#">Table 9-88</a> . |

**Table 9-87. Register Call Summary for Register L3\_PM\_REQ\_INFO\_PERMISSION\_i**

## Interconnect Overview

- Terminology: [0]

## L3 Interconnect

- REQ\_INFO\_PERMISSION Configuration: [1] [2] [3] [4] [5]
- L3 Firewall Registers Overview: [6] [7]
- Typical Example of Firewall Programming Example: [8] [9] [10] [11] [12] [13] [14] [15]
- Protection Mechanism (PM): [16] [17] [18]

**Table 9-88. Reset Value for REQ\_INFO\_PERMISSION**

|            | Regions |        |        |        |        |        |        |        |
|------------|---------|--------|--------|--------|--------|--------|--------|--------|
|            | 0       | 1      | 2      | 3      | 4      | 5      | 6      | 7      |
| PM_RT      | 0xFFFF  | 0x000  |        |        |        |        |        |        |
| PM_GPMC    | 0x0000  | 0x---  | 0x---  | 0xFFFF | 0xFFFF | 0xFFFF | 0xFFFF | 0xFFFF |
| PM_OCM_RAM | 0x0000  | 0xFFFF |
| PM_OCM_ROM | 0x---   | 0xFFFF |        |        |        |        |        |        |
| PM_MAD2D   | 0x0000  | 0xFFFF |
| PM_IVA2.2  | 0x0000  | 0xFFFF | 0xFFFF | 0xFFFF |        |        |        |        |

**Table 9-89. L3\_PM\_READ\_PERMISSION\_i**

| Address Offset          | 0x050 + (0x20+i)                                                        | Index                               | i = 0 to 1 for PM_RT<br>i = 0 to 7 for PM_GPMC<br>i = 0 to 1 for PM_OCM_ROM<br>i = 0 to 3 for PM_IVA2<br>i = 0 to 7 for PM_OCM_RAM |                                |  |  |  |
|-------------------------|-------------------------------------------------------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--|--|--|
| Physical Address        | See <a href="#">Table 9-75</a> to <a href="#">Table 9-77</a>            |                                     |                                                                                                                                    |                                |  |  |  |
| Description             | It configures protection region permissions for read incoming commands. |                                     |                                                                                                                                    |                                |  |  |  |
| Type                    | RW                                                                      |                                     |                                                                                                                                    |                                |  |  |  |
| 63 62 61 60 59 58 57 56 | 55 54 53 52 51 50 49 48                                                 | 47 46 45 44 43 42 41 40             | 39 38 37 36 35 34 33 32                                                                                                            |                                |  |  |  |
| Reserved                |                                                                         |                                     |                                                                                                                                    |                                |  |  |  |
| 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                                                                                                                    |                                |  |  |  |
| Reserved                |                                                                         |                                     |                                                                                                                                    |                                |  |  |  |
|                         |                                                                         |                                     |                                                                                                                                    |                                |  |  |  |
| Bits                    | Field Name                                                              | Description                         | Type                                                                                                                               | Reset                          |  |  |  |
| 63:15                   | Reserved                                                                | Reserved                            | R                                                                                                                                  | 0x0                            |  |  |  |
| 14                      | SGX                                                                     | Read permission for the SGX         | RW                                                                                                                                 | <a href="#">See Table 9-93</a> |  |  |  |
| 13                      | Reserved                                                                | Reserved                            | RW                                                                                                                                 | 0x0                            |  |  |  |
| 12                      | DAP                                                                     | Read permission for the DAP         | RW                                                                                                                                 | <a href="#">See Table 9-93</a> |  |  |  |
| 11                      | CAM                                                                     | Read permission for the CAMERA SS   | RW                                                                                                                                 | <a href="#">See Table 9-93</a> |  |  |  |
| 10                      | IVA2_MMU                                                                | Read permission for the IVA2 MMU    | RW                                                                                                                                 | <a href="#">See Table 9-93</a> |  |  |  |
| 9                       | USB_HS_Host                                                             | Read permission for the USB_HS_Host | RW                                                                                                                                 | <a href="#">See Table 9-93</a> |  |  |  |
| 8                       | DISPSS                                                                  | Write permission for the DISPLAY SS | RW                                                                                                                                 | <a href="#">See Table 9-93</a> |  |  |  |
| 7:6                     | Reserved                                                                | Reserved                            | RW                                                                                                                                 | 0x0                            |  |  |  |
| 5                       | SAD2D                                                                   | Read permission for the SAD2D       | RW                                                                                                                                 | <a href="#">See Table 9-93</a> |  |  |  |
| 4                       | USB_HS_OTG                                                              | Read permission for the USB_HS_OTG  | RW                                                                                                                                 | <a href="#">See Table 9-93</a> |  |  |  |
| 3                       | SDMA                                                                    | Read permission for the system DMA  | RW                                                                                                                                 | <a href="#">See Table 9-93</a> |  |  |  |
| 2                       | IVA2_DMA                                                                | Read permission for the IVA2        | RW                                                                                                                                 | <a href="#">See Table 9-93</a> |  |  |  |
| 1                       | MPU                                                                     | Read permission for the MPU         | RW                                                                                                                                 | <a href="#">See Table 9-93</a> |  |  |  |
| 0                       | Reserved                                                                | Reserved                            | RW                                                                                                                                 | 0x0                            |  |  |  |

**Table 9-90. Register Call Summary for Register L3\_PM\_READ\_PERMISSION\_i**

---

## L3 Interconnect

- Read and Write Permission: [0] [1]
  - L3 Firewall Registers Overview: [2] [3]
  - Typical Example of Firewall Programming Example: [4] [5] [6] [7] [8] [9] [10]
  - Protection Mechanism (PM): [11] [12] [13]
  - Protection Mechanism (PM) Registers Description: [14]

**Table 9-91. L3\_PM\_WRITE\_PERMISSION\_i**

|                                                                                                       |                                                                          |              |                                                                                                                                    |  |  |  |
|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| <b>Address Offset</b>                                                                                 | 0x058 + (0x20+i)                                                         | <b>Index</b> | i = 0 to 1 for PM_RT<br>i = 0 to 7 for PM_GPMC<br>i = 0 to 1 for PM_OCM_ROM<br>i = 0 to 3 for PM_IVA2<br>i = 0 to 7 for PM_OCM_RAM |  |  |  |
| <b>Physical Address</b>                                                                               | See <a href="#">Table 9-75</a> to <a href="#">Table 9-77</a>             |              |                                                                                                                                    |  |  |  |
| <b>Description</b>                                                                                    | It configures protection region permissions for write incoming commands. |              |                                                                                                                                    |  |  |  |
| <b>Type</b>                                                                                           | RW                                                                       |              |                                                                                                                                    |  |  |  |
| 63 62 61 60 59 58 57 56   55 54 53 52 51 50 49 48   47 46 45 44 43 42 41 40   39 38 37 36 35 34 33 32 |                                                                          |              |                                                                                                                                    |  |  |  |
| Reserved                                                                                              |                                                                          |              |                                                                                                                                    |  |  |  |
| 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           |                                                                          |              |                                                                                                                                    |  |  |  |
| Reserved                                                                                              |                                                                          |              |                                                                                                                                    |  |  |  |
| SGX                                                                                                   | Reserved                                                                 | DAP          | CAM                                                                                                                                |  |  |  |
| IVA2_MMU                                                                                              | USB_HS_Host                                                              | DISPSS       | Reserved                                                                                                                           |  |  |  |
| SAD2D                                                                                                 | USB_HS_OTG                                                               | SDMA         | IVA2_DMA                                                                                                                           |  |  |  |
| MPU                                                                                                   | Reserved                                                                 |              |                                                                                                                                    |  |  |  |

  

| Bits  | Field Name  | Description                          | Type | Reset                          |
|-------|-------------|--------------------------------------|------|--------------------------------|
| 63:15 | Reserved    | Reserved                             | R    | 0x0                            |
| 14    | SGX         | Write permission for the SGX         | RW   | <a href="#">See Table 9-93</a> |
| 13    | Reserved    | Reserved                             | RW   | 0x0                            |
| 12    | DAP         | Write permission for the DAP         | RW   | <a href="#">See Table 9-93</a> |
| 11    | CAM         | Write permission for the CAMERA SS   | RW   | <a href="#">See Table 9-93</a> |
| 10    | IVA2_MMU    | Write permission for the IVA2 MMU    | RW   | <a href="#">See Table 9-93</a> |
| 9     | USB_HS_Host | Write permission for the USB_HS_Host | RW   | <a href="#">See Table 9-93</a> |
| 8     | DISPSS      | Write permission for the DISPLAY SS  | RW   | <a href="#">See Table 9-93</a> |
| 7:6   | Reserved    | Reserved                             | RW   | 0x0                            |
| 5     | SAD2D       | Write permission for the SAD2D       | RW   | <a href="#">See Table 9-93</a> |
| 4     | USB_HS_OTG  | Write permission for the USB_HS_OTG  | RW   | <a href="#">See Table 9-93</a> |
| 3     | SDMA        | Write permission for the system DMA  | RW   | <a href="#">See Table 9-93</a> |
| 2     | IVA2_DMA    | Write permission for the IVA2        | RW   | <a href="#">See Table 9-93</a> |
| 1     | MPU         | Write permission for the MPU         | RW   | <a href="#">See Table 9-93</a> |
| 0     | Reserved    | Reserved                             | RW   | 0x0                            |

**Table 9-92. Register Call Summary for Register L3\_PM\_WRITE\_PERMISSION\_i**
**L3 Interconnect**

- [Read and Write Permission: \[0\] \[1\]](#)
- [L3 Firewall Registers Overview: \[2\] \[3\]](#)
- [Typical Example of Firewall Programming Example: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\]](#)
- [Protection Mechanism \(PM\): \[11\] \[12\] \[13\]](#)
- [Protection Mechanism \(PM\) Registers Description: \[14\]](#)

[Table 9-93](#) shows bit available in [L3\\_PM\\_READ\\_PERMISSION\\_i](#) and [L3\\_PM\\_WRITE\\_PERMISSION\\_i](#) registers. All N/A are considered as reserved bits with a Read access.

**Table 9-93. Bit Availability and Initialization Values for L3\_PM\_READ\_PERMISSION\_i and L3\_PM\_WRITE\_PERMISSION\_i**

| PM                                           | BITS   |             |         |               |          |            |                |              |         |         |         |                    |
|----------------------------------------------|--------|-------------|---------|---------------|----------|------------|----------------|--------------|---------|---------|---------|--------------------|
|                                              | 1: MPU | 2: IVA2_DMA | 3: SDMA | 4: USB_HS_OTG | 5: SAD2D | 8: DISP_SS | 9: USB_HS_Host | 10: IVA2_MMU | 11: CAM | 12: DAP | 14: SGX | 63:15 Reserved     |
| PM_RT region 0 to 1                          | 1      | 1           | N/A     | N/A           | N/A      | N/A        | N/A            | 1            | N/A     | 1       | N/A     | 0x0000000000000000 |
| PM_GPMC region 0 to 7                        | 1      | 1           | 1       | 1             | 1        | N/A        | 1              | 1            | N/A     | 1       | 1       | 0x0000000000000001 |
| PM_OCM_RAM region 0 to 7                     | 1      | 1           | 1       | 1             | 1        | 1          | 1              | 1            | 1       | 1       | 1       | 0x0000000000000001 |
| PM_OCM_ROM region 0 to 1 (ro) <sup>(1)</sup> | 1      | N/A         | N/A     | N/A           | N/A      | N/A        | N/A            | N/A          | N/A     | 1       | N/A     | 0x0000000000000000 |
| PM_MAD2D region 0 to 7                       | 1      | 1           | 1       | 1             | N/A      | 1          | 1              | 1            | 1       | 1       | 1       | 0x0000000000000001 |
| PM_IVA2.2 region 0 to 3                      | 1      | 1           | 1       | N/A           | N/A      | N/A        | N/A            | 1            | N/A     | 1       | N/A     | 0x0000000000000000 |

<sup>(1)</sup> ROM is a read only memory; therefore, the write permission is set to 0.

**Table 9-94. L3\_PM\_ADDR\_MATCH\_k**

| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x060 + (0x20+k)                                             | <b>Index</b>                    | k = 1 to 1 for PM_RT<br>k = 1 to 7 for PM_GPMC<br>k = 1 to 1 for PM_OCM_ROM<br>k = 1 to 3 for PM_IVA2<br>k = 1 to 7 for PM_OCM_RAM |                                |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--|--|--|-----------|--|--|--|-------|----------|------|--|--|------|------------|-------------|------|-------|-------|----------|----------|---|----------------|-------|-----------|--------------------------------|---|--------------------------------|---|-------|--------------------------|---|--------------------------------|---|----------|----------|---|---|-----|------|------------------------|---|--------------------------------|-----|------------|---------------------------------|---|--------------------------------|
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | See <a href="#">Table 9-75</a> to <a href="#">Table 9-77</a> |                                 |                                                                                                                                    |                                |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                              |                                 |                                                                                                                                    |                                |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R                                                            |                                 |                                                                                                                                    |                                |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| 63 62 61 60 59 58 57 56   55 54 53 52 51 50 49 48   47 46 45 44 43 42 41 40   39 38 37 36 35 34 33 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                              |                                 |                                                                                                                                    |                                |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                              |                                 |                                                                                                                                    |                                |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                              |                                 |                                                                                                                                    |                                |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                              |                                 |                                                                                                                                    |                                |  |  |  | BASE_ADDR |  |  |  | LEVEL | Reserved | SIZE |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                              |                                 |                                                                                                                                    |                                |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th style="text-align: left; padding: 2px;">Bits</th> <th style="text-align: left; padding: 2px;">Field Name</th> <th style="text-align: left; padding: 2px;">Description</th> <th style="text-align: left; padding: 2px;">Type</th> <th style="text-align: left; padding: 2px;">Reset</th> </tr> </thead> <tbody> <tr> <td style="text-align: center; padding: 2px;">63:20</td> <td style="text-align: center; padding: 2px;">Reserved</td> <td style="text-align: center; padding: 2px;">Reserved</td> <td style="text-align: center; padding: 2px;">R</td> <td style="text-align: center; padding: 2px;">0x000000000000</td> </tr> <tr> <td style="text-align: center; padding: 2px;">19:10</td> <td style="text-align: center; padding: 2px;">BASE_ADDR</td> <td style="text-align: center; padding: 2px;">Protection region base address</td> <td style="text-align: center; padding: 2px;">R</td> <td style="text-align: center; padding: 2px;">see <a href="#">Table 9-96</a></td> </tr> <tr> <td style="text-align: center; padding: 2px;">9</td> <td style="text-align: center; padding: 2px;">LEVEL</td> <td style="text-align: center; padding: 2px;">Protection region level.</td> <td style="text-align: center; padding: 2px;">R</td> <td style="text-align: center; padding: 2px;">see <a href="#">Table 9-96</a></td> </tr> <tr> <td style="text-align: center; padding: 2px;">8</td> <td style="text-align: center; padding: 2px;">Reserved</td> <td style="text-align: center; padding: 2px;">Reserved</td> <td style="text-align: center; padding: 2px;">R</td> <td style="text-align: center; padding: 2px;">0</td> </tr> <tr> <td style="text-align: center; padding: 2px;">7:3</td> <td style="text-align: center; padding: 2px;">SIZE</td> <td style="text-align: center; padding: 2px;">Protection region size</td> <td style="text-align: center; padding: 2px;">R</td> <td style="text-align: center; padding: 2px;">see <a href="#">Table 9-96</a></td> </tr> <tr> <td style="text-align: center; padding: 2px;">2:0</td> <td style="text-align: center; padding: 2px;">ADDR_SPACE</td> <td style="text-align: center; padding: 2px;">Protection region address space</td> <td style="text-align: center; padding: 2px;">R</td> <td style="text-align: center; padding: 2px;">see <a href="#">Table 9-96</a></td> </tr> </tbody> </table> |                                                              |                                 |                                                                                                                                    |                                |  |  |  |           |  |  |  |       |          |      |  |  | Bits | Field Name | Description | Type | Reset | 63:20 | Reserved | Reserved | R | 0x000000000000 | 19:10 | BASE_ADDR | Protection region base address | R | see <a href="#">Table 9-96</a> | 9 | LEVEL | Protection region level. | R | see <a href="#">Table 9-96</a> | 8 | Reserved | Reserved | R | 0 | 7:3 | SIZE | Protection region size | R | see <a href="#">Table 9-96</a> | 2:0 | ADDR_SPACE | Protection region address space | R | see <a href="#">Table 9-96</a> |
| Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Field Name                                                   | Description                     | Type                                                                                                                               | Reset                          |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| 63:20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Reserved                                                     | Reserved                        | R                                                                                                                                  | 0x000000000000                 |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| 19:10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | BASE_ADDR                                                    | Protection region base address  | R                                                                                                                                  | see <a href="#">Table 9-96</a> |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | LEVEL                                                        | Protection region level.        | R                                                                                                                                  | see <a href="#">Table 9-96</a> |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reserved                                                     | Reserved                        | R                                                                                                                                  | 0                              |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| 7:3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | SIZE                                                         | Protection region size          | R                                                                                                                                  | see <a href="#">Table 9-96</a> |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |
| 2:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ADDR_SPACE                                                   | Protection region address space | R                                                                                                                                  | see <a href="#">Table 9-96</a> |  |  |  |           |  |  |  |       |          |      |  |  |      |            |             |      |       |       |          |          |   |                |       |           |                                |   |                                |   |       |                          |   |                                |   |          |          |   |   |     |      |                        |   |                                |     |            |                                 |   |                                |

**Table 9-95. Register Call Summary for Register L3\_PM\_ADDR\_MATCH\_k**
**L3 Interconnect**

- Protection Region: [0] [1] [2]
- Priority Level Overview: [3] [4] [5]
- L3 Firewall Registers Overview: [6] [7] [8]
- Typical Example of Firewall Programming Example: [9] [10] [11] [12] [13]
- Protection Mechanism (PM): [14] [15] [16]

**Table 9-96. Reset Value for L3\_PM\_ADDR\_MATCH\_k**

| <b>PM</b>  | <b>Region</b> | <b>BASE ADDRESS</b> | <b>LEVEL</b> | <b>SIZE</b> | <b>ADDR_SPACE</b> |
|------------|---------------|---------------------|--------------|-------------|-------------------|
| PM_RT      | 1             | 0x040               | 0x1          | 0x06        | 0x0               |
| PM_GPMC    | 1             | 0x000               | 0x0          | 0x23        | 0x0               |
|            | 2             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 3             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 4             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 5             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 6             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 7             | 0x000               | 0x0          | 0x00        | 0x0               |
| PM_OCM_RAM | 1             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 2             | 0x03E               | 0x0          | 0x02        | 0x0               |
|            | 3             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 4             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 5             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 6             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 7             | 0x000               | 0x0          | 0x00        | 0x0               |
| PM_OCM_ROM | 1             | 0x050               | 0x0          | 0x05        | 0x0               |
|            | 2             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 3             | 0x000               | 0x0          | 0x00        | 0x0               |
| PM_MAD2D   | 1             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 2             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 3             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 4             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 5             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 6             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 7             | 0x000               | 0x0          | 0x00        | 0x0               |
| PM_IVA2    | 1             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 2             | 0x000               | 0x0          | 0x00        | 0x0               |
|            | 3             | 0x000               | 0x0          | 0x00        | 0x0               |

### 9.2.5.5 Sideband Interconnect (SI)

This section describes the sideband interconnect register block.

[Table 9-97](#) lists the SI registers and their physical addresses.

[Table 9-98](#) through [Table 9-102](#) describe the individual registers in the module instance.

**Table 9-97. SI Register Summary**

| Register Name       | Type | Register Width (Bits) | Address Offset | Physical Address |
|---------------------|------|-----------------------|----------------|------------------|
| L3_SI_CONTROL       | RW   | 64                    | 0x020          | 0x6800 0420      |
| L3_SI_FLAG_STATUS_0 | R    | 64                    | 0x110          | 0x6800 0510      |
| L3_SI_FLAG_STATUS_1 | R    | 64                    | 0x130          | 0x6800 0530      |

#### 9.2.5.5.1 Sideband Interconnect (SI) Registers Description

**Table 9-98. L3\_SI\_CONTROL**

| <b>Address Offset</b>   | 0x020                                         | <b>Physical Address</b>                                                                                                                      | 0x6800 0420             | <b>Instance</b> | SI |      |                    |
|-------------------------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|----|------|--------------------|
| <b>Description</b>      | Control of register and sideband interconnect |                                                                                                                                              |                         |                 |    |      |                    |
| <b>Type</b>             | RW                                            |                                                                                                                                              |                         |                 |    |      |                    |
| 63 62 61 60 59 58 57 56 | 55 54 53 52 51 50 49 48                       | 47 46 45 44 43 42 41 40                                                                                                                      | 39 38 37 36 35 34 33 32 |                 |    |      |                    |
| Reserved                | CLOCK_GATE_DISABLE                            |                                                                                                                                              |                         | Reserved        |    |      |                    |
| 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         | Reserved        |    |      |                    |
|                         |                                               |                                                                                                                                              |                         |                 |    |      |                    |
| Bits                    | Field Name                                    | Description                                                                                                                                  |                         |                 |    | Type | Reset              |
| 63:57                   | Reserved                                      | Reserved for future use                                                                                                                      |                         |                 |    | R    | 0x00               |
| 56                      | CLOCK_GATE_DISABLE                            | Overrides fine grained hardware clock gating in register and sideband interconnect<br>0x0: Normal clock gating<br>0x1: Clock gating disabled |                         |                 |    | RW   | 0                  |
| 55:0                    | Reserved                                      | Reserved for future use                                                                                                                      |                         |                 |    | R    | 0x0000000000000000 |

**Table 9-99. Register Call Summary for Register L3\_SI\_CONTROL**

L3 Interconnect

- [Sideband Interconnect \(SI\): \[0\]](#)

**Table 9-100. L3\_SI\_FLAG\_STATUS\_0**

| <b>Address Offset</b>   | 0x110                                                                                    | <b>Physical Address</b>                                                                                          | 0x6800 0510             | <b>Instance</b> | SI |      |                    |
|-------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|----|------|--------------------|
| <b>Description</b>      | They are used to observe the individual bits that make up a composite interconnect flag. |                                                                                                                  |                         |                 |    |      |                    |
| <b>Type</b>             | R                                                                                        |                                                                                                                  |                         |                 |    |      |                    |
| 63 62 61 60 59 58 57 56 | 55 54 53 52 51 50 49 48                                                                  | 47 46 45 44 43 42 41 40                                                                                          | 39 38 37 36 35 34 33 32 |                 |    |      |                    |
|                         |                                                                                          |                                                                                                                  |                         | STATUS          |    |      |                    |
| 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         | STATUS          |    |      |                    |
|                         |                                                                                          |                                                                                                                  |                         |                 |    |      |                    |
| Bits                    | Field Name                                                                               | Description                                                                                                      |                         |                 |    | Type | Reset              |
| 63:0                    | STATUS                                                                                   | Status of sideband signals making up composite interconnect flag for application. See <a href="#">Table 9-29</a> |                         |                 |    | R    | 0x0000000000000000 |

**Table 9-101. Register Call Summary for Register L3\_SI\_FLAG\_STATUS\_0**

## L3 Interconnect

- [Global Error Reporting: \[0\]](#)
- [Error Analysis: \[1\]](#)
- [Time-Out Handling: \[2\] \[3\] \[4\]](#)
- [Acknowledging Errors: \[5\]](#)
- [Sideband Interconnect \(SI\): \[6\]](#)

**Table 9-102. L3\_SI\_FLAG\_STATUS\_1**

|                       |                                                                                          |                         |             |                 |    |
|-----------------------|------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|----|
| <b>Address Offset</b> | 0x130                                                                                    | <b>Physical Address</b> | 0x6800 0530 | <b>Instance</b> | SI |
| <b>Description</b>    | They are used to observe the individual bits that make up a composite interconnect flag. |                         |             |                 |    |
| <b>Type</b>           | R                                                                                        |                         |             |                 |    |

|                         |                         |                         |                         |
|-------------------------|-------------------------|-------------------------|-------------------------|
| 63 62 61 60 59 58 57 56 | 55 54 53 52 51 50 49 48 | 47 46 45 44 43 42 41 40 | 39 38 37 36 35 34 33 32 |
| STATUS                  |                         |                         |                         |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| STATUS                  |                         |                       |                 |

| Bits | Field Name | Description                                                                                                  | Type | Reset              |
|------|------------|--------------------------------------------------------------------------------------------------------------|------|--------------------|
| 63:0 | STATUS     | Status of sideband signals making up composite interconnect flag for debug. See <a href="#">Table 9-30</a> . | R    | 0x0000000000000000 |

**Table 9-103. Register Call Summary for Register L3\_SI\_FLAG\_STATUS\_1**

## L3 Interconnect

- [Global Error Reporting: \[0\]](#)
- [Error Analysis: \[1\]](#)
- [Acknowledging Errors: \[2\]](#)
- [Sideband Interconnect \(SI\): \[3\]](#)

## 9.3 L4 Interconnects

### 9.3.1 Overview

To connect peripheral modules, the device uses four separate L4 interconnect structures. Although all L4 interconnects handle transfers with peripherals, the interconnects are in different power domains. The L4 interconnect is composed of the following:

- L4-Core: Includes the majority of the peripherals and the configuration interface for L3 interconnect system modules
- L4-Per: Includes peripherals that do not need to be mapped in the CORE power domain
- L4-Wakeup: Includes the peripherals attached to the WKUP power domain
- L4-Emu: Includes emulation peripherals attached to the EMU power domain

The following are the main features of the L4 interconnects:

- Single port to connect to L3 interconnect
  - L4-Core
  - L4-Per
- Dual ports for the following:
  - L4-Emu to connect to the L3 interconnect and DAP
  - L4-Wakeup to connect to the L4-Core and L4-Emu
- Single 32-bit initiator for the L3 port
- Multitarget ports (one per target interface on the L4 interconnect)
- 8-, 16-, or 32-bit data, single, or burst transactions
- Little-endian
- Nonblocking with fair arbitration between threads
- Peripherals are not burst-capable; the system initiators can address bursts to them, but the L4 interconnect breaks the bursts into single accesses.
- Target interfaces: Fully synchronous or divided synchronous
- Peak bandwidth of L4 interconnect is  $1 \text{ MBps} \times \text{L4 frequency in MHz}$  per L4 thread (that is, 100 MBps, when the L4 frequency is 100 MHz).
- Latency: Three cycles on request, one cycle on response
- Protection logic provides user-configurable access control to targets by each initiator:
  - Firewall in L4-Core protects the core and wake-up peripherals.
  - Firewall in L4-Per protects per peripherals.
  - Firewall in L4-Emu protects emulation and wake-up peripherals

---

**NOTE:** L4-Wakeup has two input ports from L4-Core and L4-Emu. Therefore, wake-up peripherals appear in two locations in the memory mapping. Normally, L4-Emu limits its access except when debugging.

---

---

**NOTE:** L4\_CORE has four threads (maximum), L4\_PER has four threads (maximum), and L4\_EMU and L4\_WKUP have one thread.

---

Figure 9-13 shows an overview of the L4 interconnects and the peripherals attached to them.

**Figure 9-13. L4 Interconnect Overview**

**Figure 9-14** shows an internal view of the L4 interconnects in the overall interconnect. This architecture, with only one initiator module (the initiator subsystem) distributing transactions to all target modules (peripherals), enables the firewall functions of the L4 interconnects to be centralized at the L4 initiator level. The L4 firewall filters the accesses according to the configurable protection groups defined in the L4 address protection (AP) registers. Each module or agent is assigned to a protection group. Configuration is also defined in the L4 AP and is programmable on a module-per-module basis.

**Figure 9-14. L4 Initiator-Target Connectivity for L4-Core and L4-Per**

**NOTE:** As [Figure 9-14](#) shows, targets are attached to branches. These branches have no functional effect and are present for timing closure reasons only.

### 9.3.1.1 L4-Core Interconnect

The L4-core interconnect handles only transfers to peripherals in the CORE power domain. [Table 9-104](#) lists the TAs.

**Table 9-104. L4-Core Target Agents**

| Module Name       | Description                                        |
|-------------------|----------------------------------------------------|
| Display subsystem | Display subsystem configuration port               |
| Camera subsystem  | Camera subsystem port                              |
| USBHS OTG         | Universal serial bus High-Speed port OTG           |
| USBHS Host        | Universal serial bus High-Speed port Host          |
| USBTLL            | USB Transceiver Less Link                          |
| UART1             | Universal asynchronous receiver transmitter port 1 |
| UART2             | Universal asynchronous receiver transmitter port 2 |
| I2C1              | Multimaster inter-integrated circuit 1             |
| I2C2              | Multimaster inter-integrated circuit 2             |
| I2C3              | Multimaster inter-integrated circuit 3             |
| McBSP1            | Multichannel buffered serial port 1                |
| McBSP5            | Multichannel buffered serial port 5                |
| GPTIMER10         | General-purpose timer 10                           |
| GPTIMER11         | General-purpose timer 11                           |
| MMC1              | Multimedia memory controller SDIO 1                |
| MMC2              | Multimedia memory controller SDIO 2                |
| MMC3              | Multimedia memory controller SDIO 3                |
| HDQ/1-Wire        | Single wire serial link low rate                   |
| MLB (mailbox)     | Mailbox                                            |
| MCSPI1            | Serial peripheral interface 1                      |
| MCSPI2            | Serial peripheral interface 2                      |
| MCSPI3            | Serial peripheral interface 3                      |
| MCSPI4            | Serial peripheral interface 4                      |
| SR1               | SmartReflex1                                       |
| SR2               | SmartReflex2                                       |
| sDMA              | System DMA controller                              |
| L4-Wakeup         | L4-Wakeup interconnect                             |
| CM                | Clock manager                                      |
| SCM               | System control module                              |

**NOTE:** A unique port is used for communication between the L3 interconnect and the L4-Core interconnect to allow the L3 initiators to access the L4-Core targets.

For the list of initiators authorized to access the L4-Core peripherals, see [Table 9-14](#). For details on restricted access, see [Section 9.3.3.3.1, Protection Mechanism](#).

### 9.3.1.2 L4-Per Interconnect

The L4-Per interconnect handles only transfers to peripherals in the PER power domain. [Table 9-105](#) lists the TAs.

**Table 9-105. L4-Per Target Agents**

| Module Name | Description                                                                    |
|-------------|--------------------------------------------------------------------------------|
| UARTIrDA    | Universal asynchronous receiver/transmitter and infrared data association port |

**Table 9-105. L4-Per Target Agents (continued)**

| Module Name | Description                                        |
|-------------|----------------------------------------------------|
| UART4       | Universal asynchronous receiver transmitter port 4 |
| McBSP2      | Multichannel buffered serial port 2                |
| McBSP3      | Multichannel buffered serial port 3                |
| McBSP4      | Multichannel buffered serial port 4                |
| GPTIMER2    | General-purpose timer 2                            |
| GPTIMER3    | General-purpose timer 3                            |
| GPTIMER4    | General-purpose timer 4                            |
| GPTIMER5    | General-purpose timer 5                            |
| GPTIMER6    | General-purpose timer 6                            |
| GPTIMER7    | General-purpose timer 7                            |
| GPTIMER8    | General-purpose timer 8                            |
| GPTIMER9    | General-purpose timer 9                            |
| GPIO2       | General-purpose I/O 2                              |
| GPIO3       | General-purpose I/O 3                              |
| GPIO4       | General-purpose I/O 4                              |
| GPIO5       | General-purpose I/O 5                              |
| GPIO6       | General-purpose I/O 6                              |

**NOTE:** A unique port is used for communication between the L3 interconnect and the L4-Core interconnect to allow the L3 initiators to access the L4-Per targets.

For the list of initiators authorized to access the L4-Per peripherals, see [Table 9-14](#). For details on restricted access, see [Section 9.3.3.3.1, Protection Mechanism](#).

### 9.3.1.3 L4-Emu Interconnect

The L4-Emu interconnect handles only transfers to peripherals in the EMU power domain. [Table 9-106](#) lists the TAs.

**Table 9-106. L4-Emu Target Agents**

| Module Name | Description                  |
|-------------|------------------------------|
| L4-Wakeup   | L4-Wakeup interconnect       |
| SDTI        | System debug trace interface |
| ETB         | Embedded trace buffer        |
| TPIU        | Trace port interface unit    |
| MPU         | ARM9                         |
| DAP         | Debug access port            |

Not all initiators can access all the targets in the L4-Emu interconnect. Additional restrictions affect the ability of these initiators to access the L4-Emu peripherals. [Table 9-107](#) lists which initiators can access the L4-Emu interconnect.

**NOTE:** For the list of initiators authorized to access the L4-Emu peripherals, see [Table 9-14](#). For details on restricted access, see [Section 9.3.3.3.1, Protection Mechanism](#).

**Table 9-107. L4-Emu Initiator Agents**

| Module Name     | Description          |
|-----------------|----------------------|
| L3 interconnect | L3 interconnect port |
| DAP             | DAP port             |

#### 9.3.1.4 L4-Wakeup Interconnect

The L4-Wakeup interconnect handles only transfers to peripherals in the WKUP power domain. [Table 9-108](#) lists the TAs.

**Table 9-108. L4-Wakeup Target Agents**

| Module Name | Description                  |
|-------------|------------------------------|
| PRM         | Power reset manager          |
| GPIO1       | General-purpose I/O 1        |
| GPTIMER1    | General-purpose timer 1      |
| WDTIMER2    | MPU subsystem watchdog timer |
| 32KTIMER    | 32-kHz timer                 |

Initiators that can access the L4-Core or L4-Emu can access all the targets in the L4-Wakeup interconnect. [Table 9-109](#) lists the initiators that can access the L4-Wakeup interconnect. For details on restricted access, see [Section 9.3.3.3.1, Protection Mechanism](#).

**Table 9-109. L4-Wakeup Initiator Agents**

| Module Name          | Description               |
|----------------------|---------------------------|
| L4-Core interconnect | L4-Core interconnect port |
| L4-Emu interconnect  | L4-Emu interconnect port  |

### 9.3.2 L4 Interconnects Integration

#### 9.3.2.1 Clocking, Reset, and Power-Management Scheme

##### 9.3.2.1.1 Clocks

Four functional clocks are used in each L4 interconnect (see [Table 9-110](#)).

**Table 9-110. L4 Interconnect Clocks**

| Clock                        | Frequency            | Name          | Comments                                           |
|------------------------------|----------------------|---------------|----------------------------------------------------|
| L4-Core interconnect clock   | Up to Core_L3_ICLK/2 | CORE_L4_GICLK | Source, control, and gating handled by PRCM module |
| L4-Per interconnect clock    | Up to Core_L3_ICLK/2 | PER_L4_GICLK  | Source, control, and gating handled by PRCM module |
| L4-Emu clock                 |                      | L4_EMU        | Clock for emulation                                |
| L4-Wakeup interconnect clock |                      | WKUP_L4_GICLK | Source, control, and gating handled by PRCM module |

##### 9.3.2.1.2 Resets

###### 9.3.2.1.2.1 Hardware Reset

L4 interconnects receive a reset signal from the PRCM module, which is the reset signal to the CORE power domain. For more details, see *Power, Reset, and Clock Management*.

[Table 9-111](#) lists the hardware reset for the L4-Core interconnect.

**Table 9-111. L4 Interconnect Hardware Reset**

| Interconnect           | Reset Domain |
|------------------------|--------------|
| L4-Core interconnect   | CORE_RST     |
| L4-Per interconnect    | PER_RST      |
| L4-Wakeup interconnect | WKUP_RST     |
| L4-Emu interconnect    | EMU_RST      |

###### 9.3.2.1.2.2 Software Reset

The L4 interconnects have hardware reset capabilities, but do not have software reset capabilities. The hardware reset capabilities are controlled by the PRCM module and are applied to the L4 interconnects and the connected L4 TAs and L4 target modules.

###### 9.3.2.1.3 Power Domain

For more details on power voltage scaling, see *Power, Reset, and Clock Management*.

[Table 9-112](#) lists the power domains for the L4-Core and L4-Wakeup interconnects.

**Table 9-112. L4 Interconnect Power Domains**

| Interconnect           | Power Domain |
|------------------------|--------------|
| L4-Core interconnect   | CORE         |
| L4-Per interconnect    | PER          |
| L4-Emu interconnect    | EMU          |
| L4-Wakeup interconnect | WKUP         |

### 9.3.2.1.4 Power Management

#### 9.3.2.1.4.1 Module Power-Saving

The L4 interconnect automatically performs internal clock autogating to reduce power consumption. Though not recommended, it is possible to deactivate clock autogating by writing 1 to the CLOCK\_GATE\_DISABLE bit [L4\\_LA\\_NETWORK\\_CONTROL\\_H\[24\]](#) of each L4 interconnect. Clock autogating is enabled by default.

#### 9.3.2.1.4.2 System Power Management and Wakeup

As part of the system-wide power-management scheme, the L4 interconnect enters an idle state at the request of the PRCM module (for more information, see *Power, Reset, and Clock Management*). The L4 interconnect is always in smart-idle mode; that is, it goes into idle state after receiving the request from the PRCM module once all the transfer requests are complete. This functionality is handled by hardware. The L4 interconnect sends an acknowledge signal back to the PRCM module when it enters idle state.

### 9.3.3 L4 Interconnects Functional Description

#### 9.3.3.1 L4-Interconnects Initiator Identification

In the device interconnect, a ConnID is an initiator module identifier. The L4 interconnect uses the same ConnID as L3.

#### 9.3.3.2 Endianness Management

Both L4 interconnects are little-endian only. Any initiator accessing the L4 interconnect module must consider byte ordering and perform a conversion, if necessary.

#### 9.3.3.3 L4 Protection and Firewalls

##### 9.3.3.3.1 Protection Mechanism

The following two parameters are used to set up access permission because of the large address spaces and the number of peripherals connected to the L4 interconnects:

- Programmable groups for initiators:
  - 8 protection groups for the L4-Core interconnect
  - 8 protection groups for the L4-Per interconnect
  - 6 protection groups for the L4-Emu interconnect
- Each segment is divided into regions of 2K bytes:
  - 100 regions for the L4-Core interconnect
  - 43 regions for the L4-Per interconnect
  - 26 regions for the L4-Emu interconnect

---

**NOTE:** Regions and segments are present for the L4-Wakeup interconnect but cannot be programmed. The L4-Wakeup protection is done through the L4-Core and L4-Emu interconnects.

---

A protection group is a group of targets that have the same protection settings. Initiator access is defined by CONNID\_BIT\_VECTOR field [L4\\_AP\\_PROT\\_GROUP\\_k\\_L\[15:0\]](#). The initiators have the same access permission to all regions in this group.

A region is programmed to allow access to a unique selectable protection group by using PROT\_GROUP\_ID field [L4\\_AP\\_REGION\\_I\\_H\[22:20\]](#).

**NOTE:** k denotes the protection group number.

I denotes the region number.

### 9.3.3.3.2 Protection Group

A protection group defines which initiators with a given MReqInfo can access the targets agent protected by this group.

The CONNID\_BIT\_VECTOR field L4\_AP\_PROT\_GROUP\_MEMBERS\_K[15:0] (see [Figure 9-15](#)) is a 1-bit vector that sets up initiator permission access regions. A protection group is accessible by an initiator if the bit position corresponding to its ConnID is set to one in the CONNID\_BIT\_VECTOR field.

The ENABLE field L4\_AP\_PROT\_GROUP\_ROLES\_K[31:0] lists all possible MReqInfo combinations. Setting a Req bit in this register determines the type of access allowed to the initiator. See [Section 9.2.3.3.4, REQ\\_INFO\\_PERMISSION Configuration](#), for more information. MReqInfo is used in L4 the same way it is used in the L3 firewall configuration.

**NOTE:** Permissions are identical for read and write accesses in L4 interconnect targets.

[Figure 9-15](#) shows an example of CONNID\_BIT\_VECTOR.

**Figure 9-15. Example of CONNID\_BIT\_VECTOR**



Setting bits 1 and 4 in the PROT\_GROUP\_ID\_1 defines a group initiator able to access targets in protection group 1, and includes:

- MPU SS
- IVA2.2 MMU

Protection group 1 (PG1) can be applied to multiple protection regions without limitation. Each protection region I that is configured with PG1 enables permission access to these two initiators only.

The firewall default configuration for the L4-Core interconnect contains eight protection groups:

- Most regions are, by default, set with protection group 7 (PG7), which is configured for all access (see [Table 9-113](#)).

- Protection group 0 (PG0) is restricted to the MPU subsystem.
- The DSS is attached to protection group 2 (PG2).
- The Camera is attached to protection group 3 (PG3).
- By default, PG5 to PG7 are configured for all access.

The L4-Per interconnect contains eight protection groups:

- By default, PG0 to PG7 are configured for all access.
- By default, most regions are set with PG7, which is configured for all access (see [Table 9-114](#)).

The L4-Emu interconnect contains six protection groups:

- By default, most regions are set with PG5, which is configured for all access (see [Table 9-115](#)).
- The AP is attached to PG0.
- The emulation organs are attached to PG3.

#### 9.3.3.3 Segments and Regions

The protection mechanism for L4 interconnects is based on a hierarchical segmentation (see [Figure 9-16](#)). By default, some regions are attached to a specific protection group. This specificity allows the user to set up the permission access for certain types of modules that require the same access protection without managing the region allocation.

## **Figure 9-16. L4 Firewall Overview**



All interconnect address spaces are covered by regions. [Table 9-113](#) to [Table 9-115](#) list the module mapping, including the address, region number, and default protection group allocated to it.

By setting ENABLE bit L4\_AP\_REGION\_y\_H[0] to 0, the region becomes inactive and therefore inaccessible. Setting the bit to 1 activates the region.

**Table 9-113. Region Allocation for L4-Core Interconnect**

| Device Name           | Start Address (Hex) | Description     | Region Number | Default Protection Group |
|-----------------------|---------------------|-----------------|---------------|--------------------------|
| Reserved              | 0x4800 0000         | Reserved        |               |                          |
| System control module | 0x4800 2000         | Module          | 73            | 7                        |
|                       | 0x4800 3000         | L4 interconnect | 75            | 7                        |

**Table 9-113. Region Allocation for L4-Core Interconnect (continued)**

| Device Name                        | Start Address<br>(Hex) | Description             | Region<br>Number | Default<br>Protection<br>Group |
|------------------------------------|------------------------|-------------------------|------------------|--------------------------------|
| Clock manager                      | 0x4800 4000            | Module region A         | 66               | 7                              |
|                                    | 0x4800 6000            | Module region B         | 72               | 7                              |
|                                    | 0x4800 6800            | Reserved                |                  |                                |
|                                    | 0x4800 7000            | L4 interconnect         | 67               | 7                              |
| Reserved                           | 0x4800 8000            |                         |                  |                                |
|                                    | 0x4802 4000            |                         | Reserved         |                                |
|                                    | 0x4802 5000            |                         |                  |                                |
|                                    | 0x4802 6000            |                         |                  |                                |
| L4-Core configuration              | 0x4804 0000            | Address protection (AP) | 0                | 7                              |
|                                    | 0x4804 0800            | Initiator port (IP)     | 1                | 7                              |
|                                    | 0x4804 1000            | Link agent (LA)         | 2                | 0                              |
| Reserved                           | 0x4804 2000            | Reserved                |                  |                                |
| Display subsystem                  | 0x4804 FC00            | DSI                     | 104              | 2                              |
|                                    | 0x4805 0400            | Display subsystem top   | 4                | 2                              |
|                                    | 0x4805 0400            | Display controller      | 4                | 2                              |
|                                    | 0x4805 0800            | RFBI                    | 5                | 2                              |
|                                    | 0x4805 0C00            | Video encoder           | 6                | 2                              |
|                                    | 0x4805 1000            | L4 interconnect         | 7                | 2                              |
| Reserved                           | 0x4805 2000            | Reserved                |                  |                                |
| sDMA                               | 0x4805 6000            | Module                  | 9                | 7                              |
|                                    | 0x4805 7000            | L4 interconnect         | 10               | 7                              |
| Reserved                           | 0x4805 8000            |                         |                  |                                |
|                                    | 0x4805 9000            |                         |                  |                                |
|                                    | 0x4805 A000            | Reserved                |                  |                                |
|                                    | 0x4805 B000            |                         |                  |                                |
| Reserved                           | 0x4805 C000            |                         |                  |                                |
| Reserved                           | 0x4805 D000            | Reserved                |                  |                                |
| I2C3                               | 0x4806 0000            | Module                  | 73               | 7                              |
|                                    | 0x4806 1000            | L4 interconnect         | 74               | 7                              |
| USBTLL                             | 0x4806 2000            | Module                  | 100              | 7                              |
|                                    | 0x4806 3000            | L4 interconnect         | 101              | 7                              |
| USBHS Host                         | 0x4806 4000            | Module                  | 15               | 7                              |
|                                    | 0x4806 5000            | L4 interconnect         | 16               | 7                              |
| UART1                              | 0x4806 A000            | Module                  | 17               | 7                              |
|                                    | 0x4806 B000            | L4 interconnect         | 18               | 7                              |
| UART2                              | 0x4806 C000            | Module                  | 19               | 7                              |
|                                    | 0x4806 D000            | L4 interconnect         | 20               | 7                              |
| Reserved                           | 0x4806 E000            | Reserved                |                  |                                |
| I2C1                               | 0x4807 0000            | Module                  | 21               | 7                              |
|                                    | 0x4807 1000            | L4 interconnect         | 22               | 7                              |
| I2C2                               | 0x4807 2000            | Module                  | 23               | 7                              |
|                                    | 0x4807 3000            | L4 interconnect         | 24               | 7                              |
| McBSP1<br>(digital base band data) | 0x4807 4000            | Module                  | 25               | 7                              |
|                                    | 0x4807 5000            | L4 interconnect         | 26               | 7                              |
| Reserved                           | 0x4807 6000            | Reserved                |                  |                                |

**Table 9-113. Region Allocation for L4-Core Interconnect (continued)**

| Device Name           | Start Address<br>(Hex) | Description                               | Region<br>Number | Default<br>Protection<br>Group |
|-----------------------|------------------------|-------------------------------------------|------------------|--------------------------------|
| GPTIMER10             | 0x4808 6000            | Module                                    | 27               | 7                              |
|                       | 0x4808 7000            | L4 interconnect                           | 28               | 7                              |
| GPTIMER11             | 0x4808 8000            | Module                                    | 29               | 7                              |
|                       | 0x4808 9000            | L4 interconnect                           | 30               | 7                              |
| Reserved              |                        | 0x4808 A000<br>0x4808 B000<br>0x4808 C000 | Reserved         |                                |
| MAILBOX               | 0x4809 4000            | Module                                    | 33               | 7                              |
|                       | 0x4809 5000            | L4 interconnect                           | 34               | 7                              |
| McBSP5<br>(MIDI data) | 0x4809 6000            | Module                                    | 59               | 7                              |
|                       | 0x4809 7000            | L4 interconnect                           | 60               | 7                              |
| MCSPI1                | 0x4809 8000            | Module                                    | 35               | 7                              |
|                       | 0x4809 9000            | L4 interconnect                           | 36               | 7                              |
| MCSPI2                | 0x4809 A000            | Module                                    | 37               | 7                              |
|                       | 0x4809 B000            | L4 interconnect                           | 38               | 7                              |
| MMC/SD/SDIO1          | 0x4809 C000            | Module                                    | 39               | 7                              |
|                       | 0x4809 D000            | L4 interconnect                           | 40               | 7                              |
| Reserved              |                        | 0x4809 E000<br>0x4809 F000                | Reserved         |                                |
| USBHS OTG             | 0x480A B000            | Module                                    | 13               | 7                              |
|                       | 0x480A C000            | L4 interconnect                           | 14               | 7                              |
| MMC/SD/SDIO3          | 0x480A D000            | Module                                    | 98               | 7                              |
|                       | 0x480A E000            | L4 interconnect                           | 99               | 7                              |
| Reserved              |                        | 0x480B 0000<br>0x480B 1000                | Reserved         |                                |
| HDQ/1-Wire            | 0x480B 2000            | Module                                    | 57               | 7                              |
|                       | 0x480B 3000            | L4 interconnect                           | 58               | 7                              |
| MMC/SD/SDIO2          | 0x480B 4000            | Module                                    | 41               | 7                              |
|                       | 0x480B 5000            | L4 interconnect                           | 42               | 7                              |
| ICR                   | 0x480B 6000            | Module                                    | 88               | 7                              |
|                       | 0x480B 7000            | L4 interconnect                           | 89               | 7                              |
| MCSPI3                | 0x480B 8000            | Module                                    | 66               | 7                              |
|                       | 0x480B 9000            | L4 interconnect                           | 67               | 7                              |
| MCSPI4                | 0x480B A000            | Module                                    | 77               | 7                              |
|                       | 0x480B B000            | L4 interconnect                           | 78               | 7                              |
| Camera ISP            | 0x480B C000            | Camera ISP                                | 8                | 3                              |
|                       | 0x480C 0000            | L4 interconnect                           | 75               | 3                              |
| MODEM INTC            | 0x480C 7000            | Module                                    | 90               | 7                              |
|                       | 0x480C 8000            | L4 interconnect                           | 91               | 7                              |
| SR1                   | 0x480C 9000            | Module                                    | 31               | 7                              |
|                       | 0x480C A000            | L4 interconnect                           | 32               | 7                              |
| SR2                   | 0x480C B000            | Module                                    | 68               | 7                              |
|                       | 0x480C C000            | L4 interconnect                           | 69               | 7                              |
| ICR                   | 0x480C D000            | Module                                    | 86               | 7                              |
|                       | 0x480C E000            | L4 interconnect                           | 87               | 7                              |
| Reserved              | 0x480C F000            | Reserved                                  |                  |                                |

**Table 9-113. Region Allocation for L4-Core Interconnect (continued)**

| Device Name            | Start Address<br>(Hex) | Description              | Region<br>Number | Default<br>Protection<br>Group |
|------------------------|------------------------|--------------------------|------------------|--------------------------------|
| MPU INTC               | 0x4820 0000            | Nonshared device mapping |                  |                                |
| Reserved               | 0x4820 1000            | Reserved                 |                  |                                |
| Reserved               | 0x4828 1000            | Reserved                 |                  |                                |
| L4-Wakeup interconnect | 0x4830 0000            | L4 wakeup                | 76               | 7                              |
|                        | 0x4830 6000            | L4 wakeup                | 92               | 7                              |
|                        | 0x4830 8000            | L4 wakeup                | 93               | 7                              |
|                        | 0x4830 9000            | L4 wakeup                | 94               | 7                              |
|                        | 0x4830 C000            | L4 wakeup                | 95               | 7                              |
|                        | 0x4831 0000            | L4 wakeup                | 96               | 7                              |
|                        | 0x4832 0000            | L4 wakeup                | 97               | 7                              |
|                        | 0x4834 0000            | L4 wakeup                | 102              | 7                              |
| Reserved               | 0x4834 1000            | Reserved                 |                  |                                |

**Table 9-114. Region Allocation for L4-Per Interconnect**

| Device Name                              | Start Address<br>(hex) | Description             | Region Number | Default<br>Protection Group |
|------------------------------------------|------------------------|-------------------------|---------------|-----------------------------|
| L4-Per configuration                     | 0x4900 0000            | Address protection (AP) | 0             | 0                           |
|                                          | 0x4900 0800            | Initiator port (IP)     | 1             | 7                           |
|                                          | 0x4900 1000            | Link agent (LA)         | 2             | 7                           |
| Reserved                                 | 0x4900 2000            | Reserved                |               |                             |
| UART3<br>(Infrared)                      | 0x4902 0000            | Module                  | 3             | 7                           |
|                                          | 0x4902 1000            | L4 interconnect         | 4             | 7                           |
| McBSP2<br>(Audio for codec)              | 0x4902 2000            | Module                  | 5             | 7                           |
|                                          | 0x4902 3000            | L4 interconnect         | 6             | 7                           |
| McBSP3<br>(Bluetooth® voice data)        | 0x4902 4000            | Module                  | 7             | 7                           |
|                                          | 0x4902 5000            | L4 interconnect         | 8             | 7                           |
| McBSP4 (digital base<br>band voice data) | 0x4902 6000            | Module                  | 9             | 7                           |
|                                          | 0x4902 7000            | L4 interconnect         | 10            | 7                           |
| McBSP2 (Sidetone)                        | 0x4902 8000            | Module                  | 39            | 7                           |
|                                          | 0x4902 9000            | L4 interconnect         | 40            | 7                           |
| McBSP3 (Sidetone)                        | 0x4902 A000            | Module                  | 41            | 7                           |
|                                          | 0x4902 B000            | L4 interconnect         | 42            | 7                           |
| Reserved                                 | 0x4902 C000            | Reserved                |               |                             |
| WDTIMER3                                 | 0x4903 0000            | Module                  | 11            | 7                           |
|                                          | 0x4903 1000            | L4 interconnect         | 12            | 7                           |
| GPTIMER2                                 | 0x4903 2000            | Module                  | 13            | 7                           |
|                                          | 0x4903 3000            | L4 interconnect         | 14            | 7                           |
| GPTIMER3                                 | 0x4903 4000            | Module                  | 15            | 7                           |
|                                          | 0x4903 5000            | L4 interconnect         | 16            | 7                           |
| GPTIMER4                                 | 0x4903 6000            | Module                  | 17            | 7                           |
|                                          | 0x4903 7000            | L4 interconnect         | 18            | 7                           |
| GPTIMER5                                 | 0x4903 8000            | Module                  | 19            | 7                           |
|                                          | 0x4903 9000            | L4 interconnect         | 20            | 7                           |
| GPTIMER6                                 | 0x4903 A000            | Module                  | 21            | 7                           |
|                                          | 0x4903 B000            | L4 interconnect         | 22            | 7                           |

**Table 9-114. Region Allocation for L4-Per Interconnect (continued)**

| Device Name | Start Address (hex) | Description     | Region Number | Default Protection Group |
|-------------|---------------------|-----------------|---------------|--------------------------|
| GPTIMER7    | 0x4903 C000         | Module          | 23            | 7                        |
|             | 0x4903 D000         | L4 interconnect | 24            | 7                        |
| GPTIMER8    | 0x4903 E000         | Module          | 25            | 7                        |
|             | 0x4903 F000         | L4 interconnect | 26            | 7                        |
| GPTIMER9    | 0x4904 0000         | Module          | 27            | 7                        |
|             | 0x4904 1000         | L4 interconnect | 28            | 7                        |
| UART4       | 0x4904 2000         | Module          | 29            | 7                        |
|             | 0x4904 3000         | L4 interconnect | 30            | 7                        |
| Reserved    | 0x4904 4000         |                 | Reserved      |                          |
| GPIO2       | 0x4905 0000         | Module          | 31            | 7                        |
|             | 0x4905 1000         | L4 interconnect | 32            | 7                        |
| GPIO3       | 0x4905 2000         | Module          | 33            | 7                        |
|             | 0x4905 3000         | L4 interconnect | 34            | 7                        |
| GPIO4       | 0x4905 4000         | Module          | 35            | 7                        |
|             | 0x4905 5000         | L4 interconnect | 36            | 7                        |
| GPIO5       | 0x4905 6000         | Module          | 37            | 7                        |
|             | 0x4905 7000         | L4 interconnect | 38            | 7                        |
| GPIO6       | 0x4905 8000         | Module          | 39            | 7                        |
|             | 0x4905 9000         | L4 interconnect | 40            | 7                        |
| Reserved    | 0x4905 A000         |                 | Reserved      |                          |

**Table 9-115. Region Allocation for L4-Emu Interconnect**

| Device Name                          | Start Address (hex) | Description                 | Region Number | Default Protection Group |
|--------------------------------------|---------------------|-----------------------------|---------------|--------------------------|
| Reserved                             | 0x5400 0000         |                             | Reserved      |                          |
| TEST-Chip-level TAP                  | 0x5400 4000         | Module                      | 1             | 5                        |
|                                      | 0x5400 5000         | L4 interconnect             | 2             | 5                        |
| L4-Emu configuration                 | 0x5400 6000         | Address protection (AP)     | 3             | 0                        |
|                                      | 0x5400 6800         | Initiator port (IP) L4-Core | 4             | 5                        |
|                                      | 0x5400 7000         | Link agent (LA)             | 5             | 5                        |
|                                      | 0x5400 8000         | Initiator port (IP) DAP     | 6             | 5                        |
| Reserved                             | 0x5400 8800         |                             | Reserved      |                          |
| MPU SS (emulation, trace, and debug) | 0x5401 0000         | Module                      | 16            | 3                        |
|                                      | 0x5401 8400         | L4 interconnect             | 7             | 3                        |
| TPIU                                 | 0x5401 9000         | Module                      | 8             | 3                        |
|                                      | 0x5401 A000         | L4 interconnect             | 9             | 3                        |
| ETB                                  | 0x5401 B000         | Module                      | 10            | 3                        |
|                                      | 0x5401 C000         | L4 interconnect             | 11            | 3                        |
| DAP                                  | 0x5401 D000         | Module                      | 12            | 3                        |
|                                      | 0x5401 E000         | L4 interconnect             | 13            | 3                        |
| SDTI                                 | 0x5401 F000         | L4 interconnect             | 15            | 5                        |
|                                      | 0x5402 0000         |                             | Reserved      |                          |
|                                      | 0x5450 0000         | SDTI module (configuration) | 14            | 5                        |
|                                      | 0x5451 0000         |                             | Reserved      |                          |
|                                      | 0x5460 0000         | SDTI module (window)        | 0             | 5                        |
| Reserved                             | 0x5470 0000         |                             | Reserved      |                          |

**Table 9-115. Region Allocation for L4-Emu Interconnect (continued)**

| Device Name                                                                          | Start Address<br>(hex) | Description                 | Region Number | Default<br>Protection<br>Group |
|--------------------------------------------------------------------------------------|------------------------|-----------------------------|---------------|--------------------------------|
| Power and reset manager<br>• Power manager<br>• Reset manager<br>(WKUP power domain) | 0x5470 6000            | Module region A             | 17            | 5                              |
|                                                                                      | 0x5470 8000            | Module region B             | 18            | 5                              |
|                                                                                      | 0x5470 8800            | Reserved                    | 20            | 5                              |
|                                                                                      | 0x5470 9000            | L4 interconnect             | 21            | 5                              |
| Reserved                                                                             | 0x5470 A000            | Reserved                    |               |                                |
| Reserved                                                                             | 0x5470 E000            | Reserved                    |               |                                |
| GPIO1 (WKUP power domain)                                                            | 0x5471 0000            | Module                      |               |                                |
|                                                                                      | 0x5471 1000            | L4 interconnect             |               |                                |
| Reserved                                                                             | 0x5471 2000            | Reserved                    |               |                                |
| WDTIMER2 (WKUP power domain)                                                         | 0x5471 4000            | Module                      |               |                                |
|                                                                                      | 0x5471 5000            | L4 interconnect             |               |                                |
| Reserved                                                                             | 0x5471 6000            | Reserved                    |               |                                |
| GPTIMER1 (WKUP power domain)                                                         | 0x5471 8000            | Module                      |               |                                |
|                                                                                      | 0x5471 9000            | L4 interconnect             |               |                                |
| Reserved                                                                             | 0x5471 A000            | Reserved                    |               |                                |
| 32KTIMER (WKUP power domain)                                                         | 0x5472 0000            | Module                      |               |                                |
|                                                                                      | 0x5472 1000            | L4 interconnect             |               |                                |
| Reserved                                                                             | 0x5472 2000            | Reserved                    |               |                                |
| L4-Wakeup configuration (WKUP power domain)                                          | 0x5472 8000            | Address protection (AP)     |               |                                |
|                                                                                      | 0x5472 8800            | Initiator port (IP) L4-Core |               |                                |
|                                                                                      | 0x5472 9000            | Link agent (LA)             |               |                                |
|                                                                                      | 0x5472 A000            | Initiator port (IP) L4-Emu  |               |                                |
| Reserved                                                                             | 0x5472 A800            | Reserved                    |               |                                |
| L4-Wakeup                                                                            | 0x5473 0000            | L4 interconnect             | 25            | 5                              |

#### 9.3.3.3.4 L4 Firewall Address and Protection Registers Setting

Table 9-116 lists the settings of the AP registers for an L4 interconnect firewall. These values are computed based on the physical implementation of each L4 interconnect.

**Table 9-116. L4 Firewall Register Description Overview**

| Register Type     | Register Name                | Bits | Field             | Description                              |
|-------------------|------------------------------|------|-------------------|------------------------------------------|
| Segment           | L4_AP_SEGMENT_i_L            | 23:0 | Base              | Segment base address                     |
|                   | L4_AP_SEGMENT_i_H            | 4:0  | SIZE              | Segment size equals to 2 power of SIZE   |
| Protection groups | L4_AP_PROT_GROUP_MEMBERS_k_L | 15:0 | CONNID_BIT_VECTOR | See Section 9.3.3.1 for L4ConnID).       |
|                   | L4_AP_PROT_GROUP_ROLES_k_L   | 15:0 | ENABLE            | Refer to Table 9-22 for MReq description |

**Table 9-116. L4 Firewall Register Description Overview (continued)**

| Register Type  | Register Name                    | Bits  | Field                | Description                                                                         |
|----------------|----------------------------------|-------|----------------------|-------------------------------------------------------------------------------------|
| Region setting | <a href="#">L4_AP_REGION_I_L</a> | 23:0  | BASE                 | Define the base address of region in respect to its respective segment base address |
|                | <a href="#">L4_AP_REGION_I_H</a> | 27:24 | SEGMENT_ID           | Segment ID number of the region                                                     |
|                |                                  | 22:20 | PROT_GROUP_ID        | The protection group attached to the region                                         |
|                |                                  | 19:17 | BYTE_DATA_WIDTH_EX_P | Determine the number of bytes in an access                                          |
|                |                                  | 5:1   | SIZE                 | Size of the region equals to 2 power of SIZE                                        |
|                |                                  | 0     | ENABLE               | Enable the region protection                                                        |

### 9.3.3.4 Error Handling

#### 9.3.3.4.1 Overview

The L4 interconnect provides mechanisms for handling either internally detected errors or errors reported by modules attached to the L4 target ports. Hardware support facilitates logging errors and cleaning up the state to allow error recovery software to treat the error.

As an L3 target, the L4 interconnect reports errors to the L3 interconnect in-band whenever possible. In-band error reporting is the default and recommended configuration. It is assumed that INBAND\_ERROR REP bit [L4\\_IA\\_AGENT\\_CONTROL\\_L\[27\]](#) is set to 1.

---

**NOTE:** *L4\_IA* denotes which interconnect is considered: L4-Core, L4-Per, L4-Emu, or L4-Wakeup.  
*L4\_TA* denotes the module name, such as UART1, McBSP1, etc.

---

The L4 interconnects handle three types of errors:

- No target core found or address hole
- Request protection violation
- Failure of the target to service a request before a time-out expires

#### 9.3.3.4.2 Error Logging

##### 9.3.3.4.2.1 No Target Core Found/Address Hole

This error indicates that a request was addressed to a hole in the L4 address map.

When this occurs, an in-band error response is returned to the L3 level.

The error is also logged into the INBAND\_ERROR bit [L4\\_IA\\_AGENT\\_STATUS\\_L\[27\]](#).

Additionally, an address hole error code is logged into the CODE field [L4\\_IA\\_ERROR\\_LOG\\_L\[25:24\]](#).

The L4\_IA\_ERROR\_LOG register also includes MULTI bit [L4\\_IA\\_ERROR\\_LOG\\_L\[31\]](#), which is asserted when multiple errors are detected. In this case, the error code corresponds to the first error that occurs.

##### 9.3.3.4.2.2 Protection Violation

This error indicates that an initiator has accessed a restricted region. This error is reported using an in-band error. It is written to the INBAND\_ERROR field. A protection violation error code is also saved in the CODE field [L4\\_IA\\_ERROR\\_LOG\\_L\[25:24\]](#).

The protection violation is also logged in the CONTROL.CONTROL\_PROT\_ERR\_STATUS [7] register of the system control module.

**NOTE:** There is no specific error signal for the protection violation that goes out from the L4 interconnects. The out-band error that goes to the system control module indicates a protection violation, but it also indicates normal interconnect errors.

#### 9.3.3.4.2.3 Time-Out

This section gives information about all modules and features in the high-tier device. To flag interconnect response being blocked, the time-out of target agents attached to unavailable modules can be enabled with the lowest setting.

A time-out mechanism can be enabled on a per-target basis in the [L4\\_TA\\_AGENT\\_CONTROL\\_L](#) register. If the mechanism is enabled for a TA, and commands are not accepted or responses are not returned within the expected delay, the L4 interconnect generates an error event.

The error is logged in the target agent REQ\_TIMEOUT bit [L4\\_TA\\_AGENT\\_STATUS\\_L\[8\]](#). The affected TA enters an error state that causes it to send error responses to any new request targeted at it. To recover from this state, the TA must be reset by system software. The time-out is counted starting from the moment a command is presented to the target, regardless of how the target responds to the command.

The L4 interconnect implements a centralized time-base circuit that broadcasts a set of four periodic pulse signals to all connected TAs. These four signals are referred to as 1X-time base, 4X-time base, 16X-time base, and 64X-time base.

The time-base circuit offers four possible sets of time-base signals. Selection is done by programming TIMEOUT\_BASE field [L4\\_LA\\_NETWORK\\_CONTROL\\_L\[10:8\]](#). [Table 9-117](#) lists the values in the number of L4 clock cycles.

**Table 9-117. L4 Time-Out Link and TA Programming**

| TIMEOUT_BASE[2:0] | REQ_TIMEOUT[2:0]                       |      |       |       |        |
|-------------------|----------------------------------------|------|-------|-------|--------|
|                   | 0                                      | 1    | 2     | 3     | 4      |
| 0                 | All L4 time-out features are disabled. |      |       |       |        |
| 1                 | Locally disabled                       | 64   | 256   | 1024  | 4096   |
| 2                 |                                        | 256  | 1024  | 4096  | 16384  |
| 3                 |                                        | 1024 | 4096  | 16384 | 65536  |
| 4                 |                                        | 4096 | 16384 | 65536 | 262144 |

The reset value is 0x4, resulting in the longest possible time-out.

The selected time-base signals are available at any TA. Each TA can be programmed to refer to one of these four time-base signals, by using REQ\_TIMEOUT field [L4\\_TA\\_AGENT\\_CONTROL\\_L\[10:8\]](#) (see [Table 9-118](#)).

**Table 9-118. L4 Time-Out TA Programming**

| REQ_TIMEOUT | Target Agent Time-Out Reference |
|-------------|---------------------------------|
| 0           | Time-out locally disabled       |
| 1           | 1X-base cycle                   |
| 2           | 4X-base cycle                   |
| 3           | 16X-base cycle                  |
| 4           | 64X-base cycle                  |

A time-out condition is detected when the command acceptance or the response is not received after a delay of between one and three time-base periods.

Example:

- L4 frequency = 100 MHz
- TIMEOUT\_BASE = 4 in the [L4\\_LA\\_NETWORK\\_CONTROL\\_L](#) register

- REQ\_TIMEOUT = 2 in the [L4\\_TA\\_AGENT\\_CONTROL\\_L](#) for target agent A
- REQ\_TIMEOUT = 4 in the [L4\\_TA\\_AGENT\\_CONTROL\\_L](#) for target agent B

At agent A, the time-base unit is 16384 cycles. A time-out is issued when a request to the attached module is not accepted or no response is sent after a delay of 164 µs to 492 µs.

At agent B, the time-base unit is 262,144 cycles. A time-out is issued when a request to the attached module is not accepted or no response is sent after a delay of 2.6 ms to 7.8 ms.

On detection of a time-out condition, the agent automatically generates an error response to the inter\_IA, which is forwarded to the L3. The agent also logs the time-out to REQ\_TIMEOUT bit [L4\\_TA\\_AGENT\\_STATUS\\_L\[8\]](#).

After the time-out has been detected and logged, the behavior of the attached module is ignored. A new request targeting the module arriving at the timed out TA receives an error response. If the request is addressed to the agent internal registers, it is processed normally.

To recover from a time-out error, the software is assumed to reset first the faulty module by using its internal soft reset bit, and then the TA by using OCP\_RESET bit [L4\\_TA\\_AGENT\\_CONTROL\\_L\[0\]](#).

#### 9.3.3.4.3 TA Software Reset

Writing 1 to OCP\_RESET bit [L4\\_TA\\_AGENT\\_CONTROL\\_L\[0\]](#) initiates the software reset period. The software reset must be asserted for at least 16 cycles of the target module OCP clock, which can be a divided clock with respect to the L4 clock.

During the software reset period the following occur:

- Requests sent to the target module receive error responses. Therefore, if the faulty request is part of a DMA transfer, it is necessary to stop the DMA to avoid getting unwanted errors.
- Requests sent to the TA register block are processed as usual.
- The [L4\\_TA\\_AGENT\\_STATUS\\_L\[8\]](#) REQ\_TIMEOUT status bit is cleared.

Writing 0 to the [L4\\_TA\\_AGENT\\_CONTROL\\_L\[0\]](#) OCP\_RESET bit terminates the software reset period.

The attached module must then be reset to complete the recovery.

#### 9.3.3.4.4 Error Reporting

[Figure 9-17](#) illustrates the error-reporting scheme used in the L4\_Core, L4\_Per, and L4\_EMU interconnects.

- Timeout error generation is enabled at each TA.
- Timeout error and target in-band errors are only reported in-band to the L3 initiator.
- Protection violations are reported out-of-band. Error steering is used to distinguish between application or debug errors.

**Figure 9-17. L4 Error Reporting**


intc-025

### 9.3.4 L4 Interconnect Programming Guide

#### 9.3.4.1 L4 Interconnect Low-Level Programming Models

This section describes the low-level hardware programming sequences for configuring and using the L4 interconnect module.

##### 9.3.4.1.1 Global Initialization

###### 9.3.4.1.1.1 Surrounding Modules Global Initialization

This section identifies the requirements for initializing the surrounding modules when the L4 interconnect module is to be used for the first time after a device reset. This initialization of surrounding modules is based on the integration and environment of the L4 interconnect. For more information, see *L4 Interconnect Integration*.

**Table 9-119. Global Initialization of Surrounding Modules**

| Surrounding Modules | Comments                                                                                                                                         |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| PRCM                | For more information about the configuration of the module, see <a href="#">Chapter 3, Power, Reset, and Clock Management</a> .                  |
| Control module      | For more information about the configuration of the module, see <a href="#">Control Module</a> .                                                 |
| MPU INT             | The MPU INT must be configured to enable the interrupts from the L4 interconnect module. See <a href="#">Chapter 12, Interrupt Controllers</a> . |
| sDMA                | For more information about the configuration of the sDMA, see <a href="#">sDMA</a> .                                                             |

**Table 9-119. Global Initialization of Surrounding Modules (continued)**

| Surrounding Modules | Comments                                                                               |
|---------------------|----------------------------------------------------------------------------------------|
| L3 interconnect     | For more information about the interconnect configuration, see , <i>Interconnect</i> . |

### 9.3.4.1.2 Operational Modes Configuration

#### 9.3.4.1.2.1 L4 Interconnect Error Analysis Mode

##### 9.3.4.1.2.1.1 Main Sequence: L4 Interconnect Error Analysis Mode

The information required to analyze an error source is logged in several registers. The number of registers to access depends on the error source.

[Figure 9-18](#) and [Figure 9-19](#) show the software sequence required in most cases.

[Table 9-120](#) and [Table 9-121](#) show the main sequence for error analysis mode and its subprocess call summary, respectively.

**Figure 9-18. Typical Error Analysis Sequence**


icnt-026

**Figure 9-19. Typical Error Analysis Sequence**

icnt-027

**Table 9-120. Main Sequence – Error Analysis Mode**

| Register Name         | Register Name                       | Register Name                             |
|-----------------------|-------------------------------------|-------------------------------------------|
| L4_IA_ERROR_LOG_L     | L4_IA_ERROR_LOG_L                   | L4_IA_AGENT_STATUS_L                      |
| L4_IA_AGENT_CONTROL_L | CONTROL.CONTROL_PROT_ERR_STA<br>TUS | CONTROL.CONTROL_PROT_ERR_STA<br>TUS_DEBUG |
| L4_TA_AGENT_STATUS_L  |                                     |                                           |

**Table 9-121. Subprocess Call Summary for Main Sequence – Error Analysis Mode**

| Subprocess                                                               | Cross-Reference                                                                                                               |
|--------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| L3 interconnect error analysis                                           | <a href="#">Section 9.2.3.4, Error Handling</a>                                                                               |
| L4 interconnect protection violation error identification                | <a href="#">Section 9.3.4.1.2.1.2, Subsequence: L4 Interconnect Protection<br/>Violation Error Identification</a>             |
| L4 interconnect unsupported command/address hole error<br>identification | <a href="#">Section 9.3.4.1.2.1.3, Subsequence: L4 Interconnect<br/>Unsupported Command/Address Hole Error Identification</a> |
| L4 interconnect reset TA and module                                      | <a href="#">Section 9.3.4.1.2.1.4, Subsequence: L4 Interconnect Reset TA<br/>and Module</a>                                   |

#### **9.3.4.1.2.1.2 Subsequence: L4 Interconnect Protection Violation Error Identification**

This procedure describes the protection violation error identification (see [Table 9-122](#)).

**Table 9-122. Protection Violation Error Identification**

| Step                                        | Register/Bit Field/Programming Model                         | Value |
|---------------------------------------------|--------------------------------------------------------------|-------|
| Read multiple errors detection.             | <a href="#">L4_IA_ERROR_LOG_L[31]</a> MULTI                  |       |
| Read error code.                            | <a href="#">L4_IA_ERROR_LOG_L[25:24]</a> CODE                |       |
| <b>IF:</b> Is it an inband error?           | <a href="#">L4_IA_AGENT_STATUS_L[27]</a><br>INBAND_ERROR REP | =0x1  |
| Read status bits.                           | CONTROL.CONTROL_SEC_ERR_STATUS[17:16]                        |       |
| Write 1 to clear status bits.               | CONTROL.CONTROL_SEC_ERR_STATUS[17:16]                        | 0x3   |
| Write 1 to clear IA status bit.             | <a href="#">L4_IA_AGENT_STATUS_L[27]</a><br>INBAND_ERROR REP | 0x1   |
| <b>ELSE</b>                                 |                                                              |       |
| Read status bits.                           | CONTROL.CONTROL_PROT_ERR_STATUS_DE<br>BUG[17:16]             |       |
| Write 1 to clear status bits.               | CONTROL.CONTROL_PROT_ERR_STATUS_DE<br>BUG[17:16]             | 0x3   |
| <b>ENDIF</b>                                |                                                              |       |
| Write 1 to clear multiple errors detection. | <a href="#">L4_IA_ERROR_LOG_L[31]</a> MULTI                  | 0x1   |
| Write 1 to clear MError status.             | <a href="#">L4_IA_AGENT_STATUS_L[24]</a> MERROR REP          | 0x1   |

#### **9.3.4.1.2.1.3 Subsequence: L4 Interconnect Unsupported Command/Address Hole Error Identification**

This procedure describes the identification of unsupported command/address hole error (see [Table 9-123](#)).

**Table 9-123. Unsupported Command/Address Hole Error Identification**

| Step                                        | Register/Bit Field/Programming Model                         | Value |
|---------------------------------------------|--------------------------------------------------------------|-------|
| Read multiple errors detection.             | <a href="#">L4_IA_ERROR_LOG_L[31]</a> MULTI                  |       |
| Read initiator error code.                  | <a href="#">L4_IA_ERROR_LOG_L[25:24]</a> CODE                |       |
| Write 1 to clear multiple errors detection. | <a href="#">L4_IA_ERROR_LOG_L[31]</a> MULTI                  | 0x1   |
| Write 1 to clear inband error status.       | <a href="#">L4_IA_AGENT_STATUS_L[27]</a><br>INBAND_ERROR REP | 0x1   |

#### **9.3.4.1.2.1.4 Subsequence: L4 Interconnect Reset TA and Module**

This procedure resets the TA and module (see [Table 9-124](#)).

**Table 9-124. Reset TA and Module**

| Step                                        | Register/Bit Field/Programming Model                       | Value |
|---------------------------------------------|------------------------------------------------------------|-------|
| Reset TA.                                   | <a href="#">L4_TA_AGENT_CONTROL_L[0]</a> OCP_RESET         | 0x1   |
| Wait until target module clock = 16 cycles. |                                                            |       |
| Write 0 to clear TA time-out status.        | <a href="#">L4_TA_AGENT_CONTROL_L[10:8]</a><br>REQ_TIMEOUT | 0x0   |
| Write 0 to clear TA reset.                  | <a href="#">L4_TA_AGENT_CONTROL_L[0]</a> OCP_RESET         | 0x0   |
| Reset the attached module. <sup>(1)</sup>   |                                                            |       |

<sup>(1)</sup> For more information, see the respective module chapter.

### 9.3.4.1.2.2 L4 Interconnect Time-Out Configuration Mode

#### 9.3.4.1.2.2.1 Main Sequence: L4 Interconnect Time-Out Configuration Mode

This procedure describes the time-out configuration sequence (see [Table 9-125](#)).

**Table 9-125. Time-Out Configuration**

| Step                                           | Register/Bit Field/Programming Model                          | Value |
|------------------------------------------------|---------------------------------------------------------------|-------|
| Disable time-out.                              | <a href="#">L4_LA_NETWORK_CONTROL_L[10:8]</a><br>TIMEOUT_BASE | 0x0   |
| Clear TA time-out error status. <sup>(1)</sup> | <a href="#">L4_TA_AGENT_STATUS_L[8]</a> REQ_TIMEOUT           | 0x1   |
| Set time-out at TA level. <sup>(1)</sup>       | <a href="#">L4_TA_AGENT_CONTROL_L[10:8]</a><br>REQ_TIMEOUT    | xxx   |
| Set time-out base.                             | <a href="#">L4_LA_NETWORK_CONTROL_L[10:8]</a><br>TIMEOUT_BASE | xxx   |

<sup>(1)</sup> Must be done for each TA

### 9.3.4.1.2.3 L4 Interconnect Firewall Configuration Mode

#### 9.3.4.1.2.3.1 Main Sequence: L4 Interconnect Firewall Configuration Mode

This procedure describes the firewall configuration sequence (see [Table 9-126](#)).

**Table 9-126. Firewall Configuration**

| Step                                                           | Register/Bit Field/Programming Model                                    | Value |
|----------------------------------------------------------------|-------------------------------------------------------------------------|-------|
| Define the members of protection group k. <sup>(1)</sup>       | <a href="#">L4_AP_PROT_GROUP_MEMBERS_K_L[15:0]</a><br>CONNID_BIT_VECTOR | xxx   |
| Define the access type of a protection group k. <sup>(1)</sup> | <a href="#">L4_AP_PROT_GROUP_ROLES_K_L[15:0]</a><br>ENABLE              | xx    |
| Set region affiliation to protection group. <sup>(2)</sup>     | <a href="#">L4_AP_REGION_L_L[22:20]</a> PROT_GROUP_ID                   | xxx   |

<sup>(1)</sup> Must be done for each protection group  
<sup>(2)</sup> Must be done for each region

## 9.3.5 L4 Interconnects Register Manual

A summary of the hardware interface for the L4-Core, L4-Per, L4-Emu, and L4-Wkup interconnects is given in [Table 9-127](#) through [Table 9-130](#), respectively. Each module instance in the design is shown with the module register map and bit definitions for each bit field.

**Table 9-127. L4-Core Instance Summary**

| Module Name         | Base Address | Size |
|---------------------|--------------|------|
| CORE_TA_CONTROL     | 0x4800 3000  | 4KB  |
| CORE_TA_CM          | 0x4800 7000  | 4KB  |
| CORE_AP             | 0x4804 0000  | 2KB  |
| CORE_IA             | 0x4804 0800  | 2KB  |
| CORE_LA             | 0x4804 1000  | 4KB  |
| CORE_TA_DISPLAY_SS  | 0x4805 1000  | 4KB  |
| CORE_TA_SDMA        | 0x4805 7000  | 4KB  |
| CORE_TA_I2C3        | 0x4806 1000  | 4KB  |
| CORE_TA_USB_HS_TLL  | 0x4806 3000  | 4KB  |
| CORE_TA_USB_HS_Host | 0x4806 5000  | 4KB  |
| CORE_TA_UART1       | 0x4806 B000  | 4KB  |
| CORE_TA_UART2       | 0x4806 D000  | 4KB  |

**Table 9-127. L4-Core Instance Summary (continued)**

| <b>Module Name</b> | <b>Base Address</b> | <b>Size</b> |
|--------------------|---------------------|-------------|
| CORE_TA_I2C1       | 0x4807 1000         | 4KB         |
| CORE_TA_I2C2       | 0x4807 3000         | 4KB         |
| CORE_TA_MCBSP1     | 0x4807 5000         | 4KB         |
| CORE_TA_GPTIMER10  | 0x4808 7000         | 4KB         |
| CORE_TA_GPTIMER11  | 0x4808 9000         | 4KB         |
| CORE_TA_MAILBOX    | 0x4809 5000         | 4KB         |
| CORE_TA_MCBSP5     | 0x4809 7000         | 4KB         |
| CORE_TA_MCSPI1     | 0x4809 9000         | 4KB         |
| CORE_TA_MCSPI2     | 0x4809 B000         | 4KB         |
| CORE_TA_MMCHS1     | 0x4809 D000         | 4KB         |
| CORE_TA_USB_HS_OTG | 0x480A C000         | 4KB         |
| CORE_TA_MMCHS3     | 0x480A E000         | 4KB         |
| CORE_TA_HDQ1W      | 0x480B 3000         | 4KB         |
| CORE_TA_MMCHS2     | 0x480B 5000         | 4KB         |
| CORE_TA_ICR        | 0x480B 7000         | 4KB         |
| CORE_TA_MCSPI3     | 0x480B 9000         | 4KB         |
| CORE_TA_MCSPI4     | 0x480B B000         | 4KB         |
| CORE_TA_CAMERA     | 0x480C 0000         | 4KB         |
| CORE_TA_INTH       | 0x480C 8000         | 4KB         |
| CORE_TA_SR1        | 0x480C A000         | 4KB         |
| CORE_TA_SR2        | 0x480C C000         | 4KB         |
| CORE_TA_ICR_MODEM  | 0x480C E000         | 4KB         |
| CORE_TA_WKUP       | 0x4834 0000         | 4KB         |

**Table 9-128. L4-Per Instance Summary**

| <b>Module Name</b>     | <b>Base Address</b> | <b>Size</b> |
|------------------------|---------------------|-------------|
| PER_AP                 | 0x4900 0000         | 2K bytes    |
| PER_IA                 | 0x4900 0800         | 2K bytes    |
| PER_LA                 | 0x4900 1000         | 4K bytes    |
| PER_TA_UART3           | 0x4902 1000         | 512 bytes   |
| PER_TA_MCBSP2          | 0x4902 3000         | 1K byte     |
| PER_TA_MCBSP3          | 0x4902 5000         | 1K byte     |
| PER_TA_MCBSP4          | 0x4902 7000         | 1K byte     |
| PER_TA_MCBSP2_SIDETONE | 0x4902 9000         | 4K bytes    |
| PER_TA_MCBSP3_SIDETONE | 0x4902 B000         | 4K bytes    |
| PER_TA_WDTIMER3        | 0x4903 1000         | 2K bytes    |
| PER_TA_GPTIMER2        | 0x4903 3000         | 1K byte     |
| PER_TA_GPTIMER3        | 0x4903 5000         | 1K byte     |
| PER_TA_GPTIMER4        | 0x4903 7000         | 1K byte     |
| PER_TA_GPTIMER5        | 0x4903 9000         | 1K byte     |
| PER_TA_GPTIMER6        | 0x4903 B000         | 1K byte     |
| PER_TA_GPTIMER7        | 0x4903 D000         | 1K byte     |
| PER_TA_GPTIMER8        | 0x4903 F000         | 1K byte     |
| PER_TA_GPTIMER9        | 0x4904 1000         | 1K byte     |
| PER_TA_UART4           | 0x4904 3000         | 4K byte     |
| PER_TA_GPIO2           | 0x4905 1000         | 1K byte     |

**Table 9-128. L4-Per Instance Summary (continued)**

| Module Name  | Base Address | Size    |
|--------------|--------------|---------|
| PER_TA_GPIO3 | 0x4905 3000  | 1K byte |
| PER_TA_GPIO4 | 0x4905 5000  | 1K byte |
| PER_TA_GPIO5 | 0x4905 7000  | 1K byte |
| PER_TA_GPIO6 | 0x4905 9000  | 1K byte |

**Table 9-129. L4-Emu Instance Summary**

| Module Name     | Base Address | Size     |
|-----------------|--------------|----------|
| EMU_TA_TEST_TAP | 0x5400 5000  | 4K bytes |
| EMU_AP          | 0x5400 6000  | 2K bytes |
| EMU_IA_L3       | 0x5400 6800  | 2K bytes |
| EMU_LA          | 0x5400 7000  | 4K bytes |
| EMU_IA_DAP      | 0x5400 8000  | 2K bytes |
| EMU_TA_MPU      | 0x5401 8000  | 4K bytes |
| EMU_TA_TPIU     | 0x5401 A000  | 4K bytes |
| EMU_TA_ETB      | 0x5401 C000  | 4K bytes |
| EMU_TA_DAP      | 0x5401 E000  | 4K bytes |
| EMU_TA_SDTI     | 0x5401 F000  | 4K bytes |
| EMU_TA_L4WKUP   | 0x5473 0000  | 4K bytes |

**Table 9-130. L4-WKUP Instance Summary**

| Module Name          | Base Address | Size     |
|----------------------|--------------|----------|
| WKUP_TA_PRM          | 0x4830 9000  | 4K bytes |
| WKUP_TA_GPIO1        | 0x4831 1000  | 4K bytes |
| WKUP_TA_WDTIMER2     | 0x4831 5000  | 4K bytes |
| WKUP_TA_GPTIMER1     | 0x4831 9000  | 4K bytes |
| WKUP_TA_SYNCTIMER32K | 0x4832 1000  | 4K bytes |
| WKUP_AP              | 0x4832 8000  | 2K bytes |
| WKUP_IA_CORE         | 0x4832 8800  | 2K bytes |
| WKUP_LA              | 0x4832 9000  | 4K bytes |
| WKUP_IA_EMU          | 0x4832 A000  | 2K bytes |

### 9.3.5.1 L4 Initiator Agent (L4 IA)

This section provides information on the L4 IA module. Each of the registers within the module instance is described separately in [Table 9-131](#) to [Table 9-132](#).

The initiator OCP interface register block (IA) consists of the status, control, and error log registers that can be used to configure the interface of an initiator OCP. There can be only one register block for each initiator OCP interface.

**Table 9-131. L4 IA Register Summary (1)**

| Register Name     | Type | Register Width (Bits) | CORE_IA Physical Address | PER_IA Physical Address | EMU_IA_L3 Physical Address |
|-------------------|------|-----------------------|--------------------------|-------------------------|----------------------------|
| L4_IA_COMPONENT_L | R    | 32                    | 0x4804 0800              | 0x4900 0800             | 0x5400 6800                |
| L4_IA_COMPONENT_H | R    | 32                    | 0x4804 0804              | 0x4900 0804             | 0x5400 6804                |
| L4_IA_CORE_L      | RW   | 32                    | 0x4804 0818              | 0x4900 0818             | 0x5400 6818                |
| L4_IA_CORE_H      | RW   | 32                    | 0x4804 081C              | 0x4900 081C             | 0x5400 681C                |

**Table 9-131. L4 IA Register Summary (1) (continued)**

| Register Name         | Type | Register Width (Bits) | CORE_IA Physical Address | PER_IA Physical Address | EMU_IA_L3 Physical Address |
|-----------------------|------|-----------------------|--------------------------|-------------------------|----------------------------|
| L4_IA_AGENT_CONTROL_L | RW   | 32                    | 0x4804 0820              | 0x4900 0820             | 0x5400 6820                |
| L4_IA_AGENT_CONTROL_H | RW   | 32                    | 0x4804 0824              | 0x4900 0824             | 0x5400 6824                |
| L4_IA_AGENT_STATUS_L  | RW   | 32                    | 0x4804 0828              | 0x4900 0828             | 0x5400 6828                |
| L4_IA_AGENT_STATUS_H  | RW   | 32                    | 0x4804 082C              | 0x4900 082C             | 0x5400 682C                |
| L4_IA_ERROR_LOG_L     | RW   | 32                    | 0x4804 0858              | 0x4900 0858             | 0x5400 6858                |
| L4_IA_ERROR_LOG_H     | RW   | 32                    | 0x4804 085C              | 0x4900 085C             | 0x5400 685C                |

**Table 9-132. L4 IA Register Summary (2)**

| Register Name         | Type | Register Width (Bits) | EMU_IA_DAP Physical Address | WKUP_IA_CORE Physical Address | WKUP_IA_EMU Physical Address |
|-----------------------|------|-----------------------|-----------------------------|-------------------------------|------------------------------|
| L4_IA_COMPONENT_L     | R    | 32                    | 0x5400 8000                 | 0x4832 8800                   | 0x4832 A000                  |
| L4_IA_COMPONENT_H     | R    | 32                    | 0x5400 8004                 | 0x4832 8804                   | 0x4832 A004                  |
| L4_IA_CORE_L          | RW   | 32                    | 0x5400 8018                 | 0x4832 8818                   | 0x4832 A018                  |
| L4_IA_CORE_H          | RW   | 32                    | 0x5400 801C                 | 0x4832 881C                   | 0x4832 A01C                  |
| L4_IA_AGENT_CONTROL_L | RW   | 32                    | 0x5400 8020                 | 0x4832 8820                   | 0x4832 A020                  |
| L4_IA_AGENT_CONTROL_H | RW   | 32                    | 0x5400 8024                 | 0x4832 8824                   | 0x4832 A024                  |
| L4_IA_AGENT_STATUS_L  | RW   | 32                    | 0x5400 8028                 | 0x4832 8828                   | 0x4832 A028                  |
| L4_IA_AGENT_STATUS_H  | RW   | 32                    | 0x5400 802C                 | 0x4832 882C                   | 0x4832 A02C                  |
| L4_IA_ERROR_LOG_L     | RW   | 32                    | 0x5400 8058                 | 0x4832 8858                   | 0x4832 A058                  |
| L4_IA_ERROR_LOG_H     | RW   | 32                    | 0x5400 805C                 | 0x4832 885C                   | 0x4832 A05C                  |

### 9.3.5.1.1 L4 Initiator Agent (L4 IA) Registers Description

**Table 9-133. L4\_IA\_COMPONENT\_L**

|                                                                                             |                                                                                                                                                                                                                                       |
|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>                                                                       | 0x000                                                                                                                                                                                                                                 |
| <b>Physical Address</b>                                                                     | See Table 9-131 to Table 9-132                                                                                                                                                                                                        |
| <b>Description</b>                                                                          | COMPONENT register identifies the component to which this register block belongs. The register contains a component code and revision, which are used to identify the hardware of the component. The COMPONENT register is read-only. |
| <b>Type</b>                                                                                 | R                                                                                                                                                                                                                                     |
| 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 |                                                                                                                                                                                                                                       |
| CODE                                                                                        | REV                                                                                                                                                                                                                                   |

| Bits  | Field Name | Description             | Type | Reset                |
|-------|------------|-------------------------|------|----------------------|
| 31:16 | CODE       | Interconnect code       | R    | See <sup>(1)</sup> . |
| 15:0  | REV        | Component revision code | R    | See <sup>(1)</sup> . |

<sup>(1)</sup> TI Internal data

**Table 9-134. Register Call Summary for Register L4\_IA\_COMPONENT\_L**

L4 Interconnects

- L4 Initiator Agent (L4 IA): [0] [1]

**Table 9-135. L4\_IA\_COMPONENT\_H**

|                         |                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x004                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| <b>Physical Address</b> | See <a href="#">Table 9-131</a> to <a href="#">Table 9-132</a>                                                                                                                                                                        |  |  |  |  |  |  |
| <b>Description</b>      | COMPONENT register identifies the component to which this register block belongs. The register contains a component code and revision, which are used to identify the hardware of the component. The COMPONENT register is read-only. |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16                                                                                                                                                                                                               |  |  |  |  |  |  |
| Reserved                |                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| 15 14 13 12 11 10 9 8   | 7 6 5 4 3 2 1 0                                                                                                                                                                                                                       |  |  |  |  |  |  |
| VENDOR_CODE             |                                                                                                                                                                                                                                       |  |  |  |  |  |  |

| Bits  | Field Name  | Description          | Type | Reset                |
|-------|-------------|----------------------|------|----------------------|
| 31:16 | Reserved    | Reserved             | R    | 0x0000               |
| 15:0  | VENDOR_CODE | Vendor revision code | R    | See <sup>(1)</sup> . |

<sup>(1)</sup> TI Internal data

**Table 9-136. Register Call Summary for Register L4\_IA\_COMPONENT\_H**

## L4 Interconnects

- [L4 Initiator Agent \(L4 IA\): \[0\] \[1\]](#)

**Table 9-137. L4\_IA\_CORE\_L**

|                         |                                                                |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x018                                                          |  |  |  |  |  |  |
| <b>Physical Address</b> | See <a href="#">Table 9-131</a> to <a href="#">Table 9-132</a> |  |  |  |  |  |  |
| <b>Description</b>      | Provide information about the core initiator                   |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                             |  |  |  |  |  |  |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16                                        |  |  |  |  |  |  |
| CORE_CODE               |                                                                |  |  |  |  |  |  |
| 15 14 13 12 11 10 9 8   | 7 6 5 4 3 2 1 0                                                |  |  |  |  |  |  |
| CORE_REV                |                                                                |  |  |  |  |  |  |

| Bits  | Field Name | Description                  | Type | Reset                |
|-------|------------|------------------------------|------|----------------------|
| 31:16 | CORE_CODE  | Interconnect core code       | R    | See <sup>(1)</sup> . |
| 15:0  | CORE_REV   | Component revision code code | R    | See <sup>(1)</sup> . |

<sup>(1)</sup> TI Internal data

**Table 9-138. Register Call Summary for Register L4\_IA\_CORE\_L**

## L4 Interconnects

- [L4 Initiator Agent \(L4 IA\): \[0\] \[1\]](#)

**Table 9-139. L4\_IA\_CORE\_H**

|                         |                                                                |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x01C                                                          |  |  |  |  |  |  |
| <b>Physical Address</b> | See <a href="#">Table 9-131</a> to <a href="#">Table 9-132</a> |  |  |  |  |  |  |
| <b>Description</b>      | Provide information about the core initiator                   |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                             |  |  |  |  |  |  |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16                                        |  |  |  |  |  |  |
| Reserved                |                                                                |  |  |  |  |  |  |
| 15 14 13 12 11 10 9 8   | 7 6 5 4 3 2 1 0                                                |  |  |  |  |  |  |
| VENDOR_CODE             |                                                                |  |  |  |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>        | <b>Type</b> | <b>Reset</b>         |
|-------------|-------------------|---------------------------|-------------|----------------------|
| 31:16       | Reserved          | Reserved                  | R           | 0x0000               |
| 15:0        | VENDOR_CODE       | Vendor revision core code | R           | See <sup>(1)</sup> . |

## (1) TI Internal data

**Table 9-140. Register Call Summary for Register L4\_IA\_CORE\_H**

- ## L4 Interconnects

- L4 Initiator Agent (L4 IA): [0] [1]

**Table 9-141. L4\_IA\_AGENT\_CONTROL\_L**

|                         |                                                                                                                                                                                                                                                  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x020                                                                                                                                                                                                                                            |
| <b>Physical Address</b> | See <a href="#">Table 9-131</a> to <a href="#">Table 9-132</a>                                                                                                                                                                                   |
| <b>Description</b>      | Enable error reporting on an initiator interface. The error reporting mechanism is enabled when the INBAND_ERROR REP bit field is set to 1. The out-of-band OCP MError reporting mechanism is enabled when the MERROR REP bit field is set to 1. |
| <b>Type</b>             | RW                                                                                                                                                                                                                                               |



| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                            | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:28       | Reserved          | Read returns 0.                                                                                               | R           | 0x0          |
| 27          | INBAND_ERROR REP  | Setting this field to 1 reports on in-band errors using the INBAND_ERROR log bit of IA.AGENT_STATUS register. | R           | 1            |
| 26:25       | Reserved          | Read returns 0.                                                                                               | R           | 0x0          |
| 24          | MERROR REP        | Enable MError reporting                                                                                       | R           | 0x0          |
| 23:0        | Reserved          | Read returns 0.                                                                                               | R           | 0x00000000   |

**Table 9-142. Register Call Summary for Register L4\_IA\_AGENT\_CONTROL\_L**

- ## L4 Interconnects

- Overview: [0]
  - Operational Modes Configuration: [1]
  - L4 Initiator Agent (L4 IA): [2] [3]

**Table 9-143. L4\_IA\_AGENT\_CONTROL\_H**

|                         |                                                                |
|-------------------------|----------------------------------------------------------------|
| <b>Address Offset</b>   | 0x024                                                          |
| <b>Physical Address</b> | See <a href="#">Table 9-131</a> to <a href="#">Table 9-132</a> |
| <b>Description</b>      | Enable error reporting on an initiator interface.              |
| <b>Type</b>             | RW                                                             |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 31:0        | Reserved          | Read returns 0.    | R           | 0x0000 0000  |

**Table 9-144. Register Call Summary for Register L4\_IA\_AGENT\_CONTROL\_H**

- L4 Initiator Agent (L4 IA): [0] [1]

**Table 9-145. L4\_IA\_AGENT\_STATUS\_L**

|                         |                                                                                                                                |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x028                                                                                                                          |
| <b>Physical Address</b> | See <a href="#">Table 9-131</a> to <a href="#">Table 9-132</a>                                                                 |
| <b>Description</b>      | Stores status information for an initiator. The INBAND_ERROR and MERROR fields are read/write and are implemented as log bits. |
| <b>Type</b>             | RW                                                                                                                             |

|    |    |    |    |                  |          |    |    |    |            |          |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|------------------|----------|----|----|----|------------|----------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
|    |    |    |    | INBAND_ERROR REP | Reserved |    |    |    | MERROR REP | Reserved |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                          | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------|-------------|--------------|
| 31:28       | Reserved          | Read returns 0.                                             | R           | 0x0          |
| 27          | INBAND_ERROR REP  | 0x0 No In-Band error present.<br>0x1 In-Band error present. | R 1toClr    | 0x0          |
| 26:25       | Reserved          | Read returns 0.                                             | R           | 0x0          |
| 24          | MERROR REP        | 0x0 No MError error present.<br>0x1 MErorr error present.   | R           | 0x0          |
| 23:0        | Reserved          | Read returns 0.                                             | R           | 0x0000000    |

**Table 9-146. Register Call Summary for Register L4\_IA\_AGENT\_STATUS\_L**

L4 Interconnects

- Error Logging: [0]
- Operational Modes Configuration: [1] [2] [3] [4] [5]
- L4 Initiator Agent (L4 IA): [6] [7]

**Table 9-147. L4\_IA\_AGENT\_STATUS\_H**

|                                                                                                |                                                                |
|------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| <b>Address Offset</b>                                                                          | 0x02C                                                          |
| <b>Physical Address</b>                                                                        | See <a href="#">Table 9-131</a> to <a href="#">Table 9-132</a> |
| <b>Description</b>                                                                             | Stores status information for an initiator.                    |
| <b>Type</b>                                                                                    | RW                                                             |
| <br>Reserved |                                                                |

| Bits | Field Name | Description     | Type | Reset       |
|------|------------|-----------------|------|-------------|
| 31:0 | Reserved   | Read returns 0. | R    | 0x0000 0000 |

**Table 9-148. Register Call Summary for Register L4\_IA\_AGENT\_STATUS\_H**

L4 Interconnects

- [L4 Initiator Agent \(L4 IA\): \[0\] \[1\]](#)

**Table 9-149. L4\_IA\_ERROR\_LOG\_L**

|                                                                                                  |                                                                                                                                                                           |
|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>                                                                            | 0x0058                                                                                                                                                                    |
| <b>Physical Address</b>                                                                          | See <a href="#">Table 9-131</a> to <a href="#">Table 9-132</a>                                                                                                            |
| <b>Description</b>                                                                               | Log information about error conditions. The CODE field logs any protection violation or address hole errors detected by the initiator subsystem while decoding a request. |
| <b>Type</b>                                                                                      | RW                                                                                                                                                                        |
| <br>Reserved |                                                                                                                                                                           |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                              | Type | Reset    |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31    | MULTI      | While the CODE field is not zero, the MULTI bit is asserted whenever an additional error is detected. Once set by hardware, the MULTI bit can only be cleared by writing a 1 to it while writing a value other than zero to the CODE field.                                              | RW   | 0        |
| 30:26 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                          | R    | 0x00     |
| 25:24 | CODE       | The error code of an initiator request.<br>0x00: No errors<br>0x01: Reserved<br>0x10: Address hole<br>0x11: Protection violation<br>The CODE field, once set by hardware, can only be cleared by writing a non-zero value to it, in conjunction with writing a 1 to the MULTI bit field. | RW   | 0x0      |
| 23:0  | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                          | R    | 0x000000 |

**Table 9-150. Register Call Summary for Register L4\_IA\_ERROR\_LOG\_L**

L4 Interconnects

- [Error Logging: \[0\] \[1\] \[2\]](#)
- [Operational Modes Configuration: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\]](#)
- [L4 Initiator Agent \(L4 IA\): \[11\] \[12\]](#)

**Table 9-151. L4\_IA\_ERROR\_LOG\_H**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x05C                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                        | See <a href="#">Table 9-131</a> to <a href="#">Table 9-132</a> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Log information about error conditions.                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="29">Reserved</td></tr> </table> |                                                                | 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 | Reserved |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description     | Type | Reset       |
|------|------------|-----------------|------|-------------|
| 31:0 | Reserved   | Read returns 0. | R    | 0x0000 0000 |

**Table 9-152. Register Call Summary for Register L4\_IA\_ERROR\_LOG\_H**

## L4 Interconnects

- [L4 Initiator Agent \(L4 IA\): \[0\] \[1\]](#)

**9.3.5.2 L4 Target Agent (L4 TA)**

This section provides information on the L4 Target agent (TA) register module. Each of the registers within the module instance is described separately in [Table 9-153](#) to [Table 9-177](#).

[Table 9-153](#) to [Table 9-178](#) provide information on the L4 Target Agent having two supplementary registers OCP\_CONTROL and OCP\_STATUS

The TA register block consists of the status and control registers that can be used to configure the interfaces of the targets.

**Table 9-153. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_CONTROL Physical Address |
|-----------------------|------|-----------------------|----------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4800 3000                      |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4800 3004                      |
| L4_TA_CORE_L          | R    | 32                    | 0x4800 3018                      |
| L4_TA_CORE_H          | R    | 32                    | 0x4800 301C                      |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4800 3020                      |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4800 3024                      |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4800 3028                      |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4800 302C                      |

**Table 9-154. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_CM Physical Address | CORE_TA_DISPLAY_SS Physical Address | CORE_TA_SDMA Physical Address |
|-----------------------|------|-----------------------|-----------------------------|-------------------------------------|-------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4802 7000                 | 0x4805 1000                         | 0x4805 7000                   |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4802 7004                 | 0x4805 1004                         | 0x4805 7004                   |
| L4_TA_CORE_L          | R    | 32                    | 0x4802 7018                 | 0x4805 1018                         | 0x4805 7018                   |
| L4_TA_CORE_H          | R    | 32                    | 0x4802 701C                 | 0x4805 101C                         | 0x4805 701C                   |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4802 7020                 | 0x4805 1020                         | 0x4805 7020                   |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4802 7024                 | 0x4805 1024                         | 0x4805 7024                   |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4802 7028                 | 0x4805 1028                         | 0x4805 7028                   |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4802 702C                 | 0x4805 102C                         | 0x4805 702C                   |

**Table 9-155. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_I2C3 Physical Address |
|-----------------------|------|-----------------------|-------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4806 1000                   |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4806 1004                   |
| L4_TA_CORE_L          | R    | 32                    | 0x4806 1018                   |
| L4_TA_CORE_H          | R    | 32                    | 0x4806 101C                   |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4806 1020                   |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4806 1024                   |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4806 1028                   |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4806 102C                   |

**Table 9-156. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_USB_TLL Physical Address | CORE_TA_USB_HS_Host Physical Address | CORE_TA_UART1 Physical Address |
|-----------------------|------|-----------------------|----------------------------------|--------------------------------------|--------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4806 3000                      | 0x4806 5000                          | 0x4806 B000                    |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4806 3004                      | 0x4806 5004                          | 0x4806 B004                    |
| L4_TA_CORE_L          | R    | 32                    | 0x4806 3018                      | 0x4806 5018                          | 0x4806 B018                    |
| L4_TA_CORE_H          | R    | 32                    | 0x4806 301C                      | 0x4806 501C                          | 0x4806 B01C                    |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4806 3020                      | 0x4806 5020                          | 0x4806 B020                    |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4806 3024                      | 0x4806 5024                          | 0x4806 B024                    |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4806 3028                      | 0x4806 5028                          | 0x4806 B028                    |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4806 302C                      | 0x4806 502C                          | 0x4806 B02C                    |

**Table 9-157. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_USB_HS_TLL Physical Address | CORE_TA_USB_HS_HOST Physical Address |
|-----------------------|------|-----------------------|-------------------------------------|--------------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4806 3000                         | 0x4806 5000                          |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4806 3004                         | 0x4806 5004                          |
| L4_TA_CORE_L          | R    | 32                    | 0x4806 3018                         | 0x4806 5018                          |
| L4_TA_CORE_H          | R    | 32                    | 0x4806 301C                         | 0x4806 501C                          |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4806 3020                         | 0x4806 5020                          |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4806 3024                         | 0x4806 5024                          |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4806 3028                         | 0x4806 5028                          |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4806 302C                         | 0x4806 502C                          |

**Table 9-158. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_UART2 Physical Address | CORE_TA_I2C1 Physical Address | CORE_TA_I2C2 Physical Address |
|-----------------------|------|-----------------------|--------------------------------|-------------------------------|-------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4806 D000                    | 0x4807 1000                   | 0x4807 3000                   |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4806 D004                    | 0x4807 1004                   | 0x4807 3004                   |
| L4_TA_CORE_L          | R    | 32                    | 0x4806 D018                    | 0x4807 1018                   | 0x4807 3018                   |
| L4_TA_CORE_H          | R    | 32                    | 0x4806 D01C                    | 0x4807 101C                   | 0x4807 301C                   |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4806 D020                    | 0x4807 1020                   | 0x4807 3020                   |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4806 D024                    | 0x4807 1024                   | 0x4807 3024                   |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4806 D028                    | 0x4807 1028                   | 0x4807 3028                   |

**Table 9-158. CORE\_TA Common Register Summary (continued)**

| Register Name        | Type | Register Width (Bits) | CORE_TA_UART2 Physical Address | CORE_TA_I2C1 Physical Address | CORE_TA_I2C2 Physical Address |
|----------------------|------|-----------------------|--------------------------------|-------------------------------|-------------------------------|
| L4_TA_AGENT_STATUS_H | RW   | 32                    | 0x4806 D02C                    | 0x4807 102C                   | 0x4807 302C                   |

**Table 9-159. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_MCBSP1 Physical Address | CORE_TA_GPTIMER10 Physical Address | CORE_TA_GPTIMER11 Physical Address |
|-----------------------|------|-----------------------|---------------------------------|------------------------------------|------------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4807 5000                     | 0x4808 7000                        | 0x4808 9000                        |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4807 5004                     | 0x4808 7004                        | 0x4808 9004                        |
| L4_TA_CORE_L          | R    | 32                    | 0x4807 5018                     | 0x4808 7018                        | 0x4808 9018                        |
| L4_TA_CORE_H          | R    | 32                    | 0x4807 501C                     | 0x4808 701C                        | 0x4808 901C                        |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4807 5020                     | 0x4808 7020                        | 0x4809 9020                        |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4807 5024                     | 0x4808 7024                        | 0x4809 9024                        |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4807 5028                     | 0x4808 7028                        | 0x4809 9028                        |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4807 502C                     | 0x4808 702C                        | 0x4809 902C                        |

**Table 9-160. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_MAILBOX Physical Address | CORE_TA_MCBSP5 Physical Address |
|-----------------------|------|-----------------------|----------------------------------|---------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4809 5000                      | 0x4809 9000                     |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4809 5004                      | 0x4809 9004                     |
| L4_TA_CORE_L          | R    | 32                    | 0x4809 5018                      | 0x4809 9018                     |
| L4_TA_CORE_H          | R    | 32                    | 0x4809 501C                      | 0x4809 901C                     |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4809 5020                      | 0x4809 9020                     |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4809 5024                      | 0x4809 9024                     |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4809 5028                      | 0x4809 9028                     |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4809 502C                      | 0x4809 902C                     |

**Table 9-161. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_MCSPI1 Physical Address | CORE_TA_MCSPI2 Physical Address | CORE_TA_MMCHS 1 Physical Address |
|-----------------------|------|-----------------------|---------------------------------|---------------------------------|----------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4809 9000                     | 0x4809 B000                     | 0x4809 D000                      |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4809 9004                     | 0x4809 B004                     | 0x4809 D004                      |
| L4_TA_CORE_L          | R    | 32                    | 0x4809 9018                     | 0x4809 B018                     | 0x4809 D018                      |
| L4_TA_CORE_H          | R    | 32                    | 0x4809 901C                     | 0x4809 B01C                     | 0x4809 D01C                      |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4809 9020                     | 0x4809 B020                     | 0x4809 D020                      |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4809 9024                     | 0x4809 B024                     | 0x4809 D024                      |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4809 9028                     | 0x4809 B028                     | 0x4809 D028                      |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4809 902C                     | 0x4809 B02C                     | 0x4809 D02C                      |

**Table 9-162. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_USB_HS_OTG Physical Address |
|-----------------------|------|-----------------------|-------------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x480A C000                         |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x480A C004                         |
| L4_TA_CORE_L          | R    | 32                    | 0x480A C018                         |
| L4_TA_CORE_H          | R    | 32                    | 0x480A C01C                         |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x480A C020                         |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x480A C024                         |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x480A C028                         |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x480A C02C                         |

**Table 9-163. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_MMCHS3 Physical Address | CORE_TA_HDQ1W Physical Address |
|-----------------------|------|-----------------------|---------------------------------|--------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x480A E000                     | 0x480B 3000                    |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x480A E004                     | 0x480B 3004                    |
| L4_TA_CORE_L          | R    | 32                    | 0x480A E018                     | 0x480B 3018                    |
| L4_TA_CORE_H          | R    | 32                    | 0x480A E01C                     | 0x480B 301C                    |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x480A E020                     | 0x480B 3020                    |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x480A E024                     | 0x480B 3024                    |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x480A E028                     | 0x480B 3028                    |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x480A E02C                     | 0x480B 302C                    |

**Table 9-164. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_MMCHS2 Physical Address | CORE_TA_ICR Physical Address | CORE_TA_MCSPI3 Physical Address |
|-----------------------|------|-----------------------|---------------------------------|------------------------------|---------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x480B 5000                     | 0x480B 7000                  | 0x480B 9000                     |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x480B 5004                     | 0x480B 7004                  | 0x480B 9004                     |
| L4_TA_CORE_L          | R    | 32                    | 0x480B 5018                     | 0x480B 7018                  | 0x480B 9018                     |
| L4_TA_CORE_H          | R    | 32                    | 0x480B 501C                     | 0x480B 701C                  | 0x480B 901C                     |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x480B 5020                     | 0x480B 7020                  | 0x480B 9020                     |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x480B 5024                     | 0x480B 7024                  | 0x480B 9024                     |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x480B 5028                     | 0x480B 7028                  | 0x480B 9028                     |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x480B 502C                     | 0x480B 702C                  | 0x480B 902C                     |

**Table 9-165. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_MCSPI4 Physical Address | CORE_TA_CAMERA Physical Address | CORE_TA_INTH Physical Address |
|-----------------------|------|-----------------------|---------------------------------|---------------------------------|-------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x480B B000                     | 0x480C 0000                     | 0x480C 8000                   |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x480B B004                     | 0x480C 0004                     | 0x480C 8004                   |
| L4_TA_CORE_L          | R    | 32                    | 0x480B B018                     | 0x480C 0018                     | 0x480C 8018                   |
| L4_TA_CORE_H          | R    | 32                    | 0x480B B01C                     | 0x480C 001C                     | 0x480C 801C                   |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x480B B020                     | 0x480C 0020                     | 0x480C 8020                   |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x480B B024                     | 0x480C 0024                     | 0x480C 8024                   |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x480B B028                     | 0x480C 0028                     | 0x480C 8028                   |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x480B B02C                     | 0x480C 002C                     | 0x480C 802C                   |

**Table 9-166. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_SR1 Physical Address | CORE_TA_SR2 Physical Address |
|-----------------------|------|-----------------------|------------------------------|------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x480C A000                  | 0x480C C000                  |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x480C A004                  | 0x480C C004                  |
| L4_TA_CORE_L          | R    | 32                    | 0x480C A018                  | 0x480C C018                  |
| L4_TA_CORE_H          | R    | 32                    | 0x480C A01C                  | 0x480C C01C                  |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x480C A020                  | 0x480C C020                  |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x480C A024                  | 0x480C C024                  |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x480C A028                  | 0x480C C028                  |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x480C A02C                  | 0x480C C02C                  |

**Table 9-167. CORE\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | CORE_TA_ICR_MODEM Physical Address | CORE_TA_WKUP Physical Address |
|-----------------------|------|-----------------------|------------------------------------|-------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x480C E000                        | 0x4834 0000                   |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x480C E004                        | 0x4834 0004                   |
| L4_TA_CORE_L          | R    | 32                    | 0x480C E018                        | 0x4834 0018                   |
| L4_TA_CORE_H          | R    | 32                    | 0x480C E01C                        | 0x4834 001C                   |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x480C E020                        | 0x4834 0020                   |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x480C E024                        | 0x4834 0024                   |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x480C E028                        | 0x4834 0028                   |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x480C E02C                        | 0x4834 002C                   |

**Table 9-168. PER\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | PER_TA_UART3 Physical Address | PER_TA_MCBSP2 Physical Address | PER_TA_MCBSP3 Physical Address |
|-----------------------|------|-----------------------|-------------------------------|--------------------------------|--------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4902 1000                   | 0x4902 3000                    | 0x4902 5000                    |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4902 1004                   | 0x4902 3004                    | 0x4902 5004                    |
| L4_TA_CORE_L          | R    | 32                    | 0x4902 1018                   | 0x4902 3018                    | 0x4902 5018                    |
| L4_TA_CORE_H          | R    | 32                    | 0x4902 101C                   | 0x4902 301C                    | 0x4902 501C                    |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4902 1020                   | 0x4902 3020                    | 0x4902 5020                    |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4902 1024                   | 0x4902 3024                    | 0x4902 5024                    |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4902 1028                   | 0x4902 3028                    | 0x4902 5028                    |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4902 102C                   | 0x4902 302C                    | 0x4902 502C                    |

**Table 9-169. PER\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | PER_TA_MCBSP4 Physical Address | PER_TA_MCBSP2_SIDETONE Physical Address | PER_TA_MCBSP3_SIDETONE Physical Address |
|-----------------------|------|-----------------------|--------------------------------|-----------------------------------------|-----------------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4902 7000                    | 0x4902 9000                             | 0x4902 B000                             |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4902 7004                    | 0x4902 9004                             | 0x4902 B004                             |
| L4_TA_CORE_L          | R    | 32                    | 0x4902 7018                    | 0x4902 9018                             | 0x4902 B018                             |
| L4_TA_CORE_H          | R    | 32                    | 0x4902 701C                    | 0x4902 901C                             | 0x4902 B01C                             |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4902 7020                    | 0x4902 9020                             | 0x4902 B020                             |

**Table 9-169. PER\_TA Common Register Summary (continued)**

| Register Name         | Type | Register Width (Bits) | PER_TA_MCBSP4 Physical Address | PER_TA_MCBSP2_SIDGETONE Physical Address | PER_TA_MCBSP3_SIDGETONE Physical Address |
|-----------------------|------|-----------------------|--------------------------------|------------------------------------------|------------------------------------------|
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4902 7024                    | 0x4902 9024                              | 0x4902 B024                              |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4902 7028                    | 0x4902 9028                              | 0x4902 B028                              |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4902 702C                    | 0x4902 902C                              | 0x4902 B02C                              |

**Table 9-170. PER\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | PER_TA_WDTIMER3 Physical Address | PER_TA_GPTIMER2 Physical Address |
|-----------------------|------|-----------------------|----------------------------------|----------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4903 1000                      | 0x4903 3000                      |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4903 1004                      | 0x4903 3004                      |
| L4_TA_CORE_L          | R    | 32                    | 0x4903 1018                      | 0x4903 3018                      |
| L4_TA_CORE_H          | R    | 32                    | 0x4903 101C                      | 0x4903 301C                      |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4903 1020                      | 0x4903 3020                      |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4903 1024                      | 0x4903 3024                      |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4903 1028                      | 0x4903 3028                      |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4903 102C                      | 0x4903 302C                      |

**Table 9-171. PER\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | PER_TA_GPTIMER3 Physical Address | PER_TA_GPTIMER4 Physical Address | PER_TA_GPTIMER5 Physical Address |
|-----------------------|------|-----------------------|----------------------------------|----------------------------------|----------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4903 5000                      | 0x4903 7000                      | 0x4903 9000                      |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4903 5004                      | 0x4903 7004                      | 0x4903 9004                      |
| L4_TA_CORE_L          | R    | 32                    | 0x4903 5018                      | 0x4903 7018                      | 0x4903 9018                      |
| L4_TA_CORE_H          | R    | 32                    | 0x4903 501C                      | 0x4903 701C                      | 0x4903 901C                      |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4903 5020                      | 0x4903 7020                      | 0x4903 9020                      |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4903 5024                      | 0x4903 7024                      | 0x4903 9024                      |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4903 5028                      | 0x4903 7028                      | 0x4903 9028                      |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4903 502C                      | 0x4903 702C                      | 0x4903 902C                      |

**Table 9-172. PER\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | PER_TA_GPTIMER6 Physical Address | PER_TA_GPTIMER7 Physical Address | PER_TA_GPTIMER8 Physical Address |
|-----------------------|------|-----------------------|----------------------------------|----------------------------------|----------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4903 B000                      | 0x4903 D000                      | 0x4903 F000                      |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4903 B004                      | 0x4903 D004                      | 0x4903 F004                      |
| L4_TA_CORE_L          | R    | 32                    | 0x4903 B018                      | 0x4903 D018                      | 0x4903 F018                      |
| L4_TA_CORE_H          | R    | 32                    | 0x4903 B01C                      | 0x4903 D01C                      | 0x4903 F01C                      |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4903 B020                      | 0x4903 D020                      | 0x4903 F020                      |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4903 B024                      | 0x4903 D024                      | 0x4903 F024                      |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4903 B028                      | 0x4903 D028                      | 0x4903 F028                      |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4903 B02C                      | 0x4903 D02C                      | 0x4903 F02C                      |

**Table 9-173. PER\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | PER_TA_GPTIM ER9 Physical Address | PER_TA_UART4 Physical Address | PER_TA_GPIO2 Physical Address | PER_TA_GPIO3 Physical Address |
|-----------------------|------|-----------------------|-----------------------------------|-------------------------------|-------------------------------|-------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4904 1000                       | 0x4904 3000                   | 0x4905 1000                   | 0x4905 3000                   |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4904 1004                       | 0x4904 3004                   | 0x4905 1004                   | 0x4905 3004                   |
| L4_TA_CORE_L          | R    | 32                    | 0x4904 1018                       | 0x4904 3018                   | 0x4905 1018                   | 0x4905 3018                   |
| L4_TA_CORE_H          | R    | 32                    | 0x4904 101C                       | 0x4904 301C                   | 0x4905 101C                   | 0x4905 301C                   |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4904 1020                       | 0x4904 3020                   | 0x4905 1020                   | 0x4905 3020                   |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4904 1024                       | 0x4904 3024                   | 0x4905 1024                   | 0x4905 3024                   |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4904 1028                       | 0x4904 3028                   | 0x4905 1028                   | 0x4905 3028                   |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4904 102C                       | 0x4904 302C                   | 0x4905 102C                   | 0x4905 302C                   |

**Table 9-174. PER\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | PER_TA_GPIO4 Physical Address | PER_TA_GPIO5 Physical Address | PER_TA_GPIO6 Physical Address |
|-----------------------|------|-----------------------|-------------------------------|-------------------------------|-------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4905 5000                   | 0x4905 7000                   | 0x4905 9000                   |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4905 5004                   | 0x4905 7004                   | 0x4905 9004                   |
| L4_TA_CORE_L          | R    | 32                    | 0x4905 5018                   | 0x4905 7018                   | 0x4905 9018                   |
| L4_TA_CORE_H          | R    | 32                    | 0x4905 501C                   | 0x4905 701C                   | 0x4905 901C                   |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4905 5020                   | 0x4905 7020                   | 0x4905 9020                   |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4905 5024                   | 0x4905 7024                   | 0x4905 9024                   |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4905 5028                   | 0x4905 7028                   | 0x4905 9028                   |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4905 502C                   | 0x4905 702C                   | 0x4905 902C                   |

**Table 9-175. EMU\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | EMU_TA_TEST_TAP Physical Address | EMU_TA_MPU Physical Address | EMU_TA_TPIU Physical Address |
|-----------------------|------|-----------------------|----------------------------------|-----------------------------|------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x5400 5000                      | 0x5401 8000                 | 0x5401 A000                  |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x5400 5004                      | 0x5401 8004                 | 0x5401 A004                  |
| L4_TA_CORE_L          | R    | 32                    | 0x5400 5018                      | 0x5401 8018                 | 0x5401 A018                  |
| L4_TA_CORE_H          | R    | 32                    | 0x5400 501C                      | 0x5401801C                  | 0x5401 A01C                  |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x5400 5020                      | 0x5401 8020                 | 0x5401 A020                  |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x5400 5024                      | 0x5401 8024                 | 0x5401 A024                  |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x5400 5028                      | 0x5401 8028                 | 0x5401 A028                  |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x5400 502C                      | 0x5401 802C                 | 0x5401 A02C                  |

**Table 9-176. EMU\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | EMU_TA_ETB Physical Address | EMU_TA_DAP Physical Address | EMU_TA_SDTI Physical Address | EMU_TA_L4WKUP Physical Address |
|-----------------------|------|-----------------------|-----------------------------|-----------------------------|------------------------------|--------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x5401 C000                 | 0x5401 E000                 | 0x5401 F000                  | 0x5473 0000                    |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x5401 C004                 | 0x5401 E004                 | 0x5401 F004                  | 0x5473 0004                    |
| L4_TA_CORE_L          | R    | 32                    | 0x5401 C018                 | 0x5401 E018                 | 0x5401 F018                  | 0x5473 0018                    |
| L4_TA_CORE_H          | R    | 32                    | 0x5401 C01C                 | 0x5401 E01C                 | 0x5401 F01C                  | 0x5473 001C                    |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x5401 C020                 | 0x5401 E020                 | 0x5401 F020                  | 0x5473 0020                    |

**Table 9-176. EMU\_TA Common Register Summary (continued)**

| Register Name         | Type | Register Width (Bits) | EMU_TA_ETB Physical Address | EMU_TA_DAP Physical Address | EMU_TA_SDTI Physical Address | EMU_TA_L4WKUP Physical Address |
|-----------------------|------|-----------------------|-----------------------------|-----------------------------|------------------------------|--------------------------------|
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x5401 C024                 | 0x5401 E024                 | 0x5401 F024                  | 0x5473 0024                    |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x5401 C028                 | 0x5401 E028                 | 0x5401 F028                  | 0x5473 0028                    |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x5401 C02C                 | 0x5401 E02C                 | 0x5401 F02C                  | 0x5473 002C                    |

**Table 9-177. WKUP\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | WKUP_TA_PRM Physical Address | WKUP_TA_GPIO1 Physical Address | WKUP_TA_WDTIMER2 Physical Address |
|-----------------------|------|-----------------------|------------------------------|--------------------------------|-----------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4830 9000                  | 0x4831 1000                    | 0x4831 5000                       |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4830 9004                  | 0x4831 1004                    | 0x4831 5004                       |
| L4_TA_CORE_L          | R    | 32                    | 0x4830 9008                  | 0x4831 1018                    | 0x4831 5018                       |
| L4_TA_CORE_H          | R    | 32                    | 0x4830 901C                  | 0x4831 101C                    | 0x4831 501C                       |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4830 9020                  | 0x4831 1020                    | 0x4831 5020                       |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4830 9024                  | 0x4831 1024                    | 0x4831 5024                       |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4830 9028                  | 0x4831 1028                    | 0x4831 5028                       |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4830 902C                  | 0x4831 102C                    | 0x4831 502C                       |

**Table 9-178. WKUP\_TA Common Register Summary**

| Register Name         | Type | Register Width (Bits) | WKUP_TA_GPTIMER1 Physical Address | WKUP_TA_SYNCTIMER32K Physical Address |
|-----------------------|------|-----------------------|-----------------------------------|---------------------------------------|
| L4_TA_COMPONENT_L     | R    | 32                    | 0x4831 9000                       | 0x4832 1000                           |
| L4_TA_COMPONENT_H     | R    | 32                    | 0x4831 9004                       | 0x4832 1004                           |
| L4_TA_CORE_L          | R    | 32                    | 0x4831 9008                       | 0x4832 1018                           |
| L4_TA_CORE_H          | R    | 32                    | 0x4831 901C                       | 0x4832 101C                           |
| L4_TA_AGENT_CONTROL_L | RW   | 32                    | 0x4831 9020                       | 0x4832 1020                           |
| L4_TA_AGENT_CONTROL_H | RW   | 32                    | 0x4831 9024                       | 0x4832 1024                           |
| L4_TA_AGENT_STATUS_L  | RW   | 32                    | 0x4831 9028                       | 0x4832 1028                           |
| L4_TA_AGENT_STATUS_H  | RW   | 32                    | 0x4831 902C                       | 0x4832 102C                           |

### 9.3.5.2.1 L4 Target Agent (L4 TA) Registers Description

**Table 9-179. L4\_TA\_COMPONENT\_L**

|                                                                                             |                                         |
|---------------------------------------------------------------------------------------------|-----------------------------------------|
| Address Offset                                                                              | 0x000                                   |
| Physical Address                                                                            | See Table 9-153 to Table 9-177          |
| Description                                                                                 | Contains a component code and revision. |
| Type                                                                                        | R                                       |
| 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 | CODE REV                                |
| CODE                                                                                        | REV                                     |

| Bits  | Field Name | Description              | Type | Reset                |
|-------|------------|--------------------------|------|----------------------|
| 31:16 | CODE       | Interconnect code.       | R    | See <sup>(1)</sup> . |
| 15:0  | REV        | Component revision code. | R    | See <sup>(1)</sup> . |

<sup>(1)</sup> TI internal Data

**Table 9-180. Register Call Summary for Register L4\_TA\_COMPONENT\_L**

L4 Interconnects

- L4 Target Agent (L4 TA): [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]

**Table 9-181. L4\_TA\_COMPONENT\_H**

|                         |                                                                |
|-------------------------|----------------------------------------------------------------|
| <b>Address Offset</b>   | 0x004                                                          |
| <b>Physical Address</b> | See <a href="#">Table 9-153</a> to <a href="#">Table 9-178</a> |
| <b>Description</b>      | Contains a component code and revision.                        |
| <b>Type</b>             | R                                                              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description    | Type | Reset      |
|------|------------|----------------|------|------------|
| 31:0 | Reserved   | Read returns 0 | R    | 0x0000 000 |

**Table 9-182. Register Call Summary for Register L4\_TA\_COMPONENT\_H**

L4 Interconnects

- L4 Target Agent (L4 TA): [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]

**Table 9-183. L4\_TA\_CORE\_L**

|                         |                                                                |
|-------------------------|----------------------------------------------------------------|
| <b>Address Offset</b>   | 0x018                                                          |
| <b>Physical Address</b> | See <a href="#">Table 9-153</a> to <a href="#">Table 9-178</a> |
| <b>Description</b>      | Contains a component code and revision.                        |
| <b>Type</b>             | R                                                              |

|           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| CORE_CODE |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CORE_REV |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                  | Type | Reset                |
|-------|------------|------------------------------|------|----------------------|
| 31:16 | CORE_CODE  | Interconnect core code       | R    | See <sup>(1)</sup> . |
| 15:0  | CORE_REV   | Component revision code code | R    | See <sup>(1)</sup> . |

<sup>(1)</sup> TI Internal data

**Table 9-184. Register Call Summary for Register L4\_TA\_CORE\_L**

L4 Interconnects

- L4 Target Agent (L4 TA): [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]

**Table 9-185. L4\_TA\_CORE\_H**

|                         |                                                                   |
|-------------------------|-------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x01C                                                             |
| <b>Physical Address</b> | See <a href="#">Table 9-153</a> to <a href="#">Table 9-178</a>    |
| <b>Description</b>      | Contains a component code and revision.                           |
| <b>Type</b>             | R                                                                 |
| 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 |
| Reserved                | VENDOR_CODE                                                       |

| Bits  | Field Name  | Description               | Type | Reset                |
|-------|-------------|---------------------------|------|----------------------|
| 31:16 | Reserved    | Reserved                  | R    | 0x0000               |
| 15:0  | VENDOR_CODE | Vendor revision core code | R    | See <sup>(1)</sup> . |

<sup>(1)</sup> TI Internal data

**Table 9-186. Register Call Summary for Register L4\_TA\_CORE\_H**

## L4 Interconnects

- L4 Target Agent (L4 TA): [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]

**Table 9-187. L4\_TA\_AGENT\_CONTROL\_L**

|                         |                                                                   |
|-------------------------|-------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x020                                                             |
| <b>Physical Address</b> | See <a href="#">Table 9-153</a> to <a href="#">Table 9-178</a>    |
| <b>Description</b>      | Enable error reporting                                            |
| <b>Type</b>             | RW                                                                |
| 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 |
| Reserved                | SERROR_REP   Reserved   REQ_TIMEOUT   Reserved   OCP_RESET        |

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                    | Type | Reset |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:25 | Reserved    | Read returns 0.                                                                                                                                                                                                                                                                                                                                                | R    | 0x00  |
| 24    | SERROR_REP  | Enable logging of error                                                                                                                                                                                                                                                                                                                                        | R    | 0x0   |
| 23:11 | Reserved    | Read returns 0.                                                                                                                                                                                                                                                                                                                                                |      |       |
| 10:8  | REQ_TIMEOUT | Timeout Bound. Values are:0 - No timeout<br>1 - 1x base cycles<br>2 - 4x base cycles<br>3 - 16x base cycles<br>4 - 64x base cycles                                                                                                                                                                                                                             | RW   | 0x2   |
| 7:1   | Reserved    | Read returns 0.                                                                                                                                                                                                                                                                                                                                                | R    | 0x00  |
| 0     | OCP_RESET   | The OCP_RESET field controls the OCP reset signal to the attached core. Setting this bit clears any pending transfers and resets the OCP interface. The bit must be cleared to de-assert the OCP reset signal. When the software reset feature is available on a target agent, the target agent OCP must also have a reset signal directed to the target core. | RW   | 0     |

**Table 9-188. Register Call Summary for Register L4\_TA\_AGENT\_CONTROL\_L**

## L4 Interconnects

- Error Logging: [0] [1] [2] [3] [4]
- TA Software Reset: [5] [6]
- Operational Modes Configuration: [7] [8] [9] [10]
- L4 Target Agent (L4 TA): [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23] [24] [25] [26] [27] [28] [29] [30] [31] [32] [33] [34] [35] [36]

**Table 9-189. L4\_TA\_AGENT\_CONTROL\_H**

|                         |                                                                |
|-------------------------|----------------------------------------------------------------|
| <b>Address Offset</b>   | 0x024                                                          |
| <b>Physical Address</b> | See <a href="#">Table 9-153</a> to <a href="#">Table 9-178</a> |
| <b>Description</b>      | Enable clock power management                                  |
| <b>Type</b>             | RW                                                             |



| Bits | Field Name | Description                                                                                                | Type | Reset    |
|------|------------|------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | Reserved   | Read returns 0.                                                                                            | R    | 0x000000 |
| 8    | EXT_CLOCK  | When set to 1, the ext_clk_off_i signal on a target agent indicates when the target agent should shut off. | R    | 0        |
| 7:0  | Reserved   | Read returns 0.                                                                                            | R    | 0x00     |

**Table 9-190. Register Call Summary for Register L4\_TA\_AGENT\_CONTROL\_H**

## L4 Interconnects

- L4 Target Agent (L4 TA): [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]

**Table 9-191. L4\_TA\_AGENT\_STATUS\_L**

|                         |                                                                |
|-------------------------|----------------------------------------------------------------|
| <b>Address Offset</b>   | 0x028                                                          |
| <b>Physical Address</b> | See <a href="#">Table 9-153</a> to <a href="#">Table 9-178</a> |
| <b>Description</b>      | Error reporting                                                |
| <b>Type</b>             | RW                                                             |



| Bits  | Field Name  | Description                                                    | Type     | Reset  |
|-------|-------------|----------------------------------------------------------------|----------|--------|
| 31:24 | Reserved    | Read returns 0.                                                | R        | 0x00   |
| 23:9  | Reserved    | Read returns 0.                                                | R        | 0x0001 |
| 8     | REQ_TIMEOUT | 0x0: No request timeout<br>0x1: A request timeout has occurred | R 1toCLR | 0      |

| Bits | Field Name | Description     | Type | Reset |
|------|------------|-----------------|------|-------|
| 7:0  | Reserved   | Read returns 0. | R    | 0x00  |

**Table 9-192. Register Call Summary for Register L4\_TA\_AGENT\_STATUS\_L**

## L4 Interconnects

- Error Logging: [0] [1]
- TA Software Reset: [2]
- Operational Modes Configuration: [3] [4]
- L4 Target Agent (L4 TA): [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]

**Table 9-193. L4\_TA\_AGENT\_STATUS\_H**

|                         |                                                                |
|-------------------------|----------------------------------------------------------------|
| <b>Address Offset</b>   | 0x02C                                                          |
| <b>Physical Address</b> | See <a href="#">Table 9-153</a> to <a href="#">Table 9-178</a> |
| <b>Description</b>      | Error reporting                                                |
| <b>Type</b>             | RW                                                             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description    | Type | Reset      |
|------|------------|----------------|------|------------|
| 31:0 | Reserved   | Read returns 0 | R    | 0x0000 000 |

**Table 9-194. Register Call Summary for Register L4\_TA\_AGENT\_STATUS\_H**

## L4 Interconnects

- L4 Target Agent (L4 TA): [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]

### 9.3.5.3 L4 Link Register Agent (LA)

This section provides information on the L4-Core link agent (LA) register module. Each of the registers within the module instance is described separately in [Table 9-195](#).

The LA register block contains the initiator subsystem information register and the composite sideband signal mask and status registers.

**Table 9-195. L4 LA Register Summary**

| Register Name           | Type | Register Width (Bits) | CORE_LA Physical Address | PER_LA Physical Address | EMU_LA Physical Address | WKUP_LA Physical Address |
|-------------------------|------|-----------------------|--------------------------|-------------------------|-------------------------|--------------------------|
| L4_LA_COMPONENT_L       | R    | 32                    | 0x4804 1000              | 4900 1000               | 0x5400 7000             | 0x4832 9000              |
| L4_LA_COMPONENT_H       | R    | 32                    | 0x4804 1004              | 0x4900 1004             | 0x5400 7004             | 0x4832 9004              |
| L4_LA_NETWORK_L         | R    | 32                    | 0x4804 1010              | 0x4900 1010             | 0x5400 7010             | 0x4832 9010              |
| L4_LA_NETWORK_H         | R    | 32                    | 0x4804 1014              | 0x4900 1014             | 0x5400 7014             | 0x4832 9014              |
| L4_LA_INITIATOR_INFO_L  | R    | 32                    | 0x4804 1018              | 0x4900 1018             | 0x5400 7018             | 0x4832 9018              |
| L4_LA_INITIATOR_INFO_H  | R    | 32                    | 0x4804 101C              | 0x4900 101C             | 0x5400 701C             | 0x4832 901C              |
| L4_LA_NETWORK_CONTROL_L | RW   | 32                    | 0x4804 1020              | 0x4900 1020             | 0x5400 7020             | 0x4832 9020              |
| L4_LA_NETWORK_CONTROL_H | RW   | 32                    | 0x4804 1024              | 0x4900 1024             | 0x5400 7024             | 0x4832 9024              |

### 9.3.5.3.1 L4 Link Register Agent (LA) Registers Description

**Table 9-196. L4\_LA\_COMPONENT\_L**

|                         |                                                                                                  |
|-------------------------|--------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x000                                                                                            |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-195</a>                                                      |
| <b>Description</b>      | Contain a component code and revision, which are used to identify the hardware of the component. |
| <b>Type</b>             | R                                                                                                |

|                                                                                             |
|---------------------------------------------------------------------------------------------|
| 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 |
| CODE                                                                                        |

| Bits  | Field Name | Description              | Type | Reset                |
|-------|------------|--------------------------|------|----------------------|
| 31:16 | CODE       | Interconnect code.       | R    | See <sup>(1)</sup> . |
| 15:0  | REV        | Component revision code. | R    | See <sup>(1)</sup> . |

<sup>(1)</sup> TI internal data

**Table 9-197. Register Call Summary for Register L4\_LA\_COMPONENT\_L**

L4 Interconnects

- [L4 Link Register Agent \(LA\): \[0\]](#)

**Table 9-198. L4\_LA\_COMPONENT\_H**

|                         |                                                                                                  |
|-------------------------|--------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x004                                                                                            |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-195</a>                                                      |
| <b>Description</b>      | Contain a component code and revision, which are used to identify the hardware of the component. |
| <b>Type</b>             | R                                                                                                |

|                                                                                             |
|---------------------------------------------------------------------------------------------|
| 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 |
| Reserved                                                                                    |

| Bits | Field Name | Description    | Type | Reset       |
|------|------------|----------------|------|-------------|
| 31:0 | Reserved   | Read returns 0 | R    | 0x0000 0000 |

**Table 9-199. Register Call Summary for Register L4\_LA\_COMPONENT\_H**

L4 Interconnects

- [L4 Link Register Agent \(LA\): \[0\]](#)

**Table 9-200. L4\_LA\_NETWORK\_L**

|                         |                                             |
|-------------------------|---------------------------------------------|
| <b>Address Offset</b>   | 0x010                                       |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-195</a> |
| <b>Description</b>      | Identify the interconnect                   |
| <b>Type</b>             | R                                           |

|                                                                                             |
|---------------------------------------------------------------------------------------------|
| 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 |
| Reserved                                                                                    |

| Bits | Field Name | Description    | Type | Reset       |
|------|------------|----------------|------|-------------|
| 31:0 | Reserved   | Read returns 0 | R    | 0x0000 0000 |

**Table 9-201. Register Call Summary for Register L4\_LA\_NETWORK\_L**

L4 Interconnects

- [L4 Link Register Agent \(LA\): \[0\]](#)

**Table 9-202. L4\_LA\_NETWORK\_H**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x014                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Please refer to <a href="#">Table 9-195</a> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Identify the interconnect                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="33" style="text-align:center;">ID</td></tr> </table> |                                             | 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 | ID |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |   |   |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ID                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                     | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------|------|------------|
| 31:0 | ID         | The ID field uniquely identifies this interconnect, and can serve as a chip ID. | R    | 0x00010000 |

**Table 9-203. Register Call Summary for Register L4\_LA\_NETWORK\_H**

L4 Interconnects

- [L4 Link Register Agent \(LA\): \[0\]](#)

**Table 9-204. L4\_LA\_INITIATOR\_INFO\_L**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                             |             |    |                |    |    |    |          |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |             |  |                |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-------------|----|----------------|----|----|----|----------|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|-------------|--|----------------|--|--|--|----------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x018                                       |             |    |                |    |    |    |          |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |             |  |                |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Please refer to <a href="#">Table 9-195</a> |             |    |                |    |    |    |          |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |             |  |                |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Contain initiator subsystem information.    |             |    |                |    |    |    |          |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |             |  |                |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R                                           |             |    |                |    |    |    |          |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |             |  |                |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="2" style="text-align:center;">Reserved</td><td colspan="2" style="text-align:center;">PROT_GROUPS</td><td colspan="4" style="text-align:center;">NUMBER_REGIONS</td><td colspan="8" style="text-align:center;">Reserved</td><td colspan="8" style="text-align:center;">SEGMENTS</td><td colspan="2"></td><td colspan="2"></td><td colspan="2"></td><td colspan="2"></td></tr> </table> |                                             | 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 | Reserved |  | PROT_GROUPS |  | NUMBER_REGIONS |  |  |  | Reserved |  |  |  |  |  |  |  | SEGMENTS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |   |   |          |  |             |  |                |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                             | PROT_GROUPS |    | NUMBER_REGIONS |    |    |    | Reserved |    |    |    |    |    |    |    | SEGMENTS |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |             |  |                |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name     | Description                                                                                                                                                                                                                                                     | Type | Reset                           |
|-------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------------|
| 31:28 | Reserved       | Read returns 0.                                                                                                                                                                                                                                                 | R    | 0x0                             |
| 27:24 | PROT_GROUPS    | The number of protection groups. The PROT_GROUPS field contains read-only configuration information for the address mapping and protection structure of the initiator subsystem. If the PROT_GROUPS field is set to 0, there are no protection group registers. | R    | see <a href="#">Table 9-206</a> |
| 23:16 | NUMBER_REGIONS | The number of regions. The NUMBER_REGIONS field contains read-only configuration information for the region register of the initiator subsystem.                                                                                                                | R    | see <a href="#">Table 9-206</a> |
| 15:4  | Reserved       | Read returns 0.                                                                                                                                                                                                                                                 | R    | 0x000                           |
| 3:0   | SEGMENTS       | The number of segments. The SEGMENT fields contains read-only configuration information for the segment register of the initiator subsystem.                                                                                                                    | R    | see <a href="#">Table 9-206</a> |

**Table 9-205. Register Call Summary for Register L4\_LA\_INITIATOR\_INFO\_L**

L4 Interconnects

- [L4 Link Register Agent \(LA\): \[0\]](#)

**Table 9-206. Reset value for L4\_LA\_INITIATOR\_INFO\_L**

| Field Name     | CORE_LA | PER_LA | EMU_LA | WKUP_LA |
|----------------|---------|--------|--------|---------|
| PROT_GROUPS    | 0x8     | 0x8    | 0x8    | 0x8     |
| NUMBER_REGIONS | 0x64    | 0x2B   | 0x1A   | 0x13    |
| SEGMENTS       | 0x6     | 0x5    | 0x3    | 0x2     |

**Table 9-207. L4\_LA\_INITIATOR\_INFO\_H**

|                  |                                             |
|------------------|---------------------------------------------|
| Address Offset   | 0x01C                                       |
| Physical Address | Please refer to <a href="#">Table 9-195</a> |
| Description      | Contain initiator subsystem information.    |
| Type             | R                                           |



| Bits  | Field Name          | Description                                                                                                                                                                                                                                               | Type | Reset                           |
|-------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------------|
| 31:19 | Reserved            | Read returns 0.                                                                                                                                                                                                                                           | R    | 0x0000                          |
| 18:16 | THREADS             | The THREADS field specifies the number of initiator threads connected to the interconnect. The field contains read-only configuration information for the initiator subsystem.                                                                            | R    | <a href="#">see Table 9-209</a> |
| 15    | Reserved            | Read returns 0.                                                                                                                                                                                                                                           | R    | 0                               |
| 14:12 | CONNID_WIDTH        | The initiator subsystem connID width. The CONNID_WIDTH field contains read-only configuration information for the initiator subsystem.                                                                                                                    | R    | <a href="#">see Table 9-209</a> |
| 11    | Reserved            | Read returns 0.                                                                                                                                                                                                                                           | R    | 0                               |
| 10:8  | BYTE_DATA_WIDTH_EXP | This field specifies the initiator subsystem data width. 1:2^1 bytes specifies a 16-bit data width and 2:2^2 bytes specifies a 32-bit data width. The BYTE_DATA_WIDTH_EXP field contains read-only configuration information for the initiator subsystem. | R    | <a href="#">see Table 9-209</a> |
| 7:5   | Reserved            | Read returns 0.                                                                                                                                                                                                                                           | R    | 0x0                             |
| 4:0   | ADDR_WIDTH          | This field specifies the initiator subsystem address width. The ADDR_WIDTH field contains read-only configuration information for the initiator subsystem.                                                                                                | R    | <a href="#">see Table 9-209</a> |

**Table 9-208. Register Call Summary for Register L4\_LA\_INITIATOR\_INFO\_H**

L4 Interconnects

- [L4 Link Register Agent \(LA\): \[0\]](#)

**Table 9-209. Reset value for L4\_LA\_INITIATOR\_INFO\_H**

| Field Name          | CORE_LA | PER_LA | EMU_LA | WKUP_LA |
|---------------------|---------|--------|--------|---------|
| THREADS             | 0x4     | 0x4    | 0x2    | 0x2     |
| CONNID_WIDTH        | 0x4     | 0x4    | 0x4    | 0x0     |
| BYTE_DATA_WIDTH_EXP | 0x2     | 0x2    | 0x2    | 0x2     |
| ADDR_WIDTH          | 0x18    | 0x14   | 0x18   | 0x14    |

**Table 9-210. L4\_LA\_NETWORK\_CONTROL\_L**

|                         |                                              |
|-------------------------|----------------------------------------------|
| <b>Address Offset</b>   | 0x020                                        |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-195</a>  |
| <b>Description</b>      | Control interconnect minimum timeout values. |
| <b>Type</b>             | RW                                           |



| Bits  | Field Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset    |
|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:11 | Reserved     | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R    | 0x000000 |
| 10:8  | TIMEOUT_BASE | The TIMEOUT_BASE field indicates the timeout period (that is, base cycles) for the highest frequency time-base signal sent from the L4 initiator subsystem to all target agents that have timeout enabled.<br>Values for the field are:<br>0 - Timeout disabled<br>1 - L4 interconnect clock cycles divided by 64<br>2 - L4 interconnect clock cycles divided by 256<br>3 - L4 interconnect clock cycles divided by 1024<br>4 - L4 interconnect clock cycles divided by 4096 | RW   | 0x4      |
| 7:0   | Reserved     | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R    | 0x00     |

**Table 9-211. Register Call Summary for Register L4\_LA\_NETWORK\_CONTROL\_L**

## L4 Interconnects

- [Error Logging: \[0\] \[1\]](#)
- [Operational Modes Configuration: \[2\] \[3\]](#)
- [L4 Link Register Agent \(LA\): \[4\]](#)

**Table 9-212. L4\_LA\_NETWORK\_CONTROL\_H**

|                         |                                             |
|-------------------------|---------------------------------------------|
| <b>Address Offset</b>   | 0x024                                       |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-195</a> |
| <b>Description</b>      | Control interconnect global power control   |
| <b>Type</b>             | RW                                          |



| Bits  | Field Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Type | Reset |
|-------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:25 | Reserved           | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R    | 0x00  |
| 24    | CLOCK_GATE_DISABLE | When set to 1 this field disables all clock gating.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW   | 0     |
| 23:21 | Reserved           | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R    | 0x0   |
| 20    | THREAD0_PRI        | Sets thread priority. If the field is set to 0, the default, all initiator threads are treated the same. Setting the THREAD0_PRI field to 1 assigns a higher arbitration priority to thread 0 of the first initiator OCP interface.<br>To avoid starvation, arbitration is imposed by the initiator subsystem. When multiple requests from different initiator threads are dispatched to targets simultaneously, the oldest request is dispatched first. If thread 0 is assigned a higher priority, a request on thread 0 always wins arbitration.<br>Assigning thread 0 of the first initiator OCP the highest priority on a request or response can result in the starvation of other threads. | R    | 1     |
| 19:9  | Reserved           | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R    | 0x000 |
| 8     | EXT_CLOCK          | When set to 1, the ext_clk_off_i signal on the initiator subsystem instructs the entire L4 to shut off.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 1     |
| 7:0   | Reserved           | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R    | 0x00  |

**Table 9-213. Register Call Summary for Register L4\_LA\_NETWORK\_CONTROL\_H**

## L4 Interconnects

- Power Management: [0]
- L4 Link Register Agent (LA): [1]

**9.3.5.4 L4 Address Protection (AP)**

This section provides information on the L4-Core link agent (LA) register module. Each of the registers within the module instance is described separately in [Table 9-214](#).

The AP register block contains the segment, address region, and protection group registers that can be used to specify the addressing scheme or restrict the access of target address regions.

**Table 9-214. L4 AP Register Summary**

| Register Name                               | Type | Register Width (Bits) | CORE_AP Physical Address | PER_AP Physical Address |
|---------------------------------------------|------|-----------------------|--------------------------|-------------------------|
| L4_AP_COMPONENT_L                           | R    | 32                    | 0x4804 0000              | 0x4900 0 000            |
| L4_AP_COMPONENT_H                           | R    | 32                    | 0x4804 0004              | 0x4900 0000             |
| L4_AP_SEGMENT_i_L <sup>(1)</sup>            | RW   | 32                    | 0x4804 0100 + (0x08*i)   | 0x4900 0100 + (0x08*i)  |
| L4_AP_SEGMENT_i_H <sup>(1)</sup>            | RW   | 32                    | 0x4804 0104 + (0x08*i)   | 0x4900 0104 + (0x08*i)  |
| L4_AP_PROT_GROUP_MEMBERS_k_L <sup>(2)</sup> | R    | 32                    | 0x4804 0200 + (0x08*k)   | 0x4900 0200 + (0x08*k)  |

<sup>(1)</sup> i = 0 to 5 for CORE\_AP  
i = 0 to 4 for PER\_AP  
i = 0 to 2 for EMU\_AP  
i = 0 to 1 for WKUP\_AP

<sup>(2)</sup> k = 0 to 7 for CORE\_AP and PER\_AP  
k = 0 to 5 for EMU\_AP

**Table 9-214. L4 AP Register Summary (continued)**

| Register Name                               | Type | Register Width (Bits) | CORE_AP Physical Address | PER_AP Physical Address |
|---------------------------------------------|------|-----------------------|--------------------------|-------------------------|
| L4_AP_PROT_GROUP_MEMBERS_k_H <sup>(2)</sup> | R    | 32                    | 0x4804 0204 + (0x08*k)   | 0x4900 0204 + (0x08*k)  |
| L4_AP_PROT_GROUP_ROLES_k_L <sup>(2)</sup>   | R    | 32                    | 0x4804 0280 + (0x08*k)   | 0x4900 0280 + (0x08*k)  |
| L4_AP_PROT_GROUP_ROLES_k_H <sup>(2)</sup>   | R    | 32                    | 0x4804 0284 + (0x08*k)   | 0x4900 0284 + (0x08*k)  |
| L4_AP_REGION_I_L <sup>(3)</sup>             | RW   | 32                    | 0x4804 0300 + (0x08*I)   | 0x4900 0300 + (0x08*I)  |
| L4_AP_REGION_I_H <sup>(3)</sup>             | RW   | 32                    | 0x4804 0304 + (0x08*I)   | 0x4900 0304 + (0x08*I)  |

<sup>(3)</sup> I = 0 to 99 for CORE\_AP

I = 0 to 42 for PER\_AP

I = 0 to 25 for EMU\_AP

I = 0 to 18 for WKUP\_AP

**Table 9-215. L4 AP Register Summary**

| Register Name                               | Type | Register Width (Bits) | EMU_AP Physical Address | WKUP_AP Physical Address |
|---------------------------------------------|------|-----------------------|-------------------------|--------------------------|
| L4_AP_COMPONENT_L                           | R    | 32                    | 0x5400 6000             | 0x4832 8000              |
| L4_AP_COMPONENT_H                           | R    | 32                    | 0x5400 6004             | 0x4832 8000              |
| L4_AP_SEGMENT_i_L <sup>(1)</sup>            | RW   | 32                    | 0x5400 6100 + (0x08*i)  | 0x4832 8100 + (0x08*i)   |
| L4_AP_SEGMENT_i_H <sup>(1)</sup>            | RW   | 32                    | 0x5400 6104 + (0x08*i)  | 0x4832 8104 + (0x08*i)   |
| L4_AP_PROT_GROUP_MEMBERS_k_L <sup>(2)</sup> | R    | 32                    | 0x5400 6200 + (0x08*k)  | N/A                      |
| L4_AP_PROT_GROUP_MEMBERS_k_H <sup>(2)</sup> | R    | 32                    | 0x5400 6204 + (0x08*k)  | N/A                      |
| L4_AP_PROT_GROUP_ROLES_k_L <sup>(2)</sup>   | R    | 32                    | 0x5400 6280 + (0x08*k)  | N/A                      |
| L4_AP_PROT_GROUP_ROLES_k_H <sup>(3)</sup>   | R    | 32                    | 0x5400 6284 + (0x08*k)  | N/A                      |
| L4_AP_REGION_I_L <sup>(4)</sup>             | RW   | 32                    | 0x5400 6300 + (0x08*I)  | 0x4832 8300 + (0x08*I)   |
| L4_AP_REGION_I_H <sup>(4)</sup>             | RW   | 32                    | 0x5400 6304 + (0x08*I)  | 0x4832 8304 + (0x08*I)   |

<sup>(1)</sup> i = 0 to 5 for CORE\_AP

i = 0 to 4 for PER\_AP

i = 0 to 2 for EMU\_AP

i = 0 to 1 for WKUP\_AP

<sup>(2)</sup> k = 0 to 7 for CORE\_AP and PER\_AP

k = 0 to 5 for EMU\_AP

<sup>(3)</sup> k = 0 to 7 for CORE\_AP and PER\_AP

k = 0 to 5 for EMU\_AP

<sup>(4)</sup> I = 0 to 99 for CORE\_AP

I = 0 to 42 for PER\_AP

I = 0 to 25 for EMU\_AP

I = 0 to 18 for WKUP\_AP

#### 9.3.5.4.1 L4 Address Protection (AP) Registers Description

**Table 9-216. L4\_AP\_COMPONENT\_L**

|                  |                                                                                                   |
|------------------|---------------------------------------------------------------------------------------------------|
| Address Offset   | 0x000                                                                                             |
| Physical Address | Please refer to <a href="#">Table 9-214</a>                                                       |
| Description      | Contains a component code and revision, which are used to identify the hardware of the component. |
| Type             | R                                                                                                 |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| CODE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | REV |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## *L4 Interconnects*

[www.ti.com](http://www.ti.com)

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>       | <b>Type</b> | <b>Reset</b>              |
|-------------|-------------------|--------------------------|-------------|---------------------------|
| 31:16       | CODE              | Interconnect code.       | R           | See <a href="#">(1)</a> . |
| 15:0        | REV               | Component revision code. | R           | See <a href="#">(1)</a> . |

(1) TI Internal Data

**Table 9-217. Register Call Summary for Register L4\_AP\_COMPONENT\_L**

- ## L4 Interconnects

- L4 Address Protection (AP): [0] [1]

**Table 9-218. L4\_AP\_COMPONENT\_H**

|                         |                                                                                                   |
|-------------------------|---------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x004                                                                                             |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-214</a>                                                       |
| <b>Description</b>      | Contains a component code and revision, which are used to identify the hardware of the component. |
| <b>Type</b>             | R                                                                                                 |

**Table 9-219. Register Call Summary for Register L4\_AP\_COMPONENT\_H**

- ## L4 Interconnects

- L4 Address Protection (AP): [0] [1]

**Table 9-220. L4\_AP\_SEGMENT\_i\_L**

|                         |                                             |              |                                                                                                        |
|-------------------------|---------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x100 + (0x08*i)                            | <b>Index</b> | i = 0 to 5 for CORE_AP,<br>i = 0 to 4 for PER_AP,<br>i = 0 to 2 for EMU_AP,<br>i = 0 to 1 for WKUP_AP, |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-214</a> |              |                                                                                                        |
| <b>Description</b>      | Define the base address of each segments    |              |                                                                                                        |
| <b>Type</b>             | RW                                          |              |                                                                                                        |

Table 9-221 Register Call Summary for Register | 4 AP SEGMENT i |

- #### 1.4 Interconnects

- L4 Firewall Address and Protection Registers Setting: [0]
  - L4 Address Protection (AP): [1] [?]

**Table 9-222. L4\_AP\_SEGMENT\_i\_L Reset Values**

| <b>BASE</b> | <b>CORE_AP</b> | <b>PER_AP</b> | <b>EMU_AP</b> | <b>WKUP_AP</b> |
|-------------|----------------|---------------|---------------|----------------|
| i = 0       | 0x00 0000      | 0x00 0000     | 0x00 0000     | 0x00 0000      |
| i = 1       | 0x04 0000      | 0x02 0000     | 0x40 0000     | 0x02 0000      |
| i = 2       | 0x08 0000      | 0x03 0000     | 0x60 0000     | N/A            |
| i = 3       | 0x0C 0000      | 0x04 0000     | N/A           | N/A            |
| i = 4       | 0x30 0000      | 0x05 0000     | N/A           | N/A            |
| i = 5       | 0x32 0000      | N/A           | N/A           | N/A            |

**Table 9-223. L4\_AP\_SEGMENT\_i\_H**

|                         |                                             |              |                                                                                                        |
|-------------------------|---------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x104 + (0x08*i)                            | <b>Index</b> | i = 0 to 5 for CORE_AP,<br>i = 0 to 4 for PER_AP,<br>i = 0 to 2 for EMU_AP,<br>i = 0 to 1 for WKUP_AP, |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-214</a> |              |                                                                                                        |
| <b>Description</b>      | Define the size of each segments            |              |                                                                                                        |
| <b>Type</b>             | RW                                          |              |                                                                                                        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |      |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|------|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | SIZE |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                  | <b>Type</b> | <b>Reset</b>                    |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------|-------------|---------------------------------|
| 31:5        | Reserved          | Read returns 0.                                                                                                     | R           | 0x00000000                      |
| 4:0         | SIZE              | Segment size is a power of 2, where 2^SIZE is the byte size of a segment (all segment registers use the same size). | R           | <a href="#">see Table 9-225</a> |

**Table 9-224. Register Call Summary for Register L4\_AP\_SEGMENT\_i\_H**

## L4 Interconnects

- [L4 Firewall Address and Protection Registers Setting: \[0\]](#)
- [L4 Address Protection \(AP\): \[1\] \[2\]](#)

**Table 9-225. L4\_AP\_SEGMENT\_i\_H Reset Values**

| SIZE      | CORE_AP | PER_AP | EMU_AP | WKUP_AP |
|-----------|---------|--------|--------|---------|
| For all i | 0x12    | 0x10   | 0x15   | 0x11    |

**Table 9-226. L4\_AP\_PROT\_GROUP\_MEMBERS\_k\_L**

|                         |                                                   |              |                                                             |
|-------------------------|---------------------------------------------------|--------------|-------------------------------------------------------------|
| <b>Address Offset</b>   | 0x200 + (0x08*k)                                  | <b>Index</b> | k = 0 to 7 for CORE_AP and PER_AP.<br>k = 0 to 5 for EMU_AP |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-214</a>       |              |                                                             |
| <b>Description</b>      | Define connID bit vectors for a protection group. |              |                                                             |
| <b>Type</b>             | R                                                 |              |                                                             |

|                                                                                             |                   |
|---------------------------------------------------------------------------------------------|-------------------|
| 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 |                   |
| Reserved                                                                                    | CONNID_BIT_VECTOR |

| Bits  | Field Name        | Description                                                                                                                  | Type | Reset  |
|-------|-------------------|------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved          | Read returns 0                                                                                                               | R    | 0x0000 |
| 15:0  | CONNID_BIT_VECTOR | A bit of 1 in position n means that connID n is allowed in this protection group. Illegal connIDs have their bits set to 0s. | R    | 0xFFFF |

**Table 9-227. Register Call Summary for Register L4\_AP\_PROT\_GROUP\_MEMBERS\_k\_L**

## L4 Interconnects

- [L4 Firewall Address and Protection Registers Setting: \[0\]](#)
- [Operational Modes Configuration: \[1\]](#)
- [L4 Address Protection \(AP\): \[2\] \[3\]](#)

**Table 9-228. L4\_AP\_PROT\_GROUP\_MEMBERS\_k\_H**

|                         |                                                   |              |                                                             |
|-------------------------|---------------------------------------------------|--------------|-------------------------------------------------------------|
| <b>Address Offset</b>   | 0x204 + (0x08*k)                                  | <b>Index</b> | k = 0 to 7 for CORE_AP and PER_AP.<br>k = 0 to 5 for EMU_AP |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-214</a>       |              |                                                             |
| <b>Description</b>      | Define connID bit vectors for a protection group. |              |                                                             |
| <b>Type</b>             | R                                                 |              |                                                             |

|                                                                                             |  |
|---------------------------------------------------------------------------------------------|--|
| 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 |  |
| Reserved                                                                                    |  |

| Bits | Field Name | Description      | Type | Reset       |
|------|------------|------------------|------|-------------|
| 31:0 | Reserved   | Read returns 0's | R    | 0x0000 0000 |

**Table 9-229. Register Call Summary for Register L4\_AP\_PROT\_GROUP\_MEMBERS\_k\_H**

## L4 Interconnects

- [L4 Address Protection \(AP\): \[0\] \[1\]](#)

**Table 9-230. L4\_AP\_PROT\_GROUP\_ROLES\_k\_L**

|                         |                                                     |              |                                                             |
|-------------------------|-----------------------------------------------------|--------------|-------------------------------------------------------------|
| <b>Address Offset</b>   | 0x200 + (0x08*k)                                    | <b>Index</b> | k = 0 to 7 for CORE_AP and PER_AP.<br>k = 0 to 5 for EMU_AP |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-214</a>         |              |                                                             |
| <b>Description</b>      | Define MReqInfo bit vectors for a protection group. |              |                                                             |
| <b>Type</b>             | R                                                   |              |                                                             |

|                                                                                             |  |
|---------------------------------------------------------------------------------------------|--|
| 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 |  |
| Reserved                                                                                    |  |

| Bits  | Field Name | Description                                                                                | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Read returns 0                                                                             | R    | 0x0000 |
| 15:0  | ENABLE     | Setting of type acces allowed for the group of initiators see <a href="#">Table 9-22</a> . | R    | 0xFFFF |

**Table 9-231. Register Call Summary for Register L4\_AP\_PROT\_GROUP\_ROLES\_k\_L**

## L4 Interconnects

- [L4 Firewall Address and Protection Registers Setting: \[0\]](#)
- [Operational Modes Configuration: \[1\]](#)
- [L4 Address Protection \(AP\): \[2\] \[3\]](#)

**Table 9-232. L4\_AP\_PROT\_GROUP\_ROLES\_k\_H**

|                         |                                                   |              |                                                             |
|-------------------------|---------------------------------------------------|--------------|-------------------------------------------------------------|
| <b>Address Offset</b>   | 0x204 + (0x08*k)                                  | <b>Index</b> | k = 0 to 7 for CORE_AP and PER_AP.<br>k = 0 to 5 for EMU_AP |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-214</a>       |              |                                                             |
| <b>Description</b>      | Define connID bit vectors for a protection group. |              |                                                             |
| <b>Type</b>             | R                                                 |              |                                                             |

|                                                                                             |
|---------------------------------------------------------------------------------------------|
| 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 |
| Reserved                                                                                    |

| Bits | Field Name | Description      | Type | Reset       |
|------|------------|------------------|------|-------------|
| 31:0 | Reserved   | Read returns 0's | R    | 0x0000 0000 |

**Table 9-233. Register Call Summary for Register L4\_AP\_PROT\_GROUP\_ROLES\_k\_H**

## L4 Interconnects

- [L4 Address Protection \(AP\): \[0\] \[1\]](#)

**Table 9-234. L4\_AP\_REGION\_I\_L**

|                         |                                                                                |                       |                                                                                                            |
|-------------------------|--------------------------------------------------------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x300 + (0x08*I)                                                               | <b>Index</b>          | I = 0 to 99 for CORE_AP,<br>I = 0 to 42 for PER_AP,<br>I = 0 to 25 for EMU_AP,<br>I = 0 to 18 for WKUP_AP, |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-214</a>                                    |                       |                                                                                                            |
| <b>Description</b>      | Define the base address of the region in respect to the segment it belongs to. |                       |                                                                                                            |
| <b>Type</b>             | RW                                                                             |                       |                                                                                                            |
| 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                                                                                            |
| Reserved                | BASE                                                                           |                       |                                                                                                            |

| Bits  | Field Name | Description                                                        | Type | Reset                                          |
|-------|------------|--------------------------------------------------------------------|------|------------------------------------------------|
| 31:24 | Reserved   | Read returns 0.                                                    | R    | 0x00                                           |
| 23:0  | BASE       | Sets the base address of this region relative to its segment base. | R    | <a href="#">See Table 9-238 to Table 9-241</a> |

**Table 9-235. Register Call Summary for Register L4\_AP\_REGION\_I\_L**

L4 Interconnects

- [L4 Firewall Address and Protection Registers Setting: \[0\]](#)
- [Operational Modes Configuration: \[1\]](#)
- [L4 Address Protection \(AP\): \[2\] \[3\]](#)

**Table 9-236. L4\_AP\_REGION\_I\_H**

|                         |                                                                |                                      |                                                                                                            |
|-------------------------|----------------------------------------------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x304 + (0x08*I)                                               | <b>Index</b>                         | I = 0 to 99 for CORE_AP,<br>I = 0 to 42 for PER_AP,<br>I = 0 to 25 for EMU_AP,<br>I = 0 to 18 for WKUP_AP, |
| <b>Physical Address</b> | Please refer to <a href="#">Table 9-214</a>                    |                                      |                                                                                                            |
| <b>Description</b>      | Define the size, protection group^and segment ID of the region |                                      |                                                                                                            |
| <b>Type</b>             | RW                                                             |                                      |                                                                                                            |
| 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                                                                                            |
| Reserved                | SEGMENT_ID                                                     | PROT_GROUP_ID<br>BYTE_DATA_WIDTH_EXP | SIZE<br>ENABLE                                                                                             |

| Bits  | Field Name | Description                                            | Type | Reset                                          |
|-------|------------|--------------------------------------------------------|------|------------------------------------------------|
| 31:28 | Reserved   | Read returns 0                                         | R    | 0x0                                            |
| 27:24 | SEGMENT_ID | Identifies the segment to which the region is part of. | R    | <a href="#">See Table 9-238 to Table 9-241</a> |
| 23    | Reserved   | Read returns 0.                                        | R    | 0                                              |

| <b>Bits</b> | <b>Field Name</b>   | <b>Description</b>                                                                                                                                  | <b>Type</b> | <b>Reset</b>                                                         |
|-------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------------------------------------------|
| 22:20       | PROT_GROUP_ID       | The protection group containing this region.                                                                                                        | RW          | See<br><a href="#">Table 9-238</a> to<br><a href="#">Table 9-241</a> |
| 19:17       | BYTE_DATA_WIDTH_EXP | The target OCP data byte width is $2^{(BYTE\_DATA\_WIDTH\_EXP)}$ bytes. The value of this field is derived from the target OCP data_wdth parameter. | R           | See<br><a href="#">Table 9-238</a> to<br><a href="#">Table 9-241</a> |
| 16:6        | Reserved            | Read returns 0.                                                                                                                                     | R           | 0x0                                                                  |
| 5:1         | SIZE                | Define the size of the region in bytes. $2^{\text{SIZE}}$ equals the region.                                                                        | R           | See<br><a href="#">Table 9-238</a> to<br><a href="#">Table 9-241</a> |
| 0           | ENABLE              | 0x0: Disable the region, no access allows<br>0x1: Enable the region, with access as define in registers                                             | R           | See<br><a href="#">Table 9-238</a> to<br><a href="#">Table 9-241</a> |

**Table 9-237. Register Call Summary for Register L4\_AP\_REGION\_I\_H**

## L4 Interconnects

- Protection Mechanism: [0]
- L4 Firewall Address and Protection Registers Setting: [1]
- L4 Address Protection (AP): [2] [3]

**Table 9-238. Reset Values for CORE\_AP L4\_AP\_REGION\_I\_L and L4\_AP\_REGION\_I\_H**

| <b>y</b> | <b>BASE</b> | <b>SEGMENT_ID</b> | <b>PROT_GROUP_ID</b> | <b>BYTE_DATA_WIDTH_EXP</b> | <b>SIZE</b> |
|----------|-------------|-------------------|----------------------|----------------------------|-------------|
| 0        | 0x00 0000   | 1                 | 0                    | 2                          | 0x0B        |
| 1        | 0x00 0800   | 1                 | 7                    | 2                          | 0x0B        |
| 2        | 0x00 1000   | 1                 | 7                    | 2                          | 0x0C        |
| 3        | 0x01 0000   | 1                 | 2                    | 2                          | 0x0A        |
| 4        | 0x01 0400   | 1                 | 2                    | 2                          | 0x0A        |
| 5        | 0x01 0800   | 1                 | 2                    | 2                          | 0x0A        |
| 6        | 0x01 0C00   | 1                 | 2                    | 2                          | 0x0A        |
| 7        | 0x01 1000   | 1                 | 2                    | 2                          | 0X0C        |
| 8        | 0x00 0000   | 3                 | 3                    | 2                          | 0x0C        |
| 9        | 0x01 6000   | 1                 | 7                    | 2                          | 0x0C        |
| 10       | 0x01 7000   | 1                 | 7                    | 2                          | 0x0C        |
| 11       | 0x01 8000   | 1                 | 7                    | 2                          | 0x0C        |
| 12       | 0x01 C000   | 1                 | 7                    | 2                          | 0x0C        |
| 13       | 0x02 B000   | 2                 | 7                    | 2                          | 0x0C        |
| 14       | 0x02 C000   | 2                 | 7                    | 2                          | 0x0C        |
| 15       | 0x01 E000   | 1                 | 7                    | 2                          | 0x0C        |
| 16       | 0x01 F000   | 1                 | 7                    | 2                          | 0x0C        |
| 17       | 0x02 A000   | 1                 | 7                    | 2                          | 0x0C        |
| 18       | 0x02 B000   | 1                 | 7                    | 2                          | 0x0C        |
| 19       | 0x02 C000   | 1                 | 7                    | 2                          | 0X0C        |
| 20       | 0x02 D000   | 1                 | 7                    | 2                          | 0x0C        |
| 21       | 0x03 0000   | 1                 | 7                    | 1                          | 0x0C        |
| 22       | 0x03 1000   | 1                 | 7                    | 1                          | 0x0C        |

**Table 9-238. Reset Values for CORE\_AP L4\_AP\_REGION\_I\_L and L4\_AP\_REGION\_I\_H (continued)**

| y  | BASE      | SEGMENT_ID | PROT_GROUP_ID | BYTE_DATA_WIDTH_EXP | SIZE |
|----|-----------|------------|---------------|---------------------|------|
| 23 | 0x03 2000 | 1          | 7             | 1                   | 0x0C |
| 24 | 0x03 3000 | 1          | 7             | 1                   | 0x0C |
| 25 | 0x03 4000 | 1          | 7             | 2                   | 0x0C |
| 26 | 0x03 5000 | 1          | 7             | 2                   | 0x0C |
| 27 | 0x00 6000 | 2          | 7             | 2                   | 0x0C |
| 28 | 0x00 7000 | 2          | 7             | 2                   | 0x0C |
| 29 | 0x00 8000 | 2          | 7             | 2                   | 0x0C |
| 30 | 0x00 9000 | 2          | 7             | 2                   | 0x0C |
| 31 | 0x00 9000 | 3          | 7             | 2                   | 0x0C |
| 32 | 0x00 A000 | 3          | 7             | 2                   | 0x0C |
| 33 | 0x01 2000 | 2          | 7             | 2                   | 0x0C |
| 34 | 0x01 3000 | 2          | 7             | 2                   | 0x0C |
| 35 | 0x01 4000 | 2          | 7             | 2                   | 0x0C |
| 36 | 0x01 5000 | 2          | 7             | 2                   | 0x0C |
| 37 | 0x01 8000 | 2          | 7             | 2                   | 0x0C |
| 38 | 0x01 9000 | 2          | 7             | 2                   | 0x0C |
| 39 | 0x01 A000 | 2          | 7             | 2                   | 0x0C |
| 40 | 0x01 B000 | 2          | 7             | 2                   | 0x0C |
| 41 | 0x01 C000 | 2          | 7             | 2                   | 0x0C |
| 42 | 0x01 D000 | 2          | 7             | 2                   | 0x0C |
| 43 | 0x03 4000 | 2          | 7             | 2                   | 0x0C |
| 44 | 0x03 5000 | 2          | 7             | 2                   | 0x0C |
| 45 | 0x01 E000 | 2          | 7             | 2                   | 0x0C |
| 46 | 0x01 F000 | 2          | 7             | 2                   | 0x0C |
| 47 | 0x02 0000 | 2          | 1             | 2                   | 0x0C |
| 48 | 0x02 1000 | 2          | 1             | 2                   | 0x0C |
| 49 | 0x02 2000 | 2          | 1             | 2                   | 0x0C |
| 50 | 0x02 3000 | 2          | 1             | 2                   | 0x0C |
| 51 | 0x02 4000 | 2          | 1             | 2                   | 0x0C |
| 52 | 0x02 5000 | 2          | 1             | 2                   | 0x0C |
| 53 | 0x02 6000 | 2          | 1             | 2                   | 0x0C |
| 54 | 0x02 7000 | 2          | 1             | 2                   | 0x0C |
| 55 | 0x02 8000 | 2          | 1             | 2                   | 0x0D |
| 56 | 0x02 A000 | 2          | 1             | 2                   | 0x0C |
| 57 | 0x03 0000 | 2          | 7             | 2                   | 0x0C |
| 58 | 0x03 1000 | 2          | 7             | 2                   | 0x0C |
| 59 | 0x03 2000 | 2          | 7             | 2                   | 0x0C |
| 60 | 0x03 3000 | 2          | 7             | 2                   | 0x0C |
| 61 | 0x01 6000 | 2          | 7             | 2                   | 0x0C |
| 62 | 0x01 7000 | 2          | 7             | 2                   | 0x0C |
| 63 | 0x01 9000 | 1          | 7             | 2                   | 0x0C |
| 64 | 0x01 A000 | 1          | 7             | 2                   | 0x0C |
| 65 | 0x01 B000 | 1          | 7             | 2                   | 0x0C |
| 66 | 0x03 8000 | 2          | 7             | 2                   | 0x0C |
| 67 | 0x03 9000 | 2          | 7             | 2                   | 0x0C |
| 68 | 0x00 4000 | 0          | 7             | 2                   | 0x0C |
| 69 | 0x00 7000 | 0          | 7             | 2                   | 0x0C |

**Table 9-238. Reset Values for CORE\_AP L4\_AP\_REGION\_I\_L and L4\_AP\_REGION\_I\_H (continued)**

| <b>y</b> | <b>BASE</b> | <b>SEGMENT_ID</b> | <b>PROT_GROUP_ID</b> | <b>BYTE_DATA_WIDTH_EXP</b> | <b>SIZE</b> |
|----------|-------------|-------------------|----------------------|----------------------------|-------------|
| 70       | 0x00 B000   | 3                 | 7                    | 2                          | 0x0C        |
| 71       | 0x00 C000   | 3                 | 7                    | 2                          | 0x0C        |
| 72       | 0x00 6000   | 0                 | 7                    | 2                          | 0x0B        |
| 73       | 0x02 0000   | 1                 | 7                    | 1                          | 0x0C        |
| 74       | 0x02 1000   | 1                 | 7                    | 1                          | 0x0C        |
| 75       | 0x00 2000   | 0                 | 7                    | 2                          | 0x0C        |
| 76       | 0x00 3000   | 0                 | 7                    | 2                          | 0x0C        |
| 77       | 0x03 C000   | 2                 | 3                    | 3                          | 0x0C        |
| 78       | 0x00 4000   | 4                 | 4                    | 2                          | 0x0D        |
| 79       | 0x03 A000   | 2                 | 7                    | 2                          | 0x0C        |
| 80       | 0x03 B000   | 2                 | 7                    | 2                          | 0x0C        |
| 81       | 0x00 0000   | 5                 | 7                    | 2                          | 0x0C        |
| 82       | 0x00 1000   | 3                 | 1                    | 2                          | 0x0C        |
| 83       | 0x00 2000   | 3                 | 1                    | 2                          | 0x0C        |
| 84       | 0x00 3000   | 3                 | 1                    | 2                          | 0x0C        |
| 85       | 0x00 4000   | 3                 | 1                    | 2                          | 0x0C        |
| 86       | 0x00 5000   | 3                 | 1                    | 2                          | 0x0C        |
| 87       | 0x00 6000   | 3                 | 1                    | 2                          | 0x0C        |
| 88       | 0x03 6000   | 2                 | 7                    | 2                          | 0x0C        |
| 89       | 0x03 7000   | 2                 | 7                    | 2                          | 0x0C        |
| 90       | 0x00 7000   | 3                 | 7                    | 2                          | 0x0C        |
| 91       | 0x00 8000   | 3                 | 7                    | 2                          | 0x0C        |
| 92       | 0x00 D000   | 3                 | 7                    | 2                          | 0x0C        |
| 93       | 0x00 E000   | 3                 | 7                    | 2                          | 0x0C        |
| 94       | 0x00 6000   | 4                 | 7                    | 2                          | 0x0D        |
| 95       | 0x00 8800   | 4                 | 7                    | 2                          | 0x0B        |
| 96       | 0x00 9000   | 4                 | 7                    | 2                          | 0x0C        |
| 97       | 0x00 C000   | 4                 | 1                    | 2                          | 0x0D        |
| 98       | 0x01 0000   | 4                 | 7                    | 2                          | 0x10        |
| 99       | 0x02 0000   | 4                 | 7                    | 2                          | 0x10        |

**Table 9-239. Reset Values for PER\_AP L4\_AP\_REGION\_I\_L and L4\_AP\_REGION\_I\_H**

| <b>y</b> | <b>BASE</b> | <b>SEGMENT_ID</b> | <b>PROT_GROUP_ID</b> | <b>BYTE_DATA_WIDTH_EXP</b> | <b>SIZE</b> |
|----------|-------------|-------------------|----------------------|----------------------------|-------------|
| 0        | 0x00 0000   | 0                 | 0                    | 2                          | 0x0B        |
| 1        | 0x00 0800   | 0                 | 7                    | 2                          | 0x0B        |
| 2        | 0x00 1000   | 0                 | 7                    | 2                          | 0x0C        |
| 3        | 0x00 0000   | 1                 | 7                    | 2                          | 0x0C        |
| 4        | 0x00 1000   | 1                 | 7                    | 2                          | 0x0C        |
| 5        | 0x00 2000   | 1                 | 7                    | 2                          | 0x0C        |
| 6        | 0x00 3000   | 1                 | 7                    | 2                          | 0x0C        |
| 7        | 0x00 4000   | 1                 | 7                    | 2                          | 0x0C        |
| 8        | 0x00 5000   | 1                 | 7                    | 2                          | 0x0C        |
| 9        | 0x00 6000   | 1                 | 7                    | 2                          | 0x0C        |
| 10       | 0x00 7000   | 1                 | 7                    | 2                          | 0x0C        |
| 11       | 0x00 0000   | 1                 | 7                    | 2                          | 0x0C        |
| 12       | 0x00 1000   | 2                 | 7                    | 2                          | 0x0C        |

**Table 9-239. Reset Values for PER\_AP L4\_AP\_REGION\_I\_L and L4\_AP\_REGION\_I\_H (continued)**

| y  | BASE      | SEGMENT_ID | PROT_GROUP_ID | BYTE_DATA_WIDTH_EXP | SIZE |
|----|-----------|------------|---------------|---------------------|------|
| 13 | 0x00 2000 | 2          | 7             | 2                   | 0x0C |
| 14 | 0x00 3000 | 2          | 7             | 2                   | 0x0C |
| 15 | 0x00 4000 | 2          | 7             | 2                   | 0x0C |
| 16 | 0x00 5000 | 2          | 7             | 2                   | 0x0C |
| 17 | 0x00 6000 | 2          | 7             | 2                   | 0x0C |
| 18 | 0x00 7000 | 2          | 7             | 2                   | 0x0C |
| 19 | 0x00 8000 | 2          | 7             | 2                   | 0x0C |
| 20 | 0x00 9000 | 2          | 7             | 2                   | 0x0C |
| 21 | 0x00 A000 | 2          | 7             | 1                   | 0x0C |
| 22 | 0x00 B000 | 2          | 7             | 2                   | 0x0C |
| 23 | 0x00 C000 | 2          | 7             | 2                   | 0x0C |
| 24 | 0x00 D000 | 2          | 7             | 2                   | 0x0C |
| 25 | 0x00 E000 | 2          | 7             | 2                   | 0x0C |
| 26 | 0x00 F000 | 2          | 7             | 2                   | 0x0C |
| 27 | 0x00 0000 | 3          | 7             | 2                   | 0x0C |
| 28 | 0x00 1000 | 3          | 7             | 2                   | 0x0C |
| 29 | 0x00 0000 | 4          | 7             | 2                   | 0x0C |
| 30 | 0x00 1000 | 4          | 7             | 2                   | 0x0C |
| 31 | 0x00 2000 | 4          | 7             | 2                   | 0x0C |
| 32 | 0x00 3000 | 4          | 7             | 2                   | 0x0C |
| 33 | 0x00 4000 | 4          | 7             | 2                   | 0x0C |
| 34 | 0x00 5000 | 4          | 7             | 2                   | 0x0C |
| 35 | 0x00 6000 | 4          | 7             | 2                   | 0x0C |
| 36 | 0x00 7000 | 4          | 7             | 2                   | 0x0C |
| 37 | 0x00 8000 | 4          | 7             | 2                   | 0x0C |
| 38 | 0x00 9000 | 4          | 7             | 2                   | 0x0C |
| 39 | 0x00 8000 | 4          | 7             | 2                   | 0x0C |
| 40 | 0x00 9000 | 1          | 7             | 2                   | 0x0C |
| 41 | 0x00 A000 | 1          | 7             | 2                   | 0x0C |
| 42 | 0x00 B000 | 1          | 7             | 2                   | 0x0C |

**Table 9-240. Reset Values for EMU\_AP L4\_AP\_REGION\_I\_L and L4\_AP\_REGION\_I\_H**

| y  | BASE      | SEGMENT_ID | PROT_GROUP_ID | BYTE_DATA_WIDTH_EXP | SIZE |
|----|-----------|------------|---------------|---------------------|------|
| 0  | 0x00 0000 | 2          | 5             | 2                   | 0x14 |
| 1  | 0x00 4000 | 0          | 5             | 2                   | 0x0C |
| 2  | 0x00 5000 | 0          | 5             | 2                   | 0x0C |
| 3  | 0x00 6000 | 0          | 5             | 0                   | 0xB  |
| 4  | 0x00 6800 | 0          | 5             | 2                   | 0xB  |
| 5  | 0x00 7000 | 0          | 5             | 2                   | 0xB  |
| 6  | 0x00 8000 | 0          | 5             | 2                   | 0xC  |
| 7  | 0x01 8000 | 0          | 3             | 2                   | 0xC  |
| 8  | 0x01 9000 | 0          | 3             | 2                   | 0xC  |
| 9  | 0x01 A000 | 0          | 3             | 2                   | 0xC  |
| 10 | 0x01 B000 | 0          | 3             | 2                   | 0xC  |
| 11 | 0x01 C000 | 0          | 3             | 2                   | 0xC  |
| 12 | 0x01 D000 | 0          | 3             | 2                   | 0xC  |

**Table 9-240. Reset Values for EMU\_AP L4\_AP\_REGION\_I\_L and L4\_AP\_REGION\_I\_H (continued)**

| <b>y</b> | <b>BASE</b> | <b>SEGMENT_ID</b> | <b>PROT_GROUP_ID</b> | <b>BYTE_DATA_WIDTH_EXP</b> | <b>SIZE</b> |
|----------|-------------|-------------------|----------------------|----------------------------|-------------|
| 13       | 0x01 E000   | 0                 | 3                    | 2                          | 0x0C        |
| 14       | 0x10 0000   | 1                 | 5                    | 2                          | 0x0C        |
| 15       | 0x01 F000   | 0                 | 5                    | 2                          | 0x0C        |
| 16       | 0x01 0000   | 0                 | 3                    | 2                          | 0x0E        |
| 17       | 0x10 6000   | 2                 | 5                    | 2                          | 0x0C        |
| 18       | 0x10 8000   | 2                 | 5                    | 2                          | 0x0C        |
| 19       | 0x10 4000   | 2                 | 2                    | 2                          | 0X0D        |
| 20       | 0x10 8800   | 2                 | 5                    | 2                          | 0x0B        |
| 21       | 0x10 9000   | 2                 | 5                    | 2                          | 0x0C        |
| 22       | 0x10C000    | 2                 | 1                    | 2                          | 0x0D        |
| 23       | 0x11 0000   | 2                 | 5                    | 2                          | 0x10        |
| 24       | 0x12 0000   | 2                 | 5                    | 2                          | 0x10        |
| 25       | 0x13 0000   | 2                 | 5                    | 2                          | 0x0C        |

**Table 9-241. Reset Values for WKUP\_AP L4\_AP\_REGION\_I\_L and L4\_AP\_REGION\_I\_H**

| <b>y</b> | <b>BASE</b> | <b>SEGMENT_ID</b> | <b>PROT_GROUP_ID</b> | <b>BYTE_DATA_WIDTH_EXP</b> | <b>SIZE</b> |
|----------|-------------|-------------------|----------------------|----------------------------|-------------|
| 0        | 0x00 0000   | 1                 | 0                    | 2                          | 0x0B        |
| 1        | 0x00 6000   | 0                 | 0                    | 2                          | 0x0D        |
| 2        | 0x00 9000   | 0                 | 0                    | 2                          | 0x0C        |
| 3        | 0x00 C000   | 0                 | 0                    | 2                          | 0x0C        |
| 4        | 0x00 D000   | 0                 | 0                    | 2                          | 0x0C        |
| 5        | 0x01 8000   | 0                 | 0                    | 2                          | 0x0C        |
| 6        | 0x01 9000   | 0                 | 0                    | 2                          | 0x0C        |
| 7        | 0x01 4000   | 0                 | 0                    | 2                          | 0x0C        |
| 8        | 0x01 5000   | 0                 | 0                    | 2                          | 0x0C        |
| 9        | 0x00 9000   | 1                 | 0                    | 2                          | 0x0C        |
| 10       | 0x00 4000   | 0                 | 0                    | 2                          | 0x0C        |
| 11       | 0x00 5000   | 0                 | 0                    | 2                          | 0x0C        |
| 12       | 0x00 8800   | 1                 | 0                    | 2                          | 0x0B        |
| 13       | 0x00 8000   | 0                 | 0                    | 2                          | 0x0B        |
| 14       | 0x01 0000   | 0                 | 0                    | 2                          | 0x0C        |
| 15       | 0x01 1000   | 0                 | 0                    | 2                          | 0x0C        |
| 16       | 0x00 0000   | 1                 | 0                    | 2                          | 0x0C        |
| 17       | 0x00 1000   | 1                 | 0                    | 2                          | 0x0C        |
| 18       | 0x00 A000   | 1                 | 0                    | 2                          | 0x0C        |



## **Memory Subsystem**

This chapter describes the memory subsystem.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                               | Page        |
|-----------------------------------------------------|-------------|
| <b>10.1 General-Purpose Memory Controller .....</b> | <b>2120</b> |
| <b>10.2 SDRAM Controller (SDRC) Subsystem .....</b> | <b>2230</b> |
| <b>10.3 On-Chip Memory Subsystem .....</b>          | <b>2339</b> |

## 10.1 General-Purpose Memory Controller

### 10.1.1 General-Purpose Memory Controller Overview

The general-purpose memory controller (GPMC) is the device unified memory controller (UMC) dedicated to interfacing external memory devices:

- Asynchronous SRAM-like memories and application-specific integrated circuit (ASIC) devices
- Asynchronous, synchronous, and page mode burst NOR flash devices
- NAND flash
- Pseudo-SRAM devices

Figure 10-1 shows the environment of the GPMC.

**Figure 10-1. GPMC Environment**



#### 10.1.1.1 GPMC Features

The GPMC is the device 16-bit external memory controller. The GPMC data access engine provides a flexible programming model for communication with all standard memories. The GPMC supports various accesses:

- Asynchronous read/write access

- Asynchronous read page access (4, 8, 16 Word16)
- Synchronous read/write access
- Synchronous read/write burst access without wrap capability (4, 8, 16 Word16)
- Synchronous read/write burst access with wrap capability (4, 8, 16 Word16)
- Address/data-multiplexed access
- Little- and big-endian access

The GPMC can communicate with a wide range of external devices:

- External asynchronous or synchronous 8-bit wide memory or device (non-burst device)
- External asynchronous or synchronous 16-bit wide memory or device
- External 16-bit nonmultiplexed device with limited address range (2 Kbytes)
- External 16-bit address/data-multiplexed NOR flash device
- External 8-bit and 16-bit NAND flash device
- External 16-bit pseudo-static random access memory (pSRAM) device

The GPMC supports up to eight chip-select regions of programmable size, and programmable base addresses in a total address space of 1 Gbyte.

### **10.1.2 GPMC Environment**

Figure 10-2 and Figure 10-3 show two GPMC external connection options:

- GPMC to 16-bit address/data-multiplexed memory

[Figure 10-2](#) shows a connection between the GPMC and a 16-bit synchronous address/data-multiplexed external memory device.

- GPMC to 16-bit NAND device

[Figure 10-3](#) shows a connection between the GPMC and a 16-bit NAND device.

**Figure 10-2. GPMC to 16-Bit Address/Data-Multiplexed Memory**



gpmc-002

**NOTE:** The device does not provide the A0 byte address line required for random-byte addressable 8-bit-wide device interfacing (for multiplexed and nonmultiplexed protocol). Hence, an 8-bit device must be connected to the D[7:0] / gpmc\_d[7:0] data bus (rather than D[15:8] / gpmc\_d[15:8]) of the GPMC. This limits the use of 8-bit-wide device interfacing to byte-alias access.

Figure 10-3. GPMC to 16-Bit NAND Device



gpmc-003

**NOTE:** The device does not provide the A0 byte address line required for random-byte addressable 8-bit-wide device interfacing (for multiplexed and nonmultiplexed protocol). Hence, an 8-bit device must be connected to the D[7:0]/gpmc\_d[7:0] data bus (rather than D[15:8]/gpmc\_d[15:8]) of the GPMC. This limits the use of 8-bit-wide device interfacing to byte-alias accesses.

Table 10-1 lists the GPMC subsystem I/O pins.

Table 10-1. GPMC I/O Description

| Pin Name      | I/O | Description                                                                                             |
|---------------|-----|---------------------------------------------------------------------------------------------------------|
| gpmc_a[11:1]  | O   | Address                                                                                                 |
| gpmc_d[15:0]  | I/O | Data                                                                                                    |
| gpmc_ncs[7:0] | O   | Chip-selects (active low)                                                                               |
| gpmc_clk      | I/O | Clock <sup>(1)</sup>                                                                                    |
| gpmc_nadv_ale | O   | Address valid (active low). Also used as address latch enable (active high) for NAND protocol memories. |
| gpmc_noe_nre  | O   | Output enable (active low). Also used as read enable (active low) for NAND protocol memories.           |
| gpmc_nwe      | O   | Write enable (active low)                                                                               |
| gpmc_nbe0_cle | O   | Lower-byte enable (active low). Also used as command latch enable for NAND protocol memories.           |

<sup>(1)</sup> This output signal is also used as retiming input (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to 1).

**Table 10-1. GPMC I/O Description (continued)**

| Pin Name       | I/O | Description                                                                                                                                                                           |
|----------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gpmc_nbe1      | O   | Byte 1 enable (active low)                                                                                                                                                            |
| gpmc_nwp       | O   | Write protect (active low)                                                                                                                                                            |
| gpmc_wait[3:0] | I   | External wait signal for NOR and NAND protocol memories                                                                                                                               |
| gpmc_io_dir    | O   | gpmc_d[15:0] signal direction control:<br>Low during transmit (for write access: data OUT from GPMC to memory),<br>High during receive (for read access: data IN from memory to GPMC) |

Table 10-2 shows the use of address and data GPMC pins based on the type of external device.

**Table 10-2. GPMC Pin Multiplexing Options**

| GPMC Pin   | Multiplexed Address Data<br>16-Bit Device | 16-Bit NAND Device | 8-Bit NAND Device |
|------------|-------------------------------------------|--------------------|-------------------|
| gpmc_a[11] | A27                                       | Not used           | Not used          |
| gpmc_a[10] | A26                                       | Not used           | Not used          |
| gpmc_a[9]  | A25                                       | Not used           | Not used          |
| gpmc_a[8]  | A24                                       | Not used           | Not used          |
| gpmc_a[7]  | A23                                       | Not used           | Not used          |
| gpmc_a[6]  | A22                                       | Not used           | Not used          |
| gpmc_a[5]  | A21                                       | Not used           | Not used          |
| gpmc_a[4]  | A20                                       | Not used           | Not used          |
| gpmc_a[3]  | A19                                       | Not used           | Not used          |
| gpmc_a[2]  | A18                                       | Not used           | Not used          |
| gpmc_a[1]  | A17                                       | Not used           | Not used          |
| gpmc_d[15] | A16/D15                                   | D15                | Not used          |
| gpmc_d[14] | A15/D14                                   | D14                | Not used          |
| gpmc_d[13] | A14/D13                                   | D13                | Not used          |
| gpmc_d[12] | A13/D12                                   | D12                | Not used          |
| gpmc_d[11] | A12/D11                                   | D11                | Not used          |
| gpmc_d[10] | A11/D10                                   | D10                | Not used          |
| gpmc_d[9]  | A10/D9                                    | D9                 | Not used          |
| gpmc_d[8]  | A9/D8                                     | D8                 | Not used          |
| gpmc_d[7]  | A8/D7                                     | D7                 | D7                |
| gpmc_d[6]  | A7/D6                                     | D6                 | D6                |
| gpmc_d[5]  | A6/D5                                     | D5                 | D5                |
| gpmc_d[4]  | A5/D4                                     | D4                 | D4                |
| gpmc_d[3]  | A4/D3                                     | D3                 | D3                |
| gpmc_d[2]  | A3/D2                                     | D2                 | D2                |
| gpmc_d[1]  | A2/D1                                     | D1                 | D1                |
| gpmc_d[0]  | A1/D0                                     | D0                 | D0                |

Enabling the GPMC.GPMC\_CONFIG[1] LIMITEDADDRESS bit forces A[26:11] to 1 on the GPMC I/O side. Thus, only devices with 2 Kbytes of addressing space can be accessed using gpmc\_a[11:1].

With all device types, the GPMC does not drive unnecessary address lines. They stay at their reset value of 0x00.

Address mapping supports address/data-multiplexed 16-bit wide devices:

- To minimize the number of IC pins required for the external memory connection, the NOR flash memory controller supports multiplexed address and data memory devices without adding logic externally.

- Multiplexing mode can be selected through the GPMC.GPMC\_CONFIG1[i][9] MUXADDATA bit ( $i = 0$  to 7).
- Asynchronous page mode is not supported for multiplexed address and data devices.

### 10.1.3 GPMC Integration

#### 10.1.3.1 Description

Figure 10-4 shows how the GPMC interacts with other modules in the device.

**Figure 10-4. GPMC Integration in the Device**



### 10.1.3.2 Clocking, Reset, and Power-Management Scheme

#### 10.1.3.2.1 Clocking

The GPMC uses a single clock, GPMC\_FCLK, which comes internally from the power, reset, and clock-management (PRCM) module and runs at the L3 interconnect frequency. Its source is the PRCM module, CORE\_L3\_ICLK output. CORE\_L3\_ICLK belongs to the L3 interconnect clock domain.

For details, see [Chapter 3, Power, Reset, and Clock Management](#).

GPMC\_CLK is the external clock provided to the attached synchronous memory or device. The GPMC\_CLK clock frequency is the GPMC\_FCLK clock frequency divided by 1, 2, 3, or 4, depending on the GPMC.[GPMC\\_CONFIG1\\_i\[1:0\]](#) GPMCFCLKDIVIDER bit field (where i = 0 to 7).

---

**NOTE:** When the GPMC is configured for synchronous mode, the GPMC\_CLK signal (which is an output) must also be set as an input (CONTROL.CONTROL\_PADCONF\_GPMC\_NCS7[24] INPUTENABLE1 = 1). GPMC\_CLK is looped back through the output and input buffers of the corresponding GPMC\_CLK pad at the device boundary. The looped-back clock is used to synchronize the sampling of the memory signals.

---

#### 10.1.3.2.2 Hardware Reset

A global reset of the GPMC occurs through activation of the CORE\_RSTRET signal (CORE power domain) controlled by the PRCM module (see [Chapter 3, Power, Reset, and Clock Management](#)). The CORE\_RSTRET signal is activated during IC global power-on and global warm reset, and it resets the controller state machine and configuration registers.

#### 10.1.3.2.3 Software Reset

GPMC modules can be reset under software control through the GPMC.[GPMC\\_SYSConfig\[1\]](#) SOFTRESET bit. When software reset bit is set, all registers and the finite state-machine (FSM) are reset immediately and unconditionally. The GPMC.[SYSSTATUS\[0\]](#) RESETDONE bit can be polled to check reset status.

#### 10.1.3.2.4 Power Domain, Power Saving, and Reset Management

GPMC power is supplied by the CORE power domain, and GPMC power management complies with system power-management guidelines.

The GPMC reduces power consumption through auto-idle mode and the idle request/acknowledge process, both of which are configurable:

- Dynamic auto-idle (configurable through the GPMC.[GPMC\\_SYSConfig\[0\]](#) AUTOIDLE bit): To reduce power consumption, the GPMC internally disables the functional clock when no requests are pending and no accesses are ongoing.
- Idle request/acknowledge (one of three idle modes configurable through the GPMC.[GPMC\\_SYSConfig\[4:3\]](#) IDLEMODE field):
  - Force-idle: Immediately on receiving an idle request from the PRCM module, the GPMC sends an idle request/acknowledge to let the PRCM module correctly cut the GPMC source clock.
  - No-idle: The GPMC never goes to idle mode.
  - Smart-idle (strongly recommended): The GPMC goes to idle mode when all ongoing transactions are complete.

For detailed information about power management, see [Chapter 3, Power, Reset, and Clock Management](#).

#### 10.1.3.2.5 Hardware Requests

The GPMC uses two hardware requests as shown in [Figure 10-4](#):

- One interrupt request goes from GPMC (GPMC\_IRQ) to the microprocessor unit (MPU) subsystem : M\_IRQ\_20.
- One DMA request goes from GPMC (GPMC\_DMA\_REQ) to the system DMA (sDMA) : S\_DMA\_3.

### 10.1.3.3 GPMC Address and Data Bus

The current application supports GPMC connection to address/data-multiplexed memory and a NAND device. Connection to a nonmultiplexed address/data memory is supported with an address range of only 2 Kbytes.

Depending on the GPMC configuration on each chip-select, address and data-bus lines that are not required for a particular access protocol are not updated (changed from current value) and are not sampled when input (input data bus).

The current application supports GPMC connection to address/data-multiplexed memory, address/data-nonmultiplexed memory with limited address (2 Kbytes), and a NAND device:

- When the GPMC.[GPMC\\_CONFIG\[1\]](#) LIMITEDADDRESS bit is set to 1, only gpmc\_a[11:1] address lines are used. This limits the memory support to 2K-byte addressable memories.
- For address/data-multiplexed NOR devices, the address is multiplexed on the data bus.
- 8-bit wide NOR devices do not use GPMC I/O: gpmc\_d[15:8] for data (they are used for address if needed).
- 16-bit wide NAND devices do not use GPMC I/O: gpmc\_a[11:1] .
- 8-bit wide NAND devices do not use GPMC I/O: gpmc\_a[11:1] and GPMC I/O: gpmc\_d[15:8].

#### CAUTION

Before trying to access a chip-select configured with a nonmultiplexed protocol, set the LIMITEDADDRESS bit control.

#### 10.1.3.3.1 GPMC I/O Configuration Setting (in Default Pinout Mode 0)

---

**NOTE:** In this section, the i in [GPMC\\_CONFIG1\\_i](#) stands for the GPMC chip-select i where i = 0 to 7.

---

The address/data-nonmultiplexed device, which is limited to a 2K-byte address range, is selected by programming the following register fields:

- GPMC.[GPMC\\_CONFIG1\\_i\[11:10\]](#) DEVICETYPE field = 0x00
- GPMC.[GPMC\\_CONFIG1\\_i\[9\]](#) MUXADDDATA bit = 0
- GPMC.[GPMC\\_CONFIG\[1\]](#) LIMITEDADDRESS bit = 1

---

**NOTE:** The LIMITEDADDRESS field applies only to address/data-nonmultiplexed devices; it has no effect on other device types (address/data-multiplexed, NAND).

---

To select the address/data-multiplexed device, program the following register fields:

- GPMC.[GPMC\\_CONFIG1\\_i\[11:10\]](#) DEVICETYPE field = 0b00
- GPMC.[GPMC\\_CONFIG1\\_i\[9\]](#) MUXADDDATA bit = 1

To select the NAND device, program the following register field:

- GPMC.[GPMC\\_CONFIG1\\_i\[11:10\]](#) DEVICETYPE field = 0b10
- GPMC.[GPMC\\_CONFIG1\\_i\[9\]](#) MUXADDDATA bit = 0

### 10.1.3.3.2 GPMC CS0 Default Configuration at IC Reset

To ensure a correct external boot with a GPMC access from IC reset time on CS0, several external pins are sampled:

- The sys\_boot[4:0] pins (device boundary) define the sequence of interfaces and devices to use for booting.
- The sys\_boot[5] pin defines which group of booting sequences is preferred: memory booting (sys\_boot[5] = 0) or peripheral booting (sys\_boot[5] = 1).
- Three additional pins are used to configure reset values in the GPMC.[GPMC\\_CONFIG1\\_i](#) register (where i = 0):
  - The bootwaitein input pin (GPMC boundary) enables the monitoring on chip-select 0 of the WAIT pin at IC reset release time for read accesses. The input pin is used to configure the GPMC.[GPMC\\_CONFIG1\\_i](#)[22] WAITREADMONITORING bit (where i = 0). Its value comes from the BOOT\_WAIT\_ENABLE signal generated by the system control module (SCM). When sys\_boot[5:0] = 0b111111, the BOOT\_WAIT\_ENABLE signal is activated, causing the wait pin to be monitored for read access.
  - The bootdevicesize input pin (GPMC boundary) defines the size of the attached device on chip-select 0 and is used to configure the GPMC.[GPMC\\_CONFIG1\\_i](#)[13:12] DEVICESIZE bits (where i = 0). A BOOT\_DEVICE\_SIZE signal is propagated from the SCM. Its value is fixed at 0x1 at IC reset, causing a 16-bit wide external memory to be used.
  - The cs0muxdevice input pin (GPMC boundary) selects whether the attached device to chip-select 0 is a multiplexed address and data device or not. The input pin is used to configure the GPMC.[GPMC\\_CONFIG1\\_i](#)[9] MUXADDDATA bit (where i = 0). A CS0\_MUX\_DEVICE signal is propagated from the SCM. Its value is fixed at 0x1 at IC reset, causing the attached device to be address/data-multiplexed.
  - The waitselectpin input pin selects the WAIT signal at IC reset release time between WAIT0 input pin or WAIT1 input pin. At IC reset release time, these two pins have different polarity.

#### CAUTION

Using the internal boot code, the entire CS0 configuration can be modified before the first CS0 access. This modification of internal boot code is necessary for two external devices:

- NAND device attached to CS0
- Nonmultiplexed 2-Kbyte address range device attached to CS0

At reset time, the IC may boot from the internal ROM or from the memory attached to the GPMC chip-select 0. This selection is made outside the GPMC.

Reset values of the timing control parameters are defined to cope with direct boot on address and data multiplexed NOR Flash device, on non-multiplexed NOR Flash device or on any asynchronous device with large timing margins assuming a low GPMC\_FCLK frequency (for example, 19.2Mhz) at boot time.

### 10.1.4 GPMC Functional Description

#### 10.1.4.1 Description

As [Figure 10-5](#) shows, the GPMC consists of six blocks:

- L3 interconnect port interface
- Address decoder, GPMC configuration, and chip-select configuration register file
- Access engine
- Prefetch and write-posting engine
- Error correction code engine (ECC)
- External device/memory port interface

**Figure 10-5. GPMC Functional Diagram**

gpmc-005

The GPMC can access various external devices through the L3 Interconnect. The flexible programming model allows a wide range of attached device types and access schemes.

Based on the programmed configuration bit fields stored in the GPMC registers, the GPMC is able to generate all control signals timing depending on the attached device and access type.

Given the chip-select decoding and its associated configuration registers, the GPMC selects the appropriate device type control signals timing.

#### 10.1.4.2 L3 Interconnect Interface

The GPMC L3 interconnect interface is a pipelined interface including an 8 \* 32-bit word write buffer.

Any system host can issue external access requests through the GPMC.

The device system can issue the following requests through this interface:

- One 8-bit/16-bit/32-bit interconnect access (read/write)
- Two incrementing 32-bit interconnect accesses (read/write)
- Two wrapped 32-bit interconnect accesses (read/write)
- Four incrementing 32-bit interconnect accesses (read/write)
- Four wrapped 32-bit interconnect accesses (read/write)
- Eight incrementing 32-bit interconnect accesses (read/write)
- Eight wrapped 32-bit interconnect accesses (read/write)

Only linear burst transactions are supported; interleaved burst transactions are not supported. Only power-of-two-length precise bursts  $2 * 32$ ,  $4 * 32$ , or  $8 * 32$  with the burst base address aligned on the total burst size are supported (this limitation applies to incrementing bursts only).

This interface also provides one interrupt and one DMA request line, for specific event control.

It is recommended to program the ATTACHEDDEVICEPAGELENGTH field ([GPMC\\_CONFIG1\\_i\[24:23\]](#)) according to the effective attached device page length and to enable WRAPBURST bit ([GPMC\\_CONFIG1\\_i\[31\]](#)) if the attached device supports wrapping burst.

However, it is possible to emulate wrapping burst on a non-wrapping memory by providing relevant addresses within the page or splitting transactions. Bursts larger than the memory page length are chopped into multiple bursts transactions. Due to the alignment requirements, a page boundary is never crossed.

#### 10.1.4.3 Address Decoder, GPMC Configuration, and Chip-Select Configuration Register File

Address-decoding logic selects for chip-selects according to the address request and the content of the chip-select base address register file, which includes a set of global GPMC configuration registers and eight sets of chip-select configuration registers.

The GPMC configuration register file is memory-mapped and can be read or written with byte, 16-bit word, or 32-bit word accesses. The register file should be configured as a noncacheable, nonbufferable region to prevent any desynchronization between host execution (write request) and the completion of register configuration (write completed with register updated). [Section 10.1.7](#) of this chapter provides the GPMC register locations. For the map of GPMC memory locations, see [Chapter 2, Memory Mapping](#).

After the chip-select is configured, the access engine accesses the external device, drives the external interface control signals, and applies the interface protocol based on user-defined timing parameters and settings.

#### 10.1.4.4 Error Correction Code Engine

The GPMC includes an error correction code (ECC) calculation engine that allows ECC calculation during data read or data program (write) operations. Two ECC algorithms are available depending on [GPMC\\_ECC\\_CONFIG\[16\]](#) ECCALGORITHM settings: Hamming code or BCH code (Bose-Chaudhuri-Hocquenghem).

The GPMC does not directly handle the error code correction itself. During writes, the GPMC computes parity bits. During reads, the GPMC provides enough information for the processor to correct errors without reading the data buffer all over again.

The Hamming code ECC is based on a 2-dimensional (row and column) bit parity accumulation. This parity accumulation is either accomplished on the programmed number of bytes or Word16s read from the memory device, or written to the memory device in stream mode.

Because the ECC engine includes only one accumulation context, it can be allocated to only one chip-select at a time through the GPMC [GPMC\\_ECC\\_CONFIG\[3:1\]](#) ECCCS bit field.

See [Section 10.1.5.14.3](#) for more information on ECC calculation.

#### 10.1.4.5 Prefetch and Write-Posting Engine

The prefetch and write-posting engine is a simplified embedded-access requester that presents requests to the access engine on a user-defined chip-select target. The access engine interleaves these requests with any request coming from the L3 interface; as a default the prefetch and write-posting engine has the lowest priority.

The prefetch and write-posting engine is dedicated to data-stream access (as opposed to random data access); thus, it is primarily dedicated to NAND support. The engine does not include an address generator; the request is limited to chip-select target identification. It includes a 64-byte FIFO associated with a DMA request synchronization line, for optimal DMA-based use.

For more information about prefetch and write-posting engine programming, see [Section 10.1.5.14.4, Prefetch and Write-Posting Engine](#).

#### 10.1.4.6 External Device/Memory Port Interface

The external port interface controls all address, data, and control signals required for communication with GPMC-supported devices and memories.

### 10.1.5 GPMC Basic Programming Model

The GPMC basic programming model offers maximum flexibility to support various access protocols for each of the eight configurable chip-selects. Use optimal chip-select settings, based on the characteristics of the external device:

- Different protocols can be selected to support generic asynchronous or synchronous random-access devices (NOR flash, SRAM) or to support specific NAND devices.
- The address and the data bus can be multiplexed on the same external bus.
- Read and write access can be independently defined as asynchronous or synchronous.
- System requests (byte, Word16, burst) are performed through single or multiple accesses. External access profiles (single, multiple with optimized burst length, native- or emulated-wrap) are based on external device characteristics (supported protocol, bus width, data buffer size, native-wrap support).
- System burst read or write requests are synchronous-burst (multiple-read or multiple-write). When neither burst nor page mode is supported by external memory or ASIC devices, system burst read or write requests are translated to successive single synchronous or asynchronous accesses (single reads or single writes). 8-bit-wide devices are supported only in single-synchronous or asynchronous read or write mode.
- To simulate a programmable internal-wait state, an external wait pin can be monitored to dynamically control external access at the beginning (initial access time) of and during a burst access.

Each control signal is controlled independently for each chip-select. The internal functional clock of the GPMC (GPMC\_FCLK) is used as a time reference to specify the following:

- Read- and write-access duration
- Most GPMC external interface control-signal assertion and deassertion times
- Data-capture time during read access
- External wait-pin monitoring time
- Duration of idle time between accesses, when required

#### 10.1.5.1 Chip-Select Base Address and Region Size Configuration

Any external memory or ASIC device attached to the GPMC external interface can be accessed by any device system host within the GPMC 1-GB contiguous address space. For details, see [Chapter 2 Memory Mapping](#).

The GPMC 1-GB address space can be divided into a maximum of eight chip-select regions with programmable base address and programmable CS size. The CS size is programmable from 16MB to 256MB (must be a power-of-2) and is defined by the mask field. Attached memory smaller than the programmed CS region size is accessed through the entire CS region (aliasing).

Each chip-select has a 6-bit base address encoding and a 4-bit decoding mask, which must be programmed according to the following rules:

- The programmed chip-select region base address must be aligned on the chip-select region size address boundary and is limited to a power-of-2 address value. During access decoding, the register base address value is used for address comparison with the address-bit line mapping as described in [Figure 10-6](#) (with A0 as the device system byte-address line). Base address is programmed through the [GPMC\\_CONFIG7\\_i\[5:0\] BASEADDRESS](#) bit field
- The register mask is used to exclude some address lines from the decoding. A register mask bit field set to 0 suppresses the associated address line from the address comparison (incoming address bit line is don't care). The register mask value must be limited to the subsequent value, based on the desired chip-select region size. Any other value has an undefined result. When multiple chip-select regions with overlapping addresses are enabled concurrently, access to these chip-select regions is cancelled and a GPMC access error is posted. The mask field is programmed through the [GPMC\\_CONFIG7\\_i\[11:8\] MASKADDRESS](#) bit field.

**Figure 10-6. Chip-Select Address Mapping and Decoding Mask**




---

**NOTE:** GPMC can address up to 256MB on cs0 and cs1, support 128MB on cs2 to cs7

---

Chip-select configuration (base and mask address or any protocol and timing settings) must be performed while the associated chip-select is disabled through the GPMC.[GPMC\\_CONFIG7\\_i\[6\] CSVVALID](#) bit (where i stands for the GPMC chip-select value, i = 0 to 7). In addition, a chip-select configuration can be disabled only if there is no ongoing access to that chip-select. This requires activity monitoring of the prefetch or write-posting engine if the engine is active on the chip-select. Also, the write buffer state must be monitored to wait for any posted write completion to the chip-select.

Conversely, before trying to access a chip-select, software must ensure that the chip-select is enabled. To account for prefetch engine effects, after the chip-select-enable instruction, an NOP instruction (equivalent to 64 bits) must be executed before the chip-select is accessed.

Any access attempted to a nonvalid GPMC address region (CSVVALID disabled or address decoding outside a valid chip-select region) is not propagated to the external interface and a GPMC access error is posted. In case of chip-selects overlapping, an error is generated and no access will occur on either chip-select.

Chip-select 0 is the only chip-select region enabled after either a power-up or a GPMC reset.

**CAUTION**

Although the GPMC interface can drive up to 8 chip-selects, the frequency specified for this interface is for a specific load. If this load is exceeded, the maximum frequency cannot be reached.

**10.1.5.2 Access Protocol Configuration****10.1.5.2.1 Supported Devices**

The access protocol of each chip-select can be independently specified through the GPMC.[GPMC\\_CONFIG1\\_i\[11:10\]](#) DEVICETYPE parameter (where i = 0 to 7) for:

- Random-access synchronous or asynchronous memory like NOR flash, SRAM
- NAND flash asynchronous devices

---

**NOTE:** NAND flash interfacing requires the parameter settings of generic chip-select 0. For more information about the NAND flash GPMC basic programming model and NAND support, see [Section 10.1.5.14, NAND Device Basic Programming Model](#), and [Section 10.1.5.14.1, NAND Memory Device in Byte or Word 16 Stream Mode](#).

---

**10.1.5.2.2 Access Size Adaptation and Device Width**

Each chip-select can be independently configured through the GPMC.[GPMC\\_CONFIG1\\_i\[13:12\]](#) DEVICESIZE field (i = 0 to 7) to interface with a 16-bit wide device or an 8-bit-wide device. System requests with data width greater than the external device data bus width are split into successive accesses according to both the external device data-bus width and little-endian data organization.

---

**NOTE:** The device does not provide the A0 byte address line required for random-byte addressable 8-bit-wide device interfacing (for both multiplexed and nonmultiplexed protocol). It limits the use of 8-bit-wide device interfacing to byte-alias accesses. This limitation is not applicable to NAND device interfacing (8-bit wide or 16-bit wide devices).

---

**10.1.5.2.3 Address/Data-Multiplexing Interface**

For random synchronous or asynchronous memory interfacing (DEVICETYPE = 0b00), an address- and data-multiplexing protocol can be selected through the GPMC.[GPMC\\_CONFIG1\\_i\[9\]](#) MUXADDDATA bit (i = 0 to 7). The nADV signal must be used as the external device address latch control signal. For the associated chip-select configuration, nADV assertion and deassertion time and nOE assertion time must be set to the appropriate value to meet the address latch setup/hold time requirements of the external device. See [Section 10.1.3, GPMC Integration](#).

---

**NOTE:** This address/data-multiplexing interface is not applicable to NAND device interfacing. NAND devices require a specific address, command, and data multiplexing protocol. See [Section 10.1.5.14, NAND Device Basic Programming Model](#).

---

**10.1.5.2.4 Address and Data Bus**

See [Section 10.1.3.3, GPMC Address and Data Bus](#).

**10.1.5.2.5 Asynchronous and Synchronous Access**

For each chip-select configuration, the read access can be specified as either asynchronous or synchronous access through the GPMC.[GPMC\\_CONFIG1\\_i\[29\]](#) READTYPE bit (i = 0 to 7). For each chip-select configuration, the write access can be specified as either synchronous or asynchronous access through the GPMC.[GPMC\\_CONFIG1\\_i\[27\]](#) WRITETYPE bit (i = 0 to 7).

Asynchronous and synchronous read (write) access time and related control signals are controlled through timing parameters that refer to GPMC\_FCLK. The primary difference of synchronous mode is the availability of a configurable clock interface (GPMC\_CLK) to control the external device. Synchronous mode also affects data-capture and wait-pin monitoring schemes in read access.

For details about asynchronous and synchronous access, see the descriptions of GPMC\_CLK, RdAccessTime, WrAccessTime, and wait-pin monitoring.

For more information about timing-parameter settings, see the sample timing diagrams in this chapter.

---

**NOTE:** The address bus and nBE[1:0] are fixed for the duration of a synchronous burst read access, but they are updated for each beat of an asynchronous page-read access.

---

#### 10.1.5.2.6 Page and Burst Support

Each chip-select can be configured to process system single or burst requests into successive single accesses or asynchronous page/synchronous burst accesses, with appropriate access size adaptation.

Depending on the external device page or burst capability, read and write accesses can be independently configured through the GPMC. The [GPMC\\_CONFIG1\\_I\[30\]](#) READMULTIPLE and [GPMC\\_CONFIG1\\_I\[28\]](#) WRITMULTIPLE bits ( $i = 0$  to 7) are associated with the READTYPE and WRITETYPE parameters.

---

**NOTE:**

- Asynchronous write page mode is not supported.
  - 8-bit-wide device support is limited to nonburstable devices (READMULTIPLE and WRITMULTIPLE are don't care).
  - Not applicable to NAND device interfacing.
- 

#### 10.1.5.2.7 System Burst Versus External Device Burst Support

The device system can issue the following requests to the GPMC:

- Byte, Word16, Word32 requests (byte enable controlled). This is always a single request from the interconnect point of view.
- Incrementing fixed-length bursts of two words, four words, and eight words
- Wrapped (critical word access first) fixed-length burst of two, four, or eight words

To process a system request with the optimal protocol, the READMULTIPLE (and READTYPE) and WRITMULTIPLE (and WRITETYPE) parameters must be set according to the burstable capability (synchronous or asynchronous) of the attached device.

The GPMC access engine issues only fixed-length burst. The maximum length that can be issued is defined per CS by the [GPMC\\_CONFIG1\\_I\[24:23\]](#) ATTACHEDDEVICEPAGELENGTH field ( $i = 0$  to 7). When the ATTACHEDDEVICEPAGELENGTH value is less than the system burst request length (including the appropriate access size adaptation according to the device width), the GPMC splits the system burst request into multiple burst beats. Within the specified 4-, 8-, or 16-word value, the ATTACHEDDEVICEPAGELENGTH field value must correspond to the maximum-length burst supported by the memory device configured in fixed-length burst mode (as opposed to continuous burst mode).

To get optimal performance from memory devices that natively support 16 Word16-length-wrapping burst capability (critical word access first), the ATTACHEDDEVICEPAGELENGTH parameter must be set to 16 words and the [GPMC\\_CONFIG1\\_I\[31\]](#) WRAPBURST bit ( $i = 0$  to 7) must be set to 1. Similarly DEVICEPAGELENGTH is set to 4 and 8 for memories supporting respectively 4 and 8 Word16-length-wrapping burst.

When the memory device does not offer (or is not configured to offer) native 16 Word16-length-wrapping burst, the WRAPBURST parameter must be cleared, and the GPMC access engine emulates the wrapping burst by issuing the appropriate burst sequences according to the ATTACHEDDEVICEPAGELENGTH value.

When the memory device does not support native-wrapping burst, there is usually no difference in behavior between a fixed burst length mode and a continuous burst mode configuration (except for a potential power increase from a memory-speculative data prefetch in a continuous burst read). However, even though continuous burst mode is compatible with GPCM behavior, because the GPMC access engine issues only fixed-length burst and does not benefit from continuous burst mode, it is best to configure the memory device in fixed-length burst mode.

The memory device maximum-length burst (configured in fixed-length burst wrap or nonwrap mode) usually corresponds to the memory device data buffer size. Memory devices with a minimum of 16 half-word buffers are the most appropriate (especially with wrap support), but memory devices with smaller buffer size (4 or 8) are also supported, assuming that the GPMC\_GPMC\_CONFIG1\_i[24:23] ATTACHEDDEVICEPAGELENGTH field is set accordingly to 4 or 8 words.

The device system issues only requests with addresses or starting addresses for nonwrapping burst requests; that is, the request size boundary is aligned. In case of an eight-word-wrapping burst, the wrapping address always occurs on the eight-words boundary. As a consequence, all words requested must be available from the memory data buffer when the buffer size is equal to or greater than the ATTACHEDDEVICEPAGELENGTH value. This usually means that data can be read from or written to the buffer at a constant rate (number of cycles between data) without wait states between data accesses. If the memory does not behave this way (nonzero wait state burstable memory), wait-pin monitoring must be enabled to dynamically control data-access completion within the burst beat.

---

**NOTE:** When the system burst request length is less than the ATTACHEDDEVICEPAGELENGTH value, the GPMC proceeds with the required accesses.

---

#### 10.1.5.3 Timing Setting

The GPMC is a signal generator that offers the maximum flexibility to support various access protocols. Most of the timing parameters of the protocol access used by the GPMC to communicate with attached memories or devices are programmable on a chip-select basis. Assertion and deassertion times of control signals are defined to match the attached memory or device timing specifications and to get maximum performance during accesses. For example, the timing diagram in Figure 10-7 shows an asynchronous single-read access performed on an asynchronous device. For more information about GPMC\_CLK and GPMC\_FCLK, see [Section 10.1.5.3.6](#).

**Figure 10-7. Asynchronous Single Read on a Nonmultiplexed Address/Data Device**


#### 10.1.5.3.1 Read Cycle Time and Write Cycle Time (RDCYCLETIME/WRCYCLETIME)

The GPMC.GPMC\_CONFIG5\_i[4:0] RDCYCLETIME and GPMC.GPMC\_CONFIG5\_i[12:8] WRCYCLETIME fields ( $i = 0$  to  $7$ ) define the address bus and byte enables valid times for read and write accesses. To ensure a correct duty cycle of GPMC\_CLK between accesses, RDCYCLETIME and WRCYCLETIME are expressed in GPMC\_FCLK cycles and must be multiples of the GPMC\_CLK cycle.

When either RDCYCLETIME or WRCYCLETIME completes, if they are not already deasserted, all control signals (NCS, nADV/ALE, nOE/RE, nWE, and BE0/CLE) are deasserted to their reset values, regardless of their deassertion time parameters.

An exception to this forced deassertion occurs when a pipelined request to the same chip-select or to a different chip-select is pending. In such a case, it is not necessary to deassert a control signal with deassertion time parameters equal to the cycle-time parameter. This exception to forced deassertion prevents any unnecessary glitchy transition. This requirement also applies to BE signals, thus avoiding an unnecessary BE glitch transition when pipelining requests.

If no inactive cycles are required between successive accesses to the same or to a different chip-select (GPMC.GPMC\_CONFIG6\_i[7] CYCLE2CYCLESAMECSEN = 0 or GPMC.GPMC\_CONFIG6\_i[6] CYCLE2CYCLEDIFFCSEN = 0, where  $i = 0$  to  $7$ ), and if assertion-time parameters associated with the pipelined access are equal to 0, asserted control signals (nCS, nADV/ALE, nBE0/CLE, nWE, and nOE/RE) are kept asserted. This applies to any read/write to read/write access combination.

If inactive cycles are inserted between successive accesses, that is, CYCLE2CYCLESAMECSEN = 1 or CYCLE2CYCLEDIFFCSEN = 1, the control signals are forced to their respective default reset values for the number of GPMC\_FCLK cycles defined in CYCLE2CYCLEDELAY:

- The RDCYCLETIME and WRCYCLETIME bit fields are programmable in the GPMC.[GPMC\\_CONFIG5\\_i](#) register, i = 0 to 7.
- The RDCYCLETIME and WRCYCLETIME bit fields can be set from 0 to 31 GPMC\_FCLK cycles with a granularity of 1 for GPMC.[GPMC\\_CONFIG1\\_i\[4\]](#) TIMEPARAGRANULARITY set to 0.
- The RDCYCLETIME and WRCYCLETIME bit fields can be set from 0 to 62 GPMC\_FCLK cycles with a granularity of 2 for GPMC.[GPMC\\_CONFIG1\\_i\[4\]](#) TIMEPARAGRANULARITY set to 1.

#### **10.1.5.3.2 nCS: Chip-Select Signal Control Assertion/Deassertion Time (CSONTIME/CSRDOFFTIME/CSWROFFTIME/CSEXTRADELAY)**

The GPMC.[GPMC\\_CONFIG2\\_i\[3:0\]](#) CSONTIME field (where i = 0 to 7) defines the nCS signal-assertion time relative to the start access time. It is common for read and write accesses.

For a read access, the GPMC.[GPMC\\_CONFIG2\\_i\[12:8\]](#) CSRDOFFTIME field defines the nCS signal deassertion time relative to start access time.

For a write access, the GPMC.[GPMC\\_CONFIG2\\_i\[20:16\]](#) CSWROFFTIME field defines the nCS signal deassertion time relative to start access time.\

CSONTIME, CSRDOFFTIME and CSWROFFTIME parameters are applicable to synchronous and asynchronous modes. CSONTIME can be used to control an address and byte enable setup time before chip-select assertion. CSRDOFFTIME and CSWROFFTIME can be used to control an address and byte enable hold time after chip-select deassertion.

nCS signal transitions as controlled through CSONTIME, CSRDOFFTIME, and CSWROFFTIME can be delayed by half a GPMC\_FCLK period by enabling the GPMC.[GPMC\\_CONFIG2\\_i\[7\]](#) CSEXTRADELAY bit. This half of a GPMC\_FCLK period provides more granularity on the nCS assertion and deassertion time to guarantee proper setup and hold time relative to GPMC\_CLK. CSEXTRADELAY is especially useful in configurations where GPMC\_CLK and GPMC\_FCLK have the same frequency, but can be used for all GPMC configurations. If asserted, CSEXTRADELAY applies to all parameters controlling nCS transitions.

The CSEXTRADELAY bit must be used carefully to avoid control-signal overlap between successive accesses to different chip-selects. This implies the need to program the RDCYCLETIME and WRCYCLETIME bit fields to be greater than the nCS signal-deassertion time, including the extra half-GPMC\_FCLK-period delay.

#### **10.1.5.3.3 nADV/ALE: Address Valid/Address Latch Enable Signal Control Assertion/Deassertion Time (ADVONTIME/ADVRDOFFTIME/ADVWROFFTIME/ADVEXTRADELAY)**

The GPMC.[GPMC\\_CONFIG3\\_i\[3:0\]](#) ADVONTIME field (where i = 0 to 7) defines the nADV/ALE signal-assertion time relative to start access time. It is common to read and write accesses.

For a read access, the GPMC.[GPMC\\_CONFIG3\\_i\[12:8\]](#) ADVRDOFFTIME field defines the nADV/ALE signal-deassertion time relative to start access time.

For a write access, the GPMC.[GPMC\\_CONFIG3\\_i\[20:16\]](#) ADVWROFFTIME field defines the nADV/ALE signal-deassertion time relative to start access time.

ADVONTIME can be used to control an address and byte enable valid setup time control before nADV/ALE assertion. ADVRDOFFTIME and ADVWROFFTIME can be used to control an address and byte enable valid hold time control after nADV/ALE de-assertion. ADVRDOFFTIME and ADVWROFFTIME are applicable to both synchronous and asynchronous modes.

nADV/ALE signal transitions as controlled through ADVONTIME, ADVRDOFFTIME, and ADVWROFFTIME can be delayed by half a GPMC\_FCLK period by enabling the GPMC.[GPMC\\_CONFIG3\\_i\[7\]](#) ADVEXTRADELAY bit. This half of a GPMC\_FCLK period provides more granularity on nADV/ALE assertion and deassertion time to guarantee proper setup and hold time relative to GPMC\_CLK. The ADVEXTRADELAY configuration parameter is especially useful in configurations where GPMC\_CLK and GPMC\_FCLK have the same frequency, but can be used for all GPMC configurations. If asserted, ADVEXTRADELAY applies to all parameters controlling nADV/ALE transitions.

ADVEXTRADELAY must be used carefully to avoid control-signal overlap between successive accesses to different chip-selects. This implies the need to program the RDCYCLETIME and WRCYCLETIME bit fields to be greater than nADV/ALE signal-deassertion time, including the extra half-GPMC\_FCLK-period delay.

See [Section 10.1.5.14](#) for more details about ADVONTIME, ADVRDOFFTIME, and ADVWROFFTIME use for command (CLE) and address latch enable (ALE) use for a NAND flash interface.

#### 10.1.5.3.4 *nOE/nRE: Output Enable/Read Enable Signal Control Assertion/Deassertion Time (OEONTIME/OEOFETIME/OEEXTRADELAY)*

The GPMC.[GPMC\\_CONFIG4\\_i](#)[3:0] OEONTIME field (where i = 0 to 7) defines the nOE/nRE signal assertion time relative to start access time. It is applicable only to read accesses.

The GPMC.[GPMC\\_CONFIG4\\_i](#)[12:8] OEOFETIME field defines the nOE/nRE signal deassertion time relative to start access time. It is applicable only to read accesses.

OEONTIME and OEOFETIME parameters are applicable to synchronous and asynchronous modes. OEONTIME can be used to control an address and byte enable valid setup time control before nOE/nRE assertion. OEOFETIME can be used to control an address and byte enable valid hold time control after nOE/nRE assertion.

The nOE/RE signal transitions as controlled through OEONTIME, and OEOFETIME can be delayed by half a GPMC\_FCLK period by enabling the GPMC.[GPMC\\_CONFIG4\\_i](#)[7] OEEXTRADELAY bit. This half of a GPMC\_FCLK period provides more granularity on nOE/RE assertion and deassertion time to guaranty proper setup and hold time relative to GPMC\_CLK. If asserted, OEEXTRADELAY applies to all parameters controlling nOE/nRE transitions.

OEEXTRADELAY must be used carefully, to avoid control-signal overlap between successive accesses to different chip-selects. This implies the need to program RDCYCLETIME and WRCYCLETIME to be greater than nOE/RE signal-deassertion time, including the extra half-GPMC\_FCLK-period delay.

nOE/nRE is not asserted during a write cycle.

---

**NOTE:** When the GPMC generates a read access to an address-/data-multiplexed device, it drives the address bus until nOE assertion time.

---

#### 10.1.5.3.5 *nWE: Write Enable Signal Control Assertion/Deassertion Time (WEONTIME/WEOFETIME/WEEXTRADELAY)*

The GPMC.[GPMC\\_CONFIG4\\_i](#)[19:16] WEONTIME field (where i = 0 to 7) defines the nWE signal-assertion time relative to start access time. It applies only to write accesses.

The GPMC.[GPMC\\_CONFIG4\\_i](#)[28:24] WEOFETIME field defines the nWE signal-deassertion time relative to start access time. It applies only to write accesses.

WEONTIME can be used to control an address and byte enable valid setup time control before nWE assertion. WEOFETIME can be used to control an address and byte enable valid hold time control after nWE assertion.

nWE signal transitions as controlled through WEONTIME, and WEOFETIME can be delayed by half a GPMC\_FCLK period by enabling the GPMC.[GPMC\\_CONFIG4\\_i](#)[23] WEEXTRADELAY bit. This half of a GPMC\_FCLK period provides more granularity on nWE assertion and deassertion time to guaranty proper setup and hold time relative to GPMC\_CLK. If asserted, WEEXTRADELAY applies to all parameters controlling nWE transitions.

The WEEXTRADELAY bit must be used carefully to avoid control-signal overlap between successive accesses to different chip-selects. This implies the need to program the WRCYCLETIME bit field to be greater than the nWE signal-deassertion time, including the extra half-GPMC\_FCLK-period delay.

nWE is not asserted during a read cycle.

### 10.1.5.3.6 GPMC\_CLK

GPMC\_CLK is the external clock provided to the attached synchronous memory or device.

- The GPMC\_CLK clock frequency is the GPMC\_FCLK functional clock frequency divided by 1, 2, 3, or 4, depending on the GPMC.GPMC\_CONFIG1\_i[1:0] GPMCFCLKDIVIDER bit field (where  $i = 0$  to 7), with a guaranteed 50-percent duty cycle.
- The GPMC\_CLK clock is only activated when the access in progress is defined as synchronous (read or write access).
- The GPMC.GPMC\_CONFIG1\_i[26:25] CLKACTIVATIONTIME field ( $i = 0$  to 7) defines the number of GPMC\_FCLK cycles from start access time to GPMC\_CLK activation.
- The GPMC\_CLK clock is stopped when cycle time completes and is asserted low between accesses.
- The GPMC\_CLK clock is kept low when access is defined as asynchronous.
- When cycle time completes, the GPMC\_CLK may be high because of the GPMCFCLKDIVIDER bit field. To ensure correct stoppage of the GPMC\_CLK clock within the 50-percent required duty cycle, it is the user's responsibility to extend the RDCYCLETIME or WRCYCLETIME value.
- When the GPMC is configured for synchronous mode, the GPMC\_CLK signal (which is an output) must also be set as an input (CONTROL.CONTROL\_PADCONF\_GPMC\_NCS7[24] INPUTENABLE1 = 1). GPMC\_CLK is looped back through the output and input buffers of the corresponding GPMC\_CLK pad at the device boundary. The looped-back clock is used to synchronize the sampling of the memory signals.

**NOTE:** To ensure a correct external clock cycle, the following rules must be applied:

- (RDCYCLETIME – CLKACTIVATIONTIME) must be a multiple of (GPMCFCLKDIVIDER + 1).
- The PAGEBURSTACCESSTIME value must be a multiple of (GPMCFCLKDIVIDER + 1).

### 10.1.5.3.7 GPMC\_CLK and Control Signals Setup and Hold

Control-signal transition (assertion and deassertion) setup and hold values with respect to the GPMC\_CLK edge can be controlled in the following ways:

- For the GPMC\_CLK signal, the GPMC.GPMC\_CONFIG1\_i[26:25] CLKACTIVATIONTIME field ( $i = 0$  to 7) allows setup and hold control of control-signal assertion time.
- The use of a divided GPMC\_CLK allows setup and hold control of control-signal assertion and deassertion times.
- When GPMC\_CLK runs at the GPMC\_FCLK frequency so that GPMC\_CLK edge and control-signal transitions refer to the same GPMC\_FCLK edge, the control-signal transitions can be delayed by half of a GPMC\_FCLK period to provide minimum setup and hold times. This half-GPMC\_FCLK delay is enabled with the CSEXTRADELAY, ADVEXTRADELAY, OEEEXTRADELAY, or WEEEXTRADELAY parameter. This delay must be used carefully to prevent control-signal overlap between successive accesses to different chip-selects. This implies that the RDCYCLETIME and WRCYCLETIME are greater than the last control-signal deassertion time, including the extra half-GPMC\_FCLK cycle.

### 10.1.5.3.8 Access Time (RDACCESSTIME / WRACCESSTIME)

The read access time and write access time durations can be programmed independently allowing nOE and GPMC data capture timing parameters to be independent of nWE and memory device data capture timing parameters.

RDACCESSTIME is programmed in the GPMC.GPMC\_CONFIG5\_i[20:16] bit field ( $i = 0$  to 7).

WRACCESSTIME is programmed in the GPMC.GPMC\_CONFIG6\_i[28:24] bit field ( $i = 0$  to 7).

RDACCESSTIME and WRACCESSTIME can be set from 0 to 31 GPMC\_FCLK cycles with a granularity of one (GPMC\_CONFIG1\_i[4] TIMEPARAGRANULARITY = 0).

RDACCESSTIME and WRACCESSTIME can be set from 0 to 62 GPMC\_FCLK cycles with a granularity of two (GPMC\_CONFIG1\_i[4] TIMEPARAGRANULARITY = 1).

#### 10.1.5.3.8.1 Access Time on Read Access

In asynchronous read mode, for single and paged accesses, RDACCESSTIME field ( $i = 0$  to  $7$ ) defines the number of GPMC\_FCLK cycles from start access time to the GPMC\_FCLK rising edge used for the first data capture. RDACCESSTIME must be programmed to the rounded greater GPMC\_FCLK cycle value of the read access time of the attached memory device.

In synchronous read mode, for single or burst accesses, RDACCESSTIME defines the number of GPMC\_FCLK cycles from start access time to the GPMC\_FCLK rising edge corresponding to the GPMC\_CLK rising edge used for the first data capture.

GPMC\_CLK which is sent to the memory device for synchronization with the GPMC, is internally retimed to correctly latch the returned data. RDCYCLETIME must be greater than RDACCESSTIME in order to let the GPMC latch the last return data using the internally retimed GPMC\_CLK.

The external WAIT signal can be used in conjunction with RDACCESSTIME to control the effective GPMC data-capture GPMC\_FCLK edge on read access in both asynchronous mode and synchronous mode. For details about wait monitoring, see [Section 10.1.5.4](#).

#### 10.1.5.3.8.2 Access Time on Write Access

In asynchronous write mode, the [GPMC\\_CONFIG6\\_i\[28:24\]](#) WRACCESSTIME timing parameter is not used to define the effective write access time. Instead, it is used as a WAIT invalid timing window, and must be set to a correct value so that the gpmc\_wait pin is at a valid state two GPMC\_CLK cycles before WRACCESSTIME completes. For details about wait monitoring, see [Section 10.1.5.4](#).

In synchronous write mode, for single or burst accesses, WRACCESSTIME defines the number of GPMC\_FCLK cycles from start access time to the GPMC\_CLK rising edge used by the memory device for the first data capture.

The external WAIT signal can be used in conjunction with WRACCESSTIME to control the effective memory device data capture GPMC\_CLK edge for a synchronous write access. For details about wait monitoring, see [Section 10.1.5.4](#).

#### 10.1.5.3.9 Page Burst Access Time (PAGEBURSTACCESSTIME)

PAGEBURSTACCESSTIME is programmed in the GPMC.[GPMC\\_CONFIG5\\_i\[27:24\]](#) bit field ( $i = 0$  to  $7$ ). PAGEBURSTACCESSTIME can be set from 0 to 15 GPMC\_FCLK cycles with a granularity of one (GPMC.[GPMC\\_CONFIG1\\_i\[4\]](#) TIMEPARAGRANULARITY set to 0), or from 0 to 30 GPMC\_FCLK cycles with a granularity of two (TIMEPARAGRANULARITY set to 1).

#### 10.1.5.3.9.1 Page Burst Access Time on Read Access

In asynchronous page read mode, the delay between successive word captures in a page is controlled through the PAGEBURSTACCESSTIME bit field. The PAGEBURSTACCESSTIME parameter must be programmed to the rounded greater GPMC\_FCLK cycle value of the read access time of the attached device.

In synchronous burst read mode, the delay between successive word captures in a burst is controlled through the PAGEBURSTACCESSTIME field.

The external WAIT signal can be used in conjunction with PAGEBURSTACCESSTIME to control the effective GPMC data capture GPMC\_FCLK edge on read access. For details about wait monitoring, see [Section 10.1.5.4](#).

#### 10.1.5.3.9.2 Page Burst Access Time on Write Access

Asynchronous page write mode is not supported. PAGEBURSTACCESSTIME is irrelevant in this case.

In synchronous burst write mode, PAGEBURSTACCESSTIME controls the delay between successive memory device word captures in a burst.

The external WAIT signal can be used in conjunction with PAGEBURSTACCESSTIME to control the effective memory-device data capture GPMC\_CLK edge in synchronous write mode. For details about wait monitoring, see [Section 10.1.5.4](#).

### 10.1.5.3.10 Bus Keeping Support

At the end-cycle time of a read access, if no other access is pending, the GPMC drives the bus with the last data read after RDACYCLETIME completion time to prevent bus floating and reduce power consumption.

After a write access, if no other access is pending, the GPMC keeps driving the data bus after WRCYCLETIME completes with the same data to prevent bus floating and power consumption.

### 10.1.5.4 WAIT Pin Monitoring Control

GPMC access time can be dynamically controlled using an external gpmc\_wait pin when the external device access time is not deterministic and cannot be defined and controlled only using the GPMC internal RDACCESSTIME, WRACCESSTIME and PAGEBURSTACCESSTIME wait state generator.

The GPMC four input wait pins: gpmc\_wait3, gpmc\_wait2, gpmc\_wait1, and gpmc\_wait0. These four pins allow direct plugin and control of external devices with different wait-pin polarity. They also allow the overlap of wait-pin assertion from different devices without affecting access to devices for which the wait pin is not asserted.

- The GPMC.[GPMC\\_CONFIG1\\_i\[17:16\]](#) WAITPINSELECT field ( $i = 0$  to 7) selects which input gpmc\_wait pin is used for the device attached to the corresponding chip-select.
- The polarity of the wait pin is defined through the WAITxPINPOLARITY bit of the GPMC.[GPMC\\_CONFIG](#) register. A wait pin configured to be active low means that low level on the WAIT signal indicates that the data is not ready and that the data bus is invalid. When WAIT is inactive, data is valid.

The GPMC access engine can be configured by CS to monitor the wait pin of the external memory device or not, based on the access type: read or write.

- The GPMC.[GPMC\\_CONFIG1\\_i\[22\]](#) WAITREADMONITORING bit defines whether the wait pin should be monitored during read accesses or not.
- The GPMC.[GPMC\\_CONFIG1\\_i\[21\]](#) WAITWRITEMONITORING bit defines whether the wait pin should be monitored during write accesses or not.

The GPMC access engine can be configured to monitor the wait pin of the external memory device asynchronously or synchronously with the GPMC\_CLK clock, depending on the access type: synchronous or asynchronous (the GPMC.[GPMC\\_CONFIG1\\_i\[29\]](#) READTYPE and GPMC.[GPMC\\_CONFIG1\\_i\[27\]](#) WRITETYPE bits).

#### 10.1.5.4.1 Wait Monitoring During an Asynchronous Read Access

When wait-pin monitoring is enabled for read accesses (WAITREADMONITORING), the effective access time is a logical AND combination of the RDACCESSTIME timing completion and the wait-deasserted state.

During asynchronous read accesses with wait-pin monitoring enabled, the wait pin must be at a valid level (asserted or deasserted) for at least two GPMC clock cycles before RDACCESSTIME completes, to ensure correct dynamic access-time control through wait-pin monitoring. The advance pipelining of the two GPMC clock cycles is the result of the internal synchronization requirements for the WAIT signal.

In this context, RDACCESSTIME is used as a WAIT invalid timing window and is set to such a value that the wait pin is at a valid state two GPMC clock cycles before RDACCESSTIME completes.

Similarly, during a multiple-access cycle (for example, asynchronous read page mode), the effective access time is a logical AND combination of PAGEBURSTACCESSTIME timing completion and the wait-deasserted state. Wait-monitoring pipelining is also applicable to multiple accesses (access within a page).

- WAIT monitored as active freezes the CYCLETIME counter. For an access within a page, when the CYCLETIME counter is by definition in a lock state, WAIT monitored as asserted extends the current access time in the page. Control signals are kept in their current state. The data bus is considered invalid, and no data are captured during this clock cycle.

- WAIT monitored as inactive unfreezes the CYCLETIME counter. For an access within a page, when the CYCLETIME counter is by definition in a lock state, WAIT monitored as inactive completes the current access time and starts the next access phase in the page. The data bus is considered valid, and data are captured during this clock cycle. In case of a single access or if this was the last access in a multiple-access cycle, all signals are controlled according to their related control timing value and according to the CYCLETIME counter status.

When a delay larger than two GPMC clocks must be observed between wait-pin deactivation time and data valid time (including the required GPMC and the device data setup time), an extra delay can be added between wait-pin deassertion time detection and effective data-capture time and the effective unlock of the CYCLETIME counter. This extra delay can be programmed in the GPMC.GPMC\_CONFIG1\_i[19:18] WAITMONITORINGTIME field ( $i = 0$  to 7).

**NOTE:**

- The WAITMONITORINGTIME parameter does not delay the wait-pin active or inactive detection, nor does it modify the two GPMC clocks pipelined detection delay.
- This extra delay is expressed as a number of GPMC\_CLK clock cycles, even though the access is defined as asynchronous, and no GPMC\_CLK clock is provided to the external device. Still, GPMCFCLKDIVIDER is used as a divider for the GPMC clock, so it must be programmed to define the correct WAITMONITORINGTIME delay.

Figure 10-8 shows wait behavior during an asynchronous single read access.

**Figure 10-8. Wait Behavior During an Asynchronous Single Read Access (GPMCFCLKDivider = 1)**



**NOTE:** The WAIT signal is active low. WAITMONITORINGTIME = 00, 01.

#### 10.1.5.4.2 Wait Monitoring During an Asynchronous Write Access

When wait-pin monitoring is enabled for write accesses (GPMC.GPMC\_CONFIG1\_i[21] WAITWRITEMONITORING bit = 0x1), the WAIT-invalid timing window is defined by the WRACCESSTIME field. WRACCESSTIME must be set so that the wait pin is at a valid state two GPMC clock cycles before WRACCESSTIME completes. The advance pipelining of the two GPMC clock cycles is the result of the internal synchronization requirements for the WAIT signal.

- WAIT monitored as active freezes the CYCLETIME counter. This informs the GPMC that the data bus is not captured by the external device. The control signals are kept in their current state. The data bus still drives the data.
- WAIT monitored as inactive unfreezes the CYCLETIME counter. This informs that the data bus is correctly captured by the external device. All signals, including the data bus, are controlled according to their related control timing value and to the CYCLETIME counter status.

When a delay larger than two GPMC clock cycles must be observed between wait-pin deassertion time and the effective data write into the external device (including the required GPMC data setup time and the device data setup time), an extra delay can be added between wait-pin deassertion time detection and effective data write time into the external device and the effective unfreezing of the CYCLETIME counter. This extra delay can be programmed in the GPMC.GPMC\_CONFIG1\_i[19:18] WAITMONITORINGTIME fields (i = 0 to 7).

---

**NOTE:**

- The WAITMONITORINGTIME parameter does not delay the wait-pin assertion or deassertion detection, nor does it modify the two GPMC clock cycles pipelined detection delay.
  - This extra delay is expressed as a number of GPMC\_CLK clock cycles, even though the access is defined as synchronous, and even though no clock is provided to the external device. Still, GPMC\_CONFIG1\_i[1:0] GPMCFCLKDIVIDER is used as a divider for the GPMC clock and so it must be programmed to define the correct WAITMONITORINGTIME delay.
- 

#### 10.1.5.4.3 Wait Monitoring During a Synchronous Read Access

During synchronous accesses with wait-pin monitoring enabled, the wait pin is captured synchronously with GPMC\_CLK, using the rising edge of this clock.

The WAIT signal can be programmed to apply to the same clock cycle it is captured in. Alternatively, it can be sampled one or two GPMC\_CLK cycles ahead of the clock cycle it applies to. This pipelining is applicable to the entire burst access, and to all data phase in the burst access. This WAIT pipelining depth is programmed in the GPMC.GPMC\_CONFIG1\_i[19:18] WAITMONITORINGTIME field (where i = 0 to 7), and is expressed as a number of GPMC\_CLK clock cycles.

In synchronous mode, when wait-pin monitoring is enabled (GPMC.GPMC\_CONFIG1\_i[22] WAITREADMONITORING bit), the effective access time is a logical AND combination of the RDACCESSTIME timing completion and the WAIT deasserted-state detection.

Depending on the programmed WAITMONITORINGTIME value, the wait pin should be at a valid level, either asserted or deasserted:

- In the same clock cycle the data is valid if WAITMONITORINGTIME = 0 (at RDACCESSTIME completion)
- In the WAITMONITORINGTIME \* (GPMCFCLKDIVIDER + 1) GPMC\_FCLK clock cycles before RDACCESSTIME completion if WAITMONITORINGTIME /= 0

Similarly, during a multiple-access cycle (burst mode), the effective access time is a logical AND combination of PAGEBURSTACCESSTIME timing completion and the wait-inactive state. The Wait pipelining depth programming applies to the whole burst access.

- WAIT monitored as active freezes the CYCLETIME counter. For an access within a burst (when the CYCLETIME counter is by definition in a lock state), WAIT monitored as active extends the current access time in the burst. Control signals are kept in their current state. The data bus is considered invalid, and no data are captured during this clock cycle.

- WAIT monitored as inactive unfreezes the CYCLETIME counter. For an access within a burst (when the CYCLETIME counter is by definition in lock state), WAIT monitored as inactive completes the current access time and starts the next access phase in the burst. The data bus is considered valid, and data are captured during this clock cycle. In a single access or if this was the last access in a multiple-access cycle, all signals are controlled according to their relative control timing value and the CYCLETIME counter status.

Figure 10-9 shows wait behavior during a synchronous read burst access.

**Figure 10-9. Wait Behavior During a Synchronous Read Burst Access**



**NOTE:** The WAIT signal is active low. WAITMONITORINGTIME = 00, 01.

#### 10.1.5.4.4 Wait Monitoring During a Synchronous Write Access

During synchronous accesses with wait-pin monitoring enabled (the WAITWRITEMONITORING bit), the wait pin is captured synchronously with GPMC\_CLK, using the rising edge of this clock.

If enabled, external wait-pin monitoring can be used in combination with WRACCESSTIME to control the effective memory device GPMC\_CLK capture edge.

Wait-monitoring pipelining depth is similar to synchronous read access:

- At WRACCESSTIME completion if WAITMONITORINGTIME = 0
- The WAITMONITORINGTIME \* (GPMCFCLKDIVIDER + 1) GPMC\_FCLK cycles before WRACCESSTIME completion if WAITMONITORINGTIME /= 0.

Wait-monitoring pipelining definition applies to whole burst accesses:

- WAIT monitored as active freezes the CYCLETIME counter. For accesses within a burst, when the CYCLETIME counter is by definition in a lock state, WAIT monitored as active indicates that the data bus is not being captured by the external device. Control signals are kept in their current state. The data bus is kept in its current state.
- WAIT monitored as inactive unfreezes the CYCLETIME counter. For accesses within a burst, when the CYCLETIME counter is by definition in a lock state, WAIT monitored as inactive indicates the effective data capture of the bus by the external device and starts the next access of the burst. In case of a single access or if this was the last access in a multiple access cycle, all signals, including the data bus, are controlled according to their related control timing value and the CYCLETIME counter status.

---

**NOTE:** Wait monitoring is supported for all configurations except for [GPMC\\_CONFIG1\\_i\[19:18\]](#) WAITMONITORINGTIME = 0x 0 (where i = 0 to 7) for write bursts with a clock divider of 1 or 2 ([GPMC\\_CONFIG1\\_i\[1:0\]](#) GPMCFCLKDIVIDER bit field equal to 0x0 or 0x1, respectively).

---

#### 10.1.5.4.5 WAIT With NAND Device

For details about the use of the wait pin for communication with a NAND flash external device, see [Section 10.1.5.14.2, NAND Device-Ready Pin](#).

#### 10.1.5.4.6 Idle Cycle Control Between Successive Accesses

##### 10.1.5.4.6.1 Bus Turnaround (BUSTURNAROUND)

To prevent data-bus contention, an access that follows a read access to a slow memory/device (that is, control the nCS/nOE de-assertion to data bus in high-impedance delay) must be delayed.

The bus turnaround is a time-out counter starting after nCS or nOE de-assertion time (whichever occurs first) and delays the next access start-cycle time. It is programmed through the [GPMC.GPMC\\_CONFIG6\\_i\[3:0\] BUSTURNAROUND](#) bit field (where i = 0 to 7).

After a read access to a chip-select with a non zero BUSTURNAROUND, the next access is delayed until the BUSTURNAROUND delay completes, if the next access is one of the following:

- A write access to any chip-select (same or different from the chip-select data was read from)
- A read access to a different chip-select from the chip-select data was read access from
- A read or write access to a chip-select associated with an address/data-multiplexed device

Another way to prevent bus contention is to define an earlier nCS or nOE deassertion time for slow devices or to extend the value of RDCYCLETIME. Doing this prevents bus contention, but affects all accesses of this specific chip-select.

##### 10.1.5.4.6.2 Idle Cycles Between Accesses to Same Chip-Select (CYCLE2CYCLESAMECSEN, CYCLE2CYCLEDELAY)

Some devices require a minimum chip-select signal inactive time between accesses. The [GPMC.GPMC\\_CONFIG6\\_i\[7\] CYCLE2CYCLESAMECSEN](#) bit (i = 0 to 7) enables insertion of a minimum number of GPMC\_FCLK cycles, defined by the [GPMC.GPMC\\_CONFIG6\\_i\[11:8\] CYCLE2CYCLEDELAY](#) field, between successive accesses of any type (read or write) to the same chip-select.

If CYCLE2CYCLESAMECSEN is enabled, any subsequent access to the same chip-select is delayed until its CYCLE2CYCLEDELAY completes. The CYCLE2CYCLEDELAY counter starts when CSRDOFFTIME/CSWROFFTIME completes.

The same applies to successive accesses occurring during Word32 or burst accesses split into successive single accesses when the single-access mode is used ([GPMC\\_CONFIG1\\_i\[30\]](#) READMULTIPLE = 0 or [GPMC\\_CONFIG1\\_i\[28\]](#) WRITEMULTIPLE = 0).

All control signals are kept in their default states during these idle GPMC\_FCLK cycles. This prevents back-to-back accesses to the same chip-select without idle cycles between accesses.

#### **10.1.5.4.6.3 Idle Cycles Between Accesses to Different Chip-Select (CYCLE2CYCLEDIFFCSEN, CYCLE2CYCLEDELAY)**

Because of the pipelined behavior of the system, successive accesses to different chip-selects can occur back-to-back with no idle cycles between accesses. Depending on the control signals (nCS, nADV/ALE, nBE0/CLE, nOE/RE, nWE) assertion and de-assertion timing parameters and on the IC timing parameters, some control signals assertion times may overlap between the successive accesses to different CS. Similarly, some control signals (WE, OE/RE) may not respect required transition times.

To work around the overlapping and to observe the required control-signal transitions, a minimum of CYCLE2CYCLEDELAY inactive cycles is inserted between the access being initiated to this chip-select and the previous access ending for a different chip-select. This applies to any type of access (read or write).

If [GPMC\\_CONFIG6\\_i\[6\]](#) CYCLE2CYCLEDIFFCSEN is enabled, the chip-select access is delayed until CYCLE2CYCLEDELAY cycles have expired since the end of a previous access to a different chip-select. CYCLE2CYCLEDELAY count starts at CSRDOFFTIME/CSWROFFTIME completion. All control signals are kept inactive during the idle GPMC\_FCLK cycles.

---

**NOTE:** CYCLE2CYCLESAMECSEN and CYCLE2CYCLEDIFFCSEN should be set in the [GPMC\\_CONFIG6\\_i](#) registers to insert idle cycles between accesses on this chip-select and after accesses to a different chip-select, respectively.

The CYCLE2CYCLEDELAY delay runs in parallel with the BUSTURNAROUND delay. BUSTURNAROUND is a timing parameter defined for the ending chip-select access, whereas CYCLE2CYCLEDELAY is a timing parameter defined for starting chip-select access. The effective minimum delay between successive accesses is based on the larger delay timing parameter and on the access type combination, since bus turnaround does not apply to all access types. See [Section 10.1.5.4.6.1](#) for more details on bus turnaround.

---

[Table 10-3](#) describes the configuration required for idle cycle insertion.

**Table 10-3. Idle Cycle Insertion Configuration**

| 1st Access Type | BUSTURN AROUND Timing Parameter | Second Access Type | Chip-Select | Add/Data Multiplexed | CYCLE2 CYCLE SAMECSEN Parameter | CYCLE2 CYCLE DIFFCSEN Parameter | Idle Cycle Insertion Between the Two Accesses                       |
|-----------------|---------------------------------|--------------------|-------------|----------------------|---------------------------------|---------------------------------|---------------------------------------------------------------------|
| R/W             | = 0                             | R/W                | Any         | Any                  | 0                               | x                               | No idle cycles are inserted if the two accesses are well pipelined. |
| R               | > 0                             | R                  | Same        | Nonmuxed             | x                               | 0                               | No idle cycles are inserted if the two accesses are well pipelined. |
| R               | > 0                             | R                  | Different   | Nonmuxed             | 0                               | 0                               | BTA cycles are inserted.                                            |
| R               | > 0                             | R/W                | Any         | Muxed                | 0                               | 0                               | BTA cycles are inserted.                                            |
| R               | > 0                             | W                  | Any         | Any                  | 0                               | 0                               | BTA cycles are inserted.                                            |
| W               | > 0                             | R/W                | Any         | Any                  | 0                               | 0                               | No idle cycles are inserted if the two accesses are well pipelined. |
| R/W             | = 0                             | R/W                | Same        | Any                  | 1                               | x                               | CYCLE2CYCLEDELAY cycles are inserted.                               |
| R/W             | = 0                             | R/W                | Different   | Any                  | x                               | 1                               | CYCLE2CYCLEDELAY cycles are inserted.                               |

**Table 10-3. Idle Cycle Insertion Configuration (continued)**

| 1st Access Type | BUSTURNAROUND Timing Parameter | Second Access Type | Chip-Select | Add/Data Multiplexed | CYCLE2 CYCLE SAMECSEN Parameter | CYCLE2 CYCLE DIFFCSEN Parameter | Idle Cycle Insertion Between the Two Accesses                                                                                                                                |
|-----------------|--------------------------------|--------------------|-------------|----------------------|---------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R/W             | > 0                            | R/W                | Same        | Any                  | 1                               | x                               | CYCLE2CYCLEDELAY cycles are inserted. If BTA idle cycles already apply on these two back-to-back accesses, the effective delay is max (BUSTURNAROUND, CYCLE2CYCLEDELAY).     |
| R/W             | > 0                            | R/W                | Different   | Any                  | x                               | 1                               | CYCLE2CYCLEDELAY cycles are inserted. If BTA idle cycles already apply on these two back-to-back accesses, the effective delay is maximum (BUSTURNAROUND, CYCLE2CYCLEDELAY). |

#### 10.1.5.4.7 Slow Device Support (TIMEPARAGRANULARITY Parameter)

All access-timing parameters can be multiplied by 2 by setting the GPMC.GPMC\_CONFIG1\_i[4] TIMEPARAGRANULARITY bit (where i stands for the GPMC chip-select value, i = 0 to 7). Increasing all access timing parameters allows support of slow devices.

#### 10.1.5.5 gpmc\_io\_dir Pin

The gpmc\_io\_dir pin is used to control I/O direction on the GPMC data bus gpmc\_d[15:0]. Depending on top-level pad multiplexing, this signal can be output and used externally to the device, if required.

The gpmc\_io\_dir pin is low during transmit (OUT) and high during receive (IN).

For write accesses, the gpmc\_io\_dir pin stays OUT from start-cycle time to end-cycle time.

For read accesses, the gpmc\_io\_dir pin goes from OUT to IN at nOE assertion time and stays IN until:

- BUSTURNAROUND is enabled:
  - The gpmc\_io\_dir pin goes from IN to OUT at end-cycle time plus programmable bus turnaround time.
- BUSTURNAROUND is disabled:
  - After an asynchronous read access, the gpmc\_io\_dir pin goes from IN to OUT at RDACCESSTIME + 1 GPMC\_FCLK cycle or when RDCYCLETIME completes, whichever occurs last.
  - After a synchronous read access, the gpmc\_io\_dir pin goes from IN to OUT at RDACCESSTIME + 2 GPMC\_FCLK cycles or when RDCYCLETIME completes, whichever occurs last.

Because of the bus-keeping feature of the GPMC, after a read or write access and with no other accesses pending, the default value of the gpmc\_io\_dir pin is OUT (see [Section 10.1.5.3.10, Bus Keeping Support](#)).

To prevent unnecessary toggling, the gpmc\_io\_dir pin stays IN between two successive read accesses to a nonmultiplexed device (address mapping supports nonmultiplexed 16-bit wide devices with limited address (2 Kbytes)).

[Figure 10-10](#) shows address mapping in nonmultiplexed mode with a limited address range (A[10:1]).

#### 10.1.5.6 Reset

No reset signal is sent to the external memory device by the GPMC. For more information see [Chapter 3, Power, Reset, and Clock Management](#).

The PRCM module provides an input pin, global\_rst\_n, to the GPMC:

- The global\_rst\_n pin is activated during device warm reset and cold reset.
- The global\_rst\_n pin initializes the internal state-machine and the internal configuration registers.

### 10.1.5.7 WRITE PROTECT (nWP)

When connected to the attached memory device, the WRITE PROTECT signal can enable or disable the lockdown function of the attached memory.

The gpmc\_nwp output pin value is controlled through the GPMC.GPMC\_CONFIG[4] WRITEPROTECT bit, which is common to all CS.

### 10.1.5.8 BYTE ENABLE (nBE1/nBE0)

BYTE ENABLE signals (nBE1/nBE0) are:

- Valid (asserted or nonasserted according to the incoming system request) from access start to access completion for asynchronous and synchronous single accesses
- Asserted low from access start to access completion for asynchronous and synchronous multiple read accesses
- Valid (asserted or nonasserted, according to the incoming system request) synchronously to each written data for synchronous multiple write accesses

### 10.1.5.9 Asynchronous Access Description

In asynchronous operations:

- GPMC\_CLK is not provided outside the GPMC.
- GPMC\_CLK is kept low.

#### 10.1.5.9.1 Asynchronous Single Read

##### 10.1.5.9.1.1 Asynchronous Single Read Operation on a Nonmultiplexed Device

Figure 10-10 shows an asynchronous single read operation on a nonmultiplexed device.

Figure 10-10. Asynchronous Single Read on an Address/Data-Nonmultiplexed Device



gpmc-010

In the following section i stands for the chip-select number, i = 0 to 7.

- GPMC.GPMC\_CONFIG[1] LIMITEDADDRESS set to 1 (A26-A11 are not modified during an external memory access)
- GPMC.GPMC\_CONFIG1\_i register settings:
  - GPMC\_CONFIG1\_i[30] READMULTIPLE bit at 0 (read single access)
  - GPMC\_CONFIG1\_i[29] READTYPE bit at 0 (asynchronous read)
  - GPMC\_CONFIG1\_i[9] MUXADDDATA bit at 0 (non multiplexed device)
- Chip-select signal nCS:
  - nCS assertion time is controlled by the GPMC\_CONFIG2\_i[3:0] CSONTIME field. It controls the address setup time to nCS assertion.
  - nCS deassertion time is controlled by the GPMC\_CONFIG2\_i[12:8] CSRDOFFTIME field. It controls the address hold time from nCS deassertion.
- Address valid signal nADV:
  - nADV assertion time is controlled by the GPMC\_CONFIG3\_i[3:0] ADVONTIME field.
  - nADV deassertion time is controlled by the GPMC\_CONFIG3\_i[12:8] ADVRDOFFTIME field.
- Output enable signal nOE:
  - nOE assertion indicates a read cycle.
  - nOE assertion time is controlled by the GPMC\_CONFIG4\_i[3:0] OEONTIME field.
  - nOE deassertion time is controlled by the GPMC\_CONFIG4\_i[12:8] OEOFETIME field.
- Read data is latched when RDACCESSTIME completes. Access time is defined in the GPMC.GPMC\_CONFIG5\_i[20:16] RDACCESSTIME field.
- The end of the access is defined by the RDCYCLETIME parameter. The read cycle time is defined in the GPMC.GPMC\_CONFIG5\_i[4:0] RDCYCLETIME field.
- Direction signal DIR: DIR goes from OUT to IN at the same time that nOE is asserted.

After a read operation, if no other access (read or write) is pending, the data bus is driven with the previous read value. See [Section 10.1.5.3.10, Bus Keeping Support](#) for more details.

#### 10.1.5.9.1.2 Asynchronous Single-Read Operation on an Address/Data Multiplexed Device

[Figure 10-11](#) shows an asynchronous single read operation on an address/data-multiplexed device.

**Figure 10-11. Asynchronous Single Read on an Address/Data-Multiplexed Device**



When the GPMC generates a read access to an address/data-multiplexed device, it drives the address bus until nOE assertion time. For details, see [Section 10.1.5.2.3, Address/Data-Multiplexing Interface](#).

GPMC.[GPMC\\_CONFIG1\\_i](#) register settings ( $i = 0$  to 7):

- READMULTIPLE bit at 0 (read single access)
- READTYPE bit at 0 (read asynchronous)
- MUXADDDATA bit at 1 (address/data-multiplexed device)

Address bits ([16:1] from a GPMC perspective, [15:0] from an external device perspective) are placed on the address/data bus, and the remaining address bits [25:16] are placed on the address bus. The address phase ends at nOE assertion, when the DIR signal goes from OUT to IN.

The nCS, nADV, nOE, and DIR signals are controlled in the same way as nonmultiplexed accesses.

### 10.1.5.9.2 Asynchronous Single Write

#### 10.1.5.9.2.1 Asynchronous Single Write Operation on a Nonmultiplexed Device

Figure 10-12 shows an asynchronous single write operation on a nonmultiplexed device.

**Figure 10-12. Asynchronous Single Write on an Address/Data-Nonmultiplexed Device**



gpmc-012

In the following section i stands for the chip-select number,  $i = 0$  to 7.

- GPMC.GPMC\_CONFIG[1] LIMITEDADDRESS set to 1 (A26-A11 are not modified during an external memory access)
- GPMC.GPMC\_CONFIG1\_i register settings:
  - WRITEMULTIPLE bit at 0 (write single access)
  - WRITETYPE bit at 0 (write asynchronous)
  - MUXADDDATA bit at 0 (nonaddress/data-multiplexed device)
- Chip-select signal nCS:
  - nCS assertion time is controlled by the GPMC.GPMC\_CONFIG2\_i[3:0] CSONTIME field and ensures address setup time to nCS assertion.
  - nCS deassertion time is controlled by the GPMC.GPMC\_CONFIG2\_i[20:16] CSWROFFTIME field and ensures address hold time to nCS deassertion.
- Address valid signal nADV:
  - nADV assertion time is controlled by the GPMC.GPMC\_CONFIG3\_i[3:0] ADVONTIME field.
  - nADV deassertion time is controlled by the GPMC.GPMC\_CONFIG3\_i[20:16] ADVWROFFTIME field.

Address and data are driven on their corresponding buses at start-of-cycle time.

- Write enable signal nWE:
  - nWE assertion indicates a write cycle.
  - nWE assertion time is controlled by the GPMC.GPMC\_CONFIG4\_i[19:16] WEONTIME field.
  - nWE deassertion time is controlled by the GPMC.GPMC\_CONFIG4\_i[28:24] WEOFFTIME field.
- Direction signal DIR:

DIR signal is OUT during the entire access.

- The end of the access is defined by the WRCYCLETIME parameter.

This write-cycle time is defined in the GPMC.GPMC\_CONFIG5\_i[12:8] WRCYCLETIME field.

After a write operation, if no other access (read or write) is pending, the data bus keeps its previous value. See [Section 10.1.5.3.10, Bus Keeping Support](#).

In the GPMC, when a 16-bit wide device is attached to the controller, a Word32 write access is split into two Word16 write accesses. For more information about GPMC access size and type adaptation, see [Section 10.1.5.2.7, System Burst Versus External Device Burst Support](#).

Between two successive accesses, if an nCS pulse is needed:

- The GPMC.GPMC\_CONFIG6\_i[11:8] CYCLE2CYCLEDELAY field can be programmed with GPMC.GPMC\_CONFIG6\_i[7] CYCLE2CYCLESAMECSEN enabled.
- The CSWROFFTIME and CSONTIME parameters also allow a chip-select pulse, but this affects all other types of access.

### 10.1.5.9.2.2 Asynchronous Single Write Operation on an Address/Data-Multiplexed Device

[Figure 10-13](#) shows an asynchronous single write operation on an address/data-multiplexed device.

**Figure 10-13. Asynchronous Single Write on an Address/Data-Multiplexed Device**



gpmc-013

When the GPMC generates a write access to an address/data-multiplexed device, it drives the address on the address/data muxed bus until WRDATAONADMUXBUS time, and then it drives the data. For more information, see [Section 10.1.5.2.3, Address/Data-Multiplexing Interface](#).

GPMC.GPMC\_CONFIG1\_i register settings (i = 0 to 7):

- WRITEMULTIPLE bit at 0 (write single access)
- WRITETYPE bit at 0 (write asynchronous)
- MUXADDDATA bit at 1 (address/data-multiplexed device)

Address bits [16:1] are placed on the address/data bus at the start of cycle time, and the remaining address bits [26:17] are placed on the address bus.

The nCS, nADV, and nWE signals are controlled in the same way as nonmultiplexed accesses.

Data is driven on the address/data bus at a **GPMC\_CONFIG6\_i[19:16]** WRDATAONADMUXBUS time.

---

**NOTE:** Write multiple access in asynchronous mode is not supported. If WRITEMULTIPLE is enabled with WRITETYPE as asynchronous, the GPMC processes single asynchronous accesses.

---

#### 10.1.5.9.3 Asynchronous Multiple (Page Mode) Read

Figure 10-14 shows an asynchronous multiple read operation.

**Figure 10-14. Asynchronous Multiple (Page Mode) Read**




---

**NOTE:** The WAIT signal is active low.

---

In the following section i stands for the chip-select number, i = 0 to 7.

For read access with GPMC.GPMC\_CONFIG1\_i register settings:

- READMULTIPLE bit at 1 (read multiple access)
- READTYPE bit at 0 (read asynchronous)
- MUXADDDATA bit at 0 (non-address/data-multiplexed device). The page mode is not supported by address/data-multiplexed devices.

In [Figure 10-14](#), two Word32 read host accesses on the GPMC configured with READMULTIPLE = 1, READTYPE = 0, and MUXADDDATA = 0 are merged into one multiple-read access (page mode of four Word16) on the attached device.

When RDACCESSTIME completes, control-signal timings are frozen during the multiple data transactions, corresponding to PAGEBURSTACCESSTIME multiplied by the number of remaining data transactions.

- Chip-select signal nCS:
  - nCS assertion time is controlled by the GPMC.[GPMC\\_CONFIG2\\_i\[3:0\]](#) CSONTIME field and ensures the address setup time to nCS assertion.
  - nCS deassertion time is controlled by the GPMC.[GPMC\\_CONFIG2\\_i\[12:8\]](#) CSRDOFFTIME field and ensures the address hold time to nCS deassertion.
- Address valid signal nADV:
  - nADV assertion time is controlled by the GPMC.[GPMC\\_CONFIG3\\_i\[3:0\]](#) ADVONTIME field.
  - nADV deassertion time is controlled by the GPMC.[GPMC\\_CONFIG3\\_i\[12:8\]](#) ADVRDOFFTIME field.
- Output enable signal nOE:
  - nOE assertion indicates a read cycle.
  - nOE assertion time is controlled by the GPMC.[GPMC\\_CONFIG4\\_i\[3:0\]](#) OEONTIME field.
  - nOE deassertion time is controlled by the GPMC.[GPMC\\_CONFIG4\\_i\[12:8\]](#) OEOFETIME field.
- Initial latency for the first read data is controlled by the RDACCESSTIME parameter.  
The access time is defined in the GPMC.[GPMC\\_CONFIG5\\_i\[20:16\]](#) RDACCESSTIME field.

During consecutive accesses, the GPMC increments the address after each data read completes.

- Delay between successive read data in the page is controlled by the PAGEBURSTACCESSTIME parameter:
  - This timing is defined in the GPMC.[GPMC\\_CONFIG5\\_i\[27:24\]](#) PAGEBURSTACCESSTIME field.
  - Depending on the device page length, the GPMC can control device page crossing during a burst request and insert initial RDACCESSTIME latency. Note that page crossing is only possible with a new burst access, meaning a new initial access phase is initiated.
- Total access time (RDCYCLETIME) corresponds to RDACCESSTIME plus the address hold time starting from the nCS deassertion plus the time from RDACCESSTIME to CSRDOFFTIME.
  - The read cycle time is defined in the GPMC.[GPMC\\_CONFIG5\\_i\[4:0\]](#) RDCYCLETIME field.
  - In [Figure 10-14](#), the RDCYCLETIME programmed value equals RDCYCLETIME0 (before paged accesses) + RDCYCLETIME1 (after paged accesses).
- Direction signal DIR:  
DIR goes from OUT to IN at the same time as nOE assertion time.

After a read operation, if no other access (read or write) is pending, the data bus is driven with the previous read value. See [Section 10.1.5.3.10, Bus Keeping Support](#).

#### 10.1.5.10 Synchronous Access

In synchronous operations:

- The GPMC\_CLK clock is provided outside the GPMC when accessing the memory device.
- The GPMC\_CLK clock is derived from the GPMC\_FCLK clock using the GPMC.[GPMC\\_CONFIG1\\_i\[1:0\]](#) GPMCFCLKDIVIDER field (where i = 0 to 7).
- The GPMC.[GPMC\\_CONFIG1\\_i\[26:25\]](#) CLKACTIVATIONTIME field specifies that the GPMC\_CLK is provided outside the GPMC 0, 1, or 2 GPMC\_FCLK cycles after start access time until CycleTime completes.
- When the GPMC is configured for synchronous mode, the GPMC\_CLK signal (which is an output) must also be set as an input (CONTROL.CONTROL\_PADCONF\_GPMC\_NCS7[24] INPUTENABLE1 = 1). GPMC\_CLK is looped back through the output and input buffers of the corresponding GPMC\_CLK pad at device boundary. The looped-back clock is used to synchronize the sampling of the memory signals.

### 10.1.5.10.1 Synchronous Single Read

Figure 10-15 and Figure 10-16 show a synchronous single-read operation with GPMCFCLKDIVIDER equal to 0 and 1, respectively.

**Figure 10-15. Synchronous Single Read (GPMCFCLKDIVIDER = 0)**



gpmc-015

**Figure 10-16. Synchronous Single Read (GPMCFCLKDIVIDER = 1)**


gpmc-016

In the following section i stands for the chip-select number, i = 0 to 7.

- GPMC.[GPMC\\_CONFIG1\\_i](#) register settings:
  - READMULTIPLE bit at 0 (read single access)
  - READTYPE bit at 1 (read synchronous)
  - MUXADDDATA bit at 0 (non-address/data-multiplexed device)
- Chip-select signal nCS:
  - nCS assertion time is controlled by the GPMC.[GPMC\\_CONFIG2\\_i\[3:0\]](#) CSONTIME field and ensures address setup time to nCS assertion.
  - nCS deassertion time is controlled by the GPMC.[GPMC\\_CONFIG2\\_i\[12:8\]](#) CSROFFTIME field and ensures address hold time to nCS deassertion.
- Address valid signal nADV:
  - nADV assertion time is controlled by the GPMC.[GPMC\\_CONFIG3\\_i\[3:0\]](#) ADVONTIME field.
  - nADV deassertion time is controlled by the GPMC.[GPMC\\_CONFIG3\\_i\[12:8\]](#) ADVRDOFFTIME field.
- Output enable signal nOE:
  - nOE assertion indicates a read cycle.
  - nOE assertion time is controlled by the GPMC.[GPMC\\_CONFIG4\\_i\[3:0\]](#) OEONTIME field.
  - nOE deassertion time is controlled by the GPMC.[GPMC\\_CONFIG4\\_i\[12:8\]](#) OEOFETIME field.
- Initial latency for the first read data is controlled by GPMC.[GPMC\\_CONFIG5\\_i\[20:16\]](#)

RDACCESSTIME or by monitoring the WAIT signal.

- Total access time (GPMC.GPMC\_CONFIG5\_i[4:0] RD CYCLETIME) corresponds to RDACCESSTIME plus the address hold time from nCS deassertion, plus time from RDACCESSTIME to CSWROFFTIME.
- Direction signal DIR:  
DIR goes from OUT to IN at the same time as nOE assertion.

After a read operation, if no other access (read or write) is pending, the data bus is driven with the previous read value. See [Section 10.1.5.3.10, Bus Keeping Support](#).

#### 10.1.5.10.2 Synchronous Single Write

**Figure 10-17. Synchronous Single Write on an Address/Data-Multiplexed Device**



**NOTE:** The WAIT signal is active low.

When the GPMC generates a write access to an address/data-multiplexed device, it drives the data bus until WRDATAONADMUXBUS time (GPMC\_CONFIG6\_i[19:16]).

The GPMC.GPMC\_CONFIG1\_i register settings ( $i = 0$  to  $7$ ) are as follows:

- WRITEMULTIPLE bit at 0 (write single access)
- WRITETYPE bit at 1 (write synchronous)
- MUXADDDATA bit at 1 (address/data-multiplexed device)

Address bits [16:1] are placed on the address/data bus at cycle-start time, and the remaining address bits [26:17] are placed on the address bus.

The address phase ends at WRDATAONADMUXBUS.

The nCS, nADV, and nWE signals are controlled in the same way as nonmultiplexed accesses.

First data of the burst is driven on the address/data bus at WRDATAONADMUXBUS time.

#### **10.1.5.10.3 Synchronous Multiple (Burst) Read (4-, 8-, 16-Word16 Burst With Wraparound Capability)**

Figure 10-18 and Figure 10-19 show a synchronous multiple read operation with GPMCFCLKDIVIDER equal to 0 and 1, respectively.

**Figure 10-18. Synchronous Multiple (Burst) Read (GPMCFCLKDIVIDER = 0)**



gpmc-018

**NOTE:** The WAIT signal is active low.

**Figure 10-19. Synchronous Multiple (Burst) Read (GPMCFCLKDIVIDER = 1)**

NOTE: The WAIT signal is active low.

In the following section i stands for the chip-select number, i = 0 to 7.

- GPMC.GPMC\_CONFIG1\_i register settings:
  - READMULTIPLE bit at 1 (read multiple access)
  - READTYPE bit at 1 (read synchronous)
  - MUXADDDATA bit at 0 (nonaddress/data-multiplexed device)

When RDACCESSTIME completes, control-signal timings are frozen during the multiple data transactions, corresponding to PAGEBURSTACCESSTIME multiplied by the number of remaining data transactions.

- Chip-select signal nCS:
  - nCS assertion time is controlled by the GPMC.GPMC\_CONFIG2\_i[3:0] CSORTIME field and ensures address setup time to nCS assertion.
  - nCS deassertion time is controlled by the GPMC.GPMC\_CONFIG2\_i[12:8] CSRDOFFTIME field and ensures address hold time to nCS deassertion.
- Address valid signal nADV:
  - nADV assertion time is controlled by the GPMC.GPMC\_CONFIG3\_i[3:0] ADVONTIME field.
  - nADV deassertion time is controlled by the GPMC.GPMC\_CONFIG3\_i[12:8] ADVRDOFFTIME field.
- Output enable signal nOE:
  - nOE assertion indicates a read cycle.
  - nOE assertion time is controlled by the GPMC.GPMC\_CONFIG4\_i[3:0] OEONTIME field.
  - nOE deassertion time is controlled by the GPMC.GPMC\_CONFIG4\_i[12:8] OEOFFTIME field.
- Initial latency for the first read data is controlled by GPMC.GPMC\_CONFIG5\_i[20:16] RDACCESSTIME or by monitoring the WAIT signal.
- Successive read data are provided by the memory device each one or two GPMC\_CLK cycles. The PAGEBURSTACCESSTIME parameter must be set accordingly with GPMCFCLKDIVIDER and the

memory-device internal configuration.

Depending on the device page length, the GPMC can control device page crossing during a new burst request and purposely insert initial latency.

- Total access time (RDCYCLETIME) corresponds to RDACCESSTIME plus the address hold time from nCS deassertion, plus the time from RDACCESSTIME to CSRDOFFTIME.
  - RDCYCLETIME is defined in the GPMC.GPMC\_CONFIG5\_i register.
  - In [Figure 10-19](#), the RDCYCLETIME programmed value equals RDCYCLETIME0 + RDCYCLETIME1.
- Direction signal DIR:  
DIR goes from OUT to IN at the same time as nOE assertion.

After a read operation, if no other access (read or write) is pending, the data bus is driven with the previous read value. See [Section 10.1.5.3.10, Bus Keeping Support](#).

- Burst wraparound

The GPMC.GPMC\_CONFIG1\_i[31] WRAPBURST bit allows a 4-, 8-, or 16-Word16 linear burst access to wrap within its burst-length boundary.

#### 10.1.5.10.4 Synchronous Multiple (Burst) Write

Burst write mode provides synchronous single or consecutive accesses.

[Figure 10-20](#) shows a synchronous multiple (burst) write.

**Figure 10-20. Synchronous Multiple (Burst) Write**

NOTE: The WAIT signal is active low.

In the following section i stands for the chip-select number, i = 0 to 7.

- GPMC.[GPMC\\_CONFIG1\\_i](#) register settings:
  - WRITEMULTIPLE bit at 1 (write multiple access)
  - WRITETYPE bit at 1 (write synchronous)
  - MUXADDDATA bit at 1 (address/data-multiplexed device)

When WRACCESSTIME completes, control-signal timings are frozen during the multiple data transactions, corresponding to the PAGEBURSTACCESSTIME multiplied by the number of remaining data transactions.

- Chip-select signal nCS:
  - nCS assertion time is controlled by the GPMC.[GPMC\\_CONFIG2\\_i\[3:0\]](#) CSONTIME field and ensures address setup time to nCS assertion.
  - nCS deassertion time controlled by the GPMC.[GPMC\\_CONFIG2\\_i\[20:16\]](#) CSWROFFTIME field and ensures address hold time to nCS deassertion.
- Address valid signal nADV:
  - nADV assertion time is controlled by the GPMC.[GPMC\\_CONFIG3\\_i\[3:0\]](#) ADVONTIME field.
  - nADV deassertion time is controlled by the GPMC.[GPMC\\_CONFIG3\\_i\[20:16\]](#) ADVWROFFTIME field.
- Write enable signal nWE:

- nWE assertion indicates a write cycle.
- nWE assertion time is controlled by the GPMC.[GPMC\\_CONFIG4\\_i\[19:16\]](#) WEONTIME field.
- nWE deassertion time is controlled by the GPMC.[GPMC\\_CONFIG4\\_i\[28:24\]](#) WEOFFTIME field.

---

**NOTE:** The nWE falling edge must not be used to control the time when the burst first data is driven in the address / data bus because some new devices require the nWE signal at low during the address phase.

---

- First write data is driven by the GPMC at WRDATAONADMUXBUS ([GPMC\\_CONFIG6\\_i\[19:16\]](#)), when in address/data mux configuration. The next write data of the burst is driven on the bus at WRACCESSTIME + 1 during PAGEBURSTACCESSTIME GPMC\_FCLK cycles. The last data of the synchronous burst write is driven until WRCYCLETIME completes.
  - WRACCESSTIME is defined in the GPMC.[GPMC\\_CONFIG5\\_i](#) register.
  - The PAGEBURSTACCESSTIME parameter must be set accordingly with GPMCFCLKDIVIDER and the memory-device internal configuration.
- Total access time (WRCYCLETIME) corresponds to WRACCESSTIME plus the address hold time from nCS deassertion, plus time from WRACCESSTIME to CSWROFFTIME.
  - WRCYCLETIME is defined in the GPMC.[GPMC\\_CONFIG5\\_i](#) register.
  - In [Figure 10-20](#), the WRCYCLETIME programmed value equals WRCYCLETIME0 + WRCYCLETIME1.
- Direction signal DIR:  
DIR is OUT during the entire access.

After a write operation, if no other access (read or write) is pending, the data bus keeps the previous value. See [Section 10.1.5.3.10, Bus Keeping Support](#).

[Figure 10-21](#) shows the same synchronous burst write access when the chip-select is configured in address/data-multiplexed mode.

**Figure 10-21. Synchronous Multiple Write (Burst Write) in Address/Data-Multiplexed Mode**

The first data of the burst is driven on the a/d bus at [GPMC\\_CONFIG6\\_i\[19:16\]](#) WRDATAONADMUXBUS.

#### 10.1.5.11 pSRAM Basic Programming Model

pSRAM devices are SRAM-pin-compatible low-power memories that contain a self-refreshed DRAM memory array. These devices can be accessed by the GPMC with the GPMC.[GPMC\\_CONFIG1\\_i\[11:10\]](#) DEVICETYPE field ( $i = 0$  to  $7$ ).

The pSRAM devices support the following operations:

- Asynchronous single read
- Asynchronous page read
- Asynchronous single write
- Synchronous single read and write
- Synchronous burst read
- Synchronous burst write

pSRAM devices must be powered up and initialized in a predefined manner according to the specifications of the attached device.

pSRAM devices can be programmed to use either mode: fixed or variable latency. pSRAM devices can either automatically schedule autorefresh operations, which force the GPMC to use its WAIT signal capability when read or write operations occur during an internal self-refresh operation, or pSRAM devices automatically include the autorefresh operation in the access time. These devices do not require additional WAIT signal capability or a minimum nCS high pulse width between consecutive accesses to ensure that the correct internal refresh operation is scheduled.

In both pSRAM cases, the GPMC configuration for this chip-select must be set according to the specifications of the attached device.

### 10.1.5.12 Error Handling

When an error occurs in the GPMC, the error information is stored in the GPMC.[GPMC\\_ERR\\_TYPE](#) register and the address of the illegal access is stored in the GPMC.[GPMC\\_ERR\\_ADDRESS](#) register. The GPMC only keeps the first error abort information until the GPMC.[GPMC\\_ERR\\_TYPE](#) register is reset. Subsequent accesses that cause errors are not logged until the error is cleared by hardware with the GPMC.[GPMC\\_ERR\\_TYPE](#)[0] ERRORVALID bit.

- ERRORNOTSUPPADD occurs when an incoming system request address decoding does not match any valid chip-select region, or if two chip-select regions are defined as overlapped, or if a register file access is tried outside the valid address range of 1 Kbyte.
- ERRORNOTSUPPMCMD occurs when an unsupported command request is decoded at the L3 interconnect interface.
- ERRORTIMEOUT: A time-out mechanism prevents the system from hanging. The start value of the 9-bit time-out counter is defined in the GPMC.[GPMC\\_TIMEOUT\\_CONTROL](#) register and enabled with the GPMC.[GPMC\\_TIMEOUT\\_CONTROL](#)[0] TIMEOUTENABLE bit. When enabled, the counter starts at start-cycle time until it reaches 0 and data is not responded to from memory, then a time-out error occurs. When data are sent from memory, this counter is reset to its start value. With multiple accesses (asynchronous page mode or synchronous burst mode), the counter is reset to its start value for each data access within the burst.

The GPMC does not generate interrupts on these errors. True abort to the MPU or interrupt generation is handled at interconnect level.

### 10.1.5.13 Boot Configuration

See [Section 10.1.3.3.2, GPMC CS0 Default Configuration at IC Reset](#).

### 10.1.5.14 NAND Device Basic Programming Model

NAND (8-bit and 16-bit) memory devices using a classical NAND asynchronous address/data-multiplexing scheme can be supported on any chip-select with the appropriate asynchronous configuration settings.

As for any other type of memory compatible with the GPMC interface, accesses to a chip-select allocated to a NAND device can be interleaved with accesses to chip-selects allocated to other external devices. This interleaved capability limits the system to chip enable dont care NAND devices since the chip-select allocated to the NAND device has to be de-asserted if accesses to other chip-selects are requested.

#### 10.1.5.14.1 NAND Memory Device in Byte or Word16 Stream Mode

NAND devices require correct command and address programming before data array read or write accesses. The GPMC does not include specific hardware to translate a random address system request into a NAND-specific multiphase access. In that sense, GPMC NAND support, as opposed to random memory-map device support, is data-stream-oriented (byte or Word16).

The GPMC NAND programming model relies on a software driver for address and command formatting with the correct data address pointer value according to the block and page structure. Because of NAND structure and protocol interface diversity, the GPMC does not support automatic command and address phase programming, and software drivers must access the NAND device ID to ensure that correct command and address formatting are used for the identified device.

NAND device data read and write accesses are achieved through an asynchronous read or write access. The associated chip-select signal timing control must be programmed according to the NAND device timing specification.

Any chip-select region can be qualified as a NAND region to constrain the nADV/ALE signal as Address Latch Enable (ALE active high, default state value at low) during address program access, and the nBE0/CLE signal as Command Latch Enable (CLE active high, default state value at low) during command program access. GPMC address lines are not used (the previous value is not changed) during NAND access.

#### 10.1.5.14.1.1 Chip-Select Configuration for NAND Interfacing in Byte or Word Stream Mode

The GPMC.[GPMC\\_CONFIG7\\_i](#) register (where  $i = 0$  to  $7$ ) associated with a NAND device region interfaced in byte or word stream mode can be initialized with a minimum size of 16 Mbytes, because any address location in the chip-select memory region can be used to access a NAND data array. The NAND Flash protocol specifies an address sequence where address bits are passed through the data bus in a series of write accesses with the ALE pin asserted. After this address phase, all operations are streamed and the system requests address is irrelevant.

#### CAUTION

To allow correct command, address, and data-access controls, the GPMC.[GPMC\\_CONFIG1\\_i](#) register associated with a NAND device region must be initialized in asynchronous read and write modes with the parameters listed in [Table 10-4](#). Failure to comply with these settings corrupts the NAND interface protocol.

**Table 10-4. Chip-Select Configuration for NAND Interfacing**

| Bit Field                | Register                                          | Value        | Comments                                         |
|--------------------------|---------------------------------------------------|--------------|--------------------------------------------------|
| WRAPBURST                | <a href="#">GPMC_CONFIG1_i[31]</a> <sup>(1)</sup> | 0            | No wrap                                          |
| READMULTIPLE             | <a href="#">GPMC_CONFIG1_i[30]</a>                | 0            | Single access                                    |
| READTYPE                 | <a href="#">GPMC_CONFIG1_i[29]</a>                | 0            | Asynchronous mode                                |
| WRITEMULTIPLE            | <a href="#">GPMC_CONFIG1_i[28]</a>                | 0            | Single access                                    |
| WRITETYPE                | <a href="#">GPMC_CONFIG1_i[27]</a>                | 0            | Asynchronous mode                                |
| CLKACTIVATIONTIME        | <a href="#">GPMC_CONFIG1_i[26:25]</a>             | 00           |                                                  |
| ATTACHEDDEVICEPAGELENGTH | <a href="#">GPMC_CONFIG1_i[24:23]</a>             | Don't care   | Single-access mode                               |
| WAITREADMONITORING       | <a href="#">GPMC_CONFIG1_i[22]</a>                | 0            | Wait not monitored by GPMC access engine         |
| WAITWRITEMONITORING      | <a href="#">GPMC_CONFIG1_i[21]</a>                | 0            | Wait not monitored by GPMC access engine         |
| WAITMONITORINGTIME       | <a href="#">GPMC_CONFIG1_i[19:18]</a>             | Don't care   | Wait not monitored by GPMC access engine         |
| WAITPINSELECT            | <a href="#">GPMC_CONFIG1_i[17:16]</a>             |              | Select which wait is monitored by edge detectors |
| DEVICESIZE               | <a href="#">GPMC_CONFIG1_i[13:12]</a>             | 0b00 or 0b01 | 8- or 16-bit interface                           |
| DEVICETYPE               | <a href="#">GPMC_CONFIG1_i[11:10]</a>             | 0b10         | NAND device in stream mode                       |
| MUXADDDATA               | <a href="#">GPMC_CONFIG1_i[9]</a>                 | 0            | Nonmultiplexed mode                              |
| TIMEPARAGRANULARITY      | <a href="#">GPMC_CONFIG1_i[4]</a>                 | 0            | Timing achieved with best GPMC clock granularity |
| GPMCFCLKDIVIDER          | <a href="#">GPMC_CONFIG1_i[1:0]</a>               | Don't care   | Asynchronous mode                                |

<sup>(1)</sup>  $i = 0$  to  $7$

The GPMC.[GPMC\\_CONFIG1\\_i](#) to GPMC.[GPMC\\_CONFIG4\\_i](#) register (where  $i = 0$  to  $7$ ) associated with a NAND device region must be initialized with the correct control-signal timing value according to the NAND device timing parameters.

#### 10.1.5.14.1.2 NAND Device Command and Address Phase Control

NAND devices require multiple address programming phases. The CPU software driver is responsible for issuing the correct number of command and address program accesses, according to the device command set and the device address-mapping scheme.

NAND device-command and address-phase programming is achieved through write requests to the GPMC.[GPMC\\_NAND\\_COMMAND\\_i](#) and GPMC.[GPMC\\_NAND\\_ADDRESS\\_i](#) register locations ( $i = 0$  to  $7$ ) with the correct command and address values. These locations are mapped in the associated chip-select register region. The associated chip-select signal timing control must be programmed according to the NAND device timing specification.

Command and address values are not latched during the access and cannot be read back at the register location.

- Only write accesses must be issued to these locations, but the GPMC does not discard any read access. Accessing a NAND device with nOE and CLE or ALE asserted (read access) can produce undefined results.
- Write accesses to the GPMC.[GPMC\\_NAND\\_COMMAND\\_i](#) register location and to the GPMC.[GPMC\\_NAND\\_ADDRESS\\_i](#) register location must be posted for faster operations ( $i = 0$  to  $7$ ). The GPMC.[GPMC\\_CONFIG\[0\]](#) NANDFORCEPOSTEDWRITE bit enables write accesses to these locations as posted, even if they are defined as nonposted.

A write buffer is used to store write transaction information before the external device is accessed:

- Up to eight consecutive posted write accesses can be accepted and stored in the write buffer.
- For nonposted write, the pipeline is one deep.
- An GPMC.[GPMC\\_STATUS\[0\]](#) EMPTYWRITEBUFFERSTATUS bit stores the empty status of the write buffer.

GPMC.[GPMC\\_NAND\\_COMMAND\\_i](#) and GPMC.[GPMC\\_NAND\\_ADDRESS\\_i](#) ( $i = 0$  to  $7$ ) are Word32 locations, which means any Word32 or Word16 access is split into 4- or 2-byte accesses if an 8-bit wide NAND device is attached. For multiple-command phase or multiple-address phase, the software driver can use Word32 or Word16 access to these registers, but it must account for the splitting and little-endian ordering scheme. When only one byte command or address phase is required, only byte write access to GPMC.[GPMC\\_NAND\\_COMMAND\\_i](#) and GPMC.[GPMC\\_NAND\\_ADDRESS\\_i](#) can be used, and any of the four byte locations of the registers are valid.

The same applies to a GPMC.[GPMC\\_NAND\\_COMMAND\\_i](#) and a GPMC.[GPMC\\_NAND\\_ADDRESS\\_i](#) ( $i = 0$  to  $7$ ) Word32 write access to a 16-bit wide NAND device (split into two Word16 accesses). In the case of a Word16 write access, the MSByte of the Word16 value must be set according to the NAND device requirement (usually 0). Either Word16 location or any one of the four byte locations of the registers is valid.

#### 10.1.5.14.1.3 Command Latch Cycle

Writing data at the GPMC.[GPMC\\_NAND\\_COMMAND\\_i](#) location ( $i = 0$  to  $7$ ) places the data as the NAND command value on the bus, using a regular asynchronous write access.

- nCE is controlled by the CSONTIME and CSWROFFTIME timing parameters.
- CLE is controlled by the ADVONTIME and ADVWROFFTIME timing parameters.
- nWE is controlled by the WEONTIME and WEOFETIME timing parameters.
- ALE and nRE (nOE) are maintained inactive.

Figure 10-22 shows the NAND command latch cycle.

**Figure 10-22. NAND Command Latch Cycle**

**NOTE:** CLE is shared with the nBE0 output signal and has an inverted polarity from BE0. The NAND qualifier deals with this. During the asynchronous NAND data access cycle, nBE0 (also nBE1) must not toggle, because it is shared with CLE.

NAND flash memories do not use byte enable signals.

#### 10.1.5.14.1.4 Address Latch Cycle

Writing data at the GPMC.GPMC\_NAND\_ADDRESS\_i location ( $i = 0$  to 7) places the data as the NAND partial address value on the bus, using a regular asynchronous write access.

- nCS is controlled by the CSONTIME and CSWROFFTIME timing parameters.
- ALE is controlled by the ADVONTIME and ADVWROFFTIME timing parameters.
- nWE is controlled by the WEONTIME and WEOFETIME timing parameters.
- CLE and nRE (nOE) are maintained inactive.

Figure 10-23 shows the NAND address latch cycle.

**Figure 10-23. NAND Address Latch Cycle**

**NOTE:** ALE is shared with the nADV output signal and has an inverted polarity from ADV. The NAND qualifier deals with this. During the asynchronous NAND data access cycle, ALE is kept stable.

#### 10.1.5.14.1.5 NAND Device Data Read and Write Phase Control in Stream Mode

NAND device data read and write accesses are achieved through a read or write request to the chip-select-associated memory region at any address location in the region or through a read or write request to the GPMC.[GPMC\\_NAND\\_DATA\\_i](#) location ( $i = 0$  to  $7$ ) mapped in the chip-select-associated control register region. GPMC.[GPMC\\_NAND\\_DATA\\_i](#) is not a true register, but an address location to enable nRE or nWE signal control. The associated chip-select signal timing control must be programmed according to the NAND device timing specification.

Reading data from the GPMC.[GPMC\\_NAND\\_DATA\\_i](#) location or from any location in the associated chip-select memory region activates an asynchronous read access.

- nCS is controlled by the CSONTIME and CSRDOFFTIME timing parameters.
- nRE is controlled by the OEONTIME and OEOFETIME timing parameters.
- To take advantage of nRE high-to-data invalid minimum timing value, the RDACCESSTIME can be set so that data are effectively captured after nRE deassertion. This allows optimization of NAND read access cycle time completion. For optimal timing parameter settings, see the NAND device and device IC timing parameters.

ALE, CLE, and nWE are maintained inactive.

Figure 10-24 shows the NAND data read cycle.

Figure 10-24. NAND Data Read Cycle



gpmc-024

Writing data to the GPMC.[GPMC\\_NAND\\_DATA\\_i](#) location or to any location in the associated chip-select memory region activates an asynchronous write access.

- nCS is controlled by the CSONTIME and CSWROFFTIME timing parameters.
- nWE is controlled by the WEONTIME and WEOFETIME timing parameters.
- ALE, CLE, and nRE (nOE) are maintained inactive.

Figure 10-25 shows the NAND data write cycle.

**Figure 10-25. NAND Data Write Cycle**

gpmc-025

#### 10.1.5.14.1.6 NAND Device General Chip-Select Timing Control Requirement

For most NAND devices, read data access time is dominated by nCS-to-data-valid timing and has faster nRE-to-data-valid timing. Successive accesses with nCS deassertions between accesses are affected by this timing constraint. Because accesses to a NAND device can be interleaved with other chip-select accesses, there is no certainty that nCS always stays low between two accesses to the same chip-select. Moreover, an nCS deassertion time between the same chip-select NAND accesses is likely to be required as follows: the nCS deassertion requires programming CYCLETIME and RDACCESSTIME according to the nCS-to-data-valid critical timing.

To get full performance from NAND read and write accesses, the prefetch engine can dynamically reduce RDCYCLETIME, WRCYCLETIME, RDACCESSTIME, WRACCESSTIME, CSRDOFFTIME, CSWROFFTIME, ADVRDOFFTIME, ADVWROFFTIME, OEOFETIME, and WEOFFTIME on back-to-back NAND accesses (to the same memory) and suppress the minimum nCS high pulse width between accesses. For more information about optimal prefetch engine access, see [Section 10.1.5.14.4, Prefetch and Write-Posting Engine](#).

Some NAND devices require minimum write-to-read idle time, especially for device-status read accesses following status-read command programming (write access). If such write-to-read transactions are used, a minimum nCS high pulse width must be set. For this, CYCLE2CYCLESAMECSEN and CYCLE2CYCLEDELAY must be set according to the appropriate timing requirement to prevent any timing violation.

NAND devices usually have an important nRE high to data bus in tristate mode. This requires a bus turnaround setting (BUSTURNAROUND = 1) so that the next access to a different chip-select is delayed until the BUSTURNAROUND delay completes. Back-to-back NAND read accesses to the same NAND flash are not affected by the programmed bus turnaround delay.

#### 10.1.5.14.1.7 Read and Write Access Size Adaptation

##### 10.1.5.14.1.7.1 8-Bit Wide NAND Device

Host Word16 and Word32 read and write access requests to a chip-select associated with an 8-bit wide NAND device are split into successive read and write byte accesses to the NAND memory device. Byte access is ordered according to little-endian organization. A NAND 8-bit-wide device must be interfaced on the D0:D7 interface bus lane. GPMC data accesses are justified on this bus lane when the chip-select is associated with an 8-bit wide NAND device.

##### 10.1.5.14.1.7.2 16-Bit Wide NAND Device

Host Word32 read and write access requests to a chip-select associated with a 16-bit wide NAND device are split into successive read and write Word16 accesses to the NAND memory device. Word16 access is ordered according to little-endian organization.

Host byte read and write access requests to a 16-bit wide NAND device are completed as 16-bit accesses on the device itself, because there is no byte-addressing capability on 16-bit wide NAND devices. This means that the NAND device address pointer is incremented on a Word16 basis and not on a byte basis. For a read access, only the requested byte is given back to the host, but the remaining byte is not stored or saved by the GPMC, and the next byte or Word16 read access gets the next Word16 NAND location. For a write access, the invalid byte part of the Word16 is driven to FF, and the next byte or Word16 write access programs the next Word16 NAND location.

Generally, byte access to a 16-bit wide NAND device should be avoided, especially when ECC calculation is enabled. 8-bit or 16-bit ECC-based computations are corrupted by a byte read to a 16-bit wide NAND device, because the nonrequested byte is considered invalid on a read access (not captured on the external data bus; FF is fed to the ECC engine) and is set to FF on a write access.

Host requests (read/write) issued in the chip-select memory region are translated in successive single or split accesses (read/write) to the attached device. Therefore, incrementing 32-bit burst requests are translated in multiple 32-bit sequential accesses following the access adaptation of the 32-bit to 8- or 16-bit device.

#### 10.1.5.14.2 NAND Device-Ready Pin

The NAND memory device provides a ready pin to indicate data availability after a block/page opening and to indicate that data programming is complete. The ready pin can be connected to one of the four WAIT GPMC input pins; data read accesses must not be tried when the ready pin is sampled inactive (device is not ready) even if the associated chip-select WAITREADMONITORING bit field is set. The duration of the NAND device busy state after the block/page opening is so long (up to 50  $\mu$ s) that accesses occurring when the ready pin is sampled inactive can stall GPMC access and eventually cause a system time-out.

---

**NOTE:** If a read access to a NAND flash is done using the wait monitoring mode, the device is blocked during a page opening, and so is the GPMC. If the correct settings are used, other chip-selects can be used while the memory processes the page opening command.

To avoid a time-out caused by a block/page opening delay in NAND flash, disable the wait pin monitoring for read and write accesses (that is, set the GPMC.[GPMC\\_CONFIG1\\_i\[21\]](#) WAITWRITEMONITORING and GPMC.[GPMC\\_CONFIG1\\_i\[22\]](#) WAITREADMONITORING bits to 0, where  $i = 0$  to 7), and use one of the following methods instead:

- Use software to poll the WAITnSTATUS bit ( $n = 0$  to 3) of the [GPMC\\_STATUS](#) register.
- Configure an interrupt that is generated on the WAIT signal change (through the GPMC.[GPMC\\_IRQENABLE](#) register bits[11:8]).

Even if the READWAITMONITORING bit is not set, the external memory nR/B pin status is captured in the programmed WAIT bit in the [GPMC\\_STATUS](#) register.

The READWAITMONITORING bit method must be used for memories other than NAND flash, if they require the use of a WAIT signal.

---

##### 10.1.5.14.2.1 Ready Pin Monitored by Software Polling

The ready signal state can be monitored through the GPMC.[GPMC\\_STATUS](#) WAITxSTATUS bit ( $x = 0$  to 3). The software must monitor the ready pin only when the signal is declared valid. See the NAND device timing parameters to set the correct software temporization to monitor ready only after the invalid window is complete from the last read command written to the NAND device.

##### 10.1.5.14.2.2 Ready Pin Monitored by Hardware Interrupt

Each gpmc\_wait input pin can generate an interrupt when a wait-to-no-wait transition is detected. Depending on whether the GPMC.[GPMC\\_CONFIG](#) WAITxPINPOLARITY bits ( $x = 0$  to 3) is active low or active high, the wait-to-no-wait transition is a low-to-high external WAIT signal transition or a high-to-low external WAIT signal transition, respectively.

The wait transition pin detector must be cleared before any transition detection. This is done by writing 1

to the WAITxEDGEDETECTIONSTATUS bit ( $x = 0$  to  $3$ ) of the GPMC.[GPMC\\_IRQSTATUS](#) register according to the gpmc\_wait pin used for the NAND device-ready signal monitoring. To detect a wait-to-no-wait transition, the transition detector requires a wait active time detection of a minimum of two GPMC\_FCLK cycles. Software must incorporate precautions to clear the wait transition pin detector before wait (busy) time completes.

A wait-to-no-wait transition detection can issue a GPMC interrupt if the WAITxEDGEDETECTIONENABLE bit in the GPMC.[GPMC\\_IRQENABLE](#) register is set and if the WAITxEDGEDETECTIONSTATUS bit field in the GPMC.[GPMC\\_IRQSTATUS](#) register is set.

The WAITMONITORINGTIME field does not affect wait-to-no-wait transition time detection.

It is also possible to poll the WAITxEDGEDETECTIONSTATUS bit field in the GPMC.[GPMC\\_IRQSTATUS](#) register according to the gpmc\_wait pin used for the NAND device ready signal monitoring.

#### **10.1.5.14.3 ECC Calculator**

The general-purpose memory controller includes an error code correction (ECC) calculator circuitry that enables on-the-fly ECC calculation during data read or data program (that is, write) operations.

The user can choose from two different algorithms with different error correction capabilities: Hamming code (for 1-bit error code correction), and BCH code (for 4- or 8-bit error correction) through the [GPMC\\_ECC\\_CONFIG\[16\]](#) ECCALGORITHM bit. Only one ECC context can be active at any given time through the [GPMC\\_ECC\\_CONFIG\[3:1\]](#) ECCCS bit. Even if two CSs use different ECC algorithms, one the Hamming code and the other a BCH code, they must define separate ECC contexts, because some of the ECC registers are common to all types of algorithms.

##### **10.1.5.14.3.1 Hamming Code**

All references to ECC in this section refer to the 1-bit error correction Hamming code.

The ECC is based on a two-dimensional (row and column) bit parity accumulation known as Hamming code. The parity accumulation is done for a programmed number of bytes or Word16 read from the memory device or written to the memory device in stream mode.

There is no automatic error detection or correction, and it is the software NAND driver responsibility to read the multiple ECC calculation results, compare them to the expected code value, and take the appropriate corrective actions according to the error handling strategy (ECC storage in spare byte, error correction on read, block invalidation).

The ECC engine includes a single accumulation context. It can be allocated to a single designated chip-select at a time and parallel computations on different chip-selects are not possible. Since it is allocated to a single chip-select, the ECC computation is not affected by interleaved GPMC accesses to other chip-selects and devices. The ECC accumulation is sequentially processed in the order of data read from or written to the memory on the designated chip-select. The ECC engine does not differentiate read accesses from write accesses and does not differentiate data from command or status information. It is the software responsibility to make sure only relevant data are passed to the NAND flash memory while the ECC computation engine is active.

The starting NAND page location must be programmed first, followed by an ECC accumulation context reset with an ECC enabling, if required. The NAND device accesses discussed in the following sections must be limited to data read or write until the specified number of ECC calculations is completed.

###### **10.1.5.14.3.1.1 ECC Result Register and ECC Computation Accumulation Size**

The GPMC includes up to nine ECC result registers (GPMC.[GPMC\\_ECCj\\_RESULT](#),  $j = 1$  to  $9$ ) to store ECC computation results when the specified number of bytes or Word16s has been computed.

The ECC result registers are used sequentially; one ECC result is stored in one ECC result register on the list, the next ECC result is stored in the next ECC result register on the list, and so forth, until the last ECC computation. The GPMC.[GPMC\\_ECCj\\_RESULT](#) register value is valid only when the programmed number of bytes or Word16s has been accumulated, which means that the same number of bytes or Word16s has been read from or written to the NAND device in sequence.

The GPMC.[GPMC\\_ECC\\_CONTROL](#)[3:0] ECCPOINTER field must be set to the correct value to select the ECC result register to be used first in the list for the incoming ECC computation process. The ECCPointer can be read to determine which ECC register is used in the next ECC result storage for the ongoing ECC computation. The GPMC.[GPMC\\_ECCj\\_RESULT](#) register value ( $j = 1$  to  $9$ ) can be considered valid when ECCPOINTER equals  $j + 1$ . When GPMC.[GPMC\\_ECCj\\_RESULT](#) (where  $j = 9$ ) is updated, ECCPOINTER is frozen at 10, and ECC computing is stopped (ECCENABLE = 0).

The ECC accumulator must be reset before any ECC computation accumulation process. The GPMC.[GPMC\\_ECC\\_CONTROL](#)[8] ECCCLEAR bit must be set to 1 (nonpersistent bit) to clear the accumulator and all ECC result registers.

For each ECC result (each GPMC.[GPMC\\_ECCj\\_RESULT](#) register,  $j = 1$  to  $9$ ), the number of bytes or Word16s used for ECC computing accumulation can be selected from between two programmable values.

The ECCjRESULTSIZE bits ( $j = 1$  to  $9$ ) in the GPMC.[GPMC\\_ECC\\_SIZE\\_CONFIG](#) register select which programmable size value (ECCSIZE0 or ECCSIZE1) must be used for this ECC result (stored in GPMC.[GPMC\\_ECCj\\_RESULT](#)).

The ECCSIZE0 and ECCSIZE1 fields allow selection of the number of bytes or Word16s used for ECC computation accumulation. Any even values from 2 to 512 are allowed.

Flexibility in the number of ECCs computed and the number of bytes or Word16s used in the successive ECC computations enables different NAND page error-correction strategies. Usually based on 256 or 512 bytes and on 128 or 256 Word16, the number of ECC results required is a function of the NAND device page size. Specific ECC accumulation size can be used when computing the ECC on the NAND spare byte.

For example, with a 2-Kbyte data page 8-bit-wide NAND device, eight ECCs accumulated on 256 bytes can be computed and added to one extra ECC computed on the 24 spare bytes area where the eight ECC results used for comparison and correction with the computed data page ECC are stored. The GPMC then provides nine GPMC.[GPMC\\_ECCj\\_RESULT](#) registers ( $j = 1$  to  $9$ ) to store the results. In this case, ECCSIZE0 is set to 256, and ECCSIZE1 is set to 24; the ECC[1:8]RESULTSIZE bits are set to 0, and the ECC9RESULTSIZE bit is set to 1.

#### 10.1.5.14.3.1.2 ECC Enabling

The GPMC.[GPMC\\_ECC\\_CONFIG](#)[3:0] ECCCS field selects the allocated chip-select. The GPMC.[GPMC\\_ECC\\_CONFIG](#)[0] ECCENABLE bit enables ECC computation on the next detected read or write access to the selected chip-select.

The ECCPOINTER, ECCCLEAR, ECCSIZE, ECCjRESULTSIZE (where  $j = 1$  to  $9$ ), ECC16B, and ECCCS fields must not be changed or cleared while an ECC computation is in progress.

The ECC accumulator and ECC result register must not be changed or cleared while an ECC computation is in progress.

Table 10-5 describes the ECC enable settings.

Table 10-5. ECC Enable Settings

| Bit Field                            | Register             | Value       | Comments                                                                                                                  |
|--------------------------------------|----------------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| ECCCS                                | GPMC_ECC_CONFIG      | 0 -7        | Selects the chip-select where ECC is computed                                                                             |
| ECC16B                               | GPMC_ECC_CONFIG      | 0/1         | Selects column number for ECC calculation                                                                                 |
| ECCCLEAR                             | GPMC_ECC_CONTROL     | 0 -7        | Clears all ECC result registers                                                                                           |
| ECCPOINTER                           | GPMC_ECC_CONTROL     | 0 -7        | A write to this bit field selects the ECC result register where the first ECC computation is stored. Set to 1 by default. |
| ECCSIZE1                             | GPMC_ECC_SIZE_CONFIG | 0x00 -0xFF  | Defines ECCSIZE1                                                                                                          |
| ECCSIZE0                             | GPMC_ECC_SIZE_CONFIG | 0x00 - 0xFF | Defines ECCSIZE0                                                                                                          |
| ECCjRESULTSIZE<br>( $j$ from 1 to 9) | GPMC_ECC_SIZE_CONFIG | 0/1         | Selects the size of ECCn result register                                                                                  |
| ECCENABLE                            | GPMC_ECC_CONFIG      | 1           | Enables the ECC computation                                                                                               |

### 10.1.5.14.3.1.3 ECC Computation

The ECC algorithm is a multiple parity bit accumulation computed on the odd and even bit streams extracted from the byte or Word 16 streams. The parity accumulation is split into row and column accumulations, as shown in [Figure 10-26](#) and [Figure 10-27](#). The intermediate row and column parities are used to compute the upper level row and column parities. Only the final computation of each parity bit is used for ECC comparison and correction.

$P1o = \text{bit7 XOR bit5 XOR bit3 XOR bit1}$  on each byte of the data stream

$P1e = \text{bit6 XOR bit4 XOR bit2 XOR bit0}$  on each byte of the data stream

$P2o = \text{bit7 XOR bit6 XOR bit5 XOR bit4}$  on each byte of the data stream

$P2e = \text{bit5 XOR bit4 XOR bit1 XOR bit0}$  on each byte of the data stream

$P4o = \text{bit7 XOR bit6 XOR bit5 XOR bit4}$  on each byte of the data stream

$P4e = \text{bit3 XOR bit2 XOR bit1 XOR bit0}$  on each byte of the data stream

Each column parity bit is XORed with the previous accumulated value.

**Figure 10-26. Hamming Code Accumulation Algorithm (1/2)**



gpmc-026

For line parities, the bits of each new data are XORed together, and line parity bits are computed as described below:

$P8e = \text{row0 XOR row2 XOR row4 XOR row254}$

$P8o = \text{row1 XOR row3 XOR row5 XOR row255}$

$P16e = \text{row0 XOR row1 XOR row4 XOR row5 XOR row252 XOR row253}$

$P16o = \text{row2 XOR row3 XOR row6 XOR row7 XOR row254 XOR row255}$

**Figure 10-27. Hamming Code Accumulation Algorithm (2/2)**


gpmc-027

Unused parity bits in the result registers are set to 0.

[Figure 10-28](#) shows ECC computation for a 256-byte data stream (read or write). The result includes six column parity bits (P1o-P2o-P4o for odd parities, and P1e-P2e-P4e for even parities) and sixteen row parity bits (P8o-P16o-P32o--P1024o for odd parities, and P8e-P16e-P32e--P1024e for even parities).

**Figure 10-28. ECC Computation for a 256-Byte Data Stream (Read or Write)**


gpmc-028

[Figure 10-29](#) shows ECC computation for a 512-byte data stream (read or write). The result includes six column parity bits (P1o-P2o-P4o for odd parities, and P1e-P2e-P4e for even parities) and eighteen row parity bits (P8o-P16o-P32o--P1024o - P2048o for odd parities, and P8e-P16e-P32e--P1024e- P2048e for even parities).

**Figure 10-29. ECC Computation for a 512-Byte Data Stream (Read or Write)**

gpmc-029

For a 2-Kbytes page, four 512-byte ECC calculations plus one for the spare area are required. Results are stored in the [GPMC\\_ECCj\\_RESULT](#) registers ( $j = 1$  to 9).

#### **10.1.5.14.3.1.4 ECC Comparison and Correction**

To detect an error, the computed ECC result must be XORed with the parity value stored in the spare area of the accessed page.

- If the result of this logical XOR is all 0s, no error is detected and the read data is correct.
- If every second bit in the parity result is a 1, one bit is corrupted and is located at bit address (P2048o, P1024o, P512o, P256o, P128o, P64o, P32o, P16o, P8o, P4o, P2o, P1o). The software must correct the corresponding bit.
- If only one bit in the parity result is 1, it is an ECC error and the read data is correct.

#### **10.1.5.14.3.1.5 ECC Calculation Based on 8-Bit Word**

The 8-bit based ECC computation is used for 8-bit wide NAND device interfacing.

The 8-bit based ECC computation can be used for 16-bit wide NAND device interfacing to get backward compatibility on the error-handling strategy used with 8-bit wide NAND devices. In this case, the 16-bit wide data read from or written to the NAND device is fragmented into 2 bytes. According to little-endian access, the least significant bit (LSB) of the 16-bit wide data is ordered first in the byte stream used for 8-bit based ECC computation.

#### **10.1.5.14.3.1.6 ECC Calculation Based on 16-Bit Word**

ECC computation based on a 16-bit word is used for 16-bit wide NAND device interfacing. This ECC computation is not supported when interfacing an 8-bit wide NAND device, and the [GPMC\\_ECC\\_CONFIG\[7\]](#) ECC16B bit must be set to 0 when interfacing an 8-bit wide NAND device.

The parity computation based on 16-bit words affects the row and column parity mapping. The main difference is that the odd and even parity bits P8o and P8e are computed on rows for an 8-bit based ECC while they are computed on columns for a 16-bit based ECC. [Figure 10-30](#) and [Figure 10-31](#) show a 128 Word 16 ECC computation scheme and a 256 Word16 ECC computation scheme.

**Figure 10-30. 128 Word16 ECC Computation**


gpmc-030

**Figure 10-31. 256 Word16 ECC Computation**


gpmc-031

#### 10.1.5.14.3.2 BCH Code

All references to ECC in this section refer to the 4- or 8-bit error correction BCH code.

##### 10.1.5.14.3.2.1 Requirements

1. Read and write accesses to a NAND flash take place by whole pages, in a predetermined sequence: first, the data byte page itself, then some spare bytes, including the BCH ECC (and other information). The NAND IC can cache a full page, including spares, for read and write accesses.

Typical page write sequence:

- Sequential write to NAND cache of main data + spare data, for a page. ECC is calculated on the fly. Calculated ECC may be inserted on the fly in the spares, or replaced by dummy accesses.

- When the calculated ECC is replaced by dummy accesses, it must be written to the cache in a second, separate phase. The ECC module is disabled during that time.
- NAND writes its cache line (page) to the array.

Typical page read sequence:

- Sequential read of a page. ECC is calculated on-the-fly.
- ECC module buffers status determines the presence of errors.

- Accesses to several memories may be interleaved by the GPMC, but only one of those memories can be a NAND using the BCH engine at a time; in other words, only one BCH calculation (for example, for a single page) can be on-going at any time. Note also that the sequential nature of NAND accesses guarantees that the data is always written / read out in the same order. BCH-relevant accesses are selected by the GPMCs chip-select.
  - Each page may hold up to 4 Kbytes of data, spare bytes not included. This means up to  $8 * 512$ -byte BCH messages. Since all the data is written / read out first, followed by the BCH ECC, this means that the BCH engine must be able to hold 8 104-bit remainders or syndromes (or smaller, 52-bit ones) at the same time.
- The BCH module has the capacity to store all remainders internally. After the page start, an internal counter is used to detect the 512-byte sector boundaries. On those boundaries, the current remainder is stored and the divider reset for the next calculation. At the end of the page, the BCH module contains all remainders.
- NAND access cycles hold 8 or 16 bits of data each (1 or 2 bytes); Each NAND cycle takes at least 4 cycles of the GPMCs internal clock. This means the NAND flash timing parameters must define a RDCYCLETIME and a WRCYCLETIME of at least 4 clock cycles after optimization when using the BCH calculator.
  - The spare area is assumed to be large enough to hold the BCH ECC, that is, to have at least a message of 13 bytes available per 512-byte sector of data. The zone of unused spare area by the ECC may or may not be protected by the same ECC scheme, by extending the BCH message beyond 512 bytes (maximum codeword is 1023-byte long, ECC included, which leaves a lot of space to cover some spares bytes).

#### 10.1.5.14.3.2.2 Memory-Mapping of the BCH Codeword

BCH encoding considers a block of data to protect as a polynomial message  $M(x)$ . In our standard case, 512 bytes of data (that is,  $2^{12}$  bits = 4096 bits) are seen as a polynomial of degree  $2^{12} - 1 = 4095$ , with parameters ranging from M0 to M4095. For 512 bytes of data, 52 bits are required for 4-bit error correction, and 104 bits are required for 8-bit error correction. The ECC is a remainder polynomial  $R(x)$  of degree 103 (or 51, depending on the selected mode). The complete codeword  $C(x)$  is the concatenation of  $M(x)$  and  $R(x)$  as shown in [Table 10-6](#).

**Table 10-6. Flattened BCH Codeword Mapping (512 Bytes + 104 Bits)**

|            | Message $M(x)$ |     |    | ECC $R(x)$ |     |    |
|------------|----------------|-----|----|------------|-----|----|
| Bit number | M4095          | ... | M0 | R103       | ... | R0 |

If the message is extended by the addition of spare bytes to be protected by the same ECC, the principle is still valid. For example, a 3-byte extension of the message gives a polynomial message  $M(x)$  of degree  $((512 + 3) * 8) - 1 = 4119$ , for a total of  $3+13 = 16$  spare bytes of spare, all protected as part of the same codeword.

The message and the ECC bits are manipulated and mapped in the GPMC byte-oriented system. The ECC bits are stored in [GPMC\\_BCH\\_RESULT0\\_i](#), [GPMC\\_BCH\\_RESULT1\\_i](#), [GPMC\\_BCH\\_RESULT2\\_i](#), and [GPMC\\_BCH\\_RESULT3\\_i](#) (where  $i = 0$  to 7).

#### 10.1.5.14.3.2.2.1 Memory-Mapping of the Data Message

The data message mapping shall follow the following rules:

- Bit endianness within a byte is little-endian, that is, the bytes LS bit is also the lowest-degree polynomial parameter: a byte b7-b0 (with b0 the LS bit) represents a segment of polynomial  $b7 * x^{(7+i)} + b6 * x^{(6+i)} + \dots + b0 * x^i$
- The message is mapped in the NAND starting with the highest-order parameters, that is, in the lowest addresses of a NAND page.
- Byte endianness within the NANDs 16-bit words is big endian. This means that the same message mapped in 8- and 16-bit memories has the same content at the same byte address.

**NOTE:** The BCH module has no visibility over actual addresses. The most important point is the sequence of data word the BCH sees. However, the NAND page is always scanned incrementally in read and write accesses, which produces the mapping patterns described in the following.

**Table 10-7** and **Table 10-8** describe the mapping of the same 512-byte vector (typically a BCH message) in the NAND memory space. The byte "address" is only an offset modulo 512 (0x200), because the same page may contain several contiguous 512-byte sectors (BCH blocks). The LSB and MSB are respectively the bits M0 and M( $2^{12}-1$ ) of the codeword mapping given previously. In both cases the data vectors are aligned; that is, their boundaries coincide with the RAMs data word boundaries.

**Table 10-7. Aligned Message Byte Mapping in 8-bit NAND**

| Byte Offset | 8-Bit Word             |
|-------------|------------------------|
| 0x000       | (msb) Byte 511 (0x1FF) |
| 0x001       | Byte 510 (0x1FE)       |
| ...         | ...                    |
| 0x1FF       | Byte 0 (0x0) (lsb)     |

**Table 10-8. Aligned Message Byte Mapping in 16-bit NAND**

| Byte Offset | 16-Bit Word MSB  | 16-Bit Word LSB        |
|-------------|------------------|------------------------|
| 0x000       | Byte 510 (0x1FE) | (msb) Byte 511 (0x1FF) |
| 0x002       | Byte 508 (0x1FC) | Byte 509 (0x1FD)       |
| ...         | ...              | ...                    |
| 0x1FE       | Byte 0 (0x0)     | (lsb) Byte 1 (0x1)     |

**Table 10-9** through **Table 10-14** show the mapping in memory of arbitrarily-sized messages, starting on access (byte or 16-bit word) boundaries for more clarity. The message may actually start and stop on arbitrary nibbles. A nibble is a 4-bit entity. The unused nibbles are not discarded; they can still be used by the BCH module, but as part of the next message section (for example, on another sector ECC).

**Table 10-9. Aligned Nibble Mapping of Message in 8-bit NAND**

| Byte Offset | 8-Bit Word                    |                               |
|-------------|-------------------------------|-------------------------------|
|             | 4-Bit Most Significant Nibble | 4-Bit Less Significant Nibble |
| 1           | (msb) Nibble S-1              | Nibble S-2                    |
| 2           | Nibble S-3                    | Nibble S-4                    |
| ...         | ...                           | ...                           |
| S/2 - 2     | Nibble 3                      | Nibble 2                      |
| S/2 - 1     | Nibble 1                      | Nibble 0 (lsb)                |

**Table 10-10. Misaligned Nibble Mapping of Message in 8-bit NAND**

| Byte Offset | 8-Bit Word                    |                               |
|-------------|-------------------------------|-------------------------------|
|             | 4-Bit Most Significant Nibble | 4-Bit Less Significant Nibble |
| 1           | (msb) Nibble S-1              | Nibble S-2                    |
| 2           | Nibble S-3                    | Nibble S-4                    |
| ...         | ...                           | ...                           |
| (S+1)/2 - 2 | Nibble 2                      | Nibble 1                      |
| (S+1)/2 - 1 | Nibble 0 (lsb)                |                               |

**Table 10-11. Aligned Nibble Mapping of Message in 16-bit NAND**

| Byte Offset | 16-Bit Word                   |                               |                  |
|-------------|-------------------------------|-------------------------------|------------------|
|             | 4-Bit Most Significant Nibble | 4-Bit Less Significant Nibble |                  |
| 0           | Nibble S-3                    | Nibble S-4                    | (msb) Nibble S-1 |
| 2           | Nibble S-7                    | Nibble S-8                    | Nibble S-5       |
| ...         | ...                           | ...                           | ...              |
| S/2 - 4     | Nibble 5                      | Nibble 4                      | Nibble 7         |
| S/2 - 2     | Nibble 1                      | Nibble 0 (lsb)                | Nibble 3         |
|             |                               |                               | Nibble 2         |

**Table 10-12. Misaligned Nibble Mapping of Message in 16-bit NAND (1 Unused Nibble)**

| Byte Offset | 16-Bit Word                   |                               |                  |
|-------------|-------------------------------|-------------------------------|------------------|
|             | 4-Bit Most Significant Nibble | 4-bit less significant Nibble |                  |
| 0           | Nibble S-3                    | Nibble S-4                    | (msb) Nibble S-1 |
| 2           | Nibble S-7                    | Nibble S-8                    | Nibble S-5       |
| ...         | ...                           | ...                           | ...              |
| (S+1)/2 - 4 | Nibble 4                      | Nibble 3                      | Nibble 6         |
| (S+1)/2 - 2 | Nibble 0 (lsb)                |                               | Nibble 2         |
|             |                               |                               | Nibble 1         |

**Table 10-13. Misaligned Nibble Mapping of Message in 16-bit NAND (2 Unused Nibbles)**

| Byte Offset | 16-Bit Word                   |                               |                  |
|-------------|-------------------------------|-------------------------------|------------------|
|             | 4-Bit Most Significant Nibble | 4-Bit Less Significant Nibble |                  |
| 0           | Nibble S-3                    | Nibble S-4                    | (msb) Nibble S-1 |
| 2           | Nibble S-7                    | Nibble S-8                    | Nibble S-5       |
| ...         | ...                           | ...                           | ...              |
| (S+2)/2 - 4 | Nibble 3                      | Nibble 2                      | Nibble 5         |
| (S+2)/2 - 2 |                               |                               | Nibble 4         |
|             |                               |                               | Nibble 1         |
|             |                               |                               | Nibble 0 (lsb)   |

**Table 10-14. Misaligned Nibble Mapping of Message in 16-bit NAND (3 Unused Nibbles)**

| Byte Offset | 16-Bit Word                   |                               |                  |
|-------------|-------------------------------|-------------------------------|------------------|
|             | 4-Bit Most Significant Nibble | 4-Bit Less Significant Nibble |                  |
| 0           | Nibble S-3                    | Nibble S-4                    | (msb) Nibble S-1 |
| 2           | Nibble S-7                    | Nibble S-8                    | Nibble S-5       |
| ...         | ...                           | ...                           | ...              |
| (S+3)/2 - 4 | Nibble 2                      | Nibble 1                      | Nibble 4         |
| (S+3)/2 - 2 |                               |                               | Nibble 3         |
|             |                               |                               | Nibble 0 (lsb)   |

Many cases exist other than the ones previously given; for example, where the message does not start on a word boundary.

#### 10.1.5.14.3.2.2.2 Memory-Mapping of the ECC

The ECC (or remainder) is presented by the BCH module as a single 104-bit (or 52-bit), little-endian vector. It is up to the software to fetch those 13 bytes (or 6 bytes) from the modules interface, and then store them to the NAND spare area (page write) or to an intermediate buffer for comparison with the stored ECC (page read). There are no constraints on the ECC mapping inside the spare area: it is software-controlled.

However, it is advised to maintain a coherence in the respective formats of the message or the ECC remainder once they have been read out of the NAND. The error correction algorithm works from the complete codeword (concatenated message and remainder) once an error has been detected. The creation of this codeword must be made as straightforward as possible.

There are cases where the same NAND access contains both data and the ECC protecting that data. This is the case when the data/ECC boundary (which can be on any nibble) does not coincide with an access boundary. The ECC is calculated on-the-fly following the write. In that case, the write must also contain part of the ECC because it is impossible to insert the ECC on-the-fly. Instead:

- During the initial page write (BCH encoding), the ECC is replaced by dummy bits. The BCH encoder is by definition turned OFF during the ECC section, so the BCH result is unmodified.
- During a second phase, the ECC is written to the correct location, next to the actual data.
- The completed line buffer is then written to the NAND array.

#### 10.1.5.14.3.2.2.3 Wrapping Modes

For a given wrapping mode, the module automatically goes through a specific number of sections, as data is being fed into the module. For each section, the BCH core can be enabled (in which case the data is fed to the BCH divider) or not (in which case the BCH simply counts to the end of the section). When enabled, the data is added to the ongoing calculation for a given sector number (for example, number 0).

Wrapping modes are described below. To get a better understanding and see the real-life read and write sequences implemented with each mode, see [Section 10.1.5.14.3.2.3](#).

For each mode:

- A sequence describes the mode in pseudo-language, with the size and the buffer used for ECC processing (if ON) for each section. The programmable lengths are size, size0, and size1.
- A checksum condition is given. If the checksum condition is not respected for a given mode, the module behavior is unpredictable. S is the number of sectors in the page; size0 and size1 are the section sizes programmed for the mode, in nibbles.

Wrapping modes 8, 9, 10, and 11 insert a 1-nibble padding where the BCH processing is OFF. This is intended for t = 4 ECC, where ECC is 6 bytes long and the ECC area is expected to include (at least) one unused nibble to remain byte-aligned.

#### 10.1.5.14.3.2.2.4 Manual Mode (0x0)

This mode is intended for short sequences, added manually to a given buffer through the software data port input. A complete page may be built out of several such sequences.

To process an arbitrary sequence of 4-bit nibbles, accesses to the software data port shall be made, containing the appropriate data. If the sequence end does not coincide with an access boundary (for example, to process 5 nibbles = 20 bits in 16-bit access mode) and those nibbles need to be skipped, a number of unused nibbles shall be programmed in size1 (in the same example: 5 nibbles to process + 3 to discard = 8 nibbles = exactly 2 x 16-bit accesses: we must program size0 = 5, size1 = 3).

---

**NOTE:** In the following figures size and size0 are the same parameter.

---

**Figure 10-32. Manual Mode Sequence and Mapping**

gpmc-032

Section processing sequence:

- One time with buffer
  - size0 nibbles of data, processing ON
  - size1 nibbles of unused data, processing OFF

Checksum: size0 + size1 nibbles must fit in a whole number of accesses.

#### 10.1.5.14.3.2.2.5 Mode 0x1

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- Repeat with buffer 0 to S-1
  - size0 nibbles spare, processing ON
  - size1 nibbles spare, processing OFF

Checksum: Spare area size (nibbles) = S - (size0 + size1)

#### 10.1.5.14.3.2.2.6 Mode 0xA (10)

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- Repeat with buffer 0 to S-1
  - size0 nibbles spare, processing ON
  - 1 nibble pad spare, processing OFF
  - size1 nibbles spare, processing OFF

Checksum: Spare area size (nibbles) = S - (size0 + 1 + size1)

#### 10.1.5.14.3.2.2.7 Mode 0x2

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- Repeat with buffer 0 to S-1
  - size0 nibbles spare, processing OFF
  - size1 nibbles spare, processing ON

Checksum: Spare area size (nibbles) = S - (size0 + size1)

**10.1.5.14.3.2.2.8 Mode 0x3**

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- One time with buffer 0
  - size0 nibbles spare, processing ON
- Repeat with buffer 0 to S-1
  - size1 nibbles spare, processing ON

Checksum: Spare area size (nibbles) = size0 + (S - size1)

**10.1.5.14.3.2.2.9 Mode 0x7**

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- One time with buffer 0
  - size0 nibbles spare, processing ON
- Repeat S times (no buffer used)
  - size1 nibbles spare, processing OFF

Checksum: Spare area size (nibbles) = size0 + (S - size1)

**10.1.5.14.3.2.2.10 Mode 0x8**

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- One time with buffer 0
  - size0 nibbles spare, processing ON
- Repeat with buffer 0 to S-1
  - 1 nibble padding spare, processing OFF
  - size1 nibbles spare, processing ON

Checksum: Spare area size (nibbles) = size0 + (S - (1+size1))

**10.1.5.14.3.2.2.11 Mode 0x4**

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- One time (no buffer used)
  - size0 nibbles spare, processing OFF
- Repeat with buffer 0 to S-1
  - size1 nibbles spare, processing ON

Checksum: Spare area size (nibbles) = size0 + (S - size1)

**10.1.5.14.3.2.2.12 Mode 0x9**

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON

- One time (no buffer used)
  - size0 nibbles spare, processing OFF
- Repeat with buffer 0 to S-1
  - 1 nibble padding spare, processing OFF
  - size1 nibbles spare, processing ON

Checksum: Spare area size (nibbles) = size0 + (S - (1+size1))

#### **10.1.5.14.3.2.2.13 Mode 0x5**

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- Repeat with buffer 0 to S-1
  - size0 nibbles spare, processing ON
- Repeat with buffer 0 to S-1
  - size1 nibbles spare, processing ON

Checksum: Spare area size (nibbles) = S - (size0 + size1)

#### **10.1.5.14.3.2.2.14 Mode 0xB (11)**

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- Repeat with buffer 0 to S-1
  - size0 nibbles spare, processing ON
- Repeat with buffer 0 to S-1
  - 1 nibble padding spare, processing OFF
  - size1 nibbles spare, processing ON

Checksum: Spare area size (nibbles) = S - (size0 + 1 + size1)

#### **10.1.5.14.3.2.2.15 Mode 0x6**

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- Repeat with buffer 0 to S-1
  - size0 nibbles spare, processing ON
- Repeat S times (no buffer used)
  - size1 nibbles spare, processing OFF

Checksum: Spare area size (nibbles) = S - (size0 + size1)

#### **10.1.5.14.3.2.3 Supported NAND Page Mappings and ECC Schemes**

The following rules apply throughout the entire mapping description:

- Main data area (sectors) size is hardcoded to 512 bytes.
- Spare area size is programmable.
- All page sections (of main area data bytes, protected spare bytes, unprotected spare bytes, and ECC) are defined as explained in [Section 10.1.5.14.3.2.2.1](#).

Each one of the following sections shows a NAND page mapping example (per-sector spare mappings, pooled spare mapping, per-sector spare mapping, with ECC separated at the end of the page).

In the mapping diagrams, sections that belong to the same BCH codeword have the same color (blue or green); unprotected sections are not covered (orange) by the BCH scheme.

Below each mapping diagram, a write (encoding) and read (decoding: syndrome generation) sequence is given, with the number of the active buffers at each point in time (yellow). In the inactive zones (grey), no computing is taking place but the data counter is still active.

A table on the left summarizes the mode, size0, size1 parameters to program for respectively write and read processing of a page, with the given mapping, where :

- P is the size of spare byte section Protected by the ECC (in nibbles)
- U is the size of spare byte section Unprotected by the ECC (in nibbles)
- E is the size of the ECC itself (in nibbles)
- S is the number of Sectors per page (2 in the current diagrams)

Each time the processing of a BCH block is complete (ECC calculation for write/encoding, syndrome generation for read/decoding, indicated by red arrows), the update pointer is pulsed. Note that the processing for block 0 can be the first or the last to complete, depending on the NAND page mapping and operation (read or write). All examples show a page size of 1kByte + spares; that is, S = 2 sectors of 512 bytes. The same principles can be extended to larger pages by adding more sectors.

The actual BCH codeword size is used during the error location work to restrict the search range: by definition, errors can only happen in the codeword that was actually written to the NAND, and not in the mathematical codeword of  $n = 2^{13} - 1 = 8191$  bits. That codeword (higher-order bits) is all-zero and implicit during computations.

The actual BCH codeword size depends on the mode, programmed sizes, and sector number (all sizes in nibbles):

- Spares mapped and protected per sector (below: see M1-M2-M3-M9-M10):
  - all sectors:  $(512) + P + E$
- Spares pooled and protected by sector 0 (below: see M5-M6):
  - sector 0 codeword:  $(512) + P + E$
  - other sectors:  $(512) + E$
- Unprotected spares (below: see M4-M7-M8-M11-M12):
  - all codewords  $(512) + E$

#### 10.1.5.14.3.2.3.1 Per-Sector Spare Mappings

In the schemes in [Figure 10-33](#), each 512-byte sector of the main area has its own dedicated section of the spare area. The spare area of each sector is composed of :

- ECC, which must be located after the data it protects
- Other data, which may or may not be protected by the sector ECC

**Figure 10-33. NAND Page Mapping and ECC: Per-Sector Schemes**

| <b>M1</b> | Per-sector spares<br>Spares covered by sector ECC per sector ECC mapping       |  <table border="1"> <thead> <tr> <th>Mode</th><th>Size0</th><th>Size1</th></tr> </thead> <tbody> <tr> <td>Write</td><td>P</td><td>E</td></tr> <tr> <td>Read</td><td>P+E</td><td>0</td></tr> </tbody> </table>     | Mode | Size0 | Size1 | Write | P   | E   | Read | P+E | 0 |
|-----------|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-------|-------|-----|-----|------|-----|---|
| Mode      | Size0                                                                          | Size1                                                                                                                                                                                                                                                                                               |      |       |       |       |     |     |      |     |   |
| Write     | P                                                                              | E                                                                                                                                                                                                                                                                                                   |      |       |       |       |     |     |      |     |   |
| Read      | P+E                                                                            | 0                                                                                                                                                                                                                                                                                                   |      |       |       |       |     |     |      |     |   |
| <b>M2</b> | Per-sector spares<br>Spares covered by sector ECC per sector, left-padded ECC  |  <table border="1"> <thead> <tr> <th>Mode</th><th>Size0</th><th>Size1</th></tr> </thead> <tbody> <tr> <td>Write</td><td>P</td><td>1+E</td></tr> <tr> <td>Read</td><td>P</td><td>E</td></tr> </tbody> </table>     | Mode | Size0 | Size1 | Write | P   | 1+E | Read | P   | E |
| Mode      | Size0                                                                          | Size1                                                                                                                                                                                                                                                                                               |      |       |       |       |     |     |      |     |   |
| Write     | P                                                                              | 1+E                                                                                                                                                                                                                                                                                                 |      |       |       |       |     |     |      |     |   |
| Read      | P                                                                              | E                                                                                                                                                                                                                                                                                                   |      |       |       |       |     |     |      |     |   |
| <b>M3</b> | Per-sector spares<br>Spares covered by sector ECC<br>ECC not right-aligned     |  <table border="1"> <thead> <tr> <th>Mode</th><th>Size0</th><th>Size1</th></tr> </thead> <tbody> <tr> <td>Write</td><td>P</td><td>E+U</td></tr> <tr> <td>Read</td><td>P+E</td><td>U</td></tr> </tbody> </table> | Mode | Size0 | Size1 | Write | P   | E+U | Read | P+E | U |
| Mode      | Size0                                                                          | Size1                                                                                                                                                                                                                                                                                               |      |       |       |       |     |     |      |     |   |
| Write     | P                                                                              | E+U                                                                                                                                                                                                                                                                                                 |      |       |       |       |     |     |      |     |   |
| Read      | P+E                                                                            | U                                                                                                                                                                                                                                                                                                   |      |       |       |       |     |     |      |     |   |
| <b>M4</b> | Per-sector spares<br>Spares not covered by ECC<br>ECC right-aligned per sector |  <table border="1"> <thead> <tr> <th>Mode</th><th>Size0</th><th>Size1</th></tr> </thead> <tbody> <tr> <td>Write</td><td>U+E</td><td>0</td></tr> <tr> <td>Read</td><td>U</td><td>E</td></tr> </tbody> </table>   | Mode | Size0 | Size1 | Write | U+E | 0   | Read | U   | E |
| Mode      | Size0                                                                          | Size1                                                                                                                                                                                                                                                                                               |      |       |       |       |     |     |      |     |   |
| Write     | U+E                                                                            | 0                                                                                                                                                                                                                                                                                                   |      |       |       |       |     |     |      |     |   |
| Read      | U                                                                              | E                                                                                                                                                                                                                                                                                                   |      |       |       |       |     |     |      |     |   |

gpmc-033

**10.1.5.14.3.2.3.2 Pooled Spare Mapping**

In the schemes in [Figure 10-34](#), the spare area is pooled for the page.

- The ECC of each sector is aligned at the end of the spare area.
- The non-ECC spare data may or may not be covered by the ECC of sector 0.

**Figure 10-34. NAND Page Mapping and ECC: Pooled Spare Schemes**

| <b>M5</b><br>Pooled spares<br>Spares covered by ECC0<br>All ECC at the end (of page)                                                                                                                                                                                                   |      |       |          |       |       |   |   |          |      |   |   |   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|----------|-------|-------|---|---|----------|------|---|---|---|
| <table border="1" style="margin-bottom: 5px;"> <thead> <tr> <th></th> <th>Mode</th> <th>Size0</th> <th>Size1</th> </tr> </thead> <tbody> <tr> <td>Write</td> <td>7</td> <td>P</td> <td>E</td> </tr> <tr> <td>Read</td> <td>3</td> <td>P</td> <td>E</td> </tr> </tbody> </table>        |      | Mode  | Size0    | Size1 | Write | 7 | P | E        | Read | 3 | P | E |
|                                                                                                                                                                                                                                                                                        | Mode | Size0 | Size1    |       |       |   |   |          |      |   |   |   |
| Write                                                                                                                                                                                                                                                                                  | 7    | P     | E        |       |       |   |   |          |      |   |   |   |
| Read                                                                                                                                                                                                                                                                                   | 3    | P     | E        |       |       |   |   |          |      |   |   |   |
|                                                                                                                                                                                                      |      |       |          |       |       |   |   |          |      |   |   |   |
| <b>M6</b><br>Pooled spares<br>Spares covered by ECC0<br>All ECC at the end, left-padded                                                                                                                                                                                                |      |       |          |       |       |   |   |          |      |   |   |   |
| <table border="1" style="margin-bottom: 5px;"> <thead> <tr> <th></th> <th>Mode</th> <th>Size0</th> <th>Size1</th> </tr> </thead> <tbody> <tr> <td>Write</td> <td>7</td> <td>P</td> <td>1+E</td> </tr> <tr> <td>Read</td> <td>8</td> <td>P</td> <td>E</td> </tr> </tbody> </table>      |      | Mode  | Size0    | Size1 | Write | 7 | P | 1+E      | Read | 8 | P | E |
|                                                                                                                                                                                                                                                                                        | Mode | Size0 | Size1    |       |       |   |   |          |      |   |   |   |
| Write                                                                                                                                                                                                                                                                                  | 7    | P     | 1+E      |       |       |   |   |          |      |   |   |   |
| Read                                                                                                                                                                                                                                                                                   | 8    | P     | E        |       |       |   |   |          |      |   |   |   |
|                                                                                                                                                                                                      |      |       |          |       |       |   |   |          |      |   |   |   |
| <b>M7</b><br>Pooled spares<br>Spares not covered by ECC<br>All ECC at the end                                                                                                                                                                                                          |      |       |          |       |       |   |   |          |      |   |   |   |
| <table border="1" style="margin-bottom: 5px;"> <thead> <tr> <th></th> <th>Mode</th> <th>Size0</th> <th>Size1</th> </tr> </thead> <tbody> <tr> <td>Write</td> <td>6</td> <td>0</td> <td>U/S +E</td> </tr> <tr> <td>Read</td> <td>4</td> <td>U</td> <td>E</td> </tr> </tbody> </table>   |      | Mode  | Size0    | Size1 | Write | 6 | 0 | U/S +E   | Read | 4 | U | E |
|                                                                                                                                                                                                                                                                                        | Mode | Size0 | Size1    |       |       |   |   |          |      |   |   |   |
| Write                                                                                                                                                                                                                                                                                  | 6    | 0     | U/S +E   |       |       |   |   |          |      |   |   |   |
| Read                                                                                                                                                                                                                                                                                   | 4    | U     | E        |       |       |   |   |          |      |   |   |   |
|                                                                                                                                                                                                    |      |       |          |       |       |   |   |          |      |   |   |   |
| <b>M8</b><br>Pooled spares<br>Spares not covered by ECC<br>All ECC at the end, left-padded                                                                                                                                                                                             |      |       |          |       |       |   |   |          |      |   |   |   |
| <table border="1" style="margin-bottom: 5px;"> <thead> <tr> <th></th> <th>Mode</th> <th>Size0</th> <th>Size1</th> </tr> </thead> <tbody> <tr> <td>Write</td> <td>6</td> <td>0</td> <td>U/S +1+E</td> </tr> <tr> <td>Read</td> <td>9</td> <td>U</td> <td>E</td> </tr> </tbody> </table> |      | Mode  | Size0    | Size1 | Write | 6 | 0 | U/S +1+E | Read | 9 | U | E |
|                                                                                                                                                                                                                                                                                        | Mode | Size0 | Size1    |       |       |   |   |          |      |   |   |   |
| Write                                                                                                                                                                                                                                                                                  | 6    | 0     | U/S +1+E |       |       |   |   |          |      |   |   |   |
| Read                                                                                                                                                                                                                                                                                   | 9    | U     | E        |       |       |   |   |          |      |   |   |   |
|                                                                                                                                                                                                    |      |       |          |       |       |   |   |          |      |   |   |   |

gpmc-034

#### 10.1.5.14.3.2.3.3 Per-Sector Spare Mapping, With ECC Separated at the End of the Page

In the schemes in [Figure 10-35](#), each 512-byte sector of the main area is associated with two sections of the spare area.

- ECC section, all aligned at the end of the page
- Other data section, aligned before the ECCs, each of which may or may not be protected by its sectors ECC

Figure 10-35. NAND Page Mapping and ECC: Per-Sector Schemes, With Separate ECC

| <b>M9</b>  | Per-sector spares, separate ECC<br>Spares covered by sector ECC<br>All ECC at the end              |       |       |  <table border="1" data-bbox="187 390 538 570"> <thead> <tr> <th></th><th>Mode</th><th>Size0</th><th>Size1</th></tr> </thead> <tbody> <tr> <td>Write</td><td>6</td><td>P</td><td>E</td></tr> <tr> <td>Read</td><td>5</td><td>P</td><td>E</td></tr> </tbody> </table>          |  |  |  |  |  | Mode | Size0 | Size1 | Write | 6 | P | E     | Read | 5  | P  | E |
|------------|----------------------------------------------------------------------------------------------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|------|-------|-------|-------|---|---|-------|------|----|----|---|
|            | Mode                                                                                               | Size0 | Size1 |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
| Write      | 6                                                                                                  | P     | E     |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
| Read       | 5                                                                                                  | P     | E     |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
|            |                                                                                                    |       |       |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
|            |                                                                                                    |       |       |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
| <b>M10</b> | Per-sector spares, separate ECC<br>Spares covered by sector ECC<br>All ECC at the end, left-padded |       |       |  <table border="1" data-bbox="187 728 538 908"> <thead> <tr> <th></th><th>Mode</th><th>Size0</th><th>Size1</th></tr> </thead> <tbody> <tr> <td>Write</td><td>6</td><td>P</td><td>1+E</td></tr> <tr> <td>Read</td><td>11</td><td>P</td><td>E</td></tr> </tbody> </table>       |  |  |  |  |  | Mode | Size0 | Size1 | Write | 6 | P | 1+E   | Read | 11 | P  | E |
|            | Mode                                                                                               | Size0 | Size1 |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
| Write      | 6                                                                                                  | P     | 1+E   |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
| Read       | 11                                                                                                 | P     | E     |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
|            |                                                                                                    |       |       |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
|            |                                                                                                    |       |       |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
| <b>M11</b> | Per-sector spares, separate ECC<br>Spares not covered by ECC<br>All ECC at the end                 |       |       |  <table border="1" data-bbox="187 1087 538 1246"> <thead> <tr> <th></th><th>Mode</th><th>Size0</th><th>Size1</th></tr> </thead> <tbody> <tr> <td>Write</td><td>6</td><td>0</td><td>U+E</td></tr> <tr> <td>Read</td><td>4</td><td>SU</td><td>E</td></tr> </tbody> </table>    |  |  |  |  |  | Mode | Size0 | Size1 | Write | 6 | 0 | U+E   | Read | 4  | SU | E |
|            | Mode                                                                                               | Size0 | Size1 |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
| Write      | 6                                                                                                  | 0     | U+E   |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
| Read       | 4                                                                                                  | SU    | E     |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
|            |                                                                                                    |       |       |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
|            |                                                                                                    |       |       |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
| <b>M12</b> | Per-sector spares, separate ECC<br>Spares not covered by ECC<br>All ECC at the end, left-padded    |       |       |  <table border="1" data-bbox="187 1404 538 1584"> <thead> <tr> <th></th><th>Mode</th><th>Size0</th><th>Size1</th></tr> </thead> <tbody> <tr> <td>Write</td><td>6</td><td>0</td><td>U+1+E</td></tr> <tr> <td>Read</td><td>9</td><td>SU</td><td>E</td></tr> </tbody> </table> |  |  |  |  |  | Mode | Size0 | Size1 | Write | 6 | 0 | U+1+E | Read | 9  | SU | E |
|            | Mode                                                                                               | Size0 | Size1 |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
| Write      | 6                                                                                                  | 0     | U+1+E |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
| Read       | 9                                                                                                  | SU    | E     |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
|            |                                                                                                    |       |       |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |
|            |                                                                                                    |       |       |                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |      |       |       |       |   |   |       |      |    |    |   |

gpmc\_035

#### 10.1.5.14.4 Prefetch and Write-Posting Engine

NAND device data access cycles are usually much slower than the MCU system frequency; such NAND read or write accesses issued by the processor will impact the overall system performance, especially considering long read or write sequences required for NAND page loading or programming. To minimize this effect on system performance, the GPMC includes a prefetch and write-posting engine, which can be used to read from or write to any chip-select location in a buffered manner.

The prefetch and write-posting engine uses an embedded 64 bytes (32 Word16) FIFO to prefetch data

from the NAND device in read mode (prefetch mode) or to store host data to be programmed into the NAND device in write mode (write-posting mode). The FIFO draining and filling (read and write) can be controlled either by the MCU through interrupt synchronization (an interrupt is triggered whenever a programmable threshold is reached) or the sDMA through DMA request synchronization, with a programmable request byte size in both prefetch or posting mode.

The prefetch and write-posting engine includes a single memory pool. Therefore, only one mode, read or write, can be used at any given time. In other words, the prefetch and write-posting engine is a single-context engine that can be allocated to only one chip-select at a time for a read prefetch or a write-posting process.

The engine does not support atomic command and address phase programming and is limited to linear memory read or write access. In consequence, it is limited to NAND data-stream access. The engine relies on the MCU NAND software driver to control block and page opening with the correct data address pointer initialization, before the engine can read from or write to the NAND memory device.

Once started, the engine data reads and writes sequencing is solely based on FIFO location availability and until the total programmed number of bytes is read or written.

Any host-concurrent accesses to a different chip-select are correctly interleaved with ongoing engine accesses. The engine has the lowest priority access so that host accesses to a different chip-select do not suffer a large latency.

A round-robin arbitration scheme can be enabled to ensure minimum bandwidth to the prefetch and write-posting engine in the case of back-to-back direct memory requests to a different chip-select. If the GPMC.[GPMC\\_PREFETCH\\_CONFIG1\[23\]](#) PFPWENROUNDROBIN bit is enabled, the arbitration grants the prefetch and write posting engine access to the GPMC bus for a number of requests programmed in the GPMC.[GPMC\\_PREFETCH\\_CONFIG1\[19:16\]](#) PFPWWIGHTEDPRIO field.

The prefetch and write-posting engine is dedicated to data-stream access (as opposed to random data access). The engine does not include an address generator, and the request is limited to chip-select target identification. The prefetch/write-posting engine read or write request is routed to the access engine with the chip-select destination ID. After the required arbitration phase, the access engine processes the request as a single access with the data access size equal to the device size specified in the corresponding chip-select configuration.

---

**NOTE:** The destination chip-select configuration must be set to the NAND protocol-compatible configuration for which address lines are not used (the address bus is not changed from its current value). Selecting a different chip-select configuration can produce undefined behavior.

---

#### 10.1.5.14.4.1 General Basic Programming Model

The engine can be configured only if the GPMC.[GPMC\\_PREFETCH\\_CONTROL\[0\]](#) STARTENGINE bit is de-asserted.

The engine must be correctly configured in prefetch or write-posting mode and must be linked to a NAND chip-select before it can be started. The chip-select is linked using the GPMC.[GPMC\\_PREFETCH\\_CONFIG1\[26:24\]](#) ENGINECSSELECTOR field.

In both prefetch and write-posting modes, the engine uses byte or Word16 access requests, respectively, for an 8- or 16-bit-wide NAND device attached to the linked chip-select. The FIFOTHRESHOLD and TRANSFERCOUNT fields must be programmed accordingly as a number of bytes.

When the GPMC.[GPMC\\_PREFETCH\\_CONFIG1\[7\]](#) ENABLEENGINE bit is set, the FIFO entry on the L3 interconnect port side is accessible at any address in the associated chip-select memory region. When the ENABLEENGINE bit is set, any host access to this chip-select is rerouted to the FIFO input. Directly accessing the NAND device linked to this chip-select from the host is still possible through the GPMC.[GPMC\\_NAND\\_COMMAND\\_i](#), GPMC.[GPMC\\_NAND\\_ADDRESS\\_i](#), and GPMC.[GPMC\\_NAND\\_DATA\\_i](#) registers (where i = 0 to 7).

The FIFO entry on the L3 interconnect port can be accessed with byte, Word16, or Word32 access size, according to little-endian format, even though the FIFO input is 32-bit wide.

The FIFO control is made easier through the use of interrupts or DMA requests associated with the FIFOTHRESHOLD bit field. The GPMC.GPMC\_PREFETCH\_STATUS[30:24] FIFOPOINTER field monitors the number of available bytes to be read in prefetch mode or the number of free empty slots which can be written in write-posting mode. The GPMC.GPMC\_PREFETCH\_STATUS[13:0] COUNTVALUE field monitors the number of remaining bytes to be read or written by the engine according to the TRANSFERCOUNT value. The FIFOPOINTER and COUNTVALUE bit fields are always expressed as a number of bytes even if a 16-bit wide NAND device is attached to the linked chip-select.

In prefetch mode, when the FIFOPOINTER equals 0, that is, the FIFO is empty, a host read access receives the byte last read from the FIFO as its response. In case of Word32 or Word16 read accesses, the last byte read from the FIFO is copied the required number of times to fit the requested word size. In write-posting mode, when the FIFOPOINTER equals 0 (that is, the FIFO is full), a host write overwrites the last FIFO byte location). There is no underflow or overflow error reporting in the GPMC.

#### 10.1.5.14.4.2 Prefetch Mode

The prefetch mode is selected when the GPMC.GPMC\_PREFETCH\_CONFIG1[0] ACCESSMODE bit is cleared.

The MCU NAND software driver must issue the block and page opening (READ) command with the correct data address pointer initialization before the engine can be started to read from the NAND memory device. The engine is started by asserting the GPMC.GPMC\_PREFETCH\_CONTROL[0] STARTENGINE bit. The STARTENGINE bit automatically clears when the prefetch process completes.

If required, the ECC calculator engine must be initialized (configured, reset, and enabled) before the prefetch engine is started, so that the ECC is correctly computed on all data read by the prefetch engine.

When the GPMC.GPMC\_PREFETCH\_CONFIG1[3] SYNCHROMODE bit is cleared, the prefetch engine starts requesting data as soon as the STARTENGINE bit is set. If using this configuration, the host must monitor the NAND device-ready pin so that it only sets the STARTENGINE bit when the NAND device is in a ready state, meaning data is valid for prefetching.

When the GPMC.GPMC\_PREFETCH\_CONFIG1[3] SYNCHROMODE bit is set, the prefetch engine starts requesting data when an active to inactive wait signal transition is detected. The transition detector must be cleared before any transition detection; see [Section 10.1.5.14.2.2](#). The GPMC.GPMC\_PREFETCH\_CONFIG1[5:4] WAITPINSELECTOR field selects which gpmc\_wait pin edge detector triggers the prefetch engine in this synchronized mode.

If the STARTENGINE bit is set after the NAND address phase (page opening command), the engine is effectively started only after the actual NAND address phase completion. To prevent GPMC stall during this NAND address phase, set the STARTENGINE bit field before NAND address phase completion when in synchronized mode. The prefetch engine will start when an active to inactive wait signal transition is detected. The STARTENGINE bit is automatically cleared on prefetch process completion.

The prefetch engine issues a read request to ensure that the FIFO is always filled with as much data as acceptable, until the programmed GPMC.GPMC\_PREFETCH\_CONFIG2[13:0] TRANSFERCOUNT field is completed.

**Table 10-15. Prefetch Mode Configuration**

| Bit Field        | Register                     | Value  | Comments                                                                                    |
|------------------|------------------------------|--------|---------------------------------------------------------------------------------------------|
| STARTENGINE      | GPMC_PREFETCH_CONTROL[0]     | 0      | Prefetch engine can be configured only if STARTENGINE is set to 0.                          |
| ENGINECSSELECTOR | GPMC_PREFETCH_CONFIG1[26:24] | 0 to 7 | Selects the chip-select associated with a NAND device where the prefetch engine is active.  |
| ACCESSMODE       | GPMC_PREFETCH_CONFIG1[0]     | 0      | Selects prefetch mode                                                                       |
| FIFOTHRESHOLD    | GPMC_PREFETCH_CONFIG1[14:8]  |        | Selects the maximum number of bytes read or written by the host on DMA or interrupt request |
| TRANSFERCOUNT    | GPMC_PREFETCH_CONFIG2[13:0]  |        | Selects the number of bytes to be read or written by the engine to the selected chip-select |

**Table 10-15. Prefetch Mode Configuration (continued)**

| Bit Field             | Register                     | Value  | Comments                                                     |
|-----------------------|------------------------------|--------|--------------------------------------------------------------|
| SYNCHROMODE           | GPMC_PREFETCH_CONFIG1[3]     | 0/1    | Selects when the engine starts the access to the chip-select |
| WAITPINSELECT         | GPMC_PREFETCH_CONFIG1[17:16] | 0 to 3 | (If SynchroMode = 1) Selects wait pin edge detector          |
| ENABLEOPTIMIZEDACCESS | GPMC_PREFETCH_CONFIG1[27]    | 0/1    | See <a href="#">Section 10.1.5.14.4.6</a> .                  |
| CYCLOOPTIMIZATION     | GPMC_PREFETCH_CONFIG1[30:28] |        |                                                              |
| ENABLEENGINE          | GPMC_PREFETCH_CONFIG1[7]     | 1      | Engine enabled                                               |
| STARTENGINE           | GPMC_PREFETCH_CONTROL[0]     | 1      | Starts the prefetch engine                                   |

**10.1.5.14.4.3 FIFO Control in Prefetch Mode**

The FIFO can be drained directly by the MPU or by an sDMA channel.

In MPU draining mode, the FIFO status can be monitored through the GPMC.GPMC\_PREFETCH\_STATUS[30:24] FIFOPOINTER field or through the GPMC.GPMC\_PREFETCH\_STATUS[16] FIFOTHRESHOLDSTATUS bit. The FIFOPOINTER indicates the current number of available data to be read; FIFOTHRESHOLDSTATUS set to 1 indicates that at least FIFOTHRESHOLD bytes are available from the FIFO.

An interrupt can be triggered by the GPMC if the GPMC.GPMC\_IRQENABLE[0] FIFOEVENTENABLE bit is set. The FIFO interrupt event is logged, and the GPMC.GPMC\_IRQSTATUS[0] FIFOEVENTSTATUS bit is set. To clear the interrupt, the MPU must read all the available bytes, or at least enough bytes to get below the programmed FIFO threshold, and the FIFOEVENTSTATUS bit must be cleared to enable further interrupt events. The FIFOEVENTSTATUS bit must always be reset prior to asserting the FIFOEVENTENABLE bit to clear any out-of-date logged interrupt event. This interrupt generation must be enabled after enabling the STARTENGINE bit.

Prefetch completion can be monitored through the GPMC.GPMC\_PREFETCH\_STATUS[13:0] COUNTVALUE field. COUNTVALUE indicates the number of currently remaining data to be requested according to the TRANSFERCOUNT value. An interrupt can be triggered by the GPMC when the prefetch process is complete (that is, COUNTVALUE equals 0) if the GPMC.GPMC\_IRQENABLE[1] TERMINALCOUNTENABLE bit is set. At prefetch completion, thee TERMINALCOUNT interrupt event is also logged, and the GPMC.GPMC\_IRQSTATUS[1] TERMINALCOUNTSTATUS bit is set. To clear the interrupt, the MPU must clear the TERMINALCOUNTSTATUS bit. The TERMINALCOUNTSTATUS bit must always be cleared prior to asserting the TERMINALCOUNTENABLE bit to clear any out-of-date logged interrupt event.

---

**NOTE:** The COUNTVALUE value is only valid when the prefetch engine is active (started), and an interrupt is triggered only when COUNTVALUE reaches 0 (that is, when the prefetch engine automatically goes from an active to inactive state).

---

The number of bytes to be prefetched (programmed in TRANSFERCOUNT) must be a multiple of the programmed FIFOTHRESHOLD to trigger the correct number of interrupts allowing a deterministic and transparent FIFO control. If this guideline is respected, the number of ISR accesses is always required and the FIFO is always empty after the last interrupt is triggered. In other cases, the TERMINALCOUNT interrupt must be used to read the remaining bytes in the FIFO (the number of remaining bytes being lower than the FIFOTHRESHOLD value).

In DMA draining mode, the GPMC.GPMC\_PREFETCH\_CONFIG1[2] DMAMODE bit must be set so that the GPMC issues a DMA hardware request when at least FIFOTHRESHOLD bytes are ready to be read from the FIFO. The DMA channel owning this DMA request must be programmed so that the number of bytes programmed in FIFOTHRESHOLD is read from the FIFO during the DMA request process. The DMA request is kept active until this number of bytes has effectively been read from the FIFO, and no other DMA request can be issued until the ongoing active request is complete.

In prefetch mode, the TERMINALCOUNT event is also a source of DMA requests if the number of bytes to be prefetched is not a multiple of FIFOThreshold, the remaining bytes in the FIFO can be read by the DMA channel using the last DMA request. This assumes that the number of remaining bytes to be read is known and controlled through the DMA channel programming model.

Any potentially active DMA request is cleared when the prefetch engine goes from inactive to active prefetch (the STARTENGINE bit is set to 1). The associated DMA channel must always be enabled by the MPU after setting the STARTENGINE bit so that the out-of-date active DMA request does not trigger spurious DMA transfers.

#### 10.1.5.14.4.4 Write-Posting Mode

The write-posting mode is selected when the GPMC.GPMC\_PREFETCH\_CONFIG1[0] ACCESSMODE bit is set.

The MCU NAND software driver must issue the correct address pointer initialization command (page program) before the engine can start writing data into the NAND memory device. The engine starts when the GPMC.GPMC\_PREFETCH\_CONTROL[0] STARTENGINE bit is set to 1. The STARTENGINE bit clears automatically when posting completes. When all data have been written to the NAND memory device, the MCU NAND software driver must issue the second cycle program command and monitor the status for programming process completion (adding ECC handling, if required).

If used, the ECC calculator engine must be started (configured, reset, and enabled) before the posting engine is started so that the ECC parities are properly calculated on all data written by the prefetch engine to the associated chip-select.

In write-posting mode, the GPMC.GPMC\_PREFETCH\_CONFIG1[3] SYNCHROMODE bit must be cleared so that posting starts as soon as the STARTENGINE bit is set and the FIFO is not empty.

If the STARTENGINE bit is set after the NAND address phase (page program command), the STARTENGINE setting is effective only after the actual NAND command completion. To prevent GPMC stall during this NAND command phase, set the STARTENGINE bit field before the NAND address completion and ensure that the associated DMA channel is enabled after the NAND address phase.

The posting engine issues a write request when valid data are available from the FIFO and until the programmed GPMC.GPMC\_PREFETCH\_CONFIG2[13:0] TRANSFERCOUNT accesses have been completed.

The STARTENGINE bit clears automatically when posting completes. When all data have been written to the NAND memory device, the MCU NAND software driver must issue the second cycle program command and monitor the status for programming process completion. The closing program command phase must only be issued when the full NAND page has been written into the NAND flash write buffer, including the spare area data and the ECC parities, if used.

**Table 10-16. Write-Posting Mode Configuration**

| Bit Field             | Register                     | Value  | Comments                                                                                         |
|-----------------------|------------------------------|--------|--------------------------------------------------------------------------------------------------|
| STARTENGINE           | GPMC_PREFETCH_CONTROL[0]     | 0      | Write-posting engine can be configured only if STARTENGINE is set to 0.                          |
| ENGINECSSELECTION     | GPMC_PREFETCH_CONFIG1[26:24] | 0 to 7 | Selects the chip-select associated with a NAND device where the prefetch engine is active        |
| ACCESSMODE            | GPMC_PREFETCH_CONFIG1[0]     | 1      | Selects write-posting mode                                                                       |
| FIFOThreshold         | GPMC_PREFETCH_CONFIG1[14:8]  |        | Selects the maximum number of bytes read or written by the host on DMA or interrupt request      |
| TRANSFERCOUNT         | GPMC_PREFETCH_CONFIG2[13:0]  |        | Selects the number of bytes to be read or written by the engine from/to the selected chip-select |
| SYNCHROMODE           | GPMC_PREFETCH_CONFIG1[3]     | 0      | Engine starts the access to chip-select as soon as STARTENGINE is set.                           |
| ENABLEOPTIMIZEDACCESS | GPMC_PREFETCH_CONFIG1[27]    | 0/1    | See <a href="#">Section 10.1.5.14.4.6</a> .                                                      |
| CYCLOPTIMIZATION      | GPMC_PREFETCH_CONFIG1[30:28] |        |                                                                                                  |

**Table 10-16. Write-Posting Mode Configuration (continued)**

| Bit Field    | Register                 | Value | Comments                   |
|--------------|--------------------------|-------|----------------------------|
| ENABLEENGINE | GPMC_PREFETCH_CONFIG1[7] | 1     | Engine enabled             |
| STARTENGINE  | GPMC_PREFETCH_CONTROL[0] | 1     | Starts the prefetch engine |

**10.1.5.14.4.5 FIFO Control in Write-Posting Mode**

The FIFO can be filled directly by the MPU or by an sDMA channel.

In MPU filling mode, the FIFO status can be monitored through the FIFOPOINTER or through the GPMC.GPMC\_PREFETCH\_STATUS[16] FIFOTHRESHOLDSTATUS bit. FIFOPOINTER indicates the current number of available free byte places in the FIFO, and the FIFOTHRESHOLDSTATUS bit, when set, indicates that at least FIFOTHRESHOLD free byte places are available in the FIFO.

An interrupt can be issued by the GPMC if the GPMC.GPMC\_IRQENABLE[0] FIFOEVENTENABLE bit is set. When the interrupt is fired, the GPMC.GPMC\_IRQSTATUS[0] FIFOEVENTSTATUS bit is set. To clear the interrupt, the MPU must write enough bytes to fill the FIFO, or enough bytes to get below the programmed threshold, and the FIFOEVENTSTATUS bit must be cleared to get further interrupt events. The FIFOEVENTSTATUS bit must always be cleared prior to asserting the FIFOEVENTENABLE bit to clear any out-of-date logged interrupt event. This interrupt must be enabled after enabling the STARTENGINE bit.

The posting completion can be monitored through the GPMC.GPMC\_PREFETCH\_STATUS[13:0] COUNTVALUE field. COUNTVALUE indicates the current number of remaining data to be written based on the TRANSFERCOUNT value. An interrupt is issued by the GPMC when the write-posting process completes (that is, COUNTVALUE equal to 0) if the GPMC.GPMC\_IRQENABLE[1] TERMINALCOUNTENABLE bit is set. When the interrupt is fired, the GPMC.GPMC\_IRQSTATUS[1] TERMINALCOUNTSTATUS bit is set. To clear the interrupt, the MPU must clear the TERMINALCOUNTSTATUS bit. The TERMINALCOUNTSTATUS bit must always be cleared prior to asserting the TERMINALCOUNTENABLE bit to clear any out-of-date logged interrupt event.

---

**NOTE:** The COUNTVALUE value is valid only if the write-posting engine is active and started, and an interrupt is issued only when COUNTVALUE reaches 0 (that is, when the posting engine automatically goes from active to inactive).

---

In DMA filling mode, the DMAMode bit field in the GPMC.GPMC\_PREFETCH\_CONFIG1[2] DMAMODE bit must be set so that the GPMC issues a DMA hardware request when at least FIFOTHRESHOLD bytes-free places are available in the FIFO. The DMA channel owning this DMA request must be programmed so that a number of bytes equal to the value programmed in the FIFOTHRESHOLD bit field are written into the FIFO during the DMA access. The DMA request remains active until the associated number of bytes has effectively been written into the FIFO, and no other DMA request can be issued until the ongoing active request has been completed.

Any potentially active DMA request is cleared when the prefetch engine goes from inactive to active prefetch (STARTENGINE set to 1). The associated DMA channel must always be enabled by the MPU after setting the STARTENGINE bit so that an out-of-date active DMA request does not trigger spurious DMA transfers.

In write-posting mode, the DMA or the MPU fill the FIFO with no consideration to the associated byte enables. Any byte stored in the FIFO is written into the memory device.

**10.1.5.14.4.6 Optimizing NAND Access Using the Prefetch and Write-Posting Engine**

Access time to a NAND memory device can be optimized for back-to-back accesses if the associated nCS signal is not deasserted between accesses. The GPMC access engine can track prefetch engine accesses to optimize the access timing parameter programmed for the allocated chip-select, if no

accesses to other chip-selects (that is, interleaved accesses) occur. Similarly, the access engine also eliminates the CYCLE2CYCLEDELAY even if CYCLE2CYCLESAMECSEN is set. This capability is limited to the prefetch and write-posting engine accesses, and MPU accesses to a NAND memory device (through the defined chip-select memory region or through the GPMC.GPMC\_NAND\_DATA\_i location, i = 0 to 7) are never optimized.

The GPMC.GPMC\_PREFETCH\_CONFIG1[27] ENABLEOPTIMIZEDACCESS bit must be set to enable optimized accesses. To optimize access time, the GPMC.GPMC\_PREFETCH\_CONFIG1[30:28] CYCLEOPTIMIZATION field defines the number of GPMC\_FCLK cycles to be suppressed from the RDCYCLETIME, WRCYCLETIME, RDACCESSTIME, WRACCESSTIME, CSOFFTIME, ADVOFFTIME, OEOFETIME, and WEOFETIME timing parameters.

Figure 10-36 highlights that, in the case of back-to-back accesses to the NAND flash through the prefetch engine, CYCLE2CYCLESAMECSEN is forced to 0 when using optimized accesses. The first access uses the regular timing settings for this chip-select. All accesses after this one use settings reduced by x clock cycles, x being defined by the GPMC\_PREFETCH\_CONFIG1[30:28] CYCLEOPTIMIZATION field.

**Figure 10-36. NAND Read Cycle Optimization Timing Description**



gpmc-036

#### 10.1.5.14.4.7 Interleaved Accesses Between Prefetch and Write-Posting Engine and Other Chip-Selects

Any on-going read or write access from the prefetch and write-posting engine is completed before an access to any other chip-select can be initiated. As a default, the arbiter uses a fixed-priority algorithm, and the prefetch and write-posting engine has the lowest priority. The maximum latency added to access starting time in this case equals the RDCYCLETIME or WRCYCLETIME (optimized or not) plus the requested BUSTURNAROUND delay for bus turnaround completion programmed for the chip-select to which the NAND device is connected to.

Alternatively, a round-robin arbitration can be used to prioritize accesses to the external bus. This arbitration scheme is enabled by setting the GPMC.GPMC\_PREFETCH\_CONFIG1[23]

PFPWENROUNDROBIN bit. When a request to another chip-select is received while the prefetch and write-posting engine is active, priority is given to the new request. The request processed thereafter is the prefetch and write-posting engine request, even if another interconnect request is passed in the mean time. The engine keeps control of the bus for an additional number of requests programmed in the GPMC.GPMC\_PREFETCH\_CONFIG1[19:16] PFPWWEIGHTEDPRIO bit field. Control is then passed to the direct interconnect request.

As an example, the round-robin arbitration scheme is selected with PFPWWEIGHTEDPRIO set to 0x2. Considering the prefetch and write-posting engine and the interconnect interface are always requesting access to the external interface, the GPMC grants priority to the direct interconnect access for one request. The GPMC then grants priority to the engine for three requests, and finally back to the direct interconnect access, until the arbiter is reset when one of the two initiators stops initiating requests.

## 10.1.6 GPMC Use Cases and Tips

### 10.1.6.1 How to Set GPMC Timing Parameters for Typical Accesses

#### 10.1.6.1.1 External Memory Attached to the GPMC Module

As discussed in the introduction to this chapter, the GPMC module supports the following external memory types:

- Asynchronous or synchronous, 8-bit or 16-bit-width memory or device
- 16-bit address/data-multiplexed or not multiplexed NOR flash device
- 8- or 16-bit NAND flash device

The following examples show how to calculate GPMC timing parameters by showing a typical parameter setup for the access to be performed.

The example is based on a 512-Mb multiplexed NOR flash memory with the following characteristics:

- Type: NOR flash (address/data-multiplexed mode)
- Size: 512M bits
- Data Bus: 16 bits wide
- Speed: 104-MHz clock frequency
- Read access time: 80 ns

#### 10.1.6.1.2 Typical GPMC Setup

Table 10-17 lists some of the I/Os of the GPMC module.

Table 10-17. GPMC Signals

| Signal Name    | I/O      | Description                                                                          |
|----------------|----------|--------------------------------------------------------------------------------------|
| GPMC_FCLK      | Internal | Functional and interface clock. Acts as the time reference.                          |
| gpmc_clk       | I/O      | External clock provided to the external device for synchronous operations            |
| gpmc_a[11: 1]  | O        | Address                                                                              |
| gpmc_d[15: 0]  | I/O      | Data-multiplexed with addresses A[16:1] on memory side                               |
| gpmc_ncs       | O        | Chip-select                                                                          |
| gpmc_nadv_ale  | O        | Address valid enable                                                                 |
| gpmc_noe_nre   | O        | Output enable (read access only)                                                     |
| gpmc_nwe       | O        | Write enable (write access only)                                                     |
| gpmc_wait[3:0] | I        | Ready signal from memory device. Indicates when valid burst data is ready to be read |

[Figure 10-37](#) shows the typical connection between the GPMC module and an attached NOR flash memory.

**Figure 10-37. GPMC Connection to an External NOR Flash Memory**



gpmc\_037

The following sections demonstrate how to calculate GPMC parameters for three access types:

- Synchronous burst read
- Asynchronous read
- Asynchronous single write

#### 10.1.6.1.2.1 GPMC Configuration for Synchronous Burst Read Access

The clock runs at 104 MHz ( $f = 104$  MHz;  $T = 9,615$  ns).

[Table 10-18](#) shows the timing parameters (on the memory side) that determine the parameters on the GPMC side.

[Table 10-19](#) shows how to calculate timings for the GPMC using the memory parameters.

[Figure 10-38](#) shows the synchronous burst read access.

**Table 10-18. Useful Timing Parameters on the Memory Side**

| AC Read Characteristics on the Memory Side | Description                 | Duration (ns) |
|--------------------------------------------|-----------------------------|---------------|
| tCES                                       | nCS setup time to clock     | 0             |
| tACS                                       | Address setup time to clock | 3             |
| tIACC                                      | Synchronous access time     | 80            |

**Table 10-18. Useful Timing Parameters on the Memory Side (continued)**

| AC Read Characteristics on the Memory Side | Description                                   | Duration (ns) |
|--------------------------------------------|-----------------------------------------------|---------------|
| tBACC                                      | Burst access time valid clock to output delay | 5,2           |
| tCEZ                                       | Chip-select to High-Z                         | 7             |
| tOEZ                                       | Output enable to High-Z                       | 7             |
| tAVC                                       | nADV setup time                               | 6             |
| tAVD                                       | nAVD pulse                                    | 6             |
| tACH                                       | Address hold time from clock                  | 3             |

The following terms, which describe the timing interface between the controller and its attached device, are used to calculate the timing parameters on the GPMC side:

- Read access time (GPMC side): Time required to activate the clock + read access time requested on the memory side + data setup time required for optimal capture of a burst of data
- Data setup time (GPMC side): Ensures a good capture of a burst of data (as opposed to taking a burst of data out). One burst of data is processed in one clock cycle ( $T = 9,615 \text{ ns}$ ). The read access time between two bursts of data is  $tBACC = 5,2 \text{ ns}$ . Therefore, data setup time is a clock period -  $tBACC = 4,415 \text{ ns}$  of data setup.
- Access completion (GPMC side): (Different from page burst access time) Time required between the last burst access and access completion: nCS/nOE hold time (nCS and nOE must be released at the end of an access. These signals are held to allow the access to complete).
- Read cycle time (GPMC side): Read access time + access completion
- Write cycle time for burst access: Not supported for NOR flash memory

**Table 10-19. Calculating GPMC Timing Parameters**

| Parameter Name on GPMC Side | Formula                                                             | Duration (ns)               | Number of Clock Cycles (F = 104 MHz) | GPMC Register Configurations |
|-----------------------------|---------------------------------------------------------------------|-----------------------------|--------------------------------------|------------------------------|
| ClkActivationTime           | min ( tCES, tACS )                                                  | 3                           | 1                                    | CLKACTIVATIONTIME = 0x1      |
| RdAccessTime                | roundmax ( ClkActivationTime + tIACC + DataSetupTime )              | 94,03: (9,615 + 80 + 4,415) | 10 : roundmax (94,03 / 9,615)        | ACCESSTIME = 0x0A            |
| PageBurstAccessTime         | roundmax (tBACC)                                                    | roundmax (5,2)              | 1                                    | PAGEBURSTACCESSTIME = 0x1    |
| RdCycleTime                 | AccessTime + max ( tCEZ, tOEZ )                                     | 101, 03: (94, 03 + 7)       | 11                                   | RDCYCLETIME = 0x0B           |
| CsOnTime                    | tCES                                                                | 0                           | 0                                    | CSONTIME = 0x0               |
| CsReadOffTime               | RdCycleTime                                                         | -                           | 11                                   | CSRDOFFTIME = 0x0B           |
| AdvOnTime                   | tAVC <sup>(1)</sup>                                                 | 0                           | 0                                    | ADVONTIME = 0x0              |
| AdvRdOffTime                | tAVD + tAVC <sup>(2)</sup>                                          | 12                          | 2                                    | ADVRDOFFTIME = 0x02          |
| OeOnTime <sup>(3)</sup>     | (ClkActivationTime + tACH) < OeOnTime < (ClkActivationTime + tIACC) | -                           | 3 for instance.                      | OEONTIME = 0x3               |
| OeOffTime                   | RdCycleTime                                                         | -                           | 11                                   | OEOFETIME = 0x0B             |

<sup>(1)</sup> The external clock provided to the NOR flash is not yet available.

<sup>(2)</sup> AdvRdOffTime - AdvOnTime = tAVD; thus, AdvRdOffTime = tAVD + AdvOnTime = tAVD + tAVC.

<sup>(3)</sup> OeOnTime must guarantee that addresses are available. It must not exceed the availability of the first burst of data.

**Figure 10-38. Synchronous Burst Read Access (Timing Parameters in Clock Cycles)**

#### 10.1.6.1.2.2 GPMC Configuration for Asynchronous Read Access

The clock runs at 104 MHz ( $f = 104$  MHz;  $T = 9,615$  ns).

[Table 10-20](#) shows the timing parameters (on the memory side) that determine the parameters on the GPMC side.

[Table 10-21](#) shows how to calculate timings for the GPMC using the memory parameters.

[Figure 10-39](#) shows the asynchronous read access.

**Table 10-20. AC Characteristics for Asynchronous Read Access**

| AC Read Characteristics on the Memory Side | Description                               | Duration (ns) |
|--------------------------------------------|-------------------------------------------|---------------|
| tCE                                        | Read Access time from nCS low             | 80            |
| tAAVDS                                     | Address setup time to rising edge of nADV | 3             |
| tAVDP                                      | nADV low time                             | 6             |
| tCAS                                       | nCS setup time to nADV                    | 0             |
| tOE                                        | Output enable to output valid             | 6             |
| tOEZ                                       | Output enable to High-Z                   | 7             |

Use the following formula to calculate the RdCycleTime parameter for this typical access:

$$\text{RdCycleTime} = \text{RdAccessTime} + \text{AccessCompletion} = \text{RdAccessTime} + 1 \text{ clock cycle} + \text{tOEZ}$$

- First, on the memory side, the external memory makes the data available to the output bus. This is the memory-side read access time defined in [Table 10-20](#): the number of clock cycles between the address capture (nADV rising edge) and the data valid on the output bus.

The GPMC side requires some hold to allow the data to be captured correctly and the access to be finished.

- To read the data correctly, the GPMC must capture it with enough data setup time; the GPMC module captures the data on the next rising edge. This is access time on the GPMC side.
- There must also be a data hold time for correctly reading the data (checking that there is no nOE/nCS deassertion while reading the data). This data hold time is 1 clock cycle (AccessTime + 1).

- To complete the access, nOE/nCS signals are driven to High-Z. AccessTime + 1 + tOEZ is the read cycle time.
- Addresses can now be relatched and a new read cycle begun.

**Table 10-21. GPMC Timing Parameters for Asynchronous Read Access**

| Parameter Name<br>on GPMC side | Formula                                        | Duration (ns) | Number of<br>Clock Cycles<br>(F = 104 MHz) | GPMC Register<br>Configurations |
|--------------------------------|------------------------------------------------|---------------|--------------------------------------------|---------------------------------|
| ClkActivationTime              | n/a (asynchronous mode)                        |               |                                            |                                 |
| AccessTime                     | round max (tCE)                                | 80            | 9                                          | ACCESSTIME = 0x09               |
| PageBurstAccess<br>Time        | n/a (single access)                            |               |                                            |                                 |
| RdCycleTime                    | AccessTime + 1cycle + tOEZ                     | 96, 615       | 11                                         | RDCYCLETIME = 0x0B              |
| CsOnTime                       | tCAS                                           | 0             | 0                                          | CSONTIME = 0x0                  |
| CsReadOffTime                  | AccessTime + 1 cycle                           | 89, 615       | 10                                         | CSRDOFFTIME = 0x0A              |
| AdvOnTime                      | tAAVDS                                         | 3             | 1                                          | ADVONTIME = 0X1                 |
| AdvRdOffTime                   | tAAVDS + tAVDP                                 | 9             | 1                                          | ADVRDOFFTIME = 0x01             |
| OeOnTime                       | OeOnTime >= AdvRdOffTime<br>(multiplexed mode) | -             | 3 for instance                             | OEONTIME = 0x3                  |
| OeOffTime                      | AccessTime + 1cycle                            | 89, 615       | 10                                         | OEOFDTIME = 0x0A                |

**Figure 10-39. Asynchronous Single Read Access (Timing Parameters in Clock Cycles)**



#### 10.1.6.1.2.3 GPMC Configuration for Asynchronous Single Write Access

The clock runs at 104 MHz: (f = 104 MHz; T = 9, 615 ns).

Table 10-23 shows how to calculate timings for the GPMC using the memory parameters.

Table 10-22 shows the timing parameters (on the memory side) that determine the parameters on the GPMC side.

Figure 10-40 shows the synchronous burst write access.

**Table 10-22. AC Characteristics for Asynchronous Single Write (Memory Side)**

| AC Characteristics on the Memory Side | Description            | Duration (ns) |
|---------------------------------------|------------------------|---------------|
| tWC                                   | Write cycle time       | 60            |
| tAVDP                                 | nADV low time          | 6             |
| tWP                                   | Write pulse width      | 25            |
| tWPH                                  | Write pulse width high | 20            |
| tCS                                   | nCS setup time to nWE  | 3             |
| tCAS                                  | nCS setup time to nADV | 0             |
| tAVSC                                 | nADV setup time        | 3             |

For asynchronous single write access, write cycle time is WrCycleTime = WeOffTime + AccessCompletion = WeOffTime + 1. For the AccessCompletion: 1 cycle is required for data hold time (nCS deassertion).

**Table 10-23. GPMC Timing parameters for Asynchronous Single Write**

| Parameter Name on GPMC side | Formula                      | Duration (ns)                                                                | Number of Clock Cycles (F = 104 MHz) | GPMC Registers Configuration |
|-----------------------------|------------------------------|------------------------------------------------------------------------------|--------------------------------------|------------------------------|
| ClkActivationTime           |                              | n/a (asynchronous mode)                                                      |                                      |                              |
| AccessTime                  |                              | Applicable only to WAITMONITORING (the value is the same as for read access) |                                      |                              |
| PageBurstAccessTime         |                              | n/a (single access)                                                          |                                      |                              |
| WrCycleTime                 | WeOffTime + AccessCompletion | 57, 615                                                                      | 6                                    | WRCYCLETIME = 0x06           |
| CsOnTime                    | tCAS                         | 0                                                                            | 0                                    | CSONTIME = 0x0               |
| CsWrOffTime                 | WeOffTime + 1                | 57, 615                                                                      | 6                                    | CSWROFFTIME = 0x06           |
| AdvOnTime                   | tAVSC                        | 3                                                                            | 1                                    | ADVONTIME = 0x1              |
| AdvWrOffTime                | tAVSC + tAVDP                | 9                                                                            | 1                                    | ADVVROFFTIME = 0x01          |
| WeOnTime                    | tCS                          | 3                                                                            | 1                                    | WEONTIME = 0x1               |
| WeOffTime                   | tCS + tWP + tWPH             | 48                                                                           | 5                                    | WEOFFTIME = 0x05             |

**Figure 10-40. Asynchronous Single Write Access (Timing Parameters in Clock Cycles)**

gpmc-040

### 10.1.6.2 How to Choose a Suitable Memory to Use With the GPMC

This section explains how to select a suitable memory device to interface with the GPMC.

#### 10.1.6.2.1 Supported Memories or Devices

NAND flash and NOR flash architectures are the two flash technologies. The GPMC supports various types of external memory or device, basically any one that supports NAND or NOR protocols:

- 8- and 16-bit width asynchronous or synchronous memory or device (8-bit: non burst device only)
- 16-bit address and data multiplexed NOR flash devices (pSRAM, OneNAND™)
- 8- and 16-bit NAND flash device

**NOTE:** Nonmultiplexed NOR flash devices are supported by the GPMC, but their use is highly limited. Because only ten address pins are available on the GPMC interface, the maximum device size supported is 2KB.

##### 10.1.6.2.1.1 Memory Pin Multiplexing

This section describes the interfacing differences of the supported GPMC memories.

Table 10-24. Supported Memory Interfaces

| Function | 16-Bit Address/Data Muxed pSRAM or NOR Flash <sup>(1)</sup> | OneNAND | 16-bit NAND | 8-bit NAND |
|----------|-------------------------------------------------------------|---------|-------------|------------|
| gpmc_a11 | A27                                                         |         |             |            |
| gpmc_a10 | A26                                                         |         |             |            |
| gpmc_a9  | A25                                                         |         |             |            |
| gpmc_a8  | A24                                                         |         |             |            |
| gpmc_a7  | A23                                                         |         |             |            |
| gpmc_a6  | A22                                                         |         |             |            |
| gpmc_a5  | A21                                                         |         |             |            |
| gpmc_a4  | A20                                                         |         |             |            |
| gpmc_a3  | A19                                                         |         |             |            |
| gpmc_a2  | A18                                                         |         |             |            |
| gpmc_a1  | A17                                                         |         |             |            |
| gpmc_d15 | D15 or A16                                                  |         | IO15        |            |
| gpmc_d14 | D14 or A15                                                  |         | IO14        |            |
| gpmc_d13 | D13 or A14                                                  |         | IO13        |            |
| gpmc_d12 | D12 or A13                                                  |         | IO12        |            |
| gpmc_d11 | D11 or A12                                                  |         | IO11        |            |
| gpmc_d10 | D10 or A11                                                  |         | IO10        |            |
| gpmc_d9  | D9 or A10                                                   |         | IO9         |            |
| gpmc_d8  | D8 or A9                                                    |         | IO8         |            |
| gpmc_d7  | D7 or A8                                                    |         |             | IO7        |
| gpmc_d6  | D6 or A7                                                    |         |             | IO6        |
| gpmc_d5  | D5 or A6                                                    |         |             | IO5        |
| gpmc_d4  | D4 or A5                                                    |         |             | IO4        |
| gpmc_d3  | D3 or A4                                                    |         |             | IO3        |
| gpmc_d2  | D2 or A3                                                    |         |             | IO2        |
| gpmc_d1  | D1 or A2                                                    |         |             | IO1        |
| gpmc_d0  | D0 or A1                                                    |         |             | IO0        |

<sup>(1)</sup> Addresses seen from the device side. When interfacing to the external IC, A1 is connected to the memory A0, A2 to the memory A1, and so on.

**Table 10-24. Supported Memory Interfaces (continued)**

| Function      | 16-Bit Address/Data Muxed<br>pSRAM or NOR Flash <sup>(1)</sup> | OneNAND | 16-bit NAND                | 8-bit NAND |
|---------------|----------------------------------------------------------------|---------|----------------------------|------------|
| gpmc_clk      | CLK                                                            |         |                            |            |
| gpmc_ncs0     | nCS0 (chip select)                                             |         | nCE0 (chip enable)         |            |
| gpmc_ncs1     | nCS1                                                           |         | nCE1                       |            |
| gpmc_ncs2     | nCS2                                                           |         | nCE2                       |            |
| GPMC_ncs3     | nCS3                                                           |         | nCE3                       |            |
| GPMC_ncs4     | nCS4                                                           |         | nCE4                       |            |
| GPMC_ncs5     | nCS5                                                           |         | nCE5                       |            |
| GPMC_ncs6     | nCS6                                                           |         | nCE6                       |            |
| GPMC_ncs7     | nCS7                                                           |         | nCE7                       |            |
| gpmc_nadv_ale | nADV (address valid)                                           |         | ALE (address latch enable) |            |
| gpmc_noe      | nOE (output enable)                                            |         | nRE (read enable)          |            |
| gpmc_nwe      | nWE (write enable)                                             |         | nWE (write enable)         |            |
| gpmc_nbe0_cle | nBE0 (byte enable)                                             |         | CLE (command latch enable) |            |
| gpmc_nbe1     | nBE1                                                           |         |                            |            |
| gpmc_nwp      | nWP (write protect)                                            |         | nWP (write protect)        |            |
| gpmc_wait0    | WAIT0                                                          |         | R/nB0 (ready/busy)         |            |
| gpmc_wait1    | WAIT1                                                          |         | R/nB1                      |            |
| gpmc_wait2    | WAIT2                                                          |         | R/nB2                      |            |
| gpmc_wait3    | WAIT3                                                          |         | R/nB3                      |            |

#### 10.1.6.2.1.2 NAND Interface Protocol

NAND flash architecture, introduced in 1989, is a flash technology. NAND is a page-oriented memory device (that is, read and write accesses are done by pages). NAND achieves density by sharing common areas of the storage transistor, which creates strings of serially connected transistors (in NOR devices, each transistor stands alone). Because of its high density, NAND is best suited to devices requiring high capacity data storage, such as pictures, music, or data files. Because of its nonvolatility, NAND is a good storage solution for many applications where mobility, low power, and speed are key factors. Low pin count and simple interface are other advantages of NAND.

Table 10-25 summarizes the level of the NAND interface signals applied to external devices or memories.

**Table 10-25. NAND Interface Bus Operations Summary**

| Bus operation         | CLE | ALE | nCE              | nWE <sup>(1)</sup> | nRE <sup>(1)</sup> | nWP                |
|-----------------------|-----|-----|------------------|--------------------|--------------------|--------------------|
| Read (cmd input)      | H   | L   | L                | RE                 | H                  | x                  |
| Read (add input)      | L   | H   | L                | RE                 | H                  | x                  |
| Write (cmd input)     | H   | L   | L                | RE                 | H                  | H                  |
| Write (add input)     | L   | H   | L                | RE                 | H                  | H                  |
| Data input            | L   | L   | L                | RE                 | H                  | H                  |
| Data output           | L   | L   | L                | H                  | FE                 | x                  |
| Busy (during read)    | x   | x   | H <sup>(2)</sup> | H <sup>(2)</sup>   | H <sup>(2)</sup>   | x                  |
| Busy (during program) | x   | x   | x                | x                  | x                  | H                  |
| Busy (during erase)   | x   | x   | x                | x                  | x                  | H                  |
| Write protect         | x   | x   | x                | x                  | x                  | L                  |
| Stand-by              | x   | x   | H                | x                  | x                  | H/L <sup>(3)</sup> |

<sup>(1)</sup> RE stands for rising edge, FE stands for falling edge.

<sup>(2)</sup> Can be either nCE high, or WE and nRE high

<sup>(3)</sup> nWP must be biased to CMOS high or CMOS low for standby.

#### **10.1.6.2.1.3 NOR Interface Protocol**

NOR flash architecture, introduced in 1988, is a flash technology. Unlike NAND, which is a sequential access device, NOR is directly addressable (that is, it is designed to be a random access device). NOR is best suited to devices used to store and run code or firmware, usually in small capacities. While NOR has fast read capabilities, it has slow write and erase functions compared to NAND architecture.

[Table 10-26](#) summarizes the level of the NOR interface signals applied to external devices or memories.

**Table 10-26. NOR Interface Bus Operations Summary**

| Bus operation        | CLK     | nADV | nCS | nOE | nWE | WAIT     | DQ[15:0] |
|----------------------|---------|------|-----|-----|-----|----------|----------|
| Read (asynchronous)  | x       | L    | L   | L   | H   | Asserted | Output   |
| Read (synchronous)   | Running | L    | L   | L   | H   | Driven   | Output   |
| Read (burst suspend) | Halted  | x    | L   | H   | H   | Active   | Output   |
| Write                | x       | L    | L   | H   | L   | Asserted | Input    |
| Output disable       | x       | x    | L   | H   | H   | Asserted | High-Z   |
| Standby              | x       | x    | H   | x   | x   | High-Z   | High-Z   |

#### **10.1.6.2.1.4 Other Technologies**

Other supported device types interact with the GPMC through the NOR interface protocol.

OneNAND is a high density and low-power memory device. OneNAND is based on a single- or multilevel-cell NAND core with SRAM and logic, and interfaces as a synchronous NOR flash; it also has synchronous write capability. It reads faster than conventional NAND and writes faster than conventional NOR flash. Therefore, it is appropriate for both mass storage and code storage.

pSRAM is a low-power memory device for mobile applications. pSRAM is based on the DRAM cell with internal refresh and address control features, and interfaces as a synchronous NOR flash; it also has synchronous write capability.

#### **10.1.6.2.1.5 Supported Protocols**

The GPMC supports the following interface protocols when communicating with external memory or external devices:

- Asynchronous read/write access
- Asynchronous read page access (4-8-16 Word16)
- Synchronous read/write access
- Synchronous read burst access without wrap capability (4-8-16 Word16)
- Synchronous read burst access with wrap capability (4-8-16 Word16)

#### **10.1.6.2.2 GPMC Features and Settings**

This section lists the GPMC features and settings:

- Supported device type: up to eight NAND or NOR protocol external memories or devices
- Operating voltage: 1.8 V
- Maximum operating frequency provided externally: up to 100 MHz (single device) with an L3-clock of 100 MHz. Up to 83 MHz (L3-clock divided by two) with an L3-clock of 166 MHz.
- Maximum GPMC addressing capability: 1 GB divided into eight chip-selects
- Maximum supported memory size: 256 MB (must be a power-of-2)
- Minimum supported memory size: 16 MB (must be a power-of-2). Aliasing occurs when addressing smaller memories.
- Data path to external memory or device: 8- and 16-bit wide
- Burst and page access: burst of 4-8-16 Word16
- Supports bus keeping and bus turnaround

## 10.1.7 GPMC Register Manual

### 10.1.7.1 GPMC Instance Summary

Table 10-27 describes the GPMC instance.

**Table 10-27. GPMC Instance Summary**

| Module Name | Base Address | Size  |
|-------------|--------------|-------|
| GPMC        | 0x6E00 0000  | 16 MB |

### 10.1.7.2 GPMC Register Summary

Table 10-28 is a summary of the GPMC registers.

**Table 10-28. GPMC Registers Mapping Summary**

| Register Name                                                  | Type | Register Width (Bits) | Address Offset                  | Physical Address                |
|----------------------------------------------------------------|------|-----------------------|---------------------------------|---------------------------------|
| GPMC_REVISION                                                  | R    | 32                    | 0x0000 0000                     | 0x6E00 0000                     |
| GPMC_SYSCONFIG                                                 | RW   | 32                    | 0x0000 0010                     | 0x6E00 0010                     |
| GPMC_SYSSTATUS                                                 | R    | 32                    | 0x0000 0014                     | 0x6E00 0014                     |
| GPMC_IRQSTATUS                                                 | RW   | 32                    | 0x0000 0018                     | 0x6E00 0018                     |
| GPMC_IRQENABLE                                                 | RW   | 32                    | 0x0000 001C                     | 0x6E00 001C                     |
| GPMC_TIMEOUT_CONTROL                                           | RW   | 32                    | 0x0000 0040                     | 0x6E00 0040                     |
| GPMC_ERR_ADDRESS                                               | RW   | 32                    | 0x0000 0044                     | 0x6E00 0044                     |
| GPMC_ERR_TYPE                                                  | RW   | 32                    | 0x0000 0048                     | 0x6E00 0048                     |
| GPMC_CONFIG                                                    | RW   | 32                    | 0x0000 0050                     | 0x6E00 0050                     |
| GPMC_STATUS                                                    | RW   | 32                    | 0x0000 0054                     | 0x6E00 0054                     |
| GPMC_CONFIG1_i <sup>(1)</sup>                                  | RW   | 32                    | 0x0000 0060 + (0x0000 0030 * i) | 0x6E00 0060 + (0x0000 0030 * i) |
| GPMC_CONFIG2_i <sup>(1)</sup>                                  | RW   | 32                    | 0x0000 0064 + (0x0000 0030 * i) | 0x6E00 0064 + (0x0000 0030 * i) |
| GPMC_CONFIG3_i <sup>(1)</sup>                                  | RW   | 32                    | 0x0000 0068 + (0x0000 0030 * i) | 0x6E00 0068 + (0x0000 0030 * i) |
| GPMC_CONFIG4_i <sup>(1)</sup>                                  | RW   | 32                    | 0x0000 006C + (0x0000 0030 * i) | 0x6E00 006C + (0x0000 0030 * i) |
| GPMC_CONFIG5_i <sup>(1)</sup>                                  | RW   | 32                    | 0x0000 0070 + (0x0000 0030 * i) | 0x6E00 0070 + (0x0000 0030 * i) |
| GPMC_CONFIG6_i <sup>(1)</sup>                                  | RW   | 32                    | 0x0000 0074 + (0x0000 0030 * i) | 0x6E00 0074 + (0x0000 0030 * i) |
| GPMC_CONFIG7_i <sup>(1)</sup>                                  | RW   | 32                    | 0x0000 0078 + (0x0000 0030 * i) | 0x6E00 0078 + (0x0000 0030 * i) |
| GPMC_NAND_COMMAND_i <sup>(1)</sup>                             | W    | 32                    | 0x0000 007C + (0x0000 0030 * i) | 0x6E00 007C + (0x0000 0030 * i) |
| GPMC_NAND_ADDRESS_i <sup>(1)</sup>                             | W    | 32                    | 0x0000 0080 + (0x0000 0030 * i) | 0x6E00 0080 + (0x0000 0030 * i) |
| GPMC_NAND_DATA_i <sup>(1)</sup>                                | RW   | 32                    | 0x0000 0084 + (0x0000 0030 * i) | 0x6E00 0084 + (0x0000 0030 * i) |
| GPMC_PREFETCH_CONFIG1                                          | RW   | 32                    | 0x0000 01E0                     | 0x6E00 01E0                     |
| GPMC_PREFETCH_CONFIG2                                          | RW   | 32                    | 0x0000 01E4                     | 0x6E00 01E4                     |
| GPMC_PREFETCH_CONTROL                                          | RW   | 32                    | 0x0000 01EC                     | 0x6E00 01EC                     |
| GPMC_PREFETCH_STATUS                                           | RW   | 32                    | 0x0000 01F0                     | 0x6E00 01F0                     |
| GPMC_ECC_CONFIG                                                | RW   | 32                    | 0x0000 01F4                     | 0x6E00 01F4                     |
| GPMC_ECC_CONTROL                                               | RW   | 32                    | 0x0000 01F8                     | 0x6E00 01F8                     |
| GPMC_ECC_SIZE_CONFIG                                           | RW   | 32                    | 0x0000 01FC                     | 0x6E00 01FC                     |
| GPMC_ECCj_RESULT <sup>(2)</sup> where k = j - 1 <sup>(3)</sup> | RW   | 32                    | 0x0000 0200 + (0x0000 0004 * k) | 0x6E00 0200 + (0x0000 0004 * k) |
| GPMC_BCH_RESULT0_i <sup>(1)</sup>                              | RW   | 32                    | 0x0000 0240 + (0x0000 0010 * i) | 0x6E00 0240 + (0x0000 0010 * i) |
| GPMC_BCH_RESULT1_i <sup>(1)</sup>                              | RW   | 32                    | 0x0000 0244 + (0x0000 0010 * i) | 0x6E00 0244 + (0x0000 0010 * i) |
| GPMC_BCH_RESULT2_i <sup>(1)</sup>                              | RW   | 32                    | 0x0000 0248 + (0x0000 0010 * i) | 0x6E00 0248 + (0x0000 0010 * i) |
| GPMC_BCH_RESULT3_i <sup>(1)</sup>                              | RW   | 32                    | 0x0000 024C + (0x0000 0010 * i) | 0x6E00 024C + (0x0000 0010 * i) |
| GPMC_BCH_SWDATA                                                | RW   | 32                    | 0x0000 02D0                     | 0x6E00 02D0                     |

<sup>(1)</sup> i = 0 to 7

<sup>(2)</sup> j = 1 to 9

<sup>(3)</sup> k = 0 to 8

### 10.1.7.3 GPMC Register Description

This section provides a description of GPMC registers.

---

**NOTE:** All GPMC registers are aligned to 32-bit address boundaries. All register file accesses, except to [GPMC\\_NAND\\_DATA\\_i](#) register, are little endian. If the [GPMC\\_NAND\\_DATA\\_i](#) register location is accessed, the endianness is access-dependent.

---

**Table 10-29. GPMC\_REVISION**

|                         |                                              |                         |                 |                 |       |
|-------------------------|----------------------------------------------|-------------------------|-----------------|-----------------|-------|
| <b>Address Offset</b>   | 0x0000 0000                                  | <b>Physical Address</b> | 0x6E00 0000     | <b>Instance</b> | GPCMC |
| <b>Description</b>      | This register contains the IP revision code. |                         |                 |                 |       |
| <b>Type</b>             | R                                            |                         |                 |                 |       |
| 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 | RESERVED        | REV   |
|                         |                                              |                         |                 |                 |       |

| Bits | Field Name | Description                                                                                         | Type | Reset              |
|------|------------|-----------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | Reserved   | Reads return 0.                                                                                     | R    | 0x000000           |
| 7:0  | REV        | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision<br>Examples: 0x10 for 1.0, 0x21 for 2.1 | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 10-30. Register Call Summary for Register GPMC\_REVISION**

|                                              |
|----------------------------------------------|
| General-Purpose Memory Controller            |
| • <a href="#">GPMC Register Summary: [0]</a> |

**Table 10-31. GPMC\_SYSCONFIG**

|                         |                                                                    |                         |                 |                 |                                      |
|-------------------------|--------------------------------------------------------------------|-------------------------|-----------------|-----------------|--------------------------------------|
| <b>Address Offset</b>   | 0x0000 0010                                                        | <b>Physical Address</b> | 0x6E00 0010     | <b>Instance</b> | GPCMC                                |
| <b>Description</b>      | This register controls the various parameters of the Interconnect. |                         |                 |                 |                                      |
| <b>Type</b>             | RW                                                                 |                         |                 |                 |                                      |
| 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 | RESERVED        | IDLEMODE RESERVED SOFTRESET AUTOIDLE |
|                         |                                                                    |                         |                 |                 |                                      |

| Bits | Field Name | Description                                                                                                                                                                                                                                            | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:5 | RESERVED   | Write 0s for future compatibility. Reads return 0s.                                                                                                                                                                                                    | RW   | 0x00000000 |
| 4:3  | IDLEMODE   | 0x0: Force-idle. An idle request is acknowledged unconditionally<br>0x1: No-idle. An idle request is never acknowledged<br>0x2: Smart-idle. Acknowledgment to an idle request is given based on the internal activity of the module<br>0x3: Do not use | RW   | 0x0        |
| 2    | RESERVED   | Write 0 for future compatibility. Reads returns 0                                                                                                                                                                                                      | RW   | 0x0        |

General-Purpose Memory Controller

[www.ti.com](http://www.ti.com)

| Bits | Field Name | Description                                                                                                                                                                                                      | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | SOFTRESET  | <p>Software reset.</p> <p>Set this bit to 1 triggers a module reset. This bit is automatically reset by hardware. During reads, it always returns 0.</p> <p>0x0: Normal mode</p> <p>0x1: The module is reset</p> | RW   | 0x0   |
| 0    | AUTOIDLE   | <p>Internal Interface clock gating strategy</p> <p>0x0: Interface clock is free-running</p> <p>0x1: Automatic Interface clock gating strategy is applied, based on the Interconnect activity</p>                 | RW   | 0x0   |

**Table 10-32. Register Call Summary for Register GPMC\_SYSCONFIG**

---

General-Purpose Memory Controller

- Clocking, Reset, and Power Management Scheme: [0] [1] [2]
  - GPMC Register Summary: [3]

**Table 10-33. GPMC\_SYSSTATUS**

|                         |                                                                                                        |                 |      |
|-------------------------|--------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0014                                                                                            |                 |      |
| <b>Physical Address</b> | 0x6E00 0014                                                                                            | <b>Instance</b> | GPMC |
| <b>Description</b>      | This register provides status information about the module, excluding the interrupt status information |                 |      |
| <b>Type</b>             | R                                                                                                      |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          |   |           |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|---|-----------|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RESERVED |   | RESETDONE |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                         | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------|-------------|--------------|
| 31:8        | RESERVED          | Reads returns 0                                                                            | R           | 0x000000     |
| 7:1         | RESERVED          | Reads returns 0 (reserved for Interconnect-socket status information)                      | R           | 0x00         |
| 0           | RESETDONE         | Internal reset monitoring<br>0x0: Internal module reset in ongoing<br>0x1: Reset completed | R           | 0x-          |

**Table 10-34. Register Call Summary for Register GPMC\_SYSSTATUS**

---

General-Purpose Memory Controller

- Clocking, Reset, and Power Management Scheme: [0]
  - GPMC Register Summary: [1]

**Table 10-35. GPMC\_IRQSTATUS**

|                       |                                                                                                                      |                         |             |                 |       |
|-----------------------|----------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-------|
| <b>Address Offset</b> | 0x0000 0018                                                                                                          | <b>Physical Address</b> | 0x6E00 0018 | <b>Instance</b> | GPCMC |
| <b>Description</b>    | This interrupt status register regroups all the status of the module internal events that can generate an interrupt. |                         |             |                 |       |
| <b>Type</b>           | RW                                                                                                                   |                         |             |                 |       |



| Bits  | Field Name                | Description                                                                                                                                                                                                                                                                                             | Type | Reset   |
|-------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED                  | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                     | RW   | 0x00000 |
| 11    | WAIT3EDGEDETECTION STATUS | Status of the Wait3 Edge Detection interrupt<br><br>Read 0x0: A transition on WAIT3 input pin has not been detected<br><br>Write 0x0: WAIT3EDGEDETECTIONSTATUS bit unchanged<br><br>Read 0x1: A transition on WAIT3 input pin has been detected<br><br>Write 0x1: WAIT3EDGEDETECTIONSTATUS bit is reset | RW   | 0x0     |
| 10    | WAIT2EDGEDETECTION STATUS | Status of the Wait2 Edge Detection interrupt<br><br>Read 0x0: A transition on WAIT2 input pin has not been detected<br><br>Write 0x0: WAIT2EDGEDETECTIONSTATUS bit unchanged<br><br>Read 0x1: A transition on WAIT2 input pin has been detected<br><br>Write 0x1: WAIT2EDGEDETECTIONSTATUS bit is reset | RW   | 0x0     |
| 9     | WAIT1EDGEDETECTION STATUS | Status of the Wait1 Edge Detection interrupt<br><br>Read 0x0: A transition on WAIT1 input pin has not been detected<br><br>Write 0x0: WAIT1EDGEDETECTIONSTATUS bit unchanged<br><br>Read 0x1: A transition on WAIT1 input pin has been detected<br><br>Write 0x1: WAIT1EDGEDETECTIONSTATUS bit is reset | RW   | 0x0     |
| 8     | WAIT0EDGEDETECTION STATUS | Status of the Wait0 Edge Detection interrupt<br><br>Read 0x0: A transition on WAIT0 input pin has not been detected<br><br>Write 0x0: WAIT0EDGEDETECTIONSTATUS bit unchanged<br><br>Read 0x1: A transition on WAIT0 input pin has been detected<br><br>Write 0x1: WAIT0EDGEDETECTIONSTATUS bit is reset | RW   | 0x0     |
| 7:2   | RESERVED                  | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                     | RW   | 0x00    |
| 1     | TERMINALCOUNTSTATUS       | Status of the TerminalCountEvent interrupt<br><br>Read 0x0: Indicates that CountValue is greater than 0<br><br>Write 0x0: TERMINALCOUNTSTATUS bit unchanged<br><br>Read 0x1: Indicates that CountValue is equal to 0<br><br>Write 0x1: TERMINALCOUNTSTATUS bit is reset                                 | RW   | 0x0     |

General-Purpose Memory Controller

[www.ti.com](http://www.ti.com)

| Bits | Field Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset |
|------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | FIFOEVENTSTATUS | <p>Status of the FIFOEvent interrupt</p> <p>Read 0x0: Indicates than less than FIFOThreshold bytes are available in prefetch mode and less than FIFOThreshold bytes free places are available in write-posting mode.</p> <p>Write 0x0: FIFOEVENTSTATUS bit unchanged</p> <p>Read 0x1: Indicates than at least FIFOThreshold bytes are available in prefetch mode and at least FIFOThreshold bytes free places are available in write-posting mode.</p> <p>Write 0x1: FIFOEVENTSTATUS bit is reset</p> | RW   | 0x0   |

**Table 10-36. Register Call Summary for Register GPMC\_IRQSTATUS**

## General-Purpose Memory Controller

- NAND Device Basic Programming Model: [0] [1] [2] [3] [4] [5] [6]
  - GPMC Register Summary: [7]

**Table 10-37. GPMC IRQENABLE**

|                         |                                                                                                                          |                 |      |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 001C                                                                                                              |                 |      |
| <b>Physical Address</b> | 0x6E00 001C                                                                                                              | <b>Instance</b> | GPMC |
| <b>Description</b>      | The interrupt enable register allows to mask/unmask the module internal sources of interrupt, on a event-by-event basis. |                 |      |
| <b>Type</b>             | RW                                                                                                                       |                 |      |



| Bits  | Field Name                   | Description                                                                                                                                                         | Type | Reset   |
|-------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED                     | Write 0s for future compatibility. Read returns 0s.                                                                                                                 | RW   | 0x00000 |
| 11    | WAIT3EDGEDETECTION<br>ENABLE | Enables the Wait3 Edge Detection interrupt<br><br>0x0: Wait3EdgeDetection interrupt is masked<br><br>0x1: Wait3EdgeDetection event generates an interrupt if occurs | RW   | 0x0     |
| 10    | WAIT2EDGEDETECTION<br>ENABLE | Enables the Wait2 Edge Detection interrupt<br><br>0x0: Wait2EdgeDetection interrupt is masked<br><br>0x1: Wait2EdgeDetection event generates an interrupt if occurs | RW   | 0x0     |
| 9     | WAIT1EDGEDETECTION<br>ENABLE | Enables the Wait1 Edge Detection interrupt<br><br>0x0: Wait1EdgeDetection interrupt is masked<br><br>0x1: Wait1EdgeDetection event generates an interrupt if occurs | RW   | 0x0     |
| 8     | WAIT0EDGEDETECTION<br>ENABLE | Enables the Wait0 Edge Detection interrupt<br><br>0x0: Wait0EdgeDetection interrupt is masked<br><br>0x1: Wait0EdgeDetection event generates an interrupt if occurs | RW   | 0x0     |
| 7:2   | RESERVED                     | Write 0s for future compatibility. Read returns 0s.                                                                                                                 | RW   | 0x00    |

| Bits | Field Name                   | Description                                                                                                                                                                           | Type | Reset |
|------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | TERMINALCOUNTEVENT<br>ENABLE | Enables TerminalCountEvent interrupt issuing in pre-fetch or write-posting mode<br><br>0x0: TerminalCountEvent interrupt is masked<br>0x1: TerminalCountEvent interrupt is not masked | RW   | 0x0   |
| 0    | FIFOEVENTENABLE              | Enables the FIFOEvent interrupt<br><br>0x0: FIFOEvent interrupt is masked<br>0x1: FIFOEvent interrupt is not masked                                                                   | RW   | 0x0   |

**Table 10-38. Register Call Summary for Register GPMC\_IRQENABLE**

General-Purpose Memory Controller

- [NAND Device Basic Programming Model](#): [0] [1] [2] [3] [4] [5]
- [GPMC Register Summary](#): [6]

**Table 10-39. GPMC\_TIMEOUT\_CONTROL**

|                         |                                                                                                                 |                       |                 |          |                   |  |  |  |  |  |  |  |          |               |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|-------------------|--|--|--|--|--|--|--|----------|---------------|--|--|--|
| Address Offset          | 0x0000 0040                                                                                                     |                       |                 |          |                   |  |  |  |  |  |  |  |          |               |  |  |  |
| Physical Address        | 0x6E00 0040                                                                                                     |                       |                 |          |                   |  |  |  |  |  |  |  | Instance | GPMC          |  |  |  |
| Description             | The <a href="#">GPMC_TIMEOUT_CONTROL</a> register allows the user to set the start value of the timeout counter |                       |                 |          |                   |  |  |  |  |  |  |  |          |               |  |  |  |
| Type                    | RW                                                                                                              |                       |                 |          |                   |  |  |  |  |  |  |  |          |               |  |  |  |
| 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 | RESERVED | TIMEOUTSTARTVALUE |  |  |  |  |  |  |  | RESERVED | TIMEOUTENABLE |  |  |  |

| Bits  | Field Name        | Description                                                                                                                            | Type | Reset   |
|-------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:13 | RESERVED          | Write 0s for future compatibility. Read returns 0s.                                                                                    | RW   | 0x00000 |
| 12:4  | TIMEOUTSTARTVALUE | Start value of the time-out counter<br>0x000: Zero GPMC_FCLK cycle<br>0x001: One GPMC_FCLK cycle<br>...<br>0x1FF: 511 GPMC_FCLK cycles | RW   | 0x1FF   |
| 3:1   | RESERVED          | Write 0s for future compatibility. Read returns 0s.                                                                                    | RW   | 0x0     |
| 0     | TIMEOUTENABLE     | Enable bit of the TimeOut feature<br><br>0x0: TimeOut feature is disabled<br>0x1: TimeOut feature is enabled                           | RW   | 0x0     |

**Table 10-40. Register Call Summary for Register GPMC\_TIMEOUT\_CONTROL**

General-Purpose Memory Controller

- [Error Handling](#): [0] [1]
- [GPMC Register Summary](#): [2]
- [GPMC Register Description](#): [3]

**Table 10-41. GPMC\_ERR\_ADDRESS**

|                         |                                                                                                             |                         |                 |                 |       |
|-------------------------|-------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-------|
| <b>Address Offset</b>   | 0x0000 0044                                                                                                 | <b>Physical Address</b> | 0x6E00 0044     | <b>Instance</b> | GPCMC |
| <b>Description</b>      | The <a href="#">GPMC_ERR_ADDRESS</a> register stores the address of the illegal access when an error occurs |                         |                 |                 |       |
| <b>Type</b>             | RW                                                                                                          |                         |                 |                 |       |
| 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 |                 |       |
| RESERVED                | ILLEGALADD                                                                                                  |                         |                 |                 |       |

| Bits | Field Name | Description                                                                                                | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------|------|------------|
| 31   | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                         | RW   | 0x0        |
| 30:0 | ILLEGALADD | Address of illegal access<br>A30: 0 for memory region, 1 for GPMC register region<br>A29-A0: 1 GBbytes max | R    | 0x00000000 |

**Table 10-42. Register Call Summary for Register GPMC\_ERR\_ADDRESS**

General-Purpose Memory Controller

- [Error Handling: \[0\]](#)
- [GPMC Register Summary: \[1\]](#)
- [GPMC Register Description: \[2\]](#)

**Table 10-43. GPMC\_ERR\_TYPE**

|                         |                                                                                          |                         |                 |                 |                  |
|-------------------------|------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|------------------|
| <b>Address Offset</b>   | 0x0000 0048                                                                              | <b>Physical Address</b> | 0x6E00 0048     | <b>Instance</b> | GPCMC            |
| <b>Description</b>      | The <a href="#">GPMC_ERR_TYPE</a> register stores the type of error when an error occurs |                         |                 |                 |                  |
| <b>Type</b>             | RW                                                                                       |                         |                 |                 |                  |
| 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 |                 |                  |
| RESERVED                | ILLEGALCMD                                                                               |                         |                 |                 |                  |
|                         |                                                                                          |                         |                 | RESERVED        | RESERVED         |
|                         |                                                                                          |                         |                 | ERRORNOTSUPPADD | ERRORNOTSUPPMCMD |
|                         |                                                                                          |                         |                 | ERRORTIMEOUT    | RESERVED         |
|                         |                                                                                          |                         |                 | ERRORVALID      | ERRORVALID       |

| Bits  | Field Name       | Description                                                                                             | Type | Reset    |
|-------|------------------|---------------------------------------------------------------------------------------------------------|------|----------|
| 31:11 | RESERVED         | Write 0s for future compatibility. Read returns 0s.                                                     | RW   | 0x000000 |
| 10:8  | ILLEGALCMD       | System Command of the transaction that caused the error                                                 | R    | 0x0      |
| 7:5   | RESERVED         | Write 0s for future compatibility. Read returns 0s.                                                     | RW   | 0x0      |
| 4     | ERRORNOTSUPPADD  | Not supported Address error<br>0x0: No error occurs<br>0x1: The error is due to a non supported Address | R    | 0x0      |
| 3     | ERRORNOTSUPPMCMD | Not supported Command error<br>0x0: No error occurs<br>0x1: The error is due to a non supported Command | R    | 0x0      |

| Bits | Field Name   | Description                                                                                                                                                                                | Type | Reset |
|------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 2    | ERRORTIMEOUT | Time-out error<br><br>0x0: No error occurs<br><br>0x1: The error is due to a time out                                                                                                      | R    | 0x0   |
| 1    | RESERVED     | Write 0s for future compatibility. Read returns 0.                                                                                                                                         | RW   | 0x0   |
| 0    | ERRORVALID   | Error validity status - Must be explicitly cleared with a write 1 transaction<br><br>0x0: All error fields no longer valid<br><br>0x1: Error detected and logged in the other error fields | RW   | 0x0   |

**Table 10-44. Register Call Summary for Register GPMC\_ERR\_TYPE**

General-Purpose Memory Controller

- [Error Handling: \[0\]](#) [\[1\]](#) [\[2\]](#)
- [GPMC Register Summary: \[3\]](#)
- [GPMC Register Description: \[4\]](#)

**Table 10-45. GPMC\_CONFIG**

| Address Offset | 0x0000 0050                                                        |  | Physical Address | 0x6E00 0050 | Instance | GPMC |
|----------------|--------------------------------------------------------------------|--|------------------|-------------|----------|------|
| Description    | The configuration register allows global configuration of the GPMC |  |                  |             | Type     | RW   |
| Type           |                                                                    |  |                  |             | Type     |      |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------|------------------|------------------|------------------|----------|------------|----------|----------------|----------------------|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WAIT3PINPOLARITY | WAIT2PINPOLARITY | WAIT1PINPOLARITY | WAIT0PINPOLARITY | RESERVED | WRITERTECT | RESERVED | LIMITEDADDRESS | NANDFORCEPOSTEDWRITE |   |   |   |   |   |   |   |

| Bits  | Field Name       | Description                                                                                    | Type | Reset   |
|-------|------------------|------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED         | Write 0s for future compatibility. Read returns 0s.                                            | RW   | 0x00000 |
| 11    | WAIT3PINPOLARITY | Selects the polarity of input pin WAIT3<br><br>0x0: WAIT3 active low<br>0x1: WAIT3 active high | RW   | 0x1     |
| 10    | WAIT2PINPOLARITY | Selects the polarity of input pin WAIT2<br><br>0x0: WAIT2 active low<br>0x1: WAIT2 active high | RW   | 0x0     |
| 9     | WAIT1PINPOLARITY | Selects the polarity of input pin WAIT1<br><br>0x0: WAIT1 active low<br>0x1: WAIT1 active high | RW   | 0x1     |
| 8     | WAIT0PINPOLARITY | Selects the polarity of input pin WAIT0<br><br>0x0: WAIT0 active low<br>0x1: WAIT0 active high | RW   | 0x0     |
| 7:5   | RESERVED         | Write 0s for future compatibility. Read returns 0s.                                            | RW   | 0x0     |

## General-Purpose Memory Controller

www.ti.com

| Bits | Field Name           | Description                                                                                                                                 | Type | Reset |
|------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4    | WRITEPROTECT         | Controls the WP output pin level<br>0x0: WP output pin is low<br>0x1: WP output pin is high                                                 | RW   | 0x0   |
| 3:2  | RESERVED             | Write 0s for future compatibility. Read returns 0s.                                                                                         | RW   | 0x0   |
| 1    | LIMITEDADDRESS       | Limited Address device support<br>0x0: No effect<br>0x1: A26-A11 are not modified during an external memory access.                         | RW   | 0x0   |
| 0    | NANDFORCEPOSTEDWRITE | Enables the Force Posted Write feature to NAND Cmd/Add/Data location<br>0x0: Disables Force Posted Write<br>0x1: Enables Force Posted Write | RW   | 0x0   |

**Table 10-46. Register Call Summary for Register GPMC\_CONFIG**

General-Purpose Memory Controller

- [GPMC Environment: \[0\]](#)
- [GPMC Address and Data Bus: \[1\] \[2\]](#)
- [WAIT Pin Monitoring Control: \[3\]](#)
- [WRITE PROTECT \(nWP\): \[4\]](#)
- [Asynchronous Access Description: \[5\] \[6\]](#)
- [NAND Device Basic Programming Model: \[7\] \[8\]](#)
- [GPMC Register Summary: \[9\]](#)

**Table 10-47. GPMC\_STATUS**

|                       |                                                             |                         |             |                 |       |
|-----------------------|-------------------------------------------------------------|-------------------------|-------------|-----------------|-------|
| <b>Address Offset</b> | 0x0000 0054                                                 | <b>Physical Address</b> | 0x6E00 0054 | <b>Instance</b> | GPCMC |
| <b>Description</b>    | The status register provides global status bits of the GPMC |                         |             |                 |       |
| <b>Type</b>           | RW                                                          |                         |             |                 |       |



| Bits  | Field Name  | Description                                                                                                                                          | Type | Reset   |
|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED    | Write 0s for future compatibility. Read returns 0s.                                                                                                  | RW   | 0x00000 |
| 11    | WAIT3STATUS | Is a copy of input pin WAIT3. (Reset value is WAIT3 input pin sampled at IC reset)<br>0x0: WAIT3 asserted (inactive state)<br>0x1: WAIT3 de-asserted | R    | 0x-     |
| 10    | WAIT2STATUS | Is a copy of input pin WAIT2. (Reset value is WAIT2 input pin sampled at IC reset)<br>0x0: WAIT2 asserted (inactive state)<br>0x1: WAIT2 de-asserted | R    | 0x-     |

| Bits | Field Name             | Description                                                                                                                                              | Type | Reset |
|------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 9    | WAIT1STATUS            | Is a copy of input pin WAIT1. (Reset value is WAIT1 input pin sampled at IC reset)<br><br>0x0: WAIT1 asserted (inactive state)<br>0x1: WAIT1 de-asserted | R    | 0x-   |
| 8    | WAIT0STATUS            | Is a copy of input pin WAIT0. (Reset value is WAIT0 input pin sampled at IC reset)<br><br>0x0: WAIT0 asserted (inactive state)<br>0x1: WAIT0 de-asserted | R    | 0x-   |
| 7:1  | RESERVED               | Write 0s for future compatibility. Reads returns 0                                                                                                       | RW   | 0x00  |
| 0    | EMPTYWRITEBUFFERSTATUS | Stores the empty status of the write buffer<br><br>0x0: Write Buffer is not empty<br>0x1: Write Buffer is empty                                          | R    | 0x1   |

**Table 10-48. Register Call Summary for Register GPMC\_STATUS**

General-Purpose Memory Controller

- [NAND Device Basic Programming Model](#): [0] [1] [2] [3]
- [GPMC Register Summary](#): [4]

**Table 10-49. GPMC\_CONFIG1\_i**

|                  |                                                                             |          |            |
|------------------|-----------------------------------------------------------------------------|----------|------------|
| Address Offset   | 0x0000 0060 + (0x0000 0030 * i)                                             | Index    | i = 0 to 7 |
| Physical Address | 0x6E00 0060 + (0x0000 0030 * i)                                             | Instance | GPMC       |
| Description      | The configuration register 1 sets signal control parameters per chip-select |          |            |
| Type             | RW                                                                          |          |            |

|    |           |    |              |    |           |    |               |    |           |    |                   |    |                          |    |                    |    |                     |    |          |    |          |    |                    |    |          |    |               |    |          |    |          |    |          |    |            |    |            |    |          |    |          |    |          |   |          |   |          |   |          |   |          |   |          |   |          |   |          |   |          |   |          |   |          |
|----|-----------|----|--------------|----|-----------|----|---------------|----|-----------|----|-------------------|----|--------------------------|----|--------------------|----|---------------------|----|----------|----|----------|----|--------------------|----|----------|----|---------------|----|----------|----|----------|----|----------|----|------------|----|------------|----|----------|----|----------|----|----------|---|----------|---|----------|---|----------|---|----------|---|----------|---|----------|---|----------|---|----------|---|----------|---|----------|
| 31 | WRAPBURST | 30 | READMULTIPLE | 29 | READYTYPE | 28 | WRITEMULTIPLE | 27 | WRITETYPE | 26 | CLKACTIVATIONTIME | 25 | ATTACHEDDEVICEPAGELENGTH | 24 | WAITREADMONITORING | 23 | WAITWRITEMONITORING | 22 | RESERVED | 21 | RESERVED | 20 | WAITMONITORINGTIME | 19 | RESERVED | 18 | WAITPINSELECT | 17 | RESERVED | 16 | RESERVED | 15 | RESERVED | 14 | DEVICESIZE | 13 | DEVICETYPE | 12 | RESERVED | 11 | RESERVED | 10 | RESERVED | 9 | RESERVED | 8 | RESERVED | 7 | RESERVED | 6 | RESERVED | 5 | RESERVED | 4 | RESERVED | 3 | RESERVED | 2 | RESERVED | 1 | RESERVED | 0 | RESERVED |
|----|-----------|----|--------------|----|-----------|----|---------------|----|-----------|----|-------------------|----|--------------------------|----|--------------------|----|---------------------|----|----------|----|----------|----|--------------------|----|----------|----|---------------|----|----------|----|----------|----|----------|----|------------|----|------------|----|----------|----|----------|----|----------|---|----------|---|----------|---|----------|---|----------|---|----------|---|----------|---|----------|---|----------|---|----------|---|----------|

| Bits | Field Name   | Description                                                                                                                                                                                                 | Type | Reset |
|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31   | WRAPBURST    | Enables the wrapping burst capability. Must be set if the attached device is configured in wrapping burst<br><br>0x0: Synchronous wrapping burst not supported<br>0x1: Synchronous wrapping burst supported | RW   | 0x0   |
| 30   | READMULTIPLE | Selects the read single or multiple access<br><br>0x0: Single access<br>0x1: Multiple access (burst if synchronous, page if asynchronous)                                                                   | RW   | 0x0   |
| 29   | READYTYPE    | Selects the read mode operation<br><br>0x0: Read Asynchronous<br>0x1: Read Synchronous                                                                                                                      | RW   | 0x0   |

## General-Purpose Memory Controller

www.ti.com

| Bits  | Field Name                | Description                                                                                                                                                                                                                                                                      | Type | Reset |
|-------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 28    | WRITEMULTIPLE             | Selects the write single or multiple access<br>0x0: Single access<br>0x1: Multiple access (burst if synchronous, considered as single if asynchronous)                                                                                                                           | RW   | 0x0   |
| 27    | WRITETYPE                 | Selects the write mode operation<br>0x0: Write Asynchronous<br>0x1: Write Synchronous                                                                                                                                                                                            | RW   | 0x0   |
| 26:25 | CLKACTIVATIONTIME         | Output GPMC_CLK activation time<br>0x0: First rising edge of GPMC_CLK at start access time<br>0x1: First rising edge of GPMC_CLK one GPMC_FCLK cycle after start access time<br>0x2: First rising edge of GPMC_CLK two GPMC_FCLK cycles after start access time<br>0x3: Reserved | RW   | 0x0   |
| 24:23 | ATTACHEDDEVICEPAGE LENGTH | Specifies the attached device page (burst) length<br>0x0: 4 Words<br>0x1: 8 Words<br>0x2: 16 Words<br>0x3: Reserved (1 Word = Interface size)                                                                                                                                    | RW   | 0x0   |
| 22    | WAITREADMONITORING        | Selects the Wait monitoring configuration for Read accesses (Reset value is BOOTWAITEN input pin sampled at IC reset)<br>0x0: Wait pin is not monitored for read accesses<br>0x1: Wait pin is monitored for read accesses                                                        | RW   | 0x-   |
| 21    | WAITWRITEMONITORING       | Selects the Wait monitoring configuration for Write accesses<br>0x0: Wait pin is not monitored for write accesses<br>0x1: Wait pin is monitored for write accesses                                                                                                               | RW   | 0x0   |
| 20    | RESERVED                  | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                               | RW   | 0x0   |
| 19:18 | WAITMONITORINGTIME        | Selects input pin Wait monitoring time<br>0x0: Wait pin is monitored with valid data<br>0x1: Wait pin is monitored one GPMC_CLK cycle before valid data<br>0x2: Wait pin is monitored two GPMC_CLK cycle before valid data<br>0x3: Reserved                                      | RW   | 0x0   |
| 17:16 | WAITPINSELECT             | Selects the input WAIT pin for this chip-select (Reset value is BOOTWAITSELECT input pin sampled at IC reset for CS0 and 0 for CS1-7)<br>0x0: Wait input pin is WAIT0<br>0x1: Wait input pin is WAIT1<br>0x2: Wait input pin is WAIT2<br>0x3: Wait input pin is WAIT3            | RW   | 0x-   |
| 15:14 | RESERVED                  | Write 0s for future compatibility.<br>Reads returns 0                                                                                                                                                                                                                            | RW   | 0x0   |
| 13:12 | DEVICESIZE                | Selects the device size attached (Reset value is BOOTDEVICESIZE input pin sampled at IC reset for CS0 and 0x1 for CS1 to CS7)<br>0x0: 8 bit<br>0x1: 16 bit<br>0x2: Reserved<br>0x3: Reserved                                                                                     | RW   | 0x-   |

| Bits  | Field Name          | Description                                                                                                                                                                                                                                                                                         | Type | Reset |
|-------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 11:10 | DEVICETYPE          | Selects the attached device type<br><br>0x0: NOR Flash like, asynchronous and synchronous devices<br><br>0x1: Reserved<br><br>0x2: NAND Flash like devices, stream mode<br><br>0x3: Reserved                                                                                                        | RW   | 0x0   |
| 9     | MUXADDATA           | Enables the Address and data multiplexed protocol (Reset value is CSOMUXDEVICE input pin sampled at IC reset for CS0 and 0 for CS1-7)<br><br>0x0: Non Multiplexed attached device<br><br>0x1: Address and data multiplexed attached device                                                          | RW   | 0x-   |
| 8:5   | RESERVED            | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                 | RW   | 0x0   |
| 4     | TIMEPARAGRANULARITY | Signals timing latencies scalar factor (Rd/WrCycleTime, Rd/WrAccessTime, PageBurstAccessTime, CSOnTime, CSRd/WrOffTime, ADVOnTime, ADVRd/WrOffTime, OEOnTime, OEOFFTime, WEOnTime, WEOFFTime, Cycle2CycleDelay, BusTurnAround, TimeOutStartValue)<br><br>0x0: x1 latencies<br><br>0x1: x2 latencies | RW   | 0x0   |
| 3:2   | RESERVED            | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                 | RW   | 0x0   |
| 1:0   | GPMCFCLKDIVIDER     | Divides the GPMC_FCLK clock<br><br>0x0: GPMC_CLK frequency = GPMC_FCLK frequency<br>0x1: GPMC_CLK frequency = GPMC_FCLK frequency / 2<br>0x2: GPMC_CLK frequency = GPMC_FCLK frequency / 3<br>0x3: GPMC_CLK frequency = GPMC_FCLK frequency / 4                                                     | RW   | 0x0   |

**Table 10-50. Register Call Summary for Register GPMC\_CONFIG1\_i**

## General-Purpose Memory Controller

- [GPMC Environment: \[0\]](#)
- [Clocking, Reset, and Power Management Scheme: \[1\]](#)
- [GPMC Address and Data Bus: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\]](#)
- [L3 Interconnect Interface: \[13\] \[14\]](#)
- [Access Protocol Configuration: \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\] \[22\] \[23\] \[24\]](#)
- [Timing Setting: \[25\] \[26\] \[27\] \[28\] \[29\] \[30\] \[31\] \[32\]](#)
- [WAIT Pin Monitoring Control: \[33\] \[34\] \[35\] \[36\] \[37\] \[38\] \[39\] \[40\] \[41\] \[42\] \[43\] \[44\] \[45\] \[46\] \[47\] \[48\]](#)
- [Asynchronous Access Description: \[49\] \[50\] \[51\] \[52\] \[53\] \[54\] \[55\] \[56\]](#)
- [Synchronous Access: \[57\] \[58\] \[59\] \[60\] \[61\] \[62\] \[63\]](#)
- [pSRAM Basic Programming Model: \[64\]](#)
- [NAND Device Basic Programming Model: \[65\] \[66\] \[67\] \[68\] \[69\] \[70\] \[71\] \[72\] \[73\] \[74\] \[75\] \[76\] \[77\] \[78\] \[79\] \[80\] \[81\] \[82\] \[83\] \[84\]](#)
- [GPMC Register Summary: \[85\]](#)

**Table 10-51. GPMC\_CONFIG2\_i**

|                         |                                          |                 |            |
|-------------------------|------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0064 + (0x0000 0030 * i)          | <b>Index</b>    | i = 0 to 7 |
| <b>Physical Address</b> | 0x6E00 0064 + (0x0000 0030 * i)          | <b>Instance</b> | GPMC       |
| <b>Description</b>      | CS signal timing parameter configuration |                 |            |
| <b>Type</b>             | RW                                       |                 |            |

## General-Purpose Memory Controller

www.ti.com

| 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 |
|----------|----|----|----|----|----|----|----|-------------|----|----|----|----|----|----|----|----------|----|-------------|----|--------------|----|----------|---|----------|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    | CSWROFFTIME |    |    |    |    |    |    |    | RESERVED |    | CSRDOFFTIME |    | CSEXTRADELAY |    | RESERVED |   | CSONTIME |   |   |   |   |   |   |   |

| Bits  | Field Name   | Description                                                                                                                                                       | Type | Reset |
|-------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED     | Write 0s for future compatibility.<br>Reads returns 0                                                                                                             | RW   | 0x000 |
| 20:16 | CSWROFFTIME  | CS i de-assertion time from start cycle time for write accesses<br>0x00: 0 GPMC_FCLK cycle<br>0x01: 1 GPMC_FCLK cycle<br>...<br>0x1F: 31 GPMC_FCLK cycles         | RW   | 0x10  |
| 15:13 | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                                               | RW   | 0x0   |
| 12:8  | CSRDOFFTIME  | CS i de-assertion time from start cycle time for read accesses<br>0x00: 0 GPMC_FCLK cycle<br>0x01: 1 GPMC_FCLK cycle<br>...<br>0x1F: 31 GPMC_FCLK cycles          | RW   | 0x10  |
| 7     | CSEXTRADELAY | CS i Add Extra Half GPMC_FCLK cycle<br>0x0: CS i Timing control signal is not delayed<br>0x1: CS i Timing control signal is delayed of half GPMC_FCLK clock cycle | RW   | 0x0   |
| 6:4   | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                                               | RW   | 0x0   |
| 3:0   | CSONTIME     | CS i assertion time from start cycle time<br>0x0: 0 GPMC_FCLK cycle<br>0x1: 1 GPMC_FCLK cycle<br>...<br>0xF: 15 GPMC_FCLK cycles                                  | RW   | 0x1   |

**Table 10-52. Register Call Summary for Register GPMC\_CONFIG2\_i**

General-Purpose Memory Controller

- Timing Setting: [0] [1] [2] [3]
- Asynchronous Access Description: [4] [5] [6] [7] [8] [9]
- Synchronous Access: [10] [11] [12] [13] [14] [15]
- GPMC Register Summary: [16]

**Table 10-53. GPMC\_CONFIG3\_i**

|                         |                                            |                 |            |    |    |    |    |              |    |    |    |    |    |    |    |          |    |              |    |               |    |          |   |           |   |   |   |   |   |   |   |
|-------------------------|--------------------------------------------|-----------------|------------|----|----|----|----|--------------|----|----|----|----|----|----|----|----------|----|--------------|----|---------------|----|----------|---|-----------|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 0068 + (0x0000 0030 * i)            | <b>Index</b>    | i = 0 to 7 |    |    |    |    |              |    |    |    |    |    |    |    |          |    |              |    |               |    |          |   |           |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x6E00 0068 + (0x0000 0030 * i)            | <b>Instance</b> | GPMC       |    |    |    |    |              |    |    |    |    |    |    |    |          |    |              |    |               |    |          |   |           |   |   |   |   |   |   |   |
| <b>Description</b>      | nADV signal timing parameter configuration |                 |            |    |    |    |    |              |    |    |    |    |    |    |    |          |    |              |    |               |    |          |   |           |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                         |                 |            |    |    |    |    |              |    |    |    |    |    |    |    |          |    |              |    |               |    |          |   |           |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                            |                 |            |    |    |    |    | ADVWROFFTIME |    |    |    |    |    |    |    | RESERVED |    | ADVRDOFFTIME |    | ADVEXTRADELAY |    | RESERVED |   | ADVONTIME |   |   |   |   |   |   |   |

| Bits  | Field Name    | Description                                                                                                                                                       | Type | Reset |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED      | Write 0s for future compatibility. Read returns 0s.                                                                                                               | RW   | 0x000 |
| 20:16 | ADFWROFFTIME  | nADV de-assertion time from start cycle time for write accesses<br>0x00: 0 GPMC_FCLK cycle<br>0x01: 1 GPMC_FCLK cycle<br>...<br>0x1F: 31 GPMC_FCLK cycles         | RW   | 0x02  |
| 15:13 | RESERVED      | Write 0s for future compatibility. Read returns 0s.                                                                                                               | RW   | 0x0   |
| 12:8  | ADVRDOFFTIME  | nADV de-assertion time from start cycle time for read accesses<br>0x00: 0 GPMC_FCLK cycle<br>0x01: 1 GPMC_FCLK cycle<br>...<br>0x1F: 31 GPMC_FCLK cycles          | RW   | 0x02  |
| 7     | ADVEXTRADELAY | nADV Add Extra Half GPMC_FCLK cycle<br>0x0: nADV Timing control signal is not delayed<br>0x1: nADV Timing control signal is delayed of half GPMC_FCLK clock cycle | RW   | 0x0   |
| 6:4   | RESERVED      | Write 0s for future compatibility. Read returns 0s.                                                                                                               | RW   | 0x0   |
| 3:0   | ADVONTIME     | nADV assertion time from start cycle time<br>0x0: 0 GPMC_FCLK cycle<br>0x1: 1 GPMC_FCLK cycle<br>...<br>0xF: 15 GPMC_FCLK cycles                                  | RW   | 0x1   |

**Table 10-54. Register Call Summary for Register GPMC\_CONFIG3\_i**

General-Purpose Memory Controller

- [Timing Setting: \[0\] \[1\] \[2\] \[3\]](#)
- [Asynchronous Access Description: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [Synchronous Access: \[10\] \[11\] \[12\] \[13\] \[14\] \[15\]](#)
- [GPMC Register Summary: \[16\]](#)

**Table 10-55. GPMC\_CONFIG4\_i**

|                  |           |    |    |    |              |          |    |    |          |                                                    |    |    |          |           |    |    |    |               |          |    |    |          |   |   |   |   |   |   |   |   |   |
|------------------|-----------|----|----|----|--------------|----------|----|----|----------|----------------------------------------------------|----|----|----------|-----------|----|----|----|---------------|----------|----|----|----------|---|---|---|---|---|---|---|---|---|
| Address Offset   |           |    |    |    |              |          |    |    |          | 0x0000 006C + (0x0000 0030 * i) <b>Index</b>       |    |    |          |           |    |    |    | i = 0 to 7    |          |    |    |          |   |   |   |   |   |   |   |   |   |
| Physical Address |           |    |    |    |              |          |    |    |          | 0x6E00 006C + (0x0000 0030 * i) <b>Instance</b>    |    |    |          |           |    |    |    | GPMC          |          |    |    |          |   |   |   |   |   |   |   |   |   |
| Description      |           |    |    |    |              |          |    |    |          | nWE and nOE signals timing parameter configuration |    |    |          |           |    |    |    |               |          |    |    |          |   |   |   |   |   |   |   |   |   |
| Type             |           |    |    |    |              |          |    |    |          | RW                                                 |    |    |          |           |    |    |    |               |          |    |    |          |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED         | WEOFFTIME |    |    |    | WEEXTRADELAY | RESERVED |    |    | WEONTIME |                                                    |    |    | RESERVED | OEOFFTIME |    |    |    | OEEEXTRADELAY | RESERVED |    |    | OEONTIME |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name   | Description                                                                                                                                                    | Type | Reset |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:29 | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                                            | RW   | 0x0   |
| 28:24 | WEOFFTIME    | nWE de-assertion time from start cycle time<br>0x00: 0 GPMC_FCLK cycle<br>0x01: 1 GPMC_FCLK cycle<br>...<br>0x1F: 31 GPMC_FCLK cycles                          | RW   | 0x10  |
| 23    | WEEXTRADELAY | nWE Add Extra Half GPMC_FCLK cycle<br>0x0: nWE Timing control signal is not delayed<br>0x1: nWE Timing control signal is delayed of half GPMC_FCLK clock cycle | RW   | 0x0   |

## General-Purpose Memory Controller

www.ti.com

| Bits  | Field Name   | Description                                                                                                                                                    | Type | Reset |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 22:20 | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                                            | RW   | 0x0   |
| 19:16 | WEONTIME     | nWE assertion time from start cycle time<br>0x0: 0 GPMC_FCLK cycle<br>0x1: 1 GPMC_FCLK cycle<br>...<br>0xF: 15 GPMC_FCLK cycles                                | RW   | 0x3   |
| 15:13 | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                                            | RW   | 0x0   |
| 12:8  | OEOFFTIME    | nOE de-assertion time from start cycle time<br>0x00: 0 GPMC_FCLK cycle<br>0x01: 1 GPMC_FCLK cycle<br>...<br>0x1F: 31 GPMC_FCLK cycles                          | RW   | 0x10  |
| 7     | OEEXTRADELAY | nOE Add Extra Half GPMC_FCLK cycle<br>0x0: nOE Timing control signal is not delayed<br>0x1: nOE Timing control signal is delayed of half GPMC_FCLK clock cycle | RW   | 0x0   |
| 6:4   | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                                            | RW   | 0x0   |
| 3:0   | OEONTIME     | nOE assertion time from start cycle time<br>0x0: 0 GPMC_FCLK cycle<br>0x1: 1 GPMC_FCLK cycle<br>...<br>0xF: 15 GPMC_FCLK cycles                                | RW   | 0x3   |

**Table 10-56. Register Call Summary for Register GPMC\_CONFIG4\_i**

General-Purpose Memory Controller

- [Timing Setting: \[0\]](#) [\[1\]](#) [\[2\]](#) [\[3\]](#) [\[4\]](#) [\[5\]](#)
- [Asynchronous Access Description: \[6\]](#) [\[7\]](#) [\[8\]](#) [\[9\]](#) [\[10\]](#) [\[11\]](#)
- [Synchronous Access: \[12\]](#) [\[13\]](#) [\[14\]](#) [\[15\]](#) [\[16\]](#) [\[17\]](#)
- [NAND Device Basic Programming Model: \[18\]](#)
- [GPMC Register Summary: \[19\]](#)

**Table 10-57. GPMC\_CONFIG5\_i**

|                         |                                                            |                       |                 |
|-------------------------|------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0070 + (0x0000 0030 * i)                            | <b>Index</b>          | i = 0 to 7      |
| <b>Physical Address</b> | 0x6E00 0070 + (0x0000 0030 * i)                            | <b>Instance</b>       | GPMC            |
| <b>Description</b>      | RdAccessTime and CycleTime timing parameters configuration |                       |                 |
| <b>Type</b>             | RW                                                         |                       |                 |
| 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 |
| RESERVED                | PAGEBURSTACCESSTIME                                        | RDACCESSTIME          | WRCYCLETIME     |
|                         |                                                            | RESERVED              | RDACCESSTIME    |

| Bits  | Field Name          | Description                                                                                                                                | Type | Reset |
|-------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED            | Write 0s for future compatibility. Read returns 0s.                                                                                        | RW   | 0x0   |
| 27:24 | PAGEBURSTACCESSTIME | Delay between successive words in a multiple access<br>0x0: 0 GPMC_FCLK cycle<br>0x1: 1 GPMC_FCLK cycle<br>...<br>0xF: 15 GPMC_FCLK cycles | RW   | 0x1   |

| Bits  | Field Name   | Description                                                                                                                                   | Type | Reset |
|-------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 23:21 | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                           | RW   | 0x0   |
| 20:16 | RDACCESSTIME | Delay between start cycle time and first data valid<br>0x00: 0 GPMC_FCLK cycle<br>0x01: 1 GPMC_FCLK cycle<br>...<br>0x1F: 31 GPMC_FCLK cycles | RW   | 0x0F  |
| 15:13 | RESERVED     | Write 0s for future compatibility.<br>Reads returns 0                                                                                         | RW   | 0x0   |
| 12:8  | WRCYCLETIME  | Total write cycle time<br>0x00: 0 GPMC_FCLK cycle<br>0x01: 1 GPMC_FCLK cycle<br>...<br>0x1F: 31 GPMC_FCLK cycles                              | RW   | 0x11  |
| 7:5   | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                           | RW   | 0x0   |
| 4:0   | RDCYCLETIME  | Total read cycle time<br>0x00: 0 GPMC_FCLK cycle<br>0x01: 1 GPMC_FCLK cycle<br>...<br>0x1F: 31 GPMC_FCLK cycles                               | RW   | 0x11  |

**Table 10-58. Register Call Summary for Register GPMC\_CONFIG5\_i**

General-Purpose Memory Controller

- [Timing Setting: \[0\]](#) [\[1\]](#) [\[2\]](#) [\[3\]](#) [\[4\]](#)
- [Asynchronous Access Description: \[5\]](#) [\[6\]](#) [\[7\]](#) [\[8\]](#) [\[9\]](#) [\[10\]](#)
- [Synchronous Access: \[11\]](#) [\[12\]](#) [\[13\]](#) [\[14\]](#) [\[15\]](#) [\[16\]](#)
- [GPMC Register Summary: \[17\]](#)

**Table 10-59. GPMC\_CONFIG6\_i**

| Address Offset   |          | 0x0000 0074 + (0x0000 0030 * i)                                                        | Index    | i = 0 to 7       |          |                  |                     |                     |          |               |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------|----------|----------------------------------------------------------------------------------------|----------|------------------|----------|------------------|---------------------|---------------------|----------|---------------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Physical Address |          | 0x6E00 0074 + (0x0000 0030 * i)                                                        | Instance | GPMC             |          |                  |                     |                     |          |               |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Description      |          | WrAccessTime, WrDataOnADmuxBus, Cycle2Cycle and BusTurnAround parameters configuration |          |                  |          |                  |                     |                     |          |               |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type             |          | RW                                                                                     |          |                  |          |                  |                     |                     |          |               |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED         | RESERVED | WRACCESSTIME                                                                           | RESERVED | WRDATAONADMUXBUS | RESERVED | CYCLE2CYCLEDELAY | CYCLE2CYCLESAMEOSEN | CYCLE2CYCLEDIFFOSEN | RESERVED | BUSTURNAROUND |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name   | Description                                                                                                                                                                                                                                          | Type | Reset |
|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | RESERVED     | TI Internal use - Do not modify.                                                                                                                                                                                                                     | RW   | 0x1   |
| 30:29 | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                  | RW   | 0x0   |
| 28:24 | WRACCESSTIME | Delay from start access time to the GPMC_FCLK rising edge corresponding to the GPMC_CLK rising edge used by the attached memory for the first data capture<br>0x00: 0 GPMC_FCLK cycle<br>0x01: 1 GPMC_FCLK cycle<br>...<br>0x1F: 31 GPMC_FCLK cycles | RW   | 0x0F  |
| 23:20 | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                  | RW   | 0x0   |

## General-Purpose Memory Controller

www.ti.com

| Bits  | Field Name          | Description                                                                                                                                                                                                                     | Type | Reset |
|-------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 19:16 | WRDATAONADMUXBUS    | Specifies on which GPMC_FCLK rising edge the first data is driven in the add/data mux bus                                                                                                                                       | RW   | 0x3   |
| 15:12 | RESERVED            | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                             | RW   | 0x0   |
| 11:8  | CYCLE2CYCLEDELAY    | Chip-select high pulse delay between successive accesses<br>0x0: 0 GPMC_FCLK cycle<br>0x1: 1 GPMC_FCLK cycle<br>...<br>0xF: 15 GPMC_FCLK cycles                                                                                 | RW   | 0x0   |
| 7     | CYCLE2CYCLESAMECSEN | Add CYCLE2CYCLEDELAY between successive accesses to the same CS (any access type)<br>0x0: No delay between the two accesses<br>0x1: Add CYCLE2CYCLEDELAY                                                                        | RW   | 0x0   |
| 6     | CYCLE2CYCLEDIFFCSEN | Add CYCLE2CYCLEDELAY between successive accesses to a different CS (any access type)<br>0x0: No delay between the two accesses<br>0x1: Add CYCLE2CYCLEDELAY                                                                     | RW   | 0x0   |
| 5:4   | RESERVED            | Write 0s for future compatibility.<br>Reads returns 0                                                                                                                                                                           | RW   | 0x0   |
| 3:0   | BUSTURNAROUND       | Bus turn around latency between successive accesses to the same CS (read to write) or to a different CS (read to read and read to write)<br>0x0: 0 GPMC_FCLK cycle<br>0x1: 1 GPMC_FCLK cycle<br>...<br>0xF: 15 GPMC_FCLK cycles | RW   | 0x0   |

**Table 10-60. Register Call Summary for Register GPMC\_CONFIG6\_i**

## General-Purpose Memory Controller

- [Timing Setting: \[0\] \[1\] \[2\] \[3\]](#)
- [WAIT Pin Monitoring Control: \[4\] \[5\] \[6\] \[7\] \[8\]](#)
- [Asynchronous Access Description: \[9\] \[10\] \[11\]](#)
- [Synchronous Access: \[12\] \[13\] \[14\]](#)
- [GPMC Register Summary: \[15\]](#)

**Table 10-61. GPMC\_CONFIG7\_i**

|                         |                                  |                 |                                       |
|-------------------------|----------------------------------|-----------------|---------------------------------------|
| <b>Address Offset</b>   | 0x0000 0078 + (0x0000 0030 * i)  | <b>Index</b>    | i = 0 to 7                            |
| <b>Physical Address</b> | 0x6E00 0078 + (0x0000 0030 * i)  | <b>Instance</b> | GPMC                                  |
| <b>Description</b>      | CS address mapping configuration |                 |                                       |
| <b>Type</b>             | RW                               |                 |                                       |
| 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 |
| RESERVED                |                                  | MASKADDRESS     | RESERVED CSVVALID BASEADDRESS         |

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                            | Type | Reset              |
|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------------|
| 31:12 | RESERVED    | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                    | RW   | 0x00000            |
| 11:8  | MASKADDRESS | CS mask address.<br>0x0000: Chip-select size of 256 Mbytes<br>0x1000: Chip-select size of 128 Mbytes<br>0x1100: Chip-select size of 64 Mbytes<br>0x1110: Chip-select size of 32 Mbytes<br>0x1111: Chip-select size of 16 Mbytes<br>Other values must be avoided as they create holes in the chip-select address space. | RW   | 0xF                |
| 7     | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                     | RW   | 0x0                |
| 6     | CSVALID     | CS enable<br>0x0: CS disabled<br>0x1: CS enabled                                                                                                                                                                                                                                                                       | RW   | See <sup>(1)</sup> |
| 5:0   | BASEADDRESS | CSI base address (16M bytes minimum granularity) bits [5:0] corresponds to A29, A28, A27, A26, A25, and A24. See Figure 10-6                                                                                                                                                                                           | RW   | 0x00               |

<sup>(1)</sup> Reset value is 0x1 for CS0 and 0x0 for CS1 to CS7

**Table 10-62. Register Call Summary for Register GPMC\_CONFIG7\_i**

General-Purpose Memory Controller

- [Chip-Select Base Address and Region Size Configuration: \[0\]](#) [\[1\]](#) [\[2\]](#)
- [NAND Device Basic Programming Model: \[3\]](#)
- [GPMC Register Summary: \[4\]](#)

**Table 10-63. GPMC\_NAND\_COMMAND\_i**

|                         |                                                                 |                 |            |
|-------------------------|-----------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 007C + (0x0000 0030 * i)                                 | <b>Index</b>    | i = 0 to 7 |
| <b>Physical Address</b> | 0x6E00 007C + (0x0000 0030 * i)                                 | <b>Instance</b> | GPMC       |
| <b>Description</b>      | This register is not a true register, just an address location. |                 |            |
| <b>Type</b>             | W                                                               |                 |            |

|                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| GPMC_NAND_COMMAND |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name        | Description                                                     | Type | Reset |
|------|-------------------|-----------------------------------------------------------------|------|-------|
| 31:0 | GPMC_NAND_COMMAND | This register is not a true register, just an address location. | W    | n/a   |

**Table 10-64. Register Call Summary for Register GPMC\_NAND\_COMMAND\_i**

General-Purpose Memory Controller

- [NAND Device Basic Programming Model: \[0\]](#) [\[1\]](#) [\[2\]](#) [\[3\]](#) [\[4\]](#) [\[5\]](#) [\[6\]](#)
- [GPMC Register Summary: \[7\]](#)

**Table 10-65. GPMC\_NAND\_ADDRESS\_i**

|                         |                                                                 |                 |            |
|-------------------------|-----------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0080 + (0x0000 0030 * i)                                 | <b>Index</b>    | i = 0 to 7 |
| <b>Physical Address</b> | 0x6E00 0080 + (0x0000 0030 * i)                                 | <b>Instance</b> | GPMC       |
| <b>Description</b>      | This register is not a true register, just an address location. |                 |            |
| <b>Type</b>             | W                                                               |                 |            |

## General-Purpose Memory Controller

www.ti.com

|                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| GPMC_NAND_ADDRESS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name        | Description                                                     | Type | Reset |
|------|-------------------|-----------------------------------------------------------------|------|-------|
| 31:0 | GPMC_NAND_ADDRESS | This register is not a true register, just an address location. | W    | n/a   |

**Table 10-66. Register Call Summary for Register GPMC\_NAND\_ADDRESS\_i**

General-Purpose Memory Controller

- NAND Device Basic Programming Model: [0] [1] [2] [3] [4] [5] [6]
- GPMC Register Summary: [7]

**Table 10-67. GPMC\_NAND\_DATA\_i**

|                  |                                                                 |          |            |
|------------------|-----------------------------------------------------------------|----------|------------|
| Address Offset   | 0x0000 0084 + (0x0000 0030 * i)                                 | Index    | i = 0 to 7 |
| Physical Address | 0x6E00 0084 + (0x0000 0030 * i)                                 | Instance | GPMC       |
| Description      | This register is not a true register, just an address location. |          |            |
| Type             | RW                                                              |          |            |

|                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| GPMC_NAND_DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name     | Description                                                     | Type | Reset |
|------|----------------|-----------------------------------------------------------------|------|-------|
| 31:0 | GPMC_NAND_DATA | This register is not a true register, just an address location. | W    | n/a   |

**Table 10-68. Register Call Summary for Register GPMC\_NAND\_DATA\_i**

General-Purpose Memory Controller

- NAND Device Basic Programming Model: [0] [1] [2] [3] [4] [5]
- GPMC Register Summary: [6]
- GPMC Register Description: [7] [8]

**Table 10-69. GPMC\_PREFETCH\_CONFIG1**

|                |                                 |                  |             |          |      |
|----------------|---------------------------------|------------------|-------------|----------|------|
| Address Offset | 0x0000 01E0                     | Physical Address | 0x6E00 01E0 | Instance | GPMC |
| Description    | Prefetch engine configuration 1 |                  |             |          |      |
| Type           | RW                              |                  |             |          |      |

|          |                   |                       |                |                  |          |                 |          |               |    |    |    |    |    |    |    |    |    |              |          |                 |             |         |          |               |   |   |   |   |   |   |   |
|----------|-------------------|-----------------------|----------------|------------------|----------|-----------------|----------|---------------|----|----|----|----|----|----|----|----|----|--------------|----------|-----------------|-------------|---------|----------|---------------|---|---|---|---|---|---|---|
| 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 |
| RESERVED | CYCLEOPTIMIZATION | ENABLEOPTIMIZEDACCESS | ENGINESELECTOR | PFPWENROUNDROBIN | RESERVED | FPPWWIGHTEDPRIO | RESERVED | FIFOThreshold |    |    |    |    |    |    |    |    |    | ENABLEENGINE | RESERVED | WATTPINSELECTOR | SYNCHROMODE | DMAMODE | RESERVED | ACCESSIONMODE |   |   |   |   |   |   |   |

| Bits  | Field Name            | Description                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|-------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                          | RW   | 0x0   |
| 30:28 | CYCLEOPTIMIZATION     | Define the number of GPMC_FCLK cycles to be subtracted from RdCycleTime, WrCycleTime, AccessTime, CSRdOffTime, CSWrOffTime, ADVRdOffTime, ADVWrOffTime, OEOffTime, WEOffTime<br>0x0: 0 GPMC_FCLK cycle<br>0x1: 1 GPMC_FCLK cycle<br>...<br>0x7: 7 GPMC_FCLK cycles                                                          | RW   | 0x0   |
| 27    | ENABLEOPTIMIZEDACCESS | Enables access cycle optimization<br>0x0: Access cycle optimization is disabled<br>0x1: Access cycle optimization is enabled                                                                                                                                                                                                | RW   | 0x0   |
| 26:24 | ENGINECSSELECTOR      | Selects the CS where Prefetch Postwrite engine is active<br>0x0 corresponds to CS0<br>0x1: CS1<br>...<br>0x7: CS7                                                                                                                                                                                                           | RW   | 0x0   |
| 23    | PFPWENROUNDROBIN      | Enables the PFPW RoundRobin arbitration<br>0x0: Prefetch Postwrite engine round robin arbitration is disabled<br>0x1: Prefetch Postwrite engine round robin arbitration is enabled                                                                                                                                          | RW   | 0x0   |
| 22:20 | RESERVED              | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                         | RW   | 0x0   |
| 19:16 | PFPWWIGHTEDPRIO       | When an arbitration occurs between a DMA and a PFPW engine access, the DMA is always serviced. If the PFPWEnRoundRobin is enabled,<br>0x0: the next access is granted to the PFPW engine,<br>0x1: the two next accesses are granted to the PFPW engine,<br>...<br>0xF: the 16 next accesses are granted to the PFPW engine. | RW   | 0x0   |
| 15    | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                          | RW   | 0x0   |
| 14:8  | FIFOTHRESHOLD         | Selects the maximum number of bytes read from the FIFO or written to the FIFO by the host on a DMA or interrupt request<br>0x0: 0 byte<br>0x1: 1 byte<br>...<br>0x40: 64 bytes                                                                                                                                              | RW   | 0x40  |
| 7     | ENABLEENGINE          | Enables the Prefetch Postwrite engine<br>0x0: Prefetch Postwrite engine is disabled<br>0x1: Prefetch Postwrite engine is enabled                                                                                                                                                                                            | RW   | 0x0   |
| 6     | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                          | RW   | 0x0   |
| 5:4   | WAITPINSELECTOR       | Select which wait pin edge detector should start the engine in synchronized mode<br>0x0: Selects Wait0EdgeDetection<br>0x1: Selects Wait1EdgeDetection<br>0x2: Selects Wait2EdgeDetection<br>0x3: Selects Wait3EdgeDetection                                                                                                | RW   | 0x0   |
| 3     | SYNCHROMODE           | Selects when the engine starts the access to CS<br>0x0: Engine starts the access to CS as soon as STARTENGINE is set<br>0x1: Engine starts the access to CS as soon as STARTENGINE is set AND wait to non wait edge detection on the selected wait pin                                                                      | RW   | 0x0   |

## General-Purpose Memory Controller

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                              | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 2    | DMAMODE    | Selects interrupt synchronization or DMA request synchronization<br><br>0x0: Interrupt synchronization is enabled. Only interrupt line will be activated on FIFO threshold crossing.<br><br>0x1: DMA request synchronization is enabled. A DMA request protocol is used. | RW   | 0x0   |
| 1    | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                                                       | RW   | 0x0   |
| 0    | ACCESSMODE | Selects pre-fetch read or write-posting accesses<br><br>0x0: Pre-fetch read mode<br><br>0x1: Write-posting mode                                                                                                                                                          | RW   | 0x0   |

**Table 10-70. Register Call Summary for Register GPMC\_PREFETCH\_CONFIG1**

General-Purpose Memory Controller

- NAND Device Basic Programming Model: [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]
- GPMC Register Summary: [32]

**Table 10-71. GPMC\_PREFETCH\_CONFIG2**

|                         |                                 |                 |      |
|-------------------------|---------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 01E4                     | <b>Instance</b> | GPMC |
| <b>Physical Address</b> | 0x6E00 01E4                     |                 |      |
| <b>Description</b>      | Prefetch engine configuration 2 |                 |      |
| <b>Type</b>             | RW                              |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | TRANSFERCOUNT |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name    | Description                                                                                                                                       | Type | Reset   |
|-------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | RESERVED      | Write Os for future compatibility. Read returns 0s.                                                                                               | RW   | 0x00000 |
| 13:0  | TRANSFERCOUNT | Selects the number of bytes to be read or written by the engine to the selected CS<br>0x0000: 0 byte<br>0x0001: 1 byte<br>...<br>0x2000: 8 Kbytes | RW   | 0x0000  |

**Table 10-72. Register Call Summary for Register GPMC\_PREFETCH\_CONFIG2**

General-Purpose Memory Controller

- NAND Device Basic Programming Model: [0] [1] [2] [3]
- GPMC Register Summary: [4]

**Table 10-73. GPMC\_PREFETCH\_CONTROL**

|                         |                         |                 |      |
|-------------------------|-------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 01EC             | <b>Instance</b> | GPMC |
| <b>Physical Address</b> | 0x6E00 01EC             |                 |      |
| <b>Description</b>      | Prefetch engine control |                 |      |
| <b>Type</b>             | RW                      |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

STARTENGINE

| Bits | Field Name  | Description                                                                                                                                                                                                                                                             | Type | Reset      |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED    | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                     | RW   | 0x00000000 |
| 0    | STARTENGINE | Resets the FIFO pointer and starts the engine<br><br>Read 0x0: Engine is stopped<br><br>Write 0x0 stops the engine<br><br>Read 0x1: Engine is running<br><br>Write 0x1 resets the FIFO pointer to 0x0 in prefetch mode and 0x40 in postwrite mode and starts the engine | RW   | 0x0        |

**Table 10-74. Register Call Summary for Register GPMC\_PREFETCH\_CONTROL**

General-Purpose Memory Controller

- NAND Device Basic Programming Model: [0] [1] [2] [3] [4] [5] [6]
- GPMC Register Summary: [7]

**Table 10-75. GPMC\_PREFETCH\_STATUS**

| Address Offset   | 0x0000 01F0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Instance    | GPMC                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-------------|------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Physical Address | 0x6E00 01F0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Description |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |             | Prefetch engine status |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name          | Description                                                                                                                                                                                                                                               | Type | Reset |
|-------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | RESERVED            | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                        | RW   | 0x0   |
| 30:24 | FIFOPOINTER         | Number of available bytes to be read or number of free empty byte places to be written<br><br>0x0: 0 byte available to be read or 0 free empty place to be written<br><br>...<br><br>0x40: 64 bytes available to be read or 64 empty places to be written | R    | 0x00  |
| 23:17 | RESERVED            | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                       | RW   | 0x00  |
| 16    | FIFOTHRESHOLDSTATUS | Set when FIFOPointer exceeds FIFOThreshold value<br><br>0x0: FIFOPointer smaller or equal to FIFOThreshold. Writing to this bit has no effect<br><br>0x1: FIFOPointer greater than FIFOThreshold. Writing to this bit has no effect                       | R    | 0x0   |

General-Purpose Memory Controller

[www.ti.com](http://www.ti.com)

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                      | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 15:14 | RESERVED   | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                              | RW   | 0x0    |
| 13:0  | COUNTVALUE | <p>Number of remaining bytes to be read or to be written by the engine according to the TransferCount value</p> <p>0x0000: 0 byte remaining to be read or to be written</p> <p>0x0001: 1 byte remaining to be read or to be written</p> <p>...</p> <p>0x2000: 8 Kbytes remaining to be read or to be written</p> | R    | 0x0000 |

**Table 10-76. Register Call Summary for Register GPMC\_PREFETCH\_STATUS**

## General-Purpose Memory Controller

- NAND Device Basic Programming Model: [0] [1] [2] [3] [4] [5] [6]
  - GPMC Register Summary: [7]

**Table 10-77. GPMC\_ECC\_CONFIG**

|                         |                   |                 |      |
|-------------------------|-------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 01F4       | <b>Instance</b> | GPMC |
| <b>Physical Address</b> | 0x6E00 01F4       |                 |      |
| <b>Description</b>      | ECC configuration |                 |      |
| <b>Type</b>             | RW                |                 |      |

---

|          |    |    |    |    |    |    |    |              |          |    |    |    |          |    |    |    |             |    |    |    |        |              |   |   |   |       |   |   |   |          |   |  |  |
|----------|----|----|----|----|----|----|----|--------------|----------|----|----|----|----------|----|----|----|-------------|----|----|----|--------|--------------|---|---|---|-------|---|---|---|----------|---|--|--|
| 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 |  |  |
| RESERVED |    |    |    |    |    |    |    | ECCALGORITHM | RESERVED |    |    |    | ECCBCHT8 |    |    |    | ECCWRAPMODE |    |    |    | ECC16B | ECCTOPSECTOR |   |   |   | ECCCS |   |   |   | ECENABLE |   |  |  |

| Bits  | Field Name   | Description                                                                                                                                                              | Type | Reset  |
|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:17 | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                                                      | RW   | 0x0000 |
| 16    | ECCALGORITHM | ECC algorithm used<br>0x0: Hamming code<br>0x1: BCH code                                                                                                                 | RW   | 0x0    |
| 15:13 | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                                                      | RW   | 0x0    |
| 12    | ECCBCHT8     | Error correction capability used for BCH<br>0x0: Up to 4 bits error correction ( $t = 4$ )<br>0x1: Up to 8 bits error correction ( $t = 8$ )                             | RW   | 0x1    |
| 11:8  | ECCWRAPMODE  | Spare area organization definition for the BCH algorithm. See the BCH syndrome/parity calculator module functional specification for more details                        | RW   | 0x0    |
| 7     | ECC16B       | Selects an ECC calculated on 16 columns<br>0x0: ECC calculated on 8 columns<br>0x1: ECC calculated on 16 columns                                                         | RW   | 0x0    |
| 6:4   | ECCTOPSECTOR | Number of sectors to process with the BCH algorithm<br>0x0: 1 sector (512kB page) 0x1: 2 sectors<br>...<br>0x3: 4 sectors (2kB page)<br>...<br>0x7: 8 sectors (4kB page) | RW   | 0x3    |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 3:1         | ECCCS             | Selects the CS where ECC is computed<br><br>0x0: Chip-select 0<br>0x1: Chip-select 1<br>0x2: Chip-select 2<br>0x3: Chip-select 3<br>0x4: Chip-select 4<br>0x5: Chip-select 5<br>0x6: Chip-select 6<br>0x7: Chip-select 7 | RW          | 0x0          |
| 0           | ECCENABLE         | Enables the ECC feature<br><br>0x0: ECC disabled<br>0x1: ECC enabled                                                                                                                                                     | RW          | 0x0          |

**Table 10-78. Register Call Summary for Register GPMC\_ECC\_CONFIG**

General-Purpose Memory Controller

- [Error correction code engine \(ECC\): \[0\] \[1\]](#)
- [NAND Device Basic Programming Model: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [GPMC Register Summary: \[10\]](#)
- [GPMC Register Description: \[11\] \[12\] \[13\]](#)

**Table 10-79. GPMC\_ECC\_CONTROL**

|                         |                         |                         |                 |                 |                     |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|---------------------|
| <b>Address Offset</b>   | 0x0000 01F8             | <b>Physical Address</b> | 0x6E00 01F8     | <b>Instance</b> | GPMC                |
| <b>Description</b>      | ECC control             |                         |                 |                 |                     |
| <b>Type</b>             | RW                      |                         |                 |                 |                     |
| 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 |                 |                     |
|                         | RESERVED                |                         |                 | ECCCLEAR        | RESERVED ECCPOINTER |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:9        | RESERVED          | Write 0s for future compatibility. Read returns 0s.                                                                                 | RW          | 0x000000     |
| 8           | ECCCLEAR          | Clear all ECC result registers<br>Reads returns 0<br>Write 0x1 to this field clear all ECC result registers<br>Write 0x0 is ignored | RW          | 0x0          |
| 7:4         | RESERVED          | Write 0s for future compatibility. Read returns 0s.                                                                                 | RW          | 0x0          |

## General-Purpose Memory Controller

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3:0  | ECCPOINTER | <p>Selects ECC result register (Reads to this field give the dynamic position of the ECC pointer - Writes to this field select the ECC result register where the first ECC computation will be stored); Other enums: writing other values disables the ECC engine (ECCENABLE bit of <a href="#">GPMC_ECC_CONFIG</a> set to 0)</p> <p>0x0: Writing 0x0 disables the ECC engine (ECCENABLE bit of <a href="#">GPMC_ECC_CONFIG</a> set to 0)</p> <p>0x1: ECC result register 1 selected</p> <p>0x2: ECC result register 2 selected</p> <p>0x3: ECC result register 3 selected</p> <p>0x4: ECC result register 4 selected</p> <p>0x5: ECC result register 5 selected</p> <p>0x6: ECC result register 6 selected</p> <p>0x7: ECC result register 7 selected</p> <p>0x8: ECC result register 8 selected</p> <p>0x9: ECC result register 9 selected</p> | RW   | 0x0   |

**Table 10-80. Register Call Summary for Register GPMC\_ECC\_CONTROL**

General-Purpose Memory Controller

- [NAND Device Basic Programming Model](#): [0] [1] [2] [3]
- [GPMC Register Summary](#): [4]

**Table 10-81. GPMC\_ECC\_SIZE\_CONFIG**

| Address Offset | 0x0000 01FC | Physical Address | 0x6E00 01FC | Instance | GPCMC |
|----------------|-------------|------------------|-------------|----------|-------|
| Description    | ECC size    |                  |             |          |       |
| Type           | RW          |                  |             |          |       |



| Bits  | Field Name | Description                                                                                                                                     | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED   | Write 0s for future compatibility. Read returns 0s.                                                                                             | RW   | 0x0   |
| 29:22 | ECCSIZE1   | <p>Defines ECC size 1</p> <p>0x00: 2 Bytes</p> <p>0x01: 4 Bytes</p> <p>0x02: 6 Bytes</p> <p>0x03: 8 Bytes</p> <p>...</p> <p>0xFF: 512 Bytes</p> | RW   | 0xFF  |
| 21:20 | RESERVED   | Write 0s for future compatibility. Read returns 0s.                                                                                             | RW   | 0x0   |
| 19:12 | ECCSIZE0   | <p>Defines ECC size 0</p> <p>0x00: 2 Bytes</p> <p>0x01: 4 Bytes</p> <p>0x02: 6 Bytes</p> <p>0x03: 8 Bytes</p> <p>...</p> <p>0xFF: 512 Bytes</p> | RW   | 0xFF  |
| 11:9  | RESERVED   | Write 0s for future compatibility. Read returns 0s.                                                                                             | RW   | 0x0   |

| Bits | Field Name     | Description                                                                                            | Type | Reset |
|------|----------------|--------------------------------------------------------------------------------------------------------|------|-------|
| 8    | ECC9RESULTSIZE | Selects ECC size for ECC 9 result register<br><br>0x0: ECCSIZE0 selected<br><br>0x1: ECCSIZE1 selected | RW   | 0x0   |
| 7    | ECC8RESULTSIZE | Selects ECC size for ECC 8 result register<br><br>0x0: ECCSIZE0 selected<br><br>0x1: ECCSIZE1 selected | RW   | 0x0   |
| 6    | ECC7RESULTSIZE | Selects ECC size for ECC 7 result register<br><br>0x0: ECCSIZE0 selected<br><br>0x1: ECCSIZE1 selected | RW   | 0x0   |
| 5    | ECC6RESULTSIZE | Selects ECC size for ECC 6 result register<br><br>0x0: ECCSIZE0 selected<br><br>0x1: ECCSIZE1 selected | RW   | 0x0   |
| 4    | ECC5RESULTSIZE | Selects ECC size for ECC 5 result register<br><br>0x0: ECCSIZE0 selected<br><br>0x1: ECCSIZE1 selected | RW   | 0x0   |
| 3    | ECC4RESULTSIZE | Selects ECC size for ECC 4 result register<br><br>0x0: ECCSIZE0 selected<br><br>0x1: ECCSIZE1 selected | RW   | 0x0   |
| 2    | ECC3RESULTSIZE | Selects ECC size for ECC 3 result register<br><br>0x0: ECCSIZE0 selected<br><br>0x1: ECCSIZE1 selected | RW   | 0x0   |
| 1    | ECC2RESULTSIZE | Selects ECC size for ECC 2 result register<br><br>0x0: ECCSIZE0 selected<br><br>0x1: ECCSIZE1 selected | RW   | 0x0   |
| 0    | ECC1RESULTSIZE | Selects ECC size for ECC 1 result register<br><br>0x0: ECCSIZE0 selected<br><br>0x1: ECCSIZE1 selected | RW   | 0x0   |

**Table 10-82. Register Call Summary for Register GPMC\_ECC\_SIZE\_CONFIG**

General-Purpose Memory Controller

- NAND Device Basic Programming Model: [0] [1] [2] [3]
- GPMC Register Summary: [4]

**Table 10-83. GPMC\_ECCj\_RESULT**

|                         |                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|--------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0200 + (0x0000 0004 * k) |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Index</b>    | j= 1 to 9 and k = 0 to 8 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x6E00 0200 + (0x0000 0004 * k) |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | GPMC                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | ECC result register             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |        |        |       |       |       |      |      |      |     |     |     |     |          |        |        |       |       |       |      |      |      |     |     |     |     |   |   |   |   |   |   |
|----------|--------|--------|-------|-------|-------|------|------|------|-----|-----|-----|-----|----------|--------|--------|-------|-------|-------|------|------|------|-----|-----|-----|-----|---|---|---|---|---|---|
| 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 |
| RESERVED | P2048o | P1024o | P512o | P256o | P128o | P64o | P32o | P16o | P8o | P4o | P2o | P1o | RESERVED | P2048e | P1024e | P512e | P256e | P128e | P64e | P32e | P16e | P8e | P4e | P2e | P1e |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                      | Type | Reset |
|-------|------------|------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED   | Write 0s for future compatibility. Read returns 0s.              | RW   | 0x0   |
| 27    | P2048o     | Odd row parity bit 2048, only used for ECC computed on 512 Bytes | R    | 0x0   |
| 26    | P1024o     | Odd row parity bit 1024                                          | R    | 0x0   |

## General-Purpose Memory Controller

www.ti.com

| Bits  | Field Name | Description                                                       | Type | Reset |
|-------|------------|-------------------------------------------------------------------|------|-------|
| 25    | P512o      | Odd row parity bit 512                                            | R    | 0x0   |
| 24    | P256o      | Odd row parity bit 256                                            | R    | 0x0   |
| 23    | P128o      | Odd row parity bit 128                                            | R    | 0x0   |
| 22    | P64o       | Odd row parity bit 64                                             | R    | 0x0   |
| 21    | P32o       | Odd row parity bit 32                                             | R    | 0x0   |
| 20    | P16o       | Odd row parity bit 16                                             | R    | 0x0   |
| 19    | P8o        | Odd row parity bit 8                                              | R    | 0x0   |
| 18    | P4o        | Odd Column Parity bit 4                                           | R    | 0x0   |
| 17    | P2o        | Odd Column Parity bit 2                                           | R    | 0x0   |
| 16    | P1o        | Odd Column Parity bit 1                                           | R    | 0x0   |
| 15:12 | RESERVED   | Write 0s for future compatibility. Read returns 0s.               | RW   | 0x0   |
| 11    | P2048e     | Even row parity bit 2048, only used for ECC computed on 512 Bytes | R    | 0x0   |
| 10    | P1024e     | Even row parity bit 1024                                          | R    | 0x0   |
| 9     | P512e      | Even row parity bit 512                                           | R    | 0x0   |
| 8     | P256e      | Even row parity bit 256                                           | R    | 0x0   |
| 7     | P128e      | Even row parity bit 128                                           | R    | 0x0   |
| 6     | P64e       | Even row parity bit 64                                            | R    | 0x0   |
| 5     | P32e       | Even row parity bit 32                                            | R    | 0x0   |
| 4     | P16e       | Even row parity bit 16                                            | R    | 0x0   |
| 3     | P8e        | Even row parity bit 8                                             | R    | 0x0   |
| 2     | P4e        | Even column parity bit 4                                          | R    | 0x0   |
| 1     | P2e        | Even column parity bit 2                                          | R    | 0x0   |
| 0     | P1e        | Even column parity bit 1                                          | R    | 0x0   |

**Table 10-84. Register Call Summary for Register GPMC\_ECCj\_RESULT**

General-Purpose Memory Controller

- NAND Device Basic Programming Model: [0] [1] [2] [3] [4] [5] [6] [7]
- GPMC Register Summary: [8]

**Table 10-85. GPMC\_BCH\_RESULT0\_i**

|                         |                                 |                       |                 |
|-------------------------|---------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0240 + (0x0000 0010 * i) | <b>Index</b>          | i = 0 to 7      |
| <b>Physical Address</b> | 0x6E00 0240 + (0x0000 0010 * i) | <b>Instance</b>       | GPMC            |
| <b>Description</b>      | BCH ECC result (bits 0 to 31)   |                       |                 |
| <b>Type</b>             | RW                              |                       |                 |
| 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 |
| BCH_RESULT_0            |                                 |                       |                 |

| Bits | Field Name   | Description                   | Type | Reset      |
|------|--------------|-------------------------------|------|------------|
| 31:0 | BCH_RESULT_0 | BCH ECC result (bits 0 to 31) | RW   | 0x00000000 |

**Table 10-86. Register Call Summary for Register GPMC\_BCH\_RESULT0\_i**

General-Purpose Memory Controller

- NAND Device Basic Programming Model: [0]
- GPMC Register Summary: [1]

**Table 10-87. GPMC\_BCH\_RESULT1\_i**

|                         |                                 |                 |            |
|-------------------------|---------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0244 + (0x0000 0010 * i) | <b>Index</b>    | i = 0 to 7 |
| <b>Physical Address</b> | 0x6E00 0244 + (0x0000 0010 * i) | <b>Instance</b> | GPMC       |
| <b>Description</b>      | BCH ECC result (bits 32 to 63)  |                 |            |
| <b>Type</b>             | RW                              |                 |            |

  

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

BCH RESULT 1

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>             | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------|-------------|--------------|
| 31:0        | BCH_RESULT_1      | BCH ECC result (bits 32 to 63) | RW          | 0x00000000   |

**Table 10-88. Register Call Summary for Register GPMC\_BCH\_RESULT1 in**

---

General-Purpose Memory Controller

- NAND Device Basic Programming Model: [0]
  - GPMC Register Summary: [1]

**Table 10-89. GPMC\_BCH\_RESULT2\_i**

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>             | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------|-------------|--------------|
| 31:0        | BCH_RESULT_2      | BCH ECC result (bits 64 to 95) | RW          | 0x00000000   |

**Table 10-90. Register Call Summary for Register GPMC\_BCH\_RESULT2\_i**

---

General-Purpose Memory Controller

- NAND Device Basic Programming Model: [0]
  - GPMC Register Summary: [1]

**Table 10-91. GPMC\_BCH\_RESULT3\_i**

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------|-------------|--------------|
| 31:8        | RESERVED          | Write 0s for future compatibility. Read returns 0s. | R           | 0x000000     |
| 7:0         | BCH_RESULT_3      | BCH ECC result (bits 96 to 103)                     | RW          | 0x00         |

**Table 10-92. Register Call Summary for Register GPMC\_BCH\_RESULT3\_i**

General-Purpose Memory Controller

- NAND Device Basic Programming Model: [0]
- GPMC Register Summary: [1]

**Table 10-93. GPMC\_BCH\_SWDATA**

|                         |                                                                                                                          |                 |      |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 02D0                                                                                                              | <b>Instance</b> | GPMC |
| <b>Physical Address</b> | 0x6E00 02D0                                                                                                              |                 |      |
| <b>Description</b>      | This register is used to directly pass data to the BCH ECC calculator without accessing the actual NAND flash interface. |                 |      |
| <b>Type</b>             | RW                                                                                                                       |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                               | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Write 0s for future compatibility. Read returns 0s.                                                                                                                       | R    | 0x0000 |
| 15:0  | BCH_DATA   | Data to be included in the BCH calculation.<br>Only bits 0 to 7 are taken into account if the calculator is configured to use 8 bits data (GPMC_ECC_CONFIG[7] ECC16B = 0) | RW   | 0x0000 |

**Table 10-94. Register Call Summary for Register GPMC\_BCH\_SWDATA**

General-Purpose Memory Controller

- GPMC Register Summary: [0]

## 10.2 SDRAM Controller (SDRC) Subsystem

This section describes the SDRAM controller (SDRC) subsystem.

### 10.2.1 SDRC Subsystem Overview

The SDRC subsystem module provides connectivity between the device POP-ed SDRAM memory components. The module includes support for low-power double-data-rate SDRAM (LPDDR1).

The SDRC subsystem provides a high-performance interface to a variety of fast memory devices. It comprises two submodules:

- The SDRAM memory scheduler (SMS), consisting of scheduler and virtual rotated frame-buffer (VRFB) modules
- The SDRC

#### CAUTION

DDR SDRAM and SDR SDRAM memory types cannot be connected simultaneously to the SDRC memory interface.

Figure 10-41 shows the SDRC subsystem environment.

**Figure 10-41. SDRC Subsystem Environment**

sdrc-001

### 10.2.1.1 Features

The main features of the SDRC subsystem module are:

- VRFB module
  - Minimizes SDRAM page-miss penalty when accessing graphics buffer in nonnatural raster-scan order
  - Supports rotations of 0, 90, 180, and 270 degrees
  - Transparent to software applications
  - 12 concurrent rotation contexts
- Memory-access scheduler
  - Optimizes latency and bandwidth usage between initiators
  - Per-system initiator group quality-of-service (QoS) control
  - 8 \* 8 \* 64 request queue FIFO for optimal scheduling
  - Programmable arbitration scheme
  - Focus on real-time memory processes (DSS display, camera interface)

- Focus on MPU/DSP memory latency
- Fair arbitration between other system initiators (DMAs, video subsystem, GFX accelerator)
- Exclusive read-write transaction support
- SDRAM Controller
  - Support for two independent CSs, with their corresponding register sets, and independent page tracking
  - Supports the following memory types:
    - Mobile Single Data Rate SDRAM (M-SDR)
    - Low-Power Double Data Rate SDRAM (LPDDR)
  - Memory device capacity:
    - 16 Mbits, 32 Mbits, 64 Mbits, 128 Mbits, 256 Mbits, 512 Mbits, 1 Gbit, 2 Gbits, and 4 Gbits device support
  - Memory device organization
    - 2-bank support for 16 Mbits and 32 Mbits
    - 4-bank support for 64 Mbits to 4 Gbits
    - Flexible row/column address multiplexing schemes
    - Bank linear addressing
    - 16- or 32-bit data path to external SDRAM memory
    - 1GB maximum addressing capability
    - Device driver strength feature for mobile DDR supported
    - New flexible address-muxing scheme lets users choose different bank mapping allocations by configuring the bank and column address decoding ordering.
  - Fully pipelined operation for optimal memory bandwidth usage
  - Burst support
    - Memory burst support
      - System burst for SDR SDRAM: system burst translated into memory burst of 2
      - System burst for mobile DDR SDRAM: system burst translated into memory burst size of 4
      - Read interrupt by read, write interrupt by write
  - CAS latency support 1, 2, 3, 4, 5
  - Fully programmable ac timing parameters (on a per-parameter basis). Parameters are set according to the memory interface clock frequency with respect to the attached memory device timing specifications.
  - Fine tuning of the controlled delay elements when operating with DDR memory
  - Dynamic endianness support
  - 9 \* 64 bit lookahead FIFO in the SDRAM controller with a maximum of four transaction entries
  - Low-power management support
    - Dynamic power-saving features (internal clock gating)
    - Static power-saving features
    - Support for all standard low-power memory features
    - Support for enhanced low-power features (mobile devices)
    - Very low-power controlled-delay technology for optimal performance with DDR memory
    - Can operate with mobile DDR memory at very low clock rates
  - Autorefresh and self-refresh management

---

**NOTE:** The device does not support regular devices, SDR or DDR, because of electrical incompatibility.

---

## 10.2.2 SDRC Subsystem Environment

### 10.2.2.1 SDRC Subsystem Description

Figure 10-42 shows the SDRC subsystem interfacing with one 16- and one 32-bit SDR external memories. Figure 10-43 shows the SDRC subsystem interfacing with one 16- and one 32-bit DDR memories.

**Figure 10-42. SDRC Subsystem Connections to SDR SDRAM**



sdrc-002

**Figure 10-43. SDRC Subsystem Connections to DDR SDRAM****CAUTION**

Both memory types (SRD/DDR SDRAM) cannot be connected simultaneously to the SDRC memory interface.

Table 10-95 lists SDRC subsystem I/O pins.

**Table 10-95. SDRC Subsystem I/O Description**

| Pin          | Type | Description          |
|--------------|------|----------------------|
| sdrc_d[31:0] | I/O  | 32-bit wide data bus |
| sdrc_ba[1:0] | O    | Bank address 1-0     |
| sdrc_a[14:0] | O    | Address bus          |

**Table 10-95. SDRC Subsystem I/O Description (continued)**

| Pin           | Type | Description                         |
|---------------|------|-------------------------------------|
| sdrc_ncs[1:0] | O    | Chip-select 1-0 (active low)        |
| sdrc_clk      | O    | Clock <sup>(1)</sup>                |
| sdrc_nclk     | O    | Clock invert (DDR only)             |
| sdrc_cke0     | O    | Clock enable (CS0)                  |
| sdrc_cke1     | O    | Clock enable (CS1)                  |
| sdrc_nras     | O    | Row address strobe (active low)     |
| sdrc_ncas     | O    | Column address strobe (active low)  |
| sdrc_nwe      | O    | Write enable (active low)           |
| sdrc_dm[3:0]  | O    | Data mask/OE for SDR read operation |
| sdrc_dqs[3:0] | I/O  | Data output strobe (DDR only)       |

<sup>(1)</sup> This output signal is also used as retiming input (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to 1).

### 10.2.2.2 External Interface Configuration

#### 10.2.2.2.1 CS0, CS1 Memory Spaces

The SDRC can be connected independently to two external SDRAM memories.

Mobile SDR SDRAM memory is supported in sizes of 16 Mbits, 32 Mbits, 64 Mbits, 128 Mbits, 256 Mbits, 512 Mbits, 1 Gbit, 2 Gbits, and 4 Gbits. See [Section 10.2.4.4.1](#) for more information on CS memory spaces.

---

**NOTE:** The device does not support regular devices, SDR or DDR (see [Section 10.2.5.3.1](#), *Chip-Select Configuration*).

---

#### 10.2.2.2.2 AC Timing Control

The SDRC permits the configuration of many of the ac timing parameters controlling the SDRAM transaction timing.

It is required to adapt the transaction timing parameters to any memory device attached to the SDRC.

A totally independent, complete set of parameters exists for each CS. The ac parameters and their quantification are summarized in [Section 10.2.5.3.1](#), *Chip-Select Configuration*.

#### 10.2.2.2.3 Address Multiplexing

A flexible address scheme has been added to support any new type of address scheme and SDRAM density. This new address-muxing scheme lets users choose a different bank mapping allocation by configuring the order of the bank and row address decoding (column address always remains the same). The SDRC.[SDRC\\_MCFG\\_p\[7:6\]](#) BANKALLOCATION field defines the order of the bank and row decoding of the incoming system address. The BANKALLOCATION field can be set on a CS basis. For more details about the flexible address scheme, see [Section 10.2.4.4.3](#), *Address Multiplexing*.

The programming model is compatible with the legacy fixed address scheme and with the new flexible address scheme. This section describes the fixed address multiplexing configurations for both SDRAM components.

The legacy fixed address scheme is selected when the SDRC.[SDRC\\_MCFG\\_p\[19\]](#) ADDRMUXLEGACY bit is set to 0 (where p = 0 or 1 for SDRC CS0 or CS1). The fixed address multiplexing configurations are described in this section, for both SDRAM components. An address multiplexing scheme is chosen by programming the SDRC.[SDRC\\_MCFG\\_p\[24:20\]](#) ADDRMUX field of the SDRC\_MEMCFG registers on a per chip select basis (p = 0 or 1 for CS0 or CS1). [Table 10-96](#) and [Table 10-97](#) show all predefined address multiplexing schemes for SDRAM memory components.

**Table 10-96. SDRC Address Multiplexing Scheme Selection vs SDRAM Configurations (x16 Memory Interface)**

| x16 Memory Interface |   |                |    |             |    |            |                    |                   |                     |
|----------------------|---|----------------|----|-------------|----|------------|--------------------|-------------------|---------------------|
| Banks                |   | Column Address |    | Row Address |    | MUX Scheme | Total Size (MBits) | Number of Devices | Device Organization |
| BA0                  | 1 | A0-A7          | 8  | A0-A10      | 11 | MUX1       | 16                 | 1                 | 1M x 16             |
| BA0                  | 1 | A0-A7          | 8  | A0-A11      | 12 | MUX2       | 32                 | 1                 | 2M x 16             |
| BA1,<br>BA0          | 2 | A0-A7          | 8  | A0-A11      | 12 | MUX2       | 64                 | 1                 | 4M x 16             |
| BA1,<br>BA0          | 2 | A0-A8          | 9  | A0-A11      | 12 | MUX4       | 128                | 2                 | 8M x 8              |
|                      |   |                |    |             |    |            |                    | 1                 | 8M x 16             |
| BA1,<br>BA0          | 2 | A0-A8          | 9  | A0-A12      | 13 | MUX7       | 256                | 1                 | 16M x 16            |
| BA1,<br>BA0          | 2 | A0-A8          | 9  | A0-A13      | 14 | MUX26      | 512                | 1                 | 32M x 16            |
| BA1,<br>BA0          | 2 | A0-A9          | 10 | A0-A11      | 12 | MUX6       | 256                | 2                 | 16M x 8             |
|                      |   |                |    |             |    |            |                    | 1                 | 16M x 16            |
| BA1,<br>BA0          | 2 | A0-A9          | 10 | A0-A12      | 13 | MUX10      | 512                | 2                 | 32M x 8             |
|                      |   |                | 10 |             |    |            |                    | 1                 | 32M x 16            |
| BA1,<br>BA0          | 2 | A0-A9          | 10 | A0-A13      | 14 | MUX13      | 1024               | 1                 | 64M x 16            |
| BA1,<br>BA0          | 2 | A0-A9; A11     | 11 | A0-A12      | 13 | MUX12      | 1024               | 2                 | 64M x 8             |
|                      |   |                |    |             |    |            |                    | 1                 | 64M x 16            |

**Table 10-97. SDRC Address Multiplexing Scheme Selection vs SDRAM Configurations (x32 Memory Interface)**

| x32 Memory Interface |   |                |   |             |    |            |                    |                   |                     |
|----------------------|---|----------------|---|-------------|----|------------|--------------------|-------------------|---------------------|
| Banks                |   | Column Address |   | Row Address |    | MUX Scheme | Total Size (MBits) | Number of Devices | Device Organization |
| BA0                  | 1 | A0-A7          | 8 | A0-A11      | 12 | MUX5       | 64                 | 2                 | 2M x 16             |
|                      |   |                |   |             |    |            |                    | 1                 | 2M x 32             |
| BA1,<br>BA0          | 2 | A0-A7          | 8 | A0-A10      | 11 | MUX3       | 64                 | 1                 | 2M x 32             |
| BA1,<br>BA0          | 2 | A0-A7          | 8 | A0-A11      | 12 | MUX5       | 128                | 1                 | 4M x 32             |
| BA1,<br>BA0          | 2 | A0-A7          | 8 | A0-A12      | 13 | MUX9       | 256                | 1                 | 8M x 32             |
| BA1,<br>BA0          | 2 | A0-A7          | 8 | A0-A13      | 14 | MUX27      | 512                | 1                 | 16M x 32            |
| BA1,<br>BA0          | 2 | A0-A7          | 8 | A0-A14      | 15 | MUX28      | 1024               | 1                 | 32M x 32            |
| BA1,<br>BA0          | 2 | A0-A8          | 9 | A0-A11      | 12 | MUX8       | 256                | 4                 | 8M x 8              |
|                      |   |                |   |             |    |            |                    | 2                 | 8M x 16             |
|                      |   |                |   |             |    |            |                    | 1                 | 8M x 32             |
| BA1,<br>BA0          | 2 | A0-A8          | 9 | A0-A12      | 13 | MUX24      | 512                | 1                 | 16M x 32            |
| BA1,<br>BA0          | 2 | A0-A8          | 9 | A0-A13      | 14 | MUX23      | 1024               | 1                 | 32M x 32            |
| BA1,<br>BA0          | 2 | A0-A8          | 9 | A0-A14      | 15 | MUX25      | 2048               | 1                 | 64M x 32            |

**Table 10-97. SDRC Address Multiplexing Scheme Selection vs SDRAM Configurations (x32 Memory Interface) (continued)**

| x32 Memory Interface |   |                |    |             |    |            |                    |                   |                     |
|----------------------|---|----------------|----|-------------|----|------------|--------------------|-------------------|---------------------|
| Banks                |   | Column Address |    | Row Address |    | MUX Scheme | Total Size (MBits) | Number of Devices | Device Organization |
| BA1,<br>BA0          | 2 | A0-A9          | 10 | A0-A11      | 12 | MUX11      | 512                | 4                 | 16M x 8             |
|                      |   |                |    |             |    |            |                    | 2                 | 16M x 16            |
|                      |   |                |    |             |    |            |                    | 1                 | 16M x 32            |
| BA1,<br>BA0          | 2 | A0-A9          | 10 | A0-A12      | 13 | MUX14      | 1024               | 4                 | 32M x 8             |
|                      |   |                |    |             |    |            |                    | 2                 | 32M x 16            |
|                      |   |                |    |             |    |            |                    | 1                 | 32M x 32            |
| BA1,<br>BA0          | 2 | A0-A9          | 10 | A0-A13      | 14 | MUX16      | 2048               | 2                 | 64M x 16            |
|                      |   |                |    |             |    |            |                    | 1                 | 64M x 32            |
| BA1,<br>BA0          | 2 | A0-A9          | 10 | A0-A14      | 15 | MUX29      | 4096               | 1                 | 128M x 32           |
| BA1,<br>BA0          | 2 | A0-A9; A11     | 11 | A0-A12      | 13 | MUX15      | 2048               | 4                 | 64M x 8             |
|                      |   |                |    |             |    |            |                    | 2                 | 64M x 16            |
|                      |   |                |    |             |    |            |                    | 1                 | 64M x 32            |

**Table 10-96** is valid per CS (in the table, the total size in Mbits corresponds to a single CS). Both chips must use the same address scheme, but can use different address multiplexing configurations.

[Figure 10-44](#) through [Figure 10-46](#) show all the SDRAM MUX schemes, including the mapping of the 32-bit system address of the column and row addresses of the memory device.

---

**NOTE:** The bank-select bit (BA1) does not exist for 2-bank devices.

---

**Figure 10-44. SDRC SDR/DDR-SDRAM System Address Multiplexing Schemes (1 of 3)****MUX1**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 11-bit row address [10:0] 8-bit column address [7:0]                            |
| Memory address  | 10 9 8 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0                                                |

**MUX2**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 12-bit row address [11:0] 9-bit column address [8:0]                            |
| Memory address  | 11 10 9 8 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0                                             |

**MUX3**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 11-bit row [10:0] 8-bit column [7:0]                                            |
| Memory address  | 10 9 8 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0                                                |

**MUX4**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 12-bit row address [11:0] 9-bit column address [8:0]                            |
| Memory address  | 11 10 9 8 7 6 5 4 3 2 1 0 8 7 6 5 4 3 2 1 0                                           |

**MUX5**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 12-bit row [11:0] 8-bit column [7:0]                                            |
| Memory address  | 11 10 9 8 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0                                             |

**MUX6**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 12-bit row [11:0] 10-bit column [9:0]                                           |
| Memory address  | 11 10 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0                                         |

**MUX7**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 13-bit row [12:0] 9-bit column [8:0]                                            |
| Memory address  | 12 11 10 9 8 7 6 5 4 3 2 1 0 8 7 6 5 4 3 2 1 0                                        |

**MUX8**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 12-bit row [11:0] 9-bit column [8:0]                                            |
| Memory address  | 11 10 9 8 7 6 5 4 3 2 1 0 8 7 6 5 4 3 2 1 0                                           |

sdrc-004

**Figure 10-45. SDRC SDR/DDR-SDRAM System Address Multiplexing Schemes (2 of 3)**
**MUX9**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0   13-bit row [12:0]   8-bit column [7:0]                                        |
| Memory address  | 12 11 10 9 8 7 6 5 4 3 2 1 0   7 6 5 4 3 2 1 0                                        |

**MUX10**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0   13-bit row [12:0]   10-bit column [9:0]                                       |
| Memory address  | 12 11 10 9 8 7 6 5 4 3 2 1 0   9 8 7 6 5 4 3 2 1 0                                    |

**MUX11**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0   12-bit row [11:0]   10-bit column [9:0]                                       |
| Memory address  | 11 10 9 8 7 6 5 4 3 2 1 0   9 8 7 6 5 4 3 2 1 0                                       |

**MUX12**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0   13-bit row [12:0]   11-bit column [10:0]                                      |
| Memory address  | 12 11 10 9 8 7 6 5 4 3 2 1 0   10 9 8 7 6 5 4 3 2 1 0                                 |

**MUX13**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0   14-bit row [13:0]   10-bit column [9:0]                                       |
| Memory address  | 13 12 11 10 9 8 7 6 5 4 3 2 1 0   9 8 7 6 5 4 3 2 1 0                                 |

**MUX14**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0   13-bit row [12:0]   10-bit column [9:0]                                       |
| Memory address  | 12 11 10 9 8 7 6 5 4 3 2 1 0   9 8 7 6 5 4 3 2 1 0                                    |

**MUX15**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0   13-bit row [12:0]   11-bit column [10:0]                                      |
| Memory address  | 12 11 10 9 8 7 6 5 4 3 2 1 0   10 9 8 7 6 5 4 3 2 1 0                                 |

**MUX16**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0   14-bit row [13:0]   10-bit column [9:0]                                       |
| Memory address  | 13 12 11 10 9 8 7 6 5 4 3 2 1 0   9 8 7 6 5 4 3 2 1 0                                 |

sdrc-005

**Figure 10-46. SDRC SDR/DDR-SDRAM System Address Multiplexing Schemes (3 of 3)****MUX23**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 14-bit row [13:0] 9-bit column [8:0]                                            |
| Memory address  | 13 12 11 10 9 8 7 6 5 4 3 2 1 0 8 7 6 5 4 3 2 1 0                                     |

**MUX24**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 13-bit row [12:0] 9-bit column [8:0]                                            |
| Memory address  | 12 11 10 9 8 7 6 5 4 3 2 1 0 8 7 6 5 4 3 2 1 0                                        |

**MUX25**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 15-bit row [14:0] 9-bit column [8:0]                                            |
| Memory address  | 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 8 7 6 5 4 3 2 1 0                                  |

**MUX26**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 14-bit row [13:0] 9-bit column [8:0]                                            |
| Memory address  | 13 12 11 10 9 8 7 6 5 4 3 2 1 0 8 7 6 5 4 3 2 1 0                                     |

**MUX27**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 14-bit row [13:0] 8-bit column [7:0]                                            |
| Memory address  | 13 12 11 10 9 8 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0                                       |

**MUX28**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 15-bit row [14:0] 8-bit column [7:0]                                            |
| Memory address  | 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0                                    |

**MUX29**

|                 |                                                                                       |
|-----------------|---------------------------------------------------------------------------------------|
| System address  | 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 |
| Address mapping | b1 b0 15-bit row [14:0] 10-bit column [9:0]                                           |
| Memory address  | 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0                                |

sdrcn4-006

**10.2.3 SDRC Subsystem Integration**

Figure 10-47 shows how the SMS and SDRC modules are integrated into the device and how they interact with the PRCM module.

**Figure 10-47. SDRC Integration to the Device**


sdrc-007

### 10.2.3.1 Clocking, Reset, and Power Management Scheme

#### 10.2.3.1.1 Clocking

##### 10.2.3.1.1.1 SMS

The SMS is a single clock domain module. The same clock is used for the interconnect system interface, the SDRC interface, and all internal operations.

SMS\_CLK comes internally from the PRCM module and runs at the L3 interconnect frequency. It is also used as a functional clock for the SMS module.

The source of the SMS\_CLK is the PRCM CORE\_L3\_ICLK output: CORE\_L3\_ICLK belongs to the L3 interconnect clock domain.

### 10.2.3.1.1.2 SDRC

The SDRC is a single-clock domain module. The same clock is used for the interconnect and the memory interface. The SDRC\_CLK clock comes from the PRCM and runs at the L3 interconnect frequency. SDRC\_CLK is also used as a functional clock for the SDRC.

The SDRC\_CLK clock source is the PRCM CORE\_L3\_ICLK output: CORE\_L3\_ICLK belongs to the L3 interconnect clock domain.

An SDRC\_CLKX2 clock is provided by the PRCM at a double frequency of the SDRC\_CLK clock. This clock can be used in the LPDDR write path, depending on the configuration.

As a power-saving feature, when the SDRC no longer requires the clock domain, the software can disable it at the PRCM level by setting the EN\_SDRC bit in the PRCM.CM\_ICKLEN1\_CORE[1] register.

---

**NOTE:** The domain clock is shut down only if all other modules that receive the clock are capable and ready to accept this idle request and have IdleAck asserted.

---

For details, see [Chapter 3, Power, Reset, and Clock Management](#).

### 10.2.3.1.2 Hardware Reset

Global reset of the SDRC is done by activating the CORE\_RST signal in the CORE\_RST domain (see [Chapter 3, Power, Reset, and Clock Management](#)).

There is one global reset signal, SDRC\_GLOBALRESET, which is qualified by the signal SDRC\_POWERON. This qualification differentiates whether the signal is a cold reset or a warm reset.

- On a cold reset (that is, the power-on reset, when SDRC\_POWERON = 0 and SDRC\_GLOBALRESET is applied), all registers and state-machines within the SDRC are asynchronously reset.
- On a warm reset (that is, any other system reset condition under control of the chip top-level power manager, SDRC\_POWERON = 1 when SDRC\_GLOBALRESET is applied), the SDRC registers and the FSM are not reset, but the external SDRAM memory can be optionally placed in self-refresh mode, depending on the configuration of the SDRC.[SDRC\\_POWER\\_REG](#)[7] SRFRONRESET bit.

### 10.2.3.1.3 Software Reset

The SMS and SDRC modules can be reset under software control through the SMS.[SMS\\_SYSCONFIG](#)[1] SOFTRESET and SDRC.[SDRC\\_SYSCONFIG](#)[1] SOFTRESET bits, respectively.

A software reset has the same action as a hardware cold reset; that is, the FSM and all registers are reset immediately and unconditionally.

### 10.2.3.1.4 Power Management

The SDRC power is supplied by the CORE power domain. For details, see [Chapter 3, Power, Reset, and Clock Management](#).

The dynamic voltage and frequency scaling (DVFS) technic is described in the following section while other power-saving features and different idle modes are described in [Section 10.2.4.4, SDRC](#).

#### 10.2.3.1.4.1 Dynamic Voltage and Frequency Scaling

If the input clock SDRC\_CLK from the PRCM module is changed during operations, the DLL may enter an undefined state and memory accesses may be corrupted. For this reason, it is necessary to manually assert the SDRC\_IDLEREQ signal before any clock frequency change. This manual access is done through a register in the chip clock controller. The SDRC then finishes processing all open transactions. If this option is activated in the SDRC\_POWER\_REG[6] SRFRONIDLEREQ bit, it puts the memory into self-refresh. When done, it unlocks the DLL and puts it into a power-down state, through the SDRC.[SDRC\\_DLL\\_CTRL](#)[6:5] DLLMODEONIDLEREQ field. The SDRC then asserts the

SDRC\_SIDLEACK signal and the input clock frequency can be changed or stopped, depending on the scenario. After the input clock is stable again, SDRC\_IDLEREQ is de-asserted. The DLL then relocks and the SDRC can be accessed normally. Putting the DLL in idle mode during the clock frequency change is required because it cannot automatically relock. It might get into a non-functional state and a new manual DLL configuration phase would then be required, with the risk of corrupting accesses in the mean time.

#### 10.2.4 SDRC Subsystem Functional Description

The SMS optimizes the SDRAM memory usage to provide:

- The QoS level required by each of the initiators in the system
- A VRFB module (also called the 2D rotation engine) that minimizes the SDRAM page-miss penalty when accessing rotated (that is, nonsequentially addressed) lines in a graphic frame buffer

##### 10.2.4.1 SDRAM Memory Scheduler

The SMS module is split into the following subsystems:

- L3 interconnect slave port
- VRFB: Rotation engine (RE)
- Configuration register file
- Request buffers
- Arbitration logic
- SDRC interface: master port
- Debug port
- Response buffer

Figure 10-48 shows the top-level diagram of the SMS.

**Figure 10-48. SMS Top-Level Diagram**

#### 10.2.4.1.1 Memory Access Scheduling

**NOTE:** For a description of the SMS mode of operation and arbitration policy, see [Section 10.2.6, SDRC Use Cases and Tips](#).

The SMS includes a set of FIFOs to queue the requests received from the system interconnect or processed by the RE. The FIFO entry contains a complete interconnect request, plus internal qualifiers added by the RE which are required to correctly process the requests modified (or generated) by the RE.

The SMS also includes a response FIFO, which is shared by all response threads. This FIFO provides full support for the response flow-control interconnect extension (handshake protocol).

When a memory transaction request arrives in the memory-access scheduler after being processed by the VRFB module, the request is sent to one of eight FIFO queues.

The allocation to a particular queue is fixed and depends on the source of the request. To prioritize concurrent transactions and optimize memory usage, each FIFO queue (and hence the memory-access request source) is categorized into one of these three arbitration classes:

- Class 0 (highest priority): For bandwidth-sensitive devices with severe real-time constraints. The system fails when the bandwidth requirement is not met. DSS or video display cores, camera capture cores belong to this category.
- Class 1: For latency-sensitive devices where system performance degrades severely when the average memory-access latency increases. These initiators also generally have some significant bandwidth requirements. All CPU cores are class 1 initiators.
- Class 2: For all other devices, possibly with high-bandwidth requirements but without being too latency-sensitive. Associated initiators may also have significant requirements in terms of bandwidth, but if the bandwidth budget requirement cannot be serviced, the system performance degrades, but remains functional (the system does not fail). General-purpose system DMA, multimedia accelerators (graphics, imaging, video) belong to this category.

The arbitration between Class 1 and Class 2 is programmable.

[Table 10-98](#) shows the mapping of FIFO queues and memory-access request sources to arbitration classes.

**Table 10-98. Arbitration Class Allocation**

| Class | FIFO Queue | Source Device                                      |
|-------|------------|----------------------------------------------------|
| 0     | 6          | D2D                                                |
|       | 7          | Display and Camera subsystems                      |
| 1     | 0          | MPU subsystem (instruction and data access)        |
|       | 1          | IVA2 subsystem (instruction, data access, and MMU) |
| 2     | 2          | IVA2 subsystem DMA (read and write), sDMA WR       |
|       | 3          | SGX                                                |
|       | 4          | USB (HS + FS), DAP                                 |
|       | 5          | sDMA (read)                                        |
|       |            |                                                    |

A 2-level arbitration scheme determines the FIFO queue from which the next memory transaction is granted.

**NOTE:** In the register description, a group represents a FIFO queue of requests from the initiator.

#### 10.2.4.1.2 Arbitration Policy

A 2-level arbitration scheme is implemented to grant access to the SDRC. The arbitration uses fully combinatorial logic, and the granted request is clocked before being issued on the interface master port of the SDRC.

- Intra-class arbitration: A first level of arbitration is done in parallel within each class between the different thread groups (request FIFOs).
- Interclass arbitration: A second level of arbitration is done among the three winners of the in-class arbitration.

#### **10.2.4.1.2.1 Arbitration Policy Within a Burst and at a Burst Boundary**

Arbitration is performed on the transaction boundary. The transaction can be either a single transaction or a burst transaction.

- Within a burst, if the thread cannot provide the subsequent request of the burst, a mechanism provides a wait for one idle cycle before moving the arbitration grant to the next thread. If only one idle cycle appears on one thread, an arbitration grant must not move (the next request served must be from the same thread). One idle cycle is then inserted in the SDRC request path.
- If the thread still cannot provide the request in the next cycle, the slot can be awarded to another initiator to avoid locking the SDRAM resource, if a thread cannot supply a subsequent request within the burst. In this case, there must not be a second idle cycle insertion in the SDRC request path. A burst with fewer than two idle cycles cannot be interrupted by a higher priority request.
- On burst boundary, the arbitration does not wait one idle cycle before moving the arbitration grant. As soon as the thread cannot request one transaction at a burst boundary, the arbitration grant can move to the next thread.

This is also valid within the ExtendedGrant and NOFsServices windows; as soon as the thread cannot request a transaction, the arbitration grant can move to the next thread. For more information, see the following descriptions of the ExtendedGrant and NOFsServices features.

#### **10.2.4.1.2.2 Burst-Complete Feature (BURST-COMPLETE Field in *SMS\_CLASS\_ARBITER0*, *SMS\_CLASS\_ARBITER1*, and *SMS\_CLASS\_ARBITER2*)**

A burst request can be submitted to the arbitration either as soon as the first request of the burst is received by the SMS or when at least one complete burst is buffered into the FIFO. The behavior is programmable on a per-group basis using the BURST-COMPLETE field of the *SMS\_CLASS\_ARBITER0*, *SMS\_CLASS\_ARBITER1*, and *SMS\_CLASS\_ARBITER2* registers. A per-FIFO counter tracks the number of complete bursts in a FIFO.

#### **10.2.4.1.2.3 ExtendedGrant Feature (EXTENDEDGRANT Field in *SMS\_CLASS\_ARBITER0*, *SMS\_CLASS\_ARBITER1*, and *SMS\_CLASS\_ARBITER2*)**

EXTENDEDGRANT is a programmable control field that allows a group to be granted for N consecutive transactions (single or burst), assuming the group is still requesting service (FIFO is not empty). EXTENDEDGRANT is applicable on a single/burst boundary. This multiple-service grant is intended to take advantage of the high probability of two consecutive transactions within a group accessing consecutive memory addresses (that is, in the same SDRAM page). This mechanism does not apply to consecutive transactions that have been split by the RE. The maximum number of consecutive grants is given in the EXTENDEDGRANT field of the *SMS\_CLASS\_ARBITER0*, *SMS\_CLASS\_ARBITER1*, and *SMS\_CLASS\_ARBITER2* registers. The allowed range is 1 to 3.

The ExtendedGrant logic is in the internal class arbitration but must be propagated to the interclass arbitration. The flag qualifying a second-service request is provided to the interclass arbiter so the extended grant scheme can be applied at the second level of arbitration.

- Class 0 requests can still override the ExtendedGrant scheme of class 1/class 2. Within an ExtendedGrant window, hand-over to another class/thread (granting another thread) can occur as soon as one idle cycle appears in the thread at burst or single boundary.
- The PWM counter of the interclass arbitration obeys the ExtendedGrant completion before handing priority to the other class.
- When a split transaction from the RE is interleaved within an ExtendedGrant window, completion of the ExtendedGrant window starts with the last ExtendedGrant counter value (not the initial value), because there are two independent counters for ExtendedGrant and NOFsServices. The ExtendedGrant counter is reloaded to its programmed value when it reaches 0.

#### 10.2.4.1.2.4 NOFSERVICES Feature (SMS.SMS\_CLASS\_ROTATIONm[4:0] NOFSERVICES Field)

NOFSERVICES is a programmable control field that allows consecutive transactions (single or burst) coming from the VRFB (with an RE\_split qualifier) to be granted consecutively, assuming the group is still requesting service (FIFO is not empty). NOFSERVICES is applicable to the RE single/burst boundary. The maximum number of consecutive grants is given by the NOFSERVICES field of the SMS.SMS\_CLASS\_ROTATIONm registers. The allowable range is 1 to 31.

The NOFSERVICES logic is in the internal class arbitration, but must be propagated to the interclass arbitration. The flag qualifying a second-service request is provided to the interclass arbiter so the extended grant scheme can be applied at the second level of arbitration.

- Class 0 requests can still override the NOFSERVICES scheme of class 1/class 2. Within a NOFSERVICES window, hand-over to another class/thread (granting another thread) can occur as soon as one idle cycle appears in the thread at burst or single boundary. A burst with fewer than two idle cycles cannot be interrupted by a class 0 request.
- The PWM counter of the interclass arbitration obeys the NOFSERVICES completion before handing priority to the other class.
- When a split transaction from the RE is interleaved within an ExtendedGrant window, completion of the NOFSERVICES window starts with the last NOFSERVICES counter value (not the initial value), because there are two independent counters for ExtendedGrant and NOFSERVICES.

If a transaction split by the VRFB follows a nonsplit transaction currently being executed on the SDRC side, an arbitration slot occurs on the nonsplit transaction boundary, regardless of the status of the ExtendedGrant counter. This is because the chances of a nonsplit transaction and a split transaction accessing the same SDRAM page are low. Similar behavior would be observed for a split transaction followed by a nonsplit transaction. The NOFSERVICES counter is reloaded with its programmed value when it reaches 0.

#### 10.2.4.1.3 Internal Class Arbitration

Class 0, class 1, and class 2 internal arbitrations are performed according to the following rules:

- Within a class, a standard least-recently-used (LRU) policy is applied. The LRU thread, if not empty, is granted when an arbitration decision occurs. LRU is applied taking into account the ExtendedGrant/NOFSERVICES counter status. Grant is given to another nonempty LRU thread only if the current thread is serviced for ExtendedGrant/NOFSERVICES times.
- On top of the LRU policy, a high-priority group can be defined through the SMS.SMS\_CLASS\_ARBITER0[7:6] HIGHPRIOVECTOR field. The high-priority group is unique and programmable. If a high-priority thread in a class, which was previously empty, starts requesting service, the current thread that has been given grant is completely serviced as per ExtendedGrant/NOFSERVICES strategy and then the grant is given to the high-priority thread.

#### 10.2.4.1.3.1 Interclass Arbitration

The interclass arbitration is managed using a time-varying policy driven by the following rules:

- The interclass arbitration is a PWM-like (Pulse Width Modulation) logic that defines two request-based windows:
  - Class 1 has higher priority than class 2 during M requests of class 1, where M is defined by the CLASS1PRIO parameter.
  - Class 2 has higher priority than class 1 during the next N requests of class 2, where N is defined by the CLASS2PRIO parameter. For more information on priority between classes, see [Section 10.2.6.2.2.3](#).
- The PWM counter is decremented each time the class is processing a single 64-bit request in its high-priority window.
- A class 0 request always has the highest priority. The PWM counter is frozen while class 0 requests are being serviced.
- A class 1 transaction can be serviced during the class 2 high-priority window if class 2 is not requesting service (conversely, a class 2 transaction can be serviced during the class 1 high-priority window if class 1 is not requesting service). The PWM counter is frozen when the grant is given to the

thread that is not in its high-priority window.

- NOfServices/ExtendedGrant have higher priority than the PWM counter.
- The PWM counter is reloaded with M and N when it reaches 1 and an arbitration decision must be made.
- The priority order is as follows:
  - Current burst service lock (assuming subsequent burst requests available when required)
  - Class 0
  - ExtendedGrant and NOfServices atomicity (assuming subsequent burst requests available when required)
  - Class 1 if PWM priority is to class 1; class 2 if PWM priority is to class 2
  - Class 2 if PWM priority is to class 1; class 1 if PWM priority is to class 2

#### 10.2.4.1.4 Firewalls

Access permissions can be defined in the target memory address space on a per-initiator basis. Initiators are differentiated using the interconnect ConnID extension.

Permissions are allocated to the various initiators on a per-region basis. The memory regions are programmable using a start address and an end address that are defined with 64K-byte granularity. Up to seven distinct regions can be defined; the software must ensure that they do not overlap.

The remaining memory space (total memory space minus the protected areas) is defined as region 0.

Depending on whether the access is a read or a write, and depending on the in-band request qualifiers, a region may be given specific access permissions. When an access is received by the SMS, the access checked against the access attributes.

- The read permission is initiator-based and is controlled using the SMS.[SMS\\_RG\\_RDPERMi](#) register.
- The write permission is initiator-based and is controlled using the SMS.[SMS\\_RG\\_WRPERMi](#) register.
- The REQINFO bits taken into account are the incoming MReqInfo attributes: Debug, privilege, and attribute, along with the host parameter decoded in the SMS module (see the SMS.[SMS\\_RG\\_ATTi\[31:0\]](#) REQINFO field). For the SMS firewall, the host parameter is set for the MPU initiator and the sDMA initiator. The decoding of the host parameter, based on the MPU ConnID and sDMAConnID generic parameters (defined at design time), is done inside the SMS module.
- Whether the access is accepted (there is one valid bit for each ReqInfo pattern) can be specified for each ReqInfo pattern. ReqInfo permission is controlled using the region attributes register SMS.[SMS\\_RG\\_ATTi\[31:0\]](#) REQINFO field.

[Table 10-99](#) lists the ReqInfo parameters ordering.

**Table 10-99. ReqInfo Parameters Ordering**

| Host                  | Privilege                | Reserved for Non-GP Devices | Debug                     | Type                                | Req Info | SMS. <a href="#">SMS_RG_ATTi[31:0]</a> REQINFO Field |
|-----------------------|--------------------------|-----------------------------|---------------------------|-------------------------------------|----------|------------------------------------------------------|
| 0: Nonhost<br>1: Host | 0: User<br>1: Supervisor | Reserved                    | 0: Functional<br>1: Debug | 0: Data Transfer<br>1: Opcode Fetch |          |                                                      |
|                       |                          | N/A <sup>(1)</sup>          |                           |                                     |          | 0b0...00000000                                       |
| 0                     | 0                        | 0                           | 0                         | 0                                   | 0        | 0b0...00000001                                       |
| 0                     | 0                        | 0                           | 0                         | 0                                   | 1        | 0b0...00000010                                       |
| 0                     | 0                        | 0                           | 1                         | 0                                   | 2        | 0b0...000000100                                      |
|                       |                          |                             |                           |                                     | ...      |                                                      |
| 0                     | 1                        | 1                           | 1                         | 0                                   | 14       | 0b0...000001...00                                    |
| 0                     | 1                        | 1                           | 1                         | 1                                   | 15       | 0b0...00001...000                                    |
| 1                     | 0                        | 0                           | 0                         | 0                                   | 16       | 0b0...0001...0000                                    |
| 1                     | 0                        | 0                           | 0                         | 1                                   | 17       | 0b0...001...00000                                    |
|                       |                          |                             |                           |                                     | ...      |                                                      |
| 1                     | 1                        | 1                           | 0                         | 1                                   | 29       | 0b0010...000000                                      |

<sup>(1)</sup> Access to the region is not allowed

**Table 10-99. ReqInfo Parameters Ordering (continued)**

| Host                                | Privilege                              | Reserved for Non-GP Devices | Debug                                   | Type                                              | Req Info | <a href="#"><b>SMS.SMS_RG_ATTi[31:0]</b></a><br>REQINFO Field |
|-------------------------------------|----------------------------------------|-----------------------------|-----------------------------------------|---------------------------------------------------|----------|---------------------------------------------------------------|
| <b>0: Nonhost</b><br><b>1: Host</b> | <b>0: User</b><br><b>1: Supervisor</b> | <b>Reserved</b>             | <b>0: Functional</b><br><b>1: Debug</b> | <b>0: Data Transfer</b><br><b>1: Opcode Fetch</b> |          |                                                               |
| 1                                   | 1                                      | 1                           | 1                                       | 0                                                 | 30       | 0b0100...000000                                               |
| 1                                   | 1                                      | 1                           | 1                                       | 1                                                 | 31       | 0b1000...000000                                               |

When all [\*\*SMS.SMS\\_RG\\_ATTi\[31:0\]\*\*](#) REQINFO bits are set to 0 the access to the region is not allowed.

Set the REQINFO[0] bit to 1 when NonHost-User-Functional-Data accesses are permitted in this region.

Set the REQINFO[1] bit to 1 when NonHost-User-Debug-Data accesses are permitted in this region.

Set the REQINFO[31] bit to 1 when Host-Supervisor-Debug-Opcode accesses are permitted in this region.

Any bit of the [\*\*SMS.SMS\\_RG\\_ATTi\[31:0\]\*\*](#) REQINFO field corresponds to a particular combination of the five attribute bits. When all [\*\*SMS.SMS\\_RG\\_ATTi\[31:0\]\*\*](#) REQINFO bits are set to 1 the region is full-access allowed.

The firewall unit performs the following checks to authorize or reject an access to the external memory:

- Compute the Region ID based on the transaction address.
- Generate a violation if overlapping of firewall regions is detected.
- From the Region ID, get the attributes for the region that has been hit.
- Check the transaction REQINFO attributes with respect to the region attributes (debug, privilege, type, and host).
- Reject the transaction if the attributes are not compatible.
- From the Region ID and the transaction qualifiers (MCmd, ConnID), check the initiator permissions for performing the access (read, write).
- Reject the transaction if there is no permission.

The protection regions are organized in priority levels (from Level 0 to Level 2) to prevent problems with overlapping region and corner cases associated with them; the lowest level has the lowest priority (see [Figure 10-49](#)).

**Figure 10-49. Region Organization**

sdrc-009

Region 0 (default region containing the whole memory space): Level 0

Region 1 (allows dynamic reprogramming of regions): Level 2

Regions 2-7 (protection regions): Level 1

Region 1 has the highest priority to perform dynamic masking of other already-programmed regions when they are reprogrammed.

Overlapping regions of the same priority level is forbidden and results in a violation when an access to the concerned region occurs. This violation is reported in the error-log register. Priority-level handling is done in the hardware; it does not involve any specific software development.

All transactions are checked, including those the RE has processed.

When detecting a violation on an incoming request, the SMS respects the response ordering within the faulty thread.

A violation flag is raised internally and the MThreadID field is logged. Generation of the interconnect error response is then local to the SMS; the response buffer must be used to manage the potential response collision with regular SDRC responses.

#### 10.2.4.1.5 Rotation Engine

Smartphone applications must often perform image rotation between the orientation of images stored in external memory and the orientation with which they must be displayed. The device offers a hardware mechanism that allows rotation tasks to be implemented efficiently, transparent to software applications, thereby keeping the MPU and DSP CPUs free for other tasks. For a description of the RE mechanism, see [Section 10.2.6, SDRC Use Cases and Tips](#).

The SMS includes address processing support for rotated DSS displays (90, 180, and 270 degrees). This function is realized by the VRFB submodule, also called the rotation engine (RE) in this document.

The primary goal of the VRFB is to eliminate the SDRAM page-miss penalty when reading graphics data in nonnatural raster scan order (that is, top to bottom, bottom to top, right to left).

The 2D-rotation module (the VRFB) is included as a black box that intercepts incoming requests when addressed to the virtual frame buffer. If the address of the request targets the VRFB address space, the request is sent to the RE. It processes the address and reinserts the modified request in the SMS request path. The SMS translates the virtual address into physical SDRAM addresses and reinserts a request or multiple requests in the SMS request path to the SDRC.

---

**NOTE:** The use of the word *virtual* does not refer to the usual CPU-related MMU concept; the word is used in a more general context of the address remapping feature, which decouples the system from the actual storage physical organization of the graphics data in the external memory.

---

The VRFB can be abstracted as a 3-port module:

- Interconnect input port
- Interconnect output port
- Configuration port; all programmable control registers are part of the SMS register file, which is described in [Section 10.2.4.1.5.3, VRFB Configuration Port](#).

#### 10.2.4.1.5.1 VRFB Input Port

The VRFB receives a 29-bit address, and two decoding signals, from the SMS module. The 29-bit address is decoded to determine the context and the rotation view of the request.

The VRFB address space is a 768-MB address space split into two non-contiguous virtual address spaces:

- Address space 0: 256 MB in quarter Q1 (start address: 0x7000 0000, end address: 0x7FFF FFFF)
- Address space 1: 512 MB in quarter Q3 (start address: 0xE000 0000, end address: 0xFFFF FFFF)

It can manage up to 12 concurrent rotation contexts. [Table 10-100](#) details the address space of each context.

**Table 10-100. VRFB Contexts Virtual Address Spaces vs Rotation Angle**

| Context Number | 0°          | 90°         | 180°        | 270°        |
|----------------|-------------|-------------|-------------|-------------|
| 0              | 0x7000 0000 | 0x7100 0000 | 0x7200 0000 | 0x7300 0000 |
| 1              | 0x7400 0000 | 0x7500 0000 | 0x7600 0000 | 0x7700 0000 |
| 2              | 0x7800 0000 | 0x7900 0000 | 0x7A00 0000 | 0x7B00 0000 |
| 3              | 0x7C00 0000 | 0x7D00 0000 | 0x7E00 0000 | 0x7F00 0000 |
| 4              | 0xE000 0000 | 0xE100 0000 | 0xE200 0000 | 0xE300 0000 |
| 5              | 0xE400 0000 | 0xE500 0000 | 0xE600 0000 | 0xE700 0000 |
| 6              | 0xE800 0000 | 0xE900 0000 | 0xEA00 0000 | 0xEB00 0000 |
| 7              | 0xEC00 0000 | 0xED00 0000 | 0xEE00 0000 | 0xEF00 0000 |
| 8              | 0xF000 0000 | 0xF100 0000 | 0xF200 0000 | 0xF300 0000 |
| 9              | 0xF400 0000 | 0xF500 0000 | 0xF600 0000 | 0xF700 0000 |
| 10             | 0xF800 0000 | 0xF900 0000 | 0xFA00 0000 | 0xFB00 0000 |

**Table 10-100. VRFB Contexts Virtual Address Spaces vs Rotation Angle (continued)**

| Context Number | 0°          | 90°         | 180°        | 270°        |
|----------------|-------------|-------------|-------------|-------------|
| 11             | 0xFC00 0000 | 0xFD00 0000 | 0xFE00 0000 | 0xFF00 0000 |

**CAUTION**

There is no protection in hardware for accesses outside the image resolution. Users can access the full virtual address range for a given context (there is no error reporting). Accessing outside of the image resolution creates aliasing within the image and is also translated as an additional physical memory space requirement on the external memory (some data outside of the image range can be overwritten by mistake). The following formula can be used to calculate the extra memory that will be accessed:  $\text{extra\_mem\_size} = (2048 - \text{image\_width\_roundedup}) * \text{page\_height} * \text{pixel\_size}$  with  $\text{image\_width\_roundedup} = \text{ROUNDUP}(\text{image\_width} * \text{pixel\_size}/\text{page\_width}) * \text{page\_width}/\text{pixel\_size}$ .

**10.2.4.1.5.2 VRFB Output Port**

The VRFB output port can be a delayed copy of the input port, with the address field transformed. Depending on the rotated view that is active, an incoming transaction can also be split into several internal transactions.

The pipeline delay between the input and the output ports is three clock periods.

**10.2.4.1.5.3 VRFB Configuration Port**

The configuration port allows 12 concurrent rotation settings.

The VRFB address space is a 768 MB (256 + 512) address space split into two noncontiguous spaces. It can manage up to 12 concurrent rotation settings.

The VRFB configuration port includes all the settings required to control the 12 rotation contexts. This is an input-only port. All settings are provided from the SMS control register file.

For each of the 12 contexts, the buffer physical base address, image height and width, and pixel size can be configured through the following registers (where n is the context number, from 0 to 11):

- SMS.[SMS\\_ROT\\_PHYSICAL\\_BAn](#)[30:0] PHYSICALBA field
- SMS.[SMS\\_ROT\\_SIZEn](#)[26:16] IMAGEHEIGHT and SMS.[SMS\\_ROT\\_SIZEn](#)[10:0] IMAGEWIDTH fields
- SMS.[SMS\\_ROT\\_CONTROLn](#)[1:0] PS field

The memory arrangement for the pixels of a frame buffer accessed through the RE is tile-based. A tile is a rectangular array of pixels. The tile size should match the page size of the SDRAM component attached to the controller for optimal performance.

The tile size is defined using the SMS.[SMS\\_ROT\\_CONTROLn](#)[10:8] page height (PH) and [6:4] page width (PW) fields.

The image height and image width (SMS.[SMS\\_ROT\\_SIZEn](#)[26:16] IMAGEHEIGHT and [10:0] IMAGEWIDTH fields, expressed in bytes) must be multiples of the tile height and width, respectively. Some padding is required if the image size does not fit this requirement.

For a configuration example, see [Section 10.2.5.1.2, VRFB Context Configuration](#).

**10.2.4.1.6 Violation Reporting**

The SMS firewall can detect violations and report them to the overall system by using the following qualifiers:

- The in-band error response to a non-authorized access

- The out-of-band error signal generation using two out-of-band error signals

Based on the fact that there is no way to prevent the debugger from generating firewall violations during debug, and that users cannot stop checking for functional violations, two out-of-band violation signals are set when:

- A functional violation is detected
- A debug violation is detected

These signals are asserted on each error detection from a read, write, or posted write faulty access: they are deasserted when the software clears the error bit in the [SMS\\_ERR\\_TYPE](#) register.

#### 10.2.4.2 Module Power Saving

Power-saving is managed through the SMS.[SMS\\_SYSCONFIG](#) register.

The [SMS\\_SYSCONFIG\[4:3\]](#) SIDLEMODE field defines the power management strategy (force idle mode, no idle mode, or smart idle mode). See [Section 10.2.4.3](#) for more details about the system power management.

By default, the internal interface clock gating strategy is enabled as the [SMS\\_SYSCONFIG\[0\]](#) AUTOIDLE bit is set to 0x1 after reset. When all FIFO queues are empty and no ongoing transactions remain, the L3 interconnect clock is disabled inside the SMS thus reducing power consumption. The L3 interconnect clock can be disabled after a programmable delay defined in the [SMS\\_POW\\_CTRL\[7:0\]](#) IDLEDELAY bit field.

When there is new activity on the interconnect interface, the interconnect clock is restarted without any latency penalty. It is recommended to enable this mode to reduce power consumption.

There is an internal interface clock gating strategy within the SDRC. This power-saving feature is always active.

#### 10.2.4.3 System Power Management

The SMS can be configured through the SMS.[SMS\\_SYSCONFIG](#) register to be in one of these idle modes:

- No-idle mode (the SMS.[SMS\\_SYSCONFIG\[4:3\]](#) SIDLEMODE field is set to 0x1): The module never goes into idle state.
- Force-idle mode (the SMS.[SMS\\_SYSCONFIG\[4:3\]](#) SIDLEMODE field is set to 0x0): The module goes into idle state immediately after receiving the request from the PRCM.
- Smart-idle mode (the SMS.[SMS\\_SYSCONFIG\[4:3\]](#) SIDLEMODE field is set to 0x2): SidleAck is asserted once the module has confirmed there are no more outstanding transactions with the SDRC.

#### 10.2.4.4 SDRC

The SDRC provides two configurable memory areas. Each supports mobile SDR SDRAM and low-power DDR SDRAM from 16 Mbits to 4 Gbits, depending on the memory organization.

Flexible row/column addressing schemes are possible with 2-bank support for 16 Mbits and 32 Mbits memories, and 4-bank support for 64 Mbits, 128 Mbits, 256 Mbits, 512 Mbits, 1 Gbit, 2 Gbits, and 4 Gbits memories.

[Figure 10-50](#) shows the architecture of the SDRC.

Figure 10-50. SDRC Architecture



sdrc-010

#### 10.2.4.4.1 CS0-CS1 Memory Spaces

##### 10.2.4.4.1.1 Chip-Select 0 Start Address

- CS0 always starts at address 0 with respect to the local interconnect address.
- The valid CS0 range is 0 - CS0max, where CS0max is defined in the SDRC.[SDRC\\_MCFG\\_p\[17:8\]](#) RAMSIZE field where p = 0 (for CS0), and by the number of banks.

##### 10.2.4.4.1.2 Chip-Select 1 Start Address

- CS1 start address is programmable.
- The default base address for CS1 after reset is defined in the register description.
- The SDRC 1G-byte/8G-bit address space is segmented so that 7 possible CS1 start address locations (8 in total minus 1 reserved for CS0) are defined by the SDRC.[SDRC\\_CS\\_CFG\[3:0\]](#) CS1STARTHIGH field as shown in [Figure 10-51](#).
- Each 128M-byte address space is also segmented into 32M-byte address spaces defined by the SDRC.[SDRC\\_CS\\_CFG\[9:8\]](#) CS1STARTLOW field so that 64 possible CS1 start address locations are defined by the SDRC.[SDRC\\_CS\\_CFG\[3:0\]](#) CS1STARTHIGH and SDRC.[SDRC\\_CS\\_CFG\[9:8\]](#) CS1STARTLOW fields.
- The valid CS1 range is:

CS1 start address slot - CS1max, where CS1max is defined by SDRC.[SDRC\\_MCFG\\_p\[17:8\]](#) RAMSIZE where p = 1 (for CS1) and SDRC.[SDRC\\_CS\\_CFG](#) registers.

**Figure 10-51. CS0/CS1 Chip-Select Start Address Slots**



sdrc-011

#### 10.2.4.4.1.3 SDRAM Memory Combinations on CS1 and CS0

The combinations of SDR and DDR memories/SDRAMs are defined as follows:

- SDR and DDR memories can be connected on either CS1 or CS0.
- The only restriction on the coexistence of SDRAMs on CS0 or CS1 is that a combination of SDR on one CS and DDR on the other CS is not allowed.

The SDRAM data bus width on each CS is determined by the SDRC.[SDRC\\_SHARING\[11:9\]](#) CS0MUXCFG and SDRC.[SDRC\\_SHARING\[14:12\]](#) CS1MUXCFG fields of the memory-sharing registers.

#### 10.2.4.4.2 Bank Tracking

The main state-machine controls all the accesses to external memories.

The SDRC contains hardware for tracking open pages on a per-bank basis. Up to four open pages are tracked per CS, for a maximum of eight open pages tracked.

To pipeline accesses efficiently, the SDRC includes a request look-ahead FIFO that analyzes interconnect requests with respect to the status of the target banks. A bank status can be any of the following:

- Bank open on another row
- Bank closed
- Bank open on the same row

The SDRC state-machine generates the appropriate sequence of memory commands. All precharge and active commands are hidden as much as possible, to optimize the memory bandwidth usage.

The look-ahead FIFO depth is  $9 * 64$ -bit requests, with a limit of four different transactions. As soon as the look-ahead FIFO stores four complete transactions or when it is full, the SCmdAccept is deasserted and any incoming request is blocked.

Requests sent to the SDRC are treated in order. The four transactions limit in the SDRC look-ahead FIFO ensures that high-priority requests performance is not hampered by a succession of SDRAM page close/page open cycles due to previous lower priority requests already accepted by the SDRC. With this limit, requests not accepted by the SDRC will have to go through the SMS arbitration at a later time. If a high-priority request has arrived in the SMS in the mean time, it will be passed to the SDRC before any lower-priority request, as defined in the regular SMS arbitration scheme.

#### 10.2.4.4.3 Address Multiplexing

A flexible address scheme allows for the support of any new type of SDRAM address multiplexing and density.

The programming model has changed but is still compatible with the legacy fixed address scheme. Both chips, hence both CS must use the same address scheme (fixed or flexible), but can use different address multiplexing configurations.

A dedicated bit controls the address scheme used: the legacy fixed address scheme or the new flexible address scheme:

- The legacy fixed address scheme is selected when the SDRC.[SDRC\\_MCFG\\_p\[19\]](#) ADDRMUXLEGACY bit is set to 0 (where p = 0 or 1 for SDRC CS0 or CS1).
- A new flexible address-muxing scheme configuration is selected with the SDRC.[SDRC\\_MCFG\\_p\[19\]](#) ADDRMUXLEGACY bit set to 1 (where p = 0 or 1 for SDRC CS0 or CS1).

To use this new flexible address scheme, configure the row address width and the column address with the SDRC.[SDRC\\_MCFG\\_p\[26:24\]](#) RASWIDTH and SDRC.[SDRC\\_MCFG\\_p\[22:20\]](#) CASWIDTH fields.

For more information about fixed address multiplexing configurations for SDRAM components, see [Section 10.2.2.2.3, Address Multiplexing](#).

#### 10.2.4.4.4 Bank Allocation Setting

##### 10.2.4.4.4.1 System Address Decoding

The SDRC has a 64-bit slave interface connected to the L3 main system interconnect. The regular allocation is to see the system address bus as the concatenation bank-row-column. The SDRC translates the interconnect request (read or write to memory for instance) into a series of commands and bank, row, column signals. The commands are sent to the external SDRAM through the sdrc\_ncs, sdrc\_nras, sdrc\_ncas and sdrc\_nwe signals. The bank, row and column addresses are sent through sdrc\_a and sdrc\_ba with the associated command. Those words can be defined as follow:

- Bank: the address of one of the four (or two) banks
- Row: the address of a page
- Column: the address of a word in a page

The bank signals are used to select which of the bank is accessed when transferring data from or to the SDRAM. In the first cycle, the SDRAM memory latches the row address (nRAS low): the adequate bank and row are activated. Next cycle, the SDRAM memory latches the column address (nCAS low): the adequate column is activated. The address is hence decoded: memory cells are sensed by sense amplifier and data is read from or written to output buffers.

[Figure 10-52](#) shows a block diagram of a 512 Mbits SDRAM memory (8M x 16 x 4 banks). The data bus DQ[15:0] has a 16-bit width. Rows are addressed through A0-A12 (8192 rows) and columns through A0-A9 (1024 columns).

**Figure 10-52. SDRAM Controller Block Diagram**


sdrc-042

#### **10.2.4.4.4.2 SDRC Commands**

Before any read or write command can be issued to a bank in the external memory, a row in that bank must be opened. This is accomplished by the active command, by which the bank and the row are selected. More than one bank (up to four according to the memory used) can be active at one time. Once a row is opened, a read or write command can be issued to that row. The row remains active until a precharge or read/write to another row in the same bank or a refresh to the bank occurs.

Autorefresh command is used during normal operation mode. This command is non-persistent (that is, it must be issued each time a refresh is required). The device requires a refresh of all rows in a periodic interval. This command takes some time (according to the memory used), and during this phase no read or write command can be processed. A precharge-all (that is, a precharge command affecting all banks) is issued before any autorefresh sequence.

An active command to a row of a bank for which another row is already active can be issued only after the previous row has been closed. The precharge command is used to deactivate the open row in a particular bank. The bank is available for a subsequent row access some time after the row precharge command is issued. A minimum time is needed to close and open a new row.

A subsequent active command to another bank can be issued while the first bank is being accessed without closing the row in the first bank. This results in a reduction of row access time in the same bank. In this case, it is not necessary to deactivate (with a precharge command) the row in the other banks. Up to four banks, depending on the memory used, can be activated at the same time. In each bank, one row can be selected at a time.

#### **10.2.4.4.4.3 BANKALLOCATION Parameter**

To optimize SDRAM memory accesses in a throughput point of view, the SDRC supports various bank-row-column allocation. The bank-row-column allocation choice depends on many parameters, such as the number of initiators in the use case, the memory usage (accesses bandwidth, frequency), and so on.

The SDRC not only supports the regular allocation where the system address bus is seen as the concatenation bank-row-column, but it also supports two other types of allocation. The **SDRC\_MCFG\_p[7:6]** BANKALLOCATION bit field (where p = 0 or 1 for CS0 or CS1) selects the type of allocation. This feature modifies the bank, row, and column address decoding order:

- BANKALLOCATION = 0x0: Bank-row-column
- BANKALLOCATION = 0x1: Bank1-row-bank0-column
- BANKALLOCATION = 0x2: Row-bank-column

Only the flexible address-muxing scheme allows choosing different bank mapping allocations throughout the BANKALLOCATION parameter (that is, the legacy address-muxing scheme does not).

The flexible address-muxing scheme ([SDRC\\_MCFG\\_p\[19\]](#) ADDRMUXLEGACY = 0x1) allows choosing different bank mapping allocations. The SDRC.[SDRC\\_MCFG\\_p\[7:6\]](#) BANKALLOCATION bit field (p = 0 or 1 for CS0 or CS1) defines the ordering of the bank, and the column and row decoding of the incoming system address. The BANKALLOCATION bit field can be set on a CS basis.

In the usual allocation, the system address bus is seen as a concatenation of bank-row-column. The system address received from the interconnect into the SDRC is composed of:

- 2 system address bits used as the bank address (going to SDRC sdrc\_ba[1:0] pins)
- 13 system address bits used as the row address (going to SDRC sdrc\_a[12:0] pins)
- 10 system address bits used as the column address (going to SDRC sdrc\_a[12:0] pins)

Setting the BANKALLOCATION bit field to 0x1 or 0x2 changes the order of the system address decoding, as shown in [Figure 10-53](#).

**Figure 10-53. Address Multiplexing Scheme According to BANKALLOCATION**



[Figure 10-54](#) compares bank-row-column and row-bank-column memory accesses.

**Figure 10-54. Simplified View of Bank-Row-Column vs Row-Bank-Column Bank Allocation**



sdrc\_044

The latency to charge another row in the same bank (that is, to close the opened page and to open another one) is bigger than the latency involved with an access to a given row in another bank. By moving bank select signals ahead of column and after row addresses, bank interleaving is likely to happen more often. More frequent use of the interleaved mode means less overall SDRAM access time and, thus, yields to better overall performance.

In some use cases, several initiators access the same bank (bank0 for instance) in external SDRAM memory at the same time. With this kind of scenario, a lot of penalties are added because of rows opening and closing. The BANKALLOCATION setting improves the latency for reading and writing operations by optimizing memory accesses through the reduction of deactivate sequence use, thereby reducing time penalties.

The bank1-row-bank0-column allocation is a good compromise between the legacy bank allocation (bank-row-column) and the full interleaving bank allocation (row-bank-column). In some use cases, it may be necessary to keep only half of the memory refreshed (on bank0 and bank1 for instance) while the other two banks are unused. In full interleaving bank allocation, the memory must be refreshed through the self-refresh mode, while with bank1-row-bank0-column, the memory can be refreshed through self-refresh mode or through partial array self-refresh mode.

In the following, an example of latency is given based on a 512-Mbit SDRAM memory data sheet. **Table 10-101** gives the duration for some AC timing parameters. The frequency used in the example is 133 MHz (that is, tCK = 7.5 ns). The CAS latency = 3.

**Table 10-101. Mobile DDR SDRAM AC Timing Parameters**

| AC Timing Parameter | Description            | Duration (ns)   |
|---------------------|------------------------|-----------------|
| tRFC                | Autorefresh cycle time | 80 (min)        |
| tRP                 | Row precharge time     | 22.5 (or 3 tCK) |

**Table 10-101. Mobile DDR SDRAM AC Timing Parameters (continued)**

| AC Timing Parameter | Description                         | Duration (ns)   |
|---------------------|-------------------------------------|-----------------|
| tRC                 | Row cycle time                      | 67.5 (or 9 tCK) |
| tRAS                | Row active time                     | 45 (or 6 tCK)   |
| tRCD                | nRAS to nCAS delay time             | 22.5 (or 3 tCK) |
| tRRD                | Row active to row active delay time | 15 (or 2 tCK)   |

The latency to access another row in the same bank depends on tRP and tRAS timings because a precharge command followed by an active command must be issued. Therefore, 6 tCK are needed to close the current row and open another one.

When accessing another bank, the latency to access another row depends on tRAS timing only because the closing of the current row is not mandatory. In other words only an active command must be issued. Therefore, 3 tCK are needed to open another row in a different bank.

Single initiator use case:

When the initiator wants to access a page in a bank for the first time, it opens only this page. It takes 3 tCK. When the initiator is done with this page, it closes this page and opens another one. It takes 6 tCK.

Two initiators use case:

When one initiator wants to access a page in the same bank, it must necessarily close the current page and open the page it wants to access. It takes 6 tCK.

When one initiator wants to access a page this time in another bank, there can be less page opening and closing. For instance, if the initiator wants to open a page in another bank where no page is open, it takes only 3 tCK, rather than 6 tCK if it was another page in the same bank.

#### 10.2.4.4.5 Data Multiplexing During Write Operations

##### 10.2.4.4.5.1 External Bus Combinations

The SDRC pin allocation scenarios are provided in [Table 10-102](#). These scenarios are defined on a per-CS basis for maximum flexibility. The pin allocation configurations allow implementation of combinations of the 16-/32-bit external interfaces listed in this table. The data multiplexer receives a 64-bit word from the SDRAM command queue and partitions the data into a series of 16-bit or 32-bit accesses. The data multiplexer also steers the data to the appropriate data lane. The data partitioning and data steering are determined by the SDRC.[SDRC\\_SHARING\[11:9\]](#) CS0MUXCFG and SDRC.[SDRC\\_SHARING\[14:12\]](#) CS1MUXCFG fields.

**Table 10-102. SDRC Data Lane Configurations**

| Device pins | sdrc_d[31:24]          | sdrc_d[23:16] | sdrc_d[15:8] | sdrc_d[7:0] |                                                             |
|-------------|------------------------|---------------|--------------|-------------|-------------------------------------------------------------|
|             | <b>DataLane[31:16]</b> |               |              |             | <b>DataLane[15:0]</b>                                       |
|             | DQS3                   | DQS2          | DQS1         | DQS0        |                                                             |
|             | DQM3                   | DQM2          | DQM1         | DQM0        | SDRC. <a href="#">SDRC_SHARING[14:9]</a><br>CSnMUXCFG field |
|             | <b>D[31:0]</b>         |               |              |             | 0x0, 0x1                                                    |
|             | D[15:0]                |               |              |             | 0x2, 0x7                                                    |
|             |                        |               | D[15:0]      |             | 0x3                                                         |
|             |                        |               |              |             | 0x4, 0x5, 0x6: Reserved                                     |

#### 10.2.4.4.5.2 Endianness-Aware Unpacking

Data transactions can be either big or little endian; the transaction endianness is determined by an in-band interconnect qualifier. Muxing 64-bit data to 16-/32-bit data is performed according to this qualifier.

For a 64-bit interconnect little-endian write transaction on a 16-/32-bit memory, Data[15(31):0] is written at the lowest memory address, and Data[63:48(32)] is written at the highest memory address.

For a 64-bit interconnect big-endian write transaction on a 16-/32-bit memory, Data[15(31):0] is written at the highest memory address, and Data[63:48(32)] is written at the lowest memory address.

Figure 10-55 shows the data multiplexing scheme.

Figure 10-55. Data Multiplexing Scheme



sdrc-012

#### 10.2.4.4.6 Data Demultiplexing During Read Operations

##### 10.2.4.4.6.1 External Bus Combinations

The SDRC pin allocation scenarios are shown in [Table 10-102](#). These scenarios are defined on a per-CS basis for maximum flexibility. The pin allocation configurations allow implementation of combinations of 16-/32-bit external interfaces. The data demultiplexer receives 16-/32-bit data from the relevant SDRC data lane, and then performs a data packing function. The packing function formats the data into 64-, 32-, 16-, or 8-bit format. The data demultiplexer also steers the data from the appropriate data lane. The data partitioning and data steering are determined by the SDRC.[SDRC\\_SHARING\[11:9\]](#) CSOMUXCFG and SDRC.[SDRC\\_SHARING\[14:12\]](#) CS1MUXCFG bit fields.

Figure 10-56 shows the data demultiplexing scheme.

Figure 10-56. Data Demultiplexing Scheme



#### 10.2.4.4.6.2 Endianness-Aware Packing

Data transactions can be big or little endian; their endianness is determined by an in-band interconnect qualifier. Demuxing 16-/32-bit memory data to 64-bit interconnect data is performed according to this qualifier.

For a 64-bit interconnect little-endian read transaction on a 16-/32-bit memory, Data[15(31):0] is read from the lowest memory address, and Data[63:48(32)] is read from the highest memory address.

For a 64-bit interconnect big-endian read transaction on a 16-/32-bit memory, Data[15(31):0] is read from the highest memory address, and Data[63:48(32)] is read from the lowest memory address.

To preserve data integrity in all situations, that is, regardless of the effective scalar size of the transferred data (byte, Word16, Word32, or DWord64), the endianness specified during the read operation must match that specified during the write operation. If there is no match, the packing and unpacking operations are not consistent. There is no attempt to perform endianness conversion in the SDRC; only endian-aware width conversion is performed.

#### 10.2.4.4.7 Refresh Management

Refresh management can be divided as follows:

- Self-refresh management
- Autorefresh management (programmable refresh period)

##### 10.2.4.4.7.1 Self-Refresh Management

Self-refresh is entered to place an attached SDRAM into an autonomous refresh mode, typically when the device enters an idle mode and switches off the SDRAM clock.

In self-refresh, the SDRAM supplies the row address generation required to refresh and retain data in the absence of external clocking.

Self-refresh can be entered using any of the following methods:

- Manually, under software control per CS
- Upon a reset event: Automatically on a warm reset event (if the SDRC is programmed to enter self-refresh on warm reset)
- Upon a hardware request: Automatically on an idle request sent by the system power manager (if the SDRC is programmed to enter self-refresh on idle request)
- Automatically after a (programmable) period of inactivity on the interconnect interface (if enabled by setting the SDRC.[SDRC\\_POWER\\_REG\[5:4\]](#) CLKCTRL bit field to 0x2)

Self-refresh can be exited as follows:

- Manual software command (exit from self-refresh mode; see [Section 10.2.5.3.4, DLL/CDL Configuration](#))
- Automatically after receiving a read or write transaction to access memory

##### 10.2.4.4.7.2 Autorefresh Management

When autorefresh is enabled, a programmable hardware counter within the SDRC generates a periodic event that triggers either a single refresh or a burst of consecutive refresh commands. This is the standard refresh mode used when the system is active, while the running applications regularly access the SDRAM.

An autorefresh command can also be applied using the SDRC.[SDRC\\_MANUAL\\_p](#) register (see [Section 10.2.5.3.4, DLL/CDL Configuration](#)). This method can be used to generate a device-specific initialization sequence after power up or after the memory device exits from a low-power mode (self-refresh or deep-power-down).

The autorefresh request period is a user-controlled parameter programmed to meet the specification of the memory devices. Each time an autorefresh request is issued, the SDRC can service the autorefresh using any of the following commands:

- Single autorefresh command
- Burst of four autorefresh commands
- Burst of eight autorefresh commands

When a burst of four or eight is selected, the programmed period value is automatically scaled in hardware by 4 or 8. Consequently, the value to be programmed does not depend on the selected burst length.

#### 10.2.4.4.8 System Power Management

Unlike the SMS, the SDRC can be configured only in smart-idle mode by setting the SDRC.[SDRC\\_SYSConfig\[4:3\]](#) IDLEMODE field to 0x2. Once all asserted output interrupts are acknowledged, the SDRC goes into idle state after it receives the request from the PRCM module.

The SDRC acknowledge is conditioned by the internal activity of the SDRC.

**NOTE:** As soon as the SDRC goes out of idle state, stalled accesses can be accepted and processed:

- In SDR mode, the access can be immediately processed (unstalled).
- In DDR fixed delay mode, the access is processed (unstalled) after expiration of MODEFIXEDDELAYINITLAT.

#### 10.2.4.4.9 Power-Saving Features

In the SDRC there are three ways to save power and they can be applied simultaneously:

- Page opening/closure policy
- Dynamic low-power mode
- Static low-power mode

##### 10.2.4.4.9.1 Page Opening/Closure Policy

The device supports only one page policy. The SDRC.[SDRC\\_POWER\\_REG\[0\]](#) PAGEPOLICY bit must be set to 1.

The SDRC tracks open pages, if any, and determines whether the current access is to an open or a closed page. If the accessed page is open, the SDRC executes the access immediately. The SDRC performs the following procedure:

1. If the current page is already open on this bank the SDRC automatically issues a *precharge* command to close that bank.
2. Opens the accessed page by issuing an *active* command to that bank
3. Executes the access by issuing a *read* or *write* command

Up to four pages can be open simultaneously with a limit of one page per bank. The pages remain open until one of the following occurs:

- New read or write request to another page in the same bank
- Autorefresh request (a *precharge all* command is issued first)
- Self-refresh entry request (a *precharge all* command is issued first)
- Manual *precharge all* command

##### 10.2.4.4.9.2 Dynamic Low-Power Operating Modes

The dynamic low-power operating modes of the SDRC are designed to:

- Control the external SDRAM clock(s)
- Control the internal clock gating of the SDRC when the interconnect interface is idle
- Control the self-refresh functionality

The external SDRAM is controlled through the SDRC.[SDRC\\_POWER\\_REG\[3\]](#) EXTCLKDIS and SDRC.[SDRC\\_POWER\\_REG\[2\]](#) PWDENA bits. The EXTCLKDIS bit is used to disable the external clock when no access is ongoing on the memory interface, whereas the PWDENA bit is used to activate the power-down mode of the target memory by pulling the relevant CKE low each time the memory interface is idle.

When the PWDENA bit is enabled but the EXTCLKDIS bit is not enabled, the SDRC still provides a free-running clock to the external memories: clock gating is done internal to the memory component for power savings.

EXTCLKDIS should be modified only when no access is in progress on the SDRAM interface. Software control is required to make sure the interface is idle.

CKE is dynamically controlled based on the current memory command. There is a zero-latency penalty when this mode is enabled.

The SDRC has three modes of automatic internal clock-gating behavior when the interconnect interface is idle, that is, there are no outstanding active transactions in progress. These modes are controlled through the SDRC.[SDRC\\_POWER\\_REG\[5:4\]](#) CLKCTRL and SDRC.[SDRC\\_POWER\\_REG\[23:8\]](#) AUTOCOUNT fields.

- Mode 0: The autoclock gating feature is disabled. No internal clock gating is performed in the SDRC in response to the detection of an idle state on the interconnect interface.
- Mode 1: A 16-bit counter starts decrementing when an interconnect idle condition is detected. The counter start value is loaded from the AUTOCOUNT 16-bit field. When this counter times out, internal clock gating within the SDRC is enabled.
- If an interconnect active command is received before the counter times out, or if an internal autorefresh request is issued, the procedure is aborted, the counter stops decrementing, and the request is serviced immediately.
- Mode 2: This mode is similar to mode 1, but before the internal clock gating, the SDRC places the SDRAM into self-refresh mode and turns off the external SDRAM clock. This is the lowest power mode.

To achieve maximum power savings, TI recommends the use of the PWDENA-, EXTCLKDIS-, and CLKCTRL-related features.

[Table 10-103](#) explains the different power-saving configurations that can be programmed with the SDRC.[SDRC\\_POWER\\_REG\[3\]](#) EXTCLKDIS, SDRC.[SDRC\\_POWER\\_REG\[2\]](#) PWDENA, and SDRC.[SDRC\\_POWER\\_REG\[5:4\]](#) CLKCTRL bits.

**Table 10-103. Dynamic Power Saving Configurations**

| CLKCTRL | EXTCLKDIS | PWDENA | CKE                | External SDRC CLK <sup>(1)</sup>              | SDRAM State                                   | Latency When Exiting Power Mode |
|---------|-----------|--------|--------------------|-----------------------------------------------|-----------------------------------------------|---------------------------------|
| 0       | 0         | 0      | Always high        | Always on                                     | Keep previous state                           |                                 |
| 0       | 0         | 1      | Low when no access | Always on                                     | Power-down                                    | Zero-latency penalty            |
| 0       | 1         | 0      | Always high        | Off when no access                            | Keep previous state                           |                                 |
| 0       | 1         | 1      | Low when no access | Off when no access                            | Power-down                                    | One cycle penalty               |
| 1       | 0         | 0      | Always high        | Always on                                     | Keep previous state                           |                                 |
| 1       | 0         | 1      | Low when no access | Always on                                     | Power-down                                    | Zero-latency penalty            |
| 1       | 1         | 0      | Always high        | Off when no access                            | Keep previous state                           |                                 |
| 1       | 1         | 1      | Low when no access | Off when no access                            | Power-down                                    | One cycle penalty               |
| 2       | 0         | 0      | Low when no access | Off when no access after AUTOCOUNT expiration | Enter self-refresh after AUTOCOUNT expiration |                                 |
| 2       | 0         | 1      | Low when no access | Off when no access after AUTOCOUNT expiration | Enter self-refresh after AUTOCOUNT expiration |                                 |
| 2       | 1         | 0      | Low when no access | Off when no access                            | Enter self-refresh after AUTOCOUNT expiration |                                 |
| 2       | 1         | 1      | Low when no access | Off when no access                            | Enter self-refresh after AUTOCOUNT expiration |                                 |

<sup>(1)</sup> EXTCLK can be set to 1 all the time for power optimization purposes, except when manual commands are sent. In this case, users must set EXTCLKDIS to 0 to ensure that a clock signal is provided to the memory device.

**NOTE:** When connected to a DDR memory, the SDRC never gates the clock provided to the DLL components so that the DLL remains locked during these idle modes. This avoids the maximum of 500 clock cycles latency required for relocking the DLL when the DLL clock is switched off.

All settings for the power-saving features are common to the two CSs. When two CSs are used, however, only the accessed CS exits self-refresh or deep-power-down mode.

If the SDRC.[SDRC\\_POWER\\_REG](#)[6] SRFRONIDLEREQ bit is enabled, the SDRC enters self-refresh mode on a hardware idle request from the PRCM. The memory clock is automatically switched off, after which the SDRC sends an acknowledge back to the PRCM. In this situation, the power manager can switch the SDRC clock off. Therefore, if the SDRC is connected to a DDR memory, and if the DLL is enabled and in TrackingDelay mode, the SDRC waits for the lock status bit of the DLL to be asserted before accessing the memory when the system exits the idle state. The WAKEUPPROC bit of the [SDRC\\_POWER\\_REG](#) register enables the SDRC to automatically wait for 500 cycles (DLL relocking maximum time) before accessing the memory instead of using the LOCK signal. These 500 wait cycles are obeyed only when the DLL is set in TrackingDelay mode. For SDR mode and DLL ModeFixedDelay mode, the access is processed immediately. This mechanism is independent of the CLKCTRL field.

---

**NOTE: DLL Behavior Upon a Warm Reset Assertion:**

Upon a warm reset (the [SDRC\\_DLLA\\_CTRL](#)[3] ENADLL bit is not reset as it is not sensitive to warm reset but the DLL will be in unlock mode since DLL is reset. To lock the DLL again, the [SDRC\\_DLLA\\_CTRL](#)[3] ENADLL needs to be made 0 and then made 1 again. This will trigger a locking sequence.

---

#### 10.2.4.4.9.3 Static Low-Power Operating Modes

The software-driven controls for low-power operation modes include:

- Possibility to put the memory in self-refresh using the manual command register ([SDRC\\_SDRC\\_MANUAL\\_p](#) (where p = 0 or 1 for SDRC CS0 or CS1). Each CS can be controlled independently. If both CSs are in self-refresh, the external SDRAM clock can be switched off by setting the SDRC.[SDRC\\_POWER\\_REG](#)[3] EXTCLKDIS control bit to 1. Self-refresh can be exited automatically if an access is initiated onto the CS. Only DPD must be exited manually.
- Possibility to put the memory in deep-power-down mode, if supported by the SDRAM, using the manual command register. Each CS can be controlled independently. The external SDRAM clock can be switched off if both CSs are either in self-refresh or deep-power-down mode by setting the SDRC.[SDRC\\_POWER\\_REG](#)[3] EXTCLKDIS control bit to 1. Another manual command must be used for the memory to exit deep-power-down mode. After a memory exits from that mode all data are lost, and a full initialization sequence must be sent to the device, before it can be used.

#### 10.2.4.4.10 SDRC Power-Down Mode

In some applications, the SDRC power domain can be powered down while the external memory is in self-refresh mode.

When the SDRC is powered off, an isolation stage prevents an unwanted exit from self-refresh when the context is restored. SDRC outputs that control the SDRAM are set to maintain self-refresh or deep-power-down (CKE low).

When a reset occurs, the default reset state of the SDRC is power-down enable (PDE).

When exiting the off mode:

- Power is restored to the SDRC.
- The software reconfigures all registers. If the NOMEMORYMRS bit is set, the MR and EMR registers can be set through the SDRC.[SDRC\\_MR\\_p](#) and SDRC.[SDRC\\_EMR2\\_p](#) registers (see [Section 10.2.4.5, Mode Registers](#)).
- Exit from self-refresh mode is achieved through the SDRC.[SDRC\\_MANUAL\\_p](#) CMDCODE field. Because exit from the self-refresh field is unconditional (that is, the current state of the SDRC state-machine is not considered), ensure that autorefresh is disabled.

Once the context is successfully restored, the software can reinitialize the SDRAM or return the SDRAM to self-refresh. When the device successfully exits self-refresh, autorefresh must be re-enabled.

#### 10.2.4.4.11 Controlled Delay Line

The DLL/CDL module is a hard macro composed of one master delay-locked loop (DLL) and five slave-controlled delay lines (CDL). It is used to generate precise delays suitable for DDR read and write operations. DLL delays are tracked at high frequency on process dispersion, and voltage and temperature variations (PVT).

A CDL is a component with a clock input signal, a clock output signal, and a delay value input. The output signal is the input signal delayed according to the delay value.

The DLL output is a command that controls the CDLs (plus the controlled voltage) and assures an output signal with 90-degree delay with respect to its input signal. The DLL contains five CDL blocks.

##### 10.2.4.4.11.1 Purpose of the DLL/CDL Module

In DDR applications, the DLL and CDL combination helps provide a data strobe (DQS) with a delay suitable to the main read and write RAM operations that exceed 83 MHz. The DLL functions within a locking range of 83 to 200 MHz. Below 83 MHz, the DLL must be used in unlocked mode. For lower clock frequencies, set the DLL to bypass mode.

DLL/CDL is used to delay the incoming DQS in case of DDR read, or delay the output DQ (data lines) in case of DDR write (and, hence, to increase the ac timing margin). DQS is used only with DDR memory. There is no need to use the DLL/CDL for the SDR DRAM because data is strobed every clock cycle. The DQS signals are left unconnected for SDR SDRAM memories.

DQS is propagated with the data (thus reducing the impact of the propagation delay) and is used by the receiver to sample the data.

The DLL/CDL combination minimizes the negative effects caused by skews and jitters of clock signals. The delay introduced by the CDL base unit depends on PVT conditions. Moreover, the CDL timing delay is not a linear function of the DLL counter offset. By means of the DLL feedback loop, the delay value is updated in real time and is adjusted according to voltage and temperature variations.

DDR interfaces transmit data on both edges of the DQS bidirectional data strobe. Address and control signals transmit at half the data frequency (that is, at the DDR clock frequency) and latch only on the rising edge of the transmit clock.

The bidirectional data strobe (DQS) is transmitted externally, along with data, for use in data capture at the receiver. `sdrc_dqs[3:0]` is an SDRC I/O that connects the SDRC with DDR SDRAM DQS pins. See [Figure 10-43](#) for an overview of DDR SDRAM connection with the SDRC. DQS is transmitted by the DDR SDRAM during reads and by the SDRC during writes. DQS is edge-aligned with data for reads and center-aligned with data for writes, as shown in [Figure 10-57](#).

[Figure 10-57](#) shows the generic DDR data-write and data-read waveforms.

**Figure 10-57. Generic DDR Data-Write and Data-Read Waveforms**

sdrc-014

Figure 10-58 shows the DDR SDRAM data and data strobe DQS signals exiting synchronously and in phase during a data read. DQS signals are used to sample incoming data internally and, hence, must be delayed to create data-setup and data-hold time at the synchronization flip-flop inputs, as shown in the bottom waveform of Figure 10-58. This is the goal of the DLL/CDL module.

**Figure 10-58. Required Synchronization DFF Input Signals**

sdrc-015

#### 10.2.4.4.11.2 DLL/CDL Module Architecture

Figure 10-59 shows how the DLL/CDL interacts with the synchronization flip-flops. See Table 10-102 for more information on device pins and SDRC data-lane configurations regarding DQS.

**Figure 10-59. DLL/CDL Architecture**



sdrc-016

Figure 10-60 shows a simplified block diagram of the DLL/CDL module.

**Figure 10-60. Simplified DLL/CDL Block Diagram**

sdrc-017

The DLL circuit contains four delay elements in series. Therefore, the DLL output code and regulator output voltage determine a delay equivalent to one fourth of the reference input period in a stand-alone DLL/CDL (those CDLs are delay elements integrated into the DLL and are not shown in Figure 10-59). In other words, the DLL/CDL delay is equivalent to 90 degrees without DLL/DCDL.

#### 10.2.4.5 Mode Registers

##### 10.2.4.5.1 Mode Register (MR)

This register is common to all SDR and DDR SDRAMs. It is a 12-bit register and controls the following parameters:

- Write burst mode (SDRC.**SDRC\_MR\_p[9]** WBST bit (where p = 0 or 1 for SDRC CS0 or CS1)
- CAS latency (SDRC.**SDRC\_MR\_p[6:4]** CASL field)
- Serial/interleaved mode (SDRC.**SDRC\_MR\_p[3]** SIL bit)
- Burst length (SDRC.**SDRC\_MR\_p[2:0]** BL field)

MR is accessible through SDRC.**SDRC\_MR\_p** (where p = 0 or 1 for SDRC CS0 or CS1). Writing to SDRC.**SDRC\_MR\_p** initiates an implicit load mode register command qualified by BA1, BA0 = 0, 0.

##### 10.2.4.5.2 Extended Mode Register 2 (EMR2)

This register is specific to low-power SDR and mobile DDR SDRAM devices. It is a 12-bit register and controls the following parameters:

- Temperature-compensated self-refresh (SDRC.**SDRC\_EMR2\_p[4:3]** TCSR field)
- Partial array self-refresh (SDRC.**SDRC\_EMR2\_p[2:0]** PASR field)

EMR2 is accessible through SDRC.**SDRC\_EMR2\_p** (where p stands for CS0 or CS1). Writing to SDRC.**SDRC\_EMR2\_p** initiates an implicit load mode register command qualified by BA1, BA0 = 1, 0.

**NOTE: PASR Setting Before Entering Self-Refresh Mode:**

Partial array self-refresh (PASR) allows memory accesses to all banks when the attached memory is not in self-refresh. Software must ensure that after a self-refresh mode with PASR field enabled on banks, only accesses to the refreshed parts of the memory are performed. Failure to do so may result in fetching corrupted data.

## 10.2.5 SDRC Subsystem Basic Programming Model

This section contains programming guides on setting up the SMS and SDRC registers according to the required application.

### 10.2.5.1 SMS Basic Programming Model

#### 10.2.5.1.1 SMS Firewall Usage

Because region 0 always has level 0 priority, it can be masked by any protected region.

To configure a region:

1. Set the SMS.[SMS\\_RG\\_ATTi](#) register (where i is the region index from 0 to 7).
2. Set the SMS.[SMS\\_RG\\_RDPERMi](#) register.
3. Set the SMS.[SMS\\_RG\\_WRPERMi](#) register.
4. Set the SMS.[SMS\\_RG\\_STARTj](#) register (except for region 0. j is the region index from 1 to 7).
5. Set the SMS.[SMS\\_RG\\_ENDj](#) register (except for region 0. j is the region index from 1 to 7).

Region 0 is always active. There are no start and an end address for region 0. As soon as the SMS.[SMS\\_RG\\_STARTj\[30:16\]](#) STARTADDRESS and SMS.[SMS\\_RG\\_ENDj\[30:16\]](#) ENDADDRESS registers (where j = 1 to 7) are programmed, the firewall is activated. To prevent unexpected violations, ensure that the protection regions do not overlap.

Region 1 ensures the proper dynamic programming of protection for regions 2 through 7. For example, the protected region A is set and currently accessed, but it must be enlarged. To avoid deactivating region A and exposing its content to unwanted leakage, region 1 can be used to mask this whole area during reprogramming. When region A is correctly reprogrammed, region 1 can be deactivated.

When all the required regions are programmed, the locking mechanism allows freezing the configuration, thus ensuring no further reprogramming.

#### 10.2.5.1.2 VRFB Context Configuration

Using the RE requires several initialization programming steps. After an RE context is set up, an application can use it transparently, as if addressing a frame buffer object with a standard raster-based memory arrangement.

1. Define the page configuration. This operation usually depends only on the external memory device. The same page settings are then applied to any newly created rotated frame buffer.  
Consider an SDRAM device with 1024-byte pages. The page can be defined as a 16 \* 64 array. The page is not necessarily a square (32 \* 32 is also a suitable value). It is recommended that the longest side corresponds to the access direction requiring the maximum bandwidth.

In terms of register settings, in any context that uses that page size:

Page (page) width =  $2^{pw}$  bytes (that is, pw = 6)

Page (page) height =  $2^{ph}$  rows (that is, ph = 4)

2. The application must allocate the appropriate amount of memory in the SDRAM address space, as required by the size of the frame buffer object.

*Example: Create a 400 x 300 frame buffer, 16 bits per pixel*

- Pixel size =  $2^{ps}$  bytes (that is ps = 1)
- Number of pages per line:  $400 * 2/64 = 12.5$ , rounded up to 13
- Number of pages per column:  $300/16 = 18.75$ , rounded up to 19

In terms of register settings, the image size parameters correspond to the enlarged image, and are programmed to:

- Image width = w pixels (that is,  $w = 13 * 64 / 2 = 416$ )
- Image height = h pixels (that is,  $h = 19 * 16 = 304$ )

---

**NOTE:** In this example, the values obtained are not integer values, but are rounded up to the closest integer value. This results in a loss of physical memory, generally negligible compared to the total size of the image.

---

In terms of memory allocation (in the physical memory), this corresponds to a  $416 * 304 * 2 = 252,928$ -byte buffer.

The physical base address of this buffer must be aligned on a page boundary (in that example, a 1024-byte boundary; that is, the 10 LSBs of the base address must be all zeros). This buffer must be allocated as a contiguous memory segment.

All these parameters, once determined, must be loaded in the registers of the chosen context (there are 12 VRFB contexts with 12 independent sets of registers).

*Example, context 1:*

- Configure the physical base address of the frame buffer. Example: 512M bytes, start of CS0, SMS.[SMS\\_ROT\\_PHYSICAL\\_BAn](#)[30:0] PHYSICALBA = 0x20000000 (where n = 1)
  - Configure the image height and width:  
Image width (416): SMS.[SMS\\_ROT\\_SIZEn](#)[10:0] IMAGEWIDTH = 0x1A0 (where n = 1)  
Image height (304): SMS.[SMS\\_ROT\\_SIZEn](#)[26:16] IMAGEHEIGHT = 0x130
  - Configure the control parameters:  
Pixel size (example: 2 bytes,  $2^1$  bytes): SMS.[SMS\\_ROT\\_CONTROLn](#)[1:0] PS = 0x1 (where n = 1)  
Page (page) size (example: 1024 bytes = 64 bytes \* 16 bytes)  
Page height (example: 16 rows,  $2^4$  rows): SMS.[SMS\\_ROT\\_CONTROLn](#)[10:8] PH = 0x4  
Page width (example: 64 bytes,  $2^6$  bytes): SMS.[SMS\\_ROT\\_CONTROLn](#)[6:4] PW = 0x6
3. The frame buffer just created is now ready for use by the different system initiators (MPU, sDMA, DSS controller, etc.).

From the perspective of these modules, the frame buffer object can be accessed at the following VRFB address-space memory locations:

- Context 1 0-degree view: 0x7400 0000
- Context 1 90-degree view: 0x7500 0000
- Context 1 180-degree view: 0x7600 0000
- Context 1 270-degree view: 0x7700 0000

The start address of the view corresponds to the logical origin of the image ( $x = 0, y = 0$ ). The image pitch parameter, commonly defined as the distance between two vertically adjacent pixels, is fixed to 2048 pixels.

*Example of usage by the application:*

In a system using an 400 \* 300 LCD panel that has a native landscape orientation, the natural scan order is as shown in [Figure 10-61](#).

**Figure 10-61. Natural Scan Order**

sdrc-018

The display buffer is the one created in the example sequence.

When the application is running and uses the portrait orientation for the display (typically, a PDA-type application):

- The DSS controller accesses the frame buffer using the 0-degree view.
- The processor and other initiators, such as 2D DMA or 3D accelerators, use the 90-degree view.

When the application is running and uses the landscape orientation for the display (typically, a video recorder/player or gaming application):

- The DSS controller still accesses the frame buffer using the 0-degree view.
- The processor and other initiators, such as 2D DMA or 3D accelerators, also use the 0-degree view. See [Section 10.2.6.1.1](#).

#### 10.2.5.1.3 Memory-Access Scheduler Configuration

The memory-access scheduler is configured as follows:

- For each of the three classes, the arbitration parameters are:
  - SMS.[SMS\\_CLASS\\_ARBITER0](#) through SMS.[SMS\\_CLASS\\_ARBITER2](#)
    - One high-priority FIFO queue in the class (HIGHPRIVECTOR field)
    - Number of consecutive transactions to perform (EXTENDEDGRANT field)
    - Burst transaction submitted for arbitration immediately or after the burst has been buffered (BURST-COMPLETE field)

#### 10.2.5.1.4 Error Logging

All data transfers in the SMS are full handshake. The SMS uses this capability to signal the system when a transaction error is detected.

The SMS captures the address of the faulty access in the SMS.[SMS\\_ERR\\_ADDR](#) register. The error type is logged in the SMS.[SMS\\_ERR\\_TYPE](#) register. Once a faulty access is logged and the SMS.[SMS\\_ERR\\_TYPE\[0\]](#) ERRORVALID bit is set, the next faulty accesses cannot be logged before clearing the ERRORVALID bit.

In the case of an interconnect transaction, an error response is generated if any of the following occur:

- An incoming request arrives after an idle request from the PRCM.
- An illegal command is received.
- A protection region overlap is detected.
- Protection errors.

It is assumed that the system interconnect on which the SMS is plugged is responsible for signaling the error event to the host MPU based on the interconnect response. The MPU error handler can then consult the error logging registers.

### 10.2.5.2 SDRC Configuration

#### 10.2.5.2.1 IP Revision

The IP revision code can be read in the SDRC.[SDRC\\_REVISION\[7:0\]](#) REV field.

#### 10.2.5.2.2 Reset Behavior

The reset behavior of the SDRC can be classified into three subgroups:

- Asynchronous cold-reset (power-on reset) behavior
- Asynchronous warm reset behavior
- Synchronous soft-reset behavior

When the system-wide power-on reset is applied through cold reset, all flops are reset to their default values, and all state-machines are returned to their idle states.

The programming model for data recovery following a warm reset is as follows:

- Program the SDRC.[SDRC\\_POWER\\_REG](#) register to enable the SDRC.[SDRC\\_POWER\\_REG\[7\]](#) SRFRONRESET bit.

A warm reset condition is then issued.

- The SDRC enters self-refresh mode since the SRFRONRESET bit is set.
- The SDRC does not execute global SDRC reset since the reset is not qualified as cold.
- The SDRC state-machine maintains the external memory device in self-refresh.

The first SDRC access to the configuration register must then be:

1. Check the SDRC configuration.
2. Exit self-refresh mode using the manual command register.

A software-controlled reset is also available by using the SDRC.[SDRC\\_SYSConfig\[1\]](#) SOFTRESET bit (set this bit to 1 to activate the reset). The completion of the reset can be determined by reading the SDRC.[SDRC\\_SYSSTATUS\[0\]](#) RESETDONE bit.

When the SDRC is reset due to the presence of either a soft or cold reset, all SDRC flops are reset.

**NOTE: SDRC Requirement at First Power-Up to Have sdrc\_cke Pin High**

To comply with the JEDEC standard, sdrc\_cke pins values are forced to 1 during the initial memory power-up phase: software must ensure that sdrc\_cke pin is released after the initialization phase; it happens only at first power-up (on a cold reset). Thus, at the end of the initial SDRC power-up sequence and before programing the PWDENA field, software must ensure that the sdrc\_cke pin is driven by the SDRC module. Then the value of the PWDENA field can be modified. See [Section 10.2.5.4.1](#) for more details on sdrc\_cke driving.

**NOTE: Set the INPUTENABLE0 bit of CONTROL.CONTROL\_PADCONF\_SDRC\_CLK to assure the synchronization of sdrc\_clk. For more information, see [Chapter 13, System Control Module](#).**

### 10.2.5.3 SDRC Setup

A number of device parameters must be set before executing the initialization sequence.

### 10.2.5.3.1 Chip-Select Configuration

CS0 always starts at 0x8000 0000 (with respect to the 32-bit interconnect address). There is no restriction on the presence of any SDRAM on CS0 or CS1.

The total address space of the SDRC is 1G byte/8G bits. The total address space is divided into 8 \* 128M-byte partitions as shown in [Figure 10-51](#). Each partition is a possible start address for CS1, except for the partition occupied by CS0.

The start address for CS1 is defined by the SDRC.[SDRC\\_CS\\_CFG\[9:8\]](#) CS1STARTLOW and SDRC.[SDRC\\_CS\\_CFG\[3:0\]](#) CS1STARTHIGH fields.

Space 0, selected by the SDRC using the CS0 (nCS0) output pin, is always at offset 0 from the SDRAM memory space base address. The size of this area is programmable through the SDRC.[SDRC\\_MCFG\\_p\[17:8\]](#) RAMSIZE field, where p = 0. Space 1, selected by the SDRC using the CS1 (nCS1) output pin, is at an offset from the SDRAM memory space base address; this offset is programmable in 128M-byte increments. The size of this area is programmable through the SDRC.[SDRC\\_MCFG\\_p\[17:8\]](#) RAMSIZE field, where p = 1. The type of device for each area is programmable through the SDRC.[SDRC\\_MCFG\\_p](#) register (where p = 0 or 1 for SDRC CS0 or CS1).

---

**NOTE:** Ensure that space 0 and space 1 do not overlap each other or extend farther than the maximum 1G-byte SDRC memory space, as explained in [Section 2.2, Global Memory Space Mapping](#), of [Chapter 2, Memory Mapping](#).

---

### 10.2.5.3.2 Memory Configuration

The memory configuration is defined on a per-CS basis through the SDRC.[SDRC\\_MCFG\\_p](#) register (where p = 0 or 1 for SDRC CS0 or CS1).

[Table 10-104](#) lists the memory configuration.

**Table 10-104. Memory Configuration**

| Bit Field     | Comments                                                                                                                                |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| ADDRMUXLEGACY | Address multiplexing scheme                                                                                                             |
| RAMSIZE       | Defines the physical RAM address space in terms of 2M -byte chunks                                                                      |
| B32NOT16      | External device data bus width.                                                                                                         |
| DEEPPD        | Set this bit if the memory supports deep-power-down mode. (This bit is only a flag for software. It does not affect any SDRC function.) |
| DDRTYPE       | Mobile DDR                                                                                                                              |
| RAMTYPE       | Single Data Rate or Double Data Rate SDRAM                                                                                              |

---

**NOTE: Exported Register Reset Values and Lock Bit**

The reset values of SDRC.[SDRC\\_MCFG\\_p](#) and SDRC.[SDRC\\_SHARING](#) are exported in the control module. At reset, these registers take the value previously stored in the control module. A new bit is added to each register to provide the capability to lock these three registers into read-only accesses:

- SDRC.[SDRC\\_MCFG\\_p\[30\]](#) LOCKSTATUS bit (p = 0 or 1 for CS0 or CS1)
- SDRC.[SDRC\\_SHARING\[30\]](#) LOCK bit

The reset value of each lock bit is also imported from the control module.

---

### 10.2.5.3.3 SDRAM AC Timing Parameters

The AC parameters described in [Table 10-105](#) can be independently programmed (standard JEDEC LPDDR1 terminology is used here) in clock cycles for each of the two memory areas through registers SDRC.[SDRC\\_ACTIM\\_CTRLA\\_p](#) and SDRC.[SDRC\\_ACTIM\\_CTRLB\\_p](#) (p = 0 or 1, depending on the CS area).

**Table 10-105. Programmable AC Parameters**

| SDRC<br>AC Parameter | Description                                                                   | Range<br>(Clock Ticks) |
|----------------------|-------------------------------------------------------------------------------|------------------------|
| tRFC                 | AUTO REFRESH to ACTIVE / AUTO REFRESH command period (autoReFresh Cycle time) | 0 - 31                 |
| tRC                  | ACTIVE to ACTIVE command period (Row Cycle time)                              | 0 - 31                 |
| tRAS                 | ACTIVE to PRECHARGE command period                                            | 0 - 15                 |
| tRP                  | PRECHARGE command period (Row Precharge time)                                 | 0 - 7                  |
| tRCD                 | ACTIVE to READ or WRITE delay (Row-to-Column Delay time)                      | 0 - 7                  |
| tRRD                 | ACTIVE bank A to ACTIVE bank B delay                                          | 0 - 7                  |
| tWR                  | WRITE Recovery time (also known as tDPL)                                      | 0 - 7                  |
| tDAL                 | Auto precharge write recovery + precharge time                                | 0 - 31                 |
| tWTR                 | Internal Write to Read command delay (also known as tCDLR)                    | 1 - 3                  |
| tCKE                 | CKE min pulse width (high and low pulse width)                                | 1 - 7                  |
| tXP                  | Exit Power-Down to next valid command delay                                   | 1 - 7                  |
| tXSR                 | Self-Refresh exit to next valid command delay                                 | 0 - 255                |

Example of configuration:

If there is a minimum tRC requirement of 88 ns at 100 MHz,  $88/10 = 9$  (8.8 is rounded up). Therefore, nine clock cycles must be set.

The SDRC AC parameters described in [Table 10-106](#) are hard-coded.

**Table 10-106. Nonprogrammable AC Parameters**

| SDRC<br>AC Parameter | Description                                    | Range<br>(Clock Ticks) | Comment                                                                                 |
|----------------------|------------------------------------------------|------------------------|-----------------------------------------------------------------------------------------|
| tMRD                 | MODE REGISTER SET command period               | 3                      |                                                                                         |
| tDQSS                | Write command to first DQS latching transition | 1 (0.75 - 1.25 CK)     |                                                                                         |
| tRPRE                | Read preamble                                  | 1 (0.9 - 1.1 CK)       | DQS is held low for read when driving on the same cycle as the read command is stopped. |

---

**NOTE:** The SDRC uses tXSR only when exiting self-refresh mode, regardless of the first command issued. The SDRC systematically inserts an autorefresh command before it serves the first request.

---

#### 10.2.5.3.4 DLL/CDL Configuration

The DLL unit is configured by writing to the SDRC.[SDRC\\_DLL\\_A\\_CTRL](#) register. This register contains the following fields:

- FIXEDDELAY
- MODEFIXEDDELAYINITLAT
- DLLMODEONIDLEREQ
- DLLIDLE
- ENADLL
- LOCKDLL

To support low-frequency DDR access, set the DLL in fixed delay mode by setting the [SDRC\\_DLLA\\_CTRL](#) [2] LOCKDLL bit to 0x1. In this mode, the [SDRC\\_DLLA\\_CTRL](#) [31:24] FIXEDDELAY field allows the programming of the CDL delay. This provides the correct fixed DCB code based on the input frequency. Only the voltage precharge part of the DLL is still used to control the CDL instances in this mode, but the control loop is broken and the voltage control is inactive.

When fixed delay mode is enabled, a counter (programmable through the [SDRC\\_DLLA\\_CTRL](#) [23:16] MODEFIXEDDELAYINITLAT field) based on the input frequency allows the SDRC to stall all incoming requests. Once this counter expires, the SDRC starts accessing the memory. The DLL characterization shows that this feature is not useful and that this value shall be set to 0x0, leading actually to a null delay.

The DLL can be put in idle mode using the [SDRC\\_DLLA\\_CTRL](#)[4] DLLIDLE bit. When in idle mode, the DLL lock is lost. The precharge voltage is kept stable to enable faster relock when going back to a functional state. If set, this bit overrides the ENADLL bit. Thus, avoid completely powering down the DLL by keeping the precharge voltage and cutting off the analog loop. Exiting from this idle mode saves some clock cycles compared to exiting from power-down mode. Refer to the note (DLL behavior upon a warm reset assertion) in [Section 10.2.4.4.9.2, Dynamic Low-Power Operating Modes](#). Furthermore, the [SDRC\\_DLLA\\_CTRL](#)[6:5] DLLMODEONIDLEREQ field defines the modes (power-down/DLLIDLE/No action) of the DLL that are automatically entered upon an Idle\_req assertion. The DLL mode (TrackedDelay or ModeFixedDelay mode) is updated only when Idle\_req/Idle\_ack handshake protocol occurs, warm reset occurs, PWRDN is enabled, or DLLIDLE mode enabled. Power-down mode is asserted upon warm reset assertion. If power-down and DLLIDLE are asserted simultaneously, power-down overwrites DLLIDLE mode inside the DLLCDL cell.

To modify the SDRC input clock when the DLL is locked and active, the DLL must first enter either its idle mode or its power-down mode. The SDRC input frequency can be changed by using any of the following scenarios:

- Internal signals handshaking protocol with PRCM module
- Warm reset event
- DLLIDLE mode
- Power-down mode

The ENADLL bit controls the PWRDN mode of the DLL module.

The LOCKDLL bit sets the DLL in TrackedDelay (lock) or ModeFixedDelay (unlock) mode. ModeFixedDelay mode is supported up to 83 MHz.

See [Section 10.2.4.4.11](#) for more information on the CDL/DLL module.

DLLMODEONIDLEREQ is of no importance to the Idle\_ack generation. In case DLLMODEONIDLEREQ = 2 and Idle\_req occurs, Idle\_ack can be generated and SDRC/core can go to idle; however, recovery from this state may be incorrectly performed and the DLL cannot relock. If this happens, the only solution to recover is to disable and then re-enable the DLL. DLLMODEONIDLEREQ = 2 is not a valid configuration under Idle\_req assertion and must not be used. DLLMODEONIDLEREQ can be set 0 or 1, depending on whether the priority is shorter wake-up latency or lower power consumption.

### 10.2.5.3.5 Mode Register Programming and Modes of Operation

The SDRC contains a group of registers known as the memory mode registers. These registers define the operational modes of the target SDRAM.

- MR: Mode register used to define operational parameters common to SDR and DDR SDRAMs.
- EMR1: Extended mode used to define operational parameters exclusive to DDR SDRAM (irrelevant to the SDRC since regular DDRs are not supported).
- EMR2: Extended mode used to define operational parameters exclusive to mobile SDRAM.

#### 10.2.5.3.5.1 Mode Register (MR)

The 12-bit SDRC.[SDRC\\_MR\\_p](#) register ( $p = 0$  or  $1$  for CS0 or CS1) is common to all SDR and DDR SDRAMs and controls the following parameters:

- Write burst mode

- CAS latency
- Serial/interleaved mode
- Burst length

When programming the SDRC.[SDRC\\_MR\\_p](#) bit fields (where p = 0 or 1 for SDRC CS0 or CS1), consider the following:

- CAS latencies of 1, 2, 3, 4, and 5 are supported (CASL).
- Only serial mode (not interleaved mode) is supported (SIL = 0x0).
- A burst length of 2 is supported for SDR SDRAM (BL = 0x2).
- A burst length of 4 is supported for DDR SDRAM (BL = 0x4).
- Burst lengths of 1 (BL = 0x0), 8 (BL = 0x3), and full page (BL = 0x7) are not supported.

Writing to SDRC.[SDRC\\_MR\\_p](#) initiates an implicit Load Mode register command qualified by BA1,BA0 = 0,0 except if the NOMEMORYMRS bit is set.

#### **10.2.5.3.5.2 Extended Mode Register 2 (EMR2)**

The SDRC.[SDRC\\_EMR2\\_p](#) register (p = 0 or 1 for CS0 or CS1) is specific to mobile SDRAM devices. It is a 12-bit register that controls the following standard parameters:

- Partial Array Self-Refresh (PASR)
- Temperature Compensated Self-Refresh (TCSR)
- Driver Strength (DS)

The SDRC.[SDRC\\_EMR2\\_p](#)[2:0] PASR field programs the partial array self-refresh feature. The low power SDR SDRAM granularity is much finer than the granularity available in a mobile DDR SDRAM. The SDRC.[SDRC\\_EMR2\\_p](#)[4:3] TCSR field programs the temperature compensated self-refresh feature. The TCSR granularity available in a low power SDR is much finer than the granularity available in a mobile DDR.

Writing to SDRC.[SDRC\\_EMR2\\_p](#) initiates an implicit load mode register command qualified by BA1, BA0 = 1,0 except if [SDRC\\_SYS CONFIG](#)[8] NOMEMORYMRS is set.

#### **10.2.5.3.6 Autorefresh Management**

The SDRAM refresh configuration register group controls refresh management in normal operation. This group contains two SDRC.[SDRC\\_RFR\\_CTRL\\_p](#) registers that are defined on a per-CS basis and contain the following bit fields:

- SDRC.[SDRC\\_RFR\\_CTRL\\_p](#)[1:0] ARE (where p = SDRC CS value 0 or 1)
- SDRC.[SDRC\\_RFR\\_CTRL\\_p](#)[23:8] ARCV (where p = SDRC CS value 0 or 1)

These bit fields can enable and disable autorefresh. Autorefresh bursts of 1, 4, and 8 are programmed using these fields. The autorefresh burst starts when the 16-bit autorefresh counter decrements to 0. The ARCV field loads the autorefresh counter with a 16-bit autorefresh value. The ARCV value is calculated using the following formula:

$$\text{Refresh value} = (\text{refresh interval} / \text{clock period} / \text{number of rows}) - \text{margin}$$

**Note:** Memory refresh interval in time unit. Margin is 50 (cycles).

The margin considers the possibility of an ongoing access when the counter expires, thus delaying the effective refresh sequence.

The value to be programmed is independent of the burst-refresh configuration: if a burst-refresh is configured, the value is automatically scaled in hardware to the burst-refresh size.

Autorefresh is enabled by programming the SDRC.[SDRC\\_MANUAL\\_p](#)[3:0] CMDCODE field to 0x2 (where p = 0 or 1 for SDRC CS0 or CS1).

#### **10.2.5.3.7 Page Closure Strategy**

The page closure strategy is defined on a per-bank basis by setting the SDRC.[SDRC\\_POWER\\_REG\[0\]](#)PAGEPOLICY bit. SDRC defines one type of page closure strategy:

1. High power/high bandwidth: Bandwidth consumption is critical.

The SDRC tracks open pages. The SDRC determines whether the current access is an open page or a closed page. The SDRC does the following:

1. If the current page is already open on this bank the SDRC automatically issues a *precharge* command to close that bank.
2. Opens the accessed page
3. Executes the access

In the worst case, four pages (one page per bank) may be opened simultaneously.

The PAGEPOLICY bit must be set to 1 to enable this mode.

#### **10.2.5.4 Manual Software Commands**

The manual commands register SDRC.[SDRC\\_MANUAL\\_p](#) (where p = 0 or 1 for SDRC CS0 or CS1) is used to implement software-driven commands:

- NOP command
- Precharge All command
- Autorefresh command
- Enter deep-power-down command
- Exit deep-power-down command
- Enter self-refresh command
- Exit self-refresh command
- Set CKE high command
- Set CKE low command

These commands are described in the following section:

- NOP (CMDCODE: 0x0)

When the SDRC.[SDRC\\_MANUAL\\_p\[3:0\]](#) CMDCODE field is programmed with 0x0, the SDRC issues a NOP/inhibit command. The following table lists the status of the SDRC memory port signals.

NOP does not initiate any new operation, but it is needed to complete operations that require more than a single clock cycle-like autorefresh.

Inhibit is also a NOP. nCS high disables the command decoder so that nRAS, nCAS, nWE, and all the address inputs are ignored.

| Command | nCS | nRAS | nCAS | nWE |
|---------|-----|------|------|-----|
| Inhibit | H   | X    | X    | X   |
| NOP     | 0   | H    | H    | H   |

- Precharge all (CMDCODE: 0x1)

When the SDRC.[SDRC\\_MANUAL\\_p\[3:0\]](#) CMDCODE field is programmed with 0x1, the SDRC issues a precharge all command. The following table lists the status of the SDRC memory port signals.

During the command, address A10 remains high, and bank information (BA0 and BA1) is don't care.

All banks can be precharged at the same time by using the precharge all command.

At the end of tRP, after performing precharge on all of the banks, they enter the idle state.

| Command       | A10 | nCS | nRAS | nCAS | nWE |
|---------------|-----|-----|------|------|-----|
| Precharge all | H   | L   | L    | H    | L   |

- Autorefresh (CMDCODE: 0x2)

When the SDRC.[SDRC\\_MANUAL\\_p\[3:0\]](#) CMDCODE field is programmed with 0x2, the SDRC issues an autorefresh command. The following table lists the status of the SDRC memory port signals.

In addition to the signal status mentioned below, the CKE signal is at logic high for autorefresh.

The autorefresh command can only be asserted when all banks are in idle state and the device is not in power-down mode (CKE is high in the previous cycle).

The autorefresh command must be followed by NOPs until the autorefresh operation completes.

All banks are in the idle state at the end of the autorefresh operation.

| Command     | nCS | nRAS | nCAS | nWE |
|-------------|-----|------|------|-----|
| Autorefresh | L   | L    | L    | H   |

- Enter deep-power-down (CMDCODE: 0x3)

When the SDRC.[SDRC\\_MANUAL\\_p\[3:0\]](#) CMDCODE field is programmed with 0x3, the SDRC executes an enter DPDM command. This command is used for low-power devices (that is, LPSDR or MDDR devices that support deep-power-down mode). The following table shows the status of the SDRC memory port signals.

The device enters deep-power-down mode by having nCS and nWE held at logic low with nRAS and nCAS high at the rising edge of the clock, while CKE is low.

| Command    | nCS | nRAS | nCAS | nWE | CKE |
|------------|-----|------|------|-----|-----|
| Enter DPDM | L   | H    | H    | L   | L   |

- Exit deep-power-down command (CMDCODE: 0x4)

When the SDRC.[SDRC\\_MANUAL\\_p\[3:0\]](#) CMDCODE field is programmed with 0x4, the SDRC executes an exit deep-power-down command. The device exits deep-power-down mode when the inhibit command is sampled with CKE held at logic high.

- Enter self-refresh (CMDCODE: 0x5)

When the SDRC.[SDRC\\_MANUAL\\_p\[3:0\]](#) CMDCODE field is programmed with 0x5, the SDRC puts the memory into self-refresh. The signal status is the same as defined in autorefresh, and CKE is held at logic low during the self-refresh entry command.

The self-refresh mode is entered from the all-banks-idle state by asserting nCS, nRAS, nCAS, and CKE low, and nWE high.

Once the self-refresh mode is entered, only the CKE state being low matters; all other inputs, including the clock, are ignored and remain in self-refresh mode.

- Exit self-refresh (CMDCODE: 0x6)

When the SDRC.[SDRC\\_MANUAL\\_p\[3:0\]](#) CMDCODE field is programmed with 0x6, the SDRC executes the self-refresh exit command and, after meeting the tXSR timing parameter, executes one autorefresh command to adhere to the memory protocol. It is an exit self-refresh command when CKE is detected high with a NOP command.

Self-refresh is exited by restarting the external clock and then asserting CKE high. This must be followed by NOPs for a minimum time of tXSR before the SDRAM reaches idle state to begin normal operation.

- Set the CKE signal high (CMDCODE: 0x7)

When the SDRC.[SDRC\\_MANUAL\\_p\[3:0\]](#) CMDCODE field is programmed with 0x7, CKE is set to high. An example of where this command is used is during DDR memory initialization.

- Set the CKE signal low (CMDCODE: 0x8)

When the SDRC.[SDRC\\_MANUAL\\_p\[3:0\]](#) CMDCODE field is programmed with 0x8, CKE is set to low. An example of where this command can be used is to put memory in power-down mode.

#### 10.2.5.4.1 Low-Power SDR/Mobile DDR Initialization Sequence

The initialization sequence is executed after the following occur:

1. Power is applied.
2. The clock is stable.
3. The power-on reset sequence is executed.

The initialization sequence is executed by programming the following manual command registers, in the SDRC.[SDRC\\_MANUAL\\_p\[3:0\]](#) CMDCODE bit field, on a per-CS basis:

1. Set CMDCODE to 0x0 (NOP command), for a minimum delay of 200  $\mu$ s. Another way to stabilize the connected device internal circuits is to deactivate the corresponding CS for the same amount of time.

#### CAUTION

Programmers must ensure that the next command (precharge-all command) is sent after a minimum delay of 200  $\mu$ s. Other timings, such as tRP timing between the precharge-all command and autorefresh command, are handled automatically by the SDRC depending on the timing values programmed in the appropriate registers.

2. Set CMDCODE to 0x1 (precharge all command) to precharge all banks.
3. Set CMDCODE to 0x2 (autorefresh command). The autorefresh command is automatically generated after a time of tRP, hence [SDRC\\_ACTIM\\_CTRLA\\_p\[17:15\]](#) TRP (where p = 0 or 1, for CS0 or CS1) must be programmed as stated in the external memory datasheet.
4. A second autorefresh command must be programmed. Set CMDCODE to 0x2 another time.
5. Then configure the mode register [SDRC\\_MR\\_p](#) (p = 0 or 1) with BA0 and BA1 set to 0.

Because the mode register powers up in an unknown state, it must be loaded before applying any operational command.

When MR is reprogrammed, a suitable time must elapse before an active command is issued. The hardware ensures this by fixing tMRD to two clock cycles. The SDRC can handle CKE as force on CKE is released through the control module.

After VDD initialization sdrc\_cke0 and sdrc\_cke1 signals are forced outside the SDRC subsystem by the control module. When the external SDRAM device is correctly initialized the control module must release the force on these sdrc\_cke signals by clearing the corresponding MUXMODE bit fields in CONTROL.CONTROL\_PADCONF\_SAD2D\_SBUSFLAG[18:16] and CONTROL.CONTROL\_PADCONF\_SDRC\_CKE1[2:0] bit fields for sdrc\_cke0 and sdrc\_cke1 respectively. See [Section 10.2.5.2.2](#) for more information on reset behavior.

#### 10.2.5.4.2 Read/Write Access

The commands required for a normal read/write access are automatically generated as a function of the following:

- The read/write command
- The address bus. A10 defines precharge all
- The relevant [SDRC\\_MR\\_p](#) / [SDRC\\_EMR2\\_p](#) registers

#### 10.2.5.4.3 Memory Power Management

##### 10.2.5.4.3.1 Clock Enable Management

The SDRC supports two autonomous clock enable pins CKE0 and CKE1. Each CS (CS0 or CS1) has its own CKE signal. Power management of the CS0 memory is controlled by CKE0. Power management of the CS1 memory is controlled by CKE1. This allows the SDRAM memories associated with CS0 or CS1 to be independently placed in power-down, deep-power-down (DPD) or self-refresh (SR) mode. This is achieved using the manual control register SDRC.[SDRC\\_MANUAL\\_p\[3:0\]](#) CMDCODE field which is defined on a per chip select basis. Entry and exit of these low-power modes is achieved using the relevant CMDCODE.

Once the memory associated with a CS has been powered down in deep-power-down mode it cannot be powered up by dynamic power management features. It can only exit the low-power state through the programming of the relevant CMDCODE. The SDRC can automatically exit other low-power modes.

#### **10.2.5.4.3.2 Clock-Controlled Memory Power Management**

The SDRC power-management register (SDRC.[SDRC\\_POWER\\_REG](#)) contains the EXTCLKDIS field, which controls suspension of the external clock on a per-CS basis. Writing 1 to this field in the relevant register freezes the clock with a latency dependent on the SDRC.[SDRC\\_POWER\\_REG](#) register programming. Subsequently, writing 0 to this field in the relevant register enables the clock with a latency dependent on the SDRC.[SDRC\\_POWER\\_REG](#) register programming.

#### **10.2.5.4.3.3 Manual Power-Down Mode Power Management**

For dynamic power-down mode refer to [Section 10.2.4.4.9.2, Power-Saving Features](#). The programming model for manual power-down mode is different for an SDR and a DDR.

##### **SDR Mechanism/Power-Down Mode Entry**

1. Ensure that no accesses are pending or active.
2. Program the CMDCODE field of the relevant manual command register to 0001.  
This ensures that all banks are idle by executing a precharge all command.
3. Wait two clock cycles.
4. Program the CMDCODE field of the relevant manual command register to 0000.  
This executes a NOP command.
5. Program the CMDCODE field of the relevant manual command register to 1000.  
This sets CKE low.
6. Maintain the clock at a stable value.

##### **SDR Mechanism/Power-Down Mode Exit**

1. Provide clock.
2. Program the CMDCODE field of the relevant manual command register to 0111.  
This sets the relevant CKE high.
3. Program the CMDCODE field of the relevant manual command register to 0000.  
This executes a NOP command.
4. Program the CMDCODE field of the relevant manual command register to 0001.  
This ensures that all banks are idle by executing a precharge.

The length of time the SDRC spends in power-down mode must not exceed the refresh period; otherwise, data becomes corrupted.

For a DDR, the sequence is as follows:

##### **DDR Mechanism/Power-Down Mode Entry**

1. Ensure that no access is currently pending or active.
2. To reduce power consumption (not mandatory): disable DLL by setting the ENADLL field of the relevant SDRC.[SDRC\\_DLLA\\_CTRL](#) register to 0x0.
3. Program the CMDCODE field of the relevant manual command register to 0001.  
This ensures that all banks are idle by executing a precharge all command.
4. Program the CMDCODE field of the relevant manual command register to 0000.  
This executes a NOP command.
5. Program the CMDCODE field of the relevant manual command register to 1000.  
This sets the relevant CKE low.
6. Maintain the clock at a stable value.

##### **DDR Mechanism/Power-Down Mode Exit**

1. Provide clock.
  2. Program the CMDCODE field of the relevant manual command register to 0111.  
This sets the relevant CKE high.
  3. Program the CMDCODE field of the relevant manual command register to 0000.  
This executes a NOP command.
  4. Program the CMDCODE field of the relevant manual command register to 0001.  
This ensures that all banks are idle by executing a precharge all command.
  5. Enable DLL by setting the ENADLL field of the relevant SDRC.[SDRC\\_DLLA\\_CTRL](#) register to 0x1.
- The amount of time the SDRC spends in power-down mode must not exceed the refresh period; otherwise, data becomes corrupted.

#### 10.2.5.4.3.4 Deep-Power-Down Mode Power Management

When in deep-power-down mode the power distribution to the entire memory array is cut. The programming model for deep-power-down mode is as follows:

##### Deep-power-down Mode Entry

- Precharge all banks (CMDCODE: 0x1). This ensures that all banks are idle.
- Enter deep-power-down mode (CMDCODE: 0x3).

##### Deep-power-down Mode Exit

- Exit deep-power-down mode (CMDCODE: 0x4).

The MR and EMR values are retained upon exiting deep-power-down mode.

---

**NOTE:** Because power-down entry/exit sequences depend on memory devices, see the memory specification for the complete sequence.

---

#### 10.2.5.4.3.5 Manual Self-Refresh Mode Power Management

The programming model for entering and exiting self-refresh mode is as follows:

##### Self-Refresh Entry

- Precharge all banks (CMDCODE: 0x1).
- NOP (CMDCODE: 0x0)
- Enter self-refresh mode (CMDCODE: 0x5).

There is no need for the software to disable the autorefresh in the SDRC.[SDRC\\_RFR\\_CTRL\\_p](#) register before entering self-refresh. The autorefresh counter is reset in hardware so that an autorefresh cycle is automatically generated immediately after a self-refresh exit, and before any other command.

##### Self-Refresh Exit

- Exit self-refresh mode (CMDCODE: 0x6).
- If needed, reconfigure SDRC registers as required.
- Enable autorefresh by programming:
  - The relevant SDRC.[SDRC\\_RFR\\_CTRL\\_p](#)[23:8] ARCV field
  - The relevant SDRC.[SDRC\\_RFR\\_CTRL\\_p](#)[1:0] ARE field to the desired refresh burst

#### 10.2.5.5 Error Management

All data transfers in the SDRC operate a system of full handshaking. A valid read or write request that is presented to the SDRC by the L3 interconnect sequencer results in the SDRC acknowledging the transfer by raising the SCmdAccept flag. Failure to do this within a defined temporal window constitutes an error. Errors can arise from the following sources:

- Any transaction while the memory is in deep-power-down mode

- An illegal initiator access. The address of the last illegal access is captured in the SDRC.[SDRC\\_ERR\\_ADDR](#) register

If an error occurs, the software error handler performs the following actions:

- Interrogates the ERRORVALID field of the SDRC.[SDRC\\_ERR\\_TYPE](#) register to verify the presence of an error
- Interrogates the ERRORDPD field of the SDRC.[SDRC\\_ERR\\_TYPE](#) register to determine whether a transaction error resulting from the device being in deep-power-down mode is present
- Interrogates the ERRORCONNID field of the SDRC.[SDRC\\_ERR\\_TYPE](#) register to determine whether a transaction error resulting from an illegal access by an interconnect initiator is present
- Interrogates the ERRORADD field of the SDRC.[SDRC\\_ERR\\_TYPE](#) register to determine whether a transaction error resulting from an illegal address is present:
  - Interconnect access to an address outside the memory space (0x0)
  - Interconnect access to an address outside the register space (0x1)
- Writes 0 to the ERRORVALID field of the SDRC.[SDRC\\_ERR\\_TYPE](#) register to clear the active error status
- Executes error recovery from software

## 10.2.6 SDRC Use Cases and Tips

### 10.2.6.1 How to Program the VRFB

#### 10.2.6.1.1 VRFB Rotation Mechanism

An inherent limitation of SDRAM technology is high-memory latency caused by page-miss penalties incurred when downloading to a memory cache. For example, switching from one page to another in external memory can cause a page-miss, indicating that the page accessed for the current pixel is different from that for the previous pixel.

A DMA engine is used to rotate pictures in external DRAM, but this rotation method increases the number of page misses.

The efficient way to rotate image data in external SDRAM is to use the VRFB module, which is an RE embedded in the SMS of the device, as shown in [Figure 10-62](#). It is configured in the SMS registers.

**Figure 10-62. SDRC Subsystem Overview**

sdrc-019

Accessing images stored in external SDRAM in a non-natural order requires an address transaction: the virtual address of an image is translated into a physical address in the corresponding buffer. Address translation causes an image to be rotated in 0-, 90-, 180-, or 270-degree views. With multiple views of the image, the RE can change addresses and issue multiple requests to the SDRC so that a maximum of consecutive accesses is performed, thus decreasing the number of page-miss penalties. The RE cannot reorder requests to the SDRAM.

A VRFB context defines the configuration used to access a picture in external SDRAM. For each VRFB context, a set of registers in the SMS describes:

- The size of the page (height and width)
- The picture parameters before rotation (width, height, and pixel format)
- The rotation angle (0-, 90-, 180-, or 270-degree)
- The physical base address in external memory

Any initiator in the device can access up to 12 images simultaneously, each image having an independent context. These 12 contexts are considered virtually addressed image buffers. Each context is assigned to a physical image buffer.

The virtual address space of each context is subdivided into four separate address regions pointing to the same physical image buffer but corresponding to the four possible rotations: 0/90/180/270.

After the VRFB context is configured, all data accesses to an address space are automatically translated when accessing SDRAM through the RE.

#### 10.2.6.1.2 Setting a VRFB Context

##### NOTE: YUV Format

The YUV standard shows a color space with three elements:

- Y for luminance
- U for chrominance
- V for chrominance

As shown in [Figure 10-63](#), pixel format (not pixel size) used in the YUV standard is spread onto a 32-bit data structure:

- This 32-bit data structure represents a packet of two pixels: P0 and P1.
- Each element (Y0, Y1, U, and V) is coded in 8 bits.
- P0 = Y0; U, V, and P1 = Y1, U, V.

There are 24 bits of information per pixel (Y, U, and V); however, because the chrominance elements U and V are common to both P0 and P1 pixels, only 16 bits are used to store a pixel in YUV format. The YUV standard uses a 32-bit data structure to represent 2 pixels; the pixel format uses 32 bits (4 bytes).

Thus, when defining YUV image parameters, the image width must be set to one-half the number of pixels per row and the pixel format must be set to 4 bytes, because the YUV pixel data is spread onto a 32-bit word representing 2 pixels.

[Figure 10-63](#) shows the pixel representation of the YUV format.

**Figure 10-63. YUV Format: Pixel Representation**



sdrc-020

[Figure 10-64](#) shows a generic way to configure a VRFB context to perform a rotation view on pixel data in external DRAM.

**Figure 10-64. VRFB Context Configuration**


sdrc-021

**Figure 10-65** is an example of VRFB context configuration using both RGB and YUV image formats. This example represents the configuration of a 1024-byte page size (32 \* 32 byte page) and a 240 \* 240 image size using VRFB context 1.

**Figure 10-65. Example of VRFB Context 1 Configuration**

sdrc-022

Table 10-107 lists guidelines for calculating image size.

**Table 10-107. Calculating Image Size<sup>(1)</sup> <sup>(2)</sup>**

| Steps |                                                                                     | RGB16 Format (16-Bit Pixel Format)                          |                                                  | YUV Format (32-Bit Pixel Format)                    |                                 |
|-------|-------------------------------------------------------------------------------------|-------------------------------------------------------------|--------------------------------------------------|-----------------------------------------------------|---------------------------------|
|       |                                                                                     | IMAGEWIDTH                                                  | IMAGEHEIGHT                                      | IMAGEWIDTH                                          | IMAGEHEIGHT                     |
| 1     | Calculate the required number of pages per line and per column.                     | 240 pixels/32 bytes * 2 bytes per pixel = 15 pages per line | 240/32 rows = 7.5, rounded to 8 pages per column | 120 pixels/32 bytes * 4 bytes per pixel format = 15 | 240/32 rows = 7.5, rounded to 8 |
| 2     | Using the number of pages calculated in Step 1, calculate the image size in pixels. | 15 * 32 bytes/2 bytes per pixel = 240                       | 8 * 32 rows = 256                                | 15 * 32 bytes/4 bytes per pixel format = 120        | 256                             |

<sup>(1)</sup> Working on a page basis, the image size must be a multiple of the page size.

<sup>(2)</sup> Depending on the page dimensions and the image size, the programmed image size (256) is larger than the actual image size (240).

To use VRFB rotation, each initiator must configure its DMA engine correctly; an additional offset to the base address may be required. For details, see [Chapter 7, Display Subsystem](#).

#### 10.2.6.1.3 Applicative Use Case and Tips

##### **Use Case Scenario: Display a Rotated QVGA Image**

[Figure 10-66](#) shows the use case for displaying a rotated QVGA image. The camera captures an image with a particular rotation and stores the pixel data in external memory. Displaying the image on the DSS requires a different orientation.

**Figure 10-66. Display a Rotated QVGA Image**

sdrc-023

The following components interact while displaying the rotated image:

- SDRC subsystem
- Camera subsystem
- Display subsystem
- External DDR
- VRFB

The following conditions exist for this application:

- QVGA image size is 320 \* 240 (width \* height).
- Pixel format is YUV4:2:2 (YUV2) in little endian.
- The rotation view is 90 degrees.
- The VRFB context is VRFB context 1.
- The camera module writes QVGA images to external DRAM at 15 fps.
- The display subsystem reads QVGA images from external DDR32 at 60 fps and displays them on the LCD screen.

- Read and write initiators use burst mode:
  - The camera uses 8 \* 64-bit burst size.
  - The display uses 8 \* 32-bit burst size.
  - Double-indexing mode is selected.
- The physical address of the buffer in external memory is 0x8030 0000.
- The memory allocation for the buffer is 320 \* 240- \* 16-bit (or 160 \* 240 \* 32-bit).
- The camera subsystem uses its dedicated DMA channel 0.
- The display subsystem uses its video channel 1.

### Configuring the VRFB Through the SMS Registers

The size of the page supported by the DDR32 memory is 1K byte, which is arranged as 32 \* 32 bytes page (width \* height).

Configuring the page size:

- [SMS\\_ROT\\_CONTROLn\[6:4\]](#) PW = 5 (where n = 1)
- [SMS\\_ROT\\_CONTROLn\[10:8\]](#) PH = 5

Configuring the image parameters:

- [SMS\\_ROT\\_SIZEn\[10:0\]](#) IMAGEWIDTH = 160 (where n = 1)
- [SMS\\_ROT\\_SIZEn\[26:16\]](#) IMAGEHEIGHT = 256
- [SMS\\_ROT\\_CONTROLn\[1:0\]](#) PS = 2

Physical base address and rotation angle:

- [SMS\\_ROT\\_PHYSICAL\\_BAn\[30:0\]](#) PHYSICALBA = 0x8030 0000 (where n = 1).

The image data is accessed at the following virtual address range for 90-degree rotation: 0x7500 0000 - 0x75FF FFFF.

#### CAUTION

Image rotation using the YUV2 image format causes the stream to become untidy. The display must be specifically configured to read and reorganize the stream to conform to the YUV2 standard.

### Tips for Configuring Successful Rotation

The following guidelines ensure optimal image rotation:

- Page arrangement:

Usually, the recommendation is to have a *square* page. If this is not possible, the longest page side should correspond to the access direction that requires the maximum bandwidth; set the longest page side to optimize the page break.

Using a 1024-byte page size, a 32 \* 32-byte page arrangement is used as an example. With a 2K-byte page organized as a 32 \* 64 byte page, depending on the read or write operation, set the longest page size to optimize the page break. If 0 is written and the 270-degree view is read, page height is greater than page width (PH > PW). Set PH to 64 bytes (PH = 6).
- Virtual address memory arrangement:

When accessing image data through virtual addresses, the maximum line size supported by the VRFB is 2,048 pixels.

In the memory buffer, the distance between two vertically adjacent pixels is fixed at 2,048 multiplied by the pixel format in bytes. This means that when reading or writing image data through virtual addresses, there must be an offset of: (2048 - IMAGEWIDTH) \* PS bytes at the end of every line.
- Base address alignment:

For optimization, the base address is aligned on the page size. For instance, a 1K-byte page size organized as a 32 \* 32-byte page is aligned on 0x400 (to be adjusted on the base address).

- To improve performance on 90° rotation consider two things:
    - Because a read access can appear more critical than a write access, a posted write may be appropriate.
    - When performing burst accesses with 90° or 270° rotation views, the burst is split on the memory side, adding latency.
- For a burst access with 90° rotation, split the data of the burst on the write side (not the read side):
- Write in 270° and read in 0°.

### 10.2.6.2 SMS Mode of Operation

#### 10.2.6.2.1 SDRAM Memory Scheduler and Arbitration Policy

The SDRAM memory scheduler improves access to external memory by:

- Optimizing SDRAM bandwidth
- Prioritizing requests to external memory

This mechanism relies on a complex arbitration policy that employs specific terminology:

- Group: a FIFO queue of requests from initiators
- Class: A collection of groups
- Transaction: A full burst request
- Arbitration grant: Authorization of a service requested by an initiator

The arbitration policy operates on two interdependent mechanisms:

- The arbitration decision, which establishes priority for processing requests. The question: Which request is processed next? occurs on a transaction boundary.
- Arbitration granularity, which determines the length of an arbitration grant. The question: How long to keep the grant? defines the boundary of the arbitration decision point in time.

**Figure 10-67** shows the link between these two concepts. On a transaction boundary, the questions: What request is serviced next, and for how long? merge the two mechanisms. The mechanisms for specifying the granularity of requests also influence the boundary of a transaction.

**Figure 10-67. Arbitration Granularity Versus Arbitration Decision**

Duration of a transaction:  
 How long to track the transaction?  
 (it depends on the granularity settings)



Arbitration decision on a transaction boundary:  
 Which group has the priority?

sdrc-024

#### 10.2.6.2.2 Arbitration Decision

The SMS module controls arbitration. Requests from initiators for access to the external SDRAM are collected into several independent FIFO queues, and each queue is assigned to a class. Priority is then assigned to groups and classes; this defines the next request to be serviced.

##### 10.2.6.2.2.1 Burst-Complete Mechanism

The burst-complete mechanism applies granularity to the arbitration scheme. Access cannot be granted to a group within a class until a complete burst has been stored in the FIFO.

Example:

There is no ongoing transaction on Class 0. The initiator requests a  $4 * 64$ -bit burst on Group 3 of Class 2 ([SMS\\_CLASS\\_ARBITER\[27\]](#) BURST-COMPLETE = 0x1). Only  $2 * 64$ -bit requests are stored in the FIFO.

The mode of operation is:

- Wait for the last  $2 * 64$ -bit request to be stored in the FIFO.
- Arbitration is requested once all requests of a burst have been received.
- After the  $4 * 64$ -bit burst is complete, the transaction occurs.
- The arbitration choice mechanism resumes:
  - Were there any incoming requests during the last transaction?
  - What is the next request to be serviced/granted?

**Figure 10-68. BURST-COMPLETE On Class 2-Group 3**

sdrc-025

### 10.2.6.2.2.2 Priority Between Groups

The SMS.SMS\_CLASS\_ARBITER[7:6] HIGHPRIOVECTOR field defines the priority between groups in a class.

### 10.2.6.2.2.3 Priority Between Classes

Class 0 always has the highest priority. Then, a weight is programmed within the arbitration of Class 1 and Class 2:

- The SMS.SMS\_INTERCLASS\_ARBITER[23:16] CLASS1PRIO field specifies the number (M) of transactions dedicated to Class 1.
- The SMS.SMS\_INTERCLASS\_ARBITER[7:0] CLASS2PRIO field specifies the number (N) of transactions dedicated to Class 2.

M and N parameters are used to set a PWM arbitration. For instance, two schemes appear: at time t, Class 1 is serviced for M cycles, and is directly followed by service to Class 2 for N cycles. If Class 2 is serviced first for N cycles, then Class 1 is granted for M cycles. Arbitration is given more importance; Class 1/2 is favored over Class 2/1. As shown in [Figure 10-69](#), two arbitration schemes can appear:

- Class 0 is serviced first, followed by Class 1, and then Class 2 (C0 - C1 - C2).
- Class 0 is serviced first, followed by Class 2, and then Class 1 (C0 - C2 - C1).

**Figure 10-69. Priority Between Classes**



SMS\_INTERCLASS\_ARBITER[7:0] CLASS1PRIO field:  
defines the number  $\bar{M}$  of transactions dedicated to class 1.

SMS\_INTERCLASS\_ARBITER[23:16] CLASS2PRIO field:  
defines the number N of transactions dedicated to class 2.

sdrc-026

### 10.2.6.2.3 Arbitration Granularity

Arbitration is the mechanism that give more or less importance to incoming requests depending on the initiator origin. Granularity influences the boundary of a transaction because it imposes the following questions:

- How many requests to service?
- How long to track the current transaction?
- When to make the next arbitration decision, or when does the next transaction boundary occur?

#### 10.2.6.2.3.1 Idle Cycle

The idle gives more granularity to the arbitration; it lets the arbiter wait one idle cycle before moving the arbitration grant to another thread.

Within a burst (see [Figure 10-70](#) for an example):

1. A thread requests a burst transaction. According to the thread ID, the last request was serviced on Class 2 - Group 2.
2. The thread cannot provide the subsequent request of the burst. The module waits for one idle cycle without moving the arbitration grant, to receive the subsequent request (from the same thread).
3. On the second idle cycle, if the subsequent request has not been received, the arbitration grant is moved so that a request from another thread is serviced.

**Figure 10-70. Idle Cycle Mechanism Within A Burst**



sdrc-027

Two bursts must be serviced at the burst boundary. One idle cycle after servicing these two bursts, the arbitration grant is moved.

#### 10.2.6.2.3.2 Extended-Grant Mechanism

The extended-grant mechanism gives additional granularity to the arbitration. An extended grant defines the number of consecutive transactions (from 1 to 3) a group is granted.

Example:

Requests were already available on Class 1-Group 0 and Class 2-Group 3.

An arbitration decision occurs: grant access to Class 1-Group 0.

A request is now being serviced on Class 1-Group 0 with `SMS_CLASS_ARBTER1[9:8]`

EXTENDEDGRANT = 0x3 (three consecutive transactions are granted to Group 0). The mode of operation is:

- Process the request for three cycles.
- If another request comes from another class (even Class 0) during the processing, it is ignored; the arbiter does not treat incoming requests.
- After three consecutive transactions, return to the arbitration decision:
  - Were there any incoming requests during the last transaction?
  - What is the next request to be serviced?

[Figure 10-71](#) shows this mechanism on Class 1-Group 0:

**Figure 10-71. Example of EXTENDEDGRANT Mechanism**



sdrc-028

#### 10.2.6.2.3.3 Number of Service Mechanism.

The [SMS\\_CLASS\\_ROTATIONm\[4:0\]](#) NOFSERVICES field defines the number of consecutive transactions (from 1 to 31) the VRFB is granted. For more information on LRU policy and Number of Service, refer to [Section 10.2.4.1.3](#).

#### 10.2.6.2.4 How these Mechanisms Interact

As described in the previous sections, the arbitration within the SMS module is based on several mechanisms giving even more importance to the arbitration. When we need to grant the access on a transaction boundary, we recall that the question we have to answer is: What will be the next request to be serviced, and for how long?

Thus, the two important concepts regarding the SMS mode of operation are:

- The arbitration decision: we choose the next request to be serviced and so we grant it the access to the external memory.
- The arbitration granularity: depending on the mechanism used, we define the boundary of the transaction: how long do we keep the grant?

[Figure 10-72](#) describes the decision happening between classes.

[Figure 10-73](#) explains the priority between groups within Class 1.

So far, the arbitration decision has taken place at class boundaries and within a class containing two groups. [Figure 10-74](#) recalls the generic way to service and therefore prioritize the requests within a class. Finally, [Figure 10-75](#) recalls mechanisms used to define the boundary of the transaction being serviced (how long do we keep the grant?).

**Figure 10-72. Arbitration Between Classes**

sdrc-029

### Figure 10-73. Arbitration Within a Class



Figure 10-74. Generic Arbitration Decision



**Figure 10-75. Arbitration Granularity**


sdrc-032

### 10.2.6.3 Understanding SDRAM Subsystem Address Spaces

One thing that the SMS does is to translate virtual addresses into physical SDRAM addresses in case of rotation only; that is, when accessing virtual address space 0 (quarter 1) and virtual address space 1 (quarter 3) as shown in [Figure 10-76](#). The SMS then reinserts a request, or multiple requests depending on the SMS parameters, in the SMS request path to the SDRC (through the VRFB or not).

The SDRAM subsystem global memory space mapping reaches 1.768G-bytes:

- 1G-byte of CS memory space (CS0 and CS1 memory spaces): the SDRC automatically accesses the two external memory devices through direct accesses (addresses are simply translated).
- 768M-bytes of virtual address space (address space 0 and address space 1): the SDRC automatically accesses the two external memory devices through re-organized access (requests are modified accordingly to the context number and rotation angle before address translation). See section [Section 10.2.6.3.1.2](#) for more information on VRFB contexts and rotation angles.

**Figure 10-76. SDRC Address Space in MPU Global Address Space**



Configuration register space is detailed in [Table 10-108](#).

**Table 10-108. SDRC and SMS Configuration Register Space**

| Module | Start Address | End Address | Total Space |
|--------|---------------|-------------|-------------|
| SMS    | 0x6C00 0000   | 0x6CFF FFFF | 16 MB       |
| SDRC   | 0x6D00 0000   | 0x6DFF FFFF | 16 MB       |

#### 10.2.6.3.1.1 Physical Address Space

The physical address space of the SDRC is 1G byte (maximum addressing capability).

The SDRC has a memory device capacity of 16M bits to 2G bits. The smallest granularity of supported memory device is 16M bits/2M bytes.

### 10.2.6.3.1.2 Virtual Address Space

The SDRC-SMS virtual memory space is a memory space used to access a subset of the SDRC memory space through the rotation engine (VRFB). The virtual address space size is 768M bytes split into two parts: the first 256M-byte part is in the second quarter (Q1) of the memory; the second 512M-byte part is in the fourth quarter (Q3) of the memory. See [Chapter 2, Memory Mapping](#), for more information on global memory mapping.

The VRFB is a rotation engine that:

- Supports rotations of 0, 90, 180, and 270 degrees
- Can handle up to 12 concurrent rotation contexts

The VRFB has therefore 48 different contexts in the virtual address space. [Table 10-109](#) gives the VRFB address-space memory locations at which the frame buffer object can be accessed. The table summarizes the virtual addresses of all 48 available image buffer from a global memory space (top level) point of view.

**Table 10-109. VRFB Contexts vs Rotation Angle**

| Context Number | 0°          | 90°         | 180°        | 270°        |
|----------------|-------------|-------------|-------------|-------------|
| 0              | 0x7000 0000 | 0x7100 0000 | 0x7200 0000 | 0x7300 0000 |
| 1              | 0x7400 0000 | 0x7500 0000 | 0x7600 0000 | 0x7700 0000 |
| 2              | 0x7800 0000 | 0x7900 0000 | 0x7A00 0000 | 0x7B00 0000 |
| 3              | 0x7C00 0000 | 0x7D00 0000 | 0x7E00 0000 | 0x7F00 0000 |
| 4              | 0xE000 0000 | 0xE100 0000 | 0xE200 0000 | 0xE300 0000 |
| 5              | 0xE400 0000 | 0xE500 0000 | 0xE600 0000 | 0xE700 0000 |
| 6              | 0xE800 0000 | 0xE900 0000 | 0xEA00 0000 | 0xEB00 0000 |
| 7              | 0xEC00 0000 | 0xED00 0000 | 0xEE00 0000 | 0xEF00 0000 |
| 8              | 0xF000 0000 | 0xF100 0000 | 0xF200 0000 | 0xF300 0000 |
| 9              | 0xF400 0000 | 0xF500 0000 | 0xF600 0000 | 0xF700 0000 |
| 10             | 0xF800 0000 | 0xF900 0000 | 0xFA00 0000 | 0xFB00 0000 |
| 11             | 0xFC00 0000 | 0xFD00 0000 | 0xFE00 0000 | 0xFF00 0000 |

The physical address of a page is calculated with the formula:

$$\text{Physical address} = \text{Physical base address} + \text{Base address of page} \quad (31)$$

where *Physical base address* is defined through the [SMS\\_ROT\\_PHYSICAL\\_BAn\[30:0\]](#) PHYSICALBA field (buffer physical base address on which the rotation occurs), and *Base address of page* is the address obtained in the function of the context number and rotation angle, as given in [Table 10-109](#).

### 10.2.6.3.2 CS Memory Spaces

Two SDRC chip-selects (sdrc\_ncs0 and sdrc\_ncs1) are available to access two external SDRAM memories.

#### 10.2.6.3.2.1 SDRAM Capacity Calculation

This section aims to explain how to calculate an SDRAM device capacity.

From the following SDRAM characteristics:

- Four banks: BA0 - BA1
- Row addresses: A0 - A12
- Column addresses: A0 - A9
- 16-bit data bus to external memory

First calculate the number of addressable locations:

- Number of address lines: 13 (A0-A12)
- Number of banks address lines: 2 (BA0-BA1)

- Maximum number of rows = 13 (number of address lines used for row decoding)
  - Maximum number of columns = 10 (number of address lines used for column decoding)
- Total locations in a bank =  $(2^{13}) * (2^{10})$  (32)

Then calculate the total locations in the device:

$$\text{Total locations in the device} = (\text{Number of banks}) * (\text{Total locations in a bank}) = (2^2) * (2^{13} * 2^{10}) = 2^{25} \quad (33)$$

Finally calculate the SDRAM device capacity:

$$\text{Total device capacity} = (\text{Total locations in the device}) * (\text{Device organization}) = (2^{25}) * (16) = 2^{29} \text{ bits} \quad (34)$$

Hence, the device has a maximal capacity of 512M bits (or 64M bytes).

In the same way, the SDRC maximal capacity can be calculated as follow:

- Number of address lines: 15 (A0-A14)
- Maximum number of rows = 15 (limited by the number of address lines, hence do not program **SDRC\_MCFG\_p[26:24]** RASWIDTH above 15)
- Maximum number of columns = 12 (limited by **SDRC\_MCFG\_p[22:20]** CASWIDTH)
- Data bus width to external device: 32-bit

$$\text{SDRC total capacity} = (2^{15} * 2^{12}) * 32 = 4\text{G bits (or 512M bytes)} \quad (35)$$

Hence, the SDRC has a maximum addressing capability of 8G bits/1G byte (as seen in [Section 10.2.6.3.1.1](#)) and can manage SDRAM devices with capacity of up to 4G bits/512M bytes.

#### 10.2.6.3.2.2 CS Size

Each chip-select has its programmable size. The CS size is expressed in **SDRC\_MCFG\_p[17:8]** RAMSIZE (p = 0 or 1 for CS0 or CS1) as a number of 2M-byte chunks.

For instance, when connecting a 256M-bit SDRAM memory (see the mux scheme MUX7 in [Table 10-96](#)) to the SDRC, RAMSIZE must be set with the value 0x010 (32M bytes = 2MB \* 16).

#### 10.2.6.3.2.3 CS Start and End Addresses

See [Figure 10-77](#), CS0/CS1 Chip-Select Start Address Slots, for a graphical representation of CS starts addresses and CS size.

CS0 start address is fixed at :

- 0x0000 0000 from an SDRC point of view
- 0x8000 0000 from a global memory space point of view.

Therefore, when connecting a 256M bit/32M-byte SDRAM memory (16M \* 8 such as in MUX6, [Table 10-96](#)), the CS0 end address is 0x0200 0000 (SDRC point of view).

CS1 start address is programmable and its default value is :

- 0x2000 0000 from an SDRC address point of view
- 0xA000 0000 from a global memory space point of view.

The SDRC 1G-byte address space is segmented into eight 128M-byte address spaces, which are themselves segmented into four 32M-byte address spaces so that 32 possible CS1 start address locations are defined, as shown in [Figure 10-77](#). The first 32M-byte address space of the first 128M-byte address space is reserved for CS0 (address 0x0000 0000). Any other address can be used as the CS1 start address. To define a CS1 start address, set the **SDRC\_CS\_CFG[9:8]** CS1STARTLOW and **SDRC\_CS\_CFG[3:0]** CS1STARTHIGH fields as follows:

- **SDRC\_CS\_CFG[3:0]** CS1STARTHIGH corresponds to one of the eight 128M-byte address spaces (total address space of SDRC is 1G-byte): 0x0000 for the first partition up to 0x0111 for the eighth partition. The **SDRC\_CS\_CFG[3]** must always be set to 0.
- **SDRC\_CS\_CFG[9:8]** CS1STARTLOW corresponds, for a given 128M-byte address space, to one of the four 32M-byte address spaces: 0x00 for the first, up to 0x11 for the fourth.

Therefore, for a start address of 0x2000 0000 (SDRC point of view) when connecting a 2048-Mbit SDRAM memory (64M \* 32 such as in MUX25, [Table 10-97](#)), the [SDRC\\_CS\\_CFG\[9:8\]](#) CS1STARTLOW bit field must be set to 0x00 (the first 32M-byte address space, as shown in [Figure 10-77](#)), and the [SDRC\\_CS\\_CFG\[3:0\]](#) CS1STARTHIGH bit field must be set to 0x0100 (fourth 128M-byte address space). The start address must be aligned on the memory size.

The CS1 end address (0x3000 0000) can be deduced from the CS1 size (that is, from the RAMSIZE parameter), which takes the value 0x80 when connecting a 2048-Mbit SDRAM memory.

**Figure 10-77. CS Start and End Address Configuration Example**



sdrc-041

#### 10.2.6.4 How to Choose a Suitable SDRAM

This section describes how to select a suitable SDRAM device to interface with the SDRC. Basically, if an SDRAM device is aligned with the JEDEC LPDDR1 SDRAM standard (JEDEC committee JC42.3), the SDRAM device is likely to be compatible with the SDRC. To ensure that an SDRAM device is fully compatible, see the following sections.

[Section 10.2.6.4.1](#) discusses the SDRAM device features to consider. [Section 10.2.6.4.2](#) discusses the SDRC features to consider. As an example, [Section 10.2.6.4.3](#) lists chosen SDRAM parameters versus the supported characteristics of the SDRC.

##### 10.2.6.4.1 SDRAM Device Parameters

Several settings must be considered when selecting an SDRAM device to interface with the SDRC:

- SDRAM type
- Operating voltage
- Maximum operating frequency
- Maximum memory size
- Memory organization:
  - Number of banks
  - Data bus width
- Burst length
- Page size
- Column address strobe (CAS) latency
- Refresh rate
- AC timing parameters and especially the access time parameter tAC

These parameters are defined in the SDRAM device datasheet and must meet the SDRC specifications.

#### **10.2.6.4.2 SDRC Characteristics**

Keeping the SDRAM device settings in mind, the SDRC supports:

- Supported device type: Up to two mobile single data rate (M-SDR) SDRAMs, or up to two low-power double data rate (LPDDR) SDRAMs.
- Maximum supported memory size: 128MB per external SDRAM bank (256- and 512-MB SDRAM may be supported, depending on their implementation)
- Minimum supported memory size: 2MB
- Maximum SDRC addressing capability: 1GB
- Memory organization:
  - Number of internal SDRAM banks: two (for 2-MB and 4-MB memory device only) or four banks (other memory device only)
  - Data path to external SDRAM memory: 16- or 32-bit
- Burst Length: Burst of 2 (M-SDR) and burst of 4 (LPDDR)
- Page size: Programmable value (up to 16K bytes)
- Column address strobe latency (CL): 1 to 5 system clock cycles
- Refresh intervals: Programmable value
- Major operation is 3-3-3 (CL-tRCD-tRP) conditions.
  - CL = 3
  - tRCD = 3 clocks cycle time
  - tRP = 3 clocks cycle time
  - tRRD = 2 clocks cycle time
  - tRAS = 7 clocks cycle time
  - tRC = 10 clocks cycle time

#### **10.2.6.4.3 SDRAM Device Compatibility Verification**

In this example, a mobile DDR SDRAM memory with the following characteristics is verified for compatibility:

- Type: Mobile DDR SDRAM
- Size: 512 Mbits (16M \* 32 in 4 banks)

Table 10-110 lists the SDRAM versus the SDRC characteristics.

**Table 10-110. SDRAM vs SDRC Characteristics**

| SDRAM Parameter         | SDRC                                                                  | 512-Mbit MDDR SDRAM (16M * 32)                                                                          | Co<br>mpa<br>tibili<br>ty |
|-------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|---------------------------|
| Device type             | Mobile SDR / low-power DDR                                            | Low-power DDR                                                                                           | yes                       |
| Operating voltage       | VDD = VDDQ = 1.7V to 1.9V; VSS = VSSQ = 0.0V (and LVCMOS 1.8V I/Os)   | 0.8xVDDQ >= High level <= VDDQ + 0.3V<br>-0.3V <= Low level <= 0.2 * VDDQ<br>1.8V <= I/O power <= 1.95V | yes                       |
| Max operating frequency | 200 MHz                                                               | 200 MHz (DDR400)                                                                                        | yes                       |
| Memory size             | Min: 16 Mbits, max: 1024M bits (2048 and 4096M bits may be supported) | 512 Mbits                                                                                               | yes                       |
| Number of banks         | 2 (16 and 32 Mb) or 4 (other)                                         | 4                                                                                                       | yes                       |
| Data path SDRC/SDRAM    | 16- and 32-bit                                                        | 32-bit                                                                                                  | yes                       |
| Burst length            | Burst of 2 (M-SDR) and Burst of 4 (LPDDR)                             | 2, 4, 8                                                                                                 | yes                       |
| Page size               | Up to 16KB                                                            | 2KB                                                                                                     | yes                       |
| CAS latency             | 1 to 5 clock cycles                                                   | 3                                                                                                       | yes                       |
| Refresh interval        | 64 ms / number of rows                                                | 7.8 $\mu$ s                                                                                             | yes                       |

## 10.2.7 SMS Register Manual

### 10.2.7.1 SMS Instance Summary

Table 10-111 describes the SMS module instance.

**Table 10-111. SMS Instance Summary**

| Module Name | Base Address | Size      |
|-------------|--------------|-----------|
| SMS         | 0x6C00 0000  | 64K bytes |

### 10.2.7.2 SMS Register Summary

Table 10-112 summarizes the SMS register mapping summary.

**Table 10-112. SMS Register Summary**

| Register Name                                                  | Type | Register Width (Bits) | Address Offset                     | Physical Address                   |
|----------------------------------------------------------------|------|-----------------------|------------------------------------|------------------------------------|
| SMS_REVISION                                                   | R    | 32                    | 0x0000 0000                        | 0x6C00 0000                        |
| SMS_SYSCONFIG                                                  | RW   | 32                    | 0x0000 0010                        | 0x6C00 0010                        |
| SMS_SYSSTATUS                                                  | R    | 32                    | 0x0000 0014                        | 0x6C00 0014                        |
| SMS_RG_ATTi <sup>(1)</sup>                                     | RW   | 32                    | 0x0000 0048 +<br>(0x0000 0020 * i) | 0x6C00 0048 +<br>(0x0000 0020 * i) |
| SMS_RG_RDPERMi <sup>(1)</sup>                                  | RW   | 32                    | 0x0000 0050 +<br>(0x0000 0020 * i) | 0x6C00 0050 +<br>(0x0000 0020 * i) |
| SMS_RG_WRPERMi <sup>(1)</sup>                                  | RW   | 32                    | 0x0000 0058 +<br>(0x0000 0020 * i) | 0x6C00 0058 +<br>(0x0000 0020 * i) |
| SMS_RG_STARTj <sup>(2)</sup><br>where k = j - 1 <sup>(3)</sup> | RW   | 32                    | 0x0000 0060 +<br>(0x0000 0020 * k) | 0x6C00 0060 +<br>(0x0000 0020 * k) |
| SMS_RG_ENDj <sup>(2)</sup><br>where k = j - 1 <sup>(3)</sup>   | RW   | 32                    | 0x0000 0064 +<br>(0x0000 0020 * k) | 0x6C00 0064 +<br>(0x0000 0020 * k) |
| SMS_CLASS_ARBITER0                                             | RW   | 32                    | 0x0000 0150                        | 0x6C00 0150                        |
| SMS_CLASS_ARBITER1                                             | RW   | 32                    | 0x0000 0154                        | 0x6C00 0154                        |
| SMS_CLASS_ARBITER2                                             | RW   | 32                    | 0x0000 0158                        | 0x6C00 0158                        |
| SMS_INTERCLASS_ARBITER                                         | RW   | 32                    | 0x0000 0160                        | 0x6C00 0160                        |
| SMS_CLASS_ROTATIONm <sup>(4)</sup>                             | RW   | 32                    | 0x0000 0164 +<br>(0x0000 0004 * m) | 0x6C00 0164 +<br>(0x0000 0004 * m) |
| SMS_ERR_ADDR                                                   | R    | 32                    | 0x0000 0170                        | 0x6C00 0170                        |
| SMS_ERR_TYPE                                                   | RW   | 32                    | 0x0000 0174                        | 0x6C00 0174                        |
| SMS_POW_CTRL                                                   | RW   | 32                    | 0x0000 0178                        | 0x6C00 0178                        |
| SMS_ROT_CONTROLn <sup>(5)</sup>                                | RW   | 32                    | 0x0000 0180 +<br>(0x0000 0010 * n) | 0x6C00 0180 +<br>(0x0000 0010 * n) |
| SMS_ROT_SIZEn <sup>(5)</sup>                                   | RW   | 32                    | 0x0000 0184 +<br>(0x0000 0010 * n) | 0x6C00 0184 +<br>(0x0000 0010 * n) |
| SMS_ROT_PHYSICAL_BAn <sup>(5)</sup>                            | RW   | 32                    | 0x0000 0188 +<br>(0x0000 0010 * n) | 0x6C00 0188 +<br>(0x0000 0010 * n) |

<sup>(1)</sup> i = 0 to 7

<sup>(2)</sup> j = 1 to 7

<sup>(3)</sup> k = 0 to 6

<sup>(4)</sup> m = 0 to 2

<sup>(5)</sup> n = 0 to 11

### 10.2.7.3 SMS Register Description

This section provides a description of SMS registers.

**Table 10-113. SMS\_REVISION**

|                         |                                                                                         |                       |                 |
|-------------------------|-----------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0000                                                                             | <b>Instance</b>       | SMS             |
| <b>Physical Address</b> | 0x6C00 0000                                                                             |                       |                 |
| <b>Description</b>      | This register contains the IP revision code. IP revision code is defined at design time |                       |                 |
| <b>Type</b>             | R                                                                                       |                       |                 |
| 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 |
|                         | RESERVED                                                                                |                       | REV             |

  

| Bits | Field Name | Description                                                                                              | Type | Reset              |
|------|------------|----------------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | RESERVED   | Read returns 0.                                                                                          | R    | 0x000000           |
| 7:0  | REV        | IP revision code<br>[7:4] Major revision<br>[3:0] Minor revision<br>Examples: 0x10 for 1.0, 0x21 for 2.1 | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 10-114. Register Call Summary for Register SMS\_REVISION**

SDRAM Controller (SDRC) Subsystem

- [SMS Register Summary: \[0\]](#)

**Table 10-115. SMS\_SYSCONFIG**

|                         |                                                                    |                       |                                               |
|-------------------------|--------------------------------------------------------------------|-----------------------|-----------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0010                                                        | <b>Instance</b>       | SMS                                           |
| <b>Physical Address</b> | 0x6C00 0010                                                        |                       |                                               |
| <b>Description</b>      | This register controls the various parameters of the Interconnect. |                       |                                               |
| <b>Type</b>             | RW                                                                 |                       |                                               |
| 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                               |
|                         | RESERVED                                                           | RESERVED              | RESERVED SIDLEMODE RESERVED SOFTRESET AUTODLE |

  

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                              | Type | Reset    |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED   | Write Os for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                      | RW   | 0x000000 |
| 8    | RESERVED   | Write Os for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                      | RW   | 0x0      |
| 7:5  | RESERVED   | Write Os for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                      | RW   | 0x0      |
| 4:3  | SIDLEMODE  | Power management Req/Ack Control<br><br>0x0: Force Idle - An idle request is acknowledged unconditionally<br>0x1: No Idle - An idle request is never acknowledged.<br>0x2: Smart Idle - Acknowledgment to an idle request is based on the internal activity of the module<br>0x3: Reserved - Do not use. | RW   | 0x0      |
| 2    | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                                                                                                                                                                                                       | RW   | 0x0      |
| 1    | SOFTRESET  | Software reset<br><br>0x0: Normal mode (no reset applied)<br>0x1: Software reset is activated                                                                                                                                                                                                            | RW   | 0x0      |

## SDRAM Controller (SDRC) Subsystem

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                       | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | AUTOIDLE   | Internal interface clock gating strategy<br>0x0: Interface clock is free-running<br>0x1: Automatic interface clock gating strategy is applied, based on the interconnect activity | RW   | 0x1   |

**Table 10-116. Register Call Summary for Register SMS\_SYSCONFIG**

## SDRAM Controller (SDRC) Subsystem

- Software Reset: [0]
- Module Power Saving: [1] [2] [3]
- System Power Management: [4] [5] [6] [7]
- SMS Register Summary: [8]

**Table 10-117. SMS\_SYSSTATUS**

|                  |                                                                        |  |  |  |  |  |  |  |  |  |  |  |          |     |  |  |  |
|------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|----------|-----|--|--|--|
| Address Offset   | 0x0000 0014                                                            |  |  |  |  |  |  |  |  |  |  |  |          |     |  |  |  |
| Physical Address | 0x6C00 0014                                                            |  |  |  |  |  |  |  |  |  |  |  | Instance | SMS |  |  |  |
| Description      | This register provides module status, excluding interrupt status info. |  |  |  |  |  |  |  |  |  |  |  |          |     |  |  |  |
| Type             | R                                                                      |  |  |  |  |  |  |  |  |  |  |  |          |     |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         |                       | RESERVED        |

RESETDONE

| Bits | Field Name | Description                                                                                                                         | Type | Reset    |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | RESERVED   | Reserved for module-specific status information.<br>Read returns 0s.                                                                | R    | 0x000000 |
| 7:1  | RESERVED   | Reserved for interconnect socket status information.<br>Read returns 0s.                                                            | R    | 0x00     |
| 0    | RESETDONE  | Internal reset monitoring<br><br>0x0: Internal module reset is ongoing.<br><br>0x1: Reset complete. The module is ready to be used. | R    | 0x-      |

**Table 10-118. Register Call Summary for Register SMS\_SYSSTATUS**

## SDRAM Controller (SDRC) Subsystem

- SMS Register Summary: [0]

**Table 10-119. SMS\_RG\_ATTi**

|                  |                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |
|------------------|---------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|------------|
| Address Offset   | 0x0000 0048 + (0x0000 0020 * i) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | i = 0 to 7 |
| Physical Address | 0x6C00 0048 + (0x0000 0020 * i) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | SMS        |
| Description      | Request information permission  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |
| Type             | RW                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| REQINFO                 |                         |                       |                 |

| Bits | Field Name | Description                                                                                                                                                                                                  | Type | Reset   |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:0 | REQINFO    | Request information permission<br>The REQINFO field is a bit vector of permissions, one per MReqInfo encoding: NonHost/Host - User/Supervisor - Functional/Debug - Data Transfer/Opcode Fetch <sup>(1)</sup> | RW   | 0x----- |

<sup>(1)</sup> See Table 10-99 for more information on REQINFO values

**Table 10-120. Register Call Summary for Register SMS\_RG\_ATTi**

SDRAM Controller (SDRC) Subsystem

- [Firewalls: \[0\]](#) [\[1\]](#) [\[2\]](#) [\[3\]](#) [\[4\]](#) [\[5\]](#)
- [SMS Firewall Usage: \[6\]](#)
- [SMS Register Summary: \[7\]](#)

**Table 10-121. SMS\_RG\_RDPERMi**

|                         |                                                                                                             |                 |            |
|-------------------------|-------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0050 + (0x0000 0020 * i)                                                                             | <b>Index</b>    | i = 0 to 7 |
| <b>Physical Address</b> | 0x6C00 0050 + (0x0000 0020 * i)                                                                             | <b>Instance</b> | SMS        |
| <b>Description</b>      | This register provides the list of all initiators that have permission for reading from that memory region. |                 |            |
| <b>Type</b>             | RW                                                                                                          |                 |            |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CONNIDVECTOR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name   | Description                                                                                                                      | Type | Reset                 |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------|------|-----------------------|
| 31:16 | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                              | RW   | 0x0000                |
| 15:0  | CONNIDVECTOR | One bit per initiator group. Bit 0 set to 1 means that initiator whose ConnID = 0 has read permission to the protected region i. | RW   | 0x---- <sup>(1)</sup> |

<sup>(1)</sup> Reset value exported from control module for region 0 and region 1; reset value equal to 0x0000 for other

**Table 10-122. Register Call Summary for Register SMS\_RG\_RDPERMi**

SDRAM Controller (SDRC) Subsystem

- [Firewalls: \[0\]](#)
- [SMS Firewall Usage: \[1\]](#)
- [SMS Register Summary: \[2\]](#)

**Table 10-123. SMS\_RG\_WRPERMi**

|                         |                                                                                                           |                 |            |
|-------------------------|-----------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0058 + (0x0000 0020 * i)                                                                           | <b>Index</b>    | i = 0 to 7 |
| <b>Physical Address</b> | 0x6C00 0058 + (0x0000 0020 * i)                                                                           | <b>Instance</b> | SMS        |
| <b>Description</b>      | This register provides the list of all initiators that have permission for writing to that memory region. |                 |            |
| <b>Type</b>             | RW                                                                                                        |                 |            |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CONNIDVECTOR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name   | Description                                                                                                                       | Type | Reset                 |
|-------|--------------|-----------------------------------------------------------------------------------------------------------------------------------|------|-----------------------|
| 31:16 | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                               | RW   | 0x0000                |
| 15:0  | CONNIDVECTOR | One bit per initiator group. Bit 0 set to 1 means that initiator whose ConnID = 0 has write permission to the protected region i. | RW   | 0x---- <sup>(1)</sup> |

<sup>(1)</sup> Reset value exported from control module for region 0 and region 1; reset value equal to 0x0000 for other

**Table 10-124. Register Call Summary for Register SMS\_RG\_WRPERM<sub>i</sub>**

|                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| SDRAM Controller (SDRC) Subsystem                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <ul style="list-style-type: none"> <li>• Firewalls: [0]</li> <li>• SMS Firewall Usage: [1]</li> <li>• SMS Register Summary: [2]</li> </ul> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 10-125. SMS\_RG\_STARTj**

|                         |                                                                                                                  |                 |                           |
|-------------------------|------------------------------------------------------------------------------------------------------------------|-----------------|---------------------------|
| <b>Address Offset</b>   | 0x0000 0060 + (0x0000 0020 * (k))                                                                                | <b>Index</b>    | j = 1 to 7 and k = 0 to 8 |
| <b>Physical Address</b> | 0x6C00 0060 + (0x0000 0020 * (k))                                                                                | <b>Instance</b> | SMS                       |
| <b>Description</b>      | This register provides the region #j start address (lowest address inside the region), with a 64-KB granularity. |                 |                           |
| <b>Type</b>             | RW                                                                                                               |                 |                           |

| 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 |
|----------|----|----|----|----|----|----|----|--------------|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    | STARTADDRESS |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31          | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                        | RW          | 0x0          |
| 30:16       | STARTADDRESS      | Region #j start address (included in the region)<br>Aligned on 64-KB boundary.<br>[15:0] must be written with 0s. No STARTADDRESS parameter for region 0. | RW          | 0x---        |
| 15:0        | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                        | RW          | 0x0000       |

**Table 10-126. Register Call Summary for Register SMS\_RG\_STARTj**

|                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| SDRAM Controller (SDRC) Subsystem                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <ul style="list-style-type: none"> <li>• SMS Firewall Usage: [0] [1]</li> <li>• SMS Register Summary: [2]</li> </ul> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 10-127. SMS\_RG\_ENDj**

|                         |                                                                                                                 |                 |                           |
|-------------------------|-----------------------------------------------------------------------------------------------------------------|-----------------|---------------------------|
| <b>Address Offset</b>   | 0x0000 0064 + (0x0000 0020 * (K))                                                                               | <b>Index</b>    | j = 1 to 7 and k = 0 to 8 |
| <b>Physical Address</b> | 0x6C00 0064 + (0x0000 0020 * (K))                                                                               | <b>Instance</b> | SMS                       |
| <b>Description</b>      | This register provides the region #j end address (lowest address outside the region), with a 64-KB granularity. |                 |                           |
| <b>Type</b>             | RW                                                                                                              |                 |                           |

| 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 |
|----------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    | ENDADDRESS |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31          | RESERVED          | Write 0s for future compatibility. Read returns 0s.                                                                                                       | RW          | 0x0          |
| 30:16       | ENDADDRESS        | Region #j end address (not included in the region)<br>Aligned on 64-KB boundary.<br>[15:0] must be written with 0s. No ENDADDRESS parameter for region 0. | RW          | 0x---        |
| 15:0        | RESERVED          | Write 0s for future compatibility. Read returns 0s.                                                                                                       | RW          | 0x0000       |

**Table 10-128. Register Call Summary for Register SMS\_RG\_ENDj**

SDRAM Controller (SDRC) Subsystem

- [SMS Firewall Usage: \[0\] \[1\]](#)
- [SMS Register Summary: \[2\]](#)

**Table 10-129. SMS\_CLASS\_ARBITER0**

|                         |                                                                                       |  |  |  |  |  |  |  |  |  |                 |  |  |  |            |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|------------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0150                                                                           |  |  |  |  |  |  |  |  |  |                 |  |  |  |            |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x6C00 0150                                                                           |  |  |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  | <b>SMS</b> |  |  |  |  |  |  |  |
| <b>Description</b>      | This register controls the arbitration parameters between the class 0 request groups. |  |  |  |  |  |  |  |  |  |                 |  |  |  |            |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                    |  |  |  |  |  |  |  |  |  |                 |  |  |  |            |  |  |  |  |  |  |  |

|                | 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 |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BURST-COMPLETE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                      | Type | Reset |
|-------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | BURST-COMPLETE | Delayed service until burst request complete BurstComplete[k], k= 6 to 7 (BURST-COMPLETE[30] is for group number 6, BURST-COMPLETE[31] is for group number 7)<br><br>0x0: Group #k request to arbiter issued as soon as the first burst request is available<br><br>0x1: Group #k request to arbiter delayed until a complete burst transaction is buffered                                                      | RW   | 0x0   |
| 29:24 | RESERVED       | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                              | RW   | 0x00  |
| 23:20 | EXTENDEDGRANT  | Extended grant service inside a class<br>Vector specifying the number of consecutive services a group is granted. 2 bits per group ExtendedGrant[2*k+1,2*k], k = 6 to 7 (EXTENDEDGRANT[21:20] is for group number 6, EXTENDEDGRANT[23:22] is for group number 7)<br><br>0x1: 1 service for group #k when granted<br>0x2: 2 services for group #k when granted<br>0x3: 3 services for group #k when granted       | RW   | 0x5   |
| 19:8  | RESERVED       | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                              | RW   | 0x000 |
| 7:6   | HIGHPRIOVECTOR | High-priority attribute inside a class<br>Vector allocating a higher priority to one of the class members. A single group may be given this attribute at a time. HighPrioVector[k], k= 6 to 7 (HIGHPRIOVECTOR[6] is for group number 6, HIGHPRIOVECTOR[7] is for group number 7)<br><br>0x0: Group #k has standard priority (LRU based).<br>0x1: Group #k has the highest priority over all other class members. | RW   | 0x0   |
| 5:0   | RESERVED       | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                              | RW   | 0x00  |

**Table 10-130. Register Call Summary for Register SMS\_CLASS\_ARBITER0**

SDRAM Controller (SDRC) Subsystem

- [Arbitration Policy: \[0\] \[1\]](#)
- [Internal Class Arbitration: \[2\]](#)
- [Memory-Access Scheduler Configuration: \[3\]](#)
- [SMS Register Summary: \[4\]](#)

**Table 10-131. SMS\_CLASS\_ARBITER1**

|                       |                                                                                       |                         |             |                 |     |
|-----------------------|---------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|-----|
| <b>Address Offset</b> | 0x0000 0154                                                                           | <b>Physical Address</b> | 0x6C00 0154 | <b>Instance</b> | SMS |
| <b>Description</b>    | This register controls the arbitration parameters between the class 1 request groups. |                         |             |                 |     |
| <b>Type</b>           | RW                                                                                    |                         |             |                 |     |

  

|          |    |                |          |    |    |    |    |    |    |    |    |    |    |    |               |    |          |    |    |    |                |   |   |   |   |   |   |   |   |   |   |
|----------|----|----------------|----------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----------|----|----|----|----------------|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    | BURST-COMPLETE | RESERVED |    |    |    |    |    |    |    |    |    |    |    | EXTENDEDGRANT |    | RESERVED |    |    |    | HIGHPRIOVECTOR |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:26 | RESERVED       | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0x00  |
| 25:24 | BURST-COMPLETE | Delayed service until burst request complete<br>BurstComplete[k], k= 0 to 1 (BURST-COMPLETE[24] is for group number 0, BURST-COMPLETE[25] is for group number 1)<br><br>0x0: Group #k request to arbiter issued as soon as the first burst request is available<br><br>0x1: Group #k request to arbiter delayed until a complete burst transaction is buffered                                                       | RW   | 0x0   |
| 23:12 | RESERVED       | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0x000 |
| 11:8  | EXTENDEDGRANT  | Extended grant service inside a class<br>Vector specifying the number of consecutive services a group is granted. 2 bits per group ExtendedGrant[2*k+1,2*k], k = 0 to 1 (EXTENDEDGRANT[9:8] is for group number 0, EXTENDEDGRANT[11:10] is for group number 1)<br><br>0x1: 1 service for group #k when granted<br>0x2: 2 services for group #k when granted<br>0x3: 3 services for group #k when granted             | RW   | 0x5   |
| 7:2   | RESERVED       | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0x00  |
| 1:0   | HIGHPRIOVECTOR | High-priority attribute inside a class<br>Vector allocating a higher priority to one of the class members. A single group may be given this attribute at a time. HighPrioVector[k], k= 0 to 1 (HIGHPRIOVECTOR[1] is for group number 1, HIGHPRIOVECTOR[0] is for group number 0)<br><br>0x0: Group #k has standard priority (LRU based).<br><br>0x1: Group #k has the highest priority over all other class members. | RW   | 0x0   |

**Table 10-132. Register Call Summary for Register SMS\_CLASS\_ARBITER1**

SDRAM Controller (SDRC) Subsystem

- [Arbitration Policy: \[0\] \[1\]](#)
- [Arbitration Granularity: \[2\]](#)
- [SMS Register Summary: \[3\]](#)

**Table 10-133. SMS\_CLASS\_ARBITER2**

|                         |             |                                                                                       |     |  |
|-------------------------|-------------|---------------------------------------------------------------------------------------|-----|--|
| <b>Address Offset</b>   | 0x0000 0158 | <b>Instance</b>                                                                       | SMS |  |
| <b>Physical Address</b> | 0x6C00 0158 | <b>Description</b>                                                                    |     |  |
| <b>Description</b>      |             | This register controls the arbitration parameters between the class 2 request groups. |     |  |
| <b>Type</b>             |             | RW                                                                                    |     |  |



| Bits  | Field Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset |
|-------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED       | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |
| 29:26 | BURST-COMPLETE | Delayed service until burst request complete<br>BurstComplete[k], k= 2 to 5 (BURST-COMPLETE[29] is for group number 5, BURST-COMPLETE[28] is for group number 4, BURST-COMPLETE[27] is for group number 3, BURST-COMPLETE[26] is for group number 2)<br>0x0: Group #k request to arbiter issued as soon as the first burst request is available<br>0x1: Group #k request to arbiter delayed until a complete burst transaction is buffered            | RW   | 0x0   |
| 25:20 | RESERVED       | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x00  |
| 19:12 | EXTENDEDGRANT  | Vector specifying the number of consecutive services a group is granted. 2 bits per group ExtendedGrant[2*k+1,2*k], k = 2 to 5 (EXTENDEDGRANT[19:18] is for group number 5, EXTENDEDGRANT[17:16] is for group number 4, EXTENDEDGRANT[15:14] is for group number 3, EXTENDEDGRANT[13:12] is for group number 2)<br>0x1: 1 service for group #k when granted<br>0x2: 2 services for group #k when granted<br>0x3: 3 services for group #k when granted | RW   | 0x55  |
| 11:6  | RESERVED       | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x00  |
| 5:2   | HIGHPRIOVECTOR | Vector allocating a higher priority to one of the class members. A single group may be given this attribute at a time. HighPrioVector[k], k= 2 to 5 (HIGHPRIOVECTOR[5] is for group number 5, HIGHPRIOVECTOR[4] is for group number 4, HIGHPRIOVECTOR[3] is for group number 3, HIGHPRIOVECTOR[2] is for group number 2)<br>0x0: Group #k has standard priority (LRU based).<br>0x1: Group #k has the highest priority over all other class members.  | RW   | 0x0   |
| 1:0   | RESERVED       | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0   |

**Table 10-134. Register Call Summary for Register SMS\_CLASS\_ARBITER2**

## SDRAM Controller (SDRC) Subsystem

- [Arbitration Policy: \[0\]](#) [\[1\]](#)
- [Memory-Access Scheduler Configuration: \[2\]](#)
- [Arbitration Decision: \[3\]](#)
- [SMS Register Summary: \[4\]](#)

**Table 10-135. SMS\_INTERCLASS\_ARBITER**

| <b>Address Offset</b>   | 0x0000 0160             | <b>Instance</b>                                                                                           | SMS             |       |
|-------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------|-----------------|-------|
| <b>Physical Address</b> | 0x6C00 0160             | <b>Description</b>                                                                                        |                 |       |
| <b>Description</b>      |                         | This register controls the PWM counter that defines the priority alternation between class 1 and class 2. |                 |       |
| <b>Type</b>             |                         | RW                                                                                                        |                 |       |
| 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 |       |
| RESERVED                | CLASS2PRIO              | RESERVED                                                                                                  | CLASS1PRIO      |       |
| Bits                    | Field Name              | Description                                                                                               | Type            | Reset |
| 31:24                   | RESERVED                | Write 0s for future compatibility. Read returns 0s.                                                       | RW              | 0x00  |
| 23:16                   | CLASS2PRIO              | Class 2 high-priority window width (clock cycle count). Do not set to 0x00.                               | RW              | 0x40  |
| 15:8                    | RESERVED                | Write 0s for future compatibility. Read returns 0s.                                                       | RW              | 0x00  |
| 7:0                     | CLASS1PRIO              | Class 1 high-priority window width (clock cycle count). Do not set to 0x00.                               | RW              | 0x40  |

**Table 10-136. Register Call Summary for Register SMS\_INTERCLASS\_ARBITER**

SDRAM Controller (SDRC) Subsystem

- Arbitration Decision: [0] [1]
- SMS Register Summary: [2]

**Table 10-137. SMS\_CLASS\_ROTATIONm**

| <b>Address Offset</b>   | 0x0000 0164 + (0x0000 0004 * m) | <b>Index</b>                                                                                                                                       | m = 0 to 2      |            |
|-------------------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Physical Address</b> | 0x6C00 0164 + (0x0000 0004 * m) |                                                                                                                                                    |                 |            |
| <b>Description</b>      |                                 | This register controls the number of consecutive services that is allocated to a thread whose transactions have been split by the rotation engine. |                 |            |
| <b>Type</b>             |                                 | RW                                                                                                                                                 |                 |            |
| 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 |            |
| RESERVED                |                                 |                                                                                                                                                    | NOFSERVICES     |            |
| Bits                    | Field Name                      | Description                                                                                                                                        | Type            | Reset      |
| 31:5                    | RESERVED                        | Write 0s for future compatibility. Read returns 0s.                                                                                                | RW              | 0x00000000 |
| 4:0                     | NOFSERVICES                     | Number of RE split transactions serviced consecutively when the thread gets granted by the arbitration logic.                                      | RW              | 0x01       |

**Table 10-138. Register Call Summary for Register SMS\_CLASS\_ROTATIONm**

SDRAM Controller (SDRC) Subsystem

- Arbitration Policy: [0]
- Arbitration Granularity: [1]
- SMS Register Summary: [2]

**Table 10-139. SMS\_ERR\_ADDR**

|                                                                                                           |                                                                              |
|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| <b>Address Offset</b>                                                                                     | 0x0000 0170                                                                  |
| <b>Physical Address</b>                                                                                   | 0x6C00 0170                                                                  |
| <b>Instance</b>                                                                                           | SMS                                                                          |
| <b>Description</b>                                                                                        | This register captures the address of an access that has generated an error. |
| <b>Type</b>                                                                                               | R                                                                            |
| <br><b>ERRORADDRESS</b> |                                                                              |

| Bits | Field Name   | Description                                                     | Type | Reset      |
|------|--------------|-----------------------------------------------------------------|------|------------|
| 31:0 | ERRORADDRESS | Access address that has generated an error (bit 31 is always 0) | R    | 0x00000000 |

**Table 10-140. Register Call Summary for Register SMS\_ERR\_ADDR**

SDRAM Controller (SDRC) Subsystem

- Error Logging: [0]
- SMS Register Summary: [1]

**Table 10-141. SMS\_ERR\_TYPE**

|                         |                                                                                              |
|-------------------------|----------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0174                                                                                  |
| <b>Physical Address</b> | 0x6C00 0174                                                                                  |
| <b>Instance</b>         | SMS                                                                                          |
| <b>Description</b>      | This register provides additional information about the access that has generated the error. |

|          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |
|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| 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        |
| RESERVED |

| Bits  | Field Name    | Description                                                                                                                                                             | Type | Reset |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | RESERVED      | Write 0s for future compatibility. Read returns 0s.                                                                                                                     | RW   | 0x00  |
| 26:24 | ERRORREGIONID | ID of the region that has been illegally accessed<br>0x0: Region 0<br>0x1: Region 1<br>...<br>0x7: Region 7<br>0x8 to 0xF: reserved                                     | R    | 0x0   |
| 23    | RESERVED      | Write 0s for future compatibility. Read returns 0s.                                                                                                                     | RW   | 0x0   |
| 22:20 | ERRORMCMD     | Interconnect command that caused the error                                                                                                                              | R    | 0x0   |
| 19:16 | ERRORCONNID   | Identifies the illegal access initiator interconnect ConnID of the illegal access initiator.<br>Refer to the top level documentation of the device using the SMS module | R    | 0x0   |
| 15:11 | RESERVED      | Write 0s for future compatibility.<br>Read returns 0s.                                                                                                                  | RW   | 0x00  |

## SDRAM Controller (SDRC) Subsystem

www.ti.com

| Bits | Field Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset |
|------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 10   | UNEXPECTEDADD   | <p>Request targeting non-defined rotation contexts (such as contexts 12, 13, 14, or 15) or non-defined L3 Interconnect request signals used for context number decoding.</p> <p>Read 0x0: No unexpected request received</p> <p>Write 0x0: No effect</p> <p>Read 0x1: A request has been received on the interconnect with address decoding targeting rotation contexts 12, 13, 14, or 15, or a signal used for context number decoding was undefined.</p> <p>Write 0x1: Clear UNEXPECTEDADD bit.</p> | RW   | 0x0   |
| 9    | UNEXPECTEDREQ   | <p>Unexpected request received during SMS idle state</p> <p>Read 0x0: No unexpected request received</p> <p>Write 0x0: No effect</p> <p>Read 0x1: A request has been received on the interconnect after the SMS was put in idle mode by the system power manager.</p> <p>Write 0x1: Clear the UNEXPECTEDREQ bit field.</p>                                                                                                                                                                            | RW   | 0x0   |
| 8    | ILLEGALCMD      | <p>Illegal command on the L3 interface</p> <p>Read 0x0: No illegal command received</p> <p>Write 0x0: No effect</p> <p>Read 0x1: Illegal command has been received.</p> <p>Write 0x1: Clear ILLEGALCMD bit field.</p>                                                                                                                                                                                                                                                                                 | RW   | 0x0   |
| 7:4  | RESERVED        | <p>Write 0s for future compatibility.</p> <p>Read returns 0s.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0   |
| 3    | ERRORSECOVERLAP | <p>Protection region overlapping error</p> <p>Read 0x0: No overlap violation detected</p> <p>Write 0x0: No effect</p> <p>Read 0x1: A protection region overlap violation has been detected.</p> <p>Write 0x1: Clear ERRORSECOVERLAP bit field.</p>                                                                                                                                                                                                                                                    | RW   | 0x0   |
| 2    | RESERVED        | Reserved for non-GP devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x0   |
| 1    | RESERVED        | Reserved for non-GP devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x0   |
| 0    | ERRORVALID      | <p>Error validity status - Must be explicitly cleared with a write transaction</p> <p>Read 0x0: No effect</p> <p>Write 0x0: All error fields no longer valid</p> <p>Read 0x1: Error detected and logged in the other error fields</p> <p>Write 0x1: Clear ERRORVALID bit field</p>                                                                                                                                                                                                                    | RW   | 0x0   |

**Table 10-142. Register Call Summary for Register SMS\_ERR\_TYPE**

## SDRAM Controller (SDRC) Subsystem

- [Violation Reporting: \[0\]](#)
- [Error Logging: \[1\] \[2\]](#)
- [SMS Register Summary: \[3\]](#)

**Table 10-143. SMS\_POW\_CTRL**

|                                                                                                                |                         |                       |                 |
|----------------------------------------------------------------------------------------------------------------|-------------------------|-----------------------|-----------------|
| <b>Address Offset</b>                                                                                          | 0x0000 0178             | <b>Instance</b>       | SMS             |
| <b>Physical Address</b>                                                                                        | 0x6C00 0178             | <b>Description</b>    |                 |
| This register controls the SMS power management in conjunction with the regular interconnect socket registers. |                         |                       |                 |
| <b>Type</b>                                                                                                    | RW                      |                       |                 |
| 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 |
| RESERVED                                                                                                       |                         |                       | IDLEDELAY       |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                    | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:8        | RESERVED          | Write 0s for future compatibility. Read returns 0s.                                                                                                   | RW          | 0x000000     |
| 7:0         | IDLEDELAY         | Delay (expressed in L3 clock cycle units) before autoidle, that is, before disabling the SMS functional clock when no more traffic in the SMS module. | RW          | 0x80         |

**Table 10-144. Register Call Summary for Register SMS\_POW\_CTRL**

SDRAM Controller (SDRC) Subsystem

- [Module Power Saving: \[0\]](#)
- [SMS Register Summary: \[1\]](#)

**Table 10-145. SMS\_ROT\_CONTROLn**

|                         |                                 |                       |                                                                                  |
|-------------------------|---------------------------------|-----------------------|----------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0180 + (0x0000 0010 * n) | <b>Index</b>          | n = 0 to 11                                                                      |
| <b>Physical Address</b> | 0x6C00 0180 + (0x0000 0010 * n) | <b>Instance</b>       | SMS                                                                              |
| <b>Description</b>      |                                 |                       | This register configures the virtual rotated frame buffer module for context #n. |
| <b>Type</b>             | RW                              |                       |                                                                                  |
| 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                                                                  |
| RESERVED                |                                 |                       | PH<br>RESERVED<br>PW<br>RESERVED<br>PS                                           |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:11       | RESERVED          | Write 0s for future compatibility. Read returns 0s.                                                                | RW          | 0x000000     |
| 10:8        | PH                | Exponent based 2 value, $2^{\text{ph}}$ indicates the page height in bytes for context #n.                         | RW          | 0x0          |
| 7           | RESERVED          | Write 0s for future compatibility. Read returns 0s.                                                                | RW          | 0x0          |
| 6:4         | PW                | Exponent based 2 value, $2^{\text{pw}}$ indicates the page width in bytes for context #n.                          | RW          | 0x0          |
| 3:2         | RESERVED          | Write 0s for future compatibility. Read returns 0s.                                                                | RW          | 0x0          |
| 1:0         | PS                | Exponent based 2 value, $2^{\text{ps}}$ indicates the pixel size in bytes for context #n. A value of 3 is invalid. | RW          | 0x0          |

**Table 10-146. Register Call Summary for Register SMS\_ROT\_CONTROLn**

SDRAM Controller (SDRC) Subsystem

- [Rotation Engine: \[0\] \[1\]](#)
- [VRFB Context Configuration: \[2\] \[3\] \[4\]](#)
- [Applicative Use Case and Tips: \[5\] \[6\] \[7\]](#)
- [SMS Register Summary: \[8\]](#)

**Table 10-147. SMS\_ROT\_SIZEn**

|                         |                                                                |                 |             |
|-------------------------|----------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 0184 + (0x0000 0010 * n)                                | <b>Index</b>    | n = 0 to 11 |
| <b>Physical Address</b> | 0x6C00 0184 + (0x0000 0010 * n)                                | <b>Instance</b> | SMS         |
| <b>Description</b>      | This register configures the bank organization for context #n. |                 |             |
| <b>Type</b>             | RW                                                             |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | IMAGEHEIGHT             | RESERVED              | IMAGEWIDTH      |

| Bits  | Field Name  | Description                                         | Type | Reset |
|-------|-------------|-----------------------------------------------------|------|-------|
| 31:27 | RESERVED    | Write 0s for future compatibility. Read returns 0s. | RW   | 0x00  |
| 26:16 | IMAGEHEIGHT | Image height in pixels for context #n               | RW   | 0x000 |
| 15:11 | RESERVED    | Write 0s for future compatibility. Read returns 0s. | RW   | 0x00  |
| 10:0  | IMAGEWIDTH  | Image width in pixels for context #n                | RW   | 0x000 |

**Table 10-148. Register Call Summary for Register SMS\_ROT\_SIZEn**

SDRAM Controller (SDRC) Subsystem

- [Rotation Engine: \[0\]](#) [\[1\]](#) [\[2\]](#)
- [VRFB Context Configuration: \[3\]](#) [\[4\]](#)
- [Applicative Use Case and Tips: \[5\]](#) [\[6\]](#)
- [SMS Register Summary: \[7\]](#)

**Table 10-149. SMS\_ROT\_PHYSICAL\_BAn**

|                         |                                                                             |                 |             |
|-------------------------|-----------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 0188 + (0x0000 0010 * n)                                             | <b>Index</b>    | n = 0 to 11 |
| <b>Physical Address</b> | 0x6C00 0188 + (0x0000 0010 * n)                                             | <b>Instance</b> | SMS         |
| <b>Description</b>      | This register allows to configure the physical base address for context #n. |                 |             |
| <b>Type</b>             | RW                                                                          |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | PHYSICALBA              |                       |                 |

| Bits | Field Name | Description                                                       | Type | Reset      |
|------|------------|-------------------------------------------------------------------|------|------------|
| 31   | RESERVED   | Write 0s for future compatibility. Read returns 0s.               | RW   | 0x0        |
| 30:0 | PHYSICALBA | Physical base address of the frame buffer for context #n in SDRAM | RW   | 0x00000000 |

**Table 10-150. Register Call Summary for Register SMS\_ROT\_PHYSICAL\_BAn**

SDRAM Controller (SDRC) Subsystem

- [Rotation Engine: \[0\]](#)
- [VRFB Context Configuration: \[1\]](#)
- [Applicative Use Case and Tips: \[2\]](#)
- [Physical vs Virtual Address Spaces: \[3\]](#)
- [SMS Register Summary: \[4\]](#)

## 10.2.8 SDRC Register Manual

### 10.2.8.1 SDRC Instance Summary

[Table 10-151](#) gives some details on the SDRC module instance.

**Table 10-151. SDRC Instance Summary**

| Module Name | Base Address | Size      |
|-------------|--------------|-----------|
| SDRC        | 0x6D00 0000  | 64K bytes |

### 10.2.8.2 SDRC Register Summary

[Table 10-152](#) summarizes the SDRC register mapping.

**Table 10-152. SDRC Register Summary**

| Register Name                     | Type | Register Width (Bits) | Address Offset                     | Physical Address                   |
|-----------------------------------|------|-----------------------|------------------------------------|------------------------------------|
| SDRC_REVISION                     | R    | 32                    | 0x0000 0000                        | 0x6D00 0000                        |
| SDRC_SYSCONFIG                    | RW   | 32                    | 0x0000 0010                        | 0x6D00 0010                        |
| SDRC_SYSSTATUS                    | R    | 32                    | 0x0000 0014                        | 0x6D00 0014                        |
| SDRC_CS_CFG                       | RW   | 32                    | 0x0000 0040                        | 0x6D00 0040                        |
| SDRC_SHARING                      | RW   | 32                    | 0x0000 0044                        | 0x6D00 0044                        |
| SDRC_ERR_ADDR                     | R    | 32                    | 0x0000 0048                        | 0x6D00 0048                        |
| SDRC_ERR_TYPE                     | RW   | 32                    | 0x0000 004C                        | 0x6D00 004C                        |
| SDRC_DLLA_CTRL                    | RW   | 32                    | 0x0000 0060                        | 0x6D00 0060                        |
| SDRC_DLLA_STATUS                  | R    | 32                    | 0x0000 0064                        | 0x6D00 0064                        |
| SDRC_POWER_REG                    | RW   | 32                    | 0x0000 0070                        | 0x6D00 0070                        |
| SDRC_MCFG_p <sup>(1)</sup>        | RW   | 32                    | 0x0000 0080<br>+ (0x0000 0030 * p) | 0x6D00 0080<br>+ (0x0000 0030 * p) |
| SDRC_MR_p <sup>(1)</sup>          | RW   | 32                    | 0x0000 0084<br>+ (0x0000 0030 * p) | 0x6D00 0084<br>+ (0x0000 0030 * p) |
| SDRC_EMR2_p <sup>(1)</sup>        | RW   | 32                    | 0x0000 008C<br>+ (0x0000 0030 * p) | 0x6D00 008C<br>+ (0x0000 0030 * p) |
| SDRC_ACTIM_CTRLA_p <sup>(1)</sup> | RW   | 32                    | 0x0000 009C<br>+ (0x0000 0028 * p) | 0x6D00 009C<br>+ (0x0000 0028 * p) |
| SDRC_ACTIM_CTRLB_p <sup>(1)</sup> | RW   | 32                    | 0x0000 00A0<br>+ (0x0000 0028 * p) | 0x6D00 00A0<br>+ (0x0000 0028 * p) |
| SDRC_RFR_CTRL_p <sup>(1)</sup>    | RW   | 32                    | 0x0000 00A4<br>+ (0x0000 0030 * p) | 0x6D00 00A4<br>+ (0x0000 0030 * p) |
| SDRC_MANUAL_p <sup>(1)</sup>      | RW   | 32                    | 0x0000 00A8<br>+ (0x0000 0030 * p) | 0x6D00 00A8<br>+ (0x0000 0030 * p) |

<sup>(1)</sup> p = 0 to 1.

### 10.2.8.3 SDRC Register Description

This section provides a description of SDRC registers.

**Table 10-153. SDRC\_REVISION**

|                         |                                                                                     |                         |                 |                 |      |
|-------------------------|-------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0000                                                                         | <b>Physical Address</b> | 0x6D00 0000     | <b>Instance</b> | SDRC |
| <b>Description</b>      | This register contains the IP revision code. This code is specified at design time. |                         |                 |                 |      |
| <b>Type</b>             | R                                                                                   |                         |                 |                 |      |
| 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 |                 |      |
| RESERVED                |                                                                                     |                         |                 | REV             |      |

  

| Bits | Field Name | Description                                                                                                | Type | Reset              |
|------|------------|------------------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | RESERVED   | Read returns 0.                                                                                            | R    | 0x000000           |
| 7:0  | REV        | IP revision code<br>[7:4]: Major revision<br>[3:0]: Minor revision<br>Examples: 0x10 for 1.0, 0x21 for 2.1 | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data**Table 10-154. Register Call Summary for Register SDRC\_REVISION**

## SDRAM Controller (SDRC) Subsystem

- [IP Revision: \[0\]](#)
- [SDRC Register Summary: \[1\]](#)

**Table 10-155. SDRC\_SYSCONFIG**

|                         |                                                                    |                         |                 |                 |                                               |
|-------------------------|--------------------------------------------------------------------|-------------------------|-----------------|-----------------|-----------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0010                                                        | <b>Physical Address</b> | 0x6D00 0010     | <b>Instance</b> | SDRC                                          |
| <b>Description</b>      | This register controls the various parameters of the interconnect. |                         |                 |                 |                                               |
| <b>Type</b>             | RW                                                                 |                         |                 |                 |                                               |
| 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 |                 |                                               |
| RESERVED                |                                                                    |                         |                 | NOMEMORYMRS     | RESERVED IDLEMODE RESERVED SOFTRESET RESERVED |

  

| Bits | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                             | Type | Reset    |
|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED    | Write 0s for future compatibility<br>Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0x000000 |
| 8    | NOMEMORYMRS | No external memory MRS command<br><br>0x0: When set to 0, the SDRC internal <a href="#">SDRC_MR_p</a> and <a href="#">SDRC_EMR2_p</a> registers (both CS) are written and MR, EMR2 commands are performed to the corresponding registers of the external SDRAM.<br><br>0x1: When set to 1, only SDRC internal <a href="#">SDRC_MR_p</a> and <a href="#">SDRC_EMR2_p</a> registers (both CS) are written, no MR or EMR2 commands are performed to SDRAM. | RW   | 0x0      |
| 7:5  | RESERVED    | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0      |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                         | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4:3  | IDLEMODE   | Power management Req/Ack control<br><br>0x0: Reserved - Do not use.<br>0x1: Reserved - Do not use.<br>0x2: Smart Idle - Acknowledgment to an idle request is based on the internal activity of the module. Issued when the SDRC enters self-refresh.<br>0x3: Reserved - Do not use. | RW   | 0x2   |
| 2    | RESERVED   | Write 0s for future compatibility. Read returns 0                                                                                                                                                                                                                                   | RW   | 0x0   |
| 1    | SOFTRESET  | Software reset<br><br>0x0: Normal mode (no reset applied)<br>0x1: Software reset activated                                                                                                                                                                                          | RW   | 0x0   |
| 0    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                  | RW   | 0x0   |

**Table 10-156. Register Call Summary for Register SDRC\_SYSCONFIG**

SDRAM Controller (SDRC) Subsystem

- [Software Reset: \[0\]](#)
- [System Power Management: \[1\]](#)
- [Reset Behavior: \[2\]](#)
- [Mode Register Programming and Modes of Operation: \[3\]](#)
- [SDRC Register Summary: \[4\]](#)

**Table 10-157. SDRC\_SYSSTATUS**

|                         |                                                                        |                         |                 |                 |           |
|-------------------------|------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-----------|
| <b>Address Offset</b>   | 0x0000 0014                                                            | <b>Physical Address</b> | 0x6D00 0014     | <b>Instance</b> | SDRC      |
| <b>Description</b>      | This register provides module status, excluding interrupt status info. |                         |                 |                 |           |
| <b>Type</b>             | R                                                                      |                         |                 |                 |           |
| 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 | RESERVED        | RESERVED  |
|                         |                                                                        |                         |                 |                 | RESETDONE |

| Bits | Field Name | Description                                                                                                                     | Type | Reset    |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | RESERVED   | Reserved for module-specific status information<br>Read returns 0.                                                              | R    | 0x000000 |
| 7:1  | RESERVED   | Reserved for interconnect socket status information<br>Read returns 0.                                                          | R    | 0x00     |
| 0    | RESETDONE  | Internal reset monitoring<br><br>0x0: Internal module reset is ongoing<br>0x1: Reset completed - The module is ready to be used | R    | 0x-      |

**Table 10-158. Register Call Summary for Register SDRC\_SYSSTATUS**

SDRAM Controller (SDRC) Subsystem

- [Reset Behavior: \[0\]](#)
- [SDRC Register Summary: \[1\]](#)

**Table 10-159. SDRC\_CS\_CFG**

|                       |                                                                                                                                                                                                                             |                         |             |                 |      |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 0040                                                                                                                                                                                                                 | <b>Physical Address</b> | 0x6D00 0040 | <b>Instance</b> | SDRC |
| <b>Description</b>    | This register configures the start address of CS1 address space. Must be aligned on a boundary that is a multiple of the size of the attached memory, or of the next power of two if the memory size is not a power of two. |                         |             |                 |      |
| <b>Type</b>           | RW                                                                                                                                                                                                                          |                         |             |                 |      |

| 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 |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----------|---|--------------|---|---|---|
| RESERVED    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |          |   |              |   |   |   |
| CS1STARTLOW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | RESERVED |   | CS1STARTHIGH |   |   |   |

| Bits  | Field Name   | Description                                                               | Type | Reset    |
|-------|--------------|---------------------------------------------------------------------------|------|----------|
| 31:10 | RESERVED     | Write 0s for future compatibility. Read returns 0.                        | RW   | 0x000000 |
| 9:8   | CS1STARTLOW  | CS1 address space start address (lower add bits a1:a0) / 32MB unit        | RW   | 0x0      |
| 7:4   | RESERVED     | Write 0s for future compatibility. Read returns 0.                        | RW   | 0x0      |
| 3:0   | CS1STARTHIGH | CS1 address space start address (upper add bits a5:a4:a3:a2) / 128MB unit | RW   | 0x4      |

**Table 10-160. Register Call Summary for Register SDRC\_CS\_CFG**

## SDRAM Controller (SDRC) Subsystem

- CS0-CS1 Memory Spaces: [0] [1] [2] [3] [4]
- Chip-Select Configuration: [5] [6]
- CS Memory Spaces: [7] [8] [9] [10] [11] [12] [13]
- SDRC Register Summary: [14]

**Table 10-161. SDRC\_SHARING**

|                       |                                                                                     |                         |             |                 |      |
|-----------------------|-------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 0044                                                                         | <b>Physical Address</b> | 0x6D00 0044 | <b>Instance</b> | SDRC |
| <b>Description</b>    | This register specifies the SDRC attached memory size and position on the SDRC IOs. |                         |             |                 |      |
| <b>Type</b>           | RW                                                                                  |                         |             |                 |      |

| 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 |
|----------|------|----------|----|----|----|----|----|----|----|----|----|----|----|-----------|-----------|--------------|----------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED | LOCK | RESERVED |    |    |    |    |    |    |    |    |    |    |    | CS1MUXCFG | CS0MUXCFG | SDRCTRISTATE | RESERVED |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                            | Type | Reset              |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------------|
| 31   | RESERVED   | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                  | RW   | 0x0                |
| 30   | LOCK       | Read-only access lock bit<br><br>0x0: This register is fully writable.<br><br>0x1: When this bit is set, the register can not be unset until next reset of the module. | RW   | See <sup>(1)</sup> |

<sup>(1)</sup> Reset value is copied from the system control module. See the note in [Section 10.2.5.3.2](#) and [Section 13.4.9, SDRC Registers](#), in [Chapter 13, System Control Module](#).

| Bits  | Field Name   | Description                                                                                                                                                                                                                                                                                      | Type | Reset              |
|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------------|
| 29:15 | RESERVED     | Write 0s for future compatibility.<br>Read returns 0s.                                                                                                                                                                                                                                           | RW   | See <sup>(1)</sup> |
| 14:12 | CS1MUXCFG    | Identifies the SDRC pins used by CS1<br><br>0x0: 32-bit SDRAM on Datalane[31:0]<br>0x1: 32-bit SDRAM on Datalane[31:0]<br>0x2: 16-bit SDRAM on Datalane[31:16]<br>0x3: 16-bit SDRAM on Datalane[16:0]<br>0x4: Reserved<br>0x5: Reserved<br>0x6: Reserved<br>0x7: 16-bit SDRAM on Datalane[31:16] | RW   | See <sup>(1)</sup> |
| 11:9  | CS0MUXCFG    | Identifies the SDRC pins used by CS0<br><br>0x0: 32-bit SDRAM on Datalane[31:0]<br>0x1: 32-bit SDRAM on Datalane[31:0]<br>0x2: 16-bit SDRAM on Datalane[31:16]<br>0x3: 16-bit SDRAM on Datalane[16:0]<br>0x4: Reserved<br>0x5: Reserved<br>0x6: Reserved<br>0x7: 16-bit SDRAM on Datalane[31:16] | RW   | See <sup>(1)</sup> |
| 8     | SDRCTRISTATE | Static 3-state command for the SDRC I/O pads<br><br>0x0: All SDRC interface pins are set to hi-Z.<br>0x1: Normal mode: SDRC drives the I/O pads based on the memory traffic.                                                                                                                     | RW   | See <sup>(2)</sup> |
| 7:0   | RESERVED     | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                              | RW   | See <sup>(2)</sup> |

<sup>(2)</sup> Reset value is copied from the system control module. See the note in [Section 10.2.5.3.2](#) and [Section 13.4.9, SDRC Registers](#), in [Chapter 13, System Control Module](#).

**Table 10-162. Register Call Summary for Register SDRC\_SHARING**

## SDRAM Controller (SDRC) Subsystem

- [CS0-CS1 Memory Spaces: \[0\] \[1\]](#)
- [Data Multiplexing During Write Operations: \[2\] \[3\] \[4\]](#)
- [Data Demultiplexing During Read Operations: \[5\] \[6\]](#)
- [Memory Configuration: \[7\] \[8\]](#)
- [SDRC Register Summary: \[9\]](#)

**Table 10-163. SDRC\_ERR\_ADDR**

|                         |                                                                                             |                         |                 |                 |      |
|-------------------------|---------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0048                                                                                 | <b>Physical Address</b> | 0x6D00 0048     | <b>Instance</b> | SDRC |
| <b>Description</b>      | This register captures the address of the last illegal access received on the interconnect. |                         |                 |                 |      |
| <b>Type</b>             | R                                                                                           |                         |                 |                 |      |
| 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 | ERRORADDRESS    |      |

| Bits | Field Name   | Description                                     | Type | Reset      |
|------|--------------|-------------------------------------------------|------|------------|
| 31:0 | ERRORADDRESS | Address of illegal access (Bit 31 is always 0.) | R    | 0x00000000 |

**Table 10-164. Register Call Summary for Register SDRC\_ERR\_ADDR**

SDRAM Controller (SDRC) Subsystem

- Error Management: [0]
- SDRC Register Summary: [1]

**Table 10-165. SDRC\_ERR\_TYPE**

|                       |                                                                              |                         |             |                 |      |
|-----------------------|------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 004C                                                                  | <b>Physical Address</b> | 0x6D00 004C | <b>Instance</b> | SDRC |
| <b>Description</b>    | This register provides additional information about the last illegal access. |                         |             |                 |      |
| <b>Type</b>           | RW                                                                           |                         |             |                 |      |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                               | Type | Reset   |
|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED    | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0x00000 |
| 11:8  | ERRORCONNID | Identifies the interconnect ConnID of the illegal access initiator: Refer to the top level documentation of the device using the SDRC module.                                                                                                                                                                                                                                                                                                             | RW   | 0x0     |
| 7     | RESERVED    | Write 0 for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0x0     |
| 6:4   | ERRORMCMD   | System command of the transaction that caused the error (3-bit field)                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0     |
| 3:2   | ERRORADD    | Flag that indicates access is to an illegal address<br><br>Read 0x0: The system request was to an address outside the memory space.<br><br>Write 0x0: Clear ErrorAdd bit field.<br><br>Read 0x1: The system request was to an address outside the register space.<br><br>Write 0x1: No effect<br><br>Read 0x2: No Err Add. Not an address error<br><br>Write 0x2: No effect<br><br>Read 0x3: No Err Add. Not an address error<br><br>Write 0x3: No effect | RW   | 0x2     |
| 1     | ERRORDPD    | Transaction error while the memory is in deep-power-down mode<br><br>Read 0x0: The memory was not in deep-power-down mode when the error occurred.<br><br>Write 0x0: No effect<br><br>Read 0x1: The error is due to an unexpected access while the memory was in deep-power-down mode.<br><br>Write 0x1: Clear the ErrorDPD bit field.                                                                                                                    | RW   | 0x0     |
| 0     | ERRORVALID  | Error validity status - Must be explicitly cleared with a write 0 transaction.<br><br>Read 0x0: All error fields no longer valid<br><br>Write 0x0: Clear ErrorValid bit field<br><br>Read 0x1: Error detected and logged in the other error fields<br><br>Write 0x1: No effect                                                                                                                                                                            | RW   | 0x0     |

**Table 10-166. Register Call Summary for Register SDRC\_ERR\_TYPE**

SDRAM Controller (SDRC) Subsystem

- Error Management: [0] [1] [2] [3] [4]
- SDRC Register Summary: [5]

**Table 10-167. SDRC\_DLL\_A\_CTRL**

|                       |                                                                                                             |                         |             |                 |      |
|-----------------------|-------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 0060                                                                                                 | <b>Physical Address</b> | 0x6D00 0060 | <b>Instance</b> | SDRC |
| <b>Description</b>    | This register controls the SDRC DLL A resource used for fine timing tuning on a double-data-rate interface. |                         |             |                 |      |
| <b>Type</b>           | RW                                                                                                          |                         |             |                 |      |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name            | Description                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|-------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | FIXEDDELAY            | Phase offset value in ModeFixedDelay mode. Maximum frequency supported in this mode is 83 MHz. FIXEDDELAY steps are defined after DLL cell characterization.                                                                                                                                                                                                                | RW   | 0x00  |
| 23:16 | MODEFIXEDDELAYINITLAT | Initial latency before first request to be processed in ModeFixedDelay mode <sup>(1)</sup><br>0x0: no initial latency before first access<br>0x1: 2 clock cycles before first access<br>0x2: 4 clock cycles before first access<br>0x3: 6 clock cycles before first access<br>0x4 : 8 clock cycles before first access<br>...<br>0xFF: 510 clock cycles before first access | RW   | 0x00  |
| 15:8  | RESERVED              | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                          | RW   | 0x00  |
| 7     | RESERVED              | Reserved                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0x0   |
| 6:5   | DLLMODEONIDLREQ       | Selects the DLL mode upon hardware idle request<br>0x0: DLL in Power-down mode upon hardware idle request<br>0x1: DLL in DLL idle mode upon hardware idle request<br>0x2: No action upon hardware idle request. Input clock frequency must not be changed.<br>0x3: Reserved for future use (no action upon hardware idle request).                                          | RW   | 0x0   |
| 4     | DLLIDLE               | Enables the DLL Idle mode<br>0x0: DLL Idle mode disabled<br>0x1: DLL Idle mode enabled                                                                                                                                                                                                                                                                                      | RW   | 0x0   |
| 3     | ENADLL                | Enables DLL<br>0x0: DLL disabled<br>0x1: DLL enabled                                                                                                                                                                                                                                                                                                                        | RW   | 0x0   |

<sup>(1)</sup> The DLL characterization shows that this feature is not useful and that this value must be left at 0x0.

## SDRAM Controller (SDRC) Subsystem

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 2    | LOCKDLL    | Selects the DLL functionality between the TrackingDelay mode (previously called lock mode) or the ModeFixedDelay mode (previously called unlock mode). The DLL mode is updated in the DLL cell after:<br>- DLLIDLE mode<br>- DLL power-down mode<br><br>0x0: LOCKDLL at 0 puts the DLL in TrackingDelay mode (tracking counter started).<br><br>0x1: LOCKDLL at 1 puts the DLL in ModeFixedDelay mode. The fixed delay defined in FIXEDDELAY bit field is used to delay DQS lines for read accesses. | RW   | 0x0   |
| 1    | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0x0   |
| 0    | RESERVED   | Write 0s for future compatibility. Reads return zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW   | 0x0   |

**Table 10-168. Register Call Summary for Register SDRC\_DLLA\_CTRL**

## SDRAM Controller (SDRC) Subsystem

- [Power Management: \[0\]](#)
- [Power-Saving Features: \[1\] \[2\]](#)
- [DLL/CDL Configuration: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\]](#)
- [Memory Power Management: \[9\] \[10\]](#)
- [SDRC Register Summary: \[11\]](#)

**Table 10-169. SDRC\_DLLA\_STATUS**

|                       |                                                         |                         |             |                 |      |
|-----------------------|---------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 0064                                             | <b>Physical Address</b> | 0x6D00 0064 | <b>Instance</b> | SDRC |
| <b>Description</b>    | This register reflects the current status of the DLL A. |                         |             |                 |      |
| <b>Type</b>           | R                                                       |                         |             |                 |      |



| Bits | Field Name | Description                                                                   | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED   | Reads return zeros.                                                           | R    | 0x00000000 |
| 2    | LOCKSTATUS | DLL lock status<br><br>0x0: The DLL is not locked.<br>0x1: The DLL is locked. | R    | 0x0        |
| 1    | RESERVED   | Reads return zero.                                                            | R    | 0x0        |
| 0    | RESERVED   | Reads return zero.                                                            | R    | 0x0        |

**Table 10-170. Register Call Summary for Register SDRC\_DLLA\_STATUS**

## SDRAM Controller (SDRC) Subsystem

- [SDRC Register Summary: \[0\]](#)

**Table 10-171. SDRC\_POWER\_REG**

|                         |                                                                                                     |                       |                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |             |               |         |           |        |          |            |
|-------------------------|-----------------------------------------------------------------------------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|-------------|---------------|---------|-----------|--------|----------|------------|
| <b>Address Offset</b>   | 0x0000 0070                                                                                         |                       |                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |             |               |         |           |        |          |            |
| <b>Physical Address</b> | 0x6D00 0070                                                                                         |                       |                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |             |               |         |           |        |          |            |
| <b>Description</b>      | This SDRC power-management register defines the global power-management policy (shared by CS0/CS1). |                       |                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |             |               |         |           |        |          |            |
| <b>Type</b>             | RW                                                                                                  |                       |                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |             |               |         |           |        |          |            |
| 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                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |             |               |         |           |        |          |            |
| RESERVED                | WAKEUPPROC                                                                                          | RESERVED              | AUTOCOUNT                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  | SRFRONRESET | SRFRONIDLEREQ | CLKCTRL | EXTCLKDIS | PWDENA | RESERVED | PAGEPOLICY |
| 31:27                   | RESERVED                                                                                            |                       | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  | RW          |               |         |           | 0x00   |          |            |
| 26                      | WAKEUPPROC                                                                                          |                       | Select if after a SDRC wakeup in DDR mode (in DLL tracking-delay mode), the first request is stalled during 500 cycles latency or until the lock signal from the DLL/CDL analog cell is asserted.<br><br>0x0: SDRC allows DDR access after 500 L3 clock cycles.<br>0x1: SDRC allows DDR access as soon as DLL LOCKSTATUS bit is 1. |  |  |  |  |  |  |  | RW          |               |         |           | 0x0    |          |            |
| 25:24                   | RESERVED                                                                                            |                       | Write 0s for future compatibility.<br>Read returns 0.                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  | RW          |               |         |           | 0x0    |          |            |
| 23:8                    | AUTOCOUNT                                                                                           |                       | 16-bit programmable count value used for delayed automatic clock gating and self-refresh entry, assuming CLKCTRL field is not 0                                                                                                                                                                                                    |  |  |  |  |  |  |  | RW          |               |         |           | 0x0000 |          |            |
| 7                       | SRFRONRESET                                                                                         |                       | Enter self refresh when a warm reset is applied:<br><br>0x0: Feature disabled<br>0x1: Feature enabled                                                                                                                                                                                                                              |  |  |  |  |  |  |  | RW          |               |         |           | 0x1    |          |            |
| 6                       | SRFRONIDLEREQ                                                                                       |                       | Enter self refresh when on hardware idle request:<br><br>0x0: Feature disabled<br>0x1: Feature enabled                                                                                                                                                                                                                             |  |  |  |  |  |  |  | RW          |               |         |           | 0x0    |          |            |
| 5:4                     | CLKCTRL                                                                                             |                       | Clock control feature defines clock gating and self refresh:<br><br>0x0: No auto clk feature turned on<br>0x1: Enable internal clock gating on timeout of Auto_cnt<br>0x2: Enable self-refresh on timeout of Auto_cnt<br>0x3: Reserved                                                                                             |  |  |  |  |  |  |  | RW          |               |         |           | 0x0    |          |            |
| 3                       | EXTCLKDIS                                                                                           |                       | Disable the clock provided to the external memories:<br><br>0x0: Enable clock<br>0x1: Disable clock- Logical 0 is applied.                                                                                                                                                                                                         |  |  |  |  |  |  |  | RW          |               |         |           | 0x0    |          |            |
| 2                       | PWDENA                                                                                              |                       | Activate the power-down mode of the target memory through CKE pin.<br><br>0x0: Power-down mode feature disabled<br>0x1: Power-down mode feature enabled                                                                                                                                                                            |  |  |  |  |  |  |  | RW          |               |         |           | 0x1    |          |            |
| 1                       | RESERVED                                                                                            |                       | Write 0 for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  | RW          |               |         |           | 0x0    |          |            |
| 0                       | PAGEPOLICY                                                                                          |                       | Page/segment closure policy with respect to power versus bandwidth trade-off - Must be set to 1<br><br>0x0: Reserved - must not be used<br>0x1: High-power/high bandwidth mode (HPHB)                                                                                                                                              |  |  |  |  |  |  |  | RW          |               |         |           | 0x1    |          |            |

**Table 10-172. Register Call Summary for Register SDRC\_POWER\_REG**

## SDRAM Controller (SDRC) Subsystem

- [Hardware Reset: \[0\]](#)
- [Power Management: \[1\]](#)
- [Refresh Management: \[2\]](#)
- [Power-Saving Features: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\]](#)
- [Reset Behavior: \[15\] \[16\]](#)
- [Page Closure Strategy: \[17\]](#)
- [Memory Power Management: \[18\] \[19\] \[20\]](#)
- [SDRC Register Summary: \[21\]](#)

**Table 10-173. SDRC\_MCFG\_p**

|                         |                                                           |                 |            |
|-------------------------|-----------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0080 + (0x0000 0030 * p)                           | <b>Index</b>    | p = 0 to 1 |
| <b>Physical Address</b> | 0x6D00 0080 + (0x0000 0030 * p)                           | <b>Instance</b> | SDRC       |
| <b>Description</b>      | This register provides the memory configuration register. |                 |            |
| <b>Type</b>             | RW                                                        |                 |            |

**Register Description for ADDRMUXLEGACY = 0x1**

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                    | Type | Reset                   |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------------------|
| 31    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                             | RW   | 0x0                     |
| 30    | LOCKSTATUS | Read-only access lock bit<br><br>0x0: This register is fully writable<br><br>0x1: When this bit is set, the register can not be unset until next reset of the module.                                                                                                                                          | RW   | See <a href="#">(1)</a> |
| 29:27 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                             | RW   | See <a href="#">(1)</a> |
| 26:24 | RASWIDTH   | RAS address width<br><br>0x0: RAS width = 11 bits<br>0x1: RAS width = 12 bits<br>0x2: RAS width = 13 bits<br>0x3: RAS width = 14 bits<br>0x4: RAS width = 15 bits<br>0x5: RAS width = 16 bits - Must not be used<br>0x6: RAS width = 17 bits - Must not be used<br>0x7: RAS width = 18 bits - Must not be used | RW   | See <a href="#">(1)</a> |
| 23    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                             | RW   | See <a href="#">(1)</a> |

<sup>(1)</sup> Reset value is copied from the system control module. See the note in [Section 10.2.5.3.2](#) and [Section 13.4.9, SDRC Registers](#), in [Chapter 13, System Control Module](#).

| Bits  | Field Name     | Description                                                                                                                                                                                                                                  | Type | Reset              |
|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------------|
| 22:20 | CASWIDTH       | CAS address width<br>0x0: CAS width = 5 bits<br>0x1: CAS width = 6 bits<br>0x2: CAS width = 7 bits<br>0x3: CAS width = 8 bits<br>0x4: CAS width = 9 bits<br>0x5: CAS width = 10 bits<br>0x6: CAS width = 11 bits<br>0x7: CAS width = 12 bits | RW   | See <sup>(1)</sup> |
| 19    | ADDRMUXLEGACY  | Selects the fixed address-muxing scheme or the flexible address-muxing scheme<br>0x0: Fixed address mux scheme<br>0x1: Flexible address mux scheme                                                                                           | RW   | See <sup>(1)</sup> |
| 18    | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                           | RW   | See <sup>(1)</sup> |
| 17:8  | RAMSIZE        | RAM address space size number of 2-MB chunks                                                                                                                                                                                                 | RW   | See <sup>(1)</sup> |
| 7:6   | BANKALLOCATION | SDRAM banks mapping. Selects the position of the bank address, the row address, and the column address in the system address.<br>0x0: Bank-row-column<br>0x1: Bank1-row-bank0-column<br>0x2: Row-bank-column<br>0x3: Reserved                | RW   | See <sup>(1)</sup> |
| 5     | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                           | RW   | See <sup>(2)</sup> |
| 4     | B32NOT16       | External SDRAM bus width<br>0x0: External SDRAM device is x16 bit.<br>0x1: External SDRAM device is x32 bit.                                                                                                                                 | RW   | See <sup>(2)</sup> |
| 3     | DEEPPD         | Indicates if the memory supports deep-power-down mode<br>0x0: No deep-power-down mode support<br>0x1: The memory supports deep-power-down mode                                                                                               | RW   | See <sup>(2)</sup> |
| 2     | DDRTYPE        | DDR memory type (assuming RAMTYPE = 01)<br>0x0: Mobile DDR<br>0x1: Reserved for future use                                                                                                                                                   | RW   | See <sup>(2)</sup> |
| 1:0   | RAMTYPE        | Memory type<br>0x0: SDR-SDRAM (single data rate)<br>0x1: DDR-SDRAM (double data rate)<br>0x2: Reserved<br>0x3: Reserved                                                                                                                      | RW   | See <sup>(2)</sup> |

<sup>(2)</sup> Reset value is copied from the system control module. See the note in [Section 10.2.5.3.2](#) and [Section 13.4.9, SDRC Registers](#), in [Chapter 13, System Control Module](#).

**Table 10-174. Register Call Summary for Register SDRC\_MCFG\_p**

SDRAM Controller (SDRC) Subsystem

- [Address Multiplexing: \[0\] \[1\] \[2\]](#)
- [CS0-CS1 Memory Spaces: \[3\] \[4\]](#)
- [Address Multiplexing: \[5\] \[6\] \[7\] \[8\]](#)
- [Bank Allocation Setting: \[9\] \[10\] \[11\]](#)
- [Chip-Select Configuration: \[13\] \[14\] \[15\]](#)
- [Memory Configuration: \[16\] \[17\] \[18\]](#)
- [CS Memory Spaces: \[19\] \[20\] \[21\]](#)
- [SDRC Register Summary: \[22\]](#)

## Register Description for ADDRMUXLEGACY = 0x0

| 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 |
|----------|------------|----------|----|----|----|----|----|---------|---------------|----------|----|----|----|----|----|----|----|----|----|----|----|---|---|----------------|----------|----------|--------|----------|---------|---|---|
| RESERVED | LOCKSTATUS | RESERVED |    |    |    |    |    | ADDRMUX | ADDRMUXLEGACY | RESERVED |    |    |    |    |    |    |    |    |    |    |    |   |   | BANKALLOCATION | RESERVED | B32NOT16 | DEEPPD | DDR TYPE | RAMTYPE |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0x0   |
| 30    | LOCKSTATUS | Read-only access lock bit<br><br>0x0: This register is fully writable.<br><br>0x1: When this bit is set, the register can not be unset until next reset of the module.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x-   |
| 29:25 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0x-   |
| 24:20 | ADDRMUX    | Address multiplexing scheme - See address-muxing paragraph for more details.<br><br>0x0: Address mux scheme 1<br>0x1: Address mux scheme 2<br>0x2: Address mux scheme 3<br>0x3: Address mux scheme 4<br>0x4: Address mux scheme 5<br>0x5: Address mux scheme 6<br>0x6: Address mux scheme 7<br>0x7: Address mux scheme 8<br>0x8: Address mux scheme 9<br>0x9: Address mux scheme 10<br>0xA: Address mux scheme 11<br>0xB: Address mux scheme 12<br>0xC: Address mux scheme 13<br>0xD: Address mux scheme 14<br>0xE: Address mux scheme 15<br>0xF: Address mux scheme 16<br>0x10: Reserved<br>0x11: Reserved<br>0x12: Reserved<br>0x13: Reserved<br>0x14: Reserved<br>0x15: Reserved<br>0x16: Address mux scheme 23<br>0x17: Address mux scheme 24<br>0x18: Address mux scheme 25<br>0x19: Address mux scheme 26<br>0x1A: Address mux scheme 27<br>0x1B: Address mux scheme 28<br>0x1C: Address mux scheme 29 | RW   | 0x-   |

| Bits | Field Name     | Description                                                                                                                                                                                                                       | Type | Reset |
|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 19   | ADDRMUXLEGACY  | Selects the fixed address-muxing scheme or the flexible address-muxing scheme.<br><br>0x0: Fixed address mux scheme<br>0x1: Flexible address mux scheme                                                                           | RW   | 0x-   |
| 18   | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                | RW   | 0x-   |
| 17:8 | RAMSIZE        | RAM address space size (number of 2-MB chunks)                                                                                                                                                                                    | RW   | 0x-   |
| 7:6  | BANKALLOCATION | SDRAM banks mapping. Selects the position of the bank address, the row address, and the column address in the system address.<br><br>0x0: Bank-row-column<br>0x1: Bank1-row-bank0-column<br>0x2: Row-bank-column<br>0x3: Reserved | RW   | 0x-   |
| 5    | RESERVED       | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                | RW   | 0x-   |
| 4    | B32NOT16       | External SDRAM bus width<br><br>0x0: External SDRAM device is x16 bit.<br>0x1: External SDRAM device is x32 bit.                                                                                                                  | RW   | 0x-   |
| 3    | DEEPPD         | Indicates if the memory supports deep-power-down mode.<br><br>0x0: No deep-power-down mode support<br>0x1: The memory supports deep-power-down mode.                                                                              | RW   | 0x-   |
| 2    | DDRTYPE        | DDR memory type (assuming RAMTYPE = 01)<br><br>0x0: Mobile DDR<br>0x1: Reserved for future use                                                                                                                                    | RW   | 0x-   |
| 1:0  | RAMTYPE        | Memory type<br><br>0x0: SDR-SDRAM (single data rate)<br>0x1: DDR-SDRAM (double data rate)<br>0x2: Reserved<br>0x3: Reserved                                                                                                       | RW   | 0x-   |

**Table 10-175. SDRC\_MR\_p**

|                         |                                                                                                                                                                                                                                                                                                                                                                                  |                       |                                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--------------------------------|
| <b>Address Offset</b>   | 0x0000 0084 + (0x0000 0030 * p)                                                                                                                                                                                                                                                                                                                                                  | <b>Index</b>          | p = 0 to 1                     |
| <b>Physical Address</b> | 0x6D00 0084 + (0x0000 0030 * p)                                                                                                                                                                                                                                                                                                                                                  | <b>Instance</b>       | SDRC                           |
| <b>Description</b>      | This 12-bit register corresponds to the JEDEC SDRAM MR register, with the standard bit fields. All 12 bits are loaded into memory for future extension support. The SDRC keeps an internal copy register used internally; that is, returned when a read access is performed at that address. Load into memory on interconnect write access using MRS command with BA1,BA0 = 0,0. |                       |                                |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                               |                       |                                |
| 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                |
| RESERVED                |                                                                                                                                                                                                                                                                                                                                                                                  |                       | ZERO_1 WBST ZERO_0 CASL SLL BL |

| Bits  | Field Name | Description                                                                                                                        | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED   | Write 0s for future compatibility. Read returns 0s.                                                                                | RW   | 0x00000 |
| 11:10 | ZERO_1     | Write 0s, as required by memory specifications. Read returns 0.                                                                    | RW   | 0x0     |
| 9     | WBST       | Write burst support must be zero.<br><br>0x0: Write burst equals read burst<br>0x1: Write burst disable (single write access only) | RW   | 0x0     |
| 8:7   | ZERO_0     | Write 0s, as required by memory specifications. Read returns 0s.                                                                   | RW   | 0x0     |

## SDRAM Controller (SDRC) Subsystem

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                      | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 6:4  | CASL       | CAS latency as defined by clock periods<br>0x1: CAS latency = 1<br>0x2: CAS latency = 2<br>0x3: CAS latency = 3<br>0x4: CAS latency = 4<br>0x5: CAS latency = 5                                                                                                                  | RW   | 0x2   |
| 3    | SIL        | Serial or interleaved mode: must be zero<br>0x0: Serial mode (always used)<br>0x1: interleaved mode (never used)                                                                                                                                                                 | RW   | 0x0   |
| 2:0  | BL         | Memory burst length<br>0x0: Burst length = 1 - Not supported<br>0x1: Burst length = 2 - SDR memory only<br>0x2: Burst length = 4 - DDR memory only<br>0x3: Burst length = 8 - Not supported<br>0x4: Reserved<br>0x5: Reserved<br>0x6: Reserved<br>0x7: Full page - Not supported | RW   | 0x4   |

**Table 10-176. Register Call Summary for Register SDRC\_MR\_p**

## SDRAM Controller (SDRC) Subsystem

- [SDRC Power-Down Mode: \[0\]](#)
- [Mode Register \(MR\): \[1\] \[2\] \[3\] \[4\] \[5\] \[6\]](#)
- [Mode Register Programming and Modes of Operation: \[7\] \[8\] \[9\]](#)
- [Low-Power SDR/Mobile DDR Initialization Sequence: \[10\]](#)
- [Read/Write Access: \[11\]](#)
- [SDRC Register Summary: \[12\]](#)
- [SDRC Register Description: \[13\] \[14\]](#)

**Table 10-177. SDRC\_EMR2\_p**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                               |                 |            |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 008C + (0x0000 0030 * p)                                                                                                                                                                                                                                                                                                                                                                               | <b>Index</b>    | p = 0 to 1 |
| <b>Physical Address</b> | 0x6D00 008C + (0x0000 0030 * p)                                                                                                                                                                                                                                                                                                                                                                               | <b>Instance</b> | SDRC       |
| <b>Description</b>      | This 12-bit register corresponds to the low-power EMR register, as defined in the mobile DDR JEDEC Standard. All 12 bits are loaded into the memory, thus assuring future extension support. The SDRC keeps an internal copy register used internally; that is, returned when a read access is performed at that address. Load into memory on interconnect write access using MRS command with BA1,BA0 = 1,0. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                            |                 |            |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |      |   |      |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|------|---|------|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ZERO |    |    |    | DS |    | TCSR |   | PASR |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                   | Type | Reset   |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED   | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                           | RW   | 0x00000 |
| 11:8  | ZERO       | Write 0s, as required by memory specifications. Read returns 0                                                                                                                                                                                                                | RW   | 0x00    |
| 7:5   | DS         | Driver strength<br><br>0x0: Full strength driver<br>0x1: Half strength driver<br>0x2: Reserved<br>0x3: Reserved<br>0x4: Three-fourths strength driver <sup>(1)</sup><br>0x5: Reserved<br>0x6: Optional one-fourth strength driver<br>0x7: Optional one-eighth strength driver | RW   | 0x0     |
| 4:3   | TCSR       | Temperature-compensated self-refresh<br><br>0x0: 70 degrees maximum temperature<br>0x1: 45 degrees maximum temperature<br>0x2: 15 degrees maximum temperature<br>0x3: 85 degrees maximum temperature                                                                          | RW   | 0x0     |
| 2:0   | PASR       | Partial array self-refresh<br><br>0x0: All banks.<br>0x1: 1/2 array<br>0x2: 1/4 array<br>0x3: Reserved<br>0x4: Reserved<br>0x5: 1/8 array<br>0x6: 1/16 array<br>0x7: Reserved                                                                                                 | RW   | 0x0     |

<sup>(1)</sup> Three-fourths strength driver is optional for speed bins LPDDR333 and below.

**Table 10-178. Register Call Summary for Register SDRC\_EMR2\_p**

SDRAM Controller (SDRC) Subsystem

- [SDRC Power-Down Mode: \[0\]](#)
- [Extended Mode Register 2 \(EMR2\): \[1\] \[2\] \[3\] \[4\]](#)
- [Mode Register Programming and Modes of Operation: \[5\] \[6\] \[7\] \[8\]](#)
- [Read/Write Access: \[9\]](#)
- [SDRC Register Summary: \[10\]](#)
- [SDRC Register Description: \[11\] \[12\]](#)

**Table 10-179. SDRC\_ACTIM\_CTRLA\_p**

|                         |                                                                                                                              |    |      |    |     |    |      |    |      |    |      |    |          |    |                 |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------|----|------|----|-----|----|------|----|------|----|------|----|----------|----|-----------------|------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 009C + (0x0000 0028 * p)                                                                                              |    |      |    |     |    |      |    |      |    |      |    |          |    | <b>Index</b>    | p = 0 to 1 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x6D00 009C + (0x0000 0028 * p)                                                                                              |    |      |    |     |    |      |    |      |    |      |    |          |    | <b>Instance</b> | SDRC       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | The ac timing control register A sets the ac parameter values in clock cycle units to best match the memory characteristics. |    |      |    |     |    |      |    |      |    |      |    |          |    |                 |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                                                                                           |    |      |    |     |    |      |    |      |    |      |    |          |    |                 |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| TRFC                    | TRC                                                                                                                          |    | TRAS |    | TRP |    | TRCD |    | TRRD |    | TDPL |    | RESERVED |    | TDAL            |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## SDRAM Controller (SDRC) Subsystem

www.ti.com

| Bits  | Field Name | Description                                            | Type | Reset |
|-------|------------|--------------------------------------------------------|------|-------|
| 31:27 | TRFC       | Autorefresh to active                                  | RW   | 0x00  |
| 26:22 | TRC        | Row cycle time                                         | RW   | 0x00  |
| 21:18 | TRAS       | Row active time                                        | RW   | 0x0   |
| 17:15 | TRP        | Row precharge time                                     | RW   | 0x0   |
| 14:12 | TRCD       | Row to column delay time                               | RW   | 0x0   |
| 11:9  | TRRD       | Active to active command period                        | RW   | 0x0   |
| 8:6   | TDPL       | Data-in to precharge command (write recovery time tWR) | RW   | 0x0   |
| 5     | RESERVED   | Write 0s for future compatibility. Read returns 0.     | RW   | 0x0   |
| 4:0   | TDAL       | Data-in to active command                              | RW   | 0x00  |

**Table 10-180. Register Call Summary for Register SDRC\_ACTIM\_CTRLA\_p**

SDRAM Controller (SDRC) Subsystem

- SDRAM AC Timing Parameters: [0]
- Low-Power SDR/Mobile DDR Initialization Sequence: [1]
- SDRC Register Summary: [2]

**Table 10-181. SDRC\_ACTIM\_CTRLB\_p**

|                         |                                                                                                                             |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------|------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00A0 + (0x0000 0028 * p)                                                                                             | <b>Index</b>    | p = 0 to 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x6D00 00A0 + (0x0000 0028 * p)                                                                                             | <b>Instance</b> | SDRC       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | The ac timing control register B sets the ac parameter values in clock cycle unit, to best match the memory characteristics |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                          |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |      |          |      |    |          |     |    |      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|------|----------|------|----|----------|-----|----|------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    | TWTR | RESERVED | TCKE |    | RESERVED | TXP |    | TXSR |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                   | Type | Reset   |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:18 | RESERVED   | Write 0s for future compatibility<br>Reads return zeros.                                                                                                                                      | RW   | 0x00000 |
| 17:16 | TWTR       | Internal write to read command delay.<br>0x0: 1 minimum clock cycle before next command<br>0x1: 1 minimum clock cycle<br>0x2: 2 minimum clock cycles<br>0x3: 3 minimum clock cycles           | RW   | 0x0     |
| 15    | RESERVED   | Write 0s for future compatibility<br>Reads return zeros.                                                                                                                                      | RW   | 0       |
| 14:12 | TCKE       | CKE minimum pulse width (high and low)<br>0x0: 1 minimum clock cycle<br>0x1: 1 minimum clock cycle<br>0x2: 2 minimum clock cycles<br>...0x7: 7 minimum clock cycles                           | RW   | 0x0     |
| 11    | RESERVED   | Write 0s for future compatibility<br>Reads return zeros.                                                                                                                                      | RW   | 0       |
| 10:8  | TXP        | Exit power-down to next valid command delay.<br>0x0: 1 minimum clock cycle before next command<br>0x1: 1 minimum clock cycle<br>0x2: 2 minimum clock cycles<br>...0x7: 7 minimum clock cycles | RW   | 0x0     |
| 7:0   | TXSR       | Self-refresh exit to active period                                                                                                                                                            | RW   | 0x00    |

**Table 10-182. Register Call Summary for Register SDRC\_ACTIM\_CTRLB\_p**

SDRAM Controller (SDRC) Subsystem

- [SDRAM AC Timing Parameters: \[0\]](#)
- [SDRC Register Summary: \[1\]](#)

**Table 10-183. SDRC\_RFR\_CTRL\_p**

|                         |                                  |                 |            |
|-------------------------|----------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 00A4 + (0x0000 0030 * p)  | <b>Index</b>    | p = 0 to 1 |
| <b>Physical Address</b> | 0x6D00 00A4 + (0x0000 0030 * p)  | <b>Instance</b> | SDRC       |
| <b>Description</b>      | SDRAM memory autorefresh control |                 |            |
| <b>Type</b>             | RW                               |                 |            |

|                         |                         |                       |                 |          |     |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|----------|-----|--|--|
| 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 |          |     |  |  |
| RESERVED                | ARCV                    |                       |                 | RESERVED | ARE |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:24 | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                          | RW   | 0x00   |
| 23:8  | ARCV       | Autorefresh counter value to set the refresh period. The autorefresh counter is uploaded with the result of:<br>(tREFI / tCK) - 50                                                                                                                                                                                                                                          | RW   | 0x0000 |
| 7:2   | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                          | RW   | 0x00   |
| 1:0   | ARE        | Autorefresh enable<br>0x0: Autorefresh is disabled<br>0x1: Counter is loaded with ARCV: 1 autorefresh command when autorefresh counter reaches 0.<br>0x2: Counter is loaded with 4 * ARCV: Burst of 4 autorefresh commands when autorefresh counter reaches 0.<br>0x3: Counter is loaded with 8 * ARCV: Burst of 8 autorefresh commands when autorefresh counter reaches 0. | RW   | 0x0    |

**Table 10-184. Register Call Summary for Register SDRC\_RFR\_CTRL\_p**

SDRAM Controller (SDRC) Subsystem

- [Autorefresh Management: \[0\] \[1\] \[2\]](#)
- [Memory Power Management: \[3\] \[4\] \[5\]](#)
- [SDRC Register Summary: \[6\]](#)

**Table 10-185. SDRC\_MANUAL\_p**

|                         |                                                                                                                                                                                                |                 |            |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 00A8 + (0x0000 0030 * p)                                                                                                                                                                | <b>Index</b>    | p = 0 to 1 |
| <b>Physical Address</b> | 0x6D00 00A8 + (0x0000 0030 * p)                                                                                                                                                                | <b>Instance</b> | SDRC       |
| <b>Description</b>      | This register allows to send specific commands to the external memory devices under software control. Any write to this register generates the appropriate sequence based on the command code. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                             |                 |            |

|                         |                         |                       |                 |         |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|---------|--|--|--|
| 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 |         |  |  |  |
| CMDPARAM                |                         |                       | RESERVED        | CMDCODE |  |  |  |

## SDRAM Controller (SDRC) Subsystem

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | CMDPARAM   | Manual command parameter, if any.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0000 |
| 15:4  | RESERVED   | Write 0s for future compatibility. Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x000  |
| 3:0   | CMDCODE    | Memory command opcode; other values reserved for future implementations.<br><br>0x0: NOP command - no parameter<br>0x1: Precharge all command - no parameter<br>0x2: Autorefresh command - no parameter<br>0x3: Enter deep-power-down - no parameter<br>0x4: Exit deep-power-down - no parameter<br>0x5: Enter self-refresh - no parameter<br>0x6: Exit self-refresh - no parameter<br>0x7: Set CKE signal high - no parameter<br>0x8: Set CKE low - no parameter<br>0x9: Reserved<br>0xA: Reserved<br>0xB: Reserved<br>0xC: Reserved | RW   | 0x0    |

**Table 10-186. Register Call Summary for Register SDRC\_MANUAL\_p**

## SDRAM Controller (SDRC) Subsystem

- Refresh Management: [0]
- Power-Saving Features: [1]
- SDRC Power-Down Mode: [2]
- Autorefresh Management: [3]
- Manual Software Commands: [4] [5] [6] [7] [8] [9] [10] [11] [12] [13]
- Low-Power SDR/Mobile DDR Initialization Sequence: [14]
- Memory Power Management: [15]
- SDRC Register Summary: [16]

## 10.3 On-Chip Memory Subsystem

### 10.3.1 OCM Subsystem Overview

The on-chip memory subsystem consists of two separate on-chip memory controllers, one connected to an on-chip ROM (OCM\_ROM) and the other connected to an on-chip RAM (OCM\_RAM). Each memory controller has its own dedicated interface to the L3 interconnect.

Figure 10-78 is an overview of the OCM subsystem.

**Figure 10-78. OCM Subsystem Overview**



Ocm-003

Multiple L3 initiators (such as remote devices) have access to the RAM through 2D/3D graphics, the MPU subsystem, sDMA, the camera subsystem, the display subsystem, IVA2, and USB.

ROM is used for direct boot code and boot from external NAND flash.

## 10.3.2 OCM Subsystem Integration

### 10.3.2.1 Description

The OCM\_ROM and OCM\_RAM allow transactions between the system initiators and the multiple memories, through the L3 interconnect.

Figure 10-79 shows the integration of the OCM subsystem to the device processor.

**Figure 10-79. OCM Subsystem Integration to the Device**



### 10.3.2.2 Clocking, Reset, and Power-Management Scheme

#### 10.3.2.2.1 Clocking

The on-chip boot ROM and RAM are clocked only when they are accessed.

The interface clock OCM\_CLK comes from the PRCM module and runs at the L3 interconnect frequency. The OCM\_CLK source is PRCM CORE\_L3\_ICLK output. This clock is also used as the functional clock for the OCM module.

For the OCM subsystem, no register enables the gating of OCM\_CLK.

However, OCM does support the handshaking protocol with the PRCM module. It is not programmable by software. The following signals support the handshaking protocol for ROM and RAM devices:

- OCMROM\_IDLEREQ/OCMROM\_SIDLEACK (for ROM devices)
- OCMRAM\_IDLEREQ/OCMRAM\_SIDLEACK (for RAM devices)

OCM\_CLK is gated if all modules (including the OCM) belonging to the L3 CLK domain send a SidleAck back to the PRCM module after reception of the MidleReq request.

For details, see [Chapter 3, Power, Reset, and Clock Management](#).

When the memory is not accessed by the system, the module performs automatic clock gating. Because the clock to the memory is dynamically gated, there is no extra latency when the clock must be switched on after an idle state.

#### 10.3.2.2.2 Hardware Reset

Global reset of the module is performed by activation of the CORE\_RST in the core reset domain (see [Chapter 3, Power, Reset, and Clock Management](#)).

#### 10.3.2.2.3 Power Domain

OCM power is supplied by the CORE power domain (see [Chapter 3, Power, Reset, and Clock Management](#)).

### 10.3.3 OCM Subsystem Functional Description

#### 10.3.3.1 OCM\_ROM

The embedded ROM is used primarily for booting, flashing, and context restoring.

The device-embedded ROM (total 32K bytes) has the following characteristics:

- The OCM\_ROM is always accessible, and contains the boot area.
- The OCM\_ROM supports single and burst access transactions.
- The OCM\_ROM operates at full interconnect clock frequency.
- The COM\_ROM needs three cycles for initial access and one cycle per subsequent access.

The memory space of the embedded ROM starts at 0x4001 4000 and ends at 0x4001 BFFF.

#### 10.3.3.2 OCM\_RAM

By default, only 2K bytes are available after reset; however, the configuration can then be changed to adapt to booting/flashing, normal boot, or to any application requirement.

The device-embedded RAM has the following characteristics:

- Operates at full L3 interconnect clock frequency
- Fully pipelined, one 32-bit access per cycle
- Restricted access support, based on:
  - A region-based partitioning (see the L3 firewall description)
  - The module owner of the access, with respect to its read and write permission to that region
  - The transaction attributes of the access, with respect to the region permission properties:
    - User/supervisor
    - Code/data access

The OCM\_RAM can be partitioned using the L3 firewall and used as RAM for a video frame buffer or to any application.

The RAM memory space starts at 0x4020 0000 and ends at 0x4020 FFFF.



---

This chapter describes the system direct memory access (SDMA) module.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                   | Page |
|-----------------------------------------|------|
| 11.1 SDMA Overview .....                | 2344 |
| 11.2 SDMA Environment .....             | 2346 |
| 11.3 SDMA Integration .....             | 2348 |
| 11.4 SDMA Functional Description .....  | 2354 |
| 11.5 SDMA Basic Programming Model ..... | 2377 |
| 11.6 SDMA Register Manual .....         | 2383 |

## 11.1 SDMA Overview

The system direct memory access (SDMA), also called DMA4, performs high-performance data transfers between memories and peripheral devices without microprocessor unit (MPU) or digital signal processor (DSP) support during transfer. A DMA transfer is programmed through a logical DMA channel, which allows the transfer to be optimally tailored to the requirements of the application.

The device also embeds dedicated DMA controllers: the camera image signal processor (ISP) DMA; the enhanced DMA (EDMA), which is embedded in the IVA2.2 subsystem; the display DMA; and the universal serial bus (USB) high-speed (HS) DMA. For more information, see [Chapter 6, Camera ISP Subsystem](#); [Chapter 5, IVA Subsystem](#); [Chapter 7, Display Subsystem](#); and [Chapter 22, High-Speed USB Controllers](#).

The DMA controller includes the following main features:

- Data transfer support in either direction between:
  - Memory and memory
  - Memory and peripheral device
- 32 logical DMA channels supporting:
  - Multiple concurrent transfers
  - Independent transfer profile for each channel
  - 8-bit, 16-bit, or 32-bit data element transfer size
  - Software-triggered or hardware-synchronized transfers
  - Flexible source and destination address generation
  - Burst read and write
  - Chained multiple-channel transfers
  - Endianism conversion
  - Draining
  - Linked-list support for descriptor types 1, 2, and 3
- First-come, first-serve DMA scheduling with fixed priority
- Up to 96 DMA requests
- Constant fill
- Transparent copy
- Four programmable interrupt request output lines
- FIFO depth: 256 x 32-bits
- Data buffering
- FIFO budget allocation
- Power-management support
- Auto-idle power-saving support
- Implementation of retention flip-flops (RFFs) to support dynamic power saving (DPS) between system power modes without MPU involvement

[Figure 11-1](#) shows an overview of the SDMA module.

**Figure 11-1. SDMA Overview**


The SDMA module has three ports - one read, one write and one configuration port - and provides multiple logical channel support. A dynamically allocated FIFO queue memory pool provides buffering between the read and write ports. Read and write ports are multithreaded (two threads for the write port and four threads for the read port); this means that each transaction is flagged by a thread ID (0, 1, 2, or 3) in the request direction and in the response direction. This allows the read port to have four outstanding requests at a time. The write port has two threads budget available.

The MPU (or DSP) configures the SDMA controller through the L4-Core interconnect.

## 11.2 SDMA Environment

### 11.2.1 External SDMA Request Signals

The SDMA controller supports external DMA requests through the sys\_ndmreq[3:0] pins. A logical channel can be configured to respond to an external synchronization request.

[Table 11-1](#) describes the external SDMA request signals.

**Table 11-1. External SDMA Request Signals**

| Pin Name    | I/O <sup>(1)</sup> | Description                              | Reset |
|-------------|--------------------|------------------------------------------|-------|
| sys_ndmreq0 | I                  | External DMA request signal (active low) | 1     |
| sys_ndmreq1 | I                  | External DMA request signal (active low) | 1     |
| sys_ndmreq2 | I                  | External DMA request signal (active low) | 1     |
| sys_ndmreq3 | I                  | External DMA request signal (active low) | 1     |

<sup>(1)</sup> I = Input, O = Output

---

**NOTE:** External SDMA requests can be configured to be either edge or transition (level) sensitive by the system control module. For more information, see [Section 11.2.3, SDMA Request Scheme](#).

---

### 11.2.2 External SDMA Requests Typical Application

[Figure 11-2](#) shows the SDMA environment with an example of how to use the external hardware DMA request pins.

**Figure 11-2. External SDMA Requests Typical Application**

dma-005

An external device can use the external DMA request pins to start a logical channel transfer over the general-purpose memory controller (GPMC) interface. The transfer can be a memory-to-memory transfer in which the source memory is in the external device.

The external DMA request signals are not available on external pins by default after cold reset. See [Chapter 13, System Control Module](#), for instructions on multiplexing out the four signal lines to pins.

### 11.2.3 SDMA Request Scheme

The hardware DMA request line schemes can be either edge-sensitive, or transition-sensitive.

The sensitivity selection of the **sys\_ndmareq[3:0]** lines can be configured in the system control module through the following register bits:

- **CONTROL\_DEVCONF0[0]** SENSDMAREQ0 register bit for **sys\_ndmareq0**
- **CONTROL\_DEVCONF0[1]** SENSDMAREQ1 register bit for **sys\_ndmareq1**
- **CONTROL\_DEVCONF1[7]** SENSDMAREQ2 register bit for **sys\_ndmareq2**
- **CONTROL\_DEVCONF1[8]** SENSDMAREQ3 register bit for **sys\_ndmareq3**

The default scheme for the external DMA requests is transition-sensitive. Other DMA requests (coming from device internal peripherals) are transition-sensitive, except display subsystem line trigger DMA request (DSS\_LINE\_DMA), which is edge-sensitive.

[Figure 11-3](#) shows the DMA request captured on a falling edge in the edge-sensitive scheme.

**Figure 11-3. Edge-Sensitive DMA Request Scheme**

For a transition-sensitive DMA request (see [Figure 11-4](#)), the line must be maintained low (asserted) until the first DMA access is complete, after which the line must be maintained high (deasserted) for greater than one clock cycle (CORE\_L3\_ICLK).

When the deassertion time is less than one clock cycle, the SDMA might not detect the deassertion.

When the channel is enabled one cycle after a DMA request is disabled, the channel detects the DMA request and starts the corresponding transfer.

When the channel is enabled two cycles after the DMA request is disabled, the channel does not detect the DMA request.

**Figure 11-4. Transition-Sensitive DMA Request Scheme**

### 11.3 SDMA Integration

[Figure 11-5](#) highlights the SDMA controller integration.

**Figure 11-5. SDMA Controller Integration**


### 11.3.1 Clocking, Reset, and Power-Management Scheme

#### 11.3.1.1 Power Domain

The SDMA controller is part of the CORE power domain.

#### 11.3.1.2 Clocking

The SDMA controller uses two clock domains:

- CORE\_L4\_ICLK supports the configuration port.
- CORE\_L3\_ICLK is both a functional clock for all internal logic and an interface clock for the two master read and write ports.

The SDMA controller supports a software-controlled standby mode with an input clock shutoff. Setting the PRCM\_CM\_IDLEST1\_CORE[2] ST\_SDMA status bit to 1 allows detection of the SDMA power mode.

For more information about power management and clock idle, see [Section 11.3.1.4, Power Management](#).

#### 11.3.1.3 Hardware Reset

The SDMA controller is part of the CORE\_RST\_RET reset domain.

Hardware reset initializes all internal logic of the SDMA module, all global registers and some of the per-channel registers, implemented in flip-flops. However, all remaining per-channel registers are memory-based, and, therefore, are not reset (have undefined values). Thus, when programming a channel for the first time, all bits that have undefined reset values must be configured before enabling the channel.

#### 11.3.1.4 Power Management

The SDMA module provides three methods to reduce power consumption:

- Internal clock gating (auto-idle)
- Automatic standby mode
- Idle mode

##### 11.3.1.4.1 Internal Clock Gating (Auto-Idle)

The auto-idle power-saving mode is enabled or disabled through the [DMA4\\_OCP\\_SYSCONFIG\[0\]](#) AUTOIDLE bit. When this mode is enabled and there is no activity on the interconnect interface, the interface clock is disabled internally to the module to reduce power consumption. When there is new activity on the interconnect interface, the interface clock is restarted without any latency penalty. After reset, this mode is disabled by default. Enabling this mode is recommended to reduce power consumption.

##### 11.3.1.4.2 Automatic Standby Mode

The module can be configured to one of the following standby modes using the [DMA4\\_OCP\\_SYSCONFIG\[13:12\]](#) MIDLEMODE bit field:

- Force-standby mode (MIDLEMODE = 0x0): The module goes into standby mode only when all the DMA channels are disabled.
- No-standby mode (MIDLEMODE = 0x1): The module never goes into standby mode.
- Smart-standby mode (MIDLEMODE = 0x2): The module enters standby mode when:
  - All DMA channels are disabled
  - OR
  - No no-synchronous channels are enabled and if hardware synchronous channels are enabled, then there should not be any hardware request asserted and there should not be any pending request in DMA4 module

##### 11.3.1.4.3 Idle Mode

The module can be configured using the [DMA4\\_OCP\\_SYSCONFIG\[3:2\]](#) SIDLEMODE bit field to one of the following idle acknowledgement modes:

- Force-idle mode (SIDLEMODE = 0x0): The module acknowledges unconditionally the idle request from the PRCM module, regardless of its internal operations. This mode must be used carefully in this case because it does not prevent the loss of data when the clocks are switched off.
- No-idle mode (SIDLEMODE = 0x1): The module never acknowledges an idle request from the PRCM module and is safe from a module point of view because it ensures that the clocks remain active. However, it is not efficient to save power because it does not allow the PRCM output clocks to be shut off and thus the power domain to be set to a lower power state.
- Smart-idle mode (SIDLEMODE = 0x2): The module acknowledges the idle request, basing its decision on its internal activity. Namely, the acknowledge signal is asserted when all the following conditions are satisfied:
  - There is no non-synchronized channel enabled.
  - No DMA request input is asserted.
  - No pending request in the read and write port scheduler state machine.
  - All transactions are completed on all the DMA ports.
  - No interrupts are pending to be serviced.

## 11.3.2 Hardware Requests

### 11.3.2.1 SDMA Interrupts

DMA4 has four interrupt lines, numbered L<sub>j</sub> with j=0..3. Each logical channel can request an interrupt over any line. The attachment of a channel interrupt event to one of these four external lines is programmable. The software determines whether it attaches a channel interrupt to a single IRQ line or to multiple IRQ lines.

There are two different registers per interrupt line:

- [DMA4\\_IRQSTATUS\\_Lj](#) CH\_31\_0\_L<sub>j</sub> field shows the status of the different sources of interrupt. If the [DMA4\\_IRQENABLE\\_Lj](#) bit *i* is 1, the channel *i* is the source of interrupt in line *j*. In contrast to the [DMA4\\_CSRi](#) registers, the [DMA4\\_IRQSTATUS\\_Lj](#) registers are updated regardless of the corresponding bits in the [DMA4\\_IRQENABLE\\_Lj](#) registers.
- [DMA4\\_IRQENABLE\\_Lj](#) CH\_31\_0\_L<sub>j</sub>\_EN field masks/unmasks the channel interrupt. If the [DMA4\\_IRQENABLE\\_Lj](#) bit *i* is set to 0, the channel interrupt *i* of the line *j* is masked.

Each logical channel can generate a number of different interrupt events when enabled (that is, set to 1) in the [DMA4\\_CICRi](#) register. Each status bit is updated in the [DMA4\\_CSRi](#) register only when the corresponding enable bit is enabled in the [DMA4\\_CICRi](#) register.

To determine an interrupt source when an interrupt rises on an interrupt line L<sub>j</sub>, you must:

- Identify the channel (LCH<sub>i</sub>) generating the interrupt.  
Read the [DMA4\\_IRQSTATUS\\_Lj.LCHi](#) (LCH0 to LCH31). If LCH<sub>i</sub> = 1, channel *i* is the originator of the interrupt.
- Identify the interrupt event.  
Read the LCH<sub>i</sub> [DMA4\\_CSRi](#). For example, if the drop event (the [DMA4\\_CSRi\[1\]](#) DROP bit) is 1, there will be a request collision.

The interrupt event status bit in the [DMA4\\_CSRi](#) register is immediately reset after it is written to 1.

The interrupt status bit in the [DMA4\\_IRQSTATUS\\_Lj](#) register is cleared after it is written to 1.

[Table 11-2](#) shows the SDMA interrupts.

**Table 11-2. SDMA Interrupts**

| Source     | IRQ to MPU INTC | IRQ to IVA2.2 INTC | Description              |
|------------|-----------------|--------------------|--------------------------|
| SDMA_IRQ_0 | M_IRQ_12        | EVT89              | SDMA interrupt request 0 |
| SDMA_IRQ_1 | M_IRQ_13        | EVT90              | SDMA interrupt request 1 |
| SDMA_IRQ_2 | M_IRQ_14        | N/A                | SDMA interrupt request 2 |
| SDMA_IRQ_3 | M_IRQ_15        | N/A                | SDMA interrupt request 3 |

### 11.3.2.2 DMA Requests to the SDMA Controller

All peripherals internal to the device use the transition-sensitive scheme for DMA requests. For more information on the transition-sensitive scheme, see [Section 11.2.3, SDMA Request Scheme](#). [Table 11-3](#) lists the SDMA request mapping.

**Table 11-3. SDMA Request Mapping**

| DMA Request Line | Source       | Description                                  |
|------------------|--------------|----------------------------------------------|
| S_DMA_0          | Reserved     | Reserved                                     |
| S_DMA_1          | SYS_DMA_REQ0 | External DMA request 0 (system expansion)    |
| S_DMA_2          | SYS_DMA_REQ1 | External DMA request 1 (system expansion)    |
| S_DMA_3          | GPMC_DMA     | GPMC request from prefetch engine            |
| S_DMA_4          | Reserved     | Reserved                                     |
| S_DMA_5          | DSS_LINE_DMA | Display subsystem - line trigger DMA request |

**Table 11-3. SDMA Request Mapping (continued)**

| DMA Request Line | Source        | Description                                |
|------------------|---------------|--------------------------------------------|
| S_DMA_6          | SYS_DMA_REQ2  | External DMA request 2 (system expansion)  |
| S_DMA_7          | Reserved      | Reserved                                   |
| S_DMA_8          | Reserved      | Reserved                                   |
| S_DMA_9          | Reserved      | Reserved                                   |
| S_DMA_10         | Reserved      | Reserved                                   |
| S_DMA_11         | Reserved      | Reserved                                   |
| S_DMA_12         | Reserved      | Reserved                                   |
| S_DMA_13         | Reserved      | Reserved                                   |
| S_DMA_14         | SPI3_DMA_TX0  | McSPI module 3—transmit request channel 0  |
| S_DMA_15         | SPI3_DMA_RX0  | McSPI module 3—receive request channel 0   |
| S_DMA_16         | MCBSP3_DMA_TX | MCBSP module 3—transmit request            |
| S_DMA_17         | MCBSP3_DMA_RX | MCBSP module 3—receive request             |
| S_DMA_18         | MCBSP4_DMA_TX | MCBSP module 4—transmit request            |
| S_DMA_19         | MCBSP4_DMA_RX | MCBSP module 4—receive request             |
| S_DMA_20         | MCBSP5_DMA_TX | MCBSP module 5—transmit request            |
| S_DMA_21         | MCBSP5_DMA_RX | MCBSP module 5—receive request             |
| S_DMA_22         | SPI3_DMA_TX1  | McSPI module 3—transmit request channel 1  |
| S_DMA_23         | SPI3_DMA_RX1  | McSPI module 3—receive request channel 1   |
| S_DMA_24         | I2C3_DMA_TX   | I <sup>2</sup> C module 3—transmit request |
| S_DMA_25         | I2C3_DMA_RX   | I <sup>2</sup> C module 3—receive request  |
| S_DMA_26         | I2C1_DMA_TX   | I <sup>2</sup> C module 1—transmit request |
| S_DMA_27         | I2C1_DMA_RX   | I <sup>2</sup> C module 1—receive request  |
| S_DMA_28         | I2C2_DMA_TX   | I <sup>2</sup> C module 2—transmit request |
| S_DMA_29         | I2C2_DMA_RX   | I <sup>2</sup> C module 2—receive request  |
| S_DMA_30         | MCBSP1_DMA_TX | MCBSP module 1—transmit request            |
| S_DMA_31         | MCBSP1_DMA_RX | MCBSP module 1—receive request             |
| S_DMA_32         | MCBSP2_DMA_TX | MCBSP module 2—transmit request            |
| S_DMA_33         | MCBSP2_DMA_RX | MCBSP module 2—receive request             |
| S_DMA_34         | SPI1_DMA_TX0  | McSPI module 1—transmit request channel 0  |
| S_DMA_35         | SPI1_DMA_RX0  | McSPI module 1—receive request channel 0   |
| S_DMA_36         | SPI1_DMA_TX1  | McSPI module 1—transmit request channel 1  |
| S_DMA_37         | SPI1_DMA_RX1  | McSPI module 1—receive request channel 1   |
| S_DMA_38         | SPI1_DMA_TX2  | McSPI module 1—transmit request channel 2  |
| S_DMA_39         | SPI1_DMA_RX2  | McSPI module 1—receive request channel 2   |
| S_DMA_40         | SPI1_DMA_TX3  | McSPI module 1—transmit request channel 3  |
| S_DMA_41         | SPI1_DMA_RX3  | McSPI module 1—receive request channel 3   |
| S_DMA_42         | SPI2_DMA_TX0  | McSPI module 2—transmit request channel 0  |
| S_DMA_43         | SPI2_DMA_RX0  | McSPI module 2—receive request channel 0   |
| S_DMA_44         | SPI2_DMA_TX1  | McSPI module 2—transmit request channel 1  |
| S_DMA_45         | SPI2_DMA_RX1  | McSPI module 2—receive request channel 1   |
| S_DMA_46         | MMC2_DMA_TX   | MMC/SD2 transmit request                   |
| S_DMA_47         | MMC2_DMA_RX   | MMC/SD2 receive request                    |
| S_DMA_48         | UART1_DMA_TX  | UART module 1—transmit request             |
| S_DMA_49         | UART1_DMA_RX  | UART module 1—receive request              |
| S_DMA_50         | UART2_DMA_TX  | UART module 2—transmit request             |
| S_DMA_51         | UART2_DMA_RX  | UART module 2—receive request              |
| S_DMA_52         | UART3_DMA_TX  | UART module 3—transmit request             |

**Table 11-3. SDMA Request Mapping (continued)**

| DMA Request Line | Source       | Description                                   |
|------------------|--------------|-----------------------------------------------|
| S_DMA_53         | UART3_DMA_RX | UART module 3—receive request                 |
| S_DMA_54         | Reserved     | Reserved                                      |
| S_DMA_55         | Reserved     | Reserved                                      |
| S_DMA_56         | Reserved     | Reserved                                      |
| S_DMA_57         | Reserved     | Reserved                                      |
| S_DMA_58         | Reserved     | Reserved                                      |
| S_DMA_59         | Reserved     | Reserved                                      |
| S_DMA_60         | MMC1_DMA_TX  | MMC/SD1 transmit request                      |
| S_DMA_61         | MMC1_DMA_RX  | MMC/SD1 receive request                       |
| S_DMA_62         | Reserved     | Reserved                                      |
| S_DMA_63         | SYS_DMA_REQ3 | External DMA request 3 (system expansion)     |
| S_DMA_64         | Reserved     | Reserved                                      |
| S_DMA_65         | Reserved     | Reserved                                      |
| S_DMA_66         | Reserved     | Reserved                                      |
| S_DMA_67         | Reserved     | Reserved                                      |
| S_DMA_68         | Reserved     | Reserved                                      |
| S_DMA_69         | SPI4_DMA_TX0 | McSPI module 4—transmit request channel 0     |
| S_DMA_70         | SPI4_DMA_RX0 | McSPI module 4—receive request channel 0      |
| S_DMA_71         | DSS_DMA0     | Display subsystem DMA request 0 (DSI)         |
| S_DMA_72         | DSS_DMA1     | Display subsystem DMA request 1 (DSI)         |
| S_DMA_73         | DSS_DMA2     | Display subsystem DMA request 2 (DSI)         |
| S_DMA_74         | DSS_DMA3     | Display subsystem DMA request 3 (DSI or RFBI) |
| S_DMA_75         | Reserved     | Reserved                                      |
| S_DMA_76         | MMC3_DMA_TX  | MMC/SD3 transmit request                      |
| S_DMA_77         | MMC3_DMA_RX  | MMC/SD3 receive request                       |
| S_DMA_78         | Reserved     | Reserved                                      |
| S_DMA_79         | Reserved     | Reserved                                      |
| S_DMA_80         | UART4_DMA_TX | UART module 4 - transmit request              |
| S_DMA_81         | UART4_DMA_RX | UART module 4 - receive request               |
| S_DMA_82         | ...          | Reserved                                      |
| S_DMA_95         | Reserved     | Reserved                                      |

## 11.4 SDMA Functional Description

The SDMA module provides high-performance data transfers between memories and peripheral devices with low processor use. A DMA transfer is programmed through a logical DMA channel, which allows the transfer to be optimally tailored to the requirements of the application.

Figure 11-6 shows the SDMA controller top-level block diagram.

**Figure 11-6. SDMA Controller Top-Level Block Diagram**



dma-006

### 11.4.1 Logical Channel Transfer Overview

As Figure 11-6 shows, the SDMA module has one read port and one write port operating independently of each other. Buffering is provided between the read and write ports through a FIFO queue memory pool that is shared dynamically between the active logical channels.

- Logical channel synchronization

A logical channel is described as hardware-synchronized when the DMA transfers are triggered by DMA requests from a hardware device. Alternatively, a logical channel is described as nonsynchronized when the DMA transfer is triggered by software.

- Logical channel activation

A logical channel becomes active as follows:

- For hardware-synchronized transfers, when the logical channel is enabled and the hardware DMA request line is asserted
- For software-triggered (nonsynchronized) transfers, as soon as software enables the logical channel
- Logical channel transfer composition

A DMA transfer is divided automatically into a number of transactions. Depending on the logical channel context configured, transfer size, the start address alignment, the addressing mode, and the configured maximum burst size, each transaction can be either a single access or a burst of accesses.

- Logical channel scheduling

When several logical channels are active at the same time, schedulers manage the read and write ports. The scheduling of logical channel transfers is similar for both read and write ports. When a logical channel becomes active, it is added to the tail of a scheduling queue. If more than one logical channel becomes active at the same time, the one with the lower number is queued first. This mechanism provides a first-come, first-serve scheduling scheme between the concurrently active logical channels.

In addition, each read and write port has a high-priority queue and a low-priority queue. The priority bit in the logical channel [DMA4\\_CCRI](#) register determines if a logical channel is queued as high or low priority. The relative weighting of the scheduling of the high-priority queue to the low priority queue is programmable from 1:1 to 1:256 through the DMA global channel register ([DMA4\\_GCR](#)).

---

**NOTE:** The [DMA4\\_GCR\[23:16\]](#) ARBITRATION\_RATE field is not dependent on the [DMA4\\_GCR\[13:12\]](#) HI\_THREAD\_RESERVED field. The ARBITRATION\_RATE field is dependent on the [DMA4\\_CCRI\[26\]](#) WRITE\_PRIORITY bit and the [DMA4\\_CCRI\[6\]](#) READ\_PRIORITY bit.

- Read/write port access scheduling policy

When either the read or write port becomes available, the port access scheduler selects the next logical channel for which to perform a DMA transaction from either the high- or low-priority queue.

When the current DMA transaction (single or burst access) is complete and the full DMA transfer is not finished, the logical channel returns to the tail of the queue. Because the port access scheduling is on a per-transaction basis, a logical channel can be queued repeatedly this way several times during its block transfer.

The SDMA module can have up to four outstanding read transactions and two outstanding write transactions in the system interconnect; four read and two write thread IDs exist. For an arbitration cycle to occur, these two conditions must be met:

- At least one channel is requesting.
- At least one free thread ID is available.

On an arbitration cycle, the scheduler grants the highest priority channel that has an active request, allocates the thread ID, and tags this thread as busy. At a given time, a channel cannot be allocated for more than one thread ID.

---

**NOTE:** If more than one channel is active, each channel is given a thread ID for the current service only, not for the whole channel transfer.

When only one channel is enabled, only one thread is allocated for the channel. In such a situation the channel can have maximum of 4 outstanding commands (without getting the responses) without rescheduling the channel at the end of each transaction. Each command can be either single access (8-bit, 16-bit or 32-bit) or burst access (2 x M, 4 x M, 8 x M or 16 x M, where M can be 8-bit, 16-bit or 32-bit).

When nonburst alignment is at the beginning of the transfer, the channel is rescheduled for each smaller access until burst-aligned. When the end of the transfer is not burst-aligned, the channel is rescheduled for each of the remaining smaller accesses.

For a logical channel transfer completion, when the last access is written to the destination, the logical channel becomes inactive. If enabled, an interrupt request is generated (see [Section 11.4.12, Interrupt Generation](#)).

#### 11.4.2 FIFO Queue Memory Pool

A FIFO queue memory pool provides buffering between the read and write ports. The hardware allocates the space dynamically to a number of FIFO queues, and each queue is associated with an active logical channel.

To avoid a memory pool overflow, if there are fewer entries in the FIFO queue memory pool than are required for the maximum configured source burst size of the next logical channel to be scheduled, the logical channel is returned to the tail of the queue, and the port access scheduler continues to search the queue until it finds a logical channel that can be scheduled.

The maximum FIFO depth that can be allocated to each individual logical channel can be limited globally through the [DMA4\\_GCR](#) register. This value should be configured to allow a fair allocation of the memory pool between the active channels.

A logical channel is scheduled if it has not yet reached its allocation limit, even if the access to be performed will exceed this limit. This means that the effective number of entries used by a particular logical channel is limited to the configured maximum entries per channel + channel maximum configured burst size (in words) -1.

#### 11.4.3 Addressing Modes

A DMA transfer block consists of a number of frames (FN). Each frame consists of a number of elements, and each element can have a size of 8, 16, or 32 bits, as follows:

$$\text{transfer block size} = \text{number of frames} \times \text{number of elements per frame} \times \text{element size}$$

The FN, number of elements per frame (EN), and size of elements are common for both the source and destination. However, the way in which the data is represented (addressing profile/mode) is independently programmable for the source and destination devices, using one of these four addressing modes:

- Constant: The address remains the same for consecutive element accesses.
- Post-increment: The address increases by the element size (ES), even across consecutive frames.
- Single-index: The address increases by the ES, plus the element index (EI) value minus one (even across consecutive frames).
- Double-index: The address increases by the ES, plus the EI value minus one within a frame. When a full frame is transferred, the address increases by the ES plus the frame index (FI) value minus 1.

The ES, EI, and FI values are expressed in bytes. The EI and FI values can be positive or negative.

When calculating the EI and FI values, it is critical to note that, after an element is accessed, the logical channel address pointer equals the address of the last byte (highest address) of the accessed element. The correct value for the EI or FI should be such that, when added to the logical channel address pointer, results in the address of the first byte (lowest address) of the next element to be accessed.

The EI and FI values must be configured so that the address of each element in the transfer is aligned on an ES boundary.

Consequently, the single-index addressing mode with EI = 1 or double-index addressing mode with EI = 1 and FI = 1 is equivalent to post-increment addressing.

---

**NOTE:** The source and destination start addresses must also be aligned on an ES boundary.

When the address of an element to be accessed is not aligned on an ES boundary, the transfer is stopped and a misaligned address error interrupt occurs, if enabled (see [Section 11.4.12, Interrupt Generation](#)).

The [DMA4\\_CFNI](#) register configures the FN in a block.

The [DMA4\\_CENI](#) register configures the EN.

The [DMA4\\_CSDPI](#) register configures the ES.

The DMA4\_CSSAi and DMA4\_CDSAi registers configure the source and destination start addresses.

The DMA4\_CCRi register configures the source and destination addressing modes.

The DMA4\_CSEi, DMA4\_CSFi, DMA4\_CDEi, and DMA4\_CDFi registers configure the source EI, source FI, destination EI, and destination FI, respectively.

The addressing profiles are expressed as equations as follows:

**Equation 1.** Constant addressing:

$$A(n+1) = A(n)$$

**Equation 2.** Post-increment addressing:

$$A(n+1) = A(n) + ES$$

**Equation 3.** Single-indexed addressing:

$$A(n+1) = A(n) + ES + (EI - 1)$$

**Equation 4.** Double-indexed addressing:

When not at the end of a frame or transfer (that is, when the element counter  $\neq 0$ ):

$$A(n+1) = A(n) + ES + (EI - 1)$$

When at the end of a frame but not at the end of the transfer (that is, when the element counter = 0 and the frame counter  $\neq 0$ ):

$$A(n+1) = A(n) + ES + (FI - 1)$$

Calculate the element and frame index as follows:

**Equation 5.** Element index

$$EI = [(Stride\ EI - 1) * ES] + 1$$

**Equation 6..** Frame index

$$FI = [(Stride\ FI - 1) * ES] + 1$$

where:

A(n): Byte address of the element n within the transfer.

ES is in bytes,  $ES \in \{1, 2, 4\}$ .

EI is in bytes, specified in a configuration register,  $-32768 \leq EI \leq 32767$ .

Stride EI: The difference in the number of elements between the start of the current element, n, to the start of next element, n+1.

Element counter: A counter that is (re)initiated with the number of elements per frame or per transfer. Decreased by 1 for each element transferred. The initial value is configured in the register DMA channel element number, DMA4\_CENi.

FI is in bytes, specified in a configuration register,  $-2147483648 \leq FI \leq 2147483647$ .

Stride FI: The difference in the number of elements between the start of the last element of the current frame and the beginning of the first element of the next frame.

Frame counter: A counter that is (re)initiated with the FN per transfer. Decreased by 1 for each frame transferred. The initial value is configured in the register DMA channel frame number, DMA4\_CFNI.

**Figure 11-7** shows how a stride EI and FI are defined. When handling complex configurations, using strides can make it easier to calculate EI and FI because you can calculate in elements instead of bytes. (This approach is used in the 90Degrees clockwise image rotation example shown in **Figure 11-11**.) The double-index addressing example shown in **Figure 11-7** has ES = 4, EN = 2, EI = 5, FI = 5, and FN = 2.

**Figure 11-7** through **Figure 11-10** show examples of addressing mode configurations. **Table 11-4** lists parameter values for the examples.

**Figure 11-7. Example Showing Double-Index Addressing, Elements, Frames, and Strides**

dma-007

**Figure 11-8. Addressing Mode Example (a)**

dma-008

**Figure 11-9. Addressing Mode Example (b)**

dma-009

**Figure 11-10. Addressing Mode Example (c)**

dma-010

**Table 11-4. Parameter Values for Addressing Mode Examples (a), (b), and (c)**

| Parameter       | Example (a)                         | Example (b)  | Example (c)  |
|-----------------|-------------------------------------|--------------|--------------|
| Addressing mode | Single index<br>(or post-increment) | Double index | Double index |
| Start address   | 0                                   | 0            | 8            |
| ES              | 4 (32-bit)                          | 4 (32-bit)   | 2 (16-bit)   |
| EN              | 3                                   | 2            | 2            |
| EI              | 1                                   | 5            | 1            |
| FN              | 1                                   | 2            | 2            |
| Frame index     | N/A                                 | 5            | -9           |

Double indexing can occur either on source (read) or destination (write). Equations for rotation of xx degrees on destination are obtained by taking equations for rotation of (360-xx) degrees on source, and swapping x and y in them. The opposite is also true. [Table 11-5](#) list the equations for rotation for 90, 180 and 270°.

**Table 11-5. Equations for Rotation**

|                                           |                    | 90° Rotation                       | 180° Rotation              | 270° Rotation                      |
|-------------------------------------------|--------------------|------------------------------------|----------------------------|------------------------------------|
| Double indexing on destination<br>(write) | Base address       | $ES \cdot (y-1)$                   | $ES \cdot (x \cdot y - 1)$ | $ES \cdot y \cdot (x-1)$           |
|                                           | Element index (EI) | $ES \cdot (y-1) + 1$               | $1 - 2 \cdot ES$           | $1 - ES \cdot (y+1)$               |
|                                           | Frame index (FI)   | $1 - ES \cdot [(x-1) \cdot y + 2]$ | $1 - 2 \cdot ES$           | $1 + ES \cdot (x-1) \cdot y$       |
| Double indexing on source (read)          | Base address       | $ES \cdot x \cdot (y-1)$           | $ES \cdot (x \cdot y - 1)$ | $ES \cdot (x-1)$                   |
|                                           | Element index (EI) | $1 - ES \cdot (x+1)$               | $1 - 2 \cdot ES$           | $ES \cdot (x-1) + 1$               |
|                                           | Frame index (FI)   | $1 + ES \cdot (y-1) \cdot x$       | $1 - 2 \cdot ES$           | $1 - ES \cdot [(y-1) \cdot x + 2]$ |

[Table 11-6](#) and [Figure 11-11](#) show the configuration required to perform a 90° clockwise image rotation of a 240 x 160 pixel, 32-bit image. The EI, frame size, and FI values are configured so that the image is rotated line by line starting at the left-hand end of the top line.

**NOTE:** The FI value for the destination is negative so that the first pixel of each subsequent line of the source image is written to the correct location at the destination.

Equation 5 and Equation 6 calculate the destination FI and EI. The example assumes that the image lines are stored at consecutive addresses in memory, meaning that both EI and FI on the source side are 1.

**Rotations:**

[Section 11.5.7, 90° Clockwise Image Rotation](#), describes how to program this example.

Observe that:

- One pixel = one element
- One line = one DMA frame
- Pixel size = element size = ES

**Table 11-6. Example Parameter Values for a 90° Clockwise Image Rotation**

| Parameter                   | Source Value                     | Destination Value                          |
|-----------------------------|----------------------------------|--------------------------------------------|
| Bits per pixel              | 32                               | 32                                         |
| ES                          | 4                                | 4                                          |
| Image width                 | SW                               | SH                                         |
| Image height                | SH                               | SW                                         |
| Stride elements (stride EI) | 1 element                        | SH                                         |
| Stride frames (stride FI)   | 1 element                        | $-[(SW-1)*SH+1] = -38241$ elements         |
| Start address               | 0x100000                         | $0x200000 + (SH - 1) \times ES = 0x20027C$ |
| EN                          | SW                               | SW                                         |
| EI                          | $[(Stride EI - 1) * ES] + 1 = 1$ | $[(Stride EI - 1) * ES] + 1 = 637$         |
| FN                          | SH                               | SH                                         |
| FI                          | $[(Stride FI - 1) * ES] + 1 = 1$ | $[(Stride FI - 1) * ES] + 1 = -152967$     |

**Figure 11-11. Example of a 90° Clockwise Image Rotation**



#### 11.4.4 Packed Accesses

When the logical channel ES is less than the DMA module read/write port size, and the addressing profile supports it (that is, post-increment mode or single- or double-index mode with EI = 1), the number of elements to transfer in each read/write port access may be maximized by specifying that the source or destination is packed through the channel [DMA4\\_CSDPi](#) register. Thus:

- For a read/write port size of 32 bits, the source or destination can be configured as packed for transfer ESs of 8 bits (four elements per access) and 16 bits (two elements per access).
- For a read/write port size of 64 bits, the source or destination can be configured as packed for transfer ESs of 8 bits (eight elements per access), 16 bits (four elements per access), and 32 bits (two elements per access).

Depending on the start address and transfer length, the first or last packed access might be only partially filled. This is indicated to the source or destination using the byte-enable signals.

#### 11.4.5 Burst Transactions

Transfer performance can be improved, where the source or destination and addressing profile supports it, by configuring the logical channel to perform burst transactions consisting of multiple instead of single accesses. The channel can be programmed to use burst sizes equivalent to 16, 32, or 64 bytes through the [DMA4\\_CSDPi](#) register, with the read burst size being programmable independently of the write burst size. Typically, the optimal burst size is 64 bytes (16 accesses for a 32-bit read/write port size or 8 accesses for a 64-bit read/write port size).

To obtain the maximum benefit from burst transactions, the source and destination start addresses should be aligned with the burst size. If this is not the case, the start of the transfer can consist of a number of smaller (single or burst) transactions until the first burst size boundary is reached.

Similarly, if the end of the transfer is not aligned on a burst size boundary, the final part of the transfer can consist of a number of smaller transactions.

---

**NOTE:** Except in the constant addressing mode, the source or destination must be specified as packed for burst transactions to occur.

---

#### 11.4.6 Endianism Conversion

The source and destination are each specified as little-endian or big-endian through the [DMA4\\_CSDPi](#) register for the particular logical channel. If the endianism of the source and destination differ, and the logical channel ES is less than the SDMA module read/write port size, an endianism conversion is applied to the data before it is written to the destination.

When transferring data between a source and a destination with different endianism, it is important to specify an ES that is equal to the type of data being transferred to preserve the correct data image at the destination.

In the system, endianism conversion can be performed in more than one place. It is possible to inform the source and/or destination to lock the endianism (that is, to not perform a conversion) through the logical DMA channel [DMA4\\_CSDPi](#) register.

#### 11.4.7 Transfer Synchronization

A logical channel can be programmed for either software-triggered or hardware synchronized transfers.

##### 11.4.7.1 Software Synchronization

A transfer is software-triggered when the logical channel is set up and started by software. To specify a software-triggered transfer, set the channel DMA register bits [DMA4\\_CCRI\[4:0\]](#) and [DMA4\\_CCRI\[20:19\]](#) to 0. The transfer starts as soon as the DMA register bit [DMA4\\_CCRI\[7\]](#) is set (that is, enters the scheduling process).

##### 11.4.7.2 Hardware Synchronization

A transfer is hardware-synchronized if the logical channel activation is driven by hardware requests from either the source or destination target. A hardware synchronized transfer is specified by configuring the DMA request line number in the channel [DMA4\\_CCRI](#) register to a value that corresponds to the DMA request line from the source or destination that generates the DMA requests. The DMA request numbers to be configured are specified in the DMA request mapping (see [Table 11-8](#)).

Specify the DMA request number in the channel DMA register bits **DMA4\_CCRI[4:0]** and **DMA4\_CCRI[20:19]**. After the DMA register bit **DMA4\_CCRI[7]** is set, the logical channel becomes enabled but not activated (that is, it does not enter the scheduling process), which means that channel registers are not updated until the first DMA request is received.

---

**NOTE: DMA Request Line**

A DMA request line must not be shared between concurrently enabled DMA channels. However, a DMA request line can be shared between several chained logical channels.

The channel synchronization control registers are 1-based. For example, to enable the **S\_DMA\_1** request, **DMA4\_CCRI[4:0]** SYNCHRO\_CONTROL must be set to 0x2 (DMA request number + 1).

For hardware synchronization, the amount of data to be transferred for each assertion of the DMA request line is configured through the frame synchronization (FS) and block synchronization (BS) bits in the logical channel **DMA4\_CCRI** register and the DMA register bits **DMA4\_CCRI[5]** and **DMA4\_CCRI[18]**, respectively.

The amount of data can be any of the following:

- A single element transfer: A complete element defined by Data\_type. For example, 8/16/32 bits are transferred in response to a DMA request.
- A full frame: A complete frame of several elements is transferred in response to a DMA request.
- A full block (a full channel transfer): A complete block of several frames is transferred in response to a DMA request.
- A full packet (a full channel transfer): A complete packet of several elements is transferred in response to a DMA request.

Packets allow the size of each part of the full DMA transfer to be configured independent of the organization of the data to be transferred (typically a number of elements). This can be useful when the source or destination has a buffer (such as a FIFO queue) with a size unrelated to the frame size of the transfer. The packet size then can be set to the size of the buffer.

Packet transfer must be used only where the source or destination is addressed in constant addressing mode, because FI registers are reused to specify size of the packet.

To support the burst mode, the logical channel must also be configured to use the target-port packed access mode.

The packet size is configured based on the source/destination synchronization select bit in the **DMA4\_CCRI** register through either the channel DMA4\_CDFi register (source synchronized) or the DMA4\_CSFi register (destination synchronized).

When the logical channel transfer block is not an exact multiple of the packet size, the final packet consists of the remaining elements in the transfer, using burst or single accesses to complete the block transfer.

The maximum transfer size, regardless of the packet size, is always as follows:

$$\text{Block\_size} = \text{Number\_of\_Frame\_in\_Block} * \text{Number\_of\_Element\_in\_Frame} * \text{Element\_Size}$$

- Synchronized at the source

The DMA module optimizes the transfer with respect to the number and size of burst transactions for the given source and destination addressing profiles and configured maximum burst sizes. When writing to the destination is slower than reading from the source, data is buffered in the channel FIFO queue. If the transfer is packet-synchronized at the source, the end-of-packet interrupt is disabled (see [Section 11.4.11, Reprogramming an Active Channel](#)).

For a source synchronized transfer, buffering can be enabled or disabled by setting the **DMA4\_CCRI[25]** BUFFERING\_DISABLE bit. For a packet source synchronization with buffering disabled and the packed/burst across the packet boundary, the last packed/burst write transaction is split in optimized smaller accesses to complete the packet transfer size. However, for a packet source synchronized transfer with buffering enabled and with the packed/burst across the packet boundary, the DMA module waits for the next DMA request(s) to read enough data to issue an atomic

packed/burst write transaction (assuming the address is packed/burst aligned).

---

**NOTE:** Regardless of whether buffering is enabled or not, buffering is not performed between frames. If the packed/burst is across the frame boundary, the last packed/burst write transaction is split into optimized smaller accesses to complete the frame transfer size.

---

- Synchronized at the destination

The performance of a hardware-synchronized transfer can be improved by using the prefetch mode, enabled through the channel DMA register bit [DMA4\\_CCRI\[23\]](#). Data is prefetched on the read port side in advance of the DMA request received and buffered in the FIFO queue. Up to a full transfer block can be prefetched, although this can be limited by the specified maximum channel FIFO queue depth (see [Section 11.4.2, FIFO Queue Memory Pool](#)).

Buffering disable is not allowed for a destination-synchronized transfer.

---

**NOTE:** Behavior is undefined when prefetch is enabled and a transfer is synchronized to the source.

Whether buffering is enabled or disabled, the last transaction in the frame or in the block is write nonposted (WNP) even if the write mode is specified as write last nonposted (WLNP; the WRITE\_MODE bit field of the [DMA4\\_CSDPi](#) register = 0x2). However, in a packet synchronization mode, the last transaction of each packet in the transfer is WNP only if buffering disable is on (even if the write mode is specified as WLNP).

Regardless of whether buffering disable is enabled or disabled, the packet interrupt is not generated in the packet source synchronized mode.

---

### CAUTION

The BUFFERING\_DISABLE bit field of the [DMA4\\_CCRI](#) register must be filled with an allowed value, as specified in [Table 11-7](#).

---

**Table 11-7. Buffering Disable**

| BUFFERING_DISABLE                           |   |             |
|---------------------------------------------|---|-------------|
| (0: buffering enable, 1: buffering disable) |   |             |
| Destination synchronized                    | 0 | Allowed     |
|                                             | 1 | Not allowed |
| Source synchronized                         | 0 | Allowed     |
|                                             | 1 | Allowed     |

Synchronized transfer monitoring using CDAC ([DMA4\\_CDACi](#)):

Context is restored only when the channel becomes active on a DMA request (not at software enable). The channel is software-enabled first, and then a DMA request is asserted followed by the first context restore.

The CDAC register is writable; thus, you can initialize the CDAC to monitor the transfer and determine if the transfer is started or not (see [Section 11.5.4, Synchronized Transfer Monitoring Using CDAC](#), for more information).

---

**NOTE:** For 16-bit transactions, start reading from or writing to the LSByte first to enable the register update. This is not an issue for 32-bit read-write transactions.

### 11.4.8 Thread Budget Allocation

When several concurrent channels are latency critical and hardware synchronized, a specific latency cannot be ensured until the target is served. This situation occurs when the concurrent channel number is superior to the number of available threads.

---

**NOTE:** Four threads are available on the read port, and two threads are available on the write port.

For a hardware-synchronized transfer (memory to peripheral), a minimum bandwidth for a latency-critical transfer must be ensured to avoid collisions between two hardware requests.

Because it is latency critical, the software user is responsible for the following:

- Programming the synchronized channel as a high-priority channel
- Reserving one or several threads for high-priority channels

The proposed implementation is as follows (see [Section 11.5.5](#)):

Prevent the regular channel queue from exceeding more than a programmable (3, 2, or 1) number of threads on the read port and no more than one thread on the write port. This number can be set on the global register [DMA4\\_GCR\[13:12\]](#).

The thread reservation is programmable for maximum use of thread resources for concurrent, low-priority channel transfer. Programmability can also allow a partial throughput control by limiting in software the number of concurrent outstanding requests that break the pipelining.

Depending on the [DMA4\\_GCR \[13:12\]](#) value, the following threadID on the read/write ports are reserved for a high-priority channel:

Read port priority thread reservation:

- [DMA4\\_GCR\[13:12\] = 0x0](#) => No ThreadID is reserved for high-priority channels.
- [DMA4\\_GCR\[13:12\] = 0x1](#) => Read ThreadID 0 is reserved for high-priority channels.
- [DMA4\\_GCR\[13:12\] = 0x2](#) => Read ThreadID 0 and Read ThreadID 1 are reserved for high-priority channels.
- [DMA4\\_GCR\[13:12\] = 0x3](#) => Read ThreadID 0, Read ThreadID 1, and Read ThreadID 2 are reserved for high-priority channels.

Write port priority thread reservation:

- [DMA4\\_GCR\[13:12\] = 0x0](#) => No ThreadID is reserved for high-priority channels
- [DMA4\\_GCR\[13:12\] = 0x1](#) => Write ThreadID 0 is reserved for high-priority channels.
- [DMA4\\_GCR\[13:12\] = 0x2](#) => Write ThreadID 0 is reserved for high-priority channels.
- [DMA4\\_GCR\[13:12\] = 0x3](#) => Write ThreadID 0 is reserved for high-priority channels.

Regardless whether or not the enabled channels are of high priority, only the setting of the [DMA4\\_GCR\[13:12\]](#) value forces the thread reservation to these values. Set the appropriate value to avoid losing threads using only regular channels.

To have an independent read and write priority context, a per-channel bit [DMA4\\_CCRi\[26\]](#) is added for write priority, and the previous priority bit becomes read priority bit [DMA4\\_CCRi\[6\]](#).

---

**NOTE:** The device has one priority bit per logical channel, not one per port.

### 11.4.9 FIFO Budget Allocation

To avoid fully occupying the FIFO with a high-priority transfer while low-priority channels wait in the arbitration queue, two separate FIFO budgets are specified: one for high-priority channels and one for low-priority channels. This is defined in the [DMA4\\_GCR](#) register, allowing the user to share the FIFO budget between the low- and high-priority channels. The amount of the FIFO allocated by the low- and high-priority channels is fixed by the value set in the [DMA4\\_GCR\[15:14\]](#) HI\_LO\_FIFO\_BUDGET field. The maximum channel FIFO depth is limited by the HI\_LO\_FIFO\_BUDGET field as follows:

If the channel is low priority:

- When HI\_LO\_FIFO\_BUDGET = 0x1, then low priority cannot exceed 75 percent of the total FIFO.
- When HI\_LO\_FIFO\_BUDGET = 0x2, then low priority cannot exceed 25 percent of the total FIFO.
- When HI\_LO\_FIFO\_BUDGET = 0x3, then low priority cannot exceed 50 percent of the total FIFO.

If channel is high priority

- When HI\_LO\_FIFO\_BUDGET = 0x1, then high priority cannot exceed 25 percent of the total FIFO.
- When HI\_LO\_FIFO\_BUDGET = 0x2, then high priority cannot exceed 75 percent of the total FIFO.
- When HI\_LO\_FIFO\_BUDGET = 0x3, then high priority cannot exceed 50 percent of the total FIFO.

The user is responsible for performing the following equation:

- For a high-priority channel: (Per\_Channel\_Maximum FIFO Depth + 1) x Number of High Channel <= High Budget FIFO
- For a low-priority channel: (Per\_Channel\_Maximum FIFO Depth + 1) x Number of Low Channel <= Low Budget FIFO

---

**NOTE:** Ensure that *Number of High Channel* means *Number of Active High-Priority Channel* and that *Number of Low Channel* means *Number of Active Low-Priority Channel*.

---

#### 11.4.10 Chained Logical Channel Transfers

Chaining multiple logical channels permits transfers consisting of multiple parts to be executed without repeated software intervention. This results in better performance than the alternative of software setting up and starting each transfer separately. Each part of a chained transfer can have the data addressed in a different manner that permits the programming of a variety of complex transfers. For example:

- Interlaced video data with one logical channel configured to transfer the even lines and another logical channel configured to transfer the odd lines
- Protocol headers with a separate DMA4 channel configured to transfer each field in the header

Channels can be chained through each channel **DMA4\_CLNK\_CTRLi** register. When the transfer for the first channel completes, the next channel in the chain is enabled. The number of channels in the chain that are configured for hardware-synchronized transfers is flexible (although typically it might be all, none, or just the first one). The DMA request line number should be set to 0 to specify that any or all of the channels in a chain are software-triggered or nonsynchronized.

The last channel in a chain can be chained to the first channel to create a continuously looping chain. The continuously looping transfer can be stopped on the fly at a specific channel by disabling the **DMA4\_CLNK\_CTRLi[15]** ENABLE\_LNK bit. The looping transfer stops after the specified channel transfer is complete.

---

**NOTE: DMA Request Line**

A DMA request line must not be shared between concurrently enabled DMA channels. However, a DMA request line can be shared between several chained logical channels.

---

For more information on the programming model, see [Section 11.5, SDMA Basic Programming Model](#).

#### 11.4.11 Reprogramming an Active Channel

A currently active logical DMA channel can be disabled through the **DMA4\_CCRI[7]** ENABLE bit. When any ongoing transaction is complete and the read-active and write-active bits in the **DMA4\_CCRI** register (**DMA4\_CCRI[9]** RD\_ACTIVE and **DMA4\_CCRI[10]** WR\_ACTIVE) are reset, the channel can be reprogrammed for a new transfer.

### 11.4.12 Interrupt Generation

The SDMA module has four interrupt request output lines, SDMA\_IRQ\_0 to SDMA\_IRQ\_3. One or more logical channels can be programmed to generate an interrupt request on any of these lines when any one of the maskable DMA events listed in [Table 11-8](#) occurs.

**Table 11-8. Logical DMA Channel Events**

| Event                        | Description                                                                                                                                                                                                                                 |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| End of packet                | A packet transfer completed.                                                                                                                                                                                                                |
| End of block                 | A block transfer completed.                                                                                                                                                                                                                 |
| End of frame                 | A frame transfer completed.                                                                                                                                                                                                                 |
| End of super block           | A super block transfer completed.                                                                                                                                                                                                           |
| Half of frame                | Half of the current frame transferred.                                                                                                                                                                                                      |
| Start of last frame          | The first element of the last frame transferred.                                                                                                                                                                                            |
| Transaction error            | A transaction error returned by the interconnect in either the read or write port.                                                                                                                                                          |
| Address error                | An attempt was made to perform a DMA access to an address not aligned on an ES boundary. Condition to occur: if DMA4_CEN[23:0] CHANNEL_ELMNT_NBR = 0x000000 or DMA4_CFN[15:0] CHANNEL_FRAME_NBR = 0x0000 or DMA4_CSDP[1:0] DATA_TYPE = 0x3. |
| Supervisor transaction error | An error occurred, for example, when an unauthorized initiator (that is not a supervisor) tries to use a supervisor transfer.                                                                                                               |
| Drain end                    | Drain is completed ( <a href="#">DMA4_CCRi[10]</a> WR_ACTIVE becomes 0).                                                                                                                                                                    |
| Drop error                   | A drop event interrupt is generated when a DMA request is being serviced while a second one is asserted and a third one arrives before the second DMA request is serviced.                                                                  |

The logical DMA channels that generate an interrupt on a particular IRQ output are specified through the [DMA4\\_IRQENABLE\\_Lj](#) register (where  $j$  is the IRQ number: 0, 1, 2, or 3). The events that generate an interrupt for a particular channel can be configured through the channel [DMA4\\_CICRi](#) register.

When an interrupt is detected, the logical DMA channel generating the event can first be identified by reading the [DMA4\\_IRQSTATUS\\_Lj](#) register. The event causing the interrupt then can be identified by reading the interrupt status via the relevant DMA channel [DMA4\\_CSRi](#) register.

### 11.4.13 Packet Synchronization

A packet transfer notion is related to the behavior of some peripheral, which have certain buffering capability and requires to transfer the buffer content once an element number threshold is reached (a hardware DMA request is generated). To associate a frame synchronization to each DMA request is possible, but this limits the maximum transfer size. Indeed the maximum transfer size is proportional to the FIFO depth of the peripheral:

`maximum_transfer_size = peripheral_FIFO_depth x number_of_frame_in_block.`

The packet synchronization allows to dissociate the transfer size from the FIFO depth of the peripheral. Only Constant addressing mode is allowed on RD port or WR port if source target or destination target is packet synchronized respectively.

*Example:*

Let's consider a camera interface, which have a FIFO\_depth of 128 Words and a FIFO\_element\_number\_threshold of 128 and a picture to transfer with a size 320 lines per 240 columns. If frame synchronization is associated to each DMA request then the maximum transfer size that can be performed is  $128 \times 2^{16}$  words. In this case, a frame is 128 words long, which does not fit the size of a line. Then it's not possible to generate an interrupt at the end of line. However with introducing the packet transfer notion, which is related to the peripheral FIFO behavior/structure, the maximum transfer size (`maximum_transfer_size =  $2^{24} \times 2^{16}$  words`) is independent of both `peripheral_FIFO_depth` and `FIFO_element_number_threshold`. This allows, making an enough long transfer within one channel context and perform rotation operation on big image format.

The main features of DMA Packet transfer are as follows:

- DMA Packet\_Data\_Size for each DMA Request: typically this will be Peripheral\_element\_number\_threshold Number of elements in a packet shares the [DMA4\\_CSFI](#) and [DMA4\\_CDFI](#) configuration registers. Indeed if the peripheral is the source target, respectively destination target, that means the used addressing mode is constant, consequently [DMA4\\_CSFI](#)[15:0], respectively [DMA4\\_CDFI](#)[15:0], is used to specify the packet data size (PKT\_ELNT\_NBR) and the bit fields [31:16] are unused. To specify the Packet data size in the [DMA4\\_CSFI](#) or [DMA4\\_CDFI](#), the user must set the [DMA4\\_CCRI](#)[24] SEL\_SRC\_DST\_SYNC respectively to 1 or 0.

---

**NOTE:** The packet size can be a sub-multiple or non sub-multiple of a frame size. If DMA Packet\_Data\_Size is aligned on DMA channel block data size boundary, DMA will transfer the last data in channel block boundary and stop at block boundary for the last packet DMA request. If the Packet\_Data\_size is not aligned on the block boundary, the remaining data smaller than a packet size are transferred using burst or single accesses to complete the block.

- DMA Packet\_Data\_Transfer does not affect DMA channel capabilities in term of packing and bursting.

The Packet synchronization mode is active when [DMA4\\_CCRI](#)[5] FS = [DMA4\\_CCRI](#)[18] BS = 1. Then

- if [DMA4\\_CCRI](#)[24] SEL\_SRC\_DST\_SYNC=0; [DMA4\\_CDFI](#)[15:0] gives the number of element in packet and [DMA4\\_CDFI](#)[31:16] is unused for the packet size.
- if [DMA4\\_CCRI](#)[24] SEL\_SRC\_DST\_SYNC=1; [DMA4\\_CSFI](#)[15:0] gives the number of element in packet and [DMA4\\_CSFI](#)[31:16] is unused for the packet size.

---

**NOTE:** The maximum transfer size, regardless of the packet size, is always: Block\_size = Number\_of\_Frame\_in\_Block x Number\_of\_Element\_in\_Frame x Element\_Size. If the DMA channel packet/burst access is across packet boundary, DMA hardware automatically splits this packing/burst access into multiple smaller accesses, which will be aligned on packet boundary. Otherwise, the DMA transfers data as usual packing/burst access.

#### 11.4.14 Graphics Acceleration Support

The SDMA supports two graphic acceleration features:

- Transparent copy
- Constant fill

Only one of these features can be enabled at any given time through the [DMA4\\_CCRI](#) register for the particular logical DMA channel.

The transparent copy feature enables specification of a particular color through the [DMA4\\_COLORI](#) register, so that when it is recognized in the data from the source, it is not copied to the corresponding location in the destination, but instead leaves the data in the corresponding location in the destination as it is.

Figure 11-12 shows the 2-D graphic transparent color block diagram.

**Figure 11-12. 2-D Graphic Transparent Color Block Diagram**

The constant fill feature provides the ability to specify a particular color through the [DMA4\\_COLOR](#) register for every specified location in the destination. In this case, the transfer consists only of writing to the destination without reading from a source.

Both features support 8 bpp (bits per pixel), 16 bpp, and 24 bpp, depending on what is specified as the DMA transfer ES via the [DMA4\\_CSDP](#)<sub>i</sub> register. An ES of 32 bits corresponds to 24 bpp. During a 32-bit (24 bpp) transfer, the most-significant 8 bits ([31:24]) are 0. Both features are compatible with packed and burst transactions.

#### 11.4.15 Supervisor Modes

A logical DMA channel can be configured to operate in supervisor mode through the corresponding bits in the channel [DMA4\\_CC](#)<sub>i</sub> register. This must be done using supervisor access. Once a channel is configured in supervisor mode, the channel configuration is protected from nonsupervisor accesses. All DMA transactions on a supervisor channel are supervisor transactions.

#### 11.4.16 Posted and Nonposted Writes

A logical channel can be configured in its DMA register bits [DMA4\\_CSDP](#)<sub>i</sub>[17:16] to use one of three write access handshake modes for the destination:

- Nonposted write: Each write must complete before transfer can continue or complete.
- Posted write: Transfer continues without waiting for each write to complete (might improve performance with slow devices).
- Posted with final write nonposted: Transfer continues without waiting for each write to complete, but final write is completed before transfer can complete.

#### 11.4.17 Disabling a Channel During Transfer

When a channel is disabled during a transfer, the channel will undergo an abort, except if the channel was hardware source synchronized with buffering Enabled ([DMA4\\_CC](#)<sub>i</sub>[25] BUFFERING\_DISABLE='0'). In that case, the fifo will be drained in order to avoid losing data. See [Section 11.4.18](#) for details on this feature.

#### 11.4.18 FIFO Draining Mechanism

When a source synchronized channel is disabled during a transfer, then the current hardware request (element/packet/frame/block) service is completed and the channel [DMA4\\_CC](#)<sub>i</sub>[9] RD\_ACTIVE bit is set to 0, which means the channel is not active on the read port. The remaining data in the corresponding disabled channel FIFO is drained onto the write port and transferred to the programmed destination as in normal transfer.

At the end of the draining the [DMA4\\_CCRI\[10\]](#) WR\_ACTIVE bit is set to 0 (channel is no more active on the write port) and if the [DMA4\\_CICRI\[12\]](#) DRAIN\_END\_IE is set to 1, the status bit [DMA4\\_CSRI\[12\]](#) DRAIN\_END is updated and an interrupt is generated.

Once a channel is disabled during a transfer, it needs to wait for [DMA4\\_CCRI\[9\]](#) RD\_ACTIVE and [DMA4\\_CCRI\[10\]](#) WR\_ACTIVE to become '0' before being re-enabled for a new transfer. The FIFO drain for a channel will happen only in the following cases:

- If the channel is a source synchronized channel and [DMA4\\_CCRI\[25\]](#) BUFFERING\_DISABLE='0' and
- If the channel is not a solid fill channel and
- If the channel is not a transparent and copy channel

---

**NOTE:** In case of a self-linked or chain-linked channel, it is user responsibility to disable the [DMA4\\_CLNK\\_CTRL\[15\]](#) ENABLE\_LINK bit before disabling the channel.

---

In all other cases, the channel will undergo an abort.

---

**NOTE:** If the channel intended to be used is a drain candidate, always enable DRAIN END INTERRUPT for that channel.

When the sDMA is in smart standby mode, before disabling a drain candidate channel ([DMA4\\_CCRI\[7\]](#) ENABLE = 0x0), the sDMA must be configured to be in force standby mode ([DMA4\\_OCP\\_SYS CONFIG\[13:12\]](#) = 0x0) or in no standby mode ([DMA4\\_OCP\\_SYS CONFIG\[13:12\]](#) = 0x1). After the occurrence of DRAIN END INTERRUPT EVENT from that channel, the sDMA can be switched back to smart standby mode ([DMA4\\_OCP\\_SYS CONFIG\[13:12\]](#) = 0x2).

---

## 11.4.19 Linked List

### 11.4.19.1 Overview

The SDMA supports the logical transfer descriptor loader feature. A transfer descriptor represents a set of values that maps to a set of logical channel configuration registers.

A logical channel transfer descriptor can be loaded by DMA from memories, then successive transfer descriptors can be autonomously loaded according to a linked-list scheme. This enables DMA4 scatter gather transfers with minimum MPU support by removing successive channel configuration processing and the associated interrupt handling overheads. It also optimizes DMA4 channel resources by enabling efficient transfer serialization on a single logical channel versus concurrent (multiple) logical channel use.

Different types of transfer descriptors are supported (full or partial logical channel configuration registers are set). This optimizes the memory size required for storing a long linked list, because parameter changes are limited to only a few logical channel configuration registers.

### 11.4.19.2 Link-List Transfer Profile

A linked-list transfer can be seen as a super-block transfer (where the block is composed of FN frames and each frame includes EN elements). In a super block. The block size (FN x EN x ES) can be changed in the linked list by loading an updated transfer descriptor.

The end of the super block is signaled in the last descriptor associated with the last block. Generally, for a given link-list transfer, the logical channel is set at the beginning of the transfer and the logical channel configurations for the subsequent blocks are slightly changed. Thus, the descriptor can be limited to an update of only few parameters, like FN or EN. This assumes that the content of unmodified registers is preserved when a new descriptor is loaded.

A transfer descriptor is composed of a set of channel configuration register values with the addition of the next-descriptor pointer register ([DMA4\\_CNDPI](#)) and a channel-descriptor parameter register ([DMA4\\_CDPi](#)). The next-descriptor pointer is the 32-bit address pointer from where the next transfer descriptor is to be loaded.

Using the next-descriptor pointer, the user can also stop a link-list transfer by setting the DMA4\_CNDPi[31:2] NEXT\_DESCRIPTOR\_POINTER bit field of the last descriptor to 0x3FFF FFFF (that is, setting the DMA4\_CNDPi[31:0] bit field to 0xFFFF FFFC).

#### CAUTION

The setting of the DMA4\_CNDPi[31:2] NEXT\_DESCRIPTOR\_POINTER bit field must be done only through the descriptor load (that is, only from the descriptor content). This is because once the channel is configured and enabled, it is not recommended to change the configuration through configuration port access. However, if there are no descriptors in the link-list chain, but still making the channel a descriptor (type 1, 2, 3) candidate, the user can configure the value 0x3FFF FFFF into the DMA4\_CNDPi[31:2] NEXT\_DESCRIPTOR\_POINTER bit field (0xFFFF FFFC into DMA4\_CNDPi[31:0]) through configuration port access.

#### 11.4.19.3 Descriptors

A transfer descriptor is a set of values that maps to a set of logical channel configuration registers. Such a descriptor contains the parameters associated with a transfer profile (transfer size, source or destination addresses, etc). Four different types of transfer descriptors are supported to optimize the memory size required to store a long linked list, and to minimize MPU use to create and maintain the descriptor list.

A transfer descriptor is a list of 32-bit values. A descriptor must be 32-bit-aligned in memory. Only the 30 least-significant bits (LSBs) of the next-descriptor address pointer are updated from the descriptor, and the DMA4 forces the 2 LSBs to 0 on the generation of the pointer address. The descriptor size, which is variable, depends on the descriptor type and the Nxt\_Dv and Nxt\_Sv bit fields.

Transfer descriptor bit mapping is the same as DMA4 logical-channel configuration register bit mapping, with the following exceptions:

- Src\_Element\_index and Dst\_Element\_index are concatenated in the same 32-bit location.
- [DMA4\\_CICRi](#) (interrupt event mask)
- CFN (frame number)
- Bit fields:
  - P: Corresponds to the PAUSE\_LINK\_LIST bit:
    - When set to 1 in the descriptor, the channel is suspended when the descriptor load completes.
    - The user must not set this bit to 1 through the configuration port. Otherwise, behavior is undefined.
    - When set to 0 (through configuration port) after pause, the linked-list channel resumes its transfer (either descriptor load or data load).
  - B: Corresponds to the end-of-block enable bit (BLOCK\_IE) of the [DMA4\\_CICRi](#) register. Valid only for type 3. This value is don't care for descriptor types 1 and 2 where [DMA4\\_CICRi](#) is fully specified.
  - Nxt\_Dv, Nxt\_Sv: Mapped in the [DMA4\\_CDPI](#) register. They indicate one of the following possibilities:
    - Next descriptor contains an updated destination or source address.
    - Next descriptor does not update the source or destination address, but increments the last source or destination address (from the end of the last transfer).
    - The next source address and/or destination address are the last valid ones in the configuration memory. This means that the corresponding location in the configuration memory is not updated (assuming that they were initialized at least once in the past). This is also called wrapping addressing.
  - Next\_Descriptor\_Type: Specify the next descriptor type that corresponds to the NEXT\_DESCRIPTOR\_TYPE bit field in the [DMA4\\_CDPI](#) register.

### 11.4.19.3.1 Type 1

A type 1 descriptor includes the overall channel configuration register value to be loaded (global registers are not part of the type 1 descriptor). This descriptor is used primarily when major changes are required:

- Channel read or write access profiles must be modified, for instance, for bursting and packing (included in the [DMA4\\_CSDPi](#) register).
- Attach a new DMA request to the same channel or change the priority (included in the [DMA4\\_CCRI](#) register).
- Enable solid or transparent color fill (included in the [DMA4\\_CCRI](#) and [DMA4\\_COLORI](#) registers).
- Enable a channel link (included in the [DMA4\\_CLNK\\_CTRLi](#) register).

[Table 11-9](#) shows a type 1 descriptor.

**Table 11-9. Type 1**

|              |                                 |        |        |        |                |        |        |        |        |        |        |        |        |        |                   |        |        |        |        |        |        |        |        |        |        |         |        |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |
|--------------|---------------------------------|--------|--------|--------|----------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-------------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---------|--------|--------|--------|--------|--------|--|--|--|--|--|--|--|--|--|--|--|
|              | 3<br>1                          | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7         | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7            | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 8<br>7 | 7<br>6 | 6<br>5  | 5<br>4 | 4<br>3 | 3<br>2 | 2<br>1 | 1<br>0 |  |  |  |  |  |  |  |  |  |  |  |
| Ptr+<br>0x2C | CCR                             |        |        |        |                |        |        |        |        |        |        |        |        |        |                   |        |        |        |        |        |        |        |        |        |        |         |        |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |
| Ptr+<br>0x28 | CLNK_CTRL                       |        |        |        |                |        |        |        |        |        |        |        |        |        |                   |        |        |        |        |        |        |        |        |        |        |         |        |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |
| Ptr+<br>0x24 | CSDP                            |        |        |        |                |        |        |        |        |        |        |        |        |        |                   |        |        |        |        |        |        |        |        |        |        |         |        |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |
| Ptr+<br>0x20 | COLOR                           |        |        |        |                |        |        |        |        |        |        |        |        |        |                   |        |        |        |        |        |        |        |        |        |        |         |        |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |
| Ptr+<br>0x1C | Src_Frame_index/Src_Packet_size |        |        |        |                |        |        |        |        |        |        |        |        |        |                   |        |        |        |        |        |        |        |        |        |        |         |        |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |
| Ptr+<br>0x18 | Dst_Frame_index/Dst_Packet_size |        |        |        |                |        |        |        |        |        |        |        |        |        |                   |        |        |        |        |        |        |        |        |        |        |         |        |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |
| Ptr+<br>0x14 | Src_Element_index               |        |        |        |                |        |        |        |        |        |        |        |        |        | Dst_Element_index |        |        |        |        |        |        |        |        |        |        |         |        |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |
| Ptr+<br>0x10 | CICR (interrupt events Mask)    |        |        |        |                |        |        |        |        |        |        |        |        |        | CFN Frame Number  |        |        |        |        |        |        |        |        |        |        |         |        |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |
| Ptr+<br>0xC  | Destination_Start_Address       |        |        |        |                |        |        |        |        |        |        |        |        |        |                   |        |        |        |        |        |        |        |        |        |        |         |        |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |
| Ptr+<br>0x8  | Source_Start_Address            |        |        |        |                |        |        |        |        |        |        |        |        |        |                   |        |        |        |        |        |        |        |        |        |        |         |        |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |
| Ptr+<br>0x4  | N_type                          | B      | Dv     | Sv     | Element_number |        |        |        |        |        |        |        |        |        |                   |        |        |        |        |        |        |        |        |        |        | R<br>sv | P      |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |
| Ptr          | Next_descriptor_address_pointer |        |        |        |                |        |        |        |        |        |        |        |        |        |                   |        |        |        |        |        |        |        |        |        |        |         |        |        |        |        |        |  |  |  |  |  |  |  |  |  |  |  |

### 11.4.19.3.2 Type 2

A type 2 descriptor includes the overall logical channel transfer address register and transfer format register to be loaded. This descriptor enables 2D addressing linked-list transfer (for example, a multimedia application where 2D objects are moved in a link). [Table 11-10](#) shows a type 2 descriptor with source and destination address updates. [Table 11-11](#) shows a type 2 descriptor with one source or destination address update.

**Table 11-10. Type 2 With Source and Destination Address Updates**

**Table 11-11. Type 2 With Source or Destination Address Update**

### **11.4.19.3.3 Type 3**

A type 3 descriptor is limited to a few logical channel transfer address registers and transfer format registers to be loaded. This descriptor enables simple 1D addressing link transfer (for example, scatter-gather or ping-pong memory movement using a linked list). [Table 11-12](#) shows a type 3 descriptor with source and destination address updates. [Table 11-13](#) shows a type 3 descriptor with one source or address destination update.

**Table 11-12. Type 3 With Source and Destination Address Updates**

**Table 11-13. Type 3 With Source or Destination Address Update**

|             |                                                   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------------|---------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|             | 3                                                 | 3 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Ptr+<br>0x8 | Source_Start_Address or Destination_Start_Address |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Ptr+<br>0x4 | Element_number                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Ptr         | Next_descriptor_address_pointer                   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

#### 11.4.19.4 Linked-List Control and Monitoring

##### 11.4.19.4.1 Transfer Mode Setting

Four descriptor types are available in [DMA4\\_CDPI\[9:8\]](#) TRANSFER\_MODE to distinguish the different transfer modes:

- [DMA4\\_CDPI\[9:8\]](#) TRANSFER\_MODE = 00: The current channel is using normal mode.
- [DMA4\\_CDPI\[9:8\]](#) TRANSFER\_MODE = 01: The current channel is using link-list channel mode for a type 1, 2, or 3 descriptor.

The reset value is Normal mode ([DMA4\\_CDPI\[9:8\]](#) TRANSFER\_MODE = 0).

##### 11.4.19.4.2 Starting a Linked List

Like a nonlinked-list transfer, a link transfer starts under host control by enabling the associated logical channel (set the [DMA4\\_CCRI\[7\]](#) ENABLE bit to 1). The [DMA4\\_CDPI\[10\]](#) FAST bit sets the start mode of the link-list transfer:

In nonfast-start mode, the logical channel configuration is fully initialized so that the transfer can start without descriptor loading.

In fast-start mode, the descriptor pointer and other inputs are given. The channel starts by loading the descriptor and then starts the data transfer phase.

##### 11.4.19.4.3 Monitoring a Linked-List Progression

In addition to the [DMA4\\_CCENi](#) (remaining elements) and [DMA4\\_CCFNi](#) (remaining frames) registers that are used to monitor the transfer progress, a per-channel register, [DMA4\\_CCDNi](#) (channel current active descriptor number), monitors which descriptor in the list is active. The user must initialize the [DMA4\\_CCDNi](#) register to 0 during the initial configuration. When the [DMA4\\_CCDNi](#) register is updated, the [DMA4\\_CCFNi](#) and the [DMA4\\_CCENi](#) registers are updated. The user must also initialize the [DMA4\\_CCFNi](#) and [DMA4\\_CCENi](#) registers to 0xFFFF and to 0xFFFF, respectively, to track the effective transfer start of synchronized transfer.

##### 11.4.19.4.4 Interrupt During Linked-List Execution

Any logical channel source of interrupt can be triggered during a linked-list execution, if the interrupt source is enabled, during the initial configuration in CICR. The [DMA4\\_CICRI](#) register can also be updated during the linked-list execution if descriptor types 1 and 2 are used.

The use of an interrupt event in a link execution can be difficult, because the link can progress in parallel with interrupt service routine (ISR) execution. This makes it difficult to synchronize them unless system assumptions are used. The most appropriate synchronization model is to get an interrupt-only on linked-list completion, when the last transfer block is complete. This prevents the interrupt from occurring during the link execution. An end-of-super-block interrupt event available in the [DMA4\\_CICRI](#) and [DMA4\\_CSRI](#) registers can be enabled at initial configuration or when using descriptor types 1 and 2. To prevent the use of descriptor type 1 or 2 to update BLOCK\_IE (full [DMA4\\_CICRI](#) update), a dedicated BLOCK\_IE bit field is also available in a type 3 descriptor.

#### 11.4.19.4.5 Pause a Linked List

When the channel is suspended, it remains enabled.

The pause behaves differently, depending on the transfer mode:

- Normal transfer mode: If the user sets the **DMA4\_CDPI[7]** PAUSE\_LINK\_LIST bit to 1, the channel completes the current read and write transactions and then suspends the channel. The channel can be resumed by setting the channel **DMA4\_CDPI[7]** PAUSE\_LINK\_LIST bit to 0.
- Linked-list type 1, 2, or 3 mode: The user must not set the **DMA4\_CDPI[7]** PAUSE\_LINK\_LIST bit through the configuration port; otherwise, transfer behavior is undefined.

A PAUSE\_LINK\_LIST bit (P) is set to 1 in the descriptor.

- The channel is suspended after the descriptor load, translation, and configuration memory update are complete.
- The linked list can be resumed by resetting the **DMA4\_CDPI[7]** PAUSE\_LINK\_LIST bit (through the configuration port).

#### 11.4.19.4.6 Stop a Linked List (Abort or Drain)

The channel can be stopped in case of a drain or an abort. These cases are exclusive.

##### 11.4.19.4.6.1 Drain

- Drain conditions:  
A channel is a drain candidate if it is a hardware-source-synchronized transfer with [DMA4\\_CCRI\[25\]](#) BUFFERING\_DISABLE = 0 and channel should not be doing any of the graphics operation (transparent copy or solid-color fill).
- Drain trigger:  
A drain candidate channel is drained if it is disabled. ([DMA4\\_CCRI\[7\]](#) ENABLE = 0) or if it receives a transaction error on the read port.
- Drain behavior with a type 1, 2, or 3 descriptor. Drain trigger can occur in two situations:
  - During descriptor loading: Any ongoing current transaction is complete and the channel is aborted.
  - During data loading: The read is completed at the boundary of the request (element/frame/packet/block boundary), the FIFO is drained to the destination, and then a DRAIN\_END interrupt can be asserted.

##### 11.4.19.4.6.2 Abort

- Abort condition:  
A channel is an abort candidate if it is software-synchronized, hardware-destination-synchronized, solid color-fill, transparent-color fill, or hardware-source-synchronized with [DMA4\\_CCRI\[25\]](#) BUFFERING\_DISABLE = 1.
- Abort trigger:  
A channel is an abort candidate if it is disabled. ([DMA4\\_CCRI\[7\]](#) ENABLE = 0), if it receives a transaction error on the read or write port, or if there is a MISALIGNMENT\_ERROR.
- Abort behavior with a type 1, 2, or 3 descriptor:  
If an abort trigger occurs, the channel aborts immediately after completion of current read/write transactions and then the FIFO is cleaned up.  
In type 1, 2, or 3, if an abort trigger or drain trigger occurs during the descriptor load phase, the channel aborts.

#### 11.4.19.4.7 Status Bit Behavior

This section describes the behavior of the [DMA4\\_CSRI\[6\]](#) SYNC, [DMA4\\_CCRI\[9\]](#) RD\_ACTIVE and [DMA4\\_CCRI\[10\]](#) WR\_ACTIVE status bits:

- For a hardware-synchronized channel in linked-list mode, the [DMA4\\_CSRI\[6\]](#) SYNC bit becomes active ([DMA4\\_CSRI\[6\]](#) SYNC = 1) when the first data load transaction is scheduled and remains active until the last data load transaction in the block (not super block) is descheduled ([DMA4\\_CSRI\[6\]](#) SYNC = 0). The SYNC bit is not active during the descriptor load phase.
- The [DMA4\\_CCRI\[9\]](#) RD\_ACTIVE bit is active during the data load phase and the descriptor load phase. It becomes active when the first read transaction is scheduled. It becomes inactive:
  - When (during the descriptor load phase) the last descriptor write request is descheduled
  - When (during the data load phase) the last read transaction in the block (not super block) is descheduled for software-synchronized transfer or destination-synchronized transfer with prefetch enabled
  - When (during the data load phase) the last read transaction in the request (element/frame/packet/block sync) is descheduled for hardware-source-synchronized transfer or hardware-destination-synchronized transfer without prefetch
- The [DMA4\\_CCRI\[10\]](#) WR\_ACTIVE bit is active only during the data load phase. It becomes active when the first write transaction is scheduled and becomes inactive:
  - Until the last write transaction in the block (not super block) is descheduled and the FIFO is cleaned up for software-synchronized transfer

- Until the last write transaction in the request (element/frame/packet/block sync) is descheduled and the FIFO is cleaned up for hardware-source-synchronized transfer (with DMA4\_CCR[25] BUFFERING\_DISABLE = 0) or hardware-destination-synchronized transfer.

#### 11.4.19.4.8 Linked-List Channel Linking

Channel linking for inter and intra super block is supported for type 1, 2, and 3 descriptors.

Assume that CHx and CHz are linked-list channels using generic descriptors. If CHx is composed of N descriptors and CHz is composed of M descriptors, then in nonfast mode,

CHx: CHx[Data1]->CHx[DES1] -> .... -> CHx[DESN]->CHx[DataN + 1]

CHz: CHz[Data1]->CHz[DES1] -> .... -> CHz[DESM]->CHz[DataM + 1]

It is possible to link CHx to CHz or CHx to itself after the completion of the CHx transfer (end of super block). To do this, the user must set the DMA4\_CLNK\_CTRL[15] ENABLE\_LNK bit to 1 and the DMA4\_CLNK\_CTRL[4:0] NEXTLCH\_ID bit to z (or to x for self linking) through the last descriptor using a type 1 descriptor. The sequence is:

CHx: CHx[Data1]->CHx[DES1] -> .... -> CHx[DESN]->CHx[DataN+1] -> CHz: CHz[Data1]->CHz[DES1] -> .... -> CHz[DESM]->CHz[DataM+1]

It is also possible to link CHx to CHz during the CHx transfer and before the end of super block. The user must set the DMA4\_CLNK\_CTRL[15] ENABLE\_LNK bit to 1 and the DMA4\_CLNK\_CTRL[4:0] NEXTLCH\_ID bit to z through descriptor p (CHx[DESp]) using a type 1 descriptor. The sequence is:

CHx: CHx[Data1]->CHx[DES1] ->....->CHx[DESp]->CHx[Data(p + 1)] -> CHz[Data1]->CHz[DES1] -> ....

The user must continue the linking until channels CHx and CHz complete their super-block transfers; otherwise, the channels remain enabled.

---

**NOTE:** In channel linking, the head of a chain can be in fast mode or nonfast mode. All channels that are not in the head of the chain can be in nonfast mode only. In self-linking, the channel cannot be in fast mode.

---



---

**NOTE:** If channel CHx links to CHz in the middle of the superblock transfer (remember link bit can be set through Type-1 descriptor load), CHx will get disabled after the corresponding data load and enables the channel CHz.

---

## 11.5 SDMA Basic Programming Model

### **11.5.1 Setup Configuration**

After a hardware reset, program all fields in the logical channel registers to default values for any channels used, because most fields are undefined following reset.

Before programming any DMA transfers, the priority arbitration rate and the maximum FIFO depth must be configured through the `DMA4_GCR` register, and any required interrupts must be enabled through the `DMA4_IRQENABLE_Lj` registers and the logical channel `DMA4_CICRi` registers.

Software clears the [DMA4\\_CSRI](#) register and the IRQSTATUS bit for the different interrupt lines before enabling the channel.

### **11.5.2 Software-Triggered (Nonsynchronized) Transfer**

To program a software-triggered DMA transfer:

- Configure the transfer parameters in the logical DMA channel registers:
    - DMA4\_CSDPi:
      - Transfer ES (8 bits, 16 bits, or 32 bits) and DMA register bits DMA4\_CSDPi[1:0]
      - Read and write port access types (single/burst), DMA register bits DMA4\_CSDPi[8:7] and DMA4\_CSDPi[15:14]
      - Source and destination endianism, DMA register bits DMA4\_CSDPi[21] and DMA4\_CSDPi[19]
      - Write mode (posted or nonposted) and DMA register bits DMA4\_CSDPi[17:16]
      - Source or destination packed or nonpacked (if the ES is less than the read/write port size), DMA register bits DMA4\_CSDPi[6] and DMA4\_CSDPi[13]
    - DMA4\_CENi: EN
    - DMA4\_CFNi: FN per transfer block
    - DMA4\_CSSAi and DMA4\_CDSEi: Source and destination start address (aligned with transfer ES)
    - DMA4\_CCRi:
      - Read and write port addressing modes, DMA register bits DMA4\_CCRi[13:12] and DMA4\_CCRi[15:14]
      - Priority bit for both read and write ports, DMA register bits DMA4\_CCRi[6] and DMA4\_CCRi[26]
      - DMA request number (set to 0 for a software-triggered transfer) and DMA register bits DMA4\_CCRi[4:0] = 0 and DMA4\_CCRi[20:19] = 0
    - DMA4\_CSEi, DMA4\_CSFi, DMA4\_CDEi, and DMA4\_CDFi: Source and destination element and frame indexes (depending on addressing mode)
  - Start the transfer through the enable bit in the channel DMA4\_CCRi register and DMA register bit DMA4\_CCRi[7]

The example below perform a DMA transfer on channel 10 of a 240\*160 picture from RAM to RAM (0x80C00000 to 0x80F00000) :

```

UWORD32 RegVal = 0; DMA4_t *DMA4; DMA4 = (DMA4_t *)malloc(sizeof(DMA4_t)); /* Init. parameters
*/ DMA4->DataType = 0x2; // DMA4_CSDPi[1:0] DMA4->ReadPortAccessType = 0; // DMA4_CSDPi[8:7] DMA4-
>WritePortAccessType = 0; // DMA4_CSDPi[15:14] DMA4->SourceEndiansim = 0; // DMA4_CSDPi[21] DMA4-
>DestinationEndianism = 0; // DMA4_CSDPi[19] DMA4->WriteMode = 0; // DMA4_CSDPi[17:16] DMA4-
>SourcePacked = 0; // DMA4_CSDPi[6] DMA4->DestinationPacked = 0; // DMA4_CSDPi[13] DMA4-
>NumberOfElementPerFrame = 240; // DMA4_CENI DMA4->NumberOfFramePerTransferBlock = 160; //
DMA4_CFNI DMA4->SourceStartAddress = 0x80C00000; // DMA4_CSSAI DMA4->DestinationStartAddress =
0x80F00000; // DMA4_CDSAi DMA4->SourceElementIndex = 1; // DMA4_CSEi DMA4->SourceFrameIndex = 1;
// DMA4_CSFi DMA4->DestinationElementIndex = 1; // DMA4_CDEi DMA4->DestinationFrameIndex = 1; //
DMA4_CDFI DMA4->ReadPortAccessMode = 1; // DMA4_CCRI[13:12] DMA4->WritePortAccessMode = 1; //
DMA4_CCRI[15:14] DMA4->ReadPriority = 0; // DMA4_CCRI[6] DMA4->WritePriority = 0; //
DMA4_CCRI[23] DMA4->ReadRequestNumber = 0; // DMA4_CCRI[4:0] DMA4->WriteRequestNumber = 0; //
DMA4_CCRI[20:19] /* 1) Configure the transfer parametres in the logical DMA registers */ /*-----*
-----* /* a) Set the data type CSDP[1:0], the Read/Write Port access type CSDP[8:7]/[15:14], the Source/dest endiansim CSDP[21]/CSDP[19],
```

```

write mode CSDP[17:16], source/dest packed or non-packed CSDP[6]/CSDP[13]/* // Read CSDP RegVal =
DMA4_CSDP_CH10; // Build reg RegVal = ((RegVal & ~ 0x3) | DMA4->DataType ); RegVal = ((RegVal &
~(0x3 << 7)) | (DMA4->ReadPortAccessType << 7)); RegVal = ((RegVal & ~(0x3 << 14)) | (DMA4-
>WritePortAccessType << 14)); RegVal = ((RegVal & ~(0x1 << 21)) | (DMA4->SourceEndiansim << 21));
RegVal = ((RegVal & ~(0x1 << 19)) | (DMA4->DestinationEndianism << 19)); RegVal = ((RegVal &
~(0x3 << 16)) | (DMA4->WriteMode << 16)); RegVal = ((RegVal & ~(0x1 << 6)) | (DMA4->SourcePacked
<< 6)); RegVal = ((RegVal & ~(0x1 << 13)) | (DMA4->DestinationPacked << 13)); // Write CSDP
DMA4_CSDP_CH10 = RegVal; /* b) Set the number of element per frame CEN[23:0]/* DMA4_CEN_CH10 =
DMA4->NumberOfElementPerFrame; /* c) Set the number of frame per block CFN[15:0]/* DMA4_CFN_CH10
= DMA4->NumberOfFramePerTransferBlock; /* d) Set the Source/dest start address index
CSSA[31:0]/CDSA[31:0]/* DMA4_CSSA_CH10 = DMA4->SourceStartAddress; // address start
DMA4_CDSA_CH10 = DMA4->DestinationStartAddress; // address dest /* e) Set the Read Port
addressing mode CCR[13:12], the Write Port addressing mode CCR[15:14], read/write priority
CCR[6]/CCR[26], the current LCH CCR[20:19]=00 and CCR[4:0]=00000/* // Read CCR RegVal =
DMA4_CCR_CH10; // Build reg RegVal = ((RegVal & ~(0x3 << 12)) | (DMA4->ReadPortAccessMode <<
12)); RegVal = ((RegVal & ~(0x3 << 14)) | (DMA4->WritePortAccessMode << 14)); RegVal = ((RegVal &
~(0x1 << 6)) | (DMA4->ReadPriority << 6)); RegVal = ((RegVal & ~(0x1 << 26)) | (DMA4-
>WritePriority << 26)); RegVal&= 0xFFCFFF0 ; // Write CCR DMA4_CCR_CH10 = RegVal; /* f) - Set the
source element index CSEI[15:0]/* DMA4_CSEI_CH10 = DMA4->SourceElementIndex; /* - Set the source
frame index CSFI[15:0]/* DMA4_CSFI_CH10 = DMA4->SourceFrameIndex ; /* - Set the destination
element index CDEI[15:0]/* DMA4_CDEI_CH10 = DMA4->DestinationElementIndex; /* - Set the
destination frame index CDIFI[31:0]/* DMA4_CDIFI_CH10 = DMA4->DestinationFrameIndex; /* 2) Start
the DMA transfer by Setting the enable bit CCR[7]=1 */ /*-----*
-----*/ //write enable bit DMA4_CCR_CH10 |= 1 << 7; /* start */

```

### 11.5.3 Hardware-Synchronized Transfer

To monitor a hardware synchronized DMA transfer, initialize the [DMA4\\_CDACi](#) register before the software enable.

To configure an LCh to synchronize by element, packet, frame, or block, the frame synchronization [DMA4\\_CCRI](#)[5] FS bit and the block synchronization [DMA4\\_CCRI](#)[18] BS bit register must be programmed. For all the following synchronized transfers (element, packet, frame or block synchronized transfers) User must set first : [DMA4\\_CCRI](#)[24] SEL\_SRC\_DST\_SYNC to 1 when the source triggers on the DMA request and [DMA4\\_CCRI](#)[24] SEL\_SRC\_DST\_SYNC to 0 when the Destination triggers on the DMA request. Note: User must take care when setting the [DMA4\\_CCRI](#)[23] PREFETCH bit it is in conjunction with [DMA4\\_CCRI](#)[24] SEL\_SRC\_DST\_SYNC bit .

- To configure an LCh to transfer one element per DMA request:
  1. Set the number of DMA request associated to the current LCH in the [DMA4\\_CCRI](#)[20:19] SYNCHRO\_CONTROL\_UPPER and [DMA4\\_CCRI](#)[4:0] SYNCHRO bit field.
  2. Set the data type, also referenced as element size (ES), in the [DMA4\\_CSDPi](#)[1:0] DATA\_TYPE bit field.
  3. Set the Read Port access type (single or burst access) in the [DMA4\\_CSDPi](#)[8:7] SRC\_BURST\_EN bit field.
  4. Set the Write Port access type (single or burst access) in the [DMA4\\_CSDPi](#)[15:14] DST\_BURST\_EN bit field.
  5. Set the Read Port addressing mode in the [DMA4\\_CCRI](#)[13:12] SRC\_AMODE bit field.
  6. Set the Write Port addressing mode in the [DMA4\\_CCRI](#)[15:14] DST\_AMODE bit field.
  7. Set the Read start address in the [DMA4\\_CSSA](#)[31:0] SRC\_START\_ADRS bit field.
  8. Set the Write start address in the [DMA4\\_CDSA](#)[31:0] DST\_START\_ADRS bit field.
  9. Set both FS and BS to 0 in [DMA4\\_CCRI](#)[5] FS and [DMA4\\_CCRI](#)[18] BS.
  10. Set to 1 the channel enable bit [DMA4\\_CCRI](#)[7] EN bit.
- To configure an LCh to transfer one frame per DMA request:
  1. Set the number of DMA request associated to the current LCH in the [DMA4\\_CCRI](#)[20:19] SYNCHRO\_CONTROL\_UPPER and [DMA4\\_CCRI](#)[4:0] SYNCHRO bit field.
  2. Set the data type, also referenced as element size (ES), in the [DMA4\\_CSDPi](#)[1:0] DATA\_TYPE bit field.

3. Set the number of element per frame in the [DMA4\\_CENi\[23:0\]](#) CHANNEL\_ELMNT\_NBR bit field.
4. Set the Read Port access type (single or burst access) in the [DMA4\\_CSDPi\[8:7\]](#) SRC\_BURST\_EN bit field.
5. Set the Write Port access type (single or burst access) in the [DMA4\\_CSDPi\[15:14\]](#) DST\_BURST\_EN bit field.
6. Set the Read Port addressing mode in the [DMA4\\_CCRI\[13:12\]](#) SRC\_AMODE bit field.
7. Set the Write Port addressing mode in the [DMA4\\_CCRI\[15:14\]](#) DST\_AMODE bit field.
8. Set the Read start address in the [DMA4\\_CSSAi\[31:0\]](#) SRC\_START\_ADRS bit field.
9. Set the Write start address in the [DMA4\\_CDSAi\[31:0\]](#) DST\_START\_ADRS bit field.
10. Set FS to 1 and BS to 0 respectively in [DMA4\\_CCRI\[5\]](#) FS and [DMA4\\_CCRI\[18\]](#) BS.
11. Set to 1 the channel enable bit [DMA4\\_CCRI\[7\]](#) EN bit.
  - To configure an LCh to transfer one block per DMA request:
    1. Set the number of DMA request associated to the current LCH in the [DMA4\\_CCRI\[20:19\]](#) SYNCHRO\_CONTROL\_UPPER and [DMA4\\_CCRI\[4:0\]](#) SYNCHRO bit field.
    2. Set the data type, also referenced as element size (ES), in the [DMA4\\_CSDPi\[1:0\]](#) DATA\_TYPE bit field.
    3. Set the number of element per frame in the [DMA4\\_CENi\[23:0\]](#) CHANNEL\_ELMNT\_NBR bit field.
    4. Set in the [DMA4\\_CFNi\[15:0\]](#) CHANNEL\_FRAME\_NBR bit field the number of frame (transfers), to take place before the LCH is disabled.
    5. Set the Read Port access type (single or burst access) in the [DMA4\\_CSDPi\[8:7\]](#) SRC\_BURST\_EN bit field.
    6. Set the Write Port access type (single or burst access) in the [DMA4\\_CSDPi\[15:14\]](#) DST\_BURST\_EN bit field.
    7. Set the Read Port addressing mode in the [DMA4\\_CCRI\[13:12\]](#) SRC\_AMODE bit field.
    8. Set the Write Port addressing mode in the [DMA4\\_CCRI\[15:14\]](#) DST\_AMODE bit field.
    9. Set the Read start address in the [DMA4\\_CSSAi\[31:0\]](#) SRC\_START\_ADRS bit field.
    10. Set the Write start address in the [DMA4\\_CDSAi\[31:0\]](#) DST\_START\_ADRS bit field.
    11. Set FS to 0 and BS to 1 respectively in [DMA4\\_CCRI\[5\]](#) FS and [DMA4\\_CCRI\[18\]](#) BS.
    12. Set to 1 the channel enable bit [DMA4\\_CCRI\[7\]](#) EN bit.
      - To configure an LCh to transfer one packet per DMA request:
        1. Set the number of DMA request associated to the current LCH in the [DMA4\\_CCRI\[20:19\]](#) SYNCHRO\_CONTROL\_UPPER and [DMA4\\_CCRI\[4:0\]](#) SYNCHRO bit field.
        2. Set the data type, also referenced as element size (ES), in the [DMA4\\_CSDPi\[1:0\]](#) DATA\_TYPE bit field.
        3. Set the number of elements per packet to transfer: If the packet requestor is in the source, set DMA4\_CCR [24] SEL\_SRC\_DST\_SYNC to 1 and set the packet element number in the [DMA4\\_CSFIi](#) register and set the addressing mode of source to constant addressing in [DMA4\\_CCRI\[13:12\]](#) SRC\_AMODE bit field; else, if the packet requestor is in the destination, set the [DMA4\\_CCRI\[24\]](#) SEL\_SRC\_DST\_SYNC to 0 and set the packet element number in the [DMA4\\_CDFIi](#) register and set the addressing mode of destination to constant addressing in [DMA4\\_CCRI\[15:14\]](#) DST\_AMODE bit field.
        4. Set the number of element per frame in the [DMA4\\_CENi\[23:0\]](#) CHANNEL\_ELMNT\_NBR bit field.
        5. Set in the [DMA4\\_CFNI\[15:0\]](#) CHANNEL\_FRAME\_NBR bit field the number of frame (transfers), to take place before the LCH is disabled.
        6. Set the element number in the packet in the [DMA4\\_CSFIi\[15:0\]](#) PKT\_ELNT\_NBR, if constant addressing or post-incremented addressing modes are used in the source side. However, the number of elements in the packet is set in the [DMA4\\_CDFIi\[15:0\]](#) PKT\_ELNT\_NBR if constant addressing mode is used in the destination side.
        7. Set the Read Port access type (single or burst access) in the [DMA4\\_CSDPi\[8:7\]](#) SRC\_BURST\_EN bit field.

8. Set the Write Port access type (single or burst access) in the [DMA4\\_CSDPi](#)[15:14] DST\_BURST\_EN bit field.
9. Set the Read start address in the [DMA4\\_CSSAi](#)[31:0] SRC\_START\_ADRS bit field.
10. Set the Write start address in the [DMA4\\_CDSAi](#)[31:0] DST\_START\_ADRS bit field.
11. Set FS to 1 and BS to 1 respectively in [DMA4\\_CCRi](#)[5] FS and [DMA4\\_CCRi](#)[18] BS.
12. Set to 1 the channel enable bit [DMA4\\_CCRi](#)[7] EN bit.

---

**NOTE:** It is possible to stop a transfer by disabling the channel. This is done by resetting the ENABLE bit in the [DMA4\\_CCRi](#) register.

---

#### 11.5.4 Synchronized Transfer Monitoring Using CDAC

The [DMA4\\_CDACi](#) register is writable and non-initialized during reset (value undefined). It can be initialized to monitor a transfer by applying the following programming model:

1. Write 0 in [DMA4\\_CDACi](#)
2. Enable the channel.
3. If timeout occurs, read [DMA4\\_CDACi](#)
4. If [DMA4\\_CDACi](#) != 0 (it is the value configured in [DMA4\\_CDACi](#)):

This indicates that the corresponding transfer has started. User can then rely on [DMA4\\_CCENi](#) and [DMA4\\_CCFNi](#) element and frame counters.

Else, if [DMA4\\_CDACi](#) = 0 (it is the value configured in the [DMA4\\_CDACi](#)):

This indicates that the corresponding transfer did not start.

#### 11.5.5 Concurrent Software and Hardware Synchronization

This section describes thread allocation only, not the entire transfer. Because synchronized transfers are latency critical, you must allocate a thread on the synchronized target side at least.

Even for multiple concurrent channels, thread reservation guarantees that as soon as an HW DMA request comes in, the read/write scheduler finds available thread(s) to initiate a channel schedule and issue a read/write transaction.

Consider these six concurrent channels:

- Channels 0/1/2/3 are dedicated to memory-memory transfer: they are software triggered and not synchronized.
  - Channel 4 is dedicated to memory→peripheral transfer, hardware triggered, and synchronized on the write side.
  - Channel 5 is dedicated to peripheral→memory transfer, hardware triggered, and synchronized on the read side.
1. Allow thread reservation for priority channel 4 and channel 5:  
Reserve one thread (Read ThreadID 0) on the read port: Set [DMA4\\_GCR](#)[13:12] = 0x1.  
Reserve one thread (Write ThreadID 0) on the write port: Set [DMA4\\_GCR](#)[13:12] = 0x1.
  2. Specify channel priority:  
Channel 4 is a write high priority channel: Set [DMA4\\_CCRi](#)[26] = 1.  
Channel 5 is a read high priority channel: Set [DMA4\\_CCRi](#)[6] = 1.

#### 11.5.6 Chained Transfer

A chained DMA transfer can be programmed as follows:

1. Configure the transfer parameters for each logical DMA channel in the chain as in step 1 for either the synchronized or non-synchronized transfers above.
2. For each channel in the chain, configure the [DMA4\\_CLNK\\_CTRLi](#) register as follows:

- Next logical DMA channel number (for a looping chained transfer link last channel to first channel number), in DMA register bits [DMA4\\_CLNK\\_CTRLi\[4:0\]](#).
  - Include the logical channel to the chain and enable link by setting the DMA register bit [DMA4\\_CLNK\\_CTRLi\[15\]](#).
  - For a non-looping chain, the last logical channel in the chain must have the DMA register bit [DMA4\\_CLNK\\_CTRLi\[15\]](#) set to 0 to indicate the end of the chain.
3. Enable the transfer via the enable bit in the first logical channel DMA register bit [DMA4\\_CCRi\[7\]](#). All other channels in the chain must be configured as disabled. Each channel is enabled automatically in turn when the previous logical channel transfer completes. A non-synchronized transfer starts immediately; a hardware-synchronized transfer starts when the DMA request line corresponding to the first DMA channel in the chain is asserted.

To stop a looping chained transfer, disable the [DMA4\\_CLNK\\_CTRLi\[15\]](#) ENABLE\_LNK bit (by setting it to 0x0), of the final channel transfer.

In the RAM to RAM copy example, to copy in loop it's possible to link channel 10 on itself. The following line can be added in the channel configuration :

```
/* g) Set link for loop */ DMA4_CLINK_CTRL_CH10 = 0x0000800A;
```

### 11.5.7 90-Degree Clockwise Image Rotation

The 90-degree clockwise image rotation example described in [Section 11.4.3, Addressing Modes](#), can be programmed as follows:

1. Configure the transfer parameters in the logical DMA channel registers:

- [DMA4\\_CSDPi](#):
  - Transfer ES = 32-bit (32 bpp), DMA register bits [DMA4\\_CSDPi\[1:0\]](#)
  - Read and write port access types = maximum burst size supported by memory device, DMA register bits [DMA4\\_CSDPi\[8:7\]](#) and [DMA4\\_CSDPi\[15:14\]](#)
  - Source and destination endianism, DMA register bits [DMA4\\_CSDPi\[21\]](#) and [DMA4\\_CSDPi\[19\]](#)
  - Write mode = posted with last element nonposted, DMA register bits [DMA4\\_CSDPi\[17:16\]](#)
  - Source and destination packed = Yes (although destination writes will not benefit because EI>1), DMA register bits [DMA4\\_CSDPi\[6\]](#) and [DMA4\\_CSDPi\[13\]](#)
- [DMA4\\_CENi](#): EN = 240
- [DMA4\\_CFNi](#): FN per transfer block = 160
- [DMA4\\_CSSAi](#): Source start address = 0x100000
- [DMA4\\_CDSAi](#): destination start address = 0x20013E
- [DMA4\\_CCRi](#):
  - Read and write port addressing modes = double-index addressing mode for both or post-increment addressing on source and double-index addressing on destination, DMA register bits [DMA4\\_CCRi\[13:12\]](#) and [DMA4\\_CCRi\[15:14\]](#)
  - Low or high priority, DMA register bit [DMA4\\_CCRi\[6\]](#)
  - DMA request number = 0 (for software-triggered transfer), DMA register bits [DMA4\\_CCRi\[4:0\]](#) and [DMA4\\_CCRi\[20:19\]](#)
- [DMA4\\_CSEi](#): Source EI = 1
- [DMA4\\_CSFi](#): Source frame index = 1
- [DMA4\\_CDEi](#): destination EI = 637
- [DMA4\\_CDFi](#): destination frame index = -152967

2. Start the transfer via the enable bit in the channel [DMA4\\_CCRi](#) register.

Below are the parameters to perform this rotation from 0x80C00000 RAM address to 0x80F00000, with the same code as in [Section 11.5.2](#):

```
/* Init. parameters */ DMA4->DataType = 0x2; // DMA4_CSDPi[1:0] DMA4->ReadPortAccessType = 0x3;
// DMA4_CSDPi[8:7] DMA4->WritePortAccessType = 0x3; // DMA4_CSDPi[15:14] DMA4->SourceEndiansim =
0; // DMA4_CSDPi[21] DMA4->DestinationEndianism = 0; // DMA4_CSDPi[19] DMA4->WriteMode = 0x2; //
DMA4_CSDPi[17:16] DMA4->SourcePacked = 0x1; // DMA4_CSDPi[6] DMA4->DestinationPacked = 0x1; //
DMA4_CSDPi[13] DMA4->NumberOfElementPerFrame = 240; // DMA4_CENi DMA4-
>NumberOfFramePerTransferBlock = 160; // DMA4_CFNi DMA4->SourceStartAddress = 0x80C00000; //
DMA4_CSSAi DMA4->DestinationStartAddress = 0x80F00000; // DMA4_CDSEAi DMA4->SourceElementIndex =
1; // DMA4_CSEi DMA4->SourceFrameIndex = 1; // DMA4_CSFi DMA4->DestinationElementIndex = 637; //
DMA4_CDEi DMA4->DestinationFrameIndex = -152967; // DMA4_CDFi DMA4->ReadPortAccessMode = 0x3; //
DMA4_CCRi[13:12] DMA4->WritePortAccessMode = 0x3; // DMA4_CCRi[15:14] DMA4->ReadPriority = 0; //
DMA4_CCRi[6] DMA4->WritePriority = 0; // DMA4_CCRi[23] DMA4->ReadRequestNumber = 0; //
DMA4_CCRi[4:0] DMA4->WriteRequestNumber = 0; // DMA4_CCRi[20:19]
```

### 11.5.8 Graphic Operations

- Transparent copy:
  - 1. Set the [DMA4\\_CCRI\[17\]](#) Transparent\_Copy\_Enable bit field to 1.
  - 2. Set the [DMA4\\_CCRI\[16\]](#) Constant\_Fill\_Enable bit field to 0.
  - 3. Set the value of key the color in the [DMA4\\_COLORi\[15:0\]](#) color\_key bit field.

To perform this graphic operation, the following lines can be added to the example of [Section 11.5.2](#)

```
DMA4_CCR_CH10 &= ~(0x1 << 16); DMA4_CCR_CH10 |= 0x1 << 17; DMA4_COLOR_CH10 = 0x00000003;
```

- Solid Color fill:
  - 1. Set the [DMA4\\_CCRI\[16\]](#) Constant\_Fill\_Enable bit field to 1.
  - 2. Set the [DMA4\\_CCRI\[17\]](#) Transparent\_Copy\_Enable bit field to 0.
  - 3. Set the value of key the color in the [DMA4\\_COLORi\[15:0\]](#) solid\_color bit field.

To perform this graphic operation, the following lines can be added to the example of [Section 11.5.2](#)

```
DMA4_CCR_CH10 &= ~(0x1 << 17); DMA4_CCR_CH10 |= 0x1 << 16; DMA4_COLOR_CH10 = 0x00000003;
```

## 11.6 SDMA Register Manual

### 11.6.1 SDMA Instance Summary

[Table 11-14](#) summarizes the SDMA instance.

**Table 11-14. SDMA Instance Summary**

| Module Name | Base Address | Size     |
|-------------|--------------|----------|
| SDMA        | 0x4805 6000  | 4K bytes |

### 11.6.2 SDMA Register Summary

[Table 11-15](#) summarizes the SDMA registers.

Index  $i$  represents the logical channel number ( $i = 0$  to  $31$ ). The offset address for some registers is calculated from channel  $c$  number. For example, register DMA4\_CCR10 (channel 10) has an offset address of  $10 * 0x60 = 0x3C0$ , and so a physical address of  $0x4805\ 6080 + 0x3C0 = 0x4805\ 6440$ .

Index  $j$  represents the interrupt line number ( $j = 0$  to  $3$ ). The offset address for some registers is calculated from channel number. For example, register DMA4 IRQSTATUS\_L3 (line 3) has an offset address of  $3 * 0x4 = 0xC$ , and so a physical address of  $0x4805\ 6008 + 0xC = 0x4805\ 6014$ .

**Table 11-15. SDMA Register Summary**

| Register Name      | Type | Register Width (Bits) | Address Offset           | SDMA Physical Address    |
|--------------------|------|-----------------------|--------------------------|--------------------------|
| DMA4_REVISION      | R    | 32                    | 0x0000 0000              | 0x4805 6000              |
| DMA4_IRQSTATUS_Lj  | RW   | 32                    | 0x0000 0008 + (j * 0x4)  | 0x4805 6008 + (j * 0x4)  |
| DMA4_IRQENABLE_Lj  | RW   | 32                    | 0x0000 0018 + (j * 0x4)  | 0x4805 6018 + (j * 0x4)  |
| DMA4_SYSSTATUS     | R    | 32                    | 0x0000 0028              | 0x4805 6028              |
| DMA4_OCP_SYSCONFIG | RW   | 32                    | 0x0000 002C              | 0x4805 602C              |
| DMA4_CAPS_0        | R    | 32                    | 0x0000 0064              | 0x4805 6064              |
| DMA4_CAPS_2        | R    | 32                    | 0x0000 006C              | 0x4805 606C              |
| DMA4_CAPS_3        | R    | 32                    | 0x0000 0070              | 0x4805 6070              |
| DMA4_CAPS_4        | R    | 32                    | 0x0000 0074              | 0x4805 6074              |
| DMA4_GCR           | RW   | 32                    | 0x0000 0078              | 0x4805 6078              |
| DMA4_CCRI          | RW   | 32                    | 0x0000 0080 + (i * 0x60) | 0x4805 6080 + (i * 0x60) |
| DMA4_CLNK_CTRLi    | RW   | 32                    | 0x0000 0084 + (i * 0x60) | 0x4805 6084 + (i * 0x60) |
| DMA4_CICRI         | RW   | 32                    | 0x0000 0088 + (i * 0x60) | 0x4805 6088 + (i * 0x60) |
| DMA4_CSRi          | RW   | 32                    | 0x0000 008C + (i * 0x60) | 0x4805 608C + (i * 0x60) |
| DMA4_CSDPi         | RW   | 32                    | 0x0000 0090 + (i * 0x60) | 0x4805 6090 + (i * 0x60) |
| DMA4_CENi          | RW   | 32                    | 0x0000 0094 + (i * 0x60) | 0x4805 6094 + (i * 0x60) |
| DMA4_CFNi          | RW   | 32                    | 0x0000 0098 + (i * 0x60) | 0x4805 6098 + (i * 0x60) |
| DMA4_CSSAi         | RW   | 32                    | 0x0000 009C + (i * 0x60) | 0x4805 609C + (i * 0x60) |
| DMA4_CDSEAi        | RW   | 32                    | 0x0000 00A0 + (i * 0x60) | 0x4805 60A0 + (i * 0x60) |
| DMA4_CSEiIi        | RW   | 32                    | 0x0000 00A4 + (i * 0x60) | 0x4805 60A4 + (i * 0x60) |
| DMA4_CSFiIi        | RW   | 32                    | 0x0000 00A8 + (i * 0x60) | 0x4805 60A8 + (i * 0x60) |
| DMA4_CDEiIi        | RW   | 32                    | 0x0000 00AC + (i * 0x60) | 0x4805 60AC + (i * 0x60) |
| DMA4_CDFiIi        | RW   | 32                    | 0x0000 00B0 + (i * 0x60) | 0x4805 60B0 + (i * 0x60) |
| DMA4_CSACi         | R    | 32                    | 0x0000 00B4 + (i * 0x60) | 0x4805 60B4 + (i * 0x60) |
| DMA4_CDACi         | RW   | 32                    | 0x0000 00B8 + (i * 0x60) | 0x4805 60B8 + (i * 0x60) |
| DMA4_CCENi         | RW   | 32                    | 0x0000 00BC + (i * 0x60) | 0x4805 60BC + (i * 0x60) |
| DMA4_CCFNi         | RW   | 32                    | 0x0000 00C0 + (i * 0x60) | 0x4805 60C0 + (i * 0x60) |
| DMA4_COLORi        | RW   | 32                    | 0x0000 00C4 + (i * 0x60) | 0x4805 60C4 + (i * 0x60) |
| DMA4_CDPI          | RW   | 32                    | 0x0000 00D0 + (i * 0x60) | 0x4805 60D0 + (i * 0x60) |
| DMA4_CNDPI         | RW   | 32                    | 0x0000 00D4 + (i * 0x60) | 0x4805 60D4 + (i * 0x60) |
| DMA4_CCDNi         | RW   | 32                    | 0x0000 00D8 + (i * 0x60) | 0x4805 60D8 + (i * 0x60) |

### 11.6.3 SDMA Register Description

**NOTE:** Some registers have no reset value (marked with -) because of hardware implementation in memory. Software must ensure the correct programming of these registers, if needed.

The shadow registers are used to read run time registers such as CCEN, CCFN, CDAC, or CSAC. Typically, when accessed in 8-bit or 16-bit access for two consecutive accesses, the value of the previous registers may change. This shadow register is used to hold the whole value to allow the next access to recover the remaining 24 bits or 16 bits.

For non-32-bit transactions, start reading or writing from the LSByte first to enable the register update. There is no issue for 32-bit read-write transactions.

**Table 11-16. DMA4\_REVISION**

| <b>Address Offset</b>   | 0x0000 0000                                  |                                                                  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | SDMA        |                  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------|------------------------------------------------------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------------|------------------|-----|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x4805 6000                                  |                                                                  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  | <b>Type</b>     | SDMA        |                  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register contains the DMA revision code |                                                                  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |                  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                            |                                                                  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |                  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |                  | REV |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                   | <b>Description</b>                                               |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                 | <b>Type</b> | <b>Reset</b>     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:8                    | RESERVED                                     | Reserved. Write 0s for future compatibility. Read returns 0.     |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                 | <b>RW</b>   | 0x0000000        |     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7:0                     | REV                                          | [7:4] DMA4 major revision code<br>[3:0] DMA4 minor revision code |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |                 | <b>R</b>    | TI internal data |     |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 11-17. Register Call Summary for Register DMA4\_REVISION**

SDMA Register Manual

- [SDMA Register Summary: \[0\]](#)

**Table 11-18. DMA4\_IRQSTATUS\_Lj**

| <b>Address Offset</b>   | 0x0000 0008 + (j * 0x4)                                                                                                 |                                                                                                                                                                                                                                                                                                                                                     |                 |            |  |  |  |  |  |  |  |  |  |  |  |  | <b>Index</b>    | j = 0 to 3  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|-------------|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x4805 6008 + (j * 0x4)                                                                                                 |                                                                                                                                                                                                                                                                                                                                                     |                 |            |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | SDMA        |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | The interrupt status register regroups all the status of the DMA4 channels that can generate an interrupt over line Lj. |                                                                                                                                                                                                                                                                                                                                                     |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                     |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | CH_31_0_Lj |  |  |  |  |  |  |  |  |  |  |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                                                                              | <b>Description</b>                                                                                                                                                                                                                                                                                                                                  |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |                 | <b>Type</b> | <b>Reset</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:0                    | CH_31_0_Lj                                                                                                              | Channel 31 Interrupt on Lj: When an interrupt is seen on the line Lj the status of a interrupting channel i is read in the bit field i.<br><br>Read 0x0: Channel Interrupt Lj false<br>Write 0x0: Channel Interrupt Lj status bit unchanged<br>Read 0x1: Channel Interrupt Lj true (pending)<br>Write 0x1: Channel Interrupt Lj status bit is reset |                 |            |  |  |  |  |  |  |  |  |  |  |  |  |                 | <b>RW</b>   | 0x00000000   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 11-19. Register Call Summary for Register DMA4\_IRQSTATUS\_Lj**

## SDMA Integration

- [SDMA Interrupts: \[0\] \[1\] \[2\] \[3\]](#)

## SDMA Functional Description

- [Interrupt Generation: \[4\]](#)

## SDMA Register Manual

- [SDMA Register Summary: \[5\]](#)

**Table 11-20. DMA4\_IRQENABLE\_Lj**

|                         |                                                                                                          |                 |            |
|-------------------------|----------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0018 + (j * 0x4)                                                                                  | <b>Index</b>    | j = 0 to 3 |
| <b>Physical Address</b> | 0x4805 6018 + (j * 0x4)                                                                                  | <b>Instance</b> | SDMA       |
| <b>Description</b>      | The interrupt enable register allows to mask/unmask the module internal sources of interrupt, on line Lj |                 |            |
| <b>Type</b>             | RW                                                                                                       |                 |            |

|               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| CH_31_0_Lj_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name    | Description                                                                                                                                                                                                                                | Type | Reset      |
|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | CH_31_0_Lj_EN | Channel Interrupt on Lj mask/unmask : to Mask/Unmask a channel i interrupt on Lj the user writes 0/1 on the bit field i.<br><br>0x0: Channel Interrupt Lj is masked<br><br>0x1: Channel Interrupt Lj generates an interrupt when it occurs | RW   | 0x00000000 |

**Table 11-21. Register Call Summary for Register DMA4\_IRQENABLE\_Lj**

## SDMA Integration

- [SDMA Interrupts: \[0\] \[1\] \[2\] \[3\]](#)

## SDMA Functional Description

- [Interrupt Generation: \[4\]](#)

## SDMA Basic Programming Model

- [Setup Configuration: \[5\]](#)

## SDMA Register Manual

- [SDMA Register Summary: \[6\]](#)

**Table 11-22. DMA4\_SYSSTATUS**

|                       |                                                                                                                                      |                         |             |                 |      |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 0028                                                                                                                          | <b>Physical Address</b> | 0x4805 6028 | <b>Instance</b> | SDMA |
| <b>Description</b>    | The register provides status information about the module excluding the interrupt status information (see interrupt status register) |                         |             |                 |      |
| <b>Type</b>           | R                                                                                                                                    |                         |             |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

RESETDONE

| Bits | Field Name | Description                                                                                 | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Reserved for module-specific status information                                             | RW   | 0x00000000 |
| 0    | RESETDONE  | Internal reset monitoring<br>0x0: Internal module reset is on-going<br>0x1: Reset completed | R    | 1          |
|      |            |                                                                                             |      |            |

**Table 11-23. Register Call Summary for Register DMA4\_SYSSTATUS**

SDMA Register Manual

- [SDMA Register Summary: \[0\]](#)

**Table 11-24. DMA4\_OCP\_SYSCONFIG**

|                         |                                                                    |                         |                 |                 |      |
|-------------------------|--------------------------------------------------------------------|-------------------------|-----------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 002C                                                        | <b>Physical Address</b> | 0x4805 602C     | <b>Instance</b> | SDMA |
| <b>Description</b>      | This register controls the various parameters of the OCP interface |                         |                 |                 |      |
| <b>Type</b>             | RW                                                                 |                         |                 |                 |      |
| 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 |                 |      |

|          |           |          |               |          |         |           |          |           |          |
|----------|-----------|----------|---------------|----------|---------|-----------|----------|-----------|----------|
| RESERVED | MIDLEMODE | RESERVED | CLOCKACTIVITY | RESERVED | EMUFREE | SIDLEMODE | RESERVED | SOFTRESET | AUTOIDLE |
|----------|-----------|----------|---------------|----------|---------|-----------|----------|-----------|----------|

| Bits  | Field Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset   |
|-------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | RESERVED      | Write 0s for future compatibility, Reads return 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0x00000 |
| 13:12 | MIDLEMODE     | Read write power management, standby/wait control<br>0x0: Force-standby: MStandby is asserted only when all the DMA channels are disabled<br>0x1: No-Standby: MStandby is never asserted<br>0x2: Smart-Standby: MStandby is asserted if at least one of the following two conditions is satisfied:<br>1. All the channels are disabled, OR<br>2. There is no non-synchronized channel enabled AND [if hardware synchronized channel is enabled, then no DMA request input is asserted and no requests are pending to be serviced].<br>0x3: reserved for second smart-standby mode if needed | RW   | 0x0     |
| 11:10 | RESERVED      | Reserved for clocks activities extension                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0x0     |
| 9:8   | CLOCKACTIVITY | Clocks activities during wake-up<br>Bit 8: OCP interface clock<br>0x0: OCP clock can be switched-off<br>Bit 9: Functional clock<br>0x0: Functional clock can be switched-off                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0x0     |
| 7:6   | RESERVED      | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW   | 0x0     |
| 5     | EMUFREE       | Enable sensitivity to MSuspend<br>0x0: DMA4 freezes its internal logic upon MSuspend assertion<br>0x1: DMA4 ignores the MSuspend input                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW   | 0x0     |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4:3  | SIDLEMODE  | <p>Configuration port power management, Idle req/ack control</p> <p>0x0: Force-idle. An idle request is acknowledged unconditionally</p> <p>0x1: No-idle. An idle request is never acknowledged</p> <p>0x2: Smart-idle. Idle acknowledge is given by DMA4 if all of the conditions are true:</p> <ul style="list-style-type: none"> <li>1. All the channels are disabled.</li> <li>2. If hardware synchronized channel is enabled, then no DMA request input is asserted and no requests are pending to be serviced.</li> <li>3. All transactions are completed on all the DMA ports.</li> <li>4. No interrupts are pending to be serviced.</li> </ul> <p>0x3: reserved - do not use</p> | RW   | 0x0   |
| 2    | RESERVED   | Write 0s for future compatibility, Reads return 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0x0   |
| 1    | RESERVED   | Reserved for non-GP device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW   | 0x0   |
| 0    | AUTOIDLE   | <p>Internal OCP clock gating strategy</p> <p>0x0: OCP clock is free running</p> <p>0x1: Automatic OCP clock gating strategy is applied, based on the OCP interface activity.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0x0   |

**Table 11-25. Register Call Summary for Register DMA4\_OCP\_SYSCONFIG**

SDMA Integration

- [Power Management: \[0\] \[1\] \[2\]](#)

SDMA Register Manual

- [SDMA Register Summary: \[3\]](#)

**Table 11-26. DMA4\_CAPS\_0**

|                         |                                 |                 |      |
|-------------------------|---------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0064                     | <b>Instance</b> | SDMA |
| <b>Physical Address</b> | 0x4805 6064                     |                 |      |
| <b>Description</b>      | DMA Capabilities Register 0 LSW |                 |      |
| <b>Type</b>             | R                               |                 |      |



| Bits  | Field Name             | Description                                                                                                                                                                  | Type | Reset |
|-------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:22 | RESERVED               | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                 | RW   | 0x000 |
| 21    | LINK_LIST_CPBLTY_TYPE4 | <p>Link List capability for type4 descriptor</p> <p>0x0: No Link List capability for type4 descriptor</p> <p>0x1: Link List capability for type4 descriptor is supported</p> | R    | 0x0   |

| Bits | Field Name               | Description                                                                                                                                                          | Type | Reset   |
|------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 20   | LINK_LIST_CPBLTY_TYPE123 | Link List capability for type123 descriptor<br>0x0: No Link List capability for type123 descriptor<br>0x1: Link List capability for type 123 descriptor is supported | R    | 0x1     |
| 19   | CONST_FILL_CPBLTY        | Constant_Fill_Capability<br>0x0: No LCH supports constant fill copy.<br>0x1: Any LCH supports constant fill copy.                                                    | R    | 0x1     |
| 18   | TRANSPARENT_BLT_CPBLTY   | Transparent_BLT_Capability<br>0x0: No LCH supports transparent BLT copy.<br>0x1: Any LCH supports transparent BLT copy.                                              | R    | 0x1     |
| 17:0 | RESERVED                 | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                         | RW   | 0x00000 |

**Table 11-27. Register Call Summary for Register DMA4\_CAPS\_0**

SDMA Register Manual

- [SDMA Register Summary: \[0\]](#)

**Table 11-28. DMA4\_CAPS\_2**

| Address Offset                                                            | 0x0000 006C                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                              | Physical Address               | 0x4805 606C           | Instance                     | SDMA                         |                                |                       |   |   |   |   |   |                                   |                              |                              |                                |                       |                              |                              |                                |                       |
|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--------------------------------|-----------------------|------------------------------|------------------------------|--------------------------------|-----------------------|---|---|---|---|---|-----------------------------------|------------------------------|------------------------------|--------------------------------|-----------------------|------------------------------|------------------------------|--------------------------------|-----------------------|
| Description                                                               | DMA Capabilities Register 2                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                              |                                |                       | Type                         |                              |                                |                       |   |   |   |   |   |                                   |                              |                              |                                |                       |                              |                              |                                |                       |
| 31 30 29 28 27 26 25 24   23 22 21 20 19 18 17 16   15 14 13 12 11 10 9 8 | <table border="1"> <tr> <td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td> </tr> <tr> <td>SEPARATE_SRC_AND_DST_INDEX_CPBLTY</td><td>DST_DOUBLE_INDEX_ADRS_CPBLTY</td><td>DST_SINGLE_INDEX_ADRS_CPBLTY</td><td>DST_POST_INCREMENT_ADRS_CPBLTY</td><td>DST_CONST_ADRS_CPBLTY</td><td>SRC_DOUBLE_INDEX_ADRS_CPBLTY</td><td>SRC_SINGLE_INDEX_ADRS_CPBLTY</td><td>SRC_POST_INCREMENT_ADRS_CPBLTY</td><td>SRC_CONST_ADRS_CPBLTY</td> </tr> </table> |                              |                                |                       |                              | 7                            | 6                              | 5                     | 4 | 3 | 2 | 1 | 0 | SEPARATE_SRC_AND_DST_INDEX_CPBLTY | DST_DOUBLE_INDEX_ADRS_CPBLTY | DST_SINGLE_INDEX_ADRS_CPBLTY | DST_POST_INCREMENT_ADRS_CPBLTY | DST_CONST_ADRS_CPBLTY | SRC_DOUBLE_INDEX_ADRS_CPBLTY | SRC_SINGLE_INDEX_ADRS_CPBLTY | SRC_POST_INCREMENT_ADRS_CPBLTY | SRC_CONST_ADRS_CPBLTY |
| 7                                                                         | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 5                            | 4                              | 3                     | 2                            | 1                            | 0                              |                       |   |   |   |   |   |                                   |                              |                              |                                |                       |                              |                              |                                |                       |
| SEPARATE_SRC_AND_DST_INDEX_CPBLTY                                         | DST_DOUBLE_INDEX_ADRS_CPBLTY                                                                                                                                                                                                                                                                                                                                                                                                                                                | DST_SINGLE_INDEX_ADRS_CPBLTY | DST_POST_INCREMENT_ADRS_CPBLTY | DST_CONST_ADRS_CPBLTY | SRC_DOUBLE_INDEX_ADRS_CPBLTY | SRC_SINGLE_INDEX_ADRS_CPBLTY | SRC_POST_INCREMENT_ADRS_CPBLTY | SRC_CONST_ADRS_CPBLTY |   |   |   |   |   |                                   |                              |                              |                                |                       |                              |                              |                                |                       |

|                                                                           |          |   |   |   |   |   |   |   |   |
|---------------------------------------------------------------------------|----------|---|---|---|---|---|---|---|---|
| 31 30 29 28 27 26 25 24   23 22 21 20 19 18 17 16   15 14 13 12 11 10 9 8 | RESERVED | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------------------------------------------------------------------|----------|---|---|---|---|---|---|---|---|

| Bits | Field Name                        | Description                                                                                                                                                                               | Type | Reset    |
|------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED                          | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                              | RW   | 0x000000 |
| 8    | SEPARATE_SRC_AND_DST_INDEX_CPBLTY | Separate_source/destination_index_capability<br>0x0: Does not support separate src/dst index for 2D addressing<br>0x1: Supports separate src/dest index for 2D addressing                 | R    | 0x1      |
| 7    | DST_DOUBLE_INDEX_ADRS_CPBLTY      | Destination_double_index_address_capability<br>0x0: Does not support double index address mode on the destination port<br>0x1: Supports double index address mode on the destination port | R    | 0x1      |

| <b>Bits</b> | <b>Field Name</b>              | <b>Description</b>                                                                                                                                                                                       | <b>Type</b> | <b>Reset</b> |
|-------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 6           | DST_SINGLE_INDEX_ADRS_CPBLTY   | Destination_single_index_address_capability<br><br>0x0: Does not support single index address mode on the destination port<br><br>0x1: Supports single index address mode on the destination port        | R           | 0x1          |
| 5           | DST_POST_INCRMNT_ADRS_CPBLTY   | Destination_post_increment_address_capability<br><br>0x0: Does not supports post-increment address mode in the destination port<br><br>0x1: Supports post-increment address mode in the destination port | R           | 0x1          |
| 4           | DST_CONST_ADRS_CPBLTY          | Destination_constant_address_capability<br><br>0x0: Does not supports constant address mode in the destination port<br><br>0x1: Supports constant address mode in the destination port                   | R           | 0x1          |
| 3           | SRC_DOUBLE_INDEX_ADRS_CPBLTY   | Source_double_index_address_capability<br><br>0x0: Does not support double index address mode on the source port<br><br>0x1: Supports double index address mode on the source port                       | R           | 0x1          |
| 2           | SRC_SINGLE_INDEX_ADRS_CPBLTY   | Source_single_index_address_capability<br><br>0x0: Does not support single index address mode on the source port<br><br>0x1: Supports single index address mode in the source port                       | R           | 0x1          |
| 1           | SRC_POST_INCREMENT_ADRS_CPBLTY | Source_post_increment_address_capability<br><br>0x0: Does not supports post-increment address mode in the source port<br><br>0x1: Supports post-increment address mode in the source port                | R           | 0x1          |
| 0           | SRC_CONST_ADRS_CPBLTY          | Source_constant_address_capability<br><br>0x0: Does not supports constant address mode in the source port<br><br>0x1: Supports constant address mode in the source port                                  | R           | 0x1          |

**Table 11-29. Register Call Summary for Register DMA4\_CAPS\_2**

- 
- SDMA Register Manual  
 • [SDMA Register Summary: \[0\]](#)
- 

**Table 11-30. DMA4\_CAPS\_3**

|                         |                             |                 |      |
|-------------------------|-----------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0070                 | <b>Instance</b> | SDMA |
| <b>Physical Address</b> | 0x4805 6070                 |                 |      |
| <b>Description</b>      | DMA Capabilities Register 3 |                 |      |
| <b>Type</b>             | R                           |                 |      |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name                | Description                                                                                                                                                            | Type | Reset    |
|------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | RESERVED                  | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                           | RW   | 0x000000 |
| 7    | BLOCK_SYNCHR_CPBLTY       | Block_synchronization_capability<br>0x0: Does not support synchronization transfer on block boundary<br>0x1: Supports synchronization transfer on block boundary       | R    | 0x1      |
| 6    | PKT_SYNCHR_CPBLTY         | Packet_synchronization_capability<br>0x0: Does not support synchronization transfer on packet boundary<br>0x1: Supports synchronization transfer on packet boundary    | R    | 0x1      |
| 5    | CHANNEL_CHAINING_CPBLTY   | Channel_Chaining_capability<br>0x0: Does not support Channel Chaining capability<br>0x1: Supports Channel Chaining capability                                          | R    | 0x1      |
| 4    | CHANNEL_INTERLEAVE_CPBLTY | Channel_interleave_capability<br>0x0: Does not support Channel interleave capability<br>0x1: Supports Channel_interleave capability                                    | R    | 0x1      |
| 3:2  | RESERVED                  |                                                                                                                                                                        | RW   | 0x0      |
| 1    | FRAME_SYNCHR_CPBLTY       | Frame_synchronization_capability<br>0x0: Does not support synchronization transfer on Frame boundary<br>0x1: Supports synchronization transfer on Frame boundary       | R    | 0x1      |
| 0    | ELMNT_SYNCHR_CPBLTY       | Element_synchronization_capability<br>0x0: Does not support synchronization transfer on Element boundary<br>0x1: Supports synchronization transfer on Element boundary | R    | 0x1      |

**Table 11-31. Register Call Summary for Register DMA4\_CAPS\_3**

## SDMA Register Manual

- [SDMA Register Summary: \[0\]](#)

**Table 11-32. DMA4\_CAPS\_4**

|                         |                             |                 |      |  |  |
|-------------------------|-----------------------------|-----------------|------|--|--|
| <b>Address Offset</b>   | 0x0000 0074                 | <b>Instance</b> | SDMA |  |  |
| <b>Physical Address</b> | 0x4805 6074                 |                 |      |  |  |
| <b>Description</b>      | DMA Capabilities Register 4 |                 |      |  |  |
| <b>Type</b>             | R                           |                 |      |  |  |



| Bits  | Field Name                            | Description                                                                                                                                                                         | Type | Reset   |
|-------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:15 | RESERVED                              | Reserved, Write 0's for future compatibility, Read returns 0                                                                                                                        | RW   | 0x00000 |
| 14    | EOSB_INTERRUPT_CPBLTY                 | End of Super Block detection capability.                                                                                                                                            | R    | 1       |
| 13    | RESERVED                              | Reserved                                                                                                                                                                            | R    | 1       |
| 12    | DRAIN_END_INTERRUPT_CPBLTY            | Drain End detection capability.                                                                                                                                                     | R    | 1       |
| 11    | MISALIGNED_ADDRS_ERR_INTERRUPT_CPBLTY | Misaligned error detection capability.                                                                                                                                              | R    | 1       |
| 10    | SUPERVISOR_ERR_INTERRUPT_CPBLTY       | Supervisor error detection capability.                                                                                                                                              | R    | 1       |
| 9     | RESERVED                              | Reserved for non-GP devices                                                                                                                                                         | R    | 1       |
| 8     | TRANS_ERR_INTERRUPT_CPBLTY            | Transaction error detection capability.                                                                                                                                             | R    | 1       |
| 7     | PKT_INTERRUPT_CPBLTY                  | End of Packet detection capability.<br>Read 0x0: Does not support end of packet interrupt generation capability<br>Read 0x1: Supports end of packet interrupt generation capability | R    | 1       |
| 6     | SYNC_STATUS_CPBLTY                    | Sync_status_capability<br>Read 0x0: Does not support synchronized transfer status bit generation<br>Read 0x1: Supports synchronized transfer status bit generation                  | R    | 1       |
| 5     | BLOCK_INTERRUPT_CPBLTY                | End of block detection capability.<br>Read 0x0: Does not support end of block interrupt generation capability<br>Read 0x1: Supports end of block interrupt generation capability    | R    | 1       |

| Bits | Field Name                      | Description                                                                                                                                                                                            | Type | Reset |
|------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4    | LAST_FRAME_INTERRUPT_CP<br>BLTY | Start of last frame detection capability.<br><br>Read 0x0: Does not support last frame interrupt generation capability<br><br>Read 0x1: Supports last frame interrupt generation capability            | R    | 1     |
| 3    | FRAME_INTERRUPT_CPBLTY          | End of frame detection capability.<br><br>Read 0x0: Does not support end of frame interrupt generation capability<br><br>Read 0x1: Supports end of frame interrupt generation capability               | R    | 1     |
| 2    | HALF_FRAME_INTERRUPT_CP<br>BLTY | Detection capability of the half of frame end.<br><br>Read 0x0: Does not support half of frame interrupt generation capability<br><br>Read 0x1: Supports half of frame interrupt generation capability | R    | 1     |
| 1    | EVENT_DROP_INTERRUPT_C<br>PBLTY | Request collision detection capability.<br><br>Read 0x0: Does not support event drop interrupt generation capability<br><br>Read 0x1: Supports event drop interrupt generation capability              | R    | 1     |
| 0    | RESERVED                        | Reserved, Write 0's for future compatibility, Read returns 0                                                                                                                                           | RW   | 0     |

**Table 11-33. Register Call Summary for Register DMA4\_CAPS\_4**

SDMA Register Manual

- [SDMA Register Summary: \[0\]](#)

**Table 11-34. DMA4\_GCR**

| Address Offset          | 0x0000 0078             |                       |                 |                   |                    |          |                        |  |  |  |  |  |  |  | Instance    | SDMA                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|-------------------|--------------------|----------|------------------------|--|--|--|--|--|--|--|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Physical Address        | 0x4805 6078             |                       |                 |                   |                    |          |                        |  |  |  |  |  |  |  | Description | FIFO sharing between high and low priority channel. The Maximum per channel FIFO depth is bounded by the low and high channel FIFO budget. The high respectively low priority channels maximum burst size must be less than the min (high respectively low priority channel FIFO budget , per channel maximum FIFO depth) |  |  |  |  |  |  |  |  |
| Type                    | RW                      |                       |                 |                   |                    |          |                        |  |  |  |  |  |  |  |             |                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |
| 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 | HI_LO_FIFO_BUDGET | HI_THREAD_RESERVED | RESERVED | MAX_CHANNEL_FIFO_DEPTH |  |  |  |  |  |  |  |             |                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |
| RESERVED                | ARBITRATION_RATE        |                       |                 |                   |                    |          |                        |  |  |  |  |  |  |  |             |                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |

| Bits  | Field Name       | Description                                                               | Type | Reset |
|-------|------------------|---------------------------------------------------------------------------|------|-------|
| 31:24 | RESERVED         | Reserved. Write 0s for future compatibility. Read returns 0.              | RW   | 0x00  |
| 23:16 | ARBITRATION_RATE | Arbitration switching rate between prioritized and regular channel queues | RW   | 0x01  |

| Bits  | Field Name             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Type | Reset |
|-------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15:14 | HI_LO_FIFO_BUDGET      | <p>Allow to have a separate Global FIFO budget for high and low priority channels.</p> <p>For Hi priority Channel:<br/> <math>(\text{Per\_channel\_Maximum FIFO depth} + 1) \times \text{Number of active High priority Channel} \leq \text{High Budget FIFO}</math></p> <p>For Low priority channel:<br/> <math>(\text{Per\_channel\_Maximum FIFO depth} + 1) \times \text{Number of active Low priority Channel} \leq \text{Low Budget FIFO}</math></p> <p>0x0: no fixed budget for neither higher nor lower priority channel</p> <p>0x1: 75% of FIFO for low priority and 25% for high priority channels</p> <p>0x2: 25% of FIFO for low priority and 75% for high priority channels</p> <p>0x3: 50% of FIFO for low priority and 50% for high priority channels</p> | RW   | 0x0   |
| 13:12 | HI_THREAD_RESERVED     | <p>Allow thread reservation for high priority channel on both read and write ports.</p> <p>0x0: No ThreadID is reserved on the Read Port for high priority channels. No ThreadID is reserved on the Write Port for high priority channels.</p> <p>0x1: Read Port ThreadID 0 is reserved for high priority channels. Write Port ThreadID 0 is reserved for high priority channels.</p> <p>0x2: Read port ThreadID 0 and ThreadID 1 are reserved for high priority channels. Write Port ThreadID 0 is reserved for high priority channels.</p> <p>0x3: Read Port ThreadID 0, ThreadID 1 and ThreadID 2 are reserved for high priority channels. Write Port ThreadID 0 is reserved for high priority channels.</p>                                                         | RW   | 0x0   |
| 11:8  | RESERVED               | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0x0   |
| 7:0   | MAX_CHANNEL_FIFO_DEPTH | Maximum FIFO depth allocated to one logical channel. Maximum FIFO depth can not be 0x0. It should be at least 0x1 or greater. Note that If channel limit is less than destination burst size enough data will not be accumulated in the data FIFO and it will never be sent out on the WR port. The burst size should be less than the FIFO limit specified in this bit field.                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x10  |

**Table 11-35. Register Call Summary for Register DMA4\_GCR**
**SDMA Functional Description**

- [Logical Channel Transfer Overview](#): [0] [1] [2]
- [FIFO Queue Memory Pool](#): [3]
- [Thread Budget Allocation](#): [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14]
- [FIFO Budget Allocation](#): [15] [16]

**SDMA Basic Programming Model**

- [Setup Configuration](#): [17]
- [Concurrent Software and Hardware Synchronization](#): [18] [19]

**SDMA Register Manual**

- [SDMA Register Summary](#): [20]

**Table 11-36. DMA4\_CCRi**

|                         |                          |                 |             |
|-------------------------|--------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 0080 + (i* 0x60)  | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 6080 + (i* 0x60)  | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Control Register |                 |             |
| <b>Type</b>             | RW                       |                 |             |



| Bits  | Field Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset |
|-------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | RESERVED          | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x00  |
| 26    | WRITE_PRIORITY    | Channel priority on the Write side<br><br>0x0: Channel has low priority on the Write side during the arbitration process<br><br>0x1: Channel has high priority on Write sided during the arbitration process                                                                                                                                                                                                                          | RW   | 0x0   |
| 25    | BUFFERING_DISABLE | This bit allows to disable the default buffering functionality when transfer is source synchronized.<br><br>0x0: buffering is enable across element/packet when source is synchronized to element, packet, frame or blocks<br><br>0x1: buffering is disabled across element/packet when source is synchronized to element, packet, frame or blocks                                                                                    | RW   | 0x-   |
| 24    | SEL_SRC_DST_SYNC  | Specifies that element, packet, frame or block transfer (depending on CCR.bs and CCR.fs) is triggered by the source or the destination on the DMA request<br><br>0x0: Transfer is triggered by the destination. If synch on packet the packet element number is specified in the CDFI register<br><br>0x1: Transfer is triggered by the source. If synchronized on packet the packet element number is specified in the CSFI register | RW   | 0x-   |
| 23    | PREFETCH          | Enables the prefetch mode<br><br>0x0: Prefetch mode is disabled. When Sel_Src_Dst_Sync=1 transfers are buffered and pipelined between DMA requests<br><br>0x1: Prefetch mode is enabled. Prefetch mode is active only when destination is synchronized. It is SW user responsibility not to have at the same time Prefetch=1 when Sel_Src_Dst_Sync=1. This mode is not supported                                                      | RW   | 0x0   |
| 22    | SUPERVISOR        | Enables the supervisor mode<br><br>0x0: Supervisor mode is disabled<br><br>0x1: Supervisor mode is enabled                                                                                                                                                                                                                                                                                                                            | RW   | 0x0   |
| 21    | RESERVED          | Reserved for non-GP devices                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b>       | <b>Description</b>                                                                                                                                                                                                                                                                                                                                          | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 20:19       | SYNCHRO_CONTROL_UPPER   | Channel Synchronization control upper (used in conjunction with the 5 bits of synchro channel DMA4_CCR[4:0])<br>Used in conjunction, as two msb, with the five bits of the synchro channel bit field.                                                                                                                                                       | RW          | 0x0          |
| 18          | BS                      | Block synchronization<br>This bit used with the fs to see how the DMA request is serviced in a synchronized transfer                                                                                                                                                                                                                                        | RW          | 0x-          |
| 17          | TRANSPARENT_COPY_ENABLE | Transparent copy enable<br>0x0: Transparent copy mode is disabled<br>0x1: Transparent copy mode is enabled                                                                                                                                                                                                                                                  | RW          | 0x-          |
| 16          | CONST_FILL_ENABLE       | Constant fill enable<br>0x0: Constant fill mode is disabled<br>0x1: Constant fill mode is enabled                                                                                                                                                                                                                                                           | RW          | 0x0          |
| 15:14       | DST_AMODE               | Selects the addressing mode on the Write Port of a channel.<br>0x0: Constant address mode<br>0x1: Post-incremented address mode<br>0x2: Single index address mode<br>0x3: Double index address mode                                                                                                                                                         | RW          | 0x-          |
| 13:12       | SRC_AMODE               | Selects the addressing mode on the Read Port of a channel.<br>0x0: Constant address mode<br>0x1: Post-incremented address mode<br>0x2: Single index address mode<br>0x3: Double index address mode                                                                                                                                                          | RW          | 0x-          |
| 11          | RESERVED                | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                                                | RW          | 0x0          |
| 10          | WR_ACTIVE               | Indicates if the channel write context is active or not<br>0x0: Channel is not active on the write port<br>0x1: Channel is active on the write port                                                                                                                                                                                                         | R           | 0x0          |
| 9           | RD_ACTIVE               | Indicates if the channel read context is active or not<br>0x0: Channel is not active on the read port<br>0x1: Channel is currently active on the read port                                                                                                                                                                                                  | R           | 0x0          |
| 8           | SUSPEND_SENSITIVE       | Logical channel suspend enable bit<br>0x0: The channel ignores the MSuspend even if EMUFree is set to 0.<br>0x1: If EMUFree is set to 0 and MSuspend comes in then all current OCP services (single transaction or burst transaction as specified in the corresponding CSDP register) have to be completed before stopping processing any more transactions | RW          | 0x0          |
| 7           | ENABLE                  | Logical channel enable. It is SW responsibility to clear the CSR register and the IRQSTATUS bit for the different interrupt lines before enabling the channel.<br>0x0: The logical channel is disabled<br>0x1: The logical channel is enabled                                                                                                               | RW          | 0x0          |
| 6           | READ_PRIORITY           | Channel priority on the read side<br>0x0: Channel has low priority on the Read side during the arbitration process<br>0x1: Channel has high priority on read sided during the arbitration process                                                                                                                                                           | RW          | 0x0          |

| Bits | Field Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 5    | FS              | <p>Frame synchronization</p> <p>This bit used with the BS to see how the DMA request is serviced in a synchronized transfer</p> <p>FS=0 and BS=0: An element is transferred once a DMA request is made.</p> <p>FS=0 and BS=1: An entire block is transferred once a DMA request is made.</p> <p>FS=1 and BS=0: An entire frame is transferred once a DMA request is made.</p> <p>FS=1 and BS=1: A packet is transferred once a DMA request is made.</p> <p>All these different transfers can be interleaved on the port with other DMA requests.</p> | RW   | 0x-   |
| 4:0  | SYNCHRO_CONTROL | <p>Channel synchronization control</p> <p>This bit used with the second_level_synchro_control_upper (as two msb)</p> <p>0000000 : Is reserved for non synchronized LCH transfer</p> <p>xxxxxx (from 1 to 127) There are 127 possible DMA request to assign to any LCH.</p> <p><b>Note:</b> The channel synchronization control registers are 1-based. For example, to enable the S_DMA_1 request, SYNCHRO_CONTROL bits (formed by DMA4_CCRi[20:19] and DMA4_CCRi[4:0]) must be set to 0x2 (DMA request number + 1).</p>                              | RW   | 0x00  |

**Table 11-37. Register Call Summary for Register DMA4\_CCRi**

## SDMA Functional Description

- [Logical Channel Transfer Overview](#): [0] [1] [2]
- [Addressing Modes](#): [3]
- [Software Synchronization](#): [4] [5] [6]
- [Hardware Synchronization](#): [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18]
- [Thread Budget Allocation](#): [19] [20]
- [Reprogramming an Active Channel](#): [21] [22] [23] [24]
- [Interrupt Generation](#): [25]
- [Packet Synchronization](#): [26] [27] [28] [29] [30]
- [Graphics Acceleration Support](#): [31]
- [Supervisor Modes](#): [32]
- [Disabling a Channel During Transfer](#): [33]
- [FIFO Draining Mechanism](#): [34] [35] [36] [37] [38]
- [Descriptors](#): [39] [40]
- [Linked-List Control and Monitoring](#): [41] [42] [43] [44] [45] [46] [47] [48] [49] [50]

## SDMA Basic Programming Model

- [Software-Trigged \(Nonsynchronized\) Transfer](#): [51] [52] [53] [54] [55] [56] [57] [58] [59]
- [Hardware-Synchronized Transfer](#): [60] [61] [62] [63] [64] [65] [66] [67] [68] [69] [70] [71] [72] [73] [74] [75] [76] [77] [78] [79] [80] [81] [82] [83] [84] [85] [86] [87] [88] [89] [90] [91] [92] [93] [94] [95]
- [Concurrent Software and Hardware Synchronization](#): [96] [97]
- [Chained Transfer](#): [98]
- [90° Clockwise Image Rotation](#): [99] [100] [101] [102] [103] [104] [105]
- [Graphic Operations](#): [106] [107] [108] [109]

## SDMA Register Manual

- [SDMA Register Summary](#): [110]
- [SDMA Register Description](#): [111]

**Table 11-38. DMA4\_CLNK\_CTRLi**

|                         |                               |                 |             |
|-------------------------|-------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 0084 + (i* 0x60)       | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 6084 + (i* 0x60)       | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Link Control Register |                 |             |
| <b>Type</b>             | RW                            |                 |             |

  

|                         |                         |                       |                 |            |  |
|-------------------------|-------------------------|-----------------------|-----------------|------------|--|
| 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 |            |  |
| RESERVED                |                         | ENABLE_LNK            | RESERVED        | NEXTLCH_ID |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                       | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                      | RW   | 0x0000 |
| 15    | ENABLE_LNK | Enables or disable the channel linking.<br><br>0x0: Channel linking mode is disabled When set on the fly to 0 the current channel will complete the transfer and stops the chain linking<br><br>0x1: Channel linking mode is enabled. The logical channel defined in the NextLCH_ID is enabled at the end of the current transfer | RW   | 0x0    |
| 14:5  | RESERVED   | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                                                      | RW   | 0x000  |
| 4:0   | NEXTLCH_ID | Defines the NextLCh_ID, which is used to build logical channel chaining queue.                                                                                                                                                                                                                                                    | RW   | 0x-    |

**Table 11-39. Register Call Summary for Register DMA4\_CLNK\_CTRLi**

## SDMA Functional Description

- [Chained Logical Channel Transfers: \[0\] \[1\]](#)
- [FIFO Draining Mechanism: \[2\]](#)
- [Descriptors: \[3\]](#)
- [Linked-List Control and Monitoring: \[4\] \[5\] \[6\] \[7\]](#)

## SDMA Basic Programming Model

- [Chained Transfer: \[8\] \[9\] \[10\] \[11\] \[12\]](#)

## SDMA Register Manual

- [SDMA Register Summary: \[13\]](#)

**Table 11-40. DMA4\_CICRi**

|                         |                                    |                 |             |
|-------------------------|------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 0088 + (i* 0x60)            | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 6088 + (i* 0x60)            | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Interrupt Control Register |                 |             |
| <b>Type</b>             | RW                                 |                 |             |



| Bits  | Field Name        | Description                                                                                                                                                                                         | Type | Reset  |
|-------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:15 | RESERVED          | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                        | RW   | 0x0000 |
| 14    | SUPER_BLOCK_IE    | Enables the end of super block interrupt<br><br>0x0: Disables the end of super block interrupt<br><br>0x1: Enables the end of super block interrupt                                                 | RW   | 0x-    |
| 13    | RESERVED          | Reserved                                                                                                                                                                                            | RW   | 0x1    |
| 12    | DRAIN_IE          | Enables the end of draining interrupt<br><br>0x0: Disables end of channel draining interrupt<br><br>0x1: Enable end of channel draining interrupt                                                   | RW   | 0x0    |
| 11    | MISALIGNED_ERR_IE | Enables the address misaligned error event interrupt<br><br>0x0: Disables the misaligned address error event interrupt<br><br>0x1: Enables the misaligned address error event interrupt             | RW   | 0x-    |
| 10    | SUPERVISOR_ERR_IE | Enables the supervisor transaction error event interrupt<br><br>0x0: Disables the supervisor transaction error event interrupt<br><br>0x1: Enables the supervisor transaction error event interrupt | RW   | 0x1    |
| 9     | RESERVED          | Reserved for non-GP devices                                                                                                                                                                         | RW   | 0x1    |
| 8     | TRANS_ERR_IE      | Enables the transaction error event interrupt<br><br>0x0: Disables the transaction error event interrupt<br><br>0x1: Enables the transaction error event interrupt                                  | RW   | 0x-    |
| 7     | PKT_IE            | Enables the end of Packet interrupt<br><br>0x0: Disables the end of Packet transfer interrupt<br><br>0x1: Enables the end of Packet transfer interrupt                                              | RW   | 0x-    |
| 6     | RESERVED          | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                        | RW   | 0x0    |
| 5     | BLOCK_IE          | Enables the end of block interrupt<br><br>0x0: Disables the end of block interrupt<br><br>0x1: Enables the end of block interrupt                                                                   | RW   | 0x-    |
| 4     | LAST_IE           | Last frame interrupt enable (start of last frame)<br><br>0x0: Disables the last frame interrupt<br><br>0x1: Enables the last frame interrupt                                                        | RW   | 0x-    |
| 3     | FRAME_IE          | Frame interrupt enable (end of frame)<br><br>0x0: Disables the end of frame interrupt<br><br>0x1: Enables the end of frame interrupt                                                                | RW   | 0x-    |
| 2     | HALF_IE           | Enables or disables the half frame interrupt.<br><br>0x0: Disables the half frame interrupt<br><br>0x1: Enables the half frame interrupt                                                            | RW   | 0x-    |

| Bits | Field Name | Description                                                                                                                                                       | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | DROP_IE    | <p>Synchronization event drop interrupt enable (request collision)</p> <p>0x0: Disables the event drop interrupt</p> <p>0x1: Enables the event drop interrupt</p> | RW   | 0x0   |
| 0    | RESERVED   | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                      | RW   | 0x0   |

**Table 11-41. Register Call Summary for Register DMA4\_CICR1**

- ## SDMA Integration

- SDMA Functional Description
    - Interrupt Generation: [2]
    - FIFO Draining Mechanism: [3]
    - Descriptors: [4] [5] [6]
    - Linked-List Control and Monitoring: [7] [8] [9]

- ## SDMA Basic Programming Model

- SDMA Register Manual

**Table 11-42. DMA4\_CSRi**

|                         |                         |                 |             |
|-------------------------|-------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 008C + (i* 0x60) | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 608C + (i* 0x60) | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Status Register |                 |             |
| <b>Type</b>             | RW                      |                 |             |



| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                          | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:15       | RESERVED          | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                                                | RW          | 0x0000       |
| 14          | SUPER_BLOCK       | End of super block event<br>Read 0x0: The current Super block transfer has not been finished<br>Write 0x0: Status bit unchanged<br>Read 0x1: The current Super block has been transferred<br>Write 0x1: Status bit is reset | RW          | 0x0          |
| 13          | RESERVED          | Reserved                                                                                                                                                                                                                    | RW          | 0x0          |

## SDMA Register Manual

www.ti.com

| Bits | Field Name              | Description                                                                                                                                                                                                                                                                | Type | Reset |
|------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 12   | DRAIN_END               | End of channel draining<br>Read 0x0: Status bit unchanged<br>Write 0x0: No drain end in the current transfer<br>Read 0x1: The current channel draining is completed<br>Write 0x1: Status bit is reset                                                                      | RW   | 0x0   |
| 11   | MISALIGNED_<br>ADRS_ERR | Misaligned address error event<br>Read 0x0: No address error<br>Write 0x0: Status bit unchanged<br>Read 0x1: An address error has been occurred<br>Write 0x1: Status bit is reset                                                                                          | RW   | 0x0   |
| 10   | SUPERVISOR_ERR          | Supervisor transaction error event<br>Read 0x0: No supervisor transaction error<br>Write 0x0: Status bit unchanged<br>Read 0x1: A supervisor transaction error has been occurred<br>Write 0x1: Status bit is reset                                                         | RW   | 0x0   |
| 9    | RESERVED                | Reserved for non-GP devices                                                                                                                                                                                                                                                | RW   | 0x0   |
| 8    | TRANS_ERR               | Transaction error event<br>Read 0x0: No transaction error<br>Write 0x0: Status bit unchanged<br>Read 0x1: A transaction error has been occurred<br>Write 0x1: Status bit is reset                                                                                          | RW   | 0x0   |
| 7    | PKT                     | End of Packet transfer<br>Read 0x0: The current packet transfer has not been finished<br>Write 0x0: Status bit unchanged<br>Read 0x1: The current packet has been transferred<br>Write 0x1: Status bit is reset                                                            | RW   | 0x0   |
| 6    | SYNC                    | Synchronization status of a channel.<br>Read 0x0: Logical channel is not scheduled or servicing a non synchronized DMA request.<br>Write 0x0: Status bit unchanged<br>Read 0x1: Logical channel is servicing a synchronized DMA request<br>Write 0x1: Status bit unchanged | RW   | 0x0   |
| 5    | BLOCK                   | End of block event<br>Read 0x0: The current block transfer has not been finished<br>Write 0x0: Status bit unchanged<br>Read 0x1: The current block has been transferred<br>Write 0x1: Status bit is reset                                                                  | RW   | 0x0   |
| 4    | LAST                    | Last frame (start of last frame)<br>Read 0x0: The start of the last frame to transfer is not reached<br>Write 0x0: Status bit unchanged<br>Read 0x1: The start of the last frame to transfer is reached<br>Write 0x1: Status bit is reset                                  | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                                                                                                                       | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3    | FRAME      | End of frame event<br>Read 0x0: The current frame transfer has not been finished.<br>Write 0x0: Status bit unchanged<br>Read 0x1: The current frame has been transferred<br>Write 0x1: Status bit is reset                        | RW   | 0x0   |
| 2    | HALF       | Half of frame event.<br>Read 0x0: Half of the current frame transfer has not been finished<br>Write 0x0: Status bit unchanged<br>Read 0x1: Half of the current frame has been transferred<br>Write 0x1: Status bit is reset       | RW   | 0x0   |
| 1    | DROP       | Synchronization event drop occurred during the transfer<br>Read 0x0: No synchronization collision<br>Write 0x0: Status bit unchanged<br>Read 0x1: A synchronization collision has been occurred<br>Write 0x1: Status bit is reset | RW   | 0x0   |
| 0    | RESERVED   | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                                                      | RW   | 0x0   |

**Table 11-43. Register Call Summary for Register DMA4\_CSRI**

## SDMA Integration

- [SDMA Interrupts: \[0\] \[1\] \[2\] \[3\] \[4\]](#)

## SDMA Functional Description

- [Interrupt Generation: \[5\]](#)
- [FIFO Draining Mechanism: \[6\]](#)
- [Linked-List Control and Monitoring: \[7\] \[8\] \[9\] \[10\] \[11\]](#)

## SDMA Basic Programming Model

- [Setup Configuration: \[12\]](#)

## SDMA Register Manual

- [SDMA Register Summary: \[13\]](#)

**Table 11-44. DMA4\_CSDPi**

|                                                                                             |                                       |                 |             |                 |            |              |            |          |  |              |            |          |  |           |
|---------------------------------------------------------------------------------------------|---------------------------------------|-----------------|-------------|-----------------|------------|--------------|------------|----------|--|--------------|------------|----------|--|-----------|
| <b>Address Offset</b>                                                                       | 0x0000 0090 + (i* 0x60)               | <b>Index</b>    | i = 0 to 31 |                 |            |              |            |          |  |              |            |          |  |           |
| <b>Physical Address</b>                                                                     | 0x4805 6090 + (i* 0x60)               | <b>Instance</b> | SDMA        |                 |            |              |            |          |  |              |            |          |  |           |
| <b>Description</b>                                                                          | Channel Source Destination Parameters |                 |             |                 |            |              |            |          |  |              |            |          |  |           |
| <b>Type</b>                                                                                 | RW                                    |                 |             |                 |            |              |            |          |  |              |            |          |  |           |
| 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 |                                       |                 |             |                 |            |              |            |          |  |              |            |          |  |           |
| RESERVED                                                                                    |                                       |                 |             |                 |            |              |            |          |  |              |            |          |  |           |
| SRC_ENDIAN                                                                                  |                                       | SRC_ENDIAN_LOCK | DST_ENDIAN  | DST_ENDIAN_LOCK | WRITE_MODE | DST_BURST_EN | DST_PACKED | RESERVED |  | SRC_BURST_EN | SRC_PACKED | RESERVED |  | DATA_TYPE |

## SDMA Register Manual

www.ti.com

| Bits  | Field Name      | Description                                                                                                                                                                                                                                                                                  | Type | Reset |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:22 | RESERVED        | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                 | RW   | 0x000 |
| 21    | SRC_ENDIAN      | Channel source endianness control<br>0x0: Source has Little Endian type<br>0x1: Source has Big Endian type                                                                                                                                                                                   | RW   | 0x-   |
| 20    | SRC_ENDIAN_LOCK | Endianness Lock<br>0x0: Endianness adapt<br>0x1: Endianness lock                                                                                                                                                                                                                             | RW   | 0x-   |
| 19    | DST_ENDIAN      | Channel Destination endianness control<br>0x0: Destination has Little Endian type<br>0x1: Destination has Big Endian type                                                                                                                                                                    | RW   | 0x-   |
| 18    | DST_ENDIAN_LOCK | Endianness Lock<br>0x0: Endianness adapt<br>0x1: Endianness lock                                                                                                                                                                                                                             | RW   | 0x-   |
| 17:16 | WRITE_MODE      | Used to enable writing mode without posting or with posting<br>0x0: Write nonposted (WRNP)<br>0x1: Write (Posted)<br>0x2: All transaction are mapped on the Write command as posted except for the last transaction in the transfer mapped on a Write nonposted<br>0x3: Undefined            | RW   | 0x-   |
| 15:14 | DST_BURST_EN    | Used to enable bursting on the Write Port. Smaller burst size than the programmed burst size is also allowed<br>0x0: Single access<br>0x1: 16 bytes or 4x32-bit/2x64-bit burst access<br>0x2: 32 bytes or 8x32-bit/4x64-bit burst access<br>0x3: 64 bytes or 16x32-bit/8x64-bit burst access | RW   | 0x0   |
| 13    | DST_PACKED      | Destination receives packed data.<br>0x0: The destination target is nonpacked<br>0x1: The destination target is packed                                                                                                                                                                       | RW   | 0x-   |
| 12:9  | RESERVED        | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                 | RW   | 0x-   |
| 8:7   | SRC_BURST_EN    | Used to enable bursting on the Read Port. Smaller burst size than the programmed burst size is also allowed<br>0x0: Single access<br>0x1: 16 bytes or 4x32-bit/2x64-bit burst access<br>0x2: 32 bytes or 8x32-bit/4x64-bit burst access<br>0x3: 64 bytes or 16x32-bit/8x64-bit burst access  | RW   | 0x-   |
| 6     | SRC_PACKED      | Source provides packed data.<br>0x0: The source target is nonpacked<br>0x1: The source target is packed                                                                                                                                                                                      | RW   | 0x-   |
| 5:2   | RESERVED        | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                 | RW   | 0x-   |
| 1:0   | DATA_TYPE       | Defines the type of the data moved in the channel.<br>0x0: 8 bits scalar<br>0x1: 16 bits scalar<br>0x2: 32 bits scalar<br>0x3: Undefined                                                                                                                                                     | RW   | 0x-   |

**Table 11-45. Register Call Summary for Register DMA4\_CSDPi**

## SDMA Functional Description

- Addressing Modes: [0]
- Packed Accesses: [1]
- Burst Transactions: [2]
- Endianism Conversion: [3] [4]
- Hardware Synchronization: [5]
- Graphics Acceleration Support: [6]
- Posted and Nonposted Writes: [7]
- Descriptors: [8]

## SDMA Basic Programming Model

- Software-Triggered (Nonsynchronized) Transfer: [9] [10] [11] [12] [13] [14] [15] [16] [17]
- Hardware-Synchronized Transfer: [18] [19] [20] [21] [22] [23] [24] [25] [26] [27] [28] [29]
- 90° Clockwise Image Rotation: [30] [31] [32] [33] [34] [35] [36] [37] [38]

## SDMA Register Manual

- SDMA Register Summary: [39]

**Table 11-46. DMA4\_CENi**

|                         |                         |                 |             |
|-------------------------|-------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 0094 + (i* 0x60) | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 6094 + (i* 0x60) | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Element Number  |                 |             |
| <b>Type</b>             | RW                      |                 |             |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | CHANNEL_ELMNT_NBR       |                       |                 |

| Bits  | Field Name        | Description                                                  | Type | Reset   |
|-------|-------------------|--------------------------------------------------------------|------|---------|
| 31:24 | RESERVED          | Reserved. Write 0s for future compatibility. Read returns 0. | RW   | 0x00    |
| 23:0  | CHANNEL_ELMNT_NBR | Number of elements within a frame (unsigned) to transfer     | RW   | 0x----- |

**Table 11-47. Register Call Summary for Register DMA4\_CENi**

## SDMA Functional Description

- Addressing Modes: [0] [1]

## SDMA Basic Programming Model

- Software-Triggered (Nonsynchronized) Transfer: [2]
- Hardware-Synchronized Transfer: [3] [4] [5]
- 90° Clockwise Image Rotation: [6]

## SDMA Register Manual

- SDMA Register Summary: [7]

**Table 11-48. DMA4\_CFNi**

|                         |                         |                 |             |
|-------------------------|-------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 0098 + (i* 0x60) | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 6098 + (i* 0x60) | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Frame Number    |                 |             |
| <b>Type</b>             | RW                      |                 |             |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CHANNEL_FRAME_NBR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name        | Description                                                    | Type | Reset  |
|-------|-------------------|----------------------------------------------------------------|------|--------|
| 31:16 | RESERVED          | Reserved. Write 0s for future compatibility. Read returns 0.   | RW   | 0x0000 |
| 15:0  | CHANNEL_FRAME_NBR | Number of frames within the block to be transferred (unsigned) | RW   | 0x---- |

**Table 11-49. Register Call Summary for Register DMA4\_CFNi**

|                                                                      |  |
|----------------------------------------------------------------------|--|
| SDMA Functional Description                                          |  |
| • <a href="#">Addressing Modes: [0] [1]</a>                          |  |
| SDMA Basic Programming Model                                         |  |
| • <a href="#">Software-Triggered (Nonsynchronized) Transfer: [2]</a> |  |
| • <a href="#">Hardware-Synchronized Transfer: [3] [4]</a>            |  |
| • <a href="#">90° Clockwise Image Rotation: [5]</a>                  |  |
| SDMA Register Manual                                                 |  |
| • <a href="#">SDMA Register Summary: [6]</a>                         |  |

**Table 11-50. DMA4\_CSSAi**

|                         |                              |                 |             |
|-------------------------|------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 009C + (i* 0x60)      | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 609C + (i* 0x60)      | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Source Start Address |                 |             |
| <b>Type</b>             | RW                           |                 |             |

  

|                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| SRC_START_ADRS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name     | Description                         | Type | Reset   |
|------|----------------|-------------------------------------|------|---------|
| 31:0 | SRC_START_ADRS | 32 bits of the source start address | RW   | 0x----- |

**Table 11-51. Register Call Summary for Register DMA4\_CSSAi**

|                                                                      |  |
|----------------------------------------------------------------------|--|
| SDMA Functional Description                                          |  |
| • <a href="#">Addressing Modes: [0]</a>                              |  |
| SDMA Basic Programming Model                                         |  |
| • <a href="#">Software-Triggered (Nonsynchronized) Transfer: [1]</a> |  |
| • <a href="#">Hardware-Synchronized Transfer: [2] [3] [4] [5]</a>    |  |
| • <a href="#">90° Clockwise Image Rotation: [6]</a>                  |  |
| SDMA Register Manual                                                 |  |
| • <a href="#">SDMA Register Summary: [7]</a>                         |  |

**Table 11-52. DMA4\_CDSAi**

|                         |                                   |                 |             |
|-------------------------|-----------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 00A0 + (i* 0x60)           | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 60A0 + (i* 0x60)           | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Destination Start Address |                 |             |
| <b>Type</b>             | RW                                |                 |             |

  

|                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| DST_START_ADRS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits | Field Name     | Description                              | Type | Reset   |
|------|----------------|------------------------------------------|------|---------|
| 31:0 | DST_START_ADRS | 32 bits of the destination start address | RW   | 0x----- |

**Table 11-53. Register Call Summary for Register DMA4\_CDSAi**

|                                                                      |  |
|----------------------------------------------------------------------|--|
| SDMA Functional Description                                          |  |
| • <a href="#">Addressing Modes: [0]</a>                              |  |
| SDMA Basic Programming Model                                         |  |
| • <a href="#">Software-Triggered (Nonsynchronized) Transfer: [1]</a> |  |
| • <a href="#">Hardware-Synchronized Transfer: [2] [3] [4] [5]</a>    |  |
| • <a href="#">90° Clockwise Image Rotation: [6]</a>                  |  |
| SDMA Register Manual                                                 |  |
| • <a href="#">SDMA Register Summary: [7]</a>                         |  |

**Table 11-54. DMA4\_CSEIi**

|                         |                                       |                 |             |
|-------------------------|---------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 00A4 + (i* 0x60)               | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 60A4 + (i* 0x60)               | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Source Element Index (Signed) |                 |             |
| <b>Type</b>             | RW                                    |                 |             |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CHANNEL_SRC_ELMNT_INDEX |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name              | Description                                                  | Type | Reset  |
|-------|-------------------------|--------------------------------------------------------------|------|--------|
| 31:16 | RESERVED                | Reserved. Write 0s for future compatibility. Read returns 0. | RW   | 0x0000 |
| 15:0  | CHANNEL_SRC_ELMNT_INDEX | Channel source element index                                 | RW   | 0x---- |

**Table 11-55. Register Call Summary for Register DMA4\_CSEIi**

|                                              |  |
|----------------------------------------------|--|
| SDMA Register Manual                         |  |
| • <a href="#">SDMA Register Summary: [0]</a> |  |

**Table 11-56. DMA4\_CSFI**

|                         |                                                           |                 |             |
|-------------------------|-----------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 00A8 + (i* 0x60)                                   | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 60A8 + (i* 0x60)                                   | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Source Frame Index (Signed) or 16-bit Packet size |                 |             |
| <b>Type</b>             | RW                                                        |                 |             |

  

|                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|-----------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| CH_SRC_FRM_INDEX_OR_16BIT_PKT_ELMNT_NBR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits | Field Name                              | Description                                                                                                                                                                                                                             | Type | Reset   |
|------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:0 | CH_SRC_FRM_INDEX_OR_16BIT_PKT_ELMNT_NBR | Channel source frame index value if source address is in double index mode. Or if fs=bs=1 and DMA_CCR[SEL_SRC_DST_SYNC]=1; the bit field [15:0] gives the number of element in packet. The field [31:16] is unused for the packet size. | RW   | 0x----- |

**Table 11-57. Register Call Summary for Register DMA4\_CSFI**

## SDMA Functional Description

- [Packet Synchronization: \[0\]](#) [\[1\]](#) [\[2\]](#) [\[3\]](#) [\[4\]](#)

## SDMA Basic Programming Model

- [Hardware-Synchronized Transfer: \[5\]](#) [\[6\]](#)

## SDMA Register Manual

- [SDMA Register Summary: \[7\]](#)

**Table 11-58. DMA4\_CDEI**

|                         |                                            |                 |             |
|-------------------------|--------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 00AC + (i* 0x60)                    | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 60AC + (i* 0x60)                    | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Destination Element Index (Signed) |                 |             |
| <b>Type</b>             | RW                                         |                 |             |

  

|          |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----------|----|----|----|----|----|----|----|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| RESERVED |    |    |    |    |    |    |    | CHANNEL_DST_ELMNT_INDEX |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits  | Field Name              | Description                                                  | Type | Reset  |
|-------|-------------------------|--------------------------------------------------------------|------|--------|
| 31:16 | RESERVED                | Reserved. Write 0s for future compatibility. Read returns 0. | RW   | 0x0000 |
| 15:0  | CHANNEL_DST_ELMNT_INDEX | Channel destination element index                            | RW   | 0x---  |

**Table 11-59. Register Call Summary for Register DMA4\_CDEI**

## SDMA Register Manual

- [SDMA Register Summary: \[0\]](#)

**Table 11-60. DMA4\_CDFli**

|                         |                                                                |                 |             |
|-------------------------|----------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 00B0 + (i* 0x60)                                        | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 60B0 + (i* 0x60)                                        | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Destination Frame Index (Signed) or 16-bit Packet size |                 |             |
| <b>Type</b>             | RW                                                             |                 |             |

  

|                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| CH_DST_FRM_IDX_OR_16BIT_PKT_ELNT_NBR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits | Field Name                           | Description                                                                                                                                                                                                                                        | Type | Reset   |
|------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:0 | CH_DST_FRM_IDX_OR_16BIT_PKT_ELNT_NBR | Channel destination frame index value if destination address is in double index mode. Or if fs=bs=1 and DMA_CCR[SEL_SRC_DST_SYNC]=0; the bit field [15:0] gives the number of element in packet. The field [31:16] is unused for the packet size.. | RW   | 0x----- |

**Table 11-61. Register Call Summary for Register DMA4\_CDFli**

SDMA Functional Description

- [Packet Synchronization: \[0\]](#) [\[1\]](#) [\[2\]](#) [\[3\]](#)

SDMA Basic Programming Model

- [Hardware-Synchronized Transfer: \[4\]](#) [\[5\]](#)

SDMA Register Manual

- [SDMA Register Summary: \[6\]](#)

**Table 11-62. DMA4\_CSACi**

|                         |                                                                                                                                            |                 |             |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 00B4 + (i* 0x60)                                                                                                                    | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 60B4 + (i* 0x60)                                                                                                                    | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Source Address Value. User has to access this register only in 32-bit access. If accessed in 8-bit or 16bit data may be corrupted. |                 |             |
| <b>Type</b>             | R                                                                                                                                          |                 |             |

  

|                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| SRC_ELMNT_ADRS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits | Field Name     | Description                          | Type | Reset   |
|------|----------------|--------------------------------------|------|---------|
| 31:0 | SRC_ELMNT_ADRS | Current source address counter value | R    | 0x----- |

**Table 11-63. Register Call Summary for Register DMA4\_CSACi**

SDMA Register Manual

- [SDMA Register Summary: \[0\]](#)

**Table 11-64. DMA4\_CDACi**

|                         |                                                                                                                                                 |                       |                 |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 00B8 + (i* 0x60)                                                                                                                         | <b>Index</b>          | i = 0 to 31     |
| <b>Physical Address</b> | 0x4805 60B8 + (i* 0x60)                                                                                                                         | <b>Instance</b>       | SDMA            |
| <b>Description</b>      | Channel Destination Address Value. User has to access this register only in 32-bit access. If accessed in 8-bit or 16bit data may be corrupted. |                       |                 |
| <b>Type</b>             | RW                                                                                                                                              |                       |                 |
| 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 |
| DST_ELMNT_ADRS          |                                                                                                                                                 |                       |                 |

| Bits | Field Name     | Description                               | Type | Reset   |
|------|----------------|-------------------------------------------|------|---------|
| 31:0 | DST_ELMNT_ADRS | Current destination address counter value | RW   | 0x----- |

**Table 11-65. Register Call Summary for Register DMA4\_CDACi**

SDMA Functional Description

- [Hardware Synchronization: \[0\]](#)

SDMA Basic Programming Model

- [Hardware-Synchronized Transfer: \[1\]](#)
- [Synchronized Transfer Monitoring Using CDAC: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\]](#)

SDMA Register Manual

- [SDMA Register Summary: \[9\]](#)

**Table 11-66. DMA4\_CCENi**

|                         |                                                                                                                                                                               |                       |                 |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 00BC + (i* 0x60)                                                                                                                                                       | <b>Index</b>          | i = 0 to 31     |
| <b>Physical Address</b> | 0x4805 60BC + (i* 0x60)                                                                                                                                                       | <b>Instance</b>       | SDMA            |
| <b>Description</b>      | Channel Current Transferred Element Number in the current frame. User has to access this register only in 32-bit access. If accessed in 8-bit or 16bit data may be corrupted. |                       |                 |
| <b>Type</b>             | RW                                                                                                                                                                            |                       |                 |
| 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 |
| RESERVED                |                                                                                                                                                                               | CURRENT_ELMNT_NBR     |                 |

| Bits  | Field Name        | Description                                                     | Type | Reset   |
|-------|-------------------|-----------------------------------------------------------------|------|---------|
| 31:24 | RESERVED          | Reserved. Write 0s for future compatibility. Read returns 0.    | RW   | 0x00    |
| 23:0  | CURRENT_ELMNT_NBR | Channel current transferred element number in the current frame | RW   | 0x----- |

**Table 11-67. Register Call Summary for Register DMA4\_CCENi**

SDMA Functional Description

- [Linked-List Control and Monitoring: \[0\] \[1\] \[2\]](#)

SDMA Basic Programming Model

- [Synchronized Transfer Monitoring Using CDAC: \[3\]](#)

SDMA Register Manual

- [SDMA Register Summary: \[4\]](#)

**Table 11-68. DMA4\_CCFNi**

|                         |                                                                                                                                                                                |                 |             |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 00C0 + (i* 0x60)                                                                                                                                                        | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 60C0 + (i* 0x60)                                                                                                                                                        | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel Current Transferred Frame Number in the current transfer. User has to access this register only in 32-bit access. If accessed in 8-bit or 16bit data may be corrupted. |                 |             |
| <b>Type</b>             | RW                                                                                                                                                                             |                 |             |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CURRENT_FRAME_NBR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name        | Description                                                      | Type | Reset  |
|-------|-------------------|------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED          | Reserved. Write 0s for future compatibility. Read returns 0.     | RW   | 0x0000 |
| 15:0  | CURRENT_FRAME_NBR | Channel current transferred frame number in the current transfer | RW   | 0x---  |

**Table 11-69. Register Call Summary for Register DMA4\_CCFNi**

SDMA Functional Description

- [Linked-List Control and Monitoring: \[0\] \[1\] \[2\]](#)

SDMA Basic Programming Model

- [Synchronized Transfer Monitoring Using CDAC: \[3\]](#)

SDMA Register Manual

- [SDMA Register Summary: \[4\]](#)

**Table 11-70. DMA4\_COLORi**

|                         |                                     |                 |             |
|-------------------------|-------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 00C4 + (i* 0x60)             | <b>Index</b>    | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 60C4 + (i* 0x60)             | <b>Instance</b> | SDMA        |
| <b>Description</b>      | Channel DMA COLOR KEY / SOLID COLOR |                 |             |
| <b>Type</b>             | RW                                  |                 |             |

  

|          |    |    |    |    |    |    |    |                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|-----------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    | CH_BLT_FRGRND_COLOR_OR_SOLID_COLOR_PTRN |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name                              | Description                                                                                                                                                                                                                                                                                       | Type | Reset   |
|-------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                | Reserved. Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                      | RW   | 0x-     |
| 23:0  | CH_BLT_FRGRND_COLOR_OR_SOLID_COLOR_PTRN | Color key or solid color pattern: The pattern is replicated according to the data type. If the data-type is 8-bit the pattern is replicated 4 times to fill the register in order to enhance processing when data is packed at the graphic module input. The same reasoning for 16-bit data-type. | RW   | 0x----- |

**Table 11-71. Register Call Summary for Register DMA4\_COLORi**

SDMA Functional Description

- [Graphics Acceleration Support: \[0\] \[1\]](#)
- [Descriptors: \[2\]](#)

SDMA Basic Programming Model

- [Graphic Operations: \[3\] \[4\]](#)

SDMA Register Manual

- [SDMA Register Summary: \[5\]](#)

**Table 11-72. DMA4\_CDPi**

|                                                                                                                                                                                                                                                                                                                                       |                                                                          |                       |                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                 | 0x0000 00D0 + (i* 0x60)                                                  | <b>index:</b>         | i = 0 to 31     |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                               | 0x4805 60D0 + (i* 0x60)                                                  | <b>Instance</b>       | SDMA            |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                    | This register controls the various parameters of the link list mechanism |                       |                 |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                           | RW                                                                       |                       |                 |
| 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 |
| RESERVED                                                                                                                                                                                                                                                                                                                              |                                                                          |                       |                 |
| <span style="font-size: small;">FAST</span><br><span style="font-size: small;">TRANSFER_MODE</span><br><span style="font-size: small;">PAUSE_LINK_LIST</span><br><span style="font-size: small;">NEXT_DESCRIPTOR_TYPE</span><br><span style="font-size: small;">SRC_VALID</span><br><span style="font-size: small;">DEST_VALID</span> |                                                                          |                       |                 |

| Bits  | Field Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset   |
|-------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:11 | RESERVED             | Write 0's for future compatibility. Reads return 0                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x00000 |
| 10    | FAST                 | Sets the fast-start mode for linked list descriptor types 1, 2 and 3<br><br>0x0: No fast-start mode<br>0x1: Fast-start mode is enabled.                                                                                                                                                                                                                                                                              | RW   | 0x0     |
| 9:8   | TRANSFER_MODE        | Enable linked-list transfer mode<br><br>0x0: Normal transfer mode is used.<br>0x1: Linked-list channel mode for type 1, 2, or 3 descriptor is used.<br>0x2: Undefined<br>0x3: Undefined                                                                                                                                                                                                                              | RW   | 0x0     |
| 7     | PAUSE_LINK_LIST      | Suspend the linked-list transfer at completion of the current block transfer.<br><br>0x0: Linked list is active.<br>0x1: Linked list is suspended at the boundary of next descriptor loading.                                                                                                                                                                                                                        | RW   | 0x0     |
| 6:4   | NEXT_DESCRIPTOR_TYPE | Next Descriptor Type<br><br>0x0: Undefined<br>0x1: Next descriptor is of type 1.<br>0x2: Next descriptor is of type 2.<br>0x3: Next descriptor is of type 3.<br>0x4: Undefined<br>0x5: Undefined<br>0x6: Undefined<br>0x7: Undefined                                                                                                                                                                                 | RW   | 0x0     |
| 3:2   | SRC_VALID            | Source address valid<br><br>0x0: The source address is not present in the next descriptor and continuous incrementing is enabled.<br>0x1: The source address must be reloaded in the next descriptor transfer.<br>0x2: The source start address is not present in the next descriptor. But will reload the one from configuration memory which belongs to the previous descriptor.<br>0x3: Undefined addressing mode | RW   | 0x0     |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1:0  | DEST_VALID | <p>Destination address valid</p> <p>0x0: The destination address is not present in the next descriptor and continuous incrementing is enabled.</p> <p>0x1: The destination address must be reloaded in the next descriptor transfer.</p> <p>0x2: The destination start address is not present in the next descriptor. But will reload the one from configuration memory which belongs to the previous descriptor.</p> <p>0x3: Undefined addressing mode</p> | RW   | 0x0   |

**Table 11-73. Register Call Summary for Register DMA4\_CDPI**

## SDMA Functional Description

- [Link-List Transfer Profile: \[0\]](#)
- [Descriptors: \[1\] \[2\]](#)
- [Linked-List Control and Monitoring: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\]](#)

## SDMA Register Manual

- [SDMA Register Summary: \[12\]](#)

**Table 11-74. DMA4\_CNDPi**

|                         |                                                                                        |                       |                 |
|-------------------------|----------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 00D4 + (i* 0x60)                                                                | <b>index:</b>         | i = 0 to 31     |
| <b>Physical Address</b> | 0x4805 60D4 + (i* 0x60)                                                                | <b>Instance</b>       | SDMA            |
| <b>Description</b>      | This register contains the next descriptor address pointer for the link list Mechanism |                       |                 |
| <b>Type</b>             | RW                                                                                     |                       |                 |
| 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 |
| NEXT_DESCRIPTOR_POINTER |                                                                                        |                       | RESERVED        |

| Bits | Field Name              | Description                                                 | Type | Reset   |
|------|-------------------------|-------------------------------------------------------------|------|---------|
| 31:2 | NEXT_DESCRIPTOR_POINTER | Next descriptor address pointer for the link list mechanism | RW   | 0x----- |
| 1:0  | RESERVED                | Write 0's for future compatibility. Reads return 0          | RW   | 0x0     |

**Table 11-75. Register Call Summary for Register DMA4\_CNDPi**

## SDMA Functional Description

- [Link-List Transfer Profile: \[0\]](#)

## SDMA Register Manual

- [SDMA Register Summary: \[1\]](#)

**Table 11-76. DMA4\_CCDNi**

|                         |                                                                                                                                                   |                 |             |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 00D8 + (i* 0x60)                                                                                                                           | <b>index:</b>   | i = 0 to 31 |
| <b>Physical Address</b> | 0x4805 60D8 + (i* 0x60)                                                                                                                           | <b>Instance</b> | SDMA        |
| <b>Description</b>      | This register when read contains the current active descriptor number in the link list. This register is read/write to allow user initialization. |                 |             |
| <b>Type</b>             | RW                                                                                                                                                |                 |             |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CURRENT_DESCRIPTOR_NBR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name             | Description                                        | Type | Reset  |
|-------|------------------------|----------------------------------------------------|------|--------|
| 31:16 | RESERVED               | Write 0's for future compatibility. Reads return 0 | RW   | 0x0000 |
| 15:0  | CURRENT_DESCRIPTOR_NBR | Current active descriptor number in the link list. | RW   | 0x---  |

**Table 11-77. Register Call Summary for Register DMA4\_CCDNi**

SDMA Functional Description

- [Linked-List Control and Monitoring: \[0\] \[1\] \[2\]](#)

SDMA Register Manual

- [SDMA Register Summary: \[3\]](#)

## ***Interrupt Controller***

This chapter gives an overview of the interrupt controllers (INTCs) and describes in detail the MPU subsystem interrupt controller (MPU\_INTC) module.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| <b>Topic</b>                                                   | <b>Page</b> |
|----------------------------------------------------------------|-------------|
| <b>12.1 Interrupt Controller Overview .....</b>                | <b>2414</b> |
| <b>12.2 Interrupt Controller Environment .....</b>             | <b>2416</b> |
| <b>12.3 MPU Subsystem INTCPS Integration .....</b>             | <b>2417</b> |
| <b>12.4 Interrupt Controller Functional Description .....</b>  | <b>2421</b> |
| <b>12.5 Interrupt Controller Basic Programming Model .....</b> | <b>2425</b> |
| <b>12.6 Interrupt Controller Register Manual .....</b>         | <b>2433</b> |

## 12.1 Interrupt Controller Overview

The device provides three interrupt controller (INTC) modules:

- **MPU subsystem INTC (INTCPS):** This module handles all MPU-related events, using Priority Threshold. It communicates with the public ARM Cortex-A8 processor using a private local interconnect, and runs at half the speed of the processor.
- **IVA2.2 subsystem INTC:** This module is a specific combination of WUGEN (wake-up generator) and the C64x+ DSP interrupt controller (IC). It is used in the device, but is not described in detail in this chapter. For detailed information about this INTC, see [Chapter 5, IVA2.2 Subsystem](#).
- **Modem INTC:** This module is an L4-mapped INTC that allows the regrouping of all the interrupts sent to the modem subsystem in stacked mode. It is seen as a level 2 INTC by the MPU and IVA2.2 subsystems. This modem INTC is integrated in the stand-alone device, but it is used only with the stacked modem. Therefore, it is not described in detail in this TRM, which focuses on the stand-alone device.

[Figure 12-1](#) shows the internal interrupt scheme with optional modem INTC (not used in the stand-alone configuration).

**Figure 12-1. Interrupt Controllers Highlight**


intc-001

## 12.2 Interrupt Controller Environment

The INTC can handle two types of interrupts originating from an external device:

- sys\_nirq interrupt inputs:

The MPU INTC and modem INTC handle external interrupts through a dedicated sys\_nirq interrupt line that connects the two INTC modules with a power IC, respectively. An interrupt can generate a system wake-up event.

If the system is idle and the external interrupt is masked, the interrupt cannot wake up the system. Like other interrupt lines, the external interrupt is active at low level and is acknowledged by the software according to the common programming model.

---

**NOTE:** If the CORE power domain is in retention (CSWR or OSWR) or off mode, the interrupt requests (internal or external), the MPU INTC, and the modem INTC (in the CORE domain) have no effect. The CORE power domain does not wake up, and the interrupt is not signaled to the MPU/modem.

---

- GPIO interrupt inputs:

External devices can also use GPIO modules to generate interrupts to the MPU and the modem. There are six dedicated interrupt lines to the MPU INTC and four dedicated interrupt inputs to the modem INTC. One interrupt line is associated with each GPIO module. Each GPIO module can generate a single interrupt whenever there is at least one event in any one of the configured 32 GPIO inputs. For more information about GPIO features, see [Chapter 25, General-Purpose Interface](#).

Figure 12-2 shows the relationship between the device and external interrupts.

**Figure 12-2. Interrupts From External Devices**




---

**NOTE:** The modem INTC cannot use GPIO5 and GPIO6 as interrupt sources.

---

The features specific to INTCPS are:

- Up to 96 level-sensitive interrupt inputs
- Individual priority (up to 64) for each interrupt input
- Interrupt lines connected to internal module interrupts
- One incoming interrupt line from an external device

## 12.3 MPU Subsystem INTCPS Integration

The INTCPS module is the interface between incoming interrupts and the two interrupt inputs of the MPU. It can handle up to 96 request inputs that can be configured as MPU FIQ or IRQ interrupt requests.

[Figure 12-3](#) shows the integration of the INTCPS in the MPU subsystem.

**Figure 12-3. MPU Subsystem INTCPS Integration**



The MPU subsystem INTCPS is directly connected to the MPU by an MPU peripheral port. Consequently, the MPU subsystem INTCPS is accessible and visible only by the MPU.

### 12.3.1 Clocking, Reset, and Power Management Scheme

#### 12.3.1.1 MPU Subsystem INTC Clocks

The MPU subsystem INTCPS runs at half the rate of the MPU functional clock (see [Chapter 4, MPU Subsystem](#)).

The interface clock used for register access runs at the rate of the interconnect bus clock (equal to the rate of the MPU interface clock; see [Chapter 3, Power, Reset, and Clock Management](#)).

The synchronizer clock allows external asynchronous interrupts to be resynchronized before they are masked.

[Table 12-1](#) lists the MPU subsystem INTC clock rates.

**Table 12-1. MPU Subsystem INTC Clock Rates**

| Clock        | Frequency     | Name                                             | Comments                     |
|--------------|---------------|--------------------------------------------------|------------------------------|
| Functional   | ARM_FCLK      | MPU_INTC_FCLK                                    | Source is the MPU DLL.       |
| Interface    | ARM_FCLK      | MPU_INTC_ICLK                                    | Source is the PRCM module.   |
| Synchronizer | MPU_INTC_FCLK | Synchronizer clock<br>(module internal<br>clock) | Source is the MPU_INTC_FCLK. |

### 12.3.1.2 Hardware and Software Reset

[Table 12-2](#) lists the MPU subsystem INTC resets.

**Table 12-2. Hardware and Software Reset**

| Type     | Name      | Source                                                         | Activation  | Domain            |
|----------|-----------|----------------------------------------------------------------|-------------|-------------------|
| Hardware | CORE_RST  | PRCM                                                           | Active low  | CORE              |
| Software | SOFTRESET | MPU_INTC. <a href="#">INTCPS_SYSCONFIG[1]</a><br>SOFTRESET bit | Active at 1 | MPU INTC internal |

### 12.3.1.3 Power Management

The MPU subsystem INTC belongs to the CORE power domain. As part of CORE power domain, it is sensitive to a CORE\_RST issued by the PRCM. For more information about the CORE power domain implementation and CORE\_RST signal, see [Chapter 3, Power, Reset, and Clock Management](#).

The MPU INTC clocks come from the MPU DPLL. For more information about these clocks control, see [Chapter 4, MPU Subsystem](#).

### 12.3.2 Interrupt Request Lines

[Table 12-3](#) lists the incoming and outgoing interrupt lines of the INTCPS.

**Table 12-3. Interrupt Lines Incoming and Outgoing**

| Type                      | Number   | Name         | Mapping                        | Comments                                              |
|---------------------------|----------|--------------|--------------------------------|-------------------------------------------------------|
| Interrupt request inputs  | Up to 96 | M_IRQ_[95:0] | See <a href="#">Table 12-4</a> | Inputs to INTCPS module, source from various modules. |
| Interrupt request outputs | 2        | MPU_INTC_FIQ | MPU_INTC_FIQ                   | Outgoing to MPU Fast Interrupt                        |
|                           |          | MPU_INTC IRQ | MPU_INTC IRQ                   | Outgoing to MPU Normal Interrupt                      |

**NOTE:** Interrupt request signals are active at low level.

**CAUTION**

A single interrupt source can be physically mapped to multiple INTCs (MPU subsystem, IVA2.2 subsystem, and modem). With multiple-mapped interrupts, it is strongly recommended each interrupt source be unmapped in only one INTC at a time.

[Table 12-4](#) lists interrupt mappings to the MPU subsystem.

**Table 12-4. Interrupt Mapping to the MPU Subsystem<sup>(1)</sup>**

| IRQ     | Source        | Description                  |
|---------|---------------|------------------------------|
| M_IRQ_0 | EMUINT        | MPU emulation <sup>(2)</sup> |
| M_IRQ_1 | COMMTX        | MPU emulation <sup>(2)</sup> |
| M_IRQ_2 | COMMRX        | MPU emulation <sup>(2)</sup> |
| M_IRQ_3 | BENCH         | MPU emulation <sup>(2)</sup> |
| M_IRQ_4 | MCBSP2_ST_IRQ | Sidetone MCBSP2 overflow     |
| M_IRQ_5 | MCBSP3_ST_IRQ | Sidetone MCBSP3 overflow     |
| M_IRQ_6 | Reserved      | Reserved                     |
| M_IRQ_7 | sys_nirq      | External source (active low) |

<sup>(1)</sup> All the IRQ signals are active at low level.

<sup>(2)</sup> These interrupts are internally generated within the MPU subsystem.

**Table 12-4. Interrupt Mapping to the MPU Subsystem<sup>(1)</sup> (continued)**

| <b>IRQ</b> | <b>Source</b>   | <b>Description</b>                            |
|------------|-----------------|-----------------------------------------------|
| M_IRQ_8    | Reserved        | Reserved                                      |
| M_IRQ_9    | SMX_DBG_IRQ     | L3 interconnect error for debug               |
| M_IRQ_10   | SMX_APP_IRQ     | L3 interconnect error for application         |
| M_IRQ_11   | PRCM_MPU_IRQ    | PRCM module IRQ                               |
| M_IRQ_12   | SDMA_IRQ_0      | System DMA request 0 <sup>(3)</sup>           |
| M_IRQ_13   | SDMA_IRQ_1      | System DMA request 1 <sup>(3)</sup>           |
| M_IRQ_14   | SDMA_IRQ_2      | System DMA request 2                          |
| M_IRQ_15   | SDMA_IRQ_3      | System DMA request 3                          |
| M_IRQ_16   | MCBSP1_IRQ      | McBSP module 1 IRQ <sup>(3)</sup>             |
| M_IRQ_17   | MCBSP2_IRQ      | McBSP module 2 IRQ <sup>(3)</sup>             |
| M_IRQ_18   | SR1_IRQ         | SmartReflex 1                                 |
| M_IRQ_19   | SR2_IRQ         | SmartReflex 2                                 |
| M_IRQ_20   | GPMC_IRQ        | General-purpose memory controller module      |
| M_IRQ_21   | SGX_IRQ         | 2D/3D graphics module                         |
| M_IRQ_22   | MCBSP3_IRQ      | McBSP module 3 <sup>(4)</sup>                 |
| M_IRQ_23   | MCBSP4_IRQ      | McBSP module 4 <sup>(4)</sup>                 |
| M_IRQ_24   | CAM_IRQ0        | Camera interface request 0                    |
| M_IRQ_25   | DSS_IRQ         | Display subsystem module <sup>(4)</sup>       |
| M_IRQ_26   | MAIL_U0_MPU_IRQ | Mailbox user 0 request                        |
| M_IRQ_27   | MCBSP5_IRQ      | McBSP module 5 <sup>(4)</sup>                 |
| M_IRQ_28   | IVA2_MMU_IRQ    | IVA2 MMU                                      |
| M_IRQ_29   | GPIO1_MPU_IRQ   | GPIO module 1 <sup>(4) (5)</sup>              |
| M_IRQ_30   | GPIO2_MPU_IRQ   | GPIO module 2 <sup>(4) (5)</sup>              |
| M_IRQ_31   | GPIO3_MPU_IRQ   | GPIO module 3 <sup>(4) (5)</sup>              |
| M_IRQ_32   | GPIO4_MPU_IRQ   | GPIO module 4 <sup>(4) (5)</sup>              |
| M_IRQ_33   | GPIO5_MPU_IRQ   | GPIO module 5 <sup>(4)</sup>                  |
| M_IRQ_34   | GPIO6_MPU_IRQ   | GPIO module 6 <sup>(4)</sup>                  |
| M_IRQ_35   | Reserved        | Reserved                                      |
| M_IRQ_36   | WDT3_IRQ        | Watchdog timer module 3 overflow              |
| M_IRQ_37   | GPT1_IRQ        | General-purpose timer module 1                |
| M_IRQ_38   | GPT2_IRQ        | General-purpose timer module 2                |
| M_IRQ_39   | GPT3_IRQ        | General-purpose timer module 3                |
| M_IRQ_40   | GPT4_IRQ        | General-purpose timer module 4                |
| M_IRQ_41   | GPT5_IRQ        | General-purpose timer module 5 <sup>(4)</sup> |
| M_IRQ_42   | GPT6_IRQ        | General-purpose timer module 6 <sup>(4)</sup> |
| M_IRQ_43   | GPT7_IRQ        | General-purpose timer module 7 <sup>(4)</sup> |
| M_IRQ_44   | GPT8_IRQ        | General-purpose timer module 8 <sup>(4)</sup> |
| M_IRQ_45   | GPT9_IRQ        | General-purpose timer module 9                |
| M_IRQ_46   | GPT10_IRQ       | General-purpose timer module 10               |
| M_IRQ_47   | GPT11_IRQ       | General-purpose timer module 11               |
| M_IRQ_48   | SPI4_IRQ        | McSPI module 4                                |
| M_IRQ_49   | Reserved        | Reserved                                      |
| M_IRQ_50   | Reserved        | Reserved                                      |
| M_IRQ_51   | Reserved        | Reserved                                      |
| M_IRQ_52   | Reserved        | Reserved                                      |

<sup>(3)</sup> Shared with the IVA2.2 interrupt controller

<sup>(4)</sup> Shared with the IVA2.2 interrupt controller

<sup>(5)</sup> Shared with the modem interrupt controller

**Table 12-4. Interrupt Mapping to the MPU Subsystem<sup>(1)</sup> (continued)**

| IRQ      | Source         | Description                                                           |
|----------|----------------|-----------------------------------------------------------------------|
| M_IRQ_53 | Reserved       | Reserved <sup>(4)</sup>                                               |
| M_IRQ_54 | MCBSP4_IRQ_TX  | McBSP module 4 transmit <sup>(4)</sup>                                |
| M_IRQ_55 | MCBSP4_IRQ_RX  | McBSP module 4 receive <sup>(4)</sup>                                 |
| M_IRQ_56 | I2C1_IRQ       | I <sup>2</sup> C module 1                                             |
| M_IRQ_57 | I2C2_IRQ       | I <sup>2</sup> C module 2                                             |
| M_IRQ_58 | HDQ_IRQ        | HDQ/1-Wire®                                                           |
| M_IRQ_59 | McBSP1_IRQ_TX  | McBSP module 1 transmit <sup>(4)</sup>                                |
| M_IRQ_60 | McBSP1_IRQ_RX  | McBSP module 1 receive <sup>(4)</sup>                                 |
| M_IRQ_61 | I2C3_IRQ       | I <sup>2</sup> C module 3                                             |
| M_IRQ_62 | McBSP2_IRQ_TX  | McBSP module 2 transmit <sup>(4)</sup>                                |
| M_IRQ_63 | McBSP2_IRQ_RX  | McBSP module 2 receive <sup>(4)</sup>                                 |
| M_IRQ_64 | Reserved       | Reserved                                                              |
| M_IRQ_65 | SPI1_IRQ       | McSPI module 1                                                        |
| M_IRQ_66 | SPI2_IRQ       | McSPI module 2                                                        |
| M_IRQ_67 | Reserved       | Reserved                                                              |
| M_IRQ_68 | Reserved       | Reserved                                                              |
| M_IRQ_69 | Reserved       | Reserved                                                              |
| M_IRQ_70 | Reserved       | Reserved                                                              |
| M_IRQ_71 | Reserved       | Reserved                                                              |
| M_IRQ_72 | UART1_IRQ      | UART module 1                                                         |
| M_IRQ_73 | UART2_IRQ      | UART module 2                                                         |
| M_IRQ_74 | UART3_IRQ      | UART module 3 (also infrared) <sup>(6)</sup>                          |
| M_IRQ_75 | PBIAS IRQ      | Merged interrupt for PBIASlite1 and 2                                 |
| M_IRQ_76 | OHCI_IRQ       | OHCI controller HSUSB MP Host Interrupt                               |
| M_IRQ_77 | EHCI_IRQ       | EHCI controller HSUSB MP Host Interrupt                               |
| M_IRQ_78 | TLL_IRQ        | HSUSB MP TLL Interrupt                                                |
| M_IRQ_79 | Reserved       | Reserved                                                              |
| M_IRQ_80 | UART4_IRQ      | UART module 4                                                         |
| M_IRQ_81 | MCBSP5_IRQ_TX  | McBSP module 5 transmit <sup>(6)</sup>                                |
| M_IRQ_82 | MCBSP5_IRQ_RX  | McBSP module 5 receive <sup>(6)</sup>                                 |
| M_IRQ_83 | MMC1_IRQ       | MMC/SD module 1                                                       |
| M_IRQ_84 | Reserved       | Reserved                                                              |
| M_IRQ_85 | Reserved       | Reserved                                                              |
| M_IRQ_86 | MMC2_IRQ       | MMC/SD module 2                                                       |
| M_IRQ_87 | MPU_ICR_IRQ    | MPU ICR interrupt                                                     |
| M_IRQ_88 | D2DFRINT       | From 3G coprocessor hardware when used in stacked modem configuration |
| M_IRQ_89 | MCBSP3_IRQ_TX  | McBSP module 3 transmit <sup>(6)</sup>                                |
| M_IRQ_90 | MCBSP3_IRQ_RX  | McBSP module 3 receive <sup>(6)</sup>                                 |
| M_IRQ_91 | SPI3_IRQ       | McSPI module 3                                                        |
| M_IRQ_92 | HSUSB_MC_NINT  | High-Speed USB OTG controller                                         |
| M_IRQ_93 | HSUSB_DMA_NINT | High-Speed USB OTG DMA controller                                     |
| M_IRQ_94 | MMC3_IRQ       | MMC/SD module 3                                                       |
| M_IRQ_95 | Reserved       | Reserved                                                              |

<sup>(6)</sup> Shared with the IVA2.2 interrupt controller

## 12.4 Interrupt Controller Functional Description

The main features of the INTCPS are:

- Individual priority (up to 64 levels) for each interrupt input
- Ability for each interrupt to be steered to either FIQ or IRQ
- Independent priority sorting for FIQ and IRQ; FIQ sorting is processed concurrently with IRQ sorting.
- Priority masking: Interrupts can be masked based on the priority threshold register.
- Atomic bit set and clear capability for interrupt mask and software interrupt registers
- Power-management and wake-up support
- Auto-idle power-saving support

The INTCPS processes incoming interrupts by masking and priority sorting, then it generates the interrupt requests to the MPU.

[Figure 12-4](#) shows the top-level view of the interrupt processing.

**Figure 12-4. Top-Level Block Diagram**

intc-004

## 12.4.1 Interrupt Processing

### 12.4.1.1 Input Selection

The INTCPS supports only level-sensitive incoming interrupt detection. A peripheral asserting an interrupt maintains it until software has handled the interrupt and instructed the peripheral to deassert the interrupt.

A software interrupt is generated if the corresponding bit in the MPU\_INTC.[INTCPS\\_ISR\\_SETn](#) register is set (register bank number: n = [0,2] for the MPU subsystem INTCPS, 96 incoming interrupt lines are supported). The software interrupt clears when the corresponding bit in the MPU\_INTC.[INTCPS\\_ISR\\_CLEARn](#) register is written. Typical use of this feature is software debugging.

### 12.4.1.2 Masking

#### 12.4.1.2.1 Individual Masking

Detection of interrupts on each incoming interrupt line can be enabled or disabled independently by the MPU\_INTC.[INTCPS\\_MIRn](#) interrupt mask register. In response to an unmasked incoming interrupt, the INTCPS can generate one of two types of interrupt requests to the processor:

- IRQ: low-priority interrupt request
- FIQ: fast interrupt request

The type of interrupt request is determined by the MPU\_INTC.[INTCPS\\_ILRm\[0\]](#) FIQNIRQ bit (m= [0,95]).

The current incoming interrupt status before masking is readable from the MPU\_INTC.[INTCPS\\_ITRn](#) register. After masking and IRQ/FIQ selection, and before priority sorting is done, the interrupt status is readable from the MPU\_INTC.[INTCPS\\_PENDING\\_IRQn](#) and MPU\_INTC.[INTCPS\\_PENDING\\_FIQn](#) registers.

#### 12.4.1.2.2 Priority Masking

To enable faster processing of high-priority interrupts, a programmable priority masking threshold is provided (the MPU\_INTC.[INTCPS\\_THRESHOLD\[7:0\]](#) PRIORITYTHRESHOLD field). This priority threshold allows preemption by higher priority interrupts; all interrupts of lower or equal priority than the threshold are masked. However, priority 0 can never be masked by this threshold; a priority threshold of 0 is treated the same way as priority 1.

PRIORITY and PRIORITYTHRESHOLD fields values can be set between 0x0 and 0x3F; 0x0 is the highest priority and 0x3F is the lowest priority.

When priority masking is not necessary, a priority threshold value of 0xFF disables the priority threshold mechanism. This value is also the reset default for backward compatibility with previous versions of the INTCPS.

#### 12.4.1.3 Priority Sorting

A priority level (0 being the highest) is assigned to each incoming interrupt line. Both the priority level and the interrupt request type are configured by the MPU\_INTC.[INTCPS\\_ILRm](#) register. If more than one incoming interrupt with the same priority level and interrupt request type occur simultaneously, the highest-numbered interrupt is serviced first.

When one or more unmasked incoming interrupts are detected, the INTCPS separates between IRQ and FIQ using the corresponding MPU\_INTC.[INTCPS\\_ILRm\[0\]](#) FIQNIRQ bit. The result is placed in [INTCPS\\_PENDING\\_IRQn](#) or [INTCPS\\_PENDING\\_FIQn](#).

If no other interrupts are currently being processed, INTCPS asserts IRQ/FIQ and starts the priority computation. Priority sorting for IRQ and FIQ can execute in parallel.

Each IRQ/FIQ priority sorter determines the highest priority interrupt number. Each priority number is placed in the corresponding MPU\_INTC.[INTCPS\\_SIR\\_IRQ\[6:0\]](#) ACTIVEIRQ field or MPU\_INTC.[INTCPS\\_SIR\\_FIQ\[6:0\]](#) ACTIVEFIQ field. The value is preserved until the corresponding MPU\_INTC.[INTCPS\\_CONTROL](#) NEWIRQAGR or NEWFIQAGR bit is set.

Once the interrupting peripheral device has been serviced and the incoming interrupt deasserted, the user must write to the appropriate NEWIRQAGR or NEWFIQAGR bit to indicate to the INTCPS the interrupt has been handled. If there are any pending unmasked incoming interrupts for this interrupt request type, the INTCPS restarts the appropriate priority sorter; otherwise, the IRQ or FIQ interrupt line is deasserted.

#### 12.4.2 Register Protection

If the MPU\_INTC.[INTCPS\\_PROTECTION](#)[0] PROTECTION bit is set, access to the INTCPS registers is restricted to the supervisor mode. Access to the MPU\_INTC.[INTCPS\\_PROTECTION](#) register is always restricted to privileged mode.

#### 12.4.3 Module Power Saving

The INTCPS provides an auto-idle function in its three clock domains:

- Interface clock
- Functional clock
- Synchronizer clock

The interface clock auto-idle power-saving mode is enabled if the MPU\_INTC.[INTCPS\\_SYSConfig](#)[0] AUTOIDLE bit is set to 1. When this mode is enabled and there is no activity on the bus interface, the interface clock is disabled internally to the module, thus reducing power consumption. When there is new activity on the bus interface, the interface clock restarts without any latency penalty. After reset, this mode is disabled, by default.

The functional clock auto-idle power-saving mode is enabled if the MPU\_INTC.[INTCPS\\_IDLE](#)[0] FUNCIDLE bit is set to 0. When this mode is enabled and there is no active interrupt (IRQ or FIQ interrupt being processed or generated) or no pending incoming interrupt, the functional clock is disabled internally to the module, thus reducing power consumption. When a new unmasked incoming interrupt is detected, the functional clock restarts and the INTCPS processes the interrupt. If this mode is disabled, the interrupt latency is reduced by one cycle. After reset, this mode is enabled, by default.

The synchronizer clock allows external asynchronous interrupts to be resynchronized before they are masked. The synchronizer input clock has an auto-idle power-saving mode enabled if the MPU\_INTC.[INTCPS\\_IDLE](#)[1] TURBO bit is set to 1. If the auto-idle mode is enabled, the standby power is reduced, but the IRQ or FIQ interrupt latency increases from four to six functional clock cycles. This feature can be enabled dynamically according to the requirements of the device. After reset, this mode is disabled, by default.

To reduce power consumption of the modem INTC, which is not use in the stand-alone device, modem INTC clocks must be configured in auto-idle mode. Therefore, both the MPU\_INTC.[INTCPS\\_SYSConfig](#)[0] AUTOIDLE and MPU\_INTC.[INTCPS\\_IDLE](#)[1] TURBO bits must be set to 1 during initialization.

#### 12.4.4 Interrupt Latency

The IRQ/FIQ interrupt generation takes four INTCPS functional clock cycles (plus or minus one cycle) if the MPU\_INTC.[INTCPS\\_IDLE](#)[1] TURBO bit is set to 0. If the TURBO bit is set to 1, the interrupt generation takes six cycles, but power consumption is reduced while waiting for an interrupt.

These latencies can be reduced by one cycle by disabling functional clock auto-idle (MPU\_INTC.[INTCPS\\_IDLE](#)[0] FUNCIDLE bit set to 1), but power consumption is increased, so the benefit is minimal. For information about power saving, see [Section 12.4.3](#).

To minimize interrupt latency when an unmasked interrupt occurs, the IRQ or FIQ interrupt is generated before priority sorting completion. The priority sorting takes 10 functional clock cycles, which is less than the minimum number of cycles required for the MPU to switch to the interrupt context after reception of the IRQ or FIQ event.

Any read of the MPU\_INTC.[INTCPS\\_SIR\\_IRQ](#) or MPU\_INTC.[INTCPS\\_SIR\\_FIQ](#) register during the priority sorting process stalls until priority sorting is complete and the relevant register is updated. However, the delay between the interrupt request being generated and the interrupt service routine being executed is such that priority sorting always completes before the MPU\_INTC.[INTCPS\\_SIR\\_IRQ](#) or MPU\_INTC.[INTCPS\\_SIR\\_FIQ](#) register is read.

## 12.5 Interrupt Controller Basic Programming Model

### 12.5.1 Initialization Sequence

1. Program the MPU\_INTC.INTCPS\_SYSCONFIG register: If necessary, enable the interface clock autogating by setting the AUTOIDLE bit.
2. Program the MPU\_INTC.INTCPS\_IDLE register: If necessary, disable functional clock autogating or enable synchronizer autogating by setting the FUNCIDLE bit or TURBO bit accordingly.
3. Program the MPU\_INTC.INTCPS\_ILRm register for each interrupt line: Assign a priority level and set the FIQNFIQ bit for an FIQ interrupt (by default, interrupts are mapped to IRQ and priority is 0x0 [highest]).
4. Program the MPU\_INTC.INTCPS\_MIRn register: Enable interrupts (by default, all interrupt lines are masked).

**NOTE:** To program the MPU\_INTC.INTCPS\_MIRn register, the MPU\_INTC.INTCPS\_MIR\_SETn and MPU\_INTC.INTCPS\_MIR\_CLEARn registers are provided to facilitate the masking, even if it is possible for backward-compatibility to write directly to the MPU\_INTC.INTCPS\_MIRn register.

### 12.5.2 MPU INTC Processing Sequence

After the MPU\_INTC.INTCPS\_MIRn and MPU\_INTC.INTCPS\_ILRm registers are configured to enable and assign priorities to incoming interrupts, the interrupt is processed as explained in the following subsections.

IRQ and FIQ processing sequences are quite similar, the differences for the FIQ sequence are shown after a '/' character in **bold** characters in the text or the code below.

1. One or more unmasked incoming interrupts (**M\_IRQ\_n** signals) are received and IRQ or FIQ outputs (MPU\_INTC\_IRQ/**FIQ**) are not currently asserted.
2. If the MPU\_INTC.INTCPS\_ILRm[0] FIQNIRQ bit is set to 0, the MPU\_INTC\_IRQ output signal is generated. If the FIQNIRQ bit is set to 1, the MPU\_INTC\_FIQ output signal is generated.
3. The INTC performs the priority sorting and updates the MPU\_INTC.INTCPS\_SIR\_IRQ[6:0] ACTIVEIRQ /**MPU\_INTC.INTCPS\_SIR\_FIQ[6:0]** ACTIVEFIQ field with the current interrupt number.
4. During priority sorting, if the IRQ/**FIQ** is enabled at the host processor side, the host processor automatically saves the current context and executes the ISR as follows:

**NOTE:** The ARM host processor automatically performs the following actions in pseudo code.

```
LR = PC + 4          /* return link */  
SPSR = CPSR          /* Save CPSR before execution */  
CPSR[5] = 0          /* Execute in ARM state */  
CPSR[7] = 1          /* Disable IRQ */  
CPSR[8] = 1          /* Disable Imprecise Data Aborts */  
CPSR[9] = CP15_reg1_EEbit /* Endianness on exception entry */  
if interrupt == IRQ then  
    CPSR[4:0] = 0b10010 /* Enter IRQ mode */  
    if high vectors configured then  
        PC = 0xFFFFF0018 /* execute interrupt vector */  
    else  
        PC = 0x000000018 /* execute interrupt vector */  
else if interrupt == FIQ then  
    CPSR[4:0] = 0b10001 /* Enter FIQ mode */  
    CPSR[6] = 1          /* Disable FIQ */  
    if high vectors configured then  
        PC = 0xFFFFF001C /* execute interrupt vector */  
    else  
        PC = 0x00000001C /* execute interrupt vector */  
endif
```

5. The ISR saves the remaining context, identifies the interrupt source by reading the **ACTIVEIRQ/ACTIVEFIQ** field, and jumps to the relevant subroutine handler as follows:

**CAUTION**

The code in steps 5 and 7 is an assembly code compatible with ARM architecture V6 and V7. This code is developed for the Texas Instruments Code Composer Studio tool set. It is a draft version, only tested on an emulated environment.

```
/* INTCPS_SIR_IRQ/INTCPS_SIR_FIQ register address
INTCP_SIR_IRQ_ADDR/INTCP_SIR_FIQ_ADDR .word 0x48200040/0x48200044

/* ACTIVEIRQ bit field mask to get only the bit field
ACTIVEIRQ_MASK .equ 0x7F
_IRQ_ISR/_FIQ_ISR:

    /* Save the critical context
    STMF D SP!, {R0-R12, LR}           /* Save working registers and the Link register

    MRS R11, SPSR                      /* Save the SPSR into R11

    /* Get the number of the highest priority active IRQ/FIQ
    LDR R10, INTCPS_SIR_IRQ_ADDR/INTCPS_SIR_FIQ_ADDR
    LDR R10, [R10]                      /* Get the INTCPS_SIR_IRQ/INTCPS_SIR_FIQ register
    AND R10, R10, #ACTIVEIRQ_MASK       /* Apply the mask to get the active IRQ number

    /* Jump to relevant subroutine handler
    LDR PC, [PC, R10, lsl #2]          /* PC base address points this instruction + 8

    NOP                                /* To index the table by the PC

    /* Table of handler start addresses
    .word IRQ0handler ;For IRQ0 of BANK0
    .word IRQ1handler
    .word IRQ2handler
```

6. The subroutine handler executes code specific to the peripheral generating the interrupt by handling the event and deasserting the interrupt condition at the peripheral side.

```
/* IRQ0 subroutine
IRQ0handler:
    /* Save working registers
    STMF D SP!, {R0-R1}

    /* Now read-modify-write the peripheral module status register
    /* to de-assert the M_IRQ_0 interrupt signal

    /* De-Assert the peripheral interrupt

    MOV R0, #0x7                         /* Mask for 3 flags
    LDR R1, MODULE0_STATUS_REG_ADDR /* Get the address of the module Status Register
    STR R0, [R1]                          /* Clear the 3 flags

    /* Restore working registers      LDMFD SP!, {R0-R1}
    /* Jump to the end part of the ISR
    B IRQ_ISR_end/_FIQ_ISR_end
```

7. After the return of the subroutine, the ISR sets the **NEWIRQAGR/NEWFIQAGR** bit to enable the processing of subsequent pending IRQs/**FIQs** and to restore ARM context in the following code. Because the writes are posted on an Interconnect bus, to be sure that the preceding writes are done before enabling IRQs/**FIQs**, a Data Synchronization Barrier is used. This operation ensure that the IRQ/**FIQ** line is de-asserted before IRQ/**FIQ** enabling. After that, the INTc processes any other pending interrupts or deasserts the MPU\_INTC\_IRQ/MPU\_INTC\_FIQ signal if there is no interrupt.

```

/* INTCPS_CONTROL register address
INTCPS_CONTROL_ADDR .word 0x48200048;

NEWIRQAGR/NEWFIQAGR bit mask to set only the NEWIRQAGR/NEWFIQAGR bit
NEWIRQAGR_MASK/NEWFIQAGR_MASK .equ 0x01/0x02

IRQ_ISR_end/FIQ_ISR_end:

/* Allow new IRQs/FIQs at INTC side
/* The INTCPS_CONTROL register is a write only register so no need to write back others bits

    MOV R0, #NEWIRQAGR_MASK/NEWFIQAGR_MASK /* Get the NEWIRQAGR/NEWFIQAGR bit position
    LDR R1, INTCPS_CONTROL_ADDR
    STR R0, [R1] /* Write the NEWIRQAGR/NEWFIQAGR bit to allow
new IRQs/FIQs

    /* Data Synchronization Barrier
    MOV R0, #0
    MCR P15, #0, R0, C7, C10, #4

    /* restore critical context
    MSR SPSR, R11 /* Restore the SPSR from R11
    LDMFD SP!, {R0-R12, LR} /* Restore working registers and Link register

    /* Return after handling the interrupt
    SUBS PC, LR, #4

```

8. After the ISR return, the ARM automatically restores its context as follows:

```

CPSR = SPSR
PC = LR

```

[Figure 12-5](#) shows the IRQ/**FIQ** processing sequence from the originating device peripheral module to the main program interruption.

**Figure 12-5. IRQ/FIQ Processing Sequence**

**NOTE:** The differences between the IRQ and the FIQ sequence are highlighted in blue and bold characters.

The priority sorting mechanism is frozen during an interrupt processing sequence. If an interrupt condition occurs during this time, the interrupt is not lost. It is sorted when the NEWIRQAGR/**NEWFIQAGR** bit is set (priority sorting is reactivated).

### 12.5.3 MPU INTC Preemptive Processing Sequence

Preemptive interrupts, also called nested interrupts, can reduce the latencies for higher priority interrupts. A preemptive ISR can be suspended by a higher priority interrupt. Thus, the higher priority interrupt can be served immediately.

Nested interrupts must be used carefully to avoid using corrupted data. Programmers must save corruptible registers and enable IRQ or FIQ at ARM side.

IRQ and FIQ processing sequences are quite similar, the differences for the FIQ sequence are shown after a '/' character in **bold** characters in the text or the code below.

To enable IRQ/**FIQ** preemption by higher priority IRQs/**FIQs**, programmers can follow this procedure to write the ISR:

At the beginning of an IRQ/**FIQ** ISR:

1. Save the ARM critical context registers.
2. Save the MPU\_INTC.**INTCPS\_THRESHOLD** PRIORITYTHRESHOLD field before modifying it.
3. Read the active interrupt priority in the MPU\_INTC.**INTCPS\_IRQ\_PRIORITY** IRQPRIORITY / **MPU\_INTC.INTCPS\_FIQ\_PRIORITY** FIQPRIORITY field and write it to the PRIORITYTHRESHOLD<sup>(1)</sup> field.
4. Read the active interrupt number in the MPU\_INTC.**INTCPS\_SIR\_IRQ[6:0]** ACTIVEIRQ / **MPU\_INTC.INTCPS\_SIR\_FIQ[6:0]** ACTIVEFIQ field to identify the interrupt source.
5. Write 1 to the appropriate MPU\_INTC.**INTCPS\_CONTROL** NEWIRQAGR and <sup>(2)</sup> NEWFIQAGR bit while an interrupt is still processing to allow only higher priority interrupts to preempt.
6. Because the writes are posted on an Interconnect bus, to be sure that the preceding writes are done before enabling IRQs/**FIQs**, a Data Synchronization Barrier is used. This operation ensure that the IRQ line is de-asserted before IRQ/**FIQ** enabling.
7. Enable IRQ/**FIQ** at ARM side.
8. Jump to the relevant subroutine handler.

The sample code below shows the previous steps:

#### CAUTION

The code below is an assembly code compatible with ARM architecture V6 and V7. This code is developed for the Texas Instruments Code Composer Studio tool set. It is a draft version, only tested on an emulated environment.

```
/* bit field mask to get only the bit field ACTIVEPRIOR_MASK .equ 0x3F _IRQ_ISR: /* Step 1 : Save the critical context STMD SP!, {R0-R12, LR} /* Save working registers MRS R11, SPSR /* Save the SPSR into R11 /* Step 2 : Save the INTCPS_THRESHOLD register into R12 LDR R0, INTCPS_THRESHOLD_ADDR LDR R12, [R0] /* Step 3 : Get the priority of the highest priority active IRQ LDR R1, INTCPS_IRQ_PRIORITY_ADDR/INTCPS_FIQ_PRIORITY_ADDR LDR R1, [R1] /* Get the INTCPS_IRQ_PRIORITY/INTCPS_FIQ_PRIORITY register AND R1, R1, #ACTIVEPRIOR_MASK /* Apply the mask to get the priority of the IRQ STR R1, [R0] /* Write it to the INTCPS_THRESHOLD register /* Step 4 : Get the number of the highest priority active IRQ LDR R10, INTCPS_SIR_IRQ_ADDR/INTCPS_SIR_FIQ_ADDR LDR R10, [R10] /* Get the INTCPS_SIR_IRQ/INTCPS_SIR_FIQ register AND R10, R10, #ACTIVEIRQ_MASK /* Apply the mask to get the active IRQ number /* Step 5 : Allow new IRQs and FIQs at INTC side MOV R0, #0x1/0x3 /* Get the NEWIRQAGR and NEWFIQAGR bit position LDR R1, INTCPS_CONTROL_ADDR STR R0, [R1] /* Write the NEWIRQAGR and NEWFIQAGR bit position
```

<sup>(1)</sup> The priority-threshold mechanism is enabled automatically when writing a priority in the range of 0x00 to 0x3F while reading it from the IRQPRIORITY and FIQPRIORITY fields. Writing a value of 0xFF (reset default) disables the priority-threshold mechanism. Values between 0x3F and 0xFF must not be used.

When the hardware-priority threshold is in use, the priorities of interrupts selected as FIQ or IRQ become linked; otherwise, they are independent. When they are linked, all FIQ priorities must be set higher than all IRQ priorities to maintain the relative priority of FIQ over IRQ.

<sup>(2)</sup> When handling FIQs using the priority-threshold mechanism, both NEWFIQAGR and NEWIRQAGR bits must be written at the same time to ensure that the new priority threshold is applied while an IRQ sort is in progress. This IRQ will not have been seen by the ARM, as it will have been masked on entry to the FIQ ISR. However, the source of the IRQ remains active and it is finally processed when the priority threshold falls to a priority sufficiently low to allow it to be processed. The precaution of writing to New FIQ Agreement is not required during an IRQ ISR, as FIQ sorting is not affected (providing all FIQ priorities are higher than all IRQ priorities).

```
NEWFIQAGR bit /* Step 6 : Data Synchronization Barrier MOV R0, #0 MCR P15, #0, R0, C7, C10, #4 */
Step 7 : Read-modify-write the CPSR to enable IRQs/FIQs at ARM side MRS R0, CPSR /* Read the
status register BIC R0, R0, #0x80/0x40 /* Clear the I/F bit MSR CPSR, R0 /* Write it back to
enable IRQs /* Step 8 : Jump to relevant subroutine handler LDR PC, [PC, R10, lsl #2] /* PC base
address points this instruction + 8 NOP /* To index the table by the PC /* Table of handler start
addresses .word IRQ0handler ;IRQ0 BANK0 .word IRQ1handler .word IRQ2handler
```

After the return of the relevant IRQ/FIQ subroutine handle :

1. Disable IRQs/FIQs at ARM side.
2. Restore the MPU\_INTC.INTCPS\_THRESHOLD PRIORITYTHRESHOLD field.
3. Restore the ARM critical context registers.

The sample code below shows the three previous steps:

#### CAUTION

The code below is an assembly code compatible with ARM architecture V6 and V7. This code is developed for the Texas Instruments Code Composer Studio tool set. It is a draft version, only tested on an emulated environment.

```
IRQ_ISR_end: /* Step 1 : Read-modify-write the CPSR to disable IRQs/FIQs at ARM side MRS R0, CPSR
/* Read the CPSR ORR R0, R0, #0x80/0x40 /* Set the I/F bit MSR CPSR, R0 /* Write it back to
disable IRQs /* Step 2 : Restore the INTCPS_THRESHOLD register from R12 LDR R0,
INTCPS_THRESHOLD_ADDR STR R12, [R0] /* Step 3 : Restore critical context MSR SPSR, R11 /* Restore
the SPSR from R11 LDMFD SP!, {R0-R12, LR} /* Restore working registers and Link register /*
Return after handling the interrupt SUBS PC, LR, #4
```

[Figure 12-6](#) shows the nested IRQ/FIQ processing sequence from the originating device peripheral module to the main program interruption.

**Figure 12-6. Nested IRQ/FIQ Sequence**


intc-006

**NOTE:** The differences between the IRQ and the FIQ sequence are highlighted in blue and bold characters.

### 12.5.4 MPU INTC Spurious Interrupt Handling

The spurious flag indicates whether the result of the sorting (a window of 10 INTC functional clock cycles after the interrupt assertion) is invalid. The sorting is invalid if:

- The interrupt that triggered the sorting is no longer active during the sorting.
- A change in the mask has affected the result during the sorting time.

As a result, the values in the MPU\_INTC.[INTCPS\\_MIRn](#), MPU\_INTC.[INTCPS\\_ILRm](#), or MPU\_INTC.[INTCPS\\_MIR\\_SETn](#) registers must not be changed while the corresponding interrupt is asserted. If these registers are changed within the 10-cycle window after the interrupt assertion, only the active interrupt input that triggered the sort can be masked before its turn in the sort. The resulting values of the following registers become invalid:

- MPU\_INTC.[INTCPS\\_SIR\\_IRQ](#)
- MPU\_INTC.[INTCPS\\_SIR\\_FIQ](#)
- MPU\_INTC.[INTCPS\\_IRQ\\_PRIORITY](#)
- MPU\_INTC.[INTCPS\\_FIQ\\_PRIORITY](#)

This condition is detected for both IRQ and FIQ, and the invalid status is flagged across the SPURIOUSIRQFLAG (see Note 1) and SPURIOUSFIQFLAG (see Note 2) bit fields in the SIR and PRIORITY registers. A 0 indicates valid and a 1 indicates invalid interrupt number and priority. The invalid indication can be tested in software as a false register value.

**NOTE:**

1. The MPU\_INTC.[INTCPS\\_SIR\\_IRQ\[31:7\]](#) SPURIOUSIRQFLAG bit field is a copy of the MPU\_INTC.[INTCPS\\_IRQ\\_PRIORITY\[31:7\]](#) SPURIOUSIRQFLAG bit field.
2. The MPU\_INTC.[INTCPS\\_SIR\\_FIQ\[31:7\]](#) SPURIOUSFIQFLAG bit field is a copy of the MPU\_INTC.[INTCPS\\_FIQ\\_PRIORITY\[31:7\]](#) SPURIOUSFIQFLAG bit field.

## 12.6 Interrupt Controller Register Manual

### 12.6.1 Instance Summary

[Table 12-5](#) lists the base address and address space for the INTC instances.

**Table 12-5. INTC Instance Summary**

| Module Name | Base Address | Size     |
|-------------|--------------|----------|
| MPU INTC    | 0x4820 0000  | 4K bytes |
| Modem INTC  | 0x480C 7000  | 4K bytes |

### 12.6.2 Register Summary

**CAUTION**

MPU INTC and Modem INTC registers are limited to 32-bit and 16-bit data accesses; 8-bit data access is not allowed and can corrupt the register content.

In [Section 12.6.3](#), each register from MPU\_INTC.INTCPS\_ITRn to MPU\_INTC.INTCPS\_PENDING\_FIQn contains 32 bits, 1 bit for each interrupt (in ascending order: bit 0 of the MPU\_INTC.INTCPS\_ITR0 register applies to interrupt line 0; bit 0 of the MPU\_INTC.INTCPS\_ITR1 register applies to interrupt line 32).

**Table 12-6. MPU INTC Register Summary**

| Register Name                      | Type | Register Width (Bits) | Address Offset           | MPU INTC Physical Address |
|------------------------------------|------|-----------------------|--------------------------|---------------------------|
| INTCPS_REVISION                    | R    | 32                    | 0x0000 0000              | 0x4820 0000               |
| INTCPS_SYSCONFIG                   | RW   | 32                    | 0x0000 0010              | 0x4820 0010               |
| INTCPS_SYSSTATUS                   | R    | 32                    | 0x0000 0014              | 0x4820 0014               |
| INTCPS_SIR_IRQ                     | R    | 32                    | 0x0000 0040              | 0x4820 0040               |
| INTCPS_SIR_FIQ                     | R    | 32                    | 0x0000 0044              | 0x4820 0044               |
| INTCPS_CONTROL                     | RW   | 32                    | 0x0000 0048              | 0x4820 0048               |
| INTCPS_PROTECTION                  | RW   | 32                    | 0x0000 004C              | 0x4820 004C               |
| INTCPS_IDLE                        | RW   | 32                    | 0x0000 0050              | 0x4820 0050               |
| INTCPS_IRQ_PRIORITY                | RW   | 32                    | 0x0000 0060              | 0x4820 0060               |
| INTCPS_FIQ_PRIORITY                | RW   | 32                    | 0x0000 0064              | 0x4820 0064               |
| INTCPS_THRESHOLD                   | RW   | 32                    | 0x0000 0068              | 0x4820 0068               |
| INTCPS_ITRn <sup>(1)</sup>         | R    | 32                    | 0x0000 0080 + (0x20 * n) | 0x4820 0080 + (0x20 * n)  |
| INTCPS_MIRn <sup>(1)</sup>         | RW   | 32                    | 0x0000 0084 + (0x20 * n) | 0x4820 0084 + (0x20 * n)  |
| INTCPS_MIR_CLEARn <sup>(1)</sup>   | W    | 32                    | 0x0000 0088 + (0x20 * n) | 0x4820 0088 + (0x20 * n)  |
| INTCPS_MIR_SETn <sup>(1)</sup>     | W    | 32                    | 0x0000 008C + (0x20 * n) | 0x4820 008C + (0x20 * n)  |
| INTCPS_ISR_SETn <sup>(1)</sup>     | RW   | 32                    | 0x0000 0090 + (0x20 * n) | 0x4820 0090 + (0x20 * n)  |
| INTCPS_ISR_CLEARn <sup>(1)</sup>   | W    | 32                    | 0x0000 0094 + (0x20 * n) | 0x4820 0094 + (0x20 * n)  |
| INTCPS_PENDING_IRQn <sup>(1)</sup> | R    | 32                    | 0x0000 0098 + (0x20 * n) | 0x4820 0098 + (0x20 * n)  |
| INTCPS_PENDING_FIQn <sup>(1)</sup> | R    | 32                    | 0x0000 009C + (0x20 * n) | 0x4820 009C + (0x20 * n)  |
| INTCPS_ILRm <sup>(2)</sup>         | RW   | 32                    | 0x0000 0100 + (0x4 * m)  | 0x4820 0100 + (0x4 * m)   |

<sup>(1)</sup> n = 0 to 2

<sup>(2)</sup> m = 0 to 95

**Table 12-7. Modem INTC Register Summary**

| Register Name  | Type | Register Width (Bits) | Address Offset | Modem INTC Physical Address |
|----------------|------|-----------------------|----------------|-----------------------------|
| INTC_SYSCONFIG | RW   | 32                    | 0x0000 0010    | 0x480C 7010                 |
| INTC_IDLE      | RW   | 32                    | 0x0000 0050    | 0x480C 7050                 |

**12.6.3 MPU INTC Register Descriptions**

Table 12-8 through Table 12-46 describe the MPU INTC registers.

**Table 12-8. INTCPS\_REVISION**

|                         |                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x000                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4820 0000                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register contains the IP revision code. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                |                         |                       | REV             |

| Bits | Field Name | Description                                                                                         | Type | Reset              |
|------|------------|-----------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | Reserved   | Read returns reset value.                                                                           | R    | 0x0000000          |
| 7:0  | REV        | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision<br>Examples: 0x10 for 1.0, 0x21 for 2.1 | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 12-9. Register Call Summary for Register INTCPS\_REVISION**

Interrupt Controller Register Manual

- [Register Summary: \[0\]](#)

**Table 12-10. INTCPS\_SYSCONFIG**

|                         |                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x010                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4820 0010                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x480C 8010                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register controls various parameters of the module interface. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |                    |
|-------------------------|-------------------------|-----------------------|-----------------|--------------------|
| 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 |                    |
| Reserved                |                         |                       |                 | SOFTRESET AUTOIDLE |

| Bits | Field Name | Description                                                                                                                                                                                           | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | Reserved   | Write 0s for future compatibility. Read returns reset value.                                                                                                                                          | R    | 0x00000000 |
| 1    | SOFTRESET  | Software reset. Set this bit to trigger a module reset. The bit is automatically reset by the hardware. Read returns 0.<br><br>Write 0x0: No functional effect<br><br>Write 0x1: The module is reset. | RW   | 0          |

| Bits | Field Name | Description                                                                                                                                                                              | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | AUTOIDLE   | Internal interface clock gating strategy<br><br>0x0: Interface clock is free-running.<br>0x1: Automatic interface clock gating strategy is applied, based on the interface bus activity. | RW   | 0     |

**Table 12-11. Register Call Summary for Register INTCPS\_SYSCONFIG**

MPU Subsystem INTCPS Integration

- [Hardware and Software Reset: \[0\]](#)

Interrupt Controller Functional Description

- [Module Power Saving: \[1\] \[2\]](#)

Interrupt Basic Programming Model

- [Initialization Sequence: \[3\]](#)

Interrupt Controller Register Manual

- [Register Summary: \[4\]](#)

**Table 12-12. INTCPS\_SYSSTATUS**

|                         |                                                             |                       |                 |           |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------|-----------------------|-----------------|-----------|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset          | 0x014                                                       |                       |                 |           |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address        | 0x4820 0014                                                 | <b>Instance</b>       |                 |           |  |  |  |  |  |  |  |  |  |  |  |  | MPU INTC |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description             | This register provides status information about the module. |                       |                 |           |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                    | R                                                           |                       |                 |           |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESETDONE |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                |                                                             |                       |                 |           |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                    | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Read returns reset value.                                                                                      | R    | 0x00000000 |
| 0    | RESETDONE  | Internal reset monitoring<br><br>Read Internal module reset is ongoing.<br>0x0:<br>Read Reset complete<br>0x1: | R    | -          |

**Table 12-13. Register Call Summary for Register INTCPS\_SYSSTATUS**

Interrupt Controller Register Manual

- [Register Summary: \[0\]](#)

**Table 12-14. INTCPS\_SIR\_IRQ**

|                         |                                                                   |                 |          |
|-------------------------|-------------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x040                                                             |                 |          |
| <b>Physical Address</b> | 0x4820 0040                                                       | <b>Instance</b> | MPU INTC |
| <b>Description</b>      | This register supplies the currently active IRQ interrupt number. |                 |          |
| <b>Type</b>             | R                                                                 |                 |          |

  

|                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |           |   |   |   |   |   |   |
|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----------|---|---|---|---|---|---|
| 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 |
| SPURIOUSIRQFLAG |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | ACTIVEIRQ |   |   |   |   |   |   |

| Bits | Field Name      | Description       | Type | Reset      |
|------|-----------------|-------------------|------|------------|
| 31:7 | SPURIOUSIRQFLAG | Spurious IRQ flag | R    | 0xFFFFFFFF |
| 6:0  | ACTIVEIRQ       | Active IRQ number | R    | 0x00       |

**Table 12-15. Register Call Summary for Register INTCPS\_SIR\_IRQ**

## Interrupt Controller Functional Description

- Priority Sorting: [0]
- Interrupt Latency: [1] [2]

## Interrupt Basic Programming Model

- MPU INTC Processing Sequence: [3]
- MPU INTC Preemptive Processing Sequence: [4]
- MPU INTC Spurious Interrupt Handling: [5] [6]

## Interrupt Controller Register Manual

- Register Summary: [7]

**Table 12-16. INTCPS\_SIR\_FIQ**

|                         |                                                                   |                 |          |
|-------------------------|-------------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x044                                                             |                 |          |
| <b>Physical Address</b> | 0x4820 0044                                                       | <b>Instance</b> | MPU INTC |
| <b>Description</b>      | This register supplies the currently active FIQ interrupt number. |                 |          |
| <b>Type</b>             | R                                                                 |                 |          |

  

|                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |
|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----------|---|---|---|---|---|---|---|
| 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 |
| SPURIOUSFIQFLAG |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | ACTIVEFIQ |   |   |   |   |   |   |   |

| Bits | Field Name      | Description       | Type | Reset      |
|------|-----------------|-------------------|------|------------|
| 31:7 | SPURIOUSFIQFLAG | Spurious FIQ flag | R    | 0xFFFFFFFF |
| 6:0  | ACTIVEFIQ       | Active FIQ number | R    | 0x00       |

**Table 12-17. Register Call Summary for Register INTCPS\_SIR\_FIQ**

## Interrupt Controller Functional Description

- Priority Sorting: [0]
- Interrupt Latency: [1] [2]

## Interrupt Basic Programming Model

- MPU INTC Processing Sequence: [3]
- MPU INTC Preemptive Processing Sequence: [4]
- MPU INTC Spurious Interrupt Handling: [5] [6]

## Interrupt Controller Register Manual

- Register Summary: [7]

**Table 12-18. INTCPS\_CONTROL**

|                         |                                                          |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |           |  |
|-------------------------|----------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|-----------------|----------|--|--|--|--|--|-----------|--|
| <b>Address Offset</b>   | 0x048                                                    |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |           |  |
| <b>Physical Address</b> | 0x4820 0048                                              |                       |                 |  |  |  |  |  | <b>Instance</b> | MPU INTC |  |  |  |  |  |           |  |
| <b>Description</b>      | This register contains the new interrupt agreement bits. |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |           |  |
| <b>Type</b>             | RW                                                       |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |           |  |
| 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 |  |  |  |  |  |                 |          |  |  |  |  |  |           |  |
| Reserved                |                                                          |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  | NEWFIQAGR |  |
| NEWIRQAGR               |                                                          |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  | NEWIRQAGR |  |

| Bits | Field Name | Description                                                                                                                                              | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | Reserved   | Write 0s for future compatibility. Read returns reset value.                                                                                             | R    | 0x00000000 |
| 1    | NEWFIQAGR  | Reset FIQ output and enable new FIQ generation.<br><br>Write 0x0: No functional effect<br><br>Write 0x1: Reset FIQ output and enable new FIQ generation. | W    | -          |
| 0    | NEWIRQAGR  | New IRQ generation<br><br>Write 0x0: No functional effect<br><br>Write 0x1: Reset IRQ output and enable new IRQ generation.                              | W    | -          |

**Table 12-19. Register Call Summary for Register INTCPS\_CONTROL**

Interrupt Controller Functional Description

- Priority Sorting: [0]

Interrupt Basic Programming Model

- MPU INTC Preemptive Processing Sequence: [1]

Interrupt Controller Register Manual

- Register Summary: [2]

**Table 12-20. INTCPS\_PROTECTION**

|                         |                                                                                                                                                              |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |  |            |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|-----------------|----------|--|--|--|--|--|--|------------|
| <b>Address Offset</b>   | 0x04C                                                                                                                                                        |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |  |            |
| <b>Physical Address</b> | 0x4820 004C                                                                                                                                                  |                       |                 |  |  |  |  |  | <b>Instance</b> | MPU INTC |  |  |  |  |  |  |            |
| <b>Description</b>      | This register controls protection of the other registers. It can be accessed only in supervisor mode, regardless of the current value of the protection bit. |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |  |            |
| <b>Type</b>             | RW                                                                                                                                                           |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |  |            |
| 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 |  |  |  |  |  |                 |          |  |  |  |  |  |  | PROTECTION |
| Reserved                |                                                                                                                                                              |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |  |            |

| Bits | Field Name | Description                                                        | Type | Reset      |
|------|------------|--------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Write 0s for future compatibility. Read returns reset value.       | R    | 0x00000000 |
| 0    | PROTECTION | Protection mode<br><br>0x0: Protection mode is disabled (default). | RW   | 0          |

| Bits | Field Name | Description                                                                                                  | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------|------|-------|
| 0x1: |            | Protection mode is enabled. When enabled, all the MPU INTC registers are accessible only in privileged mode. |      |       |

**Table 12-21. Register Call Summary for Register INTCPS\_PROTECTION**

- ## Interrupt Controller Functional Description

- Register Protection: [0] [1]

- Interrupt Controller Register Manual

- Register Summary: [2]

**Table 12-22. INTCPS IDLE**

|                         |                                                                                               |                 |            |
|-------------------------|-----------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x050                                                                                         |                 |            |
| <b>Physical Address</b> | 0x4820 0050                                                                                   | <b>Instance</b> | MPU INTC   |
|                         | 0x480C 8050                                                                                   |                 | Modem INTC |
| <b>Description</b>      | This register controls the functional clock auto-idle and the synchronizer clock auto-gating. |                 |            |
| <b>Type</b>             | RW                                                                                            |                 |            |

| Bits | Field Name | Description                                                                                                                                                                                       | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | Reserved   | Write 0s for future compatibility. Read returns reset value.                                                                                                                                      | R    | 0x00000000 |
| 1    | TURBO      | <p>Input synchronizer clock auto-gating</p> <p>0x0: Input synchronizer clock is free-running (default).</p> <p>0x1: Input synchronizer clock is auto-gated based on interrupt input activity.</p> | RW   | 0          |
| 0    | FUNCIDLE   | <p>Functional clock idle mode</p> <p>0x0: Functional clock gating strategy is applied (default).</p> <p>0x1: Functional clock is free-running.</p>                                                | RW   | 0          |

**Table 12-23. Register Call Summary for Register INTCPS\_IDLE**

- ## Interrupt Controller Functional Description

- Module Power Saving: [0] [1] [2]
  - Interrupt Latency: [3] [4]

- ## Interrupt Basic Programming Model

- Initialization Sequence: [5]

- Interrupt Controller Register Manual

- Register Summary: [6]

**Table 12-24. INTCPS\_IRQ\_PRIORITY**

|                         |                                                                 |                 |          |
|-------------------------|-----------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x060                                                           |                 |          |
| <b>Physical Address</b> | 0x4820 0060                                                     | <b>Instance</b> | MPU INTC |
| <b>Description</b>      | This register supplies the currently active IRQ priority level. |                 |          |
| <b>Type</b>             | R                                                               |                 |          |

  

|                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |             |   |   |   |   |   |   |
|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------|---|---|---|---|---|---|
| 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 |
| SPURIOUSIRQFLAG |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | IRQPRIORITY |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------|-------------|--------------|
| 31:6        | SPURIOUSIRQFLAG   | Spurious IRQ flag    | R           | 0xFFFFFFFF   |
| 5:0         | IRQPRIORITY       | Current IRQ priority | R           | 0x00         |

**Table 12-25. Register Call Summary for Register INTCPS\_IRQ\_PRIORITY**

Interrupt Basic Programming Model

- [MPU INTC Preemptive Processing Sequence: \[0\]](#)
- [MPU INTC Spurious Interrupt Handling: \[1\] \[2\]](#)

Interrupt Controller Register Manual

- [Register Summary: \[3\]](#)

**Table 12-26. INTCPS\_FIQ\_PRIORITY**

|                         |                                                                 |                 |          |
|-------------------------|-----------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x064                                                           |                 |          |
| <b>Physical Address</b> | 0x4820 0064                                                     | <b>Instance</b> | MPU INTC |
| <b>Description</b>      | This register supplies the currently active FIQ priority level. |                 |          |
| <b>Type</b>             | R                                                               |                 |          |

  

|                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |             |   |   |   |   |   |   |   |
|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------------|---|---|---|---|---|---|---|
| 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 |
| SPURIOUSFIQFLAG |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | FIQPRIORITY |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------|-------------|--------------|
| 31:6        | SPURIOUSFIQFLAG   | Spurious FIQ flag    | R           | 0xFFFFFFFF   |
| 5:0         | FIQPRIORITY       | Current FIQ priority | R           | 0x00         |

**Table 12-27. Register Call Summary for Register INTCPS\_FIQ\_PRIORITY**

Interrupt Basic Programming Model

- [MPU INTC Preemptive Processing Sequence: \[0\]](#)
- [MPU INTC Spurious Interrupt Handling: \[1\] \[2\]](#)

Interrupt Controller Register Manual

- [Register Summary: \[3\]](#)

**Table 12-28. INTCPS\_THRESHOLD**

|                         |                                            |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |                   |  |
|-------------------------|--------------------------------------------|-----------------------|-----------------|--|--|--|--|--|-----------------|----------|--|--|--|--|--|-------------------|--|
| <b>Address Offset</b>   | 0x068                                      |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |                   |  |
| <b>Physical Address</b> | 0x4820 0068                                |                       |                 |  |  |  |  |  | <b>Instance</b> | MPU INTC |  |  |  |  |  |                   |  |
| <b>Description</b>      | This register sets the priority threshold. |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |                   |  |
| <b>Type</b>             | RW                                         |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  |                   |  |
| 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 |  |  |  |  |  |                 |          |  |  |  |  |  |                   |  |
| Reserved                |                                            |                       |                 |  |  |  |  |  |                 |          |  |  |  |  |  | PRIORITYTHRESHOLD |  |

| Bits | Field Name        | Description                                                  | Type | Reset    |
|------|-------------------|--------------------------------------------------------------|------|----------|
| 31:8 | Reserved          | Write 0s for future compatibility. Read returns reset value. | R    | 0x000000 |
| 7:0  | PRIORITYTHRESHOLD | Priority threshold                                           | RW   | 0xFF     |
|      |                   | Write 0xFF: Priority threshold disabled                      |      |          |
|      |                   | Write 0x0 to 0x3F: Priority threshold enabled                |      |          |

**Table 12-29. Register Call Summary for Register INTCPS\_THRESHOLD**

Interrupt Controller Functional Description

- [Priority Masking: \[0\]](#)

Interrupt Basic Programming Model

- [MPU INTC Preemptive Processing Sequence: \[1\] \[2\]](#)

Interrupt Controller Register Manual

- [Register Summary: \[3\]](#)

**Table 12-30. INTCPS\_ITRn**

|                         |                                                                    |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |          |
|-------------------------|--------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|
| <b>Address Offset</b>   | 0x080 + (0x20 * n)                                                 |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |          |
| <b>Physical Address</b> | 0x4820 0080 + (0x20 * n)                                           |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  | Instance |
| <b>Description</b>      | This register shows the raw interrupt input status before masking. |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  | MPU INTC |
| <b>Type</b>             | R                                                                  |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |          |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |  | ITR      |

| Bits | Field Name | Description                     | Type | Reset                       |
|------|------------|---------------------------------|------|-----------------------------|
| 31:0 | ITR        | Interrupt status before masking | R    | Depends on interrupt inputs |

**Table 12-31. Register Call Summary for Register INTCPS\_ITRn**

Interrupt Controller Functional Description

- [Individual Masking: \[0\]](#)

Interrupt Controller Register Manual

- [Register Summary: \[1\] \[2\]](#)

**Table 12-32.** INTCPS\_MIRn

|                         |                                            |                 |            |
|-------------------------|--------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x084 + (0x20 * n)                         | <b>Index</b>    | n = 0 to 2 |
| <b>Physical Address</b> | 0x4820 0084 + (0x20 * n)                   | <b>Instance</b> | MPU INTC   |
| <b>Description</b>      | This register contains the interrupt mask. |                 |            |
| <b>Type</b>             | RW                                         |                 |            |

  

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

MIR

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | MIR               | Interrupt mask<br>0x1: The interrupt is masked<br>0x0: The interrupt is unmasked | RW          | 0xFFFFFFFF   |

**Table 12-33. Register Call Summary for Register INTCPS\_MIRn**

## Interrupt Controller Functional Description

- Individual Masking: [0]

## Interrupt Basic Programming Model

- Initialization Sequence: [1] [2] [3]
  - MPU INTC Processing Sequence: [4]
  - MPU INTC Spurious Interrupt Handling: [5]

Interrupt Controller Register Manual

- Register Summary: [6]

**Table 12-34. INTCPS\_MIR\_CLEARn**

|                         |                                                         |                 |            |
|-------------------------|---------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x088 + (0x20 * n)                                      | <b>Index</b>    | n = 0 to 2 |
| <b>Physical Address</b> | 0x4820 0088 + (0x20 * n)                                | <b>Instance</b> | MPU INTC   |
| <b>Description</b>      | This register is used to clear the interrupt mask bits. |                 |            |
| <b>Type</b>             | W                                                       |                 |            |

  

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

MIRCLEAR

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                          | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | MIRCLEAR          | <p>Clear the interrupt mask bits. Read returns 0.</p> <p>Write 0x1: Clears the MIR mask bit to 0</p> <p>Write 0x0: No functional effect</p> | W           | 0x00000000   |

**Table 12-35. Register Call Summary for Register INTCPS\_MIR\_CLEARn**

---

## Interrupt Basic Programming Model

- Initialization Sequence: [0]

---

Interrupt Controller Register Manual

- Register Summary: [1]

**Table 12-36. INTCPS\_MIR\_SETn**

|                         |                                                       |                 |            |
|-------------------------|-------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x08C + (0x20 * n)                                    | <b>Index</b>    | n = 0 to 2 |
| <b>Physical Address</b> | 0x4820 008C + (0x20 * n)                              | <b>Instance</b> | MPU INTC   |
| <b>Description</b>      | This register is used to set the interrupt mask bits. |                 |            |
| <b>Type</b>             | W                                                     |                 |            |

  

|        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| MIRSET |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | MIRSET            | <p>Mask the interrupt bits. Read returns 0.</p> <p>Write 0x0: No functional effect</p> <p>Write 0x1: Sets the MIR mask bit to 1.</p> | W           | 0x00000000   |

**Table 12-37. Register Call Summary for Register INTCPS\_MIR\_SETn**

Interrupt Basic Programming Model

- Initialization Sequence: [0]
- MPU INTC Spurious Interrupt Handling: [1]

Interrupt Controller Register Manual

- Register Summary: [2]

**Table 12-38. INTCPS\_ISR\_SETn**

|                         |                                                                                                                             |                 |            |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x090 + (0x20 * n)                                                                                                          | <b>Index</b>    | n = 0 to 2 |
| <b>Physical Address</b> | 0x4820 0090 + (0x20 * n)                                                                                                    | <b>Instance</b> | MPU INTC   |
| <b>Description</b>      | This register is used to set the software interrupt bits. It is also used to read the currently active software interrupts. |                 |            |
| <b>Type</b>             | RW                                                                                                                          |                 |            |

  

|        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| ISRSET |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                             | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | ISRSET            | <p>Set the software interrupt bits. Read returns the currently active software interrupts.</p> <p>Write 0x0: No functional effect</p> <p>Write 0x1: Sets the software interrupt bits to 1.</p> | RW          | 0x00000000   |

**Table 12-39. Register Call Summary for Register INTCPS\_ISR\_SETn**

Interrupt Controller Functional Description

- Input Selection: [0]

Interrupt Controller Register Manual

- Register Summary: [1]

**Table 12-40. INTCPS\_ISR\_CLEARn**

|                         |                                                             |                 |            |
|-------------------------|-------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x094 + (0x20 * n)                                          | <b>Index</b>    | n = 0 to 2 |
| <b>Physical Address</b> | 0x4820 0094 + (0x20 * n)                                    | <b>Instance</b> | MPU INTC   |
| <b>Description</b>      | This register is used to clear the software interrupt bits. |                 |            |
| <b>Type</b>             | W                                                           |                 |            |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| ISRCLEAR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | ISRCLEAR          | Clear the software interrupt bits. Read returns 0.<br><br>Write 0x0: No functional effect<br><br>Write 0x1: Clears the software interrupt bits to 0. | W           | 0x00000000   |

**Table 12-41. Register Call Summary for Register INTCPS\_ISR\_CLEARn**

Interrupt Controller Functional Description

- [Input Selection: \[0\]](#)

Interrupt Controller Register Manual

- [Register Summary: \[1\]](#)

**Table 12-42. INTCPS\_PENDING\_IRQn**

|                         |                                                      |                 |            |
|-------------------------|------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x098 + (0x20 * n)                                   | <b>Index</b>    | n = 0 to 2 |
| <b>Physical Address</b> | 0x4820 0098 + (0x20 * n)                             | <b>Instance</b> | MPU INTC   |
| <b>Description</b>      | This register contains the IRQ status after masking. |                 |            |
| <b>Type</b>             | R                                                    |                 |            |

  

|            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 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 |  |
| PENDINGIRQ |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>        | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------|-------------|--------------|
| 31:0        | PENDINGIRQ        | IRQ status after masking. | R           | 0x00000000   |

**Table 12-43. Register Call Summary for Register INTCPS\_PENDING\_IRQn**

Interrupt Controller Functional Description

- [Individual Masking: \[0\]](#)
- [Priority Sorting: \[1\]](#)

Interrupt Controller Register Manual

- [Register Summary: \[2\]](#)

**Table 12-44. INTCPS\_PENDING\_FIQn**

|                         |                                                      |                 |            |
|-------------------------|------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x09C + (0x20 * n)                                   | <b>Index</b>    | n = 0 to 2 |
| <b>Physical Address</b> | 0x4820 009C + (0x20 * n)                             | <b>Instance</b> | MPU INTC   |
| <b>Description</b>      | This register contains the FIQ status after masking. |                 |            |
| <b>Type</b>             | R                                                    |                 |            |

  

|            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| PENDINGFIQ |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description               | Type | Reset      |
|------|------------|---------------------------|------|------------|
| 31:0 | PENDINGFIQ | FIQ status after masking. | R    | 0x00000000 |

**Table 12-45. Register Call Summary for Register INTCPS\_PENDING\_FIQn**

Interrupt Controller Functional Description

- Individual Masking: [0]
- Priority Sorting: [1]

Interrupt Controller Register Manual

- Register Summary: [2] [3]

**Table 12-46. INTCPS\_ILRm**

|                         |                                                                                   |                 |             |
|-------------------------|-----------------------------------------------------------------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x100 + (0x4 * m)                                                                 | <b>Index</b>    | m = 0 to 95 |
| <b>Physical Address</b> | 0x4820 0100 + (0x4 * m)                                                           | <b>Instance</b> | MPU INTC    |
| <b>Description</b>      | These registers contain the priority for the interrupts and the FIQ/IRQ steering. |                 |             |
| <b>Type</b>             | RW                                                                                |                 |             |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                      | Type | Reset    |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved   | Write 0s for future compatibility. Read returns reset value.                                                                                     | R    | 0x000000 |
| 7:2  | PRIORITY   | Interrupt priority                                                                                                                               | RW   | 0x00     |
| 1    | Reserved   | Write 0 for future compatibility. Read returns reset value.                                                                                      | R    | 0        |
| 0    | FIQNIRQ    | Interrupt IRQ FIQ mapping. Read returns reset value.<br><br>Write 0x0: Interrupt is routed to IRQ.<br><br>Write 0x1: Interrupt is routed to FIQ. | RW   | 0        |

**Table 12-47. Register Call Summary for Register INTCPS\_ILRm**

Interrupt Controller Functional Description

- Individual Masking: [0]
- Priority Sorting: [1] [2]

Interrupt Basic Programming Model

- Initialization Sequence: [3]
- MPU INTC Processing Sequence: [4] [5]
- MPU INTC Spurious Interrupt Handling: [6]

**Table 12-47. Register Call Summary for Register INTCPS\_ILRm (continued)**

Interrupt Controller Register Manual

- [Register Summary: \[7\]](#)

#### **12.6.4 Modem INTC Register Descriptions**

[Table 12-48](#) and [Table 12-50](#) describe useful modem INTC registers.

**Table 12-48. INTC\_SYSCONFIG**

|                         |                                                                    |                         |                 |                 |                       |
|-------------------------|--------------------------------------------------------------------|-------------------------|-----------------|-----------------|-----------------------|
| <b>Address Offset</b>   | 0x010                                                              | <b>Physical Address</b> | 0x480C 7010     | <b>Instance</b> | Modem INTC            |
| <b>Description</b>      | This register controls various parameters of the module interface. |                         |                 |                 |                       |
| <b>Type</b>             | RW                                                                 |                         |                 |                 |                       |
| 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 |                 |                       |
|                         |                                                                    |                         |                 | Reserved        |                       |
|                         |                                                                    |                         |                 |                 | SOFTRESET<br>AUTOIDLE |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:2        | Reserved          | Write 0s for future compatibility. Read returns reset value.                                                                                                                             | R           | 0x00000000   |
| 1           | SOFTRESET         | Software reset. Set this bit to trigger a module reset. The bit is automatically reset by the hardware. Read returns 0.<br><br>0x0: No functional effect<br>0x1: The module is reset.    | RW          | 0            |
| 0           | AUTOIDLE          | Internal interface clock gating strategy<br><br>0x0: Interface clock is free-running.<br>0x1: Automatic interface clock gating strategy is applied, based on the interface bus activity. | RW          | 0            |

**Table 12-49. Register Call Summary for Register INTC\_SYSCONFIG**

Interrupt Controller Register Manual

- [Register Summary: \[0\]](#)

**Table 12-50. INTC\_IDLE**

|                         |                                                                                               |                         |                 |                 |                   |
|-------------------------|-----------------------------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-------------------|
| <b>Address Offset</b>   | 0x050                                                                                         | <b>Physical Address</b> | 0x480C 7050     | <b>Instance</b> | Modem INTC        |
| <b>Description</b>      | This register controls the functional clock auto-idle and the synchronizer clock auto-gating. |                         |                 |                 |                   |
| <b>Type</b>             | RW                                                                                            |                         |                 |                 |                   |
| 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 |                 |                   |
|                         |                                                                                               |                         |                 | Reserved        |                   |
|                         |                                                                                               |                         |                 |                 | TURBO<br>FUNCIDLE |

| Bits | Field Name | Description                                                                                                                                                                        | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | Reserved   | Write 0s for future compatibility. Read returns reset value.                                                                                                                       | R    | 0x00000000 |
| 1    | TURBO      | Input synchronizer clock auto-gating<br>0x0: Input synchronizer clock is free-running (default).<br>0x1: Input synchronizer clock is auto-gated based on interrupt input activity. | RW   | 0          |
| 0    | FUNCIDLE   | Functional clock idle mode<br>0x0: Functional clock gating strategy is applied (default).<br>0x1: Functional clock is free-running.                                                | RW   | 0          |

**Table 12-51. Register Call Summary for Register INTC\_IDLE**

Interrupt Controller Register Manual

- [Register Summary: \[0\]](#)

## **System Control Module**

This chapter describes the system control module (SCM).

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                 | Page |
|---------------------------------------|------|
| 13.1 SCM Overview .....               | 2448 |
| 13.2 SCM Environment .....            | 2449 |
| 13.3 SCM Integration .....            | 2450 |
| 13.4 SCM Functional Description ..... | 2454 |
| 13.5 SCM Programming Model .....      | 2543 |
| 13.6 SCM Register Manual .....        | 2559 |

### 13.1 SCM Overview

The system control module (SCM) allows software control of the various static modes supported by the device. The SCM is on the L4-Core interconnect, but it is sensitive only to the device internal power-on reset (POR). It is not affected by the L4-Core reset.

For emulator devices, the POR can also be controlled by the debugger through the JTAG® interface.

The device uses the SCM as the primary point of control for these areas:

- Pad functional input/output (I/O) multiplexing
- Pad pullup/pulldown configuration (pullup or pulldown enable)
- Pad groups associated signal integrity controls
- Device status
- Peripheral sensitivity to the microprocessor unit (MPU) and/or the digital signal processor (DSP) (IVA2.2) MSuspend signals
- Static device configuration
- Debug and observability I/O multiplexing
- Save-and-restore pad configuration

[Figure 13-1](#) provides an overview of the SCM.

**Figure 13-1. SCM Overview**



scm-001

The SCM primarily implements a bank of registers accessible by the software. Some are read-only registers that carry status information, and others are fully accessible (read/write).

The read/write registers are divided into the following classes:

- Pad functional multiplexing and configuration registers (32-bit registers, one register per two pins)
- Pad groups (not individual per pad) associated registers for signal integrity parameters control (32-bit read/write registers )
- Debug and observability I/O multiplexing register (32-bit read/write register)
- Static device configuration registers (32-bit read/write registers for module specific configuration)
- Scratchpad memory bank (256\* 32-bit)

## 13.2 SCM Environment

The SCM allows the setting of external system direct memory access (sDMA) request pin sensitivity and controls the multiplexing of device internal modules signals routed to external pins for hardware debug purposes. The SCM also integrates the decoding logic of sys\_boot[5:0].

[Figure 13-2](#) shows an overview of the SCM environment.

**Figure 13-2. SCM Environment Overview**



scm-002

The four sys\_ndmreq [3:0] pins are optional external direct memory access (DMA) requests that can be managed directly by the sDMA controller. The SCM can configure these requests to either level sensitive (active low) or edge sensitive (falling edge) through the correct setting of the SENSDMAREQN bit (where N is between 0 and 3).

The sys\_boot[5:0] pins are read-accessible in a status register (SYSBOOT field CONTROL.CONTROL\_STATUS[5:0]) following a POR. The SCM does not use sys\_boot[6] (for more information, see [Chapter 3, Power, Reset, and Clock Management](#)).

With the correct pad configuration, the SCM maps the hw\_dbg[17:0] pins at the device boundary to observe hardware debug signals from device modules. The internal observable signals are PRCM signals, DMA requests, and interrupts.

### 13.2.1 Functional Interfaces

#### 13.2.1.1 Basic SCM Pins

Figure 13-3 shows the SCM functional interface configured to observe device module debug signals.

**Figure 13-3. SCM Interface Signals**



#### 13.2.1.2 SCM Interface Description

Table 13-1 lists the SCM input and output configured to observe device module debug signals.

**Table 13-1. SCM I/O Description**

| Signal Name   | I/O <sup>(1)</sup> | Description                         | Reset Value             |
|---------------|--------------------|-------------------------------------|-------------------------|
| hw_dbg[17:0]  | O                  | Debug signals 0 to 17               | N/A                     |
| sys_boot[5:0] | I                  | Boot configuration mode bits 0 to 5 | per boot mode selection |

<sup>(1)</sup> I = Input, O = Output

### 13.3 SCM Integration

This section describes the integration of the SCM within the device.

Figure 13-4 shows the SCM integration in the device .

**Figure 13-4. SCM Integration**


scm-004

The SCM is split into two blocks: the core control module in the CORE power domain, and the wake-up control module in the WKUP power domain. The wake-up control module contains the save-and-restore memory, some observability multiplexing and pad configurations. For more information about the wake-up control module, see [Section 13.4.3, Wake-Up Control Module](#).

The software sets the configuration registers to the desired values depending on the configuration of the requested device. Static device configuration registers can be set by the software at any time and are effective immediately.

The SCM is connected on the L4-Core interconnect. The power, reset, and clock management (PRCM) module provides the module interface clock (CORE\_L4\_ICLK) and the POR signal. The PRCM generates one global reset per power domain (CORE\_RSTPWRON\_RET for the CORE power domain and WKUP\_RSTPWRON for the WKUP power domain). The SCM does not respond to a warm reset or to an L4 reset.

### 13.3.1 Clocking, Reset, and Power-Management Scheme

#### 13.3.1.1 Clock

The main sequential logic within the SCM is accessible in a register file through the L4-Core. The only clock provided to the SCM is the interface clock, CORE\_L4\_ICLK. This clock comes from the PRCM module and is controlled by the PRCM.CM\_ICLKEN1\_CORE[6] EN\_SCMCTRL bit (0 = disables the clock, 1 = enables the clock) and the PRCM.CM\_AUTOIDLE1\_CORE[6] AUTO\_SCMCTRL bit (enables/disables automatic control of the interface clock).

For further information, see [Chapter 3, Power, Reset, and Clock Management](#).

The wake-up control module is configured through the L4-Core interface of the core control module and is accessed from the core control module through a dedicated interface. This interface uses the L4-Core interface clock (CORE\_L4\_ICLK) divided by 4 or 2 according to the CONTROL.[CONTROL\\_PADCONF\\_OFF\[2\]](#) WKUPCTRLCLOCKDIV bit. Only this wake-up interface clock (WKUP\_ICLK) is propagated to the wake-up control module.

#### 13.3.1.2 Resets

The SCM responds only to the internal POR and to the device type. The CONTROL.[CONTROL\\_SYSCONFIG\[1\]](#) SOFTRESET bit has no effect; the SCM is not affected by a warm reset.

The internal POR is not a direct image of the POR input pin (SYS\_NRESPWRON). The PRCM module generates an internal POR signal per power domain and activates the internal POR when the eFuse-related settings (such as the device type) are initialized. The core control module of the CORE power domain responds to the CORE POR (CORE\_RSTPWRON\_RET). The wake-up control module of the WKUP power domain responds to the POR (WKUP\_RSTPWRON).

---

**NOTE:** References in the TRM to the POR refer to the internal POR as seen by the SCM.

On emulator devices, the debugger can also control the internal POR signal though the JTAG interface.

---

For further information, see [Chapter 3, Power, Reset, and Clock Management](#).

#### 13.3.1.3 Power Domain

The SCM is split into two blocks: the core control module, which is attached to the CORE power domain and can be in either active, retention, or off state, and the wake-up control module, which belongs to the WKUP power domain.

---

**NOTE:** The SCM is fully built with retention flip-flop.

---

For further information, see [Chapter 3, Power, Reset, and Clock Management](#).

### 13.3.1.4 Power Management

#### 13.3.1.4.1 System Power Management

The PRCM module can require the SCM to be idled to save power. The SCM enters idle mode through the CONTROL.[CONTROL\\_SYSCONFIG\[4:3\]](#) IDLEMODE bit field.

The PRCM module requests idle mode, and the SCM always accepts an idle command. Idle mode can be configured to either force-idle or smart-idle mode.<sup>3</sup>

When the SCM is in force-idle mode (IDLEMODE bits CONTROL.[CONTROL\\_SYSCONFIG\[4:3\]](#) = 0b00) and it receives an idle request from the PRCM module (PRCM.CM\_ICLKEN1\_CORE[6] set to 0 or PRCM.CM\_AUTOIDLE1\_CORE[6] set to 1 and the L4-Core interface clock idle transitions), the SCM waits unconditionally for active system clock gating by the PRCM module. Active system clock gating occurs only when all peripherals supplied by the same L4-Core interface clock domain are also ready for idle.

In smart-idle mode (IDLEMODE bits CONTROL.[CONTROL\\_SYSCONFIG\[4:3\]](#) = 0b10), an idle command is accepted only when the save mechanism completes.

In idle mode (when the PRCM module has gated the interface clock), the SCM is not active and the interface clock paths are gated.

---

**NOTE:** The PRCM.CM\_IDLEST1\_CORE[6] ST\_SCMCTRL bit (0b0 = active, 0b1 = idle) can check the SCM idle state.

The SCM idle mode is a function of the PRCM.CM\_ICLKEN1\_CORE[6] EN\_SCMCTRL bit configuration and can be controlled automatically with hardware, depending on the PRCM.CM\_AUTOIDLE1\_CORE[6] AUTO\_SCMCTRL bit configuration.

---

#### 13.3.1.4.2 Module Power Saving

An internal interface clock-gating feature provides SCM local power management. The clock for the logic within the module can be gated when there is no access to the module according to the CONTROL.[CONTROL\\_SYSCONFIG\[0\]](#) AUTOIDLE bit. Otherwise, this logic is free-running on the interface clock CORE\_L4\_ICLK.

The L4-Core interface clock (CORE\_L4\_ICLK) is also used to synchronize and resample module inputs. The clock for those functions must always be free-running. Therefore, it is not gated.

The wake-up control module is clocked only by a local wake-up interface clock from the core control module. The wake-up interface clock (WKUP\_ICLK) uses the L4-Core interface clock (CORE\_L4\_ICLK) divided by 4 or 2 to reduce power consumption according to the CONTROL.[CONTROL\\_PADCONF\\_OFF\[2\]](#) WKUPCTRLCLOCKDIV bit (0 = divided by 4; 1 = divided by 2).

Figure 13-5 shows the SCM internal clock implementation.

**Figure 13-5. Internal Clock Implementation**

scm-005

### 13.3.2 Hardware Requests

The SCM does not generate interrupt or wake-up requests.

## 13.4 SCM Functional Description

### 13.4.1 Block Diagram

The SCM controls various device modules settings through register configuration and internal signals. It also controls the pad configuration and multiplexing and the routing of internal signals (such as PRCM signals or DMA requests) to observable pins for debug.

[Figure 13-6](#) shows the SCM block diagram.

**Figure 13-6. SCM Block Diagram**


scm-006

The following sections describe the functionality of the SCM registers.

### 13.4.2 SCM Initialization

The SCM responds only to the internal POR and to the device type. At power-on, reset values for the registers define the safe state for the device. In the initialization mode, only modules used at boot time are associated with the pads. Other module inputs are internally tied, and outputs pads are turned off each time the feature is available.

For the pad configuration, pullup/pulldown fields are set according to the device pin list.

General-purpose devices include features that are inaccessible or unavailable. These inaccessible registers define the default or fixed device configuration or behavior.

### 13.4.3 Wake-Up Control Module

The wake-up control module in the SCM belongs to the WKUP power domain. It contains a 1K-byte memory in which to save the pad configuration registers in the core control module before going to off mode. Pad configuration registers driving the I/O pad control in the WKUP power domain are also instantiated in the wake-up control module.

The wake-up control module is configured through the L4-Core interface in the core control module and is accessed from the core control module through a dedicated interface. This interface between the core control module and the wake-up control module uses the CORE\_L4\_ICLK clock divided by 4 to reduce power consumption in the WKUP power domain.

### 13.4.4 Pad Functional Multiplexing and Configuration

After POR, the software sets the pad functional multiplexing and configuration registers to the requested device pad configurations. Data written in these registers command directly the multiplexing of the pad configuration logic.

Each pin is configurable by software using its associated pad configuration register field, which is 16 bits wide (see Figure 13-7).

**Figure 13-7. Pad Configuration Register Functionality**



scm-008

One pad configuration register field is available for each pin. Each 32-bit pad configuration register is grouped into two 16-bit pad configuration register fields. One pad configuration register provides control for two different pins.

Some pad configuration registers control the configuration of pads in the CORE power domain. These

registers are instantiated in the CORE power domain of the SCM (core control module, physical addresses 0x4800 2030 to 0x4800 2264 and 0x4800 25A0 to 0x4800 25F8). Pad configuration registers also control the configuration of pads in the WKUP power domain. These registers are instantiated in the WKUP power domain of the SCM (wake-up control module, physical addresses 0x4800 2A00 to 0x4800 2A24 and 0x4800 2A4C to 0x4800 2A58).

**NOTE:** These registers can be accessed using 8-, 16-, and 32-bit operations.

The functional bits of one pad configuration register are divided into the following five fields:

- MUXMODE (3 bits) defines the multiplexing mode applied to the pin. A mode corresponds to the selection of the functionality mapped on the pin with eight (0 to 7) possible functional modes for each pin.
- PULL (2 bits) for combinational pullup/pulldown configuration:
  - PULLTYPESELECT: Pullup/pulldown selection for the pin.
  - PULLUDENABLE: Pullup/pulldown enable for the pin.
- INPUTENABLE (1 bit) drives an input enable signal to the I/O CTRL.
  - INPUTENABLE = 0: Input Disable. Pin is configured in output only mode.
  - INPUTENABLE = 1: Input Enable. Pin is configured in bidirectional mode.
- Off mode values (5 bits) override the pin state when the OFFENABLE bit CONTROL.  
**CONTROL\_PADCONF\_X** is set and off mode is active. This feature allows having separate configurations for the pins when in off mode:
  - OFFENABLE: Off mode pin state override control. Set to 1 to enable the feature and to 0 to disable it.
  - OFFOUTENABLE: Off mode output enable value. Set to 0 to enable the feature and to 1 to disable it.
  - OFFOUTVALUE: Off mode output value.
  - OFFPULLUDENABLE: Off mode pullup/pulldown enable
  - OFFPULLTYPESELECT: Off mode pullup/pulldown selection

#### CAUTION

The OFFOUTENABLE and OFFOUTVALUE bits are functional only if the pad configuration supports output mode on at least one MUXMODE. For a pad that supports only the input feature, the OFFOUTENABLE and OFFOUTVALUE bits cannot be configured (they are don't care and read always returns 0).

- Wake-up bits (2 bits):
  - WAKEUPENABLE: Enable wake-up detection on input. It is also the off mode input enable value.
  - WAKEUPEVENT: Wake-up event status for the pin.

Figure 13-8 shows the pad configuration functionality when off mode is inactive. For more information about off mode, see [Section 13.4.4.4, System Off Mode](#).

Figure 13-8. Pad Configuration Diagram



scm-009

#### 13.4.4.1 Mode Selection

Table 13-2 lists the multiplexing modes and settings.

Table 13-2. Mode Selection

| MUXMODE | Selected Mode         |
|---------|-----------------------|
| 0b000   | Primary mode = Mode 0 |
| 0b001   | Mode 1                |
| 0b010   | Mode 2                |
| 0b011   | Mode 3                |
| 0b100   | Mode 4                |
| 0b101   | Mode 5                |
| 0b110   | Mode 6                |
| 0b111   | Safe mode = Mode 7    |

The MUXMODE field CONTROL.[CONTROL\\_PADCONF\\_X](#) defines the multiplexing mode applied to the pad. Functional modes are referred to by their decimal (from 0 to 7) or binary (from 0b000 to 0b111) representation.

For most pads, the reset value for the MUXMODE field CONTROL.[CONTROL\\_PADCONF\\_X](#) is 0b111 defining a mode referred to as the safe mode. The exceptions are pads to be used at boot time to transfer data from selected peripherals to the external flash memory.

Mode 0 is the primary mode. When mode 0 is set, the function mapped to the pin corresponds to the name of the pin.

Mode 1 to Mode 7 are possible modes for alternate functions. On each pin, some modes are used effectively for alternate functions, while other modes are unused and correspond to no functional configuration.

The safe mode avoids any risk of electrical contention by configuring the pin as an input with no functional interface mapped to it. The safe mode is used mainly as the default mode for all pins containing no mandatory interface at the release of POR.

---

**NOTE:** Some pads do not have safe mode capability, and all eight mux modes are functional (for instance: etk\_d0). For such pads, safe mode can be emulated by configuring the pad in GPI (muxmode 4).

---

For more information about the configurable mode on each pin, see [Table 13-4](#) through [Table 13-6](#).

#### 13.4.4.2 Pull Selection

Whichever pull value is configured, pulls are automatically disabled when a pin is configured as an output (see [Table 13-3](#)).

**Table 13-3. Pull Selection**

| PULL           |              | Pin Behavior                                                       |
|----------------|--------------|--------------------------------------------------------------------|
| PULLTYPESELECT | PULLUDENABLE |                                                                    |
| 0b0            | 0b0          | Pulldown selected but not activated                                |
| 0b0            | 0b1          | Pulldown selected and activated if pin is NOT configured as OUTPUT |
| 0b1            | 0b0          | Pullup selected but not activated                                  |
| 0b1            | 0b1          | Pullup selected and activated if pin is NOT configured as OUTPUT   |

For more information on the pull available on each pin, see [Table 13-4](#) through [Table 13-6](#).

#### 13.4.4.3 Pad Multiplexing Register Fields

[Table 13-4](#) through [Table 13-6](#) provide for each pad configuration register field the address offset , reset values, and associated signal name for each multiplexing mode (as set by the MUXMODE bit field ). Mode 0 is always defined. Modes with no signal name are undefined for the given pad.

---

**NOTE:**

- Pad configuration registers are split into three types, which correspond to the following three tables:
  - [Table 13-4](#) lists the pad configuration registers instantiated in the CORE power domain that drive the pads in the CORE power domain.
  - [Table 13-5](#) lists the pad configuration registers instantiated in the CORE power domain that drive the D2D pads. These pads are available in stacked mode only.
  - [Table 13-6](#) lists the pad configuration registers instantiated in the WKUP power domain that drive the pads in the WKUP power domain.
- In [Table 13-4](#) through [Table 13-6](#), an empty cell indicates that the mode or pull is not available for this pin.

**Table 13-4. Core Control Module Pad Configuration Register Fields**

| Register Name                   | Physical Address | Mode0    | Mode1 | Mode2 | Mode3 | Mode4 | Mode5 | Mode6 | Mode7 |
|---------------------------------|------------------|----------|-------|-------|-------|-------|-------|-------|-------|
| CONTROL_PADCONF_SDRC_D0[15:0]   | 0x4800 2030      | sdrc_d0  |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D0[31:16]  | 0x4800 2030      | sdrc_d1  |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D2[15:0]   | 0x4800 2034      | sdrc_d2  |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D2[31:16]  | 0x4800 2034      | sdrc_d3  |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D4[15:0]   | 0x4800 2038      | sdrc_d4  |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D4[31:16]  | 0x4800 2038      | sdrc_d5  |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D6[15:0]   | 0x4800 203C      | sdrc_d6  |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D6[31:16]  | 0x4800 203C      | sdrc_d7  |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D8[15:0]   | 0x4800 2040      | sdrc_d8  |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D8[31:16]  | 0x4800 2040      | sdrc_d9  |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D10[15:0]  | 0x4800 2044      | sdrc_d10 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D10[31:16] | 0x4800 2044      | sdrc_d11 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D12[15:0]  | 0x4800 2048      | sdrc_d12 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D12[31:16] | 0x4800 2048      | sdrc_d13 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D14[15:0]  | 0x4800 204C      | sdrc_d14 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D14[31:16] | 0x4800 204C      | sdrc_d15 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D16[15:0]  | 0x4800 2050      | sdrc_d16 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D16[31:16] | 0x4800 2050      | sdrc_d17 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D18[15:0]  | 0x4800 2054      | sdrc_d18 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D18[31:16] | 0x4800 2054      | sdrc_d19 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D20[15:0]  | 0x4800 2058      | sdrc_d20 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D20[31:16] | 0x4800 2058      | sdrc_d21 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D22[15:0]  | 0x4800 205C      | sdrc_d22 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D22[31:16] | 0x4800 205C      | sdrc_d23 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D24[15:0]  | 0x4800 2060      | sdrc_d24 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D24[31:16] | 0x4800 2060      | sdrc_d25 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D26[15:0]  | 0x4800 2064      | sdrc_d26 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D26[31:16] | 0x4800 2064      | sdrc_d27 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D28[15:0]  | 0x4800 2068      | sdrc_d28 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D28[31:16] | 0x4800 2068      | sdrc_d29 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D30[15:0]  | 0x4800 206C      | sdrc_d30 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_D30[31:16] | 0x4800 206C      | sdrc_d31 |       |       |       |       |       |       |       |
| CONTROL_PADCONF_SDRC_CLK[15:0]  | 0x4800 2070      | sdrc_clk |       |       |       |       |       |       |       |

**Table 13-4. Core Control Module Pad Configuration Register Fields (continued)**

| Register Name                    | Physical Address | Mode0     | Mode1         | Mode2 | Mode3 | Mode4   | Mode5 | Mode6 | Mode7     |
|----------------------------------|------------------|-----------|---------------|-------|-------|---------|-------|-------|-----------|
| CONTROL_PADCONF_SDRC_CLK[31:16]  | 0x4800 2070      | sdrc_dqs0 |               |       |       |         |       |       |           |
| CONTROL_PADCONF_SDRC_DQS1[15:0]  | 0x4800 2074      | sdrc_dqs1 |               |       |       |         |       |       |           |
| CONTROL_PADCONF_SDRC_DQS1[31:16] | 0x4800 2074      | sdrc_dqs2 |               |       |       |         |       |       |           |
| CONTROL_PADCONF_SDRC_DQS3[15:0]  | 0x4800 2078      | sdrc_dqs3 |               |       |       |         |       |       |           |
| CONTROL_PADCONF_SDRC_DQS3[31:16] | 0x4800 2078      | gpmc_a1   |               |       |       | gpio_34 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_A2[15:0]    | 0x4800 207C      | gpmc_a2   |               |       |       | gpio_35 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_A2[31:16]   | 0x4800 207C      | gpmc_a3   |               |       |       | gpio_36 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_A4[15:0]    | 0x4800 2080      | gpmc_a4   |               |       |       | gpio_37 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_A4[31:16]   | 0x4800 2080      | gpmc_a5   |               |       |       | gpio_38 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_A6[15:0]    | 0x4800 2084      | gpmc_a6   |               |       |       | gpio_39 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_A6[31:16]   | 0x4800 2084      | gpmc_a7   |               |       |       | gpio_40 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_A8[15:0]    | 0x4800 2088      | gpmc_a8   |               |       |       | gpio_41 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_A8[31:16]   | 0x4800 2088      | gpmc_a9   | sys_ndmar eq2 |       |       | gpio_42 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_A10[15:0]   | 0x4800 208C      | gpmc_a10  | sys_ndmar eq3 |       |       | gpio_43 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_A10[31:16]  | 0x4800 208C      | gpmc_d0   |               |       |       |         |       |       |           |
| CONTROL_PADCONF_GPMC_D1[15:0]    | 0x4800 2090      | gpmc_d1   |               |       |       |         |       |       |           |
| CONTROL_PADCONF_GPMC_D1[31:16]   | 0x4800 2090      | gpmc_d2   |               |       |       |         |       |       |           |
| CONTROL_PADCONF_GPMC_D3[15:0]    | 0x4800 2094      | gpmc_d3   |               |       |       |         |       |       |           |
| CONTROL_PADCONF_GPMC_D3[31:16]   | 0x4800 2094      | gpmc_d4   |               |       |       |         |       |       |           |
| CONTROL_PADCONF_GPMC_D5[15:0]    | 0x4800 2098      | gpmc_d5   |               |       |       |         |       |       |           |
| CONTROL_PADCONF_GPMC_D5[31:16]   | 0x4800 2098      | gpmc_d6   |               |       |       |         |       |       |           |
| CONTROL_PADCONF_GPMC_D7[15:0]    | 0x4800 209C      | gpmc_d7   |               |       |       |         |       |       |           |
| CONTROL_PADCONF_GPMC_D7[31:16]   | 0x4800 209C      | gpmc_d8   |               |       |       | gpio_44 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_D9[15:0]    | 0x4800 20A0      | gpmc_d9   |               |       |       | gpio_45 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_D9[31:16]   | 0x4800 20A0      | gpmc_d10  |               |       |       | gpio_46 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_D11[15:0]   | 0x4800 20A4      | gpmc_d11  |               |       |       | gpio_47 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_D11[31:16]  | 0x4800 20A4      | gpmc_d12  |               |       |       | gpio_48 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_D13[15:0]   | 0x4800 20A8      | gpmc_d13  |               |       |       | gpio_49 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_D13[31:16]  | 0x4800 20A8      | gpmc_d14  |               |       |       | gpio_50 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_D15[15:0]   | 0x4800 20AC      | gpmc_d15  |               |       |       | gpio_51 |       |       | safe_mode |
| CONTROL_PADCONF_GPMC_D15[31:16]  | 0x4800 20AC      | gpmc_ncs0 |               |       |       |         |       |       |           |
| CONTROL_PADCONF_GPMC_NCS1[15:0]  | 0x4800 20B0      | gpmc_ncs1 |               |       |       | gpio_52 |       |       | safe_mode |

**Table 13-4. Core Control Module Pad Configuration Register Fields (continued)**

| Register Name                        | Physical Address | Mode0          | Mode1         | Mode2       | Mode3          | Mode4   | Mode5    | Mode6 | Mode7     |
|--------------------------------------|------------------|----------------|---------------|-------------|----------------|---------|----------|-------|-----------|
| CONTROL_PADCONF_GPMC_NCS1[31:16]     | 0x4800 20B0      | gpmc_ncs2      |               |             |                | gpio_53 |          |       | safe_mode |
| CONTROL_PADCONF_GPMC_NCS3[15:0]      | 0x4800 20B4      | gpmc_ncs3      | sys_ndmar_eq0 |             |                | gpio_54 |          |       | safe_mode |
| CONTROL_PADCONF_GPMC_NCS3[31:16]     | 0x4800 20B4      | gpmc_ncs4      | sys_ndmar_eq1 | mcbsp4_clkx | gpt_9_pwm_evt  | gpio_55 |          |       | safe_mode |
| CONTROL_PADCONF_GPMC_NCS5[15:0]      | 0x4800 20B8      | gpmc_ncs5      | sys_ndmar_eq2 | mcbsp4_dr   | gpt_10_pwm_evt | gpio_56 |          |       | safe_mode |
| CONTROL_PADCONF_GPMC_NCS5[31:16]     | 0x4800 20B8      | gpmc_ncs6      | sys_ndmar_eq3 | mcbsp4_dx   | gpt_11_pwm_evt | gpio_57 |          |       | safe_mode |
| CONTROL_PADCONF_GPMC_NCS7[15:0]      | 0x4800 20BC      | gpmc_ncs7      | gpmc_io_dir   | mcbsp4_fx   | gpt_8_pwm_evt  | gpio_58 |          |       | safe_mode |
| CONTROL_PADCONF_GPMC_NCS7[31:16]     | 0x4800 20BC      | gpmc_clk       |               |             |                | gpio_59 |          |       | safe_mode |
| CONTROL_PADCONF_GPMC_NADV_ALE[15:0]  | 0x4800 20C0      | gpmc_nadv_ale  |               |             |                |         |          |       |           |
| CONTROL_PADCONF_GPMC_NADV_ALE[31:16] | 0x4800 20C0      | gpmc_noe       |               |             |                |         |          |       |           |
| CONTROL_PADCONF_GPMC_NWE[15:0]       | 0x4800 20C4      | gpmc_nwe       |               |             |                |         |          |       |           |
| CONTROL_PADCONF_GPMC_NWE[31:16]      | 0x4800 20C4      | gpmc_nbe_0_cle |               |             |                | gpio_60 |          |       | safe_mode |
| CONTROL_PADCONF_GPMC_NBE1[15:0]      | 0x4800 20C8      | gpmc_nbe_1     |               |             |                | gpio_61 |          |       | safe_mode |
| CONTROL_PADCONF_GPMC_NBE1[31:16]     | 0x4800 20C8      | gpmc_nwp       |               |             |                | gpio_62 |          |       | safe_mode |
| CONTROL_PADCONF_GPMC_WAIT0[15:0]     | 0x4800 20CC      | gpmc_wait_0    |               |             |                |         |          |       |           |
| CONTROL_PADCONF_GPMC_WAIT0[31:16]    | 0x4800 20CC      | gpmc_wait_1    |               |             |                | gpio_63 |          |       | safe_mode |
| CONTROL_PADCONF_GPMC_WAIT2[15:0]     | 0x4800 20D0      | gpmc_wait_2    |               | uart4_tx    |                | gpio_64 |          |       | safe_mode |
| CONTROL_PADCONF_GPMC_WAIT2[31:16]    | 0x4800 20D0      | gpmc_wait_3    | sys_ndmar_eq1 | uart4_rx    |                | gpio_65 |          |       | safe_mode |
| CONTROL_PADCONF_DSS_PCLK[15:0]       | 0x4800 20D4      | dss_pclk       |               |             |                | gpio_66 | hw_dbg12 |       | safe_mode |
| CONTROL_PADCONF_DSS_PCLK[31:16]      | 0x4800 20D4      | dss_hsync      |               |             |                | gpio_67 | hw_dbg13 |       | safe_mode |
| CONTROL_PADCONF_DSS_VSYNC[15:0]      | 0x4800 20D8      | dss_vsync      |               |             |                | gpio_68 |          |       | safe_mode |
| CONTROL_PADCONF_DSS_VSYNC[31:16]     | 0x4800 20D8      | dss_acbias     |               |             |                | gpio_69 |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA0[15:0]      | 0x4800 20DC      | dss_data0      | dsi_dx0       | uart1_cts   |                | gpio_70 |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA0[31:16]     | 0x4800 20DC      | dss_data1      | dsi_dy0       | uart1_rts   |                | gpio_71 |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA2[15:0]      | 0x4800 20E0      | dss_data2      | dsi_dx1       |             |                | gpio_72 |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA2[31:16]     | 0x4800 20E0      | dss_data3      | dsi_dy1       |             |                | gpio_73 |          |       | safe_mode |

**Table 13-4. Core Control Module Pad Configuration Register Fields (continued)**

| Register Name                     | Physical Address | Mode0      | Mode1    | Mode2            | Mode3     | Mode4    | Mode5    | Mode6 | Mode7     |
|-----------------------------------|------------------|------------|----------|------------------|-----------|----------|----------|-------|-----------|
| CONTROL_PADCONF_DSS_DATA4[15:0]   | 0x4800 20E4      | dss_data4  | dsi_dx2  | uart3_rx_irr_x   |           | gpio_74  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA4[31:16]  | 0x4800 20E4      | dss_data5  | dsi_dy2  | uart3_tx_irr_x   |           | gpio_75  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA6[15:0]   | 0x4800 20E8      | dss_data6  |          | uart1_tx         |           | gpio_76  | hw_dbg14 |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA6[31:16]  | 0x4800 20E8      | dss_data7  |          | uart1_rx         |           | gpio_77  | hw_dbg15 |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA8[15:0]   | 0x4800 20EC      | dss_data8  |          | uart3_rx_irr_x   |           | gpio_78  | hw_dbg16 |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA8[31:16]  | 0x4800 20EC      | dss_data9  |          | uart3_tx_irr_x   |           | gpio_79  | hw_dbg17 |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA10[15:0]  | 0x4800 20F0      | dss_data10 |          |                  |           | gpio_80  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA10[31:16] | 0x4800 20F0      | dss_data11 |          |                  |           | gpio_81  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA12[15:0]  | 0x4800 20F4      | dss_data12 |          |                  |           | gpio_82  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA12[31:16] | 0x4800 20F4      | dss_data13 |          |                  |           | gpio_83  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA14[15:0]  | 0x4800 20F8      | dss_data14 |          |                  |           | gpio_84  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA14[31:16] | 0x4800 20F8      | dss_data15 |          |                  |           | gpio_85  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA16[15:0]  | 0x4800 20FC      | dss_data16 |          |                  |           | gpio_86  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA16[31:16] | 0x4800 20FC      | dss_data17 |          |                  |           | gpio_87  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA18[15:0]  | 0x4800 2100      | dss_data18 |          | mcspi3_clk       | dss_data0 | gpio_88  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA18[31:16] | 0x4800 2100      | dss_data19 |          | mcspi3_si_mo     | dss_data1 | gpio_89  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA20[15:0]  | 0x4800 2104      | dss_data20 |          | mcspi3_so_mi     | dss_data2 | gpio_90  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA20[31:16] | 0x4800 2104      | dss_data21 |          | mcspi3_cs_0      | dss_data3 | gpio_91  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA22[15:0]  | 0x4800 2108      | dss_data22 |          | mcspi3_cs_1      | dss_data4 | gpio_92  |          |       | safe_mode |
| CONTROL_PADCONF_DSS_DATA22[31:16] | 0x4800 2108      | dss_data23 |          |                  | dss_data5 | gpio_93  |          |       | safe_mode |
| CONTROL_PADCONF_CAM_HS[15:0]      | 0x4800 210C      | cam_hs     | Reserved |                  |           | gpio_94  | hw_dbg0  |       | safe_mode |
| CONTROL_PADCONF_CAM_HS[31:16]     | 0x4800 210C      | cam_vs     | Reserved |                  |           | gpio_95  | hw_dbg1  |       | safe_mode |
| CONTROL_PADCONF_CAM_XCLKA[15:0]   | 0x4800 2110      | cam_xclka  |          |                  |           | gpio_96  |          |       | safe_mode |
| CONTROL_PADCONF_CAM_XCLKA[31:16]  | 0x4800 2110      | cam_pclk   |          |                  |           | gpio_97  | hw_dbg2  |       | safe_mode |
| CONTROL_PADCONF_CAM_FLD[15:0]     | 0x4800 2114      | cam_fld    |          | cam_global_reset |           | gpio_98  | hw_dbg3  |       | safe_mode |
| CONTROL_PADCONF_CAM_FLD[31:16]    | 0x4800 2114      | cam_d0     |          | csi2_dx2         |           | gpio_99  |          |       | safe_mode |
| CONTROL_PADCONF_CAM_D1[15:0]      | 0x4800 2118      | cam_d1     |          | csi2_dy2         |           | gpio_100 |          |       | safe_mode |

**Table 13-4. Core Control Module Pad Configuration Register Fields (continued)**

| Register Name                     | Physical Address | Mode0       | Mode1    | Mode2       | Mode3 | Mode4    | Mode5    | Mode6 | Mode7     |
|-----------------------------------|------------------|-------------|----------|-------------|-------|----------|----------|-------|-----------|
| CONTROL_PADCONF_CAM_D1[31:16]     | 0x4800 2118      | cam_d2      | Reserved |             |       | gpio_101 | hw_dbg4  |       | safe_mode |
| CONTROL_PADCONF_CAM_D3[15:0]      | 0x4800 211C      | cam_d3      | Reserved |             |       | gpio_102 | hw_dbg5  |       | safe_mode |
| CONTROL_PADCONF_CAM_D3[31:16]     | 0x4800 211C      | cam_d4      | Reserved |             |       | gpio_103 | hw_dbg6  |       | safe_mode |
| CONTROL_PADCONF_CAM_D5[15:0]      | 0x4800 2120      | cam_d5      | Reserved |             |       | gpio_104 | hw_dbg7  |       | safe_mode |
| CONTROL_PADCONF_CAM_D5[31:16]     | 0x4800 2120      | cam_d6      |          |             |       | gpio_105 |          |       | safe_mode |
| CONTROL_PADCONF_CAM_D7[15:0]      | 0x4800 2124      | cam_d7      |          |             |       | gpio_106 |          |       | safe_mode |
| CONTROL_PADCONF_CAM_D7[31:16]     | 0x4800 2124      | cam_d8      |          |             |       | gpio_107 |          |       | safe_mode |
| CONTROL_PADCONF_CAM_D9[15:0]      | 0x4800 2128      | cam_d9      |          |             |       | gpio_108 |          |       | safe_mode |
| CONTROL_PADCONF_CAM_D9[31:16]     | 0x4800 2128      | cam_d10     | Reserved |             |       | gpio_109 | hw_dbg8  |       | safe_mode |
| CONTROL_PADCONF_CAM_D11[15:0]     | 0x4800 212C      | cam_d11     |          |             |       | gpio_110 | hw_dbg9  |       | safe_mode |
| CONTROL_PADCONF_CAM_D11[31:16]    | 0x4800 212C      | cam_xclk    |          |             |       | gpio_111 |          |       | safe_mode |
| CONTROL_PADCONF_CAM_WEN[15:0]     | 0x4800 2130      | cam_wen     |          | cam_shutter |       | gpio_167 | hw_dbg10 |       | safe_mode |
| CONTROL_PADCONF_CAM_WEN[31:16]    | 0x4800 2130      | cam_strobe  |          |             |       | gpio_126 | hw_dbg11 |       | safe_mode |
| CONTROL_PADCONF_CSI2_RX0[15:0]    | 0x4800 2134      | csi2_rx0    |          |             |       | gpio_112 |          |       | safe_mode |
| CONTROL_PADCONF_CSI2_RX0[31:16]   | 0x4800 2134      | csi2_dy0    |          |             |       | gpio_113 |          |       | safe_mode |
| CONTROL_PADCONF_CSI2_RX1[15:0]    | 0x4800 2138      | csi2_rx1    |          |             |       | gpio_114 |          |       | safe_mode |
| CONTROL_PADCONF_CSI2_RX1[31:16]   | 0x4800 2138      | csi2_dy1    |          |             |       | gpio_115 |          |       | safe_mode |
| CONTROL_PADCONF_MCBSP2_FSX[15:0]  | 0x4800 213C      | mcbsp2_fsx  |          |             |       | gpio_116 |          |       | safe_mode |
| CONTROL_PADCONF_MCBSP2_FSX[31:16] | 0x4800 213C      | mcbsp2_clk  |          |             |       | gpio_117 |          |       | safe_mode |
| CONTROL_PADCONF_MCBSP2_DR[15:0]   | 0x4800 2140      | mcbsp2_dr   |          |             |       | gpio_118 |          |       | safe_mode |
| CONTROL_PADCONF_MCBSP2_DR[31:16]  | 0x4800 2140      | mcbsp2_dx   |          |             |       | gpio_119 |          |       | safe_mode |
| CONTROL_PADCONF_MMC1_CLK[15:0]    | 0x4800 2144      | sdmmc1_clk  | Reserved |             |       | gpio_120 |          |       | safe_mode |
| CONTROL_PADCONF_MMC1_CLK[31:16]   | 0x4800 2144      | sdmmc1_cmd  | Reserved |             |       | gpio_121 |          |       | safe_mode |
| CONTROL_PADCONF_MMC1_DAT0[15:0]   | 0x4800 2148      | sdmmc1_dat0 | Reserved |             |       | gpio_122 |          |       | safe_mode |
| CONTROL_PADCONF_MMC1_DAT0[31:16]  | 0x4800 2148      | sdmmc1_dat1 | Reserved |             |       | gpio_123 |          |       | safe_mode |
| CONTROL_PADCONF_MMC1_DAT2[15:0]   | 0x4800 214C      | sdmmc1_dat2 | Reserved |             |       | gpio_124 |          |       | safe_mode |

**Table 13-4. Core Control Module Pad Configuration Register Fields (continued)**

| Register Name                      | Physical Address | Mode0       | Mode1            | Mode2            | Mode3       | Mode4    | Mode5            | Mode6     | Mode7     |
|------------------------------------|------------------|-------------|------------------|------------------|-------------|----------|------------------|-----------|-----------|
| CONTROL_PADCONF_MMC1_DAT2[31:16]   | 0x4800 214C      | sdmmc1_dat3 | Reserved         |                  |             | gpio_125 |                  |           | safe_mode |
| CONTROL_PADCONF_MMC2_CLK[15:0]     | 0x4800 2158      | sdmmc2_clk  | mcspi3_clk       |                  |             | gpio_130 |                  |           | safe_mode |
| CONTROL_PADCONF_MMC2_CLK[31:16]    | 0x4800 2158      | sdmmc2_cmd  | mcspi3_si_mo     |                  |             | gpio_131 |                  |           | safe_mode |
| CONTROL_PADCONF_MMC2_DAT0[15:0]    | 0x4800 215C      | sdmmc2_dat0 | mcspi3_somi      |                  |             | gpio_132 |                  |           | safe_mode |
| CONTROL_PADCONF_MMC2_DAT0[31:16]   | 0x4800 215C      | sdmmc2_dat1 |                  |                  |             | gpio_133 |                  |           | safe_mode |
| CONTROL_PADCONF_MMC2_DAT2[15:0]    | 0x4800 2160      | sdmmc2_dat2 | mcspi3_cs1       |                  |             | gpio_134 |                  |           | safe_mode |
| CONTROL_PADCONF_MMC2_DAT2[31:16]   | 0x4800 2160      | sdmmc2_dat3 | mcspi3_cs0       |                  |             | gpio_135 |                  |           | safe_mode |
| CONTROL_PADCONF_MMC2_DAT4[15:0]    | 0x4800 2164      | sdmmc2_dat4 | sdmmc2_diar_dat0 |                  | sdmmc3_dat0 | gpio_136 |                  |           | safe_mode |
| CONTROL_PADCONF_MMC2_DAT4[31:16]   | 0x4800 2164      | sdmmc2_dat5 | sdmmc2_diar_dat1 | cam_global_reset | sdmmc3_dat1 | gpio_137 | hsusb3_tll_stp   | mm3_rxrdp | safe_mode |
| CONTROL_PADCONF_MMC2_DAT6[15:0]    | 0x4800 2168      | sdmmc2_dat6 | sdmmc2_diar_cmd  | cam_shuttle      | sdmmc3_dat2 | gpio_138 | hsusb3_tll_dir   |           | safe_mode |
| CONTROL_PADCONF_MMC2_DAT6[31:16]   | 0x4800 2168      | sdmmc2_dat7 | sdmmc2_ckin      |                  | sdmmc3_dat3 | gpio_139 | hsusb3_tll_nxt   | mm3_rxrdm | safe_mode |
| CONTROL_PADCONF_MCBSP3_RX[15:0]    | 0x4800 216C      | mcbsp3_rx   | uart2_cts        |                  |             | gpio_140 | hsusb3_tll_data4 |           | safe_mode |
| CONTROL_PADCONF_MCBSP3_RX[31:16]   | 0x4800 216C      | mcbsp3_dr   | uart2_rts        |                  |             | gpio_141 | hsusb3_tll_data5 |           | safe_mode |
| CONTROL_PADCONF_MCBSP3_CLKX[15:0]  | 0x4800 2170      | mcbsp3_ckx  | uart2_tx         |                  |             | gpio_142 | hsusb3_tll_data6 |           | safe_mode |
| CONTROL_PADCONF_MCBSP3_CLKX[31:16] | 0x4800 2170      | mcbsp3_fx   | uart2_rx         |                  |             | gpio_143 | hsusb3_tll_data7 |           | safe_mode |
| CONTROL_PADCONF_UART2_CTS[15:0]    | 0x4800 2174      | uart2_cts   | mcbsp3_dx        | gpt_9_pwm_evt    |             | gpio_144 |                  |           | safe_mode |
| CONTROL_PADCONF_UART2_CTS[31:16]   | 0x4800 2174      | uart2_rts   | mcbsp3_dr        | gpt_10_pwm_evt   |             | gpio_145 |                  |           | safe_mode |
| CONTROL_PADCONF_UART2_TX[15:0]     | 0x4800 2178      | uart2_tx    | mcbsp3_ckx       | gpt_11_pwm_evt   |             | gpio_146 |                  |           | safe_mode |
| CONTROL_PADCONF_UART2_TX[31:16]    | 0x4800 2178      | uart2_rx    | mcbsp3_fx        | gpt_8_pwm_evt    |             | gpio_147 |                  |           | safe_mode |
| CONTROL_PADCONF_UART1_TX[15:0]     | 0x4800 217C      | uart1_tx    | Reserved         |                  |             | gpio_148 |                  |           | safe_mode |

**Table 13-4. Core Control Module Pad Configuration Register Fields (continued)**

| Register Name                        | Physical Address | Mode0          | Mode1        | Mode2            | Mode3       | Mode4    | Mode5            | Mode6      | Mode7     |
|--------------------------------------|------------------|----------------|--------------|------------------|-------------|----------|------------------|------------|-----------|
| CONTROL_PADCONF_UART1_TX[31:16]      | 0x4800 217C      | uart1_rts      | Reserved     |                  |             | gpio_149 |                  |            | safe_mode |
| CONTROL_PADCONF_UART1_CTS[15:0]      | 0x4800 2180      | uart1_cts      | Reserved     |                  |             | gpio_150 | hsusb3_tll_clk   |            | safe_mode |
| CONTROL_PADCONF_UART1_CTS[31:16]     | 0x4800 2180      | uart1_rx       |              | mcbsp1_clk       | mcsipi4_clk | gpio_151 |                  |            | safe_mode |
| CONTROL_PADCONF_MCBSP4_CLKX[15:0]    | 0x4800 2184      | mcbsp4_clk     | Reserved     |                  |             | gpio_152 | hsusb3_tll_data1 | mm3_txse0  | safe_mode |
| CONTROL_PADCONF_MCBSP4_CLKX[31:16]   | 0x4800 2184      | mcbsp4_dr      | Reserved     |                  |             | gpio_153 | hsusb3_tll_data0 | mm3_rxrcv  | safe_mode |
| CONTROL_PADCONF_MCBSP4_DX[15:0]      | 0x4800 2188      | mcbsp4_dx      | Reserved     |                  |             | gpio_154 | hsusb3_tll_data2 | mm3_txdat  | safe_mode |
| CONTROL_PADCONF_MCBSP4_DX[31:16]     | 0x4800 2188      | mcbsp4_fx      | Reserved     |                  |             | gpio_155 | hsusb3_tll_data3 | mm3_txen_n | safe_mode |
| CONTROL_PADCONF_MCBSP1_CLKR[15:0]    | 0x4800 218C      | mcbsp1_clk     | mcsipi4_clk  | Reserved         |             | gpio_156 |                  |            | safe_mode |
| CONTROL_PADCONF_MCBSP1_CLKR[31:16]   | 0x4800 218C      | mcbsp1_fsr     |              | cam_global_reset |             | gpio_157 |                  |            | safe_mode |
| CONTROL_PADCONF_MCBSP1_RX[15:0]      | 0x4800 2190      | mcbsp1_dx      | mcsipi4_si   | mcbsp3_dx        |             | gpio_158 |                  |            | safe_mode |
| CONTROL_PADCONF_MCBSP1_RX[31:16]     | 0x4800 2190      | mcbsp1_dr      | mcsipi4_somi | mcbsp3_dr        |             | gpio_159 |                  |            | safe_mode |
| CONTROL_PADCONF_MCBSP_CLKS[15:0]     | 0x4800 2194      | mcbsp_clk      |              | cam_shutter      |             | gpio_160 | uart1_cts        |            | safe_mode |
| CONTROL_PADCONF_MCBSP_CLKS[31:16]    | 0x4800 2194      | mcbsp_fx       | mcsipi4_cs   | mcbsp3_fx        |             | gpio_161 |                  |            | safe_mode |
| CONTROL_PADCONF_MCBSP1_CLKX[15:0]    | 0x4800 2198      | mcbsp1_clk     |              | mcbsp3_clk       |             | gpio_162 |                  |            | safe_mode |
| CONTROL_PADCONF_MCBSP1_CLKX[31:16]   | 0x4800 2198      | uart3_cts_rctx |              |                  |             | gpio_163 |                  |            | safe_mode |
| CONTROL_PADCONF_UART3_RTS_SD[15:0]   | 0x4800 219C      | uart3_rts_sd   |              |                  |             | gpio_164 |                  |            | safe_mode |
| CONTROL_PADCONF_UART3_RTS_SD[31:16]  | 0x4800 219C      | uart3_rx_irrx  |              |                  |             | gpio_165 |                  |            | safe_mode |
| CONTROL_PADCONF_UART3_TX_IRTX[15:0]  | 0x4800 21A0      | uart3_tx_irtx  |              |                  |             | gpio_166 |                  |            | safe_mode |
| CONTROL_PADCONF_UART3_TX_IRTX[31:16] | 0x4800 21A0      | hsusb0_clk     |              |                  |             | gpio_120 |                  |            | safe_mode |
| CONTROL_PADCONF_HSUSB0_STP[15:0]     | 0x4800 21A4      | hsusb0_stp     |              |                  |             | gpio_121 |                  |            | safe_mode |
| CONTROL_PADCONF_HSUSB0_STP[31:16]    | 0x4800 21A4      | hsusb0_dir     |              |                  |             | gpio_122 |                  |            | safe_mode |

**Table 13-4. Core Control Module Pad Configuration Register Fields (continued)**

| Register Name                       | Physical Address | Mode0         | Mode1       | Mode2            | Mode3        | Mode4    | Mode5     | Mode6 | Mode7     |
|-------------------------------------|------------------|---------------|-------------|------------------|--------------|----------|-----------|-------|-----------|
| CONTROL_PADCONF_HSUSB0_NXT[15:0]    | 0x4800 21A8      | hsusb0_nxt    |             |                  | gpio_124     |          |           |       | safe_mode |
| CONTROL_PADCONF_HSUSB0_NXT[31:16]   | 0x4800 21A8      | hsusb0_dat_a0 |             | uart3_tx_irtx    |              | gpio_125 | uart2_tx  |       | safe_mode |
| CONTROL_PADCONF_HSUSB0_DATA1[15:0]  | 0x4800 21AC      | hsusb0_dat_a1 |             | uart3_rx_irrx    |              | gpio_130 | uart2_rx  |       | safe_mode |
| CONTROL_PADCONF_HSUSB0_DATA1[31:16] | 0x4800 21AC      | hsusb0_dat_a2 |             | uart3_rts_sd     |              | gpio_131 | uart2_rts |       | safe_mode |
| CONTROL_PADCONF_HSUSB0_DATA3[15:0]  | 0x4800 21B0      | hsusb0_dat_a3 |             | uart3_cts_rctx   |              | gpio_169 | uart2_cts |       | safe_mode |
| CONTROL_PADCONF_HSUSB0_DATA3[31:16] | 0x4800 21B0      | hsusb0_dat_a4 |             |                  |              | gpio_188 |           |       | safe_mode |
| CONTROL_PADCONF_HSUSB0_DATA5[15:0]  | 0x4800 21B4      | hsusb0_dat_a5 |             |                  |              | gpio_189 |           |       | safe_mode |
| CONTROL_PADCONF_HSUSB0_DATA5[31:16] | 0x4800 21B4      | hsusb0_dat_a6 |             |                  |              | gpio_190 |           |       | safe_mode |
| CONTROL_PADCONF_HSUSB0_DATA7[15:0]  | 0x4800 21B8      | hsusb0_dat_a7 |             |                  |              | gpio_191 |           |       | safe_mode |
| CONTROL_PADCONF_HSUSB0_DATA7[31:16] | 0x4800 21B8      | i2c1_scl      |             |                  |              |          |           |       |           |
| CONTROL_PADCONF_I2C1_SDA[15:0]      | 0x4800 21BC      | i2c1_sda      |             |                  |              |          |           |       |           |
| CONTROL_PADCONF_I2C1_SDA[31:16]     | 0x4800 21BC      | i2c2_scl      |             |                  |              | gpio_168 |           |       | safe_mode |
| CONTROL_PADCONF_I2C2_SDA[15:0]      | 0x4800 21C0      | i2c2_sda      |             |                  |              | gpio_183 |           |       | safe_mode |
| CONTROL_PADCONF_I2C2_SDA[31:16]     | 0x4800 21C0      | i2c3_scl      |             |                  |              | gpio_184 |           |       | safe_mode |
| CONTROL_PADCONF_I2C3_SDA[15:0]      | 0x4800 21C4      | i2c3_sda      |             |                  |              | gpio_185 |           |       | safe_mode |
| CONTROL_PADCONF_I2C3_SDA[31:16]     | 0x4800 21C4      | hdq_sio       | sys_altclk  | i2c2_sccbe       | i2c3_sccbe   | gpio_170 |           |       | safe_mode |
| CONTROL_PADCONF_MCSPI1_CLK[15:0]    | 0x4800 21C8      | mcspi1_clk    | sdmmc2_dat4 |                  |              | gpio_171 |           |       | safe_mode |
| CONTROL_PADCONF_MCSPI1_CLK[31:16]   | 0x4800 21C8      | mcspi1_si_mo  | sdmmc2_dat5 |                  |              | gpio_172 |           |       | safe_mode |
| CONTROL_PADCONF_MCSPI1_SOMI[15:0]   | 0x4800 21CC      | mcspi1_so_mi  | sdmmc2_dat6 |                  |              | gpio_173 |           |       | safe_mode |
| CONTROL_PADCONF_MCSPI1_SOMI[31:16]  | 0x4800 21CC      | mcspi1_cs0    | sdmmc2_dat7 |                  |              | gpio_174 |           |       | safe_mode |
| CONTROL_PADCONF_MCSPI1_CS1[15:0]    | 0x4800 21D0      | mcspi1_cs1    |             |                  | sdmmc3_crd   | gpio_175 |           |       | safe_mode |
| CONTROL_PADCONF_MCSPI1_CS1[31:16]   | 0x4800 21D0      | mcspi1_cs2    |             |                  | sdmmc3_clk   | gpio_176 |           |       | safe_mode |
| CONTROL_PADCONF_MCSPI1_CS3[15:0]    | 0x4800 21D4      | mcspi1_cs3    |             | hsusb2_tll_data2 | hsusb2_data2 | gpio_177 | mm2_txdat |       | safe_mode |

**Table 13-4. Core Control Module Pad Configuration Register Fields (continued)**

| Register Name                         | Physical Address | Mode0        | Mode1          | Mode2            | Mode3        | Mode4    | Mode5      | Mode6 | Mode7                         |
|---------------------------------------|------------------|--------------|----------------|------------------|--------------|----------|------------|-------|-------------------------------|
| CONTROL_PADCONF_MCSPI1_CS3[31:16]     | 0x4800 21D4      | mcspi2_clk   |                | hsusb2_tll_data7 | hsusb2_data7 | gpio_178 |            |       | safe_mode                     |
| CONTROL_PADCONF_MCSPI2_SIMO[15:0]     | 0x4800 21D8      | mcspi2_si_mo | gpt_9_pwm_evt  | hsusb2_tll_data4 | hsusb2_data4 | gpio_179 |            |       | safe_mode                     |
| CONTROL_PADCONF_MCSPI2_SIMO[31:16]    | 0x4800 21D8      | mcspi2_somi  | gpt_10_pwm_evt | hsusb2_tll_data5 | hsusb2_data5 | gpio_180 |            |       | safe_mode                     |
| CONTROL_PADCONF_MCSPI2_CS0[15:0]      | 0x4800 21DC      | mcspi2_cs0   | gpt_11_pwm_evt | hsusb2_tll_data6 | hsusb2_data6 | gpio_181 |            |       | safe_mode                     |
| CONTROL_PADCONF_MCSPI2_CS0[31:16]     | 0x4800 21DC      | mcspi2_cs1   | gpt_8_pwm_evt  | hsusb2_tll_data3 | hsusb2_data3 | gpio_182 | mm2_txen_n |       | safe_mode                     |
| CONTROL_PADCONF_SYS_NIRQ[15:0]        | 0x4800 21E0      | sys_nirq     |                |                  |              | gpio_0   |            |       | safe_mode                     |
| CONTROL_PADCONF_SYS_NIRQ[31:16]       | 0x4800 21E0      | sys_clkout2  |                |                  |              | gpio_186 |            |       | safe_mode                     |
| CONTROL_PADCONF_SAD2D_SBUSFLAG[31:16] | 0x4800 2260      | sdrc_cke0    |                |                  |              |          |            |       | safe_mode_out1 <sup>(1)</sup> |
| CONTROL_PADCONF_SDRC_CKE1[15:0]       | 0x4800 2264      | sdrc_cke1    |                |                  |              |          |            |       | safe_mode_out1                |
| CONTROL_PADCONF_SDRC_CKE1[31:16]      | 0x4800 2264      | gpmc_a11     |                |                  |              |          |            |       | safe_mode                     |
| CONTROL_PADCONF_SDRC_BA0[15:0]        | 0x4800 25A0      | sdrc_ba0     |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_BA0[31:16]       | 0x4800 25A0      | sdrc_ba1     |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A0[15:0]         | 0x4800 25A4      | sdrc_a0      |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A0[31:16]        | 0x4800 25A4      | sdrc_a1      |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A2[15:0]         | 0x4800 25A8      | sdrc_a2      |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A2[31:16]        | 0x4800 25A8      | sdrc_a3      |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A4[15:0]         | 0x4800 25AC      | sdrc_a4      |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A4[31:16]        | 0x4800 25AC      | sdrc_a5      |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A6[15:0]         | 0x4800 25B0      | sdrc_a6      |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A6[31:16]        | 0x4800 25B0      | sdrc_a7      |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A8[15:0]         | 0x4800 25B4      | sdrc_a8      |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A8[31:16]        | 0x4800 25B4      | sdrc_a9      |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A10[15:0]        | 0x4800 25B8      | sdrc_a10     |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A10[31:16]       | 0x4800 25B8      | sdrc_a11     |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A12[15:0]        | 0x4800 25BC      | sdrc_a12     |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A12[31:16]       | 0x4800 25BC      | sdrc_a13     |                |                  |              |          |            |       |                               |
| CONTROL_PADCONF_SDRC_A14[15:0]        | 0x4800 25C0      | sdrc_a14     |                |                  |              |          |            |       |                               |

<sup>(1)</sup> Pad initialized as an output in this specific safe mode implementation (buffer in output mode, drive 1).

**Table 13-4. Core Control Module Pad Configuration Register Fields (continued)**

| Register Name                    | Physical Address | Mode0     | Mode1                       | Mode2        | Mode3        | Mode4   | Mode5      | Mode6            | Mode7    |
|----------------------------------|------------------|-----------|-----------------------------|--------------|--------------|---------|------------|------------------|----------|
| CONTROL_PADCONF_SDRC_A14[31:16]  | 0x4800 25C0      | sdrc_ncs0 |                             |              |              |         |            |                  |          |
| CONTROL_PADCONF_SDRC_NCS1[15:0]  | 0x4800 25C4      | sdrc_ncs1 |                             |              |              |         |            |                  |          |
| CONTROL_PADCONF_SDRC_NCS1[31:16] | 0x4800 25C4      | sdrc_nclk |                             |              |              |         |            |                  |          |
| CONTROL_PADCONF_SDRC_NRAS[15:0]  | 0x4800 25C8      | sdrc_nrás |                             |              |              |         |            |                  |          |
| CONTROL_PADCONF_SDRC_NRAS[31:16] | 0x4800 25C8      | sdrc_ncas |                             |              |              |         |            |                  |          |
| CONTROL_PADCONF_SDRC_NWE[15:0]   | 0x4800 25CC      | sdrc_nwe  |                             |              |              |         |            |                  |          |
| CONTROL_PADCONF_SDRC_NWE[31:16]  | 0x4800 25CC      | sdrc_dm0  |                             |              |              |         |            |                  |          |
| CONTROL_PADCONF_SDRC_DM1[15:0]   | 0x4800 25D0      | sdrc_dm1  |                             |              |              |         |            |                  |          |
| CONTROL_PADCONF_SDRC_DM1[31:16]  | 0x4800 25D0      | sdrc_dm2  |                             |              |              |         |            |                  |          |
| CONTROL_PADCONF_SDRC_DM3[15:0]   | 0x4800 25D4      | sdrc_dm3  |                             |              |              |         |            |                  |          |
| CONTROL_PADCONF_SDRC_DM3[31:16]  | 0x4800 25D4      |           |                             |              |              |         |            |                  |          |
| CONTROL_PADCONF_ETK_CLK[15:0]    | 0x4800 25D8      | etk_clk   | mcbsp5_ckx                  | sdmmc3_ck    | hsusb1_stp   | gpio_12 | mm1_rxdp   | hsusb1_tll_stp   | hw_dbg0  |
| CONTROL_PADCONF_ETK_CLK[31:16]   | 0x4800 25D8      | etk_ctl   |                             | sdmmc3_c_md  | hsusb1_clk   | gpio_13 |            | hsusb1_tll_clk   | hw_dbg1  |
| CONTROL_PADCONF_ETK_D0[15:0]     | 0x4800 25DC      | etk_d0    | mcsipi3_si_mo               | sdmmc3_data4 | hsusb1_data0 | gpio_14 | mm1_rxrcv  | hsusb1_tll_data0 | hw_dbg2  |
| CONTROL_PADCONF_ETK_D0[31:16]    | 0x4800 25DC      | etk_d1    | mcsipi3_somi                |              | hsusb1_data1 | gpio_15 | mm1_txse0  | hsusb1_tll_data1 | hw_dbg3  |
| CONTROL_PADCONF_ETK_D2[15:0]     | 0x4800 25E0      | etk_d2    | mcsipi3_cs0                 |              | hsusb1_data2 | gpio_16 | mm1_txdat  | hsusb1_tll_data2 | hw_dbg4  |
| CONTROL_PADCONF_ETK_D2[31:16]    | 0x4800 25E0      | etk_d3    | mcsipi3_clk                 | sdmmc3_data3 | hsusb1_data7 | gpio_17 |            | hsusb1_tll_data7 | hw_dbg5  |
| CONTROL_PADCONF_ETK_D4[15:0]     | 0x4800 25E4      | etk_d4    | mcbsp5_dr                   | sdmmc3_data0 | hsusb1_data4 | gpio_18 |            | hsusb1_tll_data4 | hw_dbg6  |
| CONTROL_PADCONF_ETK_D4[31:16]    | 0x4800 25E4      | etk_d5    | mcbsp5_fx                   | sdmmc3_data1 | hsusb1_data5 | gpio_19 |            | hsusb1_tll_data5 | hw_dbg7  |
| CONTROL_PADCONF_ETK_D6[15:0]     | 0x4800 25E8      | etk_d6    | mcbsp5_dx                   | sdmmc3_data2 | hsusb1_data6 | gpio_20 |            | hsusb1_tll_data6 | hw_dbg8  |
| CONTROL_PADCONF_ETK_D6[31:16]    | 0x4800 25E8      | etk_d7    | mcsipi3_cs1                 | sdmmc3_data7 | hsusb1_data3 | gpio_21 | mm1_txen_n | hsusb1_tll_data3 | hw_dbg9  |
| CONTROL_PADCONF_ETK_D8[15:0]     | 0x4800 25EC      | etk_d8    | Reserved for Non-GP devices | sdmmc3_data6 | hsusb1_dir   | gpio_22 |            | hsusb1_tll_dir   | hw_dbg10 |
| CONTROL_PADCONF_ETK_D8[31:16]    | 0x4800 25EC      | etk_d9    | Reserved for Non-GP devices | sdmmc3_data5 | hsusb1_nxt   | gpio_23 | mm1_rxdm   | hsusb1_tll_nxt   | hw_dbg11 |

**Table 13-4. Core Control Module Pad Configuration Register Fields (continued)**

| Register Name                  | Physical Address | Mode0   | Mode1                       | Mode2    | Mode3        | Mode4   | Mode5     | Mode6            | Mode7    |
|--------------------------------|------------------|---------|-----------------------------|----------|--------------|---------|-----------|------------------|----------|
| CONTROL_PADCONF_ETK_D10[15:0]  | 0x4800 25F0      | etk_d10 |                             | uart1_rx | hsusb2_clk   | gpio_24 |           | hsusb2_tll_clk   | hw_dbg12 |
| CONTROL_PADCONF_ETK_D10[31:16] | 0x4800 25F0      | etk_d11 |                             |          | hsusb2_stp   | gpio_25 | mm2_rxrdp | hsusb2_tll_stp   | hw_dbg13 |
| CONTROL_PADCONF_ETK_D12[15:0]  | 0x4800 25F4      | etk_d12 | Reserved for Non-GP devices |          | hsusb2_dir   | gpio_26 |           | hsusb2_tll_dir   | hw_dbg14 |
| CONTROL_PADCONF_ETK_D12[31:16] | 0x4800 25F4      | etk_d13 |                             |          | hsusb2_nxt   | gpio_27 | mm2_rxrdm | hsusb2_tll_nxt   | hw_dbg15 |
| CONTROL_PADCONF_ETK_D14[15:0]  | 0x4800 25F8      | etk_d14 |                             |          | hsusb2_data0 | gpio_28 | mm2_rxrcv | hsusb2_tll_data0 | hw_dbg16 |
| CONTROL_PADCONF_ETK_D14[31:16] | 0x4800 25F8      | etk_d15 |                             |          | hsusb2_data1 | gpio_29 | mm2_txse0 | hsusb2_tll_data1 | hw_dbg17 |

**Table 13-5. Core Control Module D2D Pad Configuration Register Fields**

| Register Name                      | Physical Address | Mode0        | Mode1        | Mode2 | Mode3 | Mode4 | Mode5 | Mode6 | Mode7 |
|------------------------------------|------------------|--------------|--------------|-------|-------|-------|-------|-------|-------|
| CONTROL_PADCONF_SAD2D_MCAD0[15:0]  | 0x4800 21E4      | sad2d_mcad0  | mad2d_mcad0  |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD0[31:16] | 0x4800 21E4      | sad2d_mcad1  | mad2d_mcad1  |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD2[15:0]  | 0x4800 21E8      | sad2d_mcad2  | mad2d_mcad2  |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD2[31:16] | 0x4800 21E8      | sad2d_mcad3  | mad2d_mcad3  |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD4[15:0]  | 0x4800 21EC      | sad2d_mcad4  | mad2d_mcad4  |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD4[31:16] | 0x4800 21EC      | sad2d_mcad5  | mad2d_mcad5  |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD6[15:0]  | 0x4800 21F0      | sad2d_mcad6  | mad2d_mcad6  |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD6[31:16] | 0x4800 21F0      | sad2d_mcad7  | mad2d_mcad7  |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD8[15:0]  | 0x4800 21F4      | sad2d_mcad8  | mad2d_mcad8  |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD8[31:16] | 0x4800 21F4      | sad2d_mcad9  | mad2d_mcad9  |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD10[15:0] | 0x4800 21F8      | sad2d_mcad10 | mad2d_mcad10 |       |       |       |       |       |       |

**Table 13-5. Core Control Module D2D Pad Configuration Register Fields (continued)**

| Register Name                       | Physical Address | Mode0        | Mode1        | Mode2 | Mode3 | Mode4 | Mode5 | Mode6 | Mode7 |
|-------------------------------------|------------------|--------------|--------------|-------|-------|-------|-------|-------|-------|
| CONTROL_PADCONF_SAD2D_MCAD10[31:16] | 0x4800 21F8      | sad2d_mcad11 | mad2d_mcad11 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD12[15:0]  | 0x4800 21FC      | sad2d_mcad12 | mad2d_mcad12 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD12[31:16] | 0x4800 21FC      | sad2d_mcad13 | mad2d_mcad13 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD14[15:0]  | 0x4800 2200      | sad2d_mcad14 | mad2d_mcad14 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD14[31:16] | 0x4800 2200      | sad2d_mcad15 | mad2d_mcad15 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD16[15:0]  | 0x4800 2204      | sad2d_mcad16 | mad2d_mcad16 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD16[31:16] | 0x4800 2204      | sad2d_mcad17 | mad2d_mcad17 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD18[15:0]  | 0x4800 2208      | sad2d_mcad18 | mad2d_mcad18 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD18[31:16] | 0x4800 2208      | sad2d_mcad19 | mad2d_mcad19 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD20[15:0]  | 0x4800 220C      | sad2d_mcad20 | mad2d_mcad20 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD20[31:16] | 0x4800 220C      | sad2d_mcad21 | mad2d_mcad21 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD22[15:0]  | 0x4800 2210      | sad2d_mcad22 | mad2d_mcad22 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD22[31:16] | 0x4800 2210      | sad2d_mcad23 | mad2d_mcad23 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD24[15:0]  | 0x4800 2214      | sad2d_mcad24 | mad2d_mcad24 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD24[31:16] | 0x4800 2214      | sad2d_mcad25 | mad2d_mcad25 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD26[15:0]  | 0x4800 2218      | sad2d_mcad26 | mad2d_mcad26 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD26[31:16] | 0x4800 2218      | sad2d_mcad27 | mad2d_mcad27 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD28[15:0]  | 0x4800 221C      | sad2d_mcad28 | mad2d_mcad28 |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD28[31:16] | 0x4800 221C      | sad2d_mcad29 | mad2d_mcad29 |       |       |       |       |       |       |

**Table 13-5. Core Control Module D2D Pad Configuration Register Fields (continued)**

| Register Name                          | Physical Address | Mode0             | Mode1        | Mode2        | Mode3         | Mode4    | Mode5 | Mode6 | Mode7 |
|----------------------------------------|------------------|-------------------|--------------|--------------|---------------|----------|-------|-------|-------|
| CONTROL_PADCONF_SAD2D_MCAD30[15:0]     | 0x4800 2220      | sad2d_mcad30      | mad2d_mcad30 |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD30[31:16]    | 0x4800 2220      | sad2d_mcad31      | mad2d_mcad31 |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD32[15:0]     | 0x4800 2224      | sad2d_mcad32      | mad2d_mcad32 |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD32[31:16]    | 0x4800 2224      | sad2d_mcad33      | mad2d_mcad33 |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD34[15:0]     | 0x4800 2228      | sad2d_mcad34      | mad2d_mcad34 |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD34[31:16]    | 0x4800 2228      | sad2d_mcad35      | mad2d_mcad35 |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD36[15:0]     | 0x4800 222C      | sad2d_mcad36      | mad2d_mcad36 |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_MCAD36[31:16]    | 0x4800 222C      | chassis_clk26mi   |              |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_NRESPWRON[15:0]  | 0x4800 2230      | chassis_nrespwron |              |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_NRESPWRON[31:16] | 0x4800 2230      | chassis_nreswarm  |              |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_ARMNIRQ[15:0]    | 0x4800 2234      | chassis_nirq      |              |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_ARMNIRQ[31:16]   | 0x4800 2234      | chassis_fiq       |              |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_SPINT[15:0]      | 0x4800 2238      | chassis_armirq    |              |              |               | gpio_32  |       |       |       |
| CONTROL_PADCONF_SAD2D_SPINT[31:16]     | 0x4800 2238      | chassis_ivairq    |              |              |               | gpio_187 |       |       |       |
| CONTROL_PADCONF_SAD2D_DMAREQ0[15:0]    | 0x4800 223C      | chassis_dmareq0   |              | uart2_dma_tx | sdmmc1_dma_tx |          |       |       |       |
| CONTROL_PADCONF_SAD2D_DMAREQ0[31:16]   | 0x4800 223C      | chassis_dmareq1   |              | uart2_dma_rx | sdmmc1_dma_rx |          |       |       |       |
| CONTROL_PADCONF_SAD2D_DMAREQ2[15:0]    | 0x4800 2240      | chassis_dmareq2   | uart1_dma_tx |              | uart3_dma_tx  |          |       |       |       |
| CONTROL_PADCONF_SAD2D_DMAREQ2[31:16]   | 0x4800 2240      | chassis_dmareq3   | uart1_dma_rx |              | uart3_dma_rx  |          |       |       |       |
| CONTROL_PADCONF_SAD2D_NTRST[15:0]      | 0x4800 2244      | chassis_ntrst     |              |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_NTRST[31:16]     | 0x4800 2244      | chassis_tdi       |              |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_TDO[15:0]        | 0x4800 2248      | chassis_tdo       |              |              |               |          |       |       |       |
| CONTROL_PADCONF_SAD2D_TDO[31:16]       | 0x4800 2248      | chassis_tms       |              |              |               |          |       |       |       |

**Table 13-5. Core Control Module D2D Pad Configuration Register Fields (continued)**

| Register Name                        | Physical Address | Mode0               | Mode1              | Mode2 | Mode3 | Mode4 | Mode5 | Mode6 | Mode7 |
|--------------------------------------|------------------|---------------------|--------------------|-------|-------|-------|-------|-------|-------|
| CONTROL_PADCONF_SAD2D_TCK[15:0]      | 0x4800 224C      | chassis_tck         |                    |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_TCK[31:16]     | 0x4800 224C      | chassis_rtck        |                    |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MSTDBY[15:0]   | 0x4800 2250      | chassis_mst<br>dby  |                    |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_MSTDBY[31:16]  | 0x4800 2250      | chassis_idler<br>eq |                    |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_IDLEACK[15:0]  | 0x4800 2254      | chassis_idleack     |                    |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_IDLEACK[31:16] | 0x4800 2254      | sad2d_mwrit<br>e    | mad2d_swrit<br>e   |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_SWRITE[15:0]   | 0x4800 2258      | sad2d_swrite        | mad2d_mw<br>rite   |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_SWRITE[31:16]  | 0x4800 2258      | sad2d_mrea<br>d     | mad2d_sre<br>ad    |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_SREAD[15:0]    | 0x4800 225C      | sad2d_sread         | mad2d_mr<br>ead    |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_SREAD[31:16]   | 0x4800 225C      | sad2d_mbustf<br>lag | mad2d_sb<br>usflag |       |       |       |       |       |       |
| CONTROL_PADCONF_SAD2D_SBUSFLAG[15:0] | 0x4800 2260      | sad2d_sbusfl<br>ag  | mad2d_mb<br>usflag |       |       |       |       |       |       |

**CAUTION**

The D2D and CHASSIS pads are used only in stacked mode.

Do not modify the D2D/CHASSIS registers in standalone mode. This is dangerous for the device pads.

**Table 13-6. Wkup Control Module Pad Configuration Register Fields**

| Register Name                          | Physical Address | Mode0        | Mode1       | Mode2 | Mode3 | Mode4   | Mode5 | Mode6 | Mode7     |
|----------------------------------------|------------------|--------------|-------------|-------|-------|---------|-------|-------|-----------|
| CONTROL_PADCONF_I2C4_SCL[15:0]         | 0x4800 2A00      | i2c4_scl     | sys_nvmode1 |       |       |         |       |       | safe_mode |
| CONTROL_PADCONF_I2C4_SCL[31:16]        | 0x4800 2A00      | i2c4_sda     | sys_nvmode2 |       |       |         |       |       | safe_mode |
| CONTROL_PADCONF_SYS_32K[15:0]          | 0x4800 2A04      | sys_32k      |             |       |       |         |       |       |           |
| CONTROL_PADCONF_SYS_32K[31:16]         | 0x4800 2A04      | sys_clkreq   |             |       |       | gpio_1  |       |       | safe_mode |
| CONTROL_PADCONF_SYS_NRESWAR<br>M[15:0] | 0x4800 2A08      | sys_nreswarm |             |       |       | gpio_30 |       |       | safe_mode |

**Table 13-6. Wkup Control Module Pad Configuration Register Fields (continued)**

| Register Name                           | Physical Address | Mode0           | Mode1           | Mode2 | Mode3      | Mode4    | Mode5 | Mode6 | Mode7     |
|-----------------------------------------|------------------|-----------------|-----------------|-------|------------|----------|-------|-------|-----------|
| CONTROL_PADCONF_SYS_NRESWAR_M[31:16]    | 0x4800 2A08      | sys_boot0       |                 |       | dss_data18 | gpio_2   |       |       | safe_mode |
| CONTROL_PADCONF_SYS_BOOT1[15:0]         | 0x4800 2A0C      | sys_boot1       |                 |       | dss_data19 | gpio_3   |       |       | safe_mode |
| CONTROL_PADCONF_SYS_BOOT1[31:16]        | 0x4800 2A0C      | sys_boot2       |                 |       |            | gpio_4   |       |       | safe_mode |
| CONTROL_PADCONF_SYS_BOOT3[15:0]         | 0x4800 2A10      | sys_boot3       |                 |       | dss_data20 | gpio_5   |       |       | safe_mode |
| CONTROL_PADCONF_SYS_BOOT3[31:16]        | 0x4800 2A10      | sys_boot4       | sdmmc2_dir_dat2 |       | dss_data21 | gpio_6   |       |       | safe_mode |
| CONTROL_PADCONF_SYS_BOOT5[15:0]         | 0x4800 2A14      | sys_boot5       | sdmmc2_dir_dat3 |       | dss_data22 | gpio_7   |       |       | safe_mode |
| CONTROL_PADCONF_SYS_BOOT5[31:16]        | 0x4800 2A14      | sys_boot6       |                 |       | dss_data23 | gpio_8   |       |       | safe_mode |
| CONTROL_PADCONF_SYS_OFF_MODE[15:0]      | 0x4800 2A18      | sys_off_mode    |                 |       |            | gpio_9   |       |       | safe_mode |
| CONTROL_PADCONF_SYS_OFF_MODE[31:16]     | 0x4800 2A18      | sys_clkout1     |                 |       |            | gpio_10  |       |       | safe_mode |
| CONTROL_PADCONF_JTAG_NTRST[15:0]        | 0x4800 2A1C      | jtag_ntrst      |                 |       |            |          |       |       |           |
| CONTROL_PADCONF_JTAG_NTRST[31:16]       | 0x4800 2A1C      | jtag_tck        |                 |       |            |          |       |       |           |
| CONTROL_PADCONF_JTAG_TMS_TMS_C[15:0]    | 0x4800 2A20      | jtag_tms_tmsc   |                 |       |            |          |       |       |           |
| CONTROL_PADCONF_JTAG_TMS_TMS_C[31:16]   | 0x4800 2A20      | jtag_tdi        |                 |       |            |          |       |       |           |
| CONTROL_PADCONF_JTAG_EMU0[15:0]         | 0x4800 2A24      | jtag_emu0       |                 |       |            | gpio_11  |       |       | safe_mode |
| CONTROL_PADCONF_JTAG_EMU0[31:16]        | 0x4800 2A24      | jtag_emu1       |                 |       |            | gpio_31  |       |       | safe_mode |
| CONTROL_PADCONF_CHASSIS_SWAK_EUP[15:0]  | 0x4800 2A4C      | chassis_swakeup |                 |       |            |          |       |       |           |
| CONTROL_PADCONF_CHASSIS_SWAK_EUP[31:16] | 0x4800 2A4C      | jtag_rtck       |                 |       |            |          |       |       |           |
| CONTROL_PADCONF_JTAG_TDO[15:0]          | 0x4800 2A50      | jtag_tdo        |                 |       |            |          |       |       |           |
| CONTROL_PADCONF_JTAG_TDO[31:16]         | 0x4800 2A50      |                 |                 |       |            |          |       |       |           |
| CONTROL_PADCONF_GPIO127[15:0]           | 0x4800 2A54      | Reserved        |                 |       |            | gpio_127 |       |       | safe_mode |
| CONTROL_PADCONF_GPIO127[31:16]          | 0x4800 2A54      | Reserved        | Reserved        |       |            | gpio_126 |       |       | safe_mode |

**Table 13-6. Wkup Control Module Pad Configuration Register Fields (continued)**

| Register Name                  | Physical Address | Mode0    | Mode1 | Mode2 | Mode3 | Mode4    | Mode5 | Mode6 | Mode7     |
|--------------------------------|------------------|----------|-------|-------|-------|----------|-------|-------|-----------|
| CONTROL_PADCONF_GPIO128[15:0]  | 0x4800 2A58      | Reserved |       |       |       | gpio_128 |       |       | safe_mode |
| CONTROL_PADCONF_GPIO128[31:16] | 0x4800 2A58      | Reserved |       |       |       | gpio_129 |       |       | safe_mode |

**NOTE:** For proper functioning of the following modules, CONTROL\_PADCONF\_x.INPUTENABLE must be set to 1 for pads configured to drive output clocks:

- SDRC
- GPMC
- McSPII
- I2Ci
- MMCI
- McBSPi
- HSUSB HOST

**NOTE:** Pad names are signal names available in mode 0.

#### 13.4.4.4 System Off Mode

When system off mode is active (`SYS_OFF_MODE` = 0b1 from the PRCM module or the `CONTROL.CONTROL_PADCONF_OFF[0]` FORCEOFFMODEENABLE bit = 0b1), the off mode values field `CONTROL.CONTROL_PADCONF_X` overrides the pad state when OFFENABLE bit `CONTROL.CONTROL_PADCONF_X` is set.

Figure 13-9 shows the off mode pad control.

**Figure 13-9. Off Mode Pad Control Overview**



scm-010

If off mode is active and the OFFENABLE bit is set to disable, the pad keeps the AND value of the configuration (I/O, pullup/pulldown) it had before going into off mode:

- For an input, the pad is isolated and the pull remains active.
- For an output, the value is latched before going into off mode, to drive the same value in off mode

For more information about off mode, see [Chapter 3, Power, Reset, and Clock Management](#).

For more information about the preliminary settings that must be done before performing OFF <-> ON transitions, see [Section 13.5.3, Off Mode Preliminary Settings](#).

##### 13.4.4.4.1 Save-and-Restore Mechanism

Before going to off mode there is a context saving of the device. The save-and-restore mechanism saves the pad configuration registers (in the CORE power domain) in a WKUP power domain memory (physical addresses 0x4800 2600 to 0x4800 29FC) before going to off mode, and restores those registers when returning from off mode. This mechanism uses the dedicated wake-up interface between the core control module and the wake-up control module.

The save mechanism in the pad configuration registers is activated by setting the STARTSAVE bit `CONTROL.CONTROL_PADCONF_OFF[1]`. When all pad configuration registers have been saved to the wake-up memory, the status SAVEDONE bit `CONTROL.CONTROL_GENERAL_PURPOSE_STATUS[0]` is set. In smart-idle mode, the idleAck is returned when the save process is complete.

When returning from off mode, the registers are restored after the PRCM module asserts the START\_RESTORE signal. The SCM returns a RESTORE\_DONE signal to the PRCM module when the restore process completes.

Figure 13-10 shows an overview of the save-and-restore mechanism in off mode.

**Figure 13-10. Save-and-Restore Mechanism Overview**



scm-011

#### 13.4.4.4.2 Wake-Up Event Detection

In off mode, wake-up event detection can also be enabled on an input pad. The pad wake-up event is latched in the WAKEUPEVENT bit CONTROL. **CONTROL\_PADCONF\_X**.

The off mode I/O pads wake-up scheme is enabled by setting the EN\_I/O bit PRCM.PM \_WKEN\_WKUP[8]. The wake-up scheme status is transmitted by the WKUP\_ENABLE signal. The wake-up event detection capability of each I/O pad of the device is individually enabled/disabled by writing WAKEUPENABLE bit CONTROL. **CONTROL\_PADCONF\_X**.

Figure 13-11 shows the overview of wake-up event detection.

**Figure 13-11. Wake-Up Event Detection Overview**

For more information about the wake-up sequences, see [Chapter 3, Power, Reset, and Clock Management](#).

**NOTE:** When wake-up detection is enabled for a pad, the pad must be configured as input to avoid contention between the device output buffer and an external driver. If this pin is already configured as an input in active mode, hardware automatically retains the same input state; no software action is required.

If this pin is configured as an output in active mode, the OFF override function must be enabled to set the pin as an input during off mode: in the CONTROL.CONTROL\_PADCONF register, set OFFENABLE to 0x1 to enable the OFF override function, and set OFFOUTENABLE to 0x1 to switch this pin to input mode.

**NOTE:** Regardless of the INPUTENABLE bit being set high or low during active mode, to enable wake-up detection for a pad, user software must set WAKEUPENABLE bit to 0x1. It is recommended that pullup/pulldown resistors be applied at the pad to avoid spurious wake-up detection. Optionally, user software can enable the pad OFF-mode internal pullup/down resistors by appropriately setting the OFFMODEPULLUDENABLE and OFFMODEPULLTYPESELECT bits in the corresponding pad configuration register.

[Table 13-7](#) lists the bit directions of the CONTROL\_PADCONF\_x registers.

**Table 13-7. Bit Directions for CONTROL\_PADCONF\_x Registers**

| CONTROL_PADCONF_x Bit | Bit Direction                 |                              |
|-----------------------|-------------------------------|------------------------------|
|                       | 0                             | 1                            |
| PULLUDENABLE          | Not activated                 | Activated                    |
| PULLTYPESELECT        | Pulldown                      | Pullup                       |
| INPUTENABLE           | Input enable signal inactive  | Input enable signal active   |
| OFFENABLE             | Off mode values are invalid.  | Off mode values are valid.   |
| OFFOUTENABLE          | Output                        | Input                        |
| OFFOUTVALUE           | Low                           | High                         |
| OFFPULLUDENABLE       | Not activated                 | Activated                    |
| OFFPULLTYPESELECT     | Pulldown                      | Pullup                       |
| WAKEUPENABLE          | Disable I/O wake-up function. | Enable I/O wake-up function. |
| WAKEUPEVENT           | Wake-up event not detected    | Detect wake-up event.        |

### 13.4.5 Extended-Drain I/O Pin and PBIAS Cells

The device mainly supports 1.8-V I/O voltage on its interfaces, with the exception of MMC/SD/SDIO1 interface, which supports both 1.8-V and 3.0-V voltages through internal PBIAS generation and extended-drain I/Os.

The need for embedded extended-drain I/Os on MMC/SD/SDIO1 interface and another interface, which is supported as the GPIO interface in the GP device, imposes the use of embedded PBIAS cells to provide 1.8-V or 3.0-V reference voltage. The PBIAS cells and the extended-drain I/Os are software-controlled by bits located in the CONTROL.[CONTROL\\_PBIAS\\_LITE](#), CONTROL.[CONTROL\\_PROG\\_IO1](#) and CONTROL.[CONTROL\\_WKUP\\_CTRL](#) registers of the SCM. See [Section 13.6.3, Register Descriptions](#), for the description of these registers.

[Figure 13-12](#) shows the functional block diagram between the PBIAS cells and the extended-drain I/O cells.

**Figure 13-12. Functional Block Diagram**



[Table 13-8](#) describes the CONTROL.[CONTROL\\_PBIAS\\_LITE](#), CONTROL.[CONTROL\\_PROG\\_IO1](#) and CONTROL.[CONTROL\\_WKUP\\_CTRL](#) bit controls for the PBIAS and the extended-drain I/O cells.

**Table 13-8. PBIAS Cell and Extended-Drain I/O Pin Bit Controls**

| Control Signals for PBIAS0 and/or Associated Extended-Drain I/O Cell | Control Signals for PBIAS1 and/or Associated Extended-Drain I/O Cell | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PBIASLITEPWRDNZ0                                                     | PBIASLITEPWRDNZ1                                                     | The PBIASLITEPWRDNZ0 bit is used to protect the PBIAS0 cell when the SDMMC1_VDDS power supply voltage is not stable.<br>The PBIASLITEPWRDNZ1 bit is used to protect the PBIAS1 cell when the SIM_VDDS power supply voltage is not stable.<br>Software must keep the PBIASLITEPWRDNZ0/PBIASLITEPWRDNZ1 signal to 0b0 whenever the SDMMC1_VDDS/SIM_VDDS signal is ramping. When this bit is set to 0, the PAD is floating.                                                                                                                      |
| PBIASLITEPWRDNZ0                                                     | GPIO_IO_PWRDNZ                                                       | The same PBIASLITEPWRDNZ0 bit that controls power-down mode for the PBIAS0 cell is also used to control power-down mode for its associated MMC1 extended-drain I/O cell (see Figure 13-12).<br>A second extended-drain I/O cell (associated GPIO pads) does not share the same power-down control with the PBIAS1 cell, as the MMC/SD/SDIO1 I/O cell does with the PBIAS0 cell. A separate power-down control, GPIO_IO_PWRDNZ, which resides in a different register (CONTROL.CONTROL_WKUP_CTRL) is used to power it down. (See Figure 13-12) |
| PBIASLITEVMODE0                                                      | PBIASLITEVMODE1                                                      | Bit that controls SDMMC1_VDDS / SIM_VDDS voltage level. Default state of this bit is HIGH, indicating SDMMC1_VDDS/SIM_VDDS = 3.0 V                                                                                                                                                                                                                                                                                                                                                                                                            |
| PBIASLITESUPPLYHIGH0                                                 | PBIASLITESUPPLYHIGH1                                                 | Bit that describes whether the SDMMC1_VDDS/SIM_VDDS supply is 3.0 V or 1.8 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| PRG_SDMMC1_SPEEDCTRL                                                 | -                                                                    | Bit that controls the extended-drain MMC1 I/O cell speed. The control is in the CONTROL.CONTROL_PROG_IO1 register. The second extended-drain I/O cell (GPIO pads associated) does not have speed control.                                                                                                                                                                                                                                                                                                                                     |
| PBIASLITEVMODEERROR0                                                 | PBIASLITEVMODEERROR1                                                 | Status indicating whether the software-programmed VMODE level matches the SUPPLY_HI output signal                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| PBIAS0_ERROR                                                         | PBIAS1_ERROR                                                         | This signal determines whether the software-programmed PBIASLITVMODEx level matches PBIASLITESUPPLYHIGHx. This signal is generated only when PBIASLITEVMODEENx is high.                                                                                                                                                                                                                                                                                                                                                                       |

Table 13-9 lists the power supplies for the PBIAS and the extended-drain I/O cells.

**Table 13-9. Power Supplies**

| Name                                                                       | Description                             |
|----------------------------------------------------------------------------|-----------------------------------------|
| VDD2                                                                       | Core voltage supply                     |
| SDMMC1_VDDS or SIM_VDDS (vdds_sdmmc1 or vdds_sim power pins of the device) | I/O supply voltage nominal 1.8 V/ 3.0 V |
| VDDS                                                                       | 1.8-V supply for the input buffer       |

### 13.4.5.1 PBIAS Cells

The PBIAS0 cell provides a bias for the extended-drain I/O cell used with high voltage for the MMC/SD/SDIO1 interface.

**NOTE:** With the appropriate configuration of the PBIAS0 cell, the gpio\_120 through gpio\_125 I/Os (MuxMode = 0x4) can operate in 3-V mode.

The PBIAS1 cell provides a bias for a second extended-drain I/O cell.

**NOTE:** With the appropriate PBIAS1 cell configuration, the gpio\_126, gpio\_127, and gpio\_129 I/Os (MuxMode = 0x4) can operate in 3-V mode.

**NOTE:** Unlike gpio\_126, gpio\_127, and gpio\_129, gpio\_128 (MuxMode = 0x4) is not in the SIM\_VDDS voltage domain, and does not require PBIAS1 cell configuration. It is internally supplied in the standard 1.8-V VDDS\_IO voltage domain, and does not support 3-V mode.

PBIAS0 and PBIAS1 cells provide a voltage reference (PBIAS voltage) for biasing extended drain in the MMC/SD/SDIO1 and GPIO associated I/O cells. In addition to generating the bias voltage, the PBIAS0 cell can detect the supply voltage (SDMMC1\_VDDS ) value (1.8V or 3.0 V) and update, with its status, the PBIASLITESUPPLYHIGH0. In addition to generating the bias voltage, the PBIAS1 cell can detect the supply voltage (SIM\_VDDS ) value (1.8 V or 3.0 V) and update it with its PBIASLITESUPPLYHIGH1 status bit.

#### CAUTION

A PBIAS cell lets the peripheral associated with its corresponding extended-drain I/O cell support 1.8-V and 3.0-V voltages. A PBIAS cell is not a part of a peripheral, but a part of the device I/Os to which this peripheral is internally connected. These device I/Os are not exclusive to only one peripheral; through I/O multiplexing they can be connected to other internal signals. It is necessary to configure the PBIAS and corresponding I/O cell to enable the I/Os, regardless of how I/O multiplexing is configured for these device I/Os. In other words, independently of which signal is internally connected to a device I/O powered by SDMMC1\_VDDS or SIM\_VDDS, the corresponding PBIAS must be configured.

#### 13.4.5.2 Extended-Drain I/Os

On the device, the following extended-drain I/Os are used by I/Os from the MMC/SD/SDIO1:

- sdmmc1\_clk
- sdmmc1\_cmd
- sdmmc1\_dat<sub>i</sub> (where i = 0 to 3)

The following extended-drain I/Os are used by GPIO I/Os:

- gpio\_126 (MuxMode = 0x4)
- gpio\_127 (MuxMode = 0x4)
- gpio\_129 (MuxMode = 0x4)

[Figure 13-13](#) describes the extended-drain I/O cell.

**Figure 13-13. Extended-Drain I/O**

scm-016

The extended-drain I/O cells have the following I/O signals:

- Output signal, input signal, and oe, which comes from the selected IO module with the correct MODE field CONTROL.[CONTROL\\_PADCONF\\_X](#) configuration.

---

**NOTE:** The two extended-drain I/Os are muxed I/Os with mode and pullup/pulldown configurations programmable in the SCM.

---

- The PBIAS voltage is a voltage reference for biasing the extended-drain in the MMC/SD/SDIO1I/O and GPIO-associated I/O cells (gpio\_126, gpio\_127, and gpio\_129).
- The PBIASLITEPWRDNZ0 bit is used to protect the MMC/SD/SDIO1 I/O cell when the SDMMC1\_VDDS voltage is not stable.
- The GPIO\_IO\_PWRDNZ bit is used to protect the GPIO-associated I/O cell when the SIM\_VDDS voltage is not stable.

#### CAUTION

Software must keep the PWRDNZ-related signals to 0b0 when the SDMMC1\_VDDS or SIM\_VDDS signal is ramping up/down or changing. When PBIASLITEPWRDNZ0/PBIASLITEPWRDNZ1 is 0, the PAD is floating (the PAD may not reflect the state of the output signal, and the input signal may not reflect the state of the PAD).

#### CAUTION

It is strongly recommended to synchronize any changes of the PBIASLITEPWRDNZ1 and GPIO\_IO\_PWRDNZ bits (that is, both bits should be set to 1 or 0 at the same time).

- The CONTROL.[CONTROL\\_PROG\\_I01](#)[20] PRG\_SDMMC1\_SPEEDCTRL bit controls the speed of the MMC/SD/SDIO1 I/O cell and can be used to reduce dynamic current if fast rise/fall times are not

required.

- The PBIASLITESUPPLYHIGH0 bit is a status bit on the SDMMC1\_VDDS value and is used to inform the PBIAS0 cell on the value of SDMMC1\_VDDS signal.
- The PBIASLITESUPPLYHIGH1 bit is a status bit on the SIM\_VDDS value and is used to inform the PBIAS1 cell on the value of the SIM\_VDDS signal.

For more information about the software configurations of the extended-drain I/Os and PBIAS cells, see [Section 13.5.2, Extended-Drain I/Os and PBIAS Cells Programming Guide](#).

#### 13.4.6 Band Gap Voltage and Temperature Sensor

The device supplies a voltage reference and a temperature sensor feature which are gathered in the band gap voltage and temperature sensor (BGAPTS) module. The band gap provides current and voltage reference for its internal circuits and also to other analog IP blocks. The A/D converter (ADC) produces an output value that is proportional to the silicon temperature.

Main features of the BGAPTS module are:

- A constant voltage reference output: 0.5 V
- Four constant current reference outputs of 1 $\mu$ A
- Analog supply is a nominal 1.8 V.
- Small A/D converter with 8-bit digital output
- OFF mode compatible
- Thermal shutdown comparator output

The band gap and the temperature sensor are software-controlled by bits located in the CONTROL.[CONTROL\\_TEMP\\_SENSOR](#) and the CONTROL.[CONTROL\\_BGAPTS\\_WKUP](#) registers of the SCM. The CONTROL.[CONTROL\\_BGAPTS\\_WKUP](#) register is used to control certain inputs of the BGAPTS module in the core domain. The register is placed in wake-up domain control module so that software can program these controls appropriately before the core domain is ON. See [Table 13-279](#), for more information about this register. See [Section 13.4.7.5, Register Descriptions](#), for the description of this register.

[Figure 13-14](#) shows the functional block diagram of the band gap and the temperature sensor module.

**Figure 13-14. Functional Block Diagram**

Table 13-10 describes the input and output signals for the band gap and the temperature sensor.

**Table 13-10. Band Gap Voltage and Temperature Sensor Signals Description**

| Pin       | I/O <sup>(1)</sup> | Description                                                                                                                              |
|-----------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| SOC       | I                  | Start Of Conversion signal. A transition to high starts a new ADC conversion cycle.                                                      |
| EOCZ      | I                  | End of Conversion signal. When low, the signal indicates that the value of TEMP[6:0] is valid.                                           |
| TEMP[7:0] | O                  | Temperature data from the temperature sensor. This value is valid when EOCZ is low.                                                      |
| CONTCONV  | I                  | Configures the temperature sensor in continuous conversion mode.<br>0 – ADC single conversion mode<br>1 – ADC continuous conversion mode |
| TSHUT     | O                  | Thermal shutdown comparator output. The signal is low during normal operation and goes high during a thermal shutdown event.             |
| RESET     | I                  | When low the temperature sensor is in RESET mode. This signal needs to be LOW when OFFMODE is HIGH.                                      |
| 32K_FCLK  | I                  | 32-kHz functional clock from the CORE domain used by the temperature sensor during temperature conversion.                               |

<sup>(1)</sup> I=Input, O=Output

All the configuration signals are available through the CONTROL.CONTROL\_TEMP\_SENSOR register.

**NOTE:** BGAPTS 32K\_FCLK is used only for the temperature sensor. When ADC is not converting, this clock can be switched off (32K\_FCLK = 0). In this case, TEMP[7:0] retains the temperature code obtained at the previous conversion.

### 13.4.6.1 Band Gap Voltage Reference

The band gap voltage reference feature provides several constant voltage and current references for its internal circuits, but also for other analog modules.

The voltage reference signal is a 0.5-V output that is used internally by the module and is exported for external modules or for tests.

The current reference signals consist in four lines that each supply a 1- $\mu$ A current with a 1.8-V voltage. These lines can be used to bias other modules.

### 13.4.6.2 Temperature Sensor

The temperature sensor feature is used to convert the temperature of the device into a decimal value coded on 7 bits. An internal ADC (realized with a resistor array) is used for conversion. The recommended operating temperatures must be from  $-40$  to  $125^{\circ}\text{C}$  for standard conversion, and can go up to  $160^{\circ}\text{C}$  when using the thermal shutdown comparator output (TSHUT signal). This signal indicates a too high temperature of the device. This signal is internally connected to a general purpose input/output (GPIO) pin. See [Chapter 25, General-Purpose Interface](#), for more information.

The temperature sensor offers two operating modes: a single conversion mode and a continuous conversion mode.

#### 13.4.6.2.1 Single Conversion Mode (CONTCONV = 0)

When the ADC is idle ( $\text{EOCZ} = 0$ ), it is possible to ask for a single temperature conversion. To initiate a new conversion, the start of conversion (SOC) signal must be asserted and maintained high until the end of conversion (EOCZ) signal goes high, after which the SOC must be made low by writing 0 to the CONTROL.[CONTROL\\_TEMP\\_SENSOR\[9\]](#) SOC bit. Conversion completion is indicated by a negative edge on EOCZ (CONTROL.[CONTROL\\_TEMP\\_SENSOR\[8\]](#) EOCZ bit).

Figure 13-15 shows the timing sequence for a single temperature conversion.

Figure 13-15. Single Conversion Mode (CONTCONV = 0)



scm-031

#### 13.4.6.2.2 Continuous Conversion Mode (CONTCONV = 1)

When the ADC is idle ( $\text{EOCZ} = 0$ ), it is possible to ask for a single temperature conversion. To initiate a new conversion, the SOC signal must be asserted and maintained high until the EOCZ signal goes high, after which the SOC must be made low by writing 0 to the CONTROL.[CONTROL\\_TEMP\\_SENSOR\[9\]](#) SOC bit. The ADC starts converting continuously, and when a conversion is complete, data is written to the CONTROL.[CONTROL\\_TEMP\\_SENSOR\[7:0\]](#) TEMP bits and EOCZ goes low after four clock cycles.

Figure 13-16 shows the timing sequence for a continuous temperature conversion.

**Figure 13-16. Continuous Conversion Mode (CONTCONV = 1)**

### 13.4.6.2.3 ADC Codes Versus Temperature

Table 13-11 gives the temperature corresponding to each value of the CONTROL.CONTROL\_TEMP\_SENSOR[7:0] TEMP bits.

**Table 13-11. ADC Code Versus Temperature**

| ADC Code | Temperature °C |       | ADC Code | Temperature °C |      | ADC Code | Temperature °C |      | ADC Code | Temperature °C |       |
|----------|----------------|-------|----------|----------------|------|----------|----------------|------|----------|----------------|-------|
|          | From           | To    |          | From           | To   |          | From           | To   |          | From           | To    |
| 0        | -40            | -40   | 32       | -5             | -3.5 | 64       | 50             | 52   | 96       | 105            | 107   |
| 1        | -40            | -40   | 33       | -3.5           | -1.5 | 65       | 52             | 53.5 | 97       | 107            | 109   |
| 2        | -40            | -40   | 34       | -1.5           | 0    | 66       | 53.5           | 55   | 98       | 109            | 111   |
| 3        | -40            | -40   | 35       | 0              | 2    | 67       | 55             | 57   | 99       | 111            | 113   |
| 4        | -40            | -40   | 36       | 2              | 3.5  | 68       | 57             | 58.5 | 100      | 113            | 115   |
| 5        | -40            | -40   | 37       | 3.5            | 5    | 69       | 58.5           | 60   | 101      | 115            | 117   |
| 6        | -40            | -40   | 38       | 5              | 6.5  | 70       | 60             | 62   | 102      | 117            | 118.5 |
| 7        | -40            | -40   | 39       | 6.5            | 8.5  | 71       | 62             | 64   | 103      | 118.5          | 120   |
| 8        | -40            | -40   | 40       | 8.5            | 10   | 72       | 64             | 66   | 104      | 120            | 122   |
| 9        | -40            | -40   | 41       | 10             | 12   | 73       | 66             | 68   | 105      | 122            | 123.5 |
| 10       | -40            | -40   | 42       | 12             | 13.5 | 74       | 68             | 70   | 106      | 123.5          | 125   |
| 11       | -40            | -40   | 43       | 13.5           | 15   | 75       | 70             | 71.5 | 107      | 125            | 125   |
| 12       | -40            | -40   | 44       | 15             | 17   | 76       | 71.5           | 73.5 | 108      | 125            | 125   |
| 13       | -40            | -38   | 45       | 17             | 19   | 77       | 73.5           | 75   | 109      | 125            | 125   |
| 14       | -38            | -35   | 46       | 19             | 21   | 78       | 75             | 77   | 110      | 125            | 125   |
| 15       | -35            | -34   | 47       | 21             | 23   | 79       | 77             | 78.5 | 111      | 125            | 125   |
| 16       | -34            | -32   | 48       | 23             | 25   | 80       | 78.5           | 80   | 112      | 125            | 125   |
| 17       | -32            | -30   | 49       | 25             | 27   | 81       | 80             | 82   | 113      | 125            | 125   |
| 18       | -30            | -28   | 50       | 27             | 28.5 | 82       | 82             | 83.5 | 114      | 125            | 125   |
| 19       | -28            | -26   | 51       | 28.5           | 30   | 83       | 83.5           | 85   | 115      | 125            | 125   |
| 20       | -26            | -24   | 52       | 30             | 32   | 84       | 85             | 87   | 116      | 125            | 125   |
| 21       | -24            | -22   | 53       | 32             | 33.5 | 85       | 87             | 88.5 | 117      | 125            | 125   |
| 22       | -22            | -20   | 54       | 33.5           | 35   | 86       | 88.5           | 90   | 118      | 125            | 125   |
| 23       | -20            | -18.5 | 55       | 35             | 37   | 87       | 90             | 92   | 119      | 125            | 125   |
| 24       | -18.5          | -17   | 56       | 37             | 38.5 | 88       | 92             | 93.5 | 120      | 125            | 125   |
| 25       | -17            | -15   | 57       | 38.5           | 40   | 89       | 93.5           | 95   | 121      | 125            | 125   |
| 26       | -15            | -13.5 | 58       | 40             | 42   | 90       | 95             | 97   | 122      | 125            | 125   |
| 27       | -13.5          | -12   | 59       | 42             | 43.5 | 91       | 97             | 98.5 | 123      | 125            | 125   |
| 28       | -12            | -10   | 60       | 43.5           | 45   | 92       | 98.5           | 100  | 124      | 125            | 125   |

**Table 13-11. ADC Code Versus Temperature (continued)**

| ADC Code | Temperature °C |      | ADC Code | Temperature °C |      | ADC Code | Temperature °C |       | ADC Code | Temperature °C |     |
|----------|----------------|------|----------|----------------|------|----------|----------------|-------|----------|----------------|-----|
| 29       | -10            | -8   | 61       | 45             | 47   | 93       | 100            | 102   | 125      | 125            | 125 |
| 30       | -8             | -6.5 | 62       | 47             | 48.5 | 94       | 102            | 103.5 | 126      | 125            | 125 |
| 31       | -6.5           | -5   | 63       | 48.5           | 50   | 95       | 103.5          | 105   | 127      | 125            | 125 |

**NOTE:** ADC code values in the subrange 128–255 are reserved for future use.

### 13.4.7 Functional Register Description

#### 13.4.7.1 Static Device Configuration Registers

Table 13-12 describes the static device configuration registers.

**Table 13-12. Static Device Configuration Registers**

| Physical Address | Register Name    | Description                     | Access |
|------------------|------------------|---------------------------------|--------|
| 0x4800 2274      | CONTROL_DEVCONF0 | Module dedicated configurations | R/W    |
| 0x4800 22D8      | CONTROL_DEVCONF1 | Module dedicated configurations | R/W    |

These registers allow the static configuration of device modules such as USB, McBSP, SDMMC/SD/SDIO. For example, they allow selecting external or internal clocks for McBSP modules.

#### 13.4.7.2 MPU and/or DSP (IVA2.2) MSuspend Configuration Registers

Table 13-13 describes the MPU and/or DSP (IVA2.2) MSuspend configuration registers.

**Table 13-13. MSuspendMux Control Registers**

| Physical Address | Register Name         | Description                                         | Access |
|------------------|-----------------------|-----------------------------------------------------|--------|
| 0x4800 2290      | CONTROL_MSUSPENDMUX_0 | Control the use of MSuspend signals at module level | R/W    |
| 0x4800 2294      | CONTROL_MSUSPENDMUX_1 |                                                     | R/W    |
| 0x4800 2298      | CONTROL_MSUSPENDMUX_2 |                                                     | R/W    |
| 0x4800 229C      | CONTROL_MSUSPENDMUX_3 |                                                     | R/W    |
| 0x4800 22A0      | CONTROL_MSUSPENDMUX_4 |                                                     | R/W    |
| 0x4800 22A4      | CONTROL_MSUSPENDMUX_5 |                                                     | R/W    |

These registers provide an entry for each module that must consider the MSuspend signals from the processors (MPU and/or DSP). For each module, the sensitivity to the MSuspend signals is defined within five possibilities (coded using 3 bits):

- 0b000: No sensitivity; no MSuspend signal reaches the module.
- 0b001: Sensitivity to the MPU MSuspend signal (the DSP signal is ignored)
- 0b010: Sensitivity to the DSP MSuspend signal (the MPU signal is ignored)
- 0b011: Sensitivity to the logical ORed MPU and DSP MSuspend signals
- 0b100: Sensitivity to the logical ANDed MPU and DSP MSuspend signals
- Other values: No sensitivity; no MSuspend signal reaches the module.

The logic used to combine the MSuspend signals from the processors is implemented within the SCM. MSuspend signals are active low.

**CAUTION**

Use care when using combined sensitivity settings (ANDing or ORing DSP and MPU MSuspend signals).

ORing the DSP and MPU MSuspend signals creates a situation where the module is suspended when at least one processor is under debug; therefore, when one processor is halted, stepping within the code of the other one does not change the module suspended state.

Not all modules use the MSUSPEND signal. See the TRM chapter for each module to determine whether the module supports the MSUSPEND signal.

All MSUSPEND signals coming out of the MPU and DSP are resynchronized within the SCM by using the control module interface clock.

### 13.4.7.3 IVA2.2 Boot Registers

[Table 13-14](#) describes the IVA2.2 boot registers.

**Table 13-14. IVA2.2 Boot Registers**

| Physical Address | Register Name                         | Description                         | Access |
|------------------|---------------------------------------|-------------------------------------|--------|
| 0x4800 2400      | <a href="#">CONTROL_IVA2_BOOTADDR</a> | IVA2.2 boot loader address register | R/W    |
| 0x4800 2404      | <a href="#">CONTROL_IVA2_BOOTMOD</a>  | IVA2.2 boot mode register           | R/W    |

The CONTROL.[CONTROL\\_IVA2\\_BOOTADDR](#) register defines the physical address for the IVA2 boot loader and drives the IVA2\_BOOTADDR[21:0] signals out from the control block to the IVA2 subsystem.

The CONTROL.[CONTROL\\_IVA2\\_BOOTMOD](#) register defines the IVA2 boot mode and drives the IVA2\_BOOTMOD[3:0] signals out from the control block to the IVA2.2 subsystem. Based on the value of IVA2\_BOOTMOD[3:0], the ROM boot loader executes different boot modes of IVA2.2.

[Table 13-15](#) lists the IVA2.2 boot modes.

**Table 13-15. IVA2.2 Boot Modes**

| IVA2_BOOTMOD[3:0] Value | Meaning                                                                                                                                                                              |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0                     | Direct boot: The ROM loader is not executed. Instead, IVA2.2 directly starts executing the bootstrap at the address contained in the <a href="#">CONTROL_IVA2_BOOTADDR</a> register. |
| 0x1                     | Idle boot: The boot loader executes the IDLE instruction.                                                                                                                            |
| 0x2                     | Wait in self-loop boot: The boot loader puts IVA2.2 in a self-loop.                                                                                                                  |
| 0x3                     | User-defined bootstrap mode: The boot loader copies the boot strap into internal memory and branches to it.                                                                          |
| 0x4                     | The boot loader executes the default context restore code, which is part of the ROM boot loader.                                                                                     |

For further information, see [Chapter 5, IVA2.2 Subsystem](#).

### 13.4.7.4 PBIAS LITE Control Register

[Table 13-16](#) describes the CONTROL.[CONTROL\\_PBIAS\\_LITE](#) register, which controls most of the settings of the PBIAS0, PBIAS1 cells and their associated extended-drain I/O cells.

**Table 13-16. PBIAS Control Register**

| Physical Address | Register Name                      | Description                                             | Access |
|------------------|------------------------------------|---------------------------------------------------------|--------|
| 0x4800 2520      | <a href="#">CONTROL_PBIAS_LITE</a> | Control settings for PBIAS and extended-drain I/O cells | R/W    |

For more information about the PBIAS0 and PBIAS1 cells, see [Section 13.4.5, Extended-Drain I/O Pin and PBIAS Cells](#).

### 13.4.7.5 Temperature Sensor Control Register

[Table 13-17](#) describes the CONTROL.CONTROL\_TEMP\_SENSOR register, which controls the temperature sensor.

**Table 13-17. Temperature Sensor Register**

| Physical Address | Register Name                       | Description                         | Access |
|------------------|-------------------------------------|-------------------------------------|--------|
| 0x4800 2524      | <a href="#">CONTROL_TEMP_SENSOR</a> | Temperature sensor control register | R/W    |

### 13.4.7.6 Signal Integrity Parameter Control Registers With Pad Group Assignment

#### 13.4.7.6.1 Signal Integrity Parameter Controls Overview

Most of the I/O cells associated to the device pads are configurable/controllable to deliver their carried signals to the targeted sink with maximum signal integrity. Configuration of the buffers is done by groups assignment and not individually per pad. The I/Os parameter control includes : drive strength in terms of frequency vs. load settings (SDRC) - DS, far-end load settings -LB (GPMC, etc.) , combined slew rate -SC and load capacitance vs effective transmission line (TL) length - LB controls ( UART3, etc.), pullup strength (SDMMC) settings, pullup resistance vs capacitance load settings (I2Cx).

The pad group assigned signal integrity controls are provided through the registers described in [Table 13-18](#), Signal Integrity Parameter Control Registers.

**Table 13-18. Signal Integrity Parameter Control Registers**

| Physical Address | Register Name                         | Description                                                  | Access |
|------------------|---------------------------------------|--------------------------------------------------------------|--------|
| 0x4800 2444      | <a href="#">CONTROL_PROG_IO0</a>      | I/O pad group assignment control register                    | R/W    |
| 0x4800 2448      | <a href="#">CONTROL_PROG_IO1</a>      | I/O pad group assignment control register                    | R/W    |
| 0x4800 2408      | <a href="#">CONTROL_PROG_IO2</a>      | I/O pad group assignment control register                    | R/W    |
| 0x4800 2A80      | <a href="#">CONTROL_PROG_IO_WKUP1</a> | I/O pad group assignment control register in the WKUP domain | R/W    |

#### 13.4.7.6.2 DDR Buffer Drive Strength Related Settings

The DS control maintains the same drive strength by applying programmable capacitance load compensation at the I/O level. This is done to achieve the necessary performance of the DDR driver output groups at different target frequencies.

[Table 13-19](#) provides the DS programming pattern. The DS controls concern only the SDRC I/Os of the device.

**Table 13-19. DS Parameter Settings**

| DDR I/Os Drive Strength Setting for High-Speed I/O Cells |                                            |
|----------------------------------------------------------|--------------------------------------------|
| DS = 0b0                                                 | DS = 0b1                                   |
| Equivalent load capacitance range: 2–4 pF                | Equivalent load capacitance range: 4–12 pF |

#### 13.4.7.6.3 High Speed I/Os Far End Load Settings

[Table 13-20](#) provides the far-end-load range programming pattern applicable to high-speed I/Os. Control over this signal group parameter is acquired through programming single-bit LB.

**Table 13-20. LB Parameter Settings for High-Speed I/O Cells****Far End Load Setting on TL for High-Speed I/O Cells**

|                                     |                                      |
|-------------------------------------|--------------------------------------|
| LB = 0b0                            | LB = 0b1                             |
| Equivalent load capacitance: 1–10pF | Equivalent load capacitance: 10–16pF |

**NOTE:** For both capacitance load ranges, the TL length must be maintained in the range [1cm–6cm].

**13.4.7.6.4 Low-Speed I/Os Combined Slew Rate vs TL Length and Load Settings**

[Table 13-21](#) and [Table 13-22](#) provide the recommended SC [1:0] (slew-rate control) vs LB [1:0] (combined capacitance load and TL length control) programming pattern applicable to low-speed I/O cells. The SR settings determine three target maximal frequencies of I/O operation.

Because the TL and SC parameter values are mutually constrained in the context of a certain I/O signal transient performance, only the combined slew rate vs TL length/capacitance load settings make sense. [Table 13-21](#) and [Table 13-22](#) list the possible SC[1:0]–LB[1:0] combinations.

**Table 13-21. Recommended SC vs LB Parameter Settings for TL With Length in the Range 2–20cm****SC vs LB Settings Applicable to pads in Low-Speed I/O Cells**

|                                                 |                                                  |                                                  |
|-------------------------------------------------|--------------------------------------------------|--------------------------------------------------|
| SC[1:0] = 00 LB[1:0] = 00                       | SC[1:0] = 01 LB[1:0] = 10                        | SC[1:0] = 10 LB[1:0] = 10                        |
| 2–20 cm<br>1–10pF<br>achieved pad Freq <= 20MHz | 2–20 cm<br>10–20pF<br>achieved pad Freq <= 60MHz | 2–20 cm<br>10–20pF<br>achieved pad Freq <= 40MHz |

**Table 13-22. Recommended SC vs LB Parameter Settings for Dual TL With Length in the Range 20–40cm****SC vs LB Settings Applicable to Pads in Low-Speed I/O Cells**

|                                                             |                                                              |                                                             |
|-------------------------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------------|
| SC[1:0] = 00 LB[1:0] = 01                                   | SC[1:0] = 01 LB[1:0] = 11                                    | SC[1:0] = 10 LB[1:0] = 11                                   |
| 20–40 cm (dual TL)<br>1–10 pF<br>achieved pad Freq <= 20MHz | 20–40 cm (dual TL)<br>10–20 pF<br>achieved pad Freq <= 60MHz | 20–40 cm (dual TL)<br>10–20pF<br>achieved pad Freq <= 40MHz |

**CAUTION**

It is strongly recommended that only the SC vs LB combinations given in the [Table 13-21](#) and [Table 13-22](#) are used when programming low-speed I/Os.

**13.4.7.6.5 SDMMC Pullup Strength Control**

A control bit, PRG\_SDMMC\_PUSTRENGTH, is added in the register CONTROL\_PROG\_IO0 to program the pullup strength for the MMC/SD/SDIO1 I/O group. [Table 13-23](#) lists the supported resistance ranges.

**Table 13-23. Group Pullup Strength Setting for SDMMC1 I/Os****PUSTRENGTH Control**

|                                         |                                        |
|-----------------------------------------|----------------------------------------|
| PRG_SDMMC_PUSTRENGTH = 0b0              | PRG_SDMMC_PUSTRENGTH = 0b1             |
| Pullup with 50–110 kΩ strength selected | Pullup with 10–50 kΩ strength selected |

### 13.4.7.6.6 I<sup>2</sup>Cx I/Os Group Pullupresx Controls and Load Range Settings

[Table 13-24](#) provides examples of pullup resistance versus load range I<sup>2</sup>Cx I/O signal integrity control capabilities. Three possible operation modes of the I<sup>2</sup>C associated I/O cells are shown: non-I<sup>2</sup>C mode, full-speed (FS), and high-speed (HS) modes, which are described in [Chapter 17, Multimaster High-Speed I<sup>2</sup>C Controller](#). Non-I<sup>2</sup>C mode means that the muxmode field in I<sup>2</sup>Cx dedicated PADCONFS is set to select signals different than I<sup>2</sup>C signals. For more information, see [Section 13.4.4.3, Pad Multiplexing Register Fields](#).

**Table 13-24. Example I<sup>2</sup>Cx Pullupresx vs I<sup>2</sup>C LB Parameter Settings in Different Modes**

| Non-I <sup>2</sup> C Mode                                 | FS I <sup>2</sup> C Bus Mode                                                        | HS I <sup>2</sup> C p2p Mode                                                          |
|-----------------------------------------------------------|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| nmode = 1<br>hsmode = 0<br>pullupresx = 1<br>lb[1:0] = 00 | nmode = 0<br>hsmode = 0<br>pullupresx = 1<br>lb[1:0] = 00<br>400 kHz<br>external PU | nmode = 0<br>hsmode = 1<br>pullupresx = 0<br>lb[1:0] = 00<br>3.4 MHz, cap.load 5–12pF |

The I<sup>2</sup>Cx buffer contains internal pullup resistors for fast and high-speed modes that meet the I<sup>2</sup>C rise time specifications for loads up to 80 pF in high-speed mode and 150 pF in fast mode. LB[1:0] signals can be used to select the appropriate pullup resistor for a given load range. [Table 13-25](#) lists the configuration options.

**Table 13-25. Internal Pullup Resistor in Fast/HS Mode**

| LB1 | LB0 | Load Range HS Mode (pf) | Nominal Resistance in HS Mode (Ω) | Load Range Fast Mode (pf) | Nominal Resistance in Fast Mode (Ω) |
|-----|-----|-------------------------|-----------------------------------|---------------------------|-------------------------------------|
| 0   | 0   | 5–12                    | 1.66K                             | 5–15                      | 4.5K                                |
| 0   | 1   | 12–25                   | 920                               | 15–50                     | 2.1K                                |
| 1   | 0   | 25–50                   | 500                               | 50–150                    | 860                                 |
| 1   | 1   | 50–80                   | 300                               | –                         | –                                   |

I<sup>2</sup>C I/Os can meet I<sup>2</sup>C rise/fall time specifications in 1.2-V/1.8-V mode under all modes up to 400 pF, if a suitable external pullup resistor is used.

The type of pullup resistor (external or internal) for a certain I<sup>2</sup>Cx I/O group (where x = 1 to 4) is selected through the PRG\_I<sup>2</sup>Cx\_PULLUPRESX bit. Internal pullups are activated when PRG\_I<sup>2</sup>Cx\_PULLUPRESX = 0b0.

**NOTE:** I<sup>2</sup>C functionality is not ensured if the weak internal pullup or pulldown (100 μA nominal PU-PD) is activated on any of the I/Os connected to the bus.

### 13.4.7.6.7 Device Interfaces Signal Group Controls Mapping

[Table 13-26](#) describes the mapping of the different signal integrity control bit fields in the CONTROL\_PROG\_IOx (where x = 0 to 3) and [CONTROL\\_PROG\\_IO\\_WKUP1](#) registers to their assigned groups of different interface I/O pads.

**Table 13-26. Signal Group Parameter Controls to Different Interface I/O Pads Mapping**

| Pad Group Configurable Interface | Bit Fields for Pad Group Control          | Pads in Group                                                                | Type of I/O Group-Associated Control Bit Fields                     |
|----------------------------------|-------------------------------------------|------------------------------------------------------------------------------|---------------------------------------------------------------------|
| SDRC                             | CONTROL.CONTROL_PROG_I_O0[31]SDRC_LOWDATA | sdrc_d0 - sdrc_d15 ;<br>sdrc_dqs0 ;<br>sdrc_dqs1 ;<br>sdrc_dm0 ;<br>sdrc_dm1 | DS control (for more information, see <a href="#">Table 13-19</a> ) |

**Table 13-26. Signal Group Parameter Controls to Different Interface I/O Pads Mapping (continued)**

| Pad Group Configurable Interface | Bit Fields for Pad Group Control                    | Pads in Group                                                                                   | Type of I/O Group-Associated Control Bit Fields                                                  |
|----------------------------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
|                                  | CONTROL.CONTROL_PROG_I<br>OO[30]SDRC_HIGHDATA       | sdrc_d16 - sdrc_d31 ;<br>sdrc_dqs2 ;<br>sdrc_dqs3 ;<br>sdrc_dm2 ;<br>sdrc_dm3                   |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[29]SDRC_ADDRCTR        | sdrc_nrás ;<br>sdrc_ncas ;<br>sdrc_nwe ;<br>sdrc_nclk ;<br>sdrc_clk ;<br>sdrc_ba0 ;<br>sdrc_ba1 |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[28]SDRC_NCS0           | sdrc_ncs0 ;<br>sdrc_cke0                                                                        |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[27]SDRC_NCS1           | sdrc_ncs1 ;<br>sdrc_cke1                                                                        |                                                                                                  |
| GPMC                             | CONTROL.CONTROL_PROG_I<br>OO[26]PRG_GPMC_A1_LB      | gpmc_a1                                                                                         | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> ) |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[25]PRG_GPMC_A2_LB      | gpmc_a2                                                                                         |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[24]PRG_GPMC_A3_LB      | gpmc_a3                                                                                         |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[23]PRG_GPMC_A4_LB      | gpmc_a4                                                                                         |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[22]PRG_GPMC_A5_LB      | gpmc_a5                                                                                         |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[21]PRG_GPMC_A6_LB      | gpmc_a6                                                                                         |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[20]PRG_GPMC_A7_LB      | gpmc_a7                                                                                         |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[19]PRG_GPMC_A8_LB      | gpmc_a8                                                                                         |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[18]PRG_GPMC_A9_LB      | gpmc_a9                                                                                         |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[17]PRG_GPMC_A10_LB     | gpmc_a10                                                                                        |                                                                                                  |
| GPMC                             | CONTROL.CONTROL_PROG_I<br>OO[16]PRG_GPMC_A11_LB     | gpmc_a11                                                                                        | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> ) |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[15]PRG_GPMC_MIN_CFG_LB | gpmc_d0 - gpmc_d7;<br>gpmc_wait0 ;<br>gpmc_nadv_ale ;<br>gpmc_noe ;<br>gpmc_nwe ;               |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[14]PRG_GPMC_D8_D15_LB  | gpmc_d8 - gpmc_d15                                                                              |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[13]PRG_GPMC_NCS0_LB    | gpmc_ncs0                                                                                       |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[12]PRG_GPMC_NCS1_LB    | gpmc_ncs1                                                                                       |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[11]PRG_GPMC_NCS2_LB    | gpmc_ncs2                                                                                       |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[10]PRG_GPMC_NCS3_LB    | gpmc_ncs3                                                                                       |                                                                                                  |
|                                  | CONTROL.CONTROL_PROG_I<br>OO[9]PRG_GPMC_NCS4_LB     | gpmc_ncs4                                                                                       |                                                                                                  |

**Table 13-26. Signal Group Parameter Controls to Different Interface I/O Pads Mapping (continued)**

| Pad Group Configurable Interface | Bit Fields for Pad Group Control                   | Pads in Group                                                                                     | Type of I/O Group-Associated Control Bit Fields                                                                                       |
|----------------------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
|                                  | CONTROL.CONTROL_PROG_I_O0[8]PRG_GPMC_NCS5_LB       | gpmc_ncs5                                                                                         |                                                                                                                                       |
|                                  | CONTROL.CONTROL_PROG_I_O0[7]PRG_GPMC_NCS6_LB       | gpmc_ncs6                                                                                         |                                                                                                                                       |
|                                  | CONTROL.CONTROL_PROG_I_O0[6]PRG_GPMC_NCS7_LB       | gpmc_ncs7                                                                                         |                                                                                                                                       |
|                                  | CONTROL.CONTROL_PROG_I_O0[5]PRG_GPMC_CLK_LB        | gpmc_clk                                                                                          |                                                                                                                                       |
|                                  | CONTROL.CONTROL_PROG_I_O0[4]PRG_GPMC_NBE0_CLE_LB   | gpmc_nbe0_cle                                                                                     |                                                                                                                                       |
|                                  | CONTROL.CONTROL_PROG_I_O0[3]PRG_GPMC_NBE1_LB       | gpmc_nbe1                                                                                         |                                                                                                                                       |
|                                  | CONTROL.CONTROL_PROG_I_O0[2]PRG_GPMC_NWP_LB        | gpmc_nwp                                                                                          |                                                                                                                                       |
|                                  | CONTROL.CONTROL_PROG_I_O1[31]PRG_GPMC_WAIT1        | gpmc_wait1                                                                                        |                                                                                                                                       |
|                                  | CONTROL.CONTROL_PROG_I_O1[30]PRG_GPMC_WAIT2        | gpmc_wait2                                                                                        |                                                                                                                                       |
|                                  | CONTROL.CONTROL_PROG_I_O1[29]PRG_GPMC_WAIT3        | gpmc_wait3                                                                                        |                                                                                                                                       |
| DISPLAY                          | CONTROL.CONTROL_PROG_IO1[27:26]PRG_DISP_DSI_SC     | dss_data0 – dss_data5;                                                                            | Low-speed I/O LB[1: 0] + SC[1:0] controls<br>(for more information, see <a href="#">Table 13-21</a> and <a href="#">Table 13-22</a> ) |
|                                  | CONTROL.CONTROL_PROG_I_O1[28]PRG_DISP_SIDEBOARD_LB | dss_pclk;<br>dss_hsync;<br>dss_vsync;<br>dss_acbias                                               | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                      |
|                                  | CONTROL.CONTROL_PROG_I_O1[23]PRG_DISP_DATA_LB      | dss_data6 - dss_data23;                                                                           |                                                                                                                                       |
| CAMERA                           | CONTROL.CONTROL_PROG_I_O1[22]PRG_CAM_SIDEBOARD_LB  | cam_hs;<br>cam_vs;<br>cam_xckla;<br>cam_pclk;<br>cam_fld;<br>cam_xcklb;<br>cam_wen;<br>cam_strobe | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                      |
|                                  | CONTROL.CONTROL_PROG_I_O1[21]PRG_CAM_DATA_LB       | cam_d2 – cam_d5;<br>cam_d10 – cam_d11                                                             |                                                                                                                                       |
| HSUSBO                           | CONTROL.CONTROL_PROG_I_O1[18]PRG_HSUSBO_CLK_LB     | hsusb0_clk                                                                                        | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                      |
|                                  | CONTROL.CONTROL_PROG_I_O1[17]PRG_HSUSBO_LB         | hsusb0_stp;<br>hsusb0_dir;<br>hsusb0_nxt;                                                         | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                      |
|                                  | CONTROL.CONTROL_PROG_I_O1[17]PRG_HSUSBO_LB         | hsusb0_data0 – hsusb0_data7                                                                       |                                                                                                                                       |
| MMC/SD/SDIO1                     | CONTROL.CONTROL_PROG_I_O0[1]PRG_SDMMC_PUSTREN_GTH; | sdmmc1_clk;<br>sdmmc1_cmd;<br>sdmmc1_dat0 -sdmmc1_dat3                                            | Pullup strength control common for SDMMC1 I/Os<br>(for more information, see <a href="#">Table 13-23</a> )                            |

**Table 13-26. Signal Group Parameter Controls to Different Interface I/O Pads Mapping (continued)**

| Pad Group Configurable Interface | Bit Fields for Pad Group Control                                                                    | Pads in Group                                                       | Type of I/O Group-Associated Control Bit Fields                                                                                               |
|----------------------------------|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
|                                  | CONTROL_CONTROL_PROG_I<br>O1[20]PRG_SDMMC1_SPEEDCTRL;                                               |                                                                     | Speed control common for SDMMC1 I/Os<br>(for more information, see <a href="#">Section 13.5.2.3, Speed Control and Voltage Supply State</a> ) |
| MMC/SD/SDIO2                     | CONTROL_CONTROL_PROG_I<br>O1[16]PRG_SDMMC2_MIN_CFG_LB                                               | sdmmc2_clk;<br>sdmmc2_cmd;<br>sdmmc2_dat0 – sdmmc2_dat3             | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                              |
|                                  | CONTROL_CONTROL_PROG_I<br>O1[15]PRG_SDMMC2_EXT_LB                                                   | sdmmc2_dat4 – sdmmc2_dat7                                           | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                              |
| UART1                            | CONTROL_CONTROL_PROG_I<br>O1[14]PRG_UART1_LB                                                        | uart1_tx;<br>uart1_rx;<br>uart1_cts;<br>uart1_rts                   | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                              |
| UART2                            | CONTROL_CONTROL_PROG_I<br>O1[1] PRG_UART2_LB                                                        | uart2_tx;<br>uart2_rx;<br>uart2_cts;<br>uart2_rts                   | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                              |
| UART3                            | CONTROL_CONTROL_PROG_I<br>O1[13:12]PRG_UART3_SC;<br>CONTROL_CONTROL_PROG_I<br>O1[11:10]PRG_UART3_LB | uart3_cts_rctx;<br>uart3_rts_sd;<br>uart3_rx_irrx;<br>uart3_tx_irtx | Low-speed I/O LB[1: 0] + SC[1:0] controls<br>(for more information, see <a href="#">Table 13-21</a> and <a href="#">Table 13-22</a> )         |
| McBSP common                     | CONTROL_CONTROL_PROG_I<br>O1[8]PRG_MCBSP_CLKS_LB                                                    | mcbsp_clks                                                          | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                              |
| McBSP1                           | CONTROL_CONTROL_PROG_I<br>O1[9]PRG_MCBSP1_DUPLEX_LB                                                 | mcbsp1_clkr;<br>mcbsp1_fsr                                          | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                              |
|                                  | CONTROL_CONTROL_PROG_I<br>O1[7]PRG_MCBSP1_LB                                                        | mcbsp1_dx;<br>mcbsp1_dr;<br>mcbsp1_fx;<br>mcbsp1_clkx               |                                                                                                                                               |
| McBSP2                           | CONTROL_CONTROL_PROG_I<br>O2[31] PRG_MCBSP2_LB                                                      | mcbsp2_dx;<br>mcbsp2_dr;<br>mcbsp2_fx;<br>mcbsp2_clkx               | High speed I/Os single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                             |
| McBSP3                           | CONTROL_CONTROL_PROG_I<br>O1[6]PRG_MCBSP3_LB                                                        | mcbsp3_dx;<br>mcbsp3_dr;<br>mcbsp3_fx;<br>mcbsp3_clkx               | High speed I/Os single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                             |
| McBSP4                           | CONTROL_CONTROL_PROG_I<br>O1[5]PRG_MCBSP4_LB                                                        | mcbsp4_dx;<br>mcbsp4_dr;<br>mcbsp4_fx;<br>mcbsp4_clkx               | High speed I/Os single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                             |
| McSPI1                           | CONTROL_CONTROL_PROG_I<br>O2[1]PRG_MCSPI1_MIN_CFG_LB                                                | mcspi1_clk;<br>mcspi1_simo;<br>mcspi1_somi;<br>mcspi1_cs0           | High speed I/Os single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                             |
|                                  | CONTROL_CONTROL_PROG_I<br>O2[0]PRG_MCSPI1_CS1_LB                                                    | mcspi1_cs1                                                          |                                                                                                                                               |
|                                  | CONTROL_CONTROL_PROG_I<br>O1[4]PRG_MCSPI1_CS2_LB                                                    | mcspi1_cs2                                                          |                                                                                                                                               |
|                                  | CONTROL_CONTROL_PROG_I<br>O1[3]PRG_MCSPI1_CS3_LB                                                    | mcspi1_cs3                                                          |                                                                                                                                               |

**Table 13-26. Signal Group Parameter Controls to Different Interface I/O Pads Mapping (continued)**

| Pad Group Configurable Interface | Bit Fields for Pad Group Control                                                                                | Pads in Group                                                                                                                      | Type of I/O Group-Associated Control Bit Fields                                                                                                                            |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| McSPI2                           | CONTROL.CONTROL_PROG_I_O1[2]PRG_MCSPI2_LB                                                                       | mcspi2_clk;<br>mcspi2_simo;<br>mcspi2_somi;<br>mcspi2_cs0;<br>mcspi2_cs1                                                           | High speed I/Os single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                                                          |
| EPM                              | CONTROL.CONTROL_PROG_I_O2[29]PRG_ETK_CUT2_LB                                                                    | etk_clk;<br>etk_ctl;<br>etk_d0 – etk_d9                                                                                            | High speed I/Os single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                                                          |
|                                  | CONTROL.CONTROL_PROG_I_O2[28]PRG_ETK_CUT1_LB                                                                    | etk_d10 – etk_d15                                                                                                                  |                                                                                                                                                                            |
| CHASSIS/D2D                      | CONTROL.CONTROL_PROG_I_O2[26:25]PRG_CHASSIS_CLOC_K_SC;<br>CONTROL.CONTROL_PROG_I_O2[24:23]PRG_CHASSIS_CLOC_K_LB | chassis_clk26mi                                                                                                                    | Low speed I/Os LB[1:0]+SC[1:0] controls,<br>(for more information, see <a href="#">Table 13-21</a> and <a href="#">Table 13-22</a> )                                       |
| CHASSIS/D2D                      | CONTROL.CONTROL_PROG_I_O2[22:21]PRG_CHASSIS_INT_SC;<br>CONTROL.CONTROL_PROG_I_O2[20:19]PRG_CHASSIS_INT_LB       | chassis_nirq;<br>chassis_fiq;<br>chassis_armirq;<br>chassis_ivairq                                                                 | Low speed I/Os LB[1:0]+SC[1:0] controls,<br>(for more information, see <a href="#">Table 13-21</a> and <a href="#">Table 13-22</a> )                                       |
|                                  | CONTROL.CONTROL_PROG_I_O2[18:17]PRG_CHASSIS_DMA_SC;<br>CONTROL.CONTROL_PROG_I_O2[16:15]PRG_CHASSIS_DMA_LB;      | chassis_dmareq0 – chassis_dmareq3                                                                                                  |                                                                                                                                                                            |
|                                  | CONTROL.CONTROL_PROG_I_O2[27]PRG_CHASSIS_AD2D_LB                                                                | sad2d_mcado – sad2d_mcad36;<br>sad2d_mwrite;<br>sad2d_swrite;<br>sad2d_mread;<br>sad2d_sread;<br>sad2d_mbusflag;<br>sad2d_sbusflag | High-speed I/O single-bit LB control<br>(for more information, see <a href="#">Table 13-20</a> )                                                                           |
|                                  | CONTROL.CONTROL_PROG_I_O2[14]PRG_CHASSIS_PRCM_LB                                                                | chassis_mstdby;<br>chassis_idlereq;<br>chassis_idleack                                                                             |                                                                                                                                                                            |
| I2C1                             | CONTROL.CONTROL_PROG_I_O2[6]PRG_CHASSIS_JTAG_LB_STR                                                             | chassis_ntrst;<br>chassis_tdi;<br>chassis_tdo;<br>chassis_tms;<br>chassis_tck;<br>chassis_rtck                                     |                                                                                                                                                                            |
|                                  | CONTROL.CONTROL_PROG_I_O_WKUP1[10]PRG_CHASSIS_PRCM_LB_WKUP                                                      | chassis_swakeup                                                                                                                    |                                                                                                                                                                            |
|                                  | CONTROL.CONTROL_PROG_I_O2[13:12]PRG_I2C1_HS                                                                     | i2c1_scl;<br>i2c1_sda                                                                                                              | I2C-specific LB[1:0] setting<br>(for more information, see <a href="#">Table 13-24</a> and <a href="#">Table 13-25</a> )                                                   |
| I2C2                             | CONTROL.CONTROL_PROG_I_O1[19]PRG_I2C1_PULLUPRES_X                                                               |                                                                                                                                    | I2C1-internal pullup resistors enable control (for more information, see <a href="#">Section 13.4.7.6.6, I2Cx I/Os Group Pullupresx Controls and Load Range Settings</a> ) |
|                                  | CONTROL.CONTROL_PROG_I_O2[11:10]PRG_I2C2_FS                                                                     | i2c2_scl;<br>i2c2_sda                                                                                                              | I2C-specific LB[1:0] setting<br>(for more information, see <a href="#">Table 13-24</a> and <a href="#">Table 13-25</a> )                                                   |

**Table 13-26. Signal Group Parameter Controls to Different Interface I/O Pads Mapping (continued)**

| Pad Group Configurable Interface | Bit Fields for Pad Group Control                                                                                    | Pads in Group         | Type of I/O Group-Associated Control Bit Fields                                                                                                                            |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  | CONTROL.CONTROL_PROG_I<br>O1[0]PRG_I2C2_PULLUPRESX                                                                  |                       | I2C2–internal pullup resistors enable control (for more information, see <a href="#">Section 13.4.7.6.6, I2Cx I/Os Group Pullupresx Controls and Load Range Settings</a> ) |
| I2C3                             | CONTROL.CONTROL_PROG_I<br>O2[9:8]PRG_I2C3_FS                                                                        | I2c3_scl;<br>I2c3_sda | I2C-specific LB[1:0] setting (for more information, see <a href="#">Table 13-24</a> and <a href="#">Table 13-25</a> )                                                      |
|                                  | CONTROL.CONTROL_PROG_I<br>O2[7]PRG_I2C3_PULLUPRESX                                                                  |                       | I2C3–internal pullup resistors enable control (for more information, see <a href="#">Section 13.4.7.6.6, I2Cx I/Os Group Pullupresx Controls and Load Range Settings</a> ) |
| I2C4                             | CONTROL.CONTROL_PROG_I<br>O_WKUP1[4:3]PRG_SR_LB                                                                     | I2c4_scl;<br>I2c4_sda | I2C-specific LB[1:0] setting (for more information, see <a href="#">Table 13-24</a> and <a href="#">Table 13-25</a> )                                                      |
|                                  | CONTROL.CONTROL_PROG_I<br>O_WKUP1[5]PRG_SR_PULLUPRESX                                                               |                       | I2C4–internal pullup resistors enable control (for more information, see <a href="#">Section 13.4.7.6.6, I2Cx I/Os Group Pullupresx Controls and Load Range Settings</a> ) |
| HDQ                              | CONTROL.CONTROL_PROG_I<br>O2[5:4]PRG_HDQ_LB<br>CONTROL.CONTROL_PROG_I<br>O2[3:2]PRG_HDQ_SC                          | hdq_sio               | Low-speed I/O LB[1: 0] + SC[1:0] controls (for more information, see <a href="#">Table 13-21</a> and <a href="#">Table 13-22</a> )                                         |
| System I/Os                      | CONTROL.CONTROL_PROG_I<br>O2[30] PRG_CLKOUT2_LB                                                                     | sys_clkout2           | High-speed I/O single-bit LB control (for more information, see <a href="#">Table 13-20</a> )                                                                              |
|                                  | CONTROL.CONTROL_PROG_I<br>O_WKUP1[19] PRG_SYSBOOT_LB                                                                | sysboot_0 – sysboot_6 |                                                                                                                                                                            |
|                                  | CONTROL.CONTROL_PROG_I<br>O_WKUP1[31:30]PRG_32K_SC;<br>CONTROL.CONTROL_PROG_I<br>O_WKUP1[29:28]PRG_32K_LB           | sys_32k               | Low-speed I/O LB[1: 0] + SC[1:0] controls (for more information, see <a href="#">Table 13-21</a> and <a href="#">Table 13-22</a> )                                         |
|                                  | CONTROL.CONTROL_PROG_I<br>O_WKUP1[27:26]PRG_CLKREQ_SC ;<br>CONTROL.CONTROL_PROG_I<br>O_WKUP1[25:24]PRG_CLKREQ_LB    | sys_clkreq            |                                                                                                                                                                            |
|                                  | CONTROL.CONTROL_PROG_I<br>O_WKUP1[23:22]PRG_NIRQ_SC ;<br>CONTROL.CONTROL_PROG_I<br>O_WKUP1[21:20]PRG_NIRQ_LB        | sys_nirq              |                                                                                                                                                                            |
|                                  | CONTROL.CONTROL_PROG_I<br>O_WKUP1[18:17]PRG_OFFMO_DE_SC;<br>CONTROL.CONTROL_PROG_I<br>O_WKUP1[16:15]PRG_OFFMO_DE_LB | sys_offmode           |                                                                                                                                                                            |
|                                  | CONTROL.CONTROL_PROG_I<br>O_WKUP1[14:13]PRG_CLKOUT1_SC;<br>CONTROL.CONTROL_PROG_I<br>O_WKUP1[12:11]PRG_CLKOUT1_LB   | sys_clkout1           |                                                                                                                                                                            |

**Table 13-26. Signal Group Parameter Controls to Different Interface I/O Pads Mapping (continued)**

| Pad Group Configurable Interface | Bit Fields for Pad Group Control                                                                          | Pads in Group | Type of I/O Group-Associated Control Bit Fields |
|----------------------------------|-----------------------------------------------------------------------------------------------------------|---------------|-------------------------------------------------|
|                                  | CONTROL.CONTROL_PROG_I_O_WKUP1[9:8]PRG_GPIO_128_SC;<br>CONTROL.CONTROL_PROG_I_O_WKUP1[7:6]PRG_GPIO_128_LB | gpio_128      |                                                 |

### 13.4.8 Protection Status Registers

Table 13-27 lists the status registers.

**Table 13-27. Protection Status Registers**

| Physical Address | Register Name                                       | Description                            | Access     |
|------------------|-----------------------------------------------------|----------------------------------------|------------|
| 0x4800 22E4      | <a href="#">CONTROL.PROT_ERR_STATUS</a>             | Protection error status register       | Public (R) |
| 0x4800 22E8      | <a href="#">CONTROL.PROT_ERR_STATUS_DEBUG</a><br>UG | Protection error status register debug | Public (R) |

These registers do not depend on the device type.

The [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS](#), and [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS\\_DEBUG](#) registers can be read in public mode, but cannot be written.

These bits are cleared when the L3 and L4 firewall embedded error log registers are cleared. All bits in these registers reflect device internal events related to the device protection.

On a specific event (signal rising edge), the corresponding bit is set. On a rising edge, the input signal must stay high for at least two interface clocks periods to be recognized. Software must clear each bit after reviewing the events.

When a protection violation occurs, the following bits are set:

- In application mode:
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS \[00\]](#) = OCM-ROM protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS \[01\]](#) = OCM-RAM protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS \[02\]](#) = GPMC protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS \[04\]](#) = SMS protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS \[06\]](#) = IVA2.2 protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS \[07\]](#) = L4-Core protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS \[12\]](#) = L3 RT protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS \[15\]](#) = D2D protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS \[16\]](#) = L4-Peri protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS \[17\]](#) = L4-Emu protection violation
- In debug mode:
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS\\_DEBUG \[00\]](#) = OCM-ROM protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS\\_DEBUG \[01\]](#) = OCM-RAM protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS\\_DEBUG \[02\]](#) = GPMC protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS\\_DEBUG \[03\]](#) = SMS protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS\\_DEBUG \[06\]](#) = IVA2.2 protection violation
  - [CONTROL.CONTROL\\_PROT\\_ERR\\_STATUS\\_DEBUG \[12\]](#) = L3 RT protection violation

For more information, see [Chapter 9, Interconnect](#).

### 13.4.9 SDRC Registers

[Table 13-28](#) lists the SDRAM controller (SDRC) registers, which export reset values to the SDRC registers.

**Table 13-28. SDRC Registers**

| Physical Address | Register Name                        | Description                   | Access |
|------------------|--------------------------------------|-------------------------------|--------|
| 0x4800 2460      | <a href="#">CONTROL_SDRC_SHARING</a> | SDRC sharing configuration    | R/W    |
| 0x4800 2464      | <a href="#">CONTROL_SDRC_MCFG0</a>   | SDRC configuration register 0 | R/W    |
| 0x4800 2468      | <a href="#">CONTROL_SDRC_MCFG1</a>   | SDRC configuration register 1 | R/W    |

At reset, the following occur:

- CONTROL.[CONTROL\\_SDRC\\_SHARING](#)[30:0] copies into SDRC.SDRC\_SHARING[30:0].
- CONTROL.[CONTROL\\_SDRC\\_MCFG0](#)[30:0] copies into SDRC.SDRC\_MCFG\_0[30:0].
- CONTROL.[CONTROL\\_SDRC\\_MCFG1](#)[30:0] copies into SDRC.SDRC\_MCFG\_1[30:0].

When LOCK bit SDRC.SDRC\_SHARING[30] is set, a copy of SDRC.SDRC\_SHARING[30:0] is made into CONTROL.[CONTROL\\_SDRC\\_SHARING](#)[30:0].

When LOCK bit SDRC.SDRC\_MCFG\_0[30] is set, a copy of SDRC.SDRC\_MCFG\_0[30:0] is made into CONTROL.[CONTROL\\_SDRC\\_MCFG0](#)[30:0].

When LOCK bit SDRC.SDRC\_MCFG\_1[30] is set, a copy of SDRC.SDRC\_MCFG\_1[30:0] is made into CONTROL.[CONTROL\\_SDRC\\_MCFG1](#)[30:0].

### 13.4.10 Debug and Observability

#### 13.4.10.1 Description

[Figure 13-17](#) is an overview of observability multiplexing, which minimizes the number of signals exchanged at the power domain boundary.

**Figure 13-17. Overview of the Debug and Observability Register Functionality**



scm-017

Two layers of multiplexer are used to select the set of internal observable signals (PRCM signals, DMA requests, and interrupts) to be routed to the pins dedicated to the hardware debug.

The first layer is in the CORE power domain. It is controlled by the core control module registers and selects the set of internal signals from the CORE power domain to be routed. The second layer is in the WKUP power domain. It is controlled by the wake-up control module registers and selects the set of internal signals from the WKUP power domain.

The pads used for the hardware debug must be properly configured by selecting the hardware debug function (hw\_dbg0) of the pad. To configure the pads, select mode 5 (0b101) in the MUXMODE bit field of the CONTROL.CONTROL\_PADCONF\_CAM\_x register (only for hw\_dbg0 to hw\_dbg11), or select mode 7 (0b111) in the MUXMODE bit field of the CONTROL.CONTROL\_PADCONF\_ETK\_x register (for all hw\_dbg). Before selecting the CORE signals, the WKUPOBSMUX bit field of the CONTROL.CONTROL\_WKUP\_DEBOBS\_n registers must be set to 0.

**Table 13-29. Observability Registers**

| Physical Address | Register Name                    | Description                                        | Access      |     |
|------------------|----------------------------------|----------------------------------------------------|-------------|-----|
|                  |                                  |                                                    | Device Type |     |
|                  |                                  |                                                    | E/T/G       | S/B |
| 0x4800 2420      | <a href="#">CONTROL_DEBOBS_0</a> | Set and configure CORE observable signals 1 and 0. | R/W         | R   |
| 0x4800 2424      | <a href="#">CONTROL_DEBOBS_1</a> | Set and configure CORE observable signals 3 and 2. | R/W         | R   |
| 0x4800 2428      | <a href="#">CONTROL_DEBOBS_2</a> | Set and configure CORE observable signals 5 and 4. | R/W         | R   |

**Table 13-29. Observability Registers (continued)**

| Physical Address | Register Name         | Description                                            | Access      |     |
|------------------|-----------------------|--------------------------------------------------------|-------------|-----|
|                  |                       |                                                        | Device Type |     |
|                  |                       |                                                        | E/T/G       | S/B |
| 0x4800 242C      | CONTROL_DEBOBS_3      | Set and configure CORE observable signals 7 and 6.     | R/W         | R   |
| 0x4800 2430      | CONTROL_DEBOBS_4      | Set and configure CORE observable signals 9 and 8.     | R/W         | R   |
| 0x4800 2434      | CONTROL_DEBOBS_5      | Set and configure CORE observable signals 11 and 10.   | R/W         | R   |
| 0x4800 2438      | CONTROL_DEBOBS_6      | Set and configure CORE observable signals 13 and 12.   | R/W         | R   |
| 0x4800 243C      | CONTROL_DEBOBS_7      | Set and configure CORE observable signals 15 and 14.   | R/W         | R   |
| 0x4800 2440      | CONTROL_DEBOBS_8      | Set and configure CORE observable signals 17 and 16.   | R/W         | R   |
| 0x4800 2A68      | CONTROL_WKUP_DEBOBS_0 | Set and configure WKUP observable pins 3, 2, 1, 0.     | R/W         | R   |
| 0x4800 2A6C      | CONTROL_WKUP_DEBOBS_1 | Set and configure WKUP observable pins 7, 6, 5, 4.     | R/W         | R   |
| 0x4800 2A70      | CONTROL_WKUP_DEBOBS_2 | Set and configure WKUP observable pins 11, 10, 9, 8.   | R/W         | R   |
| 0x4800 2A74      | CONTROL_WKUP_DEBOBS_3 | Set and configure WKUP observable pins 15, 14, 13, 12. | R/W         | R   |
| 0x4800 2A78      | CONTROL_WKUP_DEBOBS_4 | Set and configure WKUP observable pins 17, 16.         | R/W         | R   |

The write capabilities of these registers differ according to the device type.

Perform the following steps to configure observability:

1. To configure the pads properly for hardware debug and observability, select the hardware debug (hw\_dbg) function mode 5 in the MUXMODE bit field of the CONTROL.CONTROL\_PADCONF\_CAM\_X or mode 7 in the MUXMODE bit field of the CONTROL.CONTROL\_PADCONF\_ETK\_X registers.
2. For the observability pads, set the proper values of the WKUPOBSMUX field CONTROL.CONTROL\_WKUP\_DEBOBS\_n. Up to 5 bits are used to select the signal set to be observed (0x00 selection sets the output to CORE\_OBSMUXn signal). For more information, see the description of each register in [Section 13.4.10.2, Observability Tables](#).
3. To observe the CORE\_OBSMUXn signals from the first layer of the multiplexer, set the WKUPOBSMUX field CONTROL.CONTROL\_WKUP\_DEBOBS\_n to 0x00, and then set the proper values of the OBMUX field CONTROL.CONTROL\_DEBOBS\_n. A maximum of 7 bits is used to select the signal set to be observed (0b0000000 selection sets the output to 0).

For more information, see the description of each register in [Section 13.4.10.2, Observability Tables](#).

The observability feature of the CONTROL.CONTROL\_DEBOBS\_n registers can be gated by setting the CONTROL.CONTROL\_PROT\_CTRL[5] OBSERVABILITYDISABLE bit to 0x1. If the user configures the pads for hardware observability, selected to observe CORE\_OBSMUXn signals and set to OBSERVABILITYDISABLE = 0x1, the corresponding hw\_dbg outputs are set to 0. Observability of the CORE\_OBSMUXn signal is enabled by default (POR value OBSERVABILITYDISABLE = 0x0). Because the type of this bit is read/one-change only (R/OCO), the CORE\_OBSMUXn signals can be gated only once after a POR event.

The observability feature of the CONTROL.CONTROL\_WKUP\_DEBOBS\_n registers can be gated using the WKUPOBSERVABILITYDISABLE bit CONTROL.CONTROL\_WKUP\_DEBOBS\_4[31]. If this bit is set, and the pads are configured for hardware observability of the WKUP mux set signals, the corresponding hw\_dbg outputs are set to 0. Observability of the WKUP mux set signals is enabled by default (POR value WKUPOBSERVABILITYDISABLE = 0x0).

Because the type of this bit is read/one-change only (R/OCO), the WKUP mux set signals can be gated only once after a POR event.

**NOTE:** The OBSERVABILITYDISABLE and WKUPOBSERVABILITYDISABLE bits are of the type (R/OCO) to which the following rules apply:

- Write actions that do not change the bit reset value are not considered.
- The first write action that changes the bit reset value is considered, but any subsequent write actions are ignored. No more write actions are effective until the next POR.

**NOTE:** To disable observability for all hw\_dbg I/Os (that is, drive the external observability outputs to 0), observability of the CORE and WKUP domains must be disabled. Disabling only wkup\_observability is not sufficient.

### 13.4.10.2 Observability Tables

This section gives information about all modules and features in the high-tier device. To check the availability of modules and features, see [Section 1.5, AM/DM37x Family](#). Unavailable module and feature pins are not functional.

[Table 13-30](#) through [Table 13-65](#) define the mapped internal signals for each OBSMUX and WKUPOBSMUX value.

**Table 13-30. Internal Signals Multiplexed on OBSMUX0**

| Out Signal Name             | Muxed Signal Name        | OBSMUX0 Field<br>CONTROL.CONT<br>ROL_DEBOBS_0<br>[22:16] (dec) | Description                                                                                                                                          | High State           | Low State             |
|-----------------------------|--------------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-----------------------|
| CORE_OBSMUX0 <sup>(1)</sup> | tie_low                  | 0                                                              | -                                                                                                                                                    | -                    | -                     |
|                             | CM_96_FCLK               | 1                                                              | 96-MHz functional clock of the CM module                                                                                                             | -                    | -                     |
|                             | CM_32K_CLK               | 2                                                              | 32-kHz functional clock of the CM module                                                                                                             | -                    | -                     |
|                             | PRCM_DPLL3_enable        | 3                                                              | Signal used to enable DPLL3.                                                                                                                         | DPLL is enabled.     | DPLL is disabled.     |
|                             | PRCM_CAM_domainFreeze    | 4                                                              | Indicates whether the CAM domain is frozen                                                                                                           | Domain is frozen.    | Domain is not frozen. |
|                             | PRCM_NEON_forceWakeups   | 5                                                              | Indicates whether a wakeup of the NEON domain is forced                                                                                              | Wakeup is forced.    | Wakeup is not forced. |
|                             | PRCM_COREL4_domainNready | 6                                                              | Indicates whether the CORE_L4 domain is ready. In other words, is domain transition ongoing?                                                         | Domain is not ready. | Domain is ready.      |
|                             | PRCM_WKUP_domainNready   | 7                                                              | Indicates whether the WKUP domain is ready. In other words, is domain transition ongoing?                                                            | Domain is not ready. | Domain is ready.      |
|                             | PRCM_STATE_IS_OFF_IVA2   | 8                                                              | Indicates to the global power manager FSM that the IVA2 domain power state is ON                                                                     | FSM state is OFF.    | FSM state is not OFF. |
|                             | Reserved                 | (10:9)                                                         | -                                                                                                                                                    | -                    | -                     |
|                             | SAD2D_MSTANDBY           | 11                                                             | SAD2D Mstandby assertion                                                                                                                             | -                    | -                     |
|                             | Reserved                 | 12                                                             | -                                                                                                                                                    | -                    | -                     |
|                             | SAD2D_GICLK              | 13                                                             | Interface clock of the L4 interconnect in the SAD2D domain                                                                                           | -                    | -                     |
|                             | Reserved                 | (16:14)                                                        | -                                                                                                                                                    | -                    | -                     |
|                             | sdma_PI_DMAREQ           | (87:17)                                                        | DMA requests lines mapped to the system DMA module. See <a href="#">Chapter 11, DMA</a> , for more information about the system DMA request mapping. | -                    | -                     |

<sup>(1)</sup> 0x00 in WKUPOBSMUX0 field CONTROL.CONTROL\_WKUP\_DEBOBS\_0[4:0]

**Table 13-30. Internal Signals Multiplexed on OBSMUX0 (continued)**

| Out Signal Name | Muxed Signal Name | OBSMUX0 Field<br><b>CONTROL.CONTROL_</b><br><b>ROL_DEBOBS_0</b><br>[22:16] (dec) | Description                                                                                                                   | High State | Low State |
|-----------------|-------------------|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|------------|-----------|
|                 | sgx_SINTERRUPTN   | (104:88)                                                                         | Interrupt lines from the SGX. See <a href="#">Chapter 8</a> , SGX, for more information about the interrupt requests mapping. | -          | -         |
|                 | Reserved          | (127:105)                                                                        | -                                                                                                                             | -          | -         |

**Table 13-31. Internal Signals Multiplexed on OBSMUX1**

| Out Signal Name             | Muxed Signal Name          | OBSMUX1 Field<br><b>CONTROL.CONTROL_</b><br><b>ROL_DEBOBS_0[6:0]</b><br>] (dec) | Description                                                                                                                                          | High State                     | Low State                       |
|-----------------------------|----------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|---------------------------------|
| CORE_OBSMUX1 <sup>(1)</sup> | tie_low                    | 0                                                                               | -                                                                                                                                                    | -                              | -                               |
|                             | PRCM_DPLL3_M2_CLK          | 1                                                                               | M2 clock generated by DPLL3                                                                                                                          | -                              | -                               |
|                             | CM_SYS_CLK                 | 2                                                                               | System clock                                                                                                                                         | -                              | -                               |
|                             | PRCM_DPLL3_enablediv       | 3                                                                               | Signal used to enable the clock divisor of DPLL3                                                                                                     | DPLL clock divisor is enabled. | DPLL clock divisor is disabled. |
|                             | PRCM_DPLL2_ClklsNotRunning | 4                                                                               | Indicates whether the clock of DPLL2 is running or not                                                                                               | Clock is not running.          | Clock is running.               |
|                             | PRCM_NEON_domainNready     | 5                                                                               | Indicates whether the NEON domain is ready. In other words, is domain transition ongoing?                                                            | Domain is not ready.           | Domain is ready.                |
|                             | PRCM_CORED2D_domainNready  | 6                                                                               | Indicates if the CORE_D2D domain is ready. In other words, is domain transition ongoing?                                                             | Domain is not ready.           | Domain is ready.                |
|                             | PRCM_WKUP_domainNready     | 7                                                                               | Indicates whether the WKUP domain is ready. In other words, is domain transition ongoing?                                                            | Domain is not ready.           | Domain is ready.                |
|                             | PRCM_STATE_IS_ON_CORE      | 8                                                                               | Indicates to the global power manager FSM that the MPU domain power state is ON                                                                      | FSM state is ON.               | FSM state is not ON.            |
|                             | Reserved                   | (10:9)                                                                          | -                                                                                                                                                    | -                              | -                               |
|                             | SAD2D.WAIT                 | 11                                                                              | SAD2D wait signal                                                                                                                                    | -                              | -                               |
|                             | Reserved                   | 12                                                                              | -                                                                                                                                                    | -                              | -                               |
|                             | PRCM_CORE_96M_GFCLK        | 13                                                                              | 96-MHz functional clock of the CORE domain                                                                                                           | -                              | -                               |
|                             | Reserved                   | (16:14)                                                                         | -                                                                                                                                                    | -                              | -                               |
|                             | sdma_PI_DMAREQ             | (87:17)                                                                         | DMA requests lines mapped to the system DMA module. See <a href="#">Chapter 11</a> , DMA, for more information about the system DMA request mapping. | -                              | -                               |
|                             | Reserved                   | (127:88)                                                                        | -                                                                                                                                                    | -                              | -                               |

<sup>(1)</sup> 0x00 in WKUPOBSMUX1 field CONTROL.CONTROL\_WKUP\_DEBOBS\_0[12:8]

**Table 13-32. Internal Signals Multiplexed on OBSMUX2**

| Out Signal Name             | Muxed Signal Name | OBSMUX2 Field<br><b>CONTROL.CONTROL_</b><br><b>DEBOBS_1[22:16]</b><br>(dec) | Description | High State | Low State |
|-----------------------------|-------------------|-----------------------------------------------------------------------------|-------------|------------|-----------|
| CORE_OBSMUX2 <sup>(1)</sup> | tie_low           | 0                                                                           | -           | -          | -         |

<sup>(1)</sup> 0x00 in WKUPOBSMUX2 field CONTROL.CONTROL\_WKUP\_DEBOBS\_0[20:16]

**Table 13-32. Internal Signals Multiplexed on OBSMUX2 (continued)**

| Out Signal Name | Muxed Signal Name            | OBSMUX2 Field<br><b>CONTROL.CONTROL_DEBOBS_1[22:16]</b><br>(dec) | Description                                                                                                                                          | High State                | Low State                     |
|-----------------|------------------------------|------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-------------------------------|
|                 | PRCM_DPLL3_M2X2_CLK          | 1                                                                | M2X2 clock generated by DPLL3                                                                                                                        | -                         | -                             |
|                 | PRCM_DPLL1_freqlock          | 2                                                                | Indicates whether the frequency of DPLL1 is locked                                                                                                   | DPLL frequency is locked. | DPLL frequency is not locked. |
|                 | PRCM_DPLL4_freqlock          | 3                                                                | Indicates whether the frequency of DPLL4 is locked                                                                                                   | DPLL frequency is locked. | DPLL frequency is not locked. |
|                 | PRCM_COREL3_IclkIsNotRunning | 4                                                                | Indicates whether the interface clock of the COREL3 domain is running or not.                                                                        | Clock is not running.     | Clock is running.             |
|                 | PRCM_NEON_forceSleep         | 5                                                                | Indicates whether the NEON domain is forced to sleep mode                                                                                            | Sleep mode is forced.     | Sleep mode is not forced.     |
|                 | PRCM_CAM_domainIsIdle        | 6                                                                | Indicates whether CAM domain is idle                                                                                                                 | Domain is in Idle mode.   | Domain is not in Idle mode.   |
|                 | PRCM_EMU_domainIsIdle        | 7                                                                | Indicates whether EMU domain is idle                                                                                                                 | Domain is in Idle mode.   | Domain is not in Idle mode.   |
|                 | PRCM_STATE_IS_OFF_CORE       | 8                                                                | Indicates to the global power manager FSM that the MPU domain power state is OFF                                                                     | FSM state is OFF.         | FSM state is not OFF.         |
|                 | Reserved                     | (12:9)                                                           | -                                                                                                                                                    | -                         | -                             |
|                 | PRCM_CORE_48M_GFCLK          | 13                                                               | 96-MHz functional clock of the CORE domain                                                                                                           | -                         | -                             |
|                 | Reserved                     | (16:14)                                                          | -                                                                                                                                                    | -                         | -                             |
|                 | sdma_PI_DMAREQ               | (87:17)                                                          | DMA requests lines mapped to the system DMA module. See <a href="#">Chapter 11, DMA</a> , for more information about the system DMA request mapping. | -                         | -                             |
|                 | Reserved                     | (127:88)                                                         | -                                                                                                                                                    | -                         | -                             |

**Table 13-33. Internal Signals Multiplexed on OBSMUX3**

| Out Signal Name             | Muxed Signal Name             | OBSMUX3 Field<br><b>CONTROL.CONTROL_DEBOBS_1[6:0]</b> (dec) | Description                                                                       | High State                | Low State                   |
|-----------------------------|-------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------|---------------------------|-----------------------------|
| CORE_OBSMUX3 <sup>(1)</sup> | tie_low                       | 0                                                           | -                                                                                 | -                         | -                           |
|                             | PRCM_L3_ICLK                  | 1                                                           | Interface clock of the L3 interconnect                                            | -                         | -                           |
|                             | PRCM_DPLL1_bypass             | 2                                                           | Indicates whether the DPLL1 is bypassed, in other words if the clock divisor is 1 | DPLL is bypassed.         | DPLL is not bypassed.       |
|                             | PRCM_DPLL4_bypass             | 3                                                           | Indicates whether the DPLL4 is bypassed, in other words if the clock divisor is 1 | DPLL is bypassed.         | DPLL is not bypassed.       |
|                             | PRCM_CORED2D_IclkIsNotRunning | 4                                                           | Indicates whether the interface clock of the CORELD2D domain is running           | The clock is not running. | The clock is running.       |
|                             | PRCM_IVA2_domainIsIdle        | 5                                                           | Indicates whether the IVA2 domain is in idle                                      | Domain is in idle mode.   | Domain is not in Idle mode. |

<sup>(1)</sup> 0x00 in WKUPOBSMUX3 field CONTROL.CONTROL\_WKUP\_DEBOBS\_0[28:24]

**Table 13-33. Internal Signals Multiplexed on OBSMUX3 (continued)**

| Out Signal Name | Muxed Signal Name     | OBSMUX3 Field<br><b>CONTROL.CONTROL_DEBOBS_1[6:0]</b> (dec) | Description                                                                                                                                          | High State                 | Low State                      |
|-----------------|-----------------------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--------------------------------|
|                 | PRCM_CAM_forceWake up | 6                                                           | Indicates whether a wakeup of the CAM domain is forced                                                                                               | Wakeup is forced.          | Wakeup is not forced.          |
|                 | PRCM_EMU_domainMut e  | 7                                                           | Generated by EMU domain to indicate that it does not require services from domain A (Domain A can go in INACTIVE state)                              | Domain is in standby mode. | Domain is not in standby mode. |
|                 | PRCM_SEQ_FORCE CLKON  | 8                                                           | Indicates whether the EMU is forcing the IVA2 clocks to ON                                                                                           | Clocks are forced.         | Clocks are not forced.         |
|                 | Reserved              | (12:9)                                                      | —                                                                                                                                                    | —                          | —                              |
|                 | PRCM_CORE_12M_GFCLK   | 13                                                          | 12-MHz functional clock of the CORE domain                                                                                                           | —                          | —                              |
|                 | Reserved              | (16:14)                                                     | —                                                                                                                                                    | —                          | —                              |
|                 | sdma_PI_DMAREQ        | (87:17)                                                     | DMA requests lines mapped to the system DMA module. See <a href="#">Chapter 11, DMA</a> , for more information about the system DMA request mapping. | —                          | —                              |
|                 | iva_gl_dmarq_na       | (107:88)                                                    | DMA requests lines used by the IVA2 subsystem. See <a href="#">Chapter 5, IVA2 Subsystem</a> , for more information about these DMA request lines.   | —                          | —                              |
|                 | Reserved              | (127:108)                                                   | —                                                                                                                                                    | —                          | —                              |

**Table 13-34. Internal Signals Multiplexed on OBSMUX4**

| Out Signal Name             | Muxed Signal Name      | OBSMUX4 Field<br><b>CONTROL.CONTROL_DEBOBS_2[22:16]</b> (dec) | Description                                                                              | High State              | Low State                   |
|-----------------------------|------------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------|-------------------------|-----------------------------|
| CORE_OBSMUX4 <sup>(1)</sup> | tie_low                | 0                                                             | -                                                                                        | —                       | —                           |
|                             | PRCM_L4_ICLK           | 1                                                             | Interface clock of the L4 interconnect                                                   | —                       | —                           |
|                             | PRCM_DPLL1_idle        | 2                                                             | Indicates whether DPLL1 is idle                                                          | Domain is in idle mode. | Domain is not in Idle mode. |
|                             | PRCM_DPLL4_idle        | 3                                                             | Indicates whether DPLL4 is idle                                                          | Domain is in idle mode. | Domain is not in Idle mode. |
|                             | Reserved               | 4                                                             | —                                                                                        | —                       | —                           |
|                             | PRCM_IVA2_force Wakeup | 5                                                             | Indicates whether a wakeup of the IVA2 domain is forced                                  | Wakeup is forced.       | Wakeup is not forced.       |
|                             | PRCM_CAM_domain Nready | 6                                                             | Indicates whether the CAM domain is ready. In other words, is domain transition ongoing? | Domain is not ready.    | Domain is ready.            |
|                             | PRCM_EMU_force Wakeup  | 7                                                             | Indicates whether a wakeup of the EMU domain is forced                                   | Wakeup is forced.       | Wakeup is not forced.       |
|                             | SEQ_FORCECLKON ACK     | 8                                                             | Indicates whether the forcing to ON of the clocks of the IVA2 domain is acknowledged     | Command acknowledged    | Command not acknowledged    |
|                             | Reserved               | (12:9)                                                        | —                                                                                        | —                       | —                           |
|                             | PRCM_CORE_L3_GICLK     | 13                                                            | Interface clock of the L3 interconnect                                                   | —                       | —                           |
|                             | Reserved               | (16:14)                                                       | —                                                                                        | —                       | —                           |

<sup>(1)</sup> 0x00 in WKUPOBSMUX4 field CONTROL.CONTROL\_WKUP\_DEBOBS\_1[4:0]

**Table 13-34. Internal Signals Multiplexed on OBSMUX4 (continued)**

| Out Signal Name | Muxed Signal Name | OBSMUX4 Field<br><b>CONTROL.CONTROL_DEBOBS_2[22:16]</b><br>(dec) | Description                                                                                                                                                          | High State | Low State |
|-----------------|-------------------|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|
|                 | mpu_PIIRQ         | (112:17)                                                         | Interrupt request lines mapped to the interrupt controller. See <a href="#">Chapter 12, Interrupt Controller</a> , for more information about these interrupt lines. | -          | -         |
|                 | Reserved          | (127:113)                                                        | -                                                                                                                                                                    | -          | -         |

**Table 13-35. Internal Signals Multiplexed on OBSMUX5**

| Out Signal Name                            | Muxed Signal Name       | OBSMUX5 Field<br><b>CONTROL.CONTROL_D_EBOBS_2[6:0]</b> (dec) | Description                                                                                                                                                          | High State            | Low State                 |
|--------------------------------------------|-------------------------|--------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|---------------------------|
| <a href="#">CORE_OBSMUX5<sup>(1)</sup></a> | tie_low                 | 0                                                            | -                                                                                                                                                                    | -                     | -                         |
|                                            | PRCM_RM_ICLK            | 1                                                            | Interface clock of the RM block                                                                                                                                      | -                     | -                         |
|                                            | PRCM_DPLL1_initz        | 2                                                            | Lock sequence initialization (HLH) of DPLL1                                                                                                                          | -                     | -                         |
|                                            | PRCM_DPLL4_initz        | 3                                                            | Lock sequence initialization (HLH) of DPLL4                                                                                                                          | -                     | -                         |
|                                            | CM_SysClkIsRunning      | 4                                                            | Indicates whether the system clock is running or not                                                                                                                 | The clock is running. | The clock is not running. |
|                                            | PRCM_IVA2_domain_Nready | 5                                                            | Indicates whether the IVA2 domain is ready. In other words, is domain transition ongoing?                                                                            | Domain is not ready.  | Domain is ready.          |
|                                            | PRCM_CAM_forceSleep     | 6                                                            | Indicates whether the CAM domain is forced to sleep mode                                                                                                             | Sleep mode is forced. | Sleep mode is not forced. |
|                                            | PRCM_EMU_domain_Nready  | 7                                                            | Indicates whether the EMU domain is ready. In other words, is domain transition ongoing?                                                                             | Domain is not ready.  | Domain is ready.          |
|                                            | Reserved                | (12:8)                                                       | -                                                                                                                                                                    | -                     | -                         |
|                                            | PRCM_CORE_L4_GICLK      | 13                                                           | Interface clock of the L4 interconnect                                                                                                                               | -                     | -                         |
|                                            | Reserved                | (16:14)                                                      | -                                                                                                                                                                    | -                     | -                         |
|                                            | mpu_PIIRQ               | (112:17)                                                     | Interrupt request lines mapped to the interrupt controller. See <a href="#">Chapter 12, Interrupt Controller</a> , for more information about these interrupt lines. | -                     | -                         |
|                                            | Reserved                | (127:113)                                                    | -                                                                                                                                                                    | -                     | -                         |

<sup>(1)</sup> 0x00 in WKUPOBSMUX5 field CONTROL.CONTROL\_WKUP\_DEBOBS\_1[12:8]

**Table 13-36. Internal Signals Multiplexed on OBSMUX6**

| Out Signal Name                            | Muxed Signal Name  | OBSMUX6 Field<br><b>CONTROL.CONTROL_DEBOBS_3[22:16]</b><br>(dec) | Description                 | High State       | Low State         |
|--------------------------------------------|--------------------|------------------------------------------------------------------|-----------------------------|------------------|-------------------|
| <a href="#">CORE_OBSMUX6<sup>(1)</sup></a> | tie_low            | 0                                                                | -                           | -                | -                 |
|                                            | PRCM_FUNC_96M_FCLK | 1                                                                | 96-MHz functional clock     | -                | -                 |
|                                            | PRCM_DPLL1_enable  | 2                                                                | Signal used to enable DPLL1 | DPLL is enabled. | DPLL is disabled. |

<sup>(1)</sup> 0x00 in WKUPOBSMUX6 field CONTROL.CONTROL\_WKUP\_DEBOBS\_1[20:16]

**Table 13-36. Internal Signals Multiplexed on OBSMUX6 (continued)**

| Out Signal Name | Muxed Signal Name           | OBSMUX6 Field<br><b>CONTROL_CONTROL</b><br><b>_DEBOBS_3[22:16]</b><br>(dec) | Description                                                                                                                                                          | High State              | Low State                   |
|-----------------|-----------------------------|-----------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------------------|
|                 | PRCM_DPLL4_enable           | 3                                                                           | Signal used to enable DPLL4                                                                                                                                          | DPLL is enabled.        | DPLL is disabled.           |
|                 | PRCM_WKUP_IClkIsRunning     | 4                                                                           | Indicates whether the interface clock of the WKUP domain is running or not                                                                                           | The clock is running.   | The clock is not running.   |
|                 | PRCM_IVA2_forceSleep        | 5                                                                           | Indicates whether the IVA2 domain is forced to sleep mode                                                                                                            | Sleep mode is forced.   | Sleep mode is not forced.   |
|                 | PRCM_CAM_domainFreeze       | 6                                                                           | Indicates whether the CAM domain is frozen                                                                                                                           | Domain is frozen.       | Domain is not frozen.       |
|                 | PRCM_USBHOST_domainIsIdle   | 7                                                                           | Indicates whether the USBHOST domain is idle                                                                                                                         | Domain is in idle mode. | Domain is not in idle mode. |
|                 | Reserved                    | (11:8)                                                                      | —                                                                                                                                                                    | —                       | —                           |
|                 | PRCM_DSS_GICLK              | 12                                                                          | Interface clock of the DSS module                                                                                                                                    | —                       | —                           |
|                 | Reserved for non-GP devices | 13                                                                          | Reserved for non-GP devices                                                                                                                                          | —                       | —                           |
|                 | Reserved                    | (16:14)                                                                     | —                                                                                                                                                                    | —                       | —                           |
|                 | mpu_PIIRQ                   | (112:17)                                                                    | Interrupt request lines mapped to the interrupt controller. See <a href="#">Chapter 12, Interrupt Controller</a> , for more information about these interrupt lines. | —                       | —                           |
|                 | Reserved                    | (114:113)                                                                   | —                                                                                                                                                                    | —                       | —                           |
|                 | PRCM_DPLL1_LOSSREF          | 115                                                                         | Reference input loss acknowledge of DPLL1                                                                                                                            | Signal acknowledged     | Signal not acknowledged     |
|                 | PRCM_DPLL2_LOSSREF          | 116                                                                         | Reference input loss acknowledge of DPLL2                                                                                                                            | Signal acknowledged     | Signal not acknowledged     |
|                 | Reserved                    | (123:117)                                                                   | —                                                                                                                                                                    | —                       | —                           |
|                 | PRCM_DPLL3_LOSSREF          | 124                                                                         | Reference input loss acknowledge of DPLL3                                                                                                                            | Signal acknowledged     | Signal not acknowledged     |
|                 | PRCM_DPLL4_LOSSREF          | 125                                                                         | Reference input loss acknowledge of DPLL4                                                                                                                            | Signal acknowledged     | Signal not acknowledged     |
|                 | Reserved                    | (127:126)                                                                   | —                                                                                                                                                                    | —                       | —                           |

**Table 13-37. Internal Signals Multiplexed on OBSMUX7**

| Out Signal Name             | Muxed Signal Name                                   | OBSMUX7 Field<br><b>CONTROL_CONTROL_DEBOBS_3[6:0]</b> (dec) | Description                                                                                                                                                          | High State                         | Low State                           |
|-----------------------------|-----------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|-------------------------------------|
| CORE_OBSMUX7 <sup>(1)</sup> | tie_low                                             | 0                                                           | -                                                                                                                                                                    | -                                  | -                                   |
|                             | PRCM_FUNC_48M_FCLK                                  | 1                                                           | 48-MHz functional clock                                                                                                                                              | -                                  | -                                   |
|                             | PRCM_DPLL1_enablediv                                | 2                                                           | Signal used to enable the clock divisor of DPLL1                                                                                                                     | DPLL frequency divisor is enabled. | DPLL frequency divisor is disabled. |
|                             | PRCM_DPLL4_enablediv                                | 3                                                           | Signal used to enable the clock divisor of DPLL4                                                                                                                     | DPLL frequency divisor is enabled. | DPLL frequency divisor is disabled. |
|                             | This information is not available in public domain. | 4                                                           | This information is not available in public domain.                                                                                                                  |                                    |                                     |
|                             | PRCM_IVA2_domainFreeze                              | 5                                                           | Indicates whether the IVA2 domain is frozen                                                                                                                          | Domain is frozen.                  | Domain is not frozen.               |
|                             | PRCM_DSS_domainIsIdle                               | 6                                                           | Indicates whether the DSS domain is in idle                                                                                                                          | Domain is in idle mode.            | Domain is not in idle mode.         |
|                             | PRCM_USBHOST_forceWakeup                            | 7                                                           | Indicates whether a wakeup of the USBHOST domain is forced                                                                                                           | Wakeup is forced.                  | Wakeup is not forced.               |
|                             | Reserved                                            | (11:8)                                                      | -                                                                                                                                                                    | -                                  | -                                   |
|                             | PRCM_CAM_GICLK                                      | 12                                                          | Interface clock of the CAM module                                                                                                                                    | -                                  | -                                   |
|                             | Reserved for non-GP devices                         | 13                                                          | Reserved for non-GP devices                                                                                                                                          | -                                  | -                                   |
|                             | Reserved                                            | (16:14)                                                     | -                                                                                                                                                                    | -                                  | -                                   |
|                             | mpu_PIIRQ                                           | (112:17)                                                    | Interrupt request lines mapped to the interrupt controller. See <a href="#">Chapter 12, Interrupt Controller</a> , for more information about these interrupt lines. | -                                  | -                                   |
|                             | Reserved                                            | (114:113)                                                   | -                                                                                                                                                                    | -                                  | -                                   |
|                             | PRCM_DPLL1_BREAKLOCKZ                               | 115                                                         | Indicates whether DPLL1 is in frequency lock condition                                                                                                               | Lock conditions not reached        | Lock conditions reached             |
|                             | Reserved                                            | (121:116)                                                   | -                                                                                                                                                                    | -                                  | -                                   |
|                             | PRCM_DPLL2_BREAKLOCKZ                               | 122                                                         | Indicates whether DPLL2 is in frequency lock condition                                                                                                               | Lock conditions not reached        | Lock conditions reached             |
|                             | PRCM_DPLL3_BREAKLOCKZ                               | 123                                                         | Indicates whether DPLL3 is in frequency lock condition                                                                                                               | Lock conditions not reached        | Lock conditions reached             |
|                             | PRCM_DPLL4_BREAKLOCKZ                               | 124                                                         | Indicates whether DPLL4 is in frequency lock condition                                                                                                               | Lock conditions not reached        | Lock conditions reached             |
|                             | Reserved                                            | (127:125)                                                   | -                                                                                                                                                                    | -                                  | -                                   |

<sup>(1)</sup> 0x00 in WKUPOBSMUX7 field CONTROL.CONTROL\_WKUP\_DEBOBS\_1[28:24]

**Table 13-38. Internal Signals Multiplexed on OBSMUX8**

| Out Signal Name             | Muxed Signal Name         | OBSMUX8 Field<br><b>CONTROL_CONTROL_DEBOBS_4[22:16]</b><br>(dec) | Description                                                                              | High State                | Low State                     |
|-----------------------------|---------------------------|------------------------------------------------------------------|------------------------------------------------------------------------------------------|---------------------------|-------------------------------|
| CORE_OBSMUX8 <sup>(1)</sup> | tie_low                   | 0                                                                | -                                                                                        | -                         | -                             |
|                             | PRCM_DSS_TV_FCLK          | 1                                                                | Functional clock of the DSS module for TV output                                         | -                         | -                             |
|                             | PRCM_dpll2_BYPASS         | 2                                                                | Indicates whether DPLL2 is bypassed, in other words if the clock divisor is 1;           | DPLL is bypassed.         | DPLL is not bypassed.         |
|                             | PRCM_DPLL5_freqlock       | 3                                                                | Indicates whether the frequency of DPLL5 is locked                                       | DPLL frequency is locked. | DPLL frequency is not locked. |
|                             | PRCM_GFX_IClkIsNotRunning | 4                                                                | Indicates whether the interface clock of the 2D/3D graphics accelerator is running       | Clock is not running.     | Clock is running.             |
|                             | PRCM_SGX_domainIsIdle     | 5                                                                | Indicates whether SGX domain is idle                                                     | Domain is in idle mode.   | Domain is not in idle mode.   |
|                             | PRCM_DSS_forceWakeUp      | 6                                                                | Indicates whether a wakeup of the DSS domain is forced                                   | Wakeup is forced.         | Wakeup is not forced.         |
|                             | PRCM_USBHOST_domainNready | 7                                                                | Indicates whether the DSS domain is ready. In other words, is domain transition ongoing? | Domain is not ready.      | Domain is ready               |
|                             | Reserved                  | (11:8)                                                           | -                                                                                        | -                         | -                             |
|                             | PRCM_CSI2_96M_GFCLK       | 12                                                               | 96-MHz functional clock of the CSIB module                                               | -                         | -                             |
|                             | Reserved                  | (18:13)                                                          | -                                                                                        | -                         | -                             |
|                             | PRCM_DPLL1_PHASELOCK      | 19                                                               | Indicates whether DPLL1 is in phase lock condition                                       | Lock conditions reached   | Lock conditions not reached   |
|                             | Reserved                  | (25:20)                                                          | -                                                                                        | -                         | -                             |
|                             | PRCM_DPLL2_PHASELOCK      | 26                                                               | Indicates whether DPLL2 is in phase lock condition                                       | Lock conditions reached   | Lock conditions not reached   |
|                             | PRCM_DPLL3_PHASELOCK      | 27                                                               | Indicates whether DPLL3 is in phase lock condition                                       | Lock conditions reached   | Lock conditions not reached   |
|                             | PRCM_DPLL4_PHASELOCK      | 28                                                               | Indicates whether DPLL4 is in phase lock condition                                       | Lock conditions reached   | Lock conditions not reached   |
|                             | Reserved                  | (127:29)                                                         | -                                                                                        | -                         | -                             |

<sup>(1)</sup> 0x00 in WKUPOBSMUX8 field CONTROL.CONTROL\_WKUP\_DEBOBS\_2[4:0]

**Table 13-39. Internal Signals Multiplexed on OBSMUX9**

| Out Signal Name             | Muxed Signal Name         | OBSMUX9 Field<br><b>CONTROL_CONTROL_D</b><br><b>EBOBS_4[8:0]</b> (dec) | Description                                                                                                                                        | High State               | Low State                    |
|-----------------------------|---------------------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------------------------------|
| CORE_OBSMUX9 <sup>(1)</sup> | tie_low                   | 0                                                                      | -                                                                                                                                                  | -                        | -                            |
|                             | Reserved                  | 1                                                                      | -                                                                                                                                                  | -                        | -                            |
|                             | PRCM_DPLL5_PHASE_LOCK     | 2                                                                      | Indicates whether the DPLL5 is in phase lock condition                                                                                             | Lock conditions reached. | Lock conditions not reached. |
|                             | PRCM_DPLL5_bypass         | 3                                                                      | Indicates whether the DPLL5 is bypassed, in other words if the clock divisor is 1                                                                  | DPLL is bypassed.        | DPLL is not bypassed.        |
|                             | PRCM_DSS_IClkIsNotRunning | 4                                                                      | Indicates whether the DSS interface clock is running or not                                                                                        | Clock is not running.    | Clock is running.            |
|                             | PRCM_SGX_forceWakeup      | 5                                                                      | Indicates whether a wakeup of the SGX domain is forced                                                                                             | Wakeup is forced.        | Wakeup is not forced.        |
|                             | PRCM_DSS_domainReady      | 6                                                                      | Indicates whether the DSS domain is ready. In other words, is domain transition ongoing ?                                                          | Domain is not ready.     | Domain is ready.             |
|                             | PRCM_USBHOST_forcSleep    | 7                                                                      | Indicates whether the USBHOST domain forced to sleep mode                                                                                          | Sleep mode is forced.    | Sleep mode is not forced.    |
|                             | Reserved                  | (11:8)                                                                 | -                                                                                                                                                  | -                        | -                            |
|                             | PRCM_PER_48M_GFCLK        | 12                                                                     | 48-MHz functional clock of the PER domain                                                                                                          | -                        | -                            |
|                             | PRCM_DSS_96M_GFCLK        | 13                                                                     | 96-MHz functional clock of the DSS domain                                                                                                          | -                        | -                            |
|                             | Reserved                  | (22:14)                                                                | -                                                                                                                                                  | -                        | -                            |
|                             | iva_gl_dmarq_na           | (42:23)                                                                | DMA requests lines used by the IVA2 subsystem. See <a href="#">Chapter 5, IVA2 Subsystem</a> , for more information about these DMA request lines. | -                        | -                            |
|                             | PRCM_DPLL1_RECAL          | 43                                                                     | Indicates that DPLL1 needs to perform internal recalibration                                                                                       | Recalibration required   | Recalibration not required   |
|                             | PRCM_DPLL2_RECAL          | 44                                                                     | Indicates that DPLL2 needs to perform internal recalibration                                                                                       | Recalibration required   | Recalibration not required   |
|                             | PRCM_DPLL3_RECAL          | 45                                                                     | Indicates that DPLL3 needs to perform internal recalibration                                                                                       | Recalibration required   | Recalibration not required   |
|                             | PRCM_DPLL4_RECAL          | 46                                                                     | Indicates that DPLL4 needs to perform internal recalibration                                                                                       | Recalibration required   | Recalibration not required   |
|                             | Reserved                  | (127:47)                                                               | -                                                                                                                                                  | -                        | -                            |

<sup>(1)</sup> 0x00 in WKUPOBSMUX9 field CONTROL.CONTROL\_WKUP\_DEBOBS\_2[12:8]

**Table 13-40. Internal Signals Multiplexed on OBSMUX10**

| Out Signal Name              | Muxed Signal Name                                   | OBSMUX10 Field<br><b>CONTROL_CONTROL_D<br/>EBOBS_5[22:16]</b> (dec) | Description                                                                               | High State                | Low State                     |
|------------------------------|-----------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------|---------------------------|-------------------------------|
| CORE_OBSMUX10 <sup>(1)</sup> | tie_low                                             | 0                                                                   | -                                                                                         | -                         | -                             |
|                              | PRCM_CPEFUSE_FCLK                                   | 1                                                                   | Functional clock of the EFUSE module                                                      | -                         | -                             |
|                              | PRCM_DPLL2_Idle                                     | 2                                                                   | Indicates whether the DPLL2 is idle                                                       | Domain is in idle mode.   | Domain is not in idle mode.   |
|                              | PRCM_DPLL5_Idle                                     | 3                                                                   | Indicates whether the DPLL5 is idle                                                       | Domain is in idle mode.   | Domain is not in idle mode.   |
|                              | PRCM_CAM_IClkIsNotRunning                           | 4                                                                   | Indicates is the CAM interface clock is running or not                                    | Clock is not running.     | Clock is running.             |
|                              | PRCM_SGX_domainReady                                | 5                                                                   | Indicates whether the MPU domain is ready. In other words, is domain transition ongoing ? | Domain is not ready.      | Domain is ready.              |
|                              | PRCM_DSS_forceSleep                                 | 6                                                                   | Indicates whether the DSS domain is forced to sleep mode                                  | Sleep mode is forced.     | Sleep mode is not forced.     |
|                              | PRCM_USBHOST_domainFreeze                           | 7                                                                   | Indicates whether the USBHOST domain is frozen                                            | Domain is frozen.         | Domain is not frozen.         |
|                              | Reserved                                            | (10:8)                                                              | -                                                                                         | -                         | -                             |
|                              | This information is not available in public domain. | 11                                                                  | This information is not available in public domain.                                       |                           |                               |
|                              | PRCM_PER_96M_GFCLK                                  | 12                                                                  | 96-MHz functional clock of the PER domain                                                 | -                         | -                             |
|                              | PRCM_EMU_MPU_ALWON_CLK                              | 13                                                                  | Functional clock of the MPU module in the EMU domain                                      | -                         | -                             |
|                              | Reserved                                            | (25:14)                                                             | -                                                                                         | -                         | -                             |
|                              | PRCM_IVA_FCLK                                       | 26                                                                  | Functional clock of the IVA2 module.                                                      | -                         | -                             |
|                              | Reserved                                            | (30:27)                                                             | -                                                                                         | -                         | -                             |
|                              | PRCM_Dpll5_LOSSREF                                  | 31                                                                  | Reference input loss acknowledge of DPLL5                                                 | Signal acknowledged.      | Signal not acknowledged.      |
|                              | PRCM_Dpll2_FREQLOCK                                 | 32                                                                  | Indicates whether the frequency of DPLL2 is locked                                        | DPLL frequency is locked. | DPLL frequency is not locked. |
|                              | PRCM_Dpll5_M2X2_CLK                                 | 33                                                                  | M2X2 clock generated by DPLL5                                                             | -                         | -                             |
|                              | PRCM_Dpll4_FREQLOCK                                 | 34                                                                  | Indicates whether the frequency of DPLL4 is locked                                        | DPLL frequency is locked. | DPLL frequency is not locked. |
|                              | Reserved                                            | (127:35)                                                            | -                                                                                         | -                         | -                             |

<sup>(1)</sup> 0x00 in WKUPOBSMUX10 field CONTROL.CONTROL\_WKUP\_DEBOBS\_2[20:16]

**Table 13-41. Internal Signals Multiplexed on OBSMUX11**

| Out Signal Name              | Muxed Signal Name                                   | OBSMUX11 Field<br><b>CONTROL.CONTROL_<br/>DEBOBS_5[6:0]</b> (dec) | Description                                                                                                                   | High State            | Low State                 |
|------------------------------|-----------------------------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------|---------------------------|
| CORE_OBSMUX11 <sup>(1)</sup> | tie_low                                             | 0                                                                 | -                                                                                                                             | -                     | -                         |
|                              | PRCM_DPLL5_M2_CLK                                   | 1                                                                 | M2 clock generated by DPLL5                                                                                                   | -                     | -                         |
|                              | PRCM_DPLL2_initz                                    | 2                                                                 | Lock sequence initialization (HLH) of DPLL2                                                                                   | -                     | -                         |
|                              | PRCM_DPLL5_initz                                    | 3                                                                 | Lock sequence initialization (HLH) of DPLL5                                                                                   | -                     | -                         |
|                              | PRCM_PERL4_IClkIsNotRunning                         | 4                                                                 | Indicates whether the interface clock of the L4 interconnect in the PER domain is running or not                              | Clock is not running. | Clock is running.         |
|                              | PRCM_SGX_forceSleep                                 | 5                                                                 | Indicates whether the SGX domain is forced to sleep mode                                                                      | Sleep mode is forced. | Sleep mode is not forced. |
|                              | PRCM_DSS_domainFreeze                               | 6                                                                 | Indicates whether the DSS domain is frozen                                                                                    | Domain is frozen.     | Domain is not frozen.     |
|                              | PRCM_emudpll3srcclkactivitystatus                   | 7                                                                 | Indicates (when enabled and required) if DPLL3 is forced in lock mode in order to ensure high speed emulation or trace clocks | Lock mode forced      | Lock mode not forced      |
|                              | Reserved                                            | (10:8)                                                            | -                                                                                                                             | -                     | -                         |
|                              | This information is not available in public domain. | 11                                                                | This information is not available in public domain.                                                                           |                       |                           |
|                              | PRCM_PER_L4_GICLK                                   | 12                                                                | Interface clock of the L4 interconnect in the PER clock domain                                                                | -                     | -                         |
|                              | PRCM_MPUI2ASYNC_CLKREQFIFO                          | 13                                                                | Not a direct MPU clock                                                                                                        | -                     | -                         |
|                              | Reserved                                            | (29:14)                                                           | -                                                                                                                             | -                     | -                         |
|                              | PRCM_DPLL1_TICOPWDN                                 | 30                                                                | Indicates a Core DCO power down condition for DPLL1                                                                           | Conditions reached    | Conditions not reached    |
|                              | PRCM_DPLL2_TICOPWDN                                 | 31                                                                | Indicates a Core DCO power down condition for DPLL2                                                                           | Conditions reached    | Conditions not reached    |
|                              | PRCM_DPLL3_TICOPWDN                                 | 32                                                                | Indicates a Core DCO power down condition for DPLL3                                                                           | Conditions reached    | Conditions not reached    |
|                              | PRCM_DPLL4_TICOPWDN                                 | 33                                                                | Indicates a Core DCO power down condition for DPLL4                                                                           | Conditions reached    | Conditions not reached    |
|                              | Reserved                                            | (127:34)                                                          | -                                                                                                                             | -                     | -                         |

<sup>(1)</sup> 0x00 in WKUPOBSMUX11 field CONTROL.CONTROL\_WKUP\_DEBOBS\_2[28:24]

**Table 13-42. Internal Signals Multiplexed on OBSMUX12**

| Out Signal Name              | Muxed Signal Name                                   | OBSMUX12 Field<br><b>CONTROL_CONTROL_D</b><br><b>EBOBS_6[22:16]</b> (dec) | Description                                              | High State              | Low State                   |
|------------------------------|-----------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------|-------------------------|-----------------------------|
| CORE_OBSMUX12 <sup>(1)</sup> | tie_low                                             | 0                                                                         | -                                                        | -                       | -                           |
|                              | PRCM_DPLL1_FCLK                                     | 1                                                                         | Functional clock of DPLL1                                | -                       | -                           |
|                              | PRCM_DPLL2_enable                                   | 2                                                                         | Signal used to enable DPLL2                              | DPLL is enabled.        | DPLL is disabled.           |
|                              | PRCM_DPLL5_enable                                   | 3                                                                         | Signal used to enable DPLL5                              | DPLL is enabled.        | DPLL is disabled.           |
|                              | PRCM_EMU_ClklsRunning                               | 4                                                                         | Indicates whether the EMU clock is running or not        | The clock is running.   | The clock is not running.   |
|                              | PRCM_COREL3_domainIsIdle                            | 5                                                                         | Indicates whether the COREL3 domain is in idle           | Domain is in idle mode. | Domain is not in Idle mode. |
|                              | PRCM_PER_domainIsIdle                               | 6                                                                         | Indicates whether the PER domain is in idle              | Domain is in idle mode. | Domain is not in Idle mode. |
|                              | PRCM_IVA2_DPLLCHARGE                                | 7                                                                         | Indicates whether the IVA2 DPLL needs to be recalibrated | Recalibration required  | Recalibration not required  |
|                              | Reserved                                            | (11:8)                                                                    | -                                                        | -                       | -                           |
|                              | This information is not available in public domain. | 12                                                                        | This information is not available in public domain.      |                         |                             |
|                              | PRCM_DPLL2_M2X2_CLK                                 | 13                                                                        | M2X2 clock generated by DPLL2                            | -                       | -                           |
|                              | Reserved                                            | (127:14)                                                                  | -                                                        | -                       | -                           |

<sup>(1)</sup> 0x00 in WKUPOBSMUX12 field CONTROL.CONTROL\_WKUP\_DEBOBS\_3[4:0]

**Table 13-43. Internal Signals Multiplexed on OBSMUX13**

| Out Signal Name              | Muxed Signal Name             | OBSMUX13 Field<br><b>CONTROL.CONTROL_DEBOBS_6</b><br>[6:0] (dec) | Description                                                                          | High State                    | Low State                      |
|------------------------------|-------------------------------|------------------------------------------------------------------|--------------------------------------------------------------------------------------|-------------------------------|--------------------------------|
| CORE_OBSMUX13 <sup>(1)</sup> | tie_low                       | 0                                                                | -                                                                                    | -                             | -                              |
|                              | PRCM_DPLL2_FCLK               | 1                                                                | Functional clock of DPLL2.                                                           | -                             | -                              |
|                              | PRCM_DPLL2_enablediv          | 2                                                                | Signal used to enable the clock divisor of DPLL2.                                    | DPLL clock divisor is enabled | DPLL clock divisor is disabled |
|                              | PRCM_DPLL5_enablediv          | 3                                                                | Signal used to enable the clock divisor of DPLL5.                                    | DPLL clock divisor is enabled | DPLL clock divisor is disabled |
|                              | PRCM_CPEFUSE_FClklsNotRunning | 4                                                                | Indicates whether the CPEFUSE functional clock is running or not.                    | Clock is not running          | Clock is running               |
|                              | PRCM_COREL4_domainIsIdle      | 5                                                                | Indicates whether the COREL4 domain is in Idle.                                      | Domain is in Idle mode        | Domain is not in Idle mode     |
|                              | PRCM_PER_forceWakeupp         | 6                                                                | Indicates whether a wakeup of the PER domain is forced.                              | Wakeup is forced              | Wakeup is not forced           |
|                              | PRCM_IVA2_DPLLCHANGEACK       | 7                                                                | Indicates whether the IVA2 DPLL re-calibration is acknowledged.                      | re-calibration required       | re-calibration not required    |
|                              | Reserved                      | (11:8)                                                           | -                                                                                    | -                             | -                              |
|                              | PRCM_USBHOST_GICLK            | 12                                                               | Interface clock of the L4 interconnect in the USBHOST module.                        | -                             | -                              |
|                              | PRCM_EMU_CORE_ALWON_CLK       | 13                                                               | Emulation clock used by PRCM in order to run the emulation trace. Supplied by DPLL3. | -                             | -                              |

<sup>(1)</sup> 0x00 in WKUPOBSMUX13 field CONTROL.CONTROL\_WKUP\_DEBOBS\_3[12:8]

**Table 13-43. Internal Signals Multiplexed on OBSMUX13 (continued)**

| Out Signal Name | Muxed Signal Name           | OBSMUX13 Field<br><b>CONTROL.CONT</b><br><b>ROL_DEBOBS_6</b><br>[6:0] (dec) | Description             | High State | Low State |
|-----------------|-----------------------------|-----------------------------------------------------------------------------|-------------------------|------------|-----------|
|                 | Reserved                    | 14                                                                          | —                       | —          | —         |
|                 | PRCM_MPUI2ASYNC_C_LKREQFIFO | 15                                                                          | Not a direct MPU clock. | —          | —         |
|                 | Reserved                    | (127:16)                                                                    | —                       | —          | —         |

**Table 13-44. Internal Signals Multiplexed on OBSMUX14**

| Out Signal Name              | Muxed Signal Name        | OBSMUX14 Field<br><b>CONTROL.CONT</b><br><b>ROL_DEBOBS_7</b> [<br>22:16] (dec) | Description                                                                              | High State                | Low State                     |
|------------------------------|--------------------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|---------------------------|-------------------------------|
| CORE_OBSMUX14 <sup>(1)</sup> | tie_low                  | 0                                                                              | —                                                                                        | —                         | —                             |
|                              | Reserved                 | 1                                                                              | —                                                                                        | —                         | —                             |
|                              | PRCM_DPLL3_freqlock      | 2                                                                              | Indicates whether the frequency of DPLL3 is locked                                       | DPLL frequency is locked. | DPLL frequency is not locked. |
|                              | PRCM_MPUDomainFreeze     | 3                                                                              | Indicates whether the MPU domain is frozen                                               | Domain is frozen.         | Domain is not frozen.         |
|                              | PRCM_MPUDomainIsIdle     | 4                                                                              | Indicates whether MPU domain is idle                                                     | Domain is in idle mode.   | Domain is not in idle mode.   |
|                              | PRCM_CORED2DDomainIsIdle | 5                                                                              | Indicates if the CORED2D domain is in idle                                               | Domain is in idle mode.   | Domain is not in idle mode.   |
|                              | PRCM_PERDomainReady      | 6                                                                              | Indicates whether the PER domain is ready. In other words, is domain transition ongoing? | Domain is not ready.      | Domain is ready.              |
|                              | PRCM_EMU_MStandby        | 7                                                                              | EMU asserts this signal to initiate a transition to standby mode                         | Transition initiated      | Transition not initiated      |
|                              | Reserved                 | (11:8)                                                                         | —                                                                                        | —                         | —                             |
|                              | PRCM_USBHOST_48MGFCLK    | 12                                                                             | 48-MHz functional clock of the USBHOST module                                            | —                         | —                             |
|                              | PRCM_EMUPERALWONCLK      | 13                                                                             | High-frequency always-on clock in the PER domain used to generate for emulation clocks   | —                         | —                             |
|                              | Reserved                 | 14                                                                             | —                                                                                        | —                         | —                             |
|                              | PRCM_IVA_CLK             | 15                                                                             | Functional clock of the IVA2                                                             | —                         | —                             |
|                              | Reserved                 | (127:16)                                                                       | —                                                                                        | —                         | —                             |

<sup>(1)</sup> 0x00 in WKUPOBSMUX14 field CONTROL.CONTROL\_WKUP\_DEBOBS\_3[20:16]

**Table 13-45. Internal Signals Multiplexed on OBSMUX15**

| Out Signal Name              | Muxed Signal Name                                   | OBSMUX15 Field<br><b>CONTROL.CONTROL_ROL_DEBOBS_7 [6:0] (dec)</b> | Description                                                                                                                                                                                                                                           | High State             | Low State                  |
|------------------------------|-----------------------------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------------------------|
| CORE_OBSMUX15 <sup>(1)</sup> | tie_low                                             | 0                                                                 | -                                                                                                                                                                                                                                                     | -                      | -                          |
|                              | PRCM_GPT10_FCLK                                     | 1                                                                 | Functional clock of GPTIMER10.                                                                                                                                                                                                                        | -                      | -                          |
|                              | PRCM_DPLL3_bypass                                   | 2                                                                 | Indicates whether DPLL3 is bypassed, in other words if the clock divisor is 1.                                                                                                                                                                        | DPLL is bypassed       | DPLL is not bypassed       |
|                              | PRCM_IVA2_domainFreeze                              | 3                                                                 | Indicates whether the IVA2 domain is frozen.                                                                                                                                                                                                          | Domain is frozen       | Domain is not frozen       |
|                              | PRCM_MPUs_domainReady                               | 4                                                                 | Indicates whether the MPU domain is ready. In other words, is domain transition ongoing ?                                                                                                                                                             | Domain is not ready    | Domain is ready            |
|                              | PRCM_CORECM_domainIsIdle                            | 5                                                                 | Indicates whether CORECM domain is in idle.                                                                                                                                                                                                           | Domain is in Idle mode | Domain is not in Idle mode |
|                              | PRCM_PER_forceSleep                                 | 6                                                                 | Indicates whether the PER domain is forced to sleep mode.                                                                                                                                                                                             | Sleep mode is forced   | Sleep mode is not forced   |
|                              | PRCM_STATE_IS_ON_MPUs                               | 7                                                                 | Indicates to the global Power Manager FSM that the MPU domain power state is ON.                                                                                                                                                                      | FSM state is ON        | FSM state is not ON        |
|                              | Reserved                                            | (11:8)                                                            | -                                                                                                                                                                                                                                                     | -                      | -                          |
|                              | PRCM_USBHOST_120M_GFCLK                             | 12                                                                | 96-MHz functional clock of the USBHOST module.                                                                                                                                                                                                        | -                      | -                          |
|                              | PRCM_DPLL4_M2_CLK                                   | 13                                                                | M2 clock generated by DPLL4.                                                                                                                                                                                                                          | -                      | -                          |
|                              | Reserved                                            | (16:14)                                                           | -                                                                                                                                                                                                                                                     | -                      | -                          |
|                              | This information is not available in public domain. | 17                                                                | This information is not available in public domain.                                                                                                                                                                                                   | -                      | -                          |
|                              | Reserved                                            | 18                                                                | -                                                                                                                                                                                                                                                     | -                      | -                          |
|                              | iva_gl_irq_na( 92:46,'1' )                          | (66:19)                                                           | External interrupts requests generated by peripherals external to the IVA2 subsystem (such as SPI, display subsystem, or camera subsystem). See <a href="#">Chapter 5, IVA2 Subsystem</a> , for more information about these interrupt request lines. | -                      | -                          |
|                              | Reserved                                            | (127:67)                                                          | -                                                                                                                                                                                                                                                     | -                      | -                          |

<sup>(1)</sup> 0x00 in WKUPOBSMUX15 field CONTROL.CONTROL\_WKUP\_DEBOBS\_3[28:24]

**Table 13-46. Internal Signals Multiplexed on OBSMUX16**

| Out Signal Name              | Muxed Signal Name                                   | OBSMUX16 Field<br><b>CONTROL.CONT<br/>ROL_DEBOBS_8[<br/>22:16]</b> (dec) | Description                                                                                                                                                                                                                                           | High State             | Low State                  |
|------------------------------|-----------------------------------------------------|--------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------------------------|
| CORE_OBSMUX16 <sup>(1)</sup> | tie_low                                             | 0                                                                        | -                                                                                                                                                                                                                                                     | -                      | -                          |
|                              | PRCM_GPT11_FCLK                                     | 1                                                                        | Functional clock of GPTIMER11.                                                                                                                                                                                                                        | -                      | -                          |
|                              | PRCM_DPLL3_idle                                     | 2                                                                        | Indicates whether the DPLL3 is idle.                                                                                                                                                                                                                  | Domain is in Idle mode | Domain is not in Idle mode |
|                              | PRCM_CORED2D_domainFreeze                           | 3                                                                        | Indicates whether the CORELD2D domain is ready (is domain transition ongoing?)                                                                                                                                                                        | Domain is ready.       | Domain is not ready.       |
|                              | PRCM_MPUs_domainFreeze                              | 4                                                                        | Indicates whether the MPU domain is frozen.                                                                                                                                                                                                           | Domain is frozen       | Domain is not frozen       |
|                              | PRCM_CORE_domainNrReady                             | 5                                                                        | Indicates whether the CORE domain is ready. In other words, is domain transition ongoing ?                                                                                                                                                            | Domain is not ready    | Domain is ready            |
|                              | PRCM_WKUP_domainIdle                                | 6                                                                        | Indicates whether WKUP domain is Idle.                                                                                                                                                                                                                | Domain is in Idle mode | Domain is not in Idle mode |
|                              | PRCM_STATE_IS_OFF_MPUs                              | 7                                                                        | Indicates to the global Power Manager FSM that the MPU domain power state is OFF.                                                                                                                                                                     | FSM state is OFF       | FSM state is not OFF       |
|                              | Reserved                                            | (11:8)                                                                   | -                                                                                                                                                                                                                                                     | -                      | -                          |
|                              | PRCM_SGX_GICLK                                      | 12                                                                       | Interface clock of the L4 interconnect in the SGX clock module.                                                                                                                                                                                       | -                      | -                          |
|                              | PRCM_DPLL4_M4_CLK                                   | 13                                                                       | M4 clock generated by DPLL4.                                                                                                                                                                                                                          | -                      | -                          |
|                              | Reserved                                            | (16:14)                                                                  | -                                                                                                                                                                                                                                                     | -                      | -                          |
|                              | This information is not available in public domain. | 17                                                                       | This information is not available in public domain.                                                                                                                                                                                                   |                        |                            |
|                              | Reserved                                            | 18                                                                       | -                                                                                                                                                                                                                                                     | -                      | -                          |
|                              | iva_gl_irq_na(92:46,'1')                            | (66:19)                                                                  | External interrupts requests generated by peripherals external to the IVA2 subsystem (such as SPI, display subsystem, or camera subsystem). See <a href="#">Chapter 5, IVA2 Subsystem</a> , for more information about these interrupt request lines. | -                      | -                          |
|                              | Reserved                                            | (127:67)                                                                 | -                                                                                                                                                                                                                                                     | -                      | -                          |

<sup>(1)</sup> 0x00 in WKUPOBSMUX16 field CONTROL.CONTROL\_WKUP\_DEBOBS\_4[4:0]

**Table 13-47. Internal Signals Multiplexed on OBSMUX17**

| Out Signal Name              | Muxed Signal Name         | OBSMUX17 Field<br><b>CONTROL.CONT<br/>ROL_DEBOBS_8[<br/>6:0] (dec)</b> | Description                                                                                 | High State             | Low State                  |
|------------------------------|---------------------------|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------|----------------------------|
| CORE_OBSMUX17 <sup>(1)</sup> | tie_low                   | 0                                                                      | -                                                                                           | -                      | -                          |
|                              | PRCM_SGX_GFCLK            | 1                                                                      | Functional clock of the L4 interconnect in the SGX clock module.                            | -                      | -                          |
|                              | PRCM_DPLL3_initz          | 2                                                                      | Lock sequence initialization (HLH) of DPLL3                                                 | -                      | -                          |
|                              | PRCM_DSS_domainFreeze     | 3                                                                      | Indicates whether the DSS domain is frozen.                                                 | Domain is frozen       | Domain is not frozen       |
|                              | PRCM_NEON_domainIsIdle    | 4                                                                      | Indicates whether the NEON domain is Idle.                                                  | Domain is in Idle mode | Domain is not in Idle mode |
|                              | PRCM_COREL3_domainNready  | 5                                                                      | Indicates whether the COREL3 domain is ready. In other words, is domain transition ongoing? | Domain is not ready    | Domain is ready            |
|                              | PRCM_WKUP_domainWakeUpAck | 6                                                                      | Indicates whether a wakeup of the WKUP domain is acknowledged.                              | Command acknowledged   | Command not acknowledged   |
|                              | PRCM_STATE_IS_ON_IVA2     | 7                                                                      | Indicates to the global Power Manager FSM that the IVA2 domain power state is ON.           | FSM state is ON        | FSM state is not ON        |
|                              | Reserved                  | (12:8)                                                                 | -                                                                                           | -                      | -                          |
|                              | PRCM_DPLL4_M5_CLK         | 13                                                                     | M5 clock generated by DPLL4.                                                                | -                      | -                          |
| Reserved                     |                           | (127:14)                                                               | -                                                                                           | -                      | -                          |

<sup>(1)</sup> 0x00 in WKUPOBSMUX17 field CONTROL.CONTROL\_WKUP\_DEBOBS\_4[12:8]

**Table 13-48. Internal Signals Multiplexed on WKUPOBSMUX0**

| Pin Name               | Observed Signal Name                                | WKUPOBSMU<br>X0 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_0[4:<br/>0] (dec)</b> | Description                                                                              | High State           | Low State                     |
|------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|----------------------|-------------------------------|
| hw_dbg0 <sup>(1)</sup> | CORE_OBSMUX0                                        | 0                                                                                       | Signal multiplexed by OBSMUX0.                                                           | –                    | –                             |
|                        | PRCM_SYS_CLK                                        | 1                                                                                       | System clock running at the system clock frequency.                                      | –                    | –                             |
|                        | PRCM_GPT5_ALWON_FCLK                                | 2                                                                                       | Always-on functional clock of GP-Timer #5.                                               | –                    | –                             |
|                        | PRCM_SGX_RST                                        | 3                                                                                       | Reset signal for SGX.                                                                    | Reset is not active  | Reset is active               |
|                        | PRCM_USBHOST_RST                                    | 4                                                                                       | Reset signal for USBHOST.                                                                | Reset is not active  | Reset is active               |
|                        | Reserved                                            | 5                                                                                       | –                                                                                        | –                    | –                             |
|                        | PRCM_CORECM_domainIsOn                              | 6                                                                                       | Indicates to the global Power Manager FSM that the CORECM domain power state is ON.      | State is ON          | State is not ON               |
|                        | PRCM_WKUP_domainWakeup                              | 7                                                                                       | Indicates that a wake-up condition is detected for the WKUP domain.                      | Conditions reached   | Conditions not reached        |
|                        | PRCM_vdd2_domain_is_ret                             | 8                                                                                       | Indicates to the global Power Manager FSM that the VDD2 domain power state is RETENTION. | State is RETENTION   | State is not RETENTION        |
|                        | PRCM_vdd5_domain_is_on                              | 9                                                                                       | Indicates to the global Power Manager FSM that the VDD5 domain power state is ON.        | State is ON          | State is not ON               |
|                        | PRCM_device_is_on                                   | 10                                                                                      | Indicates whether the device is ON.                                                      | State is ON          | State is not ON               |
|                        | PRCM_MPU_SRAMAONIN[1]                               | 11                                                                                      | SRAM array power control input (bit 1) for MPU power domain.                             | Array is powered     | Array is not powered          |
|                        | PRCM_IVA2_SRAMAONIN[3]                              | 12                                                                                      | SRAM array power control input (bit 3) for IVA2 power domain.                            | Array is powered     | Array is not powered          |
|                        | PRCM_CORE_POWER_IS_O                                | 13                                                                                      | PM command for CORE domain isolation.                                                    | Isolation is ON      | Isolation is OFF              |
|                        | PRCM_CORE_SRAMRET_ONIN[0]                           | 14                                                                                      | SRAM retention on signal to CORE power domain (bit 0).                                   | Retention is ON      | Retention is OFF              |
|                        | PRCM_SGX_POWER_GO_OD[0]                             | 15                                                                                      | Indicates whether the SGX power switches status (bit 0).                                 | Power is stable      | Power is not stable           |
|                        | PRCM_CAM_POWER_ON                                   | 16                                                                                      | CAM switch command for power-on.                                                         | Power is ON          | Power is OFF                  |
|                        | This information is not available in public domain. | 17                                                                                      | This information is not available in public domain.                                      | –                    | –                             |
|                        | PRCM_PER_POWER_GO_OD[0]                             | 18                                                                                      | Indicates whether the PER power switches status (bit 0).                                 | Power is stable      | Power is not stable           |
|                        | PRCM_forceemucm                                     | 19                                                                                      | Indicates whether the EMULATION mode of the clock manager is forced.                     | Forced               | Not forced                    |
|                        | PRCM_MPU_INTC_SWAK_EUP                              | 20                                                                                      | MPU interrupt controller asserts this signal to initiate a transition to WAKEUP mode.    | Transition initiated | Wakeup conditions not reached |
|                        | Reserved                                            | (31:21)                                                                                 | –                                                                                        | –                    | –                             |

<sup>(1)</sup> Mode 5 in MUXMODE0 field CONTROL.CONTROL\_PADCONF\_CAM\_HS[2:0]

Table 13-49. Internal Signals Multiplexed on WKUPOBSMUX1

| Pin Name               | Observed Signal Name                                | WKUPOBSMU<br>X1 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_0[1<br/>2:8] (dec)</b> | Description                                                                                                                                                                                                                      | High State              | Low State                     |
|------------------------|-----------------------------------------------------|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------------------------|
| hw_dbg1 <sup>(1)</sup> | CORE_OBSMUX1                                        | 0                                                                                        | Signal multiplexed by OBSMUX1.                                                                                                                                                                                                   | –                       | –                             |
|                        | PRCM_DPLL1_ALWON_F_CLK                              | 1                                                                                        | Always-on functional clock of DPLL1.                                                                                                                                                                                             | –                       | –                             |
|                        | PRCM_GPT6_ALWON_FC_LK                               | 2                                                                                        | Always-on functional clock of GP-Timer #6.                                                                                                                                                                                       | –                       | –                             |
|                        | PRCM_DSS_RST                                        | 3                                                                                        | Reset signal for DSS.                                                                                                                                                                                                            | Reset is not active     | Reset is active               |
|                        | PRCM_ICEPICK_RSTPW_RON                              | 4                                                                                        | Cold reset signal for ICEPICK.                                                                                                                                                                                                   | Reset is not active     | Reset is active               |
|                        | PRCM_eFuseReady_n                                   | 5                                                                                        | Indicates whether the device eFuse scan is completed.                                                                                                                                                                            | Scan complete           | Scan not complete             |
|                        | PRCM_CAM_domainWake up                              | 6                                                                                        | Indicates that a wake-up condition is detected for the CAM domain.                                                                                                                                                               | Conditions reached      | Conditions not reached        |
|                        | PRCM_cam_domain_is_inactive                         | 7                                                                                        | Indicates whether the CAM domain is active or not.                                                                                                                                                                               | Domain is inactive      | Domain is active              |
|                        | PRCM_cam_domain_is_reten tion                       | 8                                                                                        | Indicates to the global Power Manager FSM that the CAM domain power state is RETENTION.                                                                                                                                          | State is RETENTIO N     | State is not RETENTIO N       |
|                        | PRCM_Control_start_restore                          | 9                                                                                        | When asserted by the PRM, the Control module starts restoring pad configuration which has been saved before going to OFF mode. See <a href="#">Section 13.4.4.4.1</a> for more information about the save and restore mechanism. | –                       | –                             |
|                        | PRCM_device_is_lp                                   | 10                                                                                       | Indicates whether the voltage supply of the device is in a low power mode: OFF, RETENTION or SLEEP.                                                                                                                              | Low power activated     | Low power not activated       |
|                        | PRCM_MPUMSRAMAGOODOUT[0]                            | 11                                                                                       | MPU array Powergood indication from SRAM to PSCON (bit 0).                                                                                                                                                                       | Power is stable         | Power is not stable           |
|                        | PRCM_IVA2_SRAMAONIN[4]                              | 12                                                                                       | SRAM array power control input (bit 4) for IVA2 power domain.                                                                                                                                                                    | Array is powered        | Array is not powered          |
|                        | PRCM_CORE_POWER_GOOD[0]                             | 13                                                                                       | Indicates whether the CORE power switches status (bit 0).                                                                                                                                                                        | Power is stable         | Power is not stable           |
|                        | PRCM_CORE_SRAMRET ONIN[1]                           | 14                                                                                       | SRAM retention on signal to CORE power domain (bit 1).                                                                                                                                                                           | Retention is ON         | Retention is OFF              |
|                        | PRCM_SGX_POWER_GO OD[1]                             | 15                                                                                       | Indicates whether the SGX power switches status (bit 1).                                                                                                                                                                         | Power is stable         | Power is not stable           |
|                        | PRCM_CAM_POWER_ISO                                  | 16                                                                                       | PM command for CAM domain isolation.                                                                                                                                                                                             | Isolation is ON         | Isolation is OFF              |
|                        | This information is not available in public domain. | 17                                                                                       | This information is not available in public domain.                                                                                                                                                                              | –                       | –                             |
|                        | PRCM_PER_POWER_GO OD[1]                             | 18                                                                                       | Indicates whether the PER power switches status (bit 1).                                                                                                                                                                         | Power is stable         | Power is not stable           |
|                        | PRCM_emudpll3srcclkactivityctrl                     | 19                                                                                       | Indicates (when enabled and required) if DPLL3 can be forced in lock mode in order to ensure high speed emulation or trace clocks.                                                                                               | DPLL lock can be forced | DPLL lock cannot be forced    |
|                        | PRCM_IVA2_WUGEN_SWAKEUP                             | 20                                                                                       | IVA2 asserts this signal to initiate a transition to WAKEUP mode.                                                                                                                                                                | Transition initiated    | Wakeup conditions not reached |
|                        | Reserved                                            | (31:21)                                                                                  | –                                                                                                                                                                                                                                | –                       | –                             |

<sup>(1)</sup> Mode 5 in MUXMODE1 field CONTROL.CONTROL\_PADCONF\_CAM\_HS[18:16]

**Table 13-50. Internal Signals Multiplexed on WKUPOBSMUX2**

| Pin Name               | Observed Signal Name      | WKUPOBSMU<br>X2 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_0[2<br/>0:16] (dec)</b> | Description                                                                                                                                                                                                | High State           | Low State                     |
|------------------------|---------------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------------------------|
| hw_dbg2 <sup>(1)</sup> | CORE_OBSMUX2              | 0                                                                                         | Signal multiplexed by OBSMUX2                                                                                                                                                                              | –                    | –                             |
|                        | PRCM_DPLL2_ALWON_FCLK     | 1                                                                                         | Always-on functional clock of DPLL2                                                                                                                                                                        | –                    | –                             |
|                        | PRCM_GPT7_ALWON_FCLK      | 2                                                                                         | Always-on functional clock of GP-Timer #7                                                                                                                                                                  | –                    | –                             |
|                        | Reserved                  | 3                                                                                         | –                                                                                                                                                                                                          | –                    | –                             |
|                        | PRCM_BANDGAP_RSTPWRON     | 4                                                                                         | Reset signal for BANDGAP                                                                                                                                                                                   | Reset is not active  | Reset is active               |
|                        | PRCM_cam_domain_is_off    | 5                                                                                         | Indicates to the global Power Manager FSM that the CAM domain power state is OFF                                                                                                                           | State is OFF         | State is not OFF              |
|                        | PRCM_CAM_domainIsOn       | 6                                                                                         | Indicates to the global Power Manager FSM that the CAM domain power state is ON                                                                                                                            | State is ON          | State is not ON               |
|                        | PRCM_EMU_domainWake up    | 7                                                                                         | Indicates that a wake-up condition is detected for the EMU domain                                                                                                                                          | Conditions reached   | Conditions not reached        |
|                        | PRCM_vdd2_domain_is_sleep | 8                                                                                         | Indicates to the global Power Manager FSM that the VDD2 domain power state is SLEEP                                                                                                                        | State is SLEEP       | State is not SLEEP            |
|                        | PRCM_Control_restore_done | 9                                                                                         | Signal asserted by the Control module when pad configuration has been restored. See <a href="#">Section 13.4.4.4.1, System Control Module</a> , for more information about the save and restore mechanism. | Context restored     | Context not restored yet      |
|                        | Reserved                  | 10                                                                                        | –                                                                                                                                                                                                          | –                    | –                             |
|                        | PRCM_MPUMSRAMAGOODOUT[1]  | 11                                                                                        | MPU array Powergood indication from SRAM to PSCON (bit 1).                                                                                                                                                 | Power is stable      | Power is not stable           |
|                        | PRCM_IVA2_SRAMAGOODOUT[0] | 12                                                                                        | IVA2 array Powergood indication from SRAM to PSCON (bit 0).                                                                                                                                                | Power is stable      | Power is not stable           |
|                        | PRCM_CORE_POWER_GOOD[1]   | 13                                                                                        | Indicates whether the CORE power switches status (bit 1).                                                                                                                                                  | Power is stable      | Power is not stable           |
|                        | PRCM_CORE_SRAMRETONIN[2]  | 14                                                                                        | SRAM retention on signal to CORE power domain (bit 2).                                                                                                                                                     | Retention is ON      | Retention is OFF              |
|                        | PRCM_SGX_POWER_GOOD[2]    | 15                                                                                        | Indicates whether the SGX power switches status (bit 2).                                                                                                                                                   | Power is stable      | Power is not stable           |
|                        | PRCM_CAM_POWER_GOOD[0]    | 16                                                                                        | Indicates whether the CAM power switches status (bit 0).                                                                                                                                                   | Power is stable      | Power is not stable           |
|                        | PRCM_DPLL1_POWER_ON       | 17                                                                                        | DPLL1 switch command for power-on.                                                                                                                                                                         | Power is ON          | Power is OFF                  |
|                        | PRCM_PER_POWER_GOOD[2]    | 18                                                                                        | Indicates whether the PER power switches status (bit 2).                                                                                                                                                   | Power is stable      | Power is not stable           |
|                        | PRCM_dpll3RstClkSteady    | 19                                                                                        | Reset signal of the block that controls the EMU domain.                                                                                                                                                    | Reset is not active  | Reset is active               |
|                        | PRCM_DSS_SWAKEUP          | 20                                                                                        | DSS asserts this signal to initiate a transition to WAKEUP mode.                                                                                                                                           | Transition initiated | Wakeup conditions not reached |
|                        | Reserved                  | (31:21)                                                                                   | –                                                                                                                                                                                                          | –                    | –                             |

<sup>(1)</sup> Mode 5 in MUXMODE1 field CONTROL.CONTROL\_PADCONF\_CAM\_XCLKA[18:16]

**Table 13-51. Internal Signals Multiplexed on WKUPOBSMUX3**

| Pin Name               | Observed Signal Name         | WKUPOBSMU<br>X3 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_0[2<br/>8:24] (dec)</b> | Description                                                                                              | High State                  | Low State                     |
|------------------------|------------------------------|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------------------------|-------------------------------|
| hw_dbg3 <sup>(1)</sup> | CORE_OBSMUX3                 | 0                                                                                         | Signal multiplexed by OBSMUX3.                                                                           | –                           | –                             |
|                        | PRCM_DPLL3_ALWON_F_CLK       | 1                                                                                         | Always-on functional clock of DPLL3.                                                                     | –                           | –                             |
|                        | PRCM_GPT8_ALWON_FC_LK        | 2                                                                                         | Always-on functional clock of GP-Timer #8.                                                               | –                           | –                             |
|                        | Reserved                     | 3                                                                                         | –                                                                                                        | –                           | –                             |
|                        | PRCM_MP_U_WD_RST             | 4                                                                                         | Reset signal for MPU from MPU-Watchdog.                                                                  | Reset is not active         | Reset is active               |
|                        | PRCM_MP_U_domainWake up      | 5                                                                                         | Indicates that a wake-up condition is detected for the MPU domain.                                       | Conditions reached          | Conditions not reached        |
|                        | PRCM_efuseClk_is_not_running | 6                                                                                         | Indicates whether the interface clock of eFuse is running or not.                                        | Clock is not running        | Clock is running              |
|                        | PRCM_EMU_domainIsOn          | 7                                                                                         | Indicates to the global Power Manager FSM that the EMU domain power state is ON.                         | State is ON                 | State is not ON               |
|                        | PRCM_vdd2_domain_is_lp       | 8                                                                                         | Indicates whether the voltage supply of the VDD2 domain is in a low power mode: OFF, RETENTION or SLEEP. | Low power activated         | Low power not activated       |
|                        | PRCM_SYS_CLKREQ_out          | 9                                                                                         | Value of the SYS_CLKREQ pad when used as an output.                                                      | –                           | –                             |
|                        | Reserved                     | 10                                                                                        | –                                                                                                        | –                           | –                             |
|                        | PRCM_MP_U_SRAMRETO_NIN[0]    | 11                                                                                        | SRAM retention on signal to MPU power domain (bit 0).                                                    | Retention is ON             | Retention is OFF              |
|                        | PRCM_IVA2_SRAMAGOO_DOUT[1]   | 12                                                                                        | IVA2 array Powergood indication from SRAM to PSCON (bit 1).                                              | Power is stable             | Power is not stable           |
|                        | PRCM_CORE_POWER_G_OOD[2]     | 13                                                                                        | Indicates whether the CORE power switches status (bit 2).                                                | Power is stable             | Power is not stable           |
|                        | PRCM_CORE_SRAMRET_ONIN[3]    | 14                                                                                        | SRAM retention on signal to CORE power domain (bit 3).                                                   | Retention is ON             | Retention is OFF              |
|                        | PRCM_SGX_POWER_GO_OD[3]      | 15                                                                                        | Indicates whether the SGX power switches status (bit 3).                                                 | Power is stable             | Power is not stable           |
|                        | PRCM_CAM_POWER_GO_OD[1]      | 16                                                                                        | Indicates whether the CAM power switches status (bit 1).                                                 | Power is stable             | Power is not stable           |
|                        | PRCM_DPLL1_POWER_ISO         | 17                                                                                        | PM command for DPLL1 domain isolation.                                                                   | Isolation is ON             | Isolation is OFF              |
|                        | PRCM_PER_POWER_GO_OD[3]      | 18                                                                                        | Indicates whether the PER power switches status (bit 3).                                                 | Power is stable             | Power is not stable           |
|                        | PRCM_FORCEACTIVEWK_UP        | 19                                                                                        | If asserted, the WKUP domain is unable to start a sleep transition.                                      | Sleep transition impossible | Sleep transition possible     |
|                        | PRCM_USBHOST_SWAK_EUP        | 20                                                                                        | USBHOST asserts this signal to initiate a transition to WAKEUP mode.                                     | Transition initiated        | Wakeup conditions not reached |
|                        | Reserved                     | (31:21)                                                                                   | –                                                                                                        | –                           | –                             |

<sup>(1)</sup> Mode 5 in MUXMODE0 field CONTROL.CONTROL\_PADCONF\_CAM\_FLD[2:0]

**Table 13-52. Internal Signals Multiplexed on WKUPOBSMUX4**

| Pin Name               | Observed Signal Name         | WKUPOBSMU<br>X4 Field<br><b>CONTROL.CO</b><br><b>NTROL_WKUP</b><br><b>_DEBOBS_1[4:<br/>0] (dec)</b> | Description                                                                                               | High State                  | Low State                     |
|------------------------|------------------------------|-----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------|-------------------------------|
| hw_dbg4 <sup>(1)</sup> | CORE_OBSMUX4                 | 0                                                                                                   | Signal multiplexed by OBSMUX4.                                                                            | –                           | –                             |
|                        | PRCM_DPLL4_ALWON_F_CLK       | 1                                                                                                   | Always-on functional clock of DPLL4.                                                                      | –                           | –                             |
|                        | PRCM_GPT9_ALWON_FC_LK        | 2                                                                                                   | Always-on functional clock of GP-Timer #9.                                                                | –                           | –                             |
|                        | PRCM_CAM_RST                 | 3                                                                                                   | Reset signal for CAM module.                                                                              | Reset is not active         | Reset is active               |
|                        | Reserved for non-GP devices  | 4                                                                                                   | Reserved for non-GP devices                                                                               | Reset is not active         | Reset is active               |
|                        | PRCM_MPUs_domainIsOn         | 5                                                                                                   | Indicates to the global Power Manager FSM that the MPU domain power state is ON.                          | State is ON                 | State is not ON               |
|                        | PRCM_mpu_domain_is_inactive  | 6                                                                                                   | Indicates whether the MPU domain is active or not.                                                        | Domain is inactive          | Domain is active              |
|                        | PRCM_mpu_domain_is_retention | 7                                                                                                   | Indicates to the global Power Manager FSM that the MPU domain power state is RETENTION.                   | State is RETENTIO N         | State is not RETENTIO N       |
|                        | PRCM_mpu_domain_is_off       | 8                                                                                                   | Indicates to the global Power Manager FSM that the MPU domain power state is OFF.                         | State is OFF                | State is not OFF              |
|                        | PRCM_SYS_CLKREQ_in           | 9                                                                                                   | When SYS_CLKREQ is used as an input, it is used to control the SYS.CLKOUT1 (and the internal oscillator). | –                           | –                             |
|                        | PRCM_vdd1_domain_go_off_mode | 10                                                                                                  | Indicates a transition of the <b>VDD1</b> domain to OFF_MODE.                                             | Transition initiated        | No transition                 |
|                        | PRCM_MPUs_SRAMRETONIN[1]     | 11                                                                                                  | SRAM retention on signal to MPU power domain (bit 1).                                                     | Retention is ON             | Retention is OFF              |
|                        | PRCM_IVA2_SRAMAGOO_DOUT[2]   | 12                                                                                                  | IVA2 array Powergood indication from SRAM to PSCON (bit 2).                                               | Power is stable             | Power is not stable           |
|                        | PRCM_CORE_POWER_GOOD[3]      | 13                                                                                                  | Indicates whether the CORE power switches status (bit 3).                                                 | Power is stable             | Power is not stable           |
|                        | PRCM_CORE_SRAMRET_ONIN[4]    | 14                                                                                                  | SRAM retention on signal to CORE power domain (bit 4).                                                    | Retention is ON             | Retention is OFF              |
|                        | PRCM_SGX_SRAMAONIN[0]        | 15                                                                                                  | SRAM array power control input (bit 2) for SGX power domain.                                              | Array is powered            | Array is not powered          |
|                        | PRCM_CAM_POWER_GOOD[2]       | 16                                                                                                  | Indicates whether the CAM power switches status (bit 2).                                                  | Power is stable             | Power is not stable           |
|                        | PRCM_DPLL1_POWER_GOOD[0]     | 17                                                                                                  | Indicates whether the DPLL1 power switches status (bit 0).                                                | Power is stable             | Power is not stable           |
|                        | PRCM_PER_POWER_RET           | 18                                                                                                  | PER domain switch command for power-retention.                                                            | Retention is ON             | Retention is OFF              |
|                        | PRCM_FORCEACTIVECORE         | 19                                                                                                  | If asserted, the CORE domain is unable to start a sleep transition.                                       | Sleep transition impossible | Sleep transition possible     |
|                        | PRCM_GPIO2_SWAKEUP           | 20                                                                                                  | GPIO2 asserts this signal to initiate a transition to WAKEUP mode.                                        | Transition initiated        | Wakeup conditions not reached |
|                        | Reserved                     | (31:21)                                                                                             | –                                                                                                         | –                           | –                             |

<sup>(1)</sup> Mode 5 in MUXMODE1 field CONTROL.CONTROL\_PADCONF\_CAM\_D1[18:16]

**Table 13-53. Internal Signals Multiplexed on WKUPOBSMUX5**

| Pin Name               | Observed Signal Name        | WKUPOBSMU X5 Field<br><b>CONTROL.CO NTROL_WKUP _DEBOBS_1[1 2:8] (dec)</b> | Description                                                                                                                                                                                          | High State              | Low State                     |
|------------------------|-----------------------------|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------------------------|
| hw_dbg5 <sup>(1)</sup> | CORE_OBSMUX5                | 0                                                                         | Signal multiplexed by OBSMUX5.                                                                                                                                                                       | –                       | –                             |
|                        | PRCM_DPLL5_ALWON_F CLK      | 1                                                                         | Always-on functional clock of DPLL5.                                                                                                                                                                 | –                       | –                             |
|                        | PRCM_MPU_RST                | 2                                                                         | Reset signal for MPU.                                                                                                                                                                                | Reset is not active     | Reset is active               |
|                        | PRCM_PER_RST                | 3                                                                         | Reset signal for PER domain.                                                                                                                                                                         | Reset is not active     | Reset is active               |
|                        | PRCM_SYNCT_RST              | 4                                                                         | Reset signal for SYNCT domain.                                                                                                                                                                       | Reset is not active     | Reset is active               |
|                        | PRCM_NEON_domainWak eup     | 5                                                                         | Indicates that a wake-up condition is detected for the NEON domain.                                                                                                                                  | Conditions reached      | Conditions not reached        |
|                        | PRCM_vdd1_domain_is_on      | 6                                                                         | Indicates to the global Power Manager FSM that the VDD1 domain power state is ON.                                                                                                                    | State is ON             | State is not ON               |
|                        | PRCM_emu_domain_is_off      | 7                                                                         | Indicates to the global Power Manager FSM that the EMU domain power state is OFF.                                                                                                                    | State is OFF            | State is not OFF              |
|                        | PRCM_vdd4_domain_is_on      | 8                                                                         | Indicates to the global Power Manager FSM that the VDD4 domain power state is ON.                                                                                                                    | State is ON             | State is not ON               |
|                        | PRCM_SYS_CLKREQ_oe_n        | 9                                                                         | Indicates whether the SYS_CLKREQ pin is used as an output (Output ENable).                                                                                                                           | Output enabled          | Output disabled               |
|                        | PRCM_SRAMALLRET[0]          | 10                                                                        | SRAM retention on signal to all power domain (bit 0).                                                                                                                                                | Retention is ON         | Retention is OFF              |
|                        | PRCM_MPU_SRAMRETG_OODOUT[0] | 11                                                                        | Indicates whether the SRAM retention banks in the MPU domain are stable (bit 0).                                                                                                                     | Power is stable         | Power is not stable           |
|                        | PRCM_IVA2_SRAMAGOO_DOUT[3]  | 12                                                                        | IVA2 array Powergood indication from SRAM to PSCON (bit 3).                                                                                                                                          | Power is stable         | Power is not stable           |
|                        | PRCM_CORE_POWER_RET         | 13                                                                        | CORE domain switch command for power-retention.                                                                                                                                                      | Retention is ON         | Retention is OFF              |
|                        | PRCM_CORE_SRAMRET_ONIN[5]   | 14                                                                        | SRAM retention on signal to CORE power domain (bit 5).                                                                                                                                               | Retention is ON         | Retention is OFF              |
|                        | PRCM_SGX_SRAMAGOO_DOUT[0]   | 15                                                                        | SGX array Powergood indication from SRAM to PSCON (bit 0).                                                                                                                                           | Power is stable         | Power is not stable           |
|                        | PRCM_CAM_POWER_GO_OD[3]     | 16                                                                        | Indicates whether the CAM power switches status (bit 3).                                                                                                                                             | Power is stable         | Power is not stable           |
|                        | PRCM_DPLL2_POWER_ON         | 17                                                                        | DPLL2 switch command for power-on.                                                                                                                                                                   | Power is ON             | Power is OFF                  |
|                        | PRCM_PER_POWER_ISO          | 18                                                                        | PM command for PER domain isolation.                                                                                                                                                                 | Isolation is ON         | Isolation is OFF              |
|                        | PRCM_WAKEEMU                | 19                                                                        | This event is used to power-up the EMULATION power domain if it has been previously turned-off; or prevent any further transition to OFF triggered by the applicative software if it was already ON. | EMU domain is forced ON | –                             |
|                        | PRCM_GPT2_SWAKEUP           | 20                                                                        | GP-Timer2 asserts this signal to initiate a transition to WAKEUP mode.                                                                                                                               | Transition initiated    | Wakeup conditions not reached |
|                        | Reserved                    | (31:21)                                                                   | –                                                                                                                                                                                                    | –                       | –                             |

<sup>(1)</sup> Mode 5 in MUXMODE0 field CONTROL.CONTROL\_PADCONF\_CAM\_D3[2:0]

**Table 13-54. Internal Signals Multiplexed on WKUPOBSMUX6**

| Pin Name               | Observed Signal Name                                | WKUPOBSMU<br>X6 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_1[2<br/>0:16] (dec)</b> | Description                                                                              | High State            | Low State                     |
|------------------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-----------------------|-------------------------------|
| hw_dbg6 <sup>(1)</sup> | CORE_OBSMUX6                                        | 0                                                                                         | Signal multiplexed by OBSMUX6.                                                           | –                     | –                             |
|                        | This information is not available in public domain. | 1                                                                                         | This information is not available in public domain.                                      | –                     | –                             |
|                        | PRCM_MPU_RSTPWRON                                   | 2                                                                                         | Cold reset signal for MPU.                                                               | Reset is not active   | Reset is active               |
|                        | PRCM_PER_RSTRET                                     | 3                                                                                         | Retention reset signal for PER domain.                                                   | Reset is not active   | Reset is active               |
|                        | Reserved for non-GP devices                         | 4                                                                                         | Reserved for non-GP devices                                                              | Reset is not active   | Reset is active               |
|                        | PRCM_NEON_domainIsOn                                | 5                                                                                         | Indicates to the global Power Manager FSM that the NEON domain power state is ON.        | State is ON           | State is not ON               |
|                        | PRCM_neon_domain_is_inactive                        | 6                                                                                         | Indicates whether the NEON domain is active or not.                                      | Domain is inactive    | Domain is active              |
|                        | PRCM_neon_domain_is_reten                           | 7                                                                                         | Indicates to the global Power Manager FSM that the NEON domain power state is RETENTION. | State is RETENTIO N   | State is not RETENTIO N       |
|                        | PRCM_neon_domain_is_of                              | 8                                                                                         | Indicates to the global Power Manager FSM that the NEON domain power state is OFF.       | State is OFF          | State is not OFF              |
|                        | Reserved                                            | 9                                                                                         | –                                                                                        | –                     | –                             |
|                        | PRCM_SRAMALLRET[1]                                  | 10                                                                                        | SRAM retention on signal to all power domain (bit 1).                                    | Retention is ON       | Retention is OFF              |
|                        | PRCM_MPU_SRAMRETG_OODOUT[1]                         | 11                                                                                        | Indicates whether the SRAM retention banks in the MPU domain are stable (bit 1).         | Power is stable       | Power is not stable           |
|                        | PRCM_IVA2_SRAMAGOO_DOUT[4]                          | 12                                                                                        | IVA2 array Powergood indication from SRAM to PSCON (bit 4).                              | Power is stable       | Power is not stable           |
|                        | PRCM_CORE_SRAMAONI_N[0]                             | 13                                                                                        | SRAM array power control input (bit 0) for CORE power domain.                            | Array is powered      | Array is not powered          |
|                        | PRCM_CORE_SRAMRET_GOODOUT[0]                        | 14                                                                                        | Indicates whether the SRAM retention banks in the CORE domain are stable (bit 0).        | Power is stable       | Power is not stable           |
|                        | PRCM_SGX_SRAMRETO_NIN[0]                            | 15                                                                                        | SRAM retention on signal to SGX power domain (bit 0).                                    | Retention is ON       | Retention is OFF              |
|                        | PRCM_CAM_SRAMAONIN [0]                              | 16                                                                                        | SRAM array power control input (bit 0) for CAM power domain.                             | Array is powered      | Array is not powered          |
|                        | PRCM_DPLL2_POWER_ISO                                | 17                                                                                        | PM command for DPLL2 domain isolation.                                                   | Isolation is ON       | Isolation is OFF              |
|                        | PRCM_PER_SRAMAONIN [0]                              | 18                                                                                        | SRAM array power control input (bit 0) for PER power domain.                             | Array is powered      | Array is not powered          |
|                        | PRCM_IPPWRR                                         | 19                                                                                        | Indicates whether the emulation power domain is fully operational.                       | EMU power operational | EMU power not operational     |
|                        | PRCM_MCBSP2_SWAKE_UP                                | 20                                                                                        | MCBSP2 asserts this signal to initiate a transition to WAKEUP mode.                      | Transition initiated  | Wakeup conditions not reached |
|                        | Reserved                                            | (31:21)                                                                                   | –                                                                                        | –                     | –                             |

<sup>(1)</sup> Mode 5 in MUXMODE1 field CONTROL.CONTROL\_PADCONF\_CAM\_D3[18:16] 894

**Table 13-55. Internal Signals Multiplexed on WKUPOBSMUX7**

| Pin Name               | Observed Signal Name             | WKUPOBSMU<br>X7 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_1[2<br/>8:24] (dec)</b> | Description                                                                                 | High State           | Low State                     |
|------------------------|----------------------------------|-------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------|-------------------------------|
| hw_dbg7 <sup>(1)</sup> | CORE_OBSMUX7                     | 0                                                                                         | Signal multiplexed by OBSMUX7.                                                              | –                    | –                             |
|                        | Reserved                         | 1                                                                                         | –                                                                                           | –                    | –                             |
|                        | PRCM_IVA2_RST1                   | 2                                                                                         | Reset signal 1 for IVA2.                                                                    | Reset is not active  | Reset is active               |
|                        | PRCM_WKUP_RST                    | 3                                                                                         | Reset signal for WKUP domain.                                                               | Reset is not active  | Reset is active               |
|                        | PRCM_ICEPICK_RST                 | 4                                                                                         | Reset signal for ICEPICK module.                                                            | Reset is not active  | Reset is active               |
|                        | PRCM_IVA2_domainWake up          | 5                                                                                         | Indicates that a wake-up condition is detected for the IVA2 domain.                         | Conditions reached   | Conditions not reached        |
|                        | PRCM_usbhost_domain_is_inactive  | 6                                                                                         | Indicates whether the USBHOST domain is active or not.                                      | Domain is inactive   | Domain is active              |
|                        | PRCM_usbhost_domain_is_retention | 7                                                                                         | Indicates to the global Power Manager FSM that the USBHOST domain power state is RETENTION. | State is RETENTIO N  | State is not RETENTIO N       |
|                        | PRCM_usbhost_domain_is_off       | 8                                                                                         | Indicates to the global Power Manager FSM that the USBHOST domain power state is OFF.       | State is OFF         | State is not OFF              |
|                        | Reserved                         | 9                                                                                         | –                                                                                           | –                    | –                             |
|                        | PRCM_SRAMALLOFF[0]               | 10                                                                                        | Signal is asserted by the PRM when the device enters in OFF mode(bit 0).                    | State is OFF         | State is not OFF              |
|                        | PRCM_IVA2_POWER_ON               | 11                                                                                        | IVA2 switch command for power-on.                                                           | Power is ON          | Power is OFF                  |
|                        | PRCM_IVA2_SRAMRETONIN[0]         | 12                                                                                        | SRAM retention on signal to IVA2 power domain (bit 0).                                      | Retention is ON      | Retention is OFF              |
|                        | PRCM_CORE_SRAMAONIN[1]           | 13                                                                                        | SRAM array power control input (bit 1) for CORE power domain.                               | Array is powered     | Array is not powered          |
|                        | PRCM_CORE_SRAMRETGOODOUT[1]      | 14                                                                                        | Indicates whether the SRAM retention banks in the CORE domain are stable (bit 1).           | Power is stable      | Power is not stable           |
|                        | PRCM_SGX_SRAMRETGODOUT[0]        | 15                                                                                        | Indicates whether the SRAM retention banks in the SGX domain are stable (bit 0).            | Power is stable      | Power is not stable           |
|                        | PRCM_CAM_SRAMAGOODOUT[0]         | 16                                                                                        | CAM array Powergood indication from SRAM to PSCON (bit 0).                                  | Power is stable      | Power is not stable           |
|                        | PRCM_DPLL2_POWER_GOOD[0]         | 17                                                                                        | Indicates whether the DPLL2 power switches status (bit 0).                                  | Power is stable      | Power is not stable           |
|                        | PRCM_PER_SRAMAGOODOUT[0]         | 18                                                                                        | PER array Powergood indication from SRAM to PSCON (bit 0).                                  | Power is stable      | Power is not stable           |
|                        | Reserved for non-GP devices      | 19                                                                                        | Reserved for non-GP devices .                                                               | Detection possible   | Detection impossible          |
|                        | PRCM_USBHS_SWAKEUP               | 20                                                                                        | USBOTGHS asserts this signal to initiate a transition to WAKEUP mode.                       | Transition initiated | Wakeup conditions not reached |
|                        | Reserved                         | (31:21)                                                                                   | –                                                                                           | –                    | –                             |

<sup>(1)</sup> Mode 5 in MUXMODE0 field CONTROL.CONTROL\_PADCONF\_CAM\_D5[2:0]

**Table 13-56. Internal Signals Multiplexed on WKUPOBSMUX8**

| Pin Name               | Observed Signal Name         | WKUPOBSMU<br>X8 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_2[4:<br/>0] (dec)</b> | Description                                                                              | High State           | Low State                     |
|------------------------|------------------------------|-----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|----------------------|-------------------------------|
| hw_dbg8 <sup>(1)</sup> | CORE_OBSMUX8                 | 0                                                                                       | Signal multiplexed by OBSMUX8.                                                           | –                    | –                             |
|                        | PRCM_USBHOST_SAR_FCLK        | 1                                                                                       | Functional clock of USBHOST.                                                             | –                    | –                             |
|                        | PRCM_NEON_RST                | 2                                                                                       | Reset signal for NEON.                                                                   | Reset is not active  | Reset is active               |
|                        | PRCM_WKUP_RSTPWRO_N          | 3                                                                                       | Cold reset signal for WKUP domain.                                                       | Reset is not active  | Reset is active               |
|                        | PRCM_VDD1_VOLCON_RST         | 4                                                                                       | Reset signal for VDD1_VOLCON.                                                            | Reset is not active  | Reset is active               |
|                        | PRCM_IVA2_domainIsOn         | 5                                                                                       | Indicates to the global Power Manager FSM that the IVA2 domain power state is ON.        | State is ON          | State is not ON               |
|                        | PRCM_iv2_domain_is_inactive  | 6                                                                                       | Indicates whether the IVA2 domain is active or not.                                      | Domain is inactive   | Domain is active              |
|                        | PRCM_iv2_domain_is_retention | 7                                                                                       | Indicates to the global Power Manager FSM that the IVA2 domain power state is RETENTION. | State is RETENTIO N  | State is not RETENTIO N       |
|                        | PRCM_iv2_domain_is_off       | 8                                                                                       | Indicates to the global Power Manager FSM that the IVA2 domain power state is OFF.       | State is OFF         | State is not OFF              |
|                        | Reserved                     | 9                                                                                       | –                                                                                        | –                    | –                             |
|                        | PRCM_SRAMALLOFF[1]           | 10                                                                                      | Signal is asserted by the PRM when the device enters in OFF mode (bit 1).                | State is OFF         | State is not OFF              |
|                        | PRCM_IVA2_POWER_ISO          | 11                                                                                      | PM command for IVA2 domain isolation.                                                    | Isolation is ON      | Isolation is OFF              |
|                        | PRCM_IVA2_SRAMRETONIN[1]     | 12                                                                                      | SRAM retention on signal to IVA2 power domain (bit 1).                                   | Retention is ON      | Retention is OFF              |
|                        | PRCM_CORE_SRAMAONIN[2]       | 13                                                                                      | SRAM array power control input (bit 2) for CORE power domain.                            | Array is powered     | Array is not powered          |
|                        | PRCM_CORE_SRAMRETGOODOUT[2]  | 14                                                                                      | Indicates whether the SRAM retention banks in the CORE domain are stable (bit 2).        | Power is stable      | Power is not stable           |
|                        | PRCM_DSS_POWER_ON            | 15                                                                                      | DSS switch command for power-on.                                                         | Power is ON          | Power is OFF                  |
|                        | PRCM_CAM_SRAMRETONIN[0]      | 16                                                                                      | SRAM retention on signal to CAM power domain (bit 0).                                    | Retention is ON      | Retention is OFF              |
|                        | PRCM_DPLL3_POWER_ON          | 17                                                                                      | DPLL3 switch command for power-on.                                                       | Power is ON          | Power is OFF                  |
|                        | PRCM_PER_SRAMRETONIN[0]      | 18                                                                                      | SRAM retention on signal to PER power domain (bit 0).                                    | Retention is ON      | Retention is OFF              |
|                        | PRCM_USBHOST_ISO_SAR         | 19                                                                                      | PM command for USBHOST domain isolation.                                                 | Isolation is ON      | Isolation is OFF              |
|                        | PRCM_GPT10_SWAKEUP           | 20                                                                                      | GP-Timer10 asserts this signal to initiate a transition to WAKEUP mode.                  | Transition initiated | Wakeup conditions not reached |
|                        | Reserved                     | (31:21)                                                                                 | –                                                                                        | –                    | –                             |

<sup>(1)</sup> Mode 5 in MUXMODE1 field CONTROL.CONTROL\_PADCONF\_CAM\_D9[18:16]

**Table 13-57. Internal Signals Multiplexed on WKUPOBSMUX9**

| Pin Name               | Observed Signal Name        | WKUPOBSMU X9 Field<br><b>CONTROL.CO NTROL_WKUP _DEBOBS_2[1 2:8]</b> (dec) | Description                                                                                                     | High State                  | Low State                     |
|------------------------|-----------------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-----------------------------|-------------------------------|
| hw_dbg9 <sup>(1)</sup> | CORE_OBSMUX9                | 0                                                                         | Signal multiplexed by OBSMUX9.                                                                                  | –                           | –                             |
|                        | PRCM_USBPLL_SAR_FCLK        | 1                                                                         | Functional clock of USBPLL.                                                                                     | –                           | –                             |
|                        | PRCM_IVA2_RST2              | 2                                                                         | Reset signal 2 for IVA2.                                                                                        | Reset is not active         | Reset is active               |
|                        | PRCM_EMU_RST                | 3                                                                         | Reset signal for EMU domain.                                                                                    | Reset is not active         | Reset is active               |
|                        | PRCM_VDD2_VOLCON_RST        | 4                                                                         | Reset signal for VDD2_VOLCON.                                                                                   | Reset is not active         | Reset is active               |
|                        | PRCM_COREL3_domainWakeUp    | 5                                                                         | Indicates that a wake-up condition is detected for the COREL3 domain.                                           | Conditions reached          | Conditions not reached        |
|                        | PRCM_vdd1_domain_is_good    | 6                                                                         | Indicates whether the <b>VDD1</b> power domain is stable.                                                       | Power is stable             | Power is not stable           |
|                        | PRCM_vdd1_domain_is_sleep   | 7                                                                         | Indicates to the global Power Manager FSM that the <b>VDD1</b> domain power state is SLEEP.                     | State is SLEEP              | State is not SLEEP            |
|                        | PRCM_vdd4_domain_is_of      | 8                                                                         | Indicates to the global Power Manager FSM that the VDD4 domain power state is OFF.                              | State is OFF                | State is not OFF              |
|                        | PRCM_Device_wakeup          | 9                                                                         | When a wakeup transition occurs, this signal (sent by the last pad) indicates that all pads have been waken-up. | All pads have been waken-up | Some pads are in SLEEP mode   |
|                        | PRCM_MP_U_POWER_ON          | 10                                                                        | MPU switch command for power-on.                                                                                | Power is ON                 | Power is OFF                  |
|                        | PRCM_IVA2_POWER_GO_OD[0]    | 11                                                                        | Indicates whether the IVA2 power switches status (bit 0).                                                       | Power is stable             | Power is not stable           |
|                        | PRCM_IVA2_SRAMRETONIN[2]    | 12                                                                        | SRAM retention on signal to IVA2 power domain (bit 2).                                                          | Retention is ON             | Retention is OFF              |
|                        | PRCM_CORE_SRAMAONIN[3]      | 13                                                                        | SRAM array power control input (bit 3) for CORE power domain.                                                   | Array is powered            | Array is not powered          |
|                        | PRCM_CORE_SRAMRETGOODOUT[3] | 14                                                                        | Indicates whether the SRAM retention banks in the CORE domain are stable (bit 3).                               | Power is stable             | Power is not stable           |
|                        | PRCM_DSS_POWER_ISO          | 15                                                                        | PM command for DSS domain isolation.                                                                            | Isolation is ON             | Isolation is OFF              |
|                        | PRCM_CAM_SRAMRETGODOUT[0]   | 16                                                                        | Indicates whether the SRAM retention banks in the CAM domain are stable (bit 0).                                | Power is stable             | Power is not stable           |
|                        | PRCM_DPLL3_POWER_ISO        | 17                                                                        | PM command for DPLL3 domain isolation.                                                                          | Isolation is ON             | Isolation is OFF              |
|                        | PRCM_PER_SRAMRETGODOUT[0]   | 18                                                                        | Indicates whether the SRAM retention banks in the PER domain are stable (bit 0).                                | Power is stable             | Power is not stable           |
|                        | PRCM_USBHOST_STARTSAVE      | 19                                                                        | Context Save Start Control.                                                                                     | Started                     | Not started                   |
|                        | PRCM_USBPLL_SWAKEUP         | 20                                                                        | USBPLL asserts this signal to initiate a transition to WAKEUP mode.                                             | Transition initiated        | Wakeup conditions not reached |
| Reserved               |                             | (31:21)                                                                   | –                                                                                                               | –                           | –                             |

<sup>(1)</sup> Mode 5 in MUXMODE0 field CONTROL.CONTROL\_PADCONF\_CAM\_D11[2:0]

**Table 13-58. Internal Signals Multiplexed on WKUPOBSMUX10**

| Pin Name                | Observed Signal Name         | WKUPOBSMU<br>X10 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_2[2<br/>0:16] (dec)</b> | Description                                                                             | High State           | Low State                     |
|-------------------------|------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|----------------------|-------------------------------|
| hw_dbg10 <sup>(1)</sup> | CORE_OBSMUX10                | 0                                                                                          | Signal multiplexed by OBSMUX 10.                                                        | –                    | –                             |
|                         | PRCM_FUNC_96M_ALWN_CLK       | 1                                                                                          | 96-MHz Always-on functional clock.                                                      | –                    | –                             |
|                         | PRCM_IVA2_RST3               | 2                                                                                          | Reset signal 3 for IVA2 domain.                                                         | Reset is not active  | Reset is active               |
|                         | PRCM_EMU_RSTPWRON            | 3                                                                                          | Cold Reset signal for EMU domain.                                                       | Reset is not active  | Reset is active               |
|                         | PRCM_CM_RSTPWRONRET          | 4                                                                                          | Cold retention reset signal for CM.                                                     | Reset is not active  | Reset is active               |
|                         | PRCM_COREL3_domainsOn        | 5                                                                                          | Indicates to the global Power Manager FSM that the COREL3 domain power state is ON.     | State is ON          | State is not ON               |
|                         | PRCM_sgx_domain_is_inactive  | 6                                                                                          | Indicates whether the SGX domain is active or not.                                      | Domain is inactive   | Domain is active              |
|                         | PRCM_sgx_domain_is_retention | 7                                                                                          | Indicates to the global Power Manager FSM that the SGX domain power state is RETENTION. | State is RETENTION   | State is not RETENTION        |
|                         | PRCM_sgx_domain_is_off       | 8                                                                                          | Indicates to the global Power Manager FSM that the SGX domain power state is OFF.       | State is OFF         | State is not OFF              |
|                         | PRCM_PADS_OFF_mode           | 9                                                                                          | Indicates whether the I/O pads are in OFF-mode.                                         | State is OFF         | State is not OFF              |
|                         | PRCM_MPUI_POWER_ISO          | 10                                                                                         | PM command for MPU domain isolation.                                                    | Isolation is ON      | Isolation is OFF              |
|                         | PRCM_IVA2_POWER_GOOD[1]      | 11                                                                                         | Indicates whether the IVA2 power switches status (bit 1).                               | Power is stable      | Power is not stable           |
|                         | PRCM_IVA2_SRAMRETONIN[3]     | 12                                                                                         | SRAM retention on signal to IVA2 power domain (bit 3).                                  | Retention is ON      | Retention is OFF              |
|                         | PRCM_CORE_SRAMAONIN[4]       | 13                                                                                         | SRAM array power control input (bit 4) for CORE power domain.                           | Array is powered     | Array is not powered          |
|                         | PRCM_CORE_SRAMRETGOODOUT[4]  | 14                                                                                         | Indicates whether the SRAM retention banks in the CORE domain are stable (bit 4).       | Power is stable      | Power is not stable           |
|                         | PRCM_DSS_POWER_GOOD[0]       | 15                                                                                         | Indicates whether the DSS power switches status (bit 0).                                | Power is stable      | Power is not stable           |
|                         | PRCM_EMU_POWER_ON            | 16                                                                                         | EMU switch command for power-on.                                                        | Power is ON          | Power is OFF                  |
|                         | PRCM_DPLL3_POWER_GOOD[0]     | 17                                                                                         | Indicates whether the DPLL3 power switches status (bit 0).                              | Power is stable      | Power is not stable           |
|                         | PRCM_USBHOST_POWER_ON        | 18                                                                                         | USBHOST switch command for power-on.                                                    | Power is ON          | Power is OFF                  |
|                         | PRCM_USBHOST_SAVEDONE        | 19                                                                                         | Indicates that the Context Save is done.                                                | Context saved        | Context not saved             |
|                         | PRCM_GPIO1_SWAKEUP           | 20                                                                                         | GPIO1 asserts this signal to initiate a transition to WAKEUP mode.                      | Transition initiated | Wakeup conditions not reached |
|                         | Reserved                     | (31:21)                                                                                    | –                                                                                       | –                    | –                             |

<sup>(1)</sup> Mode 5 in MUXMODE0 field CONTROL.CONTROL\_PADCONF\_CAM\_WEN[2:0]

**Table 13-59. Internal Signals Multiplexed on WKUPOBSMUX11**

| Pin Name                | Observed Signal Name         | WKUPOBSMU X11 Field<br><b>CONTROL.CO NTROL_WKUP _DEBOBS_2[2 8:24] (dec)</b> | Description                                                                                                     | High State                  | Low State                       |
|-------------------------|------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-----------------------------|---------------------------------|
| hw_dbg11 <sup>(1)</sup> | CORE_OBSMUX11                | 0                                                                           | Signal multiplexed by OBSMUX11.                                                                                 | –                           | –                               |
|                         | PRCM_DSS2_ALWON_FCLK         | 1                                                                           | Always-on functional clock 2 of DSS module.                                                                     | –                           | –                               |
|                         | PRCM_IVA2_RSTPWRON           | 2                                                                           | Cold reset signal for IVA2 domain.                                                                              | Reset is not active         | Reset is active                 |
|                         | PRCM_EFUSE_RSTPWRON          | 3                                                                           | Cold reset signal for EFUSE.                                                                                    | Reset is not active         | Reset is active                 |
|                         | PRCM_DPLL3_rstdata           | 4                                                                           | Reset signal for DPLL3.                                                                                         | Reset active                | Reset not active                |
|                         | PRCM_SGX_domainWake up       | 5                                                                           | Indicates that a wake-up condition is detected for the SGX domain.                                              | Conditions reached          | Conditions not reached          |
|                         | PRCM_vdd1_domain_is_of f     | 6                                                                           | Indicates to the global Power Manager FSM that the <b>VDD1</b> domain power state is OFF.                       | State is OFF                | State is not OFF                |
|                         | PRCM_vdd1_domain_is_lp       | 7                                                                           | Indicates whether the voltage supply of the <b>VDD1</b> domain is in a low power mode: OFF, RETENTION or SLEEP. | Low power activated         | Low power not activated         |
|                         | PRCM_PRM2MPU_IRQ             | 8                                                                           | Interrupt line from PRM to the MPU.                                                                             | –                           | –                               |
|                         | PRCM_GLOBAL_WKUP_en          | 9                                                                           | Signal that enables a Global Wakeup.                                                                            | Wakeup enabled              | Wakeup disabled                 |
|                         | PRCM_MPUPOWER_GO OD[0]       | 10                                                                          | Indicates whether the MPU power switches status (bit 0).                                                        | Power is stable             | Power is not stable             |
|                         | PRCM_IVA2_POWER_GO OD[2]     | 11                                                                          | Indicates whether the IVA2 power switches status (bit 2).                                                       | Power is stable             | Power is not stable             |
|                         | PRCM_IVA2_SRAMRETONIN[4]     | 12                                                                          | SRAM retention on signal to IVA2 power domain (bit 4).                                                          | Retention is ON             | Retention is OFF                |
|                         | PRCM_CORE_SRAMAONIN[5]       | 13                                                                          | SRAM array power control input (bit 5) for CORE power domain.                                                   | Array is powered            | Array is not powered            |
|                         | PRCM_CORE_SRAMRET GOODOUT[5] | 14                                                                          | Indicates whether the SRAM retention banks in the CORE domain are stable (bit 5).                               | Power is stable             | Power is not stable             |
|                         | PRCM_DSS_POWER_GO OD[1]      | 15                                                                          | Indicates whether the DSS power switches status (bit 1).                                                        | Power is stable             | Power is not stable             |
|                         | PRCM_EMU_POWER_ISO           | 16                                                                          | PM command for EMU domain isolation.                                                                            | Isolation is ON             | Isolation is OFF                |
|                         | PRCM_DPLL4_POWER_ON          | 17                                                                          | DPLL4 switch command for power-on.                                                                              | Power is ON                 | Power is OFF                    |
|                         | PRCM_USBHOST_POWER_ISO       | 18                                                                          | PM command for USBHOST domain isolation.                                                                        | Isolation is ON             | Isolation is OFF                |
|                         | PRCM_USBHOST_START RESTORE   | 19                                                                          | Context Restore Start Control.                                                                                  | Context restoration started | Context restoration not started |
|                         | Reserved                     | 20                                                                          | –                                                                                                               | –                           | –                               |
|                         | PRCM_WAITINRESET_WK          | 21                                                                          | Indicates whether the device is booting in Wait-In-Reset mode.                                                  | Wait-In-Reset mode          | Standard boot                   |
|                         | Reserved                     | (31:22)                                                                     | –                                                                                                               | –                           | –                               |

<sup>(1)</sup> Mode 5 in MUXMODE1 field CONTROL.CONTROL\_PADCONF\_CAM\_WEN[18:16]

**Table 13-60. Internal Signals Multiplexed on WKUPOBSMUX12**

| Pin Name                | Observed Signal Name                                | WKUPOBSMU<br>X12 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_3[4:<br/>0] (dec)</b> | Description                                                                              | High State          | Low State               |
|-------------------------|-----------------------------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|---------------------|-------------------------|
| hw_dbg12 <sup>(1)</sup> | CORE_OBSMUX12                                       | 0                                                                                        | Signal multiplexed by OBSMUX12.                                                          | –                   | –                       |
|                         | PRCM_EFUSE_ALWON_F_CLK                              | 1                                                                                        | Always-on functional clock of Efuse.                                                     | –                   | –                       |
|                         | PRCM_IVA2_RSTDONE                                   | 2                                                                                        | Status of the IVA2.2 module after a reset.                                               | Reset is not active | Reset is active         |
|                         | This information is not available in public domain. | 3                                                                                        | This information is not available in public domain.                                      |                     |                         |
|                         | PRCM_GlbRstData                                     | 4                                                                                        | Global reset signal.                                                                     | Reset is not active | Reset is active         |
|                         | PRCM_SGX_domainIsOn                                 | 5                                                                                        | Indicates to the global Power Manager FSM that the SGX domain power state is ON.         | State is ON         | State is not ON         |
|                         | PRCM_core_domain_is_inactive                        | 6                                                                                        | Indicates whether the CORE domain is active or not.                                      | Domain is inactive  | Domain is active        |
|                         | PRCM_core_domain_is_retention                       | 7                                                                                        | Indicates to the global Power Manager FSM that the CORE domain power state is RETENTION. | State is RETENTIO N | State is not RETENTIO N |
|                         | PRCM_core_domain_is_off                             | 8                                                                                        | Indicates to the global Power Manager FSM that the CORE domain power state is OFF.       | State is OFF        | State is not OFF        |
|                         | PRCM_IO_WUCLK                                       | 9                                                                                        | I/O Wakeup clock.                                                                        | –                   | –                       |
|                         | PRCM_MP_UPOWER_GO_OD[1]                             | 10                                                                                       | Indicates whether the MPU power switches status (bit 1).                                 | Power is stable     | Power is not stable     |
|                         | PRCM_IVA2_POWER_GO_OD[3]                            | 11                                                                                       | Indicates whether the IVA2 power switches status (bit 3).                                | Power is stable     | Power is not stable     |
|                         | PRCM_IVA2_SRAMRETG_OODOUT[0]                        | 12                                                                                       | Indicates whether the SRAM retention banks in the IVA2 domain are stable (bit 0).        | Power is stable     | Power is not stable     |
|                         | PRCM_CORE_SRAMAGO_OODOUT[0]                         | 13                                                                                       | CORE array Powergood indication from SRAM to PSCON (bit 0).                              | Power is stable     | Power is not stable     |
|                         | PRCM_NEON_POWER_ON                                  | 14                                                                                       | NEON switch command for power-on.                                                        | Power is ON         | Power is OFF            |
|                         | PRCM_DSS_POWER_GO_OD[2]                             | 15                                                                                       | Indicates whether the DSS power switches status (bit 2).                                 | Power is stable     | Power is not stable     |
|                         | PRCM_EMU_POWER_GO_OD[0]                             | 16                                                                                       | Indicates whether the EMU power switches status (bit 0).                                 | Power is stable     | Power is not stable     |
|                         | PRCM_DPLL4_POWER_ISO                                | 17                                                                                       | PM command for DPLL4 domain isolation.                                                   | Isolation is ON     | Isolation is OFF        |
|                         | PRCM_USBHOST_POWER_GOOD[0]                          | 18                                                                                       | Indicates whether the USBHOST power switches status (bit 0).                             | Power is stable     | Power is not stable     |
|                         | PRCM_USBHOST_RESTOREDONE                            | 19                                                                                       | Indicates that the Context Restore is done.                                              | Restore done        | Restore not finished    |
|                         | Reserved                                            | (31:20)                                                                                  | –                                                                                        | –                   | –                       |

<sup>(1)</sup> Mode 5 in MUXMODE0 field CONTROL.CONTROL\_PADCONF\_DSS\_PCLK[2:0]

**Table 13-61. Internal Signals Multiplexed on WKUPOBSMUX13**

| Pin Name                | Observed Signal Name         | WKUPOBSMU<br>X13 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_3[1<br/>2:8] (dec)</b> | Description                                                                              | High State           | Low State                     |
|-------------------------|------------------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|----------------------|-------------------------------|
| hw_dbg13 <sup>(1)</sup> | CORE_OBSMUX13                | 0                                                                                         | Signal multiplexed by OBSMUX13.                                                          | –                    | –                             |
|                         | PRCM_PER_32K_ALWON_FCLK      | 1                                                                                         | Always-on 23KHz functional clock of PER domain.                                          | –                    | –                             |
|                         | PRCM_CORE_RST                | 2                                                                                         | Reset signal for CORE domain.                                                            | Reset is not active  | Reset is active               |
|                         | PRCM_DPLL1_RSTPWRO_N         | 3                                                                                         | Cold reset signal for DPLL1.                                                             | Reset is active      | Reset is not active           |
|                         | PRCM_GlblWarmRst_n           | 4                                                                                         | Global warm reset signal.                                                                | Reset is active      | Reset is not active           |
|                         | PRCM_COREL4_domainWakeupe    | 5                                                                                         | Indicates that a wake-up condition is detected for the COREL4 domain.                    | Conditions reached   | Conditions not reached        |
|                         | PRCM_vdd1_domain_is_rete     | 6                                                                                         | Indicates to the global Power Manager FSM that the VDD1 domain power state is RETENTION. | State is RETENTIO N  | State is not RETENTIO N       |
|                         | PRCM_vdd2_domain_is_on       | 7                                                                                         | Indicates to the global Power Manager FSM that the VDD2 domain power state is ON.        | State is ON          | State is not ON               |
|                         | PRCM_USBHOST_domainWakeup    | 8                                                                                         | Indicates that a wake-up condition is detected for the USBHOST domain.                   | Conditions reached   | Conditions not reached        |
|                         | PRCM_IO_ISOCLK               | 9                                                                                         | PM Input/Output isolation clock.                                                         | –                    | –                             |
|                         | PRCM_MPUM_POWER_GO_OD[2]     | 10                                                                                        | Indicates whether the MPUM power switches status (bit 2).                                | Power is stable      | Power is not stable           |
|                         | PRCM_IVA2_POWER_GO_OD[4]     | 11                                                                                        | Indicates whether the IVA2 power switches status (bit 4).                                | Power is stable      | Power is not stable           |
|                         | PRCM_IVA2_SRAMRETG_OODOUT[1] | 12                                                                                        | Indicates whether the SRAM retention banks in the IVA2 domain are stable (bit 1).        | Power is stable      | Power is not stable           |
|                         | PRCM_CORE_SRAMAGO_ODOUT[1]   | 13                                                                                        | CORE array Powergood indication from SRAM to PSCON (bit 1).                              | Power is stable      | Power is not stable           |
|                         | PRCM_NEON_POWER_IS_O         | 14                                                                                        | PM command for NEON domain isolation.                                                    | Isolation is ON      | Isolation is OFF              |
|                         | PRCM_DSS_POWER_GO_OD[3]      | 15                                                                                        | Indicates whether the DSS power switches status (bit 3).                                 | Power is stable      | Power is not stable           |
|                         | PRCM_EMU_SRAMAONIN[0]        | 16                                                                                        | SRAM array power control input (bit 0) for EMU power domain.                             | Array is powered     | Array is not powered          |
|                         | PRCM_DPLL4_POWER_GOOD[0]     | 17                                                                                        | Indicates whether the DPLL4 power switches status (bit 0).                               | Power is stable      | Power is not stable           |
|                         | PRCM_USBHOST_SRAM_AONIN[0]   | 18                                                                                        | SRAM array power control input (bit 0) for USBHOST power domain.                         | Array is powered     | Array is not powered          |
|                         | PRCM_USBTL_ISOSAR            | 19                                                                                        | PM command for USBTL domain isolation.                                                   | Isolation is ON      | Isolation is OFF              |
|                         | PRCM_GPT1_SWAKEUP            | 20                                                                                        | FP-Timer1 asserts this signal to initiate a transition to WAKEUP mode.                   | Transition initiated | Wakeup conditions not reached |
|                         | Reserved                     | (31:21)                                                                                   | –                                                                                        | –                    | –                             |

<sup>(1)</sup> Mode 5 in MUXMODE1 field CONTROL.CONTROL\_PADCONF\_DSS\_PCLK[18:16]

**Table 13-62. Internal Signals Multiplexed on WKUPOBSMUX14**

| Pin Name                | Observed Signal Name          | WKUPOBSMU<br>X14 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_3[2<br/>0:16] (dec)</b> | Description                                                                          | High State           | Low State                |
|-------------------------|-------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|----------------------|--------------------------|
| hw_dbg14 <sup>(1)</sup> | CORE_OBSMUX14                 | 0                                                                                          | Signal multiplexed by OBSMUX14.                                                      | –                    | –                        |
|                         | PRCM_GPT1_FCLK                | 1                                                                                          | Functional clock of GP-Timer1.                                                       | –                    | –                        |
|                         | PRCM_CORE_RSTPWRO_NRET        | 2                                                                                          | Cold retention reset signal for CORE domain.                                         | Reset is not active  | Reset is active          |
|                         | PRCM_DPLL2_RSTPWRO_N          | 3                                                                                          | Cold reset signal for DPLL2.                                                         | Reset is active      | Reset is not active      |
|                         | PRCM_GlblPwrOnRst_n           | 4                                                                                          | Global cold reset signal.                                                            | Reset is active      | Reset is not active      |
|                         | PRCM_COREL4_domains_On        | 5                                                                                          | Indicates to the global Power Manager FSM that the COREL4 domain power state is ON.  | State is ON          | State is not ON          |
|                         | PRCM_DSS_domainWake_up        | 6                                                                                          | Indicates that a wake-up condition is detected for the DSS domain.                   | Conditions reached   | Conditions not reached   |
|                         | PRCM_vdd2_domain_is_good      | 7                                                                                          | Indicates whether the VDD2 power domain is stable.                                   | Power is stable      | Power is not stable      |
|                         | PRCM_USBHOST_domain_IsOn      | 8                                                                                          | Indicates to the global Power Manager FSM that the USBHOST domain power state is ON. | State is ON          | State is not ON          |
|                         | PRCM_IO_ISO                   | 9                                                                                          | PM command for I/O isolation.                                                        | Isolation is ON      | Isolation is OFF         |
|                         | PRCM_MPUMOWER_GO_OD[3]        | 10                                                                                         | Indicates whether the MPU power switches status (bit 3).                             | Power is stable      | Power is not stable      |
|                         | PRCM_IVA2_POWER_GO_OD[5]      | 11                                                                                         | Indicates whether the IVA2 power switches status (bit 5).                            | Power is stable      | Power is not stable      |
|                         | PRCM_IVA2_SRAMRETG_OODOUT[2]  | 12                                                                                         | Indicates whether the SRAM retention banks in the IVA2 domain are stable (bit 2).    | Power is stable      | Power is not stable      |
|                         | PRCM_CORE_SRAMAGO_ODOUT[2]    | 13                                                                                         | CORE array Powergood indication from SRAM to PSCON (bit 2).                          | Power is stable      | Power is not stable      |
|                         | PRCM_NEON_POWER_GOOD[0]       | 14                                                                                         | Indicates whether the NEON power switches status (bit 0).                            | Power is stable      | Power is not stable      |
|                         | PRCM_DSS_SRAMAONIN[0]         | 15                                                                                         | SRAM array power control input (bit 0) for DSS power domain.                         | Array is powered     | Array is not powered     |
|                         | PRCM_EMU_SRAMAGOO_DOUT[0]     | 16                                                                                         | EMU array Powergood indication from SRAM to PSCON (bit 0).                           | Power is stable      | Power is not stable      |
|                         | PRCM_DPLL5_POWER_ON           | 17                                                                                         | DPLL5 switch command for power-on.                                                   | Power is ON          | Power is OFF             |
|                         | PRCM_USBHOST_SRAM_AGOODOUT[0] | 18                                                                                         | USBHOST array Powergood indication from SRAM to PSCON (bit 0).                       | Power is stable      | Power is not stable      |
|                         | PRCM_USBTLSTARTS_AVE          | 19                                                                                         | Context Save Start Control.                                                          | Context save started | Context save not started |
|                         | PRCM_EMU_SYS_GCLK             | 20                                                                                         | System clock of the EMU block of the PRCM module.                                    | –                    | –                        |
|                         | Reserved                      | (31:21)                                                                                    | –                                                                                    | –                    | –                        |

<sup>(1)</sup> Mode 5 in MUXMODE0 field CONTROL.CONTROL\_PADCONF\_DSS\_DATA6[2:0]

**Table 13-63. Internal Signals Multiplexed on WKUPOBSMUX15**

| Pin Name                | Observed Signal Name         | WKUPOBSMU<br>X15 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_3[2<br/>8:24] (dec)</b> | Description                                                                             | High State          | Low State               |
|-------------------------|------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|---------------------|-------------------------|
| hw_dbg15 <sup>(1)</sup> | CORE_OBSMUX15                | 0                                                                                          | Signal multiplexed by OBSMUX15.                                                         | –                   | –                       |
|                         | PRCM_GPT2_ALWON_FC_LK        | 1                                                                                          | Always-on functional clock of GP-Timer #2.                                              | –                   | –                       |
|                         | PRCM_CORE_RSTRET             | 2                                                                                          | Retention reset signal for CORE domain.                                                 | Reset is not active | Reset is active         |
|                         | PRCM_DPLL3_RSTPWRO_N         | 3                                                                                          | Cold reset signal for DPLL3.                                                            | Reset is active     | Reset is not active     |
|                         | Reserved for non-GP devices  | 4                                                                                          | Reserved for non-GP devices                                                             | Reset is active     | Reset is not active     |
|                         | Reserved                     | 5                                                                                          | –                                                                                       | –                   | –                       |
|                         | PRCM_DSS_domainIsOn          | 6                                                                                          | Indicates to the global Power Manager FSM that the DSS domain power state is ON.        | State is ON         | State is not ON         |
|                         | PRCM_dss_domain_is_inactive  | 7                                                                                          | Indicates whether the DSS domain is active or not.                                      | Domain is inactive  | Domain is active        |
|                         | PRCM_dss_domain_is_retention | 8                                                                                          | Indicates to the global Power Manager FSM that the DSS domain power state is RETENTION. | State is RETENTIO N | State is not RETENTIO N |
|                         | PRCM_dss_domain_is_off       | 9                                                                                          | Indicates to the global Power Manager FSM that the DSS domain power state is OFF.       | State is OFF        | State is not OFF        |
|                         | PRCM_MPUPOWER_GOOD[4]        | 10                                                                                         | Indicates whether the MPU power switches status (bit 4).                                | Power is stable     | Power is not stable     |
|                         | PRCM_IVA2_SRAMAONIN[0]       | 11                                                                                         | SRAM array power control input (bit 0) for IVA2 power domain.                           | Array is powered    | Array is not powered    |
|                         | PRCM_IVA2_SRAMRETG_OODOUT[3] | 12                                                                                         | Indicates whether the SRAM retention banks in the IVA2 domain are stable (bit 3).       | Power is stable     | Power is not stable     |
|                         | PRCM_CORE_SRAMAGOODOUT[3]    | 13                                                                                         | CORE array Powergood indication from SRAM to PSCON (bit 3).                             | Power is stable     | Power is not stable     |
|                         | PRCM_NEON_POWER_GOOD[1]      | 14                                                                                         | Indicates whether the NEON power switches status (bit 1).                               | Power is stable     | Power is not stable     |
|                         | PRCM_DSS_SRAMAGOO_DOUT[0]    | 15                                                                                         | DSS array Powergood indication from SRAM to PSCON (bit 0).                              | Power is stable     | Power is not stable     |
|                         | PRCM_EMU_SRAMRETONIN[0]      | 16                                                                                         | SRAM retention on signal to EMU power domain (bit 0).                                   | Retention is ON     | Retention is OFF        |
|                         | PRCM_DPLL5_POWER_ISO         | 17                                                                                         | PM command for DPLL5 domain isolation.                                                  | Isolation is ON     | Isolation is OFF        |
|                         | PRCM_USBHOST_SRAMRETTONIN[0] | 18                                                                                         | SRAM retention on signal to USBHOST power domain (bit 0).                               | Retention is ON     | Retention is OFF        |
|                         | PRCM_USBTLLSAVEDONE          | 19                                                                                         | Indicates that the Context Save is done.                                                | Context saved       | Context not saved yet   |
|                         | Reserved                     | (31:20)                                                                                    | –                                                                                       | –                   | –                       |

<sup>(1)</sup> Mode 5 in MUXMODE1 field CONTROL.CONTROL\_PADCONF\_DSS\_DATA6[18:16]

**Table 13-64. Internal Signals Multiplexed on WKUPOBSMUX16**

| Pin Name                | Observed Signal Name            | WKUPOBSMU<br>X16 Field<br><b>CONTROL.CO<br/>NTROL_WKUP<br/>_DEBOBS_4[4:<br/>0] (dec)</b> | Description                                                                          | High State            | Low State              |
|-------------------------|---------------------------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|-----------------------|------------------------|
| hw_dbg16 <sup>(1)</sup> | CORE_OBSMUX16                   | 0                                                                                        | Signal multiplexed by OBSMUX16.                                                      | –                     | –                      |
|                         | PRCM_GPT3_ALWON_FCLK            | 1                                                                                        | Always-on functional clock of GP-Timer #3.                                           | –                     | –                      |
|                         | PRCM_CPEFUSE_RST                | 2                                                                                        | Reset signal for Efuse.                                                              | Reset is not active   | Reset is active        |
|                         | PRCM_DPLL4_RSTPWRO_N            | 3                                                                                        | Cold reset signal for DPLL4.                                                         | Reset is active       | Reset is not active    |
|                         | Reserved for non-GP devices     | 4                                                                                        | Reserved for non-GP devices                                                          | Reset is not active   | Reset is active        |
|                         | Reserved                        | 5                                                                                        | –                                                                                    | –                     | –                      |
|                         | PRCM_PER_domainWake up          | 6                                                                                        | Indicates that a wake-up condition is detected for the PER domain.                   | Conditions reached    | Conditions not reached |
|                         | PRCM_vdd2_domain_is_of f        | 7                                                                                        | Indicates to the global Power Manager FSM that the VDD2 domain power state is OFF.   | State is OFF          | State is not OFF       |
|                         | PRCM_vdd5_domain_is_of f        | 8                                                                                        | Indicates to the global Power Manager FSM that the VDD5 domain power state is OFF.   | State is OFF          | State is not OFF       |
|                         | PRCM_PRM2IVA2_IRQ               | 9                                                                                        | Interrupt line from PRM to the IVA2.                                                 | –                     | –                      |
|                         | PRCM_MPUM_POWER_GO OD[5]        | 10                                                                                       | Indicates whether the MPU power switches status (bit 5).                             | Power is stable       | Power is not stable    |
|                         | PRCM_IVA2_SRAMAONIN [1]         | 11                                                                                       | SRAM array power control input (bit 4) for IVA2 power domain.                        | Array is powered      | Array is not powered   |
|                         | PRCM_IVA2_SRAMRETG OODOUT[4]    | 12                                                                                       | Indicates whether the SRAM retention banks in the IVA2 domain are stable (bit 4).    | Power is stable       | Power is not stable    |
|                         | PRCM_CORE_SRAMAGO OODOUT[4]     | 13                                                                                       | CORE array Powergood indication from SRAM to PSCON (bit 4).                          | Power is stable       | Power is not stable    |
|                         | PRCM_SGX_POWER_ON               | 14                                                                                       | SGX switch command for power-on.                                                     | Power is ON           | Power is OFF           |
|                         | PRCM_DSS_SRAMRETO NIN[0]        | 15                                                                                       | SRAM retention on signal to DSS power domain (bit 0).                                | Retention is ON       | Retention is OFF       |
|                         | PRCM_EMU_SRAMRETG OODOUT[0]     | 16                                                                                       | Indicates whether the SRAM retention banks in the EMU domain are stable (bit 0).     | Power is stable       | Power is not stable    |
|                         | PRCM_DPLL5_POWER_G OOD[0]       | 17                                                                                       | Indicates whether the DPLL5 power switches status (bit 0).                           | Power is stable       | Power is not stable    |
|                         | PRCM_USBHOST_SRAM RETGOODOUT[0] | 18                                                                                       | Indicates whether the SRAM retention banks in the USBHOST domain are stable (bit 0). | Power is stable       | Power is not stable    |
|                         | PRCM_USBTLSTARTRESTORE          | 19                                                                                       | Context Restore Start Control.                                                       | Context restore saved | Saving context         |
|                         | PRCM_WKUP_32K_GFCLK             | 20                                                                                       | 32KHz functional clock of the WKUP domain.                                           | –                     | –                      |
|                         | Reserved                        | (31:21)                                                                                  | –                                                                                    | –                     | –                      |

<sup>(1)</sup> Mode 5 in MUXMODE0 field CONTROL.CONTROL\_PADCONF\_DSS\_DATA8[2:0]

**Table 13-65. Internal Signals Multiplexed on WKUPOBSMUX17**

| Pin Name                                            | Observed Signal Name         | WKUPOBSMUX17 Field<br><b>CONTROL.CONTROL</b><br><b>ROL_WKUP_DEB</b><br><b>OBS_4[12:8]</b><br>(dec) | Description                                                                             | High State          | Low State              |
|-----------------------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|---------------------|------------------------|
| hw_dbg17 <sup>(1)</sup>                             | CORE_OBSMUX17                | 0                                                                                                  | Signal multiplexed by OBSMUX17.                                                         | –                   | –                      |
|                                                     | PRCM_GPT4_ALWON_FCLK         | 1                                                                                                  | Always-on functional clock of GP-Timer #4.                                              | –                   | –                      |
|                                                     | PRCM_USBPLL_RST              | 2                                                                                                  | Reset signal for USBPLL.                                                                | Reset is not active | Reset is active        |
|                                                     | PRCM_DPLL5_RSTPWRO_N         | 3                                                                                                  | Cold reset signal for DPLL5.                                                            | Reset is active     | Reset is not active    |
|                                                     | PRCM_ICECRUSHER_RST          | 4                                                                                                  | Reset signal for ICECrusher                                                             | Reset is not active | Reset is active        |
|                                                     | PRCM_CORECM_domain_Wakeup    | 5                                                                                                  | Indicates that a wake-up condition is detected for the CORECM domain.                   | Conditions reached  | Conditions not reached |
|                                                     | PRCM_PER_domainIsOn          | 6                                                                                                  | Indicates to the global Power Manager FSM that the PER domain power state is ON.        | State is ON         | State is not ON        |
|                                                     | PRCM_PER_domain_is_inactive  | 7                                                                                                  | Indicates whether the PER domain is active or not.                                      | Domain is inactive  | Domain is active       |
|                                                     | PRCM_PER_domain_is_retention | 8                                                                                                  | Indicates to the global Power Manager FSM that the PER domain power state is RETENTION. | State is RETENTION  | State is not RETENTION |
|                                                     | PRCM_PER_domain_is_off       | 9                                                                                                  | Indicates to the global Power Manager FSM that the PER domain power state is OFF.       | State is OFF        | State is not OFF       |
|                                                     | PRCM_MPU_SRAMAONIN[0]        | 10                                                                                                 | SRAM array power control input (bit 0) for MPU power domain.                            | Array is powered    | Array is not powered   |
|                                                     | PRCM_IVA2_SRAMAONIN[2]       | 11                                                                                                 | SRAM array power control input (bit 2) for IVA2 power domain.                           | Array is powered    | Array is not powered   |
|                                                     | PRCM_CORE_POWER_ON           | 12                                                                                                 | CORE switch command for power-on.                                                       | Power is ON         | Power is OFF           |
|                                                     | PRCM_CORE_SRAMAGO_ODOUT[5]   | 13                                                                                                 | CORE array Powergood indication from SRAM to PSCON (bit 5).                             | Power is stable     | Power is not stable    |
|                                                     | PRCM_SGX_POWER_ISO           | 14                                                                                                 | PM command for SGX domain isolation.                                                    | Isolation is ON     | Isolation is OFF       |
|                                                     | PRCM_DSS_SRAMRETG_OODOUT[0]  | 15                                                                                                 | Indicates whether the SRAM retention banks in the DSS domain are stable (bit 0).        | Power is stable     | Power is not stable    |
| This information is not available in public domain. |                              | 16                                                                                                 | This information is not available in public domain.                                     | Power is ON         | Power is OFF           |
|                                                     | PRCM_PER_POWER_ON            | 17                                                                                                 | PER switch command for power-on.                                                        | Power is ON         | Power is OFF           |
|                                                     | PRCM_Idoemuonz               | 18                                                                                                 | WAKE-UP LDO ON signal for EMU domain.                                                   | Power is ON         | Power is OFF           |
|                                                     | PRCM_USBPLL_RESTOR_EDONE     | 19                                                                                                 | Indicates that the Context Restore is done.                                             | Context restored    | Context restoration    |
|                                                     | PRCM_WKUP_L4_GICLK           | 20                                                                                                 | Interface clock of WKUPL4 domain.                                                       | –                   | –                      |
|                                                     | Reserved                     | (31:21)                                                                                            | –                                                                                       | –                   | –                      |

<sup>(1)</sup> Mode 5 in MUXMODE1 field CONTROL.CONTROL\_PADCONF\_DSS\_DATA8[18:16]

### **13.4.11 EMI Reduction for Clocking Generation (Spreading)**

#### **13.4.11.1 Overview**

There are two major forms of digital signals: digital-data and digital-clock (CLK). Digital signals are the principal signal form in today's digital electronic products.

- A digital-data signal can be viewed as a sequence of pulses with different pulse widths
- A clock (CLK) signal is usually a string of rectangular pulses with the same pulse width

In the case of a clock, the generated signal has a predetermined frequency. Electromagnetic radiations such as radio frequency emissions are also generated from the constant frequency clock signals and their harmonics. Unfortunately, a problem exists with some devices such as communication devices for example in that the system clock generates unwanted spurious signals that interfere with the decoding of information from received signals by a receiver of the communication device. Note that data periodicity also causes interference.

This periodicity generates a significant power peak at the selected frequency, which in turn causes an EMI disturbance to the environment.

The harmonics of the generated signal system clock radiates in the other modules of the device, and the spurious energy can be enough to cause enough interference, which results in performance degradation (in the form of high bit error rates in case of a wireless communication interface for example).

To reduce the power peaks (and thus the energy of the electromagnetic noise generated for a specific frequency), an internal frequency modulation of the digital phase-locked loop (DPLL) is used to distribute the energy to many different frequencies, thus reducing the power peaks.

This frequency modulation feature is directly integrated in some DPLLs of the device. The DPLLs that support this additional feature are called DPLL-D in the following.

Figure 13-18 is a diagram of a DPLL that supports the EMI reduction feature.

**Figure 13-18. DPLL With EMI Reduction Feature**


scm-033

The additional features of the DPLL compliant with EMI reduction are:

- EMI reduction using triangular frequency modulation, also called spread spectrum clocking (SSC).

### 13.4.11.2 Integration

The DPLLs/domains of the devices that support the EMI reduction feature are:

- DSS DPLL (DSI DPLL)
- CORE domain DPLL (DPLL3)
- PER domain DPLL (DPLL4)
- USBHOST DPLL (DPLL5)

[Figure 13-19](#) shows the integration of DPLL-D in the device.

**Figure 13-19. DPLL-D Integration**



The control of the DPLL is done by the PRCM module and the SCM:

- The PRCM module controls the clocking generation of the DPLL. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).
- The SCM contains all necessary bits that control the EMI reduction feature (SSC).

### **13.4.11.2.1 Clocking, Reset, and Power-Management Scheme**

See [Chapter 3, Power, Reset, and Clock Management](#).

### **13.4.11.3 Functional Description**

#### **13.4.11.3.1 Spreading Generation Block**

[Figure 13-20](#) is a diagram of the spreading generation block. It shows three essential parameters associated with spreading generation:

---

**NOTE:**  $\Delta f$  is the deviation from the center frequency. The total spreading deviation is equal to twice  $\Delta f$ .

$f_c$  is the original clock frequency.

$f_m$  is the spreading frequency.

---

**Figure 13-20. Spreading Generation Block Diagram**



scm-035

This additional block generates the required waveform used to reduce EMI. This waveform is then modulated with the initial signal to add some controlled deviation in the clock signal frequency, which spreads the energy of the clock and its harmonics into a band of frequencies, and then reduces the electromagnetic interferences.

In any case, the frequency modulation is programmed in the SCM and does not generally need to be changed in real time.

### 13.4.11.3.2 SSC

#### 13.4.11.3.2.1 Definition

The aim of SSC is to add a variation in the frequency of an original clock, which spreads the generated interferences over a larger band of frequency.

In theory, SSC means that the clock signal is varied around the desired frequency. For example, for a 1-GHz clock, the frequency may be 999.5 MHz at one moment and 1.0005 GHz at another. When SSC is enabled the clock spectrum is spread by the amount of frequency spread. Doing this constantly causes the power of the tone to be spread out more over a broader band of tight frequencies (centered at the desired tone). To realize this constant variation on the original signal, a modulation with an additional signal (called spreading waveform) is realized.

Creating an SSC by spreading the initial clock frequency is done by defining the following parameters:

- The spreading frequency (deviation), which is the ratio of the range of spreading frequency over the original clock frequency
- The modulation rate ( $f_m$ ), which is used to determine the clock-frequency spreading-cycling rate and is the time during which the generated clock frequency varies through  $\Delta f$  and returns to the original frequency
- The modulation waveform, which describes the variation curve in terms of time

The spectral power reduction in the DPLL clocks is dependent on the modulation index (K), which is a ratio of spreading frequency calculated from the frequency deviation ( $\Delta f$ ) and the modulation rate ( $f_m$ ).

#### 13.4.11.3.2.2 Effect on the Clock Signal

[Figure 13-21](#) is an example of the effect of a triangular spreading on a clock signal.

**Figure 13-21. Effect of the SSC in Frequency**



[Figure 13-21](#) shows not only the power reduction of the main peak, but also the flatter aspect of the modulated signal. The minimum level of the second signal is higher than the minimum level of the first signal. This effect is normal and is due to the noise added for the modulation.

---

**NOTE:** The spreading technique scatters the energy of the peaks on the other frequencies, which reduces the power of the peaks but increases the global noise of the signal.

[Figure 13-22](#) shows the effect of triangular spreading on a clock signal in the time domain.

**Figure 13-22. Effect of the SSC in the Time Domain**

scm-039

#### 13.4.11.3.2.3 Estimation of the EMI Reduction Level

Figure 13-23 shows the effect of spreading on a clock and its harmonics.

**Figure 13-23. Peak Reduction Caused by Spreading**

scm-037

The electromagnetic interference reduction can be estimated with the following equation:

$$\text{Peak\_power\_reduction} = 10 * \log ((\text{Deviation} * f_c) / f_m)$$

With:

- Peak\_power\_reduction in dB
- Deviation in % of the initial clock frequency ( $f_c$ ), equals  $\Delta f / f_c$
- $f_c$  is the original clock frequency, in MHz
- $f_m$  is the spreading frequency, in MHz

According to equation (1), it is also possible to compute the deviation, and then  $\Delta f$ , for a required peak power reduction:

$$\text{Deviation} = (f_m / f_c) * 10^{(\text{Peak\_power\_reduction} / 10)}$$

Example:

For  $f_c=400$  MHz, deviation =1% peak from  $f_c$ ( $\Delta f = 4$ MHz) and  $f_m=400$ kHz; the estimated peak power reduction is 10dB.

#### 13.4.11.3.2.4 Bandwidth Calculation (Carson Bandwidth Rule)

The Carson bandwidth rule defines the approximate bandwidth requirements of communications system components for a carrier signal that is frequency-modulated by a continuous or broad spectrum of frequencies rather than a single frequency.

The Carson bandwidth rule is expressed by the relation  $CBR = 2 * (\Delta f + f_m)$ , where CBR is the bandwidth requirement,  $\Delta f$  is the peak frequency deviation, and  $f_m$  is the highest frequency in the modulating signal.

For example, an FM signal with a 5-kHz peak deviation and a maximum audio frequency of 3 kHz, would require an approximate bandwidth  $2*(5.3) = 16$  kHz.

Theoretically, any FM signal has an infinite number of sidebands and hence an infinite bandwidth, but in practice all significant sideband energy (98% or more) is concentrated within the bandwidth defined by the Carson bandwidth rule.

#### 13.4.11.3.3 SSC Generation Control In The Device

SSC is performed by changing the feedback divider (M) in a triangular pattern. Implying, the frequency of the output clock would vary in a triangular pattern. The frequency of this pattern would be modulation frequency ( $f_m$ ). The peak ( $\Delta M$ ) or the amplitude of the triangular pattern as a percent of M would be equal to the percent of the output frequency spread ( $\Delta f$ ); that is,  $\Delta M / M = \Delta f / f_c$ .

Next, mark with  $F_{inp}$  the frequency of the clock signal at the input of the DPLL. Because it is divided to  $N + 1$  before entering the phase detector, the internal reference frequency is  $F_{ref} = F_{inp} / (N + 1)$ .

Assume the central frequency  $f_c$  to be equal to the DPLL output frequency  $F_{out}$ , or  $f_c = F_{out} = (F_{inp} / (N + 1)) * (M / M_2)$ .

The positions of the dividers N, M and M2 in the above formula can be also explained from the [Figure 13-18](#).

Because this is in band modulation for the DPLL, the modulation frequency is required to be within the loop bandwidth (lowest BW of  $F_{ref} / 70$ ) of the DPLL. A higher modulation frequency results in lesser spreading in the output clock. SSC can be enabled by asserting the bit and can be disabled using the same bit. For a certain ADPLL generating clock within domain – X , the spread spectrum generation is enabled from SCM by setting the CONTROL.CONTROL\_X\_DPLL\_SPREADING[4] R\_X\_SPREADING\_ENABLE bit. When this bit is deasserted, SSC is disabled only after completion of one full cycle of the triangular pattern given by the modulation frequency. This is done to maintain the average frequency.

Modulation frequency ( $f_m$ ) can be programmed as a ratio of  $F_{ref} / 4$ ; that is, the value that needs to be programmed  $\text{ModFreqDivider} = F_{ref} / (4^*f_m)$ . The ModFreqDivider is split into Mantissa and 2^Exponent ( $\text{ModFreqDivider} = \text{ModFreqDividerMantissa} * 2^{\text{ModFreqDividerExponent}}$ ). The mantissa is controlled by 7-bit signal  $\text{ModFreqDividerMantissa}$  through the CONTROL.CONTROL\_X\_DPLL\_SPREADING\_FREQ[6:0] R\_X\_MOD\_FREQ\_MANT bit field. The exponent is controlled by 3-bit signal  $\text{ModFreqDividerExponent}$  through the CONTROL.CONTROL\_X\_DPLL\_SPREADING\_FREQ[9:7] R\_X\_MOD\_FREQ\_EXP bit field.

---

**NOTE:** Although the same value of ModFreqDivider can be obtained by different combinations of mantissa and exponent values, it is recommended to get the target ModFreqDivider by programming the maximum mantissa and a minimum exponent.

---

To define the Frequency spread ( $\Delta f$ ),  $\Delta M$  must be controlled as explained previously. To define  $\Delta M$ , the step size of M for each Fref during the triangular pattern must be programmed; that is,  $\Delta M = \text{ModFreqDivider} * \text{DeltaMStep}$ . DeltaMStep is split into integer part and fractional part. Integer part is controlled by 2-bit signal DeltaMStepInteger through the CONTROL.CONTROL\_X\_DPLL\_SPREADING\_FREQ[29:28] R\_DSS\_DELTA\_M\_INT bit field. Fractional part is controlled by 18-bit signal DeltaMStepFraction through the CONTROL.CONTROL\_X\_DPLL\_SPREADING\_FREQ[27:10] R\_DSS\_DELTA\_M\_FRACT bit field.

The frequency spread achieved has an overshoot of 20 percent or an inaccuracy of +20 percent.

If the Q\_X\_SPREADING\_SIDE bit CONTROL.CONTROL\_X\_DPLL\_SPREADING[8] is set to 1, the frequency spread on lower side is twice the programmed value. The frequency spread on higher side is 0 (except for the overshoot as described previously).

As in the fractionalIM case, there is restriction of range of M values here. The restriction is  $M - \Delta M \geq 20$ . Also,  $M + \Delta M \leq 2045$ . In case the downspread feature is enabled,  $M - 2 * \Delta M \geq 20$  and  $M \leq 2045$ .

## 13.4.11.4 Basic Programming Model

### 13.4.11.4.1 SSC Configuration

The configuration of the spreading feature is not mandatory when programming the DPLL. This feature is usually enabled when the DPLL clocks generate harmonics that can potentially interfere with the GSM carrier frequencies.

Let's take the SSC featured ADPLL in the CORE domain and try to set the output frequency to  $F_{out} = f_c = 160$  MHz. The frequency of the input clock source for CORE ADPLL is  $F_{inp} = 38.4$  MHz.

1. The desired output frequency can be achieved with the following ratio of the divider coefficients:  $(M / M2)^{*}1/(N+1) = F_{out} / F_{inp} = 160 / 38.4 = 25 / 6$ . The dividers used in the CORE ADPLL can be set within the following ranges:  $N = 0..127$ ;  $M = 0..2047$ ;  $M2 = 1;2$ . The desired output frequency is achieved through the following choice of possible divider values:  $M = 25$ ;  $N = 2$  and  $M2 = 2$ . In that case the reference clock  $F_{ref} = F_{inp} / (N+1) = 38.4 / 3 = 12.8$  MHz.

The feedback divider value  $M = 25$  is chosen to satisfy the restriction from [Section 13.4.11.3.3](#). If, for example, the deviation  $\Delta M / M = \Delta f / F_c = 0.01$  (1%) is chosen, we have  $M < 2045 / 1.01$  and at the same time  $M > 20 / 0.99 = 20.2$ .

Once the clock generation control registers are configured, it is possible to configure the spreading on the clock signal.

2. Calculate the ratio between central(output) frequency and modulation frequency on the base of the desired peak power reduction, PPR and chosen relative deviation  $\Delta f / F_{out}$ , where  $\Delta f / F_{out} = f_m / f_c * 10^8$  (PPR/10). To achieve  $PPR = 10$ dB with SSC deviation chosen to be equal to 1 percent, the ratio  $f_m / f_c = 0.001$  is needed; hence,  $f_m = 0.001 * f_c = 0.001 * 160$  MHz = 160 KHz. To check whether the modulation frequency has the appropriate value, check whether it is within the DPLL loop bandwidth or if  $f_m < F_{ref} / 70 = 12.8 / 70 = 182.86$  KHz, which is true.
3. Calculate the contents of the CONTROL.CONTROL\_X\_DPLL\_SPREADING\_FREQ[6:0] R\_X\_MOD\_FREQ\_MANT and CONTROL.CONTROL\_X\_DPLL\_SPREADING\_FREQ[9:7] R\_X\_MOD\_FREQ\_EXP bit fields on the base of ModFreqDivider value:  $ModFreqDivider = F_{ref} / (4*f_m) = 12.8 / 4 * 0.16 = 20 = 20 * 2^{10}$ . This means we should write R\_X\_MOD\_FREQ\_EXP=0x0 and R\_X\_MOD\_FREQ\_INT=0x14.
4. The DeltaMStep parameter is calculated according to the formula:  

$$\text{DeltaM} = \Delta M / \text{ModFreqDivider}$$
  
 On the other side  $\Delta M = M * (\Delta f / f_c)$ , hence, parameter  $\text{DeltaM} = M * (\Delta f / f_c) / \text{ModFreqDivider} = 0.01 * 25 / 20 = 0.0125$ .  
 In this case write 0x0 in CONTROL.CONTROL\_X\_DPLL\_SPREADING\_FREQ[29:28] R\_DSS\_DELTA\_M\_INT bit field. To express the fractional part 0.0125 as a binary, calculate:  $0.0125 * 2^{18} = 3276.8$ , then round to 3277, convert the integer part to binary and write it into the field:  

$$\text{CONTROL.CONTROL_X_DPLL_SPREADING_FREQ[27:10]} \text{ R_DSS_DELTA_M_FRACT} = 0b000000110011001101$$
5. The spreading must be enabled using the CONTROL.CONTROL\_X\_DPLL\_SPREADING[4] R\_X\_SPREADING\_ENABLE bit.

---

**NOTE:** It is necessary to configure the spreading on a clock carefully to avoid adding noise on frequencies that are used by another module. For example, adding spreading on a clock to reduce noise on GSM frequencies can "move" the generated noise to the frequency of the memory controller and degrade its performance.

---

The state of the modulation feature can be monitored with the R\_X\_SPREADING\_ENABLE\_STATUS bit of the corresponding register.

## 13.5 SCM Programming Model

### 13.5.1 Feature Settings

**NOTE:** The settings listed in the following sections are example patterns for configuring the signal group I/O parameters of I<sup>2</sup>C, SDRC, GPMC, McBSP2, and McSPI1:

- [Section 13.5.1.10, I<sup>2</sup>C I/O Internal Pullup Enable](#)
- [Section 13.5.1.11, SDRC I/O Drive Strength Selection](#)
- [Section 13.5.1.12, GPMC I/O Far End Load Settings](#)
- [Section 13.5.1.13, McBSP2 I/O Far End Load Settings](#) and
- [Section 13.5.1.14, McSPI1 I/O Far End Load Settings](#)

For more information about the settings for all interface signal groups, see [Section 13.4.7.6, Signal Integrity Parameter Control Registers With Pad Group Assignment](#).

#### 13.5.1.1 Force Pad Configuration MuxMode by High-Speed USB

The two pads hsusb0\_data0 and hsusb0\_data1 can force pad configuration MuxMode when the CARKITEN signal is generated:

- CONTROL.[CONTROL\\_DEVCONF1\[19\]](#) CARKITHSUSB0DATA0AUTOEN bit:
  - 0: The hsusb0\_data0 MuxMode signal is driven by the CONTROL.CONTROL\_PADCONF\_HSUSBO\_NXT[18:16] MUXMODE1 bit.
  - 1: The hsusb0\_data0 MuxMode signal is forced to 0x2 when the CARKITEN signal is active.
- CONTROL.[CONTROL\\_DEVCONF1\[20\]](#) CARKITHSUSB0DATA1AUTOEN bit:
  - 0: The hsusb0\_data1 MuxMode signal is driven by the CONTROL.CONTROL\_PADCONF\_HSUSBO\_DATA1[2:0] MUXMODE0 bit.
  - 1: The hsusb0\_data1 MuxMode signal is forced to 0x2 when the CARKITEN signal is active.

**NOTE:** Associated pad configuration registers remain unchanged.

For more information about high-speed USB, see [Chapter 22, High-Speed USB Controllers](#).

#### 13.5.1.2 Video Driver

This section gives information about all modules and features in the high-tier device. To check the availability of modules and features, see [Section 1.5, AM/DM37x Family](#). Unavailable module and feature pins are not functional.

- CONTROL.[CONTROL\\_DEVCONF1\[18\]](#) TVOUTBYPASS bit:
  - 0b0: Dual 10-bit video DAC TV out bypass disable
  - 0b1: Dual 10-bit video DAC TV out bypass enable
- CONTROL.[CONTROL\\_DEVCONF1\[11\]](#) TVACEN bit:
  - 0b0: Enables dc coupling for TV output
  - 0b1: Enables ac coupling for TV output

For more information about video DACs, see [Chapter 7, Display Subsystem](#).

#### 13.5.1.3 McBSP1 Internal Clock

The McBSP1 internal clock gates the internal interconnect clock and selects the FSR, CLKR, and CLKS input for the McBSP1.

- CONTROL.[CONTROL\\_DEVCONF0\[4\]](#) MCBSP1\_FSR bit:
  - 0: FSR is from the pin mcbsp1\_fsr.
  - 1: FSR is from the pin mcbsp1\_fsx.

- CONTROL.[CONTROL\\_DEVCONF0\[3\]](#) MCBSP1\_CLKR bit:  
 0: CLKR is from the pin mcbsp1\_clk.  
 1: CLKR is from the pin mcbsp1\_clkx.
- CONTROL.[CONTROL\\_DEVCONF0\[2\]](#) MCBSP1\_CLKS bit:  
 0: CLKS is from the PRCM functional clock.  
 1: CLKS is from the pin mcbsp\_clks.

For more details on McBSP, see [Chapter 21, McBSP](#).

#### 13.5.1.4 McBSP2 Internal Clock

The McBSP2 internal clock gates the internal interconnect clock and selects the FSR, CLKR, and CLKS input for the McBSP2. The McBSP2 does not have mcbsp2\_clk and mcbsp2\_fsr external pins. Clock input is from the mcbsp2\_clkx pin; FSR input is from the mcbsp2\_fsx pin.

- CONTROL.[CONTROL\\_DEVCONF0\[6\]](#) MCBSP2\_CLKS bit:  
 0: Clock is from the PRCM functional clock.  
 1: Clock is from the external pin mcbsp\_clks.

For more information about McBSP, see [Chapter 21, McBSP](#).

#### 13.5.1.5 McBSP3 Internal Clock

The McBSP3 internal clock gates the internal interconnect clock and selects the FSR, CLKR, and CLKS input for the McBSP3. The McBSP3 does not have mcbsp3\_clk and mcbsp3\_fsr external pins. Clock input is from the mcbsp3\_clkx pin; FSR input is from the mcbsp3\_fsx pin.

- CONTROL.[CONTROL\\_DEVCONF1\[0\]](#) MCBSP3\_CLKS bit:  
 0: Clock is from the PRCM functional clock.  
 1: Clock is from the external pin mcbsp\_clks.

For more information about McBSP, see [Chapter 21, McBSP](#).

#### 13.5.1.6 McBSP4 Internal Clock

The McBSP4 internal clock gates the internal interconnect clock and selects the FSR, CLKR, and CLKS input for the McBSP4. The McBSP4 does not have mcbsp4\_clk and mcbsp4\_fsr external pins. Clock input is from the mcbsp4\_clkx pin; FSR input is from the mcbsp4\_fsx pin.

- CONTROL.[CONTROL\\_DEVCONF1\[2\]](#) MCBSP4\_CLKS bit:  
 0: Clock is from the PRCM functional clock.  
 1: Clock is from the external pin mcbsp\_clks.

For more information about McBSP, see [Chapter 21, McBSP](#).

#### 13.5.1.7 McBSP5 Internal Clock

The McBSP5 internal clock gates the internal interconnect clock and selects the FSR, CLKR, and CLKS input for the McBSP5. The McBSP5 does not have mcbsp5\_clk and mcbsp5\_fsr external pins. Clock input is from the mcbsp5\_clkx pin; FSR input is from the mcbsp5\_fsx pin.

- CONTROL.[CONTROL\\_DEVCONF1\[4\]](#) MCBSP5\_CLKS bit:  
 0: Clock is from the PRCM functional clock.  
 1: Clock is from the external pin mcbsp\_clks.

For more information about McBSP, see [Chapter 21, McBSP](#).

#### 13.5.1.8 MMC/SD/SDIO2 Module Input Clock Selection

- CONTROL.[CONTROL\\_DEVCONF1\[6\]](#) MMCSdio2ADPCLKISEL bit:  
 0: Input clock is from the external pin.

1: Internal loopback, module input clock is copied from the module output clock.

### 13.5.1.9 Setting Sensitivity on sys\_ndmreq[3:0] Input Pins

The four sys\_ndmreq0 to sys\_ndmreq3 input pins can be either level or edge sensitive.

- CONTROL.[CONTROL\\_DEVCONF0\[0\]](#) SENSDMREQ0 bit:
  - 0: Level sensitivity
  - 1: Edge sensitivity
- CONTROL.[CONTROL\\_DEVCONF0\[1\]](#) SENSDMREQ1 bit:
  - 0: Level sensitivity
  - 1: Edge sensitivity
- CONTROL.[CONTROL\\_DEVCONF1\[7\]](#) SENSDMREQ2 bit:
  - 0: Level sensitivity
  - 1: Edge sensitivity
- CONTROL.[CONTROL\\_DEVCONF1\[8\]](#) SENSDMREQ3 bit.
  - 0: Level sensitivity
  - 1: Edge sensitivity

For more information about DMA, see [Chapter 11, DMA](#).

### 13.5.1.10 I<sup>2</sup>C I/O Internal Pullup Enable

The I/O internal pullups of I2C1, I2C2, I2C3, and I2C4 can be enabled:

- CONTROL.[CONTROL\\_PROG\\_IO1\[19\]](#) PRG\_I2C1\_PULLUPRESX bit:
  - 0: I2C1 I/O internal pullup enabled
  - 1: I2C1 I/O internal pullup disabled
- CONTROL.[CONTROL\\_PROG\\_IO1\[0\]](#) PRG\_I2C2\_PULLUPRESX bit:
  - 0: I2C2 I/O internal pullup enabled
  - 1: I2C2 I/O internal pullup disabled
- CONTROL.[CONTROL\\_PROG\\_IO2\[7\]](#) PRG\_I2C3\_PULLUPRESX bit:
  - 0: I2C3 I/O internal pullup enabled
  - 1: I2C3 I/O internal pullup disabled
- CONTROL.[CONTROL\\_PROG\\_IO\\_WKUP1\[5\]](#) PRG\_SR\_PULLUPRESX bit:
  - 0: I2C4 I/O internal pullup enabled
  - 1: I2C4 I/O internal pullup disabled

---

**NOTE:** This feature is used for the I<sup>2</sup>C master operating mode.

---

For more information about I<sup>2</sup>C, see [Chapter 17, Multimaster Highspeed I<sup>2</sup>C Controller](#).

### 13.5.1.11 SDRC I/O Drive Strength Selection

- The CONTROL.[CONTROL\\_PROG\\_IO0\[31\]](#) SDRC\_LOWDATA bit selects data[15:0] DQS0, DQS1, DM0, and DM1 I/O drive strength:
  - 0: Load range = [2 pF – 4 pF]
  - 1: Load range = [4 pF – 12 pF]
- The CONTROL.[CONTROL\\_PROG\\_IO0\[30\]](#) SDRC\_HIGHDATA bit selects data[31:16] DQS2, DQS3, DM2, and DM3 I/O drive strength:
  - 0: Load range = [2 pF – 4 pF]
  - 1: Load range = [4 pF – 12 pF]

- The CONTROL.[CONTROL\\_PROG\\_IO0\[29\]](#) SDRC\_ADDRCTR bit selects the I/O drive strength of the NRAS, NCAS, NWE, NCLK, CLK, BA0, and BA1 signals:
  - 0: Load range = [2 pF – 4 pF]
  - 1: Load range = [4 pF – 12 pF]
- The CONTROL.[CONTROL\\_PROG\\_IO0\[28\]](#) SDRC\_NCS0 bit selects the NCS0 and CKE0 I/O drive strength:
  - 0: Load range = [2 pF – 4 pF]
  - 1: Load range = [4 pF – 12 pF]
- The CONTROL.[CONTROL\\_PROG\\_IO0\[27\]](#) SDRC\_NCS1 bit selects the NCS1 and CKE1 I/O drive strength:
  - 0: Load range = [2 pF – 4 pF]
  - 1: Load range = [4 pF – 12 pF]

### 13.5.1.12 GPMC I/O Far End Load Settings

- The CONTROL.[CONTROL\\_PROG\\_IO0\[26\]](#) PRG\_GPMC\_A1\_LB bit selects GPMC\_A1 I/O equivalent far end load within:
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.[CONTROL\\_PROG\\_IO0\[25\]](#) PRG\_GPMC\_A2\_LB bit selects GPMC\_A2 I/O equivalent far end load within:
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.[CONTROL\\_PROG\\_IO0\[24\]](#) PRG\_GPMC\_A3\_LB bit selects GPMC\_A3 I/O equivalent far end load within:
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.[CONTROL\\_PROG\\_IO0\[23\]](#) PRG\_GPMC\_A4\_LB bit selects GPMC\_A4 I/O equivalent far end load within:
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.[CONTROL\\_PROG\\_IO0\[22\]](#) PRG\_GPMC\_A5\_LB bit selects GPMC\_A5 I/O equivalent far end load within:
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.[CONTROL\\_PROG\\_IO0\[21\]](#) PRG\_GPMC\_A6\_LB bit selects GPMC\_A6 I/O equivalent far end load within:
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.[CONTROL\\_PROG\\_IO0\[20\]](#) PRG\_GPMC\_A7\_LB bit selects GPMC\_A7 I/O equivalent far end load within:
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.[CONTROL\\_PROG\\_IO0\[19\]](#) PRG\_GPMC\_A8\_LB bit selects GPMC\_A8 I/O equivalent far end load within:
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.[CONTROL\\_PROG\\_IO0\[18\]](#) PRG\_GPMC\_A9\_LB bit selects GPMC\_A9 I/O equivalent far end load within:
  - 0: Load range = [1 pF – 10 pF]

- 1: Load range = [10 pF – 16 pF]
- The CONTROL.**CONTROL\_PROG\_IO0[17]** PRG\_GPMC\_A10\_LB bit selects GPMC\_A10 I/O equivalent far end load within::
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.**CONTROL\_PROG\_IO0[16]** PRG\_GPMC\_A11\_LB bit selects GPMC\_A11 I/O equivalent far end load within::
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.**CONTROL\_PROG\_IO0[15]** PRG\_GPMC\_MIN\_CFG\_LB bit selects data[7:0], WAIT0, NADV\_ALE , NOE, NWE I/O equivalent far end load within::
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.**CONTROL\_PROG\_IO0[14]** PRG\_GPMC\_D8\_D15\_LB bit selects data[15:8] I/O equivalent far end load within::
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.**CONTROL\_PROG\_IO0[13]** PRG\_GPMC\_NCS0\_LB bit selects GPMC\_NCS0 I/O equivalent far end load within::
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.**CONTROL\_PROG\_IO0[12]** PRG\_GPMC\_NCS1\_LB bit selects GPMC\_NCS1 I/O equivalent far end load within::
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.**CONTROL\_PROG\_IO0[11]** PRG\_GPMC\_NCS2\_LB bit selects GPMC\_NCS2 I/O equivalent far end load within::
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.**CONTROL\_PROG\_IO0[10]** PRG\_GPMC\_NCS3\_LB bit selects GPMC\_NCS3 I/O equivalent far end load within::
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.**CONTROL\_PROG\_IO0[9]** PRG\_GPMC\_NCS4\_LB bit selects GPMC\_NCS4 I/O equivalent far end load within::
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.**CONTROL\_PROG\_IO0[8]** PRG\_GPMC\_NCS5\_LB bit selects GPMC\_NCS5 I/O equivalent far end load within::
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.**CONTROL\_PROG\_IO0[7]** PRG\_GPMC\_NCS6\_LB bit selects GPMC\_NCS6 I/O equivalent far end load within::
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL.**CONTROL\_PROG\_IO0[6]** PRG\_GPMC\_NCS7\_LB bit selects GPMC\_NCS7 I/O equivalent far end load within::
  - 0: Load range = [1 pF – 10 pF]

- 1: Load range = [10 pF – 16 pF]
- The CONTROL\_CONTROL\_PROG\_IO0[5] PRG\_GPMC\_CLK\_LB bit selects GPMC\_CLK I/O equivalent far end load within:-
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL\_CONTROL\_PROG\_IO0[4] PRG\_GPMC\_NBE0\_CLE\_LB bit selects GPMC\_NBE0\_CLE I/O equivalent far end load within:-
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL\_CONTROL\_PROG\_IO0[3] PRG\_GPMC\_NBE1\_LB bit selects GPMC\_NBE1 I/O equivalent far end load within:-
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL\_CONTROL\_PROG\_IO0[2] PRG\_GPMC\_NWP\_LB bit selects GPMC\_NWP I/O equivalent far end load within:-
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL\_CONTROL\_PROG\_IO1[31] PRG\_GPMC\_WAIT1\_LB bit selects GPMC\_WAIT1 I/O equivalent far end load within:-
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL\_CONTROL\_PROG\_IO1[30] PRG\_GPMC\_WAIT2\_LB bit selects GPMC\_WAIT2 I/O equivalent far end load within:-
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL\_CONTROL\_PROG\_IO1[29] PRG\_GPMC\_WAIT3\_LB bit selects GPMC\_WAIT3 I/O equivalent far end load within:-
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]

### 13.5.1.13 MCBSP2 I/O Far End Load Settings

- The CONTROL\_CONTROL\_PROG\_IO2[31] PRG\_MCBSP2\_LB bit selects the FSX, CLKX, DR, and DX I/O equivalent far end load within:-
  - 0: Load range = [1 pF–10 pF]
  - 1: Load range = [10 pF–16 pF]

### 13.5.1.14 MCSPI1 I/O Far End Load Settings

- The CONTROL\_CONTROL\_PROG\_IO2[1] PRG\_MCSPI1\_MIN\_CFG\_LB bit selects CLK, SOMI, SIMO and CS0 I/O equivalent far end load within:-
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL\_CONTROL\_PROG\_IO2[0] PRG\_MCSPI1\_CS1\_LB bit selects CS1 I/O equivalent far end load within:-
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]
- The CONTROL\_CONTROL\_PROG\_IO1[4] PRG\_MCSPI1\_CS2\_LB bit selects CS2 I/O equivalent far end load within:-
  - 0: Load range = [1 pF – 10 pF]
  - 1: Load range = [10 pF – 16 pF]

- The CONTROL.[CONTROL\\_PROG\\_IO1](#)[3] PRG\_MCSPI1\_CS3\_LB bit selects CS3 I/O equivalent far end load within:
  - 0: Load range = [1 pF–10 pF]
  - 1: Load range = [10 pF–16 pF]

### 13.5.1.15 Force MPU Writes to Be Nonposted

The MPUFORCEWRNP bit CONTROL.[CONTROL\\_DEVCONF1](#)[9] bit is for debugging only. When this bit is set to 1 (for debugging), all writes are forced to nonposted and the cache attributes are ignored. By default, this bit should be set to 0 (posted writes). For the best performance, keep this bit at 0.

## 13.5.2 Extended-Drain I/Os and PBIAS Cells Programming Guide

---

**NOTE:** The device can be supplied by an external power IC. TI provides such a global solution to its customers with the power IC.

---

If the device is associated with the power IC, before using an extended-drain I/O interface, the software must program the power IC to enable the VMMC1 (for the MMC/SD/SDIO1 module or muxed GPIO I/Os) or VIO for (gpio126, gpio127, and gpio129 I/Os), and the LDO and to provide a 1.8-V/3.0-V voltage. This is done by software through the inter-integrated circuit (I<sup>2</sup>C™) interface that links the device and power IC.

If the application does not want the interface running at 3.0 V, software users must then assert the VMODE signal to low for 1.8-V activity: in this case, the PBIAS is connected to ground. (See [Figure 13-24](#).)

[Table 13-66](#) lists the control signal with the corresponding control bits from the CONTROL.[CONTROL\\_PBIAS\\_LITE](#), CONTROL.[CONTROL\\_PROG\\_IO1](#) and CONTROL.[CONTROL\\_WKUP\\_CTRL](#) registers to configure the PBIAS and the extended-drain I/O cells. These signals can be software-controlled.

**Table 13-66. Control Signals**

| Control Signal | Bit for MMC/SD/SDIO1 Module Using PBIAS0 Cell                               | Bit for GPIO I/Os Using PBIAS1 Cell                                      | Reset Value |
|----------------|-----------------------------------------------------------------------------|--------------------------------------------------------------------------|-------------|
| PWRDNZ         | CONTROL. <a href="#">CONTROL_PBIAS_LITE</a> [1]<br>PBIASLITEPWRDNZ0         | CONTROL. <a href="#">CONTROL_PBIAS_LITE</a> [9]PBIASLIT<br>EPWRDNZ1;     | 0           |
|                |                                                                             | CONTROL. <a href="#">CONTROL_WKUP_CTRL</a> [6]GPIO_IO<br>_PWRDNZ         |             |
| VMODE          | CONTROL. <a href="#">CONTROL_PBIAS_LITE</a> [0]<br>PBIASLITEVMODE0          | CONTROL. <a href="#">CONTROL_PBIAS_LITE</a> [8]<br>PBIASLITEVMODE1       | 1           |
| SUPPLY_HIGH    | CONTROL. <a href="#">CONTROL_PBIAS_LITE</a> [7]<br>PBIASLITESUPPLYHIGH0     | CONTROL. <a href="#">CONTROL_PBIAS_LITE</a> [15]<br>PBIASLITESUPPLYHIGH1 | 0           |
| SPEEDCTRL      | CONTROL. <a href="#">CONTROL_PROG_IO1</a> [20]<br>PRG_SDMMC1_SPEEDCTRL      | N/A                                                                      | 0           |
| VMODEERROR     | CONTROL. <a href="#">CONTROL_PBIAS_LITE</a> [3]<br>PBIASLITEVMODEERROR0 bit | CONTROL. <a href="#">CONTROL_PBIAS_LITE</a> [11]<br>PBIASLITEVMODEERROR1 | 0           |

The two PBIAS cells support two ranges of I/O power supply: 1.8 V, typical for low-voltage applications, and 3.0 V, typical for high-voltage applications. For each supply voltage range, the cell generates suitable bias voltage (PBIAS) for extended-drain PMOS devices.

---

**NOTE:** If SDMMC1\_VDDS (or SIM\_VDDS) is supplied before the device reset is released, the voltage must be 3 V. It is not recommended to supply the vdds\_mmc1 (or vdds\_sim) pad with 1.8 V unless software has configured the PBIAS cells accordingly.

---

**CAUTION**

A PBIAS cell must be programmed according to peripheral power supply voltage. See [Table 13-67](#).

**Table 13-67. Voltage Configuration<sup>(1)</sup>**

| PBIASLITEVMODE Configuration | SDMMC1_VDDS/SIM_VDDS Voltage | Reset Value                           |
|------------------------------|------------------------------|---------------------------------------|
| 1.8 V                        | 1.8 V                        | Normal 1.8-V operation                |
| 1.8 V                        | 3.0 V                        | Damaging configuration <sup>(2)</sup> |
| 3.0 V                        | 1.8 V                        | Degraded functionality <sup>(2)</sup> |
| 3.0 V                        | 3.0 V                        | Normal 3.0-V operation                |

<sup>(1)</sup> For damaging configuration, hardware system protection is provided to prevent deterioration of the associated extended-drain I/Os.

<sup>(2)</sup> It is forbidden to use these modes.

[Figure 13-24](#) describes the programming flow to go from 3.0 V to 1.8 V, and vice versa.

**Figure 13-24. Flow Chart**

scm-019

The PBIAS output is the same as SDMMC1\_VDDS/SIM\_VDDS when the corresponding PBIAS cell related PWRDNZ bit is LOW. Once the SDMMC1\_VDDS/SIM\_VDDS supply settles, software releases the PWRNDZ (pulls it HIGH). This then starts up the PBIAS cell work to generate the PBIAS voltage. During the complete process the corresponding I/Os cannot be used to transmit data.

**NOTE:** In the case of a damaging configuration, hardware system protection prevents deterioration of the associated extended-drain I/Os.

### CAUTION

The following are critical requirements for the cell:

- The VMODE bit must be defined before the PWRNDZ bit is made HIGH (cell is brought out of PWRNDZ).
- The default state of VMODE bit must be HIGH (to indicate 3.0-V operation).
- PWRNDZ bit must be kept LOW when the SDMMC1\_VDDS/SIM\_VDDS supply is ramping up (PWRNDZ bit is not required to be kept LOW during ramp down of the supply). This could be damaging.

### CAUTION

It is strongly recommended to synchronize any changes of the PBIASLITEPWRDNZ1 and GPIO\_IO\_PWRDNZ bits (that is, both bits must be set to 1 or 0 at the same time).

The following power-saving recommendations apply to the power-down mode control PWRDNZx (the PBIASLITEPWRDNZ0/PBIASLITEPWRDNZ1 and GPIO\_IO\_PWRDNZ bits) and the pad configuration settings for different SDMMC1/GPIO pad setups:

- When SDMMC1 (or GPIO) I/Os are used with SDMMC1 (or GPIO) functionality and vdds\_sdmmc1 (or vdds\_sim) = vdds = 1.8 V, the corresponding PWRDNZx bit(s) must be set to 1 when the vdds\_sdmmc1 (or vdds\_sim) power supply voltage is stabilized.
- When SDMMC1 (or GPIO) I/Os are not connected and vdds\_sdmmc1 (or vdds\_sim) = 0 V, the corresponding PWRDNZx bit(s) must be set to 0.
- When SDMMC1 (or GPIO) I/Os are not connected and vdds\_sdmmc1 (or vdds\_sim) = 1.8 V, one of the following settings can be done to reduce leakage:
  - The corresponding PWRDNZx bit(s) is kept at 0.
  - If the corresponding PWRDNZx bit(s) is 1, the INPUTENABLE bit must be maintained at 0 in the corresponding CONTROL\_PADCONF\_x register. In this case, the receiver buffer does not cause static current, even if the pad is left floating. Weak pullup/pulldown resistors can be used to define the pad state, if needed. The setting of the weak pull resistor does not affect the I/O leakage in this case.
  - If the corresponding PWRDNZx bit(s) must be kept at 1 and INPUTENABLE = 1, the level of the pad signal must be defined using weak pullup/pulldown resistors at the pad, in the event of a floating pad. If weak pull resistors are not defined and the pad is floating, the current, drawn from VDDS, can be high because of the static current in the receiver.

For more information about power-saving strategies related to pad configuration, see [Section 13.5.4, Pad Configuration Programming Points](#).

### 13.5.2.1 PBIAS Error Generation

**Table 13-68** summarizes the generation of the PBIAS error interrupt (PBIAS0\_ERROR and PBIAS1\_ERROR) depending on the various CONTROL.[CONTROL\\_PBIAS\\_LITE](#) bits control. The shaded row is a potential condition that could cause a reliability issue if not detected. To prevent this reliability issue, the PBIAS voltage is kept at SDMMC1\_VDDS/SIM\_VDDS level when the PBIAS error signal is HIGH.

**Table 13-68. PBIAS Error Signal Truth Table**

| VMODE | PWRDNZ | SUPPLY_HIGH | PBIAS ERROR |
|-------|--------|-------------|-------------|
| X     | X      | X           | 0           |
| 0     | 0      | X           | 0           |
| 0     | 1      | 0           | 0           |
| 0     | 1      | 1           | 1           |
| X     | 1      | X           | 1           |
| 1     | 0      | X           | 0           |
| 1     | 1      | 0           | 1           |
| 1     | 1      | 1           | 0           |

**NOTE:** PBIAS ERROR = 1: VMODE level not same as SUPPLY\_HIGH

PBIAS ERROR = 0: VMODE level same or VMODE not considered

The PBIAS errors, PBIAS0\_ERROR and PBIAS\_ERROR1, are merged and connected to the MPU subsystem interrupt controller.

The CONTROL.[CONTROL\\_PBIAS\\_LITE](#)[i] PBIASLITEVMODEERROR (where i = 3 or 11) bits also indicate if this kind of error occurs.

### 13.5.2.2 Critical Timing Requirements

It is crucial that the PBIAS and I/O cell related PWRDNZ bits are deasserted (made 1 from 0) only after SDMMC1\_VDDS/SIM\_VDDS is stable. The device supports only the power-up sequence in which VDD2 ramps up before VDDS. However, SDMMC1\_VDDS/SIM\_VDDS must come up after both VDD2 and VDDS.

**Figure 13-25** show the expected behavior of PWRDNZ bit with regard to supply ramp up. This figure also shows the only possible combination when VDDS ramps up before VDD2.

**Figure 13-25. VDDS Ramps Up Before VDD2**



**NOTE:** These timing requirements are applicable only when SDMMC1\_VDDS/SIM\_VDDS is 3.0 V. If SDMMC1\_VDDS/SIM\_VDDS is 1.8 V, VDDS and SDMMC1\_VDDS/SIM\_VDDS can be ramped up simultaneously.

### 13.5.2.3 Speed Control and Voltage Supply State

There are other control bits, PRG\_SDMMC1\_SPEEDCTRL in the CONTROL.[CONTROL\\_PROG\\_IO1](#) and SUPPLYHIGH in the CONTROL.[CONTROL\\_PBIAS\\_LITE](#) registers:

- PRG\_SDMMC1\_SPEEDCTRL bit can be used to reduce dynamic current if fast rise/fall times are not needed.
- SUPPLYHIGH bit signal is used to inform the cell on the value of SDMMC1\_VDDS/SIM\_VDDS signal (0b0 = 1.8 V and 0b1 = 3.0 V).

### 13.5.3 Off Mode Preliminary Settings

The following actions must be performed once, and remain valid for all device OFF <-> ON transitions:

- Program a valid device OFF pads configuration, by setting in each CONTROL. **CONTROL\_PADCONF\_X** register all off mode values bits: OFFPULLTYPESELECT (OFF mode pull type), OFFPULLUDENABLE (OFF mode pull enabling), OFFOUTVALUE (OFF mode output value), OFFOUTENABLE (OFF mode output enabling), and OFFENABLE (OFF mode pad state override control) .
- Program a valid device ACTIVE pads configuration by setting pertinent bits in each CONTROL. **CONTROL\_PADCONF\_X** register (see [Section 13.5.4, Pad Configuration Programming Points](#)).
- Perform a device ACTIVE pads configuration saving in the save and restore memory from the wake-up control module by asserting the STARTSAVE bit CONTROL.**CONTROL\_PADCONF\_OFF[1]**.
- Set the SCM in smart idle mode by setting the IDLEMODE bit field CONTROL.**CONTROL\_SYSCONFIG[4:3]** (this ensures that its clocks cannot be cut until the save procedure is complete).
- Enable/disable the wake-up event detection capability of the pads by setting the WAKEUPENABLE bit CONTROL. **CONTROL\_PADCONF\_X**.

---

**NOTE:** When the wake-up detection is enabled for a pad, this pad is configured as input. Therefore, do not forget to write 0b1 in the OFFOUTENABLE bit CONTROL. **CONTROL\_PADCONF\_X** to disable the output capability.

---

For further information, see [Chapter 3, Power, Reset, and Clock Management](#).

### 13.5.4 Pad Configuration Programming Points

To configure the pad, ensure that the following are done:

- Identify signals required on the interface based on the target application.  
Example: To configure the UART1 interface on balls, the required signals are uart1\_tx, uart1\_rts, uart1\_cts, and uart1\_rx.
- Choose the pads used for those signals. Some signals could be available on several pads and/or may be multiplexed with other signals needed for another application. See [Section 13.4.4.3, Pad Multiplexing Register Fields](#).

Example: Each UART1 interface signal is available on two pads. These signals are also multiplexed with a McBSP signal.

Assume that the McBSP interface is required in the system. Therefore, for the UART1 interface signals, pads must be used where those signals are not multiplexed with the McBSP signal.

- Identify the pad configuration registers associated with the pads to be used in the application. See [Section 13.4.4.3, Pad Multiplexing Register Fields](#).

Example: Under the previous hypothesis, the pad configuration registers to program are:

- uart1\_cts: CONTROL.CONTROL\_PADCONF\_DSS\_DATA0[15:0]
- uart1\_rts: CONTROL.CONTROL\_PADCONF\_DSS\_DATA0[31:16]
- uart1\_tx: CONTROL.CONTROL\_PADCONF\_DSS\_DATA6[15:0]
- uart1\_rx: CONTROL.CONTROL\_PADCONF\_DSS\_DATA6[31:16]

---

**NOTE:** In this configuration, dss\_datan (where n = 0) signals are not available on these balls.

---

- Configure the MUXMODE field of each pad configuration register (CONTROL).

[CONTROL\\_PADCONF\\_X](#)) associated with the pads used. [Section 13.4.4.3, Pad Multiplexing Register Fields](#), lists the entire mode available for each pin. Write the binary value of the mode used in the MUXMODE field of the pad configuration registers.

Example: UART1 signals are available in mode 2. Therefore, write 0b010 in the corresponding MUXMODE field of the pad configurations registers to be programmed.

- Configure the pull of the pad when used as input. When the pad is used as output, the pull is automatically disabled. [Section 13.4.4.3, Pad Multiplexing Register Fields](#), lists the pull available on each pad and its reset value. Set the appropriate value for the PULLTYPESELECT bit of the pad configuration register to set the pull value (0b0 = Pull Down selected, 0b1 = Pull Up selected) and set the PULLUDENABLE bit of the pad configuration register to enable the pull on the pad (0b0 = pull disabled, 0b1 = pull enabled)

Example: uart1\_rts and uart1\_tx are output signals; therefore, the pull is automatically disabled on the pad. Because uart1\_cts and uart1\_rx are input signals, configure the pull for these pads:

- uart1\_cts: Enable pullup (write 0b1 in the PULLTYPESELECT bit and 0b1 in the PULLUDENABLE bit of the corresponding pad configuration register)
- uart1\_rx: Enable pullup (write 0b1 in the PULLTYPESELECT bit and 0b1 in the PULLUDENABLE bit of the corresponding pad configuration register)
- Set the INPUTENABLE bit of the pad configuration register if the pin is used as input.

Example: uart1\_rts and uart1\_tx are output signals; therefore, clear the INPUTENABLE bit of the corresponding pad configuration register. Because uart1\_cts and uart1\_rx are input signals, set the INPUTENABLE bit of the corresponding pad configuration register.

---

**NOTE:** The order for setting the previous pad configuration bits is not important.

---

### 13.5.5 I/O Power Optimization Guidelines

To optimize I/O power, it is important to avoid unconnected or incorrectly pulled pins. According to the type of pins, the way to reduce power consumption can differ. [Table 13-69](#) shows the three available pin (or ball) types.

**Table 13-69. Pin Types**

| Input                                                                                        | Output                                                                                       | Bidirectional                                                                                  |
|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| <br>scm-026 | <br>scm-027 | <br>scm-028 |

The configuration differs according to the I/O cell types. The following describes some pieces of advice which can be useful to avoid extra current leakage:

- For input pins, use a pullup/down when possible.
  - For output pins, check existing pulls to avoid conflicts.
  - For bidirectional pins, reconfigure the pin as an output driving 0 when possible.
- Some I/O configurations involve modifications during the software setup of I/Os and sometimes require several hardware updates.

[Figure 13-26](#) shows how to optimize the power consumption of pads.

**Figure 13-26. I/O Power Optimization Flow Chart**

scm-029

The following notes give additional explanation about the pin configuration.

1. To avoid unconnected pins, the configuration depends on its use:
  - If the pin is not driven externally, a pullup/down is required.
  - Otherwise, a pullup/down is not necessary.
2. Pull conflicts occur when there are different pulls on the same line. In order to correctly configure the pin, avoid external and internal pull together.
3. Logic conflicts consist in different electrical levels at the same time on one line. This can occur when several devices are connected to the same line. The two possible cases are:
  - If no external device drives the line, configure the pin to drive a 0.
  - If another device drives the line, either the same value has to be driven or the pin has to be disconnected (HZ).

---

**NOTE:** It is advised to use high impedance logical state either on the device or the external component when the line is driven by both components.

---

The I/O pads are software-controlled by:

- Writing to the `CONTROL.CONTROL_PADCONF_X` registers in the control module for I/O and pullup/down configuration.

**NOTE:** If a device pad is left unconnected, but power is supplied to the I/O, or the pad is used only as an output during the lifetime of the application, it is recommended to keep its corresponding CONTROL\_CORE/WKUP\_PAD0\_X\_PAD1\_Y.INPUTENABLE pad configuration bit set to 0b0. This keeps the input buffer disabled and reduces static current consumption.

---

- Writing to the GPIOi.GPIO\_OE registers in the GPIO module for I/O configuration. For more information about how to configure the I/O pads, see [Section 13.4.4, Pad Functional Multiplexing and Configuration](#).

For more information about the GPIO module, see [Chapter 25, General-Purpose Interface](#).

---

**NOTE:** For a correct configuration of each pin direction (input, output, bidirectional), the CONTROL.[CONTROL\\_PADCONF\\_X](#) and the GPIOi.GPIO\_OE registers must be written.

---

For unconnected device pads, safe\_mode pad configuration is recommended if available. [Table 13-70](#) summarizes recommendations for the configuration of unconnected pads (in terms of mux mode, input, and output buffer states) for all cases, including those where safe\_mode configuration is not available.

Table 13-70. Recommended Configuration For Unconnected Device Pads

| Pad MuxMode Set Features |                          |                                              | Power-on Reset Default Configuration |                          | Recommended Unconnected Device Pad Configuration |           |                        |                         |                              |  |
|--------------------------|--------------------------|----------------------------------------------|--------------------------------------|--------------------------|--------------------------------------------------|-----------|------------------------|-------------------------|------------------------------|--|
| Safe Mode Available?     | GPIO Function Available? | More Than One (Non-GPIO) Function Available? | Multiplexed Signal Direction at Pad  | Pad State <sup>(1)</sup> | Multiplexed Signal Direction at Pad              | Pad State | Input Buffer Disabled? | Output Buffer Disabled? | MUX Function Selected        |  |
| Yes                      | N/A                      | N/A                                          | Input                                | PU                       | Safe Mode                                        | PU        | Yes <sup>(2)</sup>     | N/A                     | SAFE MODE <sup>(3)</sup>     |  |
| Yes                      | N/A                      | N/A                                          | Input                                | PD                       | Safe Mode                                        | PD        | Yes                    | N/A                     | SAFE MODE                    |  |
| Yes                      | N/A                      | N/A                                          | Output                               | 1                        | Safe Mode                                        | PD        | Yes                    | N/A                     | SAFE MODE                    |  |
| Yes                      | N/A                      | N/A                                          | Output                               | 0                        | Safe Mode                                        | PD        | Yes                    | N/A                     | SAFE MODE                    |  |
| Yes                      | N/A                      | N/A                                          | –                                    | Hi-Z                     | Safe Mode                                        | PD        | Yes                    | N/A                     | SAFE MODE                    |  |
| No                       | Yes                      | N/A                                          | Input                                | PU                       | Input                                            | PU        | Yes                    | Yes <sup>(4)</sup>      | GPIO_XX <sup>(5)</sup>       |  |
| No                       | Yes                      | N/A                                          | Input                                | PD                       | Input                                            | PD        | Yes                    | Yes                     | GPIO_XX                      |  |
| No                       | Yes                      | N/A                                          | Output                               | 1                        | Input                                            | PD        | Yes                    | Yes                     | GPIO_XX                      |  |
| No                       | Yes                      | N/A                                          | Output                               | 0                        | Input                                            | PD        | Yes                    | Yes                     | GPIO_XX                      |  |
| No                       | Yes                      | N/A                                          | –                                    | Hi-Z                     | Input                                            | PD        | Yes                    | Yes                     | GPIO_XX                      |  |
| No                       | No                       | Yes                                          | Input                                | PU                       | Input                                            | PU        | Yes                    | N/A <sup>(4)</sup>      | N/A (default)                |  |
| No                       | No                       | Yes                                          | Input                                | PD                       | Input                                            | PD        | Yes                    | N/A                     | N/A (default)                |  |
| No                       | No                       | Yes                                          | Output                               | 1                        | Output                                           | 1         | Yes                    | N/A                     | N/A (default) <sup>(6)</sup> |  |
| No                       | No                       | Yes                                          | Output                               | 0                        | Output                                           | 0         | Yes                    | N/A                     | N/A (default) <sup>(6)</sup> |  |
| No                       | No                       | Yes                                          | –                                    | Hi-Z                     | Input                                            | PD        | Yes                    | N/A                     | N/A (default)                |  |
| No                       | No                       | No                                           | Input                                | PU                       | Input                                            | PU        | Yes                    | N/A <sup>(4)</sup>      | N/A (default)                |  |
| No                       | No                       | No                                           | Input                                | PD                       | Input                                            | PD        | Yes                    | N/A                     | N/A (default)                |  |
| No                       | No                       | No                                           | Output                               | 1                        | Output                                           | 1         | Yes                    | N/A                     | N/A (default)                |  |
| No                       | No                       | No                                           | Output                               | 0                        | Output                                           | 0         | Yes                    | N/A                     | N/A (default)                |  |
| No                       | No                       | No                                           | –                                    | Hi-Z                     | Input                                            | PD        | Yes                    | N/A                     | N/A (default)                |  |

(1) PU = Pullup; PD = Pulldown; Hi-Z = High impedance

(2) If a certain device pad is left unconnected, its associated padconfiguration register INPUTENABLE bit must be explicitly disabled in software (set to 0b0), regardless of pad MUXMODE bit field value.

(3) If a certain pad has a defined safe\_mode and is left unconnected in an application , it is recommended to keep its padconfiguration MuxMode value at 0x7 (that is, safe\_mode).

(4) There is no software control over the pad associated output buffer in the Control Module. In case of a GPIO function selection, the output buffer is hardware enabled once the user enables corresponding pin output direction in the GPIOx.GPIO\_OE control register.

(5) If a certain pad does not have a safe\_mode, but has an associated GPIO function, it is recommended to set its padconfiguration register MuxMode to select the GPIO mode.

(6) If one of the other mux modes available is bidirectional or input-only, then the nondefault mux mode could be used and configured with input disabled.

## 13.6 SCM Register Manual

### 13.6.1 SCM Instance Summary

[Table 13-71](#) lists the base address and address space for the SCM instances.

**Table 13-71. SCM Instance Summary**

| Module Name  | Base Address |
|--------------|--------------|
| INTERFACE    | 0x4800 2000  |
| GENERAL      | 0x4800 2270  |
| GENERAL_WKUP | 0x4800 2A5C  |

A MEM\_WKUP (1KB) instance exists; it based at 0x4800 2600. This instance is used in a save-and-restore context. See [Table 13-75](#) for more details.

To configure pads, two instances exist:

- PADCONFS instance based at 0x4800 2030. For more information, see [Table 13-73](#).
- PADCONFS\_WKUP instance based at 0x4800 2A00. See [Table 13-76](#).

### 13.6.2 SCM Register Summary

---

**NOTE:** All module registers are 8-, 16-, or 32-bit accessible through the L4 interconnect (little endian encoding).

---

[Table 13-72](#) lists the INTERFACE registers.

**Table 13-72. INTERFACE Register Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address |
|-------------------|------|-----------------------|----------------|------------------|
| CONTROL_REVISION  | R    | 32                    | 0x0000 0000    | 0x4800 2000      |
| CONTROL_SYSCONFIG | RW   | 32                    | 0x0000 0010    | 0x4800 2010      |

[Table 13-73](#) lists the PADCONFS registers.

**Table 13-73. PADCONFS Register Summary**

| Register Name            | Type | Register Width (Bits) | Address Offset | Physical Address |
|--------------------------|------|-----------------------|----------------|------------------|
| CONTROL_PADCONF_SDRC_D0  | RW   | 32                    | 0x0000 0000    | 0x4800 2030      |
| CONTROL_PADCONF_SDRC_D2  | RW   | 32                    | 0x0000 0004    | 0x4800 2034      |
| CONTROL_PADCONF_SDRC_D4  | RW   | 32                    | 0x0000 0008    | 0x4800 2038      |
| CONTROL_PADCONF_SDRC_D6  | RW   | 32                    | 0x0000 000C    | 0x4800 203C      |
| CONTROL_PADCONF_SDRC_D8  | RW   | 32                    | 0x0000 0010    | 0x4800 2040      |
| CONTROL_PADCONF_SDRC_D10 | RW   | 32                    | 0x0000 0014    | 0x4800 2044      |
| CONTROL_PADCONF_SDRC_D12 | RW   | 32                    | 0x0000 0018    | 0x4800 2048      |
| CONTROL_PADCONF_SDRC_D14 | RW   | 32                    | 0x0000 001C    | 0x4800 204C      |
| CONTROL_PADCONF_SDRC_D16 | RW   | 32                    | 0x0000 0020    | 0x4800 2050      |
| CONTROL_PADCONF_SDRC_D18 | RW   | 32                    | 0x0000 0024    | 0x4800 2054      |
| CONTROL_PADCONF_SDRC_D20 | RW   | 32                    | 0x0000 0028    | 0x4800 2058      |
| CONTROL_PADCONF_SDRC_D22 | RW   | 32                    | 0x0000 002C    | 0x4800 205C      |
| CONTROL_PADCONF_SDRC_D24 | RW   | 32                    | 0x0000 0030    | 0x4800 2060      |
| CONTROL_PADCONF_SDRC_D26 | RW   | 32                    | 0x0000 0034    | 0x4800 2064      |
| CONTROL_PADCONF_SDRC_D28 | RW   | 32                    | 0x0000 0038    | 0x4800 2068      |
| CONTROL_PADCONF_SDRC_D30 | RW   | 32                    | 0x0000 003C    | 0x4800 206C      |

**Table 13-73. PADCONFS Register Summary (continued)**

| Register Name                 | Type | Register Width (Bits) | Address Offset | Physical Address |
|-------------------------------|------|-----------------------|----------------|------------------|
| CONTROL_PADCONF_SDRC_CLK      | RW   | 32                    | 0x0000 0040    | 0x4800 2070      |
| CONTROL_PADCONF_SDRC_DQS1     | RW   | 32                    | 0x0000 0044    | 0x4800 2074      |
| CONTROL_PADCONF_SDRC_DQS3     | RW   | 32                    | 0x0000 0048    | 0x4800 2078      |
| CONTROL_PADCONF_GPMC_A2       | RW   | 32                    | 0x0000 004C    | 0x4800 207C      |
| CONTROL_PADCONF_GPMC_A4       | RW   | 32                    | 0x0000 0050    | 0x4800 2080      |
| CONTROL_PADCONF_GPMC_A6       | RW   | 32                    | 0x0000 0054    | 0x4800 2084      |
| CONTROL_PADCONF_GPMC_A8       | RW   | 32                    | 0x0000 0058    | 0x4800 2088      |
| CONTROL_PADCONF_GPMC_A10      | RW   | 32                    | 0x0000 005C    | 0x4800 208C      |
| CONTROL_PADCONF_GPMC_D1       | RW   | 32                    | 0x0000 0060    | 0x4800 2090      |
| CONTROL_PADCONF_GPMC_D3       | RW   | 32                    | 0x0000 0064    | 0x4800 2094      |
| CONTROL_PADCONF_GPMC_D5       | RW   | 32                    | 0x0000 0068    | 0x4800 2098      |
| CONTROL_PADCONF_GPMC_D7       | RW   | 32                    | 0x0000 006C    | 0x4800 209C      |
| CONTROL_PADCONF_GPMC_D9       | RW   | 32                    | 0x0000 0070    | 0x4800 20A0      |
| CONTROL_PADCONF_GPMC_D11      | RW   | 32                    | 0x0000 0074    | 0x4800 20A4      |
| CONTROL_PADCONF_GPMC_D13      | RW   | 32                    | 0x0000 0078    | 0x4800 20A8      |
| CONTROL_PADCONF_GPMC_D15      | RW   | 32                    | 0x0000 007C    | 0x4800 20AC      |
| CONTROL_PADCONF_GPMC_NCS1     | RW   | 32                    | 0x0000 0080    | 0x4800 20B0      |
| CONTROL_PADCONF_GPMC_NCS3     | RW   | 32                    | 0x0000 0084    | 0x4800 20B4      |
| CONTROL_PADCONF_GPMC_NCS5     | RW   | 32                    | 0x0000 0088    | 0x4800 20B8      |
| CONTROL_PADCONF_GPMC_NCS7     | RW   | 32                    | 0x0000 008C    | 0x4800 20BC      |
| CONTROL_PADCONF_GPMC_NADV_ALE | RW   | 32                    | 0x0000 0090    | 0x4800 20C0      |
| CONTROL_PADCONF_GPMC_NWE      | RW   | 32                    | 0x0000 0094    | 0x4800 20C4      |
| CONTROL_PADCONF_GPMC_NBE1     | RW   | 32                    | 0x0000 0098    | 0x4800 20C8      |
| CONTROL_PADCONF_GPMC_WAIT0    | RW   | 32                    | 0x0000 009C    | 0x4800 20CC      |
| CONTROL_PADCONF_GPMC_WAIT2    | RW   | 32                    | 0x0000 00A0    | 0x4800 20D0      |
| CONTROL_PADCONF_DSS_PCLK      | RW   | 32                    | 0x0000 00A4    | 0x4800 20D4      |
| CONTROL_PADCONF_DSS_VSYNC     | RW   | 32                    | 0x0000 00A8    | 0x4800 20D8      |
| CONTROL_PADCONF_DSS_DATA0     | RW   | 32                    | 0x0000 00AC    | 0x4800 20DC      |
| CONTROL_PADCONF_DSS_DATA2     | RW   | 32                    | 0x0000 00B0    | 0x4800 20E0      |
| CONTROL_PADCONF_DSS_DATA4     | RW   | 32                    | 0x0000 00B4    | 0x4800 20E4      |
| CONTROL_PADCONF_DSS_DATA6     | RW   | 32                    | 0x0000 00B8    | 0x4800 20E8      |
| CONTROL_PADCONF_DSS_DATA8     | RW   | 32                    | 0x0000 00BC    | 0x4800 20EC      |
| CONTROL_PADCONF_DSS_DATA10    | RW   | 32                    | 0x0000 00C0    | 0x4800 20F0      |
| CONTROL_PADCONF_DSS_DATA12    | RW   | 32                    | 0x0000 00C4    | 0x4800 20F4      |
| CONTROL_PADCONF_DSS_DATA14    | RW   | 32                    | 0x0000 00C8    | 0x4800 20F8      |
| CONTROL_PADCONF_DSS_DATA16    | RW   | 32                    | 0x0000 00CC    | 0x4800 20FC      |
| CONTROL_PADCONF_DSS_DATA18    | RW   | 32                    | 0x0000 00D0    | 0x4800 2100      |
| CONTROL_PADCONF_DSS_DATA20    | RW   | 32                    | 0x0000 00D4    | 0x4800 2104      |
| CONTROL_PADCONF_DSS_DATA22    | RW   | 32                    | 0x0000 00D8    | 0x4800 2108      |
| CONTROL_PADCONF_CAM_HS        | RW   | 32                    | 0x0000 00DC    | 0x4800 210C      |
| CONTROL_PADCONF_CAM_XCLKA     | RW   | 32                    | 0x0000 00E0    | 0x4800 2110      |
| CONTROL_PADCONF_CAM_FLD       | RW   | 32                    | 0x0000 00E4    | 0x4800 2114      |
| CONTROL_PADCONF_CAM_D1        | RW   | 32                    | 0x0000 00E8    | 0x4800 2118      |
| CONTROL_PADCONF_CAM_D3        | RW   | 32                    | 0x0000 00EC    | 0x4800 211C      |
| CONTROL_PADCONF_CAM_D5        | RW   | 32                    | 0x0000 00F0    | 0x4800 2120      |
| CONTROL_PADCONF_CAM_D7        | RW   | 32                    | 0x0000 00F4    | 0x4800 2124      |
| CONTROL_PADCONF_CAM_D9        | RW   | 32                    | 0x0000 00F8    | 0x4800 2128      |

**Table 13-73. PADCONFS Register Summary (continued)**

| <b>Register Name</b>          | <b>Type</b> | <b>Register Width (Bits)</b> | <b>Address Offset</b> | <b>Physical Address</b> |
|-------------------------------|-------------|------------------------------|-----------------------|-------------------------|
| CONTROL_PADCONF_CAM_D11       | RW          | 32                           | 0x0000 00FC           | 0x4800 212C             |
| CONTROL_PADCONF_CAM_WEN       | RW          | 32                           | 0x0000 0100           | 0x4800 2130             |
| CONTROL_PADCONF_CSI2_DX0      | RW          | 32                           | 0x0000 0104           | 0x4800 2134             |
| CONTROL_PADCONF_CSI2_DX1      | RW          | 32                           | 0x0000 0108           | 0x4800 2138             |
| CONTROL_PADCONF_MCBSP2_FSX    | RW          | 32                           | 0x0000 010C           | 0x4800 213C             |
| CONTROL_PADCONF_MCBSP2_DR     | RW          | 32                           | 0x0000 0110           | 0x4800 2140             |
| CONTROL_PADCONF_MMC1_CLK      | RW          | 32                           | 0x0000 0114           | 0x4800 2144             |
| CONTROL_PADCONF_MMC1_DAT0     | RW          | 32                           | 0x0000 0118           | 0x4800 2148             |
| CONTROL_PADCONF_MMC1_DAT2     | RW          | 32                           | 0x0000 011C           | 0x4800 214C             |
| CONTROL_PADCONF_MMC2_CLK      | RW          | 32                           | 0x0000 0128           | 0x4800 2158             |
| CONTROL_PADCONF_MMC2_DAT0     | RW          | 32                           | 0x0000 012C           | 0x4800 215C             |
| CONTROL_PADCONF_MMC2_DAT2     | RW          | 32                           | 0x0000 0130           | 0x4800 2160             |
| CONTROL_PADCONF_MMC2_DAT4     | RW          | 32                           | 0x0000 0134           | 0x4800 2164             |
| CONTROL_PADCONF_MMC2_DAT6     | RW          | 32                           | 0x0000 0138           | 0x4800 2168             |
| CONTROL_PADCONF_MCBSP3_RX     | RW          | 32                           | 0x0000 013C           | 0x4800 216C             |
| CONTROL_PADCONF_MCBSP3_CLKX   | RW          | 32                           | 0x0000 0140           | 0x4800 2170             |
| CONTROL_PADCONF_UART2_CTS     | RW          | 32                           | 0x0000 0144           | 0x4800 2174             |
| CONTROL_PADCONF_UART2_TX      | RW          | 32                           | 0x0000 0148           | 0x4800 2178             |
| CONTROL_PADCONF_UART1_TX      | RW          | 32                           | 0x0000 014C           | 0x4800 217C             |
| CONTROL_PADCONF_UART1_CTS     | RW          | 32                           | 0x0000 0150           | 0x4800 2180             |
| CONTROL_PADCONF_MCBSP4_CLKX   | RW          | 32                           | 0x0000 0154           | 0x4800 2184             |
| CONTROL_PADCONF_MCBSP4_RX     | RW          | 32                           | 0x0000 0158           | 0x4800 2188             |
| CONTROL_PADCONF_MCBSP1_CLKR   | RW          | 32                           | 0x0000 015C           | 0x4800 218C             |
| CONTROL_PADCONF_MCBSP1_RX     | RW          | 32                           | 0x0000 0160           | 0x4800 2190             |
| CONTROL_PADCONF_MCBSP_CLKS    | RW          | 32                           | 0x0000 0164           | 0x4800 2194             |
| CONTROL_PADCONF_MCBSP1_CLKX   | RW          | 32                           | 0x0000 0168           | 0x4800 2198             |
| CONTROL_PADCONF_UART3_RTS_SD  | RW          | 32                           | 0x0000 016C           | 0x4800 219C             |
| CONTROL_PADCONF_UART3_RX_IRTX | RW          | 32                           | 0x0000 0170           | 0x4800 21A0             |
| CONTROL_PADCONF_HSUSB0_STP    | RW          | 32                           | 0x0000 0174           | 0x4800 21A4             |
| CONTROL_PADCONF_HSUSB0_NXT    | RW          | 32                           | 0x0000 0178           | 0x4800 21A8             |
| CONTROL_PADCONF_HSUSB0_DATA1  | RW          | 32                           | 0x0000 017C           | 0x4800 21AC             |
| CONTROL_PADCONF_HSUSB0_DATA3  | RW          | 32                           | 0x0000 0180           | 0x4800 21B0             |
| CONTROL_PADCONF_HSUSB0_DATA5  | RW          | 32                           | 0x0000 0184           | 0x4800 21B4             |
| CONTROL_PADCONF_HSUSB0_DATA7  | RW          | 32                           | 0x0000 0188           | 0x4800 21B8             |
| CONTROL_PADCONF_I2C1_SDA      | RW          | 32                           | 0x0000 018C           | 0x4800 21BC             |
| CONTROL_PADCONF_I2C2_SDA      | RW          | 32                           | 0x0000 0190           | 0x4800 21C0             |
| CONTROL_PADCONF_I2C3_SDA      | RW          | 32                           | 0x0000 0194           | 0x4800 21C4             |
| CONTROL_PADCONF_MCSPI1_CLK    | RW          | 32                           | 0x0000 0198           | 0x4800 21C8             |
| CONTROL_PADCONF_MCSPI1_SOMI   | RW          | 32                           | 0x0000 019C           | 0x4800 21CC             |
| CONTROL_PADCONF_MCSPI1_CS1    | RW          | 32                           | 0x0000 01A0           | 0x4800 21D0             |
| CONTROL_PADCONF_MCSPI1_CS3    | RW          | 32                           | 0x0000 01A4           | 0x4800 21D4             |
| CONTROL_PADCONF_MCSPI2_SIMO   | RW          | 32                           | 0x0000 01A8           | 0x4800 21D8             |
| CONTROL_PADCONF_MCSPI2_CS0    | RW          | 32                           | 0x0000 01AC           | 0x4800 21DC             |
| CONTROL_PADCONF_SYS_NIRQ      | RW          | 32                           | 0x0000 01B0           | 0x4800 21E0             |
| CONTROL_PADCONF_SAD2D_MCADO   | RW          | 32                           | 0x0000 01B4           | 0x4800 21E4             |
| CONTROL_PADCONF_SAD2D_MCAD2   | RW          | 32                           | 0x0000 01B8           | 0x4800 21E8             |
| CONTROL_PADCONF_SAD2D_MCAD4   | RW          | 32                           | 0x0000 01BC           | 0x4800 21EC             |

**Table 13-73. PADCONFS Register Summary (continued)**

| Register Name                   | Type | Register Width (Bits) | Address Offset | Physical Address |
|---------------------------------|------|-----------------------|----------------|------------------|
| CONTROL_PADCONF_SAD2D_MCAD6     | RW   | 32                    | 0x0000 01C0    | 0x4800 21F0      |
| CONTROL_PADCONF_SAD2D_MCAD8     | RW   | 32                    | 0x0000 01C4    | 0x4800 21F4      |
| CONTROL_PADCONF_SAD2D_MCAD10    | RW   | 32                    | 0x0000 01C8    | 0x4800 21F8      |
| CONTROL_PADCONF_SAD2D_MCAD12    | RW   | 32                    | 0x0000 01CC    | 0x4800 21FC      |
| CONTROL_PADCONF_SAD2D_MCAD14    | RW   | 32                    | 0x0000 01D0    | 0x4800 2200      |
| CONTROL_PADCONF_SAD2D_MCAD16    | RW   | 32                    | 0x0000 01D4    | 0x4800 2204      |
| CONTROL_PADCONF_SAD2D_MCAD18    | RW   | 32                    | 0x0000 01D8    | 0x4800 2208      |
| CONTROL_PADCONF_SAD2D_MCAD20    | RW   | 32                    | 0x0000 01DC    | 0x4800 220C      |
| CONTROL_PADCONF_SAD2D_MCAD22    | RW   | 32                    | 0x0000 01E0    | 0x4800 2210      |
| CONTROL_PADCONF_SAD2D_MCAD24    | RW   | 32                    | 0x0000 01E4    | 0x4800 2214      |
| CONTROL_PADCONF_SAD2D_MCAD26    | RW   | 32                    | 0x0000 01E8    | 0x4800 2218      |
| CONTROL_PADCONF_SAD2D_MCAD28    | RW   | 32                    | 0x0000 01EC    | 0x4800 221C      |
| CONTROL_PADCONF_SAD2D_MCAD30    | RW   | 32                    | 0x0000 01F0    | 0x4800 2220      |
| CONTROL_PADCONF_SAD2D_MCAD32    | RW   | 32                    | 0x0000 01F4    | 0x4800 2224      |
| CONTROL_PADCONF_SAD2D_MCAD34    | RW   | 32                    | 0x0000 01F8    | 0x4800 2228      |
| CONTROL_PADCONF_SAD2D_MCAD36    | RW   | 32                    | 0x0000 01FC    | 0x4800 222C      |
| CONTROL_PADCONF_SAD2D_NRESPWRON | RW   | 32                    | 0x0000 0200    | 0x4800 2230      |
| CONTROL_PADCONF_SAD2D_ARMNIRQ   | RW   | 32                    | 0x0000 0204    | 0x4800 2234      |
| CONTROL_PADCONF_SAD2D_SPINT     | RW   | 32                    | 0x0000 0208    | 0x4800 2238      |
| CONTROL_PADCONF_SAD2D_DMAREQ0   | RW   | 32                    | 0x0000 020C    | 0x4800 223C      |
| CONTROL_PADCONF_SAD2D_DMAREQ2   | RW   | 32                    | 0x0000 0210    | 0x4800 2240      |
| CONTROL_PADCONF_SAD2D_NTRST     | RW   | 32                    | 0x0000 0214    | 0x4800 2244      |
| CONTROL_PADCONF_SAD2D_TDO       | RW   | 32                    | 0x0000 0218    | 0x4800 2248      |
| CONTROL_PADCONF_SAD2D_TCK       | RW   | 32                    | 0x0000 021C    | 0x4800 224C      |
| CONTROL_PADCONF_SAD2D_MSTDBY    | RW   | 32                    | 0x0000 0220    | 0x4800 2250      |
| CONTROL_PADCONF_SAD2D_IDLEACK   | RW   | 32                    | 0x0000 0224    | 0x4800 2254      |
| CONTROL_PADCONF_SAD2D_SWRITE    | RW   | 32                    | 0x0000 0228    | 0x4800 2258      |
| CONTROL_PADCONF_SAD2D_SREAD     | RW   | 32                    | 0x0000 022C    | 0x4800 225C      |
| CONTROL_PADCONF_SAD2D_SBUSFLAG  | RW   | 32                    | 0x0000 0230    | 0x4800 2260      |
| CONTROL_PADCONF_SDRC_CKE1       | RW   | 32                    | 0x0000 0234    | 0x4800 2264      |
| CONTROL_PADCONF_SDRC_BA0        | RW   | 32                    | 0x0000 0570    | 0x4800 25A0      |
| CONTROL_PADCONF_SDRC_A0         | RW   | 32                    | 0x0000 0574    | 0x4800 25A4      |
| CONTROL_PADCONF_SDRC_A2         | RW   | 32                    | 0x0000 0578    | 0x4800 25A8      |
| CONTROL_PADCONF_SDRC_A4         | RW   | 32                    | 0x0000 057C    | 0x4800 25AC      |
| CONTROL_PADCONF_SDRC_A6         | RW   | 32                    | 0x0000 0580    | 0x4800 25B0      |
| CONTROL_PADCONF_SDRC_A8         | RW   | 32                    | 0x0000 0584    | 0x4800 25B4      |
| CONTROL_PADCONF_SDRC_A10        | RW   | 32                    | 0x0000 0588    | 0x4800 25B8      |
| CONTROL_PADCONF_SDRC_A12        | RW   | 32                    | 0x0000 058C    | 0x4800 25BC      |
| CONTROL_PADCONF_SDRC_A14        | RW   | 32                    | 0x0000 0590    | 0x4800 25C0      |
| CONTROL_PADCONF_SDRC_NCS1       | RW   | 32                    | 0x0000 0594    | 0x4800 25C4      |
| CONTROL_PADCONF_SDRC_NRAS       | RW   | 32                    | 0x0000 0598    | 0x4800 25C8      |
| CONTROL_PADCONF_SDRC_NWE        | RW   | 32                    | 0x0000 059C    | 0x4800 25CC      |
| CONTROL_PADCONF_SDRC_DM1        | RW   | 32                    | 0x0000 05A0    | 0x4800 25D0      |
| CONTROL_PADCONF_SDRC_DM3        | RW   | 32                    | 0x0000 05A4    | 0x4800 25D4      |
| CONTROL_PADCONF_ETK_CLK         | RW   | 32                    | 0x0000 05A8    | 0x4800 25D8      |
| CONTROL_PADCONF_ETK_D0          | RW   | 32                    | 0x0000 05AC    | 0x4800 25DC      |

**Table 13-73. PADCONFS Register Summary (continued)**

| Register Name           | Type | Register Width (Bits) | Address Offset | Physical Address |
|-------------------------|------|-----------------------|----------------|------------------|
| CONTROL_PADCONF_ETK_D2  | RW   | 32                    | 0x0000 05B0    | 0x4800 25E0      |
| CONTROL_PADCONF_ETK_D4  | RW   | 32                    | 0x0000 05B4    | 0x4800 25E4      |
| CONTROL_PADCONF_ETK_D6  | RW   | 32                    | 0x0000 05B8    | 0x4800 25E8      |
| CONTROL_PADCONF_ETK_D8  | RW   | 32                    | 0x0000 05BC    | 0x4800 25EC      |
| CONTROL_PADCONF_ETK_D10 | RW   | 32                    | 0x0000 05C0    | 0x4800 25F0      |
| CONTROL_PADCONF_ETK_D12 | RW   | 32                    | 0x0000 05C4    | 0x4800 25F4      |
| CONTROL_PADCONF_ETK_D14 | RW   | 32                    | 0x0000 05C8    | 0x4800 25F8      |

Table 13-74 lists the GENERAL registers.

**Table 13-74. GENERAL Register Summary**

| Register Name                  | Type  | Register Width (Bits) | Address Offset | Physical Address |
|--------------------------------|-------|-----------------------|----------------|------------------|
| CONTROL_PADCONF_OFF            | RW    | 32                    | 0x0000 0000    | 0x4800 2270      |
| CONTROL_DEVCONF0               | RW    | 32                    | 0x0000 0004    | 0x4800 2274      |
| RESERVED                       | R     | 32                    | 0x0000 0008    | 0x4800 2278      |
| RESERVED                       | R     | 32                    | 0x0000 000C    | 0x4800 227C      |
| CONTROL_MSUSPEN_DMUX_0         | RW    | 32                    | 0x0000 0020    | 0x4800 2290      |
| CONTROL_MSUSPEN_DMUX_1         | RW    | 32                    | 0x0000 0024    | 0x4800 2294      |
| CONTROL_MSUSPEN_DMUX_2         | RW    | 32                    | 0x0000 0028    | 0x4800 2298      |
| CONTROL_MSUSPEN_DMUX_3         | RW    | 32                    | 0x0000 002C    | 0x4800 229C      |
| CONTROL_MSUSPEN_DMUX_4         | RW    | 32                    | 0x0000 0030    | 0x4800 22A0      |
| CONTROL_MSUSPEN_DMUX_5         | RW    | 32                    | 0x0000 0034    | 0x4800 22A4      |
| CONTROL_PROT_CTR_L             | R/OCO | 32                    | 0x0000 0040    | 0x4800 22B0      |
| CONTROL_DEVCONF1               | RW    | 32                    | 0x0000 0068    | 0x4800 22D8      |
| RESERVED                       | R     | 32                    | 0x0000 006C    | 0x4800 22DC      |
| CONTROL_PROT_ERR_STATUS        | RW    | 32                    | 0x0000 0074    | 0x4800 22E4      |
| CONTROL_PROT_ERR_STATUS_DEBUG  | RW    | 32                    | 0x0000 0078    | 0x4800 22E8      |
| CONTROL_STATUS                 | R     | 32                    | 0x0000 0080    | 0x4800 22F0      |
| CONTROL_GENERAL_PURPOSE_STATUS | R     | 32                    | 0x0000 0084    | 0x4800 22F4      |
| CONTROL_RPUB_KEY_H_0           | R     | 32                    | 0x0000 0090    | 0x4800 2300      |
| CONTROL_RPUB_KEY_H_1           | R     | 32                    | 0x0000 0094    | 0x4800 2304      |
| CONTROL_RPUB_KEY_H_2           | R     | 32                    | 0x0000 0098    | 0x4800 2308      |
| CONTROL_RPUB_KEY_H_3           | R     | 32                    | 0x0000 009C    | 0x4800 230C      |
| CONTROL_RPUB_KEY_H_4           | R     | 32                    | 0x0000 00A0    | 0x4800 2310      |
| CONTROL_USB_CONF_0             | R     | 32                    | 0x0000 0100    | 0x4800 2370      |

**Table 13-74. GENERAL Register Summary (continued)**

| Register Name                       | Type | Register Width (Bits) | Address Offset | Physical Address |
|-------------------------------------|------|-----------------------|----------------|------------------|
| CONTROL_USB_CONF_1                  | R    | 32                    | 0x0000 0104    | 0x4800 2374      |
| CONTROL_FUSE OPP 1G_VDD1            | R    | 32                    | 0x0000 0110    | 0x4800 2380      |
| CONTROL_FUSE OPP 50_VDD1            | R    | 32                    | 0x0000 0114    | 0x4800 2384      |
| CONTROL_FUSE OPP 100_VDD1           | R    | 32                    | 0x0000 0118    | 0x4800 2388      |
| RESERVED                            | R    | 32                    | 0x0000 011C    | 0x4800 238C      |
| CONTROL_FUSE OPP 130_VDD1           | R    | 32                    | 0x0000 0120    | 0x4800 2390      |
| RESERVED                            | R    | 32                    | 0x0000 0124    | 0x4700 2394      |
| CONTROL_FUSE OPP 50_VDD2            | R    | 32                    | 0x0000 0128    | 0x4800 2398      |
| CONTROL_FUSE OPP 100_VDD2           | R    | 32                    | 0x0000 012C    | 0x4800 239C      |
| CONTROL_FUSE_SR                     | R    | 32                    | 0x0000 0130    | 0x4800 23A0      |
| CONTROL_IVA2_BOOT_ADDR              | RW   | 32                    | 0x0000 0190    | 0x4800 2400      |
| CONTROL_IVA2_BOOT_MOD               | RW   | 32                    | 0x0000 0194    | 0x4800 2404      |
| CONTROL_PROG_IO2                    | RW   | 32                    | 0x0000 0198    | 0x4800 2408      |
| CONTROL_MEM_RTA_CTRL                | RW   | 32                    | 0x0000 019C    | 0x4800 240C      |
| CONTROL_DEBOBS_0                    | RW   | 32                    | 0x0000 01B0    | 0x4800 2420      |
| CONTROL_DEBOBS_1                    | RW   | 32                    | 0x0000 01B4    | 0x4800 2424      |
| CONTROL_DEBOBS_2                    | RW   | 32                    | 0x0000 01B8    | 0x4800 2428      |
| CONTROL_DEBOBS_3                    | RW   | 32                    | 0x0000 01BC    | 0x4800 242C      |
| CONTROL_DEBOBS_4                    | RW   | 32                    | 0x0000 01C0    | 0x4800 2430      |
| CONTROL_DEBOBS_5                    | RW   | 32                    | 0x0000 01C4    | 0x4800 2434      |
| CONTROL_DEBOBS_6                    | RW   | 32                    | 0x0000 01C8    | 0x4800 2438      |
| CONTROL_DEBOBS_7                    | RW   | 32                    | 0x0000 01CC    | 0x4800 243C      |
| CONTROL_DEBOBS_8                    | RW   | 32                    | 0x0000 01D0    | 0x4800 2440      |
| CONTROL_PROG_IO0                    | RW   | 32                    | 0x0000 01D4    | 0x4800 2444      |
| CONTROL_PROG_IO1                    | RW   | 32                    | 0x0000 01D8    | 0x4800 2448      |
| CONTROL_DSS_DPLL_SPREADING          | RW   | 32                    | 0x0000 01E0    | 0x4800 2450      |
| CONTROL_CORE_DPLL_SPREADING         | RW   | 32                    | 0x0000 01E4    | 0x4800 2454      |
| CONTROL_PER_DPLL_SPREADING          | RW   | 32                    | 0x0000 01E8    | 0x4800 2458      |
| CONTROL_USBHOST_DPLL_SPREADING      | RW   | 32                    | 0x0000 01EC    | 0x4800 245C      |
| CONTROL_SDRC_SHA_RING               | RW   | 32                    | 0x0000 01F0    | 0x4800 2460      |
| CONTROL_SDRC_MCF_G0                 | RW   | 32                    | 0x0000 01F4    | 0x4800 2464      |
| CONTROL_SDRC_MCF_G1                 | RW   | 32                    | 0x0000 01F8    | 0x4800 2468      |
| CONTROL_MODEM_FW_CONFIGURATION_LOCK | RW   | 32                    | 0x0000 01FC    | 0x4800 246C      |

**Table 13-74. GENERAL Register Summary (continued)**

| Register Name                              | Type | Register Width (Bits) | Address Offset | Physical Address |
|--------------------------------------------|------|-----------------------|----------------|------------------|
| CONTROL_MODEM_M_EMORY_RESOURCES_CONF       | RW   | 32                    | 0x0000 0200    | 0x4800 2470      |
| CONTROL_MODEM_G_PMC_DT_FW_REQ_IN_FO        | RW   | 32                    | 0x0000 0204    | 0x4800 2474      |
| CONTROL_MODEM_G_PMC_DT_FW_RD               | RW   | 32                    | 0x0000 0208    | 0x4800 2478      |
| CONTROL_MODEM_G_PMC_DT_FW_WR               | RW   | 32                    | 0x0000 020C    | 0x4800 247C      |
| CONTROL_MODEM_G_PMC_BOOT_CODE              | RW   | 32                    | 0x0000 0210    | 0x4800 2480      |
| CONTROL_MODEM_S_MS_RG_ATT1                 | RW   | 32                    | 0x0000 0214    | 0x4800 2484      |
| CONTROL_MODEM_S_MS_RG_RDPERM1              | RW   | 32                    | 0x0000 0218    | 0x4800 2488      |
| CONTROL_MODEM_S_MS_RG_WRPERM1              | RW   | 32                    | 0x0000 021C    | 0x4800 248C      |
| CONTROL_MODEM_D_2D_FW_DEBUG_MODE           | RW   | 32                    | 0x0000 0220    | 0x4800 2490      |
| CONTROL_DPF_OCM_RAM_FW_ADDR_MATCH          | RW   | 32                    | 0x0000 0228    | 0x4800 2498      |
| CONTROL_DPF_OCM_RAM_FW_REQINFO             | RW   | 32                    | 0x0000 022C    | 0x4800 249C      |
| CONTROL_DPF_OCM_RAM_FW_WR                  | RW   | 32                    | 0x0000 0230    | 0x4800 24A0      |
| CONTROL_DPF_REGI_ON4_GPMC_FW_ADDRESS_MATCH | RW   | 32                    | 0x0000 0234    | 0x4800 24A4      |
| CONTROL_DPF_REGI_ON4_GPMC_FW_REQINFO       | RW   | 32                    | 0x0000 0238    | 0x4800 24A8      |
| CONTROL_DPF_REGI_ON4_GPMC_FW_WR            | RW   | 32                    | 0x0000 023C    | 0x4800 24AC      |
| CONTROL_DPF_REGI_ON1_IVA2_FW_ADDRESS_MATCH | RW   | 32                    | 0x0000 0240    | 0x4800 24B0      |
| CONTROL_DPF_REGI_ON1_IVA2_FW_REQINFO       | RW   | 32                    | 0x0000 0244    | 0x4800 24B4      |
| CONTROL_DPF_REGI_ON1_IVA2_FW_WR            | RW   | 32                    | 0x0000 0248    | 0x4800 24B8      |
| CONTROL_PBIAS_LITE                         | RW   | 32                    | 0x0000 02B0    | 0x4800 2520      |
| CONTROL_TEMP_SENSOR                        | RW   | 32                    | 0x0000 02B4    | 0x4800 2524      |
| CONTROL_DPF_MAD2D_FW_ADDR_MATCH            | RW   | 32                    | 0x0000 02C8    | 0x4800 2538      |
| CONTROL_DPF_MAD2D_FW_REQINFO               | RW   | 32                    | 0x0000 02CC    | 0x4800 253C      |
| CONTROL_DPF_MAD2D_FW_WR                    | RW   | 32                    | 0x0000 02D0    | 0x4800 2540      |
| CONTROL_DSS_DPLL_SPREADING_FREQ            | RW   | 32                    | 0x0000 02D4    | 0x4800 2544      |
| CONTROL_CORE_DPLL_SPREADING_FREQ           | RW   | 32                    | 0x0000 02D8    | 0x4800 2548      |

**Table 13-74. GENERAL Register Summary (continued)**

| Register Name                         | Type | Register Width (Bits) | Address Offset | Physical Address |
|---------------------------------------|------|-----------------------|----------------|------------------|
| CONTROL_PER_DPLL_SPREADING_FREQ       | RW   | 32                    | 0x0000 02DC    | 0x4800 254C      |
| CONTROL_USBHOST_DPLL_SPREADING_FRE_EQ | RW   | 32                    | 0x0000 02E0    | 0x4800 2550      |
| CONTROL_AVDAC1                        | RW   | 32                    | 0x0000 02E4    | 0x4800 2554      |
| CONTROL_AVDAC2                        | RW   | 32                    | 0x0000 02E8    | 0x4800 2558      |
| CONTROL_CAMERA_PHY_CTRL               | RW   | 32                    | 0x0000 02F0    | 0x4800 2560      |
| CONTROL_IDCODE                        | R    | 32                    | 0x0030 7F94    | 0x4830 A204      |

[Table 13-75](#) lists the MEM\_WKUP registers.

**Table 13-75. MEM\_WKUP Register Summary**

| Register Name             | Type | Register Width (Bits) | Address Offset  | Physical Address          |
|---------------------------|------|-----------------------|-----------------|---------------------------|
| CONTROL_SAVE_REST_ORE_MEM | RW   | 32                    | 0x0600 - 0x09FC | 0x4800 2600 - 0x4800 29FC |

[Table 13-76](#) lists the PADCONFS\_WKUP registers.

**Table 13-76. PADCONFS\_WKUP Register Summary**

| Register Name                        | Type | Register Width (Bits) | Address Offset | Physical Address |
|--------------------------------------|------|-----------------------|----------------|------------------|
| CONTROL_PADCONF_WKUP_I2C4_SCL        | RW   | 32                    | 0x0000 0000    | 0x4800 2A00      |
| CONTROL_PADCONF_WKUP_SYS_32K         | RW   | 32                    | 0x0000 0004    | 0x4800 2A04      |
| CONTROL_PADCONF_WKUP_SYS_NRESWARM    | RW   | 32                    | 0x0000 0008    | 0x4800 2A08      |
| CONTROL_PADCONF_WKUP_SYS_BOOT1       | RW   | 32                    | 0x0000 000C    | 0x4800 2A0C      |
| CONTROL_PADCONF_WKUP_SYS_BOOT3       | RW   | 32                    | 0x0000 0010    | 0x4800 2A10      |
| CONTROL_PADCONF_WKUP_SYS_BOOT5       | RW   | 32                    | 0x0000 0014    | 0x4800 2A14      |
| CONTROL_PADCONF_WKUP_SYS_OFF_MODE    | RW   | 32                    | 0x0000 0018    | 0x4800 2A18      |
| CONTROL_PADCONF_WKUP_JTAG_NTRST      | RW   | 32                    | 0x0000 001C    | 0x4800 2A1C      |
| CONTROL_PADCONF_WKUP_JTAG_TMS_TMSC   | RW   | 32                    | 0x0000 0020    | 0x4800 2A20      |
| CONTROL_PADCONF_WKUP_JTAG_EMU0       | RW   | 32                    | 0x0000 0024    | 0x4800 2A24      |
| CONTROL_PADCONF_WKUP_CHASSIS_SWAKEUP | RW   | 32                    | 0x0000 004C    | 0x4800 2A4C      |
| CONTROL_PADCONF_WKUP_JTAG_TDO        | RW   | 32                    | 0x0000 0050    | 0x4800 2A50      |
| CONTROL_PADCONF_WKUP_GPIO127         | RW   | 32                    | 0x0000 0054    | 0x4800 2A54      |
| CONTROL_PADCONF_WKUP_GPIO128         | RW   | 32                    | 0x0000 0058    | 0x4800 2A58      |

[Table 13-77](#) lists the GENERAL\_WKUP registers.

**Table 13-77. GENERAL\_WKUP Register Summary**

| Register Name          | Type | Register Width (Bits) | Address Offset | Physical Address |
|------------------------|------|-----------------------|----------------|------------------|
| CONTROL_WKUP_CTR_L     | RW   | 32                    | 0x0000 0000    | 0x4800 2A5C      |
| CONTROL_WKUP_DEB_OBS_0 | RW   | 32                    | 0x0000 000C    | 0x4800 2A68      |
| CONTROL_WKUP_DEB_OBS_1 | RW   | 32                    | 0x0000 0010    | 0x4800 2A6C      |
| CONTROL_WKUP_DEB_OBS_2 | RW   | 32                    | 0x0000 0014    | 0x4800 2A70      |
| CONTROL_WKUP_DEB_OBS_3 | RW   | 32                    | 0x0000 0018    | 0x4800 2A74      |
| CONTROL_WKUP_DEB_OBS_4 | RW   | 32                    | 0x0000 001C    | 0x4800 2A78      |
| CONTROL_PROG_IO_WKUP1  | RW   | 32                    | 0x0000 0024    | 0x4800 2A80      |
| CONTROL_BGAPTS_WKUP    | RW   | 32                    | 0x0000 0028    | 0x4800 2A84      |
| CONTROL_SRAM_LDO_CTRL  | RW   | 32                    | 0x0000 002C    | 0x4800 2A88      |
| RESERVED               | R    | 32                    | 0x0000 0030    | 0x4800 2A8C      |
| CONTROL_VBBLDO_SW_CTRL | RW   | 32                    | 0x0000 0034    | 0x4800 2A90      |

### 13.6.3 SCM Register Description

#### 13.6.3.1 INTERFACE Register Description

[Table 13-78](#) through [Table 13-80](#) describe the interface register bits.

**Table 13-78. CONTROL\_REVISION**

|                  |                                |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|--------------------------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x00                           |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical address | 0x4800 2000                    | Instance |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | Control module Revision number |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | R                              |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |          |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|----------|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | REVISION |   |   |   |

| Bits | Field Name | Description               | Type | Reset              |
|------|------------|---------------------------|------|--------------------|
| 31:8 | RESERVED   | Read returns reset value. | R    | 0x000000           |
| 7:0  | REVISION   | Revision number           | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 13-79. Register Call Summary for Register CONTROL\_REVISION**

- SCM Register Manual
- [SCM Register Summary: \[0\]](#)

**Table 13-80. CONTROL\_SYSCONFIG**

|                         |                                                                        |                         |                 |                 |           |
|-------------------------|------------------------------------------------------------------------|-------------------------|-----------------|-----------------|-----------|
| <b>Address Offset</b>   | 0x10                                                                   | <b>Physical address</b> | 0x4800 2010     | <b>Instance</b> | INTERFACE |
| <b>Description</b>      | Set various parameters relative to the Idle mode of the Control module |                         |                 |                 |           |
| <b>Type</b>             | RW                                                                     |                         |                 |                 |           |
| 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 |                 |           |
|                         |                                                                        |                         |                 |                 |           |
| RESERVED                |                                                                        |                         |                 |                 | IDLEMODE  |
|                         |                                                                        |                         |                 |                 | ENAWAKEUP |
|                         |                                                                        |                         |                 |                 | SOFTRESET |
|                         |                                                                        |                         |                 |                 | AUTOIDLE  |

  

| Bits | Field Name | Description                                                                                          | Type | Reset     |
|------|------------|------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | RESERVED   | Read returns reset value.                                                                            | R    | 0x0000000 |
| 4:3  | IDLEMODE   | Power Management, req/ack control                                                                    | R/W  | 0x0       |
|      | 0x0:       | Force-idle. An idle request is acknowledged unconditionally                                          |      |           |
|      | 0x1:       | Reserved                                                                                             |      |           |
|      | 0x2:       | Smart-idle. Acknowledgement to an idle request is given based on the internal activity of the module |      |           |
|      | 0x3:       | Reserved                                                                                             |      |           |
| 2    | ENAWAKEUP  | Wake-up enable. Not used in the module                                                               | R    | 0x0       |
| 1    | SOFTRESET  | Software reset. Not used in the module                                                               | R    | 0x0       |
| 0    | AUTOIDLE   | Internal interface clock gating strategy                                                             | R/W  | 0x1       |
|      | 0x0:       | Interface clock is free-running                                                                      |      |           |
|      | 0x1:       | Automatic interface clock gating strategy is applied, based on the interconnect interface activity   |      |           |

**Table 13-81. Register Call Summary for Register CONTROL\_SYSCONFIG**

## SCM Integration

- Resets: [0]
- System Power Management: [1] [2] [3]
- Module Power Saving: [4]

## SCM Programming Model

- Off Mode Preliminary Settings: [5]

## SCM Register Manual

- SCM Register Summary: [6]

**13.6.3.2 PADCONFS Register Description**

Each 32-bit PADCONF register gathers the configuration of two pads. For example, CONTROL.CONTROL\_PADCONF\_GPMC\_7 is used to configure gpmc\_7 pad (bits [15:0]) and gpmc\_8 pad (bits [31:16]). See [Figure 13-8](#) for more information about PADCONFS registers.

According to the pad type, some features are configurable or not. [Table 13-82](#) gives the description of a fully configurable pad.

**Table 13-82. CONTROL\_PADCONF\_X**

|                              |                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------------------|--------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>        | 0x0000 0000 - 0x0000 05C8            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical base address</b> | 0x4800 2030 <b>Instance</b> PADCONFS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>           | Pad configuration register           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                  | RW                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|--------------|---------------|--------------------|------------------|--------------|---------------|--------------|----------|-----------------|---------------|----------|--------------|---------------|--------------------|------------------|--------------|---------------|--------------|----------|-----------------|---------------|----------|---|---|---|---|---|---|---|---|---|---|
| WAKEUPEVENT1 | WAKEUPENABLE1 | OFFPULLTYPESELECT1 | OFFPULLUDENABLE1 | OFFOUTVALUE1 | OFFOUTENABLE1 | INPUTENABLE1 | RESERVED | PULLTYPESELECT1 | PULLUDENABLE1 | MUXMODE1 | WAKEUPEVENT0 | WAKEUPENABLE0 | OFFPULLTYPESELECT0 | OFFPULLUDENABLE0 | OFFOUTVALUE0 | OFFOUTENABLE0 | INPUTENABLE0 | RESERVED | PULLTYPESELECT0 | PULLUDENABLE0 | MUXMODE0 |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name                         | Description                                                                                                                                          | Type | Reset         |
|-------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------|
| 31    | WAKEUPEVENT1<br>See <sup>(1)</sup> | Pad_x wake-up event status latched in the I/O:<br>0: No wake-up event occurred<br>1: A wake-up event occurred                                        | R    | 0             |
| 30    | WAKEUPENABLE1                      | Input pad wake-up enable (and OFF mode input enable value) for pad_x:<br>0: Wake-up detection on is disabled.<br>1: Wake-up detection on is enabled. | R/W  | 0             |
| 29    | OFFPULLTYPESELECT1                 | Off mode PullUp/Down selection for pad_x:<br>0: PullDown selected<br>1: PullUp selected                                                              | R/W  | 0             |
| 28    | OFFPULLUDENABLE1                   | Off mode PullUp/Down enable for pad_x:<br>0: PullUp/Down disabled<br>1: PullUp/Down enabled                                                          | R/W  | 0             |
| 27    | OFFOUTVALUE1                       | Off mode pad_x output value                                                                                                                          | R/W  | 0             |
| 26    | OFFOUTENABLE1                      | Off mode pad_x output enable value: (Warning: This is an active low signal.)<br>0: Output enabled<br>1: Output disabled                              | R/W  | 0             |
| 25    | OFFENABLE1                         | Off mode pad_x state override control:<br>0: Off mode disabled<br>1: Off mode enabled                                                                | R/W  | 0             |
| 24    | INPUTENABLE1                       | Input enable value for pad_x                                                                                                                         | R/W  | 1             |
| 23:21 | RESERVED                           | Reserved                                                                                                                                             | R    | 0             |
| 20    | PULLTYPESELECT1                    | PullUp/Down selection for pad_x:<br>0: PullDown selected<br>1: PullUp selected                                                                       | R/W  | Pad dependent |
| 19    | PULLUDENABLE1                      | PullUp/Down enable for pad_x:<br>0: PullUp/Down disabled<br>1: PullUp/Down enabled                                                                   | R/W  | Pad dependent |
| 18:16 | MUXMODE1                           | Functional multiplexing selection for pad_x                                                                                                          | R/W  | Pad dependent |
| 15    | WAKEUPEVENT0<br>See <sup>(1)</sup> | Pad_y wake-up event status latched in the I/O:<br>0: No wake-up event occurred<br>1: A wake-up event occurred                                        | R    | Pad dependent |
| 14    | WAKEUPENABLE0                      | Input pad wake-up enable (and OFF mode input enable value) for pad_y:<br>0: Wake-up detection on is disabled.<br>1: Wake-up detection on is enabled. | R/W  | 0             |
| 13    | OFFPULLTYPESELECT0                 | Off mode PullUp/Down selection for pad_y:<br>0: PullDown selected<br>1: PullUp selected                                                              | R/W  | 0             |

<sup>(1)</sup> The WAKEUPEVENT1 of the CAM\_D0 register is swapped with the WAKEUPEVENT0 of CAM\_D1.

| Bits | Field Name       | Description                                                                                                                  | Type | Reset         |
|------|------------------|------------------------------------------------------------------------------------------------------------------------------|------|---------------|
| 12   | OFFPULLUDENABLE0 | Off mode PullUp/Down enable for pad_y:<br>0: PullUp/Down disabled<br>1: PullUp/Down enabled                                  | R/W  | 0             |
| 11   | OFFOUTVALUE0     | Off mode pad_y output value                                                                                                  | R/W  | 0             |
| 10   | OFFOUTENABLE0    | Off mode pad_y output enable value: (Warning: This is an active low signal.)<br>0: Off mode enabled.<br>1: Off mode disabled | R/W  | 0             |
| 9    | OFFENABLE0       | Off mode pad_y state override control:<br>0: Off mode disabled.<br>1: Off mode enabled                                       | R/W  | 0             |
| 8    | INPUTENABLE0     | Input enable value for pad_y                                                                                                 | R/W  | 1             |
| 7:5  | RESERVED         | Reserved                                                                                                                     | R    | 0             |
| 4    | PULLTYPESELECT0  | PullUp/Down selection for pad_y:<br>0: PullDown selected<br>1: PullUp selected                                               | R/W  | Pad dependent |
| 3    | PULLUDENABLE0    | PullUp/Down enable for pad_y:<br>0: PullUp/Down disabled<br>1: PullUp/Down enabled                                           | R/W  | Pad dependent |
| 2:0  | MUXMODE0         | Functional multiplexing selection for pad_y                                                                                  | R/W  | Pad dependent |

**Table 13-83. Register Call Summary for Register CONTROL\_PADCONF\_X**

## SCM Programming Model

- I/O Power Optimization Guidelines: [0] [1]

**CAUTION**

The OFFOUTENABLE and OFFOUTVALUE bits are functional only if the pad configuration supports output mode on at least one MUXMODE. For a pad that supports only the input feature, the OFFOUTENABLE and OFFOUTVALUE bits cannot be configured (they are don't care and read always returns 0).

---

**NOTE:** The bit field gives the field number for the pairs of pads gathered in each register.

---

Table 13-84 describes the reset values, the capabilities, and the corresponding register for each pad.

---

**NOTE:**

- In the following table, a dash (-) indicates that the field is hardwired to logic 0. No corresponding control block ports are implemented for these bits.
  - Reset values of fields MuxMode and PU/PD vary for different pads. Hence the reset values of these bit fields are shown in Table 13-84, wherever supported.
- 

**CAUTION**

During booting process, Device Boot ROM code alters the padconfiguration bitfields, depending on the targeted booting interface or memory. The Boot Code does not restore the initial padconf reset values at the end of the booting procedure.

**Table 13-84. CONTROL\_PADCONF\_CAPABILITIES**

| REGISTER NAME                   | Pad name | Physical address | WakeUpx | Off Mode | Input Enable | Reserved | PU/PD | MuxMode |
|---------------------------------|----------|------------------|---------|----------|--------------|----------|-------|---------|
| CONTROL_PADCONF_SDRC_D0[15:0]   | sdrc_d0  | 0x48002030       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D0[31:16]  | sdrc_d1  | 0x48002030       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D2[15:0]   | sdrc_d2  | 0x48002034       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D2[31:16]  | sdrc_d3  | 0x48002034       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D4[15:0]   | sdrc_d4  | 0x48002038       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D4[31:16]  | sdrc_d5  | 0x48002038       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D6[15:0]   | sdrc_d6  | 0x4800203C       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D6[31:16]  | sdrc_d7  | 0x4800203C       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D8[15:0]   | sdrc_d8  | 0x48002040       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D8[31:16]  | sdrc_d9  | 0x48002040       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D10[15:0]  | sdrc_d10 | 0x48002044       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D10[31:16] | sdrc_d11 | 0x48002044       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D12[15:0]  | sdrc_d12 | 0x48002048       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D12[31:16] | sdrc_d13 | 0x48002048       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D14[15:0]  | sdrc_d14 | 0x4800204C       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D14[31:16] | sdrc_d15 | 0x4800204C       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D16[15:0]  | sdrc_d16 | 0x48002050       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D16[31:16] | sdrc_d17 | 0x48002050       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D18[15:0]  | sdrc_d18 | 0x48002054       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D18[31:16] | sdrc_d19 | 0x48002054       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D20[15:0]  | sdrc_d20 | 0x48002058       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D20[31:16] | sdrc_d21 | 0x48002058       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D22[15:0]  | sdrc_d22 | 0x4800205C       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D22[31:16] | sdrc_d23 | 0x4800205C       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D24[15:0]  | sdrc_d24 | 0x48002060       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D24[31:16] | sdrc_d25 | 0x48002060       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D26[15:0]  | sdrc_d26 | 0x48002064       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D26[31:16] | sdrc_d27 | 0x48002064       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D28[15:0]  | sdrc_d28 | 0x48002068       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D28[31:16] | sdrc_d29 | 0x48002068       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D30[15:0]  | sdrc_d30 | 0x4800206C       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_D30[31:16] | sdrc_d31 | 0x4800206C       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_CLK[15:0]  | sdrc_clk | 0x48002070       | --      | ----     | 0b1          | 0b000    | 0b00  | ---     |

**Table 13-84. CONTROL\_PADCONF\_CAPABILITIES (continued)**

| REGISTER NAME                    | Pad name  | Physical address | WakeUpx | Off Mode | Input Enable | Reserved | PU/PD | MuxMode |
|----------------------------------|-----------|------------------|---------|----------|--------------|----------|-------|---------|
| CONTROL_PADCONF_SDRC_CLK[31:16]  | sdrc_dqs0 | 0x48002070       | --      | -----    | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_DQS1[15:0]  | sdrc_dqs1 | 0x48002074       | --      | -----    | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_DQS1[31:16] | sdrc_dqs2 | 0x48002074       | --      | -----    | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_DQS3[15:0]  | sdrc_dqs3 | 0x48002078       | --      | -----    | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_DQS3[31:16] | gpmc_a1   | 0x48002078       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_GPMC_A2[15:0]    | gpmc_a2   | 0x4800207C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_GPMC_A2[31:16]   | gpmc_a3   | 0x4800207C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_GPMC_A4[15:0]    | gpmc_a4   | 0x48002080       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_GPMC_A4[31:16]   | gpmc_a5   | 0x48002080       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_GPMC_A6[15:0]    | gpmc_a6   | 0x48002084       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_GPMC_A6[31:16]   | gpmc_a7   | 0x48002084       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_GPMC_A8[15:0]    | gpmc_a8   | 0x48002088       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_GPMC_A8[31:16]   | gpmc_a9   | 0x48002088       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_GPMC_A10[15:0]   | gpmc_a10  | 0x4800208C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_GPMC_A10[31:16]  | gpmc_d0   | 0x4800208C       | --      | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_GPMC_D1[15:0]    | gpmc_d1   | 0x48002090       | --      | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_GPMC_D1[31:16]   | gpmc_d2   | 0x48002090       | --      | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_GPMC_D3[15:0]    | gpmc_d3   | 0x48002094       | --      | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_GPMC_D3[31:16]   | gpmc_d4   | 0x48002094       | --      | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_GPMC_D5[15:0]    | gpmc_d5   | 0x48002098       | --      | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_GPMC_D5[31:16]   | gpmc_d6   | 0x48002098       | --      | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_GPMC_D7[15:0]    | gpmc_d7   | 0x4800209C       | --      | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_GPMC_D7[31:16]   | gpmc_d8   | 0x4800209C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_GPMC_D9[15:0]    | gpmc_d9   | 0x480020A0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_GPMC_D9[31:16]   | gpmc_d10  | 0x480020A0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_GPMC_D11[15:0]   | gpmc_d11  | 0x480020A4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_GPMC_D11[31:16]  | gpmc_d12  | 0x480020A4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_GPMC_D13[15:0]   | gpmc_d13  | 0x480020A8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_GPMC_D13[31:16]  | gpmc_d14  | 0x480020A8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_GPMC_D15[15:0]   | gpmc_d15  | 0x480020AC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_GPMC_D15[31:16]  | gpmc_ncs0 | 0x480020AC       | --      | 0b00000  | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_GPMC_NCS1[15:0]  | gpmc_ncs1 | 0x480020B0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_GPMC_NCS1[31:16] | gpmc_ncs2 | 0x480020B0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |

**Table 13-84. CONTROL\_PADCONF\_CAPABILITIES (continued)**

| REGISTER NAME                        | Pad name      | Physical address | WakeUpx | Off Mode | Input Enable | Reserved | PU/PD | MuxMode |
|--------------------------------------|---------------|------------------|---------|----------|--------------|----------|-------|---------|
| CONTROL_PADCONF_GPMC_NCS3[15:0]      | gpmc_ncs3     | 0x480020B4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_GPMC_NCS3[31:16]     | gpmc_ncs4     | 0x480020B4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_GPMC_NCS5[15:0]      | gpmc_ncs5     | 0x480020B8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_GPMC_NCS51:16]       | gpmc_ncs6     | 0x480020B8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_GPMC_NCS7[15:0]      | gpmc_ncs7     | 0x480020BC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_GPMC_NCS7[31:16]     | gpmc_clk      | 0x480020BC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_GPMC_NADV_ALE[15:0]  | gpmc_nadv_ale | 0x480020C0       | --      | 0b00000  | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_GPMC_NADV_ALE[31:16] | gpmc_noe      | 0x480020C0       | --      | 0b00000  | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_GPMC_NWE[15:0]       | gpmc_nwe      | 0x480020C4       | --      | 0b00000  | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_GPMC_NWE[31:16]      | gpmc_nbe0_cle | 0x480020C4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_GPMC_NBE1[15:0]      | gpmc_nbe1     | 0x480020C8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_GPMC_NBE1[31:16]     | gpmc_nwp      | 0x480020C8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_GPMC_WAIT0[15:0]     | gpmc_wait0    | 0x480020CC       | --      | 0b00--0  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_GPMC_WAIT0[31:16]    | gpmc_wait1    | 0x480020CC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_GPMC_WAIT2[15:0]     | gpmc_wait2    | 0x480020D0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_GPMC_WAIT2[31:16]    | gpmc_wait3    | 0x480020D0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_DSS_PCLK[15:0]       | dss_pclk      | 0x480020D4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_DSS_PCLK[31:16]      | dss_hsync     | 0x480020D4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_DSS_VSYNC[15:0]      | dss_vsync     | 0x480020D8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_DSS_VSYNC[31:16]     | dss_acbias    | 0x480020D8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA0[15:0]      | dss_data0     | 0x480020DC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA0[31:16]     | dss_data1     | 0x480020DC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA2[15:0]      | dss_data2     | 0x480020E0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA2[31:16]     | dss_data3     | 0x480020E0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA4[15:0]      | dss_data4     | 0x480020E4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA4[31:16]     | dss_data5     | 0x480020E4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA6[15:0]      | dss_data6     | 0x480020E8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA6[31:16]     | dss_data7     | 0x480020E8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA8[15:0]      | dss_data8     | 0x480020EC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA8[31:16]     | dss_data9     | 0x480020EC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA10[15:0]     | dss_data10    | 0x480020F0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA10[31:16]    | dss_data11    | 0x480020F0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA12[15:0]     | dss_data12    | 0x480020F4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |

**Table 13-84. CONTROL\_PADCONF\_CAPABILITIES (continued)**

| REGISTER NAME                     | Pad name   | Physical address | WakeUpx | Off Mode | Input Enable | Reserved | PU/PD | MuxMode |
|-----------------------------------|------------|------------------|---------|----------|--------------|----------|-------|---------|
| CONTROL_PADCONF_DSS_DATA12[31:16] | dss_data13 | 0x480020F4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA14[15:0]  | dss_data14 | 0x480020F8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA14[31:16] | dss_data15 | 0x480020F8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA16[15:0]  | dss_data16 | 0x480020FC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA16[31:16] | dss_data17 | 0x480020FC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA18[15:0]  | dss_data18 | 0x48002100       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA18[31:16] | dss_data19 | 0x48002100       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA20[15:0]  | dss_data20 | 0x48002104       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_DSS_DATA20[31:16] | dss_data21 | 0x48002104       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA22[15:0]  | dss_data22 | 0x48002108       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_DSS_DATA22[31:16] | dss_data23 | 0x48002108       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_HS[15:0]      | cam_hs     | 0x4800210C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_HS[31:16]     | cam_vs     | 0x4800210C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_XCLKA[15:0]   | cam_xclka  | 0x48002110       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_XCLKA[31:16]  | cam_pclk   | 0x48002110       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_FLD[15:0]     | cam_fld    | 0x48002114       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_FLD[31:16]    | cam_d0     | 0x48002114       | 0b00    | 0b00--0  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_D1[15:0]      | cam_d1     | 0x48002118       | 0b00    | 0b00--0  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_D1[31:16]     | cam_d2     | 0x48002118       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_D3[15:0]      | cam_d3     | 0x4800211C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_D3[31:16]     | cam_d4     | 0x4800211C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_D5[15:0]      | cam_d5     | 0x48002120       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_D5[31:16]     | cam_d6     | 0x48002120       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_D7[15:0]      | cam_d7     | 0x48002124       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_D7[31:16]     | cam_d8     | 0x48002124       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_D9[15:0]      | cam_d9     | 0x48002128       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_D9[31:16]     | cam_d10    | 0x48002128       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_D11[15:0]     | cam_d11    | 0x4800212C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_D11[31:16]    | cam_xclkb  | 0x4800212C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_WEN[15:0]     | cam_wen    | 0x48002130       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CAM_WEN[31:16]    | cam_strobe | 0x48002130       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CSI2_RX0[15:0]    | csi2_rx0   | 0x48002134       | 0b00    | 0b00--0  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CSI2_RX0[31:16]   | csi2_dx0   | 0x48002134       | 0b00    | 0b00--0  | 0b1          | 0b000    | 0b01  | 0b111   |

**Table 13-84. CONTROL\_PADCONF\_CAPABILITIES (continued)**

| REGISTER NAME                      | Pad name    | Physical address | WakeUpx | Off Mode | Input Enable | Reserved | PU/PD | MuxMode |
|------------------------------------|-------------|------------------|---------|----------|--------------|----------|-------|---------|
| CONTROL_PADCONF_CSI2_DX1[15:0]     | csi2_dx1    | 0x48002138       | 0b00    | 0b00--0  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_CSI2_RX1[31:16]    | csi2_dy1    | 0x48002138       | 0b00    | 0b00--0  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP2_FSX[15:0]   | mcbsp2_fsx  | 0x4800213C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP2_FSX[31:16]  | mcbsp2_clkx | 0x4800213C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP2_DR[15:0]    | mcbsp2_dr   | 0x48002140       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP2_DR[31:16]   | mcbsp2_dx   | 0x48002140       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MMCI_CLK[15:0]     | sdmmc1_clk  | 0x48002144       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MMCI_CLK[31:16]    | sdmmc1_cmd  | 0x48002144       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MMCI_DAT0[15:0]    | sdmmc1_dat0 | 0x48002148       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MMCI_DAT0[31:16]   | sdmmc1_dat1 | 0x48002148       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MMCI_DAT2[15:0]    | sdmmc1_dat2 | 0x4800214C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MMCI_DAT2[31:16]   | sdmmc1_dat3 | 0x4800214C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MMCI_CLK[15:0]     | sdmmc2_clk  | 0x48002158       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MMCI_CLK[31:16]    | sdmmc2_cmd  | 0x48002158       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_MMCI_DAT0[15:0]    | sdmmc2_dat0 | 0x4800215C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_MMCI_DAT0[31:16]   | sdmmc2_dat1 | 0x4800215C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_MMCI_DAT2[15:0]    | sdmmc2_dat2 | 0x48002160       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_MMCI_DAT2[31:16]   | sdmmc2_dat3 | 0x48002160       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_MMCI_DAT4[15:0]    | sdmmc2_dat4 | 0x48002164       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MMCI_DAT4[31:16]   | sdmmc2_dat5 | 0x48002164       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MMCI_DAT6[15:0]    | sdmmc2_dat6 | 0x48002168       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MMCI_DAT6[31:16]   | sdmmc2_dat7 | 0x48002168       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP3_RX[15:0]    | mcbsp3_dx   | 0x4800216C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP3_RX[31:16]   | mcbsp3_dr   | 0x4800216C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP3_CLKX[15:0]  | mcbsp3_clkx | 0x48002170       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP3_CLKX[31:16] | mcbsp3_fsx  | 0x48002170       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_UART2_CTS[15:0]    | uart2_cts   | 0x48002174       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_UART2_CTS[31:16]   | uart2_rts   | 0x48002174       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_UART2_TX[15:0]     | uart2_tx    | 0x48002178       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_UART2_RX[31:16]    | uart2_rx    | 0x48002178       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_UART1_TX[15:0]     | uart1_tx    | 0x4800217C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_UART1_RX[31:16]    | uart1_rts   | 0x4800217C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_UART1_CTS[15:0]    | uart1_cts   | 0x48002180       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |

**Table 13-84. CONTROL\_PADCONF\_CAPABILITIES (continued)**

| REGISTER NAME                        | Pad name       | Physical address | WakeUpx | Off Mode | Input Enable | Reserved | PU/PD | MuxMode |
|--------------------------------------|----------------|------------------|---------|----------|--------------|----------|-------|---------|
| CONTROL_PADCONF_UART1_CTS[31:16]     | uart1_rx       | 0x48002180       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP4_CLKX[15:0]    | mcbsp4_clkx    | 0x48002184       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP4_CLKX[31:16]   | mcbsp4_dr      | 0x48002184       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP4_RX[15:0]      | mcbsp4_dx      | 0x48002188       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP4_RX[31:16]     | mcbsp4_fsx     | 0x48002188       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP1_CLKR[15:0]    | mcbsp1_clkr    | 0x4800218C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP1_CLKR[31:16]   | mcbsp1_fsr     | 0x4800218C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP1_RX[15:0]      | mcbsp1_dx      | 0x48002190       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP1_RX[31:16]     | mcbsp1_dr      | 0x48002190       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP_CLKS[15:0]     | mcbsp_clks     | 0x48002194       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP_CLKS[31:16]    | mcbsp1_fsx     | 0x48002194       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP1_CLKX[15:0]    | mcbsp1_clkx    | 0x48002198       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCBSP1_CLKX[31:16]   | uart3_cts_rctx | 0x48002198       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_UART3 RTS_SD[15:0]   | uart3_rts_sd   | 0x4800219C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_UART3 RTS_SD[31:16]  | uart3_rx_irrx  | 0x4800219C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_UART3 TX_IRTX[15:0]  | uart3_tx_irtx  | 0x480021A0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_UART3 TX_IRTX[31:16] | hsusb0_clk     | 0x480021A0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_HSUSB0_STP[15:0]     | hsusb0_stp     | 0x480021A4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_HSUSB0_STP[31:16]    | hsusb0_dir     | 0x480021A4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_HSUSB0_NXT[15:0]     | hsusb0_nxt     | 0x480021A8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_HSUSB0_NXT[31:16]    | hsusb0_data0   | 0x480021A8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_HSUSB0_DATA1[15:0]   | hsusb0_data1   | 0x480021AC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_HSUSB0_DATA1[31:16]  | hsusb0_data2   | 0x480021AC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_HSUSB0_DATA3[15:0]   | hsusb0_data3   | 0x480021B0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_HSUSB0_DATA3[31:16]  | hsusb0_data4   | 0x480021B0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_HSUSB0_DATA5[15:0]   | hsusb0_data5   | 0x480021B4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_HSUSB0_DATA5[31:16]  | hsusb0_data6   | 0x480021B4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_HSUSB0_DATA7[15:0]   | hsusb0_data7   | 0x480021B8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_HSUSB0_DATA7[31:16]  | i2c1_scl       | 0x480021B8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_I2C1_SDA[15:0]       | i2c1_sda       | 0x480021BC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_I2C1_SDA[31:16]      | i2c2_scl       | 0x480021BC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_I2C2_SDA[15:0]       | i2c2_sda       | 0x480021C0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_I2C2_SDA[31:16]      | i2c3_scl       | 0x480021C0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |

**Table 13-84. CONTROL\_PADCONF\_CAPABILITIES (continued)**

| REGISTER NAME                       | Pad name     | Physical address | WakeUpx | Off Mode | Input Enable | Reserved | PU/PD | MuxMode |
|-------------------------------------|--------------|------------------|---------|----------|--------------|----------|-------|---------|
| CONTROL_PADCONF_I2C3_SDA[15:0]      | i2c3_sda     | 0x480021C4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_I2C3_SDA[31:16]     | hdq_sio      | 0x480021C4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_MCSPI1_CLK[15:0]    | mcspi1_clk   | 0x480021C8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCSPI1_CLK[31:16]   | mcspi1_simo  | 0x480021C8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCSPI1_SOMI[15:0]   | mcspi1_somi  | 0x480021CC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCSPI1_SOMI[31:16]  | mcspi1_cs0   | 0x480021CC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_MCSPI1_CS1[15:0]    | mcspi1_cs1   | 0x480021D0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_MCSPI1_CS1[31:16]   | mcspi1_cs2   | 0x480021D0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_MCSPI1_CS3[15:0]    | mcspi1_cs3   | 0x480021D4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_MCSPI1_CS3[31:16]   | mcspi2_clk   | 0x480021D4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCSPI2_SIMO[15:0]   | mcspi2_simo  | 0x480021D8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCSPI2_SIMO[31:16]  | mcspi2_somi  | 0x480021D8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_MCSPI2_CS0[15:0]    | mcspi2_cs0   | 0x480021DC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_MCSPI2_CS0[31:16]   | mcspi2_cs1   | 0x480021DC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_SYS_NIRQ[15:0]      | sys_nirq     | 0x480021E0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b111   |
| CONTROL_PADCONF_SYS_NIRQ[31:16]     | sys_clkout2  | 0x480021E0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_SAD2D_MCAD0[15:0]   | sad2d_mcad0  | 0x480021E4       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD0[31:16]  | sad2d_mcad1  | 0x480021E4       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD2[15:0]   | sad2d_mcad2  | 0x480021E8       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD2[31:16]  | sad2d_mcad3  | 0x480021E8       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD4[15:0]   | sad2d_mcad4  | 0x480021EC       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD4[31:16]  | sad2d_mcad5  | 0x480021EC       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD6[15:0]   | sad2d_mcad6  | 0x480021F0       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD6[31:16]  | sad2d_mcad7  | 0x480021F0       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD8[15:0]   | sad2d_mcad8  | 0x480021F4       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD8[31:16]  | sad2d_mcad9  | 0x480021F4       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD10[15:0]  | sad2d_mcad10 | 0x480021F8       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD10[31:16] | sad2d_mcad11 | 0x480021F8       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD12[15:0]  | sad2d_mcad12 | 0x480021FC       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD12[31:16] | sad2d_mcad13 | 0x480021FC       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD14[15:0]  | sad2d_mcad14 | 0x48002200       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD14[31:16] | sad2d_mcad15 | 0x48002200       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD16[15:0]  | sad2d_mcad16 | 0x48002204       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |

**Table 13-84. CONTROL\_PADCONF\_CAPABILITIES (continued)**

| REGISTER NAME                          | Pad name           | Physical address | WakeUpx | Off Mode | Input Enable | Reserved | PU/PD | MuxMode |
|----------------------------------------|--------------------|------------------|---------|----------|--------------|----------|-------|---------|
| CONTROL_PADCONF_SAD2D_MCAD16[31:16]    | sad2d_mcad17       | 0x48002204       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD18[15:0]     | sad2d_mcad18       | 0x48002208       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD18[31:16]    | sad2d_mcad19       | 0x48002208       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD20[15:0]     | sad2d_mcad20       | 0x4800220C       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD20[31:16]    | sad2d_mcad21       | 0x4800220C       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD22[15:0]     | sad2d_mcad22       | 0x48002210       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD22[31:16]    | sad2d_mcad23       | 0x48002210       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD24[15:0]     | sad2d_mcad24       | 0x48002214       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD24[31:16]    | sad2d_mcad25       | 0x48002214       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD26[15:0]     | sad2d_mcad26       | 0x48002218       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD26[31:16]    | sad2d_mcad27       | 0x48002218       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD28[15:0]     | sad2d_mcad28       | 0x4800221C       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD28[31:16]    | sad2d_mcad29       | 0x4800221C       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD30[15:0]     | sad2d_mcad30       | 0x48002220       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD30[31:16]    | sad2d_mcad31       | 0x48002220       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD32[15:0]     | sad2d_mcad32       | 0x48002224       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD32[31:16]    | sad2d_mcad33       | 0x48002224       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD34[15:0]     | sad2d_mcad34       | 0x48002228       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD34[31:16]    | sad2d_mcad35       | 0x48002228       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD36[15:0]     | sad2d_mcad36       | 0x4800222C       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_MCAD36[31:16]    | chassis_clk26mi    | 0x4800222C       | --      | 0b00000  | -            | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_NRESPWRON[15:0]  | chassis_nrespwr_on | 0x48002230       | --      | 0b--000  | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SAD2D_NRESPWRON[31:16] | chassis_nreswar_m  | 0x48002230       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_SAD2D_ARMNIRQ[15:0]    | chassis_nirq       | 0x48002234       | --      | 0b00000  | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SAD2D_ARMNIRQ[31:16]   | chassis_fiq        | 0x48002234       | --      | 0b00000  | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SAD2D_SPINT[15:0]      | chassis_armirq     | 0x48002238       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_SPINT[31:16]     | chassis_ivairq     | 0x48002238       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_DMAREQ0[15:0]    | chassis_dmareq_0   | 0x4800223C       | --      | 0b00000  | -            | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SAD2D_DMAREQ0[31:16]   | chassis_dmareq_1   | 0x4800223C       | --      | 0b00000  | -            | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SAD2D_DMAREQ2[15:0]    | chassis_dmareq_2   | 0x48002240       | --      | 0b00000  | -            | 0b000    | 0b00  | 0b000   |

**Table 13-84. CONTROL\_PADCONF\_CAPABILITIES (continued)**

| REGISTER NAME                        | Pad name        | Physical address | WakeUpx | Off Mode | Input Enable | Reserved | PU/PD | MuxMode |
|--------------------------------------|-----------------|------------------|---------|----------|--------------|----------|-------|---------|
| CONTROL_PADCONF_SAD2D_DMAREQ2[31:16] | chassis_dmareq3 | 0x48002240       | --      | 0b00000  | -            | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SAD2D_NTRST[15:0]    | chassis_ntrst   | 0x48002244       | --      | 0b00000  | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SAD2D_NTRST[31:16]   | chassis_tdi     | 0x48002244       | --      | 0b00000  | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SAD2D_TDO[15:0]      | chassis_tdo     | 0x48002248       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | ---     |
| CONTROL_PADCONF_SAD2D_TDO[31:16]     | chassis_tms     | 0x48002248       | --      | 0b00000  | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SAD2D_TCK[15:0]      | chassis_tck     | 0x4800224C       | --      | 0b00000  | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SAD2D_TCK[31:16]     | chassis_rtck    | 0x4800224C       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | ---     |
| CONTROL_PADCONF_SAD2D_MSTDBY[15:0]   | chassis_mstdby  | 0x48002250       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_SAD2D_MSTDBY[31:16]  | chassis_idlereq | 0x48002250       | --      | 0b00000  | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SAD2D_IDLEACK[15:0]  | chassis_idleack | 0x48002254       | --      | 0b00000  | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_SAD2D_IDLEACK[31:16] | sad2d_mwrite    | 0x48002254       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_SWRITE[15:0]   | sad2d_swrite    | 0x48002258       | --      | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SAD2D_SWRITE[31:16]  | sad2d_mread     | 0x48002258       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_SREAD[15:0]    | sad2d_sread     | 0x4800225C       | --      | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SAD2D_SREAD[31:16]   | sad2d_mbusflag  | 0x4800225C       | --      | 0b00000  | 0b1          | 0b000    | 0b01  | 0b000   |
| CONTROL_PADCONF_SAD2D_SBUSFLAG[15:0] | sad2d_sbusflag  | 0x48002260       | --      | 0b00000  | -            | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SDRC_SBUSFLAG[31:16] | sdrc_cke0       | 0x48002260       | --      | -----    | -            | 0b000    | 0b00  | 0b111   |
| CONTROL_PADCONF_SDRC_CKE1[15:0]      | sdrc_cke1       | 0x48002264       | --      | -----    | -            | 0b000    | 0b00  | 0b111   |
| CONTROL_PADCONF_SDRC_CKE1[31:16]     | gpmc_a11        | 0x48002264       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_SDRC_BA0[15:0]       | sdrc_ba0        | 0x480025A0       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_BA0[31:16]      | sdrc_ba1        | 0x480025A0       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A0[15:0]        | sdrc_a0         | 0x480025A4       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A0[31:16]       | sdrc_a1         | 0x480025A4       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A2[15:0]        | sdrc_a2         | 0x480025A8       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A2[31:16]       | sdrc_a3         | 0x480025A8       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A4[15:0]        | sdrc_a4         | 0x480025AC       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A4[31:16]       | sdrc_a5         | 0x480025AC       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A6[15:0]        | sdrc_a6         | 0x480025B0       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A6[31:16]       | sdrc_a7         | 0x480025B0       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A8[15:0]        | sdrc_a8         | 0x480025B4       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A8[31:16]       | sdrc_a9         | 0x480025B4       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A10[15:0]       | sdrc_a10        | 0x480025B8       | --      | -----    | -            | 0b000    | 0b00  | ---     |

**Table 13-84. CONTROL\_PADCONF\_CAPABILITIES (continued)**

| REGISTER NAME                    | Pad name  | Physical address | WakeUpx | Off Mode | Input Enable | Reserved | PU/PD | MuxMode |
|----------------------------------|-----------|------------------|---------|----------|--------------|----------|-------|---------|
| CONTROL_PADCONF_SDRC_A10[31:16]  | sdrc_a11  | 0x480025B8       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A12[15:0]   | sdrc_a12  | 0x480025BC       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A12[31:16]  | sdrc_a13  | 0x480025BC       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A14[15:0]   | sdrc_a14  | 0x480025C0       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_A14[31:16]  | sdrc_ncs0 | 0x480025C0       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_NCS1[15:0]  | sdrc_ncs1 | 0x480025C4       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_NCS1[31:16] | sdrc_nclk | 0x480025C4       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_NRAS[15:0]  | sdrc_nras | 0x480025C8       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_NRAS[31:16] | sdrc_ncas | 0x480025C8       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_NWE[15:0]   | sdrc_nwe  | 0x480025CC       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_NWE[31:16]  | sdrc_dm0  | 0x480025CC       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_DM1[15:0]   | sdrc_dm1  | 0x480025D0       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_DM1[31:16]  | sdrc_dm2  | 0x480025D0       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_DM3[15:0]   | sdrc_dm3  | 0x480025D4       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SDRC_DM3[31:16]  | un-used   | 0x480025D4       | --      | -----    | -            | 0b000    | --    | ---     |
| CONTROL_PADCONF_ETK_CLK[15:0]    | etk_clk   | 0x480025D8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b100   |
| CONTROL_PADCONF_ETK_CLK[31:16]   | etk_ctl   | 0x480025D8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b100   |
| CONTROL_PADCONF_ETK_D0[15:0]     | etk_d0    | 0x480025DC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b100   |
| CONTROL_PADCONF_ETK_D0[31:16]    | etk_d1    | 0x480025DC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b100   |
| CONTROL_PADCONF_ETK_D2[15:0]     | etk_d2    | 0x480025E0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b100   |
| CONTROL_PADCONF_ETK_D2[31:16]    | etk_d3    | 0x480025E0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b100   |
| CONTROL_PADCONF_ETK_D4[15:0]     | etk_d4    | 0x480025E4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b100   |
| CONTROL_PADCONF_ETK_D4[31:16]    | etk_d5    | 0x480025E4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b100   |
| CONTROL_PADCONF_ETK_D6[15:0]     | etk_d6    | 0x480025E8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b100   |
| CONTROL_PADCONF_ETK_D6[31:16]    | etk_d7    | 0x480025E8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b100   |
| CONTROL_PADCONF_ETK_D8[15:0]     | etk_d8    | 0x480025EC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b100   |
| CONTROL_PADCONF_ETK_D8[31:16]    | etk_d9    | 0x480025EC       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b100   |
| CONTROL_PADCONF_ETK_D10[15:0]    | etk_d10   | 0x480025F0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b100   |
| CONTROL_PADCONF_ETK_D10[31:16]   | etk_d11   | 0x480025F0       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b100   |
| CONTROL_PADCONF_ETK_D12[15:0]    | etk_d12   | 0x480025F4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b100   |
| CONTROL_PADCONF_ETK_D12[31:16]   | etk_d13   | 0x480025F4       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b100   |
| CONTROL_PADCONF_ETK_D14[15:0]    | etk_d14   | 0x480025F8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b100   |
| CONTROL_PADCONF_ETK_D14[31:16]   | etk_d15   | 0x480025F8       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b100   |



### 13.6.3.3 GENERAL Register Description

Table 13-85 through Table 13-255 describe the GENERAL registers bits.

**Table 13-85. CONTROL\_PADCONF\_OFF**

|                         |                                     |                       |                 |                  |           |                |  |  |  |  |          |         |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------|-----------------------|-----------------|------------------|-----------|----------------|--|--|--|--|----------|---------|--|--|--|--|--|--|--|--|--|
| Address Offset          | 0x0000 0000                         |                       |                 |                  |           |                |  |  |  |  |          |         |  |  |  |  |  |  |  |  |  |
| Physical address        | 0x4800 2270                         |                       |                 |                  |           |                |  |  |  |  | Instance | GENERAL |  |  |  |  |  |  |  |  |  |
| Description             | Off mode pad configuration register |                       |                 |                  |           |                |  |  |  |  |          |         |  |  |  |  |  |  |  |  |  |
| Type                    | RW                                  |                       |                 |                  |           |                |  |  |  |  |          |         |  |  |  |  |  |  |  |  |  |
| 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 | WKUPCTRLCLOCKDIV | STARTSAVE | FORCEOFFMODEEN |  |  |  |  |          |         |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                     |                       |                 |                  |           |                |  |  |  |  |          |         |  |  |  |  |  |  |  |  |  |

| Bits | Field Name       | Description                                                                                                                                                             | Type | Reset     |
|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:3 | RESERVED         | Read returns reset value.                                                                                                                                               | R    | 0x0000000 |
| 2    | WKUPCTRLCLOCKDIV | Wkup_ctrl module clock divider<br>0: Clock is divided by 4<br>1: Clock is divided by 2                                                                                  | R/W  | 0x0       |
| 1    | STARTSAVE        | Start pad configuration registers save mechanism<br><br>0x0: Save is not started.<br><br>0x1: Save is running. This bit is auto-cleared after 8 interface clock cycles. | R/W  | 0x0       |
| 0    | FORCEOFFMODEEN   | Force OFF mode active<br><br>0x0: OFF mode is not forced active.<br><br>0x1: OFF mode is forced active.                                                                 | R/W  | 0x0       |

**Table 13-86. Register Call Summary for Register CONTROL\_PADCONF\_OFF**

SCM Integration

- [Clock: \[0\]](#)
- [Module Power Saving: \[1\]](#)

SCM Functional Description

- [System Off Mode: \[2\]](#)
- [Save-and-Restore Mechanism: \[3\]](#)

SCM Programming Model

- [Off Mode Preliminary Settings: \[4\]](#)

SCM Register Manual

- [SCM Register Summary: \[5\]](#)

**Table 13-87. CONTROL\_DEVCONF0**

|                         |                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0004                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical address</b> | 0x4800 2274                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Static device configuration register-0. Module dedicated functions |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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           |
|-------|-------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------|----------|------------|-------------|-------------|-------------|-------------|
| SPARE | SPARE | SPARE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | MCBSP2_CLKS | RESERVED | MCBSP1_FSR | MCBSP1_CLKR | MCBSP1_CLKS | SENSDMAREQ1 | SENSDMAREQ0 |

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | SPARE       | Spare bits                                                                                                                                                                                                                                                                                                                                  | R/W  | 0x00  |
| 26    | SPARE       | Spare bit                                                                                                                                                                                                                                                                                                                                   | R/W  | 0x1   |
| 25    | SPARE       | Spare bit                                                                                                                                                                                                                                                                                                                                   | R/W  | 0x0   |
| 24:7  | RESERVED    | Read returns reset value                                                                                                                                                                                                                                                                                                                    | R    | 0x000 |
| 6     | MCBSP2_CLKS | Select the CLKS input for the module McBSP2<br><br>Note : There are no external pins McBSP2_CLKR and McBSP2_FSR for the module McBSP2. For this module, CLKR input is from the pin McBSP2_CLKX and FSR input is from the pin McBSP2_FSX<br><br>0x0: CLKS is from the PRCM functional clock<br>0x1: CLKS is from the external pin McBSP_CLKS | R/W  | 0x0   |
| 5     | RESERVED    | Read returns reset value.                                                                                                                                                                                                                                                                                                                   | R    | 0     |
| 4     | MCBSP1_FSR  | Select the FSR input for the module McBSP1<br><br>0x0: FSR is from the pin McBSP1_FSR<br>0x1: FSR is from the pin McBSP1_FSX                                                                                                                                                                                                                | R/W  | 0x0   |
| 3     | MCBSP1_CLKR | Select the CLKR input for the module McBSP1<br><br>0x0: CLKR is from the pin McBSP1_CLKR<br>0x1: CLKR is from the pin McBSP1_CLKX                                                                                                                                                                                                           | R/W  | 0x0   |
| 2     | MCBSP1_CLKS | Select the CLKS input for the module McBSP1<br><br>0x0: CLKS is from the PRCM functional clock<br>0x1: CLKS is from the external pin McBSP_CLKS                                                                                                                                                                                             | R/W  | 0x0   |
| 1     | SENSDMAREQ1 | Set sensitivity on SYS.DMAREQ1 input pin<br><br>0x0: Level sensitivity<br>0x1: Edge sensitivity                                                                                                                                                                                                                                             | R/W  | 0x0   |
| 0     | SENSDMAREQ0 | Set sensitivity on SYS.DMAREQ0 input pin<br><br>0x0: Level sensitivity<br>0x1: Edge sensitivity                                                                                                                                                                                                                                             | R/W  | 0x0   |

**Table 13-88. Register Call Summary for Register CONTROL\_DEVCONF0**
**SCM Functional Description**

- [Static Device Configuration Registers: \[0\]](#)

**SCM Programming Model**

- [McBSP1 Internal Clock: \[1\] \[2\] \[3\]](#)
- [McBSP2 Internal Clock: \[4\]](#)
- [Setting Sensitivity on sys\\_ndmreq\[3:0\] Input Pins: \[5\] \[6\]](#)

**SCM Register Manual**

- [SCM Register Summary: \[7\]](#)

**Table 13-89. CONTROL\_MSUSPENDMUX\_0**

| <b>Address Offset</b>   | 0x0000 0020                                                                    |                                                                    |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------|-----------------|------------|----------|--|--|--|--|--|--|--|--|---------|--|--|-------------|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical address</b> | 0x4800 2290                                                                    | <b>Instance</b>                                                    |                 |            |          |  |  |  |  |  |  |  |  | GENERAL |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | MSuspend Control register: control the use of MSuspend signals at module level |                                                                    |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                             |                                                                    |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                | MCBSP2MSCTRL                                                                   | MCBSP1MSCTRL                                                       | I2C2MSCTRL      | I2C1MSCTRL | RESERVED |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                                     | <b>Description</b>                                                 |                 |            |          |  |  |  |  |  |  |  |  |         |  |  | <b>Type</b> | <b>Reset</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:24                   | RESERVED                                                                       | Read returns reset value.                                          |                 |            |          |  |  |  |  |  |  |  |  |         |  |  | R           | 0x00         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23:21                   | MCBSP2MSCTRL                                                                   | Control McBSP_2 sensitivity to MCU and/or DSP MSuspend signals     |                 |            |          |  |  |  |  |  |  |  |  |         |  |  | RW          | 0x0          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x0: No sensitivity: no MSuspend signal reaches the module         |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)      |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)       |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals  |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x5: No sensitivity: no MSuspend signal reaches the module         |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x6: No sensitivity: no MSuspend signal reaches the module         |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x7: No sensitivity: no MSuspend signal reaches the module         |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20:18                   | MCBSP1MSCTRL                                                                   | Control McBSP_1 sensitivity to MCU and/or DSP MSuspend signals     |                 |            |          |  |  |  |  |  |  |  |  |         |  |  | RW          | 0x0          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x0: No sensitivity: no MSuspend signal reaches the module         |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)      |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)       |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals  |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x5: No sensitivity: no MSuspend signal reaches the module         |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x6: No sensitivity: no MSuspend signal reaches the module         |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                | 0x7: No sensitivity: no MSuspend signal reaches the module         |                 |            |          |  |  |  |  |  |  |  |  |         |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 17:15 | I2C2MSCTRL | Control I2C_2 sensitivity to MCU and/or DSP MSuspend signals<br><br>0x0: No sensitivity: no MSuspend signal reaches the module<br>0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)<br>0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)<br>0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals<br>0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals<br>0x5: No sensitivity: no MSuspend signal reaches the module<br>0x6: No sensitivity: no MSuspend signal reaches the module<br>0x7: No sensitivity: no MSuspend signal reaches the module | RW   | 0x0   |
| 14:12 | I2C1MSCTRL | Control I2C_1 sensitivity to MCU and/or DSP MSuspend signals<br><br>0x0: No sensitivity: no MSuspend signal reaches the module<br>0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)<br>0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)<br>0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals<br>0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals<br>0x5: No sensitivity: no MSuspend signal reaches the module<br>0x6: No sensitivity: no MSuspend signal reaches the module<br>0x7: No sensitivity: no MSuspend signal reaches the module | RW   | 0x0   |
| 11:0  | RESERVED   | Read returns reset value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R    | 0x00  |

**Table 13-90. Register Call Summary for Register CONTROL\_MSUSPENDMUX\_0**
**SCM Functional Description**

- [MPU and/or DSP \(IVA2.2\) MSuspend Configuration Registers: \[0\]](#)

**SCM Register Manual**

- [SCM Register Summary: \[1\]](#)

**Table 13-91. CONTROL\_MSUSPENDMUX\_1**

|                       |                                                                                 |                         |             |                 |         |
|-----------------------|---------------------------------------------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 0024                                                                     | <b>Physical address</b> | 0x4800 2294 | <b>Instance</b> | GENERAL |
| <b>Description</b>    | MSuspend Control register : control the use of MSuspend signals at module level |                         |             |                 |         |
| <b>Type</b>           | RW                                                                              |                         |             |                 |         |

| 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 |
|----------|-------------|-------------|----|-------------|----|-------------|----|-------------|----|-------------|----|-------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----------|---|---|
| RESERVED | GPTM7MSCTRL | GPTM6MSCTRL |    | GPTM5MSCTRL |    | GPTM4MSCTRL |    | GPTM3MSCTRL |    | GPTM2MSCTRL |    | GPTM1MSCTRL |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RESERVED |   |   |

| Bits  | Field Name  | Description                                                                    | Type | Reset |
|-------|-------------|--------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED    | Read returns reset value.                                                      | R    | 0x0   |
| 29:27 | GPTM7MSCTRL | Control General Purpose Timer 7 sensitivity to MCU and/or DSP MSuspend signals | RW   | 0x0   |
|       | 0x0:        | No sensitivity: no MSuspend signal reaches the module                          |      |       |
|       | 0x1:        | Sensitivity to MCU MSuspend signals (DSP signal ignored)                       |      |       |
|       | 0x2:        | Sensitivity to DSP MSuspend signal (MCU signal ignored)                        |      |       |
|       | 0x3:        | Sensitivity to the logical ORed MCU and DSP MSuspend signals                   |      |       |
|       | 0x4:        | Sensitivity to the logical ANDed MCU and DSP MSuspend signals                  |      |       |
|       | 0x5:        | No sensitivity: no MSuspend signal reaches the module                          |      |       |
|       | 0x6:        | No sensitivity: no MSuspend signal reaches the module                          |      |       |
|       | 0x7:        | No sensitivity: no MSuspend signal reaches the module                          |      |       |
| 26:24 | GPTM6MSCTRL | Control General Purpose Timer 6 sensitivity to MCU and/or DSP MSuspend signals | RW   | 0x0   |
|       | 0x0:        | No sensitivity: no MSuspend signal reaches the module                          |      |       |
|       | 0x1:        | Sensitivity to MCU MSuspend signals (DSP signal ignored)                       |      |       |
|       | 0x2:        | Sensitivity to DSP MSuspend signal (MCU signal ignored)                        |      |       |
|       | 0x3:        | Sensitivity to the logical ORed MCU and DSP MSuspend signals                   |      |       |
|       | 0x4:        | Sensitivity to the logical ANDed MCU and DSP MSuspend signals                  |      |       |
|       | 0x5:        | No sensitivity: no MSuspend signal reaches the module                          |      |       |
|       | 0x6:        | No sensitivity: no MSuspend signal reaches the module                          |      |       |
|       | 0x7:        | No sensitivity: no MSuspend signal reaches the module                          |      |       |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 23:21       | GPTM5MSCTRL       | Control General Purpose Timer 5 sensitivity to MCU and/or DSP MSuspend signals<br><br>0x0: No sensitivity: no MSuspend signal reaches the module<br>0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)<br>0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)<br>0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals<br>0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals<br>0x5: No sensitivity: no MSuspend signal reaches the module<br>0x6: No sensitivity: no MSuspend signal reaches the module<br>0x7: No sensitivity: no MSuspend signal reaches the module | RW          | 0x0          |
| 20:18       | GPTM4MSCTRL       | Control General Purpose Timer 4 sensitivity to MCU and/or DSP MSuspend signals<br><br>0x0: No sensitivity: no MSuspend signal reaches the module<br>0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)<br>0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)<br>0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals<br>0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals<br>0x5: No sensitivity: no MSuspend signal reaches the module<br>0x6: No sensitivity: no MSuspend signal reaches the module<br>0x7: No sensitivity: no MSuspend signal reaches the module | RW          | 0x0          |
| 17:15       | GPTM3MSCTRL       | Control General Purpose Timer 3 sensitivity to MCU and/or DSP MSuspend signals<br><br>0x0: No sensitivity: no MSuspend signal reaches the module<br>0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)<br>0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)<br>0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals<br>0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals<br>0x5: No sensitivity: no MSuspend signal reaches the module<br>0x6: No sensitivity: no MSuspend signal reaches the module<br>0x7: No sensitivity: no MSuspend signal reaches the module | RW          | 0x0          |

| Bits  | Field Name  | Description                                                                    | Type | Reset |
|-------|-------------|--------------------------------------------------------------------------------|------|-------|
| 14:12 | GPTM2MSCTRL | Control General Purpose Timer 2 sensitivity to MCU and/or DSP MSuspend signals | RW   | 0x0   |
|       |             | 0x0: No sensitivity: no MSuspend signal reaches the module                     |      |       |
|       |             | 0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)                  |      |       |
|       |             | 0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)                   |      |       |
|       |             | 0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals              |      |       |
|       |             | 0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals             |      |       |
|       |             | 0x5: No sensitivity: no MSuspend signal reaches the module                     |      |       |
|       |             | 0x6: No sensitivity: no MSuspend signal reaches the module                     |      |       |
|       |             | 0x7: No sensitivity: no MSuspend signal reaches the module                     |      |       |
| 11:9  | GPTM1MSCTRL | Control General Purpose Timer 1 sensitivity to MCU and/or DSP MSuspend signals | RW   | 0x0   |
|       |             | 0x0: No sensitivity: no MSuspend signal reaches the module                     |      |       |
|       |             | 0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)                  |      |       |
|       |             | 0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)                   |      |       |
|       |             | 0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals              |      |       |
|       |             | 0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals             |      |       |
|       |             | 0x5: No sensitivity: no MSuspend signal reaches the module                     |      |       |
|       |             | 0x6: No sensitivity: no MSuspend signal reaches the module                     |      |       |
|       |             | 0x7: No sensitivity: no MSuspend signal reaches the module                     |      |       |
| 8:0   | RESERVED    | Read returns reset value.                                                      | R    | 0x00  |

**Table 13-92. Register Call Summary for Register CONTROL\_MSUSPENDMUX\_1**

## SCM Functional Description

- [MPU and/or DSP \(IVA2.2\) MSuspend Configuration Registers: \[0\]](#)

## SCM Register Manual

- [SCM Register Summary: \[1\]](#)

**Table 13-93. CONTROL\_MSUSPENDMUX\_2**

|                         |                                                                                 |                 |         |
|-------------------------|---------------------------------------------------------------------------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0028                                                                     |                 |         |
| <b>Physical Address</b> | 0x4800 2298                                                                     | <b>Instance</b> | GENERAL |
| <b>Description</b>      | MSuspend Control register : control the use of MSuspend signals at module level |                 |         |
| <b>Type</b>             | RW                                                                              |                 |         |

| 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 |
|----------|----|--------------|----|----------|----|-----------|----|-----------|----|----|----|----------|----|----|----|--------------|----|--------------|----|----|-------------|---|---|-------------|---|---|---|---|---|---|---|
| RESERVED |    | SYNCTMMSCTRL |    | RESERVED |    | WD3MSCTRL |    | WD2MSCTRL |    |    |    | RESERVED |    |    |    | GPTM11MSCTRL |    | GPTM10MSCTRL |    |    | GPTM9MSCTRL |   |   | GPTM8MSCTRL |   |   |   |   |   |   |   |

| Bits  | Field Name   | Description                                                          | Type | Reset |
|-------|--------------|----------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED     | Read returns reset value.                                            | R    | 0x0   |
| 29:27 | SYNCTMMSCTRL | Control Sync Timer32K sensitivity to MCU and/or DSP MSuspend signals | R/W  | 0x0   |
|       |              | 0x0: No sensitivity: no MSuspend signal reaches the module           |      |       |
|       |              | 0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)        |      |       |
|       |              | 0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)         |      |       |
|       |              | 0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals    |      |       |
|       |              | 0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals   |      |       |
|       |              | 0x5: No sensitivity: no MSuspend signal reaches the module           |      |       |
|       |              | 0x6: No sensitivity: no MSuspend signal reaches the module           |      |       |
|       |              | 0x7: No sensitivity: no MSuspend signal reaches the module           |      |       |
| 26:24 | RESERVED     | Read returns reset value.                                            | R    | 0x0   |
| 23:21 | WD3MSCTRL    | Control Watch Dog 3 sensitivity to MCU and/or DSP MSuspend signals   | R/W  | 0x1   |
|       |              | 0x0: No sensitivity: no MSuspend signal reaches the module           |      |       |
|       |              | 0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)        |      |       |
|       |              | 0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)         |      |       |
|       |              | 0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals    |      |       |
|       |              | 0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals   |      |       |
|       |              | 0x5: No sensitivity: no MSuspend signal reaches the module           |      |       |
|       |              | 0x6: No sensitivity: no MSuspend signal reaches the module           |      |       |
|       |              | 0x7: No sensitivity: no MSuspend signal reaches the module           |      |       |

| Bits  | Field Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Type | Reset |
|-------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 20:18 | WD2MSCTRL    | Control Watch Dog 2 sensitivity to MCU and/or DSP MSuspend signals<br><br>0x0: No sensitivity: no MSuspend signal reaches the module<br>0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)<br>0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)<br>0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals<br>0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals<br>0x5: No sensitivity: no MSuspend signal reaches the module<br>0x6: No sensitivity: no MSuspend signal reaches the module<br>0x7: No sensitivity: no MSuspend signal reaches the module              | R/W  | 0x1   |
| 17:12 | RESERVED     | Reserved. Read returns reset value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R    | 0x8   |
| 11:9  | GPTM11MSCTRL | Control General Purpose Timer 11 sensitivity to MCU and/or DSP MSuspend signals<br><br>0x0: No sensitivity: no MSuspend signal reaches the module<br>0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)<br>0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)<br>0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals<br>0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals<br>0x5: No sensitivity: no MSuspend signal reaches the module<br>0x6: No sensitivity: no MSuspend signal reaches the module<br>0x7: No sensitivity: no MSuspend signal reaches the module | R/W  | 0x0   |
| 8:6   | GPTM10MSCTRL | Control General Purpose Timer 10 sensitivity to MCU and/or DSP MSuspend signals<br><br>0x0: No sensitivity: no MSuspend signal reaches the module<br>0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)<br>0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)<br>0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals<br>0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals<br>0x5: No sensitivity: no MSuspend signal reaches the module<br>0x6: No sensitivity: no MSuspend signal reaches the module<br>0x7: No sensitivity: no MSuspend signal reaches the module | R/W  | 0x0   |

| Bits | Field Name  | Description                                                                    | Type | Reset |
|------|-------------|--------------------------------------------------------------------------------|------|-------|
| 5:3  | GPTM9MSCTRL | Control General Purpose Timer 9 sensitivity to MCU and/or DSP MSuspend signals | R/W  | 0x0   |
|      |             | 0x0: No sensitivity: no MSuspend signal reaches the module                     |      |       |
|      |             | 0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)                  |      |       |
|      |             | 0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)                   |      |       |
|      |             | 0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals              |      |       |
|      |             | 0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals             |      |       |
|      |             | 0x5: No sensitivity: no MSuspend signal reaches the module                     |      |       |
|      |             | 0x6: No sensitivity: no MSuspend signal reaches the module                     |      |       |
|      |             | 0x7: No sensitivity: no MSuspend signal reaches the module                     |      |       |
| 2:0  | GPTM8MSCTRL | Control General Purpose Timer 8 sensitivity to MCU and/or DSP MSuspend signals | R/W  | 0x0   |
|      |             | 0x0: No sensitivity: no MSuspend signal reaches the module                     |      |       |
|      |             | 0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)                  |      |       |
|      |             | 0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)                   |      |       |
|      |             | 0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals              |      |       |
|      |             | 0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals             |      |       |
|      |             | 0x5: No sensitivity: no MSuspend signal reaches the module                     |      |       |
|      |             | 0x6: No sensitivity: no MSuspend signal reaches the module                     |      |       |
|      |             | 0x7: No sensitivity: no MSuspend signal reaches the module                     |      |       |

**Table 13-94. Register Call Summary for Register CONTROL\_MSUSPENDMUX\_2**
**SCM Functional Description**

- [MPU and/or DSP \(IVA2.2\) MSuspend Configuration Registers: \[0\]](#)

**SCM Register Manual**

- [SCM Register Summary: \[1\]](#)

**Table 13-95. CONTROL\_MSUSPENDMUX\_3**

|                       |                                                                                 |                         |             |                 |         |
|-----------------------|---------------------------------------------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 002C                                                                     | <b>Physical Address</b> | 0x4800 229C | <b>Instance</b> | GENERAL |
| <b>Description</b>    | MSuspend Control register : control the use of MSuspend signals at module level |                         |             |                 |         |
| <b>Type</b>           | RW                                                                              |                         |             |                 |         |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description               | Type | Reset |
|------|------------|---------------------------|------|-------|
| 31:0 | RESERVED   | Read returns reset value. | R    | 0x0   |

**Table 13-96. Register Call Summary for Register CONTROL\_MSUSPENDMUX\_3**

SCM Functional Description

- [MPU and/or DSP \(IVA2.2\) MSuspend Configuration Registers: \[0\]](#)

SCM Register Manual

- [SCM Register Summary: \[1\]](#)

**Table 13-97. CONTROL\_MSUSPENDMUX\_4**

|                         |  |             |                                                                                |         |
|-------------------------|--|-------------|--------------------------------------------------------------------------------|---------|
| <b>Address Offset</b>   |  | 0x0000 0030 |                                                                                |         |
| <b>Physical Address</b> |  | 0x4800 22A0 | <b>Instance</b>                                                                | GENERAL |
| <b>Description</b>      |  |             | MSuspend Control register: control the use of MSuspend signals at module level |         |
| <b>Type</b>             |  |             |                                                                                | RW      |

|          |           |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|-----------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED | DMAMSCTRL | RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                        | Type | Reset     |
|-------|------------|--------------------------------------------------------------------|------|-----------|
| 31:30 | RESERVED   | Read returns reset value.                                          | R    | 0x0       |
| 29:27 | DMAMSCTRL  | Control DMA sensitivity to MCU and/or DSP MSuspend signals         | R/W  | 0x0       |
|       |            | 0x0: No sensitivity: No MSuspend signal reaches the module         |      |           |
|       |            | 0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)      |      |           |
|       |            | 0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)       |      |           |
|       |            | 0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals  |      |           |
|       |            | 0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals |      |           |
|       |            | 0x5: No sensitivity: No MSuspend signal reaches the module         |      |           |
|       |            | 0x6: No sensitivity: No MSuspend signal reaches the module         |      |           |
|       |            | 0x7: No sensitivity: No MSuspend signal reaches the module         |      |           |
| 26:0  | RESERVED   | Read returns reset value.                                          | R    | 0x0000000 |

**Table 13-98. Register Call Summary for Register CONTROL\_MSUSPENDMUX\_4**

SCM Functional Description

- [MPU and/or DSP \(IVA2.2\) MSuspend Configuration Registers: \[0\]](#)

SCM Register Manual

- [SCM Register Summary: \[1\]](#)

**Table 13-99. CONTROL\_MSUSPENDMUX\_5**

|                       |                                                                                            |                         |             |                 |         |
|-----------------------|--------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 0034                                                                                | <b>Physical Address</b> | 0x4800 22A4 | <b>Instance</b> | GENERAL |
| <b>Description</b>    | MSuspend Control register: control the use of MSuspend signals at module level<br>Not used |                         |             |                 |         |
| <b>Type</b>           | RW                                                                                         |                         |             |                 |         |



| Bits  | Field Name   | Description                                                        | Type | Reset |
|-------|--------------|--------------------------------------------------------------------|------|-------|
| 31:24 | RESERVED     | Read returns reset value.                                          | R    | 0x0   |
| 23:21 | I2C3MSCTRL   | Control I2C-3 Sensitivity to MCU and/or DSP MSuspend Signals       | R/W  | 0x0   |
|       |              | 0x0: No sensitivity: No MSuspend signal reaches the module         |      |       |
|       |              | 0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)      |      |       |
|       |              | 0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)       |      |       |
|       |              | 0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals  |      |       |
|       |              | 0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals |      |       |
|       |              | 0x5: No sensitivity: No MSuspend signal reaches the module         |      |       |
|       |              | 0x6: No sensitivity: No MSuspend signal reaches the module         |      |       |
|       |              | 0x7: No sensitivity: No MSuspend signal reaches the module         |      |       |
| 20:9  | RESERVED     | Read returns reset value.                                          | R    | 0x0   |
| 8:6   | MCBSP5MSCTRL | Control McBSP-5 Sensitivity to MCU and/or DSP MSuspend Signals     | R/W  | 0x0   |
|       |              | 0x0: No sensitivity: No MSuspend signal reaches the module         |      |       |
|       |              | 0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)      |      |       |
|       |              | 0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)       |      |       |
|       |              | 0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals  |      |       |
|       |              | 0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals |      |       |
|       |              | 0x5: No sensitivity: No MSuspend signal reaches the module         |      |       |
|       |              | 0x6: No sensitivity: No MSuspend signal reaches the module         |      |       |
|       |              | 0x7: No sensitivity: No MSuspend signal reaches the module         |      |       |

| Bits | Field Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset |
|------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 5:3  | MCBSP4MSCTRL | Control McBSP-4 Sensitivity to MCU and/or DSP MSuspend Signals<br><br>0x0: No sensitivity: No MSuspend signal reaches the module<br>0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)<br>0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)<br>0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals<br>0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals<br>0x5: No sensitivity: No MSuspend signal reaches the module<br>0x6: No sensitivity: No MSuspend signal reaches the module<br>0x7: No sensitivity: No MSuspend signal reaches the module | R/W  | 0x0   |
| 2:0  | MCBSP3MSCTRL | Control McBSP-3 Sensitivity to MCU and/or DSP MSuspend Signals<br><br>0x0: No sensitivity: no MSuspend signal reaches the module<br>0x1: Sensitivity to MCU MSuspend signals (DSP signal ignored)<br>0x2: Sensitivity to DSP MSuspend signal (MCU signal ignored)<br>0x3: Sensitivity to the logical ORed MCU and DSP MSuspend signals<br>0x4: Sensitivity to the logical ANDed MCU and DSP MSuspend signals<br>0x5: No sensitivity: No MSuspend signal reaches the module<br>0x6: No sensitivity: No MSuspend signal reaches the module<br>0x7: No sensitivity: No MSuspend signal reaches the module | R/W  | 0x0   |

**Table 13-100. Register Call Summary for Register CONTROL\_MSUSPENDMUX\_5**

SCM Functional Description

- [MPU and/or DSP \(IVA2.2\) MSuspend Configuration Registers: \[0\]](#)

SCM Register Manual

- [SCM Register Summary: \[1\]](#)

**Table 13-101. CONTROL\_PROT\_CTRL**

|                         |                  |                 |         |
|-------------------------|------------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0040      | <b>Instance</b> | GENERAL |
| <b>Physical Address</b> | 0x4800 22B0      |                 |         |
| <b>Description</b>      | control register |                 |         |
| <b>Type</b>             | R/OCO            |                 |         |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------------------|----------|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | OBSERVABILITYDISABLE | RESERVED |   |   |   |   |   |

| Bits | Field Name           | Description                                                                                                                                                                                                                                          | Type  | Reset |
|------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|
| 31:6 | RESERVED             | Read returns reset value.                                                                                                                                                                                                                            | R     | 0x0   |
| 5    | OBSERVABILITYDISABLE | Control the observability feature<br><br>0x0: Observability can be configured through the ObsMux bit field in the CONTROL_DEBOBS register.<br><br>0x1: Observability is disabled. If pads are configured for the hardware debug, output is tied low. | R/OCO | 0x0   |
| 4:0  | RESERVED             | Read returns reset value.                                                                                                                                                                                                                            | R     | 0x0   |

**Table 13-102. Register Call Summary for Register CONTROL\_PROT\_CTRL**

SCM Functional Description

- [Description: \[0\]](#)

SCM Register Manual

- [SCM Register Summary: \[1\]](#)

**Table 13-103. CONTROL\_DEVCONF1**

|                         |                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0068                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 22D8                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | <a href="#">CONTROL_DEVCONF1</a> register description |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name  | Description                                                                                | Type | Reset |
|-------|-------------|--------------------------------------------------------------------------------------------|------|-------|
| 31:24 | RESERVED    | Read returns reset value.                                                                  | R    | 0x00  |
| 23    | SENSDMAREQ6 | Set sensitivity on SYS.nDMAREQ6 input pin<br>0 : Level sensitivity<br>1 : Edge sensitivity | RW   | 0     |

## SCM Register Manual

www.ti.com

| Bits  | Field Name              | Description                                                                                                                                                                                                                                           | Type | Reset |
|-------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 22    | SENSDMAREQ5             | Set sensitivity on SYS.nDMAREQ5 input pin<br>0 : Level sensitivity<br>1 : Edge sensitivity                                                                                                                                                            | RW   | 0     |
| 21    | SENSDMAREQ4             | Set sensitivity on SYS.nDMAREQ4 input pin<br>0 : Level sensitivity<br>1 : Edge sensitivity                                                                                                                                                            | RW   | 0     |
| 20    | CARKITHSUSB0DATA1AUTOEN | Enable force from HSUB0 DATA1 pad configuration MuxMode when CARKITEN is generated:<br>0: HSUB0 DATA1 pad MuxMode is driven by HSUB0 DATA1 pad configuration register.<br>1: HSUB0 DATA1 pad MuxMode is forced to 0x2 when CARKITEN signal is active. | RW   | 0     |
| 19    | CARKITHSUSB0DATA0AUTOEN | Enable force from HSUB0 DATA0 pad configuration MuxMode when CARKITEN is generated<br>0 : HSUB0 DATA0 pad MuxMode is driven by HSUB0 NXT pad configuration register<br>1 : HSUB0 DATA0 pad MuxMode is forced to 0x2 when CARKITEN signal is active.   | RW   | 0     |
| 18    | TVOUTBYPASS             | Active high enable AVDAC TV out bypass                                                                                                                                                                                                                | RW   | 0     |
| 17:12 | RESERVED                | Read returns reset value.                                                                                                                                                                                                                             | R    | 0x00  |
| 11    | TVACEN                  | TV AC coupled load enable<br>0 : DC coupled load<br>1 : AC coupled load                                                                                                                                                                               | RW   | 0     |
| 10    | RESERVED                | Read returns reset value.                                                                                                                                                                                                                             | R    | 0     |
| 9     | MPUFORCEWRNP            | Force MPU writes to be nonposted<br>0 : Posted writes<br>1 : Nonposted writes                                                                                                                                                                         | RW   | 0     |
| 8     | SENSDMAREQ3             | Set sensitivity on SYS.nDMAREQ3 input pin<br>0 : Level sensitivity<br>1 : Edge sensitivity                                                                                                                                                            | RW   | 0     |
| 7     | SENSDMAREQ2             | Set sensitivity on SYS.nDMAREQ2 input pin<br>0 : Level sensitivity<br>1 : Edge sensitivity                                                                                                                                                            | RW   | 0     |
| 6     | MMCSDIO2ADPCLKISEL      | MMC/SDIO2 Module Input Clock selection:<br>0 : Input clock is from the external pin<br>1 : Internal loop_back, module input clock is copied from the module output clock                                                                              | RW   | 0     |
| 5     | RESERVED                | Read returns reset value.                                                                                                                                                                                                                             | R    | 0     |
| 4     | MCBSP5_CLKS             | Select the CLKS input for the module McBSP5<br>0 : CLKS is from the PRCM functional clock<br>1 : CLKS is from the external pin McBSP_CLKS                                                                                                             | RW   | 0     |
| 3     | RESERVED                | Read returns reset value.                                                                                                                                                                                                                             | R    | 0     |
| 2     | MCBSP4_CLKS             | Select the CLKS input for the module McBSP4<br>0 : CLKS is from the PRCM functional clock<br>1 : CLKS is from the external pin McBSP_CLKS                                                                                                             | RW   | 0     |
| 1     | RESERVED                | Read returns reset value.                                                                                                                                                                                                                             | R    | 0     |
| 0     | MCBSP3_CLKS             | Select the CLKS input for the module McBSP3<br>0 : CLKS is from the PRCM functional clock<br>1 : CLKS is from the external pin McBSP_CLKS                                                                                                             | RW   | 0     |

**Table 13-104. Register Call Summary for Register CONTROL\_DEVCONF1**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCM Functional Description                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <ul style="list-style-type: none"> <li>• <a href="#">Static Device Configuration Registers: [0]</a></li> </ul>                                                                                                                                                                                                                                                                                                                                        |
| SCM Programming Model                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <ul style="list-style-type: none"> <li>• Force Pad Configuration MuxMode by High-Speed USB: [1] [2]</li> <li>• Video Driver: [3] [4]</li> <li>• McBSP3 Internal Clock: [5]</li> <li>• McBSP4 Internal Clock: [6]</li> <li>• McBSP5 Internal Clock: [7]</li> <li>• MMC/SD/SDIO2 Module Input Clock Selection: [8]</li> <li>• Setting Sensitivity on sys_ndmareq[3:0] Input Pins: [9] [10]</li> <li>• Force MPU Writes to Be Nonposted: [11]</li> </ul> |
| SCM Register Manual                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <ul style="list-style-type: none"> <li>• <a href="#">SCM Register Summary: [12]</a></li> <li>• <a href="#">GENERAL Register Description: [13]</a></li> </ul>                                                                                                                                                                                                                                                                                          |

**Table 13-105. CONTROL\_PROT\_ERR\_STATUS**

|                         |                                  |                 |         |
|-------------------------|----------------------------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0074                      | <b>Instance</b> | GENERAL |
| <b>Physical Address</b> | 0x4800 22E4                      |                 |         |
| <b>Description</b>      | Protection error status register |                 |         |
| <b>Type</b>             | RW                               |                 |         |

| 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             |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|-----------------|------------|----------|-----------------|----------|-----------------|-------------------|----------------|---------------|-------------|--------------|-------------|-----------------|-------------|---------------|---------------|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | L4EMUFVERROR | L4PERIPHFWERROR | D2DFWERROR | RESERVED | SMXAPERTFWERROR | RESERVED | DISPDMAACCERROR | CAMERADMAACCERROR | SYSDMAACCERROR | L4COREFWERROR | IVA2FWERROR | MAD2DFWERROR | SMSSFWERROR | SMSSFUNCFWERROR | GPMCFWERROR | OCMRAMFWERROR | OCMROMFWERROR |

| Bits  | Field Name          | Description                                       | Type | Reset |
|-------|---------------------|---------------------------------------------------|------|-------|
| 31:18 | RESERVED            | Read returns reset value.                         | R    | 0x0   |
| 17    | L4EMUFWERROR        | L4 Emulation Firewall Error                       | R    | 0x0   |
|       |                     | 0x0: No L4 Emulation interconnect firewall error  |      |       |
|       |                     | 0x1: L4 Emulation interconnect firewall error     |      |       |
| 16    | L4PERIPHFW<br>ERROR | L4 Peripheral Firewall Error                      | R    | 0x0   |
|       |                     | 0x0: No L4 Peripheral interconnect firewall error |      |       |
|       |                     | 0x1: L4 Peripheral interconnect firewall error    |      |       |
| 15    | D2DFWERROR          | D2D Firewall error                                | R    | 0x0   |
|       |                     | 0x0: No D2D firewall error                        |      |       |
|       |                     | 0x1: D2D firewall error                           |      |       |
| 14:13 | RESERVED            | Read returns reset value.                         | R    | 0x0   |
| 12    | SMXAPERTFW<br>ERROR | L3 Register target Firewall error                 | R    | 0x0   |
|       |                     | 0x0: No L3 Register Target firewall error         |      |       |
|       |                     | 0x1: L3 Register Target firewall error            |      |       |
| 11    | RESERVED            | Reserved for non GRP-devices                      | R    | 0x0   |

## SCM Register Manual

www.ti.com

| Bits | Field Name            | Description                                                                                                                                              | Type | Reset |
|------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 10   | DISPDMAACC<br>ERROR   | Disp Dma Access Error<br><br>0x0: No access error to DISP DMA protection channels<br><br>0x1: Unauthorized access to a DISP DMA protection channel       | R    | 0x0   |
| 9    | CAMERADMAACC<br>ERROR | Camera Dma Access Error<br><br>0x0: No access error to Camera DMA protection channels<br><br>0x1: Unauthorized access to a Camera DMA protection channel | R    | 0x0   |
| 8    | SYSDMAACC<br>ERROR    | sDma Access Error<br><br>0x0: No access error to sDMA protection channels<br><br>0x1: Unauthorized access to a sDMA protection channel                   | R    | 0x0   |
| 7    | L4COREFW<br>ERROR     | L4 Protection Firewall Error<br><br>0x0: No error from L4 Core protection firewall<br><br>0x1: Error from L4 Core protection firewall                    | R    | 0x0   |
| 6    | IVA2FWERROR           | IVA2 Protection Firewall Error<br><br>0x0: No error from IVA2 protection firewall<br><br>0x1: Error from IVA2 protection firewall                        | R    | 0x0   |
| 5    | MAD2DFW<br>ERROR      | MAD2D Firewall Error<br><br>0x0: No MAD2D functional firewall error<br><br>0x1: No MAD2D functional firewall error                                       | R    | 0x0   |
| 4    | SMSFWERROR            | SMS Firewall Error<br><br>0x0: No SMS firewall error<br><br>0x1: SMS firewall error                                                                      | R    | 0x0   |
| 3    | SMSFUNCFW<br>ERROR    | SMS Functional Firewall Error<br><br>0x0: No SMS functional firewall error<br><br>0x1: SMS functional firewall error                                     | R    | 0x0   |
| 2    | GPMCFWERROR           | GPMC Firewall Error<br><br>0x0: No error from GPMC protection firewall<br><br>0x1: Error from GPMC protection firewall                                   | R    | 0x0   |
| 1    | OCMRAMFW<br>ERROR     | On Chip Ram Firewall Error<br><br>0x0: No error from On Chip RAM protection firewall<br><br>0x1: Error from On Chip RAM protectionfirewall               | R    | 0x0   |
| 0    | OCMROMFW<br>ERROR     | On Chip Rom Firewall Error<br><br>0x0: No error from On Chip ROM protection firewall<br><br>0x1: Error from On Chip ROM protection firewall              | R    | 0x0   |

**Table 13-106. Register Call Summary for Register CONTROL\_PROT\_ERR\_STATUS**

## SCM Functional Description

- [Protection Status Registers: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\]](#)

## SCM Register Manual

- [SCM Register Summary: \[12\]](#)

**Table 13-107. CONTROL\_PROT\_ERR\_STATUS\_DEBUG**

|                         |                                        |                 |         |  |  |
|-------------------------|----------------------------------------|-----------------|---------|--|--|
| <b>Address Offset</b>   | 0x0000 0078                            | <b>Instance</b> | GENERAL |  |  |
| <b>Physical Address</b> | 0x4800 22E8                            |                 |         |  |  |
| <b>Description</b>      | Protection Error Status Debug Register |                 |         |  |  |
| <b>Type</b>             | RW                                     |                 |         |  |  |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name                 | Description                                                                                                                                          | Type | Reset |
|-------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:18 | RESERVED                   | Read returns reset value                                                                                                                             | R    | 0x0   |
| 17    | L4EMUDBGFW<br>ERROR        | L4 Emulation Debug Firewall Error<br><br>0x0: No firewall error in L4 Emulation Debug<br>0x1: Firewall error in L4 Emulation Debug                   | R    | 0x0   |
| 16    | L4PERIPHERALD<br>BGFWERROR | L4 Peripheral Debug Firewall Error<br><br>0x0: No firewall error in L4 Peripheral Debug<br>0x1: Firewall error in L4 Peripheral Debug                | R    | 0x0   |
| 15:13 | RESERVED                   | Read returns reset value                                                                                                                             | R    | 0x0   |
| 12    | SMXAPERT<br>DBGFWERROR     | L3 Register target Debug Firewall error<br><br>0x0: No firewall error in L3 Register Target Debug<br>0x1: Firewall error in L3 Register Target Debug | R    | 0x0   |
| 11:8  | RESERVED                   | Read returns reset value.                                                                                                                            | R    | 0x0   |
| 7     | L4COREDBGFW<br>ERROR       | L4 Core Debug Firewall Error<br><br>0x0: No firewall error in L4 Core Debug<br>0x1: Firewall error in L4 Core Debug                                  | R    | 0x0   |
| 6     | IVA2DBGFW<br>ERROR         | IVA2 Debug Firewall Error<br><br>0x0: No error from IVA2 debug protection firewall<br>0x1: Error from IVA2 debug protection firewall                 | R    | 0x0   |
| 5     | MAD2DDBGFW<br>ERROR        | MAD2D Debug Firewall Error<br><br>0x0: No Firewall debug error in MAD2D<br>0x1: No Firewall debug error in MAD2D                                     | R    | 0x0   |
| 4     | RESERVED                   | Read returns reset value.                                                                                                                            | R    | 0x0   |
| 3     | SMSDBGFW<br>ERROR          | SMS Debug Firewall Error<br><br>0x0: No Firewall debug error in SMS<br>0x1: Firewall debug error in SMS                                              | R    | 0x0   |
| 2     | GPMCDDBGFW<br>ERROR        | GPMC Debug Firewall Error<br><br>0x0: No error from GPMC debug protection firewall<br>0x1: Error from GPMC debug protection firewall                 | R    | 0x0   |

## SCM Register Manual

www.ti.com

| Bits | Field Name           | Description                                                                                                                                                   | Type | Reset |
|------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | OCMRAMDBGFW<br>ERROR | On Chip Ram Debug Firewall Error<br><br>0x0: No error from On Chip RAM debug protection firewall<br><br>0x1: Error from On Chip RAM debug protection firewall | R    | 0x0   |
| 0    | OCMROMDBGFW<br>ERROR | On Chip Rom Debug Firewall Error<br><br>0x0: No error from On Chip ROM debug protection firewall<br><br>0x1: Error from On Chip ROM debug protection firewall | R    | 0x0   |

**Table 13-108. Register Call Summary for Register CONTROL\_PROT\_ERR\_STATUS\_DEBUG**

SCM Functional Description

- [Protection Status Registers: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\]](#)

SCM Register Manual

- [SCM Register Summary: \[8\]](#)

**Table 13-109. CONTROL\_STATUS**

|                         |                                                     |                       |                  |
|-------------------------|-----------------------------------------------------|-----------------------|------------------|
| Address Offset          | 0x0000 0080                                         | Instance              | GENERAL          |
| Physical Address        | 0x4800 22F0                                         |                       |                  |
| Description             | <a href="#">CONTROL_STATUS</a> register description |                       |                  |
| Type                    | R                                                   |                       |                  |
| 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  |
|                         | RESERVED                                            | DEVICETYPE            | RESERVED SYSBOOT |

| Bits  | Field Name | Description                                                                                 | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Reserved field                                                                              | R    | 0x-   |
| 10:8  | DEVICETYPE | Device type value sampled at power_on reset<br>0b011 : GP device<br>Other values : Reserved | R    | 0x-   |
| 7:6   | RESERVED   | Reserved field                                                                              | R    | 0x-   |
| 5:0   | SYSBOOT    | Sys.Boot pin values sampled at power_on reset                                               | R    | 0x-   |

**Table 13-110. Register Call Summary for Register CONTROL\_STATUS**

SCM Environment

- [SCM Environment: \[0\]](#)

SCM Register Manual

- [SCM Register Summary: \[1\]](#)
- [GENERAL Register Description: \[2\]](#)

**Table 13-111. CONTROL\_GENERAL\_PURPOSE\_STATUS**

|                         |                                                                     |                         |                 |                 |         |
|-------------------------|---------------------------------------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0084                                                         | <b>Physical Address</b> | 0x4800 22F4     | <b>Instance</b> | GENERAL |
| <b>Description</b>      | <a href="#">CONTROL_GENERAL_PURPOSE_STATUS register description</a> |                         |                 |                 |         |
| <b>Type</b>             | R                                                                   |                         |                 |                 |         |
| 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 |                 |         |
| RESERVED                | RESERVED                                                            |                         |                 |                 |         |
|                         |                                                                     |                         |                 |                 |         |
| SAVEDONE                |                                                                     |                         |                 |                 |         |

| Bits | Field Name | Description                                                                          | Type | Reset       |
|------|------------|--------------------------------------------------------------------------------------|------|-------------|
| 31   | RESERVED   | RESERVED. Read returns reset value                                                   | R    | 0           |
| 30:1 | RESERVED   | Reserved field                                                                       | R    | 0x0000 0000 |
| 0    | SAVEDONE   | Pad configuration save status:<br>0 : Save is not completed<br>1 : Save is completed | R    | 0           |

**Table 13-112. Register Call Summary for Register CONTROL\_GENERAL\_PURPOSE\_STATUS**

SCM Functional Description

- [Save-and-Restore Mechanism: \[0\]](#)

SCM Register Manual

- [SCM Register Summary: \[1\]](#)
- [GENERAL Register Description: \[2\]](#)

**Table 13-113. CONTROL\_RPUB\_KEY\_H\_0**

|                         |                                                   |                         |                 |                 |         |
|-------------------------|---------------------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0090                                       | <b>Physical Address</b> | 0x4800 2300     | <b>Instance</b> | GENERAL |
| <b>Description</b>      | <a href="#">rpub_key_h_0 register description</a> |                         |                 |                 |         |
| <b>Type</b>             | R                                                 |                         |                 |                 |         |
| 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 |                 |         |
|                         | RPKH_0                                            |                         |                 |                 |         |

| Bits | Field Name | Description            | Type | Reset       |
|------|------------|------------------------|------|-------------|
| 31:0 | RPKH_0     | Root_public_key_hash 0 | R    | 0x0000 0000 |

**Table 13-114. Register Call Summary for Register CONTROL\_RPUB\_KEY\_H\_0**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-115. CONTROL\_RPUB\_KEY\_H\_1**

|                         |                                   |                       |                 |  |  |
|-------------------------|-----------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0094                       | <b>Instance</b>       | GENERAL         |  |  |
| <b>Physical Address</b> | 0x4800 2304                       |                       |                 |  |  |
| <b>Description</b>      | rpub_key_h_1 register description |                       |                 |  |  |
| <b>Type</b>             | R                                 |                       |                 |  |  |
| 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 |  |  |
| RPKH_1                  |                                   |                       |                 |  |  |

| Bits | Field Name | Description            | Type | Reset       |
|------|------------|------------------------|------|-------------|
| 31:0 | RPKH_1     | Root_public_key_hash 1 | R    | 0x0000 0000 |

**Table 13-116. Register Call Summary for Register CONTROL\_RPUB\_KEY\_H\_1**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-117. CONTROL\_RPUB\_KEY\_H\_2**

|                         |                                   |                       |                 |  |  |
|-------------------------|-----------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0098                       | <b>Instance</b>       | GENERAL         |  |  |
| <b>Physical Address</b> | 0x4800 2308                       |                       |                 |  |  |
| <b>Description</b>      | rpub_key_h_2 register description |                       |                 |  |  |
| <b>Type</b>             | R                                 |                       |                 |  |  |
| 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 |  |  |
| RPKH_2                  |                                   |                       |                 |  |  |

| Bits | Field Name | Description            | Type | Reset       |
|------|------------|------------------------|------|-------------|
| 31:0 | RPKH_2     | Root_public_key_hash 2 | R    | 0x0000 0000 |

**Table 13-118. Register Call Summary for Register CONTROL\_RPUB\_KEY\_H\_2**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-119. CONTROL\_RPUB\_KEY\_H\_3**

|                         |                                   |                       |                 |  |  |
|-------------------------|-----------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 009C                       | <b>Instance</b>       | GENERAL         |  |  |
| <b>Physical Address</b> | 0x4800 230C                       |                       |                 |  |  |
| <b>Description</b>      | rpub_key_h_3 register description |                       |                 |  |  |
| <b>Type</b>             | R                                 |                       |                 |  |  |
| 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 |  |  |
| RPKH_3                  |                                   |                       |                 |  |  |

| Bits | Field Name | Description            | Type | Reset       |
|------|------------|------------------------|------|-------------|
| 31:0 | RPKH_3     | Root_public_key_hash 3 | R    | 0x0000 0000 |

**Table 13-120. Register Call Summary for Register CONTROL\_RPUB\_KEY\_H\_3**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-121. CONTROL\_RPUB\_KEY\_H\_4**

|                         |                                   |                       |                 |  |  |
|-------------------------|-----------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 00A0                       | <b>Instance</b>       | GENERAL         |  |  |
| <b>Physical Address</b> | 0x4800 2310                       |                       |                 |  |  |
| <b>Description</b>      | rpub_key_h_4 register description |                       |                 |  |  |
| <b>Type</b>             | R                                 |                       |                 |  |  |
| 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 |  |  |
| RPKH_4                  |                                   |                       |                 |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------|-------------|--------------|
| 31:0        | RPKH_4            | Root_public_key_hash 4 | R           | 0x0000 0000  |

**Table 13-122. Register Call Summary for Register CONTROL\_RPUB\_KEY\_H\_4**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-123. CONTROL\_USB\_CONF\_0**

|                         |                                 |                       |                 |  |  |
|-------------------------|---------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0100                     | <b>Instance</b>       | GENERAL         |  |  |
| <b>Physical Address</b> | 0x4800 2370                     |                       |                 |  |  |
| <b>Description</b>      | usb_conf_0 register description |                       |                 |  |  |
| <b>Type</b>             | R                               |                       |                 |  |  |
| 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 |  |  |
| USB_PROD_ID             |                                 |                       |                 |  |  |
| USB_VENDOR_ID           |                                 |                       |                 |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 31:16       | USB_PROD_ID       | USB product ID     | R           | 0x0000       |
| 15:0        | USB_VENDOR_ID     | Vendor ID          | R           | 0x0000       |

**Table 13-124. Register Call Summary for Register CONTROL\_USB\_CONF\_0**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-125. CONTROL\_USB\_CONF\_1**

|                         |                                 |                       |                 |  |  |
|-------------------------|---------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0104                     | <b>Instance</b>       | GENERAL         |  |  |
| <b>Physical Address</b> | 0x4800 2374                     |                       |                 |  |  |
| <b>Description</b>      | usb_conf_1 register description |                       |                 |  |  |
| <b>Type</b>             | R                               |                       |                 |  |  |
| 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 |  |  |
| USB_CONF_1              |                                 |                       |                 |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------|-------------|--------------|
| 31:0        | USB_CONF_1        | USB Fuse conf 1. SEQ_DISADAPTCLOCK (1), USB PHY detection mode(0). | R           | 0x0000 0000  |

**Table 13-126. Register Call Summary for Register CONTROL\_USB\_CONF\_1**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-127. CONTROL\_FUSE OPP1G\_VDD1**

|                         |                                        |                 |         |  |  |
|-------------------------|----------------------------------------|-----------------|---------|--|--|
| <b>Address Offset</b>   | 0x0000 0110                            | <b>Instance</b> | GENERAL |  |  |
| <b>Physical Address</b> | 0x4800 2380                            |                 |         |  |  |
| <b>Description</b>      | Standard fuse OPP1G <b>VDD1</b> [23:0] |                 |         |  |  |
| <b>Type</b>             | R                                      |                 |         |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | FUSE_OPP1G_VDD1         |                       |                 |

| Bits  | Field Name      | Description                                                    | Type | Reset             |
|-------|-----------------|----------------------------------------------------------------|------|-------------------|
| 31:24 | RESERVED        | Read returns reset value.                                      | R    | 0x00000000        |
| 23:0  | FUSE_OPP1G_VDD1 | SmartReflex Ntarget value for OPP1G <b>VDD1</b> <sup>(1)</sup> | R    | 0x <sup>(2)</sup> |

<sup>(1)</sup> Only available starting with 3630-1000 version.<sup>(2)</sup> Register reset value undefined; 0x0 on -600 and -800 versions.**Table 13-128. Register Call Summary for Register CONTROL\_FUSE\_OPP1G\_VDD1**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-129. CONTROL\_FUSE OPP50\_VDD1**

|                         |                                        |                 |         |  |  |
|-------------------------|----------------------------------------|-----------------|---------|--|--|
| <b>Address Offset</b>   | 0x0000 0114                            | <b>Instance</b> | GENERAL |  |  |
| <b>Physical Address</b> | 0x4800 2384                            |                 |         |  |  |
| <b>Description</b>      | Standard fuse OPP50 <b>VDD1</b> [23:0] |                 |         |  |  |
| <b>Type</b>             | R                                      |                 |         |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | FUSE_OPP50_VDD1         |                       |                 |

| Bits  | Field Name      | Description                                     | Type | Reset             |
|-------|-----------------|-------------------------------------------------|------|-------------------|
| 31:24 | RESERVED        | Read returns reset value.                       | R    | 0x00000000        |
| 23:0  | FUSE_OPP50_VDD1 | SmartReflex Ntarget value for OPP50 <b>VDD1</b> | R    | 0x <sup>(1)</sup> |

<sup>(1)</sup> Register reset value undefined; differs between devices.**Table 13-130. Register Call Summary for Register CONTROL\_FUSE\_OPP50\_VDD1**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-131. CONTROL\_FUSE OPP100\_VDD1**

|                         |                                         |                       |                 |  |  |
|-------------------------|-----------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0118                             | <b>Instance</b>       | GENERAL         |  |  |
| <b>Physical Address</b> | 0x4800 2388                             |                       |                 |  |  |
| <b>Description</b>      | Standard fuse OPP100 <b>VDD1</b> [23:0] |                       |                 |  |  |
| <b>Type</b>             | R                                       |                       |                 |  |  |
| 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 |  |  |
| RESERVED                | FUSE_OPP100_VDD1                        |                       |                 |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                               | <b>Type</b> | <b>Reset</b>       |
|-------------|-------------------|--------------------------------------------------|-------------|--------------------|
| 31:24       | RESERVED          | Read returns reset value.                        | R           | 0x00000000         |
| 23:0        | FUSE_OPP100_VDD1  | SmartReflex Ntarget value for OPP100 <b>VDD1</b> | R           | 0x- <sup>(1)</sup> |

<sup>(1)</sup> Register reset value undefined; differs between devices.

**Table 13-132. Register Call Summary for Register VDD1**

## SCM Functional Description

- [Observability Tables: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\]](#)

## SCM Register Manual

- [SCM Register Summary: \[7\]](#)
- [GENERAL Register Description: \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\]](#)

**Table 13-133. CONTROL\_FUSE OPP130\_VDD1**

|                         |                                         |                       |                 |  |  |
|-------------------------|-----------------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0120                             | <b>Instance</b>       | GENERAL         |  |  |
| <b>Physical Address</b> | 0x4800 2390                             |                       |                 |  |  |
| <b>Description</b>      | Standard fuse OPP130 <b>VDD1</b> [23:0] |                       |                 |  |  |
| <b>Type</b>             | R                                       |                       |                 |  |  |
| 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 |  |  |
| RESERVED                | FUSE_OPP100_VDD1                        |                       |                 |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                               | <b>Type</b> | <b>Reset</b>       |
|-------------|-------------------|--------------------------------------------------|-------------|--------------------|
| 31:24       | RESERVED          | Read returns reset value.                        | R           | 0x00000000         |
| 23:0        | FUSE_OPP130_VDD1  | SmartReflex Ntarget value for OPP130 <b>VDD1</b> | R           | 0x- <sup>(1)</sup> |

<sup>(1)</sup> Register reset value undefined; differs between devices.

**Table 13-134. Register Call Summary for Register CONTROL\_FUSE OPP130\_VDD1**

## SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-135. CONTROL\_FUSE\_OPP50\_VDD2**

|                         |                                 |                       |                 |  |  |
|-------------------------|---------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0128                     | <b>Instance</b>       | GENERAL         |  |  |
| <b>Physical Address</b> | 0x4800 2398                     |                       |                 |  |  |
| <b>Description</b>      | Standard fuse OPP50 VDD2 [23:0] |                       |                 |  |  |
| <b>Type</b>             | R                               |                       |                 |  |  |
| 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 |  |  |
| RESERVED                | FUSE_OPP50_VDD2                 |                       |                 |  |  |

| Bits  | Field Name      | Description                              | Type | Reset                 |
|-------|-----------------|------------------------------------------|------|-----------------------|
| 31:24 | RESERVED        | Read returns reset value.                | R    | 0x00000000            |
| 23:0  | FUSE_OPP50_VDD2 | SmartReflex Ntarget value for OPP50 VDD2 | R    | 0x-( <sup>(1)</sup> ) |

<sup>(1)</sup> Register reset value undefined; differs between devices.

**Table 13-136. Register Call Summary for Register CONTROL\_FUSE\_OPP50\_VDD2**

## SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-137. CONTROL\_FUSE\_OPP100\_VDD2**

|                         |                                  |                       |                 |  |  |
|-------------------------|----------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 012C                      | <b>Instance</b>       | GENERAL         |  |  |
| <b>Physical Address</b> | 0x4800 239C                      |                       |                 |  |  |
| <b>Description</b>      | Standard fuse OPP100 VDD2 [23:0] |                       |                 |  |  |
| <b>Type</b>             | R                                |                       |                 |  |  |
| 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 |  |  |
| RESERVED                | FUSE_OPP100_VDD2                 |                       |                 |  |  |

| Bits  | Field Name       | Description                               | Type | Reset                 |
|-------|------------------|-------------------------------------------|------|-----------------------|
| 31:24 | RESERVED         | Read returns reset value.                 | R    | 0x00000000            |
| 23:0  | FUSE_OPP100_VDD2 | SmartReflex Ntarget value for OPP100 VDD2 | R    | 0x-( <sup>(1)</sup> ) |

<sup>(1)</sup> Register reset value undefined; differs between devices.

**Table 13-138. Register Call Summary for Register CONTROL\_FUSE\_OPP100\_VDD2**

## SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-139. CONTROL\_FUSE\_SR**

|                         |                         |                       |                 |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0130             | <b>Instance</b>       | GENERAL         |  |  |
| <b>Physical Address</b> | 0x4800 23A0             |                       |                 |  |  |
| <b>Description</b>      | Fuse SR1 and SR2        |                       |                 |  |  |
| <b>Type</b>             | R                       |                       |                 |  |  |
| 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 |  |  |
| RESERVED                | FUSE_SR2                |                       | FUSE_SR1        |  |  |

| Bits  | Field Name | Description               | Type | Reset      |
|-------|------------|---------------------------|------|------------|
| 31:16 | RESERVED   | Read returns reset value. | R    | 0x00000000 |
| 15:8  | FUSE_SR2   | Fuse SR 2                 | R    | 0x00000000 |
| 7:0   | FUSE_SR1   | Fuse SR 1                 | R    | 0x00000000 |

**Table 13-140. Register Call Summary for Register CONTROL\_FUSE\_SR**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-141. CONTROL\_IVA2\_BOOTADDR**

|                         |                                                                    |                       |                 |              |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------|-----------------------|-----------------|--------------|--|--|--|--|--|--|-----------------|----------|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0190                                                        |                       |                 |              |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 2400                                                        |                       |                 |              |  |  |  |  |  |  | <b>Instance</b> | GENERAL  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register defines the physical address of the IVA2 boot loader |                       |                 |              |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                 |                       |                 |              |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |
| 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 | BOOTLOADADDR |  |  |  |  |  |  |                 | RESERVED |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name   | Description                                                                 | Type | Reset |
|-------|--------------|-----------------------------------------------------------------------------|------|-------|
| 31:10 | BOOTLOADADDR | Physical Address of the IVA2 boot loader. This is an index to a 4kByte page | R/W  | 0x0   |
| 9:0   | RESERVED     | Reserved. Write 0's for compatibility.                                      | R    | 0x0   |

**Table 13-142. Register Call Summary for Register CONTROL\_IVA2\_BOOTADDR**

SCM Functional Description

- [IVA2.2 Boot Registers: \[0\] \[1\] \[2\]](#)

SCM Register Manual

- [SCM Register Summary: \[3\]](#)

**Table 13-143. CONTROL\_IVA2\_BOOTMOD**

|                         |                                         |                       |                 |          |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|-----------------|----------|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0194                             |                       |                 |          |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 2404                             |                       |                 |          |  |  |  |  |  |  | <b>Instance</b> | GENERAL  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register defines the IVA2 bootmode |                       |                 |          |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                      |                       |                 |          |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |                 | BOOTMODE |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description               | Type | Reset |
|------|------------|---------------------------|------|-------|
| 31:4 | RESERVED   | Read returns reset value. | R    | 0x0   |
| 3:0  | BOOTMODE   | Boot mode of the IVA2     | R/W  | 0x0   |

**Table 13-144. Register Call Summary for Register CONTROL\_IVA2\_BOOTMOD**

SCM Functional Description

- [IVA2.2 Boot Registers: \[0\] \[1\]](#)

SCM Register Manual

- [SCM Register Summary: \[2\]](#)

**Table 13-145. CONTROL\_PROG\_IO2**

|                         |                               |                 |                 |                     |                      |                      |                    |                    |                    |                    |                     |             |             |             |                     |                         |                 |            |                       |                   |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|-------------------------------|-----------------|-----------------|---------------------|----------------------|----------------------|--------------------|--------------------|--------------------|--------------------|---------------------|-------------|-------------|-------------|---------------------|-------------------------|-----------------|------------|-----------------------|-------------------|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 0198                   |                 |                 |                     |                      |                      |                    |                    |                    |                    |                     |             |             |             |                     |                         | <b>Instance</b> | GENERAL    |                       |                   |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x4800 2408                   |                 |                 |                     |                      |                      |                    |                    |                    |                    |                     |             |             |             |                     |                         | <b>Instance</b> | GENERAL    |                       |                   |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | prog_io2 register description |                 |                 |                     |                      |                      |                    |                    |                    |                    |                     |             |             |             |                     |                         | <b>Instance</b> | GENERAL    |                       |                   |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                            |                 |                 |                     |                      |                      |                    |                    |                    |                    |                     |             |             |             |                     |                         | <b>Instance</b> | GENERAL    |                       |                   |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| PRG_MCBSP2_LB           | PRG_CLKOUT2_LB                | PRG_ETK_CUT2_LB | PRG_ETK_CUT1_LB | PRG_CHASSIS_AD2D_LB | PRG_CHASSIS_CLOCK_SC | PRG_CHASSIS_CLOCK_LB | PRG_CHASSIS_INT_SC | PRG_CHASSIS_INT_LB | PRG_CHASSIS_DMA_SC | PRG_CHASSIS_DMA_LB | PRG_CHASSIS_PRCM_LB | PRG_I2C1_HS | PRG_I2C2_FS | PRG_I2C3_FS | PRG_I2C3_PULLUPRESX | PRG_CHASSIS_JTAG_LB_STR | PRG_HDQ_LB      | PRG_HDQ_SC | PRG_MCSPI1_MIN_CFG_LB | PRG_MCSPI1_CS1_LB |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name           | Description                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|-------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | PRG_MCBSP2_LB        | Format used in the field name below is :<br>(programmable_group_name)_ (configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm] 0x1:<br>Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 30    | PRG_CLKOUT2_LB       | Format used in the field name below is :<br>(programmable_group_name)_ (configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm] 0x1:<br>Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 29    | PRG_ETK_CUT2_LB      | Format used in the field name below is :<br>(programmable_group_name)_ (configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm] 0x1:<br>Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 28    | PRG_ETK_CUT1_LB      | Format used in the field name below is :<br>(programmable_group_name)_ (configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm] 0x1:<br>Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 27    | PRG_CHASSIS_AD2D_LB  | Format used in the field name below is :<br>(programmable_group_name)_ (configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm] 0x1:<br>Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 26:25 | PRG_CHASSIS_CLOCK_SC | Slew rate control bits.<br>Format used in the field name below is:<br>(programmable_group_name)_ (configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bit field combinations                                                                                                                    | RW   | 0x1   |
| 24:23 | PRG_CHASSIS_CLOCK_LB | Effective TL length and farend capacitive load controls.<br>This bit allows control of programmable drive/slew control on IO cell. Format used in the field name below is:<br>(programmable_group_name)_ (configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bit field combinations            | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b>   | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 22:21       | PRG_CHASSIS_INT_SC  | Slew rate control bits.<br>Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bit field combinations                                                                                                                                                                                                                                                                                                                                                                                                                         | RW          | 0x1          |
| 20:19       | PRG_CHASSIS_INT_LB  | Effective TL length and farend capacitive load controls.<br>This bit allows control of programmable drive/slew control on IO cell. Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bit field combinations                                                                                                                                                                                                                                                                                                                 | RW          | 0x0          |
| 18:17       | PRG_CHASSIS_DMA_SC  | Slew rate control bits.<br>Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bit field combinations                                                                                                                                                                                                                                                                                                                                                                                                                         | RW          | 0x1          |
| 16:15       | PRG_CHASSIS_DMA_LB  | Effective TL length and farend capacitive load controls.<br>This bit allows control of programmable drive/slew control on IO cell. Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bit field combinations                                                                                                                                                                                                                                                                                                                 | RW          | 0x0          |
| 14          | PRG_CHASSIS_PRCM_LB | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm:<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm] 0x1:<br>Far end load = [10pF-16pF] / TL length=[1cm-6cm]                                                                                                                                                                                                                                                                                                       | RW          | 0            |
| 13:12       | PRG_I2C1_HS         | The bits select a proper resistor value for the I2C1 pullups for a given load range at FS / HS modes.<br>Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>FS mode :<br>0b00: 4,5K Ohms / 5-15pF cap.load<br>0b01: 2,1K Ohms /15-50pF cap.load<br>0b10: 860 Ohms / 50-150pF cap.load<br>0b11: Reserved<br>HS mode :<br>0b00: 1,66K Ohms / 5-12pF cap.load<br>0b01: 920 Ohms / 12-25pF cap.load<br>0b10: 500 Ohms/ 25-50pF cap.load<br>0b11: 300 Ohms/ 50-80pF cap.load<br>See <a href="#">Table 13-24</a> for example [LB1:LB0] bit field vs PRG_I2C1_PULLUPRESX bit combinations.   | RW          | 0x0          |
| 11:10       | PRG_I2C2_FS         | The bits select a proper resistor value for the I2C2 pull-ups for a given load range at FS / HS modes.<br>Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>FS mode :<br>0b00: 4,5K Ohms / 5-15pF cap.load<br>0b01: 2,1K Ohms /15-50pF cap.load<br>0b10: 860 Ohms / 50-150pF cap.load<br>0b11: Reserved<br>HS mode :<br>0b00: 1,66K Ohms / 5-12pF cap.load<br>0b01: 920 Ohms / 12-25pF cap.load<br>0b10: 500 Ohms/ 25-50pF cap.load<br>0b11: 300 Ohms/ 50-80pF cap.load<br>See <a href="#">Table 13-24</a> for example [LB1:LB0] bit field vs PRG_I2C2_PULLUPRESX bit combinations. | RW          | 0x0          |

| Bits | Field Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Type | Reset |
|------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 9:8  | PRG_I2C3_FS             | The bits select a proper resistor value for the I2C3 pull-ups for a given load range at FS / HS modes.<br>Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>FS mode :<br>0b00: 4.5K Ohms / 5-15pF cap.load<br>0b01: 2.1K Ohms / 15-50pF cap.load<br>0b10: 860 Ohms / 50-150pF cap.load<br>0b11: Reserved<br>HS mode :<br>0b00: 1.66K Ohms / 5-12pF cap.load<br>0b01: 920 Ohms / 12-25pF cap.load<br>0b10: 500 Ohms/ 25-50pF cap.load<br>0b11: 300 Ohms/ 50-80pF cap.load<br>See <a href="#">Table 13-24</a> for example [LB1:LB0] bit field vs PRG_I2C3_PULLUPRESX bit combinations. | RW   | 0x0   |
| 7    | PRG_I2C3_PULLUPRESX     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>I2C3 pad group control for internal pull-up resistors enable:<br>0x0 : Enables internal pull-ups for the I2C3 pad group<br>0x1: Disables internal pull-ups for the I2C3 pad group                                                                                                                                                                                                                                                                                                                                                  | RW   | 0x1   |
| 6    | PRG_CHASSIS_JTAG_LB_STR | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm:<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm] 0x1:<br>Far end load = [10pF-16pF] / TL length=[1cm-6cm]                                                                                                                                                                                                                                                                                                        | RW   | 0     |
| 5:4  | PRG_HDQ_LB              | Effective TL length and farend capacitive load controls.<br>This bit allows control of programmable drive/slew control on IO cell. Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations !                                                                                                                                                                                                                                                                                                                 | RW   | 0x0   |
| 3:2  | PRG_HDQ_SC              | Slew rate control bits.<br>Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations !                                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0x0   |
| 1    | PRG_MCSPI1_MIN_CFG_LB   | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm:<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm] 0x1:<br>Far end load = [10pF-16pF] / TL length=[1cm-6cm]                                                                                                                                                                                                                                                                                                        | RW   | 0     |
| 0    | PRG_MCSPI1_CS1_LB       | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm:<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm] 0x1:<br>Far end load = [10pF-16pF] / TL length=[1cm-6cm]                                                                                                                                                                                                                                                                                                        | RW   | 0     |

**Table 13-146. Register Call Summary for Register CONTROL\_PROG\_IO2**

## SCM Functional Description

- [Signal Integrity Parameter Controls Overview: \[0\]](#)
- [Device Interfaces Signal Group Controls Mapping: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\]](#)

## SCM Programming Model

- [I2C I/O Internal Pullup Enable: \[22\]](#)
- [MCBSP2 I/O Far End Load Settings: \[23\]](#)
- [MCSPI1 I/O Far End Load Settings: \[24\] \[25\]](#)

## SCM Register Manual

- [SCM Register Summary: \[26\]](#)

**Table 13-147. CONTROL\_MEM\_RTA\_CTRL**

|                         |                                           |                         |                 |                 |                |
|-------------------------|-------------------------------------------|-------------------------|-----------------|-----------------|----------------|
| <b>Address Offset</b>   | 0x0000 019C                               | <b>Physical Address</b> | 0x4800 240C     | <b>Instance</b> | GENERAL        |
| <b>Description</b>      | control_mem_rta_ctrl register description |                         |                 |                 |                |
| <b>Type</b>             | RW                                        |                         |                 |                 |                |
| 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 |                 |                |
|                         |                                           |                         |                 |                 | HD_MEM_RTA_SEL |
|                         |                                           |                         |                 | RESERVED        |                |

| Bits | Field Name     | Description                                                                                                           | Type | Reset       |
|------|----------------|-----------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED       | Reserved field                                                                                                        | R    | 0x0000 0000 |
| 0    | HD_MEM_RTA_SEL | Device level control for selection of RTA feature of HD memories in the device<br>1 : RTA enabled<br>0 : RTA disabled | RW   | 0x1         |

**Table 13-148. Register Call Summary for Register CONTROL\_MEM\_RTA\_CTRL**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-149. CONTROL\_DEBOBS\_0**

|                         |                                                               |                         |                 |                 |         |
|-------------------------|---------------------------------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 01B0                                                   | <b>Physical Address</b> | 0x4800 2420     | <b>Instance</b> | GENERAL |
| <b>Description</b>      | Select the set of signals to be observed for hw_dbg0, hw_dbg1 |                         |                 |                 |         |
| <b>Type</b>             | RW                                                            |                         |                 |                 |         |
| 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 |                 |         |
| RESERVED                | OBSMUX0                                                       | RESERVED                | OBSMUX1         |                 |         |

| Bits  | Field Name | Description                                              | Type | Reset |
|-------|------------|----------------------------------------------------------|------|-------|
| 31:23 | RESERVED   | Read returns reset value.                                | R    | 0x00  |
| 22:16 | OBSMUX0    | Select the set of signals to be exported for WKUPOBSMUX0 | RW   | 0x000 |
| 15:7  | RESERVED   | Read returns reset value.                                | R    | 0x00  |
| 6:0   | OBSMUX1    | Select the set of signals to be exported for WKUPOBSMUX1 | RW   | 0x000 |

**Table 13-150. Register Call Summary for Register CONTROL\_DEBOBS\_0**

SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\]](#)

SCM Register Manual

- [SCM Register Summary: \[3\]](#)

**Table 13-151. CONTROL\_DEBOBS\_1**

| <b>Address Offset</b>   | 0x0000 01B4                                                   |                                                          |                 |         |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------|----------------------------------------------------------|-----------------|---------|--|--|--|----------|--|--|-----------------|-------------|--------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x4800 2424                                                   |                                                          |                 |         |  |  |  |          |  |  | <b>Instance</b> | GENERAL     |              |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Select the set of signals to be observed for hw_dbg2, hw_dbg3 |                                                          |                 |         |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                            |                                                          |                 |         |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
| 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 |         |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                                               |                                                          |                 | OBSMUX2 |  |  |  | RESERVED |  |  |                 | OBSMUX3     |              |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                    | <b>Description</b>                                       |                 |         |  |  |  |          |  |  |                 | <b>Type</b> | <b>Reset</b> |  |  |  |  |  |  |  |  |  |  |  |
| 31:23                   | RESERVED                                                      | Read returns reset value.                                |                 |         |  |  |  |          |  |  |                 | R           | 0x00         |  |  |  |  |  |  |  |  |  |  |  |
| 22:16                   | OBSMUX2                                                       | Select the set of signals to be exported for WKUPOBSMUX2 |                 |         |  |  |  |          |  |  |                 | RW          | 0x000        |  |  |  |  |  |  |  |  |  |  |  |
| 15:7                    | RESERVED                                                      | Read returns reset value.                                |                 |         |  |  |  |          |  |  |                 | R           | 0x00         |  |  |  |  |  |  |  |  |  |  |  |
| 6:0                     | OBSMUX3                                                       | Select the set of signals to be exported for WKUPOBSMUX3 |                 |         |  |  |  |          |  |  |                 | RW          | 0x000        |  |  |  |  |  |  |  |  |  |  |  |

**Table 13-152. Register Call Summary for Register CONTROL\_DEBOBS\_1**

## SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\]](#)

## SCM Register Manual

- [SCM Register Summary: \[3\]](#)

**Table 13-153. CONTROL\_DEBOBS\_2**

| <b>Address Offset</b>   | 0x0000 01B8                                                   |                                                          |                 |         |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------|----------------------------------------------------------|-----------------|---------|--|--|--|----------|--|--|-----------------|-------------|--------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x4800 2428                                                   |                                                          |                 |         |  |  |  |          |  |  | <b>Instance</b> | GENERAL     |              |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Select the set of signals to be observed for hw_dbg4, hw_dbg5 |                                                          |                 |         |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                            |                                                          |                 |         |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
| 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 |         |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                                               |                                                          |                 | OBSMUX4 |  |  |  | RESERVED |  |  |                 | OBSMUX5     |              |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                    | <b>Description</b>                                       |                 |         |  |  |  |          |  |  |                 | <b>Type</b> | <b>Reset</b> |  |  |  |  |  |  |  |  |  |  |  |
| 31:23                   | RESERVED                                                      | Read returns reset value.                                |                 |         |  |  |  |          |  |  |                 | R           | 0x00         |  |  |  |  |  |  |  |  |  |  |  |
| 22:16                   | OBSMUX4                                                       | Select the set of signals to be exported for WKUPOBSMUX4 |                 |         |  |  |  |          |  |  |                 | RW          | 0x000        |  |  |  |  |  |  |  |  |  |  |  |
| 15:7                    | RESERVED                                                      | Read returns reset value.                                |                 |         |  |  |  |          |  |  |                 | R           | 0x00         |  |  |  |  |  |  |  |  |  |  |  |
| 6:0                     | OBSMUX5                                                       | Select the set of signals to be exported for WKUPOBSMUX5 |                 |         |  |  |  |          |  |  |                 | RW          | 0x000        |  |  |  |  |  |  |  |  |  |  |  |

**Table 13-154. Register Call Summary for Register CONTROL\_DEBOBS\_2**

## SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\]](#)

## SCM Register Manual

- [SCM Register Summary: \[3\]](#)

**Table 13-155. CONTROL\_DEBOBS\_3**

| <b>Address Offset</b>   | 0x0000 01BC                                                   |                                                          |                 |         |  |  |  |          |                 |         |  |         |  |  |  |      |       |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------|----------------------------------------------------------|-----------------|---------|--|--|--|----------|-----------------|---------|--|---------|--|--|--|------|-------|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x4800 242C                                                   |                                                          |                 |         |  |  |  |          | <b>Instance</b> | GENERAL |  |         |  |  |  |      |       |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Select the set of signals to be observed for hw_dbg6, hw_dbg7 |                                                          |                 |         |  |  |  |          |                 |         |  |         |  |  |  |      |       |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                            |                                                          |                 |         |  |  |  |          |                 |         |  |         |  |  |  |      |       |  |  |  |  |  |  |  |  |
| 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 |         |  |  |  |          |                 |         |  |         |  |  |  |      |       |  |  |  |  |  |  |  |  |
| RESERVED                |                                                               |                                                          |                 | OBSMUX6 |  |  |  | RESERVED |                 |         |  | OBSMUX7 |  |  |  |      |       |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                    | <b>Description</b>                                       |                 |         |  |  |  |          |                 |         |  |         |  |  |  | Type | Reset |  |  |  |  |  |  |  |  |
| 31:23                   | RESERVED                                                      | Read returns reset value.                                |                 |         |  |  |  |          |                 |         |  |         |  |  |  | R    | 0x00  |  |  |  |  |  |  |  |  |
| 22:16                   | OBSMUX6                                                       | Select the set of signals to be exported for WKUPOBSMUX6 |                 |         |  |  |  |          |                 |         |  |         |  |  |  | RW   | 0x000 |  |  |  |  |  |  |  |  |
| 15:7                    | RESERVED                                                      | Read returns reset value.                                |                 |         |  |  |  |          |                 |         |  |         |  |  |  | R    | 0x00  |  |  |  |  |  |  |  |  |
| 6:0                     | OBSMUX7                                                       | Select the set of signals to be exported for WKUPOBSMUX7 |                 |         |  |  |  |          |                 |         |  |         |  |  |  | RW   | 0x000 |  |  |  |  |  |  |  |  |

**Table 13-156. Register Call Summary for Register CONTROL\_DEBOBS\_3**

SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\]](#)

SCM Register Manual

- [SCM Register Summary: \[3\]](#)

**Table 13-157. CONTROL\_DEBOBS\_4**

| <b>Address Offset</b>   | 0x0000 01C0                                                   |                                                          |                 |         |  |  |  |          |                 |         |  |         |  |  |  |      |       |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------|----------------------------------------------------------|-----------------|---------|--|--|--|----------|-----------------|---------|--|---------|--|--|--|------|-------|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x4800 2430                                                   |                                                          |                 |         |  |  |  |          | <b>Instance</b> | GENERAL |  |         |  |  |  |      |       |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Select the set of signals to be observed for hw_dbg8, hw_dbg9 |                                                          |                 |         |  |  |  |          |                 |         |  |         |  |  |  |      |       |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                            |                                                          |                 |         |  |  |  |          |                 |         |  |         |  |  |  |      |       |  |  |  |  |  |  |  |  |
| 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 |         |  |  |  |          |                 |         |  |         |  |  |  |      |       |  |  |  |  |  |  |  |  |
| RESERVED                |                                                               |                                                          |                 | OBSMUX8 |  |  |  | RESERVED |                 |         |  | OBSMUX9 |  |  |  |      |       |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                    | <b>Description</b>                                       |                 |         |  |  |  |          |                 |         |  |         |  |  |  | Type | Reset |  |  |  |  |  |  |  |  |
| 31:23                   | RESERVED                                                      | Read returns reset value.                                |                 |         |  |  |  |          |                 |         |  |         |  |  |  | R    | 0x00  |  |  |  |  |  |  |  |  |
| 22:16                   | OBSMUX8                                                       | Select the set of signals to be exported for WKUPOBSMUX8 |                 |         |  |  |  |          |                 |         |  |         |  |  |  | RW   | 0x000 |  |  |  |  |  |  |  |  |
| 15:7                    | RESERVED                                                      | Read returns reset value.                                |                 |         |  |  |  |          |                 |         |  |         |  |  |  | R    | 0x00  |  |  |  |  |  |  |  |  |
| 6:0                     | OBSMUX9                                                       | Select the set of signals to be exported for WKUPOBSMUX9 |                 |         |  |  |  |          |                 |         |  |         |  |  |  | RW   | 0x000 |  |  |  |  |  |  |  |  |

**Table 13-158. Register Call Summary for Register CONTROL\_DEBOBS\_4**

SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\]](#)

SCM Register Manual

- [SCM Register Summary: \[3\]](#)

**Table 13-159. CONTROL\_DEBOBS\_5**

| <b>Address Offset</b>   | 0x0000 01C4                                                     |                                                           |                 |          |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------|-----------------------------------------------------------|-----------------|----------|--|--|--|----------|--|--|-----------------|-------------|--------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x4800 2434                                                     |                                                           |                 |          |  |  |  |          |  |  | <b>Instance</b> | GENERAL     |              |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Select the set of signals to be observed for hw_dbg10, hw_dbg11 |                                                           |                 |          |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                              |                                                           |                 |          |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
| 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 |          |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                                                 |                                                           |                 | OBSMUX10 |  |  |  | RESERVED |  |  |                 | OBSMUX11    |              |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                      | <b>Description</b>                                        |                 |          |  |  |  |          |  |  |                 | <b>Type</b> | <b>Reset</b> |  |  |  |  |  |  |  |  |  |  |  |
| 31:23                   | RESERVED                                                        | Read returns reset value.                                 |                 |          |  |  |  |          |  |  |                 | R           | 0x00         |  |  |  |  |  |  |  |  |  |  |  |
| 22:16                   | OBSMUX10                                                        | Select the set of signals to be exported for WKUPOBSMUX10 |                 |          |  |  |  |          |  |  |                 | RW          | 0x000        |  |  |  |  |  |  |  |  |  |  |  |
| 15:7                    | RESERVED                                                        | Read returns reset value.                                 |                 |          |  |  |  |          |  |  |                 | R           | 0x00         |  |  |  |  |  |  |  |  |  |  |  |
| 6:0                     | OBSMUX11                                                        | Select the set of signals to be exported for WKUPOBSMUX11 |                 |          |  |  |  |          |  |  |                 | RW          | 0x000        |  |  |  |  |  |  |  |  |  |  |  |

**Table 13-160. Register Call Summary for Register CONTROL\_DEBOBS\_5**

## SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\]](#)

## SCM Register Manual

- [SCM Register Summary: \[3\]](#)

**Table 13-161. CONTROL\_DEBOBS\_6**

| <b>Address Offset</b>   | 0x0000 01C8                                                     |                                                           |                 |          |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------|-----------------------------------------------------------|-----------------|----------|--|--|--|----------|--|--|-----------------|-------------|--------------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x4800 2438                                                     |                                                           |                 |          |  |  |  |          |  |  | <b>Instance</b> | GENERAL     |              |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Select the set of signals to be observed for hw_dbg12, hw_dbg13 |                                                           |                 |          |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                              |                                                           |                 |          |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
| 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 |          |  |  |  |          |  |  |                 |             |              |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                                                 |                                                           |                 | OBSMUX12 |  |  |  | RESERVED |  |  |                 | OBSMUX13    |              |  |  |  |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                      | <b>Description</b>                                        |                 |          |  |  |  |          |  |  |                 | <b>Type</b> | <b>Reset</b> |  |  |  |  |  |  |  |  |  |  |  |
| 31:23                   | RESERVED                                                        | Read returns reset value.                                 |                 |          |  |  |  |          |  |  |                 | R           | 0x00         |  |  |  |  |  |  |  |  |  |  |  |
| 22:16                   | OBSMUX12                                                        | Select the set of signals to be exported for WKUPOBSMUX12 |                 |          |  |  |  |          |  |  |                 | RW          | 0x000        |  |  |  |  |  |  |  |  |  |  |  |
| 15:7                    | RESERVED                                                        | Read returns reset value.                                 |                 |          |  |  |  |          |  |  |                 | R           | 0x00         |  |  |  |  |  |  |  |  |  |  |  |
| 6:0                     | OBSMUX13                                                        | Select the set of signals to be exported for WKUPOBSMUX13 |                 |          |  |  |  |          |  |  |                 | RW          | 0x000        |  |  |  |  |  |  |  |  |  |  |  |

**Table 13-162. Register Call Summary for Register CONTROL\_DEBOBS\_6**

## SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\]](#)

## SCM Register Manual

- [SCM Register Summary: \[3\]](#)

**Table 13-163. CONTROL\_DEBOBS\_7**

| <b>Address Offset</b>   | 0x0000 01CC                                                     |                                                           |                 |          |  |  |  |          |                 |         |  |          |  |  |  |      |       |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------|-----------------------------------------------------------|-----------------|----------|--|--|--|----------|-----------------|---------|--|----------|--|--|--|------|-------|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x4800 243C                                                     |                                                           |                 |          |  |  |  |          | <b>Instance</b> | GENERAL |  |          |  |  |  |      |       |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Select the set of signals to be observed for hw_dbg14, hw_dbg15 |                                                           |                 |          |  |  |  |          |                 |         |  |          |  |  |  |      |       |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                              |                                                           |                 |          |  |  |  |          |                 |         |  |          |  |  |  |      |       |  |  |  |  |  |  |  |  |
| 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 |          |  |  |  |          |                 |         |  |          |  |  |  |      |       |  |  |  |  |  |  |  |  |
| RESERVED                |                                                                 |                                                           |                 | OBSMUX14 |  |  |  | RESERVED |                 |         |  | OBSMUX15 |  |  |  |      |       |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                      | <b>Description</b>                                        |                 |          |  |  |  |          |                 |         |  |          |  |  |  | Type | Reset |  |  |  |  |  |  |  |  |
| 31:23                   | RESERVED                                                        | Read returns reset value.                                 |                 |          |  |  |  |          |                 |         |  |          |  |  |  | R    | 0x00  |  |  |  |  |  |  |  |  |
| 22:16                   | OBSMUX14                                                        | Select the set of signals to be exported for WKUPOBSMUX14 |                 |          |  |  |  |          |                 |         |  |          |  |  |  | RW   | 0x000 |  |  |  |  |  |  |  |  |
| 15:7                    | RESERVED                                                        | Read returns reset value.                                 |                 |          |  |  |  |          |                 |         |  |          |  |  |  | R    | 0x00  |  |  |  |  |  |  |  |  |
| 6:0                     | OBSMUX15                                                        | Select the set of signals to be exported for WKUPOBSMUX15 |                 |          |  |  |  |          |                 |         |  |          |  |  |  | RW   | 0x000 |  |  |  |  |  |  |  |  |

**Table 13-164. Register Call Summary for Register CONTROL\_DEBOBS\_7**

SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\]](#)

SCM Register Manual

- [SCM Register Summary: \[3\]](#)

**Table 13-165. CONTROL\_DEBOBS\_8**

| <b>Address Offset</b>   | 0x0000 01D0                                                     |                                                           |                 |          |  |  |  |          |                 |         |  |          |  |  |  |      |       |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------|-----------------------------------------------------------|-----------------|----------|--|--|--|----------|-----------------|---------|--|----------|--|--|--|------|-------|--|--|--|--|--|--|--|--|
| <b>Physical Address</b> | 0x4800 2440                                                     |                                                           |                 |          |  |  |  |          | <b>Instance</b> | GENERAL |  |          |  |  |  |      |       |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Select the set of signals to be observed for hw_dbg16, hw_dbg17 |                                                           |                 |          |  |  |  |          |                 |         |  |          |  |  |  |      |       |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                              |                                                           |                 |          |  |  |  |          |                 |         |  |          |  |  |  |      |       |  |  |  |  |  |  |  |  |
| 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 |          |  |  |  |          |                 |         |  |          |  |  |  |      |       |  |  |  |  |  |  |  |  |
| RESERVED                |                                                                 |                                                           |                 | OBSMUX16 |  |  |  | RESERVED |                 |         |  | OBSMUX17 |  |  |  |      |       |  |  |  |  |  |  |  |  |
| Bits                    | Field Name                                                      | <b>Description</b>                                        |                 |          |  |  |  |          |                 |         |  |          |  |  |  | Type | Reset |  |  |  |  |  |  |  |  |
| 31:23                   | RESERVED                                                        | Read returns reset value.                                 |                 |          |  |  |  |          |                 |         |  |          |  |  |  | R    | 0x00  |  |  |  |  |  |  |  |  |
| 22:16                   | OBSMUX16                                                        | Select the set of signals to be exported for WKUPOBSMUX16 |                 |          |  |  |  |          |                 |         |  |          |  |  |  | RW   | 0x000 |  |  |  |  |  |  |  |  |
| 15:7                    | RESERVED                                                        | Read returns reset value.                                 |                 |          |  |  |  |          |                 |         |  |          |  |  |  | R    | 0x00  |  |  |  |  |  |  |  |  |
| 6:0                     | OBSMUX17                                                        | Select the set of signals to be exported for WKUPOBSMUX17 |                 |          |  |  |  |          |                 |         |  |          |  |  |  | RW   | 0x000 |  |  |  |  |  |  |  |  |

**Table 13-166. Register Call Summary for Register CONTROL\_DEBOBS\_8**

SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\]](#)

SCM Register Manual

- [SCM Register Summary: \[3\]](#)

**Table 13-167. CONTROL\_PROG\_IO0**

|                       |                               |                         |             |                 |         |
|-----------------------|-------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 01D4                   | <b>Physical Address</b> | 0x4800 2444 | <b>Instance</b> | GENERAL |
| <b>Description</b>    | prog_io0 register description |                         |             |                 |         |
| <b>Type</b>           | RW                            |                         |             |                 |         |

|              |               |              |           |                |                |                |                |                |                |                |                |                |                 |                 |                     |                    |                  |                  |                  |                  |                  |                  |                  |                  |                 |                      |                   |                 |                      |          |   |  |
|--------------|---------------|--------------|-----------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-----------------|-----------------|---------------------|--------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|-----------------|----------------------|-------------------|-----------------|----------------------|----------|---|--|
| 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 |  |
| SDRC_LOWDATA | SDRC_HIGHDATA | SDRC_ADDRCTR | SDRC_NCS0 | PRG_GPMC_A1_LB | PRG_GPMC_A2_LB | PRG_GPMC_A3_LB | PRG_GPMC_A4_LB | PRG_GPMC_A5_LB | PRG_GPMC_A6_LB | PRG_GPMC_A7_LB | PRG_GPMC_A8_LB | PRG_GPMC_A9_LB | PRG_GPMC_A10_LB | PRG_GPMC_A11_LB | PRG_GPMC_MIN_CFG_LB | PRG_GPMC_D8_D15_LB | PRG_GPMC_NCS0_LB | PRG_GPMC_NCS1_LB | PRG_GPMC_NCS2_LB | PRG_GPMC_NCS3_LB | PRG_GPMC_NCS4_LB | PRG_GPMC_NCS5_LB | PRG_GPMC_NCS6_LB | PRG_GPMC_NCS7_LB | PRG_GMPC_CLK_LB | PRG_GPMC_NBEO_CLE_LB | PRG_GPMC_NBEE1_LB | PRG_GPMC_NWP_LB | PRG_SDMMC_PUSTRENGTH | RESERVED |   |  |
|              |               |              |           |                |                |                |                |                |                |                |                |                |                 |                 |                     |                    |                  |                  |                  |                  |                  |                  |                  |                  |                 |                      |                   |                 |                      |          |   |  |
|              |               |              |           |                |                |                |                |                |                |                |                |                |                 |                 |                     |                    |                  |                  |                  |                  |                  |                  |                  |                  |                 |                      |                   |                 |                      |          |   |  |

| Bits | Field Name     | Description                                                                                                                                                                                                                                                                                                                           | Type | Reset |
|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31   | SDRC_LOWDATA   | This bit allows for drive strength control on DDR output buffer for high speed operations. Format used in the field name below is : (programmable_group_name)_ (configurable_pin on IO cell)<br><br>Drive strength for output load:<br>0x0: Load range = [2 pF-4 pF]<br>0x1: Load range = [4 pF-12 pF]                                | RW   | 0     |
| 30   | SDRC_HIGHDATA  | This bit allows for drive strength control on DDR output buffer for high speed operations. Format used in the field name below is : (programmable_group_name)_ (configurable_pin on IO cell)<br><br>Drive strength for output load:<br>0x0: Load range = [2 pF-4 pF]<br>0x1: Load range = [4 pF-12 pF]                                | RW   | 0     |
| 29   | SDRC_ADDRCTR   | This bit allows for drive strength control on DDR output buffer for high speed operations. Format used in the field name below is : (programmable_group_name)_ (configurable_pin on IO cell)<br><br>Drive strength for output load:<br>0x0: Load range = [2 pF-4 pF]<br>0x1: Load range = [4 pF-12 pF]                                | RW   | 0     |
| 28   | SDRC_NCS0      | This bit allows for drive strength control on DDR output buffer for high speed operations. Format used in the field name below is : (programmable_group_name)_ (configurable_pin on IO cell)<br><br>Drive strength for output load:<br>0x0: Load range = [2 pF-4 pF]<br>0x1: Load range = [4 pF-12 pF]                                | RW   | 0     |
| 27   | SDRC_NCS1      | This bit allows for drive strength control on DDR output buffer for high speed operations. Format used in the field name below is : (programmable_group_name)_ (configurable_pin on IO cell)<br><br>Drive strength for output load:<br>0x0: Load range = [2 pF-4 pF]<br>0x1: Load range = [4 pF-12 pF]                                | RW   | 0     |
| 26   | PRG_GPMC_A1_LB | Format used in the field name below is : (programmable_group_name)_ (configurable_pin on IO cell)<br><br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |

| <b>Bits</b> | <b>Field Name</b>   | <b>Description</b>                                                                                                                                                                                                                                                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 25          | PRG_GPMC_A2_LB      | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 24          | PRG_GPMC_A3_LB      | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 23          | PRG_GPMC_A4_LB      | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 22          | PRG_GPMC_A5_LB      | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 21          | PRG_GPMC_A6_LB      | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 20          | PRG_GPMC_A7_LB      | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 19          | PRG_GPMC_A8_LB      | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 18          | PRG_GPMC_A9_LB      | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 17          | PRG_GPMC_A10_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 16          | PRG_GPMC_A11_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 15          | PRG_GPMC_MIN_CFG_LB | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |

| Bits | Field Name           | Description                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 14   | PRG_GPMC_D8_D15_LB   | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 13   | PRG_GPMC_NCS0_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 12   | PRG_GPMC_NCS1_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 11   | PRG_GPMC_NCS2_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 10   | PRG_GPMC_NCS3_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 9    | PRG_GPMC_NCS4_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 8    | PRG_GPMC_NCS5_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 7    | PRG_GPMC_NCS6_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 6    | PRG_GPMC_NCS7_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 5    | PRG_GPMC_CLK_LB      | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 4    | PRG_GPMC_NBE0_CLE_LB | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |

| Bits | Field Name           | Description                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3    | PRG_GPMC_NBE1_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 2    | PRG_GPMC_NWP_LB      | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 1    | PRG_SDMMC_PUSTRENGTH | This bit allows control of programmable pullup strength on SDMMC IO cells. Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Conducting pullup with :<br>0x0: 50–110 kΩ strength selected<br>0x1: 10–50 kΩ strength selected                                                   | RW   | 0     |
| 0    | RESERVED             | Reserved field                                                                                                                                                                                                                                                                                                                       | R    | 0     |

**Table 13-168. Register Call Summary for Register CONTROL\_PROG\_IO0**
**SCM Functional Description**

- [Signal Integrity Parameter Controls Overview: \[0\]](#)
- [Device Interfaces Signal Group Controls Mapping: \[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\]](#)

**SCM Programming Model**

- [SDRC I/O Drive Strength Selection: \[32\] \[33\] \[34\] \[35\] \[36\]](#)
- [GPMC I/O Far End Load Settings: \[37\] \[38\] \[39\] \[40\] \[41\] \[42\] \[43\] \[44\] \[45\] \[46\] \[47\] \[48\] \[49\] \[50\] \[51\] \[52\] \[53\] \[54\] \[55\] \[56\] \[57\] \[58\] \[59\] \[60\] \[61\]](#)

**SCM Register Manual**

- [SCM Register Summary: \[62\]](#)

**Table 13-169. CONTROL\_PROG\_IO1**

| Address Offset          | 0x0000 01D8                   |                  |                      |                 |                      |                     |                   |               |                       |                   |              |              |              |                      |                    | GENERAL       |               |               |                   |                   |               |                     |              |
|-------------------------|-------------------------------|------------------|----------------------|-----------------|----------------------|---------------------|-------------------|---------------|-----------------------|-------------------|--------------|--------------|--------------|----------------------|--------------------|---------------|---------------|---------------|-------------------|-------------------|---------------|---------------------|--------------|
| Physical Address        | 0x4800 2448                   |                  |                      |                 |                      |                     |                   |               |                       |                   |              |              |              |                      |                    | GENERAL       |               |               |                   |                   |               |                     |              |
| Description             | prog_io1 register description |                  |                      |                 |                      |                     |                   |               |                       |                   |              |              |              |                      |                    | GENERAL       |               |               |                   |                   |               |                     |              |
| Type                    | RW                            |                  |                      |                 |                      |                     |                   |               |                       |                   |              |              |              |                      |                    | GENERAL       |               |               |                   |                   |               |                     |              |
| 31 30 29 28 27 26 25 24 | PRG_GPMC_WAIT1_LB             | PRG_DISP_DATA_LB | PRG_CAM_SIDEBOARD_LB | PRG_CAM_DATA_LB | PRG_SDMMC1_SPEEDCTRL | PRG_I2C1_PULLUPRESX | PRG_HSUSB0_CLK_LB | PRG_HSUSB0_LB | PRG_SDMMC2_MIN_CFG_LB | PRG_SDMMC2_EXT_LB | PRG_UART1_LB | PRG_UART3_SC | PRG_UART3_LB | PRG_MCBSP1_DUPLEX_LB | PRG_MCBSP1_CLKS_LB | PRG_MCBSP1_LB | PRG_MCBSP3_LB | PRG_MCBSP4_LB | PRG_MCSPI1_CS2_LB | PRG_MCSPI1_CS3_LB | PRG_MCSPI2_LB | PRG_I2C2_PULLUPRESX | PRG_UART2_LB |

| Bits | Field Name        | Description                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31   | PRG_GPMC_WAIT1_LB | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |

## SCM Register Manual

www.ti.com

| Bits  | Field Name            | Description                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|-------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 30    | PRG_GPMC_WAIT2_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 29    | PRG_GPMC_WAIT3_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 28    | PRG_DISP_SIDEBOARD_LB | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 27:26 | PRG_DISP_DSI_SC       | Slew rate control bits.<br>Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations !                                                                                                                  | RW   | 0x0   |
| 25:24 | PRG_DISP_DSI_LB       | Effective TL length and farend capacitive load controls.<br>This bit allows control of programmable drive/slew control on IO cell. Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations !          | RW   | 0x0   |
| 23    | PRG_DISP_DATA_LB      | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 22    | PRG_CAM_SIDEBOARD_LB  | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 21    | PRG_CAM_DATA_LB       | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 20    | PRG_SDMMC1_SPEEDCTRL  | Speed Control for MMC I/O<br>0b0 : 26 MHz I/O max speed<br>0b1 : 52 MHz I/O max speed                                                                                                                                                                                                                                                | RW   | 1     |
| 19    | PRG_I2C1_PULLUPRESX   | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>I2C1 pad group control for internal pull-up resistors enable:<br>0x0 : Enables internal pull-ups for the I2C1 pad group<br>0x1: Disables internal pull-ups for the I2C1 pad group                                            | RW   | 0     |
| 18    | PRG_HSUSB0_CLK_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |

| <b>Bits</b> | <b>Field Name</b>     | <b>Description</b>                                                                                                                                                                                                                                                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 17          | PRG_HSUSB0_LB         | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 16          | PRG_SDMMC2_MIN_CFG_LB | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 15          | PRG_SDMMC2_EXT_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 14          | PRG_UART1_LB          | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 13:12       | PRG_UART3_SC          | Slew rate control bits.<br>Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations !                                                                                                                  | RW          | 0x0          |
| 11:10       | PRG_UART3_LB          | Effective TL length and farend capacitive load controls.<br>This bit allows control of programmable drive/slew control on IO cell. Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations !          | RW          | 0x0          |
| 9           | PRG_MCBSP1_DUPLEX_LB  | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 8           | PRG_MCBSP_CLKS_LB     | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 7           | PRG_MCBSP1_LB         | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 6           | PRG_MCBSP3_LB         | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 5           | PRG_MCBSP4_LB         | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |

| Bits | Field Name          | Description                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4    | PRG_MCSPI1_CS2_LB   | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 3    | PRG_MCSPI1_CS3_LB   | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 2    | PRG_MCSPI2_LB       | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 1    | PRG_UART2_LB        | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm :<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW   | 0     |
| 0    | PRG_I2C2_PULLUPRESX | Format used in the field name below is :<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>I2C2 pad group control for internal pull-up resistors enable:<br>0x0 : Enables internal pull-ups for the I2C2 pad group<br>0x1: Disables internal pull-ups for the I2C2 pad group                                            | RW   | 1     |

**Table 13-170. Register Call Summary for Register CONTROL\_PROG\_IO1**

## SCM Functional Description

- [Extended-Drain I/O Pin and PBIAS Cells: \[0\] \[1\] \[2\]](#)
- [Extended-Drain I/Os: \[3\]](#)
- [Signal Integrity Parameter Controls Overview: \[4\]](#)
- [Device Interfaces Signal Group Controls Mapping: \[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\]](#)

## SCM Programming Model

- [I2C I/O Internal Pullup Enable: \[32\] \[33\]](#)
- [GPMC I/O Far End Load Settings: \[34\] \[35\] \[36\]](#)
- [MCSPI1 I/O Far End Load Settings: \[37\] \[38\]](#)
- [Extended-Drain I/Os and PBIAS Cells Programming Guide: \[39\] \[40\]](#)
- [Speed Control and Voltage Supply State: \[41\]](#)

## SCM Register Manual

- [SCM Register Summary: \[42\]](#)

**Table 13-171. CONTROL\_DSS\_DPLL\_SPREADING**

|                         |                                                 |                 |         |
|-------------------------|-------------------------------------------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 01E0                                     |                 |         |
| <b>Physical Address</b> | 0x4800 2450                                     | <b>Instance</b> | GENERAL |
| <b>Description</b>      | control_dss_dpll_spreading register description |                 |         |
| <b>Type</b>             | RW                                              |                 |         |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

RESERVED

Q\_DSS\_SPREADING\_SIDE  
DSS\_SPREADING\_ENABLE\_STATUS  
RESERVED  
DSS\_SPREADING\_ENABLE  
RESERVED

| Bits | Field Name                  | Description                                                                                                                                               | Type | Reset    |
|------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED                    | Read returns reset value                                                                                                                                  | R    | 0x000000 |
| 8    | Q_DSS_SPREADING_SIDE        | 0 : Enables both side frequency spread about the programmed frequency<br>1 : Enables low frequency spread only                                            | RW   | 0        |
| 7    | DSS_SPREADING_ENABLE_STATUS | Indicates the status of the SSC feature                                                                                                                   | R    | -        |
| 6:5  | RESERVED                    | Read returns reset value                                                                                                                                  | R    | 0x0      |
| 4    | DSS_SPREADING_ENABLE        | Enables/disables EMI reduction feature (spreading):<br>0: Modulation stops at the end of the current modulation cycle.<br>1: Modulation cycle is started. | RW   | 0        |
| 3:0  | RESERVED                    | Reserved field                                                                                                                                            | R    | 0x0      |

**Table 13-172. Register Call Summary for Register CONTROL\_DSS\_DPLL\_SPREADING**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-173. CONTROL\_CORE\_DPLL\_SPREADING**

| Address Offset     | 0x0000 01E4 | Physical Address                                 | 0x4800 2454 | Instance | GENERAL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------------|-------------|--------------------------------------------------|-------------|----------|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Description</b> |             | control_core_dpll_spreading register description |             |          |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>        |             | RW                                               |             |          |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
|                    |             |                                                  |             |          |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

RESERVED

Q\_CORE\_SPREADING\_SIDE  
CORE\_SPREADING\_ENABLE\_STATUS  
RESERVED  
CORE\_SPREADING\_ENABLE  
RESERVED

| Bits | Field Name                   | Description                                                                                                                                               | Type | Reset    |
|------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED                     | Read returns reset value.                                                                                                                                 | R    | 0x000000 |
| 8    | Q_CORE_SPREADING_SIDE        | 0 : Enables both side frequency spread about the programmed frequency<br>1 : Enables low frequency spread only                                            | RW   | 0        |
| 7    | CORE_SPREADING_ENABLE_STATUS | Indicates the status of the SSC feature                                                                                                                   | R    | -        |
| 6:5  | RESERVED                     | Read returns reset value                                                                                                                                  | R    | 0x0      |
| 4    | CORE_SPREADING_ENABLE        | Enables/disables EMI reduction feature (spreading):<br>0: Modulation stops at the end of the current modulation cycle.<br>1: Modulation cycle is started. | RW   | 0        |
| 3:0  | RESERVED                     | Reserved field                                                                                                                                            | R    | 0x0      |

**Table 13-174. Register Call Summary for Register CONTROL\_CORE\_DPLL\_SPREADING**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-175. CONTROL\_PER\_DPLL\_SPREADING**

| Address Offset   | 0x0000 01E8                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |                             |          |                      |          |   |   |   |   |   |   |   |   |   |   |
|------------------|-------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------|-----------------------------|----------|----------------------|----------|---|---|---|---|---|---|---|---|---|---|
| Physical Address | 0x4800 2458                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Instance             |                             |          |                      |          |   |   |   |   |   |   |   |   |   |   |
| Description      | control_per_dpll_spreading register description |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | GENERAL              |                             |          |                      |          |   |   |   |   |   |   |   |   |   |   |
| Type             | RW                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |                             |          |                      |          |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED         |                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Q_PER_SPREADING_SIDE | PER_SPREADING_ENABLE_STATUS | RESERVED | PER_SPREADING_ENABLE | RESERVED |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name                  | Description                                                                                                                                               | Type | Reset    |
|------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED                    | Read returns reset value                                                                                                                                  | R    | 0x000000 |
| 8    | Q_PER_SPREADING_SIDE        | 0 : Enables both side frequency spread about the programmed frequency<br>1 : Enables low frequency spread only                                            | RW   | 0        |
| 7    | PER_SPREADING_ENABLE_STATUS | Indicates the status of the SSC feature.                                                                                                                  | R    | -        |
| 6:5  | RESERVED                    | Read returns reset value                                                                                                                                  | R    | 0x0      |
| 4    | PER_SPREADING_ENABLE        | Enables/disables EMI reduction feature (spreading):<br>0: Modulation stops at the end of the current modulation cycle.<br>1: Modulation cycle is started. | RW   | 0        |
| 3:0  | RESERVED                    | Reserved field                                                                                                                                            | R    | 0x0      |

**Table 13-176. Register Call Summary for Register CONTROL\_PER\_DPLL\_SPREADING**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-177. CONTROL\_USBHOST\_DPLL\_SPREADING**

|                         |                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                    |         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|-----------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------------------------------------------------------------|---------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 01EC                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b>                                                                                    | GENERAL |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x4800 245C                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b>                                                                                    | GENERAL |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | control_usbhost_dpll_spreading register description |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Type</b>                                                                                        | GENERAL |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>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</b> |         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |

RESERVED

Q\_USBHOST\_SPREADING\_SIDE  
USBHOST\_SPREADING\_ENABLE\_STATUS  
RESERVED  
USBHOST\_SPREADING\_ENABLE  
RESERVED

| Bits | Field Name                      | Description                                                                                                                                               | Type | Reset     |
|------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:9 | RESERVED                        | Read returns reset value.                                                                                                                                 | R    | 0x0000000 |
| 8    | Q_USBHOST_SPREADING_SIDE_E      | 0 : Enables both side frequency spread about the programmed frequency<br>1 : Enables low frequency spread only                                            | RW   | 0         |
| 7    | USBHOST_SPREADING_ENABLE_STATUS | Indicates the status of the SSC feature.                                                                                                                  | R    | -         |
| 6:5  | RESERVED                        | Read returns reset value                                                                                                                                  | R    | 0         |
| 4    | USBHOST_SPREADING_ENABLE        | Enables/disables EMI reduction feature (spreading):<br>0: Modulation stops at the end of the current modulation cycle.<br>1: Modulation cycle is started. | RW   | 0         |
| 3:0  | RESERVED                        | Reserved field                                                                                                                                            | R    | 0x0       |

**Table 13-178. Register Call Summary for Register CONTROL\_USBHOST\_DPLL\_SPREADING**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-179. CONTROL\_SDRC\_SHARING**

|                                 |                                     |                         |                 |                 |             |
|---------------------------------|-------------------------------------|-------------------------|-----------------|-----------------|-------------|
| <b>Address Offset</b>           | 0x0000 01F0                         | <b>Physical Address</b> | 0x4800 2460     | <b>Instance</b> | GENERAL     |
| <b>Description</b>              | SDRC Sharing configuration register |                         |                 |                 |             |
| <b>Type</b>                     | RW                                  |                         |                 |                 |             |
| 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 |                 |             |
| RESERVED<br><br>SDRCSHARINGLOCK |                                     |                         |                 |                 | SDRCSHARING |

| Bits | Field Name      | Description                                                                                                           | Type     | Reset      |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------|----------|------------|
| 31   | RESERVED        | Reserved for non-GP devices                                                                                           | Reserved | 0x0        |
| 30   | SDRCSHARINGLOCK | Exported value to SDRC.SDRC_SHARING[30]<br>For more information, see <a href="#">Section 13.4.9, SDRC Registers</a>   | R/W      | 0x0        |
| 29:0 | SDRCSHARING     | Exported value to SDRC.SDRC_SHARING[29:0]<br>For more information, see <a href="#">Section 13.4.9, SDRC Registers</a> | R/W      | 0x00002700 |

**Table 13-180. Register Call Summary for Register CONTROL\_SDRC\_SHARING**

SCM Functional Description

- [SDRC Registers: \[0\] \[1\] \[2\]](#)

SCM Register Manual

- [SCM Register Summary: \[3\]](#)

**Table 13-181. CONTROL\_SDRC\_MCFG0**

|                               |                                    |                         |                 |                 |           |
|-------------------------------|------------------------------------|-------------------------|-----------------|-----------------|-----------|
| <b>Address Offset</b>         | 0x0000 01F4                        | <b>Physical Address</b> | 0x4800 2464     | <b>Instance</b> | GENERAL   |
| <b>Description</b>            | SDRC MCFG Configuration register-0 |                         |                 |                 |           |
| <b>Type</b>                   | RW                                 |                         |                 |                 |           |
| 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 |                 |           |
| RESERVED<br><br>SDRCMCFG0LOCK |                                    |                         |                 |                 | SDRCMCFG0 |

| Bits | Field Name    | Description                                                                                                          | Type     | Reset      |
|------|---------------|----------------------------------------------------------------------------------------------------------------------|----------|------------|
| 31   | RESERVED      | Reserved for non-GP devices                                                                                          | Reserved | 0x0        |
| 30   | SDRCMCFG0LOCK | Exported value to SDRC.SDRC_MCFG_0[30]<br>For more information, see <a href="#">Section 13.4.9, SDRC Registers</a>   | R/W      | 0x0        |
| 29:0 | SDRCMCFG0     | Exported value to SDRC.SDRC_MCFG_0[29:0]<br>For more information, see <a href="#">Section 13.4.9, SDRC Registers</a> | R/W      | 0x00300000 |

**Table 13-182. Register Call Summary for Register CONTROL\_SDRC\_MCFG0**
**SCM Functional Description**

- [SDRC Registers: \[0\] \[1\] \[2\]](#)

**SCM Register Manual**

- [SCM Register Summary: \[3\]](#)

**Table 13-183. CONTROL\_SDRC\_MCFG1**

|                         |                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 01F8                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 2468                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | SDRC MCFG Configuration register-1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |               |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|---------------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED | SDRCMCFG1LOCK | SDRCMCFG1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name    | Description                                                                                                          | Type     | Reset      |
|------|---------------|----------------------------------------------------------------------------------------------------------------------|----------|------------|
| 31   | RESERVED      | Reserved for non-GP devices                                                                                          | Reserved | 0x0        |
| 30   | SDRCMCFG1LOCK | Exported value to SDRC.SDRC_MCFG_1[30]<br>For more information, see <a href="#">Section 13.4.9, SDRC Registers</a>   | R/W      | 0x0        |
| 29:0 | SDRCMCFG1     | Exported value to SDRC.SDRC_MCFG_1[29:0]<br>For more information, see <a href="#">Section 13.4.9, SDRC Registers</a> | R/W      | 0x00300000 |

**Table 13-184. Register Call Summary for Register CONTROL\_SDRC\_MCFG1**
**SCM Functional Description**

- [SDRC Registers: \[0\] \[1\] \[2\]](#)

**SCM Register Manual**

- [SCM Register Summary: \[3\]](#)

**Table 13-185. CONTROL\_MODEM\_FW\_CONFIGURATION\_LOCK**

|                         |                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 01FC                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 246C                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Allows locking of the modem isolation registers in the SCM until the next battery removal. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name          | Description                                                                                                                      | Type             | Reset      |
|------|---------------------|----------------------------------------------------------------------------------------------------------------------------------|------------------|------------|
| 31:1 | RESERVED            | Read returns reset value.                                                                                                        | R                | 0x00000000 |
| 0    | FWCONFIGURATIONLOCK | Allows locking of the modem isolation registers in the SCM until the next battery removal.<br><br>0x0: Not locked<br>0x1: Locked | See Table 13-187 | 0x0        |
|      |                     |                                                                                                                                  |                  |            |

**Table 13-186. Register Call Summary for Register CONTROL\_MODEM\_FW\_CONFIGURATION\_LOCK**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)
- [GENERAL Register Description: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\]](#)

**Table 13-187. Type Value For CONTROL\_MODEM\_FW\_CONFIGURATION\_LOCK**

|                                                                |     |   |
|----------------------------------------------------------------|-----|---|
| CONTROL_MODEM_FW_CONFIGURATION_LOCK[0] FWCONFIGURATIONLOCK bit | 0   | 1 |
| FWCONFIGURATIONLOCK                                            | R/W | R |

**Table 13-188. CONTROL\_MODEM\_MEMORY\_RESOURCES\_CONF**

|                  |                             |          |
|------------------|-----------------------------|----------|
| Address Offset   | 0x0000 0200                 |          |
| Physical Address | 0x4800 2470                 | Instance |
| Description      | Modem Memory Resources Conf |          |
| Type             | RW                          |          |

|                   |                      |                    |    |                          |    |                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                            |
|-------------------|----------------------|--------------------|----|--------------------------|----|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------------------------|
| 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                          |
| CMDWTOCMRAMSWITCH | MODEMSTACKMEMORYSIZE | MODEMSMSMEMORYSIZE |    | MODEMGPMLCRESERVEDS2SIZE |    | MODEMGPMLCRESERVEDS1SIZE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | MODEMGPMLCRESERVEDBASEADDR |

| Bits  | Field Name                 | Description                                                                                                             | Type             | Reset |
|-------|----------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------|-------|
| 31    | CMDWTOCMRAMSWITCH          | Select if CMDWT or OCMRAM is accessible by the Modem                                                                    | See Table 13-190 | 0x0   |
| 30:27 | MODEMSTACKMEMORYSIZE       | Configuration of the modem stack memory size                                                                            | See Table 13-190 | 0x0   |
| 26:22 | MODEMSMSMEMORYSIZE         | Configuration of the SMS modem memory                                                                                   | See Table 13-190 | 0x00  |
| 21:17 | MODEMGPMLCRESERVEDS2SIZE   | Configuration of the GPMC modem shared section size                                                                     | See Table 13-190 | 0x00  |
| 16:12 | MODEMGPMLCRESERVEDS1SIZE   | Configuration of the GPMC modem reserved section size                                                                   | See Table 13-190 | 0x00  |
| 11:0  | MODEMGPMLCRESERVEDBASEADDR | Configuration of the GPMC base address of the modem reserved section. This base address is configurable in 1Mbyte step. | See Table 13-190 | 0x000 |

**Table 13-189. Register Call Summary for Register  
CONTROL\_MODEM\_MEMORY\_RESOURCES\_CONF**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-190. Type Value For CONTROL\_MODEM\_MEMORY\_RESOURCES\_CONF**

| <a href="#">CONTROL_MODEM_FW_CONFIGURATION_LOCK[0] FWCONFIGURATIONLOCK bit</a> | 0   | 1 |
|--------------------------------------------------------------------------------|-----|---|
| CMDWTOCMRAMSWITCH                                                              | R/W | R |
| MODEMSTACKMEMORYSIZE                                                           | R/W | R |
| MODEMSMSMEMORYSIZE                                                             | R/W | R |
| MODEMGPMCRESERVEDS2SIZE                                                        | R/W | R |
| MODEMGPMCRESERVEDS1SIZE                                                        | R/W | R |
| MODEMGPMCRESERVEDBASEADDR                                                      | R/W | R |

**Table 13-191. CONTROL\_MODEM\_GPMC\_DT\_FW\_REQ\_INFO**

|                         |                                                   |                         |                 |                 |         |
|-------------------------|---------------------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0204                                       | <b>Physical Address</b> | 0x4800 2474     | <b>Instance</b> | GENERAL |
| <b>Description</b>      | Modem GPMC Default firewall request info register |                         |                 |                 |         |
| <b>Type</b>             | RW                                                |                         |                 |                 |         |
| 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 |                 |         |

| Bits  | Field Name           | Description                                                               | Type                                | Reset  |
|-------|----------------------|---------------------------------------------------------------------------|-------------------------------------|--------|
| 31:16 | RESERVED             | Read returns reset value.                                                 | R                                   | 0x0000 |
| 15:0  | MODEMGPMCDTFWREQINFO | Exported values to the GPMC firewall region1<br>REQ_INFO_PERMISSION field | See<br><a href="#">Table 13-193</a> | 0xFFFF |

**Table 13-192. Register Call Summary for Register CONTROL\_MODEM\_GPMC\_DT\_FW\_REQ\_INFO**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-193. Type Value For CONTROL\_MODEM\_GPMC\_DT\_FW\_REQ\_INFO**

| <a href="#">CONTROL_MODEM_FW_CONFIGURATION_LOCK[0] FWCONFIGURATIONLOCK bit</a> | 0   | 1 |
|--------------------------------------------------------------------------------|-----|---|
| MODEMGPMCDTFWREQINFO                                                           | R/W | R |

**Table 13-194. CONTROL\_MODEM\_GPMC\_DT\_FW\_RD**

|                         |                                                      |                         |                 |                 |         |
|-------------------------|------------------------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0208                                          | <b>Physical Address</b> | 0x4800 2478     | <b>Instance</b> | GENERAL |
| <b>Description</b>      | Modem GPMC Default firewall read permission register |                         |                 |                 |         |
| <b>Type</b>             | RW                                                   |                         |                 |                 |         |
| 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 |                 |         |
| RESERVED                |                                                      |                         |                 | MODEMGPMCDTFWRD |         |

| Bits  | Field Name      | Description                                                           | Type                                | Reset  |
|-------|-----------------|-----------------------------------------------------------------------|-------------------------------------|--------|
| 31:16 | RESERVED        | Read returns reset value.                                             | R                                   | 0x0000 |
| 15:0  | MODEMGPMCDTFWRD | Exported values to the GPMC firewall region1<br>READ_PERMISSION field | See<br><a href="#">Table 13-196</a> | 0xFFFF |

**Table 13-195. Register Call Summary for Register CONTROL\_MODEM\_GPMC\_DT\_FW\_RD**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-196. Type Value For CONTROL\_MODEM\_GPMC\_DT\_FW\_RD**

|                                                                |     |   |
|----------------------------------------------------------------|-----|---|
| CONTROL_MODEM_FW_CONFIGURATION_LOCK[0] FWCONFIGURATIONLOCK bit | 0   | 1 |
| MODEMGPMCDTFWRD                                                | R/W | R |

**Table 13-197. CONTROL\_MODEM\_GPMC\_DT\_FW\_WR**

|                                                                                             |                                                       |                         |             |                 |         |
|---------------------------------------------------------------------------------------------|-------------------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b>                                                                       | 0x0000 020C                                           | <b>Physical Address</b> | 0x4800 247C | <b>Instance</b> | GENERAL |
| <b>Description</b>                                                                          | Modem GPMC Default firewall write permission register |                         |             |                 |         |
| <b>Type</b>                                                                                 | RW                                                    |                         |             |                 |         |
| 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 | RESERVED                                              |                         |             | MODEMGPMCDTFWWR |         |

| Bits  | Field Name      | Description                                                             | Type                                | Reset  |
|-------|-----------------|-------------------------------------------------------------------------|-------------------------------------|--------|
| 31:16 | RESERVED        | Read returns reset value.                                               | R                                   | 0x0000 |
| 15:0  | MODEMGPMCDTFWWR | Exported values to the GPMC firewall region1<br>WRITER_PERMISSION field | See<br><a href="#">Table 13-199</a> | 0xFFFF |

**Table 13-198. Register Call Summary for Register CONTROL\_MODEM\_GPMC\_DT\_FW\_WR**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-199. Type Value For CONTROL\_MODEM\_GPMC\_DT\_FW\_WR**

|                                                                |     |   |
|----------------------------------------------------------------|-----|---|
| CONTROL_MODEM_FW_CONFIGURATION_LOCK[0] FWCONFIGURATIONLOCK bit | 0   | 1 |
| MODEMGPMCDTFWWR                                                | R/W | R |

**Table 13-200. CONTROL\_MODEM\_GPMC\_BOOT\_CODE**

|                                                                                             |                                          |                         |             |                 |         |
|---------------------------------------------------------------------------------------------|------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b>                                                                       | 0x0000 0210                              | <b>Physical Address</b> | 0x4800 2480 | <b>Instance</b> | GENERAL |
| <b>Description</b>                                                                          | GPMC Flash Boot Code protection register |                         |             |                 |         |
| <b>Type</b>                                                                                 | RW                                       |                         |             |                 |         |
| 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 | RESERVED                                 |                         |             | MODEMGPMCDTFWWR |         |

| Bits | Field Name                     | Description                                                                                                                                                                                 | Type                    | Reset      |
|------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------------|
| 31:6 | RESERVED                       | Read returns reset value.                                                                                                                                                                   | R                       | 0x00000000 |
| 5    | GPMCBOOTCODEWRITE<br>PROTECTED | When set HIGH the Flash Boot Code area is write protected<br><br>0x0: When cleared Flash boot code area is not write protected<br><br>0x1: When set Flash boot code area is write protected | See<br>Table 13-<br>202 | 0          |
| 4:0  | GPMCBOOTCODESIZE               | Size of the Flash boot code to protect                                                                                                                                                      | See<br>Table 13-<br>202 | 0x00       |

**Table 13-201. Register Call Summary for Register CONTROL\_MODEM\_GPMC\_BOOT\_CODE**

SCM Register Manual

- SCM Register Summary: [0]

**Table 13-202. Type Value For CONTROL\_MODEM\_GPMC\_BOOT\_CODE**

| <b>CONTROL_MODEM_FW_CONFIGURATION_LOCK[0]</b> FWCONFIGURATIONLOCK bit | 0   | 1 |
|-----------------------------------------------------------------------|-----|---|
| GPMCBOOTCODEWRITEPROTECTED                                            | R/W | R |
| GPMCBOOTCODESIZE                                                      | R/W | R |

**Table 13-203. CONTROL\_MODEM\_SMS\_RG\_ATT1**

|                         |                                     |                 |         |
|-------------------------|-------------------------------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0214                         |                 |         |
| <b>Physical Address</b> | 0x4800 2484                         | <b>Instance</b> | GENERAL |
| <b>Description</b>      | Modem SMS Default firewall register |                 |         |
| <b>Type</b>             | RW                                  |                 |         |

|           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| SMSRGATT1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                   | Type                    | Reset       |
|------|------------|---------------------------------------------------------------|-------------------------|-------------|
| 31:0 | SMSRGATT1  | Exported values to the SMS firewall region1 SMS_RG_ATT1 field | See<br>Table 13-<br>205 | 0xFFFF FFFF |

**Table 13-204. Register Call Summary for Register CONTROL\_MODEM\_SMS\_RG\_ATT1**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-205. Type Value For CONTROL\_MODEM\_SMS\_RG\_ATT1**

|                                                                                |     |   |
|--------------------------------------------------------------------------------|-----|---|
| <a href="#">CONTROL_MODEM_FW_CONFIGURATION_LOCK[0] FWCONFIGURATIONLOCK bit</a> | 0   | 1 |
| SMSRGATT1                                                                      | R/W | R |

**Table 13-206. CONTROL\_MODEM\_SMS\_RG\_RDPERM1**

|                       |                                                     |                         |             |                 |         |
|-----------------------|-----------------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 0218                                         | <b>Physical Address</b> | 0x4800 2488 | <b>Instance</b> | GENERAL |
| <b>Description</b>    | Modem SMS Default firewall read permission register |                         |             |                 |         |
| <b>Type</b>           | RW                                                  |                         |             |                 |         |

|                                                                                             |               |
|---------------------------------------------------------------------------------------------|---------------|
| 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 |               |
| RESERVED                                                                                    | SMSRG RDPERM1 |

| Bits  | Field Name    | Description                                                      | Type                             | Reset  |
|-------|---------------|------------------------------------------------------------------|----------------------------------|--------|
| 31:16 | RESERVED      | Read returns reset value.                                        | R                                | 0x0000 |
| 15:0  | SMSRG RDPERM1 | Exported values to the SMS firewall region1 SMS_RG_RDPERM1 field | See <a href="#">Table 13-208</a> | 0xFFFF |

**Table 13-207. Register Call Summary for Register CONTROL\_MODEM\_SMS\_RG\_RDPERM1**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-208. Type Value For CONTROL\_MODEM\_SMS\_RG\_RDPERM1**

|                                                                                |     |   |
|--------------------------------------------------------------------------------|-----|---|
| <a href="#">CONTROL_MODEM_FW_CONFIGURATION_LOCK[0] FWCONFIGURATIONLOCK bit</a> | 0   | 1 |
| SMSRG RDPERM1                                                                  | R/W | R |

**Table 13-209. CONTROL\_MODEM\_SMS\_RG\_WRPERM1**

|                       |                                                      |                         |             |                 |         |
|-----------------------|------------------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 021C                                          | <b>Physical Address</b> | 0x4800 248C | <b>Instance</b> | GENERAL |
| <b>Description</b>    | Modem SMS Default firewall write permission register |                         |             |                 |         |
| <b>Type</b>           | RW                                                   |                         |             |                 |         |

|                                                                                             |               |
|---------------------------------------------------------------------------------------------|---------------|
| 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 |               |
| RESERVED                                                                                    | SMSRG WRPERM1 |

| Bits  | Field Name    | Description                                                      | Type                             | Reset  |
|-------|---------------|------------------------------------------------------------------|----------------------------------|--------|
| 31:16 | RESERVED      | Read returns reset value.                                        | R                                | 0x0000 |
| 15:0  | SMSRG WRPERM1 | Exported values to the SMS firewall region1 SMS_RG_WRPERM1 field | See <a href="#">Table 13-211</a> | 0xFFFF |

**Table 13-210. Register Call Summary for Register CONTROL\_MODEM\_SMS\_RG\_WRPERM1**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-211. Type Value For CONTROL\_MODEM\_SMS\_RG\_WRPERM1**

|                                                                                |     |   |
|--------------------------------------------------------------------------------|-----|---|
| <a href="#">CONTROL_MODEM_FW_CONFIGURATION_LOCK[0] FWCONFIGURATIONLOCK bit</a> | 0   | 1 |
| SMSRGWRPERM1                                                                   | R/W | R |

**Table 13-212. CONTROL\_MODEM\_D2D\_FW\_DEBUG\_MODE**

|                       |                                  |                         |             |                 |         |
|-----------------------|----------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 0220                      | <b>Physical Address</b> | 0x4800 2490 | <b>Instance</b> | GENERAL |
| <b>Description</b>    | D2D firewall debug mode register |                         |             |                 |         |
| <b>Type</b>           | RW                               |                         |             |                 |         |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name     | Description                                      | Type                             | Reset      |
|------|----------------|--------------------------------------------------|----------------------------------|------------|
| 31:1 | RESERVED       | Read returns reset value.                        | R                                | 0x00000000 |
| 0    | D2DFWDEBUGMODE | When set to high the L3-D2D FW is in debug mode. | See <a href="#">Table 13-214</a> | 0x0        |

**Table 13-213. Register Call Summary for Register CONTROL\_MODEM\_D2D\_FW\_DEBUG\_MODE**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-214. Type Value For CONTROL\_MODEM\_D2D\_FW\_DEBUG\_MODE**

|                                                                                |     |   |
|--------------------------------------------------------------------------------|-----|---|
| <a href="#">CONTROL_MODEM_FW_CONFIGURATION_LOCK[0] FWCONFIGURATIONLOCK bit</a> | 0   | 1 |
| D2DFWDEBUGMODE                                                                 | R/W | R |

**Table 13-215. CONTROL\_DPF\_OCM\_RAM\_FW\_ADDR\_MATCH**

|                       |                                          |                         |             |                 |         |
|-----------------------|------------------------------------------|-------------------------|-------------|-----------------|---------|
| <b>Address Offset</b> | 0x0000 0228                              | <b>Physical Address</b> | 0x4800 2498 | <b>Instance</b> | GENERAL |
| <b>Description</b>    | OCM RAM Dynamic Power Framework Handling |                         |             |                 |         |
| <b>Type</b>           | RW                                       |                         |             |                 |         |

| 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 |
|----------|----|----|----|----|----|----|----|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    | REGIONOCMRAMFWADDRMATCH |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name                  | Description                | Type | Reset    |
|-------|-----------------------------|----------------------------|------|----------|
| 31:20 | RESERVED                    | Read returns reset value   | R    | 0x00     |
| 19:0  | REGIONOCMRAMFW<br>ADDRMATCH | See L3 FW addr_match field | R    | 0x000000 |

**Table 13-216. Register Call Summary for Register CONTROL\_DPF\_OCM\_RAM\_FW\_ADDR\_MATCH**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-217. CONTROL\_DPF\_OCM\_RAM\_FW\_REQINFO**

|                         |                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 022C                              |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x4800 249C                              |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | OCM RAM Dynamic Power Framework Handling |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                          |    |    |    |    |    |    |    |    |    |    |    |    |    | REGIONOCMRAMFWREQINFO |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name                | Description                        | Type | Reset  |
|-------|---------------------------|------------------------------------|------|--------|
| 31:16 | RESERVED                  | Read returns reset value           | R    | 0x00   |
| 15:0  | REGIONOCMRAMFW<br>REQINFO | See L3 FW REQINFO permission field | R    | 0xFFFF |

**Table 13-218. Register Call Summary for Register CONTROL\_DPF\_OCM\_RAM\_FW\_REQINFO**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-219. CONTROL\_DPF\_OCM\_RAM\_FW\_WR**

|                         |                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 0230                              |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x4800 24A0                              |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | OCM RAM Dynamic Power Framework Handling |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                          |    |    |    |    |    |    |    |    |    |    |    |    |    | REGIONOCMRAMFWWR |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name       | Description                   | Type | Reset    |
|-------|------------------|-------------------------------|------|----------|
| 31:16 | RESERVED         | Read returns reset value      | R    | 0x000000 |
| 15:0  | REGIONOCMRAMFWWR | See L3 FW WR permission field | R    | 0xFFFF   |

**Table 13-220. Register Call Summary for Register CONTROL\_DPF\_OCM\_RAM\_FW\_WR**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-221. CONTROL\_DPF\_REGION4\_GPMC\_FW\_ADDR\_MATCH**

|                         |                                       |                         |                 |                 |         |
|-------------------------|---------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0234                           | <b>Physical Address</b> | 0x4800 24A4     | <b>Instance</b> | GENERAL |
| <b>Description</b>      | GPMC Dynamic Power Framework Handling |                         |                 |                 |         |
| <b>Type</b>             | RW                                    |                         |                 |                 |         |
| 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 |                 |         |
| RESERVED                |                                       | REGION4GPMCFWADDRMATCH  |                 |                 |         |

| Bits  | Field Name                   | Description                                                | Type | Reset      |
|-------|------------------------------|------------------------------------------------------------|------|------------|
| 31:30 | RESERVED                     | Read returns reset value                                   | R    | 0x00000000 |
| 29:0  | REGION4GPMCFWADDRMATCHC<br>H | Exported value to L3 FW region 4 GPMC<br>ADDR_MATCH4 field | R    | 0x00000000 |

**Table 13-222. Register Call Summary for Register  
CONTROL\_DPF\_REGION4\_GPMC\_FW\_ADDR\_MATCH**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-223. CONTROL\_DPF\_REGION4\_GPMC\_FW\_REQINFO**

|                         |                                       |                         |                 |                 |         |
|-------------------------|---------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 0238                           | <b>Physical Address</b> | 0x4800 24A8     | <b>Instance</b> | GENERAL |
| <b>Description</b>      | GPMC Dynamic Power Framework Handling |                         |                 |                 |         |
| <b>Type</b>             | RW                                    |                         |                 |                 |         |
| 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 |                 |         |
| RESERVED                |                                       | REGION4GPMCFWREQINFO    |                 |                 |         |

| Bits  | Field Name           | Description                                                         | Type | Reset  |
|-------|----------------------|---------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED             | Read returns reset value.                                           | R    | 0x0000 |
| 15:0  | REGION4GPMCFWREQINFO | Exported value to L3 FW region 4 GPMC<br>REQINFO_PERMISSION_4 field | R    | 0xFFFF |

**Table 13-224. Register Call Summary for Register CONTROL\_DPF\_REGION4\_GPMC\_FW\_REQINFO**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-225. CONTROL\_DPF\_REGION4\_GPMC\_FW\_WR**

|                         |                                       |                         |                 |                 |         |
|-------------------------|---------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 023C                           | <b>Physical Address</b> | 0x4800 24AC     | <b>Instance</b> | GENERAL |
| <b>Description</b>      | GPMC Dynamic Power Framework Handling |                         |                 |                 |         |
| <b>Type</b>             | RW                                    |                         |                 |                 |         |
| 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 |                 |         |
| RESERVED                |                                       |                         |                 | REGION4GPMCFWWR |         |

| Bits  | Field Name      | Description                                                       | Type | Reset  |
|-------|-----------------|-------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED        | Read returns reset value.                                         | R    | 0x0000 |
| 15:0  | REGION4GPMCFWWR | Exported value to L3 FW region 4 GPMC<br>WRITE_PERMISSION_4 field | R    | 0xFFFF |

**Table 13-226. Register Call Summary for Register CONTROL\_DPF\_REGION4\_GPMC\_FW\_WR**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-227. CONTROL\_DPF\_REGION1\_IVA2\_FW\_ADDR\_MATCH**

|                         |                                       |                         |                 |                        |         |
|-------------------------|---------------------------------------|-------------------------|-----------------|------------------------|---------|
| <b>Address Offset</b>   | 0x0000 0240                           | <b>Physical Address</b> | 0x4800 24B0     | <b>Instance</b>        | GENERAL |
| <b>Description</b>      | IVA2 Dynamic Power Framework Handling |                         |                 |                        |         |
| <b>Type</b>             | RW                                    |                         |                 |                        |         |
| 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 |                        |         |
| RESERVED                |                                       |                         |                 | REGION1IVA2FWADDRMATCH |         |

| Bits  | Field Name             | Description                                             | Type | Reset |
|-------|------------------------|---------------------------------------------------------|------|-------|
| 31:24 | RESERVED               | Read returns reset value                                | R    | 0x0   |
| 23:0  | REGION1IVA2FWADDRMATCH | Exported value to L3 FW region 1 IVA2 ADDR_MATCH1 field | R    | 0x0   |

**Table 13-228. Register Call Summary for Register CONTROL\_DPF\_REGION1\_IVA2\_FW\_ADDR\_MATCH**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-229. CONTROL\_DPF\_REGION1\_IVA2\_FW\_REQINFO**

|                         |                                       |                         |                 |                      |         |
|-------------------------|---------------------------------------|-------------------------|-----------------|----------------------|---------|
| <b>Address Offset</b>   | 0x0000 0244                           | <b>Physical Address</b> | 0x4800 24B4     | <b>Instance</b>      | GENERAL |
| <b>Description</b>      | IVA2 Dynamic Power Framework Handling |                         |                 |                      |         |
| <b>Type</b>             | RW                                    |                         |                 |                      |         |
| 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 |                      |         |
| RESERVED                |                                       |                         |                 | REGION1IVA2FWREQINFO |         |

| Bits  | Field Name           | Description                                                         | Type | Reset  |
|-------|----------------------|---------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED             | Read returns reset value.                                           | R    | 0x0    |
| 15:0  | REGION1IVA2FWREQINFO | Exported value to L3 FW region 1 IVA2<br>REQINFO_PERMISSION_1 field | R    | 0xFFFF |

**Table 13-230. Register Call Summary for Register CONTROL\_DPF\_REGION1\_IVA2\_FW\_REQINFO**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-231. CONTROL\_DPF\_REGION1\_IVA2\_FW\_WR**

|                         |                                       |                       |                 |  |  |  |  |                 |  |  |                 |  |  |  |         |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------|-----------------------|-----------------|--|--|--|--|-----------------|--|--|-----------------|--|--|--|---------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0248                           |                       |                 |  |  |  |  |                 |  |  |                 |  |  |  |         |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 24B8                           |                       |                 |  |  |  |  |                 |  |  | <b>Instance</b> |  |  |  | GENERAL |  |  |  |  |  |  |  |
| <b>Description</b>      | IVA2 Dynamic Power Framework Handling |                       |                 |  |  |  |  |                 |  |  |                 |  |  |  |         |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                    |                       |                 |  |  |  |  |                 |  |  |                 |  |  |  |         |  |  |  |  |  |  |  |
| 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 |  |  |  |  |                 |  |  |                 |  |  |  |         |  |  |  |  |  |  |  |
| RESERVED                |                                       |                       |                 |  |  |  |  | REGION1IVA2FWWR |  |  |                 |  |  |  |         |  |  |  |  |  |  |  |

| Bits  | Field Name      | Description                                                       | Type | Reset  |
|-------|-----------------|-------------------------------------------------------------------|------|--------|
| 31:13 | RESERVED        | Read returns reset value.                                         | R    | 0x0    |
| 12:0  | REGION1IVA2FWWR | Exported value to L3 FW region 1 IVA2<br>WRITE_PERMISSION_1 field | R    | 0x1FFF |

**Table 13-232. Register Call Summary for Register CONTROL\_DPF\_REGION1\_IVA2\_FW\_WR**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-233. CONTROL\_PBIAS\_LITE**

|                         |                                                                      |                       |                 |  |  |  |  |                      |          |                       |                 |                  |                 |                      |          |                       |          |                  |                 |  |  |  |
|-------------------------|----------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|----------------------|----------|-----------------------|-----------------|------------------|-----------------|----------------------|----------|-----------------------|----------|------------------|-----------------|--|--|--|
| <b>Address Offset</b>   | 0x0000 02B0                                                          |                       |                 |  |  |  |  |                      |          |                       |                 |                  |                 |                      |          |                       |          |                  |                 |  |  |  |
| <b>Physical Address</b> | 0x4800 2520                                                          |                       |                 |  |  |  |  |                      |          |                       | <b>Instance</b> |                  |                 |                      | GENERAL  |                       |          |                  |                 |  |  |  |
| <b>Description</b>      | This register controls the settings for PBIAS LITE MMC/SD/SDIO1 pins |                       |                 |  |  |  |  |                      |          |                       |                 |                  |                 |                      |          |                       |          |                  |                 |  |  |  |
| <b>Type</b>             | RW                                                                   |                       |                 |  |  |  |  |                      |          |                       |                 |                  |                 |                      |          |                       |          |                  |                 |  |  |  |
| 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 |  |  |  |  |                      |          |                       |                 |                  |                 |                      |          |                       |          |                  |                 |  |  |  |
| RESERVED                |                                                                      |                       |                 |  |  |  |  | PBIASLITESUPPLYHIGH1 | RESERVED | PBIASLITEVMMODEERROR1 | RESERVED        | PBIASLITEPWRDNZ1 | PBIASLITEVMODE1 | PBIASLITESUPPLYHIGH0 | RESERVED | PBIASLITEVMMODEERROR0 | RESERVED | PBIASLITEPWRDNZ0 | PBIASLITEVMODE0 |  |  |  |

| Bits  | Field Name           | Description                                                                                                                | Type | Reset      |
|-------|----------------------|----------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:16 | RESERVED             | Reserved for future use.                                                                                                   | R    | 0x00000000 |
| 15    | PBIASLITESUPPLYHIGH1 | Status indicating if PBIAS1 cell is supplied by 1.8 or 3.0 V<br>SIM_VDDS<br>1 => SIM_VDDS = 3.0 V<br>0 => SIM_VDDS = 1.8 V | R    | 0          |

| Bits  | Field Name           | Description                                                                                                                                                                                                      | Type | Reset |
|-------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 14:12 | RESERVED             | Reserved for future use                                                                                                                                                                                          | R    | 0     |
| 11    | PBIASLITEVMODEERROR1 | Status indicating if the software-programmed VMODE level matches the SUPPLY_HI output signal<br>0b0 => VMODE Level same or VMODE level not considered.<br>0b1 => indicates VMODE_LEVEL not same as SUPPLY_HI_OUT | R    | 0     |
| 10    | RESERVED             | Reserved                                                                                                                                                                                                         | R    | 0x0   |
| 9     | PBIASLITEPWRDNZ1     | Input signal referenced to VDD2. Software must keep this signal low whenever SIM_VDDS is ramping up.<br>1 => SIM_VDDS stable<br>0 => SIM_VDDS is ramping up                                                      | R/W  | 0     |
| 8     | PBIASLITEVMODE1      | SIM_VDDS voltage level information:<br>1 => SIM_VDDS = 3.0 V<br>0 => SIM_VDDS = 1.8 V                                                                                                                            | R/W  | 1     |
| 7     | PBIASLITESUPPLYHIGH0 | Status indicating if PBIAS0 is supplied by 1.8 V or 3.0 V SDMMC1_VDDS<br>0b0 => PBIAS0 is supplied by SDMMC1_VDDS = 1.8 V<br>0b1 => PBIAS0 is supplied by SDMMC1_VDDS = 3.0 V                                    | R    | 0x0   |
| 6:4   | RESERVED             | Read returns reset value.                                                                                                                                                                                        | R    | 0x0   |
| 3     | PBIASLITEVMODEERROR0 | Status indicating if the software programmed VMODE level matches the SUPPLY_HI output signal<br>0b0 => VMODE level same or VMODE level not considered<br>0b1 => Indicates VMODE_LEVEL not same as SUPPLY_HI_OUT  | R    | 0x0   |
| 2     | RESERVED             | Reserved                                                                                                                                                                                                         | R    | 0x0   |
| 1     | PBIASLITEPWRDNZ0     | Input Signal Referenced to VDD2. Software has to keep this bit at 0b0 when SDMMC1_VDDS is ramping up<br>0b0 => SDMMC1_VDDS ramping up<br>0b1 => SDMMC1_VDDS stable                                               | RW   | 0x0   |
| 0     | PBIASLITEVMODE0      | SDMMC1_VDDS voltage level information control from software<br>0b0 => SDMMC1_VDDS = 1.8 V<br>0b1 => SDMMC1_VDDS = 3.0 V                                                                                          | RW   | 0x1   |

**Table 13-234. Register Call Summary for Register CONTROL\_PBIAS\_LITE**

## SCM Functional Description

- [Extended-Drain I/O Pin and PBIAS Cells: \[0\] \[1\]](#)
- [PBIAS LITE Control Register: \[2\] \[3\]](#)

## SCM Programming Model

- [Extended-Drain I/Os and PBIAS Cells Programming Guide: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\]](#)
- [PBIAS Error Generation: \[13\] \[14\]](#)
- [Speed Control and Voltage Supply State: \[15\]](#)

## SCM Register Manual

- [SCM Register Summary: \[16\]](#)

**Table 13-235. CONTROL\_TEMP\_SENSOR**

|                         |                             |                         |                 |                 |         |      |      |
|-------------------------|-----------------------------|-------------------------|-----------------|-----------------|---------|------|------|
| <b>Address Offset</b>   | 0x0000 02B4                 | <b>Physical Address</b> | 0x4800 2524     | <b>Instance</b> | GENERAL |      |      |
| <b>Description</b>      | temperature sensor register |                         |                 |                 |         |      |      |
| <b>Type</b>             | RW                          |                         |                 |                 |         |      |      |
| 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 |                 |         |      |      |
|                         |                             |                         |                 | CONTCONV        | SOC     | EOCZ | TEMP |
|                         | RESERVED                    |                         |                 |                 |         |      |      |

| Bits  | Field Name | Description                                                                                                                                           | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:11 | RESERVED   | Read returns reset value.                                                                                                                             | R    | 0x0   |
| 10    | CONTCONV   | VDD level digital inputs. When high the ADC is in continuous conversion mode<br>0 : ADC Single Conversion Mode;<br>1 : ADC Continuous Conversion Mode | RW   | 0x0   |
| 9     | SOC        | ADC Start of Conversion. A transition to high starts a new ADC conversion cycle                                                                       | RW   | 0x0   |
| 8     | EOCZ       | ADC End of Conversion. Active low, when CTRL_TEMP[7:0] is valid                                                                                       | R    | 0x0   |
| 7:0   | TEMP       | Temperature data from the ADC. Valid if EOCZ is low                                                                                                   | R    | 0x0   |

**Table 13-236. Register Call Summary for Register CONTROL\_TEMP\_SENSOR**
**SCM Functional Description**

- Band Gap Voltage and Temperature Sensor: [0] [1]
- Single Conversion Mode (CONTCONV = 0): [2] [3]
- Continuous Conversion Mode (CONTCONV = 1): [4] [5]
- ADC Codes Versus Temperature: [6]
- Temperature Sensor Control Register: [7] [8]

**SCM Register Manual**

- [SCM Register Summary: \[9\]](#)

**Table 13-237. CONTROL\_DPF\_MAD2D\_FW\_ADDR\_MATCH**

|                         |                                       |                         |                 |                 |         |
|-------------------------|---------------------------------------|-------------------------|-----------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 02C8                           | <b>Physical Address</b> | 0x4800 2538     | <b>Instance</b> | GENERAL |
| <b>Description</b>      | MAD2D Dynamic Power Framework Handing |                         |                 |                 |         |
| <b>Type</b>             | RW                                    |                         |                 |                 |         |
| 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 |                 |         |
| RESERVED                |                                       | REGIONMAD2DFWADDRMATCH  |                 |                 |         |

| Bits  | Field Name              | Description                | Type | Reset     |
|-------|-------------------------|----------------------------|------|-----------|
| 31:27 | RESERVED                | Read returns reset value   | R    | 0x00000   |
| 26:0  | REGIONMAD2DFWADDRMATC H | See L3 FW addr match field | R    | 0x0000000 |

**Table 13-238. Register Call Summary for Register CONTROL\_DPF\_MAD2D\_FW\_ADDR\_MATCH**
**SCM Register Manual**

- [SCM Register Summary: \[0\]](#)

**Table 13-239. CONTROL\_DPF\_MAD2D\_FW\_REQINFO**

|                         |                                        |                       |                 |  |  |  |  |
|-------------------------|----------------------------------------|-----------------------|-----------------|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 02CC                            | <b>Instance</b>       | GENERAL         |  |  |  |  |
| <b>Physical Address</b> | 0x4800 253C                            |                       |                 |  |  |  |  |
| <b>Description</b>      | MAD2D Dynamic Power Framework Handling |                       |                 |  |  |  |  |
| <b>Type</b>             | RW                                     |                       |                 |  |  |  |  |
| 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 |  |  |  |  |
| RESERVED                |                                        | MAD2DFWREQINFO        |                 |  |  |  |  |

| Bits  | Field Name     | Description                        | Type | Reset  |
|-------|----------------|------------------------------------|------|--------|
| 31:16 | RESERVED       | Read returns reset value           | R    | 0x00   |
| 15:0  | MAD2DFWREQINFO | See L3 FW REQINFO permission field | R    | 0xFFFF |

**Table 13-240. Register Call Summary for Register CONTROL\_DPF\_MAD2D\_FW\_REQINFO**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-241. CONTROL\_DPF\_MAD2D\_FW\_WR**

|                         |                                        |                       |                 |  |  |  |  |
|-------------------------|----------------------------------------|-----------------------|-----------------|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 02D0                            | <b>Instance</b>       | GENERAL         |  |  |  |  |
| <b>Physical Address</b> | 0x4800 2540                            |                       |                 |  |  |  |  |
| <b>Description</b>      | MAD2D Dynamic Power Framework Handling |                       |                 |  |  |  |  |
| <b>Type</b>             | RW                                     |                       |                 |  |  |  |  |
| 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 |  |  |  |  |
| RESERVED                |                                        | REGIONMAD2DFWWR       |                 |  |  |  |  |

| Bits  | Field Name      | Description                   | Type | Reset   |
|-------|-----------------|-------------------------------|------|---------|
| 31:16 | RESERVED        | Read returns reset value      | R    | 0x00000 |
| 15:0  | REGIONMAD2DFWWR | See L3 FW WR permission field | R    | 0xFFFF  |

**Table 13-242. Register Call Summary for Register CONTROL\_DPF\_MAD2D\_FW\_WR**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-243. CONTROL\_DSS\_DPLL\_SPREADING\_FREQ**

|                         |                                                      |                 |         |
|-------------------------|------------------------------------------------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 02D4                                          | <b>Instance</b> | GENERAL |
| <b>Physical Address</b> | 0x4800 2544                                          |                 |         |
| <b>Description</b>      | control_dss_dpll_spreading_freq register description |                 |         |
| <b>Type</b>             | RW                                                   |                 |         |

| 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 |
|----------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED | R_DSS_DELTA_M_INT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

R\_DSS\_DELTA\_M\_FRACT

R\_DSS\_MOD\_FREQ\_EXP

R\_DSS\_MOD\_FREQ\_MANT

| Bits  | Field Name          | Description                            | Type | Reset   |
|-------|---------------------|----------------------------------------|------|---------|
| 31:30 | RESERVED            | Reserved field                         | R    | 0x0     |
| 29:28 | R_DSS_DELTA_M_INT   | Integer part of DeltaM coefficient     | RW   | 0x00000 |
| 27:10 | R_DSS_DELTA_M_FRACT | Fractional part of DeltaM coefficient  | RW   | 0x00000 |
| 9:7   | R_DSS_MOD_FREQ_EXP  | Exponent of ModFreqDivider coefficient | RW   | 0x0     |
| 6:0   | R_DSS_MOD_FREQ_MANT | Mantissa of ModFreqDivider coefficient | RW   | 0x00    |

**Table 13-244. Register Call Summary for Register CONTROL\_DSS\_DPLL\_SPREADING\_FREQ**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-245. CONTROL\_CORE\_DPLL\_SPREADING\_FREQ**

|                  |                                                       |          |
|------------------|-------------------------------------------------------|----------|
| Address Offset   | 0x0000 02D8                                           |          |
| Physical Address | 0x4800 2548                                           | Instance |
| Description      | control_core_dpll_spreading_freq register description |          |
| Type             | RW                                                    |          |

| 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 |
|----------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED | R_CORE_DELTA_M_INT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

R\_CORE\_DELTA\_M\_FRACT

R\_CORE\_MOD\_FREQ\_EXP

R\_CORE\_MOD\_FREQ\_MANT

| Bits  | Field Name           | Description                            | Type | Reset   |
|-------|----------------------|----------------------------------------|------|---------|
| 31:30 | RESERVED             | Reserved field                         | R    | 0x0     |
| 29:28 | R_CORE_DELTA_M_INT   | Integer part of DeltaM coefficient     | RW   | 0x00000 |
| 27:10 | R_CORE_DELTA_M_FRACT | Fractional part of DeltaM coefficient  | RW   | 0x00000 |
| 9:7   | R_CORE_MOD_FREQ_EXP  | Exponent of ModFreqDivider coefficient | RW   | 0x0     |
| 6:0   | R_CORE_MOD_FREQ_MANT | Mantissa of ModFreqDivider coefficient | RW   | 0x00    |

**Table 13-246. Register Call Summary for Register CONTROL\_CORE\_DPLL\_SPREADING\_FREQ**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-247. CONTROL\_PER\_DPLL\_SPREADING\_FREQ**

|                       |                   |                                                      |    |                         |             |    |                 |         |    |    |    |    |    |    |    |    |    |                    |                     |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------------------|-------------------|------------------------------------------------------|----|-------------------------|-------------|----|-----------------|---------|----|----|----|----|----|----|----|----|----|--------------------|---------------------|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b> |                   | 0x0000 02DC                                          |    | <b>Physical Address</b> | 0x4800 254C |    | <b>Instance</b> | GENERAL |    |    |    |    |    |    |    |    |    |                    |                     |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>    |                   | control_per_dpll_spreading_freq register description |    |                         |             |    |                 |         |    |    |    |    |    |    |    |    |    |                    |                     |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>           |                   | RW                                                   |    |                         |             |    |                 |         |    |    |    |    |    |    |    |    |    |                    |                     |    |    |   |   |   |   |   |   |   |   |   |   |
|                       |                   |                                                      |    |                         |             |    |                 |         |    |    |    |    |    |    |    |    |    |                    |                     |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED              | R_PER_DELTA_M_INT | R_PER_DELTA_M_FRACT                                  |    |                         |             |    |                 |         |    |    |    |    |    |    |    |    |    | R_PER_MOD_FREQ_EXP | R_PER_MOD_FREQ_MANT |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name          | Description                            | Type | Reset   |
|-------|---------------------|----------------------------------------|------|---------|
| 31:30 | RESERVED            | Reserved field                         | R    | 0x0     |
| 29:28 | R_PER_DELTA_M_INT   | Integer part of DeltaM coefficient     | RW   | 0x00000 |
| 27:10 | R_PER_DELTA_M_FRACT | Fractional part of DeltaM coefficient  | RW   | 0x00000 |
| 9:7   | R_PER_MOD_FREQ_EXP  | Exponent of ModFreqDivider coefficient | RW   | 0x0     |
| 6:0   | R_PER_MOD_FREQ_MANT | Mantissa of ModFreqDivider coefficient | RW   | 0x0     |

**Table 13-248. Register Call Summary for Register CONTROL\_PER\_DPLL\_SPREADING\_FREQ**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-249. CONTROL\_USBHOST\_DPLL\_SPREADING\_FREQ**

|                       |                       |                                                          |    |                         |             |    |                 |         |    |    |    |    |    |    |    |    |    |                        |                         |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------------------|-----------------------|----------------------------------------------------------|----|-------------------------|-------------|----|-----------------|---------|----|----|----|----|----|----|----|----|----|------------------------|-------------------------|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b> |                       | 0x0000 02E0                                              |    | <b>Physical Address</b> | 0x4800 2550 |    | <b>Instance</b> | GENERAL |    |    |    |    |    |    |    |    |    |                        |                         |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>    |                       | control_usbhost_dpll_spreading_freq register description |    |                         |             |    |                 |         |    |    |    |    |    |    |    |    |    |                        |                         |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>           |                       | RW                                                       |    |                         |             |    |                 |         |    |    |    |    |    |    |    |    |    |                        |                         |    |    |   |   |   |   |   |   |   |   |   |   |
|                       |                       |                                                          |    |                         |             |    |                 |         |    |    |    |    |    |    |    |    |    |                        |                         |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED              | R_USBHOST_DELTA_M_INT | R_USBHOST_DELTA_M_FRACT                                  |    |                         |             |    |                 |         |    |    |    |    |    |    |    |    |    | R_USBHOST_MOD_FREQ_EXP | R_USBHOST_MOD_FREQ_MANT |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name              | Description                            | Type | Reset   |
|-------|-------------------------|----------------------------------------|------|---------|
| 31:30 | RESERVED                | Reserved field                         | R    | 0x0     |
| 29:28 | R_USBHOST_DELTA_M_INT   | Integer part of DeltaM coefficient     | RW   | 0x00000 |
| 27:10 | R_USBHOST_DELTA_M_FRACT | Fractional part of DeltaM coefficient  | RW   | 0x00000 |
| 9:7   | R_USBHOST_MOD_FREQ_EXP  | Exponent of ModFreqDivider coefficient | RW   | 0x0     |
| 6:0   | R_USBHOST_MOD_FREQ_MANT | Mantissa of ModFreqDivider coefficient | RW   | 0x00    |

**Table 13-250. Register Call Summary for Register CONTROL\_USBHOST\_DPLL\_SPREADING\_FREQ**

---

SCM Register Manual

- SCM Register Summary: [0]

**Table 13-251. CONTROL\_AVDAC1**

|                         |                                     |                 |         |
|-------------------------|-------------------------------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 02E4                         |                 |         |
| <b>Physical Address</b> | 0x4800 2554                         | <b>Instance</b> | GENERAL |
| <b>Description</b>      | control_avdac1 register description |                 |         |
| <b>Type</b>             | RW                                  |                 |         |

| Bits  | Field Name        | Description                                                                                                                                                                                                                                                                                                                                                              | Type         | Reset |
|-------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------|
| 31    | RESERVED          | Reserved: Keep at reset value.                                                                                                                                                                                                                                                                                                                                           | RW<br>WtoClr | 0     |
| 30:20 | RESERVED          | Reserved                                                                                                                                                                                                                                                                                                                                                                 | R            | 0x000 |
| 19    | AVDAC1_COMP_EN[3] | Optional control used only for dual-channel configuration.<br>It should be low by default (single-channel configuration).<br><br>0: (default) Single channel<br>1: Dual channel configuration                                                                                                                                                                            | RW           | 0x1   |
| 18    | AVDAC1_COMP_EN[2] | Optional control used only for dual-channel configuration.<br>It should be low by default (single-channel configuration).<br><br>0: (default) Module configured as Luma video channel<br>(dual-channel configuration) or Composite video channel<br>(single-channel configuration).<br><br>1: Module configured as Chroma video channel<br>(dual-channel configuration). | RW           | 0x0   |
| 17    | AVDAC1_COMP_EN[1] | Optional control for lower output swing. It should be low<br>by default (high output swing).<br><br>0: (default) High full-scale output swing<br>1: Low full-scale output swing.                                                                                                                                                                                         | RW           | 0x0   |
| 16    | AVDAC1_COMP_EN[0] | Optional control for internal current reference. It should<br>be low by default (external current reference).<br><br>0: (default) External current reference (external resistor<br>connected to rset)<br><br>1: Internal current reference. In this case, clkres clock is<br>required to generate the current reference based on an<br>internal switched-cap resistor.   | RW           | 0x0   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>             | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------|-------------|--------------|
| 15:0        | RESERVED          | Reserved: Keep at reset value. | RW          | 0x0000       |

**Table 13-252. Register Call Summary for Register CONTROL\_AVDAC1**

---

SCM Register Manual

- SCM Register Summary: [0]

**Table 13-253. CONTROL\_AVDAC2**

|                         |                                     |                 |         |
|-------------------------|-------------------------------------|-----------------|---------|
| <b>Address Offset</b>   | 0x0000 02E8                         |                 |         |
| <b>Physical Address</b> | 0x4800 2558                         | <b>Instance</b> | GENERAL |
| <b>Description</b>      | control_avdac2 register description |                 |         |
| <b>Type</b>             | RW                                  |                 |         |

| Bits  | Field Name        | Description                                                                                                                                                                                                                                                                                                                                                              | Type         | Reset  |
|-------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------|
| 31    | RESERVED          | Reserved: Keep at reset value.                                                                                                                                                                                                                                                                                                                                           | RW<br>WtoClr | 0      |
| 30:20 | RESERVED          | Reserved.                                                                                                                                                                                                                                                                                                                                                                | R            | 0x000  |
| 19    | AVDAC2_COMP_EN[3] | Optional control used only for dual-channel configuration.<br>It should be low by default (single-channel configuration).<br><br>0: (default) Single channel<br><br>1: Dual channel configuration                                                                                                                                                                        | RW           | 0x1    |
| 18    | AVDAC2_COMP_EN[2] | Optional control used only for dual-channel configuration.<br>It should be low by default (single-channel configuration).<br><br>0: (default) Module configured as Luma video channel<br>(dual-channel configuration) or Composite video channel<br>(single-channel configuration).<br><br>1: Module configured as Chroma video channel<br>(dual-channel configuration). | RW           | 0x1    |
| 17    | AVDAC2_COMP_EN[1] | Optional control for lower output swing. It should be low<br>by default (high output swing).<br><br>0: (default) High full-scale output swing<br><br>1: Low full-scale output swing.                                                                                                                                                                                     | RW           | 0x0    |
| 16    | AVDAC2_COMP_EN[0] | Optional control for internal current reference. It should<br>be low by default (external current reference).<br><br>0: (default) External current reference (external resistor<br>connected to rset)<br><br>1: Internal current reference. In this case, clkres clock is<br>required to generate the current reference based on an<br>internal switched-cap resistor.   | RW           | 0x0    |
| 15:0  | RESERVED          | Reserved: Keep at reset value.                                                                                                                                                                                                                                                                                                                                           | RW           | 0x0000 |

**Table 13-254. Register Call Summary for Register CONTROL\_AVDAC2**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**Table 13-255. CONTROL\_CAMERA\_PHY\_CTRL**

|                         |                                                                                                    |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 02F0                                                                                        |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 2560                                                                                        |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Register to control the mode and multiplexing of the two camera complex IOs (CSIPHY2 and CSIPHY1 ) |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                 |                       |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name                    | Description                                                                                                                                                                                                                                                        | Type | Reset      |
|------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:5 | RESERVED                      | Reserved field                                                                                                                                                                                                                                                     | R    | 0x00000000 |
| 4    | R_CONTROL_CSI1_RX_SEL         | Selects the CAMERA PHY that will feed the receiver B on ISP2P<br>0 : CAMERA1_PHY data is sent to ISP2P receiver B<br>1 : CAMERA2_PHY data is sent to ISP2P receiver B                                                                                              | RW   | 0          |
| 3:2  | R_CONTROL_CAMERA1_PHY_CAMMODE | Sets the mode of CSIPHY1<br>00: D-PHY mode<br>01: CCP2 mode configured for data/strobe transmission<br>10: CCP2 mode configured for data/clock transmission<br>11: GPI mode<br>Not a dynamic signal. Should be changed only when the CSIPHY1 is in OFF power state | RW   | 0x0        |
| 1:0  | R_CONTROL_CAMERA2_PHY_CAMMODE | Sets the mode of CSIPHY2<br>00: D-PHY mode<br>01: CCP2 mode configured for data/strobe transmission<br>10: CCP2 mode configured for data/clock transmission<br>11: GPI mode<br>Not a dynamic signal. Should be changed only when the CSIPHY2 is in OFF power state | RW   | 0x0        |

**Table 13-256. Register Call Summary for Register CONTROL\_CAMERA\_PHY\_CTRL**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)

**NOTE:**

- If the parallel camera sensor is the only sensor connected to one CSIPHY, the SCM.CONTROL\_CAMERA0\_PHY\_CAMMOD and SCM.CONTROL\_CAMERA1\_PHY\_CAMMOD bits must be set to 0x11 (that is, GPI mode).
- If the parallel camera sensor and other camera sensor (CCP2 or CSI2) are connected to the same CSIPHY, the CONTROL\_CAMERAx\_PHY\_CAMMOD bit must be set for CCP2 or CSI2 mode, respectively, (even if only one pair is used as GPI for CPI mode). In that case, the corresponding CSI2\_COMPLEXIO\_CFG1.DATAx\_POSITION must be set to 0x0 for the lane used in GPI mode.

**Table 13-257. CONTROL\_IDCODE**

|                         |                         |                       |                 |  |  |  |  |  |        |  |  |  |   |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|--|--|--|--------|--|--|--|---|--|--|--|
| <b>Address Offset</b>   | 0x307F94                |                       |                 |  |  |  |  |  |        |  |  |  |   |  |  |  |
| <b>Physical Address</b> | 0x4830 A204             |                       |                 |  |  |  |  |  |        |  |  |  |   |  |  |  |
| <b>Description</b>      | Device IDCODE           |                       |                 |  |  |  |  |  |        |  |  |  |   |  |  |  |
| <b>Type</b>             | R                       |                       |                 |  |  |  |  |  |        |  |  |  |   |  |  |  |
| 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 |  |  |  |  |  |        |  |  |  |   |  |  |  |
| VERSION                 | HAWKEYE                 |                       |                 |  |  |  |  |  | TI_IDM |  |  |  | – |  |  |  |

| Bits  | Field Name | Description                | Type | Reset                 |
|-------|------------|----------------------------|------|-----------------------|
| 31:28 | VERSION    | Revision number            | R    | 0x-( <sup>(1)</sup> ) |
| 27:12 | HAWKEYE    | Hawkeye number             | R    | 0x-( <sup>(1)</sup> ) |
| 11:1  | TI_IDM     | Manufacturer identity (TI) | R    | 0x17                  |
| 0     | –          | Always set to 1            | R    | 0x1                   |

<sup>(1)</sup> For more information, see , *Device Identification*, in, *Introduction*.

**Table 13-258. Register Call Summary for Register CONTROL\_IDCODE**

- [SCM Register Summary: \[0\]](#)

**13.6.3.4 MEM\_WKUP Register Description**

Physical addresses 0x4800 2600 to 0x4800 29FC are memories mapped for save and restore location (1KB).

- 0x4800 2600 - 0x4800 28DC: nonaccessible (pad configuration)
- 0x4800 28E0 - 0x4800 29FC: user accessible

**13.6.3.5 PADCONFS\_WKUP Register Description**

Each 32-bit PADCONF\_WKUP register gathers the configuration of two pads. For example, CONTROL.CONTROL\_PADCONF\_I2C4\_SCL pad is used to configure i2c4\_scl pad (bits [15:0]) and i2c4\_sda pad (bits [31:16]). See [Figure 13-8](#) for more information about PADCONF registers.

According to the pad type, some features are configurable or not. [Table 13-82](#) gives the description of a fully configurable pad.

[Table 13-259](#) describes the reset values, the capabilities, and the corresponding register for each pad.

**NOTE:**

- In the following table, a dash (-) indicates that the field is hardwired to logic 0. No corresponding control block ports are implemented for these bits.
- Reset values of fields MuxMode and PU/PD vary for different pads. Hence the reset values of these bitfields are shown in [Table 13-84](#), wherever supported.

**CAUTION**

During booting process, Device Boot ROM code alters the padconfiguration bitfields, depending on the targeted booting interface or memory. The Boot Code does not restore the initial padconf reset values at the end of the booting procedure.

**Table 13-259. CONTROL\_PADCONF\_WKUP\_CAPABILITIES**

| REGISTER NAME                          | Pad name        | Physical address | WakeUpx | Off Mode | Input Enable | Reserved | PU/PD | MuxMode |
|----------------------------------------|-----------------|------------------|---------|----------|--------------|----------|-------|---------|
| CONTROL_PADCONF_I2C4_SCL[15:0]         | i2c4_scl        | 0x48002A00       | --      | -----    | 0b1          | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_I2C4_SCL[31:16]        | i2c4_sda        | 0x48002A00       | --      | -----    | 0b1          | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_SYS_32K[15:0]          | sys_32k         | 0x48002A04       | --      | -----    | 0b1          | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_SYS_32K[31:16]         | sys_clkreq      | 0x48002A04       | 0b00    | -----    | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SYS_NRESWARM[15:0]     | sys_nreswarm    | 0x48002A08       | 0b00    | -----    | -            | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_SYS_NRESWARM[31:16]    | sys_boot0       | 0x48002A08       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SYS_BOOT1[15:0]        | sys_boot1       | 0x48002A0C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SYS_BOOT1[31:16]       | sys_boot2       | 0x48002A0C       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SYS_BOOT3[15:0]        | sys_boot3       | 0x48002A10       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SYS_BOOT3[31:16]       | sys_boot4       | 0x48002A10       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SYS_BOOT5[15:0]        | sys_boot5       | 0x48002A14       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SYS_BOOT5[31:16]       | sys_boot6       | 0x48002A14       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b00  | 0b000   |
| CONTROL_PADCONF_SYS_OFF_MODE[15:0]     | sys_off_mode    | 0x48002A18       | 0b00    | -----    | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_SYS_OFF_MODE[31:16]    | sys_clkout1     | 0x48002A18       | 0b00    | -----    | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_JTAG_NTRST[15:0]       | jtag_nrst       | 0x48002A1C       | --      | -----    | 0b1          | 0b000    | 0b01  | ---     |
| CONTROL_PADCONF_JTAG_NTRST[31:16]      | jtag_tck        | 0x48002A1C       | --      | -----    | 0b1          | 0b000    | 0b01  | ---     |
| CONTROL_PADCONF_JTAG_TMS_TMSC[15:0]    | jtag_tms_tmse   | 0x48002A20       | --      | -----    | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_JTAG_TMS_TMSC[31:16]   | jtag_tdi        | 0x48002A20       | --      | -----    | 0b1          | 0b000    | 0b11  | ---     |
| CONTROL_PADCONF_JTAG_EMU0[15:0]        | jtag_emu0       | 0x48002A24       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_JTAG_EMU0[31:16]       | jtag_emu1       | 0x48002A24       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b11  | 0b000   |
| CONTROL_PADCONF_CHASSIS_SWAKEUP[15:0]  | chassis_swakeup | 0x48002A4C       | --      | -----    | 0b1          | 0b000    | 0b01  | ---     |
| CONTROL_PADCONF_CHASSIS_SWAKEUP[31:16] | jtag_rtck       | 0x48002A4C       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_JTAG_TDO[15:0]         | jtag_tdo        | 0x48002A50       | --      | -----    | -            | 0b000    | 0b00  | ---     |
| CONTROL_PADCONF_JTAG_TDO[31:16]        | un-used         | 0x48002A50       | --      | -----    | -            | 0b000    | --    | ---     |
| CONTROL_PADCONF_GPIO127[15:0]          | Reserved        | 0x48002A54       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_GPIO127[31:16]         | Reserved        | 0x48002A54       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_GPIO128[15:0]          | Reserved        | 0x48002A58       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |
| CONTROL_PADCONF_GPIO128[31:16]         | Reserved        | 0x48002A58       | 0b00    | 0b00000  | 0b1          | 0b000    | 0b01  | 0b111   |

### 13.6.3.6 GENERAL\_WKUP Register Description

**Table 13-260. CONTROL\_WKUP\_CTRL**

|                         |                                                        |                         |                 |                 |              |
|-------------------------|--------------------------------------------------------|-------------------------|-----------------|-----------------|--------------|
| <b>Address Offset</b>   | 0x0000 0000                                            | <b>Physical Address</b> | 0x48002A5C      | <b>Instance</b> | GENERAL_WKUP |
| <b>Description</b>      | <a href="#">CONTROL_WKUP_CTRL</a> register description |                         |                 |                 |              |
| <b>Type</b>             | RW                                                     |                         |                 |                 |              |
| 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 |                 |              |
|                         |                                                        |                         |                 |                 |              |

RESERVED

|                                     |                                    |                                    |
|-------------------------------------|------------------------------------|------------------------------------|
| GPIO_1_IN_SEL_SAD2D_NRESWARM_IN_SEL | GPIO_IO_PWRDNZ                     | MM_FSUSB3_TXEN_N_OUT_POLARITY_CTRL |
| MM_FSUSB2_TXEN_N_OUT_POLARITY_CTRL  | MM_FSUSB2_TXEN_N_OUT_POLARITY_CTRL | MM_FSUSB1_TXEN_N_OUT_POLARITY_CTRL |

| Bits | Field Name                          | Description                                                                                                                                                                                                                                                            | Type | Reset |
|------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:7 | RESERVED                            | Reserved field                                                                                                                                                                                                                                                         | R    | 0     |
| 6    | GPIO_IO_PWRDNZ                      | Software must keep this signal 0 whenever SIM_VDDS voltage is changing.<br>When GPIO_IO_PWRDNZ is 0, input and output buffers in the gpio126, gpio127, and gpio129 associated exteneded-drain I/O cell are disabled. Pad can be pulled down by asserting the PIPD pin. | RW   | 0x0   |
| 5    | GPIO_1_IN_SEL_SAD2D_NRESWARM_IN_SEL | Mux select for GPIO1/SAD2D_NRESWARM bit                                                                                                                                                                                                                                | RW   | 0     |
| 4:3  | RESERVED                            | Reserved field                                                                                                                                                                                                                                                         | R    | 0x0   |
| 2    | MM_FSUSB3_TXEN_N_OUT_POLARITY_CTRL  | Polarity control for TXEN signal of multimode USB interface port3<br>0 : Active low<br>1 : Active high                                                                                                                                                                 | RW   | 0     |
| 1    | MM_FSUSB2_TXEN_N_OUT_POLARITY_CTRL  | Polarity control for TXEN signal of multimode USB interface port2<br>0 : Active low<br>1 : Active high                                                                                                                                                                 | RW   | 0     |
| 0    | MM_FSUSB1_TXEN_N_OUT_POLARITY_CTRL  | Polarity control for TXEN signal of multimode USB interface port1<br>0 : Active low<br>1 : Active high                                                                                                                                                                 | RW   | 0     |

**Table 13-261. Register Call Summary for Register CONTROL\_WKUP\_CTRL**
**SCM Functional Description**

- [Extended-Drain I/O Pin and PBias Cells: \[0\] \[1\] \[2\]](#)

**SCM Programming Model**

- [Extended-Drain I/Os and PBias Cells Programming Guide: \[3\] \[4\]](#)

**SCM Register Manual**

- [SCM Register Summary: \[5\]](#)
- [GENERAL\\_WKUP Register Description: \[6\]](#)

**Table 13-262. CONTROL\_WKUP\_DEBOBS\_0**

|                  |         |          |         |          |         |          |         |                                                                                             |    |    |    |              |    |    |    |  |  |  |  |
|------------------|---------|----------|---------|----------|---------|----------|---------|---------------------------------------------------------------------------------------------|----|----|----|--------------|----|----|----|--|--|--|--|
| Address Offset   |         |          |         |          |         |          |         | 0x0000 000C                                                                                 |    |    |    |              |    |    |    |  |  |  |  |
| Physical Address |         |          |         |          |         |          |         | Instance                                                                                    |    |    |    | GENERAL_WKUP |    |    |    |  |  |  |  |
| Description      |         |          |         |          |         |          |         | Select the WKUP domain set of signals to be observed for hw_dbg3, hw_dbg2, hw_dbg1, hw_dbg0 |    |    |    |              |    |    |    |  |  |  |  |
| Type             |         |          |         |          |         |          |         | RW                                                                                          |    |    |    |              |    |    |    |  |  |  |  |
| 31               | 30      | 29       | 28      | 27       | 26      | 25       | 24      | 23                                                                                          | 22 | 21 | 20 | 19           | 18 | 17 | 16 |  |  |  |  |
| RESERVED         | OBSMUX3 | RESERVED | OBSMUX2 | RESERVED | OBSMUX1 | RESERVED | OBSMUX0 | 7                                                                                           | 6  | 5  | 4  | 3            | 2  | 1  | 0  |  |  |  |  |

| Bits  | Field Name | Description                                          | Type                             | Reset |
|-------|------------|------------------------------------------------------|----------------------------------|-------|
| 31:29 | RESERVED   | Read returns reset value.                            | R                                | 0x0   |
| 28:24 | OBSMUX3    | Select the set of signals to be observed for hw_dbg3 | See <a href="#">Table 13-264</a> | 0x00  |
| 23:21 | RESERVED   | Read returns reset value.                            | R                                | 0x0   |
| 20:16 | OBSMUX2    | Select the set of signals to be observed for hw_dbg2 | See <a href="#">Table 13-264</a> | 0x00  |
| 15:13 | RESERVED   | Read returns reset value.                            | R                                | 0x0   |
| 12:8  | OBSMUX1    | Select the set of signals to be observed for hw_dbg1 | See <a href="#">Table 13-264</a> | 0x00  |
| 7:5   | RESERVED   | Read returns reset value.                            | R                                | 0x0   |
| 4:0   | OBSMUX0    | Select the set of signals to be observed for hw_dbg0 | See <a href="#">Table 13-264</a> | 0x00  |

**Table 13-263. Register Call Summary for Register CONTROL\_WKUP\_DEBOBS\_0**

## SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\] \[3\] \[4\]](#)

## SCM Register Manual

- [SCM Register Summary: \[5\]](#)

**Table 13-264. Type Value For CONTROL\_WKUP\_DEBOBS\_0 Register**

| CONTROL_WKUP_DEBOBS_4[31] WKUPOBSERVABILITYDISABLE bit | 0  | 1 |
|--------------------------------------------------------|----|---|
| OBSMUX3                                                | RW | R |
| OBSMUX2                                                | RW | R |
| OBSMUX1                                                | RW | R |
| OBSMUX0                                                | RW | R |

**Table 13-265. CONTROL\_WKUP\_DEBOBS\_1**

|                  |    |    |    |    |    |    |    |                                                                                             |    |    |    |              |    |    |    |  |  |  |  |
|------------------|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------|----|----|----|--------------|----|----|----|--|--|--|--|
| Address Offset   |    |    |    |    |    |    |    | 0x0000 0010                                                                                 |    |    |    |              |    |    |    |  |  |  |  |
| Physical Address |    |    |    |    |    |    |    | Instance                                                                                    |    |    |    | GENERAL_WKUP |    |    |    |  |  |  |  |
| Description      |    |    |    |    |    |    |    | Select the WKUP domain set of signals to be observed for hw_dbg7, hw_dbg6, hw_dbg5, hw_dbg4 |    |    |    |              |    |    |    |  |  |  |  |
| Type             |    |    |    |    |    |    |    | RW                                                                                          |    |    |    |              |    |    |    |  |  |  |  |
| 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                                                                                          | 22 | 21 | 20 | 19           | 18 | 17 | 16 |  |  |  |  |

|          |         |          |         |          |         |          |         |
|----------|---------|----------|---------|----------|---------|----------|---------|
| RESERVED | OBSMUX7 | RESERVED | OBSMUX6 | RESERVED | OBSMUX5 | RESERVED | OBSMUX4 |
|----------|---------|----------|---------|----------|---------|----------|---------|

| Bits  | Field Name | Description                                          | Type                                | Reset |
|-------|------------|------------------------------------------------------|-------------------------------------|-------|
| 31:29 | RESERVED   | Read returns reset value.                            | R                                   | 0x0   |
| 28:24 | OBSMUX7    | Select the set of signals to be observed for hw_dbg7 | See<br><a href="#">Table 13-267</a> | 0x00  |
| 23:21 | RESERVED   | Read returns reset value.                            | R                                   | 0x0   |
| 20:16 | OBSMUX6    | Select the set of signals to be observed for hw_dbg6 | See<br><a href="#">Table 13-267</a> | 0x00  |
| 15:13 | RESERVED   | Read returns reset value.                            | R                                   | 0x0   |
| 12:8  | OBSMUX5    | Select the set of signals to be observed for hw_dbg5 | See<br><a href="#">Table 13-267</a> | 0x00  |
| 7:5   | RESERVED   | Read returns reset value.                            | R                                   | 0x0   |
| 4:0   | OBSMUX4    | Select the set of signals to be observed for hw_dbg4 | See<br><a href="#">Table 13-267</a> | 0x00  |

**Table 13-266. Register Call Summary for Register CONTROL\_WKUP\_DEBOBS\_1**

## SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\] \[3\] \[4\]](#)

## SCM Register Manual

- [SCM Register Summary: \[5\]](#)

**Table 13-267. Type Value For CONTROL\_WKUP\_DEBOBS\_1 Register**

| CONTROL_WKUP_DEBOBS_4[31] WKUPOBSERVABILITYDISABLE bit | 0  | 1 |
|--------------------------------------------------------|----|---|
| OBSMUX7                                                | RW | R |
| OBSMUX6                                                | RW | R |
| OBSMUX5                                                | RW | R |
| OBSMUX4                                                | RW | R |

**Table 13-268. CONTROL\_WKUP\_DEBOBS\_2**

|                |                                                                                              |                  |             |          |              |
|----------------|----------------------------------------------------------------------------------------------|------------------|-------------|----------|--------------|
| Address Offset | 0x0000 0014                                                                                  | Physical Address | 0x4800 2A70 | Instance | GENERAL_WKUP |
| Description    | Select the WKUP domain set of signals to be observed for hw_dbg11 hw_dbg10, hw_dbg9, hw_dbg8 |                  |             |          |              |
| Type           | RW                                                                                           |                  |             |          |              |

|          |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |
|----------|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|--|
| 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 |  |
| RESERVED |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |   |   | RESERVED |   |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                                           | Type                                | Reset |
|-------|------------|-------------------------------------------------------|-------------------------------------|-------|
| 31:29 | RESERVED   | Read returns reset value.                             | R                                   | 0x0   |
| 28:24 | OBSMUX11   | Select the set of signals to be observed for hw_dbg11 | See<br><a href="#">Table 13-270</a> | 0x00  |
| 23:21 | RESERVED   | Read returns reset value.                             | R                                   | 0x0   |
| 20:16 | OBSMUX10   | Select the set of signals to be observed for hw_dbg10 | See<br><a href="#">Table 13-270</a> | 0x00  |
| 15:13 | RESERVED   | Read returns reset value.                             | R                                   | 0x0   |
| 12:8  | OBSMUX9    | Select the set of signals to be observed for hw_dbg9  | See<br><a href="#">Table 13-270</a> | 0x00  |

## SCM Register Manual

www.ti.com

| Bits | Field Name | Description                                          | Type                                | Reset |
|------|------------|------------------------------------------------------|-------------------------------------|-------|
| 7:5  | RESERVED   | Read returns reset value.                            | R                                   | 0x0   |
| 4:0  | OBSMUX8    | Select the set of signals to be observed for hw_dbg8 | See<br><a href="#">Table 13-270</a> | 0x00  |

**Table 13-269. Register Call Summary for Register CONTROL\_WKUP\_DEBOBS\_2**

SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\] \[3\] \[4\]](#)

SCM Register Manual

- [SCM Register Summary: \[5\]](#)

**Table 13-270. Type Value For CONTROL\_WKUP\_DEBOBS\_2 Register**

| CONTROL_WKUP_DEBOBS_4[31] WKUPOBSERVABILITYDISABLE bit | 0  | 1 |
|--------------------------------------------------------|----|---|
| OBSMUX11                                               | RW | R |
| OBSMUX10                                               | RW | R |
| OBSMUX9                                                | RW | R |
| OBSMUX8                                                | RW | R |

**Table 13-271. CONTROL\_WKUP\_DEBOBS\_3**

| Address Offset          | 0x0000 0018                                                                                    |                       |                 |          |          |          |          |          |          |          |          |  |  |  |          |              |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|----------|----------|----------|----------|----------|----------|----------|--|--|--|----------|--------------|--|--|--|
| Physical Address        | 0x4800 2A74                                                                                    |                       |                 |          |          |          |          |          |          |          |          |  |  |  | Instance | GENERAL_WKUP |  |  |  |
| Description             | Select the WKUP domain set of signals to be observed for hw_dbg15 hw_dbg14, hw_dbg13, hw_dbg12 |                       |                 |          |          |          |          |          |          |          |          |  |  |  |          |              |  |  |  |
| Type                    | RW                                                                                             |                       |                 |          |          |          |          |          |          |          |          |  |  |  |          |              |  |  |  |
| 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 | RESERVED | OBSMUX15 | RESERVED | OBSMUX14 | RESERVED | OBSMUX13 | RESERVED | OBSMUX12 |  |  |  |          |              |  |  |  |

| Bits  | Field Name | Description                                           | Type                                | Reset |
|-------|------------|-------------------------------------------------------|-------------------------------------|-------|
| 31:29 | RESERVED   | Read returns reset value.                             | R                                   | 0x0   |
| 28:24 | OBSMUX15   | Select the set of signals to be observed for hw_dbg15 | See<br><a href="#">Table 13-273</a> | 0x00  |
| 23:21 | RESERVED   | Read returns reset value.                             | R                                   | 0x0   |
| 20:16 | OBSMUX14   | Select the set of signals to be observed for hw_dbg14 | See<br><a href="#">Table 13-273</a> | 0x00  |
| 15:13 | RESERVED   | Read returns reset value.                             | R                                   | 0x0   |
| 12:8  | OBSMUX13   | Select the set of signals to be observed for hw_dbg13 | See<br><a href="#">Table 13-273</a> | 0x00  |
| 7:5   | RESERVED   | Read returns reset value.                             | R                                   | 0x0   |
| 4:0   | OBSMUX12   | Select the set of signals to be observed for hw_dbg12 | See<br><a href="#">Table 13-273</a> | 0x00  |

**Table 13-272. Register Call Summary for Register CONTROL\_WKUP\_DEBOBS\_3**

SCM Functional Description

- [Description: \[0\]](#)
- [Observability Tables: \[1\] \[2\] \[3\] \[4\]](#)

**Table 13-272. Register Call Summary for Register CONTROL\_WKUP\_DEBOBS\_3 (continued)**

SCM Register Manual

- [SCM Register Summary: \[5\]](#)

**Table 13-273. Type Value For CONTROL\_WKUP\_DEBOBS\_3 Register**

|                                                               |    |   |
|---------------------------------------------------------------|----|---|
| <b>CONTROL_WKUP_DEBOBS_4[31]</b> WKUPOBSERVABILITYDISABLE bit | 0  | 1 |
| OBSMUX15                                                      | RW | R |
| OBSMUX14                                                      | RW | R |
| OBSMUX13                                                      | RW | R |
| OBSMUX12                                                      | RW | R |

**Table 13-274. CONTROL\_WKUP\_DEBOBS\_4**

| Address Offset | 0x0000 001C                                                                 |  | Physical Address | 0x4800 2A78 | Instance | GENERAL_WKUP |
|----------------|-----------------------------------------------------------------------------|--|------------------|-------------|----------|--------------|
| Description    | Select the WKUP domain set of signals to be observed for hw_dbg17, hw_dbg16 |  |                  |             | Type     | RW           |
|                |                                                                             |  |                  |             |          |              |

|                          |                         |                       |                  |
|--------------------------|-------------------------|-----------------------|------------------|
| 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  |
| WKUPOBSERVABILITYDISABLE | RESERVED                | OBSMUX17              | RESERVED OSMUX16 |

| Bits  | Field Name               | Description                                                                                                                                                                                                                              | Type                             | Reset   |
|-------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|---------|
| 31    | WKUPOBSERVABILITYDISABLE | Control the observability feature<br>0x0: Observability can be configured through the ObsMux bit field in CONTROL_DEBOBS register<br>0x1: Observability is disabled. If pads are configured for the 'hardware debug', output is tied low | See <a href="#">Table 13-276</a> | 0x0     |
| 30:13 | RESERVED                 | Read returns reset value.                                                                                                                                                                                                                | R                                | 0x00000 |
| 12:8  | OBSMUX17                 | Select the set of signals to be observed for hw_dbg17                                                                                                                                                                                    | See <a href="#">Table 13-276</a> | 0x00    |
| 7:5   | RESERVED                 | Read returns reset value.                                                                                                                                                                                                                | R                                | 0x0     |
| 4:0   | OBSMUX16                 | Select the set of signals to be observed for hw_dbg16                                                                                                                                                                                    | See <a href="#">Table 13-276</a> | 0x00    |

**Table 13-275. Register Call Summary for Register CONTROL\_WKUP\_DEBOBS\_4**

SCM Functional Description

- [Description: \[0\] \[1\]](#)
- [Observability Tables: \[2\] \[3\]](#)

SCM Register Manual

- [SCM Register Summary: \[4\]](#)
- [GENERAL\\_WKUP Register Description: \[5\] \[6\] \[7\] \[8\] \[9\]](#)

**Table 13-276. Type Value For CONTROL\_WKUP\_DEBOBS\_4 Register**

| CONTROL_WKUP_DEBOBS_4[31] WKUPOBSERVABILITYDISABLE bit | 0     | 1 |
|--------------------------------------------------------|-------|---|
| WKUPOBSERVABILITYDISABLE                               | R/OCO | R |
| OBSMUX17                                               | RW    | R |
| OBSMUX16                                               | RW    | R |

**Table 13-277. CONTROL\_PROG\_IO\_WKUP1**

|                  |                                            |          |              |
|------------------|--------------------------------------------|----------|--------------|
| Address Offset   | 0x0000 0024                                | Instance | GENERAL_WKUP |
| Physical Address | 0x4800 2A80                                |          |              |
| Description      | CONTROL_PROG_IO_WKUP1 register description |          |              |
| Type             | RW                                         |          |              |

| 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 |
|------------|------------|---------------|---------------|-------------|-------------|----------------|----------------|----------------|----------------|----------------|--------------------------|----------|-------------------|-----------|----------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| PRG_32K_SC | PRG_32K_LB | PRG_CLKREQ_SC | PRG_CLKREQ_LB | PRG_NIRQ_SC | PRG_NIRQ_LB | PRG_SYSBOOT_LB | PRG_OFFMODE_SC | PRG_OFFMODE_LB | PRG_CLKOUT1_SC | PRG_CLKOUT1_LB | PRG_CHASSIS_PRCM_LB_WKUP | RESERVED | PRG_SR_PULLUPRESX | PRG_SR_LB | RESERVED |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name    | Description                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | PRG_32K_SC    | Slew rate control bits.<br>Format used in the field name below is :<br>(programmable_group_name)_ (configurable_pin on I/O cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations.                                                                                                         | RW   | 0x0   |
| 29:28 | PRG_32K_LB    | Effective TL length and farend capacitive load controls.<br>This bit allows control of programmable drive/slew control on I/O cell. Format used in the field name below is:<br>(programmable_group_name)_ (configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations.  | RW   | 0x0   |
| 27:26 | PRG_CLKREQ_SC | Slew rate control bits.<br>Format used in the field name below is:<br>(programmable_group_name)_ (configurable_pin on I/O cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations.                                                                                                          | RW   | 0x0   |
| 25:24 | PRG_CLKREQ_LB | Effective TL length and farend capacitive load controls.<br>This bit allows control of programmable drive/slew control on I/O cell. Format used in the field name below is:<br>(programmable_group_name)_ (configurable_pin on I/O cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations. | RW   | 0x0   |
| 23:22 | PRG_NIRQ_SC   | Slew rate control bits.<br>Format used in the field name below is:<br>(programmable_group_name)_ (configurable_pin on I/O cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations.                                                                                                          | RW   | 0x0   |

| <b>Bits</b> | <b>Field Name</b>         | <b>Description</b>                                                                                                                                                                                                                                                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 21:20       | PRG_NIRQ_LB               | Effective TL length and farend capacitive load controls.<br>This bit allows control of programmable drive/slew control on IO cell. Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on I/O cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations.          | RW          | 0x0          |
| 19          | PRG_SYSBOOT_LB            | Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on I/O cell)<br>Far end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm:<br>0x0: Far end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 18:17       | PRG_OFFMODE_SC            | Slew rate control bits.<br>Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on I/O cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations.                                                                                                                  | RW          | 0x0          |
| 16:15       | PRG_OFFMODE_LB            | Effective TL length and farend capacitive load controls.<br>This bit allows control of programmable drive/slew control on I/O cell. Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on I/O cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations.         | RW          | 0x0          |
| 14:13       | PRG_CLKOUT1_SC            | Slew rate control bits.<br>Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on I/O cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations.                                                                                                                  | RW          | 0x0          |
| 12:11       | PRG_CLKOUT1_LB            | Effective TL length and farend capacitive load controls.<br>This bit allows control of programmable drive/slew control on IO cell. Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on I/O cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bitfield combinations.          | RW          | 0x0          |
| 10          | PRG_CHASSIS_PRCM_LB_WK_UP | Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on I/O cell)<br>Far-end load setting. Transmission Line (TL) characteristic impedance is 50 Ohm, TL capacitance =1pF / cm:<br>0x0: Far-end load = [1pF-10pF] / TL length=[1cm-6cm]<br>0x1: Far-end load = [10pF-16pF] / TL length=[1cm-6cm] | RW          | 0            |
| 9:8         | PRG_GPIO_128_SC           | Slew rate control bits.<br>Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on I/O cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bit field combinations.                                                                                                                 | RW          | 0x0          |
| 7:6         | PRG_GPIO_128_LB           | Effective TL length and farend capacitive load controls.<br>This bit allows control of programmable drive/slew control on I/O cell.<br>Format used in the field name below is:<br>(programmable_group_name)_(_configurable_pin on IO cell)<br>See <a href="#">Table 13-21</a> for the allowed SC vs LB bit field combinations.      | RW          | 0x0          |

| Bits | Field Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Type | Reset |
|------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 5    | PRG_SR_PULLUPRESX | <p>Format used in the field name below is:<br/>         (programmable_group_name)_(configurable_pin on IO cell)</p> <p>(SR interface) I2C4 pad group control for external / internal pull-up resistor enable:</p> <p>0x0: Enables internal pull-ups for the I2C4 pad group<br/>         0x1: Disables internal pull-ups for the I2C4 pad group</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0     |
| 4:3  | PRG_SR_LB         | <p>The bits select a proper resistor value for the (SR interface) I2C4 pull-ups for a given load range at FS / HS modes.</p> <p>Format used in the field name below is :<br/>         (programmable_group_name)_(configurable_pin on IO cell)</p> <p>FS mode :</p> <ul style="list-style-type: none"> <li>0b00: 4,5K Ohms / 5-15pF cap.load</li> <li>0b01: 2,1K Ohms / 15-50pF cap.load</li> <li>0b10: 860 Ohms / 50-150pF cap.load</li> <li>0b11: Reserved</li> </ul> <p>HS mode :</p> <ul style="list-style-type: none"> <li>0b00: 1,66K Ohms / 5-12pF cap.load</li> <li>0b01: 920 Ohms / 12-25pF cap.load</li> <li>0b10: 500 Ohms/ 25-50pF cap.load</li> <li>0b11: 300 Ohms/ 50-80pF cap.load</li> </ul> <p>See <a href="#">Table 13-24</a> for example [LB1:LB0] bitfield vs PRG_I2C4_PULLUPRESX bit combinations.</p> | RW   | 0x0   |
| 2:0  | RESERVED          | Reserved field                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R    | 0x0   |

**Table 13-278. Register Call Summary for Register CONTROL\_PROG\_IO\_WKUP1**

## SCM Functional Description

- [Signal Integrity Parameter Controls Overview: \[0\]](#)
- [Device Interfaces Signal Group Controls Mapping: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\]](#)

## SCM Programming Model

- [I2C I/O Internal Pullup Enable: \[18\]](#)

## SCM Register Manual

- [SCM Register Summary: \[19\]](#)
- [GENERAL\\_WKUP Register Description: \[20\]](#)

**Table 13-279. CONTROL\_BGAPTS\_WKUP**

|                         |                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |              |  |        |          |         |
|-------------------------|----------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|--------------|--|--------|----------|---------|
| <b>Address Offset</b>   | 0x0000 0028                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | GENERAL_WKUP |  |        |          |         |
| <b>Physical Address</b> | 0x4800 2A84                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |              |  |        |          |         |
| <b>Description</b>      | <a href="#">CONTROL_BGAPTS_WKUP register description</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |              |  |        |          |         |
| <b>Type</b>             | RW                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |              |  |        |          |         |
| 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 |              |  |        |          |         |
| RESERVED                |                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |              |  | BGROFF | RESERVED | TMPSOFF |

| Bits | Field Name | Description                                                                                                                                                                                                      | Type | Reset       |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:3 | RESERVED   | Reserved field                                                                                                                                                                                                   | R    | 0x0000 0000 |
| 2    | BGROFF     | <p>Used for ON/OFF control of BGAPTS module</p> <p>0 : BGAP is ON<br/>         1 : BGAP is OFF</p> <p>Note : BGAP cannot be turned off with TMPS ON. i.e.<br/>         BGROFF 1 AND TMPSOFF 0 is not allowed</p> | RW   | 0           |
| 1    | RESERVED   | Reserved field                                                                                                                                                                                                   | R    | 0           |

| Bits | Field Name | Description                                                                                                                                                     | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | TMPSOFF    | Used to control the TMPSOFF input of BGAPTS module<br>1 : Temperature sensor and thermal shutdown in OFF mode<br>0 : Temperature sensor and thermal shutdown ON | RW   | 0     |

**Table 13-280. Register Call Summary for Register CONTROL\_BGAPTS\_WKUP**

SCM Functional Description

- [Band Gap Voltage and Temperature Sensor: \[0\]](#) [\[1\]](#)

SCM Register Manual

- [SCM Register Summary: \[2\]](#)
- [GENERAL\\_WKUP Register Description: \[3\]](#)

**Table 13-281. CONTROL\_SRAM\_LDO\_CTRL**

|                         |                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 002C                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 2A88                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | <a href="#">CONTROL_SRAM_LDO_CTRL register description</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | RESERVED                | RESERVED              | RESERVED        |

| Bits  | Field Name | Description                                          | Type | Reset |
|-------|------------|------------------------------------------------------|------|-------|
| 31:23 | RESERVED   | Reserved field                                       | R    | 0x000 |
| 22:16 | RESERVED   | Write the reset value; read returns the reset value. | RW   | 0     |
| 15:6  | RESERVED   | Reserved field                                       | R    | 0x000 |
| 5:0   | RESERVED   | Write the reset value; read returns the reset value. | RW   | 0     |

**Table 13-282. Register Call Summary for Register CONTROL\_SRAM\_LDO\_CTRL**

SCM Register Manual

- [SCM Register Summary: \[0\]](#)
- [GENERAL\\_WKUP Register Description: \[1\]](#)

**Table 13-283. CONTROL\_VBBLDO\_SW\_CTRL**

|                         |                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0034                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4800 2A90                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | <a href="#">CONTROL_VBBLDO_SW_CTRL register description</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                                                                  |
|-------------------------|-------------------------|-----------------------|------------------------------------------------------------------|
| 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                                                  |
| RESERVED                |                         |                       | NOCAP_MUX_SEL<br>BBSEL_MUX_SEL<br>LDOBYPASSZ_MUX_SEL<br>AIOPASSZ |

| Bits | Field Name         | Description                                                    | Type | Reset     |
|------|--------------------|----------------------------------------------------------------|------|-----------|
| 31:7 | RESERVED           | Reserved field                                                 | R    | 0x0000000 |
| 6    | NOCAP_MUX_SEL      | Enable NOCAP Override                                          | RW   | 0         |
| 5    | NOCAP              | Override NOCAP                                                 | RW   | 0         |
| 4    | BBSEL_MUX_SEL      | Enables BBSEL Override                                         | RW   | 0         |
| 3    | BBSEL              | Override for BBSEL signal                                      | RW   | 0         |
| 2    | LDOBYPASSZ_MUX_SEL | Enable LDOBYPASSZ Override                                     | RW   | 0         |
| 1    | LDOBYPASSZ         | Override LDOBYPASSZ                                            | RW   | 0         |
| 0    | AIPOFF             | Override AIPOFF input. When high will act as AIPOFF for VBBLDO | RW   | 0         |

**Table 13-284. Register Call Summary for Register CONTROL\_VBBLDO\_SW\_CTRL**

## SCM Register Manual

- [SCM Register Summary: \[0\]](#)
- [GENERAL\\_WKUP Register Description: \[1\]](#)

## ***Interprocessor Communication***

This chapter describes the interprocessor communication (IPC) module in the device.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| <b>Topic</b>                                          | <b>Page</b> |
|-------------------------------------------------------|-------------|
| <b>14.1 IPC Overview .....</b>                        | <b>2660</b> |
| <b>14.2 IPC Integration .....</b>                     | <b>2660</b> |
| <b>14.3 IPC Mailbox Functional Description .....</b>  | <b>2664</b> |
| <b>14.4 IPC Mailbox Basic Programming Model .....</b> | <b>2667</b> |
| <b>14.5 IPC Mailbox Register Manual .....</b>         | <b>2672</b> |

## 14.1 IPC Overview

Communication between the on-chip processors of the device uses a queued mailbox-interrupt mechanism.

The queued mailbox-interrupt mechanism allows the software to establish a communication channel between two processors through a set of registers and associated interrupt signals by sending and receiving messages (mailboxes).

[Figure 14-1](#) shows a block diagram of the interprocessor communication (IPC) module.

**Figure 14-1. Simplified Block Diagram of the IPC**



ipc-001

The mailbox module includes these features:

- Two mailbox message queues for microprocessor unit (MPU) and imaging video and audio accelerator (IVA2.2) communications.
- Flexible assignment of receiver and sender for each mailbox through interrupt configuration
- 32-bit message width
- Four-message FIFO depth for each message queue
- Message reception and queue-not-full notification using interrupts
- Support of 16-/32-bit addressing scheme
- Power management support
- Automatic idle mode for power savings

## 14.2 IPC Integration

[Figure 14-2](#) highlights the IPC integration in the device.

**Figure 14-2. IPC Integration**

ipc-002

### 14.2.1 Clocking, Reset, and Power-Management Scheme

#### 14.2.1.1 Clocks

##### 14.2.1.1.1 Module Clocks

The mailbox module receives one input clock, CORE\_L4\_ICLK, from the power, reset, and clock management (PRCM) module. CORE\_L4\_ICLK is gated internally and can be turned off to lower operating power when a module is not active. The exact frequency of this clock depends on PRCM programming.

#### 14.2.1.2 Resets

The IPC supports both a hardware reset and a software reset.

##### 14.2.1.2.1 Hardware Reset

The mailbox module receives its reset signal, CORE\_RST (the reset signal of the CORE power domain), from the PRCM module.

##### 14.2.1.2.2 Software Reset

The mailbox module supports a software reset by accessing the MAILBOX.[MAILBOX\\_SYSCONFIG\[1\]](#) SOFTRESET bit (0: normal mode, 1: module is reset).

#### 14.2.1.3 Power Domains

The mailbox module connects to the CORE power domain.

## 14.2.1.4 Power Management

### 14.2.1.4.1 System Power Management

This section describes system power management for the mailbox module.

As part of the system-wide power-management scheme, the mailbox module supports a communication protocol with the PRCM that allows the PRCM to request the mailbox to enter a low-power state. When the mailbox module acknowledges a low-power-mode request from the PRCM, the clock to the module is gated off at the PRCM clock generator. Because the clock is disabled at the source, the low-power mode offers lower power consumption than the internal clock-gating method in the local power management.

The PRCM.CM\_ICLKEN1\_CORE[7] EN\_MAILBOXES bit in the PRCM module controls the mailbox clock. When this bit is 1, the clock to the mailbox module is enabled; otherwise, the clock is disabled (see [Chapter 3, Power, Reset, and Clock Management](#), for more information).

The mailbox module can be configured using the MAILBOX.[MAILBOX\\_SYSConfig\[4:3\]](#) SIDLEMODE field to one of the following acknowledgment modes:

- No-idle mode: The mailbox module never enters the idle state.
- Force-idle mode: The mailbox module immediately enters the idle state on receiving a low-power-mode request from the PRCM module. In this mode, the software must ensure that there are no asserted output interrupts before requesting this mode to go into the idle state.
- Smart-idle mode: After receiving a low-power-mode request from the PRCM module, the mailbox module enters the idle state only after all asserted output interrupts are acknowledged.

[Table 14-1](#) describes the mailbox power-management modes.

**Table 14-1. Mailbox Power Management Modes**

| Power-Management Mode Requested by the PRCM | MAILBOX. <a href="#">MAILBOX_SYSConfig[4:3]</a> SIDLEMODE Bit Field (Offset: 0x010) |
|---------------------------------------------|-------------------------------------------------------------------------------------|
| Force-idle                                  | 00                                                                                  |
| No-idle                                     | 01                                                                                  |
| Smart-idle                                  | 10                                                                                  |
| Reserved (not used)                         | 11                                                                                  |

---

**NOTE:** The mailbox idle status can be read from the PRCM.CM\_IDLEST1\_CORE[7] ST\_MAILBOXES bit. When this bit is 0, the mailbox module cannot be accessed; otherwise, the mailbox module can be accessed (see [Chapter 3, Power, Reset, and Clock Management](#), for more information).

---

### 14.2.1.4.2 Module Power Management

This section describes local power management for the mailbox module.

To conserve power, the mailbox module supports an automatic idle mode whenever no activity is detected on the mailbox L4-Core interconnect interface. The automatic idle mode is enabled or disabled through the MAILBOX.[MAILBOX\\_SYSConfig\[0\]](#) AUTOIDLE bit.

When the MAILBOX.[MAILBOX\\_SYSConfig\[0\]](#) AUTOIDLE bit is asserted, the automatic idle mode is enabled in cases in which no activity is detected on the L4-Core interconnect interface, and the mailbox clock is disabled internally to the module, thus reducing power consumption.

When new activity is detected on the L4-Core interconnect interface, the clock is restarted with no latency penalty. After reset, the automatic idle mode is disabled; therefore, it is recommended that software enable the automatic idle mode for reduced power consumption.

---

**NOTE:** The PRCM.CM\_AUTOIDLE1\_CORE[7] AUTO\_MAILBOXES bit controls whether the mailbox interface clock is enabled or disabled in synchronization with the CORE power domain state transition (see [Chapter 3, Power, Reset, and Clock Management](#), for more information).

---

## 14.2.2 Hardware Requests

### 14.2.2.1 Interrupt Requests

The mailbox module can generate two interrupts:

- MAIL\_U0\_MPUIRQ, mapped on M\_IRQ\_26 of the MPU subsystem interrupt controller
- MAIL\_U1\_IVA2\_IRQ, mapped on IVA2\_IRQ[10] of the IVA2.2 subsystem interrupt controller

Each interrupt allows the user (MPU subsystem or IVA2.2 subsystem) of the mailbox to be notified when a message is received or when the message queue is not full. There is one interrupt per user.

### 14.2.2.2 Idle Handshake Protocol

The PRCM module handles an idle handshake protocol for the mailbox module. The PRCM requires the mailbox module to enter idle mode. The mailbox module acknowledges when it is ready.

## 14.3 IPC Mailbox Functional Description

**NOTE:** In the mailbox functional description,  $u$  is the user number from 0 to 1 and  $m$  is the mailbox number from 0 to 1.

The mailbox module provides a means of communication through message queues among the MPU and the IVA2.2. The two individual mailbox modules, or FIFOs, can associate with any of the processors using the MAILBOX.[MAILBOX\\_IRQENABLE\\_u](#) registers.

The mailbox module includes the following two user subsystems:

- User 0: MPU subsystem ( $u = 0$ )
- User 1: IVA2.2 subsystem ( $u = 1$ )

Each user has a dedicated interrupt signal from the mailbox module and a dedicated pair of interrupt enabling and status registers. Each MAILBOX.[MAILBOX\\_IRQSTATUS\\_u](#) interrupt status register corresponds to a particular user. A user can query its interrupt status register through the L4-Core interconnect.

### 14.3.1 Block Diagram

Figure 14-3 shows the mailbox block diagram.

**Figure 14-3. Mailbox Block Diagram**



ipc-003

## 14.3.2 Mailbox Assignment

### 14.3.2.1 Description

To assign a receiver to a mailbox, set the new message interrupt enable bit corresponding to the desired mailbox in the MAILBOX.[MAILBOX IRQENABLE\\_u](#) register. The receiver reads the MAILBOX.[MAILBOX MESSAGE\\_m](#) register to retrieve a message from the mailbox.

An alternate method for the receiver that does not use the interrupts is to poll the MAILBOX.[MAILBOX FIFOSTATUS\\_m](#) and/or MAILBOX.[MAILBOX MSGSTATUS\\_m](#) registers to know when to send or retrieve a message to or from the mailbox. This method does not require assigning a receiver to a mailbox. Because this method does not include the explicit assignment of the mailbox, the software must avoid having multiple receivers use the same mailbox, which can result in incoherency.

To assign a sender to a mailbox, set the queue-not-full interrupt enable bit of the desired mailbox in the MAILBOX.[MAILBOX IRQENABLE\\_u](#) register, where  $u$  is the number of the receiving user. However, direct allocation of a mailbox to a sender is not recommended because it can cause the sending processor to be constantly interrupted.

It is recommended that register polling be used to:

- Check the status of either the MAILBOX.[MAILBOX FIFOSTATUS\\_m](#) or MAILBOX.[MAILBOX MSGSTATUS\\_m](#) registers
- Write the message to the corresponding MAILBOX.[MAILBOX MESSAGE\\_m](#) register, if space is available.

The sender should use the queue-not-full interrupt when the initial mailbox status check indicates the mailbox is full. In this case, the sender can enable the queue-not-full interrupt for its mailbox in the appropriate MAILBOX.[MAILBOX IRQENABLE\\_u](#) register. This allows the sender to be notified by interrupt only when a FIFO queue has at least one available entry.

Reading the MAILBOX.[MAILBOX IRQSTATUS\\_u](#) register determines the status of the new message and the queue-not-full interrupts for a particular user. Writing 1 to the corresponding bit in the same register location acknowledges, and subsequently clears, an interrupt.

#### CAUTION

Assigning multiple senders or multiple receivers to the same mailbox is not recommended.

## 14.3.3 Sending and Receiving Messages

### 14.3.3.1 Description

When a 32-bit message is written to the MAILBOX.[MAILBOX MESSAGE\\_m](#) register, the message is appended into the FIFO queue. This queue holds four messages. If the queue is full, the message is discarded.

Queue overflow can be avoided by first reading the MAILBOX.[MAILBOX FIFOSTATUS\\_m](#) register to check that the mailbox message queue is not full before writing a new message to it.

Reading the MAILBOX.[MAILBOX MESSAGE\\_m](#) register returns the message at the beginning of the FIFO queue and removes it from the queue. If the FIFO queue is empty when the MAILBOX.[MAILBOX MESSAGE\\_m](#) register is read, the value 0 is returned.

The new message interrupt is asserted when at least one message is in the mailbox message FIFO queue. To determine the number of messages in the mailbox message FIFO queue, read the MAILBOX.[MAILBOX MSGSTATUS\\_m](#) register.

## 14.3.4 16-Bit Register Access

### 14.3.4.1 Description

So that 16-bit processors can access the mailbox module, the device allows 16-bit register read and write access, with restrictions for the MAILBOX.[MAILBOX\\_MESSAGE\\_m](#) registers. The 16-bit half-words are organized in little endian fashion; that is, the least-significant 16 bits are at the low address and the most-significant 16 bits are at the high address (low address + 0x02).

All mailbox module registers can be read or written to directly using individual 16-bit accesses with no restriction on interleaving, except the MAILBOX.[MAILBOX\\_MESSAGE\\_m](#) registers, which must always be accessed by either single 32-bit accesses or two consecutive 16-bit accesses.

#### CAUTION

When using 16-bit accesses, it is critical to ensure that the mailbox used has only one assigned receiver and only one assigned sender.

When using 16-bit accesses to the MAILBOX.[MAILBOX\\_MESSAGE\\_m](#) registers, the order of access must be the least-significant half-word first (low address) and the most-significant half-word last (high address). This requirement is due to the update operation by the message FIFO of the MAILBOX.[MAILBOX\\_MSGSTATUS\\_m](#) registers. The update of the FIFO queue contents and the associated status registers and possible interrupt generation occurs only when the most-significant 16 bits of a MAILBOX.[MAILBOX\\_MESSAGE\\_m](#) are accessed.

## 14.4 IPC Mailbox Basic Programming Model

### 14.4.1 Initialization Flow for the Mailbox Module

The initialization flow for the mailbox module consists of the following steps:

1. Perform a software reset of the mailbox module (see [Section 14.4.1.1, Software Reset](#)).
2. Set the idle mode and clock configuration of the mailbox module (see [Section 14.4.1.2, Idle Mode and Clock Configuration](#)).

#### 14.4.1.1 Software Reset

To perform a software reset, write 1 in the MAILBOX.[MAILBOX\\_SYSCONFIG\[1\]](#) SOFTRESET bit. The MAILBOX.[MAILBOX\\_SYSSTATUS\[0\]](#) RESETDONE bit indicates that the software reset is complete when its value is 1.

When the software reset completes, the MAILBOX.[MAILBOX\\_SYSCONFIG\[1\]](#) SOFTRESET bit is automatically reset. The software must ensure that the software reset completes before doing mailbox operations.

#### CAUTION

When performing a software reset by writing 1 in the MAILBOX.[MAILBOX\\_SYSCONFIG\[1\]](#) SOFTRESET bit, 0 must be written in the other bits of the MAILBOX.[MAILBOX\\_SYSCONFIG](#) register.

#### 14.4.1.2 Idle Mode and Clock Configuration

The idle mode and clock configuration is done by setting the MAILBOX.[MAILBOX\\_SYSCONFIG\[4:3\]](#) SIDLEMODE field and the MAILBOX.[MAILBOX\\_SYSCONFIG\[0\]](#) AUTOIDLE bit (see [Section 14.5, Mailbox Register Manual](#), for more information).

### 14.4.2 Mailbox Assignment

Before communicating, mailboxes can be explicitly assigned to a user using the appropriate MAILBOX.[MAILBOX\\_IRQENABLE\\_u](#) register. The software must ensure that only one sender and one receiver are assigned per mailbox.

For example, to assign mailbox 1 ( $m = 1$ ) to the MPU ( $u = 0$ , see [Section 14.3, Mailbox Functional Description](#), for the user number) as a receiver, set the MAILBOX.[MAILBOX\\_IRQENABLE\\_0\[2\]](#) NEWMSGENABLEUUMB1 bit to generate an interrupt to the MPU when a new message is received in mailbox 1.

To assign mailbox 0 ( $m = 0$ ) to the MPU ( $u = 0$ ) as a sender, set the MAILBOX.[MAILBOX\\_IRQENABLE\\_0\[1\]](#) NOTFULLENABLEUUMB0 bit to generate an interrupt to the MPU when the message queue of mailbox 0 is not full.

### 14.4.3 Mailbox Communication Preparation

Before communicating with another user, the sender must first use one of the following methods to determine that the mailbox message FIFO queue is not full:

- Poll the MAILBOX.[MAILBOX\\_FIFOSTATUS\\_m\[0\]](#) FIFOFULLMB bit or the MAILBOX.[MAILBOX\\_MSGSTATUS\\_m\[2:0\]](#) NBOFMSGMB field to determine if there is an open slot available to write a message.
- If the queue-not-full interrupt is enabled by setting the corresponding bit in the MAILBOX.[MAILBOX\\_IRQENABLE\\_u](#) register, an interrupt to the sender indicates that the mailbox has an available slot. To avoid continuous interrupt to the sender, it is recommended that the software waits until the message queue is full by reading the MAILBOX.[MAILBOX\\_MSGSTATUS\\_m\[2:0\]](#) NBOFMSGMB field before enabling the interrupt in the MAILBOX.[MAILBOX\\_IRQENABLE\\_u](#) register. When a queue-not-full interrupt is generated to the sender, the interrupt should be disabled until the

message queue is full for the same reason.

The receiver can also detect new messages from another user using two methods:

- Poll the MAILBOX.MAILBOX\_FIFOSTATUS\_m[0] FIFOFULLMB bit or the MAILBOX.MAILBOX\_MSGSTATUS\_m[2:0] NBOFMSGMB field.
- Use a new message ISR (interrupt service routine). In this case, the receiver must enable the appropriate interrupt in the MAILBOX.MAILBOX\_IRQENABLE\_u register.

---

**NOTE:** After an interrupt is generated, and before exiting the ISR, write 1 in each bit responsible for this generation in the MAILBOX.MAILBOX\_IRQSTATUS\_u register, thereby clearing these bits.

---

#### 14.4.4 Mailbox Communication Sequence

When a message slot is available in the mailbox, a message can be transmitted by a sender to a receiver using the following steps:

1. The sender writes a message in the MAILBOX.MAILBOX\_MESSAGE\_m register. This results in the following actions:
  - The message is stored at the tail of the FIFO queue of mailbox  $m$ , and the MAILBOX.MAILBOX\_FIFOSTATUS\_m and MAILBOX.MAILBOX\_MSGSTATUS\_m registers are updated.
  - If the FIFO queue was previously empty, a new message interrupt can be generated to the receiver to which the mailbox is allocated; otherwise, the interrupt is already asserted and remains so.
2. The receiver can either use an ISR or poll the MAILBOX.MAILBOX\_FIFOSTATUS\_m or MAILBOX.MAILBOX\_MSGSTATUS\_m registers to detect new messages and read them by accessing the MAILBOX.MAILBOX\_MESSAGE\_m register.
  - If using interrupts, the receiver enters the ISR when it detects the new message interrupt. The receiver checks both the MAILBOX.MAILBOX\_IRQSTATUS\_u register to determine the source of the interrupt and the MAILBOX.MAILBOX\_MSGSTATUS\_m register(s) to determine the number of messages in the FIFO queue.
  - The receiver can poll the appropriate MAILBOX.MAILBOX\_MSGSTATUS\_m register(s) to check the status and determine if there are any pending messages to read. The receiver can read the MAILBOX.MAILBOX\_MSGSTATUS\_m[2:0] NBOFMSGMB field to determine how many messages are available.
3. Using either ISR or polling method, when the receiver determines that it has a message pending in a mailbox, it repeatedly reads the MAILBOX.MAILBOX\_MESSAGE\_m register to remove all messages from the FIFO queue until a read in the MAILBOX.MAILBOX\_MSGSTATUS\_m register indicates no more messages are available (MAILBOX.MAILBOX\_MSGSTATUS\_m[2:0] NBOFMSGMB field = 0x00).
4. After reading all of the messages, the receiver can acknowledge the new message interrupt by writing 1 in the appropriate bit of the MAILBOX.MAILBOX\_IRQSTATUS\_u register to clear the interrupt flag before exiting the ISR.

#### 14.4.5 Example of Communication

This example shows how communication is established between the MPU and IVA2.2 subsystems in the device. The MPU subsystem sends messages to the IVA2.2 subsystem through mailbox 0, and the IVA2.2 subsystem sends messages to the MPU subsystem through mailbox 1.

To establish communication, the software follows these steps:

1. Turn on the automatic idle feature by writing 1 in the MAILBOX.MAILBOX\_SYSCONFIG[0] AUTOIDLE bit.

2. Configure the mailbox in smart-idle mode by setting the MAILBOX.[MAILBOX\\_SYSConfig\[4:3\]](#) SIDLEMODE field in smart-idle mode (smart-idle is the recommended mode; see [Section 14.5, Mailbox Register Manual](#), for more information). Smart-idle mode allows the PRCM low-power-mode requests to be acknowledged only after clearing any pending interrupts.
3. Write 1 in the MAILBOX.MAILBOX\_IRQENABLE\_1[0] NEWMSGENABLEUUMB0 bit to enable interrupts to the IVA2.2 subsystem when a new message is received in mailbox 0.
4. Write 1 in the MAILBOX.MAILBOX\_IRQENABLE\_0[2] NEWMSGENABLEUUMB1 bit to enable interrupts to the MPU subsystem when a new message is received in mailbox 1.
5. Enable interrupts in the corresponding subsystems.

#### **14.4.5.1 Sending a Message (Polling Method)**

To send a message using the polling method, the MPU or IVA2.2 subsystem follows these steps:

1. The MPU subsystem (or IVA2.2 subsystem) determines if the message queue of mailbox 0 (or mailbox 1 for the IVA2.2 subsystem) is full by reading the MAILBOX.MAILBOX\_FIFOSTATUS\_0[0] FIFOFULLMB bit (or the MAILBOX.MAILBOX\_FIFOSTATUS\_1[0] FIFOFULLMB bit for the IVA2.2 subsystem).
2. If the MAILBOX.MAILBOX\_FIFOSTATUS\_0[0] FIFOFULLMB bit (or the MAILBOX.MAILBOX\_FIFOSTATUS\_1[0] FIFOFULLMB bit for the IVA2.2 subsystem) is 0, mailbox 0 (or mailbox 1 for the IVA2.2 subsystem) has a message slot available to store a new message; go to step 4.
3. If the MAILBOX.MAILBOX\_FIFOSTATUS\_0[0] FIFOFULLMB bit (or the MAILBOX.MAILBOX\_FIFOSTATUS\_1[0] FIFOFULLMB bit for the IVA2.2 subsystem) is 1, mailbox 0 (or mailbox 1 for the IVA2.2 subsystem) is full; go back to step 1.
4. The MPU subsystem (or IVA2.2 subsystem) can send a message by writing it into the MAILBOX.MAILBOX\_MESSAGE\_0 register (or the MAILBOX.MAILBOX\_MESSAGE\_1 register for the IVA2.2 subsystem).

#### **14.4.5.2 Sending a Message (Interrupt Method)**

To send a message using the interrupt method, the MPU or IVA2.2 subsystem follows these steps:

1. To avoid continuous interruption, the MPU subsystem (or the IVA2.2 subsystem) must determine if mailbox 0 (or mailbox 1 for the IVA2.2 subsystem) is full by reading the MAILBOX.MAILBOX\_FIFOSTATUS\_0[0] FIFOFULLMB bit (or the MAILBOX.MAILBOX\_FIFOSTATUS\_1[0] FIFOFULLMB bit for the IVA2.2 subsystem).
2. If mailbox 0 (or mailbox 1 for the IVA2.2 subsystem) is full, the MPU subsystem (or the IVA2.2 subsystem) can enable the queue-not-full interrupt by setting the MAILBOX.MAILBOX\_IRQENABLE\_0[1] NOTFULLENABLEUUMB0 bit (or the MAILBOX.MAILBOX\_IRQENABLE\_1[3] NOTFULLENABLEUUMB1 bit for the IVA2.2 subsystem), and perform another task before an interrupt occurs; go to step 4).
3. If mailbox 0 (or mailbox 1 for the IVA2.2 subsystem) is not full, the MPU can go back to step 1 and wait for mailbox 0 (or mailbox 1 for the IVA2.2 subsystem) to fill, or the MPU can send a message, if necessary, by writing in the MAILBOX.MAILBOX\_MESSAGE\_0 register (or the MAILBOX.MAILBOX\_MESSAGE\_1 register for the IVA2.2 subsystem).
4. After receiving an interrupt, the MPU subsystem (or the IVA2.2 subsystem) enters the ISR and reads the MAILBOX.MAILBOX\_IRQSTATUS\_0[1] NOTFULLSTATUSUUMB0 bit (or the MAILBOX.MAILBOX\_IRQSTATUS\_1[3] NOTFULLSTATUSUUMB1 bit for the IVA2.2 subsystem) to determine if mailbox 0 (or mailbox 1 for the IVA2.2 subsystem) is not full and thus send its message. The MPU subsystem writes the message in the MAILBOX.MAILBOX\_MESSAGE\_0 register (or the MAILBOX.MAILBOX\_MESSAGE\_1 register for the IVA2.2 subsystem). The MPU subsystem (or the IVA2.2 subsystem) then acknowledges the interrupt by writing 1 in the MAILBOX.MAILBOX\_IRQSTATUS\_0[1] NOTFULLSTATUSUUMB0 bit (or the MAILBOX.MAILBOX\_IRQSTATUS\_1[3] NOTFULLSTATUSUUMB1 bit for the IVA2.2 subsystem).

---

**NOTE:** To send several messages, a subsystem or processor must determine if the message queue of mailbox m has enough available slots by checking the MAILBOX.MAILBOX\_MSGSTATUS\_m[2:0] NBOFMSGMB bit field before writing all of the messages in this mailbox (see [Section 14.5, Mailbox Register Manual](#), for more information).

---

#### 14.4.5.3 Receiving Messages (Interrupt Method)

After receiving an interrupt indicating that a new message is received, the MPU or IVA2.2 subsystem follows these steps:

1. The MPU subsystem (or the IVA2.2 subsystem) determines how many messages are stored in the message queue of mailbox 1 by reading the MAILBOX.MAILBOX\_MSGSTATUS\_1[2:0] NBOFMSGMB field (or the MAILBOX.MAILBOX\_MSGSTATUS\_0[2:0] NBOFMSGMB bit field for the IVA2.2 subsystem).
2. The MPU subsystem (or the IVA2.2 subsystem) reads the MAILBOX.MAILBOX\_MESSAGE\_1 register (or the MAILBOX.MAILBOX\_MESSAGE\_0 register for the IVA2.2 subsystem) as many times as there are messages in mailbox 1 (or mailbox 0 for the IVA2.2 subsystem).
3. Finally, the MPU subsystem (or the IVA2.2 subsystem) acknowledges the interrupt by writing 1 in the MAILBOX.MAILBOX\_IRQSTATUS\_0[2] NEWMSGSTATUSUUMB1 bit (or the MAILBOX.MAILBOX\_IRQSTATUS\_1[0] NEWMSGSTATUSUUMB0 bit for the IVA2.2 subsystem).

---

**NOTE:** After the interrupt is acknowledged, if the mailbox message queue is not empty, the interrupt is reasserted.

---

[Figure 14-4](#) shows an example of communication:

**Figure 14-4. Example of Communication**


ipc-004

## 14.5 IPC Mailbox Register Manual

Table 14-2 summarizes the mailbox instance.

**Table 14-2. Mailbox Instance Summary**

| Module Name | Base Address | Size     |
|-------------|--------------|----------|
| MLB         | 0x4809 4000  | 4K bytes |

### 14.5.1 Mailbox Register Mapping Summary

Table 14-3 summarizes the MLB registers.

**Table 14-3. MLB Register Summary**

| Register Name                       | Type | Register Width (Bits) | Address Offset     | Physical Address         |
|-------------------------------------|------|-----------------------|--------------------|--------------------------|
| MAILBOX_REVISION                    | R    | 32                    | 0x000              | 0x4809 4000              |
| MAILBOX_SYS CONFIG                  | RW   | 32                    | 0x010              | 0x4809 4010              |
| MAILBOX_SYS STATUS                  | R    | 32                    | 0x014              | 0x4809 4014              |
| MAILBOX_MESSAGE_m <sup>(1)</sup>    | RW   | 32                    | 0x040 + (0x04 * m) | 0x4809 4040 + (0x04 * m) |
| MAILBOX_FIFOSTATUS_m <sup>(1)</sup> | R    | 32                    | 0x080 + (0x04 * m) | 0x4809 4080 + (0x04 * m) |
| MAILBOX_MSGSTATUS_m <sup>(1)</sup>  | R    | 32                    | 0x0C0 + (0x04 * m) | 0x4809 40C0 + (0x04 * m) |
| MAILBOX_IRQSTATUS_u <sup>(2)</sup>  | RW   | 32                    | 0x100 + (0x08 * u) | 0x4809 4100 + (0x08 * u) |
| MAILBOX_IRQENABLE_u <sup>(2)</sup>  | RW   | 32                    | 0x104 + (0x08 * u) | 0x4809 4104 + (0x08 * u) |

<sup>(1)</sup> m = 0 to 1

<sup>(2)</sup> u = 0 to 1

**NOTE:** In MAILBOX\_MESSAGE\_0, MAILBOX\_MESSAGE\_1, MAILBOX\_FIFOSTATUS\_0, MAILBOX\_FIFOSTATUS\_1, MAILBOX\_MSGSTATUS\_0, and MAILBOX\_MSGSTATUS\_1 register names, 0 or 1 is the mailbox number.

In MAILBOX\_IRQSTATUS\_0, MAILBOX\_IRQSTATUS\_1, MAILBOX\_IRQENABLE\_0, and MAILBOX\_IRQENABLE\_1 register names, 0 or 1 is the user number:

- User 0: MPU subsystem
- User 1: IVA2.2 subsystem

### 14.5.2 Register Description

Table 14-4 through Table 14-18 describe the register bits.

**Table 14-4. MAILBOX\_REVISION**

|                  |                                             |          |     |
|------------------|---------------------------------------------|----------|-----|
| Address Offset   | 0x000                                       | Instance | MLB |
| Physical Address | 0x4809 4000                                 |          |     |
| Description      | This register contains the IP revision code |          |     |
| Type             | R                                           |          |     |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                         | Type | Reset              |
|------|------------|-----------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | Reserved   | Reads returns 0                                                                                     | R    | 0x000000           |
| 7:0  | REV        | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision<br>Examples: 0x10 for 1.0, 0x21 for 2.1 | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 14-5. Register Call Summary for Register MAILBOX\_REVISION**

- [Mailbox Register Mapping Summary: \[0\]](#)

**Table 14-6. MAILBOX\_SYSCONFIG**

|                         |                                |
|-------------------------|--------------------------------|
| <b>Address Offset</b>   | 0x010                          |
| <b>Physical Address</b> | 0x4809 4010                    |
| <b>Description</b>      | Instance                   MLB |
| <b>Type</b>             | RW                             |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Reserved

|               |          |           |          |           |          |
|---------------|----------|-----------|----------|-----------|----------|
| CLOCKACTIVITY | Reserved | SIDLEMODE | Reserved | SOFTRESET | AUTOIDLE |
|---------------|----------|-----------|----------|-----------|----------|

| Bits | Field Name    | Description                                                                                                                                                                                                                                                                                                     | Type | Reset    |
|------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | Reserved      | Write 0's for future compatibility<br>Read returns 0                                                                                                                                                                                                                                                            | RW   | 0x000000 |
| 8    | CLOCKACTIVITY | Clock activity during wake up mode period<br>Clock can always be switched off and read returns 0                                                                                                                                                                                                                | R    | 0        |
| 7:5  | Reserved      | Write 0's for future compatibility<br>Read returns 0                                                                                                                                                                                                                                                            | RW   | 0x0      |
| 4:3  | SIDLEMODE     | 0x0: Force-idle. An idle request is acknowledged unconditionally<br>0x1: No-idle. An idle request is never acknowledged<br>0x2: Smart-idle. Acknowledgement to an idle request is given based on the internal activity of the module based on the internal activity of the module<br>0x3: Reserved. Do not use. | RW   | 0x0      |
| 2    | Reserved      | Write 0's for future compatibility Read returns 0                                                                                                                                                                                                                                                               | RW   | 0        |
| 1    | SOFTRESET     | Software reset. This bit is automatically reset by the hardware. During reads, it always return 0<br><br>0x0: Normal mode<br>0x1: The module is reset                                                                                                                                                           | RW   | 0        |
| 0    | AUTOIDLE      | Internal interface clock gating strategy<br><br>0x0: Interface clock is free-running<br>0x1: Automatic interface clock gating strategy is applied, based on the L4-Core interface activity                                                                                                                      | RW   | 0        |

**Table 14-7. Register Call Summary for Register MAILBOX\_SYSCONFIG**

## IPC Integration

- Resets: [0]
- Power Management: [1] [2] [3] [4]

## IPC Mailbox Basic Programming Model

- Software Reset: [5] [6] [7] [8]
- Idle Mode and Clock Configuration: [9] [10]
- Example of Communication: [11] [12]

## IPC Mailbox Register Manual

- Mailbox Register Mapping Summary: [13]

**Table 14-8. MAILBOX\_SYSSTATUS**

|                         |                                                                                                        |          |     |
|-------------------------|--------------------------------------------------------------------------------------------------------|----------|-----|
| <b>Address Offset</b>   | 0x014                                                                                                  |          |     |
| <b>Physical Address</b> | 0x4809 4014                                                                                            | Instance | MLB |
| <b>Description</b>      | This register provides status information about the module, excluding the interrupt status information |          |     |
| <b>Type</b>             | R                                                                                                      |          |     |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |           |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----------|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RESETDONE |   |   |

| Bits | Field Name | Description                                 | Type | Reset    |
|------|------------|---------------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0                              | R    | 0x000000 |
| 7:1  | Reserved   | Read returns 0                              | R    | 0x00     |
| 0    | RESETDONE  | Internal reset monitoring                   | R    | 1        |
|      |            | Read 0x0: Internal module reset in on-going |      |          |
|      |            | Read 0x1: Reset completed                   |      |          |

**Table 14-9. Register Call Summary for Register MAILBOX\_SYSSTATUS**

## IPC Mailbox Basic Programming Model

- Software Reset: [0]

## IPC Mailbox Register Manual

- Mailbox Register Mapping Summary: [1]

**Table 14-10. MAILBOX\_MESSAGE\_m**

|                         |                                                                                                |          |     |
|-------------------------|------------------------------------------------------------------------------------------------|----------|-----|
| <b>Address Offset</b>   | 0x040 = MAILBOX_MESSAGE_0 for mailbox 0<br>0x044 = MAILBOX_MESSAGE_1 for mailbox 1             |          |     |
| <b>Physical Address</b> | 0x4809 4040 = MAILBOX_MESSAGE_0 for mailbox 0<br>0x4809 4044 = MAILBOX_MESSAGE_1 for mailbox 1 | Instance | MLB |
| <b>Description</b>      | The message register stores the next to be read message of the mailbox X                       |          |     |
| <b>Type</b>             | RW                                                                                             |          |     |

|                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| MESSAGEVALUEMB |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name     | Description        | Type | Reset      |
|------|----------------|--------------------|------|------------|
| 31:0 | MESSAGEVALUEMB | Message in Mailbox | RW   | 0x00000000 |

**Table 14-11. Register Call Summary for Register MAILBOX\_MESSAGE\_m**


---

 IPC Mailbox Functional Description

- [Description: \[0\] \[1\]](#)
  - [Description: \[2\] \[3\] \[4\]](#)
  - [Description: \[5\] \[6\] \[7\] \[8\]](#)
- 

IPC Mailbox Basic Programming Model

- [Mailbox Communication Sequence: \[9\] \[10\] \[11\]](#)
- 

IPC Mailbox Register Manual

- [Mailbox Register Mapping Summary: \[12\]](#)
- 

**Table 14-12. MAILBOX\_FIFOSTATUS\_m**

|                         |                                                                                                      |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |     |
|-------------------------|------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|-----|
| <b>Address Offset</b>   | 0x080 = MAILBOX_FIFOSTATUS_0 for mailbox 0<br>0x084 = MAILBOX_FIFOSTATUS_1 for mailbox 1             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | MLB |
| <b>Physical Address</b> | 0x4809 4080 = MAILBOX_FIFOSTATUS_0 for mailbox 0<br>0x4809 4084 = MAILBOX_FIFOSTATUS_1 for mailbox 1 |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |     |
| <b>Description</b>      | The FIFO status register has the status related to the mailbox internal FIFO                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |     |
| <b>Type</b>             | R                                                                                                    |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |     |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |  | FIFOFULLMB      |     |
| Reserved                |                                                                                                      |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |     |

| Bits | Field Name | Description           | Type | Reset      |
|------|------------|-----------------------|------|------------|
| 31:1 | Reserved   | Read returns 0        | R    | 0x00000000 |
| 0    | FIFOFULLMB | Full flag for Mailbox | R    | 0          |

**Table 14-13. Register Call Summary for Register MAILBOX\_FIFOSTATUS\_m**


---

 IPC Mailbox Functional Description

- [Description: \[0\] \[1\]](#)
  - [Description: \[2\]](#)
- 

IPC Mailbox Basic Programming Model

- [Mailbox Communication Preparation: \[3\] \[4\]](#)
  - [Mailbox Communication Sequence: \[5\] \[6\]](#)
- 

IPC Mailbox Register Manual

- [Mailbox Register Mapping Summary: \[7\]](#)
-

**Table 14-14. MAILBOX\_MSGSTATUS\_m**

|                         |                                                                                                    |                       |                 |
|-------------------------|----------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0C0 = MAILBOX_MSGSTATUS_0 for mailbox 0<br>0x0C4 = MAILBOX_MSGSTATUS_1 for mailbox 1             |                       |                 |
| <b>Physical Address</b> | 0x4809 40C0 = MAILBOX_MSGSTATUS_0 for mailbox 0<br>0x4809 40C4 = MAILBOX_MSGSTATUS_1 for mailbox 1 | <b>Instance</b>       | MLB             |
| <b>Description</b>      | The message status register has the status of the messages in the mailbox                          |                       |                 |
| <b>Type</b>             | R                                                                                                  |                       |                 |
| 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 |
| Reserved                |                                                                                                    |                       | NBOFMSGMB       |

| Bits | Field Name | Description                                                                  | Type | Reset     |
|------|------------|------------------------------------------------------------------------------|------|-----------|
| 31:3 | Reserved   | Read returns 0                                                               | R    | 0x0000000 |
| 2:0  | NBOFMSGMB  | Number of Messages in Mailbox<br>Note: Limited to four messages per mailbox. | R    | 0x00      |

**Table 14-15. Register Call Summary for Register MAILBOX\_MSGSTATUS\_m**

## IPC Mailbox Functional Description

- [Description: \[0\]](#) [\[1\]](#)
- [Description: \[2\]](#)
- [Description: \[3\]](#)

## IPC Mailbox Basic Programming Model

- [Mailbox Communication Preparation: \[4\]](#) [\[5\]](#) [\[6\]](#)
- [Mailbox Communication Sequence: \[7\]](#) [\[8\]](#) [\[9\]](#) [\[10\]](#) [\[11\]](#) [\[12\]](#) [\[13\]](#)
- [Sending a Message \(Interrupt Method\): \[14\]](#)

## IPC Mailbox Register Manual

- [Mailbox Register Mapping Summary: \[15\]](#)

**Table 14-16. MAILBOX\_IRQSTATUS\_u**

|                         |                                                                                                                                                                                           |                       |                                                                                |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x100 = MAILBOX_IRQSTATUS_0 for user 0<br>0x108 = MAILBOX_IRQSTATUS_1 for user 1                                                                                                          |                       |                                                                                |
| <b>Physical Address</b> | 0x4809 4100 = MAILBOX_IRQSTATUS_0 for user 0<br>0x4809 4108 = MAILBOX_IRQSTATUS_1 for user 1                                                                                              | <b>Instance</b>       | MLB                                                                            |
| <b>Description</b>      | The interrupt status register has the status for each event that may be responsible for the generation of an interrupt to the corresponding user - write 1 to a given bit resets this bit |                       |                                                                                |
| <b>Type</b>             | RW                                                                                                                                                                                        |                       |                                                                                |
| 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                                                                |
| Reserved                |                                                                                                                                                                                           |                       | NOTFULLSTATUSUMB1<br>NEWMSGSTATUSUMB1<br>NOTFULLSTATUSUMB0<br>NEWMSGSTATUSUMB0 |

| Bits | Field Name         | Description                                       | Type | Reset      |
|------|--------------------|---------------------------------------------------|------|------------|
| 31:4 | Reserved           | Write 0s for future compatibility. Read returns 0 | RW   | 0x00000000 |
| 3    | NOTFULLSTATUSUUMB1 | NotFull Status bit for User u, Mailbox 1          | RW   | 0          |
| 2    | NEWMMSGSTATUSUUMB1 | NewMessage Status bit for User u, Mailbox 1       | RW   | 0          |
| 1    | NOTFULLSTATUSUUMB0 | NotFull Status bit for User u, Mailbox 0          | RW   | 0          |
| 0    | NEWMMSGSTATUSUUMB0 | NewMessage Status bit for User u, Mailbox 0       | RW   | 0          |

**Table 14-17. Register Call Summary for Register MAILBOX\_IRQSTATUS\_u**

IPC Mailbox Functional Description

- [IPC Mailbox Functional Description: \[0\]](#)
- [Description: \[1\]](#)

IPC Mailbox Basic Programming Model

- [Mailbox Communication Preparation: \[2\]](#)
- [Mailbox Communication Sequence: \[3\] \[4\]](#)

IPC Mailbox Register Manual

- [Mailbox Register Mapping Summary: \[5\]](#)

**Table 14-18. MAILBOX\_IRQENABLE\_u**

|                         |                                                                                                                        |                 |     |
|-------------------------|------------------------------------------------------------------------------------------------------------------------|-----------------|-----|
| <b>Address Offset</b>   | 0x104 = MAILBOX_IRQENABLE_0 for user 0<br>0x10C = MAILBOX_IRQENABLE_1 for user 1                                       |                 |     |
| <b>Physical Address</b> | 0x4809 4104 = MAILBOX_IRQENABLE_0 for user 0<br>0x4809 410C = MAILBOX_IRQENABLE_1 for user 1                           | <b>Instance</b> | MLB |
| <b>Description</b>      | The interrupt enable register enables to mask/unmask the module internal source of interrupt to the corresponding user |                 |     |
| <b>Type</b>             | RW                                                                                                                     |                 |     |



| Bits | Field Name        | Description                                       | Type | Reset      |
|------|-------------------|---------------------------------------------------|------|------------|
| 31:4 | Reserved          | Write 0s for future compatibility. Read returns 0 | RW   | 0x00000000 |
| 3    | NOTFULENABLEUUMB1 | NotFull Enable bit for User u, Mailbox 1          | RW   | 0          |
| 2    | NEWMSGENABLEUUMB1 | NewMessage Enable bit for User u, Mailbox 1       | RW   | 0          |
| 1    | NOTFULENABLEUUMB0 | NotFull Enable bit for User u, Mailbox 0          | RW   | 0          |
| 0    | NEWMSGENABLEUUMB0 | NewMessage Enable bit for User u, Mailbox 0       | RW   | 0          |

**Table 14-19. Register Call Summary for Register MAILBOX\_IRQENABLE\_u**

IPC Mailbox Functional Description

- [IPC Mailbox Functional Description: \[0\]](#)
- [Description: \[1\] \[2\] \[3\]](#)

IPC Mailbox Basic Programming Model

- [Mailbox Assignment: \[4\]](#)
- [Mailbox Communication Preparation: \[5\] \[6\] \[7\]](#)

---

**Table 14-19. Register Call Summary for Register MAILBOX\_IRQENABLE\_u (continued)**

---

IPC Mailbox Register Manual

- [Mailbox Register Mapping Summary: \[8\]](#)
-

## **Memory Management Units**

This chapter describes the memory management units (MMUs).

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| <b>Topic</b>                                  | <b>Page</b> |
|-----------------------------------------------|-------------|
| <b>15.1 MMU Overview .....</b>                | <b>2680</b> |
| <b>15.2 MMU Integration .....</b>             | <b>2681</b> |
| <b>15.3 MMU Functional Description .....</b>  | <b>2684</b> |
| <b>15.4 MMU Basic Programming Model .....</b> | <b>2696</b> |
| <b>15.5 MMU Register Manual .....</b>         | <b>2703</b> |

## 15.1 MMU Overview

The device contains three memory management units (MMUs):

- Microprocessor unit (MPU) MMU
- Camera MMU
- Image Video and Audio accelerator (IVA2.2) MMU

The camera MMU and IVA2.2 MMU share the same architecture and are both described in this chapter. The MPU MMU, which implements a different architecture, is covered in [Chapter 4, MPU Subsystem](#).

---

**NOTE:** The MMUn prefix provides information about the register instantiation, where n = 1 for the camera MMU, and n = 2 for the IVA2.2 MMU.

---

The MMU instances include the following main features:

- N entries fully associative translation look-aside buffer (TLB) with N = 8 for the camera MMU and N = 32 for the IVA2.2 MMU
- 1 interrupt line out to the MPU subsystem
- 32-bit virtual addresses, 32-bit physical address
- Mapping size: 4KB and 64KB pages, 1MB section, and 16MB supersection
- Predefined (static) or table-driven (hardware table walker) software translation strategies

[Figure 15-1](#) shows the MMU instances in the device.

**Figure 15-1. Device MMU Instances**



## 15.2 MMU Integration

The MMU communicates accesses from the requestor (either the camera subsystem or the IVA2.2) to the L3 main interconnect, performing virtual to physical address translation. The camera MMU is programmed through the L4-core interconnect. The IVA2.2 MMU is programmed through the L3 interconnect. Both MMU error conditions are signaled as interrupts to the system master processor (that is, the MPU).

[Figure 15-2](#) and [Figure 15-3](#) show the system integration of the camera MMU instance and the IVA2.2 MMU instance.

**Figure 15-2. Camera MMU System Integration**



**Figure 15-3. IVA2.2 MMU System Integration**



### 15.2.1 Clock Domains

The camera MMU instance has two clock domains: the functional clock domain for the MMU, which is synchronous to the L3 interconnect clock, and the L4 interconnect clock, which is used to configure the MMU instance. Both camera MMU clocks are derived from a common reference clock generated by the power reset and clock management (PRCM) module.

The IVA2.2 MMU instance has only one clock domain: the functional clock domain for the MMU. The IVA MMU clock is generated by the DPLL2 embedded in IVA2.2, but controlled by PRCM registers.

### 15.2.2 Power Management

The device functional units are grouped into power domains. Each power domain is a section of the device with independent and dedicated power rails. Fifteen different power domains exist. For information about the device power management, see [Chapter 3, Power, Reset, and Clock Management](#).

The MMU instances belong to different power domains. [Table 15-1](#) shows the correspondence between the MMU instance and power domains.

**Table 15-1. Power Domains of the MMU Instances**

| MMU Instance      | Power Domain |
|-------------------|--------------|
| MMU1 (camera MMU) | CAM          |
| MMU2 (IVA2.2 MMU) | IVA2         |

#### 15.2.2.1 System Power Management

As part of the device system-wide power management scheme, each MMU instance supports a communication protocol with the PRCM module that allows the PRCM module to request an MMU instance to enter a low-power state. When the MMU instance acknowledges a low-power mode request from the PRCM module, the clock to the instance is gated off at the PRCM clock generator. Because the clock is disabled at the source, the low-power mode offers lower power consumption than the internal clock gating method in the local power management.

The MMU instance can be configured through the MMUn.[MMU\\_SYSCONFIG\[4:3\]](#) IDLEMODE field as one of the following acknowledgement modes:

- No-idle mode: The MMU instance never enters the idle state.
- Force-idle mode: The MMU instance immediately enters the idle state after receiving a low-power mode request from the PRCM module. In this mode, the software must ensure that there are no pending interrupts before requesting this mode to go into the idle state; otherwise, an error can occur.
- Smart-idle mode: After receiving a low-power mode request from the PRCM module, the MMU instance enters the idle state only after all interrupts are acknowledged.

[Table 15-2](#) describes the MMU power management modes. For details, see the [MMU\\_SYSCONFIG](#) register.

**Table 15-2. Power Domains of the MMU Instances**

| Power Management Mode Requested by the PRCM | MMUn. <a href="#">MMU_SYSCONFIG[4:3]</a> IDLEMODE field |
|---------------------------------------------|---------------------------------------------------------|
| Force-idle                                  | 00                                                      |
| No-idle                                     | 01                                                      |
| Smart-idle                                  | 10                                                      |
| Reserved                                    | 11                                                      |

#### 15.2.2.2 Module Power Saving

To conserve power, the MMU instance supports an automatic idle mode whenever activity is not detected on the configuration register port of the MMU instance. The automatic idle mode is enabled or disabled through the MMUn.[MMU\\_SYSCONFIG\[0\]](#) AUTOIDLE bit.

If the MMUn.[MMU\\_SYSCONFIG\[0\]](#) AUTOIDLE bit is asserted, the automatic idle mode is enabled when activity is not detected on the configuration register port, and the MMU instance clock is disabled internally to the module, thereby reducing power consumption.

When new activity is detected on the configuration register port, the clock is restarted with no latency penalty. After reset, the automatic idle mode is disabled; therefore, it is recommended to enable the automatic idle mode to reduce power consumption.

### 15.2.3 Reset

The MMU instances are reset together with their respective reset domains. [Table 15-3](#) shows the correspondence between the MMU instances and the reset domains.

**Table 15-3. Reset Domains of the MMU Instances**

| MMU Instance      | Reset Domain |
|-------------------|--------------|
| MMU1 (camera MMU) | CAM_RST      |
| MMU2 (IVA2.2 MMU) | IVA_RST2     |

Software reset is applied when the MMU<sub>n</sub>.[MMU\\_SYSConfig\[1\]](#) SOFTRESET is set to 1. The MMU<sub>n</sub>.[MMU\\_SYSSTATUS\[0\]](#) RESETDONE bit can be polled to know the reset status.

When an MMU instance is released from reset, its TLB is empty and the MMU is disabled.

---

**NOTE:** IVA2.2 MMU can be accessed from the L3 interconnect (configuration registers) even if the DSP is still under reset (IVA\_RST1 active).

---

### 15.2.4 Interrupts

Each MMU instance can generate an interrupt to the MPU on the occurrence of the following predefined set of events:

- Multi-hit fault  
There is more than one TLB entry for the given virtual address.
- Table walk fault  
A table walk data read generated an error.
- Emulation miss  
A TLB miss was caused by an emulation access.
- Translation fault  
No translation is found for the given virtual address. The hardware table walker is enabled but no valid page table entry exists for the requested address.
- TLB miss with table walk disabled  
No translation is found in the TLB for the given virtual address and the table walking logic is disabled.

Each of these events can be individually enabled and disabled using the MMU<sub>n</sub>.[MMU\\_IRQENABLE](#) register. If an event occurs and is enabled, an interrupt is generated to the MPU. The MPU can use the MMU<sub>n</sub>.[MMU\\_IRQSTATUS](#) register to find the precise cause of the interrupt.

The MMU<sub>n</sub>.[MMU\\_FAULT\\_AD](#) register holds the virtual address of the translation that causes the interrupt. The MMU<sub>n</sub>.[MMU\\_EMU\\_FAULT\\_AD](#) indicates the address of the last emulation event causing an MMU interrupt.

[Table 15-4](#) shows the generated interrupt versus the MMU instance.

**Table 15-4. Interrupts of the MMU Instances**

| MMU Instance      | MMU Interrupt Name | MMU Interrupt Mapping |
|-------------------|--------------------|-----------------------|
| MMU1 (camera MMU) | CAM IRQ0           | M_IRQ_24              |
| MMU2 (IVA2.2 MMU) | IVA2_MMU_IRQ       | M_IRQ_28              |

---

**NOTE:** The IVA2\_MMU\_IRQ (MMU2 instance) interrupt is a dedicated interrupt to the MPU subsystem.

[Chapter 6, Camera Subsystem](#), and [Chapter 5, IVA2.2 Subsystem](#), outline details about interrupt generation in the camera and IVA2.2 subsystems. For details about the MPU interrupt scheme, see [Chapter 12, Interrupt Controller](#).

## 15.3 MMU Functional Description

The MMUs handle the translation from virtual into physical addresses. The requestor (either the camera subsystem or the DSP mega cell or the EDMA module for IVA2.2) issues virtual addresses to the respective MMU (MMU1 for the camera subsystem and MMU2 for the IVA2.2). The MMU translates these virtual addresses into physical addresses to access the actual resource (memory) when the MMU instance is enable. That is when MMU<sub>n</sub>.MMU\_CNTL[1] MMUENABLE is set to 1.

Figure 15-4 shows the relationship between the physical address, the virtual address, and the MMU.

**Figure 15-4. MMU Address Translation**



### 15.3.1 MMU Benefits

The MMU offers two major benefits:

- Memory defragmentation: Fragmented physical memory can be translated into contiguous virtual memory without moving data.
- Memory protection: Illegal, that is, non-allowed accesses to memory locations can be detected and prevented.

Figure 15-5 shows two typical MMU use cases.

**Figure 15-5. MMU Usage Examples**

Figure 15-5 shows two benefits of using an MMU. Memory region 1 and memory region 2 are fragmented in physical memory. Using the MMU, they appear as one contiguous memory region in the virtual memory space.

On the other hand, task 1 and task 2 are located adjacent to each other in physical memory. In systems without an MMU, there is a danger that task 1 can accidentally write into the memory area allocated to task 2 and vice versa. Allocating task 1 and task 2 into two separate virtual memory regions prevents this problem, because a region of unmapped memory separates the two tasks. Any erroneous access to this region results in an error that can be detected easily.

### 15.3.2 MMU Architecture

The MMU translation process is based on translation entries stored in translation tables. One first-level translation table can exist with several optional second-level translation tables.

Each table entry describes the translation of one contiguous memory region. For a description of the structure of these tables, see [Section 15.3.3, Translation Tables](#).

Two major functional units exist in the MMU to provide address translation automatically based on the table entries:

- The table walker automatically retrieves the correct translation table entry for a requested translation. If two-level translation is used (for the translation of small memory pages), the table walker also automatically reads the required second-level translation table entry. The two-level translation is described later in the chapter.
- The TLB stores recently used translation entries, acting like a cache of the translation table.

This basic architecture is outlined in [Figure 15-6](#).

**Figure 15-6. MMU Architecture**



#### 15.3.2.1 MMU Address Translation Process

Whenever an address translation is requested (that is, for every access with the MMU enabled), the MMU first checks whether the translation is already contained in the TLB, which acts like a cache storing recent translations. The TLB can also be programmed manually to ensure that time-critical data can be translated without delay.

If the requested translation is not in the TLB, the table-walking logic retrieves this translation from the translation table(s), and then updates the TLB. The address translation is then performed. [Figure 15-7](#) summarizes the process.

**Figure 15-7. Translation Process**


MMU-007

### 15.3.3 Translation Tables

The translation of virtual to physical addresses is based on entries in translation tables that define the following properties:

- Address translation, that is, the correspondence between virtual and physical addresses
- Size of the memory region the entry translates
- Endianness, data access size, and the mixed property of this memory region

The virtual addresses index the translation tables. Each virtual address corresponds to exactly one entry in the translation table.

#### 15.3.3.1 Translation Table Hierarchy

When developing a table-based address translation scheme, one of the most important design parameters is the memory page size described by each translation table entry. MMU instances support 4KB and 64KB pages, a 1MB section, and a 16MB supersection. Using bigger page sizes means a smaller translation table.

Using a smaller page size greatly increases the efficiency of dynamic memory allocation and defragmentation. That is why many operating systems (OSs) can operate on memory blocks as small as 4KB; however, the smaller size implies a more complex table structure.

A quick calculation shows that using 4KB memory pages with one translation table would require one million entries to span the entire 4GB address range. The table itself would be 32MB, a size that is not feasible.

However, using bigger pages greatly reduces the functionality of the OS memory management. Implementing a two-level hierarchy reconciles these two requirements. Within this hierarchy, one first-level translation table describes the translation properties based on 1MB memory regions.

Each of the entries in this first-level translation table can specify the following:

- The translation properties for a big memory section. This memory section can be either 1MB (section) or 16MB (supersection). In this case, all translation parameters are specified in the first-level translation table entry.

- A pointer to a second-level translation table that specifies individual translation properties based on smaller pages within the 1MB page of memory. These pages can be either 64KB (large page) or 4KB (small page). In this case, the actual translation parameters are specified in the second-level translation table entry. The first-level translation table entry specifies only the base address of the second-level translation table.

This hierarchical approach means that additional translation information for smaller pages must be provided only when the pages are actually used. [Figure 15-8](#) shows this hierarchy.

**Figure 15-8. Translation Hierarchy**



The structure of the first and second-level translation tables and their entries are described in more detail in [Section 15.3.3.2, First-Level Translation Table](#), and [Section 15.3.3.3, Two-Level Translation](#).

### 15.3.3.2 First-Level Translation Table

The first-level translation table describes the translation properties for 1MB sections. To describe a 4GB address range requires 4096 32-bit entries (so-called first-level descriptors).

The first-level translation table start address must be aligned on a multiple of the table size with a 128-byte minimum. Consequently, an alignment of at least 16K bytes is required for a complete 4096-entry table; that is, at least the last fourteen address bits must be zero.

The start address of the first-level translation table is specified by the so-called translation table base. The table is indexed by the upper 12-bits of the virtual address. This mechanism is shown in [Figure 15-9](#).

**Figure 15-9. First-Level Descriptor Address Calculation**



To summarize, the translation table base and the translation table index together define the first-level descriptor address. [Figure 15-10](#) outlines the precise mechanism used to calculate this address.

**Figure 15-10. Detailed First-Level Descriptor Address Calculation**



MMU-01C

As an example of this mechanism, consider a translation table base address of 0x8000:0000 and a virtual address of 0x1234:5678. In this case, the first-level descriptor address is  $0x8000:0000 + (0x123 \ll 2) = 0x8000:048C$ .

#### **15.3.3.2.1 First-Level Descriptor Format**

Each first-level descriptor provides either the complete address translation for 1MB or 16MB sections or provides a pointer to a second-level translation table for 4KB or 64KB pages. The first-level descriptor format is shown in [Table 15-5](#).

**Table 15-5. First-Level Descriptor Format**

| First-Level Descriptor Format               |       |    |    |    |    |    |          |       |     |   |   |              |
|---------------------------------------------|-------|----|----|----|----|----|----------|-------|-----|---|---|--------------|
| 31:24                                       | 23:20 | 19 | 18 | 17 | 16 | 15 | 14:12    | 11:10 | 9:2 | 1 | 0 |              |
| X                                           |       |    |    |    |    |    |          |       |     | 0 | 0 | Fault        |
| Second-Level Translation Table Base Address |       |    |    |    |    |    |          |       |     | X | 0 | 1            |
| Section Base Address                        |       |    | X  | 0  | M  | X  | E<br>(1) | X     | ES  | X | 1 | 0            |
| Supersection Base Address                   |       | X  | 1  | M  | X  | E  | X        | ES    | X   | 1 | 0 | Supersection |
| X                                           |       |    |    |    |    |    |          |       |     | 1 | 1 | Fault        |

<sup>(1)</sup> See Table 15-34 for endianness limitations.

M = Mixed region; 0 = Page-based endianness, 1 = Access-based endianness

E = Endianness: 0 = Little endian, 1 = Big endian (endianness is locked on little endian)

ES = Element Size: 00 = 8-bit, 01 = 16-bit, 10 = 32-bit, 11 = No endianness conversion

X = Don't care

### **15.3.3.2.2 First-Level Page Descriptor Format**

If a translation granularity smaller than 1MB is required, a two-level translation process is used. In this case, the first-level block descriptor specifies only the start address of a second-level translation table. The second-level translation table entries specify the actual translation properties.

### 15.3.3.2.3 First-Level Section Descriptor Format

Each section descriptor in the first-level translation table specifies the complete translation properties for a 1MB section or a 16MB supersection.

**NOTE:** Supersection descriptors must be repeated 16 times, because each descriptor in the first-level translation table describes 1MB of memory. If an access points to a descriptor which is not initialized, MMU will behave in an unpredictable way.

In addition to the address translation itself, three parameters are specified in the section descriptors:

- Endianness

The *endianness* parameter specifies whether the memory section uses a big- or little-endian data format. This parameter is locked to little endian. See [Table 15-34](#) for more information.

- Element size

The *element size* parameter can optionally specify the data access size (8, 16, or 32 bits) for all data items in the defined section.

- Mixed region

The *mixed region* parameter specifies whether the information about the data access size is detected from the access itself (access-based detection) or if the specified element size parameter is used (page-based detection). For example, the specified element size parameter can be used when several smaller sized accesses are packed into a bigger sized access, such as two 16-bit accesses packed into one 32-bit access. In this case, with no specified data access size, 32 bits would be the access size detected, leading to an incorrect result. To avoid this problem, specify the data access size for the memory section.

### 15.3.3.2.4 Section Translation Summary

Sections and supersections can be translated based solely on the information in the first-level translation table. [Figure 15-11](#) summarizes the address translation process for a section.

**Figure 15-11. Section Translation Summary**



MMU-011

### 15.3.3.2.5 Supersection Translation Summary

The translation of a supersection is similar to the translation of a section. The difference is that for a supersection only bits 31 to 24 index into the first-level translation table. The last four bits of the table index are implicitly assumed to be zero as there are 16 identical consecutive entries for a supersection.

[Figure 15-12](#) shows the translation mechanism for a supersection.

**Figure 15-12. Supersection Translation Summary**


MMU-012

### 15.3.3.3 Two-Level Translation

Two-level translation is used when fine-grain granularity is required, that is when memory sections smaller than 1MB are needed. In this case, the first-level descriptor provides a pointer to the base address of a second-level translation table. This second-level table is indexed by bits 19 to 12 of the virtual address. [Figure 15-13](#) shows this indexing mechanism.

**Figure 15-13. Two-Level Translation**


MMU-013

Each second-level translation table describes the translation of 1MB of address space in pages of 64KB (large page) or 4KB (small page). It consists of 256 second-level descriptors describing 4KB each.

**NOTE:** In the case of a large page, the same descriptor must be repeated 16 times. If an access points to a descriptor which is not initialized, MMU will behave in an unpredictable way.

### 15.3.3.3.1 Second-Level Descriptor Format

Similar to first-level section descriptors, second-level descriptors provide all of the necessary information for the translation of a large or small page. [Table 15-6](#) shows the format of second-level descriptors. The translation parameters (endianness, element size, and mixed region) have the same meaning as those for sections.

**Table 15-6. Second-Level Descriptor Format**

| Second-Level Descriptor Format |       |    |    |                       |     |     |     |   |   |            |
|--------------------------------|-------|----|----|-----------------------|-----|-----|-----|---|---|------------|
| 31:16                          | 15:12 | 11 | 10 | 9                     | 8:6 | 5:4 | 3:2 | 1 | 0 |            |
| X                              |       |    |    |                       |     |     |     | 0 | 0 | Fault      |
| Large Page Base Address        | X     | M  | X  | E<br>( <sup>1</sup> ) | X   | ES  | X   | 0 | 1 | Large Page |
| Small Page Base Address        | M     | X  | E  | X                     | ES  | X   | 1   | X |   | Small Page |

<sup>(1)</sup> See [Table 15-34](#) for endianness limitations.

M = Mixed region: 0 = Page-based endianness, 1 = Access-based endianness

E = Endianness: 0 = Little-endian, 1 = Big-endian (endianness is locked on little endian)

ES = Element Size: 00 = 8-bit, 01= 16-bit, 10 = 32-bit, 11 = No endianness conversion

X = Don't care

### 15.3.3.3.2 Small Page Translation Summary

[Figure 15-14](#) summarizes the translation process for small pages.

**Figure 15-14. Small Page Translation Summary**



MMU-014

### 15.3.3.3.3 Large Page Translation Summary

The translation of a large page is similar to the translation of a small page. The difference is that, for a large page, only bits 19 to 16 index into the second-level translation table. The last four bits of the table index are implicitly assumed to be zero as there are 16 identical consecutive entries for a large page. This is shown in [Figure 15-15](#).

**Figure 15-15. Large Page Translation Summary**



MMU-015

### 15.3.4 Translation Lookaside Buffer

Translating virtual to physical addresses is required for each memory access in systems using an MMU. To accelerate this translation process, a cache, or TLB, holds the result of recent translations.

For every translation, the MMU internal logic first checks whether the requested translation is already cached in the TLB. If the translation is cached, this translation is used; otherwise the translation is retrieved from the translation tables and the TLB is updated. If the TLB is full, one of its entries must be replaced. This entry is selected on a random basis.

The first  $n$  TLB entries, where  $n < \text{Total Number } N \text{ of TLB Entries}$ , can be protected (locked) against being overwritten by setting the TLB base pointer to  $n$ . When this mechanism is used, only unprotected entries can be overwritten. The victim pointer indicates the next TLB entry to be written. [Figure 15-16](#) shows an example of TLB with  $N$  TLB entries (ranging from 0 to  $N-1$ ). The base pointer contains the value "3" protecting Entry 0, Entry 1, and Entry 2 and the victim pointer points to the next TLB entry to be updated.

---

**NOTE:** The last TLB entry (Entry  $N-1$ , where  $N = 8$  for the camera MMU and  $N = 32$  for the IVA2.2 MMU) always remains unprotected.

---

**Figure 15-16. TLB Entry Lock Mechanism**

The table walking logic automatically writes the TLB entries. The entries can also be manually written, which is done typically to ensure that the translation of time-critical data accesses is already present in the TLB so that they execute as fast as possible. The entries must be locked to prevent them from being overwritten.

#### 15.3.4.1 TLB Entry Format

TLB entries consist of two parts:

- The CAM part contains the virtual address tag used to determine if a virtual address translation is in the TLB. The TLB acts like a fully associative cache addressed by the virtual address tag. The CAM part also contains the section/page size, as well as the preserved and the valid parameters. See the [MMU\\_CAM](#) register table for more details.
- The RAM part contains the address translation that belongs to the virtual address tag as well as the endianness, element size, and mixed parameters described in [Section 15.3.3.2](#). See the [MMU\\_RAM](#) register table for more details.

The valid parameter specifies whether an entry is valid or not. The preserved parameter determines the behavior of an entry in the event of a TLB flush. If an entry is set as preserved, it is not deleted when a TLB is flushed, that is when [MMU\\_GFLUSH\[0\]](#) GLOBALFLUSH is set to 1. Preserved entries must be deleted manually. [Section 15.3.3.2](#) describes the procedure to delete TLB entries.

[Figure 15-17](#) shows the TLB entry structure.

**Figure 15-17. TLB Entry Structure**


MMU-017

### 15.3.5 MMU Error Handling

The following types of faults can occur:

- TLB miss with table walker disabled  
No translation is found for the virtual address required. If the hardware table walker is disabled, a fault is generated.
- Translation fault  
No translation is found for the virtual address required (TLB miss). The table walker is enabled but a page table entry does not exist for the given virtual address.
- Table walk fault  
A table walk results in a memory read error.
- Multi-hit fault  
More than one valid entry exists in the TLB for the given virtual address.

When a fault occurs and its corresponding interrupt is enabled, an interrupt is signaled to the MPU. The interrupt service routine (ISR) is then responsible for fault recovery. The requestor is stalled by the MMU while the fault is handled. For example, for a TLB miss, the ISR might load the missing entry into the TLB.

The ISR can determine the cause of the fault interrupt by reading the MMU<sub>n</sub>.[MMU\\_IRQSTATUS](#) register. The virtual address that caused the fault can be determined by reading the MMU<sub>n</sub>.[MMU\\_FAULT\\_AD](#) register.

In the case of a TLB miss, the MMU continues servicing the request as soon as a valid TLB entry is written. In the case of a translation fault, table walk fault, or multi-hit fault, the ISR first addresses the cause of the fault and then releases the MMU by writing to the interrupt status register. The MMU then continues servicing the request.

### 15.3.6 MMU Instance Design Parameters

The various MMU instances have different design parameters, most notably the size of the virtual address space and the number of TLB entries. [Table 15-7](#) shows the correspondence between the MMU instances and the design parameters.

**Table 15-7. Design Parameters of the MMU Instances**

| MMU Instance      | Virtual Address Space | TLB Entries |
|-------------------|-----------------------|-------------|
| MMU1 (camera MMU) | 4GB                   | 8 entries   |
| MMU2 (IVA2.2 MMU) | 4GB                   | 32 entries  |

## 15.4 MMU Basic Programming Model

MMU instances handle translation from virtual into physical addresses. Virtual addresses are issued by the Camera or the IVA2.2 subsystems to the MMU, which converts them into physical addresses. These physical addresses correspond to actual memory resource. Refer to [Chapter 2, Memory Mapping](#) for more information on the device memory mapping.

MMU instances can be used dynamically or statically, in other words, MMU can be managed by the MPU software or configured directly.

An MMU is configured dynamically when a software subroutine writes translation tables into the appropriate physical memory space. Translation tables are most likely stored in external SDRAM (see SMS, [Section 10.2.4.1, SDRAM Memory Scheduler](#), for more details). They are automatically written by the MPU OS (Symbian™, Linux®,...). Operating System may limit the memory section size to page or sections. A MPU memory management software treats all information concerning addressing. Sub-set tables can be copied into external SDRAM to automatically create a given MMU translation table. Features such as mixed region, endianness, element size are then overwritten in SDRAM to match one's need and customize Camera or IVA2.2 subsystems' need (8-bit exchange in little-endian format for example). Note that 16MB sections and 64KB page table entries must be duplicated 16 times with the same content in translation tables. This process avoids a second read operation when an access points to another element than first one in the table. If they are not copied the MMU will behave in an unpredictable way.

When an MMU is configured statically, translation tables are not used, and TLB entries are written directly by the programmer.

[Figure 15-18](#) shows the configuration strategies: static, dynamic and mixed use of MMU.

**Figure 15-18. MMU Configuration Strategies**


MMU-018

MMU components must be set up before the MMU can be used for address translation. The following steps are required:

- Initialize translation tables and the table walker logic if translation tables are used.
- Write TLB entries if required.
- Enable MMU.

Next paragraph explains how to configure the IVA2.2 MMU by directly writing the entries in the Translation Look-aside Buffer (TLB). The focus of this example is to explain the required configuration steps rather than to provide the most efficient implementation.

#### **15.4.1 Writing TLB Entries Statically**

This example deals with predefined translation strategy, that is, entries are “statically” written in the TLB.

This method avoids the need to write Translation tables in memory and is commonly used for relatively small address spaces. It ensures that the translation of time-critical data accesses execute as fast as possible with entries already present in the TLB. These entries must be locked to prevent them from being overwritten. To setup the MMU follow those steps:

1. Reset MMU: write **MMU\_SYSCONFIG[1]** SOFTRESET = 1 and wait for the system reset completion by polling **MMU\_SYSSTATUS[0]** RESETDONE until it is equal to 1.
2. Set **MMU\_SYSCONFIG[0]** AUTOIDLE bit to enable power saving via automatic interface clock gating.

After reset the Table walking logic remain disabled (**MMU\_CRTL[2]** TWLENABLE = 0), the TLB is empty and the victim pointer points to the first TLB entry, Entry 0 (**MMU\_LOCK[8:4]** CURRENTVICTIM at 0).

To initialize a TLB entry, follow those steps:

3. Load the Virtual Address (VATAG), the preserved (P=1) and valid (V=1) bits and the page size (small

- or large page, section, supersection) into **MMU\_CAM** register.
4. Load the Physical Address (PHYSICALADDRESS), the endianness (ENDIANNESS = 0), element size (ELEMENTSIZE) and mixed page attributes bits (MIXED) into **MMU\_RAM** register.
  5. Specify the TLB entry you want to write by setting the **MMU\_LOCK[8:4]** CURRENTVICTIM pointer. Start with TLB Entry 0 and increment this pointer for each subsequent entry you want to write.
  6. Load the specified entry in the TLB by setting **MMU\_LD\_TLB[0]** LDTLBITEM = 1.
  7. Repeat steps 3 to 6 for all entries you want to write.

Remember to increment the **MMU\_LOCK[8:4]** CURRENTVICTIM pointer with each entry you are writing. To prevent replacement of TLB entries see [Section 15.4.1.1, Protecting TLB Entries](#).

To enable error handling when more than one valid entry exists in the TLB for the given virtual address or when no translation is found for the virtual address required (with the Table walking logic disabled):

8. Enable Multi-hit fault and TLB miss with table walker disabled interrupts by writing 1 in **MMU\_IRQENABLE[4]** MULTIHITFAULT and **MMU\_IRQENABLE[0]** TLBMISS.
9. To determine the cause of the fault interrupt the interrupt service routine (ISR) can read corresponding **MMU\_IRQSTATUS** bits. The virtual address that caused the fault can be determined by reading **MMU\_FAULT\_AD**.

---

**NOTE:** MMU errors result in a memory stall; the MMU will not process any request until the cause of the error has been addressed.

---

To enable memory translations enable MMU (virtual addresses are treated as physical addresses when MMU is disabled):

10. Set **MMU\_CNTL[1]** MMUENABLE = 1 to enable memory translations enable the MMU (virtual addresses are treated as physical addresses when the MMU is disabled).

### 15.4.1.1 Protecting TLB Entries

The first  $n$  TLB entries (with  $n <$  total number of TLB entries) can be protected from being overwritten with new translations. This is useful to ensure that certain commonly used or time-critical translations are always in the TLB and do not require retrieval via the table walking process.

The entry protection mechanism is shown in [Figure 15-16](#). To protect the first  $n$  TLB entries, set the MMU1.**MMU\_LOCK[12:10]** BASEVALUE bit field for the camera MMU (MMU2.**MMU\_LOCK[14:10]** BASEVALUE field for the IVA2.2 MMU) to  $n$ .

### 15.4.1.2 Deleting TLB Entries

Two mechanisms exist to delete TLB entries. All unpreserved TLB entries, i.e., TLB entries that were written with the preserved bit set to zero, can be deleted by invoking a TLB flush. Such a TLB flush is invoked by setting the MMU.**GFLUSH[0]** GLOBALFLUSH bit.

Individual TLB entries can be flushed, regardless of the preserved bit setting, by specifying its virtual address in the MMU.**MMU\_CAM** register and setting the MMU.**MMU\_FLUSH\_ENTRY[0]** FLUSHENTRY bit.

The preserved bit should only be used on protected TLB entries, as it does not prevent replacement by the table walking logic.

### 15.4.1.3 Reading TLB Entries

TLB entries can be read by you to determine the TLB content at runtime. In doing so, the TLB entry number is specified by setting the MMU.**MMU\_LOCK[8:4]** CURRENTVICTIM pointer. CAM and RAM parts of the TLB entry can then be read in the MMU.**MMU\_READ\_CAM** and MMU.**MMU\_READ\_RAM** registers, respectively.

### 15.4.2 Programming the MMU Dynamically

When translation tables are used for MMU address translation they must be properly set up and the table walking logic must be enabled.

The following page sizes are supported:

- Supersection: 16M bytes
- Section: 1M byte
- Large page: 64K bytes
- Small page: 4K bytes

The memory location of these sections or pages (the Physical Address) is found by reading the Translation Table Hierarchy using a combination of the Virtual Address and the Translation Table Base address. [Figure 15-19](#) illustrates the MMUn translation table hierarchy, with first-level descriptors (L1D) and second-level descriptors (L2D).

**Figure 15-19. MMUn Translation Table Hierarchy**



MMU-019

The first step is to build translation tables (first- and second-level translation tables depending on translation strategy) and place them into memory.

The start address of translation tables must always be aligned according to their size. For example, a 4096-entry first-level translation table must be aligned on a 16KB boundary (4096 Entries \* 4 bytes = 16KB); that is, the lower 14 bits of the translation table start address (MMU\_TTB[13:0]) must be 0. For more details, see [Section 15.3.3.2](#).

After the translation tables have been written to memory the translation table base address (that is, the most significant bits of the first-level translation table start address) must be set. This is done using the MMU<sub>n</sub>.MMU\_TTB[31:7] TTBADDRESS bit field. See [Section 15.5](#) for a complete description of the MMU control registers.

Once the translation tables have been written to memory and the translation table base is set, the table walking logic can be enabled. This is done by setting the MMU<sub>n</sub>.MMU\_CNTL[2] TWLENABLE bit.

#### 15.4.2.1 Programming the MMU Using First- and Second-Level Translation Tables

Translation tables must be set up and written in memory. Each TLB entry contains a memory page size: 1MB section or 16MB supersection. When the page size is smaller, 4KB or 64KB, second-level translation tables are necessary. To set up the MMU, follow the same steps as in the previous example but write the first- and second-level descriptors in physical memory.

The first-level translation table describes the translation properties for 1MB sections. To describe a 4-GB address range with 1-MB sections, 4096 32-bit entries (so-called first-level descriptors) are required. The first-level translation table start address must be aligned on a multiple of the table size with a 128-byte minimum. Consequently, an alignment of at least 16K bytes is required for a complete 4096-entry table (that is, at least the last 14 address bits must be 0). The start address of the first-level translation table is specified by the so-called translation table base. The table is indexed by the upper 12-bits of the virtual address. [Figure 15-20](#) through [Figure 15-23](#) shows how the physical address is built from the virtual address as a function of the page sizes and hierarchy.

**Figure 15-20. Translation of a Supersection**



MMU-020

**Figure 15-21. Translation of a Section**

**Figure 15-22. Translation of a Large Page Included in a Page Table**


**Figure 15-23. Translation of an Extended Small Page Included in a Page Table**

MMU-023

## 15.5 MMU Register Manual

The MMU1 (camera ISP MMU) and MMU2 (IVA2.2 MMU) instances are programmed using two identical sets of configuration registers. [Table 15-8](#) lists the base address of each register set.

**Table 15-8. MMU Instance Summary**

| MMU Instance      | Base Address | Size      |
|-------------------|--------------|-----------|
| MMU1 (Camera MMU) | 0x480B D400  | 256 bytes |
| MMU2 (IVA2.2 MMU) | 0x5D00 0000  | 256 bytes |

**NOTE:** The MPU MMU is configured using register CP15. For more information, see the public ARM Cortex-A8 TRM.

### 15.5.1 Register Mapping Summary

Each MMU instance (except the MPU MMU) is programmed using a set of 18 configuration registers. [Table 15-9](#) lists these registers and their access type, access size, and offset against their respective base address.

**NOTE:** The registers and their bit fields in this set are identical for the two instances except the MMU<sub>n</sub>.[MMU\\_LOCK](#) register, which has bit fields for the MMU1 (camera ISP MMU) that are different from the MMU2 (IVA2.2 MMU).

**CAUTION**

MMU2 instance (IVA2.2 MMU) registers are limited to 32-bit data accesses. Data access of 16 bits and 8 bits are not allowed and can corrupt register content.

**Table 15-9. MMU Register Summary**

| Register Name   | Type | Register Width (Bits) | Address Offset | MMU1 (Camera MMU)<br>Physical Address | MMU2 (IVA2.2 MMU)<br>Physical Address |
|-----------------|------|-----------------------|----------------|---------------------------------------|---------------------------------------|
| MMU_REVISION    | R    | 32                    | 0x00           | 0x480B D400                           | 0x5D00 0000                           |
| MMU_SYSCONFIG   | RW   | 32                    | 0x10           | 0x480B D410                           | 0x5D00 0010                           |
| MMU_SYSSTATUS   | R    | 32                    | 0x14           | 0x480B D414                           | 0x5D00 0014                           |
| MMU_IRQSTATUS   | RW   | 32                    | 0x18           | 0x480B D418                           | 0x5D00 0018                           |
| MMU_IRQENABLE   | RW   | 32                    | 0x1C           | 0x480B D41C                           | 0x5D00 001C                           |
| MMU_WALKING_ST  | R    | 32                    | 0x40           | 0x480B D440                           | 0x5D00 0040                           |
| MMU_CNTL        | RW   | 32                    | 0x44           | 0x480B D444                           | 0x5D00 0044                           |
| MMU_FAULT_AD    | R    | 32                    | 0x48           | 0x480B D448                           | 0x5D00 0048                           |
| MMU_TTB         | RW   | 32                    | 0x4C           | 0x480B D44C                           | 0x5D00 004C                           |
| MMU_LOCK        | RW   | 32                    | 0x50           | 0x480B D450                           | 0x5D00 0050                           |
| MMU_LD_TLB      | RW   | 32                    | 0x54           | 0x480B D454                           | 0x5D00 0054                           |
| MMU_CAM         | RW   | 32                    | 0x58           | 0x480B D458                           | 0x5D00 0058                           |
| MMU_RAM         | RW   | 32                    | 0x5C           | 0x480B D45C                           | 0x5D00 005C                           |
| MMU_GFLUSH      | RW   | 32                    | 0x60           | 0x480B D460                           | 0x5D00 0060                           |
| MMU_FLUSH_ENTRY | RW   | 32                    | 0x64           | 0x480B D464                           | 0x5D00 0064                           |
| MMU_READ_CAM    | R    | 32                    | 0x68           | 0x480B D468                           | 0x5D00 0068                           |
| MMU_READ_RAM    | R    | 32                    | 0x6C           | 0x480B D46C                           | 0x5D00 006C                           |
| MMU_EMUFAULT_AD | R    | 32                    | 0x70           | 0x480B D470                           | 0x5D00 0070                           |

## 15.5.2 MMU Register Description

**Table 15-10. MMU\_REVISION**

|                         |                                              |                 |                                            |
|-------------------------|----------------------------------------------|-----------------|--------------------------------------------|
| <b>Address Offset</b>   | 0x000                                        |                 |                                            |
| <b>Physical address</b> | 0x480B D400<br>0x5D00 0000                   | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |
| <b>Description</b>      | This register contains the IP revision code. |                 |                                            |
| <b>Type</b>             | R                                            |                 |                                            |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REV |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                           | Type | Reset              |
|------|------------|-------------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | Reserved   | Reads return 0.                                                                                       | R    | 0x000000           |
| 7:0  | REV        | IP revision<br>[7:4]: Major revision<br>[3:0]: Minor revision<br>Examples: 0x10 for 1.0, 0x21 for 2.1 | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 15-11. Register Call Summary for Register MMU\_REVISION**

- MMU Register Manual
  - [Register Mapping Summary: \[0\]](#)

**Table 15-12. MMU\_SYSCONFIG**

|                         |                                                                              |                 |                                            |
|-------------------------|------------------------------------------------------------------------------|-----------------|--------------------------------------------|
| <b>Address Offset</b>   | 0x010                                                                        |                 |                                            |
| <b>Physical address</b> | 0x480B D410<br>0x5D00 0010                                                   | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |
| <b>Description</b>      | This register contains the various parameters of the interconnect interface. |                 |                                            |
| <b>Type</b>             | RW                                                                           |                 |                                            |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |               |          |          |          |           |          |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------------|----------|----------|----------|-----------|----------|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CLOCKACTIVITY | Reserved | IDLEMODE | Reserved | SOFTRESET | AUTOIDLE |   |

| Bits  | Field Name    | Description                                                                                                                                                                                                                                                                  | Type | Reset    |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:10 | Reserved      | Reads return 0. Write 0s for future compatibility.                                                                                                                                                                                                                           | R    | 0x000000 |
| 9:8   | CLOCKACTIVITY | Clock activity during wake-up mode<br>Read 0x0: Functional and interconnect clocks can be switched off.<br>Read 0x1, 0x2, 0x3: never happens.<br>Write 0s for future compatibility.                                                                                          | R    | 0x0      |
| 7:5   | Reserved      | Reads return 0. Write 0s for future compatibility.                                                                                                                                                                                                                           | R    | 0x0      |
| 4:3   | IDLEMODE      | Idle mode<br>0x0: Force idle. Idle request is acknowledged unconditionally.<br>0x1: No idle. Idle request is never acknowledged.<br>0x2: Smart idle. Acknowledgement to an idle request is given based on the internal activity of the module.<br>0x3: Reserved - Do not use | RW   | 0x0      |

| Bits | Field Name | Description                                                                                                                                                                                                                            | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 2    | Reserved   | Reads return 0. Write 0s for future compatibility.                                                                                                                                                                                     | R    | 0     |
| 1    | SOFTRESET  | Software reset. This bit is automatically reset by the hardware. During reads, it always returns 0.<br><br>Read 0x0: Always returns 0<br>Write 0x0: No functional effect<br>Read 0x1: Never happens<br>Write 0x1: The module is reset. | RW   | 0     |
| 0    | AUTOIDLE   | Internal interconnect clock gating strategy<br><br>0x0: Interconnect clock is free-running.<br>0x1: Automatic interconnect clock gating strategy is applied, based on the interconnect interface activity.                             | RW   | 0     |

**Table 15-13. Register Call Summary for Register MMU\_SYSCONFIG**
**MMU Integration**

- [System Power Management: \[0\]](#) [\[1\]](#) [\[2\]](#)
- [Module Power Saving: \[3\]](#) [\[4\]](#)
- [Reset: \[5\]](#)

**Basic Programming Model**

- [Writing TLB entries statically: \[6\]](#) [\[7\]](#)

**MMU Register Manual**

- [Register Mapping Summary: \[8\]](#)

**Table 15-14. MMU\_SYSSTATUS**

|                         |                                                                                                         |                       |                 |          |  |  |  |  |  |  |                                                               |          |  |  |  |           |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|---------------------------------------------------------------|----------|--|--|--|-----------|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x014                                                                                                   |                       |                 |          |  |  |  |  |  |  |                                                               |          |  |  |  |           |  |  |  |  |  |  |
| <b>Physical address</b> | 0x480B D414                                                                                             |                       |                 |          |  |  |  |  |  |  | <b>Instance</b><br>MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |          |  |  |  |           |  |  |  |  |  |  |
| <b>Description</b>      | This register provides status information about the module, excluding the interrupt status information. |                       |                 |          |  |  |  |  |  |  |                                                               |          |  |  |  |           |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                       |                       |                 |          |  |  |  |  |  |  |                                                               |          |  |  |  |           |  |  |  |  |  |  |
| 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 | Reserved |  |  |  |  |  |  |                                                               | Reserved |  |  |  | RESETDONE |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                     | Type | Reset    |
|------|------------|-------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved   | Reads return 0.                                                                                 | R    | 0x000000 |
| 7:1  | Reserved   | Reads return 0.<br>Reserved for interconnect-socket status information                          | R    | 0x00     |
| 0    | RESETDONE  | Internal reset monitoring<br><br>0x0: Internal module reset in ongoing.<br>0x1: Reset completed | R    | -        |

**Table 15-15. Register Call Summary for Register MMU\_SYSSTATUS**
**MMU Integration**

- [Reset: \[0\]](#)

**Basic Programming Model**

- [Writing TLB entries statically: \[1\]](#)

**MMU Register Manual**

- [Register Mapping Summary: \[2\]](#)

**Table 15-16. MMU\_IRQSTATUS**

|                         |                                                                                                                      |                         |                            |                 |                                                                           |
|-------------------------|----------------------------------------------------------------------------------------------------------------------|-------------------------|----------------------------|-----------------|---------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x018                                                                                                                | <b>Physical address</b> | 0x480B D418<br>0x5D00 0018 | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU)                                |
| <b>Description</b>      | This interrupt status register regroups all the status of the module internal events that can generate an interrupt. |                         |                            |                 |                                                                           |
| <b>Type</b>             | RW                                                                                                                   |                         |                            |                 |                                                                           |
| 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            |                 |                                                                           |
|                         |                                                                                                                      |                         |                            |                 |                                                                           |
| Reserved                |                                                                                                                      |                         |                            |                 | MULTIHITFAULT<br>TABLEWALKFAULT<br>EMUMISS<br>TRANSLATIONFAULT<br>TLBMISS |

| Bits | Field Name        | Description                                                                                                                                                                                                                                                 | Type | Reset     |
|------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | Reserved          | Reads return 0. Write Os for future compatibility.                                                                                                                                                                                                          | R    | 0x0000000 |
| 4    | MULTIHITFAULT     | Error due to multiple matches in the TLB<br><br>Read 0x0: MultiHitFault false<br>Write 0x0: MultiHitFault status bit unchanged<br>Read 0x1: MultiHitFault is true (pending)<br>Write 0x1: TableWalkFault status bit is reset                                | RW   | 0         |
| 3    | TABLEWALKFAULT    | Error response received during a table walk<br><br>Read 0x0: TableWalkFault false<br>Write 0x0: TableWalkFault status bit unchanged<br>Read 0x1: TableWalkFault is true (pending)<br>Write 0x1: TableWalkFault status bit is reset                          | RW   | 0         |
| 2    | EMUMISS           | Unrecoverable TLB miss during debug (hardware TWL disabled)<br><br>Read 0x0: EMUMiss false<br>Write 0x0: EMUMiss status bit unchanged<br>Read 0x1: EMUMiss is true (pending)<br>Write 0x1: EMUMiss status bit is reset                                      | RW   | 0         |
| 1    | TRANSLATION FAULT | Invalid descriptor in translation tables (translation fault)<br><br>Read 0x0: TranslationFault false<br>Write 0x0: TranslationFault status bit unchanged<br>Read 0x1: TranslationFault is true (pending)<br>Write 0x1: TranslationFault status bit is reset | RW   | 0         |
| 0    | TLBMISS           | Unrecoverable TLB miss (hardware TWL disabled)<br><br>Read 0x0: TLBMiss false<br>Write 0x0: TLBMiss status bit unchanged<br>Read 0x1: TLBMiss is true (pending)<br>Write 0x1: TLBMiss status bit is reset                                                   | RW   | 0         |

**Table 15-17. Register Call Summary for Register MMU\_IRQSTATUS**

## MMU Integration

- [Interrupts: \[0\]](#)

## MMU Functional Description

- [MMU Error Handling: \[1\]](#)

**Table 15-17. Register Call Summary for Register MMU\_IRQSTATUS (continued)**

Basic Programming Model

- [Writing TLB entries statically: \[2\]](#)

MMU Register Manual

- [Register Mapping Summary: \[3\]](#)

**Table 15-18. MMU\_IRQENABLE**

| <b>Address Offset</b> | 0x01C                                                                                                                                  | <b>Physical address</b> | 0x480B D41C<br>0x5D00 001C | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |               |                |         |                  |         |   |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------|-------------------------|----------------------------|-----------------|--------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---------------|----------------|---------|------------------|---------|---|
| <b>Description</b>    | The interrupt enable register allows the module's internal sources of interrupt to be masked and unmasked on an event-by-event basis.. |                         |                            |                 |                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |               |                |         |                  |         |   |
| <b>Type</b>           | RW                                                                                                                                     |                         |                            |                 |                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |               |                |         |                  |         |   |
| 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 |
| Reserved              |                                                                                                                                        |                         |                            |                 |                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | MULTIHITFAULT | TABLEWALKFAULT | EMUMISS | TRANSLATIONFAULT | TLBMISS |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                      | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:5        | Reserved          | Reads return 0. Write 0s for future compatibility.                                                                                                                      | R           | 0x00000000   |
| 4           | MULTIHITFAULT     | Error due to multiple matches in the TLB<br><br>0x0: MultiHitFault interrupt is masked<br>0x1: MultiHitFault event generates an interrupt if occurs                     | RW          | 0            |
| 3           | TABLEWALKFAULT    | Error response received during a table walk<br><br>0x0: TableWalkFault interrupt is masked<br>0x0: TableWalkFault event generates an interrupt if occurs                | RW          | 0            |
| 2           | EMUMISS           | Unrecoverable TLB miss during debug (hardware TWL disabled)<br><br>0x0: EMUMiss interrupt is masked<br>0x1: EMUMiss event generates an interrupt if occurs              | RW          | 0            |
| 1           | TRANSLATIONFAULT  | Invalid descriptor in translation tables (translation fault)<br><br>0x0: TranslationFault interrupt is masked<br>0x1: TranslationFault generates an interrupt if occurs | RW          | 0            |
| 0           | TLBMISS           | Unrecoverable TLB miss (hardware TWL disabled)<br><br>0x0: TLBMiss interrupt is masked<br>0x1: TLBMiss event generates an interrupt if occurs                           | RW          | 0            |

**Table 15-19. Register Call Summary for Register MMU\_IRQENABLE**

MMU Integration

- [Interrupts: \[0\]](#)

Basic Programming Model

- [Writing TLB entries statically: \[1\] \[2\]](#)

MMU Register Manual

- [Register Mapping Summary: \[3\]](#)

**Table 15-20. MMU\_WALKING\_ST**

|                         |                                                                          |                 |                                            |
|-------------------------|--------------------------------------------------------------------------|-----------------|--------------------------------------------|
| <b>Address Offset</b>   | 0x040                                                                    |                 |                                            |
| <b>Physical address</b> | 0x480B D440<br>0x5D00 0040                                               | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |
| <b>Description</b>      | This register provides status information about the table walking logic. |                 |                                            |
| <b>Type</b>             | R                                                                        |                 |                                            |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |            |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|------------|
| 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 |  |            |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  | TWLRUNNING |

| Bits | Field Name | Description                                                                   | Type | Reset      |
|------|------------|-------------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Reads return 0.                                                               | R    | 0x00000000 |
| 0    | TWLRUNNING | Table walking logic is running.<br><br>0x0: TWL completed<br>0x1: TWL running | R    | 0          |

**Table 15-21. Register Call Summary for Register MMU\_WALKING\_ST**

MMU Register Manual

- [Register Mapping Summary: \[0\]](#)

**Table 15-22. MMU\_CNTL**

|                         |                                          |                 |                                            |
|-------------------------|------------------------------------------|-----------------|--------------------------------------------|
| <b>Address Offset</b>   | 0x044                                    |                 |                                            |
| <b>Physical address</b> | 0x480B D444<br>0x5D00 0044               | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |
| <b>Description</b>      | This register programs the MMU features. |                 |                                            |
| <b>Type</b>             | RW                                       |                 |                                            |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |              |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--------------|
| 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 |              |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | EMUTLBUPDATE |

| Bits | Field Name   | Description                                                                                                           | Type | Reset      |
|------|--------------|-----------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:4 | Reserved     | Reads return 0. Write 0s for future compatibility.                                                                    | R    | 0x00000000 |
| 3    | EMUTLBUPDATE | Enable TLB update on emulator table walk<br><br>0x0: Emulator TLB update disabled<br>0x1: Emulator TLB update enabled | RW   | 0          |
| 2    | TWLENABLE    | Table walking logic enable<br><br>0x0: TWL disabled<br>0x1: TWL enabled                                               | RW   | 0          |
| 1    | MMUENABLE    | MMU enable<br><br>0x0: MMU disabled<br>0x1: MMU enabled                                                               | RW   | 0          |

| Bits | Field Name | Description                                        | Type | Reset |
|------|------------|----------------------------------------------------|------|-------|
| 0    | Reserved   | Reads return 0. Write 0s for future compatibility. | R    | 0     |

**Table 15-23. Register Call Summary for Register MMU\_CNTL**

MMU Functional Description

- [MMU Functional Description: \[0\]](#)

Basic Programming Model

- [Writing TLB entries statically: \[1\] \[2\]](#)
- [Programming the MMU dynamically: \[3\]](#)

MMU Register Manual

- [Register Mapping Summary: \[4\]](#)

**Table 15-24. MMU\_FAULT\_AD**

|                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                          |                 |                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|-----------------|--------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x048                                                                    |                 |                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical address</b>                                                                                                                                                                                                                                                                                                                                                                                                               | 0x480B D448<br>0x5D00 0048                                               | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                    | This register contains the virtual address that generated the interrupt. |                 |                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                           | R                                                                        |                 |                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> </table> |                                                                          |                 |                                            |    | 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 |
| 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 |   |   |   |   |   |
| FAULTADDRESS                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                          |                 |                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name   | Description                                          | Type | Reset      |
|------|--------------|------------------------------------------------------|------|------------|
| 31:0 | FAULTADDRESS | Virtual address of the access that generated a fault | R    | 0x00000000 |

**Table 15-25. Register Call Summary for Register MMU\_FAULT\_AD**

MMU Integration

- [Interrupts: \[0\]](#)

MMU Functional Description

- [MMU Error Handling: \[1\]](#)

Basic Programming Model

- [Writing TLB entries statically: \[2\]](#)

MMU Register Manual

- [Register Mapping Summary: \[3\]](#)

**Table 15-26. MMU\_TTB**

|                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                           |                 |                                            |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-----------------|--------------------------------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x04C                                                     |                 |                                            |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical address</b>                                                                                                                                                                                                                                                                                                                                                                                                               | 0x480B D44C<br>0x5D00 004C                                | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                    | This register contains the resolution table base address. |                 |                                            |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                           | RW                                                        |                 |                                            |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> </table> |                                                           |                 |                                            |          | 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 |
| 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 |   |   |   |   |   |
| TTBADRESS                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                           |                 |                                            | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                        | Type | Reset      |
|------|------------|----------------------------------------------------|------|------------|
| 31:7 | TTBADRESS  | Translation table base address                     | RW   | 0x00000000 |
| 6:0  | Reserved   | Reads return 0. Write 0s for future compatibility. | R    | 0x00       |

**Table 15-27. Register Call Summary for Register MMU\_TTB**

## Basic Programming Model

- [Programming the MMU dynamically: \[0\] \[1\]](#)

## MMU Register Manual

- [Register Mapping Summary: \[2\]](#)

**Table 15-28. MMU\_LOCK**

|                         |                                                                                    |                         |                            |                 |                                            |
|-------------------------|------------------------------------------------------------------------------------|-------------------------|----------------------------|-----------------|--------------------------------------------|
| <b>Address Offset</b>   | 0x050                                                                              | <b>Physical address</b> | 0x480B D450<br>0x5D00 0050 | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |
| <b>Description</b>      | This register locks some of the TLB entries or specifies the TLB entry to be read. |                         |                            |                 |                                            |
| <b>Type</b>             | RW                                                                                 |                         |                            |                 |                                            |
| 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            |                 |                                            |
| Reserved                |                                                                                    |                         |                            |                 | BASEVALUE                                  |
|                         |                                                                                    |                         |                            |                 | Reserved                                   |
|                         |                                                                                    |                         |                            |                 | CURRENTVICTIM                              |
|                         |                                                                                    |                         |                            |                 | Reserved                                   |

| Bits  | Field Name    | Description                                                                                                                                                                                                                                                                                                                         | Type | Reset   |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:15 | Reserved      | Reads return 0. Write 0s for future compatibility.                                                                                                                                                                                                                                                                                  | R    | 0x00000 |
| 14:10 | BASEVALUE     | Locked entries base value<br>Note: In the Camera MMU instance, BASEVALUE is a 3-bit field, ie. bits 13 and 14 are reserved.                                                                                                                                                                                                         | RW   | 0x00    |
| 9     | Reserved      | Reads return 0. Write 0s for future compatibility.                                                                                                                                                                                                                                                                                  | R    | 0       |
| 8:4   | CURRENTVICTIM | Current entry to be updated either by the TWL or by the software or TLB entry to be read<br>Note: In the Camera MMU instance, CURRENTVICTIM is a 3-bit field, ie. bits 7 and 8 are reserved.<br>Write value: TLB entry to be updated by software or TLB entry to be read<br>Read value: TLB entry to be updated by table walk logic | RW   | 0x00    |
| 3:0   | Reserved      | Reads return 0. Write 0s for future compatibility.                                                                                                                                                                                                                                                                                  | R    | 0x0     |

**Table 15-29. Register Call Summary for Register MMU\_LOCK**

## Basic Programming Model

- [Writing TLB entries statically: \[0\] \[1\] \[2\]](#)
- [Protecting TLB Entries: \[3\] \[4\]](#)
- [Reading TLB Entries: \[5\]](#)

## MMU Register Manual

- [Register Mapping Summary: \[6\] \[7\]](#)

**Table 15-30. MMU\_LD\_TLB**

|                       |                                            |                         |                            |                 |                                            |
|-----------------------|--------------------------------------------|-------------------------|----------------------------|-----------------|--------------------------------------------|
| <b>Address Offset</b> | 0x054                                      | <b>Physical address</b> | 0x480B D454<br>0x5D00 0054 | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |
| <b>Description</b>    | This register loads a TLB entry (CAM+RAM). |                         |                            |                 |                                            |
| <b>Type</b>           | RW                                         |                         |                            |                 |                                            |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |           |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----------|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | LDTLBITEM |   |   |

| Bits | Field Name | Description                                                                                                                                          | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Reads return 0. Write 0s for future compatibility                                                                                                    | R    | 0x00000000 |
| 0    | LDTLBITEM  | Write (load) data in the TLB<br>Read 0x0: Always returns 0<br>Write 0x0: No functional effect<br>Read 0x1: Never happens<br>Write 0x1: Load TLB data | RW   | 0          |

**Table 15-31. Register Call Summary for Register MMU\_LD\_TLB**

## Basic Programming Model

- Writing TLB entries statically: [0]

## MMU Register Manual

- Register Mapping Summary: [1]

**Table 15-32. MMU\_CAM**

|                       |                                  |                         |                            |                 |                                            |
|-----------------------|----------------------------------|-------------------------|----------------------------|-----------------|--------------------------------------------|
| <b>Address Offset</b> | 0x058                            | <b>Physical address</b> | 0x480B D458<br>0x5D00 0058 | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |
| <b>Description</b>    | This register holds a CAM entry. |                         |                            |                 |                                            |
| <b>Type</b>           | RW                               |                         |                            |                 |                                            |

|       |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |          |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|----------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| VATAG |    |    |    |    |    |    |    |    |    | Reserved |    |    |    |    | P  | V  | PAGESIZE |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                    | Type | Reset   |
|-------|------------|----------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | VATAG      | Virtual address tag                                                                                            | RW   | 0x00000 |
| 11:4  | Reserved   | Reads return 0. Write 0s for future compatibility.                                                             | R    | 0x00    |
| 3     | P          | Preserved bit<br>0x0: TLB entry can be flushed<br>0x1: TLB entry is protected against flush                    | RW   | 0       |
| 2     | V          | Valid bit<br>0x0: TLB entry is invalid<br>0x1: TLB entry is valid                                              | RW   | 0       |
| 1:0   | PAGESIZE   | Page size<br>0x0: Section (1MB)<br>0x1: Large page (64KB)<br>0x2: Small page (4KB)<br>0x3: Supersection (16MB) | RW   | 0x0     |

**Table 15-33. Register Call Summary for Register MMU\_CAM**

## MMU Functional Description

- [TLB Entry Format: \[0\]](#)

## Basic Programming Model

- [Writing TLB entries statically: \[1\]](#)
- [Deleting TLB Entries: \[2\]](#)

## MMU Register Manual

- [Register Mapping Summary: \[3\]](#)
- [MMU Register Description: \[4\]](#)

**Table 15-34. MMU\_RAM**

|                       |                                  |                         |                            |                 |                                            |
|-----------------------|----------------------------------|-------------------------|----------------------------|-----------------|--------------------------------------------|
| <b>Address Offset</b> | 0x05C                            | <b>Physical address</b> | 0x480B D45C<br>0x5D00 005C | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |
| <b>Description</b>    | This register holds a RAM entry. |                         |                            |                 |                                            |
| <b>Type</b>           | RW                               |                         |                            |                 |                                            |

  

|                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |            |             |       |          |   |   |   |   |   |   |   |   |   |   |
|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------------|-------------|-------|----------|---|---|---|---|---|---|---|---|---|---|
| 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 |
| PHYSICALADDRESS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Reserved | ENDIANNESS | ELEMENTSIZE | MIXED | Reserved |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name      | Description                                                                                                                                | Type | Reset   |
|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | PHYSICALADDRESS | Physical address of the page                                                                                                               | RW   | 0x00000 |
| 11:10 | Reserved        | Reads return 0. Write 0s for future compatibility.                                                                                         | R    | 0x0     |
| 9     | ENDIANNESS      | Endianness of the page<br><br>0x0: Little endian<br><br>0x1: Big endian - must not be used (locked on little endian)                       | RW   | 0       |
| 8:7   | ELEMENTSIZE     | Element size of the page (8, 16, 32, no translation)<br><br>0x0: 8 bits<br><br>0x1: 16 bits<br><br>0x2: 32 bits<br><br>0x3: No translation | RW   | 0x0     |
| 6     | MIXED           | Mixed page attribute (use CPU element size)<br><br>0x0: Use TLB element size<br><br>0x1: Use CPU element size                              | RW   | 0       |
| 5:0   | Reserved        | Reads return 0. Write 0s for future compatibility.                                                                                         | R    | 0x00    |

**Table 15-35. Register Call Summary for Register MMU\_RAM**

## MMU Functional Description

- [TLB Entry Format: \[0\]](#)

## Basic Programming Model

- [Writing TLB entries statically: \[1\]](#)

## MMU Register Manual

- [Register Mapping Summary: \[2\]](#)

**Table 15-36. MMU\_GFLUSH**

|                                                                                             |                                                          |
|---------------------------------------------------------------------------------------------|----------------------------------------------------------|
| <b>Address Offset</b>                                                                       | 0x060                                                    |
| <b>Physical address</b>                                                                     | 0x480B D460<br>0x5D00 0060                               |
| <b>Instance</b>                                                                             | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU)               |
| <b>Description</b>                                                                          | This register flushes all the non-protected TLB entries. |
| <b>Type</b>                                                                                 | RW                                                       |
| 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 |                                                          |
|                                                                                             | Reserved                                                 |
|                                                                                             | GLOBALFLUSH                                              |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------|-------------|--------------|
| 31:1        | Reserved          | Reads return 0. Write 0s for future compatibility. | RW          | 0x00000000   |
| 0           | GLOBALFLUSH       | Flush all the non-protected TLB entries when set   | RW          | 0            |
|             |                   | Read 0x0: Always returns 0                         |             |              |
|             |                   | Write 0x0: No functional effect                    |             |              |
|             |                   | Read 0x1: Never happens                            |             |              |
|             |                   | Write 0x1: Flush all the non-protected TLB entries |             |              |

**Table 15-37. Register Call Summary for Register MMU\_GFLUSH**

- ## MMU Functional Description

- ## Basic Programming Model

  - Deleting TLB Entries: [1]

- ## MMU Register Manual

  - [Register Mapping Summary: \[2\]](#)

**Table 15-38. MMU FLUSH ENTRY**

|                         |                                                                        |
|-------------------------|------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x064                                                                  |
| <b>Physical address</b> | 0x480B D464<br>0x5D00 0064                                             |
| <b>Instance</b>         | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU)                             |
| <b>Description</b>      | This register flushes the entry pointed to by the CAM virtual address. |
| <b>Type</b>             | RW                                                                     |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |            |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | FLUSHENTRY |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                  | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Reads return 0. Write 0s for future compatibility.                                                                                                                                                           | RW   | 0x00000000 |
| 0    | FLUSHENTRY | Flush the TLB entry pointed by the virtual address (VATag) in <a href="#">MMU_CAM</a> register, even if this entry is set protected<br><br>Read 0x0: Always returns 0<br><br>Write 0x0: No functional effect | RW   | 0          |

| Bits | Field Name | Description                                                        | Type | Reset |
|------|------------|--------------------------------------------------------------------|------|-------|
|      |            | Read 0x1: Never happens                                            |      |       |
|      |            | Write 0x1: Flush all the TLB entries specified by the CAM register |      |       |

**Table 15-39. Register Call Summary for Register MMU\_FLUSH\_ENTRY**

Basic Programming Model

- [Deleting TLB Entries: \[0\]](#)

MMU Register Manual

- [Register Mapping Summary: \[1\]](#)

**Table 15-40. MMU\_READ\_CAM**

|                       |                                                |                         |                            |                 |                                            |
|-----------------------|------------------------------------------------|-------------------------|----------------------------|-----------------|--------------------------------------------|
| <b>Address Offset</b> | 0x068                                          | <b>Physical address</b> | 0x480B D468<br>0x5D00 0068 | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |
| <b>Description</b>    | This register reads CAM data from a CAM entry. |                         |                            |                 |                                            |
| <b>Type</b>           | R                                              |                         |                            |                 |                                            |

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |          |   |   |   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|----------|---|---|---|
| 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 |
| VATAG |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Reserved |   | P | V | PAGESIZE |   |   |   |

| Bits  | Field Name | Description                                                                                                        | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | VATAG      | Virtual address tag                                                                                                | R    | 0x00000 |
| 11:4  | Reserved   | Reads return 0.                                                                                                    | R    | 0x00    |
| 3     | P          | Preserved bit<br><br>0x0: TLB entry can be flushed<br>0x1: TLB entry is protected against flush                    | R    | 0       |
| 2     | V          | Valid bit<br><br>0x0: TLB entry is invalid<br>0x1: TLB entry is valid                                              | R    | 0       |
| 1:0   | PAGESIZE   | Page size<br><br>0x0: Section (1MB)<br>0x1: Large page (64KB)<br>0x2: Small page (4KB)<br>0x3: Supersection (16MB) | R    | 0x0     |

**Table 15-41. Register Call Summary for Register MMU\_READ\_CAM**

Basic Programming Model

- [Reading TLB Entries: \[0\]](#)

MMU Register Manual

- [Register Mapping Summary: \[1\]](#)

**Table 15-42. MMU\_READ\_RAM**

|                       |                                                |                         |                            |                 |                                            |
|-----------------------|------------------------------------------------|-------------------------|----------------------------|-----------------|--------------------------------------------|
| <b>Address Offset</b> | 0x06C                                          | <b>Physical address</b> | 0x480B D46C<br>0x5D00 006C | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |
| <b>Description</b>    | This register reads RAM data from a RAM entry. |                         |                            |                 |                                            |
| <b>Type</b>           | R                                              |                         |                            |                 |                                            |



| Bits  | Field Name      | Description                                                                                                                       | Type | Reset   |
|-------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | PHYSICALADDRESS | Physical address of the page                                                                                                      | R    | 0x00000 |
| 11:10 | Reserved        | Reads return 0.                                                                                                                   | R    | 0x0     |
| 9     | ENDIANNES       | Endianness of the page<br>0x0: Little endian<br>0x1: Big endian - must not be used (locked on little endian)                      | R    | 0       |
| 8:7   | ELEMENTSIZE     | Element size of the page (8, 16, 32 bits or no translation)<br>0x0: 8 bits<br>0x1: 16 bits<br>0x2: 32 bits<br>0x3: No translation | R    | 0x0     |
| 6     | MIXED           | Mixed page attribute (use CPU element size)<br>0x0: Use TLB element size<br>0x1: Use CPU element size                             | R    | 0       |
| 5:0   | Reserved        | Reads return 0. Write 0s for future compatibility.                                                                                | R    | 0x00    |

**Table 15-43. Register Call Summary for Register MMU\_READ\_RAM**

- Basic Programming Model
- [Reading TLB Entries: \[0\]](#)
- MMU Register Manual
- [Register Mapping Summary: \[1\]](#)

**Table 15-44. MMU\_EMUFAULT\_AD**

|                       |                                                                                    |                         |                            |                 |                                            |
|-----------------------|------------------------------------------------------------------------------------|-------------------------|----------------------------|-----------------|--------------------------------------------|
| <b>Address Offset</b> | 0x070                                                                              | <b>Physical address</b> | 0x480B D470<br>0x5D00 0070 | <b>Instance</b> | MMU1 (Camera ISP MMU)<br>MMU2 (IVA2.2 MMU) |
| <b>Description</b>    | This register contains the last virtual address of a fault caused by the debugger. |                         |                            |                 |                                            |
| <b>Type</b>           | R                                                                                  |                         |                            |                 |                                            |



| Bits | Field Name      | Description                                                        | Type | Reset      |
|------|-----------------|--------------------------------------------------------------------|------|------------|
| 31:0 | EMUFAULTADDRESS | Virtual address of the last emulator access that generated a fault | R    | 0x00000000 |

---

**Table 15-45. Register Call Summary for Register MMU\_EMUFAULT\_AD**

---

MMU Integration

- [Interrupts: \[0\]](#)
- 

MMU Register Manual

- [Register Mapping Summary: \[1\]](#)
-

This chapter describes the timer modules for the device.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                                    | Page        |
|----------------------------------------------------------|-------------|
| <b>16.1 Timers Overview .....</b>                        | <b>2718</b> |
| <b>16.2 General-Purpose Timers .....</b>                 | <b>2719</b> |
| <b>16.3 General-Purpose Timers Register Manual .....</b> | <b>2740</b> |
| <b>16.4 Watchdog Timers .....</b>                        | <b>2766</b> |
| <b>16.5 Watchdog Timer Register Manual .....</b>         | <b>2775</b> |
| <b>16.6 32-kHz Synchronized Timer .....</b>              | <b>2783</b> |
| <b>16.7 32-kHz Sync Timer Register Manual .....</b>      | <b>2785</b> |

## 16.1 Timers Overview

The device includes several types of timers used by the system software, including 11 general-purpose timers (GP timers), two watchdog timers (WDTs), and a 32-kHz synchronized timer. [Figure 16-1](#) shows the counters in the device in a high-level block diagram.

**Figure 16-1. Timers**



timers-027

The 2 WDTs are clocked with 32-kHz clocks. The 32-kHz synchronized timer, which is reset only at power up, provides the operating system with a stable timing source that stores the relative time since the last power cycle of the product. Finally, 11 GP timers, which are useful simply as basic timers, are included to generate time-stamp-based interrupts to the system software or to use as a source of pulse-width modulation (PWM) signals.

## 16.2 General-Purpose Timers

### 16.2.1 GP Timers Overview

The device has 11 GP timers: GPTIMER1 through GPTIMER11.

Each timer can be clocked from either the system clock (12, 13, 16.8, 19.2, 26, or 38.4 MHz) or the 32-kHz clock. The selection of the clock source is made at the power, reset, clock management (PRCM) module level. For more information, see [Section 16.2.3.1, Clocking, Reset, and Power-Management Scheme](#).

GPTIMER1 has its GPT1\_EVENT\_CAPTURE pin tied to the 32-kHz clock and can be used to gauge the system clock input; it detects its frequency among 12, 13, 16.8, 19.2, 26, or 38.4 MHz.

Each timer can provide an interrupt to the microprocessor unit (MPU) subsystem. In addition, GPTIMER5 through GPTIMER8 also have interrupts connected to the IVA2.2 subsystem.

GPTIMER1, GPTIMER2, and GPTIMER10 include specific functions to generate accurate tick interrupts to the operating system. GPTIMER8 through GPTIMER11 are connected to external pins by their PWM output or their event capture input pin (for external timer triggering). [Figure 16-2](#) shows an overview of the GP timers.

**Figure 16-2. GP Timers Overview**



### 16.2.1.1 GP Timers Features

The following are the main features of the GP timers controllers:

- L4 slave interface support:
  - 32-bit data bus width
  - 32-/16-bit access supported
  - 8-bit access not supported
  - 10-bit address bus width
  - Burst mode not supported
  - Software-selectable nonposted or posted write/read internal resynchronization modes
- Interrupts generated on overflow, compare, and capture
- Free-running 32-bit upward counter
- Compare and capture modes
- Autoreload mode
- Start/stop mode
- Programmable divider clock source ( $2^n$  with  $n = [0:8]$ )
- Dedicated input trigger for capture mode and dedicated output trigger/PWM signal
- Dedicated output signal for general-purpose using GPTi\_GPOCFG signal
- On-the-fly read/write register (while counting)
- 1-ms tick with 32,768 Hz functional clock generated (only GPTIMER1, GPTIMER2, and GPTIMER10)

### 16.2.2 GP Timers Environment

#### 16.2.2.1 GP Timers External System Interface

Four of the 11 GP timers can send or receive stimulus to/from the external (off-chip) system. In the device, however, only GPTIMER8 through GPTIMER11 are configured to output a PWM pulse or receive an external event signal used as a trigger to capture the current timer count. GPTIMER1 is also configured to receive an event trigger input (GPT1\_EVENT\_CAPTURE) tied to the internal 32-kHz clock. This event signal gauges the system clock input; it detects its frequency among 12, 13, 16.8, 19.2, 26, or 38.4 MHz.

[Figure 16-3](#) shows the external system interface for the GP timers, and [Table 16-1](#) describes the GP timer inputs and outputs.

---

**NOTE:** Software must ensure that mux mode is configured to select the gpt\_x\_pwm\_evt (where  $x = 8$  to 11) signal on only one pad. Other pads on which the same signal is multiplexed must be configured in safe mode or non-gptimer mode to avoid two different pads driving the same signal.

For more information about the gpt\_8\_pwm\_evt through gpt11\_pwm\_evt I/O pad configuration, see [Chapter 13, System Control Module](#).

---

Figure 16-3. GP Timers External System Interface



timers-003

Table 16-1. Input/Output Description

| Pin Name      | Type <sup>(1)</sup> | Reset Value | Signal Name                          | Description                            |
|---------------|---------------------|-------------|--------------------------------------|----------------------------------------|
| gpt8_pwm_evt  | I/O                 | 0           | GPT8_EVENT_CAPTURE<br>GPT8_PWM_OUT   | GPTIMER8 trigger input/<br>PWM output  |
| gpt9_pwm_evt  | I/O                 | 0           | GPT9_EVENT_CAPTURE<br>GPT9_PWM_OUT   | GPTIMER9 trigger input/<br>PWM output  |
| gpt10_pwm_evt | I/O                 | 0           | GPT10_EVENT_CAPTURE<br>GPT10_PWM_OUT | GPTIMER10 trigger input/<br>PWM output |
| gpt11_pwm_evt | I/O                 | 0           | GPT11_EVENT_CAPTURE<br>GPT11_PWM_OUT | GPTIMER11 trigger input/<br>PWM output |

<sup>(1)</sup> When configured for that function; I = input, O = output

**NOTE:** The event trigger input (GPTi\_EVENT\_CAPTURE) for GPTIMER2 through GPTIMER7 is internally tied low, and the PWM output (GPTi\_PWM\_OUT) is not connected.

### 16.2.3 GP Timers Integration

Figure 16-4 shows the GP timer integration in the device.

**Figure 16-4. GP Timer Integration**



#### 16.2.3.1 Clocking, Reset, and Power-Management Scheme

##### 16.2.3.1.1 Clock Management

There are two clock domains in the GP timers:

- Functional clock domain: GPTi\_FCLK is the GP timer functional clock. It is used to clock the GP timer internal logic.
- Interface clock domain: GPTi\_ICLK is the GP timer interface clock. It is used to synchronize the GP timer L4 port to the L4 interconnect. All accesses from the interconnect are synchronous to GPTi\_ICLK.

Table 16-2 lists the source clocks for each GP timer in the device. For more information on clock control and domains, see [Chapter 3, Power, Reset, and Clock Management](#).

**Table 16-2. Clock, Power, and Reset Domains for GP Timers**

| Timer                     | Interface Clock | Functional Clock                  | Power Domain |
|---------------------------|-----------------|-----------------------------------|--------------|
| GPTIMER1                  | WKUP_L4_ICLK    | GPT1_FCLK                         | WKUP         |
| GPTIMER2 through GPTIMER9 | PER_L4_ICLK     | GPTx_ALWON_FCLK (x = 2 through 9) | PER          |
| GPTIMER10 and 11          | CORE_L4_ICLK    | GPTx_FCLK (x = 10 or 11)          | CORE         |

GP timers can be selected as the source of GPT<sub>i</sub>\_FCLK (32-kHz clock or 12, 13, 16.8, 19.2, 26, or 38.4 MHz) at the PRCM level in the corresponding registers. For more information, see [Chapter 3, Power, Reset, and Clock Management](#). **Table 16-3** lists the GP timer PRCM clock selection bits.

**Table 16-3. GP Timer PRCM Clock Selection Bits**

| Name          | Associated PRCM Clock Output | Selection Bit                               |
|---------------|------------------------------|---------------------------------------------|
| GPT1_FCLK     | GPT1_FCLK                    | PRCM.CM_CLKSEL_WKUP[0]<br>CLKSEL_GPT1       |
| GPT[2:9]_FCLK | GPT[2:9]_ALWON_FCLK          | PRCM.CM_CLKSEL_PER [0:7]<br>CLKSEL_GPT[2:9] |
| GPT10_FCLK    | GPT10_FCLK                   | PRCM.CM_CLKSEL_CORE [6]<br>CLKSEL_GPT10     |
| GPT11_FCLK    | GPT11_FCLK                   | PRCM.CM_CLKSEL_CORE [7]<br>CLKSEL_GPT11     |

From a global system power-management perspective, when one or both of the GP timer clocks is no longer required, the GP timers can be deactivated at the PRCM level in the corresponding registers. **Table 16-4** lists the GP timer PRCM clock control bits.

**Table 16-4. GP Timer PRCM Clock Control Bits**

| Name          | Associated PRCM Clock Output | Enable Bit                                   | Autoidle Bit                                    |
|---------------|------------------------------|----------------------------------------------|-------------------------------------------------|
| GPT1_FCLK     | GPT1_FCLK                    | PRCM.CM_FCLKEN_WKUP[0]<br>EN_GPT1 bit        | N/A                                             |
| GPT[2:9]_FCLK | GPT[2:9]_ALWON_FCLK          | PRCM.CM_FCLKEN_PER [3:10]<br>EN_GPT[2:9] bit | N/A                                             |
| GPT10_FCLK    | GPT10_FCLK                   | PRCM.CM_FCLKEN1_CORE [11]<br>EN_GPT10 bit    | N/A                                             |
| GPT11_FCLK    | GPT11_FCLK                   | PRCM.CM_FCLKEN1_CORE [12]<br>EN_GPT11 bit    | N/A                                             |
| GPT1_ICLK     | WKUP_L4_ICLK                 | PRCM.CM_ICLKEN_WKUP[0]<br>EN_GPT1 bit        | PRCM.CM_AUTOIDLE_WKUP[0]<br>AUTO_GPT1 bit       |
| GPT[2:9]_ICLK | PER_L4_ICLK                  | PRCM.CM_ICLKEN_PER[3:10]<br>EN_GPT[2:9] bit  | PRCM.CM_AUTOIDLE_PER[3:10]<br>AUTO_GPT[2:9] bit |
| GPT10_ICLK    | CORE_L4_ICLK                 | PRCM.CM_ICLKEN1_CORE[11]<br>EN_GPT10 bit     | PRCM.CM_AUTOIDLE1_CORE[11]<br>AUTO_GPT10 bit    |
| GPT11_ICLK    |                              | PRCM.CM_ICLKEN1_CORE[12]<br>EN_GPT11 bit     | PRCM.CM_AUTOIDLE1_CORE[12]<br>AUTO_GPT11 bit    |

**NOTE:**

- The PRCM function clock outputs are gated at the PRCM level, assuming all the modules that share it are disabled in the corresponding register. Disabling GP timers is a necessary but not sufficient action. The clock is effectively out when all PRCM conditions are fulfilled. For the other actions to be taken, see [Chapter 3, Power, Reset, and Clock Management](#).
- The PRCM interface clock outputs are gated at the PRCM level, assuming all the modules that share it are disabled in the corresponding register. Disabling GP timers is a necessary but not sufficient action. The clock is effectively out when all PRCM conditions are fulfilled. For the other actions to be taken, see [Chapter 3, Power, Reset, and Clock Management](#).
- The PRCM AUTOIDLE bits are used to link/unlink the GP timers from the clock domain transitions related to the GPTi\_ICLK clocks.
- For further details about source clock gating and domain transitions, see [Chapter 3, Power, Reset, and Clock Management](#).

GP timer modules also have an internal bit, GPTi.[TIOCP\\_CFG\[0\]](#) AUTOIDLE. The GP timer AUTOIDLE bit is used to apply an internal interface clock gating strategy.

At the PRCM level, when all conditions to shut off the PRCM functional or interface output clocks are met (see [Chapter 3, Power, Reset, and Clock Management](#), for details), the PRCM automatically launches a hardware handshake protocol to ensure the GP timer is ready to have its clocks switched off. Namely, the PRCM asserts an IDLE request to the GP timer.

Although this handshake is a hardware function and is out of software control, the way the GP timer acknowledges the PRCM IDLE request is configurable through the GPTi.[TIOCP\\_CFG\[4:3\]](#) IDLEMODE bit. [Table 16-5](#) lists the IDLEMODE settings and the related acknowledgment modes.

**Table 16-5. IDLEMODE Settings**

| IDLEMODE Value | Selected Mode | Description                                                                                                                                                                                                                                                                                                                                                     |
|----------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00             | Force-idle    | The GP timer acknowledges unconditionally the IDLE request from the PRCM module, regardless of its internal operations. This mode must be used carefully, because it does not prevent the loss of data when the clock is switched off.                                                                                                                          |
| 01             | No-idle       | The GP timer never acknowledges an IDLE request from the PRCM module. This mode is safe from a module point of view, because it ensures that the clocks remain active. It is not efficient from a power-saving perspective, however, because it does not allow the PRCM output clock to be shut off and thus the power domain to be set to a lower power state. |
| 10             | Smart-idle    | The GP timer acknowledges the IDLE request, basing its decision on its internal activity. The acknowledge signal is asserted only when all pending transactions and IRQ requests are treated. This is the best approach for efficient system power management.                                                                                                  |
| 11             | Reserved      |                                                                                                                                                                                                                                                                                                                                                                 |

When configured in smart-idle mode, the GP timer also offers an additional granularity on GPTi\_FCLK and GPTi\_ICLK gating. The GPTi.[TIOCP\\_CFG\[9:8\]](#) CLOCKACTIVITY bit field is used to determine which clock will be shut down (GPTi\_FCLK, GPTi\_ICLK, neither of them, or both of them).

The CLOCKACTIVITY setting is used internally to the GP timer to determine the part of the module on which the conditions to acknowledge the PRCM IDLE request will be tested. For example, if GPTi\_FCLK is not to be shut down on a PRCM IDLE request, the GP timer considers only GPTi\_ICLK and the associated pending activities before acknowledging the request.

Some GP timer features are associated with GPTi\_ICLK and others are associated with GPTi\_FCLK. Using the CLOCKACTIVITY setting along with the smart-idle mode ensures that the features associated with the clock that will remain active are always enabled, even if the GP timer acknowledges an IDLE request.

Table 16-6 lists the CLOCKACTIVITY settings and the associated features.

**Table 16-6. CLOCKACTIVITY Settings**

| CLOCKACTIVITY Value | GPTi_ICLK Effects | GPTi_FCLK Effects | Description                                                                                                                                                                       | Associated Features                                                                                                                                                                                                                                                                                                                                       |
|---------------------|-------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00                  | OFF               | OFF               | Both GPTi_ICLK and GPTi_FCLK are considered for generating the acknowledge. This setting also means both GPTi_FCLK and GPTi_ICLK are likely to be shut down on PRCM IDLE request. | The idle acknowledge signal is asserted when there are no pending activities on the functional clock domain (improved latency in assertion of idle acknowledge). The wake-up capability of the GP timer is disabled.                                                                                                                                      |
| 01                  | ON                | OFF               | GPTi_ICLK is not shut down on PRCM IDLE request; only GPTi_FCLK is affected.                                                                                                      |                                                                                                                                                                                                                                                                                                                                                           |
| 10                  | OFF               | ON                | GPTi_FCLK is not shut down on PRCM IDLE request; only GPTi_ICLK is affected.                                                                                                      |                                                                                                                                                                                                                                                                                                                                                           |
| 11                  | ON                | ON                | None of the clocks are shut down. Therefore, the GP timer can potentially acknowledge the IDLE request without checking the internal functionalities linked to its clocks.        | The idle acknowledge signal is asserted when there are no pending activities on the interface clock domain, without evaluating the pending activities on the functional clock domain (the GP timer enters into sleep mode, and if a pending interrupt event is finished during idle mode, the wake-up signal is asserted). The wake-up signal is enabled. |

### CAUTION

The PRCM module does *not* have any hardware means to read the CLOCKACTIVITY settings. The software must ensure consistent programming between the GP timer CLOCKACTIVITY and the PRCM functional clock and interface clock control bits. If the GP timer is disabled in both CM\_FCLKEN and CM\_ICLKEN PRCM registers while CLOCKACTIVITY is set to 11, nothing prevents the PRCM module from asserting its IDLE request, which is acknowledged regardless of the features associated with the GP timer clocks. This can lead to unpredictable behavior.

#### 16.2.3.1.2 Wake-Up Capability

If the GPTi.TIOCP\_CFG[4:3] IDLEMODE field sets the smart-idle mode, the timer module evaluates its internal capability to have the interface clock switched off. When there is no more internal activity (no pending interrupt sources: match, overflow, or timer capture events), the idle acknowledge signal is asserted and the timer enters into sleep mode, ready to issue a wake-up request. This wake-up request is sent only if the GPTi.TIOCP\_CFG[2] ENAWAKEUP bit enables the timer wake-up capability.

Figure 16-5 shows the wake-up request generation. For more information on the GP timer clock control, see Section 16.2.3.1.1, *Clock Management*.

**Figure 16-5. Wake-Up Request Generation**

timers-005

The timer wake-up enable register (GPTi.TWER) allows masking the expected source of the wake-up event that generates a wake-up request. The GPTi.TWER register is programmed synchronously with the interface clock before the PRCM module sends an idle mode request. The expected source of the wake-up event is an overflow (GPTi.TCRR), a timer match (the compare result of GPTi.TCRR and GPTi.TMAR matches the counter value), and a timer capture (an external pulse transition of the correct polarity is detected on the GPTi.EVENT\_CAPTURE).

When the wake-up event is issued, the associated interrupt status bit is set in the timer status register (GPTi.TISR). The pending wake-up event is reset when the set status bit is overwritten by 1.

---

**NOTE:** The status bit must be reset to re-enter idle mode.

---

#### 16.2.3.1.3 Reset and Power Management

GPTIMER1 belongs to the WKUP power domain. As part of that domain, this GP timer is sensitive to a WKUP\_RST signal issued by the PRCM module. For further details about the WKUP power domain implementation and the WKUP\_RST signal, see [Chapter 3, Power, Reset, and Clock Management](#).

GPTIMER2 through GPTIMER9 belong to the PER power domain. As part of that domain, these GP timers are sensitive to a PER\_RST signal issued by the PRCM module. For further details about the PER power domain implementation and the PER\_RST signal, see [Chapter 3, Power, Reset, and Clock Management](#).

GPTIMER10 and GPTIMER11 belong to the CORE power domain. As part of that domain, these GP timers are sensitive to a CORE\_RST signal issued by the PRCM module. For further details about the CORE power domain implementation and the CORE\_RST signal, see [Chapter 3, Power, Reset, and Clock Management](#).

#### 16.2.3.2 Software Reset

Two bit fields (GPTi.TIOCP\_CFG[1] SOFTRESET and GPTi.TSICR[1] SFT) can generate a software reset of the GP timer. For both of these bits, all read accesses return 0.

The GPTi.TIOCP\_CFG[1] SOFTRESET bit allows resetting the functional and interface domains. The GPTi.TSICR[1] SFT bit allows resetting the functional part of the GP timer.

Before accessing or using the GP timer, the local host must ensure that both internal resets are released by reading the GPTi.TISTAT[0] RESETDONE bit. This bit field monitors the internal reset status.

### 16.2.3.3 GP Timer Interrupts

Table 16-7 lists the interrupt mapping from the 12 GP timers to the three internal processors.

**Table 16-7. Timer Interrupt Names and Processor IRQ Mapping**

| Timer     | Interrupt Name | Mapping     | Comments                                    |
|-----------|----------------|-------------|---------------------------------------------|
| GPTIMER 1 | GPT1_IRQ       | M_IRQ_37    | GPTIMER1 interrupt to MPU                   |
| GPTIMER2  | GPT2_IRQ       | M_IRQ_38    | GPTIMER2 interrupt to MPU                   |
| GPTIMER3  | GPT3_IRQ       | M_IRQ_39    | GPTIMER3 interrupt to MPU                   |
| GPTIMER4  | GPT4_IRQ       | M_IRQ_40    | GPTIMER4 interrupt to MPU                   |
| GPTIMER5  | GPT5_IRQ       | M_IRQ_41    | GPTIMER5 interrupt to MPU                   |
|           |                | IVA2_IRQ[6] | GPTIMER5 interrupt to IVA2.2                |
| GPTIMER6  | GPT6_IRQ       | M_IRQ_42    | GPTIMER6 interrupt to MPU                   |
|           |                | IVA2_IRQ[7] | GPTIMER6 interrupt to IVA2.2                |
|           |                | MD_IRQ_6    | GPTIMER6 interrupt to modem subsystem (D2D) |
| GPTIMER7  | GPT7_IRQ       | M_IRQ_43    | GPTIMER7 interrupt to MPU                   |
|           |                | IVA2_IRQ[8] | GPTIMER7 interrupt to IVA2.2                |
|           |                | MD_IRQ_7    | GPTIMER7 interrupt to modem subsystem (D2D) |
| GPTIMER8  | GPT8_IRQ       | M_IRQ_44    | GPTIMER8 interrupt to MPU                   |
|           |                | IVA2_IRQ[9] | GPTIMER8 interrupt to IVA2.2                |
|           |                | MD_IRQ_8    | GPTIMER8 interrupt to modem subsystem (D2D) |
| GPTIMER9  | GPT9_IRQ       | M_IRQ_45    | GPTIMER9 interrupt to MPU                   |
|           |                | MD_IRQ_9    | GPTIMER9 interrupt to modem subsystem (D2D) |
| GPTIMER10 | GPT10_IRQ      | M_IRQ_46    | GPTIMER10 interrupt to MPU                  |
| GPTIMER11 | GPT11_IRQ      | M_IRQ_47    | GPTIMER11 interrupt to MPU                  |

The timer can issue an overflow interrupt, a timer match interrupt, and a timer capture interrupt. Each internal interrupt source can be independently enabled/disabled in the interrupt enable register (GPTi.TIER). When the interrupt event is issued, the associated interrupt status bit is set in the timer status register (GPTi.TISR). The pending interrupt event is reset when the set status bit is overwritten by a1.

### 16.2.4 GP Timers Functional Description

Each GP timer contains a free-running upward counter with autoreload capability on overflow. The timer counter can be read and written on-the-fly (while counting). Each GP timer includes compare logic to allow an interrupt event on a programmable counter matching value. A dedicated output signal can be pulsed or toggled on either an overflow or a match event. This offers time-stamp trigger signaling or PWM signal sources. A dedicated input signal can be used to trigger an automatic timer counter capture or an interrupt event on a programmable input signal transition type. A programmable clock divider (prescaler) allows reduction of the timer input clock frequency. All internal timer interrupt sources are merged into one module interrupt line and one wake-up line. Each internal interrupt source can be independently enabled/disabled with a dedicated bit of the GPTi.[TIER](#) register for the interrupt features and a dedicated bit of the GPTi.[TWER](#) register for the wakeup. In addition, GPTIMER1, GPTIMER2, and GPTIMER10 have implemented a mechanism to generate an accurate tick interrupt.

For each GP timer implemented in the device, there are two possible clock sources:

- 32-kHz clock
- System clock

Selection of the input clock source is done in the registers in the PRCM configuration (see [Section 16.2.1, GP Timers Overview](#)).

Each GP timer supports three functional modes:

- Timer mode
- Capture mode
- Compare mode

By default, after core reset, the capture and compare modes are disabled.

#### 16.2.4.1 GP Timers Block Diagram

[Figure 16-6](#) shows the block diagram of common GP timers, and [Figure 16-7](#) shows the block diagram of GP timers with 1-ms tick generation module.

**Figure 16-6. Block Diagram of GPTIMER3 through GPTIMER9 and GPTIMER11**



timers-006

Figure 16-7. Block Diagram of GPTIMER1, GPTIMER2, and GPTIMER10



timers-007

#### 16.2.4.2 Timer Mode Functionality

The timer is an upward counter that can be started and stopped at any time through the timer control register (GPTi.TCLR[0] ST bit). The timer counter register (GPTi.TCRR) can be loaded when stopped or on-the-fly (while counting). GPTn.TCRR can be loaded directly by a GPTi.TCRR write access with a new timer value. The GPTi.TCRR register can also be loaded with the value held in the timer load register GPTi.TLDR by a trigger register (GPTi.TTGR) write access. The GPTi.TCRR loading is done regardless of the GPTi.TTGR written value. The timer counter register GPTi.TCRR value can be read when stopped or captured on-the-fly by a GPTi.TCRR read access. The timer is stopped and the counter value is set to 0 when the module reset is asserted. The timer is maintained at stop after the reset is released.

In one-shot mode (the GPTi.TCLR[1] AR bit set to 0), the counter is stopped after counting overflow occurs (the counter value remains at 0).

When the autoreload mode is enabled (the GPTi.TCLR[1] AR bit set to 1), the GPTi.TCRR register is reloaded with the timer load register (GPTi.TLDR) value after a counting overflow occurs.

**CAUTION**

Do not put the overflow value (0xFFFFFFFF) in the GPTi.TLDR register because it can lead to undesired results.

An interrupt can be issued on overflow if the overflow interrupt enable bit is set in the timer interrupt enable register (GPTi.TIER[1] OVF\_IT\_ENA bit set to 1), the interrupt is enabled after  $10 * \text{GPTi.} \text{ICLK}$  clock cycles. A dedicated output pin (timer PWM) can be programmed in GPTi.TCLR[12] through GPTi.TCLR[11:10] (PT and TRG bits) to generate one positive pulse (prescaler duration) or to invert the current value (toggle mode) when an overflow occurs. The GPTi.TCLR[12] PT bit selects pulse/toggle modulation (GPTi.TCLR[11:10] TRG bit field select trigger mode).

Figure 16-8 shows the GPTi.TCRR timing value.

**Figure 16-8. GPTi.TCRR Timing Value**



#### 16.2.4.2.1 1-ms Tick Generation (Only GPTIMER1, GPTIMER2, and GPTIMER10)

Because the timer input clock is 32,768 Hz, the interrupt period is not exactly 1 ms. If the clock counts up to 32, it obtains a 0.977-ms period; if it counts up to 33, it obtains a 1.007-ms period. For large granularity, the error is cumulative and can generate important deviations to the standard value.

To minimize the error between a true 1-ms tick and the tick generated by the 32,768 Hz timer, the sequencing of periods less than 1 ms and periods greater than 1 ms must be shuffled. An additional 1-ms block is used to correct this error. Refer to Figure 16-9.

In this implementation, the increment sequencing is automatically managed by the timer to minimize the error. The user must define only the value of the timer positive increment register (GPTi.TPIR[31:0] POSITIVE\_INC\_VALUE bit field) and the timer negative increment register (GPTi.TNIR[31:0] NEGATIVE\_INC\_VALUE bit field). An automatic adaptation mechanism is used to simplify the programming model.

**Figure 16-9. Block Diagram of the 1-ms Tick Module**

timers-009

The GPTi.TPIR, GPTi.TNIR, and GPTi.TCVR registers and adders Add1, Add2, and Add3 are used to define whether the next value loaded in the timer counter register (GPTi.TCRR[31:0] TIMER\_COUNTER bit field) is the value of the GPTi.TLDR[31:0] LOAD\_VALUE bit field (period less than 1 ms) or the value of GPTi.TLDR[31:0] LOAD\_VALUE - 1 (period greater than 1 ms).

Table 16-8 lists the value loaded in the GPTi.TCRR register according to the sign of the result of Add1, Add2, and Add3.

MSB = 0: Positive value, MSB = 1: Negative value

**Table 16-8. Value Loaded in GPTi.TCRR to Generate 1-ms Tick**

| Add1 MSB | Add2 MSB | Add3 MSB | Value of GPTi.TCRR Register          |
|----------|----------|----------|--------------------------------------|
| 0        | 0        | 0        | GPTi.TLDR[31:0] LOAD_VALUE bit field |
| 0        | 0        | 1        | GPTi.TLDR[31:0] LOAD_VALUE bit field |
| 0        | 1        | 0        | GPTi.TLDR[31:0] LOAD_VALUE bit field |
| 0        | 1        | 1        | GPTi.TLDR[31:0] LOAD_VALUE - 1       |
| 1        | 0        | 0        | N/A                                  |
| 1        | 0        | 1        | N/A                                  |
| 1        | 1        | 0        | GPTi.TLDR[31:0] LOAD_VALUE - 1       |
| 1        | 1        | 1        | GPTi.TLDR[31:0] LOAD_VALUE - 1       |

The values of the GPTi.TPIR and GPTi.TNIR registers are calculated using the following formula:

- Positive increment value = ( (INTEGER[ Fclk \* Ttick] + 1) \* 1e6) - (Fclk \* Ttick \* 1e6)
- Negative increment value = (INTEGER[ Fclk \* Ttick] \* 1e6) - (Fclk \* Ttick \* 1e6)

---

**NOTE:** Fclk clock frequency (kHz)

Ttick tick period (ms)

---

The timer overflow counter register (GPTi.TOCR) and the timer overflow wrapping register (GPTi.TOWR) are used to filter interrupts. When the timer overflows, it increments the 24-bit TOCR register. When the 24-bit TOCR register values match the value in the 24-bit TOWR register and the timer overflow is asserted, the TOCR register is reset and an interrupt is generated to the TISR register.

With the conversion block in reset state (the positive increment register, negative increment register, and counter value register are zeroed), the programming model and the behavior of GPTIMER1, GPTIMER2, and GPTIMER10 remain unchanged.

For 1-ms tick with a 32,768-Hz clock:

- GPTi.TPIR[31:0] POSITIVE\_INC\_VALUE = 232000
- GPTi.TNIR[31:0] NEGATIVE\_INC\_VALUE = -768000
- GPTi.TLDR[31:0] LOAD\_VALUE = 0xFFFFFFF0

---

**NOTE:** Any value of the tick period can be generated with the appropriate value of the GPTi.TPIR, GPTi.TNIR, and GPTi.TLDR registers.

By default, the GPTi.TPIR, GPTi.TNIR, GPTi.TCVR, GPTi.TOCR, and GPTi.TOWR registers and the associated logic are in reset mode (all 0s) and have no action on the programming model.

---

#### 16.2.4.3 Capture Mode Functionality

When a transition is detected on the module input pin (EVENT\_CAPTURE), the timer value in the GPTi.TCRR register can be captured and saved in the GPTi.TCAR1 or GPTi.TCAR2 register function of the mode selected in the GPTi.TCLR[13] CAPT\_MODE bit. The edge detection circuitry monitors transitions on the input pin (EVENT\_CAPTURE).

The rising edge, falling edge, or both, can be selected in the GPTi.TCLR[9:8] TCM field to trigger the timer counter capture. The module sets the GPTi.TISR[2] TCAR\_IT\_FLAG bit when an active edge is detected, and at the same time, the counter value GPTi.TCRR is stored in timer capture register GPTi.TCAR1 or GPTi.TCAR2, as follows:

- If the GPTi.TCLR[13] CAPT\_MODE bit is 0, then on the first enabled capture event the value of the counter register is saved in the GPTi.TCAR1 register, and all the next events are ignored (no update on the GPTi.TCAR1 register and no interrupt triggering) until the detection logic is reset or the GPTi.TISR[2] TCAR\_IT\_FLAG bit is cleared by writing 1 in it.
- If the GPTi.TCLR[13] CAPT\_MODE bit is 1, then on the first enabled capture event the value of the counter register is saved in the GPTi.TCAR1 register, and on the second enabled capture event, the value of the counter register is saved in the GPTi.TCAR2 register. If a capture interrupt is enabled, the interrupt triggers on the second event capture. All other events are ignored (no update on GPTi.TCAR1/GPTi.TCAR2 and no interrupt triggering) until the detection logic is reset or GPTi.TISR[2] TCAR\_IT\_FLAG bit is cleared by writing 1 in it. This mechanism is useful for period calculation of a clock, if that clock is connected to the EVENT\_CAPTURE input pin.

The edge detection logic is reset (a new capture is enabled) when the active capture interrupt is served the GPTi.TISR[2] TCAR\_IT\_FLAG bit (previously 1) is cleared by writing 1 to it or when the edge detection mode bits (the GPTi.TCLR[9:8] TCM bit field) are changed from no-capture mode detection to any other mode. The timer functional clock (input to prescaler) is used to sample the input pin (EVENT\_CAPTURE). An input negative or positive pulse can be detected when the pulse time is greater than the functional clock period. An interrupt is issued on edge detection if the capture interrupt enable bit is set in the GPTi.TIER[2] TCAR\_IT\_ENA bit. See the examples in Figure 16-10 and Figure 16-11.

In Figure 16-10, the GPTi.TCLR[9:8] TCM value is 0b01, and GPTi.TCLR[13] CAPT\_MODE is 0. Only the rising edge of EVENT\_CAPTURE triggers a capture in the GPTi.TCAR1 and GPTi.TCAR2 registers, and only the GPTi.TCAR1 register updates.

**Figure 16-10. Capture Wave Example for GPTi.TCLR[13] CAPT\_MODE = 0**



In Figure 16-11, the GPTi.TCLR[9:8] TCM value is 0b01, and GPTi.TCLR[13] CAPT\_MODE is 1. Only the rising edge of EVENT\_CAPTURE triggers a capture in the GPTi.TCAR1 register on the first enabled event, and the GPTi.TCAR2 register updates on the second enabled event.

**Figure 16-11. Capture Wave Example for GPTi.TCLR[13] CAPT\_MODE = 1**



#### 16.2.4.4 Compare Mode Functionality

When the compare enable register GPTi.TCLR[6] CE bit is set to 1, the timer value (GPTi.TCRR[31:0] TIMER\_COUNTER field) is continuously compared to the value held in the timer match register (GPTi.TMAR). The GPTi.TMAR[31:0] COMPARE\_VALUE value can be loaded at any time (timer counting or stopped). When the GPTi.TCRR and the GPTi.TMAR values match, an interrupt is issued, if the GPTi.TIER[0] MAT\_IT\_ENA bit is set.

The dedicated output pin (timer PWM) can be programmed in the GPTi.[TCLR\[12\]](#) PT bit through the GPTi.[TCLR\[11:10\]](#) TRG field to generate one positive pulse (timer clock duration) or to invert the current value (toggle mode) when an overflow or a match occurs.

#### 16.2.4.5 Prescaler Functionality

A prescaler can be used to divide the timer counter input clock frequency. The prescaler is enabled when the GPTi.[TCLR\[5\]](#) PRE bit is set. The GPTi.[TCLR\[4:2\]](#) PTV field sets the second prescaler ratio. The prescaler counter is reset when the timer counter is stopped or reloaded on-the-fly.

[Table 16-9](#) lists the prescaler/timer reload values versus contexts.

**Table 16-9. Prescaler/Timer Reload Values Versus Contexts**

| Context                          | Prescaler | Timer Counter                    |
|----------------------------------|-----------|----------------------------------|
| Overflow (when autoreload is on) | Reset     | GPTi. <a href="#">TLDR[31:0]</a> |
| <a href="#">TCRR</a> write       | Reset     | GPTi. <a href="#">TCRR[31:0]</a> |
| <a href="#">TTGR</a> write       | Reset     | GPTi. <a href="#">TLDR[31:0]</a> |
| Stop                             | Reset     | Frozen                           |

#### 16.2.4.6 Pulse-Width Modulation

The timer can be configured to provide a programmable PWM output. The timer PWM output pin can be configured to toggle on an event. The GPTi.[TCLR\[11:10\]](#) TRG field determines on which register value the PWM pin toggles. Either overflow alone or both overflow and match can be selected to toggle the timer PWM pin when a compare condition occurs.

**CAUTION**

In toggle mode when GPTi.[TCLR\[11:10\]](#) TRG = 0x2 (overflow and match), the first event that will toggle the PWM line is an overflow event. If a match event occurs first, it will not toggle the PWM line. [Figure 16-13](#) illustrates those.

The GPTi.[TCLR\[7\]](#) SCPWM bit can be programmed to set or clear the timer PWM output signal only while the counter is stopped or the trigger is off. This allows setting the output pin to a known state before modulation starts. Modulation synchronously stops when the GPTi.[TCLR\[11:10\]](#) TRG field is cleared and overflow occurs. This allows fixing a deterministic state of the output pin when modulation stops.

In [Figure 16-12](#), the internal overflow pulse is set each time (0xFFFF FFFF – GPTi.[TLDR\[31:0\]](#) LOAD\_VALUE + 1) the value is reached, and the internal match pulse is set when the counter reaches the GPTi.[TMAR](#) register value. According to the value of the GPTi.[TCLR\[12\]](#) PT and GPTi.[TCLR\[11:10\]](#) TRG bits, the timer provides pulse or PWM event on the output pin (timer PWM).

The GPTi.[TLDR](#) and GPTi.[TMAR](#) registers must keep values smaller than the overflow value (0xFFFF FFFF) by at least two units. In case the PWM trigger events are both overflow and match, the difference between the values kept in the GPTi.[TMAR](#) register and the value in the GPTi.[TLDR](#) register must be at least two units. When match event is used, the compare mode GPTi.[TCLR\[6\]](#) CE bit must be set.

In [Figure 16-12](#), the GPTi.[TCLR\[7\]](#) SCPWM bit is set to 0. In [Figure 16-13](#), the GPTi.[TCLR\[7\]](#) SCPWM bit is set to 1. To obtain the desired wave form, start the counter at 0xFFFF FFFE value (to ensure an overflow first) or adjust the line polarity (GPTi.[TCLR\[7\]](#) SCPWM bit).

**Figure 16-12. Timing Diagram of PWM With GPTi.TCLR[7] SCPWM Bit = 0****Figure 16-13. Timing Diagram of PWM With GPTi.TCLR[7] SCPWM Bit = 1**

#### 16.2.4.7 Timer Counting Rate

The timer rate is defined by the following values:

- Value of the prescaler fields (GPTi.TCLR[5] PRE bit and GPTi.TCLR[4:2] PTV field)
- Value loaded into the timer load register (GPTi.TLDR)

Table 16-10 lists prescaler clock ratio values.

**Table 16-10. Prescaler Clock Ratio Values**

| GPTi.TCLR[5] PRE | GPTi.TCLR[4:2] PTV | Divisor (PS) |
|------------------|--------------------|--------------|
| 0                | X                  | 1            |
| 1                | 0                  | 2            |
| 1                | 1                  | 4            |
| 1                | 2                  | 8            |
| 1                | 3                  | 16           |
| 1                | 4                  | 32           |

**Table 16-10. Prescaler Clock Ratio Values (continued)**

| GPTi.TCLR[5] PRE | GPTi.TCLR[4:2] PTV | Divisor (PS) |
|------------------|--------------------|--------------|
| 1                | 5                  | 64           |
| 1                | 6                  | 128          |
| 1                | 7                  | 256          |

Thus, the timer overflow-rate is expressed as:

$$\text{OVF\_Rate} = (0xFFFF FFFF - \text{GPTn.TLDR} + 1) * (\text{timer-functional clock period}) * \text{PS}$$

With  $(\text{timer-functional clock period}) = 1 / (\text{timer-functional clock frequency})$  and  $\text{PS} = 2^{(\text{PTV} + 1)}$  if prescaler is enabled, or  $\text{PS} = 1$  if prescaler is disabled.

#### CAUTION

Internal resynchronization causes any write to the GPTn.TCLR[1] ST bit to have some latency before the register is updated:

2.5 \* functional clock cycles write\_GPTn.TCLR\_latency 3.5 \* functional clock cycles

Remember to take this latency into account whenever the timer must be started or stopped by a software change to the GPTn.TCLR[1] ST bit.

#### CAUTION

- In the non-PWM mode, GPTi.TLDR must be maintained at less than or equal to 0xFFFF FFFE.
- In the PWM mode, GPTi.TLDR must be maintained at less than or equal to 0xFFFF FFFD.

For example, with a timer clock input of 32 kHz and a GPTn.TCLR[5] PRE field equal to 0, the timer output period is as listed in [Table 16-11](#).

**Table 16-11. Value and Corresponding Interrupt Period**

| GPTi.TLDR[31:0] LOAD_VALUE | Interrupt Period |
|----------------------------|------------------|
| 0x0000 0000                | 39 h             |
| 0xFFFF 0000                | 2.1 s            |
| 0xFFFF FFF0                | 524 µs           |
| 0xFFFF FFFE                | 65.5 µs          |

### 16.2.5 Timer Under Emulation

During emulation mode, the timer continues to run according to the value of the GPTi.TIOCP\_CFG[5] EMUFREE bit.

If the GPTi.TIOCP\_CFG[5] EMUFREE bit is set to 1, timer execution is not stopped in emulation mode and the interrupt is still generated when overflow or match is reached.

If the GPTi.TIOCP\_CFG[5] EMUFREE bit is set to 0, the prescaler and timer are frozen and both resume on exit from emulation mode. The asynchronous external input pin (gpti\_pwm\_evt, where i = [8:11]) is internally synchronized on two timer-clock rising edges.

### 16.2.6 Accessing GP Timer Registers

All accesses are nonposted until software reconfiguration.

All registers are 32 bits wide, accessible through the L4 interface with 16-bit or 32-bit access (read/write).

Any 16-bit write access must be least-significant bit (LSB) first, and the second write access must be most-significant bit (MSB). Write operations to the GP timer registers (GPTi.TIDR, GPTi.TIOCP\_CFG, GPTi.TISR, GPTi.TIER, GPTi.TWER, and GPTi.TSICR) can skip the MSB access if it is not necessary to update the 16 MSBs of the register.

Write operations to any functional register (GPTi.TCLR, GPTi.TCRR, GPTi.TLDR, GPTi.TTGR, and GPTi.TMAR, and GPTi.TPIR, GPTi.TNIR, GPTi.TCVR, GPTi.TOCR, and GPTi.TOWR for GPTIMER1, GPTIMER2, and GPTIMER10) must be complete (the MSB must be written even if the MSB data is not used).

### 16.2.6.1 Writing to Timer Registers

The host uses the L4 interface to write the following registers synchronously with the timer interface clock:

- GPTi.TLDR
- GPTi.TCRR
- GPTi.TIER
- GPTi.TISR
- GPTi.TCLR
- GPTi.TIOCP\_CFG
- GPTi.TWER
- GPTi.TTGR
- GPTi.TSICR
- GPTi.TMAR

GPTIMER1, GPTIMER2, and GPTIMER10 also have the following registers:

- GPTi.TPIR
- GPTi.TNIR
- GPTi.TCVR
- GPTi.TOCR
- GPTi.TOWR

In 16-bit access mode, the 16 LSBs must be written before writing to the 16 MSBs.

#### 16.2.6.1.1 Write Posting Synchronization Mode

This mode is used if the GPTi.TSICR[2] POSTED bit is set to 1.

This mode uses a posted write scheme to update any internal register (GPTi.TCLR, GPTi.TCRR, GPTi.TLDR, GPTi.TTGR, GPTi.TMAR, and GPTi.TPIR, GPTi.TNIR, GPTi.TCVR, GPTi.TOCR, and GPTi.TOWR for GPTIMER1, GPTIMER2, and GPTIMER10). Therefore, the write transaction is immediately acknowledged on the L4 interface, although the effective write operation occurs later, because of a resynchronization in the timer clock domain. The advantage is that neither the interconnect nor the device that requested the write transaction is stalled.

For each register, a status bit is provided in the timer write-posted status register GPTi.TWPS. In this mode, it is mandatory that the software checks this status bit prior to any write access. In case a write is attempted to a register with a previous access pending, the previous access is discarded without notice.

The timer module updates the timer counter register value synchronously with the L4 clock. Consequently, any read access to the timer counter register GPTi.TCRR does not add any resynchronization latency; the current value is always available.

If a write access is pending for a register, reading from this register does not yield a correct result. Software synchronization must be used to avoid incorrect results.

The drawback of this automatic update mechanism is that it assumes a given relationship between the timer interface frequency and the timer clock frequency.

Functional frequency range: freq(timer clock) freq(L4 interface clock)/4

#### 16.2.6.1.2 Write Nonposting Synchronization Mode

This mode is used if the GPTi.[TSICR\[2\]](#) POSTED bit is set to 0.

This mode uses a nonposted write scheme to update any internal register. Therefore, the write transaction is not acknowledged on the L4 interface until the effective write operation occurs after the resynchronization in the timer functional clock domain. The drawback is that both the interconnect and the device that requested the write transaction are stalled during this period.

The same full resynchronization scheme is used for a read transaction, and the same stall period applies. A register read following a write to the same register is always coherent.

This mode is functional regardless of the ratio between the L4 interface frequency and the timer clock frequency.

#### 16.2.6.2 Reading From Timer Counter Registers

In 16-bit access mode, reading the 16 LSBs from the timer counter registers (GPTi.[TCRR](#), GPTi.[TCAR1](#), and GPTi.[TCAR2](#)) captures the current timer counter value. This must be followed by reading the 16MSBs.

IVA2.2 subsystem 16-bit accesses can be interleaved with MPU subsystem 32-bit accesses.

---

**NOTE:** LSB/MSB accesses cannot be interleaved (that is, the sequence LSB register 1, LSB register 2, MSB register 1, MSB register 2 is not supported).

---

## 16.3 General-Purpose Timers Register Manual

### 16.3.1 GP Timer Register Map

#### 16.3.1.1 Instance Summary

[Table 16-12](#) lists the base address and block size for the GP timer module instances. All timers are memory mapped to the L4 peripheral bus memory space.

**Table 16-12. GP Timer Instance Summary**

| Module Name | Base Address | Size     |
|-------------|--------------|----------|
| GPTIMER1    | 0x4831 8000  | 4K bytes |
| GPTIMER2    | 0x4903 2000  | 4K bytes |
| GPTIMER3    | 0x4903 4000  | 4K bytes |
| GPTIMER4    | 0x4903 6000  | 4K bytes |
| GPTIMER5    | 0x4903 8000  | 4K bytes |
| GPTIMER6    | 0x4903 A000  | 4K bytes |
| GPTIMER7    | 0x4903 C000  | 4K bytes |
| GPTIMER8    | 0x4903 E000  | 4K bytes |
| GPTIMER9    | 0x4904 0000  | 4K bytes |
| GPTIMER10   | 0x4808 6000  | 4K bytes |
| GPTIMER11   | 0x4808 8000  | 4K bytes |

### 16.3.2 GP Timer Register Mapping Summary

**CAUTION**

The GP timer registers are limited to 32-bit and 16-bit data accesses; 8-bit access is not allowed and can corrupt the register content.

[Table 16-13](#) through [Table 16-15](#) provide the register summary and associated offset addresses for the 11 GP timer internal registers. (Example: The physical address for the [TCLR](#) register of GPTIMER8 is 0x4903 E024.)

**Table 16-13. GPTIMER1 to GPTIMER4 Register Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | Physical Address (GPTIMER1) | Physical Address (GPTIMER2) | Physical Address (GPTIMER3) | Physical Address (GPTIMER4) |
|---------------|------|-----------------------|----------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|
| TIDR          | R    | 32                    | 0x000          | 0x4831 8000                 | 0x4903 2000                 | 0x4903 4000                 | 0x4903 6000                 |
| TIOCP_CFG     | RW   | 32                    | 0x010          | 0x4831 8010                 | 0x4903 2010                 | 0x4903 4010                 | 0x4903 6010                 |
| TISTAT        | R    | 32                    | 0x014          | 0x4831 8014                 | 0x4903 2014                 | 0x4903 4014                 | 0x4903 6014                 |
| TISR          | RW   | 32                    | 0x018          | 0x4831 8018                 | 0x4903 2018                 | 0x4903 4018                 | 0x4903 6018                 |
| TIER          | RW   | 32                    | 0x01C          | 0x4831 801C                 | 0x4903 201C                 | 0x4903 401C                 | 0x4903 601C                 |
| TWER          | RW   | 32                    | 0x020          | 0x4831 8020                 | 0x4903 2020                 | 0x4903 4020                 | 0x4903 6020                 |
| TCLR          | RW   | 32                    | 0x024          | 0x4831 8024                 | 0x4903 2024                 | 0x4903 4024                 | 0x4903 6024                 |
| TCRR          | RW   | 32                    | 0x028          | 0x4831 8028                 | 0x4903 2028                 | 0x4903 4028                 | 0x4903 6028                 |
| TLDR          | RW   | 32                    | 0x02C          | 0x4831 802C                 | 0x4903 202C                 | 0x4903 402C                 | 0x4903 602C                 |
| TTGR          | RW   | 32                    | 0x030          | 0x4831 8030                 | 0x4903 2030                 | 0x4903 4030                 | 0x4903 6030                 |
| TWPS          | R    | 32                    | 0x034          | 0x4831 8034                 | 0x4903 2034                 | 0x4903 4034                 | 0x4903 6034                 |
| TMAR          | RW   | 32                    | 0x038          | 0x4831 8038                 | 0x4903 2038                 | 0x4903 4038                 | 0x4903 6038                 |
| TCAR1         | R    | 32                    | 0x03C          | 0x4831 803C                 | 0x4903 203C                 | 0x4903 403C                 | 0x4903 603C                 |
| TSICR         | RW   | 32                    | 0x040          | 0x4831 8040                 | 0x4903 2040                 | 0x4903 4040                 | 0x4903 6040                 |
| TCAR2         | R    | 32                    | 0x044          | 0x4831 8044                 | 0x4903 2044                 | 0x4903 4044                 | 0x4903 6044                 |
| TPIR          | RW   | 32                    | 0x048          | 0x4831 8048                 | 0x4903 2048                 | -                           | -                           |
| TNIR          | RW   | 32                    | 0x04C          | 0x4831 804C                 | 0x4903 204C                 | -                           | -                           |
| TCVR          | RW   | 32                    | 0x050          | 0x4831 8050                 | 0x4903 2050                 | -                           | -                           |
| TOCR          | RW   | 32                    | 0x054          | 0x4831 8054                 | 0x4903 2054                 | -                           | -                           |
| TOWR          | RW   | 32                    | 0x058          | 0x4831 8058                 | 0x4903 2058                 | -                           | -                           |

**Table 16-14. GPTIMER5 to GPTIMER8 Register Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | Physical Address (GPTIMER5) | Physical Address (GPTIMER6) | Physical Address (GPTIMER7) | Physical Address (GPTIMER8) |
|---------------|------|-----------------------|----------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|
| TIDR          | R    | 32                    | 0x000          | 0x4903 8000                 | 0x4903 A000                 | 0x4903 C000                 | 0x4903 E000                 |
| TIOCP_CFG     | RW   | 32                    | 0x010          | 0x4903 8010                 | 0x4903 A010                 | 0x4903 C010                 | 0x4903 E010                 |
| TISTAT        | R    | 32                    | 0x014          | 0x4903 8014                 | 0x4903 A014                 | 0x4903 C014                 | 0x4903 E014                 |
| TISR          | RW   | 32                    | 0x018          | 0x4903 8018                 | 0x4903 A018                 | 0x4903 C018                 | 0x4903 E018                 |
| TIER          | RW   | 32                    | 0x01C          | 0x4903 801C                 | 0x4903 A01C                 | 0x4903 C01C                 | 0x4903 E01C                 |
| TWER          | RW   | 32                    | 0x020          | 0x4903 8020                 | 0x4903 A020                 | 0x4903 C020                 | 0x4903 E020                 |
| TCLR          | RW   | 32                    | 0x024          | 0x4903 8024                 | 0x4903 A024                 | 0x4903 C024                 | 0x4903 E024                 |
| TCRR          | RW   | 32                    | 0x028          | 0x4903 8028                 | 0x4903 A028                 | 0x4903 C028                 | 0x4903 E028                 |
| TLDR          | RW   | 32                    | 0x02C          | 0x4903 802C                 | 0x4903 A02C                 | 0x4903 C02C                 | 0x4903 E02C                 |
| TTGR          | RW   | 32                    | 0x030          | 0x4903 8030                 | 0x4903 A030                 | 0x4903 C030                 | 0x4903 E030                 |
| TWPS          | R    | 32                    | 0x034          | 0x4903 8034                 | 0x4903 A034                 | 0x4903 C034                 | 0x4903 E034                 |
| TMAR          | RW   | 32                    | 0x038          | 0x4903 8038                 | 0x4903 A038                 | 0x4903 C038                 | 0x4903 E038                 |
| TCAR1         | R    | 32                    | 0x03C          | 0x4903 803C                 | 0x4903 A03C                 | 0x4903 C03C                 | 0x4903 E03C                 |
| TSICR         | RW   | 32                    | 0x040          | 0x4903 8040                 | 0x4903 A040                 | 0x4903 C040                 | 0x4903 E040                 |
| TCAR2         | R    | 32                    | 0x044          | 0x4903 8044                 | 0x4903 A044                 | 0x4903 C044                 | 0x4903 E044                 |

**Table 16-15. GPTIMER9 to GPTIMER11 Register Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | Physical Address (GPTIMER9) | Physical Address (GPTIMER10) | Physical Address (GPTIMER11) |
|---------------|------|-----------------------|----------------|-----------------------------|------------------------------|------------------------------|
| TIDR          | R    | 32                    | 0x000          | 0x4904 0000                 | 0x4808 6000                  | 0x4808 8000                  |
| TIOCP_CFG     | RW   | 32                    | 0x010          | 0x4904 0010                 | 0x4808 6010                  | 0x4808 8010                  |
| TISTAT        | R    | 32                    | 0x014          | 0x4904 0014                 | 0x4808 6014                  | 0x4808 8014                  |
| TISR          | RW   | 32                    | 0x018          | 0x4904 0018                 | 0x4808 6018                  | 0x4808 8018                  |
| TIER          | RW   | 32                    | 0x01C          | 0x4904 001C                 | 0x4808 601C                  | 0x4808 801C                  |
| TWER          | RW   | 32                    | 0x020          | 0x4904 0020                 | 0x4808 6020                  | 0x4808 8020                  |
| TCLR          | RW   | 32                    | 0x024          | 0x4904 0024                 | 0x4808 6024                  | 0x4808 8024                  |
| TCRR          | RW   | 32                    | 0x028          | 0x4904 0028                 | 0x4808 6028                  | 0x4808 8028                  |
| TLDR          | RW   | 32                    | 0x02C          | 0x4904 002C                 | 0x4808 602C                  | 0x4808 802C                  |
| TTGR          | RW   | 32                    | 0x030          | 0x4904 0030                 | 0x4808 6030                  | 0x4808 8030                  |
| TWPS          | R    | 32                    | 0x034          | 0x4904 0034                 | 0x4808 6034                  | 0x4808 8034                  |
| TMAR          | RW   | 32                    | 0x038          | 0x4904 0038                 | 0x4808 6038                  | 0x4808 8038                  |
| TCAR1         | R    | 32                    | 0x03C          | 0x4904 003C                 | 0x4808 603C                  | 0x4808 803C                  |
| TSICR         | RW   | 32                    | 0x040          | 0x4904 0040                 | 0x4808 6040                  | 0x4808 8040                  |
| TCAR2         | R    | 32                    | 0x044          | 0x4904 0044                 | 0x4808 6044                  | 0x4808 8044                  |
| TPIR          | RW   | 32                    | 0x048          | -                           | 0x4808 6048                  | -                            |
| TNIR          | RW   | 32                    | 0x04C          | -                           | 0x4808 604C                  | -                            |
| TCVR          | RW   | 32                    | 0x050          | -                           | 0x4808 6050                  | -                            |
| TOCR          | RW   | 32                    | 0x054          | -                           | 0x4808 6054                  | -                            |
| TOWR          | RW   | 32                    | 0x058          | -                           | 0x4808 6058                  | -                            |

### 16.3.3 GP Timer Register Descriptions

Table 16-16 through Table 16-54 describe the GP timer register bits.

**Table 16-16. TIDR**

|                         |                                                                                                                                                                                                                                                                                                                             |                 |                                                                                                                                                                                                                        |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x000                                                                                                                                                                                                                                                                                                                       |                 |                                                                                                                                                                                                                        |
| <b>Physical Address</b> | 0x4831 8000<br>0x4903 2000<br>0x4903 4000<br>0x4903 6000<br>0x4903 8000<br>0x4903 A000<br>0x4903 C000<br>0x4903 E000<br>0x4904 0000<br>0x4808 6000<br>0x4808 8000<br><br>0x4903 2000<br>0x4903 4000<br>0x4903 6000<br>0x4903 8000<br>0x4903 A000<br>0x4903 C000<br>0x4903 E000<br>0x4904 0000<br>0x4808 6000<br>0x4808 8000 | <b>Instance</b> | GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER9<br>GPTIMER9<br>GPTIMER9<br><br>GPT2<br>GPT3<br>GPT4<br>GPT5<br>GPT6<br>GPT7<br>GPT8<br>GPT9<br>GPT10<br>GPT11 |
| <b>Description</b>      | This register contains the IP revision code.                                                                                                                                                                                                                                                                                |                 |                                                                                                                                                                                                                        |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                           |                 |                                                                                                                                                                                                                        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | TID_REV |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                         | Type | Reset              |
|------|------------|-----------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | Reserved   | Reads return 0.                                                                                     | R    | 0x000000           |
| 7:0  | TID_REV    | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision<br>Examples: 0x10 for 1.0, 0x21 for 2.1 | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 16-17. Register Call Summary for Register TIDR**

## General-Purpose Timers

- [Accessing GP Timer Registers: \[0\]](#)

## General-Purpose Timers Register Manual

- [GP Timer Register Mapping Summary: \[1\] \[2\] \[3\]](#)

**Table 16-18. TIOCP\_CFG**

|                         |                                                                                                                                                                                                                                                                                                                             |                 |                                                                                                                                                                                                                        |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <b>Address Offset</b>   | 0x010                                                                                                                                                                                                                                                                                                                       |                 |                                                                                                                                                                                                                        |  |
| <b>Physical Address</b> | 0x4831 8010<br>0x4903 2010<br>0x4903 4010<br>0x4903 6010<br>0x4903 8010<br>0x4903 A010<br>0x4903 C010<br>0x4903 E010<br>0x4904 0010<br>0x4808 6010<br>0x4808 8010<br><br>0x4903 2010<br>0x4903 4010<br>0x4903 6010<br>0x4903 8010<br>0x4903 A010<br>0x4903 C010<br>0x4903 E010<br>0x4904 0010<br>0x4808 6010<br>0x4808 8010 | <b>Instance</b> | GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER9<br>GPTIMER9<br>GPTIMER9<br><br>GPT2<br>GPT3<br>GPT4<br>GPT5<br>GPT6<br>GPT7<br>GPT8<br>GPT9<br>GPT10<br>GPT11 |  |
| <b>Description</b>      | This register controls the various parameters of the GP timer L4 interface.                                                                                                                                                                                                                                                 |                 |                                                                                                                                                                                                                        |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                          |                 |                                                                                                                                                                                                                        |  |

| 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        |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------------|----------|---------|----------|-----------|-----------|----------|
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CLOCKACTIVITY | Reserved | EMUFREE | IDLEMODE | ENAWAKEUP | SOFTRESET | AUTOIDLE |

| Bits  | Field Name    | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                | Type | Reset      |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:10 | Reserved      | Write 0s for future compatibility. Reads return 0.                                                                                                                                                                                                                                                                                                                                                         | R    | 0x00000000 |
| 9:8   | CLOCKACTIVITY | Clock activity during wakeup mode period:<br><br>0x0: L4 interface and Functional clocks can be switched off.<br>0x1: L4 interface clock is maintained during wake-up period; Functional clock can be switched off.<br>0x2: L4 interface clock can be switched off; Functional clock is maintained during wake-up period.<br>0x3: L4 interface and Functional clocks are maintained during wake-up period. | RW   | 0x0        |
| 7:6   | Reserved      | Write 0s for future compatibility. Reads return 0.                                                                                                                                                                                                                                                                                                                                                         | R    | 0x0        |
| 5     | EMUFREE       | Emulation mode<br><br>0x0: Timer counter frozen in emulation<br>0x1: Timer counter free-running in emulation                                                                                                                                                                                                                                                                                               | RW   | 0          |
| 4:3   | IDLEMODE      | Power management, req/ack control<br><br>0x0: Force-idle. An idle request is acknowledged unconditionally.<br>0x1: No-idle. An idle request is never acknowledged.<br>0x2: Smart-idle. Acknowledgement to an idle request is given based on the internal activity of the module.                                                                                                                           | RW   | 0x0        |

| Bits | Field Name | DESCRIPTION                                                                                                                                                                                  | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x3: Reserved. Do not use.                                                                                                                                                                   |      |       |
| 2    | ENAWAKEUP  | Wake-up feature global control<br>0x0: No wake-up line assertion in idle mode<br>0x1: Wake-up line assertion enabled in smart-idle mode                                                      | RW   | 0     |
| 1    | SOFTRESET  | Software reset. This bit is automatically reset by the hardware. During reads, it always returns 0.<br>0x0: Normal mode<br>0x1: The module is reset.                                         | RW   | 0     |
| 0    | AUTOIDLE   | Internal L4 interface clock gating strategy<br>0x0: L4 interface clock is free-running.<br>0x1: Automatic L4 interface clock gating strategy is applied, based on the L4 interface activity. |      | 0     |

**Table 16-19. Register Call Summary for Register TIOCP\_CFG**

## General-Purpose Timers

- [Clock Management: \[0\]](#) [\[1\]](#) [\[2\]](#)
- [Wake-Up Capability: \[3\]](#) [\[4\]](#)
- [Software Reset: \[5\]](#) [\[6\]](#)
- [Timer Under Emulation: \[7\]](#) [\[8\]](#) [\[9\]](#)
- [Accessing GP Timer Registers: \[10\]](#)
- [Writing to Timer Registers: \[11\]](#)

## General-Purpose Timers Register Manual

- [GP Timer Register Mapping Summary: \[12\]](#) [\[13\]](#) [\[14\]](#)

**Table 16-20. TISTAT**

|                         |                                                                                                                                                                                                                                                                                                                             |                 |                                                                                                                                                                                                                        |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x014                                                                                                                                                                                                                                                                                                                       |                 |                                                                                                                                                                                                                        |
| <b>Physical Address</b> | 0x4831 8014<br>0x4903 2014<br>0x4903 4014<br>0x4903 6014<br>0x4903 8014<br>0x4903 A014<br>0x4903 C014<br>0x4903 E014<br>0x4904 0014<br>0x4808 6014<br>0x4808 8014<br><br>0x4903 2014<br>0x4903 4014<br>0x4903 6014<br>0x4903 8014<br>0x4903 A014<br>0x4903 C014<br>0x4903 E014<br>0x4904 0014<br>0x4808 6014<br>0x4808 8014 | <b>Instance</b> | GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER9<br>GPTIMER9<br>GPTIMER9<br><br>GPT2<br>GPT3<br>GPT4<br>GPT5<br>GPT6<br>GPT7<br>GPT8<br>GPT9<br>GPT10<br>GPT11 |
| <b>Description</b>      | This register provides status information about the module, excluding the interrupt status information.                                                                                                                                                                                                                     |                 |                                                                                                                                                                                                                        |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                           |                 |                                                                                                                                                                                                                        |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|-----------|---|---|---|
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Reserved |    |    |    |    |    |   |   |   |   |   |   | RESETDONE |   |   |   |

| Bits | Field Name | DESCRIPTION                                                                                     | Type | Reset    |
|------|------------|-------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved   | Reads return 0.                                                                                 | R    | 0x000000 |
| 7:1  | Reserved   | Reads return 0.                                                                                 | R    | 0x00     |
| 0    | RESETDONE  | Internal reset monitoring<br><br>0x0: Internal module reset is ongoing.<br>0x1: Reset completed | R    | 0        |

**Table 16-21. Register Call Summary for Register TISTAT**

General-Purpose Timers

- [Software Reset: \[0\]](#)

General-Purpose Timers Register Manual

- [GP Timer Register Mapping Summary: \[1\] \[2\] \[3\]](#)

**Table 16-22. TISR**

|                         |                                                                           |                 |          |  |
|-------------------------|---------------------------------------------------------------------------|-----------------|----------|--|
| <b>Address Offset</b>   | 0x018                                                                     |                 |          |  |
| <b>Physical Address</b> | 0x4831 8018                                                               | <b>Instance</b> | GPTIMER1 |  |
|                         | 0x4903 2018                                                               |                 | GPTIMER1 |  |
|                         | 0x4903 4018                                                               |                 | GPTIMER1 |  |
|                         | 0x4903 6018                                                               |                 | GPTIMER1 |  |
|                         | 0x4903 8018                                                               |                 | GPTIMER5 |  |
|                         | 0x4903 A018                                                               |                 | GPTIMER5 |  |
|                         | 0x4903 C018                                                               |                 | GPTIMER5 |  |
|                         | 0x4903 E018                                                               |                 | GPTIMER5 |  |
|                         | 0x4904 0018                                                               |                 | GPTIMER9 |  |
|                         | 0x4808 6018                                                               |                 | GPTIMER9 |  |
|                         | 0x4808 8018                                                               |                 | GPTIMER9 |  |
|                         | 0x4903 2018                                                               |                 | GPT2     |  |
|                         | 0x4903 4018                                                               |                 | GPT3     |  |
|                         | 0x4903 6018                                                               |                 | GPT4     |  |
|                         | 0x4903 8018                                                               |                 | GPT5     |  |
|                         | 0x4903 A018                                                               |                 | GPT6     |  |
|                         | 0x4903 C018                                                               |                 | GPT7     |  |
|                         | 0x4903 E018                                                               |                 | GPT8     |  |
|                         | 0x4904 0018                                                               |                 | GPT9     |  |
|                         | 0x4808 6018                                                               |                 | GPT10    |  |
|                         | 0x4808 8018                                                               |                 | GPT11    |  |
| <b>Description</b>      | This register shows which interrupt events are pending inside the module. |                 |          |  |
| <b>Type</b>             | RW                                                                        |                 |          |  |



| Bits | Field Name   | Description                                                                                                                                                                                       | Type | Reset      |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | Reserved     | Reads return 0.                                                                                                                                                                                   | R    | 0x00000000 |
| 2    | TCAR_IT_FLAG | Pending capture interrupt status<br><br>Read 0x0: No capture interrupt event pending<br>Write 0x0: Status unchanged<br>Read 0x1: Capture interrupt event pending<br>Write 0x1: Status bit cleared | RW   | 0          |
| 1    | OVF_IT_FLAG  | Pending overflow interrupt status<br><br>Read 0x0: No overflow interrupt pending<br>Write 0x0: Status unchanged<br>Read 0x1: Overflow interrupt pending<br>Write 0x1: Status bit cleared          | RW   | 0          |
| 0    | MAT_IT_FLAG  | Pending match interrupt status<br><br>Read 0x0: No match interrupt pending<br>Write 0x0: Status unchanged<br>Read 0x1: Match interrupt pending<br>Write 0x1: Status bit cleared                   | RW   | 0          |

**Table 16-23. Register Call Summary for Register TISR**
**General-Purpose Timers**

- Wake-Up Capability: [0]
- GP Timer Interrupts: [1]
- 1-ms Tick Generation (Only GPTIMER1, GPTIMER2, and GPTIMER10): [2]
- Capture Mode Functionality: [3] [4] [5] [6]
- Accessing GP Timer Registers: [7]
- Writing to Timer Registers: [8]

**General-Purpose Timers Register Manual**

- GP Timer Register Mapping Summary: [9] [10] [11]

**Table 16-24. TIER**

|                         |                                                               |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|---------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x01C                                                         |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4831 801C                                                   |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | GPTIMER1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 201C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPTIMER1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 401C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPTIMER1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 601C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPTIMER1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 801C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPTIMER5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 A01C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPTIMER5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 C01C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPTIMER5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 E01C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPTIMER5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4904 001C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPTIMER9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4808 601C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPTIMER9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4808 801C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPTIMER9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 201C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPT2     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 401C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPT3     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 601C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPT4     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 801C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPT5     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 A01C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPT6     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 C01C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPT7     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4903 E01C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPT8     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4904 001C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPT9     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4808 601C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPT10    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4808 801C                                                   |  |  |  |  |  |  |  |  |  |  |                 | GPT11    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register controls (enable/disable) the interrupt events. |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                            |  |  |  |  |  |  |  |  |  |  |                 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



| Bits | Field Name | Description              | Type | Reset |
|------|------------|--------------------------|------|-------|
|      | 0x0:       | Disable match interrupt. |      |       |
|      | 0x1:       | Enable match interrupt.  |      |       |

**Table 16-25. Register Call Summary for Register TIER**

## General-Purpose Timers

- [GP Timer Interrupts: \[0\]](#)
- [GP Timers Functional Description: \[1\]](#)
- [Timer Mode Functionality: \[2\]](#)
- [Capture Mode Functionality: \[3\]](#)
- [Compare Mode Functionality: \[4\]](#)
- [Accessing GP Timer Registers: \[5\]](#)
- [Writing to Timer Registers: \[6\]](#)

## General-Purpose Timers Register Manual

- [GP Timer Register Mapping Summary: \[7\] \[8\] \[9\]](#)

**Table 16-26. TWER**

|                         |                                                                                                                                                                                                                                                                                                                             |                 |                                                                                                                                                                                                                        |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <b>Address Offset</b>   | 0x020                                                                                                                                                                                                                                                                                                                       |                 |                                                                                                                                                                                                                        |  |
| <b>Physical Address</b> | 0x4831 8020<br>0x4903 2020<br>0x4903 4020<br>0x4903 6020<br>0x4903 8020<br>0x4903 A020<br>0x4903 C020<br>0x4903 E020<br>0x4904 0020<br>0x4808 6020<br>0x4808 8020<br><br>0x4903 2020<br>0x4903 4020<br>0x4903 6020<br>0x4903 8020<br>0x4903 A020<br>0x4903 C020<br>0x4903 E020<br>0x4904 0020<br>0x4808 6020<br>0x4808 8020 | <b>Instance</b> | GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER9<br>GPTIMER9<br>GPTIMER9<br><br>GPT2<br>GPT3<br>GPT4<br>GPT5<br>GPT6<br>GPT7<br>GPT8<br>GPT9<br>GPT10<br>GPT11 |  |
| <b>Description</b>      | This register controls (enable/disable) the wake-up feature on specific interrupt events.                                                                                                                                                                                                                                   |                 |                                                                                                                                                                                                                        |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                          |                 |                                                                                                                                                                                                                        |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name   | Description                                                                                | Type | Reset      |
|------|--------------|--------------------------------------------------------------------------------------------|------|------------|
| 31:3 | Reserved     | Reads return 0                                                                             | R    | 0x00000000 |
| 2    | TCAR_WUP_ENA | Enable capture wake-up<br>0x0: Disable capture wake-up.<br>0x1: Enable capture wake-up.    | RW   | 0          |
| 1    | OVF_WUP_ENA  | Enable overflow wake-up<br>0x0: Disable overflow wake-up.<br>0x1: Enable overflow wake-up. | RW   | 0          |
| 0    | MAT_WUP_ENA  | Enable match wake-up<br>0x0: Disable match wake-up.<br>0x1: Enable match wake-up.          | RW   | 0          |

**Table 16-27. Register Call Summary for Register TWER**

## General-Purpose Timers

- [Wake-Up Capability: \[0\] \[1\]](#)
- [GP Timers Functional Description: \[2\]](#)
- [Accessing GP Timer Registers: \[3\]](#)
- [Writing to Timer Registers: \[4\]](#)

## General-Purpose Timers Register Manual

- [GP Timer Register Mapping Summary: \[5\] \[6\] \[7\]](#)

**Table 16-28. TCLR**

| Address Offset | 0x024                                                                         | Physical Address | 0x4831 8024<br>0x4903 2024<br>0x4903 4024<br>0x4903 6024<br>0x4903 8024<br>0x4903 A024<br>0x4903 C024<br>0x4903 E024<br>0x4904 0024<br>0x4808 6024<br>0x4808 8024<br><br>0x4903 2024<br>0x4903 4024<br>0x4903 6024<br>0x4903 8024<br>0x4903 A024<br>0x4903 C024<br>0x4903 E024<br>0x4904 0024<br>0x4808 6024<br>0x4808 8024 | Instance | GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER9<br>GPTIMER9<br>GPTIMER9<br><br>GPT2<br>GPT3<br>GPT4<br>GPT5<br>GPT6<br>GPT7<br>GPT8<br>GPT9<br>GPT10<br>GPT11 |
|----------------|-------------------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description    | This register controls optional features specific to the timer functionality. |                  |                                                                                                                                                                                                                                                                                                                             |          |                                                                                                                                                                                                                        |
| Type           | RW                                                                            |                  |                                                                                                                                                                                                                                                                                                                             |          |                                                                                                                                                                                                                        |

| 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  |  |    |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|-----------|----|----|----|-----|----|-----|---|-------|---|----|---|-----|---|-----|---|----|--|----|--|
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    | GPO_CFG |    | CAPT_MODE |    | PT |    | TRG |    | TCM |   | SCPWM |   | CE |   | PRE |   | PTV |   | AR |  | ST |  |

## General-Purpose Timers Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                 | Type | Reset   |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:15 | Reserved   | Reads return 0.                                                                                                                                                                                                             | R    | 0x00000 |
| 14    | GPO_CFG    | PWM output/event detection input pin direction control:<br><br>0x0: Configures the pin as an output (needed when PWM mode is required)<br><br>0x1: Configures the pin as an input (needed when capture mode is required)    | RW   | 0       |
| 13    | CAPT_MODE  | Capture mode select bit (first/second)<br><br>0x0: Capture the first enabled capture event in <a href="#">TCAR1</a> .<br><br>0x1: Capture the second enabled capture event in <a href="#">TCAR2</a> .                       | RW   | 0       |
| 12    | PT         | Pulse or toggle select bit<br><br>0x0: Pulse modulation<br><br>0x1: Toggle modulation                                                                                                                                       | RW   | 0       |
| 11:10 | TRG        | Trigger output mode<br><br>0x0: No trigger<br><br>0x1: Overflow trigger<br><br>0x2: Overflow and match trigger<br><br>0x3: Reserved                                                                                         | RW   | 0x0     |
| 9:8   | TCM        | Transition capture mode<br><br>0x0: No capture<br><br>0x1: Capture on rising edges of EVENT_CAPTURE pin.<br><br>0x2: Capture on falling edges of EVENT_CAPTURE pin.<br><br>0x3: Capture on both edges of EVENT_CAPTURE pin. | RW   | 0x0     |
| 7     | SCPWM      | Pulse-width-modulation output pin default setting when counter is stopped or trigger output mode is set to no trigger.<br><br>0x0: Default value of PWM_out output: 0<br><br>0x1: Default value of PWM_out output: 1        | RW   | 0       |
| 6     | CE         | Compare enable<br><br>0x0: Compare disabled<br><br>0x1: Compare enabled                                                                                                                                                     | RW   | 0       |
| 5     | PRE        | Prescaler enable<br><br>0x0: Prescaler disabled<br><br>0x1: Prescaler enabled                                                                                                                                               | RW   | 0       |
| 4:2   | PTV        | Trigger output mode<br><br>0x0: The timer counter is prescaled with the value: $2^{(PTV+1)}$ . Example: PTV = 3, counter increases value (if started) after 16 functional clock periods.                                    | RW   | 0x0     |
| 1     | AR         | Autoreload mode<br><br>0x0: One-shot mode overflow<br><br>0x1: Autoreload mode overflow                                                                                                                                     | RW   | 0       |
| 0     | ST         | Start/stop timer control<br><br>0x0: Stop the timer<br><br>0x1: Start the timer                                                                                                                                             | RW   | 0       |

**Table 16-29. Register Call Summary for Register TCLR**
**General-Purpose Timers**

- [Timer Mode Functionality](#): [0] [1] [2] [3] [4] [5] [6]
- [Capture Mode Functionality](#): [7] [8] [9] [10] [11] [12] [13] [14] [15]
- [Compare Mode Functionality](#): [16] [17] [18]
- [Prescaler Functionality](#): [19] [20]
- [Pulse-Width Modulation](#): [21] [22] [23] [24] [25] [26] [27] [28] [29] [30]
- [Timer Counting Rate](#): [31] [32] [33] [34] [35] [36] [37]
- [Accessing GP Timer Registers](#): [38]
- [Writing to Timer Registers](#): [39]
- [Write Posting Synchronization Mode](#): [40]

**General-Purpose Timers Register Manual**

- [GP Timer Register Mapping Summary](#): [41] [42] [43] [44]

**Table 16-30. TCRR**

| <b>Address Offset</b>   | 0x028                                                  |                                         |                 |              |
|-------------------------|--------------------------------------------------------|-----------------------------------------|-----------------|--------------|
| <b>Physical Address</b> |                                                        | <b>Instance</b>                         |                 |              |
| 0x4831 8028             |                                                        | GPTIMER1                                |                 |              |
| 0x4903 2028             |                                                        | GPTIMER1                                |                 |              |
| 0x4903 4028             |                                                        | GPTIMER1                                |                 |              |
| 0x4903 6028             |                                                        | GPTIMER1                                |                 |              |
| 0x4903 8028             |                                                        | GPTIMER5                                |                 |              |
| 0x4903 A028             |                                                        | GPTIMER5                                |                 |              |
| 0x4903 C028             |                                                        | GPTIMER5                                |                 |              |
| 0x4903 E028             |                                                        | GPTIMER5                                |                 |              |
| 0x4904 0028             |                                                        | GPTIMER9                                |                 |              |
| 0x4808 6028             |                                                        | GPTIMER9                                |                 |              |
| 0x4808 8028             |                                                        | GPTIMER9                                |                 |              |
| 0x4903 2028             |                                                        | GPT2                                    |                 |              |
| 0x4903 4028             |                                                        | GPT3                                    |                 |              |
| 0x4903 6028             |                                                        | GPT4                                    |                 |              |
| 0x4903 8028             |                                                        | GPT5                                    |                 |              |
| 0x4903 A028             |                                                        | GPT6                                    |                 |              |
| 0x4903 C028             |                                                        | GPT7                                    |                 |              |
| 0x4903 E028             |                                                        | GPT8                                    |                 |              |
| 0x4904 0028             |                                                        | GPT9                                    |                 |              |
| 0x4808 6028             |                                                        | GPT10                                   |                 |              |
| 0x4808 8028             |                                                        | GPT11                                   |                 |              |
| <b>Description</b>      | This register holds the value of the internal counter. |                                         |                 |              |
| <b>Type</b>             | RW                                                     |                                         |                 |              |
| 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 |              |
| TIMER_COUNTER           |                                                        |                                         |                 |              |
| Bits                    | <b>Field Name</b>                                      | <b>Description</b>                      | <b>Type</b>     | <b>Reset</b> |
| 31:0                    | TIMER_COUNTER                                          | The value of the timer counter register | RW              | 0x00000000   |

**Table 16-31. Register Call Summary for Register TCRR**

## General-Purpose Timers

- Wake-Up Capability: [0] [1]
- Timer Mode Functionality: [2] [3] [4] [5] [6] [7] [8] [9] [10]
- 1-ms Tick Generation (Only GPTIMER1, GPTIMER2, and GPTIMER10): [11] [12] [13]
- Capture Mode Functionality: [14] [15]
- Compare Mode Functionality: [16] [17]
- Prescaler Functionality: [18] [19]
- Accessing GP Timer Registers: [20]
- Writing to Timer Registers: [21]
- Write Posting Synchronization Mode: [22] [23]
- Reading From Timer Counter Registers: [24]

## General-Purpose Timers Register Manual

- GP Timer Register Mapping Summary: [25] [26] [27]
- GP Timer Register Descriptions: [28] [29] [30]

**Table 16-32. TLDR**

| <b>Address Offset</b>   | 0x02C                                      |                 |  |
|-------------------------|--------------------------------------------|-----------------|--|
| <b>Physical Address</b> |                                            | <b>Instance</b> |  |
|                         | 0x4831 802C                                | GPTIMER1        |  |
|                         | 0x4903 202C                                | GPTIMER1        |  |
|                         | 0x4903 402C                                | GPTIMER1        |  |
|                         | 0x4903 602C                                | GPTIMER1        |  |
|                         | 0x4903 802C                                | GPTIMER5        |  |
|                         | 0x4903 A02C                                | GPTIMER5        |  |
|                         | 0x4903 C02C                                | GPTIMER5        |  |
|                         | 0x4903 E02C                                | GPTIMER5        |  |
|                         | 0x4904 002C                                | GPTIMER9        |  |
|                         | 0x4808 602C                                | GPTIMER9        |  |
|                         | 0x4808 802C                                | GPTIMER9        |  |
|                         | 0x4903 202C                                | GPT2            |  |
|                         | 0x4903 402C                                | GPT3            |  |
|                         | 0x4903 602C                                | GPT4            |  |
|                         | 0x4903 802C                                | GPT5            |  |
|                         | 0x4903 A02C                                | GPT6            |  |
|                         | 0x4903 C02C                                | GPT7            |  |
|                         | 0x4903 E02C                                | GPT8            |  |
|                         | 0x4904 002C                                | GPT9            |  |
|                         | 0x4808 602C                                | GPT10           |  |
|                         | 0x4808 802C                                | GPT11           |  |
| <b>Description</b>      | This register holds the timer load values. |                 |  |
| <b>Type</b>             | RW                                         |                 |  |

|            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| LOAD_VALUE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------|-------------|--------------|
| 31:0        | LOAD_VALUE        | The value of the timer load register | RW          | 0x00000000   |

**Table 16-33. Register Call Summary for Register TLDR**

## General-Purpose Timers

- Timer Mode Functionality: [0] [1] [2]
- 1-ms Tick Generation (Only GPTIMER1, GPTIMER2, and GPTIMER10): [3] [4] [5] [6] [7] [8] [9] [10] [11] [12]
- Prescaler Functionality: [13] [14]
- Pulse-Width Modulation: [15] [16] [17]
- Timer Counting Rate: [18] [19] [20] [21] [22]
- Accessing GP Timer Registers: [23]
- Writing to Timer Registers: [24]
- Write Posting Synchronization Mode: [25]

## General-Purpose Timers Register Manual

- GP Timer Register Mapping Summary: [26] [27] [28]

**Table 16-34. TTGR**

|                         |                                                                                                                                                                                                                                                                                                                             |                 |                                                                                                                                                                                                                        |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x030                                                                                                                                                                                                                                                                                                                       |                 |                                                                                                                                                                                                                        |
| <b>Physical Address</b> | 0x4831 8030<br>0x4903 2030<br>0x4903 4030<br>0x4903 6030<br>0x4903 8030<br>0x4903 A030<br>0x4903 C030<br>0x4903 E030<br>0x4904 0030<br>0x4808 6030<br>0x4808 8030<br><br>0x4903 2030<br>0x4903 4030<br>0x4903 6030<br>0x4903 8030<br>0x4903 A030<br>0x4903 C030<br>0x4903 E030<br>0x4904 0030<br>0x4808 6030<br>0x4808 8030 | <b>Instance</b> | GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER9<br>GPTIMER9<br>GPTIMER9<br><br>GPT2<br>GPT3<br>GPT4<br>GPT5<br>GPT6<br>GPT7<br>GPT8<br>GPT9<br>GPT10<br>GPT11 |
| <b>Description</b>      | This register triggers a counter reload of timer by writing any value in it.                                                                                                                                                                                                                                                |                 |                                                                                                                                                                                                                        |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                          |                 |                                                                                                                                                                                                                        |

|            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| TTGR_VALUE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                    | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------|------|------------|
| 31:0 | TTGR_VALUE | The value of the trigger register. During reads, it always returns 0xFFFFFFFF. | RW   | 0xFFFFFFFF |

**Table 16-35. Register Call Summary for Register TTGR**

## General-Purpose Timers

- Timer Mode Functionality: [0] [1]
- Prescaler Functionality: [2]
- Accessing GP Timer Registers: [3]
- Writing to Timer Registers: [4]
- Write Posting Synchronization Mode: [5]

**Table 16-35. Register Call Summary for Register TTGR (continued)**

General-Purpose Timers Register Manual

- GP Timer Register Mapping Summary: [6] [7] [8]

**Table 16-36. TWPS**

|                         |                                                       |                 |          |
|-------------------------|-------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x034                                                 |                 |          |
| <b>Physical Address</b> | 0x4831 8034                                           | <b>Instance</b> | GPTIMER1 |
|                         | 0x4903 2034                                           |                 | GPTIMER1 |
|                         | 0x4903 4034                                           |                 | GPTIMER1 |
|                         | 0x4903 6034                                           |                 | GPTIMER1 |
|                         | 0x4903 8034                                           |                 | GPTIMER5 |
|                         | 0x4903 A034                                           |                 | GPTIMER5 |
|                         | 0x4903 C034                                           |                 | GPTIMER5 |
|                         | 0x4903 E034                                           |                 | GPTIMER5 |
|                         | 0x4904 0034                                           |                 | GPTIMER9 |
|                         | 0x4808 6034                                           |                 | GPTIMER9 |
|                         | 0x4808 8034                                           |                 | GPTIMER9 |
|                         | 0x4903 2034                                           |                 | GPT2     |
|                         | 0x4903 4034                                           |                 | GPT3     |
|                         | 0x4903 6034                                           |                 | GPT4     |
|                         | 0x4903 8034                                           |                 | GPT5     |
|                         | 0x4903 A034                                           |                 | GPT6     |
|                         | 0x4903 C034                                           |                 | GPT7     |
|                         | 0x4903 E034                                           |                 | GPT8     |
|                         | 0x4904 0034                                           |                 | GPT9     |
|                         | 0x4808 6034                                           |                 | GPT10    |
|                         | 0x4808 8034                                           |                 | GPT11    |
| <b>Description</b>      | This register indicates if a Write-Posted is pending. |                 |          |
| <b>Type</b>             | R                                                     |                 |          |

| <b>Bits</b> | <b>Field Name</b>                                  | <b>Description</b>                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:10       | Reserved                                           | Reads return 0.                                                                                                                           | R           | 0x0000000    |
| 9           | W_PEND_TOWR                                        | Write pending for register GPT_TOWR<br>0x0: Overflow wrapping register write not pending<br>0x1: Overflow wrapping register write pending | R           | 0            |
|             | Reserved for instances 3, 4, 5, 6, 7, 8, 9, 11, 12 | Read returns reset value.                                                                                                                 | R           | 0            |
| 8           | W_PEND_TOCR                                        | Write pending for register GPT_TOCR<br>0x0: Overflow counter register write not pending<br>0x1: Overflow counter register write pending   | R           | 0            |
|             | Reserved for instances 3, 4, 5, 6, 7, 8, 9, 11, 12 | Read returns reset value.                                                                                                                 | R           | 0            |
| 7           | W_PEND_TCVR                                        | Write pending for register GPT_TCVR<br>0x0: Counter value register write not pending<br>0x1: Counter value register write pending         | R           | 0            |

| <b>Bits</b> | <b>Field Name</b>                                  | <b>Description</b>                                                                                                                          | <b>Type</b> | <b>Reset</b> |
|-------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
|             | Reserved for instances 3, 4, 5, 6, 7, 8, 9, 11, 12 | Read returns reset value.                                                                                                                   | R           | 0            |
| 6           | W_PEND_TNIR                                        | Write pending for register GPT_TNIR<br>0x0: Negative increment register write not pending<br>0x1: Negative increment register write pending | R           | 0            |
|             | Reserved for instances 3, 4, 5, 6, 7, 8, 9, 11, 12 | Read returns reset value.                                                                                                                   | R           | 0            |
| 5           | W_PEND_TPIR                                        | Write pending for register GPT_TPIR<br>0x0: Positive increment register write not pending<br>0x1: Positive increment register write pending | R           | 0            |
|             | Reserved for instances 3, 4, 5, 6, 7, 8, 9, 11, 12 | Read returns reset value.                                                                                                                   | R           | 0            |
| 4           | W_PEND_TMAR                                        | Write pending for register GPT_TMAR<br>0x0: Match register write not pending<br>0x1: Match register write pending                           | R           | 0            |
| 3           | W_PEND_TTGR                                        | Write pending for register GPT_TTGR<br>0x0: Trigger register write not pending<br>0x1: Trigger register write pending                       | R           | 0            |
| 2           | W_PEND_TLDR                                        | Write pending for register GPT_TLDR<br>0x0: Load register write not pending<br>0x1: Load register write pending                             | R           | 0            |
| 1           | W_PEND_TCRR                                        | Write pending for register GPT_TCRR<br>0x0: Counter register write not pending<br>0x1: Counter register write pending                       | R           | 0            |
| 0           | W_PEND_TCLR                                        | Write pending for register GPT_TCLR<br>0x0: Control register write not pending<br>0x1: Control register write pending                       | R           | 0            |

**Table 16-37. Register Call Summary for Register TWPS**

General-Purpose Timers

- [Write Posting Synchronization Mode: \[0\]](#)

General-Purpose Timers Register Manual

- [GP Timer Register Mapping Summary: \[1\] \[2\] \[3\]](#)

**Table 16-38. TMAR**

|                         |                                                                      |                 |          |
|-------------------------|----------------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x038                                                                |                 |          |
| <b>Physical Address</b> | 0x4831 8038                                                          | <b>Instance</b> | GPTIMER1 |
|                         | 0x4903 2038                                                          |                 | GPTIMER1 |
|                         | 0x4903 4038                                                          |                 | GPTIMER1 |
|                         | 0x4903 6038                                                          |                 | GPTIMER1 |
|                         | 0x4903 8038                                                          |                 | GPTIMER5 |
|                         | 0x4903 A038                                                          |                 | GPTIMER5 |
|                         | 0x4903 C038                                                          |                 | GPTIMER5 |
|                         | 0x4903 E038                                                          |                 | GPTIMER5 |
|                         | 0x4904 0038                                                          |                 | GPTIMER9 |
|                         | 0x4808 6038                                                          |                 | GPTIMER9 |
|                         | 0x4808 8038                                                          |                 | GPTIMER9 |
|                         | 0x4903 2038                                                          |                 | GPT2     |
|                         | 0x4903 4038                                                          |                 | GPT3     |
|                         | 0x4903 6038                                                          |                 | GPT4     |
|                         | 0x4903 8038                                                          |                 | GPT5     |
|                         | 0x4903 A038                                                          |                 | GPT6     |
|                         | 0x4903 C038                                                          |                 | GPT7     |
|                         | 0x4903 E038                                                          |                 | GPT8     |
|                         | 0x4904 0038                                                          |                 | GPT9     |
|                         | 0x4808 6038                                                          |                 | GPT10    |
|                         | 0x4808 8038                                                          |                 | GPT11    |
| <b>Description</b>      | This register holds the value to be compared with the counter value. |                 |          |
| <b>Type</b>             | RW                                                                   |                 |          |

|               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| COMPARE_VALUE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name    | Description                     | Type | Reset      |
|------|---------------|---------------------------------|------|------------|
| 31:0 | COMPARE_VALUE | The value of the match register | RW   | 0x00000000 |

**Table 16-39. Register Call Summary for Register TMAR**

## General-Purpose Timers

- Wake-Up Capability: [0]
- Compare Mode Functionality: [1] [2] [3]
- Pulse-Width Modulation: [4] [5] [6]
- Accessing GP Timer Registers: [7]
- Writing to Timer Registers: [8]
- Write Posting Synchronization Mode: [9]

## General-Purpose Timers Register Manual

- GP Timer Register Mapping Summary: [10] [11] [12]

**Table 16-40. TCAR1**

|                         |                                                                       |                 |          |
|-------------------------|-----------------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x03C                                                                 |                 |          |
| <b>Physical Address</b> | 0x4831 803C                                                           | <b>Instance</b> | GPTIMER1 |
|                         | 0x4903 203C                                                           |                 | GPTIMER1 |
|                         | 0x4903 403C                                                           |                 | GPTIMER1 |
|                         | 0x4903 603C                                                           |                 | GPTIMER1 |
|                         | 0x4903 803C                                                           |                 | GPTIMER5 |
|                         | 0x4903 A03C                                                           |                 | GPTIMER5 |
|                         | 0x4903 C03C                                                           |                 | GPTIMER5 |
|                         | 0x4903 E03C                                                           |                 | GPTIMER5 |
|                         | 0x4904 003C                                                           |                 | GPTIMER9 |
|                         | 0x4808 603C                                                           |                 | GPTIMER9 |
|                         | 0x4808 803C                                                           |                 | GPTIMER9 |
|                         | 0x4903 203C                                                           |                 | GPT2     |
|                         | 0x4903 403C                                                           |                 | GPT3     |
|                         | 0x4903 603C                                                           |                 | GPT4     |
|                         | 0x4903 803C                                                           |                 | GPT5     |
|                         | 0x4903 A03C                                                           |                 | GPT6     |
|                         | 0x4903 C03C                                                           |                 | GPT7     |
|                         | 0x4903 E03C                                                           |                 | GPT8     |
|                         | 0x4904 003C                                                           |                 | GPT9     |
|                         | 0x4808 603C                                                           |                 | GPT10    |
|                         | 0x4808 803C                                                           |                 | GPT11    |
| <b>Description</b>      | This register holds the first captured value of the counter register. |                 |          |
| <b>Type</b>             | R                                                                     |                 |          |

|                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| CAPTURE_VALUE1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name     | Description                                  | Type | Reset      |
|------|----------------|----------------------------------------------|------|------------|
| 31:0 | CAPTURE_VALUE1 | The value of first captured counter register | R    | 0x00000000 |

**Table 16-41. Register Call Summary for Register TCAR1**
**General-Purpose Timers**

- [Capture Mode Functionality: \[0\]](#) [\[1\]](#) [\[2\]](#) [\[3\]](#) [\[4\]](#) [\[5\]](#) [\[6\]](#) [\[7\]](#) [\[8\]](#)
- [Reading From Timer Counter Registers: \[9\]](#)

**General-Purpose Timers Register Manual**

- [GP Timer Register Mapping Summary: \[10\]](#) [\[11\]](#) [\[12\]](#)
- [GP Timer Register Descriptions: \[13\]](#)

**Table 16-42. TSICR**

|                         |                                                                                                                                                                                                                                                                                                                             |                 |                                                                                                                                                                                                                        |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <b>Address Offset</b>   | 0x040                                                                                                                                                                                                                                                                                                                       |                 |                                                                                                                                                                                                                        |  |
| <b>Physical Address</b> | 0x4831 8040<br>0x4903 2040<br>0x4903 4040<br>0x4903 6040<br>0x4903 8040<br>0x4903 A040<br>0x4903 C040<br>0x4903 E040<br>0x4904 0040<br>0x4808 6040<br>0x4808 8040<br><br>0x4903 2040<br>0x4903 4040<br>0x4903 6040<br>0x4903 8040<br>0x4903 A040<br>0x4903 C040<br>0x4903 E040<br>0x4904 0040<br>0x4808 6040<br>0x4808 8040 | <b>Instance</b> | GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER1<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER5<br>GPTIMER9<br>GPTIMER9<br>GPTIMER9<br><br>GPT2<br>GPT3<br>GPT4<br>GPT5<br>GPT6<br>GPT7<br>GPT8<br>GPT9<br>GPT10<br>GPT11 |  |
| <b>Description</b>      | This register contains the bits that control the interface between the L4 interface and functional clock domains-posted mode and functional SW reset.                                                                                                                                                                       |                 |                                                                                                                                                                                                                        |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                          |                 |                                                                                                                                                                                                                        |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                         | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | Reserved   | Reads return 0.                                                                                                                                                                                     | R    | 0x00000000 |
| 2    | POSTED     | Posted mode selection<br>0x0: Non-posted mode selected<br>0x1: Posted mode selected                                                                                                                 | RW   | 1          |
| 1    | SFT        | Reset software functional registers. This bit is automatically reset by the hardware. During reads, it always returns 0.<br>0x0: Normal functional mode<br>0x1: The functional registers are reset. | RW   | 0          |
| 0    | Reserved   | Reads return 0.                                                                                                                                                                                     | R    | 0          |

**Table 16-43. Register Call Summary for Register TSICR**

## General-Purpose Timers

- Software Reset: [0] [1]
- Accessing GP Timer Registers: [2]
- Writing to Timer Registers: [3]
- Write Posting Synchronization Mode: [4]
- Write Nonposting Synchronization Mode: [5]

## General-Purpose Timers Register Manual

- GP Timer Register Mapping Summary: [6] [7] [8]

**Table 16-44. TCAR2**

|                         |                                                                        |                 |          |
|-------------------------|------------------------------------------------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x044                                                                  |                 |          |
| <b>Physical Address</b> | 0x4831 8044                                                            | <b>Instance</b> | GPTIMER1 |
|                         | 0x4903 2044                                                            |                 | GPTIMER1 |
|                         | 0x4903 4044                                                            |                 | GPTIMER1 |
|                         | 0x4903 6044                                                            |                 | GPTIMER1 |
|                         | 0x4903 8044                                                            |                 | GPTIMER5 |
|                         | 0x4903 A044                                                            |                 | GPTIMER5 |
|                         | 0x4903 C044                                                            |                 | GPTIMER5 |
|                         | 0x4903 E044                                                            |                 | GPTIMER5 |
|                         | 0x4904 0044                                                            |                 | GPTIMER9 |
|                         | 0x4808 6044                                                            |                 | GPTIMER9 |
|                         | 0x4808 8044                                                            |                 | GPTIMER9 |
|                         | 0x4903 2044                                                            |                 | GPT2     |
|                         | 0x4903 4044                                                            |                 | GPT3     |
|                         | 0x4903 6044                                                            |                 | GPT4     |
|                         | 0x4903 8044                                                            |                 | GPT5     |
|                         | 0x4903 A044                                                            |                 | GPT6     |
|                         | 0x4903 C044                                                            |                 | GPT7     |
|                         | 0x4903 E044                                                            |                 | GPT8     |
|                         | 0x4904 0044                                                            |                 | GPT9     |
|                         | 0x4808 6044                                                            |                 | GPT10    |
|                         | 0x4808 8044                                                            |                 | GPT11    |
| <b>Description</b>      | This register holds the second captured value of the counter register. |                 |          |
| <b>Type</b>             | R                                                                      |                 |          |

|                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| CAPTURE_VALUE2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name     | Description                                   | Type | Reset      |
|------|----------------|-----------------------------------------------|------|------------|
| 31:0 | CAPTURE_VALUE2 | The value of second captured counter register | R    | 0x00000000 |

**Table 16-45. Register Call Summary for Register TCAR2**
**General-Purpose Timers**

- [Capture Mode Functionality: \[0\]](#) [\[1\]](#) [\[2\]](#) [\[3\]](#) [\[4\]](#) [\[5\]](#)
- [Reading From Timer Counter Registers: \[6\]](#)

**General-Purpose Timers Register Manual**

- [GP Timer Register Mapping Summary: \[7\]](#) [\[8\]](#) [\[9\]](#)
- [GP Timer Register Descriptions: \[10\]](#)

**Table 16-46. TPIR**

|                         |                                                                                                                                                                                                                                                                                                     |                 |                                  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------------------------|
| <b>Address Offset</b>   | 0x048                                                                                                                                                                                                                                                                                               |                 |                                  |
| <b>Physical Address</b> | 0x4831 8048<br>0x4903 2048<br>0x4808 6048                                                                                                                                                                                                                                                           | <b>Instance</b> | GPTIMER1<br>GPTIMER1<br>GPTIMER9 |
|                         | 0x4903 2048                                                                                                                                                                                                                                                                                         |                 | GPT2                             |
|                         | 0x4808 6048                                                                                                                                                                                                                                                                                         |                 | GPT10                            |
| <b>Description</b>      | This register is used for 1 ms tick generation. The <b>TPIR</b> register holds the value of the positive increment. The value of this register is added with the value of the <b>TCVR</b> to define whether next value loaded in <b>TCRR</b> will be the sub-period value or the over-period value. |                 |                                  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                  |                 |                                  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| POSITIVE_INC_VALUE      |                         |                       |                 |

| Bits | Field Name         | Description                      | Type | Reset      |
|------|--------------------|----------------------------------|------|------------|
| 31:0 | POSITIVE_INC_VALUE | The value of positive increment. | RW   | 0x00000000 |

**Table 16-47. Register Call Summary for Register TPIR**

## General-Purpose Timers

- 1-ms Tick Generation (Only GPTIMER1, GPTIMER2, and GPTIMER10): [0] [1] [2] [3] [4] [5]
- Accessing GP Timer Registers: [6]
- Writing to Timer Registers: [7]
- Write Posting Synchronization Mode: [8]

## General-Purpose Timers Register Manual

- GP Timer Register Mapping Summary: [9] [10]
- GP Timer Register Descriptions: [11]

**Table 16-48. TNIR**

|                         |                                                                                                                                                                                                                                                                                                     |                 |                                  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------------------------|
| <b>Address Offset</b>   | 0x04C                                                                                                                                                                                                                                                                                               |                 |                                  |
| <b>Physical Address</b> | 0x4831 804C<br>0x4903 204C<br>0x4808 604C                                                                                                                                                                                                                                                           | <b>Instance</b> | GPTIMER1<br>GPTIMER1<br>GPTIMER9 |
|                         | 0x4903 204C                                                                                                                                                                                                                                                                                         |                 | GPT2                             |
|                         | 0x4808 604C                                                                                                                                                                                                                                                                                         |                 | GPT10                            |
| <b>Description</b>      | This register is used for 1 ms tick generation. The <b>TNIR</b> register holds the value of the negative increment. The value of this register is added with the value of the <b>TCVR</b> to define whether next value loaded in <b>TCRR</b> will be the sub-period value or the over-period value. |                 |                                  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                  |                 |                                  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| NEGATIVE_INC_VALUE      |                         |                       |                 |

| Bits | Field Name         | Description                      | Type | Reset      |
|------|--------------------|----------------------------------|------|------------|
| 31:0 | NEGATIVE_INC_VALUE | The value of negative increment. | RW   | 0x00000000 |

**Table 16-49. Register Call Summary for Register TNIR**

## General-Purpose Timers

- 1-ms Tick Generation (Only GPTIMER1, GPTIMER2, and GPTIMER10): [0] [1] [2] [3] [4] [5]
- Accessing GP Timer Registers: [6]
- Writing to Timer Registers: [7]
- Write Posting Synchronization Mode: [8]

## General-Purpose Timers Register Manual

- GP Timer Register Mapping Summary: [9] [10]
- GP Timer Register Descriptions: [11]

**Table 16-50. TCVR**

| <b>Address Offset</b>   | 0x050                                                                                                                                                                            |                           |                 |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-----------------|
| <b>Physical Address</b> | 0x4831 8050                                                                                                                                                                      | <b>Instance</b>           | GPTIMER1        |
|                         | 0x4903 2050                                                                                                                                                                      |                           | GPTIMER1        |
|                         | 0x4808 6050                                                                                                                                                                      |                           | GPTIMER9        |
|                         | 0x4903 2050                                                                                                                                                                      |                           | GPT2            |
|                         | 0x4808 6050                                                                                                                                                                      |                           | GPT10           |
| <b>Description</b>      | This register is used for 1 ms tick generation. The <b>TCVR</b> register defines whether next value loaded in <b>TCRR</b> will be the sub-period value or the over-period value. |                           |                 |
| <b>Type</b>             | RW                                                                                                                                                                               |                           |                 |
| 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 |
| COUNTER_VALUE           |                                                                                                                                                                                  |                           |                 |
| Bits                    | Field Name                                                                                                                                                                       | Description               | Type            |
| 31:0                    | COUNTER_VALUE                                                                                                                                                                    | The value of CVR counter. | RW              |
| Reset                   |                                                                                                                                                                                  |                           |                 |
| 0x00000000              |                                                                                                                                                                                  |                           |                 |

**Table 16-51. Register Call Summary for Register TCVR**

## General-Purpose Timers

- 1-ms Tick Generation (Only GPTIMER1, GPTIMER2, and GPTIMER10): [0] [1]
- Accessing GP Timer Registers: [2]
- Writing to Timer Registers: [3]
- Write Posting Synchronization Mode: [4]

## General-Purpose Timers Register Manual

- GP Timer Register Mapping Summary: [5] [6]
- GP Timer Register Descriptions: [7] [8] [9]

**Table 16-52. TOCR**

|                         |                                                                                  |                 |                                  |
|-------------------------|----------------------------------------------------------------------------------|-----------------|----------------------------------|
| <b>Address Offset</b>   | 0x054                                                                            |                 |                                  |
| <b>Physical Address</b> | 0x4831 8054<br>0x4903 2054<br>0x4808 6054                                        | <b>Instance</b> | GPTIMER1<br>GPTIMER1<br>GPTIMER9 |
|                         | 0x4903 2054                                                                      |                 | GPT2                             |
|                         | 0x4808 6054                                                                      |                 | GPT10                            |
| <b>Description</b>      | This register is used to mask the tick interrupt for a selected number of ticks. |                 |                                  |
| <b>Type</b>             | RW                                                                               |                 |                                  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | OVF_COUNTER_VALUE       |                       |                 |

| Bits  | Field Name        | Description                    | Type | Reset      |
|-------|-------------------|--------------------------------|------|------------|
| 31:24 | Reserved          | Reads return 0.                | RW   | 0x00       |
| 23:0  | OVF_COUNTER_VALUE | The number of overflow events. | RW   | 0x00000000 |

**Table 16-53. Register Call Summary for Register TOCR**

## General-Purpose Timers

- 1-ms Tick Generation (Only GPTIMER1, GPTIMER2, and GPTIMER10): [0] [1] [2] [3] [4]
- Accessing GP Timer Registers: [5]
- Writing to Timer Registers: [6]
- Write Posting Synchronization Mode: [7]

## General-Purpose Timers Register Manual

- GP Timer Register Mapping Summary: [8] [9]

**Table 16-54. TOWR**

|                         |                                                               |                 |                                  |
|-------------------------|---------------------------------------------------------------|-----------------|----------------------------------|
| <b>Address Offset</b>   | 0x058                                                         |                 |                                  |
| <b>Physical Address</b> | 0x4831 8058<br>0x4903 2058<br>0x4808 6058                     | <b>Instance</b> | GPTIMER1<br>GPTIMER1<br>GPTIMER9 |
|                         | 0x4903 2058                                                   |                 | GPT2                             |
|                         | 0x4808 6058                                                   |                 | GPT10                            |
| <b>Description</b>      | This register holds the number of masked overflow interrupts. |                 |                                  |
| <b>Type</b>             | RW                                                            |                 |                                  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| Reserved                | OVF_WRAPPING_VALUE      |                       |                 |

| Bits  | Field Name         | Description                      | Type | Reset      |
|-------|--------------------|----------------------------------|------|------------|
| 31:24 | Reserved           | Reads return 0.                  | RW   | 0x00       |
| 23:0  | OVF_WRAPPING_VALUE | The number of masked interrupts. | RW   | 0x00000000 |

**Table 16-55. Register Call Summary for Register TOWR**

## General-Purpose Timers

- 1-ms Tick Generation (Only GPTIMER1, GPTIMER2, and GPTIMER10): [0] [1] [2]
- Accessing GP Timer Registers: [3]
- Writing to Timer Registers: [4]
- Write Posting Synchronization Mode: [5]

**Table 16-55. Register Call Summary for Register TOWR (continued)**

---

General-Purpose Timers Register Manual

- [GP Timer Register Mapping Summary: \[6\] \[7\]](#)
-

## 16.4 Watchdog Timers

### 16.4.1 WDTs Overview

The device includes two instances of the 32-bit WDT: WDT2 and WDT3. [Figure 16-14](#) shows how each timer is connected in the device.

**NOTE:** WDT*i* (where *i* is the watchdog timer instance: *i* = 2 or 3) stands for the following:

- WDT2: Watchdog timer 2, also called MPU watchdog timer
- WDT3: Watchdog timer 3, also called IVA2 watchdog timer

Each WDT is an upward counter capable of generating both a pulse on the reset pin and an interrupt to the device system modules following an overflow condition. The MPU WDT serves resets to the PRCM module (its interrupt outputs are unused), and the IVA2 WDT serves watchdog interrupts to the MPU (its reset outputs are unused).

The WDTs can be accessed, loaded, and cleared by registers through the L4 interface. The MPU and IVA2 WDTs have the 32-kHz clock for their timer clock input.

The MPU WDT directly generates a warm reset condition on overflow. The IVA2 WDT generates an MPU interrupt condition on overflow, which can be used by the application software via the PRCM to indirectly trigger a reset condition (that is, to the IVA2 subsystem).

The MPU WDT connects to a single target agent port on the L4 interconnect.

**Table 16-56. WD Timers Default State for GP and EMU devices**

| Timer         | Device  |             |         |             |  |
|---------------|---------|-------------|---------|-------------|--|
|               | EMU     |             | GP      |             |  |
| MPU_WDTIMER2  | Enabled | Running     | Enabled | Running     |  |
| IVA2_WDTIMER3 | Enabled | NOT Running | Enabled | NOT Running |  |

**Figure 16-14. WDTs Block Diagram**



timers-014

#### 16.4.1.1 WDT Features

The following are the main features of the WDT controllers:

- L4 slave interface support:

- 32-bit data bus width
- 32-/16-bit access supported
- 8-bit access not supported
- 11-bit address bus width
- Burst mode not supported
- Only posted write/read internal resynchronization mode supported
- Free-running 32-bit upward counter
- Programmable divider clock source ( $2^n$  with  $n=[0:7]$ )
- On-the-fly read/write register (while counting)
- Subset programming model of the GP timer
- WDTs are reset either on power-on or after a warm reset.
- Reset or interrupt actions when a timer overflow condition occurs
- WDT generates either a reset or an interrupt in its hardware integration (WDT2, or WDT3).

### 16.4.2 WDT Integration

Figure 16-15 shows the integration of the WDT in the device.

Figure 16-15. WDT Integration



#### 16.4.2.1 Clocking, Reset, and Power-Management Scheme

##### 16.4.2.1.1 Clock Management

There are two clock domains in the WDTs:

- Functional clock domain: WDT<sub>i</sub>\_FCLK is the WDT functional clock. It is used to clock the WDT internal logic.
- Interface clock domain: WDT<sub>i</sub>\_ICLK is the WDT interface clock. It is used to synchronize the WDT L4 port to the L4 interconnect. All accesses from the interconnect are synchronous to WDT<sub>i</sub>\_ICLK.

Table 16-57 lists the source clocks for each WDT in the device. For more information on clock control and domains, see [Chapter 3, Power, Reset, and Clock Management](#).

**Table 16-57. Clock, Power, and Reset Domains for WDTs**

| Timer    | Interface Clock | Functional Clock   | Power Domain |
|----------|-----------------|--------------------|--------------|
| MPU WDT  | WKUP_L4_ICLK    | WKUP_32K_FCLK      | WKUP         |
| IVA2 WDT | PER_L4_ICLK     | PER_32K_ALWON_FCLK | PER          |

From a global system power-management perspective, when one or both of the WDT clocks is no longer required, the WDTs can be deactivated at the PRCM level in the corresponding registers. [Table 16-58](#) lists the WDT PRCM clock control bits.

**Table 16-58. WDT PRCM Clock Control Bits**

| Name      | Associated PRCM Clock Output | Enable Bit                            | Autoidle Bit                              |
|-----------|------------------------------|---------------------------------------|-------------------------------------------|
| WDT2_FCLK | WKUP_32K_FCLK                | PRCM.CM_FCLKEN_WKUP[5]<br>EN_WDT2 bit | N/A                                       |
| WDT3_FCLK | PER_32K_ALWON_FCLK           | PRCM.CM_FCLKEN_PER[12]<br>EN_WDT3 bit | N/A                                       |
| WDT2_ICLK | WKUP_L4_ICLK                 | PRCM.CM_ICLKEN_WKUP[5]<br>EN_WDT2 bit | PRCM.CM_AUTOIDLE_WKUP[5]<br>AUTO_WDT2 bit |
| WDT3_ICLK | PER_L4_ICLK                  | PRCM.CM_ICLKEN_PER[12]<br>EN_WDT3 bit | PRCM.CM_AUTOIDLE_PER[12]<br>AUTO_WDT3 bit |

**NOTE:**

- The PRCM function clock outputs are gated at the PRCM level, assuming the modules that share it have been disabled in the corresponding register. Disabling the WDTs is a necessary but not sufficient action. The clock is effectively out when all PRCM conditions are fulfilled. For the other actions to be taken, see [Chapter 3, Power, Reset, and Clock Management](#).
- The PRCM interface clock outputs are gated at the PRCM level, assuming the modules that share it have been disabled in the corresponding register. Disabling the WDTs is a necessary but not sufficient condition. The clock is effectively out when all PRCM conditions are fulfilled. For the other actions to be taken, see [Chapter 3, Power, Reset, and Clock Management](#).
- The PRCM AUTOIDLE bits are used to link/unlink the WDTs from the clock domain transitions related to the GPTI\_ICLK clocks.
- For further details about source clocks gating and domain transitions, see [Chapter 3, Power, Reset, and Clock Management](#).

At the PRCM level, when the conditions to shut off the PRCM functional or interface output clocks are met (see [Chapter 3, Power, Reset, and Clock Management](#), for details), the PRCM automatically launches a hardware handshake protocol to ensure the WDT is ready to have its clocks switched off. Namely, the PRCM module asserts an IDLE request to the WDT.

Although this handshake is a hardware function and out of software control, the way the WDT acknowledges the PRCM IDLE request is configurable through the WDTi.WD\_SYSCONFIG[4:3] IDLEMODE bit. [Table 16-59](#) lists the IDLEMODE settings and the related acknowledgement modes.

**Table 16-59. IDLEMODE Settings**

| IDLEMODE Value | Selected Mode | Description                                                                                                                                                                                                                                                                                                                                           |
|----------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00             | Force-idle    | The WDT acknowledges unconditionally the IDLE request from the PRCM module, regardless of its internal operations. This mode must be used carefully, because it does not prevent loss of data when the clock is switched off.                                                                                                                         |
| 01             | No-idle       | The WDT never acknowledges an IDLE request from the PRCM module. This mode is safe from a module point of view, because it ensures the clocks remain active; it is not efficient from a power-saving perspective, however, because it does not allow the PRCM output clock to be shut off and thus the power domain to be set to a lower power state. |

**Table 16-59. IDLEMODE Settings (continued)**

| IDLEMODE Value | Selected Mode | Description                                                                                                                                                                                                                                                |
|----------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10             | Smart-idle    | The WDT acknowledges the IDLE request, basing its decision on its internal activity. The acknowledge signal is asserted only when all pending transactions and IRQs requests are treated. This is the best approach for efficient system power management. |
| 11             | Reserved      |                                                                                                                                                                                                                                                            |

When configured in smart-idle mode, the WDT also offers an additional granularity on WDTi\_FCLK and WDTi\_ICLK gating. The WDTi.WD\_SYSCONFIG[9:8] CLOCKACTIVITY bit field is used to determine which clock will be shut down (WDTi\_FCLK, WDTi\_ICLK, neither of them, or both of them).

The CLOCKACTIVITY setting is used internally to the WDT to determine the part of the module on which the conditions to acknowledge the PRCM IDLE request will be tested. For example, if WDTi\_FCLK is not to be shut down on a PRCM IDLE request, the WDT considers only WDTi\_ICLK and the associated pending activities before acknowledging the request.

Some WDT features are associated with WDTi\_ICLK, and others are associated with WDTi\_FCLK. Using the CLOCKACTIVITY setting along with the smart-idle mode ensures that the features associated with the clock that will remain active are always enabled, even if the WDT acknowledges an IDLE request.

Table 16-60 lists the CLOCKACTIVITY settings.

**Table 16-60. CLOCKACTIVITY Settings**

| CLOCKACTIVITY Value | WDTi_ICLK Effects | WDTi_FCLK Effects | Description                                                                                                                                                                         |
|---------------------|-------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00                  | OFF               | OFF               | Both WDTi_ICLK and WDTi_FCLK are considered for generating the acknowledge. This setting also means both WDTi_FCLK and WDTi_ICLK are likely to be shut down on a PRCM IDLE request. |
| 01                  | OFF               | ON                | WDTi_FCLK is not shut down on a PRCM IDLE request; only WDTi_ICLK is concerned.                                                                                                     |
| 10                  | ON                | OFF               | WDTi_ICLK is not shut down on a PRCM IDLE request; only WDTi_FCLK is concerned.                                                                                                     |
| 11                  | ON                | ON                | None of the clocks are shut down. Therefore, the WDT can potentially acknowledge the IDLE request without checking the internal functionalities linked to its clocks.               |

### CAUTION

The PRCM module does *not* have any hardware means to read the CLOCKACTIVITY settings. The software must ensure consistent programming between the WDT CLOCKACTIVITY and the PRCM functional clock and interface clock control bits. If the WDT is disabled in both the CM\_FCLKEN and CM\_ICLKEN PRCM registers while CLOCKACTIVITY is set to 11, nothing prevents the PRCM module from asserting its IDLE request, which is acknowledged regardless of the features associated with the WDT clocks. This can lead to unpredictable behavior.

#### 16.4.2.1.2 Reset and Power Management

The MPU WDT (WDT2) belong to the WKUP power domain. As part of that domain, this WDT is sensitive to a WKUP\_RST signal issued by the PRCM module. For further details about the WKUP power domain implementation and WKUP\_RST signal, see [Chapter 3, Power, Reset, and Clock Management](#).

The IVA WDT (WDT3) belongs to the PER power domain. As part of that domain, WDT3 is sensitive to the PER\_RST signal issued by the PRCM module. For further details about the PER power domain implementation and PER\_RST signal, see [Chapter 3, Power, Reset, and Clock Management](#).

**NOTE:** WDT2 is reset on power-on or after a warm reset, and then it starts counting.

WDT3 is reset either on power-on or after a warm reset, and then it doesn't start counting.

### 16.4.2.2 Interrupts

Table 16-61 shows interrupt mapping from the three WDTs to the MPU.

**Table 16-61. WDT Interrupt Names and Processor IRQ Mapping**

| Timer    | Interrupt Name | Mapping       | Comments          |
|----------|----------------|---------------|-------------------|
| MPU WDT  | WDT2_IRQ       | Not connected |                   |
| IVA2 WDT | WDT3_IRQ       | M_IRQ_36      | IVA2 WDT overflow |

### 16.4.3 WDTs Functional Description

#### 16.4.3.1 General WDT Operation

The WDTs are based on an upward 32-bit counter coupled with a prescaler. The counter overflow is signaled through two independent signals: a simple reset signal and an interrupt signal, both active low. The use of these signals depends on whether they are connected or not. For this information, see Figure 16-14. The interrupt generation mechanism is controlled through the WDTi.WIER and WDTi.WISR registers.

The prescaler ratio can be set between 1 and 128 by accessing the WDTi.WCLR[4:2] PTV and WDTi.WCLR[5] PRE fields of the watchdog control register (WDTi.WCLR).

The current timer value can be accessed on-the-fly by reading the WDT counter register (WDTi.WCRR), modified by accessing the WDT load register (WDTi.WLDR) (no on-the-fly update), or reloaded by following a specific reload sequence on the WDT trigger register (WDTi.WTGR). A start/stop sequence applied to the WDT start/stop register (WDTi.WSPR) can start and stop the WDT.

**Figure 16-16. 32-Bit WDT Functional Block Diagram**



timers-016

#### 16.4.3.2 Reset Context

After reset, the WDTs are enabled. Table 16-62 lists the default reset values of the three WDT load registers (WDTi.WLDR) and prescaler ratios (WDTi.WCLR[4:2] PTV field). To get these values, software must read the corresponding WDTi.WCLR[4:2] PTV fields and the 32-bit register to retrieve the static configuration of the module.

**Table 16-62. Count and Prescaler Default Reset Values**

| Timer             | WLDR Reset Value | PTV Reset Value |
|-------------------|------------------|-----------------|
| DEVICE WDT (WDT2) | 0xFFFFB 0000     | 0               |
| IVA2 WDT (WDT3)   | 0xFFFFB 0000     | 0               |

#### 16.4.3.3 Overflow/Reset Generation

When the WDT counter register (WDTi.WCRR) overflows, an active-low reset pulse is generated to the PRCM module. This pulse is one prescaled timer clock cycle wide and occurs at the same time as the timer counter overflow.

After reset generation, the counter is automatically reloaded with the value stored in the watchdog load register (WDTi.WLDR) and the prescaler is reset (the prescaler ratio remains unchanged). Then, after the reset pulse output has been generated, the timer counter begins incrementing again.

Figure 16-17 shows a general functional view of the WDT.

**Figure 16-17. WDT General Functional View**

timers-017

#### 16.4.3.4 Prescaler Value/Timer Reset Frequency

Each WDT is composed of a prescaler stage and a timer counter.

The timer rate is defined by the following values:

- Value of the prescaler fields (the WDTi.WCLR[5] PRE bit and the WDTi.WCLR[4:2] PTV field)
- Value loaded into the timer load register (WDTi.WLDR)

The prescaler stage is clocked with the timer clock and acts as a clock divider for the timer counter stage. The ratio is managed by accessing the ratio definition field (the WDTi.WCLR[4:2] PTV field) and is enabled with the WDTi.WCLR[5] PRE bit.

Table 16-63 lists the prescaler clock ratio values.

**Table 16-63. Prescaler Clock Ratios**

| PRE Bit (in WDTi.WCLR Register) | PTV Bits (in WDTi.WCLR Register) | Clock Divider (PS) |
|---------------------------------|----------------------------------|--------------------|
| 0                               | X                                | 1                  |
| 1                               | 0                                | 1                  |
| 1                               | 1                                | 2                  |
| 1                               | 2                                | 4                  |
| 1                               | 3                                | 8                  |
| 1                               | 4                                | 16                 |
| 1                               | 5                                | 32                 |
| 1                               | 6                                | 64                 |
| 1                               | 7                                | 128                |

The watchdog timer overflow rate is expressed by:  $OVF\_Rate = (0xFFFF FFFF - WDTn.WLDR + 1) * (wd-functional clock period) * PS$

With wd-functional clock period =  $1 / (\text{wd-functional clock frequency})$  and  $PS = 2^{(\text{PTV})}$ .

### CAUTION

Internal resynchronization causes any software write to GPTn.WSPR to have some latency before WSPR is updated with the programmed value:

$1.5 * \text{functional clock cycles} \leq \text{write\_WSPR\_latency} \leq 2.5 * \text{functional clock cycles}$

Remember to take this latency into account whenever the watchdog must be started or stopped.

For example, for a timer clock input of 32 kHz with a prescaler ratio value of 0x1 (clock divided by 2) and WDTi.WCLR[5] PRE bit = 1 (clock divider enabled), the reset period is as listed in [Table 16-64](#).

**Table 16-64. Reset Period Examples**

| WDTi.WLDR Value | Reset Period |
|-----------------|--------------|
| 0x0000 0000     | 74 h 56 min  |
| 0xFFFF 0000     | 4 s          |
| 0xFFFF FFF0     | 1 ms         |
| 0xFFFF FFFF     | 62.5 us      |

### CAUTION

- Ensure that the reloaded value allows the correct operation of the application. When a WDT is enabled, the software must periodically trigger a reload before the counter overflows. Hence, the WDTi.WLDR[31:0] value must be chosen according to the ongoing activity preceding the watchdog reload.
- Due to design reasons, WDTi.WLDR[31:0] = 0xFFFF FFFF is a special case, although such a WDTi.WLDR value is meaningless. When WDTi.WLDR is programmed with the overflow value, a triggering event generates a reset/interrupt one functional clock cycle later, even if the WDT is stopped.

[Table 16-65](#) lists the default reset periods for the WDTs.

**Table 16-65. Default WDT Time Periods**

| WDTs             | Clock Source | Default Reset Period |
|------------------|--------------|----------------------|
| DEVICE/IVA2 WDTs | 32 kHz       | 10 s                 |

#### 16.4.3.5 Triggering a Timer Reload

To reload the timer counter and reset the prescaler before reaching overflow, a reload command is executed by accessing the WDT trigger register (WDTi.WTGR) using a specific reload sequence.

The specific reload sequence is performed whenever the written value on the WDT trigger register (WDTi.WTGR) differs from its previous value. In this case, reload is executed in the same way as an overflow autoreload, but without a reset pulse generation.

The timer counter is loaded with the WDT load register value (the WDTi.WLDR[31:0] TIMER\_LOAD field), and the prescaler is reset.

#### 16.4.3.6 Start/Stop Sequence for WDTs (Using WDTi.WSPR Register)

To start/stop a WDT, access must be made through the start/stop register (WDTi.WSPR) using a specific sequence.

To disable the timer, follow this sequence:

1. Write 0xXXXX AAAA in WDTi.WSPR.
2. Write 0xXXXX 5555 in WDTi.WSPR.

To enable the timer, follow this sequence:

1. Write 0xXXXX BBBB in WDTi.WSPR.
2. Write 0xXXXX 4444 in WDTi.WSPR.

All other write sequences on WDTi.WSPR have no effect on the start/stop feature of the module.

#### 16.4.3.7 Modifying Timer Count/Load Values and Prescaler Setting

To modify the timer counter value (WDTi.WCRR), prescaler ratio (the WDTi.WCLR[4:2] PTV field), or load value (the WDTi.WLDR[31:0] TIMER\_LOAD field), the WDT must be disabled by using the start/stop sequence (the WDTi.WSPR register).

After a write access, the load register value and prescaler ratio registers are updated immediately, but new values are considered only after the next consecutive counter overflow or after a new trigger command (WDTi.WTGR).

#### 16.4.3.8 Watchdog Counter Register Access Restriction (WDTi.WCRR Register)

Because the WDTi.WCRR register is directly related to the timer counter value and is updated on the timer clock (WDTi\_FCLK), a 32-bit shadow register is implemented to read a coherent value of the WDTi.WCRR register. The shadow register is updated by a 16-bit LSB read command.

---

**NOTE:** Although the L4 clock (WDTi\_ICLK) is completely asynchronous with the timer clock (WDTi\_FCLK), some synchronization is done to ensure that the WDTi.WCRR value is not read while it is being incremented.

---

When 32-bit read access is performed, the shadow register is not updated. Read access is made directly from the accessed register.

To ensure that a coherent value is read inside WDTi.WCRR, the first read access is to the lower 16 bits (offset = 0x08), followed by read access to the upper 16 bits (offset = 0x0A).

#### 16.4.3.9 WDT Interrupt Generation

The WDT issues an overflow interrupt if this interrupt is enabled in the WDT interrupt enable register (WDTi.WIER[0] OVF\_IT\_ENA = 1). When the overflow occurs, the interrupt status bit (the WDTi.WISR[0] OVF\_IT\_FLAG bit) is set to 1. The output interrupt line (WDTi\_IRQ) is asserted (active low) when both status (OVF\_IT\_FLAG) and enable (OVF\_IT\_ENA) flags are set to 1; the order is not relevant. Writing 1 in the enable bit (the status is already set at 1) also triggers the interrupt in the normal order (enable first, status after). The pending interrupt event is cleared when the set status bit is overwritten by a value of 1 by a write command in the WDTi.WISR register. Reading the WDTi.WISR register and writing the value back allows a fast acknowledge interrupt process.

---

**NOTE:** Writing 0 in the WDTi.WISR[0] OVF\_IT\_FLAG bit has no effect on it.

---

Because the interrupt event is generated on the functional clock domain (WDTi\_FCLK), during the interrupt status register (WDTi.WISR) update, the two clock domains are resynchronized.

#### 16.4.3.10 WDT Under Emulation

During emulation mode, the WDT can/cannot continue running, according on the value of the WDTi.WD\_SYSCONFIG[5] EMUFREE bit of the system configuration register (WDTi.WD\_SYSCONFIG).

- When EMUFREE is 1, WDT execution is not stopped and a reset pulse is still generated when overflow is reached.
- When EMUFREE is 0, the counters (prescaler/timer) are frozen and incrementation restarts after exiting from emulation mode.

#### 16.4.3.11 Accessing Watchdog Timer Registers

Posted mode applies only to functional registers that require synchronization on/from the timer functional clock domain (WDTi\_FCLK). For a write/read operation, the following registers are affected:

- WDT\_WCLR
- WDT\_WCRR
- WDT\_WLDR
- WDT\_WTGR
- WDT\_WDLY
- WDT\_WSPR

---

**NOTE:** To ensure completion of successive writes in a WDT2 / WDT3 functional clock domain register, user software must poll the appropriate WDT\_WWPS status bit.

---



---

**NOTE:** To ensure coherent reading when a read transaction immediately follows a write access to a WDT2/WDT3 functional clock domain register, user software must check the appropriate WDT\_WWPS status bit.

---

The synchronous registers in the timer interface clock domain are not affected by the posted mode mechanism; the write/read operation is effective and acknowledged (command accepted) after one WDT\_ICLK cycle from the command assertion. The synchronous registers in the timer interface clock domain are:

- WDT\_WIDR
- WDT\_WDSC
- WDT\_WDST
- WDT\_WIRQSTATRAW
- WDT\_WIRQSTAT
- WDT\_WIRQENSET
- WDT\_WIRQENCLR
- WDT\_WIRQWAKEEN
- WDT\_WWPS

---

**NOTE:** Accesses to the synchronous registers in the WDT2 and WDT3 functional clock domain are posted.

---

## 16.5 Watchdog Timer Register Manual

All registers are 32 bits wide and are accessible through the L4 interface with 16-bit or 32-bit access (read/write).

### 16.5.1 Instance Summary

Table 16-66 lists the base address and address space for the WDT module instances. All timers are memory mapped to the L4 peripheral bus memory space.

**Table 16-66. WDT Instance Summary**

| Module Name | Base Address | Size |
|-------------|--------------|------|
| WDTIMER2    | 0x4831 4000  | 4KB  |
| WDTIMER3    | 0x4903 0000  | 4KB  |

### 16.5.2 WDT Register Mapping Summary

**CAUTION**

The WDT registers are limited to 32-bit and 16-bit data accesses; 8-bit access is not allowed and can corrupt register content.

Table 16-67 lists the WDT2 registers and Table 16-68 lists the WDT3 registers.

**Table 16-67. WDTIMER2 Register Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | WDTIMER2 Physical Address |
|---------------|------|-----------------------|----------------|---------------------------|
| WIDR          | R    | 32                    | 0x000          | 0x4831 4000               |
| WD_SYSCONFIG  | RW   | 32                    | 0x010          | 0x4831 4010               |
| WD_SYSSTATUS  | R    | 32                    | 0x014          | 0x4831 4014               |
| WISR          | RW   | 32                    | 0x018          | 0x4831 4018               |
| WIER          | RW   | 32                    | 0x01C          | 0x4831 401C               |
| WCRL          | RW   | 32                    | 0x024          | 0x4831 4024               |
| WCRR          | RW   | 32                    | 0x028          | 0x4831 4028               |
| WLDR          | RW   | 32                    | 0x02C          | 0x4831 402C               |
| WTGR          | RW   | 32                    | 0x030          | 0x4831 4030               |
| WWPS          | R    | 32                    | 0x034          | 0x4831 4034               |
| WSPR          | RW   | 32                    | 0x048          | 0x4831 4048               |

**Table 16-68. WDTIMER3 Register Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | WDTIMER3 Physical Address |
|---------------|------|-----------------------|----------------|---------------------------|
| WIDR          | R    | 32                    | 0x000          | 0x4903 0000               |
| WD_SYSCONFIG  | RW   | 32                    | 0x010          | 0x4903 0010               |
| WD_SYSSTATUS  | R    | 32                    | 0x014          | 0x4903 0014               |
| WISR          | RW   | 32                    | 0x018          | 0x4903 0018               |
| WIER          | RW   | 32                    | 0x01C          | 0x4903 001C               |
| WCRL          | RW   | 32                    | 0x024          | 0x4903 0024               |
| WCRR          | RW   | 32                    | 0x028          | 0x4903 0028               |
| WLDR          | RW   | 32                    | 0x02C          | 0x4903 002C               |
| WTGR          | RW   | 32                    | 0x030          | 0x4903 0030               |

**Table 16-68. WDTIMER3 Register Summary (continued)**

| Register Name | Type | Register Width (Bits) | Address Offset | WDTIMER3 Physical Address |
|---------------|------|-----------------------|----------------|---------------------------|
| WWPS          | R    | 32                    | 0x034          | 0x4903 0034               |
| WSPR          | RW   | 32                    | 0x048          | 0x4903 0048               |

**16.5.3 WDT Register Descriptions**

Table 16-69 through Table 16-89 describe the WDT register bits.

**Table 16-69. WIDR**

|                  |                                              |          |                      |
|------------------|----------------------------------------------|----------|----------------------|
| Address Offset   | 0x000                                        |          |                      |
| Physical Address | 0x4831 4000<br>0x4903 0000                   | Instance | WDTIMER2<br>WDTIMER3 |
|                  | 0x4903 0000                                  |          | WDTIMER3             |
| Description      | This register contains the IP revision code. |          |                      |
| Type             | R                                            |          |                      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |        |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | WD_REV |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                         | Type | Reset              |
|------|------------|-----------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | Reserved   | Reads return 0.                                                                                     | R    | 0x000000           |
| 7:0  | WD_REV     | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision<br>Examples: 0x10 for 1.0, 0x21 for 2.1 | R    | See <sup>(1)</sup> |
|      |            |                                                                                                     |      |                    |

<sup>(1)</sup> TI internal data

**Table 16-70. Register Call Summary for Register WIDR**

- Watchdog Timer Register Manual
  - [WDT Register Mapping Summary: \[0\] \[1\]](#)

**Table 16-71. WD\_SYSCONFIG**

|                  |                                                                    |          |                      |
|------------------|--------------------------------------------------------------------|----------|----------------------|
| Address Offset   | 0x010                                                              |          |                      |
| Physical Address | 0x4831 4010<br>0x4903 0010                                         | Instance | WDTIMER2<br>WDTIMER3 |
|                  | 0x4903 0010                                                        |          | WDTIMER3             |
| Description      | This register controls the various parameters of the L4 interface. |          |                      |
| Type             | RW                                                                 |          |                      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |               |          |         |          |           |           |          |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------------|----------|---------|----------|-----------|-----------|----------|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CLOCKACTIVITY | Reserved | EMUFREE | IDLEMODE | ENAWAKEUP | SOFTRESET | AUTOIDLE |   |
|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |               |          |         |          |           |           |          |   |

| Bits  | Field Name    | Description                                                                                                                                                                                                                                               | Type | Reset      |
|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:10 | Reserved      | Write 0s for future compatibility. Reads return 0.                                                                                                                                                                                                        | R    | 0x00000000 |
| 9:8   | CLOCKACTIVITY | Clock Activity selection bits.<br><br>0x0: Both clocks can be cut off<br>0x1: Only L4 clock must be kept active; timer clock can be cut off<br>0x2: Only timer clock must be kept active; L4 clock can be cut off<br>0x3: both clocks must be kept active | RW   | 0x0        |
| 7:6   | Reserved      | Write 0s for future compatibility. Reads return 0.                                                                                                                                                                                                        | R    | 0x00000000 |
| 5     | EMUFREE       | Emulation mode<br><br>0x0: Timer counter frozen in emulation<br>0x1: Timer counter free-running in emulation                                                                                                                                              | RW   | 0          |
| 4:3   | IDLEMODE      | Idle mode selection bits<br><br>0x0: Force Idle mode<br>0x1: No Idle mode<br>0x2: Smart Idle mode<br>0x3: Reserved                                                                                                                                        | RW   | 0x0        |
| 2     | ENAWAKEUP     | Enable wakeup control bit<br><br>0x0: Wakeup mechanism is disabled<br>0x1: Wakeup mechanism is enabled                                                                                                                                                    | RW   | 0          |
| 1     | SOFTRESET     | Software reset. This bit is automatically reset by the hardware. During reads, it always return 0.<br><br>0x0: Normal mode<br>0x1: The module is reset.                                                                                                   | RW   | 0          |
| 0     | AUTOIDLE      | L4 interconnect clock gating strategy<br><br>0x0: L4 interface clock is free-running.<br>0x1: Automatic L4 interface clock gating strategy is applied, based on the L4 interface activity.                                                                | RW   | 0          |

**Table 16-72. Register Call Summary for Register WD\_SYSCONFIG**

## Watchdog Timers

- [Clock Management: \[0\]](#) [\[1\]](#)
- [WDT Under Emulation: \[2\]](#) [\[3\]](#)

## Watchdog Timer Register Manual

- [WDT Register Mapping Summary: \[4\]](#) [\[5\]](#)

**Table 16-73. WD\_SYSSTATUS**

|                         |                                                                                                         |                         |                            |                 |                       |
|-------------------------|---------------------------------------------------------------------------------------------------------|-------------------------|----------------------------|-----------------|-----------------------|
| <b>Address Offset</b>   | 0x014                                                                                                   | <b>Physical Address</b> | 0x4831 4014<br>0x4903 0014 | <b>Instance</b> | WDTIMER2<br>WDTIMER3  |
| <b>Description</b>      | This register provides status information about the module, excluding the interrupt status information. |                         |                            |                 |                       |
| <b>Type</b>             | R                                                                                                       |                         |                            |                 |                       |
| 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            | Reserved        | Reserved<br>RESETDONE |

## Watchdog Timer Register Manual

www.ti.com

| Bits | Field Name | Description                                                     | Type | Reset      |
|------|------------|-----------------------------------------------------------------|------|------------|
| 31:8 | Reserved   | Reads return 0.                                                 | R    | 0x00000000 |
| 7:1  | Reserved   | Reads return 0.                                                 | R    | 0x00       |
| 0    | RESETDONE  | Internal reset monitoring                                       | R    | -          |
|      |            | 0x0: Internal module reset in ongoing.<br>0x1: Reset completed. |      |            |

**Table 16-74. Register Call Summary for Register WD\_SYSSTATUS**

Watchdog Timer Register Manual

- [WDT Register Mapping Summary: \[0\] \[1\]](#)

**Table 16-75. WISR**

|                         |                                                                           |                       |                 |             |
|-------------------------|---------------------------------------------------------------------------|-----------------------|-----------------|-------------|
| Address Offset          | 0x018                                                                     |                       |                 |             |
| Physical Address        | 0x4831 4018                                                               | Instance              | WDTIMER2        |             |
|                         | 0x4903 0018                                                               |                       | WDTIMER3        |             |
|                         | 0x4903 0014                                                               |                       | WDTIMER3        |             |
| Description             | This register shows which interrupt events are pending inside the module. |                       |                 |             |
| Type                    | RW                                                                        |                       |                 |             |
| 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 |             |
| Reserved                |                                                                           |                       |                 | OVF_IT_FLAG |

| Bits | Field Name  | Description                                                                                                                                     | Type | Reset      |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved    | Reads return 0.                                                                                                                                 | R    | 0x00000000 |
| 0    | OVF_IT_FLAG | Pending overflow interrupt status                                                                                                               | RW   | 0          |
|      |             | Read 0x0: No overflow interrupt pending<br>Write 0x0: Status unchanged<br>Read 0x1: Overflow interrupt pending<br>Write 0x1: Status bit cleared |      |            |

**Table 16-76. Register Call Summary for Register WISR**

Watchdog Timers

- [General WDT Operation: \[0\]](#)
- [WDT Interrupt Generation: \[1\] \[2\] \[3\] \[4\] \[5\]](#)

Watchdog Timer Register Manual

- [WDT Register Mapping Summary: \[6\] \[7\]](#)

**Table 16-77. WIER**

|                         |                                                                     |                       |                      |            |
|-------------------------|---------------------------------------------------------------------|-----------------------|----------------------|------------|
| <b>Address Offset</b>   | 0x01C                                                               |                       |                      |            |
| <b>Physical Address</b> | 0x4831 401C<br>0x4903 001C                                          | <b>Instance</b>       | WDTIMER2<br>WDTIMER3 |            |
|                         | 0x4903 0014                                                         |                       | WDTIMER3             |            |
| <b>Description</b>      | This register shows controls (enable/disable) the interrupt events. |                       |                      |            |
| <b>Type</b>             | RW                                                                  |                       |                      |            |
| 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      |            |
| Reserved                |                                                                     |                       |                      | OVF_IT_ENA |

| Bits | Field Name | Description                                                                                              | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Reads return 0.                                                                                          | R    | 0x00000000 |
| 0    | OVF_IT_ENA | Enable overflow interrupt<br><br>0x0: Disable overflow interrupt.<br><br>0x1: Enable overflow interrupt. | RW   | 0          |
|      |            |                                                                                                          |      |            |

**Table 16-78. Register Call Summary for Register WIER**

## Watchdog Timers

- General WDT Operation: [0]
- WDT Interrupt Generation: [1]

## Watchdog Timer Register Manual

- WDT Register Mapping Summary: [2] [3]

**Table 16-79. WCLR**

|                         |                                                            |                       |                      |                  |
|-------------------------|------------------------------------------------------------|-----------------------|----------------------|------------------|
| <b>Address Offset</b>   | 0x024                                                      |                       |                      |                  |
| <b>Physical Address</b> | 0x4831 4024<br>0x4903 0024                                 | <b>Instance</b>       | WDTIMER2<br>WDTIMER3 |                  |
|                         | 0x4903 0024                                                |                       | WDTIMER3             |                  |
| <b>Description</b>      | This register controls the prescaler stage of the counter. |                       |                      |                  |
| <b>Type</b>             | RW                                                         |                       |                      |                  |
| 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      |                  |
| Reserved                |                                                            |                       |                      | PRE PTV Reserved |

| Bits | Field Name | Description                                                                                                                                                                              | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:6 | Reserved   | Reads return 0.                                                                                                                                                                          | R    | 0x00000000 |
| 5    | PRE        | Prescaler enable<br><br>0x0: Prescaler disabled<br><br>0x1: Prescaler enabled                                                                                                            | RW   | 1          |
| 4:2  | PTV        | Prescaler value: The timer counter is prescaled with the value:<br>$\text{pow}(2, \text{PTV})$<br>Example: PTV = 2: counter increases value is started after 4 functional clock periods. | RW   | 0x0        |
| 1:0  | Reserved   | Reads return 0.                                                                                                                                                                          | R    | 0x0        |

**Table 16-80. Register Call Summary for Register WCLR**

## Watchdog Timers

- General WDT Operation: [0] [1] [2]
- Reset Context: [3] [4]
- Prescaler Value/Timer Reset Frequency: [5] [6] [7] [8] [9] [10] [11]
- Modifying Timer Count/Load Values and Prescaler Setting: [12]

## Watchdog Timer Register Manual

- WDT Register Mapping Summary: [13] [14]
- WDT Register Descriptions: [15]

**Table 16-81. WCRR**

|                         |                                                        |                 |                                  |
|-------------------------|--------------------------------------------------------|-----------------|----------------------------------|
| <b>Address Offset</b>   | 0x028                                                  | <b>Instance</b> | WDTIMER2<br>WDTIMER3<br>WDTIMER3 |
| <b>Physical Address</b> | 0x4831 4028<br>0x4903 0028                             |                 |                                  |
|                         | 0x4903 0028                                            |                 |                                  |
| <b>Description</b>      | This register holds the value of the internal counter. |                 |                                  |
| <b>Type</b>             | RW                                                     |                 |                                  |

|               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| TIMER_COUNTER |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                      | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------|-------------|--------------|
| 31:0        | TIMER_COUNTER     | The value of the timer counter register | RW          | 0x00000000   |

**Table 16-82. Register Call Summary for Register WCRR**

## Watchdog Timers

- General WDT Operation: [0]
- Overflow/Reset Generation: [1]
- Modifying Timer Count/Load Values and Prescaler Setting: [2]
- Watchdog Counter Register Access Restriction (WDTi.WCRR Register): [3] [4] [5] [6]

## Watchdog Timer Register Manual

- WDT Register Mapping Summary: [7] [8]
- WDT Register Descriptions: [9]

**Table 16-83. WLDR**

|                         |                                           |                 |                                  |
|-------------------------|-------------------------------------------|-----------------|----------------------------------|
| <b>Address Offset</b>   | 0x02C                                     | <b>Instance</b> | WDTIMER2<br>WDTIMER3<br>WDTIMER3 |
| <b>Physical Address</b> | 0x4831 402C<br>0x4903 002C                |                 |                                  |
|                         | 0x4903 002C                               |                 |                                  |
| <b>Description</b>      | This register holds the timer load value. |                 |                                  |
| <b>Type</b>             | RW                                        |                 |                                  |

|            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| TIMER_LOAD |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                   | <b>Type</b> | <b>Reset</b>                                   |
|-------------|-------------------|--------------------------------------|-------------|------------------------------------------------|
| 31:0        | TIMER_LOAD        | The value of the timer load register | RW          | 0xFFA6 0000 (WDT1)<br>0xFFFFB 000 (WDT2 and 3) |

**Table 16-84. Register Call Summary for Register WLDR**

## Watchdog Timers

- General WDT Operation: [0]
- Reset Context: [1] [2]
- Overflow/Reset Generation: [3]
- Prescaler Value/Timer Reset Frequency: [4] [5] [6] [7] [8] [9] [10]
- Triggering a Timer Reload: [11]
- Modifying Timer Count/Load Values and Prescaler Setting: [12]

## Watchdog Timer Register Manual

- WDT Register Mapping Summary: [13] [14]
- WDT Register Descriptions: [15]

**Table 16-85. WTGR**

| <b>Address Offset</b>   | 0x030                                                                                                     |                                   |                      |            |
|-------------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------|----------------------|------------|
| <b>Physical Address</b> | 0x4831 4030<br>0x4903 0030                                                                                | <b>Instance</b>                   | WDTIMER2<br>WDTIMER3 |            |
|                         | 0x4903 0030                                                                                               |                                   | WDTIMER3             |            |
| <b>Description</b>      | Writing a different value than the one already written in this register causes a watchdog counter reload. |                                   |                      |            |
| <b>Type</b>             | RW                                                                                                        |                                   |                      |            |
| 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      |            |
| TTGR_VALUE              |                                                                                                           |                                   |                      |            |
| Bits                    | Field Name                                                                                                | Description                       | Type                 | Reset      |
| 31:0                    | TTGR_VALUE                                                                                                | The value of the trigger register | RW                   | 0x00000000 |

**Table 16-86. Register Call Summary for Register WTGR**

## Watchdog Timers

- General WDT Operation: [0]
- Triggering a Timer Reload: [1] [2]
- Modifying Timer Count/Load Values and Prescaler Setting: [3]

## Watchdog Timer Register Manual

- WDT Register Mapping Summary: [4] [5]
- WDT Register Descriptions: [6]

**Table 16-87. WWPS**

|                         |                                                                                       |                       |                      |  |
|-------------------------|---------------------------------------------------------------------------------------|-----------------------|----------------------|--|
| <b>Address Offset</b>   | 0x034                                                                                 |                       |                      |  |
| <b>Physical Address</b> | 0x4831 4034<br>0x4903 0034                                                            | <b>Instance</b>       | WDTIMER2<br>WDTIMER3 |  |
|                         | 0x4903 0034                                                                           |                       | WDTIMER3             |  |
| <b>Description</b>      | This register contains the write posting bits for all writeable functional registers. |                       |                      |  |
| <b>Type</b>             | R                                                                                     |                       |                      |  |
| 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      |  |
| Reserved                |                                                                                       |                       |                      |  |
|                         |                                                                                       |                       | W_PEND_WPSR          |  |
|                         |                                                                                       |                       | W_PEND_WTGR          |  |
|                         |                                                                                       |                       | W_PEND_WLDR          |  |
|                         |                                                                                       |                       | W_PEND_WCRR          |  |
|                         |                                                                                       |                       | W_PEND_WCLR          |  |

| Bits | Field Name  | Description                                                                                                                            | Type | Reset |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:5 | Reserved    | Reads return 0                                                                                                                         | R    | 0x0   |
| 4    | W_PEND_WSPR | Write pending for register <a href="#">WSPR</a><br>0x0: No Start-Stop Register write pending<br>0x1: Start-Stop Register write pending | R    | 0     |
| 3    | W_PEND_WTGR | Write pending for register <a href="#">WTGR</a><br>0x0: No Trigger Register write pending<br>0x1: Trigger Register write pending       | R    | 0     |
| 2    | W_PEND_WLDR | Write pending for register <a href="#">WLDR</a><br>0x0: No Load Register write pending<br>0x1: Load Register write pending             | R    | 0     |
| 1    | W_PEND_WCRR | Write pending for register <a href="#">WCRR</a><br>0x0: No Counter Register write pending<br>0x1: Counter Register write pending       | R    | 0     |
| 0    | W_PEND_WCLR | Write pending for register <a href="#">WCLR</a><br>0x0: No Control Register write pending<br>0x1: Control Register write pending       | R    | 0     |

**Table 16-88. Register Call Summary for Register WWPS**

Watchdog Timer Register Manual

- [WDT Register Mapping Summary: \[0\] \[1\]](#)

**Table 16-89. WSPR**

|                         |                                                                                     |                       |                      |
|-------------------------|-------------------------------------------------------------------------------------|-----------------------|----------------------|
| <b>Address Offset</b>   | 0x048                                                                               |                       |                      |
| <b>Physical Address</b> | 0x4831 4048<br>0x4903 0048                                                          | <b>Instance</b>       | WDTIMER2<br>WDTIMER3 |
|                         | 0x4903 0048                                                                         |                       | WDTIMER3             |
| <b>Description</b>      | This register holds the start-stop value that controls the internal start-stop FSM. |                       |                      |
| <b>Type</b>             | RW                                                                                  |                       |                      |
| 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      |
| WSPR_VALUE              |                                                                                     |                       |                      |

| Bits | Field Name | Description                          | Type | Reset      |
|------|------------|--------------------------------------|------|------------|
| 31:0 | WSPR_VALUE | The value of the start/stop register | RW   | 0x00000000 |

**Table 16-90. Register Call Summary for Register WSPR**

Watchdog Timers

- [General WDT Operation: \[0\]](#)
- [Prescaler Value/Timer Reset Frequency: \[1\] \[2\]](#)
- [Start/Stop Sequence for WDTs \(Using WDTi.WSPR Register\): \[3\] \[4\] \[5\] \[6\] \[7\] \[8\]](#)
- [Modifying Timer Count/Load Values and Prescaler Setting: \[9\]](#)

Watchdog Timer Register Manual

- [WDT Register Mapping Summary: \[10\] \[11\]](#)
- [WDT Register Descriptions: \[12\]](#)

## 16.6 32-kHz Synchronized Timer

### 16.6.1 32-kHz Sync Timer Functional Description

The 32-kHz sync timer is a 32-bit counter, clocked by the falling edge of the 32-kHz system clock. It is reset while the external asynchronous power-up reset (sys\_nrespwron) primary I/O is active (main device reset). When sys\_nrespwron is released (on the rising edge of sys\_nrespwron), after three 32-kHz clock periods, the counter starts counting up from the reset value of the counter register on the falling edge of the 32-kHz system clock. After reaching its highest value, the counter wraps back to 0 and starts counting again. [Figure 16-18](#) shows the block diagram of the 32-kHz sync timer.

**NOTE:** sys\_nrespwron is an active low I/O.

**Figure 16-18. 32-kHz Sync Timer Block Diagram**



#### 16.6.1.1 Reading the 32-kHz Sync Timer

The sync counter register is 32 bits wide and for correct count capture must be accessed as 16-bit LSB access first and two 16-bit MSB access last. Internal synchronization logic allows reading of the counter value while the counter is running. The time latency to read the counter is one L4 interconnect clock period.

#### 16.6.1.2 32-kHz Sync Timer Features

The following are the main features of the 32-kHz sync timer controller:

- L4 slave interface support:
  - 32-bit data bus width
  - 32-/16-bit access supported
  - 8-bit access not supported
  - 16-bit address bus width
  - Burst mode not supported
- Only read operations are supported on the module registers; no write operation is supported (no error/no action on write).
- Free-running 32-bit upward counter
- Start and keep counting after power-on reset
- Automatic roll over to 0, highest value reached (0xFFFF FFFF)
- On-the-fly read (while counting)

#### 16.6.2 32-kHz Sync Timer Environment

The sync timer is accessible only through the L4 interface.

### 16.6.3 32-kHz Sync Timer Integration

#### 16.6.3.1 Clocking, Reset, and Power-Management Scheme

Table 16-91 lists the power and reset domain and the source clock for the 32-kHz sync timer in the device. For more information on power, reset, and clock control and domains, see [Chapter 3, Power, Reset, and Clock Management](#).

**Table 16-91. Clock, Power, and Reset Domains for 32-kHz Sync Timer**

| Timer             | Source Clock | Interface Clock | Clock and Power Domain | Reset Domain             |
|-------------------|--------------|-----------------|------------------------|--------------------------|
| 32-kHz sync timer | sys_32k      | 32KSYNC_ICLK    | WKUP                   | SYNCT_RST <sup>(1)</sup> |

#### 16.6.3.2 Interrupts

The 32-kHz sync timer has no interrupt outputs.

#### 16.6.3.3 Sync Timer 32k and MSuspend Signal

By default, the Sync Timer 32k is not stopped when the MPU or DSP is in *halt*. To activate its sensitivity to the MSuspend signal, the CONTROL.CONTROL\_MSUSPEND\_2[29:27] SyncTMMctrl bit has been added to the system control module.

## 16.7 32-kHz Sync Timer Register Manual

### 16.7.1 32-kHz Sync Timer Instance Summary

[Table 16-92](#) lists the base address and block size for the 32-kHz sync timer. It is memory mapped to the L4 peripheral bus memory space.

**Table 16-92. 32-kHz Sync Timer Instance Summary**

| Module Name       | Base Address | Size     |
|-------------------|--------------|----------|
| 32-kHz Sync Timer | 0x4832 0000  | 4K bytes |

### 16.7.2 32-kHz Sync Timer Register Mapping Summary

**CAUTION**

The 32-kHz sync timer registers are limited to 32-bit and 16-bit data accesses; 8-bit access is not allowed and can corrupt the register content.

[Table 16-93](#) lists the 32-kHz sync timer registers. [Table 16-94](#) through [Table 16-98](#) describe the register bits.

**Table 16-93. 32-kHz Sync Timer Register Summary**

| Register Name           | Type | Register Width (Bits) | Offset Address | 32-kHz-Sync Timer Physical Address |
|-------------------------|------|-----------------------|----------------|------------------------------------|
| REG_32KSYNCNT_REV       | R    | 32                    | 0x0000         | 0x4832 0000                        |
| REG_32KSYNCNT_SYSConfig | R/W  | 32                    | 0x0004         | 0x4832 0004                        |
| REG_32KSYNCNT_CR        | R    | 32                    | 0x0010         | 0x4832 0010                        |

### 16.7.3 32-kHz Sync Timer Register Descriptions

**Table 16-94. REG\_32KSYNCNT\_REV**

|                                                                                             |                                                           |
|---------------------------------------------------------------------------------------------|-----------------------------------------------------------|
| Address Offset                                                                              | 0x0000                                                    |
| Physical Address                                                                            | 0x4832 0000                                               |
| Description                                                                                 | This register contains the sync counter IP revision code. |
| Type                                                                                        | R                                                         |
| 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 | Reserved CID_REV                                          |
|                                                                                             | Reserved CID_REV                                          |

| Bits | Field Name | Description                                                                                                           | Type | Reset              |
|------|------------|-----------------------------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | Reserved   | Reads return 0.                                                                                                       | R    | 0x000000           |
| 7:0  | CID_REV    | Counter revision number<br>[7:4] = Major revision<br>[3:0] = Minor revision<br>(Examples: 0x10 for 1.0, 0x21 for 2.1) | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 16-95. Register Call Summary for Register REG\_32KSYNCNT\_REV**

32-kHz Sync Timer Register Manual

- 32-kHz Sync Timer Register Mapping Summary: [0]

**Table 16-96. REG\_32KSYNCNT\_SYSCONFIG**

|                         |                                            |
|-------------------------|--------------------------------------------|
| <b>Address Offset</b>   | 0x0004                                     |
| <b>Physical Address</b> | 0x4832 0004                                |
| <b>Description</b>      | This register is used for IDLE modes only. |
| <b>Type</b>             | RW                                         |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                         | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:5 | Reserved   | Reads return 0.                                                                                                                                                                                     | R    | 0x0   |
| 4:3  | IDLEMODE   | Power management REQ/ACK control<br><br>0x0: Force idle. An idle request is acknowledged unconditionally.<br>0x1: No-idle. An idle request is never acknowledged.<br>0x2: Reserved<br>0x3: Reserved | RW   | 0x0   |
| 2:0  | Reserved   | Reads return 0.                                                                                                                                                                                     | R    | 0x0   |

**Table 16-97. Register Call Summary for Register REG\_32KSYNCNT\_SYSCONFIG**

32-kHz Sync Timer Register Manual

- 32-kHz Sync Timer Register Mapping Summary: [0]

**Table 16-98. REG\_32KSYNCNT\_CR**

|                         |                                                       |
|-------------------------|-------------------------------------------------------|
| <b>Address Offset</b>   | 0x0010                                                |
| <b>Physical Address</b> | 0x4832 0010                                           |
| <b>Description</b>      | This register contains the 32-kHz sync counter value. |
| <b>Type</b>             | R                                                     |

| 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 |
|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| COUNTER_VALUE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name    | Description            | Type | Reset      |
|------|---------------|------------------------|------|------------|
| 31:0 | COUNTER_VALUE | Counter register value | R    | 0x00000003 |

**Table 16-99. Register Call Summary for Register REG\_32KSYNCNT\_CR**

32-kHz Sync Timer Register Manual

- 32-kHz Sync Timer Register Mapping Summary: [0]

## Multimaster High-Speed I<sup>2</sup>C Controller

This chapter describes the four multimaster high-speed (HS) inter-integrated circuit (I<sup>2</sup>C) <sup>TM</sup> controllers integrated in the device. For reading ease, the multimaster high-speed controller 1, 2, 3, and 4 will be referred and factorized as HS I<sup>2</sup>C*i*.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                                  | Page |
|--------------------------------------------------------|------|
| 17.1 HS I <sup>2</sup> C Overview .....                | 2788 |
| 17.2 HS I <sup>2</sup> C Environment .....             | 2790 |
| 17.3 HS I <sup>2</sup> C Integration .....             | 2802 |
| 17.4 HS I <sup>2</sup> C Functional Description .....  | 2811 |
| 17.5 HS I <sup>2</sup> C Basic Programming Model ..... | 2820 |
| 17.6 HS I <sup>2</sup> C Register Manual .....         | 2840 |

## 17.1 HS I<sup>2</sup>C Overview

The device contains four multimaster high-speed (HS) inter-integrated circuit (I<sup>2</sup>C) <sup>TM</sup> controllers (I<sup>2</sup>C<sub>i</sub>, where  $i = 1, 2, 3$ , or 4), each of which provides an interface between a local host (LH), such as the microprocessor unit (MPU) subsystem, and any I<sup>2</sup>C-bus-compatible device that connects through the I<sup>2</sup>C serial bus. External components attached to the I<sup>2</sup>C bus can serially transmit and receive up to 8 bits of data to and from the LH device through the 2-wire I<sup>2</sup>C interface.

Each HS I<sup>2</sup>C controller can be configured to act like a slave or master I<sup>2</sup>C-compatible device. Moreover, each HS I<sup>2</sup>C controller can be configured in serial camera control bus (SCCB) mode (the SCCB is a serial bus developed by Omnivision Technologies, Inc.) to act as a master on a 2-wire SCCB bus. Only HS I<sup>2</sup>C2 and I<sup>2</sup>C3 can be configured in SCCB mode to act as a master device on a 3-wire SCCB bus.

The fourth HS I<sup>2</sup>C4 controller (I<sup>2</sup>C4) is in the power, reset, and clock management (PRCM) module to perform dynamic voltage control and power sequencing. For mode details on I<sup>2</sup>C4 see [Chapter 3, Power, Reset, and Clock Management](#). Moreover,

[Figure 17-1](#) shows the HS I<sup>2</sup>C controller in the device.

**Figure 17-1. HS I<sup>2</sup>C Controllers Overview Block Diagram**



(1)  $i = 1, 2, 3$  and 4. Where i<sup>2</sup>C<sub>i</sub> sccb is available only when  $i=2$  and 3.

The three HS I<sup>2</sup>C controllers have the following features:

- Compliance with Philips I<sup>2</sup>C specification version 2.1
- Support for standard mode (up to 100Kbps) and fast mode (up to 400Kbps)
- Support for HS mode for transfer up to 3.4Mbps
- Support for 3-wire/2-wire SCCB master mode for I<sup>2</sup>C2 and I<sup>2</sup>C3 modules, 2-wire SCCB master mode for I<sup>2</sup>C1 module, up to 100K bits/s
- 7-bit and 10-bit device addressing modes
- General call

- Start/restart/stop
- Multimaster transmitter/slave receiver mode
- Multimaster receiver/slave transmitter mode
- Combined master transmit/receive and receive/transmit mode
- Built-in FIFOs (8, 16, 32, 64 bytes size) for buffered read or write
- Module enable/disable capability
- Programmable clock generation
- 8-bit-wide data access
- Low-power consumption design
- Two direct memory access (DMA) channels
- Wide interrupt capability
- Auto Idle mechanism
- Idle Request / Idle Acknowledge handshake mechanism

The master transmitter HS I<sup>2</sup>C4 controller has the following features:

- Support of HS and fast modes
- 7-bit addressing mode only
- Master transmitter mode only
- Start/restart/stop

---

**NOTE:** Before using HS I<sup>2</sup>C mode, determine that the target device supports this mode.

---

## 17.2 HS I<sup>2</sup>C Environment

### 17.2.1 HS I<sup>2</sup>C in I<sup>2</sup>C Mode

Figure 17-2 shows the HS I<sup>2</sup>C controllers and their related connections with I<sup>2</sup>C-compliant devices in I<sup>2</sup>C mode.

**Figure 17-2. HS I<sup>2</sup>C Controllers and Typical Connections to I<sup>2</sup>C Devices**



i2c-002

#### 17.2.1.1 HS I<sup>2</sup>C Pins for Typical Connections in I<sup>2</sup>C Mode

Figure 17-3 shows the HS I<sup>2</sup>C controllers pins used for typical connections with I<sup>2</sup>C devices.

**Figure 17-3. HS I<sup>2</sup>C Controller Interface Signals in I<sup>2</sup>C Mode**



i2c-003

NOTE: In master mode, the clock signal (IP clk configured as output) is also used as retiming input (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to 1).

#### 17.2.1.2 HS I<sup>2</sup>C Interface Typical Connections

Table 17-1 lists the pins associated with the I<sup>2</sup>C interface.

**Table 17-1. HS I<sup>2</sup>C Input/Output**

| Signal   | I/O <sup>(1)</sup> | Description                                                                                                           | Reset Value                    |
|----------|--------------------|-----------------------------------------------------------------------------------------------------------------------|--------------------------------|
| i2ci_scl | I/O(OD)            | I <sup>2</sup> C serial clock line <sup>(2)</sup> . Open-drain output buffer. Requires external pullup resistor (Rp). | Hi-Z for $i=1$ ; 1 for $i=2,3$ |
| i2ci_sda | I/O(OD)            | I <sup>2</sup> C serial data line. Open-drain output buffer. Requires external Rp.                                    | Hi-Z for $i=1$ ; 1 for $i=2,3$ |

<sup>(1)</sup> I = Input; O = Output; OD = Open Drain; Hi-Z = High Impedance

<sup>(2)</sup> This signal is also used as retiming input (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to 1).

### 17.2.1.3 HS I<sup>2</sup>C Typical Connection Protocol and Data Format

#### 17.2.1.3.1 HS I<sup>2</sup>C Serial Data Format

The HS I<sup>2</sup>C controller operates in 8-bit word data format (byte write access supported for the last access). Each byte transmitted or received on the serial data line (i2ci\_sda) is 8 bits long. The number of bytes that can be transmitted or received is not restricted. The data is transferred with the most-significant bit (MSB) first. In receiver mode, each byte is followed by an acknowledge bit from the HS I<sup>2</sup>C. Figure 17-4 shows a typical HS I<sup>2</sup>C communication format.

**Figure 17-4. HS I<sup>2</sup>C Serial Data Transfer**


i2c-004

#### 17.2.1.3.2 HS I<sup>2</sup>C Data Validity

The data on the serial data line must be stable during the high period of the clock i2ci\_scl. The high and low states of the data line can change only when the clock signal on the serial clock line is low.

Figure 17-5 is an example of data validity requirements.

**Figure 17-5. HS I<sup>2</sup>C Bit Data Validity Transfer on the I<sup>2</sup>C Bus**


i2c-005

#### 17.2.1.3.3 HS I<sup>2</sup>C Start and Stop Conditions

The HS I<sup>2</sup>C module generates start (S) and stop (P) conditions when it is configured as a master.

- An S condition is a high-to-low transition on the i2ci\_sda line while i2ci\_scl is high.
- A P condition is a low-to-high transition on the i2ci\_sda line while i2ci\_scl is high.

The bus is considered busy after the S condition (the I<sub>2</sub>C<sub>i</sub>.I<sub>2</sub>C\_STAT[12] BB bit is 1 to indicate that the bus is busy) and free after the P condition (the I<sub>2</sub>C<sub>i</sub>.I<sub>2</sub>C\_STAT[12] BB bit is 0 to indicate that the bus is free).

Figure 17-6 shows the waveforms that occur during an S and a P condition.

**Figure 17-6. HS I<sup>2</sup>C Start and Stop Condition Events**



i2c-006

#### 17.2.1.3.4 HS I<sup>2</sup>C Addressing

The HS I<sup>2</sup>C controller supports two data formats in fast/standard (F/S) and HS modes:

- 7-bit/10-bit addressing format
- 7-bit/10-bit addressing format with repeated start (Sr) condition

##### 17.2.1.3.4.1 HS I<sup>2</sup>C Data Transfer Format in F/S Mode

Figure 17-7 shows the I<sup>2</sup>C data transfer format in F/S mode.

**Figure 17-7. HS I<sup>2</sup>C Data Transfer Formats in F/S Mode**



(a) 7-bit addressing format



(b) 10-bit addressing format



(c) addressing format with repeated start condition

i2c-007

The first word after an S condition consists of 8 bits. In acknowledge mode, an extra dedicated acknowledgment bit is inserted after each byte.

In addressing formats with 7-bit addresses, the first byte is composed of 7 MSB slave address bits and 1 least-significant bit (LSB) R/W\_ bit.

The LSB R/W\_ bit of the address byte indicates the transmission direction of the data bytes that follow it. If R/W\_ is 0, the master writes data to the selected slave; if it is 1, the master reads data from the slave.

In addressing formats with 10-bit addresses, the structure of the first byte is 11110XXY, where XX is the two MSBs of the 10-bit addresses, and Y is the R/W\_ bit. If the R/W\_ bit is 0, the next byte contains the last 8 bits of the slave address. If the R/W\_ bit is 1, the next byte contains data transmitted from the slave to the master.

#### 17.2.1.3.4.2 HS I<sup>2</sup>C Data Transfer Format in HS Mode

Figure 17-8 shows the I<sup>2</sup>C data transfer format in HS mode.

Figure 17-8. HS I<sup>2</sup>C Data Transfers in HS Mode



Each HS I<sup>2</sup>C controller module can also operate in HS mode. In this case, after the S condition, the module, which is in F/S mode, writes the master code address (000001XXX, where XXX is the variable portion of the master code) on the bus. No device connected on the same bus acknowledges this address. The module switches the clock to the HS clock and after an Sr condition, and sends the slave address and the data, as shown in Figure 17-8.

**NOTE:** For more information, see *I<sup>2</sup>C Bus Specification v2.1*, January 2000.

#### 17.2.1.3.5 HS I<sup>2</sup>C Master Transmitter Mode

In master transmitter mode, data assembled in one of the previously described data formats is shifted out on serial data line i<sub>2</sub>ci\_sda in synchronization with the self-generated clock pulses on serial clock line i<sub>2</sub>ci\_scl. When the intervention of the processor is required (the I<sub>2</sub>C<sub>i</sub>.I<sub>2</sub>C\_STAT[10] XUDF bit) after a byte is transmitted, the clock pulses are inhibited and the serial clock line is held low.

#### 17.2.1.3.6 HS I<sup>2</sup>C Master Receiver Mode

Master receiver mode can be entered only from master transmitter mode. With any of the address formats (a), (b), or (c) (see Figure 17-7), if the R/W\_ bit is high, the module enters master receiver mode after the slave address byte and bit R/W\_ are transmitted. Serial data bits received on bus line i<sub>2</sub>ci\_sda are shifted in synchronization with the self-generated clock pulses on i<sub>2</sub>ci\_scl. When the intervention of the processor is required (the I<sub>2</sub>C<sub>i</sub>.I<sub>2</sub>C\_STAT[11] ROVR bit) after a byte is transmitted, the clock pulses are inhibited and the serial clock line is held low. At the end of a transfer, a P condition is generated.

#### 17.2.1.3.7 HS I<sup>2</sup>C Slave Transmitter Mode

Slave transmitter mode can be entered only from slave receiver mode. With any of the address formats (a), (b), or (c) (see Figure 17-7), slave transmitter mode is entered if the slave address byte is the same as its own address, and when the R/W\_ bit transmitted by the master transmitter is high. The slave transmitter shifts the serial data out on data line i<sub>2</sub>ci\_sda in synchronization with the clock pulses generated by the master device. It does not generate the clock, but it can hold clock line i<sub>2</sub>ci\_scl low when intervention of the LH is required (the I<sub>2</sub>C<sub>i</sub>.I<sub>2</sub>C\_STAT[10] XUDF bit).

#### 17.2.1.3.8 HS I<sup>2</sup>C Slave Receiver Mode

In slave receiver mode, serial data bits received on bus line i<sub>2</sub>ci\_sda are shifted in synchronization with the clock pulses on i<sub>2</sub>ci\_scl generated by the master device. The slave receiver does not generate the clock, but it can hold the serial clock line low when intervention of the LH is required (the I<sub>2</sub>C<sub>i</sub>.I<sub>2</sub>C\_STAT[11] ROVR bit) after a byte is received.

### 17.2.1.3.9 HS I<sup>2</sup>C Bus Arbitration

If two or more master transmitters start a transmission on the same bus simultaneously, an arbitration procedure is invoked. This arbitration procedure uses the data presented on the serial bus by the competing transmitters. When a transmitter senses that a high signal it has presented on the bus has been overruled by a low signal, it switches to slave receiver mode, sets the arbitration lost flag (the I2C*i*.I2C\_STAT[0] AL bit), and generates the arbitration lost interrupt. Figure 17-9 shows arbitration between two devices. The arbitration procedure gives priority to the device that transmits the serial data stream with the lowest binary value. If two or more devices send identical first bytes, arbitration continues on the subsequent bytes.

**Figure 17-9. HS I<sup>2</sup>C Arbitration Between Master Transmitters**



### 17.2.1.3.10 HS I<sup>2</sup>C Clock Generation and Synchronization

Under normal conditions, only one master device generates clock signal i2ci\_scl. During arbitration, however, there are two or more master devices, and the clock must be synchronized so that the data output can be compared. The wired-AND property of the clock line means that the device that first generates a low period of the clock line overrules the other devices. At this high-low transition, the clock generators of the other devices are forced to start generating their own low periods. The clock line is then held low by the device with the longest low period, while the other devices that finish their low periods must wait for the clock line to be released before starting their high periods. A synchronized signal on the clock line is thus obtained, where the slowest device determines the length of the low period and the fastest device determines the length of the high period.

If a device pulls down the clock line for a longer time, all clock generators must enter the WAIT state. In this way, a slave can slow down a fast master, and the slow device can create enough time to store a received byte or prepare a byte to be transmitted (Clock Stretching).

**NOTE:** In case the SCL or SDA lines are stuck low, the Bus Clear operation is supported:

If the clock line (SCL) is stuck low, the preferred procedure is to reset the bus using the hardware reset signal if your I<sup>2</sup>C devices have hardware reset inputs. If the I<sup>2</sup>C devices do not have hardware reset inputs, cycle power to the devices to activate the mandatory internal power-on reset (POR) circuit.

If the data line (SDA) is stuck low, the master should send nine clock pulses. The device that held the bus low should release it sometime within those nine clocks. If not, then use the hardware reset or cycle power to clear the bus.

Figure 17-10 shows clock synchronization.

**Figure 17-10. HS I<sup>2</sup>C Synchronization of I<sup>2</sup>C Clock Generators**

### 17.2.2 HS I<sup>2</sup>C in SCCB Mode

The SCCB is a 3-wire serial bus developed by Omnivision Technologies, Inc. The SCCB can also operate in a modified 2-wire serial mode. For details, see the SCCB specifications version 2.1 document at <http://www.ovt.com/>.

The HS I<sup>2</sup>C controllers support the 2-wire SCCB protocol in master mode. Only I<sup>2</sup>C2 and I<sup>2</sup>C3 support the 3-wire SCCB protocol in master mode.

Figure 17-11 shows the HS I<sup>2</sup>C controllers and their related connections with 3-wire or 2-wire SCCB-compliant devices.

**Figure 17-11. HS I<sup>2</sup>C Controllers and Typical Connections to SCCB Devices**

(a) Typical connection with 3-wire SCCB devices



(b) Typical connection with 2-wire SCCB devices

i2c-011

**NOTE:** Only one 2-wire SCCB slave device can be connected to the 2-wire SCCB bus.

### 17.2.2.1 HS I<sup>2</sup>C Controller Pins for Typical Connections in SCCB Mode

Figure 17-12 shows the HS I<sup>2</sup>C controller pins used for typical connections with 3-wire or 2-wire SCCB devices.

**Figure 17-12. HS I<sup>2</sup>C Controller Interface Signals in SCCB Mode**


### 17.2.2.2 HS I<sup>2</sup>C SCCB Interface Typical Connections

[Table 17-2](#) lists the pins associated with the SCCB interface.

**Table 17-2. HS I<sup>2</sup>C Input/Output**

| Signal                    | I/O <sup>(1)</sup> | Description                                                                                                                                            | Reset Value | I2Ci.I2C_CON[15]<br>I2C_EN = 0 |
|---------------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------------------|
| i2ci_scl                  | O                  | SCCB serial clock line <sup>(2)</sup> . Standard CMOS output buffer.                                                                                   | Hi-Z        | High                           |
| i2ci_sda                  | I/O(OD)            | SCCB serial data line. Standard CMOS 3-state output buffer. Requires external conflict-protection resistor for each slave device connected to the bus. | Hi-Z        | Hi-Z                           |
| i2ci_sccbe <sup>(3)</sup> | O                  | SCCB enable line. Standard CMOS output buffer.                                                                                                         | High        | High                           |

<sup>(1)</sup> I = Input; O = Output; OD = Open Drain; Hi-Z = High Impedance

<sup>(2)</sup> This output signal is also used as retiming input (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to 1).

<sup>(3)</sup> This signal is used for the 3-wire SCCB protocol only.

**NOTE:** Because they share the same ball, the i2c2\_sccbe and i2c3\_sccbe signals are not available at the same time. For detailed information about pin configuration, see [Chapter 13, System Control Module](#).

The HS I2C1 module does not provide any i2c1\_sccbe signal at the chip boundary of the device; thus, this module does not support the 3-wire SCCB protocol.

### 17.2.2.3 HS I<sup>2</sup>C SCCB Typical Connection Protocol and Data Format

#### 17.2.2.3.1 HS I<sup>2</sup>C Serial Transmission Timing Diagram

Figure 17-13 is the timing diagram of the 3-wire SCCB data transmission.

**Figure 17-13. HS I<sup>2</sup>C 3-Wire SCCB Transmission Timing Diagram**



**NOTE:** When operating in 2-wire SCCB mode, the i2ci\_sccbe signal is not used by the 2-wire SCCB-compliant slave device attached to the 2-wire SCCB bus.

#### 17.2.2.3.2 HS I<sup>2</sup>C SCCB Transmission Data Formats

Figure 17-14 describes the data format of the three kinds of transmission.

**Figure 17-14. HS I<sup>2</sup>C SCCB Transmission Data Formats**



R/W: 0 = Write, 1 = Read

X: Don't care

NA: Ninth bit of a read phase. This bit must be set to 1 by the master device.

Master to slave   Slave to master

i2c-014

The basic element of a data transmission is a phase. A phase contains 9 bits, which consist of an 8-bit sequential data transmission followed by a ninth bit. The ninth bit is a don't-care bit (X) or an NA bit, depending on whether the data transmission is a write or a read. The maximum number of phases that can be included in a transmission is three. The MSB is always asserted first for each phase.

A data transmission is one of three types:

- **3-phase write transmission:** The 3-phase write transmission cycle (see (a) of [Figure 17-14](#)) is a full write operation in which the master can write 1 byte of data to a specific slave(s). The 7-bit slave address in the ID value identifies the specific slave that the master intends to access. The subaddress identifies the register location of the specified slave. The write data contains 8-bit data that the master intends to write over the content of this specific address. The ninth bit of each of the three phases is a don't-care bit (X bit).
- **2-phase write transmission:** The 2-phase write transmission cycle is followed by a 2-phase read transmission cycle (see below). The purpose of issuing a 2-phase write transmission cycle (see (b) of [Figure 17-14](#)) is to identify the subaddress of some specific slave from which the master intends to read data for the following 2-phase read transmission cycle. The ninth bit of each phase is a don't-care bit (X bit).
- **2-phase read transmission:** Either a 3-phase or a 2-phase write transmission cycle must be asserted ahead of a 2-phase read transmission cycle. The 2-phase read transmission cycle (see (c) of [Figure 17-14](#)) has no ability to identify the subaddress. The 2-phase write transmission cycle contains read data of 8 bits and a ninth don't-care bit or NA bit. The master must drive the NA bit at logical 1.

In each transmission type, phase 1 (the 7-bit slave address of the ID value) is asserted by the master to identify the selected slave to which the data is read or written. Each slave has a unique 7-bit slave address. The 7-bit slave address of the ID value comprises 7 bits, from bit 7 to bit 1, that can identify up to 128 slaves. The eighth bit, bit 0, is the read/write selector bit that specifies the transmission direction of the current cycle. A logical 0 represents a write cycle and a logical 1 represents a read cycle. The ninth bit of phase 1 is a don't-care bit (X bit).

Phase 2 (subaddress/read data) is asserted by the master (subaddress) or the slave(s) (read data). A phase 2 transmission asserted by the master identifies the subaddress of the slave(s) the master intends to access. A phase 2 transmission asserted by the slave(s) indicates the read data that the master will receive. The slave(s) recognize the subaddress of this read data according to the previous 3-phase or 2-phase write transmission cycle. The ninth bit is defined as a don't-care bit (X bit) when the master asserts phase 2. The ninth bit is defined as an NA bit when the slave(s) asserts the phase 2 transmission. The master is responsible for a logical 1 during the period of the NA bit.

Phase 3 (write data) is asserted only by the master. This phase contains the data the master intends to write to the slave(s). Because the master asserts the transmission, the ninth bit of the phase 3 transmission is defined as a don't-care bit (X bit).

---

**NOTE:** A HS I<sup>2</sup>C controller configured in SCCB mode can perform two operations:

- Writing a single byte to an SCCB slave device by using the 3-phase write transmission cycle
  - Reading a single byte from an SCCB slave device by using the 2-phase write transmission cycle followed by the 2-phase read transmission cycle
- 

### 17.2.3 HS I<sup>2</sup>C Communication With Power Chip(s)

The HS I<sup>2</sup>C controller I2C4 interfaces between the external power chip(s) for voltage control. This module is always configured as an I<sup>2</sup>C master transmitter; it does not support the SCCB protocol. For a definition of master transmitter mode, see [Section 17.2.1.3.5, HS I<sup>2</sup>C Master Transmitter Mode](#).

[Figure 17-15](#) shows a typical connection between master transmitter HS I<sup>2</sup>C controller I2C4 of the device and external power chip(s).

**Figure 17-15. HS I<sup>2</sup>C Typical Connection Between Power Chip(s) and for I<sup>2</sup>C4**

### 17.2.3.1 HS I<sup>2</sup>C Pins for Typical Connections for I<sup>2</sup>C4

Figure 17-16 shows the HS I<sup>2</sup>C controller I<sup>2</sup>C4 pins used for typical connections with power chips. Its configuration is in master transmitter only high speed.

**Figure 17-16. HS I<sup>2</sup>C Interface Signals for I<sup>2</sup>C4**

### 17.2.3.2 HS I<sup>2</sup>C Interface Typical Connections for I<sup>2</sup>C4

Table 17-3 lists the pins associated with the I<sup>2</sup>C interface of the HS I<sup>2</sup>C controller I<sup>2</sup>C4 of the device.

**Table 17-3. HS I<sup>2</sup>C Input/Output Description for I2C4**

| Signal   | I/O <sup>(1)</sup> | Description                                                                                         | Reset Value |
|----------|--------------------|-----------------------------------------------------------------------------------------------------|-------------|
| i2c4_scl | I/O(OD)            | I <sup>2</sup> C serial clock line <sup>(2)</sup> . Open-drain output buffer. Requires external Rp. | Hi-Z        |
| i2c4_sda | I/O(OD)            | I <sup>2</sup> C serial data line. Open-drain output buffer. Requires external Rp.                  | Hi-Z        |

<sup>(1)</sup> I = Input; O = Output; OD = Open Drain; Hi-Z = High Impedance

<sup>(2)</sup> This signal is also used as retiming input (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to 1).

### 17.2.3.3 HS I<sup>2</sup>C Typical Connections Protocol and Data Format for I2C4

#### 17.2.3.3.1 HS I<sup>2</sup>C Serial Data Format for I2C4

The serial data format is the same as described in [Section 17.2.1.3.1, HS I<sup>2</sup>C Serial Data Format](#).

#### 17.2.3.3.2 HS I<sup>2</sup>C Data Validity for I2C4

The data validity is the same as described in [Section 17.2.1.3.2, HS I<sup>2</sup>C Data Validity](#).

#### 17.2.3.3.3 HS I<sup>2</sup>C Start and Stop Conditions for I2C4

The S and P conditions are the same as described in [Section 17.2.1.3.3, HS I<sup>2</sup>C Start and Stop Conditions](#).

#### 17.2.3.3.4 HS I<sup>2</sup>C Addressing for I2C4

The master transmitter HS I<sup>2</sup>C controller I2C4 supports only the 7-bit addressing mode. For each frame, the master writes the 8-bit value (DATA) in the register specified by the 8-bit register address (RA) of the slave addressed by the slave address (SA).

##### 17.2.3.3.4.1 HS I<sup>2</sup>C Data Transfer Format in F/S Mode for I2C4

[Figure 17-17](#) shows the HS I<sup>2</sup>C data transfer format in F/S mode for I2C4.

**Figure 17-17. HS I<sup>2</sup>C Data Transfer Format in F/S Mode for I2C4**


W: Write = 0

S: Start condition

Sr: Repeated start condition

P: Stop condition

Master to slave      Slave to master

i2c-017

##### 17.2.3.3.4.2 HS I<sup>2</sup>C Data Transfer Format in HS Mode for I2C4

[Figure 17-18](#) shows the HS I<sup>2</sup>C data transfer format in HS mode for I2C4.

**Figure 17-18. HS I<sup>2</sup>C Data Transfer Format in HS Mode for I2C4**

i2c-018

### 17.3 HS I<sup>2</sup>C Integration

Figure 17-19 shows the integration of the four HS I<sup>2</sup>C controllers in the device.

**Figure 17-19. HS I<sup>2</sup>C Controller Integration Diagram**


i2c019

### 17.3.1 HS I<sup>2</sup>C Clocking, Reset, and Power-Management Scheme

#### 17.3.1.1 HS I<sup>2</sup>C Clocks

##### 17.3.1.1.1 HS I<sup>2</sup>C Module Clocks

Each HS I<sup>2</sup>C controller is clocked with an independent functional clock of 96 MHz (I<sup>2</sup>C<sub>i</sub>\_FCLK) and an interface clock (I<sup>2</sup>C<sub>i</sub>\_ICLK) for interfacing with the L4-Core interconnect. These clocks are provided by the PRCM module.

The SYS\_CLK clock provided by the clock generator of the PRCM module is connected to the functional and interface clocks of the HS I<sup>2</sup>C controller I2C4. For detailed information about the module clocking, see [Chapter 3, Power, Reset, and Clock Management](#).

The interface clock can be enabled or disabled for each HS I<sup>2</sup>C controller by setting the following bits in the PRCM module:

- PRCM.CM\_ICLKEN1\_CORE[15] EN\_I2C1 bit for I2C1
- PRCM.CM\_ICLKEN1\_CORE[16] EN\_I2C2 bit for I2C2
- PRCM.CM\_ICLKEN1\_CORE[17] EN\_I2C3 bit for I2C3

The functional clock can be enabled or disabled for each multimaster HS I<sup>2</sup>C controller by setting the following bits in the PRCM module:

- PRCM.CM\_FCLKEN1\_CORE[15] EN\_I2C1 bit for I2C1
- PRCM.CM\_FCLKEN1\_CORE[16] EN\_I2C2 bit for I2C2
- PRCM.CM\_FCLKEN1\_CORE[17] EN\_I2C3 bit for I2C3

The functional clock is processed by a prescaler block to produce the internal sampling clock. This clock is generated by the I<sup>2</sup>C prescaler block. The prescaler block consists of the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_PSC[7:0] PSC bit field (where  $i = 1, 2, 3$ ) that is used to divide down the functional clock to obtain an internal sampling clock with a frequency value of I<sup>2</sup>C<sub>i</sub>\_FCLK/(I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_PSC[7:0] PSC bit field value + 1, where  $i = 1, 2, 3$ ).

---

**NOTE:** The I<sup>2</sup>C<sub>4</sub>.I<sup>2</sup>C\_PSC[7:0] PSC bit field of I<sup>2</sup>C<sub>4</sub> is not accessible by software. For details about the bit rates available for I<sup>2</sup>C<sub>4</sub>, see [Section 17.4.7, HS I<sup>2</sup>C Clocking](#).

---

### 17.3.1.2 HS I<sup>2</sup>C Power Management

#### 17.3.1.2.1 HS I<sup>2</sup>C Module Power Saving

This section describes power-saving techniques for the HS I<sup>2</sup>C controllers. To conserve power, when no activity is detected on the L4-Core interconnect interface of the module, each of these modules supports an automatic idle mode that is enabled or disabled by setting the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SYSC[0] AUTOIDLE bit.

When this bit is asserted (set to 1), if no activity is detected on the L4-Core interface, automatic idle mode is enabled and the interface clock I<sup>2</sup>C<sub>i</sub>\_ICLK is disabled internally to the module, thus reducing power consumption.

When new activity is detected on the L4-Core interconnect interface of the module, the clock restarts with no latency penalty. After reset, automatic idle mode is disabled; thus, this mode must be enabled by software for reduced power consumption.

#### 17.3.1.2.2 HS I<sup>2</sup>C System Power Management

As part of the system-wide power-management scheme, each HS I<sup>2</sup>C controller supports a communication protocol with the PRCM module to request the module to enter a low-power mode. When a module acknowledges a low-power mode request from the PRCM module, the interface and/or the functional clocks are gated off at the PRCM clock generator. Because the clocks are disabled at the source, the low-power mode offers lower power consumption than the internal clock autogating method used by local power management.

The PRCM.CM\_ICLKEN1\_CORE[15] EN\_I2C1, PRCM.CM\_ICLKEN1\_CORE[16] EN\_I2C2, and PRCM.CM\_ICLKEN1\_CORE[17] EN\_I2C3 bits in the PRCM module control the interface clocks of the HS I<sup>2</sup>C1, I<sup>2</sup>C2, and I<sup>2</sup>C3 modules, respectively.

The PRCM.CM\_FCLKEN1\_CORE[15] EN\_I2C1, PRCM.CM\_FCLKEN1\_CORE[16] EN\_I2C2, and PRCM.CM\_FCLKEN1\_CORE[17] EN\_I2C3 bits in the PRCM module control the functional clocks of the HS I<sup>2</sup>C1, I<sup>2</sup>C2, and I<sup>2</sup>C3 modules, respectively.

For details about clock enabling and disabling in the PRCM module, see [Chapter 3, Power, Reset, and Clock Management](#).

Each HS I<sup>2</sup>C controller can be configured through the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SYSC[4:3] IDLEMODE bit field as one of the following acknowledgment modes:

- Force-idle mode (I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SYSC[4:3] IDLEMODE bit field = b00): The module immediately enters idle mode when a low-power-mode request is received from the PRCM module. In this mode, software must ensure that there are no asserted output interrupts before requesting this mode to go to IDLE state.
- No-idle mode (I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SYSC[4:3] IDLEMODE bit field = b01): The module never enters idle mode.
- Smart-idle mode (I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SYSC[4:3] IDLEMODE bit field = b10): After receiving a low-power-mode request from the PRCM module, the module enters idle mode only after all asserted output interrupts are acknowledged and there is no pending internal event.

---

**NOTE:** The value I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SYSC[4:3] IDLEMODE = b11 must not be used.

---

Table 17-4 describes the HS I<sup>2</sup>C controller power-management modes.

**Table 17-4. HS I<sup>2</sup>C Power Management Modes**

| Power-Management Mode Requested by the PRCM Module | I <sup>2</sup> C <sub>i</sub> .I <sup>2</sup> C_SYSC[4:3] IDLEMODE Bit Field Value (where i = 1, 2, 3) |
|----------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| Force-idle                                         | b00                                                                                                    |
| No-idle                                            | b01                                                                                                    |
| Smart-idle                                         | b10                                                                                                    |
| Reserved (not used)                                | b11                                                                                                    |

The PRCM module gates the interface and/or the functional clocks after receiving the acknowledgment of the I<sup>2</sup>C<sub>i</sub> (where *i* = 1, 2, 3). The I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SYSC[9:8] CLOCKACTIVITY bit field indicates the state of the interface and functional clocks of the module when in idle mode. Table 17-5 lists the value of the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SYSC[9:8] CLOCKACTIVITY bit field and indicates the state of the interface and functional clocks at the PRCM clock generator output in idle mode.

**Table 17-5. HS I<sup>2</sup>C State of the Interface and Functional Clocks When the Module is in Idle Mode**

| I <sup>2</sup> C <sub>i</sub> .I <sup>2</sup> C_SYSC[9:8]<br>CLOCKACTIVITY Bit Field<br>Value (where i= 1, 2, 3) | Functional Clock | Interface Clock |
|------------------------------------------------------------------------------------------------------------------|------------------|-----------------|
| b00                                                                                                              | Off              | Off             |
| b01                                                                                                              | Off              | On              |
| b10                                                                                                              | On               | Off             |
| b11                                                                                                              | On               | On              |

---

**NOTE:** The PRCM.CM\_AUTOIDLE1\_CORE[15] AUTO\_I2C1, PRCM.CM\_AUTOIDLE1\_CORE[16] AUTO\_I2C2, and PRCM.CM\_AUTOIDLE1[17] AUTO\_I2C3 bits control, for each HS I<sup>2</sup>C controller, whether the L4-Core interconnect interface clock is enabled or disabled in synchronization with the CORE power domain state transition (see [Chapter 3, Power, Reset, and Clock Management](#)).

---



---

**NOTE:** The voltage controller, in which HS I<sup>2</sup>C controller I2C4 is implemented, has no idle request/acknowledge mechanism. The idle modes for the voltage controller are directly managed by the PRM module. For details, see [Chapter 3, Power, Reset, and Clock Management](#).

---

### 17.3.1.2.3 HS I<sup>2</sup>C Wake-Up Capability

Each HS I<sup>2</sup>C controller can wake up the system by generating a wake-up request through the I<sup>2</sup>C<sub>i</sub>\_WAKE signal connected to the PRCM module.

The wake-up request is composed of the merge of all wake-up events. Each wake-up event can be separately enabled or disabled by setting the corresponding bit in the I2Ci.I<sup>2</sup>C\_WE register.

The global wake-up capability of the module can be enabled or disabled by setting the I2Ci.I<sup>2</sup>C\_SYSC[2] ENAWAKEUP bit (1: enabled; 0: disabled).

Figure 17-20 shows the wake-up generation flow.

**Figure 17-20. HS I<sup>2</sup>C Wake-up Generation Flow**



i2c-020

Table 17-6 lists all wake-up events with the corresponding enable/disable bit in the I2Ci.I<sup>2</sup>C\_WE register.

**Table 17-6. HS I<sup>2</sup>C Wake-Up Events**

| Wake-Up Event Name | Supported Configuration Mode                     | Enable/Disable Bit <sup>(1)</sup>   | Event Generated When:                                                                                |
|--------------------|--------------------------------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------|
| AL event           | I <sup>2</sup> C mode only                       | I2Ci.I <sup>2</sup> C_WE[0] AL_WE   | I2Ci in the device loses the arbitration of the I <sup>2</sup> C bus in master transmitter mode.     |
| NACK event         | I <sup>2</sup> C mode only                       | I2Ci.I <sup>2</sup> C_WE[1] NACK_WE | A nonacknowledgment has been generated on the I <sup>2</sup> C bus, indicating a transmission error. |
| ARDY event         | I <sup>2</sup> C receive mode and SCCB read mode | I2Ci.I <sup>2</sup> C_WE[2] ARDY_WE | The current transaction is finished and the module registers can be accessed.                        |
| DRDY event         | I <sup>2</sup> C and SCCB modes                  | I2Ci.I <sup>2</sup> C_WE[3] DRDY_WE | The TX FIFO needs some data to be transferred or the RX FIFO must be read.                           |

<sup>(1)</sup> To enable the corresponding wake-up event generation, set the bit to 1. To disable the corresponding wake-up event generation, set the bit to 0.

**Table 17-6. HS I<sup>2</sup>C Wake-Up Events (continued)**

| Wake-Up Event Name       | Supported Configuration Mode               | Enable/Disable Bit <sup>(1)</sup> | Event Generated When:                                                                                                                                                                                                                                                                                                                      |
|--------------------------|--------------------------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GC event                 | I <sup>2</sup> C mode only                 | I2Ci.I2C_WE[5] GC_WE              | A general call is received on the I <sup>2</sup> C bus.                                                                                                                                                                                                                                                                                    |
| STC event <sup>(2)</sup> | I <sup>2</sup> C mode only                 | I2Ci.I2C_WE[6] STC_WE             | A start (S) condition is detected on the I <sup>2</sup> C bus. <sup>(3)</sup>                                                                                                                                                                                                                                                              |
| BF event                 | I <sup>2</sup> C and SCCB modes            | I2Ci.I2C_WE[8] BF_WE              | The bus is free and the LH can initiate its own transfer.                                                                                                                                                                                                                                                                                  |
| AAS event                | I <sup>2</sup> C mode only                 | I2Ci.I2C_WE[9] AAS_WE             | An external master I <sup>2</sup> C device addresses the module of the device to inform the LH that it can check which of its own addresses was used by the external master I <sup>2</sup> C device to access the module of the device.                                                                                                    |
| ROVR event               | I <sup>2</sup> C receive mode only         | I2Ci.I2C_WE[10] ROVR_WE           | Overrunning and draining while receiving.                                                                                                                                                                                                                                                                                                  |
| XUDF event               | I <sup>2</sup> C transmit mode only        | I2Ci.I2C_WE[11] XUDF_WE           | Transmitting and receiving an underflow event during the transmission.                                                                                                                                                                                                                                                                     |
| RDR event                | I <sup>2</sup> C receive mode only         | I2Ci.I2C_WE[13] RDR_WE            | The module, configured as a receiver, has detected a stop (P) condition on the I <sup>2</sup> C bus and the RX FIFO threshold (I2Ci.I2C_BUF[13:8] RTRSH bit field value + 1) is not reached and the RX FIFO is not empty. This allows the module to inform the LH that it can check the amount of data to be transferred from the RX FIFO. |
| XDR event                | I <sup>2</sup> C master transmit mode only | I2Ci.I2C_WE[14] XDR_WE            | The TXFIFO level is below the threshold (I2Ci.I2C_BUF[5:0] XTRSH bit field value + 1) and the amount of data left to be transferred is less than this threshold. This allows the module to inform the LH that it can check the amount of data to be written to the TX FIFO.                                                                |

<sup>(2)</sup> Wake-up event asynchronously detected.

<sup>(3)</sup> This event must not be enabled if the functional clock cannot be disabled.

**NOTE:** With the exception of the STC event, the functional clock must be active for wake-up event detection to occur. The HS I2C4 has no wake-up capability.

### 17.3.1.3 HS I<sup>2</sup>C Resets

#### 17.3.1.3.1 HS I<sup>2</sup>C Hardware Reset

The three HS I<sup>2</sup>C controllers receive their reset signal CORE\_RST (the reset signal of the CORE power domain) from the PRCM module.

The HS I2C4 gets its reset signal PRM\_RSTPWRON from the reset manager in the PRCM module.

#### 17.3.1.3.2 HS I<sup>2</sup>C Software Reset

Each HS I<sup>2</sup>C controller supports the software reset by accessing the I2Ci.I2C\_SYSC[1] SRST bit (1: reset; 0: normal mode).

The software reset status can be checked by accessing the I2Ci.I2C\_SYSS[0] RDONE bit (1: reset is done; 0: reset is ongoing).

To do a software reset, the following steps must be done:

1. Ensure that the module is disabled (clear the I2Ci.I2C\_CON[15] I2C\_EN bit to 0).
2. Set the I2Ci.I2C\_SYSC[1] SRST bit to 1.
3. Enable the module by setting I2Ci.I2C\_CON[15] I2C\_EN bit to 1.
4. Check the I2Ci.I2C\_SYSS[0] RDONE bit until it is set to 1 to indicate the software reset is complete.

**NOTE:** The I<sup>2</sup>C*i*.I<sup>2</sup>C\_CON[15] I<sup>2</sup>C\_EN bit can hold the functional clock domain of the HS I<sup>2</sup>C controller in reset after the device reset has been released. When the system bus reset is removed, this bit remains cleared. The functional part of the I<sup>2</sup>C controller is held in reset state while this bit is 0, and all configuration registers can be accessed.

The I<sup>2</sup>C*i*.I<sup>2</sup>C\_CON[15] I<sup>2</sup>C\_EN bit must be set to 1 to enable the functional part of the I<sup>2</sup>C controller.

The I<sup>2</sup>C*i*.I<sup>2</sup>C\_SYSS[0] RDONE bit is asserted only after the module is enabled by setting the I<sup>2</sup>C*i*.I<sup>2</sup>C\_CON[15] I<sup>2</sup>C\_EN bit to 1.

#### 17.3.1.4 HS I<sup>2</sup>C Power Domain

The three HS I<sup>2</sup>C controllers are connected to the CORE power domain, whereas the HS I<sup>2</sup>C4 controller belongs to the WKUP power domain.

### 17.3.2 HS I<sup>2</sup>C Hardware Requests

#### 17.3.2.1 HS I<sup>2</sup>C DMA Requests

Each HS I<sup>2</sup>C controller can generate two DMA requests to the system DMA (sDMA) controller. [Table 17-7](#) lists the DMA requests with mapping on the sDMA controller.

**Table 17-7. HS I<sup>2</sup>C DMA Requests**

| Name                     | Source            | Destination (sDMA controller) | Description                                                                                                                           |
|--------------------------|-------------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| I <sup>2</sup> C1_DMA_TX | I <sup>2</sup> C1 | S_DMA_26                      | I <sup>2</sup> C1 DMA write request to inform the sDMA to write new data in the I <sup>2</sup> C1.I <sup>2</sup> C_DATA[7:0] register |
| I <sup>2</sup> C1_DMA_RX | I <sup>2</sup> C1 | S_DMA_27                      | I <sup>2</sup> C1 DMA read request to inform the sDMA to read the data in the I <sup>2</sup> C1.I <sup>2</sup> C_DATA[7:0] register   |
| I <sup>2</sup> C2_DMA_TX | I <sup>2</sup> C2 | S_DMA_28                      | I <sup>2</sup> C2 DMA write request to inform the sDMA to write new data in the I <sup>2</sup> C2.I <sup>2</sup> C_DATA[7:0] register |
| I <sup>2</sup> C2_DMA_RX | I <sup>2</sup> C2 | S_DMA_29                      | I <sup>2</sup> C2 DMA read request to inform the sDMA to read the data in the I <sup>2</sup> C2.I <sup>2</sup> C_DATA[7:0] register   |
| I <sup>2</sup> C3_DMA_TX | I <sup>2</sup> C3 | S_DMA_24                      | I <sup>2</sup> C3 DMA write request to inform the sDMA to write new data in the I <sup>2</sup> C3.I <sup>2</sup> C_DATA[7:0] register |
| I <sup>2</sup> C3_DMA_RX | I <sup>2</sup> C3 | S_DMA_25                      | I <sup>2</sup> C3 DMA read request to inform the sDMA to read the data in the I <sup>2</sup> C3.I <sup>2</sup> C_DATA[7:0] register   |

**NOTE:** The HS I<sup>2</sup>C4 does not generate any DMA request.

#### 17.3.2.2 HS I<sup>2</sup>C Interrupt Requests

Each HS I<sup>2</sup>C controller can generate an interrupt I<sup>2</sup>C*i*\_IRQ to the MPU subsystem. [Table 17-8](#) lists the interrupt requests with the mapping on the MPU interrupt controller (INTC).

**Table 17-8. HS I<sup>2</sup>C Interrupt Requests**

| Name                  | Source            | Destination (MPU INTC) |
|-----------------------|-------------------|------------------------|
| I <sup>2</sup> C1_IRQ | I <sup>2</sup> C1 | M_IRQ_56               |
| I <sup>2</sup> C2_IRQ | I <sup>2</sup> C2 | M_IRQ_57               |
| I <sup>2</sup> C3_IRQ | I <sup>2</sup> C3 | M_IRQ_61               |

An event can generate an interrupt request when the corresponding mask bit in the I<sup>2</sup>C*i*.I<sup>2</sup>C\_IE register is set to 1. [Table 17-9](#) summarizes the events causing the generation of an interrupt request.

**Table 17-9. HS I<sup>2</sup>C Interrupt Events**

| Event Name | Supported Configuration Mode                       | Status Bit                                  | Mask Bit                                     | This Event Happens When:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|----------------------------------------------------|---------------------------------------------|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AL event   | I <sup>2</sup> C mode only                         | I2C <i>i</i> .I <sup>2</sup> C_STAT[0] AL   | I2C <i>i</i> .I <sup>2</sup> C_IE[0] AL_IE   | Two or more I <sup>2</sup> C master devices initiate a transfer and the I <sup>2</sup> C module I <sup>2</sup> C <i>i</i> in the device loses arbitration of the I <sup>2</sup> C bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| NACK event | I <sup>2</sup> C mode only                         | I2C <i>i</i> .I <sup>2</sup> C_STAT[1] NACK | I2C <i>i</i> .I <sup>2</sup> C_IE[1] NACK_IE | A nonacknowledgment has been received. In master mode, the transfer is automatically ended by generating a stop condition on the bus. The I2C <i>i</i> .I <sup>2</sup> C_CON[1] STP, I2C <i>i</i> .I <sup>2</sup> C_CON[10] MST, and I2C <i>i</i> .I <sup>2</sup> C_CON[9] TRX bits are automatically cleared to 0 (slave receiver mode). TX and RX FIFOs must be cleared (the I2C <i>i</i> .I <sup>2</sup> C_BUF[6] TXFIFO_CLR and I2C <i>i</i> .I <sup>2</sup> C_BUF[14] RXFIFO_CLR bits are set to 1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| ARDY event | I <sup>2</sup> C and SCCB modes                    | I2C <i>i</i> .I <sup>2</sup> C_STAT[2] ARDY | I2C <i>i</i> .I <sup>2</sup> C_IE[2] ARDY_IE | One of the following cases occurs: <ul style="list-style-type: none"> <li>• In I<sup>2</sup>C master receiver mode, the I2C<i>i</i>.I<sup>2</sup>C_CON[1] STP bit is set to 1, the I2C<i>i</i>.I<sup>2</sup>C_CNT[15:0] DCOUNT bit field value is 0, and the RX FIFO is empty.</li> <li>• In I<sup>2</sup>C master transmitter mode, the I2C<i>i</i>.I<sup>2</sup>C_CON[1] STP bit is set to 1 and the I2C<i>i</i>.I<sup>2</sup>C_CNT[15:0] DCOUNT bit field value is 0.</li> <li>• In I<sup>2</sup>C master transmitter mode, the I2C<i>i</i>.I<sup>2</sup>C_CON[1] STP bit is cleared to 0 and the I2C<i>i</i>.I<sup>2</sup>C_CNT[15:0] DCOUNT bit field value passed 0.</li> <li>• In I<sup>2</sup>C master receiver mode, the I2C<i>i</i>.I<sup>2</sup>C_CON[1] STP bit is set to 1, the I2C<i>i</i>.I<sup>2</sup>C_CNT[15:0] DCOUNT field value passed 0, and the RX FIFO is empty.</li> <li>• In I<sup>2</sup>C slave transmitter mode, a stop(P) or start (S) condition is received from the external I<sup>2</sup>C master device.</li> <li>• In I<sup>2</sup>C slave receiver mode, a stop(P) or start (S) condition is received from the external I<sup>2</sup>C master device and the RX FIFO is empty.</li> <li>• In SCCB master transmitter or receiver mode, a stop (P) condition is detected.</li> </ul> |
| RRDY event | I <sup>2</sup> C receive mode and SCCB read mode   | I2C <i>i</i> .I <sup>2</sup> C_STAT[3] RRDY | I2C <i>i</i> .I <sup>2</sup> C_IE[3] RRDY_IE | The RX FIFO level is above the threshold (I2C <i>i</i> .I <sup>2</sup> C_BUF[13:8] RTRSH bit field value + 1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| XRDY event | I <sup>2</sup> C transmit mode and SCCB write mode | I2C <i>i</i> .I <sup>2</sup> C_STAT[4] XRDY | I2C <i>i</i> .I <sup>2</sup> C_IE[4] XRDY_IE | The module requires new data to be served. A master transmitter module requests new data when the TX FIFO level is below the threshold (I2C <i>i</i> .I <sup>2</sup> C_BUF[5:0] XTRSH bit field value + 1) and the required amount of data to be transmitted specified by the I2C <i>i</i> .I <sup>2</sup> C_BUFSIZE[5:0] TXSTAT bit field is greater than the threshold. A slave transmitter requests new data when the TX FIFO is below the threshold (if the I2C <i>i</i> .I <sup>2</sup> C_BUF[5:0] XTRSH bit field value is greater than 1), or when there is a read request from the external master device (for each acknowledge received from the master) when the I2C <i>i</i> .I <sup>2</sup> C_BUF[5:0] XTRSH bit field value is 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| GC event   | I <sup>2</sup> C mode only                         | I2C <i>i</i> .I <sup>2</sup> C_STAT[5] GC   | I2C <i>i</i> .I <sup>2</sup> C_IE[5] GC_IE   | The module detects a general call on the I <sup>2</sup> C bus (all bits of the address cleared to 0).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**Table 17-9. HS I<sup>2</sup>C Interrupt Events (continued)**

| Event Name | Supported Configuration Mode               | Status Bit                | Mask Bit                   | This Event Happens When:                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|--------------------------------------------|---------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| STC event  | I <sup>2</sup> C mode only                 | I2Ci.I2C_STAT[6]<br>STC   | I2Ci.I2C_IE[6]<br>STC_IE   | The module is in idle mode and a start (S) condition is asynchronously detected on the I <sup>2</sup> C bus and signaled with a wakeup. When the active mode is restored and the interrupt generated, this bit indicates the reason for the wakeup. <sup>(1)</sup>                                                                                                                                                      |
| AERR event | I <sup>2</sup> C and SCCB modes            | I2Ci.I2C_STAT[7]<br>AERR  | I2Ci.I2C_IE[7]<br>AERR_IE  | A write access to the I2Ci.I2C_DATA register by the LH through the L4-Core interconnect is performed while the TX FIFO is full or a read access to the I2Ci.I2C_DATA register by the LH through the L4-Core interconnect is performed while the RX FIFO is empty. When the RX FIFO is empty, the read of the RX FIFO returns the previous read data value. When the TX FIFO is full, a write in the TX FIFO is ignored. |
| BF event   | I <sup>2</sup> C and SCCB modes            | I2Ci.I2C_STAT[8] BF       | I2Ci.I2C_IE[8]<br>BF_IE    | The I <sup>2</sup> C bus becomes free (after a transfer is ended on the bus and a stop [P] condition is detected).                                                                                                                                                                                                                                                                                                      |
| AAS event  | I <sup>2</sup> C mode only                 | I2Ci.I2C_STAT[9]<br>AAS   | I2Ci.I2C_IE[9]<br>AAS_IE   | The module has recognized its own slave address or an alternate Own Address, or a general call (all address bits cleared to 0).                                                                                                                                                                                                                                                                                         |
| XUDF event | I <sup>2</sup> C and SCCB transmit mode    | I2Ci.I2C_STAT[10]<br>XUDF | I2Ci.I2C_IE[10]<br>XUDF_IE | The module has recognized a transmission underflow interrupt event.                                                                                                                                                                                                                                                                                                                                                     |
| ROVR event | I <sup>2</sup> C and SCCB receive mode     | I2Ci.I2C_STAT[11]<br>ROVR | I2Ci.I2C_IE[11]<br>ROVR_IE | The module has recognized an overrun event on the receiving line.                                                                                                                                                                                                                                                                                                                                                       |
| RDR event  | I <sup>2</sup> C receive mode only         | I2Ci.I2C_STAT[13]<br>RDR  | I2Ci.I2C_IE[13]<br>RDR_IE  | The module is configured as a receiver, a stop (P) condition was received on the I <sup>2</sup> C bus, and the RX FIFO level is below the threshold (I2Ci.I2C_BUF[13:8] RTRSH bit field value + 1).                                                                                                                                                                                                                     |
| XDR event  | I <sup>2</sup> C master transmit mode only | I2Ci.I2C_STAT[14]<br>XDR  | I2Ci.I2C_IE[14]<br>XDR_IE  | The module is configured as a master transmitter, the TX FIFO level is below the threshold (I2Ci.I2C_BUF[5:0] XTRSH bit field value + 1), and the amount of data still to be transferred is less than this threshold.                                                                                                                                                                                                   |

<sup>(1)</sup> The interrupt request generation on an STC event must be enabled only if the module is configured to allow the possibility of switching off the functional clock while in IDLE state (the I2Ci.I2C\_SYSC[9:8] CLOCKACTIVITY bit field set to b00 or b01). The first transfer (corresponding to the detected start [S] condition) is lost, and is used only to restore the active mode of the module. On the I<sup>2</sup>C bus, the external master that generated the transfer detects this behavior as a nonacknowledge to the address phase and may possibly restart the transfer.

When an interrupt request is generated, software must read the I2Ci.I2C\_STAT register to check which event caused the interrupt request generation, process accordingly, and acknowledge each processed event by writing 1 to the corresponding bit in the I2Ci.I2C\_STAT register.

**NOTE:** The I2Ci.I2C\_STAT[9] AAS status bit, corresponding to the AAS event, can be cleared in two ways:

- If the I2Ci.I2C\_IE[9] AAS\_IE bit is set to 1 (interrupt generation enabled), the status bit is cleared by writing 1 to the I2Ci.I2C\_STAT[9] AAS status bit.
- If the I2Ci.I2C\_IE[9] AAS\_IE bit is cleared to 0 (interrupt generation disabled), the status bit is cleared when a new start(S) or stop (P) condition is detected on the I<sup>2</sup>C bus.

## 17.4 HS I<sup>2</sup>C Functional Description

### 17.4.1 HS I<sup>2</sup>C Block Diagram

Figure 17-21 is a functional block diagram of the HS I<sup>2</sup>C controllers.

**Figure 17-21. HS I<sup>2</sup>C Controllers Functional Block Diagram**



**NOTE:** The i2c1\_sccbe and i2c4\_sccbe signal is not available. The i2c4 does not have SWAKEUP request. It also gets its RESET signal from the PRCM reset manager.

The three HS I<sup>2</sup>C controllers can be configured in F/S I<sup>2</sup>C mode, in HS I<sup>2</sup>C mode, or in SCCB mode. The operation mode is selected by configuring the I2Ci.I2C\_CON[13:12] OPMODE bit field. Table 17-10 lists the available operation modes.

**Table 17-10. HS I<sup>2</sup>C Operation Mode Selection**

| Operation Mode       | I2C.I2C_CON[13:12] OPMODE Bit Field Value |
|----------------------|-------------------------------------------|
| F/S I <sup>2</sup> C | 0x0                                       |
| HS I <sup>2</sup> C  | 0x1                                       |
| SCCB                 | 0x2                                       |
| Reserved (not used)  | 0x3                                       |

### 17.4.2 HS I<sup>2</sup>C Transmit Mode in I<sup>2</sup>C Mode

This mode is available for master or slave. The master and slave modes are configurable with the I2Ci.I2C\_CON[10] MST bit (0: slave mode; 1: master mode).

In master mode, the transmit mode is configured by setting the I2Ci.I2C\_CON[9] TRX bit to 1. The MPU subsystem puts the data to transmit in the TX FIFO by writing to the I2Ci.I2C\_DATA[7:0] DATA bit field.

The transmitter can write new data to this register when the I2Ci.I2C\_STAT[4] XRDY bit is set to 1, or when the I2Ci.I2C\_STAT[14] XDR bit is set to 1 according to the draining mechanism description.

A master transmitter requests new data if the I2Ci.I2C\_CNT[15:0] DCOUNT bit field value is not 0. A slave transmitter requests new data if a read is performed by the external master.

---

**NOTE:** The HS I<sup>2</sup>C4 is configured in master transmitter mode, and its configuration cannot be changed.

---

#### 17.4.3 HS I<sup>2</sup>C Receive Mode in I<sup>2</sup>C Mode

This mode is available for master or slave mode. In master mode, it is configured by clearing the I2Ci.I2C\_CON[9] TRX bit to 0.

The MPU subsystem can read new data from the I2Ci.I2C\_DATA[15:0] DCOUNT bit field when the I2Ci.I2C\_STAT[3] RRDY bit is set to 1, or when the I2Ci.I2C\_STAT[13] RDR bit is set according to the description of the draining mechanism.

Each time the I2Ci.I2C\_STAT[3] RRDY bit is set to 1, if the interrupt is enabled (the I2Ci.I2C\_IE[3] RRDY\_IE bit must be set to 1), the I<sup>2</sup>C controller generates an interrupt to the MPU subsystem.

---

**NOTE:** In interrupt mode, the MPU subsystem must read this bit after each read in the I2Ci.I2C\_DATA register to ensure that no other data is waiting for the FIFO to be read. For a new interrupt to be received, the I2Ci.I2C\_STAT[3] RRDY bit must be cleared in the interrupt routine.

If the DMA receive mode is enabled (the I2Ci.I2C\_BUF[15] RDMA\_EN bit is set), this bit is forced to 0 and no interrupt is generated; instead, a DMA RX request to the sDMA controller is generated.

---

#### 17.4.4 HS I<sup>2</sup>C FIFO Management

Each HS I<sup>2</sup>C controller implements two internal 8-bit FIFOs, the RX and TX FIFOs. The FIFOs are fully configurable / controllable to deliver their carried signals to the targeted sink with maximum signal integrity. Configuration of the buffers is done by groups assignment and not individually per pad; each group is assigned a specific prg\_xxx register inside the System Control Module. Refer to [Chapter 13, System Control Module](#).

[Table 17-11](#) lists the depth of these FIFOs, depending on the instance of the I<sup>2</sup>C controller.

**Table 17-11. HS I<sup>2</sup>C RX and TX FIFO Depths**

| I <sup>2</sup> C Controller Instance | RX and TX FIFO Depth (in bytes) |
|--------------------------------------|---------------------------------|
| I2C1                                 | 8                               |
| I2C2                                 | 8                               |
| I2C3                                 | 64                              |

The depth of the RX and TX FIFOs can be checked by reading the I2Ci.I2C\_BUFSTAT[15:14] FIFODEPTH bit field (0x0: 8 bytes, 0x1: 16 bytes, 0x2: 32 bytes, and 0x3: 64 bytes).

##### 17.4.4.1 HS I<sup>2</sup>C FIFO Interrupt Mode Operation

In FIFO interrupt mode (relevant interrupts enabled by the I2Ci.I2C\_IE register), the processor is informed of the receiver and transmitter status by an interrupt signal. These interrupts are raised when the RX/TX FIFO thresholds (defined by the I2Ci.I2C\_BUF[13:8] RTRSH bit field value + 1 for the RX FIFO or the I2Ci.I2C\_BUF[5:0] XTRSH bit field value + 1 for the TX FIFO) are reached; the interrupt signals instruct the LH to transfer data to the destination (from the I<sup>2</sup>C controller in receive mode and/or from any source to the HS I<sup>2</sup>C controller FIFO in transmit mode).

Figure 17-22 and Figure 17-23 show receive and transmit operations, respectively, from a FIFO management point of view.

**Figure 17-22. HS I<sup>2</sup>C Receive FIFO Interrupt Request Generation**



In Figure 17-22, the RRDY interrupt condition shows that the condition for generating an RRDY interrupt is achieved. The interrupt request is generated when this signal is active, and it can be cleared only by the LH by writing 1 in the I2Ci.I2C\_STAT[3] RRDY bit. If the condition is still present after clearing the previous interrupt, another interrupt request is generated.

In receive mode, an RRDY interrupt is generated as soon as the FIFO reaches its receive threshold (the I2Ci.I2C\_BUF[13:8] RTRSH bit field value + 1). The interrupt can be deasserted only when the LH has handled enough bytes to make the number of bytes in the RX FIFO lower than the programmed threshold. For each interrupt, the LH can be configured to read a number of bytes equal to the value of the RX FIFO threshold.

---

**NOTE:** In SCCB mode, the RX and TX threshold values must be set to 1 by setting the I2Ci.I2C\_BUF[13:8] RTRSH and I2Ci.I2C\_BUF[5:0] XTRSH bit fields to 0x0.

---

**Figure 17-23. HS I<sup>2</sup>C Transmit FIFO Interrupt Request Generation**



In [Figure 17-23](#), the XRDY interrupt condition shows that the condition for generating an XRDY interrupt is achieved. The interrupt request is generated when TX FIFO is empty or when the TX FIFO threshold is not reached, and the LH can clear the XRDY status bit by writing 1 in the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_STAT[4] XRDY bit after transmitting the configured number of bytes. If the condition is still present after clearing the previous interrupt, another interrupt request is generated.

In interrupt mode, the module offers two options for the LH application to handle the interrupts:

- When detecting an interrupt request (XRDY/RRDY type), the LH can write/read 1 data byte to/from the TX/RX FIFO and then clear the interrupt. The module reasserts the interrupt until the interrupt condition is no longer met.
- When detecting an interrupt request (XRDY/RRDY type), the LH can be programmed to write/read the number of data bytes specified by the corresponding FIFO threshold (the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_BUF[5:0] XTRSH bit field value + 1 for the TX threshold or the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_BUF[13:8] RTRSH bit field value + 1 for the RX threshold). In this case, the interrupt condition is cleared and the next interrupt is asserted again when the XRDY/RRDY condition is met again.

If the second-interrupt-serving approach is used, an additional mechanism (draining feature) is implemented for cases where the transfer length is not a multiple of the FIFO threshold value (see [Section 17.4.4.4, HS I<sup>2</sup>C Draining Feature \(I<sup>2</sup>C Mode Only\)](#).

---

**NOTE:** In slave transmit mode (the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_CON[10] MST bit is cleared and the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_CON[9] TRX bit is set to 1), the draining feature must not be used, because the transfer length is not known at configuration time, and the external master can end the transfer at any point by not acknowledging 1 data byte. If the draining feature is used in slave transmit mode, data can remain in the TX FIFO without being transmitted over the I<sup>2</sup>C bus. In this case, the TX FIFO must be cleared by setting the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_BUF[6] TXFIFO\_CLR bit.

---

#### 17.4.4.2 HS I<sup>2</sup>C FIFO Polling Mode Operation

In FIFO polled mode (the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_IE[4] XRDY\_IE and I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_IE[3] RRDY\_IE bits are disabled, and the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_BUF[15] RDMA\_EN and I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_BUF[7] XDMA\_EN bits are disabled), the status of the module (receiver or transmitter) can be checked by polling the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_STAT[4] XRDY and the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_STAT[3] RRDY bits (the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_STAT[13] RDR and I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_STAT[14] XDR bits can also be polled if the draining feature is enabled). The I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_STAT[4] XRDY and I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_STAT[3] RRDY bits accurately reflect the interrupt conditions described in the discussion of the FIFO interrupt mode operation.

#### 17.4.4.3 HS I<sup>2</sup>C FIFO DMA Mode Operation (I<sup>2</sup>C Mode Only)

In receive mode, a DMA request is generated by the I<sup>2</sup>C\_DMA\_RX signal as soon as the RX FIFO exceeds its threshold level (the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_BUF[13:8] RTRSH bit field value + 1). This request is deasserted when the number of bytes defined by the threshold level is read by the sDMA controller.

[Figure 17-24](#) shows the DMA request generation in receive mode.

**Figure 17-24. HS I<sup>2</sup>C Receive FIFO DMA Request Generation**

In transmit mode, a DMA request is automatically asserted by the I2Ci\_DMA\_TX signal when the TX FIFO is empty. This request is deasserted when the number of bytes (the I2Ci.I2C\_BUF[5:0] XTRSH bit field value + 1) is written in the FIFO by the sDMA controller. If an insufficient number of bytes is written, the DMA request remains active. [Figure 17-25](#) and [Figure 17-26](#) show the DMA TX transfers with different values for the I2Ci.I2C\_BUF[5:0] XTRSH bit field.

**Figure 17-25. HS I<sup>2</sup>C Transmit FIFO Request Generation (High Threshold)**

**Figure 17-26. HS I<sup>2</sup>C Transmit FIFO Request Generation (Low Threshold)**

**NOTE:** In SCCB mode, the RX and TX threshold values must be set to 1 by setting the I2Ci.I2C\_BUF[13:8] RTRSH and I2Ci.I2C\_BUF[5:0] XTRSH bit fields to 0x0.

The I<sup>2</sup>C module allows the user to clear the RX or TX FIFO by setting the I2Ci.I2C\_BUF[14] RXFIFO\_CLR and I2Ci.I2C\_BUF[6] TXFIFO\_CLR bits, which act like software reset for the FIFOs. In DMA mode, these bits also reset the DMA state-machines. The FIFO clearing feature can be used when the following conditions are met:

- The module is configured as a transmitter.
- The external receiver responds with a NACK in the middle of the transfer.
- Data in the TX FIFO are still waiting to be transferred.

#### 17.4.4.4 HS I<sup>2</sup>C Draining Feature (I<sup>2</sup>C Mode Only)

The draining feature is implemented to handle the end of a transfer whose length is not a multiple of the FIFO threshold values (the I2Ci.I2C\_BUF[13:8] RTRSH bit field value + 1 for the RX threshold and the I2Ci.I2C\_BUF[5:0] XTRSH bit field value + 1 for the TX threshold). It also offers the possibility of transferring the remaining number of bytes (because the threshold is not reached).

This feature prevents the LH or the sDMA controller from trying more FIFO accesses than necessary (for example, to generate at the end of a transfer a DMA RX request having fewer bytes in the FIFO than the configured DMA transfer length). Otherwise, an AERR interrupt is generated by the I2Ci.I2C\_STAT[7] AERR bit.

The draining mechanism generates an interrupt using the I2Ci.I2C\_STAT[13] RDR or the I2Ci.I2C\_STAT[14] XDR bit at the end of the transfer, informing the LH that it must check the amount of data left to be transferred (the I2Ci.I2C\_BUFSTAT[13:8] RXSTAT or I2Ci.I2C\_BUFSTAT[5:0] TXSTAT bit fields) and enable the draining feature of the DMA controller by reconfiguring the DMA transfer length according to this value (when the DMA mode is enabled) or perform only the required number of data accesses (when the DMA mode is disabled).

In receive mode (master or slave), if the RX FIFO threshold (the I2Ci.I2C\_BUF[13:8] RTRSH bit field value + 1) is not reached, but the transfer ends on the I<sup>2</sup>C bus and there is still data in the RX FIFO (less than the threshold), the receive draining interrupt (the I2Ci.I2C\_STAT[13] RDR bit) is asserted to inform the LH that it can read the amount of data in the FIFO (the I2Ci.I2C\_BUFSTAT[13:8] RXSTAT bit field). The LH performs a number of data read accesses equal to the value of the I2Ci.I2C\_BUFSTAT[13:8] RXSTAT bit field value (interrupt or polling mode), or reconfigures the sDMA controller with the required value to drain the FIFO.

In master transmit mode, if the TX FIFO threshold (the I2Ci.I2C\_BUF[5:0] XTRSH bit field value + 1) is not reached, but the amount of data remaining to be written in the TX FIFO is less than the threshold, the transmit draining interrupt (the I2Ci.I2C\_STAT[14] XDR bit) is asserted to inform the LH that it can read the amount of data remaining to be written in the TX FIFO (the I2Ci.I2C\_BUFSTAT[5:0] TXSTAT bit field). The LH must write the required number of data bytes specified by the value of the I2Ci.I2C\_BUFSTAT[5:0] TXSTAT field value or reconfigure the sDMA controller with the value required to transfer the last bytes to the FIFO.

In master mode, the LH can alternately skip the checking of the value of the I2Ci.I2C\_BUFSTAT[5:0] TXSTAT and I2Ci.I2C\_BUFSTAT[13:8] RXSTAT bit fields, because it can obtain this information internally (by computing the value of the I2Ci.I2C\_CNT[15:0] DATACOUNT bit field modulo I2Ci.I2C\_BUF[13:8] RTRSH or I2Ci.I2C\_BUF[5:0] XTRSH).

By default, the draining feature is disabled; it can be enabled using the I2Ci.I2C\_IE[14] XDR\_IE or I2Ci.I2C\_IE[13] RDR\_IE bits (default disabled) only for transfers with lengths not equal to the threshold values (the I2Ci.I2C\_BUF[5:0] XTRSH bit field value + 1 for the TX threshold or the I2Ci.I2C\_BUF[13:8] RTRSH bit field value + 1 for the RX threshold).

#### 17.4.5 HS I<sup>C</sup> Programmable Multislave Channel Feature (I<sup>C</sup> Mode Only)

This feature allows each HS I<sup>C</sup> controller to be addressed using four separate Own Addresses configured in the I2Ci.I2C\_OAx registers (where x = 0, 1, 2, 3). An additional register (I2Ci.I2C\_ACTOA) is used to indicate to the LH which address is used by the external master to communicate with the I<sup>C</sup> controller.

Each Own Address can be independently configured in 7-bit or 10-bit mode by setting the corresponding bit (I2Ci.I2C\_CON[7] XOA0, I2Ci.I2C\_CON[6] XOA1, I2Ci.I2C\_CON[5] XOA2, or I2Ci.I2C\_CON[4] XOA3).

#### 17.4.6 HS I<sup>C</sup> Automatic Blocking of the I<sup>C</sup> Clock Feature (I<sup>C</sup> Mode Only)

This feature offers the possibility for the LH to command the blocking of the I<sup>C</sup> clock after the slave addressing phase, when the I<sup>C</sup> controller is addressed by an external master device using a certain Own Address.

The release of the I<sup>C</sup> clock (i2ci\_scl signal, where i = 1, 2, 3) can be performed independently for each Own Address (I2Ci.I2C\_OAi registers, where i = 0, 1, 2, 3) by deasserting the corresponding bit in the I2Ci.I2C\_SBLOCK register.

#### 17.4.7 HS I<sup>C</sup> Clocking

Figure 17-27 shows the I<sup>C</sup> clock generation of the HS I<sup>C</sup> controllers.

Figure 17-27. HS I<sup>C</sup> Clock Generation



Each HS I<sup>C</sup> controller uses the I2Ci\_FCLK functional clock in the PRCM module. The internal sampling clock I2Ci\_INTERNAL\_CLK is generated by dividing the functional clock by (the I2Ci.I2C\_PSC[7:0] PSC bit field value + 1) in F/S mode, in SCCB mode, or in the first phase of HS mode; or by directly using the functional clock in the second phase of HS mode (prescaler is bypassed).

The low time of the I2Ci\_SCL signal is determined by the I2Ci.I2C\_SCL[7:0] SCLL bit field in F/S mode, in SCCB mode, or in the first phase of HS mode; or by the I2Ci.I2C\_SCL[15:8] HSSCLL bit field in the second phase of HS mode.

The high time of the I<sup>2</sup>C<sub>i</sub>\_SCL signal is determined by the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SCLH[7:0] SCLH bit field in F/S mode, in SCCB mode, or in the first phase of HS mode; or by the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SCLH[15:8] HSSCLH bit field in the second phase of HS mode.

Table 17-12 lists the t<sub>LOW</sub> and t<sub>HIGH</sub> values in master mode only (in slave mode, the I<sup>2</sup>C controller does not generate the I<sup>2</sup>C clock).

**Table 17-12. HS I<sup>2</sup>C t<sub>LOW</sub> and t<sub>HIGH</sub> Values of the I<sup>2</sup>C Clock**

| Mode                         | I <sup>2</sup> C_INTERNAL_CLK                                                                                                                                             | t <sub>Low</sub>                                                                                                                                | t <sub>HIGH</sub>                                                                                                                                                                       |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F/S, SCCB, or HS first phase | I <sup>2</sup> C <sub>i</sub> _INTERNAL_CLK =<br>I <sup>2</sup> C <sub>i</sub> _FCLK /<br>(I <sup>2</sup> C <sub>i</sub> .I <sup>2</sup> C_PSC[7:0] PSC bit field +<br>1) | (I <sup>2</sup> C <sub>i</sub> .I <sup>2</sup> C_SCLH[7:0] SCLL bit field value + 7) x<br>I <sup>2</sup> C <sub>i</sub> _INTERNAL_CLK period    | (I <sup>2</sup> C <sub>i</sub> .I <sup>2</sup> C_SCLH[7:0] SCLH bit field value +<br>5 + t <sub>delay</sub> <sup>(1)</sup> ) x<br>I <sup>2</sup> C <sub>i</sub> _INTERNAL_CLK period    |
| HS second phase              | I <sup>2</sup> C <sub>i</sub> _FCLK                                                                                                                                       | (I <sup>2</sup> C <sub>i</sub> .I <sup>2</sup> C_SCLH[15:8] HSSCLL bit field value + 7) x<br>I <sup>2</sup> C <sub>i</sub> _INTERNAL_CLK period | (I <sup>2</sup> C <sub>i</sub> .I <sup>2</sup> C_SCLH[15:8] HSSCLH bit field value +<br>5 + t <sub>delay</sub> <sup>(1)</sup> ) x<br>I <sup>2</sup> C <sub>i</sub> _INTERNAL_CLK period |

<sup>(1)</sup> t<sub>delay</sub> = Internal propagation delay for I<sup>2</sup>C<sub>i</sub>\_SCL to consider process dispersion and voltage and temperature variations (PVT)  
t<sub>delay</sub> (min) = floor(36 ns/( I<sup>2</sup>C<sub>i</sub>\_INTERNAL\_CLK period))  
t<sub>delay</sub> (max) = floor(117 ns/( I<sup>2</sup>C<sub>i</sub>\_INTERNAL\_CLK period))

**NOTE:** The equations in Table 17-12 give the SCL timing values for SCLL/SCLH/HSSCLL/HSSCLH at HS I<sup>2</sup>C controller outputs. Actual t<sub>low</sub> and t<sub>high</sub> periods may vary, depending on the board (the load capacitance on the SCL signal). If necessary, any adjustments to the SCLL/SCLH/HSSCLL/HSSCLH values must be determined by measurements of actual SCL signal on the board

**NOTE:** For HS mode, the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SCLL[15:8] HSSCLL and I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SCLL[7:0] SCLL bit fields must be programmed (the first phase of an HS transaction is performed at F/S speed).

For HS mode, the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SCLH[15:8] HSSCLH and I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SCLH[7:0] SCLH bit fields must be programmed (the first phase of an HS transaction is performed at F/S speed).

#### CAUTION

During active mode (the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_CON[15] I<sup>2</sup>C\_EN bit is set to 1), make no changes to the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SCLL and I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SCLH registers. Changes may result in unpredictable behavior.

**NOTE:** Each HS I<sup>2</sup>C controller can be used with an internal secondary pullup. This pullup is mandatory when the I<sup>2</sup>C controller is configured in HS mode for a bit rate of 3.4 Mbps, and the bus line capacitance exceeds 45 pF. Pullups can be programmed through the CONTROL.CONTROL\_PROG\_IO1[19] PRG\_I2C1\_PULLUPRESX bit for I<sup>2</sup>C1, the CONTROL.CONTROL\_PROG\_IO1[0] PRG\_I2C2\_PULLUPRESX bit for I<sup>2</sup>C2, and the CONTROL.CONTROL\_PROG\_IO2[7] PRG\_I2C3\_PULLUPRESX bit for I<sup>2</sup>C3.

The maximum bit rate specified by the SCCB specifications is 100 Kbps.

#### 17.4.8 HS I<sup>2</sup>C Noise Filter

The noise filter is used to suppress any noise that is 50 ns or less in case of F/S and SCCB operation modes, and any noise that is 10 ns or less in case of HS mode operation. The noise filter is always one period of the I<sup>2</sup>C<sub>i</sub>\_INTERNAL\_CLK clock. This way, for HS mode operation (prescaler bypassed), the filter suppresses spikes of less than 10.4 ns.

For SCCB modes (for example, the I2Ci.I2C\_PSC[7:0] PSC bit field = 4), the maximum width of suppressed spikes is 52 ns.

To ensure correct filtering, the prescaler must be programmed accordingly by the 2Ci.I2C\_PSC[7:0] PSC bit field.

#### **17.4.9 HS I<sup>2</sup>C System Test Mode**

A system test mode is available for the HS I<sup>2</sup>C controller module testing. This mode is enabled by setting the I2Ci.I2C\_SYSTEST[15] ST\_EN to 1. When this bit is cleared to 0, the I<sup>2</sup>C controller is configured in normal operation mode.

In system test mode, the I2Ci\_SYSTEST[13:12] TMODE bit field selects the type of test. [Table 17-14](#) lists the tests available for the HS I<sup>2</sup>C controllers.

**Table 17-13. HS I<sup>2</sup>C List of tests for the HS I<sup>2</sup>C Controllers**

| I2Ci.I2C_SYSTEST[13:12]<br>] TMODE Bit Field Value | Test                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| b00                                                | Functional mode                                              | Normal operation mode                                                                                                                                                                                                                                                                                                                                                                       |
| b01                                                | Reserved (not used)                                          |                                                                                                                                                                                                                                                                                                                                                                                             |
| b10                                                | Test of i2ci_scl serial clock line                           | The i2ci_scl line is driven with a permanent clock as if mastered with the parameters set in the I2Ci.I2C_PSC, I2Ci.I2C_SCLL, and I2Ci.I2C_SCLH registers.                                                                                                                                                                                                                                  |
| b11                                                | Loop-back mode + i2ci_scl/ i2ci_sda/ i2ci_sccbe input/output | In the master transmit mode only, data transmitted out of the I2Ci.I2C_DATA register (write action) is received in the same I2Ci.I2C_DATA register through an internal path through the FIFO buffers. The DMA and interrupt requests are normally generated if they are enabled. Moreover, the i2ci_scl, i2ci_sda, and i2ci_sccbe lines are controlled with the I2Ci.I2C_SYSTEST[4:0] bits. |

---

**NOTE:** When the I2Ci.I2C\_SYSTEST[13:12] TMODE bit field = b11, the I<sup>2</sup>C controller must be configured in I<sup>2</sup>C F/S mode (I2Ci.I2C\_CON[13:12] OPMODE = b00) or I<sup>2</sup>C HS mode (I2Ci.I2C\_CON[13:12] OPMODE = b01). The loop-back mode is not available in SCCB mode (I2Ci.I2C\_CON[13:12] OPMODE = b10).

---

**NOTE:** In normal operation mode (I2Ci.I2C\_SYSTEST[15] ST\_EN clear to 0), the I2Ci.I2C\_SYSTEST[4:0] bits that control the i2ci\_scl, i2ci\_sda, and i2ci\_sccbe lines in system test mode are read-only bits.

---

In system test mode (the I2Ci.I2C\_SYSTEST[15] ST\_EN bit set to 1), the I2Ci.I2C\_STAT[5:0] status bits can be set to 1 when the I2Ci.I2C\_SYSTEST[11] SSB bit is set to 1. Clearing the I2Ci.I2C\_SYSTEST[11] SSB bit to 0 does not clear the I2Ci.I2C\_STAT[5:0] status bits to 0. The I2Ci.I2C\_STAT[5:0] status bits can be cleared to 0 only by writing 1 in the corresponding bits. In addition to the test modes, this actual data can be polled to see what is being inputted and outputted on the two clock and data lines. These tests are only available in functional mode. [Table 17-14](#) lists the data polling tests.

**Table 17-14. HS I<sup>2</sup>C List of Data In/Out Checks**

| I2Ci.I2C_SYSTEST Bit Field | Test                  | Description                                       |
|----------------------------|-----------------------|---------------------------------------------------|
| [8] SCL_I_FUNC             | SCL line input value  | Testing/reading incoming 1 or 0 on the clock line |
| [7] SCL_O_FUNC             | SCL line output value | Testing/reading outgoing 1 or 0 on the clock line |
| [6] SDA_I_FUNC             | SDA line input value  | Testing/reading incoming 1 or 0 on the data line  |
| [5] SDA_O_FUNC             | SDA line output value | Testing/reading outgoing 1 or 0 on the data line  |

### 17.4.10 HS I<sup>2</sup>C Write and Read Operations in SCCB Mode

In SCCB mode, the HS I<sup>2</sup>C controller can write or read a single byte to or from the external SCCB device.

To write a single byte to the external SCCB device, the HS I<sup>2</sup>C controller must be configured in multimaster transmitter mode by setting the I2Ci.I2C\_CON[10] MST and I2Ci.I2C\_CON[9] TRX bits to 1. The external device slave address (7-bit address of the ID value) is set in the I2Ci.I2C\_SA register; the register address (8-bit subaddress in the external SCCB device) is set in the I2Ci.I2C\_OA register. The 8-bit data to be transmitted is written by the LH in the I2Ci.I2C\_DATA register.

To read a single byte from the external SCCB device, the HS I<sup>2</sup>C controller must be configured in multimaster receiver mode by setting the I2Ci.I2C\_CON[10] MST to 1 and by clearing the I2Ci.I2C\_CON[9] TRX bit to 0. The external device slave address (7-bit address of the ID value) is set in the I2Ci.I2C\_SA register; the register address (8-bit subaddress in the external SCCB device) is set in the I2Ci.I2C\_OA register. The 8-bit data received from the external SCCB device is read by the LH from the I2Ci.I2C\_DATA register.

---

**NOTE:** In SCCB mode, the RX and TX thresholds must be set to 1 by configuring the I2Ci.I2C\_BUF[13:8] RTRSH and I2Ci.I2C\_BUF[5:0] XTRSH bit fields to 0x0.

---

### 17.4.11 HS I<sup>2</sup>C Power Chip Communication Operations

The master transmitter HS I<sup>2</sup>C controller I2C4 inside the voltage controller of the PRM module is used to send configuration commands from the LH to external power chip(s).

For voltage control operations, the LH must set the slave address of the first power chip in the PRCM.PRM\_VC\_SMPS\_SA[6:0] SA0 bit field, and the slave address of the second power chip (if necessary) in the PRCM.PRM\_VC\_SMPS\_SA[22:16] SA1 bit field.

The LH must also configure the specific registers in the voltage controller of the PRCM module, for the voltage control and power-sequencing functions.

A high-priority bypass mode is available to allow the LH to configure the external power chip(s) through the I<sup>2</sup>C bus. To write 8-bit data to the configuration registers of an external power chip, the LH must set the 7-bit external power chip slave address in the PRCM.PRM\_VC\_BYPASS\_VAL[6:0] SLAVEADDR bit field, the configuration register address in the PRCM.PRM\_VC\_BYPASS\_VAL[15:8] REGADDR bit field, and the 8-bit data in the PRCM.PRM\_BYPASS\_VAL[23:16] bit field.

For details about voltage control, see [Chapter 3, Power, Reset, and Clock Management](#).

## 17.5 HS I<sup>2</sup>C Basic Programming Model

### 17.5.1 HS I<sup>2</sup>C Controller Basic Programming Model in I<sup>2</sup>C Mode

This section describes the programming model of the multimaster HS I<sup>2</sup>C controllers configured in I<sup>2</sup>C mode.

#### 17.5.1.1 HS I<sup>2</sup>C Main Program (I<sup>2</sup>C Mode)

##### 17.5.1.1.1 HS I<sup>2</sup>C Configure the Module Before Enabling the I<sup>2</sup>C Controller (I<sup>2</sup>C Mode)

Before enabling the I<sup>2</sup>C controller, perform the following steps:

1. Enable the functional and interface clocks (see [Section 17.3.1.1.1, HS I<sup>2</sup>C Module Clocks](#)).
2. Program the prescaler to obtain an approximately 12-MHz internal sampling clock (I2Ci\_INTERNAL\_CLK) by programming the corresponding value in the I2Ci.I2C\_PSC[3:0] PSC bit field. This value depends on the frequency of the functional clock (I2Ci\_FCLK). Because this frequency is 96 MHz, the value of the I2Ci.I2C\_PSC[7:0] PSC bit field is 0x7.
3. Program the I2Ci.I2C\_SCLL[7:0] SCLL and I2Ci.I2C\_SCLH[7:0] SCLH bit fields to obtain a bit rate of 100 Kbps or 400 Kbps. These values depend on the internal sampling clock frequency (see [Table 17-12](#)).

4. (Optional) Program the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SCLL[15:8] HSSCLL and I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_SCLH[15:8] HSSCLH bit fields to obtain a bit rate of 400 Kbps or 3.4 Mbps (for the second phase of HS mode). These values depend on the internal sampling clock frequency (see [Table 17-12](#)).
5. (Optional) If a bit rate of 3.4 Mbps is used and the bus line capacitance exceeds 45 pF, program the CONTROL.CONTROL\_PROG\_IO1[19] PRG\_I2C1\_PULLUPRESX bit for I<sup>2</sup>C1, the CONTROL.CONTROL\_PROG\_IO1[0] PRG\_I2C2\_PULLUPRESX bit for I<sup>2</sup>C2, or the CONTROL.CONTROL\_PROG\_IO2[7] PRG\_I2C3\_PULLUPRESX bit for I<sup>2</sup>C3.
6. Configure the Own Address of the I<sup>2</sup>C controller by storing it in the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_OA register. Up to four Own Addresses can be programmed in the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_OAi registers (where i = 0, 1, 2, 3) for each I<sup>2</sup>C controller.

---

**NOTE:** For a 10-bit address, set the corresponding expand Own Address bit in the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_CON register.

---

7. Set the TX threshold (in transmitter mode) and the RX threshold (in receiver mode) by setting the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_BUF[5:0] XTRSH field to (TX threshold –1) and the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_BUF[13:8] RTRSH bit field to (RX threshold –1), where the TX and RX thresholds are greater than or equal to 1.
8. Take the I<sup>2</sup>C controller out of reset by setting the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_CON[15] I<sup>2</sup>C\_EN bit to 1.

#### 17.5.1.1.2 HS I<sup>2</sup>C Initialize the I<sup>2</sup>C Controller (I<sup>2</sup>C Mode)

To initialize the HS I<sup>2</sup>C controller, perform the following steps:

1. Configure the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_CON register:
  - For master or slave mode, set the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_CON[10] MST bit (0: slave; 1: master).
  - For transmitter or receiver mode, set the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_CON[9] TRX bit (0: receiver; 1: transmitter).
2. For a module that should work in master mode, set the CONTROL.CONTROL\_PADCONF\_x INPUTENABLE bit for the corresponding I<sup>2</sup>C module to achieve the synchronous clock on the clock output.
3. If using an interrupt to transmit/receive data, set the corresponding bit in the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_IE register to 1 (the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_IE[4] XRDY\_IE bit for the transmit interrupt, the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_IE[3] RRDY\_IE bit for the receive interrupt). Also, if needed enable the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_IE[11] ROVR\_IE bit for receiving start of draining on the internal FIFO interrupt. If using the HS I<sup>2</sup>C for transmitter the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_IE[10] XUDF\_IE for interrupting if underflow occurs on the internal FIFO.
4. If using DMA to receive/transmit data, set the corresponding bit in the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_BUF register to 1 (the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_BUF[15] RDMA\_EN bit for the receive DMA channel, the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_BUF[7] XDMA\_EN bit for the transmit DMA channel).

### 17.5.1.1.3 HS I<sup>2</sup>C Configure Slave Address and the Data Control Register (I<sup>2</sup>C Mode)

In master mode, configure the slave address register by programming the I2Ci.I2C\_SA[9:0] SA bit field and the number of data bytes (I<sup>2</sup>C data payload) associated with the transfer by programming the I2Ci.I2C\_CNT[15:0] DCOUNT bit field.

---

**NOTE:** For a 10-bit address, set the I2Ci.I2C\_CON[8] XSA bit to 1.

---

### 17.5.1.1.4 HS I<sup>2</sup>C Initiate a Transfer (I<sup>2</sup>C Mode)

Poll the I2Ci.I2C\_STAT[12] BB bit. If it is cleared to 0 (bus not busy), configure the I2Ci.I2C\_CON[0] STT and I2Ci.I2C\_CON[1] STP bits. To initiate a transfer, the I2Ci.I2C\_CON[0] STT bit must be set to 1, and it is not mandatory to set the I2Ci.I2C\_CON[1] STP bit to 1.

### 17.5.1.1.5 HS I<sup>2</sup>C Receive Data (I<sup>2</sup>C Mode)

Poll the I2Ci.I2C\_STAT[3] RRDY bit, or use the RRDY interrupt (the I2Ci.I2C\_IE[3] RRDY\_IE bit must be set to 1) or the DMA RX channel (the I2Ci.I2C\_BUF[15] RDMA\_EN bit must be set to 1) to read the receive data in the I2Ci.I2C\_DATA register.

If the transfer length does not equal the RX FIFO threshold (the I2Ci.I2C\_BUF[13:8] RTRSH bit field + 1), use the draining feature (enable the RDR interrupt by setting the I2Ci.I2C\_IE[13] RDR\_IE bit to 1).

---

**NOTE:** In receive mode only, the I2Ci.I2C\_STAT[11] ROVR (receive overrun) bit indicates whether the receiver has experienced overrun. An overrun condition occurs when the shift register and the RX FIFO are full. An overrun condition does not result in data loss; the I<sup>2</sup>C controller simply holds the serial clock line i2ci\_scl to low to prevent other bytes from being received.

The I2Ci.I2C\_STAT[7] AERR bit is set to 1 when a read access is performed in the I2Ci.I2C\_DATA register while the RX FIFO is empty. The corresponding interrupt can be enabled by setting the I2Ci.I2C\_IE[7] AERR\_IE bit to 1.

---

### 17.5.1.1.6 HS I<sup>2</sup>C Transmit Data (I<sup>2</sup>C Mode)

Poll the I2Ci.I2C\_STAT[4] XRDY bit, or use the XRDY interrupt (the I2Ci.I2C\_IE[4] XRDY\_IE bit must be set to 1) or the DMA TX channel (the I2Ci.I2C\_BUF[7] XDMA\_EN bit must be set to 1) to write data to the I2Ci.I2C\_DATA register.

If the transfer length does not equal the TX FIFO threshold (the I2Ci.I2C\_BUF[5:0] XTRSH bit field + 1), use the draining feature (enable the XDR interrupt by setting the I2Ci.I2C\_IE[14] XDR\_IE bit to 1).

---

**NOTE:** In transmit mode only, the I2Ci.I2C\_STAT[10] XUDF bit indicates whether the transmitter has experienced underflow.

In master transmit mode, underflow occurs when the shift register and the TX FIFO are empty and there are still some bytes to transmit (the I2Ci.I2C\_CNT[15:0] DCOUNT bit field value is not 0).

In slave transmit mode, underflow occurs when the shift register and the TX FIFO are empty and the external I<sup>2</sup>C master device still requests data bytes to be read.

The I2Ci.I2C\_STAT[7] AERR bit is set to 1 when a write access is performed in the I2Ci.I2C\_DATA register while the TX FIFO is full. The corresponding interrupt can be enabled by setting the I2Ci.I2C\_IE[7] AERR\_IE bit to 1.

Underflow interrupt on the FIFO can be also enabled from the I2Ci.I2C\_IE[10] XUDF\_IE bit.

---

### 17.5.1.2 HS I<sup>2</sup>C Interrupt Subroutine Sequence (I<sup>2</sup>C Mode)

Perform the following steps:

1. Test for arbitration lost (the I2Ci.I2C\_STAT[0] AL "status" bit) and resolve accordingly.
2. Test for no acknowledgment (the I2Ci.I2C\_STAT[1] NACK "status" bit) and resolve accordingly.
3. Test for register access ready (the I2Ci.I2C\_STAT[2] ARDY "status" bit) and resolve accordingly.
4. Test for receive data ready (the I2Ci.I2C\_STAT[3] RRDY "status" bit) and resolve accordingly.
5. Test for transmit data ready (the I2Ci.I2C\_STAT[4] XRDY "status" bit) and resolve accordingly.
6. Test for general call (the I2Ci.I2C\_STAT[5] GC "status" bit) and resolve accordingly.
7. Test for start (S) condition (the I2Ci.I2C\_STAT[6] STC "status" bit) and resolve accordingly. For this test, the functional clock must be inactive.
8. Test for access error (the I2Ci.I2C\_STAT[7] AERR "status" bit) and resolve accordingly.
9. Test for bus free (the I2Ci.I2C\_STAT[8] BF "status" bit) and resolve accordingly.

#### 17.5.1.3 HS I<sup>2</sup>C Programming Flow Diagrams (I<sup>2</sup>C Mode)

Figure 17-28 through Figure 17-36 are procedure flow charts for programming the I<sup>2</sup>C F/S and HS modes.

**Figure 17-28. HS I<sup>2</sup>C Mode Setup Procedure (I<sup>2</sup>C Mode)**

i2c-028

**Figure 17-29. HS I<sup>2</sup>C Master Transmitter Mode, Polling Method, in F/S and HS Modes (I<sup>2</sup>C Mode)**


- (1) The NACK, AL, ARDY, XDR, and XRDY bits are cleared by writing 1 to each corresponding bit in the I2C\_I2C\_STAT register.
- (2) Reprogram the registers means: I2C\_I2C\_CON[11] STB and/or I2C\_I2C\_CON[10] MST bit and/or I2C\_I2C\_SA[9:0] SA register and/or I2C\_I2C\_CNT[15:0] DCOUNT register and/or I2C\_I2C\_CON[0] STT bit and/or I2C\_I2C\_CON[1] STP bit.

**NOTE:** In HS mode, the Sr condition and the clock frequency switching are automatically generated by the multimaster HS I<sup>2</sup>C controller.

**Figure 17-30. HS I<sup>2</sup>C Master Receiver Mode, Polling Method, in F/S and HS Modes (I<sup>2</sup>C Mode)**

i2c-030

- (1) The NACK, AL, ARDY, RDR, and RRDY bits are cleared by writing 1 to each corresponding bit in the I<sup>2</sup>CSTAT register.
- (2) Reprogram registers means: I<sup>2</sup>C CON[11] STB and/or I<sup>2</sup>C CON[10] MST bit and/or I<sup>2</sup>C SA[9:0] SA register and/or I<sup>2</sup>C CNT[15:0] DCOUNT register and/or I<sup>2</sup>C CON[0] STT bit and/or I<sup>2</sup>C CON[1] STP bit.

**Figure 17-31. HS I<sup>2</sup>C Master Transmitter Mode, Interrupt Method, in F/S and HS Modes (I<sup>2</sup>C Mode)**



i2c-031

- (1) The NACK, AL, ARDY, XDR, and XRDY bits are cleared by writing 1 to each corresponding bit in the I2C.I2C\_STAT register.
- (2) Reprogram registers means: I2C.I2C\_CON[11] STB and/or I2C.I2C\_CON[10] MST bit and/or I2C.I2C\_SA[9:0] SA register and/or I2C.I2C\_CNT[15:0] DCOUNT register and/or I2C.I2C\_CON[0] STT bit and/or I2C.I2C\_CON[1] STP bit.

**NOTE:** In HS mode, the Sr condition and the clock frequency switching are automatically generated by the multimaster HS I<sup>2</sup>C controller.

**Figure 17-32. HS I<sup>2</sup>C Master Receiver Mode, Interrupt Method, in F/S and HS Modes (I<sup>2</sup>C Mode)**

i2c-032

- (1) The NACK, AL, ARDY, RDR, and RRDY bits are cleared by writing 1 to each corresponding bit in the I<sup>2</sup>C/I<sup>2</sup>C\_STAT register.
- (2) Reprogram registers means: I<sup>2</sup>C/I<sup>2</sup>C\_CON[11] STB and/or I<sup>2</sup>C/I<sup>2</sup>C\_CON[10] MST bit and/or I<sup>2</sup>C/I<sup>2</sup>C\_SA[9:0] SA register and/or I<sup>2</sup>C/I<sup>2</sup>C\_CNT[15:0] DCOUNT register and/or I<sup>2</sup>C/I<sup>2</sup>C\_CON[0] STT bit and/or I<sup>2</sup>C/I<sup>2</sup>C\_CON[1] STP bit.

**Figure 17-33. HS I<sup>2</sup>C Master Transmitter Mode, DMA Method in F/S and HS Modes (I<sup>2</sup>C Mode)**



i2c-033

- (1) The NACK, AL, ARDY, and XDR bits are cleared by writing 1 to each corresponding bit in the I2C/I2C\_STAT register.
- (2) Reprogram registers means: I2C/I2C\_CON[11] STB and/or I2C/I2C\_CON[10] MST bit and/or I2C/I2C\_SA[9:0] SA register and/or I2C/I2C\_CNT[15:0] DCOUNT register and/or I2C/I2C\_CON[0] STT bit and/or I2C/I2C\_CON[1] STP bit.

**NOTE:** In HS mode, the Sr condition and the clock frequency switching are automatically generated by the multimaster HS I<sup>2</sup>C controller.

**Figure 17-34. HS I<sup>2</sup>C Master Receiver Mode, DMA Method in F/S and HS Modes (I<sup>2</sup>C Mode)**

i2c-035

- (1) The XRDY, RDR, RRDY and ARDY bits are cleared by writing 1 to each corresponding bit in the I2Ci.I2C\_STAT register.
- (2) Reprogram registers means: I2Ci.I2C\_CON[11] STB and/or I2Ci.I2C\_CON[10] MST bit and/or I2Ci.I2C\_SA[9:0] SA register and/or I2Ci.I2C\_CNT[15:0] DCOUNT register and/or I2Ci.I2C\_CON[0] STT bit and/or I2Ci.I2C\_CON[1] STP bit.

**Figure 17-35. HS I<sup>2</sup>C Slave Transmitter/Receiver Mode, Polling (I<sup>2</sup>C Mode)**



i2c-035

- (1) The NACK, AL, ARDY and RDR bits are cleared by writing 1 to each corresponding bit in the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_STAT register.
- (2) In slave transmitter mode, the amount of data requested by the external master I<sup>2</sup>C device is unknown; thus, the I<sup>2</sup>C<sub>i</sub>.I<sup>2</sup>C\_BUFBUF[5:0] XTRSH bit field must be configured to 0x0 (TX threshold = 1).

**Figure 17-36. HS I<sup>2</sup>C Slave Transmitter/Receiver Mode, Interrupt (I<sup>2</sup>C Mode)**

i2c-036

- (1) The XRDY, RDR, RRDY, and ARDY bits are cleared by writing 1 to each corresponding bit in the I2Ci.I2C\_STAT register.
- (2) In slave transmitter mode, the amount of data requested by the external master I<sup>2</sup>C device is unknown; thus, the I2Ci.I2C\_BUF[5:0] XTRSH bit field must be configured to 0x0 (TX threshold = 1).

## 17.5.2 HS I<sup>2</sup>C Controller Basic Programming Model in SCCB Mode

This section describes the programming model of the multimaster HS I<sup>2</sup>C controllers configured in SCCB mode.

### 17.5.2.1 HS I<sup>2</sup>C Main Program (SCCB Mode)

#### 17.5.2.1.1 HS I<sup>2</sup>C Configure the Module Before Enabling the I<sup>2</sup>C Controller (SCCB Mode)

Before enabling the I<sup>2</sup>C controller, perform the following steps:

1. Enable the functional and interface clocks (see [Section 17.3.1.1.1, HS I<sup>2</sup>C Module Clocks](#)).
2. Program the prescaler to obtain an approximately 12-MHz internal sampling clock (the I2Ci\_INTERNAL\_CLK) by programming the corresponding value in the I2Ci.I2C\_PSC[7:0] PSC bit field. This value depends on the frequency of the functional clock (the I2Ci\_FCLK). Because this frequency is 96 MHz, the value of I2Ci.I2C\_PSC[7:0] PSC bit field is 0x7.
3. Program the I2Ci.I2C\_SCLL[7:0] SCLL and I2Ci.I2C\_SCLH[7:0] SCLH bit fields to obtain a bit rate of 100 Kbps (maximum authorized bit rate in SCCB mode). This value depends on the internal sampling clock frequency (see [Table 17-12](#)).
4. Configure the 7-bit slave address (ID value) by storing it in the I2Ci.I2C\_SA register.

5. Configure the 8-bit register address (subaddress) by storing it in the I2Ci.I2C\_OA0 register.
6. Configure the I2Ci.I2C\_BUF[13:8] RTRSH bit field to 0x0 (RX threshold to 1) and the I2Ci.I2C\_BUF[5:0] XTRSH bit field to 0x0 (TX threshold to 1).
7. Take the I<sup>2</sup>C controller out of reset by setting the I2Ci.I2C\_CON[15] I2C\_EN bit to 1.

#### 17.5.2.1.2 HS I<sup>2</sup>C Initialize the I<sup>2</sup>C Controller (SCCB Mode)

To initialize the I<sup>2</sup>C controller, perform the following steps:

1. Configure the I2Ci.I2C\_CON register:
  - In SCCB mode, only the master mode is supported; set the I2Ci.I2C\_CON[10] MST bit to 1.
  - For transmitter mode (write to the external SCCB device register) or receiver mode (read from the external SCCB device register), set the I2Ci.I2C\_CON[9] TRX bit (0: receiver; 1: transmitter).
2. Set the CONTROL.CONTROL\_PADCONF\_x.INPUTENABLE bit for the corresponding I<sup>2</sup>C module to achieve the synchronous clock on the clock output.
3. If using an interrupt to transmit/receive data, set the corresponding bit in the I2Ci.I2C\_IE register to 1 (the I2Ci.I2C\_IE[4] XRDY\_IE bit for the transmit interrupt, the I2Ci.I2C\_IE[3] RRDY bit for the receive interrupt). Also, if needed enable the I2Ci.I2C\_IE[11] ROVR\_IE bit for receiving start of draining on the internal FIFO interrupt. If using the HS I<sup>2</sup>C for transmitter the I2Ci.I2C\_IE[10] XUDF\_IE bit for interrupting if underflow occurs on the internal FIFO.

#### 17.5.2.1.3 HS I<sup>2</sup>C Initiate a Transfer (SCCB Mode)

Poll the I2Ci.I2C\_STAT[12] BB bit. If it is cleared to 0 (bus not busy), set the I2Ci.I2C\_CON[0] STT bit to 1. Because a transfer allows the LH to write or read only a single byte to or from the external SCCB device, the transmission automatically stops at the end of the transfer. When the transfer completes, the I2Ci.I2C\_STAT[2] ARDY bit is set to 1. In SCCB mode, the I2Ci.I2C\_CON[1] STP bit is not used.

#### 17.5.2.1.4 HS I<sup>2</sup>C Receive Data (SCCB Mode)

Poll the I2Ci.I2C\_STAT[3] RRDY bit, or use the RRDY interrupt (the I2Ci.I2C\_IE[3] RRDY\_IE bit must be set to 1) to read the receive data in the I2Ci.I2C\_DATA register.

**NOTE:** In SCCB mode, the I2Ci.I2C\_BUF[13:8] RTRSH bit field (RX threshold) must be set to a value of 0x0 (RX threshold = 1).

#### 17.5.2.1.5 HS I<sup>2</sup>C Transmit Data (SCCB Mode)

Poll the I2Ci.I2C\_STAT[4] XRDY bit, or use the XRDY interrupt (the I2Ci.I2C\_IE[4] XRDY\_IE bit must be set to 1) to write the data to the I2Ci.I2C\_DATA register.

**NOTE:** In SCCB mode, the I2Ci.I2C\_BUF[5:0] XTRSH bit field (TX threshold) must be set to a value of 0x0 (TX threshold = 1).

#### 17.5.2.2 HS I<sup>2</sup>C Interrupt Subroutine Sequence (SCCB Mode)

Perform the following steps:

1. Test for register access ready (the I2Ci.I2C\_STAT[2] ARDY status bit) and resolve accordingly.
2. Test for receive data ready (the I2Ci.I2C\_STAT[3] RRDY status bit) and resolve accordingly.
3. Test for transmit data ready (the I2Ci.I2C\_STAT[4] XRDY status bit) and resolve accordingly.

#### 17.5.2.3 HS I<sup>2</sup>C Programming Flow Diagrams (SCCB Mode)

Figure 17-37 through Figure 17-41 are procedure flow charts for programming the SCCB mode.

**Figure 17-37. HS I<sup>2</sup>C Setup Procedure (SCCB Mode)**

i2c-037

**Figure 17-38. HS I<sup>C</sup> Master Transmitter Mode, Polling (SCCB Mode)**

i2c-038

**NOTE:** The XRDY and ARDY bits are cleared by writing 1 to the corresponding bit in the I2Ci.I2C\_STAT register.

**Figure 17-39. HS I<sup>2</sup>C Master Receiver Mode, Polling (SCCB Mode)**

i2c-039

**NOTE:** The RRDY and ARDY bits are cleared by writing 1 in the corresponding bit in the I2Ci.I2C\_STAT register.

**Figure 17-40. HS I<sup>2</sup>C Master Transmitter Mode, Interrupt (SCCB Mode)**


 I<sup>2</sup>C-040

**NOTE:** The XRDY and ARDY bits are cleared by writing 1 in the corresponding bit in the I2Ci.I2C\_STAT register.

**Figure 17-41. HS I<sup>2</sup>C Master Receiver Mode, Interrupt (SCCB Mode)**

I2c-041

**NOTE:** The RRDY and ARDY bits are cleared by writing 1 in the corresponding bit in the I2Ci.I2C\_STAT register.

### 17.5.3 HS I<sup>2</sup>C Controller I<sup>2</sup>C4 Basic Programming Model for Communication With Power Chips

This section describes the programming model of master transmitter HS I<sup>2</sup>C4 for communication with one or more power chips. I<sup>2</sup>C4 allows the two voltage finite state machines (FSMs) in the PRCM module of the device to be interfaced to external power chips through the I<sup>2</sup>C bus for dynamic voltage control of two power supplies and power sequencing. The primary programming tasks are to set up the configuration registers according to the external power supply chip(s) being used.

#### 17.5.3.1 HS I<sup>2</sup>C Configure the Voltage Controller Registers

To use the voltage control function, the LH must configure the following registers in the voltage controller of the PRCM module:

- The voltage configuration register address for each VDD channel in the PRCM.PRM\_VC\_SMPS\_RA register
- The ON/ON-low-power-Retention/OFF command configuration register address for each VDD channel in the PRCM.PRM\_VC\_SMPS\_CMD\_RA register
- The set of ON/ON-low-power/Retention/OFF voltage/mode values in the PRCM.  
PRM\_VC\_CMD\_VAL\_0 register for the first VDD channel and the PRCM.  
PRM\_VC\_CMD\_VAL\_1 register for the second VDD channel
- The VDD channels configuration selection in the PRCM.PRM\_VC\_CH\_CONF register

For details about voltage controller register configuration, see [Chapter 3, Power, Reset, and Clock Management](#).

#### 17.5.3.2 HS I<sup>2</sup>C Configure the HS I<sup>2</sup>C4

At power-on reset (PoR), the I<sup>2</sup>C4 is in HS mode (the PRCM.PRM\_VC\_I<sup>2</sup>C\_CFG[3] HSEN bit). In HS mode, the LH must configure the master code value for the preamble I<sup>2</sup>C HS transmission by configuring the PRCM.PRM\_VC\_I<sup>2</sup>C\_CFG[2:0] MCODE bit field. If the external power chips do not support the I<sup>2</sup>C HS mode, the HS mode can be disabled and F/S mode enabled by clearing the PRCM.PRM\_VC\_I<sup>2</sup>C\_CFG[3] HSEN bit to 0.

By default, the repeated start operation is enabled (the PRCM.PRM\_VC\_I<sup>2</sup>C\_CFG[4] SREN bit is set to 1 at PoR). In F/S mode, the repeated start operation can be disabled by clearing the PRCM.PRM\_VC\_I<sup>2</sup>C\_CFG[4] SREN bit to 0.

#### 17.5.3.3 HS I<sup>2</sup>C Configure the External Power Chip(s)

The LH can send configuration commands from one bypass input to the external power chip(s), using the same I<sup>2</sup>C interface. To send a configuration command, the LH must process as follows:

- Check whether the transmission of a configuration command is ongoing by polling the PRCM.PRM\_VC\_BYPASS\_VAL[24] VALID bit (1: a transmission is ongoing, 0: a new transmission can start).
- Set the external power chip 7-bit slave address in the PRCM.PRM\_VC\_BYPASS\_VAL[6:0] SLAVEADDR bit field, set the configuration register address of the external power chip in the PRCM.PRM\_VC\_BYPASS\_VAL[15:8] REGADDR bit field, and set the data to be written to the external power chip configuration register in the PRCM.PRM\_VC\_BYPASS\_VAL[23:16] DATA bit field.
- Set the PRCM.PRM\_VC\_BYPASS\_VAL[24] VALID bit to 1 to send the configuration command to the external power chip.

## 17.6 HS I<sup>2</sup>C Register Manual

### CAUTION

The HS I<sup>2</sup>C<sub>i</sub> registers are limited to 16 bit and 8 bit data accesses; 32-bit data access is not allowed and can corrupt register content.

**NOTE:** For register configuration of HS I<sup>2</sup>C controller I2C4, see [Chapter 3, Power, Reset, and Clock Management](#).

[Table 17-15](#) provides the instance summary.

### 17.6.1 HS I<sup>2</sup>C Instance Summary

[Table 17-15](#) provides the instance summary.

**Table 17-15. HS I<sup>2</sup>C Instance Summary**

| Module Name          | Base Address | Size      |
|----------------------|--------------|-----------|
| HS I <sup>2</sup> C1 | 0x4807 0000  | 512 bytes |
| HS I <sup>2</sup> C2 | 0x4807 2000  | 512 bytes |
| HS I <sup>2</sup> C3 | 0x4806 0000  | 512 bytes |

### 17.6.2 HS I<sup>2</sup>C Registers

#### 17.6.2.1 HS I<sup>2</sup>C Register Summary

[Table 17-16](#) lists the I<sup>2</sup>C<sub>i</sub> registers (where  $i = 1, 2$  and  $3$ ).

**Table 17-16. HS I<sup>2</sup>C Registers Mapping Summary**

| Register Name            | Type | Register Width (Bits) | Address Offset | Physical Address for HS I <sup>2</sup> C1 | Physical Address for HS I <sup>2</sup> C2 | Physical Address for HS I <sup>2</sup> C3 |
|--------------------------|------|-----------------------|----------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|
| I <sup>2</sup> C_REV     | R    | 16                    | 0x00           | 0x4807 0000                               | 0x4807 2000                               | 0x4806 0000                               |
| I <sup>2</sup> C_IE      | RW   | 16                    | 0x04           | 0x4807 0004                               | 0x4807 2004                               | 0x4806 0004                               |
| I <sup>2</sup> C_STAT    | RW   | 16                    | 0x08           | 0x4807 0008                               | 0x4807 2008                               | 0x4806 0008                               |
| I <sup>2</sup> C_WE      | RW   | 16                    | 0x0C           | 0x4807 000C                               | 0x4807 200C                               | 0x4806 000C                               |
| I <sup>2</sup> C_SYSS    | R    | 16                    | 0x10           | 0x4807 0010                               | 0x4807 2010                               | 0x4806 0010                               |
| I <sup>2</sup> C_BUF     | RW   | 16                    | 0x14           | 0x4807 0014                               | 0x4807 2014                               | 0x4806 0014                               |
| I <sup>2</sup> C_CNT     | RW   | 16                    | 0x18           | 0x4807 0018                               | 0x4807 2018                               | 0x4806 0018                               |
| I <sup>2</sup> C_DATA    | RW   | 16                    | 0x1C           | 0x4807 001C                               | 0x4807 201C                               | 0x4806 001C                               |
| I <sup>2</sup> C_SYSC    | RW   | 16                    | 0x20           | 0x4807 0020                               | 0x4807 2020                               | 0x4806 0020                               |
| I <sup>2</sup> C_CON     | RW   | 16                    | 0x24           | 0x4807 0024                               | 0x4807 2024                               | 0x4806 0024                               |
| I <sup>2</sup> C_OA0     | RW   | 16                    | 0x28           | 0x4807 0028                               | 0x4807 2028                               | 0x4806 0028                               |
| I <sup>2</sup> C_SA      | RW   | 16                    | 0x2C           | 0x4807 002C                               | 0x4807 202C                               | 0x4806 002C                               |
| I <sup>2</sup> C_PSC     | RW   | 16                    | 0x30           | 0x4807 0030                               | 0x4807 2030                               | 0x4806 0030                               |
| I <sup>2</sup> C_SCLL    | RW   | 16                    | 0x34           | 0x4807 0034                               | 0x4807 2034                               | 0x4806 0034                               |
| I <sup>2</sup> C_SCLH    | RW   | 16                    | 0x38           | 0x4807 0038                               | 0x4807 2038                               | 0x4806 0038                               |
| I <sup>2</sup> C_SYSTEST | RW   | 16                    | 0x3C           | 0x4807 003C                               | 0x4807 203C                               | 0x4806 003C                               |
| I <sup>2</sup> C_BUFSTAT | R    | 16                    | 0x40           | 0x4807 0040                               | 0x4807 2040                               | 0x4806 0040                               |
| I <sup>2</sup> C_OA1     | RW   | 16                    | 0x44           | 0x4807 0044                               | 0x4807 2044                               | 0x4806 0044                               |
| I <sup>2</sup> C_OA2     | RW   | 16                    | 0x48           | 0x4807 0048                               | 0x4807 2048                               | 0x4806 0048                               |

**Table 17-16. HS I<sup>2</sup>C Registers Mapping Summary (continued)**

| Register Name           | Type | Register Width (Bits) | Address Offset | Physical Address for HS I <sup>2</sup> C1 | Physical Address for HS I <sup>2</sup> C2 | Physical Address for HS I <sup>2</sup> C3 |
|-------------------------|------|-----------------------|----------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|
| I <sup>2</sup> C_OA3    | RW   | 16                    | 0x4C           | 0x4807 004C                               | 0x4807 204C                               | 0x4806 004C                               |
| I <sup>2</sup> C_ACTOA  | R    | 16                    | 0x50           | 0x4807 0050                               | 0x4807 2050                               | 0x4806 0050                               |
| I <sup>2</sup> C_SBLOCK | RW   | 16                    | 0x54           | 0x4807 0054                               | 0x4807 2054                               | 0x4806 0054                               |

### 17.6.2.2 HS I<sup>2</sup>C Register Summary

**Table 17-17. I<sup>2</sup>C\_REV**

|                         |                                                                                               |                                                                                                     |    |    |    |   |   |   |   |   |   |   |   |   |             |                    |
|-------------------------|-----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|----|----|----|---|---|---|---|---|---|---|---|---|-------------|--------------------|
| <b>Address Offset</b>   | 0x00                                                                                          |                                                                                                     |    |    |    |   |   |   |   |   |   |   |   |   |             |                    |
| <b>Physical Address</b> | 0x4806 0000                                                                                   |                                                                                                     |    |    |    |   |   |   |   |   |   |   |   |   |             |                    |
|                         | Instance                                                                                      |                                                                                                     |    |    |    |   |   |   |   |   |   |   |   |   |             |                    |
|                         | I <sup>2</sup> C3                                                                             |                                                                                                     |    |    |    |   |   |   |   |   |   |   |   |   |             |                    |
| <b>Description</b>      | IP Revision Identifier (X.Y.R)<br>Used by software to track features, bugs, and compatibility |                                                                                                     |    |    |    |   |   |   |   |   |   |   |   |   |             |                    |
| <b>Type</b>             | R                                                                                             |                                                                                                     |    |    |    |   |   |   |   |   |   |   |   |   |             |                    |
| 15                      | 14                                                                                            | 13                                                                                                  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           |                    |
| REVISION                |                                                                                               |                                                                                                     |    |    |    |   |   |   |   |   |   |   |   |   |             |                    |
| <b>Bits</b>             | <b>Field Name</b>                                                                             | <b>Description</b>                                                                                  |    |    |    |   |   |   |   |   |   |   |   |   | <b>Type</b> | <b>Reset</b>       |
| 15:8                    | Reserved                                                                                      | Read returns 0.                                                                                     |    |    |    |   |   |   |   |   |   |   |   |   | R           | 0x00               |
| 7:0                     | REV                                                                                           | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision<br>Examples: 0x30 for 3.0, 0x31 for 3.1 |    |    |    |   |   |   |   |   |   |   |   |   | R           | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 17-18. Register Call Summary for Register I<sup>2</sup>C\_REV**

HS I<sup>2</sup>C Register Manual

- [HS I<sup>2</sup>C Register Summary: \[0\]](#)

**Table 17-19. I<sup>2</sup>C\_IE**

|                         |                                                                                               |        |          |         |         |        |       |         |        |       |         |         |         |         |       |
|-------------------------|-----------------------------------------------------------------------------------------------|--------|----------|---------|---------|--------|-------|---------|--------|-------|---------|---------|---------|---------|-------|
| <b>Address Offset</b>   | 0x04                                                                                          |        |          |         |         |        |       |         |        |       |         |         |         |         |       |
| <b>Physical Address</b> | 0x4806 0004                                                                                   |        |          |         |         |        |       |         |        |       |         |         |         |         |       |
|                         | Instance                                                                                      |        |          |         |         |        |       |         |        |       |         |         |         |         |       |
|                         | I <sup>2</sup> C3                                                                             |        |          |         |         |        |       |         |        |       |         |         |         |         |       |
| <b>Description</b>      | I <sup>2</sup> C interrupt enable register. This register contains the interrupt enable bits. |        |          |         |         |        |       |         |        |       |         |         |         |         |       |
| <b>Type</b>             | RW                                                                                            |        |          |         |         |        |       |         |        |       |         |         |         |         |       |
| 15                      | 14                                                                                            | 13     | 12       | 11      | 10      | 9      | 8     | 7       | 6      | 5     | 4       | 3       | 2       | 1       | 0     |
| RESERVED                | XDR_IE                                                                                        | RDR_IE | RESERVED | ROVR_IE | XUDF_IE | AAS_IE | BF_IE | AERR_IE | STC_IE | GC_IE | XRDY_IE | RRDY_IE | ARDY_IE | NACK_IE | AL_IE |

HS I<sup>C</sup> Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                   | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15   | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                            | RW   | 0     |
| 14   | XDR_IE     | Transmit Draining interrupt enable. Mask or unmask the interrupt signaled by the bit in I <sub>2</sub> C_STAT[XDR].<br><br>0x0: Transmit Draining interrupt disabled<br>0x1: Transmit Draining interrupt enabled              | RW   | 0     |
| 13   | RDR_IE     | Receive Draining interrupt enable. Mask or unmask the interrupt signaled by the bit in I <sub>2</sub> C_STAT[RDR].<br><br>0x0: Receive Draining interrupt disabled<br>0x1: Receive Draining interrupt enabled                 | RW   | 0     |
| 12   | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                            | RW   | 0x0   |
| 11   | ROVR_IE    | Receive overrun enable set.<br><br>0x0: Receive overrun interrupt disabled<br>0x1: Receive Draining interrupt enabled                                                                                                         | RW   | 0     |
| 10   | XUDF_IE    | Transmit underflow enable set.<br><br>0x0: Transmit underflow interrupt disabled<br>0x1: Transmit underflow interrupt enabled                                                                                                 | RW   | 0     |
| 9    | AAS_IE     | Addressed as Slave interrupt enable. Mask or unmask the interrupt signaled by the bit in I <sub>2</sub> C_STAT[AAS].<br><br>0x0: Addressed as Slave interrupt disabled<br>0x1: Addressed as Slave interrupt enabled           | RW   | 0     |
| 8    | BF_IE      | Bus Free interrupt enable. Mask or unmask the interrupt signaled by the bit in I <sub>2</sub> C_STAT[BF].<br><br>0x0: Bus Free interrupt disabled<br>0x1: Bus Free interrupt enabled                                          | RW   | 0     |
| 7    | AERR_IE    | Access Error interrupt enable. Mask or unmask the interrupt signaled by the bit in I <sub>2</sub> C_STAT[AERR].<br><br>0x0: Access Error interrupt disabled<br>0x1: Access Error interrupt enabled                            | RW   | 0     |
| 6    | STC_IE     | Start Condition interrupt enable. Mask or unmask the interrupt signaled by the bit in I <sub>2</sub> C_STAT[STC].<br><br>0x0: Start Condition interrupt disabled<br>0x1: Start Condition interrupt enabled                    | RW   | 0     |
| 5    | GC_IE      | General Call interrupt enable. Mask or unmask the interrupt signaled by the bit in I <sub>2</sub> C_STAT[GC].<br><br>0x0: General Call interrupt disabled<br>0x1: General Call interrupt enabled                              | RW   | 0     |
| 4    | XRDY_IE    | Transmit data ready interrupt enable. Mask or unmask the interrupt signaled by bit in I <sub>2</sub> C_STAT[XRDY]<br><br>0x0: Transmit Data Ready interrupt disabled<br>0x1: Transmit Data Ready interrupt enabled            | RW   | 0     |
| 3    | RRDY_IE    | Receive Data Ready interrupt enable. Mask or unmask the interrupt signaled by the bit in I <sub>2</sub> C_STAT[RRDY].<br><br>0x0: Receive Data Ready interrupt disabled<br>0x1: Receive Data Ready interrupt enabled          | RW   | 0     |
| 2    | ARDY_IE    | Register Access Ready interrupt enable. Mask or unmask the interrupt signaled by the bit in I <sub>2</sub> C_STAT[ARDY].<br><br>0x0: Register Access Ready interrupt disabled<br>0x1: Register Access Ready interrupt enabled | RW   | 0     |
| 1    | NACK_IE    | No Acknowledgment interrupt enable. Mask or unmask the interrupt signaled by the bit in I <sub>2</sub> C_STAT[NACK].<br><br>0x0: No Acknowledge interrupt disabled<br>0x1: No Acknowledge Ready interrupt enabled             | RW   | 0     |

| Bits | Field Name | Description                                                                                                                                                                                                  | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | AL_IE      | Arbitration Lost interrupt enable. Mask or unmask the interrupt signaled by the bit in I <sub>2</sub> C_STAT[AL].<br><br>0x0: Arbitration Lost interrupt disabled<br>0x1: Arbitration Lost interrupt enabled | RW   | 0     |
|      |            |                                                                                                                                                                                                              |      |       |
|      |            |                                                                                                                                                                                                              |      |       |

**Table 17-20. Register Call Summary for Register I<sub>2</sub>C\_IE**

HS I<sub>2</sub>C Integration

- [HS I<sub>2</sub>C Interrupt Requests: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\]](#)

HS I<sub>2</sub>C Functional Description

- [HS I<sub>2</sub>C Receive Mode in I<sub>2</sub>C Mode: \[17\]](#)
- [HS I<sub>2</sub>C FIFO Interrupt Mode Operation: \[18\]](#)
- [HS I<sub>2</sub>C FIFO Polling Mode Operation: \[19\] \[20\]](#)
- [HS I<sub>2</sub>C Draining Feature \(I<sub>2</sub>C Mode Only\): \[21\] \[22\]](#)

HS I<sub>2</sub>C Basic Programming Model

- [HS I<sub>2</sub>C Initialize the I<sub>2</sub>C Controller \(I<sub>2</sub>C Mode\): \[23\] \[24\] \[25\] \[26\] \[27\]](#)
- [HS I<sub>2</sub>C Receive Data \(I<sub>2</sub>C Mode\): \[28\] \[29\] \[30\]](#)
- [HS I<sub>2</sub>C Transmit Data \(I<sub>2</sub>C Mode\): \[31\] \[32\] \[33\] \[34\]](#)
- [HS I<sub>2</sub>C Initialize the I<sub>2</sub>C Controller \(SCCB Mode\): \[35\] \[36\] \[37\] \[38\] \[39\]](#)
- [HS I<sub>2</sub>C Receive Data \(SCCB Mode\): \[40\]](#)
- [HS I<sub>2</sub>C Transmit Data \(SCCB Mode\): \[41\]](#)

HS I<sub>2</sub>C Register Manual

- [HS I<sub>2</sub>C Register Summary: \[42\]](#)

**Table 17-21. I<sub>2</sub>C\_STAT**

| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |     |    |      |      |     |    | 0x08                                                                                                                                          |     |                   |      |      |      |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |     |     |    |      |      |     |    |      |     |    |      |      |      |      |    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|----|------|------|-----|----|-----------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------------|------|------|------|------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|-----|-----|----|------|------|-----|----|------|-----|----|------|------|------|------|----|
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |     |    |      |      |     |    | <b>Instance</b>                                                                                                                               |     | I <sub>2</sub> C3 |      |      |      |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |     |     |    |      |      |     |    |      |     |    |      |      |      |      |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |     |    |      |      |     |    | 0x4806 0008                                                                                                                                   |     | I <sub>2</sub> C1 |      |      |      |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |     |     |    |      |      |     |    |      |     |    |      |      |      |      |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |     |    |      |      |     |    | 0x4807 0008                                                                                                                                   |     | I <sub>2</sub> C2 |      |      |      |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |     |     |    |      |      |     |    |      |     |    |      |      |      |      |    |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |     |    |      |      |     |    | I <sub>2</sub> C status register. This register provides specific status information about the module, including interrupt status information |     |                   |      |      |      |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |     |     |    |      |      |     |    |      |     |    |      |      |      |      |    |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |     |    |      |      |     |    | RW                                                                                                                                            |     |                   |      |      |      |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |     |     |    |      |      |     |    |      |     |    |      |      |      |      |    |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr style="background-color: #ffffcc;"> <th>15</th><th>14</th><th>13</th><th>12</th><th>11</th><th>10</th><th>9</th><th>8</th><th>7</th><th>6</th><th>5</th><th>4</th><th>3</th><th>2</th><th>1</th><th>0</th></tr> </thead> <tbody> <tr> <td style="text-align: center;">RESERVED</td><td>XDR</td><td>RDR</td><td>BB</td><td>ROVR</td><td>XUDF</td><td>AAS</td><td>BF</td><td>AERR</td><td>STC</td><td>GC</td><td>XRDY</td><td>RRDY</td><td>ARDY</td><td>NACK</td><td>AL</td></tr> </tbody> </table> |     |     |    |      |      |     |    |                                                                                                                                               |     |                   |      |      |      |      |    | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | RESERVED | XDR | RDR | BB | ROVR | XUDF | AAS | BF | AERR | STC | GC | XRDY | RRDY | ARDY | NACK | AL |
| 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 14  | 13  | 12 | 11   | 10   | 9   | 8  | 7                                                                                                                                             | 6   | 5                 | 4    | 3    | 2    | 1    | 0  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |     |     |    |      |      |     |    |      |     |    |      |      |      |      |    |
| RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | XDR | RDR | BB | ROVR | XUDF | AAS | BF | AERR                                                                                                                                          | STC | GC                | XRDY | RRDY | ARDY | NACK | AL |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |     |     |    |      |      |     |    |      |     |    |      |      |      |      |    |

| Bits | Field Name | Description                                                                                                                                                                                                        | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15   | RESERVED   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                 | RW   | 0     |
| 14   | XDR        | Transmit Draining IRQ status<br><br>Read      Transmit draining inactive<br>0x0:<br><br>Read      Transmit draining active<br>0x1:<br><br>Write     No effect<br>0x0:<br><br>Write     Clear this bit to 0<br>0x1: | RW   | 0     |
| 13   | RDR        | Receive Draining IRQ status<br><br>Read     Receive draining inactive<br>0x0:                                                                                                                                      | RW   | 0     |

| Bits | Field Name | Description                                                                                                                                                                                                        | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | Read 0x1: Receive draining active<br>Write 0x0: No effect<br>Write 0x1: Clear this bit to 0                                                                                                                        |      |       |
| 12   | BB         | Bus busy status. Read-only bit. Writing this bit does not affect the read value.<br>Read 0x0: Bus is free.<br>Read 0x1: Bus is occupied.                                                                           | R    | 0     |
| 11   | ROVR       | Receive overrun status. Read-only bit. Writing this bit does not affect the read value.<br>Read 0x0: Normal operation<br>Read 0x1: Receiver overrun<br>Write 0x0: No effect<br>Write 0x1: Clear this bit to 0      | RW   | 0     |
| 10   | XUDF       | Transmit underflow status. Read-only bit. Writing this bit does not affect the read value.<br>Read 0x0: Normal operation<br>Read 0x1: Transmit underflow<br>Write 0x0: No effect<br>Write 0x1: Clear this bit to 0 | RW   | 0     |
| 9    | AAS        | Address recognized as slave IRQ status<br>Read 0x0: No action<br>Read 0x1: Address recognized<br>Write 0x0: No effect<br>Write 0x1: Clear this bit to 0.                                                           | RW   | 0     |
| 8    | BF         | Bus Free IRQ status<br>Read 0x0: No action<br>Read 0x1: Bus free<br>Write 0x0: No effect<br>Write 0x1: Clear this bit to 0.                                                                                        | RW   | 0     |
| 7    | AERR       | Access Error IRQ status<br>Read 0x0: No action<br>Read 0x1: Access error<br>Write 0x0: No effect                                                                                                                   | RW   | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                          | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
|             |                   | Write 0x1: Clear this bit to 0.                                                                                                                                                                                                                                                                                                                             |             |              |
| 6           | STC               | Start Condition IRQ status<br>Read 0x0: No action<br>Read 0x1: Start condition detected<br>Write 0x0: No effect<br>Write 0x1: Clear this bit to 0.                                                                                                                                                                                                          | RW          | 0            |
| 5           | GC                | General Call IRQ status. Set to 1 when general call address detected. Interrupt signaled to MPU subsystem<br>Read 0x0: No general call detected<br>Read 0x1: General call address detected<br>Write 0x0: No effect<br>Write 0x1: Clear this bit to 0.                                                                                                       | RW          | 0            |
| 4           | XRDY              | Transmit Data Ready IRQ status. Set to 1 in transmit mode when new data is requested for transmission. When this bit is set to 1, an interrupt is signaled to MPU subsystem<br>Read 0x0: No transmit data is requested for transmission<br>Read 0x1: Transmit data is requested for transmission<br>Write 0x0: No effect<br>Write 0x1: Clear this bit to 0. | RW          | 0            |
| 3           | RRDY              | Receive Data Ready IRQ status. Set to 1 when in receive mode, causing new data to be able to be read. When this bit is set to 1, an interrupt is signaled to MPU subsystem.<br>Read 0x0: No data available<br>Read 0x1: Receive data available<br>Write 0x0: No effect<br>Write 0x1: Clear this bit to 0.                                                   | RW          | 0            |
| 2           | ARDY              | Register Access Ready IRQ status. Setting this bit to 1 indicates that previous access has been performed and registers are ready to be accessed again. An interrupt is signaled to MPU subsystem.<br>Read 0x0: Module busy<br>Read 0x1: Access ready<br>Write 0x0: No effect<br>Write 0x1: Clear this bit to 0.                                            | RW          | 0            |

| Bits  | Field Name                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset            |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
|-------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------------|------|--|------|---------------------------|------|--|-------|-----------|------|--|-------|----------------------|------|--|----|---|
| 1     | NACK                      | <p>No Acknowledgment IRQ status. This bit is set when No Acknowledgment has been received. An interrupt is signaled to MPU subsystem.</p> <p>In master mode, the transfer is automatically ended by generating a stop condition on the bus. The I2Ci.I2C_CON[1] STP, I2Ci.I2C_CON[10] MST and I2Ci.I2C_CON[9] TRX bits are automatically cleared to 0 (slave receiver mode). TX and RX FIFOs must be cleared (I2Ci.I2C_BUF[6] TXFIFO_CLR and I2Ci.I2C_BUF[14] RXFIFO_CLR bits set to 1).</p> <table> <tr> <td>Read</td> <td>Normal operation</td> </tr> <tr> <td>0x0:</td> <td></td> </tr> <tr> <td>Read</td> <td>No Acknowledge detected</td> </tr> <tr> <td>0x1:</td> <td></td> </tr> <tr> <td>Write</td> <td>No effect</td> </tr> <tr> <td>0x0:</td> <td></td> </tr> <tr> <td>Write</td> <td>Clear this bit to 0.</td> </tr> <tr> <td>0x1:</td> <td></td> </tr> </table> | Read | Normal operation | 0x0: |  | Read | No Acknowledge detected   | 0x1: |  | Write | No effect | 0x0: |  | Write | Clear this bit to 0. | 0x1: |  | RW | 0 |
| Read  | Normal operation          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| 0x0:  |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| Read  | No Acknowledge detected   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| 0x1:  |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| Write | No effect                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| 0x0:  |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| Write | Clear this bit to 0.      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| 0x1:  |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| 0     | AL                        | <p>Arbitration Lost IRQ status. This bit is set automatically by the hardware when the I2C controller inside the device loses arbitration in master transmit mode. An interrupt is signaled to MPU subsystem.</p> <table> <tr> <td>Read</td> <td>Normal operation</td> </tr> <tr> <td>0x0:</td> <td></td> </tr> <tr> <td>Read</td> <td>Arbitration loss detected</td> </tr> <tr> <td>0x1:</td> <td></td> </tr> <tr> <td>Write</td> <td>No effect</td> </tr> <tr> <td>0x0:</td> <td></td> </tr> <tr> <td>Write</td> <td>Clear this bit to 0.</td> </tr> <tr> <td>0x1:</td> <td></td> </tr> </table>                                                                                                                                                                                                                                                                          | Read | Normal operation | 0x0: |  | Read | Arbitration loss detected | 0x1: |  | Write | No effect | 0x0: |  | Write | Clear this bit to 0. | 0x1: |  | RW | 0 |
| Read  | Normal operation          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| 0x0:  |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| Read  | Arbitration loss detected |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| 0x1:  |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| Write | No effect                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| 0x0:  |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| Write | Clear this bit to 0.      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |
| 0x1:  |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                  |      |  |      |                           |      |  |       |           |      |  |       |                      |      |  |    |   |

**Table 17-22. Register Call Summary for Register I2C\_STAT**

## HS I2C Environment

- HS I2C Start and Stop Conditions: [0] [1]
- HS I2C Master Transmitter Mode: [2]
- HS I2C Master Receiver Mode: [3]
- HS I2C Slave Transmitter Mode: [4]
- HS I2C Slave Receiver Mode: [5]
- HS I2C Bus Arbitration: [6]

## HS I2C Integration

- HS I2C Interrupt Requests: [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23] [24]

## HS I2C Functional Description

- HS I2C Transmit Mode in I2C Mode: [25] [26]
- HS I2C Receive Mode in I2C Mode: [27] [28] [29] [30]
- HS I2C FIFO Interrupt Mode Operation: [31] [32]
- HS I2C FIFO Polling Mode Operation: [33] [34] [35] [36] [37] [38]
- HS I2C Draining Feature (I2C Mode Only): [39] [40] [41] [42] [43]
- HS I2C System Test Mode: [44] [45] [46]

**Table 17-22. Register Call Summary for Register I2C\_STAT (continued)**

## HS I2C Basic Programming Model

- HS I2C Initiate a Transfer (I2C Mode): [47]
- HS I2C Receive Data (I2C Mode): [48] [49] [50]
- HS I2C Transmit Data (I2C Mode): [51] [52] [53]
- HS I2C Interrupt Subroutine Sequence (I2C Mode): [54] [55] [56] [57] [58] [59] [60] [61] [62]
- HS I2C Programming Flow Diagrams (I2C Mode): [63] [64] [65] [66] [67] [68] [69] [70]
- HS I2C Initiate a Transfer (SCCB Mode): [71] [72]
- HS I2C Receive Data (SCCB Mode): [73]
- HS I2C Transmit Data (SCCB Mode): [74]
- HS I2C Interrupt Subroutine Sequence (SCCB Mode): [75] [76] [77]
- HS I2C Programming Flow Diagrams (SCCB Mode): [78] [79] [80] [81]

## HS I2C Register Manual

- HS I2C Register Summary: [82]
- HS I2C Register Summary: [83] [84] [85] [86] [87] [88] [89] [90] [91] [92] [93] [94] [95] [96] [97]

**Table 17-23. I2C\_WE**

| Address Offset   |        | 0x0C                                           |          |         |         |             |       |          |        | Instance    |          | I2C3    |         |         |       |      |  |  |  |  |  |  |  |  |  |  |
|------------------|--------|------------------------------------------------|----------|---------|---------|-------------|-------|----------|--------|-------------|----------|---------|---------|---------|-------|------|--|--|--|--|--|--|--|--|--|--|
| Physical Address |        | 0x4806 000C                                    |          |         |         | 0x4807 000C |       |          |        | 0x4807 200C |          |         |         | I2C1    |       | I2C2 |  |  |  |  |  |  |  |  |  |  |
| Description      |        | This register contains the wakeup enable bits. |          |         |         |             |       |          |        |             |          |         |         |         |       |      |  |  |  |  |  |  |  |  |  |  |
| Type             |        | RW                                             |          |         |         |             |       |          |        |             |          |         |         |         |       |      |  |  |  |  |  |  |  |  |  |  |
| 15               | 14     | 13                                             | 12       | 11      | 10      | 9           | 8     | 7        | 6      | 5           | 4        | 3       | 2       | 1       | 0     |      |  |  |  |  |  |  |  |  |  |  |
| RESERVED         | XDR_WE | RDR_WE                                         | Reserved | ROVR_WE | XUDF_WE | AAS_WE      | BF_WE | Reserved | STC_WE | GC_WE       | Reserved | DRDY_WE | ARDY_WE | NACK_WE | AL_WE |      |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name | Description                                                                                                            | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15   | RESERVED   | Write Os for future compatibility. Read returns 0.                                                                     | RW   | 0     |
| 14   | XDR_WE     | Transmit draining wakeup enable<br><br>0x0: Transmit draining wakeup disabled<br>0x1: Transmit draining wakeup enabled | RW   | 0     |
| 13   | RDR_WE     | Receive draining wakeup enable<br><br>0x0: Receive draining wakeup disabled<br>0x1: Receive draining wakeup enabled    | RW   | 0     |
| 12   | Reserved   | Write Os for future compatibility. Read returns 0.                                                                     | RW   | 0x0   |
| 11   | ROVR_WE    | Receive overrun wakeup set.<br><br>0x0: Receive overrun wakeup disabled<br>0x1: Receive overrun wakeup enabled         | RW   | 0     |
| 10   | XUDF_WE    | Transmit underflow wakeup set<br><br>0x0: Transmit underflow wakeup disabled<br>0x1: Transmit underflow wakeup enabled | RW   | 0     |
| 9    | AAS_WE     | Address as slave wakeup enabled<br><br>0x0: Address as slave wakeup disabled<br>0x1: Address as slave wakeup enabled   | RW   | 0     |
| 8    | BF_WE      | Bus Free wakeup enable<br><br>0x0: Bus Free wakeup disabled                                                            | RW   | 0     |

| Bits | Field Name | Description                                                                                                            | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x1: Bus Free wakeup enabled                                                                                           |      |       |
| 7    | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                     | RW   | 0     |
| 6    | STC_WE     | Start Condition wakeup enable                                                                                          | RW   | 0     |
|      |            | 0x0: Start condition wakeup disabled<br>0x1: Start condition wakeup enabled                                            |      |       |
| 5    | GC_WE      | General call wakeup enable                                                                                             | RW   | 0     |
|      |            | 0x0: General call wakeup disabled<br>0x1: General call wakeup enabled                                                  |      |       |
| 4    | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                     | RW   | 0     |
| 3    | DRDY_WE    | Transmit/receive data ready wakeup enable. Mask or unmask the interrupt signaled by bit in I <sup>2</sup> C_STAT[RRDY] | RW   | 0     |
|      |            | 0x0: Transmit/receive data ready wakeup disabled<br>0x1: Transmit/receive data ready wakeup enabled                    |      |       |
| 2    | ARDY_WE    | Register access ready wakeup enable                                                                                    | RW   | 0     |
|      |            | 0x0: Register access ready wakeup disabled<br>0x1: Register access ready wakeup enabled                                |      |       |
| 1    | NACK_WE    | No Acknowledgment wakeup enable                                                                                        | RW   | 0     |
|      |            | 0x0: No Acknowledgment wakeup disabled<br>0x1: No Acknowledgment wakeup enabled                                        |      |       |
| 0    | AL_WE      | Arbitration lost wakeup enable                                                                                         | RW   | 0     |
|      |            | 0x0: Arbitration lost wakeup disabled<br>0x1: Arbitration lost wakeup enabled                                          |      |       |

**Table 17-24. Register Call Summary for Register I<sup>2</sup>C\_WE**HS I<sup>2</sup>C Integration

- [HS I<sup>2</sup>C Wake-Up Capability: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\]](#)

HS I<sup>2</sup>C Register Manual

- [HS I<sup>2</sup>C Register Summary: \[14\]](#)

**Table 17-25. I<sup>2</sup>C\_SYSS**

|                         |                                                                                                         |    |    |    |                 |                   |   |   |   |   |   |   |   |       |   |
|-------------------------|---------------------------------------------------------------------------------------------------------|----|----|----|-----------------|-------------------|---|---|---|---|---|---|---|-------|---|
| <b>Address Offset</b>   | 0x10                                                                                                    |    |    |    |                 |                   |   |   |   |   |   |   |   |       |   |
| <b>Physical Address</b> | 0x4806 0010                                                                                             |    |    |    | <b>Instance</b> | I <sup>2</sup> C3 |   |   |   |   |   |   |   |       |   |
|                         | 0x4807 0010                                                                                             |    |    |    |                 | I <sup>2</sup> C1 |   |   |   |   |   |   |   |       |   |
|                         | 0x4807 2010                                                                                             |    |    |    |                 | I <sup>2</sup> C2 |   |   |   |   |   |   |   |       |   |
| <b>Description</b>      | This register provides status information about the module, excluding the interrupt status information. |    |    |    |                 |                   |   |   |   |   |   |   |   |       |   |
| <b>Type</b>             | R                                                                                                       |    |    |    |                 |                   |   |   |   |   |   |   |   |       |   |
| 15                      | 14                                                                                                      | 13 | 12 | 11 | 10              | 9                 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0 |
| RESERVED                |                                                                                                         |    |    |    |                 |                   |   |   |   |   |   |   |   | RDONE |   |

| Bits | Field Name | Description                                | Type | Reset |
|------|------------|--------------------------------------------|------|-------|
| 15:1 | RESERVED   | Read returns 0.                            | R    | 0x00  |
| 0    | RDONE      | Internal reset monitoring                  | R    | 0     |
|      |            | Read 0x0: Internal module reset in ongoing |      |       |
|      |            | Read 0x1: Internal module reset complete   |      |       |

**Table 17-26. Register Call Summary for Register I2C\_SYSS**

## HS I2C Integration

- [HS I2C Software Reset: \[0\] \[1\] \[2\]](#)

## HS I2C Register Manual

- [HS I2C Register Summary: \[3\]](#)

**Table 17-27. I2C\_BUFS**

|                         |                               |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------|--|--|--|--|--|--|--|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x14                          |  |  |  |  |  |  |  | <b>Instance</b> | I2C3 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4806 0014                   |  |  |  |  |  |  |  |                 | I2C1 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4807 0014                   |  |  |  |  |  |  |  |                 | I2C2 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Receive DMA channel disabled. |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                            |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 15      | 14         | 13 | 12 | 11 | 10 | 9 | 8 | 7       | 6          | 5 | 4 | 3 | 2 | 1 | 0     |
|---------|------------|----|----|----|----|---|---|---------|------------|---|---|---|---|---|-------|
| RDMA_EN | RXFIFO_CLR |    |    |    |    |   |   | XDMA_EN | TXFIFO_CLR |   |   |   |   |   | XTRSH |

| Bits | Field Name | Description                                                                                            | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------|------|-------|
| 15   | RDMA_EN    | Receive DMA channel enable<br>0x0: Receive DMA channel disabled<br>0x1: Receive DMA channel enabled    | RW   | 0     |
| 14   | RXFIFO_CLR | Receive FIFO clear<br>0x0: Normal mode<br>0x1: Rx FIFO is reset                                        | RW   | 0     |
| 13:8 | RTRSH      | Threshold value for FIFO buffer in RX mode is equal to RTRSH + 1.                                      | RW   | 0x00  |
| 7    | XDMA_EN    | Transmit DMA channel enable<br>0x0: Transmit DMA channel disabled<br>0x1: Transmit DMA channel enabled | RW   | 0     |
| 6    | TXFIFO_CLR | Transmit FIFO clear<br>0x0: Normal mode<br>0x1: Tx FIFO is reset                                       | RW   | 0     |
| 5:0  | XTRSH      | Threshold value for FIFO buffer in TX mode is equal to XTRSH + 1.                                      | RW   | 0x00  |

**Table 17-28. Register Call Summary for Register I2C\_BUFS**

## HS I2C Integration

- [HS I2C Wake-Up Capability: \[0\] \[1\]](#)
- [HS I2C Interrupt Requests: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)

## HS I2C Functional Description

- [HS I2C Receive Mode in I2C Mode: \[10\]](#)
- [HS I2C FIFO Interrupt Mode Operation: \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\]](#)
- [HS I2C FIFO Polling Mode Operation: \[19\] \[20\]](#)
- [HS I2C FIFO DMA Mode Operation \(I2C Mode Only\): \[21\] \[22\] \[23\] \[24\] \[25\] \[26\] \[27\]](#)
- [HS I2C Draining Feature \(I2C Mode Only\): \[28\] \[29\] \[30\] \[31\] \[32\] \[33\] \[34\] \[35\]](#)
- [HS I2C Write and Read Operations in SCCB Mode: \[36\] \[37\]](#)

**Table 17-28. Register Call Summary for Register I2C\_BUFS (continued)**

## HS I2C Basic Programming Model

- HS I2C Configure the Module Before Enabling the I2C Controller (I2C Mode): [38] [39]
- HS I2C Initialize the I2C Controller (I2C Mode): [40] [41] [42]
- HS I2C Receive Data (I2C Mode): [43] [44]
- HS I2C Transmit Data (I2C Mode): [45] [46]
- HS I2C Programming Flow Diagrams (I2C Mode): [47] [48]
- HS I2C Configure the Module Before Enabling the I2C Controller (SCCB Mode): [49] [50]
- HS I2C Receive Data (SCCB Mode): [51]
- HS I2C Transmit Data (SCCB Mode): [52]

## HS I2C Register Manual

- HS I2C Register Summary: [53]
- HS I2C Register Summary: [54] [55]

**Table 17-29. I2C\_CNT**

| <b>Address Offset</b>   | 0x18                                                                                      |    |    |                                                                                                                                                           |    |   |   |   |                 |      |   |             |              |   |   |
|-------------------------|-------------------------------------------------------------------------------------------|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|-----------------|------|---|-------------|--------------|---|---|
| <b>Physical Address</b> | 0x4806 0018                                                                               |    |    |                                                                                                                                                           |    |   |   |   | <b>Instance</b> | I2C3 |   |             |              |   |   |
|                         | 0x4807 0018                                                                               |    |    |                                                                                                                                                           |    |   |   |   |                 | I2C1 |   |             |              |   |   |
|                         | 0x4807 2018                                                                               |    |    |                                                                                                                                                           |    |   |   |   |                 | I2C2 |   |             |              |   |   |
| <b>Description</b>      | This read/write register is used to control the numbers of bytes in the I2C data payload. |    |    |                                                                                                                                                           |    |   |   |   |                 |      |   |             |              |   |   |
| <b>Type</b>             | RW                                                                                        |    |    |                                                                                                                                                           |    |   |   |   |                 |      |   |             |              |   |   |
| 15                      | 14                                                                                        | 13 | 12 | 11                                                                                                                                                        | 10 | 9 | 8 | 7 | 6               | 5    | 4 | 3           | 2            | 1 | 0 |
| DCOUNT                  |                                                                                           |    |    |                                                                                                                                                           |    |   |   |   |                 |      |   |             |              |   |   |
| Bits                    | <b>Field Name</b>                                                                         |    |    | <b>Description</b>                                                                                                                                        |    |   |   |   |                 |      |   | <b>Type</b> | <b>Reset</b> |   |   |
| 15:0                    | DCOUNT                                                                                    |    |    | Data count<br><b>Note:</b> Because the transfer length for DCOUNT=0x0000 is 65536, the module does not allow the initiation of zero-data-byte transfers.. |    |   |   |   |                 |      |   | RW          | 0x0000       |   |   |

**Table 17-30. Register Call Summary for Register I2C\_CNT**

## HS I2C Integration

- HS I2C Interrupt Requests: [0] [1] [2] [3]

## HS I2C Functional Description

- HS I2C Transmit Mode in I2C Mode: [4]
- HS I2C Draining Feature (I2C Mode Only): [5]

## HS I2C Basic Programming Model

- HS I2C Configure Slave Address and the Data Control Register (I2C Mode): [6]
- HS I2C Transmit Data (I2C Mode): [7]
- HS I2C Programming Flow Diagrams (I2C Mode): [8] [9] [10] [11] [12] [13]

## HS I2C Register Manual

- HS I2C Register Summary: [14]

**Table 17-31. I2C\_DATA**

|                         |                                                                                                                                                                                                                       |  |  |  |                 |      |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|-----------------|------|--|--|--|
| <b>Address Offset</b>   | 0x1C                                                                                                                                                                                                                  |  |  |  |                 |      |  |  |  |
| <b>Physical Address</b> | 0x4806 001C                                                                                                                                                                                                           |  |  |  | <b>Instance</b> | I2C3 |  |  |  |
|                         | 0x4807 001C                                                                                                                                                                                                           |  |  |  |                 | I2C1 |  |  |  |
|                         | 0x4807 201C                                                                                                                                                                                                           |  |  |  |                 | I2C2 |  |  |  |
| <b>Description</b>      | This register is the end point/entry point for the LH to read data from or write data to the FIFO buffer.<br><br>Read accesses from an empty FIFO (i.e. at reset) or write accesses to a full FIFO will return error. |  |  |  |                 |      |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                    |  |  |  |                 |      |  |  |  |

|          |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |    |    |    |    |    |   |   | DATA |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                        | Type | Reset |
|------|------------|----------------------------------------------------|------|-------|
| 15:8 | Reserved   | Write Os for future compatibility. Read returns 0. | RW   | 0x00  |
| 7:0  | DATA       | Transmit/Receive FIFO data                         | RW   | 0x-   |

**Table 17-32. Register Call Summary for Register I2C\_DATA**
**HS I2C Integration**

- [HS I2C DMA Requests: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\]](#)
- [HS I2C Interrupt Requests: \[6\] \[7\]](#)

**HS I2C Functional Description**

- [HS I2C Transmit Mode in I2C Mode: \[8\]](#)
- [HS I2C Receive Mode in I2C Mode: \[9\] \[10\]](#)
- [HS I2C System Test Mode: \[11\] \[12\]](#)
- [HS I2C Write and Read Operations in SCCB Mode: \[13\] \[14\]](#)

**HS I2C Basic Programming Model**

- [HS I2C Receive Data \(I2C Mode\): \[15\] \[16\]](#)
- [HS I2C Transmit Data \(I2C Mode\): \[17\] \[18\]](#)
- [HS I2C Receive Data \(SCCB Mode\): \[19\]](#)
- [HS I2C Transmit Data \(SCCB Mode\): \[20\]](#)

**HS I2C Register Manual**

- [HS I2C Register Summary: \[21\]](#)

**Table 17-33. I2C\_SYSC**

|                         |                                                                                      |  |  |  |                 |      |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------|--|--|--|-----------------|------|--|--|--|
| <b>Address Offset</b>   | 0x20                                                                                 |  |  |  |                 |      |  |  |  |
| <b>Physical Address</b> | 0x4806 0020                                                                          |  |  |  | <b>Instance</b> | I2C3 |  |  |  |
|                         | 0x4807 0020                                                                          |  |  |  |                 | I2C1 |  |  |  |
|                         | 0x4807 2020                                                                          |  |  |  |                 | I2C2 |  |  |  |
| <b>Description</b>      | This register controls the various parameters of the L4-Core interconnect interface. |  |  |  |                 |      |  |  |  |
| <b>Type</b>             | RW                                                                                   |  |  |  |                 |      |  |  |  |

|          |    |    |    |    |    |               |   |          |   |          |   |           |   |      |   |         |
|----------|----|----|----|----|----|---------------|---|----------|---|----------|---|-----------|---|------|---|---------|
| 15       | 14 | 13 | 12 | 11 | 10 | 9             | 8 | 7        | 6 | 5        | 4 | 3         | 2 | 1    | 0 |         |
| RESERVED |    |    |    |    |    | CLOCKACTIVITY |   | RESERVED |   | IDLEMODE |   | ENAWAKEUP |   | SRST |   | AUTODLE |

| Bits  | Field Name    | Description                                                                                                                                                                                                                                                                      | Type | Reset |
|-------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15:10 | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                               | RW   | 0x00  |
| 9:8   | CLOCKACTIVITY | Clock Activity selection bits<br><br>0x0: Both clocks can be cut off<br>0x1: Only interface clock must be kept active; functional clock can be cut off<br>0x2: Only functional clock must be kept active; interface clock can be cut off<br>0x3: Both clocks must be kept active | RW   | 0x0   |
| 7:5   | RESERVED      | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                               | RW   | 0x0   |
| 4:3   | IDLEMODE      | Idle Mode selection bits<br><br>0x0: Force Idle mode<br>0x1: No Idle mode<br>0x2: Smart Idle mode<br>0x3: Reserved                                                                                                                                                               | RW   | 0x0   |
| 2     | ENAWAKEUP     | Enable wakeup control bit<br><br>0x0: Wakeup mechanism is disabled<br>0x1: Wakeup mechanism is enabled                                                                                                                                                                           | RW   | 0     |
| 1     | SRST          | Software reset. This bit is automatically reset by the hardware. During reads, it always returns 0.<br><br>0x0: Normal mode<br>0x1: The module is reset                                                                                                                          | RW   | 0     |
| 0     | AUTOIDLE      | Auto Idle enable control bit<br><br>0x0: Auto Idle mechanism is disabled<br>0x1: Auto Idle mechanism is enabled                                                                                                                                                                  | RW   | 1     |

**Table 17-34. Register Call Summary for Register I2C\_SYSC**

## HS I2C Integration

- HS I2C Module Power Saving: [0]
- HS I2C System Power Management: [1] [2] [3] [4] [5] [6] [7] [8] [9]
- HS I2C Wake-Up Capability: [10]
- HS I2C Software Reset: [11] [12]

## HS I2C Register Manual

- HS I2C Register Summary: [13]

**Table 17-35. I2C\_CON**

|                  |          |        |     |     |     |     |      |                                                                                                                                                                                                                    |      |      |          |     |     |   |   |  |  |  |  |  |  |
|------------------|----------|--------|-----|-----|-----|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|----------|-----|-----|---|---|--|--|--|--|--|--|
| Address Offset   |          |        |     |     |     |     |      | 0x24                                                                                                                                                                                                               |      |      |          |     |     |   |   |  |  |  |  |  |  |
| Physical Address |          |        |     |     |     |     |      | Instance                                                                                                                                                                                                           |      | I2C3 |          |     |     |   |   |  |  |  |  |  |  |
|                  |          |        |     |     |     |     |      | I2C1                                                                                                                                                                                                               |      |      |          |     |     |   |   |  |  |  |  |  |  |
|                  |          |        |     |     |     |     |      | I2C2                                                                                                                                                                                                               |      |      |          |     |     |   |   |  |  |  |  |  |  |
| Description      |          |        |     |     |     |     |      | This register controls the functional features. Caution: during an active transfer phase (STT has been set to 1), no modification must be done in this register. Changing it may result in unpredictable behavior. |      |      |          |     |     |   |   |  |  |  |  |  |  |
| Type             |          |        |     |     |     |     |      | RW                                                                                                                                                                                                                 |      |      |          |     |     |   |   |  |  |  |  |  |  |
| 15               | 14       | 13     | 12  | 11  | 10  | 9   | 8    | 7                                                                                                                                                                                                                  | 6    | 5    | 4        | 3   | 2   | 1 | 0 |  |  |  |  |  |  |
| I2C_EN           | RESERVED | OPMODE | STB | MST | TRX | XSA | XOA0 | XOA1                                                                                                                                                                                                               | XOA2 | XOA3 | Reserved | STP | STT |   |   |  |  |  |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 15          | I2C_EN            | Module enable bit<br><br>0x0: Controller in reset. FIFO are cleared and status bits are set to their default value.<br><br>0x1: Module enabled                                                                                                                                       | RW          | 0            |
| 14          | RESERVED          | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                                                                   | RW          | 0            |
| 13:12       | OPMODE            | Operation mode selection<br><br>0x0: I2C Fast/Standard mode<br>0x1: I2C High Speed mode<br>0x2: SCCB mode<br>0x3: Reserved                                                                                                                                                           | RW          | 0x0          |
| 11          | STB               | Start byte mode (master mode only)<br><br>0x0: Normal mode<br>0x1: Start byte mode                                                                                                                                                                                                   | RW          | 0            |
| 10          | MST               | Master/slave mode selection<br><br>0x0: Slave mode<br>0x1: Master mode                                                                                                                                                                                                               | RW          | 0            |
| 9           | TRX               | Transmitter/Receiver mode (master mode only)<br><br>0x0: Receiver mode<br>0x1: Transmitter mode                                                                                                                                                                                      | RW          | 0            |
| 8           | XSA               | Expand slave address enable bit<br><br>0x0: 7-bit address mode<br>0x1: 10-bit address mode                                                                                                                                                                                           | RW          | 0            |
| 7           | XOA0              | Expand Own Address 0 enable bit (default)<br><br>0x0: 7-bit address mode<br>0x1: 10-bit address mode                                                                                                                                                                                 | RW          | 0            |
| 6           | XOA1              | Expand Own Address 1 enable bit<br><br>0x0: 7-bit address mode<br>0x1: 10-bit address mode                                                                                                                                                                                           | RW          | 0            |
| 5           | XOA2              | Expand Own Address 2 enable bit<br><br>0x0: 7-bit address mode<br>0x1: 10-bit address mode                                                                                                                                                                                           | RW          | 0            |
| 4           | XOA3              | Expand Own Address 3 enable bit<br><br>0x0: 7-bit address mode<br>0x1: 10-bit address mode                                                                                                                                                                                           | RW          | 0            |
| 3:2         | Reserved          | Write 0s for future compatibility. Read returns 0                                                                                                                                                                                                                                    | RW          | 0x0          |
| 1           | STP               | Stop condition (master mode only). The STP bit is cleared by the module itself once it has generated and detected the programmed stop condition on the bus.<br><br>0x0: No action or generated stop (P) condition detected on the bus (by the module)<br>0x1: Stop condition queried | RW          | 0            |
| 0           | STT               | Start condition (master mode only). The STT bit is cleared by the module itself once it has generated and detected the programmed start condition on the bus.<br><br>0x0: No action or generated start (S) condition detected (by the module)<br>0x1: Start condition queried        | RW          | 0            |

**Table 17-36. Register Call Summary for Register I2C\_CON**

|                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HS I2C Environment             | <ul style="list-style-type: none"> <li><a href="#">HS I2C SCCB Interface Typical Connections: [0]</a></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| HS I2C Integration             | <ul style="list-style-type: none"> <li><a href="#">HS I2C Software Reset: [1] [2] [3] [4] [5]</a></li> <li><a href="#">HS I2C Interrupt Requests: [6] [7] [8] [9] [10] [11] [12]</a></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| HS I2C Functional Description  | <ul style="list-style-type: none"> <li><a href="#">HS I2C Block Diagram: [13] [14]</a></li> <li><a href="#">HS I2C Transmit Mode in I2C Mode: [15] [16]</a></li> <li><a href="#">HS I2C Receive Mode in I2C Mode: [17]</a></li> <li><a href="#">HS I2C FIFO Interrupt Mode Operation: [18] [19]</a></li> <li><a href="#">HS I2C Programmable Multislave Channel Feature (I2C Mode Only): [20] [21] [22] [23]</a></li> <li><a href="#">HS I2C Clocking: [24]</a></li> <li><a href="#">HS I2C System Test Mode: [25] [26] [27]</a></li> <li><a href="#">HS I2C Write and Read Operations in SCCB Mode: [28] [29] [30] [31]</a></li> </ul>                                                                                                                                                                                                                                                                                                          |
| HS I2C Basic Programming Model | <ul style="list-style-type: none"> <li><a href="#">HS I2C Configure the Module Before Enabling the I2C Controller (I2C Mode): [32] [33]</a></li> <li><a href="#">HS I2C Initialize the I2C Controller (I2C Mode): [34] [35] [36]</a></li> <li><a href="#">HS I2C Configure Slave Address and the Data Control Register (I2C Mode): [37]</a></li> <li><a href="#">HS I2C Initiate a Transfer (I2C Mode): [38] [39] [40] [41]</a></li> <li><a href="#">HS I2C Programming Flow Diagrams (I2C Mode): [42] [43] [44] [45] [46] [47] [48] [49] [50] [51] [52] [53] [54] [55] [56] [57] [58]</a></li> <li><a href="#">[59] [60] [61] [62] [63] [64] [65]</a></li> <li><a href="#">HS I2C Configure the Module Before Enabling the I2C Controller (SCCB Mode): [66]</a></li> <li><a href="#">HS I2C Initialize the I2C Controller (SCCB Mode): [67] [68] [69]</a></li> <li><a href="#">HS I2C Initiate a Transfer (SCCB Mode): [70] [71]</a></li> </ul> |
| HS I2C Register Manual         | <ul style="list-style-type: none"> <li><a href="#">HS I2C Register Summary: [72]</a></li> <li><a href="#">HS I2C Register Summary: [73] [74] [75]</a></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

**Table 17-37. I2C\_OA0**

|                         |                                                                                                                                                                             |  |  |  |                 |      |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|-----------------|------|--|--|--|
| <b>Address Offset</b>   | 0x28                                                                                                                                                                        |  |  |  |                 |      |  |  |  |
| <b>Physical Address</b> | 0x4806 0028                                                                                                                                                                 |  |  |  | <b>Instance</b> | I2C3 |  |  |  |
|                         | 0x4807 0028                                                                                                                                                                 |  |  |  |                 | I2C1 |  |  |  |
|                         | 0x4807 2028                                                                                                                                                                 |  |  |  |                 | I2C2 |  |  |  |
| <b>Description</b>      | This register is used to specify the module I2C 7-bit or 10-bit address for the I2C operations or the 8-bit subaddress of the SCCB module register for the SCCB operations. |  |  |  |                 |      |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                          |  |  |  |                 |      |  |  |  |

|       |          |    |    |    |    |   |   |    |   |   |   |   |   |   |   |
|-------|----------|----|----|----|----|---|---|----|---|---|---|---|---|---|---|
| 15    | 14       | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| MCODE | RESERVED |    |    |    |    |   |   | OA |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                        | Type | Reset |
|-------|------------|----------------------------------------------------|------|-------|
| 15:13 | MCODE      | Master Code value                                  | RW   | 0x0   |
| 12:10 | RESERVED   | Write 0s for future compatibility. Read returns 0. | RW   | 0x0   |
| 9:0   | OA         | Own address 0 value                                | RW   | 0x000 |

**Table 17-38. Register Call Summary for Register I2C\_OA0**

|                                |                                                                                                                                                   |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| HS I2C Basic Programming Model | <ul style="list-style-type: none"> <li><a href="#">HS I2C Configure the Module Before Enabling the I2C Controller (SCCB Mode): [0]</a></li> </ul> |
| HS I2C Register Manual         | <ul style="list-style-type: none"> <li><a href="#">HS I2C Register Summary: [1]</a></li> </ul>                                                    |

**Table 17-39. I2C\_SA**

|                         |                                                                                                                                                                                    |                 |      |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x2C                                                                                                                                                                               |                 |      |
| <b>Physical Address</b> | 0x4806 002C                                                                                                                                                                        | <b>Instance</b> | I2C3 |
|                         | 0x4807 002C                                                                                                                                                                        |                 | I2C1 |
|                         | 0x4807 202C                                                                                                                                                                        |                 | I2C2 |
| <b>Description</b>      | This register is used to specify the addressed I2C module 7-bit or 10-bit address for the I2C operations or the 7-bit address of the external SCCB module for the SCCB operations. |                 |      |
| <b>Type</b>             | RW                                                                                                                                                                                 |                 |      |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------|-------------|--------------|
| 15:10       | Reserved          | Write 0s for future compatibility. Read returns 0. | RW          | 0x00         |
| 9:0         | SA                | Slave address value.                               | RW          | 0x3FF        |

**Table 17-40. Register Call Summary for Register I2C\_SA**

- ## HS I2C Functional Description

  - HS I2C Write and Read Operations in SCCB Mode: [0] [1]

- HS I2C Configure Slave Address and the Data Control Register (I2C Mode): [2]
  - HS I2C Programming Flow Diagrams (I2C Mode): [3] [4] [5] [6] [7] [8]
  - HS I2C Configure the Module Before Enabling the I2C Controller (SCCB Mode): [9]

- ## HS I2C Register Manual

  - HS I2C Register Summary: [10]

**Table 17-41. I2C\_PSC**

|                         |                                                                                                                                                                                           |                 |      |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x30                                                                                                                                                                                      |                 |      |
| <b>Physical Address</b> | 0x4806 0030                                                                                                                                                                               | <b>Instance</b> | I2C3 |
|                         | 0x4807 0030                                                                                                                                                                               |                 | I2C1 |
|                         | 0x4807 2030                                                                                                                                                                               |                 | I2C2 |
| <b>Description</b>      | This register is used to specify the internal clocking of the I2C peripheral core. The core logic is sampled at the clock rate of the functional clock for the module divided by (PSC+1). |                 |      |
| <b>Type</b>             | RW                                                                                                                                                                                        |                 |      |

| 15       | 14         | 13 | 12                                                                                                                                         | 11 | 10 | 9 | 8 | 7   | 6 | 5 | 4    | 3     | 2 | 1 | 0 |
|----------|------------|----|--------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|---|-----|---|---|------|-------|---|---|---|
| Reserved |            |    |                                                                                                                                            |    |    |   |   | PSC |   |   |      |       |   |   |   |
| Bits     | Field Name |    | Description                                                                                                                                |    |    |   |   |     |   |   | Type | Reset |   |   |   |
| 15:8     | Reserved   |    | Write 0s for future compatibility. Read returns 0.                                                                                         |    |    |   |   |     |   |   | RW   | 0x00  |   |   |   |
| 7:0      | PSC        |    | Fast/Standard and SCCB modes prescale sampling clock divider value<br>0x0: Divide by 1<br>0x1: Divide by 2<br>.....<br>0xFF: Divide by 256 |    |    |   |   |     |   |   | RW   | 0x00  |   |   |   |

**Table 17-42. Register Call Summary for Register I2C\_PSC**

|                                |                                                                                                                                                                                                             |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HS I2C Integration             | <a href="#">HS I2C Module Clocks: [0] [1] [2]</a>                                                                                                                                                           |
| HS I2C Functional Description  | <a href="#">HS I2C Clocking: [3] [4]</a><br><a href="#">HS I2C Noise Filter: [5] [6]</a><br><a href="#">HS I2C System Test Mode: [7]</a>                                                                    |
| HS I2C Basic Programming Model | <a href="#">HS I2C Configure the Module Before Enabling the I2C Controller (I2C Mode): [8] [9]</a><br><a href="#">HS I2C Configure the Module Before Enabling the I2C Controller (SCCB Mode): [10] [11]</a> |
| HS I2C Register Manual         | <a href="#">HS I2C Register Summary: [12]</a>                                                                                                                                                               |

**Table 17-43. I2C\_SCLL**

| <b>Address Offset</b>                                    | 0x34                                                                   |                                                                 |  |  |                 |      |  |      |       |
|----------------------------------------------------------|------------------------------------------------------------------------|-----------------------------------------------------------------|--|--|-----------------|------|--|------|-------|
| <b>Physical Address</b>                                  | 0x4806 0034                                                            |                                                                 |  |  | <b>Instance</b> | I2C3 |  |      |       |
|                                                          | 0x4807 0034                                                            |                                                                 |  |  |                 | I2C1 |  |      |       |
|                                                          | 0x4807 2034                                                            |                                                                 |  |  |                 | I2C2 |  |      |       |
| <b>Description</b>                                       | This register is used to determine the SCL low time value when master. |                                                                 |  |  |                 |      |  |      |       |
| <b>Type</b>                                              | RW                                                                     |                                                                 |  |  |                 |      |  |      |       |
| 15      14      13      12      11      10      9      8 | 7      6      5      4      3      2      1      0                     |                                                                 |  |  |                 |      |  |      |       |
| HSSCLL                                                   |                                                                        |                                                                 |  |  |                 |      |  | SCLL |       |
| Bits                                                     | Field Name                                                             | Description                                                     |  |  |                 |      |  | Type | Reset |
| 15:8                                                     | HSSCLL                                                                 | I <sup>2</sup> C High Speed mode SCL low time value.            |  |  |                 |      |  | RW   | 0x00  |
| 7:0                                                      | SCLL                                                                   | I <sup>2</sup> C Fast/Standard or SCCB modes SCL low time value |  |  |                 |      |  | RW   | 0x00  |

**Table 17-44. Register Call Summary for Register I2C\_SCLL**

|                                |                                                                                                                                                                                                        |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HS I2C Functional Description  | <a href="#">HS I2C Clocking: [0] [1] [2] [3] [4] [5] [6]</a><br><a href="#">HS I2C System Test Mode: [7]</a>                                                                                           |
| HS I2C Basic Programming Model | <a href="#">HS I2C Configure the Module Before Enabling the I2C Controller (I2C Mode): [8] [9]</a><br><a href="#">HS I2C Configure the Module Before Enabling the I2C Controller (SCCB Mode): [10]</a> |
| HS I2C Register Manual         | <a href="#">HS I2C Register Summary: [11]</a>                                                                                                                                                          |

**Table 17-45. I2C\_SCLH**

|                                                          |                                                                        |  |  |  |                 |      |  |  |  |
|----------------------------------------------------------|------------------------------------------------------------------------|--|--|--|-----------------|------|--|--|--|
| <b>Address Offset</b>                                    | 0x38                                                                   |  |  |  |                 |      |  |  |  |
| <b>Physical Address</b>                                  | 0x4806 0038                                                            |  |  |  | <b>Instance</b> | I2C3 |  |  |  |
|                                                          | 0x4807 0038                                                            |  |  |  |                 | I2C1 |  |  |  |
|                                                          | 0x4807 2038                                                            |  |  |  |                 | I2C2 |  |  |  |
| <b>Description</b>                                       | This register is used to determine the SCL low time value when master. |  |  |  |                 |      |  |  |  |
| <b>Type</b>                                              | RW                                                                     |  |  |  |                 |      |  |  |  |
| 15      14      13      12      11      10      9      8 | SCLH                                                                   |  |  |  |                 |      |  |  |  |
|                                                          | HSSCLH                                                                 |  |  |  |                 |      |  |  |  |

| Bits | Field Name | Description                                                      | Type | Reset |
|------|------------|------------------------------------------------------------------|------|-------|
| 15:8 | HSSCLH     | I <sup>2</sup> C high-speed mode SCL high time value             | RW   | 0x00  |
| 7:0  | SCLH       | I <sup>2</sup> C Fast/Standard or SCCB modes SCL high time value | RW   | 0x00  |

**Table 17-46. Register Call Summary for Register I2C\_SCLH**

## HS I2C Functional Description

- [HS I2C Clocking: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\]](#)
- [HS I2C System Test Mode: \[7\]](#)

## HS I2C Basic Programming Model

- [HS I2C Configure the Module Before Enabling the I2C Controller \(I2C Mode\): \[8\] \[9\]](#)
- [HS I2C Configure the Module Before Enabling the I2C Controller \(SCCB Mode\): \[10\]](#)

## HS I2C Register Manual

- [HS I2C Register Summary: \[11\]](#)

**Table 17-47. I2C\_SYSTEST**

|                                                          |                                                                                                                                  |       |     |          |                 |            |            |         |  |
|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-------|-----|----------|-----------------|------------|------------|---------|--|
| <b>Address Offset</b>                                    | 0x3C                                                                                                                             |       |     |          |                 |            |            |         |  |
| <b>Physical Address</b>                                  | 0x4806 003C                                                                                                                      |       |     |          | <b>Instance</b> | I2C3       |            |         |  |
|                                                          | 0x4807 003C                                                                                                                      |       |     |          |                 | I2C1       |            |         |  |
|                                                          | 0x4807 203C                                                                                                                      |       |     |          |                 | I2C2       |            |         |  |
| <b>Description</b>                                       | This register is used to facilitate system-level tests by overriding some of the standard functional features of the peripheral. |       |     |          |                 |            |            |         |  |
| <b>Type</b>                                              | RW                                                                                                                               |       |     |          |                 |            |            |         |  |
| 15      14      13      12      11      10      9      8 | SYSTEST                                                                                                                          |       |     |          |                 |            |            |         |  |
| ST_EN                                                    | FREE                                                                                                                             | TMODE | SSB | Reserved | SCL_I_FUNC      | SCL_O_FUNC | SDA_O_FUNC | SDA_I_O |  |

| Bits | Field Name | Description                                                                                                           | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------|------|-------|
| 15   | ST_EN      | System test enable<br>0x0: Normal mode<br>0x1: System test enabled. Permit other system test registers bits to be set | RW   | 0     |
| 14   | FREE       | Free-running mode                                                                                                     | RW   | 0     |

| Bits  | Field Name | Description                                                                                                                                                                                                                                  | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|       |            | 0x0: Stop mode (on breakpoint condition). If Master mode, it stops after completion of the ongoing bit transfer. In slave mode, it stops during the phase transfer when 1 byte is completely transmitted/received.<br>0x1: Free-running mode |      |       |
| 13:12 | TMODE      | Test mode select<br>0x0: Functional mode (default)<br>0x1: Reserved<br>0x2: Test of SCL counters (SCLL, SCLH, PSC). SCL provides a permanent clock with master mode.<br>0x3: Loop back mode select + SDA/SCL IO mode select                  | RW   | 0     |
| 11    | SSB        | Set status bits<br>0x0: No action<br>0x1: Set all interrupt status bits to 1                                                                                                                                                                 | RW   | 0     |
| 10:9  | Reserved   | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                           | RW   | 0x0   |
| 8     | SCL_I_FUNC | SCL line input value (functional mode).<br>0x0: Read 0 from SCL line<br>0x1: Read 1 from SCL line                                                                                                                                            | R    | 1     |
| 7     | SCL_O_FUNC | SCL line output value (functional mode).<br>0x0: Driven 0 on SCL line<br>0x1: Driven 1 on SCL line                                                                                                                                           | R    | 1     |
| 6     | SDA_I_FUNC | SDA line input value (functional mode).<br>0x0: Read 0 from SDA line<br>0x1: Read 1 from SDA line                                                                                                                                            | R    | 1     |
| 5     | SDA_O_FUNC | SDA line output value (functional mode).<br>0x0: Driven 0 to SDA line<br>0x1: Driven 1 to SDA line                                                                                                                                           | RW   | 0     |
| 4     | SCCBE_O    | SCCBE line sense output value. Writing is possible only if ST_EN bit is set to 1<br>0x0: Write 0 to SCCBE line<br>0x1: Write 1 to SCCBE line                                                                                                 | RW   | 0     |
| 3     | SCL_I      | SCL line sense input value<br>0x0: Read 0 from SCL line<br>0x1: Read 1 from SCL line                                                                                                                                                         | R    | 0     |
| 2     | SCL_O      | SCL line drive output value. Writing is possible only if ST_EN bit is set to 1<br>0x0: Write 0 to SCL line<br>0x1: Write 1 to SCL line                                                                                                       | RW   | 0     |
| 1     | SDA_I      | SDA line sense input value<br>0x0: Read 0 from SDA line<br>0x1: Read 1 from SDA line                                                                                                                                                         | R    | 0     |
| 0     | SDA_O      | SDA line drive output value. Writing is possible only if ST_EN bit is set to 1<br>0x0: Write 0 to SDA line<br>0x1: Write 1 to SDA line                                                                                                       | RW   | 0     |

**Table 17-48. Register Call Summary for Register I2C\_SYSTEST**

## HS I2C Functional Description

- [HS I2C System Test Mode: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)

## HS I2C Register Manual

- [HS I2C Register Summary: \[10\]](#)

**Table 17-49. I2C\_BUFSTAT**

|                         |                                                     |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------|--|--|--|--|--|--|--|-----------------|------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x40                                                |  |  |  |  |  |  |  | <b>Instance</b> | I2C3 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4806 0040                                         |  |  |  |  |  |  |  |                 | I2C1 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4807 0040                                         |  |  |  |  |  |  |  |                 | I2C2 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register contains the FIFO status information. |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                   |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7      | 6 | 5        | 4 | 3 | 2 | 1 | 0      |  |
|-----------|----|----|----|----|----|---|---|--------|---|----------|---|---|---|---|--------|--|
| FIFODEPTH |    |    |    |    |    |   |   | RXSTAT |   | Reserved |   |   |   |   | TXSTAT |  |

| Bits  | Field Name               | Description                                                                                                                                                                                                                             | Type | Reset |
|-------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15:14 | FIFODEPTH <sup>(1)</sup> | FIFO depth indication.<br><br>Read 8-bytes FIFO<br>0x0:<br><br>Read 16-bytes FIFO<br>0x1:<br><br>Read 32-bytes FIFO<br>0x2:<br><br>Read 64-bytes FIFO<br>0x3:                                                                           | R    | 0x3   |
| 13:8  | RXSTAT                   | RX Buffer Status. It indicates the number of bytes to be read in the RX FIFO when the <a href="#">I2C_STAT[RDR]</a> is asserted (set to 1). This indication is useful only in receiver mode when the draining feature is enabled.       | R    | 0x00  |
| 7:6   | Reserved                 | Write 0s for future compatibility. Read returns 0.                                                                                                                                                                                      | R    | 0x0   |
| 5:0   | TXSTAT                   | TX Buffer Status. It indicates the number of bytes to be written in the TX FIFO when the <a href="#">I2C_STAT[XDR]</a> is asserted (set to 1). This indication is useful only in transmitter mode when the draining feature is enabled. | R    | 0x00  |

<sup>(1)</sup> See Table 17-11

**Table 17-50. Register Call Summary for Register I2C\_BUFSTAT**

## HS I2C Integration

- [HS I2C Interrupt Requests: \[0\]](#)

## HS I2C Functional Description

- [HS I2C FIFO Management: \[1\]](#)
- [HS I2C Draining Feature \(I2C Mode Only\): \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)

## HS I2C Register Manual

- [HS I2C Register Summary: \[10\]](#)

**Table 17-51. I2C\_OA1**

|                                            |                                                                          |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
|--------------------------------------------|--------------------------------------------------------------------------|--|--|--|--|--|--|-----|--|--|--|--|--|--|--|
| <b>Address Offset</b>                      | 0x44                                                                     |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <b>Physical Address</b>                    | 0x4806 0044 <b>Instance</b> I2C3                                         |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
|                                            | 0x4807 0044      I2C1                                                    |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
|                                            | 0x4807 2044      I2C2                                                    |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <b>Description</b>                         | This register is used to specify the module I2C 7-bit or 10-bit address. |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <b>Type</b>                                | RW                                                                       |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| 15    14    13    12    11    10    9    8 | 7    6    5    4    3    2    1    0                                     |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| RESERVED                                   |                                                                          |  |  |  |  |  |  | OA1 |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                        | Type | Reset |
|-------|------------|----------------------------------------------------|------|-------|
| 15:10 | RESERVED   | Write 0s for future compatibility. Read returns 0. | R    | 0x00  |
| 9:0   | OA1        | Own address 1 value                                | RW   | 0x000 |

**Table 17-52. Register Call Summary for Register I2C\_OA1**

- HS I2C Register Manual
- [HS I2C Register Summary: \[0\]](#)

**Table 17-53. I2C\_OA2**

|                                            |                                                                          |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
|--------------------------------------------|--------------------------------------------------------------------------|--|--|--|--|--|--|-----|--|--|--|--|--|--|--|
| <b>Address Offset</b>                      | 0x48                                                                     |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <b>Physical Address</b>                    | 0x4806 0048 <b>Instance</b> I2C3                                         |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
|                                            | 0x4807 0048      I2C1                                                    |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
|                                            | 0x4807 2048      I2C2                                                    |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <b>Description</b>                         | This register is used to specify the module I2C 7-bit or 10-bit address. |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <b>Type</b>                                | RW                                                                       |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| 15    14    13    12    11    10    9    8 | 7    6    5    4    3    2    1    0                                     |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| RESERVED                                   |                                                                          |  |  |  |  |  |  | OA2 |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                        | Type | Reset |
|-------|------------|----------------------------------------------------|------|-------|
| 15:10 | RESERVED   | Write 0s for future compatibility. Read returns 0. | R    | 0x00  |
| 9:0   | OA2        | Own address 2 value                                | RW   | 0x000 |

**Table 17-54. Register Call Summary for Register I2C\_OA2**

- HS I2C Register Manual
- [HS I2C Register Summary: \[0\]](#)

**Table 17-55. I2C\_OA3**

|                         |                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x4C                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4806 004C <b>Instance</b> I2C3                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4807 004C      I2C1                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4807 204C      I2C2                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register is used to specify the module I2C 7-bit or 10-bit address. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |    |    |    |    |    |   |   | OA3 |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                        | Type | Reset |
|-------|------------|----------------------------------------------------|------|-------|
| 15:10 | Reserved   | Write 0s for future compatibility. Read returns 0. | RW   | 0x00  |
| 9:0   | OA3        | Own address 3 value                                | RW   | 0x000 |

**Table 17-56. Register Call Summary for Register I2C\_OA3**

HS I2C Register Manual

- [HS I2C Register Summary: \[0\]](#)

**Table 17-57. I2C\_ACTOA**

|                         |                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x50                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4806 0050 <b>Instance</b> I2C3                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4807 0050      I2C1                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4807 2050      I2C2                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register contains the accessed slave Own Address indicators. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |         |
|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------|
| 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
| Reserved |    |    |    |    |    |   |   |   |   |   |   |   |   |   | OA3_ACT |

| Bits | Field Name | Description                                                                                            | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------|------|-------|
| 15:4 | Reserved   | Write 0s for future compatibility. Read returns 0.                                                     | R    | 0x000 |
| 3    | OA3_ACT    | Own Address 3 active<br>Read      Own Address inactive<br>0x0:<br>Read      Own Address active<br>0x1: | R    | 0     |
| 2    | OA2_ACT    | Own Address 2 active<br>Read      Own Address inactive<br>0x0:<br>Read      Own Address active<br>0x1: | R    | 0     |
| 1    | OA1_ACT    | Own Address 1 active<br>Read      Own Address inactive<br>0x0:<br>Read      Own Address active<br>0x1: | R    | 0     |
| 0    | OA0_ACT    | Own Address 0 active                                                                                   | R    | 0     |

| Bits | Field Name | Description                    | Type | Reset |
|------|------------|--------------------------------|------|-------|
|      |            | Read 0x0: Own Address inactive |      |       |
|      |            | Read 0x1: Own Address active   |      |       |

**Table 17-58. Register Call Summary for Register I2C\_ACTOA**

HS I2C Functional Description

- [HS I2C Programmable Multislave Channel Feature \(I2C Mode Only\): \[0\]](#)

HS I2C Register Manual

- [HS I2C Register Summary: \[1\]](#)

**Table 17-59. I2C\_SBLOCK**

|                         |                                                               |  |  |  |  |  |  |  |  |  |                 |      |  |  |
|-------------------------|---------------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|------|--|--|
| <b>Address Offset</b>   | 0x54                                                          |  |  |  |  |  |  |  |  |  |                 |      |  |  |
| <b>Physical Address</b> | 0x4806 0054                                                   |  |  |  |  |  |  |  |  |  | <b>Instance</b> | I2C3 |  |  |
|                         | 0x4807 0054                                                   |  |  |  |  |  |  |  |  |  |                 | I2C1 |  |  |
|                         | 0x4807 2054                                                   |  |  |  |  |  |  |  |  |  |                 | I2C2 |  |  |
| <b>Description</b>      | This register controls the slave mode i2c bus clock features. |  |  |  |  |  |  |  |  |  |                 |      |  |  |
| <b>Type</b>             | RW                                                            |  |  |  |  |  |  |  |  |  |                 |      |  |  |

|          |    |    |    |    |    |   |   |   |   |   |   |   |   |        |        |        |        |
|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|--------|--------|--------|--------|
| 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0      |        |        |
| RESERVED |    |    |    |    |    |   |   |   |   |   |   |   |   | OA3_EN | OA2_EN | OA1_EN | OA0_EN |

| Bits | Field Name | Description                                                                                      | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------|------|-------|
| 15:4 | RESERVED   | Write Os for future compatibility. Read returns 0.                                               | R    | 0x000 |
| 3    | OA3_EN     | Enable I2C Clock Blocking for Own Address 3<br>0x0: I2C Clock Released<br>0x1: I2C Clock Blocked | RW   | 0     |
| 2    | OA2_EN     | Enable I2C Clock Blocking for Own Address 2<br>0x0: I2C Clock Released<br>0x1: I2C Clock Blocked | RW   | 0     |
| 1    | OA1_EN     | Enable I2C Clock Blocking for Own Address 1<br>0x0: I2C Clock Released<br>0x1: I2C Clock Blocked | RW   | 0     |
| 0    | OA0_EN     | Enable I2C Clock Blocking for Own Address 0<br>0x0: I2C Clock Released<br>0x1: I2C Clock Blocked | RW   | 0     |

**Table 17-60. Register Call Summary for Register I2C\_SBLOCK**

HS I2C Functional Description

- [HS I2C Automatic Blocking of the I2C Clock Feature \(I2C Mode Only\): \[0\]](#)

HS I2C Register Manual

- [HS I2C Register Summary: \[1\]](#)

This chapter describes the features and functions of the HDQ/1-Wire module.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                                | Page        |
|------------------------------------------------------|-------------|
| <b>18.1 HDQ/1-Wire Overview .....</b>                | <b>2864</b> |
| <b>18.2 HDQ/1-Wire Environment .....</b>             | <b>2865</b> |
| <b>18.3 HDQ/1-Wire Integration .....</b>             | <b>2868</b> |
| <b>18.4 HDQ/1-Wire Functional Description .....</b>  | <b>2870</b> |
| <b>18.5 HDQ/1-Wire Basic Programming Model .....</b> | <b>2876</b> |
| <b>18.6 HDQ/1-Wire Use Cases and Tips .....</b>      | <b>2880</b> |
| <b>18.7 HDQ/1-Wire Register Manual .....</b>         | <b>2883</b> |

## 18.1 HDQ/1-Wire Overview

The HDQ/1-Wire module implements the hardware protocol of the master functions of the Benchmark HDQ and the Dallas Semiconductor 1-Wire® protocols. These protocols use a single wire for communication between the master (HDQ/1-Wire controller) and the slaves (HDQ/1-Wire external compliant devices).

Figure 18-1 shows the HDQ/1-Wire controller module.

**Figure 18-1. HDQ/1-Wire Highlight**



The HDQ and 1-Wire module has a generic L4 interface and is intended to be used in an interrupt-driven fashion. The one-pin interface is implemented as an open-drain output at the device level.

The HDQ operates from a fixed 12-MHz functional clock provided by the PRCM module.

Only the MPU subsystem uses the HDQ/1-Wire module.

The main features of the HDQ/1-Wire module support the following:

- Benchmark HDQ protocol
- Dallas Semiconductor 1-Wire protocol
- Power-down mode

The HDQ/1-Wire module provides a communication rate of 5K bits/s over an address space of 128 bytes.

A typical application of the HDQ/1-Wire module is the communication with battery monitor (gas gauge) integrated circuits.

## 18.2 HDQ/1-Wire Environment

### 18.2.1 HDQ/1-Wire Functional Interface

Figure 18-2 shows a typical application using the HDQ/1-Wire connection.

**Figure 18-2. HDQ/1-Wire Typical Application System Overview**



hdq1wr-002

An external pullup is required, because the two protocols use a return-to-1 mechanism (that is, logical '1' level is applied by a pullup after any drive-to-zero by a HDQ/1-Wire master or slave). Pullup is typically implemented as a resistor connected between HDQ/1-Wire line and the I/O power supply.

The HDQ/1-Wire module operates according to a command structure that is programmed into transmit command registers (as described in [Section 18.5](#)).

The 1-Wire mode runs at slower speeds than the capabilities of the mode.

[Table 18-1](#) describes the external signal for connection with HDQ or 1-Wire compliant devices.

**Table 18-1. I/O Description**

| Signal Name | I/O   | Description                                             | Value at Reset |
|-------------|-------|---------------------------------------------------------|----------------|
| hdq_sio     | Bidir | Serial data input/output.<br>Output is open drain type. | 0              |

### 18.2.2 HDQ and 1-Wire (SDQ) Protocols

#### 18.2.2.1 HDQ Protocol Initialization (Default)

In HDQ mode, the firmware does not require the host to create an initialization pulse to the slave.

However, the slave can be reset by using an initialization pulse (also referred to as a break pulse). The initialization pulse is generated by setting the INITIALIZATION bit (HDQ.[HDQ\\_CTRL\\_STATUS](#)[2]). The slave does not respond with a presence pulse as it does in the 1-Wire protocol.

The HDQ is a command-based protocol in which the host sends a command byte to the slave. The command directs the slave either to store the next eight bits of data received to a register specified by the command byte (write operation) or to output the eight bits of data from a register specified by the command byte (read operation). The master implementation is a simple byte engine. The sending of the ID, command/address, and data is controlled by firmware. The master engine provides only a single HDQ.[HDQ\\_TX\\_DATA](#) register.

The command and data bytes consist of a stream of eight bits with a maximum transmission rate of 5K bits/s. The least significant bit (LSB) of a command or data byte is transmitted first. If a communication time-out occurs between the host and the slave (for example, if the host waits longer than the specified time for the slave to respond, or if this is the first access command), then the host must send an initialization pulse (BREAK pulse) before sending the command again.

The slave detects a break when the HDQ pin is driven to a logic-low state for a specified break time  $t(B)$  or greater. The HDQ pin then returns to its normal ready-high logic state for a specified break-recovery time  $t(BR)$ . The slave is then ready for a command from the host processor. [Figure 18-3](#) shows this behavior.

An interrupt condition indicates either a TX-complete, an RX-complete, or a time-out condition. Reading the interrupt status register clears all interrupt conditions. Only one interrupt signal is sent to the microcontroller, and only one overall mask bit can enable or disable the interrupt. The interrupt conditions cannot be individually masked.

**Figure 18-3. HDQ Break-Pulse Timing Diagram**



#### 18.2.2.2 1-Wire (SDQ) Protocol Initialization

In 1-Wire (SDQ) protocol, the host first sends an initialization pulse (by pulling the line to a logic-low state) and then waits for the slave to respond with a presence pulse before enabling any communication sequence.

As for the initialization pulse, the presence pulse is a low-going edge on the line initiated by the slave. The timing diagram in [Figure 18-4](#) shows the 1-Wire (SDQ) reset sequence.

**Figure 18-4. 1-Wire (SDQ) Reset Timing Diagram**



The host drives the line to a logic-low state for a minimum of reset low time. Once the slave detects this pulse, it must drive the line to a logic-low state within the presence pulse high delay for a minimum period of presence pulse low time.

If the slave does not respond within this interval of time, a time-out event occurs and no transaction can be initiated. The host must initiate the reset sequence again before sending any command to the slave.

On the other hand, if the slave sends back its presence pulse within the specified interval of time, the communication can be enabled after the reset high time.

#### 18.2.2.3 Communication Sequence (HDQ and 1-Wire Protocols)

This section describes the part common to both protocols.

After a successful break pulse (HDQ mode) or initialization sequence (1-Wire protocol), the host and slave are ready for bit transmission. Each bit to transmit (either from the host to the slave or from the slave to the host) is preceded by a low-going edge on the line, as shown in [Figure 18-5](#).

**Figure 18-5. HDQ/1-Wire Transmitted Bit Timing**


hdq1wr-005

The return-to-1 data-bit frame consists of three distinct sections. The first section starts the transmission when either the slave or the host takes the line to a logic-low state. The next section is the actual data transmission in which the data must be valid during a specified period of time after the negative edge that starts the communication. The final section stops the transmission by returning the HDQ/1-Wire line to a logic-high state. Communication with an HDQ/1-Wire slave always occurs with the LSB being transmitted first.

The command byte of the HDQ/1-Wire protocols consists of eight contiguous valid command bits. The command byte contains two fields: R/W command and address. The R/W bit of the command byte determines whether the command is a read or a write, and the address field containing bits AD6-AD0 indicates the address to be read or written. [Table 18-2](#) lists the command byte values.

**Table 18-2. HDQ/1-Wire Command Byte**

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| R/W | AD6 | AD5 | AD4 | AD3 | AD2 | AD1 | AD0 |

- R/W**      Indicates whether the command byte is a read or a write. A 1 indicates a write command; the following eight bits must be written to the register specified by the address field of the command byte. A 0 indicates that the command is a read. On a read command, the slave outputs the requested register contents.
- AD6-AD0**      Represent the seven bits labeled AD6-AD0 containing the address portion of the register to be accessed.  
The communication sequence example in [Figure 18-6](#) shows a read command at address 0x55; the received data is 0x65.

**Figure 18-6. HDQ/1-Wire Communication Sequence**


hdq1wr-006

## 18.3 HDQ/1-Wire Integration

Figure 18-7 shows the HDQ/1-Wire module integration in the device.

**Figure 18-7. HDQ/1-Wire Integration**



### 18.3.1 Clocking, Reset, and Power-Management Scheme

#### 18.3.1.1 HDQ/1-Wire Clocks

There are two clock domains in the HDQ/1-Wire module: the functional clock domain and the interface clock domain. When these clocks are set in the PRCM module, the following rule must be observed:  $\text{HDQ\_ICLK} \geq \text{HDQ\_FCLK}$ .

- HDQ\_FCLK belongs to the functional clock domain. It is a fixed 12-MHz clock provided by the PRCM. It is used to clock the internal module logic.

The HDQ\_FCLK source is the CORE\_12M\_FCLK PRCM output, which is derived from the CORE\_48M\_FCLK clock signal (a 1/4 ratio is applied). The CORE\_12M\_FCLK clock is issued from the peripherals DPLL4. For more information about the clock, see [Chapter 3, Power, Reset, and Clock Management](#).

When the HDQ/1-Wire module no longer requires the HDQ\_FCLK, the software can disable it at the PRCM level by setting the EN\_HDQ bit (PRCM.CM\_FCLKEN1\_CORE[22]) in the PRCM registers. The clock is effectively cut, provided the other modules that receive it do not require it either.

For details about the PRCM register settings and DPLL4 configuration, see [Chapter 3, Power, Reset, and Clock Management](#).

- HDQ\_ICLK is the interface clock. It runs at L4 interconnect clock speed and is used to trigger access to the HDQ/1-Wire L4 interface. Its source is the PRCM CORE\_L4\_ICLK signal. It typically runs at L3/2 frequency.

When the HDQ/1-Wire module no longer requires the HDQ\_ICLK, the software can disable it at the PRCM level by setting the EN\_HDQ bit (PRCM.CM\_ICLKEN1\_CORE[22]) in the PRCM registers. The clock is effectively cut, provided the other modules that receive it do not require it either.

It is also possible to activate an autoidle mode for this clock (AUTO\_HDQ bit PRCM.CM\_AUTOIDLE1\_CORE[22] set to 1). In this case, HDQ\_ICLK follows the CORE clock domain behavior. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

### 18.3.1.2 HDQ/1-Wire Reset Scheme

Global reset of the module is done either by activating the CORE\_RST signal in the CORE\_RST domain (for more information, see [Chapter 3, Power, Reset, and Clock Management](#)) or by setting to 1 the SOFTRESET bit HDQ.[HDQ\\_SYSCONFIG\[1\]](#). Setting this bit enables an active software reset functionality equivalent to a hardware reset.

### 18.3.1.3 HDQ/1-Wire Power Domain

The HDQ/1-Wire belongs to the CORE power domain. For more information about the CORE power domain, see [Chapter 3, Power, Reset, and Clock Management](#).

### 18.3.2 Hardware Requests

The HDQ/1-Wire can generate one interrupt:

- HDQ\_IRQ: This is an interrupt to the MPU subsystem interrupt controller. It is mapped on M\_IRQ\_58.

## 18.4 HDQ/1-Wire Functional Description

The HDQ/1-Wire module works with both the HDQ and 1-Wire protocols. The protocols use a single wire to establish communication between the master and the slave. Both protocols use a return-to-1 mechanism; that is, after any command is driven, the line is pulled to a high level. This mechanism requires an external pullup.

### 18.4.1 HDQ/1-Wire Block Diagram

Figure 18-8 shows the HDQ/1-Wire block diagram.

**Figure 18-8. HDQ/1-Wire Block Diagram**



The MODE bit HDQ.HDQ\_CTRL\_STATUS[0] allows selection between the HDQ and 1-Wire protocols. This bit is assumed static for design purposes. The configuration is in HDQ mode by default.

Figure 18-9 shows the protocol-dedicated register scheme.

**Figure 18-9. Protocol Registers Description**


hdq1wr-009

The receive and transmit operations are performed with respect to the HDQ protocol timing. The module is implemented once in the device and is clocked with a single clock whether it runs HDQ or 1-Wire protocol. Although the data exchange is slower than the capabilities of the 1-Wire mode, this mode still meets the timing requirements and practical considerations. That is, the 1-Wire protocol runs at the HDQ protocol speed, which is slower (5K bits/s). The timing parameters and protocol are different in the two modes.

#### **18.4.2 HDQ Mode (Default)**

##### **18.4.2.1 HDQ Mode Features**

The HDQ mode supports the following:

- Benchmark HDQ protocol
- Power-down mode

##### **18.4.2.2 Description**

In the HDQ mode, there is no need for the host to create an initialization pulse to the slave. However, the host can reset the slave by using an initialization pulse (also known as a break pulse). Setting the INITIALIZATION bit HDQ\_CTRL\_STATUS[2] creates this pulse by pulling the line down. When the slave receives the pulse, it is ready for communication but does not respond with a presence pulse.

In a typical write operation, two bytes are sent to the slave. The first byte corresponds to the command/address byte, and the second byte corresponds to the data to be written.

In a typical read operation, the host sends a command/address byte and the slave returns a byte of data.

The master is implemented to send and receive bytes. Sending the command/address and data is controlled by the firmware. The master provides only a single data TX register.

The HDQ protocol is a return-to-1 protocol. Consequently, after a byte is sent to the slave (either command/address + data for a write, or just command/address for a read), the host pulls the line up. The line is set to the high-impedance state in the device and an external pullup brings it to a logical high level.

In the case of a read operation, the slave also drives the line to a logic-low state before sending the requested data.

If the host initiates a read and does not receive data within a specified interval of time (that is, the slave does not drive the line low within this interval), the TIMEOUT bit HDQ.[HDQ\\_INT\\_STATUS\[0\]](#) is set, thereby indicating a read failure. The TIMEOUT bit remains set until the host reads the interrupt status register (HDQ.[HDQ\\_INT\\_STATUS](#)).

An interrupt condition indicates either a TX-complete, an RX-complete, or a time-out on a transaction. The corresponding bit is set in the interrupt status register (HDQ.[HDQ\\_INT\\_STATUS](#)). This register is cleared as soon as it is read.

Only one interrupt signal is sent to the MPU, and only an overall mask can enable or disable the interrupts. These interrupts cannot be individually masked.

#### 18.4.2.3 Single-Bit Mode

In HDQ mode, the single-bit mode (1\_WIRE\_SINGLE\_BIT bit HDQ.[HDQ\\_CTRL\\_STATUS\[7\]](#) set to 1) has no effect because the HDQ protocol supports only byte transfers.

#### 18.4.2.4 Interrupt Conditions

The HDQ/1-Wire module provides the following interrupt status:

1. Transmission complete:

A write operation of one byte was completed. Successful or failed completion is not indicated, because there is no acknowledgment from the slave in HDQ protocol. This interrupt condition is cleared by reading the interrupt status register (HDQ.[HDQ\\_INT\\_STATUS](#)).

2. Read complete:

In HDQ mode, the interrupt status indicates that a byte has been successfully read. This interrupt condition is cleared by reading the interrupt status register (HDQ.[HDQ\\_INT\\_STATUS](#)).

3. Presence detect/time-out:

In HDQ mode, the interrupt status indicates that after a read command initiated by the host, the slave did not pull the line low within the specified time. This interrupt condition is cleared by reading the interrupt status register (HDQ.[HDQ\\_INT\\_STATUS](#)).

In HDQ mode, a time-out condition is also used to indicate the successful completion of a break pulse. That is, if the master has sent the break pulse, it is indicated with a time-out instead of a TX-complete.

Only one interrupt is generated to the MPU based on any of these interrupt conditions. A read operation on the interrupt status register clears all the interrupt status bits that were previously set.

### 18.4.3 1-Wire Mode

#### 18.4.3.1 1-Wire Mode Features

The 1-Wire mode supports the following:

- Dallas Semiconductor 1-Wire protocol
- Power-down mode
- Single-bit mode

#### 18.4.3.2 Description

The 1-Wire mode requires an initialization pulse to be sent to the slave(s) connected on the interface. If a slave is present, it responds with a presence pulse.

The initialization pulse is sent after INITIALIZATION bit HDQ.[HDQ\\_CTRL\\_STATUS\[2\]](#) is set. The firmware sends the initialization pulse depending on the value of this bit.

The slave presence on the line is detected by a presence bit in the control and status register. When the slave receives the initialization pulse, it sends back its presence pulse by pulling down the line. The module detects this low-going edge and sets the PRESENCEDETECT bit HDQ.[HDQ\\_CTRL\\_STATUS\[3\]](#).

In a similar way, if a presence pulse is not received from the slave after an initialization pulse is sent, the PRESENCEDETECT bit remains cleared.

Whether or not a presence pulse is detected after an initialization pulse is sent, the TIMEOUT bit HDQ.[HDQ\\_INT\\_STATUS\[0\]](#) is set and an interrupt condition is generated.

In 1-Wire mode, the generated interrupt condition means the maximum time allowed for receiving the response has elapsed and the software must check the PRESENCEDETECT bit to determine whether or not there was a presence pulse.

The INITIALIZATION bit is cleared at the end of the initialization pulse at the same time as the TIMEOUT bit is set. The TIMEOUT bit is cleared when the interrupt status register (HDQ.[HDQ\\_INT\\_STATUS](#)) is read.

For read operations, 1-Wire is a bit-by-bit protocol, which means the slave must be clocked by the host for each bit of the byte to read.

The line is pulled up at the end of the command/address byte. On the first read, the host creates a low-going edge to initiate a bit read. The line is then pulled up (pulled to the high-impedance state by the host and set to a high logical level by the external pullup) and the slave either drives the line low to transmit a 0 or does not drive the line to transmit a 1. This sequence is repeated for each bit to read.

The first bit the host receives is the LSB, and the last bit is the most significant bit (MSB) in the receive data register (HDQ.[HDQ\\_RX\\_DATA](#)).

An interrupt condition indicates either a TX-complete, an RX-complete, or a time-out condition (that is, the time allowed for the slave to indicate its presence has elapsed). A read operation on the interrupt status register clears the interrupt conditions previously set. As in the HDQ mode, only one interrupt signal is sent to the MPU. Only an overall mask bit can enable or disable the interrupt (the interrupt conditions cannot be masked individually).

#### 18.4.3.3 1-Wire Single-Bit Mode Operation

A single-bit mode can be entered by setting the appropriate bit in the control and status register (1\_WIRE\_SINGLE\_BIT bit HDQ.[HDQ\\_CTRL\\_STATUS\[7\]](#)). In this mode, only one bit of data at a time is transferred between the master and the slave. After the bit is transferred, an interrupt is generated (that is, there is an RX-complete for a read operation and a TX-complete for a write operation). Bit 0 of the RX register (HDQ.[HDQ\\_RX\\_DATA](#)) is updated each time a bit is received from the slave; bit 0 of the TX register (HDQ.[HDQ\\_TX\\_DATA](#)) contains the bit to be sent.

#### 18.4.3.4 Interrupt Conditions

The HDQ/1-Wire module provides the following interrupt status:

1. Transmission complete:

A write operation of one byte was completed. Successful or failed completion is not indicated, because there is no acknowledgment from the slave in 1-Wire protocol. This interrupt condition is cleared by reading the interrupt status register (HDQ.[HDQ\\_INT\\_STATUS](#)).

2. Read complete:

In 1-Wire mode, the interrupt status indicates that a byte has been successfully read. This interrupt condition is cleared by reading the interrupt status register (HDQ.[HDQ\\_INT\\_STATUS](#)).

3. Presence detect/time-out:

In 1-Wire mode, the interrupt status indicates that it is now valid to check the PRESENCEDETECT bit. This interrupt condition is cleared by reading the interrupt status register (HDQ.[HDQ\\_INT\\_STATUS](#)).

Only one interrupt is generated to the MPU based on any of these interrupt conditions. A read operation on the interrupt status register clears all interrupt status bits that were previously set.

#### 18.4.3.5 Status Flags

The presence-condition-detected status flag is contained in the PRESENCEDETECT bit HDQ.[HDQ\\_CTRL\\_STATUS](#)[3]. This is valid only in 1-Wire mode. The flag is updated when TIMEOUT bit HDQ.[HDQ\\_INT\\_STATUS](#)[0] is set. Therefore, its correct value shows only after the interrupt is generated. The firmware must wait for the time-out condition; otherwise, the flag keeps its previous value and is undefined.

### 18.4.4 Module Power Saving

#### 18.4.4.1 Autoidle Mode

The HDQ/1-Wire module provides an autoidle function in its interconnect clock domain.

The interconnect clock autoidle power-saving mode is enabled or disabled through the AUTOIDLE bit HDQ.[HDQ\\_SYSCONFIG](#)[0]. When this mode is enabled and there is no activity on the interconnect interface, the interconnect clock (HDQ\_ICLK) is disabled inside the module, thereby reducing power consumption. When there is new activity on the interconnect interface, the interconnect clock is restarted with no latency penalty. This mode is disabled by default after a reset.

This mode is recommended to reduce power consumption.

#### 18.4.4.2 Power-Down Mode

The HDQ/1-Wire module also provides a power-saving function in its functional clock domain.

Setting the CLOCKENABLE bit in the control and status register (CLOCKENABLE bit HDQ.[HDQ\\_CTRL\\_STATUS](#)[5]) to 0 shuts off the functional clock (HDQ\_FCLK) to the state-machine. The state-machine is reset when the functional clock is disabled; if any transaction is ongoing, it is aborted into the reset state.

The register values are not affected by disabling the functional clock.

Do not access the module registers after the software has put the module in power-down mode except to write to the CLOCKENABLE bit to take the module out of power-down mode.

### 18.4.5 System Power Management and Wakeup

As part of the system-wide power-management scheme, the HDQ/1-Wire module can go into idle state at the request of the PRCM module (for more information, see [Chapter 3, Power, Reset, and Clock Management](#)). However, the HDQ/1-Wire module does not support handshake protocol with the PRCM. The HDQ/1-Wire module can go into idle mode only as part of the L4 interconnect clock domain (both CORE\_L4\_ICLK and FUNC\_12M\_CLK belong to the L4 interconnect clock domain).

When the AUTO\_HDQ bit PRCM.CM\_AUTOIDLE1\_CORE[22] is set, the HDQ/1-Wire module behavior follows the L4 interconnect clock domain behavior. If the whole domain is put into idle, the HDQ/1-Wire is also put into idle.

Software must ensure correct clock management.

**CAUTION**

There is no hardware mechanism to prevent cutting off the HDQ/1-Wire clocks while the module is performing a transfer. The result would be a loss of data being transferred.

## 18.5 HDQ/1-Wire Basic Programming Model

The HDQ/1-Wire module can be considered a simple byte engine because it only implements the hardware interface layer for both HDQ and 1-Wire protocols. The correct sequencing is controlled by the firmware, which is described in this section.

### 18.5.1 Module Initialization Sequence

#### 18.5.1.1 Mode Selection

MODE bit HDQ.[HDQ\\_CTRL\\_STATUS\[0\]](#) allows selection between the HDQ and 1-Wire protocols. When set to 0, the protocol is HDQ; when set to 1, the protocol is 1-Wire. The bit is assumed static for design purposes. The configuration is in HDQ mode by default.

Although this bit can be modified at any point, it is strongly recommended that it be modified only as part of the boot-up configuration.

#### 18.5.1.2 Reset/Initialization

No slave presence test is required in HDQ mode; however, the slave can be reset by setting the INITIALIZATION bit HDQ.[HDQ\\_CTRL\\_STATUS\[2\]](#) and the GO bit HDQ.[HDQ\\_CTRL\\_STATUS\[4\]](#). The line is then pulled down (break pulse) and the bit returns to 0 after the pulse is sent. Upon completion, a time-out interrupt is also generated. The slave does not respond to this pulse.

In 1-Wire mode, the slave returns a presence pulse when it receives the initialization pulse. The protocol for initialization is as follows:

1. Set the INITIALIZATION bit HDQ.[HDQ\\_CTRL\\_STATUS\[2\]](#) to 1 and the GO bit HDQ.[HDQ\\_CTRL\\_STATUS\[4\]](#) to 1 to send the pulse. When the pulse is sent, the bit is cleared in the register.
2. Wait for the presence detect flag (TIMEOUT bit HDQ.[HDQ\\_INT\\_STATUS\[0\]](#)) to generate an interrupt. This flag is set when the response time allowed to the slave has elapsed, whether it has sent a pulse or not.
3. Read the HDQ.[HDQ\\_CTRL\\_STATUS](#) register to check whether the presence pulse has been received before starting any transfer.

### 18.5.2 HDQ Protocol Basic Programming Model

#### 18.5.2.1 Write Operation

The write operation sequence is as follows:

1. Write the command/address or data value to the TX write register (HDQ.[HDQ\\_TX\\_DATA](#)).

---

**NOTE:** Steps 2 and 3 can be performed simultaneously.

---

2. Set DIR bit HDQ.[HDQ\\_CTRL\\_STATUS\[1\]](#) to indicate a write.
3. Set GO bit HDQ.[HDQ\\_CTRL\\_STATUS\[4\]](#) to start the transmission.
  - (a) The hardware sends the byte from the TX write register.
  - (b) In a write operation, the TIMEOUT bit is always cleared, because there is no acknowledge mechanism from the slave.
  - (c) When the write operation is completed, the TX-complete flag is set in the interrupt status register (TXCOMPLETE bit HDQ.[HDQ\\_INT\\_STATUS\[2\]](#)). If interrupts are masked (that is, the corresponding bit has been previously set in the control and status register), no interrupt signal is generated.
  - (d) The GO bit HDQ.[HDQ\\_CTRL\\_STATUS\[4\]](#) is cleared at the end of a write operation.
4. The software must read the interrupt status register to clear the interrupt.
5. Repeat step 1 through step 4 for each successive byte to write.

### 18.5.2.2 Read Operation

The read operation sequence is as follows:

1. Write the command value to the TX write register (HDQ.[HDQ\\_TX\\_DATA](#)).
2. Set DIR bit HDQ.[HDQ\\_CTRL\\_STATUS](#)[1] to 0 and GO bit HDQ.[HDQ\\_CTRL\\_STATUS](#)[4] to 1 and wait for the TX-complete interrupt.

---

**NOTE:** Steps 3 and 4 can be performed simultaneously.

3. Set DIR bit HDQ.[HDQ\\_CTRL\\_STATUS](#)[1] to 1 to indicate a read.
4. Write 1 to GO bit HDQ.[HDQ\\_CTRL\\_STATUS](#)[4] to initiate the read.
  - (a) The hardware detects a low-going edge on the line (generated by the slave) and receives 8 bits of data in the RX receive buffer register (HDQ.[HDQ\\_RX\\_DATA](#)). The first bit received is the LSB and the last bit is the MSB. The master performs this step as soon as the slave sends the data, irrespective of the state of GO bit HDQ.[HDQ\\_CTRL\\_STATUS](#)[4]. However, an RX-complete interrupt is generated only when the software writes the GO bit.
  - (b) If a time-out occurs, the TIMEOUT bit HDQ.[HDQ\\_CTRL\\_STATUS](#)[0] is set.
  - (c) Completion of the operation is indicated by setting the RX-complete flag in the interrupt status register (TXCOMPLETE bit HDQ.[HDQ\\_INT\\_STATUS](#)[1]). If interrupts are masked (that is, the corresponding bit was previously set in the control and status register), no interrupt signal is generated.
  - (d) At the end of the read operation, the GO bit HDQ.[HDQ\\_CTRL\\_STATUS](#)[4] is cleared. It is also cleared if a time-out is detected
5. The software must read the interrupt status register (HDQ.[HDQ\\_INT\\_STATUS](#)) to determine whether an RX was successfully completed or a time-out occurred.
6. The software reads the RX receive buffer register (HDQ.[HDQ\\_RX\\_DATA](#)) to retrieve the read data from the slave.
7. Repeat step 1 through step 6 for each successive byte.

---

**NOTE:** In HDQ mode, the address/command is written only once to the slave. However, after the first byte is received, an RX-complete interrupt is set. Therefore, the software must initiate the read of the second byte by setting the GO bit in the control and status register. The first byte received is shadowed and provided to the software while the hardware is fetching the second byte of data.

### 18.5.3 1-Wire Mode (SDQ) Basic Programming Model

#### 18.5.3.1 Write Operation

The write operation sequence is as follows:

1. Write the ID, command, or data value to the TX write register (HDQ.[HDQ\\_TX\\_DATA](#)).

---

**NOTE:** Steps 2 and 3 can be performed simultaneously.

2. Set DIR bit HDQ.[HDQ\\_CTRL\\_STATUS](#)[1] to 0 to indicate a write operation.
3. Set GO bit HDQ.[HDQ\\_CTRL\\_STATUS](#)[4] to 1 to start the transmission.
  - (a) The hardware sends the byte stored in the TX write register.
  - (b) In a write operation, the TIMEOUT bit is always cleared.
  - (c) When the operation is completed, the TX-complete flag is set in the interrupt status register (TXCOMPLETE bit [HDQ\\_INT\\_STATUS](#) [2]). No interrupt signal is generated if interrupts are masked (that is, the corresponding bit was previously set in the control and status register).
  - (d) The GO bit of the control and status register is cleared at the end of a write operation.

4. The software must read the interrupt status register (HDQ.HDQ\_INT\_STATUS) to clear the interrupt.
5. Repeat step 1 through step 4 for each successive byte to write.

### 18.5.3.2 Read Operation

The read operation sequence is as follows:

1. Write the address to the TX write register (HDQ.HDQ\_TX\_DATA).
2. Set DIR bit HDQ.HDQ\_CTRL\_STATUS[1] to 0 and the GO bit HDQ.HDQ\_CTRL\_STATUS[4] to 1 and wait for the TX-complete interrupt flag.
3. Write the command value to the TX write register (HDQ.HDQ\_TX\_DATA).
4. Set DIR bit HDQ.HDQ\_CTRL\_STATUS[1] to 0 and GO bit HDQ.HDQ\_CTRL\_STATUS[4] to 1 and wait for the TX-complete interrupt flag.

---

**NOTE:** Steps 5 and 6 can be performed simultaneously.

---

5. Set DIR bit HDQ.HDQ\_CTRL\_STATUS[1] to 1 to indicate a read.
6. Set GO bit HDQ.HDQ\_CTRL\_STATUS[4] to 1 to start the transmission.
  - (a) The hardware (master) generates a low-going edge and clocks 8 bits of data into the RX receive register (HDQ.HDQ\_RX\_DATA). The first bit received is the LSB and the last bit is the MSB.
  - (b) TIMEOUT bit HDQ.HDQ\_INT\_STATUS[0] is always cleared in a read operation.
  - (c) When the operation is complete, the RX-complete flag is set in the interrupt status register (RXCOMPLETE bit HDQ.HDQ\_INT\_STATUS[1]). No interrupt signal is generated if the interrupts are masked (that is, the corresponding bit was previously set in the control and status register).
  - (d) GO bit HDQ.HDQ\_CTRL\_STATUS[4] is cleared at the end of the read. It is also cleared if a time-out occurs.
7. The software must read the interrupt status register to determine whether an RX was successfully completed or a time-out occurred.
8. The software reads the RX receive buffer register (HDQ.HDQ\_RX\_DATA) to retrieve the read data from the slave.
9. Repeat step 1 through step 8 for each successive byte.

### 18.5.3.3 1-Wire Bit Mode Operation

Select the single-bit mode by setting the 1\_WIRE\_SINGLE\_BIT bit HDQ.HDQ\_CTRL\_STATUS[7] to 1. In this mode, only one bit of data at a time is transferred between the master and the slave. After the bit is transferred, the corresponding interrupt flag is set (that is, there is an RX-complete (RXCOMPLETE bit HDQ.HDQ\_INT\_STATUS[1]) for a read operation and a TX-complete (TXCOMPLETE bit HDQ.HDQ\_INT\_STATUS[2]) for a write operation). Bit 0 of the RX register (HDQ.HDQ\_RX\_DATA) is updated each time a bit is received; bit 0 of the TX register (HDQ.HDQ\_TX\_DATA) contains the bit of data to be sent.

### 18.5.4 Power Management

The software has independent control of the two clock domains (interconnect clock: HDQ\_ICLK and functional clock: HDQ\_FCLK). Because there is no acknowledge mechanism from the HDQ/1-Wire module to an idle request, the software must ensure that a clock is not shut off while a transfer is being processed (the data would be lost).

If the autoidle function (AUTOIDLE bit HDQ.HDQ\_SYSCONFIG[0] set to 1) provides a safe transfer (the module wakes up the HDQ\_ICLK as soon as a transfer is initiated), the power-down mode and the PRCM idle requests (through the whole L4 clock domain idle request) must be handled carefully.

The following sections describe the steps to follow to use the power-down and idle modes.

#### 18.5.4.1 Module Power-Down Mode

1. Before shutting off the HDQ\_FCLK, wait for an RX-complete or a TX-complete interrupt.

- In a read operation, the transfer is completed when the RX-complete flag (RXCOMPLETE bit HDQ.[HDQ\\_INT\\_STATUS](#) [1]) generates an interrupt.
- In a write operation, the transfer is completed when the TX-complete flag (TXCOMPLETE bit HDQ.[HDQ\\_INT\\_STATUS](#) [2]) generates an interrupt. The software must check whether the interrupt was generated after the address/command byte was sent or after the data byte was sent. The clock must not be shut off after the command/address byte is sent; otherwise, the data is not written to the slave.

HDQ.[HDQ\\_INT\\_STATUS](#) must be read to clear the interrupt condition.

2. Set the CLOCKENABLE bit HDQ.[HDQ\\_CTRL\\_STATUS](#)[5] to 0 to disable the clock.

Do not access the module registers after the software has put the module into power-down mode except to write to the clock-enable bit to take the module out of power-down mode.

#### **18.5.4.2 System Idle Mode**

This section describes the steps to follow at the module level before enabling the idle mode at the system level (for more information about the system power management scheme, see [Chapter 3, Power, Reset, and Clock Management](#)).

As part of the L4 interconnect clock domain, the HDQ/1-Wire clocks can be cut at the PRCM level. HDQ\_FCLK can be cut if the EN\_HDQ bit PRCM.CM\_FCLKEN1\_CORE [22] is set to 0 and no other modules require CORE\_12M\_FCLK. The software must verify that no transfer is in progress.

In a read operation:

1. Wait for an RX-complete interrupt.

In a read operation, the transfer is completed when the RX-complete flag (RXCOMPLETE bit HDQ.[HDQ\\_INT\\_STATUS](#) [1]) generates an interrupt.

2. Read the HDQ.[HDQ\\_INT\\_STATUS](#) to clear the read-complete interrupt flag.
3. Read the HDQ.[HDQ\\_RX\\_DATA](#) to retrieve the read data.
4. The HDQ\_ICLK can be shut off by entering the system idle mode.

In a write operation:

1. Wait for a TX-complete interrupt.

In a write operation, the transfer is completed when the TX-complete flag (TXCOMPLETE bit HDQ.[HDQ\\_INT\\_STATUS](#)[2]) generates an interrupt. The software must check whether the interrupt was generated after the address/command byte was sent or after the data byte was sent. The clock must not be shut off after the command/address byte is sent; otherwise, the data is not written to the slave.

2. Read the HDQ.[HDQ\\_INT\\_STATUS](#) to clear the TX-complete interrupt flag.
3. The HDQ\_ICLK can be shut off by entering the system idle mode.

Concerning HDQ\_ICLK, two situations can occur:

- The clock is no longer required and EN\_HDQ bit PRCM.CM\_ICLKEN1\_CORE[22] is set by software. In this case, the clock is cut off, provided no other modules require it. Before setting the EN\_HDQ bit, the software must follow the steps described in this section.
- AUTO\_HDQ bit PRCM.CM\_AUTOIDLE1\_CORE[22] is set. In this case, the software must verify that all HDQ/1-Wire transfers are complete before enabling the L4 interconnect clock domain idle mode. Otherwise, the HDQ/1-Wire has no way to prevent the clock from being cut, because no hardware mechanism exists. The steps listed in this section must be verified before putting the L4 clock domain into idle state.

## 18.6 HDQ/1-Wire Use Cases and Tips

### 18.6.1 How to Configure the HDQ/1-Wire when Connected with a BQ27000 Gauge

#### 18.6.1.1 Environment

Figure 18-10 details the device connections with the BQ27000 gauge.

**Figure 18-10. Environment**



#### 18.6.1.2 Programming Flow

This section details the programming flow of the HDQ/1-Wire. Figure 18-11 shows the main steps of this configuration. The BQ27000 gauge uses the HDQ mode.

**Figure 18-11. HDQ/1-Wire Configuration in HDQ Mode**



#### 18.6.1.3 Pad Configuration and HDQ/1-Wire Clock and Power Management

Table 18-3 shows the pad multiplexing and the clock and power management configuration to select for the HDQ/1-Wire module.

**Table 18-3. Registers Print for HDQ/1-Wire Configuration**

| Register Name                    | Address      | Value       | Value description               |
|----------------------------------|--------------|-------------|---------------------------------|
| SCM.CONTROL_PA<br>DCONF_I2C3_SDA | 0x 4800 21C4 | 0x0118 0100 | Configure hdq_sio pad in mode 0 |

**Table 18-3. Registers Print for HDQ/1-Wire Configuration (continued)**

| Register Name         | Address     | Value       | Value description                                    |
|-----------------------|-------------|-------------|------------------------------------------------------|
| PRCM.CM_FCLKEN_1_CORE | 0x4800 4A00 | 0x0020 0000 | Enable HDQ/1-Wire Functional clock                   |
| PRCM.CM_ICLKEN_1_CORE | 0x4800 4A10 | 0x0020 0000 | Enable HDQ/1-Wire Interface clock                    |
| HDQ_CTRL_STATUS       | 0x480B 200C | 0x0000 0020 | Enable clocks and select the HDQ mode                |
| HDQ_SYSCONFIG         | 0x480B 2014 | 0x0000 0000 | Module clock is free-running (Disable autoidle mode) |

#### 18.6.1.4 HDQ/1-Wire Software Reset

Perform a software reset as described in [Figure 18-12](#).

**Figure 18-12. Software Reset Flowchart**

hdq1wr-013

[Table 18-4](#) describes the registers to be configured for the HDQ/1-Wire software reset step.

**Table 18-4. Registers Print for HDQ/1-Wire Software Reset**

| Register Name | Address     | Value       | Value description                                                                             |
|---------------|-------------|-------------|-----------------------------------------------------------------------------------------------|
| HDQ_SYSCONFIG | 0x480B 2014 | 0x0000 0002 | Initiate a software reset. The HDQ_SYSCONFIG[1] SOFTRESET is automatically reset by hardware. |
| HDQ_SYSSTATUS | 0x480B 2018 | 0x0000 0001 | The HDQ_SYSSTATUS[0] RESETDONE is set to 1 when the reset sequence is done.                   |

#### 18.6.1.5 Interrupts Enable

[Table 18-5](#) describes the registers to be configured for the interrupts enable step and the use case values.

**Table 18-5. Registers Print for HDQ/1-Wire Interrupts Enable**

| Register Name   | Address     | Value       | Value description |
|-----------------|-------------|-------------|-------------------|
| HDQ_CTRL_STATUS | 0x480B 200C | 0x0000 0060 | Enable Interrupts |

### 18.6.1.6 Read and Write Operations

The Read and Write operations in HDQ mode are described in [Section 18.5.2](#).

Some write operations are needed to configure the BQ27000 gauge: for example, it is necessary to write a COMMAND KEY (0xA9 or 0x56) in the Device Control Register of the gauge. For more information, see the TI BQ27000 gauge specification.

## 18.7 HDQ/1-Wire Register Manual

### 18.7.1 HDQ/1-Wire Instance Summary

Table 18-6 lists the HDQ/1-Wire instances.

**Table 18-6. Instance Summary**

| Module Name | Base Address | Size     |
|-------------|--------------|----------|
| HDQ/1-Wire  | 0x480B 2000  | 4K bytes |

**CAUTION**

All reserved bits must be written with 0. There is no synchronization between the register clock domain and the state-machine domain. Therefore, the following rules must be observed when accessing the module registers:

- A read from the interrupt status register or the receive buffer register is not allowed unless the processor has been interrupted by the module.
- After the release of the GO bit in the control and status register, no access to the TX data register or the control and status register is allowed until the processor has been interrupted by the module.
- Polling of the interrupt status register by software to determine whether an interrupt was generated is not allowed.
- No access to the module registers should be done after the software puts the module in power-down mode (by setting bit 5 of the control and status register to 0) except to re-enable the clock.

**CAUTION**

The HDQ/1-Wire registers are limited to 32-bit data accesses. 16-bit and 8-bit are not allowed and can corrupt register content.

### 18.7.2 HDQ/1-Wire Register Mapping Summary

Table 18-7 lists the HDQ/1-Wire registers.

**Table 18-7. HDQ/1-Wire Register Summary**

| Register Name   | Type | Register Width (Bits) | Address Offset | HDQ/1-Wire Physical Address |
|-----------------|------|-----------------------|----------------|-----------------------------|
| HDQ_REVISION    | R    | 32                    | 0x000          | 0x480B2000                  |
| HDQ_TX_DATA     | RW   | 32                    | 0x004          | 0x480B2004                  |
| HDQ_RX_DATA     | R    | 32                    | 0x008          | 0x480B2008                  |
| HDQ_CTRL_STATUS | RW   | 32                    | 0x00C          | 0x480B200C                  |
| HDQ_INT_STATUS  | R    | 32                    | 0x010          | 0x480B2010                  |
| HDQ_SYSCONFIG   | RW   | 32                    | 0x014          | 0x480B2014                  |
| HDQ_SYSSTATUS   | R    | 32                    | 0x018          | 0x480B2018                  |

### 18.7.3 HDQ/1-Wire Register Description

Table 18-8 through Table 18-20 describe the individual bits of the HDQ/1-Wire registers.

**Table 18-8. HDQ\_REVISION**

|                         |                                              |                 |            |  |  |
|-------------------------|----------------------------------------------|-----------------|------------|--|--|
| <b>Address Offset</b>   | 0x000                                        | <b>Instance</b> | HDQ/1-Wire |  |  |
| <b>Physical Address</b> | 0x480B 2000                                  |                 |            |  |  |
| <b>Description</b>      | This register contains the IP revision code. |                 |            |  |  |
| <b>Type</b>             | R                                            |                 |            |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |          |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----------|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | REVISION |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                             | Type | Reset                |
|------|------------|-------------------------------------------------------------------------------------------------------------------------|------|----------------------|
| 31:8 | Reserved   | Reads return 0s.                                                                                                        | R    | 0x000000             |
| 7:0  | REVISION   | IP revision<br>The 4 LSBs indicate a minor revision.<br>The 4 MSBs indicate a major revision.<br>Ex: 0x21: Revision 2.1 | R    | See <sup>(1)</sup> . |

<sup>(1)</sup> TI internal data

**Table 18-9. Register Call Summary for Register HDQ\_REVISION**

- HDQ/1-Wire Register Manual
- [HDQ/1-Wire Register Mapping Summary: \[0\]](#)

**Table 18-10. HDQ\_TX\_DATA**

|                         |                                                    |                 |            |  |  |
|-------------------------|----------------------------------------------------|-----------------|------------|--|--|
| <b>Address Offset</b>   | 0x004                                              | <b>Instance</b> | HDQ/1-Wire |  |  |
| <b>Physical Address</b> | 0x480B 2004                                        |                 |            |  |  |
| <b>Description</b>      | This register contains the data to be transmitted. |                 |            |  |  |
| <b>Type</b>             | RW                                                 |                 |            |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | TX_DATA |   |   |   |   |   |   |

| Bits | Field Name | Description                                       | Type | Reset    |
|------|------------|---------------------------------------------------|------|----------|
| 31:8 | Reserved   | Reads return 0s.                                  | R    | 0x000000 |
| 7:0  | TX_DATA    | Transmit data (used in both HDQ and 1-Wire modes) | RW   | 0x00     |

**Table 18-11. Register Call Summary for Register HDQ\_TX\_DATA**

- HDQ/1-Wire Environment
- [HDQ Protocol Initialization \(Default\): \[0\]](#)

- HDQ/1-Wire Functional Description
- [1-Wire Single-Bit Mode Operation: \[1\]](#)

- HDQ/1-Wire Basic Programming Model

- [Write Operation: \[2\]](#)
- [Read Operation: \[3\]](#)
- [Write Operation: \[4\]](#)
- [Read Operation: \[5\] \[6\]](#)
- [1-Wire Bit Mode Operation: \[7\]](#)

- HDQ/1-Wire Register Manual

- [HDQ/1-Wire Register Mapping Summary: \[8\]](#)

**Table 18-12. HDQ\_RX\_DATA**

|                         |                                                 |                 |            |  |  |
|-------------------------|-------------------------------------------------|-----------------|------------|--|--|
| <b>Address Offset</b>   | 0x008                                           | <b>Instance</b> | HDQ/1-Wire |  |  |
| <b>Physical Address</b> | 0x480B 2008                                     |                 |            |  |  |
| <b>Description</b>      | This register contains the data to be received. |                 |            |  |  |
| <b>Type</b>             | R                                               |                 |            |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RX_DATA |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------|-------------|--------------|
| 31:8        | Reserved          | Reads return 0s.                                 | R           | 0x000000     |
| 7:0         | RX_DATA           | Receive data (used in both HDQ and 1-Wire modes) | R           | 0x00         |

**Table 18-13. Register Call Summary for Register HDQ\_RX\_DATA**

HDQ/1-Wire Functional Description

- [Description: \[0\]](#)
- [1-Wire Single-Bit Mode Operation: \[1\]](#)

HDQ/1-Wire Basic Programming Model

- [Read Operation: \[2\] \[3\]](#)
- [Read Operation: \[4\] \[5\]](#)
- [1-Wire Bit Mode Operation: \[6\]](#)
- [System Idle Mode: \[7\]](#)

HDQ/1-Wire Register Manual

- [HDQ/1-Wire Register Mapping Summary: \[8\]](#)

**Table 18-14. HDQ\_CTRL\_STATUS**

|                         |                                                             |                 |            |  |  |
|-------------------------|-------------------------------------------------------------|-----------------|------------|--|--|
| <b>Address Offset</b>   | 0x00C                                                       | <b>Instance</b> | HDQ/1-Wire |  |  |
| <b>Physical Address</b> | 0x480B 200C                                                 |                 |            |  |  |
| <b>Description</b>      | This register provides status information about the module. |                 |            |  |  |
| <b>Type</b>             | RW                                                          |                 |            |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                   |               |             |    |                |                |     |      |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------------|---------------|-------------|----|----------------|----------------|-----|------|
| 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   |      |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 1_WIRE_SINGLE_BIT | INTERRUPTMASK | CLOCKENABLE | GO | PRESENCEDETECT | INITIALIZATION | DIR | MODE |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>         | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------|-------------|--------------|
| 31:8        | Reserved          | Reads return 0s.           | R           | 0x000000     |
| 7           | 1_WIRE_SINGLE_BIT | Single-bit mode for 1-Wire | RW          | 0            |
|             |                   | 0x0: Disabled              |             |              |
|             |                   | 0x1: Enabled               |             |              |
| 6           | INTERRUPTMASK     | Interrupt masking bit      | RW          | 0            |
|             |                   | 0x0: Disable interrupts    |             |              |
|             |                   | 0x1: Enable interrupts     |             |              |
| 5           | CLOCKENABLE       | Power down mode bit        | RW          | 0            |

## HDQ/1-Wire Register Manual

www.ti.com

| Bits | Field Name     | Description                                                                                            | Type | Reset |
|------|----------------|--------------------------------------------------------------------------------------------------------|------|-------|
|      |                | 0x0: Disable clocks<br>0x1: Enable clocks                                                              |      |       |
| 4    | GO             | Go bit<br>Write 1 to send the appropriate commands.<br>Bit returns to 0 after the command is complete. | RW   | 0     |
| 3    | PRESENCEDETECT | Presence detect received, 1-Wire mode only<br>0x0: Not detected<br>0x1: Detected                       | R    | 0     |
| 2    | INITIALIZATION | Write 1 to send initialization pulse.<br>Bit returns to 0 after pulse is sent.                         | RW   | 0     |
| 1    | DIR            | DIR bit, determines if next command is read or write<br>0x0: Write<br>0x1: Read                        | RW   | 0     |
| 0    | MODE           | Mode selection bit<br>0x0: HDQ mode<br>0x1: 1-Wire mode                                                | RW   | 0     |

**Table 18-15. Register Call Summary for Register HDQ\_CTRL\_STATUS**

## HDQ/1-Wire Environment

- [HDQ Protocol Initialization \(Default\): \[0\]](#)

## HDQ/1-Wire Functional Description

- [HDQ/1-Wire Block Diagram: \[1\]](#)
- [Description: \[2\]](#)
- [Single-Bit Mode: \[3\]](#)
- [Description: \[4\] \[5\]](#)
- [1-Wire Single-Bit Mode Operation: \[6\]](#)
- [Status Flags: \[7\]](#)
- [Power-Down Mode: \[8\]](#)

## HDQ/1-Wire Basic Programming Model

- [Mode Selection: \[9\]](#)
- [Reset/Initialization: \[10\] \[11\] \[12\] \[13\] \[14\]](#)
- [Write Operation: \[15\] \[16\] \[17\]](#)
- [Read Operation: \[18\] \[19\] \[20\] \[21\] \[22\] \[23\] \[24\]](#)
- [Write Operation: \[25\] \[26\]](#)
- [Read Operation: \[27\] \[28\] \[29\] \[30\] \[31\] \[32\] \[33\]](#)
- [1-Wire Bit Mode Operation: \[34\]](#)
- [Module Power-Down Mode: \[35\]](#)

## HDQ/1-Wire Use Cases and Tips

- [Pad Configuration and HDQ/1-Wire clock and power management: \[36\]](#)
- [Interrupts Enable: \[37\]](#)

## HDQ/1-Wire Register Manual

- [HDQ/1-Wire Register Mapping Summary: \[38\]](#)

**Table 18-16. HDQ\_INT\_STATUS**

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:3        | Reserved          | Reads return 0s.                                                                                                                                                                     | R           | 0x00000000   |
| 2           | TXCOMPLETE        | TX-complete interrupt flag<br>Set to 1 if cause of interrupt.<br>Set to 0 when register read.                                                                                        | R           | 0            |
| 1           | RXCOMPLETE        | Read-complete interrupt flag<br>Set to 1 if cause of interrupt.<br>Set to 0 when register read.                                                                                      | R           | 0            |
| 0           | TIMEOUT           | Presence detect/timeout interrupt flag<br>In 1-Wire mode, set to 1 if slave's presence detected.<br>In HDQ mode, set to 1 if timeout on read occurs.<br>Set to 0 when register read. | R           | 0            |

**Table 18-17. Register Call Summary for Register HDQ\_INT\_STATUS**

- Description: [0] [1] [2]
  - Interrupt Conditions: [3] [4] [5]
  - Description: [6] [7]
  - Interrupt Conditions: [8] [9] [10]
  - Status Flags: [11]

- **Reset/Initialization:** [12]
  - **Write Operation:** [13]
  - **Read Operation:** [14] [15]
  - **Write Operation:** [16] [17]
  - **Read Operation:** [18] [19]
  - **1-Wire Bit Mode Operation:** [20] [21]
  - **Module Power-Down Mode:** [22] [23]
  - **System Idle Mode:** [25] [26] [27] [28]

- HDQ/1-Wire Register Manual

**Table 18-18. HDQ\_SYSCONFIG**

|                         |                                      |                         |                 |                 |            |
|-------------------------|--------------------------------------|-------------------------|-----------------|-----------------|------------|
| <b>Address Offset</b>   | 0x014                                | <b>Physical Address</b> | 0x480B 2014     | <b>Instance</b> | HDQ/1-Wire |
| <b>Description</b>      | This register controls various bits. |                         |                 |                 |            |
| <b>Type</b>             | RW                                   |                         |                 |                 |            |
| 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 |                 |            |
| Reserved                |                                      |                         |                 | SOFTRESET       | AUTOIDLE   |

| Bits | Field Name | Description                                                                                                                                                                                         | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:2 | Reserved   | Reads return 0s.                                                                                                                                                                                    | R    | 0x00000000 |
| 1    | SOFTRESET  | Start soft reset sequence.<br><br>0x0: Disabled<br>0x1: Enabled                                                                                                                                     | RW   | 0          |
| 0    | AUTOIDLE   | Interconnect idle<br><br>0x0: Module clock is free-running.<br>0x1: Module is in power saving mode: Clock is running only when module is accessed or inside logic is in function to process events. | RW   | 0          |

**Table 18-19. Register Call Summary for Register HDQ\_SYSCONFIG**

- HDQ/1-Wire Integration
  - [HDQ/1-Wire Reset Scheme: \[0\]](#)
- HDQ/1-Wire Functional Description
  - [Autoidle Mode: \[1\]](#)
- HDQ/1-Wire Basic Programming Model
  - [Power Management: \[2\]](#)
- HDQ/1-Wire Use Cases and Tips
  - [Pad Configuration and HDQ/1-Wire clock and power management: \[3\]](#)
  - [HDQ/1-Wire Software Reset: \[4\] \[5\]](#)
- HDQ/1-Wire Register Manual
  - [HDQ/1-Wire Register Mapping Summary: \[6\]](#)

**Table 18-20. HDQ\_SYSSTATUS**

|                         |                                            |                         |                 |                 |            |
|-------------------------|--------------------------------------------|-------------------------|-----------------|-----------------|------------|
| <b>Address Offset</b>   | 0x018                                      | <b>Physical Address</b> | 0x480B 2018     | <b>Instance</b> | HDQ/1-Wire |
| <b>Description</b>      | This register monitors the reset sequence. |                         |                 |                 |            |
| <b>Type</b>             | R                                          |                         |                 |                 |            |
| 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 |                 |            |
| Reserved                |                                            |                         |                 | RESETDONE       |            |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:1        | Reserved          | Reads return 0s.                                                                                                                                                                                 | R           | 0x00000000   |
| 0           | RESETDONE         | Reset monitoring<br><br>0x0: The module is currently performing its reset. When the module is in power-down mode, set to 0 to indicate this fact.<br><br>0x1: The module has finished its reset. | R           | 0x-          |

**Table 18-21. Register Call Summary for Register HDQ\_SYSSTATUS**

HDQ/1-Wire Use Cases and Tips

- [HDQ/1-Wire Software Reset: \[0\] \[1\]](#)

HDQ/1-Wire Register Manual

- [HDQ/1-Wire Register Mapping Summary: \[2\]](#)



This chapter describes the function, operation, and configuration of the universal asynchronous receiver/transmitter (UART)/infrared data association (IrDA)/consumer infrared (CIR) module.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                                   | Page        |
|---------------------------------------------------------|-------------|
| <b>19.1 UART/IrDA/CIR Overview .....</b>                | <b>2892</b> |
| <b>19.2 UART/IrDA/CIR Environment .....</b>             | <b>2895</b> |
| <b>19.3 UART/IrDA/CIR Integration .....</b>             | <b>2908</b> |
| <b>19.4 UART/IrDA/CIR Functional Description .....</b>  | <b>2912</b> |
| <b>19.5 UART/IrDA/CIR Basic Programming Model .....</b> | <b>2942</b> |
| <b>19.6 UART/IrDA/CIR Register Manual .....</b>         | <b>2950</b> |

## 19.1 UART/IrDA/CIR Overview

The device contains three universal asynchronous receiver/transmitter (UART) devices controlled by the microprocessor unit (MPU) (see Figure 19-1):

- Three UART-only modules, UART1, UART2 and UART4 are pinned out for use as UART devices only. UART1 and UART2 must be programmed by setting the `UARTi.MDR1_REG[2:0]` MODE\_SELECT field to one of the three UART operating modes.
- UART3, which adds infrared communication support, is pinned out for use as a UART, infrared data association (IrDA), or consumer infrared (CIR) device, and can be programmed to any available operating mode.

**Figure 19-1. UART Module**



### 19.1.1 UART Features

The UARTs (UART1, UART2, UART3, UART4 when in UART mode) include the following key features:

- 16C750 compatibility
- 64-byte FIFO for receiver and 64-byte FIFO for transmitter
- Programmable interrupt trigger levels for FIFOs
- Baud generation based on programmable divisors N ( $N = 1 \dots 16,384$ ) operating from a fixed functional clock of 48 MHz

Oversampling is programmed by software as 16 or 13; thus, the baud rate computation is either:

- Baud rate = (functional clock/16)/N
- Baud rate = (functional clock/13)/N

This software programming mode enables higher baud rates with the same error amount without changing the clock source:

- Break character detection and generation
- Configurable data format
  - Data bit: 5, 6, 7, or 8 bits
  - Parity bit: Even, odd, none
  - Stop-bit: 1, 1.5, 2 bit(s)
- Flow control: Hardware (RTS/CTS) or software (XON/XOFF) (UART1, UART2 and UART3 only)

The UART clocks are connected to produce a baud rate of up to 3.6M bits/s. [Table 19-1](#) lists the supported baud rates, the requested divisor, and the corresponding error versus the standard baud rate.

**Table 19-1. UART Mode Baud Rates, Divisor Values, and Error Rates**

| Baud Rate | Oversampling | Divisor | Error (%) |
|-----------|--------------|---------|-----------|
| 300       | 16           | 10000   | 0         |
| 600       | 16           | 5000    | 0         |
| 1200      | 16           | 2500    | 0         |
| 2400      | 16           | 1250    | 0         |
| 4800      | 16           | 625     | 0         |
| 9600      | 16           | 312     | 0.16      |
| 14,400    | 16           | 208     | 0.16      |
| 19,200    | 16           | 156     | 0.16      |
| 28,800    | 16           | 704     | 0.16      |
| 38,400    | 16           | 78      | 0.16      |
| 57,600    | 16           | 52      | 0.16      |
| 115,200   | 16           | 26      | 0.16      |
| 230,400   | 16           | 13      | 0.16      |
| 460,800   | 13           | 8       | 0.16      |
| 921,600   | 13           | 4       | 0.16      |
| 1,843,200 | 13           | 2       | 0.16      |
| 3,000,000 | 16           | 1       | 0         |
| 3,686,400 | 13           | 1       | 0.16      |

### 19.1.2 IrDA Features

The IrDA (UART3 only) includes the following key features:

- Support of IrDA 1.4 slow infrared (SIR), medium infrared (MIR), and fast infrared (FIR) communications
  - Frame formatting: Addition of variable beginning-of-frame (xBOF) characters and end-of-frame (EOF) characters
  - Uplink/downlink cyclic redundancy check (CRC) generation/detection
  - Asynchronous transparency (automatic insertion of break character)
  - Eight-entry status FIFO (with selectable trigger levels) to monitor frame length and frame errors
  - Framing error, CRC error, illegal symbol (FIR), and abort pattern (SIR, MIR) detection

[Table 19-2](#) lists the supported baud rates, the requested divisor, and the corresponding error versus the standard baud rate.

**Table 19-2. UART IrDA Mode Baud Rates, Divisor Values, and Error Rates**

| Baud Rate | IR Mode | Encoding             | Divisor | Error (%) |
|-----------|---------|----------------------|---------|-----------|
| 2400      | SIR     | 3/16                 | 1250    | 0         |
| 9600      | SIR     | 3/16                 | 312     | 0.16      |
| 19,200    | SIR     | 3/16                 | 156     | 0.16      |
| 38,400    | SIR     | 3/16                 | 78      | 0.16      |
| 57,600    | SIR     | 3/16                 | 52      | 0.16      |
| 115,200   | SIR     | 3/16                 | 26      | 0.16      |
| 576,000   | MIR     | 1/4                  | 2       | 0         |
| 1,152,000 | MIR     | 1/4                  | 1       | 0         |
| 4,000,000 | FIR     | 4 PPM <sup>(1)</sup> | 1       | 0         |

<sup>(1)</sup> PPM = pulse-position-modulation

---

**NOTE:** The maximum baud rate required of the module does not depend on the change of OPP.

---

### 19.1.3 CIR Features

The CIR mode uses a variable pulse-width modulation (PWM) technique (based on multiples of a programmable  $t$  period) to encompass the various formats of infrared encoding for remote-control applications. The CIR logic transmits data packets based on a user-definable frame structure and packet content.

The CIR (UART3 only) includes the following key features to provide CIR support for remote control applications:

- Transmit mode only (receive mode is not supported)
- Free data format (supports any remote-control private standards)
- Selectable bit rate
- Configurable carrier frequency
- 1/2, 5/12, 1/3, or 1/4 carrier duty cycle

## 19.2 UART/IrDA/CIR Environment

This section describes the UART/IrDA/CIR connection with an external device.

### 19.2.1 System Using UART Communication with Hardware Handshake

UART1, UART2, UART3 or UART4 can be connected easily to the UART port of an external IC (see Figure 19-2).

**Figure 19-2. UART Mode Bus System Overview**



**NOTE:** UART4 does not provide flow control, so it does not have uarti\_rts and uarti\_cts signals

### 19.2.2 System Using IrDA Communication Protocol

As Figure 19-3 shows, UART3 can be connected to an external infrared transceiver in the IrDA modes (FIR, SIR, and MIR).

**Figure 19-3. IrDA System Overview**



### 19.2.3 System Using CIR Communication Protocol with Remote Control

UART3 can be connected to an external Infrared transceiver in CIR mode (see Figure 19-4).

**Figure 19-4. CIR System Overview**

108-004

## 19.2.4 UART Interface Description

### 19.2.4.1 UART Interface Description

Table 19-3 describes the UART interface.

**Table 19-3. UART I/O Pin Description**

| Signal                    | I/O <sup>(1)</sup> | Description                                                                                                                                                                                                                                                                                                                                                                                                                            | Reset   |
|---------------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| <b>UART Modem Signals</b> |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |
| uarti_rx                  | I                  | Serial data input                                                                                                                                                                                                                                                                                                                                                                                                                      | Unknown |
| uarti_tx                  | O                  | Serial data output                                                                                                                                                                                                                                                                                                                                                                                                                     | 1       |
| uarti_cts                 | I                  | Clear to send (UART1, UART2 and UART3 only)                                                                                                                                                                                                                                                                                                                                                                                            | Unknown |
|                           |                    | Active-low modem status signal. Reading the <code>UARTi.MSR_REG[4]</code> NCTS_STS bit checks the condition of <code>uarti_cts</code> . Reading the <code>UARTi.MSR_REG[0]</code> CTS_STS bit checks a change of state of <code>uarti_cts</code> since the last read of the modem status register. The auto-nCTS mode uses <code>uarti_cts</code> to control the transmitter.                                                          |         |
| uarti_rts                 | O                  | Request to send (UART1, UART2 and UART3 only)<br><br>When active (low), the module is ready to receive data. Setting the <code>UARTi.MCR_REG[1]</code> RTS bit activates <code>uarti_rts</code> , which becomes inactive as the result of a module reset, loopback mode, or clearing the <code>UARTi.MCR_REG[1]</code> RTS bit. In auto-RTS mode, <code>uarti_rts</code> becomes inactive as a result of the receiver threshold logic. | 1       |

<sup>(1)</sup> I = Input, O = Output

### 19.2.4.2 UART Protocol and Data Format

The UART device operates in three modes:

- UART 16x mode ( $\leq 230.4\text{K}$  bits/s)
- UART 16x mode with autobauding ( $\leq 1200$  bits/s and  $\leq 115.2\text{K}$  bits/s)
- UART 13x mode ( $\geq 460.8\text{K}$  bits/s)

#### CAUTION

To be used as a UART, the operating mode must be programmed appropriately in the `UARTi.MDR1_REG[2:0]` MODE\_SELECT field to select the UART, IrDA, or CIR mode.

The UART uses a wired interface for serial communication with a remote device.

The UART module is functionally compatible with the TL16C750 UART and earlier designs such as the TL16C550.

Figure 19-5 shows the UART frame data format.

**Figure 19-5. UART Frame Data Format**



uart-005

## 19.2.5 IrDA Functional Interfaces

### 19.2.5.1 UART3 Interface Description

Table 19-4 describes the UART3 interface.

**Table 19-4. UART3 I/O Description**

| Signal              | I/O <sup>(1)</sup> | Description                                                                                                                | Reset            |
|---------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|------------------|
| <b>IrDA Signals</b> |                    |                                                                                                                            |                  |
| uart3_rx_irrx       | I                  | Serial data input                                                                                                          | Unknown          |
| uart3_tx_irtx       | O                  | Serial data output in IrDA modes (SIR, MIR, and FIR). In other modes, this pin is set to the reset value (inactive state). | 0 <sup>(2)</sup> |
| uart3_rts_sd        | O                  | SD mode is used to configure the transceivers.<br>The SD pinout is an inverted value of the UART3.ACREG_REG[6] SD_MOD bit. | 1                |

<sup>(1)</sup> I = Input, O = Output

<sup>(2)</sup> This value is only for IrDA mode. It is not for UART and CIR modes.

### 19.2.5.2 IrDA Protocol and Data Format

#### 19.2.5.2.1 SIR Mode

In SIR mode, data is transferred between the MPU and peripheral devices at speeds of up to 115,200 baud. A SIR transmit frame begins with start flags (a single 0xC0, a multiple 0xC0, or a single 0xC0 preceded by a number of 0xFF flags), is followed by frame data and a CRC-16, and ends with a stop flag (0xC1).

The bit format for a single word uses 1 start bit, 8 data bits, and 1 stop bit, and is unaffected by the use and settings of the UART3.LCR\_REG register.

The UART3.BLR\_REG[6] XBOF\_TYPE bit selects whether the 0xC0 or 0xFF start patterns are used when multiple start flags are required.

The SIR transmit state-machine attaches start flags, CRC-16, and stop flags, and checks the outgoing data to establish whether data transparency is required.

SIR transparency is carried out if the outgoing data between the start and stop flags contains 0xC0, 0xC1, or 0x7D. If one of these start flags is about to be transmitted, the SIR state-machine first sends an escape character (0x7D), then inverts the fifth bit of the real data to be sent, and sends this data immediately after the 0x7D character.

The SIR receive state-machine recovers the receive clock, removes the start flags and any transparency from the incoming data, and determines the frame boundary with reception of the stop flag. The SIR state-machine also checks for errors, such as a frame abort (0x7D character followed immediately by a 0xC1 stop flag without transparency), a CRC error, and a frame-length error. At the end of a frame reception, the MPU reads the line status register (UART3.LSR\_REG) to find possible errors of the received frame.

---

**NOTE:** Data can be transferred both ways by the module, but when the device is transmitting, the IR RX circuitry is automatically disabled by hardware. See the UART3.ACREG\_REG[5] DIS\_IR\_RX bit description. This applies to all three modes: SIR, MIR, and FIR.

---

Infrared output in SIR mode can be either 1.6- $\mu$ s or 3/16th encoding, selected by the UART3.ACREG\_REG[7] PULSE\_TYPE bit. In 1.6- $\mu$ s encoding, the infrared pulse width is 1.6  $\mu$ s; and in 3/16th encoding, the infrared pulse width is 3/16th of a bit duration (1/baud rate).

The transmitting device must send at least two start flags at the start of each frame for back-to-back frames.

---

**NOTE:** Reception supports variable-length stop-bits.

---

#### 19.2.5.2.1.1 Frame Format

Figure 19-6 shows the IrDA SIR frame format.

**Figure 19-6. IrDA SIR Frame Format**



The CRC is applied on the address (A), control (C), and information (I) bytes.

---

**NOTE:** The two words of CRC are written to the FIFO in reception.

---

#### 19.2.5.2.1.2 Asynchronous Transparency

Before transmitting a byte, the UART IrDA controller examines each byte of the payload and the CRC field (between BOF and EOF). For each byte equal to 0xC0 (BOF), 0xC1 (EOF), or 0x7D (control escape), the controller performs certain tasks:

- In transmission:
  - Inserts a control escape (CE) byte preceding the byte
  - Complements bit 5 of the byte (that is, exclusive ORs the byte with 0x20)

The byte sent for the CRC computation is the initial byte written in the TX FIFO (before the XOR with 0x20).
- In reception:
  - For the A, C, I, CRC field:

- Compares the byte with the CE byte; if they are not equal, sends the byte to the CRC detector and stores it in the RX FIFO
- If the byte is equal to the CE byte, discards the CE byte
- Complements bit 5 of the byte following the CE
- Sends the complemented byte to the CRC detector and stores it in the RX FIFO

#### 19.2.5.2.1.3 Abort Sequence

The transmitter can decide to prematurely close a frame. The transmitter aborts by sending the following sequence: 0x7DC1. The abort pattern closes the frame without a CRC field or an ending flag.

The receiver treats a frame as an aborted frame when a 0x7D character followed immediately by a 0xC1 character is received without transparency.

#### 19.2.5.2.1.4 Pulse Shaping

The SIR mode supports both the 3/16th and the 1.6- $\mu$ s pulse duration methods in receive and transmit. The UART3.ACREG\_REG[7] PULSE\_TYPE bit selects the pulse width method in transmit mode.

#### 19.2.5.2.1.5 Encoder

Serial data from the transmit state-machine is encoded to transmit data to the optoelectronics. While the TX FIFO output is high, the uart3\_tx\_irtx line is always low, and the counter used to form a pulse on uart3\_tx\_irtx is cleared continuously.

After the TX FIFO output resets to 0, uart3\_tx\_irtx rises on the falling edge of the 7th 16XCLK. On the falling edge of the 10th 16XCLK pulse, uart3\_tx\_irtx falls, creating a three-clock-wide pulse. While the TX FIFO output stays low, a pulse is transmitted during the 7th to the 10th clock of each 16-clock bit cycle.

Figure 19-7 shows the IrDA SIR encoding mechanism.

Figure 19-7. IrDA SIR Encoding Mechanism



uart-007

#### 19.2.5.2.1.6 Decoder

After reset, the RX FIFO input is high and the 4-bit counter is cleared. When a rising edge is detected on RX, the RX FIFO input falls on the next rising edge of 16XCLK with sufficient setup time. The RX FIFO input stays low for 16 cycles (16XCLK) and then returns to high as required by the IrDA specification. As long as no pulses (rising edges) are detected on the RX, the RX FIFO input remains high.

Figure 19-8 shows the IrDA SIR decoding mechanism.

**Figure 19-8. IrDA SIR Decoding Mechanism**

Data can be transferred both ways by the module, but when the device is transmitting, the IR RX circuitry is automatically disabled by hardware. The operation of the uart3\_rx\_irrx input can be disabled using the **UART3.ACREG\_REG[5]** DIS\_IR\_RX bit. Furthermore, the **UART3.MDR2\_REG[6]** IRRXINVERT bit can invert the signal from the transceiver (RXD) pin to the IRRX logic inside the UART. This inversion is performed by default.

#### 19.2.5.2.1.7 IR Address Checking

In all IR modes, when address checking is enabled by setting **EFR\_REG[1:0]** (see [Table 19-5](#)), only frames intended for the device are written to the RX FIFO. This is to avoid receiving frames not meant for this device in a multipoint infrared environment. To program two frame addresses that the UART3 receives in IrDA mode, use the **UART3.XON1\_ADDR1\_REG[7:0]** field and the **UART3.XON2\_ADDR2\_REG[7:0]** field.

**Table 19-5. EFR\_REG[0-1] IR Address Checking Options**

| <b>EFR_REG[1]</b> | <b>EFR_REG[0]</b> | <b>IR Address Checking</b>               |
|-------------------|-------------------|------------------------------------------|
| 0                 | 0                 | All address-checking operations disabled |
| 0                 | 1                 | Only address 1 checking enabled          |
| 1                 | 0                 | Only address 2 checking enabled          |
| 1                 | 1                 | All address-checking operations enabled  |

#### 19.2.5.2.2 SIR Free Format Mode

To allow complete software flexibility when transmitting and receiving infrared data packets, the SIR free format (FF) mode is a subfunction of the existing SIR mode; all frames going to and from the FIFO buffers are untouched with respect to appending and removing control characters and CRC values.

This mode corresponds to a UART mode with a pulse modulation of 3/16 of baud rate pulse width.

For example, a normal SIR packet has BOF control and CRC error-checking data appended (transmitting) or removed (receiving) from the data going to and from the FIFOs.

[Figure 19-9](#) shows the SIR free format mode.

**Figure 19-9. SIR Free Format Mode**


In the SIR free format mode, the MPU software must construct (that is, encode and decode) the entire FIFO data packet.

#### 19.2.5.2.3 MIR Mode

In MIR mode, data is transferred between the MPU and the peripheral devices at 0.576 or 1.152M bits/s speed. A MIR transmit frame starts with start flags (at least two), followed by a frame data, CRC-16, and ends with a stop flag (see [Figure 19-10](#)).

**Figure 19-10. MIR Transmit Frame Format**


On transmit, the MIR state-machine attaches start flags, CRC-16, and stop flags, as in SIR mode. All fields are transmitted least-significant bit (LSB) of each byte first.

Contrary to SIR mode:

- The state-machine looks for consecutive 1s in the frame data and automatically inserts 0 after five consecutive 1s (this is called bit-stuffing).
- 0x7E is used for both start and stop flags (unambiguously, not data, because of bit-stuffing).
- Abort sequence requires a minimum of seven consecutive 1s (unambiguously, not data, because of bit stuffing).
- Back-to-back frames are allowed with three or more stop flags in between. If two consecutive frames are not back to back, the gap between the last stop flag of the first frame and the start flag of the second frame must be separated by at least seven bit durations.

On receive, the MIR receive state-machine recovers the receive clock, removes the start flags, destuffs the incoming data, and determines the frame boundary with reception of the stop flag. The state-machine also checks for errors, such as frame abort, CRC error, and frame-length error. At the end of a frame reception, the MPU reads the line status register (UART3.[LSR\\_REG](#)) to detect possible errors of the received frame.

Data can be transferred both ways by the module, but when the device is transmitting, the IR RX circuitry is automatically disabled by hardware.

### 19.2.5.2.3.1 MIR Encoder/Decoder

To meet the MIR baud rate tolerance of +/-0.1 percent with a 48-MHz clock input, a 42-41-42 encoding/decoding adjustment is performed. The reference start point is the first start flag, and the 42-41-42 cyclic pattern is repeated until the stop flag is sent or detected.

The jitter created this way is within MIR tolerances. The pulse width is not exactly 1/4, but it is within the tolerances defined by the IrDA specifications.

Figure 19-11 shows the MIR baud rate adjustment mechanism.

**Figure 19-11. MIR Baud Rate Adjustment Mechanism**



### 19.2.5.2.3.2 SIP Generation

In the MIR and FIR operation modes, the transmitter must send a serial infrared interaction pulse (SIP) at least once every 500 ms. The SIP informs slow devices (operating in SIR mode) that the medium is currently occupied.

Figure 19-12 shows the SIP.

**Figure 19-12. SIP**



### 19.2.5.2.4 FIR Mode

In FIR mode, data is transferred between the MPU and the peripheral devices at 4M bits/s. A FIR transmit frame starts with a preamble that is followed by a start flag, frame data, CRC-32, and ends with a stop flag.

Table 19-6 shows the FIR transmit frame format.

**Table 19-6. FIR Transmit Frame Format**

|                   |            |            |        |           |
|-------------------|------------|------------|--------|-----------|
| Preamble<br>(16x) | Start flag | Frame data | CRC-32 | Stop flag |
|-------------------|------------|------------|--------|-----------|

On transmit, the FIR transmit state-machine attaches the preamble, start flag, CRC-32, and stop flag. An abort sequence requires at least two transmissions of 0000. Back-to-back frames are allowed, but each frame must be complete.

The state-machine also encodes the transmit data into 4-PPM format (see [Table 19-7](#)) and generates the SIP (see [Section 19.2.5.2.3.2, SIP Generation](#)).

**Table 19-7. 4-PPM Format**

| Data Bit Pair (Bin) | 4-PPM Data Symbol (Bin) |
|---------------------|-------------------------|
| 00                  | 1000                    |
| 01                  | 0100                    |
| 10                  | 0010                    |
| 11                  | 0001                    |

The four symbols described in [Table 19-7](#) are the legal encoded data symbols. All other combinations are illegal for encoding data. Some of these illegal symbols are used in the definition of the preamble, start flag, and stop flag because they are unambiguously not data (see [Table 19-8](#)).

**Table 19-8. FIR Preamble, Start Flag, and Stop Flag**

| Frame Part | Transmitted Frame (Bin)                         |
|------------|-------------------------------------------------|
| Preamble   | 1000 0000 1010 1000 (16 repeated transmissions) |
| Start Flag | 0000 1100 0000 1100 0110 0000 0110 0000         |
| Stop Flag  | 0000 1100 0000 1100 0000 0110 0000 0110         |

All fields are transmitted the LSBs of each byte first (see [Table 19-9](#)).

**Table 19-9. FIR Data Byte Transmission Order Example**

| Data Byte (Hex) | Data Byte Pair (Bin) | 4-PPM Data Symbol (Bin) | Transmission Order |
|-----------------|----------------------|-------------------------|--------------------|
| 0xB             | 00                   | 1000                    | 4                  |
|                 | 00                   | 1000                    | 3                  |
|                 | 10                   | 0010                    | 2                  |
|                 | 11                   | 0001                    | 1                  |

On receive, the FIR receive state-machine recovers the receive clock, removes the preamble and the start flag, decodes the 4-PPM incoming data, and determines the frame boundary with reception of the stop flag. The state-machine also checks for errors, such as illegal symbol, CRC error, and frame-length error. At the end of a frame reception, the MPU reads the line status register (UART3.[LSR\\_REG](#)) to detect possible errors of the received frame.

Data can be transferred both ways by the module, but when the device is transmitting, the IR RX circuitry is automatically disabled by hardware.

## 19.2.6 CIR Functional Interfaces

### 19.2.6.1 CIR Interface Description

Table 19-10 describes the CIR interface.

**Table 19-10. CIR I/O Description**

| Signal             | I/O <sup>(1)</sup> | Description                                                                                                                | Reset   |
|--------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|---------|
| <b>CIR Signals</b> |                    |                                                                                                                            |         |
| uart3_rx_irrx      | I                  | Serial data input                                                                                                          | Unknown |
| uart3_cts_rctx     | O                  | Serial data output in CIR mode. In other modes, this pin is set to the reset value (inactive state).                       | 0       |
| uart3_rts_sd       | O                  | SD mode is used to configure the transceivers.<br>The SD pinout is an inverted value of the UART3.ACREG_REG[6] SD_MOD bit. | 1       |

<sup>(1)</sup> I = Input, O = Output

### 19.2.6.2 CIR Protocol and Data Format

In the CIR mode, the infrared operation functions as a programmable (universal) remote control.

The CIR mode uses a variable PWM technique (based on multiples of a programmable  $t$  period) to encompass the various formats of infrared encoding for remote control applications. The CIR logic transmits data packets based on the user-defined frame structure and packet content.

#### 19.2.6.2.1 Carrier Modulation

Each modulated pulse that constitutes a digit is a train of on/off pulses (see Figure 19-13).

**Figure 19-13. CIR Pulse Modulation**



uart-014

### 19.2.6.2.2 Pulse Duty Cycle

The programmer can choose between four possible duty cycles for modulation pulses by setting the appropriate value in the UART3.MDR2\_REG[5:4] CIR\_PULSE\_MODE field (1/4, 1/3, 5/12, or 1/2).

Figure 19-14 shows the CIR modulation duty cycles.

**Figure 19-14. CIR Modulation Duty Cycle**



The transmission logic ensures that all pulses are transmitted completely (that is, no cutoff during transmission). Furthermore, while transmitting continuous bytes back-to-back, no delay is inserted between 2 transmitted bytes. Thus, software must handle the delay between consecutively transmitted bytes if the receiving end needs it.

### 19.2.6.2.3 Consumer IR Encoding/Decoding

There are two methods of encoding for remote control applications. The first method uses time-extended bit forms (a variable pulse distance, or duration, in which the difference between a logic 1 and logic 0 is the length of the pulse width).

The second encoding method uses a biphase in which the encoding of the logic 0 and logic 1 is in the change of signal level from 1 to 0 or 0 to 1, respectively. Japanese manufacturers favor pulse duration encoding; European manufacturers favor biphase encoding.

The CIR mode uses a completely flexible free-format encoding in which the TX FIFO is transmitted as a modulated pulse with duration T.

Similarly, 0 is transmitted as a blank duration T. The MPU constructs and deciphers the protocol of the data. For example, the RC-5 protocol using Manchester encoding can be emulated as using a 01 pair for 1 and a 10 pair for 0 (see Figure 19-15.).

**Figure 19-15. RC-5 Bit Encoding**

Because the CIR mode logic does not impose a fixed format for infrared packets of data, the MPU software can define the format using simple data structures that are then modulated into an industry standard, such as RC-5 or SIRC. To send a sequence of 0101 in RC-5, the MPU software must write an 8-bit binary character of 10011001 to the data FIFO of the UART.

For SIRC, the modulation length (that is, multiples of T) is the method used to distinguish between 1 and 0. The following SIRC digits show the difference in encoding between this and, for example, RC-5. The pulse width is extended for one digit.

[Figure 19-16](#) shows SIRC bit encoding.

**Figure 19-16. SIRC Bit Encoding**

To construct comprehensive packets constituting remote-control commands, the MPU software must combine a number of 8-bit data characters in a sequence that follows one of the universally accepted formats.

[Figure 19-17](#) shows a standard RC-5 frame as detected by the UART3 in CIR mode (the SIRC format follows this). Each field in RC-5 can be considered as two T pulses (digital bits) from the TX and RX FIFOs.

**Figure 19-17. RC-5 Standard Packet Format**

|    |    |   |    |    |    |    |    |    |    |    |    |    |    |
|----|----|---|----|----|----|----|----|----|----|----|----|----|----|
| S1 | S2 | T | A4 | A3 | A2 | A1 | A0 | C5 | C4 | C3 | C2 | C1 | C0 |
|----|----|---|----|----|----|----|----|----|----|----|----|----|----|

uart-018

Where:

- S1, S2: Start bits (always 1)
- T: Toggle bit
- A4..A0: Address (or system) bits
- C5..C0: Command bits

The toggle bit T changes when a new command is transmitted to detect when the same key is pressed twice (effectively receiving the same data from the host consecutively). A brief delay in the transmission of the same command is detected by the use of the toggle bit because a code is sent while the MPU transmits characters to the UART for transmission. The address bits define the machine or device for which the infrared transmission is intended, and the command defines the operation.

To accommodate an extended RC-5 format, the S2 bit is replaced by an additional command bit (C6) that allows the command range to increase to 7 bits. This format is known as the extended RC-5 format.

SIRC encoding uses the duration of modulation for mark and space; therefore, the duration of data bits inside the standard frame length varies.

[Figure 19-18](#) shows the packet format and bit encoding. As [Figure 19-19](#) shows, 1 start bit of 2 ms and control codes are followed by data that constitute the entire frame.

**Figure 19-18. SIRC Packet Format**

|   |    |    |    |    |    |    |    |    |    |    |    |    |
|---|----|----|----|----|----|----|----|----|----|----|----|----|
| S | C0 | C1 | C2 | C3 | C4 | C5 | C6 | D0 | D1 | D2 | D3 | D4 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|

uart-019

**NOTE:** The encoding must take a standard duration, but the contents of the data can vary. This implies that the control software for emitting and receiving data packets must exercise a scheme of interpacket delay, where the emission of successive packets can be done only after a real-time delay has expired.

**Figure 19-19. SIRC Bit Transmission Example**

uart-020

This document does not describe all encoding methods and techniques; the preceding information shows the considerations required to employ different encoding methods for different industry-standard protocols. See industry-standard documentation for specific methods of encoding and protocol usage.

## 19.3 UART/IrDA/CIR Integration

Figure 19-20 shows the device internal connections with related modules for UART functions.

**Figure 19-20. UART Functional Integration**



uart-021

### 19.3.1 Clocking, Reset, and Power-Management Scheme

#### 19.3.1.1 Clocking

Each UART uses a 48-MHz functional clock for its logic and the generation of external interface signals. Each UART uses an interface clock for register accesses. The power, reset, and clock management (PRCM) module generates and controls all these clocks (for more information, see [Chapter 3, Power, Reset, and Clock Management](#)).

[Table 19-11](#) describes the UART clocks.

**Table 19-11. UART Clocks**

| Clock Type       | Frequency     | Name       | Comments                                                                                                                                                                                                                 |
|------------------|---------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>UART1</b>     |               |            |                                                                                                                                                                                                                          |
| Functional clock | CORE_48M_FCLK | UART1_FCLK | Source and gating is the PRCM module.<br>Enable/disable this clock with the<br>PRCM.CM_FCLKEN1_CORE[13] EN_UART1 bit.                                                                                                    |
| Interface clock  | CORE_L4_ICLK  | UART1_ICLK | Source and gating is the PRCM module.<br>Enable/disable this clock with the<br>PRCM.CM_ICLKEN1_CORE[13] EN_UART1 bit.<br>Enable/disable auto-idle for this clock with the<br>PRCM.CM_AUTOIDLE1_CORE[13] AUTO_UART1 bit.  |
| <b>UART2</b>     |               |            |                                                                                                                                                                                                                          |
| Functional clock | CORE_48M_FCLK | UART2_FCLK | Source and gating is the PRCM module.<br>Enable/disable this clock with the<br>PRCM.CM_FCLKEN1_CORE[14] EN_UART2 bit.                                                                                                    |
| Interface clock  | CORE_L4_ICLK  | UART2_ICLK | Source and gating is the PRCM module.<br>Enable/disable this clock with the PRCM.<br>CM_ICLKEN1_CORE[14] EN_UART2 bit.<br>Enable/disable auto-idle for this clock with the<br>PRCM.CM_AUTOIDLE1_CORE[14] AUTO_UART2 bit. |
| <b>UART3</b>     |               |            |                                                                                                                                                                                                                          |
| Functional clock | PER_48M_FCLK  | UART3_FCLK | Source and gating is the PRCM module.<br>Enable/disable this clock with the<br>PRCM.CM_FCLKEN_PER[11] EN_UART3 bit.                                                                                                      |
| Interface clock  | PER_L4_ICLK   | UART3_ICLK | Source and gating is the PRCM module.<br>Enable/disable this clock with the PRCM.<br>CM_ICLKEN_PER[11] EN_UART3 bit. Enable/disable<br>auto-idle for this clock with the PRCM.CM_AUTOIDLE_<br>PER[11] AUTO_UART3 bit.    |
| <b>UART4</b>     |               |            |                                                                                                                                                                                                                          |
| Functional clock | PER_48M_FCLK  | UART4_FCLK | Source and gating is the PRCM module.<br>Enable/disable this clock with the<br>PRCM.CM_FCLKEN_PER[18] EN_UART4 bit.                                                                                                      |
| Interface clock  | PER_L4_ICLK   | UART4_ICLK | Source and gating is the PRCM module.<br>Enable/disable this clock with the PRCM.<br>CM_ICLKEN_PER[18] EN_UART4 bit. Enable/disable<br>auto-idle for this clock with the PRCM.CM_AUTOIDLE_<br>PER[18] AUTO_UART4 bit.    |

The idle and wake-up processes use a handshake protocol between the PRCM module and the UARTs (for a description of the protocol, see [Chapter 3, Power, Reset, and Clock Management](#)). The **UARTi.SYSC\_REG[4:3]** IDLEMODE field controls the UART idle mode.

#### 19.3.1.2 Hardware Reset

[Table 19-12](#) lists the UART reset domain.

**Table 19-12. Reset Domain**

| Peripherals | Reset Domain |
|-------------|--------------|
| UART1       | CORE_RST     |
| UART2       | CORE_RST     |
| UART3       | PER_RST      |
| UART4       | PER_RST      |

#### 19.3.1.3 Software Reset

The **UARTi.SYSC\_REG[1]** SOFTRESET bit controls the software reset; writing 1 to this bit triggers a software-reset functionally equivalent to hardware reset.

#### 19.3.1.4 Power Domain

Each UART in the CORE or PER power domain can dynamically switch between available voltage levels (see [Table 19-13](#)).

**Table 19-13. Power Domain**

| Peripherals | Power Domain |
|-------------|--------------|
| UART1       | CORE         |
| UART2       | CORE         |
| UART3       | PER          |
| UART4       | PER          |

#### 19.3.2 Hardware Requests

##### 19.3.2.1 Interrupts

[Table 19-14](#) describes the UART interrupt mappings.

**Table 19-14. Interrupt Mapping to MPU Subsystem**

| IRQ      | Source    | Description                    |
|----------|-----------|--------------------------------|
| M_IRQ_72 | UART1_IRQ | UART module 1 interrupt to MPU |
| M_IRQ_73 | UART2_IRQ | UART module 2 interrupt to MPU |
| M_IRQ_74 | UART3_IRQ | UART module 3 interrupt to MPU |
| M_IRQ_80 | UART4_IRQ | UART module 4 interrupt to MPU |

**Table 19-15. Interrupt Mapping to IVA2.2 Subsystem**

| IRQ          | SOURCE    | DESCRIPTION                                 |
|--------------|-----------|---------------------------------------------|
| IVA2_IRQ[15] | UART3_IRQ | UART module 3 interrupt to IVA2.2 subsystem |

##### 19.3.2.2 DMA Requests

[Table 19-16](#) describes the UART DMA requests.

**Table 19-16. UART DMA Requests to System DMA**

| DMA <sup>(1)</sup> | Source       | Description                    |
|--------------------|--------------|--------------------------------|
| S_DMA_48           | UART1_DMA_TX | UART module 1 transmit request |
| S_DMA_49           | UART1_DMA_RX | UART module 1 receive request  |
| S_DMA_50           | UART2_DMA_TX | UART module 2 transmit request |
| S_DMA_51           | UART2_DMA_RX | UART module 2 receive request  |
| S_DMA_52           | UART3_DMA_TX | UART module 3 transmit request |
| S_DMA_53           | UART3_DMA_RX | UART module 3 receive request  |
| S_DMA_80           | UART4_DMA_TX | UART module 4 transmit request |
| S_DMA_81           | UART4_DMA_RX | UART module 4 receive request  |

<sup>(1)</sup> This table assumes that DMA mode 1 is used.

**Table 19-17. UART DMA Requests to IVA2.2 Subsystem DMA**

| DMA      | SOURCE       | DESCRIPTION                    |
|----------|--------------|--------------------------------|
| D_DMA_10 | UART3_DMA_TX | UART module 3 transmit request |
| D_DMA_11 | UART3_DMA_RX | UART module 3 receive request  |

### 19.3.2.3 Wake-up Request

The UART can wake up the system on different events (see [Section 19.6, UART/IrDA/CIR Register Manual](#)).

One important wake-up generation is event detection on the uart1\_cts pin when the system is idle. The uart1\_cts pin uses an asynchronous path to transmit the wake-up request to the system (PRCM), which enables wake-up capabilities to be active even if all module clocks are off (see [Table 19-18](#)).

**Table 19-18. Wake-Up Requests From PRCM**

| Wake-Up Pin | PRCM Input    | Description                              |
|-------------|---------------|------------------------------------------|
| uart1_cts   | UART1_SWAKEUP | Wake UART1 (system wake-up capabilities) |
| uart2_cts   | UART2_SWAKEUP | Wake UART2 (system wake-up capabilities) |
| uart3_cts   | UART3_SWAKEUP | Wake UART3 (system wake-up capabilities) |

**CAUTION**

UARTs are not in the WAKEUP power domain, which implies limitations on wake-up capability. If the CORE power domain is off, UART1 and UART2 cannot wake up the system, because power is not supplied. If the PER power domain is off, UART3 cannot wake up the system, because power is not supplied. In these cases, a GPIO multiplexed on the uart1\_cts pin can be used to capture the event and wake up the system. Software must enable this strategy, if required. See [Chapter 25, General-Purpose Interface](#), for a full description of this mechanism.

## 19.4 UART/IrDA/CIR Functional Description

### 19.4.1 UART/IrDA/CIR Block Description

The UART/IrDA/CIR module can be divided into three main blocks:

- FIFO management
- Mode selection
- Protocol formatting

FIFO management is common to all functions and enables the transmission and reception of data from the host processor point of view.

There are two mode selections:

- Function mode selection: Route the data to the chosen functionality (UART, IrDA, or CIR) and enable the mechanism corresponding to the chosen functionality.
- Register mode selection, which enables conditional access to registers

Protocol formatting has three subcategories:

- Clock generation: The 48-MHz input clock generates all necessary clocks.
- Data formatting: Each function uses its own state-machine, which assumes the transition between FIFO data and frame data.
- Interrupt management: Different interrupt types are generated depending on the chosen function.

In parallel with these functional blocks, a power-saving strategy exists for each function.

Figure 19-21 is the UART/IrDA/CIR block diagram.

**Figure 19-21. UART/IrDA/CIR Block Diagram**



### 19.4.2 FIFO Management

The FIFO is accessed by reading/writing the `UARTi.RHR_REG` and `UARTi.THR_REG` registers. Parameters are controlled using the FIFO control register (`UARTi.FCR_REG`) and supplementary control register (`UARTi.SCR_REG`). Reading the `UARTi.SSR_REG[0]` TX\_FIFO\_FULL bit at 1 means the FIFO is full.

The `UARTi.TLR_REG` register controls the FIFO trigger level, which enables the DMA and interrupt generation. After reset, both transmitter and receiver FIFOs are disabled; so, in effect, the trigger level is the default value of 1 byte. [Figure 19-22](#) shows the FIFO management registers.

**NOTE:** Data in the `UARTi.RHR_REG` register is not overwritten when an overflow occurs.

**NOTE:** The `UARTi.SFLSR_REG`, `UARTi.SFREGL_REG`, and `UARTi.SFREGH_REG` status registers are used in IrDA mode only. For use, see [Section 19.4.4.2.3, IrDA Data Formatting](#).

**Figure 19-22. FIFO Management Registers**



### 19.4.2.1 FIFO Trigger

#### 19.4.2.1.1 Transmit FIFO Trigger

Table 19-19 summarizes the transmit FIFO trigger level settings.

**Table 19-19. TX FIFO Trigger Level Setting Summary**

| SCR_REG[6] | TLR_REG[3:0] | TX FIFO Trigger Level                                                                                                                                                                                                                                                                                                 |
|------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | = 0x0        | Defined by the UARTi. <a href="#">FCR_REG</a> [5:4] TX_FIFO_TRIG field (8,16, 32, or 56 spaces)                                                                                                                                                                                                                       |
| 0          | ≠ 0x0        | Defined by the UARTi. <a href="#">TLR_REG</a> [3:0] TX_FIFO_TRIG_DMA field (from 4 to 60 spaces with a granularity of 4 spaces)                                                                                                                                                                                       |
| 1          | Value        | Defined by the concatenated value of TX_FIFO_TRIG_DMA and TX_FIFO_TRIG (from 1 to 63 spaces with a granularity of 1 space)<br><b>Note:</b> The combination of TX_FIFO_TRIG_DMA = 0x0 and TX_FIFO_TRIG = 0x0 (all zeros) is not supported (minimum of one space required). All zeros result in unpredictable behavior. |
|            |              |                                                                                                                                                                                                                                                                                                                       |

#### 19.4.2.1.2 Receive FIFO Trigger

Table 19-20 summarizes the receive FIFO trigger level settings.

**Table 19-20. RX FIFO Trigger Level Setting Summary**

| SCR_REG[7] | TLR_REG[7:4] | RX FIFO Trigger Level                                                                                                                                                                                                                                                                                                         |
|------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | = 0x0        | Defined by the UARTi. <a href="#">FCR_REG</a> [7:6] RX_FIFO_TRIG field (8,16, 56, or 60 characters)                                                                                                                                                                                                                           |
| 0          | ≠ 0x0        | Defined by UARTi. <a href="#">TLR_REG</a> [7:4] RX_FIFO_TRIG_DMA field (from 4 to 60 characters with a granularity of 4 characters)                                                                                                                                                                                           |
| 1          | Value        | Defined by the concatenated value of RX_FIFO_TRIG_DMA and RX_FIFO_TRIG (from 1 to 63 characters with a granularity of 1 character).<br><b>Note:</b> The combination of RX_FIFO_TRIG_DMA = 0x0 and RX_FIFO_TRIG = 0x0 (all zeros) is not supported (minimum 1 character required). All zeros result in unpredictable behavior. |
|            |              |                                                                                                                                                                                                                                                                                                                               |

The receive threshold is programmed using the UARTi.[TCR\\_REG](#)[7:4] RX\_FIFO\_TRIG\_START and UARTi.[TCR\\_REG](#)[3:0] RX\_FIFO\_TRIG\_HALT fields.

- Trigger levels from 0 to 60 bytes are available with a granularity of four. (Trigger level = 4 × [4-bit register value])
- To ensure correct device operation, ensure that RX\_FIFO\_TRIG\_HALT > RX\_FIFO\_TRIG when auto-RTS is enabled.

$$\text{Delay} = [4 + 16 \times (1 + \text{CHAR\_LENGTH} + \text{Parity} + \text{Stop} - 0.5)] \times \text{Baud\_rate} + 4 \times \text{FCLK}$$

---

**NOTE:** The RTS signal is deasserted after the UART module receives the data over RX\_FIFO\_TRIG\_HALT. Delay means how long the UART module takes to deassert the RTS signal after reaching RX\_FIFO\_TRIG\_HALT.

---

- In the FIFO interrupt mode with flow control, ensure that the trigger level to HALT transmission is greater than or equal to the receive FIFO trigger level (either the UARTi.[TCR\\_REG](#)[7:4] RX\_FIFO\_TRIG\_START field or the UARTi.[FCR\\_REG](#)[7:6] RX\_FIFO\_TRIG field); otherwise, FIFO operation stalls. In the FIFO DMA mode with flow control, this concept does not exist, because a DMA request is sent when a byte is received.

### 19.4.2.2 FIFO Interrupt Mode

In the FIFO interrupt mode (the FIFO control register UARTi.[FCR\\_REG](#)[0] FIFO\_EN bit is set to 1 and

relevant interrupts are enabled by the **UART<sub>i</sub>.IER\_REG** register), an interrupt signal informs the processor of the status of the receiver and transmitter. These interrupts are raised when the receive/transmit FIFO threshold (the **UART<sub>i</sub>.TLR\_REG[7:4]** RX\_FIFO\_TRIG\_DMA and **UART<sub>i</sub>.TLR\_REG[3:0]** TX\_FIFO\_TRIG\_DMA fields or the **UART<sub>i</sub>.FCR\_REG[7:6]** RX\_FIFO\_TRIG and **UART<sub>i</sub>.FCR\_REG[5:4]** TX\_FIFO\_TRIG fields, respectively) is reached.

The interrupt signals instruct the MPU to transfer data to the destination (from the UART module in receive mode and/or from any source to the UART FIFO in transmit mode).

When the UART flow control is enabled with the interrupt capabilities, the UART flow control FIFO threshold (**UART<sub>i</sub>.TCR\_REG[3:0]** RX\_FIFO\_TRIG\_HALT field) must be greater than or equal to the receive FIFO threshold.

[Figure 19-23](#) shows the generation of the receive FIFO interrupt request.

**Figure 19-23. Receive FIFO Interrupt Request Generation**



In receive mode, no interrupt is generated until the receive FIFO reaches its threshold. Once low, the interrupt can be deasserted only when the MPU has handled enough bytes to make the FIFO level below threshold. The flow control threshold is set at a higher value than the FIFO threshold.

[Figure 19-24](#) shows the generation of the transmit FIFO interrupt request.

**Figure 19-24. Transmit FIFO Interrupt Request Generation**



In transmit mode, an interrupt request is automatically asserted when the TX FIFO is empty. This request is deasserted when the TX FIFO crosses the threshold level. The interrupt line is deasserted until a sufficient number of elements is transmitted to go below the TX FIFO threshold.

#### 19.4.2.3 FIFO Polled Mode Operation

In the FIFO polled mode (the [UARTi.FCR\\_REG\[0\]](#) FIFO\_EN bit is set to 0 and the relevant interrupts are disabled by the [UARTi.IER\\_REG](#) register), the status of the receiver and transmitter can be checked by polling the line status register ([UARTi.LSR\\_REG](#)).

This mode is an alternative to the FIFO interrupt mode of operation in which the status of the receiver and transmitter is automatically determined by sending interrupts to the MPU.

#### 19.4.2.4 FIFO DMA Mode Operation

Although DMA operation includes four modes (DMA modes 0/1/2/3), the information in [Table 19-16](#) assumes that mode 1 is used. (Mode 2 and mode 3 are legacy modes that use only one DMA request for each module.)

In mode 2, the remaining DMA request is used for RX. In mode 3, the remaining DMA request is used for TX.

The DMA requests in mode 2 and mode 3 use S\_DMA\_48, S\_DMA\_50, and S\_DMA\_52/D\_DMA\_10. S\_DMA\_49, S\_DMA\_51, and S\_DMA\_53/D\_DMA\_11 are not used by the module in mode 2 and mode 3 and can be selected as follows:

- When the [UARTi.SCR\\_REG\[0\]](#) DMA\_MODE\_CTL bit is set to 0, setting the [UARTi.FCR\\_REG\[3\]](#) DMA\_MODE bit to 0 enables DMA mode 0. Setting the DMA\_MODE bit to 1 enables DMA mode 1.
- When the DMA\_MODE\_CTL bit is set to 1, the [UARTi.FCR\\_REG\[2:1\]](#) DMA\_MODE\_2 field determines DMA mode 0 to 3 based on the supplementary control register ([SCR\\_REG](#)) description.

For example:

- If no DMA operation is desired, set the DMA\_MODE\_CTL bit to 1 and the DMA\_MODE\_2 field to 0x0. (The DMA\_MODE bit is discarded.)
- If DMA mode 1 is desired, set either the DMA\_MODE\_CTL bit to 0 and the DMA\_MODE bit to 1, or set the DMA\_MODE\_CTL bit to 1 and the DMA\_MODE\_2 field to 01. (The DMA\_MODE bit is discarded.)

If the FIFOs are disabled (the [UARTi.FCR\\_REG\[0\]](#) FIFO\_EN bit = 0), the DMA occurs in single-character transfers.

When DMA mode 0 is programmed, the signals associated with DMA operation are not active.

##### 19.4.2.4.1 DMA Transfers (DMA Mode 1, 2, or 3)

[Figure 19-25](#) through [Figure 19-28](#) show the supported DMA operations.

**Figure 19-25. Receive FIFO DMA Request Generation (32 Characters)**


In receive mode, a DMA request is generated when the receive FIFO reaches its threshold level defined in the trigger level register (UART<sub>i</sub>.[TLR\\_REG](#)). This request is deasserted when the number of bytes defined by the threshold level is read by the system DMA (sDMA).

In transmit mode, a DMA request is automatically asserted when the transmit FIFO is empty. This request is deasserted when the number of bytes defined by the number of spaces in the trigger level register (UART<sub>i</sub>.[TLR\\_REG](#)) is written by the sDMA. If an insufficient number of characters is written, the DMA request stays active.

**Figure 19-26. Transmit FIFO DMA Request Generation (56 Spaces)**


The DMA request is again asserted if the FIFO can receive the number of bytes defined by the `UARTi.TLR_REG` register.

The threshold can be programmed in a number of ways. [Figure 19-26](#) shows a DMA transfer operating with a space setting of 56 that can arise from using the auto settings in the `UARTi.FCR_REG[5:4]` TX\_FIFO\_TRIG field or the `UARTi.TLR_REG[3:0]` TX\_FIFO\_TRIG\_DMA field concatenated with the TX\_FIFO\_TRIG field.

The setting of 56 spaces in the UART/IrDA/CIR module must correlate with the settings of the sDMA so that the buffer does not overflow (program the DMA request size of the local host controller to be equal to the number of spaces value in the UART/IrDA/CIR module).

[Figure 19-27](#) shows an example with eight spaces to show the buffer level crossing the space threshold. Again, the local host DMA controller settings must correspond to that of the UART/IrDA/CIR module.

**Figure 19-27. Transmit FIFO DMA Request Generation (8 Spaces)**



The final example shows the setting of one space that uses the DMA for each transfer of one character to the transmit buffer (see [Figure 19-28](#)). The buffer is filled at a faster rate than the baud rate at which data is transmitted to the TX pin. Eventually, the buffer is completely full and the DMA operations stop transferring data to the transmit buffer.

On two occasions the buffer holds the maximum amount of data words; shortly after this, the DMA is disabled to show the slower transmission of the data words to the TX pin. Eventually, the buffer is emptied at the rate specified by the baud rate settings of the `UARTi.DLL_REG` and the `UARTi.DLH_REG` registers.

Again, the DMA settings must correspond to the system local host DMA controller settings to ensure correct operation of this logic.

**Figure 19-28. Transmit FIFO DMA Request Generation (1 Space)**



uart-029

#### 19.4.2.4.2 DMA Transmission

Figure 19-29 shows the DMA transmission process.

**Figure 19-29. Transmission Process**



uart-030

- Data to be transmitted are put in the device memory reserved for UART/IrDA/CIR transmission by the DMA:
  - Until the TX FIFO trigger level is not reached, a DMA request is generated.
  - An element (1 byte) is transferred from the SDRAM to the TX FIFO at each DMA request (DMA element synchronization).
- Data in the TX FIFO are automatically transmitted.
- The end of the transmission is signaled by the [UARTi.THR\\_REG](#) empty (TX FIFO empty).

**NOTE:** In IrDA mode, the transmission is not ended immediately after the TX FIFO empties, at which point there are still the last data byte, the CRC field, and the stop flag to be transmitted; thus, the end of transmission is a few milliseconds after the [UARTi.THR\\_REG](#) register empties.

#### 19.4.2.4.3 DMA Reception

Figure 19-30 shows the DMA reception process.

**Figure 19-30. Reception Process**

uart-031

1. Enable the reception.
2. Received data are put in the RX FIFO.
3. Data are transferred from the RX FIFO to the device memory by the DMA.
  - At each received byte, the RX FIFO trigger level (one character) is reached and a DMA request is generated.
  - An element (1 byte) is transferred from the RX FIFO to the SDRAM at each DMA request (DMA element synchronization).
4. The end of the reception is signaled by the EOF interrupt.

### 19.4.3 Mode Selection

#### 19.4.3.1 Register Access Modes

##### 19.4.3.1.1 Operational Mode and Configuration Modes

Register access depends on the register access mode, although register access modes are not correlated to functional mode selection. Three different modes are available:

- Operational mode
- Configuration mode A
- Configuration mode B

Operational mode is the selected mode when the function is active; serial data transfer can be performed in this mode.

Both configuration mode A and configuration mode B are used during module initialization steps. These modes enable access to configuration registers, which are hidden in the operational mode. The modes are used when the module is inactive (no serial data transfer processed) and only in the initialization step or reconfiguration of the module.

The value of the `UARTi.LCR_REG` register determines the register access mode (see [Table 19-21](#)).

**Table 19-21. UART/IrDA/CIR Register Access Mode Programming (Using LCR\_REG)**

| Mode                 | Condition                                                           |
|----------------------|---------------------------------------------------------------------|
| Configuration_mode_A | <code>LCR_REG[7] = 0x1</code> and <code>LCR_REG[7:0]! = 0xBF</code> |
| Configuration_mode_B | <code>LCR_REG[7] = 0x1</code> and <code>LCR_REG[7:0] = 0xBF</code>  |
| Operational_mode     | <code>LCR_REG[7] = 0x0</code>                                       |

#### **19.4.3.1.2 Register Access Submode**

In each access register mode (operational mode or configuration mode A/B), some register accesses are conditional to the programming of a submode (MSR\_SPR, TCR\_TLR, and XOFF). These registers are identified in [Section 19.6, UART/IrDA/CIR Register Manual](#).

[Table 19-22](#) through [Table 19-24](#) summarize the register access submodes.

**Table 19-22. Sub-Configuration\_Mode\_A Mode Summary**

| Mode    | Condition                              |
|---------|----------------------------------------|
| MSR_SPR | (EFR_REG[4] = 0x0 or MCR_REG[6] = 0x0) |
| TCR_TLR | EFR_REG[4] = 0x1 and MCR_REG[6] = 0x1  |

**Table 19-23. Sub-Configuration\_Mode\_B Mode Summary**

| Mode    | Condition                              |
|---------|----------------------------------------|
| TCR_TLR | EFR_REG[4] = 0x1 and MCR_REG[6] = 0x1  |
| XOFF    | (EFR_REG[4] = 0x0 or MCR_REG[6] = 0x0) |

**Table 19-24. Sub-Operational\_Mode Mode Summary**

| Mode    | Condition                             |
|---------|---------------------------------------|
| MSR_SPR | EFR_REG[4] = 0x0 or MCR_REG[6] = 0x0  |
| TCR_TLR | EFR_REG[4] = 0x1 and MCR_REG[6] = 0x1 |

#### **19.4.3.1.3 Registers Available to Register Access Modes**

[Table 19-25](#) lists the names of the register hits in each access register mode. Gray-shaded registers do not depend on the register access mode (available in all modes).

**Table 19-25. UART/IrDA/CIR Register Access Mode Overview**

| Address<br>Offset | Registers                                            |                                                      |                                                        |                                                        |                                                      |                                                      |
|-------------------|------------------------------------------------------|------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------|------------------------------------------------------|------------------------------------------------------|
|                   | Configuration_Mode_A                                 |                                                      | Configuration_Mode_B                                   |                                                        | Operational_Mode                                     |                                                      |
| Read              | Write                                                | Read                                                 | Write                                                  | Read                                                   | Write                                                |                                                      |
| 0x000             | DLL_REG                                              | DLL_REG                                              | DLL_REG                                                | DLL_REG                                                | RHR_REG                                              | THR_REG                                              |
| 0x004             | DLH_REG                                              | DLH_REG                                              | DLH_REG                                                | DLH_REG                                                | IER_REG                                              | IER_REG                                              |
| 0x008             | IIR_REG                                              | FCR_REG                                              | EFR_REG                                                | EFR_REG                                                | IIR_REG                                              | FCR_REG                                              |
| 0x00C             | LCR_REG                                              | LCR_REG                                              | LCR_REG                                                | LCR_REG                                                | LCR_REG                                              | LCR_REG                                              |
| 0x010             | MCR_REG                                              | MCR_REG                                              | XON1_ADDR1_REG                                         | XON1_ADDR1_REG                                         | MCR_REG                                              | MCR_REG                                              |
| 0x014             | LSR_REG                                              | -                                                    | XON2_ADDR2_REG                                         | XON2_ADDR2_REG                                         | LSR_REG                                              | -                                                    |
| 0x018             | MSR_REG<br><sup>(1)</sup> /TCR_REG<br><sup>(2)</sup> | TCR_REG<br><sup>(2)</sup>                            | TCR_REG<br><sup>(2)</sup> /XOFF1_REG<br><sup>(3)</sup> | TCR_REG<br><sup>(2)</sup> /XOFF1_REG<br><sup>(3)</sup> | MSR_REG<br><sup>(1)</sup> /TCR_REG<br><sup>(2)</sup> | TCR_REG<br><sup>(2)</sup>                            |
| 0x01C             | SPR_REG<br><sup>(1)</sup> /TLR_REG<br><sup>(2)</sup> | SPR_REG<br><sup>(1)</sup> /TLR_REG<br><sup>(2)</sup> | TLR_REG<br><sup>(2)</sup> /XOFF2_REG<br><sup>(3)</sup> | TLR_REG<br><sup>(2)</sup> /XOFF2_REG<br><sup>(3)</sup> | SPR_REG<br><sup>(1)</sup> /TLR_REG<br><sup>(2)</sup> | SPR_REG<br><sup>(1)</sup> /TLR_REG<br><sup>(2)</sup> |
| 0x020             | MDR1_REG                                             | MDR1_REG                                             | MDR1_REG                                               | MDR1_REG                                               | MDR1_REG                                             | MDR1_REG                                             |
| 0x024             | MDR2_REG                                             | MDR2_REG                                             | MDR2_REG                                               | MDR2_REG                                               | MDR2_REG                                             | MDR2_REG                                             |
| 0x028             | SFLSR_REG                                            | TXFLL_REG                                            | SFLSR_REG                                              | TXFLL_REG                                              | SFLSR_REG                                            | TXFLL_REG                                            |
| 0x02C             | RESUME_REG                                           | TXFLH_REG                                            | RESUME_REG                                             | TXFLH_REG                                              | RESUME_REG                                           | TXFLH_REG                                            |
| 0x030             | SFREGL_REG                                           | RXFLL_REG                                            | SFREGL_REG                                             | RXFLL_REG                                              | SFREGL_REG                                           | RXFLL_REG                                            |

<sup>(1)</sup> if MSR\_SPR mode is active (see [Section 19.4.3.1.2, Register Access Submode](#))

<sup>(2)</sup> if TCR\_TLR mode is active (see [Section 19.4.3.1.2, Register Access Submode](#))

<sup>(3)</sup> if XOFF mode is active (see [Section 19.4.3.1.2, Register Access Submode](#))

**Table 19-25. UART/IrDA/CIR Register Access Mode Overview (continued)**

| Address<br>Offset | Registers            |           |                      |           |                  |           |
|-------------------|----------------------|-----------|----------------------|-----------|------------------|-----------|
|                   | Configuration_Mode_A |           | Configuration_Mode_B |           | Operational_Mode |           |
|                   | Read                 | Write     | Read                 | Write     | Read             | Write     |
| 0x034             | SFREGH_REG           | RXFLH_REG | SFREGH_REG           | RXFLH_REG | SFREGH_REG       | RXFLH_REG |
| 0x038             | UASR_REG             | -         | UASR_REG             | -         | BLR_REG          | BLR_REG   |
| 0x03C             | -                    | -         | -                    | -         | ACREG_REG        | ACREG_REG |
| 0x040             | SCR_REG              | SCR_REG   | SCR_REG              | SCR_REG   | SCR_REG          | SCR_REG   |
| 0x044             | SSR_REG              | -         | SSR_REG              | -         | SSR_REG          | -         |
| 0x048             | -                    | -         | -                    | -         | EBLR_REG         | EBLR_REG  |
| 0x050             | MVR_REG              | -         | MVR_REG              | -         | MVR_REG          | -         |
| 0x054             | SYSC_REG             | SYSC_REG  | SYSC_REG             | SYSC_REG  | SYSC_REG         | SYSC_REG  |
| 0x058             | SYSS_REG             | -         | SYSS_REG             | -         | SYSS_REG         | -         |
| 0x05C             | WER_REG              | WER_REG   | WER_REG              | WER_REG   | WER_REG          | WER_REG   |
| 0x060             | CFPS_REG             | CFPS_REG  | CFPS_REG             | CFPS_REG  | CFPS_REG         | CFPS_REG  |
| 0x064             | RXFIFO_LVL_REG       | -         | RXFIFO_LVL_REG       | -         | RXFIFO_LVL_REG   | -         |
| 0x068             | TXFIFO_LVL_REG       | -         | TXFIFO_LVL_REG       | -         | TXFIFO_LVL_REG   | -         |
| 0x06C             | IER2_REG             | IER2_REG  | IER2_REG             | IER2_REG  | IER2_REG         | IER2_REG  |
| 0x070             | ISR2_REG             | ISR2_REG  | ISR2_REG             | ISR2_REG  | ISR2_REG         | ISR2_REG  |
| 0x080             | MDR3_REG             | MDR3_REG  | MDR3_REG             | MDR3_REG  | MDR3_REG         | MDR3_REG  |

### 19.4.3.2 UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection

To select a mode, set the **UARTi.MDR1\_REG[2:0]** MODE\_SELECT field (see [Table 19-26](#)).

**Table 19-26. UART Mode Selection**

| Value | Mode                  |
|-------|-----------------------|
| 0x0:  | UART 16x mode         |
| 0x1:  | SIR mode (UART3 only) |
| 0x2:  | UART 16x auto-baud    |
| 0x3:  | UART 13x mode         |
| 0x4:  | MIR mode (UART3 only) |
| 0x5:  | FIR mode (UART3 only) |
| 0x6:  | CIR mode (UART3 only) |

MODE\_SELECT is effective when the module is in operational mode (see [Section 19.4.3.1, Register Access Modes](#)).

#### 19.4.3.2.1 Registers Available for the UART Function

Only the registers listed in [Table 19-27](#) are used for the UART function.

**Table 19-27. UART Mode Register Overview<sup>(1)</sup> <sup>(2)</sup>**

| Address<br>Offset | Registers            |                     |                       |                       |                     |                     |
|-------------------|----------------------|---------------------|-----------------------|-----------------------|---------------------|---------------------|
|                   | Configuration_Mode_A |                     | Configuration_Mode_B  |                       | Operational_Mode    |                     |
| Read              | Write                | Read                | Write                 | Read                  | Write               |                     |
| 0x000             | DLL_REG              | DLL_REG             | DLL_REG               | DLL_REG               | RHR_REG             | THR_REG             |
| 0x004             | DLH_REG              | DLH_REG             | DLH_REG               | DLH_REG               | IER_REG(UART)       | IER_REG(UAR<br>T)   |
| 0x008             | IIR_REG              | FCR_REG             | EFR_REG[4]            | EFR_REG[4]            | IIR_REG(UART)       | FCR_REG(UAR<br>T)   |
| 0x00C             | LCR_REG              | LCR_REG             | LCR_REG               | LCR_REG               | LCR_REG             | LCR_REG             |
| 0x010             | MCR_REG              | MCR_REG             | XON1_ADDR1_REG        | XON1_ADDR1_RE<br>G    | MCR_REG             | MCR_REG             |
| 0x014             | LSR_REG(UAR<br>T)    | -                   | XON2_ADDR2_REG        | XON2_ADDR2_RE<br>G    | LSR_REG(UART)       | -                   |
| 0x018             | MSR_REG/TCR<br>_REG  | TCR_REG             | XOFF1_REG/TCR_R<br>EG | XOFF1_REG/TCR<br>_REG | MSR_REG/TCR_RE<br>G | TCR_REG             |
| 0x01C             | TLR_REG/SPR<br>_REG  | TLR_REG/SPR_<br>REG | TLR_REG/XOFF2_R<br>EG | TLR_REG/XOFF2_<br>REG | TLR_REG/SPR_RE<br>G | TLR_REG/SPR<br>_REG |
| 0x020             | MDR1_REG             | MDR1_REG[2:0]       | MDR1_REG[2:0]         | MDR1_REG[2:0]         | MDR1_REG[2:0]       | MDR1_REG[2:0<br>]   |
| 0x024             | MDR2_REG             | MDR2_REG            | MDR2_REG              | MDR2_REG              | MDR2_REG            | MDR2_REG            |
| 0x028             | -                    | -                   | -                     | -                     | -                   | -                   |
| 0x02C             | -                    | -                   | -                     | -                     | -                   | -                   |
| 0x030             | -                    | -                   | -                     | -                     | -                   | -                   |
| 0x034             | -                    | -                   | -                     | -                     | -                   | -                   |
| 0x038             | UASR_REG             | -                   | UASR_REG              | -                     | -                   | -                   |
| 0x03C             | -                    | -                   | -                     | -                     | -                   | -                   |
| 0x040             | SCR_REG              | SCR_REG             | SCR_REG               | SCR_REG               | SCR_REG             | SCR_REG             |
| 0x044             | SSR_REG              | -                   | SSR_REG               | -                     | SSR_REG             | -                   |
| 0x048             | -                    | -                   | -                     | -                     | -                   | -                   |

<sup>(1)</sup> REGISTER\_NAME(UART) notation indicates that the register exists for other functions (IrDA or CIR), but fields have different meanings for other functions (described separately in [Section 19.6, UART/IrDA/CIR Register Manual](#)).

<sup>(2)</sup> REGISTER\_NAME[m:n] notation indicates that only register bits numbered m to n apply to the UART function.

**Table 19-27. UART Mode Register Overview<sup>(1)</sup> <sup>(2)</sup> (continued)**

| Address<br>Offset | Registers            |                    |                      |                    |                  |                    |
|-------------------|----------------------|--------------------|----------------------|--------------------|------------------|--------------------|
|                   | Configuration_Mode_A |                    | Configuration_Mode_B |                    | Operational_Mode |                    |
|                   | Read                 | Write              | Read                 | Write              | Read             | Write              |
| 0x050             | MVR_REG              | -                  | MVR_REG              | -                  | MVR_REG          | -                  |
| 0x054             | SYSC_REG             | SYSC_REG           | SYSC_REG             | SYSC_REG           | SYSC_REG         | SYSC_REG           |
| 0x058             | SYSS_REG             | -                  | SYSS_REG             | -                  | SYSS_REG         | -                  |
| 0x05C             | WER_REG              | WER_REG            | WER_REG              | WER_REG            | WER_REG          | WER_REG            |
| 0x060             | -                    | -                  | -                    | -                  | -                | -                  |
| 0x064             | RXFIFO_LVL_R<br>EG   | RXFIFO_LVL_R<br>EG | RXFIFO_LVL_REG       | RXFIFO_LVL_R<br>EG | RXFIFO_LVL_REG   | RXFIFO_LVL_R<br>EG |
| 0x068             | TXFIFO_LVL_R<br>EG   | TXFIFO_LVL_R<br>EG | TXFIFO_LVL_REG       | TXFIFO_LVL_REG     | TXFIFO_LVL_REG   | TXFIFO_LVL_R<br>EG |
| 0x06C             | IER2_REG             | IER2_REG           | IER2_REG             | IER2_REG           | IER2_REG         | IER2_REG           |
| 0x070             | ISR2_REG             | ISR2_REG           | ISR2_REG             | ISR2_REG           | ISR2_REG         | ISR2_REG           |
| 0x080             | MDR3_REG             | MDR3_REG           | MDR3_REG             | MDR3_REG           | MDR3_REG         | MDR3_REG           |

**19.4.3.2.2 Registers Available for the IrDA Function (UART3 Only)**

Only the registers listed in Table 19-28 are used for the IrDA function.

**Table 19-28. IrDA Mode Register Overview<sup>(1)</sup> <sup>(2)</sup>**

| Address<br>Offset | Registers            |                 |                      |                |                  |                 |
|-------------------|----------------------|-----------------|----------------------|----------------|------------------|-----------------|
|                   | Configuration_Mode_A |                 | Configuration_Mode_B |                | Operational_Mode |                 |
|                   | Read                 | Write           | Read                 | Write          | Read             | Write           |
| 0x000             | DLL_REG              | DLL_REG         | DLL_REG              | DLL_REG        | RHR_REG          | THR_REG         |
| 0x004             | DLH_REG              | DLH_REG         | DLH_REG              | DLH_REG        | IER_REG(IrDA )   | IER_REG(IrDA )  |
| 0x008             | IIR_REG              | FCR_REG         | EFR_REG[4]           | EFR_REG[4]     | IIR_REG(IrDA )   | FCR_REG(IrDA )  |
| 0x00C             | LCR_REG              | LCR_REG         | LCR_REG              | LCR_REG        | LCR_REG          | LCR_REG         |
| 0x010             | -                    | -               | XON1_ADDR1_REG       | XON1_ADDR1_REG | MCR_REG          | MCR_REG         |
| 0x014             | LSR_REG(IrDA )       | -               | XON2_ADDR2_REG       | XON2_ADDR2_REG | LSR_REG(IrDA )   | -               |
| 0x018             | MSR_REG/TCR<br>_REG  | TCR_REG         | TCR_REG              | TCR_REG        | MSR_REG/TCR_REG  | TCR_REG         |
| 0x01C             | TLR_REG/SPR<br>_REG  | TLR_REG/SPR_REG | TLR_REG              | TLR_REG        | TLR_REG/SPR_REG  | TLR_REG/SPR_REG |
| 0x020             | MDR1_REG             | MDR1_REG        | MDR1_REG             | MDR1_REG       | MDR1_REG         | MDR1_REG        |
| 0x024             | MDR2_REG             | MDR2_REG        | MDR2_REG             | MDR2_REG       | MDR2_REG         | MDR2_REG        |
| 0x028             | SFLSR_REG            | TXFLL_REG       | SFLSR_REG            | TXFLL_REG      | SFLSR_REG        | TXFLL_REG       |
| 0x02C             | RESUME_REG           | TXFLH_REG       | RESUME_REG           | TXFLH_REG      | RESUME_REG       | TXFLH_REG       |
| 0x030             | SFREGL_REG           | RXFLL_REG       | SFREGL_REG           | RXFLL_REG      | SFREGL_REG       | RXFLL_REG       |
| 0x034             | SFREGH_REG           | RXFLH_REG       | SFREGH_REG           | RXFLH_REG      | SFREGH_REG       | RXFLH_REG       |
| 0x038             | -                    | -               | -                    | -              | BLR_REG          | BLR_REG         |
| 0x03C             | -                    | -               | -                    | -              | ACREG_REG        | ACREG_REG       |
| 0x040             | SCR_REG              | SCR_REG         | SCR_REG              | SCR_REG        | SCR_REG          | SCR_REG         |
| 0x044             | SSR_REG              | -               | SSR_REG              | -              | SSR_REG          | -               |

<sup>(1)</sup> REGISTER\_NAME(UART) notation indicates that the register exists for other functions (IrDA or CIR), but fields have different meanings for other functions (described separately in [Section 19.6, UART/IrDA/CIR Register Manual](#)).

<sup>(2)</sup> REGISTER\_NAME[m:n] notation indicates that only register bits numbered m to n apply to the UART function.

**Table 19-28. IrDA Mode Register Overview<sup>(1)</sup> <sup>(2)</sup> (continued)**

| Address<br>Offset | Registers            |                |                      |                |                  |                |
|-------------------|----------------------|----------------|----------------------|----------------|------------------|----------------|
|                   | Configuration_Mode_A |                | Configuration_Mode_B |                | Operational_Mode |                |
|                   | Read                 | Write          | Read                 | Write          | Read             | Write          |
| 0x048             | -                    | -              | -                    | -              | EBLR_REG         | EBLR_REG       |
| 0x050             | MVR_REG              | -              | MVR_REG              | -              | MVR_REG          | -              |
| 0x054             | SYSC_REG             | SYSC_REG       | SYSC_REG             | SYSC_REG       | SYSC_REG         | SYSC_REG       |
| 0x058             | SYSS_REG             | -              | SYSS_REG             | -              | SYSS_REG         | -              |
| 0x05C             | WER_REG[6:4]         | WER_REG[6:4]   | WER_REG[6:4]         | WER_REG[6:4]   | WER_REG[6:4]     | WER_REG[6:4]   |
| 0x060             | -                    | -              | -                    | -              | -                | -              |
| 0x064             | RXFIFO_LVL_REG       | RXFIFO_LVL_REG | RXFIFO_LVL_REG       | RXFIFO_LVL_REG | RXFIFO_LVL_REG   | RXFIFO_LVL_REG |
| 0x068             | TXFIFO_LVL_REG       | TXFIFO_LVL_REG | TXFIFO_LVL_REG       | TXFIFO_LVL_REG | TXFIFO_LVL_REG   | TXFIFO_LVL_REG |
| 0x06C             | IER2_REG             | IER2_REG       | IER2_REG             | IER2_REG       | IER2_REG         | IER2_REG       |
| 0x070             | ISR2_REG             | ISR2_REG       | ISR2_REG             | ISR2_REG       | ISR2_REG         | ISR2_REG       |
| 0x080             | MDR3_REG             | MDR3_REG       | MDR3_REG             | MDR3_REG       | MDR3_REG         | MDR3_REG       |

#### 19.4.3.2.3 Registers Available for the CIR Function (UART3 Only)

Only the registers listed in Table 19-29 are used for CIR function.

**Table 19-29. CIR Mode Register Overview<sup>(1)</sup> <sup>(2)</sup>**

| Address<br>Offset | Registers            |                 |                      |               |                  |                 |
|-------------------|----------------------|-----------------|----------------------|---------------|------------------|-----------------|
|                   | Configuration_Mode_A |                 | Configuration_Mode_B |               | Operational_Mode |                 |
|                   | Read                 | Write           | Read                 | Write         | Read             | Write           |
| 0x000             | DLL_REG              | DLL_REG         | DLL_REG              | DLL_REG       |                  | THR_REG         |
| 0x004             | DLH_REG              | DLH_REG         | DLH_REG              | DLH_REG       | IER_REG(CIR)     | IER_REG(CIR)    |
| 0x008             | IIR_REG              | FCR_REG         | EFR_REG              | EFR_REG       | IIR_REG(CIR)     | FCR_REG(CIR)    |
| 0x00C             | LCR_REG              | LCR_REG[7]      | LCR_REG[7]           | LCR_REG[7]    | LCR_REG[7]       | LCR_REG[7]      |
| 0x010             | -                    | -               | -                    | -             | -                | -               |
| 0x014             | LSR_REG(IrDA )       | -               | -                    | -             | LSR_REG(IrDA )   | -               |
| 0x018             | MSR_REG/TCR_REG      | TCR_REG         | TCR_REG              | TCR_REG       | MSR_REG/TCR_REG  | TCR_REG         |
| 0x01C             | TLR_REG/SPR_REG      | TLR_REG/SPR_REG | TLR_REG              | TLR_REG       | TLR_REG/SPR_REG  | TLR_REG/SPR_REG |
| 0x020             | MDR1_REG[3:0]        | MDR1_REG[3:0]   | MDR1_REG[3:0]        | MDR1_REG[3:0] | MDR1_REG[3:0]    | MDR1_REG[3:0]   |
| 0x024             | MDR2_REG             | MDR2_REG        | MDR2_REG             | MDR2_REG      | MDR2_REG         | MDR2_REG        |
| 0x028             | -                    | -               | -                    | -             | -                | -               |
| 0x02C             | RESUME_REG           | -               | RESUME_REG           | -             | RESUME_REG       | -               |
| 0x030             | -                    | -               | -                    | -             | -                | -               |
| 0x034             | -                    | -               | -                    | -             | -                | -               |
| 0x038             | -                    | -               | -                    | -             | -                | -               |
| 0x03C             | -                    | -               | -                    | -             | ACREG_REG        | ACREG_REG       |
| 0x040             | SCR_REG              | SCR_REG         | SCR_REG              | SCR_REG       | SCR_REG          | SCR_REG         |
| 0x044             | SSR_REG              | -               | SSR_REG              | -             | SSR_REG          | -               |

<sup>(1)</sup> REGISTER\_NAME(UART) notation indicates that the register exists for other functions (IrDA or CIR), but fields have different meanings for other functions (described separately in [Section 19.6, UART/IrDA/CIR Register Manual](#)).

<sup>(2)</sup> REGISTER\_NAME[m:n] notation indicates that only register bits numbered m to n apply to the UART function.

**Table 19-29. CIR Mode Register Overview<sup>(1)</sup> <sup>(2)</sup> (continued)**

| Address<br>Offset | Registers            |                    |                      |                    |                  |                    |
|-------------------|----------------------|--------------------|----------------------|--------------------|------------------|--------------------|
|                   | Configuration_Mode_A |                    | Configuration_Mode_B |                    | Operational_Mode |                    |
|                   | Read                 | Write              | Read                 | Write              | Read             | Write              |
| 0x048             | -                    | -                  | -                    | -                  | EBLR_REG         | EBLR_REG           |
| 0x050             | MVR_REG              | -                  | MVR_REG              | -                  | MVR_REG          | -                  |
| 0x054             | SYSC_REG             | SYSC_REG           | SYSC_REG             | SYSC_REG           | SYSC_REG         | SYSC_REG           |
| 0x058             | SYSS_REG             | -                  | SYSS_REG             | -                  | SYSS_REG         | -                  |
| 0x05C             | WER_REG[6:4]         | WER_REG[6:4]       | WER_REG[6:4]         | WER_REG[6:4]       | WER_REG[6:4]     | WER_REG[6:4]       |
| 0x060             | CFPS_REG             | CFPS_REG           | CFPS_REG             | CFPS_REG           | CFPS_REG         | CFPS_REG           |
| 0x064             | RXFIFO_LVL_R<br>EG   | RXFIFO_LVL_R<br>EG | RXFIFO_LVL_REG       | RXFIFO_LVL_R<br>EG | RXFIFO_LVL_REG   | RXFIFO_LVL_R<br>EG |
| 0x068             | TXFIFO_LVL_R<br>EG   | TXFIFO_LVL_R<br>EG | TXFIFO_LVL_REG       | TXFIFO_LVL_REG     | TXFIFO_LVL_REG   | TXFIFO_LVL_R<br>EG |
| 0x06C             | IER2_REG             | IER2_REG           | IER2_REG             | IER2_REG           | IER2_REG         | IER2_REG           |
| 0x070             | ISR2_REG             | ISR2_REG           | ISR2_REG             | ISR2_REG           | ISR2_REG         | ISR2_REG           |
| 0x080             | MDR3_REG             | MDR3_REG           | MDR3_REG             | MDR3_REG           | MDR3_REG         | MDR3_REG           |

## 19.4.4 Protocol Formatting

### 19.4.4.1 UART Mode

#### 19.4.4.1.1 UART Clock Generation: Baud Rate Generation

The UART function contains a programmable baud generator and a set of fixed dividers that divide the 48-MHz clock input down to the expected baud rate.

Figure 19-31 shows the baud rate generator and associated controls.

**Figure 19-31. Baud Rate Generation**

#### CAUTION

It is mandatory that MODE\_SELECT = DISABLE (UARTi.MDR1\_REG[2:0] = 0x7) before initializing or modifying clock parameter controls (UARTi.DLH\_REG, UARTi.DLL\_REG). Failure to observe this rule can result in unpredictable module behavior.

#### **19.4.4.1.2 Choosing the Appropriate Divisor Value**

Two divisor values are:

- UART 16x mode: Divisor value = Operating frequency/(16x baud rate)
- UART 13x mode: Divisor value = Operating frequency/(13x baud rate)

[Table 19-30](#) describes the UART baud rate settings.

**Table 19-30. UART Baud Rate Settings (48-MHz Clock)**

| Baud Rate   | Baud Multiple | DLH,DLL (Decimal) | DLH,DLL (Hex) | Actual Baud Rate | Error (%) |
|-------------|---------------|-------------------|---------------|------------------|-----------|
| 0.3 Kbps    | 16x           | 10000             | 0x27, 0x10    | 0.3 Kbps         | 0         |
| 0.6 Kbps    | 16x           | 5000              | 0x13, 0x88    | 0.6 Kbps         | 0         |
| 1.2 Kbps    | 16x           | 2500              | 0x09, 0xC4    | 1.2 Kbps         | 0         |
| 2.4 Kbps    | 16x           | 1250              | 0x04, 0xE2    | 2.4 Kbps         | 0         |
| 4.8 Kbps    | 16x           | 625               | 0x02, 0x71    | 4.8 Kbps         | 0         |
| 9.6 Kbps    | 16x           | 312               | 0x01, 0x38    | 9.6153 Kbps      | +0.16     |
| 14.4 Kbps   | 16x           | 208               | 0x00, 0xD0    | 14.423 Kbps      | +0.16     |
| 19.2 Kbps   | 16x           | 156               | 0x00, 0x9C    | 19.231 Kbps      | +0.16     |
| 28.8 Kbps   | 16x           | 104               | 0x00, 0x68    | 28.846 Kbps      | +0.16     |
| 38.4 Kbps   | 16x           | 78                | 0x00, 0x4E    | 38.462 Kbps      | +0.16     |
| 57.6 Kbps   | 16x           | 52                | 0x00, 0x34    | 57.692 Kbps      | +0.16     |
| 115.2 Kbps  | 16x           | 26                | 0x00, 0x1A    | 115.38 Kbps      | +0.16     |
| 230.4 Kbps  | 16x           | 13                | 0x00, 0x0D    | 230.77 Kbps      | +0.16     |
| 460.8 Kbps  | 13x           | 8                 | 0x00, 0x08    | 461.54 Kbps      | +0.16     |
| 921.6 Kbps  | 13x           | 4                 | 0x00, 0x04    | 923.08 Kbps      | +0.16     |
| 1.843 Mbps  | 13x           | 2                 | 0x00, 0x02    | 1.846 Mbps       | +0.16     |
| 3.6884 Mbps | 13x           | 1                 | 0x00, 0x01    | 3.6923 Mbps      | +0.16     |

#### **19.4.4.1.3 UART Data Formatting**

The UART module can use hardware flow control to manage transmission/reception. Hardware flow control significantly reduces software overhead and increases system efficiency by automatically controlling serial data flow using the RTS output and CTS input signals.

The UART module is enhanced with the autobauding function. In control mode, autobauding allows the speed, the number of bits per character, and the parity selected to be set automatically.

##### **19.4.4.1.3.1 Frame Formatting**

When autobauding is not used, frame format attributes must be defined in the [UARTi.LCR\\_REG](#) register.

Character length is specified using the [UARTi.LCR\\_REG\[1:0\]](#) CHAR\_LENGTH field.

The number of stop bits is specified using the [UARTi.LCR\\_REG\[2\]](#) NB\_STOP register bit.

The parity bit is programmed using the [UARTi.LCR\\_REG\[5:3\]](#) PARITY\_EN, PARITY\_TYPE\_1, and PARITY\_TYPE\_2 register bits (see [Table 19-31](#)).

**Table 19-31. UART Parity Bit Encoding**

| PARITY_EN | PARITY_TYPE1 | PARITY_TYPE2 | Parity      |
|-----------|--------------|--------------|-------------|
| 0         | N/A          | N/A          | No parity   |
| 1         | 0            | 0            | Odd parity  |
| 1         | 1            | 0            | Even parity |
| 1         | 0            | 1            | Forced 1    |
| 1         | 1            | 1            | Forced 0    |

#### 19.4.4.1.3.2 Hardware Flow Control

Hardware flow control is composed of auto-CTS and auto-RTS. Auto-CTS and auto-RTS can be enabled/disabled independently by programming the UARTi.[EFR\\_REG\[7:6\]](#) AUTO\_CTS\_EN and AUTO\_RTS\_EN bits, respectively.

With auto-CTS, uarti\_cts must be active before the module can transmit data.

Auto-RTS activates the uarti\_rts output only when there is enough room in the RX FIFO to receive data. It deactivates the uarti\_rts output when the RX FIFO is sufficiently full. The HALT and RESTORE trigger levels in the UARTi.[TCR\\_REG](#) register determine the levels at which uarti\_rts is activated/deactivated.

If both auto-CTS and auto-RTS are enabled, data transmission does not occur unless the receiver FIFO has empty space. Thus, overrun errors are eliminated during hardware flow control. If auto-CTS and auto-RTS are not enabled, overrun errors occur if the transmit data rate exceeds the receive FIFO latency.

- **Auto-RTS**

Auto-RTS data flow control originates in the receiver block. The receiver FIFO trigger levels used in auto-RTS are stored in the UARTi.[TCR\\_REG](#) register. uarti\_rts is active if the RX FIFO level is below the HALT trigger level in the UARTi.[TCR\\_REG\[3:0\]](#) RX\_FIFO\_TRIG\_HALTI field. When the receiver FIFO HALT trigger level is reached, uarti\_rts is deasserted. The sending device (for example, another UART) might send an additional byte after the trigger level is reached because it might not recognize the deassertion of RTS until it begins sending the additional byte.

uarti\_rts is automatically reasserted when the receiver FIFO reaches the RESUME trigger level programmed by the UARTi.[TCR\\_REG\[7:4\]](#) RX\_FIFO\_TRIG\_START field. This reassertion requests the sending device to resume transmission.

In this case, uarti\_rts is an active-low signal.

- **Auto-CTS**

The transmitter circuitry checks uarti\_cts before sending the next data byte. When uarti\_cts is active, the transmitter sends the next byte. To stop the transmitter from sending the next byte, uarti\_cts must be deasserted before the middle of the last stop bit currently sent.

The auto-CTS function reduces interrupts to the host system. When auto-CTS flow control is enabled, the uarti\_cts state changes do not have to trigger host interrupts because the device automatically controls its own transmitter. Without auto-CTS, the transmitter sends any data present in the transmit FIFO, and a receiver overrun error can result.

In this case, uarti\_cts is an active-low signal.

#### 19.4.4.1.3.3 Software Flow Control

Software flow control is enabled through the enhanced feature register (UARTi.[EFR\\_REG](#)) and the modem control register (UARTi.[MCR\\_REG](#)). Different combinations of software flow control can be enabled by setting different combinations of UARTi.[EFR\\_REG\[3:0\]](#) (see [Table 19-32](#)).

Two other enhanced features relate to software flow control:

- XON any function (UARTi.[MCR\\_REG\[5\]](#)): Operation resumes after receiving any character after recognition of the XOFF character. If special character detect is enabled and a special character is received after XOFF1, transmission is not resumed. The special character is stored in the RX FIFO.

---

**NOTE:** The XON-any character is written into the RX FIFO even if it is a software flow character.

---

- Special character (UARTi.[EFR\\_REG\[5\]](#)): Incoming data is compared to XOFF2. When the special character is detected, the XOFF interrupt (UARTi.[IIR\\_REG\[4\]](#)) is set, but it does not halt transmission. The XOFF interrupt is cleared by a read of UARTi.[IIR\\_REG](#). The special character is transferred to the RX FIFO. The special character feature does not work with XON2, XOFF2, or sequential XOFFs.

**Table 19-32. EFR\_REG[0-3] Software Flow Control Options**

| Bit 3 | Bit 2 | Bit 1 | Bit 0 | Tx, Rx Software Flow Controls |
|-------|-------|-------|-------|-------------------------------|
| 0     | 0     | X     | X     | No transmit flow control      |
| 1     | 0     | X     | X     | Transmit XON1, XOFF1          |

**Table 19-32. EFR\_REG[0-3] Software Flow Control Options (continued)**

| Bit 3 | Bit 2 | Bit 1 | Bit 0 | Tx, Rx Software Flow Controls                             |
|-------|-------|-------|-------|-----------------------------------------------------------|
| 0     | 1     | X     | X     | Transmit XON2, XOFF2                                      |
| 1     | 1     | X     | X     | Transmit XON1, XON2: XOFF1, XOFF2 <sup>(1)</sup>          |
| X     | X     | 0     | 0     | No receive flow control                                   |
| X     | X     | 1     | 0     | Receiver compares XON1, XOFF1                             |
| X     | X     | 0     | 1     | Receiver compares XON2, XOFF2                             |
| X     | X     | 1     | 1     | Receiver compares XON1, XON2: XOFF1, XOFF2 <sup>(1)</sup> |

<sup>(1)</sup> In these cases, the XON1 and XON2 characters or the XOFF1 and XOFF2 characters must be transmitted/received sequentially with XON1/XOFF1 followed by XON2/XOFF2.

XON1 is defined in the `UARTi.XON1_ADDR1_REG[7:0]` XON\_WORD1 field, XON2 is defined in `UARTi.XON2_ADDR2_REG[7:0]` XON\_WORD2.

XOFF1 is defined in the `UARTi.XOFF1_REG[7:0]` XOFF\_WORD1 field, XOFF2 is defined in `UARTi.XOFF2_REG[7:0]` XOFF\_WORD2.

#### 19.4.4.1.3.3.1 Receive (RX)

When software flow control operation is enabled, the UART compares incoming data with XOFF1/2 programmed characters (in certain cases, XOFF1 and XOFF2 must be received sequentially). When the correct XOFF characters are received, transmission stops after transmission of the current character is complete. XOFF detection also sets `UARTi.IIR_REG[4]` (if enabled by `UARTi.IER_REG[5]`) and causes the interrupt line to go low.

To resume transmission, an XON1/2 character must be received (in certain cases, XON1 and XON2 must be received sequentially). When the correct XON characters are received, `UARTi.IIR_REG[4]` is cleared and the XOFF interrupt disappears.

---

**NOTE:** When a parity, framing, or break error occurs while receiving a software flow control character, this character is treated as normal data and is written to the RX FIFO.

---

When XON-any and special character detect are disabled and software flow control is enabled, no valid XON or XOFF characters are written to the RX FIFO. For example, when `UARTi.EFR_REG[1:0] = 0x2`, if XON1 and XOFF1 characters are received, they do not get written to the RX FIFO.

When pairs of software flow characters are programmed to be received sequentially (`UARTi.EFR_REG[1:0] = 0x3`), the software flow characters are not written to the RX FIFO if they are received sequentially. However, received XON1/XOFF1 characters must be written to the RX FIFO if the subsequent character is not XON2/XOFF2.

#### 19.4.4.1.3.3.2 Transmit (TX)

XOFF1: Two characters are transmitted when the RX FIFO passes the trigger level programmed by `UARTi.TCR_REG[3:0]`.

XON1: Two characters are transmitted when the RX FIFO reaches the trigger level programmed by `UARTi.TCR_REG[7:4]`.

---

**NOTE:** If software flow control is disabled after an XOFF character is sent, the module transmits XON characters automatically to enable normal transmission to proceed.

---

The transmission of XOFF(s)/XON(s) follows the same protocol as transmission of an ordinary byte from the TX FIFO. This means that even if the word length is set to 5, 6, or 7 characters, the 5, 6, or 7 LSBs of XOFF1/2 and XON1/2 are transmitted. The 5, 6, or 7 bits of a character are seldom transmitted, but this function is included to maintain compatibility with earlier designs.

It is assumed that software flow control and hardware flow control are never enabled simultaneously.

#### 19.4.4.1.3.4 Autobaunding Modes

In autobaunding mode, the UART can extract transfer characteristics (speed, length, and parity) from an AT command (ASCII code). These characteristics are used to receive data after an "at" (AT) and to send data.

The valid AT commands follow:

|    |      |      |
|----|------|------|
| AT | DATA | <CR> |
| at | DATA | <CR> |
| A/ |      |      |
| a/ |      |      |

A line break during the acquisition of the sequence AT is not recognized, and echo functionality is not implemented in hardware.

A/ and a/ are not used to extract characteristics, but they must be recognized because of their special meaning. Either A/ or a/ is used to instruct the software to repeat the last received AT command; therefore, an a/ always follows an AT, and transfer characteristics are not expected to change between an AT and an a/.

When a valid AT is received, AT and all subsequent data, including the final <CR> (0x0D), are saved to RX FIFO. The autobaunding state-machine waits for the next valid AT command. If an a/ (A/) is received, the a/ (A/) is saved into RX FIFO and the state-machine waits for the next valid AT command.

On the first successful detection of the baud rate, the UART activates an interrupt to signify that the AT (upper or lower case) sequence is detected. The [UARTi.UASR\\_REG](#) register reflects the correct settings for the baud rate detected. The interrupt activity can continue in this fashion when a subsequent character is received. Therefore, it is recommended that the software enable the RHR interrupt when using the autobaunding mode.

The following settings are detected in autobaunding mode with a module clock of 48 MHz:

- Speed: 115.2k baud, 57.6k baud, 38.4k baud, 28.8k baud, 19.2k baud, 14.4k baud, 9.6k baud, 4.8k baud, 2.4k baud, or 1.2k baud
- Length: 7 or 8 bits
- Parity: Odd, even, or space

---

**NOTE:** The combination of 7-bit character + space parity is not supported.

---

Autobaunding mode is selected when the [UARTi.MDR1\\_REG\[2:0\]](#) MODE\_SELECT field is set to 0x2. In the UART autobaunding mode, [UARTi.DLL\\_REG](#), [UARTi.DLH\\_REG](#), [UARTi.LCR\\_REG\[5:0\]](#) settings are not used; instead, [UASR\\_REG](#) is updated with the configuration detected by the autobaunding logic.

#### [UASR\\_REG](#) Autobaunding Status Register Use

This register is used to set up transmission according to the characteristics of the previous reception instead of the [UARTi.LCR\\_REG](#), [UARTi.DLL\\_REG](#), and [UARTi.DLH\\_REG](#) registers when the UART is in autobaunding mode.

To reset the autobaunding hardware (to start a new AT detection) or to set the UART in standard mode (no autobaunding), the [UARTi.MDR1\\_REG\[2:0\]](#) MODE\_SELECT field must be set to reset state (0x7) and then to the UART in autobaunding mode (0x2) or to the UART in standard mode (0x0).

Use limitation:

- Only 7- and 8-bit characters (5- and 6-bit not supported)
- 7-bit character with space parity not supported
- Baud rate between 1,200 and 115,200 bps (10 possibilities)

#### 19.4.4.1.3.5 Error Detection

When the `UARTi.LSR_REG` register is read, `UARTi.LSR_REG[4:2]` reflects the error bits (BI: break condition, FE: framing error, PE: parity error) of the character at the top of the RX FIFO (next character to be read). Therefore, reading the `UARTi.LSR_REG` register and then reading the `UARTi.RHR_REG` register identifies errors in a character.

Reading the `UARTi.RHR_REG` register updates the BI, FE, and PE bits (see [Table 19-33](#) for the UART mode interrupts).

The `UARTi.LSR_REG [7] RX_FIFO_STS` bit is set when there is an error in the RX FIFO and is cleared only when no errors remain in the RX FIFO.

---

**NOTE:** Reading `UARTi.LSR_REG` does not cause an increment of the RX FIFO read pointer. The RX FIFO read pointer is incremented by reading `UARTi.RHR_REG`.

---

Reading `UARTi.LSR_REG` clears the OE bit if it is set (see [Table 19-33](#) for the UART mode interrupts).

#### 19.4.4.1.3.6 Overrun During Receive

Overrun during receive occurs if the RX state-machine tries to write data into the RX FIFO when it is already full. When overrun occurs, the device interrupts the MPU with `UARTi.IIR_REG[5:1] IT_TYPE = 0x3` (receiver line status error) and discards the remaining portion of the frame.

Overrun also causes an internal flag to be set, which disables further reception. Before the next frame can be received, the system (MPU) must:

- Reset the RX FIFO
- Read the `UARTi.RESUME_REG` register (which clears the internal flag)

#### 19.4.4.1.3.7 Time-Out and Break Conditions

##### 19.4.4.1.3.7.1 Time-Out Counter

An RX idle condition is detected when the receiver line (`uarti_rx`) is high for a time equivalent to  $4 \times$  programmed word length + 12 bits. `uarti_rx` is sampled midway through each bit.

For sleep mode, the counter is reset when there is activity on `uarti_rx`.

For the time-out interrupt, the counter counts only when there is data in the RX FIFO, and the count is reset when there is activity on `uarti_rx` or when the `UARTi.RHR_REG` is read.

##### 19.4.4.1.3.7.2 Break Condition

When a break condition occurs, `uarti_tx` is pulled low. A break condition is activated by setting the `UARTi.LCR_REG[6] BREAK_EN` bit. The break condition is not aligned on word stream (that is, a break condition can occur in the middle of a character). The only way to send a break condition on a full character is as follows:

1. Reset the transmit FIFO (if enabled).
2. Wait for the transmit shift register to empty (`UARTi.LSR_REG[6] TX_SR_E = 1`).
3. Take a guard time according to stop-bit definition.
4. Set the `BREAK_EN` bit to 1.

The break condition is asserted while the `BREAK_EN` bit is set to 1.

The time-out counter and break condition apply only to UART modem operation and not to IrDA/CIR mode operation.

#### 19.4.4.1.4 UART Mode Interrupt Management

The UART mode includes seven possible interrupts prioritized to six levels.

When an interrupt is generated, the interrupt identification register (UART*i*.[IIR\\_REG](#)) sets the UART*i*.[IIR\\_REG\[0\]](#) IT\_PENDING bit to 0 to indicate that an interrupt is pending, and provides the type of interrupt through UART*i*.[IIR\\_REG\[5:1\]](#). [Table 19-33](#) summarizes the interrupt control functions.

**Table 19-33. UART Mode Interrupts**

| <a href="#">IIR_REG[5:0]</a> | Priority Level | Interrupt Type                             | Interrupt Source                                                      | Interrupt Reset Method                                                                                        |
|------------------------------|----------------|--------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| 000001                       | None           | None                                       | None                                                                  | None                                                                                                          |
| 000110                       | 1              | Receiver line status                       | OE, FE, PE, or BI errors occur in characters in the RX FIFO.          | FE, PE, BI: Read <a href="#">RHR_REG</a> . OE: Read <a href="#">LSR_REG</a> .                                 |
| 001100                       | 2              | RX time-out                                | Stale data in RX FIFO                                                 | Read <a href="#">RHR_REG</a> .                                                                                |
| 000100                       | 2              | RHR interrupt                              | DRDY (data ready) (FIFO disable)                                      | Read <a href="#">RHR_REG</a> until interrupt condition disappears.                                            |
|                              |                |                                            | RX FIFO above trigger level (FIFO enable)                             |                                                                                                               |
| 000010                       | 3              | THR interrupt                              | TFE ( <a href="#">THR_REG</a> empty) (FIFO disable)                   | Write to <a href="#">THR_REG</a> until interrupt condition disappears.                                        |
|                              |                |                                            | TX FIFO below trigger level (FIFO enable)                             |                                                                                                               |
| 000000                       | 4              | Modem status                               | See the <a href="#">MSR_REG</a> register.                             | Read <a href="#">MSR_REG</a> .                                                                                |
| 010000                       | 5              | XOFF interrupt/special character interrupt | Receive XOFF characters/special character                             | Receive XON character(s), if XOFF interrupt/read of <a href="#">IIR_REG</a> , if special character interrupt. |
| 100000                       | 6              | CTS, RTS                                   | RTS pin or CTS pin change state from active (low) to inactive (high). | Read <a href="#">IIR_REG</a> .                                                                                |

For the receiver-line status interrupt, the RX\_FIFO\_STS bit (UART*i*.[LSR\\_REG\[7\]](#)) generates the interrupt.

For the XOFF interrupt, if an XOFF flow character detection caused the interrupt, the interrupt is cleared by an XON flow character detection. If special character detection caused the interrupt, the interrupt is cleared by a read of the UART*i*.[IIR\\_REG](#) register.

#### 19.4.4.1.4.1 Wake-Up Interrupt

Wake-up interrupt is a special interrupt that is not designed the same way as other interrupts. This interrupt is enabled when the UART*i*.[SCR\\_REG\[4\]](#) RX\_CTS\_WU\_EN bit is set to 1. The UART*i*.[IIR\\_REG](#) register is not modified when it occurs; the UART3.[SSR\\_REG\[1\]](#) RX\_CTS\_WU\_STS bit must be checked to detect a wake-up event.

When a wake-up interrupt occurs, the only way to clear it is to reset the UART*i*.[SCR\\_REG\[4\]](#) RX\_CTS\_WU\_EN bit. This bit must be re-enabled (set to 1) after the current wake-up interrupt event is processed to detect the next incoming wake-up event.

#### 19.4.4.2 IrDA Mode (UART3 Only)

##### 19.4.4.2.1 IrDA Clock Generation: Baud Generator

The IrDA function contains a programmable baud generator and a set of fixed dividers that divide the 48-MHz clock input down to the expected baud rate.

[Figure 19-32](#) shows the baud rate generator and associated controls.

**Figure 19-32. Baud Rate Generator**


uart-033

**CAUTION**

Before trying to initialize or modify clock parameter controls (UARTi.DLH\_REG, UARTi.DLL\_REG), it is mandatory to set MODE\_SELECT=DISABLE (UARTi.MDR1\_REG[2:0]=0x7).

Failure to observe this rule can result in unpredictable module behavior.

#### 19.4.4.2.2 Choosing the Appropriate Divisor Value

- SIR mode: Divisor value = Operating frequency/(16x baud rate)
- MIR mode: Divisor value = Operating frequency/(41x/42x baud rate)
- FIR mode: Divisor value = None

[Table 19-34](#) lists the IrDA baud rate settings.

**Table 19-34. IrDA Baud Rates Settings**

| Baud Rate  | IR Mode | Baud Multiple | Encoding | DLH, DLL (Decimal) | Actual Baud Rate | Error (%)\$ | Source Jitter (%) | Pulse duration |
|------------|---------|---------------|----------|--------------------|------------------|-------------|-------------------|----------------|
| 2.4 Kbps   | SIR     | 16x           | 3/16     | 1250               | 2.4 Kbps         | 0           | 0                 | 78.1 $\mu$ s   |
| 9.6 Kbps   | SIR     | 16x           | 3/16     | 312                | 9.6153 Kbps      | +0.16       | 0                 | 19.5 $\mu$ s   |
| 19.2 Kbps  | SIR     | 16x           | 3/16     | 156                | 19.231 Kbps      | +0.16       | 0                 | 9.75 $\mu$ s   |
| 38.4 Kbps  | SIR     | 16x           | 3/16     | 78                 | 38.462 Kbps      | +0.16       | 0                 | 4.87 $\mu$ s   |
| 57.6 Kbps  | SIR     | 16x           | 3/16     | 52                 | 57.692 Kbps      | +0.16       | 0                 | 3.25 $\mu$ s   |
| 115.2 Kbps | SIR     | 16x           | 3/16     | 26                 | 115.38 Kbps      | +0.16       | 0                 | 1.62 $\mu$ s   |

**Table 19-34. IrDA Baud Rates Settings (continued)**

| Baud Rate  | IR Mode | Baud Multiple | Encoding | DLH, DLL (Decimal) | Actual Baud Rate           | Error (%\$) | Source Jitter (%) | Pulse duration |
|------------|---------|---------------|----------|--------------------|----------------------------|-------------|-------------------|----------------|
| 0.576 Mbps | MIR     | 41x/42x       | 1/4      | 2                  | 0.5756 Mbps <sup>(1)</sup> | 0           | +1.63/- 0.80      | 416 ns         |
| 1.152 Mbps | MIR     | 41x/42x       | 1/4      | 1                  | 1.1511 Mbps <sup>(1)</sup> | 0           | +1.63/- 0.80      | 208 ns         |
| 4 Mbps     | FIR     | 6x            | 4 PPM    | -                  | 4 Mbps                     | 0           | 0                 | 125 ns         |

<sup>(1)</sup> Average value

---

**NOTE:** Baud rate error and source jitter table values do not include 48-MHz reference clock error and jitter.

---

#### 19.4.4.2.3 IrDA Data Formatting

The methods described in this section apply to all IrDA modes (SIR, MIR, and FIR).

##### 19.4.4.2.3.1 IRRX Polarity Control

The UART3.[MDR2\\_REG](#)[6] IRRXINVERT bit provides the flexibility to invert the uart3\_rx\_irrx pin in the UART module to ensure that the protocol at the output of the transceiver module has the same polarity at module level. By default, the uart3\_rx\_irrx pin is inverted because most transceivers invert the IR receive pin.

##### 19.4.4.2.3.2 IrDA Reception Control

Data can be transferred both ways by the module, but when the device is transmitting, the IR RX circuitry is automatically disabled by hardware.

Operation of the uart3\_rx\_irrx input can be disabled by the UART3.[ACREG\\_REG](#)[5] DIS\_IR\_RX bit.

##### 19.4.4.2.3.3 IR Address Checking

In all IR modes, when address checking is enabled, only frames intended for the device are written to the RX FIFO. This restriction avoids receiving frames not meant for this device in a multipoint infrared environment. It is possible to program two frame addresses that the UART IrDA receives with the UART3.[XON1\\_ADDR1\\_REG](#)[7:0] XON\_WORD1 and UART3.[XON2\\_ADDR2\\_REG](#)[7:0] XON\_WORD2 fields.

Setting the [EFR\\_REG](#)[0] bit to 1 selects address1 checking. Setting the [EFR\\_REG](#)[1] bit to 1 selects address2 checking. Setting the [EFR\\_REG](#)[1:0] bit to 0 disables all address checking operations. If both bits are set, the incoming frame is checked for both private and public addresses.

If address checking is disabled, all received frames write to the reception FIFO.

##### 19.4.4.2.3.4 Frame Closing

A transmission frame can be correctly terminated in two ways:

- Frame-length method: The frame-length method is selected by setting the UART3.[MDR1\\_REG](#)[7] FRAME\_END\_MODE bit to 0. The MPU writes the frame-length value to the UART3.[TXFLH\\_REG](#) and UART3.[TXFLL\\_REG](#) registers. The device automatically attaches end flags to the frame when the number of bytes transmitted equals the frame-length value.
- Set-EOT bit method: The set-EOT bit method is selected by setting the FRAME\_END\_MODE bit to 1. The MPU writes 1 to the UART3.[ACREG\\_REG](#)[0] EOT bit just before it writes the last byte to the TX FIFO. When the MPU writes the last byte to the TX FIFO, the device internally sets the tag bit for that character in the TX FIFO. As the TX state-machine reads data from the TX FIFO, it uses this tag-bit information to attach end flags and correctly terminate the frame.

#### 19.4.4.2.3.5 Store and Controlled Transmission

In store and controlled transmission (SCT) mode, the MPU starts writing data to the TX FIFO. Then, after writing a part of a frame (for a bigger frame) or a whole frame (a small frame; that is, a supervisory frame), the MPU writes 1 to the UART3.[ACREG\\_REG\[2\]](#) SCTX\_EN bit (deferred TX start) to start transmission.

SCT mode is enabled by setting the UART3.[MDR1\\_REG\[5\]](#) SCT bit to 1. This transmission method is different from the normal mode, in which data transmission starts immediately after data is written to the TX FIFO. SCT mode is useful for sending short frames without TX underrun.

#### 19.4.4.2.3.6 Error Detection

When the UART3.[LSR\\_REG](#) register is read, the UART3.[LSR\\_REG\[4:2\]](#) field reflects the error bits [FL, CRC, ABORT] of the frame at the top of the STATUS FIFO (the next frame status to be read).

The error is triggered by an interrupt (see [Table 19-35](#) for IrDA mode interrupts). STATUS FIFO must be read until empty (a maximum of eight reads is required).

#### 19.4.4.2.3.7 Underrun During Transmission

Underrun during transmission occurs when the TX FIFO is empty before the end of the frame is transmitted. When underrun occurs, the device closes the frame with end flags but attaches an incorrect CRC value. The receiving device detects a CRC error and discards the frame; it can then ask for a retransmission.

Underrun also causes an internal flag to be set, which disables additional transmissions. Before the next frame can be transmitted, the system (MPU) must:

- Reset the TX FIFO.
- Read the UART3.[RESUME\\_REG](#) register (which clears the internal flag).

This functionality can be disabled by the UART3.[ACREG\\_REG\[4\]](#) DIS\_TX\_UNDERRUN bit, compensated by the extension of the stop bit in transmission if the TX FIFO is empty.

#### 19.4.4.2.3.8 Overrun During Receive

Overrun during receive for the IrDA mode has the same functionality as that for the UART mode (see [Section 19.4.4.1.3.6, Overrun During Receive](#)).

#### 19.4.4.2.3.9 Status FIFO

In IrDA modes, a status FIFO records the received frame status. When a complete frame is received, the length of the frame and the error bits associated with the frame are written to the status FIFO.

Reading UART3.[SFREGH\\_REG\[3:0\]](#) (MSB) and UART3.[SFREGL\\_REG\[3:0\]](#) (LSB) obtains the frame length. The frame error status is read in the UART3.[SFLSR\\_REG](#) register. Reading the UART3.[SFLSR\\_REG](#) register increments the status FIFO read pointer. The status FIFO is eight entries deep and, therefore, can hold the status of eight frames.

The MPU uses the frame-length information to locate the frame boundary in the received frame data. The MPU can screen bad frames using the error status information and can later request the sender to resend only the bad frames.

This status FIFO can be used effectively in DMA mode because the MPU must be interrupted only when the programmed status FIFO trigger level is reached, not each time a frame is received.

#### 19.4.4.2.4 SIR Mode DATA Formatting

This section provides specific instructions for SIR mode programming.

##### 19.4.4.2.4.1 Abort Sequence

When the transmitter prematurely closes a frame, it sends the following sequence to abort: 0x7DC1. The abort pattern closes the frame without a CRC field or an ending flag.

A transmission frame can be aborted by setting the UART3.[ACREG\\_REG\[1\]](#) ABORT\_EN bit to 1.

When this bit is set to 1, 0x7D and 0xC1 are transmitted and the frame is not terminated with CRC or stop flags.

The receiver treats a frame as an aborted frame when a 0x7D character followed immediately by a 0xC1 character is received without transparency.

#### CAUTION

When the transmit FIFO is not empty and the UART3.[MDR1\\_REG\[5\]](#) SCT bit is set to 1, the UART IrDA starts a new transfer with data of a previous frame when the abort frame is sent. Therefore, TX FIFO must be reset before sending an abort frame.

#### **19.4.4.2.4.2 Pulse Shaping**

The SIR mode supports both the 3/16th or the 1.6- $\mu$ s pulse duration methods in receive and transmit. The UART3.[ACREG\\_REG\[7\]](#) PULSE\_TYPE bit selects the pulse width method in the transmit mode.

#### **19.4.4.2.4.3 SIR Free Format Programming**

The SIR FF mode is selected by setting the module in the UART mode (UART3.[MDR1\\_REG\[2:0\]](#) MODE\_SELECT = 0x0) and the UART3.[MDR2\\_REG\[3\]](#) UART\_PULSE bit to 1 to allow pulse shaping.

Because the bit format remains the same, some UART mode configuration registers must be set at specific values:

- UART3.[LCR\\_REG\[1:0\]](#) CHAR\_LENGTH field = 0x3 (8 data bits)
- UART3.[LCR\\_REG\[2\]](#) NB\_STOP bit = 0x0 (1 stop-bit)
- UART3.[LCR\\_REG\[3\]](#) PARITY\_EN bit = 0x0 (no parity)

The UART mode interrupts are used for the SIR FF mode, but many of them are not relevant (XOFF, RTS, CTS, modem status register, etc.).

#### **19.4.4.2.5 MIR and FIR Mode Data Formatting**

This section describes common instructions for FIR and MIR mode programming.

At the end of a frame reception, the MPU reads the line status register (UART3.[LSR\\_REG](#)) to detect possible errors in the received frame.

When the UART3.[MDR1\\_REG\[6\]](#) SIP\_MODE bit is set to 1, the TX state-machine always sends one SIP at the end of a transmission frame. However, when the SIP\_MODE bit is set to 0, SIP transmission depends on the UART3.[ACREG\\_REG\[3\]](#) SEND\_SIP bit.

The system (MPU) can set the SEND\_SIP bit at least once every 500 ms. The advantage of this approach over the default approach is that the TX state-machine does not have to send the SIP at the end of each frame, which can reduce the overhead required.

#### **19.4.4.2.6 IrDA Mode Interrupt Management**

##### **19.4.4.2.6.1 IrDA Interrupts**

The IrDA function generates interrupts. All interrupts can be enabled/disabled by writing to the appropriate bit in the interrupt enable register (UART3.[IER\\_REG](#)). The interrupt status of the device can be checked at any time by reading the interrupt identification register (UART3.[IIR\\_REG](#)).

The UART, IrDA, and CIR modes have different interrupts in the UART/IrDA/CIR module and, therefore, different UART3.[IER\\_REG](#) and UART3.[IIR\\_REG](#) mappings, depending on the selected mode.

The IrDA modes have eight possible interrupts (see [Table 19-35](#)). The interrupt line is activated when any of the eight interrupts is generated (there is no priority).

**Table 19-35. IrDA Mode Interrupts**

| IIR_REG Bit | Interrupt Type                 | Interrupt Source                                                                                                                                                                                      | Interrupt Reset Method                                                 |
|-------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|
| 0           | RHR interrupt                  | DRDY (data ready) (FIFO disable)<br>RX FIFO above trigger level (FIFO enable)                                                                                                                         | Read RHR_REG until interrupt condition disappears.                     |
| 1           | THR interrupt                  | TFE (THR_REG empty) (FIFO disable)<br>TX FIFO below trigger level (FIFO enable)                                                                                                                       | Write to THR_REG until interrupt condition disappears.                 |
| 2           | Last byte in RX FIFO           | Last byte of frame in RX FIFO is available to be read at the RHR port.                                                                                                                                | Read RHR_REG.                                                          |
| 3           | RX overrun                     | Write to RHR_REG when RX FIFO full.                                                                                                                                                                   | Read RESUME_REG register.                                              |
| 4           | Status FIFO interrupt          | Status FIFO triggers level reached.                                                                                                                                                                   | Read STATUS FIFO.                                                      |
| 5           | TX status                      | 1. THR_REG empty before EOF sent. Last bit of transmission of the IrDA frame occurred, but with an underrun error.<br>OR<br>2. Transmission of the last bit of the IrDA frame completed successfully. | 1. Read RESUME_REG register.<br>OR<br>2. Read IIR_REG.                 |
| 6           | Receiver line status interrupt | CRC, ABORT, or frame-length error is written into STATUS FIFO.                                                                                                                                        | Read STATUS FIFO (read until empty - maximum of eight reads required). |
| 7           | Received EOF                   | Received end-of-frame.                                                                                                                                                                                | Read IIR_REG.                                                          |

#### 19.4.4.2.6.2 Wake-Up Interrupts

The wake-up interrupt for the IrDA mode has the same functionality as that for the UART mode (see Section 19.4.4.1.4.1, *Wake-Up Interrupt*).

#### CAUTION

Wake-up interface implementation in this mode is based on the UARTi\_SIDLEACK low-to-high transition instead of the UARTi\_SIDLEACK state.

This does not ensure wake-up event generation as expected when configured in smart-idle mode and the system wakes up for a short period.

#### 19.4.4.3 CIR Mode (UART3 Only)

##### 19.4.4.3.1 CIR Mode Clock Generation

Depending on the encoding method (variable pulse distance/biphase), the MPU must develop a data structure that combines 1 and 0 with a t period to encode the complete frame to transmit. This can then be transmitted to the infrared output with a modulation method, as shown in Figure 19-33.

**Figure 19-33. CIR Mode Block Components**

uart-034

Based on the requested modulation frequency, the **UART3.CFPS\_REG** register must be set with the correct dividing value to provide the more accurate pulse frequency:

$$\text{Dividing value} = (\text{FCLK}/12)/\text{MODfreq}$$

Where:

FCLK = System clock frequency (48 MHz)

12 = Real value of baud multiple

MODfreq = Effective frequency of the modulation (MHz)

Example: For a targeted modulation frequency of 36 kHz, the **CFPS\_REG** value must be set to 111 (decimal), which provides a modulation frequency of 36.04 kHz.

---

**NOTE:** The **UART3.CFPS\_REG** register starts with a reset value of 105 (decimal), which translates to a frequency of 38.1 kHz.

---

The duty cycle of these pulses is user-defined by the pulse duty register bits in the **UART3.MDR2\_REG** configuration register. **Table 19-36** shows the duty cycle.

**Table 19-36. Duty Cycle**

| MDR2_REG[5:4] | Duty Cycle (High Level) |
|---------------|-------------------------|
| 00            | 1/4                     |
| 01            | 1/3                     |
| 10            | 5/12                    |
| 11            | 1/2                     |

#### 19.4.4.3.2 CIR Data Formatting

The methods described in this section apply to all CIR modes.

##### 19.4.4.3.2.1 IRRX Polarity Control

The IRRX polarity control for the CIR mode has the same functionality as that for the IrDA mode (see Section 19.4.4.2.3.1, *IRRX Polarity Control*).

##### 19.4.4.3.2.2 CIR Transmission

In transmission, the MPU software must exercise an element of real-time control to transmit data packets, each of which must be emitted at a constant delay from the start bits of each individual packet. Thus, when sending a series of packets, the packet-to-packet delay must respect a specific delay. Two methods can be used to control this delay:

- Filling the TX FIFO with a number of zero bits that are transmitted with a  $t$  period
- Using an external system timer to control the delay either between each start-of-frame or between the end of a frame and the start of the next one. This can be performed by:
  - Controlling the start of the frame using the UART3.MDR1\_REG[5] SCT bit and UART3.ACREG\_REG[2] SCTX\_EN bit, depending on the timer status
  - Using the UART3.IIR\_REG[5] TX\_STATUS\_IT interrupt to preload the next frame in the TX FIFO and to control the start of the timer (in case of control delay between the end of a frame and the start of the next frame).

##### 19.4.4.3.2.3 CIR Reception

There are two methods of stopping reception:

- The MPU can disable the reception by setting the UART3.ACREG\_REG[5] DIS\_IR\_RX bit to 1 when it detects that the reception is complete because of the large number of 0s received. To receive a new frame, the DIS\_IR\_RX bit must be set to 0.
- The reception stops automatically, depending on the value set in the BOF-length register (the UART3.EBLR\_REG[7:0] EBLR field). If the value set in the UART3.EBLR\_REG[7:0] EBLR field is different from 0, this feature is enabled and counts the number of bits received at 0.

When the counter achieves the value defined in the EBLR\_REG register, the reception automatically stops and the UART3.IIR\_REG[2] RX\_STOP\_IT bit is set. When 1 is detected on the uart3.rx\_irrx pin, the reception is automatically enabled.

**CAUTION**

If the UART3.IER\_REG[2] RX\_STOP\_IT interrupt occurs before a byte boundary, the remaining bits of the last byte are filled with zeros and then passed into the RX FIFO.

### 19.4.4.3.3 CIR Mode Interrupt Management

#### 19.4.4.3.3.1 CIR Interrupts

The CIR function generates interrupts that can be enabled/disabled by writing to the appropriate bit in the interrupt enable register (UART3.[IER\\_REG](#)). The interrupt status of the device can be checked at any time by reading the interrupt identification register (UART3.[IIR\\_REG](#)).

The UART, IrDA, and CIR modes have different interrupts in the UART/IrDA/CIR module and, therefore, different UART3.[IER\\_REG](#) and UART3.[IIR\\_REG](#) mappings, depending on the selected mode.

[Table 19-37](#) lists the interrupt modes to be maintained. In CIR mode, the sole purpose of the UART3.[IIR\\_REG](#)[5] bit is to indicate that the last bit of infrared data was passed to the uart3\_cts\_rctx pin.

**Table 19-37. CIR Mode Interrupts**

| IIR_REG Bit Number | Interrupt Type   | Interrupt Source                                                                                     | Interrupt Reset Method                                                 |
|--------------------|------------------|------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|
| 0                  | N/A for CIR mode | N/A for CIR mode                                                                                     | N/A for CIR mode                                                       |
| 1                  | THR interrupt    | TFE ( <a href="#">THR_REG</a> empty) (FIFO disable)<br><br>TX FIFO below trigger level (FIFO enable) | Write to <a href="#">THR_REG</a> until interrupt condition disappears. |
| 2                  | N/A for CIR mode | N/A for CIR mode                                                                                     | N/A for CIR mode                                                       |
| 3                  | N/A for CIR mode | N/A for CIR mode                                                                                     | N/A for CIR mode                                                       |
| 4                  | N/A for CIR mode | N/A for CIR mode                                                                                     | N/A for CIR mode                                                       |
| 5                  | TX status        | Transmission of the last bit of the frame is completed successfully.                                 | Read <a href="#">IIR_REG</a> .                                         |
| 6                  | N/A for CIR mode | N/A for CIR mode                                                                                     | N/A for CIR mode                                                       |
| 7                  | N/A for CIR mode | N/A for CIR mode                                                                                     | N/A for CIR mode                                                       |

#### 19.4.4.3.3.2 Wake-Up Interrupts

The wake-up interrupt for the IrDA mode has the same functionality as that for the UART mode (see [Section 19.4.4.1.4.1, Wake-Up Interrupt](#)).

### 19.4.5 Power Management

#### 19.4.5.1 UART Mode Power Management

##### 19.4.5.1.1 Module Power Saving

In UART modes, sleep mode is enabled by setting the [UART\*i\*.IER\\_REG](#)[4] SLEEP\_MODE bit to 1 (when the [UART\*i\*.EFR\\_REG](#)[4] ENHANCED\_EN bit is set to 1).

Sleep mode is entered when all the following conditions exist:

- The serial data input line, [uart\*i\*\\_rx](#), is idle.
- The TX FIFO and TX shift register are empty.
- The RX FIFO is empty.
- No interrupts are pending except THR interrupts.

Sleep mode is a good way to lower power consumption of the UART, but this state can be achieved only when the UART is set in modem mode. Therefore, even if the UART has no functional key role, it must be initialized in a functional mode to take advantage of sleep mode.

In sleep mode, the module clock and baud rate clock are stopped internally. Because most registers are clocked using these clocks, this greatly reduces power consumption. The module wakes up when a change is detected on the [uart\*i\*\\_rx](#) line, when data is written to the TX FIFO, and when there is a change in the state of the modem input pins.

An interrupt can be generated on a wake-up event by setting the UARTi.[SCR\\_REG\[4\]](#) RX\_CTS\_WU\_EN bit to 1. See [Section 19.4.4.1.4.1, Wake-Up Interrupt](#), to understand how to manage the interrupt.

---

**NOTE:** There must be no writing to the divisor latches, UARTi.[DLL\\_REG](#) and UARTi.[DLH\\_REG](#), to set the baud clock, BCLK, while in sleep mode. It is advisable to disable sleep mode using the UARTi.[IER\\_REG\[4\]](#) SLEEP\_MODE bit before writing to the UARTi.[DLL\\_REG](#) register or the UARTi.[DLH\\_REG](#) register.

---

#### 19.4.5.1.2 System Power Saving

Sleep and auto-idle modes are embedded power-saving features. At the system level, power-reduction techniques can be applied by shutting down certain internal clock and power domains of the device.

The UART supports an idle req/idle ack handshaking protocol. This protocol is used at the system level to shut down clocks of the UART in a clean and controlled manner and to switch the UART from interrupt-generation mode to wake-up generation mode for unmasked events (see the UARTi.[SYSC\\_REG\[2\]](#) ENAWAKEUP bit and the UARTi.[WER\\_REG](#) register).

For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

#### 19.4.5.2 IrDA Mode Power Management (UART3 Only)

##### 19.4.5.2.1 Module Power Saving

In IrDA modes, sleep mode is enabled by setting the UART3.MDR[3] IR\_SLEEP bit to 1.

Sleep mode is entered when all the following conditions exist:

- The serial data input line, uart3.rx\_irrx, is idle.
- The TX FIFO and TX shift register are empty.
- The RX FIFO is empty.
- No interrupts are pending except THR interrupts.

The module wakes up when a change is detected on the uart3\_rx\_irrx line or when data is written to the TX FIFO.

##### 19.4.5.2.2 System Power Saving

System power saving for the IrDA mode has the same functionality as that for the UART mode (see [Section 19.4.5.1.2, System Power Saving](#)).

#### 19.4.5.3 CIR Mode Power Management (UART3 Only)

##### 19.4.5.3.1 Module Power Saving

Module power saving for the CIR mode has the same functionality as that for the IrDA mode (see [Section 19.4.5.2.1, Module Power Saving](#)).

##### 19.4.5.3.2 System Power Saving

System power saving for the CIR mode has the same functionality as that for the UART mode (see [Section 19.4.5.2.2, System Power Saving](#)).

## 19.5 UART/IrDA/CIR Basic Programming Model

### 19.5.1 UART Programming Model

#### 19.5.1.1 Quick start

This section outlines the procedure for operating the UART module with FIFO and DMA or interrupts. This 3-part procedure ensures the quick start of the UART module. It does not cover every UART module feature.

The first programming model covers software reset of the module. The second programming model deals with FIFO and DMA configuration. The last programming model deals with protocol, baud rate and interrupt configuration.

---

**NOTE:** Each programming model can be used independently of the other two; for instance, reconfiguring the FIFOs and DMA settings only.

Each programming model can be executed starting from any UART register access mode (register modes, submodes, and other register dependencies). However, if the UART register access mode is known before executing the programming model, some steps that enable or restore register access are optional. For more information see [Section 19.4.3.1, Register Access Modes](#).

---

#### 19.5.1.1.1 Software Reset

To clear the UART registers, perform the following steps:

1. Initiate a software reset:

Set the `UARTi.SYSC_REG[1]` SOFTRESET bit to 1.

2. Wait for the end of the reset operation:

Poll the `UARTi.SYSS_REG[0]` RESETDONE bit until it equals 1.

#### 19.5.1.1.2 FIFOs and DMA Settings

To enable and configure the receive and transmit FIFOs and program the DMA mode, perform the following steps:

1. Switch to register configuration mode B to access the `UARTi.EFR_REG` register:

(a) Save the current `UARTi.LCR_REG` value.

(b) Set `UARTi.LCR_REG` to 0x00BF.

2. Enable register submode TCR\_TLR to access `UARTi.TLR_REG` (part 1 of 2):

(a) Save the `UARTi.EFR_REG[4]` ENHANCED\_EN value.

(b) Set the `UARTi.EFR_REG[4]` ENHANCED\_EN bit to 1.

3. Switch to register configuration mode A to access the `UARTi.MCR_REG` register:

Set `UARTi.LCR_REG` to 0x0080.

4. Enable register submode TCR\_TLR to access `UARTi.TLR_REG` (part 2 of 2):

(a) Save the `UARTi.MCR_REG[6]` TCR\_TLR value.

(b) Set the `UARTi.MCR_REG[6]` TCR\_TLR bit to 1.

5. Enable FIFO, load the new FIFO triggers (part 1 of 3) and the new DMA mode (part 1 of 2):

Set the following bits to the desired values:

- `UARTi.FCR_REG[7:6]` RX\_FIFO\_TRIG

- `UARTi.FCR_REG[5:4]` TX\_FIFO\_TRIG

- `UARTi.FCR_REG[3]` DMA\_MODE

- `UARTi.FCR_REG[0]` FIFO\_ENABLE (0: Disable the FIFO/1: Enable the FIFO)

**NOTE:** The `UARTi.FCR_REG` register is not readable.

6. Switch to register configuration mode B to access the `UARTi.EFR_REG` register:  
Set `UARTi.LCR_REG` to 0x00BF.
7. Load the new FIFO triggers (part 2 of 3):  
Set the following bits to the desired values:
  - `UARTi.TLR_REG[7:4]` RX\_FIFO\_TRIG\_DMA
  - `UARTi.TLR_REG[3:0]` TX\_FIFO\_TRIG\_DMA
8. Load the new FIFO triggers (part 3 of 3) and the new DMA mode (part 2 of 2):  
Set the following bits to the desired values:
  - `UARTi.SCR_REG[7]` RX\_TRIG\_GRANU1
  - `UARTi.SCR_REG[6]` TX\_TRIG\_GRANU1
  - `UARTi.SCR_REG[2:1]` DMA\_MODE\_2
  - `UARTi.SCR_REG[0]` DMA\_MODE\_CTL
9. Restore the `UARTi.EFR_REG[4]` ENHANCED\_EN value saved in Step 2a.
10. Switch to register configuration mode A to access the `UARTi.MCR_REG` register:  
Set `UARTi.LCR_REG` to 0x0080.
11. Restore the `UARTi.MCR_REG[6]` TCR\_TLR value saved in Step 4a.
12. Restore the `UARTi.LCR_REG` value saved in Step 1a.

Triggers are used to generate interrupt and DMA requests. See [Section 19.4.2.1.1, Transmit FIFO Trigger](#), to choose the following values:

- `UARTi.FCR_REG[5:4]` TX\_FIFO\_TRIG
- `UARTi.TLR_REG[3:0]` TX\_FIFO\_TRIG\_DMA
- `UARTi.SCR_REG[6]` TX\_TRIG\_GRANU1

Triggers are used to generate interrupt and DMA requests. See [Section 19.4.2.1.2, Receive FIFO Trigger](#), to choose the following values:

- `UARTi.FCR_REG[7:6]` RX\_FIFO\_TRIG
- `UARTi.TLR_REG[7:4]` RX\_FIFO\_TRIG\_DMA
- `UARTi.SCR_REG[7]` RX\_TRIG\_GRANU1

DMA mode enables the different DMA requests. See [Section 19.4.2.4, FIFO DMA Mode Operation](#), to choose the following values:

- `UARTi.FCR_REG[3]` DMA\_MODE
- `UARTi.SCR_REG[2:1]` DMA\_MODE\_2
- `UARTi.SCR_REG[0]` DMA\_MODE\_CTL

### 19.5.1.1.3 Protocol, Baud Rate, and Interrupt Settings

To program the protocol, baud rate and interrupt settings, perform the following steps:

1. Disable UART to access `UARTi.DLL_REG` and `UARTi.DLH_REG`:  
Set `UARTi.MDR1_REG[2:0]` MODE\_SELECT to 0x7.
2. Switch to register configuration mode B to access the `UARTi.EFR_REG` register:  
Set `UARTi.LCR_REG` to 0x00BF.
3. Enable access to `UARTi.IER_REG[7:4]`:
  - (a) Save the `UARTi.EFR_REG[4]` ENHANCED\_EN value.
  - (b) Set the `UARTi.EFR_REG[4]` ENHANCED\_EN bit to 1.
4. Switch to register operational mode to access the `UARTi.IER_REG` register:  
Set `UARTi.LCR_REG` to 0x0000.

5. Clear the `UARTi.IER_REG` (`UARTi.IER_REG[4]` SLEEP\_MODE bit to 0 to change `UARTi.DLL_REG` and `UARTi.DLH_REG`). Set `UARTi.IER_REG` to 0x0000.
6. Switch to register configuration mode B to access the `UARTi.DLL_REG` and `UARTi.DLH_REG` registers:  
Set `UARTi.LCR_REG` to 0x00BF.
7. Load the new divisor value:  
Set the `UARTi.DLL_REG[7:0]` CLOCK\_LSB and `UARTi.DLH_REG[5:0]` CLOCK\_MSB fields to the desired value.
8. Switch to register operational mode to access the `UARTi.IER_REG` register:  
Set `UARTi.LCR_REG` to 0x0000.
9. Load the new interrupt configuration.(0: Disable the interrupt/1: Enable the interrupt):  
Set the following bits to the desired values:
  - `UARTi.IER_REG[7]` CTS\_IT
  - `UARTi.IER_REG[6]` RTS\_IT
  - `UARTi.IER_REG[5]` XOFF\_IT
  - `UARTi.IER_REG[4]` SLEEP\_MODE
  - `UARTi.IER_REG[3]` MODEM\_STS\_IT
  - `UARTi.IER_REG[2]` LINE\_STS\_IT
  - `UARTi.IER_REG[1]` THR\_IT
  - `UARTi.IER_REG[0]` RHR\_IT
10. Switch to register configuration mode B to access the `UARTi.EFR_REG` register:  
Set `UARTi.LCR_REG` to 0x00BF.
11. Restore the `UARTi.EFR_REG[4]` ENHANCED\_EN value saved in Step 3a.
12. Load the new protocol formatting (parity, stop bit, char length) and switch to register operational mode:  
Set `UARTi.LCR_REG[7]` DIV\_EN to 0.  
Set `UARTi.LCR_REG[6]` BREAK\_EN to 0.  
Set the following bits to the desired values:
  - `UARTi.LCR_REG[5]` PARITY\_TYPE\_2
  - `UARTi.LCR_REG[4]` PARITY\_TYPE\_1
  - `UARTi.LCR_REG[3]` PARITY\_EN
  - `UARTi.LCR_REG[2]` NB\_STOP
  - `UARTi.LCR_REG[1:0]` CHAR\_LENGTH
13. Load the new UART mode:  
Set `UARTi.MDR1_REG[2:0]` MODE\_SELECT to the desired value.

See [Section 19.4.4.1.2, Choosing the Appropriate Divisor Value](#), to choose the following values:

- `UARTi.DLL_REG[7:0]` CLOCK\_LSB
- `UARTi.DLH_REG[5:0]` CLOCK\_MSB
- `UARTi.MDR1_REG[2:0]` MODE\_SELECT

See [Section 19.4.4.1.3.1, Frame Formatting](#), to choose the following values:

- `UARTi.LCR_REG[5]` PARITY\_TYPE\_2
- `UARTi.LCR_REG[4]` PARITY\_TYPE\_1
- `UARTi.LCR_REG[3]` PARITY\_EN
- `UARTi.LCR_REG[2]` NB\_STOP
- `UARTi.LCR_REG[1:0]` CHAR\_LENGTH

### 19.5.1.2 Hardware and Software Flow Control Configuration

This section outlines the programming steps to enable and configure hardware and software flow control. Hardware and software flow control cannot be used at the same time.

---

**NOTE:** Each programming model can be executed starting from any UART register access mode (register modes, submodes, and other register dependencies). However, if the UART register access mode is known before executing the programming model, some steps that enable or restore register access are optional. For more information, see [Section 19.4.3.1, Register Access Modes](#).

---

#### 19.5.1.2.1 Hardware Flow Control Configuration

To enable and configure hardware flow control, perform the following procedure:

1. Switch to register configuration mode A to access the `UARTi.MCR_REG` register:
  - (a) Save the current `UARTi.LCR_REG`.
  - (b) Set `UARTi.LCR_REG` to 0x0080.
2. Enable register submode TCR\_TLR to access `UARTi.TCR_REG` (part 1 of 2):
  - (a) Save the `UARTi.MCR_REG[6]` TCR\_TLR value.
  - (b) Set `UARTi.MCR_REG[6]` TCR\_TLR = 1.
3. Switch to register configuration mode B to access the `UARTi.EFR_REG` register:  
Set `UARTi.LCR_REG` to 0x00BF.
4. Enable register submode TCR\_TLR to access the `UARTi.TCR_REG` register (part 2 of 2):
  - (a) Save the `UARTi.EFR_REG[4]` ENHANCED\_EN value.
  - (b) Set the `UARTi.EFR_REG[4]` ENHANCED\_EN bit to 1.
5. Load the new start and halt trigger values for hardware flow control:  
Set the following bits to the desired values:
  - `UARTi.TCR_REG[7:4]` AUTO\_RTS\_START
  - `UARTi.TCR_REG[3:0]` AUTO\_RTS\_HALT
6. Enable or disable receive and transmit hardware flow control mode and restore the `UARTi.EFR_REG[4]` ENHANCED\_EN value saved in Step 4a.  
Set the following bits to the desired values:
  - `UARTi.EFR_REG[7]` AUTO\_CTS\_EN (0: Disable/1: Enable)
  - `UARTi.EFR_REG[6]` AUTO\_RTS\_EN (0: Disable/1: Enable)Restore `UARTi.EFR_REG[4]` ENHANCED\_EN to the saved value.
7. Switch to register configuration mode A to access `UARTi.MCR_REG`:  
Set `UARTi.LCR_REG` to 0x0080.
8. Restore the `UARTi.MCR_REG[6]` TCR\_TLR value saved in Step 2a.
9. Restore the `UARTi.LCR_REG` value saved in Step 1a.

See [Section 19.4.4.1.3.2, Hardware Flow Control](#), to choose the following values:

- `UARTi.EFR_REG[7]` AUTO\_CTS\_EN
- `UARTi.EFR_REG[6]` AUTO\_RTS\_EN
- `UARTi.TCR_REG[7:4]` AUTO\_RTS\_START
- `UARTi.TCR_REG[3:0]` AUTO\_RTS\_HALT

#### 19.5.1.2.2 Software Flow Control Configuration

To enable and configure software flow control, perform the following procedure:

1. Switch to register configuration mode B to access the `UARTi.EFR_REG` register.

- (a) Save the current UARTi.[LCR\\_REG](#).
- (b) Set UARTi.[LCR\\_REG](#) to 0x00BF.
2. Enable register submode XOFF to access the UARTi.[XOFF1\\_REG](#) and UARTi.[XOFF2\\_REG](#) registers:
- (a) Save the UARTi.[EFR\\_REG\[4\]](#) ENHANCED\_EN value.
- (b) Set the UARTi.[EFR\\_REG\[4\]](#) ENHANCED\_EN bit to 0.
3. Load the new software flow control characters:
- Set the following bits to the desired values:
- UARTi.[XON1\\_ADDR1\\_REG\[7:0\]](#) XON\_WORD1
  - UARTi.[XON2\\_ADDR2\\_REG\[7:0\]](#) XON\_WORD2
  - UARTi.[XOFF1\\_REG\[7:0\]](#) XOFF\_WORD1
  - UARTi.[XOFF2\\_REG\[7:0\]](#) XOFF\_WORD2
4. Enable access to UARTi.[MCR\\_REG\[7:5\]](#) and enable register submode TCR\_TLR to access UARTi.[TCR\\_REG](#) (part 1 of 2):
- Set the UARTi.[EFR\\_REG\[4\]](#) ENHANCED\_EN bit to 1.
5. Switch to register configuration mode A to access the UARTi.[MCR\\_REG](#) register:
- Set UARTi.[LCR\\_REG](#) to 0x0080.
6. Enable register submode TCR\_TLR to access UARTi.[TCR\\_REG](#) (part 2 of 2) and enable or disable XON any function:
- (a) Save the UARTi.[MCR\\_REG\[6\]](#) TCR\_TLR value.
- (b) Set the UARTi.[MCR\\_REG\[6\]](#) TCR\_TLR to 1.
- Set UARTi.[MCR\\_REG\[5\]](#) XON\_EN to the desired value (0: Disable/1: Enable).
7. Switch to register configuration mode B to access the UARTi.[EFR\\_REG](#) register:
- Set UARTi.[LCR\\_REG](#) to 0x00BF.
8. Load the new start and halt trigger values for software flow control:
- Set the following bits to the desired values:
- UARTi.[TCR\\_REG\[7:4\]](#) AUTO\_RTS\_START
  - UARTi.[TCR\\_REG\[3:0\]](#) AUTO\_RTS\_HALT
9. Enable or disable special char function and load the new software flow control mode and restore the UARTi.[EFR\\_REG\[4\]](#) ENHANCED\_EN value saved in Step 2a:
- Set the following bits to the desired values:
- UARTi.[EFR\\_REG\[5\]](#) SPEC\_CHAR (0: Disable/1: Enable)
  - UARTi.[EFR\\_REG\[3:0\]](#) SW\_FLOW\_CONTROL
- Restore UARTi.[EFR\\_REG\[4\]](#) ENHANCED\_EN to the saved value.
10. Switch to register configuration mode A to access the UARTi.[MCR\\_REG](#) register:
- Set UARTi.[LCR\\_REG](#) to 0x0080.
11. Restore the UARTi.[MCR\\_REG\[6\]](#) TCR\_TLR value saved in Step 6a.
12. Restore the UARTi.[LCR\\_REG](#) value saved in Step 1a.
- See [Section 19.4.4.1.3.3, Software Flow Control](#), to choose the following values:
- UARTi.[EFR\\_REG\[5\]](#) SPEC\_CHAR
  - UARTi.[EFR\\_REG\[3:0\]](#) SW\_FLOW\_CONTROL
  - UARTi.[TCR\\_REG\[7:4\]](#) AUTO\_RTS\_START
  - UARTi.[TCR\\_REG\[3:0\]](#) AUTO\_RTS\_HALT
  - UARTi.[XON1\\_ADDR1\\_REG\[7:0\]](#) XON\_WORD1
  - UARTi.[XON2\\_ADDR2\\_REG\[7:0\]](#) XON\_WORD2
  - UARTi.[XOFF1\\_REG\[7:0\]](#) XOFF\_WORD1
  - UARTi.[XOFF2\\_REG\[7:0\]](#) XOFF\_WORD2

## 19.5.2 IrDA Programming Model (UART3 Only)

### 19.5.2.1 SIR Mode

#### 19.5.2.1.1 Receive

The following programming model explains how to program the module to receive IrDA frame with parity forced to 1, baud rate = 112.5 Kbs, FIFOs disable, 2 stop bits, 8-bit word length.

1. **Disable UART before accessing `UARTi.DLL_REG` and `UARTi.DLH_REG`:**  
Set `UARTi.MDR1_REG[2:0]` MODE\_SELECT to 0x7.
2. **Grant access to `DLL_REG` and `DLH_REG` (`LCR_REG[7]` DIV\_EN = 0x1)**  
`UART3.LCR_REG` = 0x80 (Note: Data format is unaffected by the use and settings of the `UART3.LCR_REG` register in IrDA mode.)
3. **Load the new baud rate (115.2Kbs)**  
`UART3.DLL_REG` = 0x1A  
`UART3.DLH_REG` = 0x00
4. **Set SIR Mode**  
`UART3.MDR1_REG[2:0]` MODE\_SELECT = 0x1
5. **Disable access to `DLL_REG` and `DLH_REG` and switch to register operational mode**  
`UART3.LCR_REG` = 0x00.
6. **Optional: Enable RHR interrupt**  
`UART3.IER_REG[0]` RHR\_IT = 0x1

#### 19.5.2.1.2 Transmit

The following programming model explains how to program the module to transmit IrDA 6 bytes frame with no parity, baud rate = 112.5Kbs, FIFOs disable, 3/16 encoding, 2 stop bits, 7 bits word length

1. **Disable UART before accessing `UARTi.DLL_REG` and `UARTi.DLH_REG`:**  
Set `MDR1_REG[2:0]` MODE\_SELECT = 0x7).
2. **Grant access to `EFR_REG`**  
`UART3.LCR_REG` = 0xBF
3. **Enable the enhanced features (`EFR_REG[4]` ENAHNCED\_EN = 0x1)**  
`UART3.EFR_REG` = 0x10.
4. **Grant access to `DLL_REG` and `DLH_REG` (`LCR_REG[7]` DIV\_EN = 0x1)**  
`UART3.LCR_REG` = 0x80 (Note: Data format is unaffected by the use and settings of the `UART3.LCR_REG` register in IrDA mode.)
5. **Load the new baud rate (115.2Kbs)**  
`UART3.DLL_REG` = 0x1A  
`UART3.DLH_REG` = 0x00
6. **Set SIR Mode (`MDR1_REG[2:0]` MODE\_SELECT = 0x1)**  
`UART3.MDR1_REG` = 0x01.
7. **Disable access to `DLL_REG` and `DLH_REG` and switch to register operational mode**  
`UART3.LCR_REG`  
`UART3.LCR_REG` = 0x00.
8. **Force DTR output to active**  
`UART3.MCR_REG[0]` DTR = 0x1
9. **Optional: Enable THR interrupt**  
`UART3.IER_REG[1]` THR\_IT = 0x1
10. **Set transmit frame length to 6 bytes**  
`UART3.TXFLL_REG` = 0x06
11. **Set 7 starts of frame transmission**  
`UART3.EBLR_REG` = 0x08
12. **Optional: Set SIR pulse width to be 1.6 $\mu$ s**  
`UART3.ACREG_REG[7]` PULSE\_TYPE = 0x1

**13. Load `THR_REG` with the desired data to be transmitted**

### 19.5.2.2 MIR Mode

#### 19.5.2.2.1 Receive

The following programming model explains how to program the module to receive IrDA frame with no parity, baud rate = 1.152Mbs, FIFOs disable

1. **Disable UART before accessing `UARTi.DLL_REG` and `UARTi.DLH_REG`**  
Set `UARTi.MDR1_REG[2:0]` MODE\_SELECT to 0x7.
2. **Grant access to `DLL_REG` and `DLH_REG` (`LCR_REG[7] DIV_EN = 0x1`)**  
`UART3.LCR_REG` = 0x80 (Note: Data format is unaffected by the use and settings of the `UART3.LCR_REG` register in IrDA mode).
3. **Load the new baud rate (1.152 Mbs)**  
`UART3.DLL_REG` = 0x01  
`UART3.DLH_REG` = 0x00.
4. **Set MIR Mode**  
`UART3.MDR1_REG[2:0]` MODE\_SELECT = 0x4
5. **Disable access to `DLL_REG` and `DLH_REG` and switch to register operational mode**  
`UART3.LCR_REG` = 0x00.
6. **Force DTR output to active (`MCR_REG[0] DTR = 0x1`)**  
**Force RTS output to active (`MCR_REG[1] RTS = 0x1`)**  
`UART3.MCR_REG` = 0x3
7. **Optional: Enable RHR interrupt**  
`UART3.IER_REG[0]` RHR\_IT = 0x1

#### 19.5.2.2.2 Transmit

The following programming model explains how to program the module to transmit IrDA 60 bytes frame with no parity, baud rate = 1.152Mbs, FIFOs disable

1. **Disable UART before accessing `UARTi.DLL_REG` and `UARTi.DLH_REG`:**  
Set `UARTi.MDR1_REG[2:0]` MODE\_SELECT to 0x7.
2. **Grant access to `DLL_REG` and `DLH_REG` (`LCR_REG[7] DIV_EN = 0x1`)**  
`UART3.LCR_REG` = 0x80 (Note: Data format is unaffected by the use and settings of the `UART3.LCR_REG` register in IrDA mode.)
3. **Load the new baud rate (1.152 Mbs)**  
`UART3.DLL_REG` = 0x01  
`UART3.DLH_REG` = 0x00
4. **Set MIR Mode**  
`UART3.MDR1_REG[2:0]` MODE\_SELECT = 0x4.
5. **Disable access to `DLL_REG` and `DLH_REG` and switch to register operational mode:**  
`UART3.LCR_REG` = 0x00.
6. **Force DTR output to active**  
`UART3.MCR_REG[0]` DTR = 0x1
7. **Optional: Enable THR interrupt**  
`UART3.IER_REG[1]` THR\_IT = 0x1
8. **Set frame length to 60 bytes**  
`UART3.TXFLL_REG` = 0x3C
9. **Optional: Transmit 8 additional starts of frame (MIR mode requires 2 starts anyway)**  
`UART3.EBLR_REG` = 0x08
10. **SIP will be send at the end of transmission**  
`UART3.ACREG_REG[3]` = 0x1
11. **Load `THR_REG` with the desired data to be transmitted**

### **19.5.2.2.3 FIR Mode**

#### **19.5.2.2.3.1 Receive**

The following programming model explains how to program the module to receive IrDA frame with no parity, baud rate = 4M bits/s, FIFOs enable, 8-bit word length.

1. Disable UART before accessing **UART<sub>i</sub>.DLL\_REG** and **UART<sub>i</sub>.DLH\_REG**: Set **UART<sub>i</sub>.MDR1\_REG[2:0]** **MODE\_SELECT** to 0x7.
2. Grant access to **DLL\_REG** and **DLH\_REG** (**LCR\_REG[7]** DIV\_EN = 0x1 **UART3.LCR\_REG** = 0x80  
(Note: Data format is unaffected by the use and settings of the **UART3.LCR\_REG** register in IrDA mode.)
3. FIFO clear and enable **FCR\_REG** = 0x7 (Tx/Rx FIFO trigger : **FCR\_REG[7:6]** & **FCR\_REG[5:4]**) **LCR\_REG[7]**=0.
4. Set FIR Mode **UART3.MDR1\_REG[2:0]** **MODE\_SELECT** = 0x5.
5. Set frame length **RXFLL\_REG** = 0xA (Data + CRC + STO).
6. Disable access to **DLL\_REG** and **DLH\_REG** and switch to register operational mode **UART3.LCR\_REG[7]** DIV\_EN = 0x0.
7. Optional: Enable RHR interrupt **UART3.IER\_REG[0]** RHR\_IT = 0x1.

#### **19.5.2.2.3.2 Transmit**

The following programming model explains how to program the module to transmit IrDA 4 bytes frame with no parity, baud rate = 4M bits/s, FIFOs enable, 8-bit word length.

1. Disable UART before accessing **UART<sub>i</sub>.DLL\_REG** and **UART<sub>i</sub>.DLH\_REG**: Set **MDR1\_REG[2:0]** **MODE\_SELECT** = 0x7).
2. Grant access to **EFR\_REG** **UART3.LCR\_REG** = 0xBF.
3. Enable the enhanced features (**EFR\_REG[4]** ENAHNCED\_EN = 0x1) **UART3.EFR\_REG** = 0x10.
4. FIFO clear and enable **FCR\_REG** = 0x7 (Tx/Rx FIFO trigger: **FCR\_REG[7:6]** and **FCR\_REG[5:4]**) **LCR\_REG[7]** = 0
5. Set FIR mode and enable auto-SIP mode **MDR1\_REG** = 0x45.
6. Set Frame Length **TXFLL\_REG** = 0x4 **TXFLH\_REG** = 0x0 **RXFLL\_REG** = 0xA (Data + CRC + STO) **RXFLH\_REG** = 0x0.
7. Force DTR output to active **UART3.MCR\_REG[0]** DTR = 0x1.
8. Optional: Enable THR interrupt **UART3.IER\_REG[1]** THR\_IT = 0x1.
9. Load **THR\_REG** with the desired data to be transmitted.

## 19.6 UART/IrDA/CIR Register Manual

### 19.6.1 UART/IrDA/CIR Instance Summary

Table 19-38 shows the base address and address space for the UART/IrDA/CIR module instances.

**Table 19-38. UART/IrDA/CIR Instance Summary**

| Module Name          | Base Address | Size |
|----------------------|--------------|------|
| UART1 <sup>(1)</sup> | 0x4806 A000  | 4KB  |
| UART2 <sup>(1)</sup> | 0x4806 C000  | 4KB  |
| UART3 <sup>(2)</sup> | 0x4902 0000  | 4KB  |
| UART4 <sup>(1)</sup> | 0x4904 2000  | 4KB  |

<sup>(1)</sup> UART only

<sup>(2)</sup> UART, IrDA and CIR

**CAUTION**

The UART\_THR register is limited to 8-bit data accesses; 16- and 32-bit data accesses are not allowed and can corrupt the register content.

### 19.6.2 UART/IrDA/CIR Register Summary

**NOTE:** UART/IrDA/CIR registers access depends on access mode and submode. For more information, see [Section 19.4.3.1, Register Access Modes](#).

**Table 19-39. UART/IrDA/CIR Register Summary Part 1**

| Register Name  | Type | Register Width (Bits) | Address Offset | UART1 Physical Address | UART2 Physical Address | UART3 Physical Address |
|----------------|------|-----------------------|----------------|------------------------|------------------------|------------------------|
| DLL_REG        | RW   | 32                    | 0x000          | 0x4806 A000            | 0x4806 C000            | 0x4902 0000            |
| RHR_REG        | R    | 32                    | 0x000          | 0x4806 A000            | 0x4806 C000            | 0x4902 0000            |
| THR_REG        | W    | 32                    | 0x000          | 0x4806 A000            | 0x4806 C000            | 0x4902 0000            |
| DLH_REG        | RW   | 32                    | 0x004          | 0x4806 A004            | 0x4806 C004            | 0x4902 0004            |
| IER_REG        | RW   | 32                    | 0x004          | 0x4806 A004            | 0x4806 C004            | 0x4902 0004            |
| IIR_REG        | R    | 32                    | 0x008          | 0x4806 A008            | 0x4806 C008            | 0x4902 0008            |
| FCR_REG        | W    | 32                    | 0x008          | 0x4806 A008            | 0x4806 C008            | 0x4902 0008            |
| EFR_REG        | RW   | 32                    | 0x008          | 0x4806 A008            | 0x4806 C008            | 0x4902 0008            |
| LCR_REG        | RW   | 32                    | 0x00C          | 0x4806 A00C            | 0x4806 C00C            | 0x4902 000C            |
| MCR_REG        | RW   | 32                    | 0x010          | 0x4806 A010            | 0x4806 C010            | 0x4902 0010            |
| XON1_ADDR1_REG | RW   | 32                    | 0x010          | 0x4806 A010            | 0x4806 C010            | 0x4902 0010            |
| LSR_REG        | R    | 32                    | 0x014          | 0x4806 A014            | 0x4806 C014            | 0x4902 0014            |
| XON2_ADDR2_REG | RW   | 32                    | 0x014          | 0x4806 A014            | 0x4806 C014            | 0x4902 0014            |
| MSR_REG        | R    | 32                    | 0x018          | 0x4806 A018            | 0x4806 C018            | 0x4902 0018            |
| TCR_REG        | RW   | 32                    | 0x018          | 0x4806 A018            | 0x4806 C018            | 0x4902 0018            |
| XOFF1_REG      | RW   | 32                    | 0x018          | 0x4806 A018            | 0x4806 C018            | 0x4902 0018            |
| SPR_REG        | RW   | 32                    | 0x01C          | 0x4806 A01C            | 0x4806 C01C            | 0x4902 001C            |
| TLR_REG        | RW   | 32                    | 0x01C          | 0x4806 A01C            | 0x4806 C01C            | 0x4902 001C            |
| XOFF2_REG      | RW   | 32                    | 0x01C          | 0x4806 A01C            | 0x4806 C01C            | 0x4902 001C            |
| MDR1_REG       | RW   | 32                    | 0x020          | 0x4806 A020            | 0x4806 C020            | 0x4902 0020            |
| MDR2_REG       | RW   | 32                    | 0x024          | 0x4806 A024            | 0x4806 C024            | 0x4902 0024            |
| SFLSR_REG      | R    | 32                    | 0x028          | N/A                    | N/A                    | 0x4902 0028            |

|                                |    |    |       |             |             |             |
|--------------------------------|----|----|-------|-------------|-------------|-------------|
| <a href="#">TXFLL_REG</a>      | W  | 32 | 0x028 | N/A         | N/A         | 0x4902 0028 |
| <a href="#">RESUME_REG</a>     | R  | 32 | 0x02C | N/A         | N/A         | 0x4902 002C |
| <a href="#">TXFLH_REG</a>      | W  | 32 | 0x02C | N/A         | N/A         | 0x4902 002C |
| <a href="#">SFREGL_REG</a>     | R  | 32 | 0x030 | N/A         | N/A         | 0x4902 0030 |
| <a href="#">RXFLL_REG</a>      | W  | 32 | 0x030 | N/A         | N/A         | 0x4902 0030 |
| <a href="#">SFREGH_REG</a>     | R  | 32 | 0x034 | N/A         | N/A         | 0x4902 0034 |
| <a href="#">RXFLH_REG</a>      | W  | 32 | 0x034 | N/A         | N/A         | 0x4902 0034 |
| <a href="#">UASR_REG</a>       | R  | 32 | 0x038 | 0x4806 A038 | 0x4806 C038 | 0x4902 0038 |
| <a href="#">BLR_REG</a>        | RW | 32 | 0x038 | N/A         | N/A         | 0x4902 0038 |
| <a href="#">ACREG_REG</a>      | RW | 32 | 0x03C | N/A         | N/A         | 0x4902 003C |
| <a href="#">SCR_REG</a>        | RW | 32 | 0x040 | 0x4806 A040 | 0x4806 C040 | 0x4902 0040 |
| <a href="#">SSR_REG</a>        | R  | 32 | 0x044 | 0x4806 A044 | 0x4806 C044 | 0x4902 0044 |
| <a href="#">EBLR_REG</a>       | RW | 32 | 0x048 | N/A         | N/A         | 0x4902 0048 |
| <a href="#">MVR_REG</a>        | R  | 32 | 0x050 | 0x4806 A050 | 0x4806 C050 | 0x4902 0050 |
| <a href="#">SYSC_REG</a>       | RW | 32 | 0x054 | 0x4806 A054 | 0x4806 C054 | 0x4902 0054 |
| <a href="#">SYSS_REG</a>       | R  | 32 | 0x058 | 0x4806 A058 | 0x4806 C058 | 0x4902 0058 |
| <a href="#">WER_REG</a>        | RW | 32 | 0x05C | 0x4806 A05C | 0x4806 C05C | 0x4902 005C |
| <a href="#">CFPS_REG</a>       | RW | 32 | 0x060 | N/A         | N/A         | 0x4902 0060 |
| <a href="#">RXFIFO_LVL_REG</a> | R  | 32 | 0x064 | 0x4806 A064 | 0x4806 C064 | 0x4902 0064 |
| <a href="#">TXFIFO_LVL_REG</a> | R  | 32 | 0x068 | 0x4806 A068 | 0x4806 C068 | 0x4902 0068 |
| <a href="#">IER2_REG</a>       | RW | 32 | 0x06C | 0x4806 A06C | 0x4806 C06C | 0x4902 006C |
| <a href="#">ISR2_REG</a>       | RW | 32 | 0x070 | 0x4806 A070 | 0x4806 C070 | 0x4902 0070 |
| <a href="#">MDR3_REG</a>       | RW | 32 | 0x080 | 0x4806 A080 | 0x4806 C080 | 0x4902 0080 |

**Table 19-40. UART/IrDA/CIR Register Summary Part 2**

| Register Name                  | Type | Register Width (Bits) | Address Offset | UART4 Physical Address |
|--------------------------------|------|-----------------------|----------------|------------------------|
| <a href="#">DLL_REG</a>        | RW   | 32                    | 0x000          | 0x4904 2000            |
| <a href="#">RHR_REG</a>        | R    | 32                    | 0x000          | 0x4904 2000            |
| <a href="#">THR_REG</a>        | W    | 32                    | 0x000          | 0x4904 2000            |
| <a href="#">DLH_REG</a>        | RW   | 32                    | 0x004          | 0x4904 2004            |
| <a href="#">IER_REG</a>        | RW   | 32                    | 0x004          | 0x4904 2004            |
| <a href="#">IIR_REG</a>        | R    | 32                    | 0x008          | 0x4904 2008            |
| <a href="#">FCR_REG</a>        | W    | 32                    | 0x008          | 0x4904 2008            |
| <a href="#">EFR_REG</a>        | RW   | 32                    | 0x008          | 0x4904 2008            |
| <a href="#">LCR_REG</a>        | RW   | 32                    | 0x00C          | 0x4904 200C            |
| <a href="#">MCR_REG</a>        | RW   | 32                    | 0x010          | 0x4904 2010            |
| <a href="#">XON1_ADDR1_REG</a> | RW   | 32                    | 0x010          | 0x4904 2010            |
| <a href="#">LSR_REG</a>        | R    | 32                    | 0x014          | 0x4904 2014            |
| <a href="#">XON2_ADDR2_REG</a> | RW   | 32                    | 0x014          | 0x4904 2014            |
| <a href="#">MSR_REG</a>        | R    | 32                    | 0x018          | 0x4904 2018            |
| <a href="#">TCR_REG</a>        | RW   | 32                    | 0x018          | 0x4904 2018            |
| <a href="#">XOFF1_REG</a>      | RW   | 32                    | 0x018          | 0x4904 2018            |
| <a href="#">SPR_REG</a>        | RW   | 32                    | 0x01C          | 0x4904 201C            |
| <a href="#">TLR_REG</a>        | RW   | 32                    | 0x01C          | 0x4904 201C            |
| <a href="#">XOFF2_REG</a>      | RW   | 32                    | 0x01C          | 0x4904 201C            |
| <a href="#">MDR1_REG</a>       | RW   | 32                    | 0x020          | 0x4904 2020            |
| <a href="#">MDR2_REG</a>       | RW   | 32                    | 0x024          | 0x4904 2024            |
| <a href="#">SFLSR_REG</a>      | R    | 32                    | 0x028          | N/A                    |
| <a href="#">TXFLL_REG</a>      | W    | 32                    | 0x028          | N/A                    |

## UART/IrDA/CIR Register Manual

www.ti.com

|                                |    |    |       |             |
|--------------------------------|----|----|-------|-------------|
| <a href="#">RESUME_REG</a>     | R  | 32 | 0x02C | N/A         |
| <a href="#">TXFLH_REG</a>      | W  | 32 | 0x02C | N/A         |
| <a href="#">SFREGL_REG</a>     | R  | 32 | 0x030 | N/A         |
| <a href="#">RXFLL_REG</a>      | W  | 32 | 0x030 | N/A         |
| <a href="#">SFREGH_REG</a>     | R  | 32 | 0x034 | N/A         |
| <a href="#">RXFLH_REG</a>      | W  | 32 | 0x034 | N/A         |
| <a href="#">UASR_REG</a>       | R  | 32 | 0x038 | 0x4904 2038 |
| <a href="#">BLR_REG</a>        | RW | 32 | 0x038 | N/A         |
| <a href="#">ACREG_REG</a>      | RW | 32 | 0x03C | N/A         |
| <a href="#">SCR_REG</a>        | RW | 32 | 0x040 | 0x4904 2040 |
| <a href="#">SSR_REG</a>        | R  | 32 | 0x044 | 0x4904 2044 |
| <a href="#">EBLR_REG</a>       | RW | 32 | 0x048 | N/A         |
| <a href="#">MVR_REG</a>        | R  | 32 | 0x050 | 0x4904 2050 |
| <a href="#">SYSC_REG</a>       | RW | 32 | 0x054 | 0x4904 2054 |
| <a href="#">SYSS_REG</a>       | R  | 32 | 0x058 | 0x4904 2058 |
| <a href="#">WER_REG</a>        | RW | 32 | 0x05C | 0x4904 205C |
| <a href="#">CFPS_REG</a>       | RW | 32 | 0x060 | N/A         |
| <a href="#">RXFIFO_LVL_REG</a> | R  | 32 | 0x064 | 0x4904 2064 |
| <a href="#">TXFIFO_LVL_REG</a> | R  | 32 | 0x068 | 0x4904 2068 |
| <a href="#">IER2_REG</a>       | RW | 32 | 0x06C | 0x4904 206C |
| <a href="#">ISR2_REG</a>       | RW | 32 | 0x070 | 0x4904 2070 |
| <a href="#">MDR3_REG</a>       | RW | 32 | 0x080 | 0x4904 2080 |

### **19.6.3 UART/IrDA/CIR Register Description**

**Table 19-41. DLL\_REG**

---

|                         |                                                                                                                                                                                                                                                                                         |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x000                                                                                                                                                                                                                                                                                   |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                                                                                                                          |
| <b>Description</b>      | Divisor latches low<br><br>This register, with <b>DLH_REG</b> , stores the 14-bit divisor for generation of the baud clock in the baud rate generator. <b>DLH_REG</b> stores the most-significant part of the divisor. <b>DLL_REG</b> stores the least-significant part of the divisor. |
| <b>Note:</b>            | <b>DLL_REG</b> and <b>DLH_REG</b> can be written to only before sleep mode is enabled (before <b>IER_REG[4]</b> is set).                                                                                                                                                                |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                      |

---

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----------|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CLOCK_LSB |   |   |   |   |   |   |   |

---

| Bits | Field Name | Description                        | Type | Reset    |
|------|------------|------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0.                    | R    | 0x000000 |
| 7:0  | CLOCK_LSB  | Stores the 8-bit LSB divisor value | RW   | 0x00     |

---

**Table 19-42. Register Call Summary for Register DLL\_REG**

UART/IrDA/CIR Functional Description

- [FIFO DMA Mode Operation: \[0\]](#)
- [Register Access Modes: \[1\] \[2\] \[3\] \[4\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\]](#)
- [UART Mode: \[17\] \[18\] \[19\]](#)
- [IrDA Mode \(UART3 Only\): \[20\]](#)
- [UART Mode Power Management: \[21\] \[22\]](#)

UART/IrDA/CIR Basic Programming Model

- [Quick start: \[23\] \[24\] \[25\] \[26\] \[27\]](#)
- [SIR Mode: \[28\] \[29\] \[30\] \[31\] \[32\] \[33\] \[34\] \[35\]](#)
- [MIR Mode: \[36\] \[37\] \[38\] \[39\] \[40\] \[41\] \[42\] \[43\] \[44\] \[45\] \[46\] \[47\]](#)

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[48\] \[49\]](#)
- [UART/IrDA/CIR Register Description: \[50\] \[51\] \[52\] \[53\] \[54\] \[55\] \[56\] \[57\] \[58\]](#)

**Table 19-43. RHR\_REG**

| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x000                          |                          |      |          |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--------------------------|------|----------|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----|--|--|--|--|--|--|--|
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | See Table 19-39 to Table 19-40 |                          |      |          |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Receive holding register       |                          |      |          |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <p>The receiver section consists of the receiver holding register (<a href="#">RHR_REG</a>) and the receiver shift register. The <a href="#">RHR_REG</a> is actually a 64-byte FIFO. The receiver shift register receives serial data from RX input. The data is converted to parallel data and moved to the <a href="#">RHR_REG</a>. If the FIFO is disabled, location zero of the FIFO is used to store the single data character.</p> <p><a href="#">RHR_REG</a> must be read only after it is verified that the receive FIFO is not empty; this is done by reading the <a href="#">LSR_REG[0]</a> RX_FIFO_E bit.</p> <p><b>Note:</b> If an overflow occurs the data in the <a href="#">RHR_REG</a> is not overwritten.</p> |                                |                          |      |          |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R                              |                          |      |          |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="16">RESERVED</td><td colspan="8">RHR</td></tr> </table>                                                                                                                                                                                                                         |                                | 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RHR |  |  |  |  |  |  |  |
| 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 |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                |                          |      |          |    |    |    |    |    |    |    |    |    |    |    | RHR |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Field Name                     | Description              | Type | Reset    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| 31:8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reserved                       | Read returns 0.          | R    | 0x000000 |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| 7:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RHR                            | Receive holding register | R    | 0x-      |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |

**Table 19-44. Register Call Summary for Register RHR\_REG**

## UART/IrDA/CIR Functional Description

- [FIFO Management: \[0\] \[1\]](#)
- [Register Access Modes: \[2\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[3\] \[4\]](#)
- [UART Mode: \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\]](#)
- [IrDA Mode \(UART3 Only\): \[12\] \[13\] \[14\]](#)

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[15\] \[16\]](#)
- [UART/IrDA/CIR Register Description: \[17\] \[18\] \[19\] \[20\] \[21\] \[22\] \[23\]](#)

**Table 19-45. THR\_REG**

| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x000                          |                                 |      |          |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|---------------------------------|------|----------|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----|--|--|--|--|--|--|--|
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | See Table 19-39 to Table 19-40 |                                 |      |          |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Transmit holding register      |                                 |      |          |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <p>The transmitter section consists of the transmit holding register (<a href="#">THR_REG</a>) and the transmit shift register. The transmit holding register is a 64-byte FIFO. The MPU writes data to the <a href="#">THR_REG</a>. The data is placed in the transmit shift register where it is shifted out serially on the TX output. If the FIFO is disabled, location zero of the FIFO is used to store the data.</p>                                                                            |                                |                                 |      |          |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | W                              |                                 |      |          |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="16">RESERVED</td><td colspan="8">THR</td></tr> </table> |                                | 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | THR |  |  |  |  |  |  |  |
| 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 |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |                                 |      |          |    |    |    |    |    |    |    |    |    |    |    | THR |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Field Name                     | Description                     | Type | Reset    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| 31:8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reserved                       | Write has no functional effect. | W    | 0x000000 |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |
| 7:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | THR                            | Transmit holding register       | W    | 0x-      |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |

**Table 19-46. Register Call Summary for Register THR\_REG**

## UART/IrDA/CIR Functional Description

- [FIFO Management: \[0\]](#)
- [FIFO DMA Mode Operation: \[1\] \[2\]](#)
- [Register Access Modes: \[3\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[4\] \[5\] \[6\]](#)
- [UART Mode: \[7\] \[8\]](#)
- [IrDA Mode \(UART3 Only\): \[9\] \[10\] \[11\]](#)
- [CIR Mode \(UART3 Only\): \[12\] \[13\]](#)

## UART/IrDA/CIR Basic Programming Model

- [SIR Mode: \[14\]](#)
- [MIR Mode: \[15\] \[16\]](#)

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[17\] \[18\]](#)
- [UART/IrDA/CIR Register Description: \[19\] \[20\] \[21\] \[22\]](#)

**Table 19-47. IER\_REG**

|                         |                                                                |
|-------------------------|----------------------------------------------------------------|
| <b>Address Offset</b>   | 0x004                                                          |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a> |
| <b>Description</b>      | Interrupt enable register                                      |
| <b>Type</b>             | RW                                                             |

**UART Bit Field Details**

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|--------|---------|------------|--------------|-------------|--------|--------|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CTS_IT | RTS_IT | XOFF_IT | SLEEP_MODE | MODEM_STS_IT | LINE_STS_IT | THR_IT | RHR_IT |   |   |   |   |   |   |   |   |

| Bits | Field Name   | Description                                                                                                                                                       | Type | Reset |
|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15:8 | Reserved     | Read returns 0x00. Write has no functional effect.                                                                                                                | RW   | 0x00  |
| 7    | CTS_IT       | Can be written only when <a href="#">EFR_REG[4] = 1</a><br>0x0: Disables the nCTS interrupt<br>0x1: Enables the nCTS interrupt                                    | RW   | 0     |
| 6    | RTS_IT       | Can be written only when <a href="#">EFR_REG[4] = 1</a><br>0x0: Disables the interrupt<br>0x1: Enables the nRTS interrupt                                         | RW   | 0     |
| 5    | XOFF_IT      | Can be written only when <a href="#">EFR_REG[4] = 1</a><br>0x0: Disables the XOFF interrupt<br>0x1: Enables the XOFF interrupt                                    | RW   | 0     |
| 4    | SLEEP_MODE   | Can be only written when <a href="#">EFR_REG[4] = 1</a><br>0x0: Disables sleep mode<br>0x1: Enables sleep mode (stop baud rate clock when the module is inactive) | RW   | 0     |
| 3    | MODEM_STS_IT |                                                                                                                                                                   | RW   | 0     |
|      |              | 0x0: Disables the modem status register interrupt<br>0x1: Enables the modem status register interrupt                                                             |      |       |
| 2    | LINE_STS_IT  |                                                                                                                                                                   | RW   | 0     |
|      |              | 0x0: Disables the receiver line status interrupt                                                                                                                  |      |       |

| Bits | Field Name | Description                                             | Type | Reset |
|------|------------|---------------------------------------------------------|------|-------|
|      |            | 0x1: Enables the receiver line status interrupt         |      |       |
| 1    | THR_IT     |                                                         | RW   | 0     |
|      |            | 0x0: Disables the THR interrupt                         |      |       |
|      |            | 0x1: Enables the THR interrupt                          |      |       |
| 0    | RHR_IT     |                                                         | RW   | 0     |
|      |            | 0x0: Disables the RHR interrupt and time out interrupt. |      |       |
|      |            | 0x1: Enables the RHR interrupt and time out interrupt.  |      |       |

**Table 19-48. Register Call Summary for Register IER\_REG**

## UART/IrDA/CIR Functional Description

- [FIFO Interrupt Mode: \[0\]](#)
- [FIFO Polled Mode Operation: \[1\]](#)
- [Register Access Modes: \[2\] \[3\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [UART Mode: \[10\]](#)
- [IrDA Mode \(UART3 Only\): \[11\] \[12\]](#)
- [CIR Mode \(UART3 Only\): \[13\] \[14\] \[15\]](#)
- [UART Mode Power Management: \[16\] \[17\]](#)

## UART/IrDA/CIR Basic Programming Model

- [Quick start: \[18\] \[19\] \[20\] \[21\] \[22\] \[23\] \[24\] \[25\] \[26\] \[27\] \[28\] \[29\] \[30\] \[31\]](#)
- [SIR Mode: \[32\] \[33\]](#)
- [MIR Mode: \[34\] \[35\] \[36\] \[37\]](#)

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[38\] \[39\]](#)
- [UART/IrDA/CIR Register Description: \[40\] \[41\] \[42\] \[43\] \[44\]](#)

**CIR Bit Field Details**

| Bits | Field Name    | Description                                                                                                                                     | Type | Reset     |
|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:6 | Reserved      | Read returns 0. Write has no functional effect.                                                                                                 | RW   | 0x0000000 |
| 5    | TX_STATUS_IT  | In IR-CIR mode, contrary to the IR-IrDA mode, the TX_STATUS_IT has only one meaning corresponding to the case <a href="#">MDR2_REG[0] = 0</a> . | RW   | 0         |
| 4    | RESERVED      | Not used in CIR mode                                                                                                                            | RW   | 0         |
| 3    | RX_OVERRUN_IT |                                                                                                                                                 | RW   | 0         |
|      |               | 0x0: Disables the RX overrun interrupt                                                                                                          |      |           |
|      |               | 0x1: Enables the RX overrun interrupt                                                                                                           |      |           |
| 2    | RX_STOP_IT    |                                                                                                                                                 | RW   | 0         |
|      |               | 0x0: Disables the receive stop interrupt                                                                                                        |      |           |
|      |               | 0x1: Enables the receive stop interrupt                                                                                                         |      |           |
| 1    | THR_IT        |                                                                                                                                                 | RW   | 0         |
|      |               | 0x0: Disables the THR interrupt                                                                                                                 |      |           |
|      |               | 0x1: Enables the THR interrupt                                                                                                                  |      |           |

| Bits | Field Name | Description                                                       | Type | Reset |
|------|------------|-------------------------------------------------------------------|------|-------|
| 0    | RHR_IT     |                                                                   | RW   | 0     |
|      |            | 0x0: Disables the RHR interrupt<br>0x1: Enables the RHR interrupt |      |       |
|      |            |                                                                   |      |       |

**IrDA Bit Field Details**


| Bits | Field Name       | Description                                                                                                                                                                                                                                       | Type | Reset    |
|------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved         | Read returns 0. Write has no functional effect.                                                                                                                                                                                                   | RW   | 0x000000 |
| 7    | EOF_IT           | 0x0: Disables the received EOF interrupt<br>0x1: Enables the received EOF interrupt                                                                                                                                                               |      |          |
| 6    | LINE_STS_IT_I    | 0x0: Disables the receiver line status interrupt<br>0x1: Enables the receiver line status interrupt                                                                                                                                               | RW   | 0        |
| 5    | TX_STATUS_IT     | TX_STATUS_IT interrupt reflects two possible conditions.<br>The <a href="#">MDR2_REG[0]</a> must be read to determine the status in the event of this interrupt.<br>0x0: Disables the TX status interrupt<br>0x1: Enables the TX status interrupt | RW   | 0        |
| 4    | STS_FIFO_TRIG_IT | 0x0: Disables status FIFO trigger level interrupt<br>0x1: Enables status FIFO trigger level interrupt.                                                                                                                                            | RW   | 0        |
| 3    | RX_OVERRUN_IT    | 0x0: Disables the RX overrun interrupt<br>0x1: Enables the RX overrun interrupt                                                                                                                                                                   | RW   | 0        |
| 2    | LAST_RX_BYTE_IT  | 0x0: Disables the last byte of frame in RX FIFO interrupt<br>0x1: Enables the last byte of frame in RX FIFO interrupt                                                                                                                             | RW   | 0        |
| 1    | THR_IT           | 0x0: Disables the THR interrupt<br>0x1: Enables the THR interrupt                                                                                                                                                                                 | RW   | 0        |
| 0    | RHR_IT           | 0x0: Disables the RHR interrupt<br>0x1: Enables the RHR interrupt                                                                                                                                                                                 | RW   | 0        |

**Table 19-49. DLH\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x004                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>Description</b>      | Divisor latches high<br><br>This register, with <a href="#">DLL_REG</a> , stores the 14-bit divisor for generation of the baud clock in the baud rate generator. <a href="#">DLH_REG</a> stores the most-significant part of the divisor. <a href="#">DLL_REG</a> stores the least-significant part of the divisor.<br><br><b>Note:</b> <a href="#">DLL_REG</a> and <a href="#">DLH_REG</a> can be written to only before sleep mode is enabled (before <a href="#">IER_REG[4]</a> is set). |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |



| Bits | Field Name | Description                                               | Type | Reset     |
|------|------------|-----------------------------------------------------------|------|-----------|
| 31:6 | Reserved   | Read returns 0.                                           | R    | 0x0000000 |
| 5:0  | CLOCK_MSB  | Stores the 6-bit most-significant bit (MSB) divisor value | RW   | 0x00      |

**Table 19-50. Register Call Summary for Register DLH\_REG**

## UART/IrDA/CIR Functional Description

- [FIFO DMA Mode Operation: \[0\]](#)
- [Register Access Modes: \[1\] \[2\] \[3\] \[4\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\]](#)
- [UART Mode: \[17\] \[18\] \[19\]](#)
- [IrDA Mode \(UART3 Only\): \[20\]](#)
- [UART Mode Power Management: \[21\] \[22\]](#)

## UART/IrDA/CIR Basic Programming Model

- [Quick start: \[23\] \[24\] \[25\] \[26\] \[27\]](#)
- [SIR Mode: \[28\] \[29\] \[30\] \[31\] \[32\] \[33\] \[34\] \[35\]](#)
- [MIR Mode: \[36\] \[37\] \[38\] \[39\] \[40\] \[41\] \[42\] \[43\] \[44\] \[45\] \[46\] \[47\]](#)

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[48\] \[49\]](#)
- [UART/IrDA/CIR Register Description: \[50\] \[51\] \[52\] \[53\] \[54\] \[55\] \[56\] \[57\] \[58\]](#)

**Table 19-51. FCR\_REG**

|                         |                                |
|-------------------------|--------------------------------|
| <b>Address Offset</b>   | 0x008                          |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40 |
| <b>Description</b>      | FIFO control register          |
| <b>Type</b>             | W                              |



| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:8        | Reserved          | Write has no functional effect.                                                                                                                                                                                                                                                                                                                                                                                                                                    | W           | 0x000000     |
| 7:6         | RX_FIFO_TRIG      | Sets the trigger level for the RX FIFO: If <b>SCR_REG[7] = 0</b> and <b>TLR_REG[7:4] ≠ 0000</b> , RX_FIFO_TRIG is not considered.<br><br>If <b>SCR_REG[7] = 1</b> , RX_FIFO_TRIG is 2 LSB of the trigger level (1 to 63 on 6 bits) with a granularity of 1.<br><br>If <b>SCR_REG[7] = 0</b> and <b>TLR_REG[7:4] = 0000</b> :<br>0x0: 8 characters<br>0x1: 16 characters<br>0x2: 56 characters<br>0x3: 60 characters                                                | W           | 0x0          |
| 5:4         | TX_FIFO_TRIG      | Can be written only if <b>EFR_REG[4] = 1</b> . Sets the trigger level for the TX FIFO. If <b>SCR_REG[6] = 0</b> and <b>TLR_REG[3:0] ≠ 0000</b> , TX_FIFO_TRIG is not considered.<br><br>If <b>SCR_REG[6] = 1</b> , RX_FIFO_TRIG is 2 LSB of the trigger level (1 to 63 on 6 bits) with a granularity of 1.<br><br>If <b>SCR_REG[6] = 0</b> and <b>TLR_REG[3:0] = 0000</b> :<br>0x0: 8 characters<br>0x1: 16 characters<br>0x2: 32 characters<br>0x3: 56 characters | W           | 0x0          |
| 3           | DMA_MODE          | Can be changed only when the baud clock is not running ( <b>DLL_REG</b> and <b>DLH_REG</b> set to 0).<br><br>This register is considered if <b>SCR_REG[0] = 0</b> .<br>0x0: DMA_MODE 0 (No DMA)<br>0x1: DMA_MODE 1 (UART_NDMA_REQ[0] in TX, UART_NDMA_REQ[1] in RX)                                                                                                                                                                                                | W           | 0            |
| 2           | TX_FIFO_CLEAR     | Clears the TX FIFO<br>0x0: No change<br>0x1: Clears the transmit FIFO and resets its counter logic to 0. Returns to 0 after clearing FIFO.                                                                                                                                                                                                                                                                                                                         | W           | 0            |
| 1           | RX_FIFO_CLEAR     | Clears the RX FIFO.<br>0x0: No change<br>0x1: Clears the receive FIFO and resets its counter logic to 0. Returns to 0 after clearing FIFO.                                                                                                                                                                                                                                                                                                                         | W           | 0            |
| 0           | FIFO_EN           | Can be changed only when the baud clock is not running ( <b>DLL_REG</b> and <b>DLH_REG</b> set to 0).<br>0x0: Disables the transmit and receive FIFOs. The transmit and receive holding registers are 1-byte FIFOs.<br>0x1: Enables the transmit and receive FIFOs. The transmit and receive holding registers are 64-byte FIFOs.                                                                                                                                  | W           | 0            |

**Table 19-52. Register Call Summary for Register FCR\_REG**

- [UART/IrDA/CIR Functional Description](#)
- [FIFO Management](#): [0]
- [FIFO Trigger](#): [1] [2] [3]
- [FIFO Interrupt Mode](#): [4] [5] [6]
- [FIFO Polled Mode Operation](#): [7]
- [FIFO DMA Mode Operation](#): [8] [9] [10] [11]
- [Register Access Modes](#): [12] [13]
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection](#): [14] [15] [16] [17] [18] [19]

---

- [UART/IrDA/CIR Basic Programming Model](#)
- [Quick start](#): [20] [21] [22] [23] [24] [25] [26] [27]
- [MIR Mode](#): [28] [29] [30] [31] [32] [33]

---

- [UART/IrDA/CIR Register Manual](#)
- [UART/IrDA/CIR Register Summary](#): [34] [35]
- [UART/IrDA/CIR Register Description](#): [36] [37] [38] [39] [40]

**Table 19-53. IIR\_REG**

|                         |                                                                                                                        |
|-------------------------|------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x008                                                                                                                  |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a>                                                         |
| <b>Description</b>      | Interrupt Identification register                                                                                      |
|                         | The <a href="#">IIR_REG</a> is a read-only register that provides the source of the interrupt in a prioritized manner. |
|                         | <b>Note:</b> An interrupt source can be flagged only if enabled in the <a href="#">IER_REG</a> register.               |
| <b>Type</b>             | R                                                                                                                      |

## UART Bit Field Details

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |            |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|------------|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IT_TYPE |    |    |    | IT_PENDING |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15:8 | Reserved   | Read returns 0x00.                                                                                                                                                                                                                                                                                                                                                                                         | R    | 0x00  |
| 7:6  | FCR_MIRROR | Mirror the contents of FCR_REG[0] on both bits.                                                                                                                                                                                                                                                                                                                                                            | R    | 0x0   |
| 5:1  | IT_TYPE    | Seven possible interrupts in UART mode; other combinations never occur:<br><br>0x0: Modem interrupt. Priority = 4<br>0x1: THR interrupt. Priority = 3<br>0x2: RHR interrupt. Priority = 2<br>0x3: Receiver line status error. Priority = 1<br>0x6: Rx timeout. Priority = 2<br>0x8: Xoff/special character. Priority = 5<br>0x10: CTS, RTS change state from active (low) to inactive (high). Priority = 6 | R    | 0x00  |
| 0    | IT_PENDING | 0x0: An interrupt is pending.<br>0x1: No interrupt is pending.                                                                                                                                                                                                                                                                                                                                             | R    | 1     |

**Table 19-54. Register Call Summary for Register IIR\_REG**

## UART/IrDA/CIR Functional Description

- Register Access Modes: [0] [1]
- UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [2] [3] [4] [5] [6] [7]
- UART Mode: [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20]
- IrDA Mode (UART3 Only): [21] [22] [23] [24] [25]
- CIR Mode (UART3 Only): [26] [27] [28] [29] [30] [31] [32]

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary](#): [33] [34]
- [UART/IrDA/CIR Register Description](#): [35] [36] [37] [38] [39]

**CIR Bit Field Details**

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

RESERVED

| Bits | Field Name   | Description                             | Type | Reset |
|------|--------------|-----------------------------------------|------|-------|
| 15:8 | Reserved     | Read returns 0x00.                      | R    | 0x00  |
| 7:6  | Reserved     | Read returns 0x0.                       | R    | 0x0   |
| 5    | TX_STATUS_IT |                                         | R    | 0     |
|      |              | 0x0: TX status interrupt inactive       |      |       |
|      |              | 0x1: TX status interrupt active         |      |       |
| 4    | RESERVED     | Not used in CIR mode                    | R    | 0     |
| 3    | RX_OE_IT     |                                         | R    | 0     |
|      |              | 0x0: THR interrupt inactive             |      |       |
|      |              | 0x1: THR interrupt active               |      |       |
| 2    | RX_STOP_IT   |                                         | R    | 0     |
|      |              | 0x0: Receive stop interrupt is inactive |      |       |
|      |              | 0x1: Receive stop interrupt is active   |      |       |
| 1    | THR_IT       |                                         | R    | 0     |
|      |              | 0x0: THR interrupt inactive             |      |       |
|      |              | 0x1: THR interrupt active               |      |       |
| 0    | RHR_IT       |                                         | R    | 0     |
|      |              | 0x0: RHR INTERRUPT INACTIVE             |      |       |
|      |              | 0x1: RHR interrupt active               |      |       |

**IrDA Bit Field Details**

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

RESERVED

| Bits | Field Name    | Description                                                                                                                                           | Type | Reset    |
|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved      | Read returns 0x00.                                                                                                                                    | R    | 0x000000 |
| 7    | EOF_IT        | 0x0: Received EOF interrupt inactive<br>0x1: Received EOF interrupt active                                                                            |      |          |
| 6    | LINE_STS_IT   | 0x0: Receiver line status interrupt inactive<br>0x1: Receiver line status interrupt active                                                            | R    | 0        |
| 5    | TX_STATUS_IT  | 0x0: TX status interrupt inactive<br>0x1: TX status interrupt active                                                                                  | R    | 0        |
| 4    | STS_FIFO_IT   | 0x0: Status FIFO trigger level interrupt inactive<br>0x1: Status FIFO trigger level interrupt active                                                  | R    | 0        |
| 3    | RX_OE_IT      | 0x0: RX overrun interrupt inactive<br>0x1: RX overrun interrupt active                                                                                | R    | 0        |
| 2    | RX_FIFO_LB_IT | 0x0: Receive FIFO last byte interrupt<br>0x1: Last byte of frame in RX FIFO interrupt inactive<br>0x1: Last byte of frame in RX FIFO interrupt active | R    | 0        |
| 1    | THR_IT        | 0x0: THR interrupt inactive<br>0x1: THR interrupt active                                                                                              | R    | 0        |
| 0    | RHR_IT        | 0x0: RHR interrupt inactive<br>0x1: RHR interrupt active                                                                                              | R    | 0        |

**Table 19-55. EFR\_REG**

|                         |                                                                                                                                                                                                                                      |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x008                                                                                                                                                                                                                                |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                                                                       |
| <b>Description</b>      | Enhanced feature register                                                                                                                                                                                                            |
|                         | This register enables or disables enhanced features. Most enhanced functions apply only to UART modes, but <b>EFR_REG[4]</b> enables write accesses to <b>FCR_REG[5:4]</b> , the TX trigger level, which is also used in IrDA modes. |
| <b>Type</b>             | RW                                                                                                                                                                                                                                   |



| Bits | Field Name  | Description                                                   | Type | Reset    |
|------|-------------|---------------------------------------------------------------|------|----------|
| 31:8 | Reserved    | Read returns 0.                                               | R    | 0x000000 |
| 7    | AUTO_CTS_EN | Auto-CTS enable bit (UART mode only)<br>0x0: Normal operation | RW   | 0        |

| Bits | Field Name      | Description                                                                                                                                                                                                                                                                                                                      | Type | Reset |
|------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |                 | 0x1: Auto-CTS flow control is enabled; transmission is halted when the nCTS pin is high (inactive).                                                                                                                                                                                                                              |      |       |
| 6    | AUTO_RTS_EN     | Auto-RTS enable bit (UART mode only)<br><br>0x0: Normal operation<br><br>0x1: Auto-RTS flow control is enabled; nRTS pin goes high (inactive) when the receiver FIFO HALT trigger level, <a href="#">TCR_REG[3:0]</a> , is reached and goes low (active) when the receiver FIFO RESTORE transmission trigger level is reached.   | RW   | 0     |
| 5    | SPEC_CHAR       | (UART mode only) Special character detect<br><br>0x0: Normal operation<br><br>0x1: Special character detect enable. Received data is compared with XOFF2 data. If a match occurs, the received data is transferred to RX FIFO and <a href="#">IIR_REG</a> bit 4 is set to 1 to indicate that a special character was detected.   | RW   | 0     |
| 4    | ENHANCED_EN     | Enhanced functions write enable bit<br><br>0x0: Disables writing to <a href="#">IER_REG</a> bits [7:4], <a href="#">FCR_REG</a> bits [5:4], and <a href="#">MCR_REG</a> bits [7:5]<br><br>0x1: Enables writing to <a href="#">IER_REG</a> bits [7:4], <a href="#">FCR_REG</a> bits [5:4], and <a href="#">MCR_REG</a> bits [7:5] | RW   | 0     |
| 3:0  | SW_FLOW_CONTROL | Combinations of software flow control can be selected by programming bit [3:0].<br><br>See <a href="#">Table 19-32</a> . In IrDA mode, bits [1:0] select IR address to check. See <a href="#">Section 19.2.5.2.1.7, IR Address Checking</a> .                                                                                    | RW   | 0x0   |

**Table 19-56. Register Call Summary for Register EFR\_REG**


---

UART/IrDA/CIR Environment

- [IrDA Protocol and Data Format](#): [0] [1] [2]
- 

## UART/IrDA/CIR Functional Description

- [Register Access Modes](#): [3] [4] [5] [6] [7] [8] [9] [10]
  - [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection](#): [11] [12] [13] [14] [15] [16]
  - [UART Mode](#): [17] [18] [19] [20] [21] [22]
  - [IrDA Mode \(UART3 Only\)](#): [23] [24] [25]
  - [UART Mode Power Management](#): [26]
- 

## UART/IrDA/CIR Basic Programming Model

- [Quick start](#): [27] [28] [29] [30] [31] [32] [33] [34] [35] [36]
  - [Hardware and Software Flow Control Configuration](#): [37] [38] [39] [40] [41] [42] [43] [44] [45] [46] [47] [48] [49] [50] [51] [52] [53] [54] [55] [56]
  - [SIR Mode](#): [57] [58] [59]
  - [MIR Mode](#): [60] [61] [62]
- 

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary](#): [63] [64]
  - [UART/IrDA/CIR Register Description](#): [65] [66] [67] [68] [69] [70] [71] [72]
-

**Table 19-57. LCR\_REG**

|                         |                                                                                                                                                                                   |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x00C                                                                                                                                                                             |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                    |
| <b>Description</b>      | Line control register                                                                                                                                                             |
|                         | <b>LCR_REG[6:0]</b> define parameters of the transmission and reception for UART mode. <b>LCR_REG[7]</b> is used to put the module in operational mode or Configuration_Mode_A/B. |



| Bits | Field Name   | Description                                                                                                                                                                                                                                                                                                                                                                     | Type | Reset    |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved     | Read returns 0                                                                                                                                                                                                                                                                                                                                                                  | R    | 0x000000 |
| 7    | DIV_EN       |                                                                                                                                                                                                                                                                                                                                                                                 | RW   | 0        |
|      |              | 0x0: Operational mode<br>0x1: Divisor latch enable; put the module in Configuration_Mode_A/B. Allows access to <b>DLL_REG</b> , <b>DLH_REG</b> , and other registers (see <a href="#">Section 19.6.2, UART/IrDA/CIR Register Mapping Summary</a> ). Configuration_Mode_B: <b>LCR_REG[7:0] = 0xBF</b> Else, Configuration_Mode_A                                                 |      |          |
| 6    | BREAK_EN     | Break control bit. UART mode only.<br><br><b>Note:</b> When <b>LCR_REG[6]</b> is set to 1, the TX line is forced to 0 and remains in this state as long as <b>LCR_REG[6] = 1</b> .<br>0x0: Normal operating condition<br>0x1: Forces the transmitter output to go low to alert the communication terminal. TX line is forced to 0 and remains in this state while BREAK_EN = 1. | RW   | 0        |
| 5    | PARITY_TYPE2 | Selects the forced parity format (if <b>LCR_REG[3] = 1</b> ).<br>UART mode only. If <b>LCR_REG[5] = 1</b> and <b>LCR_REG[4] = 0</b> , the parity bit is forced to 1 in the transmitted and received data. If <b>LCR_REG[5] = 1</b> and <b>LCR_REG[4] = 1</b> , the parity bit is forced to 0 in the transmitted and received data.                                              | RW   | 0        |
| 4    | PARITY_TYPE1 | UART mode only<br>0x0: Odd parity is generated (if <b>LCR_REG[3] = 1</b> ).<br>0x1: Even parity is generated (if <b>LCR_REG[3] = 1</b> ).                                                                                                                                                                                                                                       | RW   | 0        |
| 3    | PARITY_EN    | UART mode only<br>0x0: No parity<br>0x1: A parity bit is generated during transmission, and the receiver checks for received parity.                                                                                                                                                                                                                                            | RW   | 0        |
| 2    | NB_STOP      | Specifies the number of stop bits. UART mode only.<br>0x0: 1 stop bit (word length = 5, 6, 7, 8)<br>0x1: 1.5 stop bits (word length = 5)1 - 2 stop bits (word length = 6, 7, 8)                                                                                                                                                                                                 | RW   | 0        |
| 1:0  | CHAR_LENGTH  | Specifies the word length to be transmitted or received. UART mode only.<br>0x0: 5 bits<br>0x1: 6 bits                                                                                                                                                                                                                                                                          | RW   | 0x0      |

| Bits | Field Name | Description | Type | Reset |
|------|------------|-------------|------|-------|
|      |            | 0x2: 7 bits |      |       |
|      |            | 0x3: 8 bits |      |       |

**Table 19-58. Register Call Summary for Register LCR\_REG**

UART/IrDA/CIR Environment

- IrDA Protocol and Data Format: [0]

UART/IrDA/CIR Functional Description

- Register Access Modes: [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12]
- UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23] [24] [25] [26] [27] [28] [29] [30]
- UART Mode: [31] [32] [33] [34] [35] [36] [37]
- IrDA Mode (UART3 Only): [38] [39] [40]

UART/IrDA/CIR Basic Programming Model

- Quick start: [41] [42] [43] [44] [45] [46] [47] [48] [49] [50] [51] [52] [53] [54] [55] [56] [57] [58] [59] [60] [61] [62] [63]
- Hardware and Software Flow Control Configuration: [64] [65] [66] [67] [68] [69] [70] [71] [72] [73] [74]
- SIR Mode: [75] [76] [77] [78] [79] [80] [81] [82] [83] [84]
- MIR Mode: [85] [86] [87] [88] [89] [90] [91] [92] [93] [94] [95] [96] [97] [98] [99]

UART/IrDA/CIR Register Manual

- UART/IrDA/CIR Register Summary: [100] [101]
- UART/IrDA/CIR Register Description: [102] [103] [104] [105] [106] [107] [108] [109] [110] [111] [112] [113] [114]

**Table 19-59. MCR\_REG**

|                  |                                                                                                                                               |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Address Offset   | 0x010                                                                                                                                         |
| Physical Address | See Table 19-39 to Table 19-40                                                                                                                |
| Description      | Modem control register<br><br>MCR_REG[3:0] controls the interface with the modem, data set, or peripheral device that is emulating the modem. |
| Type             | RW                                                                                                                                            |



| Bits | Field Name  | Description                                                                                                                           | Type | Reset     |
|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:7 | Reserved    | Read returns 0.                                                                                                                       | R    | 0x0000000 |
| 6    | TCR_TLR     | Can be written only when EFR_REG[4] ENHANCED_EN = 1<br><br>0x0: No action<br>0x1: Enables access to the TCR_REG and TLR_REG registers | RW   | 0         |
| 5    | XON_EN      | Can be written only when EFR_REG[4] ENHANCED_EN = 1<br><br>0x0: Disable XON any function<br>0x1: Enable XON any function              | RW   | 0         |
| 4    | LOOPBACK_EN | <br><br>0x0: Normal operating mode<br>0x1: Enable local loopback mode (internal).                                                     | RW   | 0         |

| Bits | Field Name | Description                                                                                                                                                                    | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | In this mode, the <a href="#">MCR_REG[3:0]</a> signals are looped back into <a href="#">MSR_REG[7:4]</a> . The transmit output is looped back to the receive input internally. |      |       |
| 3    | CD_STS_CH  |                                                                                                                                                                                | RW   | 0     |
|      |            | 0x0: In loopback, forces nDCD input high and IRQ outputs to INACTIVE state.<br>0x1: In loopback, forces nDCD input low and IRQ outputs to INACTIVE state.                      |      |       |
| 2    | RI_STS_CH  |                                                                                                                                                                                | RW   | 0     |
|      |            | 0x0: In loopback, forces nRI input inactive (high).<br>0x1: In loopback, forces nRI input active (low).                                                                        |      |       |
| 1    | RTS        | In loop back, controls <a href="#">MSR_REG[4]</a> . If auto-RTS is enabled, the nRTS output is controlled by hardware flow control.                                            | RW   | 0     |
|      |            | 0x0: Force nRTS output to inactive (high).<br>0x1: Force nRTS output to active (low).                                                                                          |      |       |
| 0    | DTR        | 0: Force DTR output (used in loop back mode) to inactive (high)<br>1: Force DTR output (used in loop back mode) to active (low)                                                | RW   | 0     |

**Table 19-60. Register Call Summary for Register MCR\_REG**

## UART/IrDA/CIR Environment

- [UART Interface Description: \[0\] \[1\]](#)

## UART/IrDA/CIR Functional Description

- [Register Access Modes: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[12\] \[13\] \[14\] \[15\] \[16\] \[17\]](#)
- [UART Mode: \[18\] \[19\]](#)

## UART/IrDA/CIR Basic Programming Model

- [Quick start: \[20\] \[21\] \[22\] \[23\] \[24\]](#)
- [Hardware and Software Flow Control Configuration: \[25\] \[26\] \[27\] \[28\] \[29\] \[30\] \[31\] \[32\] \[33\] \[34\] \[35\] \[36\]](#)
- [SIR Mode: \[37\]](#)
- [MIR Mode: \[38\] \[39\] \[40\] \[41\] \[42\]](#)

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[43\] \[44\]](#)
- [UART/IrDA/CIR Register Description: \[45\] \[46\] \[47\] \[48\] \[49\] \[50\] \[51\] \[52\] \[53\] \[54\] \[55\] \[56\]](#)

**Table 19-61. XON1\_ADDR1\_REG**

|                         |                                                                |
|-------------------------|----------------------------------------------------------------|
| <b>Address Offset</b>   | 0x010                                                          |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a> |
| <b>Description</b>      | UART mode: XON1 character, IrDA mode: ADDR1 address            |
| <b>Type</b>             | RW                                                             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                             | Type | Reset    |
|------|------------|-----------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0                                                                          | R    | 0x000000 |
| 7:0  | XON_WORD1  | Used to store the 8-bit XON1 character in UART modes and ADDR1 address 1 for IrDA modes | RW   | 0x00     |

**Table 19-62. Register Call Summary for Register XON1\_ADDR1\_REG**


---

 UART/IrDA/CIR Environment

- IrDA Protocol and Data Format: [0]
- 

## UART/IrDA/CIR Functional Description

- Register Access Modes: [1] [2]
  - UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [3] [4] [5] [6]
  - IrDA Mode (UART3 Only): [7]
- 

## UART/IrDA/CIR Basic Programming Model

- Hardware and Software Flow Control Configuration: [8] [9]
- 

## UART/IrDA/CIR Register Manual

- UART/IrDA/CIR Register Summary: [10] [11]
- 

**Table 19-63. LSR\_REG**

|                         |                                |
|-------------------------|--------------------------------|
| <b>Address Offset</b>   | 0x014                          |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40 |
| <b>Description</b>      | Line status register           |
| <b>Type</b>             | R                              |

---

**UART Bit Field Details**

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name  | Description                                                                                                                                                                 | Type | Reset    |
|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved    | Read returns 0.                                                                                                                                                             | R    | 0x000000 |
| 7    | RX_FIFO_STS | 0x0: Normal operation<br>0x1: At least one parity error, framing error, or break indication in the RX FIFO. Bit 7 is cleared when no errors are present in the RX FIFO.     | R    | 0        |
| 6    | TX_SR_E     | 0x0: Transmitter hold (TX FIFO) and shift registers are not empty.<br>0x1: Transmitter hold (TX FIFO) and shift registers are empty                                         | R    | 1        |
| 5    | TX_FIFO_E   | 0x0: Transmit hold register (TX FIFO) is not empty.<br>0x1: Transmit hold register (TX FIFO) is empty. The transmission is not necessarily complete.                        | R    | 1        |
| 4    | RX_BI       | 0x0: No break condition<br>0x1: A break was detected while the data being read from the RX FIFO was being received (RX input was low for one character + 1 bit time frame). | R    | 0        |
| 3    | RX_FE       | 0x0: No framing error in data being read from RX FIFO<br>0x1: Framing error occurred in data being read from RX FIFO (received data did not have a valid stop bit).         | R    | 0        |

| Bits | Field Name | Description                                                                                                                                                                | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 2    | RX_PE      |                                                                                                                                                                            | R    | 0     |
|      |            | 0x0: No parity error in data being read from RX FIFO                                                                                                                       |      |       |
|      |            | 0x1: Parity error in data being read from RX FIFO                                                                                                                          |      |       |
| 1    | RX_OE      |                                                                                                                                                                            | R    | 0     |
|      |            | 0x0: No overrun error                                                                                                                                                      |      |       |
|      |            | 0x1: Overrun error occurred. Set when the character held in the receive shift register is not transferred to the RX FIFO. This case occurs only when receive FIFO is full. |      |       |
| 0    | RX_FIFO_E  |                                                                                                                                                                            | R    | 0     |
|      |            | 0x0: No data in the receive FIFO                                                                                                                                           |      |       |
|      |            | 0x1: At least one data character in the RX FIFO                                                                                                                            |      |       |

**Table 19-64. Register Call Summary for Register LSR\_REG**

## UART/IrDA/CIR Environment

- [IrDA Protocol and Data Format](#): [0] [1] [2]

## UART/IrDA/CIR Functional Description

- [FIFO Polled Mode Operation](#): [3]
- [Register Access Modes](#): [4] [5]
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection](#): [6] [7] [8] [9] [10] [11]
- [UART Mode](#): [12] [13] [14] [15] [16] [17] [18] [19] [20]
- [IrDA Mode \(UART3 Only\)](#): [21] [22] [23]

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary](#): [24] [25]
- [UART/IrDA/CIR Register Description](#): [26] [27]

**CIR Bit Field Details**

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |          |         |          |    |    |   |           |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----------|---------|----------|----|----|---|-----------|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | THR_EMPTY | RESERVED | RX_STOP | RESERVED |    |    |   | RX_FIFO_E |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                   | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------|------|-------|
| 15:8 | Reserved   | Read returns 0x00.                                                                            | R    | 0x00  |
| 7    | THR_EMPTY  |                                                                                               | R    | 0     |
|      |            | 0x0: Transmit holding register (TX FIFO) is not empty.                                        |      |       |
|      |            | 0x1: Transmit hold register (TX FIFO) is empty. The transmission is not necessarily complete. |      |       |
| 6    | Reserved   |                                                                                               |      |       |
| 5    | Reserved   |                                                                                               | R    | 1     |
| 4:1  | Reserved   |                                                                                               |      |       |
| 0    | Reserved   |                                                                                               | R    | 1     |

**IrDA Bit Field Details**

| 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          |           |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----------|---------------|--------------|----------------|-------|-----|------------|-----------|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | THR_EMPTY | STS_FIFO_FULL | RX_LAST_BYTE | FRAME_TOO_LONG | ABORT | CRC | STS_FIFO_E | RX_FIFO_E |

| Bits | Field Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Type | Reset    |
|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved       | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R    | 0x000000 |
| 7    | THR_EMPTY      | <p>0x0: Transmit holding register (TX FIFO) is not empty.</p> <p>0x1: Transmit hold register (TX FIFO) is empty. The transmission is not necessarily complete.</p>                                                                                                                                                                                                                                                                                                 | R    | 0        |
| 6    | STS_FIFO_FUL   | <p>0x0: Status FIFO not full</p> <p>0x1: Status FIFO full</p>                                                                                                                                                                                                                                                                                                                                                                                                      | R    | 1        |
| 5    | RX_LAST_BYTE   | <p>Receive last byte</p> <p>0x0: The RX FIFO (<a href="#">RHR_REG</a>) does not contain the last byte of the frame to be read.</p> <p>0x1: The RX FIFO (<a href="#">RHR_REG</a>) contains the last byte of the frame to be read. This bit is set only when the last byte of a frame is available to be read. It is used to determine the frame boundary. It is cleared on a single read of the <a href="#">LSR_REG</a> register.</p>                               | R    | 1        |
| 4    | FRAME_TOO_LONG | <p>Frame too long</p> <p>0x0: No frame-too-long error in frame</p> <p>0x1: Frame-too-long error in the frame at the top of the STATUS FIFO (next character to be read). This bit is set to 1 when a frame exceeding the maximum length (set by <a href="#">RXFLH_REG</a> and <a href="#">RXFLL_REG</a> registers) is received. When this error is detected, current frame reception is terminated. Reception is stopped until the next START flag is detected.</p> | R    | 0        |
| 3    | ABORT          | <p>0x0: No abort pattern error in frame</p> <p>0x1: Abort pattern received. SIR and MIR: abort pattern. FIR: Illegal symbol.</p>                                                                                                                                                                                                                                                                                                                                   | R    | 0        |
| 2    | CRC            | <p>0x0: No CRC error in frame</p> <p>0x1: CRC error in the frame at the top of the STATUS FIFO (next character to be read)</p>                                                                                                                                                                                                                                                                                                                                     | R    | 0        |
| 1    | STS_FIFO_E     | <p>0x0: Status FIFO not empty</p> <p>0x1: Status FIFO empty</p>                                                                                                                                                                                                                                                                                                                                                                                                    | R    | 0        |
| 0    | RX_FIFO_E      | <p>0x0: At least one data character in the RX FIFO</p> <p>0x1: No data in the receive FIFO</p>                                                                                                                                                                                                                                                                                                                                                                     | R    | 1        |

**Table 19-65. XON2\_ADDR2\_REG**

|                         |                                |
|-------------------------|--------------------------------|
| <b>Address Offset</b>   | 0x014                          |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40 |
| <b>Description</b>      |                                |
| <b>Type</b>             | RW                             |
| 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                |
| RESERVED                |                                |
| XON_WORD2               |                                |

| Bits | Field Name | Description                                                                      | Type | Reset    |
|------|------------|----------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0.                                                                  | R    | 0x000000 |
| 7:0  | XON_WORD2  | Stores the 8-bit XON2 character in UART modes and ADDR2 address 2 for IrDA modes | RW   | 0x00     |

**Table 19-66. Register Call Summary for Register XON2\_ADDR2\_REG**

UART/IrDA/CIR Environment

- IrDA Protocol and Data Format: [0]

UART/IrDA/CIR Functional Description

- Register Access Modes: [1] [2]
- UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [3] [4] [5] [6]
- IrDA Mode (UART3 Only): [7]

UART/IrDA/CIR Basic Programming Model

- Hardware and Software Flow Control Configuration: [8] [9]

UART/IrDA/CIR Register Manual

- UART/IrDA/CIR Register Summary: [10] [11]

**Table 19-67. XOFF1\_REG**

|                         |                                |
|-------------------------|--------------------------------|
| <b>Address Offset</b>   | 0x018                          |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40 |
| <b>Description</b>      | UART mode XOFF1 character      |
| <b>Type</b>             | RW                             |
| 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                |
| RESERVED                |                                |
| XOFF_WORD1              |                                |

| Bits | Field Name | Description                                         | Type | Reset    |
|------|------------|-----------------------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0                                      | R    | 0x000000 |
| 7:0  | XOFF_WORD1 | Stores the 8-bit XOFF1 character used in UART modes | RW   | 0x00     |

**Table 19-68. Register Call Summary for Register XOFF1\_REG**

UART/IrDA/CIR Functional Description

- Register Access Modes: [0] [1]
- UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [2] [3]

UART/IrDA/CIR Basic Programming Model

- Hardware and Software Flow Control Configuration: [4] [5] [6]

UART/IrDA/CIR Register Manual

- UART/IrDA/CIR Register Summary: [7] [8]

**Table 19-69. TCR\_REG**

|                         |                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                    |                   |   |   |   |   |   |   |
|-------------------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--------------------|-------------------|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x018                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                    |                   |   |   |   |   |   |   |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                    |                   |   |   |   |   |   |   |
| <b>Description</b>      | Transmission control register.                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                    |                   |   |   |   |   |   |   |
|                         | This register stores the receive FIFO threshold levels to start/stop transmission during hardware flow control. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                    |                   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                    |                   |   |   |   |   |   |   |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                    |                   |   |   |   |   |   |   |
| RESERVED                |                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 7                  | 6                 | 5 | 4 | 3 | 2 | 1 | 0 |
|                         |                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RX_FIFO_TRIG_START | RX_FIFO_TRIG_HALT |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b>  | <b>Description</b>                                      | <b>Type</b> | <b>Reset</b> |
|-------------|--------------------|---------------------------------------------------------|-------------|--------------|
| 31:8        | Reserved           | Read returns 0.                                         | R           | 0x000000     |
| 7:4         | RX_FIFO_TRIG_START | RX FIFO trigger level to RESTORE transmission (0 to 60) | RW          | 0x0          |
| 3:0         | RX_FIFO_TRIG_HALT  | RX FIFO trigger level to HALT transmission (0 to 60)    | RW          | 0xF          |

**Table 19-70. Register Call Summary for Register TCR\_REG**

UART/IrDA/CIR Functional Description

- [FIFO Trigger: \[0\] \[1\] \[2\]](#)
- [FIFO Interrupt Mode: \[3\]](#)
- [Register Access Modes: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\] \[22\] \[23\] \[24\] \[25\] \[26\] \[27\]](#)
- [UART Mode: \[28\] \[29\] \[30\] \[31\] \[32\] \[33\]](#)

UART/IrDA/CIR Basic Programming Model

- [Hardware and Software Flow Control Configuration: \[34\] \[35\] \[36\] \[37\] \[38\] \[39\] \[40\] \[41\] \[42\] \[43\] \[44\] \[45\]](#)

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[46\] \[47\]](#)
- [UART/IrDA/CIR Register Description: \[48\] \[49\]](#)

**Table 19-71. MSR\_REG**

|                         |                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |         |          |          |         |        |         |         |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---------|---------|----------|----------|---------|--------|---------|---------|
| <b>Address Offset</b>   | 0x018                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |         |          |          |         |        |         |         |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |         |          |          |         |        |         |         |
| <b>Description</b>      | Modem status register. UART mode only.                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |         |          |          |         |        |         |         |
|                         | This register provides information about the current state of the control lines from the modem, data set, or peripheral device to the MPU. It also indicates when a control input from the modem changes state. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |         |          |          |         |        |         |         |
| <b>Type</b>             | R                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |         |          |          |         |        |         |         |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |         |          |          |         |        |         |         |
| RESERVED                |                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 7       | 6       | 5        | 4        | 3       | 2      | 1       | 0       |
|                         |                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | NCD_STS | NRI_STS | NDSR_STS | NCTS_STS | DCD_STS | RI_STS | DSR_STS | CTS_STS |

| Bits | Field Name | Description                                                                                                             | Type | Reset    |
|------|------------|-------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0x00.                                                                                                      | R    | 0x000000 |
| 7    | NCD_STS    | In loopback mode, it is equivalent to <a href="#">MCR_REG[3]</a> .                                                      | R    | -        |
| 6    | NRI_STS    | This bit is the complement of the nRI input. In loopback mode, it is equivalent to <a href="#">MCR_REG[2]</a> .         | R    | -        |
| 5    | NDSR_STS   | In loopback mode, it is equivalent to <a href="#">MCR_REG[0]</a> .                                                      | R    | -        |
| 4    | NCTS_STS   | This bit is the complement of the nCTS input. In loopback mode, it is equivalent to <a href="#">MCR_REG[1]</a> .        | R    | -        |
| 3    | DCD_STS    | Indicates that <a href="#">MCR_REG[3]</a> in loopback changed. Cleared on a read.                                       | R    | 0        |
| 2    | RI_STS     | Indicates that nRI input (or <a href="#">MCR_REG[2]</a> in loopback) changed state from low to high. Cleared on a read. | R    | 0        |
| 1    | DSR_STS    |                                                                                                                         | R    | 0        |
|      |            | 0x1: Indicates that <a href="#">MCR_REG[0]</a> in loopback changed state. Cleared on a read.                            |      |          |
| 0    | CTS_STS    |                                                                                                                         | R    | 0        |
|      |            | 0x1: Indicates that nCTS input (or <a href="#">MCR_REG[1]</a> in loopback) changed state. Cleared on a read.            |      |          |

**Table 19-72. Register Call Summary for Register MSR\_REG**

UART/IrDA/CIR Environment

- [UART Interface Description: \[0\] \[1\]](#)

UART/IrDA/CIR Functional Description

- [Register Access Modes: \[2\] \[3\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [UART Mode: \[10\] \[11\]](#)

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[12\] \[13\]](#)
- [UART/IrDA/CIR Register Description: \[14\] \[15\]](#)

**Table 19-73. SPR\_REG**

|                         |                                                                                                                                  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x01C                                                                                                                            |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a>                                                                   |
| <b>Description</b>      | Scratchpad register                                                                                                              |
|                         | This read/write register does not control the module. It is a scratchpad register used by the programmer to hold temporary data. |

**Type**

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPR_WORD |   |   |   |   |   |   |

| Bits | Field Name | Description         | Type | Reset    |
|------|------------|---------------------|------|----------|
| 31:8 | Reserved   | Read returns 0x00.  | R    | 0x000000 |
| 7:0  | SPR_WORD   | Scratchpad register | RW   | 0x00     |

**Table 19-74. Register Call Summary for Register SPR\_REG**

UART/IrDA/CIR Functional Description

- [Register Access Modes: \[0\] \[1\] \[2\] \[3\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\]](#)

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[16\] \[17\]](#)

**Table 19-75. XOFF2\_REG**

|                         |                                |
|-------------------------|--------------------------------|
| <b>Address Offset</b>   | 0x01C                          |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40 |
| <b>Description</b>      | UART mode XOFF2 character.     |
| <b>Type</b>             | RW                             |
| 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                |
|                         | RESERVED                       |
|                         | XOFF_WORD2                     |

| Bits | Field Name | Description                                         | Type | Reset    |
|------|------------|-----------------------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0.                                     | R    | 0x000000 |
| 7:0  | XOFF_WORD2 | Stores the 8-bit XOFF2 character used in UART modes | RW   | 0x00     |

**Table 19-76. Register Call Summary for Register XOFF2\_REG**

UART/IrDA/CIR Functional Description

- [Register Access Modes: \[0\] \[1\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[2\] \[3\]](#)

UART/IrDA/CIR Basic Programming Model

- [Hardware and Software Flow Control Configuration: \[4\] \[5\] \[6\]](#)

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[7\] \[8\]](#)

**Table 19-77. TLR\_REG**

|                         |                                                                                                                             |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x01C                                                                                                                       |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                              |
| <b>Description</b>      | Trigger level register.<br>Stores the programmable transmit and receive FIFO trigger levels used for DMA and IRQ generation |
| <b>Type</b>             | RW                                                                                                                          |
| 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                                                                                                             |
|                         | RESERVED                                                                                                                    |
|                         | RX_FIFO_TRIG_DMA                                                                                                            |
|                         | TX_FIFO_TRIG_DMA                                                                                                            |

| Bits | Field Name       | Description                 | Type | Reset    |
|------|------------------|-----------------------------|------|----------|
| 31:8 | Reserved         | Read returns 0x00.          | R    | 0x000000 |
| 7:4  | RX_FIFO_TRIG_DMA | Receive FIFO trigger level  | RW   | 0x0      |
| 3:0  | TX_FIFO_TRIG_DMA | Transmit FIFO trigger level | RW   | 0x0      |

**Table 19-78. Register Call Summary for Register TLR\_REG**

## UART/IrDA/CIR Functional Description

- FIFO Management: [0]
- FIFO Trigger: [1] [2] [3] [4]
- FIFO Interrupt Mode: [5] [6]
- FIFO DMA Mode Operation: [7] [8] [9] [10]
- Register Access Modes: [11] [12] [13] [14] [15] [16]
- UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [17] [18] [19] [20] [21] [22] [23] [24] [25] [26] [27] [28] [29] [30] [31] [32] [33] [34]

## UART/IrDA/CIR Basic Programming Model

- Quick start: [35] [36] [37] [38] [39] [40]

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary](#): [41] [42]
- [UART/IrDA/CIR Register Description](#): [43] [44] [45] [46] [47]

**Table 19-79. MDR1\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x020                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                                                                                                                                                                                                                                |
| <b>Description</b>      | Mode definition register 1.                                                                                                                                                                                                                                                                                                                                                                   |
|                         | The mode of operation can be programmed by writing to <a href="#">MDR1_REG[2:0]</a> ; therefore, the <a href="#">MDR1_REG</a> must be programmed on startup after configuration of the configuration registers ( <a href="#">DLL_REG</a> , <a href="#">DLH_REG</a> , <a href="#">LCR_REG</a> ). The value of <a href="#">MDR1_REG[2:0]</a> must not be changed again during normal operation. |

  

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name     | Description                                                                                                                                                                                                                                                                                                             | Type | Reset    |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved       | Read returns 0.                                                                                                                                                                                                                                                                                                         | R    | 0x000000 |
| 7    | FRAME_END_MODE | IrDA mode only<br><br>0x0: Frame-length method<br>0x1: Set EOT bit method                                                                                                                                                                                                                                               | RW   | 0        |
| 6    | SIP_MODE       | MIR/FIR modes only. IrDA only.<br><br>0x0: Manual SIP mode: SIP is generated with the control of <a href="#">ACREG_REG[3]</a> .<br>0x1: Automatic SIP mode: SIP is generated after each transmission.                                                                                                                   | RW   | 0        |
| 5    | SCT            | Store and control the transmission.<br><br>0x0: Starts the infrared transmission when a value is written to <a href="#">THR_REG</a><br>0x1: Starts the infrared transmission with the control of <a href="#">ACREG_REG[2]</a><br><br><b>Note:</b> Before starting any transmission, there must be no reception ongoing. | RW   | 0        |
| 4    | SET_TXIR       | Used to configure the infrared transceiver. IrDA only.<br><br>0x0: a) No action if MDR2[7]=0<br>b) TXIR pin output is forced low if MDR2[7]=1                                                                                                                                                                           | RW   | 0        |

| Bits | Field Name  | Description                                                                                                                                                                                                 | Type | Reset |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |             | 0x1: TXIR pin output is forced high (not dependant on value of MDR2[7]).                                                                                                                                    |      |       |
| 3    | IR_SLEEP    |                                                                                                                                                                                                             | RW   | 0     |
|      |             | 0x0: IrDA/CIR sleep mode disabled<br>0x1: IrDA/CIR sleep mode enabled                                                                                                                                       |      |       |
| 2:0  | MODE_SELECT | UART-IrDA-CIR mode selection<br><br>0x0: UART 16x mode<br>0x1: SIR mode<br>0x2: UART 16x auto-baud<br>0x3: UART 13x mode<br>0x4: MIR mode<br>0x5: FIR mode<br>0x6: CIR mode<br>0x7: Disable (default state) | RW   | 0x7   |

**Table 19-80. Register Call Summary for Register MDR1\_REG**

UART/IrDA/CIR Overview

- [UART/IrDA/CIR Overview: \[0\]](#)

UART/IrDA/CIR Environment

- [UART Protocol and Data Format: \[1\]](#)

UART/IrDA/CIR Functional Description

- [Register Access Modes: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\] \[22\] \[23\] \[24\] \[25\] \[26\]](#)
- [UART Mode: \[27\] \[28\] \[29\]](#)
- [IrDA Mode \(UART3 Only\): \[30\] \[31\] \[32\] \[33\] \[34\] \[35\]](#)
- [CIR Mode \(UART3 Only\): \[36\]](#)

UART/IrDA/CIR Basic Programming Model

- [Quick start: \[37\] \[38\] \[39\]](#)
- [SIR Mode: \[40\] \[41\] \[42\] \[43\] \[44\]](#)
- [MIR Mode: \[45\] \[46\] \[47\] \[48\] \[49\] \[50\] \[51\] \[52\]](#)

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[53\] \[54\]](#)
- [UART/IrDA/CIR Register Description: \[55\] \[56\] \[57\] \[58\] \[59\]](#)

**Table 19-81. MDR2\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x024                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a>                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>Description</b>      | Mode definition register 2<br><br>IR-IrDA and IR-CIR modes only<br><br><a href="#">MDR2_REG[0]</a> describes the status of the interrupt in <a href="#">IIR_REG[5]</a> . The IRTX_UNDERRUN bit must be read after an <a href="#">IIR_REG[5]</a> TX_STATUS_IT interrupt occurs. The bits [2:1] of this register set the trigger level for the frame status FIFO (8 entries) and must be programmed before the mode is programmed in <a href="#">MDR1_REG[2:0]</a> . |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------------|-------------|----------------|------------|---------------|---------------|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SET_TXIR_ALT | IRR_XINVERT | CIR_PULSE_MODE | UART_PULSE | STS_FIFO_TRIG | IRTX_UNDERRUN |   |

| Bits | Field Name     | Description                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:8 | Reserved       | Read returns 0x00.                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x00  |
| 7    | SET_TXIR_ALT   | Provide alternate functionnality for MDR1[4] (SET_TXIR)<br><br>0x0: Normal mode.<br>0x1: Alternate mode for SET_TXIR.                                                                                                                                                                                                                                                                        | RW   | 0     |
| 6    | IRR_XINVERT    | Only for IR mode (IrDA and CIR). Invert RX pin in the module before the voting or sampling system logic of the infrared block. This does not affect the RX path in UART modem modes.<br><br>0x0: Inversion is performed.<br>0x1: No inversion is performed.                                                                                                                                  | RW   | 0     |
| 5:4  | CIR_PULSE_MODE | CIR pulse modulation definition. Defines high level of the pulse width associated with a digit:<br><br>0x0: Pulse width of 3 from 12 cycles<br>0x1: Pulse width of 4 from 12 cycles<br>0x2: Pulse width of 5 from 12 cycles<br>0x3: Pulse width of 6 from 12 cycles                                                                                                                          | RW   | 0x00  |
| 3    | UART_PULSE     | UART mode only. Used to allow pulse shaping in UART mode.<br><br>0x0: Normal UART mode<br>0x1: UART mode with pulse shaping                                                                                                                                                                                                                                                                  | RW   | 0     |
| 2:1  | STS_FIFO_TRIG  | Only for IR-IrDA mode<br><br>Frame status FIFO threshold select:<br><br>0x0: 1 entry<br>0x1: 4 entries<br>0x2: 7 entries<br>0x3: 8 entries                                                                                                                                                                                                                                                   | RW   | 0x00  |
| 0    | IRTX_UNDERRUN  | IrDA transmission status interrupt. When the <a href="#">IIR_REG[5]</a> interrupt occurs, the meaning of the interrupt is:<br><br>0x0: The last bit of the frame was transmitted successfully without error.<br>0x1: An underrun occurred. The last bit of the frame was transmitted but with an underrun error. The bit is reset to 0 when the <a href="#">RESUME_REG</a> register is read. | R    | 0     |

**Table 19-82. Register Call Summary for Register MDR2\_REG**

## UART/IrDA/CIR Environment

- [IrDA Protocol and Data Format: \[0\]](#)
- [CIR Protocol and Data Format: \[1\]](#)

## UART/IrDA/CIR Functional Description

- [Register Access Modes: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\] \[22\] \[23\] \[24\] \[25\]](#)
- [IrDA Mode \(UART3 Only\): \[26\] \[27\]](#)
- [CIR Mode \(UART3 Only\): \[28\] \[29\]](#)

**Table 19-82. Register Call Summary for Register MDR2\_REG (continued)**


---

 UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[30\] \[31\]](#)
  - [UART/IrDA/CIR Register Description: \[32\] \[33\] \[34\]](#)
- 

**Table 19-83. TXFLL\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|-------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x028                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a>                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |
| <b>Description</b>      | Transmit frame length register low<br><br>IrDA modes only<br><br>The registers <a href="#">TXFLL_REG</a> and <a href="#">TXFLH_REG</a> hold the 13-bit transmit frame length (expressed in bytes). <a href="#">TXFLL_REG</a> holds the LSBs and <a href="#">TXFLH_REG</a> holds the MSBs. The frame length value is used if the frame length method of frame closing is used. |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |
| <b>Type</b>             | W                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |
| 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                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |       |  |  |  |  |  |  |  |
| RESERVED                |                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  | TXFLL |  |  |  |  |  |  |  |

  

| Bits | Field Name | Description                                   | Type | Reset    |
|------|------------|-----------------------------------------------|------|----------|
| 31:8 | Reserved   | Write has no functional effect.               | W    | 0x000000 |
| 7:0  | TXFLL      | LSB register used to specify the frame length | W    | 0x00     |

**Table 19-84. Register Call Summary for Register TXFLL\_REG**


---

 UART/IrDA/CIR Functional Description

- [Register Access Modes: \[0\] \[1\] \[2\]](#)
  - [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[3\] \[4\] \[5\]](#)
  - [IrDA Mode \(UART3 Only\): \[6\]](#)
- 

UART/IrDA/CIR Basic Programming Model

- [SIR Mode: \[7\]](#)
  - [MIR Mode: \[8\] \[9\]](#)
- 

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[10\] \[11\]](#)
  - [UART/IrDA/CIR Register Description: \[12\] \[13\] \[14\] \[15\]](#)
- 

**Table 19-85. SFLSR\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x028                                                                                                                                                                                                                                                                                                                                          |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a>                                                                                                                                                                                                                                                                                 |
| <b>Description</b>      | Status FIFO line status register<br><br>IrDA modes only<br><br>Reading this register effectively reads frame status information from the status FIFO (this register does not physically exist). Reading this register increments the status FIFO read pointer ( <a href="#">SFREGL_REG</a> and <a href="#">SFREGH_REG</a> must be read first). |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                              |

|                                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| OE_ERROR<br>FRAME_TOO_LONG_ERROR<br>ABORT_DETECT<br>CRC_ERROR<br>RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name   | Description                                                                                                                   | Type | Reset |
|------|--------------|-------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:5 | Reserved     | Read returns 0.                                                                                                               | R    | 0x00  |
| 4    | OE_ERROR     |                                                                                                                               | R    | -     |
|      |              | 0x1: Overrun error in RX FIFO when frame at top of RX FIFO was received. Top of RX FIFO = next frame to be read from RX FIFO. |      |       |
| 3    | FTL_ERROR    | Frame-too-long error                                                                                                          | R    | -     |
|      |              | 0x1: Frame-length too long error in frame at top of RX FIFO                                                                   |      |       |
| 2    | ABORT_DETECT |                                                                                                                               | R    | -     |
|      |              | 0x1: Abort pattern detected in frame at top of RX FIFO                                                                        |      |       |
|      |              | 0x1: CRC error in frame at top of RX FIFO                                                                                     |      |       |
| 1    | CRC_ERROR    |                                                                                                                               | R    | -     |
| 0    | Reserved     | Read returns 0.                                                                                                               | R    | 0     |

**Table 19-86. Register Call Summary for Register SFLSR\_REG**

## UART/IrDA/CIR Functional Description

- [FIFO Management: \[0\]](#)
- [Register Access Modes: \[1\] \[2\] \[3\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[4\] \[5\] \[6\]](#)
- [IrDA Mode \(UART3 Only\): \[7\] \[8\]](#)

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[9\] \[10\]](#)
- [UART/IrDA/CIR Register Description: \[11\] \[12\]](#)

**Table 19-87. RESUME\_REG**

|                         |                                                                                                                                                                                                                                               |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x02C                                                                                                                                                                                                                                         |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a>                                                                                                                                                                                |
| <b>Description</b>      | IR-IrDA and IR-CIR modes only                                                                                                                                                                                                                 |
|                         | This register is used to clear internal flags, which halt transmission/reception when an underrun/overrun error occurs. Reading this register resumes the halted operation. This register does not physically exist and always reads as 0x00. |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RESUME |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                        | Type | Reset    |
|------|------------|------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0x00                  | R    | 0x000000 |
| 7:0  | RESUME     | Dummy read to restart the TX or RX | R    | 0x00     |

**Table 19-88. Register Call Summary for Register RESUME\_REG**


---

 UART/IrDA/CIR Functional Description

- Register Access Modes: [0] [1] [2]
  - UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [3] [4] [5] [6] [7] [8]
  - UART Mode: [9]
  - IrDA Mode (UART3 Only): [10] [11] [12]
- 

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary](#): [13] [14]
  - [UART/IrDA/CIR Register Description](#): [15]
- 

**Table 19-89. TXFLH\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |       |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|-------|
| <b>Address Offset</b>   | 0x02C                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |       |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a>                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |       |
| <b>Description</b>      | Transmit frame length register low<br><br>IrDA modes only<br><br>The registers <a href="#">TXFLL_REG</a> and <a href="#">TXFLH_REG</a> hold the 13-bit transmit frame length (expressed in bytes). <a href="#">TXFLL_REG</a> holds the LSBs and <a href="#">TXFLH_REG</a> holds the MSBs. The frame length value is used if the frame length method of frame closing is used. |  |  |  |  |  |  |       |
| <b>Type</b>             | W                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |       |
| 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                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |       |
| RESERVED                |                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  | TXFLH |

  

| Bits | Field Name | Description                                   | Type | Reset     |
|------|------------|-----------------------------------------------|------|-----------|
| 31:5 | Reserved   | Read returns 0.                               | R    | 0x0000000 |
| 4:0  | TXFLH      | MSB register used to specify the frame length | W    | 0x00      |

**Table 19-90. Register Call Summary for Register TXFLH\_REG**


---

 UART/IrDA/CIR Functional Description

- Register Access Modes: [0] [1] [2]
  - UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [3] [4] [5]
  - IrDA Mode (UART3 Only): [6]
- 

## UART/IrDA/CIR Basic Programming Model

- [MIR Mode](#): [7]
- 

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary](#): [8] [9]
  - [UART/IrDA/CIR Register Description](#): [10] [11] [12] [13]
-

**Table 19-91. RXFLL\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x030                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>Description</b>      | Received frame length register low<br><br>IrDA modes only                                                                                                                                                                                                                                                                                                                                                                                                |
|                         | The registers <b>RXFLL_REG</b> and <b>RXFLH_REG</b> hold the 12-bit receive maximum frame length. <b>RXFLL_REG</b> holds the LSBs, and <b>RXFLH_REG</b> holds the MSBs. If the intended maximum receive frame length is n bytes, program <b>RXFLL_REG</b> and <b>RXFLH_REG</b> to be n + 3 in SIR or MIR modes and n + 6 in FIR mode (+3 and +6 are the result of frame format with CRC and stop flag; two bytes are associated with the FIR stop flag). |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         |                       | RXFLL           |

| Bits | Field Name | Description                                                | Type | Reset |
|------|------------|------------------------------------------------------------|------|-------|
| 15:8 | Reserved   | Write has no functional effect.                            | W    | 0x00  |
| 7:0  | RXFLL      | LSB register used to specify the frame length in reception | W    | 0x00  |

**Table 19-92. Register Call Summary for Register RXFLL\_REG**

## UART/IrDA/CIR Functional Description

- Register Access Modes: [0] [1] [2]
- UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [3] [4] [5]

## UART/IrDA/CIR Basic Programming Model

- MIR Mode: [6] [7]

## UART/IrDA/CIR Register Manual

- UART/IrDA/CIR Register Summary: [8] [9]
- UART/IrDA/CIR Register Description: [10] [11] [12] [13] [14] [15] [16]

**Table 19-93. SFREGL\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x030                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Description</b>      | Status FIFO register low<br><br>IrDA modes only                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                         | The frame lengths of received frames are written into the status FIFO. This information can be read by reading the <b>SFREGL_REG</b> and <b>SFREGH_REG</b> registers (these registers do not physically exist). The LSBs are read from <b>SFREGL_REG</b> , and the MSBs are read from <b>SFREGH_REG</b> . Reading these registers does not alter the status FIFO read pointer. These registers must be read before the pointer is incremented by reading the <b>SFLSR_REG</b> . |

|                       |                 |
|-----------------------|-----------------|
| 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0 |
| Reserved              | SFREGL          |

| Bits | Field Name | Description                  | Type | Reset    |
|------|------------|------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0x00.           | R    | 0x000000 |
| 7:0  | SFREGL     | LSB part of the frame length | R    | 0x-      |

**Table 19-94. Register Call Summary for Register SFREGL\_REG**

## UART/IrDA/CIR Functional Description

- [FIFO Management: \[0\]](#)
- [Register Access Modes: \[1\] \[2\] \[3\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[4\] \[5\] \[6\]](#)
- [IrDA Mode \(UART3 Only\): \[7\]](#)

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[8\] \[9\]](#)
- [UART/IrDA/CIR Register Description: \[10\] \[11\] \[12\] \[13\] \[14\]](#)

**Table 19-95. SFREGH\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x034                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>Description</b>      | Status FIFO register high<br><br>IrDA modes only<br><br>The frame lengths of received frames are written into the status FIFO. This information can be read by reading the <a href="#">SFREGL_REG</a> and <a href="#">SFREGH_REG</a> registers (these registers do not physically exist). The LSBs are read from <a href="#">SFREGL_REG</a> , and the MSBs are read from <a href="#">SFREGH_REG</a> . Reading these registers does not alter the status FIFO read pointer. These registers must be read before the pointer is incremented by reading the <a href="#">SFLSR_REG</a> . |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |   |        |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|---|--------|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RESERVED |   | SFREGH |   |   |   |   |   |   |   |

| Bits | Field Name | Description                  | Type | Reset     |
|------|------------|------------------------------|------|-----------|
| 31:4 | Reserved   | Read returns 0.              | R    | 0x0000000 |
| 3:0  | SFREGH     | MSB part of the frame length | R    | 0x-       |

**Table 19-96. Register Call Summary for Register SFREGH\_REG**

## UART/IrDA/CIR Functional Description

- [FIFO Management: \[0\]](#)
- [Register Access Modes: \[1\] \[2\] \[3\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[4\] \[5\] \[6\]](#)
- [IrDA Mode \(UART3 Only\): \[7\]](#)

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[8\] \[9\]](#)
- [UART/IrDA/CIR Register Description: \[10\] \[11\] \[12\] \[13\] \[14\]](#)

**Table 19-97. RXFLH\_REG**

| <b>Address Offset</b>   | 0x034                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                            |      |           |  |  |  |  |  |  |  |  |  |  |  |          |  |       |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|------|-----------|--|--|--|--|--|--|--|--|--|--|--|----------|--|-------|--|
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                            |      |           |  |  |  |  |  |  |  |  |  |  |  |          |  |       |  |
| <b>Description</b>      | Received frame length register high<br><br>IrDA modes only<br><br>The registers RXFLL_REG and RXFLH_REG hold the 12-bit receive maximum frame length. RXFLL_REG holds the LSBs, and RXFLH_REG holds the MSBs. If the intended maximum receive frame length is n bytes, program RXFLL_REG and RXFLH_REG to be n + 3 in SIR or MIR modes and n + 6 in FIR mode (+3 and +6 are the result of frame format with CRC and stop flag; there are two bytes associated with the FIR stop flag). |                                                            |      |           |  |  |  |  |  |  |  |  |  |  |  |          |  |       |  |
| <b>Type</b>             | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                            |      |           |  |  |  |  |  |  |  |  |  |  |  |          |  |       |  |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                            |      |           |  |  |  |  |  |  |  |  |  |  |  |          |  |       |  |
| RESERVED                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                            |      |           |  |  |  |  |  |  |  |  |  |  |  | RESERVED |  | RXFLH |  |
| Bits                    | Field Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Description                                                | Type | Reset     |  |  |  |  |  |  |  |  |  |  |  |          |  |       |  |
| 31:4                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Write has no functional effect.                            | W    | 0x0000000 |  |  |  |  |  |  |  |  |  |  |  |          |  |       |  |
| 3:0                     | RXFLH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | MSB register used to specify the frame length in reception | W    | 0x0       |  |  |  |  |  |  |  |  |  |  |  |          |  |       |  |

**Table 19-98. Register Call Summary for Register RXFLH\_REG**

## UART/IrDA/CIR Functional Description

- Register Access Modes: [0] [1] [2]
- UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [3] [4] [5]

## UART/IrDA/CIR Basic Programming Model

- MIR Mode: [6]

## UART/IrDA/CIR Register Manual

- UART/IrDA/CIR Register Summary: [7] [8]
- UART/IrDA/CIR Register Description: [9] [10] [11] [12] [13] [14] [15]

**Table 19-99. BLR\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                |  |           |  |          |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------------|--|-----------|--|----------|--|
| <b>Address Offset</b>   | 0x038                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                |  |           |  |          |  |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                |  |           |  |          |  |
| <b>Description</b>      | BOF control register<br><br>IrDA modes only<br><br>BLR_REG[6] is used to select whether 0xC0 or 0xFF start patterns are to be used, when multiple start flags are required in SIR mode. If only one start flag is required, this is always 0xC0. If n start flags are required, either (-1) 0xC0 or (-1) 0xFF flags are sent, followed by a single 0xC0 flag (immediately preceding the first data byte). |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                |  |           |  |          |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                |  |           |  |          |  |
| 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                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                |  |           |  |          |  |
| RESERVED                |                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  | STS_FIFO_RESET |  | XBOF_TYPE |  | RESERVED |  |

| Bits | Field Name     | Description                                   | Type | Reset     |
|------|----------------|-----------------------------------------------|------|-----------|
| 31:8 | Reserved       | Read returns 0.                               | R    | 0x0000000 |
| 7    | STS_FIFO_RESET | Status FIFO reset. This bit is self-clearing. | RW   | 0         |
| 6    | XBOF_TYPE      | SIR xBOF select                               | RW   | 1         |

| Bits | Field Name | Description            | Type | Reset |
|------|------------|------------------------|------|-------|
|      |            | 0x0: 0xFF<br>0x1: 0xC0 |      |       |
| 5:0  | Reserved   | Read returns 0x00.     | R    | 0x00  |

**Table 19-100. Register Call Summary for Register BLR\_REG**

UART/IrDA/CIR Environment

- [IrDA Protocol and Data Format: \[0\]](#)

UART/IrDA/CIR Functional Description

- [Register Access Modes: \[1\] \[2\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[3\] \[4\]](#)

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[5\] \[6\]](#)
- [UART/IrDA/CIR Register Description: \[7\]](#)

**Table 19-101. UASR\_REG**

|                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                    |          |  |  |  |  |  |             |             |             |             |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--|--|--|--|--|-------------|-------------|-------------|-------------|-------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                       | 0x038                                                                                                                                                                                                                                                                                                                                                                                              |          |  |  |  |  |  |             |             |             |             |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b>                                                                     | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a>                                                                                                                                                                                                                                                                                                                                     |          |  |  |  |  |  |             |             |             |             |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                          | UART autobauding status register<br><br>UART autobauding mode only<br><br>This status register returns the speed, the number of bits by characters, and the type of parity in UART autobauding mode.<br><br>In autobauding mode, the input frequency of the UART modem must be fixed to 48 MHz. Any other module clock frequency results in incorrect baud rate recognition.                       |          |  |  |  |  |  |             |             |             |             |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                 | R                                                                                                                                                                                                                                                                                                                                                                                                  |          |  |  |  |  |  |             |             |             |             |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | <table border="1"> <tr> <td colspan="8" style="text-align: center;">RESERVED</td> <td rowspan="2" style="vertical-align: middle; padding: 0 5px;">PARITY_TYPE</td> <td rowspan="2" style="vertical-align: middle; padding: 0 5px;">BIT_BY_CHAR</td> <td colspan="4" style="text-align: center;">SPEED</td> </tr> <tr> <td colspan="8"></td> <td></td> <td></td> <td></td> <td></td> </tr> </table> | RESERVED |  |  |  |  |  |             |             | PARITY_TYPE | BIT_BY_CHAR | SPEED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                    |          |  |  |  |  |  | PARITY_TYPE | BIT_BY_CHAR |             |             | SPEED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                    |          |  |  |  |  |  |             |             |             |             |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits | Field Name  | Description                                                                                                                                                          | Type | Reset     |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:8 | Reserved    | Read returns 0.                                                                                                                                                      | R    | 0x0000000 |
| 7:6  | PARITY_TYPE | 0x0: No parity identified<br>0x1: Parity space<br>0x2: Even parity<br>0x3: Odd parity                                                                                | R    | 0x0       |
| 5    | BIT_BY_CHAR | 0x0: 7-bit character identified<br>0x1: 8-bit character identified                                                                                                   | R    | 0         |
| 4:0  | SPEED       | Used to report the speed identified<br>0x0: No speed identified<br>0x1: 115 200 baud<br>0x2: 57 600 baud<br>0x3: 38 400 baud<br>0x4: 28 800 baud<br>0x5: 19 200 baud | R    | 0x00      |

| Bits | Field Name | Description      | Type | Reset |
|------|------------|------------------|------|-------|
|      |            | 0x6: 14 400 baud |      |       |
|      |            | 0x7: 9 600 baud  |      |       |
|      |            | 0x8: 4 800 baud  |      |       |
|      |            | 0x9: 4 800 baud  |      |       |
|      |            | 0xA: 1 200 baud  |      |       |

**Table 19-102. Register Call Summary for Register UASR\_REG**

UART/IrDA/CIR Functional Description

- [Register Access Modes: \[0\] \[1\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[2\] \[3\]](#)
- [UART Mode: \[4\] \[5\] \[6\]](#)

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[7\] \[8\]](#)

**Table 19-103. ACREG\_REG**

|                  |                                                                |
|------------------|----------------------------------------------------------------|
| Address Offset   | 0x03C                                                          |
| Physical Address | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a> |
| Description      | Auxiliary control register                                     |
| Type             | RW                                                             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name      | Description                                                                                                                                                                              | Type | Reset |
|------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:8 | Reserved        | Read returns 0.                                                                                                                                                                          | R    | 0x00  |
| 7    | PULSE_TYPE      | SIR pulse-width select:<br><br>0x0: 3/16 of baud-rate pulse width<br>0x1: 1.6 µs                                                                                                         | RW   | 0     |
| 6    | SD_MOD          | Primary output used to configure transceivers. Connected to the SD/MODE input pin of IrDA transceivers.<br><br>0x0: SD pin is set to high.<br>0x1: SD pin is set to low.                 | RW   | 0     |
| 5    | DIS_IR_RX       | 0x0: Normal operation (RX input automatically disabled during transmit, but enabled outside of transmit operation).<br>0x1: Disables RX input (permanent state; independent of transmit) | RW   | 0     |
| 4    | DIS_TX_UNDERRUN | 0x0: Long stop bits cannot be transmitted. TX underrun is enabled.<br>0x1: Long stop bits can be transmitted. TX underrun is disabled.                                                   | RW   | 0     |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                       | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3    | SEND_SIP   | MIR/FIR modes only. Send serial infrared interaction pulse (SIP).<br><br>If this bit is set during an MIR/FIR transmission, the SIP is sent at the end of it. This bit is automatically cleared at the end of the SIP transmission.<br><br>0x0: No action<br>0x1: Send SIP pulse. | RW   | 0     |
| 2    | SCTX_EN    | Store and control TX start. When <a href="#">MDR1_REG</a> [5] = 1 and the MPU writes 1 to this bit, the TX state-machine starts frame transmission. This bit is self-clearing.                                                                                                    | RW   | 0     |
| 1    | ABORT_EN   | Frame abort. The MPU can intentionally abort transmission of a frame by writing 1 to this bit. Neither the end flag nor the CRC bits are appended to the frame.                                                                                                                   | RW   | 0     |
| 0    | EOT_EN     | EOT (end-of-transmission) bit. The MPU writes 1 to this bit just before it writes the last byte to the TX FIFO in the set-EOT bit frame-closing method. This bit is automatically cleared when the MPU writes to the <a href="#">THR_REG</a> (TX FIFO).                           | RW   | 0     |

**Table 19-104. Register Call Summary for Register ACREG\_REG**

## UART/IrDA/CIR Environment

- [UART3 Interface Description](#): [0]
- [IrDA Protocol and Data Format](#): [1] [2] [3] [4]
- [CIR Interface Description](#): [5]

## UART/IrDA/CIR Functional Description

- [Register Access Modes](#): [6] [7]
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection](#): [8] [9] [10] [11]
- [IrDA Mode \(UART3 Only\)](#): [12] [13] [14] [15] [16] [17] [18]
- [CIR Mode \(UART3 Only\)](#): [19] [20]

## UART/IrDA/CIR Basic Programming Model

- [SIR Mode](#): [21]
- [MIR Mode](#): [22]

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary](#): [23] [24]
- [UART/IrDA/CIR Register Description](#): [25] [26]

**Table 19-105. SCR\_REG**

|                         |                                                                |
|-------------------------|----------------------------------------------------------------|
| <b>Address Offset</b>   | 0x040                                                          |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a> |
| <b>Description</b>      | Supplementary control register                                 |
| <b>Type</b>             | RW                                                             |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name      | Description                                                                                                 | Type | Reset    |
|------|-----------------|-------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved        | Read returns 0.                                                                                             | R    | 0x000000 |
| 7    | RX_TRIG_GRANU1  |                                                                                                             | RW   | 0        |
|      |                 | 0x0: Disables the granularity of 1 for TRIGGER RX level                                                     |      |          |
|      |                 | 0x1: Enables the granularity of 1 for TRIGGER RX level                                                      |      |          |
| 6    | TX_TRIG_GRANU1  |                                                                                                             | RW   | 0        |
|      |                 | 0x0: Disables the granularity of 1 for TRIGGER TX level                                                     |      |          |
|      |                 | 0x1: Enables the granularity of 1 for trigger TX level                                                      |      |          |
| 5    | RESERVED        | Read returns 0. Write has no functional effect.                                                             | R    | 0        |
| 4    | RX_CTS_WU_EN    | RX CTS wake-up enable                                                                                       | RW   | 0        |
|      |                 | 0x0: Disables the WAKE UP interrupt and clears <a href="#">SSR_REG[1]</a>                                   |      |          |
|      |                 | 0x1: Waits for a falling edge of pins RX, nCTS, or nDSR to generate an interrupt                            |      |          |
| 3    | TX_EMPTY_CTL_IT |                                                                                                             | RW   | 0        |
|      |                 | 0x0: Normal mode for THR interrupt (see <a href="#">Table 19-33</a> for details about UART mode interrupts) |      |          |
|      |                 | 0x1: The THR interrupt is generated when TX FIFO and TX shift register are empty.                           |      |          |
| 2:1  | DMA_MODE_2      | Specifies the DMA mode valid if <a href="#">SCR_REG[0] = 1</a>                                              | RW   | 0x0      |
|      |                 | 0x0: DMA mode 0 (no DMA)                                                                                    |      |          |
|      |                 | 0x1: DMA mode 1 (UART <i>i</i> _DMA_TX, UART <i>i</i> _DMA_RX)                                              |      |          |
|      |                 | 0x2: DMA mode 2 (UART <i>i</i> _DMA_RX)                                                                     |      |          |
|      |                 | 0x3: DMA mode 3 (UART <i>i</i> _DMA_TX)                                                                     |      |          |
| 0    | DMA_MODE_CTL    |                                                                                                             | RW   | 0        |
|      |                 | 0x0: The DMA_MODE is set with <a href="#">FCR_REG[3]</a> .                                                  |      |          |
|      |                 | 0x1: The DMA_MODE is set with <a href="#">SCR_REG[2:1]</a> .                                                |      |          |

**Table 19-106. Register Call Summary for Register SCR\_REG**

## UART/IrDA/CIR Functional Description

- [FIFO Management: \[0\]](#)
- [FIFO Trigger: \[1\] \[2\]](#)
- [FIFO DMA Mode Operation: \[3\] \[4\]](#)
- [Register Access Modes: \[5\] \[6\] \[7\] \[8\] \[9\] \[10\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\] \[22\] \[23\] \[24\] \[25\] \[26\] \[27\] \[28\]](#)
- [UART Mode: \[29\] \[30\]](#)
- [UART Mode Power Management: \[31\]](#)

## UART/IrDA/CIR Basic Programming Model

- [Quick start: \[32\] \[33\] \[34\] \[35\] \[36\] \[37\] \[38\] \[39\]](#)

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[40\] \[41\]](#)
- [UART/IrDA/CIR Register Description: \[42\] \[43\] \[44\] \[45\] \[46\] \[47\] \[48\] \[49\] \[50\] \[51\]](#)

**Table 19-107. SSR\_REG**

|                         |                                |
|-------------------------|--------------------------------|
| <b>Address Offset</b>   | 0x044                          |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40 |
| <b>Description</b>      | Supplementary status register  |
| <b>Type</b>             | R                              |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                 |   |   |   |                        |   |   |   |              |  |  |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----------------|---|---|---|------------------------|---|---|---|--------------|--|--|--|
| 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 |              |  |  |  |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DMA_COUNTER_RST |   |   |   | RX_CTS_DSR_WAKE_UP_STS |   |   |   | TX_FIFO_FULL |  |  |  |

| Bits | Field Name             | Description                                                                                                                                                                                                                 | Type | Reset      |
|------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 15:3 | Reserved               | Read returns 0.                                                                                                                                                                                                             | R    | 0x00000000 |
| 2    | DMA_COUNTER_RST        | DMA counter reset.<br><br>0x0: The DMA counter will not be reset if the corresponding FIFO is reset (via FCR[1] or FCR[2])<br><br>0x1: The DMA counter will be reset if corresponding FIFO is reset (via FCR[1] or FCR[2]). | RW   | 1          |
| 1    | RX_CTS_DSR_WAKE_UP_STS | Pin falling edge detection: Reset only when <a href="#">SCR_REG</a> [4] is reset to 0.<br><br>0x0: No falling-edge event on RX, nCTS, and nDSR<br>0x1: A falling edge occurred on RX, nCTS, or nDSR.                        | R    | 0          |
| 0    | TX_FIFO_FULL           | TX FIFO status.<br><br>0x0: TX FIFO is not full.<br>0x1: TX FIFO is full.                                                                                                                                                   | R    | 0          |

**Table 19-108. Register Call Summary for Register SSR\_REG**

## UART/IrDA/CIR Functional Description

- [FIFO Management: \[0\]](#)
- [Register Access Modes: \[1\] \[2\] \[3\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\]](#)
- [UART Mode: \[13\]](#)

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[14\] \[15\]](#)
- [UART/IrDA/CIR Register Description: \[16\]](#)

**Table 19-109. EBLR\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x048                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Description</b>      | BOF length register.<br>IR-IrDA mode only<br>In IR-IrDA SIR operation, this register specifies the number of BOF + xBOFs to transmit. Value set into this register must consider the BOF character; therefore, to send only one BOF with no XBOF, this register must be set to 1. To send one BOF with N XBOF, this register must be set to N + 1. Furthermore, the value 0 sends 1 BOF plus 255 XBOF.<br>In IR-IrDA MIR mode, this register specifies the number of additional start flags (MIR protocol mandates a minimum of 2 start flags). |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | EBLR |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                      | Type | Reset    |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0.                                                                                                                                                                                                                                                                                  | R    | 0x000000 |
| 7:0  | EBLR       | IR-IrDA mode: This register allows definition of up to 176 xBOFs, the maximum required by IrDA specification.<br>IR-CIR mode: N/A<br>0x00: Feature disabled<br>0x01: Generate RX_STOP interrupt after receiving one zero bit.<br>0xFF: Generate RX_STOP interrupt after receiving 255 zero bits. | RW   | 0x00     |

**Table 19-110. Register Call Summary for Register EBLR\_REG**

## UART/IrDA/CIR Functional Description

- [Register Access Modes: \[0\] \[1\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[2\] \[3\] \[4\] \[5\]](#)
- [CIR Mode \(UART3 Only\): \[6\] \[7\] \[8\]](#)

## UART/IrDA/CIR Basic Programming Model

- [SIR Mode: \[9\]](#)
- [MIR Mode: \[10\]](#)

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[11\] \[12\]](#)

**Table 19-111. MVR\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                           |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x050                                                                                                                                                                                                                                                                                                                                     |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                                                                                                                                                                            |
| <b>Description</b>      | Module version register                                                                                                                                                                                                                                                                                                                   |
|                         | The reset value is fixed by hardware and corresponds to the RTL revision of this module. A reset has no effect on the value returned.                                                                                                                                                                                                     |
|                         | UART/IrDA SIR only module is revision 1.x (WMU_012_1 specification).<br>UART/IrDA with SIR, MIR, and FIR support is revision 2.x (WMU_012_2 specification).<br>UART/IrDA with SIR, MIR, and FIR/CIR support is revision 3.x (this specification). For example: <b>MVR_REG</b> = 0x30 => version 3.0 <b>MVR_REG</b> = 0x38 => version 3.8. |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                         |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |           |           |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----------|-----------|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | MAJOR_REV | MINOR_REV |   |   |   |   |

| Bits | Field Name | Description                  | Type | Reset              |
|------|------------|------------------------------|------|--------------------|
| 31:8 | Reserved   | Read returns 0.              | R    | 0x0000000          |
| 7:4  | MAJOR_REV  | Major revision of the module | R    | See <sup>(1)</sup> |
| 3:0  | MINOR_REV  | Minor revision of the module | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 19-112. Register Call Summary for Register MVR\_REG**

UART/IrDA/CIR Functional Description

- [Register Access Modes: \[0\]](#) [\[1\]](#) [\[2\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[3\]](#) [\[4\]](#) [\[5\]](#) [\[6\]](#) [\[7\]](#) [\[8\]](#) [\[9\]](#) [\[10\]](#) [\[11\]](#)

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[12\]](#) [\[13\]](#)
- [UART/IrDA/CIR Register Description: \[14\]](#) [\[15\]](#)

**Table 19-113. SYSC\_REG**

|                         |                                                                                                                                                                                                                                                                                                           |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x054                                                                                                                                                                                                                                                                                                     |
| <b>Physical Address</b> | See Table 19-39 to Table 19-40                                                                                                                                                                                                                                                                            |
| <b>Description</b>      | System configuration register.                                                                                                                                                                                                                                                                            |
|                         | The auto idle bit controls a power-saving technique to reduce the logic power consumption of the module interface; that is, when the feature is enabled, the interface clock is gated off until the module interface is accessed. When the software reset bit is set high, it causes a full device reset. |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                        |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |          |           |           |          |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----------|-----------|-----------|----------|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | IDLEMODE | ENAWAKEUP | SOFTRESET | AUTOIDLE |   |   |
|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |          |           |           |          |   |   |

| Bits | Field Name | Description                                                    | Type | Reset       |
|------|------------|----------------------------------------------------------------|------|-------------|
| 31:5 | Reserved   | Read returns 0.                                                | R    | 0x000000000 |
| 4:3  | IDLEMODE   | Power management req/ack control                               | RW   | 0x0         |
|      |            | 0x0: Force idle: Idle request is acknowledged unconditionally. |      |             |
|      |            | 0x1: No-idle: Idle request is never acknowledged.              |      |             |

| Bits | Field Name | Description                                                                                                                                                                    | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x2: Smart idle: Idle request is acknowledged based on the internal module activity.<br>0x3: Reserved                                                                          |      |       |
| 2    | ENAWAKEUP  | Wakeup control<br>0x0: Wakeup is disabled.<br>0x1: Wakeup capability is enabled.                                                                                               | RW   | 0     |
| 1    | SOFTRESET  | Software reset. Set this bit to 1 to trigger a module reset. This bit is automatically reset by the hardware. Read returns 0.<br>0x0: Normal mode<br>0x1: The module is reset. | RW   | 0     |
| 0    | AUTOIDLE   | Internal interface clock-gating strategy<br>0x0: Clock is running.<br>0x1: Automatic interface clock-gating strategy is applied based on interface activity.                   | RW   | 0     |

**Table 19-114. Register Call Summary for Register SYSC\_REG**

## UART/IrDA/CIR Integration

- [Clocking: \[0\]](#)
- [Software Reset: \[1\]](#)

## UART/IrDA/CIR Functional Description

- [Register Access Modes: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\] \[22\] \[23\] \[24\] \[25\]](#)
- [UART Mode Power Management: \[26\]](#)

## UART/IrDA/CIR Basic Programming Model

- [Quick start: \[27\]](#)

## UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[28\] \[29\]](#)

**Table 19-115. SYSS\_REG**

|                         |                                                                |
|-------------------------|----------------------------------------------------------------|
| <b>Address Offset</b>   | 0x058                                                          |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a> |
| <b>Description</b>      | System status register                                         |
| <b>Type</b>             | R                                                              |
| 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  |
|                         | RESERVED                                                       |
|                         | RESETDONE                                                      |

| Bits | Field Name | Description                                                                                | Type | Reset     |
|------|------------|--------------------------------------------------------------------------------------------|------|-----------|
| 31:1 | Reserved   | Read returns 0.                                                                            | R    | 0x0000000 |
| 0    | RESETDONE  | Internal reset monitoring<br>0x0: Internal module reset is ongoing.<br>0x1: Reset complete | R    | 0         |

**Table 19-116. Register Call Summary for Register SYSS\_REG**

UART/IrDA/CIR Functional Description

- [Register Access Modes: \[0\] \[1\] \[2\]](#)
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\]](#)

UART/IrDA/CIR Basic Programming Model

- [Quick start: \[12\]](#)

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary: \[13\] \[14\]](#)

**Table 19-117. WER\_REG**

|                         |                                                |
|-------------------------|------------------------------------------------|
| <b>Address Offset</b>   | 0x05C                                          |
| <b>Physical Address</b> | <a href="#">See Table 19-39 to Table 19-40</a> |
| <b>Description</b>      | Wake-up enable register                        |
| <b>Type</b>             | RW                                             |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name            | Description                                                                                                                                                                              | Type | Reset    |
|------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | Reserved              | Read returns 0x00.                                                                                                                                                                       | R    | 0x000000 |
| 7    | EVENT_7_TX_WAKEUP_EN  | Receiver line status interrupt<br><br>0x0: Event is not allowed to wake up the system.<br>0x1: EVENT CAN WAKE UP THE SYSTEM: Event can be: THR_IT or TX_DMA request and/or TX_STATUS_IT. | RW   | 1        |
| 6    | EVENT_6_RLS_INTERRUPT | Receiver line status interrupt<br><br>0x0: Event is not allowed to wake up the system.<br>0x1: Event can wake up the system.                                                             | RW   | 1        |
| 5    | EVENT_5_RHR_INTERRUPT | <br><br>0x0: Event is not allowed to wake up the system.<br>0x1: Event can wake up the system.                                                                                           | RW   | -        |
| 4    | EVENT_4_RX_ACTIVITY   | <br><br>0x0: Event is not allowed to wake up the system.                                                                                                                                 | RW   | 1        |

| Bits | Field Name           | Description                                                                                                  | Type | Reset |
|------|----------------------|--------------------------------------------------------------------------------------------------------------|------|-------|
|      |                      | 0x1: Event can wake up the system.                                                                           |      |       |
| 3    | RESERVED             | Read returns 1. Must be set to 1 for correct behavior.                                                       | RW   | 1     |
| 2    | EVENT_2_RI_ACTIVITY  |                                                                                                              | RW   | 1     |
|      |                      | 0x0: Event is not allowed to wake up the system.<br>0x1: Event can wake up the system.                       |      |       |
| 1    | RESERVED             | Read returns 1. Must be set to 1 for correct behavior.                                                       | RW   | 1     |
| 0    | EVENT_0_CTS_ACTIVITY | UART mode only<br><br>0x0: Event is not allowed to wake up the system.<br>0x1: Event can wake up the system. | RW   | 1     |

**Table 19-118. Register Call Summary for Register WER\_REG**

UART/IrDA/CIR Functional Description

- Register Access Modes: [0] [1] [2] [3] [4] [5]
- UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23]
- UART Mode Power Management: [24]

UART/IrDA/CIR Register Manual

- UART/IrDA/CIR Register Summary: [25] [26]

**Table 19-119. CFPS\_REG**

|                         |                                                               |
|-------------------------|---------------------------------------------------------------|
| Address Offset          | 0x060                                                         |
| Physical Address        | See Table 19-39 to Table 19-40                                |
| Description             | Carrier frequency prescaler                                   |
| Type                    | RW                                                            |
| 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 |
| RESERVED                | CFPS                                                          |

| Bits              | Field Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type              | Reset          |                  |    |     |       |       |     |       |    |     |       |      |     |       |    |     |      |    |     |    |      |    |       |    |      |
|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------|------------------|----|-----|-------|-------|-----|-------|----|-----|-------|------|-----|-------|----|-----|------|----|-----|----|------|----|-------|----|------|
| 31:8              | Reserved       | Read returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R                 | 0x000000       |                  |    |     |       |       |     |       |    |     |       |      |     |       |    |     |      |    |     |    |      |    |       |    |      |
| 7:0               | CFPS           | Because the consumer IR works at modulation rates of 30-56.8 kHz, the 48-MHz clock must be prescaled before the clock can drive the IR logic. This register sets the divisor rate to give a range to accommodate remote-control requirements in BAUD multiples of 12x. The value of the CFPS at reset is 0105 (decimal), which equates to a 38.1-kHz output from starting conditions. The 48-MHz carrier is prescaled by the CFPS, which is then divided by the 12x BAUD multiple.<br><br>Example:<br><table border="1" style="margin-left: 20px;"> <thead> <tr> <th>Target Freq (kHz)</th> <th>CFPS (decimal)</th> <th>Actual Freq(kHz)</th> </tr> </thead> <tbody> <tr> <td>30</td> <td>133</td> <td>30.08</td> </tr> <tr> <td>32.75</td> <td>122</td> <td>32.79</td> </tr> <tr> <td>36</td> <td>111</td> <td>36.04</td> </tr> <tr> <td>36.7</td> <td>109</td> <td>36.69</td> </tr> <tr> <td>38</td> <td>105</td> <td>38.1</td> </tr> <tr> <td>40</td> <td>100</td> <td>40</td> </tr> <tr> <td>56.8</td> <td>70</td> <td>57.14</td> </tr> </tbody> </table><br>CFPS = 0 is not supported. | Target Freq (kHz) | CFPS (decimal) | Actual Freq(kHz) | 30 | 133 | 30.08 | 32.75 | 122 | 32.79 | 36 | 111 | 36.04 | 36.7 | 109 | 36.69 | 38 | 105 | 38.1 | 40 | 100 | 40 | 56.8 | 70 | 57.14 | RW | 0x69 |
| Target Freq (kHz) | CFPS (decimal) | Actual Freq(kHz)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   |                |                  |    |     |       |       |     |       |    |     |       |      |     |       |    |     |      |    |     |    |      |    |       |    |      |
| 30                | 133            | 30.08                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                   |                |                  |    |     |       |       |     |       |    |     |       |      |     |       |    |     |      |    |     |    |      |    |       |    |      |
| 32.75             | 122            | 32.79                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                   |                |                  |    |     |       |       |     |       |    |     |       |      |     |       |    |     |      |    |     |    |      |    |       |    |      |
| 36                | 111            | 36.04                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                   |                |                  |    |     |       |       |     |       |    |     |       |      |     |       |    |     |      |    |     |    |      |    |       |    |      |
| 36.7              | 109            | 36.69                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                   |                |                  |    |     |       |       |     |       |    |     |       |      |     |       |    |     |      |    |     |    |      |    |       |    |      |
| 38                | 105            | 38.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                   |                |                  |    |     |       |       |     |       |    |     |       |      |     |       |    |     |      |    |     |    |      |    |       |    |      |
| 40                | 100            | 40                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                   |                |                  |    |     |       |       |     |       |    |     |       |      |     |       |    |     |      |    |     |    |      |    |       |    |      |
| 56.8              | 70             | 57.14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                   |                |                  |    |     |       |       |     |       |    |     |       |      |     |       |    |     |      |    |     |    |      |    |       |    |      |

**Table 19-120. Register Call Summary for Register CFPS\_REG**


---

 UART/IrDA/CIR Functional Description

- Register Access Modes: [0] [1] [2] [3] [4] [5]
  - UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [6] [7] [8] [9] [10] [11]
  - CIR Mode (UART3 Only): [12] [13] [14]
- 

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary](#): [15] [16]
- 

**Table 19-121. RXFIFO\_LVL\_REG**

|                         |                                                                |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |            |  |  |
|-------------------------|----------------------------------------------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|--|--|--|--|--|------------|--|--|
| <b>Address Offset</b>   | 0x064                                                          |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |            |  |  |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a> |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |            |  |  |
| <b>Description</b>      | Instance                                                       |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |            |  |  |
| <b>Type</b>             | UART                                                           |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |            |  |  |
| 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 |  |  |  |  |  |            |  |  |
| RESERVED                |                                                                |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  | RXFIFO_LVL |  |  |

| Bits | Field Name | Description                                        | Type | Reset    |
|------|------------|----------------------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0.                                    | R    | 0x000000 |
| 7:0  | RXFIFO_LVL | Shows the number of received bytes in the RX FIFO. | R    | 0x00     |

**Table 19-122. Register Call Summary for Register RXFIFO\_LVL\_REG**


---

 UART/IrDA/CIR Functional Description

- Register Access Modes: [0] [1] [2]
  - UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20]
- 

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary](#): [21] [22]
- 

**Table 19-123. TXFIFO\_LVL\_REG**

|                         |                                                                |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |            |  |  |
|-------------------------|----------------------------------------------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|--|--|--|--|--|------------|--|--|
| <b>Address Offset</b>   | 0x068                                                          |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |            |  |  |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a> |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |            |  |  |
| <b>Description</b>      | Instance                                                       |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |            |  |  |
| <b>Type</b>             | UART                                                           |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |            |  |  |
| 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 |  |  |  |  |  |            |  |  |
| RESERVED                |                                                                |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  | TXFIFO_LVL |  |  |

| Bits | Field Name | Description                                        | Type | Reset    |
|------|------------|----------------------------------------------------|------|----------|
| 31:8 | Reserved   | Read returns 0x00.                                 | R    | 0x000000 |
| 7:0  | TXFIFO_LVL | Shows the number of received bytes in the TX FIFO. | R    | 0x00     |

**Table 19-124. Register Call Summary for Register TXFIFO\_LVL\_REG**


---

 UART/IrDA/CIR Functional Description

- Register Access Modes: [0] [1] [2]
  - UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20]
- 

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary](#): [21] [22]
-

**Table 19-125. IER2\_REG**

|                         |                                                                 |
|-------------------------|-----------------------------------------------------------------|
| <b>Address Offset</b>   | 0x06C                                                           |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a>  |
| <b>Description</b>      | Instance<br>Enables RX/TX FIFOs empty corresponding interrupts. |
| <b>Type</b>             | RW                                                              |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                    |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | EN_TXFIFO_EMPTY<br>EN_RXFIFO_EMPTY |   |   |   |   |   |   |   |

| Bits | Field Name      | Description                                                                                                                        | Type | Reset     |
|------|-----------------|------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:2 | Reserved        | Read returns 0.                                                                                                                    | R    | 0x0000000 |
| 1    | EN_TXFIFO_EMPTY | Enables TX FIFO empty corresponding interrupt<br>0x0: Enables EN_TXFIFO_EMPTY interrupt<br>0x1: Disables EN_TXFIFO_EMPTY interrupt | RW   | 0         |
| 0    | EN_RXFIFO_EMPTY | Enables RX FIFO empty corresponding interrupt<br>0x0: Enables EN_RXFIFO_EMPTY interrupt<br>0x1: Disables EN_RXFIFO_EMPTY interrupt | RW   | 0         |

**Table 19-126. Register Call Summary for Register IER2\_REG**

UART/IrDA/CIR Functional Description

- [Register Access Modes](#): [0] [1] [2] [3] [4] [5]
- [UART/IrDA \(SIR, MIR, FIR\)/CIR Mode Selection](#): [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23]

UART/IrDA/CIR Register Manual

- [UART/IrDA/CIR Register Summary](#): [24] [25]

**Table 19-127. ISR2\_REG**

|                         |                                                                   |
|-------------------------|-------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x070                                                             |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a>    |
| <b>Description</b>      | Instance<br>Status of RX/TX FIFOs empty corresponding interrupts. |
| <b>Type</b>             | RW                                                                |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                      |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------------------------------------|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | TXFIFO_EMPTY_STS<br>RXFIFO_EMPTY_STS |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:2        | Reserved          | Read returns 0.                                                                                                                                                   | R           | 0x0000000    |
| 1           | TXFIFO_EMPTY_STS  | Used to generate interrupt if the TX_FIFO is empty<br>(software flow control)<br>0x0: TXFIFO_EMPTY interrupt not pending.<br>0x1: TXFIFO_EMPTY interrupt pending. | RW          | 1            |
| 0           | RXFIFO_EMPTY_STS  | Used to generate interrupt if the RX_FIFO is empty<br>(software flow control)<br>0x0: RXFIFO_EMPTY interrupt not pending.<br>0x1: RXFIFO_EMPTY interrupt pending. | RW          | 1            |

**Table 19-128. Register Call Summary for Register ISR2\_REG**

## UART/IrDA/CIR Functional Description

- Register Access Modes: [0] [1] [2] [3] [4] [5]
  - UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23]

---

UART/IrDA/CIR Register Manual

- UART/IrDA/CIR Register Summary: [24] [25]

**Table 19-129. MDR3\_REG**

|                         |                                                                |                 |      |
|-------------------------|----------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x080                                                          |                 |      |
| <b>Physical Address</b> | See <a href="#">Table 19-39</a> to <a href="#">Table 19-40</a> | <b>Instance</b> | UART |
| <b>Description</b>      | Mode definition register 3.                                    |                 |      |
| <b>Type</b>             | RW                                                             |                 |      |



| <b>Bits</b> | <b>Field Name</b>    | <b>Description</b>                                                                                             | <b>Type</b> | <b>Reset</b> |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:1        | Reserved             | Read returns 0.                                                                                                | R           | 0x00000000   |
| 0           | DISABLE_CIR_RX_DEMOD | Used to enable CIR RX demodulation.<br>0x0: Enables CIR RX demodulation.<br>0x1: Disables CIR RX demodulation. | RW          | 0            |

**Table 19-130. Register Call Summary for Register MDR3\_REG**

## UART/IrDA/CIR Functional Description

- Register Access Modes: [0] [1] [2] [3] [4] [5]
  - UART/IrDA (SIR, MIR, FIR)/CIR Mode Selection: [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23]

---

UART/IrDA/CIR Register Manual

- #### • UART/IrDA/CIR Register Summary: [24] [25]



## Multichannel SPI

This chapter describes the four multichannel serial port interface (McSPI) modules.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                           | Page        |
|-------------------------------------------------|-------------|
| <b>20.1 McSPI Overview .....</b>                | <b>2998</b> |
| <b>20.2 McSPI Environment .....</b>             | <b>3001</b> |
| <b>20.3 McSPI Functional Interface .....</b>    | <b>3004</b> |
| <b>20.4 McSPI Integration .....</b>             | <b>3009</b> |
| <b>20.5 McSPI Functional Description .....</b>  | <b>3013</b> |
| <b>20.6 McSPI Basic Programming Model .....</b> | <b>3034</b> |
| <b>20.7 McSPI Register Manual .....</b>         | <b>3055</b> |

## 20.1 McSPI Overview

The multichannel serial port interface (McSPI) is a master/slave synchronous serial bus. There are four separate McSPI modules (SPI1, SPI2, SPI3, and SPI4) in the device (see [Figure 20-1](#)). The McSPI modules differ as follows: SPI1 supports up to four peripherals, SPI2 and SPI3 support up to two peripherals, and SPI4 supports only one peripheral.

---

**NOTE:** In this chapter,  $m=[1,4]$  represents the module instance and  $x$  represents the channel in signal and register naming. There are four McSPI instances. Each module instance has different channel numbers:

- SPI1: 4 channels (if  $m=1$ ,  $x=4$ )
  - SPI2: 2 channels (if  $m=2$ ,  $x=2$ )
  - SPI3: 2 channels (if  $m=3$ ,  $x=2$ )
  - SPI4: 1 channel (if  $m=4$ ,  $x=1$ )
-

**Figure 20-1. Multichannel Modules SPI1, SPI2, SPI3, and SPI4**



The McSPI instances include the following main features:

- Serial clock with programmable frequency, polarity, and phase for each channel
- Wide selection of SPI word lengths ranging from 4 bits to 32 bits
- Up to four master channels or single channel in slave mode
- Master multichannel mode:
  - Full duplex/half duplex
  - Transmit-only/receive-only/transmit-and-receive modes

- Flexible I/O port controls per channel
- Two direct memory access (DMA) requests (read/write) per channel
- Single interrupt line for multiple interrupt source events
- Power management through wake-up capabilities
- Enable the addition of a programmable start-bit for SPI transfer per channel (start-bit mode)
- Support start-bit write command
- Support start-bit pause and break sequence
- 64 bytes built-in FIFO available for a single channel
- Force CS mode for continuous transfers

## 20.2 McSPI Environment

Figure 20-2 shows a simplified overview of a typical application system using the McSPI. This example is based on a TFS chipset (TFS6040-0098), including a 2.2-inch color-active matrix thin-film transistor (TFT) liquid crystal display (LCD) with a light-emitting diode (LED) front light, a four-wire resistive touch-screen panel, and LCD controllers. This chipset is associated with the TSC2005 or TSC2006 touch-screen controller, powered by a power-management unit, and driven by the device. The McSPI device interface is set to master mode; the touch-screen McSPI controller interface operates in slave mode.

**Figure 20-2. Typical Application Using the McSPI**



mcspi\_GN3-001

Figure 20-3 through Figure 20-8 show master mode and slave mode configurations. Each mode can be wired on a single-duplex or full-duplex configuration.

### 20.2.1 SPI Interface in Master Mode

Figure 20-3 shows a case in master mode (full-duplex) where the McSPI module is connected with two slave devices.

**Figure 20-3. McSPI Master Mode (Full-Duplex)**

**NOTE:** In this case  $m=[1,3]$ .

Figure 20-4 shows the master single mode, which can also be configured in receive-only mode.

**Figure 20-4. McSPI Master Single Mode (Receive-Only)**

## 20.2.2 SPI Interface in Slave Mode

Figure 20-5 shows a case in slave mode (full-duplex).

**NOTE:** Only channel 0 can be configured as slave, and only `spim_cs0` can be used as a chip-enable in slave mode.

**Figure 20-5. McSPI Slave Mode (Full Duplex)**


mcsipi-004

[Figure 20-6 shows the slave single mode, which can also be configured in transmit-only mode.](#)

**Figure 20-6. McSPI Slave Single Mode (Transmit Only)**


mcsipi-005

## 20.3 McSPI Functional Interface

### 20.3.1 Basic McSPI Pins for Master Mode

Figure 20-7 shows all of the McSPI interface signals in master mode.

**Figure 20-7. McSPI Interface Signals in Master Mode**



mcsipi-006

Table 20-1 describes the McSPI I/O in master mode.

**Table 20-1. McSPI I/O Description (Master Mode)**

| Signal Name | I/O | Description                                                          | Reset (1) |
|-------------|-----|----------------------------------------------------------------------|-----------|
| spim_clk    | O   | SPIm module serial clock <sup>(2)</sup>                              | Unknown   |
| spim_simo   | O   | SPIm module serial data master out<br>(slave input, master output)   | Unknown   |
| spim_somi   | I   | SPIm module serial data master input<br>(slave output, master input) | —         |
| spim_csx    | O   | SPIm module chip-select x output                                     | Low       |

(1) After reset, the SPI modules are in slave mode by default. This paragraph implies that the McSPI module is configured in slave mode. (See the MCSPI\_MODULCTRL[2] MS bit in the module control register [MCSPI\_MODULCTRL].)

(2) This output signal is also used as retiming input (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to 1).

### 20.3.2 Basic McSPI Pins for Slave Mode

Figure 20-8 shows all of the McSPI interface signals in slave mode.

**Figure 20-8. McSPI Interface Signals in Slave Mode**



mcsipi-007

Table 20-2 describes the McSPI I/O in slave mode.

**Table 20-2. McSPI I/O Description (Slave Mode)**

| <b>Signal Name</b> | <b>I/O</b> | <b>Description</b>                                                  | <b>Reset <sup>(1)</sup></b> |
|--------------------|------------|---------------------------------------------------------------------|-----------------------------|
| spim_clk           | I          | SPI module serial clock                                             | Unknown                     |
| spim_simo          | I          | SPI module serial data master out<br>(slave input, master output)   | Unknown                     |
| spim_somi          | O          | SPI module serial data master input<br>(slave output, master input) | -                           |
| spim_csx           | I          | SPI module chip-select x output                                     | Low                         |

<sup>(1)</sup> After reset, the SPI modules are in slave mode by default. This paragraph implies that the McSPI module is configured in slave mode. (See the MCSPI\_MODULCTRL[2] MS bit in Module Control Register (MCSPI\_MODULCTRL).)

### 20.3.3 Multichannel SPI Protocol and Data Format

The synchronous SPI protocol allows a master device to initiate serial data transfers to a slave device. A slave select line (spim\_csx) allows selection of an individual slave SPI device. Slave devices that are not selected do not interfere with SPI bus activities.

McSPI offers the flexibility to modify the following parameters to adapt to the device features:

- Word length

McSPI supports any SPI word ranging from 4 bits to 32 bits long (SPI module. [MCSPI\\_CHxCONF\[11:7\]](#) WL field).

SPI word length can be changed between transmissions to allow the master device to communicate with peripheral slaves that have different requirements.

- SPI enable (spim\_csx, for channel x of instance m)

The polarity of the SPI enable signals is programmable (SPI module. [MCSPI\\_CHxCONF\[6\]](#) EPOL bit). spim\_csx signals can be active high or low.

The assertion of the spim\_csx signals is programmable and can be manually or automatically asserted. The manual assertion mode is available in single master mode only. spim\_csx can be kept active between words with the SPI module. [MCSPI\\_CHxCONF\[20\]](#) FORCE bit.

Two consecutive words for two different slave devices can go along with active spim\_csx signals with different polarity (see the example in [Section 20.6, McSPI Basic Programming Model](#)).

- Programmable start-bit

In start-bit mode a start-bit is added before the SPI word length to indicate how the next SPI word must be handled. The start-bit is enabled by setting SPI module. [MCSPI\\_CHxCONF\[23\]](#) SBE bit to 1. The SPI module. [MCSPI\\_CHxCONF\[24\]](#) SBPOL bit defines the polarity of the start-bit.

- Programmable SPI clock

- Bit rate

In master mode, the baud rate of the SPI serial clock is programmable using the 48-MHz reference clock (from the power, reset, and clock management [PRCM] module). [Table 20-3](#) gives the spim\_clk bit rates obtained for data transfer when programming the clock divider (SPI module. [MCSPI\\_CHxCONF\[5:2\]](#) CLKD bit field).

**Table 20-3. SPI Master Clock Rates**

| <b>Divider</b> | <b>Clock Rate</b> |
|----------------|-------------------|
| 1              | 48 MHz            |
| 2              | 24 MHz            |
| 4              | 12 MHz            |
| 8              | 6 MHz             |
| 16             | 3 MHz             |
| 32             | 1.5 MHz           |
| 64             | 750 kHz           |
| 128            | 375 kHz           |

**Table 20-3. SPI Master Clock Rates (continued)**

| Divider | Clock Rate |
|---------|------------|
| 256     | ~187 kHz   |
| 512     | ~93.7 kHz  |
| 1024    | ~46.8 kHz  |
| 2048    | ~23.4 kHz  |
| 4096    | ~11.7 kHz  |
| 8192    | ~5.8 kHz   |
| 16384   | ~2.9 kHz   |
| 32768   | ~1.5 kHz   |

- Polarity and phase

The polarity (the SPIm.`MCSPI_CHxCONF[1]` POL bit) and the phase (the SPIm.`MCSPI_CHxCONF[0]` PHA bit) of the SPI serial clock (`spim_clk`) are configurable to offer four combinations. Software selects the right combination, depending on the device. See [Table 20-4](#) and [Figure 20-9](#).

**Table 20-4. Phase and Polarity Combinations**

| Polarity (POL) | Phase (PHA) | SPI Mode | Comments                                                                      |
|----------------|-------------|----------|-------------------------------------------------------------------------------|
| 0              | 0           | Mode 0   | <code>spim_clk</code> is active high and sampling occurs on the rising edge.  |
| 0              | 1           | Mode 1   | <code>spim_clk</code> is active high and sampling occurs on the falling edge. |
| 1              | 0           | Mode 2   | <code>spim_clk</code> is active low and sampling occurs on the falling edge.  |
| 1              | 1           | Mode 3   | <code>spim_clk</code> is active low and sampling occurs on the rising edge.   |

**Figure 20-9. Phase and Polarity Combinations**

mcsipi-009

### 20.3.3.1 Transfer Format

In both master and slave modes, McSPI drives the data lines when `spim_csx` is asserted.

Each word is transmitted starting with the most-significant bit (MSB).

This section explains the two cases of data transmission determined by the clock phase (PHA) and the type of data transmission using a start-bit (SBE) called the start-bit mode:

- Transmission in mode 0 and mode 2 (PHA = 0)

When PHA = 0, the first bit of the SPI word to transmit (on the master or the slave data output pin) is valid one half cycle of spim\_clk after the spim\_csx assertion.

Therefore, the first edge of the spim\_clk line is used by the master to sample the first data bit sent by the slave. On the same edge, the first data bit sent by the master is sampled by the slave.

On the next spim\_clk edge, the received data bit is shifted into the receive shift register and a new data bit is transmitted on the serial data line.

This process continues for a number of pulses on the spim\_clk line defined by the SPI word length programmed in the master device, with data being latched on odd-numbered edges and shifted on even-numbered edges. See [Figure 20-10](#).

**Figure 20-10. Full-Duplex Transfer Format With PHA = 0**



- Transmission in mode 1 and mode 3 (PHA = 1)

When PHA = 1, the first bit of the SPI word to transmit (on the master or the slave data output pin) is valid on the following spim\_clk edge (one half cycle later). This is the sampling edge for the master and slave. A synchronization delay is added between the spim\_csx activation and the first spim\_clk edge.

The received data bit is shifted into the shift register on the third spim\_clk edge.

This process continues for a number of pulses on the spim\_clk line defined by the SPI word length programmed in the master device, with data being latched on even-numbered edges and shifted on odd-numbered edges.

**NOTE:** The minimum synchronization delay is one cycle of spim\_clk, if the spim\_clk frequency equals the SPIIm\_FCLK (McSPIIm functional clock) frequency in master mode. The minimum synchronization delay is one-half cycle of spim\_clk, if the spim\_clk frequency is lower than the SPIIm\_FCLK frequency in both master and slave modes.

- Transmission with a start-bit (SBE = 1)

When the SPIIm.MCSPI\_CHxCONF[23] SBE bit = 1, a start-bit is added before the MSB to indicate whether the next SPI word must be handled as a command or as data.

[Figure 20-11](#) shows an example of a data transfer with an extra start-bit.

**Figure 20-11. Extended SPI Transfer With a Start-Bit (SBE = 1)**

mcsipi-010

## 20.4 McSPI Integration

### 20.4.1 McSPI Description

Figure 20-12 highlights the McSPI module integration in the device.

**Figure 20-12. McSPI Integration**



### 20.4.2 Clocking, Reset, and Power-Management Scheme

#### 20.4.2.1 Clocking

Each McSPI module is clocked with an independent functional clock of 48 MHz from the PRCM module ( $SPI_{m,FCLK}$  with  $m = [1,4]$ ) and with an interface clock,  $CORE_{L4\_ICLK}$  (L4 interconnect):

- $SPI_{m,FCLK}$  is the McSPI module  $m$  functional clock and is used to clock the McSPI internal logic. The source of  $SPI_{m,FCLK}$  is the PRCM  $CORE_{48M\_FCLK}$  output clock.
- $SPI_{m,ICLK}$  is the McSPI module  $m$  interface clock and is used to synchronize the McSPI L4 port to the L4 interconnect. All accesses from the interconnect are synchronous with  $SPI_{m,ICLK}$ . The source of  $SPI_{m,ICLK}$  is the PRCM  $CORE_{L4\_ICLK}$  output clock.

From a global system power management perspective, when one or both of the McSPI clocks is not required, the McSPI module can be deactivated at the PRCM level in the corresponding registers.

Table 20-5 describes the McSPI module PRCM clock control bits.

**Table 20-5. McSPI Clocks**

| McSPI Clock            | Associated PRCM Clock Output | Enable Bit                                                    | Autoidle Bit                                                      |
|------------------------|------------------------------|---------------------------------------------------------------|-------------------------------------------------------------------|
| SPI <sub>m</sub> _FCLK | CORE_48M_FCLK                | PRCM.CM_FCLKEN1_CORE.EN_MC<br>SPI <sub>m</sub> (with m=[1,4]) | N/A                                                               |
| SPI <sub>m</sub> _ICLK | CORE_L4_ICLK                 | PRCM.CM_ICLKEN1_CORE.EN_MCS<br>Plm (with m=[1,4])             | PRCM.CM_AUTOIDLE1_CORE.AUTO_M<br>CSPI <sub>m</sub> (with m=[1,4]) |

**NOTE:**

- The PRCM CORE\_48M\_FCLK output is gated at the PRCM level, assuming that all modules sharing it are disabled in the corresponding register. Disabling the McSPI module is a necessary but insufficient condition.
- The PRCM CORE\_L4\_ICLK output is gated at the PRCM level, assuming that all modules sharing it are disabled in the corresponding register. Disabling the McSPI module is a necessary but insufficient condition.
- The PRCM.CM\_AUTOIDLE1\_CORE bit is used to link/unlink the McSPI module from CORE\_L4\_ICLK-related clock domain transitions.

For more information about source clocks gating and domain transitions, see [Chapter 3, Power, Reset, and Clock Management](#). For more information on power saving management, see [Section 20.5.7](#).

**20.4.2.2 Power Domain**

The McSPI modules belong to the CORE power domain (see [Table 20-6](#)).

**Table 20-6. Power Domain**

| Peripherals   | Power Domain      |
|---------------|-------------------|
| McSPI modules | CORE power domain |

**20.4.2.3 Hardware Reset**

As part of the CORE power domain, CORE\_RST is issued by the PRCM module (for more information about the CORE power domain implementation and CORE\_RST signal, see [Chapter 3, Power, Reset, and Clock Management](#)). The module is reset by hardware when an active-low reset signal is asserted. The hardware reset signal has a global reset effect on the module. All configuration registers and all state-machines are reset in all clock domains (see [Table 20-7](#)).

**Table 20-7. McSPI Hardware Reset**

| Peripherals  | Name     | Comments             |
|--------------|----------|----------------------|
| McSPI module | CORE_RST | Same as global reset |

**20.4.2.4 Software Reset**

The SPI<sub>m</sub>.[MCSPI\\_SYSCONFIG](#)[1] SOFTRESET bit controls the software reset of the SPI interface. Writing 1 to this bit enables active software reset functionality, which is equivalent to a hardware reset. The bit is automatically reset by hardware.

**NOTE:** The SPI<sub>m</sub>.[MCSPI\\_SYSCONFIG](#) register is not sensitive to software reset.

## **20.4.3 Hardware Requests**

### **20.4.3.1 DMA Requests**

Each channel includes two DMA requests, one for reception and one for transmission (see [Table 20-8](#)).

**Table 20-8. DMA Requests**

| Attributes  | DMA Request | Name         | Mapping  | Comments                          |
|-------------|-------------|--------------|----------|-----------------------------------|
| <b>SPI1</b> |             |              |          |                                   |
|             | 8           | SPI1_DMA_TX0 | S_DMA_34 | Destination is system DMA (sDMA). |
|             |             | SPI1_DMA_RX0 | S_DMA_35 |                                   |
|             |             | SPI1_DMA_TX1 | S_DMA_36 |                                   |
|             |             | SPI1_DMA_RX1 | S_DMA_37 |                                   |
|             |             | SPI1_DMA_TX2 | S_DMA_38 |                                   |
|             |             | SPI1_DMA_RX2 | S_DMA_39 |                                   |
|             |             | SPI1_DMA_TX3 | S_DMA_40 |                                   |
|             |             | SPI1_DMA_RX3 | S_DMA_41 |                                   |
| <b>SPI2</b> |             |              |          |                                   |
|             | 4           | SPI2_DMA_TX0 | S_DMA_42 | Destination is sDMA.              |
|             |             | SPI2_DMA_RX0 | S_DMA_43 |                                   |
|             |             | SPI2_DMA_TX1 | S_DMA_44 |                                   |
|             |             | SPI2_DMA_RX1 | S_DMA_45 |                                   |
| <b>SPI3</b> |             |              |          |                                   |
|             | 4           | SPI3_DMA_TX0 | S_DMA_14 | Destination is sDMA.              |
|             |             | SPI3_DMA_RX0 | S_DMA_15 |                                   |
|             |             | SPI3_DMA_TX1 | S_DMA_22 |                                   |
|             |             | SPI3_DMA_RX1 | S_DMA_23 |                                   |
| <b>SPI4</b> |             |              |          |                                   |
|             | 2           | SPI4_DMA_TX0 | S_DMA_69 | Destination is sDMA.              |
|             |             | SPI4_DMA_RX0 | S_DMA_70 |                                   |

### 20.4.3.2 Interrupt Requests

Each McSPI module handles one interrupt line (see [Table 20-9](#)).

**Table 20-9. Interrupt Requests**

| Attributes  | Interrupt Request | Name     | Mapping  | Comments                                                           |
|-------------|-------------------|----------|----------|--------------------------------------------------------------------|
| <b>SPI1</b> |                   |          |          |                                                                    |
|             | 1                 | SPI1_IRQ | M_IRQ_65 | Destination is the microprocessor unit (MPU) interrupt controller. |
| <b>SPI2</b> |                   |          |          |                                                                    |
|             | 1                 | SPI2_IRQ | M_IRQ_66 | Destination is the MPU interrupt controller.                       |
| <b>SPI3</b> |                   |          |          |                                                                    |
|             | 1                 | SPI3_IRQ | M_IRQ_91 | Destination the MPU interrupt controller.                          |
| <b>SPI4</b> |                   |          |          |                                                                    |
|             | 1                 | SPI4_IRQ | M_IRQ_48 | Destination is the MPU interrupt controller.                       |

### 20.4.3.3 Wake-Up Requests

[Table 20-10](#) lists the wake-up requests.

**Table 20-10. Wake-Up Requests**

| Attributes  | Wake Request | Name     | Mapping      | Comments                        |
|-------------|--------------|----------|--------------|---------------------------------|
| <b>SPI1</b> |              |          |              |                                 |
|             | 1            | spi1_cs0 | SPI1_SWAKEUP | Destination is the PRCM module. |
| <b>SPI2</b> |              |          |              |                                 |
|             | 1            | spi2_cs0 | SPI2_SWAKEUP | Destination is the PRCM module. |
| <b>SPI3</b> |              |          |              |                                 |
|             | 1            | spi3_cs0 | SPI3_SWAKEUP | Destination is the PRCM module. |
| <b>SPI4</b> |              |          |              |                                 |
|             | 1            | spi4_cs0 | SPI4_SWAKEUP | Destination is the PRCM module. |

## 20.5 McSPI Functional Description

### 20.5.1 McSPI Block Diagram

Figure 20-13 shows the McSPI module.

**Figure 20-13. McSPI Block Diagram**



## 20.5.2 Master Mode

### 20.5.2.1 Master Mode Features

The McSPI master mode supports multichannel communication with up to four independent SPI communication channel contexts. The McSPI initiates a data transfer on the data lines (spim\_simo and spim\_somi) and generates clock (spim\_clk) and control signals (spim\_cx).

Connected to multiple external devices, the McSPI exchanges data with one SPI device at a time through two main modes (available in slave mode):

- Two-data-pins interface mode (transmit-and-receive mode for full-duplex transmission)
- Single-data-pin interface mode (recommended for half-duplex transmission)

Two DMA request events (read and write) allow synchronized accesses of the DMA controller with the activity of McSPI.

Three interrupt events can be used for data transmission and reception in master mode (for more information on interrupts, see [Section 20.5.5.1, Interrupt Events in Master Mode](#)).

### 20.5.2.2 Master Transmit-and-Receive Mode (Full Duplex)

In full-duplex transmission, data is transmitted (shifted out serially on spim\_simo) and received (shifted in serially on spim\_somi) simultaneously on separate data lines.

The master transmit-and-receive mode is programmable per channel (the SPIIm.[MCSPI\\_CHxCONF\[13:12\]](#) TRM field).

Channel access to the shift registers for transmission/reception is based on the [MCSPI\\_TXx](#) transmitter register state, the [MCSPI\\_RXx](#) receiver register state, and round robin arbitration.

Channels that meet the following rules are included in the round robin list of active channels scheduled for transmission and/or reception. The arbiter skips channels that do not meet the rules and searches in the rotation for the next enabled channel.

- Rule 1: Only enabled channels (the SPIIm.[MCSPI\\_CHxCTRL\[0\]](#) EN bit) can be scheduled for transmission and/or reception.
- Rule 2: If its [MCSPI\\_TXx](#) transmitter register is not empty (the SPIIm.[MCSPI\\_CHxSTAT\[1\]](#) TXS bit), an enabled channel can be scheduled when the shift register is assigned. If the [MCSPI\\_TXx](#) register is empty when the shift register is assigned, the TXx\_UNDERFLOW event is activated, and the next enabled channel with new data to transmit is scheduled (see also the transmit-only mode).
- Rule 3: An enabled channel can be scheduled if its receive register is not full (the SPIIm.[MCSPI\\_CHxSTAT\[0\]](#) RXS bit) when the shift register is assigned (see also the receive-only mode). Therefore, the [MCSPI\\_RXx](#) register cannot be overwritten. Note that the SPI1.[MCSPI\\_IRQSTATUS\[3\]](#) RX0\_OVERFLOW bit is never set to this mode.

When SPI word transfer completes (the SPIIm.[MCSPI\\_CHxSTAT\[2\]](#) EOT bit is set), the updated [MCSPI\\_TXx](#) register of the next scheduled channel is loaded into the shift register. The serialization (transmit-and-receive) starts depending on the channel communication configuration. When serialization completes, the received data transfers to the channel receive register.

The serial clock (spim\_clk) synchronizes shifting and sampling of the information on the two serial data lines (spim\_simo and spim\_somi). Each time a bit transfers out from the master, 1 bit transfers in from the slave.

[Figure 20-14](#) shows an example of a full-duplex system with a master device (McSPI module m) on the left and a slave device on the right. After eight cycles of the serial clock spim\_clk, WordA transfers from the master to the slave. At the same time, WordB transfers from the slave to the master.

**Figure 20-14. SPI Full-Duplex Transmission (Example)**


### 20.5.2.3 Master Transmit-Only Mode (Half Duplex)

The master transmit-only mode prevents the MPU from reading the [MCSPI\\_RXx](#) register (minimizing data movement) when only transmission is meaningful.

The master transmit-only mode is programmable per channel (the SPIIm.[MCSPI\\_CHxCONF\[13:12\]](#) TRM field). Transmission starts only after data is loaded into the [MCSPI\\_TXx](#) register.

Rule 1 and Rule 2, defined in [Section 20.5.2.2](#), are applicable in this mode.

Rule 3, defined in [Section 20.5.2.2](#), is not applicable.

In master transmit-only mode, the [MCSPI\\_RXx](#) register state FULL does not prevent transmission and the [MCSPI\\_RXx](#) register is always overwritten with the new SPI word. This event is not significant when only transmission is meaningful. Thus, the RX0\_OVERFLOW bit in the SPIIm.[MCSPI\\_IHQSTATUS](#) register is never set in this mode.

The hardware automatically disables the RX\_FULL interrupt and the DMA read requests.

The transfer status is given by the SPIIm.[MCSPI\\_CHxSTAT\[2\]](#) EOT bit.

### 20.5.2.4 Master Receive-Only Mode (Half Duplex)

The master receive mode prevents the MPU from refilling the [MCSPI\\_TXx](#) register (minimizing data movement) when only reception is meaningful.

The master receive mode is programmable per channel (the SPIIm.[MCSPI\\_CHxCONF\[13:12\]](#) TRM field).

The master receive-only mode enables channel scheduling only on the empty state of the [MCSPI\\_RXx](#) register.

Rule 1 and Rule 3, defined in [Section 20.5.2.2](#), are applicable in this mode.

Rule 2, defined in [Section 20.5.2.2](#), is not applicable.

In the master receive-only mode, software must write dummy data to the [MCSPI\\_TXx](#) register, and only after the TX buffer is empty (check the [MCSPI\\_CH0STAT\[2\]](#) bit in the software).. Only one dummy write is enough to receive any number of words from the slave. Software should ensure that the [MCSPI\\_TXx](#) register is always full (the [TXx\\_EMPTY](#) bits of SPIm.[MCSPI\\_IRQSTATUS](#)) when receiving. The content of the [MCSPI\\_TXx](#) register is always loaded into the shift register when the shift register is assigned. After writing the dummy data to the [MCSPI\\_TXx](#) register, the [TXx\\_EMPTY](#) and [TXx\\_UNDERFLOW](#) bits in the SPIm.[MCSPI\\_IRQSTATUS](#) register are never set in receive-only mode.

The SPIm.[MCSPI\\_CHxSTAT\[2\]](#) EOT bit gives the status of serialization. The [RXx\\_FULL](#) bits of the SPIm.[MCSPI\\_IRQSTATUS](#) register are set when received data is loaded from the shift register to the corresponding [MCSPI\\_RXx](#) register. The SPIm.[MCSPI\\_IRQSTATUS\[3\]](#) RX0\_OVERFLOW bit is never set in this mode.

### 20.5.2.5 Single-Channel Master Mode

When the McSPI is configured as a master device with a single enabled channel, the assertion of the spim\_csx signal can be controlled in two different ways:

- If the [MCSPI\\_MODULCTRL\[0\]](#) SINGLE bit is set to 0, spim\_csx assertion/deassertion after each SPI word is automatically controlled by the McSPI module (see subsections of [Section 20.5.2.1, Master Mode Features](#)).
- If the [MCSPI\\_MODULCTRL\[0\]](#) SINGLE bit and the [MCSPI\\_CHxCONF\[20\]](#) FORCE bit are set to 1: spim\_csx assertion/deassertion is controlled by software (see [Section 20.5.2.5.1, Programming Tips When Switching to Another Channel](#)).

#### 20.5.2.5.1 Programming Tips When Switching to Another Channel

When a single channel is enabled and data transfer is ongoing:

- Wait for completion of the SPI word transfer (wait until the SPIm.[MCSPI\\_CHxSTAT\[2\]](#) EOT bit is set to 1) before disabling the current channel and enabling a different channel.
- Disable the current channel first, and then enable the other channel.

#### 20.5.2.5.2 Force spim\_csx Mode

Continuous transfers are manually allowed by keeping the spim\_csx signal active for successive SPI words transfer. Several sequences (configuration/enable/disable of the channel) can be run without deactivating the spim\_csx line. This mode is supported by all channels and any master sequence can be used (transmit-receive, transmit-only, receive-only).

Keeping the spim\_csx active mode is supported when:

- A single channel is used (with the SPIm.[MCSPI\\_MODULCTRL\[0\]](#) SINGLE bit set to 1).
- Transfer parameters are loaded in the configuration register of the appropriate channel (SPIm.[MCSPI\\_CHxCONF](#)).

The state of the spim\_csx signal is programmable.

- Writing 1 to the SPIm.[MCSPI\\_CHxCONF\[20\]](#) FORCE bit drives the spim\_csx line high when the SPIm.[MCSPI\\_CHxCONF\[6\]](#) EPOL bit is set to 0. spim\_csx is driven low when the SPIm.[MCSPI\\_CHxCONF\[6\]](#) EPOL bit is set to 1.
- Writing 0 to the SPIm.[MCSPI\\_CHxCONF\[20\]](#) FORCE bit drives the spim\_csx line low when the SPIm.[MCSPI\\_CHxCONF\[6\]](#) EPOL bit is set to 0. spim\_csx is driven high when the SPIm.[MCSPI\\_CHxCONF\[6\]](#) EPOL bit is set to 1.
- A single channel is enabled (the SPIm.[MCSPI\\_CHxCTRL\[0\]](#) EN bit is set to 1). The first enabled channel activates the spim\_csx line.

When the channel is enabled, the spim\_csx signal activates with the programmed polarity. As in the multichannel master mode, the transfer start depends on the status of the [MCSPI\\_TXx](#) register (the SPIm.[MCSPI\\_CHxSTAT\[1\]](#) TXS bit), the status of the [MCSPI\\_RXx](#) register (the SPIm.[MCSPI\\_CHxSTAT\[1\]](#) RXS bit), and the defined mode (the SPIm.[MCSPI\\_CHxCONF\[13:12\]](#) TRM field) of the channel enabled.

The SPIIm.[MCSPI\\_CHxSTAT\[2\]](#) EOT bit gives the transfer status of each SPI word. The RXx\_FULL bit in the SPIIm.[MCSPI\\_IRQSTATUS](#) register is set when received data is loaded from the shift register to the [MCSPI\\_RXx](#) register.

A change in the configuration parameters is propagated directly on the SPI interface. If the spim\_csx signal is activated, ensure that the configuration is changed only between SPI words to avoid corrupting the current transfer.

---

**NOTE:** To avoid data corruption, spim\_csx polarity and spim\_clk phase and spim\_clk polarity must not be modified when the spim\_csx signal is activated.

---

A delay between SPI words that requires the connected SPI slave device to switch from one configuration (transmit-only for instance) to another (receive-only for instance) must be handled by software.

At the end of the last SPI word, the channel must be deactivated (the SPIIm.[MCSPI\\_CHxCTRL\[0\]](#) EN bit set to 0) and spim\_csx can be forced to its inactive state using the SPIIm.[MCSPI\\_CHxCONF\[20\]](#) FORCE bit.

[Figure 20-15](#) and [Figure 20-16](#) show successive transfers with spim\_csx maintained active low with a different configuration for each SPI word in single-data-pin and dual-data-pin interface modes, respectively.

**Figure 20-15. Continuous Transfers With spim\_csx Maintained Active (Single-Data-Pin Interface Mode)**



**Figure 20-16. Continuous Transfers With spim\_csx Maintained Active (Dual-Data-Pin Interface Mode)**



---

**NOTE:** The turbo mode described in [Section 20.5.2.5.3, Turbo Mode](#), maintains spim\_csx in active mode when the following conditions are met:

- A single channel is explicitly used (the SPIIm.[MCSPI\\_MODULCTRL\[0\]](#) SINGLE bit is set to 1).
- Turbo mode is enabled in the configuration of the channel. (The SPIIm.[MCSPI\\_CHxCONF\[19\]](#) TURBO bit is set to 1.)

---

### 20.5.2.5.3 Turbo Mode

The turbo mode improves the throughput of the SPI interface when a single channel is enabled by allowing transfers until the shift register and the **MCSPI\_RXx** register are full. The turbo mode is useful (time savings) when a transfer exceeds two words. This mode is programmable per channel (via the SPI1.**MCSPI\_CHxCONF[9]** TURBO bit).

When several channels are enabled, the TURBO bit has no effect and the channel access to the shift registers remains as previously described.

In turbo mode, Rule 1 and Rule 2 applies, but Rule 3 does not (see [Section 20.5.2.2](#)). An enabled channel can be scheduled if its receive register is full (the SPI1m.**MCSPI\_CHxSTAT[0]** RXS bit) at the time of the shift-register assignment until the shift register is full.

The **MCSPI\_RXx** register cannot be overwritten in turbo mode. Consequently, the SPI1m.**MCSPI\_IRQSTATUS[3]** RX0\_OVERFLOW bit is never set in this mode.

### 20.5.2.6 Start Bit Mode

In start bit mode, an extended bit is added before the SPI word in order to indicate whether the next SPI word must be handled as a command or as data. This feature is only available in master mode. The start bit mode cannot be used at the same time as turbo mode and/or force spim\_csx mode. In this case, only one channel can be used; round-robin arbitration is not possible.

This mode is programmable per channel by setting the SPI1m.**MCSPI\_CHxCONF[23]** SBE bit to 1. The polarity of the extended bit is programmable per channel. When the SPI1m.**MCSPI\_CHxCONF[24]** SBPOL bit is set to 0, the SPI word must be handled as a command. When the SPI1m.**MCSPI\_CHxCONF[24]** SBPOL bit is set to 1, the SPI word must be handled as data. Moreover, start-bit polarity can be changed dynamically during start bit transfer without disabling the channel for reconfiguration; in this case, users must configure the SPI1m.**MCSPI\_CHxCONF[24]** SBPOL bit before writing the SPI word to be transmitted to the TX register.

### 20.5.2.7 Chip-Select Timing Control

The chip select timing control is only available in master mode with automatic chip select generation (**MCSPI\_MODULCTRL[0]** SINGLE bit field set to 0), to add a programmable delay between chip select assertion and first clock edge, or chip select removal and last clock edge.

This mode is programmable per channel (the TCS bit of the SPI1m.**MCSPI\_CHxCONF** register).

[Figure 20-17](#) shows the chip-select SPIEN timing control.

**Figure 20-17. Chip-Select SPIEN Timing Controls**



**NOTE:** Because of the design implementation for transfers using a clock divider ratio set to 1 (clock bypassed), a half cycle must be added to the value between chip-select assertion and the first clock edge with PHA = 1 or between chip-select removal and the last clock edge with PHA = 0.

### 20.5.2.8 Programmable SPI Clock (spim\_clk)

In master mode, the baud rate of the SPI serial clock is programmable.

An internal reference clock, SPIm\_FCLK, is used as input of a programmable divider (the SPIm.[MCSPI\\_CHxCONF\[5:2\]](#) CLKD field) to generate the bit rate of the serial output clock spim\_clk. Table 20-11 summarizes the supported divisor values.

**Table 20-11. SPI Master Clock Rates**

| Divider | Clock Rate |
|---------|------------|
| 1       | 48 MHz     |
| 2       | 24 MHz     |
| 4       | 12 MHz     |
| 8       | 6 MHz      |
| 16      | 3 MHz      |
| 32      | 1.5 MHz    |
| 64      | 750 kHz    |
| 128     | 375 kHz    |
| 256     | ~187 kHz   |
| 512     | ~93.7 kHz  |
| 1024    | ~46.8 kHz  |
| 2048    | ~23.4 kHz  |
| 4096    | ~11.7 kHz  |
| 8192    | ~5.8 kHz   |
| 16384   | ~2.9 kHz   |
| 32768   | ~1.5 kHz   |

#### 20.5.2.8.1 Clock Ratio Granularity

By default the clock division ratio is defined by the SPIm.[MCSPI\\_CHxCONF\[5:2\]](#) CLKD bit field with power of two granularity leading to a clock division in range 1 to 4096, in this case the duty cycle is always 50%. With the SPIm.[MCSPI\\_CHxCONF\[29\]](#) CLKG bit, clock division granularity can be changed to one clock cycle, in that case the SPIm.[MCSPI\\_CHxCTRL\[15:8\]](#) EXTCLK bit field is concatenated with SPIm.[MCSPI\\_CHxCONF\[5:2\]](#) CLKD bit field to give a 12-bit width division ratio in range 1 to 4096.

When granularity is one clock cycle (CLKG set to 1), for odd value of clock ratio the clock high level lasts one clock cycle more than low level depending on SPIm.[MCSPI\\_CHxCONF\[1\]](#) POL bit and SPIm.[MCSPI\\_CHxCONF\[0\]](#) PHA bit refer to [Table 20-12](#).

**Table 20-12. CLKSPIO High/Low Time Computation**

| Clock ratio Fratio            | CLKSPIO High Time                | CLKSPIO Low Time                 |
|-------------------------------|----------------------------------|----------------------------------|
| 1                             | T <sub>high_ref</sub>            | T <sub>low_ref</sub>             |
| Even $\geq$ 2                 | T <sub>ref</sub> * (Fratio/2)    | T <sub>ref</sub> * (Fratio/2)    |
| Odd $\geq$ 3 (POL=PHA)        | T <sub>ref</sub> * (Fratio-1) /2 | T <sub>ref</sub> * (Fratio+1) /2 |
| Odd $\geq$ 3 (POL $\neq$ PHA) | T <sub>ref</sub> * (Fratio+1) /2 | T <sub>ref</sub> * (Fratio-1) /2 |

---

**NOTE:** Fratio = spi1\_clk frequency (Fout) division ratio.  
 Thigh = spi1\_clk High Time period.  
 Tlow = spi1\_clk Low Time period.  
 $T_{ref}$  = SPI1\_FCLK period.  
 Thigh\_ref = SPI1\_FCLK high Time period.  
 Tlow\_ref = SPI1\_FCLK low Time period.

---

If CLKG = 1: Fratio = EXTCLK concatenated with CLKD + 1 as shown below:

| Fratio - 1                                |    |    |    |    |    |   |   |                                        |   |   |   |
|-------------------------------------------|----|----|----|----|----|---|---|----------------------------------------|---|---|---|
| 11                                        | 10 | 9  | 8  | 7  | 6  | 5 | 4 | 3                                      | 2 | 1 | 0 |
| SPI1.MCSPI_CHxCTRL[15:8] EXTCLK bit field |    |    |    |    |    |   |   | SPI1.MCSPI_CHxCONF[5:2] CLKD bit field |   |   |   |
| 15                                        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 5                                      | 4 | 3 | 2 |

For odd ratio values, the duty cycle is calculated as below:

$$\text{Duty\_cycle} = (1-1/\text{Fratio})/2$$

Table 20-13 shows clock granularity examples with a clock source frequency of 48 MHz.

**Table 20-13. Clock Granularity Examples**

| EXTCLK | CLKD | CLKG | Fratio | PHA | POL | Thigh (ns) | Tlow (ns) | Tperiod (ns) | Duty Cycle | Fout (MHz) |
|--------|------|------|--------|-----|-----|------------|-----------|--------------|------------|------------|
| X      | 0    | 0    | 1      | X   | X   | 10.4       | 10.4      | 20.8         | 50-50      | 48         |
| X      | 1    | 0    | 2      | X   | X   | 20.8       | 20.8      | 41.6         | 50-50      | 24         |
| X      | 2    | 0    | 4      | X   | X   | 41.6       | 41.6      | 83.2         | 50-50      | 12         |
| X      | 3    | 0    | 8      | X   | X   | 83.2       | 83.2      | 166.4        | 50-50      | 6          |
| 0      | 0    | 1    | 1      | X   | X   | 10.4       | 10.4      | 20.8         | 50-50      | 48         |
| 0      | 1    | 1    | 2      | X   | X   | 20.8       | 20.8      | 41.6         | 50-50      | 24         |
| 0      | 2    | 1    | 3      | 1   | 0   | 41.6       | 20.8      | 62.4         | 66-33      | 16         |
| 0      | 2    | 1    | 3      | 1   | 1   | 20.8       | 41.6      | 62.4         | 33-66      | 16         |
| 0      | 3    | 1    | 4      | X   | X   | 41.6       | 41.6      | 83.2         | 50-50      | 12         |
| 5      | 0    | 1    | 81     | 1   | 0   | 852.8      | 832       | 1684.8       | 50.6-49.4  | 0.592      |
| 5      | 7    | 1    | 88     | X   | X   | 915.2      | 915.2     | 1830.4       | 50-50      | 0.545      |

### 20.5.3 Slave Mode

To select the McSPI slave mode, set the SPI1.MCSPI\_MODULCTRL[2] MS bit.

A McSPI slave device can be connected to up to four external SPI master devices but handles transactions with one SPI master device at a time.

In slave mode, the McSPI initiates data transfer on the data lines (spim\_simo and spim\_somi) when it is selected by an active control signal (spim\_csx) and receives an SPI clock (spim\_clk) from the external SPI master device. Only channel 0 can be configured as a slave. In slave mode, the McSPI uses the edge of spim\_csx to detect word length. For this reason, spim\_csx must become inactive between each word.

The McSPI does not support spim\_csx active between SPI words. It uses the edge to detect word length.

#### 20.5.3.1 Dedicated Resources

Only channel 0 can be enabled in slave mode. In this section registers name such as SPI1.MCSPI\_CHxCTRL stand for SPI1.MCSPI\_CH0CTRL where x=0 (channel 0 control register).

Figure 20-18 shows an example of four slaves wired on a single master device.

**Figure 20-18. Example of McSPI Slave With One Master and Multiple Slave Devices on Channel 0**



mcsipi-017

The channel 0 in slave mode has the following resources:

- Its own channel enable, programmable with the SPIm.[MCSPI\\_CHxCTRL\[0\]](#) EN bit (with x=0). This channel must be enabled before transmission and reception.
- For this mode, the slave-select signal can be detected only on spim\_cs0.
- Its own transmitter register, SPIm.[MCSPI\\_TXx](#) (with x=0), on top of the common transmit shift register. If the [MCSPI\\_TXx](#) register is empty, the SPIm.[MCSPI\\_CHxSTAT\[1\]](#) TXS bit (with x=0) is set. If McSPI is selected by an external master (the active signal on the spim\_csx port assigned to channel 0), the [MCSPI\\_TXx](#) register content of channel 0 is always loaded into the shift register, whether its content is updated or not. The [MCSPI\\_TXx](#) register must be loaded before McSPI is selected by a master.
- Its own receiver register, SPIm.[MCSPI\\_RXx](#) (with x=0), on top of the common receive shift register. If the [MCSPI\\_RXx](#) register is full, the SPIm.[MCSPI\\_CHxSTAT\[0\]](#) RXS bit (with x=0) is set.

**NOTE:** The [MCSPI\\_TXx](#) register and [MCSPI\\_RXx](#) registers of the other channels are not used. Reading from or writing to a channel register other than channel 0 has no effect.

- Its own communication configuration with the following parameters through the SPIm. [MCSPI\\_CHxCONF](#) register (with x=0):
  - Transmit and receive modes, programmable with the TRM field
  - Interface mode (two data pins or single data pin) and data pins assignment, both programmable with the IS and DPE bits. (The SPIm modules are in slave mode after reset and must be properly configured for the modules to act in master mode.)
  - SPI word length, programmable with the WL bit
  - spim\_csx polarity, programmable with the EPOL bit

- spim\_clk polarity, programmable with the POL bit
- spim\_clk phase, programmable with the PHA bit

The spim\_clk frequency of a transfer is controlled by the external SPI master connected to the McSPI slave device. The SPIIm.[MCSPI\\_CHxCONF\[5:2\]](#) CLKD field (with x=0) is not used in slave mode.

---

**NOTE:** The configuration of the channel can be loaded in the SPIIm.[MCSPI\\_CHxCONF](#) register (with x=0) only when the channel is disabled.

---

- Two DMA request events, read and write, synchronize read/write accesses of the DMA controller with the activity of McSPI. DMA requests are asserted using the SPIIm.[MCSPI\\_CHxCONF\[15\]](#) DMAR bit (with x=0) for reading and the SPIIm.[MCSPI\\_CHxCONF\[14\]](#) DMAW bit (with x=0) for writing.
- Four interrupt events (see [Section 20.5.5.2, Interrupt Events in Slave Mode](#))

### 20.5.3.2 Slave Transmit-and-Receive Mode

The slave receive mode is programmable (set the SPIIm.[MCSPI\\_CHxCONF\[13:12\]](#) TRM field (with x=0) to 0x0).

In slave transmit-and-receive mode, the [MCSPI\\_TXx](#) register must be loaded before McSPI is selected by an external SPI master device.

After a channel is enabled, transmission and reception proceed with interrupt and DMA request events.

The [MCSPI\\_TXx](#) register content is always loaded in the shift register whether it is updated or not. The event TXx\_UNDERFLOW is activated accordingly and does not prevent transmission.

When an SPI word transfer completes (the SPIIm.[MCSPI\\_CHxSTAT0\[2\]](#) EOT bit (with x=0) set to 1), the received data is transferred to the channel receive register.

To use McSPI as a slave transmit-only device, the RXx\_FULL and RX0\_OVERFLOW interrupts and DMA read requests must be disabled due to the [MCSPI\\_RXx](#) register state (see [Section 20.5.5.2, Interrupt Events in Slave Mode](#)).

### 20.5.3.3 Slave Transmit-Only Mode

The slave transmit-only mode is programmable (set the SPIIm.[MCSPI\\_CHxCONF\[13:12\]](#) TRM field (with x=0) to 0x2) and avoids the requirement for the MPU to read the [MCSPI\\_RXx](#) register (minimizing data movement) only when transmission is meaningful.

To use the McSPI as a slave transmit-only device, the RXx\_FULL and RX0\_OVERFLOW interrupts and DMA read requests must be disabled because of the [MCSPI\\_RXx](#) register state.

When the SPI word transfer completes, the SPIIm.[MCSPI\\_CHxSTAT\[2\]](#) EOT bit is set (with x=0).

[Figure 20-19](#) shows a half-duplex system with a master device on the left and a transmit-only slave device on the right. Each time a bit transfers out from the slave device, 1 bit transfers in the master. After eight cycles of the serial clock spim\_clk, WordB transfers from the slave to the master.

**Figure 20-19. SPI Half-Duplex Transmission (Transmit-Only Slave)**



#### 20.5.3.4 Slave Receive-Only Mode

The slave receive mode is programmable (set the SPIIm.[MCSPI\\_CHxCONF\[13:12\]](#) TRM field (with x=0) to 0x1).

In receive-only mode, the [MCSPI\\_TXx](#) register must be loaded before the McSPI is selected by an external SPI master device. The [MCSPI\\_TXx](#) register content is always loaded into the shift register whether it is updated or not. The TXx\_UNDERFLOW event is activated accordingly and does not prevent transmission.

When an SPI word transfer completes (the SPIIm.[MCSPI\\_CHxSTAT0\[2\]](#) EOT bit (with x=0) is set to 1), the received data is transferred to the channel receive register.

To use the McSPI as a slave receive-only device, the TXx\_EMPTY and TXx\_UNDERFLOW interrupts and the DMA write requests must be disabled due to the [MCSPI\\_TXx](#) register state.

For a full-duplex transmission, the serial clock (spim\_clk) synchronizes shifting and sampling of the information on the single serial data line. For full duplex, two data lines are required. If spim\_clk synchronizes on a single serial data line, the data line should be half-duplex.

[Figure 20-20](#) shows an example of a half-duplex system with a master device on the left and a receive-only slave device on the right. Each time a bit transfers out from the master, 1 bit transfers in from the slave. After eight cycles of the serial clock spim\_clk, Word A transfers from the master to the slave.

**Figure 20-20. SPI Half-Duplex Transmission (Receive-Only Slave)**

#### 20.5.4 FIFO Buffer Management

The McSPI controller has a built-in 64 bytes buffer to unload DMA or interrupt handler and improve data throughput.

This buffer can be used by only one channel at once and is selected by setting SPIIm.**MCSPI\_CHxCONF[28]** FFER bit or SPIIm.**MCSPI\_CHxCONF[27]** FFEW bit to 1. If several channel are selected and several FIFO enable bit fields set to 1, the controller forces buffer not to be used, it is the responsibility of the driver to set only one FIFO enable bit field.

The buffer can be used in the modes defined below:

- Master or Slave mode.
- Transmit only, Receive only or Transmit/Receive mode.
- Single channel or turbo mode, or in normal round robin mode. In round robin mode the buffer is used by only one channel.
- Every word length SPIIm.**MCSPI\_CHxCONF[11:7]** WL are supported.

In transmit/receive mode, the buffer can be used in transmit (see [Figure 20-21](#)) or receive (see [Figure 20-22](#)) directions, or in both directions. If only one direction is chosen in transmit/receive mode, the full buffer is used for this direction. In both directions, the buffer is split into two 32-byte buffers, one for each direction. See [Figure 20-23](#).

**Figure 20-21. Buffer Use in Transmit Direction Only**


mcspi-102

**Figure 20-22. Buffer Use in Receive Direction Only**


mcspi-103

**Figure 20-23. Buffer Used For Both Transmit/Receive Directions**


mcspi-101

Two levels SPIm.MCSPI\_XFERLEVEL[5:0] AEL and SPIm.MCSPI\_XFERLEVEL[13:8] AFL rule the buffer management. The granularity of these levels is one byte, then it is not aligned with SPI word length. It is the responsibility of the driver to set these values as a multiple of SPI word length defined in WL. Table 20-14 shows the number of byte written in the FIFO depending on the word length.

**Table 20-14. FIFO Writes, Word Length Relationship**

| SPI Word Length WL                 | $3 \leq WL \leq 7$ | $8 \leq WL \leq 15$ | $16 \leq WL \leq 31$ |
|------------------------------------|--------------------|---------------------|----------------------|
| Number of byte written in the FIFO | 1 byte             | 2 bytes             | 4 bytes              |

The FIFO buffer pointers are reset when the corresponding channel is enabled or FIFO configuration changes.

#### 20.5.4.1 Buffer Almost Full

The MCSPI\_XFERLEVEL[13:8] AFL bit field is needed when the buffer is used to receive SPI word from a slave ([MCSPI\\_CHxCONF\[28\]](#) FFER bit must be set to 1). It defines the Almost Full buffer status. See [Figure 20-24](#).

When FIFO pointer reaches this level an interrupt or a DMA request is sent to the MPU to enable system to read AFL+1 bytes from Receive register. Be careful AFL+1 must correspond to a multiple value of [MCSPI\\_CHxCONF\[11:7\]](#) WL bit field.

When DMA is used, the request is de-asserted after the first Receive register read.

No new request will be asserted again as long as system has not performed the right number of read accesses.

**Figure 20-24. Buffer Almost Full Level (AFL)**



mcspi-043

**NOTE:** [MCSPI\\_IRQSTATUS](#) register bits are not available in DMA mode. In DMA mode, the SPIm\_DMA\_RXx request is asserted on the same conditions than the [MCSPI\\_IRQSTATUS RXx\\_FULL](#) flag.

#### 20.5.4.2 Buffer Almost Empty

The MCSPI\_XFERLEVEL[5:0] AEL bit field is needed when the buffer is used to transmit SPI word to a slave ([MCSPI\\_CHxCONF\[27\]](#) FFEW bit must be set to 1). It defines the Almost Empty buffer status. See [Figure 20-25](#).

When FIFO pointer has not reached this level an interrupt or a DMA request is sent to the MPU to enable system to write AEL+1 bytes to Transmit register. Be careful AEL+1 must correspond to a multiple value of [MCSPI\\_CHxCONF\[11:7\]](#) WL bit field.

When DMA is used, the request is de-asserted after the first Transmit register write.

No new request will be asserted again as long as system has not performed the right number of write accesses.

**Figure 20-25. Buffer Almost Empty Level (AEL)**

**NOTE:** [MCSPI\\_IRQSTATUS](#) register bits are not available in DMA mode. In DMA mode, the SPI<sub>m</sub>\_DMA\_TX<sub>x</sub> request is asserted on the same conditions than the [MCSPI\\_IRQSTATUS](#) TX<sub>x</sub>\_EMPTY flag.

#### 20.5.4.3 End of Transfer Management

When the FIFO buffer is enabled for a channel, the user shall previously configure in the MCSPI\_XFERLEVEL register the AEL and AFL levels and especially the MCSPI\_XFERLEVEL[31:16] WCNT bit field to define the number of SPI words to be transferred using the FIFO before enabling the channel.

This counter allows the controller to stop the transfer correctly after a defined number of SPI word transfers. If WNCT is set to 0x0000, the counter is not used and the user must stop the transfer manually by disabling the channel, in this case the user does not know how many SPI transfers have been done. For received words, software shall poll the CHxSTAT[5] RXFFE bit and read the [MCSPI\\_RX<sub>x</sub>](#) Receive register to empty the FIFO buffer.

When the End Of Word count interrupt is generated ([MCSPI\\_IRQSTATUS](#)[17] EOW bit set), the user can disable the channel and poll the [MCSPI\\_CHxSTAT](#)[5] RXFFE bit to know it lasts SPI words in the FIFO buffer and read them.

No new request will be asserted again as long as system has not performed the right number of write accesses.

**NOTE:** The status bit RXFFE shows only the FIFO status. The data received are stored not only in the FIFO, but also in the shift register and MCSPI\_RX register. Therefore, the FIFO can be empty even after receiving two words.

#### 20.5.5 Interrupts

Each channel can issue interrupt events.

Each interrupt event has status bits in the SPI<sub>m</sub>.[MCSPI\\_IRQSTATUS](#) register (RX<sub>x</sub>\_FULL, TX<sub>x</sub>\_UNDERFLOW, TX<sub>x</sub>\_EMPTY, ...) with x = [0,3] that indicate if service is required. Each status bit has an interrupt enable bit (a mask) in the SPI<sub>m</sub>.[MCSPI\\_IRQENABLE](#) register (RX<sub>x</sub>\_FULL\_ENABLE, TX<sub>x</sub>\_UNDERFLOW\_ENABLE, TX<sub>x</sub>\_EMPTY\_ENABLE, ...).

When an interrupt occurs and a mask is later applied on it, the interrupt line is not asserted again, even if the interrupt source is not serviced.

The McSPI supports interrupt-driven and polling operations.

### 20.5.5.1 Interrupt Events in Master Mode

In master mode, the interrupt events related to the [MCSPI\\_TXx](#) register state are TXx\_EMPTY and TXx\_UNDERFLOW. The interrupt event related to the [MCSPI\\_RXx](#) register state is RXx\_FULL.

#### 20.5.5.1.1 TXx\_EMPTY

The TXx\_EMPTY event is activated when a channel is enabled and its [MCSPI\\_TXx](#) register is empty (transient event). Enabling a channel automatically triggers this event, except in master receive-only mode (see [Section 20.5.2.4, Master Receive-Only Mode](#)). When the FIFO buffer is enabled ([MCSPI\\_CHxCONF\[27\]](#) FF EW bit set to 1), the [MCSPI\\_IRQSTATUS](#) TXx\_EMPTY bit is set as soon as there is enough space in buffer to write a number of bytes defined by the [MCSPI\\_XFERLEVEL\[5:0\]](#) AFL bit field.

The [MCSPI\\_TXx](#) register must be loaded with data to remove the source of the interrupt; the SPIm.[MCSPI\\_IRQSTATUS](#) TXx\_EMPTY interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

When FIFO is enabled, no new TXx\_EMPTY event will be asserted as soon as the MPU has not performed the number of write into the [MCSPI\\_TXx](#) register defined by [MCSPI\\_XFERLEVEL\[5:0\]](#) AFL bit field. It is the responsibility of the MPU to perform the right number of writes.

#### 20.5.5.1.2 TXx\_UNDERFLOW

The event TXx\_UNDERFLOW is activated when the channel is enabled and if the [MCSPI\\_TXx](#) register or if the FIFO is empty (not updated with new data) when an external master device starts a data transfer with the McSPI (transmit and receive).

The TXx\_UNDERFLOW is a harmless warning in master mode.

To avoid having TXx\_UNDERFLOW event at the beginning of a transmission, the event TXx\_UNDERFLOW is not activated when no data has been loaded into the [MCSPI\\_TXx](#) register since channel has been enabled. To avoid having TXx\_UNDERFLOW event, the [MCSPI\\_TXx](#) register must be loaded seldom.

The SPIm.[MCSPI\\_IRQSTATUS](#) TXx\_UNDERFLOW interrupt status bit must be cleared for interrupt line de-assertion (if event enable as interrupt source).

#### 20.5.5.1.3 RXx\_FULL

The RXx\_FULL event is activated when channel is enabled and [MCSPI\\_RXx](#) register becomes filled (transient event). When FIFO buffer is enabled ([MCSPI\\_CHxCONF\[28\]](#) FF ER bit set to 1), the RXx\_FULL is asserted as soon as the number of bytes holds in the FIFO to be read reaches the [MCSPI\\_XFERLEVEL\[13:8\]](#) AFL threshold.

The [MCSPI\\_RXx](#) register must be read to remove the source of the interrupt; the [MCSPI\\_IRQSTATUS](#) RXx\_FULL interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

When FIFO is enabled, no new RXx\_FULL event will be asserted as soon as the MPU has not performed AFL+1 reads into [MCSPI\\_RXx](#). It is the responsibility of MPU to perform the right number of reads.

#### 20.5.5.1.4 End Of Word Count

The [MCSPI\\_IRQSTATUS\[17\]](#) EOW event (End Of Word count) is activated when channel is enabled and configured to use the built-in FIFO. This interrupt is raised when the controller had performed the number of transfer defined in the [MCSPI\\_XFERLEVEL\[31:16\]](#) WCNT bit field. If WCNT is set to 0x0000, the counter is not enable and this interrupt is not generated.

The End of Word count interrupt also indicates that the SPI transfer is halt on channel using the FIFO buffer as soon as [MCSPI\\_XFERLEVEL\[31:16\]](#) WCNT is not reloaded and the channel is not re-enabled.

The [MCSPI\\_IRQSTATUS\[17\]](#) EOW interrupt status bit must be cleared for interrupt line de-assertion (if event enable as interrupt source).

### 20.5.5.2 Interrupt Events in Slave Mode

In slave mode, the interrupt events related to the [MCSPI\\_TXx](#) register state are TXx\_EMPTY and TXx\_UNDERFLOW. The interrupt events related to the [MCSPI\\_RXx](#) register state are RXx\_FULL and RX0\_OVERFLOW (channels 1, 2, and 3 do not have a receiver overflow status bit). See the [MCSPI\\_IRQSTATUS](#) register.

#### 20.5.5.2.1 TXx\_EMPTY

The TXx\_EMPTY event is activated when a channel is enabled and its [MCSPI\\_TXx](#) register is empty. Enabling the channel automatically raises this event. If the FIFO buffer is enabled ([MCSPI\\_CHxCONF\[27\]](#) FFEW bit set to 1), the TXx\_EMPTY event is asserted as soon as there is enough space in buffer to write a number of byte defined by the [MCSPI\\_XFERLEVEL\[5:0\]](#) AFL bit field.

The [MCSPI\\_TXx](#) register must be loaded with data to remove the source of the interrupt; the SPIm.[MCSPI\\_IRQSTATUS](#) TXx\_EMPTY interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

When FIFO is enabled, no new TXx\_EMPTY event will be asserted as soon as the MPU has not performed the number of write into the [MCSPI\\_TXx](#) register defined by [MCSPI\\_XFERLEVEL\[5:0\]](#) AFL bit field. It is the responsibility of the MPU to perform the right number of writes.

#### 20.5.5.2.2 TXx\_UNDERFLOW

The TXx\_UNDERFLOW event is activated when a channel is enabled and if the [MCSPI\\_TXx](#) register is empty (not updated with new data) when an external master device starts a data transfer with the McSPI (transmit and receive).

When FIFO is enabled, the data emitted while underflow event is raised is not the last data written in the FIFO but the next data in the FIFO (an old transmitted value or a dummy data is the FIFO has been reset).

TXx\_UNDERFLOW indicates an error (data loss) in slave mode.

To avoid having a TXx\_UNDERFLOW event at the beginning of a transmission, the TXx\_UNDERFLOW event is not activated when data is not loaded into the [MCSPI\\_TXx](#) register because the channel is enabled.

The SPIm.[MCSPI\\_IRQSTATUS](#) TXx\_UNDERFLOW interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

#### 20.5.5.2.3 RXx\_FULL

The RXx\_FULL event is activated when a channel is enabled and the [MCSPI\\_RXx](#) register is being filled (transient event). When FIFO buffer is enabled ([MCSPI\\_CHxCONF\[28\]](#) FFER bit set to 1), RXx\_FULL is asserted as soon as there is a number of bytes holds in buffer to read defined by the [MCSPI\\_XFERLEVEL\[13:8\]](#) AFL bit field.

The [MCSPI\\_RXx](#) register must be read to remove the source of the interrupt; the SPIm.[MCSPI\\_IRQSTATUS](#) RXx\_FULL interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

When FIFO is enabled, no new RXx\_FULL event will be asserted as soon as the MPU has not performed AFL+1 reads into [MCSPI\\_RXx](#). It is the responsibility of MPU to perform the right number of reads.

#### 20.5.5.2.4 RX0\_OVERFLOW

The RX0\_OVERFLOW event is activated in slave mode in either transmit-and-receive or receive-only mode, when a channel is enabled and the [MCSPI\\_RXx](#) register or FIFO is full when a new SPI word is received. The [MCSPI\\_RXx](#) register is always overwritten with the new SPI word. If the FIFO is enabled data within the FIFO are overwritten, it must be considered as corrupted. The RX0\_OVERFLOW event should not appear in slave mode using the FIFO.

The RX0\_OVERFLOW indicates an error (data loss) in slave mode.

The [MCSPI IRQSTATUS\[3\]](#) RX0\_OVERFLOW interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

#### 20.5.5.2.5 End Of Word Count

The [MCSPI IRQSTATUS\[17\]](#) EOW event (End Of Word count) is activated when channel is enabled and configured to use the built-in FIFO. This interrupt is raised when the controller had performed the number of transfer defined in the [MCSPI\\_XFERLEVEL\[31:16\]](#) WCNT bit field. If WCNT is set to 0x0000, the counter is not enabled and this interrupt is not generated.

The End of Word count interrupt also indicates that the SPI transfer is halt on channel using the FIFO buffer as soon as WCNT is not reloaded and channel re-enabled.

The [MCSPI IRQSTATUS\[17\]](#) EOW interrupt status bit must be cleared for interrupt line de-assertion (if event enable as interrupt source).

#### 20.5.5.3 Interrupt-Driven Operation

An interrupt enable bit, in SPIm.[MCSPI IRQENABLE](#) register, can be set to enable each event to generate interrupt requests when the corresponding event occurs. Status bits are automatically set by hardware logic conditions.

When an event occurs (the single interrupt line is asserted), the MPU must:

- Read the SPIm.[MCSPI IRQSTATUS](#) register to identify which event occurred.
- Read the [MCSPI\\_RXx](#) register that corresponds to the event to remove the source of an RXx\_FULL event or write into the [MCSPI\\_TXx](#) register that corresponds to the event to remove the source of a TXx\_EMPTY event. No action is required to remove the source of the WKS (wake-up), TXx\_UNDERFLOW, and RX0\_OVERFLOW events.
- Write 1 into the corresponding bit of the SPIm.[MCSPI IRQSTATUS](#) register to clear an interrupt status and then release the interrupt line.

The interrupt status bit must always be reset after channel enabling and before events are enabled as interrupt sources.

#### 20.5.5.4 Polling

When the interrupt capability of an event is disabled in the SPIm.[MCSPI IRQENABLE](#) register, the interrupt line is not asserted, but the status bits in the SPIm.[MCSPI IRQSTATUS](#) register can be polled by software to detect when the corresponding event occurs.

Once the expected event occurs:

- RXx\_FULL: To remove the source of the event, the MPU must read the corresponding [MCSPI\\_RXx](#) register.
- TXx\_EMPTY: To remove the source of the event, the MPU must write into the corresponding [MCSPI\\_TXx](#) register.
- WKS (wake-up), TXx\_UNDERFLOW, and RX0\_OVERFLOW: No action is required to remove the source of the event.

To clear an interrupt, set the corresponding status bit of the SPIm.[MCSPI IRQSTATUS](#) register to 1. This does not affect the interrupt line state.

#### 20.5.6 DMA Requests

The sDMA controller module manages DMA accesses. The sDMA controller advantage is to lower the MPU charge for data transfers.

Each McSPI channel can issue DMA requests if they are enabled. There are two DMA request lines per McSPI channel (one for read and one for write).

The DMA read request line is asserted when the McSPI channel is enabled and new data is available in the receive register of the McSPI channel. A DMA read request can be individually masked with the SPI1.[MCSPI\\_CHxCONF\[15\]](#) DMAR bit. The DMA read request line is deasserted on read completion of the [MCSPI\\_RXx](#) register of the McSPI channel.

The DMA write request line is asserted when the McSPI channel is enabled and the [MCSPI\\_TXx](#) register of the McSPI channel is empty. A DMA write request can be individually masked with the SPI1.[MCSPI\\_CHxCONF\[14\]](#) DMAW bit. The DMA write request line is deasserted on load completion of the [MCSPI\\_TXx](#) register of the channel.

## 20.5.7 Power Saving Management

Power consumption can be optimized by switching off internal clocks (interface and functional clock) when there is no activity. The McSPI is compliant with the idle and wake-up system handshake protocol.

### 20.5.7.1 Normal Mode

In normal mode, internal SPI module clocks are automatically switched off (autogating) when there is no activity in slave or master mode.

Autogating of the module interface clock and functional clock occurs when the following conditions are met:

- The SPI1.[MCSPI\\_SYSCONFIG\[0\]](#) AUTOIDLE bit is set.
- In master mode, there is no data to transmit or receive in all channels.
- In slave mode, the McSPI is not selected by the external master and there are no register accesses.

Autogating of the module interface clock and functional clock stops when the following conditions are met:

- In master mode, an internal access occurs.
- In slave mode, an internal access occurs or the McSPI is selected by the external master.

### 20.5.7.2 Idle Mode

At the PRCM module level, when all conditions are met to shut off the CORE\_48M\_FCLK or CORE\_L4\_ICLK output clocks (see [Chapter 3, Power, Reset, and Clock Management](#), for details), the PRCM module automatically launches a hardware handshake protocol to ensure that the McSPI is ready to have its clocks switched off. Namely, the PRCM module asserts an idle request to the McSPI.

Although this handshake is completely hardware-oriented and out of software control, the method in which the McSPI module acknowledges the PRCM idle request is configurable through the McSPI.SYSCONFIG[4:3] SIDLEMODE bit.

The following list details the settings of the SIDLEMODE bit and the related acknowledgment modes:

- Force-idle mode (the SPI1.[MCSPI\\_SYSCONFIG\[4:3\]](#) SIDLEMODE bit set to 0x0): the McSPI module acknowledges unconditionally the idle request from the PRCM module, regardless of its internal operations. This mode must be used carefully in this case because it does not prevent the loss of data when the clock is switched off.
- No-idle mode (the SIDLEMODE bit set to 0x1): The McSPI module never acknowledges an idle request from the PRCM module and is safe from a module point of view because it ensures that the clocks remain active. However, it is not efficient to save power because it does not allow the PRCM output clock to be shut off and thus the power domain to be set to a lower power state.
- Smart-idle mode (the SIDLEMODE bit set to 0x2): The McSPI module acknowledges the idle request, basing its decision on its internal activity. Namely, the acknowledge signal is asserted only when all pending transactions, IRQs, or DMA requests are treated. This is the best approach for an efficient system power management.

When configured in smart-idle mode, the McSPI module also offers an additional granularity on the CORE\_48M\_FCLK and CORE\_L4\_ICLK gating. The SPI1.[SYSCONFIG\[9:8\]](#) CLOCKACTIVITY bit field determines which clock shuts down (the CORE\_48M\_FCLK, the CORE\_L4\_ICLK, neither clock, or both clocks).

The CLOCKACTIVITY setting is used internally to McSPI to determine on which part of the module the conditions to acknowledge the PRCM idle request are tested. For example, if CORE\_48M\_FCLK is not shut down on a PRCM idle request, McSPI considers only CORE\_L4\_ICLK and the associated pending activities before acknowledging the request.

Some McSPI features are associated with CORE\_L4\_ICLK and others with CORE\_48M\_FCLK. Using the CLOCKACTIVITY bit field along with the smart-idle mode ensures that the features associated with the clock that remains active are always enabled, even if McSPI acknowledges an idle request.

The following list details CLOCKACTIVITY settings and the associated features:

- CLOCKACTIVITY set to 00: ICLK OFF and FCLK OFF, both ICLK and FCLK are taken into account for generating the acknowledge. This setting also means that both FCLK and ICLK are likely to be shut down on a PRCM idle request.
- CLOCKACTIVITY set to 01: ICLK ON and FCLK OFF, ICLK is not shut down on a PRCM idle request; only FCLK is concerned.
- CLOCKACTIVITY set to 10: ICLK OFF and FCLK ON, FCLK is not shut down on a PRCM idle request; only ICLK is concerned.
- CLOCKACTIVITY set to 11: ICLK ON and FCLK ON, none of the clocks are shut down. This means McSPI can potentially acknowledge the idle request without checking the internal functionalities linked to its clocks.

#### CAUTION

The PRCM module does not have a hardware means of reading the CLOCKACTIVITY settings. Therefore, the software must ensure consistent programming between the CLOCKACTIVITY and the PRCM CORE\_48M\_FCLK and CORE\_L4\_ICLK control bits. If the McSPI is disabled in both the CM\_FCLKEN and CM\_ICLKEN PRCM registers while CLOCKACTIVITY is set to 11, nothing prevents the PRCM module from asserting its idle request, which is acknowledged regardless of the features associated with the McSPI clocks. This can lead to unpredictable behavior.

#### 20.5.7.2.1 Wake-Up Event in Smart-Idle Mode

The module wake-up feature is enabled when both the SPIIm.[MCSPI\\_SYSCONFIG\[2\]](#) ENAWAKEUP and SPIIm.[MCSPI\\_WAKEUPENABLE\[0\]](#) WKEN bits are set. Wake-up capability is relevant only when the module is configured in slave mode.

The module generates an asynchronous wake-up request to the system power manager to switch the interface clock and the functional clock back. A wake-up is requested when channel 0 is enabled and an asynchronous selection occurs on the spim.csx port associated with channel 0 (see the definition for the SPIIm.[MCSPI\\_CHxCONF](#) SPIENSLV field (with x=0) in the register description table).

After the McSPI wake-up request, the system power manager must reactivate the interface clock:

- *Before the beginning* of the second SPI word serialization when McSPI is in slave transmit-only mode or in slave transmit-and-receive mode
- *Before the end* of the second received SPI word in slave receive-only mode. To avoid data loss, the first received SPI word must be read from the SPIIm.[MCSPI\\_RXx](#) register (with x=0) before the completion of the second SPI word serialization.

[Table 20-15](#) lists the supported cases in wake-up mode.

**Table 20-15. Smart-Idle Mode and Wake-Up Capabilities**

| Mode   | Interface Clock    | SPI Clock Ref      | Functionality                                                                                                            | Wake-Up Event    |
|--------|--------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|------------------|
| Master | Must be maintained | Must be maintained | Full functionality, but the module does not generate a new interrupt or DMA request until the system exits wake-up mode. | No wake-up event |

**Table 20-15. Smart-Idle Mode and Wake-Up Capabilities (continued)**

| Mode  | Interface Clock     | SPI Clock Ref       | Functionality                                                                                                                                            | Wake-Up Event                                                                                                           |
|-------|---------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| Slave | Can be switched off | Can be switched off | An SPI word can be transmitted and/or received, but the module does not generate any new interrupts or DMA requests until the system exits wake-up mode. | The module asynchronously sends a wake-up request if an event on the spim_csx port associated to channel 0 is detected. |

In wake-up mode, the interrupt and DMA request lines are no longer asserted.

Any access to the module in wake-up mode generates an error as long as the interface clock is alive.

#### **20.5.7.2.2 Transitions From Smart-Idle Mode to Normal Mode**

The McSPI detects the end of the wake period through the idle and wake-up hardware handshake protocol.

The interrupt status register (the SPIm.[MCSPI\\_IRQSTATUS](#)[16] WKS bit) is updated with the event causing the wake-up; the wake-up event at the origin of the transition to the normal mode is converted to its corresponding interrupt when enabled by the SPIm.[MCSPI\\_IRQENABLE](#)[16] WKE bit or the DMA request.

Interrupts and wake-up events have independent enable/disable controls, accessible through the SPIm.[MCSPI\\_IRQENABLE](#) and SPIm.[MCSPI\\_WAKEUPENABLE](#) registers. Software must ensure the overall consistency.

The interrupt status register SPIm.[MCSPI\\_IRQSTATUS](#) is updated with the event causing the wake-up; the wake-up event at the origin of the transition to normal mode is converted to its corresponding interrupt request or DMA request. The module is fully operational.

#### **20.5.7.2.3 Force-Idle Mode**

Force-idle mode is enabled and exited as follows:

- Force-idle mode is enabled when the SPIm.[MCSPI\\_SYSCONFIG](#)[4:3] SIDLEMODE field is set to 0x0. In force-idle mode, McSPI responds unconditionally to the idle request by deasserting unconditionally the interrupt and DMA request lines, if asserted. In addition, the wake-up capability is totally inhibited even if both the SPIm.[MCSPI\\_SYSCONFIG](#)[2] ENAWAKEUP and SPIm.[MCSPI\\_WAKEUPENABLE](#)[0] WKEN bits are set.

The transition from normal mode to idle mode does not affect the interrupt event bits of the SPIm.[MCSPI\\_IRQSTATUS](#) register.

In force-idle mode, the module must be disabled so the interrupt and DMA request lines are likely deasserted. The interface clock and SPI clock provided to the McSPI can be switched off.

An idle request during an SPI data transfer can lead to an unexpected and unpredictable result. The software must avoid such a request.

- The module exits force-idle mode through the idle and wake-up hardware handshake protocol. The module is fully operational. The interrupt and DMA request lines are optionally asserted one clock cycle later.

## 20.6 McSPI Basic Programming Model

### 20.6.1 Initialization of Modules

Figure 20-26 shows the overview of the module initialization flow process. Section 20.6.2 and Section 20.6.3 show the steps required to configure McSPI modes.

**Figure 20-26. Module Initialization Flow**



mcspi-018

**NOTE:** Before the SPIIm.MCSPI\_SYSSTATUS[0] RESETDONE bit is set, the CLK and CLKSPIREF clocks must be provided to the module.

To avoid unpredictable behavior, reset the module before changing from master mode to slave mode, or vice versa.

### 20.6.2 Transfer Procedures without FIFO

In the subsections below, the transfer procedures are described without FIFO using (MCSPI\_CHxCONF[27:28] FFER and FF EW = 0).

The McSPI allows the transfer of one or more words based on the different modes:

- Master normal, master turbo, slave
- Transmit-and-receive, transmit-only, receive-only

- Write and read requests: Interrupts, DMA
- spi1\_csx line assertion/deassertion: Automatic, manual

For these flows, the host process contains the main process and the interrupt routines. The interrupt routines are called on the interrupt signals or by an internal call if the module is used in polling mode.

#### 20.6.2.1 Common Transfer Procedure

Figure 20-27 shows the main sequence common to all transfers. In multichannel master mode, the flows of different channels can be run simultaneously.

**Figure 20-27. Common Transfer Sequence: Main Process**



mcspi-030

#### 20.6.2.2 End-of-Transfer Procedure

For transfers carried out with DMA or interrupt mode, the end of transfer must be achieved by following the steps shown in the flowcharts corresponding to Table 20-16, which summarizes the end-of-transfer types per transfer mode and provides cross-references for further information.

**Table 20-16. End-of-Transfer Sequences**

|               |                                  | Transmit Receive                     |     | Transmit Only                        |                                      | Receive Only                           |                                        |
|---------------|----------------------------------|--------------------------------------|-----|--------------------------------------|--------------------------------------|----------------------------------------|----------------------------------------|
|               |                                  | Interrupt                            | DMA | Interrupt                            | DMA                                  | Interrupt                              | DMA                                    |
| Master normal | End of transfer sequence         | See <a href="#">Section 20.6.2.3</a> |     | See <a href="#">Section 20.6.2.4</a> | See <a href="#">Section 20.6.2.4</a> | See <a href="#">Section 20.6.2.5.1</a> | See <a href="#">Section 20.6.2.5.1</a> |
|               | Minimum number of words          | 1                                    | 1   | 1                                    | 1                                    | 1                                      | 1                                      |
|               | DMA transfer size <sup>(1)</sup> |                                      | w   |                                      | w                                    |                                        | w - 1                                  |
| Master turbo  | End of transfer sequence         | See <a href="#">Section 20.6.2.3</a> |     | See <a href="#">Section 20.6.2.4</a> | See <a href="#">Section 20.6.2.4</a> | See <a href="#">Section 20.6.2.5.2</a> | See <a href="#">Section 20.6.2.5.2</a> |
|               | Minimum number of words          | 1                                    | 1   | 1                                    | 1                                    | 2                                      | 3                                      |
|               | DMA transfer size <sup>(1)</sup> |                                      | w   |                                      | w                                    |                                        | w - 2                                  |
| Slave         | End of transfer sequence         | See <a href="#">Section 20.6.2.3</a> |     | See <a href="#">Section 20.6.2.4</a> | See <a href="#">Section 20.6.2.4</a> | See <a href="#">Section 20.6.2.5.3</a> |                                        |
|               | Minimum number of words          | 1                                    | 1   | 1                                    | 1                                    | 1                                      | 1                                      |
|               | DMA transfer size <sup>(1)</sup> |                                      | w   |                                      | w                                    | w                                      | w                                      |

<sup>(1)</sup> w = number of words to transfer

The different sequences can be merged in one process to manage transfers of several types. The end-of-transfer sequences are described from the start of the channel.

In these sequences and in later sections of this chapter, some software variables are used:

- WRITE\_COUNT (= 0 at initialization): Contains the number of words to transfer
- READ\_COUNT (= 0 at initialization): Contains the number of words to receive
- CHANNEL\_ENABLE (= false at initialization)
- LAST\_TRANSFER (= false at initialization): Indicates that the last word is in transmission
- LAST\_REQUEST (= false at initialization): Indicates that the last request is in progress

All variables are initialized before starting the channel.

### 20.6.2.3 Transmit and Receive Procedure

[Figure 20-28](#) shows the handling procedure for words received and transmitted by interrupt in master and slave modes. The main process flow shows how the end of the transfer must be done after all words are received for this mode.

If the requests are configured in DMA, WRITE\_COUNT and READ\_COUNT are assigned with the value w when the DMA handler completes w interface accesses.

**Figure 20-28. Transmit and Receive (Master and Slave)**



mcspi-033

## 20.6.2.4 Transmit-Only Procedure

### 20.6.2.4.1 Based on Interrupt Requests

Figure 20-29 shows the handling procedure for words transmitted by interrupt in transmit-only mode. The main process flow shows how the end-of-transfer must be done after all words are received for this mode.

**Figure 20-29. Transmit-Only With Interrupts (Master and Slave)**



mcspi-023

### 20.6.2.4.2 Transmit-Only Based on DMA Write Requests

In Figure 20-30, the main process shows completion of the transfer of words in transmit-only mode with DMA write requests.

When the DMA handler completes  $w$  interface accesses,  $WRITE\_COUNT$  is assigned the value  $w$ .

**Figure 20-30. Transmit-Only With DMA (Master and Slave)**


mcspi-024

### 20.6.2.5 Receive-Only Procedure

#### 20.6.2.5.1 Master Normal Receive-Only Procedure

##### 20.6.2.5.1.1 Based on Interrupt Requests

Figure 20-31 shows the handling procedure for words received by interrupt in master normal receive-only mode. The main process flow shows how the end-of-transfer must be done after all words are received for this mode.

**Figure 20-31. Receive Only With Interrupt (Master Normal)**

#### 20.6.2.5.1.2 Receive-Only Based on DMA Read Requests

In Figure 20-32, the main process shows the completion of a word transfer in receive-only mode with DMA read requests.

When the DMA handler completes  $w - 1$  interface accesses, READ\_COUNT is assigned the value  $w - 1$ .

**Figure 20-32. Receive-Only With DMA (Master Normal)**

mcspi-025

### 20.6.2.5.2 Master Turbo Receive-Only Procedure

#### 20.6.2.5.2.1 Based on Interrupt Requests

Figure 20-33 shows the handling procedure for words received by interrupt in master turbo receive-only mode. The main process shows how the end-of-transfer must be done after all words are received for this mode.

**Figure 20-33. Receive-Only With Interrupt (Master Turbo)**

#### 20.6.2.5.2.2 Based on DMA Read Requests

In Figure 20-34, the main process shows the completion of a word reception in master turbo receive-only mode with DMA write requests.

When the DMA handler completes  $w - 2$  interface accesses, READ\_COUNT is assigned the value  $w - 2$ .

**Figure 20-34. Receive-Only With DMA (Master Turbo)**

mcsipi-028

#### 20.6.2.5.3 Slave Receive-Only Procedure

Figure 20-35 shows the handling procedure for words received by interrupt in slave receive-only mode. The main process shows how the end-of-transfer must be done after all words are received for this mode.

If the requests are configured in DMA, READ\_COUNT is assigned the value  $w$  when the DMA handler completes  $w$  interface processes.

**Figure 20-35. Receive Only (Slave)**

mcspi-035

### 20.6.2.6 McSPI Configuration and Operations Example

This section details an example of a typical configuration.

[Figure 20-36](#) shows an implementation of successive transfers between two devices (slave) and the McSPI1 (master) in transmit-and-receive mode.

McSPI1 is the master, and spi1\_simo shifts out the data to the external slaves. spi1\_somi is connected to the data output port of two slave devices. The McSPI1 controls the first device with the spi1\_cs0 signal (active low) for the exchange of 9-bit words synchronized with an active-high SPI clock.

The second device is controlled by the spi1\_cs1 control signal (active high) for the exchange of 4-bit words synchronized with a SPI clock (active low) with a slower frequency than used with the first slave device.

**Figure 20-36. Two SPI Transfers With PHA = 0 (Flexibility of McSPI)**



mcspi-036

This section details the steps required for this type of transmission.

#### 20.6.2.6.1 McSPI Initialization Sequence

As shown in [Figure 20-26](#), the McSPI module must first reset all registers and all state-machines.

For a software reset:

1. Set the SPI1.[MCSPI\\_SYSCONFIG\[1\]](#) SOFTRESET bit to 1.
2. Read the SPI1.[MCSPI\\_SYSSTATUS\[0\]](#) RESETDONE bit and check that it is set to 1.

#### 20.6.2.6.2 Operations for the First Slave (On Channel 0)

##### 20.6.2.6.2.1 Programming in Polling Mode

###### 20.6.2.6.2.1.1 Mode Selection

The SPI1.[MCSPI\\_CHxCONF](#) register (with x = 0) allows configuration of the operating mode:

1. Set the SPI1.[MCSPI\\_CHxCONF\[18\]](#) IS bit to 0 for the spi1\_somi pin in receive mode.
2. Set the SPI1.[MCSPI\\_CHxCONF\[17\]](#) DPE1 bit to 0 and the SPI1.[MCSPI\\_CHxCONF\[16\]](#) DPE0 bit to 1 for the spi1.simo pin in transmit mode.
3. Set the SPI1.[MCSPI\\_CHxCONF\[13:12\]](#) TRM field to 0x0 for transmit and receive mode.
4. Write 0x8 in the SPI1.[MCSPI\\_CHxCONF\[11:7\]](#) WL field for 9-bit word length.

5. Set the SPI1.[MCSPI\\_CHxCONF](#)[6] EPOL bit to 1 for spi1\_cs0 activated low during active state.
6. Set the SPI1.[MCSPI\\_CHxCONF](#)[1] POL bit to 0 for spi1\_clk held high during active state.
7. Set the SPI1.[MCSPI\\_CHxCONF](#)[0] PHA bit to 0 for data latched on odd-numbered edges of the SPI clock.

#### Clock Initialization and spi1\_cs0 Enable

In master mode, the SPI must provide the clock and enable the channel:

8. Set the SPI1.[MCSPI\\_MODULCTRL](#)[2] MS bit to 0 to provide the clock.
9. Set the INPUTENABLE bit of the corresponding CONTROL\_PADCONF\_x register to achieve the synchronous clock by using loopback through the output and input buffers of the pad.
10. Set the SPI1.[MCSPI\\_CHxCTRL](#)[0] EN bit to 1 (where x = 0) to enable channel 0.

#### 20.6.2.6.2.1.2 Write Operation

1. Write 1 to the SPI1.[MCSPI\\_IRQSTATUS](#)[0] TX0\_EMPTY bit to reset the status.
2. Write the command/address or data value in the SPI1.[MCSPI\\_TX0](#) register to transmit the value.
3. If the SPI1.[MCSPI\\_IRQSTATUS](#)[0] TX0\_EMPTY bit is set to 1, write 1 to it and return to Step 2 (polling method).

#### 20.6.2.6.2.1.3 Read Operation

1. Read the SPI1.[MCSPI\\_IRQSTATUS](#)[2] RX0\_FULL bit and if it is set to 1, go to Step 2.
2. If the SPI1.[MCSPI\\_IRQSTATUS](#)[2] RX0\_FULL bit is set to 1, write 1 to it and return to Step 1 (polling method).

---

**NOTE:** Write and read operations can be performed simultaneously.

---

#### 20.6.2.6.3 Programming in Interrupt Mode

This section follows the flow of [Figure 20-26](#).

1. Initialize software variables: WRITE\_COUNT = 0 and READ\_COUNT = 0.
2. Initialize interrupts: Write 0x7 in the SPI1.[MCSPI\\_IRQSTATUS](#)[3:0] field and set the SPI1.[MCSPI\\_IRQENABLE](#)[3:0] field to 0x7.
3. Follow the steps described in [Section 20.6.2.6.2.1.1, Mode Selection](#).
4. If WRITE\_COUNT = w and READ\_COUNT = w, write SPI1.[MCSPI\\_CHxCTRL](#)[0] = 0x0 (x = 0) to stop the channel.

This interrupt routine follows the flow of [Table 20-16](#) and [Figure 20-28](#).

1. Read the SPI1.[MCSPI\\_IRQSTATUS](#)[3:0] field.
2. If the SPI1.[MCSPI\\_IRQSTATUS](#)[0] TX0\_EMPTY bit is set to 1:
  - (a) Write the command/address or data value in SPI1.[MCSPI\\_TXx](#) (where x = 0).
  - (b) WRITE\_COUNT += 1
  - (c) Write SPI1.[MCSPI\\_IRQSTATUS](#)[0] = 0x1.
3. If the SPI1.[MCSPI\\_IRQSTATUS](#)[2] RX0\_FULL bit is set to 1:
  - (a) Read SPI1.[MCSPI\\_RXx](#) (where x = 0)
  - (b) READ\_COUNT += 1
  - (c) Write SPI1.[MCSPI\\_IRQSTATUS](#)[2] = 0x1

#### 20.6.2.6.4 Operations for the Second Slave (on Channel 1) in Polling Mode

##### 20.6.2.6.4.1 Mode Selection

The SPI1.[MCSPI\\_CHxCONF](#) register (with x = 1) allows configuration of the operating mode:

1. Set the SPI1.MCSPI\_CH1CONF[18] IS bit to 0 for the spi1\_somi pin in receive mode.
2. Set the SPI1.MCSPI\_CH1CONF[17] DPE1 bit to 0 and the SPI1.MCSPI\_CH1CONF[16] DPE0 bit to 1 for the spi1\_somi pin in transmit mode.
3. Set the SPI1.MCSPI\_CH1CONF[13:12] TRM field to 0x0 for transmit-and-receive mode.
4. Write 0x3 in the SPI1.MCSPI\_CH1CONF[11:7] WL field.
5. Set the SPI1.MCSPI\_CH1CONF[6] EPOL bit to 0 for spi1\_cs1 activated high during the active state.
6. Set the SPI1.MCSPI\_CH1CONF[1] POL bit to 1 for spi1\_clk held low during the active state.
7. Set the SPI1.MCSPI\_CH1CONF[0] PHA bit to 1 for data latched on even numbered edges of spi1\_clk.

#### **Clock Initialization and spi1\_cs1 Enable**

The SPI1.[MCSPI\\_MODULCTRL](#)[2] MS bit was set to 0 (providing the clock).

In master mode, the SPI must provide the clock and enable the channel:

8. Set the SPI1.MCSPI\_CH0CTRL[0] EN bit to 0 to disable channel 0, and set the SPI1.MCSPI\_CH1CTRL[0] EN bit to 1 to enable channel 1.

---

**NOTE:** Read and write operations for the second slave are identical to those for the first slave.

---

#### **20.6.2.6.4.2 Write Operation**

1. Write 1 to the SPI1.[MCSPI\\_IRQSTATUS](#)[4] TX1\_EMPTY bit to reset the status.
2. Write the command/address or data value in the SPI1.MCSPI\_TX1 register to transmit the value.
3. If the SPI1.[MCSPI\\_IRQSTATUS](#)[4] TX1\_EMPTY bit is set to 1, write 1 to it and return to Step 2 (polling method).

#### **20.6.2.6.4.3 Read Operation**

1. Read the SPI1.[MCSPI\\_IRQSTATUS](#)[6] RX1\_FULL bit and if it is set to 1, go to Step 2.
2. If the SPI1.[MCSPI\\_IRQSTATUS](#)[6] RX1\_FULL bit is set to 1, write 1 to it and return to Step 1 (polling method).

---

**NOTE:** Write and read operations can be performed simultaneously.

---

### **20.6.3 Transfer Procedures with FIFO**

In the subsections below, the transfer procedures are described with FIFO using ([MCSPI\\_CHxCONF](#)[27:28] FFER or/and FFEW = 1).

The MCSPI module allows the transfer of one or more words, according to different modes:

- Master normal, master turbo, slave
- Transmit-and-receive, transmit-only, receive-only
- Write and read requests: Interrupts, DMA

For these flows, the host process contains the main process and the interrupt routine, which is called on the IRQ signals or by an internal call if the module is used in polling mode.

#### **20.6.3.1 Common Transfer Procedure**

The common transfer sequence is the host sequence for a transfer of any type defined above.

In multichannel, only one channel can use the FIFO. Before enabling the FIFO for a channel (FFExW and FFExR bits in the [MCSPI\\_CHx\\_CONF](#) register), the host must ensure that the FIFO is not enabled for another channel, even if these channels are not used.

In transmit/receive mode, the FIFO can be enabled for write or read request only, without FIFO for the other request.

In slave mode, only channel 0 only can be activated. The correct spim\_csx line is chosen in the MCSPI\_CH0CONF register with the SPIENSLV bits.

The MCSPI module can start the transfer only when the first write request is released by writing the [MCSPI\\_TXx](#) register, even in receive-only mode (only one write request occurs in this case). [Figure 20-37](#) shows the main process of the common transfer sequence.

**Figure 20-37. Common Transfer Sequence/Main Process**



mcspi-041

The MCSPI module can start the transfer only after the first write request is released by writing the [MCSPI\\_TXx](#) register, even in receive-only mode (only one write request occurs in this case).

This first write request can be managed by the IRQ routine or DMA handler, as are as other requests. It appears in [Figure 20-37](#) to show this point.

The end of the transfer (dotted line in [Figure 20-37](#)) is more complex and depends on the transfer type. [Table 20-17](#) describes the different types of end-of-transfer and the transfer types to which they are applicable.

**Table 20-17. End-of-Transfer Types**

| Word Count | Transmit/Receive                                                            | Transmit Only                                         | Receive Only                                                            |
|------------|-----------------------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------------------------|
| Yes        | See <a href="#">Section 20.6.3.2, Transmit-Receive With Word Count</a> .    | See <a href="#">Section 20.6.3.4, Transmit-Only</a> . | See <a href="#">Section 20.6.3.5, Receive-Only With Word Count</a> .    |
| No         | See <a href="#">Section 20.6.3.3, Transmit-Receive Without Word Count</a> . | See <a href="#">Section 20.6.3.4, Transmit-Only</a> . | See <a href="#">Section 20.6.3.6, Receive-Only Without Word Count</a> . |

The sequence differs depending on whether word count is used (MCSPI\_XFERLEVEL: WCNT is set or not). The AEL and/or AFL values can be different, but they must be multiples of the word size in the FIFO: 1, 2, or 4 bytes, according to word length.

In these sequences, the transfer to execute has a size of N words.

When accessing the FIFO, only one word is written or read for each OCP access.

In these sequences, the number of words written or read for each write or read FIFO request is:

- `write_request_size`
- `read_request_size`

If they are not submultiples of N, the last request sizes are:

- `last_write_request_size (< write_request_size)`
- `last_read_request_size. (< read_request_size)`

The different sequences can be merged in one process to manage transfers of several types.

The end-of-transfer sequences are described from the start of the channel.

In these sequences, some soft variables are used:

- `write_count = N`
- `read_count = N`
- `last_request = FALSE`

They are initialized before starting the channel.

### 20.6.3.2 Transmit-Receive Procedure With Word Count (WCNT≠0)

[Figure 20-38](#) shows the flow of a transfer in transmit-receive mode, with word count.

**Figure 20-38. Transmit-Receive With Word Count**

mcspi-042

### 20.6.3.3 Transmit-Receive Procedure Without Word Count (WCNT=0)

Figure 20-39 shows the flow of a transfer in transmit-receive mode, without word count.

**Figure 20-39. Transmit-Receive Without Word Count**

mcspi-046

#### 20.6.3.4 Transmit-Only Procedure

Figure 20-40 shows the flow of a transfer in transmit only mode, with our without word count.

**Figure 20-40. Transmit-Only**

mcspi-047

The difference between word count enabled or not is the condition after starting the channel:

- Word count enable: Wait for EOW interrupt.
- Word count disable: Wait for write\_count = 0.

#### 20.6.3.5 Receive-Only Procedure With Word Count (WCNT≠0)

Figure 20-41 shows the flow of a transfer in receive-only mode, with word count.

**Figure 20-41. Receive-Only With Word Count**


mcspi-045

#### 20.6.3.6 Receive-Only Procedure Without Word Count (WCNT=0)

Figure 20-42 shows the flow of a transfer in receive-only mode, without word count.

**Figure 20-42. Receive-Only Without Word Count**

mcspi-048

## 20.7 McSPI Register Manual

### 20.7.1 McSPI Instance Summary

[Table 20-18](#) lists the McSPI instances.

**Table 20-18. McSPI Instance Summary**

| Module Name | Base Address | Size    |
|-------------|--------------|---------|
| MCSPI1      | 0x4809 8000  | 4Kbytes |
| MCSPI2      | 0x4809 A000  | 4Kbytes |
| MCSPI3      | 0x480B 8000  | 4Kbytes |
| MCSPI4      | 0x480B A000  | 4Kbytes |

### 20.7.2 McSPI Register Summary

[Table 20-19](#) lists the McSPI registers. Each register has a 32-bit width. [Table 20-20](#) through [Table 20-46](#) describe the register bits.

**Table 20-19. McSPI Register Summary**

| Register                                     | Type | Offset Address       | MCSPI1 Instance Physical Address | MCSPI2 Instance Physical Address | MCSPI3 Instance Physical Address | MCSPI4 Instance Physical Address |
|----------------------------------------------|------|----------------------|----------------------------------|----------------------------------|----------------------------------|----------------------------------|
| <a href="#">MCSPI_REVISION</a>               | R    | 0x00                 | 0x4809 8000                      | 0x4809 A000                      | 0x480B 8000                      | 0x480B A000                      |
| <a href="#">MCSPI_SYSCONFIG</a>              | RW   | 0x10                 | 0x4809 8010                      | 0x4809 A010                      | 0x480B 8010                      | 0x480B A010                      |
| <a href="#">MCSPI_SYSSTATUS</a>              | R    | 0x14                 | 0x4809 8014                      | 0x4809 A014                      | 0x480B 8014                      | 0x480B A014                      |
| <a href="#">MCSPI_IRQSTATUS</a>              | RW   | 0x18                 | 0x4809 8018                      | 0x4809 A018                      | 0x480B 8018                      | 0x480B A018                      |
| <a href="#">MCSPI_IRQENABLE</a>              | RW   | 0x1C                 | 0x4809 801C                      | 0x4809 A01C                      | 0x480B 801C                      | 0x480B A01C                      |
| <a href="#">MCSPI_WAKEUPENABLE</a>           | RW   | 0x20                 | 0x4809 8020                      | 0x4809 A020                      | 0x480B 8020                      | 0x480B A020                      |
| <a href="#">MCSPI_SYST</a>                   | RW   | 0x24                 | 0x4809 8024                      | 0x4809 A024                      | 0x480B 8024                      | 0x480B A024                      |
| <a href="#">MCSPI_MODULCTRL</a>              | RW   | 0x28                 | 0x4809 8028                      | 0x4809 A028                      | 0x480B 8028                      | 0x480B A028                      |
| <a href="#">MCSPI_CHxCONF <sup>(1)</sup></a> | RW   | 0x2C +<br>(0x14 * x) | 0x4809 802C +<br>(0x14 * x)      | 0x4809 A02C +<br>(0x14 * x)      | 0x480B 802C +<br>(0x14 * x)      | 0x480B A02C +<br>(0x14 * x)      |
| <a href="#">MCSPI_CHxSTAT <sup>(1)</sup></a> | R    | 0x30 +<br>(0x14 * x) | 0x4809 8030 +<br>(0x14 * x)      | 0x4809 A030 +<br>(0x14 * x)      | 0x480B 8030 +<br>(0x14 * x)      | 0x480B A030 +<br>(0x14 * x)      |
| <a href="#">MCSPI_CHxCTRL <sup>(1)</sup></a> | RW   | 0x34 +<br>(0x14 * x) | 0x4809 8034 +<br>(0x14 * x)      | 0x4809 A034 +<br>(0x14 * x)      | 0x480B 8034 +<br>(0x14 * x)      | 0x480B A034 +<br>(0x14 * x)      |
| <a href="#">MCSPI_TXx <sup>(1)</sup></a>     | RW   | 0x38 +<br>(0x14 * x) | 0x4809 8038 +<br>(0x14 * x)      | 0x4809 A038 +<br>(0x14 * x)      | 0x480B 8038 +<br>(0x14 * x)      | 0x480B A038 +<br>(0x14 * x)      |
| <a href="#">MCSPI_RXx <sup>(1)</sup></a>     | R    | 0x3C +<br>(0x14 * x) | 0x4809 803C +<br>(0x14 * x)      | 0x4809 A03C +<br>(0x14 * x)      | 0x480B 803C +<br>(0x14 * x)      | 0x480B A03C +<br>(0x14 * x)      |
| <a href="#">MCSPI_XFERLEVEL</a>              | RW   | 0x7C                 | 0x4809 807C                      | 0x4809 A07C                      | 0x480B 807C                      | 0x480B A07C                      |

<sup>(1)</sup> x= 0 to 3 for MCSPI1.

x= 0 to 1 for MCSPI2 and MCSPI3.

x= 0 for MCSPI4.

## 20.7.3 McSPI Register Description

**Table 20-20. MCSPI\_REVISION**

|                         |                                                            |                 |        |  |
|-------------------------|------------------------------------------------------------|-----------------|--------|--|
| <b>Address Offset</b>   | 0x00                                                       |                 |        |  |
| <b>Physical Address</b> | 0x4809 8000                                                | <b>Instance</b> | MCSPI1 |  |
|                         | 0x4809 A000                                                |                 | MCSPI2 |  |
|                         | 0x480B 8000                                                |                 | MCSPI3 |  |
|                         | 0x480B A000                                                |                 | MCSPI4 |  |
| <b>Description</b>      | This register contains the hard coded RTL revision number. |                 |        |  |
| <b>Type</b>             | R                                                          |                 |        |  |
| <b>Write Latency</b>    | Not relevant                                               |                 |        |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REV |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                        | Type | Reset              |
|------|------------|----------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | Reserved   | Reads returns 0                                                                                    | R    | 0x000000           |
| 7:0  | REV        | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision<br>Example: 0x10 for 1.0, 0x21 for 2.1 | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 20-21. Register Call Summary for Register MCSPI\_REVISION**

- McSPI Register Manual
- [McSPI Register Summary: \[0\]](#)

**Table 20-22. MCSPI\_SYSCONFIG**

|                         |                                                                                                                    |                 |        |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------|-----------------|--------|--|
| <b>Address Offset</b>   | 0x10                                                                                                               |                 |        |  |
| <b>Physical Address</b> | 0x4809 8010                                                                                                        | <b>Instance</b> | MCSPI1 |  |
|                         | 0x4809 A010                                                                                                        |                 | MCSPI2 |  |
|                         | 0x480B 8010                                                                                                        |                 | MCSPI3 |  |
|                         | 0x480B A010                                                                                                        |                 | MCSPI4 |  |
| <b>Description</b>      | This register allows control of various parameters of the module interface. It is not sensitive to software reset. |                 |        |  |
| <b>Type</b>             | RW                                                                                                                 |                 |        |  |
| <b>Write Latency</b>    | Immediate                                                                                                          |                 |        |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |               |          |           |           |           |          |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------------|----------|-----------|-----------|-----------|----------|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CLOCKACTIVITY | Reserved | SIDLEMODE | ENAWAKEUP | SOFTRESET | AUTOIDLE |   |

| Bits  | Field Name    | Description                                                                                                 | Type | Reset    |
|-------|---------------|-------------------------------------------------------------------------------------------------------------|------|----------|
| 31:10 | Reserved      | Reads returns 0                                                                                             | RW   | 0x000000 |
| 9:8   | CLOCKACTIVITY | Clocks activity during wake up mode period<br><br>0x0: Interface and Functional clocks may be switched off. | RW   | 0x0      |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x1: Interface clock is maintained. Functional clock may be switched off.<br>0x2: Functional clock is maintained. Interface clock may be switched off.<br>0x3: Interface and Functional clocks are maintained.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |       |
| 7:5  | Reserved   | Reads returns 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0x0   |
| 4:3  | SIDLEMODE  | Power management<br>0x0: If an idle request is detected, the McSPI acknowledges it unconditionally and goes in Inactive mode. Interrupt, DMA requests and wake up lines are unconditionally de-asserted and the module wake-up capability is deactivated even if the bit <a href="#">MCSPI_SYSCONFIG[ENAWAKEUP]</a> is set.<br>0x1: If an idle request is detected, the request is ignored and the module does not switch to wake up mode and keeps on behaving normally.<br>0x2: If an idle request is detected, the module will switch to wake up mode based on its internal activity and the wake up capability can be used if the bit <a href="#">MCSPI_SYSCONFIG[ENAWAKEUP]</a> is set.<br>0x3: Reserved - do not use. | RW   | 0x0   |
| 2    | ENAWAKEUP  | Wake-up feature control<br>0x0: Wake-up capability disabled<br>0x1: Wake-up capability enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW   | 0     |
| 1    | SOFTRESET  | Software reset. Read always returns 0.<br>0x0: Normal mode.<br>0x1: Trigger a module reset. This bit is automatically reset by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0     |
| 0    | AUTOIDLE   | Internal interface Clock gating strategy<br>0x0: interface clock is free-running<br>0x1: Automatic interface clock gating strategy is applied, based on the module interface activity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0     |

**Table 20-23. Register Call Summary for Register MCSPI\_SYSCONFIG**

McSPI Integration

- [Software Reset: \[0\] \[1\]](#)

McSPI Functional Description

- [Normal Mode: \[2\]](#)
- [Idle Mode: \[3\] \[4\] \[5\] \[6\]](#)

McSPI Basic Programming Model

- [McSPI Configuration and Operations Example: \[7\]](#)

McSPI Register Manual

- [McSPI Register Summary: \[8\]](#)
- [McSPI Register Description: \[9\] \[10\]](#)

**Table 20-24. MCSPI\_SYSSTATUS**

|                         |                                                                                                       |                 |        |
|-------------------------|-------------------------------------------------------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x14                                                                                                  |                 |        |
| <b>Physical Address</b> | 0x4809 8014                                                                                           | <b>Instance</b> | MCSPI1 |
|                         | 0x4809 A014                                                                                           |                 | MCSPI2 |
|                         | 0x480B 8014                                                                                           |                 | MCSPI3 |
|                         | 0x480B A014                                                                                           |                 | MCSPI4 |
| <b>Description</b>      | This register provides status information about the module excluding the interrupt status information |                 |        |
| <b>Type</b>             | R                                                                                                     |                 |        |
| <b>Write Latency</b>    | Immediate                                                                                             |                 |        |



| Bits | Field Name | Description                                                                                 | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Reserved for module specific status information.<br>Read returns 0                          | R    | 0x00000000 |
| 0    | RESETDONE  | Internal Reset Monitoring<br>0x0: Internal module reset is on-going<br>0x1: Reset completed | R    | 0          |

**Table 20-25. Register Call Summary for Register MCSPI\_SYSSTATUS**

## McSPI Basic Programming Model

- Initialization of Modules: [0]
- McSPI Configuration and Operations Example: [1]

## McSPI Register Manual

- McSPI Register Summary: [2]

**Table 20-26. MCSPI\_IRQSTATUS**

|                         |                                                                                                           |                 |        |
|-------------------------|-----------------------------------------------------------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x18                                                                                                      |                 |        |
| <b>Physical Address</b> | 0x4809 8018                                                                                               | <b>Instance</b> | MCSPI1 |
|                         | 0x4809 A018                                                                                               |                 | MCSPI2 |
|                         | 0x480B 8018                                                                                               |                 | MCSPI3 |
|                         | 0x480B A018                                                                                               |                 | MCSPI4 |
| <b>Description</b>      | The interrupt status regroups all the status of the module internal events that can generate an interrupt |                 |        |
| <b>Type</b>             | RW                                                                                                        |                 |        |
| <b>Write Latency</b>    | Immediate                                                                                                 |                 |        |



| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                    | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:18       | Reserved          | Reads returns 0                                                                                                                                                                                                                                                                                                       | RW          | 0x0000       |
| 17          | EOW               | End of word count event when a channel is enabled using the FIFO buffer and the channel had sent the number of SPI word defined by MCSPI_XFERLEVEL[31:16] WCNT bit field.<br>Write 0x0: Event status bit unchanged.<br>Read 0x0: Event false.<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending. | RW          | 0x0          |
| 16          | WKS               | Wake-up event in slave mode when an active control signal is detected on the spim_csx line programmed in the <b>MCSPI_CHxCONF[SPIENSLV]</b> field (where x=0 only)<br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending.          | RW          | 0x0          |
| 15          | Reserved          | Reads returns 0.                                                                                                                                                                                                                                                                                                      | RW          | 0x0          |
| 14          | RX3_FULL          | MCSPI_RX3 register is full (only when channel 3 is enabled)<br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending.                                                                                                                 | RW          | 0x0          |
| 13          | TX3_UNDERFLOW     | MCSPI_TX3 register underflow (only when channel 3 is enabled) <sup>(1)</sup><br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending.                                                                                                | RW          | 0x0          |
| 12          | TX3_EMPTY         | MCSPI_TX3 register is empty (only when channel 3 is enabled) <sup>(2)</sup><br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending.                                                                                                 | RW          | 0x0          |
| 11          | Reserved          | Read returns 0.                                                                                                                                                                                                                                                                                                       | RW          | 0x0          |
| 10          | RX2_FULL          | MCSPI_RX2 register full (only when channel 2 is enabled)<br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending.                                                                                                                    | RW          | 0x0          |
| 9           | TX2_UNDERFLOW     | MCSPI_TX2 register underflow (only when channel 2 is enabled) <sup>(1)</sup><br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending.                                                                                                | RW          | 0x0          |
| 8           | TX2_EMPTY         | MCSPI_TX2 register empty (only when channel 2 is enabled) <sup>(2)</sup><br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false                                                                                                                                                                            | RW          | 0x0          |

<sup>(1)</sup> The MCSPI\_Tx register is empty (not updated by host or DMA with new data) before its time slot assignment.

Exception: No TX\_UNDERFLOW event when no data has been loaded into the MCSPI\_Tx register since channel has been enabled.

<sup>(2)</sup> Enabling the channel automatically rises this event.

| Bits | Field Name    | Description                                                                                                                                                                                                                | Type | Reset |
|------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |               | Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending.                                                                                                                                                       |      |       |
| 7    | Reserved      | Read returns 0.                                                                                                                                                                                                            | RW   | 0x0   |
| 6    | RX1_FULL      | MCSPI_RX1 register full (only when channel 1 is enabled)<br><br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending.                     | RW   | 0x0   |
| 5    | TX1_UNDERFLOW | MCSPI_TX1 register underflow (only when channel 1 is enabled) <sup>(1)</sup><br><br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending. | RW   | 0x0   |
| 4    | TX1_EMPTY     | MCSPI_TX1 register empty (only when channel 1 is enabled) <sup>(3)</sup><br><br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending.     | RW   | 0x0   |
| 3    | RX0_OVERFLOW  | MCSPI_RX0 register overflow (only in slave mode)<br><br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending.                             | RW   | 0x0   |
| 2    | RX0_FULL      | MCSPI_RX0 register full (only when channel 0 is enabled)<br><br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending.                     | RW   | 0x0   |
| 1    | TX0_UNDERFLOW | MCSPI_TX0 register underflow (only when channel 0 is enabled) <sup>(4)</sup><br><br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending. | RW   | 0x0   |
| 0    | TX0_EMPTY     | MCSPI_TX0 register empty (only when channel 0 is enabled) <sup>(3)</sup><br><br>Write 0x0: Event status bit unchanged<br>Read 0x0: Event false<br>Write 0x1: Event status bit is reset.<br>Read 0x1: Event is pending.     | RW   | 0x0   |

<sup>(3)</sup> Enabling the channel automatically rises this event.

<sup>(4)</sup> The MCSPI\_Txx register is empty (not updated by host or DMA with new data) before its time slot assignment.  
Exception: No TX\_UNDERFLOW event when no data has been loaded into the MCSPI\_Txx register since channel has been enabled.

**Table 20-27. Register Call Summary for Register MCSPI\_IRQSTATUS**
**McSPI Functional Description**

- Master Transmit-and-Receive Mode (Full Duplex): [0]
- Master Transmit-Only Mode (Half Duplex): [1]
- Master Receive-Only Mode (Half Duplex): [2] [3] [4] [5]
- Single-Channel Master Mode: [6] [7]
- Buffer Almost Full: [8] [9]
- Buffer Almost Empty: [10] [11]
- End of Transfer Management: [12]
- Interrupts: [13]
- Interrupt Events in Master Mode: [14] [15] [16] [17] [18] [19]
- Interrupt Events in Slave Mode: [20] [21] [22] [23] [24] [25] [26]
- Interrupt-Driven Operation: [27] [28]
- Polling: [29] [30]
- Idle Mode: [31] [32] [33]

**McSPI Basic Programming Model**

- [McSPI Configuration and Operations Example](#): [34] [35] [36] [37] [38] [39] [40] [41] [42] [43] [44] [45] [46] [47]

**McSPI Register Manual**

- [McSPI Register Summary](#): [48]
- [McSPI Register Description](#): [49]

**Table 20-28. MCSPI\_IRQENABLE**

| <b>Address Offset</b> | 0x1C                                                                                                         | <b>Physical Address</b> | 0x4809 801C | <b>Instance</b> | MCSPI1 |
|-----------------------|--------------------------------------------------------------------------------------------------------------|-------------------------|-------------|-----------------|--------|
|                       |                                                                                                              |                         | 0x4809 A01C |                 | MCSPI2 |
|                       |                                                                                                              |                         | 0x480B 801C |                 | MCSPI3 |
|                       |                                                                                                              |                         | 0x480B A01C |                 | MCSPI4 |
| <b>Description</b>    | This register allows to enable/disable the module internal sources of interrupt, on an event-by-event basis. |                         |             |                 |        |
| <b>Type</b>           | RW                                                                                                           |                         |             |                 |        |
| <b>Write Latency</b>  | Immediate                                                                                                    |                         |             |                 |        |

| 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                    |                  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-----|----------|-----------------|----------------------|------------------|----------|-----------------|----------------------|------------------|----------|-----------------|----------------------|------------------|---------------------|-----------------|----------------------|------------------|
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EOWKE | WKE | Reserved | RX3_FULL_ENABLE | TX3_UNDERFLOW_ENABLE | TX3_EMPTY_ENABLE | Reserved | RX2_FULL_ENABLE | TX2_UNDERFLOW_ENABLE | TX2_EMPTY_ENABLE | Reserved | RX1_FULL_ENABLE | TX1_UNDERFLOW_ENABLE | TX1_EMPTY_ENABLE | RX0_OVERFLOW_ENABLE | RX0_FULL_ENABLE | RX0_UNDERFLOW_ENABLE | TX0_EMPTY_ENABLE |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:18       | Reserved          | Reads return 0                                                                                                                                                                                                           | RW          | 0x0000       |
| 17          | EOWKE             | End of Word count Interrupt Enable.<br>0x0: Interrupt disabled<br>0x1: Interrupt enabled                                                                                                                                 | RW          | 0x0          |
| 16          | WKE               | Wake-up event interrupt enable in slave mode when an active control signal is detected on the spim_csx line programmed in the <a href="#">MCSPI_CHxCONF</a> [SPIENSLV] field (where x=0 only)<br>0x0: Interrupt disabled | RW          | 0x0          |

| Bits | Field Name           | Description                                               | Type | Reset |
|------|----------------------|-----------------------------------------------------------|------|-------|
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 15   | Reserved             | Read returns 0.                                           | RW   | 0x0   |
| 14   | RX3_FULL_ENABLE      | MCSPI_RX3 register full interrupt enable (channel 3)      | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 13   | TX3_UNDERFLOW_ENABLE | MCSPI_TX3 register underflow interrupt enable (channel 3) | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 12   | TX3_EMPTY_ENABLE     | MCSPI_TX3 register empty interrupt enable (channel 3)     | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 11   | Reserved             | Read returns 0.                                           | RW   | 0x0   |
| 10   | RX2_FULL_ENABLE      | MCSPI_RX2 register full interrupt enable (channel 2)      | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 9    | TX2_UNDERFLOW_ENABLE | MCSPI_TX2 register underflow interrupt enable (channel 2) | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 8    | TX2_EMPTY_ENABLE     | MCSPI_TX2 register empty interrupt enable (channel 2)     | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 7    | Reserved             | Read returns 0.                                           | RW   | 0x0   |
| 6    | RX1_FULL_ENABLE      | MCSPI_RX1 register full interrupt enable (channel 1)      | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 5    | TX1_UNDERFLOW_ENABLE | MCSPI_TX1 register underflow interrupt enable (channel 1) | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 4    | TX1_EMPTY_ENABLE     | MCSPI_TX1 register empty interrupt enable (channel 1)     | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 3    | RX0_OVERFLOW_ENABLE  | MCSPI_RX0 register overflow interrupt enable (channel 0)  | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 2    | RX0_FULL_ENABLE      | MCSPI_RX0 register full interrupt enable (channel 0)      | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 1    | TX0_UNDERFLOW_ENABLE | MCSPI_TX0 register underflow interrupt enable (channel 0) | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |
| 0    | TX0_EMPTY_ENABLE     | MCSPI_TX0 register empty interrupt enable (channel 0)     | RW   | 0x0   |
|      |                      | 0x0: Interrupt disabled                                   |      |       |
|      |                      | 0x1: Interrupt enabled                                    |      |       |

**Table 20-29. Register Call Summary for Register MCSPI\_IRQENABLE**

## McSPI Functional Description

- [Interrupts: \[0\]](#)
- [Interrupt-Driven Operation: \[1\]](#)
- [Polling: \[2\]](#)
- [Idle Mode: \[3\] \[4\]](#)

## McSPI Basic Programming Model

- [McSPI Configuration and Operations Example: \[5\]](#)

## McSPI Register Manual

- [McSPI Register Summary: \[6\]](#)

**Table 20-30. MCSPI\_WAKEUPENABLE**

|                         |                                                                                                                      |                 |        |
|-------------------------|----------------------------------------------------------------------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x20                                                                                                                 |                 |        |
| <b>Physical Address</b> | 0x4809 8020                                                                                                          | <b>Instance</b> | MCSPI1 |
|                         | 0x4809 A020                                                                                                          |                 | MCSPI2 |
|                         | 0x480B 8020                                                                                                          |                 | MCSPI3 |
|                         | 0x480B A020                                                                                                          |                 | MCSPI4 |
| <b>Description</b>      | The wake-up enable register allows to enable/disable the module internal sources of wake-up on event-by-event basis. |                 |        |
| <b>Type</b>             | RW                                                                                                                   |                 |        |
| <b>Write Latency</b>    | Immediate                                                                                                            |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |      |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|------|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | WKEN |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:1        | Reserved          | Reads return 0                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW          | 0x00000000   |
| 0           | WKEN              | <p>Wake-up functionality in slave mode when an active control signal is detected on the spim_cs line programmed in the field <a href="#">MCSPI_CHxCONF[SPIENSLV]</a></p> <p>0x0: The event is not allowed to wake-up the system, even if the global control bit <a href="#">MCSPI_SYSCONF[ENAWAKEUP]</a> is set.</p> <p>0x1: The event is allowed to wake-up the system if the global control bit <a href="#">MCSPI_SYSCONF[ENAWAKEUP]</a> is set.</p> | RW          | 0            |

**Table 20-31. Register Call Summary for Register MCSPI\_WAKEUPENABLE**

## McSPI Functional Description

- [Idle Mode: \[0\] \[1\] \[2\]](#)

## McSPI Register Manual

- [McSPI Register Summary: \[3\]](#)

**Table 20-32. MCSPI\_SYST**

|                         |                                                                                                                                                                                                              |  |                 |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|-----------------|--|--------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x24                                                                                                                                                                                                         |  |                 |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4809 8024                                                                                                                                                                                                  |  | <b>Instance</b> |  | MCSPI1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4809 A024                                                                                                                                                                                                  |  |                 |  | MCSPI2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x480B 8024                                                                                                                                                                                                  |  |                 |  | MCSPI3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x480B A024                                                                                                                                                                                                  |  |                 |  | MCSPI4 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register is used to check the correctness of the system interconnect either internally to peripheral bus, or externally to device IO pads, when the module is configured in system test (SYSTEST) mode. |  |                 |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                           |  |                 |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Write Latency</b>    | Immediate                                                                                                                                                                                                    |  |                 |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |          |            |            |      |        |          |          |         |        |         |         |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----------|------------|------------|------|--------|----------|----------|---------|--------|---------|---------|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SSB | SPIENDIR | SPIDATDIR1 | SPIDATDIR0 | WAKD | SPICLK | SPIDAT_1 | SPIDAT_0 | SPIEN_3 | PIEN_2 | SPIEN_1 | SPIEN_0 |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset   |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | Reserved   | Reads returns 0                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x00000 |
| 11    | SSB        | <p>Set status bit</p> <p>0x0: No action. Writing 0 does not clear already set status bits;</p> <p>This bit must be cleared prior attempting to clear a status bit of the MCSPI_IRQSTATUS register.</p> <p>0x1: Force to 1 all status bits of MCSPI_IRQSTATUS register.</p> <p>Writing 1 into this bit sets to 1 all status bits contained in the <a href="#">MCSPI_IRQSTATUS</a> register.</p>    | RW   | 0       |
| 10    | SPIENDIR   | <p>Set the direction of the spim_cs lines and spim_clk line</p> <p>0x0: Output (as in master mode)</p> <p>0x1: Input (as in slave mode)</p>                                                                                                                                                                                                                                                       | RW   | 0       |
| 9     | SPIDATDIR1 | <p>Set the direction of the SPIDAT[1] (spim_simo)</p> <p>0x0: Output</p> <p>0x1: Input</p>                                                                                                                                                                                                                                                                                                        | RW   | 0       |
| 8     | SPIDATDIR0 | <p>Set the direction of the SPIDAT[0] (spim_somi)</p> <p>0x0: Output</p> <p>0x1: Input</p>                                                                                                                                                                                                                                                                                                        | RW   | 0       |
| 7     | WAKD       | <p>SWAKEUP output (signal data value of internal signal to system).</p> <p>The signal is driven high or low according to the value written into this register bit.</p> <p>0x0: The pin is driven low.</p> <p>0x1: The pin is driven high.</p>                                                                                                                                                     | RW   | 0       |
| 6     | SPICLK     | <p>spim_clk line (signal data value)</p> <p>If <a href="#">MCSPI_SYST</a>[SPIENDIR] = 1 (input mode direction), this bit returns the value on the spim_clk line (high or low) and a write into this bit has no effect.</p> <p>If <a href="#">MCSPI_SYST</a>[SPIENDIR] = 0 (output mode direction), the spim_clk line is driven high or low according to the value written into this register.</p> | RW   | 0       |
| 5     | SPIDAT_1   | <p>spim_somi line (signal data value)</p> <p>If <a href="#">MCSPI_SYST</a>[SPIDATDIR1] = 0 (output mode direction), the spim_somi line is driven high or low according to the value written into this register.</p>                                                                                                                                                                               | RW   | 0       |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | If <b>MCSPI_SYST</b> [SPIDATDIR1] = 1 (input mode direction), this bit returns the value on the spim_somi line (high or low) and a write into this bit has no effect.                                                                                                                                                                                                             |      |       |
| 4    | SPIDAT_0   | spim_simo line (signal data value)<br><br>If <b>MCSPI_SYST</b> [SPIDATDIR0] = 0 (output mode direction), the spim_simo line is driven high or low according to the value written into this register.<br><br>If <b>MCSPI_SYST</b> [SPIDATDIR0] = 1 (input mode direction), this bit returns the value on the spim_simo line (high or low) and a write into this bit has no effect. | RW   | 0     |
| 3    | SPIEN_3    | spim_cs3 line (signal data value)<br><br>If <b>MCSPI_SYST</b> [SPIENDIR] = 0 (output mode direction), the spim_cs3 line is driven high or low according to the value written into this register.<br><br>If <b>MCSPI_SYST</b> [SPIENDIR] = 1 (input mode direction), this bit returns the value on the spim_cs3 line (high or low) and a write into this bit has no effect.        | RW   | 0     |
| 2    | PIEN_2     | spim_cs2 line (signal data value)<br><br>If <b>MCSPI_SYST</b> [SPIENDIR] = 0 (output mode direction), the spim_cs2 line is driven high or low according to the value written into this register.<br><br>If <b>MCSPI_SYST</b> [SPIENDIR] = 1 (input mode direction), this bit returns the value on the spim_cs2 line (high or low) and a write into this bit has no effect.        | RW   | 0     |
| 1    | SPIEN_1    | spim_cs1 line (signal data value)<br><br>If <b>MCSPI_SYST</b> [SPIENDIR] = 0 (output mode direction), the spim_cs1 line is driven high or low according to the value written into this register.<br><br>If <b>MCSPI_SYST</b> [SPIENDIR] = 1 (input mode direction), this bit returns the value on the spim_cs1 line (high or low) and a write into this bit has no effect.        | RW   | 0     |
| 0    | SPIEN_0    | spim_cs0 line (signal data value)<br><br>If <b>MCSPI_SYST</b> [SPIENDIR] = 0 (output mode direction), the spim_cs0 line is driven high or low according to the value written into this register.<br><br>If <b>MCSPI_SYST</b> [SPIENDIR] = 1 (input mode direction), this bit returns the value on the spim_cs0 line (high or low) and a write into this bit has no effect.        | RW   | 0     |

**Table 20-33. Register Call Summary for Register MCSPI\_SYST**


---

McSPI Register Manual

- [McSPI Register Summary: \[0\]](#)
  - [McSPI Register Description: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\]](#)
-

**Table 20-34. MCSPI\_MODULCTRL**

|                         |                                                                               |                 |        |  |
|-------------------------|-------------------------------------------------------------------------------|-----------------|--------|--|
| <b>Address Offset</b>   | 0x28                                                                          |                 |        |  |
| <b>Physical Address</b> | 0x4809 8028                                                                   | <b>Instance</b> | MCSPI1 |  |
|                         | 0x4809 A028                                                                   |                 | MCSPI2 |  |
|                         | 0x480B 8028                                                                   |                 | MCSPI3 |  |
|                         | 0x480B A028                                                                   |                 | MCSPI4 |  |
| <b>Description</b>      | This register is dedicated to the configuration of the serial port interface. |                 |        |  |
| <b>Type</b>             | RW                                                                            |                 |        |  |
| <b>Write Latency</b>    | Immediate                                                                     |                 |        |  |



| Bits | Field Name  | Description                                                                                                                                                                     | Type | Reset      |
|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:4 | Reserved    | Reads returns 0                                                                                                                                                                 | RW   | 0x00000000 |
| 3    | SYSTEM_TEST | Enables the system test mode                                                                                                                                                    | RW   | 0          |
|      |             | 0x0: Functional mode                                                                                                                                                            |      |            |
|      |             | 0x1: System test mode (SYSTEST)                                                                                                                                                 |      |            |
| 2    | MS          | Master/ Slave                                                                                                                                                                   | RW   | 1          |
|      |             | 0x0: Master - The module generates the spim_clk and spim_cs for channel x                                                                                                       |      |            |
|      |             | 0x1: Slave - The module receive                                                                                                                                                 |      |            |
| 1    | Reserved    | (returns 0 after writing 0) (returns 1 after writing 1)                                                                                                                         | RW   | 0          |
| 0    | SINGLE      | Single forced channel/multichannel (master mode only)                                                                                                                           | RW   | 0          |
|      |             | 0x0: One or more channels will be used in master mode with automatic chip-select generation.                                                                                    |      |            |
|      |             | 0x1: Only one channel will be used in master mode and the chip-select is driven by the <a href="#">MCSPI_CHxCONF[20]</a> FORCE bit. This bit must be set in force spim_cs mode. |      |            |

**Table 20-35. Register Call Summary for Register MCSPI\_MODULCTRL**

## McSPI Functional Description

- [Single-Channel Master Mode: \[0\] \[1\] \[2\] \[3\]](#)
- [Chip-Select Timing Control: \[4\]](#)
- [Slave Mode: \[5\]](#)

## McSPI Basic Programming Model

- [McSPI Configuration and Operations Example: \[6\] \[7\]](#)

## McSPI Register Manual

- [McSPI Register Summary: \[8\]](#)
- [McSPI Register Description: \[9\]](#)

**Table 20-36. MCSPI\_CHxCONF**

|                         |                                                                   |                 |                                                                               |
|-------------------------|-------------------------------------------------------------------|-----------------|-------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x2C + (0x14 * x)                                                 | <b>Index</b>    | x= 0 to 3 for MCSPI1.<br>x= 0 to 1 for MCSPI2 and MCSPI3.<br>x= 0 for MCSPI4. |
| <b>Physical Address</b> | 0x4809 802C + (0x14 * x)                                          | <b>Instance</b> | MCSPI1                                                                        |
|                         | 0x4809 A02C + (0x14 * x)                                          |                 | MCSPI2                                                                        |
|                         | 0x480B 802C + (0x14 * x)                                          |                 | MCSPI3                                                                        |
|                         | 0x480B A02C + (0x14 * x)                                          |                 | MCSPI4                                                                        |
| <b>Description</b>      | This register is dedicated to the configuration of the channel x. |                 |                                                                               |
| <b>Type</b>             | RW                                                                |                 |                                                                               |
| <b>Write Latency</b>    | Immediate                                                         |                 |                                                                               |

| 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 |
|----------|------|------|------|-----|-------|-----|----------|-------|-------|----|------|------|------|------|-----|----|----|------|------|----|-----|-----|---|---|---|---|---|---|---|---|---|
| Reserved | CLKG | FFER | FFEW | TCS | SBPOL | SBE | Reserved | FORCE | TURBO | IS | DPE1 | DPE0 | DMAR | DMAW | TRM | WL |    | EPOL | CLKD |    | POL | PHA |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | Reserved   | Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x00  |
| 29    | CLKG       | Clock divider granularity. This register defines the granularity of channel clock divider: power of two or one clock cycle granularity. When this bit is set, the <a href="#">MCSPI_CHxCTRL[15:8]</a> EXTCLK bit field must be configured to reach a maximum of 4096 clock divider ratio. Then the clock divider ratio is a concatenation of <a href="#">MCSPI_CHxCONF[5:2]</a> CLKD and EXTCLK values.<br><br>0x0: Clock granularity of power of two<br>0x1: One clock cycle granularity | RW   | 0x0   |
| 28    | FFER       | FIFO enabled for Receive. Only one channel can have this bit field set.<br><br>0x0: The buffer is not used to Receive data<br>0x1: The buffer is used to Receive data                                                                                                                                                                                                                                                                                                                     | RW   | 0x0   |
| 27    | FFEW       | FIFO enabled for Transmit. Only one channel can have this bit field set.<br><br>0x0: The buffer is not used to Transmit data<br>0x1: The buffer is used to Transmit data                                                                                                                                                                                                                                                                                                                  | RW   | 0x0   |
| 26:25 | TCS        | Chip select time control<br><br>Defines the number of interface clock cycles between CS toggling and first (or last) edge of SPI clock.<br><br>0x0: 0.5 clock cycle<br>0x1: 1.5 clock cycles<br>0x2: 2.5 clock cycles<br>0x3: 3.5 clock cycles                                                                                                                                                                                                                                            | RW   | 0x0   |
| 24    | SBPOL      | Start bit polarity<br><br>0x0: Start bit polarity is held to 0 during SPI transfer.<br>0x1: Start bit polarity is held to 1 during SPI transfer.                                                                                                                                                                                                                                                                                                                                          | RW   | 0x0   |
| 23    | SBE        | Start bit enable for SPI transfer<br><br>0x0: Default SPI transfer length as specified by WL bit field<br>0x1: Start bit D/CX added before SPI transfer. Polarity is defined by <a href="#">MCSPI_CHxCONF[SBPOL]</a> .                                                                                                                                                                                                                                                                    | RW   | 0x0   |
| 22:21 | Reserved   | Write the reset value. Read returns the reset value.                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW   | 0x0   |
| 20    | FORCE      | Manual spim_csx assertion to keep spim_csx for channel x active between SPI words (single channel master mode only). The <a href="#">MCSPI_MODULCTRL[0]</a> SINGLE bit must be set to 1.                                                                                                                                                                                                                                                                                                  | RW   | 0x0   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|       |            | 0x0: Writing 0 into this bit drives the spin_csx line low for channel x when <a href="#">MCSPI_CHxCONF</a> [6] EPOL = 0, and drives it high when <a href="#">MCSPI_CHxCONF</a> [6] EPOL = 1.<br>0x1: Writing 1 into this bit drives the spim_csx line high for channel x when <a href="#">MCSPI_CHxCONF</a> [E6] EPOL = 0, and drives it low when <a href="#">MCSPI_CHxCONF</a> [6] EPOL = 1. |      |       |
| 19    | TURBO      | Turbo mode<br>0x0: Turbo is deactivated (recommended for single SPI word transfer)<br>0x1: Turbo is activated to maximize the throughput for multi-SPI word transfers.                                                                                                                                                                                                                        | RW   | 0x0   |
| 18    | IS         | Input select<br>0x0: Data Line 0 (spim_somi) selected for reception<br>0x1: Data Line 1 (spim_simo) selected for reception                                                                                                                                                                                                                                                                    | RW   | 0x1   |
| 17    | DPE1       | Transmission enable for data line 1 (spim_simo)<br>0x0: Data Line 1 (spim_simo) selected for transmission<br>0x1: No transmission on data Line 1 (spim_simo)                                                                                                                                                                                                                                  | RW   | 0x1   |
| 16    | DPE0       | Transmission enable for data line 0 (spim_somi)<br>0x0: Data Line 0 (spim_somi) selected for transmission<br>0x1: No transmission on data Line 0 (spim_somi)                                                                                                                                                                                                                                  | RW   | 0x0   |
| 15    | DMAR       | DMA Read request<br>The DMA Read request line is asserted when the channel is enabled and a new data is available in the receive register of the channel.<br>The DMA Read request line is deasserted on read completion of the receive register of the channel.<br>0x0: DMA read request disabled<br>0x1: DMA read request enabled                                                            | RW   | 0x0   |
| 14    | DMAW       | DMA Write request.<br>The DMA write request line is asserted when the channel is enabled and the <a href="#">MCSPI_TXx</a> register of the channel is empty.<br>The DMA write request line is deasserted on load completion of the <a href="#">MCSPI_TXx</a> register of the channel.<br>0x0: DMA write request disabled<br>0x1: DMA write request enabled                                    | RW   | 0x0   |
| 13:12 | TRM        | Transmit/receive modes<br>0x0: Transmit and receive mode<br>0x1: Receive-only mode<br>0x2: Transmit-only mode<br>0x3: Reserved                                                                                                                                                                                                                                                                | RW   | 0x0   |
| 11:7  | WL         | SPI word length<br>0x0: Reserved<br>0x1: Reserved<br>0x2: Reserved<br>0x3: The SPI word is 4-bit long<br>0x4: The SPI word is 5-bit long<br>0x5: The SPI word is 6-bit long<br>0x6: The SPI word is 7-bit long<br>0x7: The SPI word is 8-bit long<br>0x8: The SPI word is 9-bit long<br>0x9: The SPI word is 10-bit long<br>0xA: The SPI word is 11-bit long                                  | RW   | 0x00  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
|             |                   | 0xB: The SPI word is 12-bit long<br>0xC: The SPI word is 13-bit long<br>0xD: The SPI word is 14-bit long<br>0xE: The SPI word is 15-bit long<br>0xF: The SPI word is 16-bit long<br>0x10: The SPI word is 17-bit long<br>0x11: The SPI word is 18-bit long<br>0x12: The SPI word is 19-bit long<br>0x13: The SPI word is 20-bit long<br>0x14: The SPI word is 21-bit long<br>0x15: The SPI word is 22-bit long<br>0x16: The SPI word is 23-bit long<br>0x17: The SPI word is 24-bit long<br>0x18: The SPI word is 25-bit long<br>0x19: The SPI word is 26-bit long<br>0x1A: The SPI word is 27-bit long<br>0x1B: The SPI word is 28-bit long<br>0x1C: The SPI word is 29-bit long<br>0x1D: The SPI word is 30-bit long<br>0x1E: The SPI word is 31-bit long<br>0x1F: The SPI word is 32-bit long |             |              |
| 6           | EPOL              | spim_csx polarity for channel x<br><br>0x0: spim_csx is held high during the active state.<br>0x1: spim_csx is held low during the active state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RW          | 0x0          |
| 5:2         | CLKD              | Frequency divider for spim_clk (for master device only)<br>A programmable clock divider divides the SPI reference clock (CLKSPIREF) by a 4-bit value and results in a new spim_clk clock available to shift data in and out.<br><br>0x0: 1<br>0x1: 2<br>0x2: 4<br>0x3: 8<br>0x4: 16<br>0x5: 32<br>0x6: 64<br>0x7: 128<br>0x8: 256<br>0x9: 512<br>0xA: 1024<br>0xB: 2048<br>0xC: 4096<br>0xD: 8192<br>0xE: 16384<br>0xF: 32768                                                                                                                                                                                                                                                                                                                                                                    | RW          | 0x0          |
| 1           | POL               | spim_clk polarity<br><br>0x0: spim_clk is held high during the active state.<br>0x1: spim_clk is held low during the active state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW          | 0x0          |
| 0           | PHA               | spim_clk phase<br><br>0x0: Data are latched on odd-numbered edges of spim_clk.<br>0x1: Data are latched on even-numbered edges of spim_clk.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW          | 0x0          |

**Table 20-37. Register Call Summary for Register MCSPI\_CHxCONF**

|                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| McSPI Functional Interface    | <ul style="list-style-type: none"> <li>• Multichannel SPI Protocol and Data Format: [0] [1] [2] [3] [4] [5] [6] [7]</li> <li>• Transfer Format: [8]</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| McSPI Functional Description  | <ul style="list-style-type: none"> <li>• Master Transmit-and-Receive Mode (Full Duplex): [9]</li> <li>• Master Transmit-Only Mode (Half Duplex): [10]</li> <li>• Master Receive-Only Mode (Half Duplex): [11]</li> <li>• Single-Channel Master Mode: [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23]</li> <li>• Start Bit Mode: [24] [25] [26] [27]</li> <li>• Chip-Select Timing Control: [28]</li> <li>• Programmable SPI Clock (spim_clk): [29] [30] [31] [32] [33] [34]</li> <li>• Dedicated Resources: [35] [36] [37] [38] [39]</li> <li>• Slave Transmit-and-Receive Mode: [40]</li> <li>• Slave Transmit-Only Mode: [41]</li> <li>• Slave Receive-Only Mode: [42]</li> <li>• FIFO Buffer Management: [43] [44] [45]</li> <li>• Buffer Almost Full: [46] [47]</li> <li>• Buffer Almost Empty: [48] [49]</li> <li>• Interrupt Events in Master Mode: [50] [51]</li> <li>• Interrupt Events in Slave Mode: [52] [53]</li> <li>• DMA Requests: [54] [55]</li> <li>• Idle Mode: [56]</li> </ul> |
| McSPI Basic Programming Model | <ul style="list-style-type: none"> <li>• Transfer Procedures without FIFO: [57]</li> <li>• McSPI Configuration and Operations Example: [58] [59] [60] [61] [62] [63] [64] [65] [66] [67]</li> <li>• Transfer Procedures with FIFO: [68]</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| McSPI Register Manual         | <ul style="list-style-type: none"> <li>• McSPI Register Summary: [69]</li> <li>• McSPI Register Description: [70] [71] [72] [73] [74] [75] [76] [77] [78] [79] [80] [81]</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

**Table 20-38. MCSPI\_CHxSTAT**

|                         |                                                                                                                                 |                 |                                                                               |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x30 + (0x14 * x)                                                                                                               | <b>Index</b>    | x= 0 to 3 for MCSPI1.<br>x= 0 to 1 for MCSPI2 and MCSPI3.<br>x= 0 for MCSPI4. |
| <b>Physical Address</b> | 0x4809 8030 + (0x14 * x)                                                                                                        | <b>Instance</b> | MCSPI1                                                                        |
|                         | 0x4809 A030 + (0x14 * x)                                                                                                        |                 | MCSPI2                                                                        |
|                         | 0x480B 8030 + (0x14 * x)                                                                                                        |                 | MCSPI3                                                                        |
|                         | 0x480B A030 + (0x14 * x)                                                                                                        |                 | MCSPI4                                                                        |
| <b>Description</b>      | This register provides status information about <a href="#">MCSPI_TXx</a> and <a href="#">MCSPI_RXx</a> registers of channel x. |                 |                                                                               |
| <b>Type</b>             | R                                                                                                                               |                 |                                                                               |
| <b>Write Latency</b>    | Immediate                                                                                                                       |                 |                                                                               |



| Bits | Field Name | Description                               | Type | Reset      |
|------|------------|-------------------------------------------|------|------------|
| 31:7 | Reserved   | Read returns 0s.                          | R    | 0x00000000 |
| 6    | RXFFF      | Channel x FIFO Receive Buffer Full Status | R    | 0x0        |
|      |            | Read 0x0: FIFO Receive Buffer is not full |      |            |
|      |            | Read 0x1: FIFO Receive Buffer is full     |      |            |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 5           | RXFFE             | Channel x FIFO Receive Buffer Empty Status<br><br>Read 0x0: FIFO Receive Buffer is not empty<br><br>Read 0x1: FIFO Receive Buffer is empty                                                                                                                                                                                                                                                                                                                                       | R           | 0x0          |
| 4           | TXFFF             | Channel x FIFO Transmit Buffer Full Status<br><br>Read 0x0: FIFO Transmit Buffer is not full<br><br>Read 0x1: FIFO Transmit Buffer is full                                                                                                                                                                                                                                                                                                                                       | R           | 0x0          |
| 3           | TXFFE             | Channel x FIFO Transmit Buffer Empty Status<br><br>Read 0x0: FIFO Transmit Buffer is not empty<br><br>Read 0x1: FIFO Transmit Buffer is empty                                                                                                                                                                                                                                                                                                                                    | R           | 0x0          |
| 2           | EOT               | Channel x end-of-transfer status. The definitions of beginning and end of transfer vary with master versus slave and the transfer format (transmit/receive mode, turbo mode). See dedicated chapters for details.<br><br>Read 0x0: This flag is automatically cleared when the shift register is loaded with the data from the <a href="#">MCSPI_TXx</a> register (beginning of transfer).<br><br>Read 0x1: This flag is automatically set to one at the end of an SPI transfer. | R           | 0x0          |
| 1           | TXS               | Channel x <a href="#">MCSPI_TXx</a> register status<br><br>Read 0x0: Register is full.<br><br>Read 0x1: Register is empty.                                                                                                                                                                                                                                                                                                                                                       | R           | 0x0          |
| 0           | RXS               | Channel x <a href="#">MCSPI_RXx</a> register status<br><br>Read 0x0: Register is empty.<br><br>Read 0x1: Register is full.                                                                                                                                                                                                                                                                                                                                                       | R           | 0x0          |

**Table 20-39. Register Call Summary for Register MCSPI\_CHxSTAT**
**McSPI Functional Description**

- Master Transmit-and-Receive Mode (Full Duplex): [0] [1] [2]
- Master Transmit-Only Mode (Half Duplex): [3]
- Master Receive-Only Mode (Half Duplex): [4]
- Single-Channel Master Mode: [5] [6] [7] [8] [9]
- Dedicated Resources: [10] [11]
- Slave Transmit-and-Receive Mode: [12]
- Slave Transmit-Only Mode: [13]
- Slave Receive-Only Mode: [14]
- End of Transfer Management: [15]

**McSPI Register Manual**

- [McSPI Register Summary](#): [16]

**Table 20-40. MCSPI\_CHxCTRL**

|                         |                                                    |                 |                                                                               |
|-------------------------|----------------------------------------------------|-----------------|-------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x34 + (0x14 * x)                                  | <b>Index</b>    | x= 0 to 3 for MCSPI1.<br>x= 0 to 1 for MCSPI2 and MCSPI3.<br>x= 0 for MCSPI4. |
| <b>Physical Address</b> | 0x4809 8034 + (0x14 * x)                           | <b>Instance</b> | MCSPI1                                                                        |
|                         | 0x4809 A034 + (0x14 * x)                           |                 | MCSPI2                                                                        |
|                         | 0x480B 8034 + (0x14 * x)                           |                 | MCSPI3                                                                        |
|                         | 0x480B A034 + (0x14 * x)                           |                 | MCSPI4                                                                        |
| <b>Description</b>      | This register is dedicated to enable the channel x |                 |                                                                               |
| <b>Type</b>             | RW                                                 |                 |                                                                               |
| <b>Write Latency</b>    | Immediate                                          |                 |                                                                               |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EXTCLK |    |    |    |    | Reserved |    |   |   |   | Z | W |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0x0000 |
| 15:8  | EXTCLK     | Clock ratio extension: This register is used to concatenate with <a href="#">MCSPI_CHxCONF[5:2]</a> CLKD bit field for clock ratio only when granularity is one clock cycle ( <a href="#">MCSPI_CHxCONF[28]</a> CLKG bit set to 1). Then the max value reached is 4096 clock divider ratio.<br><br>0x0: Clock ratio is CLKD + 1<br>0x1: Clock ratio is CLKD + 1 + 16<br>0xFF: Clock ratio is CLKD + 1 + 4080 | RW   | 0x00   |
| 7:1   | Reserved   | Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0x00   |
| 0     | EN         | Channel enable<br><br>0x0: Channel x is not active.<br>0x1: Channel x is active.                                                                                                                                                                                                                                                                                                                             | RW   | 0x0    |

**Table 20-41. Register Call Summary for Register MCSPI\_CHxCTRL**

## McSPI Functional Description

- [Master Transmit-and-Receive Mode \(Full Duplex\): \[0\]](#)
- [Single-Channel Master Mode: \[1\] \[2\]](#)
- [Programmable SPI Clock \(spim\\_clk\): \[3\]](#)
- [Dedicated Resources: \[4\] \[5\]](#)

## McSPI Basic Programming Model

- [McSPI Configuration and Operations Example: \[6\] \[7\]](#)

## McSPI Register Manual

- [McSPI Register Summary: \[8\]](#)
- [McSPI Register Description: \[9\]](#)

**Table 20-42. MCSPI\_TXx**

|                         |                                                                                                       |                 |                                                                               |
|-------------------------|-------------------------------------------------------------------------------------------------------|-----------------|-------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x38 + (0x14 * x)                                                                                     | <b>Index</b>    | x= 0 to 3 for MCSPI1.<br>x= 0 to 1 for MCSPI2 and MCSPI3.<br>x= 0 for MCSPI4. |
| <b>Physical Address</b> | 0x4809 8038 + (0x14 * x)                                                                              | <b>Instance</b> | MCSPI1                                                                        |
|                         | 0x4809 A038 + (0x14 * x)                                                                              |                 | MCSPI2                                                                        |
|                         | 0x480B 8038 + (0x14 * x)                                                                              |                 | MCSPI3                                                                        |
|                         | 0x480B A038 + (0x14 * x)                                                                              |                 | MCSPI4                                                                        |
| <b>Description</b>      | This register contains a single SPI word to transmit on the serial link, whatever SPI word length is. |                 |                                                                               |
| <b>Type</b>             | RW                                                                                                    |                 |                                                                               |
| <b>Write Latency</b>    | Immediate                                                                                             |                 |                                                                               |

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| TDATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                | Type | Reset      |
|------|------------|----------------------------|------|------------|
| 31:0 | TDATA      | Channel 0 Data to transmit | RW   | 0x00000000 |

**Table 20-43. Register Call Summary for Register MCSPI\_TXx**
**McSPI Functional Description**

- [Master Transmit-and-Receive Mode \(Full Duplex\)](#): [0] [1] [2] [3]
- [Master Transmit-Only Mode \(Half Duplex\)](#): [4]
- [Master Receive-Only Mode \(Half Duplex\)](#): [5] [6] [7] [8] [9]
- [Single-Channel Master Mode](#): [10]
- [Dedicated Resources](#): [11] [12] [13] [14] [15]
- [Slave Transmit-and-Receive Mode](#): [16] [17]
- [Slave Receive-Only Mode](#): [18] [19] [20]
- [Interrupt Events in Master Mode](#): [21] [22] [23] [24] [25] [26] [27]
- [Interrupt Events in Slave Mode](#): [28] [29] [30] [31] [32] [33]
- [Interrupt-Driven Operation](#): [34]
- [Polling](#): [35]
- [DMA Requests](#): [36] [37]

**McSPI Basic Programming Model**

- [McSPI Configuration and Operations Example](#): [38]
- [Common Transfer Procedure](#): [39] [40]

**McSPI Register Manual**

- [McSPI Register Summary](#): [41]
- [McSPI Register Description](#): [42] [43] [44] [45] [46]

**Table 20-44. MCSPI\_RXx**

|                         |                                                                                                         |                 |                                                                               |
|-------------------------|---------------------------------------------------------------------------------------------------------|-----------------|-------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x3C + (0x14 * x)                                                                                       | <b>Index</b>    | x= 0 to 3 for MCSPI1.<br>x= 0 to 1 for MCSPI2 and MCSPI3.<br>x= 0 for MCSPI4. |
| <b>Physical Address</b> | 0x4809 803C + (0x14 * x)                                                                                | <b>Instance</b> | MCSPI1                                                                        |
|                         | 0x4809 A03C + (0x14 * x)                                                                                |                 | MCSPI2                                                                        |
|                         | 0x480B 803C + (0x14 * x)                                                                                |                 | MCSPI3                                                                        |
|                         | 0x480B A03C + (0x14 * x)                                                                                |                 | MCSPI4                                                                        |
| <b>Description</b>      | This register contains a single SPI word received through the serial link, whatever SPI word length is. |                 |                                                                               |
| <b>Type</b>             | R                                                                                                       |                 |                                                                               |
| <b>Write Latency</b>    | Immediate                                                                                               |                 |                                                                               |

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RDATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description             | Type | Reset      |
|------|------------|-------------------------|------|------------|
| 31:0 | RDATA      | Channel 0 Received Data | R    | 0x00000000 |

**Table 20-45. Register Call Summary for Register MCSPI\_RXx**

## McSPI Functional Description

- Master Transmit-and-Receive Mode (Full Duplex): [0] [1]
- Master Transmit-Only Mode (Half Duplex): [2] [3] [4]
- Master Receive-Only Mode (Half Duplex): [5] [6]
- Single-Channel Master Mode: [7] [8] [9] [10]
- Dedicated Resources: [11] [12] [13]
- Slave Transmit-and-Receive Mode: [14]
- Slave Transmit-Only Mode: [15] [16]
- End of Transfer Management: [17]
- Interrupt Events in Master Mode: [18] [19] [20] [21]
- Interrupt Events in Slave Mode: [22] [23] [24] [25] [26] [27]
- Interrupt-Driven Operation: [28]
- Polling: [29]
- DMA Requests: [30]
- Idle Mode: [31]

## McSPI Basic Programming Model

- McSPI Configuration and Operations Example: [32]

## McSPI Register Manual

- McSPI Register Summary: [33]
- McSPI Register Description: [34] [35]

**Table 20-46. MCSPI\_XFERLEVEL**

|                         |                                                                                        |                 |        |  |
|-------------------------|----------------------------------------------------------------------------------------|-----------------|--------|--|
| <b>Address Offset</b>   | 0x7C                                                                                   |                 |        |  |
| <b>Physical Address</b> | 0x4809 807C                                                                            | <b>Instance</b> | MCSPI1 |  |
|                         | 0x4809 A07C                                                                            |                 | MCSPI2 |  |
|                         | 0x480B 807C                                                                            |                 | MCSPI3 |  |
|                         | 0x480B A07C                                                                            |                 | MCSPI4 |  |
| <b>Description</b>      | This register provides transfer levels needed while using FIFO buffer during transfer. |                 |        |  |
| <b>Type</b>             | RW                                                                                     |                 |        |  |
| <b>Write Latency</b>    | Immediate                                                                              |                 |        |  |



| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | WCNT       | Spi word counter: This register holds the programmable value of number of SPI word to be transferred on channel which is using the FIFO buffer. When transfer had started, a read back in this register returns the current SPI word transfer index.<br><br>0x0: Counter not used<br>0x1: One spi word<br>0xFFFFE 65534 spi word<br>:<br>0xFFFFF 65535 spi word<br>:                                 | RW   | 0x0000 |
| 15:14 | Reserved   | Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0    |
| 13:8  | AFL        | Buffer Almost Full: This register holds the programmable almost full level value used to determine almost full buffer condition. If the user wants an interrupt or a DMA read request to be issued during a receive operation when the data buffer holds at least l bytes, then this bit field must be set to l-1.<br><br>0x0: One byte<br>0x1: 2 bytes<br>0x3E: 63 bytes<br>0x3F: 64 bytes          | RW   | 0x00   |
| 7:6   | Reserved   | Read returns 0s.                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0    |
| 5:0   | AEL        | Buffer Almost Empty: This register holds the programmable almost empty level value used to determine almost empty buffer condition. If the user wants an interrupt or a DMA write request to be issued during a transmit operation when the data buffer is able to receive l bytes, then this bit field must be set to l-1.<br><br>0x0: One byte<br>0x1: 2 bytes<br>0x3E: 63 bytes<br>0x3F: 64 bytes | RW   | 0x00   |



## **Multichannel Buffered Serial Port**

This chapter introduces the multichannel buffered serial port of the multimedia device.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                    | Page |
|------------------------------------------|------|
| 21.1 McBSP Overview .....                | 3078 |
| 21.2 McBSP Environment .....             | 3081 |
| 21.3 McBSP Integration .....             | 3091 |
| 21.4 McBSP Functional Description .....  | 3112 |
| 21.5 McBSP Basic Programming Model ..... | 3148 |
| 21.6 McBSP Register Manual .....         | 3177 |

## 21.1 McBSP Overview

The multichannel buffered serial port (McBSP) provides a full-duplex direct serial interface between the device and other devices in a system such as other application chips (digital base band), audio and voice codec , etc. Because of its high level of versatility, it can accommodate to a wide range of peripherals and clocked frame oriented protocols (for details, see [Section 21.1.1](#)).

The device provides five instances of the McBSP module.

[Figure 21-1](#) shows the McBSP overview in the device.

**Figure 21-1. McBSP Highlight**



### 21.1.1 McBSP Features

The main features of the McBSP modules are:

- L4 interconnect slave interface supports:

- 32-bit data bus width
- 32-bit access supported
- 16- /8-bit access supported only by data registers
- 10-bit address bus width
- Burst mode not supported
- Write nonposted transaction mode supported
- 128 × 32-bit words (512 bytes) for each buffer for transmit/receive operations (McBSP1, 3, 4, 5)
- 5K bytes (1024 × 32 bits for audio buffer + 256 × 32 bits for buffer) for each buffer for transmit/receive audio operations (McBSP2 only)
- Interrupts configurable in legacy mode (2 requests) or PRCM compliant (1 request)
- Transmit and receive DMA requests triggered with programmable FIFO thresholds
- SIDETONE core support: Audio loopback capability (McBSP2 and 3 only)
- Multidrop support
- Serial interface description
  - 6 pin configuration (McBSP 1 only)
  - 4 pin configuration (McBSP2, 3, 4, 5)
  - Full-duplex communication
  - Multichannel selection modes
    - Support to enable or block transfers in each of the channels
    - 128 channels for transmission and for reception
  - Direct interface to industry-standard codecs, analog interface chips (AICs), and other serially connected A/D and D/A devices:
    - Inter-IC sound (I2S) compliant devices
    - Pulse code modulation (PCM) devices
    - Time division multiplexed (TDM) bus devices

**CAUTION**

McBSP modules do not offer support for µ-law and A-law companding, two partitions mode dynamic reassignment, AC'97, and SPI protocol.

- A wide selection of data sizes: 8, 12, 16, 20, 24, and 32 bits
- Bit reordering (send/receive least significant bit [LSB])
- Clock and frame-synchronization generation support:
  - Independent clocking and framing for reception and for transmission up to 48 MHz
  - Support for external generation of clock signals and frame-synchronization (frame-sync) signals
  - A programmable sample rate generator for internal generation and control of clock signals and frame-sync signals
  - Programmable polarity for frame-sync pulses and for clock signals

**NOTE:**

- McBSP modules do not support features such as re-transmit or re-receive of an erroneous frame or word.
- McBSP modules support dual phase frames to provide I2S fully compliant capabilities. But, this dual phase mode is limited at one channel (or word) for each phase instead of 128 channels max for single phase mode.

## 21.1.2 SIDETONE Core

The purpose of this section is to present the SIDETONE core implemented in McBSP2 and 3 modules. It is required that two of the audio input channels to be looped back, filtered, and mixed to the two corresponding audio output channels.

Data to be processed comes on two separate paths (one for each channel) through a simple interface. After filtering the data, gain is applied and outputted through a similar interface. For more details, see [Figure 21-2](#).

**Figure 21-2. SIDETONE Core Architecture**



mcbsp-002

The SIDETONE core offers the following features:

- Filter coefficients are shared between the two channels (the filter coefficient is assumed to represent values in the range  $-1\dots+1$ )
- Gains are independent for the two channels (the gain coefficients are in the range  $-2\dots+2$ )
- The filter output is multiplied with the gain, and the result is rounded to output channel word width.
- The FIR filter length is 128 samples.
- Filtered loop back signals are added to the corresponding output signals, and saturation is applied if the result exceeds arithmetic range.
- Filter coefficients and gains are programmable:
  - Coefficients are changed while audio is stopped.
  - Gains are changed at any time (also during audio operation with SIDETONE enabled).

## 21.2 McBSP Environment

This section describes the intended functions for McBSP module from an environment point of view (that is, external connections). It presents the McBSP connectivity options, lists the possible interfaces, and details the protocol and data format used in each case.

### 21.2.1 McBSP Functions

The device provides five instances of the McBSP module, called McBSP1, McBSP2, McBSP3, McBSP4, and McBSP5.

List of recommended usage (non exhaustive) per McBSP modules in the device:

- McBSP1: Digital baseband (DBB) data
- McBSP2: Audio data with audio buffer and SIDETONE feature
- McBSP3: Bluetooth® voice data with SIDETONE feature
- McBSP4: DBB voice data
- McBSP5: Midi data

[Table 21-1](#) describes the functions and the corresponding application fields.

**Table 21-1. Functions Description**

| Function         | Application Field                                 | Recommended McBSP module | Description                                                                   |
|------------------|---------------------------------------------------|--------------------------|-------------------------------------------------------------------------------|
| Control and Data | Digital Base Band (DBB) Data                      | McBSP1                   | Serial interface to transfer data                                             |
| Audio Data       | Audio Data with Audio Buffer                      | McBSP2                   | Audio interface to transfer audio data with Inter-IC Sound codec (I2S)        |
|                  | Audio Data with Audio Buffer and SIDETONE feature |                          |                                                                               |
|                  | Midi Data                                         | McBSP5                   |                                                                               |
| Voice Data       | Bluetooth Voice Data                              | McBSP3                   | Voice interface to transfer voice data with Pulse Code Modulation codec (PCM) |
|                  | Bluetooth Voice Data with SIDETONE feature        |                          |                                                                               |
|                  | DBB Voice Data                                    | McBSP4                   |                                                                               |

### 21.2.2 McBSP Signals Descriptions

The five McBSP modules consist of a data-flow path and a control path connected to external devices by a serial interface with 6-pin configuration (McBSP 1 only) or 4-pin configuration (McBSP2, 3, 4, 5).

For a McBSP module with 6-pin configuration, an internal loopback capability between transmitter and receiver clock signals, and both frame-synchronization signals enables using the McBSP module with 4-pin configuration. The related internal multiplexers are controlled through the system control module on the device (see [Section 21.3](#)).

**Table 21-2. Input/Output Description**

| Pin Name <sup>(1)</sup> | I/O <sup>(2)</sup> | Description                                   | Internal Signal Name | Reset Value | Control and Data | Audio Data | Voice Data |
|-------------------------|--------------------|-----------------------------------------------|----------------------|-------------|------------------|------------|------------|
| mcbsp_clks              | I                  | External clock (shared by all McBSP modules)  | CLKS                 | -           | ✓                | ✓          | ✓          |
| mcbspi_dr               | I                  | Receive serial data                           | DR                   | -           | ✓                | ✓          | ✓          |
| mcbspi_dx               | I/O <sup>(3)</sup> | Transmit serial data                          | DX                   | 0           | ✓                | ✓          | ✓          |
| mcbspi_clkx             | I/O <sup>(3)</sup> | Transmit clock <sup>(4)</sup>                 | CLKX                 | 0           | ✓                | ✓          | ✓          |
| mcbspi_fsx              | I/O <sup>(3)</sup> | Transmit frame synchronization <sup>(5)</sup> | FSX                  | 0           | ✓                | ✓          | ✓          |
| mcbsp1_clkx             | I/O <sup>(3)</sup> | Receive clock <sup>(6)</sup>                  | CLKR                 | 1           | ✓                |            |            |
| mcbsp1_fsr              | I/O <sup>(3)</sup> | Receive frame synchronization <sup>(7)</sup>  | FSR                  | 0           | ✓                |            |            |

<sup>(1)</sup> I = 1 to 5<sup>(2)</sup> I = Input; O = Output<sup>(3)</sup> For details of the input/output selection, see [Section 21.2.3.1](#).<sup>(4)</sup> This signal is also used as CLKR when it is configured as output (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to1).<sup>(5)</sup> This signal is also used as FSR when it is configured as output (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to1).<sup>(6)</sup> This signal is also used as CLKX when it is configured as input (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to1).<sup>(7)</sup> This signal is also used as FSX when it is configured as input (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to1).

- The mcbsp\_clks pin can be used to inject an external clock. This clock is used to generate control signals depending on the module internal configuration (see [Section 21.4.3, McBSP SRG](#)). The CLKS signal of the McBSP modules is linked to an external signal through the mcbsp\_clks pin, but the CLKS signal can also be linked to an internal clock provided by PRCM of the device. For more information, see [Section 21.3, McBSP Integration](#).
- Data are transmitted to external devices interfacing with McBSP modules via the mcbspi\_dx pin. Data from those devices are received on the mcbspi\_dr pin.

**NOTE:** The mcbspi\_dx pin is an input/output signal to use the McBSP module in half-duplex mode.

- Control information is communicated through the following pins: mcbspi\_clkx (transmit clock), mcbsp1\_clkx (receive clock), mcbspi\_fsx (transmit frame-sync), and mcbsp1\_fsr (receive frame-sync).

### CAUTION

External pins mcbsp1\_clkx and mcbsp1\_fsr are connected to pads only for McBSP1 module; other McBSP modules don't have these connections. For these modules, CLKR and FSR signals sources are mcbspi\_clkx and mcbspi\_fsx pins, respectively. Consequently, there is a light restriction on other McBSP modules when used in full-duplex mode. Reception and transmission use the same clock signal and the same frame synchronization signal.

## 21.2.3 McBSP Functions Description

### 21.2.3.1 McBSP Modes

For all McBSP functions, McBSP modules can operate in master or slave mode. The difference between these modes is the definition of the source of McBSP clocks and McBSP frames synchronization:

- Master mode: McBSP module provides them to the external device

- Slave mode: McBSP module receives them from the external device

The choice between the two modes depends of technical data of the external device and the type of interface (protocols and data formats). For one McBSP module, there are four possible functions:

1. Transmit and receive master mode
2. Transmit and receive slave mode
3. Transmit master mode and receive slave mode
4. Transmit slave mode and receive master mode

---

**NOTE:** If the McBSP module has a serial interface with 4-pin configuration (McBSP2, 3, 4, 5), only modes 1 and 2 are possible.

---

[Figure 21-3](#) shows the connection between the McBSP1 module (6-pin configuration) and an external device in transmit master mode and receive slave mode.

**Figure 21-3. Mode Overview of McBSP1 Module**



[Figure 21-4](#) shows the connection between the McBSP*i* module, with  $i = 2, 3, 4$  or  $5$  (4-pin configuration) and an external device in transmit and receive master mode.

**Figure 21-4. Mode Overview of McBSPi Module**

### 21.2.3.2 McBSP Functions

#### 21.2.3.2.1 McBSP Function 1: Control and Data

In full-duplex mode (reception and transmission use independent clock signals and frame-synchronization signals), the McBSP module can be used to exchange control and data with an external chipset, allowing the device to be interfaced with a modem device. [Figure 21-5](#) shows typical connections between device and modem chipset to illustrate the DBB data application.

**Figure 21-5. DBB Data Application**

In [Figure 21-5](#), the McBSP1 module is configured in transmit master mode and in receive slave mode.

#### 21.2.3.2.2 McBSP Function 2: Audio Data

The McBSP module is connected to audio devices through the I<sub>2</sub>S™ interface. The I<sub>2</sub>S link serial interface is a TDM slot based serial interface that is used to transfer audio data. Those audio devices can be either AICs or other serially connected A/D and D/A devices.

[Figure 21-6](#) shows typical connections between device and a typical device of analog audio interface (TPS65950 device) to illustrate the audio data application. The typical device contains several audio analog inputs and outputs, as well as digital microphone inputs.

**Figure 21-6. Audio Data Application**



In [Figure 21-6](#), the McBSP2 module is configured in transmit and receive master modes.

#### 21.2.3.2.3 McBSP Function 3: Voice Data

The McBSP module is connected to a voice device through the PCM interface. The PCM link serial interface is a TDM slot based serial interface that is used to transfer voice data. The voice devices can be modem chipsets, Bluetooth chipsets, or other devices with voice data interface.

[Figure 21-7](#) shows typical connections between the device and Bluetooth chipset (TI BRF6300 or TI BRF6350) to illustrate voice data application.

**Figure 21-7. Voice Data Application**



In [Figure 21-7](#), the McBSP3 module is configured in transmit and receive master modes.

#### 21.2.4 McBSP Protocols and Data Formats

The McBSP module can use one of the three protocols with associated data formats:

- Serial protocol to exchange serial data
- Audio protocol to exchange the audio samples
- Voice protocol to exchange the voice samples

The McBSP modules offer the flexibility to modify the following parameters to adapt to the device features as described in the following subsections.

## 21.2.4.1 Word, Frame, and Phase Definitions

### 21.2.4.1.1 Words or Channels

The data bits are transferred (transmission or reception) in a group called a serial word or channel. The number of bits in a word (length) is programmable via bits field (McBSPi.[MCBSPLP\\_RCR1\\_REG\[7:5\]](#) RWDLEN1 field and McBSPi.[MCBSPLP\\_RCR2\\_REG\[7:5\]](#) RWDLEN2 field, McBSPi.[MCBSPLP\\_XCR1\\_REG\[7:5\]](#) XWDLEN1 bit field and McBSPi.[MCBSPLP\\_XCR2\\_REG\[7:5\]](#) XWDLEN2 bit field) and can be 8, 12, 16, 20, 24, or 32 bits (see [Section 21.4.2.3, Clocking and Framing Data](#)). The McBSP module uses clock signals to control the time for each bit transfer. Data are sampled/driven on rising or falling edge of clock signals. This clock polarity is programmable through the bit fields of the pin-control register (McBSPi.[MCBSPLP\\_PCR\\_REG](#)).

For more information, see [Section 21.4.2.4, Frame Phases \(Dual-Phase Frame I2S Support\)](#).

### 21.2.4.1.2 Frames

One or more words (maximum 128) are transferred in a group called a frame. The McBSP module can transmit/receive a maximum of 128 words per frame, programmable through the bit fields of the transmit and receive control registers (McBSPi.[MCBSPLP\\_XCR1\\_REG](#)/McBSPi.[MCBSPLP\\_XCR2\\_REG](#) and McBSPi.[MCBSPLP\\_RCR1\\_REG](#)/McBSPi.[MCBSPLP\\_RCR2\\_REG](#)). For more details, see [Section 21.4.2.3, Clocking and Framing Data](#).

All the words in a frame are sent in a continuous stream. However, there can be pauses between frame transfers. The McBSP module uses frame-synchronization signals to determine when each frame is received/transmitted. When a pulse occurs on a frame-synchronization signal, the McBSP module begins receiving/transmitting a frame of data. When the next pulse occurs, the McBSP module receives/transmits the next frame, and so on. Frame-synchronization pulse is active high or low. This pulse polarity is programmable via bits field of pin-control register (McBSPi.[MCBSPLP\\_PCR\\_REG](#)).

Each frame transfer can be delayed by 0, 1, or 2 clock cycles, depending on the value of the bits for the transmit and receive control registers (McBSPi.[MCBSPLP\\_XCR2\\_REG](#) and McBSPi.[MCBSPLP\\_RCR2\\_REG](#)). For more information, see [Section 21.4.4.3.3, Preventing Unexpected Receive Frame-sync Pulses](#) and [Section 21.4.4.6.3, Preventing Unexpected Transmit Frame-Sync Pulses](#).

### 21.2.4.1.3 Phases

The McBSP module allows configuring each frame to contain one or two phases. The McBSP module supports dual-phase frames to provide I2S fully compliant capabilities. These two phases represent left and right channels of audio stereo signals.

The limitation on dual-phase frame is that the number of words per phase must be set to 1 for both first and second phases. But, the number of bits per word can be specified differently for each of the two phases of a frame, allowing greater flexibility in structuring data transfers.

For example, software can define a frame composed of a first phase with one 12-bit word and a second phase with one 16-bit word. This configuration allows the software to compose frames for custom applications. For more details, see [Section 21.4.2.4, Frame Phases \(Dual-Phase Frame I2S Support\)](#).

[Figure 21-8](#) shows signal activity for two possible reception/transmission scenarios.

**Figure 21-8. McBSP Reception/Transmission Signal Activity**


## 21.2.4.2 Serial Protocol and Data Formats

### 21.2.4.2.1 Protocol

The serial protocol is used to send and receive control data without specific formats. This allows McBSP module to accommodate all serial devices and their protocols.

### 21.2.4.2.2 Data Format

Figure 21-9 shows the typical operation of the McBSP clock and frame sync signals. Serial clocks CLKR and CLKX define the boundaries between bits for receive and transmit, respectively. Similarly, frame-sync signals FSR and FSX define the beginning of an element and/or frame transfer. The McBSP module allows the configuration of the following parameters for data and frame synchronization:

- Polarity of FSR, FSX, CLKX, and CLKR
- The number of words per frame
- The number of bits per word
- Whether subsequent frame synchronization restarts the serial data stream or is ignored
- The data delay from frame synchronization to first data bit which can be 0-, 1-, or 2-bit delays

The configuration is independent for receive and transmit parts. For more details and configuration examples, see [Section 21.4, McBSP Functional Description](#) and [Section 21.5, McBSP Basic Programming Model](#).

**Figure 21-9. Serial Data Formats**


### 21.2.4.3 Audio Protocol and Data Formats

#### 21.2.4.3.1 Protocol

The I2S protocol is used to send and receive audio data from 8-kHz to 48-kHz sampling rate (frame-sync frequency), with 16 bits or 32 bits per words (supported frequencies are 8, 11.025, 12, 16, 22.05, 24, 32, 44.1, and 48 kHz).

The frame-synchronization signal defines the frame length in the I2S protocol. Each frame consists of a fixed number of words. In dual-phase frame, the frame-synchronization signal is low for the left phase time slot and high for the right phase time slot. In addition, the frame-synchronization signal is synchronous to the falling edge of the clock signal.

#### 21.2.4.3.2 Data Formats

The I2S protocol supports TDM, I2S, left-justified, and right-justified data formats.

Bits of each word (sample) are clocked using the clock signal. For each word, the MSB is first. LSBs are padded to 0 when the data length (8, 12, 16, 20, or 24 bits) is less than the sample word width (16 or 32 bits).

##### 21.2.4.3.2.1 TDM Data Format

Figure 21-10 shows that each frame of TDM data format is composed of four words (or channels).

**Figure 21-10. TDM Data Format; Word Width: 32 Bits; Data Length: 24 Bits**



##### 21.2.4.3.2.2 I2S Data Format

Figure 21-11 shows an example with 24-bit data (MSB first) and 8 padding bits at 0.

**Figure 21-11. I2S Data Format; Word Width: 32 Bits; Data Length: 24 Bits**



mcbsp-011

#### 21.2.4.3.2.3 Left-Justified Data Format

Figure 21-12 shows an example with 24-bit data (MSB first) and 8 padding bits at 0.

**Figure 21-12. Left-Justified Data Format; Word Width: 32 Bits; Data Length: 24 Bits**



mcbsp-012

#### 21.2.4.3.2.4 Right-Justified Data Format

Figure 21-13 shows an example with 8 padding bits at '0' and 24 bits data (MSB first).

**Figure 21-13. Right-Justified Data Format; Word Width: 32 Bits; Data Length: 24 Bits**



mcbsp-013

## 21.2.4.4 Voice Protocol and Data Formats

### 21.2.4.4.1 Protocol

The PCM protocol is intended to transfer voice data at 8-kHz (default narrowband mode) or 16-kHz (wideband mode) sample rates (frame-sync frequency). PCM protocol can act as a slave or master, and is used by the Bluetooth interface and the modem generic interface. The frame-synchronization defines the frame length in the PCM protocol. Bits are clocked using the PCM clock signal, with the MSB first.

### 21.2.4.4.2 Data Formats

Two modes are available for the PCM protocol: mode 1 and mode 2. For both modes, there are two types of operation: mono and stereo channels. The difference between PCM mode 1 and PCM mode 2 is in the way they use either the rising or the falling edge of the clock signal, and the frame-synchronization polarity.

- PCM Mode 1: Input data is latched on the falling edge of the clock, and the transmitted data starts on the rising edge of the clock. Frame-synchronization pulse is active high.
- PCM Mode 2: Input data is latched on the falling edge of the clock, and the transmitted data starts on the falling edge of the clock. Frame-synchronization pulse is active low.

[Figure 21-14](#) and [Figure 21-15](#) shows an example of PCM protocol, mode 1 and mode 2, respectively, for a frame composed one word (width: 32 bits) with 16 bits data.

**Figure 21-14. PCM Protocol – Mode 1 Data Format**



**Figure 21-15. PCM Protocol – Mode 2 Data Format**



## 21.3 McBSP Integration

This section describes the McBSP modules integration inside the device and all the details about signal source controls, clocks, resets, power management, and hardware requests.

McBSP modules are divided into two families: McBSP modules that are gated in the CORE domain (McBSP1 and 5), and McBSP modules that are gated in the PER domain (McBSP2, 3, and 4).

For more details on the CORE and PER domains, see [Chapter 3, Power, Reset and Clock Management](#).

[Figure 21-16](#) through [Figure 21-20](#) show the integration of the McBSP modules in the device, including interrupt handlers, DMA requests, clock generators, and interconnections.

**Figure 21-16. McBSP1 Integration**



mcbsp-016

Figure 21-17. McBSP2 Integration



mcbsp-018

**Figure 21-18. McBSP3 Integration**


mcbsp-019

Figure 21-19. McBSP4 Integration



**Figure 21-20. McBSP5 Integration**


### 21.3.1 Signal Source Control

The FSR, CLKR, and CLKS signal sources are defined by the system control module. The control registers of the system control module are used to select these signal sources.

#### 21.3.1.1 McBSP1 Module (6-Pin Configuration)

The MCBSP1\_CLKS bit of the CONTROL.CONTROL\_DEVCONF0[2] register is used to select the McBSP1 module CLKS signal source:

- When set to 0, the CLKS source is from the CORE\_96M\_FCLK.
- When set to 1, the CLKS source is from the mcbsp\_clks pin.

The MCBSP1\_CLKR bit of the CONTROL\_DEVCONF0[3] register is used to select the McBSP1 module CLKR signal source:

- When set to 0, the CLKR source is from the CLKR input signal.
- When set to 1, the CLKR source is from the CLKX input signal.

The MCBSP1\_FSR bit of the CONTROL\_DEVCONF0[4] register is used to select the McBSP1 module FSR signal source:

- When set to 0, the FSR source is from the FSR input signal.
- When set to 1, the FSR source is from the FSX input signal.

### 21.3.1.2 McBSP2, 3, 4, and 5 Modules (4-Pin Configuration)

For these McBSPi modules, there are no external mcbspi\_clk and mcbspi\_fxr pins (where I = 2, 3, 4, and 5).

Consequently, the system control module controls only the internal connection of CLKS input signals. The settings are explained in [Section 21.3.2.2.2](#), [Section 21.3.2.2.3](#), [Section 21.3.2.2.4](#), and [Section 21.3.2.2.5](#).

## 21.3.2 Clocking, Reset, and Power Management Scheme

### 21.3.2.1 Power Domain

The McBSP1 and McBSP5 modules belong to the CORE domain, whereas the McBSP2, McBSP3, and McBSP4 modules belong to the PER (peripheral) domain. This separation of the McBSP modules into two power domains allows the major part of the device to be switched off while keeping McBSP2, 3, and 4 active.

For more information about these power domains, see [Chapter 3, Power , Reset, and Clock Management](#).

### 21.3.2.2 Clocks

There are two clock domains in the McBSP module:

- Functional clock domain
- Interface clock domain

**Table 21-3. Clocking Signals Input to McBSP Module**

| Type       | Name               | Source                                                   | Description                                                                                                                                                                                                                                                        |
|------------|--------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interface  | McBSPi_ICLK        | PER_L4_ICLK (McBSP2, 3, 4) <sup>(1)</sup>                | The L4 interface clock is used for the module internal L4 interconnect slave interface and all depending parts of the Interface clock domain.                                                                                                                      |
|            |                    | CORE_L4_ICLK (McBSP1, 5) <sup>(1)</sup>                  |                                                                                                                                                                                                                                                                    |
| Functional | CLKS               | PER_96M_FCLK (McBSP2, 3, 4) <sup>(1)</sup>               | McBSP module is running using either a functional clock generated internally (master mode) or supplied from its serial interface (slave mode) for the internal logic. Internal registers select the source of the functional clock and the divider ratio to apply. |
|            |                    | CORE_96M_FCLK (McBSP1, 5) <sup>(1)</sup>                 |                                                                                                                                                                                                                                                                    |
|            |                    | mcbsp_clks (external source common to all McBSP modules) |                                                                                                                                                                                                                                                                    |
| Functional | CLKX               | mcbspi_clkx (external source)                            | Functional clock after division in any mode is limited to maximum frequency divided by 2.                                                                                                                                                                          |
| Functional | CLKR (McBSP1 only) | mcbsp1_clkr (external source)                            |                                                                                                                                                                                                                                                                    |

<sup>(1)</sup> For more information about these sources, see [Chapter 3, Power, Reset, and Clock Management](#).

### 21.3.2.2.1 McBSP1 Clocks

The McBSP1 module is clocked by a functional clock (CLKS, CLKX, or CLKR) and an interface clock (McBSP1\_ICLK).

- The functional clock is used to generate control signals depending on the module internal configuration (see [Section 21.4](#)). For McBSP1 module, the functional clock comes from the CLKS signal, CLKX signal, or CLKR signal. The choice between these three clocks is defined by the SCLKME bit of the MCBSP1.MCBSPLP\_PCR\_REG[7] register and the CLKSM bit of the MCBSP1.MCBSPLP\_SRGR2\_REG[13] register.

The CLKS signal of the McBSP1 module is linked to an internal clock (CORE\_96M\_FCLK) provided by PRCM, whereas the CLKS signal can also be linked to an external signal through the mcbsp\_clks pin of the device boundary. The MCBSP1\_CLKS bit of the CONTROL.CONTROL\_DEVCONF0[2] register is used to select the McBSP1 module CLKS signal source:

- 0: The CLKS source is from the CORE\_96M\_FCLK.
- 1: The CLKS source is from the mcbsp\_clks pin.

For more information on this register, see [Chapter 13, System Control Module](#).

---

**NOTE:** When the McBSP1 module no longer requires the PRCM functional clock, software can disable it at the PRCM level by setting the EN\_MCBSP1 bit (PRCM.CM\_FCLKEN1\_CORE[9]) in the PRCM registers. The clock is effectively cut, provided the other modules that receive it do not require it. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

At PRCM level, when all the conditions to shut-off CORE\_96M\_FCLK clock are met the PRCM automatically launches a hardware handshake protocol to ensure McBSP1 is ready to have this clock switched off. Namely, the PRCM asserts an idle request to McBSP1. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

The CLKX and CLKR signals are connected by the mcbsp1\_clkx or mcbsp1\_clkr pads. These signals are used like functional clocks by the intermediary of the sample rate generator (SRG).

- The McBSP1\_ICLK runs at the L4 core interconnect clock speed. It is used to trigger access to the McBSP1 L4 interface and McBSP1 configuration interface through the MPU/IVA2.2 shared bus. It can also be an input clock for the McBSP SRG (clock divider), depending on the module configuration (see [Section 21.4.3](#)). Its source is the CORE\_L4\_ICLK signal.

---

**NOTE:** When the McBSP1 module no longer requires the interface clock, software can disable it at the PRCM level by setting the EN\_MCBSP1 bit (PRCM.CM\_ICLKEN1\_CORE[9]) in the PRCM registers. The clock is effectively cut, provided the other modules that receive it do not require it. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

At the PRCM level, when all the conditions to shut off the CORE\_L4\_ICLK clock are met, the PRCM module automatically launches a hardware handshake protocol to ensure McBSP1 is ready to have this clock switched off. Namely, the PRCM asserts an idle request to McBSP1. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

It is also possible to activate an autoidle mode for this clock (PRCM.CM\_AUTOIDLE1\_CORE[9] register AUTO\_MCBSP1 bit set to 1). In this case, McBSP1\_ICLK follows the CORE\_L4 clock domain behavior on the device. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

### 21.3.2.2.2 McBSP2 Clocks

The McBSP2 module is clocked by a functional clock (CLKS, CLKX or CLKR) and an interface clock (McBSP2\_ICLK).

- The functional clock is used to generate control signals depending on the module internal configuration (see [Section 21.4](#)). For McBSP2 module, the functional clock comes from the CLKS signal CLKX signal, or CLKR signal. The choice between these three clocks is defined by the SCLKME bit of the MCBSP2.MCBSPLP\_PCR\_REG[7] register and the CLKSM bit of the MCBSP2.MCBSPLP\_SRGR2\_REG[13] register.

The CLKS signal of the McBSP2 module is linked to an internal clock (PER\_96M\_FCLK) provided by PRCM, whereas the CLKS signal can also be linked to an external signal through the mcbsp\_clks pin of the device boundary. The MCBSP2\_CLKS bit of the CONTROL.CONTROL\_DEVCONF0[6] register is used to select the McBSP2 module CLKS signal source:

- 0: The CLKS source is from the PER\_96M\_FCLK.
- 1: The CLKS source is from the mcbsp\_clks pin.

For more information, see [Chapter 13, System Control Module](#).

---

**NOTE:** When the McBSP2 module no longer requires the functional clock, software can disable it at the PRCM level by setting the EN\_MCBSP2 bit (PRCM.CM\_FCLKEN\_PER[0]) in the PRCM registers. The clock is effectively cut, provided the other modules that receive it do not require it. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

At the PRCM level, when all the conditions to shut off the PER\_96M\_FCLK clock are met, the PRCM module automatically launches a hardware handshake protocol to ensure McBSP2 is ready to have this clock switched off. Namely, the PRCM asserts an idle request to McBSP2. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

---

Only, the CLKX signal is connected by mcbsp2\_clkx pads. The CLKR signal is connected to the CLKX signal. These signals are used like functional clocks by the intermediary of the SRG.

- The McBSP2\_ICLK runs at the L4 core interconnect clock speed. It is used to trigger access to the McBSP2 L4 interface and McBSP2 configuration interface via the MPU/IVA2.2 shared bus. It can also be an input clock for the McBSP sample-rate generator (clock divider), depending on the module configuration (see [Section 21.4.3](#)). Its source is the PER\_L4\_ICLK signal.

---

**NOTE:** When the McBSP2 module no longer requires the interface clock, software can disable it at the PRCM level by setting the EN\_MCBSP2 bit (PRCM.CM\_ICLKEN\_PER[0]) in the PRCM registers. The clock is effectively cut, provided the other modules that receive it do not require it. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

At the PRCM level, when all the conditions to shut-off PER\_L4\_ICLK clock are met, the PRCM module automatically launches a hardware handshake protocol to ensure McBSP2 is ready to have this clock switched off. Namely, the PRCM asserts an idle request to McBSP2. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

It is also possible to activate an autoidle mode for this clock (PRCM.CM\_AUTOIDLE\_PER[0] register AUTO\_MCBSP2 bit set to 1). In this case, McBSP2\_ICLK follows the CORE\_L4 clock domain behavior on the device. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

### 21.3.2.2.3 McBSP3 Clocks

The McBSP3 module is clocked by a functional clock (CLKS, CLKX or CLKR) and an interface clock (McBSP3\_ICLK).

- The functional clock is used to generate control signals depending on the module internal configuration (see [Section 21.4](#)). For McBSP3 module, the functional clock comes from the CLKS signal CLKX signal, or CLKR signal. The choice between these three clocks is defined by the SCLKME bit of the MCBSP3.MCBSPPLP\_PCR\_REG[7] register and the CLKSM bit of the MCBSP3.MCBSPPLP\_SRGR2\_REG[13] register.

The CLKS signal of the McBSP3 module is linked to an internal clock (PER\_96M\_FCLK) provided by PRCM, whereas the CLKS signal can also be linked to an external signal through the mcbsp\_clks pin of the device boundary. The MCBSP3\_CLKS bit of the CONTROL.CONTROL\_DEVCONF1[0] register is used to select the McBSP3 module CLKS signal source:

- 0: The CLKS source is from the PER\_96M\_FCLK.
- 1: The CLKS source is from the mcbsp\_clks pin.

For more information, see [Chapter 13, System Control Module](#).

**NOTE:** When the McBSP3 module no longer requires the functional clock, software can disable it at the PRCM level by setting the EN\_MCBSP3 bit (PRCM.CM\_FCLKEN\_PER[1]) in the PRCM registers. The clock is effectively cut, provided the other modules that receive it do not require it. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

At the PRCM level, when all the conditions to shut off the PER\_96M\_FCLK clock are met, the PRCM module automatically launches a hardware handshake protocol to ensure McBSP3 is ready to have this clock switched off. Namely, the PRCM asserts an idle request to McBSP3. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

Only, the CLKX signal is connected by mcbsp3\_clkx pads. The CLKR signal is connected to the CLKX signal. These signals are used like functional clocks by the intermediary of SRG.

- The McBSP3\_ICLK runs at the L4 core interconnect clock speed. It is used to trigger access to the McBSP3 L4 interface and McBSP3 configuration interface via the MPU/IVA2.2 shared bus. It can also be an input clock for the McBSP sample-rate generator (clock divider), depending on the module configuration (see [Section 21.4.3](#)). Its source is the PER\_L4\_ICLK signal.

**NOTE:** When the McBSP3 module no longer requires the interface clock, software can disable it at the PRCM level by setting the EN\_MCBSP3 bit (PRCM.CM\_ICLKEN\_PER[1]) in the PRCM registers. The clock is effectively cut, provided the other modules that receive it do not require it. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

At the PRCM level, when all the conditions to shut off the PER\_L4\_ICLK clock are met, the PRCM module automatically launches a hardware handshake protocol to ensure McBSP3 is ready to have this clock switched off. Namely, the PRCM asserts an idle request to McBSP3. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

It is also possible to activate an autoidle mode for this clock (PRCM.CM\_AUTOIDLE\_PER[1] register AUTO\_MCBSP3 bit set to 1). In this case, McBSP3\_ICLK follows the PER\_L4 clock domain behavior on the device. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

#### 21.3.2.2.4 McBSP4 Clocks

The McBSP4 module is clocked by a functional clock (CLKS or CLKX) and an interface clock (McBSP4\_ICLK).

- The functional clock is used to generate control signals depending on the module internal configuration (see [Section 21.4](#)). For McBSP4 module, the functional clock comes from the CLKS signal, the CLKX signal, or the CLKR signal. The choice between these three clocks is defined by the SCLKME bit of the MCBSP4.MCBSPPLP\_PCR\_REG[7] register and the CLKSM bit of the MCBSP4.MCBSPPLP\_SRGR2\_REG[13] register.

The CLKS signal of the McBSP4 module is linked to an internal clock (PER\_96M\_FCLK) provided by PRCM, whereas the CLKS signal can also be linked to an external signal through the mcbsp\_clks pin of the device boundary. The MCBSP4\_CLKS bit of the CONTROL.CONTROL\_DEVCONF1[2] register is used to select the McBSP4 module CLKS signal source:

- 0: The CLKS source is from the PER\_96M\_FCLK.
- 1: The CLKS source is from the mcbsp\_clks pin.

For more information, see [Chapter 13, System Control Module](#).

**NOTE:** When the McBSP4 module no longer requires the functional clock, software can disable it at the PRCM level by setting the EN\_MCBSP4 bit (PRCM.CM\_FCLKEN\_PER[2]) in the PRCM registers. The clock is effectively cut, provided the other modules that receive it do not require it. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

At the PRCM level, when all the conditions to shut off the PER\_96M\_FCLK clock are met, the PRCM module automatically launches a hardware handshake protocol to ensure McBSP4 is ready to have this clock switched off. Namely, the PRCM asserts an idle request to McBSP4. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

Only the CLKX signal is connected by mcbsp4\_clkx pads. The CLKR signal is connected to the CLKX signal. These signals are used like functional clocks by the intermediary of SRG.

- The McBSP4\_ICLK runs at the L4 core interconnect clock speed. It is used to trigger access to the McBSP4 L4 interface and McBSP4 configuration interface via the MPU/IVA2.2 shared bus. It can also be an input clock for the McBSP sample-rate generator (clock divider), depending on the module configuration (see [Section 21.4.3](#)). Its source is the PER\_L4\_ICLK signal.

**NOTE:** When the McBSP4 module no longer requires the interface clock, software can disable it at the PRCM level by setting the EN\_MCBSP4 bit (PRCM.CM\_ICLKEN\_PER[2]) in the PRCM registers. The clock is effectively cut, provided the other modules that receive it do not require it. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

At the PRCM level, when all the conditions to shut off the PER\_L4\_ICLK clock are met, the PRCM module automatically launches a hardware handshake protocol to ensure McBSP4 is ready to have this clock switched off. Namely, the PRCM asserts an idle request to McBSP4. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

It is also possible to activate an autoidle mode for this clock (PRCM.CM\_AUTOIDLE\_PER[2] register AUTO\_MCBSP4 bit set to 1). In this case, McBSP4\_ICLK follows the PER\_L4 clock domain behavior on the device. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

### 21.3.2.2.5 McBSP5 Clocks

The McBSP5 module is clocked by a functional clock (CLKS or CLKX) and an interface clock (McBSP5\_ICLK).

- The functional clock is used to generate control signals depending on the module internal configuration (see [Section 21.4](#)). For McBSP5 module, the functional clock comes from the CLKS signal, the CLKX signal, or the CLKR signal. The choice between these three clocks is defined by the SCLKME bit of the MCBSP5.MCBSPPLP\_PCR\_REG[7] register and the CLKSM bit of the MCBSP5.MCBSPPLP\_SRGR2\_REG[13] register.

The CLKS signal of the McBSP5 module is linked to an internal clock (CORE\_96M\_FCLK) provided by PRCM. The CLKS signal can also be linked to an external signal through the mcbsp\_clks pin of the device boundary. The MCBSP5\_CLKS bit of the CONTROL.CONTROL\_DEVCONF1[4] register is used to select the McBSP5 module CLKS signal source:

- 0: The CLKS source is from the CORE\_96M\_FCLK.
- 1: The CLKS source is from the mcbsp\_clks pin.

For more information, see [Chapter 13, System Control Module](#).

**NOTE:** When the McBSP5 module no longer requires the functional clock, software can disable it at the PRCM level by setting the EN\_MCBSP5 bit (PRCM.CM\_FCLKEN1\_CORE[10]) in the PRCM registers. The clock is effectively cut, provided the other modules that receive it do not require it. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

At the PRCM level, when all the conditions to shut off the CORE\_96M\_FCLK clock are met, the PRCM module automatically launches a hardware handshake protocol to ensure McBSP5 is ready to have this clock switched off. Namely, the PRCM asserts an idle request to McBSP5. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

Only, the CLKX signal is connected by mcbsp5\_clkx pads. The CLKR signal is connected to the CLKX signal. These signals are used like functional clocks by the intermediary of SRG.

- The McBSP5\_ICLK runs at the L4 core interconnect clock speed. It is used to trigger access to the McBSP5 L4 interface and McBSP5 configuration interface via the MPU/IVA2.2 shared bus. It can also be an input clock for the McBSP sample-rate generator (clock divider), depending on the module configuration (see [Section 21.4.3](#)). Its source is the CORE\_L4\_ICLK signal.

**NOTE:** When the McBSP5 module no longer requires the interface clock, software can disable it at the PRCM level by setting the EN\_MCBSP5 bit (PRCM.CM\_ICLKEN1\_CORE[10]) in the PRCM registers. The clock is effectively cut, provided the other modules that receive it do not require it. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

At the PRCM level, when all the conditions to shut off the CORE\_L4\_ICLK clock are met, the PRCM module automatically launches a hardware handshake protocol to ensure McBSP5 is ready to have this clock switched off. Namely, the PRCM asserts an idle request to McBSP5. For more details, see [Chapter 3, Power, Reset, and Clock Management](#).

It is also possible to activate an autoidle mode for this clock (PRCM.CM\_AUTOIDLE1\_CORE[10] register AUTO\_MCBSP5 bit set to 1). In this case, McBSP5\_ICLK follows the CORE\_L4 clock domain behavior on the device. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).

#### 21.3.2.2.6 SIDETONE Clock

The SIDETONE feature, in the McBSP2 and McBSP3 modules, is clocked only by an interface clock (McBSP2\_ICLK or McBSP3\_ICLK).

##### CAUTION

See [Section 21.3.2.2](#) and [Section 21.3.2.3](#) for information on McBSP2\_ICLK and McBSP3\_ICLK clocks.

When the SIDETONE feature no longer requires the clock, software can disable it at the SIDETONE level by setting the McBSPi.[ST\\_SYSConfig\\_REG\[0\]](#) AUTOIDLE bit in SIDETONE registers. To conserve power, when SIDETONE feature is not active or there is no activity on SIDETONE feature, the McBSPi\_ICLK clock supports an automatic gating that is enabled or disabled by setting the McBSPi.[ST\\_SYSConfig\\_REG\[0\]](#) AUTOIDLE bit.

- When this bit is asserted (set to 1), the McBSPi\_ICLK clock auto-gating is enabled and this clock is disabled internally to the SIDETONE feature, thus reducing power consumption, but not to the McBSP module that contains this feature.  
After reset, the automatic clock gating is enabled; thus, this bit must be disabled by software for activated SIDETONE feature.
- When this bit is set to 0, the McBSPi\_ICLK clock auto-gating is disabled and this clock is enabled. The SIDETONE feature can be used normally.

### 21.3.2.3 Hardware and Software Reset

McBSP1 and McBSP5 modules belong to the CORE domain and their reset signal is the CORE\_RST signal from the PRCM module, whereas McBSP2, 3 and 4 modules belong to the PER domain and their reset signal is the PER\_RST signal from the PRCM module.

For more details about these signals, see [Chapter 3, Power, Reset, and Clock Management](#).

**Table 21-4. Software Reset Signals to All McBSP Modules**

| Type     | Bit Field | Register Source                  | Activation  | Description                                                                        |
|----------|-----------|----------------------------------|-------------|------------------------------------------------------------------------------------|
| Software | SOFTRESET | MCBSPi.MCBSPPLP_SYSCONFIG_REG[1] | Active high | McBSP global software reset                                                        |
|          | RRST      | MCBSPi.MCBSPPLP_SPCR1_REG[0]     |             | This resets and disables the receiver, including the RB.                           |
|          | XRST      | MCBSPi.MCBSPPLP_SPCR2_REG[0]     |             | This resets and disables the transmitter, including the XB.                        |
|          | GRST      | MCBSPi.MCBSPPLP_SPCR2_REG[6]     |             | SRG is reset                                                                       |
|          | FRST      | MCBSPi.MCBSPPLP_SPCR2_REG[7]     |             | Frame-sync logic is reset. Frame-sync generated signal is not generated by the SRG |

For more details about these signals, see [Section 21.6, McBSP Register Manual](#). See [Section 21.5.1.1, McBSP Initialization Procedure](#), for a complete description of the McBSP initialization procedure.

### 21.3.2.4 Power Management

#### 21.3.2.4.1 McBSP Operating States

Two operating states are defined for all the McBSP modules:

- ACTIVE state: The module is running synchronously on the interface and functional clock, interrupts and DMA requests can be generated according to the configuration (register, master or slave mode, etc) and the external signals.
- IDLE state: As part of the system power management, the PRCM module can request the McBSP modules to enter IDLE state. Depending on the configured acknowledgment mode: Force Idle, No Idle and Smart Idle modes, a McBSP module will effectively enter IDLE state or not. As soon as a McBSP module enters IDLE state, it doesn't have anymore activities except those unrelated to clock activity (for example wake-up features) and its clocks are likely to be switched off at PRCM level.

When the McBSP goes into IDLE state, the McBSP internal state-machine clock switches from interface clock (L4\_ICLK) to external serial clock (because OMAP is supposed to shut down all internal clocks). Then the McBSP can continue to process during IDLE state with the external clock provided by the external component/AUDIOBUFFER.

The McBSP can exit IDLE state only if the external serial clock is active. After exiting IDLE state, McBSP state-machine clock is provided by the OMAP interface clock (L4\_ICLK).

---

**NOTE:** Idle request and idle acknowledge are only internal signals, with no means to observe or to control. The signals generation and control is purely hardware (managed automatically by the PRCM and the McBSP module depending on the SIDLEMODE settings).

---

#### 21.3.2.4.2 McBSP Acknowledgment Modes

During initialization or configuration of the McBSP module, the software must configure how the McBSP module will answer an IDLE solicitation from the PRCM module (that is, the way idle acknowledge will be asserted following an idle request assertion).

Each McBSP module can be configured via the MCBSPi.MCBSPPLP\_SYSCONFIG\_REG[4:3] SIDLEMODE field as one of the following acknowledgment modes:

- Force Idle mode (SIDLEMODE bit = 0x0): An idle request is acknowledged unconditionally, regardless of the internal state of the module. The McBSP module immediately enters Idle state (no activity), interface and PRCM functional clock can be stopped, no interrupts and DMA requests can be generated. In this mode, the McBSP module freezes all the internal activity when the PRCM clocks are switched off by the PRCM module, leading to a potential loss of data.

**CAUTION**

In Force Idle mode, the wake-up feature is inhibited.

**CAUTION**

If the McBSP functional part, transmitter or receiver, is running within this period of time (the functional clock source is not the PRCM functional clock), the internal state of the McBSP module will not be idle (FSM states, processes, etc.), and when the McBSP module exits from the Force Idle state unexpected behavior may happen in both receiver and transmitter. To avoid this, both receive and transmit parts, must be disabled by software prior to idle request assertion (all functional clock external sources must be disabled).

- No Idle mode (SIDLEMODE bit = 0x1): An idle request is never acknowledged, meaning it will prevent the PRCM from switching off its related clocks and from putting in a lower power state than the power domain it belongs to. The McBSP module never enters Idle state (is active).
- Smart Idle mode (SIDLEMODE bit = 0x2): Acknowledgment to an idle request is given based on the internal activity of the McBSP module. The McBSP module is in a waiting state, interface / functional clocks can be stopped, no interrupt can be generated, a wake-up signal can be generated according to the configuration (See [Section 21.3.2.4.4](#)) and external signals.

---

**NOTE:** The value `MCBSPi.MCBSPPLP_SYSCONFIG_REG[4:3]` SIDLEMODE field = 0x3 must not be used.

---

When configured in Smart Idle mode, McBSP module also offers an additional granularity on `MCBSPi_FCLK` and `MCBSPi_ICLK` gating. `MCBSPi.MCBSPPLP_SYSCONFIG_REG[9:8]` CLOCKACTIVITY bit field is used to determine which clock will be shut down (`MCBSPi_FCLK`, `MCBSPi_ICLK`, none of them or both of them).

CLOCKACTIVITY setting is used in the McBSP module to determine on which part of the module the conditions to acknowledge the PRCM idle request will be tested. As an example, if `MCBSPi_FCLK` is said not to be shut down upon a PRCM idle request, this means McBSP module will only consider `MCBSPi_ICLK` and the associated pending activities before acknowledging the request.

---

**NOTE:** Some of McBSP features are associated to `MCBSPi_ICLK` and others to `MCBSPi_FCLK`. Using the CLOCKACTIVITY along with the Smart Idle mode ensures that the features associated with the clock that will remain active are always enabled, even if McBSP has acknowledged an idle request. For more information, see [Section 21.3.2.4.4](#).

---

**Table 21-5** lists the value of the bit field and indicates if the interface (`MCBSPi_ICLK`) and PRCM functional (`MCBSPi_FCLK`) clocks can be switched-off or not when an idle request is received by McBSP module.

**Table 21-5. State of Clocks When the Module is in Idle State**

| CLOCKACTIVITY Value | Interface Clock ( <code>MCBSPi_ICLK</code> ) | PRCM Functional Clock ( <code>CORE_96M_FCLK</code> or <code>PER_96M_FCLK</code> ) |
|---------------------|----------------------------------------------|-----------------------------------------------------------------------------------|
| 0b00                | OFF                                          | OFF                                                                               |
| 0b01                | OFF                                          | ON                                                                                |

**Table 21-5. State of Clocks When the Module is in Idle State (continued)**

| CLOCKACTIVITY Value | Interface Clock (McBSPi_ICLK) | PRCM Functional Clock (CORE_96M_FCLK or PER_96M_FCLK) |
|---------------------|-------------------------------|-------------------------------------------------------|
| 0b10                | ON                            | OFF                                                   |
| 0b11                | ON                            | ON                                                    |

**NOTE:** OFF means this clock can be switched-off.

ON means this clock must be maintained during wake up period.

#### **CAUTION**

The PRCM module does not have any hardware mean to read CLOCKACTIVITY settings. It is thus software responsibility to ensure a consistent programming between McBSPi.MCBSPLP\_SYSConfig\_REG[9:8] CLOCKACTIVITY bit field and PRCM 96M\_FCLK and L4\_ICLK control bits (for more information about clocks, see [Section 21.3.2.2, Clocks](#)). If McBSP module is disabled in both CM\_FCLKEN and CM\_ICLKEN PRCM registers while CLOCKACTIVITY is set to 11, nothing prevents the PRCM module from asserting its idle request which will be acknowledged regardless of the features associated with the McBSP clocks. This may lead to unpredictable behaviors.

The software can disable all clocks at the McBSP module level by setting the IDLE\_EN bit in McBSPi.MCBSPLP\_PCR\_REG[14] registers. The IDLE\_EN bit allows stopping all the clocks in the McBSP module (legacy):

- When set to 0, the McBSP module is running.
- When set to 1, the clocks in the McBSP module are shut off when both IDLE\_EN =1 and his power domain is in idle mode.

#### **21.3.2.4.3 Wake-Up Capability**

When configured in smart-Idle mode, the sources for wake-up generation are a subset of the interrupt sources. The wake up sources are enabled by setting the McBSPi.MCBSPLP\_SYSConfig\_REG[2] ENAWAKEUP bit (wake up feature control):

- Set to 0, wake up capability is disabled.
- Set to 1, wake up capability is enabled.

The McBSPi\_SWAKEUP signal is the McBSP module asynchronous wake-up signal sent to the PRCM module when a wake-up generation is requested.

The wake up configurations are defined by setting the corresponding bits in the McBSPi.MCBSPLP\_WAKEUPEN\_REG register.

##### **21.3.2.4.3.1 Receive Wakeup**

There are four receive possible wake-up configurations:

- McBSPi.MCBSPLP\_WAKEUPEN\_REG[3] RRDYEN bit: The McBSP module asserts the McBSPi\_SWAKEUP request when the receive buffer reaches the high threshold value (RTHRESHOLD value + 1) of the McBSPi.MCBSPLP\_THRS1\_REG register. If the McBSPi.MCBSPLP\_IRQENABLE\_REG[3] RRDYEN bit is set to 1, the McBSP module sends an interrupt (McBSPi IRQ) request to the MPU or IVA 2.2 subsystems when exiting from idle mode (interrupt will be asserted once the McBSPi.MCBSPLP\_IRQSTATUS\_REG[3] RRDY bit changes from '0' to '1', indicating that received data is ready to be read).

- McBSPi.[MCBSPLP\\_WAKEUPEN\\_REG](#)[2] REOFEN bit: The McBSP module asserts the McBSPi\_SWAKEUP request at the end of the frame. If the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#)[2] REOFEN bit is set to 1, the McBSP module sends an interrupt (McBSPi\_IRQ) request to the MPU or IVA 2.2 subsystems when exiting idle mode.
- McBSPi.[MCBSPLP\\_WAKEUPEN\\_REG](#)[1] RFSREN bit: The McBSP module sends a McBSPi\_SWAKEUP request to the PRCM module when a receive frame-sync pulse is detected while the McBSP module is in idle mode. If the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#)[1] RFSREN bit is set to 1, the McBSP module sends an interrupt (McBSPi\_IRQ) request to the MPU or IVA 2.2 subsystems when exiting idle mode.
- McBSPi.[MCBSPLP\\_WAKEUPEN\\_REG](#)[0] RSYNCERREN bit: The McBSP module asserts the McBSPi\_SWAKEUP request when an unexpected receive frame-sync pulse is detected. If the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#)[0] RSYNCERREN bit is set to 1, the McBSP module sends an interrupt (McBSPi\_IRQ) request to the MPU or IVA 2.2 subsystems when exiting from idle mode (interrupt is asserted once the McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[0] RSYNCERR bit changes from '0' to '1', indicating that a receive error occurred).

#### 21.3.2.4.3.2 Transmit Wakeup

For transmit, there are also five possible wake-up configuration scenarios:

- McBSPi.[MCBSPLP\\_WAKEUPEN\\_REG](#)[14] XEMPTYEOFEN bit: The McBSP module asserts the McBSPi\_SWAKEUP request when a complete frame was transmitted and the transmit buffer is empty. If the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#)[14] XEMPTYEOFEN bit is set to 1, the McBSP module sends an interrupt (McBSPi\_IRQ) request to the MPU or IVA 2.2 subsystems when exiting from idle mode.
- McBSPi.[MCBSPLP\\_WAKEUPEN\\_REG](#)[10] XRDYEN bit: The McBSP module asserts the McBSPi\_SWAKEUP request when the transmit buffer reaches the high threshold value (XTHRESHOLD value + 1) of the McBSPi.[MCBSPLP\\_THRSH2\\_REG](#) register. If the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#)[10] XRDYEN bit is set to 1, the McBSP module sends an interrupt (McBSPi\_IRQ) request to the MPU or IVA 2.2 subsystems when exiting from idle mode (interrupt is asserted once the McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[10] XRDY bit changes from 0 to 1, indicating that transmit buffer data is ready to accept new data).
- McBSPi.[MCBSPLP\\_WAKEUPEN\\_REG](#)[9] XEOFEN bit: The McBSP module asserts the McBSPi\_SWAKEUP request at the end of the frame. If the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#)[9] XEOFEN bit is set to 1, the McBSP module sends an interrupt (McBSPi\_IRQ) request to the MPU or IVA 2.2 subsystems when exiting from idle mode.
- McBSPi.[MCBSPLP\\_WAKEUPEN\\_REG](#)[8] XFSXEN bit: The McBSP module sends a McBSPi\_SWAKEUP request when a transmit frame-sync pulse is detected while the module is in idle mode. If the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#)[8] XFSXEN bit is set to 1, the McBSP module sends an interrupt (McBSPi\_IRQ) request to the MPU or IVA 2.2 subsystems when exiting from idle mode.
- McBSPi.[MCBSPLP\\_WAKEUPEN\\_REG](#)[7] XSYNCERREN bit: The McBSP module asserts the McBSPi\_SWAKEUP request when an unexpected transmits frame-sync pulse is detected. If the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#)[7] XSYNCERREN bit is set to 1, the McBSP module sends an interrupt (McBSPi\_IRQ) request to the MPU or IVA 2.2 subsystems when exiting from idle mode (interrupt will be asserted once the McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[7] XSYNCERR bit changes from '0' to '1', indicating that a transmit error occurred).

#### 21.3.2.4.3.3 Notes

When mcbsp1\_fsr/mcbspi\_fsx pins is configured as an output, the FSR/FSX wake-up generation makes no sense (the module cannot be in smart-idle mode).

Detection of RSYNCERR/XSYNCERR during idle mode can be used only when mcbsp1\_fsr/mcbspi\_fsx pins is configured as an input and the remote system knows to assert such an error to trigger the wake up of the McBSP module.

The module does not implement interrupt request (IRQ) assertion when configured as (GPIO). Pins that can be used to accept input signals and/or send output signals but are not linked to specific uses); also a wake up capability in this mode is not available.

#### 21.3.2.4.4 Analysis of the Receiver Smart-Idle Behavior

The analysis of the power mode behavior is shown in [Table 21-6](#) :

In this table, the CLKRM bit is in the McBSPi.[MCBSPLP\\_PCR\\_REG](#) register on position 8, CLKXM bit in the McBSPi.[MCBSPLP\\_PCR\\_REG\[9\]](#) register, and CLOCKACTIVITY bit in the McBSPi.[MCBSPLP\\_SYSCONFIG\\_REG\[9:8\]](#) register.

The value X signifies that the bit value is not significant.

**Table 21-6. McBSP Smart Idle Mode Configuration Behavior**

| CLKRM Bit | CLKXM Bit | McBSP Mode      | Source of Functional Clock | CLOCKACTIVITY Bit | Behavior                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------|-----------|-----------------|----------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0         | 0         | Slave           | outside                    | 0bXX              | The module acknowledges the idle request as soon as there is no pending DMA, interrupt request or transmit buffer threshold synchronization (only when wake-up event is set on transmit threshold reached), regardless of the CLOCKACTIVITY settings or receive and transmit activity.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0         | 1         | Transmit Master | McBSPi_ICLK                | 0b0X              | The McBSP will not acknowledge the idle request unless: <ul style="list-style-type: none"> <li>The transmit part is disabled (XDISABLE) or under software reset (XRST) and the receive part is not using the transmit loop-back clock (CLKR is not connected to the CLKX input pin).</li> <li>Both transmit and receive parts are disabled (XDISABLE/RDISABLE) or under software reset (XRST/RRST)</li> </ul> The idle acknowledge is asserted as soon as there is no pending DMA, interrupt request or transmit/receive buffer threshold synchronization (only when wake-up event is set on transmit/receive threshold reached) and the pending transmit and/or receive frames were completed in case of transmit and/or receive disable. |
|           |           |                 | CLKS                       | 0bX0              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           |           |                 | McBSPi_ICLK                | 0b1X              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           |           |                 | CLKS                       | 0bX1              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           |           |                 | CLKR (outside)             | 0bXX              | The module acknowledges the idle request as soon as there is no pending DMA, interrupt request or transmit/receive buffer threshold synchronization (only when wake-up event is set on transmit/receive threshold reached), regardless of the CLOCKACTIVITY settings.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**Table 21-6. McBSP Smart Idle Mode Configuration Behavior (continued)**

| <b>CLKRM Bit</b> | <b>CLKXM Bit</b> | <b>McBSP Mode</b>           | <b>Source of Functional Clock</b> | <b>CLOCKACTIVITY Bit</b> | <b>Behavior</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|------------------|-----------------------------|-----------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                | 0                | Receive master              | McBSPi_ICLK                       | 0b0X                     | The McBSP will not acknowledge the idle request unless: The receive part is disabled (RDISABLE) or under software reset (RRST)<br><br>The Idle acknowledge is asserted as soon as there is no pending DMA, interrupt request or transmit/receive buffer threshold synchronization (only when wake-up event is set on transmit/receive threshold reached) and the pending transmit and/or receive frames where completed in case of transmit and/or receive disable.                                                                                                                                                |
|                  |                  |                             | CLKS                              | 0bX0                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |                  |                             | McBSPi_ICLK                       | 0b1X                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |                  |                             | CLKS                              | 0bX1                     | The module acknowledges the idle request as soon as there is no pending DMA, interrupt request or transmit/receive buffer threshold synchronization (only when wake-up event is set on transmit/receive threshold reached).                                                                                                                                                                                                                                                                                                                                                                                        |
|                  |                  |                             | CLKX                              | 0bXX                     | When CLKX is used as source (functional clock is provided from outside) then the module acknowledges the idle request as soon as there is no pending DMA, interrupt request or transmit/receive buffer threshold synchronization (only when wake-up event is set on transmit/receive threshold reached), regardless of the CLOCKACTIVITY settings.                                                                                                                                                                                                                                                                 |
| 1                | 1                | Transmit and Receive Master | McBSPi_ICLK                       | 0b0X                     | The McBSP will not acknowledge the idle request unless: Both transmit and receive parts are disabled (XDISABLE/RDISABLE) or under software reset (XRST/RRST)<br><br>The idle acknowledge is asserted as soon as there is no pending DMA, interrupt request or transmit/receive buffer threshold synchronization (only when wake-up event is set on transmit/receive threshold reached) and the pending transmit and/or receive frames were completed in case of transmit and/or receive disable. Note that no wake-up event is available in this mode since the entire McBSP and remote device activity is frozen. |
|                  |                  |                             | CLKS                              | 0bX0                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |                  |                             | McBSPi_ICLK                       | 0b1X                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |                  |                             | CLKS                              | 0bX1                     | The module acknowledges the idle request as soon as there is no pending DMA, interrupt request or transmit/receive buffer threshold synchronization (only when wake-up event is set on transmit/receive threshold reached).                                                                                                                                                                                                                                                                                                                                                                                        |

**NOTE:** The RFSREN/XFSXEN mode is suitable for wake-up generation when both clocks (PRCM functional and interface) are switched off and mcbsp1\_fsr/mcbspi\_fsx pins is configured as input. The frame-sync pulse is asynchronously detected during idle.

The RSYNCERREN/XSYNCERREN mode can be used to wake-up the McBSP module only by a remote module implementing such a feature, to trigger a wake up. This mode requires functional clock to be active.

### 21.3.3 Hardware Requests

#### 21.3.3.1 DMA Requests

The DMA requests are shared between the IVA2.2 subsystem DMA controller (eDMA) and system DMA controller (sDMA). Each of the five McBSP modules can generate two DMA events:

- McBSPi\_DMA\_TX : McBSPi module transmit request
- McBSPi\_DMA\_RX : McBSPi module receive request

The following table summarizes the DMA events with the mapping on both DMA controllers.

**Table 21-7. McBSP DMA Requests**

| Request Name  | Mapping                 | Destination                                              | Description                 |
|---------------|-------------------------|----------------------------------------------------------|-----------------------------|
| McBSP1_DMA_TX | EDMA_REQ[0]<br>S_DMA_30 | IVA2.2 subsystem DMA controller<br>system DMA controller | write (or transmit) request |
| McBSP1_DMA_RX | EDMA_REQ[1]<br>S_DMA_31 | IVA2.2 subsystem DMA controller<br>system DMA controller | read (or receive) request   |
| McBSP2_DMA_TX | EDMA_REQ[2]<br>S_DMA_32 | IVA2.2 subsystem DMA controller<br>system DMA controller | write (or transmit) request |
| McBSP2_DMA_RX | EDMA_REQ[3]<br>S_DMA_33 | IVA2.2 subsystem DMA controller<br>system DMA controller | read (or receive) request   |
| McBSP3_DMA_TX | EDMA_REQ[4]<br>S_DMA_16 | IVA2.2 subsystem DMA controller<br>system DMA controller | write (or transmit) request |
| McBSP3_DMA_RX | EDMA_REQ[5]<br>S_DMA_17 | IVA2.2 subsystem DMA controller<br>system DMA controller | read (or receive) request   |
| McBSP4_DMA_TX | EDMA_REQ[6]<br>S_DMA_18 | IVA2.2 subsystem DMA controller<br>system DMA controller | write (or transmit) request |
| McBSP4_DMA_RX | EDMA_REQ[7]<br>S_DMA_19 | IVA2.2 subsystem DMA controller<br>system DMA controller | read (or receive) request   |
| McBSP5_DMA_TX | EDMA_REQ[8]<br>S_DMA_20 | IVA2.2 subsystem DMA controller<br>system DMA controller | write (or transmit) request |
| McBSP5_DMA_RX | EDMA_REQ[9]<br>S_DMA_21 | IVA2.2 subsystem DMA controller<br>system DMA controller | read (or receive) request   |

#### 21.3.3.2 Interrupt Requests

##### 21.3.3.2.1 McBSP Interrupt Requests

Each of the five McBSP modules can generate three interrupts, shared between the MPU subsystem and IVA2.2 subsystem interrupt controllers:

- McBSPi\_IRQ: McBSPi module common interrupt request
- McBSPi\_IRQ\_TX: McBSPi module transmit interrupt request
- McBSPi\_IRQ\_RX: McBSPi module receive interrupt request

The following tables list the interrupt requests with the mapping.

**Table 21-8. McBSP Common Interrupt Requests**

| Request Name | Mapping                  | Destination                                                                 |
|--------------|--------------------------|-----------------------------------------------------------------------------|
| McBSP1_IRQ   | IVA2_IRQ[33]<br>M_IRQ_16 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |
| McBSP2_IRQ   | IVA2_IRQ[34]<br>M_IRQ_17 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |
| McBSP3_IRQ   | IVA2_IRQ[35]<br>M_IRQ_22 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |
| McBSP4_IRQ   | IVA2_IRQ[36]<br>M_IRQ_23 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |

**Table 21-8. McBSP Common Interrupt Requests (continued)**

| Request Name | Mapping                  | Destination                                                                 |
|--------------|--------------------------|-----------------------------------------------------------------------------|
| McBSP5_IRQ   | IVA2_IRQ[37]<br>M_IRQ_27 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |

**Table 21-9. McBSP Transmit Interrupt Requests**

| Request Name  | Mapping                  | Destination                                                                 |
|---------------|--------------------------|-----------------------------------------------------------------------------|
| McBSP1_IRQ_TX | IVA2_IRQ[16]<br>M_IRQ_59 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |
| McBSP2_IRQ_TX | IVA2_IRQ[19]<br>M_IRQ_62 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |
| McBSP3_IRQ_TX | IVA2_IRQ[21]<br>M_IRQ_89 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |
| McBSP4_IRQ_TX | IVA2_IRQ[23]<br>M_IRQ_54 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |
| McBSP5_IRQ_TX | IVA2_IRQ[25]<br>M_IRQ_81 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |

**Table 21-10. McBSP Receive Interrupt Requests**

| Request Name  | Mapping                  | Destination                                                                 |
|---------------|--------------------------|-----------------------------------------------------------------------------|
| McBSP1_IRQ_RX | IVA2_IRQ[17]<br>M_IRQ_60 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |
| McBSP2_IRQ_RX | IVA2_IRQ[20]<br>M_IRQ_63 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |
| McBSP3_IRQ_RX | IVA2_IRQ[22]<br>M_IRQ_90 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |
| McBSP4_IRQ_RX | IVA2_IRQ[24]<br>M_IRQ_55 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |
| McBSP5_IRQ_RX | IVA2_IRQ[26]<br>M_IRQ_82 | IVA2.2 subsystem interrupt controller<br>MPU subsystem interrupt controller |

An event can generate an interrupt request when the corresponding mask bit in the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#) register is set to '1'.

[Table 21-11](#) and [Table 21-12](#) summarize the events causing the generation of an interrupt request.

**Table 21-11. McBSP Transmit Interrupt Events**

| Event Name                            | Status Bit                                                      | Mask Bit                                                          | Description                                                                                                                       |
|---------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Transmit buffer empty at end of frame | McBSPi. <a href="#">MCBSPLP_IRQSTATUS_REG</a> [14]<br>XEMPTYEOF | McBSPi. <a href="#">MCBSPLP_IRQENABLE_REG</a><br>[14] XEMPTYEOFEN | This event happens when a complete frame was transmitted and the transmit buffer is empty .                                       |
| Overflow                              | McBSPi. <a href="#">MCBSPLP_IRQSTATUS_REG</a> [12]<br>XOVFLSTAT | McBSPi. <a href="#">MCBSPLP_IRQENABLE_REG</a><br>[12] XOVFLEN     | This event happens when transmit data buffer is full and a new data is written in this buffer. The new data written is discarded. |
| Underflow                             | McBSPi. <a href="#">MCBSPLP_IRQSTATUS_REG</a> [11]<br>XUNDLSTAT | McBSPi. <a href="#">MCBSPLP_IRQENABLE_REG</a><br>[11] XUNDflen    | This event happens when transmit data buffer is empty and a new data is required to be transmitted.                               |
| Threshold reached                     | McBSPi. <a href="#">MCBSPLP_IRQSTATUS_REG</a> [10]<br>XRDY      | McBSPi. <a href="#">MCBSPLP_IRQENABLE_REG</a><br>[10] XRDYEN      | This event happens when the transmit buffer free locations are equal or above the THRSH2_REG value.                               |
| End of Frame                          | McBSPi. <a href="#">MCBSPLP_IRQSTATUS_REG</a> [9]<br>XEOF       | McBSPi. <a href="#">MCBSPLP_IRQENABLE_REG</a><br>[9] XEOFLEN      | This event happens when a complete frame was transmitted.                                                                         |

**Table 21-11. McBSP Transmit Interrupt Events (continued)**

| Event Name       | Status Bit                                   | Mask Bit                                        | Description                                                                 |
|------------------|----------------------------------------------|-------------------------------------------------|-----------------------------------------------------------------------------|
| Frame-sync       | McBSPi.MCBSPPLP_IRQSTATUS_REG[8]<br>XFSX     | McBSPi.MCBSPPLP_IRQENABLE_REG<br>[8] XFSXEN     | This event happens when a new transmit frame synchronization is asserted.   |
| Frame-sync error | McBSPi.MCBSPPLP_IRQSTATUS_REG[7]<br>XSYNCERR | McBSPi.MCBSPPLP_IRQENABLE_REG<br>[7] XSYNCERREN | This event happens when a transmit frame synchronization error is detected. |

**Table 21-12. McBSP Receive Interrupt Events**

| Event Name        | Status bit                                        | Mask bit                                           | Description                                                                                                                                                       |
|-------------------|---------------------------------------------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Overflow          | McBSPi.MCBSPPLP_IRQS<br>TATUS_REG[5]<br>ROVFLSTAT | McBSPi.MCBSPPLP_IRQENABLE_<br>REG[5]<br>ROVFLLEN   | This event happens when receive data buffer is full and a new data is written in this buffer. The new data written is discarded.                                  |
| Underflow         | McBSPi.MCBSPPLP_IRQS<br>TATUS_REG[4]<br>XUNDLSTAT | McBSPi.MCBSPPLP_IRQENABLE_<br>REG[4]<br>RUNDflen   | This event happens when read operation is performed to the receive data register while receive buffer is empty; data read while underflow condition is undefined. |
| Threshold reached | McBSPi.MCBSPPLP_RQS<br>TATUS_REG[3]<br>RRDY       | McBSPi.MCBSPPLP_IRQENABLE_<br>REG[3]<br>RRDYEN     | This event happens when the receive buffer occupied locations are equal or above the THRSH1_REG value.                                                            |
| End of Frame      | McBSPi.MCBSPPLP_IRQS<br>TATUS_REG[2]<br>REOF      | McBSPi.MCBSPPLP_IRQENABLE_<br>REG[2]<br>REOFLLEN   | This event happens when a complete frame was received.                                                                                                            |
| Frame-sync        | McBSPi.MCBSPPLP_IRQS<br>TATUS_REG[1]<br>RFSR      | McBSPi.MCBSPPLP_IRQENABLE_<br>REG[1]<br>RFSREN     | This event happens when a new receive frame synchronization is asserted.                                                                                          |
| Frame-sync error  | McBSPi.MCBSPPLP_IRQS<br>TATUS_REG[0]<br>RSYNCERR  | McBSPi.MCBSPPLP_IRQENABLE_<br>REG[0]<br>RSYNCERREN | This event happens when a receive frame synchronization error is detected.                                                                                        |

Once an interrupt request is generated, the software must read the McBSPi.MCBSPPLP\_IRQSTATUS\_REG register to check what event has caused the interrupt request generation, and acknowledge each processed event by writing a 1 to the corresponding bit in the McBSPi.MCBSPPLP\_IRQSTATUS\_REG register.

**NOTE:** All Status bits can be cleared in two ways:

- If the corresponding mask bit is set to '1' (interrupt generation enabled), the status bit is cleared by writing a '1'.
- If the corresponding mask bit is cleared to '0' (interrupt generation disabled), the status bit is cleared when a new start or stop condition is detected on the receiver/transmitter.

### 21.3.3.2.2 SIDETONE\_McBSP Interrupt Requests

The McBSP2 and McBSP3 can generate another interrupt to the MPU subsystem interrupt controller:

- **ST\_McBSPi\_IRQ:** SIDETONE interrupt request for McBSPi module (where I = 2, 3).

**Table 21-13. SIDETONE\_McBSP Interrupt Requests**

| Request Name  | Mapping | Destination                        |
|---------------|---------|------------------------------------|
| ST_McBSP2_IRQ | M_IRQ_4 | MPU subsystem interrupt controller |
| ST_McBSP3_IRQ | M_IRQ_5 | MPU subsystem interrupt controller |

**Table 21-14. SIDETONE\_McBSP Interrupt Events**

| <b>Event Name</b> | <b>Status Bit</b>                                        | <b>Mask Bit</b>                                            | <b>Description</b>                                                                            |
|-------------------|----------------------------------------------------------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| Over-run          | McBSPi. <a href="#">ST_IRQSTATUS_REG[0]</a><br>OVRRERROR | McBSPi. <a href="#">ST_IRQENABLE_REG[0]</a><br>OVRERRROREN | This event happens when a new data to be processed arrives before the previous one has ended. |

Once an interrupt request has been generated, the software must read the McBSPi.[ST\\_IRQSTATUS\\_REG](#) register to check what event caused the interrupt request generation, and acknowledge each processed event by writing a 1 to the corresponding bit in the McBSPi.[ST\\_IRQSTATUS\\_REG](#) register.

**NOTE:** The McBSPi.[ST\\_IRQSTATUS\\_REG\[0\]](#) OVRRERROR status bit can be cleared in two ways:

- If the McBSPi.[ST\\_IRQENABLE\\_REG\[0\]](#) OVRERRROREN mask bit is set to '1' (interrupt generation enabled), the status bit is cleared by writing a '1'.
- If the McBSPi.[ST\\_IRQENABLE\\_REG\[0\]](#) OVRERRROREN mask bit is cleared to '0' (interrupt generation disabled), the status bit is cleared when a new start or stop condition is detected on the SIDETONE channels.

## 21.4 McBSP Functional Description

This section is a functional description of the McBSP module.

### 21.4.1 Block Diagram

[Figure 21-21](#), [Figure 21-22](#), and [Figure 21-23](#) show functional block diagrams of the five instances of the McBSP modules.

These figures regroup the McBSP modules by categories:

- McBSP module without audio buffer and SIDETONE core: McBSP1, McBSP4 and McBSP5
- McBSP module with audio buffer and SIDETONE core: McBSP2
- McBSP module without audio buffer, but with SIDETONE core: McBSP3

**Figure 21-21. McBSP1, McBSP4 and McBSP5 Block Diagrams**



**Figure 21-22. McBSP2 Block Diagram**


mcbsp-022

Figure 21-23. McBSP3 Block Diagram



mcbsp-023

#### 21.4.2 McBSP Data Transfer Process

For McBSP1, McBSP3, McBSP4, and McBSP5 modules, receive and transmit operations are triple-buffered (512 bytes buffers organized in 32-bit words are used).

For the McBSP2 module, receive and transmit operations are quadruple-buffered (5K bytes buffers organized in 32-bit words are used). Receive and transmit buffers are separated in two memories: The same buffer as the others McBSP modules (1K bytes) and an audio buffer (4K bytes). The audio buffer is the largest one and is clocked by the interface clock, while the other buffer is used for synchronizing data to/from the audio buffer with the functional transmit/receive clock domains. [Figure 21-25](#) shows this implementation in the McBSP2 data transfer paths.

All registers of McBSP data transfer paths are 32-bits wide. [Figure 21-24](#) and [Figure 21-25](#) illustrate the McBSP data transfer paths.

**CAUTION**

The McBSP registers (DRR\_REG and DXR\_REG) are limited to 32-bit data accesses (L4 Interconnect). 16-bit and 8-bit is not allowed and can corrupt register content.

**Figure 21-24. McBSP Data Transfer Paths**



mcbsp-024

**Figure 21-25. McBSP2 Data Transfer Paths**



mcbsp-068

#### 21.4.2.1 Data Transfer Process for 8- / 12- / 16- / 20- / 24- / 32-bits Long Words

**CAUTION**

For each data word length, one data occupies one 32-bit buffer word.

Receive data arrives on the mcbspi\_dr pin and is shifted into the receive shift register (RSR). When a full word (depending on the data length configuration) is received, the content of the shift register is copied into the receive buffer (RB) if it is not full. When the RB threshold is reached the McBSP module asserts DMA or interrupt request and the RB content is then transferred (the sDMA or the eDMA controller reads the data receive register McBSPi.[MCBSPLP\\_DRR\\_REG](#)).

Transmit data is written by the MPU subsystem, the IVA2.2 subsystem or the DMA controller to data transmit register (McBSPi.[MCBSPLP\\_DXR\\_REG](#)) using the McBSPi.[MCBSPLP\\_SPCR2\\_REG\[1\]](#) XRDY bit enable input (when a byte is not enabled, the byte value in the memory will contain the previous written value). If there is no previous data in transmit shift register (XSR), the value from the transmit buffer (XB) is copied to XSR; otherwise, the content is copied to the XSR when the last bit of the previous data is shifted out on the mcbspi\_dx pin.

### 21.4.2.2 Bit Reordering (Option to Transfer LSB First)

Generally, the McBSP module transmits or receives all data with the MSB first. However, some data protocols require the LSB to be transferred first.

If you set McBSPi.[MCBSPLP\\_XCR2\\_REG\[4:3\]](#) XREVERSE = 0b01, the bit ordering of the data words is reversed (LSB first) before being sent to the serial port. If you set McBSPi.[MCBSPLP\\_RCR2\\_REG\[4:3\]](#) RREVERSE = 0b01, the bit ordering of the data words is reversed during reception (LSB first).

This feature is available for all the data formats from 8-to 32-bit data length.

### 21.4.2.3 Clocking and Framing Data

This section explains basic concepts and terminology important for understanding how McBSP data transfers are timed and delimited.

**Figure 21-26. Conceptual Block Diagram for Clock and Frame Generation When MCBSPLP\_SPCR1\_REG[15] ALB = 0 and CONTROL\_DEVCONF0[3] MCBSP1\_CLKR = 0**



mcbsp-025

The CLKR\_int clock signal can be derived from three sources:

- The sample rate generator (CLKG): When [MCBSPLP\\_XCCR\\_REG\[5\]](#) DLB = 1 or [MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC = 1
- mcbsp1\_clk pin (CLKR): When [MCBSPLP\\_PCR\\_REG\[9\]](#) CLKXM = 0 and [MCBSPLP\\_XCCR\\_REG\[15\]](#) EXTCLKGATE = 0, and [MCBSPLP\\_XCCR\\_REG\[5\]](#) DLB = 0 or [MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC = 0
- mcbspi\_clk pin (CLKX): When [MCBSPLP\\_PCR\\_REG\[9\]](#) CLKXM = 1 and [MCBSPLP\\_XCCR\\_REG\[15\]](#) EXTCLKGATE = 1, and [MCBSPLP\\_XCCR\\_REG\[5\]](#) DLB = 0 or [MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC = 0

The CLKX\_int clock signal can be derived from two sources:

- The sample rate generator (CLKG): When [MCBSPLP\\_PCR\\_REG\[9\]](#) CLKXM = 1, [MCBSPLP\\_XCCR\\_REG\[5\]](#) DLB = 1, or [MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC = 1
- mcbspi\_clk pin (CLKX): When [MCBSPLP\\_PCR\\_REG\[9\]](#) CLKXM = 0, [MCBSPLP\\_XCCR\\_REG\[5\]](#) DLB = 0, or [MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC = 0

The FSR\_int frame-sync signal can be derived from three sources:

- The sample rate generator (FSG): When [MCBSPLP\\_XCCR\\_REG\[5\]](#) DLB = 1, [MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC = 1, or [MCBSPLP\\_PCR\\_REG\[10\]](#) FSRM = 1 and [MCBSPLP\\_PCR\\_REG\[8\]](#) CLKRM = 1

- mcbsp1\_fsr pin (FSR): When [MCBSPLP\\_PCR\\_REG\[9\]](#) CLKXM = 0 and [MCBSPLP\\_XCCR\\_REG\[15\]](#) EXTCLKGATE = 0 and [MCBSPLP\\_XCCR\\_REG\[5\]](#) DLB = 0 or [MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSNC = 0, or [MCBSPLP\\_PCR\\_REG\[10\]](#) FSRM = 0 and [MCBSPLP\\_PCR\\_REG\[8\]](#) CLKRM = 0
- mcbspi\_fsx pin (FSX): When [MCBSPLP\\_PCR\\_REG\[9\]](#) CLKXM = 1 and [MCBSPLP\\_XCCR\\_REG\[15\]](#) EXTCLKGATE = 1, and [MCBSPLP\\_XCCR\\_REG\[5\]](#) DLB = 0 or [MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSNC = 0, or [MCBSPLP\\_PCR\\_REG\[10\]](#) FSRM = 0 and [MCBSPLP\\_PCR\\_REG\[8\]](#) CLKRM = 0

The FSX\_int frame-sync signal can be derived from two sources:

- The sample rate generator (FSG): When [MCBSPLP\\_XCCR\\_REG\[5\]](#) DLB = 1 or [MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSNC = 1, or [MCBSPLP\\_SRGR2\\_REG\[12\]](#) FSGM = 1 and [MCBSPLP\\_PCR\\_REG\[11\]](#) FSXM = 1
- mcbspi\_fsx pin (FSX): When [MCBSPLP\\_XCCR\\_REG\[5\]](#) DLB = 0 or [MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSNC = 0, or [MCBSPLP\\_SRGR2\\_REG\[12\]](#) FSGM = 0 and [MCBSPLP\\_PCR\\_REG\[11\]](#) FSXM = 0

#### **21.4.2.3.1 Clocking**

Data is shifted one bit at a time from the mcbspi\_dr pin to the RSRs or from the XSRs to the mcbspi\_dx pin. The time for each bit transfer is controlled by the rising or falling edge of a clock signal.

The receive clock signal (CLKR\_int) controls bit transfers from the mcbspi\_dr pin to the RSRs. The transmit clock signal (CLKX\_int) controls bit transfers from the XSRs to the mcbspi\_dx pin. CLKR\_int or CLKX\_int signals can be derived from a pin at the boundary of the McBSP module (mcbspi\_clk and mcbspi\_clkx respectively) or derived from inside the McBSP module (see [Figure 21-26](#)). The clocks source is selected by programming the McBSPi.[MCBSPLP\\_PCR\\_REG\[9\]](#) CLKXM bit and the McBSPi.[MCBSPLP\\_PCR\\_REG\[8\]](#) CLKRM bit respectively.

When the McBSPi.[MCBSPLP\\_PCR\\_REG\[9\]](#) CLKXM bit (transmitter clock mode) is set to:

- 0: CLKX\_int is driven by an external clock and mcbspi\_clkx is an input pin.
- 1: CLKX\_int is driven by the internal sample rate generator and mcbspi\_clkx is an output pin.

For the McBSPi.[MCBSPLP\\_PCR\\_REG\[8\]](#) CLKRM bit (receiver clock mode), see [Table 21-15](#).

**Table 21-15. Receiver Clock Mode**

| Value | Digital loop back mode                                 | mcbspi_clk pin | Description                                                                       |
|-------|--------------------------------------------------------|----------------|-----------------------------------------------------------------------------------|
| 0x0   | McBSPi. <a href="#">MCBSPLP_XCCR_REG[5]</a> DLB bit =0 | input          | CLKR_int is driven by an external clock                                           |
|       | McBSPi. <a href="#">MCBSPLP_XCCR_REG[5]</a> DLB bit =1 | High-impedance | CLKR_int is driven by CLKX_int. The CLKX_int is derived based on the CLKXM value. |
| 0x1   | McBSPi. <a href="#">MCBSPLP_XCCR_REG[5]</a> DLB bit =0 | output         | CLKR_int is driven by the internal sample rate generator                          |
|       | McBSPi. <a href="#">MCBSPLP_XCCR_REG[5]</a> DLB bit =1 | output         | CLKR_int is driven by CLKX_int. The CLKX_int is derived based on the CLKXM value. |

The polarities of CLKR and CLKX signals are configured in McBSPi.[MCBSPLP\\_PCR\\_REG](#) register.

The McBSPi.[MCBSPLP\\_PCR\\_REG\[1\]](#) CLKXP defines the transmit clock polarity:

- When set to 0, transmit data driven on rising edge of CLKX signal
- When set to 1, transmit data driven on falling edge of CLKX signal

The McBSPi.[MCBSPLP\\_PCR\\_REG\[0\]](#) CLKRP defines the receive clock polarity:

- When set to 0, receive data sampled on falling edge of CLKX signal
- When set to 1, transmit data sampled on rising edge of CLKX signal

[Figure 21-27](#) gives an example where the clock signal controls the timing of each bit transfer on the pin.

**Figure 21-27. Clock Signal Control of Bit Transfer Timing**

mcbsp-026

**NOTE:** The McBSP module is constrained to operate at an internal functional frequency of up to L4 interface frequency divided by 2. When driving CLKX or CLKR at the pin, choose an appropriate input clock frequency. When using the internal sample rate generator for CLKX/CLKR/CLKS, choose an appropriate input clock frequency (up to L4 interface frequency) and divide down value by programming the [McBSPi.MCBSPLP\\_SRGR1\\_REG\[7:0\]](#) CLKGDV bit field.

#### 21.4.2.3.2 Serial Words

Bits traveling between a shift register (RSR or XSR) and a data pin (`mcbspi_dr` or `mcbspi_dx`) are transferred in a group called a serial word. The software defines how many bits are in a word by programming:

- For the receiver: the [McBSPi.MCBSPLP\\_RCR1\\_REG\[7:5\]](#) RWDLEN1 bit field and the [McBSPi.MCBSPLP\\_RCR2\\_REG\[7:5\]](#) RWDLEN2 bit field.
- For the transmitter: the [McBSPi.MCBSPLP\\_XCR1\\_REG\[7:5\]](#) XWDLEN1 bit field and the [McBSPi.MCBSPLP\\_XCR2\\_REG\[7:5\]](#) XWDLEN2 bit field.

The difference of use is explained to [Section 21.4.2.4.1](#).

The various possibilities of word length are 8, 12, 16, 20, 24, and 32 bits (for field values, see [Section 21.6](#))

Bits coming from the `mcbspi_dr` pin are held in the RSR until it holds a full serial word, then the word is passed to the RB and to the [McBSPi.MCBSPLP\\_DRR\\_REG](#) register.

During transmission, XSR accepts new data from XB after a full serial word has been passed from XSR to the `mcbspi_dx` pin.

In the example in [Figure 21-27](#), an 8-bit word size was defined (see the transfer of the 8-bit word B).

#### 21.4.2.3.3 Frames and Frame Synchronization

One or more words (up to 128) are transferred in a group called a frame. The software defines how many words are in a frame by programming:

- For the receiver: The [McBSPi.MCBSPLP\\_RCR1\\_REG\[14:8\]](#) RFRLLEN1 bit field and the [McBSPi.MCBSPLP\\_RCR2\\_REG\[14:8\]](#) RFRLLEN2 bit field.
- For the transmitter: The [McBSPi.MCBSPLP\\_XCR1\\_REG\[14:8\]](#) XFRLEN1 bit field and the [McBSPi.MCBSPLP\\_XCR2\\_REG\[14:8\]](#) XFRLEN2 bit field.

The difference between these registers is explained to [Section 21.4.2.4.1](#). For the corresponding between field value and words number, see [Section 21.6](#).

All the words in a frame are sent in a continuous stream. However, there can be pauses between frame transfers. The McBSP module uses frame-synchronization signals (FSG) to determine when each frame is received/transmitted. When a pulse occurs on a frame-synchronization signal, the McBSP module begins receiving/transmitting a frame of data. When the next pulse occurs, the McBSP module receives/transmits the next frame, and so on.

Pulses on the receive frame-synchronization (FSR\_int) signal initiate frame transfers on mcbspi\_dr. Pulses on the transmit frame-sync (FSX\_int) signal initiate frame transfers on mcbspi\_dx. FSR\_int or FSX\_int signals can be derived from a pin at the boundary of the McBSP module (mcbspi\_fsr and mcbspi\_fsx respectively) or derived from inside the McBSP module (see [Figure 21-25](#)). The frame-sync source is selected by programming the McBSPi.[MCBSPLP\\_PCR\\_REG\[11\]](#) FSXM bit and the McBSPi.[MCBSPLP\\_PCR\\_REG\[10\]](#) FSRM bit respectively.

When the McBSPi.[MCBSPLP\\_PCR\\_REG\[11\]](#) FSXM bit (transmitter frame-sync mode) is set to:

- 0: FSX\_int is derived from an external source and mcbspi\_fsx is an input pin.
- 1: FSX\_int is determined by the McBSPi.[MCBSPLP\\_SRGR2\\_REG\[12\]](#) FSGM bit and mcbspi\_fsx is an output pin.

For the McBSPi.[MCBSPLP\\_PCR\\_REG\[10\]](#) FSRM bit (receiver frame-sync mode), is set to:

- 0: FSR\_int is generated by an external source and mcbsp1\_fsr is an input pin.
- 1: FSR\_int is generated internally by sample rate generator. The mcbsp1\_fsr is an output pin except when McBSPi.[MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC bit = 0x1.

In the example in [Figure 21-26](#), a one-word frame is transferred when a frame-synchronization pulse occurs. The polarities of FSR and FSX signals are programmable by bits on McBSPi.[MCBSPLP\\_PCR\\_REG](#) register.

The McBSPi.[MCBSPLP\\_PCR\\_REG\[3\]](#) FSXP bit defines the transmit frame-sync polarity:

- When set to 0,, frame-sync pulse FSX is active high.
- When set to 1, frame-sync pulse FSX is active low.

The McBSPi.[MCBSPLP\\_PCR\\_REG\[2\]](#) FSRP bit defines the receive frame-sync polarity:

- When set to 0, frame-sync pulse FSR is active high.
- When set to 1, frame-sync pulse FSR is active low.

In McBSP operation, the inactive-to-active transition of the frame-synchronization signal indicates the start of the next frame. For this reason, the frame-synchronization signal may be high for an arbitrary number of clock cycles. Only after the signal is recognized to have gone inactive, and then active again, does the next frame synchronization occur.

#### 21.4.2.3.4 Detecting Frame-Synchronization Pulses, Even in Reset State

The McBSP module can generate receive and transmit interrupts to the MPU/IVA2.2 subsystems to indicate specific events in the McBSP module. To facilitate detection of frame synchronization, these interrupts can be sent in response to frame-synchronization pulses (see [Section 21.5](#) for further details).

Unlike other serial port interrupt modes, this mode can operate while the associated portion of the serial port is in reset (such as activating receive interrupt when the receiver is in reset). In this case, McBSPi.[MCBSPLP\\_PCR\\_REG\[0\]](#) FSRM bit/McBSPi.[MCBSPLP\\_PCR\\_REG\[1\]](#) FSXM bit and McBSPi.[MCBSPLP\\_PCR\\_REG\[2\]](#) FSRP bit/McBSPi.[MCBSPLP\\_PCR\\_REG\[3\]](#) FSXP bit still select the appropriate source and polarity of frame synchronization. Thus, even when the serial port is in the reset state, these signals are synchronized to the interface clock (McBSPi\_ICLK) and then sent to the MPU/IVA2.2 subsystem in the form of receive interrupt and transmit interrupt at the point where they feed the receiver and transmitter of the serial port. Consequently, a new frame-synchronization pulse can be detected, and then, the MPU/IVA2.2 subsystem can take the serial port out of reset safely.

#### 21.4.2.3.5 Ignoring Frame-Synchronization Pulses

The McBSP module ignores transmit and/or receive frame-synchronization pulses if the frame transfer was started by a previous frame-synchronization pulse (unexpected frame-synchronization pulses). The McBSP module does not support features like retransmit or re-receive of an erroneous frame or word. The receiver or transmitter ignores frame-synchronization pulses until the desired frame length or number of words is reached. For more details on unexpected frame-synchronization pulses, see [Section 21.4.4.3](#), or [Section 21.4.4.6](#).

### 21.4.2.3.6 Frame Frequency

The frame frequency is determined by the period between frame-synchronization pulses and is defined as shown in the following equation:

Frame frequency = Clock frequency/(Number of clock cycles between two rising edges [or falling edges] of two consecutive frame synchronization pulses)

The frame frequency can be increased by decreasing the time between frame-synchronization pulses (limited only by the number of bits per frame). As the frame transmit frequency increases, the inactivity period between the data packets for adjacent transfers decreases to zero.

### 21.4.2.3.7 Maximum Frame Frequency

The minimum number of clock cycles between frame synchronization pulses is equal to the number of bits transferred per frame. The maximum frame frequency is defined as shown in the following equation:

Maximum frame frequency = clock frequency/Number of bits per frame

[Figure 21-28](#) below shows the McBSP operating at maximum packet frequency. At maximum packet frequency, the data bits in consecutive packets are transmitted contiguously with no inactivity between bits.

**Figure 21-28. McBSP Operating at Maximum Packet Frequency**



If there is a 1-bit data delay as shown in [Figure 21-28](#), the frame-synchronization pulse overlaps the last bit transmitted in the previous frame. Effectively, this permits a continuous stream of data, back-to-back transfers.

---

**NOTE:** For McBSPi.MCBSPPLP\_XCR2\_REG[1:0] XDATDLY = 0x0 (0-bit data delay), the first bit of data is transmitted asynchronously to the internal transmit clock signal (CLKX\_int). For more details, see [Section 21.5.1.6.2.2.5](#).

---

### 21.4.2.4 Frame Phases (Dual-Phase Frame I2S Support)

The McBSP module allows you to configure each frame to contain one or two phases. The support for dual-phase frames is required to provide I2S fully compliant capabilities (audio left and right channels—stereo audio stream).

#### CAUTION

The limitation on dual-phase frame support is that the number of words per phase must be set to 1 for both first and second phase. It is the only possible value for word per frame when using the dual phase frame.

The number of bits per word can be specified differently for each of the two phases of a frame, allowing greater flexibility in structuring data transfers. For example, a user might define a frame as consisting of one phase containing one word of 16 bits, followed by a second phase consisting of one word of 32 bits. This configuration allows the user to compose frames for custom applications such as I2S protocol.

#### 21.4.2.4.1 Number of Phases, Words, and Bits per Frame

Table 21-16 below shows which bit fields in the receive control registers (McBSPi.[MCBSPLP\\_RCR1\\_REG](#) and McBSPi.[MCBSPLP\\_RCR2\\_REG](#)) and in the transmit control registers (McBSPi.[MCBSPLP\\_XCR1\\_REG](#) and McBSPi.[MCBSPLP\\_XCR2\\_REG](#)) determine the number of phases per frame, the number of words per frame, and the number of bits per word for each phase, for both receiver and transmitter. The maximum number of words per frame is limited to 2 when using dual-phase frames (one word for each phase), and to 128 for a single-phase frame. The number of bits per word can be 8, 12, 16, 20, 24, or 32 bits.

The following legend applies to the table:

- RPHASE = McBSPi.[MCBSPLP\\_RCR2\\_REG](#)[15] RPHASE bit
- XPHASE = McBSPi.[MCBSPLP\\_XCR2\\_REG](#)[15] XPHASE bit
- RFRLLEN1 = McBSPi.[MCBSPLP\\_RCR1\\_REG](#)[14:8] RFRLLEN1 field
- RFRLLEN2 = McBSPi.[MCBSPLP\\_RCR2\\_REG](#)[14:8] RFRLLEN2 field
- XFRLEN1 = McBSPi.[MCBSPLP\\_XCR1\\_REG](#)[14:8] XFRLEN1 field
- XFRLEN2 = McBSPi.[MCBSPLP\\_XCR2\\_REG](#)[14:8] XFRLEN2 field
- RWDLEN1 = McBSPi.[MCBSPLP\\_RCR1\\_REG](#)[7:5] RWDLEN1 field
- RWDLEN2 = McBSPi.[MCBSPLP\\_RCR2\\_REG](#)[7:5] RWDLEN2 field
- XWDLEN1 = McBSPi.[MCBSPLP\\_XCR1\\_REG](#)[7:5] XWDLEN1 field
- XWDLEN2 = McBSPi.[MCBSPLP\\_XCR2\\_REG](#)[7:5] XWDLEN2 field

**Table 21-16. Phases, Words and Bits per Frame Control Bit**

| Operation    | Number of phases | Words per frame set with      | Bits per word set with                  |
|--------------|------------------|-------------------------------|-----------------------------------------|
| Reception    | 1 (RPHASE=0)     | RFRLLEN1                      | RWDLEN1                                 |
| Reception    | 2 (RPHASE=1)     | RFRLLEN1=0x0 and RFRLLEN2=0x0 | RWDLEN1 for phase 1 RWDLEN2 for phase 2 |
| Transmission | 1 (XPHASE=0)     | XFRLEN1                       | XWDLEN1                                 |
| Transmission | 2 (XPHASE=1)     | XFRLEN1=0x0 and XFRLEN2=0x0   | XWDLEN1 for phase 1 XWDLEN2 for phase 2 |

#### 21.4.2.4.2 Single-Phase Frame Example

Figure 21-29 below shows an example of a single-phase data frame containing one 8-bit word. Because the transfer is configured for one data bit delay, the data on the `mcbspi_dx` and `mcbspi_dr` pins are available one clock cycle after FS(R/X) goes active. The following table shows the assumptions used in the example of this figure.

**Table 21-17. Assumptions for the Single-Phase Frame Example**

| Assumption                           | Value   | Bit or Field Name                                                                                                               |
|--------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------|
| Single-phase frame                   | '0'     | McBSPi. <a href="#">MCBSPLP_RCR2_REG</a> [15] RPHASE bit<br>McBSPi. <a href="#">MCBSPLP_XCR2_REG</a> [15] XPHASE bit            |
| One word per frame                   | 0x0     | McBSPi. <a href="#">MCBSPLP_RCR1_REG</a> [14:8] RFRLLEN1 field<br>McBSPi. <a href="#">MCBSPLP_XCR1_REG</a> [14:8] XFRLEN1 field |
| 8-bit word length                    | 0x0     | McBSPi. <a href="#">MCBSPLP_RCR1_REG</a> [7:5] RWDLEN1 field<br>McBSPi. <a href="#">MCBSPLP_XCR1_REG</a> [7:5] XWDLEN1 field    |
| word length in register2             | ignored | McBSPi. <a href="#">MCBSPLP_RCR2_REG</a> [14:8] RFRLLEN2 field<br>McBSPi. <a href="#">MCBSPLP_XCR2_REG</a> [14:8] XWDLEN2 field |
| Receive data clocked on falling edge | '0'     | McBSPi. <a href="#">MCBSPLP_PCR_REG</a> [0] CLKRP bit                                                                           |
| Transmit data clocked on rising edge | '0'     | McBSPi. <a href="#">MCBSPLP_PCR_REG</a> [1] CLKXP bit                                                                           |
| Active-high frame-sync signals       | '0'     | McBSPi. <a href="#">MCBSPLP_PCR_REG</a> [2] FSRP bit<br>McBSPi. <a href="#">MCBSPLP_PCR_REG</a> [3] FSXP bit                    |
| 1-bit data delay                     | 01b     | McBSPi. <a href="#">MCBSPLP_RCR2_REG</a> [1:0] RDATDLY field<br>McBSPi. <a href="#">MCBSPLP_XCR2_REG</a> [1:0] XDARDLY field    |

**Figure 21-29. Single-Phase Frame for a McBSP Data Transfer****21.4.2.4.3 Dual-Phase Frame Example**

Figure 21-30 below shows an example of a frame. The first phase consists of one word of 16 bits, followed by a second phase of one word of 8 bits. The entire bit stream in the frame is contiguous. There are no gaps between words/phases. Table 21-18 shows the assumptions used to the example in Figure 21-30.

**Table 21-18. Assumptions for the Dual-Phase Frame Example**

| Assumption                           | Value | Bit or Field name                            |
|--------------------------------------|-------|----------------------------------------------|
| Single-phase frame                   | '1'   | McBSPi.MCBSPPLP_RCR2_REG[15] RPHASE bit      |
|                                      |       | McBSPi.MCBSPPLP_XCR2_REG[15] XPHASE bit      |
| One word per frame                   | 0x0   | McBSPi.MCBSPPLP_RCR1_REG[14:8] RFRLEN1 field |
|                                      |       | McBSPi.MCBSPPLP_XCR1_REG[14:8] XFRLEN1 field |
| 16-bit word length                   | 0x0   | McBSPi.MCBSPPLP_RCR1_REG[7:5] RWDLEN1 field  |
|                                      |       | McBSPi.MCBSPPLP_XCR1_REG[7:5] XWDLEN1 field  |
| 8-bit word length                    | 0x2   | McBSPi.MCBSPPLP_RCR2_REG[14:8] RFRLEN2 field |
|                                      |       | McBSPi.MCBSPPLP_XCR2_REG[14:8] XWDLEN2 field |
| Receive data clocked on falling edge | '0'   | McBSPi.MCBSPPLP_PCR_REG[0] CLKRP bit         |
|                                      |       | McBSPi.MCBSPPLP_PCR_REG[1] CLKXP bit         |
| Transmit data clocked on rising edge | '0'   | McBSPi.MCBSPPLP_PCR_REG[2] FSRP bit          |
|                                      |       | McBSPi.MCBSPPLP_PCR_REG[3] FSXP bit          |
| 0-bit data delay                     | 00b   | McBSPi.MCBSPPLP_RCR2_REG[1:0] RDATDLY field  |
|                                      |       | McBSPi.MCBSPPLP_XCR2_REG[1:0] XDARDLY field  |

**Figure 21-30. Dual-Phase Frame for a McBSP Data Transfer****21.4.2.5 McBSP Reception**

This section explains the fundamental process of reception in the McBSP module. For details about how to program the McBSP receiver, see [Section 21.5](#), [Section 21.5.1.4](#), and [Section 21.5.1.5](#).

Figure 21-31 and Figure 21-32 below show how reception occurs in the McBSP module. A description of the process follows the figures. Figure 21-31 shows the physical path for the data.

**Figure 21-31. McBSP Reception Physical Data Path**


Figure 21-32 is a timing diagram showing signal activity for one possible reception scenario.

**Figure 21-32. McBSP Reception Signal Activity**


RRDY: Status of receiver ready bit (high is 1)

mcbsp-031

The following process describes how data travels from the `mcbspi_dr` pin to the MPU/IVA2.2 subsystem or to the sDMA controller:

1. The McBSP module waits for a receive frame-synchronization pulse on `FSR_int`.
2. When the pulse arrives, the McBSP module inserts the appropriate data delay that is selected with the McBSPi.[MCBSPLP\\_RCR2\\_REG\[1:0\]](#) RDATDLY bits. In the preceding timing diagram a 1-bit data delay is selected.
3. The McBSP module accepts data bits on the `mcbspi_dr` pin and shifts them into the RSR. For details on choosing a word length, see [Section 21.5.1.5.2.2.2](#).
4. When a full word is received, the McBSP module copies the contents of the RSR to the RB, provided that RB is not full.
5. When the programmed receive threshold is reached (McBSPi.[MCBSPLP\\_THRSH1\\_REG\[10:0\]](#) RTHRESHOLD bit field), the McBSP module asserts the receiver ready bit (McBSPi.[MCBSPLP\\_SPCR1\\_REG\[1\]](#) RRDY bit). This indicates that receive data is ready to be read by the MPU/IVA2.2 subsystem or the sDMA controller by accessing McBSPi.[MCBSPLP\\_DRR\\_REG](#) register.

The data copied from RB to McBSPi.[MCBSPLP\\_DRR\\_REG](#) is justified and bit filled according to the McBSPi.[MCBSPLP\\_SPCR1\\_REG\[14:13\]](#) RJUST bit field.

6. The MPU/IVA2.2 subsystem or the sDMA controller reads the data from the data receive register. When the RB is empty, McBSPi.[MCBSPLP\\_SPCR1\\_REG\[1\]](#) RRDY bit is cleared.

#### 21.4.2.6 McBSP Transmission

This section explains the fundamental process of transmission in the McBSP module. For details about how to program the McBSP transmitter, see [Section 21.5](#), and [Section 21.5.1.6](#).

Figures below show how transmission occurs in the McBSP module. A description of the process follows the figures. [Figure 21-33](#) shows the physical path for the data.

**Figure 21-33. McBSP Transmission Physical Data Path**


mcbsp-032

Figure 21-34 is a timing diagram showing signal activity for one possible transmission scenario.

**Figure 21-34. McBSP Transmission Signal Activity**



XRDY: Status of transmitter ready bit (high is 1)

mcbspi-033

1. The MPU/IVA2.2 subsystem or the sDMA controller writes data to the data transmit register (McBSPi.MCBSPPLP\_DXR\_REG). When the XB is reached the transmitter ready bit (McBSPi.MCBSPPLP\_SPCR2\_REG[1] XRDY bit) is cleared to indicate that the transmitter is not ready for new data. For details on choosing a word length, see [Section 21.5.1.6.2.2.2](#).
2. When new data arrives in McBSPi.MCBSPPLP\_DXR\_REG register, the McBSP module copies the content of the data transmit register to the XB. In addition, the transmit ready bit (McBSPi.MCBSPPLP\_SPCR2\_REG[1] XRDY bit) is set as long as the buffer contains at least the transmit threshold number of free locations (McBSPi.MCBSPPLP\_THRSH2\_REG[10:0] XTHRESHOLD field). This indicates that the transmitter is ready to accept new data from the MPU/IVA2.2 subsystem or the sDMA controller.
3. The McBSP module waits for a transmit frame-synchronization pulse on FSX\_int.
4. When the pulse arrives, the McBSP module inserts the appropriate data delay that is selected with the McBSPi.MCBSPPLP\_XCR2\_REG[1:0] XDATDLY field.  
In the preceding timing diagram, a 1-bit data delay is selected.
5. The McBSP module shifts data bits from the XSR to the mcbspi\_dx pin.

#### 21.4.2.7 Enable/Disable the Transmit and Receive Processes

The McBSP module has the option to stop-resume the transmit/receive process while the module is in functional mode (out of transmit/receive reset).

When the transmit/receive disable bit (McBSPi.MCBSPPLP\_XCCR\_REG[0] XDISABLE/McBSPi.MCBSPPLP\_RCCR\_REG[0] RDISABLE) is set, the McBSP module stops the transmit/receive operation at the next frame boundary (frame corruption avoided).

During the receive disable state, the frames that are sent (when FSR signal is asserted while receive disable) by the remote device are lost, and receive buffer overflow status bit (McBSPi.MCBSPPLP\_IRQSTATUS\_REG[5] ROVFLSTAT) is not set. Also, the frames received by the remote device while McBSPi.MCBSPPLP\_XCCR\_REG[0] XDISABLE bit is set (when FSX signal is asserted while transmit disable) are meaningless undefined data frames, and transmit buffer underflow status bit (McBSPi.MCBSPPLP\_IRQSTATUS\_REG[11] XUNDFLSTAT) is not set. The presence of the frame synchronization, while transmit/receive process is disabled, can be checked by reading the transmit/receive Frame-sync interrupt status: McBSPi.MCBSPPLP\_IRQSTATUS\_REG[8] XFSX / McBSPi.MCBSPPLP\_IRQSTATUS\_REG[1] RFSR bits.

As soon as the McBSPi.MCBSPPLP\_XCCR\_REG[0] XDISABLE/McBSPi.MCBSPPLP\_RCCR\_REG[0] RDISABLE bit is cleared, the transmit/receive process resumes at the next frame boundary.

---

**NOTE:** It is not recommended to use this mechanism together with the possibility to interrogate the transmit/receive buffer status register (McBSPi.MCBSPPLP\_XBUFFSTAT\_REG[7:0] XBUFFSTAT/McBSPi.MCBSPPLP\_RBUFFSTAT\_REG[7:0] RBUFFSTAT bit field indicating the occupied/available buffer locations), since this register is an interface clock (McBSPi\_ICLK) synchronous register and does not reflect the exact number of occupied/free locations available on the functional clock domain.

---

### 21.4.2.8 McBSP Data Transfer Mode

**NOTE:** For all examples in this section, the configured CLKX edge is the rising edge (McBSPi.MCBSPLP\_PCR\_REG[1] CLKXP bit=0x0) and the configured CLKR edge is the falling edge (McBSPi.MCBSPLP\_PCR\_REG[0] CLKRP bit=0x0). These are the reset values.

In timing diagrams below, a 1-bit data delay is selected (McBSPi.MCBSPLP\_RCR2\_REG[1:0] RDATDLY field=0x01 and McBSPi.MCBSPLP\_XCR2\_REG[1:0] XDATDLY field=0x01), because data often follows a 1-cycle active frame-synchronisation.

McBSP modules can support 2 edge selection modes for transmit and receive data transfer at the system level:

- The full cycle mode, for which one clock period is used to transfer the data, generated on one edge and captured on the same edge (one clock period later).
- The half cycle mode, for which one half clock period is used to transfer the data, generated on one edge and captured on the opposite edge (one half clock period later). Note that a new data is generated only every clock period, which permits to guarantee the required hold time.

#### 21.4.2.8.1 Transmit Full Cycle Mode

When configured in full cycle mode (McBSPi.MCBSPLP\_XCCR\_REG[11] XFULL\_CYCLE bit = 0x1), the FSX signal is sampled on the configured CLKX edge and the data is driven on the same configured edge. See [Figure 21-35](#).

**Figure 21-35. Transmit Full Cycle Timing Diagram**



#### 21.4.2.8.2 Transmit Half Cycle Mode

When configured in half cycle mode (McBSPi.MCBSPLP\_XCCR\_REG[11] XFULL\_CYCLE bit = 0x0, reset value), the FSX signal is sampled on the opposite configured CLKX edge and the data is driven on the next configured edge. See [Figure 21-36](#).

**Figure 21-36. Transmit Half Cycle Timing Diagram**



### 21.4.2.8.3 Receive Full Cycle Mode

When configured in full cycle mode (McBSPi.MCBSPLP\_RCCR\_REG[11] RFULL\_CYCLE bit = 0x1, reset value), the FSR signal is sampled on the configured CLKR edge and the data is driven on the same configured edge. See [Figure 21-37](#).

**Figure 21-37. Receive Full Cycle Timing Diagram**



mcbsp-071

### 21.4.2.8.4 Receive Half Cycle Mode

When configured in half cycle mode (McBSPi.MCBSPLP\_RCCR\_REG[11] RFULL\_CYCLE bit = 0x0), the FSR signal is sampled on the opposite configured CLKR edge and the data is driven on the next configured edge. See [Figure 21-38](#).

**Figure 21-38. Receive Half Cycle Timing Diagram**



mcbsp-072

### 21.4.3 McBSP SRG

The McBSP module contains an internal SRG that can be used to generate an internal data clock (CLKG) and an internal frame-synchronization signal (FSG). CLKG can be used for bit shifting on the data receive pin (**mcbspi\_dr**) and/or the data transmit pin (**mcbspi\_dx**). FSG can be used to initiate frame transfers on **mcbspi\_dr** pin and/or **mcbspi\_dx** pin. [Figure 21-39](#) is a conceptual block diagram of the SRG.

**Figure 21-39. Conceptual Block Diagram of the Sample Rate Generator**


mcbsp-034

The source clock for the SRG (labeled CLKSRG in the diagram) can be supplied by either the interface clock (McBSPI\_ICLK), or the functional clock (CLKS input), or by an external pin (mcbspi\_clkx, or mcbspi\_clkr). The source is selected with the McBSPI.[MCBSPLP\\_PCR\\_REG\[7\]](#) SCLKME bit and the McBSPI.[MCBSPLP\\_SRGR2\\_REG\[13\]](#) CLKSM bit.

If a pin or CLKS signal is used, the polarity of the incoming signal can be inverted with the appropriate polarity bit (McBSPI.[MCBSPLP\\_SRGR2\\_REG\[14\]](#) CLKSP bit, McBSPI.[MCBSPLP\\_PCR\\_REG\[1\]](#) CLKXP bit, or McBSPI.[MCBSPLP\\_PCR\\_REG\[0\]](#) CLKRP bit).

The SRG has a three-stage clock divider that gives CLKG and FSG programmability.

The three stages provide:

- Clock divide-down: The source clock (CLKSRG) is divided according to the McBSPI.[MCBSPLP\\_SRGR1\\_REG\[7:0\]](#) CLKGDV field to produce CLKG signal
- Frame period divide-down: CLKG is divided according to the McBSPI.[MCBSPLP\\_SRGR2\\_REG\[11:0\]](#) FPER field to control the period from the start of a frame-pulse to the start of the next pulse
- Frame-synchronization pulse-width countdown: CLKG cycles are counted according to the McBSPI.[MCBSPLP\\_SRGR1\\_REG\[15:8\]](#) FWID bit field to control the width of each frame-synchronization pulse

---

**NOTE:** The McBSP module cannot operate at an internal functional frequency faster than L4 interface frequency divided by 2. Choose an input clock frequency and a McBSPI.[MCBSPLP\\_SRGR1\\_REG\[7:0\]](#) CLKGDV value such that CLKG is less than or equal to L4 interface frequency divided by 2.

---

In addition to the three-stage clock divider, the sample rate generator has a frame-synchronization pulse detection and clock synchronization module that allows synchronization of the clock divide down with an incoming frame-synchronization pulse on the mcbspi\_fsr pin. This feature is enabled or disabled with the McBSPI.[MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC bit.

CLKG is used as source to generate the output clocks CLKX/CLKR when the McBSPI.[MCBSPLP\\_PCR\\_REG\[9\]](#) CLKXM / McBSPI.[MCBSPLP\\_PCR\\_REG\[8\]](#) CLKRM bit indicates that the clock is an output. The output CLKX/CLKR is generated according to the clock polarity setting (see [Figure 21-26](#)).

For details on getting the sample rate generator ready for operation, see [Section 21.5](#).

### 21.4.3.1 Clock Generation in the SRG

The SRG can produce a clock signal (CLKG) for use by the receiver, the transmitter, or both. Use of the SRG to drive clocking is controlled by the clock mode bits (McBSPi.MCBSPPLP\_PCR\_REG[9] CLKXM and McBSPi.MCBSPPLP\_PCR\_REG[8] CLKRM) and polarity mode bits (McBSPi.MCBSPPLP\_PCR\_REG[1] CLKXP and McBSPi.MCBSPPLP\_PCR\_REG[0] CLKRP).

When a clock mode bit is set to 1 (CLKRM=1 for reception, CLKXM=1 for transmission), the corresponding data clock (CLKR for reception, CLKX for transmission) is driven by the internal SRG output clock (CLKG) according to the polarity setting.

The effects of this setting on the McBSP module are partially affected by the use of the digital loopback (DLB) mode, the analog loop back (ALB) mode and by the synchronous receive/transmit setting, respectively, as described in [Table 21-19](#). The ALB mode is selected with the McBSPi.MCBSPPLP\_SPCR1\_REG[15] ALB bit. The DLB mode is selected with the McBSPi.MCBSPPLP\_XCCR\_REG[5] DLB bit. The synchronous setting is controlled by input signals. These signals are defined by the control registers of the System Control Module (more details, refer [Section 21.3.1](#))

When using the SRG as a clock source, make sure the SRG is enabled (McBSPi.MCBSPPLP\_SPCR2\_REG[6] GRST bit =1).

**Table 21-19. Effects of DLB and ALB Bits on Clock Modes**

| Mode Bit Settings |                                                                                       | Effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|---------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLKRM=1           | DLB=0 and ALB = 0 (Digital and analog loop back mode disabled)                        | mcbsp1_clk is an output pin driven by the SRG output clock (CLKG).                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                   | DLB=0 and ALB = 1 (Digital loop back mode disabled and Analog loop back mode enabled) | <p>mcbsp1_clk is an output pin driven by the SRG output clock (CLKG).</p> <p>The receiver functional part internal clock is driven by CLKX input signal provided by mcbspi_clkx pin. The source of CLKX depends on the CLKXM bit.</p> <p>The receive frame synchronization is driven by FSX input signal provided by mcbspi_fsx pin.</p> <p>The receive data is driven by the DX input loop-back pin (mcbspi_dx).</p>                                                                 |
|                   | DLB=1 ALB = 0 (Digital loop back mode enabled and Analog loop back mode disabled)     | <p>The SRG and the frame synchronization generator must be enabled.</p> <p>The internal transmit and receive clocks are driven by the SRG (CLKG having the appropriate CLKXP polarity).</p> <p>The transmit and receive frame synchronization signals are driven by FSG (having the appropriate FSXP polarity).</p> <p>The transmit data is connected to the DR input data.</p> <p>Note that in digital loop back mode no serial link activity will be seen by the remote device.</p> |
|                   | DLB=1 ALB = 1 (reserved mode)                                                         | Undefined functionality.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

**Table 21-19. Effects of DLB and ALB Bits on Clock Modes (continued)**

| Mode Bit Settings |                                                                                      | Effect                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLKXM= 1          | DLB=0 ALB = 0 (Digital analog loop back mode disabled)                               | mcbspi_clkx is an output pin driven by the SRG output clock (CLKG).                                                                                                                                                                                                                                                                                                                                                                                               |
|                   | DLB=0 ALB = 1 (Digital loop back mode disabled and Analog loop back mode enabled)    | mcbspi_clkx is an output pin driven by the SRG output clock (CLKG).                                                                                                                                                                                                                                                                                                                                                                                               |
|                   | DLB=1 ALB = 0 (Digital loop back mode enabled and Analog loop back mode disabled)    | The SRG and the frame synchronization generator need to be enabled.<br>The internal transmit and receive clocks are driven by the SRG (CLKG having the appropriate CLKXP polarity).<br>The transmit and receive frame synchronization signals are driven by FSG (having the appropriate FSXP polarity).<br>The transmit data is connected to the DR input data.<br>Note that in digital loop back mode no serial link activity will be seen by the remote device. |
|                   | DLB=1 ALB = 1 (reserved mode)                                                        | Undefined functionality.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                   | SCM.CONTROL_DEVCONF0[3] MCBSP1_CLKR bit =1 (synchronous setting and DLB = 0 ALB = 0) | CLKX is an output pin driven by the SRG output clock (CLKG).<br>CLKR is connected to the CLKX.                                                                                                                                                                                                                                                                                                                                                                    |

### 21.4.3.2 Frame Sync Generation in the SRG

The SRG can produce a frame-synchronization signal (FSG) for use by the receiver, the transmitter, or both.

If you want the receiver to use FSG for frame synchronization, make sure McBSPi.[MCBSPLP\\_PCR\\_REG](#)[10] FSRM bit =1. (When FSRM=0, receive frame synchronization is supplied via the mcbspi\_fsr pin.)

If you want the transmitter to use FSG for frame synchronization, you must set:

- McBSPi.[MCBSPLP\\_PCR\\_REG](#)[11] FSXM = 1: This indicates that transmit frame synchronization is supplied by the McBSP module itself rather than from the mcbspi\_fx pin.
- [MCBSPLP\\_SRGR2\\_REG](#)[12] FSGM=1: This indicates that when FSXM=1, transmit frame synchronization is supplied by the SRG.

---

**NOTE:** When FSGM=0 and FSXM=1, the transmit frame-sync signal (FSX) is generated when XB is not empty. When FSGM = 0, McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)[11:0] FPER and McBSPi.[MCBSPLP\\_SRGR1\\_REG](#)[15:8] FWID field are used to determine the frame synchronization period and width (external FSX is gated by the buffer empty condition).

---

In either case, the SRG must be enabled (McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[6] GRST bit=1) and the frame-synchronization logic in the SRG must be enabled (McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[7] FRST bit=0).

#### 21.4.3.2.1 Choosing the Width of the Frame-sync Pulse

Each pulse on FSG has a programmable width. You program the McBSPi.[MCBSPLP\\_SRGR1\\_REG](#)[15:8] FWID field, and the resulting pulse width is (FWID+1)CLKG cycles, where CLKG is the output clock of the SRG. The range is from 1 to 256 clock periods.

#### 21.4.3.2.2 Controlling the Period Between the Starting Edges of Frame Sync Pulses

You can control the amount of time from the starting edge of one FSG pulse to the starting edge of the next FSG pulse. This period is controlled in one of two ways, depending on the configuration of the SRG:

- If the SRG is using an external input clock and McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)[15] GSYNC bit =1, FSG pulses in response to an inactive-to-active transition on the mcbspi\_fsr pin. Thus, an external device controls the frame-synchronization period.

- Otherwise, the software program the McBSPi.[MCBSPLP\\_SRGR2\\_REG\[11:0\]](#) FPER field, and the resulting frame-synchronization period is (FPER+1)CLKG cycles, where CLKG is the output clock of the SRG. The range is from 1 to 4096 clock periods.

#### 21.4.3.2.3 Keeping FSG Synchronized to an External Clock

When an external signal is selected to drive the SRG, the McBSPi.[MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC bit and the `mcbspi_fsr` pin can be used to configure the timing of FSG pulses.

McBSPi.[MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC=1 ensures that the McBSP module and an external device are dividing down the input clock with the same phase relationship.

If McBSPi.[MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC=1, an inactive-to-active transition on the `mcbspi_fsr` pin triggers a resynchronization of CLKG and generation of FSG.

#### 21.4.3.3 Synchronizing SRG Outputs to an External Clock

The SRG can produce a clock signal (CLKG) and a FSG based on an input clock signal that is either the interface clock signal (McBSPi\_ICLK), or the CLKS signal (PRCM functional clock or `mcbsp_clks`), or a signal at the `mcbspi_clk`, or `mcbspi_clkx` pin. When an external clock (`mcbsp_clks`, or `mcbspi_clk`, or `mcbspi_clkx`) is selected to drive the SRG, the McBSPi.[MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC bit and the `mcbspi_fsr` pin can be used to control the timing of CLKG and the pulsing of FSG relative to the chosen input clock. Make GSYNC=1 so that the McBSP module and an external device divide down the input clock with the same phase relationship.

If the McBSPi.[MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC bit=1:

- An inactive-to-active transition on the `mcbspi_fsr` pin triggers a resynchronization of CLKG signal and a pulsing of FSG signal.
- CLKG signal always begins with a high state after synchronization.
- FSR signal is always detected at the same edge of the input clock signal that generates CLKG signal, no matter how long the FSR pulse is.
- The McBSPi.[MCBSPLP\\_SRGR2\\_REG\[11:0\]](#) FPER field are ignored because the frame-synchronization period on FSG is determined by the arrival of the next frame-synchronization pulse on the `mcbspi_fsr` pin.

If the McBSPi.[MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC bit=0, CLKG signal runs freely and is not resynchronized, and the frame-synchronization period on FSG signal is determined by McBSPi.[MCBSPLP\\_SRGR2\\_REG\[11:0\]](#) FPER field.

##### 21.4.3.3.1 Operating the Transmitter Synchronously with the Receiver

When the McBSPi.[MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC bit = 1, the transmitter can operate synchronously with the receiver, provided that the FSX signal is programmed to be driven by FSG signal (McBSPi.[MCBSPLP\\_SRGR2\\_REG\[12\]](#) FSGM = 1 and McBSPi.[MCBSPLP\\_PCR\\_REG\[11\]](#) FSXM = 1). If the FSR input signal has appropriate timing so that it can be sampled by the falling edge of CLKG signal, it can be used, instead, by setting McBSPi.[MCBSPLP\\_PCR\\_REG\[11\]](#) FSXM=0 and connecting FSR signal to FSX externally.

The SRG clock drives the transmit and receive clocking (McBSPi.[MCBSPLP\\_PCR\\_REG\[8\]](#) CLKRM bit and McBSPi.[MCBSPLP\\_PCR\\_REG\[9\]](#) CLKXM bit are set to 1). Therefore, the CLK(R/X) pin must not be driven by any other driving source.

##### 21.4.3.3.2 Synchronization Examples

[Figure 21-40](#) and [Figure 21-41](#) show the clock and frame-synchronization operation with various polarities of CLKS (the chosen input clock) and FSR signals. These figures assume McBSPi.[MCBSPLP\\_SRGR1\\_REG\[15:8\]](#) FWID = 0x0, for an FSG pulse that is one CLKG cycle wide. The McBSPi.[MCBSPLP\\_SRGR2\\_REG\[11:0\]](#) FPER field are not programmed; the period from the start of a frame-synchronization pulse to the start of the next pulse is determined by the arrival of the next inactive-to-active transition on the `mcbspi_fsr` pin.

Each figure shows what happens to CLKG signal when the McBSPi.[MCBSPLP\\_SRGR2\\_REG\[15\]](#) GSYNC bit = 1 and if it is initially synchronized or if it is not initially synchronized. [Figure 21-41](#) has a slower CLKG frequency (it has a larger divide-down value in the McBSPi.[MCBSPLP\\_SRGR1\\_1\\_REG\[7:0\]](#) CLKGDV field).

**Figure 21-40. CLKG Synchronization and FSG Generation (GSYNC = 1 and CLKGDV = 0x1)**



**Figure 21-41. CLKG Synchronization and FSG Generation (GSYNC = 1 and CLKGDV = 0x3)**



## 21.4.4 McBSP Exception/Error Conditions

### 21.4.4.1 Introduction

There are several serial port events that can constitute a system error. Any error conditions can be a source of an interrupt:

- Receiver overrun (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG\[5\]](#) ROVFLSTAT bit is set to 1, and legacy mode McBSPi.[MCBSPLP\\_SPCR1\\_REG\[2\]](#) RFULL bit is set to 1)

This occurs when RB is full and RSR are full with another new word shifted in from mcbspi\_dr. Therefore, McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG\[5\]](#) ROVFLSTAT

(McBSPi.[MCBSPLP\\_SPCR1\\_REG\[2\]](#) RFULL) indicates an error condition wherein any new data that can arrive at this time on mcbspi\_dr replaces the contents of the RSR, and the previous word is lost.

The RSR continues to be overwritten as long as new data arrives on mcbspi\_dr and

McBSPi.[MCBSPLP\\_DRR\\_REG](#) register is not read. For more details about overrun in the receiver, see [Section 21.4.4.2](#).

- Unexpected receive frame-synchronization pulse (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[0] RSYNCERR bit is set to 1, and legacy mode McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[3] RSYNCERR bit is set to 1).  
 This occurs during reception when an unexpected frame-synchronization pulse arrives. An unexpected frame-synchronization pulse is one that is supposed to begin the next frame transfer before all the bits of the current frame have been received. Such a pulse is ignored by the receiver, but sets the McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[3] RSYNCERR bit. For more details about receive frame-synchronization errors, see [Section 21.4.4.3, Unexpected Receive Frame-Sync Pulse](#).
- Receiver underflow (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[4] RUNDLSTAT bit is set to '1')  
 This occurs when sDMA controller or MPU/IVA2.2 subsystem reads data from an empty receive buffer. For more details about underflow in the receiver, see [Section 21.4.4.4](#).
- Transmitter underflow (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[11] XUNDFLSTAT bit is set to '1', and legacy mode McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[2] XEMPTY bit is set to '0')  
 If a new frame-synchronization signal arrives when XB is empty, the previous data in the XSR is sent again. This procedure continues for every new frame-synchronization pulse that arrives until McBSPi.[MCBSPLP\\_DXR\\_REG](#) register is loaded with new data (and the XB is no longer empty). For more details about underflow in the transmitter, see [Section 21.4.4.5](#).
- Unexpected transmit frame-synchronization pulse (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[7] XSYNCERR bit is set to '1', and legacy mode McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[3] XSYNCERR bit is set to '1')  
 This occurs during transmission when an unexpected frame-synchronization pulse arrives. An unexpected pulse is one that is supposed to begin the next frame transfer before all the bits of the current frame have been transferred. Such a pulse is ignored by the transmitter, but sets the McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[3] XSYNCERR bit. For more details see [Section 21.4.4.6](#).
- Transmitter overflow (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[12] XOVFLSTAT bit is set to '1')  
 This occurs when sDMA controller or MPU/IVA2.2 subsystem writes data to a full XB. For more details about underflow in the receiver, see [Section 21.4.4.7](#).

#### 21.4.4.2 Overrun in the Receiver

When McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[5] ROVFLSTAT bit set to '1', and McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[2] RFULL bit set to '1' (legacy mode) indicates that the receiver has experienced overrun and is in an error condition. Receive overrun is set when all of the following conditions are met:

1. McBSPi.[MCBSPLP\\_DRR\\_REG](#) is not read even if the McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[3] RRDY bit is set (legacy mode) and DMA or interrupt request has been asserted.
2. RB is full
3. RSR is full

As previously described, data arriving on `mcbspi_dr` is continuously shifted into the Receive Shift Register (RSR). Once a complete word is shifted into the RSR, an RSR-to-RB copy can occur only if the RB is not full.

Either of the following events clears the legacy mode McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[2] RFULL bit and allows subsequent transfers to be read properly:

- The MPU/IVA2.2 subsystems or sDMA controller reads McBSPi.[MCBSPLP\\_DRR\\_REG](#).
- The receiver is reset individually (McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[0] RRST bit =0) or as part of a global reset.

Another frame-synchronization pulse is required to restart the receiver.

According to the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#) register setting, this condition can generate the McBSPi.[IRQ](#) line to be asserted low. Writing 1 to the corresponding bit in McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#) register clears the interrupt.

[Figure 21-42](#) shows the receive overrun condition.

**Figure 21-42. Overrun in the McBSP Receiver**


#### 21.4.4.3 Unexpected Receive Frame-sync Pulse

##### 21.4.4.3.1 Possible Responses to Receive Frame-sync Pulses

If a frame-synchronization pulse starts the transfer of a new frame before the current frame is fully received, this pulse is treated as an unexpected frame-synchronization pulse, and the receiver sets the receive frame-synchronization error bit [McBSPi.MCBSPPLP\\_IRQSTATUS\\_REG\[0\]](#) RSYNCERR (and the legacy [McBSPi.MCBSPPLP\\_SPCR1\\_REG\[3\]](#) RSYNCERR bit).

According to the [McBSPi.MCBSPPLP\\_IRQENABLE\\_REG](#) register settings this condition can generate the [McBSPi.IRQ](#) line to be asserted low. Writing 1 to the corresponding bit in [McBSPi.MCBSPPLP\\_IRQSTATUS\\_REG](#) register clears the interrupt.

Using the legacy mode, [McBSPi.MCBSPPLP\\_SPCR1\\_REG\[3\]](#) RSYNCERR bit can be cleared only by a receiver reset or by writing 0 to this bit. If you want the McBSP module to notify the MPU/IVA2.2 subsystem of receive frame-synchronization errors, set the legacy mode receive interrupt with the [McBSPi.MCBSPPLP\\_SPCR1\\_REG\[5:4\]](#) RINTM bit field. When RINTM = 0b11, the McBSP module sends a receive interrupt (legacy mode) request to the MPU/IVA2.2 subsystems each time that RSYNCERR is set.

##### 21.4.4.3.2 Example of an Unexpected Receive Frame-sync Pulse

[Figure 21-43](#) shows an unexpected receive frame-synchronization pulse during normal operation of the serial port, with time intervals between data packets.

**NOTE:** The unexpected receive frame-synchronization pulse does not influence the data receive process, being ignored by the data receive state-machine.

**Figure 21-43. Unexpected Frame-sync Pulse During a McBSP Reception**


##### 21.4.4.3.3 Preventing Unexpected Receive Frame-sync Pulses

Each frame transfer can be delayed by 0, 1, or 2 CLKR cycles, depending on the value of the [McBSPi.MCBSPPLP\\_RCR2\\_REG\[1:0\]](#) RDATDLY field. For each possible data delay, [Figure 21-44](#) shows when a new frame-synchronization pulse on FSR can safely occur relative to the last bit of the current frame.

**Figure 21-44. Proper Positioning of Receive Frame-sync Pulses**

mcbsp-039

#### 21.4.4.4 Underflow in the Receiver

The McBSP module indicates a receiver underflow condition by setting the McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[4] RUNDLSTAT bit. This error occurs when sDMA controller or MPU/IVA2.2 subsystem reads data from an empty RB this happens only if the MPU/IVA2.2 subsystem or sDMA controller does not respect the DMA length, does not wait for DMA request, or does not check the buffer status before reading data. According to the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#) register settings this condition can generate the McBSPi\_IRQ line to be asserted low. Writing 1 to the corresponding bit in McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#) register clears the interrupt.

#### 21.4.4.5 Underflow in the Transmitter

The McBSP module indicates a transmitter empty (or underflow) condition by setting the McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[11] XUNDLSTAT bit. Also the legacy mode McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[2] XEMPTY bit is cleared. Either of the following events activates XEMPTY bit (XEMPTY = 0):

- McBSPi.[MCBSPLP\\_DXR\\_REG](#) has not been loaded and XB is empty, and all bits of the data word in the XSR have been shifted out on the mcbspi\_dx pin.
- The transmitter is reset (by forcing McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[0] XRST=0, or by a global reset) and is then restarted.

XEMPTY bit is deactivated (XEMPTY=1) when a new word in McBSPi.[MCBSPLP\\_DXR\\_REG](#) is transferred to Transmit Buffer (XB). If McBSPi.[MCBSPLP\\_PCR\\_REG](#)[11] FSXM=1 and McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)[12] FSGM=0, the transmit frame-sync signal (FSX) is generated when Transmit Buffer (XB) is not empty. When McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)[12] FSGM=0, McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)[11:0] FPER and McBSPi.[MCBSPLP\\_SRGR1\\_REG](#)[15:8] FWID are used to determine the frame-synchronization period and width (external FSX is gated by the buffer empty condition). Otherwise, the transmitter waits for the next frame-synchronization pulse before sending out the next frame on mcbspi\_dx.

When the transmitter is taken out of reset (McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[0] XRST=1), it is in a transmitter ready state (McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[1] XRDY bit =1) and transmitter empty (McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[2] XEMPTY=0) state. If McBSPi.[MCBSPLP\\_DXR\\_REG](#) is loaded by

the MPU/IVA2.2 subsystem or the sDMA controller before internal FSX goes active high, a valid XB-to-XSR transfer occurs. This allows for the first word of the first frame to be valid even before the transmit frame-synchronization pulse is generated or detected. Alternatively, if a transmit frame-synchronization pulse is detected before McBSPi.[MCBSPLP\\_DXR\\_REG](#) is loaded, zeros are output on mcbspi\_dx.

The McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[11] XUNDLSTAT bit indicates a real underflow condition, in which the frame is corrupted due to lack of data availability during transmit process. According to the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#) register settings this condition can generate the McBSPi\_IRQ line to be asserted low. Writing 1 to the corresponding bit in McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#) register clears the interrupt.

#### 21.4.4.6 Unexpected Transmit Frame-sync Pulse

##### 21.4.4.6.1 Possible Responses to Transmit Frame-sync Pulses

If a frame-synchronization pulse starts the transfer of a new frame before the current frame is fully transmitted, this pulse is treated as an unexpected frame-synchronization pulse, and the transmitter sets the transmit frame-synchronization error bit McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[7] XSYNCERR (and the legacy McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[3] XSYNCERR bit).

According to the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#) register settings, this condition can generate the McBSPi\_IRQ line to be asserted low. Writing 1 to the corresponding bit in status register clears the interrupt.

Using the legacy mode, McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[3] XSYNCERR bit can be cleared only by a transmitter reset or by a write of 0 to this bit. If you want the McBSP module to notify the MPU/IVA2.2 subsystem of frame-synchronization errors, you can set a special transmit interrupt mode with the McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[5:4] XINTM field. When XINTM=0b11, the McBSP module sends a transmit interrupt request to the MPU/IVA2.2 subsystem each time that XSYNCERR is set.

##### 21.4.4.6.2 Example of Unexpected Transmit Frame-Synchronization Pulse

Figure 21-45 shows an unexpected transmit frame-synchronization pulse during normal operation of the serial port with intervals between the data packets.

**NOTE:** The unexpected transmit frame-synchronization pulse does not influence the data transmit process, being ignored by the data transmit state-machine.

**Figure 21-45. Unexpected Frame-sync Pulse During a McBSP Transmission**



##### 21.4.4.6.3 Preventing Unexpected Transmit Frame-sync Pulses

Each frame transfer can be delayed by 0, 1, or 2 CLKX cycles, depending on the value in the McBSPi.[MCBSPLP\\_XCR2\\_REG](#)[1:0] XDATDLY field. For each possible data delay, Figure 21-46 shows when a new frame-synchronization pulse on FSX can safely occur relative to the last bit of the current frame.

**Figure 21-46. Proper Positioning of Transmit Frame-sync Pulses**

mcbsp-041

#### 21.4.4.7 Overflow in the Transmitter

The McBSP module indicates a transmitter overflow condition by setting the McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG\[12\]](#) XOVFLSTAT bit. This error occurs when sDMA controller or MPU/IVA2.2 subsystem write data to a full XB (this may happen only if the MPU/IVA2.2 subsystem or sDMA controller does not respect the DMA length, does not wait for DMA request or does not check the buffer status before writing data). According to the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#) register settings this condition can generate the McBSPi\_IRQ line to be asserted low. Writing 1 to the corresponding bit in status register clears the interrupt.

#### 21.4.5 McBSP DMA Configuration

The McBSP receive and transmit data DMA requests are active after the receive McBSPi.[MCBSPLP\\_SPCR1\\_REG\[0\]](#) RRST and transmit McBSPi.[MCBSPLP\\_SPCR2\\_REG\[0\]](#) XRST are released. After reset the default DMA threshold (and length) is one.

The receive and transmit DMA requests can be individually disabled by setting the McBSPi.[MCBSPLP\\_RCCR\\_REG\[3\]](#) RDMAEN, McBSPi.[MCBSPLP\\_XCCR\\_REG\[3\]](#) XDMAEN bits to 0. When disabling the DMA, the DMA request line is de-asserted even if a DMA transfer is pending and the DMA state-machine is not reset.

The DMA threshold and length configuration is done through McBSPi.[MCBSPLP\\_THRSH1\\_REG](#) and McBSPi.[MCBSPLP\\_THRSH2\\_REG](#) registers as follows:

- (THRSH1\_REG + 1) value represents the required receive DMA request length (the length of the transfer is the same as the threshold value plus one). As long as the RB occupied locations level is above or equal to the THRSH1\_REG value + 1, the DMA request is asserted. After transferring the configured (THRSH1\_REG + 1) number of words, the receive DMA request is de-asserted and reasserted as soon as the conditions are met again.
- (THRSH2\_REG + 1) value represents the required transmit DMA request length (the length of the transfer is the same as the threshold value plus one). As long as the XB free locations level is above or equal to the THRSH2\_REG value + 1, the DMA request is asserted. After transferring the configured (THRSH2\_REG + 1) number of words, the transmit DMA request is de-asserted and reasserted as soon as the conditions are met again.

**NOTE:** The MPU/IVA2.2 subsystem can decide not to use the DMA to transfer the data. In this case, the DMA must be disabled (or the DMA request can be ignored by MPU/IVA2.2 subsystem) and the common interrupt line (McBSPi\_IRQ) can be used. The McBSPi.MCBSPPLP\_SPCR1\_REG[1] RRDY bit for receive and McBSPi.MCBSPPLP\_SPCR2\_REG[1] XRDY bit for transmit will indicate when the threshold values are reached. Also, by reading the receive buffer status McBSPi.MCBSPPLP\_RBUFFSTAT\_REG register and transmit buffer status McBSPi.MCBSPPLP\_XBUFFSTAT\_REG register, the MPU/IVA2.2 subsystem can decide to transfer data even if the threshold is not reached. This mechanism is useful on the last transfer on receive side when the threshold value is bigger than the occupied locations inside the receive buffer and the MPU/IVA2.2 subsystem needs to read this data. Since no interrupt or DMA request is asserted the only option in this case is to read the RB status register value and to transfer the remaining data without using the DMA or interrupt indication.

## 21.4.6 Multichannel Selection Modes

### 21.4.6.1 Channels, Blocks, and Partitions

A McBSP channel is a time slot for shifting in/out the bits of one serial word. The McBSP module supports up to 128 channels for reception and 128 channels for transmission. In the receiver and in the transmitter, the 128 available channels are divided into eight blocks that contain 16 contiguous channels each:

- Block 0: Channels 0–15
- Block 1: Channels 16–31
- Block 2: Channels 32–47
- Block 3: Channels 48–63
- Block 4: Channels 64–79
- Block 5: Channels 80–95
- Block 6: Channels 96–111
- Block 7: Channels 112–127

The blocks are assigned to partitions according to the selected partition mode. In the two-partition mode described in [Section 21.4.6.6](#), you assign one even-numbered block (0, 2, 4, or 6) to partition A and one odd-numbered block (1, 3, 5, or 7) to partition B. In the 8-partition mode [Section 21.4.6.4](#), blocks 0 through 7 are automatically assigned to partitions A through H, respectively.

The number of partitions for reception and the number of partitions for transmission are independent of each other. For example, it is possible to use two receive partitions (A and B) and eight transmit partitions (A–H).

### 21.4.6.2 Multichannel Selection

When a McBSP module uses a time-division multiplexed (TDM) data stream while communicating with other McBSP modules or serial devices, the McBSP module may need to receive and/or transmit on only a few channels. To save memory and bus bandwidth, use a multichannel selection mode to prevent data flow in some of the channels.

Each channel partition has a dedicated channel enable register. If the appropriate multichannel selection mode is on, each bit in the register controls whether data flow is allowed or prevented in one of the channels that is assigned to that partition.

The McBSP module has one receive multichannel selection mode [Section 21.4.6.5](#), and three transmit multichannel selection modes [Section 21.4.6.7](#).

### 21.4.6.3 Configuring a Frame for Multichannel Selection

Before enabling a multichannel selection mode, make sure you properly configure the data frame:

- Select a single-phase frame (McBSPi.MCBSPPLP\_RCR2\_REG[15] RPHASE bit and McBSPi.MCBSPPLP\_XCR2\_REG[15] XPHASE bit = 0). Each frame represents a TDM data stream.

- Set a frame length (in McBSPi.[MCBSPLP\\_RCR1\\_REG](#)[14:8] RFRLEN1 field and in McBSPi.[MCBSPLP\\_XCR1\\_REG](#)[14:8] XFRLEN1 field) that includes the highest-numbered channel to be used. For example, if you plan to use channels 0, 15, and 39 for reception, the receive frame length must be at least 40 (RFRLEN1 = 39). If RFRLEN1 = 39 in this case, the receiver creates 40 time slots per frame but only receives data during time slots 0, 15, and 39 of each frame.

#### 21.4.6.4 Using Eight Partitions

For multichannel selection operation in the receiver and/or the transmitter, you can use eight partitions or two partitions (as previously described). If you choose the 8-partition mode (McBSPi.[MCBSPLP\\_MCR1\\_REG](#)[9] RMCME = 1 for reception, McBSPi.[MCBSPLP\\_MCR2\\_REG](#)[9] XMCME = 1 for transmission), McBSP channels are activated in the following order: A, B, C, D, E, F, G, H.

In response to a frame-synchronization pulse, the receiver or transmitter begins with the channels in partition A and then continues with the other partitions in order until the complete frame has been transferred. When the next frame-synchronization pulse occurs, the next frame is transferred, beginning with the channels in partition A.

In the 8-partition mode, the McBSPi.[MCBSPLP\\_MCR1\\_REG](#)[6:5] RPABLK and McBSPi.[MCBSPLP\\_MCR2\\_REG](#)[6:5] XPABLK, and McBSPi.[MCBSPLP\\_MCR1\\_REG](#)[8:7] RPBBLK and McBSPi.[MCBSPLP\\_MCR2\\_REG](#)[8:7] XPBBLK bit fields are ignored, and the 16 channel blocks are assigned to the partitions as shown in [Table 21-20](#) through [Table 21-21](#). These assignments cannot be changed. The tables also show the registers used to control the channels in the partitions.

**Table 21-20. Eight Partitions – Receive Channel Assignment and Control**

| Receive Partition | Assigned Block of Receive Channels | Register Used for Channel Control         |
|-------------------|------------------------------------|-------------------------------------------|
| A                 | Block 0: Channels 0 through 15     | McBSPi. <a href="#">MCBSPLP_RCERA_REG</a> |
| B                 | Block 1: Channels 16 through 31    | McBSPi. <a href="#">MCBSPLP_RCERB_REG</a> |
| C                 | Block 2: Channels 32 through 47    | McBSPi. <a href="#">MCBSPLP_RCERC_REG</a> |
| D                 | Block 3: Channels 48 through 63    | McBSPi. <a href="#">MCBSPLP_RCERD_REG</a> |
| E                 | Block 4: Channels 64 through 79    | McBSPi. <a href="#">MCBSPLP_RCERE_REG</a> |
| F                 | Block 5: Channels 80 through 95    | McBSPi. <a href="#">MCBSPLP_RCERF_REG</a> |
| G                 | Block 6: Channels 96 through 111   | McBSPi. <a href="#">MCBSPLP_RCERG_REG</a> |
| H                 | Block 7: Channels 112 through 127  | McBSPi. <a href="#">MCBSPLP_RCERH_REG</a> |

**Table 21-21. Eight Partitions – Transmit Channel Assignment and Control**

| Transmit Partition | Assigned Block of Receive Channels | Register Used for Channel Control         |
|--------------------|------------------------------------|-------------------------------------------|
| A                  | Block 0: Channels 0 through 15     | McBSPi. <a href="#">MCBSPLP_XCERA_REG</a> |
| B                  | Block 1: Channels 16 through 31    | McBSPi. <a href="#">MCBSPLP_XCERB_REG</a> |
| C                  | Block 2: Channels 32 through 47    | McBSPi. <a href="#">MCBSPLP_XCERC_REG</a> |
| D                  | Block 3: Channels 48 through 63    | McBSPi. <a href="#">MCBSPLP_XCERD_REG</a> |
| E                  | Block 4: Channels 64 through 79    | McBSPi. <a href="#">MCBSPLP_XCERE_REG</a> |
| F                  | Block 5: Channels 80 through 95    | McBSPi. <a href="#">MCBSPLP_XCERF_REG</a> |
| G                  | Block 6: Channels 96 through 111   | McBSPi. <a href="#">MCBSPLP_XCERG_REG</a> |
| H                  | Block 7: Channels 112 through 127  | McBSPi. <a href="#">MCBSPLP_XCERH_REG</a> |

Figure 21-47 shows an example of the McBSP using the 8-partition mode. In response to a frame-synchronization pulse, the McBSP module begins a frame transfer with partition A and then activates B, C, D, E, F, G, and H to complete a 128-word frame.

**Figure 21-47. McBSP Data Transfer in 8-Partition Mode**



#### 21.4.6.5 Receive Multichannel Selection Mode

The McBSPi.[MCBSPLP\\_MCR1\\_REG\[0\]](#) RMCM bit determines whether all channels or only selected channels are enabled for reception.

- When RMCM = 0, all 128 receive channels are enabled and cannot be disabled.
- When RMCM = 1, the receive multichannel selection mode is enabled. In this mode:
  - Channels can be individually enabled or disabled. The enabled channels are those selected in the appropriate receive channel enable registers (McBSPi.[MCBSPLP\\_RCERA\\_REG](#) to McBSPi.[MCBSPLP\\_RCERH\\_REG](#)). The channels are assigned to the McBSPi.[MCBSPLP\\_RCERA\\_REG](#) to McBSPi.[MCBSPLP\\_RCERH\\_REG](#) registers depends on the number of receive channel partitions (2 or 8), as defined by the McBSPi.[MCBSPLP\\_MCR1\\_REG\[9\]](#) RMCME bit.
  - If a receive channel is disabled, any bits received in that channel are not transferred to the RB, and as a result, the receiver ready bit (RRDY) is not set. Therefore, no DMA synchronization event is generated and, if the receiver interrupt mode depends on RRDY (McBSPi.[MCBSPLP\\_SPCR1\\_REG\[5:4\]](#) RINTM = 0b00), no interrupt is generated.

As an example of how the McBSP module behaves in the receive multichannel selection mode, suppose you enable only channels 0, 15, and 39 and that the frame length is 40. The McBSP module:

1. Accepts bits shifted in from the mcbspi\_dr pin in channel 0
2. Ignores bits received in channels 1–14
3. Accepts bits shifted in from the mcbspi\_dr pin in channel 15
4. Ignores bits received in channels 16–38
5. Accepts bits shifted in from the mcbspi\_dr pin in channel 39

#### 21.4.6.6 Using Two Partitions (Legacy Only)

For multichannel selection operation in the receiver and/or the transmitter, you can use two partitions or eight partitions. If you choose the 2-partition mode (McBSPi.[MCBSPLP\\_MCR1\\_REG\[9\]](#) RMCME = 0 for reception, McBSPi.[MCBSPLP\\_MCR2\\_REG\[9\]](#) XMCME = 0 for transmission), McBSP channels are activated using an alternating scheme. In response to a frame-synchronization pulse, the receiver or transmitter begins with the channels in partition A and then alternates between partitions B and A until the complete frame has been transferred. When the next frame-synchronization pulse occurs, the next frame is transferred beginning with the channels in partition A.

For reception, any two of the eight receive-channel blocks can be assigned to receive partitions A and B, which means up to 32 receive channels can be enabled at any given point. Similarly, any two of the eight transmit-channel blocks (up 32 enabled transmit channels) can be assigned to transmit partitions A and B.

For reception:

- Assign an even-numbered channel block (0, 2, 4, or 6) to receive partition A by writing to the McBSPi.[MCBSPLP\\_MCR1\\_REG](#)[6:5] RPABLK field. In the receive multichannel selection mode, the channels in this partition are controlled by receive channel enable register A (McBSPi.[MCBSPLP\\_RCERA\\_REG](#)).
  - Assign an odd-numbered block (1, 3, 5, or 7) to receive partition B with the McBSPi.[MCBSPLP\\_MCR1\\_REG](#)[8:7] RPBLBK field. In the receive multichannel selection mode, the channels in this partition are controlled by receive channel enable register B (McBSPi.[MCBSPLP\\_RCERB\\_REG](#)).

For transmission:

- Assign an even-numbered channel block (0, 2, 4, or 6) to transmit partition A by writing to the McBSPi.[MCBSPLP\\_MCR2\\_REG](#)[6:5] XPABLK fields. In one of the transmit multichannel selection modes, the channels in this partition are controlled by transmit channel enable register A (McBSPi.[MCBSPLP\\_XCERA\\_REG](#)).
  - Assign an odd-numbered block (1, 3, 5, or 7) to transmit partition B with the McBSPi.[MCBSPLP\\_MCR1\\_REG](#)[8:7] XPBBLK field. In one of the transmit multichannel selection modes, the channels in this partition are controlled by transmit channel enable register B (McBSPi.[MCBSPLP\\_XCERB\\_REG](#)).

[Figure 21-48](#) shows an example of alternating between the channels of partition A and the channels of partition B. Channels 0–15 have been assigned to partition A, and channels 16–31 have been assigned to partition B. In response to a frame-synchronization pulse, the McBSP module begins a frame transfer with partition A and then alternates between partitions B and A until the complete frame is transferred.

**Figure 21-48. Alternating Between Partitions A and B Channels**

| Slot | Partition | Block | Channel |
|------|-----------|-------|---------|
| 1    | A         | 0     | 0-15    |
| 2    | B         | 1     | 16-31   |
| 3    | A         | 0     | 0-15    |
| 4    | B         | 1     | 16-31   |
| 5    | A         | 0     | 0-15    |
| 6    | B         | 1     | 16-31   |
| 7    | A         | 0     | 0-15    |
| 8    | B         | 1     | 16-31   |
| 9    | A         | 0     | 0-15    |
| 10   | A         | 0     | 0-15    |

#### 21.4.6.7 Transmit Multichannel Selection Modes

The McBSPi.MCBSPPLP\_MCR2\_REG[1:0] XMCM field determine whether all channels or only selected channels are enabled and unmasked for transmission. The McBSP module has three transmit multichannel selection modes (XMCM = 0b01, XMCM = 0b10, and XMCM = 0b11), which are described in Table 21-22.

**Table 21-22.** Selecting a Transmit Multichannel Selection Mode With the XMCM Bit Field

| XMCM | Transmit Multichannel Selection Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b00 | No transmit multichannel selection mode is on. All channels are enabled and unmasked. No channels can be disabled or masked.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0b01 | All channels are disabled unless they are selected in the appropriate transmit channel enable registers (McBSPi. <a href="#">MCBSPLP_XCERA_REG</a> /McBSPi. <a href="#">MCBSPLP_XCERH_REG</a> ). If enabled, a channel in this mode is also unmasked. The McBSPi. <a href="#">MCBSPLP_MCR2_REG[9]</a> XMCME bit determines whether 32 channels or 128 channels are selectable in the McBSPi. <a href="#">MCBSPLP_XCERA_REG</a> /McBSPi. <a href="#">MCBSPLP_XCERH_REG</a> registers.                                                                                                                                                                                                                                                                                                                                              |
| 0b10 | All channels are enabled, but they are masked unless they are selected in the appropriate transmit channel enable registers (McBSPi. <a href="#">MCBSPLP_XCERA_REG</a> /McBSPi. <a href="#">MCBSPLP_XCERH_REG</a> ). The McBSPi. <a href="#">MCBSPLP_MCR2_REG[9]</a> XMCME bit determines whether 32 channels or 128 channels are selectable in the McBSPi. <a href="#">MCBSPLP_XCERA_REG</a> /McBSPi. <a href="#">MCBSPLP_XCERH_REG</a> registers.                                                                                                                                                                                                                                                                                                                                                                               |
| 0b11 | This mode is used for symmetric transmission and reception. All channels are disabled for transmission unless they are enabled for reception in the appropriate receive channel enable registers (McBSPi. <a href="#">MCBSPLP_RCERA_REG</a> /McBSPi. <a href="#">MCBSPLP_RCERH_REG</a> ). Once enabled, they are masked unless they are also selected in the appropriate transmit channel enable registers (McBSPi. <a href="#">MCBSPLP_XCERA_REG</a> /McBSPi. <a href="#">MCBSPLP_XCERH_REG</a> ). The McBSPi. <a href="#">MCBSPLP_MCR2_REG[9]</a> XMCME bit determines whether 32 channels or 128 channels are selectable in McBSPi. <a href="#">MCBSPLP_RCERA_REG</a> /McBSPi. <a href="#">MCBSPLP_RCERH_REG</a> registers and McBSPi. <a href="#">MCBSPLP_XCERA_REG</a> /McBSPi. <a href="#">MCBSPLP_XCERH_REG</a> registers. |

As an example of how the McBSP module behaves in a transmit multichannel selection mode, suppose that XMCM = 0b01 (all channels disabled unless individually enabled) and that you have enabled only channels 0, 15, and 39. Suppose also that the frame length is 40. The McBSP module:

1. Shifts data to the mcbspi\_dx pin in channel 0
2. Places the mcbspi\_dx pin in the high impedance state in channels 1–14
3. Shifts data to the mcbspi\_dx pin in channel 15
4. Places the mcbspi\_dx pin in the high impedance state in channels 16–38
5. Shifts data to the mcbspi\_dx pin in channel 39

#### 21.4.6.7.1 Disabling/Enabling Versus Masking/Unmasking

For transmission, a channel can be:

- Enabled and unmasked (transmission can begin and can be completed)
- Enabled but masked (transmission can begin but cannot be completed)
- Disabled (transmission cannot occur)

The definitions in [Table 21-23](#) explain the channel control options:

**Table 21-23. McBSP Channel Control Options**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enabled channel</b>  | A channel that can begin transmission by passing data from the data transmit register ( <a href="#">McBSPi.MCBSPPLP_DXR_REG</a> ) to the XSR through XB.                                                                                                                                                                                                                                                                                                  |
| <b>Masked channel</b>   | A channel that cannot complete transmission. The mcbspi_dx pin is held in the high impedance state; data cannot be shifted out on the mcbspi_dx pin. In systems where symmetric transmit and receive provide software benefits, this feature allows transmit channels to be disabled on a shared serial bus. A similar feature is not needed for reception because multiple receptions cannot cause serial bus contention.                                |
| <b>Disabled channel</b> | A channel that is not enabled. A disabled channel is also masked. Because no DXR-to-XB copy occurs, the <a href="#">McBSPi.MCBSPPLP_SPCR2_REG[1]</a> XRDY bit is not set. Therefore, no DMA synchronization event is generated, and if the transmit interrupt mode depends on XRDY ( <a href="#">McBSPi.MCBSPPLP_SPCR2_REG[5:4]</a> XINTM = 00b), no interrupt is generated. The <a href="#">McBSPi.MCBSPPLP_SPCR2_REG[2]</a> XEMPTY bit is not affected. |
| <b>Unmasked channel</b> | A channel that is not masked. Data in the XSR(s) is shifted out on the mcbspi_dx pin.                                                                                                                                                                                                                                                                                                                                                                     |

#### 21.4.6.7.2 Activity on McBSP Pins for Different Values of XMCM

[Figure 21-49](#) shows the activity on the McBSP pins for the various McBSPi.[MCBSPLP\\_MCR2\\_REG\[1:0\]](#) XMCM values. In all cases, the transmit frame is configured as follows:

- XPHASE=0: Single-phase frame (required for multichannel selection modes)
- XFRLEN1=0b0000011: 4 words per frame
- XWDLEN1=0b000: 8 bits per word
- XMCME=0: 2-partition mode (only partitions A and B used)

In the case where McBSPi.[MCBSPLP\\_MCR2\\_REG\[1:0\]](#) XMCM=0b11, transmission and reception are symmetric, which means the corresponding bits for the receiver (RPHASE, RFRLEN1, RWDLEN1, and RMCME) must have the same values as XPHASE, XFRLEN1, and XWDLEN1, respectively.

In [Figure 21-49](#), the arrows showing where the various events occur are only sample indications. Wherever possible, there is a time window in which these events can occur.

**Figure 21-49. Activity on McBSP Pins When XMCM=0b00**

If XMCM = 0b00, all channels are enabled and unmasked. Words W0, W1, W2, and W3 are written to the XB, then, from the XB, there are transferred by mcbspi\_dx.

**Figure 21-50. Activity on McBSP Pins When XMCM=0b01**

In [Figure 21-50](#) if XMCM = 0b01, XPABLK = 0b00, and XCERA = 0b1010, only channels 1 and 3 are enabled and unmasked. Words W1 and W3 are written to the XB, then, from the XB, there are transferred by mcbspi\_dx.

**Figure 21-51. Activity on McBSP Pins When XMCM=0b10**

In [Figure 21-51](#) if XMCM = 0b10, XPABLK = 0b00, and XCERA = 0b1010, all channels are enabled, only 1 and 3 unmasked. Words W0, W1, W2, and W3 are written to the XB, but only W1 and W3, from the XB, there are transferred by mcbspi\_dx.

**Figure 21-52. Activity on McBSP Pins When XMCM=0b11**

mcbsp-047

In Figure 21-52 if XMCM = 0b11, RPABLK = 0b00, XPABLK = 0bX, RCERA = 0b1010 and XCERA = 0b1000, channels 1 and 3 are enabled in receive and transmit mode, but only 3 unmasked. Words W1 and W3 are written to the XB, but only W3, from the XB, there are transferred by mcbspi\_dx.

## **21.4.7 SIDETONE Mode (ALP)**

### **21.4.7.1 Introduction**

In multimedia-rich mobile communication devices, loopback signals from audio inputs to audio outputs are renamed. A traditional example is the telephone SIDETONE (that is, the telephone user expects to also hear his own voice in the earpiece).

Some of the features using the loopback have strict delay requirements.

It is required that two of the audio input channels be looped back, filtered, and mixed to the corresponding two audio output channels. The SIDETONE mode filters and applies gain to each sample received.

### **21.4.7.2 SIDETONE Interface**

The data from digital microphone, two (out of four) channels, can be configured to be input in the external SIDETONE core. After filtering, the data from digital microphone data is mixed and sent out to the speaker output channels using two (out of eight) configured output channels (separate configuration bits are used). The McBSP module synchronizes the incoming data (filtered by the external SIDETONE core). The transmit and receive part of the McBSP module are not required to operate on the same functional frequency.

The SIDETONE interface offers the following features:

- Send out two 24-bit data channels for the configured SIDETONE received channels (channels can be the same)
- Send out two control signals to indicate to the SIDETONE module that the data is valid (toggle signals which are changing the value from 0 to 1 or 1 to 0 each time a new data is available)
- Receive two 24-bit filtered data channels from the external SIDETONE module and send these channels to the configured transmit channels after mixing the data with the incoming data (from the L4 interface). The sum between the incoming data and SIDETONE loopback data is a saturated sum.
- Receive two control signals to indicate that the SIDETONE module filtered data is available (toggle signals which are changing the value from 0 to 1 or 1 to 0 each time a new data is available).

Figure 21-53 shows the SIDETONE external module data path:

**Figure 21-53. SIDETONE Data Path**



mcbsp-048

Before you enable a SIDETONE selection mode, make sure you properly configure the data frame for multichannel and SIDETONE mode:

- Select a single-phase frame (McBSPi.[MCBSPLP\\_RCR2\\_REG\[15\]](#) RPHASE bit and McBSPi.[MCBSPLP\\_XCR2\\_REG\[15\]](#) XPHASE bit=0). Each frame represents a TDM data stream.
- Set McBSPi.[MCBSPLP\\_MCR1\\_REG\[0\]](#) RMCM=1 to select multichannel mode enable.
- Set a frame length (in McBSPi.[MCBSPLP\\_RCR1\\_REG\[14:8\]](#) RFRLEN1 bit field and in McBSPi.[MCBSPLP\\_XCR1\\_REG\[14:8\]](#) XFRLEN1 bit field) that includes the highest-numbered channel to be used (a maximum of 4 channels can be used in this configuration).
- Set a word length (in McBSPi.[MCBSPLP\\_RCR1\\_REG\[7:5\]](#) RWDLEN1 bit field and in McBSPi.[MCBSPLP\\_XCR1\\_REG\[7:5\]](#) XWDLEN1 bit field) to be either 16, 24 or 32 (see note).
- Select the input/output channels configured as SIDETONE channels and enable SIDETONE by setting the McBSPi.[MCBSPLP\\_SSELCR\\_REG\[1:0\]](#) ICH0ASSIGN/McBSPi.[MCBSPLP\\_SSELCR\\_REG\[6:4\]](#) OCH0ASSIGN , McBSPi.[MCBSPLP\\_SSELCR\\_REG\[3:2\]](#) ICH1ASSIGN/McBSPi.[MCBSPLP\\_SSELCR\\_REG\[9:7\]](#) OCH1ASSIGN fields (2 out of 4 channels external SIDETONE assignment) and McBSPi.[MCBSPLP\\_SSELCR\\_REG\[10\]](#) SIDETONEEN bit to 1.

---

**NOTE:** Word width in the loop is 24 bits. If input channel word width is less than 24 bits, LSBs of the samples are zero padded. If input channel word width is more than 24 bits, samples are truncated.

---

Figure 21-54 describes the data exchange protocol between McBSP module and SIDETONE core:

**Figure 21-54. McBSP to SIDETONE Data Exchange**


mcbsp-049

[Figure 21-55 describes the data exchange protocol between SIDETONE core and McBSP module:](#)

**Figure 21-55. SIDETONE to McBSP Data Exchange**


mcbsp-050

**NOTE:** To use the same input channel as source for both SIDETONE output channels the McBSPi.MCBSPPLP\_SSELCR\_REG[1:0] ICH0ASSIGN should be equal to McBSPi.MCBSPPLP\_SSELCR\_REG[3:2] ICH1ASSIGN. The McBSP module does not support two input channels to be assigned to only one SIDETONE output channel.

#### 21.4.7.3 Data Processing Path

The SIDETONE core receives the data to be processed through two 24-bits parallel data interfaces, one for each audio channel. When enabled through McBSPi.[ST\\_SSELCR\\_REG\[0\]](#) SIDETONEEN bit-field, the module applies the filtering and gain functions to each data item (frame) and outputs it through two similar 24-bits parallel data interfaces.

[Figure 21-56 below describes how the data is sampled and output through the dedicated data interfaces.](#)

**Figure 21-56. SIDETONE Processed Data Interfaces**

**NOTE:** The processing time needed is 132 clock cycles (SIDETONE enabled). The total number of cycles needed for outputting the new processed data upon arrival of a sample is maximum 135 (including synchronizations). When not enabled, the data response takes maximum 5 clock cycles.

The ST\_CH0\_VALIDR and ST\_CH1\_VALIDR are 1 bit inputs and their toggling information is used to signal that new data is valid for sampling from ST\_CH0\_DATAR / ST\_CH1\_DATAR.

The ST\_CH0\_VALIDX and ST\_CH1\_VALIDX are 1 bit outputs and their toggling information is used to signal that new data is valid on the output data bus ST\_CH0\_DATAX / ST\_CH1\_DATAX.

#### 21.4.7.4 Data Processing

The processing consists in 2 stages filtering and applying gain to signal. The whole process takes 132 clock cycles.

If a new frame comes too early causing the interrupt assertion, the current frame will be completely processed and this new frame will be ignored. Consequent frames will also be ignored until the current frame processing has ended.

#### 21.4.7.4.1 Filtering

A 128 length FIR filter scheme is used. The module must process the two channels in parallel so two instances of filter will work in parallel sharing only the same coefficients.

Samples data are signed values in interval (-1..1) in Q23 format, negative values are expressed in 2's complement. Coefficients are also signed values in interval (-1..1) in Q15 format, negative values are expressed in 2's complement too.

The module handles overflows in the sums of the product but the user should choose the coefficients with the sum of magnitudes in absolute value is smaller than 1, otherwise the user must ensure that gain applying brings the samples value below |1|, to avoid saturation.

$$|C_0| + |C_1| + \dots + |C_{127}| < 1$$

#### CAUTION

The coefficients cannot be loaded while the filtering is active (SIDETONE enabled).

#### 21.4.7.4.2 Applying Gain

Each output sample will be multiplied with the gain value specified in the McBSPi.[ST\\_SGAINCR\\_REG](#). The gain is independent for each channel and can be modified anytime through L4-interface with immediate effect. Gain values are in the interval (-2..2) in Q1.14 format, negative values are expressed in 2's complement.

The user must choose the gain's value according to the magnitude of the samples to avoid overflow in the final product between the FIR data and gain value. If an overflow occurs, the output data is saturated.

#### 21.4.7.4.3 Enabling SIDETONE

When the SIDETONE operation is enabled (McBSPi.[ST\\_SSELCR\\_REG\[0\]](#) SIDETONEEN is 1), the module starts collecting samples received through the data interface without returning any sample or toggling any of the ST\_CH0/CH1\_VALIDX outputs. The first 127 samples for each channel are only accumulated, no processed data is provided. The first processed frame comes after receiving the 128th sample (with the specific delay).

When the SIDETONE operation is disabled, data is output through the data interface as it comes on the data input interface with the resynchronization latency of maximum 5 clock cycles. Re-enabling it requires waiting another 128 samples before providing new processed samples (each transition of McBSPi.[ST\\_SSELCR\\_REG\[0\]](#) SIDETONEEN from 0 to 1 triggers this initialization process).

---

**NOTE:** After reset, the McBSPi.[ST\\_SSELCR\\_REG\[0\]](#) SIDETONEEN bit is 0.

---

#### 21.4.7.4.4 FIR Accuracy

All the arithmetic inside the module is performed without any truncation/saturation until the last stage – the gain applying, where the result of the product between gain and FIR value is saturated to +/-1 if overflow occurs and the LSBs are truncated.

#### 21.4.7.5 Interrupt Operation

The SIDETONE core has a single interrupt line and a single event that may trigger the interrupt. The event (an error one) occurs when the input interface data rate overflows the processing ability of the module. As described in the data processing path section, the SIDETONE core completes a frame processing in 132 cycles. If the input frame rate for any channel exceeds 1 frame/132 x interface clock period while SIDETONE is enabled , the McBSPi.[ST\\_IRQSTATUS\\_REG\[0\]](#) OVRERROR bit in is set and, if McBSPi.[ST\\_IRQENABLE\\_REG\[0\]](#) OVRERRROREN bit is set to 1, the interrupt line is asserted.

## 21.5 McBSP Basic Programming Model

This section describes the programming model of typical McBSP module and SIDETONE core applications.

### 21.5.1 McBSP Core

#### CAUTION

For all descriptions in this section, the McBSPi.[MCBSPLP\\_XCCR\\_REG\[11\]](#) XFULL\_CYCLE bit and the McBSPi.[MCBSPLP\\_RCCR\\_REG\[11\]](#) RFULL\_CYCLE bit are their reset value (XFULL\_CYCLE bit=0 and RFULL\_CYCLE bit=1).

#### 21.5.1.1 McBSP Initialization Procedure

This procedure for reset/initialization can be applied in general when the Receiver or Transmitter has to be reset during its normal operation, and also when the Sample Rate Generator is not used for either operation.

Figure 21-57 shows the serial port initialization procedure for master mode.

**Figure 21-57. Flow Diagram of McBSP Initialization Procedure for Master Mode**



mcbsp-062

Alternatively, on write (step 1 or 4), the transmitter and receiver can be placed in or taken out of reset by modifying the McBSPi.MCBSPPLP\_SPCR2\_REG[0] XRST bit and the McBSPi.MCBSPPLP\_SPCR1\_REG[0] RRST bit, respectively.

Figure 21-58 shows the flow diagram of the McBSP initialization procedure for slave mode.

**Figure 21-58. Flow Diagram of McBSP Initialization Procedure for Slave Mode**

mcbsp-074

**NOTE:**

- The necessary duration of the active-low period of XRST or RRST is at least two CLKR/CLKX cycles.
- The appropriate bits in serial port configuration registers (McBSPi.[MCBSPLP\\_SPCR1\\_REG](#), McBSPi.[MCBSPLP\\_SPCR2\\_REG](#), McBSPi.[MCBSPLP\\_PCR\\_REG](#), McBSPi.[MCBSPLP\\_RCR1\\_REG](#), McBSPi.[MCBSPLP\\_RCR2\\_REG](#), McBSPi.[MCBSPLP\\_XCR1\\_REG](#), McBSPi.[MCBSPLP\\_XCR2\\_REG](#), McBSPi.[MCBSPLP\\_THRSH2\\_REG](#), McBSPi.[MCBSPLP\\_XCCR\\_REG](#), McBSPi.[MCBSPLP\\_SYSCONFIG\\_REG](#), McBSPi.[MCBSPLP\\_SRGR1\\_REG](#), and McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)) should only be modified when the affected portion of the serial port is in its reset state.
- In most cases, the data transmit register (McBSPi.[MCBSPLP\\_DXR\\_REG](#)) should be loaded by the MPU/IVA2 subsystem or the sDMA controller only when the transmitter is enabled (McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[0] XRST = 1). An exception to this rule is when these registers are used for loopback internal data.
- The bits of the channel control registers (McBSPi.[MCBSPLP\\_MCR1\\_REG](#), McBSPi.[MCBSPLP\\_MCR2\\_REG](#), McBSPi.[MCBSPLP\\_RCER{A-H}\\_REG](#) and McBSPi.[MCBSPLP\\_XCER{A-H}\\_REG](#)) can be modified at any time as long as they are not being used by the current reception/transmission in a multichannel selection mode.
- The SRG is reset by setting McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[6] GRST bit to 0.
- It is not necessary to wait if SRG is not used.
- Modification on-the-fly has no effect if a reset is not done first.

### **21.5.1.2 Reset and Initialization Procedure for the Sample Rate Generator**

To reset and initialize the Sample Rate Generator:

- Place the McBSP Sample Rate Generator in RESET.

During a Global RESET, the Sample Rate Generator, the Receiver, and the Transmitter reset bits (GRST, RRST, and XRST) are automatically forced to '0'. Otherwise, during normal operation, the Sample Rate Generator can be reset by making McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[6] GRST=0, provided that CLKG and/or FSG internal signal is not used by any portion of the McBSP module. Depending on the system needs, the software may also to reset the Receiver (McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[0] RRST=0) and reset the Transmitter (McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[0] XRST bit =0).

- Program the registers that affect the Sample Rate Generator.

Program the Sample Rate Generator registers (McBSPi.[MCBSPLP\\_SPCR1\\_REG](#) and McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)) as required for your application. Refer to [Figure 21-59](#).

If necessary, other control registers can be loaded with desired values provided the respective portion of the McBSP module (the Receiver or Transmitter) is in reset. [Table 21-24](#) presents the McBSP configuration when one of the clock sources is selected, but others registers can be impacted in function of the user application.

**Table 21-24. McBSP Configuration in Function of the SRG Clock Source Selected**

| SRG Clock Source Selected | Module Configuration                  | McBSPi. <a href="#">MCBSPLP_PCR_REG</a> Configuration |           |                         |          |
|---------------------------|---------------------------------------|-------------------------------------------------------|-----------|-------------------------|----------|
|                           |                                       | CLKRM bit <sup>(1)</sup>                              | CLKXM bit | FSRM bit <sup>(1)</sup> | FSXM bit |
| McBSPi_ICLK or CLKS       | Master Transmitter and Slave Receiver | 0                                                     | 1         | 0                       | 1        |
|                           | Master Receiver and Slave Transmitter | 1                                                     | 0         | 1                       | 0        |
|                           | Master Transmitter and Receiver       | 1                                                     | 1         | 1                       | 1        |
| CLKR                      | Master Transmitter and Slave Receiver | 0                                                     | 1         | 0                       | 1        |
| CLKX                      | Master Receiver and Slave Transmitter | 1                                                     | 0         | 1                       | 0        |

<sup>(1)</sup> This configuration is correct if McBSPi.[MCBSPLP\\_XCCR\\_REG](#)[5] DLB bit=0x0. When the DLB bit is set to 1, the CLKR clock (not the mcbspi\_clk pin) is driven by the CLKX clock, which is based on the CLKXM bit.

After the Sample Rate Generator registers are programmed, wait for 2 CLKSRG cycles. This ensures proper synchronization internally.

- Enable the Sample Rate Generator (take it out of reset).

Set McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[6] GRST bit to1 to enable the Sample Rate Generator.

After the Sample Rate Generator is enabled, wait for 2 CLKG cycles for the Sample Rate Generator logic to stabilize.

On the next rising edge of CLKSRG, the CLKG signal transitions to '1' and starts clocking with a frequency equal to (input clock frequency)/(CLKGDV + 1).

- If necessary, enable the receiver and/or the transmitter.

If necessary, remove the receiver and/or transmitter from reset by setting McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[0] RRST bit and/or McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[0] XRST =1.

**Figure 21-59. Flow Diagram for the SRG Registers Programmation**


mcbsp-073

The input clock is selected with the McBSPi.[MCBSPLP\\_PCR\\_REG\[7\]](#) SCLKME bit and the McBSPi.[MCBSPLP\\_SRGR2\\_REG\[13\]](#) CLKSM bit in one of the following configurations (see [Table 21-25](#)):

**Table 21-25. Input Clock Selection for Sample Rate Generator**

| SCLKME bit | CLKSM bit | Input Clock for Sample Rate Generator |
|------------|-----------|---------------------------------------|
| 0          | 0         | Signal on mcbsp_clks pin              |
| 0          | 1         | McBSPi_ICLK clock                     |
| 1          | 0         | Signal on mcbsp_clk pin               |
| 1          | 1         | Signal on mcbsp_clkx pin              |

### 21.5.1.3 Data Transfer DMA Request Configuration

To configure the McBSP receive/transmit data DMA requests (McBSPi\_DMA\_RX and McBSPi\_DMA\_TX), perform the following procedure:

- Write the receive McBSPi.[MCBSPLP\\_THRESHOLD1\\_REG](#) register with the required receive DMA request length (the length of the transfer is the same as the threshold value + 1). As long as the RB occupied locations level is above or equal to the THRSH1\_REG value + 1, the DMA request will be asserted. After transferring the configured THRSH1\_REG value + 1 number of words, the receive DMA request will be de-asserted and reasserted as soon as the conditions are met again.

---

**NOTE:** In case of a number of transfers that exceed the number of the programmed DMA length the McBSP module will respond to the command, and will perform the transfer regardless of the receive buffer empty condition. When the receive buffer is empty a data transfer access will trigger a receive underflow interrupt, if enabled by McBSPi.[MCBSPLP\\_IRQENABLE\\_REG\[4\]](#) RUNDLEN bit.

- Write the transmit McBSPi.[MCBSPLP\\_THRESHOLD2\\_REG](#) register with the required transmit DMA request length (the length of the transfer is the same as the threshold value + 1). As long as the XB free locations level is above or equal to the THRSH2\_REG value + 1, the DMA request will be asserted. After transferring the configured THRSH2\_REG value + 1 number of words, the transmit DMA request will be de-asserted and reasserted as soon as the conditions are met again.

---

**NOTE:** In case of a number of transfers that exceed the number of the programmed DMA length the McBSP module will respond to the command, and will perform the transfer regardless of the transmit buffer full condition. When the transmit buffer is full a data transfer access will trigger a transmit overflow interrupt, if enabled by McBSPi.[MCBSPLP\\_IRQENABLE\\_REG\[12\]](#) XOVFLEN bit.

### 21.5.1.4 Interrupt Configuration

The McBSP module offers two interrupt schemes:

- L4 compliant interrupt request scheme using a common receive/transmit interrupt request line
- The legacy interrupt compliant scheme using 3 interrupt lines: one for receive, one for transmit and the common interrupt line.

#### 21.5.1.4.1 L4-Compliant Interrupt Line

The L4-compliant interrupt line can be configured by using the McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#) register. When the McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#) bit is set and the corresponding McBSPi.[MCBSPLP\\_IRQENABLE\\_REG](#) bit is set to one, the interrupt line is asserted. Writing one to a bit in McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#) register clears the bit.

There are several conditions, which can be configured to generate an interrupt as follows:

- Transmit buffer empty at end of frame (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG\[14\]](#) XEMPTYEOF bit is set to one when a complete frame was transmitted and the transmit buffer is empty).
- Transmit buffer overflow (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG\[12\]](#) XOVFLSTAT bit is set to one when transmit buffer overflow; the data written while overflow condition is discarded).
- Transmit buffer underflow (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG\[11\]](#) XUNDFLSTAT bit is set to one

- when the transmit data buffer is empty, new data needs to be transmitted).
4. Transmit buffer threshold reached (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[10] XRDY bit is set to one when the transmit buffer free locations are equal or above the [THRSH2\_REG + 1] value).
  5. Transmit end of frame (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[9] XEOF is set to one when a complete frame was transmitted).
  6. Transmit frame synchronization (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[8] XFSX bit is set to one when a new transmit frame synchronization is asserted).
  7. Transmit frame synchronization Error (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[7] XSYNCERR is set to one when a transmit frame synchronization error is detected).
  8. Receive buffer overflow (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[5] ROVFLSTAT bit is set to one when receive buffer overflow; the data which is written while overflow condition is discarded).
  9. Receive buffer underflow (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[4] RUNDLSTAT bit is set to one when read operation is performed to the receive data register while receive buffer is empty; data read while underflow condition is undefined).
  10. Receive buffer threshold Reached (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[3] RRDY bit is set to one when the receive buffer occupied locations are equal or above the [THRSH1\_REG + 1] value).
  11. Receive end of frame (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[2] REOF is set to one when a complete frame was received).
  12. Receive frame synchronization (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[1] RFSR bit is set to one when a new receive frame synchronization is asserted).
  13. Receive frame synchronization error (McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#)[0] RSYNCERR is set to one when a receive frame synchronization error is detected).

#### **21.5.1.4.2 Legacy Interrupt Line**

McBSPi\_IRQ\_TX and McBSPi\_IRQ\_RX are legacy interrupts. Not to be used for new development. McBSPi\_IRQ (common interrupt line) should be preferred.

##### **21.5.1.4.2.1 Set the receive interrupt line (legacy only)**

The McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[5:4] RINTM bit field determines which event generates a receive interrupt request, McBSPi\_IRQ\_RX, to the MPU/IVA2.2 subsystem.

The receive interrupt informs the MPU/IVA2.2 subsystem of changes to the serial port status. Four options exist for configuring this interrupt.

- RINTM=0b00: The receive interrupt generated when the McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[1] RRDY bit changes from 0 to 1. Interrupt on every serial word by tracking the McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[1] RRDY bit. Regardless of the value of RINTM, RRDY bit can be read to detect the RRDY=1 condition.
- RINTM = 0b01: The receive interrupt generated by an end-of-frame condition in the receive multichannel selection mode. In any other serial transfer case, this setting is not applicable and, therefore, no interrupts are generated.
- RINTM = 0b10: The receive interrupt generated by a new receive frame-synchronization pulse. Interrupt on detection of receive frame-synchronization pulses. This generates an interrupt even when the receiver is in its reset state. This is done by synchronizing the incoming frame-synchronization pulse to the McBSPi\_ICLK clock and sending it to the MPU/IVA2.2 subsystem via the receive interrupt .
- RINTM = 0b11: The receive interrupt generated when McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[3] RSYNCERR is set. Interrupt on frame-synchronization error. Regardless of the value of RINTM, RSYNCERR can be read to detect this condition. For information on using RSYNCERR, see [Section 21.4.4.3](#).

The McBSP module also provides a common interrupt line McBSPi\_IRQ, which can be used by setting the McBSPi.MCBSPLP\_IRQENABLE register. All the above settings have equivalent enable bits in the McBSPi.MCBSPLP\_IRQENABLE register to enable the common interrupt line:

- RRDYEN is equivalent with RINTM = 0 setting

- REOFEN is equivalent with RINTM = 0b01 setting (the interrupt is generated by an end-of-frame condition regardless of the multichannel selection mode)
- RFSREN is equivalent with RINTM = 0b10 setting
- RSYNCERREN is equivalent with RINTM = 0b11 setting

This interrupt line has its own status register, McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#).

#### **21.5.1.4.2.2 Set the transmit interrupt line (legacy only)**

The McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[5:4] XINTM bit field determines which event generates a transmit interrupt request (McBSPi\_IRQ\_TX) to the MPU/IVA2.2 subsystem.

The transmit interrupt informs the MPU/IVA2.2 subsystem of changes to the serial port status. Four options exist for configuring this interrupt.

- XINTM = 0b00: The transmit interrupt generated when the McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[1] XRDY bit changes from 0 to 1. Interrupt on every serial word by tracking the XRDY bit. Regardless of the value of XINTM, XRDY bit can be read to detect the XRDY=1 condition.
- XINTM = 0b01: The transmit interrupt generated by an end-of-frame condition in the transmit multichannel selection mode. In any other serial transfer case, this setting is not applicable and, therefore, no interrupts are generated.
- XINTM = 0b10: The transmit interrupt generated by a new transmit frame-synchronization pulse. Interrupt on detection of transmit frame-synchronization pulses. This generates an interrupt even when the transmitter is in its reset state. This is done by synchronizing the incoming frame-synchronization pulse to the McBSPi\_ICLK clock and sending it to the MPU/IVA2.2 subsystem via transmit interrupt.
- XINTM = 0b11: The transmit interrupt generated when McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[3] XSYNCERR is set. Interrupt on frame-synchronization error. Regardless of the value of XINTM, XSYNCERR bit can be read to detect this condition. For information on using XSYNCERR bit, see [Section 21.4.4.6](#).

The McBSP module provides also a common interrupt line McBSPi\_IRQ, which can be used by setting the McBSPi.MCBSPLP\_IRQENABLE register. All the above settings have equivalent enable bits in the McBSPi.MCBSPLP\_IRQENABLE register to enable the common interrupt line:

- XDYEN is equivalent with XINTM = 0b00 setting
- XEOFEN is equivalent with XINTM = 0b01 setting (the interrupt is generated by an end-of-frame condition regardless of the multichannel selection mode)
- XFSXEN is equivalent with XINTM = 0b10 setting
- XSYNCERREN is equivalent with XINTM = 0b11 setting

This interrupt line has its own status register, McBSPi.[MCBSPLP\\_IRQSTATUS\\_REG](#).

#### **21.5.1.5 Receiver Configuration**

To configure the McBSP receiver, perform the following procedure:

1. Place the McBSP receiver in reset .
2. Program the McBSP registers for the desired receiver operation.
3. Take the receiver out of reset.

These 3 steps are detailed in the following subsections.

##### **21.5.1.5.1 Resetting (Step 1) and Enabling (Step 3) the Receiver**

The first step of the receiver configuration procedure is to reset the receiver, and the last step is to enable the receiver (to take it out of reset).

The serial port can be reset in the following 2 ways:

1. A global reset places the receiver, transmitter, and SRG in reset. When the device reset is removed, McBSPi.MCBSPPLP\_SPCR2\_REG[6] GRST, McBSPi.MCBSPPLP\_SPCR2\_REG[7] FRST, McBSPi.MCBSPPLP\_SPCR1\_REG[0] RRST and McBSPi.MCBSPPLP\_SPCR2\_REG[0] XRST bits = 0, which keeps the entire serial port in the reset state.
2. The serial port receiver can be reset directly using the McBSPi.MCBSPPLP\_SPCR1\_REG[0] RRST bit. If the SRG needs to be used, SRG must be reset directly using the McBSPi.MCBSPPLP\_SPCR2\_REG[6] GRST bit. Similar operations with frame synchronization generator also require using the McBSPi.MCBSPPLP\_SPCR2\_REG[7] FRST bit when the frame-sync signal must be generated.

To enable the receiver, the preceding bits, cleared to 0, must be set to 1.

#### **21.5.1.5.2 Programming the McBSP Registers for the Desired Receiver Configuration (Step 2)**

Figure 21-60 and Figure 21-61 lists important tasks to be performed when the software is configuring the McBSP receiver. Each task corresponds to one or more McBSP register bit fields.

**Figure 21-60. Important Tasks to Configure the McBSP Receiver (Part 1)**



mcbsp-063

**Figure 21-61. Important Tasks to Configure the McBSP Receiver (Part 2)**

mcbsp-064

### 21.5.1.5.2.1 Global Behavior

#### 21.5.1.5.2.1.1 Set the Receiver Pins to Operate as McBSP Pins

The McBSPi.[MCBSPLP\\_PCR\\_REG](#)[12] RIOEN bit determines whether the receiver pins are McBSP pins (RIOEN bit=0) or general-purpose I/O pins (RIOEN bit=1).

See [Section 21.5.1.7](#) which describes how to use McBSP pins as GPIO pins.

#### 21.5.1.5.2.1.2 Enable/Disable the Digital Loop Back Mode

The McBSPi.[MCBSPLP\\_XCCR\\_REG](#)[5] DLB bit determines whether the digital loopback mode is on or off.

In the digital loopback mode, the receive signals are connected internally through multiplexers to the corresponding transmit signals:

- DR signal is connected on DX signal to receive the transmitted data
- FSR is connected to FRX output signal
- CLKR is connected to the CLKX output signal

This mode allows testing of serial port; the McBSP module receives the data it transmits. This loopback mode is not done through pads, all output signals being disabled.

**NOTE:** That in digital loopback mode the SRG and the frame synchronization generator need to be enabled to generate the CLKX and FSX signals.

#### 21.5.1.5.2.1.3 Enable/Disable the Analog Loopback Mode

The McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[15] ALB bit determines whether the analog loopback mode is on or off.

In the analog loopback mode, the receive signals are connected internally through multiplexers to the corresponding transmit loop back signals:

- DR is connected to transmit loop back data on DX input pin
- FSR is connected to FRX input pin
- CLKR is connected to the CLKX input pin

This Analog Loopback mode is also done to test the Input/Output buffers, through pads.

#### 21.5.1.5.2.1.4 Enable/disable the synchronous transmit-receive mode (McBSP1 only)

The control registers of the System Control Module is used to configure the synchronous transmit-receive mode.

The MCBSP1\_CLKR bit of the CONTROL\_DEVCONF0[3] register is used to select the McBSP1 module CLKR signal source:

- When set to '0', the CLKR source is from the CLKR input signal
- When set to '1', the CLKR source is from the CLKX input signal

The MCBSP1\_FSR bit of the CONTROL\_DEVCONF0[4] register is used to select the McBSP1 module FSR signal source:

- When set to '0', the FSR source is from the FSR input signal
- When set to '1', the FSR source is from the FSX input signal

#### 21.5.1.5.2.1.5 Enable/Disable the Receive Multichannel Selection Mode

The McBSPi.[MCBSPLP\\_MCR1\\_REG](#)[0] RMCM bit determines whether the receive multichannel selection mode is on or off.

For further details, see [Section 21.4.6.5](#).

#### 21.5.1.5.2.2 Data Behavior

##### 21.5.1.5.2.2.1 Choose 1 or 2 Phases for the Receive Frame

The McBSPi.[MCBSPLP\\_RCR2\\_REG](#)[15] RPHASE bit determines whether the receive data frame has one (Single phase) or two phases (Dual phase). When dual-phase is selected the number of words per phase must be set to one.

##### 21.5.1.5.2.2.2 Set the Receive Word Length(s)

The McBSPi.[MCBSPLP\\_RCR1\\_REG](#)[7:5] RWDLEN1 and McBSPi.[MCBSPLP\\_RCR2\\_REG](#)[7:5] RWDLEN2 bit fields determine how many bits are in each serial word in phase 1 and in phase 2, respectively, of the receive data frame.

If a single-phase frame is selected, RWDLEN1 selects the length for every serial word received in the frame.

If a dual-phase frame is selected, RWDLEN1 and RWDLEN2 must be set to select the both length. These both bits can have values different.

### 21.5.1.5.2.2.3 Set the Receive Frame Length

The receive frame length is the number of serial words in the receive frame.

The McBSPi.[MCBSPLP\\_RCR1\\_REG\[14:8\]](#) RFRLEN1 and McBSPi.[MCBSPLP\\_RCR2\\_REG\[14:8\]](#) RFRLEN2 bit fields determine how many serial words are in phase 1 and in phase 2, respectively, of the receive data frame.

If a dual-phase frame is selected (RPHASE=1), the frame length must be two words (one word for phase 1 plus the one word for phase 2). Others values must not be used.

The 7-bit RFRLEN1 field allows up to 128 words per phase when single-phase frame. See [Table 21-26](#) below for a summary of how to calculate the frame length. This length corresponds to the number of words or logical time slots or channels per frame-synchronization pulse.

Program the RFRLEN fields with [W - 1], where W represents the number of words per phase. For example, to get a phase length of 128 words in phase 1, load 127 words into RFRLEN1.

**Table 21-26. How to Calculate the Length of the Receive Frame**

| RPHASE | RFRLEN1           | RFRLEN2     | Frame Length             |
|--------|-------------------|-------------|--------------------------|
| 0      | 0 ≤ RFRLEN1 ≤ 127 | Don't care  | (RFRLEN1 value +1) words |
| 1      | RFRLEN1 = 0       | RFRLEN2 = 0 | 2 words                  |

### 21.5.1.5.2.2.4 Set the Receive Reverse Mode

The McBSPi.[MCBSPLP\\_RCR2\\_REG\[4:3\]](#) RREVERSE bit field determines whether reverse (LSB first) data transfer option is chosen for McBSP reception.

For further information about reverse mode, see [Section 21.4.2.2](#).

### 21.5.1.5.2.2.5 Set the Receive Data Delay

The McBSPi.[MCBSPLP\\_RCR2\\_REG\[1:0\]](#) RDATDLY bit field determines the length of the data delay for the receive frame.

The start of a frame is defined by the first clock cycle in which frame synchronization is active. The beginning of actual data reception or transmission with respect to the start of the frame can be delayed if required. This delay is called data delay.

McBSPi.[MCBSPLP\\_RCR2\\_REG\[1:0\]](#) RDATDLY specifies the data delay for reception. The range of programmable data delay is zero to two bit-clocks (RDATDLY = 0b00–0b10), as shown in [Figure 21-62](#) below. In this figure, the data transferred is an 8-bit value with bits labeled B7, B6, B5, and so on. Typically a 1-bit delay is selected, because data often follows a 1-cycle active frame-synchronization pulse.

**Figure 21-62. Range of Programmable Data Delay**



### 21.5.1.5.2.2.5.1 0-Bit Data Delay

Normally, a frame-synchronization pulse is detected or sampled with respect to an edge of internal serial clock CLK(R/X). Thus, on the following cycle or later (depending on the data delay value), data may be received or transmitted. However, in the case of 0-bit data delay, the data must be ready for reception and/or transmission on the same serial clock cycle.

For reception, this problem is solved because receive data is sampled on the first falling edge of CLKR where an active-high internal FSR is detected. However, data transmission must begin on the rising edge of the internal CLKX clock that generated the frame synchronization. Therefore, the first data bit is assumed to be present in XSR, and thus on mcbsp\_dx. The transmitter then asynchronously detects the frame-synchronization signal (FSX) going active high and immediately starts driving the first bit to be transmitted on the mcbsp\_dx pin.

### 21.5.1.5.2.2.5.2 2-Bit Data Delay

A data delay of two bit periods allows the serial port to interface to different types of T1 framing devices where the data stream is preceded by a framing bit. During reception of such a stream with data delay of two bits (framing bit appears after a 1-bit delay and data appears after a 2-bit delay), the serial port essentially discards the framing bit from the data stream, as shown in [Figure 21-63](#). In this figure, the data transferred is an 8-bit value with bits labeled B7, B6, B5, and so on.

**Figure 21-63. 2-Bit Data Delay Used to Skip a Framing Bit**



mcbsp-053

### 21.5.1.5.2.2.6 Set the Receive Sign-Extension and Justification Mode

The McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[14:13] RJUST bit field determines whether data received by the McBSP module is sign-extended or not and how it is justified.

RJUST bit selects whether data in RB is right- or left-justified (with respect to the MSB) in McBSPi.[MCBSPLP\\_DRR\\_REG](#) register and whether unused bits in McBSPi.[MCBSPLP\\_DRR\\_REG](#) are filled with zeroes or with sign bits.

[Table 21-27](#) and [Table 21-28](#) show the effects of various RJUST values; the effect on an example 12-bit receive-data value 0xABC, and the effect on an example 20-bit receive-data value 0ABCDE, respectively.

**Table 21-27. Example: Use of RJUST Bit Field With 12-bit Data Value 0xABC**

| RJUST | Justification | Extension                  | Value in DRR_REG |
|-------|---------------|----------------------------|------------------|
| 0b00  | Right         | Zero fill MSBs             | 0x0000 0ABC      |
| 0b01  | Right         | Sign extend data into MSBs | 0xFFFF FABC      |
| 0b10  | Left          | Zero fill LSBs             | 0xABCO 0000      |
| 0b11  | Reserved      | Reserved                   | Reserved         |

**Table 21-28. Example: Use of RJUST Bit Field With 20-bit Data Value 0xABCD E000**

| RJUST | Justification | Extension                  | Value in DRR_REG |
|-------|---------------|----------------------------|------------------|
| 0b00  | Right         | Zero fill MSBs             | 0x000A BCDE      |
| 0b01  | Right         | Sign extend data into MSBs | 0xFFFF BCDE      |
| 0b10  | Left          | Zero fill LSBs             | 0xABCD E000      |

**Table 21-28. Example: Use of RJUST Bit Field With 20-bit Data Value 0xABCD (continued)**

| RJUST | Justification | Extension | Value in DRR_REG |
|-------|---------------|-----------|------------------|
| 0b11  | Reserved      | Reserved  | Reserved         |

### 21.5.1.5.2.2.7 Set the Receive Interrupt Mode

Please refer to [Section 21.5.1.4.2.1](#).

### 21.5.1.5.2.2.8 Set the Receive DMA Mode

The McBSP receive-data DMA requests (McBSPi\_DMA\_RX) are active after the McBSPi.[MCBSPLP\\_SPCR1\\_REG](#) [0] RRST bit is released. After reset, the default DMA threshold (and length) is 1.

The receive DMA requests can be disabled by setting the McBSPi.[MCBSPLP\\_RCCR\\_REG](#)[3] RDMAEN bit to 0. When disabling the DMA, the DMA request line is deasserted even if a DMA transfer is pending, and the DMA state-machine is not reset.

To configure the McBSP receive data DMA requests, perform the following:

- Write the receive McBSPi.[MCBSPLP\\_THRSH1\\_REG](#) register with the required receive DMA request length (the length of the transfer is the same as the threshold value + 1).
- As long as the occupied locations level in the RB is above or equal to the THRSH1\_REG value + 1, the DMA request is asserted.
- After transferring the configured (THRSH1\_REG value + 1) number of words, the receive DMA request is deasserted, and then reasserted as soon as the conditions are met again.

### 21.5.1.5.2.3 Frame-Sync Behavior

#### 21.5.1.5.2.3.1 Set the Receive Frame-Sync Mode

McBSPi.[MCBSPLP\\_PCR\\_REG](#)[10] FSRM bit, McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)[15] GSYNC bit, McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[15] ALB bit and McBSPi.[MCBSPLP\\_XCCR\\_REG](#)[5] DLB bit field are used to determine the source for receive frame synchronization and the function of the mcbsp\_fsr pin.

[Table 21-29](#) below shows how you can select various sources to provide the receive frame-synchronization signal and the effect on the mcbsp\_fsr pin. The polarity of the signal on the mcbsp\_fsr pin is determined by the McBSPi.[MCBSPLP\\_PCR\\_REG](#)[2] FSRP bit.

**Table 21-29. FSRM and GSYNC Effects on Frame-Sync Signal and mcbsp\_fsr Pin**

| FSRM | GSYNC  | Source of Receive Frame Synchronization                                                                                                                                              | MCBSPLP.FSR Pin Status                                                                                                    |
|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| 0    | 0 or 1 | An external frame synchronization signal enters the McBSP module through the mcbsp_fsr pin. The signal is then inverted as determined by FSRP bit before being used as internal FSR. | Input                                                                                                                     |
| 1    | 0      | Internal FSR is driven by the SRG frame-synchronization signal (FSG).                                                                                                                | Output. FSG is inverted as determined by FSRP bit before being driven out on the mcbsp_fsr pin.                           |
| 1    | 1      | Internal FSR is driven by the SRG frame-synchronization signal (FSG).                                                                                                                | Input. The external frame-synchronization input on the mcbsp_fsr pin is used to synchronize CLKG and generate FSG pulses. |

In digital loop-back mode (DLB=1), the transmit frame-synchronization signal is used as the receive frame-synchronization signal.

Also in the analog loop back mode (ALB=1), the internal receive clock signal (CLKR), and the internal receive frame-synchronization signal (FSR) are internally connected to their transmit counterparts, CLKX and FSX.

For more details on clock and frame-sync configuration, see [Section 21.4.3](#).

#### **21.5.1.5.2.3.2 Set the Receive Frame-Sync Polarity**

The McBSPi.[MCBSPLP\\_PCR\\_REG](#)[2] FSRP bit determines whether frame-synchronization pulses are active high or active low on the mcbsp\_fsr pin.

Receive frame-synchronization pulses can be generated internally by the SRG or driven by an external source. The source of frame synchronization is selected by programming the McBSPi.[MCBSPLP\\_PCR\\_REG](#)[10] FSRM bit. FSR is also affected by the McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)[15] GSYNC bit. For information about the effects of FSRM and GSYNC, see [Section 21.5.1.5.2.3.1, Set the Receive Frame-Sync Mode](#).

When FSR and FSX are inputs (FSXM = FSRM = 0, external frame-synchronization pulses), the McBSP module detects them on the internal falling edge of clock, internal CLKR, and internal CLKX, respectively. The receive data arriving at the mcbspi\_dr pin is also sampled on the falling edge of internal CLKR. These internal clock signals are either derived from an external source via CLK(R/X) pins or driven by the SRG clock (CLKG) internal to the McBSP module.

When FSR and FSX are outputs, implying that they are driven by the SRG, they are generated (transition to their active state) on the rising edge of the internal clock, CLK(R/X). Similarly, data on the mcbsp\_dx pin is output on the rising edge of internal CLKX.

FSRP, FSXP, CLKRP, and CLKXP bit fields in the pin control register (McBSPi.[MCBSPLP\\_PCR\\_REG](#)) configure the polarities of the FSR, FSX, CLKR, and CLKX signals, respectively. All frame-synchronization signals (internal FSR, internal FSX) that are internal to the serial port are active high. If the serial port is configured for external frame synchronization (FSR/FSX are inputs to McBSP), and FSRP = FSXP = 1, the external active-low frame-synchronization signals are inverted before being sent to the receiver (internal FSR) and transmitter (internal FSX). Similarly, if internal synchronization (FSR/FSX are output pins and GSYNC = 0) is selected, the internal active-high frame-synchronization signals are inverted, if the polarity bit FS(R/X)P = 1, before being sent to the FS(R/X) pin.

[Figure 21-64](#) shows how data clocked by an external serial device using a rising edge can be sampled by the McBSP receiver on the falling edge of the same clock.

**Figure 21-64. Data Externally Clocked on a Rising Edge and Sampled on a Falling Edge**



mcbsp-054

#### **21.5.1.5.2.3.3 Set the SRG Frame-Sync Period and Pulse Width**

The SRG can produce a clock signal, CLKG, and FSG. If the SRG is supplying receive or transmit frame synchronization, you must program the bit fields FPER and FWID.

McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)[11:0] FPER bit field is used to set the SRG frame-sync period and McBSPi.[MCBSPLP\\_SRGR1\\_REG](#)[15:8] FWID bit field is used to set the SRG pulse width.

On FSG, the period from the start of a frame-synchronization pulse to the start of the next pulse is (FPER+1) CLKG cycles. The 12 bits of FPER allow a frame-synchronization period of 1 to 4096 CLKG cycles, which allows up to 4096 data bits per frame. When GSYNC=1, FPER is a don't care value.

Each pulse on FSG has a width of (FWID+1) CLKG cycles. The eight bits of FWID allow a pulse width of 1 to 256 CLKG cycles. It is recommended that FWID be programmed to a value less than the programmed word length.

The values in FPER and FWID are loaded into separate down-counters. The 12-bit FPER counter counts down the generated clock cycles from the programmed value (4095 maximum) to 0. The 8-bit FWID counter counts down from the programmed value (255 maximum) to 0.

Figure 21-65 shows a frame-synchronization period of 16 CLKG periods (FPER=15 or 00001111b) and a frame-synchronization pulse with an active width of 2 CLKG periods (FWID=1).

**Figure 21-65. Frame of Period 16 CLKG Periods and Active Width of 2 CLKG Periods**



When the SRG comes out of reset, FSG is in its inactive state. Then, when GRST=1 and FSGM=1, a frame-synchronization pulse is generated. The frame width value (FWID+1) is counted down on every CLKG cycle until it reaches 0, at which time FSG goes low. At the same time, the frame period value (FPER+1) is also counting down. When this value reaches 0, FSG goes high, indicating a new frame.

#### 21.5.1.5.2.4 Clock Behavior

##### 21.5.1.5.2.4.1 Set the receive clock mode

McBSPi.MCBSPLP\_PCR\_REG[8] CLKRM bit, McBSPi.MCBSPLP\_SPCR1\_REG[15] ALB bit and McBSPi.MCBSPLP\_XCCR\_REG[5] DLB bit are used to set the receive clock mode.

Table 21-30 shows how to select various sources to provide the receive clock signal and affect the mcbsp\_clk pin. The McBSPi.MCBSPLP\_PCR\_REG[0] CLKRP bit determines the polarity of the signal on the mcbsp\_clk pin.

**Table 21-30. CLKRM Effect on Receive Clock Signal and mcbsp\_clk Pin**

| CLKRM | Source of Receive Clock                                                                                                                        | mcbsp_clk Pin Status                                                               |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| 0     | The mcbsp_clk pin is an input driven by an external clock. The external clock signal is inverted as determined by CLKRP bit before being used. | Input                                                                              |
| 1     | The SRG clock (CLKG) drives internal CLKR.                                                                                                     | Output. CLKG, inverted as determined by CLKRP, is driven out on the mcbsp_clk pin. |

In the digital loop-back mode (DLB = 1) or analog loop-back mode (ALB = 1), the transmit clock signal is used as the receive clock signal. For more details on clock configuration, see [Section 21.4.3.1](#).

##### 21.5.1.5.2.4.2 Set the Receive Clock Polarity

McBSPi.MCBSPLP\_PCR\_REG[0] CLKRP bit is used to set the receive clock polarity.

The receive clock polarity bit, CLKRP, sets the edge used to sample received data. The receive data is always sampled on the falling edge of internal CLKR. Therefore, if CLKRP = 1 and external clocking is selected (CLKRM = 0 and CLKR is an input pin), the external rising-edge triggered input clock on CLKR is inverted to a falling-edge triggered clock before being sent to the receiver. If CLKRP = 1 and internal clocking is selected (CLKRM = 1), the internal falling-edge triggered clock is inverted to a rising-edge triggered clock before being sent out on the mcbsp\_clk pin.

---

**NOTE:** CLKRP = CLKXP in a system where the same clock (internal or external) is used to clock the receiver and transmitter. The receiver uses the opposite edge as the transmitter to ensure valid setup and hold of data around this edge.

---

#### 21.5.1.5.2.4.3 Set the SRG Clock Divide-Down Value

McBSPi.[MCBSPLP\\_SRGR1\\_REG](#)[7:0] CLKGDV bit field is used to set the SRG clock divide-down value.

The first divider stage generates the serial data bit clock from the input clock. This divider stage utilizes a counter, preloaded by CLKGDV, that contains the divide ratio value.

The output of the first divider stage is the data bit clock, which is output as CLKG and which serves as the input for the second and third stages of the divider.

CLKG has a frequency equal to  $1/(CLKGDV + 1)$  of SRG input clock. Thus, the sample generator input clock frequency is divided by a value between 1 and 256. The CLKG duty cycle is 50 percent.

#### 21.5.1.5.2.4.4 Set the SRG Clock Synchronization Mode

McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)[15] GSYNC bit is used to set the SRG clock synchronization mode.

For more information about the clock synchronization feature, see [Section 21.4.3](#).

#### 21.5.1.5.2.4.5 Set the SRG Clock Mode (Choose an Input Clock)

McBSPi.[MCBSPLP\\_PCR\\_REG](#)[7] SCLKME bit and McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)[13] CLKSM bit are used to set the SRG clock mode.

The SRG can produce a clock signal (CLKG) for use by the receiver, the transmitter, or both, but CLKG is derived from an input clock.

For further details about the clock synchronization feature, see [Section 21.4.3](#).

#### 21.5.1.5.2.4.6 Set the SRG Input Clock Polarity

McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)[14] CLKSP bit, McBSPi.[MCBSPLP\\_PCR\\_REG](#)[1] CLKXP bit and McBSPi.[MCBSPLP\\_PCR\\_REG](#)[0] CLKRP bit are used to set the SRG input clock polarity.

The SRG can produce a clock signal (CLKG) and a frame-synchronization signal (FSG) for use by the receiver, the transmitter, or both. To produce CLKG and FSG, the SRG must be driven by an input clock signal derived from the McBSP\_FCLK clock or from an external clock on the mcbsp\_clks, mcbsp\_clkx, or mcbsp\_clkr pin. If you use a pin, choose a polarity for that pin by using the appropriate polarity bit (CLKSP for the mcbsp\_clks pin, CLKXP for the mcbsp\_clkx pin, CLKRP for the mcbsp\_clkr pin). The polarity determines whether the rising or falling edge of the input clock generates transitions on CLKG and FSG.

### 21.5.1.6 Transmitter Configuration

To configure the McBSP transmitter, perform the following procedure:

1. Place the McBSP transmitter in reset
2. Program the McBSP registers for the desired transmitter operation
3. Take the transmitter out of reset

These 3 steps are described in more details in the sub-sections below.

#### 21.5.1.6.1 Resetting (Step 1) and Enabling (Step 3) the Transmitter

The first step of the transmitter configuration procedure is to reset the transmitter, and the last step is to enable the transmitter (to take it out of reset).

The serial port can be reset in the following two ways:

1. A global reset places the receiver, transmitter, and SRG in reset. When the device reset is removed, McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[6] GRST, McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[7] FRST, McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[0] RRST and McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[0] XRST bits = 0, which keeps the entire serial port in the reset state.

2. The serial port receiver can be reset directly using the McBSPi.MCBSPLP\_SPCR2\_REG[0] XRST bit. If the SRG needs to be used, SRG must be reset directly using the McBSPi.MCBSPLP\_SPCR2\_REG[6] GRST bit. Similar operation with the Frame Synchronization Generator also requires using the McBSPi.MCBSPLP\_SPCR2\_REG[7] FRST bit when the frame-sync signal must be generated.

To enable the transmitter, the preceding bits, cleared to 0, must be set to 1.

#### 21.5.1.6.2 Programming the McBSP Registers for the Desired Transmitter Operation (Step 2)

Figure 21-66 and Figure 21-67 list important tasks to be performed when configuring the McBSP transmitter. Each task corresponds to one or more McBSP register bit fields.

**Figure 21-66. Important Tasks to Configure the McBSP Transmitter (Part 1)**



mcbsp-065

**Figure 21-67. Important Tasks to Configure the McBSP Transmitter (Part 2)**

mcbsp-066

#### 21.5.1.6.2.1 Global Behavior

##### 21.5.1.6.2.1.1 Set the Transmitter Pins to Operate as McBSP Pins

McBSPi.[MCBSPLP\\_PCR\\_REG](#)[13] XIOEN bit determines whether the transmitter pins are McBSP pins (XIOEN=0) or general-purpose I/O pins (XIOEN=1).

See [Section 21.5.1.7](#) which describes how to use McBSP pins as GPIO pins.

##### 21.5.1.6.2.1.2 Enable/Disable the Digital Loop-Back Mode

See [Section 21.5.1.5.2.1.2](#).

##### 21.5.1.6.2.1.3 Enable/Disable the Analog Loop-Back Mode

See [Section 21.5.1.5.2.1.3](#).

##### 21.5.1.6.2.1.4 Enable/Disable the Synchronous Transmit-Receive Mode (McBSP1 only)

See [Section 21.5.1.5.2.1.4](#).

##### 21.5.1.6.2.1.5 Enable/Disable the Transmit Multichannel Selection

McBSPi.[MCBSPLP\\_MCR2\\_REG](#)[1:0] XMCM bit field determines whether the transmit multichannel selection mode is on or off.

See [Section 21.4.6.7](#).

### 21.5.1.6.2.2 Data Behavior

#### 21.5.1.6.2.2.1 Choose 1 or 2 Phases for the Transmit Frame

McBSPi.[MCBSPLP\\_XCR2\\_REG\[15\]](#) XPHASE bit determines whether the transmit data frame has one (Single phase) or two phases (Dual phase). When dual-phase is selected the number of words per phase must be set to one.

#### 21.5.1.6.2.2.2 Set the Transmit Word Length(s)

McBSPi.[MCBSPLP\\_XCR1\\_REG\[7:5\]](#) XWDLEN1 and McBSPi.[MCBSPLP\\_XCR2\\_REG\[7:5\]](#) XWDLEN2 bit fields determine how many bits are in each serial word in phase 1 and in phase 2, respectively, of the transmit data frame.

If a single-phase frame is selected, XWDLEN1 selects the length for every serial word received in the frame.

If a dual-phase frame is selected, XWDLEN1 and XWDLEN2 must be set to select the both length. These both bits can have values different.

#### 21.5.1.6.2.2.3 Set the Transmit Frame Length

The transmit frame length is the number of serial words in the transmit frame.

McBSPi.[MCBSPLP\\_XCR1\\_REG\[14:8\]](#) XFRLEN1 and McBSPi.[MCBSPLP\\_XCR2\\_REG\[14:8\]](#) XFRLEN2 bit fields determine how many serial words are in phase 1 and in phase 2, respectively, of the transmit data frame.

If a dual-phase frame is selected (XPHASE=1), the frame length is 2 words, the length of phase 1 (one word) plus the length of phase 2 (one word). Others values must not be used.

The 7-bit XFRLEN fields allow up to 128 words per phase. See [Table 21-31](#) for a summary of how to calculate the frame length. This length corresponds to the number of words or logical time slots or channels per frame-synchronization pulse.

Program the XFRLEN fields with [W minus 1], where W represents the number of words per phase. For the example, if you want a phase length of 128 words in phase 1, load 127 into XFRLEN1.

**Table 21-31. How to Calculate the Length of the Transmit Frame**

| XPHASE | XFRLEN1                   | XFRLEN2       | Frame Length             |
|--------|---------------------------|---------------|--------------------------|
| 0      | $0 \leq XFRLEN1 \leq 127$ | Don't care    | (XFRLEN1 value +1) words |
| 1      | $XFRLEN1 = 0$             | $XFRLEN2 = 0$ | 2 words                  |

#### 21.5.1.6.2.2.4 Set the Transmit Reverse Mode

McBSPi.[MCBSPLP\\_XCR2\\_REG\[4:3\]](#) XREVERSE bit field determines whether reverse (LSB first) data transfer option is chosen for McBSP reception.

For additional information about reverse mode, see [Section 21.4.2.2](#).

#### 21.5.1.6.2.2.5 Set the Transmit Data Delay

McBSPi.[MCBSPLP\\_XCR2\\_REG\[1:0\]](#) XDATDLY bit field determines the length of the data delay for the transmit frame.

The start of a frame is defined by the first clock cycle in which frame synchronization is found to be active. The beginning of actual data transmission with respect to the start of the frame can be delayed if required. This delay is called data delay.

XDATDLY specifies the data delay for reception. The range of programmable data delay is zero to two bit-clocks (XDATDLY=00b–10b), as shown in [Figure 21-68](#). In this figure, the data transferred is an 8-bit value with bits labeled B7, B6, B5, and so on.

---

**NOTE:** Typically a 1-bit delay is selected, because data often follows a 1-cycle active frame-synchronization pulse.

---

**Figure 21-68. Range of Programmable Data Delay**



#### 21.5.1.6.2.2.5.1 0-Bit Data Delay:

Normally, a frame-synchronization pulse is detected or sampled with respect to an edge of internal serial clock CLK(R/X). Thus, on the following cycle or later (depending on the data delay value), data may be received or transmitted. However, in the case of 0-bit data delay, the data must be ready for reception and/or transmission on the same serial clock cycle.

For reception, this problem is solved because receive data is sampled on the first falling edge of CLKR where an active-high internal FSR is detected. However, data transmission must begin on the rising edge of the internal CLKX clock that generated the frame synchronization. Therefore, the first data bit is assumed to be present in XSR1, and thus on mcbspi\_dx. The transmitter then asynchronously detects the frame-synchronization signal (FSX) going active high and immediately starts driving the first bit to be transmitted on the mcbspi\_dx pin.

#### 21.5.1.6.2.2.5.2 2-Bit Data Delay:

A data delay of two bit periods allows the serial port to interface to different types of T1 framing devices where the data stream is preceded by a framing bit. During reception of such a stream with data delay of two bits (framing bit appears after a 1-bit delay and data appears after a 2-bit delay), the serial port essentially discards the framing bit from the data stream, as shown in [Figure 21-69](#). The data transferred is an 8-bit value with bits labeled B7, B6, B5, and so on.

**Figure 21-69. 2-Bit Data Delay Used to Skip a Framing Bit**



#### 21.5.1.6.2.2.6 Set the Transmit DXENA Mode

McBSPi.[MCBSPLP\\_SPCR1\\_REG\[7\]](#) DXENA bit is used to set the transmit DXENA (DX delay enable) mode.

The DXENA bit controls the delay enabler on the mcbsp\_dx pin. Set DXENA to enable an extra delay for turn-on time. This bit does not control the data itself, so only the first bit is delayed (the delay is given by a combinatorial delay buffer). The inserted delay: 13 ns, 18 ns (default), 24 ns, or 30 ns can be set using the McBSPi.[MCBSPLP\\_XCCR\\_REG\[13:12\]](#) DXENDLY bit field. If you tie together the mcbsp\_dx pins of multiple McBSP modules, make sure DXENA = 1, to avoid having more than one McBSP transmitting on the data line at one time.

#### 21.5.1.6.2.2.7 Set the Transmit Interrupt Mode

See [Section 21.5.1.4.2.2](#).

#### 21.5.1.6.2.2.8 Set the Transmit DMA Mode

The McBSP transmit data DMA requests (McBSPi\_DMA\_TX) are active after the transmit McBSPi.[MCBSPLP\\_SPCR2\\_REG\[0\]](#) XRST bit is released. After reset, the default DMA threshold (and length) is 1.

The transmit DMA requests can be disabled by setting the McBSPi.[MCBSPLP\\_XCCR\\_REG\[3\]](#) XDMAEN bit to 0. When disabling the DMA, the DMA request line is deasserted even if a DMA transfer is pending, and the DMA state-machine is not reset.

To configure the McBSP transmit data DMA requests, follow this procedure:

- Write the transmit McBSPi.[MCBSPLP\\_THRSH2\\_REG](#) register with the required transmit DMA request length (the length of the transfer is the same as the threshold value + 1).
- As long as the free locations level in XB is above or equal to the THRSH2\_REG value + 1, the DMA request is asserted.
- After transferring the configured (THRSH2\_REG value + 1) number of words, the transmit DMA request is deasserted, and then reasserted as soon as the conditions are met again.

#### 21.5.1.6.2.3 Frame-Synchronization Behavior

##### 21.5.1.6.2.3.1 Set the Transmit Frame-Sync Mode

McBSPi.[MCBSPLP\\_PCR\\_REG\[11\]](#) FSXM bit and McBSPi.[MCBSPLP\\_SRGR2\\_REG\[12\]](#) FSGM bit are used to set the transmit frame-sync mode.

[Table 21-32](#) shows how FSXM and FSGM select the source of transmit frame-synchronization pulses. The three choices are:

1. External frame-synchronization input
2. Sample rate generator frame-synchronization signal (FSG)
3. Sample rate generator frame-synchronization signal (FSG) gated by the transmit buffer XB empty condition.

[Table 21-32](#) also shows the effect of each bit setting on the mcbsp\_fsx pin. The FSXP bit determines the polarity of the signal on the mcbsp\_fsx pin.

**Table 21-32. How FSXM and FSGM Select the Source of Transmit Frame-Sync Pulses**

| FSXM | FSGM   | Source of Transmit Frame Synchronization                                                                                                                                                                                                                                                                   | mcbsp_fsx Pin Status                                                                                                              |
|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 0    | 0 or 1 | An external FSG enters the McBSP through the mcbsp_fsx pin. The signal is then inverted by FSXP bit before being used as internal FSX.                                                                                                                                                                     | Input                                                                                                                             |
| 1    | 1      | Internal FSX is driven by the SRG FSG.                                                                                                                                                                                                                                                                     | Output. FSG is inverted by FSXP bit before being driven out on mcbsp_fsx pin.                                                     |
| 1    | 0      | A XB empty condition causes the McBSP not to generate a transmit frame-synchronization pulse. The frame synchronization is generated taking into account the FWID and FPER bits as long as the transmit buffer is not empty. When the buffer is empty the generated frame synchronization signal is gated. | Output. The generated frame-synchronization pulse is inverted as determined by FSXP bit before being driven out on mcbsp_fsx pin. |

If the SRG creates a frame-synchronization signal (FSG) that is derived from an external input clock, the GSYNC bit determines whether FSG is kept synchronized with pulses on the mcbsp\_fsr pin. For more details, see [Section 21.4.3.3](#).

In the digital loopback mode (DLB=1) or analog loopback mode (ALB = 1), the transmit frame synchronization signal is used as the receive frame synchronization signal. For more details on frame-sync configuration, see [Section 21.4.3.2](#).

#### 21.5.1.6.2.3.2 Set the Transmit Frame-Sync Polarity

McBSPi.[MCBSPLP\\_PCR\\_REG](#)[3] FSXP bit determines whether frame-synchronization pulses are active high or active low on the mcbsp\_fx pin.

Transmit frame-synchronization pulses can be generated internally by the SRG or driven by an external source. The source of frame synchronization is selected by programming the McBSPi.[MCBSPLP\\_PCR\\_REG](#)[11] FSXM bit. FSX is also affected by the McBSPi.[MCBSPLP\\_SRGR2\\_REG](#)[12] FSGM bit. For information about the effects of FSXM and FSGM, see [Section 21.5.1.6.2.3.1](#).

When FSR and FSX are inputs (FSXM=FSRM=0, external frame-synchronization pulses), the McBSP module detects them on the internal falling edge of clock, internal CLKR, and internal CLKX, respectively. The receive data arriving at the mcbsp\_dr pin is also sampled on the falling edge of internal CLKR. These internal clock signals are either derived from external source via CLK(R/X) pins or driven by the SRG clock (CLKG) internal to the McBSP module.

When FSR and FSX are outputs, implying that they are driven by the SRG, they are generated (transition to their active state) on the rising edge of internal clock, CLK(R/X). Similarly, data on the mcbsp\_dx pin is output on the rising edge of internal CLKX.

FSRP, FSXP, CLKRP, and CLKXP in the pin control register (PCR\_REG) configure the polarities of the FSR, FSX, CLKR, and CLKX signals, respectively. All FSG (internal FSR, internal FSX) that are internal to the serial port are active high. If the serial port is configured for external frame synchronization (FSR/FSX are inputs to McBSP) and FSRP=FSXP=1, the external active-low frame-synchronization signals are inverted before being sent to the receiver (internal FSR) and transmitter (internal FSX). Similarly, if internal synchronization (FSR/FSX are output pins and GSYNC=0) is selected and the polarity bit FS(R/X)P=1, the internal active-high FSG are inverted before being sent to the FS(R/X) pin.

#### 21.5.1.6.2.3.3 Set the SRG Frame-Sync Period and Pulse Width

See [Section 21.5.1.5.2.3.3](#).

#### 21.5.1.6.2.4 Clock Behavior

##### 21.5.1.6.2.4.1 Set the Transmit Clock Mode

The McBSPi.[MCBSPLP\\_PCR\\_REG](#)[9] CLKXM bit is used to set the transmit clock mode.

[Table 21-33](#) shows how the CLKXM bit selects the transmit clock and the corresponding status of the mcbsp\_clkx pin. The CLKXP bit determines the polarity of the signal on the mcbsp\_clkx pin.

**Table 21-33. CLKXM Bit Effect on Transmit Clock and MCBSPLP.CLKX Pin**

| CLKXM | Source of Transmit Clock                                                                                                       | mcbsp_clkx Pin Status                                                       |
|-------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| 0     | Internal CLKX is driven by an external clock on the mcbsp_clkx pin. CLKX is inverted as determined by CLKXP before being used. | Input                                                                       |
| 1     | Internal CLKX is driven by the SRG clock, CLKG.                                                                                | Output. CLKG, inverted as determined by CLKXP, is driven out on mcbsp_clkx. |

If the SRG creates a clock signal (CLKG) that is derived from an external input clock, the GSYNC bit determines whether CLKG is kept synchronized with pulses on the mcbsp\_fsr pin.

In the digital loopback mode (DLB=1) or analog loopback mode (ALB = 1), the transmit frame synchronization signal is used as the receive frame synchronization signal. For more details on clock configuration, see [Section 21.4.3.1](#).

#### **21.5.1.6.2.4.2 Set the Transmit Clock Polarity**

The McBSPi.[MCBSPLP\\_PCR\\_REG](#)[1] CLKXP bit is used to set the transmit clock polarity.

On the transmit side, the transmit clock polarity bit, CLKXP, sets the edge used to shift and clock out transmit data. Data is always transmitted on the rising edge of internal CLKX. If CLKXP=1 and external clocking is selected (CLKXM=0 and CLKX is an input), the external falling-edge triggered input clock on CLKX is inverted to a rising-edge triggered clock before being sent to the transmitter. If CLKXP=1 and internal clocking is selected (CLKXM=1 and CLKX is an output pin), the internal (rising-edge triggered) clock, internal CLKX, is inverted before being sent out on the mcbsp\_clkx pin.

Similarly, the receiver can reliably sample data that is clocked with a rising edge clock (by the transmitter). The receive clock polarity bit, CLKRP, sets the edge used to sample received data. The receive data is always sampled on the falling edge of internal CLKR. Therefore, if CLKRP=1 and external clocking is selected (CLKRM=0 and CLKR is an input pin), the external rising-edge triggered input clock on CLKR is inverted to a falling-edge triggered clock before being sent to the receiver. If CLKRP=1 and internal clocking is selected (CLKRM=1), the internal falling-edge triggered clock is inverted to a rising-edge triggered clock before being sent out on the mcbsp\_clkr pin.

---

**NOTE:** CLKRP=CLKXP in a system where the same clock (internal or external) is used to clock the receiver and transmitter. The receiver uses the opposite edge as the transmitter to ensure valid setup and hold of data around this edge.

---

#### **21.5.1.6.2.4.3 Set the SRG Clock Divide-Down Value**

See [Section 21.5.1.5.2.4.3](#).

#### **21.5.1.6.2.4.4 Set the SRG Clock Synchronization Mode**

See [Section 21.5.1.5.2.4.4](#).

#### **21.5.1.6.2.4.5 Set the SRG Clock Mode (Choose an Input Clock)**

See [Section 21.5.1.5.2.4.5](#).

#### **21.5.1.6.2.4.6 Set the SRG Input Clock Polarity**

See [Section 21.5.1.5.2.4.6](#).

### **21.5.1.7 General-Purpose I/O on the McBSP Pins (Legacy Only)**

[Table 21-34](#) summarizes how to use the McBSP pins as general-purpose I/O pins. All the bits mentioned in the table except XRST and RRST bits are in the pin control register (McBSPi.[MCBSPLP\\_PCR\\_REG](#)). McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[0] XRST bit and McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[0] RRST bit are in the serial port control registers.

To use receiver pins mcbsp\_clkr, mcbsp\_fsr, and mcbsp\_dr as general-purpose I/O pins rather than as serial port pins, you must set two conditions:

1. The receiver of the serial port is in reset (McBSPi.[MCBSPLP\\_SPCR1\\_REG](#)[0] RRST bit =0).
2. General-purpose I/O is enabled for the serial port receiver (McBSPi.[MCBSPLP\\_PCR\\_REG](#)[12] RIOEN=1).

The mcbsp\_clk and mcbsp\_fsr pins can be individually configured as either input or output pins with the CLKRM and FSRM bits, respectively. The mcbsp\_dr pin can only be an input pin. [Table 21-34](#) shows, which bits in McBSPi.[MCBSPLP\\_PCR\\_REG](#) are used to read from/write to these pins.

For the transmitter pins mcbsp\_clkx, mcbsp\_fsx, and mcbsp\_dx, you must meet two conditions:

1. The transmitter of the serial port is in reset (McBSPi.[MCBSPLP\\_SPCR2\\_REG](#)[0] XRST=0).
2. General-purpose I/O is enabled for the serial port transmitter (McBSPi.[MCBSPLP\\_PCR\\_REG](#)[12] XIOEN=1).

The mcbsp\_clkx and mcbsp\_fsx pins can be individually configured as input or output pins with the CLKXM and FSXM bits, respectively. The mcbsp\_dx pin can only be an output pin. [Table 21-34](#) shows the bits in McBSPi.[MCBSPLP\\_PCR\\_REG](#) used to read from/write to these pins.

For the mcbsp\_clks pin (common to all McBSP modules), all of the reset and I/O enable conditions must be met:

1. Both the receiver and transmitter of the serial port are in reset (RRST=0 and XRST=0).
2. General-purpose I/O is enabled for both the receiver and the transmitter (RIOEN=1 and XIOEN=1).

The mcbsp\_clks pin can only be an input pin. To read the status of the signal on the mcbsp\_clks pin, read the McBSPi.[MCBSPLP\\_PCR\\_REG](#)[6] CLKS\_STAT bit.

**Table 21-34. Using McBSP Pins for General-Purpose I/O**

| Pin        | General-Purpose use enabled by this bit combination | Selected as output when | Output value driven from this bit | Selected as input when | Input value read from this bit |
|------------|-----------------------------------------------------|-------------------------|-----------------------------------|------------------------|--------------------------------|
| mcbsp_clkx | XRST = 0<br>XIOEN = 1                               | CLKXM = 1               | CLKXP                             | CLKXM = 0              | CLKXP                          |
| mcbsp_fsx  | XRST = 0<br>XIOEN = 1                               | FSXM = 1                | FSXP                              | FSXM = 0               | FSXP                           |
| mcbsp_dx   | XRST = 0<br>XIOEN = 1                               | Always                  | DX_STAT                           | Never                  | Does not apply                 |
| mcbsp_clk  | RRST = 0<br>RIOEN = 1                               | CLKRM = 1               | CLKRP                             | CLKRM = 0              | CLKRP                          |
| mcbsp_fsr  | RRST = 0<br>RIOEN = 1                               | FSRM = 1                | FSRP                              | FSRM = 0               | FSRP                           |
| mcbsp_dr   | RRST = 0<br>RIOEN = 1                               | Never                   | Does not apply                    | Always                 | DR_STAT                        |
| mcbsp_clks | RRST = XRST = 0<br>RIOEN = XIOEN = 1                | Never                   | Does not apply                    | Always                 | CLKS_STAT                      |

### 21.5.1.8 Data Packing Examples

This section describes two ways to implement data packing in the McBSP: Using frame length and word length, and using word length and ignoring frame sync pulses.

#### 21.5.1.8.1 Data Packing Using Frame Length and Word Length

Frame length and word length can be manipulated to pack data effectively. For example, four 8-bit words are transferred in a single-phase frame, as shown in [Figure 21-70](#). In this case:

- (R/X)PHASE = 0: Single-phase frame
- (R/X)FRLEN1 = 00011b: 4-word frame
- (R/X)WDLEN1 = 101b: 32-bit words

Four 8-bit data words are transferred to and from the McBSP by the MPU/IVA2.2 subsystems or the sDMA controller. Thus, four reads from McBSPi.[MCBSPLP\\_DRR\\_REG](#) and four writes to McBSPi.[MCBSPLP\\_DXR\\_REG](#) are necessary for each frame.

**Figure 21-70. Four 8-bit Data Words Transferred To/From McBSP Module**

mcbsp-058

This data can also be treated as a single-phase frame consisting of one 32-bit data word, as shown in [Figure 21-71](#). In this case:

- (R/X)PHASE = 0: Single-phase frame
- (R/X)FRLEN1 = 0000000b: 1-word frame
- (R/X)WDLEN1 = 000b: 8-bit words

Two 16-bit data words are transferred to and from the McBSP by the MPU/IVA2.2 subsystems or the sDMA controller. Thus, two reads from McBSPi.[MCBSPLP\\_DRR\\_REG](#) and two writes to McBSPi.[MCBSPLP\\_DXR\\_REG](#) are necessary for each frame. This results in only half the number of transfers, as compared to the previous case. This manipulation reduces the percentage of bus time required for serial port data movement.

**Figure 21-71. One 32-bit Data Word Transferred To/From McBSP Module**

mcbsp-059

#### 21.5.1.8.2 Data Packing Using Word Length and the Frame-Sync Ignore Function

When there are multiple words per frame, data can be packed by increasing the word length (defining a serial word with more bits) and by ignoring frame-sync pulses. [Figure 21-72](#) shows the McBSP operating at the maximum packet frequency. Here, each frame has only one 8-bit word. Notice the frame-sync pulse that initiates each frame transfer for reception and for transmission. For reception, this configuration requires one read operation for each word. For transmission, this configuration requires one write operation for each word.

**Figure 21-72. 8-bit Data Words Transferred at Maximum Packet Frequency**

mcbsp-060

Figure 21-73 shows the McBSP configured to treat this data stream as a continuous 32-bit word. In this example, the McBSP responds to an initial frame-sync pulse. However, the McBSP ignores subsequent pulses. Only one read transfer or one write transfer is required every 32 bits. This configuration effectively reduces the required bus bandwidth to one-fourth the bandwidth needed to transfer four 8-bit words.

**Figure 21-73. Configuring the Data Stream as a Continuous 32-bit Word**

mcbsp-061

## 21.5.2 SIDETONE Feature

### 21.5.2.1 SIDETONE Activation Procedure

Before you enable a SIDETONE selection mode, make sure you properly configure the data frame for multichannel mode of the McBSP module:

- Select a single-phase frame (McBSPi.[MCBSPLP\\_RCR2\\_REG](#)[15] RPHASE bit and McBSPi.[MCBSPLP\\_XCR2\\_REG](#)[15] XPHASE bit=0). Each frame represents a TDM data stream.
- Set to 1 the McBSPi.[MCBSPLP\\_MCR1\\_REG](#)[0] RMCM bit, to select multichannel mode enable.
- Set a frame length (McBSPi.[MCBSPLP\\_RCR1\\_REG](#)[14:8] RFRLEN1 bit field and McBSPi.[MCBSPLP\\_XCR1\\_REG](#)[14:8] XFRLEN1 bit field) that includes the highest-numbered channel to be used (a maximum of 4 channels can be used in this configuration).
- Set a word length (McBSPi.[MCBSPLP\\_RCR1\\_REG](#)[7:5] RWDLEN1 bit field and McBSPi.[MCBSPLP\\_XCR1\\_REG](#)[7:5] XWDLEN1 bit field) to be either 16, 24 or 32 (see the note)

below).

- Select the input/output channels configured as SIDETONE channels by setting the following bit fields listed in [Table 21-35](#):

**Table 21-35. Selection of the SIDETONE Input and Output Channels**

| Bit field                                                      | Description                                                                                              |
|----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| McBSPi. <a href="#">MCBSPLP_SSELCR_REG</a> [9:7]<br>OCH1ASSIGN | Map the CH1 data for the speaker out channels to one of the McBSP channels (1 out of 8 channels)         |
| McBSPi. <a href="#">MCBSPLP_SSELCR_REG</a> [6:4]<br>OCH0ASSIGN | Map the CH0 data for the speaker out channels to one of the McBSP channels (1 out of 8 channels)         |
| McBSPi. <a href="#">MCBSPLP_SSELCR_REG</a> [3:2]<br>ICH1ASSIGN | Map the CH1 data from the digital microphone channels to one of the McBSP channels (1 out of 4 channels) |
| McBSPi. <a href="#">MCBSPLP_SSELCR_REG</a> [1:0]<br>ICH0ASSIGN | Map the CH0 data from the digital microphone channels to one of the McBSP channels (1 out of 4 channels) |

- Enable SIDETONE by setting 2 bits to 1:
  1. In McBSP module, the McBSPi.[MCBSPLP\\_SSELCR\\_REG](#)[10] SIDETONEEN bit
  2. In SIDETONE core, the McBSPi.[ST\\_SSELCR\\_REG](#)[0] SIDETONEEN bit

**NOTE:** Word width in the loop is 24 bits. If input channel word width is less than 24 bits, LSBs of the samples are zero padded. If input channel word width is more than 24 bits, samples are truncated.

### 21.5.2.2 SIDETONE Initialization Procedure

The SIDETONE core initialization procedure is as follows:

1. Write 1 in McBSPi.[ST\\_SSELCR\\_REG](#)[1] COEFFWREN bit to enable loading of the FIR coefficients.
2. Load one by one the FIR coefficients performing 128 write accesses to McBSPi.[ST\\_SFIRCR\\_REG](#)[15:0] FIRCOEFF bit field, the McBSPi.[ST\\_SFIRCR\\_REG](#)[0] FIRCOEFF bit is loaded first. To ensure the completion of loading, check the status bit-field, McBSPi.[ST\\_SSELCR\\_REG](#)[2] COEFFWRDONE bit.
3. Set-up gain values for both channels writing desired values inside McBSPi.[ST\\_SGAINCR\\_REG](#)[31:16] CH1GAIN bit field for the second sidetone channel and McBSPi.[ST\\_SGAINCR\\_REG](#)[15:0] CH0GAIN bit field for the first sidetone channel.

### 21.5.2.3 SIDETONE FIR Coefficients Writing

Writing the coefficients is only possible when the SIDETONE is disabled.

1. Write 1 in McBSPi.[ST\\_SSELCR\\_REG](#)[1] COEFFWREN bit to enable writing of the FIR coefficients, or write 0, and then write 1 in the COEFFWREN bit to reset the write process.
2. Perform 128 write accesses in 32/16 LSB bit mode on the McBSPi.[ST\\_SFIRCR\\_REG](#)[15:0] FIRCOEFF bit field. The first write action following the previous step sets the coefficient index 0.
3. Check that the write is done by reading McBSPi.[ST\\_SSELCR\\_REG](#)[2] COEFFWRDONE bit (it becomes 1 after the 128th coefficient is written).

### 21.5.2.4 SIDETONE FIR Coefficients Reading

Reading the coefficients is only possible when the SIDETONE is disabled.

- Write 0 in McBSPi.[ST\\_SSELCR\\_REG](#)[1] COEFFWREN bit to enable reading of the FIR coefficients, or write 1, and then write 0 in the COEFFWREN bit to reset the read process.
- Perform 128 read accesses from McBSPi.[ST\\_SFIRCR\\_REG](#)[15:0] FIRCOEFF bit field. Each read returns coefficients one by one. The first read following previous step returns coefficient index 0.

## 21.6 McBSP Register Manual

[Table 21-36](#) shows the base address and address space for the McBSP module instances.

**Table 21-36. McBSP Instance Summary**

| Module Name     | Base Address (hex) | Size     |
|-----------------|--------------------|----------|
| McBSP1          | 0x4807 4000        | 4K bytes |
| McBSP5          | 0x4809 6000        | 4K bytes |
| McBSP2          | 0x4902 2000        | 4K bytes |
| McBSP3          | 0x4902 4000        | 4K bytes |
| McBSP4          | 0x4902 6000        | 4K bytes |
| SIDETONE_McBSP2 | 0x4902 8000        | 4K bytes |
| SIDETONE_McBSP3 | 0x4902 A000        | 4K bytes |

### 21.6.1 McBSP Register Mapping Summary

**CAUTION**

The McBSP data registers (that is, DXR\_REG for data transmit and DRR\_REG for data receive) support 8-, 16-, and 32-bit data accesses. All other McBSP registers are limited to 32-bit data accesses; 16- and 8-bit data accesses are not allowed and can corrupt register contents.

**Table 21-37. McBSP1 Registers Mapping Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address |
|-------------------|------|-----------------------|----------------|------------------|
| MCBSPLP_DRR_REG   | R    | 32                    | 0x0000 0000    | 0x4807 4000      |
| MCBSPLP_DXR_REG   | W    | 32                    | 0x0000 0008    | 0x4807 4008      |
| MCBSPLP_SPCR2_REG | RW   | 32                    | 0x0000 0010    | 0x4807 4010      |
| MCBSPLP_SPCR1_REG | RW   | 32                    | 0x0000 0014    | 0x4807 4014      |
| MCBSPLP_RCR2_REG  | RW   | 32                    | 0x0000 0018    | 0x4807 4018      |
| MCBSPLP_RCR1_REG  | RW   | 32                    | 0x0000 001C    | 0x4807 401C      |
| MCBSPLP_XCR2_REG  | RW   | 32                    | 0x0000 0020    | 0x4807 4020      |
| MCBSPLP_XCR1_REG  | RW   | 32                    | 0x0000 0024    | 0x4807 4024      |
| MCBSPLP_SRGR2_REG | RW   | 32                    | 0x0000 0028    | 0x4807 4028      |
| MCBSPLP_SRGR1_REG | RW   | 32                    | 0x0000 002C    | 0x4807 402C      |
| MCBSPLP_MCR2_REG  | RW   | 32                    | 0x0000 0030    | 0x4807 4030      |
| MCBSPLP_MCR1_REG  | RW   | 32                    | 0x0000 0034    | 0x4807 4034      |
| MCBSPLP_RCERA_REG | RW   | 32                    | 0x0000 0038    | 0x4807 4038      |
| MCBSPLP_RCERB_REG | RW   | 32                    | 0x0000 003C    | 0x4807 403C      |
| MCBSPLP_XCERA_REG | RW   | 32                    | 0x0000 0040    | 0x4807 4040      |
| MCBSPLP_XCERB_REG | RW   | 32                    | 0x0000 0044    | 0x4807 4044      |
| MCBSPLP_PCR_REG   | RW   | 32                    | 0x0000 0048    | 0x4807 4048      |
| MCBSPLP_RCERC_REG | RW   | 32                    | 0x0000 004C    | 0x4807 404C      |
| MCBSPLP_RCERD_REG | RW   | 32                    | 0x0000 0050    | 0x4807 4050      |
| MCBSPLP_XCERC_REG | RW   | 32                    | 0x0000 0054    | 0x4807 4054      |
| MCBSPLP_XCERD_REG | RW   | 32                    | 0x0000 0058    | 0x4807 4058      |
| MCBSPLP_RCERE_REG | RW   | 32                    | 0x0000 005C    | 0x4807 405C      |
| MCBSPLP_RCERF_REG | RW   | 32                    | 0x0000 0060    | 0x4807 4060      |

**Table 21-37. McBSP1 Registers Mapping Summary (continued)**

| Register Name         | Type | Register Width (Bits) | Address Offset | Physical Address |
|-----------------------|------|-----------------------|----------------|------------------|
| MCBSPLP_XCERE_REG     | RW   | 32                    | 0x0000 0064    | 0x4807 4064      |
| MCBSPLP_XCERF_REG     | RW   | 32                    | 0x0000 0068    | 0x4807 4068      |
| MCBSPLP_RCERG_REG     | RW   | 32                    | 0x0000 006C    | 0x4807 406C      |
| MCBSPLP_RCERH_REG     | RW   | 32                    | 0x0000 0070    | 0x4807 4070      |
| MCBSPLP_XCERG_REG     | RW   | 32                    | 0x0000 0074    | 0x4807 4074      |
| MCBSPLP_XCERH_REG     | RW   | 32                    | 0x0000 0078    | 0x4807 4078      |
| MCBSPLP_REV_REG       | R    | 32                    | 0x0000 007C    | 0x4807 407C      |
| MCBSPLP_RINTCLR_REG   | RW   | 32                    | 0x0000 0080    | 0x4807 4080      |
| MCBSPLP_XINTCLR_REG   | RW   | 32                    | 0x0000 0084    | 0x4807 4084      |
| MCBSPLP_ROVFLCLR_REG  | RW   | 32                    | 0x0000 0088    | 0x4807 4088      |
| MCBSPLP_SYSCONFIG_REG | RW   | 32                    | 0x0000 008C    | 0x4807 408C      |
| MCBSPLP_THRSH2_REG    | RW   | 32                    | 0x0000 0090    | 0x4807 4090      |
| MCBSPLP_THRSH1_REG    | RW   | 32                    | 0x0000 0094    | 0x4807 4094      |
| MCBSPLP_IRQSTATUS_REG | RW   | 32                    | 0x0000 00A0    | 0x4807 40A0      |
| MCBSPLP_IRQENABLE_REG | RW   | 32                    | 0x0000 00A4    | 0x4807 40A4      |
| MCBSPLP_WAKEUPEN_REG  | RW   | 32                    | 0x0000 00A8    | 0x4807 40A8      |
| MCBSPLP_XCCR_REG      | RW   | 32                    | 0x0000 00AC    | 0x4807 40AC      |
| MCBSPLP_RCCR_REG      | RW   | 32                    | 0x0000 00B0    | 0x4807 40B0      |
| MCBSPLP_XBUFFSTAT_REG | R    | 32                    | 0x0000 00B4    | 0x4807 40B4      |
| MCBSPLP_RBUFFSTAT_REG | R    | 32                    | 0x0000 00B8    | 0x4807 40B8      |
| MCBSPLP_SSELCR_REG    | RW   | 32                    | 0x0000 00BC    | 0x4807 40BC      |
| MCBSPLP_STATUS_REG    | R    | 32                    | 0x0000 00C0    | 0x4807 40C0      |

**Table 21-38. McBSP5 Registers Mapping Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address |
|-------------------|------|-----------------------|----------------|------------------|
| MCBSPLP_DRR_REG   | R    | 32                    | 0x0000 0000    | 0x4809 6000      |
| MCBSPLP_DXR_REG   | W    | 32                    | 0x0000 0008    | 0x4809 6008      |
| MCBSPLP_SPCR2_REG | RW   | 32                    | 0x0000 0010    | 0x4809 6010      |
| MCBSPLP_SPCR1_REG | RW   | 32                    | 0x0000 0014    | 0x4809 6014      |
| MCBSPLP_RCR2_REG  | RW   | 32                    | 0x0000 0018    | 0x4809 6018      |
| MCBSPLP_RCR1_REG  | RW   | 32                    | 0x0000 001C    | 0x4809 601C      |
| MCBSPLP_XCR2_REG  | RW   | 32                    | 0x0000 0020    | 0x4809 6020      |
| MCBSPLP_XCR1_REG  | RW   | 32                    | 0x0000 0024    | 0x4809 6024      |
| MCBSPLP_SRGR2_REG | RW   | 32                    | 0x0000 0028    | 0x4809 6028      |
| MCBSPLP_SRGR1_REG | RW   | 32                    | 0x0000 002C    | 0x4809 602C      |
| MCBSPLP_MCR2_REG  | RW   | 32                    | 0x0000 0030    | 0x4809 6030      |
| MCBSPLP_MCR1_REG  | RW   | 32                    | 0x0000 0034    | 0x4809 6034      |
| MCBSPLP_RCERA_REG | RW   | 32                    | 0x0000 0038    | 0x4809 6038      |
| MCBSPLP_RCERB_REG | RW   | 32                    | 0x0000 003C    | 0x4809 603C      |
| MCBSPLP_XCERA_REG | RW   | 32                    | 0x0000 0040    | 0x4809 6040      |
| MCBSPLP_XCERB_REG | RW   | 32                    | 0x0000 0044    | 0x4809 6044      |
| MCBSPLP_PCR_REG   | RW   | 32                    | 0x0000 0048    | 0x4809 6048      |
| MCBSPLP_RCERC_REG | RW   | 32                    | 0x0000 004C    | 0x4809 604C      |
| MCBSPLP_RCERD_REG | RW   | 32                    | 0x0000 0050    | 0x4809 6050      |
| MCBSPLP_XCERC_REG | RW   | 32                    | 0x0000 0054    | 0x4809 6054      |

**Table 21-38. McBSP5 Registers Mapping Summary (continued)**

| Register Name         | Type | Register Width (Bits) | Address Offset | Physical Address |
|-----------------------|------|-----------------------|----------------|------------------|
| MCBSPLP_XCERD_REG     | RW   | 32                    | 0x0000 0058    | 0x4809 6058      |
| MCBSPLP_RCERE_REG     | RW   | 32                    | 0x0000 005C    | 0x4809 605C      |
| MCBSPLP_RCERF_REG     | RW   | 32                    | 0x0000 0060    | 0x4809 6060      |
| MCBSPLP_XCERE_REG     | RW   | 32                    | 0x0000 0064    | 0x4809 6064      |
| MCBSPLP_XCERF_REG     | RW   | 32                    | 0x0000 0068    | 0x4809 6068      |
| MCBSPLP_RCERG_REG     | RW   | 32                    | 0x0000 006C    | 0x4809 606C      |
| MCBSPLP_RCERH_REG     | RW   | 32                    | 0x0000 0070    | 0x4809 6070      |
| MCBSPLP_XCERG_REG     | RW   | 32                    | 0x0000 0074    | 0x4809 6074      |
| MCBSPLP_XCERH_REG     | RW   | 32                    | 0x0000 0078    | 0x4809 6078      |
| MCBSPLP_REV_REG       | R    | 32                    | 0x0000 007C    | 0x4809 607C      |
| MCBSPLP_RINTCLR_REG   | RW   | 32                    | 0x0000 0080    | 0x4809 6080      |
| MCBSPLP_XINTCLR_REG   | RW   | 32                    | 0x0000 0084    | 0x4809 6084      |
| MCBSPLP_ROVFLCLR_REG  | RW   | 32                    | 0x0000 0088    | 0x4809 6088      |
| MCBSPLP_SYSCONFIG_REG | RW   | 32                    | 0x0000 008C    | 0x4809 608C      |
| MCBSPLP_THRSH2_REG    | RW   | 32                    | 0x0000 0090    | 0x4809 6090      |
| MCBSPLP_THRSH1_REG    | RW   | 32                    | 0x0000 0094    | 0x4809 6094      |
| MCBSPLP_IRQSTATUS_REG | RW   | 32                    | 0x0000 00A0    | 0x4809 60A0      |
| MCBSPLP_IRQENABLE_REG | RW   | 32                    | 0x0000 00A4    | 0x4809 60A4      |
| MCBSPLP_WAKEUPEN_REG  | RW   | 32                    | 0x0000 00A8    | 0x4809 60A8      |
| MCBSPLP_XCCR_REG      | RW   | 32                    | 0x0000 00AC    | 0x4809 60AC      |
| MCBSPLP_RCCR_REG      | RW   | 32                    | 0x0000 00B0    | 0x4809 60B0      |
| MCBSPLP_XBUFFSTAT_REG | R    | 32                    | 0x0000 00B4    | 0x4809 60B4      |
| MCBSPLP_RBUFFSTAT_REG | R    | 32                    | 0x0000 00B8    | 0x4809 60B8      |
| MCBSPLP_SSELCR_REG    | RW   | 32                    | 0x0000 00BC    | 0x4809 60BC      |
| MCBSPLP_STATUS_REG    | R    | 32                    | 0x0000 00C0    | 0x4809 60C0      |

**Table 21-39. McBSP2 Registers Mapping Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address |
|-------------------|------|-----------------------|----------------|------------------|
| MCBSPLP_DRR_REG   | R    | 32                    | 0x0000 0000    | 0x4902 2000      |
| MCBSPLP_DXR_REG   | W    | 32                    | 0x0000 0008    | 0x4902 2008      |
| MCBSPLP_SPCR2_REG | RW   | 32                    | 0x0000 0010    | 0x4902 2010      |
| MCBSPLP_SPCR1_REG | RW   | 32                    | 0x0000 0014    | 0x4902 2014      |
| MCBSPLP_RCR2_REG  | RW   | 32                    | 0x0000 0018    | 0x4902 2018      |
| MCBSPLP_RCR1_REG  | RW   | 32                    | 0x0000 001C    | 0x4902 201C      |
| MCBSPLP_XCR2_REG  | RW   | 32                    | 0x0000 0020    | 0x4902 2020      |
| MCBSPLP_XCR1_REG  | RW   | 32                    | 0x0000 0024    | 0x4902 2024      |
| MCBSPLP_SRGR2_REG | RW   | 32                    | 0x0000 0028    | 0x4902 2028      |
| MCBSPLP_SRGR1_REG | RW   | 32                    | 0x0000 002C    | 0x4902 202C      |
| MCBSPLP_MCR2_REG  | RW   | 32                    | 0x0000 0030    | 0x4902 2030      |
| MCBSPLP_MCR1_REG  | RW   | 32                    | 0x0000 0034    | 0x4902 2034      |
| MCBSPLP_RCERA_REG | RW   | 32                    | 0x0000 0038    | 0x4902 2038      |
| MCBSPLP_RCERB_REG | RW   | 32                    | 0x0000 003C    | 0x4902 203C      |
| MCBSPLP_XCERA_REG | RW   | 32                    | 0x0000 0040    | 0x4902 2040      |
| MCBSPLP_XCERB_REG | RW   | 32                    | 0x0000 0044    | 0x4902 2044      |
| MCBSPLP_PCR_REG   | RW   | 32                    | 0x0000 0048    | 0x4902 2048      |

**Table 21-39. McBSP2 Registers Mapping Summary (continued)**

| Register Name         | Type | Register Width (Bits) | Address Offset | Physical Address |
|-----------------------|------|-----------------------|----------------|------------------|
| MCBSPLP_RCERC_REG     | RW   | 32                    | 0x0000 004C    | 0x4902 204C      |
| MCBSPLP_RCERD_REG     | RW   | 32                    | 0x0000 0050    | 0x4902 2050      |
| MCBSPLP_XCERC_REG     | RW   | 32                    | 0x0000 0054    | 0x4902 2054      |
| MCBSPLP_XCERD_REG     | RW   | 32                    | 0x0000 0058    | 0x4902 2058      |
| MCBSPLP_RCERE_REG     | RW   | 32                    | 0x0000 005C    | 0x4902 205C      |
| MCBSPLP_RCERF_REG     | RW   | 32                    | 0x0000 0060    | 0x4902 2060      |
| MCBSPLP_XCERE_REG     | RW   | 32                    | 0x0000 0064    | 0x4902 2064      |
| MCBSPLP_XCERF_REG     | RW   | 32                    | 0x0000 0068    | 0x4902 2068      |
| MCBSPLP_RCERG_REG     | RW   | 32                    | 0x0000 006C    | 0x4902 206C      |
| MCBSPLP_RCERH_REG     | RW   | 32                    | 0x0000 0070    | 0x4902 2070      |
| MCBSPLP_XCERG_REG     | RW   | 32                    | 0x0000 0074    | 0x4902 2074      |
| MCBSPLP_XCERH_REG     | RW   | 32                    | 0x0000 0078    | 0x4902 2078      |
| MCBSPLP_REV_REG       | R    | 32                    | 0x0000 007C    | 0x4902 207C      |
| MCBSPLP_RINTCLR_REG   | RW   | 32                    | 0x0000 0080    | 0x4902 2080      |
| MCBSPLP_XINTCLR_REG   | RW   | 32                    | 0x0000 0084    | 0x4902 2084      |
| MCBSPLP_ROVFLCLR_REG  | RW   | 32                    | 0x0000 0088    | 0x4902 2088      |
| MCBSPLP_SYSCONFIG_REG | RW   | 32                    | 0x0000 008C    | 0x4902 208C      |
| MCBSPLP_THRSH2_REG    | RW   | 32                    | 0x0000 0090    | 0x4902 2090      |
| MCBSPLP_THRSH1_REG    | RW   | 32                    | 0x0000 0094    | 0x4902 2094      |
| MCBSPLP_IRQSTATUS_REG | RW   | 32                    | 0x0000 00A0    | 0x4902 20A0      |
| MCBSPLP_IRQENABLE_REG | RW   | 32                    | 0x0000 00A4    | 0x4902 20A4      |
| MCBSPLP_WAKEUPEN_REG  | RW   | 32                    | 0x0000 00A8    | 0x4902 20A8      |
| MCBSPLP_XCCR_REG      | RW   | 32                    | 0x0000 00AC    | 0x4902 20AC      |
| MCBSPLP_RCCR_REG      | RW   | 32                    | 0x0000 00B0    | 0x4902 20B0      |
| MCBSPLP_XBUFFSTAT_REG | R    | 32                    | 0x0000 00B4    | 0x4902 20B4      |
| MCBSPLP_RBUFFSTAT_REG | R    | 32                    | 0x0000 00B8    | 0x4902 20B8      |
| MCBSPLP_SSELCR_REG    | RW   | 32                    | 0x0000 00BC    | 0x4902 20BC      |
| MCBSPLP_STATUS_REG    | R    | 32                    | 0x0000 00C0    | 0x4902 20C0      |

**Table 21-40. McBSP3 Registers Mapping Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address |
|-------------------|------|-----------------------|----------------|------------------|
| MCBSPLP_DRR_REG   | R    | 32                    | 0x0000 0000    | 0x4902 4000      |
| MCBSPLP_DXR_REG   | W    | 32                    | 0x0000 0008    | 0x4902 4008      |
| MCBSPLP_SPCR2_REG | RW   | 32                    | 0x0000 0010    | 0x4902 4010      |
| MCBSPLP_SPCR1_REG | RW   | 32                    | 0x0000 0014    | 0x4902 4014      |
| MCBSPLP_RCR2_REG  | RW   | 32                    | 0x0000 0018    | 0x4902 4018      |
| MCBSPLP_RCR1_REG  | RW   | 32                    | 0x0000 001C    | 0x4902 401C      |
| MCBSPLP_XCR2_REG  | RW   | 32                    | 0x0000 0020    | 0x4902 4020      |
| MCBSPLP_XCR1_REG  | RW   | 32                    | 0x0000 0024    | 0x4902 4024      |
| MCBSPLP_SRGR2_REG | RW   | 32                    | 0x0000 0028    | 0x4902 4028      |
| MCBSPLP_SRGR1_REG | RW   | 32                    | 0x0000 002C    | 0x4902 402C      |
| MCBSPLP_MCR2_REG  | RW   | 32                    | 0x0000 0030    | 0x4902 4030      |
| MCBSPLP_MCR1_REG  | RW   | 32                    | 0x0000 0034    | 0x4902 4034      |
| MCBSPLP_RCERA_REG | RW   | 32                    | 0x0000 0038    | 0x4902 4038      |
| MCBSPLP_RCERB_REG | RW   | 32                    | 0x0000 003C    | 0x4902 403C      |

**Table 21-40. McBSP3 Registers Mapping Summary (continued)**

| Register Name         | Type | Register Width (Bits) | Address Offset | Physical Address |
|-----------------------|------|-----------------------|----------------|------------------|
| MCBSPLP_XCERA_REG     | RW   | 32                    | 0x0000 0040    | 0x4902 4040      |
| MCBSPLP_XCERB_REG     | RW   | 32                    | 0x0000 0044    | 0x4902 4044      |
| MCBSPLP_PCR_REG       | RW   | 32                    | 0x0000 0048    | 0x4902 4048      |
| MCBSPLP_RCERC_REG     | RW   | 32                    | 0x0000 004C    | 0x4902 404C      |
| MCBSPLP_RCERD_REG     | RW   | 32                    | 0x0000 0050    | 0x4902 4050      |
| MCBSPLP_XCERC_REG     | RW   | 32                    | 0x0000 0054    | 0x4902 4054      |
| MCBSPLP_XCERD_REG     | RW   | 32                    | 0x0000 0058    | 0x4902 4058      |
| MCBSPLP_RCERE_REG     | RW   | 32                    | 0x0000 005C    | 0x4902 405C      |
| MCBSPLP_RCERF_REG     | RW   | 32                    | 0x0000 0060    | 0x4902 4060      |
| MCBSPLP_XCERE_REG     | RW   | 32                    | 0x0000 0064    | 0x4902 4064      |
| MCBSPLP_XCERF_REG     | RW   | 32                    | 0x0000 0068    | 0x4902 4068      |
| MCBSPLP_RCERG_REG     | RW   | 32                    | 0x0000 006C    | 0x4902 406C      |
| MCBSPLP_RCERH_REG     | RW   | 32                    | 0x0000 0070    | 0x4902 4070      |
| MCBSPLP_XCERG_REG     | RW   | 32                    | 0x0000 0074    | 0x4902 4074      |
| MCBSPLP_XCERH_REG     | RW   | 32                    | 0x0000 0078    | 0x4902 4078      |
| MCBSPLP_REV_REG       | R    | 32                    | 0x0000 007C    | 0x4902 407C      |
| MCBSPLP_RINTCLR_REG   | RW   | 32                    | 0x0000 0080    | 0x4902 4080      |
| MCBSPLP_XINTCLR_REG   | RW   | 32                    | 0x0000 0084    | 0x4902 4084      |
| MCBSPLP_ROVFLCLR_REG  | RW   | 32                    | 0x0000 0088    | 0x4902 4088      |
| MCBSPLP_SYSCONFIG_REG | RW   | 32                    | 0x0000 008C    | 0x4902 408C      |
| MCBSPLP_THRSH2_REG    | RW   | 32                    | 0x0000 0090    | 0x4902 4090      |
| MCBSPLP_THRSH1_REG    | RW   | 32                    | 0x0000 0094    | 0x4902 4094      |
| MCBSPLP_IRQSTATUS_REG | RW   | 32                    | 0x0000 00A0    | 0x4902 40A0      |
| MCBSPLP_IRQENABLE_REG | RW   | 32                    | 0x0000 00A4    | 0x4902 40A4      |
| MCBSPLP_WAKEUPEN_REG  | RW   | 32                    | 0x0000 00A8    | 0x4902 40A8      |
| MCBSPLP_XCCR_REG      | RW   | 32                    | 0x0000 00AC    | 0x4902 40AC      |
| MCBSPLP_RCCR_REG      | RW   | 32                    | 0x0000 00B0    | 0x4902 40B0      |
| MCBSPLP_XBUFFSTAT_REG | R    | 32                    | 0x0000 00B4    | 0x4902 40B4      |
| MCBSPLP_RBUFFSTAT_REG | R    | 32                    | 0x0000 00B8    | 0x4902 40B8      |
| MCBSPLP_SSELCR_REG    | RW   | 32                    | 0x0000 00BC    | 0x4902 40BC      |
| MCBSPLP_STATUS_REG    | R    | 32                    | 0x0000 00C0    | 0x4902 40C0      |

**Table 21-41. McBSP4 Registers Mapping Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address |
|-------------------|------|-----------------------|----------------|------------------|
| MCBSPLP_DRR_REG   | R    | 32                    | 0x0000 0000    | 0x4902 6000      |
| MCBSPLP_DXR_REG   | W    | 32                    | 0x0000 0008    | 0x4902 6008      |
| MCBSPLP_SPCR2_REG | RW   | 32                    | 0x0000 0010    | 0x4902 6010      |
| MCBSPLP_SPCR1_REG | RW   | 32                    | 0x0000 0014    | 0x4902 6014      |
| MCBSPLP_RCR2_REG  | RW   | 32                    | 0x0000 0018    | 0x4902 6018      |
| MCBSPLP_RCR1_REG  | RW   | 32                    | 0x0000 001C    | 0x4902 601C      |
| MCBSPLP_XCR2_REG  | RW   | 32                    | 0x0000 0020    | 0x4902 6020      |
| MCBSPLP_XCR1_REG  | RW   | 32                    | 0x0000 0024    | 0x4902 6024      |
| MCBSPLP_SRGR2_REG | RW   | 32                    | 0x0000 0028    | 0x4902 6028      |
| MCBSPLP_SRGR1_REG | RW   | 32                    | 0x0000 002C    | 0x4902 602C      |
| MCBSPLP_MCR2_REG  | RW   | 32                    | 0x0000 0030    | 0x4902 6030      |

**Table 21-41. McBSP4 Registers Mapping Summary (continued)**

| Register Name          | Type | Register Width (Bits) | Address Offset | Physical Address |
|------------------------|------|-----------------------|----------------|------------------|
| MCBSPPLP_MCR1_REG      | RW   | 32                    | 0x0000 0034    | 0x4902 6034      |
| MCBSPPLP_RCERA_REG     | RW   | 32                    | 0x0000 0038    | 0x4902 6038      |
| MCBSPPLP_RCERB_REG     | RW   | 32                    | 0x0000 003C    | 0x4902 603C      |
| MCBSPPLP_XCERA_REG     | RW   | 32                    | 0x0000 0040    | 0x4902 6040      |
| MCBSPPLP_XCERB_REG     | RW   | 32                    | 0x0000 0044    | 0x4902 6044      |
| MCBSPPLP_PCR_REG       | RW   | 32                    | 0x0000 0048    | 0x4902 6048      |
| MCBSPPLP_RCERC_REG     | RW   | 32                    | 0x0000 004C    | 0x4902 604C      |
| MCBSPPLP_RCERD_REG     | RW   | 32                    | 0x0000 0050    | 0x4902 6050      |
| MCBSPPLP_XCERC_REG     | RW   | 32                    | 0x0000 0054    | 0x4902 6054      |
| MCBSPPLP_XCERD_REG     | RW   | 32                    | 0x0000 0058    | 0x4902 6058      |
| MCBSPPLP_RCERE_REG     | RW   | 32                    | 0x0000 005C    | 0x4902 605C      |
| MCBSPPLP_RCERF_REG     | RW   | 32                    | 0x0000 0060    | 0x4902 6060      |
| MCBSPPLP_XCERE_REG     | RW   | 32                    | 0x0000 0064    | 0x4902 6064      |
| MCBSPPLP_XCERF_REG     | RW   | 32                    | 0x0000 0068    | 0x4902 6068      |
| MCBSPPLP_RCERG_REG     | RW   | 32                    | 0x0000 006C    | 0x4902 606C      |
| MCBSPPLP_RCERH_REG     | RW   | 32                    | 0x0000 0070    | 0x4902 6070      |
| MCBSPPLP_XCERG_REG     | RW   | 32                    | 0x0000 0074    | 0x4902 6074      |
| MCBSPPLP_XCERH_REG     | RW   | 32                    | 0x0000 0078    | 0x4902 6078      |
| MCBSPPLP_REV_REG       | R    | 32                    | 0x0000 007C    | 0x4902 607C      |
| MCBSPPLP_RINTCLR_REG   | RW   | 32                    | 0x0000 0080    | 0x4902 6080      |
| MCBSPPLP_XINTCLR_REG   | RW   | 32                    | 0x0000 0084    | 0x4902 6084      |
| MCBSPPLP_ROVFLCLR_REG  | RW   | 32                    | 0x0000 0088    | 0x4902 6088      |
| MCBSPPLP_SYSCONFIG_REG | RW   | 32                    | 0x0000 008C    | 0x4902 608C      |
| MCBSPPLP_THRSH2_REG    | RW   | 32                    | 0x0000 0090    | 0x4902 6090      |
| MCBSPPLP_THRSH1_REG    | RW   | 32                    | 0x0000 0094    | 0x4902 6094      |
| MCBSPPLP_IRQSTATUS_REG | RW   | 32                    | 0x0000 00A0    | 0x4902 60A0      |
| MCBSPPLP_IRQENABLE_REG | RW   | 32                    | 0x0000 00A4    | 0x4902 60A4      |
| MCBSPPLP_WAKEUPEN_REG  | RW   | 32                    | 0x0000 00A8    | 0x4902 60A8      |
| MCBSPPLP_XCCR_REG      | RW   | 32                    | 0x0000 00AC    | 0x4902 60AC      |
| MCBSPPLP_RCCR_REG      | RW   | 32                    | 0x0000 00B0    | 0x4902 60B0      |
| MCBSPPLP_XBUFFSTAT_REG | R    | 32                    | 0x0000 00B4    | 0x4902 60B4      |
| MCBSPPLP_RBUFFSTAT_REG | R    | 32                    | 0x0000 00B8    | 0x4902 60B8      |
| MCBSPPLP_SSELCR_REG    | RW   | 32                    | 0x0000 00BC    | 0x4902 60BC      |
| MCBSPPLP_STATUS_REG    | R    | 32                    | 0x0000 00C0    | 0x4902 60C0      |

## 21.6.2 SIDETONE Register Mapping Summary

**Table 21-42. SIDETONE\_McBSP2 Registers Mapping Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address |
|------------------|------|-----------------------|----------------|------------------|
| ST_REV_REG       | R    | 32                    | 0x0000 0000    | 0x4902 8000      |
| ST_SYSCONFIG_REG | RW   | 32                    | 0x0000 0010    | 0x4902 8010      |
| ST_IRQSTATUS_REG | RW   | 32                    | 0x0000 0018    | 0x4902 8018      |
| ST_IRQENABLE_REG | RW   | 32                    | 0x0000 001C    | 0x4902 801C      |
| ST_SGAINCR_REG   | RW   | 32                    | 0x0000 0024    | 0x4902 8024      |
| ST_SFIRCR_REG    | RW   | 32                    | 0x0000 0028    | 0x4902 8028      |
| ST_SSELCR_REG    | RW   | 32                    | 0x0000 002C    | 0x4902 802C      |

**Table 21-43. SIDETONE\_McBSP3 Registers Mapping Summary**

| Register Name    | Type | Register Width (Bits) | Address Offset | Physical Address |
|------------------|------|-----------------------|----------------|------------------|
| ST_REV_REG       | R    | 32                    | 0x0000 0000    | 0x4902 A000      |
| ST_SYSCONFIG_REG | RW   | 32                    | 0x0000 0010    | 0x4902 A010      |
| ST_IRQSTATUS_REG | RW   | 32                    | 0x0000 0018    | 0x4902 A018      |
| ST_IRQENABLE_REG | RW   | 32                    | 0x0000 001C    | 0x4902 A01C      |
| ST_SGAINCR_REG   | RW   | 32                    | 0x0000 0024    | 0x4902 A024      |
| ST_SFIRCR_REG    | RW   | 32                    | 0x0000 0028    | 0x4902 A028      |
| ST_SSELCR_REG    | RW   | 32                    | 0x0000 002C    | 0x4902 A02C      |

### 21.6.3 McBSP Register Description

**Table 21-44. MCBSPLP\_DRR\_REG**

|                  |                                                                                                                                         |                                                                                            |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--|
| Address Offset   | 0x0000 0000                                                                                                                             | Instance                                                                                   |  |
| Physical Address | 0x4807 4000<br>0x4809 6000<br>0x4902 2000<br>0x4902 4000<br>0x4902 6000<br><br>0x4809 6000<br>0x4902 2000<br>0x4902 4000<br>0x4902 6000 | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4 |  |
| Description      | McBSPLP data receive register                                                                                                           |                                                                                            |  |
| Type             | R                                                                                                                                       |                                                                                            |  |

|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| DRR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description           | Type | Reset      |
|------|------------|-----------------------|------|------------|
| 31:0 | DRR        | Data receive register | R    | 0x00000000 |

**Table 21-45. Register Call Summary for Register MCBSPLP\_DRR\_REG**

## McBSP Functional Description

- Data Transfer Process for 8- / 12- / 16- / 20- / 24- / 32-bits Long Words: [0]
- Serial Words: [1]
- McBSP Reception: [2] [3]
- Introduction: [4]
- Overrun in the Receiver: [5] [6]

## McBSP Basic Programming Model

- Programming the McBSP Registers for the Desired Receiver Configuration (Step 2): [7] [8]
- Data Packing Using Frame Length and Word Length: [9] [10]

## McBSP Register Manual

- McBSP Register Mapping Summary: [11] [12] [13] [14] [15]

**Table 21-46. MCBSPLP\_DXR\_REG**

|                         |                              |                 |        |
|-------------------------|------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 0008                  | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 4008                  |                 | McBSP5 |
|                         | 0x4809 6008                  |                 | McBSP2 |
|                         | 0x4902 2008                  |                 | McBSP3 |
|                         | 0x4902 4008                  |                 | McBSP4 |
|                         | 0x4902 6008                  |                 | McBSP5 |
|                         | 0x4809 6008                  |                 | McBSP2 |
|                         | 0x4902 2008                  |                 | McBSP3 |
|                         | 0x4902 4008                  |                 | McBSP4 |
|                         | 0x4902 6008                  |                 | McBSP1 |
| <b>Description</b>      | McBSP data transmit register |                 |        |
| <b>Type</b>             | W                            |                 |        |

  

|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| DXR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description            | Type | Reset      |
|------|------------|------------------------|------|------------|
| 31:0 | DXR        | Data transmit register | W    | 0x00000000 |

**Table 21-47. Register Call Summary for Register MCBSPLP\_DXR\_REG**

## McBSP Functional Description

- Data Transfer Process for 8- / 12- / 16- / 20- / 24- / 32-bits Long Words: [0]
- McBSP Transmission: [1] [2]
- Introduction: [3]
- Underflow in the Transmitter: [4] [5] [6] [7]
- Disabling/Enabling Versus Masking/Unmasking: [8]

## McBSP Basic Programming Model

- McBSP Initialization Procedure: [9]
- Data Packing Using Frame Length and Word Length: [10] [11]

## McBSP Register Manual

- McBSP Register Mapping Summary: [12] [13] [14] [15] [16]

**Table 21-48. MCBSPLP\_SPCR2\_REG**

|                         |                                        |                 |        |
|-------------------------|----------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 0010                            | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 4010                            |                 | McBSP5 |
|                         | 0x4809 6010                            |                 | McBSP2 |
|                         | 0x4902 2010                            |                 | McBSP3 |
|                         | 0x4902 4010                            |                 | McBSP4 |
|                         | 0x4809 6010                            |                 | McBSP5 |
|                         | 0x4902 2010                            |                 | McBSP2 |
|                         | 0x4902 4010                            |                 | McBSP3 |
|                         | 0x4902 6010                            |                 | McBSP4 |
| <b>Description</b>      | McBSPLP serial port control register 2 |                 |        |
| <b>Type</b>             | RW                                     |                 |        |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |       |          |        |      |      |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|-------|----------|--------|------|------|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FREE | SOFT | FRST | GRST | XINTM | XSYNCERR | XEMPTY | XRDY | XRST |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                        | Type | Reset    |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:10 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                  | R    | 0x000000 |
| 9     | FREE       | Free Running Mode<br>(When this bit is set, the module ignores the Msuspend input)<br><br>0x0: Free running mode is disabled<br>0x1: Free running mode is enabled                                                                                                                                  | RW   | 0x0      |
| 8     | SOFT       | Soft Bit<br><br>0x0: SOFT Mode is disabled: the McBSP module stops its activity immediately following MSuspend assertion.<br>0x1: SOFT Mode is enabled: the McBSP module freezes its state after completion of the current operation when MSuspend is asserted.                                    | RW   | 0x0      |
| 7     | FRST       | Frame-Sync Generator Reset<br><br>0x0: Frame-synchronization logic is reset. Frame-sync signal FSG is not generated by the sample-rate generator<br>0x1: Frame-sync signal FSG is generated after (FPER+1) number of CLKG clocks; i.e., all frame counters are loaded with their programmed values | RW   | 0x0      |
| 6     | GRST       | Sample-Rate Generator Reset<br><br>0x0: SRG is reset<br>0x1: SRG is pulled out of reset. CLKG is driven as per programmed value in SRG registers (SRGR[1,2])                                                                                                                                       | RW   | 0x0      |
| 5:4   | XINTM      | Transmit Interrupt Mode (legacy)<br><br>0x0: Transmit interrupt is driven by XRDY<br>0x1: Transmit interrupt generated by end-of-frame<br>0x2: Transmit interrupt generated by a new frame synchronization<br>0x3: Transmit interrupt generated by XSYNCERR                                        | RW   | 0x0      |
| 3     | XSYNCERR   | Transmit Synchronization Error<br>(writing 0 to this bit clear the legacy transmit interrupt if asserted due to XSYNCERROR condition)<br><br>0x0: No synchronization error<br>0x1: Synchronization error detected by McBSP                                                                         | RW   | 0x0      |
| 2     | XEMPTY     | Transmit Shift Register XSR Empty<br><br>0x0: XSR is empty<br>0x1: XSR is not empty                                                                                                                                                                                                                | R    | 0x0      |
| 1     | XRDY       | Transmitter ready<br><br>0x0: Transmitter is not ready.<br>0x1: Transmitter is ready for new data in DXR                                                                                                                                                                                           | R    | 0x0      |
| 0     | XRST       | Transmitter reset. This resets and enables the transmitter.<br><br>0x0: The serial port transmitter is disabled and in reset state.<br>0x1: The serial port transmitter is enabled.                                                                                                                | RW   | 0x0      |

**Table 21-49. Register Call Summary for Register MCBSPLP\_SPCR2\_REG**

## McBSP Integration

- [Hardware and Software Reset](#): [0] [1] [2]

## McBSP Functional Description

- [Data Transfer Process for 8- / 12- / 16- / 20- / 24- / 32-bits Long Words](#): [3]
- [McBSP Transmission](#): [4] [5]
- [Clock Generation in the SRG](#): [6]
- [Frame Sync Generation in the SRG](#): [7] [8]
- [Introduction](#): [9] [10] [11]
- [Underflow in the Transmitter](#): [12] [13] [14] [15] [16]
- [Possible Responses to Transmit Frame-sync Pulses](#): [17] [18] [19]
- [McBSP DMA Configuration](#): [20] [21]
- [Disabling/Enabling Versus Masking/Unmasking](#): [22] [23] [24]

## McBSP Basic Programming Model

- [McBSP Initialization Procedure](#): [25] [26] [27] [28]
- [Reset and Initialization Procedure for the Sample Rate Generator](#): [29] [30] [31] [32] [33]
- [Legacy Interrupt Line](#): [34] [35] [36]
- [Resetting \(Step 1\) and Enabling \(Step 3\) the Receiver](#): [37] [38] [39] [40] [41]
- [Resetting \(Step 1\) and Enabling \(Step 3\) the Transmitter](#): [42] [43] [44] [45] [46] [47]
- [Programming the McBSP Registers for the Desired Transmitter Operation \(Step 2\)](#): [48]
- [General-Purpose I/O on the McBSP Pins \(Legacy Only\)](#): [49] [50]

## McBSP Register Manual

- [McBSP Register Mapping Summary](#): [51] [52] [53] [54] [55]

**Table 21-50. MCBSPLP\_SPCR1\_REG**

|                         |                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |          |        |
|-------------------------|----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--------|
| <b>Address Offset</b>   | 0x0000 0014                            |  |  |  |  |  |  |  |  |  |  |  |  |  |          |        |
| <b>Physical Address</b> | 0x4807 4014                            |  |  |  |  |  |  |  |  |  |  |  |  |  | Instance | McBSP1 |
|                         | 0x4809 6014                            |  |  |  |  |  |  |  |  |  |  |  |  |  |          |        |
|                         | 0x4902 2014                            |  |  |  |  |  |  |  |  |  |  |  |  |  |          |        |
|                         | 0x4902 4014                            |  |  |  |  |  |  |  |  |  |  |  |  |  | McBSP3   | McBSP4 |
|                         | 0x4902 6014                            |  |  |  |  |  |  |  |  |  |  |  |  |  |          |        |
|                         | 0x4809 6014                            |  |  |  |  |  |  |  |  |  |  |  |  |  |          |        |
|                         | 0x4902 2014                            |  |  |  |  |  |  |  |  |  |  |  |  |  | McBSP2   | McBSP5 |
|                         | 0x4902 4014                            |  |  |  |  |  |  |  |  |  |  |  |  |  |          |        |
|                         | 0x4902 6014                            |  |  |  |  |  |  |  |  |  |  |  |  |  |          |        |
| <b>Description</b>      | McBSPLP serial port control register 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |          |        |
| <b>Type</b>             | RW                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |          |        |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-------|----------|----|----|----|-------|----------|-------|---|----------|-------|------|------|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ALB | RJUST | RESERVED |    |    |    | DXENA | RESERVED | RINTM |   | RSYNCERR | RFULL | RRDY | RRST |   |   |

| Bits  | Field Name | Description                                                                                     | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                               | R    | 0x0000 |
| 15    | ALB        | Analog loopback Mode<br>0x0: Analog loopback mode disabled<br>0x1: Analog loopback mode enabled | RW   | 0x0    |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 14:13 | RJUST      | Receive Sign-Extension and Justification Mode<br>0x0: Right-justify and zero-fill MSBs in DRR<br>0x1: Right-justify and sign-extend MSBs in DRR<br>0x2: Left-justify and zero-fill LSBs in DRR<br>0x3: Reserved                                                                                                                             | RW   | 0x0   |
| 12:8  | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                                                           | R    | 0x00  |
| 7     | DXENA      | DX Enabler<br>0x0: DX enabler is off<br>0x1: DX enabler is on                                                                                                                                                                                                                                                                               | RW   | 0x0   |
| 6     | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                                                           | R    | 0x0   |
| 5:4   | RINTM      | Receive Interrupt Mode (legacy)<br>0x0: Receive Interrupt driven by RRDY (i.e. end of word) and end of frame in A-bis mode<br>0x1: Receive Interrupt generated by end-of-block or end-of-frame in multichannel operation<br>0x2: Receive Interrupt generated by a new frame synchronization<br>0x3: Receive Interrupt generated by RSYNCERR | RW   | 0x0   |
| 3     | RSYNCERR   | Receive Synchronization Error<br>(writing 0 to this bit clear the legacy receive interrupt if asserted due to RSYNCERROR condition)<br>0x0: No synchronization error<br>0x1: Synchronization error detected by McBSP                                                                                                                        | RW   | 0x0   |
| 2     | RFULL      | Receive Shift Register (RSR) Full<br>0x0: DRR is not read, RB is full and RSR is also full with new word<br>0x1: RB is not in overrun condition                                                                                                                                                                                             | R    | 0x0   |
| 1     | RRDY       | Receiver Ready<br>0x0: Receiver is not ready<br>0x1: Receiver is ready with data to be read from DRR                                                                                                                                                                                                                                        | R    | 0x0   |
| 0     | RRST       | Receiver reset. This resets and enables the receiver.<br>0x0: The serial port receiver is disabled and in reset state.<br>0x1: The serial port receiver is enabled.                                                                                                                                                                         | RW   | 0x0   |

**Table 21-51. Register Call Summary for Register MCBSPLP\_SPCR1\_REG**
**McBSP Integration**

- [Hardware and Software Reset: \[0\]](#)

**McBSP Functional Description**

- [McBSP Reception: \[1\] \[2\] \[3\]](#)
- [Clock Generation in the SRG: \[4\]](#)
- [Introduction: \[5\] \[6\] \[7\] \[8\]](#)
- [Overrun in the Receiver: \[9\] \[10\] \[11\]](#)
- [Possible Responses to Receive Frame-sync Pulses: \[12\] \[13\] \[14\]](#)
- [McBSP DMA Configuration: \[15\] \[16\]](#)
- [Receive Multichannel Selection Mode: \[17\]](#)

**Table 21-51. Register Call Summary for Register MCBSPLP\_SPCR1\_REG (continued)**

## McBSP Basic Programming Model

- McBSP Initialization Procedure: [18] [19]
- Reset and Initialization Procedure for the Sample Rate Generator: [20] [21] [22]
- Legacy Interrupt Line: [23] [24] [25] [26]
- Resetting (Step 1) and Enabling (Step 3) the Receiver: [27] [28]
- Programming the McBSP Registers for the Desired Receiver Configuration (Step 2): [29] [30] [31] [32] [33]
- Resetting (Step 1) and Enabling (Step 3) the Transmitter: [34]
- Programming the McBSP Registers for the Desired Transmitter Operation (Step 2): [35]
- General-Purpose I/O on the McBSP Pins (Legacy Only): [36] [37]

## McBSP Register Manual

- McBSP Register Mapping Summary: [38] [39] [40] [41] [42]
- McBSP Register Description: [43]

**Table 21-52. MCBSPLP\_RCR2\_REG**

|                         |                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0018                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4807 4018                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | McBSP1          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4809 6018                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | McBSP5          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 2018                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | McBSP2          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 4018                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | McBSP3          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 6018                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | McBSP4          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | McBSPLP receive control register 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----------|----|----|----|---------|----------|---|---|---|----------|---------|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RPHASE | RFRLLEN2 |    |    |    | RWDLEN2 | RREVERSE |   |   |   | RESERVED | RDATDLY |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                      | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                | R    | 0x0000 |
| 15    | RPHASE     | Receive Phases<br>0x0: Single-phase frame<br>0x1: Dual-phase frame                                                                                                               | RW   | 0x0    |
| 14:8  | RFRLLEN2   | Receive Frame Length 2<br>Single-phase frame selected: RFRLLEN2=don't care<br>Dual-phase frame selected: RFRLLEN2=000 0000 - 1 word per second phase (other values are reserved) | RW   | 0x00   |
| 7:5   | RWDLEN2    | Receive Word Length 2<br>0x0: 8 bits<br>0x1: 12 bits<br>0x2: 16 bits<br>0x3: 20 bits<br>0x4: 24 bits<br>0x5: 32 bits<br>0x6: Reserved (do not use)<br>0x7: Reserved (do not use) | RW   | 0x0    |

| Bits | Field Name | Description                                                                                                                                                                 | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4:3  | RREVERSE   | Receive reverse mode.<br>0x0: Data transfer starts with MSB first.<br>0x1: Data transfer starts with LSB first.<br>0x2: Reserved (do not use)<br>0x3: Reserved (do not use) | RW   | 0x0   |
| 2    | RESERVED   | Read returns 0x0.                                                                                                                                                           | R    | 0x0   |
| 1:0  | RDATDLY    | Receive Data Delay<br>0x0: 0-bit data delay<br>0x1: 1-bit data delay<br>0x2: 2-bit data delay<br>0x3: Reserved                                                              | RW   | 0x0   |

**Table 21-53. Register Call Summary for Register MCBSPLP\_RCR2\_REG**

---

McBSP Environment

- [Words or Channels: \[0\]](#)
  - [Frames: \[1\] \[2\]](#)
- 

McBSP Functional Description

- [Bit Reordering \(Option to Transfer LSB First\): \[3\]](#)
  - [Serial Words: \[4\]](#)
  - [Frames and Frame Synchronization: \[5\]](#)
  - [Number of Phases, Words, and Bits per Frame: \[6\] \[7\] \[8\] \[9\]](#)
  - [Single-Phase Frame Example: \[10\] \[11\] \[12\]](#)
  - [Dual-Phase Frame Example: \[13\] \[14\] \[15\]](#)
  - [McBSP Reception: \[16\]](#)
  - [MCBSP Data Transfer Mode: \[17\]](#)
  - [Preventing Unexpected Receive Frame-sync Pulses: \[18\]](#)
  - [Configuring a Frame for Multichannel Selection: \[19\]](#)
  - [SIDETONE Interface: \[20\]](#)
- 

McBSP Basic Programming Model

- [McBSP Initialization Procedure: \[21\]](#)
  - [Programming the McBSP Registers for the Desired Receiver Configuration \(Step 2\): \[22\] \[23\] \[24\] \[25\] \[26\] \[27\]](#)
  - [SIDETONE Activation Procedure: \[28\]](#)
- 

McBSP Register Manual

- [McBSP Register Mapping Summary: \[29\] \[30\] \[31\] \[32\] \[33\]](#)
-

**Table 21-54. MCBSPLP\_RCR1\_REG**

|                         |                                    |                 |        |
|-------------------------|------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 001C                        | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 401C                        |                 | McBSP5 |
|                         | 0x4809 601C                        |                 | McBSP2 |
|                         | 0x4902 201C                        |                 | McBSP3 |
|                         | 0x4902 401C                        |                 | McBSP4 |
|                         | 0x4809 601C                        |                 | McBSP5 |
|                         | 0x4902 201C                        |                 | McBSP2 |
|                         | 0x4902 401C                        |                 | McBSP3 |
|                         | 0x4902 601C                        |                 | McBSP4 |
| <b>Description</b>      | McBSPLP receive control register 1 |                 |        |
| <b>Type</b>             | RW                                 |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |         |    |          |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|---------|----|----------|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RFRLEN1 |    |    |    | RWDLEN1 |    | RESERVED |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                   | Type | Reset   |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:15 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                             | R    | 0x00000 |
| 14:8  | RFRLEN1    | Receive Frame Length 1<br>Single-phase frame selected: RFRLEN1=000 0000 - 1 word per frame<br>RFRLEN1=000 0001 - 2 words per frame<br>RFRLEN1=111 1111 - 128 words per frame<br>Dual-phase frame selected: RFRLEN1=000 0000 - 1 word per phase<br>(other values are reserved) | RW   | 0x00    |
| 7:5   | RWDLEN1    | Receive Word Length 1<br>0x0: 8 bits<br>0x1: 12 bits<br>0x2: 16 bits<br>0x3: 20 bits<br>0x4: 24 bits<br>0x5: 32 bits<br>0x6: Reserved (do not use)<br>0x7: Reserved (do not use)                                                                                              | RW   | 0x0     |
| 4:0   | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                             | R    | 0x00    |

**Table 21-55. Register Call Summary for Register MCBSPLP\_RCR1\_REG**

## McBSP Environment

- Words or Channels: [0]
- Frames: [1]

## McBSP Functional Description

- Serial Words: [2]
- Frames and Frame Synchronization: [3]
- Number of Phases, Words, and Bits per Frame: [4] [5] [6]
- Single-Phase Frame Example: [7] [8]
- Dual-Phase Frame Example: [9] [10]
- Configuring a Frame for Multichannel Selection: [11]
- SIDETONE Interface: [12] [13]

## McBSP Basic Programming Model

- McBSP Initialization Procedure: [14]
- Programming the McBSP Registers for the Desired Receiver Configuration (Step 2): [15] [16]
- SIDETONE Activation Procedure: [17] [18]

**Table 21-55. Register Call Summary for Register MCBSPLP\_RCR1\_REG (continued)**

McBSP Register Manual

- [McBSP Register Mapping Summary: \[19\] \[20\] \[21\] \[22\] \[23\]](#)

**Table 21-56. MCBSPLP\_XCR2\_REG**

|                         |                                     |                 |        |
|-------------------------|-------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 0020                         | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 4020                         |                 | McBSP5 |
|                         | 0x4809 6020                         |                 | McBSP2 |
|                         | 0x4902 2020                         |                 | McBSP3 |
|                         | 0x4902 4020                         |                 | McBSP4 |
|                         | 0x4902 6020                         |                 | McBSP5 |
|                         | 0x4809 6020                         |                 | McBSP2 |
|                         | 0x4902 2020                         |                 | McBSP3 |
|                         | 0x4902 4020                         |                 | McBSP4 |
|                         | 0x4902 6020                         |                 | McBSP4 |
| <b>Description</b>      | McBSPLP transmit control register 2 |                 |        |
| <b>Type</b>             | RW                                  |                 |        |

| 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 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|---------|----|---------|----|----------|---|----------|---|---------|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | XPHASE |    | XFRLEN2 |    | XWDLEN2 |    | XREVERSE |   | RESERVED |   | XDATDLY |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                       | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                 | R    | 0x0000 |
| 15    | XPHASE     | Transmit Phases<br><br>0x0: Single-phase frame<br><br>0x1: Dual-phase frame                                                                                                                                       | RW   | 0x0    |
| 14:8  | XFRLEN2    | Transmit Frame Length 2<br><br>Single-phase frame selected: XFRLEN2=don't care<br><br>Dual-phase frame selected: XFRLEN2=000 0000 - 1 word per second phase (other values are reserved)                           | RW   | 0x0    |
| 7:5   | XWDLEN2    | Transmit Word Length 2<br><br>0x0: 8 bits<br><br>0x1: 12 bits<br><br>0x2: 16 bits<br><br>0x3: 20 bits<br><br>0x4: 24 bits<br><br>0x5: 32 bits<br><br>0x6: Reserved (do not use)<br><br>0x7: Reserved (do not use) | RW   | 0x0    |
| 4:3   | XREVERSE   | Transmit reverse mode.<br><br>0x0: Data transfer starts with MSB first.<br><br>0x1: Data transfer starts with LSB first.<br><br>0x2: Reserved (do not use)<br><br>0x3: Reserved (do not use)                      | RW   | 0x0    |
| 2     | RESERVED   | Read returns 0x0.                                                                                                                                                                                                 | R    | 0x0    |

| Bits | Field Name | Description                                                                                                     | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------|------|-------|
| 1:0  | XDATDLY    | Transmit Data Delay<br>0x0: 0-bit data delay<br>0x1: 1-bit data delay<br>0x2: 2-bit data delay<br>0x3: Reserved | RW   | 0x0   |

**Table 21-57. Register Call Summary for Register MCBSPLP\_XCR2\_REG**

## McBSP Environment

- [Words or Channels: \[0\]](#)
- [Frames: \[1\] \[2\]](#)

## McBSP Functional Description

- [Bit Reordering \(Option to Transfer LSB First\): \[3\]](#)
- [Serial Words: \[4\]](#)
- [Frames and Frame Synchronization: \[5\]](#)
- [Maximum Frame Frequency: \[6\]](#)
- [Number of Phases, Words, and Bits per Frame: \[7\] \[8\] \[9\] \[10\]](#)
- [Single-Phase Frame Example: \[11\] \[12\] \[13\]](#)
- [Dual-Phase Frame Example: \[14\] \[15\] \[16\]](#)
- [McBSP Transmission: \[17\]](#)
- [MCBSP Data Transfer Mode: \[18\]](#)
- [Preventing Unexpected Transmit Frame-sync Pulses: \[19\]](#)
- [Configuring a Frame for Multichannel Selection: \[20\]](#)
- [SIDETONE Interface: \[21\]](#)

## McBSP Basic Programming Model

- [McBSP Initialization Procedure: \[22\]](#)
- [Programming the McBSP Registers for the Desired Transmitter Operation \(Step 2\): \[23\] \[24\] \[25\] \[26\] \[27\]](#)
- [SIDETONE Activation Procedure: \[28\]](#)

## McBSP Register Manual

- [McBSP Register Mapping Summary: \[29\] \[30\] \[31\] \[32\] \[33\]](#)

**Table 21-58. MCBSPLP\_XCR1\_REG**

|                                                                                             |                                                                                                                                         |                                                                                            |                    |
|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------|
| <b>Address Offset</b>                                                                       | 0x0000 0024                                                                                                                             | <b>Instance</b>                                                                            |                    |
| <b>Physical Address</b>                                                                     | 0x4807 4024<br>0x4809 6024<br>0x4902 2024<br>0x4902 4024<br>0x4902 6024<br><br>0x4809 6024<br>0x4902 2024<br>0x4902 4024<br>0x4902 6024 | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4 |                    |
| <b>Description</b>                                                                          | McBSPLP transmit control register 1                                                                                                     |                                                                                            |                    |
| <b>Type</b>                                                                                 | RW                                                                                                                                      |                                                                                            |                    |
| 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 | RESERVED                                                                                                                                | XFRLEN1                                                                                    | XWDLEN1   RESERVED |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                          | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:15 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                    | R    | 0x00000 |
| 14:8  | XFRLEN1    | Transmit Frame Length 1<br>Single-phase frame selected:<br>XFRLEN1=000 0000 - 1 word per frame<br>XFRLEN1=000 0001 - 2 words per frame<br>XFRLEN1=111 1111 - 128 words per frame<br>Dual-phase frame selected:<br>XFRLEN1=000 0000 - 1 word per phase<br>(other values are reserved) | RW   | 0x00    |
| 7:5   | XWDLEN1    | Transmit Word Length 1<br>0x0: 8 bits<br>0x1: 12 bits<br>0x2: 16 bits<br>0x3: 20 bits<br>0x4: 24 bits<br>0x5: 32 bits<br>0x6: Reserved (do not use)<br>0x7: Reserved (do not use)                                                                                                    | RW   | 0x0     |
| 4:0   | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                    | R    | 0x00    |

**Table 21-59. Register Call Summary for Register MCBSPLP\_XCR1\_REG**

---

McBSP Environment

- [Words or Channels: \[0\]](#)
  - [Frames: \[1\]](#)
- 

McBSP Functional Description

- [Serial Words: \[2\]](#)
  - [Frames and Frame Synchronization: \[3\]](#)
  - [Number of Phases, Words, and Bits per Frame: \[4\] \[5\] \[6\]](#)
  - [Single-Phase Frame Example: \[7\] \[8\]](#)
  - [Dual-Phase Frame Example: \[9\] \[10\]](#)
  - [Configuring a Frame for Multichannel Selection: \[11\]](#)
  - [SIDETONE Interface: \[12\] \[13\]](#)
- 

McBSP Basic Programming Model

- [McBSP Initialization Procedure: \[14\]](#)
  - [Programming the McBSP Registers for the Desired Transmitter Operation \(Step 2\): \[15\] \[16\]](#)
  - [SIDETONE Activation Procedure: \[17\] \[18\]](#)
- 

McBSP Register Manual

- [McBSP Register Mapping Summary: \[19\] \[20\] \[21\] \[22\] \[23\]](#)
-

**Table 21-60. MCBSPLP\_SRGR2\_REG**

|                         |                        |                 |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |
|-------------------------|------------------------|-----------------|--|--|--|--|--|--|--|--------|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0028            |                 |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4807 4028            | <b>Instance</b> |  |  |  |  |  |  |  | McBSP1 |  |  |  |  |  |  |  |  |
|                         | 0x4809 6028            |                 |  |  |  |  |  |  |  | McBSP5 |  |  |  |  |  |  |  |  |
|                         | 0x4902 2028            |                 |  |  |  |  |  |  |  | McBSP2 |  |  |  |  |  |  |  |  |
|                         | 0x4902 4028            |                 |  |  |  |  |  |  |  | McBSP3 |  |  |  |  |  |  |  |  |
|                         | 0x4902 6028            |                 |  |  |  |  |  |  |  | McBSP4 |  |  |  |  |  |  |  |  |
|                         | 0x4809 6028            |                 |  |  |  |  |  |  |  | McBSP5 |  |  |  |  |  |  |  |  |
|                         | 0x4902 2028            |                 |  |  |  |  |  |  |  | McBSP2 |  |  |  |  |  |  |  |  |
|                         | 0x4902 4028            |                 |  |  |  |  |  |  |  | McBSP3 |  |  |  |  |  |  |  |  |
|                         | 0x4902 6028            |                 |  |  |  |  |  |  |  | McBSP4 |  |  |  |  |  |  |  |  |
| <b>Description</b>      | McBSPLP SRG register 2 |                 |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                     |                 |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |       |       |      |      |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-------|-------|------|------|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | GSYNC | CLKSP | CLKSM | FSGM | FPER |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R    | 0x0000 |
| 15    | GSYNC      | Sample Rate Generator Synchronization<br>Only used when the external clock (CLKS) drives the SRG clock (CLKSM=0)<br><br>0x0: The SRG clock (CLKG) is free running.<br>0x1: The SRG clock (CLKG) is running.<br>But CLKG is resynchronized and frame-sync signal (FSG) is generated only after detecting the receive frame-synchronization signal (FSR). Also, frame period, FPER, is a don't care because the period is dictated by the external frame-sync pulse. | RW   | 0x0    |
| 14    | CLKSP      | CLKS Polarity Clock Edge Select<br>Only used when the external clock CLKS drives the SRG clock (CLKSM=0).<br><br>0x0: Rising edge of CLKG and FSG.<br>0x1: Falling edge of CLKG and FSG.                                                                                                                                                                                                                                                                           | RW   | 0x0    |
| 13    | CLKSM      | McBSP SRG Clock Mode<br><br>0x0:<br>SCLKME=0: SRG clock derived from the CLKS pin.<br>SCLKME=1: SRG clock derived from the CLKR input pin.<br><br>0x1:<br>SCLKME=0: SRG clock derived from the McBSPi_ICLK clock.<br>SCLKME=1: SRG clock derived from the CLKX input pin.                                                                                                                                                                                          | RW   | 0x1    |
| 12    | FSGM       | Sample Rate Generator Transmit Frame-Synchronization Mode<br>Used when FSXM=1 in the PCR.<br><br>0x0: Transmit frame-sync signal (FSX) is generated when transmit buffer is not empty.<br>When FSGM=0, FPER and FWID are used to determine the frame synchronization period and width (external FSX is gated by the buffer empty condition).<br><br>0x1: Transmit frame-sync signal driven by the SRG frame-sync signal, FSG.                                      | RW   | 0x0    |
| 11:0  | FPER       | Frame Period. This value + 1 determines when the next frame-sync signal becomes active.<br>Range: 1 to 4096 CLKG periods                                                                                                                                                                                                                                                                                                                                           | RW   | 0x000  |

**Table 21-61. Register Call Summary for Register MCBSPLP\_SRGR2\_REG**
**McBSP Integration**

- [McBSP1 Clocks: \[0\]](#)
- [McBSP2 Clocks: \[1\]](#)
- [McBSP3 Clocks: \[2\]](#)
- [McBSP4 Clocks: \[3\]](#)
- [McBSP5 Clocks: \[4\]](#)

**McBSP Functional Description**

- [Clocking and Framing Data: \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\]](#)
- [Frames and Frame Synchronization: \[17\] \[18\]](#)
- [McBSP SRG: \[19\] \[20\] \[21\] \[22\]](#)
- [Frame Sync Generation in the SRG: \[23\] \[24\]](#)
- [Controlling the Period Between the Starting Edges of Frame Sync Pulses: \[25\] \[26\]](#)
- [Keeping FSG Synchronized to an External Clock: \[27\] \[28\] \[29\]](#)
- [Synchronizing SRG Outputs to an External Clock: \[30\] \[31\] \[32\] \[33\] \[34\]](#)
- [Operating the Transmitter Synchronously with the Receiver: \[35\] \[36\]](#)
- [Synchronization Examples: \[37\] \[38\]](#)
- [Underflow in the Transmitter: \[39\] \[40\] \[41\]](#)

**McBSP Basic Programming Model**

- [McBSP Initialization Procedure: \[42\]](#)
- [Reset and Initialization Procedure for the Sample Rate Generator: \[43\]](#)
- [Programming the McBSP Registers for the Desired Receiver Configuration \(Step 2\): \[44\] \[45\] \[46\] \[47\] \[48\] \[49\]](#)
- [Programming the McBSP Registers for the Desired Transmitter Operation \(Step 2\): \[50\] \[51\]](#)

**McBSP Register Manual**

- [McBSP Register Mapping Summary: \[52\] \[53\] \[54\] \[55\] \[56\]](#)

**Table 21-62. MCBSPLP\_SRGR1\_REG**

|                         |                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 002C                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4807 402C<br>0x4809 602C<br>0x4902 202C<br>0x4902 402C<br>0x4902 602C<br><br>0x4809 602C<br>0x4902 202C<br>0x4902 402C<br>0x4902 602C |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | Instance                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | McBSPLP SRG register 1                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |        |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|--------|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FWID |    |    |    | CLKGDV |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                              | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                        | R    | 0x0000 |
| 15:8  | FWID       | Frame Width. This value + 1 determines the width of the frame-sync pulse, FSG, during its active period.<br>Range: 1 to 256 CLKG periods.                | RW   | 0x00   |
| 7:0   | CLKGDV     | Sample Rate Generator Clock Divider<br>This value is used as the divide-down number to generate the required SRG clock frequency.<br>Default value is 1. | RW   | 0x01   |

**Table 21-63. Register Call Summary for Register MCBSPLP\_SRGR1\_REG**

## McBSP Functional Description

- [Clocking: \[0\]](#)
- [McBSP SRG: \[1\] \[2\] \[3\]](#)
- [Frame Sync Generation in the SRG: \[4\]](#)
- [Choosing the Width of the Frame-sync Pulse: \[5\]](#)
- [Synchronization Examples: \[6\] \[7\]](#)
- [Underflow in the Transmitter: \[8\]](#)

## McBSP Basic Programming Model

- [McBSP Initialization Procedure: \[9\]](#)
- [Programming the McBSP Registers for the Desired Receiver Configuration \(Step 2\): \[10\] \[11\]](#)

## McBSP Register Manual

- [McBSP Register Mapping Summary: \[12\] \[13\] \[14\] \[15\] \[16\]](#)

**Table 21-64. MCBSPLP\_MCR2\_REG**

|                         |                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0030                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4807 4030<br>0x4809 6030<br>0x4902 2030<br>0x4902 4030<br>0x4902 6030<br><br>0x4809 6030<br>0x4902 2030<br>0x4902 4030<br>0x4902 6030 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | Instance                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | McBSPLP multi channel register 2                                                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------|--------|--------|----------|------|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | XMCME | XPBBLK | XPABLK | RESERVED | XMCM |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:10       | RESERVED          | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R           | 0x000000     |
| 9           | XMCME             | <p>Transmit multichannel partition mode determines whether only 32 channels or all 128 channels are to be individually selectable.</p> <p>XMCME is only applicable if channels can be individually disabled/enabled or masked/unmasked for transmission (XMCM is nonzero).</p> <p>0x0: 2-partition mode: Only partitions A and B are used. You can control up to 32 channels in the transmit multichannel selection mode selected with the XMCM bits.</p> <p>If XMCM = 01b or 10b, assign 16 channels to partition A with the XPABLK bits. Assign 16 channels to partition B with the XPBBLK bits.</p> <p>If XMCM = 11b (for symmetric transmission and reception), assign 16 channels to receive partition A with the RPABLK bits. Assign 16 channels to receive partition B with the RPBBLK bits.</p> <p>You control the channels with the appropriate transmit channel enable registers:</p> <p>XCERA: Channels in partition A<br/>           XCERB: Channels in partition B</p> <p>0x1: 8-partition mode: All partitions (A through H) are used.</p> <p>You can control up to 128 channels in the transmit multichannel selection mode selected with the XMCM bits.</p> <p>You control the channels with the appropriate transmit channel enable registers:</p> <p>XCERA: Channels 0 through 15<br/>           XCERB: Channels 16 through 31<br/>           XCERC: Channels 32 through 47<br/>           XCERD: Channels 48 through 63<br/>           XCERE: Channels 64 through 79<br/>           XCERF: Channels 80 through 95<br/>           XCERG: Channels 96 through 111<br/>           XCERH: Channels 112 through 127</p> | RW          | 0x0          |
| 8:7         | XPBBLK            | <p>Transmit Partition B Block (legacy)</p> <p>0x0: Block 1. Channel 16 to channel 31<br/>           0x1: Block 3. Channel 48 to channel 63<br/>           0x2: Block 5. Channel 80 to channel 95<br/>           0x3: Block 7. Channel 112 to channel 127</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW          | 0x0          |
| 6:5         | XPABLK            | <p>Transmit Partition A Block (legacy)</p> <p>0x0: Block 0. Channel 0 to channel 15<br/>           0x1: Block 2. Channel 32 to channel 47<br/>           0x2: Block 4. Channel 64 to channel 79<br/>           0x3: Block 6. Channel 96 to channel 111</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW          | 0x0          |
| 4:2         | RESERVED          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R           | 0x0          |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1:0  | XMCM       | <p>Transmit Multichannel Selection Enable</p> <p>0x0: All channels enabled without masking (DX is always driven during transmission of data).</p> <p>0x1: All channels disabled and therefore masked by default.</p> <p>Required channels are selected by enabling XP(A/B)BLK and XCER(A/B) appropriately. Also, these selected channels are not masked and therefore DX is always driven.</p> <p>0x2: All channels enabled, but masked.</p> <p>Selected channels enabled via XP(A/B)BLK and XCER(A/B) are unmasked.</p> <p>0x3: All channels disabled and therefore masked by default.</p> <p>Required channels are selected by enabling RP(A/B)BLK and RCER(A/B) appropriately. Selected channels can be unmasked by RP(A/B)BLK and XCER(A/B). This mode is used for symmetric transmit and receive operation.</p> | RW   | 0x0   |

**Table 21-65. Register Call Summary for Register MCBSPLP\_MCR2\_REG**

## McBSP Functional Description

- Using Eight Partitions: [0] [1] [2]
- Using Two Partitions (Legacy Only): [3] [4]
- Transmit Multichannel Selection Modes: [5] [6] [7] [8]
- Activity on McBSP Pins for Different Values of XMCM: [9] [10]

## McBSP Basic Programming Model

- McBSP Initialization Procedure: [11]
- Programming the McBSP Registers for the Desired Transmitter Operation (Step 2): [12]

## McBSP Register Manual

- McBSP Register Mapping Summary: [13] [14] [15] [16] [17]

**Table 21-66. MCBSPLP\_MCR1\_REG**

|                  |                                                                                                                                         |                                                                                            |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--|
| Address Offset   | 0x0000 0034                                                                                                                             | Instance                                                                                   |  |
| Physical Address | 0x4807 4034<br>0x4809 6034<br>0x4902 2034<br>0x4902 4034<br>0x4902 6034<br><br>0x4809 6034<br>0x4902 2034<br>0x4902 4034<br>0x4902 6034 | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4 |  |
| Description      | McBSPLP multi channel register 1                                                                                                        |                                                                                            |  |
| Type             | RW                                                                                                                                      |                                                                                            |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |        |        |          |    |    |   |   |   |      |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|--------|--------|----------|----|----|---|---|---|------|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RMCM | RPBBLK | RPABLK | RESERVED |    |    |   |   |   | RMCM |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset    |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:10 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R    | 0x000000 |
| 9     | RMCME      | <p>Receive multichannel partition mode determines whether only 32 channels or all 128 channels are to be individually selectable.</p> <p>RMCME is only applicable if channels can be individually enabled or disabled for reception (RMCM = 1).</p> <p>0x0: 2-partition mode. Only partitions A and B are used. You can control up to 32 channels in the receive multichannel selection mode (RMCN = 1). Assign 16 channels to partition A with the RPABLK bits. Assign 16 channels to partition B with the RPBLK bits. You control the channels with the appropriate receive channel enable registers:</p> <p>RCERA: Channels in partition A<br/>RCERB: Channels in partition B</p> <p>0x1: 8-partition mode: All partitions (A through H) are used. You can control up to 128 channels in the receive multichannel selection mode. You control the channels with the appropriate receive channel enable registers:</p> <p>RCERA: Channels 0 through 15<br/>RCERB: Channels 16 through 31<br/>RCERC: Channels 32 through 47<br/>RCERD: Channels 48 through 63<br/>RCERE: Channels 64 through 79<br/>RCERF: Channels 80 through 95<br/>RCERG: Channels 96 through 111<br/>RCERH: Channels 112 through 127</p> | RW   | 0x0      |
| 8:7   | RPBBLK     | <p>Receive Partition B Block (legacy)</p> <p>0x0: Block 1. Channel 16 to channel 31<br/>0x1: Block 3. Channel 48 to channel 63<br/>0x2: Block 5. Channel 80 to channel 95<br/>0x3: Block 7. Channel 112 to channel 127</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0x0      |
| 6:5   | RPABLK     | <p>Receive Partition A Block (legacy)</p> <p>0x0: Block 0. Channel 0 to channel 15<br/>0x1: Block 2. Channel 32 to channel 47<br/>0x2: Block 4. Channel 64 to channel 79<br/>0x3: Block 6. Channel 96 to channel 111</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW   | 0x0      |
| 4:1   | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R    | 0x0      |
| 0     | RMCM       | <p>Receive Multichannel Selection Enable</p> <p>0x0: All 128 channels<br/>0x1: All channels disabled by default.<br/>Required channels are selected by enabling RP(A/B)BLK and RCER(A/B) appropriately</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0x0      |

**Table 21-67. Register Call Summary for Register MCBSPLP\_MCR1\_REG**
**McBSP Functional Description**

- [Using Eight Partitions: \[0\] \[1\] \[2\]](#)
- [Receive Multichannel Selection Mode: \[3\] \[4\]](#)
- [Using Two Partitions \(Legacy Only\): \[5\] \[6\] \[7\] \[8\]](#)
- [SIDETONE Interface: \[9\]](#)

**McBSP Basic Programming Model**

- [McBSP Initialization Procedure: \[10\]](#)
- [Programming the McBSP Registers for the Desired Receiver Configuration \(Step 2\): \[11\]](#)
- [SIDETONE Activation Procedure: \[12\]](#)

**Table 21-67. Register Call Summary for Register MCBSPLP\_MCR1\_REG (continued)**

McBSP Register Manual

- McBSP Register Mapping Summary: [13] [14] [15] [16] [17]

**Table 21-68. MCBSPLP\_RCERA\_REG**

|                         |                                                                                                                                                                                                                                                                                                     |                 |                                                                                                        |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0038                                                                                                                                                                                                                                                                                         |                 |                                                                                                        |
| <b>Physical Address</b> | <a href="#">0x4807 4038</a><br><a href="#">0x4809 6038</a><br><a href="#">0x4902 2038</a><br><a href="#">0x4902 4038</a><br><a href="#">0x4902 6038</a><br><br><a href="#">0x4809 6038</a><br><br><a href="#">0x4902 2038</a><br><br><a href="#">0x4902 4038</a><br><br><a href="#">0x4902 6038</a> | <b>Instance</b> | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br><br>McBSP2<br><br>McBSP3<br><br>McBSP4 |
| <b>Description</b>      | McBSPLP receive channel enable register partition A                                                                                                                                                                                                                                                 |                 |                                                                                                        |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                  |                 |                                                                                                        |

RESERVED RCERA

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                      | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:16       | RESERVED          | Read returns 0x0.                                                                                                                                                                                       | R           | 0x0000       |
| 15:0        | RCERA             | Receive Channel Enable<br>RCERA n=0 Disables reception of n-th channel in an even-numbered block in partition A<br>RCERA n=1 Enables reception of n-th channel in an even-numbered block in partition A | RW          | 0x0000       |

**Table 21-69. Register Call Summary for Register MCBSPLP\_RCERA\_REG**

## McBSP Functional Description

- Using Eight Partitions: [0]
  - Receive Multichannel Selection Mode: [1] [2]
  - Using Two Partitions (Legacy Only): [3]
  - Transmit Multichannel Selection Modes: [4] [5]

McBSP Register Manual

- McBSP Register Mapping Summary: [6] [7] [8] [9] [10]

**Table 21-70. MCBSPLP\_RCERB\_REG**

| <b>Address Offset</b>   | 0x0000 003C                                                                                                                             |                                                                                                                                                                                                               |  |  |  |  |  |  |                       |                 |  |  |  |  |  |      |        |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|-----------------------|-----------------|--|--|--|--|--|------|--------|
| <b>Physical Address</b> | 0x4807 403C<br>0x4809 603C<br>0x4902 203C<br>0x4902 403C<br>0x4902 603C<br><br>0x4809 603C<br>0x4902 203C<br>0x4902 403C<br>0x4902 603C |                                                                                                                                                                                                               |  |  |  |  |  |  |                       |                 |  |  |  |  |  |      |        |
|                         | Instance                                                                                                                                |                                                                                                                                                                                                               |  |  |  |  |  |  |                       |                 |  |  |  |  |  |      |        |
|                         | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4                                              |                                                                                                                                                                                                               |  |  |  |  |  |  |                       |                 |  |  |  |  |  |      |        |
| <b>Description</b>      | McBSPLP receive channel enable register partition B                                                                                     |                                                                                                                                                                                                               |  |  |  |  |  |  |                       |                 |  |  |  |  |  |      |        |
| <b>Type</b>             | RW                                                                                                                                      |                                                                                                                                                                                                               |  |  |  |  |  |  |                       |                 |  |  |  |  |  |      |        |
| 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 |  |  |  |  |  |      |        |
|                         | RESERVED                                                                                                                                |                                                                                                                                                                                                               |  |  |  |  |  |  |                       | RCERB           |  |  |  |  |  |      |        |
| Bits                    | Field Name                                                                                                                              | <b>Description</b>                                                                                                                                                                                            |  |  |  |  |  |  |                       |                 |  |  |  |  |  | Type | Reset  |
| 31:16                   | RESERVED                                                                                                                                | Read returns 0x0.                                                                                                                                                                                             |  |  |  |  |  |  |                       |                 |  |  |  |  |  | R    | 0x0000 |
| 15:0                    | RCERB                                                                                                                                   | Receive Channel Enable<br><br>RCERB n=0 Disables reception of n-th channel in a even-numbered block in partition B<br><br>RCERB n=1 Enables reception of n-th channel in a even-numbered block in partition B |  |  |  |  |  |  |                       |                 |  |  |  |  |  | RW   | 0x0000 |

**Table 21-71. Register Call Summary for Register MCBSPLP\_RCERB\_REG**

McBSP Functional Description

- [Using Eight Partitions: \[0\]](#)
- [Using Two Partitions \(Legacy Only\): \[1\]](#)

McBSP Register Manual

- [McBSP Register Mapping Summary: \[2\] \[3\] \[4\] \[5\] \[6\]](#)

**Table 21-72. MCBSPLP\_XCERA\_REG**

|                         |                                                                                                                                         |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|-----------------------|-----------------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0040                                                                                                                             |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4807 4040<br>0x4809 6040<br>0x4902 2040<br>0x4902 4040<br>0x4902 6040<br><br>0x4809 6040<br>0x4902 2040<br>0x4902 4040<br>0x4902 6040 |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
|                         | Instance                                                                                                                                |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
|                         | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4                                              |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
| <b>Description</b>      | McBSPLP transmit channel enable register partition A                                                                                    |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                      |  |  |  |  |  |  |  |                       |                 |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |
|                         | RESERVED                                                                                                                                |  |  |  |  |  |  |  |                       | XCERA           |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                      | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                | R    | 0x0000 |
| 15:0  | XCERA      | Transmit Channel Enable<br>XCERA n=0 Disables transmission of n-th channel in an event-numbered block in partition A<br>XCERA n=1 Enables transmission of n-th channel in an event-numbered block in partition A | RW   | 0x0000 |

**Table 21-73. Register Call Summary for Register MCBSPLP\_XCERA\_REG**

McBSP Functional Description

- Using Eight Partitions: [0]
- Using Two Partitions (Legacy Only): [1]
- Transmit Multichannel Selection Modes: [2] [3] [4] [5] [6] [7]

McBSP Register Manual

- McBSP Register Mapping Summary: [8] [9] [10] [11] [12]

**Table 21-74. MCBSPLP\_XCERB\_REG**

|                  |                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 0044                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | 0x4807 4044<br>0x4809 6044<br>0x4902 2044<br>0x4902 4044<br>0x4902 6044<br><br>0x4809 6044<br>0x4902 2044<br>0x4902 4044<br>0x4902 6044 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | Instance                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | McBSPLP transmit channel enable register partition B                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | RW                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                    | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                                              | R    | 0x0000 |
| 15:0  | XCERB      | Transmit Channel Enable<br>XCERB n=0 Disables transmission of n-th channel in an even-numbered block in partition B<br>XCERB n=1 Enables transmission of n-th channel in an even-numbered block in partition B | RW   | 0x0000 |

**Table 21-75. Register Call Summary for Register MCBSPLP\_XCERB\_REG**

McBSP Functional Description

- Using Eight Partitions: [0]
- Using Two Partitions (Legacy Only): [1]

McBSP Register Manual

- McBSP Register Mapping Summary: [2] [3] [4] [5] [6]

**Table 21-76. MCBSPLP\_PCR\_REG**

|                         |                              |                 |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--------|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0048                  |                 |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4807 4048                  | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  | McBSP1 |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4809 6048                  | McBSP5          |  |  |  |  |  |  |  |  |  |  |  | McBSP2 |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 2048                  | McBSP2          |  |  |  |  |  |  |  |  |  |  |  | McBSP3 |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 4048                  | McBSP3          |  |  |  |  |  |  |  |  |  |  |  | McBSP4 |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 6048                  |                 |  |  |  |  |  |  |  |  |  |  |  | McBSP5 |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4809 6048                  |                 |  |  |  |  |  |  |  |  |  |  |  | McBSP2 |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 2048                  |                 |  |  |  |  |  |  |  |  |  |  |  | McBSP3 |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 4048                  |                 |  |  |  |  |  |  |  |  |  |  |  | McBSP4 |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | McBSPLP pin control register |                 |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                           |                 |  |  |  |  |  |  |  |  |  |  |  |        |  |  |  |  |  |  |  |  |  |  |  |  |



| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    | Type | Reset   |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:15 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                              | R    | 0x00000 |
| 14    | IDLE_EN    | Idle enable. This bit allows stopping all the clocks in the McBSP module.<br><br>(legacy)<br><br>0x0: The McBSP is running<br><br>0x1: The clocks in the McBSP are shut off when both IDLE_EN=1 and his power domain is in idle mode (Force idle or Smart idle)                                                                                                                                                                                | RW   | 0x0     |
| 13    | XIOEN      | Transmit General Purpose I/O Mode only when XRST=0 in SPCR[1,2]<br><br>(legacy)<br><br>0x0: DX, FSX and CLKX are configured as serial port pins and do not function as general-purpose I/Os.<br><br>0x1: DX pin is a general purpose output. FSX and CLKX are general purpose I/Os. These serial port pins do not perform serial port operation.                                                                                               | RW   | 0x0     |
| 12    | RIOEN      | Receive General Purpose I/O Mode when RRST=0 in SPCR[1,2]<br><br>(legacy)<br><br>0x0: DR, FSR, CLKR and CLKS are configured as serial port pins and do not function as general-purpose I/Os.<br><br>0x1: DR and CLKS pins are general purpose inputs; FSR and CLKR are general purpose I/Os. These serial port pins do not perform serial port operation. The CLKS pin is affected by a combination of RRST and RIOEN signals of the receiver. | RW   | 0x0     |
| 11    | FSXM       | Transmit Frame-Synchronization Mode<br><br>0x0: Frame-synchronization signal derived from an external source<br><br>0x1: Frame synchronization is determined by the SRG frame-synchronization mode bit FSGM in SRGR2.                                                                                                                                                                                                                          | RW   | 0x0     |
| 10    | FSRM       | Receive Frame-Synchronization Mode<br><br>0x0: Frame-Synchronization pulses generated by an external device. FSR is an input pin.<br><br>0x1: Frame synchronization generated internally by SRG. FSR is an output pin except when GSYNC=1 in SRGR.                                                                                                                                                                                             | RW   | 0x0     |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                               | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 9    | CLKXM      | <p>Transmitter Clock Mode</p> <p>When digital loop-back mode set (McBSPi.MCBSPLP_XCCR_REG[5] DLB=1), CLKXM bit is ignored. The internal transmit clock (not the mcbspi_clkx pin) is driven by the internal SRG and mcbspi_clkx pin is in high-impedance.</p> <p>0x0: Transmitter clock is driven by an external clock with CLKX as an input pin.</p> <p>0x1: CLKX is an output pin and is driven by the internal SRG.</p> | RW   | 0x0   |
| 8    | CLKRM      | <p>Receiver Clock Mode</p> <p>When digital loop-back mode set (McBSPi.MCBSPLP_XCCR_REG[5] DLB=1), CLKRM bit is ignored. The internal receive lock (not the mcbsp1_clkr pin) is driven by the internal SRG and mcbsp1_clkr pin is in high-impedance.</p> <p>0x0: Receive clock is an input driven by an external clock with CLKR as an input pin.</p> <p>0x1: CLKR is an output pin and is driven by the internal SRG.</p> | RW   | 0x0   |
| 7    | SCLKME     | <p>The frequency of CLKG is:<br/> <math>\text{CLKG frequency} = (\text{Input clock frequency}) / (\text{CLKGDV} + 1)</math></p> <p>SCLKME is used in conjunction with the CLKSM bit to select the input clock:</p> <p>0x0:<br/>     CLKSM = 0: Signal on CLKS pin<br/>     CLKSM = 1: McBSPi_ICLK clock</p> <p>0x1:<br/>     CLKSM = 0: Signal on CLKR pin<br/>     CLKSM = 1: Signal on CLKX pin</p>                     | RW   | 0x0   |
| 6    | CLKS_STAT  | <p>CLKS pin status. Reflects value on CLKS pin when selected as a general purpose input.<br/> <small>(legacy)</small></p> <p>0x0: The signal on the CLKS pin is low</p> <p>0x1: The signal on the CLKS pin is high</p>                                                                                                                                                                                                    | R    | 0x0   |
| 5    | DX_STAT    | <p>DX pin status. Reflects value driven on to DX pin when selected as a general purpose output.<br/> <small>(legacy)</small></p> <p>0x0: Drive the signal on the DX pin low</p> <p>0x1: Drive the signal on the DX pin high</p>                                                                                                                                                                                           | RW   | 0x0   |
| 4    | DR_STAT    | <p>DR pin status. Reflects value on DR pin when selected as a general purpose input.<br/> <small>(legacy)</small></p> <p>0x0: The signal on DR pin is low</p> <p>0x1: The signal on DR pin is high</p>                                                                                                                                                                                                                    | R    | 0x0   |
| 3    | FSXP       | <p>Transmit Frame-Synchronization Polarity</p> <p>0x0: Frame-synchronization pulse FSX is active high</p> <p>0x1: Frame-synchronization pulse FSX is active low</p>                                                                                                                                                                                                                                                       | RW   | 0x0   |
| 2    | FSRP       | <p>Receive Frame-Synchronization Polarity</p> <p>0x0: Frame-synchronization pulse FSR is active high</p> <p>0x1: Frame-synchronization pulse FSR is active low</p>                                                                                                                                                                                                                                                        | RW   | 0x0   |
| 1    | CLKXP      | <p>Transmit Clock Polarity</p> <p>0x0: Transmit data driven on rising edge of CLKX</p> <p>0x1: Transmit data driven on falling edge of CLKX</p>                                                                                                                                                                                                                                                                           | RW   | 0x0   |

| Bits | Field Name | Description                                                                                                                     | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | CLKRP      | Receive Clock Polarity<br>0x0: Receive data sampled on falling edge of CLKR<br>0x1: Receive data sampled on rising edge of CLKR | RW   | 0x0   |

**Table 21-77. Register Call Summary for Register MCBSPLP\_PCR\_REG**

---

McBSP Environment

- [Words or Channels: \[0\]](#)
  - [Frames: \[1\]](#)
- 

McBSP Integration

- [McBSP1 Clocks: \[2\]](#)
  - [McBSP2 Clocks: \[3\]](#)
  - [McBSP3 Clocks: \[4\]](#)
  - [McBSP4 Clocks: \[5\]](#)
  - [McBSP5 Clocks: \[6\]](#)
  - [McBSP Acknowledgment Modes: \[7\]](#)
  - [Analysis of the Receiver Smart-Idle Behavior: \[8\] \[9\]](#)
- 

McBSP Functional Description

- [Clocking and Framing Data: \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\] \[22\] \[23\]](#)
  - [Clocking: \[24\] \[25\] \[26\] \[27\] \[28\] \[29\] \[30\]](#)
  - [Frames and Frame Synchronization: \[31\] \[32\] \[33\] \[34\] \[35\] \[36\] \[37\]](#)
  - [Detecting Frame-Synchronization Pulses, Even in Reset State: \[38\] \[39\] \[40\] \[41\]](#)
  - [Single-Phase Frame Example: \[42\] \[43\] \[44\] \[45\]](#)
  - [Dual-Phase Frame Example: \[46\] \[47\] \[48\] \[49\]](#)
  - [MCBSP Data Transfer Mode: \[50\] \[51\]](#)
  - [McBSP SRG: \[52\] \[53\] \[54\] \[55\] \[56\]](#)
  - [Clock Generation in the SRG: \[57\] \[58\] \[59\] \[60\]](#)
  - [Frame Sync Generation in the SRG: \[61\] \[62\]](#)
  - [Operating the Transmitter Synchronously with the Receiver: \[63\] \[64\] \[65\] \[66\]](#)
  - [Underflow in the Transmitter: \[67\]](#)
- 

McBSP Basic Programming Model

- [McBSP Initialization Procedure: \[68\]](#)
  - [Reset and Initialization Procedure for the Sample Rate Generator: \[69\] \[70\]](#)
  - [Programming the McBSP Registers for the Desired Receiver Configuration \(Step 2\): \[71\] \[72\] \[73\] \[74\] \[75\] \[76\] \[77\] \[78\] \[79\] \[80\] \[81\] \[82\]](#)
  - [Programming the McBSP Registers for the Desired Transmitter Operation \(Step 2\): \[83\] \[84\] \[85\] \[86\] \[87\] \[88\]](#)
  - [General-Purpose I/O on the McBSP Pins \(Legacy Only\): \[89\] \[90\] \[91\] \[92\] \[93\] \[94\]](#)
- 

McBSP Register Manual

- [McBSP Register Mapping Summary: \[95\] \[96\] \[97\] \[98\] \[99\]](#)
-

**Table 21-78. MCBSPLP\_RCERC\_REG**

|                         |                                                     |                 |        |
|-------------------------|-----------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 004C                                         | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 404C                                         |                 | McBSP5 |
|                         | 0x4809 604C                                         |                 | McBSP2 |
|                         | 0x4902 204C                                         |                 | McBSP3 |
|                         | 0x4902 404C                                         |                 | McBSP4 |
|                         | 0x4902 604C                                         |                 | McBSP5 |
|                         | 0x4809 604C                                         |                 | McBSP2 |
|                         | 0x4902 204C                                         |                 | McBSP3 |
|                         | 0x4902 404C                                         |                 | McBSP4 |
|                         | 0x4902 604C                                         |                 | McBSP1 |
| <b>Description</b>      | McBSPLP receive channel enable register partition C |                 |        |
| <b>Type</b>             | RW                                                  |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RCERC |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                             | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                                       | R    | 0x0000 |
| 15:0  | RCERC      | Receive Channel Enable<br>RCERC n=0 Disables reception of n-th channel in an even-numbered block in partition C<br>RCERC n=1 Enables reception of n-th channel in an even-numbered block in partition C | RW   | 0x0000 |

**Table 21-79. Register Call Summary for Register MCBSPLP\_RCERC\_REG**

McBSP Functional Description

- Using Eight Partitions: [0]

McBSP Register Manual

- McBSP Register Mapping Summary: [1] [2] [3] [4] [5]

**Table 21-80. MCBSPLP\_RCERD\_REG**

|                         |                                                     |                 |        |
|-------------------------|-----------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 0050                                         | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 4050                                         |                 | McBSP5 |
|                         | 0x4809 6050                                         |                 | McBSP2 |
|                         | 0x4902 2050                                         |                 | McBSP3 |
|                         | 0x4902 4050                                         |                 | McBSP4 |
|                         | 0x4902 6050                                         |                 | McBSP5 |
|                         | 0x4809 6050                                         |                 | McBSP2 |
|                         | 0x4902 2050                                         |                 | McBSP3 |
|                         | 0x4902 4050                                         |                 | McBSP4 |
|                         | 0x4902 6050                                         |                 | McBSP1 |
| <b>Description</b>      | McBSPLP receive channel enable register partition D |                 |        |
| <b>Type</b>             | RW                                                  |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RCERD |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                           | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                     | R    | 0x0000 |
| 15:0  | RCERD      | Receive Channel Enable                                                                | RW   | 0x0000 |
|       |            | RCERD n=0 Disables reception of n-th channel in an even-numbered block in partition D |      |        |
|       |            | RCERD n=1 Enables reception of n-th channel in an even-numbered block in partition D  |      |        |

**Table 21-81. Register Call Summary for Register MCBSPLP\_RCERD\_REG**

McBSP Functional Description

- [Using Eight Partitions: \[0\]](#)

McBSP Register Manual

- [McBSP Register Mapping Summary: \[1\] \[2\] \[3\] \[4\] \[5\]](#)

**Table 21-82. MCBSPLP\_XCERC\_REG**

|                         |                                                                                                                                         |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|-------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0054                                                                                                                             |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4807 4054<br>0x4809 6054<br>0x4902 2054<br>0x4902 4054<br>0x4902 6054<br><br>0x4809 6054<br>0x4902 2054<br>0x4902 4054<br>0x4902 6054 |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
|                         | Instance                                                                                                                                |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
|                         | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4                                              |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | McBSPLP transmit channel enable register partition C                                                                                    |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                      |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                                                                                                                         |                       |                 |  |  |  |  | XCERC |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                               | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                         | R    | 0x0000 |
| 15:0  | XCERC      | Transmit Channel Enable                                                                   | RW   | 0x0000 |
|       |            | XCERC n=0 Disables transmission of n-th channel in an event-numbered block in partition C |      |        |
|       |            | XCERC n=1 Enables transmission of n-th channel in an event-numbered block in partition C  |      |        |

**Table 21-83. Register Call Summary for Register MCBSPLP\_XCERC\_REG**

McBSP Functional Description

- [Using Eight Partitions: \[0\]](#)

McBSP Register Manual

- [McBSP Register Mapping Summary: \[1\] \[2\] \[3\] \[4\] \[5\]](#)

**Table 21-84. MCBSPLP\_XCERD\_REG**

|                         |                                                      |                 |        |
|-------------------------|------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 0058                                          | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 4058                                          |                 | McBSP5 |
|                         | 0x4809 6058                                          |                 | McBSP2 |
|                         | 0x4902 2058                                          |                 | McBSP3 |
|                         | 0x4902 4058                                          |                 | McBSP4 |
|                         | 0x4902 6058                                          |                 | McBSP5 |
|                         | 0x4809 6058                                          |                 | McBSP2 |
|                         | 0x4902 2058                                          |                 | McBSP3 |
|                         | 0x4902 4058                                          |                 | McBSP4 |
|                         | 0x4902 6058                                          |                 | McBSP1 |
| <b>Description</b>      | McBSPLP transmit channel enable register partition D |                 |        |
| <b>Type</b>             | RW                                                   |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | XCERD |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                    | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                                              | R    | 0x0000 |
| 15:0  | XCERD      | Transmit Channel Enable<br>XCERD n=0 Disables transmission of n-th channel in an even-numbered block in partition D<br>XCERD n=1 Enables transmission of n-th channel in an even-numbered block in partition D | RW   | 0x0000 |

**Table 21-85. Register Call Summary for Register MCBSPLP\_XCERD\_REG**

McBSP Functional Description

- Using Eight Partitions: [0]

McBSP Register Manual

- McBSP Register Mapping Summary: [1] [2] [3] [4] [5]

**Table 21-86. MCBSPLP\_RCERE\_REG**

|                         |                                                     |                 |        |
|-------------------------|-----------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 005C                                         | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 405C                                         |                 | McBSP5 |
|                         | 0x4809 605C                                         |                 | McBSP2 |
|                         | 0x4902 205C                                         |                 | McBSP3 |
|                         | 0x4902 405C                                         |                 | McBSP4 |
|                         | 0x4902 605C                                         |                 | McBSP5 |
|                         | 0x4809 605C                                         |                 | McBSP2 |
|                         | 0x4902 205C                                         |                 | McBSP3 |
|                         | 0x4902 405C                                         |                 | McBSP4 |
|                         | 0x4902 605C                                         |                 | McBSP1 |
| <b>Description</b>      | McBSPLP receive channel enable register partition E |                 |        |
| <b>Type</b>             | RW                                                  |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RCERE |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                           | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                     | R    | 0x0000 |
| 15:0  | RCERE      | Receive Channel Enable                                                                | RW   | 0x0000 |
|       |            | RCERE n=0 Disables reception of n-th channel in an even-numbered block in partition E |      |        |
|       |            | RCERE n=1 Enables reception of n-th channel in an even-numbered block in partition E  |      |        |

**Table 21-87. Register Call Summary for Register MCBSPLP\_RCERE\_REG**

McBSP Functional Description

- [Using Eight Partitions: \[0\]](#)

McBSP Register Manual

- [McBSP Register Mapping Summary: \[1\] \[2\] \[3\] \[4\] \[5\]](#)

**Table 21-88. MCBSPLP\_RCERF\_REG**

|                         |                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0060                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4807 4060<br>0x4809 6060<br>0x4902 2060<br>0x4902 4060<br>0x4902 6060<br><br>0x4809 6060<br>0x4902 2060<br>0x4902 4060<br>0x4902 6060 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | Instance                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | McBSPLP receive channel enable register partition F                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         | RCERF                 |                 |

| Bits  | Field Name | Description                                                                           | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                     | R    | 0x0000 |
| 15:0  | RCERF      | Receive Channel Enable                                                                | RW   | 0x0000 |
|       |            | RCERF n=0 Disables reception of n-th channel in an even-numbered block in partition F |      |        |
|       |            | RCERF n=1 Enables reception of n-th channel in an even-numbered block in partition F  |      |        |

**Table 21-89. Register Call Summary for Register MCBSPLP\_RCERF\_REG**

McBSP Functional Description

- [Using Eight Partitions: \[0\]](#)

McBSP Register Manual

- [McBSP Register Mapping Summary: \[1\] \[2\] \[3\] \[4\] \[5\]](#)

**Table 21-90. MCBSPLP\_XCERE\_REG**

| <b>Address Offset</b>   | 0x0000 0064                                          | <b>Instance</b>                                                                                                                                                                                                  | McBSP1          |        |
|-------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------|
| <b>Physical Address</b> | 0x4807 4064                                          |                                                                                                                                                                                                                  | McBSP5          |        |
|                         | 0x4809 6064                                          |                                                                                                                                                                                                                  | McBSP2          |        |
|                         | 0x4902 2064                                          |                                                                                                                                                                                                                  | McBSP3          |        |
|                         | 0x4902 4064                                          |                                                                                                                                                                                                                  | McBSP4          |        |
|                         | 0x4902 6064                                          |                                                                                                                                                                                                                  | McBSP5          |        |
|                         | 0x4809 6064                                          |                                                                                                                                                                                                                  | McBSP2          |        |
|                         | 0x4902 2064                                          |                                                                                                                                                                                                                  | McBSP3          |        |
|                         | 0x4902 4064                                          |                                                                                                                                                                                                                  | McBSP4          |        |
|                         | 0x4902 6064                                          |                                                                                                                                                                                                                  | McBSP4          |        |
| <b>Description</b>      | McBSPLP transmit channel enable register partition E |                                                                                                                                                                                                                  |                 |        |
| <b>Type</b>             | RW                                                   |                                                                                                                                                                                                                  |                 |        |
| 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 |        |
| RESERVED                |                                                      |                                                                                                                                                                                                                  |                 |        |
| XCERE                   |                                                      |                                                                                                                                                                                                                  |                 |        |
| Bits                    | Field Name                                           | Description                                                                                                                                                                                                      | Type            | Reset  |
| 31:16                   | RESERVED                                             | Read returns 0x0.                                                                                                                                                                                                | R               | 0x0000 |
| 15:0                    | XCERE                                                | Transmit Channel Enable<br>XCERE n=0 Disables transmission of n-th channel in an event-numbered block in partition E<br>XCERE n=1 Enables transmission of n-th channel in an event-numbered block in partition E | RW              | 0x0000 |

**Table 21-91. Register Call Summary for Register MCBSPLP\_XCERE\_REG**

McBSP Functional Description

- Using Eight Partitions: [0]

McBSP Register Manual

- McBSP Register Mapping Summary: [1] [2] [3] [4] [5]

**Table 21-92. MCBSPLP\_XCERF\_REG**

|                         |                                                      |                       |                 |
|-------------------------|------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0068                                          | <b>Instance</b>       | McBSP1          |
| <b>Physical Address</b> | 0x4807 4068                                          |                       | McBSP5          |
|                         | 0x4809 6068                                          |                       | McBSP2          |
|                         | 0x4902 2068                                          |                       | McBSP3          |
|                         | 0x4902 4068                                          |                       | McBSP4          |
|                         | 0x4902 6068                                          |                       | McBSP5          |
|                         | 0x4809 6068                                          |                       | McBSP2          |
|                         | 0x4902 2068                                          |                       | McBSP3          |
|                         | 0x4902 4068                                          |                       | McBSP4          |
|                         | 0x4902 6068                                          |                       | McBSP4          |
| <b>Description</b>      | McBSPLP transmit channel enable register partition F |                       |                 |
| <b>Type</b>             | RW                                                   |                       |                 |
| 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 |
| RESERVED                |                                                      |                       |                 |
| XCERF                   |                                                      |                       |                 |

| Bits  | Field Name | Description                                                                                                                                                                                                            | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                      | R    | 0x0000 |
| 15:0  | XCERF      | Transmit Channel Enable<br><br>XCERF n=0 Disables transmission of n-th channel in an even-numbered block in partition F<br><br>XCERF n=1 Enables transmission of n-th channel in an even-numbered block in partition F | RW   | 0x0000 |

**Table 21-93. Register Call Summary for Register MCBSPLP\_XCERF\_REG**

McBSP Functional Description

- [Using Eight Partitions: \[0\]](#)

McBSP Register Manual

- [McBSP Register Mapping Summary: \[1\] \[2\] \[3\] \[4\] \[5\]](#)

**Table 21-94. MCBSPLP\_RCERG\_REG**

|                         |                                                     |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------|-----------------------|-----------------|--|--|--|--|-------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 006C                                         |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4807 406C                                         |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4809 606C                                         |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 206C                                         |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 406C                                         |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 606C                                         |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4809 606C                                         |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 206C                                         |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 406C                                         |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 606C                                         |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | McBSPLP receive channel enable register partition G |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                  |                       |                 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                |                                                     |                       |                 |  |  |  |  | RCERG |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                     | Type | Reset  |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                                               | R    | 0x0000 |
| 15:0  | RCERG      | Receive Channel Enable<br><br>RCERG n=0 Disables reception of n-th channel in an even-numbered block in partition G<br><br>RCERG n=1 Enables reception of n-th channel in an even-numbered block in partition G | RW   | 0x0000 |

**Table 21-95. Register Call Summary for Register MCBSPLP\_RCERG\_REG**

McBSP Functional Description

- [Using Eight Partitions: \[0\]](#)

McBSP Register Manual

- [McBSP Register Mapping Summary: \[1\] \[2\] \[3\] \[4\] \[5\]](#)

**Table 21-96. MCBSPLP\_RCERH\_REG**

|                         |                                                                                                                                         |                 |                                                                                            |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0070                                                                                                                             |                 |                                                                                            |
| <b>Physical Address</b> | 0x4807 4070<br>0x4809 6070<br>0x4902 2070<br>0x4902 4070<br>0x4902 6070<br><br>0x4809 6070<br>0x4902 2070<br>0x4902 4070<br>0x4902 6070 | <b>Instance</b> | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4 |
| <b>Description</b>      | McBSPLP receive channel enable register partition H                                                                                     |                 |                                                                                            |
| <b>Type</b>             | RW                                                                                                                                      |                 |                                                                                            |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RCERH |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                             | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                                       | R    | 0x0000 |
| 15:0  | RCERH      | Receive Channel Enable<br>RCERH n=0 Disables reception of n-th channel in an even-numbered block in partition H<br>RCERH n=1 Enables reception of n-th channel in an even-numbered block in partition H | RW   | 0x0000 |

**Table 21-97. Register Call Summary for Register MCBSPLP\_RCERH\_REG**

## McBSP Functional Description

- Using Eight Partitions: [0]
- Receive Multichannel Selection Mode: [1] [2]
- Transmit Multichannel Selection Modes: [3] [4]

## McBSP Register Manual

- McBSP Register Mapping Summary: [5] [6] [7] [8] [9]

**Table 21-98. MCBSPLP\_XCERG\_REG**

|                         |                                                                                                                                         |                 |                                                                                            |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0074                                                                                                                             |                 |                                                                                            |
| <b>Physical Address</b> | 0x4807 4074<br>0x4809 6074<br>0x4902 2074<br>0x4902 4074<br>0x4902 6074<br><br>0x4809 6074<br>0x4902 2074<br>0x4902 4074<br>0x4902 6074 | <b>Instance</b> | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4 |
| <b>Description</b>      | McBSPLP transmit channel enable register partition G                                                                                    |                 |                                                                                            |
| <b>Type</b>             | RW                                                                                                                                      |                 |                                                                                            |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | XCERG |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                              | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                        | R    | 0x0000 |
| 15:0  | XCERG      | Transmit Channel Enable<br><br>XCERG n=0 Disables transmission of n-th channel in an event-numbered block in partition G<br><br>XCERG n=1 Enables transmission of n-th channel in an event-numbered block in partition G | RW   | 0x0000 |

**Table 21-99. Register Call Summary for Register MCBSPLP\_XCERG\_REG**

McBSP Functional Description

- [Using Eight Partitions: \[0\]](#)

McBSP Register Manual

- [McBSP Register Mapping Summary: \[1\] \[2\] \[3\] \[4\] \[5\]](#)

**Table 21-100. MCBSPLP\_XCERH\_REG**

|                         |                                                                                                                                                                                                                                                                                         |                       |                 |          |  |  |  |  |  |  |  |       |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--|--|--|--|--|--|--|-------|--|--|--|
| <b>Address Offset</b>   | 0x0000 0078                                                                                                                                                                                                                                                                             |                       |                 |          |  |  |  |  |  |  |  |       |  |  |  |
| <b>Physical Address</b> | <a href="#">0x4807 4078</a><br><a href="#">0x4809 6078</a><br><a href="#">0x4902 2078</a><br><a href="#">0x4902 4078</a><br><a href="#">0x4902 6078</a><br><br><a href="#">0x4809 6078</a><br><a href="#">0x4902 2078</a><br><a href="#">0x4902 4078</a><br><a href="#">0x4902 6078</a> |                       |                 |          |  |  |  |  |  |  |  |       |  |  |  |
|                         | Instance                                                                                                                                                                                                                                                                                |                       |                 |          |  |  |  |  |  |  |  |       |  |  |  |
|                         | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4                                                                                                                                                                                              |                       |                 |          |  |  |  |  |  |  |  |       |  |  |  |
| <b>Description</b>      | McBSPLP transmit channel enable register partition H                                                                                                                                                                                                                                    |                       |                 |          |  |  |  |  |  |  |  |       |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                      |                       |                 |          |  |  |  |  |  |  |  |       |  |  |  |
| 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 | RESERVED |  |  |  |  |  |  |  | XCERH |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                            | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                      | R    | 0x0000 |
| 15:0  | XCERH      | Transmit Channel Enable<br><br>XCERH n=0 Disables transmission of n-th channel in an even-numbered block in partition H<br><br>XCERH n=1 Enables transmission of n-th channel in an even-numbered block in partition H | RW   | 0x0000 |

**Table 21-101. Register Call Summary for Register MCBSPLP\_XCERH\_REG**

McBSP Functional Description

- [Using Eight Partitions: \[0\]](#)
- [Transmit Multichannel Selection Modes: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\]](#)

McBSP Register Manual

- [McBSP Register Mapping Summary: \[7\] \[8\] \[9\] \[10\] \[11\]](#)

**Table 21-102. MCBSPLP\_REV\_REG**

|                         |                                  |                 |        |
|-------------------------|----------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 007C                      | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 407C                      |                 | McBSP5 |
|                         | 0x4809 607C                      |                 | McBSP2 |
|                         | 0x4902 207C                      |                 | McBSP3 |
|                         | 0x4902 407C                      |                 | McBSP4 |
|                         | 0x4902 607C                      |                 | McBSP5 |
|                         | 0x4809 607C                      |                 | McBSP2 |
|                         | 0x4902 207C                      |                 | McBSP3 |
|                         | 0x4902 407C                      |                 | McBSP4 |
|                         | 0x4902 607C                      |                 | McBSP1 |
| <b>Description</b>      | MCBSPLP Revision number register |                 |        |
| <b>Type</b>             | R                                |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | REV |   |   |   |   |   |

| Bits | Field Name | Description                                                                                         | Type | Reset              |
|------|------------|-----------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | RESERVED   | Read returns 0x0.                                                                                   | R    | 0x0000000          |
| 7:0  | REV        | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision<br>examples: 0x10 for 1.0, 0x21 for 2.1 | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 21-103. Register Call Summary for Register MCBSPLP\_REV\_REG**

- McBSP Register Manual
- McBSP Register Mapping Summary: [\[0\]](#) [\[1\]](#) [\[2\]](#) [\[3\]](#) [\[4\]](#)

**Table 21-104. MCBSPLP\_RINTCLR\_REG**

|                         |                                 |                 |        |
|-------------------------|---------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 0080                     | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 4080                     |                 | McBSP5 |
|                         | 0x4809 6080                     |                 | McBSP2 |
|                         | 0x4902 2080                     |                 | McBSP3 |
|                         | 0x4902 4080                     |                 | McBSP4 |
|                         | 0x4902 6080                     |                 | McBSP5 |
|                         | 0x4809 6080                     |                 | McBSP2 |
|                         | 0x4902 2080                     |                 | McBSP3 |
|                         | 0x4902 4080                     |                 | McBSP4 |
|                         | 0x4902 6080                     |                 | McBSP1 |
| <b>Description</b>      | McBSPLP receive interrupt clear |                 |        |
| <b>Type</b>             | RW                              |                 |        |

|         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RINTCLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                  | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | RINTCLR    | Read from this register will clear the IRQ generated by receive end-of-frame indication or mcbsp1_fsr detection.<br>(legacy) | RW   | 0x00000000 |

**Table 21-105. Register Call Summary for Register MCBSPLP\_RINTCLR\_REG**


---

 McBSP Register Manual

- [McBSP Register Mapping Summary: \[0\] \[1\] \[2\] \[3\] \[4\]](#)
- 

**Table 21-106. MCBSPLP\_XINTCLR\_REG**

|                         |                                                                                                                                         |                 |                                                                                            |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------|--|
| <b>Address Offset</b>   | 0x0000 0084                                                                                                                             |                 |                                                                                            |  |
| <b>Physical Address</b> | 0x4807 4084<br>0x4809 6084<br>0x4902 2084<br>0x4902 4084<br>0x4902 6084<br><br>0x4809 6084<br>0x4902 2084<br>0x4902 4084<br>0x4902 6084 | <b>Instance</b> | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4 |  |
| <b>Description</b>      | McBSPLP transmit interrupt clear (legacy)                                                                                               |                 |                                                                                            |  |
| <b>Type</b>             | RW                                                                                                                                      |                 |                                                                                            |  |

|         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| XINTCLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                              | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | XINTCLR    | Read from this register will clear the IRQ generated by transmit end-of-frame indication or mcbspi_fsx detection (l=1:5). Write to this register has no effect. (legacy) | RW   | 0x00000000 |

**Table 21-107. Register Call Summary for Register MCBSPLP\_XINTCLR\_REG**


---

 McBSP Register Manual

- [McBSP Register Mapping Summary: \[0\] \[1\] \[2\] \[3\] \[4\]](#)
- 

**Table 21-108. MCBSPLP\_ROVFLCLR\_REG**

|                         |                                                                                                                                         |                 |                                                                                            |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------|--|
| <b>Address Offset</b>   | 0x0000 0088                                                                                                                             |                 |                                                                                            |  |
| <b>Physical Address</b> | 0x4807 4088<br>0x4809 6088<br>0x4902 2088<br>0x4902 4088<br>0x4902 6088<br><br>0x4809 6088<br>0x4902 2088<br>0x4902 4088<br>0x4902 6088 | <b>Instance</b> | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4 |  |
| <b>Description</b>      | McBSPLP receive overflow interrupt clear                                                                                                |                 |                                                                                            |  |
| <b>Type</b>             | RW                                                                                                                                      |                 |                                                                                            |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| ROVFLCLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                    | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | ROVFLCLR   | Read from this register will clear the IRQ generated by the receive overflow condition.<br>Write to this register has no effect.<br>((legacy)) | RW   | 0x00000000 |

**Table 21-109. Register Call Summary for Register MCBSPLP\_ROVFLCLR\_REG**

McBSP Register Manual

- [McBSP Register Mapping Summary: \[0\] \[1\] \[2\] \[3\] \[4\]](#)

**Table 21-110. MCBSPLP\_SYSCONFIG\_REG**

|                         |                                                                                                                                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |               |          |           |           |           |          |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|---------------|----------|-----------|-----------|-----------|----------|
| <b>Address Offset</b>   | 0x0000 008C                                                                                                                             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |               |          |           |           |           |          |
| <b>Physical Address</b> | 0x4807 408C<br>0x4809 608C<br>0x4902 208C<br>0x4902 408C<br>0x4902 608C<br><br>0x4809 608C<br>0x4902 208C<br>0x4902 408C<br>0x4902 608C |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |               |          |           |           |           |          |
|                         | Instance                                                                                                                                |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |               |          |           |           |           |          |
|                         | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4                                              |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |               |          |           |           |           |          |
| <b>Description</b>      | McBSPLP System Configuration register                                                                                                   |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |               |          |           |           |           |          |
| <b>Type</b>             | RW                                                                                                                                      |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |               |          |           |           |           |          |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |               |          |           |           |           |          |
| RESERVED                |                                                                                                                                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | CLOCKACTIVITY | RESERVED | SIDLEMODE | ENAWAKEUP | SOFTRESET | RESERVED |

| Bits  | Field Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset     |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:10 | RESERVED      | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R    | 0x0000000 |
| 9:8   | CLOCKACTIVITY | 0x0: The McBSP <sub>i</sub> _ICLK clock can be switched off.<br>The PRCM functional clock can be switched off.<br><br>0x1: The McBSP <sub>i</sub> _ICLK clock must be maintained during wakeup.<br>The PRCM functional clock can be switched off.<br><br>0x2: The McBSP <sub>i</sub> _ICLK clock can be switched off.<br>The PRCM functional clock must be maintained during wakeup.<br><br>0x3: The McBSP <sub>i</sub> _ICLK clock must be maintained during wakeup.<br>The PRCM functional clock must be maintained during wakeup. | RW   | 0x0       |
| 7:5   | RESERVED      | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R    | 0x0       |
| 4:3   | SIDLEMODE     | Slave interface power management, idle request / acknowledge control:<br><br>0x0: Force-idle. An idle request is acknowledged unconditionally.<br>0x1: No-idle. An idle request is never acknowledged.<br>0x2: Smart-idle. Acknowledgment to an idle request is given based on the internal activity of the module<br>0x3: Reserved                                                                                                                                                                                                  | RW   | 0x0       |
| 2     | ENAWAKEUP     | Wake-up feature control:<br><br>0x0: Wake-up is disabled<br>0x1: Wake-up capability is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0x0       |
| 1     | SOFTRESET     | McBSP global software reset<br><br>0x0: NO soft reset<br>0x1: Soft reset triggered                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0x0       |
| 0     | RESERVED      | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R    | 0x0       |

**Table 21-111. Register Call Summary for Register MCBSPLP\_SYSCONFIG\_REG**

## McBSP Integration

- [Hardware and Software Reset: \[0\]](#)
- [McBSP Acknowledgment Modes: \[1\] \[2\] \[3\] \[4\]](#)
- [Wake-Up Capability: \[5\]](#)
- [Analysis of the Receiver Smart-Idle Behavior: \[6\]](#)

## McBSP Basic Programming Model

- [McBSP Initialization Procedure: \[7\]](#)

## McBSP Register Manual

- [McBSP Register Mapping Summary: \[8\] \[9\] \[10\] \[11\] \[12\]](#)

**Table 21-112. MCBSPLP\_THRSH2\_REG**

|                         |                                                                                                                                         |                 |                                                                                            |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0090                                                                                                                             |                 |                                                                                            |
| <b>Physical Address</b> | 0x4807 4090<br>0x4809 6090<br>0x4902 2090<br>0x4902 4090<br>0x4902 6090<br><br>0x4809 6090<br>0x4902 2090<br>0x4902 4090<br>0x4902 6090 | <b>Instance</b> | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4 |
| <b>Description</b>      | McBSPLP transmit buffer threshold (DMA or IRQ trigger)                                                                                  |                 |                                                                                            |
| <b>Type</b>             | RW                                                                                                                                      |                 |                                                                                            |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         |                       | XTHRESHOLD      |

| Bits                | Field Name | Description                                                                                                                                                                                                                                                                                                                                                             | Type | Reset    |
|---------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:11               | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                       | R    | 0x000000 |
| 10:0 <sup>(1)</sup> | XTHRESHOLD | Transmit buffer threshold value. The DMA request (if enabled) of interrupt assertion (if enabled) is triggered if the number of free locations in the transmit buffer are above or equal to the XTHRESHOLD value + 1. Also, this value (XTHRESHOLD value + 1) indicates the number of words transferred during a transmit data DMA request, if transmit DMA is enabled. | RW   | 0x00     |

<sup>(1)</sup> XTHRESHOLD is an 11-bit field for McBSP2 only. For other McBSPs, XTHRESHOLD is an 8-bit field (bits 7 to 10 are reserved). In other words, the other McBSPs are limited to a FIFO width of 0x7F.

**Table 21-113. Register Call Summary for Register MCBSPLP\_THRSH2\_REG**

## McBSP Integration

- [Wake-Up Capability: \[0\]](#)

## McBSP Functional Description

- [McBSP Transmission: \[1\]](#)
- [McBSP DMA Configuration: \[2\]](#)

## McBSP Basic Programming Model

- [McBSP Initialization Procedure: \[3\]](#)
- [Data Transfer DMA Request Configuration: \[4\]](#)
- [Programming the McBSP Registers for the Desired Transmitter Operation \(Step 2\): \[5\]](#)

## McBSP Register Manual

- [McBSP Register Mapping Summary: \[6\] \[7\] \[8\] \[9\] \[10\]](#)

**Table 21-114. MCBSPLP\_THRSH1\_REG**

|                         |                                                       |                 |        |
|-------------------------|-------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 0094                                           | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 4094                                           |                 | McBSP5 |
|                         | 0x4809 6094                                           |                 | McBSP2 |
|                         | 0x4902 2094                                           |                 | McBSP3 |
|                         | 0x4902 4094                                           |                 | McBSP4 |
|                         | 0x4809 6094                                           |                 | McBSP5 |
|                         | 0x4902 2094                                           |                 | McBSP2 |
|                         | 0x4902 4094                                           |                 | McBSP3 |
|                         | 0x4902 6094                                           |                 | McBSP4 |
| <b>Description</b>      | McBSPLP receive buffer threshold (DMA or IRQ trigger) |                 |        |
| <b>Type</b>             | RW                                                    |                 |        |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RTHRESHOLD |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits                | Field Name | Description                                                                                                                                                                                                                                                                                                                                                             | Type | Reset    |
|---------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:11               | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                       | R    | 0x000000 |
| 10:0 <sup>(1)</sup> | RTHRESHOLD | Receive buffer threshold value. The DMA request (if enabled) of interrupt assertion (if enabled) is triggered if the number of occupied locations in the receive buffer are above or equal to the RTHRESHOLD value + 1. Also, this value (RTHRESHOLD value + 1) indicates the number of words transferred during a receive data DMA request, if receive DMA is enabled. | RW   | 0x00     |

<sup>(1)</sup> RTHRESHOLD is an 11-bit field for McBSP2 only. For other McBSPs, RTHRESHOLD is an 8-bit field (bits 7 to 10 are reserved). In other words, the other McBSPs are limited to a FIFO width of 0x7F.

**Table 21-115. Register Call Summary for Register MCBSPLP\_THRSH1\_REG**

## McBSP Integration

- [Wake-Up Capability: \[0\]](#)

## McBSP Functional Description

- [McBSP Reception: \[1\]](#)
- [McBSP DMA Configuration: \[2\]](#)

## McBSP Basic Programming Model

- [Data Transfer DMA Request Configuration: \[3\]](#)
- [Programming the McBSP Registers for the Desired Receiver Configuration \(Step 2\): \[4\]](#)

## McBSP Register Manual

- [McBSP Register Mapping Summary: \[5\] \[6\] \[7\] \[8\] \[9\]](#)

**Table 21-116. MCBSPLP\_IRQSTATUS\_REG**

|                         |                                                            |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 00A0                                                |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4807 40A0                                                | <b>Instance</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4809 60A0                                                | McBSP1          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 20A0                                                | McBSP5          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 40A0                                                | McBSP2          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4902 60A0                                                | McBSP3          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4809 60A0                                                | McBSP4          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | McBSPLP Interrupt Status register (OCP compliant IRQ line) |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                         |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                     | Type | Reset   |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:15 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                               | R    | 0x00000 |
| 14    | XEMPTYEOF  | Transmit Buffer Empty at end of frame (XEMPTYEOF is set to one when a complete frame was transmitted and the transmit buffer is empty). Writing 1 to this bit clears the bit.<br><br>0x0: Transmit buffer NOT Empty at end of frame<br>0x1: Transmit buffer Empty at end of frame; Writing 1 to this bit clears the bit.                                                                        | RW   | 0x0     |
| 13    | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                               | R    | 0x0     |
| 12    | XOVFLSTAT  | Transmit Buffer Overflow (XOVFLSTAT bit is set to one when transmit buffer overflow; the data which is written while overflow condition is discarded). Writing 1 to this bit clears the bit.<br><br>0x0: Transmit buffer NOT overflow<br>0x1: Transmit buffer overflow; Writing 1 to this bit clears the bit.                                                                                   | RW   | 0x0     |
| 11    | XUNDFLSTAT | Transmit Buffer Underflow (XUNDFLSTAT bit is set to one when the transmit data buffer is empty new data is required to be transmitted). Writing 1 to this bit clears the bit.<br><br>0x0: the transmit data buffer is NOT empty new data is required to be transmitted.<br>0x1: the transmit data buffer is empty new data is required to be transmitted. Writing 1 to this bit clears the bit. | RW   | 0x0     |
| 10    | XRDY       | Transmit Buffer Threshold Reached (XRDY bit is set to one when the transmit buffer free locations are equal or above the THRSH2_REG value). Writing 1 to this bit clears the bit.<br><br>0x0: Transmit buffer occupied locations are below the THRSH2_REG value.<br>0x1: Transmit buffer occupied locations are equal or above the THRSH2_REG value). Writing 1 to this bit clears the bit.     | RW   | 0x0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 9           | XEOF              | <p>Transmit End Of Frame (XEOF is set to one when a complete frame was transmitted). Writing 1 to this bit clears the bit.</p> <p>0x0: complete frame was NOT transmitted</p> <p>0x1: complete frame was transmitted; Writing 1 to this bit clears the bit.</p>                                                                                                                                                                                                                                      | RW          | 0x0          |
| 8           | XFSX              | <p>Transmit Frame Synchronization (XFSX bit is set to one when a new transmit frame synchronization is asserted). Writing 1 to this bit clears the bit.</p> <p>0x0: new transmit frame synchronization is NOT asserted</p> <p>0x1: new transmit frame synchronization is asserted; Writing 1 to this bit clears the bit.</p>                                                                                                                                                                         | RW          | 0x0          |
| 7           | XSYNCERR          | <p>Transmit Frame Synchronization Error (XSYNCERR is set to one when a transmit frame synchronization error is detected). Writing 1 to this bit clears the bit.</p> <p>0x0: Transmit frame synchronization error is NOT detected</p> <p>0x1: Transmit frame synchronization error is detected. Writing 1 to this bit clears the bit.</p>                                                                                                                                                             | RW          | 0x0          |
| 6           | RESERVED          | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R           | 0x0          |
| 5           | ROVFLSTAT         | <p>Receive Buffer Overflow (ROVFLSTAT bit is set to one when receive buffer overflow; the data which is written while overflow condition is discarded). Writing 1 to this bit clears the bit.</p> <p>0x0: receive buffer NOT overflow</p> <p>0x1: receive buffer overflow; Writing 1 to this bit clears the bit.</p>                                                                                                                                                                                 | RW          | 0x0          |
| 4           | RUNDFLSTAT        | <p>Receive Buffer Underflow (RUNDFLSTAT bit is set to one when read operation is performed to the receive data register while receive buffer is empty; data read while underflow condition is undefined). Writing 1 to this bit clears the bit.</p> <p>0x0: read operation is performed to the receive data register while receive buffer is NOT empty</p> <p>0x1: read operation is performed to the receive data register while receive buffer is empty; Writing 1 to this bit clears the bit.</p> | RW          | 0x0          |
| 3           | RRDY              | <p>Receive Buffer Threshold Reached (RRDY bit is set to one when the receive buffer occupied locations are equal or above the THRSH1_REG value). Writing 1 to this bit clears the bit.</p> <p>0x0: receive buffer occupied locations are below the THRSH1_REG value).</p> <p>0x1: receive buffer occupied locations are equal or above the THRSH1_REG value). Writing 1 to this bit clears the bit.</p>                                                                                              | RW          | 0x0          |
| 2           | REOF              | <p>Receive End Of Frame (REOF is set to one when a complete frame was received). Writing 1 to this bit clears the bit.</p> <p>0x0: complete frame was NOT received</p> <p>0x1: complete frame was received; Writing 1 to this bit clears the bit.</p>                                                                                                                                                                                                                                                | RW          | 0x0          |
| 1           | RFSR              | <p>Receive Frame Synchronization (RFSR bit is set to one when a new receive frame synchronization is asserted). Writing 1 to this bit clears the bit.</p> <p>0x0: new receive frame synchronization is NOT asserted</p> <p>0x1: new receive frame synchronization is asserted; Writing 1 to this bit clears the bit.</p>                                                                                                                                                                             | RW          | 0x0          |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | RSYNCERR   | <p>Receive Frame Synchronization Error (RSYNCERR is set to one when a receive frame synchronization error is detected). Writing 1 to this bit clears the bit.</p> <p>0x0: receive frame synchronization error is NOT detected</p> <p>0x1: receive frame synchronization error is detected. Writing 1 to this bit clears the bit.</p> | RW   | 0x0   |

**Table 21-117. Register Call Summary for Register MCBSPLP\_IRQSTATUS\_REG**

## McBSP Integration

- Wake-Up Capability: [0] [1] [2] [3]
- McBSP Interrupt Requests: [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17]

## McBSP Functional Description

- Enable/Disable the Transmit and Receive Processes: [18] [19] [20] [21]
- Introduction: [22] [23] [24] [25] [26] [27] [28]
- Overrun in the Receiver: [29] [30] [31]
- Possible Responses to Receive Frame-sync Pulses: [32] [33]
- Underflow in the Receiver: [34] [35]
- Underflow in the Transmitter: [36] [37] [38]
- Possible Responses to Transmit Frame-sync Pulses: [39]
- Overflow in the Transmitter: [40]

## McBSP Basic Programming Model

- L4-Compliant Interrupt Line: [41] [42] [43] [44] [45] [46] [47] [48] [49] [50] [51] [52] [53] [54] [55]
- Legacy Interrupt Line: [56] [57]

## McBSP Register Manual

- McBSP Register Mapping Summary: [58] [59] [60] [61] [62]

**Table 21-118. MCBSPLP\_IRQENABLE\_REG**

| Address Offset          | 0x0000 00A4                                                | Physical Address                                                                                                                                                           | 0x4807 40A4<br>0x4809 60A4<br>0x4902 20A4<br>0x4902 40A4<br>0x4902 60A4<br><br>0x4809 60A4<br>0x4902 20A4<br>0x4902 40A4<br>0x4902 60A4                                    | Instance | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4 |
|-------------------------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------------------------------------------------------------------------------|
| Description             | McBSPLP Interrupt Enable register (OCP compliant IRQ line) |                                                                                                                                                                            |                                                                                                                                                                            |          | Type                                                                                       |
| 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                                                                                                                                                            |          |                                                                                            |
|                         |                                                            | XEMPTYEOFEN<br>RESERVED<br>XOVFLLEN<br>XUNDFLLEN<br>XRDYEN<br>XEOFEN<br>XFSXEN<br>XSYNCERREN<br>RESERVED<br>RWFLEN<br>RUNDFLLEN<br>RRDYEN<br>REOPEN<br>RFSEN<br>RSYNCERREN | RESERVED<br>XEMPTYEOFEN<br>XOVFLLEN<br>XUNDFLLEN<br>XRDYEN<br>XEOFEN<br>XFSXEN<br>XSYNCERREN<br>RESERVED<br>RWFLEN<br>RUNDFLLEN<br>RRDYEN<br>REOPEN<br>RFSEN<br>RSYNCERREN |          |                                                                                            |
|                         | RESERVED                                                   |                                                                                                                                                                            |                                                                                                                                                                            |          |                                                                                            |

| Bits  | Field Name  | Description                                                                                                                                                           | Type | Reset   |
|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:15 | RESERVED    | Read returns 0x0.                                                                                                                                                     | R    | 0x00000 |
| 14    | XEMPTYEOFEN | Transmit buffer empty at end of frame enable bit.<br><br>0x0: Transmit buffer Empty at end of frame NOT enabled<br>0x1: Transmit buffer Empty at end of frame enabled | RW   | 0x0     |
| 13    | RESERVED    | Read returns 0x0.                                                                                                                                                     | R    | 0x0     |
| 12    | XOVFLEN     | Transmit Buffer Overflow enable bit.<br><br>0x0: Transmit Buffer Overflow NOT enabled<br>0x1: Transmit Buffer Overflow enabled                                        | RW   | 0x0     |
| 11    | XUNDFLEN    | Transmit Buffer Underflow enable bit.<br><br>0x0: Transmit Buffer Underflow NOT enabled<br>0x1: Transmit Buffer Underflow enabled                                     | RW   | 0x0     |
| 10    | XRDYEN      | Transmit Buffer Threshold Reached enable bit.<br><br>0x0: Transmit Buffer Threshold Reached NOT enabled<br>0x1: Transmit Buffer Threshold Reached enabled             | RW   | 0x0     |
| 9     | XEOFEN      | Transmit End Of Frame enable bit.<br><br>0x0: Transmit End Of Frame NOT enabled<br>0x1: Transmit End Of Frame enabled                                                 | RW   | 0x0     |
| 8     | XFSXEN      | Transmit Frame Synchronization enable bit.<br><br>0x0: Transmit Frame Synchronization NOT enabled<br>0x1: Transmit Frame Synchronization enabled                      | RW   | 0x0     |
| 7     | XSYNCERREN  | Transmit Frame Synchronization Error enable bit.<br><br>0x0: Transmit Frame Synchronization Error NOT enabled<br>0x1: Transmit Frame Synchronization Error enabled    | RW   | 0x0     |
| 6     | RESERVED    | Read returns 0x0.                                                                                                                                                     | R    | 0x0     |
| 5     | ROVFLLEN    | Receive Buffer Overflow enable bit.<br><br>0x0: Receive Buffer Overflow NOT enabled<br>0x1: Receive Buffer Overflow enabled                                           | RW   | 0x0     |
| 4     | RUNDFLLEN   | Receive Buffer Underflow enable bit.<br><br>0x0: Receive Buffer Underflow NOT enabled<br>0x1: Receive Buffer Underflow enabled                                        | RW   | 0x0     |
| 3     | RRDYEN      | Receive Buffer Threshold enable bit.<br><br>0x0: Receive Buffer Threshold NOT enabled<br>0x1: Receive Buffer Threshold enabled                                        | RW   | 0x0     |
| 2     | REOFEN      | Receive End Of Frame enable bit.<br><br>0x0: Receive End Of Frame NOT enabled<br>0x1: Receive End Of Frame enabled                                                    | RW   | 0x0     |
| 1     | RFSREN      | Receive Frame Synchronization enable bit. RW<br><br>0x0: Receive Frame Synchronization NOT enabled<br>0x1: Receive Frame Synchronization enabled                      | RW   | 0x0     |
| 0     | RSYNCERREN  | Receive Frame Synchronization Error enable bit.<br><br>0x0: Receive Frame Synchronization Error NOT enabled<br>0x1: Receive Frame Synchronization Error enabled       | RW   | 0x0     |

**Table 21-119. Register Call Summary for Register MCBSPLP\_IRQENABLE\_REG**
**McBSP Integration**

- [Wake-Up Capability: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\]](#)
- [McBSP Interrupt Requests: \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\] \[22\]](#)

**Table 21-119. Register Call Summary for Register MCBSPLP\_IRQENABLE\_REG (continued)**

---

### McBSP Functional Description

- Overrun in the Receiver: [23]
- Possible Responses to Receive Frame-sync Pulses: [24]
- Underflow in the Receiver: [25]
- Underflow in the Transmitter: [26]
- Possible Responses to Transmit Frame-sync Pulses: [27]
- Overflow in the Transmitter: [28]

---

### McBSP Basic Programming Model

- Data Transfer DMA Request Configuration: [29] [30]
- L4-Compliant Interrupt Line: [31] [32]

---

### McBSP Register Manual

- McBSP Register Mapping Summary: [33] [34] [35] [36] [37]

**Table 21-120. MCBSPLP\_WAKEUPEN\_REG**

|                         |                                |                 |        |
|-------------------------|--------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 00A8                    |                 |        |
| <b>Physical Address</b> | 0x4807 40A8                    | <b>Instance</b> | McBSP1 |
|                         | 0x4809 60A8                    |                 | McBSP5 |
|                         | 0x4902 20A8                    |                 | McBSP2 |
|                         | 0x4902 40A8                    |                 | McBSP3 |
|                         | 0x4902 60A8                    |                 | McBSP4 |
|                         | 0x4809 60A8                    |                 | McBSP5 |
|                         | 0x4902 20A8                    |                 | McBSP2 |
|                         | 0x4902 40A8                    |                 | McBSP3 |
|                         | 0x4902 60A8                    |                 | McBSP4 |
| <b>Description</b>      | McBSPLP Wakeup Enable register |                 |        |
| <b>Type</b>             | RW                             |                 |        |



| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                           | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:15       | RESERVED          | Read returns 0x0.                                                                                                                                                                            | R           | 0x00000      |
| 14          | XEMPTYEOFEN       | Transmit buffer empty at end of frame WK enable bit.<br>0x0: Transmit buffer Empty at end of frame WK enable is NOT active<br>0x1: Transmit buffer Empty at end of frame WK enable is active | RW          | 0x0          |
| 13:11       | RESERVED          | Read returns 0x0.                                                                                                                                                                            | R           | 0x0          |
| 10          | XRDYEN            | Transmit Buffer Threshold Reached WK enable bit.<br>0x0: Transmit Buffer Threshold WK enable is NOT active<br>0x1: Transmit Buffer Threshold WK enable is active                             | RW          | 0x0          |
| 9           | XEOFEN            | Transmit End Of Frame WK enable bit.<br>0x0: Transmit End Of Frame WK enable is NOT active<br>0x1: Transmit End Of Frame WK enable is active                                                 | RW          | 0x0          |

| Bits | Field Name | Description                                                                                                                                                                                       | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 8    | XFSXEN     | Transmit Frame Synchronization WK enable bit.<br><br>0x0: Transmit Frame Synchronization WK enable is NOT active<br><br>0x1: Transmit Frame Synchronization WK enable is active                   | RW   | 0x0   |
| 7    | XSYNCERREN | Transmit Frame Synchronization Error WK enable bit.<br><br>0x0: Transmit Frame Synchronization Error WK enable is NOT active<br><br>0x1: Transmit Frame Synchronization Error WK enable is active | RW   | 0x0   |
| 6:4  | RESERVED   | Read returns 0x0.                                                                                                                                                                                 | R    | 0x0   |
| 3    | RRDYEN     | Receive Buffer Threshold wake-up enable bit.<br><br>0x0: Receive Buffer Threshold WK enable is NOT active<br><br>0x1: Receive Buffer Threshold WK enable is active                                | RW   | 0x0   |
| 2    | REOFEN     | Receive End Of Frame WK enable bit.<br><br>0x0: Receive End Of Frame WK enable is NOT active<br><br>0x1: Receive End Of Frame WK enable is active                                                 | RW   | 0x0   |
| 1    | RFSREN     | Receive Frame Synchronization WK enable bit.<br><br>0x0: Receive Frame Synchronization WK enable is NOT active<br><br>0x1: Receive Frame Synchronization WK enable is active                      | RW   | 0x0   |
| 0    | RSYNCERREN | Receive Frame Synchronization Error WK enable bit.<br><br>0x0: Receive Frame Synchronization Error WK enable is NOT active<br><br>0x1: Receive Frame Synchronization Error WK enable is active    | RW   | 0x0   |

**Table 21-121. Register Call Summary for Register MCBSPLP\_WAKEUPEN\_REG**

McBSP Integration

- [Wake-Up Capability: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)

McBSP Register Manual

- [McBSP Register Mapping Summary: \[10\] \[11\] \[12\] \[13\] \[14\]](#)

**Table 21-122. MCBSPLP\_XCCR\_REG**

|                         |                                                                         |                 |                                                |
|-------------------------|-------------------------------------------------------------------------|-----------------|------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 00AC                                                             |                 |                                                |
| <b>Physical Address</b> | 0x4807 40AC<br>0x4809 60AC<br>0x4902 20AC<br>0x4902 40AC<br>0x4902 60AC | <b>Instance</b> | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4 |
|                         | 0x4809 60AC                                                             |                 | McBSP5                                         |
|                         | 0x4902 20AC                                                             |                 | McBSP2                                         |
|                         | 0x4902 40AC                                                             |                 | McBSP3                                         |
|                         | 0x4902 60AC                                                             |                 | McBSP4                                         |
| <b>Description</b>      | McBSPLP transmit configuration control register                         |                 |                                                |
| <b>Type</b>             | RW                                                                      |                 |                                                |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|-----------|---------|-------------|----------|----|---|---|-----|----------|--------|----------|----------|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EXTCLKGATE | PPCONNECT | DXENDLY | XFULL_CYCLE | RESERVED |    |   |   | DLB | RESERVED | XDMAEN | RESERVED | XDISABLE |   |   |   |

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Type | Reset  |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED    | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0x0000 |
| 15    | EXTCLKGATE  | <p>External clock gating enable (CLKX and FSX master only). When this bit is set and the transmit clock and FSX are set as output, the CLKX is enabled when FSX is active plus 3 clock cycles after (clock is provided for FWID + 4 clock cycles, assuming that the FSX width, active, is FWID + 1 clock cycles); outside this window the external transmit clock is gated. The receive use the same gated transmit clock and transmit frame synchronization signals regardless of the CLKRM/FSRM settings. When using this mode the frame synchronization signal must be active during reception of the entire frame (FWID must be programmed accordingly) to ensure the proper receive process, which requires at least 3 cycles after the frame complete to transfer the data into the receive buffer.</p> <p>0x0: External clock gating disabled.<br/>0x1: External clock gating enable.</p> | RW   | 0x0    |
| 14    | PPCONNECT   | <p>Pair to pair connection. When set the DXENO pin is always set to 0, regardless of the frame boundary, setting the tree state buffer as output.</p> <p>0x0: non Pair-to-pair connection. The DX pin will go to high-impedance state when there is no frame to transmit.</p> <p>0x1: Pair-to-pair connection. When set, the DXENO pin is always set to 0, regardless of the frame boundary, setting the tree state buffer as output. This means the DX pin will be driven outside valid frame window. In that case, data sent by McBSP module during inactive channel are not guaranteed.</p>                                                                                                                                                                                                                                                                                                   | RW   | 0x0    |
| 13:12 | DXENDLY     | <p>When McBSPi.<a href="#">MCBSPLP_SPCR1_REG</a>[7] DXENA bit is set to one, this field selects the added delay as follow:</p> <p>0x0: 13 ns<br/>0x1: 18 ns (default)<br/>0x2: 24 ns<br/>0x3: 30 ns</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0x1    |
| 11    | XFULL_CYCLE | <p>Transmit full cycle mode select:</p> <p>0x0: McBSP module operates in transmit half-cycle mode (transmit frame synchronization is sampled by the opposite edge of the clock used to drive transmit data)</p> <p>0x1: McBSP module operates in transmit full-cycle mode (transmit frame synchronization is sampled by the same edge of the clock used to drive transmit data)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW   | 0x0    |
| 10:6  | RESERVED    | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0x00   |
| 5     | DLB         | Digital Loop-Back                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW   | 0x0    |
|       |             | 0x0: No DLB<br>0x1: DLB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |        |
| 4     | RESERVED    | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0x0    |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3    | XDMAEN     | Transmit DMA Enable bit. When set to zero this bit will gate the external transmit DMA request, without resetting the DMA state machine. It is recommended to change this bit value only during transmit reset.<br><br>0x0: When set to zero this bit will gate the external transmit DMA request,<br><br>0x1: When set to one this bit will NOT gate the external transmit DMA request, | RW   | 0x1   |
| 2:1  | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                        | R    | 0x0   |
| 0    | XDISABLE   | Transmit Disable bit. When this bit is set the transmit process will stop at the next frame boundary.<br><br>0x0: The transmit process will NOT stop at the next frame boundary.<br><br>0x1: The transmit process will stop at the next frame boundary.                                                                                                                                  | RW   | 0x0   |

**Table 21-123. Register Call Summary for Register MCBSPLP\_XCCR\_REG**

## McBSP Functional Description

- [Clocking and Framing Data: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\]](#)
- [Clocking: \[14\] \[15\] \[16\] \[17\]](#)
- [Enable/Disable the Transmit and Receive Processes: \[18\] \[19\] \[20\]](#)
- [Transmit Full Cycle Mode: \[21\]](#)
- [Transmit Half Cycle Mode: \[22\]](#)
- [Clock Generation in the SRG: \[23\]](#)
- [McBSP DMA Configuration: \[24\]](#)

## McBSP Basic Programming Model

- [McBSP Core: \[25\]](#)
- [McBSP Initialization Procedure: \[26\]](#)
- [Programming the McBSP Registers for the Desired Receiver Configuration \(Step 2\): \[27\] \[28\] \[29\]](#)
- [Programming the McBSP Registers for the Desired Transmitter Operation \(Step 2\): \[30\] \[31\]](#)

## McBSP Register Manual

- [McBSP Register Mapping Summary: \[32\] \[33\] \[34\] \[35\] \[36\]](#)
- [McBSP Register Description: \[37\] \[38\]](#)

**Table 21-124. MCBSPLP\_RCCR\_REG**

|                       |                                                |                         |                                                                                                                                         |                 |                                                                                            |
|-----------------------|------------------------------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------|
| <b>Address Offset</b> | 0x0000 00B0                                    | <b>Physical Address</b> | 0x4807 40B0<br>0x4809 60B0<br>0x4902 20B0<br>0x4902 40B0<br>0x4902 60B0<br><br>0x4809 60B0<br>0x4902 20B0<br>0x4902 40B0<br>0x4902 60B0 | <b>Instance</b> | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br><br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4 |
| <b>Description</b>    | McBSPLP receive configuration control register |                         |                                                                                                                                         |                 |                                                                                            |
| <b>Type</b>           | RW                                             |                         |                                                                                                                                         |                 |                                                                                            |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |    |          |    |    |    |        |   |          |   |          |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|----|----------|----|----|----|--------|---|----------|---|----------|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RFULL_CYCLE |    | RESERVED |    |    |    | RDMAEN |   | RESERVED |   | RDISABLE |   |   |   |   |   |   |

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset     |
|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:12 | RESERVED    | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                            | R    | 0x0000000 |
| 11    | RFULL_CYCLE | Receive full cycle mode select:<br>0x0: McBSP module operates in receive half-cycle mode (receive frame synchronization is sampled by the opposite edge of the clock used to sample receive data)<br>0x1: McBSP module operates in receive full-cycle mode (receive frame synchronization is sampled by the same edge of the clock used to sample receive data)              | RW   | 0x1       |
| 10:4  | RESERVED    | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                            | R    | 0x0000000 |
| 3     | RDMAEN      | Receive DMA Enable bit. When set to zero this bit will gate the external transmit DMA request, without resetting the DMA state machine. It is recommended to change this bit value only during receive reset.<br>0x0: When set to zero this bit will gate the external transmit DMA request<br>0x1: When set to one this bit will NOT gate the external transmit DMA request | RW   | 0x1       |
| 2:1   | RESERVED    | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                            | R    | 0x0       |
| 0     | RDISABLE    | Receive Disable bit. When this bit is set the receive process will stop at the next frame boundary.<br>0x0: the receive process will NOT stop at the next frame boundary.<br>0x1: When this bit is set the receive process will stop at the next frame boundary.                                                                                                             | RW   | 0x0       |

**Table 21-125. Register Call Summary for Register MCBSPLP\_RCCR\_REG**

## McBSP Functional Description

- [Enable/Disable the Transmit and Receive Processes: \[0\] \[1\]](#)
- [Receive Full Cycle Mode: \[2\]](#)
- [Receive Half Cycle Mode: \[3\]](#)
- [McBSP DMA Configuration: \[4\]](#)

## McBSP Basic Programming Model

- [McBSP Core: \[5\]](#)
- [Programming the McBSP Registers for the Desired Receiver Configuration \(Step 2\): \[6\]](#)

## McBSP Register Manual

- [McBSP Register Mapping Summary: \[7\] \[8\] \[9\] \[10\] \[11\]](#)

**Table 21-126. MCBSPLP\_XBUFFSTAT\_REG**

|                         |                                 |                 |        |
|-------------------------|---------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 00B4                     | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 40B4                     |                 | McBSP5 |
|                         | 0x4809 60B4                     |                 | McBSP2 |
|                         | 0x4902 20B4                     |                 | McBSP3 |
|                         | 0x4902 40B4                     |                 | McBSP4 |
|                         | 0x4902 60B4                     |                 | McBSP5 |
|                         | 0x4902 20B4                     |                 | McBSP2 |
|                         | 0x4902 40B4                     |                 | McBSP3 |
|                         | 0x4902 60B4                     |                 | McBSP4 |
| <b>Description</b>      | McBSPPLP transmit buffer status |                 |        |
| <b>Type</b>             | R                               |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | XBUFFSTAT |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits                | Field Name | Description                                                                                                                                                                                                                                                                 | Type | Reset                |
|---------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------------------|
| 31:11               | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                           | R    | 0x0000000            |
| 10:0 <sup>(1)</sup> | XBUFFSTAT  | Transmit Buffer Status (indicates the number of free locations in the transmit buffer). The XBUFFSTAT value reflects the buffer status on the L4 clock domain and it can be bigger than the real number of the free locations which are seen by the transmit state machine. | R    | 0x500 <sup>(2)</sup> |

<sup>(1)</sup> XBUFFSTAT is an 11-bit field for McBSP2 only. For other McBSPs, XBUFFSTAT is an 8-bit field (bits 8 to 10 are reserved).

<sup>(2)</sup> The reset value of XBUFFSTAT for other McBSPs is 0x080.

**Table 21-127. Register Call Summary for Register MCBSPLP\_XBUFFSTAT\_REG**

## McBSP Functional Description

- Enable/Disable the Transmit and Receive Processes: [0]
- McBSP DMA Configuration: [1]

## McBSP Register Manual

- McBSP Register Mapping Summary: [2] [3] [4] [5] [6]

**Table 21-128. MCBSPLP\_RBUFFSTAT\_REG**

|                         |                                |                 |        |
|-------------------------|--------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 00B8                    | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 40B8                    |                 | McBSP5 |
|                         | 0x4809 60B8                    |                 | McBSP2 |
|                         | 0x4902 20B8                    |                 | McBSP3 |
|                         | 0x4902 40B8                    |                 | McBSP4 |
|                         | 0x4902 60B8                    |                 | McBSP5 |
|                         | 0x4902 20B8                    |                 | McBSP2 |
|                         | 0x4902 40B8                    |                 | McBSP3 |
|                         | 0x4902 60B8                    |                 | McBSP4 |
| <b>Description</b>      | McBSPPLP receive buffer status |                 |        |
| <b>Type</b>             | R                              |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RBUFFSTAT |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits                | Field Name | Description                                                                                                                                                                                                                                                                       | Type | Reset    |
|---------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:11               | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                 | R    | 0x000000 |
| 10:0 <sup>(1)</sup> | RBUFFSTAT  | Receive Buffer Status (indicates the number of occupied locations in the receive buffer). The RBUFFSTAT value reflects the buffer status on the L4 clock domain and it can be smaller than the real number of the occupied locations which are seen by the receive state machine. | R    | 0x00     |

<sup>(1)</sup> RBUFFSTAT is an 11-bit field in McBSP2. For other McBSPs, RBUFFSTAT is an 8-bit field (bits 8 to 10 are reserved).

**Table 21-129. Register Call Summary for Register MCBSPLP\_RBUFFSTAT\_REG**

## McBSP Functional Description

- [Enable/Disable the Transmit and Receive Processes: \[0\]](#)
- [McBSP DMA Configuration: \[1\]](#)

## McBSP Register Manual

- [McBSP Register Mapping Summary: \[2\] \[3\] \[4\] \[5\] \[6\]](#)

**Table 21-130. MCBSPLP\_SSELCR\_REG**

|                         |                                                                                                                                            |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |            |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|------------|
| <b>Address Offset</b>   | 0x0000 00BC                                                                                                                                |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |            |
| <b>Physical Address</b> | 0x4807 40BC<br>0x4809 60BC<br>0x4902 20BC<br>0x4902 40BC<br><b>0x4902 60BC</b><br>0x4809 60BC<br>0x4902 20BC<br>0x4902 40BC<br>0x4902 60BC |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |            |
|                         | Instance                                                                                                                                   |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |            |
|                         | McBSP1<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4<br>McBSP5<br>McBSP2<br>McBSP3<br>McBSP4                                                     |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |            |
| <b>Description</b>      | McBSPLP sidetone select register.                                                                                                          |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |            |
| <b>Type</b>             | RW                                                                                                                                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |            |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |            |
| RESERVED                |                                                                                                                                            |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | SIDETONEEN |
| OCH1ASSIGN              |                                                                                                                                            |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | OCH0ASSIGN |
| ICH1ASSIGN              |                                                                                                                                            |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | ICH0ASSIGN |

| Bits  | Field Name | Description                                                                                      | Type | Reset    |
|-------|------------|--------------------------------------------------------------------------------------------------|------|----------|
| 31:11 | RESERVED   | Read returns 0x0.                                                                                | R    | 0x000000 |
| 10    | SIDETONEEN | Sidetone mode enable.<br>0x0: Sidetone disabled.<br>0x1: Sidetone enabled.                       | RW   | 0x0      |
| 9:7   | OCH1ASSIGN | Map the data for the speaker out channels to one of the McBSP channels (1 out of 8 channels)     | RW   | 0x1      |
| 6:4   | OCH0ASSIGN | Map the data for the speaker out channels to one of the McBSP channels (1 out of 8 channels)     | RW   | 0x0      |
| 3:2   | ICH1ASSIGN | Map the data from digital microphone channels to one of the McBSP channels (1 out of 4 channels) | RW   | 0x1      |
| 1:0   | ICH0ASSIGN | Map the data from digital microphone channels to one of the McBSP channels (1 out of 4 channels) | RW   | 0x0      |

**Table 21-131. Register Call Summary for Register MCBSPLP\_SSELCR\_REG**

## McBSP Functional Description

- [SIDETONE Interface](#): [0] [1] [2] [3] [4] [5] [6]

## McBSP Basic Programming Model

- [SIDETONE Activation Procedure](#): [7] [8] [9] [10] [11]

## McBSP Register Manual

- [McBSP Register Mapping Summary](#): [12] [13] [14] [15] [16]

**Table 21-132. MCBSPLP\_STATUS\_REG**

|                         |                          |                 |        |
|-------------------------|--------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 00C0              | <b>Instance</b> | McBSP1 |
| <b>Physical Address</b> | 0x4807 40C0              |                 | McBSP5 |
|                         | 0x4809 60C0              |                 | McBSP2 |
|                         | 0x4902 20C0              |                 | McBSP3 |
|                         | 0x4902 40C0              |                 | McBSP4 |
|                         | 0x4902 60C0              |                 | McBSP5 |
|                         | 0x4809 60C0              |                 | McBSP2 |
|                         | 0x4902 20C0              |                 | McBSP3 |
|                         | 0x4902 40C0              |                 | McBSP4 |
| <b>Description</b>      | McBSPLP status register. |                 |        |
| <b>Type</b>             | R                        |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Type | Reset      |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED     | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R    | 0x00000000 |
| 0    | CLKMUXSTATUS | <p>When going to/exiting from idle mode, the clock for the interface domain is switched between McBSP_ICLK and master serial clock to allow functioning in idle mode. This bit indicates that the status of clock switching and accesses to the McBSP registers are delayed during clock switching. To avoid such a situation, polling can be performed to status register to evaluate when McBSPLP is ready. This information is relevant only for the McBSPLP operating in slave mode (serial clock provided by external component).</p> <p>0: McBSP registers can be accessed.</p> <p>1: The response to a different register access is delayed until the muxing process is done. Only the <a href="#">MCBSPLP_STATUS_REG[CLKMUXSTATUS]</a> register can be accessed under this condition. The McBSP cannot exit from IDLE state (the external clock must be restarted).</p> | R    | 0x0        |

**Table 21-133. Register Call Summary for Register MCBSPLP\_STATUS\_REG**

## McBSP Register Manual

- [McBSP Register Mapping Summary](#): [0] [1] [2] [3] [4]
- [McBSP Register Description](#): [5]

## 21.6.4 SIDETONE Register Description

**Table 21-134. ST\_REV\_REG**

|                         |                                   |                 |                 |  |
|-------------------------|-----------------------------------|-----------------|-----------------|--|
| <b>Address Offset</b>   | 0x0000 0000                       | <b>Instance</b> | SIDETONE_McBSP2 |  |
| <b>Physical Address</b> | 0x4902 8000<br>0x4902 A000        |                 | SIDETONE_McBSP3 |  |
|                         | 0x4902 A000                       |                 | SIDETONE_McBSP3 |  |
| <b>Description</b>      | SIDETONE Revision number register |                 |                 |  |
| <b>Type</b>             | R                                 |                 |                 |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         |                       | REV             |

| Bits                 | Field Name | Description                                                                                         | Type | Reset              |
|----------------------|------------|-----------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8                 | RESERVED   | Read returns 0x0.                                                                                   | R    | 0x0000000          |
| 7:0                  | REV        | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision<br>Examples: 0x10 for 1.0, 0x21 for 2.1 | R    | See <sup>(1)</sup> |
| (1) TI internal data |            |                                                                                                     |      |                    |

**Table 21-135. Register Call Summary for Register ST\_REV\_REG**

McBSP Register Manual

- SIDETONE Register Mapping Summary: [0] [1]

**Table 21-136. ST\_SYSCONFIG\_REG**

|                         |                                        |                 |                 |  |
|-------------------------|----------------------------------------|-----------------|-----------------|--|
| <b>Address Offset</b>   | 0x0000 0010                            | <b>Instance</b> | SIDETONE_McBSP2 |  |
| <b>Physical Address</b> | 0x4902 8010<br>0x4902 A010             |                 | SIDETONE_McBSP3 |  |
|                         | 0x4902 A010                            |                 | SIDETONE_McBSP3 |  |
| <b>Description</b>      | SIDETONE System Configuration register |                 |                 |  |
| <b>Type</b>             | RW                                     |                 |                 |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                |                         |                       | AUTOIDLE        |

| Bits | Field Name | Description                                                                                                                                                              | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Read returns 0x0.                                                                                                                                                        | R    | 0x00000000 |
| 0    | AUTOIDLE   | Automatic McBSP <sub>i</sub> _ICLK clock gating<br>0x0: McBSP <sub>i</sub> _ICLK clock auto-gating disabled.<br>0x1: McBSP <sub>i</sub> _ICLK clock auto-gating enabled. | RW   | 0x1        |

**Table 21-137. Register Call Summary for Register ST\_SYSCONFIG\_REG**

McBSP Integration

- SIDETONE Clock: [0] [1]

McBSP Register Manual

- SIDETONE Register Mapping Summary: [2] [3]

**Table 21-138. ST\_IRQSTATUS\_REG**

|                         |                                    |                       |                 |  |
|-------------------------|------------------------------------|-----------------------|-----------------|--|
| <b>Address Offset</b>   | 0x0000 0018                        | <b>Instance</b>       | SIDETONE_McBSP2 |  |
| <b>Physical Address</b> | 0x4902 8018<br>0x4902 A018         |                       | SIDETONE_McBSP3 |  |
|                         | 0x4902 A018                        |                       | SIDETONE_McBSP3 |  |
| <b>Description</b>      | SIDETONE Interrupt Status Register |                       |                 |  |
| <b>Type</b>             | RW                                 |                       |                 |  |
| 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 |  |
| RESERVED                |                                    |                       | OVRRERROR       |  |

| Bits | Field Name | Description                                                                                                                                   | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Read returns 0x0.                                                                                                                             | R    | 0x00000000 |
| 0    | OVRRERROR  | Over-run error has occurred. New data to be processed has arrived before the previous one has ended.<br>Writing 1 to this bit clears the bit. | RW   | 0x0        |

**Table 21-139. Register Call Summary for Register ST\_IRQSTATUS\_REG**

## McBSP Integration

- [SIDETONE\\_McBSP Interrupt Requests: \[0\] \[1\] \[2\] \[3\]](#)

## McBSP Functional Description

- [Interrupt Operation: \[4\]](#)

## McBSP Register Manual

- [SIDETONE Register Mapping Summary: \[5\] \[6\]](#)

**Table 21-140. ST\_IRQENABLE\_REG**

|                         |                                    |                       |                 |  |
|-------------------------|------------------------------------|-----------------------|-----------------|--|
| <b>Address Offset</b>   | 0x0000 001C                        | <b>Instance</b>       | SIDETONE_McBSP2 |  |
| <b>Physical Address</b> | 0x4902 801C<br>0x4902 A01C         |                       | SIDETONE_McBSP3 |  |
|                         | 0x4902 A01C                        |                       | SIDETONE_McBSP3 |  |
| <b>Description</b>      | SIDETONE Interrupt enable register |                       |                 |  |
| <b>Type</b>             | RW                                 |                       |                 |  |
| 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 |  |
| RESERVED                |                                    |                       | OVRRERROREN     |  |

| Bits | Field Name  | Description                          | Type | Reset      |
|------|-------------|--------------------------------------|------|------------|
| 31:1 | RESERVED    | Read returns 0x0.                    | R    | 0x00000000 |
| 0    | OVRRERROREN | Over-run error interrupt enable bit. | RW   | 0x0        |

**Table 21-141. Register Call Summary for Register ST\_IRQENABLE\_REG**

McBSP Integration  
 • [SIDETONE\\_McBSP Interrupt Requests: \[0\] \[1\] \[2\]](#)

McBSP Functional Description  
 • [Interrupt Operation: \[3\]](#)

McBSP Register Manual  
 • [SIDETONE Register Mapping Summary: \[4\] \[5\]](#)

**Table 21-142. ST\_SGAINCR\_REG**

|                       |                                |                         |                            |                 |                                    |
|-----------------------|--------------------------------|-------------------------|----------------------------|-----------------|------------------------------------|
| <b>Address Offset</b> | 0x0000 0024                    | <b>Physical Address</b> | 0x4902 8024<br>0x4902 A024 | <b>Instance</b> | SIDETONE_McBSP2<br>SIDETONE_McBSP3 |
|                       |                                |                         | 0x4902 A024                |                 | SIDETONE_McBSP3                    |
| <b>Description</b>    | Sidetone gain control register |                         |                            |                 |                                    |
| <b>Type</b>           | RW                             |                         |                            |                 |                                    |

|                                                                                             |         |
|---------------------------------------------------------------------------------------------|---------|
| 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 |         |
| CH1GAIN                                                                                     | CH0GAIN |

| Bits  | Field Name | Description                  | Type | Reset  |
|-------|------------|------------------------------|------|--------|
| 31:16 | CH1GAIN    | Second sidetone channel gain | RW   | 0x0000 |
| 15:0  | CH0GAIN    | First sidetone channel gain  | RW   | 0x0000 |

**Table 21-143. Register Call Summary for Register ST\_SGAINCR\_REG**

McBSP Functional Description

- [Applying Gain: \[0\]](#)

McBSP Basic Programming Model

- [SIDETONE Initialization Procedure: \[1\] \[2\]](#)

McBSP Register Manual

- [SIDETONE Register Mapping Summary: \[3\] \[4\]](#)

**Table 21-144. ST\_SFIRCR\_REG**

|                       |                                            |                         |                            |                 |                                    |
|-----------------------|--------------------------------------------|-------------------------|----------------------------|-----------------|------------------------------------|
| <b>Address Offset</b> | 0x0000 0028                                | <b>Physical Address</b> | 0x4902 8028<br>0x4902 A028 | <b>Instance</b> | SIDETONE_McBSP2<br>SIDETONE_McBSP3 |
|                       |                                            |                         | 0x4902 A028                |                 | SIDETONE_McBSP3                    |
| <b>Description</b>    | Sidetone FIR coefficients control register |                         |                            |                 |                                    |
| <b>Type</b>           | RW                                         |                         |                            |                 |                                    |

|                                                                                             |          |
|---------------------------------------------------------------------------------------------|----------|
| 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 |          |
| RESERVED                                                                                    | FIRCOEFF |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Read returns 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R    | 0x0000 |
| 15:0  | FIRCOEFF   | <p>FIR coefficients control register (the coefficients are programmed by successive write sequence of all 128 FIR coefficients)</p> <p>The write sequence should start with the coefficient 0. In order to enable the write to this register the COEFFWREN bit in SSELCR_REG should be set to one. When this bit is set the read operation will return only the last written value.</p> <p>After a complete FIR coefficients write sequence the COEFFWREN should be set to zero.</p> <p>A read sequence from SFIRCR_REG while COEFFWREN is set to zero will return the coefficients values starting from 0 to 127.</p> <p>The write coefficient address is set to 0 by the change of COEFFWREN from 0 to 1.</p> <p>The read coefficient address is set to 0 by the change of COEFFWREN from 1 to 0</p> | RW   | 0x0000 |

**Table 21-145. Register Call Summary for Register ST\_SFIRCR\_REG**

McBSP Basic Programming Model

- [SIDETONE Initialization Procedure: \[0\] \[1\]](#)
- [SIDETONE FIR Coefficients Writing: \[2\]](#)
- [SIDETONE FIR Coefficients Reading: \[3\]](#)

McBSP Register Manual

- [SIDETONE Register Mapping Summary: \[4\] \[5\]](#)

**Table 21-146. ST\_SSELCR\_REG**

|                         |                            |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |             |
|-------------------------|----------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|-------------|
| <b>Address Offset</b>   | 0x0000 002C                |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |             |
| <b>Physical Address</b> | 0x4902 802C<br>0x4902 A02C |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |             |
|                         | 0x4902 A02C                |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |             |
| <b>Description</b>      | Sidetone select register   |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |             |
| <b>Type</b>             | RW                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |             |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |             |
| RESERVED                |                            |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | COEFFWRDONE |
| SIDETONEEN              |                            |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | COEFFWREN   |

| Bits | Field Name  | Description                                                                                           | Type | Reset      |
|------|-------------|-------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED    | Read returns 0x0.                                                                                     | R    | 0x00000000 |
| 2    | COEFFWRDONE | Write FIR coefficients completed.<br>0x0: FIR coefficients not loaded<br>0x1: FIR coefficients loaded | R    | 0x0        |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | COEFFWREN  | <p>Write enable FIR coefficients.<br/>0x1:<br/>If a 0 to 1 transition on this bit occurs, the write coefficient index is reset. When this bit is 1, all coefficients can be written in SFIRCR_REG performing 128 write accesses with SIDETONEEN 1. First access writes coefficient index 0.</p> <p>Read access in this case returns the last written value.<br/>0x0:<br/>If a 1 to 0 transition on this bit occurs, the read coefficient index is reset. When this bit is 0, all coefficients can be read from SFIRCR_REG by performing 128 read accesses with SIDETONEEN 0. First access reads coefficient index 0.</p> | RW   | 0x0   |
| 0    | SIDETONEEN | <p>Sidetone mode enable.<br/>0x0: Sidetone disabled<br/>0x1: Sidetone enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0x0   |

**Table 21-147. Register Call Summary for Register ST\_SSELCR\_REG**

## McBSP Functional Description

- [Data Processing Path: \[0\]](#)
- [Enabling SIDETONE: \[1\] \[2\] \[3\]](#)

## McBSP Basic Programming Model

- [SIDETONE Activation Procedure: \[4\]](#)
- [SIDETONE Initialization Procedure: \[5\] \[6\]](#)
- [SIDETONE FIR Coefficients Writing: \[7\] \[8\]](#)
- [SIDETONE FIR Coefficients Reading: \[9\]](#)

## McBSP Register Manual

- [SIDETONE Register Mapping Summary: \[10\] \[11\]](#)

## **High-Speed USB Host Subsystem and High-Speed USB OTG Controller**

This chapter describes the high-speed universal serial bus (USB) host subsystem and the high-speed USB On-The-Go (OTG) controller of the device.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                           | Page        |
|-------------------------------------------------|-------------|
| <b>22.1 High-Speed USB OTG Controller .....</b> | <b>3239</b> |
| <b>22.2 High-Speed USB Host Subsystem .....</b> | <b>3262</b> |

## Overview

The device contains two USB modules:

- A High-Speed USB OTG Controller (see [Section 22.1, High-Speed USB OTG Controller](#))
- A High-Speed USB Host Subsystem (see [Section 22.2, High-Speed USB Host Subsystem](#))

**Figure 22-1. USB Modules Overview**



usb-035

## 22.1 High-Speed USB OTG Controller

**NOTE:** The High-Speed USB OTG Controller is an instantiation of the MUSBMHDRC from Mentor Graphics Corporation.

This document contains materials that are ©2003-2007 Mentor Graphics Corporation.

Mentor Graphics is a registered trademarks of Mentor Graphics Corporation or its affiliated companies in the United States and other countries.

### 22.1.1 High-Speed USB OTG Controller Overview

The High-Speed USB OTG dual-role-device (DRD) link controller supports the following modes:

- USB 2.0 peripheral (function controller) in high/full speed (480/12 Mbps, respectively)
- USB 2.0 host in high/full/low speed (480/12/1.5 Mbps respectively), with one downstream port but multipoint capability when a hub is connected to it (split transaction support, etc.)
- USB 2.0 OTG DRD in high/full speed, with HNP and SRP support.

The high-speed USB controller supports a single USB port, which uses the ULPI interface mode, to connect to an off-chip transceiver (12-pin/8-bit data SDR mode).

Figure 22-2 highlights the high-speed USB controller.

**Figure 22-2. High-Speed USB Controller Highlight**



#### 22.1.1.1 Main Features

The high-speed USB controller has the following features:

- Operates either as the function controller of a high-/full-speed USB peripheral or as the host/peripheral in point-to-point or multipoint communications with other USB functions

- Complies with the USB 2.0 standard for high-speed (480 Mbps) functions and with the OTG supplement (Revision 1.0a)
- Includes all transfer types: Control, bulk, isochronous, interrupt
- Supports SRP and HNP
- Supports suspend/resume and remote wakeup
- Supports high-bandwidth isochronous and interrupt transfers
- Contains one PHY (physical layer) interface: ULPI interface (12/8-pin version)
- 15 transmit endpoints and 15 receive endpoints in addition to control endpoint 0
- Each endpoint has its own FIFO, with the following properties:
  - Implemented within a single, 16K-byte internal RAM
  - Can be dynamically sized by software
  - Can be configured to hold multiple packets (up to 8192 bytes per FIFO)
  - Can be accessed either by direct access or by DMA controller
- Software connect/disconnect option for peripheral
- Performs all transaction scheduling in hardware

## 22.1.2 High-Speed USB OTG Controller Environment

Figure 22-3 shows a typical application using the high-speed USB controller.

**Figure 22-3. High-Speed USB Controller Typical Application System**



usb-002

The high-speed USB controller supports a single USB port, which uses the ULPI interface mode, to connect to an off-chip transceiver (12-pin/8-bit data SDR mode). A mini A-B external receptacle allows the connection of an external device.

The current implementation of ULPI includes a method for manual, software-controlled generation of PHY-side register accesses supporting the following features:

- Access to vendor-specific or optional PHY-side registers
- Carkit operation (including interrupt, PHY-side registers)
- Access to vendor ID, product ID, scratch and debug registers

The 12-pin ULPI interface uses an 8-bit data bus with data synchronous to the rising edge of the PHY clock (SDR mode); the 8-pin ULPI uses a 4-bit data bus with data generated on both the rising and falling clock edge (DDR mode).

The TI high-speed USB controller supports only the 12-pin, 8-bit version ULPI interface.

The 12-pin/8-bit data SDR ULPI interface is selected through the USBOTG.OTG\_INTERFSEL[1:0] PHYSEL field and must be set to 0x1.

## 22.1.2.1 High-Speed USB Controller Functional Interfaces

### 22.1.2.1.1 Basic High-Speed USB Controller Pins

Figure 22-4 shows the high-speed USB controller functional interface.

**Figure 22-4. High-Speed USB Controller Functional Interface Signals**



usb-003

### 22.1.2.1.2 High-Speed USB Controller Interface Description

Table 22-1 describes the I/O of the high-speed USB controller interface.

**Table 22-1. Input/Output Description**

| Signal Name  | I/O <sup>(1)</sup> | Description                          | Reset Value |
|--------------|--------------------|--------------------------------------|-------------|
| hsusb0_clk   | I                  | 60-MHz clock input from ULPI PHY     | N/A         |
| hsusb0_dir   | I                  | Data direction control from ULPI PHY | N/A         |
| hsusb0_stp   | O                  | Stop signal to ULPI PHY              | 1           |
| hsusb0_nxt   | I                  | Next signal from ULPI PHY            | N/A         |
| hsusb0_data0 | I/O                | Bidirectional DATA0                  | N/A         |
| hsusb0_data1 | I/O                | Bidirectional DATA1                  | N/A         |
| hsusb0_data2 | I/O                | Bidirectional DATA2                  | N/A         |
| hsusb0_data3 | I/O                | Bidirectional DATA3                  | N/A         |
| hsusb0_data4 | I/O                | Bidirectional DATA4                  | N/A         |
| hsusb0_data5 | I/O                | Bidirectional DATA5                  | N/A         |
| hsusb0_data6 | I/O                | Bidirectional DATA6                  | N/A         |
| hsusb0_data7 | I/O                | Bidirectional DATA7                  | N/A         |

<sup>(1)</sup> I = Input; O = Output

### 22.1.3 High-Speed USB OTG Controller Integration

The high-speed USB controller is connected to L3 interconnect master (initiator) and slave (target) interfaces and L4-Core interconnect. The L3 interconnect generates data traffic within the device. The L4-Core interconnect is a configuration port for register setting.

Figure 22-5 highlights the high-speed USB controller integration in the device.

**Figure 22-5. High-Speed USB Controller Integration**



usb-004

#### 22.1.3.1 Clocking, Reset, and Power-Management Scheme

##### 22.1.3.1.1 Clocks

###### 22.1.3.1.1.1 Module Clocks

Three clocks are provided to the high-speed USB controller, as shown in Table 22-2.

**Table 22-2. USB Clocks**

| Attributes             | Frequency                           | Name        | Mapping      | Comments                              |
|------------------------|-------------------------------------|-------------|--------------|---------------------------------------|
| Functional clock       | 60 MHz                              | USBHS_FCLK  | hsusb0_clk   | Source is external transceiver (ULPI) |
| Master Interface clock | Depending on PRCM register settings | USBHS_MICLK | CORE_L3_ICLK | Source is PRCM module                 |

**Table 22-2. USB Clocks (continued)**

| Attributes            | Frequency                           | Name        | Mapping      | Comments              |
|-----------------------|-------------------------------------|-------------|--------------|-----------------------|
| Slave Interface clock | Depending on PRCM register settings | USBHS_SICLK | CORE_L4_ICLK | Source is PRCM module |

### 22.1.3.1.1.2 Master Interface Clock

The master interface clock USBHS\_MICLK comes from the PRCM module. This clock is controlled by the PRCM register bits PRCM.CM\_ICLKEN1\_CORE[4]:

- 0: Disabled
- 1: Enabled

and PRCM.CM\_AUTOIDLE1\_CORE[4] (enables/disables automatic control of the interface clock)-see Table 22-3.

**Table 22-3. High-Speed USB Interface Clock**

| PRCM.CM_AUTOIDLE1_CORE[4] | PRCM.CM_ICLKEN1_CORE[4] | Interface Clock              |
|---------------------------|-------------------------|------------------------------|
| 0                         | 0                       | Disabled                     |
| 0                         | 1                       | Enabled                      |
| 1                         | 0                       | Disabled                     |
| 1                         | 1                       | Automatic enabling/disabling |

### 22.1.3.1.1.3 Functional Clock

The functional clock (60MHz), USBHS\_FCLK, comes from the external ULPI transceiver through the hsusb0\_clk input pin.

### 22.1.3.1.2 Resets

The high-speed USB controller can be reset either by the domain reset (hardware reset) or by setting a dedicated configuration bit (software reset) in the module.

#### 22.1.3.1.2.1 Hardware Reset

The high-speed USB controller is attached to the CORE power domain: The CORE\_RST signal resets the module (see [Chapter 3, Power, Reset, and Clock Management](#)). The hardware reset signal has a global reset action on the high-speed USB controller.

#### 22.1.3.1.2.2 Software Reset

The high-speed USB controller has a software reset through the USBOTG.OTG\_SYSConfig[1] SOFTRESET bit (0: Normal mode, 1: Module is reset).

This bit controls the software reset. Writing 1 to this bit resets the module. The bit value 1 remains until the reset is complete. When the software reset is complete, the SOFTRESET bit is automatically reset to 0 and has the same effect as the hardware reset.

### 22.1.3.1.3 Power-Management Scheme

#### 22.1.3.1.3.1 Overview

To save dynamic power consumption, an efficient idle scheme in the device is based on the following:

- An efficient local autoclock gating for each module
- The implementation of control sideband signals between the PRCM module and each module

This enhanced idle control allows clocks to be activated/deactivated safely without complex software intervention. In both cases, the high-speed USB controller power management is applied only to the interface clock domain. The USB functional clock (60 MHz), USBHS\_FCLK, is controlled by the transceiver and is responsible only for a very small percentage of the module overall power consumption.

The high-speed USB controller has both master (initiator) and slave (target) interfaces.

- As an initiator, the high-speed USB controller implements the standby handshake protocol to inform the PRCM module when it enters standby mode and does not generate traffic on the interconnect.
- As a target, the high-speed USB controller implements the IDLE handshake protocol to allow the PRCM module requiring it to enter idle mode.

#### 22.1.3.1.3.2 System Power Management

##### Master Interface Power Management

The high-speed USB controller can choose to go to standby mode, in which case it stops generating transactions on the interconnect. The module standby leads the PRCM to disable the USB clocks to save power.

The high-speed USB controller has a MSTANDBY handshake mechanism with the PRCM module (see Figure 22-5).

The module is ready to enter standby mode (indicated by the MSTANDBY signal to the PRCM asserted) when there is no USB activity and the module is idle. It means the following:

- The module is committed not to start any new transaction on its master interface.
- The module is idle and, therefore, the power manager can start the procedure to turn off the interface clock, if needed. This procedure must be implemented using the slave power-management protocol.

The handshake mechanism lets the module to go to standby state based on the [USBOTG.OTG\\_SYSCONFIG\[13:12\]](#) MIDLEMODE field.

- Smart standby

The high-speed USB controller is configured in smart-standby mode ([USBOTG.OTG\\_SYSCONFIG\[13:12\]](#) MIDLEMODE field = 0x2). The module is ready to enter standby mode (MSTANDBY is asserted) when there is no more activity on the USB master interface of the interconnect. MSTANDBY is asserted when the module is idle and deasserted when the module is activated by either an external USB event or an appropriate register access. The module then waits for MWAIT deassertion before a DMA transfer is started.

- Force standby

The high-speed USB controller is configured in force-standby mode ([USBOTG.OTG\\_SYSCONFIG\[13:12\]](#) MIDLEMODE field = 0x0).

- When the high-speed USB controller operates as a host: The [USBOTG.POWER\[1\]](#) SUSPENDMODE bit is set to 1 to bring the module to low-power mode (suspend mode). After this setting, the high-speed USB controller waits for its idle state. The [USBOTG.OTG\\_FORCESTDBY\[0\]](#) ENABLEFORCE bit must be set to 1 to assert MSTANDBY. Similarly, to release the MSTANDBY signal, an appropriate register access must be applied, which can be either of the following two cases:

- Remote wakeup causes a RESUME interrupt
- Set the [USBOTG.POWER\[3\]](#) RESET bit to 1.
- Write 0 to the [USBOTG.OTG\\_FORCESTDBY\[0\]](#) ENABLEFORCE bit.  
OR
- Set the [USBOTG.POWER\[3\]](#) RESET bit to 1.
- Write 0 to the [USBOTG.OTG\\_FORCESTDBY\[0\]](#) ENABLEFORCE bit.

- When the high-speed USB controller operates as a peripheral: When the USB bus is idle for 3 ms, a SUSPEND interrupt is generated by the high-speed USB controller. The [USBOTG.OTG\\_FORCESTDBY\[0\]](#) ENABLEFORCE bit must be set to 1 to enable the MSTANDBY signal. The high-speed USB controller then asserts MSTANDBY. Similarly, to release the MSTANDBY signal, an appropriate register access must be applied, which can be either of the

following two cases:

- Set the USBOTG.POWER[2] RESUME bit to 1.
- Write 0 to the USBOTG.OTG\_FORCESTDBY[0] ENABLEFORCE bit.  
OR
- RESET interrupt is generated by the high-speed USB controller.
- Write 0 to the USBOTG.OTG\_FORCESTDBY[0] ENABLEFORCE bit.

When MSTANDBY is deasserted as a consequence of the previous register access, the module waits for MWAIT deassertion before a DMA transfer is started.

- No standby

The high-speed USB controller is configured in no-standby mode (USBOTG.OTG\_SYSConfig[13:12] MIDLEMODE field = 0x1). The module never enters standby mode (that is, MSTANDBY is never asserted).

**Table 22-4** describes the high-speed USB master interface power management modes.

**Table 22-4. High-Speed USB Master Interface Power Management Modes**

| Power Management Mode Requested by the PRCM | USBOTG.OTG_SYSConfig[13:12] MIDLEMODE Field |
|---------------------------------------------|---------------------------------------------|
| Force-standby                               | 0x0                                         |
| No-standby                                  | 0x1                                         |
| Smart-standby                               | 0x2                                         |
| Reserved                                    | 0x3                                         |

### Slave Interface Power Management

The high-speed USB controller can be configured through the USBOTG.OTG\_SYSConfig[4:3] SIDLEMODE field as one of the following acknowledgment modes:

- Smart-Idle Mode

When the high-speed USB controller receives an IDLE request from the PRCM module:

- The interface clock USBHS\_ICLK is disabled (PRCM register bit PRCM.CM\_ICLKEN1\_CORE[4] set to 0) or under automatic control (PRCM register bits PRCM.CM\_ICLKEN1\_CORE[4] and PRCM.CM\_AUTOIDLE1\_CORE[4] both set to 1)
- L4 interface clock idle transitions:

Configured in smart-idle mode (USBOTG.OTG\_SYSConfig[4:3] SIDLEMODE field = 0x2), the high-speed USB controller checks for no ongoing activity. The idle acknowledge then is asserted and the module waits for active system clock gating by the PRCM module (this occurs only when all peripherals supplied by the same L3 clock domain are also ready for idle).

Once in idle mode (when the PRCM module gates the interface clock), the module has no activity, the interface clock paths are gated, no interrupt request can be generated, and the module is ready to issue a wake-up request. If a wake-up condition occurs, the high-speed USB controller exits from idle mode if the USBOTG.OTG\_SYSConfig[2] ENABLEWAKEUP bit is set to 1 (wake-up capability enabled) and the PRCM register bit PRCM.PM\_WKEN1\_CORE[4] is also set to 1.

- Force-Idle Mode

When the high-speed USB controller receives an IDLE request from the PRCM module:

- The interface clock USBHS\_ICLK is disabled (PRCM register bit PRCM.CM\_ICLKEN1\_CORE[4] set to 0) or under automatic control (PRCM register bits PRCM.CM\_ICLKEN1\_CORE[4] and PRCM.CM\_AUTOIDLE1\_CORE[4] both set to 1)
- The L4 interface clock idle transitions:

Configured in force-idle mode (USBOTG.OTG\_SYSConfig[4:3] SIDLEMODE field = 0x0), the high-speed USB controller waits unconditionally for active system clock gating by the PRCM module (this occurs only when all peripherals supplied by the same L3 clock domain are also ready for idle).

Once in idle mode (when the PRCM module gates the interface clock), the module has no activity, the interface clock paths are gated, no interrupt request can be generated, and the wake-up feature is

totally inhibited.

- No-Idle Mode

When the high-speed USB controller receives an IDLE request from the PRCM module:

- The interface clock(s) USBHS\_ICLK are disabled (PRCM register bit PRCM.CM\_ICLKEN1\_CORE[4] set to 0) or under automatic control (PRCM register bits PRCM.CM\_ICLKEN1\_CORE[4] and PRCM.CM\_AUTOIDLE1\_CORE[4] both set to 1)
  - L4 interface clock idle transitions
- Configured in no-idle mode (USBOTG.OTG\_SYS CONFIG[4:3] SIDLEMODE field = 0x1), the high-speed USB controller module does not go to idle mode and the idle acknowledge is never sent.

[Table 22-5](#) describes the high-speed USB slave interface power management modes.

**Table 22-5. High-Speed USB Slave Interface Power Management Modes**

| Power Management Mode Requested by the PRCM | USBOTG.OTG_SYS CONFIG[4:3] SIDLEMODE Field |
|---------------------------------------------|--------------------------------------------|
| Force-idle                                  | 0x0                                        |
| No-idle                                     | 0x1                                        |
| Smart-idle                                  | 0x2                                        |
| Reserved                                    | 0x3                                        |

**NOTE:** The high-speed USB controller standby status can be checked by the PRCM module register bit CM\_IDLEST1\_CORE[4].

- 0: High-Speed USB is active.
- 1: High-Speed USB is in standby mode.

The high-speed USB controller wake-up status can be checked by the PRCM module register bit PM\_WKST1\_CORE[4].

- Read 0: Wakeup has not occurred or was masked.
- Read 1: Wakeup has occurred.
- Write 0: Status bit unchanged.
- Write 1: Status bit is cleared to 0.

### 22.1.3.1.3.3 Local Power Management

The high-speed USB controller has local power management by internal clock gating features:

- Internal interface clock autogating: Clock for the L3 interconnect logic can be gated when the module is not accessed, if the USBOTG.OTG\_SYS CONFIG[0] AUTOIDLE bit is set. Otherwise, this logic is free-running on the interface clock. This bit is used to save power when the module is not used because of the multiplexing configuration selected at the chip level. This bit has precedence over all other internal configuration bits.

### 22.1.3.1.4 Power Domain

The high-speed USB controller is attached to the CORE power domain (see [Chapter 3, Power, Reset, and Clock Management](#)).

### 22.1.3.2 Hardware Requests

#### 22.1.3.2.1 Interrupt Requests

[Table 22-6](#) lists the interrupt lines that are driven out from the high-speed USB controller to the MPU subsystem INTC.

**Table 22-6. High-Speed USB Interrupts**

| Name                                   | Mapping  | Comments                                          |
|----------------------------------------|----------|---------------------------------------------------|
| <b>HS USB Controller Interrupt</b>     |          |                                                   |
| HSUSB_MC_NINT                          | M_IRQ_92 | Destination is MPU subsystem interrupt controller |
| <b>HS USB DMA Controller Interrupt</b> |          |                                                   |
| HSUSB_DMA_NINT                         | M_IRQ_93 | Destination is MPU subsystem interrupt controller |

#### 22.1.3.2.2 *IDLE Handshake Protocol*

The PRCM handles an IDLE handshake protocol for the high-speed USB controller. The IDLE handshake protocol allows the PRCM requiring the high-speed USB controller to enter idle mode. The high-speed USB controller acknowledges when it is ready.

#### 22.1.3.2.3 *MSTANDBY Handshake Protocol*

The PRCM module handles an MSTANDBY handshake protocol for the high-speed USB controller, which initiates the MSTANDBY handshake to inform the PRCM module when it enters standby mode and does not generate traffic on interconnect.

#### 22.1.3.2.4 *Wake-Up Request*

The high-speed USB controller generates a wake-up request signal (UBSHS\_SWAKEUP) to the PRCM module.

## **22.1.4 High-Speed USB OTG Controller Functional Description**

### **22.1.4.1 Inventra™ MUSBMHDRC**

The core functionality of the module is provided by a third-party IP, the Inventra MUSBMHDRC from Mentor Graphics Corporation.

The high-speed USB controller is basically the appropriate adaptation/integration of this IP to comply with TI requirements.

The high-speed USB controller includes the following:

- MUSBMHDRC (USB 2.0 controller)
- Master and slave bridges for conversion AHB to L3 interconnect and L3 interconnect to AHB
- Two memories (total of 16Kbytes; available for various endpoints)
- Reset and clock generation

[Figure 22-6](#) shows the high-speed USB controller.

**Figure 22-6. High-Speed USB Controller**



usb-005

## 22.1.4.2 Configuration

The Mentor Graphics IP RTL MUSBMHDRC can be configured to generate some customized hardware. Those options are all hard-wired and cannot be reprogrammed in the case of the TI High-Speed USB controller.

The following options are selected:

- 8-bit internal data path processing width (mandated by the use of ULPI)
- 32-bit vcontrol/vstatus support
- External charge pump: Hacked
- Software connect/disconnect supported
- Little-endian and big-endian byte ordering
- Eight DMA channels (with internal DMA initiator implemented)
- Dynamic FIFO sizing enabled
- 16K bytes RAM buffer
- 15 IN/OUT endpoints in addition to control endpoint 0
- IN/OUT bulk packet splitting/combining enabled
- High-bandwidth IN/OUT isochronous support enabled (see *Universal Serial Bus Specification Revision 2.0*)

## 22.1.4.3 Basic Operation

This section provides an overview of the module basic operation.

To implement the most time-critical functions in hardware, the module provides all of the encoding, decoding, and checking required to send and receive USB packets-interrupting the MPU only when endpoint data is successfully transferred. Generally, the following steps are performed:

### 22.1.4.3.1 Module Initialization

First, the firmware must do the overall initialization of the module by configuring the interrupts, the DMA controller, and the individual endpoints.

The specific items of a configuration are for each endpoint:

- Direction TX/RX
- Speed: High/full/low
- Special host settings when used in host mode (function address/hub parameters, etc.)
- Transaction protocol: Control/isochronous/bulk/interrupt
- Maximum packet size, that can be transferred through the endpoint
- Whether DMA is required (DMA enable)
- DMA mode
- Start address of the endpoint FIFO within the RAM block
- Maximum packet size allowed
- Whether double-buffering is required. This and the previous option define the amount of space that must be allocated to the FIFO. In the case of double-buffering, the FIFO size is doubled; therefore, the maximum supported size is 8196 bytes for the endpoint FIFOs.

---

**NOTE:** On the system level, it must be ensured that the reset and the interface are selected before the 60-MHz functional clock (USBHS\_FCLK) is applied to the module. Correct functionality is not ensured if either a reset deassertion or a change in the interface selection occurs when the functional clock USBHS\_FCLK is already running.

---

#### 22.1.4.3.1.1 MSTANDBY Deassertion

MSTANDBY is asserted during reset and continues to be 1 after reset. The high-speed USB controller does not perform master interface transactions until this signal is deasserted. Firmware must follow these steps to begin normal operations on the master interface bus:

- Write 0 to the USBOTG.OTG\_FORCESTDBY[0] ENABLEFORCE bit.
- Put the high-speed USB controller into no-idle mode (USBOTG.OTG\_SYSCONFIG[4:3] SIDLEMODE field = 0x1) and no-standby mode (USBOTG.OTG\_SYSCONFIG[13:12] MIDLEMODE field = 0x1).

Even though ENABLEFORCE is 0, MSTANDBY remains asserted until the high-speed USB controller core is out of idle state.

#### 22.1.4.3.2 Transaction Handling

Depending on whether the module is in the host or peripheral mode, an RX endpoint is assigned to IN or OUT transactions, respectively. Similarly, a TX endpoint is used for IN transactions in the peripheral mode and for OUT transactions in the host mode. When a transaction is complete, the appropriate endpoint interrupt is generated (if enabled).

When a transaction is handled through an RX endpoint, the received packet is placed in the RX FIFO, and the appropriate RX endpoint interrupt is generated. The packet can then be unloaded from the FIFO either manually (that is, by the MPU) or by the DMA. Although an RX endpoint is always active for a peripheral, in host mode the transaction must first be initiated by setting the appropriate request flag (REQPKT). This indicates to the transaction scheduler that there is an active transaction on this endpoint, which requires an IN token to be sent to the target function.

When a transaction is handled through a TX endpoint, the packet to send is loaded into the TX FIFO either manually (that is, by the MPU) or by the DMA. The transaction then must be initiated by setting the appropriate ready flag (TXPKTRDY) to indicate the availability of the new packet. When the packet is successfully sent (scheduled according to the protocol rules), the appropriate TX interrupt is generated.

#### 22.1.4.4 Optional Features

This section gives a quick overview of the optional features that are available, depending on the endpoint configuration.

##### 22.1.4.4.1 Double Packet Buffering

When double packet buffering is enabled (by setting the MSB of the FIFOSZ register two data packets can be stored in the FIFO. This option can be set for both the TX and RX endpoints in both the peripheral and host mode. For a TX endpoint, double-buffering means that up to two packets can be loaded into the FIFO awaiting transmission; for an RX endpoint, one packet can be received while another is being read.

Double packet buffering is especially advisable for isochronous transactions to avoid underrun or overrun errors.

The high-speed USB controller provides dynamic FIFO sizing with an overall RAM size of 16K bytes, which can then be allocated to the different endpoints when the module is initialized. The maximum size of an endpoint FIFO is 4096 bytes for single packet buffering and 8192 bytes for double packet buffering.

The firmware must ensure that a block of RAM is properly assigned to all TX and RX endpoints, considering the total RAM size and the maximum packet size set for the endpoint.

##### 22.1.4.4.2 High-Speed USB OTG Support for Big Endian

In the example in [Figure 22-7](#), the high-speed USB OTG controller module is configured as a USB device and is connected to a standard USB host. The two interconnect interfaces of the high-speed USB OTG controller connect it to the system bus. The register read/write is performed through the interconnect slave interface (control path). The data transfer to/from system memory takes place through the interconnect master interface (data path).

The data transfer on the USB is always in little-endian mode, but on interconnect it can be in little- or big-endian mode, as shown in [Figure 22-7](#).

**Figure 22-7. High-Speed USB OTG Controller Endianess**

usb-036

Big-endian support in the high-speed USB OTG controller may or may not require byte-swapping in the data path. Byte-swapping is performed based on the unit size of data. For example, if multiple bytes are packed into one 32-bit word, these bytes must be swapped in a big-endian interconnect. On the other hand, if the data is only a 32-bit word (for example, a 32-bit descriptor pointer in a memory buffer), the bytes in the word must not be swapped in big-endian mode.

In the high-speed USB OTG controller, the unit size of descriptors(descriptor pointers is 32 bits and that of the USB data is 8 bits. Four 8-bit USB data are packed to form a 32-bit word. This 32-bit data requires byte-swapping, whereas the descriptorsdescriptor pointers do not require the same.

---

**NOTE:** Byte-swapping is not required in the control path (slave interface).

---

The OCP master interface (a submodule within the OCP wrapper) supports big-endian conversion by setting the OTG\_BIGENDIAN[0] BIG\_ENDIAN bit to 0x1.

For interconnect write transactions, the data word is swapped as shown in [Table 22-7](#) before its output on the interconnect master interface. In case of an interconnect read transaction, the received data is swapped before its output on the AHB master interface of the MUSBMHDRC core. The OCP MByteEn is swapped before the command is issued on the OCP master interface. The OCP MAddr is always aligned to the interconnect data size (32 bits). Therefore, the OCP MAddr is always word-aligned.

**Table 22-7. Interconnect Data and MByteEn in Little- and Big-Endian Modes**

| Unit Size of Data | AHB Size (of Packed/Nonpacked Data) | AHB Start Address Offset (Always in Little-Endian Mode) | OCP MByteEn in Little-Endian Mode | OCP MByteEn in Big-Endian Mode | OCP Data in Little-Endian Mode | OCP Data in Big-Endian Mode |
|-------------------|-------------------------------------|---------------------------------------------------------|-----------------------------------|--------------------------------|--------------------------------|-----------------------------|
| Byte              | Byte                                | 0                                                       | 0001                              | 1000                           | xxxb0                          | b0xxx                       |
| Byte              | Byte                                | 1                                                       | 0010                              | 0100                           | xxb0x                          | xb0xx                       |
| Byte              | Byte                                | 2                                                       | 0100                              | 0010                           | xb0xx                          | xxb0x                       |
| Byte              | Byte                                | 3                                                       | 1000                              | 0001                           | b0xxx                          | xxxb0                       |
| Byte              | Half-word                           | 0                                                       | 0011                              | 1100                           | xxb1b0                         | b0b1xx                      |

**Table 22-7. Interconnect Data and MByteEn in Little- and Big-Endian Modes (continued)**

| Unit Size of Data | AHB Size (of Packed/Nonpacked Data) | AHB Start Address Offset (Always in Little-Endian Mode) | OCP MByteEn in Little-Endian Mode | OCP MByteEn in Big-Endian Mode | OCP Data in Little-Endian Mode | OCP Data in Big-Endian Mode |
|-------------------|-------------------------------------|---------------------------------------------------------|-----------------------------------|--------------------------------|--------------------------------|-----------------------------|
| Byte              | Half-word                           | 2                                                       | 1100                              | 0011                           | b1b0xx                         | xxb0b1                      |
| Byte              | Word                                | 0                                                       | 1111                              | 1111                           | b3b2b1b0                       | b0b1b2b3                    |
| Half-word         | Half-word <sup>(1)</sup>            | 0                                                       | 0011                              | 1100                           | xxb1b0                         | b1b0xx                      |
| Half-word         | Half-word <sup>(1)</sup>            | 2                                                       | 1100                              | 0011                           | b1b0xx                         | xxb1b0                      |
| Half-word         | Word <sup>(1)</sup>                 | 0                                                       | 1111                              | 1111                           | b3b2b1b0                       | b1b0b3b2                    |
| Word              | Word <sup>(2)</sup>                 | 0                                                       | 1111                              | 1111                           | b3b2b1b0                       | b3b2b1b0                    |

<sup>(1)</sup> Not a likely scenario for high-speed USB OTG controller

<sup>(2)</sup> Corresponds to descriptor and descriptor pointer. No bytes are packed to form a word; therefore, no byte-swapping is done in this case.

#### 22.1.4.4.3 DMA

The high-speed USB controller has an internal DMA controller for efficient loading/unloading of the endpoint FIFOs.

If the DMA is enabled for a TX endpoint, a DMA transfer occurs whenever the endpoint can accept another packet in its FIFO (that is, the DMA controller loads the packets into the FIFO without processor intervention).

If the DMA is enabled for an RX endpoint, a DMA transfer occurs whenever the endpoint has a packet in its FIFO (that is, the DMA CONTROLLER unloads the packets from the FIFO without processor intervention).

The high-speed USB controller supports two DMA request modes, which also affects the generation of endpoint interrupts.

- DMA request mode 0 is especially advisable for isochronous transfers but can also be used for bulk and interrupt transfers.
- DMA request mode 1 is mainly valuable for bulk transfers, where typically a large block of data is split into a series of packets of the maximum size.

##### 22.1.4.4.3.1 DMA Request Mode 0

For RX endpoints, the DMA transfer is initiated when a data packet is available in the endpoint FIFO. The appropriate endpoint interrupt is also generated after the packets are received.

For TX endpoints, the DMA transfer is initiated when the endpoint FIFO can accept a data packet. The appropriate endpoint interrupt is also generated to prompt the loading of the packets.

##### 22.1.4.4.3.2 DMA Request Mode 1

For RX endpoints the DMA transfer is initiated only when the received packet is the maximum packet size (as set in the RXMAXP register for the corresponding endpoint). The appropriate endpoint interrupt is generated only when the received packet is a short packet (that is, one less than the maximum packet size); otherwise, it is suppressed.

For TX endpoints, the DMA transfer is initiated when the endpoint FIFO can accept a data packet. The appropriate endpoint interrupt is suppressed.

##### 22.1.4.4.3.3 Internal DMA Controller

The high-speed USB controller has an internal DMA controller to perform DMA transfers acting as host on the L3 interconnect. The DMA controller has eight channels, which can be independently programmed based on the following configuration options:

- DMA enable

- Direction (DMA write/DMA read)
- DMA mode (transfer one or more packets)
- Interrupt enable
- Endpoint number
- L3 interconnect memory address (32 bits)
- Byte count

The DMA controller can issue single accesses (8-, 16-, or 32-bit) and also bursts ( $4 \times 32\text{-bit}$ ,  $8 \times 32\text{-bit}$ , or  $16 \times 32\text{-bit}$ ) on the L3 interconnect. The start address provided to the DMA controller must be 32-bit aligned.

#### 22.1.4.5 Automatic Packet Splitting/Combining for Bulk Transfers

The high-speed USB controller offers the facility for bulk endpoints to store larger amounts of data in their FIFOs than can be transferred in a single USB operation. In other words, the module includes a configuration option that, if selected, allows larger data packets to be written to bulk TX endpoints, which are then split into packets of an appropriate size for transfer across the USB. A similar option exists for bulk RX endpoints, which, if selected, causes the module to combine the packet received across the USB into larger data packets before being read by the application software.

The firmware can enable these options by setting the corresponding bits (MPRXE and MPTXE) in the CONFIGDATA register. The necessary packet size information contains the payload size for one transaction and a multiplier defining the maximum number of USB packets. The payload is required to be either 8, 16, 32, 64, or (in case of high-speed transfers) 512 bytes; the multiplier can be any value up to 32.

#### 22.1.4.6 High-Bandwidth Isochronous Endpoints

In the high-speed mode, isochronous endpoints can transfer up to three USB packets in any microframe with a payload of up to 1024 bytes in each packet, corresponding to a data transfer rate of up to 3072 bytes per microframe (see *Universal Serial Bus Specification Revision 2.0*).

For TX endpoints, the high-speed USB controller supports this by allowing loading data packets of up to 3072 bytes (that is,  $3 \times 1024$  bytes) into the associated endpoint FIFO, which is then automatically split into USB packets of the maximum payload, or smaller to be transmitted in one microframe.

For RX endpoints, the module automatically combines all the USB packets received during a microframe into a single packet of up to 3072 bytes (that is,  $3 \times 1024$  bytes) within the RX FIFO.

The number of USB packets transferred per microframe and the maximum payload in each packet is defined through the appropriate registers (RXMAXP and TXMAXP).

### 22.1.5 High-Speed USB OTG Controller Basic Programming Model

This section describes only the TI-specific programming model details.

#### 22.1.5.1 High-Speed USB Controller Interface Selection

The TI High-Speed USB controller supports only the 12-pin/8-bit data version ULPI interface (see [Table 22-16](#)).

The 8-pin, 4-bit version ULPI interface and 8-bit UTMI+ Level 3 interface are not supported.

The 12-pin/8-bit data SDR ULPI interface is selected through the USBOTG.[OTG\\_INTERFSEL\[1:0\]](#) PHYSEL field set to 0x1.

#### 22.1.5.2 Enable Simulation Acceleration Features

The USBOTG.[OTG\\_SIMENABLE](#) register is dedicated solely for simulation (see [Table 22-18](#)) and is used to reduce timer length and, hence, the time taken for the test bench to run.

This special mode can be active only during simulation and must be disabled for normal operation. The firmware must keep TM1 inactive (reset value) during normal operation. An accidental write to this register can cause a malfunction.

### 22.1.5.3 Enabling MSTANDBY in Force-Standby Mode

The USBOTG.OTG\_FORCESTDBY[0] ENABLEFORCE bit controls MSTANDBY behavior in force-standby mode only (see [Table 22-20](#)). In this mode, only when the internal core is idle (the module has no activity; that is, the USB is in suspend state) and when 1 is written to this bit, MSTANDBY goes high. Similarly, when ENABLEFORCE is 0 and the internal core is also in a non-idle state, MSTANDBY is deasserted. This bit does not influence MSTANDBY behavior in all other modes, such as no-standby and smart-standby.

### 22.1.5.4 Power Management Basic Programming Model

This section describes the settings for optimal High-Speed USB controller power management, depending on the use of this module in the application.

Two registers are involved in power management: USBOTG.OTG\_SYSCONFIG and USBOTG.OTG\_FORCESTDBY.

On reset, the high-speed USB controller has the following configuration:

- Master interface power management is in force-standby mode (USBOTG.OTG\_SYSCONFIG[13:12] MIDLEMODE field = 0x0).
- Slave interface power management is in force-idle mode (USBOTG.OTG\_SYSCONFIG[4:3] SIDLEMODE field = 0x0).
- Internal clock autogating feature is disabled (USBOTG.OTG\_SYSCONFIG[0] AUTOIDLE bit = 0).
- MSTANDBY signal assertion is enabled (USBOTG.OTG\_FORCESTDBY[0] ENABLEFORCE bit = 1).

#### 22.1.5.4.1 High-Speed USB Controller Not Used for Application

In this scenario, the high-speed USB controller is not used by the system software. Default settings must be changed to reduce power consumption. Enabling the internal clock autogating feature cuts off the module internal interface clock as soon as it is no longer required. This is done by setting the USBOTG.OTG\_SYSCONFIG[0] AUTOIDLE bit to 1.

The optimal configuration when the high-speed USB controller is not used by the application is as follows:

- Master interface power management is in force-standby mode (USBOTG.OTG\_SYSCONFIG[13:12] MIDLEMODE field = 0x0).
- Slave interface power management is in force-idle mode (USBOTG.OTG\_SYSCONFIG[4:3] SIDLEMODE field = 0x0).
- Internal clock autogating feature is enabled (USBOTG.OTG\_SYSCONFIG[0] AUTOIDLE bit = 1).
- MSTANDBY signal assertion enabled (USBOTG.OTG\_FORCESTDBY[0] ENABLEFORCE bit = 1)

#### 22.1.5.4.2 High-Speed USB Controller in Host Mode

When used as a host, the high-speed USB controller must be programmed as follows:

- Master interface power management in smart-standby mode
- Slave interface power management in smart-idle mode
- Internal clock autogating feature enabled
- MSTANDBY signal assertion disabled

The programming sequence must be as follows:

1. Write 0 to the USBOTG.OTG\_FORCESTDBY[0] ENABLEFORCE bit to disable the MSTANDBY assertion before programming to smart-standby and smart-idle modes.

2. Set the USBOTG.OTG\_SYSConfig[13:12] MIDLEMODE field to 0x2, the USBOTG.OTG\_SYSConfig[4:3] SIDLEMODE field to 0x2, and the USBOTG.OTG\_SYSConfig[0] AUTOIDLE bit to 0 to program the smart-standby and smart-idle modes. Ensure that internal clock autogating is not enabled while programming smart-idle mode.
3. Set the USBOTG.OTG\_SYSConfig[0] AUTOIDLE bit to 1 to cut off the internal clocks to save power.

---

**NOTE:** The internal clock autogating feature and smart-idle mode must not be programmed simultaneously.

---

#### 22.1.5.4.3 High-Speed USB Controller in Peripheral Mode

When used as a peripheral, the high-speed USB controller must be programmed as follows:

- Master interface power management in smart-standby mode
- Slave interface power management in smart-idle mode
- Internal clock autogating feature enabled
- MSTANDBY signal assertion disabled

The programming sequence must be as follows:

1. Write 0 to the USBOTG.OTG\_FORCESTDBY[0] ENABLEFORCE bit to disable the MSTANDBY assertion before programming to smart-standby mode.
2. Set the USBOTG.OTG\_SYSConfig[13:12] MIDLEMODE field to 0x2, the USBOTG.OTG\_SYSConfig[4:3] SIDLEMODE field to 0x2, and the USBOTG.OTG\_SYSConfig[0] AUTOIDLE bit to 0 to program the smart-standby and smart-idle modes. Ensure that the internal clock autogating is not enabled while programming the smart-idle mode..
3. Set the USBOTG.OTG\_SYSConfig[0] AUTOIDLE bit to 1 to cut off the internal clocks to save power.

---

**NOTE:** The internal clock autogating feature and smart-idle mode must not be programmed simultaneously.

---

#### 22.1.5.4.4 High-Speed USB Controller in Host/Peripheral Mode

When used as a host/peripheral, the high-speed USB controller must be programmed as follows:

- Master interface power management in smart-standby mode
- Slave interface power management in smart-idle mode
- Internal clock autogating feature enabled
- MSTANDBY signal assertion disabled

See [Section 22.1.5.4.2](#) and [Section 22.1.5.4.3](#) for the programming sequence.

As an application required to disable the master interface, the high-speed USB controller can also be programmed as follows:

- Master interface power management in force-standby mode
- Slave interface power management in smart-idle mode
- Internal clock autogating feature enabled
- MSTANDBY signal assertion enabled

The programming sequence must be as follows:

1. Write 0 to the USBOTG.OTG\_FORCESTDBY[0] ENABLEFORCE bit to disable the MSTANDBY assertion before programming to smart-standby mode.
2. Set the USBOTG.OTG\_SYSConfig[13:12] MIDLEMODE field to 0x0, the USBOTG.OTG\_SYSConfig[4:3] SIDLEMODE field to 0x2, and the USBOTG.OTG\_SYSConfig[0] AUTOIDLE bit to 0 to program the force-standby and smart-idle modes. Ensure that the internal clock autogating is not enabled while programming smart-idle mode.

3. Set the USBOTG.OTG\_FORCESTDBY[0] ENABLEFORCE bit to 1 to enable the MSTANDBY assertion before enabling internal clock autogating feature.
4. Set the USBOTG.OTG\_SYSCONFIG[0] AUTOIDLE bit to 1 to cut off the internal clocks to save power.

---

**NOTE:** The internal clock the autogating feature and smart-idle mode must not be programmed simultaneously.

---

## 22.1.6 High-Speed USB OTG Controller Register Manual

As this chapter describes only the TI-specific details, this section presents only the TI-specific registers of the high-speed USB controller.

[Table 22-8](#) lists the base address and address space for the high-speed USB controller.

**Table 22-8. High-Speed USB Controller Instance Summary**

| Module Name | Base Address | Size |
|-------------|--------------|------|
| USBHS       | 0x480A B000  | 4KB  |

**CAUTION**

The high-speed USB registers are limited to 32-bit data accesses; 16-bit and 8-bit accesses are not allowed and can corrupt register content.

### 22.1.6.1 High-Speed USB OTG Controller Registers

#### 22.1.6.1.1 High-Speed USB Register Summary

**Table 22-9. High-Speed USB Controller Register Summary**

| Register Name  | Type | Register Width (Bits) | Address Offset | USBHS Physical Address |
|----------------|------|-----------------------|----------------|------------------------|
| OTG_REVISION   | R    | 32                    | 0x400          | 0x480A B400            |
| OTG_SYSCONFIG  | RW   | 32                    | 0x404          | 0x480A B404            |
| OTG_SYSSTATUS  | R    | 32                    | 0x408          | 0x480A B408            |
| OTG_INTERFSEL  | RW   | 32                    | 0x40C          | 0x480A B40C            |
| OTG_SIMENABLE  | RW   | 32                    | 0x410          | 0x480A B410            |
| OTG_FORCESTDBY | RW   | 32                    | 0x414          | 0x480A B414            |
| OTG_BIGENDIAN  | RW   | 32                    | 0x418          | 0x480A B418            |

#### 22.1.6.1.2 High-Speed USB Register Description

**Table 22-10. OTG\_REVISION**

|                  |                                          |          |       |
|------------------|------------------------------------------|----------|-------|
| Address Offset   | 0x0000 0400                              | Instance | USBHS |
| Physical Address | See <a href="#">Table 22-9</a>           |          |       |
| Description      | Standard USB OTG HS core revision number |          |       |
| Type             | R                                        |          |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|--------------|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | OTG_REVISION |   |   |   |   |   |

| Bits | Field Name   | Description                  | Type | Reset              |
|------|--------------|------------------------------|------|--------------------|
| 31:8 | Reserved     | Reserved                     | R    | 0x000000           |
| 7:0  | OTG_REVISION | Revision number, BCD-encoded | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 22-11. Register Call Summary for Register OTG\_REVISION**

High-Speed USB OTG Controller

- [High-Speed USB OTG Controller Registers: \[0\]](#)

**Table 22-12. OTG\_SYSCONFIG**

|                         |                         |                         |                                |                 |                                       |
|-------------------------|-------------------------|-------------------------|--------------------------------|-----------------|---------------------------------------|
| <b>Address Offset</b>   | 0x0000 0404             | <b>Physical Address</b> | See <a href="#">Table 22-9</a> | <b>Instance</b> | USBHS                                 |
| <b>Description</b>      | Standard configuration  |                         |                                |                 |                                       |
| <b>Type</b>             | RW                      |                         |                                |                 |                                       |
| 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                |                 |                                       |
|                         |                         |                         |                                |                 |                                       |
|                         | RESERVED                | MIDLEMODE               | RESERVED                       | SIDLEMODE       | ENABLEWAKEUP<br>SOFTRESET<br>AUTOIDLE |
|                         |                         |                         |                                |                 |                                       |

| Bits  | Field Name   | Description                                                                                                                                                                                                                                                                           | Type | Reset   |
|-------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | RESERVED     | reserved                                                                                                                                                                                                                                                                              | R    | 0x00000 |
| 13:12 | MIDLEMODE    | Master interface power management control. Standby/wait control<br><br>0x0: Force Standby mode. Mstandby asserted unconditionally<br>0x1: No standby mode. Mstandby never asserted.<br>0x2: Smart standby mode. Mstandby asserted when no more activity on the USB master.            | RW   | 0x0     |
| 11:5  | RESERVED     | reserved                                                                                                                                                                                                                                                                              | R    | 0x00    |
| 4:3   | SIDLEMODE    | Slave interface power management control. Req/ack control<br><br>0x0: Force Idle mode. Sidleack asserted after Midlereq assertion<br>0x1: No idle mode. Sidleack never asserted.<br>0x2: Smartidle mode. Sidleack asserted after Midlereq assertion when no more activity on the USB. | RW   | 0X0     |
| 2     | ENABLEWAKEUP | Enable wakeup capability<br><br>0x0: Wakeup disabled<br>0x1: Wakeup enabled                                                                                                                                                                                                           | RW   | 0       |
| 1     | SOFTRESET    | Software reset bit<br><br>0x1: Starts softreset sequence.                                                                                                                                                                                                                             | RW   | 0       |
| 0     | AUTOIDLE     | Autoidle bit<br><br>0x0: Clock always running<br>0x1: When no activity on L3 interconnect, clock is cut off.                                                                                                                                                                          | RW   | 1       |

**Table 22-13. Register Call Summary for Register OTG\_SYSCONFIG**

High-Speed USB OTG Controller

- [Clocking, Reset, and Power-Management Scheme: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\]](#)
- [Basic Operation: \[13\] \[14\]](#)
- [Power Management Basic Programming Model: \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\] \[22\] \[23\] \[24\] \[25\] \[26\] \[27\] \[28\] \[29\] \[30\] \[31\] \[32\] \[33\] \[34\]](#)
- [High-Speed USB OTG Controller Registers: \[35\]](#)

**Table 22-14. OTG\_SYSSTATUS**

| <b>Address Offset</b>   | 0x0000 0408             | <b>Physical Address</b>                                               | See <a href="#">Table 22-9</a> | <b>Instance</b> | USBHS     |      |             |
|-------------------------|-------------------------|-----------------------------------------------------------------------|--------------------------------|-----------------|-----------|------|-------------|
| <b>Description</b>      | OCP standard status     |                                                                       |                                |                 |           |      |             |
| <b>Type</b>             | R                       |                                                                       |                                |                 |           |      |             |
| 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                | RESERVED        |           |      |             |
|                         |                         |                                                                       |                                |                 | RESETDONE |      |             |
| Bits                    | Field Name              | Description                                                           |                                |                 |           | Type | Reset       |
| 31:1                    | RESERVED                | reserved                                                              |                                |                 |           | R    | 0x0000 0000 |
| 0                       | RESETDONE               | resetdone<br>Read 0x0: On going reset<br>Read 0x1: Reset is finished. |                                |                 |           | R    | 1           |

**Table 22-15. Register Call Summary for Register OTG\_SYSSTATUS**

High-Speed USB OTG Controller

- [High-Speed USB OTG Controller Registers: \[0\]](#)

**Table 22-16. OTG\_INTERFSEL**

| <b>Address Offset</b>   | 0x0000 040C                    | <b>Physical Address</b>                                                                                                                                                                                                          | See <a href="#">Table 22-9</a> | <b>Instance</b> | USBHS  |      |             |
|-------------------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-----------------|--------|------|-------------|
| <b>Description</b>      | USB OTG HS interface selection |                                                                                                                                                                                                                                  |                                |                 |        |      |             |
| <b>Type</b>             | RW                             |                                                                                                                                                                                                                                  |                                |                 |        |      |             |
| 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                | RESERVED        |        |      |             |
|                         |                                |                                                                                                                                                                                                                                  |                                |                 | PHYSEL |      |             |
| Bits                    | Field Name                     | Description                                                                                                                                                                                                                      |                                |                 |        | Type | Reset       |
| 31:2                    | RESERVED                       | Reserved                                                                                                                                                                                                                         |                                |                 |        | R    | 0x0000 0000 |
| 1:0                     | PHYSEL                         | PHY interface selection<br>0x0: PHY interface is 8-bit, UTMI+ level 3. Not supported in the device.<br>0x1: PHY interface is 12-pin, 8-bit SDR ULPI<br>0x2: PHY interface is 8-pin, 4-bit DDR ULPI. Not supported in the device. |                                |                 |        | RW   | 0x1         |

**Table 22-17. Register Call Summary for Register OTG\_INTERFSEL**

High-Speed USB OTG Controller

- [High-Speed USB OTG Controller Environment: \[0\]](#)
- [High-Speed USB Controller Interface Selection: \[1\]](#)
- [High-Speed USB OTG Controller Registers: \[2\]](#)

**Table 22-18. OTG\_SIMENABLE**

|                                                                                    |                                                                                                                                 |
|------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>                                                              | 0x0000 0410                                                                                                                     |
| <b>Physical Address</b>                                                            | See <a href="#">Table 22-9</a>                                                                                                  |
| <b>Description</b>                                                                 | Enable simulation acceleration features.<br>WARNING: For simulations only, since those features have an impact on USB protocol. |
| <b>Type</b>                                                                        | RW                                                                                                                              |
|  |                                                                                                                                 |
| RESERVED                                                                           |                                                                                                                                 |
| TM1                                                                                |                                                                                                                                 |

| Bits | Field Name | Description                            | Type | Reset       |
|------|------------|----------------------------------------|------|-------------|
| 31:1 | RESERVED   | reserved                               | R    | 0x0000 0000 |
| 0    | TM1        | Test Mode 1 enabling (timer shortcuts) | RW   | 0           |

**Table 22-19. Register Call Summary for Register OTG\_SIMENABLE**

High-Speed USB OTG Controller

- [Enable Simulation Acceleration Features: \[0\]](#)
- [High-Speed USB OTG Controller Registers: \[1\]](#)

**Table 22-20. OTG\_FORCESTDBY**

|                                                                                      |                                         |
|--------------------------------------------------------------------------------------|-----------------------------------------|
| <b>Address Offset</b>                                                                | 0x0000 0414                             |
| <b>Physical Address</b>                                                              | See <a href="#">Table 22-9</a>          |
| <b>Description</b>                                                                   | Enabling MSTANDBY in FORCESTANDBY mode. |
| <b>Type</b>                                                                          | RW                                      |
|  |                                         |
| RESERVED                                                                             |                                         |
| ENABLEFORCE                                                                          |                                         |

| Bits | Field Name  | Description                  | Type | Reset       |
|------|-------------|------------------------------|------|-------------|
| 31:1 | RESERVED    | Reserved                     | R    | 0x0000 0000 |
| 0    | ENABLEFORCE | Enabling MSTANDBY to go high | RW   | 1           |

**Table 22-21. Register Call Summary for Register OTG\_FORCESTDBY**

High-Speed USB OTG Controller

- [Clocking, Reset, and Power-Management Scheme: \[0\] \[1\] \[2\] \[3\] \[4\] \[5\]](#)
- [Basic Operation: \[6\]](#)
- [Enabling MSTANDBY in Force-Standby Mode: \[7\]](#)
- [Power Management Basic Programming Model: \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\]](#)
- [High-Speed USB OTG Controller Registers: \[15\]](#)

**Table 22-22. OTG\_BIGENDIAN**

|                         |                                     |                         |                                |                 |            |
|-------------------------|-------------------------------------|-------------------------|--------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0418                         | <b>Physical Address</b> | See <a href="#">Table 22-9</a> | <b>Instance</b> | USBHS      |
| <b>Description</b>      | Enable BIG ENDIANESS for OCP MASTER |                         |                                |                 |            |
| <b>Type</b>             | RW                                  |                         |                                |                 |            |
| 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                |                 |            |
|                         |                                     |                         |                                | RESERVED        |            |
|                         |                                     |                         |                                |                 | BIG_ENDIAN |

| Bits | Field Name | Description                     | Type | Reset       |
|------|------------|---------------------------------|------|-------------|
| 31:1 | RESERVED   | Reserved                        | R    | 0x0000 0000 |
| 0    | BIG_ENDIAN | Enable BIG ENDIAN in OCP MASTER | RW   | 0x0         |
|      |            | 0x0 Little Endian               |      |             |
|      |            | 0x1 Big Endian                  |      |             |

**Table 22-23. Register Call Summary for Register OTG\_BIGENDIAN**

High-Speed USB OTG Controller

- [High-Speed USB OTG Controller Registers: \[0\]](#)

## 22.2 High-Speed USB Host Subsystem

**NOTE:** Copyright ©2004,2005, 2006, 2007, 2008 Synopsys, Inc. All rights reserved. Used with permission.

### 22.2.1 High-Speed USB Host Subsystem Overview

The high-speed universal serial bus (USB) host subsystem is composed of the high-speed multiport USB host controller and the USBTLL module.

The USB controller is a high-speed multiport USB2.0 host controller. It contains two independent, 3-port host controllers that operate in parallel:

- The EHCI controller, based on the *Enhanced Host Controller Interface (EHCI) specification for USB Release 1.0*, is in charge of high-speed traffic (480M bit/s), over the ULPI/UTMI interface
- The OHCI controller, based on the *Open Host Controller Interface (OHCI) specification for USB Release 1.0a*, is in charge of full-speed/low-speed traffic (12/1.5M bit/s, respectively), over a serial interface

Each of the three device external ports is owned by exactly one and only one of the controllers at any time.

The USBTLL module is a high-speed USB UTMI low-pin interface (ULPI) transceiverless link logic (TLL) adapter. It implements a TLL compatible with a number of USB standard interface protocols. It consists of three channels, defined as independent USB path through the TLL module, which always converts the UTMI+ PHY interface protocol coming from the high-speed USB host controller.

Each USB port (1, 2, and 3) can connect either to an external-to-device chip USB transceiver or directly using a transceiverless link to an external integrated circuit (IC) supporting the same TLL protocol.

[Figure 22-8](#) highlights the high-speed USB host subsystem.

**Figure 22-8. High-Speed USB Host Subsystem Highlight**


usb-007

### 22.2.1.1 Main Features

The high-speed USB host subsystem includes the following features:

- **Multiport high-speed USB host controller:**
  - Complies with the USB 2.0 standard for high-speed (480 Mbps) functions
  - USB 2.0 low-speed (1.5M bit/s), full-speed (12M bit/s), and high-speed (480M bit/s) operations
  - Three downstream ports (3-port root hub)
  - Complies with EHCI (high-speed host controller)
  - Complies with OHCI (low-speed/full-speed host controller)
  - Supports suspend/resume and remote wakeup
  - Interface with USBTLL port A on all ports (UTMI+)
    - 8-bit datapath
    - 60-MHz synchronous (on-chip) interface
  - Interface with ULPI PHYs (transceivers) on all ports (only two mapped)
    - 12-pin/8-bit data single data rate (SDR) mode
    - 60-MHz clock input, provided by the host not the PHY (see TLL module below)

**CAUTION**

The HS USB host subsystem can only support the external charge pump of PHY (no support of internal charge pump for ULPI PHY)

- Hardware-driven save-and-restore of the suspended host hardware context
- Two interrupt lines
- USBTLL module
  - Three channels
  - Three ports (A, C, and D) by channel
- Port A: PHY-side UTMI+ port. Connects to the local link controller. The UTMI "local" port is used in all configurations, (that is, the entire channel can be seen as a protocol converted from that port to one of the other, "remote" ports).
  - Compliant with UTMI+ (USB 2.0 Transceiver Macrocell Interface) version 1.0
  - 8-data-bit, 60-MHz UTMI (HS/FS/LS-capable)
  - UTMI+ Level 3 extensions
  - Vcontrol/Vstatus (from UTMI)
  - Serial FS/LS "6-pin" mode
- Port C: PHY-side ULPI port. Connects to a remote (off-chip) ULPI link controller through I/O pads.
  - SDR and dual data rate (DDR) ULPI capable (resp 8/4-bit data width modes)
  - Supports optional 6-pin/3-pin serial modes
- Port D: Serial multimode port. Connects to either a serial link controller (TLL modes) or a serial PHY (PHY interface modes).
  - Supports 6-pin unidirectional, 4-pin bidirectional, 3-pin bidirectional, 2-pin bidirectional modes
  - All modes are supported for TLL or PHY interface configuration.
  - Supports sideband signals (pullup/down control, speed/suspend enable, etc)
- An interrupt line
- USB port signal pins interface supporting:
  - External USB transceivers
    - ULPI interface: 12-pin/8-bit data SDR version; ULPI clock provided by the device
    - Serial 6-pin PHY (transceiver) interfaces: 6-pin mode (TX: DAT/SE0 or TX: DP/DM unidirectional mode), 4-pin mode (DP/DM bidirectional mode), and 3-pin mode (DAT/SE0 bidirectional mode)
  - TLL mode
    - ULPI TLL interfaces: 12-pin/8-bit data SDR and 8-pin/4-bit data DDR versions
    - Serial 6-pin TLL interfaces: 6-pin mode (DAT/SE0 and DP/DM unidirectional modes), 4-pin mode, (DP/DM bidirectional mode), 3-pin mode (DAT/SE0 bidirectional mode) and 2-pin mode (DAT/SE0 and DP/DM bidirectional modes)

**Table 22-24. USB Connectivity Modes**

| USB Connectivity Modes              | Port 1 | Port 2 | Port 3 |
|-------------------------------------|--------|--------|--------|
| ULPI interface                      | ✓      | ✓      |        |
| Serial 6-pin transceiver interfaces | ✓      | ✓      | ✓      |
| ULPI TLL interfaces                 | ✓      | ✓      | ✓      |
| Serial 6-pin TLL interfaces         | ✓      | ✓      | ✓      |

---

**NOTE:** Only FS/LS USB transceivers can be connected to port 3; HS ULPI transceivers are not supported on port 3.

---

**WARNING**

**The three channels when in ULPI mode are always ULPI clock providers, an input clock is not accepted.**

## 22.2.2 High-Speed USB Host Subsystem Environment

The high-speed USB host controller provides two kinds of interfaces for connection:

- ULPI interfaces for high-speed data transactions (up to 480M bit/s)
- Serial interfaces (with the use of the USBTLL module) for full- and low-speed data transactions (up to 12M bit/s)

The high-speed USB host controller connects to either controllers (TLL modes) and/or transceivers. It supports the following configurations with the serial interfaces and ULPI interfaces:

- External USB transceiver configurations
  - ULPI interface: 12-pin/8-bit data SDR version
  - Serial 6-pin PHY (transceiver) interfaces: 6-pin mode (TX: DAT/SE0 or TX: DP/DM unidirectional mode), 4-pin mode (DP/DM bidirectional mode) and 3-pin mode (DAT/SE0 bidirectional mode)
- TLL configurations
  - ULPI TLL interfaces: 12-pin/8-bit data SDR and 8-pin/4-bit data DDR versions
  - Serial 6-pin TLL interfaces: 6-pin mode (DAT/SE0 and DP/DM unidirectional modes), 4-pin mode (DP/DM bidirectional mode), 3-pin mode (DAT/SE0 bidirectional mode), and 2-pin mode (DAT/SE0 and DP/DM bidirectional modes)

### 22.2.2.1 Standard USB Implementation: Transceiver Connection

From a logical point of view, a point-to-point USB connection is composed of several blocks, organized in protocol layers, and shown in [Figure 22-9](#).

**Figure 22-9. USB Connection**



The host system (USB master) and the peripheral system (USB slave) connected through the USB cable include a link or controller (link layer) and a PHY or transceiver (physical layer). Each system talks to its own controller, which talks to its own transceiver, which is connected to the opposite side (transceiver) through an assembly of connectors, receptacles, and cable.

### 22.2.2.2 TLL Connection

The TLL feature enables connection of the high-speed USB host subsystem to an external, onboard USB peripheral controller, without using USB transceivers or associated circuitry. When TLL is used, the following components are removed:

- Both USB transceivers
- The series resistors
- Pullup and pulldown resistors
- VBUS switching components
- USB connectors and cables, typically used between a USB host controller and the downstream USB peripheral controller

The TLL signaling system is not suitable for use across a cable. It is intended only for use when the device is used with an external USB integrated circuit (IC) that is on the same board.

When using the TLL, signals of the external USB IC pins, which typically connect to a USB transceiver, instead directly connect to the device pins. Signaling on these pins use CMOS levels. TLL logic can be used with external devices that support ULPI TLL interface and serial 6-pin TLL interface connectivity.

The TLL function in the device interprets the transmit control signals from the external USB IC and similar signals from the device USB host controller, and computes the equivalent USB differential-pair state. The computed differential-pair state is interpreted and the appropriate transceiver output signals are provided to the external USB IC and to the device USB host controller.

Figure 22-10 shows the device and how TLL can be compared to a typical USB implementation. The top portion of Figure 22-10 shows the a transceiver-based solution, and the bottom portion shows a transceiverless solution using TLL.

**Figure 22-10. High-Speed USB Host Controller Connection-With and Without TLL**



usb-009

**NOTE:** The USB bus lines (D+/D-) no longer appear in subsequent figures: They are emulated by the TLL.

### 22.2.2.3 ULPI Interfaces

The high-speed USB host subsystem supports the following configurations with the ULPI interfaces:

- External USB transceiver
  - ULPI interfaces: 12-pin/8-bit data SDR version
- TLL
  - ULPI TLL interfaces: 12-pin/8-bit data SDR and 8-pin/4-bit data DDR versions

The high-speed USB host subsystem supports USB ports, which use the ULPI interface mode to connect to an off-chip high-speed ULPI transceiver (12-pin/8-bit data SDR mode) for high- and full-speed data transactions (up to 480M bit/s). Using the ULPI interfaces in 12-pin/8-bit data version, the device and the transceiver achieve the USB function. A mini A-B external receptacle allows the connection of an external device.

The device supports TLL logic interfaces on its ports in the ULPI TLL interface mode. TLL modes enable glueless interconnect to another USB device port without a costly transceiver.

Figure 22-11 and Figure 22-12 show typical applications using the high-speed USB host subsystem with the ULPI, and the ULPI TLL, respectively.

**Figure 22-11. High-Speed USB Host Controller Typical Application System - ULPI Interfaces**



usb-010

NOTE: ULPI interfaces: USBTLL is bypassed and high-speed USB host controller ports 1 and 2 are connected directly to external transceivers.

**Figure 22-12. High-Speed USB Host Subsystem Typical Application System - ULPI TLL Interfaces**



usb-032

NOTE: ULPI TLL interfaces: The high-speed USB host controller is coupled with the USBTLL module to compose the ULPI TLL interface modes.

The current implementation of the ULPI includes a method for manual, software-controlled generation of PHY-side register accesses. This implies support of the following features:

- Access to vendor-specific or optional PHY-side registers
- Access to vendor ID, product ID, and scratch and debug registers

The 12-pin ULPI interface uses an 8-bit data bus with data synchronous to the rising edge of the PHY (transceiver) clock (SDR mode), whereas the 8-pin ULPI uses a 4-bit data bus with data generated on both the rising and falling clock edges (DDR mode).

### 22.2.2.3.1 Transceiver Interface Configurations

The high-speed USB host subsystem supports only the 12-pin/8-bit data SDR version of the ULPI interface mode.

---

**NOTE:** In the device, only the ULPI ports 1 and 2 of the high-speed USB host controller are mapped and can be connected directly to external transceivers.

---

Figure 22-13 shows USB ports using the 12-pin/8-bit data SDR version of the ULPI interface mode.

**Figure 22-13. ULPI Interfaces - 12-Pin/8-Bit Data SDR Version**



usb-011

### 22.2.2.3.2 TLL Configurations

The high-speed USB host controller is coupled with the USBTLL module to compose the ULPI TLL interface modes.

The high-speed USB host subsystem supports the 12-pin/8-bit data SDR and 8-pin/4-bit data DDR versions of the ULPI TLL interface mode.

Figure 22-14 shows USB ports using the 12-pin/8-bit data SDR version of the ULPI TLL interface mode.

**Figure 22-14. ULPI TLL Interfaces - 12-Pin/8-Bit Data SDR Version**



x is the USB port number (1, 2 or 3)

usb-012

Figure 22-15 shows USB ports using the 8-pin/4-bit data DDR version of the ULPI TLL interface mode.

**Figure 22-15. ULPI TLL Interfaces - 8-Pin/4-Bit Data DDR Version**



x is the USB port number (1, 2 or 3)

usb-013

### 22.2.2.3.3 High-Speed USB Host Subsystem Functional Interfaces

#### 22.2.2.3.3.1 Basic High-Speed USB Host Subsystem Pins

Figure 22-16 shows the high-speed USB host controller ULPI functional interfaces.

**Figure 22-16. High-Speed USB Host Subsystem Functional Interface Signals**



usb-014

### **22.2.2.3.3.2 High-Speed USB Host Subsystem Interface Description**

Table 22-25 describes the I/O of the high-speed USB host subsystem ULPI interfaces.

**Table 22-25. I/O Description**

| Signal Name       | I/O <sup>(1)</sup> | Description                                                | Reset Value |
|-------------------|--------------------|------------------------------------------------------------|-------------|
| <b>HSUSB1</b>     |                    |                                                            |             |
| hsusb1_clk        | O                  | 60-MHz clock output to ULPI transceiver <sup>(2)</sup>     | 0           |
| hsusb1_dir        | I                  | Data direction control from ULPI transceiver               | n/a         |
| hsusb1_stp        | O                  | Stop signal to ULPI transceiver                            | 1           |
| hsusb1_nxt        | I                  | Next signal from ULPI transceiver                          | n/a         |
| hsusb1_data0      | I/O                | Bidirectional DATA0                                        | n/a         |
| hsusb1_data1      | I/O                | Bidirectional DATA1                                        | n/a         |
| hsusb1_data2      | I/O                | Bidirectional DATA2                                        | n/a         |
| hsusb1_data3      | I/O                | Bidirectional DATA3                                        | n/a         |
| hsusb1_data4      | I/O                | Bidirectional DATA4                                        | n/a         |
| hsusb1_data5      | I/O                | Bidirectional DATA5                                        | n/a         |
| hsusb1_data6      | I/O                | Bidirectional DATA6                                        | n/a         |
| hsusb1_data7      | I/O                | Bidirectional DATA7                                        | n/a         |
| <b>HSUSB1 TLL</b> |                    |                                                            |             |
| hsusb1_tll_clk    | O                  | 60-MHz clock output to ULPI link controller <sup>(2)</sup> | 0           |
| hsusb1_tll_dir    | O                  | Data direction control from ULPI link controller           | 0           |
| hsusb1_tll_stp    | I                  | Stop signal to ULPI link controller                        | n/a         |
| hsusb1_tll_nxt    | O                  | Next signal from ULPI link controller                      | 0           |
| hsusb1_tll_data0  | I/O                | Bidirectional DATA0                                        | 0           |
| hsusb1_tll_data1  | I/O                | Bidirectional DATA1                                        | 0           |
| hsusb1_tll_data2  | I/O                | Bidirectional DATA2                                        | 0           |
| hsusb1_tll_data3  | I/O                | Bidirectional DATA3                                        | 0           |
| hsusb1_tll_data4  | I/O                | Bidirectional DATA4                                        | 0           |
| hsusb1_tll_data5  | I/O                | Bidirectional DATA5                                        | 0           |
| hsusb1_tll_data6  | I/O                | Bidirectional DATA6                                        | 0           |
| hsusb1_tll_data7  | I/O                | Bidirectional DATA7                                        | 0           |
| <b>HSUSB2</b>     |                    |                                                            |             |
| hsusb2_clk        | O                  | 60-MHz clock output to ULPI transceiver <sup>(2)</sup>     | 0           |
| hsusb2_dir        | I                  | Data direction control from ULPI transceiver               | n/a         |
| hsusb2_stp        | O                  | Stop signal to ULPI transceiver                            | 1           |
| hsusb2_nxt        | O                  | Next signal from ULPI transceiver                          | n/a         |
| hsusb2_data0      | I/O                | Bidirectional DATA0                                        | n/a         |
| hsusb2_data1      | I/O                | Bidirectional DATA1                                        | n/a         |
| hsusb2_data2      | I/O                | Bidirectional DATA2                                        | n/a         |
| hsusb2_data3      | I/O                | Bidirectional DATA3                                        | n/a         |
| hsusb2_data4      | I/O                | Bidirectional DATA4                                        | n/a         |
| hsusb2_data5      | I/O                | Bidirectional DATA5                                        | n/a         |
| hsusb2_data6      | I/O                | Bidirectional DATA6                                        | n/a         |
| hsusb2_data7      | I/O                | Bidirectional DATA7                                        | n/a         |
| <b>HSUSB2 TLL</b> |                    |                                                            |             |
| hsusb2_tll_clk    | O                  | 60-MHz clock output to ULPI link controller <sup>(2)</sup> | 0           |
| hsusb2_tll_dir    | O                  | Data direction control from ULPI link controller           | 0           |
| hsusb2_tll_stp    | I                  | Stop signal to ULPI link controller                        | n/a         |

<sup>(1)</sup> I = Input; O = Output

<sup>(2)</sup> This output signal is also used as retiming input (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to 1).

**Table 22-25. I/O Description (continued)**

| Signal Name       | I/O <sup>(1)</sup> | Description                                                | Reset Value |
|-------------------|--------------------|------------------------------------------------------------|-------------|
| hsusb2_tll_nxt    | O                  | Next signal from ULPI link controller                      | 0           |
| hsusb2_tll_data0  | I/O                | Bidirectional DATA0                                        | 0           |
| hsusb2_tll_data1  | I/O                | Bidirectional DATA1                                        | 0           |
| hsusb2_tll_data2  | I/O                | Bidirectional DATA2                                        | 0           |
| hsusb2_tll_data3  | I/O                | Bidirectional DATA3                                        | 0           |
| hsusb2_tll_data4  | I/O                | Bidirectional DATA4                                        | 0           |
| hsusb2_tll_data5  | I/O                | Bidirectional DATA5                                        | 0           |
| hsusb2_tll_data6  | I/O                | Bidirectional DATA6                                        | 0           |
| hsusb2_tll_data7  | I/O                | Bidirectional DATA7                                        | 0           |
| <b>HSUSB3 TLL</b> |                    |                                                            |             |
| hsusb3_tll_clk    | O                  | 60-MHz clock output to ULPI link controller <sup>(2)</sup> | 0           |
| hsusb3_tll_dir    | O                  | Data direction control from ULPI link controller           | 0           |
| hsusb3_tll_stp    | I                  | Stop signal to ULPI link controller                        | n/a         |
| hsusb3_tll_nxt    | O                  | Next signal from ULPI link controller                      | 0           |
| hsusb3_tll_data0  | I/O                | Bidirectional DATA0                                        | 0           |
| hsusb3_tll_data1  | I/O                | Bidirectional DATA1                                        | 0           |
| hsusb3_tll_data2  | I/O                | Bidirectional DATA2                                        | 0           |
| hsusb3_tll_data3  | I/O                | Bidirectional DATA3                                        | 0           |
| hsusb3_tll_data4  | I/O                | Bidirectional DATA4                                        | 0           |
| hsusb3_tll_data5  | I/O                | Bidirectional DATA5                                        | 0           |
| hsusb3_tll_data6  | I/O                | Bidirectional DATA6                                        | 0           |
| hsusb3_tll_data7  | I/O                | Bidirectional DATA7                                        | 0           |

ULPI (PHY) Interfaces and ULPI TLL Interfaces can not be used together: Either the ULPI (PHY) Interfaces or the ULPI TLL Interfaces are selected.

#### 22.2.2.4 Serial Interfaces

The high-speed USB host subsystem supports the following configurations with the serial interfaces:

- External USB transceiver
  - Serial 6-pin PHY (transceiver) interfaces: 6-pin mode (TX: DAT/SE0 or TX: DP/DM unidirectional mode), 4-pin mode (DP/DM bidirectional mode), and 3-pin mode (DAT/SE0 bidirectional mode)
- TLL
  - Serial 6-pin TLL interfaces: 6-pin mode (DAT/SE0 and DP/DM unidirectional modes), 4-pin mode (DP/DM bidirectional mode), 3-pin mode (DAT/SE0 bidirectional mode), and 2-pin mode (DAT/SE0 and DP/DM bidirectional modes)

Figure 22-17 shows a typical application using the high-speed USB host subsystem with the serial interfaces.

**Figure 22-17. High-Speed USB Host Subsystem Typical Application System**



usb-015

The high-speed USB host controller is coupled with the USBTLL module to compose the serial interface modes. The USBTLL module translates the parallel, synchronous UTMI+ (Level 3) protocol to a serial, asynchronous one. The benefit of the conversion is a simplified interface to the transceiver.

**CAUTION**

Only full- and low-speed data transactions are possible in serial mode. Transceiver interface is serial (its frequency is that of the actual USB line) and combinatorial (no clock is passed).

**CAUTION**

It is possible to change the polarity of the TXEN signal for each USB port using the following bits:

- CONTROL.[CONTROL\\_WKUP\\_CTRL\[2\]](#)  
M\_FSUSB3\_TXEN\_N\_OUT\_POLARITY\_CTRL
- CONTROL.[CONTROL\\_WKUP\\_CTRL\[1\]](#)MM\_FSUSB3\_TXEN\_N\_OUT\_POLARITY\_CTRL
- CONTROL.[CONTROL\\_WKUP\\_CTRL\[0\]](#)  
M\_FSUSB3\_TXEN\_N\_OUT\_POLARITY\_CTRL

Whether in TLL or transceiver configuration, the serial interface follows the same principles. It is limited to full/low speed, and that high speed requires a parallel interface.

**22.2.2.4.1 Encoding in Serial Mode****22.2.2.4.1.1 Unidirectional**

When a USB transceiver is connected to the device and used in 6-pin unidirectional DAT/SE0 encoding mode, the encoding described in [Table 22-26](#) is used.

**Table 22-26. Signaling Between High-Speed USB Host Subsystem and 6-Pin Unidirectional USB Transceiver (DAT/SE0 Signaling)**

| Logical Signal Name | Device Pin Direction | Transceiver Pin Direction | Description                                                                                                                                                                                                                                                        |      |     |     |          |          |
|---------------------|----------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|-----|----------|----------|
| TXEN                | Output               | Input                     | When low, the USB transceiver drives D+ and D-.                                                                                                                                                                                                                    |      |     |     |          |          |
| DAT and SE0         | Output               | Input                     | Controls the values output by the USB transceiver on D+ and D- when TXEN is low/high; ignored when TXEN is high/low (depending on the TXEN signal polarity; see CONTROL. <a href="#">CONTROL_WKUP_CTRL[2, 1 and/or 0]</a> MM_FSUSBi_TXEN_N_OUT_POLARITY_CTRL bit). | TXEN | DAT | SE0 | D+       | D-       |
|                     |                      |                           |                                                                                                                                                                                                                                                                    | 0    | 0   | 0   | 0        | 1        |
|                     |                      |                           |                                                                                                                                                                                                                                                                    | 0    | 1   | 0   | 1        | 0        |
|                     |                      |                           |                                                                                                                                                                                                                                                                    | 0    | X   | 1   | 0        | 0        |
|                     |                      |                           |                                                                                                                                                                                                                                                                    | 1    | X   | X   | Undriven | Undriven |
| RCV                 | Input                | Output                    | Output from transceiver differential receiver                                                                                                                                                                                                                      |      |     |     |          |          |
|                     |                      |                           | D+                                                                                                                                                                                                                                                                 |      | D-  |     | RCV      |          |
|                     |                      |                           | 0                                                                                                                                                                                                                                                                  |      | 0   |     | X        |          |
|                     |                      |                           | 0                                                                                                                                                                                                                                                                  |      | 1   |     | 0        |          |
|                     |                      |                           | 1                                                                                                                                                                                                                                                                  |      | 0   |     | 1        |          |
|                     |                      |                           | 1                                                                                                                                                                                                                                                                  |      | 1   |     | X        |          |
| DP                  | Input                | Output                    | Output from transceiver single-ended D+ signal receiver                                                                                                                                                                                                            |      |     |     |          |          |
|                     |                      |                           | D+                                                                                                                                                                                                                                                                 |      |     | DP  |          |          |
|                     |                      |                           | 0                                                                                                                                                                                                                                                                  |      |     | 0   |          |          |
|                     |                      |                           | 1                                                                                                                                                                                                                                                                  |      |     | 1   |          |          |
| DM                  | Input                | Output                    | Output from transceiver single-ended D- signal receiver                                                                                                                                                                                                            |      |     |     |          |          |
|                     |                      |                           | D-                                                                                                                                                                                                                                                                 |      |     | DM  |          |          |
|                     |                      |                           | 0                                                                                                                                                                                                                                                                  |      |     | 0   |          |          |
|                     |                      |                           | 1                                                                                                                                                                                                                                                                  |      |     | 1   |          |          |

When a USB transceiver is connected to the device and used in 6-pin unidirectional DP/DM encoding mode, the encoding described in [Table 22-27](#) is used.

**Table 22-27. Signaling Between High-Speed USB Host Subsystem and 6-Pin Unidirectional USB Transceiver (DP/DM Signaling)**

| Logical Signal Name | Device Pin Direction | Transceiver Pin Direction | Description                                                                                                                                                                                                                                                                                   |     |     |          |          |  |  |  |
|---------------------|----------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|----------|----------|--|--|--|
| TXEN                | Output               | Input                     | When low, the USB transceiver drives D+ and D-.                                                                                                                                                                                                                                               |     |     |          |          |  |  |  |
| DAT and SE0         | Output               | Input                     | Controls the values output by the USB transceiver on D+ and D- when TXEN is low/high; ignored when TXEN is high/low (depending on the TXEN signal polarity; see the CONTROL.<br><a href="#">CONTROL_WKUP_CTRL</a> [2, 1 and/or 0]<br><a href="#">MM_FFSUBI_TXEN_N_OUT_POLARITY_CTRL</a> bit). |     |     |          |          |  |  |  |
|                     |                      |                           | TXEN                                                                                                                                                                                                                                                                                          | DAT | SE0 | D+       | D-       |  |  |  |
|                     |                      |                           | 0                                                                                                                                                                                                                                                                                             | 0   | 1   | 0        | 1        |  |  |  |
|                     |                      |                           | 0                                                                                                                                                                                                                                                                                             | 1   | 0   | 1        | 0        |  |  |  |
|                     |                      |                           | 0                                                                                                                                                                                                                                                                                             | 0   | 0   | 0        | 0        |  |  |  |
|                     |                      |                           | 1                                                                                                                                                                                                                                                                                             | X   | X   | Undriven | Undriven |  |  |  |
| RCV                 | Input                | Output                    | Output from transceiver differential receiver                                                                                                                                                                                                                                                 |     |     |          |          |  |  |  |
|                     |                      |                           | D+                                                                                                                                                                                                                                                                                            | D-  | RCV |          |          |  |  |  |
|                     |                      |                           | 0                                                                                                                                                                                                                                                                                             | 0   | X   |          |          |  |  |  |
|                     |                      |                           | 0                                                                                                                                                                                                                                                                                             | 1   | 0   |          |          |  |  |  |
|                     |                      |                           | 1                                                                                                                                                                                                                                                                                             | 0   | 1   |          |          |  |  |  |
|                     |                      |                           | 1                                                                                                                                                                                                                                                                                             | 1   | X   |          |          |  |  |  |
| DP                  | Input                | Output                    | Output from transceiver single-ended D+ signal receiver                                                                                                                                                                                                                                       |     |     |          |          |  |  |  |
|                     |                      |                           | D+                                                                                                                                                                                                                                                                                            | DP  |     |          |          |  |  |  |
|                     |                      |                           | 0                                                                                                                                                                                                                                                                                             | 0   |     |          |          |  |  |  |
|                     |                      |                           | 1                                                                                                                                                                                                                                                                                             | 1   |     |          |          |  |  |  |
| DM                  | Input                | Output                    | Output from transceiver single-ended D- signal receiver                                                                                                                                                                                                                                       |     |     |          |          |  |  |  |
|                     |                      |                           | D-                                                                                                                                                                                                                                                                                            | DM  |     |          |          |  |  |  |
|                     |                      |                           | 0                                                                                                                                                                                                                                                                                             | 0   |     |          |          |  |  |  |
|                     |                      |                           | 1                                                                                                                                                                                                                                                                                             | 1   |     |          |          |  |  |  |

#### **22.2.2.4.1.2 Bidirectional**

When a USB or USB OTG transceiver is connected to the device and is used in 3-pin bidirectional DAT/SE0 encoding mode, the encoding described in [Table 22-28](#) is used.

**Table 22-28. Signaling Between High-Speed USB Host Subsystem and 3-Pin Bidirectional USB Transceiver Using DAT/SE0 Signaling**

| Logical Signal Name | Device Pin Direction | Transceiver Pin Direction | Description                                     |  |
|---------------------|----------------------|---------------------------|-------------------------------------------------|--|
| TXEN                | Output               | Input                     | When low, the USB transceiver drives D+ and D-. |  |

**Table 22-28. Signaling Between High-Speed USB Host Subsystem and 3-Pin Bidirectional USB Transceiver Using DAT/SE0 Signaling (continued)**

| Logical Signal Name | Device Pin Direction | Transceiver Pin Direction | Description                                                                                                                                                                                                                                                                     |     |     |           |     |  |
|---------------------|----------------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-----------|-----|--|
| DAT and SE0         | Output               | Input                     | When TXEN is low/high (depending on the TXEN signal polarity; see the CONTROL. <a href="#">CONTROL_WKUP_CTRL</a> [2, 1 and/or 0] MM_FSUSBi_TXEN_N_OUT_POLARITY_CTR bit), the device drives DAT and SE0 and the transceiver drives D+ and D- based on the values of DAT and SE0. |     |     |           |     |  |
|                     |                      |                           | TXEN                                                                                                                                                                                                                                                                            | DAT | SE0 | D+        | D-  |  |
|                     |                      |                           | 0                                                                                                                                                                                                                                                                               | 0   | 0   | 0         | 1   |  |
|                     | Output               | Input                     | 1                                                                                                                                                                                                                                                                               | 0   | 1   | 0         | 0   |  |
|                     |                      |                           | X                                                                                                                                                                                                                                                                               | 1   | 0   | 0         | 0   |  |
|                     |                      |                           | TXEN                                                                                                                                                                                                                                                                            | D+  | D-  | DAT       | SE0 |  |
|                     |                      |                           |                                                                                                                                                                                                                                                                                 | 1   | 0   | 0         | 1   |  |
|                     |                      |                           |                                                                                                                                                                                                                                                                                 | 0   | 1   | 0         | 0   |  |
|                     |                      |                           |                                                                                                                                                                                                                                                                                 | 1   | 0   | 1         | 0   |  |
|                     |                      |                           |                                                                                                                                                                                                                                                                                 | 1   | 1   | Undefined | 0   |  |

**NOTE:** The device does not support 3-wire bidirectional signaling using DP/DM signals.

When a USB or USB OTG transceiver is connected to the device and is used in 4-pin bidirectional DP/DM encoding mode, the encoding described in [Table 22-29](#) is used.

**Table 22-29. Signaling Between High-Speed USB Host Subsystem and 4-Pin Bidirectional USB Transceiver Using DP/DM Signaling**

| Logical Signal Name | Device Pin Direction | Transceiver Pin Direction | Description                                     |    |     |
|---------------------|----------------------|---------------------------|-------------------------------------------------|----|-----|
| TXEN                | Output               | Input                     | When low, the USB transceiver drives D+ and D-. |    |     |
| DM                  | Output               | Input                     | Value driven to or received from D-             |    |     |
|                     |                      |                           | TXEN                                            | DM | D-  |
|                     |                      |                           | 0                                               | 0  | 0   |
|                     |                      |                           | 0                                               | 1  | 1   |
|                     | Input                | Output                    | TXEN                                            | D- | DM  |
|                     |                      |                           | 1                                               | 0  | 0   |
|                     |                      |                           | 1                                               | 1  | 1   |
|                     |                      |                           | Value driven to or received from D+             |    |     |
|                     |                      |                           | TXEN                                            | DP | D+  |
| DP                  | Output               | Input                     | 0                                               | 0  | 0   |
|                     |                      |                           | 0                                               | 1  | 1   |
|                     | Input                | Output                    | TXEN                                            | D+ | DP  |
|                     |                      |                           | 1                                               | 0  | 0   |
|                     |                      |                           | 1                                               | 1  | 1   |
| RCV                 | Input                | Output                    | Output from transceiver differential receiver   |    |     |
|                     |                      |                           | D+                                              | D- | RCV |
|                     |                      |                           | 0                                               | 0  | X   |
|                     |                      |                           | 0                                               | 1  | 0   |
|                     |                      |                           | 1                                               | 0  | 1   |
|                     |                      |                           | 1                                               | 1  | X   |

**NOTE:** The device does not support 4-pin bidirectional signaling using DAT/SEO signals.

#### 22.2.2.4.2 Sideband Signals for Serial Modes

Serial interfaces only carry the USB data information. Sideband control and status (respectively, to/from the transceiver/TLL or to the bus lines themselves) require additional signals, which are usually implemented in a case-by-case, ad hoc way.

- Sideband control examples: FS/LS (slew rate control), transceiver suspend, connect (D+/D– pullup), pulldown enable, VBUS drive, etc.
- Sideband status example: VBUS level (VBUS valid, session valid, session end), etc.
- Sideband signal implementations: Dedicated lines (one per sideband information bit), serial bus + interrupt line with register-mapped control/status (I<sup>2</sup>C, UART, etc.)

Figure 22-18 and Figure 22-19 show system integration for sideband signals for two logically identical USB connections: One in transceiver configuration, and one in TLL configuration. Although the sideband (purple) arrows are all oriented from controller to transceiver in the two figures, the sideband information flow is bidirectional (that is, it flows from controller to transceiver [control] but also from transceiver to controller [status]).

Figure 22-18 shows the transceiver configuration, where each side connects the sideband signals to its own transceiver. On the device (containing the USBTLL module), the sideband is decoded/re-encoded. The sideband signals available at the device boundary (and the USBTLL module) are decoded from the standard UTMI+ interface.

- Sideband output signals from the USBTLL module (speed, suspend, puen, etc.)
- The software-driven VBUS reporting procedure is described in [Section 22.2.4.2.4.1.1, VBUS Management in Serial Transceiver Configurations](#).

**Figure 22-18. Serial Interface Sideband Integration - Transceiver Configuration**



usb-016

Figure 22-19 shows the TLL configuration, where both transceivers are actually emulated inside the USBTLL module.

- The transceiver of the local controller (left) is working with the sideband information to/from the UTMI+ port. This is internal to the USBTLL module.
- The transceiver of the remote controller (right) must communicate with its controller, located on another IC. This is done in two ways:
  - Sideband input signals at the TLL module boundary (tllpuen, tlldrvvbus, tlvbustvalid, etc.)

- The software-driven VBUS control procedure is described in [Section 22.2.4.2.4.2.2, VBUS Emulation for TLL Configurations](#)

**Figure 22-19. Serial Interface Sideband Integration - TLL Configuration**



#### 22.2.2.4.3 Transceiver Interface Configurations

An external USB transceiver is required for each USB port used in the system. It converts between appropriate signaling for the high-speed USB host subsystem and appropriate signaling for the USB wire.

The serial interface mode of the high-speed USB host subsystem includes support for several types of USB transceivers. It provides signaling to up to three external USB transceivers.

Several types of external transceiver signaling are supported. Signaling between the high-speed USB subsystem in the serial-interface mode and the external USB transceiver for monitoring and controlling the differential USB signal can be done through a 6-, 4-, or 3-wire signaling interface, with two or more control signals provided either by additional signals or through an I<sup>2</sup>C link.

The following subsections describe the transceiver interface modes supported by the high-speed USB host subsystem in the serial interface mode. In each case, the subsystem is connected to external transceivers, on the other side of which are the actual USB lines (D+/D-).

##### 22.2.2.4.3.1 Unidirectional Transceiver Interface Modes: 6-Pin

The 6-pin modes are the "natural" transceiver interface modes for the full-speed transceivers in the sense that they mirror the internal makeup of the transceivers.

Two encodings exist for TX: DAT/SE0 or DP/DM.

When a USB is connected to the device and used in 6-pin unidirectional DAT/SE0 signaling mode, the signaling described in [Table 22-26](#) is used.

[Figure 22-20](#) shows a USB port using DAT/SE0 encoding.

**Figure 22-20. 6-Pin Unidirectional Using DAT/SE0 Signaling**

x is the USB port number (1, 2 or 3)

usb-018

When a USB is connected to the device and used in 6-pin unidirectional DP/DM signaling mode, the signaling described in [Table 22-27](#) is used.

[Figure 22-21](#) shows a USB port using DP/DM encoding.

**Figure 22-21. 6-Pin Unidirectional Using DP/DM Signaling**

x is the USB port number (1, 2 or 3)

usb-019

#### 22.2.2.4.3.2 Bidirectional Transceiver Interface Modes: 3-Pin, 4-Pin

The bidirectional transceiver interface modes are pin-count optimizations of the unidirectional modes. They take advantage of the fact that a USB port is either sending or receiving at any given time, but never both. The TX and RX paths of the unidirectional mode can be multiplexed on bidirectional lines. To prevent glitches at TX/RX turnaround, the same encoding is used for both directions (DAT/SE0 or DP/DM).

The signaling listed in [Table 22-28](#) is used when a USB transceiver is connected to the device and is used in 3-pin bidirectional DAT/SE0 signaling mode.

**NOTE:** The device does not support 3-wire bidirectional signaling using DP/DM signals.

Figure 22-22 shows a USB port using DAT/SE0 encoding.

**Figure 22-22. 3-Pin Bidirectional Using DAT/SE0 Signaling**



x is the USB port number (1, 2 or 3)

usb-020

The signaling listed in [Table 22-29](#) is used when a USB transceiver is connected to the device and is used in 4-pin bidirectional DP/DM signaling mode.

**NOTE:** The device does not support 4-pin bidirectional signaling using DAT/SE0 signals.

Figure 22-23 shows a USB port using DP/DM encoding.

**Figure 22-23. 4-Pin Bidirectional Using DP/DM Signaling**



x is the USB port number (1, 2 or 3)

usb-021

#### 22.2.2.4.4 TLL Configurations

The high-speed USB host subsystem supports unidirectional and bidirectional TLL logic interfaces on its ports. The TLL modes enable glueless interconnect to the USB device port of another device without needing a costly transceiver.

Serial interface modes are full- or low-speed only. Transceiver interface is serial (its frequency is that of the actual USB line) and combinatorial (no clock is passed).

##### 22.2.2.4.4.1 Unidirectional TLL Modes

The 6-pin TLL configurations are mirror images of the 6-pin transceiver configurations presented above. The same signals are mapped on the same physical pins, but in the opposite directions.

Two possible modes exist, depending on the TX data encoding used by the external device.

Figure 22-24 shows an external device using DAT/SE0 encoding.

Figure 22-24. 6-Pin Unidirectional TLL Using DAT/SE0 Signaling



usb-022

Figure 22-25 shows an external device using DP/DM encoding.

**Figure 22-25. 6-Pin Unidirectional TLL Using DP/DM Signaling**

usb-023

#### 22.2.2.4.4.2 Bidirectional TLL Modes

The 3-pin/4-pin TLL configurations are mirror images of the 3-pin/4-pin transceiver configurations presented above. The same signals are mapped on the same physical pins, but in the opposite directions (bidirectional lines remain bidirectional).

Two possible modes exist, depending on the TX data encoding used by the external device.

Figure 22-26 shows an external device using DAT/SE0 encoding.

**Figure 22-26. 3-Pin Bidirectional TLL Using DAT/SE0 Signaling**

usb-024

Figure 22-27 shows an external device using DP/DM encoding.

**Figure 22-27. 4-Pin Bidirectional TLL Using DP/DM Signaling**



usb-025

The 2-pin TLL configurations have unique specifications:

- They require pullups/pulldowns to operate, because the bidirectional lines are not driven at all times like the other serial transceiver interfaces described above. The connection of pull resistors depends on the speed of the controller.
- The module supports explicit 2-pin TLL modes, with either DAT/SE0 or DP/DM encoding.
- Non-TLL modes (that is, transceiver configuration mode) can be used to implement the 2-pin functionality, using a specific connectivity.

Figure 22-28 shows USB port using DP/DM encoding.

**Figure 22-28. 2-Pin Bidirectional TLL Using DP/DM Encoding, With 4-Pin Bidirectional USB Device**



2-pin bidirectional TLL using DP/DM encoding,  
against full-speed USB device

2-pin bidirectional TLL using DP/DM encoding,  
against low-speed USB device

usb-026

Table 22-30 shows the pullup/pulldown configuration for DP/DM encoding.

**Table 22-30. Pullup/Pulldown Configuration for DP/DM Encoding**

| Nonconnected Device<br>(Any Speed) | Connected<br>Low-Speed Device | Connected<br>Full-Speed Device |
|------------------------------------|-------------------------------|--------------------------------|
| DP                                 | Pulldown                      | Pulldown                       |
| DM                                 | Pulldown                      | Pullup                         |

Figure 22-29 shows a USB port using DAT/SE0 encoding.

**Figure 22-29. 2-Pin Bidirectional TLL Using DAT/SE0 Encoding, With 3-Pin Bidirectional USB Device**

Table 22-31 shows pullup/pulldown configuration for DAT/SE0 encoding.

**Table 22-31. Pullup/Pulldown Configuration for DAT/SE0 Encoding**

| Nonconnected Device<br>(Any Speed) | Connected<br>Low-Speed Device | Connected<br>Full-Speed Device |
|------------------------------------|-------------------------------|--------------------------------|
| DAT                                | Pulldown                      | Pullup                         |
| SEO                                | Pullup                        | Pulldown                       |

#### 22.2.2.4.5 High-Speed USB Host Subsystem Interface Description

Table 22-32 describes the I/O of the high-speed USB host subsystem serial interfaces.

**Table 22-32. I/O Description**

| Signal Name                                         | I/O <sup>(1)</sup> | Description                                                                                                                                                                                   | Value at Reset |
|-----------------------------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| <b>Multiple-Mode FS/LS Serial Interface: Port 1</b> |                    |                                                                                                                                                                                               |                |
| mm1_txse0                                           | I/O                | SE0 function in 3-pin bidirectional DAT/SE0 mode                                                                                                                                              | 0              |
|                                                     | I/O                | DM function in 4-pin bidirectional DP/DM mode                                                                                                                                                 |                |
|                                                     | O                  | SE0 output in 6-pin unidirectional DAT/SE0 mode                                                                                                                                               |                |
|                                                     | O                  | DM output in 6-pin unidirectional DP/DM mode                                                                                                                                                  |                |
|                                                     | I/O                | SE0-TLL in 2-/3-pin bidirectional DAT/SE0 TLL mode                                                                                                                                            |                |
|                                                     | I/O                | DM-TLL in 2-/4-pin bidirectional DP/DM TLL mode                                                                                                                                               |                |
|                                                     | I                  | SE0-TLL input in 6-pin unidirectional DAT/SE0 TLL mode                                                                                                                                        |                |
|                                                     | I                  | DM-TLL input in 6-pin unidirectional DP/DM TLL mode                                                                                                                                           |                |
| mm1_txdat                                           | I/O                | DAT function in 3-pin bidirectional DAT/SE0 mode                                                                                                                                              | n/a            |
|                                                     | I/O                | DP function in 4-pin bidirectional DP/DM mode                                                                                                                                                 |                |
|                                                     | O                  | DAT output in 6-pin unidirectional DAT/SE0 mode                                                                                                                                               |                |
|                                                     | O                  | DP output in 6-pin unidirectional DAT/SE0 mode                                                                                                                                                |                |
|                                                     | I/O                | DAT-TLL in 2-/3-pin bidirectional DAT/SE0 TLL mode                                                                                                                                            |                |
|                                                     | I/O                | DP-TLL in 2-/4-pin bidirectional DP/DM TLL mode                                                                                                                                               |                |
|                                                     | I                  | DAT-TLL input in 6-pin unidirectional DAT/SE0 TLL mode                                                                                                                                        |                |
|                                                     | I                  | DP-TLL input in 6-pin unidirectional DP/DM TLL mode                                                                                                                                           |                |
| mm1_txen_n                                          | O                  | Transmit enable in the 3-pin bidirectional DAT/SE0 or 4-pin bidirectional DP/DM or 6-pin unidirectional modes                                                                                 | 1              |
|                                                     | I                  | Transmit enable in the 3-pin bidirectional DAT/SE0 TLL or 4-pin bidirectional DP/DM TLL or 6-pin unidirectional TLL modes (not used in the 2-pin bidirectional TLL modes)                     |                |
| mm1_rxrcv                                           | I                  | Differential receiver signal input in the 4-pin bidirectional DP/DM or 6-pin unidirectional modes (not used in the 3-pin bidirectional DAT/SE0 mode)                                          | n/a            |
|                                                     | O                  | Differential receiver signal output in the 4-pin bidirectional DP/DM TLL or 6-pin unidirectional TLL modes (not used in the 3-pin bidirectional DAT/SE0 TLL or 2-pin bidirectional TLL modes) |                |
| mm1_rxdp                                            | I                  | Single-ended DP receiver signal input in 6-pin unidirectional modes (not used in the 3-pin bidirectional DAT/SE0 or 4-pin bidirectional DP/DM modes)                                          | n/a            |
|                                                     | O                  | Single-ended DP receiver signal output in 6-pin unidirectional TLL modes (not used in the 3-pin bidirectional DAT/SE0 TLL or 4-pin bidirectional DP/DM TLL or 2-pin bidirectional TLL modes)  |                |
| mm1_rxdm                                            | I                  | Single-ended DM receiver signal input in 6-pin unidirectional TLL modes (not used in the 3-pin bidirectional DAT/SE0 or 4-pin bidirectional DP/DM or 2-pin bidirectional TLL modes)           | n/a            |
|                                                     | O                  | Single-ended DM receiver signal output in 6-pin unidirectional TLL modes (not used in the 3-pin bidirectional DAT/SE0 TLL or 4-pin bidirectional DP/DM TLL or 2-pin bidirectional TLL modes)  |                |
| <b>Multiple-mode FS/LS serial interface: Port 2</b> |                    |                                                                                                                                                                                               |                |
| mm2_txse0                                           | I/O                | SE0 function in 3-pin bidirectional DAT/SE0 mode                                                                                                                                              | 0              |
|                                                     | I/O                | DM function in 4-pin bidirectional DP/DM mode                                                                                                                                                 |                |
|                                                     | O                  | SE0 output in 6-pin unidirectional DAT/SE0 mode                                                                                                                                               |                |
|                                                     | O                  | DM output in 6-pin unidirectional DP/DM mode                                                                                                                                                  |                |
|                                                     | I/O                | SE0-TLL in 2-/3-pin bidirectional DAT/SE0 TLL mode                                                                                                                                            |                |
|                                                     | I/O                | DM-TLL in 2-/4-pin bidirectional DP/DM TLL mode                                                                                                                                               |                |
|                                                     | I                  | SE0-TLL input in 6-pin unidirectional DAT/SE0 TLL mode                                                                                                                                        |                |
|                                                     | I                  | DM-TLL input in 6-pin unidirectional DP/DM TLL mode                                                                                                                                           |                |
| mm2_txdat                                           | I/O                | DAT function in 3-pin bidirectional DAT/SE0 mode                                                                                                                                              | n/a            |
|                                                     | I/O                | DP function in 4-pin bidirectional DP/DM mode                                                                                                                                                 |                |
|                                                     | O                  | DAT output in 6-pin unidirectional DAT/SE0 mode                                                                                                                                               |                |
|                                                     | O                  | DP output in 6-pin unidirectional DAT/SE0 mode                                                                                                                                                |                |

<sup>(1)</sup> I = Input, O = Output

**Table 22-32. I/O Description (continued)**

| Signal Name                                         | I/O <sup>(1)</sup> | Description                                                                                                                                                                                   | Value at Reset |
|-----------------------------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| <b>Multiple-Mode FS/LS Serial Interface: Port 1</b> |                    |                                                                                                                                                                                               |                |
|                                                     | I/O                | DAT-TLL in 2-/3-pin bidirectional DAT/SE0 TLL mode                                                                                                                                            |                |
|                                                     | I/O                | DP-TLL in 2-/4-pin bidirectional DP/DM TLL mode                                                                                                                                               |                |
|                                                     | I                  | DAT-TLL input in 6-pin unidirectional DAT/SE0 TLL mode                                                                                                                                        |                |
|                                                     | I                  | DP-TLL input in 6-pin unidirectional DP/DM TLL mode                                                                                                                                           |                |
| mm2_txen_n                                          | O                  | Transmit enable in the 3-pin bidirectional DAT/SE0 or 4-pin bidirectional DP/DM or 6-pin unidirectional modes                                                                                 | 1              |
|                                                     | I                  | Transmit enable in the 3-pin bidirectional DAT/SE0 TLL or 4-pin bidirectional DP/DM TLL or 6-pin unidirectional TLL modes (not used in the 2-pin bidirectional TLL modes)                     |                |
| mm2_rxrcv                                           | I                  | Differential receiver signal input in the 4-pin bidirectional DP/DM or 6-pin unidirectional modes (not used in the 3-pin bidirectional DAT/SE0 mode)                                          | n/a            |
|                                                     | O                  | Differential receiver signal output in the 4-pin bidirectional DP/DM TLL or 6-pin unidirectional TLL modes (not used in the 3-pin bidirectional DAT/SE0 TLL or 2-pin bidirectional TLL modes) |                |
| mm2_rxdp                                            | I                  | Single-ended DP receiver signal input in 6-pin unidirectional modes (not used in the 3-pin bidirectional DAT/SE0 or 4-pin bidirectional DP/DM modes)                                          | n/a            |
|                                                     | O                  | Single-ended DP receiver signal output in 6-pin unidirectional TLL modes (not used in the 3-pin bidirectional DAT/SE0 TLL or 4-pin bidirectional DP/DM TLL or 2-pin bidirectional TLL modes)  |                |
| mm2_rxdm                                            | I                  | Single-ended DM receiver signal input in 6-pin unidirectional TLL modes (not used in the 3-pin bidirectional DAT/SE0 or 4-pin bidirectional DP/DM or 2-pin bidirectional TLL modes)           | n/a            |
|                                                     | O                  | Single-ended DM receiver signal output in 6-pin unidirectional TLL modes (not used in the 3-pin bidirectional DAT/SE0 TLL or 4-pin bidirectional DP/DM TLL or 2-pin bidirectional TLL modes)  |                |
| <b>Multiple-mode FS/LS serial interface: Port 3</b> |                    |                                                                                                                                                                                               |                |
| mm3_txse0                                           | I/O                | SE0 function in 3-pin bidirectional DAT/SE0 mode                                                                                                                                              | 0              |
|                                                     | I/O                | DM function in 4-pin bidirectional DP/DM mode                                                                                                                                                 |                |
|                                                     | O                  | SE0 output in 6-pin unidirectional DAT/SE0 mode                                                                                                                                               |                |
|                                                     | O                  | DM output in 6-pin unidirectional DP/DM mode                                                                                                                                                  |                |
|                                                     | I/O                | SE0-TLL in 2-/3-pin bidirectional DAT/SE0 TLL mode                                                                                                                                            |                |
|                                                     | I/O                | DM-TLL in 2-/4-pin bidirectional DP/DM TLL mode                                                                                                                                               |                |
|                                                     | I                  | SE0-TLL input in 6-pin unidirectional DAT/SE0 TLL mode                                                                                                                                        |                |
|                                                     | I                  | DM-TLL input in 6-pin unidirectional DP/DM TLL mode                                                                                                                                           |                |
| mm3_txdat                                           | I/O                | DAT function in 3-pin bidirectional DAT/SE0 mode                                                                                                                                              | n/a            |
|                                                     | I/O                | DP function in 4-pin bidirectional DP/DM mode                                                                                                                                                 |                |
|                                                     | O                  | DAT output in 6-pin unidirectional DAT/SE0 mode                                                                                                                                               |                |
|                                                     | O                  | DP output in 6-pin unidirectional DAT/SE0 mode                                                                                                                                                |                |
|                                                     | I/O                | DAT-TLL in 2-/3-pin bidirectional DAT/SE0 TLL mode                                                                                                                                            |                |
|                                                     | I/O                | DP-TLL in 2-/4-pin bidirectional DP/DM TLL mode                                                                                                                                               |                |
|                                                     | I                  | DAT-TLL input in 6-pin unidirectional DAT/SE0 TLL mode                                                                                                                                        |                |
|                                                     | I                  | DP-TLL input in 6-pin unidirectional DP/DM TLL mode                                                                                                                                           |                |
| mm3_txen_n                                          | O                  | Transmit enable in the 3-pin bidirectional DAT/SE0 or 4-pin bidirectional DP/DM or 6-pin unidirectional modes                                                                                 | 1              |
|                                                     | I                  | Transmit enable in the 3-pin bidirectional DAT/SE0 TLL or 4-pin bidirectional DP/DM TLL or 6-pin unidirectional TLL modes (not used in the 2-pin bidirectional TLL modes)                     |                |
| mm3_rxrcv                                           | I                  | Differential receiver signal input in the 4-pin bidirectional DP/DM or 6-pin unidirectional modes (not used in the 3-pin bidirectional DAT/SE0 mode)                                          | n/a            |
|                                                     | O                  | Differential receiver signal output in the 4-pin bidirectional DP/DM TLL or 6-pin unidirectional TLL modes (not used in the 3-pin bidirectional DAT/SE0 TLL or 2-pin bidirectional TLL modes) |                |
| mm3_rxdp                                            | I                  | Single-ended DP receiver signal input in 6-pin unidirectional modes (not used in                                                                                                              |                |

**Table 22-32. I/O Description (continued)**

| Signal Name                                         | I/O <sup>(1)</sup> | Description                                                                                                                                                                                  | Value at Reset |
|-----------------------------------------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| <b>Multiple-Mode FS/LS Serial Interface: Port 1</b> |                    |                                                                                                                                                                                              |                |
|                                                     |                    | the 3-pin bidirectional DAT/SE0 or 4-pin bidirectional DP/DM modes)                                                                                                                          | n/a            |
|                                                     | O                  | Single-ended DP receiver signal output in 6-pin unidirectional TLL modes (not used in the 3-pin bidirectional DAT/SE0 TLL or 4-pin bidirectional DP/DM TLL or 2-pin bidirectional TLL modes) |                |
| mm3_rxdm                                            | I                  | Single-ended DM receiver signal input in 6-pin unidirectional modes (not used in the 3-pin bidirectional DAT/SE0 or 4-pin bidirectional DP/DM modes)                                         | n/a            |
|                                                     | O                  | Single-ended DM receiver signal output in 6-pin unidirectional TLL modes (not used in the 3-pin bidirectional DAT/SE0 TLL or 4-pin bidirectional DP/DM TLL or 2-pin bidirectional TLL modes) |                |

### 22.2.3 High-Speed USB Host Subsystem Integration

This section describes the integration of the high-speed USB host subsystem.

The high-speed USB host controller is connected to the L3 interconnect master (initiator) and L4-Core interconnect slave (target) interfaces. The USBTLL module is connected to the L4-Core interconnect slave (target) interface. The L3 interconnect is used to generate data traffic within the device. The L4-Core interconnect is a configuration port for register setting.

Three interrupts, M\_IRQ\_[78:76], are connected to the system.

The system control module (SCM) offers complementary settings for USB port connectivity modes.

[Figure 22-30](#) highlights the high-speed USB host subsystem integration in the device.

Figure 22-30. High-Speed USB Subsystem Integration



usb-028

### 22.2.3.1 Reset, Clocking, and Power-Management Scheme

The high-speed USB host controller belongs to the USBHOST power domain. As part of the USBHOST power domain, it is sensible to the USBHOST\_RST reset signal issued by the PRCM and to USBHOST power domain-related transitions. For further details about USBHOST power domain implementation and USBHOST\_RST signal, see [Chapter 3, Power, Reset, and Clock Management](#).

The USBTLL module belongs to the CORE power domain. As part of the CORE power domain, it is sensible to the asynchronous USBTLL\_RST reset signal issued by the PRCM and to CORE power domain-related transitions. For further details about CORE power domain implementation and USBTLL\_RST signal, see [Chapter 3, Power, Reset, and Clock Management](#).

#### **22.2.3.1.1 High-Speed USB Host Subsystem Resets**

[Table 22-33](#) lists and describes all the high-speed USB host subsystem resets:

**Table 22-33. High-Speed USB Host Subsystem Reset Description**

| Type     | Name                                                            | Source                                                 | Polarity    | Description                                                                                                                                                                                                                                 |
|----------|-----------------------------------------------------------------|--------------------------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Software | USBHOST. <a href="#">UHH_SYSCONF1</a><br>G[1] SOFTRESET bit     | High-speed USB host controller internal software reset | Active high | Writing 1 to the SOFTRESET bit resets the module. The bit value of 1 remains until the reset is complete. When the software reset is complete, the SOFTRESET bit is automatically reset to 0 and has the same effect as the hardware reset. |
| Software | USBHOST. <a href="#">USBTLL_SYSSCO</a><br>NFIG[1] SOFTRESET bit | USBTLL module internal software reset                  | Active high | Writing 1 to the SOFTRESET bit resets the module. The bit value of 1 remains until the reset is complete. When the software reset is complete, the SOFTRESET bit is automatically reset to 0 and has the same effect as the hardware reset. |
| Hardware | USBHOST_RESET                                                   | PRCM USBHOST_RST signal                                | Active low  | The USBHOST_RST signal resets the module. The hardware reset signal has a global reset action on the high-speed USB host controller (see <a href="#">Chapter 3, Power, Reset, and Clock Management</a> ).                                   |
| Hardware | USBTLL_RESET                                                    | PRCM USBTLL_RST signal                                 | Active low  | The USBTLL_RST signal resets asynchronously the module. The hardware reset signal has a global reset action on the USBTLL module (see <a href="#">Chapter 3, Power, Reset, and Clock Management</a> ).                                      |

##### **22.2.3.1.1.1 Hardware Resets**

The high-speed USB host controller is attached to the USBHOST power domain: The USBHOST\_RST signal resets the module. The USBTLL module is attached to the CORE power domain: The USBTLL\_RST signal resets asynchronously the module (see [Chapter 3, Power, Reset, and Clock Management](#)). The hardware reset signal has a global reset action on the modules.

##### **22.2.3.1.1.2 Software Resets**

The high-speed USB host controller and the USBTLL module have their own software-reset functionality through the USBHOST.[UHH\\_SYSCONFIG](#)[1] SOFTRESET bit (0: Normal mode; 1: Module is reset) for the high-speed USB host controller, and through the USBHOST.[USBTLL\\_SYSCONFIG](#)[1] SOFTRESET bit (0: Normal mode; 1: Module is reset) for the USBTLL module.

Writing 1 to the SOFTRESET bit resets the module. The bit value of 1 remains until the reset is complete. When the software reset is complete, the SOFTRESET bit is automatically reset to 0 and has the same effect as the hardware reset.

##### **22.2.3.1.2 High-Speed USB Host Subsystem Clocks**

The high-speed USB host controller operates from four clock domains:

- USBHOST\_FCLK1 is a high-speed USB host controller functional clock. It is used to clock the OHCI and EHCI controller internal logic of the high-speed USB host controller. Its source is the PRCM USBHOST\_48M\_FCLK output clock. USBHOST\_FCLK1 is controlled by the PRCM.PRCM.CM\_FCLKEN\_USBHOST[0] EN\_USBHOST1 bit (0: Disabled; 1: Enabled).
- USBHOST\_FCLK2 is a high-speed USB host controller functional clock. It is used to clock EHCI controller internal logic of the high-speed USB host controller. Its source is the PRCM USBHOST\_120M\_FCLK output clock. USBHOST\_FCLK2 is controlled by the PRCM.PRCM.CM\_FCLKEN\_USBHOST[1] EN\_USBHOST2 bit (0: Disabled; 1: Enabled).
- USBHOST\_MICLK is the high-speed USB host controller L3 master interface clock. It is used to synchronize the high-speed USB host controller L3 port to L3 interconnect. All accesses from the interconnect are synchronous to USBHOST\_MICLK. Its source is the PRCM USBHOST\_L3\_ICLK output clock. USBHOST\_MICLK is controlled by the PRCM.CM\_ICLKEN\_USBHOST[0] EN\_USBHOST bit (0: Disabled; 1: Enabled) and the PRCM.CM\_AUTOIDLE\_USBHOST[0] AUTO\_USBHOST bit (enables/disables automatic control of the interface clock).
- USBHOST\_SICLK is a high-speed USB host controller L4 slave interface clock. It is used to synchronize the high-speed USB host controller L4 port to L4 interconnect. All accesses from the interconnect are synchronous to USBHOST\_SICLK. Its source is the PRCM USBHOST\_L4\_ICLK output clock.

The USBTLL module operates from two clock domains:

- USBTLL\_FCLK is the USBTLL module functional clock. It is used to clock the USBTLL module internal logic. Its source is the PRCM CORE\_120M\_FCLK output clock. UBTLL\_FCLK is controlled by the PRCM.CM\_FCLKEN3\_CORE[2] EN\_USBTLL bit (0: Disabled; 1: Enabled).
- USBTLL\_ICLK is the USBTLL module interface clock. It is used to synchronize USBTLL module L4 port to L4 interconnect. All accesses from the interconnect are synchronous to USBTLL\_ICLK. Its source is the PRCM CORE\_L4\_ICLK output clock. USBTLL\_ICLK is controlled by the PRCM.CM\_ICLKEN3\_CORE[2] EN\_USBTLL bit (0: Disabled; 1: Enabled) and the PRCM.CM\_AUTOIDLE3\_CORE[2] AUTO\_USBTLL bit (enables/disables automatic control of the interface clock).

Table 22-34 summarizes the high-speed USB host subsystem clocks.

**Table 22-34. High-Speed USB Host Subsystem Clocks**

| Attributes                | Frequency                           | Name          | Module                         | Mapping           | Comments              |
|---------------------------|-------------------------------------|---------------|--------------------------------|-------------------|-----------------------|
| Functional clock          | 48 MHz                              | USBHOST_FCLK1 | High-speed USB Host controller | USBHOST_48M_FCLK  | Source is PRCM module |
| Functional clock          | 120 MHz                             | USBHOST_FCLK2 | High-speed USB Host controller | USBHOST_120M_FCLK | Source is PRCM module |
| L3 master interface clock | Depending on PRCM register settings | USBHOST_MICLK | High-speed USB Host controller | USBHOST_L3_ICLK   | Source is PRCM module |
| L4 slave interface clock  | Depending on PRCM register settings | USBHOST_SICLK | High-speed USB Host controller | USBHOST_L4_ICLK   | Source is PRCM module |
| Functional clock          | 120 MHz                             | USBTLL_FCLK   | USBTLL                         | CORE_120M_FCLK    | Source is PRCM module |
| L4 interface clock        | Depending on PRCM register settings | USBTLL_ICLK   | USBTLL                         | CORE_L4_ICLK      | Source is PRCM module |

#### 22.2.3.1.2.1 L3 Master Interface Clock

The L3 master interface clock (USBHOST\_L3\_ICLK) is used only by the high-speed USB host controller (USBHOST\_MICLK) in the subsystem, and comes from the PRCM module. This clock is controlled by the PRCM register bits PRCM.CM\_ICLKEN\_USBHOST[0]:

0: Disabled  
1: Enabled

and PRCM.CM\_AUTOIDLE\_USBHOST[0] (enables/disables automatic control of the interface clock)-see Table 22-35.

**Table 22-35. High-Speed USB Controller L3 Master Interface Clock**

| PRCM.CM_AUTOIDLE_USBHOST[0] | PRCM.CM_ICLKEN_USBHOST[0] | Interface Clock              |
|-----------------------------|---------------------------|------------------------------|
| 0                           | 0                         | Disabled                     |
| 0                           | 1                         | Enabled                      |
| 1                           | 0                         | Disabled                     |
| 1                           | 1                         | Automatic enabling/disabling |

**CAUTION**

The L3 master interface clock should not be below 30 MHz, ULPI clock divided by 2 (this can occur during DPLL3 relocking).

#### 22.2.3.1.2.2 L4 Slave Interface Clock

The L4 slave interface clock (USBHOST\_L4\_ICLK) is used only by the high-speed USB host controller (USBHOST\_SCLK) in the subsystem, and comes from the PRCM module.

#### 22.2.3.1.2.3 L4 Interface Clock

The L4 interface clock (CORE\_L4\_ICLK) is used only by the USTLL module (USTLL\_ICLK) in the subsystem, and comes from the PRCM module.

This clock is controlled by the PRCM register bits PRCM.CM\_ICLKEN3\_CORE[2]:

- 0: Disabled
- 1: Enabled

and PRCM.CM\_AUTOIDLE3\_CORE[2] (enables/disables automatic control of the interface clock), see Table 22-36.

**Table 22-36. USTLL Module Interface Clock**

| PRCM.CM_AUTOIDLE3_CORE[2] | PRCM.CM_ICLKEN3_CORE[2] | Interface Clock              |
|---------------------------|-------------------------|------------------------------|
| 0                         | 0                       | Disabled                     |
| 0                         | 1                       | Enabled                      |
| 1                         | 0                       | Disabled                     |
| 1                         | 1                       | Automatic enabling/disabling |

#### 22.2.3.1.2.4 Functional Clocks

Two functional clocks are provided by the PRCM module to the high-speed USB host controller: USBHOST\_FLCK1 running at 48 MHz (USBHOST\_48M\_FCLK) and USBHOST\_FLCK2 running at 120 MHz (USBHOST\_120M\_FCLK).

The USBHOST\_FLCK1 functional clock is controlled by the PRCM register bit PRCM.CM\_FCLKEN\_USBHOST[0]:

- 0: Disabled
- 1: Enabled

The USBHOST\_FCLK2 functional clock is controlled by the PRCM register bit PRCM.CM\_FCLKEN\_USBHOST[1]:

- 0: Disabled
- 1: Enabled

The CORE\_120M\_FCLK functional clock is used only by the USBTLL module (USBTLL\_FCLK) in the subsystem, and comes from the PRCM module.

This clock is controlled by the PRCM register bit

PRCM.CM\_FCLKEN3\_CORE[2]:

- 0: Disabled
- 1: Enabled

### **22.2.3.1.3 Power-Management Scheme**

#### **22.2.3.1.3.1 High-Speed USB Host Controller Power-Management Scheme**

##### **22.2.3.1.3.1.1 Overview**

To save dynamic power consumption, an efficient idle scheme in the device is based on the following:

- An efficient local autoclock gating for each module
- The implementation of control sideband signals between the PRCM module and each module

This enhanced idle control allows clocks to be activated/deactivated safely without complex software intervention. In both cases, the high-speed USB host controller power management is applied only to the interface clock domain.

The high-speed USB host controller has both master (initiator) and slave (target) interfaces.

- As an initiator, the high-speed USB host controller implements the standby handshake protocol to inform the PRCM module when it enters standby mode and does not generate traffic on the interconnect.
- As a target, the high-speed USB host controller implements the IDLE handshake protocol to allow the PRCM module requiring it to enter idle mode.

Table 22-37 details the high-speed USB host controller module PRCM clock control bits.

**Table 22-37. High-Speed USB Host Controller PRCM Clock Control Bits**

| Module Clock  | Associated PRCM Clock Output | Enabled Bit                                  | Autoidle Bit                                    |
|---------------|------------------------------|----------------------------------------------|-------------------------------------------------|
| USBHOST_FCLK1 | USBHOST_48M_FCLK             | PRCM.CM_FCLKEN_USBHOST[0]<br>EN_USBHOST1 bit | N/A                                             |
| USBHOST_FCLK2 | USBHOST_120M_FCLK            | PRCM.CM_FCLKEN_USBHOST[1]<br>EN_USBHOST2 bit | N/A                                             |
| USBHOST_MCLK  | USBHOST_L3_ICLK              | PRCM.CM_ICLKEN_USBHOST[0]<br>EN_USBHOST bit  | PRCM.CM_AUTOIDLE_USBHOST[0]<br>AUTO_USBHOST bit |

**NOTE:**

- The PRCM USBHOST\_48M\_FCLK output is cut at PRCM level assuming all the modules that share it have been disabled in the corresponding register. Disabling the high-speed USB host controller is a necessary but not sufficient condition.
- The PRCM USBHOST\_120M\_FCLK output is cut at PRCM level assuming all the modules that share it have been disabled in the corresponding register. Disabling the high-speed USB host controller is a necessary but not sufficient condition.
- The PRCM USBHOST\_L3\_ICLK output is cut at PRCM level assuming all the modules that share it have been disabled in the corresponding register. Disabling the high-speed USB host controller is a necessary but not sufficient condition.
- The PRCM.CM\_AUTOIDLE\_USBHOST[0] AUTO\_USBHOST bit is used to link/unlink the high-speed USB host controller from USBHOST\_L3\_ICLK-related clock domain transitions.
- For further details about source clocks gating and domain transitions, see [Chapter 3, Power, Reset, and Clock Management](#).

#### 22.2.3.1.3.1.2 L3 Master Interface Power Management

The high-speed USB host controller can go to standby mode, in which case it stops generating transactions on the interconnect. The module standby leads the PRCM to disable the USB clocks to save power.

The high-speed USB host controller has a MSTANDBY/WAIT handshake mechanism with the PRCM module (see [Figure 22-30](#)).

The module is ready to enter standby mode (indicated by the MSTANDBY signal to the PRCM asserted) when there is no USB activity and the module is idle. It means the following:

- The module is committed not to start any new transaction on its master interface.
- The whole module is idle and, therefore, the power manager can start the procedure to turn off the interface clock, if needed. This procedure must be implemented using the slave power-management protocol.

The handshake mechanism lets the module go to standby mode based on the USBHOST.UHH\_SYSConfig[13:12] MIDLEMODE field.

**Table 22-38. High-Speed USB Host Controller MIDLEMODE Settings**

| MIDLEMODE Value | Selected Mode | Description                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0             | Force-standby | The high-speed USB host controller enters standby mode unconditionally (MSTANDBY is asserted unconditionally).                                                                                                                                                                                                                                                                                                     |
| 0x1             | No-standby    | The high-speed USB host controller never enters standby mode (MSTANDBY is never asserted).                                                                                                                                                                                                                                                                                                                         |
| 0x2             | Smart-standby | The high-speed USB host controller is ready to enter standby mode (MSTANDBY is asserted) when there is no more activity on the USB master interface of the interconnect. MSTANDBY is asserted when the module is idle and deasserted when the module is activated by either an external USB event or an appropriate register access. The module then waits for MWAIT deassertion before a DMA transfer is started. |

#### 22.2.3.1.3.1.3 L4 Slave Interface Power Management

At PRCM level, when all the conditions to shut off the high-speed USB host controller output clocks are met (see [Chapter 3, Power, Reset, and Clock Management](#) for details), the PRCM module automatically launches a hardware handshake protocol to ensure the high-speed USB host controller is ready to have its clocks switched off. Namely, the PRCM asserts an IDLE request to the high-speed USB host controller. Although this handshake is completely hardware and out of any software control, the way in which the high-speed USB host controller acknowledges the PRCM IDLE request is configurable through the USBHOST.UHH\_SYSConfig[4:3] SIDLEMODE bit field. [Table 22-39](#) details SIDLEMODE settings and the related acknowledgment modes.

**Table 22-39. High-Speed USB Host Controller SIDLEMODE Settings**

| SIDLEMODE Value | Selected Mode | Description                                                                                                                                                                                                                                                                                                                                                         |
|-----------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0             | Force-idle    | The high-speed USB host controller acknowledges unconditionally the IDLE request from the PRCM, regardless of its internal operations. Because such a mode does not prevent any loss of data when the clock is switched off, the mode must be used carefully.                                                                                                       |
| 0x1             | No-idle       | The high-speed USB host controller never acknowledges any IDLE request from the PRCM. This mode is safe from a module point of view as it ensures the clocks remain active; however, it is not efficient from a power-saving perspective because it does not allow the PRCM output clock to be shut off and thus the power domain to be set to a lower power state. |
| 0x2             | Smart-idle    | The high-speed USB host controller acknowledges the IDLE request basing its decision on its internal activity. Namely, the acknowledge signal is asserted only when all pending transactions, IRQs or DMA requests are treated. This is the best approach for an efficient system power management.                                                                 |

When configured in smart-idle mode, the high-speed USB host controller also offers an additional granularity on its interface clock gating. The USBHOST.UHH\_SYSConfig[9:8] CLOCKACTIVITY bit is used to control the interface clock internal gating while module is idle. [Table 22-40](#) details the CLOCKACTIVITY settings.

**Table 22-40. High-Speed USB Host Controller CLOCKACTIVITY Settings**

| CLOCKACTIVITY Value | Interface Clock Effect | Description                                                                                                                                                                                                 |
|---------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                   | OFF                    | Interface clock is considered for generating the acknowledgment. This setting also means the interface clock is shut down upon PRCM IDLE request.                                                           |
| 1                   | ON                     | Interface clock is not shut down upon PRCM IDLE request. The high-speed USB host controller can potentially acknowledge the IDLE request without checking the internal functionalities linked to its clock. |

### CAUTION

The PRCM does not have any hardware means to read CLOCKACTIVITY settings. Software ensures a consistent programming between the high-speed USB host controller CLOCKACTIVITY and PRCM interface clock control bit. Indeed, if the USBTLL module is disabled in the PRCM.CM\_ICLKEN\_USBHOST register while CLOCKACTIVITY is set to 1, nothing prevents the PRCM module from asserting its IDLE request, which is acknowledged regardless of the features associated to the USBTLL module interface clock. This may lead to unpredictable behaviors.

#### 22.2.3.1.3.2 USBTLL Module Device Power-Management Scheme

From a global system power-management perspective, when one or both of the USBTLL module clocks are no longer required, the USBTLL module can be deactivated at PRCM level in the corresponding registers.

[Table 22-41](#) details the USBTLL module PRCM clock control bits.

**Table 22-41. USBTLL Module PRCM Clock Control Bits**

| Module Clock | Associated PRCM Clock Output | Enabled Bit                              | Autoidle Bit                                  |
|--------------|------------------------------|------------------------------------------|-----------------------------------------------|
| USBTLL_FCLK  | CORE_120M_FCLK               | PRCM.CM_FCLKEN3_CORE[2]<br>EN_USBTLL bit | N/A                                           |
| USBTLL_ICLK  | CORE_L4_ICLK                 | PRCM.CM_ICLKEN3_CORE[2]<br>EN_USBTLL bit | PRCM.CM_AUTOIDLE3_CORE<br>[2] AUTO_USBTLL bit |

**NOTE:**

- The PRCM CORE\_120M\_CLK output is cut at PRCM level assuming all the modules that share it have been disabled in the corresponding register. Disabling the USBTLL module is a necessary but not sufficient condition.
- The PRCM CORE\_L4\_ICLK output is cut at PRCM level assuming all the modules that share it have been disabled in the corresponding register. Disabling the USBTLL module is a necessary but not sufficient condition.
- The PRCM.CM\_AUTOIDLE3\_CORE[2] AUTO\_USBPLL bit is used to link/unlink the USBTLL module from CORE\_L4\_ICLK-related clock domain transitions.
- For further details about source clocks gating and domain transitions, see [Chapter 3, Power, Reset, and Clock Management](#).

At PRCM level, when all the conditions to shut off the USBTLL\_FCLK or USBTLL\_ICLK output clocks are met (see [Chapter 3, Power, Reset, and Clock Management](#) for details), the PRCM module automatically launches a hardware handshake protocol to ensure the USBTLL module is ready to have its clocks switched off. Namely, the PRCM asserts an IDLE request to the USBTLL module. Although this handshake is completely hardware and out of any software control, the way in which the USBTLL module acknowledges the PRCM IDLE request is configurable through the USBHOST.USBTLL\_SYSConfig[4:3] SIDLEMODE bit field. [Table 22-42](#) details SIDLEMODE settings and the related acknowledgment modes.

**Table 22-42. USBTLL Module SIDLEMODE Settings**

| SIDLEMODE Value | Selected Mode | Description                                                                                                                                                                                                                                                                                                                                        |
|-----------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0             | Force-idle    | The USBTLL module acknowledges unconditionally the IDLE request from the PRCM, regardless of its internal operations. Because such a mode does not prevent any loss of data when the clock is switched off, the mode must be used carefully.                                                                                                       |
| 0x1             | No-idle       | The USBTLL module never acknowledges any IDLE request from the PRCM. This mode is safe from a module point of view as it ensures the clocks remain active; however, it is not efficient from a power-saving perspective because it does not allow the PRCM output clock to be shut off and thus the power domain to be set to a lower power state. |
| 0x2             | Smart-idle    | The USBTLL module acknowledges the IDLE request basing its decision on its internal activity. Namely, the acknowledge signal is asserted only when all pending transactions, IRQs or DMA requests are treated. This is the best approach for an efficient system power management.                                                                 |

When configured in smart-idle mode, the USBTLL module also offers an additional granularity on USBTLL\_ICLK gating. The USBHOST.USBTLL\_SYSConfig[9:8] CLOCKACTIVITY bit is used to control the USBTLL\_ICLK clock internal gating while the module is idle. [Table 22-43](#) details the CLOCKACTIVITY settings.

**Table 22-43. USBTLL Module CLOCKACTIVITY Settings**

| CLOCKACTIVIT Y Value | USBPLL_ICLK Effect | Description                                                                                                                                                                            |
|----------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                    | OFF                | USBPLL_ICLK is considered for generating the acknowledgment. This setting also means USBPLL_ICLK is shut down upon PRCM IDLE request.                                                  |
| 1                    | ON                 | USBPLL_ICLK is not shut down upon PRCM IDLE request. The USBPLL module can potentially acknowledge the IDLE request without checking the internal functionalities linked to its clock. |

**CAUTION**

The PRCM does not have any hardware means to read CLOCKACTIVITY settings. Software ensures a consistent programming between the USBTLL module CLOCKACTIVITY and PRCM USBTLL\_ICLK control bit. Indeed, if the USBTLL module is disabled in the PRCM.CM\_ICLKEN3\_CORE register while CLOCKACTIVITY is set to 1, nothing prevents the PRCM module from asserting its IDLE request, which is acknowledged regardless of the features associated to the USBTLL module interface clock. This may lead to unpredictable behaviors.

**22.2.3.2 Hardware Requests****22.2.3.2.1 Interrupt Requests**

**Table 22-44** lists the interrupt lines that are driven out from the high-speed USB host controller to the microprocessor unit (MPU) subsystem interrupt controller (INTC).

**Table 22-44. High-Speed USB Host Subsystem Interrupts**

| Name                                         | Mapping  | Comments                                          |
|----------------------------------------------|----------|---------------------------------------------------|
| <b>HS USB OHCI Host Controller Interrupt</b> |          |                                                   |
| OHCI_IRQ                                     | M_IRQ_76 | Destination is MPU subsystem interrupt controller |
| <b>HS USB EHCI Host Controller Interrupt</b> |          |                                                   |
| EHCI_IRQ                                     | M_IRQ_77 | Destination is MPU subsystem interrupt controller |
| <b>USBTLL Module Interrupt</b>               |          |                                                   |
| TLL_IRQ                                      | M_IRQ_78 | Destination is MPU subsystem interrupt controller |

**22.2.3.2.2 IDLE Handshake Protocol**

The PRCM handles an IDLE handshake protocol for the high-speed USB host controller and the USBTLL module. The IDLE handshake protocol allows the PRCM requiring the high-speed USB host controller to enter idle mode. The module acknowledges when it is ready.

**22.2.3.2.3 MSTANDBY Handshake Protocol**

The PRCM module handles an MSTANDBY handshake protocol for the high-speed USB host controller, which initiates the MSTANDBY handshake to inform the PRCM module when it enters standby mode and does not generate traffic on interconnect.

**22.2.3.2.4 Wake-Up Request**

Wake-up request signal USBHOST\_SWAKEUP is generated by the high-speed USB host controller to the PRCM module. Wake-up request signal USBTLL\_SWAKEUP is generated by the USBTLL module to the PRCM module.

## 22.2.4 High-Speed USB Host Subsystem Functional Description

This section describes the functionality of the high-speed USB host subsystem by describing the high-speed USB host controller and the USBTLL module.

### 22.2.4.1 High-Speed USB Host Controller Functionality

The full details of the standard OHCI and EHCI host controller APIs (implemented by the current module) are not repeated here. For more information, see the following public specifications:

- *Open Host Controller Interface (OHCI) specification for USB Release 1.0a*
- *Enhanced Host Controller Interface (EHCI) specification for USB Release 1.0*

#### 22.2.4.1.1 High-Speed USB Host Controller Architecture

Figure 22-31 shows an overview of the high-speed USB host controller internal architecture: It contains two independent, 3-port host controllers that operate in parallel: EHCI and OHCI. Each of the three external ports is owned by exactly one of the controllers at any point in time. Each port can work in several modes:

- When the port is owned by the OHCI (full-speed) host controller, the serial 6-pin interface mode is used.
- When the port is owned by the EHCI (high-speed) host controller, either the ULPI or the UTMI modes are used.

The L4-Core interconnect is used to configure the two controllers, as well as a general, TI-specific register bank. The L3 interconnect merges and arbitrates between the transactions generated by the controller respective DMA engines.

Figure 22-31. High-Speed USB Host Controller Architecture



usb-029

#### 22.2.4.1.2 OHCI Implementation Specifications

Some features of the OHCI API are optional and/or implementation-specific. The choices made in the current implementation, the high-speed USB host controller, are described below, and are reflected in the register descriptions (see [Section 22.2.6.4.3, OHCI Registers](#)). For all standard features, see the *Open Host Controller Interface (OHCI) specification for USB Release 1.0a*.

- **USBHOST.HCFMINTERVAL[30:16]** FSMPS field (FullSpeedMaxPacketSize) = 0x0000: Host will stop scheduling new packets 0 bit times before the end of the frame (that is, there is no scheduling overrun protection by default). To be updated by the software driver.
- **USBHOST.HCRHDESCRIPTORA[7:0]** NDP field (NumberDownstreamPorts) = 0x03 = 3 ports.
- **USBHOST.HCRHDESCRIPTORA[9]** NPS bit (NoPowerSwitching) = 0: Ports are power-switched by default.
- **USBHOST.HCRHDESCRIPTORA[8]** PSM bit (PowerSwitchingMode) = 1: Per-port power switching is supported, although PPCM default setup has all ports controlled globally (default must be = OCPM).
- **USBHOST.HCRHDESCRIPTORA[31:24]** POTPG field (PowerOnToPowerGood) = 0x0A = 10: Power

rampup time is  $10 \times 2 \text{ ms} = 20 \text{ ms}$ .

- **USBHOST.HCRHDESCRIPTORB[15:0]** DR field (DeviceRemovable) = 0x0000: By default, no nonremovable devices (that is, devices attached to any of the ports) are removable.
- **USBHOST.HCRHDESCRIPTORB[31:16]** PPCM field (PortPowerControlMask) = 0x0000: By default, all ports are affected only by global power control.

#### **22.2.4.1.3 UTMI Ports**

The high-speed USB host controller supports N "downstream" ports, numbered from 1 through N. (In USB terminology, port 0 is necessarily an "upstream" port, and because the host is on "top" of the USB topological tree it has none). In the current implementation N = 3 (that is, available ports are 1, 2, 3).

The high-speed USB host controller is configured to be either in UTMI or in ULPI mode (see each port configuration with the **USBHOST.UHH\_HOSTCONFIG[12]** P3\_ULPI\_BYPASS, **USBHOST.UHH\_HOSTCONFIG[11]** P2\_ULPI\_BYPASS, and **USBHOST.UHH\_HOSTCONFIG[0]** P1\_ULPI\_BYPASS bits).

In UTMI mode (see *USB 2.0 Transceiver Macrocell Interface specification Release 1.05* ), all ports are in UTMI mode (that is, each port has its UTMI signal set broadcast the "outgoing" packets - from the host to the peripherals) and gather the "incoming" ones (that is, from the addressed peripheral to the host). ULPI signal sets are undefined/don't care on all ports.

In the device, the UTMI ports connect to the USBTLL module. The UTMI ports between the high-speed USB host controller and the USBTLL module are on-chip and remain invisible.

#### **22.2.4.1.4 ULPI Ports**

The high-speed USB host controller supports N "downstream" ports, numbered from 1 through N. (In USB terminology, port 0 is necessarily an "upstream" port, and because the host is on "top" of the USB topological tree it has none). In the current implementation N = 3 (that is, available ports are 1, 2, 3).

The high-speed USB host controller is configured to be either in UTMI or in ULPI mode (see each port configuration with the **USBHOST.UHH\_HOSTCONFIG[12]** P3\_ULPI\_BYPASS, **USBHOST.UHH\_HOSTCONFIG[11]** P2\_ULPI\_BYPASS, and **USBHOST.UHH\_HOSTCONFIG[0]** P1\_ULPI\_BYPASS bits).

In ULPI mode , all ports are in ULPI mode (that is, each port has its ULPI signal set broadcast the "outgoing" packets - from the host to the peripherals) and gather the "incoming" ones (that is, from the addressed peripheral to the host). UTMI signal sets are undefined/don't care on all ports.

When in ULPI mode, the high-speed USB host controller is in charge of generating the (nominally 60-MHz) clock to the transceiver on the ULPI interface. This is called ULPI "input" clocking mode, because the ULPI protocol is transceiver-centric. The opposite mode, "output mode" (that is, the host receives the ULPI clock from the transceiver), is not supported and there is consequently no ULPI clock input.

In the device, the ULPI ports can only be connected directly to external transceivers. The USBTLL module is bypassed. USB traffic can be monitored directly on the USB lines.

#### **22.2.4.1.5 Port Status**

The USB port status is given through the **USBHOST.UHH\_HOSTCONFIG[10:8]** bit field. The default value of the following bits is 1:

- **USBHOST.UHH\_HOSTCONFIG[8]** P1\_CONNECT\_STATUS
- **USBHOST.UHH\_HOSTCONFIG[9]** P2\_CONNECT\_STATUS
- **USBHOST.UHH\_HOSTCONFIG[10]** P3\_CONNECT\_STATUS

**CAUTION**

These bits show the port status as connected after power on even though no USB device is connected. The USB host controller has operational status registers (for example, `USBHOST.HCRHPORTSTATUS_1` for OHCI port 1) that indicate the correct port connect status. The USB driver software must read these status bits and check whether or not a port is connected. If the port is not connected, the USB driver software must reprogram the `USBHOST.UHH_HOSTCONFIG` bits to indicate the correct port connect status.

**22.2.4.1.6 Save and Restore**

The save-and-restore (SAR) mechanism can extract the hardware context of the high-speed USB host controller (after all USB activity has been suspended) before switching off (=save), save it to an external always-on memory, and reinject it later after the module has been switched on again and reset (=restore) seamlessly for the USB. Part of that context is composed of the register fields described in the current chapter. The rest of the context is composed of the "buried" flip-flops and memories (not accessible by software) like finite state-machine (FSM) states, buffer contents, and miscellaneous random logic bits.

The `PRCM.PM_PWSTCTRL_USBHOSTE[4]` `SAVEANDRESTORE` bit enables the SAR mechanism for the high-speed USB host controller (see [Chapter 3, Power, Reset, and Clock Management](#)). When set, the PRCM module initiates the save and/or the restore sequences at the appropriate time. When not set, the USB host is treated as a standard module, and the save/restore sequences do not occur.

**22.2.4.1.7 L3 Burst Control**

To avoid buffer underflow, bursts must be enabled by writing 0x7 in the `USBHOST.UHH_HOSTCONFIG[4:2]` bit field and by setting the `USBHOST.UHH_HOSTCONFIG[5]` `ENA_INCR_ALIGN` bit to 1.

**22.2.4.2 USBTLL Module Functionality**

The USBTLL module implements a TLL compatible with a number of USB standard interface protocols. Once the interface protocol has been selected during an initial configuration phase, USB operation should take place seamlessly (that is, as if actual transceivers were present). To ensure maximum compatibility, as many features as possible have been included, as described in the rest of this document. The basic principle is that all the software "handles" should be available and behave in a proper way, even if there is no actual functionality underneath.

The USBTLL module is integrated with the high-speed USB host controller in the device. The transceiver interfaces (UTMI ports) between the high-speed USB host controller and the USBTLL module are on-chip and remain invisible. The other transceiver interfaces go off-chip, where they can be connected to the other controllers (for example, peripherals) on another IC.

**22.2.4.2.1 Channels and Ports**

Following the same convention than UTMI and ULPI, the current specification is consistently PHY-centric (that is, directions are always given with respect to the transceiver emulated here by the TLL), and not with respect to the link controller: An "input" goes from the link controller to the TLL (transceiver emulator) (that is, it is an input for the USBTLL module. Reciprocally, an "output" goes from TLL (transceiver) to the link controller (that is, it is an output for the USBTLL module).

By convention, the local link controller is the controller integrated on the same IC as the USBTLL module: This is the high-speed USB host controller in the device. The remote link controller is the other controller, located off-chip (that is, on another IC). One controller is always the USB host, the other the USB peripheral, and they communicate through the USBTLL module.

A channel is defined as an independent USB path through the USBTLL module, which always converts the UTMI+ transceiver interface protocol coming from the local link controller (the high-speed USB host controller in the device). The number of channels of the USBTLL module is three in the device.

A USB port is a set of I/O signals that carry the data and control information from/to a USB line. Several port formats exist, with different capabilities. A channel has three ports. If the channel is active, two ports are active at a time, depending on the channel configuration. The mode remains static throughout USB operation. [Table 22-45](#) summarizes the ports features.

#### **22.2.4.2.2 Channel Architecture**

[Figure 22-32](#) shows the architecture of a single channel (of three) of the USBTLL module, and its integration in a USB system. The ports are indicated by the circled letters (A, C, and D). See the following descriptions:

- Full arrows represent parallel, synchronous, high-speed-capable interfaces.
- Line arrows represent serial, combinatorial, full-speed/low-speed-only interfaces.
- Arrows always point toward the PHY layer (actual transceiver or TLL, in yellow), away from the link controller.
- The arrow marked ULPI\* represents the entire ULPI protocol (synchronous or not) except the 3-/6-pin serial TLL modes which are reoriented toward the serial TLL block.
- The USBTLL module cannot interface with a ULPI transceiver. This functionality is provided by the high-speed USB host controller.
- Top-level multiplexing is shown only for information. It is static and does not add functionality. The figure shows ULPI and serial ports implemented on different I/O pads for clarity, but a real implementation would typically reuse the same pads, because the interfaces cannot be active simultaneously

**Figure 22-32. USBTLL Channel**



[Table 22-45](#) summarizes the properties of each port.

**Table 22-45. USBTLL Channel USB Ports**

| USBTLL Port | Port Description | Connect to Controller | Connect to Transceiver | Serial (Full-Speed/ Low-Speed only) | Parallel (High-Speed/ Full-Speed/Low-Speed) |
|-------------|------------------|-----------------------|------------------------|-------------------------------------|---------------------------------------------|
| A           | PHY-side UTMI+   | UTMI+ (L3)            | No                     | 6-pin                               | 60-MHz UTMI                                 |
| C           | PHY-side ULPI    | ULPI TLL              | No                     | 6-pin                               | 60-MHz UTMI                                 |
| D           | Multimode Serial | 6-/4-/3-/2-pin TLL    | 6-/4-/3-/2-pin         | 6-/4-/3-/2-pin TLL                  | No                                          |

#### 22.2.4.2.2.1 Port A: PHY-side UTMI+ Port

Connects to the high-speed USB host controller in the device. The UTMI "local" port is used in all configurations (that is, the entire channel can be seen as a protocol converted from that port to one of the remote ports C or D).

- Compliant with UTMI+ version 1.0
- 8-data-bit, 60 MHz UTMI (HS/FS/LS-capable)
- UTMI+ Level 3 extensions
- Vcontrol/Vstatus (from UTMI)
- Serial FS/LS "6-pin" mode

#### 22.2.4.2.2.2 Port C: PHY-Side ULPI Port

Connects to a remote (off-chip) ULPI controller through I/O pads.

- Compliant with ULPI version 1.1
- SDR and DDR ULPI capable (respectively, 8-bit/4-bit data width modes)
- Supports optional 6-pin/3-pin serial modes

#### 22.2.4.2.2.3 Port D: Serial Multimode Port

Connects to either a serial controller (TLL modes) or a serial transceiver (transceiver interface modes).

- Supports 6-pin (TX: DAT/SE0 or TX: DP/DM) unidirectional, 4-pin bidirectional, 3-pin bidirectional, 2-pin bidirectional modes
- All modes are supported for TLL or transceiver interface configuration.
- Supports sideband signals (pullup/down control, speed/suspend enable, etc.)

#### 22.2.4.2.3 Channel Configuration

A channel configuration is a set of software settings that specifies the connection of two of the channel ports through the USBTLL module. USB data and control injected on one side (or port) comes out on the other side (or port) after a certain amount of processing, depending on the mode. [Table 22-46](#), lists the modes.

All configurations connect the PHY UTMI port (attached to the high-speed USB host controller) to one of the other two ports (attached to a variety of transceivers or controllers on the pads side).

[Table 22-46](#) describes the available modes and the software settings required for each. Channel i has the following settings:

- CHANMODE: `USBHOST.TLL_CHANNEL_CONF_i[2:1]` CHANMODE field
- FSLSMODE: `USBHOST.TLL_CHANNEL_CONF_i[27:24]` FSLSMODE field
- FSLSSERIALMODE\_3PIN/6PIN: Either the ULPI PHY-side `USBHOST.ULPI_INTERFACE_CTRL_i[1]` FSLSSERIALMODE\_3PIN bit or the `USBHOST.ULPI_INTERFACE_CTRL_i[0]` FSLSSERIALMODE\_6PIN bit (only one can be set to 1 at a time)

**Table 22-46. USBTLL Channel Configuration**

| Configuration | Mode                           | CHAN MODE | FSLSMODE                 | Other Settings               | Ports | Speed | Remote Port Connection                                     |
|---------------|--------------------------------|-----------|--------------------------|------------------------------|-------|-------|------------------------------------------------------------|
| 2             | ULPI synchronou s TLL          | 0         | N/A                      | FSLSSERIALMODE_3PIN/6PIN = 0 | A-C   | HFL   | ULPI link (peripheral controller)                          |
| 4             | Serial UTMI to serial ULPI TLL | 0         | N/A                      | FSLSSERIALMODE_3PIN/6PIN = 1 | A-C   | FL    | ULPI link (peripheral controller) supporting 3-/6-pin mode |
| 6             | Serial UTMI to serial TLL      | 1         | 0x4 to 0x7; - 0xA to 0xB |                              | A-D   | FL    | Serial link (2-/3-/4-/6-pin)                               |

**Table 22-46. USBTLL Channel Configuration (continued)**

| Configuration | Mode                             | CHAN<br>MODE | FSLSMODE   | Other Settings | Ports | Speed | Remote Port Connection                 |
|---------------|----------------------------------|--------------|------------|----------------|-------|-------|----------------------------------------|
| 6             | Serial UTMII<br>to serial<br>PHY | 1            | 0x0 to 0x3 | -              | A-D   | FL    | Serial transceiver<br>(2-/3-/4-/6-pin) |

**Figure 22-33. Per-Configuration Datapath Through USBTLL**

usb-031

#### 22.2.4.2.4 VBUS Management and Emulations

In transceiver configurations, an actual USB cable is present, including an actual 5 V VBUS supply line. On the other hand, in TLL configurations, the physical USB lines are emulated and have no physical existence. This is especially true for the VBUS line, which distributes the 5-V power provided by the default host (or A-device) to the entire bus. VBUS is also used for signaling purposes, and those features must be emulated:

- A peripheral detects the presence of a host by detecting the presence of VBUS.
- USB OTG defines an elaborate voltage-sensing scheme to dynamically switch on and off VBUS (start and stop sessions). In the context of TLL, this brings no power saving compared to simple suspend.
- In particular, USB OTG uses VBUS as a wake-up source (VBUS-pulsing SRP) for the default peripheral (or B-device).

For more information on how sideband controls are integrated, see [Figure 22-18](#) and [Figure 22-19](#) and the related explanations.

##### 22.2.4.2.4.1 VBUS Control and Status for Transceiver (Non-TLL) Configurations

In non-TLL modes, VBUS exists, and the problem is to propagate control and status to/from the actual VBUS manager IC (typically the transceiver itself).

Only serial transceiver configurations are concerned in the case of the high-speed USB host subsystem in the device.

###### 22.2.4.2.4.1.1 VBUS Management in Serial Transceiver Configurations

VBUS management is not standardized in transceiver configurations. The chosen implementation is described below. See also [Figure 22-18](#).

- VBUS control required for host and OTG operation (VBUS drive, VBUS pullup "charge", VBUS pulldown "discharge") is assumed to be taken care of separately from the USBTLL module (that is, by software and straight to the power IC, which can be the transceiver itself, especially in OTG cases).
- VBUS status must be sampled by the appropriate hardware (again, most of the time the transceiver itself) and reported by software to the USBTLL module, using the USBHOST.TLL\_CHANNEL\_CONF\_i.DRVVBUS and CHRGVBUS bits, as indicated in [Table 22-47](#).

[Table 22-47](#) lists the values to write to the USBHOST.TLL\_CHANNEL\_CONF\_i register depending on the VBUS status observed by the transceiver on the actual VBUS line. The same register fields are also used in TLL configuration, and have been named according to that second configuration. In transceiver configurations the fields actual signification is:

- DRVVBUS: Set to 1 to report a VBUS level greater than *VBUS valid*.
- CHRGVBUS: Set to 1 to report a VBUS level greater than *Session valid*

**Table 22-47. VBUS Level Software Reporting for Serial Transceiver Configuration**

| VBUS Status         | USBHOST.TLL_CHANNEL_CONF_i[16]<br>DRVVBUS Bit | USBHOST.TLL_CHANNEL_CONF_i[15]<br>CHRGVBUS Bit |
|---------------------|-----------------------------------------------|------------------------------------------------|
| VBUS valid          | 1                                             | 1                                              |
| Session valid (A/B) | 0                                             | 1                                              |
| Session not valid   | 0                                             | 0                                              |
| Session end         | 0                                             | 0                                              |

##### 22.2.4.2.4.2 VBUS Emulation for TLL Configurations

The TLL VBUS emulation sums up all actions on the VBUS line, obtains a voltage level, reported in the VBUS status bits following the protocol. The level depends on the immediate VBUS actions and has no memory of previous levels, whereas a real VBUS line behaves like an RC circuit and takes time to charge and discharge. This causes the following differences:

- The TLL level always jumps abruptly from session valid to session end (and back) with no transient time in between (where session is neither valid nor ended) as in real life.

- The Charge feature is used for VBUS-pulsing SRP, and is enabled long enough to go over the Session valid threshold, but without reaching VBUS valid. In the TLL the transition to Session valid is immediate, and VBUS valid is never reached even if the Charge is intentionally kept active.
- The Discharge feature is used in real life to accelerate the voltage drop of an undriven VBUS towards the session-end level. For TLL, this is therefore useless (although the UTMI input/ULPI register bit do exist, for compatibility), and always a "don't care"

#### 22.2.4.2.4.2.1 VBUS Emulation in ULPI TLL Modes

**Table 22-48** summarizes the VBUS emulation in ULPI TLL modes. VBUS controls are writable, static PHY-side registers on the ULPI side, and input signals on the ULPI ports (port A). VBUS status bits are read-only, volatile PHY-side registers on the ULPI, and output signals on the ULPI ports (port A).

**Table 22-48. Emulation of VBUS Levels for UTMI-to-ULPI TLL Mode**

| VBUS Controls (Actions)  |                          |                          | VBUS Level             | VBUS Status                    |                                |                                |
|--------------------------|--------------------------|--------------------------|------------------------|--------------------------------|--------------------------------|--------------------------------|
| USBHOST.ULPI_OTG_CTRL[5] | USBHOST.ULPI_OTG_CTRL[4] | USBHOST.ULPI_OTG_CTRL[3] | USBHOST.ULPI_USB_VALID | USBHOST.ULPI_USB_INT_STATUS[1] | USBHOST.ULPI_USB_INT_STATUS[2] | USBHOST.ULPI_USB_INT_STATUS[3] |
| DRVVBUS Bit              | CHRGVBUS Bit             | DISCHRGVBUS Bit          | Bit                    | Bit                            | SESSVALID Bit                  | SESEND Bit                     |
| 1                        | X                        | X                        | VBUS valid             | 1                              | 1                              | 0                              |
| 0                        | 1                        | X                        | VBUS valid             | 0                              | 1                              | 0                              |
| 0                        | 0                        | X                        | Session end            | 0                              | 0                              | 1                              |

#### 22.2.4.2.4.2.2 VBUS Emulation in Serial TLL Modes

In serial TLL modes, VBUS status and control is implemented with ad-hoc sideband signals. See [Figure 22-19](#).

VBUS control can be done in software, by writing to the following fields of the [USBHOST.TLL\\_CHANNEL\\_CONF\\_i](#) register:

- DRVVBUS: Set to 1 to drive VBUS to 5 V (for A-device or host)
- CHRGVBUS: Set to 1 to pullup VBUS (for SRP)
- There is no pulldown (discharge) control, because the emulated VBUS has no latency and VBUS level goes to the session end level as soon as it is neither driven nor pulled up.

Alternatively, VBUS drive can also be hardware-controlled through a dedicated input. (DRVVBUS register bit and input signal are actually ORed internally.)

VBUS status is available on dedicated output signals. If those outputs are not available at top level, a software alternative is to use the voltage status reported on the local controller (the high-speed USB host controller in the device) interface (through the standard UTMI+ sideband signals) and to pass it to the remote controller (a peripheral controller), by means of an ad hoc software-controller interface other than the USB itself. This is based on the fact that the level of VBUS is the same on both extremities of the bus (that is, it does not matter which side does the measurement).

#### 22.2.4.2.5 Multimode Serial Port

The multimode serial port requires six bidirectional I/O pads to support all eight defined modes (selected in the [USBHOST.TLL\\_CHANNEL\\_CONF\\_i\[27:24\]](#) FSLSMODE field when field CHANMODE = 0x1 = UTMI-to-serial). Those modes are full-speed/low-speed only (that is, high-speed is not supported over a serial interface).

The pads are named TXEN, TXDAT, TXSE0, RXRCV, and RXDM after their functionality in standard 6-pin mode (mode 0). Each pad has an input, output, and output enable signal associated to it on the USBTLL entity.

[Table 22-49](#) shows the functionality of each pad in each mode. USBTLL outputs are shown in yellow, inputs in blue, and bidirectional pads in green.

**Table 22-49. Serial Mode Description, Signal Functionality**

| Usual Name                                        | 6-Pin Mode       | 6-Pin Mode (Alt) | 3-Pin Mode      | 4-Pin Mode          | 6-Pin TLL Mode        | 6-Pin TLL (Alt) Mode  | 3-Pin TLL Mode  | 4-Pin TLL Mode        | 2-Pin TLL Mode  | 2-Pin TLL (Alt) Mode |
|---------------------------------------------------|------------------|------------------|-----------------|---------------------|-----------------------|-----------------------|-----------------|-----------------------|-----------------|----------------------|
| USBHOST.TLL_CH_ANNEL_CONF_i[27:24] FSLSMODE field | 0x0              | 0x1              | 0x2             | 0x3                 | 0x4                   | 0x5                   | 0x6             | 0x7                   | 0xA             | 0xB                  |
| TX encoding                                       | DAT/SE0          | DP/DM            | DAT/SE0         | DP/DM               | DAT/SE0               | DP/DM                 | DAT/SE0         | DP/DM                 | DAT/SE0         | DP/DM                |
| RX encoding                                       | DP/DM/R CV       | DP/DM/RCV        | DAT/SE0         | DP/DM/RCV           | DP/DM/RCV             | DP/DM/RCV             | DAT/SE0         | DP/DM/RCV             | DAT/SE0         | DP/DM                |
| Pin usage                                         | Unidirectional   | Unidirectional   | Bidirectional   | Bidirectional       | Unidirectional        | Unidirectional        | Bidirectional   | Bidirectional         | Bidirectional   | Bidirectional        |
| Pin count                                         | 6                | 6                | 3               | 4                   | 6 or 5 <sup>(1)</sup> | 6 or 5 <sup>(1)</sup> | 3               | 4 or 3 <sup>(2)</sup> | 2               | 2                    |
| <b>I/O Pad Function Per Mode</b>                  |                  |                  |                 |                     |                       |                       |                 |                       |                 |                      |
| TXEN                                              | TX Enable        | TX Enable        | TX Enable       | TX Enable           | TX Enable             | TX Enable             | TX Enable       | TX Enable             | N/C             | N/C                  |
| TXDAT                                             | TX Diff Data     | TX SE Plus Data  | TX/RX Diff Data | TX/RX SE Plus Data  | TX Diff Data          | TX SE Plus Data       | TX/RX Diff Data | TX/RX Diff Data       | TX/RX Diff Data | TX/RX SE Plus Data   |
| TXSE0                                             | TX force SE0     | TX SE Minus Data | TX/RX force SE0 | TX/RX SE Minus Data | TX force SE0          | TX SE Minus Data      | TX/RX force SE0 | TX/RX force SE0       | TX/RX force SE0 | TX/RX SE Minus Data  |
| RXRCV                                             | RX Diff Data     | RX Diff Data     | N/C             | RX Diff Data        | RX Diff Data          | RX Diff Data          | N/C             | RX Diff Data          | N/C             | N/C                  |
| RXDM                                              | RX SE Plus Data  | RX SE Plus Data  | N/C             | N/C                 | RX SE Plus Data       | RX SE Plus Data       | N/C             | N/C                   | N/C             | N/C                  |
| RXDM                                              | RX SE Minus Data | RX SE Minus Data | N/C             | N/C                 | RX SE Minus Data      | RX SE Minus Data      | N/C             | N/C                   | N/C             | N/C                  |

<sup>(1)</sup> RXRCV and RXDM carry the same info: RXDM can drive both inputs of the remote controller and RXRCV kept unused

<sup>(2)</sup> Same remark on TXDAT (for outputs) and RXRCV: TXDAT only is enough

#### 22.2.4.2.6 Attach/Connect Emulation for Serial TLL Modes

This section applies to all serial TLL modes:

- In UTMI-to-serial mode (USBHOST.TLL\_CHANNEL\_CONF\_i[2:1] CHANMODE field = 0x1) for all TLL values of USBHOST.TLL\_CHANNEL\_CONF\_i[27:24] FSLSMODE field (0x4 to 0x7; 0xA to 0xB)
- In UTMI-to-ULPI TLL mode (USBHOST.TLL\_CHANNEL\_CONF\_i[2:1] CHANMODE field = 0x0) when the ULPI bus is switched to 6-pin serial or 3-pin serial modes

In those modes, the USB bus lines are emulated by USBTLL internal logic, and are never available on the outside. The pullup/pulldown actions described in the USB specification cannot be applied directly, and the USB cable cannot be physically attached.

Because serial modes do not specify a standard format for those sideband settings, a custom software-controlled one was implemented:

- USBHOST.TLL\_CHANNEL\_CONF\_i[4] TLLATTACH bit emulates the physical attachment of the two controllers through a TLL cable.
  - When this bit is cleared, the local controller RX path only shows the local controller (the high-speed USB host controller) actions on the bus: TX driving, pullups, pulldowns (see below). The same thing applies for the remote controller RX path (except that test override is not available).
  - As soon as the bit is set, the actions of both sides are applied to the same bus and are resolved, similar to a real bus. The RX path for both sides shows the same bus state.
- USBHOST.TLL\_CHANNEL\_CONF\_i[5] TLLCONNECT bit emulates the USB electrical connect (that is,

the pullup by the USB peripheral of one of the two USB lines [by a 1.5KOhm resistor], which causes the linestate to transition from SE0 to J, which is detected by the USB host. The register bit is ORed with a USBTLL module input signal - the connect control can be software (L4-Core interconnect write access) or hardware (input level). The speed of the connection is determined by the TLLFULLSPEED bit below.

- **USBHOST.TLL\_CHANNEL\_CONF\_i[6]** TLLFULLSPEED bit determines the speed (full or low) of the USB connect to be emulated. The connect enable (controlled as defined above) results in the pulling-up of either D+ (1 = full speed) or D- (0 = low speed): See [Table 22-50](#).
- The 15kOhm pulldowns are implicit: Because they are supposed to be turned on at least on the host side of the bus, they do not require an additional control.

---

**NOTE:** Sideband control and status actions like pullups are included in parallel (that is, nonserial) standards (UTMI, ULPPI), and do not require any custom additions.

---

**Table 22-50. Pullup Enable Emulation in Serial TLL Modes**

| USBHOST.TLL_CHANNEL_CONF_i Fields |            | Input Signal           | Resulting TLL Pullup Emulation |           |
|-----------------------------------|------------|------------------------|--------------------------------|-----------|
| TLLFULLSPEED                      | TLLCONNECT | USB State              | D+ Pullup                      | D- Pullup |
| 1                                 | 0          | Full-speed unconnected | Off                            | Off       |
| 1                                 | 1          | Full-speed connected   | on                             | Off       |
| 0                                 | 0          | Low-speed unconnected  | Off                            | Off       |
| 0                                 | 1          | Low-speed connected    | Off                            | On        |

#### 22.2.4.2.7 Save and Restore

The SAR mechanism can extract the hardware context of the USBTLL module (after all USB activity has been suspended) before switching off (=save), save it to an external always-on memory, and reinject it later after the module has been switched on again and reset (=restore) seamlessly for the USB. Part of that context is composed of the register fields described in the current chapter. The rest of the context is composed of the buried flip-flops and memories (not accessible by software) like FSM states, buffer contents, and miscellaneous random logic bits.

The PRCM.PM\_PWSTCTRL\_CORE[4] SAVEANDRESTORE bit enables the SAR mechanism for the USBTLL module (see [Chapter 3, Power, Reset, and Clock Management](#)). When set, the PRCM module initiates the save and/or the restore sequences at the appropriate time. When not set, the USB host is treated as a standard module, and the save/restore sequences do not occur.

[Table 22-51](#) lists the USBTLL registers impacted by the SAR context.

---

**NOTE:** Because all addresses give access to the same physical register (that is, to the same piece of context), the ULPPI registers with multiple accesses (write, set, clear) are listed only once in the table.

---

**Table 22-51. USBTLL Registers Impacted by the SAR Context**

| Register Name          | Comments on SAR Policy                |
|------------------------|---------------------------------------|
| USBTLL_SYSCONFIG       | Except the SOFTRESET bit (write-only) |
| USBTLL_IRQENABLE       | -                                     |
| TLL_SHARED_CONF        | Except the FCLK_REQ bit               |
| TLL_CHANNEL_CONF_i     | Except the FSLSLINESTATE field        |
| ULPI_FUNCTION_CTRL_i   | -                                     |
| ULPI_INTERFACE_CTRL_i  | -                                     |
| ULPI_OTG_CTRL_i        | -                                     |
| ULPI_USB_INT_EN_RISE_i | -                                     |
| ULPI_USB_INT_EN_FALL_i | -                                     |

**Table 22-51. USBTLL Registers Impacted by the SAR Context (continued)**

| Register Name            | Comments on SAR Policy |
|--------------------------|------------------------|
| ULPI_USB_INT_STATUS_i    | -                      |
| ULPI_VENDOR_INT_EN_i     | -                      |
| ULPI_VENDOR_INT_STATUS_i | -                      |

## 22.2.5 High-Speed USB Host Subsystem Basic Programming Model

### 22.2.5.1 Selecting and Configuring USB Connectivity

Perform the following steps to select the desired USB connectivity and configure the device accordingly.

The high-speed USB host subsystem provides three kinds of interfaces for connection:

- ULPI PHY interfaces for high-speed data transactions (up to 480 Mbps)
- Serial interfaces for full- and low-speed data transactions (up to 12 Mbps)
- ULPI TLL interfaces for high-speed data transactions (up to 480 Mbps)

[Figure 22-34](#) shows how to select and configure the high-speed USB host subsystem connectivity.

**Figure 22-34. Selecting and Configuring High-Speed USB Host Subsystem Connectivity**

usb-034

**Table 22-52. Register Call Summary for Selecting and Configuring High-Speed USB Host Subsystem Connectivity**

| Register Name      |
|--------------------|
| UHH_HOSTCONFIG     |
| TLL_CHANNEL_CONF_i |

**Table 22-53. Subprocess Call Summary for Selecting and Configuring High-Speed USB Host Subsystem Connectivity**

| Subprocess Name                    | Cross reference                                                   |
|------------------------------------|-------------------------------------------------------------------|
| UHH_HOSTCONFIG[12] Pi_ULPI_BYPASS  | Section 22.2.4.1.3, UTMI Ports                                    |
| TLL_CHANNEL_CONF_i[2:1] CHANMODE   | Section 22.2.4.2.3, Channel Configurations                        |
| TLL_CHANNEL_CONF_i[27:24] FSLSMODE | Section 22.2.4.2.6, Attach/Connect Emulation for Serial TLL Modes |
| TLL_CHANNEL_CONF_i[8] ULPIDDRMODE  | Section 22.2.5.1.1, ULPI Interface Selection                      |

**NOTE:**

- When the USBHOST.UHH\_HOSTCONFIG[12] P3\_ULPI\_BYPASS bit is 0 (the port 3 ULPI transceiver interface selection), only the 12-pin/8-bit data SDR version of the ULPI interface mode is supported for port 3.
- When the USBHOST.UHH\_HOSTCONFIG[11] P2\_ULPI\_BYPASS bit is 0, (the port 2 ULPI transceiver interface selection), only the 12-pin/8-bit data SDR version of the ULPI interface mode is supported for port 2.
- When the USBHOST.UHH\_HOSTCONFIG[0] P1\_ULPI\_BYPASS bit is 0 (the port 1 ULPI transceiver interface selection), only the 12-pin/8-bit data SDR version of the ULPI interface mode is supported for port 1.
- When the USBHOST.UHH\_HOSTCONFIG[12] P3\_ULPI\_BYPASS bit is 1, (the ULPI TLL interface selection and serial interface selection), there is no restriction and port 3 can be configured in any ULPI TLL or serial mode.
- When the USBHOST.UHH\_HOSTCONFIG[11] P2\_ULPI\_BYPASS bit is 1 (the ULPI TLL interface selection and serial interface selection), there is no restriction and port 2 can be configured in any ULPI TLL or serial mode.
- When the USBHOST.UHH\_HOSTCONFIG[0] P1\_ULPI\_BYPASS bit is 1 (ULPI TLL interface selection and serial interface selection), there is no restriction and port 1 can be configured in any ULPI TLL or serial mode.

### 22.2.5.1.1 ULPI Interface Selection

The high-speed USB host subsystem supports the following modes with the ULPI interfaces:

- External USB transceiver
  - ULPI interfaces: 12-pin/8-bit data version
- TLL
  - ULPI TLL interfaces: 12-pin/8-bit data version or 8-pin/4-bit data version

#### 22.2.5.1.1.1 Transceiver Interfaces

The USBTLL module is bypassed and the high-speed USB host controller ports 1 and 2 are connected directly to external transceivers.

The high-speed USB host subsystem supports only the 12-pin/8-bit data SDR version of the ULPI interface mode. The high-speed USB host controller uses its ULPI ports (UTMI ports cannot be used). The USBHOST.UHH\_HOSTCONFIG[12] P3\_ULPI\_BYPASS, USBHOST.UHH\_HOSTCONFIG[11] P2\_ULPI\_BYPASS, or USBHOST.UHH\_HOSTCONFIG[0] P1\_ULPI\_BYPASS bit must be cleared to 0, depending on the port used in ULPI mode.

#### 22.2.5.1.1.2 TLL

The high-speed USB host controller is coupled with the USBTLL module to compose the ULPI TLL interface modes.

The high-speed USB host controller uses its UTMI ports (bypassing the ULPI ports). The USBHOST.UHH\_HOSTCONFIG[12] P3\_ULPI\_BYPASS, USBHOST.UHH\_HOSTCONFIG[11] P2\_ULPI\_BYPASS, or USBHOST.UHH\_HOSTCONFIG[0] P1\_ULPI\_BYPASS bit must be set to 1, depending on the port used in UTMI mode.

At the USBTLL module level, a channel configuration for ULPI TLL interfaces must be set (see [Section 22.2.4.2.3, Channel Configurations](#)).

Two configurations are supported for ULPI TLL interfaces in the device:

- Configuration 2: ULPI synchronous TLL mode
- Configuration 4: Serial UTMI to serial ULPI TLL mode

In both configurations, the USBHOST.TLL\_CHANNEL\_CONF\_i[2:1] CHANMODE field must be cleared to 0x0 (UTMI-to-ULPI TLL mode).

The selection of the ULPI TLL interface version, 12-pin/8-bit data version (SDR mode) or 8-pin/4-bit data version (DDR mode) is done through the USBHOST.TLL\_CHANNEL\_CONF\_i[8] ULPIDDRMODE bit (0: SDR mode; 1: DDR mode).

### 22.2.5.1.2 Serial Interface Selection

The high-speed USB host subsystem supports the following modes with the serial interfaces:

- External USB transceiver configurations
  - Serial 6-pin PHY (transceiver) interfaces: 6-pin unidirectional (TX: DAT/SE0 or TX: DP/DM), 4-pin bidirectional and 3-pin bidirectional modes
- TLL configurations
  - Serial 6-pin TLL interfaces: 6-pin unidirectional (TX: DAT/SE0 or TX: DP/DM), 4-pin bidirectional, 3-pin bidirectional, and 2-pin bidirectional modes

The high-speed USB host controller is coupled with the USBTLL module to compose the serial interface modes.

The high-speed USB host controller uses its UTMI ports (bypassing the ULPI ports). The USBHOST.UHH\_HOSTCONFIG[12] P3\_ULPI\_BYPASS, USBHOST.UHH\_HOSTCONFIG[11] P2\_ULPI\_BYPASS, or USBHOST.UHH\_HOSTCONFIG[0] P1\_ULPI\_BYPASS bit must be set to 1, depending on the port. In UTMI mode, all ports of the high-speed USB host controller are in UTMI mode.

At the USBTLL module level, a channel configuration for serial interfaces must be set (see [Section 22.2.4.2.3, Channel Configurations](#)).

One configuration is supported for serial interfaces in the device, the Configuration 6 including two modes:

- Serial UTMI to serial TLL
- Serial UTMI to serial PHY

The multimode-mode serial interface mode selection is done through the USBHOST.TLL\_CHANNEL\_CONF\_i[27:24] FSLSMODE field only when the main channel mode is serial (USBHOST.TLL\_CHANNEL\_CONF\_i[2:1] CHANMODE field = 0x1 = UTMI-to-serial mode).

**Table 22-54. USB Connectivity Mode Description**

| Usual Name                                       | 6-Pin Mode     | 6-Pin Mode (Alt) | 3-Pin Mode    | 4-Pin Mode    | 6-Pin TLL Mode        | 6-Pin TLL Mode (Alt)  | 3-Pin TLL Mode | 4-Pin TLL Mode        | 2-Pin TLL Mode | 2-Pin TLL (Alt) Mode |
|--------------------------------------------------|----------------|------------------|---------------|---------------|-----------------------|-----------------------|----------------|-----------------------|----------------|----------------------|
| USBHOST.TLL_CHANNEL_CONF_i[27:24] FSLSMODE field | 0x0            | 0x1              | 0x2           | 0x3           | 0x4                   | 0x5                   | 0x6            | 0x7                   | 0xA            | 0xB                  |
| TX encoding                                      | DAT/SE0        | DP/DM            | DAT/SE0       | DP/DM         | DAT/SE0               | DP/DM                 | DAT/SE0        | DP/DM                 | DAT/SE0        | DP/DM                |
| RX encoding                                      | DP/DM/R CV     | DP/DM/RCV        | DAT/SE0       | DP/DM/RCV     | DP/DM/RCV             | DP/DM/RCV             | DAT/SE0        | DP/DM/RCV             | DAT/SE0        | DP/DM                |
| Pin usage                                        | Unidirectional | Unidirectional   | Bidirectional | Bidirectional | Unidirectional        | Unidirectional        | Bidirectional  | Bidirectional         | Bidirectional  | Bidirectional        |
| Pin count                                        | 6              | 6                | 3             | 4             | 6 or 5 <sup>(1)</sup> | 6 or 5 <sup>(1)</sup> | 3              | 4 or 3 <sup>(2)</sup> | 2              | 2                    |

<sup>(1)</sup> RxRCV and RxDP carry the same info: RxDP can drive both inputs of the remote controller and RxRCV kept unused

<sup>(2)</sup> Same remark on TXDAT (for outputs) and RxRCV: TXDAT only is enough

### 22.2.5.2 USBTLL Registers

The USBTLL module contains two types of software-programmable registers.

#### 22.2.5.2.1 TLL Control and Status Registers

These 32-bit registers configure the various channels. These registers are accessed by the MPU through the L4-Core interconnect. They are used mostly before the actual USB activity starts. These registers are:

- 
- Standard registers for revision number, IRQ, clocking management, etc.
  - TLL-specific registers

#### 22.2.5.2.2 ULPI PHY-side Registers

Each TLL channel emulates a ULPI transceiver and accordingly contains this set of 8-bit PHY-side registers, per ULPI specification. Those registers are:

- All ULPI-mandatory standard registers and fields
- A selection of ULPI-optional standard registers and fields, when relevant to the TLL context
- Vendor-specific registers, mapped at the addresses specified for that purpose in ULPI specification

Those registers are accessed by the external (that is, off-chip) link controller over the ULPI port of each channel, in the 0x100-byte ULPI address space, using the ULPI register access protocol.

Those registers are accessible by the L4-Core interconnect: The ULPI register sets of all channels are mapped side by side in the upper part of the L4-Core interconnect address space, where they can be accessed through byte accesses. In case of conflict between the two access modes, the access over ULPI will have priority, but both accesses will eventually complete correctly. For normal USB activity, all register accesses are expected to go over ULPI, and register changes caused by L4-Core interconnect accesses could compromise proper USB operation. The L4-Core interconnect access port is intended for:

- Miscellaneous test and debug
- Nonintrusive observation of ongoing USB operations (test)
- Context restore: During USB suspend periods, the USBTLL module can be switched off to save power. Upon resume, the ULPI register contents have been lost and can be restored over L4-Core interconnect before USB operations restarts, provided they have been saved elsewhere beforehand.

## 22.2.6 High-Speed USB Host Subsystem Register Manual

### 22.2.6.1 USBTLL ULPI PHY-Side Register Space

Each ULPI port emulates a separate ULPI transceiver and as such gives access to a single set of ULPI PHY-side registers, mapped in a separate ULPI register space as specified in the ULPI specification. The ULPI protocol defines two register access methods: Immediate and extended.

- The immediate space maps ULPI PHY-side registers in a 0x400- (64-) byte space (address is 6 bits wide). All ULPI PHY-side registers implemented in the USBTLL implementation are in the immediate space.
- The extended register space maps all ULPI PHY-side registers in a 0x1000- (256-) byte space (address is 8 bits wide). The immediate space is remapped at the bottom of the extended space (that is, the extended access method can be used to access any ULPI register).

An access is recognized as extended by first pointing to a reserved dummy address 0x2F (EXTENDED\_SET\_ACCESS in [Table 22-56](#)). Immediate-mode accesses to this address over the ULPI interface are forbidden by the protocol and the USBTLL behavior is then undefined. Extended accesses to this address have no effect.

Some physical registers are accessible at more than one address, where write accesses perform different actions on the register value: (over-)write, set, clear. A read to any of the addresses returns the register value. The names of the set and clear registers are the write name postfixed with respectively \_SET and \_CLR. The register fields are described only once, at the write address (see [Section 22.2.6.4.1, USBTLL Registers](#)).

---

**NOTE:** Some ULPI registers are cleared upon read.

---

### 22.2.6.2 L4-Core Interconnect Register Space

[Table 22-55](#) lists the base address and address space for the high-speed USB host subsystem.

**Table 22-55. High-Speed USB Host Subsystem Instance Summary**

| Module Name | Base Address (hex) | Size       |
|-------------|--------------------|------------|
| USBTLL      | 0x4806 2000        | 4096 bytes |
| UHH_config  | 0x4806 4000        | 1024 bytes |
| OHCI        | 0x4806 4400        | 1024 bytes |
| EHCI        | 0x4806 4800        | 1024 bytes |

### 22.2.6.3 High-Speed USB Host Subsystem Register Summary

The USBTLL single L4-Core interconnect gives access to both the TLL control and status registers, and the ULPI PHY-side registers.

[Table 22-56](#) lists all the USBTLL registers mapped by the L4-Core interconnect, for the maximum 8-channel configuration.

**CAUTION****On ULPI PHY-side register access over L4-Core interconnect:**

ULPI registers are byte-sized, and can only be accessed in this size. Attempts to access them over L4-Core interconnect using any other data size (16- or 32-bit) will complete without error (or any other warning), but will result in undefined behaviors.

The following cases can cause problems:

- If the ULPI register contents are defined as static (nonvolatile) by the software, a cache update may result in a burst of 32-bit access, with unwanted consequences.
- Some registers have adjacent overwrite, set, and clear addresses. An oversized write access could clear and set the same bit, which can have several results.
- Some registers are cleared on read: Oversized read accesses to adjacent memory locations could cause unwanted clears.

**Table 22-56. USBTLL Registers Mapping Summary (L4-Core Interconnect Register Space)**

| Register Name                             | Type | Register Width (Bits) | Address Offset            | Physical Address          |
|-------------------------------------------|------|-----------------------|---------------------------|---------------------------|
| USBTLL_REVISION                           | R    | 32                    | 0x0000 0000               | 0x4806 2000               |
| USBTLL_SYSCONFIG                          | RW   | 32                    | 0x0000 0010               | 0x4806 2010               |
| USBTLL_SYSSTATUS                          | R    | 32                    | 0x0000 0014               | 0x4806 2014               |
| USBTLL_IRQSTATUS                          | RW   | 32                    | 0x0000 0018               | 0x4806 2018               |
| USBTLL_IRQENABLE                          | RW   | 32                    | 0x0000 001C               | 0x4806 201C               |
| TLL_SHARED_CONF                           | RW   | 32                    | 0x0000 0030               | 0x4806 2030               |
| TLL_CHANNEL_CONF_i <sup>(1)</sup>         | RW   | 32                    | 0x0000 0040 + (0x04 * i)  | 0x4806 2040 + (0x04 * i)  |
| ULPI_VENDOR_ID_LO_i <sup>(1)</sup>        | R    | 8                     | 0x0000 0800 + (0x100 * i) | 0x4806 2800 + (0x100 * i) |
| ULPI_VENDOR_ID_HI_i <sup>(1)</sup>        | R    | 8                     | 0x0000 0001 + (0x100 * i) | 0x4806 2801 + (0x100 * i) |
| ULPI_PRODUCT_ID_LO_i <sup>(1)</sup>       | R    | 8                     | 0x0000 0002 + (0x100 * i) | 0x4806 2802 + (0x100 * i) |
| ULPI_PRODUCT_ID_HI_i <sup>(1)</sup>       | R    | 8                     | 0x0000 0003 + (0x100 * i) | 0x4806 2803 + (0x100 * i) |
| ULPI_FUNCTION_CTRL_i <sup>(1)</sup>       | RW   | 8                     | 0x0000 0004 + (0x100 * i) | 0x4806 2804 + (0x100 * i) |
| ULPI_FUNCTION_CTRL_SET_i <sup>(1)</sup>   | RW   | 8                     | 0x0000 0005 + (0x100 * i) | 0x4806 2805 + (0x100 * i) |
| ULPI_FUNCTION_CTRL_CLR_i <sup>(1)</sup>   | RW   | 8                     | 0x0000 0006 + (0x100 * i) | 0x4806 2806 + (0x100 * i) |
| ULPI_INTERFACE_CTRL_i <sup>(1)</sup>      | RW   | 8                     | 0x0000 0007 + (0x100 * i) | 0x4806 2807 + (0x100 * i) |
| ULPI_INTERFACE_CTRL_SET_i <sup>(1)</sup>  | RW   | 8                     | 0x0000 0008 + (0x100 * i) | 0x4806 2808 + (0x100 * i) |
| ULPI_INTERFACE_CTRL_CLR_i <sup>(1)</sup>  | RW   | 8                     | 0x0000 0009 + (0x100 * i) | 0x4806 2809 + (0x100 * i) |
| ULPI_OTG_CTRL_i <sup>(1)</sup>            | RW   | 8                     | 0x0000 000A + (0x100 * i) | 0x4806 280A + (0x100 * i) |
| ULPI_OTG_CTRL_SET_i <sup>(1)</sup>        | RW   | 8                     | 0x0000 000B + (0x100 * i) | 0x4806 280B + (0x100 * i) |
| ULPI_OTG_CTRL_CLR_i <sup>(1)</sup>        | RW   | 8                     | 0x0000 000C + (0x100 * i) | 0x4806 280C + (0x100 * i) |
| ULPI_USB_INT_EN_RISE_i <sup>(1)</sup>     | RW   | 8                     | 0x0000 000D + (0x100 * i) | 0x4806 280D + (0x100 * i) |
| ULPI_USB_INT_EN_RISE_SET_i <sup>(1)</sup> | RW   | 8                     | 0x0000 000E + (0x100 * i) | 0x4806 280E + (0x100 * i) |
| ULPI_USB_INT_EN_RISE_CLR_i <sup>(1)</sup> | RW   | 8                     | 0x0000 000F + (0x100 * i) | 0x4806 280F + (0x100 * i) |
| ULPI_USB_INT_EN_FALL_i <sup>(1)</sup>     | RW   | 8                     | 0x0000 0010 + (0x100 * i) | 0x4806 2810 + (0x100 * i) |
| ULPI_USB_INT_EN_FALL_SET_i <sup>(1)</sup> | RW   | 8                     | 0x0000 0011 + (0x100 * i) | 0x4806 2811 + (0x100 * i) |

<sup>(1)</sup> i = 0 to 2

**Table 22-56. USBTLL Registers Mapping Summary (L4-Core Interconnect Register Space)  
(continued)**

| Register Name                              | Type     | Register Width (Bits) | Address Offset            | Physical Address          |
|--------------------------------------------|----------|-----------------------|---------------------------|---------------------------|
| ULPI_USB_INT_EN_FALL_CLR_i <sup>(1)</sup>  | RW       | 8                     | 0x0000 0012 + (0x100 * i) | 0x4806 2812 + (0x100 * i) |
| ULPI_USB_INT_STATUS_i <sup>(1)</sup>       | R        | 8                     | 0x0000 0013 + (0x100 * i) | 0x4806 2813 + (0x100 * i) |
| ULPI_USB_INT_LATCH_i <sup>(1)</sup>        | R        | 8                     | 0x0000 0014 + (0x100 * i) | 0x4806 2814 + (0x100 * i) |
| ULPI_DEBUG_i <sup>(1)</sup>                | R        | 8                     | 0x0000 0015 + (0x100 * i) | 0x4806 2815 + (0x100 * i) |
| ULPI_SCRATCH_REGISTER_i <sup>(1)</sup>     | RW       | 8                     | 0x0000 0016 + (0x100 * i) | 0x4806 2816 + (0x100 * i) |
| ULPI_SCRATCH_REGISTER_SET_i <sup>(1)</sup> | RW       | 8                     | 0x0000 0017 + (0x100 * i) | 0x4806 2817 + (0x100 * i) |
| ULPI_SCRATCH_REGISTER_CLR_i <sup>(1)</sup> | RW       | 8                     | 0x0000 0018 + (0x100 * i) | 0x4806 2818 + (0x100 * i) |
| ULPI_EXTENDED_SET_ACCESS_i <sup>(1)</sup>  | Reserved | 8                     | 0x0000 002F + (0x100 * i) | 0x4806 282F + (0x100 * i) |
| ULPI_UTMI_VCONTROL_EN_i <sup>(1)</sup>     | RW       | 8                     | 0x0000 0030 + (0x100 * i) | 0x4806 2830 + (0x100 * i) |
| ULPI_UTMI_VCONTROL_EN_SET_i <sup>(1)</sup> | RW       | 8                     | 0x0000 0031 + (0x100 * i) | 0x4806 2831 + (0x100 * i) |
| ULPI_UTMI_VCONTROL_EN_CLR_i <sup>(1)</sup> | RW       | 8                     | 0x0000 0032 + (0x100 * i) | 0x4806 2832 + (0x100 * i) |
| ULPI_UTMI_VCONTROL_STATUS_i <sup>(1)</sup> | RW       | 8                     | 0x0000 0033 + (0x100 * i) | 0x4806 2833 + (0x100 * i) |
| ULPI_UTMI_VCONTROL_LATCH_i <sup>(1)</sup>  | R        | 8                     | 0x0000 0034 + (0x100 * i) | 0x4806 2834 + (0x100 * i) |
| ULPI_UTMI_VSTATUS_i <sup>(2)</sup>         | RW       | 8                     | 0x0000 0035 + (0x100 * i) | 0x4806 2835 + (0x100 * i) |
| ULPI_UTMI_VSTATUS_SET_i <sup>(2)</sup>     | RW       | 8                     | 0x0000 0036 + (0x100 * i) | 0x4806 2836 + (0x100 * i) |
| ULPI_UTMI_VSTATUS_CLR_i <sup>(2)</sup>     | RW       | 8                     | 0x0000 0037 + (0x100 * i) | 0x4806 2837 + (0x100 * i) |
| ULPI_USB_INT_LATCH_NOCLR_i <sup>(2)</sup>  | R        | 8                     | 0x0000 0038 + (0x100 * i) | 0x4806 2838 + (0x100 * i) |
| ULPI_VENDOR_INT_EN_i <sup>(2)</sup>        | RW       | 8                     | 0x0000 003B + (0x100 * i) | 0x4806 283B + (0x100 * i) |
| ULPI_VENDOR_INT_EN_SET_i <sup>(2)</sup>    | RW       | 8                     | 0x0000 003C + (0x100 * i) | 0x4806 283C + (0x100 * i) |
| ULPI_VENDOR_INT_EN_CLR_i <sup>(2)</sup>    | RW       | 8                     | 0x0000 003D + (0x100 * i) | 0x4806 283D + (0x100 * i) |
| ULPI_VENDOR_INT_STATUS_i <sup>(2)</sup>    | R        | 8                     | 0x0000 003E + (0x100 * i) | 0x4806 283E + (0x100 * i) |
| ULPI_VENDOR_INT_LATCH_i <sup>(2)</sup>     | R        | 8                     | 0x0000 003F + (0x100 * i) | 0x4806 283F + (0x100 * i) |

<sup>(2)</sup> i = 0 to 2

Table 22-57, Table 22-58, and Table 22-59 list the high-speed USB host controller registers.

**Table 22-57. UHH\_config Registers Mapping Summary**

| Register Name  | Type | Register Width (Bits) | Address Offset | Physical Address |
|----------------|------|-----------------------|----------------|------------------|
| UHH_REVISION   | R    | 32                    | 0x0000 0000    | 0x4806 4000      |
| UHH_SYSCONFIG  | RW   | 32                    | 0x0000 0010    | 0x4806 4010      |
| UHH_SYSSTATUS  | R    | 32                    | 0x0000 0014    | 0x4806 4014      |
| UHH_HOSTCONFIG | RW   | 32                    | 0x0000 0040    | 0x4806 4040      |
| UHH_DEBUG_CSR  | RW   | 32                    | 0x0000 0044    | 0x4806 4044      |

**Table 22-58. OHCI Registers Mapping Summary**

| Register Name     | Type | Register Width (Bits) | Address Offset | Physical Address |
|-------------------|------|-----------------------|----------------|------------------|
| HCREVISION        | R    | 32                    | 0x0000 0000    | 0x4806 4400      |
| HCCONTROL         | RW   | 32                    | 0x0000 0004    | 0x4806 4404      |
| HCOMMANDSTATUS    | RW   | 32                    | 0x0000 0008    | 0x4806 4408      |
| HCINTERRUPTSTATUS | RW   | 32                    | 0x0000 000C    | 0x4806 440C      |
| HCINTERRUPTENABLE | RW   | 32                    | 0x0000 0010    | 0x4806 4410      |

**Table 22-58. OHCI Registers Mapping Summary (continued)**

| Register Name      | Type | Register Width (Bits) | Address Offset | Physical Address |
|--------------------|------|-----------------------|----------------|------------------|
| HCINTERRUPTDISABLE | RW   | 32                    | 0x0000 0014    | 0x4806 4414      |
| HCHCCA             | RW   | 32                    | 0x0000 0018    | 0x4806 4418      |
| HCPERIODCURRENTED  | R    | 32                    | 0x0000 001C    | 0x4806 441C      |
| HCCONTROLHEADED    | RW   | 32                    | 0x0000 0020    | 0x4806 4420      |
| HCCONTROLCURRENTED | RW   | 32                    | 0x0000 0024    | 0x4806 4424      |
| HCBULKHEADED       | RW   | 32                    | 0x0000 0028    | 0x4806 4428      |
| HCBULKCURRENTED    | RW   | 32                    | 0x0000 002C    | 0x4806 442C      |
| HCDONEHEAD         | R    | 32                    | 0x0000 0030    | 0x4806 4430      |
| HCFMINTERVAL       | RW   | 32                    | 0x0000 0034    | 0x4806 4434      |
| HCFMREMAINING      | R    | 32                    | 0x0000 0038    | 0x4806 4438      |
| HCFMNUMBER         | R    | 32                    | 0x0000 003C    | 0x4806 443C      |
| HCPERIODICSTART    | RW   | 32                    | 0x0000 0040    | 0x4806 4440      |
| HCLSTHRESHOLD      | RW   | 32                    | 0x0000 0044    | 0x4806 4444      |
| HCRHDESCRIPTORA    | RW   | 32                    | 0x0000 0048    | 0x4806 4448      |
| HCRHDESCRIPTORB    | RW   | 32                    | 0x0000 004C    | 0x4806 444C      |
| HCRHSTATUS         | RW   | 32                    | 0x0000 0050    | 0x4806 4450      |
| HCRHPORTSTATUS_1   | RW   | 32                    | 0x0000 0054    | 0x4806 4454      |
| HCRHPORTSTATUS_2   | RW   | 32                    | 0x0000 0058    | 0x4806 4458      |
| HCRHPORTSTATUS_3   | RW   | 32                    | 0x0000 005C    | 0x4806 445C      |

OHCI register descriptions conform to the OHCI USB standard: *Open Host controller Interface Specification for USB*, Release 1.0a.

For more information about these registers, or for new specification releases, search OHCI on [www.usb.org](http://www.usb.org).

**Table 22-59. EHCI Registers Mapping Summary**

| Register Name           | Type | Register Width (Bits) | Address Offset           | Physical Address         |
|-------------------------|------|-----------------------|--------------------------|--------------------------|
| HCCAPBASE               | R    | 32                    | 0x0000 0000              | 0x4806 4800              |
| HCSPARAMS               | R    | 32                    | 0x0000 0004              | 0x4806 4804              |
| HCCPARAMS               | R    | 32                    | 0x0000 0008              | 0x4806 4808              |
| USBCMD                  | RW   | 32                    | 0x0000 0010              | 0x4806 4810              |
| USBSTS                  | RW   | 32                    | 0x0000 0014              | 0x4806 4814              |
| USBINTR                 | RW   | 32                    | 0x0000 0018              | 0x4806 4818              |
| FRINDEX                 | RW   | 32                    | 0x0000 001C              | 0x4806 481C              |
| CTRLDSSEGMENT           | R    | 32                    | 0x0000 0020              | 0x4806 4820              |
| PERIODICLISTBASE        | RW   | 32                    | 0x0000 0024              | 0x4806 4824              |
| ASYNCLISTADDR           | RW   | 32                    | 0x0000 0028              | 0x4806 4828              |
| CONFIGFLAG              | RW   | 32                    | 0x0000 0050              | 0x4806 4850              |
| PORTSC_i <sup>(1)</sup> | RW   | 32                    | 0x0000 0054 + (0x04 * i) | 0x4806 4854 + (0x04 * i) |
| INSNREG00               | RW   | 32                    | 0x0000 0090              | 0x4806 4890              |
| INSNREG01               | RW   | 32                    | 0x0000 0094              | 0x4806 4894              |
| INSNREG02               | RW   | 32                    | 0x0000 0098              | 0x4806 4898              |
| INSNREG03               | RW   | 32                    | 0x0000 009C              | 0x4806 489C              |
| INSNREG04               | RW   | 32                    | 0x0000 00A0              | 0x4806 48A0              |

<sup>(1)</sup> i = 0 to 2

**Table 22-59. EHCI Registers Mapping Summary (continued)**

| Register Name  | Type | Register Width (Bits) | Address Offset | Physical Address |
|----------------|------|-----------------------|----------------|------------------|
| INSNREG05_UTMI | RW   | 32                    | 0x0000 00A4    | 0x4806 48A4      |
| INSNREG05_ULPI | RW   | 32                    | 0x0000 00A4    | 0x4806 48A4      |

EHCI register descriptions conform to the EHCI USB standard: *Enhanced Host Controller Interface (EHCI) Specification for USB*, Release 1.0.

For more information about these registers or for new specification releases, search EHCI on [www.usb.org](http://www.usb.org).

## 22.2.6.4 High-Speed USB Host Subsystem Register Description

### 22.2.6.4.1 USBTLL Registers

**Table 22-60. USBTLL\_REVISION**

|                         |                                       |                         |                 |                 |        |
|-------------------------|---------------------------------------|-------------------------|-----------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 0000                           | <b>Physical Address</b> | 0x4806 2000     | <b>Instance</b> | USBTLL |
| <b>Description</b>      | Standard revision number, BCD encoded |                         |                 |                 |        |
| <b>Type</b>             | R                                     |                         |                 |                 |        |
| 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 |                 |        |
|                         | RESERVED                              |                         |                 | MAJOR           | MINOR  |

| Bits | Field Name | Description           | Type | Reset     |
|------|------------|-----------------------|------|-----------|
| 31:8 | RESERVED   | Reserved              | R    | 0x0000000 |
| 7:4  | MAJOR      | Major revision number | R    | 0x0       |
| 3:0  | MINOR      | Minor revision number | R    | 0x1       |

**Table 22-61. Register Call Summary for Register USBTLL\_REVISION**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-62. USBTLL\_SYSCONFIG**

|                         |                                        |                         |                 |                 |           |
|-------------------------|----------------------------------------|-------------------------|-----------------|-----------------|-----------|
| <b>Address Offset</b>   | 0x0000 0010                            | <b>Physical Address</b> | 0x4806 2010     | <b>Instance</b> | USBTLL    |
| <b>Description</b>      | Standard system configuration register |                         |                 |                 |           |
| <b>Type</b>             | RW                                     |                         |                 |                 |           |
| 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 |                 |           |
|                         | RESERVED                               |                         |                 | CLOCKACTIVITY   |           |
|                         |                                        |                         |                 | RESERVED        | SIDLEMODE |
|                         |                                        |                         |                 |                 | ENAWAKEUP |
|                         |                                        |                         |                 |                 | SOFTRESET |
|                         |                                        |                         |                 |                 | AUTOIDLE  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:9        | RESERVED          | Reserved                                                                                                                                                                                                                                                                                          | R           | 0x0000000    |
| 8           | CLOCKACTIVITY     | Enable autogating of L3 interconnect-derived internal clocks while module is idle.<br><br>0x0: L3 interconnect-derived internal clocks OFF during idle<br><br>0x1: L3 interconnect-derived internal clocks ON during idle                                                                         | RW          | 0x0          |
| 7:5         | RESERVED          | Reserved                                                                                                                                                                                                                                                                                          | R           | 0x0          |
| 4:3         | SIDLEMODE         | Slave interface power management control. Idle Req/ack control<br><br>0x0: Force-Idle mode. Sidleack asserted after Idlereq assertion<br><br>0x1: No-idle mode. Sidleack never asserted.<br><br>0x2: Smart-idle mode. Sidleack asserted after Idlereq assertion when no more activity on the USB. | RW          | 0x0          |
| 2           | ENAWAKEUP         | Asynchronous wakeup generation control (Swakeup)<br><br>0x0: Wakeup generation disabled<br><br>0x1: Wakeup generation enabled                                                                                                                                                                     | RW          | 0x0          |
| 1           | SOFTRESET         | Module software reset<br><br>0x0: No effect<br><br>0x1: Starts softreset sequence.                                                                                                                                                                                                                | W           | 0x0          |
| 0           | AUTOIDLE          | Internal autogating control<br><br>0x0: Clock always running<br><br>0x1: When no activity on L3 interconnect, clock is cut off.                                                                                                                                                                   | RW          | 0x1          |

**Table 22-63. Register Call Summary for Register USBTLL\_SYSCONFIG**

## High-Speed USB Host Subsystem

- [Reset, Clocking, and Power-Management Scheme](#): [0] [1] [2] [3]
- [USBPLL Module Functionality](#): [4]
- [High-Speed USB Host Subsystem Register Summary](#): [5]

**Table 22-64. USBTLL\_SYSSTATUS**

|                         |                                 |    |    |    |    |    |    |    |    |    |    |    |                 |        |    |    |           |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------|--------|----|----|-----------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 0014                     |    |    |    |    |    |    |    |    |    |    |    |                 |        |    |    |           |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x4806 2014                     |    |    |    |    |    |    |    |    |    |    |    | <b>Instance</b> | USBPLL |    |    |           |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | Standard system status register |    |    |    |    |    |    |    |    |    |    |    |                 |        |    |    |           |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | R                               |    |    |    |    |    |    |    |    |    |    |    |                 |        |    |    |           |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                 |    |    |    |    |    |    |    |    |    |    |    |                 |        |    |    | RESETDONE |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                              | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:1        | RESERVED          | Reserved                                                                                                        | R           | 0x00000000   |
| 0           | RESETDONE         | Indicates when the module has entirely come out of reset<br><br>0x0: Reset is ongoing<br><br>0x1: Reset is done | R           | 0x0          |

**Table 22-65. Register Call Summary for Register USBTLL\_SYSSTATUS**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-66. USBTLL\_IRQSTATUS**

|                       |                                                     |                         |             |                 |        |
|-----------------------|-----------------------------------------------------|-------------------------|-------------|-----------------|--------|
| <b>Address Offset</b> | 0x0000 0018                                         | <b>Physical Address</b> | 0x4806 2018 | <b>Instance</b> | USBTLL |
| <b>Description</b>    | Standard IRQ status vector. Write 1 to clear a bit. |                         |             |                 |        |
| <b>Type</b>           | RW                                                  |                         |             |                 |        |

| 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 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name   | Description                                                                                                                                                                                                                                                                                               | Type | Reset      |
|------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED     | Reserved                                                                                                                                                                                                                                                                                                  | R    | 0x00000000 |
| 2    | ACCESS_ERROR | Access error to ULPI register over L3 interconnect: USB clock must run for that type of access to succeed.<br><br>0x0: No event pending<br>0x1: Event pending                                                                                                                                             | RW   | 0x0        |
| 1    | FCLK_END     | Functional clock is no longer requested for USB clocking<br>When <a href="#">TLL_SHARED_CONF[1]</a> FCLK_REQ=0 and <a href="#">TLL_SHARED_CONF[0]</a> FCLK_IS_ON=1, IRQ is generated to request the clock to be switched OFF and FCLK_END is set to 1.<br><br>0x0: No event pending<br>0x1: Event pending | RW   | 0x0        |
| 0    | FCLK_START   | Functional clock is requested for USB clocking<br>When <a href="#">TLL_SHARED_CONF[1]</a> FCLK_REQ=1 and <a href="#">TLL_SHARED_CONF[0]</a> FCLK_IS_ON=0, IRQ is generated to request the clock to be switched ON and FCLK_START is set to 1.<br><br>0x0: No event pending<br>0x1: Event pending          | RW   | 0x0        |

**Table 22-67. Register Call Summary for Register USBTLL\_IRQSTATUS**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\] \[2\]](#)

**Table 22-68. USBTLL\_IRQENABLE**

|                         |                            |                         |                 |                 |        |
|-------------------------|----------------------------|-------------------------|-----------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 001C                | <b>Physical Address</b> | 0x4806 201C     | <b>Instance</b> | USBTLL |
| <b>Description</b>      | Standard IRQ enable vector |                         |                 |                 |        |
| <b>Type</b>             | RW                         |                         |                 |                 |        |
| 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 |                 |        |
| RESERVED                |                            |                         |                 |                 |        |
|                         |                            |                         |                 | ACCESS_ERROR_EN |        |
|                         |                            |                         |                 | FCLK_END_EN     |        |
|                         |                            |                         |                 | FCLK_START_EN   |        |

  

| Bits | Field Name      | Description                                                                                                                                     | Type | Reset      |
|------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED        | Reserved                                                                                                                                        | R    | 0x00000000 |
| 2    | ACCESS_ERROR_EN | Enable IRQ generation upon access error to ULPI register over L3 interconnect<br><br>0x0: IRQ event is masked<br>0x1: IRQ event is enabled      | RW   | 0x0        |
| 1    | FCLK_END_EN     | IRQ event mask for FCLK_END interrupt (see <a href="#">USBTLL_IRQSTATUS[1]</a> )<br><br>0x0: IRQ event is masked<br>0x1: IRQ event is enabled   | RW   | 0x0        |
| 0    | FCLK_START_EN   | IRQ event mask for FCLK_START interrupt (see <a href="#">USBTLL_IRQSTATUS[0]</a> )<br><br>0x0: IRQ event is masked<br>0x1: IRQ event is enabled | RW   | 0x0        |

**Table 22-69. Register Call Summary for Register USBTLL\_IRQENABLE**

High-Speed USB Host Subsystem

- [USBTLL Module Functionality](#): [0]
- [High-Speed USB Host Subsystem Register Summary](#): [1]

**Table 22-70. TLL\_SHARED\_CONF**

|                         |                                              |                         |                 |                 |        |
|-------------------------|----------------------------------------------|-------------------------|-----------------|-----------------|--------|
| <b>Address Offset</b>   | 0x0000 0030                                  | <b>Physical Address</b> | 0x4806 2030     | <b>Instance</b> | USBTLL |
| <b>Description</b>      | Common control register for all TLL channels |                         |                 |                 |        |
| <b>Type</b>             | RW                                           |                         |                 |                 |        |
| 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 |                 |        |
| RESERVED                |                                              |                         |                 |                 |        |
|                         |                                              |                         |                 | USB_90D_DDR_EN  |        |
|                         |                                              |                         |                 | USB_180D_SDR_EN |        |
|                         |                                              |                         |                 | USB_DIVRATIO    |        |
|                         |                                              |                         |                 | FCLK_REQ        |        |
|                         |                                              |                         |                 | FCLK_IS_ON      |        |

## High-Speed USB Host Subsystem

www.ti.com

| Bits | Field Name      | Description                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset     |
|------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:7 | RESERVED        | Reserved                                                                                                                                                                                                                                                                                                                                                                                               | R    | 0x0000000 |
| 6    | USB_90D_DDR_EN  | Software enable/disable of the 90-degree phase shift scheme on output DDR data, when implemented.<br>Read-only, always-0 when HDL generic<br>ULPI_90DEG4DDR = 0.<br><br>0x0: ULPI DDR output DATA aligned with CLK<br>0x1: ULPI DDR output DATA delayed by 90 degree wrt CLK                                                                                                                           | RW   | 0x1       |
| 5    | USB_180D_SDR_EN | Software enable/disable of the 180-degree phase shift scheme on output SDR data, when implemented.<br>Read-only, always-0 when HDL generic<br>ULPI_180DEG4SDR = 0<br><br>0x0: ULPI SDR output DATA aligned with CLK<br>0x1: ULPI SDR output DATA delayed by 180 degree wrt CLK                                                                                                                         | RW   | 0x1       |
| 4:2  | USB_DIVRATIO    | (Log2 of) division ratio from functional clock to USB (UTMI/ULPI) clock<br><br>0x0: Div ratio is $2^{**}0 = 1$ : Bypass<br>0x1: Div ratio is $2^{**}1 = 2$<br>0x2: Div ratio is $2^{**}2 = 4$<br>0x3: Div ratio is $2^{**}3 = 8$<br>0x4: Div ratio is $2^{**}4 = 16$<br>0x5: Div ratio is $2^{**}5 = 32$<br>0x6: Div ratio is $2^{**}6 = 64$<br>0x7: Div ratio is $2^{**}7 = 128$                      | RW   | 0x0       |
| 1    | FCLK_REQ        | Functional clock request, ORed from all channels depending on their respective USB bus state.<br>Combined with the Fclk_is_on status to generate fclk_start/end IRQs.<br><br>0x0: Func clock input is not requested by TLL<br>0x1: Func clock input is requested by TLL                                                                                                                                | R    | 0x0       |
| 0    | FCLK_IS_ON      | Status of the functional clock input, provided by the system to the TLL module. The TLL module will only use that clock if the current status indicated that it is ready.<br>Combined with the Fclk_request to generate fclk_start/end IRQs.<br><br>0x0: Functional clock input is not guaranteed ON (can actually be ON, OFF, or unstable)<br>0x1: Functional clock input is guaranteed ON and stable | RW   | 0x0       |

**Table 22-71. Register Call Summary for Register TLL\_SHARED\_CONF**

## High-Speed USB Host Subsystem

- [USBTLL Module Functionality: \[0\]](#)
- [High-Speed USB Host Subsystem Register Summary: \[1\]](#)
- [High-Speed USB Host Subsystem Register Description: \[2\] \[3\] \[4\] \[5\]](#)

**Table 22-72. TLL\_CHANNEL\_CONF\_i**

|                         |                                            |                 |            |
|-------------------------|--------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0040 + (0x04 * i)                   | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2040 + (0x04 * i)                   | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Control and Status register for channel I. |                 |            |
| <b>Type</b>             | RW                                         |                 |            |

| 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 |  |
|----------|---------------|----------|----|----------|-----------|-----------|----------|--------|---------|----------|----------|----|----|---------------|--------------|--------------|-------------|------------------|--------------|------------|-----------|-----------|----------|--------|---|---|---|---|---|---|---|--|
| RESERVED | FSLSLINESTATE | FSLSMODE |    | RESERVED | TESTTXSE0 | TESTTXDAT | TESTTXEN | TESTEN | DRVVBUS | CHRGVBUS | RESERVED |    |    | ULPINOBITSUFF | ULPIAUTOIDLE | UTMIAUTOIDLE | ULPIDDRMODE | ULPIOUTCLOCKMODE | TLLFULLSPEED | TLLCONNECT | TLLATTACH | UTMISADEV | CHANMODE | CHANEN |   |   |   |   |   |   |   |  |

| Bits  | Field Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|-------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | RESERVED      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R    | 0x0   |
| 29:28 | FSLSLINESTATE | <p>Line state for Full/Low speed serial modes</p> <p>Bit1 = D-/ Bit0 = D+</p> <p>0x0: Single-ended 0</p> <p>0x1: Full-Speed J = differential 1</p> <p>0x2: Full-Speed K = differential 0</p> <p>0x3: Single-ended 1 (illegal in USB)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R    | 0x0   |
| 27:24 | FSLSMODE      | <p>Multiple-mode serial interface's mode select. Only when main channel mode is serial. No effect in other main modes.</p> <p>0x0: "6pin" unidirectional PHY i/f mode. TX encoding is Dat/Se0 (default)</p> <p>0x1: "6-pin" unidirectional PHY i/f mode. TX encoding is Dp/Dm</p> <p>0x2: "3-pin" bidirectional PHY i/f mode.</p> <p>0x3: "4-pin" bidirectional PHY i/f mode.</p> <p>0x4: "6pin" unidirectional TLL mode. TX encoding is Dat/Se0</p> <p>0x5: "6pin" unidirectional TLL mode. TX encoding is Dp/Dm</p> <p>0x6: "3-pin" bidirectional TLL mode.</p> <p>0x7: "4-pin" bidirectional TLL mode.</p> <p>0xA: "2-pin" bidirectional TLL mode. Encoding is Dat/Se0</p> <p>0xB: "2-pin" bidirectional TLL mode. Encoding is Dp/Dm</p> | RW   | 0x0   |
| 23:21 | RESERVED      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R    | 0x0   |
| 20    | TESTTXSE0     | <p>Force-Se0 transmit override value for serial mode test</p> <p>Don't care if TestEn = 0 (functional mode) or = TestTxen = 1 (tx = hiz)</p> <p>0x0: Drive differential value on TX according to TestTxDat</p> <p>0x1: Drive SE0 on TX</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW   | 0x0   |
| 19    | TESTTXDAT     | <p>Differential data transmit override value for serial mode test</p> <p>Don't care if TestEn = 0 (functional mode) or = TestTxen = 1 (tx = hiz) or TestSe0 = 1 (tx = se0)</p> <p>0x0: Drive full-speed K = differential 0</p> <p>0x1: Drive full-speed J = differential 1</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW   | 0x0   |

## High-Speed USB Host Subsystem

www.ti.com

| Bits  | Field Name     | Description                                                                                                                                                                                                                                                                                    | Type | Reset |
|-------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 18    | TESTTXEN       | Differential data transmit override value for serial mode test<br>Don't care if TestEn = 0 (functional mode)<br>0x0: Drive TX according to TestTXDat/Se0<br>0x1: Drive TX Hiz (no drive: Pullups determine line state)                                                                         | RW   | 0x0   |
| 17    | TESTEN         | Enable manual test override for serial mode TX path (from local controller's UTMI port)<br>0x0: No override. TX is from local link controller<br>0x1: Override enabled                                                                                                                         | RW   | 0x0   |
| 16    | DRVVBUS        | VBUS-drive for ChanMode = serial<br>* In TLL config, write 1 to emulate serial-side VBUS drive<br>* In PHY config, write 1 to report "VBus valid" status (of actual VBUS) to UTMI controller<br>0x0: VBUS not driven<br>0x1: VBUS driven to 5V                                                 | RW   | 0x0   |
| 15    | CHRGVBUS       | VBUS-drive for ChanMode = serial<br>* In TLL config, write 1 to emulate serial-side VBUS charge/pullup (OTG)<br>* In PHY config, write 1 to reports "session valid" status (of actual VBUS) to UTMI controller<br>0x0: VBUS not charged, session not valid<br>0x1: VBUS charged, session valid | RW   | 0x0   |
| 14:12 | RESERVED       | Reserved                                                                                                                                                                                                                                                                                       | R    | 0x0   |
| 11    | ULPINOBITSUFF  | Disable bitstuff emulation in ULPI TLL for ULPI ChanMode<br>0x0: Bitstuff enabled, following USB standard<br>0x1: No bitstuff or associated delays (non-standard)                                                                                                                              | RW   | 0x0   |
| 10    | ULPIAUTOIDLE   | For ChanMode = ULPI TLL only. Allow the ULPI output clock to be stopped when ULPI goes into asynchronous mode (low-power, 3-pin serial, 6-pin serial). No effect in ULPI input clock mode.<br>0x0: ULPI output clock always-on<br>0x1: ULPI output clock stops during asynchronous ULPI modes  | RW   | 0x1   |
| 9     | UTMIAUTOIDLE   | For ChanMode = ULPI TLL only. Allow the UTMI clock (output) to be stopped when UTMI goes to suspended mode (suspendm = 0)<br>0x0: UTMI clock output always on<br>0x1: UTMI clock output gated upon suspend                                                                                     | RW   | 0x1   |
| 8     | ULPIDDRMODE    | Select single/double data rate (SDR/DDR) mode for ULPI TLL<br>Reset value depends on hardware generics ULPI_SDR/DDR_MODE.<br>0x0: SDR mode (8 data bit/12 pin)<br>0x1: DDR mode (4 data bit/8 pin)                                                                                             | RW   | 0x0   |
| 7     | ULPIOUTCLKMODE | ULPI clocking mode select for ULPI TLL ChanMode<br>0x0: ULPI clock provided by LINK (that is, off-chip). ULPI clock is input<br>0x1: ULPI clock provided by PHY side (that is, TLL, from functional clock). ULPI clock is output                                                               | RW   | 0x1   |
| 6     | TLLFULLSPEED   | Sets PHY speed emulation in TLL (full/slow), which determines the line to pull up upon connect. The two connect source controls are: Input m(N)_tlpuen, register field TIIConnect.<br>0x0: Connect is Low-speed: D- pullup<br>0x1: Connect is Full-Speed: D+ pullup                            | RW   | 0x1   |

| Bits | Field Name  | Description                                                                                                                                                                                                                                                                                                                   | Type | Reset |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 5    | TLLCONNECT  | Emulation of Full/Low-Speed connect (that is, D+ resp D-pullup) for serial TLL modes. Speed is determined by field TLLSpeed.<br><br>0x0: Unconnected<br>0x1: Connected                                                                                                                                                        | RW   | 0x0   |
| 4    | TLLATTACH   | Emulates cable attach/detach for all serial TLL modes:<br>* ChanMode = serial, in TLL mode (FsLsMode)<br>* ChanMode = ULPI, in serial mode (6pin/3pin TLL)<br><br>0x0: Cable detach emulated on serial TLL<br>0x1: Cable attach emulated on serial TLL                                                                        | RW   | 0x1   |
| 3    | UTMIIISADEV | Select the cable end "seen" by UTMI side of TLL, that is, the emulated USB cable's orientation.<br>Note that host must always be on A side, Peripheral on B side.<br>Reset value depends on generic DEFUTMIISSHOST.<br><br>0x0: UTMI side is peripheral, ULPI side is host<br>0x1: UTMI side is host, ULPI side is peripheral | RW   | 0x1   |
| 2:1  | CHANMODE    | Main channel mode selection<br><br>0x0: UTMI-to-ULPI TLL mode (HS capable): To ULPI controller<br>0x1: UTMI-to-serial (FS/LS) mode: To serial controller (TLL) or serial PHY<br>0x2: Transparent UTMI mode: To UTMI PHY<br>0x3: No mode selected                                                                              | RW   | 0x0   |
| 0    | CHANEN      | Active-high channel enable. A disabled channel is unclocked and kept under reset.<br><br>0x0: Channel #N disabled<br>0x1: Channel #N enabled                                                                                                                                                                                  | RW   | 0x0   |

**Table 22-73. Register Call Summary for Register TLL\_CHANNEL\_CONF\_i**

High-Speed USB Host Subsystem

- [USBTLL Module Functionality](#): [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16]
- [Selecting and Configuring USB Connectivity](#): [17] [18] [19] [20] [21] [22] [23] [24] [25]
- [High-Speed USB Host Subsystem Register Summary](#): [26]

**Table 22-74. ULPI\_VENDOR\_ID\_LO\_i**

|                         |                                                                                                                                                    |                 |            |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0000 + (0x100 * i)                                                                                                                          | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2800 + (0x100 * i)                                                                                                                          | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Lower byte of USB-IF-supplied vendor ID Value is set for all channels by HDL generic ULPI_VENDORID Default is Texas-Instruments Vendor ID = 0x0451 |                 |            |
| <b>Type</b>             | R                                                                                                                                                  |                 |            |

  

|              |   |   |   |   |   |   |   |
|--------------|---|---|---|---|---|---|---|
| 7            | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| VENDOR_ID_LO |   |   |   |   |   |   |   |

| Bits | Field Name   | Description | Type | Reset |
|------|--------------|-------------|------|-------|
| 7:0  | VENDOR_ID_LO |             | R    | 0x51  |

**Table 22-75. Register Call Summary for Register ULPI\_VENDOR\_ID\_LO\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary](#): [0]

**Table 22-76. ULPI\_VENDOR\_ID\_HI\_i**

|                         |                                                                                                                                                              |                 |            |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0001 + (0x100 * i)                                                                                                                                    | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2801 + (0x100 * i)                                                                                                                                    | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Upper byte of USB-IF-supplied 16-bit vendor ID Value is set for all channels by HDL generic<br>ULPI_VENDORID Default is Texas-Instruments Vendor ID = 0x0451 |                 |            |
| <b>Type</b>             | R                                                                                                                                                            |                 |            |
| 7                       | 6                                                                                                                                                            | 5               | 4          |
| 3                       | 2                                                                                                                                                            | 1               | 0          |
| VENDOR_ID_HI            |                                                                                                                                                              |                 |            |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 7:0         | VENDOR_ID_HI      |                    | R           | 0x04         |

**Table 22-77. Register Call Summary for Register ULPI\_VENDOR\_ID\_HI\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-78. ULPI\_PRODUCT\_ID\_LO\_i**

|                         |                                                                                                              |                 |            |
|-------------------------|--------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0002 + (0x100 * i)                                                                                    | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2802 + (0x100 * i)                                                                                    | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Lower byte of vendor-chosen 16-bit product ID Value is set for all channels by HDL generic<br>ULPI_PRODUCTID |                 |            |
| <b>Type</b>             | R                                                                                                            |                 |            |
| 7                       | 6                                                                                                            | 5               | 4          |
| 3                       | 2                                                                                                            | 1               | 0          |
| PRODUCT_ID_LO           |                                                                                                              |                 |            |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 7:0         | PRODUCT_ID_LO     |                    | R           | 0x00         |

**Table 22-79. Register Call Summary for Register ULPI\_PRODUCT\_ID\_LO\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-80. ULPI\_PRODUCT\_ID\_HI\_i**

|                         |                                                                                                              |                 |            |
|-------------------------|--------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0003 + (0x100 * i)                                                                                    | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2803 + (0x100 * i)                                                                                    | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Upper byte of vendor-chosen 16-bit product ID Value is set for all channels by HDL generic<br>ULPI_PRODUCTID |                 |            |
| <b>Type</b>             | R                                                                                                            |                 |            |
| 7                       | 6                                                                                                            | 5               | 4          |
| 3                       | 2                                                                                                            | 1               | 0          |
| PRODUCT_ID_HI           |                                                                                                              |                 |            |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 7:0         | PRODUCT_ID_HI     |                    | R           | 0x00         |

**Table 22-81. Register Call Summary for Register ULPI\_PRODUCT\_ID\_HI\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-82. ULPI\_FUNCTION\_CTRL\_i**

|                         |                                                                 |                 |            |
|-------------------------|-----------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0004 + (0x100 * i)                                       | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2804 + (0x100 * i)                                       | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Controls UTMI function settings of the PHY. Read/Write address. |                 |            |
| <b>Type</b>             | RW                                                              |                 |            |

| 7        | 6        | 5     | 4 | 3      | 2          | 1 | 0          |
|----------|----------|-------|---|--------|------------|---|------------|
| RESERVED | SUSPENDM | RESET |   | OPMODE | TERMSELECT |   | XCVRSELECT |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                        | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7    | RESERVED   | Reserved                                                                                                                                                                                                                                                                           | R    | 0x0   |
| 6    | SUSPENDM   | Active low PHY suspend: Puts the ULPI bus in Low Power Mode. Automatically set back to 1 upon Low Power Mode exit.<br><br>0x0: PHY is in low-power mode<br>0x1: PHY is not in low-power mode                                                                                       | RW   | 0x1   |
| 5    | RESET      | Active high UTMI transceiver reset. Autocleared. Does not reset the ULPI interface or ULPI register set.<br><br>0x0: No ongoing reset/ no action<br>0x1: Ongoing reset/apply reset                                                                                                 | RW   | 0x0   |
| 4:3  | OPMODE     | Select the required bit encoding style during transmit<br><br>0x0: Normal operation<br>0x1: Non-driving<br>0x2: Disable bit-stuff and NRZI encoding<br>0x3: Reserved                                                                                                               | RW   | 0x0   |
| 2    | TERMSELECT | Controls the internal 1.5Kohms pull-up resistor and 45ohms HS terminations. Control over bus resistors changes depending on XcvrSelect, OpMode, DpPulldown and DmPulldown.<br><br>0x0: HS termination enabled (other conditions)<br>0x1: FS termination enabled (other conditions) | RW   | 0x0   |
| 1:0  | XCVRSELECT | Select the required transceiver speed.<br><br>0x0: Enable HS transceiver<br>0x1: Enable FS transceiver<br>0x2: Enable LS transceiver<br>0x3: Enable FS transceiver for LS packets (automatic FS preamble pre-pending)                                                              | RW   | 0x1   |

**Table 22-83. Register Call Summary for Register ULPI\_FUNCTION\_CTRL\_i**

High-Speed USB Host Subsystem

- [USBTLL Module Functionality: \[0\]](#)
- [High-Speed USB Host Subsystem Register Summary: \[1\]](#)

**Table 22-84. ULPI\_FUNCTION\_CTRL\_SET\_i**

| <b>Address Offset</b>   | 0x0000 0005 + (0x100 * i)                                                                                                                                                                                    | <b>Index</b>                                                                                                                                                                                                                                        | i = 0 to 2 |       |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------|
| <b>Physical Address</b> | 0x4806 2805 + (0x100 * i)                                                                                                                                                                                    | <b>Instance</b>                                                                                                                                                                                                                                     | USBTLL     |       |
| <b>Description</b>      | Controls UTMI function settings of the PHY. Read/set address (write 1 to a bit to set it to 1; writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                                                                                                                                                                                                                                                     |            |       |
| <b>Type</b>             | RW                                                                                                                                                                                                           |                                                                                                                                                                                                                                                     |            |       |
| 7                       | 6                                                                                                                                                                                                            | 5                                                                                                                                                                                                                                                   | 4          |       |
| RESERVED                | SUSPENDM                                                                                                                                                                                                     | RESET                                                                                                                                                                                                                                               | OPMODE     |       |
| 3                       |                                                                                                                                                                                                              |                                                                                                                                                                                                                                                     | TERMSELECT |       |
| 2                       |                                                                                                                                                                                                              |                                                                                                                                                                                                                                                     | XCVRSELECT |       |
| 1                       |                                                                                                                                                                                                              |                                                                                                                                                                                                                                                     | 0          |       |
|                         |                                                                                                                                                                                                              |                                                                                                                                                                                                                                                     |            |       |
| Bits                    | Field Name                                                                                                                                                                                                   | Description                                                                                                                                                                                                                                         | Type       | Reset |
| 7                       | RESERVED                                                                                                                                                                                                     | Reserved                                                                                                                                                                                                                                            | R          | 0x0   |
| 6                       | SUSPENDM                                                                                                                                                                                                     | Active low PHY suspend: Puts the ULPI bus in Low Power Mode. Automatically set back to 1 upon Low Power Mode exit.<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1.                                                         | RW         | 0x0   |
| 5                       | RESET                                                                                                                                                                                                        | Active high UTMI transceiver reset. Autocleared. Does not reset the ULPI interface or ULPI register set.<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1.                                                                   | RW         | 0x0   |
| 4:3                     | OPMODE                                                                                                                                                                                                       | Select the required bit encoding style during transmit<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1.                                                                                                                     | RW         | 0x0   |
| 2                       | TERMSELECT                                                                                                                                                                                                   | Controls the internal 1.5Kohms pull-up resistor and 45ohms HS terminations. Control over bus resistors changes depending on XcvrSelect, OpMode, DpPulldown and DmPulldown.<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW         | 0x0   |
| 1:0                     | XCVRSELECT                                                                                                                                                                                                   | Select the required transceiver speed.<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1.                                                                                                                                     | RW         | 0x0   |

**Table 22-85. Register Call Summary for Register ULPI\_FUNCTION\_CTRL\_SET\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-86. ULPI\_FUNCTION\_CTRL\_CLR\_i**

|                         |                                                                                                                                                                                                                  |                 |            |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0006 + (0x100 * i)                                                                                                                                                                                        | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2806 + (0x100 * i)                                                                                                                                                                                        | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Controls UTMI function settings of the PHY. Read/clear address (write 1 to a bit to clear it to 0, writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                               |                 |            |
| 7                       | 6                                                                                                                                                                                                                | 5               | 4          |
| RESERVED                | SUSPENDM                                                                                                                                                                                                         | RESET           | OPMODE     |
| 3                       |                                                                                                                                                                                                                  |                 | TERMSELECT |
| 2                       |                                                                                                                                                                                                                  |                 | XCVRSELECT |
| 1                       |                                                                                                                                                                                                                  |                 | 0          |
|                         |                                                                                                                                                                                                                  |                 |            |

| Bits | Field Name | Description                                                                                                                                                                                                                                          | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7    | RESERVED   | Reserved                                                                                                                                                                                                                                             | R    | 0x0   |
| 6    | SUSPENDM   | Active low PHY suspend: Puts the ULPI bus in Low Power Mode. Automatically set back to 1 upon Low Power Mode exit.<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0                                                         | RW   | 0x0   |
| 5    | RESET      | Active high UTMI transceiver reset. Autocleared. Does not reset the ULPI interface or ULPI register set.<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0                                                                   | RW   | 0x0   |
| 4:3  | OPMODE     | Select the required bit encoding style during transmit<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0                                                                                                                     | RW   | 0x0   |
| 2    | TERMSELECT | Controls the internal 1.5Kohms pull-up resistor and 45ohms HS terminations. Control over bus resistors changes depending on XcvrSelect, OpMode, DpPulldown and DmPulldown.<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW   | 0x0   |
| 1:0  | XCVRSELECT | Select the required transceiver speed.<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0                                                                                                                                     | RW   | 0x0   |

**Table 22-87. Register Call Summary for Register ULPI\_FUNCTION\_CTRL\_CLR\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-88. ULPI\_INTERFACE\_CTRL\_i**

|                         |                                                                      |                 |            |
|-------------------------|----------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0007 + (0x100 * i)                                            | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2807 + (0x100 * i)                                            | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Enables alternative interfaces and PHY features. Read/Write address. |                 |            |
| <b>Type</b>             | RW                                                                   |                 |            |

| 7                         | 6        | 5          | 4             | 3        | 2                   | 1                   | 0 |
|---------------------------|----------|------------|---------------|----------|---------------------|---------------------|---|
| INTERFACE_PROTECT_DISABLE | RESERVED | AUTORESUME | CLOCKSUSPENDM | RESERVED | FSLSSERIALMODE_3PIN | FSLSSERIALMODE_6PIN |   |

| Bits | Field Name                | Description                                                                                                                                                                                                   | Type | Reset |
|------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7    | INTERFACE_PROTECT_DISABLE | Controls circuitry built into the PHY for protecting the ULPI interface when the link 3-states stp and data.<br><br>0x0: Enables the interface protect circuit<br>0x1: Disables the interface protect circuit | RW   | 0x0   |

## *High-Speed USB Host Subsystem*

[www.ti.com](http://www.ti.com)

| Bits | Field Name          | Description                                                                                                                                                                    | Type | Reset |
|------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 6:5  | RESERVED            | Reserved                                                                                                                                                                       | R    | 0x0   |
| 4    | AUTORESUME          | Enables the PHY to automatically drive resume signaling.<br>On by default.<br><br>0x0: AutoResume disabled<br><br>0x1: AutoResume enabled                                      | RW   | 0x1   |
| 3    | CLOCKSUSPENDDM      | Active low clock suspend for serial modes (6pin/3-pin).<br><br>0x0: ULPI clock will stop during serial modes.<br><br>0x1: ULPI clock will run during serial modes.             | RW   | 0x0   |
| 2    | RESERVED            | Reserved                                                                                                                                                                       | R    | 0x0   |
| 1    | FSLSSERIALMODE_3PIN | Sets the ULPI interface to 3-pin (FS/LS only) Serial Mode. Autocleared when serial mode is exited.<br><br>0x0: ULPI is not in 3-pin mode<br><br>0x1: ULPI in 3-pin serial mode | RW   | 0x0   |
| 0    | FSLSSERIALMODE_6PIN | Sets the ULPI interface to 6-pin (FS/LS only) Serial Mode. Autocleared when serial mode is exited.<br><br>0x0: ULPI is not in 6-pin mode<br><br>0x1: ULPI in 6-pin serial mode | RW   | 0x0   |

**Table 22-89. Register Call Summary for Register ULPI\_INTERFACE\_CTRL\_i**

---

High-Speed USB Host Subsystem

- USBTLL Module Functionality: [0] [1] [2]
  - High-Speed USB Host Subsystem Register Summary: [3]

**Table 22-90. ULPI\_INTERFACE\_CTRL\_SET\_i**

|                           |                                                                                                                                                                                                                   |                     |               |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------|
| <b>Address Offset</b>     | 0x0000 0008 + (0x100 * i)                                                                                                                                                                                         | <b>Index</b>        | i = 0 to 2    |
| <b>Physical Address</b>   | 0x4806 2808 + (0x100 * i)                                                                                                                                                                                         | <b>Instance</b>     | USBTLL        |
| <b>Description</b>        | Enables alternative interfaces and PHY features. Read/set address (write 1 to a bit to set it to 1; writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                     |               |
| <b>Type</b>               | RW                                                                                                                                                                                                                |                     |               |
| 7                         | 6                                                                                                                                                                                                                 | 5                   | 4             |
| INTERFACE_PROTECT_DISABLE | RESERVED                                                                                                                                                                                                          | AUTORESUME          | CLOCKSUSPENDM |
| 3                         | 2                                                                                                                                                                                                                 | 1                   | 0             |
| FSLSSERIALMODE_3PIN       | RESERVED                                                                                                                                                                                                          | FSLSSERIALMODE_6PIN |               |

| Bits | Field Name                | Description                                                                                                                                                                                      | Type | Reset |
|------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7    | INTERFACE_PROTECT_DISABLE | <p>Controls circuitry built into the PHY for protecting the ULPI interface when the link 3-states stp and data.</p> <p>Write 0x0: No effect on bit value</p> <p>Write 0x1: Set the bit to 1.</p> | RW   | 0x0   |
| 6:5  | RESERVED                  | Reserved                                                                                                                                                                                         | R    | 0x0   |

| Bits | Field Name          | Description                                                                                                                                                                     | Type | Reset |
|------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4    | AUTORESUME          | Enables the PHY to automatically drive resume signaling.<br>On by default.<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Set the bit to 1.                         | RW   | 0x0   |
| 3    | CLOCKSUSPENDM       | Active low clock suspend for serial modes (6pin/3-pin).<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Set the bit to 1.                                            | RW   | 0x0   |
| 2    | RESERVED            | Reserved                                                                                                                                                                        | R    | 0x0   |
| 1    | FSLSSERIALMODE_3PIN | Sets the ULPI interface to 3-pin (FS/LS only) Serial Mode. Autocleared when serial mode is exited.<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Set the bit to 1. | RW   | 0x0   |
| 0    | FSLSSERIALMODE_6PIN | Sets the ULPI interface to 6-pin (FS/LS only) Serial Mode. Autocleared when serial mode is exited.<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Set the bit to 1. | RW   | 0x0   |

**Table 22-91. Register Call Summary for Register ULPI\_INTERFACE\_CTRL\_SET\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-92. ULPI\_INTERFACE\_CTRL\_CLR\_i**

| Address Offset   | 0x0000 0009 + (0x100 * i)                                                                                                                                                                                             | Index    | i = 0 to 2 |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|
| Physical Address | 0x4806 2809 + (0x100 * i)                                                                                                                                                                                             | Instance | USBTLL     |
| Description      | Enables alternative interfaces and PHY features. Read/clear address (write 1 to a bit to clear it to 0, writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |          |            |
| Type             | RW                                                                                                                                                                                                                    |          |            |

| 7                         | 6        | 5          | 4             | 3        | 2                   | 1                   | 0 |
|---------------------------|----------|------------|---------------|----------|---------------------|---------------------|---|
| INTERFACE_PROTECT_DISABLE | RESERVED | AUTORESUME | CLOCKSUSPENDM | RESERVED | FSLSSERIALMODE_3PIN | FSLSSERIALMODE_6PIN |   |

| Bits | Field Name                | Description                                                                                                                                                                                | Type | Reset |
|------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7    | INTERFACE_PROTECT_DISABLE | Controls circuitry built into the PHY for protecting the ULPI interface when the link 3-states stp and data.<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Clear the bit to 0 | RW   | 0x0   |
| 6:5  | RESERVED                  | Reserved                                                                                                                                                                                   | R    | 0x0   |

## High-Speed USB Host Subsystem

www.ti.com

| Bits | Field Name          | Description                                                                                                                                                                      | Type | Reset |
|------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4    | AUTORESUME          | Enables the PHY to automatically drive resume signaling.<br>On by default.<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Clear the bit to 0                         | RW   | 0x0   |
| 3    | CLOCKSUSPENDM       | Active low clock suspend for serial modes (6pin/3-pin).<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Clear the bit to 0                                            | RW   | 0x0   |
| 2    | RESERVED            | Reserved                                                                                                                                                                         | R    | 0x0   |
| 1    | FSLSSERIALMODE_3PIN | Sets the ULPI interface to 3-pin (FS/LS only) Serial Mode. Autocleared when serial mode is exited.<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Clear the bit to 0 | RW   | 0x0   |
| 0    | FSLSSERIALMODE_6PIN | Sets the ULPI interface to 6-pin (FS/LS only) Serial Mode. Autocleared when serial mode is exited.<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Clear the bit to 0 | RW   | 0x0   |

**Table 22-93. Register Call Summary for Register ULPI\_INTERFACE\_CTRL\_CLR\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-94. ULPI\_OTG\_CTRL\_i**

|                         |                                                              |                 |            |
|-------------------------|--------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 000A + (0x100 * i)                                    | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 280A + (0x100 * i)                                    | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Controls UTMI+ OTG functions of the PHY. Read/Write address. |                 |            |
| <b>Type</b>             | RW                                                           |                 |            |

| 7        | 6       | 5        | 4 | 3           | 2          | 1          | 0        |
|----------|---------|----------|---|-------------|------------|------------|----------|
| RESERVED | DRVVBUS | CHRGVBUS |   | DISCHRGVBUS | DMPULLDOWN | DPPULLDOWN | IDPULLUP |

| Bits | Field Name  | Description                                                                                                                                 | Type | Reset |
|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:6  | RESERVED    | Reserved                                                                                                                                    | R    | 0x0   |
| 5    | DRVVBUS     | Drive 5 V on VBUS<br><br>0x0: No action<br><br>0x1: Drive VBUS                                                                              | RW   | 0x0   |
| 4    | CHRGVBUS    | Charge VBUS through a resistor for VBUS-pulsing SRP.<br><br>0x0: No action<br><br>0x1: Charge VBUS                                          | RW   | 0x0   |
| 3    | DISCHRGVBUS | Discharge VBUS through a resistor, until the session-end VBUS state is reached.<br><br>0x0: No action<br><br>0x1: Discharge VBUS            | RW   | 0x0   |
| 2    | DMPULLDOWN  | Enables the 15k? pull-down resistor on D-<br><br>0x0: Pull-down resistor not connected to D-<br><br>0x1: Pull-down resistor connected to D- | RW   | 0x1   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                      | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 1           | DPPULLDOWN        | Enables the 15k? pull-down resistor on D+<br><br>0x0: Pull-down resistor not connected to D+<br>0x1: Pull-down resistor connected to D+ | RW          | 0x1          |
| 0           | IDPULLUP          | Pull-up to the (OTG) ID line to allow its sampling<br><br>0x0: Disable sampling of ID line.<br>0x1: Enable sampling of ID line.         | RW          | 0x0          |

**Table 22-95. Register Call Summary for Register ULPI\_OTG\_CTRL\_i**

High-Speed USB Host Subsystem

- [USBTLL Module Functionality: \[0\]](#)
- [High-Speed USB Host Subsystem Register Summary: \[1\]](#)

**Table 22-96. ULPI\_OTG\_CTRL\_SET\_i**

| <b>Address Offset</b>   | 0x0000 000B + (0x100 * i)                                                                                                                                                                                 | <b>Index</b>    | i = 0 to 2  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| <b>Physical Address</b> | 0x4806 280B + (0x100 * i)                                                                                                                                                                                 | <b>Instance</b> | USBTLL      |
| <b>Description</b>      | Controls UTMI+ OTG functions of the PHY. Read/set address (write 1 to a bit to set it to 1; writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |             |
| <b>Type</b>             | RW                                                                                                                                                                                                        |                 |             |
| 7                       | 6                                                                                                                                                                                                         | 5               | 4           |
| RESERVED                | DRVVBUS                                                                                                                                                                                                   | CHRGVBUS        | DISCHRGVBUS |
|                         |                                                                                                                                                                                                           |                 |             |
| 3                       | 2                                                                                                                                                                                                         | 1               | 0           |
| DMPULLDOWN              | DPPULLDOWN                                                                                                                                                                                                | IDPULLUP        |             |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 7:6         | RESERVED          | Reserved                                                                                                                                                 | R           | 0x0          |
| 5           | DRVVBUS           | Drive 5 V on VBUS<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1.                                                               | RW          | 0x0          |
| 4           | CHRGVBUS          | Charge VBUS through a resistor for VBUS-pulsing SRP.<br><br>Write 0x0: No effect on bit value<br>0x1: Set the bit to 1.                                  | RW          | 0x0          |
| 3           | DISCHRGVBUS       | Discharge VBUS through a resistor, until the session-end VBUS state is reached.<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW          | 0x0          |
| 2           | DMPULLDOWN        | Enables the 15k? pull-down resistor on D-<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1.                                       | RW          | 0x0          |
| 1           | DPPULLDOWN        | Enables the 15k? pull-down resistor on D+<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1.                                       | RW          | 0x0          |
| 0           | IDPULLUP          | Pull-up to the (OTG) ID line to allow its sampling<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1.                              | RW          | 0x0          |

**Table 22-97. Register Call Summary for Register ULPI\_OTG\_CTRL\_SET\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-98. ULPI\_OTG\_CTRL\_CLR\_i**

|                         |                                                                                                                                                                                                               |                 |            |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 000C + (0x100 * i)                                                                                                                                                                                     | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 280C + (0x100 * i)                                                                                                                                                                                     | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Controls UTMI+ OTG functions of the PHY. Read/clear address (write 1 to a bit to clear it to 0, writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                            |                 |            |



| Bits | Field Name  | Description                                                                                                                                                   | Type | Reset |
|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:6  | RESERVED    | Reserved                                                                                                                                                      | R    | 0x0   |
| 5    | DRVVBUS     | Drive 5 V on VBUS<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Clear the bit to 0                                                               | RW   | 0x0   |
| 4    | CHRGVBUS    | Charge VBUS through a resistor for VBUS-pulsing SRP.<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Clear the bit to 0                            | RW   | 0x0   |
| 3    | DISCHRGVBUS | Discharge VBUS through a resistor, until the session-end VBUS state is reached.<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Clear the bit to 0 | RW   | 0x0   |
| 2    | DMPULLDOWN  | Enables the 15k? pull-down resistor on D-<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Clear the bit to 0                                       | RW   | 0x0   |
| 1    | DPPULLDOWN  | Enables the 15k? pull-down resistor on D+<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Clear the bit to 0                                       | RW   | 0x0   |
| 0    | IDPULLUP    | Pull-up to the (OTG) ID line to allow its sampling<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Clear the bit to 0                              | RW   | 0x0   |

**Table 22-99. Register Call Summary for Register ULPI\_OTG\_CTRL\_CLR\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-100. ULPI\_USB\_INT\_EN\_RISE\_i**

|                         |                                                                                                                                                                  |                 |            |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 000D + (0x100 * i)                                                                                                                                        | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 280D + (0x100 * i)                                                                                                                                        | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Enables an interrupt event notification when the corresponding status bit changes from low to high. By default, all transitions are enabled. Read/Write address. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                               |                 |            |



| <b>Bits</b> | <b>Field Name</b>   | <b>Description</b>                                                                                                                                                                       | <b>Type</b> | <b>Reset</b> |
|-------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 7:5         | RESERVED            | Reserved                                                                                                                                                                                 | R           | 0x0          |
| 4           | IDGND_RISE          | Generate an interrupt event notification when IdGnd changes from low to high.<br>Event is automatically masked if IdPullup bit is cleared to 0 and for 50 ms after IdPullup is set to 1. | RW          | 0x1          |
| 3           | SESEND_RISE         | Generate an interrupt event notification when SessEnd changes from low to high.                                                                                                          | RW          | 0x1          |
| 2           | SESSVALID_RISE      | Generate an interrupt event notification when SessValid changes from low to high. SessValid is the same as UTMI+ AValid.                                                                 | RW          | 0x1          |
| 1           | VBUSVALID_RISE      | Generate an interrupt event notification when VbusValid changes from low to high.                                                                                                        | RW          | 0x1          |
| 0           | HOSTDISCONNECT_RISE | Generate an interrupt event notification when Hostdisconnect changes from low to high. Applicable only in host mode (DpPulldown and DmPulldown both set to 1b).                          | RW          | 0x1          |

**Table 22-101. Register Call Summary for Register ULPI\_USB\_INT\_EN\_RISE\_i**

High-Speed USB Host Subsystem

- [USBTLL Module Functionality: \[0\]](#)
- [High-Speed USB Host Subsystem Register Summary: \[1\]](#)

**Table 22-102. ULPI\_USB\_INT\_EN\_RISE\_SET\_i**

|                         |                                                                                                                                                                                                                                                                      |                 |            |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 000E + (0x100 * i)                                                                                                                                                                                                                                            | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 280E + (0x100 * i)                                                                                                                                                                                                                                            | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Enables an interrupt event notification when the corresponding status bit changes from low to high. Read/set address (write 1 to a bit to set it to 1; writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                   |                 |            |



| Bits | Field Name          | Description                                                                                                                                                                                                                                                       | Type | Reset |
|------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:5  | RESERVED            | Reserved                                                                                                                                                                                                                                                          | R    | 0x0   |
| 4    | IDGND_RISE          | Generate an interrupt event notification when IdGnd changes from low to high.<br>Event is automatically masked if the IdPullup bit is cleared to 0 and for 50 ms after IdPullup is set to 1.<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW   | 0x0   |
| 3    | SESEND_RISE         | Generate an interrupt event notification when SessEnd changes from low to high.<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1.                                                                                                              | RW   | 0x0   |
| 2    | SESSVALID_RISE      | Generate an interrupt event notification when SessValid changes from low to high. SessValid is the same as UTMI+ AValid.<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1.                                                                     | RW   | 0x0   |
| 1    | VBUSVALID_RISE      | Generate an interrupt event notification when VbusValid changes from low to high.<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1.                                                                                                            | RW   | 0x0   |
| 0    | HOSTDISCONNECT_RISE | Generate an interrupt event notification when Hostdisconnect changes from low to high. Applicable only in host mode (DpPulldown and DmPulldown both set to 1b).<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1.                              | RW   | 0x0   |

**Table 22-103. Register Call Summary for Register ULPI\_USB\_INT\_EN\_RISE\_SET\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-104. ULPI\_USB\_INT\_EN\_RISE\_CLR\_i**

|                         |                                                                                                                                                                                                                                                                          |                 |            |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 000F + (0x100 * i)                                                                                                                                                                                                                                                | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 280F + (0x100 * i)                                                                                                                                                                                                                                                | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Enables an interrupt event notification when the corresponding status bit changes from low to high. Read/clear address (write 1 to a bit to clear it to 0, writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                       |                 |            |



| <b>Bits</b> | <b>Field Name</b>   | <b>Description</b>                                                                                                                                                                                                                                                 | <b>Type</b> | <b>Reset</b> |
|-------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 7:5         | RESERVED            | Reserved                                                                                                                                                                                                                                                           | R           | 0x0          |
| 4           | IDGND_RISE          | Generate an interrupt event notification when IdGnd changes from low to high.<br>Event is automatically masked if the IdPullup bit is cleared to 0 and for 50 ms after IdPullup is set to 1.<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW          | 0x0          |
| 3           | SESEND_RISE         | Generate an interrupt event notification when SessEnd changes from low to high.<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0                                                                                                              | RW          | 0x0          |
| 2           | SESSVALID_RISE      | Generate an interrupt event notification when SessValid changes from low to high. SessValid is the same as UTMI+ AValid.<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0                                                                     | RW          | 0x0          |
| 1           | VBUSVALID_RISE      | Generate an interrupt event notification when VbusValid changes from low to high.<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0                                                                                                            | RW          | 0x0          |
| 0           | HOSTDISCONNECT_RISE | Generate an interrupt event notification when Hostdisconnect changes from low to high. Applicable only in host mode (DpPulldown and DmPulldown both set to 1b).<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0                              | RW          | 0x0          |

**Table 22-105. Register Call Summary for Register ULPI\_USB\_INT\_EN\_RISE\_CLR\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-106. ULPI\_USB\_INT\_EN\_FALL\_i**

|                         |                                                                                                                                                                  |                 |            |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0010 + (0x100 * i)                                                                                                                                        | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2810 + (0x100 * i)                                                                                                                                        | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Enables an interrupt event notification when the corresponding status bit changes from high to low. By default, all transitions are enabled. Read/Write address. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                               |                 |            |

| 7        | 6 | 5          | 4 | 3           | 2              | 1              | 0                   |
|----------|---|------------|---|-------------|----------------|----------------|---------------------|
| RESERVED |   | IDGND_FALL |   | SESEND_FALL | SESSVALID_FALL | VBUSVALID_FALL | HOSTDISCONNECT_FALL |

| Bits | Field Name          | Description                                                                                                                                                                              | Type | Reset |
|------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:5  | RESERVED            | Reserved                                                                                                                                                                                 | R    | 0x0   |
| 4    | IDGND_FALL          | Generate an interrupt event notification when IdGnd changes from high to low.<br>Event is automatically masked if IdPullup bit is cleared to 0 and for 50 ms after IdPullup is set to 1. | RW   | 0x1   |
| 3    | SESEND_FALL         | Generate an interrupt event notification when SessEnd changes from high to low.                                                                                                          | RW   | 0x1   |
| 2    | SESSVALID_FALL      | Generate an interrupt event notification when SessValid changes from high to low. SessValid is the same as UTMI+ AValid.                                                                 | RW   | 0x1   |
| 1    | VBUSVALID_FALL      | Generate an interrupt event notification when VbusValid changes from high to low.                                                                                                        | RW   | 0x1   |
| 0    | HOSTDISCONNECT_FALL | Generate an interrupt event notification when Hostdisconnect changes from high to low. Applicable only in host mode (DpPulldown and DmPulldown both set to 1b).                          | RW   | 0x1   |

**Table 22-107. Register Call Summary for Register ULPI\_USB\_INT\_EN\_FALL\_i**

High-Speed USB Host Subsystem

- [USBTLL Module Functionality: \[0\]](#)
- [High-Speed USB Host Subsystem Register Summary: \[1\]](#)

**Table 22-108. ULPI\_USB\_INT\_EN\_FALL\_SET\_i**

|                         |                                                                                                                                                                                                                                                                      |                 |            |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0011 + (0x100 * i)                                                                                                                                                                                                                                            | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2811 + (0x100 * i)                                                                                                                                                                                                                                            | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Enables an interrupt event notification when the corresponding status bit changes from high to low. Read/set address (write 1 to a bit to set it to 1; writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                   |                 |            |

| 7        | 6 | 5          | 4 | 3           | 2              | 1              | 0                   |
|----------|---|------------|---|-------------|----------------|----------------|---------------------|
| RESERVED |   | IDGND_FALL |   | SESEND_FALL | SESSVALID_FALL | VBUSVALID_FALL | HOSTDISCONNECT_FALL |

| Bits | Field Name          | Description                                                                                                                                                                                                                                                                          | Type | Reset |
|------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:5  | RESERVED            | Reserved                                                                                                                                                                                                                                                                             | R    | 0x0   |
| 4    | IDGND_FALL          | <p>Generate an interrupt event notification when IdGnd changes from high to low.</p> <p>Event is automatically masked if the IdPullup bit is cleared to 0 and for 50 ms after IdPullup is set to 1.</p> <p>Write 0x0: No effect on bit value</p> <p>Write 0x1: Set the bit to 1.</p> | RW   | 0x0   |
| 3    | SESEND_FALL         | <p>Generate an interrupt event notification when SessEnd changes from high to low.</p> <p>Write 0x0: No effect on bit value</p> <p>Write 0x1: Set the bit to 1.</p>                                                                                                                  | RW   | 0x0   |
| 2    | SESSVALID_FALL      | <p>Generate an interrupt event notification when SessValid changes from high to low. SessValid is the same as UTMI+ AValid.</p> <p>Write 0x0: No effect on bit value</p> <p>Write 0x1: Set the bit to 1.</p>                                                                         | RW   | 0x0   |
| 1    | VBUSVALID_FALL      | <p>Generate an interrupt event notification when VbusValid changes from high to low.</p> <p>Write 0x0: No effect on bit value</p> <p>Write 0x1: Set the bit to 1.</p>                                                                                                                | RW   | 0x0   |
| 0    | HOSTDISCONNECT_FALL | <p>Generate an interrupt event notification when Hostdisconnect changes from high to low. Applicable only in host mode (DpPulldown and DmPulldown both set to 1b).</p> <p>Write 0x0: No effect on bit value</p> <p>Write 0x1: Set the bit to 1.</p>                                  | RW   | 0x0   |

**Table 22-109. Register Call Summary for Register ULPI\_USB\_INT\_EN\_FALL\_SET\_i**

## High-Speed USB Host Subsystem

- High-Speed USB Host Subsystem Register Summary: [0]

**Table 22-110. ULPI\_USB\_INT\_EN\_FALL\_CLR\_i**

|                         |                                                                                                                                                                                                                                                                          |                 |                     |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------------------|
| <b>Address Offset</b>   | 0x0000 0012 + (0x100 * i)                                                                                                                                                                                                                                                | <b>Index</b>    | i = 0 to 2          |
| <b>Physical Address</b> | 0x4806 2812 + (0x100 * i)                                                                                                                                                                                                                                                | <b>Instance</b> | USBTLL              |
| <b>Description</b>      | Enables an interrupt event notification when the corresponding status bit changes from high to low. Read/clear address (write 1 to a bit to clear it to 0, writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |                     |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                       |                 |                     |
| 7                       | 6                                                                                                                                                                                                                                                                        | 5               | 4                   |
| RESERVED                | IDGND_FALL                                                                                                                                                                                                                                                               | SESSEND_FALL    | SESSVALID_FALL      |
|                         |                                                                                                                                                                                                                                                                          |                 | \VBUSVALID_FALL     |
|                         |                                                                                                                                                                                                                                                                          |                 | HOSTDISCONNECT_FALL |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 7:5         | RESERVED          | Reserved                                                                                                                                                                                                                                                           | R           | 0x0          |
| 4           | IDGND_FALL        | Generate an interrupt event notification when IdGnd changes from high to low.<br>Event is automatically masked if the IdPullup bit is cleared to 0 and for 50 ms after IdPullup is set to 1.<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW          | 0x0          |

## High-Speed USB Host Subsystem

www.ti.com

| Bits | Field Name          | Description                                                                                                                                                                                                                           | Type | Reset |
|------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3    | SESEND_FALL         | Generate an interrupt event notification when SessEnd changes from high to low.<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0                                                                                 | RW   | 0x0   |
| 2    | SESSVALID_FALL      | Generate an interrupt event notification when SessValid changes from high to low. SessValid is the same as UTMI+ AValid.<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0                                        | RW   | 0x0   |
| 1    | VBUSVALID_FALL      | Generate an interrupt event notification when VbusValid changes from high to low.<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0                                                                               | RW   | 0x0   |
| 0    | HOSTDISCONNECT_FALL | Generate an interrupt event notification when Hostdisconnect changes from high to low. Applicable only in host mode (DpPulldown and DmPulldown both set to 1b).<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW   | 0x0   |

**Table 22-111. Register Call Summary for Register ULPI\_USB\_INT\_EN\_FALL\_CLR\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-112. ULPI\_USB\_INT\_STATUS\_i**

|                         |                                                             |                 |            |
|-------------------------|-------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0013 + (0x100 * i)                                   | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2813 + (0x100 * i)                                   | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Indicates the current value of the interrupt source signal. |                 |            |
| <b>Type</b>             | R                                                           |                 |            |

| 7 | 6 | 5        | 4     | 3      | 2         | 1         | 0              |
|---|---|----------|-------|--------|-----------|-----------|----------------|
|   |   | RESERVED | IDGND | SESEND | SESSVALID | VBUSVALID | HOSTDISCONNECT |

| Bits | Field Name | Description                                                                                                                                                                 | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:5  | RESERVED   | Reserved                                                                                                                                                                    | R    | 0x0   |
| 4    | IDGND      | Value of UTMI+ IdDig output. Undefined unless IdPullup = 1<br>0x0: ID pin is grounded = OTG A = default Host<br>0x1: ID pin is floating = OTG B = default Peripheral        | R    | 0x0   |
| 3    | SESEND     | Current value of UTMI+ SessEnd output.<br>0x0: VBUS is above Session-End threshold<br>0x1: VBUS is below Session-End threshold                                              | R    | 0x0   |
| 2    | SESSVALID  | Current value of UTMI+ SessValid output. SessValid is the same as UTMI+ AValid.<br>0x0: VBUS is below Session-Valid threshold<br>0x1: VBUS is above Session-Valid threshold | R    | 0x0   |

| Bits | Field Name     | Description                                                                                                                                                                                                                  | Type | Reset |
|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | VBUSVALID      | Current value of UTMI+ VbusValid output.<br>0x0: VBUS is below Vbus-Valid threshold<br>0x1: VBUS is above Vbus-Valid threshold                                                                                               | R    | 0x0   |
| 0    | HOSTDISCONNECT | Current value of UTMI+ Hostdisconnect output.<br>Applicable only in host mode. Automatically reset to 0 when Low Power Mode is entered.<br>0x0: Peripheral not disconnected or non-host mode<br>0x1: Peripheral disconnected | R    | 0x0   |

**Table 22-113. Register Call Summary for Register ULPI\_USB\_INT\_STATUS\_i**

High-Speed USB Host Subsystem

- [USBTLL Module Functionality: \[0\]](#)
- [High-Speed USB Host Subsystem Register Summary: \[1\]](#)

**Table 22-114. ULPI\_USB\_INT\_LATCH\_i**

| Address Offset   | 0x0000 0014 + (0x100 * i)                                                                                                                                                    | Index    | i = 0 to 2 |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|
| Physical Address | 0x4806 2814 + (0x100 * i)                                                                                                                                                    | Instance | USBTLL     |
| Description      | Set by unmasked changes on the corresponding status bits to generate the ULPI interrupt. Cleared upon read, and when Low Power Mode, Serial Mode or Carkit Mode are entered. |          |            |
| Type             | R                                                                                                                                                                            |          |            |



| Bits | Field Name           | Description                                                                                                                                | Type | Reset |
|------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:5  | RESERVED             | Reserved                                                                                                                                   | R    | 0x0   |
| 4    | IDGND_LATCH          | Set to 1 by the PHY when an unmasked event occurs on IdGnd. Cleared when this register is read.                                            | R    | 0x0   |
| 3    | SESEND_LATCH         | Set to 1 by the PHY when an unmasked event occurs on SessEnd. Cleared when this register is read.                                          | R    | 0x0   |
| 2    | SESSVALID_LATCH      | Set to 1 by the PHY when an unmasked event occurs on SessValid. Cleared when this register is read. SessValid is the same as UTMI+ AValid. | R    | 0x0   |
| 1    | VBUSVALID_LATCH      | Set to 1 by the PHY when an unmasked event occurs on VbusValid. Cleared when this register is read.                                        | R    | 0x0   |
| 0    | HOSTDISCONNECT_LATCH | Set to 1 by the PHY when an unmasked event occurs on Hostdisconnect. Cleared when this register is read.<br>Applicable only in host mode.  | R    | 0x0   |

**Table 22-115. Register Call Summary for Register ULPI\_USB\_INT\_LATCH\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-116. ULPI\_DEBUG\_i**

| <b>Address Offset</b>   | 0x0000 0015 + (0x100 * i)                                            | <b>Index</b>                                                                                                                                                                                                                                                                                                                                                | i = 0 to 2 |       |
|-------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------|
| <b>Physical Address</b> | 0x4806 2815 + (0x100 * i)                                            | <b>Instance</b>                                                                                                                                                                                                                                                                                                                                             | USBTLL     |       |
| <b>Description</b>      | Indicates the current value of various signals useful for debugging. |                                                                                                                                                                                                                                                                                                                                                             |            |       |
| <b>Type</b>             | R                                                                    |                                                                                                                                                                                                                                                                                                                                                             |            |       |
| 7 6 5 4 3 2 1 0         |                                                                      |                                                                                                                                                                                                                                                                                                                                                             |            |       |
| RESERVED                |                                                                      |                                                                                                                                                                                                                                                                                                                                                             | LINESTATE  |       |
| <hr/>                   |                                                                      |                                                                                                                                                                                                                                                                                                                                                             |            |       |
| Bits                    | Field Name                                                           | Description                                                                                                                                                                                                                                                                                                                                                 | Type       | Reset |
| 7:2                     | RESERVED                                                             | Reserved                                                                                                                                                                                                                                                                                                                                                    | R          | 0x00  |
| 1:0                     | LINESTATE                                                            | Current state of the USB line: D+ (bit 0) and D- (bit 1).<br>0x0: SE0 (LS/FS), Squelch (HS/Chirp)<br>0x1: LS: 'K' State, FS: 'J' State, HS: !Squelch,<br>Chirp: !Squelch & HS_Differential_Receiver_Output<br>0x2: LS: 'J' State, FS: 'K' State, HS: Invalid,<br>Chirp: !Squelch & !HS_Differential_Receiver_Output<br>0x3: SE1 (LS/FS), Invalid (HS/Chirp) | R          | 0x0   |

**Table 22-117. Register Call Summary for Register ULPI\_DEBUG\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- 

**Table 22-118. ULPI\_SCRATCH\_REGISTER\_i**

| <b>Address Offset</b>   | 0x0000 0016 + (0x100 * i)                                                                                      | <b>Index</b>    | i = 0 to 2 |       |
|-------------------------|----------------------------------------------------------------------------------------------------------------|-----------------|------------|-------|
| <b>Physical Address</b> | 0x4806 2816 + (0x100 * i)                                                                                      | <b>Instance</b> | USBTLL     |       |
| <b>Description</b>      | Register byte for register access testing purposes. Value has no functional effect on PHY. Read/Write address. |                 |            |       |
| <b>Type</b>             | RW                                                                                                             |                 |            |       |
| 7 6 5 4 3 2 1 0         |                                                                                                                |                 |            |       |
| SCRATCH                 |                                                                                                                |                 |            |       |
| <hr/>                   |                                                                                                                |                 |            |       |
| Bits                    | Field Name                                                                                                     | Description     | Type       | Reset |
| 7:0                     | SCRATCH                                                                                                        | Scratch data.   | RW         | 0x00  |

**Table 22-119. Register Call Summary for Register ULPI\_SCRATCH\_REGISTER\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
-

**Table 22-120. ULPI\_SCRATCH\_REGISTER\_SET\_i**

|                         |                                                                                                                                                                                                                                                             |                 |            |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|--|--|--|
| <b>Address Offset</b>   | 0x0000 0017 + (0x100 * i)                                                                                                                                                                                                                                   | <b>Index</b>    | i = 0 to 2 |  |  |  |
| <b>Physical Address</b> | 0x4806 2817 + (0x100 * i)                                                                                                                                                                                                                                   | <b>Instance</b> | USBTLL     |  |  |  |
| <b>Description</b>      | Register byte for register access testing purposes. Value has no functional effect on PHY. Read/set address (write 1 to a bit to set it to 1; writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |            |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                          |                 |            |  |  |  |
| 7 6 5 4 3 2 1 0         |                                                                                                                                                                                                                                                             |                 |            |  |  |  |
| SCRATCH                 |                                                                                                                                                                                                                                                             |                 |            |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                      | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------|-------------|--------------|
| 7:0         | SCRATCH           | Scratch data<br>write 1 to a bit to set it to 1<br>writing 0 has no effect on bit value | RW          | 0x00         |

**Table 22-121. Register Call Summary for Register ULPI\_SCRATCH\_REGISTER\_SET\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-122. ULPI\_SCRATCH\_REGISTER\_CLR\_i**

| <b>Address Offset</b>   | 0x0000 0018 + (0x100 * i)                                                                                                                                                                                                                                       | <b>Index</b>                                                                              | i = 0 to 2  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|-------------|--|--|--|
| <b>Physical Address</b> | 0x4806 2818 + (0x100 * i)                                                                                                                                                                                                                                       | <b>Instance</b>                                                                           | USBTLL      |  |  |  |
| <b>Description</b>      | Register byte for register access testing purposes. Value has no functional effect on PHY. Read/clear address (write 1 to a bit to clear it to 0, writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                                                                                           |             |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                              |                                                                                           |             |  |  |  |
| 7 6 5 4 3 2 1 0         |                                                                                                                                                                                                                                                                 |                                                                                           |             |  |  |  |
| SCRATCH                 |                                                                                                                                                                                                                                                                 |                                                                                           |             |  |  |  |
| <b>Bits</b>             | <b>Field Name</b>                                                                                                                                                                                                                                               | <b>Description</b>                                                                        | <b>Type</b> |  |  |  |
| 7:0                     | SCRATCH                                                                                                                                                                                                                                                         | Scratch data<br>write 1 to a bit to clear it to 0<br>writing 0 has no effect on bit value | RW          |  |  |  |

**Table 22-123. Register Call Summary for Register ULPI\_SCRATCH\_REGISTER\_CLR\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-124. ULPI\_EXTENDED\_SET\_ACCESS\_i**

|                         |                                                                                          |                 |            |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------|-----------------|------------|--|--|--|
| <b>Address Offset</b>   | 0x0000 002F + (0x100 * i)                                                                | <b>Index</b>    | i = 0 to 2 |  |  |  |
| <b>Physical Address</b> | 0x4806 282F + (0x100 * i)                                                                | <b>Instance</b> | USBTLL     |  |  |  |
| <b>Description</b>      | This address is used to access the extended register set, that is, addresses above 0x40. |                 |            |  |  |  |
| <b>Type</b>             | UNDEFINED_TYPE_STRING                                                                    |                 |            |  |  |  |
| 7 6 5 4 3 2 1 0         |                                                                                          |                 |            |  |  |  |
| SET_ACCESS              |                                                                                          |                 |            |  |  |  |

| Bits | Field Name | Description                                                                               | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------|------|-------|
| 7:0  | SET_ACCESS | This bitfield is used to access the extended register set, that is, addresses above 0x40. | RW   | 0x00  |

**Table 22-125. Register Call Summary for Register ULPI\_EXTENDED\_SET\_ACCESS\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-126. ULPI\_UTMI\_VCONTROL\_EN\_i**

|                         |                                                                                                                                                                                                                                                                                                                                  |                 |            |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0030 + (0x100 * i)                                                                                                                                                                                                                                                                                                        | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2830 + (0x100 * i)                                                                                                                                                                                                                                                                                                        | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Part of non-standard UTMI-to-ULPI mailbox system, implemented if HDL generic VCS_MAILBOX bit is 1. Enables an interrupt notification when the corresponding vcontrol_status bit changes. Read/Write address. Lowest VCS_CTRL_WIDTH (HDL generic) bits are implemented, others are always-0, read-only. (UTMI standard is 4-bit). |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                               |                 |            |

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| VC7_EN | VC6_EN | VC5_EN | VC4_EN | VC3_EN | VC2_EN | VC1_EN | VC0_EN |

| Bits | Field Name | Description                                              | Type | Reset |
|------|------------|----------------------------------------------------------|------|-------|
| 7    | VC7_EN     | Enable alt_int assertion upon vcontrol_status bit change | RW   | 0x0   |
| 6    | VC6_EN     | Enable alt_int assertion upon vcontrol_status bit change | RW   | 0x0   |
| 5    | VC5_EN     | Enable alt_int assertion upon vcontrol_status bit change | RW   | 0x0   |
| 4    | VC4_EN     | Enable alt_int assertion upon vcontrol_status bit change | RW   | 0x0   |
| 3    | VC3_EN     | Enable alt_int assertion upon vcontrol_status bit change | RW   | 0x0   |
| 2    | VC2_EN     | Enable alt_int assertion upon vcontrol_status bit change | RW   | 0x0   |
| 1    | VC1_EN     | Enable alt_int assertion upon vcontrol_status bit change | RW   | 0x0   |
| 0    | VC0_EN     | Enable alt_int assertion upon vcontrol_status bit change | RW   | 0x0   |

**Table 22-127. Register Call Summary for Register ULPI\_UTMI\_VCONTROL\_EN\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-128. ULPI\_UTMI\_VCONTROL\_EN\_SET\_i**

|                         |                                                                                                                                                                                                                                                                                                                                                           |                 |            |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0031 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                 | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2831 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                 | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Part of non-standard UTMI-to-ULPI mailbox system, implemented if HDL generic VCS_MAILBOX bit is 1. Enables an interrupt notification when the corresponding vcontrol_status bit changes. Read/set address (write 1 to a bit to set it to 1; writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                        |                 |            |

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| VC7_EN | VC6_EN | VC5_EN | VC4_EN | VC3_EN | VC2_EN | VC1_EN | VC0_EN |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                            | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 7           | VC7_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW          | 0x0          |
| 6           | VC6_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW          | 0x0          |
| 5           | VC5_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW          | 0x0          |
| 4           | VC4_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW          | 0x0          |
| 3           | VC3_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW          | 0x0          |
| 2           | VC2_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW          | 0x0          |
| 1           | VC1_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW          | 0x0          |
| 0           | VC0_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW          | 0x0          |

**Table 22-129. Register Call Summary for Register ULPI\_UTMI\_VCONTROL\_EN\_SET\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-130. ULPI\_UTMI\_VCONTROL\_EN\_CLR\_i**

|                         |                                                                                                                                                                                                                                                                                                                                                                 |                 |            |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0032 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                       | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2832 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                       | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Part of non-standard UTMI-to-ULPI mailbox system, implemented if HDL generic VCS_MAILBOX bit is 1<br>Enables an interrupt notification when the corresponding vcontrol_status bit changes. Read/clear address (write 1 to a bit to clear it to 0, writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                              |                 |            |

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| VC7_EN | VC6_EN | VC5_EN | VC4_EN | VC3_EN | VC2_EN | VC1_EN | VC0_EN |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                             | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 7           | VC7_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW          | 0x0          |
| 6           | VC6_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW          | 0x0          |
| 5           | VC5_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW          | 0x0          |
| 4           | VC4_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW          | 0x0          |
| 3           | VC3_EN            | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW          | 0x0          |

## High-Speed USB Host Subsystem

www.ti.com

| Bits | Field Name | Description                                                                                                                    | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 2    | VC2_EN     | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW   | 0x0   |
| 1    | VC1_EN     | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW   | 0x0   |
| 0    | VC0_EN     | Enable alt_int assertion upon vcontrol_status bit change<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW   | 0x0   |

**Table 22-131. Register Call Summary for Register ULPI\_UTMI\_VCONTROL\_EN\_CLR\_i**

## High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-132. ULPI\_UTMI\_VCONTROL\_STATUS\_i**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                 |            |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0033 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2833 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Part of non-standard UTMI-to-ULPI mailbox system, implemented if HDL generic VCS_MAILBOX bit is 1<br>UTMI-standard Vcontrol vector byte is sent by the UTMI controller (other side of TLL) to its PHY<br>(emulated here by the TLL). Alternatively, data can be also written directly into the register. Can contain any user-defined data. Vcontrol bit changes can be used to assert the ULPI ALT interrupt. Lowest VCS_CTRL_WIDTH (HDL generic) bits are implemented, others are always-0, read-only. (UTMI standard is 4-bit). |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |            |

  

|    |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|
| 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| VC |   |   |   |   |   |   |   |

| Bits | Field Name | Description                         | Type | Reset |
|------|------------|-------------------------------------|------|-------|
| 7:0  | VC         | User-defined UTMI Control data byte | RW   | 0x00  |

**Table 22-133. Register Call Summary for Register ULPI\_UTMI\_VCONTROL\_STATUS\_i**

## High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-134. ULPI\_UTMI\_VCONTROL\_LATCH\_i**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                       |                 |            |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0034 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                                                                             | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2834 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                                                                             | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Part of non-standard UTMI-to-ULPI mailbox system, implemented if HDL generic VCS_MAILBOX bit is 1<br>Set by unmasked changes on the corresponding vcontrol_status bits to generate the ULPI ALT interrupt.<br>Cleared upon read, and when Low Power Mode, Serial Mode or Carkit Mode are entered. Lowest VCS_CTRL_WIDTH (HDL generic) bits are implemented, others are always-0, read-only. (UTMI standard is 4-bit). |                 |            |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |            |

  

|            |            |            |            |            |            |            |            |
|------------|------------|------------|------------|------------|------------|------------|------------|
| 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          |
| VC7_CHANGE | VC6_CHANGE | VC5_CHANGE | VC4_CHANGE | VC3_CHANGE | VC2_CHANGE | VC1_CHANGE | VC0_CHANGE |

| Bits | Field Name | Description                            | Type | Reset |
|------|------------|----------------------------------------|------|-------|
| 7    | VC7_CHANGE | Unmasked change on vcontrol_status bit | R    | 0x0   |
| 6    | VC6_CHANGE | Unmasked change on vcontrol_status bit | R    | 0x0   |
| 5    | VC5_CHANGE | Unmasked change on vcontrol_status bit | R    | 0x0   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------|-------------|--------------|
| 4           | VC4_CHANGE        | Unmasked change on vcontrol_status bit | R           | 0x0          |
| 3           | VC3_CHANGE        | Unmasked change on vcontrol_status bit | R           | 0x0          |
| 2           | VC2_CHANGE        | Unmasked change on vcontrol_status bit | R           | 0x0          |
| 1           | VC1_CHANGE        | Unmasked change on vcontrol_status bit | R           | 0x0          |
| 0           | VC0_CHANGE        | Unmasked change on vcontrol_status bit | R           | 0x0          |

**Table 22-135. Register Call Summary for Register ULPI\_UTMI\_VCONTROL\_LATCH\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-136. ULPI\_UTMI\_VSTATUS\_i**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                 |            |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0035 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2835 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Part of non-standard UTMI-to-ULPI mailbox system, implemented if HDL generic VCS_MAILBOX bit is 1. UTMI-standard Vstatus vector byte is sent by the PHY (emulated here by the TLL) to the UTMI controller (other side of TLL): Information written into this register will go directly to the UTMI controller, and can contain any user-defined data. Read/Write address. Lowest VCS_STAT_WIDTH (HDL generic) bits are implemented, others are always-0, read-only. (UTMI standard is 8-bit). |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                 |            |

|    |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|
| 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| VS |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------|-------------|--------------|
| 7:0         | VS                | User-defined UTMI Status data byte | RW          | 0x00         |

**Table 22-137. Register Call Summary for Register ULPI\_UTMI\_VSTATUS\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-138. ULPI\_UTMI\_VSTATUS\_SET\_i**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |            |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0036 + (0x100* i)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 2836 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Part of non-standard UTMI-to-ULPI mailbox system, implemented if HDL generic VCS_MAILBOX bit is 1. UTMI-standard Vstatus vector byte is sent by the PHY (emulated here by the TLL) to the UTMI controller (other side of TLL): Information written into this register will go directly to the UTMI controller, and can contain any user-defined data. Read/set address (write 1 to a bit to set it to 1; writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |            |

|    |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|
| 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| VS |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                      | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------|-------------|--------------|
| 7:0         | VS                | User-defined UTMI status data byte<br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW          | 0x00         |

**Table 22-139. Register Call Summary for Register ULPI\_UTMI\_VSTATUS\_SET\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-140. ULPI\_UTMI\_VSTATUS\_CLR\_i**

| <b>Address Offset</b>   | 0x0000 0037 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <b>Index</b>                                                                                             | i = 0 to 2 |       |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|------------|-------|
| <b>Physical Address</b> | 0x4806 2837 + (0x100 * i)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <b>Instance</b>                                                                                          | USBTLL     |       |
| <b>Description</b>      | Part of non-standard UTMI-to-ULPI mailbox system, implemented if HDL generic VCS_MAILBOX bit is 1. UTMI-standard Vstatus vector byte is sent by the PHY (emulated here by the TLL) to the UTMI controller (other side of TLL). Information written into this register will go directly to the UTMI controller, and can contain any user-defined data. Read/clear address (write 1 to a bit to clear it to 0, writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                                                                                                          |            |       |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                          |            |       |
| 7                       | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 5                                                                                                        | 4          |       |
|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                          | 3          |       |
|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                          | 2          |       |
|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                          | 1          |       |
|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                          | 0          |       |
| VS                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                          |            |       |
| Bits                    | Field Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Description                                                                                              | Type       | Reset |
| 7:0                     | VS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | User-defined UTMI status data byte<br>Write 0x0: No effect on bit value<br>Write 0x1: Clear the bit to 0 | RW         | 0x00  |

**Table 22-141. Register Call Summary for Register ULPI\_UTMI\_VSTATUS\_CLR\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-142. ULPI\_USB\_INT\_LATCH\_NOCLR\_i**

|                                                                                         |                                                                                                                                                                                                                                                             |                                                               |            |     |
|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|------------|-----|
| <b>Address Offset</b>                                                                   | 0x0000 0038 + (0x100 * i)                                                                                                                                                                                                                                   | <b>Index</b>                                                  | i = 0 to 2 |     |
| <b>Physical Address</b>                                                                 | 0x4806 2838 + (0x100 * i)                                                                                                                                                                                                                                   | <b>Instance</b>                                               | USBTLL     |     |
| <b>Description</b>                                                                      | Set by unmasked changes on the corresponding status bits to generate the ULPI interrupt. Debug, non-standard address to the standard register: Register is not cleared on read. See fields description at the "clear-on-read" address of the same register. |                                                               |            |     |
| <b>Type</b>                                                                             | UNDEFINED_TYPE_STRING                                                                                                                                                                                                                                       |                                                               |            |     |
| 7                                                                                       | 6                                                                                                                                                                                                                                                           | 5                                                             | 4          |     |
|                                                                                         |                                                                                                                                                                                                                                                             |                                                               | 3          |     |
|                                                                                         |                                                                                                                                                                                                                                                             |                                                               | 2          |     |
|                                                                                         |                                                                                                                                                                                                                                                             |                                                               | 1          |     |
|                                                                                         |                                                                                                                                                                                                                                                             |                                                               | 0          |     |
| RESERVED IDGND_LATCH SESSEND_LATCH SESSVALID_LATCH VBUSVALID_LATCH HOSTDISCONNECT_LATCH |                                                                                                                                                                                                                                                             |                                                               |            |     |
| 7:5                                                                                     | RESERVED                                                                                                                                                                                                                                                    | Reserved                                                      | R          | 0x0 |
| 4                                                                                       | IDGND_LATCH                                                                                                                                                                                                                                                 | Set to 1 by the PHY when an unmasked event occurs on IdGnd.   | R          | 0x0 |
| 3                                                                                       | SESEND_LATCH                                                                                                                                                                                                                                                | Set to 1 by the PHY when an unmasked event occurs on SessEnd. | R          | 0x0 |

| Bits | Field Name   | Description                                                   | Type | Reset |
|------|--------------|---------------------------------------------------------------|------|-------|
| 7:5  | RESERVED     | Reserved                                                      | R    | 0x0   |
| 4    | IDGND_LATCH  | Set to 1 by the PHY when an unmasked event occurs on IdGnd.   | R    | 0x0   |
| 3    | SESEND_LATCH | Set to 1 by the PHY when an unmasked event occurs on SessEnd. | R    | 0x0   |

| <b>Bits</b> | <b>Field Name</b>    | <b>Description</b>                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|----------------------|--------------------------------------------------------------------------------------------------------|-------------|--------------|
| 2           | SESSVALID_LATCH      | Set to 1 by the PHY when an unmasked event occurs on SessValid. SessValid is the same as UTMI+ AValid. | R           | 0x0          |
| 1           | VBUSVALID_LATCH      | Set to 1 by the PHY when an unmasked event occurs on VbusValid.                                        | R           | 0x0          |
| 0           | HOSTDISCONNECT_LATCH | Set to 1 by the PHY when an unmasked event occurs on Hostdisconnect. Applicable only in host mode.     | R           | 0x0          |

**Table 22-143. Register Call Summary for Register ULPI\_USB\_INT\_LATCH\_NOCLR\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-144. ULPI\_VENDOR\_INT\_EN\_i**

|                         |                                                                                                     |                 |            |
|-------------------------|-----------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 003B + (0x100 * i)                                                                           | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 283B + (0x100 * i)                                                                           | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Vendor-specific interrupt enables (mask) for miscellaneous ULPI alt_int events. Read/Write address. |                 |            |
| <b>Type</b>             | RW                                                                                                  |                 |            |

|          |   |   |   |   |   |   |        |
|----------|---|---|---|---|---|---|--------|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
| RESERVED |   |   |   |   |   |   | P2P_EN |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 7:1         | RESERVED          | Reserved                                                                                                                            | R           | 0x00         |
| 0           | P2P_EN            | Enable PHY-to-PHY ULPI wakeup upon inactive UTMI suspenddm.<br><br>0x0: PHY-to-PHY wakeup enabled<br>0x1: PHY-to-PHY wakeup enabled | RW          | 0x0          |

**Table 22-145. Register Call Summary for Register ULPI\_VENDOR\_INT\_EN\_i**

High-Speed USB Host Subsystem

- [USBTLL Module Functionality: \[0\]](#)
- [High-Speed USB Host Subsystem Register Summary: \[1\]](#)

**Table 22-146. ULPI\_VENDOR\_INT\_EN\_SET\_i**

|                         |                                                                                                                                                                                                                                                     |                 |            |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 003C + (0x100 * i)                                                                                                                                                                                                                           | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 283C + (0x100 * i)                                                                                                                                                                                                                           | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Vendor-specific interrupt enable bit (mask) for miscellaneous ULPI alt_int events. Read/set address (write 1 to a bit to set it to 1; writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                  |                 |            |

|          |   |   |   |   |   |   |        |
|----------|---|---|---|---|---|---|--------|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
| RESERVED |   |   |   |   |   |   | P2P_EN |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 7:1         | RESERVED          | Reserved                                                                                                                             | R           | 0x00         |
| 0           | P2P_EN            | Enable PHY-to-PHY ULPI wakeup upon inactive UTMI suspenddm.<br><br>Write 0x0: No effect on bit value<br>Write 0x1: Set the bit to 1. | RW          | 0x0          |

**Table 22-147. Register Call Summary for Register ULPI\_VENDOR\_INT\_EN\_SET\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-148. ULPI\_VENDOR\_INT\_EN\_CLR\_i**

|                         |                                                                                                                                                                                                                                                      |                 |            |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 003D + (0x100 * i)                                                                                                                                                                                                                            | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 283D + (0x100 * i)                                                                                                                                                                                                                            | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Vendor-specific interrupt enables (mask) for miscellaneous ULPI alt_int events. Read/clear address (write 1 to a bit to clear it to 0, writing 0 has no effect on bit value). See fields description at the read/write address of the same register. |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                   |                 |            |

| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|----------|---|---|---|---|---|---|--------|
| RESERVED |   |   |   |   |   |   | P2P_EN |

| Bits | Field Name | Description                                                                                                                               | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:1  | RESERVED   | Reserved                                                                                                                                  | R    | 0x00  |
| 0    | P2P_EN     | Enable PHY-to-PHY ULPI wakeup upon inactive UTMI suspenddm.<br><br>Write 0x0: No effect on bit value<br><br>Write 0x1: Clear the bit to 0 | RW   | 0x0   |

**Table 22-149. Register Call Summary for Register ULPI\_VENDOR\_INT\_EN\_CLR\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-150. ULPI\_VENDOR\_INT\_STATUS\_i**

|                         |                                                                          |                 |            |
|-------------------------|--------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 003E + (0x100 * i)                                                | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 283E + (0x100 * i)                                                | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Vendor-specific interrupt sources for miscellaneous ULPI alt_int events. |                 |            |
| <b>Type</b>             | R                                                                        |                 |            |

| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0              |
|----------|---|---|---|---|---|---|----------------|
| RESERVED |   |   |   |   |   |   | UTMI_SUSPENDDM |

| Bits | Field Name     | Description                                                                                                                                                             | Type | Reset |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:1  | RESERVED       | Reserved                                                                                                                                                                | R    | 0x00  |
| 0    | UTMI_SUSPENDDM | UTMI suspenddm status (active-low), source of TLL PHY-to-PHY wakeup interrupt.<br><br>0x0: UTMI interface is suspended<br>0x1: UTMI interface is active (not suspended) | R    | 0x1   |

**Table 22-151. Register Call Summary for Register ULPI\_VENDOR\_INT\_STATUS\_i**

High-Speed USB Host Subsystem

- [USBTLL Module Functionality: \[0\]](#)
- [High-Speed USB Host Subsystem Register Summary: \[1\]](#)

**Table 22-152. ULPI\_VENDOR\_INT\_LATCH\_i**

|                         |                                                                                                                                                              |                 |            |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 003F + (0x100 * i)                                                                                                                                    | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 283F + (0x100 * i)                                                                                                                                    | <b>Instance</b> | USBTLL     |
| <b>Description</b>      | Vendor-specific interrupt latches for miscellaneous ULPI alt_int events. Cleared upon read, and when Low Power Mode, Serial Mode or Carkit Mode are entered. |                 |            |
| <b>Type</b>             | R                                                                                                                                                            |                 |            |

| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|----------|---|---|---|---|---|---|-----------|
| RESERVED |   |   |   |   |   |   | P2P_LATCH |

| Bits | Field Name | Description                                                                                                                                                                                                                                   | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:1  | RESERVED   | Reserved                                                                                                                                                                                                                                      | R    | 0x00  |
| 0    | P2P_LATCH  | PHY-to-PHY ULPI wakeup event latch. Set when ULPI is in low-power mode (suspendm = 0) and UTMI is active (suspendm = 1).<br><br>0x0: No PHY-to-PHY wakeup event latched<br><br>0x1: PHY-to-PHY wakeup event was latched, ALT interrupt active | R    | 0x0   |

**Table 22-153. Register Call Summary for Register ULPI\_VENDOR\_INT\_LATCH\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

#### 22.2.6.4.2 UHH\_config Registers

**Table 22-154. UHH\_REVISION**

|                         |                                                              |                         |                 |                 |            |         |
|-------------------------|--------------------------------------------------------------|-------------------------|-----------------|-----------------|------------|---------|
| <b>Address Offset</b>   | 0x0000 0000                                                  | <b>Physical Address</b> | 0x4806 4000     | <b>Instance</b> | UHH_config |         |
| <b>Description</b>      | Standard revision number, BCD encoded Revision = <maj>.<min> |                         |                 |                 |            |         |
| <b>Type</b>             | R                                                            |                         |                 |                 |            |         |
| 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 | RESERVED        | MAJ_REV    | MIN_REV |

| Bits | Field Name | Description                | Type | Reset     |
|------|------------|----------------------------|------|-----------|
| 31:8 | RESERVED   | Reserved                   | R    | 0x0000000 |
| 7:4  | MAJ_REV    | Major revision number 0..9 | R    | 0x1       |
| 3:0  | MIN_REV    | Minor revision number 0..9 | R    | 0x0       |

**Table 22-155. Register Call Summary for Register UHH\_REVISION**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-156. UHH\_SYSCONFIG**

| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0000 0010                            | <b>Instance</b>                                                                                                                                                                                                                                                                                               | UHH_config |         |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------|----|----|----|----|----|----|----|----|----|----|----|-----------|----------|---------------|----------|-----------|-----------|-----------|----------|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------|----------|---------------|----------|-----------|-----------|-----------|----------|
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x4806 4010                            |                                                                                                                                                                                                                                                                                                               |            |         |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Standard system configuration register |                                                                                                                                                                                                                                                                                                               |            |         |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW                                     |                                                                                                                                                                                                                                                                                                               |            |         |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <tr> <td style="text-align: center; width: 25px;">31</td><td style="text-align: center; width: 25px;">30</td><td style="text-align: center; width: 25px;">29</td><td style="text-align: center; width: 25px;">28</td><td style="text-align: center; width: 25px;">27</td><td style="text-align: center; width: 25px;">26</td><td style="text-align: center; width: 25px;">25</td><td style="text-align: center; width: 25px;">24</td><td style="text-align: center; width: 25px;">23</td><td style="text-align: center; width: 25px;">22</td><td style="text-align: center; width: 25px;">21</td><td style="text-align: center; width: 25px;">20</td><td style="text-align: center; width: 25px;">19</td><td style="text-align: center; width: 25px;">18</td><td style="text-align: center; width: 25px;">17</td><td style="text-align: center; width: 25px;">16</td><td style="text-align: center; width: 25px;">15</td><td style="text-align: center; width: 25px;">14</td><td style="text-align: center; width: 25px;">13</td><td style="text-align: center; width: 25px;">12</td><td style="text-align: center; width: 25px;">11</td><td style="text-align: center; width: 25px;">10</td><td style="text-align: center; width: 25px;">9</td><td style="text-align: center; width: 25px;">8</td><td style="text-align: center; width: 25px;">7</td><td style="text-align: center; width: 25px;">6</td><td style="text-align: center; width: 25px;">5</td><td style="text-align: center; width: 25px;">4</td><td style="text-align: center; width: 25px;">3</td><td style="text-align: center; width: 25px;">2</td><td style="text-align: center; width: 25px;">1</td><td style="text-align: center; width: 25px;">0</td></tr> <tr> <td colspan="16" style="text-align: center; padding-top: 10px;">RESERVED</td><td style="text-align: center;">MIDLEMODE</td><td style="text-align: center;">RESERVED</td><td style="text-align: center;">CLOCKACTIVITY</td><td style="text-align: center;">RESERVED</td><td style="text-align: center;">SIDLEMODE</td><td style="text-align: center;">ENAWAKEUP</td><td style="text-align: center;">SOFTRESET</td><td style="text-align: center;">AUTOIDLE</td></tr> </table> |                                        |                                                                                                                                                                                                                                                                                                               |            | 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 | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | MIDLEMODE | RESERVED | CLOCKACTIVITY | RESERVED | SIDLEMODE | ENAWAKEUP | SOFTRESET | AUTOIDLE |
| 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 |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                        |                                                                                                                                                                                                                                                                                                               |            |         |    |    |    |    |    |    |    |    |    |    |    | MIDLEMODE | RESERVED | CLOCKACTIVITY | RESERVED | SIDLEMODE | ENAWAKEUP | SOFTRESET | AUTOIDLE |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Field Name                             | Description                                                                                                                                                                                                                                                                                                   | Type       | Reset   |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| 31:14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RESERVED                               | Reserved                                                                                                                                                                                                                                                                                                      | R          | 0x00000 |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| 13:12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | MIDLEMODE                              | Master interface power management control.<br>Standby/wait control<br><br>0x0: Force-standby mode. Mstandby asserted unconditionally<br><br>0x1: No-standby mode. Mstandby never asserted.<br><br>0x2: Smart-standby mode. Mstandby asserted when initiator activity stops                                    | RW         | 0x0     |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| 11:9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RESERVED                               | Reserved                                                                                                                                                                                                                                                                                                      | R          | 0x0     |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | CLOCKACTIVITY                          | Control of clock internal gating while module is idle. One bit per clock, actual register width depends on the number of functional clocks controlled.<br><br>Lower bit: Interface clock<br>Upper bits (if any): Functional clocks<br>1: Clock is kept on during idle<br>0: Clock is switched off during idle | RW         | 0x0     |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| 7:5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RESERVED                               | Reserved                                                                                                                                                                                                                                                                                                      | R          | 0x0     |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| 4:3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | SIDLEMODE                              | Slave interface power management control. Idle Req/ack control<br><br>0x0: Force-Idle mode. Sidleack asserted after Idlereq assertion<br><br>0x1: No-idle mode. Sidleack never asserted.<br><br>0x2: Smart-idle mode. Sidleack asserted upon Idlereq assertion, after target activity is over                 | RW         | 0x0     |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ENAWAKEUP                              | Asynchronous wakeup generation control (Swakeup)<br><br>0x0: Wakeup generation disabled<br>0x1: Wakeup generation enabled                                                                                                                                                                                     | RW         | 0x0     |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | SOFTRESET                              | Module software reset<br><br>0x0: No effect<br>0x1: Starts softreset sequence.                                                                                                                                                                                                                                | W          | 0x0     |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | AUTOIDLE                               | Internal autogating control<br><br>0x0: Clock always running<br>0x1: When no activity on L3 interconnect, clock is cut off.                                                                                                                                                                                   | RW         | 0x1     |    |    |    |    |    |    |    |    |    |    |    |           |          |               |          |           |           |           |          |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |           |          |               |          |           |           |           |          |

**Table 22-157. Register Call Summary for Register UHH\_SYSCONFIG**

High-Speed USB Host Subsystem

- [Reset, Clocking, and Power-Management Scheme](#): [0] [1] [2] [3] [4]
- [High-Speed USB Host Subsystem Register Summary](#): [5]

**Table 22-158. UHH\_SYSSTATUS**

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:3        | RESERVED          | Reserved                                                                                         | R           | 0x00000000   |
| 2           | EHCI_RESETDONE    | Indicated when the EHCI HS host is out of reset                                                  | R           | 0x0          |
| 1           | OHCI_RESETDONE    | Indicates when the OHCI FS/LS host is out of reset                                               | R           | 0x0          |
| 0           | RESETDONE         | Indicates when the USB Host has come out of reset<br>0x0: Reset is ongoing<br>0x1: Reset is done | R           | 0x0          |

**Table 22-159. Register Call Summary for Register UHH\_SYSSTATUS**

## High-Speed USB Host Subsystem

- High-Speed USB Host Subsystem Register Summary: [0]

**Table 22-160. UHH\_HOSTCONFIG**

|                         |                                                 |                                                                                                 |                 |                                                                                                   |
|-------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------|
| <b>Address Offset</b>   | 0x0000 0040                                     | <b>Instance</b><br>UHH_config                                                                   |                 |                                                                                                   |
| <b>Physical Address</b> | 0x4806 4040                                     |                                                                                                 |                 |                                                                                                   |
| <b>Description</b>      | Static configuration of the OTG controller host |                                                                                                 |                 |                                                                                                   |
| <b>Type</b>             | RW                                              |                                                                                                 |                 |                                                                                                   |
| 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 |                                                                                                   |
|                         |                                                 | P3_ULPI_BYPASS<br>P2_ULPI_BYPASS<br>P3_CONNECT_STATUS<br>P2_CONNECT_STATUS<br>P1_CONNECT_STATUS | RESERVED        | ENA_INCR_ALIGN<br>ENA_INCR16<br>ENA_INCR8<br>ENA_INCR4<br>AUTOPPD_ON_OVERRUN_EN<br>P1_ULPI_BYPASS |
|                         |                                                 |                                                                                                 | RESERVED        |                                                                                                   |
|                         |                                                 |                                                                                                 |                 | RESERVED                                                                                          |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:13       | RESERVED          | Reserved                                                                                                                                                           | R           | 0x00000000   |
| 12          | P3_ULPI_BYPASS    | Host controller (root hub) port 3 control.<br>0x0: ULPI port 3 is active (and UTMI port 3 is inactive)<br>0x1: UTMI port 3 is active (and ULPI port 3 is inactive) | RW          | 0            |

## High-Speed USB Host Subsystem

www.ti.com

| Bits | Field Name            | Description                                                                                                                                                                                                                                                                                                                    | Type | Reset |
|------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 11   | P2_ULPI_BYPASS        | Host controller (root hub) port 2 control.<br><br>0x0: ULPI port 2 is active (and UTMI port 2 is inactive)<br>0x1: UTMI port 2 is active (and ULPI port 2 is inactive)                                                                                                                                                         | RW   | 0     |
| 10   | P3_CONNECT_STATUS     | Connection status for port 3.<br><br>0x0: USB port 3 is disconnected<br>0x1: USB port 3 is connected and in use (also the default state)                                                                                                                                                                                       | RW   | 0x1   |
| 9    | P2_CONNECT_STATUS     | Connection status for port 2.<br><br>0x0: USB port 2 is disconnected<br>0x1: USB port 2 is connected and in use (also the default state)                                                                                                                                                                                       | RW   | 0x1   |
| 8    | P1_CONNECT_STATUS     | Connection status for port 1.<br><br>0x0: USB port 1 is disconnected<br>0x1: USB port 1 is connected and in use (also the default state)                                                                                                                                                                                       | RW   | 0x1   |
| 7:6  | RESERVED              | Reserved                                                                                                                                                                                                                                                                                                                       | RW   | 0x0   |
| 5    | ENA_INCR_ALIGN        | Force alignment of bursts to the respective burst-size boundaries <sup>(1)</sup><br><br>0x0: Disable burst type<br>0x1: Enable burst type                                                                                                                                                                                      | RW   | 0x0   |
| 4    | ENA_INCR16            | Control the use of INCR16-type bursts (in AHB sense)<br><br>0x0: Disable burst type<br>0x1: Enable burst type                                                                                                                                                                                                                  | RW   | 0x0   |
| 3    | ENA_INCR8             | Control the use of INCR8-type bursts (in AHB sense)<br><br>0x0: Disable burst type<br>0x1: Enable burst type                                                                                                                                                                                                                   | RW   | 0x0   |
| 2    | ENA_INCR4             | Control the use of INCR4-type bursts (in AHB sense)<br><br>0x0: Disable burst type<br>0x1: Enable burst type                                                                                                                                                                                                                   | RW   | 0x0   |
| 1    | AUTOPPD_ON_OVERCUR_EN | Configure reaction upon port overcurrent condition<br><br>0x0: Port remains on upon overcurrent<br>0x1: Port is powered down automatically upon overcurrent<br><b>Note:</b> The bit must not be used, and is always written to with its default (reset) value as the hardware overcurrent inputs are tied off at device level. | RW   | 0x0   |
| 0    | P1_ULPI_BYPASS        | Host controller (root hub) port 1 control.<br><br>0x0: ULPI port 1 is active (and UTMI port 1 is inactive)<br>0x1: UTMI port 1 is active (and ULPI port 1 is inactive)                                                                                                                                                         | RW   | 0     |

<sup>(1)</sup> This bit must be set to 1 to avoid buffer underflow.

Table 22-161. Register Call Summary for Register UHH\_HOSTCONFIG

## High-Speed USB Host Subsystem

- [High-Speed USB Host Controller Functionality](#): [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12]
- [Selecting and Configuring USB Connectivity](#): [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23] [24] [25] [26] [27] [28] [29]
- [High-Speed USB Host Subsystem Register Summary](#): [30]

**Table 22-162. UHH\_DEBUG\_CSR**

|                       |                                                    |                         |             |                 |            |
|-----------------------|----------------------------------------------------|-------------------------|-------------|-----------------|------------|
| <b>Address Offset</b> | 0x0000 0044                                        | <b>Physical Address</b> | 0x4806 4044 | <b>Instance</b> | UHH_config |
| <b>Description</b>    | Debug control and status for the EHCI, OHCI hosts. |                         |             |                 |            |
| <b>Type</b>           | RW                                                 |                         |             |                 |            |



| Bits  | Field Name           | Description                                                                                                                                                                                                                                                      | Type | Reset |
|-------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:20 | RESERVED             | Reserved                                                                                                                                                                                                                                                         | R    | 0x000 |
| 19    | OHCI_CCS_3           | Current Connect Status of port 3<br><br>0x0: No periph connected<br>0x1: Periph connected                                                                                                                                                                        | R    | 0x0   |
| 18    | OHCI_CCS_2           | Current Connect Status of port 2<br><br>0x0: No periph connected<br>0x1: Periph connected                                                                                                                                                                        | R    | 0x0   |
| 17    | OHCI_CCS_1           | Current Connect Status of port 1<br><br>0x0: No periph connected<br>0x1: Periph connected                                                                                                                                                                        | R    | 0x0   |
| 16    | OHCI_GLOBALSUSPEND   | OHCI global suspend status, asserted 5ms after the suspend order.<br><br>0x0: Host is not suspended<br>0x1: Host is suspended                                                                                                                                    | R    | 0x0   |
| 15:8  | RESERVED             | Reserved                                                                                                                                                                                                                                                         | R    | 0x00  |
| 7     | OCHI_CNTSEL          | Selection of a shorter "1 ms" counter in OHCI host, to speed up long USB phases like reset, resume, etc (Used only for simulation.)<br><br>0x0: Functional mode, 1ms = 12,000 x 12 MHz cycles<br>0x1: Simulation mode, 1ms = 7 x 12 MHz cycles = 583 ns          | RW   | 0x0   |
| 6     | EHCI_SIMULATION_MODE | Sets the PHY to non-driving mode. (Used only for simulation.)<br><br>0x0: Functional mode<br>0x1: PHY set to non-driving                                                                                                                                         | RW   | 0x0   |
| 5:0   | EHCI_FLADJ           | EHCI host frame length adjust. Modify only when EHCI bitfield <b>USBSTS.HCHalted = 1</b><br>Field value + 59,488 = 60,000 by default<br>= number of 60 MHz UTMI/ULPI clock cycles per 1 ms USB frame<br>= number of 480 MHz HS bits per 125 us HS USB microframe | RW   | 0x20  |

**Table 22-163. Register Call Summary for Register UHH\_DEBUG\_CSR**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**22.2.6.4.3 OHCI Registers****Table 22-164. HCREVISION**

|                         |                      |                 |      |
|-------------------------|----------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0000          | <b>Instance</b> | OHCI |
| <b>Physical Address</b> | 0x4806 4400          |                 |      |
| <b>Description</b>      | OHCI revision number |                 |      |
| <b>Type</b>             | R                    |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | REV |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                              | Type | Reset     |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:8 | RESERVED   | Reserved                                                                                                                                 | R    | 0x0000000 |
| 7:0  | REV        | OHCI specification revision the OHCI revision number upon which the USB host controller is based.<br>Examples: 0x10 for 1.0 0x21 for 2.1 | R    | 0x10      |

**Table 22-165. Register Call Summary for Register HCREVISION**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-166. HCCONTROL**

|                         |                            |                 |      |
|-------------------------|----------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0004                | <b>Instance</b> | OHCI |
| <b>Physical Address</b> | 0x4806 4404                |                 |      |
| <b>Description</b>      | HC Operating Mode Register |                 |      |
| <b>Type</b>             | RW                         |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                          | Type | Reset     |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:11 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                             | R    | 0x0000000 |
| 10    | RWE        | Remote wake-up enable<br><br>This bit is used to enable or disable the remote wakeup feature upon detection of upstream resume signaling.                                                                                                                                                            | RW   | 0         |
| 9     | RWC        | Remote wake-up connected.<br><br>This bit indicates whether the host controller supports remote wakeup signaling.                                                                                                                                                                                    | RW   | 0         |
| 8     | IR         | Interrupt routing.<br><br>This bit determines the routing of interrupts generated by events registered in <b>USBHOST.HCINTERRUPTSTATUS</b> .<br><br>0x0: All interrupts are routed to the normal host bus interrupt mechanism.<br><br>0x1: interrupts are routed to the system management Interrupt. | RW   | 0         |

| Bits | Field Name | Description                                                                                                                                                                                                                                       | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 7:6  | HCFS       | Host Controller Functional State<br>0x0: HCFS: USB Reset<br>0x1: HCFS: USB Resume<br>0x2: HCFS: USB Operational<br>0x3: HCFS: USB Suspend                                                                                                         | RW   | 0x0   |
| 5    | BLE        | Bulk list processing enable.<br>0x0: Bulk ED list is not processed after the next SOF.<br>0x1: Enables processing of bulk ED list in the next frame.                                                                                              | RW   | 0     |
| 4    | CLE        | Control list processing enable.<br>0x0: Control ED list is not processed after the next SOF.<br>0x1: Enables processing of control ED list in the next frame.                                                                                     | RW   | 0     |
| 3    | IE         | Isochronous ED processing enabled by Host Controller Driver.<br>0x0: Isochronous EDs are not processed<br>0x1: Enables processing of isochronous EDs.                                                                                             | RW   | 0     |
| 2    | PLE        | Periodic list enable<br>0x0: Periodic ED lists are not processed after the next frame.<br>0x1: Enables processing of periodic ED lists in the next frame.                                                                                         | RW   | 0     |
| 1:0  | CBSR       | Control/bulk service ratio. Specifies the ratio between control and bulk EDs processed in a frame.<br>0x0: One control ED per bulk ED<br>0x1: Two control ED per bulk ED<br>0x2: Three control ED per bulk ED<br>0x3: Four control ED per bulk ED | RW   | 0x0   |

**Table 22-167. Register Call Summary for Register HCCONTROL**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-168. HCOMMANDSTATUS**

|                         |                         |                         |                 |                 |      |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0008             | <b>Physical Address</b> | 0x4806 4408     | <b>Instance</b> | OHCI |
| <b>Description</b>      | HC Command and Status   |                         |                 |                 |      |
| <b>Type</b>             | RW                      |                         |                 |                 |      |
| 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 |                 |      |
| RESERVED                | SOC                     | RESERVED                |                 | OCSR            | BLFC |
|                         |                         |                         |                 | CLFR            | HCSR |

| Bits  | Field Name | Description                                                                                                                                                                                                | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:18 | RESERVED   | Reserved                                                                                                                                                                                                   | R    | 0x0000 |
| 17:16 | SOC        | Scheduling overrun count.<br>This is used to monitor any persistent scheduling problems.<br>These bits are incremented on each scheduling overrun error. It is initialized to 0x0 and wraps around at 0x3. | R    | 0x0    |
| 15:4  | RESERVED   | Reserved                                                                                                                                                                                                   | R    | 0x000  |

## High-Speed USB Host Subsystem

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                            | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 3    | OCR        | Ownership change request.<br><br>This bit is set to request a change of control of the host controller.                                                                                                                                                                                                | RW   | 0     |
| 2    | BLF        | Bulk list filled.<br><br>This bit is used to indicate whether there are any TDs on the bulk list. It is set whenever it adds a TD to an ED in the bulk list.                                                                                                                                           | RW   | 0     |
| 1    | CLF        | Control list filled.<br><br>This bit is used to indicate whether there are any TDs on the control list. It is set whenever it adds a TD to an ED in the control list.                                                                                                                                  | RW   | 0     |
| 0    | HCR        | Host controller reset. (software reset) Set this bit to initiate a USB host controller reset. This resets most USB host controller OHCI registers. OHCI register accesses must not be attempted until a read of this register returns a 0.<br><br>0x0: No effect<br>0x1: USB host controller is reset. | RW   | 0     |

**Table 22-169. Register Call Summary for Register HCCOMMANDSTATUS**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\]](#)

**Table 22-170. HCINTERRUPTSTATUS**

|                  |    |                     |                         |                       |                          |
|------------------|----|---------------------|-------------------------|-----------------------|--------------------------|
| Address Offset   |    | 0x0000 000C         | Instance                | OHCI                  |                          |
| Physical Address |    | 0x4806 440C         |                         |                       |                          |
| Description      |    | HC Interrupt Status |                         |                       |                          |
| Type             |    | RW                  |                         |                       |                          |
| 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          |
| RESERVED         | OC | RESERVED            |                         |                       | RHSC FNO UE RD SF WDH SO |

| Bits | Field Name | Description                                                                                                                                                                                                           | Type | Reset     |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31   | RESERVED   | Reserved                                                                                                                                                                                                              | R    | 0         |
| 30   | OC         | Ownership change.<br><br>This bit is set when the <a href="#">USBHOST.HCCOMMANDSTATUS[3]</a> OCR bit is set.<br><br>Read 0x1: An ownership change has occurred.<br>Write 0x0: No effect<br>Write 0x1: Clears this bit | R    | 0         |
| 29:7 | RESERVED   | Reserved                                                                                                                                                                                                              | R    | 0x0000000 |
| 6    | RHSC       | Root hub status change.<br>When 0x1: A root hub status change has occurred.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.                                                                                   | RW   | 0         |
| 5    | FNO        | Frame number overflow.<br>When 0x1: A frame number overflow has occurred.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.                                                                                     | RW   | 0         |

| Bits | Field Name | Description                                                                                                                                                        | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4    | UE         | Unrecoverable error.<br>When 0x1: An unrecoverable error has occurred.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.                                     | RW   | 0     |
| 3    | RD         | Resume detected.<br>When 0x1: A downstream device has issued a resume request.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.                             | RW   | 0     |
| 2    | SF         | Start of frame.<br>When 0x1: A SOF has been issued.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.                                                        | RW   | 0     |
| 1    | WDH        | Write done head.<br>When 0x1: The USB host controller has updated the <a href="#">HCDONEHEAD</a> register.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit. | RW   | 0     |
| 0    | SO         | Scheduling overrun.<br>When 0x1: A scheduling overrun has occurred.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit                                         | RW   | 0     |

**Table 22-171. Register Call Summary for Register HCINTERRUPTSTATUS**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\]](#)

**Table 22-172. HCINTERRUPTENABLE**

|                       |    |                     |                         |             |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |    |    |    |     |    |   |   |   |
|-----------------------|----|---------------------|-------------------------|-------------|-----------------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-----|----|----|----|-----|----|---|---|---|
| <b>Address Offset</b> |    | 0x0000 0010         | <b>Physical Address</b> | 0x4806 4410 | <b>Instance</b> | OHCI |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |    |    |    |     |    |   |   |   |
| <b>Description</b>    |    | HC Interrupt Enable | <b>Type</b>             | RW          |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |    |    |    |     |    |   |   |   |
|                       |    |                     |                         |             |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |    |    |    |     |    |   |   |   |
|                       |    |                     |                         |             |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |    |    |    |     |    |   |   |   |
| 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 |
| MIE                   | OC | RESERVED            |                         |             |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RHSC | FNO | UE | RD | SF | WDH | SO |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                        | Type | Reset     |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31   | MIE        | Master interrupt enable.<br>When 0x1: Allows other enabled OHCI interrupt sources to propagate to the device interrupt controller.<br>When 0x0: OHCI interrupt sources are ignored.<br>Write 0x0: No effect.<br>Write 0x1: Sets this bit.                                          | RW   | 0         |
| 30   | OC         | Ownership change.<br>Write 0x0: No effect.<br>Write 0x1: Enable interrupt generation due to ownership change.                                                                                                                                                                      | RW   | 0         |
| 29:7 | RESERVED   | Reserved                                                                                                                                                                                                                                                                           | R    | 0x0000000 |
| 6    | RHSC       | Root hub status change.<br>When 0x1 and MIE is 0x1: Allows root hub status change interrupts to propagate to the device interrupt controller.<br>When 0x0 or MIE is 0x0: Root hub status change interrupts do not propagate.<br>Write 0x0: No effect.<br>Write 0x1: Sets this bit. | RW   | 0         |

## High-Speed USB Host Subsystem

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                 | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 5    | FNO        | Frame number overflow.<br>When 0x1 and MIE is 0x1: Allows FNO interrupts to propagate to the device interrupt controller.<br>When 0x0 or MIE is 0x0: FNO interrupts do not propagate.<br>Write 0x0: No effect.<br>Write 0x1: Sets this bit. | RW   | 0     |
| 4    | UE         | Unrecoverable error.<br>When 0x1 and MIE is 0x1: Allows UE interrupts to propagate to the device interrupt controller.<br>When 0x0 or MIE is 0x0: UE interrupts do not propagate.<br>Write 0x0: No effect.<br>Write 0x1: Sets this bit.     | RW   | 0     |
| 3    | RD         | Resume detected.<br>When 0x1 and MIE is 0x1: Allows RD interrupts to propagate to the device interrupt controller.<br>When 0x0 or MIE is 0x0: RD interrupts do not propagate.<br>Write 0x0: No effect.<br>Write 0x1: Sets this bit.         | RW   | 0     |
| 2    | SF         | Start of frame.<br>When 0x1 and MIE is 0x1: Allows SF interrupts to propagate to the device interrupt controller.<br>When 0x0 or MIE is 0x0: SF interrupts do not propagate.<br>Write 0x0: No effect.<br>Write 0x1: Sets this bit.          | RW   | 0     |
| 1    | WDH        | Write done head.<br>When 0x1 and MIE is 0x1: Allows WDH interrupts to propagate to the device interrupt controller.<br>When 0x0 or MIE is 0x0: WDH interrupts do not propagate.<br>Write 0x0: No effect.<br>Write 0x1: Sets this bit.       | RW   | 0     |
| 0    | SO         | Scheduling overrun.<br>When 0x1 and MIE is 0x1: Allows SO interrupts to propagate to the device interrupt controller.<br>When 0x0 or MIE is 0x0: SO interrupts do not propagate.<br>Write 0x0: No effect.<br>Write 0x1: Sets this bit.      | RW   | 0     |

**Table 22-173. Register Call Summary for Register HCINTERRUPTENABLE**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\]](#)

**Table 22-174. HCINTERRUPTDISABLE**

|                         |    |                      |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |    |    |    |     |    |   |   |   |   |   |
|-------------------------|----|----------------------|-----------------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-----|----|----|----|-----|----|---|---|---|---|---|
| <b>Address Offset</b>   |    | 0x0000 0014          | <b>Instance</b> | OHCI |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |    |    |    |     |    |   |   |   |   |   |
| <b>Physical Address</b> |    | 0x4806 4414          |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |    |    |    |     |    |   |   |   |   |   |
| <b>Description</b>      |    | HC Interrupt Disable |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |    |    |    |     |    |   |   |   |   |   |
| <b>Type</b>             |    | RW                   |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |    |    |    |     |    |   |   |   |   |   |
| 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 |
| MIE                     | OC | RESERVED             |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RHSC | FNO | UE | RD | SF | WDH | SO |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31   | MIE        | Master interrupt enable.<br>Always reads 0x0.<br>Write 0x0: No effect.<br>Write 0x1: Clears the <a href="#">HCINTERRUPTENABLE</a> MIE bit. | RW   | 0     |

[www.ti.com](http://www.ti.com)
*High-Speed USB Host Subsystem*

| Bits | Field Name | Description                                                                                                                       | Type | Reset    |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 30   | OC         | Ownership change.<br>Write 0x0: No effect.<br>Write 0x1: Disable interrupt generation due to ownership change.                    | RW   | 0        |
| 29:7 | RESERVED   | Reserved                                                                                                                          | R    | 0x000000 |
| 6    | RHSC       | Root hub status change.<br>Always reads 0x0.<br>Write 0x0: No effect.<br>Write 0x1: Clears the <b>HCINTERRUPTENABLE</b> RHSC bit. | RW   | 0        |
| 5    | FNO        | Frame number overflow.<br>Always reads 0x0.<br>Write 0x0: No effect.<br>Write 0x1: Clears the <b>HCINTERRUPTENABLE</b> FNO bit.   | RW   | 0        |
| 4    | UE         | Unrecoverable error.<br>Always reads 0x0.<br>Write 0x0: No effect.<br>Write 0x1: Clears the <b>HCINTERRUPTENABLE</b> UE bit.      | RW   | 0        |
| 3    | RD         | Resume detected.<br>Always reads 0x0.<br>Write 0x0: No effect.<br>Write 0x1: Clears the <b>HCINTERRUPTENABLE</b> RD bit.          | RW   | 0        |
| 2    | SF         | Start of frame.<br>Always reads 0x0.<br>Write 0x0: No effect.<br>Write 0x1: Clears the <b>HCINTERRUPTENABLE</b> SF bit.           | RW   | 0        |
| 1    | WDH        | Write done head.<br>Always reads 0x0.<br>Write 0x0: No effect.<br>Write 0x1: Clears the <b>HCINTERRUPTENABLE</b> WDH bit.         | RW   | 0        |
| 0    | SO         | Scheduling overrun.<br>Always reads 0x0.<br>Write 0x0: No effect.<br>Write 0x1: Clears the <b>HCINTERRUPTENABLE</b> SO bit.       | RW   | 0        |

**Table 22-175. Register Call Summary for Register HCINTERRUPTDISABLE**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-176. HCHCCA**

|                                                                                             |                          |                 |          |
|---------------------------------------------------------------------------------------------|--------------------------|-----------------|----------|
| <b>Address Offset</b>                                                                       | 0x0000 0018              | <b>Instance</b> | OHCI     |
| <b>Physical Address</b>                                                                     | 0x4806 4418              |                 |          |
| <b>Description</b>                                                                          | HC HCCA Address Register |                 |          |
| <b>Type</b>                                                                                 | RW                       |                 |          |
| 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 |                          |                 |          |
| HCCA                                                                                        |                          |                 | RESERVED |

| Bits | Field Name | Description                                    | Type | Reset    |
|------|------------|------------------------------------------------|------|----------|
| 31:8 | HCCA       | Physical address of the beginning of the HCCA. | RW   | 0x000000 |
| 7:0  | RESERVED   | Reserved                                       | R    | 0x00     |

**Table 22-177. Register Call Summary for Register HCHCCA**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-178. HCPERIODCURRENTED**

|                         |                              |                         |                 |                 |          |
|-------------------------|------------------------------|-------------------------|-----------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 001C                  | <b>Physical Address</b> | 0x4806 441C     | <b>Instance</b> | OHCI     |
| <b>Description</b>      | HC Current Periodic Register |                         |                 |                 |          |
| <b>Type</b>             | R                            |                         |                 |                 |          |
| 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 | PCED            | RESERVED |

| Bits | Field Name | Description                                             | Type | Reset     |
|------|------------|---------------------------------------------------------|------|-----------|
| 31:4 | PCED       | Physical address of current ED on the periodic ED list. | R    | 0x0000000 |
| 3:0  | RESERVED   | Reserved                                                | R    | 0x0       |

**Table 22-179. Register Call Summary for Register HCPERIODCURRENTED**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-180. HCCONTROLHEADED**

|                         |                          |                         |                 |                 |          |
|-------------------------|--------------------------|-------------------------|-----------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 0020              | <b>Physical Address</b> | 0x4806 4420     | <b>Instance</b> | OHCI     |
| <b>Description</b>      | HC Head Control Register |                         |                 |                 |          |
| <b>Type</b>             | RW                       |                         |                 |                 |          |
| 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 | CHED            | RESERVED |

| Bits | Field Name | Description                                         | Type | Reset     |
|------|------------|-----------------------------------------------------|------|-----------|
| 31:4 | CHED       | Physical address of head ED on the control ED list. | RW   | 0x0000000 |
| 3:0  | RESERVED   | Reserved                                            | R    | 0x0       |

**Table 22-181. Register Call Summary for Register HCCONTROLHEADED**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-182. HCCONTROLCURRENTED**

|                         |                             |                         |                 |                 |          |
|-------------------------|-----------------------------|-------------------------|-----------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 0024                 | <b>Physical Address</b> | 0x4806 4424     | <b>Instance</b> | OHCI     |
| <b>Description</b>      | HC Current Control Register |                         |                 |                 |          |
| <b>Type</b>             | RW                          |                         |                 |                 |          |
| 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 | CCED            | RESERVED |

| Bits | Field Name | Description                                            | Type | Reset     |
|------|------------|--------------------------------------------------------|------|-----------|
| 31:4 | CCED       | Physical address of current ED on the control ED list. | RW   | 0x0000000 |
| 3:0  | RESERVED   | Reserved                                               | R    | 0x0       |

**Table 22-183. Register Call Summary for Register HCCONTROLCURRENTED**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-184. HCBULKHEADED**

|                         |                       |                 |             |
|-------------------------|-----------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 0028           | <b>Instance</b> | <b>OHCI</b> |
| <b>Physical Address</b> | 0x4806 4428           |                 |             |
| <b>Description</b>      | HC Head Bulk Register |                 |             |
| <b>Type</b>             | RW                    |                 |             |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |          |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----------|---|---|---|---|---|
| 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 |
| BHED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | RESERVED |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------|-------------|--------------|
| 31:4        | BHED              | Physical address of head ED on the bulk ED list. | RW          | 0x00000000   |
| 3:0         | RESERVED          | Reserved                                         | R           | 0x0          |

**Table 22-185. Register Call Summary for Register HCBULKHEADED**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-186. HCBULKCURRENTED**

|                         |                          |                 |             |
|-------------------------|--------------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x0000 002C              | <b>Instance</b> | <b>OHCI</b> |
| <b>Physical Address</b> | 0x4806 442C              |                 |             |
| <b>Description</b>      | HC Current Bulk Register |                 |             |
| <b>Type</b>             | RW                       |                 |             |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |          |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----------|---|---|---|---|---|
| 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 |
| BCED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | RESERVED |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------|-------------|--------------|
| 31:4        | BCED              | Physical address of current ED on the bulk ED list. | RW          | 0x00000000   |
| 3:0         | RESERVED          | Reserved                                            | R           | 0x0          |

**Table 22-187. Register Call Summary for Register HCBULKCURRENTED**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-188. HCDONEHEAD**

|                         |                         |                       |                 |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0030             | <b>Instance</b>       | OHCI            |  |  |
| <b>Physical Address</b> | 0x4806 4430             |                       |                 |  |  |
| <b>Description</b>      | HC Head Done Register   |                       |                 |  |  |
| <b>Type</b>             | R                       |                       |                 |  |  |
| 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 |  |  |
| DH                      |                         |                       | RESERVED        |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                            | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------|-------------|--------------|
| 31:4        | DH                | Physical address of last TD that was added to the Done queue. | R           | 0x00000000   |
| 3:0         | RESERVED          | Reserved                                                      | R           | 0x0          |

**Table 22-189. Register Call Summary for Register HCDONEHEAD**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\]](#)

**Table 22-190. HCFMINTERVAL**

|                         |                            |                       |                 |  |  |
|-------------------------|----------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0034                | <b>Instance</b>       | OHCI            |  |  |
| <b>Physical Address</b> | 0x4806 4434                |                       |                 |  |  |
| <b>Description</b>      | HC Frame Interval Register |                       |                 |  |  |
| <b>Type</b>             | RW                         |                       |                 |  |  |
| 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 |  |  |
| FIT                     | FSMPS                      | RESERVED              | FI              |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                               | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31          | FIT               | Frame interval toggle.<br>This bit is toggled whenever it loads a new value to FI.                                                                                               | RW          | 0            |
| 30:16       | FSMPS             | Largest data packet size for full-speed packets, bit times.<br>This field specifies a value which is loaded into the largest data packet counter at the beginning of each frame. | RW          | 0x0000       |
| 15:14       | RESERVED          | Reserved                                                                                                                                                                         | R           | 0x0          |
| 13:0        | FI                | Frame interval. Number of 12-MHz clocks in the USB frame. The nominal value is set to 11,999, to give a 1-ms frame.                                                              | RW          | 0x2EDF       |

**Table 22-191. Register Call Summary for Register HCFMINTERVAL**

High-Speed USB Host Subsystem

- [High-Speed USB Host Controller Functionality: \[0\]](#)
- [High-Speed USB Host Subsystem Register Summary: \[1\]](#)
- [High-Speed USB Host Subsystem Register Description: \[2\] \[3\] \[4\]](#)

**Table 22-192. HCFMREMAINING**

|                         |                             |                 |      |  |  |
|-------------------------|-----------------------------|-----------------|------|--|--|
| <b>Address Offset</b>   | 0x0000 0038                 | <b>Instance</b> | OHCI |  |  |
| <b>Physical Address</b> | 0x4806 4438                 |                 |      |  |  |
| <b>Description</b>      | HC Frame Remaining Register |                 |      |  |  |
| <b>Type</b>             | R                           |                 |      |  |  |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| FRT                     | RESERVED                |                       | FR              |

| Bits  | Field Name | Description                                                                                                                                                                                     | Type | Reset   |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31    | FRT        | Frame remaining toggle.<br><br>This bit is used for the synchronization between<br>USBHOST.HCFMINTERVAL[13:0] FI and FR.                                                                        | R    | 0       |
| 30:14 | RESERVED   | Reserved                                                                                                                                                                                        | R    | 0x00000 |
| 13:0  | FR         | Frame remaining.<br><br>This counter is decremented at each bit time. When it<br>reaches 0, it is reset by loading the<br>USBHOST.HCFMINTERVAL[13:0] FI value at the next bit<br>time boundary. | R    | 0x0000  |

**Table 22-193. Register Call Summary for Register HCFMREMAINING**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\]](#)

**Table 22-194. HCFMNUMBER**

|                         |                          |                 |      |  |  |
|-------------------------|--------------------------|-----------------|------|--|--|
| <b>Address Offset</b>   | 0x0000 003C              | <b>Instance</b> | OHCI |  |  |
| <b>Physical Address</b> | 0x4806 443C              |                 |      |  |  |
| <b>Description</b>      | HC Frame Number Register |                 |      |  |  |
| <b>Type</b>             | R                        |                 |      |  |  |

|                         |                         |                       |                 |  |
|-------------------------|-------------------------|-----------------------|-----------------|--|
| 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 |  |
| RESERVED                |                         | FN                    |                 |  |

| Bits  | Field Name | Description                                                                                                                   | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Reserved                                                                                                                      | R    | 0x0000 |
| 15:0  | FN         | Frame Number.<br><br>This is incremented when USBHOST.HCFMREMAINING<br>is reloaded. It is rolled over to 0x0000 after 0xFFFF. | R    | 0x0000 |

**Table 22-195. Register Call Summary for Register HCFMNUMBER**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-196. HCPERIODICSTART**

|                         |                            |                       |                 |  |  |
|-------------------------|----------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0040                | <b>Instance</b>       | OHCI            |  |  |
| <b>Physical Address</b> | 0x4806 4440                |                       |                 |  |  |
| <b>Description</b>      | HC Periodic Start Register |                       |                 |  |  |
| <b>Type</b>             | RW                         |                       |                 |  |  |
| 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 |  |  |
| RESERVED                |                            |                       | PS              |  |  |

  

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                | Type | Reset   |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | RESERVED   | Reserved                                                                                                                                                                                                                                                                   | R    | 0x00000 |
| 13:0  | PS         | Periodic start. The host controller driver must program this value to be about 10% less than the frame interval field value so that control and bulk EDs have priority for the first 10% of the frame; then periodic EDs have priority for the remaining 90% of the frame. | RW   | 0x0000  |

**Table 22-197. Register Call Summary for Register HCPERIODICSTART**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-198. HCLSTHRESHOLD**

|                         |                                 |                       |                 |  |  |
|-------------------------|---------------------------------|-----------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0044                     | <b>Instance</b>       | OHCI            |  |  |
| <b>Physical Address</b> | 0x4806 4444                     |                       |                 |  |  |
| <b>Description</b>      | HC Low-Speed Threshold Register |                       |                 |  |  |
| <b>Type</b>             | RW                              |                       |                 |  |  |
| 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 |  |  |
| RESERVED                |                                 |                       | LST             |  |  |

  

| Bits  | Field Name | Description          | Type | Reset   |
|-------|------------|----------------------|------|---------|
| 31:12 | RESERVED   | Reserved             | R    | 0x00000 |
| 11:0  | LST        | Low-speed threshold. | RW   | 0x628   |

**Table 22-199. Register Call Summary for Register HCLSTHRESHOLD**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-200. HCRHDESCRIPTORA**

|                         |                         |                                  |                 |  |  |
|-------------------------|-------------------------|----------------------------------|-----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0048             | <b>Instance</b>                  | OHCI            |  |  |
| <b>Physical Address</b> | 0x4806 4448             |                                  |                 |  |  |
| <b>Description</b>      | HC Root Hub A Register  |                                  |                 |  |  |
| <b>Type</b>             | RW                      |                                  |                 |  |  |
| 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 |  |  |
| POTPG                   | RESERVED                |                                  |                 |  |  |
|                         |                         | NOCP<br>OCPM<br>DT<br>NPS<br>PSM | NDP             |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | POTPG      | Power-on to power-good time. Defines the minimum amount of time (2 ms * POTPG) between the USB host controller turning on power to a downstream port and when the USB host can access the downstream device.                                                                                                                                                 | RW   | 0x0A  |
| 23:13 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                     | R    | 0x000 |
| 12    | NOCP       | No overcurrent protection.<br>0x0: Overcurrent status is reported collectively for all downstream ports.<br>0x1: The USB host controller does not implement overcurrent protection inputs<br><b>Note:</b> The bit must not be used, and is always written to with its default (reset) value as the hardware overcurrent inputs are tied off at device level. | RW   | 0     |
| 11    | OCPM       | Overcurrent protection mode.<br><b>Note:</b> The bit must not be used, and is always written to with its default (reset) value as the hardware overcurrent inputs are tied off at device level.                                                                                                                                                              | RW   | 1     |
| 10    | DT         | Device type.<br>Always reads 0x0: Indicates that the USB host controller implemented is not a compound device.                                                                                                                                                                                                                                               | R    | 0     |
| 9     | NPS        | No power switching<br>0x0: VBUS power switching is supported, either per-port or all-port switched per the power<br>0x1: VBUS power switching is not supported, power is available to all downstream ports.                                                                                                                                                  | RW   | 0     |
| 8     | PSM        | Power switching mode.<br>0x0: Indicates that all ports are powered at the same time<br>0x1: Individual port power switching is supported                                                                                                                                                                                                                     | RW   | 1     |
| 7:0   | NDP        | Number of downstream ports.<br>These bits specify the number of downstream ports supported by the root hub. It is implementation-specific. The minimum number of ports is 1. The maximum number of ports supported by OHCI is 15.                                                                                                                            | R    | 0x03  |

**Table 22-201. Register Call Summary for Register HCRHDESCRIPTORA**

High-Speed USB Host Subsystem

- [High-Speed USB Host Controller Functionality](#): [0] [1] [2] [3]
- [High-Speed USB Host Subsystem Register Summary](#): [4]

**Table 22-202. HCRHDESCRIPTORB**

|                         |                        |                 |      |
|-------------------------|------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 004C            | <b>Instance</b> | OHCI |
| <b>Physical Address</b> | 0x4806 444C            |                 |      |
| <b>Description</b>      | HC Root Hub B Register |                 |      |
| <b>Type</b>             | RW                     |                 |      |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| PPCM |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DR |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | PPCM       | Port power control mask. Each bit defines whether a corresponding downstream port has port power controlled by the global power control. When set the port's power state is only affected by per-port power control. When cleared the port is controlled by the global power switch. If the device is configured to global switch mode this field is not valid. bit 0: Reserved, bit 1: Ganged-power mask on port 1, ..., bit 15: Ganged-power mask on port 15 | RW   | 0x0000 |

## High-Speed USB Host Subsystem

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                | Type | Reset  |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 15:0 | DR         | Device removable. Each bit defines whether a corresponding downstream port has a removable device. When cleared the attached device is removable. When set the attached device is not removable. Bit 0: Reserved, bit 1 : Device attached to port 1, &, bit 15: Device attached to port 15 | RW   | 0x0000 |

**Table 22-203. Register Call Summary for Register HCRHDESCRIPTORB**

High-Speed USB Host Subsystem

- [High-Speed USB Host Controller Functionality: \[0\] \[1\]](#)
- [High-Speed USB Host Subsystem Register Summary: \[2\]](#)
- [High-Speed USB Host Subsystem Register Description: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\]](#)

**Table 22-204. HCRHSTATUS**

|                  |                             |          |      |
|------------------|-----------------------------|----------|------|
| Address Offset   | 0x0000 0050                 | Instance | OHCI |
| Physical Address | 0x4806 4450                 |          |      |
| Description      | HC Root Hub Status Register |          |      |
| Type             | RW                          |          |      |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |   |   |   |   |   |   |   |   |     |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|
| 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 |
| CRWE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LPSC | DRWE |    |    |    |    |   |   |   |   |   |   |   |   | LPS |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                      | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31    | CRWE       | Clear remote wake-up enable.<br>Write 0x0: No effect.<br>Write 0x1: Clears the device remote wake-up enable bit.                                                                                                                                                                                                                                                                                                 | W    | 0      |
| 30:17 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                         | R    | 0x0000 |
| 16    | LPSC       | Local power status change.<br>Always reads 0x0: The Root Hub does not support the local power status feature<br>Write 0x0: No effect.<br>Write 0x1: Sets port power status bits for all ports, if power switching mode is 0. Sets port power status bits for ports with their corresponding port power control mask bits cleared if power switching mode is 1.                                                   | RW   | 0      |
| 15    | DRWE       | Device remote wake-up enable. Enables a connect status change event as a resume event, causing a USB suspend to USB resume state transition and sets the resume detected interrupt status bit.<br>Read 0x1: Connect status change is a remote wake-up event.<br>Read 0x0: Connect status change is not a remote wake-up event.<br>Write 0x0: No effect.<br>Write 0x1: Sets the device remote wake-up enable bit. | RW   | 0      |
| 14:1  | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                         | R    | 0x0000 |
| 0     | LPS        | Local power status.<br>Always reads 0x0.<br>Write 0x0: No effect.<br>Write 0x1: When in global power mode (power switching mode = 0), turns off power to all ports. If in per-port power mode (power switching mode = 1), turns off power to those ports whose corresponding port power control mask bit is 0.                                                                                                   | RW   | 0      |

**Table 22-205. Register Call Summary for Register HCRHSTATUS**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-206. HCRHPORTSTATUS\_1**

|                       |                                       |                         |             |                 |      |
|-----------------------|---------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 0054                           | <b>Physical Address</b> | 0x4806 4454 | <b>Instance</b> | OHCI |
| <b>Description</b>    | HC Port 1 Status and Control Register |                         |             |                 |      |
| <b>Type</b>           | RW                                    |                         |             |                 |      |



| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R    | 0x000 |
| 20    | PRSC       | Port 1 reset status change. This bit is set when the Port 1 port reset status bit has changed.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.                                                                                                                                                                                                                                                                                                                                       | RW   | 0     |
| 19    | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW   | 0     |
| 18    | PSSC       | Port 1 suspend status change. This bit is set when the Port1 port suspend status has changed.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.                                                                                                                                                                                                                                                                                                                                        | RW   | 0     |
| 17    | PESC       | Port 1 enable status change. This bit is set when the Port1 port enable status has changed.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.                                                                                                                                                                                                                                                                                                                                          | RW   | 0     |
| 16    | CSC        | Port 1 connect status change. This bit is set when the Port1 port current connect status has changed due to a connect or disconnect event. If current connect status is 0 when a set port reset, set port enable, or set port suspend write occurs, this bit is set.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.<br>Note: If the DR bit <a href="#">HCRHDESCRIPTORB[1]</a> is set, this bit is set only after a root hub reset to inform the system that the device is attached. | RW   | 0     |
| 15:10 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R    | 0x00  |
| 9     | LSDA_CPP   | Port 1 low-speed device attached/clear port power. This bit is valid only when port 1 current connect status is 1.<br>Read 0x0: A full-speed device is attached to port 1.<br>Read 0x1: A low-speed device is attached to port 1.<br>Write 0x0: No effect.<br>Write 0x1: Clears the port 1 port power status.                                                                                                                                                                                | RW   | 0     |
| 8     | PPS_SPP    | Port 1 port power status/set port power.<br>Read 0x0: Port 1 power is enabled.<br>Read 0x1: Port 1 power is not enabled.<br>Write 0x0: No effect.<br>Write 0x1: Sets the port 1 port power status bit.                                                                                                                                                                                                                                                                                       | RW   | 0     |
| 7:5   | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R    | 0x0   |

## High-Speed USB Host Subsystem

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 4    | PRS_SPR    | Port 1 port reset status/set port reset.<br>Read 0x0: USB reset is not being sent to port 1.<br>Read 0x1: Port 1 is signaling the USB reset.<br>Write 0x0: No effect.<br>Write 0x1: Sets the port 1 port reset status bit and causes the USB host controller to begin signaling USB reset to port 1.                                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 3    | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0     |
| 2    | PSS_SPS    | Port 1 port suspend status/set port suspend. This bit is cleared automatically at the end of the USB resume sequence and also at the end of the USB reset sequence.<br>Write 0x0: No effect.<br>Read 0x0: Port 1 is not in the USB suspend state.<br>Read 0x1: Port 1 is in the USB suspend state or is in the resume sequence.<br>Write 0x1: If port 1 current connect status is 1, sets the port 1 port suspend status bit and places port 1 in USB suspend state. If current connect status is 0, sets instead connect status change to inform the USB host controller driver of an attempt to suspend a disconnected port. | RW   | 0     |
| 1    | PES_SPE    | Port 1 port enable status/set port enable. This bit is automatically set at completion of port 1 USB reset if it was not already set before the USB reset completed, and is automatically set at the end of a USB suspend if the port was not enabled when the USB resume completed.<br>Read 0x0: Port 1 is not enabled.<br>Read 0x1: Port 1 is enabled.<br>Write 0x0: No effect.<br>Write 0x1: When port 1 current connect status is 1 sets the port 1 port enable status bit. When port 1 current status is 0 has no effect.                                                                                                 | RW   | 0     |
| 0    | CCS_CPE    | Port 1 current connection status/clear port enable.<br>Read 0x0: No USB device is attached to port 1.<br>Read 0x1: Port 1 currently has a USB device attached.<br>Write 0x0: No effect.<br>Write 0x1: Clears the port 1 port enable bit.<br>Note: This bit is set to 1 if the DR bit <b>HCRHDESCRIPTORB[1]</b> is set to indicate a non-removable device on port 1.                                                                                                                                                                                                                                                            | RW   | 0     |

**Table 22-207. Register Call Summary for Register HCRHPORTSTATUS\_1**

High-Speed USB Host Subsystem

- [High-Speed USB Host Controller Functionality: \[0\]](#)
- [High-Speed USB Host Subsystem Register Summary: \[1\]](#)

**Table 22-208. HCRHPORTSTATUS\_2**

| Address Offset | 0x0000 0058                           | Physical Address | 0x4806 4458 | Instance | OHCI |    |    |      |          |      |      |     |          |    |    |    |          |         |          |    |    |   |         |          |         |         |         |   |   |   |   |
|----------------|---------------------------------------|------------------|-------------|----------|------|----|----|------|----------|------|------|-----|----------|----|----|----|----------|---------|----------|----|----|---|---------|----------|---------|---------|---------|---|---|---|---|
| Description    | HC Port 2 Status and Control Register |                  |             |          | Type |    |    |      |          |      |      |     |          |    |    |    |          |         |          |    |    |   |         |          |         |         |         |   |   |   |   |
| Type           | RW                                    |                  |             |          | Type | RW |    |      |          |      |      |     |          |    |    |    |          |         |          |    |    |   |         |          |         |         |         |   |   |   |   |
| 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 |
| RESERVED       |                                       |                  |             |          |      |    |    | PRSC | RESERVED | PSSC | PESC | CSC | RESERVED |    |    |    | LSDA_CPP | PPS_SPP | RESERVED |    |    |   | PRS_SPR | RESERVED | PSS_SPS | PES_SPE | CCS_CPE |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R    | 0x000 |
| 20    | PRSC       | Port 2 reset status change. This bit is set when the Port 2 port reset status bit has changed.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0     |
| 19    | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0     |
| 18    | PSSC       | Port 2 suspend status changed. This bit is set when the Port 2 port suspend status has changed.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0     |
| 17    | PESC       | Port 2 enable status change. This bit is set when the Port 2 port enable status has changed.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 16    | CSC        | Port 2 connect status change. This bit is set when the Port 2 port current connect status has changed due to a connect or disconnect event.<br>If current connect status is 0 when a set port reset, set port enable, or set port suspend write occurs, this bit is set.<br>Write 0x0: No effect.<br>Write 0x1: Clears this bit.<br>Note: If the DR bit <b>HCRHDESCRIPTORB[1]</b> is set, this bit is set only after a root hub reset to inform the system that the device is attached.                                                                                                                                        | RW   | 0     |
| 15:10 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R    | 0x00  |
| 9     | LSDA_CPP   | Port 2 low-speed device attached/clear port power. This bit is valid only when port 2 current connect status is 1.<br>Read 0x0: A full-speed device is attached to port 2.<br>Read 0x1: A low-speed device is attached to port 2.<br>Write 0x0: No effect.<br>Write 0x1: Clears the port 2 port power status.                                                                                                                                                                                                                                                                                                                  | RW   | 0     |
| 8     | PPS_SPP    | Port 2 port power status/set port power.<br>Read 0x0: Port 2 power is enabled.<br>Read 0x1: Port 2 power is not enabled.<br>Write 0x0: No effect.<br>Write 0x1: Sets the port 2 port power status bit.                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0     |
| 7:5   | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R    | 0x0   |
| 4     | PRS_SPR    | Port 2 port reset status/set port reset.<br>Read 0x0: USB reset is not being sent to port 2.<br>Read 0x1: Port 2 is signaling the USB reset.<br>Write 0x0: No effect.<br>Write 0x1: Sets the port 2 port reset status bit and causes the USB host controller to begin signaling USB reset to port 2.                                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 3     | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0     |
| 2     | PSS_SPS    | Port 2 port suspend status/set port suspend. This bit is cleared automatically at the end of the USB resume sequence and also at the end of the USB reset sequence.<br>Write 0x0: No effect.<br>Read 0x0: Port 2 is not in the USB suspend state.<br>Read 0x1: Port 2 is in the USB suspend state or is in the resume sequence.<br>Write 0x1: If port 2 current connect status is 1, sets the port 2 port suspend status bit and places port 2 in USB suspend state. If current connect status is 0, sets instead connect status change to inform the USB host controller driver of an attempt to suspend a disconnected port. | RW   | 0     |

## High-Speed USB Host Subsystem

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | PES_SPE    | <p>Port 2 port enable status/set port enable. This bit is automatically set at completion of port 2 USB reset if it was not already set before the USB reset completed, and is automatically set at the end of a USB suspend if the port was not enabled when the USB resume completed.</p> <p>Read 0x0: Port 2 is not enabled.<br/>           Read 0x1: Port 2 is enabled.<br/>           Write 0x0: No effect.<br/>           Write 0x1: When port 2 current connect status is 1 sets the port 2 port enable status bit. When port 2 current status is 0 has no effect.</p> | RW   | 0     |
| 0    | CCS_CPE    | <p>Port 2 current connection status/clear port enable.</p> <p>Read 0x0: No USB device is attached to port 2.<br/>           Read 0x1: Port 2 currently has a USB device attached.<br/>           Write 0x0: No effect.<br/>           Write 0x1: Clears the port 2 port enable bit.<br/>           Note: This bit is set to 1 if the DR bit <b>HCRHDESCRIPTORB[1]</b> is set to indicate a non-removable device on port 2.</p>                                                                                                                                                | RW   | 0     |

**Table 22-209. Register Call Summary for Register HCRHPORTSTATUS\_2**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-210. HCRHPORTSTATUS\_3**

|                       |                                       |                         |             |                 |      |
|-----------------------|---------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 005C                           | <b>Physical Address</b> | 0x4806 445C | <b>Instance</b> | OHCI |
| <b>Description</b>    | HC Port 3 Status and Control Register |                         |             |                 |      |
| <b>Type</b>           | RW                                    |                         |             |                 |      |

|          |    |    |    |    |    |    |    |      |          |      |      |     |          |    |    |    |    |          |         |          |    |   |         |          |         |         |         |   |   |   |   |
|----------|----|----|----|----|----|----|----|------|----------|------|------|-----|----------|----|----|----|----|----------|---------|----------|----|---|---------|----------|---------|---------|---------|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    | PRSC | RESERVED | PSSC | PESC | CSC | RESERVED |    |    |    |    | LSDA_CPP | PPS_SPP | RESERVED |    |   | PRS_SPR | RESERVED | PSS_SPS | PES_SPE | CCS_CPE |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                   | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:21 | RESERVED   | Reserved                                                                                                                                                                      | R    | 0x000 |
| 20    | PRSC       | <p>Port 3 reset status change. This bit is set when the Port 3 port reset status bit has changed.</p> <p>Write 0x0: No effect.<br/>           Write 0x1: Clears this bit.</p> | RW   | 0     |
| 19    | RESERVED   | Reserved                                                                                                                                                                      | RW   | 0     |
| 18    | PSSC       | <p>Port 3 suspend status change. This bit is set when the Port 3 port suspend status has changed.</p> <p>Write 0x0: No effect.<br/>           Write 0x1: Clears this bit.</p> | RW   | 0     |
| 17    | PESC       | <p>Port 3 enable status change. This bit is set when the Port 3 port enable status has changed.</p> <p>Write 0x0: No effect.<br/>           Write 0x1: Clears this bit.</p>   | RW   | 0     |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 16    | CSC        | <p>Port 3 connect status change. This bit is set when the Port 3 port current connect status has changed due to a connect or disconnect event.</p> <p>If current connect status is 0 when a set port reset, set port enable, or set port suspend write occurs, this bit is set.</p> <p>Write 0x0: No effect.</p> <p>Write 0x1: Clears this bit.</p> <p>Note: If the DR bit <b>HCRHDESCRIPTORB[1]</b> is set, this bit is set only after a root hub reset to inform the system that the device is attached.</p>                                                                                                                                        | RW   | 0     |
| 15:10 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R    | 0x00  |
| 9     | LSDA_CPP   | <p>Port 3 low-speed device attached/clear port power. This bit is valid only when port 3 current connect status is 1.</p> <p>Read 0x0: A full-speed device is attached to port 3.</p> <p>Read 0x1: A low-speed device is attached to port 3.</p> <p>Write 0x0: No effect.</p> <p>Write 0x1: Clears the port 3 port power status.</p>                                                                                                                                                                                                                                                                                                                  | RW   | 0     |
| 8     | PPS_SPP    | <p>Port 3 power status/set port power.</p> <p>Read 0x0: Port 3 power is enabled.</p> <p>Read 0x1: Port 3 power is not enabled.</p> <p>Write 0x0: No effect.</p> <p>Write 0x1: Sets the port 3 port power status bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                              | RW   | 0     |
| 7:5   | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R    | 0x0   |
| 4     | PRS_SPR    | <p>Port 3 reset status/set port reset.</p> <p>Read 0x0: USB reset is not being sent to port 3.</p> <p>Read 0x1: Port 3 is signaling the USB reset.</p> <p>Write 0x0: No effect.</p> <p>Write 0x1: Sets the port 3 port reset status bit and causes the USB host controller to begin signaling USB reset to port 3.</p>                                                                                                                                                                                                                                                                                                                                | RW   | 0     |
| 3     | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW   | 0     |
| 2     | PSS_SPS    | <p>Port 3 port suspend status/set port suspend. This bit is cleared automatically at the end of the USB resume sequence and also at the end of the USB reset sequence.</p> <p>Write 0x0: No effect.</p> <p>Read 0x0: Port 3 is not in the USB suspend state.</p> <p>Read 0x1: Port 3 is in the USB suspend state or is in the resume sequence.</p> <p>Write 0x1: If port 3 current connect status is 1, sets the port 3 port suspend status bit and places port 3 in USB suspend state. If current connect status is 0, sets instead connect status change to inform the USB host controller driver of an attempt to suspend a disconnected port.</p> | RW   | 0     |
| 1     | PES_SPE    | <p>Port 3 enable status/set port enable. This bit is automatically set at completion of port 3 USB reset if it was not already set before the USB reset completed, and is automatically set at the end of a USB suspend if the port was not enabled when the USB resume completed.</p> <p>Read 0x0: Port 3 is not enabled.</p> <p>Read 0x1: Port 3 is enabled.</p> <p>Write 0x0: No effect.</p> <p>Write 0x1: When port 3 current connect status is 1 sets the port 3 port enable status bit. When port 3 current status is 0 has no effect.</p>                                                                                                      | RW   | 0     |
| 0     | CCS_CPE    | <p>Port 3 current connection status/clear port enable.</p> <p>Read 0x0: No USB device is attached to port 3.</p> <p>Read 0x1: Port 3 currently has a USB device attached.</p> <p>Write 0x0: No effect.</p> <p>Write 0x1: Clears the port 3 port enable bit.</p> <p>Note: This bit is set to 1 if the DR bit <b>HCRHDESCRIPTORB[1]</b> is set to indicate a non-removable device on port 3.</p>                                                                                                                                                                                                                                                        | RW   | 0     |

**Table 22-211. Register Call Summary for Register HCRHPORTSTATUS\_3**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**22.2.6.4.4 EHCI Registers****Table 22-212. HCCAPBASE**

|                         |                                     |                 |      |
|-------------------------|-------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0000                         | <b>Instance</b> | EHCI |
| <b>Physical Address</b> | 0x4806 4800                         |                 |      |
| <b>Description</b>      | Host Controller Capability register |                 |      |
| <b>Type</b>             | R                                   |                 |      |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
|                         | HCIVERSION              | RESERVED              | CAPLENGTH       |

| Bits  | Field Name | Description                                                                                                                                                        | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | HCIVERSION | Interface version number It contains a BCD encoding of the EHCI revision number supported by this host controller.<br>[7:4] Major revision<br>[3:0] Minor revision | R    | 0x0100 |
| 15:8  | RESERVED   | Reserved                                                                                                                                                           | R    | 0x00   |
| 7:0   | CAPLENGTH  | Capability register length                                                                                                                                         | R    | 0x10   |

**Table 22-213. Register Call Summary for Register HCCAPBASE**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-214. HCSPARAMS**

|                         |                                       |                 |      |
|-------------------------|---------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0004                           | <b>Instance</b> | EHCI |
| <b>Physical Address</b> | 0x4806 4804                           |                 |      |
| <b>Description</b>      | Host Controller Structural Parameters |                 |      |
| <b>Type</b>             | R                                     |                 |      |

|                         |                         |                       |                 |       |     |          |     |         |
|-------------------------|-------------------------|-----------------------|-----------------|-------|-----|----------|-----|---------|
| 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 |       |     |          |     |         |
| RESERVED                | RESERVED                | P_INDICATOR           | N_CC            | N_PCC | PRR | RESERVED | PPC | N_PORTS |

| Bits  | Field Name  | Description                                                                                                                                                                                                                                 | Type | Reset |
|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:20 | RESERVED    | Reserved                                                                                                                                                                                                                                    | R    | 0x000 |
| 19:17 | RESERVED    | Reserved                                                                                                                                                                                                                                    | R    | 0x0   |
| 16    | P_INDICATOR | Port indicator support indication<br><br>This bit indicates whether the ports support port indicator control.<br><br>0x1: The port status and control registers include a read/write field for controlling the state of the port indicator. | R    | 0     |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 15:12 | N_CC       | <p>Number of Companion Controllers</p> <p>This field indicates the number of companion controllers associated with this USB 2.0 host controller.</p> <p>0x0: There are no companion host controllers. Port-ownership hand-off is not supported. Only high-speed devices are supported on the host controller root ports.</p> <p>Others: there are companion USB 1.1 host controller(s). Port-ownership hand-off is supported. High-, full-, and low-speed devices are supported on the host controller root ports.</p>                                                 | R    | 0x1   |
| 11:8  | N_PCC      | <p>Number of Ports per Companion Controller</p> <p>This field indicates the number of ports supported per companion host controller. It is used to indicate the port routing configuration to system software.</p> <p>For example, if N_PORTS has a value of 6 and N_CC has a value of 2, then N_PCC can have a value of 3.</p> <p>The convention is that the first N_PCC ports are assumed to be routed to companion controller 1, the next N_PCC ports to companion controller 2, etc.</p> <p>The number in this field must be consistent with N_PORTS and N_CC.</p> | R    | 0x3   |
| 7     | PRR        | <p>Port Routing Rules</p> <p>The first N_PCC ports are routed to the lowest-numbered function companion host controller, the next N_PCC ports are routed to the next lowest-function companion controller, and so on.</p>                                                                                                                                                                                                                                                                                                                                              | R    | 0     |
| 6:5   | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R    | 0x0   |
| 4     | PPC        | <p>Port Power control</p> <p>This field indicates whether the host controller implementation includes port power control.</p> <p>0x0: The ports do not have port power switches.</p> <p>0x1: The ports have port power switches.</p>                                                                                                                                                                                                                                                                                                                                   | R    | 1     |
| 3:0   | N_PORTS    | <p>Number of downstream ports</p> <p>This field specifies the number of physical downstream ports implemented on this host controller.</p>                                                                                                                                                                                                                                                                                                                                                                                                                             | R    | 0x3   |

**Table 22-215. Register Call Summary for Register HCSPARAMS**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\] \[2\] \[3\]](#)

**Table 22-216. HCCPARAMS**

|                       |                                       |                         |             |                 |      |
|-----------------------|---------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 0008                           | <b>Physical Address</b> | 0x4806 4808 | <b>Instance</b> | EHCI |
| <b>Description</b>    | Host Controller Capability Parameters |                         |             |                 |      |
| <b>Type</b>           | R                                     |                         |             |                 |      |

|                         |                         |                       |                 |          |      |      |         |
|-------------------------|-------------------------|-----------------------|-----------------|----------|------|------|---------|
| 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 |          |      |      |         |
| RESERVED                |                         | EECP                  | IST             | RESERVED | ASPC | PFLF | BIT64AC |

## High-Speed USB Host Subsystem

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                  | Type | Reset  |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                     | R    | 0x0000 |
| 15:8  | EECP       | EHCI Extended Capabilities Pointer<br><br>This field indicates the existence of a capabilities list.<br>0x0: No extended capabilities are implemented.<br>Others: The offset in PCI configuration space of the first EHCI extended capability.                                                                                               | R    | 0x00   |
| 7:4   | IST        | Isochronous Scheduling Threshold<br><br>This field indicates where software can reliably update the isochronous schedule in relation to the current position of the executing host controller.<br><br>The host controller can hold 1 microframe of isochronous data structures before flushing the state.                                    | R    | 0x1    |
| 3     | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                     | R    | 0      |
| 2     | ASPC       | Asynchronous Schedule Park Capability<br><br>0x1: The host controller supports the park feature for high-speed queue heads in the asynchronous schedule.<br><br>The feature can be disabled or enabled and set to a specific level by using the USBHOST.USBCMD[11]ASPME and the USBHOST.USBCMD[9:8] ASPMC fields.                            | R    | 1      |
| 1     | PFLF       | Programmable Frame List Flag<br><br>0x0: System software must use a frame list length of 1024 elements with this host controller.<br><br>0x1: System software can specify and use a smaller frame list and configure the host controller via the USBHOST.USBCMD[3:2] FLS field. The frame list must always be aligned on a 4K-page boundary. | R    | 1      |
| 0     | BIT64AC    | 64-bit addressing capability<br><br>This field documents the addressing range capability of this implementation.<br><br>0x0: Data structures using 32-bit address memory pointers<br><br>0x1: Data structures using 64-bit address memory pointers                                                                                           | R    | 0      |

**Table 22-217. Register Call Summary for Register HCCPARAMS**

## High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\]](#)

**Table 22-218. USBCMD**

|                         |                         |                       |                 |          |          |          |      |      |     |     |                 |     |    |  |      |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|----------|----------|----------|------|------|-----|-----|-----------------|-----|----|--|------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0010             |                       |                 |          |          |          |      |      |     |     |                 |     |    |  |      |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4806 4810             |                       |                 |          |          |          |      |      |     |     | <b>Instance</b> |     |    |  | EHCI |  |  |  |  |  |  |  |
| <b>Description</b>      | USB Command             |                       |                 |          |          |          |      |      |     |     |                 |     |    |  |      |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                      |                       |                 |          |          |          |      |      |     |     |                 |     |    |  |      |  |  |  |  |  |  |  |
| 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 | RESERVED | RESERVED | RESERVED | LHCR | IAAD | ASE | PSE | FLS             | HCR | RS |  |      |  |  |  |  |  |  |  |
| RESERVED                | ITC                     | RESERVED              | ASPME           | RESERVED | ASPMC    |          |      |      |     |     |                 |     |    |  |      |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R    | 0x00  |
| 23:16 | ITC        | Interrupt Threshold Control<br><br>This field is used by the system software to select the maximum rate at which the host controller issues interrupts. The only valid values are defined below. If software writes an invalid value to this register, the results are undefined.<br><br>0x00: Reserved<br>0x01: 1 microframe<br>0x02: 2 microframes<br>0x04: 4 microframes<br>0x08: 8 microframes (default, equates to 1 ms)<br>0x10: 16 microframes (2 ms)<br>0x20: 32 microframes (4 ms)<br>0x40: 64 microframes (8 ms)<br>Others: Undefined | RW   | 0x08  |
| 15:12 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R    | 0x0   |
| 11    | ASPME      | Asynchronous Schedule Park Mode Enable<br><br>0x0: Park mode is disabled.<br>0x1: Park mode is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 1     |
| 10    | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R    | 0     |
| 9:8   | ASPMC      | Asynchronous Schedule Park Mode Count<br><br>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.<br><br>Valid values are 0x1 to 0x3. The software must not write a 0 to this bit when Park Mode Enable is a 1 as this may result in undefined behavior.                                                                                                                  | RW   | 0x3   |
| 7     | LHCR       | Light Host Controller Reset<br><br>It allows the driver to reset the EHCI controller without affecting the state of the ports or the relationship to the companion host controllers.<br><br>Read 0x0: Light host controller reset is complete and it is safe for host software to reinitialize the host controller.<br>Read 0x1: Light host controller reset is still ongoing.                                                                                                                                                                  | RW   | 0     |
| 6     | IAAD       | Interrupt on Async Advance Doorbell<br><br>This bit is used as a doorbell by software to tell the host controller to issue an interrupt the next time it advances asynchronous schedule.<br><br>Write 0x1: Ring the doorbell.<br><br>Software should not write a 1 to this bit when the asynchronous schedule is disabled. Doing so may yield undefined results.                                                                                                                                                                                | RW   | 0     |
| 5     | ASE        | Asynchronous Schedule Enable<br><br>This bit controls whether the host controller skips processing the asynchronous schedule.<br>0x0: Do not process the asynchronous schedule<br>0x1: Use the <a href="#">USBHOST.ASYNCLISTADDR</a> register to access the asynchronous schedule.                                                                                                                                                                                                                                                              | RW   | 0     |
| 4     | PSE        | Periodic Schedule Enable<br><br>This bit controls whether the host controller skips processing the periodic schedule.<br>0x0: Do not process the periodic schedule                                                                                                                                                                                                                                                                                                                                                                              | RW   | 0     |

## High-Speed USB Host Subsystem

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                               | Type | Reset |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x1: Use the USBHOST.PERIODICLISTBASE register to access the periodic schedule.                                                                                                                                                                                                                                                                                                           |      |       |
| 3:2  | FLS        | <p>Frame List Size</p> <p>This field specifies the size of the frame list. The size of the frame list controls which bits in the frame index register should be used for the frame list current index.</p> <p>0x0: 1024 elements (4096 bytes)</p> <p>0x1: 512 elements (2048 bytes)</p> <p>0x2: 256 elements (1024 bytes), for resource-constrained environments</p> <p>0x3: Reserved</p> | RW   | 0     |
| 1    | HCR        | <p>Host Controller Reset</p> <p>This control bit is used by software to reset the host controller. Write</p> <p>0x1: Reset the host controller, the PCI configuration registers are not affected by this reset and all operational registers are set to their initial values.</p> <p>This bit is set to 0 by the host controller when the reset process is complete.</p>                  | W    | 0     |
| 0    | RS         | <p>Run/stop</p> <p>0x1: Run, the host controller proceeds with execution of the schedule. The host controller continues execution as long as this bit is set to 1.</p> <p>0x0: Stop, the host controller completes the current and any actively pipelined transactions on the USB and then halts.</p>                                                                                     | RW   | 0     |

**Table 22-219. Register Call Summary for Register USBCMD**

## High-Speed USB Host Subsystem

- High-Speed USB Host Subsystem Register Summary: [0]
- High-Speed USB Host Subsystem Register Description: [1] [2] [3] [4] [5]

**Table 22-220. USBSTS**

|                         |                         |                         |                 |                            |      |
|-------------------------|-------------------------|-------------------------|-----------------|----------------------------|------|
| <b>Address Offset</b>   | 0x0000 0014             | <b>Physical Address</b> | 0x4806 4814     | <b>Instance</b>            | EHCI |
| <b>Description</b>      | USB status              |                         |                 |                            |      |
| <b>Type</b>             | RW                      |                         |                 |                            |      |
| 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 |                            |      |
| RESERVED                |                         | ASS PSS REC HCH         | RESERVED        | IAA HSE FLR PCD USBEI USBI |      |

| Bits  | Field Name | Description                                                                                                                                                                                                                                       | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RESERVED   | Reserved                                                                                                                                                                                                                                          | R    | 0x0000 |
| 15    | ASS        | <p>Asynchronous Schedule Status</p> <p>The bit reports the current real status of the asynchronous schedule.</p> <p>0x0: The status of the asynchronous schedule is disabled.</p> <p>0x1: The status of the asynchronous schedule is enabled.</p> | R    | 0      |
| 14    | PSS        | <p>Periodic Schedule Status</p> <p>The bit reports the current real status of the periodic schedule.</p>                                                                                                                                          | R    | 0      |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | 0x0: The status of the periodic schedule is disabled.<br>0x1: The status of the periodic schedule is enabled.                                                                                                                                                                                                                                                                                                                                                                         |      |       |
| 13   | REC        | Reclamation<br><br>It is used to detect an empty asynchronous schedule.                                                                                                                                                                                                                                                                                                                                                                                                               | R    | 0     |
| 12   | HCH        | Host Controller Halted<br><br>This bit is a 0 whenever the USBHOST.USBCMD[0]<br><br>RS bit is a 1. The host controller sets this bit to 1 after it<br>has stopped executing as a result of the RS bit being set<br>to 0, either by software or by the host controller<br>hardware.                                                                                                                                                                                                    | R    | 1     |
| 11:6 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R    | 0x00  |
| 5    | IAA        | Interrupt on Async Advance<br><br>System software can force the host controller to issue an<br>interrupt the next time the host controller advances the<br>asynchronous schedule by writing a 1 in the<br>USBHOST.USBCMD[6] IAAD bit. This status bit indicates<br>the assertion of that interrupt source.                                                                                                                                                                            | RW   | 0     |
| 4    | HSE        | Host System Error<br><br>The host controller sets this bit to 1 when a serious error<br>occurs during a host system access involving the host<br>controller module.                                                                                                                                                                                                                                                                                                                   | RW   | 0     |
| 3    | FLR        | Frame List Rollover<br><br>The host controller sets this bit to 1 when the<br>USBHOST.FRINDEX rolls over from its maximum value<br>to 0. The exact value at which the rollover occurs<br>depends on the frame list size.                                                                                                                                                                                                                                                              | RW   | 0     |
| 2    | PCD        | Port Change Detect<br><br>The host controller sets this bit to 1 when any port for<br>which the USBHOST.PORTSC_I[13] PO bit is set to 0<br>has a change bit transition from a 0 to a 1 or a<br>USBHOST.PORTSC_I[6] FPR bit transition from a 0 to a<br>1.<br><br>This bit is also set as a result of the<br>USBHOST.PORTSC_I[1] CSC bit being set to 1 after<br>system software has relinquished ownership of a<br>connected port by writing a 1 to a<br>USBHOST.PORTSC_I[13] PO bit. | RW   | 0     |
| 1    | USBEI      | USB Error Interrupt<br><br>The host controller sets this bit to 1 when completion of a<br>USB transaction results in an error condition.                                                                                                                                                                                                                                                                                                                                              | RW   | 0     |
| 0    | USBI       | USB Interrupt<br><br>The host controller sets this bit to 1 on completion of a<br>USB transaction, which results in the retirement of a<br>transfer descriptor that had its IOC bit set.<br><br>The host controller also sets this bit to 1 when a short<br>packet is detected (actual number of bytes received was<br>less than the expected number of bytes).                                                                                                                       | RW   | 0     |

**Table 22-221. Register Call Summary for Register USBSTS**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\]](#)

**Table 22-222. USBINTR**

|                         |                         |                         |                 |                                   |      |
|-------------------------|-------------------------|-------------------------|-----------------|-----------------------------------|------|
| <b>Address Offset</b>   | 0x0000 0018             | <b>Physical Address</b> | 0x4806 4818     | <b>Instance</b>                   | EHCI |
| <b>Description</b>      | USB interrupt enable    |                         |                 |                                   |      |
| <b>Type</b>             | RW                      |                         |                 |                                   |      |
| 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 |                                   |      |
|                         |                         |                         |                 | IAAE HSEE FLRE PCIE USBEIE USBIIE |      |
|                         |                         |                         | RESERVED        |                                   |      |

| Bits | Field Name | Description                                                                                                                                                                                                                                       | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:6 | RESERVED   | Reserved                                                                                                                                                                                                                                          | R    | 0x00000000 |
| 5    | IAAE       | Interrupt on Async Advance Enable<br><br>0x1: When the USBHOST.USBSTS[5] IAA bit is 1, the host controller issues an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing the USBHOST.USBSTS[5] IAA bit. | RW   | 0          |
| 4    | HSEE       | Host System Error Enable<br><br>0x1: When the USBHOST.USBSTS[4] HSE bit is 1, the host controller issues an interrupt. The interrupt is acknowledged by software clearing the USBHOST.USBSTS[4] HSE bit.                                          | RW   | 0          |
| 3    | FLRE       | Frame List Rollover Enable<br><br>0x1: When the USBHOST.USBSTS[3] FLR bit is 1, the host controller issues an interrupt. The interrupt is acknowledged by software clearing the USBHOST.USBSTS[3] FLR bit.                                        | RW   | 0          |
| 2    | PCIE       | Port Change Interrupt Enable<br><br>0x1: When the USBHOST.USBSTS[2] PCD bit is 1, the host controller issues an interrupt. The interrupt is acknowledged by software clearing the USBHOST.USBSTS[3] FLR bit.                                      | RW   | 0          |
| 1    | USBEIE     | USB Error Interrupt Enable<br><br>0x1: When the USBHOST.USBSTS[1] USBEI bit is 1, the host controller issues an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing the USBHOST.USBSTS[1] USBEI bit.    | RW   | 0          |
| 0    | USBIE      | USB Interrupt Enable<br><br>0x1: When the USBHOST.USBSTS[0] USBI bit is 1, the host controller issues an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing the USBHOST.USBSTS[0] USBI bit.            | RW   | 0          |

**Table 22-223. Register Call Summary for Register USBINTR**

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-224. FRINDEX**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0000 001C     | <b>Instance</b> | EHCI |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x4806 481C     |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | USB frame index |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW              |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="8">RESERVED</td><td colspan="16">FI</td></tr> </table> |                 |                 |      | 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 | RESERVED |  |  |  |  |  |  |  | FI |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |   |   |   |   |          |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |                 |      |    |    |    |    | FI |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 22-225. Register Call Summary for Register FRINDEX**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\]](#)

**Table 22-226. CTRLDSSEGMENT**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                     |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-----------------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0x0000 0020         | <b>Instance</b> | EHCI |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x4806 4820         |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 4G segment selector |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R                   |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="16">CDSS</td><td colspan="8"></td></tr> </table> |                     |                 |      | 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 | CDSS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| CDSS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                     |                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 22-227. Register Call Summary for Register CTRLDSSEGMENT**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-228. PERIODICLISTBASE**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                         |                 |      |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|------|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-----|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0000 0024             | <b>Instance</b> | EHCI |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x4806 4824             |                 |      |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Frame list base address |                 |      |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW                      |                 |      |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1" style="width: 100%; text-align: center;"> <tr> <td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr> <td colspan="12">BAL</td><td colspan="12">RESERVED</td></tr> </table> |                         |                 |      | 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 | BAL |  |  |  |  |  |  |  |  |  |  |  | RESERVED |  |  |  |  |  |  |  |  |  |  |  |
| 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 |   |   |   |   |     |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |
| BAL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                         |                 |      |    |    |    |    |    |    |    |    | RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |

## High-Speed USB Host Subsystem

www.ti.com

| Bits  | Field Name | Description                                                            | Type | Reset    |
|-------|------------|------------------------------------------------------------------------|------|----------|
| 31:12 | BAL        | Base address (low)<br>These bits correspond to memory address signals. | RW   | 0x000000 |
| 11:0  | RESERVED   | Reserved                                                               | R    | 0x000    |

**Table 22-229. Register Call Summary for Register PERIODICLISTBASE**

High-Speed USB Host Subsystem

- High-Speed USB Host Subsystem Register Summary: [0]
- High-Speed USB Host Subsystem Register Description: [1]

**Table 22-230. ASYNCLISTADDR**

|                         |                                |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |
|-------------------------|--------------------------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|------|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0028                    |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |
| <b>Physical Address</b> | 0x4806 4828                    |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | EHCI |  |  |  |  |  |
| <b>Description</b>      | Next asynchronous list address |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |
| <b>Type</b>             | RW                             |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |

|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|
| 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 |
| LPL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RESERVED |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                         | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------|------|------------|
| 31:5 | LPL        | Link Pointer Low<br><br>It contains the address of the next asynchronous queue head to be executed. | RW   | 0x00000000 |
| 4:0  | RESERVED   | Reserved                                                                                            | R    | 0x00       |

**Table 22-231. Register Call Summary for Register ASYNCLISTADDR**

High-Speed USB Host Subsystem

- High-Speed USB Host Subsystem Register Summary: [0]
- High-Speed USB Host Subsystem Register Description: [1]

**Table 22-232. CONFIGFLAG**

|                         |                          |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |
|-------------------------|--------------------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|------|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0050              |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |
| <b>Physical Address</b> | 0x4806 4850              |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | EHCI |  |  |  |  |  |
| <b>Description</b>      | Configured flag register |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |
| <b>Type</b>             | RW                       |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                      | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                         | R    | 0x00000000 |
| 0    | CF         | Configure Flag<br><br>This bit controls the default port-routing control logic.<br><br>0x0: Port routing control logic default-routes each port to an implementation dependent classic host controller.<br><br>0x1: Port routing control logic default-routes all ports to this host controller. | RW   | 0          |

**Table 22-233. Register Call Summary for Register CONFIGFLAG**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\] \[2\]](#)

**Table 22-234. PORTSC\_i**

|                         |                          |                 |            |
|-------------------------|--------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0054 + (0x04 * i) | <b>Index</b>    | i = 0 to 2 |
| <b>Physical Address</b> | 0x4806 4854 + (0x04 * i) | <b>Instance</b> | EHCI       |
| <b>Description</b>      | Port Status/Control      |                 |            |
| <b>Type</b>             | RW                       |                 |            |

| 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 |
|----------|----|----|----|----|----|----|----|-----|-----|-----|----|----|-----|----|----|----|----------|----|-----|-----|----------|------|-----|-----|-----|---|---|---|---|---|---|
| RESERVED |    |    |    |    |    |    |    | WDE | WCE | PTC |    |    | PIC | PO | PP | LS | RESERVED | PR | SUS | FPR | RESERVED | PEDC | PED | CSC | CCS |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                | Type | Reset |           |     |     |                                                                                                  |    |   |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-----------|-----|-----|--------------------------------------------------------------------------------------------------|----|---|
| 31:22 | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                   | R    | 0x000 |           |     |     |                                                                                                  |    |   |
| 21    | WDE        | Wake on Disconnect Enable<br><br>This field is 0 if the PP bit is 0.<br><br>Write 0x1: Enables the port to be sensitive to device disconnects as wake-up events.                                                                                                                                                                                                           | RW   | 0     |           |     |     |                                                                                                  |    |   |
| 20    | WCE        | Wake on Connect Enable<br><br>This field is 0 if the PP bit is 0.<br><br>Write 0x1: Enables the port to be sensitive to device connects as wake-up events.                                                                                                                                                                                                                 | RW   | 0     |           |     |     |                                                                                                  |    |   |
| 19:16 | PTC        | Port Test Control<br><br>The port is operating in specific test modes as indicated by the specific value. The encoding of the test mode bits are:<br><br>0x0: Test mode not enabled<br>0x1: Test J_STATE<br>0x2: Test K_STATE<br>0x3: Test SE0_NAK<br>0x4: Test Packet<br>0x5: Test FORCE_ENABLE<br>Others: Reserved                                                       | RW   | 0x0   |           |     |     |                                                                                                  |    |   |
| 15:14 | PIC        | Port Indicator Control (not implemented)                                                                                                                                                                                                                                                                                                                                   | R    | 0x0   |           |     |     |                                                                                                  |    |   |
| 13    | PO         | Port Owner<br><br>This bit unconditionally goes to a 0x0 when the USBHOST.CONFIGFLAG[0] CF bit makes a 0 to 1 transition. This bit unconditionally goes to 0 whenever the USBHOST.CONFIGFLAG[0] CF bit is 0.<br><br>0x1: A companion host controller owns and controls the port.                                                                                           | RW   | 1     |           |     |     |                                                                                                  |    |   |
| 12    | PP         | Port Power<br><br>The function of this bit depends on the value of the USBHOST.HCSPARAMS[4] PPC bit. The behavior is as follows:<br><br><table border="1"> <tr> <th>PPC</th> <th>PP</th> <th>Operation</th> </tr> <tr> <td>0x0</td> <td>0x1</td> <td>Host controller does not have port power.<br/>control switches. Each port is hard-wired to power.</td> </tr> </table> | PPC  | PP    | Operation | 0x0 | 0x1 | Host controller does not have port power.<br>control switches. Each port is hard-wired to power. | RW | 0 |
| PPC   | PP         | Operation                                                                                                                                                                                                                                                                                                                                                                  |      |       |           |     |     |                                                                                                  |    |   |
| 0x0   | 0x1        | Host controller does not have port power.<br>control switches. Each port is hard-wired to power.                                                                                                                                                                                                                                                                           |      |       |           |     |     |                                                                                                  |    |   |

## High-Speed USB Host Subsystem

www.ti.com

| Bits        | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type        | Reset     |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
|-------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------|----------------|-----|-----|-------------------------------------------|-----|---------|-------------------------------------------|-----|---------|----------------------------------------------|-----|-----------|-------------------------------------------|---|-----|
|             |            | 0x1 N/A Host controller has port power control switches. This bit represents the current setting of the switch (0 = Off, 1 = On).<br><br>When an overcurrent condition is detected on a powered port and the USBHOST.HCSPARAMS[4] PPC bit is a 1, the PP bit in each affected port may be transitioned by the host controller from 1 to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                  |             |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 11:10       | LS         | Line Status<br><br>These bits reflect the current logical levels of the D+ (bit 11) and D- (bit 10) signal lines. This field is valid only when the port enable bit is 0 and the current connect status bit is set to 1. The encoding of the bits is:<br><br><table> <thead> <tr> <th>Bits[11:10]</th> <th>USB State</th> <th>Interpretation</th> </tr> </thead> <tbody> <tr> <td>0x0</td> <td>SE0</td> <td>Not low-speed device, perform EHCI reset.</td> </tr> <tr> <td>0x2</td> <td>J-state</td> <td>Not low-speed device, perform EHCI reset.</td> </tr> <tr> <td>0x1</td> <td>K-state</td> <td>Low-speed device, release ownership of port.</td> </tr> <tr> <td>0x3</td> <td>Undefined</td> <td>Not low-speed device, perform EHCI reset.</td> </tr> </tbody> </table> | Bits[11:10] | USB State | Interpretation | 0x0 | SE0 | Not low-speed device, perform EHCI reset. | 0x2 | J-state | Not low-speed device, perform EHCI reset. | 0x1 | K-state | Low-speed device, release ownership of port. | 0x3 | Undefined | Not low-speed device, perform EHCI reset. | R | 0x0 |
| Bits[11:10] | USB State  | Interpretation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 0x0         | SE0        | Not low-speed device, perform EHCI reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 0x2         | J-state    | Not low-speed device, perform EHCI reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 0x1         | K-state    | Low-speed device, release ownership of port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |             |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 0x3         | Undefined  | Not low-speed device, perform EHCI reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 9           | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R           | 0         |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 8           | PR         | Port Reset<br><br>This field is 0 if the PP bit is 0.<br><br>0x0: Port is not in reset.<br><br>0x1: Port is in reset.<br><br>Write 0x0: Terminate the bus reset sequence.<br><br>Write 0x1 when at 0x0: The bus reset sequence is started.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW          | 0         |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 7           | SUS        | Suspend<br><br>This field is 0 if the PP bit is 0.<br><br>0x0 when PED = 0x1: Port enabled<br><br>0x1 when PED = 0x1: Port in suspend state<br><br>When PED = 0x0: Port disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW          | 0         |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 6           | FPR        | Force Port Resume<br><br>This field is 0 if the PP bit is 0.<br><br>0x0: No resume (K-state) detected/driven on port<br><br>0x1: Resume detected/driven on port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW          | 0         |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 5:4         | RESERVED   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW          | 0         |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 3           | PEDC       | Port Enabled/Disabled Change<br><br>This field is 0 if the PP bit is 0.<br><br>Read 0x0: No change.<br><br>Read 0x1: Port enabled/disabled status has changed.<br><br>Write 0x1: Clears this bit to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW          | 0         |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 2           | PED        | Port Enabled/Disabled<br><br>Software cannot enable a port by writing a 1 to this field. The host controller only sets this to 1 when the reset sequence determines that the attached device is a high-speed device.<br><br>Ports can be disabled by either a fault condition (disconnect event or other fault condition) or by host software.<br><br>This field is 0 if the PP bit is 0.<br><br>0x0: Disable<br><br>0x1: Enable                                                                                                                                                                                                                                                                                                                                            | RW          | 0         |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |
| 1           | CSC        | Connect Status Change<br><br>Indicates a change has occurred in the port CCS bit.<br><br>This field is 0 if the PP bit is 0.<br><br>Read 0x0: No change                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW          | 0         |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |   |     |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                 | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | Read 0x1: Change in current connect status<br>Write 0x1: Clears this bit to 0                                                                                                                                                                                                               |      |       |
| 0    | CCS        | <p>Current Connect Status</p> <p>This value reflects the current state of the port, and may not correspond directly to the event that caused the CSC bit to be set.</p> <p>This field is 0 if the PP bit is 0.</p> <p>0x0: No device is present.</p> <p>0x1: Device is present on port.</p> | R    | 0     |

**Table 22-235. Register Call Summary for Register PORTSC\_i**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\] \[2\] \[3\] \[4\]](#)

**Table 22-236. INSNREG00**

|                       |                                     |                         |             |                 |      |
|-----------------------|-------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 0090                         | <b>Physical Address</b> | 0x4806 4890 | <b>Instance</b> | EHCI |
| <b>Description</b>    | Implementation-specific register #0 |                         |             |                 |      |
| <b>Type</b>           | RW                                  |                         |             |                 |      |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
|                         | RESERVED                |                       | UFRAME_CNT      |

| Bits  | Field Name | Description                                                                                      | Type | Reset   |
|-------|------------|--------------------------------------------------------------------------------------------------|------|---------|
| 31:14 | RESERVED   | Reserved                                                                                         | R    | 0x00000 |
| 13:1  | UFRAME_CNT | 1-microframe length value, to reduce simulation time<br>SIMULATIONS ONLY, NOT AN ACTUAL REGISTER | RW   | 0x0000  |
| 0     | EN         | Enable of this register                                                                          | RW   | 0       |

**Table 22-237. Register Call Summary for Register INSNREG00**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-238. INSNREG01**

|                       |                                     |                         |             |                 |      |
|-----------------------|-------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 0094                         | <b>Physical Address</b> | 0x4806 4894 | <b>Instance</b> | EHCI |
| <b>Description</b>    | Implementation-specific register #1 |                         |             |                 |      |
| <b>Type</b>           | RW                                  |                         |             |                 |      |

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
|                         | OUT_THRESHOLD           |                       | IN_THRESHOLD    |

| Bits  | Field Name    | Description                                                  | Type | Reset  |
|-------|---------------|--------------------------------------------------------------|------|--------|
| 31:16 | OUT_THRESHOLD | Programmable output packet buffer threshold, in 32-bit words | RW   | 0x0020 |
| 15:0  | IN_THRESHOLD  | Programmable input packet buffer threshold, in 32-bit words  | RW   | 0x0020 |

**Table 22-239. Register Call Summary for Register INSNREG01**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)
- [High-Speed USB Host Subsystem Register Description: \[1\]](#)

**Table 22-240. INSNREG02**

|                       |                                     |                         |             |                 |      |
|-----------------------|-------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 0098                         | <b>Physical Address</b> | 0x4806 4898 | <b>Instance</b> | EHCI |
| <b>Description</b>    | Implementation-specific register #2 |                         |             |                 |      |
| <b>Type</b>           | RW                                  |                         |             |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BUF_DEPTH |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                       | Type | Reset   |
|-------|------------|---------------------------------------------------|------|---------|
| 31:12 | RESERVED   | Reserved                                          | R    | 0x00000 |
| 11:0  | BUF_DEPTH  | Programmable packet buffer depth, in 32-bit words | RW   | 0x080   |

**Table 22-241. Register Call Summary for Register INSNREG02**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-242. INSNREG03**

|                       |                                     |                         |             |                 |      |
|-----------------------|-------------------------------------|-------------------------|-------------|-----------------|------|
| <b>Address Offset</b> | 0x0000 009C                         | <b>Physical Address</b> | 0x4806 489C | <b>Instance</b> | EHCI |
| <b>Description</b>    | Implementation-specific register #3 |                         |             |                 |      |
| <b>Type</b>           | RW                                  |                         |             |                 |      |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name   | Description                                                                            | Type | Reset      |
|------|--------------|----------------------------------------------------------------------------------------|------|------------|
| 31:1 | RESERVED     | Reserved                                                                               | R    | 0x00000000 |
| 0    | BRK_MEM_TRSF | Break Memory Transfer, with <a href="#">INSNREG01</a><br>0x0: Disabled<br>0x1: Enabled | RW   | 0x1        |

**Table 22-243. Register Call Summary for Register INSNREG03**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-244. INSNREG04**

|                         |                                     |                         |                 |                 |               |
|-------------------------|-------------------------------------|-------------------------|-----------------|-----------------|---------------|
| <b>Address Offset</b>   | 0x0000 00A0                         | <b>Physical Address</b> | 0x4806 48A0     | <b>Instance</b> | EHCI          |
| <b>Description</b>      | Implementation-specific register #4 |                         |                 |                 |               |
| <b>Type</b>             | RW                                  |                         |                 |                 |               |
| 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 |                 |               |
|                         |                                     |                         |                 | NAK_FIX_DIS     | RESERVED      |
|                         |                                     |                         |                 | SHORT_PORT_ENUM | HCCPARAMS_WRE |
|                         |                                     |                         |                 | HCCPARAMS_WRE   | HCSPARAMS_WRE |

RESERVED

| Bits | Field Name      | Description                                                        | Type | Reset     |
|------|-----------------|--------------------------------------------------------------------|------|-----------|
| 31:5 | RESERVED        | Reserved                                                           | R    | 0x0000000 |
| 4    | NAK_FIX_DIS     | Disable NAK fix (don't touch)                                      | RW   | 0         |
| 3    | RESERVED        | Reserved                                                           | R    | 0         |
| 2    | SHORT_PORT_ENUM | Scale down Port enumeration time (debug)                           | RW   | 0         |
| 1    | HCCPARAMS_WRE   | Make read-only <a href="#">HCCPARAMS</a> register writable (debug) | RW   | 0         |
| 0    | HCSPARAMS_WRE   | Make read-only <a href="#">HCSPARAMS</a> register writable (debug) | RW   | 0         |

**Table 22-245. Register Call Summary for Register INSNREG04**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-246. INSNREG05\_UTMI**

|                         |                                                                          |                         |                 |                 |      |
|-------------------------|--------------------------------------------------------------------------|-------------------------|-----------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 00A4                                                              | <b>Physical Address</b> | 0x4806 48A4     | <b>Instance</b> | EHCI |
| <b>Description</b>      | Implementation-specific register #5 Register functionality for UTMI mode |                         |                 |                 |      |
| <b>Type</b>             | RW                                                                       |                         |                 |                 |      |
| 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 |                 |      |
| RESERVED                | VBUSY                                                                    | VPORT                   | VCONTROL        | VSTATUS         |      |

| Bits  | Field Name | Description                                                             | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------|------|--------|
| 31:18 | RESERVED   | Reserved                                                                | R    | 0x0000 |
| 17    | VBUSY      | 0x0: Vendor interface is done/inactive<br>0x1: Vendor interface is busy | R    | 0      |

## High-Speed USB Host Subsystem

www.ti.com

| Bits  | Field Name    | Description                                                                                                                                                | Type | Reset |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 16:13 | VPORT         | Vendor interface port selection<br>0x1: Port 1 vendor interface selected<br>0x2: Port 2 vendor interface selected<br>0x3: Port 3 vendor interface selected | RW   | 0x0   |
| 12    | VCONTROLLOADM | UTMI VcontrolLoadM output (active-low)<br>0x0: Load Vcontrol value into PHY<br>0x1: No Action                                                              | RW   | 0     |
| 11:8  | VCONTROL      | UTMI Vcontrol output, to be loaded into the PHY                                                                                                            | RW   | 0x0   |
| 7:0   | VSTATUS       | UTMI Vstatus input image, from PHY                                                                                                                         | R    | 0x00  |

**Table 22-247. Register Call Summary for Register INSNREG05\_UTMI**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

**Table 22-248. INSNREG05\_ULPI**

|                  |                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|--------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 00A4                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Physical Address | 0x4806 48A4                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description      | Implementation-specific register #5 Register functionality for ULPI mode |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type             | RW                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |

|         |          |    |        |       |    |        |    |    |    |           |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------|----------|----|--------|-------|----|--------|----|----|----|-----------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| CONTROL | RESERVED |    | PORSEL | OPSEL |    | REGADD |    |    |    | EXTREGADD |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                      | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | CONTROL    | Control/status of the ULPI register access<br>0x0: ULPI access done<br>0x1: Start ULPI access                                    | RW   | 0     |
| 30:28 | RESERVED   | Reserved                                                                                                                         | R    | 0x0   |
| 27:24 | PORSEL     | 0x1: Port 1 selected for register access<br>0x2: Port 2 selected for register access<br>0x3: Port 3 selected for register access | RW   | 0x0   |
| 23:22 | OPSEL      | 0x2: Register access is Write<br>0x3: Register access is Read                                                                    | RW   | 0x0   |
| 21:16 | REGADD     | ULPI direct register address, for any value different than 0x2F.<br>0x2F: Triggers an extended address                           | RW   | 0x00  |
| 15:8  | EXTREGADD  | Address for extended register accesses. Don't care for direct accesses.                                                          | RW   | 0x00  |
| 7:0   | WRDATA     | Read/Write data of register access                                                                                               | RW   | 0x00  |

**Table 22-249. Register Call Summary for Register INSNREG05\_ULPI**

High-Speed USB Host Subsystem

- [High-Speed USB Host Subsystem Register Summary: \[0\]](#)

## **Memory Stick PRO Host Controller**

This chapter presents an overview of the Memory Stick PRO™ host controller in the device.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| <b>Topic</b>                                                | <b>Page</b> |
|-------------------------------------------------------------|-------------|
| <b>23.1 Memory Stick PRO Host Controller Overview .....</b> | <b>3392</b> |

## 23.1 Memory Stick PRO Host Controller Overview

The Memory Stick PRO host controller provides the device with an interface between a microprocessor unit (MPU) local host (LH) and either a Memory Stick® or a Memory Stick PRO card.

The Memory Stick PRO host controller is connected to the L4-Core interconnect.

Figure 23-1 shows an overview of the Memory Stick PRO host controller.

**Figure 23-1. Memory Stick PRO Host Controller Overview**



ms-pro-001

### 23.1.1 Main Features

The Memory Stick PRO host controller includes the following main features:

- Supports Memory Stick v1.x and Memory Stick PRO
- Data transmit/receive internal first-in first-out (FIFO) (64 bits x 4)
- Cyclic redundancy check (CRC) circuit
- Memory Stick serial clock (Memory Stick v1.x: 19.2 MHz; Memory Stick PRO: 32 MHz with 96-MHz functional clock source)
- Direct memory access (DMA) supported
- Lower 16-/32-bit access possible
- Little endian (internally big endian)
- L4 interconnect support

**NOTE:** Other information about Memory Stick PRO host controller are not available in the public domain.

## MMC/SD/SDIO Card Interface

This chapter describes the features and functions of the multimedia card/SD/SD I/O (MMC/SDIO) card interface.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                                 | Page        |
|-------------------------------------------------------|-------------|
| <b>24.1 MMC/SD/SDIO Overview .....</b>                | <b>3394</b> |
| <b>24.2 MMC/SD/SDIO Environment .....</b>             | <b>3397</b> |
| <b>24.3 MMC/SD/SDIO Integration .....</b>             | <b>3405</b> |
| <b>24.4 MMC/SD/SDIO Functional Description .....</b>  | <b>3413</b> |
| <b>24.5 MMC/SD/SDIO Basic Programming Model .....</b> | <b>3426</b> |
| <b>24.6 MMC/SD/SDIO Use Cases and Tips .....</b>      | <b>3442</b> |
| <b>24.7 MMC/SD/SDIO Register Manual .....</b>         | <b>3454</b> |

## 24.1 MMC/SD/SDIO Overview

The multimedia card high-speed/SD/SD I/O (MMC/SD/SDIO) host controller provides an interface between a local host (LH) such as a microprocessor unit (MPU) or digital signal processor (DSP) and either MMC, SD memory cards, or SDIO cards and handles MMC/SD/SDIO transactions with minimal LH intervention.

The application interface manages transaction semantics. The MMC/SD/SDIO host controller deals with MMC/SD/SDIO protocol at transmission level, data packing, adding cyclic redundancy checks (CRC), start/end bit, and checking for syntactical correctness.

The application interface can send every MMC/SD/SDIO command and either poll for the status of the adapter or wait for an interrupt request, which is sent back in case of exceptions or to warn of end of operation.

The application interface can read card responses or flag registers. It can also mask individual interrupt sources. All these operations can be performed by reading and writing control registers. The MMC/SD/SDIO host controller also supports two DMA channels.

There are three MMC/SD/SDIO host controllers inside the device: [Figure 24-1](#) gives an overview of the MMC/SD/SDIO controller instances 1 and 3, and [Figure 24-2](#) gives an overview of the MMC/SD/SDIO2 controller instance.

**Figure 24-1. MMC/SD/SDIO1 and 3 Overview**



**Figure 24-2. MMC/SD/SDIO2 Overview**


#### 24.1.1 MMC/SD/SDIO Features

The main features of the MMC/SD/SDIO host controller are:

- Full compliance with MMC command/response sets as defined in the *Multimedia Card System Specification*, v4.2 including high-capacity (size > 2GB) cards HC MMC.
- Full compliance with SD command/response sets as defined in the *SD Memory Card Specifications*, v2.0 including high-capacity SDHC cards up to 32GB.
- Full compliance with SDIO command/response sets and interrupt/read-wait mode as defined in the *SDIO Card Specification, Part E1*, v2.00
- Full compliance with sets as defined in the *SD Card Specification, Part A2, SD Host Controller Standard Specification*, v2.00
- Full compliance with MMC bus testing procedure as defined in the *Multimedia Card System Specification*, v4.2
- Full compliance with CE-ATA command/response sets as defined in the *CE-ATA Standard Specification*
- Full compliance with ATA for MMCA specification
- Flexible architecture allowing support for new command structure
- Support:
  - 1-bit or 4-bit transfer mode specifications for SD and SDIO cards
  - 1-bit, 4-bit, or 8-bit transfer mode specifications for MMC cards (1-bit and 4-bit only available for instance 1)
- Built-in 1024-byte buffer for read or write
- 32-bit-wide access bus to maximize bus throughput
- Single interrupt line for multiple interrupt source events
- Two slave DMA channels (1 for TX, 1 for RX)

- Designed for low power
- Programmable clock generation
- Support SDIO Read Wait and Suspend/Resume functions
- Support Stop at block gap
- Support command completion signal (CCS) and command completion signal disable (CCSD) management as specified in the *CE-ATA Standard Specification*

The known limitations are as follows:

- No built-in hardware support for error correction codes (ECC). See the *Multimedia Card System Specification*, v4.2, and the *SD Memory Card Specifications*, v2.0, for details about ECC.
- The maximum block size defined in the *SD Memory Card Specifications*, v2.0, that the host driver can read and write to the buffer in the host controller is 2048 bytes. MMC supports a maximum block size of 1024 bytes. Up to 512 byte transfers, the buffer in MMC is considered as a double buffering with ping-pong management; half of the buffer can be written while the other part is read. For 512 to 1024 byte transfers, the entire buffer is dedicated to the transfer (read only or write only).

---

**NOTE:** MMC/e.MMC compliance versus the *Multimedia Card System Specification*, v4.3 (or v4.4):

Full compliance with the MMC command/response sets and MMC bus testing procedure, as defined in the *Multimedia Card System Specification*, v4.2, does not prevent the use of e.MMC version 4.3 (or 4.4) devices with the OMAP36xx, because e.MMC devices are backward compatible. Only the e.MMC version 4.3 (or 4.4) boot operation is not supported in the OMAP36xx. Boot operation in the OMAP36xx follows the TI booting scheme, ID booting from standard memory array.

---

The differences between the MMC/SD/SDIO host controllers and a standard SD host controller are defined by the *SD Card Specification, Part A2, SD Host Controller Standard Specification*, v1.00, as follows:

- The MMC/SD/SDIO host controllers support MMC cards.
- The MMC/SD/SDIO host controller is defined as a DMA slave device. A standard SD host controller is defined as a DMA master controller that can start and stop a DMA transfer. MMC/SD/SDIO host controllers support DMA transfers through slave DMA requests.
- The clock divider in MMC/SD/SDIO host controller supports a wider range of frequency than specified in the *SD Memory Card Specifications*, v2.0. The MMC/SD/SDIO host controller supports odd and even clock ratio.
- The MMC/SD/SDIO host controller supports configurable busy time-out.

## 24.2 MMC/SD/SDIO Environment

One MMC/SD/SDIO host controller can support one MMC memory card, one SD memory card, or one SDIO card.

Other combinations (for example, two SD cards, one MMC card, and one SD card) are not supported through a single controller.

- The first controller (MMC/SD/SDIO1) integrates an internal transceiver that allows a direct connection to the MMC/SD/SDIO card (1.8 and 3V), without external transceiver. It supports 1-bit and 4-bit data transfer modes.
- The second controller (MMC/SD/SDIO2) allows connecting MMC/SD/SDIO cards (only 1.8V cards) or an external device that uses the MMC/SD/SDIO interface (WLAN device for example). The second instance also supports an external transceiver and provides direction signals for data and command. It supports 1-bit, 4-bit and 8-bit data transfer modes. Using an external transceiver device precludes 8-bit transfer mode.
- The third controller (MMC/SD/SDIO3) allows connecting MMC/SD/SDIO cards (only 1.8V cards) or an external device that uses the MMC/SD/SDIO interface (Wireless USB card for example). This interface is used without external transceiver. It supports 1-bit, 4-bit and 8-bit data transfer modes.

### 24.2.1 MMC/SD/SDIO Connected to MMC, SD, or SDIO Card

Figure 24-3 shows MMC/SD/SDIOi host controller, instance 1, 2 or 3, connected to an MMC, an SD, or an SDIO card and its related external connections.

**Figure 24-3. MMC/SD/SDIO Connected to MMC, SD, or SDIO Card Without External Transceiver**



mmchs-002

### 24.2.2 MMC/SD/SDIO Connected to MMC, SD, or SDIO Card Through an External Transceiver Device

This connection is supported only by the MMC/SD/SDIO2 host controller. Figure 24-4 shows the MMC/SD/SDIO2 host controller connected to an MMC, an SD, or an SDIO card through an external transceiver device.

**Figure 24-4. MMC/SD/SDIO2 Connected to MMC, SD, SDIO Card with External Transceiver**

mmchs-003

## 24.2.3 MMC/SD/SDIO Functional Interfaces

### 24.2.3.1 Basic MMC/SD/SDIOi Pins Without External Transceiver

Figure 24-5 shows the MMC/SD/SDIOi host controller interface signals (instance 1, 2 or 3).

**Figure 24-5. MMC/SD/SDIOi Interface Signals**

mmchs-004

Table 24-1 describes the MMC/SD/SDIOi inputs/outputs.

**Table 24-1. MMC/SD/SDIOi I/O Description**

| Signal Name   | I/O <sup>(1)</sup> | Description                                        | Reset Value |
|---------------|--------------------|----------------------------------------------------|-------------|
| mmci_clk      | O                  | External clock for MMC/SD/SDIO card <sup>(2)</sup> | 0           |
| mmci_cmd      | I/O                | Command signal                                     | 0           |
| mmci_dat[3:0] | I/O                | Data signals                                       | 0           |

<sup>(1)</sup> I = Input; O = Output

<sup>(2)</sup> This output signal is also used as retiming input (the CONTROL\_PADCONF\_x.INPUTENABLE bit must be set to 1).

**Table 24-1. MMC/SD/SDIOi I/O Description (continued)**

| Signal Name   | I/O <sup>(1)</sup> | Description                              | Reset Value |
|---------------|--------------------|------------------------------------------|-------------|
| mmc1_dat[7:4] | I/O                | Data signals (only for instance 2 and 3) | 0           |

#### 24.2.3.2 Basic MMC/SD/SDIO2 Pins With External Transceiver

Figure 24-6 shows the MMC/SD/SDIO2 host controller interface signals.

**Figure 24-6. MMC/SD/SDIO2 Interface Signals**

mmchs-005

Table 24-2 describes the MMC/SD/SDIO2 inputs/outputs.

**Table 24-2. MMC/SD/SDIO2 I/O Description**

| Signal Name   | I/O | Description                                                                                                                                                                                                                                                                                                             | Reset Value |
|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| mmc2_clk      | O   | External clock for MMC/SD/SDIO card                                                                                                                                                                                                                                                                                     | 0           |
| mmc2_clkin    | I   | Input clock from MMC/SD/SDIO card                                                                                                                                                                                                                                                                                       | 0           |
| mmc2_cmd      | I/O | Command signal                                                                                                                                                                                                                                                                                                          | 0           |
| mmc2_dir_cmd  | O   | Direction control for mmc2_cmd signal case an external transceiver is used (high when transmit, low when receive)                                                                                                                                                                                                       | 0           |
| mmc2_dat[3:0] | I/O | Data signals                                                                                                                                                                                                                                                                                                            | 0           |
| mmc2_dir_dat0 | O   | Direction control for mmc2_dat0 signal when an external transceiver is used (high when transmit, low when receive)                                                                                                                                                                                                      | 0           |
| mmc2_dir_dat1 | O   | Direction control for mmc2_dat1 and mmc2_dat3 signal when an external transceiver is used (high when transmit, low when receive)                                                                                                                                                                                        | 0           |
| mmc2_dir_dat2 | O   | Direction control for mmc2_dat2 signal when an external transceiver is used (high when transmit, low when receive)                                                                                                                                                                                                      | 0           |
| mmc2_dir_dat3 | O   | Direction control for mmc2_dat[7:4] signal when an external transceiver is used (high when transmit, low when receive). Unusable on the device because mmc1_dat[7:4] are muxed with other direction control signals. See <a href="#">Chapter 13, System Control Module</a> for further details on the pin multiplexing. | 0           |

#### 24.2.3.3 MMC/SD/SDIO Protocol and Data Format

The bus protocol between the MMC/SD/SDIOi host controller and the card is message-based. Each message is represented by one of the following parts:

**Command:** a command starts an operation. The command is transferred serially from the MMC/SD/SDIO host controller to the card on the mmc1\_cmd line.

**Response:** a response is an answer to a command. The response is sent from the card to the MMC/SD/SDIO host controller. It is transferred serially on the mmc1\_cmd line.

**Data:** data are transferred from the MMC/SD/SDIOi host controller to the card or from a card to the MMC/SD/SDIO host controller using the DATA lines.

**Busy:** the mmci\_dat0 signal is maintained low by the card as far as it is programming the data received.

**CRC status:** CRC result is sent by the card through the mmci\_dat0 line when executing a write transfer. In the case of transmission error, occurring on any of the active data lines, the card sends a negative CRC status on mmci\_dat0. In the case of successful transmission, over all active data lines, the card sends a positive CRC status on mmci\_dat0 and starts the data programming procedure.

#### 24.2.3.3.1 Protocol

There are two types of data transfer:

- Sequential operation
- Block-oriented operation

There are specific commands for each type of operation (sequential or block-oriented).

See the *Multimedia Card System Specification*, v4.2, the *SD Memory Card Specifications*, v2.0, and the *SDIO Card Specification, Part E1*, August 2004, for details about commands and programming sequences supported by the MMC, SD, and SDIO cards.

Figure 24-7 and Figure 24-8 show how sequential operations are defined. Sequential operation is only for 1-bit transfer and initiates a continuous data stream. The transfer terminates when a stop command follows on the mmci\_cmd line.

#### CAUTION

Stream commands are supported only by MMC cards.

**Figure 24-7. Sequential Read Operation (MMC Cards Only)**



**Figure 24-8. Sequential Write Operation (MMC Cards Only)**



[Figure 24-9](#) and [Figure 24-10](#) show how multiple block-oriented operations are defined. A multiple block-oriented operation sends a data block plus CRC bits. The transfer terminates when a stop command follows on the mmci\_cmd line. These operations are available for all kinds of cards.

**Figure 24-9. Multiple Block Read Operation**



mmchs-008

**Figure 24-10. Multiple Block Write Operation with Card Busy Signal**



mmchs-009

**NOTE:**

1. The card busy signal is not always generated by the card; the previous examples show a particular case.
2. It is software responsibility to do a software reset (set MMCI.[MMCHS\\_SYSCTL\[26\]](#) SRD bit to 0x1) after data timeout to ensure mmci\_clk is stopped
3. For multiblock transfer, and especially for MMC cards, you can abort a transfer without using a stop command. Use a CMD23 before data transfer to define the number of blocks that will be transferred, then the transfer stops automatically after the last block (if the MMC card supports this feature).

### 24.2.3.3.2 Data Format

#### Coding Scheme for Command Token

Command tokens always start with 0 and end with 1. The second bit is a transmitter bit: 1 for a host command. The content is the command index (coded by 6 bits) and an argument (for example, an address), coded by 32 bits. The content is protected by 7-bit CRC checksum (see [Figure 24-11](#)).

**Figure 24-11. Command Token Format**



#### Coding Scheme for Response Token

Response tokens always start with 0 and end with a 1. The second bit is a transmitter bit: 0 for a card response. The content is different for each type of response (R1, R2, R3, R4, and R5 R6 [for SDIO]) and the content is protected by 7-bit CRC checksum (see [Figure 24-12](#) and [Figure 24-13](#)). Depending on the type of commands sent to the card, the [MMCHS\\_CMD](#) register must be configured differently to avoid false CRC or index errors to be flagged on command response (see [Table 24-3](#)). For more details about response types, see the *Multimedia Card System Specification*, v4.2, the *SD Memory Card Specifications*, v2.0, or the *SDIO Card Specification, Part E1*, v1.10.

**Figure 24-12. Response Token Format (R1, R3, R4, R5, R6)**



**Figure 24-13. Response Token Format (R2)**



**Table 24-3. Relation Between Configuration and Name of Response Type<sup>(1)</sup>**

| Response Type<br><b>MMCi.MMCHS_CMD[17:16]</b><br>RSP_TYPE | Index Check Enable<br><b>MMCi.MMCHS_CMD[20]</b><br>CICE | CRC Check Enable<br><b>MMCi.MMCHS_CMD[19]</b><br>CCCE | Name of Response Type |
|-----------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------------|-----------------------|
| 00                                                        | 0                                                       | 0                                                     | No Response           |
| 01                                                        | 0                                                       | 1                                                     | R2                    |
| 10                                                        | 0                                                       | 0                                                     | R3 (R4 for SD cards)  |
| 10                                                        | 1                                                       | 1                                                     | R1, R6, R5            |
| 11                                                        | 1                                                       | 1                                                     | R1b, R5b              |

<sup>(1)</sup> The MMC/SD/SDIOi host controller assumes that both clocks may be switched off, whatever the value set in the MMCi.MMCHS\_SYSConfig[9:8] CLOCKACTIVITY bit.

### Coding Scheme for Data Token

Data tokens always start with 0 and end with 1 (see [Figure 24-14](#), [Figure 24-15](#), and [Figure 24-16](#)).

**Figure 24-14. Data Token Format for 1-Bit Transfers**

**Figure 24-15. Data Token Format for 4-Bit Transfers**


**Figure 24-16. Data Token Format for 8-Bit Transfers**

mmchs-015

## 24.3 MMC/SD/SDIO Integration

[Figure 24-17](#) shows the internal connections between the three instances of the MMC/SD/SDIO host controller and the other modules

**Figure 24-17. MMC/SD/SDIO1 Integration**



mmchs-016

### 24.3.1 Clocking, Reset, and Power-Management Scheme

#### 24.3.1.1 Clocks

##### 24.3.1.1.1 Module Clocks

The MMC/SD/SDIO receives three clocks:

- A fixed functional clock of 96 MHz (the MMC<sub>i</sub>\_FCLK) independent of the device external clock frequency
- An interface clock (the MMC<sub>i</sub>\_ICLK) for interfacing with L4 interconnects (register accesses)
- A debounce clock, the MMC<sub>i</sub>\_32K for reset process only

All these clocks are generated and controlled by the power, reset, and clock manager (PRCM) module (see [Chapter 3, Power, Reset, and Clock Management](#) for more information).

#### 24.3.1.1.2 Power Management

The MMC/SD/SDIO host controller can enter into different modes and save power:

- Normal mode
- Idle mode

The two modes are mutually exclusive (the module can be in normal mode or in idle mode). The MMC/SD/SDIO host controller is compliant with the PRCM module handshake protocol.

##### Normal Mode

The autogating of interface and functional clocks occurs when the following conditions are met:

- The MMCI.[MMCHS\\_SYSCONFIG\[0\]](#) AUTOIDLE bit is set to 1 (I = 1 for MMC/SD/SDIO1, 2 for MMC/SD/SDIO2 and 3 for MMC/SD/SDIO3 instances).
- There is no transaction on the MMC interface.

The autogating of interface and functional clocks stops when the following conditions are met:

- A register access occurs through the L4 interconnect.
- A wake-up event occurs (an interrupt from a SDIO card).
- A transaction on the MMC/SD/SIO interface starts.

Then the MMC/SD/SDIO host controller enters in low-power state (MMCI\_ICLK clock autogated) even if MMCI.[MMCHS\\_SYSCONFIG\[0\]](#) AUTOIDLE is set to 0.

The functional clock is internally switched off and only interconnect read and write accesses are allowed.

##### Idle Mode

The MMCI\_ICLK and MMCI\_FCLK clocks provided to MMC/SD/SDIO are switched off upon a PRCM module request. They are switched back upon module request.

The MMC/SD/SDIO host controller complies with the PRCM module handshaking protocol:

- Idle request from the system power manager
- Idle acknowledgment from the MMC/SD/SDIO host controller
- Wake-up request from the MMC/SD/SDIO host controller

The idle acknowledgment varies according to the MMCI.[MMCHS\\_SYSCONFIG\[4:3\]](#) SIDLEMODE bit field:

- 0x0: Force-idle mode. The MMC/SD/SDIO host controller acknowledges the system power manager request unconditionally.
- 0x1: No-idle mode. The MMC/SD/SDIO host controller ignores the system power manager request and behaves normally as if the request was not asserted.
- 0x2: Smart-idle mode. The MMC/SD/SDIO host controller acknowledges the system power manager request according to its internal state.

During the smart-idle mode period, the MMC/SD/SDIO host controller acknowledges that the MMCI\_ICLK and MMCI\_FCLK clocks may be switched off whatever the value set in the MMCI.[MMCHS\\_SYSCONFIG\[9:8\]](#) CLOCKACTIVITY field.

##### Transition From Normal Mode to Smart-Idle Mode

Smart-idle mode is enabled when the MMCI.[MMCHS\\_SYSCONFIG\[4:3\]](#) SIDLEMODE bit field is set to 0x2.

The MMC/SD/SDIOi host controller goes into idle mode when the PRCM issues an idle request, according to its internal activity.

During normal to idle mode transition, any access to the registers of the MMC/SD/SDIOi host controller generates an error as long as the MMCI\_ICLK clock is alive. The PRCM.CM\_IDLEST1\_CORE[25] ST\_MMC2 and (respectively the PRCM.CM\_IDLEST1\_CORE[24] ST\_MMC1 bit) is set to 0x0 when the MMC/SD/SDIO2 module (respectively the MMC/SD/SDIO1 module) can be accessed.

The MMC/SD/SDIO host controller acknowledges the idle request from the PRCM after ensuring the following:

- The current multi/single-block transfer is completed.
- Any interrupt or DMA request is asserted.
- There is no card interrupt on mmci\_dat[1] signal.

As long as the MMC/SD/SDIOi controller do not acknowledge the idle request, if an event occurs, the MMC/SD/SDIOi host controller can still generate an interrupt or a DMA request. In this case, the module ignores the idle request from the PRCM.

As soon as the MMC/SD/SDIOi controller acknowledges the idle request from the PRCM, the module does not assert any new interrupt or DMA request.

### Wake-Up Event in Smart-Idle Mode

The wake-up feature is enabled when the following enable wake-up bits are set:

- MMCI.MMCHS\_SYSCONFIG[2] ENAWAKEUP bit is set to 0x1
- MMCI.MMCHS\_HCTL[24] IWE bit is set to 0x1
- MMCI.MMCHS\_IE[8] CIRQ\_ENABLE bit is set to 0x1

The wakeup is generated only in smart-idle mode only, when module is in idle mode.

Table 24-4 lists the supported cases in smart-idle mode.

**Table 24-4. Smart Idle Mode and Wake-Up Capabilities**

| Mode           | MMCI_ICLK clock                    | MMCI_FCLK clock                    | Wake-up Event                                                                                           |
|----------------|------------------------------------|------------------------------------|---------------------------------------------------------------------------------------------------------|
| Card interrupt | May be switched off <sup>(1)</sup> | May be switched off <sup>(1)</sup> | The module sends an asynchronous wake-up request on detection of a card interrupt on mmci_dat[1] signal |

<sup>(1)</sup> The MMC/SD/SDIOi host controller assumes that both clocks may be switched off, whatever the value set in the MMCI.MMCHS\_SYSCONFIG[9:8] CLOCKACTIVITY bit.

### Transition From Smart-Idle Mode to Normal Mode

The MMC/SD/SDIO host controller detects the end of the idle period when the PRCM deasserts the idle request.

For the wake-up event, there is a corresponding interrupt status in the MMCI.MMCHS\_STAT register. The MMC/SD/SDIOi host controller operates the conversion between wake-up and interrupt (or DMA request) upon exit from smart-idle mode if the associated enable bit is set in the MMCI.MMCHS\_ISE register.

Interrupts and wake-up events have independent enable/disable controls, accessible through the MMCI.MMCHS\_HCTL and MMCI.MMCHS\_ISE registers. The overall consistency must be ensured by software.

The interrupt status register MMCI.MMCHS\_STAT is updated with the event that caused the wake-up in the CIRQ bit when the MMCI.MMCHS\_IE[8] CIRQ\_ENABLE associated bit is enabled.

Then, the wake-up event at the origin of the transition from smart-idle mode to normal mode is converted into its corresponding interrupt or DMA request. (The MMCI.MMCHS\_STAT register is updated and the status of the interrupt signal changes.)

When the idle request from the PRCM is deasserted, the module switches back to normal mode. The module is fully operational.

### Force-Idle Mode

Force-idle mode is enabled when the MMCI.MMCHS\_SYSCONFIG[4:3] SIDLEMODE bit field is set to 0x0.

Force-idle mode is an idle mode where the MMC/SD/SDIOi host controller responds unconditionally to the idle request from the PRCM. Moreover, in this mode, the MMC/SD/SDIOi host controller unconditionally deasserts interrupts and DMA request lines asserted.

The transition from normal mode to force-idle mode does not affect the bits of the MMCI.[MMCHS\\_STAT](#) register.

In force-idle mode, the interrupt and DMA request lines are deasserted. MMCI\_ICLK and MMCI\_FCLK can be switched off.

#### CAUTION

In force-idle mode, an idle request from the PRCM during a command or a data transfer can lead to an unexpected and unpredictable result.

When the module is idle, any access to the module generates an error as long as the MMCI\_ICLK clock is alive.

The module exits the force-idle mode when the PRCM deasserts the idle request. Then the module switches back to normal mode. The module is fully operational. Interrupt and DMA request lines are optionally asserted one clock cycle later.

### 24.3.1.2 Resets

#### 24.3.1.2.1 Hardware Reset

The module is reinitialized by the hardware when the active-low reset signal (CORE\_RST), synchronous to the MMCI\_ICLK clock is asserted on the input pin MMCI\_RESET (see [Chapter 3, Power, Reset, and Clock Management](#) for more information).

A global status bit RESETDONE is provided in the status register MMCI.[MMCHS\\_SYSSTATUS\[0\]](#). This bit is set to 1 when all the different clock domain resets (interface domain, functional domain, and 32K domain) have been released.

The MMCI.[MMCHS\\_SYSSTATUS\[0\]](#) RESETDONE bit can be monitored by the software to check if the module is ready-to-use after a hardware reset.

---

**NOTE:** Functional clock MMCI\_FCLK, interface clock MMCI\_ICLK, and debounce clock MMCI\_32K must be provided to the module to allow the RESETDONE status bit to be set.

---

This hardware reset signal has a global reset action on the module. All configuration registers and all state-machines are reset in all clock domains.

#### 24.3.1.2.2 Software Reset

The module is reinitialized by software through the MMCI.[MMCHS\\_SYSCONFIG\[1\]](#) SOFTRESET bit. This bit has the same action on the module logic as the hardware MMCI\_RESET signal except for:

- Debounce logic
- MMCI.[MMCHS\\_PSTATE](#), MMCI.[MMCHS\\_CAPA](#), and MMCI.[MMCHS\\_CUR\\_CAPA](#) registers (see corresponding register descriptions)

The SOFTRESET bit is active high. The bit is automatically reinitialized to 0 by the hardware. The MMCI.[MMCHS\\_SYSCTL\[24\]](#) SRA bit has the same action as the SOFTRESET bit on the design.

The MMCI.[MMCHS\\_SYSSTATUS\[0\]](#) RESETDONE bit can be monitored by the software to check if the module is ready-to-use after a software reset.

Moreover, two partial software reset bits are provided:

- MMCI.[MMCHS\\_SYSCTL\[26\]](#) SRD bit
- MMCI.[MMCHS\\_SYSCTL\[25\]](#) SRC bit

These two reset bits are useful to reinitialize data or command processes respectively in case of line conflict. When set to 1, a reset process is automatically released when the reset completes:

- The MMCI.[MMCHS\\_SYSCTL](#)[26] SRD bit resets all finite state-machines and status management that handle data transfers on both the interface and functional side.
- The MMCI.[MMCHS\\_SYSCTL](#)[25] SRC bit resets all finite state-machines and status management that handle command transfers on both the interface and functional side.

#### 24.3.1.3 Power Domain

MMC/SD/SDIOi power is supplied by the CORE power domain (see [Chapter 3, Power Reset and Clock Management](#) for more information).

When the MMC/SD/SDIOi power domain is off, the only way to wake up the power domain and different MMC/SD/SDIOi clocks is to monitor mmci\_dat[1] input pin state via a different GPIO line for each MMC/SD/SDIO interface (see [Chapter 25, General-Purpose Interface](#), for more information).

#### 24.3.2 Hardware Requests

##### 24.3.2.1 DMA Requests

The MMC/SD/SDIOi host controller can be interfaced with a DMA controller. At system level, the advantage is to discharge the LH of the data transfers. The module does not support wide DMA access (above 1024 bytes) for SD cards as specified in the *SD Card Specification, Part A2, SD Host Controller Standard Specification*, v1.00.

The DMA request is issued if the three following conditions are met:

- The MMCI.[MMCHS\\_CMD](#)[0] DE bit is set to 1 to trigger the initial DMA request (the write must be done when running the data transfer command).
- A command was emitted on the mmci\_cmd line.
- There is enough space in the buffer of the MMC/SD/SDIOi host controller to write an entire block (BLEN writes).

DMA request lines are connected on the system DMA (sDMA) inputs:

- S\_DMA\_60 (MMC1\_DMA\_TX)
- S\_DMA\_61 (MMC1\_DMA\_RX)
- S\_DMA\_46 (MMC2\_DMA\_TX)
- S\_DMA\_47 (MMC2\_DMA\_RX)
- S\_DMA\_76 (MMC3\_DMA\_TX)
- S\_DMA\_77 (MMC3\_DMA\_RX)

###### 24.3.2.1.1 DMA Receive Mode

In a DMA block read operation (single or multiple), the request signal MMCI\_DMA\_RX is asserted to its active level when a complete block is written in the buffer. The block size transfer is specified in the MMCI.[MMCHS\\_BLK](#)[10:0] BLEN field.

The MMCI\_DMA\_RX signal is deasserted to its inactive level when the sDMA has read one single word from the buffer.

Only one request is sent per block; the DMA controller can make a 1-shot read access or several DMA bursts, in which case the DMA controller must manage the number of burst accesses, according to block size BLEN field.

New DMA requests are internally masked if the sDMA has not read exactly BLEN bytes and a new complete block is not ready. As DMA accesses are in 32-bit, then the number of sDMA read is Integer(BLEN/4)+1.

The receive buffer never overflows. In multiple block transfers for block size above 512 bytes, when the buffer gets full, the mmci\_clk clock signal (provided to the card) is momentarily stopped until the sDMA or the MPU performs a read access, which reads a complete block in the buffer.

Summary (see [Figure 24-18](#)):

- DMA transfer size = BLEN buffer size (maximum 1024 32-bit words) in one shot or by burst
- One DMA request per block

**Figure 24-18. DMA Receive Mode**

mmchs-018

#### 24.3.2.1.2 DMA Transmit Mode

In a DMA block write operation (single or multiple), the request signal MMCI\_DMA\_TX is asserted to its active level when a complete block is to be written to the buffer. The block size transfer is specified in the MMCI.**MMCHS\_BLK[10:0]** BLEN field.

The MMCI\_DMA\_TX signal is deasserted to its inactive level when the sDMA has written one single word to the buffer.

Only one request is sent per block; the DMA controller can make a 1-shot write access or multiple write DMA bursts, in which case the DMA controller must manage the number of burst accesses, according to block size BLEN field.

New DMA requests are internally masked if the sDMA has not written exactly BLEN bytes (as DMA accesses are in 32-bit, then the number of sDMA read is Integer(BLEN/4)+1) and if there is not enough memory space to write a complete block in the buffer.

Summary (see [Figure 24-19](#)):

- DMA transfer size = BLEN buffer size (maximum 1024 32-bit words) in one shot or by burst
- One DMA request per block

**Figure 24-19. DMA Transmit Mode**


mmchs-019

### 24.3.2.2 Interrupt Requests

Several internal module events can generate an interrupt. Each interrupt has a status bit, an interrupt enable bit, and a signal status enable:

- The status of each type of interrupt is automatically updated in the MMCI.MMCHS\_STAT register; it indicates which service is required.
- The interrupt status enable bits of the MMCI.MMCHS\_IE register enable/disable the automatic update of the MMCI.MMCHS\_STAT register on an event-by-event basis.
- The interrupt signal enable bits of the MMCI.MMCHS\_ISE register enable/disable the transmission of an interrupt request on the interrupt line MMCI\_IRQ (from the MMC/SD/SDIOi host controller to the MPU subsystem interrupt controller) on an event-by-event basis.

If an interrupt status is disabled in the MMCI.MMCHS\_IE register, then the corresponding interrupt request is not transmitted, and the value of the corresponding interrupt signal enable in the MMCI.MMCHS\_ISE register is ignored.

When an interrupt event occurs, the corresponding status bit is automatically set to 0x1 (the MMC/SD/SDIOi host controller updates the status bit) in the MMCI.MMCHS\_STAT register. If later a mask is applied on the interrupt in the MMCI.MMCHS\_ISE register, the interrupt request is deactivated.

When the interrupt source has not been serviced, if the interrupt status is cleared in the MMCI.MMCHS\_STAT register and the corresponding mask is removed from the MMCI.MMCHS\_ISE register, the interrupt status is not asserted again in the MMCI.MMCHS\_STAT register and the MMC/SD/SDIOi host controller does not transmit an interrupt request.

**CAUTION**

If the buffer write ready interrupt (BWR) or the buffer read ready only interrupt (BRR) are not serviced and are cleared in the MMCi.[MMCHS\\_STAT](#) register, and the corresponding mask is removed, then the MMC/SD/SDIOi host controller will wait for the service of the interrupt without updating the status MMCi.[MMCHS\\_STAT](#) or transmitting an interrupt request.

The MMC/SD/SDIOi host controller supports interrupt-driven operation and polling.

There are one interrupt line for each instance of the MMC/SD/SDIOi host controller:

- MMC1\_IRQ is connected to M\_IRQ\_83 for MMC/SD/SDIO1 instance.
- MMC2\_IRQ is connected to M\_IRQ\_86 for MMC/SD/SDIO2 instance.
- MMC3\_IRQ is connected to M\_IRQ\_94 for MMC/SD/SDIO3 instance.

#### **24.3.2.2.1 Interrupt-Driven Operation**

An interrupt enable bit must be set in the MMCi.[MMCHS\\_IE](#) register to enable the module internal source of interrupt.

When an interrupt event occurs, the single interrupt line is asserted and the LH must:

- Read the MMCi.[MMCHS\\_STAT](#) register to identify which event occurred.
- Write 1 into the corresponding bit of the MMCi.[MMCHS\\_STAT](#) register to clear the interrupt status and release the interrupt line (if a read is done after this write, this would return 0).

---

**NOTE:** In the MMCi.[MMCHS\\_STAT](#) register, Card Interrupt (CIRQ) and Error Interrupt (ERRI) bits cannot be cleared.

The MMCi.[MMCHS\\_STAT](#)[8] CIRQ status bit must be masked by disabling the MMCi.[MMCHS\\_IE](#)[8] CIRQ\_ENABLE bit (set to 0x0), then the interrupt routine must clear SDIO interrupt source in SDIO card common control register (CCCR). See [Chapter 9, Interconnect](#) for more information.

The MMCi.[MMCHS\\_STAT](#)[15] ERRI bit is automatically cleared when all status bits in MMCi.[MMCHS\\_STAT](#)[31:16] are cleared.

#### **24.3.2.2.2 Polling**

When the interrupt capability of an event is disabled in the MMCi.[MMCHS\\_ISE](#) register, the interrupt line is not asserted:

- Software can poll the status bit in the MMCi.[MMCHS\\_STAT](#) register to detect when the corresponding event occurs.
- Writing 1 into the corresponding bit of the MMCi.[MMCHS\\_STAT](#) register clears the interrupt status and does not affect the interrupt line state.

---

**NOTE:** See the previous note concerning CIRQ and ERRI bits clearing.

## 24.4 MMC/SD/SDIO Functional Description

### 24.4.1 Description

MMC/SD/SDIOi host controller is partitioned into two clock domains:

- The interface L4 clock domain
- The functional clock domain

Any two domains are considered asynchronous to each other, and exchanges between the two domains are synchronized through a synchronization stage and an asynchronous buffer. Data are transferred from one domain to other through the buffer (2\*512 RAM).

[Figure 24-20](#) shows a block diagram of the MMC/SD/SDIO host controller.

Figure 24-20. MMC/SD/SDIO Diagram



In the L4 clock domain, the user can:

- Control the transfer (configure parameters for the transfer)
- Control clock activities and reset
- Manage interrupts and hardware requests
- Consult different status:
  - Bus
  - Buffer
  - Interrupts
  - Errors
- Transmit and receive data through the buffer

In the functional clock domain, the internal mechanisms perform the transfers of data and commands.

For more detail see the command response registers (MMCi.MMCHS\_RSPn registers: [Table 24-53](#), [Table 24-55](#), [Table 24-57](#), and [Table 24-59](#)).

#### CAUTION

Read access to the command response registers is allowed only when the command process is completed.

### 24.4.2 Mode Selection

The MMC/SD/SDIO host controller can be used in two modes: MMC and SD/SDIO modes. It has been designed to be the most transparent with the type of card.

The type of the card connected is differentiated by the software initialization procedure. Software identifies the type of card connected during software initialization. For each given card type, there are corresponding commands. Some commands are not supported by all cards. See the *Multimedia Card System Specification*, v4.2, the *SD Memory Card Specifications*, v2.0, and the *SDIO Card Specification, Part E1*, v1.10, for more details.

The purpose of the module is to transfer commands and data, to whatever card is connected, respecting the protocol of the connected card.

Writes and reads to the card must respect the appropriate protocol of that card.

### 24.4.3 Buffer Management

#### 24.4.3.1 Data Buffer

The MMC/SD/SDIOi host controller uses a data buffer divided into two 512-byte portions that are 32 bits wide by 128 words deep. This buffer transfers data from one data bus (Interconnect) to another data bus (SD/SDIO or MMC card bus) and vice versa.

The buffer is the heart of the interface and ensures the transfer between the two interfaces (L4 and the card).

To enhance performance, the data buffer is completed by a prefetch register and a post-write buffer that are not accessible by the host controller.

The read access time of the prefetch register is faster than the one of the data buffer. The prefetch register allows data to be read from the data buffer at an increased speed by preloading data into the prefetch register.

The entry point of the data buffer for the two portions, the prefetch buffer and the post-write buffer, is the 32-bit register MMCi.[MMCHS\\_DATA](#). A write access to the MMCi.[MMCHS\\_DATA](#) register followed by a read access from the MMCi.[MMCHS\\_DATA](#) register corresponds to a write access to the post-write buffer followed by a read access to the prefetch buffer. As a consequence, it is normal that the data of the write access to the MMCi.[MMCHS\\_DATA](#) register and the data of the read access to the MMCi.[MMCHS\\_DATA](#) register are different.

The number of 32-bit accesses to the MMCi.[MMCHS\\_DATA](#) register that are needed to read (or write) a data block with a size of MMCi.[MMCHS\\_BLK](#)[10:0] BLEN, and equals the rounded up result of BLEN divided by 4.

The maximum block size supported by the host controller is 1024 bytes. This value is hard-coded in the register MMCi.[MMCHS\\_CAPA](#)[17:16] MBL field and cannot be changed.

A read access to the MMCi.[MMCHS\\_DATA](#) register is allowed only when the buffer read enable status is set to 1 (MMCi.[MMCHS\\_PSTATE](#)[11] BRE); otherwise, a bad access (MMCi.[MMCHS\\_STAT](#)[29] BADA) is signaled.

A write access to the MMCi.[MMCHS\\_DATA](#) register is allowed only when the buffer write enable status is set to 1 (MMCi.[MMCHS\\_PSTATE](#)[10] BWE); otherwise, a bad access (MMCi.[MMCHS\\_STAT](#)[29] BADA) is signaled and the data is not written.

The data buffer has two modes of operation to store and read of the first and second portions of the data buffer:

- When the size of the data block to transfer is less than or equal to 512 bytes, meaning the value written in BLEN is less than or equal to 0x200, two data transfers can occur from one data bus to the other data bus and vice versa at the same time. The MMC/SD/SDIOi host controller uses the two portions of the data buffer in a ping pong manner so that storing and reading of the first and second portions of the data buffer are automatically interchanged from time to time so that data may be read from one portion (for instance, through a DMA read access on the interconnect bus) while data (for instance, from the card) is being stored into the other portion and vice versa. When BLEN is less than, or equal to 0x200 (that is, less than, or equal to 512 bytes), each of the two portions of the buffer that can be used have a size of BLEN (that is, 32 bits x BLEN div by 4). Do not use a size greater than 2 times this value.

#### CAUTION

The MMCi.[MMCHS\\_CMD](#)[4] DDIR bit must be configured before a transfer to indicate the direction of the transfer.

Figure 24-21 and Figure 24-22 show the buffer management for a write and for a read, respectively.

**Figure 24-21. Buffer Management for a Write**


mmchs-047

Figure 24-22. Buffer Management for a Read



mmchs-043

- When the size of the data block to transfer is larger than 512 bytes, meaning the value written in BLEN is 0x201 or larger, only one data transfer can occur from one data bus to the other data bus at a time. The MMC/SD/SDIOi host controller uses the entire data buffer as a single 1024-byte portion. In this mode, a bad access (MMCi.MMCHS\_STAT[29] BADA) is signaled when two data transfers occur from one data bus to the other data bus and vice versa at the same time.

#### 24.4.3.1.1 Data Buffer Status

The data buffer status is defined in the following interrupt status register and status register:

- Interrupt status registers (see Table 24-69):
  - MMCi.MMCHS\_STAT[29] BADA: Bad access to data space
  - MMCi.MMCHS\_STAT[5] BRR: Buffer read ready
  - MMCi.MMCHS\_STAT[4] BWR: Buffer write ready
- Status registers (see Table 24-63):
  - MMCi.MMCHS\_PSTATE[11] BRE: Buffer read enable
  - MMCi.MMCHS\_PSTATE[10] BWE: Buffer write enable

## 24.4.4 Transfer Process

The process of a transfer is dependent on the type of command. It can be with or without a response, with or without data.

### 24.4.4.1 Different Types of Commands

Different types of commands are specific to MMC, SD, or SDIO cards. See the *Multimedia Card System Specification*, v4.2, the *SD Memory Card Specifications*, v2.0, the *SDIO Card Specification, Part E1*, v1.10, or the *SD Card Specification, Part A2, SD Host Controller Standard Specification*, v1.00, for more details.

### 24.4.4.2 Different Types of Responses

Different types of responses are specific to MMC, SD, or SDIO cards. See the *Multimedia Card System Specification*, v4.2, the *SD Memory Card Specifications*, v2.0, the *SDIO Card Specification, Part E1*, v1.10, or the *SD Card Specification, Part A2, SD Host Controller Standard Specification*, v1.00, for more details.

[Table 24-5](#) shows how the MMC, SD, and SDIO responses are stored in the MMCHS\_RSPxx registers.

**Table 24-5. MMC, SD, SDIO responses in the MMCHS\_RSPxx registers**

| Kind of Response                                  | Response Field             | Response Register                                                                |
|---------------------------------------------------|----------------------------|----------------------------------------------------------------------------------|
| R1, R1b (normal response), R3, R4,<br>R5, R5b, R6 | RESP[39:8] <sup>(1)</sup>  | MMCHS_RSP10[31:0]                                                                |
| R1b (Auto CMD12 response)                         | RESP[39:8] <sup>(1)</sup>  | MMCHS_RSP76[31:0]                                                                |
| R2                                                | RESP[127:0] <sup>(1)</sup> | MMCHS_RSP76[31:0]<br>MMCHS_RSP54[31:0]<br>MMCHS_RSP32[31:0]<br>MMCHS_RSP10[31:0] |

<sup>(1)</sup> RESP refers to the command response format described in the specifications mentioned above.

When the host controller modifies part of the MMCHS\_RSPxx registers, it preserves the unmodified bits.

The host controller stores the Auto CMD12 response in the [MMCHS\\_RSP76\[31:0\]](#) register because the Host Controller may have a multiple block data DAT line transfer executing concurrently with a command. This allows the host controller to avoid overwriting the Auto CMD12 response with the command response stored in [MMCHS\\_RSP10](#) register and vice versa.

## 24.4.5 Transfer or Command Status and Error Reporting

Flags in the MMC/SD/SDIOi host controller show status of communication with the card:

- A timeout (of a command, a data, or a response)
- A CRC

Error conditions generate interrupts. See [Table 24-6](#) and register description for more details.

**Table 24-6. CC and TC Values Upon Error Detected**

| Error hold in the MMCI.MMCHS_STAT register | CC   | TC | Comments                                                                                                                                                 |
|--------------------------------------------|------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29                                         | BADA |    | No dependency with CC nor TC<br>BADA is related to <a href="#">MMCHS_DATA</a> register accesses. Its assertion is not dependent of the ongoing transfer. |
| 28                                         | CERR | 1  | CC is set upon CERR.                                                                                                                                     |
| 22                                         | DEB  | 1  | TC is set upon DEB.                                                                                                                                      |
| 21                                         | DCRC | 1  | TC is set upon DCRC.                                                                                                                                     |
| 20                                         | DTO  |    | DTO and TC are mutually exclusive<br>DCRC and DEB cannot occur with DTO.                                                                                 |
| 19                                         | CIE  | 1  | CC is set upon CIE.                                                                                                                                      |

**Table 24-6. CC and TC Values Upon Error Detected (continued)**

| Error hold in the MMCI.MMCHS_STAT register | CC   | TC | Comments                                                                                                                                                                                                            |
|--------------------------------------------|------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18                                         | CEB  | 1  | CC is set upon CEB.                                                                                                                                                                                                 |
| 17                                         | CCRC | 1  | CC can be set upon CCRC - See CTO comment                                                                                                                                                                           |
| 16                                         | CTO  |    | CTO and CC are mutually exclusive.<br>CIE, CEB and CERR cannot occur with CTO.<br>CTO can occur at the same time as CCRC: it indicates a command abort due to a contention on CMD line. In this case no CC appears. |

**MMCHS\_STAT[21]** DCRC event can be asserted in the following conditions:

- busy timeout for R1b, R5b response type
- busy timeout after write CRC status
- write CRC status timeout
- read data timeout
- boot acknowledge timeout

#### 24.4.5.1 Busy Timeout For R1b, R5b Response Type

Figure 24-23 shows DCRC event condition asserted when there is busy timeout for Rb1, R5b response.

**Figure 24-23. Busy Timeout for R1b, R5b Response Type**

t1 - Data timeout counter is loaded and starts after R1b, R5b response type

t2 - Data timeout counter stops and if it is 0, **MMCHS\_STAT[21]** DCRC is generated.

#### 24.4.5.2 Busy Timeout After Write CRC Status

Figure 24-24 shows DCRC event condition asserted when there is busy timeout after write CRC status.

**Figure 24-24. Busy Timeout After Write CRC Status**



mmchs-057

t1 - Data timeout counter is loaded and starts after CRC Status

t2 - Data timeout counter stops and if it is 0, [MMCHS\\_STAT\[21\]](#) DCRC is generated.

#### 24.4.5.3 Write CRC Status Timeout

Figure 24-25 shows DCRC event condition asserted when there is write CRC status timeout.

**Figure 24-25. Write CRC Status Timeout**



mmchs-058

t1 - Data timeout counter is loaded and starts after Data block + CRC

t2 - Data timeout counter stops and if it is 0, [MMCHS\\_STAT\[21\]](#) DCRC is generated.

#### 24.4.5.4 Read Data Timeout

Figure 24-26 shows DCRC event condition asserted when there is read data timeout.

**Figure 24-26. Read Data Timeout**

mmchs-059

- t1 - Data timeout counter is loaded and starts after Command transmission.
- t2 - Data timeout counter stops and if it is 0, [MMCHS\\_STAT\[21\]](#) DCRC is generated.
- t3 - Data timeout counter is loaded and starts after Data block + CRC transmission.
- t4 - Data timeout counter stops and if it is 0, [MMCHS\\_STAT\[21\]](#) DCRC is generated.

#### 24.4.5.5 Boot Acknowledge Timeout

[Figure 24-28](#) shows DCRC event condition asserted when there is boot acknowledge timeout and CMD0 is used.

**Figure 24-27. Boot Acknowledge Timeout When Using CMD0**

\* Refer to MMC specification for correct argument.

mmchs-060

- t1 - Data timeout counter is loaded and starts after CMD0.
- t2 - Data timeout counter stops and if it is 0, [MMCHS\\_STAT\[21\]](#) DCRC is generated.
- t3 - Data timeout counter is loaded and starts.
- t4 - Data timeout counter stops and if it is 0, [MMCHS\\_STAT\[21\]](#) DCRC is generated.
- t5 - Data timeout counter is loaded and starts after Data + CRC transmission.
- t6 - Data timeout counter stops and if it is 0, [MMCHS\\_STAT\[21\]](#) DCRC is generated.

[Figure 24-28](#) shows DCRC event condition asserted when there is boot acknowledge timeout and CMD0 is used.

**Figure 24-28. Boot Acknowledge Timeout When CMD Line Tied To 0**


- t1 - Data timeout counter is loaded and starts after cmd line is tied to 0.
- t2 - Data timeout counter stops and if it is 0, [MMCHS\\_STAT\[DCRC\]](#) is generated.
- t3 - Data timeout counter is loaded and starts.
- t4 - Data timeout counter stops and if it is 0, [MMCHS\\_STAT\[DCRC\]](#) is generated.
- t5 - Data timeout counter is loaded and starts after Data + CRC transmission.
- t6 - Data timeout counter stops and if it is 0, [MMCHS\\_STAT\[DCRC\]](#) is generated.

#### **24.4.6 Autocommand 12 Timings**

With the UHS definition of SD cards with higher frequency for MMC clock up to 208, SD standard imposes a specific timing for Auto CMD12 'end bit' arrival.

##### **24.4.6.1 Autocommand 12 Timings During Write Transfer**

A margin named Ncrc in range of 2 to 8 cycles has been defined for SDR50 and SDR104 card components for write data transfers, as autocommand 12 'end bit' shall arrive after the CRC status 'end bit'.

[Figure 24-29](#) shows auto CMD12 timings during write transfer.

**Figure 24-29. Autocommand 12 Timings During Write Transfer**


The Host controller has a margin of 18 clock cycles to make sure that auto CMD12 'end bit' arrives after the CRC status. This margin does not depend on MMC bus configuration, DDR or standard transfer, 1,4 or 8 bus width.

#### 24.4.6.2 Autocommand 12 Timings During Read Transfer

With UHS very high speed cards gap timing between 2 successive cards has been extended to 4 cycles instead of 2. By the way it gives more flexibility for Host Auto CMD12 arrival in order to receive the last complete and reliable block. MMCHS controller only follows the 'Left Border Case' defined by SD UHS specification.

Figure 24-30 shows ACMD12 timings during read transfer.

**Figure 24-30. Autocommand 12 Timings During Read Transfer**



mmchs-063

The Auto CMD12 arrival sent by the Host controller is not sensitive to the MMC bus configuration whether it is DDR or standard transfer and whether it is a 1,4 or 8 bit bus width transfer.

#### 24.4.7 Transfer Stop

Whenever a transfer is initiated, the transmission may be willed to stop whereas it is still not finished. Several cases can be faced depending on the transfer type:

- Multiple blocks oriented transfers (for which transfer length is known)
- Continuous stream transfers (which have an infinite length)

---

**NOTE:** Since the MMC/SD/SDIOi controller manages transfers based on a block granularity, the buffer will accept a block only if there is enough space to completely store it. Consequently, if a block is pending in the buffer, no command will be sent to the card because the card clock will be shut off by the controller.

---

The MMC/SD/SDIOi controller includes two features which makes a transfer stop more convenient and easier to manage:

- Auto CMD12 (for MMC and SD only).

This feature is enabled by setting the MMC<sub>i</sub>.MMCHS\_CMD[2] ACEN bit to 0x1 (this setting is relevant for a MMC/SD transfer with a known number of blocks to transfer). When the Auto CMD12 feature is enabled, the MMC/SD/SDIOi controller will automatically issue a CMD12 command when the expected number of blocks has been exchanged.

- Stop at block gap

This feature is enabled by setting the MMC<sub>i</sub>.MMCHS\_HCTL[16] SBGR bit to 0x1. When enabled, this capability holds the transfer on until the end of a block boundary. If a stop transmission is needed, software can use this pause to send a CMD12 to the card.

**NOTE:** For MMC and SD cards, the stop at block gap feature is not supported in READ mode.

For SDIO cards, this setting can be supported in READ mode if the card has a read wait capability.

Table 24-7 shows the common way to stop a transfer, indicating command to send and features to enable.

**Table 24-7. MMC/SD/SDIOi Controller Transfer Stop Command Summary**

|                                      |                                                           | <b>WRITE transfer</b>                                       |                                                                             | <b>READ transfer</b>                                        |                                                               |
|--------------------------------------|-----------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------|-------------------------------------------------------------|---------------------------------------------------------------|
|                                      |                                                           | SD / MMC                                                    | SDIO                                                                        | SD / MMC                                                    | SDIO                                                          |
| Single block                         |                                                           | Transfer ends automatically<br>Wait TC                      | Transfer ends automatically<br>Wait TC                                      | Transfer ends automatically<br>Wait TC                      | Transfer ends automatically<br>Wait TC                        |
| Multi blocks<br>(finite or infinite) | Before the programmed block boundary                      | Send CMD12<br>Wait TC                                       | Send CMD52<br>Wait TC                                                       | Send CMD12<br>Wait TC                                       | Send CMD52<br>Wait TC                                         |
|                                      | Stop at the end of the transfer<br>(finite transfer only) | Auto CMD12 active<br>Transfer ends automatically<br>Wait TC | Set<br>MMCI.MMCHS_HC<br>TL[16] SBGR bit to<br>0x1.<br>Send CMD52<br>Wait TC | Auto CMD12 active<br>Transfer ends automatically<br>Wait TC | <b>If READ_WAIT supported</b><br>Stop at block gap<br>Wait TC |
|                                      |                                                           |                                                             |                                                                             | <b>If READ_WAIT not supported</b><br>Send CMD52<br>Wait TC  |                                                               |

**NOTE:** The MMC/SD/SDIOi controller will send the stop command to the card on a block boundary, regardless the moment the command was written to the controller registers.

#### 24.4.8 MMC CE-ATA Command Completion Disable Management

The MMC/SD/SDIOi host controller supports CE-ATA features, in particular the detection of command completion token. When a command that requires a command completion signal ([MMCHS\\_CON\[12\]](#) CEATA and [MMCHS\\_CMD\[2\]](#) ACEN set to 1) is launched, host system is no longer allowed to emit a new command in parallel of data transfer unless it is a command completion disable.

The settings to emit a command completion disable token follow:

- [MMCHS\\_CON\[12\]](#) CEATA is set to 1.
- [MMCHS\\_CON\[2\]](#) HR set to 1.
- Clear the [MMCHS\\_ARG](#) register.
- Write into [MMCHS\\_CMD](#) register with value 0x00000000.

When a command completion disable token was emitted (that is, [MMCHS\\_STAT\[0\]](#) CC received), the host system is again allowed to emit another type of command (for example a transfer abort command CMD12 to abort transfer).

A critical case can be met when command completion signal disable (CCSD) is emitted during the last data block transfer, the sequence on command line could be sent very close to command completion signal (CCS) token sent by the card.

Three cases can be met:

- CCS is receive just before CCSD is emitted:  
An interrupt CIRQ is generated with CCS detection, CCSD is transmitted to card then an interrupt CC is generated when CCSD ends. In this case, card consider the CCSD sequence.
- CCS is not generated or generated during the CCSD transfer:  
The CCS bit cannot be detected (conflict is not possible as they drive the same level on command line, then no CIRQ interrupt is generated; besides CC interrupt is generated when CCSD ends).
- CCS is generated without CCSD token required:

Only the interrupt CIRQ is generated when CCS is detected.

## 24.5 MMC/SD/SDIO Basic Programming Model

### 24.5.1 MMC/SD/SDIO Host Controller Initialization Flow

Figure 24-31 shows the general boot process.

**Figure 24-31. MMC/SD/SDIO Controller Meta Initialization Steps**



mmchs-024

#### 24.5.1.1 Enable Interface and Functional clock for MMC Controller

Prior to any MMCHS register access one must enable MMCHS interface clock and functional clock in PRCM module registers PRCM.CM\_ICLKEN1\_CORE and PRCM.CM\_FCLKEN1\_CORE. See [Chapter 3, Power, Reset, and Clock Management](#).

#### 24.5.1.2 MMCHS Soft Reset Flow

Figure 24-32 shows the soft reset process of MMCHS controller.

**Figure 24-32. MMC/SD/SDIO Controller Software Reset Flow**

mmchs-025

#### 24.5.1.3 Set MMCHS Default Capabilities

Software must read capabilities (in boot ROM for instance) and is allowed to set (write) MMCI.**MMCHS\_CAPA**[26:24] and MMCI.**MMCHS\_CUR\_CAPA**[23:0] registers before the MMC/SD/SDIO host driver is started.

#### 24.5.1.4 Wake-Up Configuration

Figure 24-33 details MMCHS controller wake-up configuration.

**Figure 24-33. MMC/SD/SDIO Controller Wake-Up Configuration**

mmchs-027

#### 24.5.1.5 MMC Host and Bus Configuration

Figure 24-34 details MMC bus configuration process.

**Figure 24-34. MMC/SD/SDIO Controller Bus Configuration**


mmchs-028

#### 24.5.2 Basic Operations for MMC/SD/SDIO Host Controller

The MMC/SD/SDIO host controller performs data transfers: data to card (referred to as write transfers) and data from card (referred to as read transfers).

The host controller requires transfers to run on a block-by-block basis, rather than on a DMA burst size basis. A single DMA request (or block request interrupt) is signaled for each block. Pipelining is supported as long as the block size is less than one half of the memory buffer size.

#### 24.5.2.1 Card Detection, Identification, and Selection

Figure 24-35 and Figure 24-36 show the card identification and selection process.

**Figure 24-35. MMC/SD/SDIO Controller Card Identification and Selection - Part 1**



mmchs-030

**Figure 24-36. MMC/SD/SDIO Controller Card Identification and Selection - Part 2**


108-031

#### 24.5.2.2 Read/Write Transfer Flow in DMA Mode With Interrupt

Figure 24-37 describes the read and write protocol in DMA mode with interrupt signaling. See Chapter 11, SDMA, for more information on the DMA settings.

**Figure 24-37. MMC/SD/SDIO Controller Read/Write Transfer Flow in DMA Mode With Interrupt**

#### 24.5.2.3 Read/Write Transfer Flow in DMA Mode With Polling

Figure 24-38 describes the read and write protocol in DMA mode. See [Chapter 11, SDMA](#), for more information on the DMA settings.

**Figure 24-38. MMC/SD/SDIO Controller Read/Write Transfer Flow in DMA Mode With Polling**


mmchs-033

#### 24.5.2.4 Read/Write Transfer Flow Wthout DMA and With Polling

Figure 24-39 describes a read/write transfer without using the DMA and with polling.

**Figure 24-39. MMC/SD/SDIO Controller Read/Write Transfer Flow Without DMA and With Polling**



mmchs-034

#### 24.5.2.5 Read/Write Transfer Flow in CE-ATA Mode

Figure 24-40 describes the read and write CE-ATA protocol when in Polling mode.

**Figure 24-40. MMC/SD/SDIO Controller Read/Write in CE-ATA Mode**



mmchs-037

**CAUTION**

CE-ATA protocol is only supported by MMC cards.

In CE-ATA mode, issuing command during the transfer (except a CCSD command) is not allowed

In CE-ATA mode, infinite transfers are not allowed, only finite transfers are permitted.

#### 24.5.2.6 Suspend-Resume Flow

The suspend and resume feature is only supported by SDIO cards.

##### 24.5.2.6.1 Suspend Flow

Figure 24-41 describes the suspend flow for SDIO cards.

**Figure 24-41. MMC/SD/SDIO Controller Suspend Flow**

mmchs-038

#### 24.5.2.6.2 Resume Flow

Figure 24-42 describes the resume flow for SDIO cards.

**Figure 24-42. MMC/SD/SDIO Controller Resume Flow**

mmchs-039

### 24.5.2.7 Basic Operations - Step Details

#### 24.5.2.7.1 Command Transfer Flow

Figure 24-43 describes how to send a command to the card using polling instead of interrupts for event signaling.

**Figure 24-43. MMC/SD/SDIO Controller Command Transfer Flow With Polling**

mmchs-040

**Figure 24-44** describes how to send a command to the card using interrupts for event signaling.

**Figure 24-44. MMC/SD/SDIO Controller Command Transfer Flow With Interrupts**



#### 24.5.2.7.2 MMC/SD/SDIO Clock Frequency Change

Figure 24-45 describes the different steps that allow to change the MMC/SD/SDIO output clock frequency.

**Figure 24-45. MMC/SD/SDIO Controller Clock Frequency Change Flow**

mmchs-042

### 24.5.3 MMC/SD/SDIO1 Bus Voltage Selection

The MMC/SD/SDIO1 controller can operate with two types of card voltages: 1.8 V and 3.0 V. For this reason, dual voltage pads are implemented on this interface. For technological concerns those pads must have an internal bias voltage reference to operate. The PBIAS\_LITE module supplies this bias voltage, depending on the CONTROL.CONTROL\_PBIAS\_LITE register settings.

See [Section 13.4.5, Extended-Drain I/O Pin and PBIAS Cell](#), for more information about the PBIAS\_LITE cell.

[Section 13.5.2, Extended-Drain I/Os and PBIAS Cell Basic Programming Guide](#), describes the steps involved in transitioning from 1.8 V to 3.0 V and from 3.0 V to 1.8 V, applicable to the MMC/SD/SDIO1 controller.

#### CAUTION

The BIAS voltage must be set using the procedure described in [Section 13.5.2, Extended-Drain I/Os and PBIAS Cell Basic Programming Guide](#). Failure to follow this procedure can damage the MMCHS interface.

[Figure 24-46](#) describes how to configure the MMCHS controller to fit with power switching sequence.

**Figure 24-46. MMC/SD/SDIO Power Switching Procedure**


mmchs-055

## 24.6 MMC/SD/SDIO Use Cases and Tips

### 24.6.1 MMCHS Controller Usage

#### 24.6.1.1 Overview

The MMCHS controller is in charge of managing raw data storage in a MMC memory card. The MMCHS controller transfers data between DDRAM and MMC card. [Figure 24-47](#) gives an overview of MMCHS controller position in the use case.

**Figure 24-47. Overview**



mmchs\_050

For the Camcorder use case, the MMCHS controller is configured to operate with the following features :

- High speed mode with a card clock frequency of 48 MHz.
- 4 data lines.
- 1.8 V and 3.0 V voltage capabilities.

MMC card power supply is not provided by the MMCHS controller itself but rather by the companion device. See [Chapter 17](#) to learn how to set these voltage levels.

Only MMC1 controller is used in this configuration. Hence this document describes the output of the test carried out with MMC1 controller.

### 24.6.1.2 Environment

To operate in the correct manner, the MMCHS controller needs the System Control Module (SCM) to be configured with the right muxing mode and with the right pull up state. The MMC card needs to be powered with the right power level and this is done with the companion device. [Figure 24-48](#) gives the environment picture of the MMCHS controller.

**Figure 24-48. Environment**



#### 24.6.1.2.1 Command and Data Transfer Formats

When communicating with a MMC card, The MMCHS controller is always the master. The communication between the MMCHS controller and the MMC card always starts by sending a command. Both command and data transfers are started with a command.

The data transfer type used by the MMCHS controller is a finite multiple block transfer. [Figure 24-49](#) illustrates a command transfer without data. [Figure 24-50](#) and [Figure 24-51](#) illustrate a multiple block transfer between the MMCHS controller and the MMC card.

**Figure 24-49. Command Transfer**

mmchs\_052

**Figure 24-50. Data Read Transfer**

mmchs\_053

**Figure 24-51. Data Write Transfer**

mmchs\_054

### 24.6.1.3 Programming Flow

#### 24.6.1.3.1 Initial Configuration

The initialization of the MMCHS controller is done through these steps :

1. MMCHS controller interface and functional clocks enabling.
2. MMCHS controller software reset.
3. MMCHS controller voltage capabilities initialization.
4. MMCHS controller default initialization.
5. MMCHS controller INIT procedure start.

## 6. MMCHS controller pre-card identification configuration.

For more information about different steps the MMCHS controller goes through during initial configuration see [Section 24.5, MMC/SD/SDIO Basic Programming Model](#).

### **24.6.1.3.1.1 MMCHS Controller Interface and Functional Clocks Enabling**

In order to enable the interface and functional clocks of the MMCHS1 controller, the following steps must be done:

1. Enable the interface clock for the MMCHS1 controller (set the PRCM.CM\_ICLKEN1\_CORE[24] EN\_MMCHS1).
2. Enable the functional clock for the MMCHS1 module (set the PRCM.CM\_FCLKEN1\_CORE[24] EN\_MMCHS1).

[Table 24-8](#) shows all PRCM registers to be configured to enable interface and functional clocks for MMCHS1 controller.

**Table 24-8. Register Print for the MMCHS1 Controller Clock Initialization**

| Register Name        | Register Address | Value      | Value Description               |
|----------------------|------------------|------------|---------------------------------|
| PRCM.CM_ICLKEN1_CORE | 0x4800 4A10      | 0x01000000 | MMCHS1 interface clock enabled  |
| PRCM.CM_FCLKEN1_CORE | 0x4800 4A00      | 0x01000000 | MMCHS1 functional clock enabled |

### **24.6.1.3.1.2 MMCHS Controller Software Reset**

To software-reset the MMCHS1 controller, the following steps must be performed:

1. Write 0x2 in MMCHS1.[MMCHS\\_SYS CONFIG](#) register.
2. Wait until MMCHS1.[MMCHS\\_SYS STATUS](#)[0] RESETDONE turns 1.

[Table 24-9](#) describes the software-reset registers.

**Table 24-9. Software-Reset Register Description**

| Register Name                            | Register Address | Value      | Value Description        |
|------------------------------------------|------------------|------------|--------------------------|
| MMCHS1. <a href="#">MMCHS_SYS CONFIG</a> | 0x4809 C010      | 0x00000002 | Activate software reset. |
| MMCHS1. <a href="#">MMCHS_SYS STATUS</a> | 0x4809 C014      | 0x00000001 | Reset is over.           |

### **24.6.1.3.1.3 MMCHS Controller Voltage Capabilities Initialization**

MMCHS1 controller's voltage capabilities should be set in MMCHS1.[MMCHS\\_CAPA](#). See [Table 24-10](#).

**Table 24-10. MMCHS Controller Voltage Capabilities Initialization**

| Register Name                      | Register Address | Value                      | Value Description                                                  |
|------------------------------------|------------------|----------------------------|--------------------------------------------------------------------|
| MMCHS1. <a href="#">MMCHS_CAPA</a> | 0x4809 C140      | current_value   0x06000000 | Activate VS18 and VS30 in the <a href="#">MMCHS_CAPA</a> register. |

### **24.6.1.3.1.4 MMCHS Controller Default Initialization**

Before sending any command, the MMCHS controller is configured with default values:

1. Default voltage support is set to 1.8 V in MMCHS1.[MMCHS\\_HCTL](#)[11:9] SDVS.
2. MMC bus is set to open drain in MMCHS1.[MMCHS\\_CON](#)[0] OD.
3. MMC data bus width is set to 1 in MMCHS1.[MMCHS\\_HCTL](#)[1] DTW.
4. MMC Card's power is off.
5. MMC card's clock is on in MMCHS1.[MMCHS\\_SYS CTL](#)[0] ICE and MMCHS1.[MMCHS\\_SYS CTL](#)[2] CEN.
6. MMCHS controller bus power up in MMCHS1.[MMCHS\\_HCTL](#)[8] SDBP.

7. MMC card's clock frequency is set to 150 kHz in MMCHS1.[MMCHS\\_SYSCTL\[15:6\]](#) CLKD.

[Table 24-11](#) shows the values that must be written in the right register pool.

**Table 24-11. MMC Controller Default Initialization Values**

| Register Name                        | Register Address | Value      | Value Description                                                           |
|--------------------------------------|------------------|------------|-----------------------------------------------------------------------------|
| MMCHS1. <a href="#">MMCHS_HCTL</a>   | 0x4809C128       | 0x00000b00 | data bus width = 1, voltage = 1.8 V, MMC bus power is on (not card's power) |
| MMCHS1. <a href="#">MMCHS_SYSCTL</a> | 0x4809C12C       | 0x0000a007 | card's clock enable and card's clock frequency divider                      |
| MMCHS1. <a href="#">MMCHS_CON</a>    | 0x4809C02C       | 0x00000001 | Set MMC bus mode to open-drain.                                             |

A small notice about MMCHS1.[MMCHS\\_HCTL](#). Even if the value written in it is 0x00000b00, the value read from it is equal to 0x00000a00. This is due to the fact that the MMCHS controller is not in a card state mode which sets automatically the [MMCHS\\_HCTL\[8\]](#) SDBP bit to 0.

#### 24.6.1.3.1.5 MMCHS Controller INIT Procedure Start

Prior to issuing any command, the MMCHS controller has to execute a special INIT procedure. The MMCHS controller has to generate a clock during 1ms. During the INIT procedure, the MMCHS controller generates 80 clock periods. In order to keep the 1 ms gap, the MMCHS controller should be configured to generate a clock whose frequency is smaller or equal to 80 kHz.

The INIT procedure is executed by setting MMCHS1.[MMCHS\\_CON\[1\]](#) INIT bit field to 1 and by sending a dummy command, writing 0x00000000 in the MMCHS1.[MMCHS\\_CMD](#) register.

To assure the synchronous clock on the clock output of the MMC1 controller, set the CONTROL.CONTROL\_PADCONF\_MMC1\_CLK[8] bit. In this way, the clock output is also configured as input and the result is looped back through the output and input buffers of the pad.

[Table 24-12](#) shows the values that should be written in the right register pool.

**Table 24-12. MMCHS Controller INIT Procedure Start**

| Register Name                     | Register Address | Value                      | Value Description                                        |
|-----------------------------------|------------------|----------------------------|----------------------------------------------------------|
| MMCHS1. <a href="#">MMCHS_CON</a> | 0x4809C02C       | current_value   0x00000002 | Sets MMCHS1. <a href="#">MMCHS_CON[1]</a> INIT to 1      |
| MMCHS1. <a href="#">MMCHS_CMD</a> | 0x4809C10C       | 0x00000000                 | Sends dummy command.                                     |
| CONTROL.CONTROL_PADCO_NF_MMC1_CLK | 0x4800 2144      | 0x100                      | Set the INPUTENABLE bit to assure the synchronous clock. |

#### 24.6.1.3.1.6 MMCHS Controller Precard Identification Configuration

Before card identification starts, the MMCHS controller's configuration should change. The MMC card's clock should now be 400 kHz, according to the MMC system spec requirements. [Table 24-13](#) shows the values that should be written in the right register pool.

**Table 24-13. MMCHS Controller Precard Identification Configuration**

| Register Name                        | Register Address | Value      | Value Description                                                            |
|--------------------------------------|------------------|------------|------------------------------------------------------------------------------|
| MMCHS1. <a href="#">MMCHS_HCTL</a>   | 0x4809C128       | 0x00000b00 | Data bus width = 1, voltage = 1.8 V, MMC bus power is on (not power of card) |
| MMCHS1. <a href="#">MMCHS_SYSCTL</a> | 0x4809C12C       | 0x00003C07 | Card's clock enable and card's clock frequency divider                       |
| MMCHS1. <a href="#">MMCHS_CON</a>    | 0x4809C02C       | 0x00000001 | Set MMC bus mode to open drain.                                              |

### 24.6.1.3.2 MMC Card Identification

MMC card identification is performed by issuing many MMC commands. Each command imposes certain configuration values in a pool of registers. The status of command transfer is read in MMCHS1.MMCHS\_STAT register and command response if any is read from MMCHS1.MMCHS\_RSP10, MMCHS1.MMCHS\_RSP32, MMCHS1.MMCHS\_RSP54 and MMCHS1.MMCHS\_RSP76.

This TRM output describes a use case where interrupts are used to signal MMCHS controller status changes.

For more details about the card identification sequence, see [Section 24.5, MMC/SD/SDIO Basic Programming Model](#).

#### 24.6.1.3.2.1 Sending CMD0

This command resets the MMC card (see [Table 24-14](#)).

**Table 24-14. Sending CMD0**

| Register Name    | Register Address | Value      | Value Description                                   |
|------------------|------------------|------------|-----------------------------------------------------|
| MMCHS1.MMCHS_CON | 0x4809C02C       | 0x00000001 | MMC bus is still in open drain state for broadcast. |
| MMCHS1.MMCHS_IE  | 0x4809C134       | 0x00040001 | Enables CC and CEB events to occur.                 |
| MMCHS1.MMCHS_ISE | 0x4809C138       | 0x00040001 | Enables CC and CEB interrupts to rise.              |
| MMCHS1.MMCHS_CMD | 0x4809C10C       | 0x00000000 | Sends CMD0 whose opcode is 0.                       |

#### 24.6.1.3.2.2 Sending CMD5

This command asks a SDIO card to send its operating conditions (see [Table 24-15](#)). This command will fail if there is no SDIO card. In case of success the response will be in MMCHS1.MMCHS\_RSP10 register.

**Table 24-15. Sending CMD5**

| Register Name    | Register Address | Value      | Value Description                                          |
|------------------|------------------|------------|------------------------------------------------------------|
| MMCHS1.MMCHS_CON | 0x4809C02C       | 0x00000001 | MMC bus is still in open drain state for broadcast.        |
| MMCHS1.MMCHS_IE  | 0x4809C134       | 0x00050001 | Enables CC, CTO and CEB events to occur.                   |
| MMCHS1.MMCHS_ISE | 0x4809C138       | 0x00050001 | Enables CC, CTO and CEB interrupts to rise.                |
| MMCHS1.MMCHS_CMD | 0x4809C10C       | 0x05020000 | Sends CMD5 whose opcode is 5 and response type is 48 bits. |

#### 24.6.1.3.2.2.1 Sending CMD8

This command asks a SD card version 2.X to send its operating conditions (see [Table 24-16](#)). This command will fail if there is no SD card verison 2.X. In case of success the response will be in MMCHS1.MMCHS\_RSP10 register.

**Table 24-16. Sending CMD8**

| Register Name    | Register Address | Value      | Value Description                                                                  |
|------------------|------------------|------------|------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_CON | 0x4809C02C       | 0x00000001 | MMC bus is still in open drain state for broadcast.                                |
| MMCHS1.MMCHS_IE  | 0x4809C134       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB events to occur.                          |
| MMCHS1.MMCHS_ISE | 0x4809C138       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB interrupts to rise.                       |
| MMCHS1.MMCHS_CMD | 0x4809C10C       | 0x81a0000  | Sends CMD8 whose opcode is 8, response type is 48 bits with CICE and CCCE enabled. |

#### 24.6.1.3.2.3 Sending CMD55

This is a special command used to prevent the card that the following command is going to be an application one (see [Table 24-17](#)). This is used to prepare the issuing of ACMD41 (opcode = 41) that usually asks a SD card version 1.X to send its operating conditions. If no SD card version 1.X is connected to the MMCHS controller this command will fail. In case of success the response will be received in the MMCHS1.[MMCHS\\_RSP10](#) register.

**Table 24-17. Sending CMD55**

| Register Name                     | Register Address | Value      | Value Description                                                                    |
|-----------------------------------|------------------|------------|--------------------------------------------------------------------------------------|
| MMCHS1. <a href="#">MMCHS_CON</a> | 0x4809C02C       | 0x00000001 | MMC bus is still in open drain state for broadcast.                                  |
| MMCHS1. <a href="#">MMCHS_IE</a>  | 0x4809C134       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB events to occur.                            |
| MMCHS1. <a href="#">MMCHS_ISE</a> | 0x4809C138       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB interrupts to rise.                         |
| MMCHS1. <a href="#">MMCHS_CMD</a> | 0x4809C10C       | 0x371a0000 | Sends CMD55 whose opcode is 55, response type is 48 bits with CICE and CCCE enabled. |

#### 24.6.1.3.2.4 Sending CMD1

Once the card response is available in register MMCHS1.[MMCHS\\_RSP10](#), the software is responsible to compare Card OCR and Host OCR, and then send a second CMD1 command with the cross-checked OCR.

This way, the card is notified of the Operating Voltage to work with.

**Table 24-18. Sending CMD1**

| Register Name                     | Register Address | Value      | Value Description                                          |
|-----------------------------------|------------------|------------|------------------------------------------------------------|
| MMCHS1. <a href="#">MMCHS_CON</a> | 0x4809C02C       | 0x00000001 | MMC bus is still in open drain state for broadcast.        |
| MMCHS1. <a href="#">MMCHS_IE</a>  | 0x4809C134       | 0x00050001 | Enables CC, CTO and CEB events to occur.                   |
| MMCHS1. <a href="#">MMCHS_ISE</a> | 0x4809C138       | 0x00050001 | Enables CC, CTO and CEB interrupts to rise.                |
| MMCHS1. <a href="#">MMCHS_CMD</a> | 0x4809C10C       | 0x01020000 | Sends CMD1 whose opcode is 1 and response type is 48 bits. |

Once the card response is available in register MMCHS1.[MMCHS\\_RSP10](#), the software should compare card OCR and host OCR, and then send a second CMD1 command with the cross-checked OCR. This tells the card what operating voltage to use.

#### 24.6.1.3.2.5 Sending CMD2

This command asks the MMC card to send its CID register's content (see [Table 24-19](#)). The response is 128 bits wide and is received in the MMCHS1.[MMCHS\\_RSP10](#), MMCHS1.[MMCHS\\_RSP32](#), MMCHS1.[MMCHS\\_RSP54](#) and MMCHS1.[MMCHS\\_RSP76](#) registers.

**Table 24-19. Sending CMD2**

| Register Name                     | Register Address | Value      | Value Description                                                          |
|-----------------------------------|------------------|------------|----------------------------------------------------------------------------|
| MMCHS1. <a href="#">MMCHS_CON</a> | 0x4809C02C       | 0x00000001 | MMC bus is still in open drain state for broadcast.                        |
| MMCHS1. <a href="#">MMCHS_IE</a>  | 0x4809C134       | 0x00070001 | Enables CERR, CIE, CCRC, CC, CTO and CEB events to occur.                  |
| MMCHS1. <a href="#">MMCHS_ISE</a> | 0x4809C138       | 0x00070001 | Enables CERR, CIE, CCRC, CC, CTO and CEB interrupts to rise.               |
| MMCHS1. <a href="#">MMCHS_CMD</a> | 0x4809C10C       | 0x02090000 | Sends CMD2 whose opcode is 2, response type is 136 bits with CCCE enabled. |

#### **24.6.1.3.2.6 Sending CMD3**

This command sets the MMC card address (see [Table 24-20](#)). Useful when the MMCHS controller switches to addressed mode.

**Table 24-20. Sending CMD3**

| Register Name    | Register Address | Value      | Value Description                                                                                                                  |
|------------------|------------------|------------|------------------------------------------------------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_CON | 0x4809C02C       | 0x00000001 | MMC bus is still in open drain state for broadcast.                                                                                |
| MMCHS1.MMCHS_IE  | 0x4809C134       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB events to occur.                                                                          |
| MMCHS1.MMCHS_ISE | 0x4809C138       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB interrupts to rise.                                                                       |
| MMCHS1.MMCHS_CMD | 0x4809C10C       | 0x031a0000 | Sends CMD3 whose opcode is 3, response type is 48 bits with CICE and CCCE enabled.                                                 |
| MMCHS1.MMCHS_ARG | 0x4809C108       | 0x00010000 | <a href="#">MMCHS_ARG</a> register carries MMC card's address. We choose to assign address 1 any other 16 bit wide value is valid. |

#### **24.6.1.3.3 MMC Bus Setting Change After Card Identification**

After the CMD3 command transfer is completed successfully, an auto-negotiation on voltage value starts. This is the frontier when the MMCHS controller should switch from identification mode to transfer mode. This impacts the controller in a way that it should change its bus state from open drain to push-pull. [Table 24-21](#) gives several registers and their values.

**Table 24-21. MMC Bus Setting Change Table**

| Register Name       | Register Address | Value       | Value Description                                                                                                                                                                              |
|---------------------|------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_CON    | 0x4809C02C       | 0x00000000  | Bus is now in push-pull mode.                                                                                                                                                                  |
| MMCHS1.MMCHS_HCTL   | 0x4809C128       | 0x00000B00  | Bus power is on, 1.8 V is selected.                                                                                                                                                            |
| MMCHS1.MMCHS_SYSCTL | 0x4809C12C       | 0x000003C07 | The internal clock of the MMCHS controller is stable and enabled, and the MMC card clock is on. The divider value is 240, which means the MMCHS controller is still supplying a 400-kHz clock. |

#### **24.6.1.3.4 Reading the CSD Register of an MMC Card**

After settling on a voltage value, additional information must be read from the MMC card. This data is stored in MMC card CSD register. The card sends CSD register content after receiving CMD9 command. The CSD register holds important information on the card, MMC system specification version support, maximum clock speed support, memory capacity, minimum block length, and read and write transfer latency timings.

##### **24.6.1.3.4.1 Sending CMD9**

This command asks the card to send its CSD register's content (see [Table 24-22](#)). The 136-bit (128 bits are valid payload) response is received in the MMCHS1.MMCHS\_RSP10, MMCHS1.MMCHS\_RSP32, MMCHS1.MMCHS\_RSP54, and MMCHS1.MMCHS\_RSP76 registers. CMD9 is an addressed command which means that the card's address must be written in the MMCHS1.MMCHS\_ARG register before the command is issued.

**Table 24-22. Sending CMD9**

| Register Name    | Register Address | Value      | Value Description                                 |
|------------------|------------------|------------|---------------------------------------------------|
| MMCHS1.MMCHS_CON | 0x4809C02C       | 0x00000000 | MMC bus is in push-pull mode.                     |
| MMCHS1.MMCHS_IE  | 0x4809C134       | 0x00070001 | Enables CCRC, CC, CTO and CEB events to occur.    |
| MMCHS1.MMCHS_ISE | 0x4809C138       | 0x00070001 | Enables CCRC, CC, CTO and CEB interrupts to rise. |

**Table 24-22. Sending CMD9 (continued)**

| Register Name    | Register Address | Value      | Value Description                                                                                                  |
|------------------|------------------|------------|--------------------------------------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_CMD | 0x4809C10C       | 0x09090000 | Sends CMD9 whose opcode is 9, response type is 136 bits with CCCE enabled.                                         |
| MMCHS1.MMCHS_ARG | 0x4809C108       | 0x00010000 | MMCHS_ARG register carries MMC card's address. We choose to assign address 1 any other 16 bit wide value is valid. |

After receiving and parsing CMD9 response, MMC card clock speed must change to take advantage to card's maximum speed. This has an impact on MMC bus as we should perform a clock frequency change. At this stage the maximum clock frequency will be 20 MHz (see MMC system specification from [www.mmca.org](http://www.mmca.org)).

Clock frequency change procedure is performed in several steps. Please refer to [Section 24.5.2.7.2, MMCHS Clock Frequency Change](#).

[Table 24-23](#) shows the value written in MMCHS1.MMCHS\_SYSCTL register.

**Table 24-23. MMCHS\_SYSCTL Value**

| Register Name       | Register Address | Value      | Value Description                                                                                                                                                             |
|---------------------|------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_SYSCTL | 0x4809C12C       | 0x00000147 | MMCHS controller's internal clock is stable and enabled, MMC card's clock is on. Divider value is 5 which means that MMCHS controller is supplying a 19.2 MHz clock < 20 MHz. |

Another important parameter read from CSD register is MMC system specification version. If this parameter points to a value greater than or equal to 4, the MMC card is capable of a speed up to 52 MHz and a bus width up to 8 (1, 4 or 8 are the possible options). To enable these two extra features, MMCHS controller must issue a CMD6 command with specific argument.

A CMD6 command is issued in the data transfer mode after MMC card is selected. MMC card selection consists of sending CMD7 command with MMC card's address in command argument.

[Table 24-24](#) shows the set of register impacted by CMD7 issue action.

**Table 24-24. Sending CMD7**

| Register Name    | Register Address | Value      | Value Description                                                                                                  |
|------------------|------------------|------------|--------------------------------------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_CON | 0x4809C02C       | 0x00000000 | MMC bus is in push-pull mode.                                                                                      |
| MMCHS1.MMCHS_IE  | 0x4809C134       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB events to occur.                                                          |
| MMCHS1.MMCHS_ISE | 0x4809C138       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB interrupts to rise.                                                       |
| MMCHS1.MMCHS_CMD | 0x4809C10C       | 0x071a0000 | Sends CMD7 whose opcode is 7, response type is 48 bits with CICE and CCCE enabled.                                 |
| MMCHS1.MMCHS_ARG | 0x4809C108       | 0x00010000 | MMCHS_ARG register carries MMC card's address. We choose to assign address 1 any other 16 bit wide value is valid. |

After a CMD7 transfer is complete, the MMC card is ready to receive a CMD6 command. CMD6 command is used to write a byte in MMC card extended CSD register (ext\_csd). It is an IO access function. There are two write actions, the first one enables a specific data bus width in the card. For our use case we used data bus width 4. The second one enables high speed feature in the card.

#### 24.6.1.3.4.1.1 Setting Data Bus Width to 4

[Table 24-25](#) shows the set of registers impacted by issuing CMD6.

**Table 24-25. Setting Data Bus Width With CMD6**

| Register Name    | Register Address | Value      | Value Description                                                                                           |
|------------------|------------------|------------|-------------------------------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_CON | 0x4809C02C       | 0x00000000 | MMC bus is in push-pull mode.                                                                               |
| MMCHS1.MMCHS_IE  | 0x4809C134       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB events to occur.                                                   |
| MMCHS1.MMCHS_ISE | 0x4809C138       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB interrupts to rise.                                                |
| MMCHS1.MMCHS_CMD | 0x4809C10C       | 0x061b0000 | Sends CMD6 whose opcode is 6, response type is 48 bits with busy, with CICE and CCCE enabled.               |
| MMCHS1.MMCHS_ARG | 0x4809C108       | 0x03b70100 | (3 << 24)   (byte_address << 16)   (byte_value << 8). byte_address is the byte address in ext_csd register. |

After issuing CMD6 completes successfully and MMC card leaves busy state, MMCHS controller should change its data bus width to 4. This is done by changing MMCHS1.MMCHS\_HCTL configuration value.

**Table 24-26. MMCHS\_HCTL Value**

| Register Name     | Register Address | Value      | Value Description                              |
|-------------------|------------------|------------|------------------------------------------------|
| MMCHS1.MMCHS_HCTL | 0x4809C128       | 0x00000002 | MMCHS controller's data bus width is set to 4. |

#### 24.6.1.3.4.1.2 Enable High-Speed Feature

Table 24-27 shows the set of registers impacted by issuing CMD6 issuing.

**Table 24-27. Enabling High-Speed With CMD6**

| Register Name     | Register Address | Value      | Value Description                                                                                           |
|-------------------|------------------|------------|-------------------------------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_CON  | 0x4809C02C       | 0x00000000 | MMC bus is in push-pull mode.                                                                               |
| MMCHS1.MMCHS_HCTL | 0x4809C128       | 0x00000002 | MMCHS controller's data bus width is set to 4.                                                              |
| MMCHS1.MMCHS_IE   | 0x4809C134       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB events to occur.                                                   |
| MMCHS1.MMCHS_ISE  | 0x4809C138       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB interrupts to rise.                                                |
| MMCHS1.MMCHS_CMD  | 0x4809C10C       | 0x061b0000 | Sends CMD6 whose opcode is 6, response type is 48 bits with busy, with CICE and CCCE enabled.               |
| MMCHS1.MMCHS_ARG  | 0x4809C108       | 0x03b90100 | (3 << 24)   (byte_address << 16)   (byte_value << 8). byte_address is the byte address in ext_csd register. |

After issuing CMD6 completes successfully and MMC card leaves busy state, MMCHS controller should now change its output clock to bring it to 48 MHz. 52 MHz, max frequency value supported by MMC card version 4 and above, is not supported because 96 MHz, MMCHS controller functional clock, is not a multiple of 52 MHz. We fall off to 48 MHz.

**Table 24-28. MMCHS\_SYSCTL Value**

| Register Name       | Register Address | Value      | Value Description                                                                                                                                                  |
|---------------------|------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_SYSCTL | 0x4809C12C       | 0x00000087 | MMCHS controller's internal clock is stable and enabled, MMC card's clock is on. Divider value is 2 which means that MMCHS controller is supplying a 48 MHz clock. |

#### 24.6.1.3.5 MMC Write Transfer

Either data read or data write transfer uses DMA controller to perform memory (DDRAM) to/from MMCHS controller transfers. The DMA part is not described in this chapter, it is described in [Chapter 11, SDMA](#).

Before any data transfer begins, the card must selected by issuing CMD7 command ([Table 24-24](#)).

A write transfer is a finite multiple block write transfer. To perform a write transfer, the following steps must be performed.

#### 24.6.1.3.5.1 Send CMD16

Issuing CMD16 allows to set the block length. For our use case we decided to use a static block length of 512 bytes. The block length value is passed to the MMC card via MMCHS1.MMCHS\_ARG register. The registers impacted by this operation are as follows:

**Table 24-29. Setting Block Length**

| Register Name     | Register Address | Value       | Value Description                                                                     |
|-------------------|------------------|-------------|---------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_CON  | 0x4809C02C       | 0x00000000  | MMC bus is in push-pull mode.                                                         |
| MMCHS1.MMCHS_HCTL | 0x4809C128       | 0x00000002  | MMCHS controller's data bus width is set to 4.                                        |
| MMCHS1.MMCHS_IE   | 0x4809C134       | 0x100f0001  | Enables CERR, CIE, CCRC, CC, CTO and CEB events to occur.                             |
| MMCHS1.MMCHS_ISE  | 0x4809C138       | 0x100f0001  | Enables CERR, CIE, CCRC, CC, CTO and CEB interrupts to rise.                          |
| MMCHS1.MMCHS_CMD  | 0x4809C10C       | 0x101a0000  | Sends CMD16 whose opcode is 16, response type is 48 bits, with CICE and CCCE enabled. |
| MMCHS1.MMCHS_ARG  | 0x4809C108       | 0x000000200 | Block length is 512 = 0x200                                                           |

#### 24.6.1.3.5.2 Send CMD23

Issuing CMD23 allows to set the number of how many 512-byte blocks the MMC card should expect from the MMCHS controller. The number of blocks is passed to MMC card via MMCHS1.MMCHS\_ARG register. The registers impacted by this operation are as follows:

**Table 24-30. Setting Number of Blocks**

| Register Name     | Register Address | Value      | Value Description                                                                     |
|-------------------|------------------|------------|---------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_CON  | 0x4809C02C       | 0x00000000 | MMC bus is in push-pull mode.                                                         |
| MMCHS1.MMCHS_HCTL | 0x4809C128       | 0x00000002 | MMCHS controller's data bus width is set to 4.                                        |
| MMCHS1.MMCHS_IE   | 0x4809C134       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB events to occur.                             |
| MMCHS1.MMCHS_ISE  | 0x4809C138       | 0x100f0001 | Enables CERR, CIE, CCRC, CC, CTO and CEB interrupts to rise.                          |
| MMCHS1.MMCHS_CMD  | 0x4809C10C       | 0x171a0000 | Sends CMD23 whose opcode is 23, response type is 48 bits, with CICE and CCCE enabled. |
| MMCHS1.MMCHS_ARG  | 0x4809C108       | 0x00000008 | Number of 512-byte blocks in 4 KB buffer is 8.                                        |

#### 24.6.1.3.5.3 Send CMD25

Issuing CMD25 starts the finite, multiple block write transfer. Before the transfer starts, DMA controller should be configured for this operation. For more details about DMA configuration see [Chapter 11, SDMA](#).

**Table 24-31. CMD25 Issuing**

| Register Name     | Register Address | Value      | Value Description                                                                                        |
|-------------------|------------------|------------|----------------------------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_CON  | 0x4809C02C       | 0x00000000 | MMC bus is in push-pull mode.                                                                            |
| MMCHS1.MMCHS_HCTL | 0x4809C128       | 0x00000002 | MMCHS controller's data bus width is set to 4.                                                           |
| MMCHS1.MMCHS_IE   | 0x4809C134       | 0x107f0013 | Enables CERR, CIE, CCRC, CC, TC, BWR, CTO, DTO, DCRC, DEB and CEB events to occur.                       |
| MMCHS1.MMCHS_ISE  | 0x4809C138       | 0x107f0013 | Enables CERR, CIE, CCRC, CC, TC, BWR, CTO, DTO, DCRC, DEB and CEB interrupts to rise.                    |
| MMCHS1.MMCHS_CMD  | 0x4809C10C       | 0x193a0023 | Sends CMD25 whose opcode is 25, response type is 48 bits, with CICE, DP, MSBS, BCE, DE and CCCE enabled. |

**Table 24-31. CMD25 Issuing (continued)**

| Register Name    | Register Address | Value      | Value Description                      |
|------------------|------------------|------------|----------------------------------------|
| MMCHS1.MMCHS_ARG | 0x4809C108       | 0x00000000 | Not used                               |
| MMCHS1.MMCHS_BLK | 0x4809C104       | 0x00080200 | (number_blocks << 16)   (block_length) |

#### 24.6.1.3.6 MMC Read Transfer

Either data read or data write transfer uses DMA controller to perform memory (DDRAM) to/from MMCHS controller transfers. The DMA part is not described in this document, it is described in [Chapter 11, SDMA](#).

Before any data transfer begins, the card must be selected by issuing CMD7 command ([Table 24-24](#)).

A read transfer is a finite multiple block write transfer. To perform a read transfer, the following steps must be performed.

##### 24.6.1.3.6.1 Send CMD16

Issuing CMD16 allows to set the block length. For our use case we decided to use a static block length of 512 bytes. The block length value is passed to the MMC card via MMCHS1.MMCHS\_ARG register. See [Table 24-29](#).

##### 24.6.1.3.6.2 Send CMD23

Issuing CMD23 allows to set the number of how many 512-byte blocks the MMC card should expect from the MMCHS controller. The number of blocks is passed to MMC card via MMCHS1.MMCHS\_ARG register. See [Table 24-30](#).

##### 24.6.1.3.6.3 Send CMD18

Issuing CMD18 starts the finite, multiple block read transfer. Before the transfer starts, DMA controller should be configured for this operation. For more details about DMA configuration see [Chapter 11, SDMA](#).

**Table 24-32. CMD18 Issuing**

| Register Name     | Register Address | Value      | Value Description                                                                                              |
|-------------------|------------------|------------|----------------------------------------------------------------------------------------------------------------|
| MMCHS1.MMCHS_CON  | 0x4809C02C       | 0x00000000 | MMC bus is in push-pull mode.                                                                                  |
| MMCHS1.MMCHS_HCTL | 0x4809C128       | 0x00000002 | MMCHS controller's data bus width is set to 4.                                                                 |
| MMCHS1.MMCHS_IE   | 0x4809C134       | 0x107f0023 | Enables CERR, CIE, CCRC, CC, TC, BRR, CTO, DTO, DCRC, DEB and CEB events to occur.                             |
| MMCHS1.MMCHS_ISE  | 0x4809C138       | 0x107f0023 | Enables CERR, CIE, CCRC, CC, TC, BRR, CTO, DTO, DCRC, DEB and CEB interrupts to rise.                          |
| MMCHS1.MMCHS_CMD  | 0x4809C10C       | 0x123a0033 | Sends CMD18 whose opcode is 18, response type is 48 bits, with CICE, DP, MSBS, BCE, DE, DDIR and CCCE enabled. |
| MMCHS1.MMCHS_ARG  | 0x4809C108       | 0x00000000 | Not used                                                                                                       |
| MMCHS1.MMCHS_BLK  | 0x4809C104       | 0x00080200 | (number_blocks << 16)   (block_length)                                                                         |

#### 24.6.1.3.7 Dealing With High-Capacity Cards

Unlike standard-capacity cards, memory addressing mode for high-capacity cards (SDHC and HC MMC) is in 512-byte block format instead of byte format. This means that byte and partial accesses are not allowed with high-capacity cards.

The 32-bit wide argument configured in the [MMCHS\\_ARG](#) register and sent in data transfer commands CMD17, CMD18, CMD24, and CMD25, carries the block index where the read/write should start and not the 32-bit byte address.

For high-capacity cards, the block size is fixed at 512 bytes. Any data transfer, when the data bus is involved, must be a multiple of 512 bytes.

The number of blocks for a high-capacity card, which determines the capacity of the card block\_count x 512 bytes, is accessible through field C\_SIZE in the card's CSD register version 2.0 for SD cards, or through the SEC\_COUNT field in the card's EXT\_CSD register for MMC cards compliant with MMC specification version 4.x.

To write/read a packet whose size is less than 512 bytes to/from a high-capacity card, write/read the whole 512-byte block that contains the range of bytes to modify/read.

## 24.7 MMC/SD/SDIO Register Manual

### 24.7.1 MMC/SD/SDIO Instance Summary

**Table 24-33. Instance Summary**

| Module Name | Base Address | Size    |
|-------------|--------------|---------|
| MMCHS1      | 0x4809 C000  | 4K byte |
| MMCHS2      | 0x480B 4000  | 4K byte |
| MMCHS3      | 0x480A D000  | 4K byte |

### 24.7.2 MMC/SD/SDIO Registers

#### 24.7.2.1 MMC/SD/SDIO Register Summary

**Table 24-34. MMC/SD/SDIO Register Summary**

| Register Name   | Type | Register Width (Bits) | Address Offset | MMCHS1 Physical Address | MMCHS2 Physical Address | MMCHS3 Physical Address |
|-----------------|------|-----------------------|----------------|-------------------------|-------------------------|-------------------------|
| MMCHS_SYSCONFIG | RW   | 32                    | 0x0000 0010    | 0x4809 C010             | 0x480B 4010             | 0x480A D010             |
| MMCHS_SYSSTATUS | R    | 32                    | 0x0000 0014    | 0x4809 C014             | 0x480B 4014             | 0x480A D014             |
| MMCHS_CSRE      | RW   | 32                    | 0x0000 0024    | 0x4809 C024             | 0x480B 4024             | 0x480A D024             |
| MMCHS_SYSTEST   | RW   | 32                    | 0x0000 0028    | 0x4809 C028             | 0x480B 4028             | 0x480A D028             |
| MMCHS_CON       | RW   | 32                    | 0x0000 002C    | 0x4809 C02C             | 0x480B 402C             | 0x480A D02C             |
| MMCHS_PWCNT     | RW   | 32                    | 0x0000 0030    | 0x4809 C030             | 0x480B 4030             | 0x480A D030             |
| MMCHS_BLK       | RW   | 32                    | 0x0000 0104    | 0x4809 C104             | 0x480B 4104             | 0x480A D104             |
| MMCHS_ARG       | RW   | 32                    | 0x0000 0108    | 0x4809 C108             | 0x480B 4108             | 0x480A D108             |
| MMCHS_CMD       | RW   | 32                    | 0x0000 010C    | 0x4809 C10C             | 0x480B 410C             | 0x480A D10C             |
| MMCHS_RSP10     | R    | 32                    | 0x0000 0110    | 0x4809 C110             | 0x480B 4110             | 0x480A D110             |
| MMCHS_RSP32     | R    | 32                    | 0x0000 0114    | 0x4809 C114             | 0x480B 4114             | 0x480A D114             |
| MMCHS_RSP54     | R    | 32                    | 0x0000 0118    | 0x4809 C118             | 0x480B 4118             | 0x480A D118             |
| MMCHS_RSP76     | R    | 32                    | 0x0000 011C    | 0x4809 C11C             | 0x480B 411C             | 0x480A D11C             |
| MMCHS_DATA      | RW   | 32                    | 0x0000 0120    | 0x4809 C120             | 0x480B 4120             | 0x480A D120             |
| MMCHS_PSTATE    | R    | 32                    | 0x0000 0124    | 0x4809 C124             | 0x480B 4124             | 0x480A D124             |
| MMCHS_HCTL      | RW   | 32                    | 0x0000 0128    | 0x4809 C128             | 0x480B 4128             | 0x480A D128             |
| MMCHS_SYSCTL    | RW   | 32                    | 0x0000 012C    | 0x4809 C12C             | 0x480B 412C             | 0x480A D12C             |
| MMCHS_STAT      | RW   | 32                    | 0x0000 0130    | 0x4809 C130             | 0x480B 4130             | 0x480A D130             |
| MMCHS_IE        | RW   | 32                    | 0x0000 0134    | 0x4809 C134             | 0x480B 4134             | 0x480A D134             |
| MMCHS_ISE       | RW   | 32                    | 0x0000 0138    | 0x4809 C138             | 0x480B 4138             | 0x480A D138             |
| MMCHS_AC12      | R    | 32                    | 0x0000 013C    | 0x4809 C13C             | 0x480B 413C             | 0x480A D13C             |
| MMCHS_CAPA      | RW   | 32                    | 0x0000 0140    | 0x4809 C140             | 0x480B 4140             | 0x480A D140             |
| MMCHS_CUR_CAPA  | RW   | 32                    | 0x0000 0148    | 0x4809 C148             | 0x480B 4148             | 0x480A D148             |
| MMCHS_REV       | R    | 32                    | 0x0000 01FC    | 0x4809 C1FC             | 0x480B 41FC             | 0x480A D1FC             |

## 24.7.2.2 MMCHS Registers

**Table 24-35. MMCHS\_SYSCONFIG**

|                         |                                                                                                                     |                 |        |
|-------------------------|---------------------------------------------------------------------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x010                                                                                                               | <b>Instance</b> | MMCHS1 |
| <b>Physical Address</b> | 0x4809 C010                                                                                                         |                 | MMCHS3 |
|                         | 0x480A D010                                                                                                         |                 | MMCHS2 |
|                         | 0x480B 4010                                                                                                         |                 |        |
| <b>Description</b>      | System Configuration Register<br>This register allows controlling various parameters of the Interconnect interface. |                 |        |
| <b>Type</b>             | RW                                                                                                                  |                 |        |



| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:10       | Reserved          | These bits are initialized to zero, and writes to them are ignored.<br>Reads return 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R           | 0x00000      |
| 9:8         | CLOCKACTIVITY     | Clocks activity during wake up mode period.<br>Bit8: Interface clock<br>Bit9: Functional clock<br><br>0x0: Interface and Functional clock may be switched off.<br>0x1: Interface clock is maintained. Functional clock may be switched-off.<br>0x2: Functional clock is maintained. Interface clock may be switched-off.<br>0x3: Interface and Functional clocks are maintained.                                                                                                                                                                                                                               | RW          | 0x0          |
| 7:5         | Reserved          | These bits are initialized to zero, and writes to them are ignored.<br>Reads return 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R           | 0            |
| 4:3         | SIDLEMODE         | Power management<br><br>0x0: If an idle request is detected, the MMC/SD/SDIO host controller acknowledges it unconditionally and goes in Inactive mode. Interrupt and DMA requests are unconditionally deasserted.<br>0x1: If an idle request is detected, the request is ignored and the module keeps on behaving normally.<br>0x2: If an idle request is detected, the module will switch to wake up mode based on its internal activity, and the wake up capability can be used if the wake up capability is enabled (bit MMCI.MMCHS_SYSCONFIG[2] ENAWAKEUP bit is set to 1).<br>0x3: Reserved - do not use | RW          | 0x2          |
| 2           | ENAWAKEUP         | Wake-up feature control<br><br>0x0: Wake-up capability is disabled<br>0x1: Wake-up capability is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW          | 1            |
| 1           | SOFTRESET         | Software reset.<br>The bit is automatically reset by the hardware. During reset, it always returns 0.<br><br>Read 0x0: Normal mode<br>Write 0x0: No effect.<br>Read 0x1: The module is reset.<br>Write 0x1: Trigger a module reset.                                                                                                                                                                                                                                                                                                                                                                            | RW          | 0            |
| 0           | AUTOIDLE          | Internal Clock gating strategy<br><br>0x0: Clocks are free-running                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW          | 1            |

| Bits | Field Name | Description                                                                                      | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------|------|-------|
| 0x1: |            | Automatic clock gating strategy is applied, based on the interconnect and MMC interface activity |      |       |

**Table 24-36. Register Call Summary for Register MMCHS\_SYSCONFIG**

|                                                       |  |
|-------------------------------------------------------|--|
| MMC/SD/SDIO Integration                               |  |
| • Clocks: [0] [1] [2] [3] [4] [5] [6]                 |  |
| • Resets: [7]                                         |  |
| MMC/SD/SDIO Use Cases and Tips                        |  |
| • Programming Flow: [8] [9]                           |  |
| MMC/SD/SDIO Register Manual                           |  |
| • MMC/SD/SDIO Register Summary: [10]                  |  |
| • MMCHS Registers: [11] [12] [13] [14] [15] [16] [17] |  |

**Table 24-37. MMCHS\_SYSSTATUS**

|                         |                         |                       |                                                                                                       |
|-------------------------|-------------------------|-----------------------|-------------------------------------------------------------------------------------------------------|
| Address Offset          | 0x014                   |                       |                                                                                                       |
| Physical Address        | 0x4809 C014             | Instance              | MMCHS1                                                                                                |
|                         | 0x480A D014             |                       | MMCHS3                                                                                                |
|                         | 0x480B 4014             |                       | MMCHS2                                                                                                |
| Description             | System Status Register  |                       | This register provides status information about the module excluding the interrupt status information |
| Type                    | R                       |                       |                                                                                                       |
| 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                                                                                       |
|                         |                         |                       |                                                                                                       |
|                         |                         | Reserved              |                                                                                                       |
|                         |                         |                       | RESETDONE                                                                                             |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                    | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:1 | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                    | R    | 0x00000000 |
| 0    | RESETDONE  | Internal Reset Monitoring<br>Note: the debounce clock , the interface clock and the functional clock shall be provided to the MMC/SD/SDIO host controller to allow the internal reset monitoring.<br>Read 0x0: Internal module reset is on-going<br>Read 0x1: Reset completed. | R    | 0          |

**Table 24-38. Register Call Summary for Register MMCHS\_SYSSTATUS**

|                                     |  |
|-------------------------------------|--|
| MMC/SD/SDIO Integration             |  |
| • Resets: [0] [1] [2]               |  |
| MMC/SD/SDIO Use Cases and Tips      |  |
| • Programming Flow: [3] [4]         |  |
| MMC/SD/SDIO Register Manual         |  |
| • MMC/SD/SDIO Register Summary: [5] |  |

**Table 24-39. MMCHS\_CSRE**

| <b>Address Offset</b>   | 0x024                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <b>Instance</b>            | MMCHS1<br>MMCHS3<br>MMCHS2 |            |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----------------------------|------------|
| <b>Physical Address</b> | 0x4809 C024                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                            |                            |            |
|                         | 0x480A D024                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                            |                            |            |
|                         | 0x480B 4024                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                            |                            |            |
| <b>Description</b>      | Card status response error<br>This register enables the host controller to detect card status errors of response type R1, R1b for all cards and of R5, R5b and R6 response for cards types SD or SDIO.<br>When a bit MMCi.MMCHS_CSRE[I] is set to 1, if the corresponding bit at the same position in the response MMCi.MMCHS_RSP10[I] is set to 1, the host controller indicates a card error (MMCi.MMCHS_STAT[28] CERR bit) interrupt status to avoid the host driver reading the response register (MMCi.MMCHS_RSP10).<br>Note: No automatic card error detection for autoCMD12 is implemented; the host system has to check autoCMD12 response register (MMCi.MMCHS_RSP76) for possible card errors. |                            |                            |            |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                            |                            |            |
| 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            |            |
| CSRE                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                            |                            |            |
| Bits                    | Field Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Description                | Type                       | Reset      |
| 31:0                    | CSRE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Card status response error | RW                         | 0x00000000 |

**Table 24-40. Register Call Summary for Register MMCHS\_CSRE**

MMC/SD/SDIO Register Manual

- MMC/SD/SDIO Register Summary: [0]
- MMCHS Registers: [1] [2]

**Table 24-41. MMCHS\_SYSTEST**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       |                                                                            |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|----------------------------------------------------------------------------|--|
| <b>Address Offset</b>   | 0x028                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <b>Instance</b>       | MMCHS1<br>MMCHS3<br>MMCHS2                                                 |  |
| <b>Physical Address</b> | 0x4809 C028                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       |                                                                            |  |
|                         | 0x480A D028                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       |                                                                            |  |
|                         | 0x480B 4028                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       |                                                                            |  |
| <b>Description</b>      | System Test register<br>This register is used to control the signals that connect to I/O pins when the module is configured in system test (SYSTEST) mode for boundary connectivity verification.<br>Note: In SYSTEST mode, a write into MMCi.MMCHS_CMD register will not start a transfer. The buffer behaves as a stack accessible only by the local host (push and pop operations). In this mode, the Transfer Block Size (MMCi.MMCHS_BLK[10:0] BLEN bits) and the Blocks count for current transfer (MMCi.MMCHS_BLK[31:16] NBLK bits) are needed to generate a Buffer write ready interrupt (MMCi.MMCHS_STAT[4] BWR bit) or a Buffer read ready interrupt (MMCi.MMCHS_STAT[5] BRR bit) and DMA requests if enabled. |                       |                                                                            |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                       |                                                                            |  |
| 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                                                            |  |
| Reserved                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       | OBI SDCD SDWP WAKD SSB D7D D6D D5D D4D D3D D2D D1D D0D DDIR CDAT CDIR MCKD |  |

| Bits  | Field Name | Description                                                                                                                                        | Type | Reset   |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:17 | Reserved   | Reserved bit field. Do not write any value. Reads return 0.                                                                                        | R    | 0x00000 |
| 16    | OBI        | Out-Of-Band Interrupt (OBI) data value.<br>0x0: The Out-of-Band Interrupt pin is driven low.<br>0x1: The Out-of-Band Interrupt pin is driven high. | RW   | 0       |
| 15    | SDCD       | Card detect input signal (SDCD) data value<br>0x0: The card detect pin is driven low.                                                              | R    | 0       |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 14   | SDWP       | <p>0x1: The card detect pin is driven high.</p> <p>0x0: Write protect input signal (SDWP) data value.</p> <p>0x1: The write protect pin SDWP is driven low.</p> <p>0x1: The write protect pin SDWP is driven high.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R    | 0     |
| 13   | WAKD       | <p>Wake request output signal data value.</p> <p>Read 0x0: No action. Returns 0.</p> <p>Write 0x0: The pin SWAKEUP is driven low.</p> <p>Read 0x1: No action. Returns 1.</p> <p>Write 0x1: The pin SWAKEUP is driven high.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW   | 0     |
| 12   | SSB        | <p>Set status bit</p> <p>This bit must be cleared prior attempting to clear a status bit of the interrupt status register (MMCi.MMCHS_STAT).</p> <p>Read 0x0: No action. Returns 0.</p> <p>Write 0x0: Clear this SSB bit field. Writing 0 does not clear already set status bits.</p> <p>Read 0x1: No action. Returns 1.</p> <p>Write 0x1: Force to 1 all status bits of the interrupt status register (MMCi.MMCHS_STAT) only if the corresponding bit field in the Interrupt signal enable register (MMCi.MMCHS_ISE) is set.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW   | 0     |
| 11   | D7D        | <p>DAT7 input/output signal data value.</p> <p>Read 0x0:</p> <ul style="list-style-type: none"> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 1 (input mode direction), returns the value on the DAT7 line (low).</li> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 0 (output mode direction), returns 0.</li> </ul> <p>Write 0x0:</p> <ul style="list-style-type: none"> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 0 (output mode direction), the DAT7 line is driven low.</li> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 1 (input mode direction), no effect.</li> </ul> <p>Read 0x1:</p> <ul style="list-style-type: none"> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 1 (input mode direction), returns the value on the DAT7 line (high)</li> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 0 (output mode direction), returns 1.</li> </ul> <p>Write 0x1:</p> <ul style="list-style-type: none"> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 0 (output mode direction), the DAT7 line is driven high.</li> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 1 (input mode direction), no effect.</li> </ul> | RW   | 0     |
| 10   | D6D        | <p>DAT6 input/output signal data value.</p> <p>Read 0x0:</p> <ul style="list-style-type: none"> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 1 (input mode direction), returns the value on the DAT6 line (low).</li> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 0 (output mode direction), returns 0.</li> </ul> <p>Write 0x0:</p> <ul style="list-style-type: none"> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 0 (output mode direction), the DAT6 line is driven low.</li> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 1 (input mode direction), no effect.</li> </ul> <p>Read 0x1:</p> <ul style="list-style-type: none"> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 1 (input mode direction), returns the value on the DAT6 line (high)</li> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 0 (output mode direction), returns 1.</li> </ul> <p>Write 0x1:</p> <ul style="list-style-type: none"> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 0 (output mode direction), the DAT6 line is driven high.</li> <li>If MMCi.MMCHS_SYSTEST[3] DDIR bit = 1 (input mode direction), no effect.</li> </ul> | RW   | 0     |
| 9    | D5D        | DAT5 input/output signal data value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
|             |                   | <p>Read 0x0: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), returns the value on the DAT5 line (low).<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), returns 0.</p> <p>Write 0x0: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), the DAT5 line is driven low.<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), no effect.</p> <p>Read 0x1: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), returns the value on the DAT5 line (high)<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), returns 1.</p> <p>Write 0x1: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), the DAT5 line is driven high.<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), no effect.</p> |             |              |
| 8           | D4D               | DAT4 input/output signal data value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW          | 0            |
|             |                   | <p>Read 0x0: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), returns the value on the DAT4 line (low).<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), returns 0.</p> <p>Write 0x0: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), the DAT4 line is driven low.<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), no effect.</p> <p>Read 0x1: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), returns the value on the DAT4 line (high)<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), returns 1.</p> <p>Write 0x1: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), the DAT4 line is driven high.<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), no effect.</p> |             |              |
| 7           | D3D               | DAT3 input/output signal data value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW          | 0            |
|             |                   | <p>Read 0x0: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), returns the value on the DAT3 line (low).<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), returns 0.</p> <p>Write 0x0: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), the DAT3 line is driven low.<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), no effect.</p> <p>Read 0x1: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), returns the value on the DAT3 line (high)<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), returns 1.</p> <p>Write 0x1: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), the DAT3 line is driven high.<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), no effect.</p> |             |              |
| 6           | D2D               | DAT2 input/output signal data value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW          | 0            |
|             |                   | <p>Read 0x0: If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 1 (input mode direction), returns the value on the DAT2 line (low).<br/> If MMCi.<b>MMCHS_SYTEST[3]</b> DDIR bit = 0 (output mode direction), returns 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |              |

| Bits | Field Name | Description                                                                                                                                                                                                      | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | Write 0x0: If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 0 (output mode direction), the DAT2 line is driven low.<br>If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 1 (input mode direction), no effect.             |      |       |
|      |            | Read 0x1: If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 1 (input mode direction), returns the value on the DAT2 line (high)<br>If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 0 (output mode direction), returns 1. |      |       |
|      |            | Write 0x1: If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 0 (output mode direction), the DAT2 line is driven high.<br>If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 1 (input mode direction), no effect.            |      |       |
| 5    | D1D        | DAT1 input/output signal data value.                                                                                                                                                                             | RW   | 0     |
|      |            | Read 0x0: If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 1 (input mode direction), returns the value on the DAT1 line (low).<br>If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 0 (output mode direction), returns 0. |      |       |
|      |            | Write 0x0: If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 0 (output mode direction), the DAT1 line is driven low.<br>If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 1 (input mode direction), no effect.             |      |       |
|      |            | Read 0x1: If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 1 (input mode direction), returns the value on the DAT1 line (high)<br>If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 0 (output mode direction), returns 1. |      |       |
|      |            | Write 0x1: If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 0 (output mode direction), the DAT1 line is driven high.<br>If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 1 (input mode direction), no effect.            |      |       |
| 4    | D0D        | DAT0 input/output signal data value.                                                                                                                                                                             | RW   | 0     |
|      |            | Read 0x0: If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 1 (input mode direction), returns the value on the DAT0 line (low).<br>If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 0 (output mode direction), returns 0. |      |       |
|      |            | Write 0x0: If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 0 (output mode direction), the DAT0 line is driven low.<br>If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 1 (input mode direction), no effect.             |      |       |
|      |            | Read 0x1: If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 1 (input mode direction), returns the value on the DAT0 line (high)<br>If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 0 (output mode direction), returns 1. |      |       |
|      |            | Write 0x1: If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 0 (output mode direction), the DAT0 line is driven high.<br>If MMCi. <b>MMCHS_SYSTEST</b> [3] DDIR bit = 1 (input mode direction), no effect.            |      |       |
| 3    | DDIR       | Control of the DAT[7:0] pins direction.                                                                                                                                                                          | RW   | 0     |
|      |            | Read 0x0: No action. Returns 0.                                                                                                                                                                                  |      |       |
|      |            | Write 0x0: The DAT lines are outputs (host to card).                                                                                                                                                             |      |       |
|      |            | Read 0x1: No action. Returns 1.                                                                                                                                                                                  |      |       |
|      |            | Write 0x1: The DAT lines are inputs (card to host).                                                                                                                                                              |      |       |
| 2    | CDAT       | CMD input/output signal data value.                                                                                                                                                                              | RW   | 0     |
|      |            | Read 0x0: If MMCi. <b>MMCHS_SYSTEST</b> [1] CDIR bit = 1 (input mode direction), returns the value on the CMD line (low).<br>If MMCi. <b>MMCHS_SYSTEST</b> [1] CDIR bit = 0 (output mode direction), returns 0 . |      |       |

| Bits | Field Name | Description                                                                                                                                                                                                                             | Type | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|      |            | Write 0x0: If MMCI.MMCHS_SYSTEST[1] CDIR bit = 0 (output mode direction), the CMD line is driven low.<br>If MMCI.MMCHS_SYSTEST[1] CDIR bit = 1 (input mode direction), no effect.                                                       |      |       |
|      |            | Read 0x1: If MMCI.MMCHS_SYSTEST[1] CDIR bit = 1 (input mode direction), returns the value on the CMD line (high)<br>If MMCI.MMCHS_SYSTEST[1] CDIR bit = 0 (output mode direction), returns 1 .                                          |      |       |
|      |            | Write 0x1: If MMCI.MMCHS_SYSTEST[1] CDIR bit = 0 (output mode direction), the CMD line is driven high.<br>If MMCI.MMCHS_SYSTEST[1] CDIR bit = 1 (input mode direction), no effect.                                                      |      |       |
| 1    | CDIR       | Control of the CMD pin direction.<br><br>Read 0x0: No action. Returns 0.<br><br>Write 0x0: The CMD line is an output (host to card).<br><br>Read 0x1: No action. Returns 1.<br><br>Write 0x1: The CMD line is an input (card to host) . | RW   | 0     |
| 0    | MCKD       | MMC clock output signal data value.<br><br>Read 0x0: No action. Returns 0.<br><br>Write 0x0: The output clock is driven low.<br><br>Read 0x1: No action. Returns 1.<br><br>Write 0x1: The output clock is driven high.                  | RW   | 0     |

**Table 24-42. Register Call Summary for Register MMCHS\_SYSTEST**

MMC/SD/SDIO Register Manual

- [MMC/SD/SDIO Register Summary: \[0\]](#)
- [MMCHS Registers: \[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\] \[32\] \[33\] \[34\] \[35\] \[36\] \[37\] \[38\] \[39\] \[40\] \[41\] \[42\] \[43\] \[44\] \[45\] \[46\] \[47\] \[48\] \[49\] \[50\] \[51\] \[52\] \[53\] \[54\] \[55\] \[56\] \[57\] \[58\] \[59\] \[60\] \[61\] \[62\] \[63\] \[64\] \[65\] \[66\] \[67\] \[68\] \[69\] \[70\] \[71\] \[72\]](#)

**Table 24-43. MMCHS\_CON**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                     |                 |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|-----------------|--|
| <b>Address Offset</b>   | 0x02C                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                     |                 |  |
| <b>Physical Address</b> | 0x4809 C02C                                                                                                                                                                                                                                                                                                                                                                                                                       | <b>Instance</b>                                                     | MMCHS1          |  |
|                         | 0x480A D02C                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                     | MMCHS3          |  |
|                         | 0x480B 402C                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                     | MMCHS2          |  |
| <b>Description</b>      | Configuration register<br><br>This register is used:<br>- to select the functional mode for any card.<br>- to send an initialization sequence to any card.<br>- to enable the detection on the mmci_dat[1] signal of a card interrupt for SDIO cards only.<br>And also to configure:<br>- specific data and command transfers for MMC cards only.<br>- the parameters related to the card detect and write protect input signals. |                                                                     |                 |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                     |                 |  |
| 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 |  |
| Reserved                | CLKEXTFREE                                                                                                                                                                                                                                                                                                                                                                                                                        | PADEN OBIE OBIP CEATA CTPL DVAL WPP CDP MIT DW8 MODE STR HR INIT OD |                 |  |

## MMC/SD/SDIO Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset   |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:17 | Reserved   | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R    | 0x00000 |
| 16    | CLKEXTFREE | <p>External clock free running.</p> <p>This register is used to maintain card clock out of transfer transaction to enable slave module (for example to generate a synchronous interrupt on mmci_dat[1]). The Clock will be maintain only if MMCi.MMCHS_SYSCTL[2] CEN bit is set.</p> <p>0x0: External card clock is cut off outside active transaction period.</p> <p>0x1: External card clock is maintain even out of active transaction period only if MMCi.MMCHS_SYSCTL[2] CEN bit is set.</p>                                                                                                                                                                                                                 | RW   | 0       |
| 15    | PADEN      | <p>Control Power for MMC Lines.</p> <p>This register is only useful when MMC PADs contain power saving mechanism to minimize its leakage power. It works as a GPIO that directly control the ACTIVE pin of PADs. Excepted for mmci_dat[1], the signal is also combine outside the module with the dedicated power control MMCi.MMCHS_CON[11] CTPL bit.</p> <p>0x0: ADPIDE module pin is not forced, it is automatically generated by the MMC fsm.</p> <p>0x1: ADPIDE module pin is forced to active state.</p>                                                                                                                                                                                                    | RW   | 0       |
| 14    | OBIE       | <p>Out-of-Band Interrupt Enable (MMC cards only).</p> <p>This bit enables the detection of Out-of-Band Interrupt on MMCOBI input pin. The usage of the Out-of-Band signal (OBI) is optional and depends on the system integration.</p> <p>0x0: Out-of-Band interrupt detection disabled.</p> <p>0x1: Out-of-Band interrupt detection enabled.</p>                                                                                                                                                                                                                                                                                                                                                                 | RW   | 0       |
| 13    | OBIP       | <p>Out-of-Band Interrupt Polarity (MMC cards only).</p> <p>This bit selects the active level of the out-of-band interrupt coming from MMC cards. The usage of the Out-of-Band signal (OBI) is optional and depends on the system integration.</p> <p>0x0: active high level.</p> <p>0x1: active low level.</p>                                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0       |
| 12    | CEATA      | <p>CE-ATA control mode (MMC cards compliant with CE-ATA):</p> <p>By default, this bit is set to 0. It is use to indicate that next commands are considered as specific CE-ATA commands that potentially use 'command completion' features.</p> <p>0x0: Standard MMC/SD/SDIO mode.</p> <p>0x1: CE-ATA mode.<br/>Next commands are considered as CE-ATA commands.</p>                                                                                                                                                                                                                                                                                                                                               | RW   | 0       |
| 11    | CTPL       | <p>Control Power for mmci_dat[1] line (MMC and SD cards):</p> <p>By default, this bit is set to 0 and the host controller automatically disables all the input buffers outside of a transaction to minimize the leakage current.</p> <p>SDIO cards:</p> <p>When this bit is set to 1, the host controller automatically disables all the input buffers except the buffer of mmci_dat[1] outside of a transaction in order to detect asynchronous card interrupt on mmci_dat[1] line and minimize the leakage current of the buffers.</p> <p>0x0: Disable all the input buffers outside of a transaction.</p> <p>0x1: Disable all the input buffers except the buffer of mmci_dat[1] outside of a transaction.</p> | RW   | 0       |
| 10:9  | DVAL       | <p>Debounce filter value (All cards)</p> <p>This register is used to define a debounce period to filter the card detect input signal (SDCD). The usage of the card detect input signal (SDCD) is optional and depends on the system integration and the type of the connector housing that accommodates the card.</p> <p>0x0: 33 us debounce period.</p> <p>0x1: 231 us debounce period.</p>                                                                                                                                                                                                                                                                                                                      | RW   | 0x3     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
|             |                   | 0x2: 1 ms debounce period.<br>0x3: 8.4 ms debounce period.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |             |              |
| 8           | WPP               | Write protect polarity (SD and SDIO cards only)<br>This bit selects the active level of the write protect input signal (SDWP). The usage of the write protect input signal (SDWP) is optional and depends on the system integration and the type of the connector housing that accommodates the card.<br>0x0: Active high level.<br>0x1: Active low level.                                                                                                                                                                                                                                                            | RW          | 0            |
| 7           | CDP               | Card detect polarity (All cards)<br>This bit selects the active level of the card detect input signal (SDCD). The usage of the card detect input signal (SDCD) is optional and depends on the system integration and the type of the connector housing that accommodates the card.<br>0x0: Active high level.<br>0x1: Active low level.                                                                                                                                                                                                                                                                               | RW          | 0            |
| 6           | MIT               | MMC interrupt command (Only for MMC cards.)<br>This bit must be set to 1, when the next write access to the command register (MMCI. <a href="#">MMCHS_CMD</a> ) is for writing a MMC interrupt command (CMD40) requiring the command timeout detection to be disabled for the command response.<br>0x0: Command timeout enabled<br>0x1: Command timeout disabled                                                                                                                                                                                                                                                      | RW          | 0            |
| 5           | DW8               | 8-bit mode MMC select<br>For SD/SDIO cards, this bit must be set to 0.<br>For MMC card, this bit must be set following a valid SWITCH command (CMD6) with the correct value and extend CSD index written in the argument. Prior to this command, the MMC card configuration register (CSD and EXT_CSD) must be verified for compliancy with MMC standard specification.<br>0x0: 1-bit or 4-bit Data width (mmci_dat[0] or mmci_dat[3:0] used, MMC, SD cards)<br>0x1: 8-bit Data width (mmci_dat[7:0] used, MMC cards)                                                                                                 | RW          | 0            |
| 4           | MODE              | Mode select (All cards)<br>These bits select the functional mode.<br>0x0: Functional mode.<br>Transfers to the MMC/SD/SDIO cards follow the card protocol. MMC clock is enabled. MMC/SD transfers are operated under the control of the MMCI. <a href="#">MMCHS_CMD</a> register.<br>0x1: SYSTEST mode.<br>The signal pins are configured as general-purpose input/output and the 1024-byte buffer is configured as a stack memory accessible only by the local host or system DMA. The pins retain their default type (input, output or in-out). SYSTEST mode is operated under the control of the SYSTEST register. | RW          | 0            |
| 3           | STR               | Stream command (Only for MMC cards).<br>This bit must be set to 1 only for the stream data transfers (read or write) of the adtc commands.<br>Stream read is a class 1 command (CMD11: READ_DAT_UNTIL_STOP).<br>Stream write is a class 3 command (CMD20: WRITE_DAT_UNTIL_STOP).<br>0x0: Block oriented data transfer.<br>0x1: Stream oriented data transfer.                                                                                                                                                                                                                                                         | RW          | 0            |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 2    | HR         | <p>Broadcast host response (Only for MMC cards).<br/> This register is used to force the host to generate a 48-bit response for bc command type.<br/> It can be used to terminate the interrupt mode by generating a CMD40 response by the core. To have the host response to be generated in open drain mode, the register <b>MMCHS_CON[OD]</b> must be set to 1.<br/> When MMCI.MMCHS_CON[12] CEATA bit is set to 1 and MMCI.MMCHS_ARG set to 0x00000000, when writing 0x00000000 into MMCI.MMCHS_CMD register, the host controller performs a 'command completion signal disable' token (i.e. mmci_cmd line held to '0' during 47 cycles followed by a 1).</p> <p>0x0: The host does not generate a 48-bit response instead of a command.</p> <p>0x1: The host generates a 48-bit response instead of a command or a command completion signal disable token.</p> | RW   | 0     |
| 1    | INIT       | <p>Send initialization stream (All cards).<br/> When this bit is set to 1, and the card is idle, an initialization sequence is sent to the card.<br/> An initialization sequence consists of setting the mmci_cmd line to 1 during 80 clock cycles. The initialization sequence is mandatory - but it is not required to do it through this bit - this bit makes it easier. Clock divider (MMCI.MMCHS_SYSCTL[15:6] CLKD bits) should be set to ensure that 80 clock periods are greater than 1ms.<br/> Note: in this mode, there is no command sent to the card and no response is expected. A command complete interrupt will be generated once the initialization sequence is completed.<br/> MMCI.MMCHS_STAT[0] CC bit can be polled.</p> <p>0x0: The host does not send an initialization sequence.</p> <p>0x1: The host sends an initialization sequence.</p>   | RW   | 0     |
| 0    | OD         | <p>Card open drain mode (Only for MMC cards).<br/> This bit must be set to 1 for MMC card commands 1, 2, 3 and 40, and if the MMC card bus is operating in open-drain mode during the response phase to the command sent. Typically, during card identification mode when the card is either in idle, ready or ident state.<br/> It is also necessary to set this bit to 1, for a broadcast host response (see Broadcast host response register MMCI.MMCHS_CON[2] HR bit)</p> <p>0x0: No Open Drain</p> <p>0x1: Open Drain or Broadcast host response</p>                                                                                                                                                                                                                                                                                                            | RW   | 0     |

**Table 24-44. Register Call Summary for Register MMCHS\_CON**

## MMC/SD/SDIO Functional Description

- MMC CE-ATA Command Completion Disable Management: [0] [1] [2]

## MMC/SD/SDIO Use Cases and Tips

- Programming Flow: [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23] [24]

## MMC/SD/SDIO Register Manual

- MMC/SD/SDIO Register Summary: [25]
- MMCHS Registers: [26] [27] [28] [29] [30] [31] [32] [33] [34] [35] [36] [37]

**Table 24-45. MMCHS\_PWCNT**

|                         |                                                                                                                                                                                            |                 |        |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x030                                                                                                                                                                                      |                 |        |
| <b>Physical Address</b> | 0x4809 C030                                                                                                                                                                                | <b>Instance</b> | MMCHS1 |
|                         | 0x480A D030                                                                                                                                                                                |                 | MMCHS3 |
|                         | 0x480B 4030                                                                                                                                                                                |                 | MMCHS2 |
| <b>Description</b>      | Power counter register<br>This register is used to program a mmc counter to delay command transfers after activating the PAD power, this value depends on PAD characteristics and voltage. |                 |        |
| <b>Type</b>             | RW                                                                                                                                                                                         |                 |        |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PWRcnt |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                  | Type | Reset  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | Reserved   | These bits are initialized to zero, and writes to them are ignored.<br>Reads return 0.                                                                                                                                                                                                                                                                       | R    | 0x00   |
| 15:0  | PWRcnt     | Power counter register.<br>This register is used to introduce a delay between the PAD ACTIVE pin assertion and the command issued.<br>0x0: No additional delay added.<br>0x1: TCF delay (card clock period).<br>0x2: TCF x 2 delay (card clock period).<br>0xFFFFE: TCF x 65534 delay (card clock period).<br>0xFFFF: TCF x 65535 delay (card clock period). | RW   | 0x0000 |

**Table 24-46. Register Call Summary for Register MMCHS\_PWCNT**

MMC/SD/SDIO Register Manual

- MMC/SD/SDIO Register Summary: [0]

**Table 24-47. MMCHS\_BLK**

|                         |                                                                                     |                 |        |    |    |    |    |    |    |    |    |          |      |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------|-------------------------------------------------------------------------------------|-----------------|--------|----|----|----|----|----|----|----|----|----------|------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x104                                                                               |                 |        |    |    |    |    |    |    |    |    |          |      |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | 0x4809 C104                                                                         | <b>Instance</b> | MMCHS1 |    |    |    |    |    |    |    |    |          |      |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         | 0x480A D104                                                                         |                 | MMCHS3 |    |    |    |    |    |    |    |    |          |      |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         | 0x480B 4104                                                                         |                 | MMCHS2 |    |    |    |    |    |    |    |    |          |      |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | Transfer Length Configuration register<br>This register shall be used for any card. |                 |        |    |    |    |    |    |    |    |    |          |      |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>             | RW                                                                                  |                 |        |    |    |    |    |    |    |    |    |          |      |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| NBLK                    |                                                                                     |                 |        |    |    |    |    |    |    |    |    | Reserved | BLEN |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | NBLK       | <p>Blocks count for current transfer.<br/>           This register is enabled when Block count Enable (MMCI.MMCHS_CMD[1] BCE bit) is set to 1 and is valid only for multiple block transfers. Setting the block count to 0 results no data blocks being transferred. Note: The host controller decrements the block count after each block transfer and stops when the count reaches zero. This register can be accessed only if no transaction is executing (i.e., after a transaction has stopped). Read operations during transfers may return an invalid value and write operation will be ignored. In suspend context, the number of blocks yet to be transferred can be determined by reading this register. When restoring transfer context prior to issuing a Resume command, The local host shall restore the previously saved block count.</p> <ul style="list-style-type: none"> <li>0x0: Stop count</li> <li>0x1: 1 block</li> <li>0x2: 2 blocks</li> <li>0xFFFF: 65535 blocks</li> </ul> | RW   | 0x0000 |
| 15:11 | Reserved   | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R    | 0x00   |
| 10:0  | BLEN       | <p>Transfer Block Size. This register specifies the block size for block data transfers. Read operations during transfers may return an invalid value, and write operations are ignored. When a CMD12 command is issued to stop the transfer, a read of the BLEN field after transfer completion (MMCI.MMCHS_STAT[1] TC bit set to 1) will not return the true byte number of data length while the stop occurs but the value written in this register before transfer is launched.</p> <ul style="list-style-type: none"> <li>0x0: No data transfer</li> <li>0x1: 1 byte block length</li> <li>0x2: 2 bytes block length</li> <li>0x3: 3 bytes block length</li> <li>0xFF: 511 bytes block length</li> <li>0x200: 512 bytes block length</li> <li>0x3FF: 1023 bytes block length</li> <li>0x400: 1024 bytes block length</li> </ul>                                                                                                                                                                  | RW   | 0x000  |

**Table 24-48. Register Call Summary for Register MMCHS\_BLK**

## MMC/SD/SDIO Integration

- [DMA Requests: \[0\] \[1\]](#)

## MMC/SD/SDIO Functional Description

- [Data Buffer: \[2\]](#)

## MMC/SD/SDIO Use Cases and Tips

- [Programming Flow: \[3\] \[4\]](#)

## MMC/SD/SDIO Register Manual

- [MMC/SD/SDIO Register Summary: \[5\]](#)
- [MMCHS Registers: \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\]](#)

**Table 24-49. MMCHS\_ARG**

|                         |                                                                                                                                                                                                                                                                                                                                                                     |                 |        |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x108                                                                                                                                                                                                                                                                                                                                                               |                 |        |
| <b>Physical Address</b> | 0x4809 C108                                                                                                                                                                                                                                                                                                                                                         | <b>Instance</b> | MMCHS1 |
|                         | 0x480A D108                                                                                                                                                                                                                                                                                                                                                         |                 | MMCHS3 |
|                         | 0x480B 4108                                                                                                                                                                                                                                                                                                                                                         |                 | MMCHS2 |
| <b>Description</b>      | Command argument Register<br>This register contains command argument specified as bit 39-8 of Command-Format<br>These registers must be initialized prior to sending the command itself to the card (write action into the register MMCi.MMCHS_CMD register). Only exception is for a command index specifying stuff bits in arguments, making a write unnecessary. |                 |        |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                  |                 |        |

|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| ARG |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                 | Type | Reset      |
|------|------------|---------------------------------------------|------|------------|
| 31:0 | ARG        | Command argument bits [31:0] <sup>(1)</sup> | RW   | 0x00000000 |

<sup>(1)</sup> For CMD52, ARG has to be programmed with IO\_RW\_DIRECT[39:8]. See SDIO specification.

**Table 24-50. Register Call Summary for Register MMCHS\_ARG**

## MMC/SD/SDIO Functional Description

- MMC CE-ATA Command Completion Disable Management: [0]

## MMC/SD/SDIO Use Cases and Tips

- Programming Flow: [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18]

## MMC/SD/SDIO Register Manual

- MMC/SD/SDIO Register Summary: [19]
- MMCHS Registers: [20]

**Table 24-51. MMCHS\_CMD**

|                         |                                                                                                                                                                                                                                                                                                                                                                                   |                 |        |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x10C                                                                                                                                                                                                                                                                                                                                                                             |                 |        |
| <b>Physical Address</b> | 0x4809 C10C                                                                                                                                                                                                                                                                                                                                                                       | <b>Instance</b> | MMCHS1 |
|                         | 0x480A D10C                                                                                                                                                                                                                                                                                                                                                                       |                 | MMCHS3 |
|                         | 0x480B 410C                                                                                                                                                                                                                                                                                                                                                                       |                 | MMCHS2 |
| <b>Description</b>      | Command and transfer mode register<br>MMCi.MMCHS_CMD[31:16] = the command register<br>MMCi.MMCHS_CMD[15:0] = the transfer mode.<br>This register configures the data and command transfers. A write into the most significant byte send the command. A write into MMCi.MMCHS_CMD[15:0] registers during data transfer has no effect.<br>This register shall be used for any card. |                 |        |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                |                 |        |

|          |      |    |          |    |      |      |          |          |          |    |    |    |    |    |    |    |    |    |      |      |          |      |     |    |   |   |   |   |   |   |   |
|----------|------|----|----------|----|------|------|----------|----------|----------|----|----|----|----|----|----|----|----|----|------|------|----------|------|-----|----|---|---|---|---|---|---|---|
| 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 |
| Reserved | INDX |    | CMD_TYPE | DP | CICE | CCCE | Reserved | RSP_TYPE | Reserved |    |    |    |    |    |    |    |    |    | MSBS | DDIR | Reserved | ACEN | BCE | DE |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                      | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | Reserved   | Reserved bit field. Do not write any value                                                                       | R    | 0x0   |
| 29:24 | INDX       | Command index Binary encoded value from 0 to 63 specifying the command number send to card<br>0x0: CMD0 or ACMD0 | RW   | 0x00  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|       |            | 0x1: CMD1 or ACMD1<br>0x3F: CMD63 or ACMD63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |       |
| 23:22 | CMD_TYPE   | Command type.<br>This register specifies three types of special command: Suspend, Resume and Abort. These bits shall be set to 0b00 for all other commands.<br><br>0x0: Others Commands<br>0x1: Upon CMD52 "Bus Suspend" operation<br>0x2: Upon CMD52 "Function Select" operation<br>0x3: Upon CMD12 or CMD52 "I/O Abort" command                                                                                                                                                                                           | RW   | 0x0   |
| 21    | DP         | Data present select.<br>This register indicates that data is present and mmci_dat line shall be used. It must be set to 0 in the following conditions:<br>- Command using only mmci_cmd line<br>-Command with no data transfer but using busy signal on mmci_dat[0]<br>-Resume command<br><br>0x0: Command with no data transfer<br>0x1: Command with data transfer                                                                                                                                                         | RW   | 0     |
| 20    | CICE       | Command Index check enable.<br>This bit must be set to 1 to enable index check on command response to compare the index field in the response against the index of the command. If the index is not the same in the response as in the command, it is reported as a command index error (MMCi.MMCHS_STAT[19] CIE bit set to 1) Note: The CICE bit cannot be configured for an Auto CMD12, then index check is automatically checked when this command is issued.<br><br>0x0: Index check disable<br>0x1: Index check enable | RW   | 0     |
| 19    | CCCE       | Command CRC check enable.<br>This bit must be set to 1 to enable CRC7 check on command response to protect the response against transmission errors on the bus. If an error is detected, it is reported as a command CRC error (MMCi.MMCHS_STAT[17] CCRC bit set to 1). Note: The CCCE bit cannot be configured for an Auto CMD12, and then CRC check is automatically checked when this command is issued.<br><br>0x0: CRC7 check disable<br>0x1: CRC7 check enable                                                        | RW   | 0     |
| 18    | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R    | 0     |
| 17:16 | RSP_TYPE   | Response type.<br>This bits defines the response type of the command.<br><br>0x0: No response<br>0x1: Response Length 136 bits<br>0x2: Response Length 48 bits<br>0x3: Response Length 48 bits with busy after response                                                                                                                                                                                                                                                                                                     | RW   | 0x0   |
| 15:6  | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R    | 0x000 |
| 5     | MSBS       | Multi/Single block select.<br>This bit must be set to 1 for data transfer in case of multi block command. For any others command this bit shall be set to 0.<br><br>0x0: Single block. If this bit is 0, it is not necessary to set the register MMCi.MMCHS_BLK[31:16] NBLK bits.<br>0x1: Multi block. When Block Count is disabled (MMCi.MMCHS_CMD[1] BCE bit is set to 0) in Multiple block transfers (MMCi.MMCHS_CMD[5] MSBS bit is set to 1), the module can perform infinite transfer.                                 | RW   | 0     |
| 4     | DDIR       | Data transfer Direction.<br>Select This bit defines either data transfer will be a read or a write.<br><br>0x0: Data Write (host to card)<br>0x1: Data Read (card to host)                                                                                                                                                                                                                                                                                                                                                  | RW   | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 3           | Reserved          | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R           | 0            |
| 2           | ACEN              | Auto CMD12 Enable. (SDIO does not support this feature.)<br>When this bit is set to 1, the host controller issues a CMD12 automatically after the transfer completion of the last block. The Host Driver shall not set this bit to issue commands that do not require CMD12 to stop data transfer.<br>For CE-ATA commands (MMCI. <a href="#">MMCHS_CON</a> [12] CEATA bit set to 1), auto CMD12 is useless; therefore when this bit is set the mechanism to detect command completion signal, named CCS, interrupt is activated.<br><br>0x0: Auto CMD12 disable<br>0x1: Auto CMD12 enable or CCS detection enabled. | RW          | 0            |
| 1           | BCE               | Block Count Enable (Multiple block transfers only).<br>This bit is used to enable the block count register ( <a href="#">MMCHS_BLK</a> [31:16] NBLK bits). When Block Count is disabled ( <a href="#">MMCHS_CMD</a> [1] BCE bit is set to 0) in Multiple block transfers ( <a href="#">MMCHS_CMD</a> [5] MSBS bits is set to 1), the module can perform infinite transfer.<br><br>0x0: Block count disabled for infinite transfer.<br>0x1: Block count enabled for multiple block transfer with known number of blocks                                                                                              | RW          | 0            |
| 0           | DE                | DMA Enable.<br>This bit is used to enable DMA mode for host data access.<br><br>0x0: DMA mode disable<br>0x1: DMA mode enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW          | 0            |

**Table 24-52. Register Call Summary for Register MMCHS\_CMD**


---

 MMC/SD/SDIO Environment

- [MMC/SD/SDIO Protocol and Data Format](#): [0] [1] [2] [3]
- 

MMC/SD/SDIO Integration

- [DMA Requests](#): [4]
- 

MMC/SD/SDIO Functional Description

- [Data Buffer](#): [5]
  - [Transfer Stop](#): [6]
  - [MMC CE-ATA Command Completion Disable Management](#): [7] [8]
- 

MMC/SD/SDIO Use Cases and Tips

- [Programming Flow](#): [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23] [24] [25]
- 

MMC/SD/SDIO Register Manual

- [MMC/SD/SDIO Register Summary](#): [26]
  - [MMCHS Registers](#): [27] [28] [29] [30] [31] [32] [33] [34] [35] [36] [37] [38] [39] [40] [41] [42] [43] [44] [45] [46]
- 

**Table 24-53. MMCHS\_RSP10**

|                         |                                                                                                                                        |                       |                 |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x110                                                                                                                                  |                       |                 |
| <b>Physical Address</b> | 0x4809 C110                                                                                                                            | <b>Instance</b>       | MMCHS1          |
|                         | 0x480A D110                                                                                                                            |                       | MMCHS3          |
|                         | 0x480B 4110                                                                                                                            |                       | MMCHS2          |
| <b>Description</b>      | Command response[31:0] Register<br>This 32-bit register holds bits positions [31:0] of command response type R1/R1b/R2/R3/R4/R5/R5b/R6 |                       |                 |
| <b>Type</b>             | R                                                                                                                                      |                       |                 |
| 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 |
| RSP1                    |                                                                                                                                        |                       |                 |
| RSP0                    |                                                                                                                                        |                       |                 |

| Bits  | Field Name | Description                                                                                          | Type | Reset  |
|-------|------------|------------------------------------------------------------------------------------------------------|------|--------|
| 31:16 | RSP1       | R1/R1b (normal response) /R3/R4/R5/R5b/R6 : Command Response [39:24]<br>R2: Command Response [31:16] | R    | 0x0000 |
| 15:0  | RSP0       | R1/R1b (normal response) /R3/R4/R5/R5b/R6 : Command Response [23:8]<br>R2: Command Response [15:0]   | R    | 0x0000 |

**Table 24-54. Register Call Summary for Register MMCHS\_RSP10**

MMC/SD/SDIO Functional Description

- [Different Types of Responses: \[0\]](#) [\[1\]](#) [\[2\]](#)

MMC/SD/SDIO Use Cases and Tips

- [Programming Flow: \[3\]](#) [\[4\]](#) [\[5\]](#) [\[6\]](#) [\[7\]](#) [\[8\]](#) [\[9\]](#) [\[10\]](#)

MMC/SD/SDIO Register Manual

- [MMC/SD/SDIO Register Summary: \[11\]](#)
- [MMCHS Registers: \[12\]](#) [\[13\]](#)

**Table 24-55. MMCHS\_RSP32**

|                         |                                                                                                                   |                       |                 |
|-------------------------|-------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x114                                                                                                             |                       |                 |
| <b>Physical Address</b> | 0x4809 C114                                                                                                       | <b>Instance</b>       | MMCHS1          |
|                         | 0x480A D114                                                                                                       |                       | MMCHS3          |
|                         | 0x480B 4114                                                                                                       |                       | MMCHS2          |
| <b>Description</b>      | Command response[63:32] Register<br>This 32-bit register holds bits positions [63:32] of command response type R2 |                       |                 |
| <b>Type</b>             | R                                                                                                                 |                       |                 |
| 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 |
| RSP3                    |                                                                                                                   |                       | RSP2            |

| Bits  | Field Name | Description                  | Type | Reset  |
|-------|------------|------------------------------|------|--------|
| 31:16 | RSP3       | R2: Command Response [63:48] | R    | 0x0000 |
| 15:0  | RSP2       | R2: Command Response [47:32] | R    | 0x0000 |

**Table 24-56. Register Call Summary for Register MMCHS\_RSP32**

MMC/SD/SDIO Functional Description

- [Different Types of Responses: \[0\]](#)

MMC/SD/SDIO Use Cases and Tips

- [Programming Flow: \[1\]](#) [\[2\]](#) [\[3\]](#)

MMC/SD/SDIO Register Manual

- [MMC/SD/SDIO Register Summary: \[4\]](#)

**Table 24-57. MMCHS\_RSP54**

|                         |                                                                                                                   |                       |                 |
|-------------------------|-------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x118                                                                                                             | <b>Instance</b>       | MMCHS1          |
| <b>Physical Address</b> | 0x4809 C118                                                                                                       |                       |                 |
|                         | 0x480A D118                                                                                                       |                       |                 |
|                         | 0x480B 4118                                                                                                       |                       |                 |
| <b>Description</b>      | Command response[95:64] Register<br>This 32-bit register holds bits positions [95:64] of command response type R2 |                       |                 |
| <b>Type</b>             | R                                                                                                                 |                       |                 |
| 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 |
|                         | RSP5                                                                                                              |                       | RSP4            |

| Bits  | Field Name | Description                  | Type | Reset  |
|-------|------------|------------------------------|------|--------|
| 31:16 | RSP5       | R2: Command Response [95:80] | R    | 0x0000 |
| 15:0  | RSP4       | R2: Command Response [79:64] | R    | 0x0000 |

**Table 24-58. Register Call Summary for Register MMCHS\_RSP54**

MMC/SD/SDIO Functional Description

- [Different Types of Responses: \[0\]](#)

MMC/SD/SDIO Use Cases and Tips

- [Programming Flow: \[1\] \[2\] \[3\]](#)

MMC/SD/SDIO Register Manual

- [MMC/SD/SDIO Register Summary: \[4\]](#)

**Table 24-59. MMCHS\_RSP76**

|                         |                                                                                                                     |                       |                 |
|-------------------------|---------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x11C                                                                                                               | <b>Instance</b>       | MMCHS1          |
| <b>Physical Address</b> | 0x4809 C11C                                                                                                         |                       |                 |
|                         | 0x480A D11C                                                                                                         |                       |                 |
|                         | 0x480B 411C                                                                                                         |                       |                 |
| <b>Description</b>      | Command response[127:96] Register<br>This 32-bit register holds bits positions [127:96] of command response type R2 |                       |                 |
| <b>Type</b>             | R                                                                                                                   |                       |                 |
| 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 |
|                         | RSP7                                                                                                                |                       | RSP6            |

| Bits  | Field Name | Description                                                                           | Type | Reset  |
|-------|------------|---------------------------------------------------------------------------------------|------|--------|
| 31:16 | RSP7       | R1b (Auto CMD12 response): Command Response [39:24]<br>R2: Command Response [127:112] | R    | 0x0000 |
| 15:0  | RSP6       | R1b (Auto CMD12 response): Command Response [23:8]<br>R2: Command Response [111:96]   | R    | 0x0000 |

**Table 24-60. Register Call Summary for Register MMCHS\_RSP76**

MMC/SD/SDIO Functional Description

- [Different Types of Responses: \[0\] \[1\] \[2\]](#)

MMC/SD/SDIO Use Cases and Tips

- [Programming Flow: \[3\] \[4\] \[5\]](#)

MMC/SD/SDIO Register Manual

- [MMC/SD/SDIO Register Summary: \[6\]](#)
- [MMCHS Registers: \[7\] \[8\]](#)

**Table 24-61. MMCHS\_DATA**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 |        |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x120                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                 |        |
| <b>Physical Address</b> | 0x4809 C120                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | <b>Instance</b> | MMCHS1 |
|                         | 0x480A D120                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 | MMCHS3 |
|                         | 0x480B 4120                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 | MMCHS2 |
| <b>Description</b>      | Data Register<br>This register is the 32-bit entry point of the buffer for read or write data transfers.<br>The buffer size is 32bits x256(1024 bytes). Bytes within a word are stored and read in little endian format.<br>This buffer can be used as two 512 byte buffers to transfer data efficiently without reducing the throughput.<br>Sequential and contiguous access is necessary to increment the pointer correctly. Random or skipped access is not allowed. In little endian, if the local host accesses this register byte-wise or 16bit-wise, the least significant byte (bits [7:0]) must always be written/read first. The update of the buffer address is done on the most significant byte write for full 32-bit DATA register or on the most significant byte of the last word of block transfer.<br>Example 1: Byte or 16-bit access<br>Mbyteen[3:0]=0001 (1-byte) => Mbyteen[3:0]=0010 (1-byte) => Mbyteen[3:0]=1100 (2-bytes) OK<br>Mbyteen[3:0]=0001 (1-byte) => Mbyteen[3:0]=0010 (1-byte) => Mbyteen[3:0]=0100 (1-byte) OK<br>Mbyteen[3:0]=0001 (1-byte) => Mbyteen[3:0]=0010 (1-byte) => Mbyteen[3:0]=1000 (1-byte) Bad |                 |        |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |        |

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset      |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | DATA       | Data Register [31:0]<br>In functional mode (MMCi.MMCHS_CON[4] MODE bit set to the default value 0):<br>A read access to this register is allowed only when the buffer read enable status is set to 1 (MMCi.MMCHS_PSTATE[11] BRE bit), otherwise a bad access (MMCi.MMCHS_STAT[29] BADA bit) is signaled.<br>A write access to this register is allowed only when the buffer write enable status is set to 1 (MMCi.MMCHS_PSTATE[10] BWE bit), otherwise a bad access (MMCi.MMCHS_STAT[29] BADA bit) is signaled and the data is not written. | RW   | 0x00000000 |

**Table 24-62. Register Call Summary for Register MMCHS\_DATA**

## MMC/SD/SDIO Functional Description

- Data Buffer: [0] [1] [2] [3] [4] [5] [6] [7]
- Transfer or Command Status and Error Reporting: [8]

## MMC/SD/SDIO Register Manual

- MMC/SD/SDIO Register Summary: [9]
- MMCHS Registers: [10] [11] [12] [13]

**Table 24-63. MMCHS\_PSTATE**

|                         |                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |        |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|--------|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x124                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |        |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4809 C124                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | MMCHS1 |  |  |  |  |  |  |  |  |
|                         | 0x480A D124                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |                 | MMCHS3 |  |  |  |  |  |  |  |  |
|                         | 0x480B 4124                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |                 | MMCHS2 |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Present state register.<br>The Host can get status of the Host Controller from this 32-bit read only register. |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |        |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |        |  |  |  |  |  |  |  |  |

| 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 |  |
|----------|------|------|----------|----------|----------|----------|----------|-----|-----|-----|-----|----------|----------|----------|----------|-----|------|------|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| Reserved | CLEV | DLEV | Reserved | Reserved | Reserved | Reserved | Reserved | BRE | BWE | RTA | WTA | Reserved | Reserved | Reserved | Reserved | DLA | DATI | CMDI |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:25 | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R    | 0x00  |
| 24    | CLEV       | mmci_cmd line signal level.<br>This status is used to check the mmci_cmd line level to recover from errors, and for debugging.<br>The value of this register after reset depends on the mmci_cmd line level at that time.<br><br>Read 0x0: The mmci_cmd line level is 0.<br>Read 0x1: The mmci_cmd line level is 1.                                                                                                                                                                                                                         | R    | -     |
| 23:20 | DLEV       | mmci_dat[3:0] line signal level<br>mmci_dat[3] => bit 23<br>mmci_dat[2] => bit 22<br>mmci_dat[1] => bit 21<br>mmci_dat[0] => bit 20<br><br>This status is used to check mmci_dat line level to recover from errors, and for debugging. This is especially useful in detecting the busy signal level from mmci_dat[0].<br>The value of these registers after reset depends on the mmci_dat lines level at that time.                                                                                                                         | R    | 0x-   |
| 19    | Reserved   | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R    | 0     |
| 18    | Reserved   | Reserved bit field. Do not write any value<br>This bit is not affected by soft reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R    | 1     |
| 17:16 | Reserved   | Reserved bit field. Do not write any value<br>The value of these bits after soft reset is 0x0. These bits will be automatically set to 0x3 after debounce time.<br>Debounce time is fixed to 256 x32 kHz clock cycles.                                                                                                                                                                                                                                                                                                                      | R    | 00    |
| 15:12 | Reserved   | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R    | 0x0   |
| 11    | BRE        | Buffer read enable.<br>This bit is used for non-DMA read transfers. It indicates that a complete block specified by MMCI.MMCHS_BLK[10:0] BLEN bits has been written in the buffer and is ready to be read.<br>It is set to 0 when the entire block is read from the buffer. It is set to 1 when a block data is ready in the buffer and generates the Buffer read ready status of interrupt (MMCI.MMCHS_STAT[5] BRR bit).<br><br>Read 0x0: Read BLEN bytes disable<br>Read 0x1: Read BLEN bytes enable. Readable data exists in the buffer. | R    | 0     |
| 10    | BWE        | Buffer Write enable.<br>This status is used for non-DMA write transfers. It indicates if space is available for write data.<br><br>Read 0x0: There is no room left in the buffer to write BLEN bytes of data.<br>Read 0x1: There is enough space in the buffer to write BLEN bytes of data.                                                                                                                                                                                                                                                 | R    | 0     |

## MMC/SD/SDIO Register Manual

www.ti.com

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 9    | RTA        | <p>Read transfer active.</p> <p>This status is used for detecting completion of a read transfer. It is set to 1 after the end bit of read command or by activating a continue request (MMCi.MMCHS_HCTL[17] CR bit) following a stop at block gap request. This bit is set to 0 when all data have been read by the local host after last block or after a stop at block gap request.</p> <p>Read 0x0: No valid data on the mmci_dat lines.</p> <p>Read 0x1: Read data transfer on going.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R    | 0     |
| 8    | WTA        | <p>Write transfer active.</p> <p>This status indicates a write transfer active. It is set to 1 after the end bit of write command or by activating a continue request (MMCi.MMCHS_HCTL[17] CR bit) following a stop at block gap request. This bit is set to 0 when CRC status has been received after last block or after a stop at block gap request.</p> <p>Read 0x0: No valid data on the mmci_dat lines.</p> <p>Read 0x1: Write data transfer on going.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R    | 0     |
| 7:3  | Reserved   | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R    | 0x00  |
| 2    | DLA        | <p>mmci_dat line active.</p> <p>This status bit indicates whether one of the mmci_dat line is in use. In the case of read transactions (card to host):</p> <p>This bit is set to 1 after the end bit of read command or by activating continue request MMCi.MMCHS_HCTL[17] CR bit. This bit is set to 0 when the host controller received the end bit of the last data block or at the beginning of the read wait mode. In the case of write transactions (host to card):</p> <p>This bit is set to 1 after the end bit of write command or by activating continue request MMCi.MMCHS_HCTL[17] CR bit.</p> <p>This bit is set to 0 on the end of busy event for the last block; host controller must wait 8 clock cycles with line not busy to really consider not "busy state" or after the busy block as a result of a stop at gap request.</p> <p>Read 0x0: mmci_dat Line inactive</p> <p>Read 0x1: mmci_dat Line active</p>                                                                   | R    | 0     |
| 1    | DATI       | <p>Command inhibit (mmci_dat).</p> <p>This status bit is generated if either mmci_dat line is active (MMCi.MMCHS_PSTATE[2] DLA bit) or Read transfer is active (MMCi.MMCHS_PSTATE[9] RTA bit) or when a command with busy is issued. This bit prevents the local host to issue a command.</p> <p>A change of this bit from 1 to 0 generates a transfer complete interrupt (MMCi.MMCHS_STAT[1] TC bit).</p> <p>Read 0x0: Issuing of command using the mmci_dat lines is allowed</p> <p>Read 0x1: Issuing of command using mmci_dat lines is not allowed</p>                                                                                                                                                                                                                                                                                                                                                                                                                                        | R    | 0     |
| 0    | CMDI       | <p>Command inhibit(mmci_cmd).</p> <p>This status bit indicates that the mmci_cmd line is in use.</p> <p>This bit is set to 0 when the most significant byte is written into the command register. This bit is not set when Auto CMD12 is transmitted.</p> <p>This bit is set to 0 in either the following cases:</p> <ul style="list-style-type: none"> <li>- After the end bit of the command response, excepted if there is a command conflict error (MMCi.MMCHS_STAT[17] CCRC bit or MMCi.MMCHS_STAT[18] CEB bit set to 1) or a Auto CMD12 is not executed (MMCi.MMCHS_AC12[0] ACNE bit).</li> <li>- After the end bit of the command without response (MMCi.MMCHS_CMD[17:16] RSP_TYPE bits set to "00"). In case of a command data error is detected (MMCi.MMCHS_STAT[19] CTO bit set to 1), this register is not automatically cleared.</li> </ul> <p>Read 0x0: Issuing of command using mmci_cmd line is allowed</p> <p>Read 0x1: Issuing of command using mmci_cmd line is not allowed</p> | R    | 0     |

**Table 24-64. Register Call Summary for Register MMCHS\_PSTATE**

- MMC/SD/SDIO Integration
  - Resets: [0]
- MMC/SD/SDIO Functional Description
  - Data Buffer: [1] [2] [3] [4]
- MMC/SD/SDIO Register Manual
  - MMC/SD/SDIO Register Summary: [5]
  - MMCHS Registers: [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19]

**Table 24-65. MMCHS\_HCTL**

|                         |                                                                                                                                                                                                                                                                                    |                 |        |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x128                                                                                                                                                                                                                                                                              |                 |        |
| <b>Physical Address</b> | 0x4809 C128                                                                                                                                                                                                                                                                        | <b>Instance</b> | MMCHS1 |
|                         | 0x480A D128                                                                                                                                                                                                                                                                        |                 | MMCHS3 |
|                         | 0x480B 4128                                                                                                                                                                                                                                                                        |                 | MMCHS2 |
| <b>Description</b>      | Control register. This register defines the host controls to set power, wake up and transfer parameters.<br>MMCI.MMCHS_HCTL[31:24] = Wake-up control<br>MMCI.MMCHS_HCTL[23:16] = Block gap control<br>MMCI.MMCHS_HCTL[15:8] = Power control<br>MMCI.MMCHS_HCTL[7:0] = Host control |                 |        |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                 |                 |        |

|          |      |     |     |     |          |     |     |    |      |          |      |      |          |     |          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|------|-----|-----|-----|----------|-----|-----|----|------|----------|------|------|----------|-----|----------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| Reserved | OBWE | REM | INS | IWE | Reserved | IBG | RWC | CR | SBGR | Reserved | SDVS | SDBP | Reserved | DTW | Reserved |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:28 | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                 | R    | 0x00  |
| 27    | OBWE       | <p>Wake-up event enable for 'Out-of-Band' Interrupt.<br/>           This bit enables wake-up events for 'Out-of-Band' assertion. Wakeup is generated if the wake-up feature is enabled (MMCi.MMCHS_SYSCONFIG[2] ENAWAKEUP bit). The write to this register is ignored when MMCi.MMCHS_CON[14] OBIE bit is not set.</p> <p>0x0: Disable wakeup on 'Out-of-Band' Interrupt.<br/>           0x1: Enable wakeup on 'Out-of-Band' Interrupt.</p> | RW   | 0     |
| 26    | REM        | <p>Wake-up event enable on SD card removal.<br/>           This bit enables wake-up events for card removal assertion. Wakeup is generated if the wake-up feature is enabled (MMCi.MMCHS_SYSCONFIG[2] ENAWAKEUP bit).</p> <p>0x0: Disable wakeup on card removal.<br/>           0x1: Enable wakeup on card removal.</p>                                                                                                                    | RW   | 0     |
| 25    | INS        | <p>Wake-up event enable on SD card insertion<br/>           This bit enables wake-up events for card insertion assertion. Wakeup is generated if the wake-up feature is enabled (MMCi.MMCHS_SYSCONFIG[2] ENAWAKEUP bit).</p> <p>0x0: Disable wakeup on card insertion.<br/>           0x1: Enable wakeup on card insertion.</p>                                                                                                             | RW   | 0     |
| 24    | IWE        | <p>Wake-up event enable on SD card interrupt.<br/>           This bit enables wake-up events for card interrupt assertion. Wakeup is generated if the wake-up feature is enabled (MMCi.MMCHS_SYSCONFIG[2] ENAWAKEUP bit) and enable status bit is set (MMCi.MMCHS_IE[8] CIRQ_ENABLE bit).</p> <p>0x0: Disable wakeup on card interrupt<br/>           0x1: Enable wakeup on card interrupt</p>                                              | RW   | 0     |
| 23:20 | Reserved   | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                  | R    | 0x0   |

## MMC/SD/SDIO Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 19    | IBG        | <p>Interrupt block at gap.</p> <p>This bit is valid only in 4-bit mode of SDIO card to enable interrupt detection in the interrupt cycle at block gap for a multiple block transfer. For MMC cards and for SD card this bit should be set to 0.</p> <p>0x0: Disable interrupt detection at the block gap in 4-bit mode</p> <p>0x1: Enable interrupt detection at the block gap in 4-bit mode</p>                                                                                                                                                                                                                                                                         | RW   | 0     |
| 18    | RWC        | <p>Read wait control.</p> <p>The read wait function is optional only for SDIO cards. If the card supports read wait, this bit must be enabled, then requesting a stop at block gap (MMCi.MMCHS_HCTL[16] SBGR bit) generates a read wait period after the current end of block. Be careful, if read wait is not supported it may cause a conflict on mmci_dat line.</p> <p>0x0: Disable Read Wait Control. Suspend/Resume cannot be supported.</p> <p>0x1: Enable Read Wait Control</p>                                                                                                                                                                                   | RW   | 0     |
| 17    | CR         | <p>Continue request.</p> <p>This bit is used to restart a transaction that was stopped by requesting a stop at block gap (MMCi.MMCHS_HCTL[16] SBGR bit). Set this bit to 1 restarts the transfer. The bit is automatically set to 0 by the host controller when transfer has restarted i.e. mmci_dat line is active (MMCi.MMCHS_PSTATE[2] DLA bit) or transferring data (MMCi.MMCHS_PSTATE[8] WTA bit).</p> <p>The Stop at block gap request must be disabled (MMCi.MMCHS_HCTL[16] SBGR bit =0) before setting this bit.</p> <p>0x0: No affect</p> <p>0x1: transfer restart</p>                                                                                          | RW   | 0     |
| 16    | SBGR       | <p>Stop at block gap request.</p> <p>This bit is used to stop executing a transaction at the next block gap. The transfer can restart with a continue request (MMCi.MMCHS_HCTL[17] CR bit) or during a suspend/resume sequence. In case of read transfer, the card must support read wait control. In case of write transfer, the host driver shall set this bit after all block data written. Until the transfer completion (MMCi.MMCHS_STAT[1] TC bit set to 1), the host driver shall leave this bit set to 1. If this bit is set, the local host shall not write to the data register (MMCi.MMCHS_DATA).</p> <p>0x0: Transfer mode</p> <p>0x1: Stop at block gap</p> | RW   | 0     |
| 15:12 | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R    | 0x0   |
| 11:9  | SDVS       | <p>SD bus voltage select (All cards).</p> <p>The host driver should set these bits to select the voltage level for the card according to the voltage supported by the system (MMCi.MMCHS_CAPA[26] VS18 bit, MMCi.MMCHS_CAPA[25] VS30 bit, MMCi.MMCHS_CAPA[24] VS33 bit) before starting a transfer.</p> <p>0x5: 1.8V (Typical)</p> <p>0x6: 3.0V (Typical)</p> <p>0x7: 3.3V (Typical)</p> <p>MMCHS2: This field must be set to 0x5.</p> <p>MMCHS3: This field must be set to 0x5.</p>                                                                                                                                                                                     | RW   | 0x0   |
| 8     | SDBP       | <p>SD bus power.</p> <p>Before setting this bit, the host driver shall select the SD bus voltage (MMCi.MMCHS_HCTL[11:9] SDVS bits). If the host controller detects the No card state, this bit is automatically set to 0. If the module is power off, a write in the command register (MMCi.MMCHS_CMD) will not start the transfer. A write to this bit has no effect if the selected SD bus voltage is not supported according to capability register (MMCi.MMCHS_CAPA[VS*]).</p> <p>0x0: Power off</p> <p>0x1: Power on</p>                                                                                                                                            | RW   | 0     |
| 7:2   | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R    | 0x00  |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 1    | DTW        | <p>Data transfer width.</p> <p>For MMC card, this bit must be set following a valid SWITCH command (CMD6) with the correct value and extend CSD index written in the argument. Prior to this command, the MMC card configuration register (CSD and EXT_CSD) must be verified for compliance with <i>MMC standard specification 4.x</i>.</p> <p>This register has no effect when the MMC 8-bit mode is selected (MMCI.MMCHS_CON[5] DW8 bit set to 1)</p> <p>For SD/SDIO cards, this bit must be set following a valid SET_BUS_WIDTH command (ACMD6) with the value written in bit 1 of the argument. Prior to this command, the SD card configuration register (SCR) must be verified for the supported bus width by the SD card.</p> <p>0x0: 1-bit Data width (mmci_dat[0] used)</p> <p>0x1: 4-bit Data width (mmci_dat[3:0] used)</p> | RW   | 0     |
| 0    | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R    | 0     |

**Table 24-66. Register Call Summary for Register MMCHS\_HCTL**

|                                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------|
| MMC/SD/SDIO Integration                                                                                            |
| • <a href="#">Clocks: [0] [1]</a>                                                                                  |
| MMC/SD/SDIO Functional Description                                                                                 |
| • <a href="#">Transfer Stop: [2] [3]</a>                                                                           |
| MMC/SD/SDIO Use Cases and Tips                                                                                     |
| • <a href="#">Programming Flow: [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18]</a>           |
| MMC/SD/SDIO Register Manual                                                                                        |
| • <a href="#">MMC/SD/SDIO Register Summary: [19]</a>                                                               |
| • <a href="#">MMCHS Registers: [20] [21] [22] [23] [24] [25] [26] [27] [28] [29] [30] [31] [32] [33] [34] [35]</a> |

**Table 24-67. MMCHS\_SYSCTL**

|                         |                                                                                                                                                                                                                                                                        |                       |                 |                           |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|---------------------------|
| Address Offset          | 0x12C                                                                                                                                                                                                                                                                  |                       |                 |                           |
| Physical Address        | 0x4809 C12C                                                                                                                                                                                                                                                            | Instance              | MMCHS1          |                           |
|                         | 0x480A D12C                                                                                                                                                                                                                                                            |                       | MMCHS3          |                           |
|                         | 0x480B 412C                                                                                                                                                                                                                                                            |                       | MMCHS2          |                           |
| Description             | SD system control register. This register defines the system controls to set software resets, clock frequency management and data timeout.<br><br>MMCHS_SYSCTL[31:24] = Software resets<br>MMCHS_SYSCTL[23:16] = Timeout control<br>MMCHS_SYSCTL[15:0] = Clock control |                       |                 |                           |
| Type                    | RW                                                                                                                                                                                                                                                                     |                       |                 |                           |
| 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 |                           |
| Reserved                | SRD SRC SRA                                                                                                                                                                                                                                                            | Reserved              | DTO             | CLKD Reserved CEN ICS ICE |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R    | 0x00  |
| 26    | SRD        | <p>Software reset for mmci_dat line. This bit is set to 1 for reset and released to 0 when completed .mmci_dat finite state machine in both clock domain are also reset.</p> <p>Here below are the registers cleared by the <a href="#">MMCHS_SYSCTL[26]</a> SRD bit:</p> <p>MMCI.MMCHS_DATA</p> <p>MMCI.MMCHS_PSTATE: BRE, BWE, RTA, WTA, DLA and DATI</p> <p>MMCI.MMCHS_HCTL: SBGR and CR</p> <p>MMCI.MMCHS_STAT: BRR, BWR, BGE and TC Interconnect and MMC buffer data management is reinitialized.</p> <p>0x0: Reset completed</p> <p>0x1: Software reset for mmci_dat line</p> | RW   | 0     |

## MMC/SD/SDIO Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 25    | SRC        | <p>Software reset for mmci_cmd line. This bit is set to 1 for reset and released to 0 when completed. mmci_cmd finite state machine in both clock domain are also reset.</p> <p>Here below the registers cleared by the MMCi.<a href="#">MMCHS_SYSCTL</a>[25] SRC bit:</p> <ul style="list-style-type: none"> <li>MMCi.<a href="#">MMCHS_PSTATE</a>: CMDI</li> <li>MMCi.<a href="#">MMCHS_STAT</a>: CC Interconnect and MMC command status management is reinitialized.</li> </ul> <p>0x0: Reset completed</p> <p>0x1: Software reset for mmci_cmd line</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0     |
| 24    | SRA        | <p>Software reset for all. This bit is set to 1 for reset , and released to 0 when completed. This reset affects the entire host controller except for the card detection circuit and capabilities registers.</p> <p>0x0: Reset completed</p> <p>0x1: Software reset for all the design</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0     |
| 23:20 | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0x0   |
| 19:16 | DTO        | <p>Data timeout counter value and busy timeout. This value determines the interval by which mmci_dat lines timeouts are detected.</p> <p>The host driver needs to set this bit field based on</p> <ul style="list-style-type: none"> <li>- the maximum read access time (NAC) (See the SD Specification Part1 Physical Layer),</li> <li>- the data read access time values (TAAC and NSAC) in the card specific data register (CSD) of the card,</li> <li>- the timeout clock base frequency (MMCi.<a href="#">MMCHS_CAPA</a>[5:0] TCF bits).</li> </ul> <p>If the card does not respond within the specified number of cycles, a data timeout error occurs (MMCi.<a href="#">MMCHS_STAT</a>[20] DTO bit). The MMCi.<a href="#">MMCHS_SYSCTL</a>[19,16] DTO bit field is also used to check busy duration, to generate busy timeout for commands with busy response or for busy programming during a write command. Timeout on CRC status is generated if no CRC token is present after a block write.</p> <p>0x0: TCF x 2^13</p> <p>0x1: TCF x 2^14</p> <p>0xE: TCF x 2^27</p> <p>0xF: Reserved</p> | RW   | 0x0   |
| 15:6  | CLKD       | <p>Clock frequency select These bits define the ratio between a reference clock frequency (system dependant) and the output clock frequency on the mmci_clk pin of either the memory card (MMC, SD or SDIO).</p> <p>0x0: Clock Ref bypass</p> <p>0x1: Clock Ref bypass</p> <p>0x2: Clock Ref / 2</p> <p>0x3: Clock Ref / 3</p> <p>0x3FF: Clock Ref / 1023</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0x000 |
| 5:3   | Reserved   | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x0   |
| 2     | CEN        | <p>Clock enable. This bit controls if the clock is provided to the card or not.</p> <p>0x0: The clock is not provided to the card . Clock frequency can be changed .</p> <p>0x1: The clock is provided to the card and can be automatically gated when MMCi.<a href="#">MMCHS_SYSCONFIG</a>[0] AUTOIDLE bit is set to 1 (default value) .</p> <p>The host driver shall wait to set this bit to 1 until the Internal clock is stable (MMCi.<a href="#">MMCHS_SYSCTL</a>[1] ICS bit).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW   | 0     |
| 1     | ICS        | <p>Internal clock stable (status)This bit indicates either the internal clock is stable or not.</p> <p>Read    The internal clock is not stable.</p> <p>0x0:</p> <p>Read    The internal clock is stable after enabling the clock (MMCi.<a href="#">MMCHS_SYSCTL</a>[0] ICE bit) or after changing the clock ratio (MMCi.<a href="#">MMCHS_SYSCTL</a>[15:6] CLKD bits).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0     |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Type | Reset |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 0    | ICE        | <p>Internal clock enable. This register controls the internal clock activity. In very low power state, the internal clock is stopped. Note: The activity of the debounce clock (used for wake-up events) and the interface clock (used for reads and writes to the module register map) are not affected by this register.</p> <p>0x0: The internal clock is stopped (very low power state).</p> <p>0x1: The internal clock oscillates and can be automatically gated when MMCI.MMCHS_SYSCTRL[0] AUTOIDLE bit is set to 1 (default value).</p> | RW   | 0     |

**Table 24-68. Register Call Summary for Register MMCHS\_SYSCTRL**

MMC/SD/SDIO Environment

- MMC/SD/SDIO Protocol and Data Format: [0]

MMC/SD/SDIO Integration

- Resets: [1] [2] [3] [4] [5]

MMC/SD/SDIO Use Cases and Tips

- Programming Flow: [6] [7] [8] [9] [10] [11] [12] [13] [14]

MMC/SD/SDIO Register Manual

- MMC/SD/SDIO Register Summary: [15]
- MMCHS Registers: [16] [17] [18] [19] [20] [21] [22] [23] [24] [25] [26] [27] [28] [29]

**Table 24-69. MMCHS\_STAT**

| Address Offset   | 0x130                                                                                                                                                                                                                                             |      |          |     |          |     |      |     |          |        |      |     |     |    |    |    | Instance | MMCHS1 |      |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|-----|----------|-----|------|-----|----------|--------|------|-----|-----|----|----|----|----------|--------|------|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| Physical Address | 0x4809 C130                                                                                                                                                                                                                                       |      |          |     |          |     |      |     | Instance | MMCHS1 |      |     |     |    |    |    |          |        |      |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|                  | 0x480A D130                                                                                                                                                                                                                                       |      |          |     |          |     |      |     | Instance | MMCHS3 |      |     |     |    |    |    |          |        |      |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|                  | 0x480B 4130                                                                                                                                                                                                                                       |      |          |     |          |     |      |     | Instance | MMCHS2 |      |     |     |    |    |    |          |        |      |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| Description      | Interrupt status register<br>The interrupt status regroups all the status of the module internal events that can generate an interrupt.<br><b>MMCHS_STAT[31:16]</b> = Error Interrupt Status<br><b>MMCHS_STAT[15:0]</b> = Normal Interrupt Status |      |          |     |          |     |      |     |          |        |      |     |     |    |    |    |          |        |      |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| Type             | RW                                                                                                                                                                                                                                                |      |          |     |          |     |      |     |          |        |      |     |     |    |    |    |          |        |      |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| 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 |  |  |  |  |
| Reserved         | BADA                                                                                                                                                                                                                                              | CERR | Reserved | ACE | Reserved | DEB | DCRC | DTO | CIE      | CEB    | CCRC | CTO | ERR |    |    |    |          | OBI    | CIRQ |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | Reserved   | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R    | 0x0   |
| 29    | BADA       | Bad access to data space.<br>This bit is set automatically to indicate a bad access to buffer when not allowed:<br>- During a read access to the data register (MMCI.MMCHS_DATA) while buffer reads are not allowed (MMCI.MMCHS_PSTATE[11] BRE bit=0)<br>- During a write access to the data register (MMCI.MMCHS_DATA) while buffer writes are not allowed (MMCI.MMCHS_PSTATE[10] BWE bit=0)<br>Read 0x0: No Interrupt.<br>Write 0x0: Status bit unchanged<br>Read 0x1: Bad Access<br>Write 0x1: Status is cleared | RW   | 0     |

## MMC/SD/SDIO Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Type | Reset |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 28    | CERR       | <p>Card error.</p> <p>This bit is set automatically when there is at least one error in a response of type R1, R1b, R6, R5 or R5b. Only bits referenced as type E (error) in status field in the response can set a card status error. An error bit in the response is flagged only if corresponding bit in card status response error MMCI.<a href="#">MMCHS_CSRE</a> in set.</p> <p>There is no card error detection for autoCMD12 command. The host driver shall read MMCI.<a href="#">MMCHS_RSP76</a> register to detect error bits in the command response.</p> <p>Read 0x0: No Error</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Card error</p> <p>Write 0x1: Status is cleared</p> | RW   | 0     |
| 27:25 | Reserved   | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R    | 0x0   |
| 24    | ACE        | <p>Auto CMD12 error.</p> <p>This bit is set automatically when one of the bits in Auto CMD12 Error status register has changed from 0 to 1.</p> <p>Read 0x0: No Error</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: AutoCMD12 error</p> <p>Write 0x1: Status is cleared</p>                                                                                                                                                                                                                                                                                                                                                                                                                 | RW   | 0     |
| 23    | Reserved   | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R    | 0     |
| 22    | DEB        | <p>Data End Bit error.</p> <p>This bit is set automatically when detecting a 0 at the end bit position of read data on mmci_dat line or at the end position of the CRC status in write mode.</p> <p>Read 0x0: No Error</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Data end bit error</p> <p>Write 0x1: Status is cleared</p>                                                                                                                                                                                                                                                                                                                                                             | RW   | 0     |
| 21    | DCRC       | <p>Data CRC Error.</p> <p>This bit is set automatically when there is a CRC16 error in the data phase response following a block read command or if there is a 3-bit CRC status different of a position "010" token during a block write command.</p> <p>Read 0x0: No Error.</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Data CRC error</p> <p>Write 0x1: Status is cleared</p>                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 20    | DTO        | <p>Data timeout error. This bit is set automatically according to the following conditions:</p> <ul style="list-style-type: none"> <li>- Busy timeout for R1b, R5b response type.</li> <li>- Busy timeout after write CRC status.</li> <li>- Write CRC status timeout.</li> <li>- Read data timeout.</li> </ul> <p>Read 0x0: No error</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Time out</p> <p>Write 0x1: Status is cleared</p>                                                                                                                                                                                                                                                        | RW   | 0     |
| 19    | CIE        | <p>Command index error.</p> <p>This bit is set automatically when response index differs from corresponding command index previously emitted. It depends on the enable bit (MMCI.<a href="#">MMCHS_CMD</a>[20] CICE).</p> <p>Read 0x0: No error</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Command index error</p> <p>Write 0x1: Status is cleared</p>                                                                                                                                                                                                                                                                                                                                   | RW   | 0     |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Type | Reset |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 18    | CEB        | <p>Command end bit error.<br/>This bit is set automatically when detecting a 0 at the end bit position of a command response.</p> <p>Read 0x0: No error<br/>Write 0x0: Status bit unchanged<br/>Read 0x1: Command end bit error<br/>Write 0x1: Status is cleared</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0     |
| 17    | CCRC       | <p>Command CRC Error.<br/>This bit is set automatically when there is a CRC7 error in the command response depending on the enable bit (MMCI.<a href="#">MMCHS_CMD[19]</a> CCCE).</p> <p>Read 0x0: No Error<br/>Write 0x0: Status bit unchanged<br/>Read 0x1: Command CRC error<br/>Write 0x1: Status is cleared</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW   | 0     |
| 16    | CTO        | <p>Command Timeout Error.<br/>This bit is set automatically when no response is received within 64 clock cycles from the end bit of the command.<br/>For commands that reply within 5 clock cycles - the timeout is still detected at 64 clock cycles.</p> <p>Read 0x0: No error<br/>Write 0x0: Status bit unchanged<br/>Read 0x1: Time Out<br/>Write 0x1: Status is cleared</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 15    | ERRI       | <p>Error Interrupt.<br/>If any of the bits in the Error Interrupt Status register (MMCI.<a href="#">MMCHS_STAT[31:16]</a>) are set, then this bit is set to 1. Therefore the host driver can efficiently test for an error by checking this bit first.<br/>Writes to this bit are ignored.</p> <p>Read 0x0: No Interrupt<br/>Read 0x1: Error interrupt event(s) occurred</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R    | 0     |
| 14:10 | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0x00  |
| 9     | OBI        | <p>Out-Of-Band interrupt (This interrupt is only useful for MMC card).<br/>This bit is set automatically when MMCI.<a href="#">MMCHS_CON[14]</a> OBIE bit is set and an Out-of-Band interrupt occurs on OBI pin.<br/>The interrupt detection depends on polarity controlled by MMCI.<a href="#">MMCHS_CON[13]</a> OBIP bit.<br/>The Out-of-Band interrupt signal is a system specific feature for future use, this signal is not required for existing specification implementation.</p> <p>Read 0x0: No Out-Of-Band interrupt.<br/>Write 0x0: Status bit unchanged.<br/>Read 0x1: Interrupt Out-Of-Band occurs.<br/>Write 0x1: Status is cleared.</p>                                                                                                                                                                                                                                                                     | R    | 0     |
| 8     | CIRQ       | <p>Card interrupt.<br/>This bit is only used for SD and SDIO cards.<br/>In 1-bit mode, interrupt source is asynchronous (can be a source of asynchronous wakeup).<br/>In 4-bit mode, interrupt source is sampled during the interrupt cycle.<br/>In CE-ATA mode, interrupt source is detected when the card drives mmci_cmd line to zero during one cycle after data transmission end.<br/>All modes above are fully exclusive.<br/>The controller interrupt must be clear by setting MMCI.<a href="#">MMCHS_IE[8]</a> CIRQ_ENABLE to 0, then the host driver must start the interrupt service with card (clearing card interrupt status) to remove card interrupt source.<br/>Otherwise the Controller interrupt will be reasserted as soon as MMCI.<a href="#">MMCHS_IE[8]</a> CIRQ_ENABLE is set to 1.<br/>Writes to this bit are ignored.</p> <p>Read 0x0: No card interrupt<br/>Read 0x1: Generate card interrupt</p> | R    | 0     |
| 7:6   | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW   | 00    |

| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 5    | BRR        | <p>Buffer read ready.</p> <p>This bit is set automatically during a read operation to the card (see class 2 - block oriented read commands) when one block specified by the MMCI.MMCHS_BLK[10:0] BLEN bit field is completely written in the buffer. It indicates that the memory card has filled out the buffer and that the local host needs to empty the buffer by reading it.</p> <p>Note: If the DMA receive-mode is enabled, this bit is never set; instead a DMA receive request to the main DMA controller of the system is generated.</p> <p>Read 0x0: Not Ready to read buffer</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Ready to read buffer</p> <p>Write 0x1: Status is cleared</p>                                          | RW   | 0     |
| 4    | BWR        | <p>Buffer write ready.</p> <p>This bit is set automatically during a write operation to the card (see class 4 - block oriented write command) when the host can write a complete block as specified by MMCI.MMCHS_BLK[10:0] BLEN. It indicates that the memory card has emptied one block from the buffer and that the local host is able to write one block of data into the buffer.</p> <p>Note: If the DMA transmit mode is enabled, this bit is never set; instead, a DMA transmit request to the main DMA controller of the system is generated.</p> <p>Read 0x0: Not Ready to write buffer</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Ready to write buffer</p> <p>Write 0x1: Status is cleared</p>                                 | RW   | 0     |
| 3    | Reserved   | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R    | 0     |
| 2    | BGE        | <p>Block gap event.</p> <p>When a stop at block gap is requested (MMCI.MMCHS_HCTL[16] SBGR bit), this bit is automatically set when transaction is stopped at the block gap during a read or write operation.</p> <p>This event does not occur when the stop at block gap is requested on the last block.</p> <p>In read mode, a 1-to-0 transition of the mmci_dat line active status (MMCI.MMCHS_PSTATE[2] DLA bit) between data blocks generates a Block gap event interrupt.</p> <p>Read 0x0: No block gap event</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Transaction stopped at block gap</p> <p>Write 0x1: Status is cleared</p>                                                                                                   | RW   | 0     |
| 1    | TC         | <p>Transfer completed.</p> <p>This bit is always set when a read/write transfer is completed or between two blocks when the transfer is stopped due to a stop at block gap request (MMCI.MMCHS_HCTL[16] SBGR bit).</p> <p>This bit is also set when exiting a command in a busy state (if the command has a busy notification capability).</p> <p>In Read mode: This bit is automatically set on completion of a read transfer (MMCI.MMCHS_PSTATE[9] RTA bit).</p> <p>In write mode: This bit is set automatically on completion of the mmci_dat line use (MMCI.MMCHS_PSTATE[2] DLA bit).</p> <p>Read 0x0: No transfer complete</p> <p>Write 0x0: Status bit unchanged</p> <p>Read 0x1: Data transfer complete</p> <p>Write 0x1: Status is cleared</p> | RW   | 0     |
| 0    | CC         | <p>Command complete.</p> <p>This bit is set when a 1-to-0 transition occurs in the register command inhibit (MMCI.MMCHS_PSTATE[0] CMDI bit)</p> <p>If the command is a type for which no response is expected, then the command complete interrupt is generated at the end of the command. A command timeout error (MMCI.MMCHS_STAT[16] CTO bit) has higher priority than command complete (MMCI.MMCHS_STAT[0] CC bit).</p> <p>If a response is expected but none is received, then a command timeout error is detected and signaled instead of the command complete interrupt.</p>                                                                                                                                                                    | RW   | 0     |

| Bits | Field Name | Description                     | Type | Reset |
|------|------------|---------------------------------|------|-------|
|      |            | Read 0x0: No Command complete   |      |       |
|      |            | Write 0x0: Status bit unchanged |      |       |
|      |            | Read 0x1: Command complete      |      |       |
|      |            | Write 0x1: Status is cleared    |      |       |

**Table 24-70. Register Call Summary for Register MMCHS\_STAT**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MMC/SD/SDIO Integration                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <ul style="list-style-type: none"> <li>Clocks: [0] [1] [2] [3]</li> <li>Interrupt Requests: [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18]</li> </ul>                                                                                                                                                                                                                                                                                                              |
| MMC/SD/SDIO Functional Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <ul style="list-style-type: none"> <li>Data Buffer: [19] [20] [21] [22] [23] [24]</li> <li>Transfer or Command Status and Error Reporting: [25] [26]</li> <li>Busy Timeout For R1b, R5b Response Type: [27]</li> <li>Busy Timeout After Write CRC Status: [28]</li> <li>Write CRC Status Timeout: [29]</li> <li>Read Data Timeout: [30] [31]</li> <li>Boot Acknowledge Timeout: [32] [33] [34] [35] [36] [37]</li> <li>MMC CE-ATA Command Completion Disable Management: [38]</li> </ul> |
| MMC/SD/SDIO Use Cases and Tips                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <ul style="list-style-type: none"> <li>Programming Flow: [39]</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                 |
| MMC/SD/SDIO Register Manual                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <ul style="list-style-type: none"> <li>MMC/SD/SDIO Register Summary: [40]</li> <li>MMCHS Registers: [41] [42] [43] [44] [45] [46] [47] [48] [49] [50] [51] [52] [53] [54] [55] [56] [57] [58] [59] [60] [61] [62] [63] [64] [65] [66] [67] [68]</li> </ul>                                                                                                                                                                                                                               |

**Table 24-71. MMCHS\_IE**

|                  |                                                                                                                                                                                                                                                       |          |        |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|
| Address Offset   | 0x134                                                                                                                                                                                                                                                 |          |        |
| Physical Address | 0x4809 C134                                                                                                                                                                                                                                           | Instance | MMCHS1 |
|                  | 0x480A D134                                                                                                                                                                                                                                           |          | MMCHS3 |
|                  | 0x480B 4134                                                                                                                                                                                                                                           |          | MMCHS2 |
| Description      | Interrupt SD enable register<br>This register allows to enable/disable the module to set status bits, on an event-by-event basis.<br><b>MMCHS_IE[31:16]</b> = Error Interrupt Status Enable<br><b>MMCHS_IE[15:0]</b> = Normal Interrupt Status Enable |          |        |
| Type             | RW                                                                                                                                                                                                                                                    |          |        |

| 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 |
|----------|-------------|-------------|----|----------|------------|----------|------------|-------------|------------|------------|------------|-------------|------------|------|----|----------|------------|-------------|----------|-------------|--------------|----------|------------|-----------|-----------|---|---|---|---|---|---|
| Reserved | BADA_ENABLE | CERR_ENABLE |    | Reserved | ACE_ENABLE | Reserved | DEB_ENABLE | DCRC_ENABLE | DTO_ENABLE | CIE_ENABLE | CEB_ENABLE | CCRC_ENABLE | CTO_ENABLE | NULL |    | Reserved | OBI_ENABLE | CIRQ_ENABLE | Reserved | BRRI_ENABLE | BWRRI_ENABLE | Reserved | BGE_ENABLE | TC_ENABLE | CC_ENABLE |   |   |   |   |   |   |

| Bits  | Field Name  | Description                                                              | Type | Reset |
|-------|-------------|--------------------------------------------------------------------------|------|-------|
| 31:30 | Reserved    | Reserved bit field. Do not write any value.                              | R    | 0     |
| 29    | BADA_ENABLE | Bad access to data space Interrupt Enable<br>0x0: Masked<br>0x1: Enabled | RW   | 0     |
| 28    | CERR_ENABLE | Card error interrupt Enable<br>0x0: Masked<br>0x1: Enabled               | RW   | 0     |

## MMC/SD/SDIO Register Manual

www.ti.com

| Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Type | Reset |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 27:25 | Reserved    | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                 | R    | 0x0   |
| 24    | ACE_ENABLE  | Auto CMD12 error Interrupt Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                           | RW   | 0     |
| 23    | Reserved    | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                 | R    | 0     |
| 22    | DEB_ENABLE  | Data end bit error Interrupt Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0     |
| 21    | DCRC_ENABLE | Data CRC error Interrupt Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                             | RW   | 0     |
| 20    | DTO_ENABLE  | Data timeout error Interrupt Enable<br>0x0: The data timeout detection is deactivated.<br>The host controller provides the clock to the card until<br>the card sends the data or the transfer is aborted.<br>0x1: The data timeout detection is enabled.                                                                                                                                                                                                                   | RW   | 0     |
| 19    | CIE_ENABLE  | Command index error Interrupt Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                        | RW   | 0     |
| 18    | CEB_ENABLE  | Command end bit error Interrupt Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                      | RW   | 0     |
| 17    | CCRC_ENABLE | Command CRC error Interrupt Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0     |
| 16    | CTO_ENABLE  | Command timeout error Interrupt Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                      | RW   | 0     |
| 15    | NULL        | Fixed to 0<br>The host driver shall control error interrupts using the Error<br>Interrupt Signal Enable register.<br>Writes to this bit are ignored.                                                                                                                                                                                                                                                                                                                       | R    | 0     |
| 14:10 | Reserved    | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                                | R    | 0x00  |
| 9     | OBI_ENABLE  | Out-of-Band interrupt Enable A write to this register when<br>MMCi.MMCHS_CON[14] OBIE is set to '0' is ignored.<br>0x0: Masked<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                             | RW   | 0     |
| 8     | CIRQ_ENABLE | Card interrupt Enable<br>A clear of this bit also clears the corresponding status bit.<br>During 1-bit mode, if the interrupt routine does not remove the<br>source of a card interrupt in the SDIO card, the status bit is<br>reasserted when this bit is set to 1.<br>This bit must be set to 1 when entering in smart idle mode to<br>enable system to identify wakeup event and to allow controller to<br>clear internal wakeup source.<br>0x0: Masked<br>0x1: Enabled | RW   | 0     |
| 7:6   | Reserved    | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                 | RW   | 00    |
| 5     | BRR_ENABLE  | Buffer Read Ready Interrupt Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0     |
| 4     | BWR_ENABLE  | Buffer Write Ready Interrupt Enable<br>0x0: Masked                                                                                                                                                                                                                                                                                                                                                                                                                         | RW   | 0     |

| Bits | Field Name | Description                                 | Type | Reset |
|------|------------|---------------------------------------------|------|-------|
|      |            | 0x1: Enabled                                |      |       |
| 3    | Reserved   | Reserved bit field. Do not write any value. | R    | 0     |
| 2    | BGE_ENABLE | Block Gap Event Interrupt Enable            | RW   | 0     |
|      |            | 0x0: Masked                                 |      |       |
|      |            | 0x1: Enabled                                |      |       |
| 1    | TC_ENABLE  | Transfer completed Interrupt Enable         | RW   | 0     |
|      |            | 0x0: Masked                                 |      |       |
|      |            | 0x1: Enabled                                |      |       |
| 0    | CC_ENABLE  | Command completed Interrupt Enable          | RW   | 0     |
|      |            | 0x0: Masked                                 |      |       |
|      |            | 0x1: Enabled                                |      |       |

**Table 24-72. Register Call Summary for Register MMCHS\_IE**

MMC/SD/SDIO Integration

- [Clocks: \[0\] \[1\]](#)
- [Interrupt Requests: \[2\] \[3\] \[4\] \[5\]](#)

MMC/SD/SDIO Use Cases and Tips

- [Programming Flow: \[6\] \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\]](#)

MMC/SD/SDIO Register Manual

- [MMC/SD/SDIO Register Summary: \[21\]](#)
- [MMCHS Registers: \[22\] \[23\] \[24\] \[25\] \[26\]](#)

**Table 24-73. MMCHS\_ISE**

|                         |                                                                                                                                                                                                                                                                                       |                 |        |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------|
| <b>Address Offset</b>   | 0x138                                                                                                                                                                                                                                                                                 |                 |        |
| <b>Physical Address</b> | 0x4809 C138                                                                                                                                                                                                                                                                           | <b>Instance</b> | MMCHS1 |
|                         | 0x480A D138                                                                                                                                                                                                                                                                           |                 | MMCHS3 |
|                         | 0x480B 4138                                                                                                                                                                                                                                                                           |                 | MMCHS2 |
| <b>Description</b>      | Interrupt signal enable register<br>This register allows to enable/disable the module internal sources of status, on an event-by-event basis.<br><a href="#">MMCHS_ISE[31:16]</a> = Error Interrupt Signal Enable<br><a href="#">MMCHS_ISE[15:0]</a> = Normal Interrupt Signal Enable |                 |        |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                    |                 |        |



| Bits  | Field Name | Description                                   | Type | Reset |
|-------|------------|-----------------------------------------------|------|-------|
| 31:30 | Reserved   | Reserved bit field. Do not write any value.   | R    | 0     |
| 29    | BADA_SIGEN | Bad access to data space signal status Enable | RW   | 0     |
|       |            | 0x0: Masked                                   |      |       |
|       |            | 0x1: Enabled                                  |      |       |
| 28    | CERR_SIGEN | Card error interrupt signal status Enable     | RW   | 0     |
|       |            | 0x0: Masked                                   |      |       |
|       |            | 0x1: Enabled                                  |      |       |
| 27:25 | Reserved   | Reserved bit field. Do not write any value    | R    | 0x0   |
| 24    | ACE_SIGEN  | Auto CMD12 error signal status Enable         | RW   | 0     |

## MMC/SD/SDIO Register Manual

www.ti.com

| Bits  | Field Name | Description                                                                                                                                                                  | Type | Reset |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
|       |            | 0x0: Masked<br>0x1: Enabled                                                                                                                                                  |      |       |
| 23    | Reserved   | Reserved bit field. Do not write any value                                                                                                                                   | R    | 0     |
| 22    | DEB_SIGEN  | Data end bit error signal status Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                       | RW   | 0     |
| 21    | DCRC_SIGEN | Data CRC error signal status Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                           | RW   | 0     |
| 20    | DTO_SIGEN  | Data timeout error signal status Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                       | RW   | 0     |
| 19    | CIE_SIGEN  | Command index error signal status Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                      | RW   | 0     |
| 18    | CEB_SIGEN  | Command end bit error signal status Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                    | RW   | 0     |
| 17    | CCRC_SIGEN | Command CRC error signal status Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                        | RW   | 0     |
| 16    | CTO_SIGEN  | Command timeout error signal status Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                    | RW   | 0     |
| 15    | NULL       | Fixed to 0<br>The host driver shall control error interrupts using the Error Interrupt Signal Enable register.<br>Writes to this bit are ignored                             | R    | 0     |
| 14:10 | Reserved   | Reserved bit field. Do not write any value                                                                                                                                   | R    | 0x00  |
| 9     | OBI_SIGEN  | Out-Of-Band Interrupt signal status Enable.<br>A write to this register when <a href="#">MMCHS_CON[14]</a> OBIE bit is set to '0' is ignored.<br>0x0: Masked<br>0x1: Enabled | RW   | 0     |
| 8     | CIRQ_SIGEN | Card interrupt signal status Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                           | RW   | 0     |
| 7     | Reserved   | Reserved bit field. Do not write any value                                                                                                                                   | RW   | 0     |
| 6     | Reserved   | Reserved bit field. Do not write any value                                                                                                                                   | RW   | 0     |
| 5     | BRR_SIGEN  | Buffer Read Ready signal status Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                        | RW   | 0     |
| 4     | BWR_SIGEN  | Buffer Write Ready signal status Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                       | RW   | 0     |
| 3     | Reserved   | Reserved bit field. Do not write any value                                                                                                                                   | R    | 0     |
| 2     | BGE_SIGEN  | Black Gap Event signal status Enable<br>0x0: Masked<br>0x1: Enabled                                                                                                          | RW   | 0     |
| 1     | TC_SIGEN   | Transfer completed signal status Enable<br>0x0: Masked                                                                                                                       | RW   | 0     |

| Bits | Field Name | Description                            | Type | Reset |
|------|------------|----------------------------------------|------|-------|
|      |            | 0x1: Enabled                           |      |       |
| 0    | CC_SIGEN   | Command completed signal status Enable | RW   | 0     |
|      |            | 0x0: Masked                            |      |       |
|      |            | 0x1: Enabled                           |      |       |

**Table 24-74. Register Call Summary for Register MMCHS\_ISE**

---

MMC/SD/SDIO Integration

- [Clocks: \[0\] \[1\]](#)
- [Interrupt Requests: \[2\] \[3\] \[4\] \[5\] \[6\]](#)

MMC/SD/SDIO Use Cases and Tips

- [Programming Flow: \[7\] \[8\] \[9\] \[10\] \[11\] \[12\] \[13\] \[14\] \[15\] \[16\] \[17\] \[18\] \[19\] \[20\] \[21\]](#)

MMC/SD/SDIO Register Manual

- [MMC/SD/SDIO Register Summary: \[22\]](#)
- [MMCHS Registers: \[23\] \[24\] \[25\]](#)

**Table 24-75. MMCHS\_AC12**

|                         |                                                                                                                                                                                                                                    |                       |                 |     |          |      |      |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|-----|----------|------|------|
| <b>Address Offset</b>   | 0x13C                                                                                                                                                                                                                              |                       |                 |     |          |      |      |
| <b>Physical Address</b> | 0x4809 C13C                                                                                                                                                                                                                        | <b>Instance</b>       | MMCHS1          |     |          |      |      |
|                         | 0x480A D13C                                                                                                                                                                                                                        |                       | MMCHS3          |     |          |      |      |
|                         | 0x480B 413C                                                                                                                                                                                                                        |                       | MMCHS2          |     |          |      |      |
| <b>Description</b>      | Auto CMD12 Error Status Register. The host driver may determine which of the errors cases related to Auto CMD12 has occurred by checking this MMCi. <a href="#">MMCHS_AC12</a> register when an Auto CMD12 Error interrupt occurs. |                       |                 |     |          |      |      |
|                         | This register is valid only when Auto CMD12 is enabled (MMCi. <a href="#">MMCHS_CMD</a> [2] ACEN bit) and Auto CMD12Error (MMCi. <a href="#">MMCHS_STAT</a> [24] ACE bit) is set to 1.                                             |                       |                 |     |          |      |      |
|                         | Note: These bits are automatically reset when starting a new adtc command with data.                                                                                                                                               |                       |                 |     |          |      |      |
| <b>Type</b>             | R                                                                                                                                                                                                                                  |                       |                 |     |          |      |      |
| 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 |     |          |      |      |
| Reserved                |                                                                                                                                                                                                                                    |                       |                 |     |          |      |      |
|                         |                                                                                                                                                                                                                                    |                       |                 |     |          |      |      |
|                         |                                                                                                                                                                                                                                    |                       |                 | CNI | Reserved | ACIE | ACEB |
|                         |                                                                                                                                                                                                                                    |                       |                 |     |          | ACCE | ACTO |
|                         |                                                                                                                                                                                                                                    |                       |                 |     |          | ACNE |      |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                              | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:8        | Reserved          | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                     | R           | 0x0          |
| 7           | CNI               | Command not issue by Auto CMD12 error. If this bit is set to 1, it means that pending command is not executed due to Auto CMD12 error: ACEB, ACCE, ACTO or ACNE.<br><br>Read 0x0: Not error<br>Read 0x1: Command not issued                                                                                     | R           | 0            |
| 6:5         | Reserved          | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                     | R           | 0x0          |
| 4           | ACIE              | Auto CMD12 index error. This bit is a set to 1 when response index differs from corresponding command auto CMD12 index previously emitted.<br>This bit depends on the command index check enable (MMCI. <a href="#">MMCHS_CMD</a> [20] CICE bit).<br><br>Read 0x0: No error<br>Read 0x1: Auto CMD12 Index Error | R           | 0            |
| 3           | ACEB              | Auto CMD12 end bit error. This bit is set to 1 when detecting a 0 at the end bit position of auto CMD12 command response.<br><br>Read 0x0: No error<br>Read 0x1: AutoCMD12 End bit Error                                                                                                                        | R           | 0            |

| Bits | Field Name | Description                                                                                                                                                                                                                                                        | Type | Reset |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 2    | ACCE       | Auto CMD12 CRC error. This bit is automatically set to 1 when a CRC7 error is detected in the auto CMD12 command response depending on the enable in the MMCI. <a href="#">MMCHS_CMD[19]</a> CCCE bit.<br><br>Read 0x0: No error<br>Read 0x1: Auto CMD12 CRC Error | R    | 0     |
| 1    | ACTO       | Auto CMD12 timeout error. This bit is set to 1 if no response is received within 64 clock cycles from the end bit of the auto CMD12 command.<br><br>Read 0x0: No error<br>Read 0x1: Auto CMD12 Time Out                                                            | R    | 0     |
| 0    | ACNE       | Auto CMD12 not executed. This bit is set to 1 if multiple block data transfer command has started and if an error occurs in command before Auto CMD12 starts.<br><br>Read 0x0: Auto CMD12 Executed<br>Read 0x1: Auto CMD12 Not Executed                            | R    | 0     |

**Table 24-76. Register Call Summary for Register MMCHS\_AC12**

MMC/SD/SDIO Register Manual

- MMC/SD/SDIO Register Summary: [0]
- MMCHS Registers: [1] [2]

**Table 24-77. MMCHS\_CAPA**

| Address Offset   | 0x140                                                                                           |      |      |      |     |    |     |          |    |     |          |    |     |    |     |          |          |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------|-------------------------------------------------------------------------------------------------|------|------|------|-----|----|-----|----------|----|-----|----------|----|-----|----|-----|----------|----------|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| Physical Address | 0x4809 C140                                                                                     |      |      |      |     |    |     |          |    |     |          |    |     |    |     | Instance | MMCHS1   |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|                  | 0x480A D140                                                                                     |      |      |      |     |    |     |          |    |     |          |    |     |    |     | Instance | MMCHS3   |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|                  | 0x480B 4140                                                                                     |      |      |      |     |    |     |          |    |     |          |    |     |    |     | Instance | MMCHS2   |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
| Description      | Capabilities register. This register lists the capabilities of the MMC/SD/SDIO host controller. |      |      |      |     |    |     |          |    |     |          |    |     |    |     | Type     |          |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
| Type             | RW                                                                                              |      |      |      |     |    |     |          |    |     |          |    |     |    |     | Type     |          |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| Reserved         |                                                                                                 | VS18 | VS30 | VS33 | SRS | DS | HSS | Reserved |    | MBL | Reserved |    | BCF |    | TCU |          | Reserved |    | TCF |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:27 | Reserved   | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                               | R    | 0x00  |
| 26    | VS18       | Voltage support 1.8V Initialization of this register (via a write access to this register) depends on the system capabilities. The host driver shall not modify this register after the initialization. This register is only reinitialized by a hard reset (via MMCI_RESET signal).<br><br>Read 0x0: 1.8 V Not Supported<br>Write 0x0: 1.8 V Not supported<br>Read 0x1: 1.8 V Supported<br>Write 0x1: 1.8 V Supported<br><br>MMCHS1, 2 and 3: This bit must be set to 1. | RW   | 0     |
| 25    | VS30       | Voltage support 3.0V Initialization of this register (via a write access to this register) depends on the system capabilities. The host driver shall not modify this register after the initialization. This register is only reinitialized by a hard reset (via MMCI_RESET signal).<br><br>Read 0x0: 3.0 V Not Supported<br>Write 0x0: 3.0 V Not supported<br>Read 0x1: 3.0 V Supported                                                                                  | RW   | 0     |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
|             |                   | Write 0x1: 3.0 V Supported<br>MMCHS1: This bit must be set to 1.<br>MMCHS2 and 3: This bit must be left to 0.                                                                                                                                                                                                                                                                                                                                                             |             |              |
| 24          | VS33              | Voltage support 3.3V Initialization of this register (via a write access to this register) depends on the system capabilities. The host driver shall not modify this register after the initialization. This register is only reinitialized by a hard reset (via MMCi_RESET signal)<br><br>Read 0x0: 3.3 V Not Supported<br>Write 0x0: 3.3 V Not supported<br>Read 0x1: 3.3 V Supported<br>Write 0x1: 3.3 V Supported<br><br>MMCHS1, 2 and 3: This bit must be left to 0. | RW          | 0            |
| 23          | SRS               | Suspend/Resume support (SDIO cards only)This bit indicates whether the host controller supports Suspend/Resume functionality.<br><br>Read 0x0: The Host controller does not Suspend/Resume functionality.<br>Read 0x1: The Host controller supports Suspend/Resume functionality.                                                                                                                                                                                         | R           | 1            |
| 22          | DS                | DMA support. This bit indicates that the Host Controller is able to use DMA to transfer data between system memory and the Host Controller directly.<br><br>Read 0x0: DMA Not Supported<br>Read 0x1: DMA Supported                                                                                                                                                                                                                                                        | R           | 1            |
| 21          | HSS               | High speed support. This bit indicates that the host controller supports high speed operations and can supply an up-to-52 MHz clock to the card.<br><br>Read 0x0: High Speed Not Supported<br>Read 0x1: High Speed Supported                                                                                                                                                                                                                                              | R           | 1            |
| 20:18       | Reserved          | Reserved bit field. Do not write any value.                                                                                                                                                                                                                                                                                                                                                                                                                               | R           | 0x0          |
| 17:16       | MBL               | Maximum block length. This value indicates the maximum block size that the host driver can read and write to the buffer in the host controller.<br>The host controller supports 512 bytes and 1024 bytes block transfers.<br><br>Read 0x0: 512 bytes<br>Read 0x1: 1024 bytes<br>Read 0x2: 2048 bytes                                                                                                                                                                      | R           | 0x1          |
| 15:14       | Reserved          | Reserved bit field. Do not write any value                                                                                                                                                                                                                                                                                                                                                                                                                                | R           | 0x0          |
| 13:8        | BCF               | Base clock frequency for clock provided to the card.<br><br>Read 0x0: The value indicating the base (maximum) frequency for the output clock provided to the card is system dependent and is not available in this register. Get the information via another method. See <a href="#">Chapter 3, Power, Reset, and Clock Management</a> , for more information on the value of FUNC_96M_CLK clock signal.                                                                  | R           | 0x00         |
| 7           | TCU               | Timeout clock unit. This bit shows the unit of base clock frequency used to detect Data Timeout Error (MMCi.MMCHS_STAT[20] DTO bit).<br><br>Read 0x0: kHz<br>Read 0x1: MHz                                                                                                                                                                                                                                                                                                | R           | 1            |
| 6           | Reserved          | Reserved. This bit is initialized to zero, and writes to it are ignored.                                                                                                                                                                                                                                                                                                                                                                                                  | R           | 0            |
| 5:0         | TCF               | Timeout clock frequency. The timeout clock frequency is used to detect Data Timeout Error (MMCi.MMCHS_STAT[20] DTO bit).<br><br>Read 0x0: The timeout clock frequency depends on the frequency of the clock provided to the card. The value of the timeout clock frequency is not available in this register.<br><b>Note:</b> You can have the timeout clock frequency by dividing FUNC_96M_CLK by the value of the MMCi.MMCHS_SYSCTL[15:6] CLKD bit field.               | R           | 0x00         |

**Table 24-78. Register Call Summary for Register MMCHS\_CAPA**

|                                                               |  |
|---------------------------------------------------------------|--|
| MMC/SD/SDIO Integration                                       |  |
| • <a href="#">Resets: [0]</a>                                 |  |
| MMC/SD/SDIO Functional Description                            |  |
| • <a href="#">Data Buffer: [1]</a>                            |  |
| MMC/SD/SDIO Basic Programming Model                           |  |
| • <a href="#">Set MMCHS Default Capabilities: [2]</a>         |  |
| MMC/SD/SDIO Use Cases and Tips                                |  |
| • <a href="#">Programming Flow: [3] [4] [5]</a>               |  |
| MMC/SD/SDIO Register Manual                                   |  |
| • <a href="#">MMC/SD/SDIO Register Summary: [6]</a>           |  |
| • <a href="#">MMCHS Registers: [7] [8] [9] [10] [11] [12]</a> |  |

**Table 24-79. MMCHS\_CUR\_CAPA**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                       |                 |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x148                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                       |                 |
| <b>Physical Address</b> | 0x4809 C148                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Instance</b>       | MMCHS1          |
|                         | 0x480A D148                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                       | MMCHS3          |
|                         | 0x480B 4148                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                       | MMCHS2          |
| <b>Description</b>      | Maximum current capabilities Register.<br>This register indicates the maximum current capability for each voltage. The value is meaningful if the voltage support is set in the capabilities register (MMCi: <a href="#">MMCHS_CAPA</a> ).<br>Initialization of this register (via a write access to this register) depends on the system capabilities. The host driver shall not modify this register after the initialization.<br>This register is only reinitialized by a hard reset (via MMCi_RESET signal) |                       |                 |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                       |                 |
| 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 |
| Reserved                | CUR_1V8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | CUR_3V0               | CUR_3V3         |

| Bits  | Field Name | Description                                                                                                                             | Type | Reset |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:24 | Reserved   | Reserved. This bit is initialized to zero, and writes to it are ignored.                                                                | R    | 0x0   |
| 23:16 | CUR_1V8    | Maximum current for 1.8 V<br><br>Read 0x0 The maximum current capability for this voltage is not available.<br>Feature not implemented. | RW   | 0x0   |
| 15:8  | CUR_3V0    | Maximum current for 3.0 V<br><br>Read 0x0 The maximum current capability for this voltage is not available.<br>Feature not implemented. | RW   | 0x0   |
| 7:0   | CUR_3V3    | Maximum current for 3.3 V<br><br>Read 0x0 The maximum current capability for this voltage is not available.<br>Feature not implemented. | RW   | 0x0   |

**Table 24-80. Register Call Summary for Register MMCHS\_CUR\_CAPA**

|                                                       |  |
|-------------------------------------------------------|--|
| MMC/SD/SDIO Integration                               |  |
| • <a href="#">Resets: [0]</a>                         |  |
| MMC/SD/SDIO Basic Programming Model                   |  |
| • <a href="#">Set MMCHS Default Capabilities: [1]</a> |  |
| MMC/SD/SDIO Register Manual                           |  |
| • <a href="#">MMC/SD/SDIO Register Summary: [2]</a>   |  |



**Table 24-81. MMCHS\_REV**

|                         |                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x1FC                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4809 C1FC                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | Instance                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | MMCHS1                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | Versions Register. This register contains the hard coded RTL vendor revision number, the version number of SD specification compliance and a slot status bit.<br>MMCi.MMCHS_REV[31:16] = Host controller version<br>MMCi.MMCHS_REV[15:0] = Slot Interrupt Status |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|      |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |    |    |   |   |   |   |   |   |  |  |
|------|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|----|----|---|---|---|---|---|---|--|--|
| 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 |  |  |
| VREV |    |    |    |    |    |    |    | SREV |    |    |    |    |    |    |    | Reserved |    |    |    |    |    |   |   | SS | SS |   |   |   |   |   |   |  |  |

| Bits  | Field Name | Description                                                                                                                                                                                                                                                               | Type | Reset              |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------------|
| 31:24 | VREV       | Vendor Version Number: IP revision<br>[31:28] Major revision<br>[27:24] Minor revision<br>Examples:<br>0x10 for 1.0<br>0x21 for 2.1                                                                                                                                       | R    | See <sup>(1)</sup> |
| 23:16 | SREV       | Specification Version Number. This status indicates the Standard SD Host Controller Specification Version. The upper and lower 4-bits indicate the version.<br><br>Read 0x0: SD Host Specification Version 1.0                                                            | R    | 0x00               |
| 15:1  | Reserved   | Reserved bit field. Do not write any value                                                                                                                                                                                                                                | R    | 0x0000             |
| 0     | SIS        | Slot Interrupt Status. This status bit indicates the inverted state of interrupt signal for the module.<br>By a power on reset or by setting a software reset for all (MMCi.MMCHS_SYSCTL[24] SRA), the interrupt signal shall be deasserted and this status shall read 0. | R    | 0                  |

<sup>(1)</sup> TI internal data**Table 24-82. Register Call Summary for Register MMCHS\_REV**

- MMC/SD/SDIO Register Summary: [0]
- MMCHS Registers: [1] [2]

## **General-Purpose Interface**

This chapter describes the general-purpose interface for the device.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                                               | Page        |
|---------------------------------------------------------------------|-------------|
| <b>25.1 General-Purpose Interface Overview .....</b>                | <b>3494</b> |
| <b>25.2 General-Purpose Interface Environment .....</b>             | <b>3497</b> |
| <b>25.3 General-Purpose Interface Integration .....</b>             | <b>3500</b> |
| <b>25.4 General-Purpose Interface Functional Description .....</b>  | <b>3507</b> |
| <b>25.5 General-Purpose Interface Basic Programming Model .....</b> | <b>3511</b> |
| <b>25.6 General-Purpose Interface Register Manual .....</b>         | <b>3517</b> |

## 25.1 General-Purpose Interface Overview

The general-purpose interface combines six general-purpose input/output (GPIO) banks.

Each GPIO module provides 32 dedicated general-purpose pins with input and output capabilities; thus, the general-purpose interface supports up to 192 (6 x 32) pins.

These pins can be configured for the following applications:

- Data input (capture)/output (drive)
- Keyboard interface with a debounce cell
- Interrupt generation in active mode when external events are detected. Detected events are processed by two parallel independent interrupt-generation submodules to support biprocessor operations.
- Wake-up request generation in idle mode when external events are detected

These modules do not include pad control (pullup/down control, open-drain feature). For more information, see [Chapter 13, System Control Module](#).

### 25.1.1 Global Features

GPIOs include the following global features:

- Synchronous interrupt requests in active mode from each channel are processed by two identical interrupt generation submodules used independently by the imaging video and audio accelerator (IVA2.2) and the microprocessor unit (MPU) subsystems. One of these interrupts is mapped on the IVA2.2 subsystem interrupt controller (INTC) and the other on the MPU subsystem INTC.
- Asynchronous wake-up requests in idle mode from input channels are merged together to issue one wake-up signal per GPIO module.
- Data input (capture)/output (drive)
- Power management support

The general-purpose interface has 12 interrupt lines (two interrupt lines per GPIO module instance).

Each GPIO module produces a wake-up request signal to the power, reset, and clock management (PRCM) module.

[Figure 25-1](#) shows an overview of the general-purpose interface.

**Figure 25-1. General-Purpose Interface Overview**


gpif-001

Each channel in GPIOs has the following features:

- The **GPIO<sub>i</sub>.GPIO\_OE** register controls the output capability for each pin.
- The output line level reflects the value written in the **GPIO<sub>i</sub>.GPIO\_DATAOUT** register through the level 4 (L4) interconnect.
- The input line can be fed to GPIO through an optional and configurable debounce cell. (The debouncing time value is global for all ports of one GPIO module, so up to five different debouncing time values are possible.)
- The input line value is sampled into the **GPIO<sub>i</sub>.GPIO\_DATAIN** register and can be read through the L4 interconnect.
- In active mode, the input line can be used through level and edge detectors to trigger synchronous interrupts. The edge (rising, falling, or both) or the level (logical 0, logical 1, or both) used can be configured.
- In idle mode, the input line can be used to activate the asynchronous wake-up request (on edge detection: Rising edge, falling edge, or both).

The module provides an alternative to the atomic test and set operations for the following registers:

- **GPIO<sub>i</sub>.GPIO\_DATAOUT**
- **GPIO<sub>i</sub>.GPIO\_IRQENABLE1**
- **GPIO<sub>i</sub>.GPIO\_IRQENABLE2**
- **GPIO<sub>i</sub>.GPIO\_WAKEUPENABLE**

For these registers, the modules implement the set-and-clear protocol register update (see [Section 25.5.2, Set and Clear Instructions](#)).

## 25.2 General-Purpose Interface Environment

The general-purpose interface combines six GPIO modules for a flexible, user-programmable, GPIO controller. The general-purpose interface implements functions that are not implemented with the dedicated controllers in the device and require simple input and/or output software-controlled signals. The general-purpose interface allows a variety of custom connections and expands the I/O capabilities of the system to the real world.

Figure 25-2 shows a typical application using the general-purpose interface.

**Figure 25-2. General-Purpose Interface Typical Application System Overview**



**NOTE: Temperature Sensing**

Most memories provide a temperature sensor to control the auto-refresh duty cycle. The device monitors the temperature of the external memory using the `pop_tq_temp_sense_ft` ball and a GPIO input. To do this, `pop_tq_temp_sense_ft` is connected to a GPIO through the customer board. This feature is application-dependent.

**CAUTION**

Due to buffer strength, an external serial resistor must be connected to the balls corresponding to `gpio_120` to `gpio_129` pads.

GPIO multiplexed on these pads should only be used with special electrical attention, and if no other solutions are possible for their considered application.

They are not multiplexed on standard 1.8-V I/O cell buffers but specific dual -voltage USIM/MMC-compliant buffers with nonstandard voltage domains, power-up sequences, power states, and controls/configurations.

The general-purpose interface can physically connect the device to a keyboard matrix and peripheral integrated circuits (ICs).

### 25.2.1 GPIO as a Keyboard Interface

The general-purpose interface can be used as a keyboard interface. You can dedicate channels based on the keyboard matrix size ( $r \times c$ ). Figure 25-3 shows row channels configured as inputs with the input debounce feature enabled. The row channels are driven high with an external pullup. Column channels are configured as outputs and drive a low-level.

**Figure 25-3. General-Purpose Interface Used as a Keyboard Interface**

gpiif-003

When a keyboard matrix key is pressed, the corresponding row and column lines are shorted together and a low-level is driven on the corresponding row channel. This generates an interrupt based on the proper configuration (see [Section 25.5.3, Interrupt and Wakeup](#)).

When the keyboard interrupt is received, the processor (the MPU and/or IVA2.2 subsystem) can disable the keyboard interrupt and scan the column channels for the key coordinates.

- The scanning sequence has as many states as column channels: For each step in the sequence, the processor drives one column channel low and the others high.
- The processor reads the values of the row channels and thus detects which keys in the column are pressed.

At the end of the scanning sequence, the processor establishes which keys are pressed. The keyboard interface can then be reconfigured in the interrupt waiting state.

## 25.2.2 General-Purpose Interface Functional Interfaces

### 25.2.2.1 General-Purpose Interface Pins

Table 25-1 lists the interface pins of the general-purpose interface.

**Table 25-1. I/O Pin Description**

| Signal Name    | I/O <sup>(1)</sup> <sup>(2)</sup> | Description <sup>(3)</sup> <sup>(2)</sup> | Reset Value |
|----------------|-----------------------------------|-------------------------------------------|-------------|
| gpio_[31:0]    | I/O                               | GPIO in configuration mode 4.             | HiZ         |
| gpio_[186:34]  | I/O                               | GPIO in configuration mode 4.             | HiZ         |
| gpio_[191:188] | I/O                               | GPIO in configuration mode 4.             | HiZ         |

<sup>(1)</sup> I = Input; O = Output

<sup>(2)</sup> Some of the pins have special or restricted use. For more information, see [Table 25-5](#).

<sup>(3)</sup> For more information about pin configuration modes, see [Chapter 13, System Control Module](#).

## 25.3 General-Purpose Interface Integration

### 25.3.1 Description

Figure 25-4 highlights the general-purpose interface integration in the device.

**Figure 25-4. General-Purpose Interface Integration**



gpif-004

#### 25.3.1.1 Clocking, Reset, and Power-Management Scheme

##### 25.3.1.1.1 Clocking

Each GPIO module uses two clocks:

- Debounce clock: The 32-KHz debounce clock,  $\text{GPIO}_i\text{\_DBCLK}$ , (where  $i = 1, 2, 3, 4, 5$ , and  $6$ , with one debounce clock per module), comes from the PRCM module and is used for the debounce cell logic (without the corresponding configuration registers). This cell can sample the input line and filters the input level using a programmed delay.

For GPIO2 to GPIO6, this clock is controlled by the  $\text{EN\_GPIO}_i$  (where  $i = 2$  to  $6$ ) bit

$\text{PRCM.CM\_FCLKEN\_PER}$  (0: Disables, 1: Enables the clock). For GPIO1, this clock is controlled by the  $\text{EN\_GPIO1}$  bit  $\text{PRCM.CM\_FCLKEN\_WKUP}[3]$  (0: Disables, 1: Enables the clock) for GPIO1.

- Interface clock: The interface clock, GPIO<sub>i</sub>\_ICLK (where  $i = 1, 2, 3, 4, 5$ , and  $6$ ), comes from the PRCM module and is used throughout GPIO (except within the debounce cell logic). The interface clock clocks the data exchanges between the L4 interconnect and the internal logic. The clock-gating features allow module power consumption to be adapted to the activity. For GPIO1, this clock is controlled by the EN\_GPIO1 bit PRCM.CM\_ICLKEN\_WKUP[3] (0: Disabled, 1: Enabled the clock) and the AUTO\_GPIO1 bit PRCM.CM\_AUTOIDLE\_WKUP[3] (enables/disables automatic control of the interface clock). For GPIO2 to GPIO6, this clock is controlled by the EN\_GPIO<sub>i</sub> (where  $i = 2$  to  $6$ ) bit PRCM.CM\_ICLKEN\_PER (0: Disables, 1: Enables the clock) and the AUTO\_GPIO<sub>i</sub> (where  $i = 2$  to  $6$ ) bit PRCM.CM\_AUTOIDLE\_PER (enables/disables automatic control of the interface clock). [Table 25-2](#) describes the GPIO clocks.

**Table 25-2. Clocks**

| Attribute       | Frequency                                   | Name                                           | Mapping         | Comments                      |
|-----------------|---------------------------------------------|------------------------------------------------|-----------------|-------------------------------|
| Debounce clock  | 32 KHz                                      | GPIO <sub>i</sub> _DBCLK, where $i = 2$ to $6$ | PER_32K_ALWON_F | Source is PRCM module.<br>CLK |
|                 |                                             | GPIO1_DBCLK                                    | WKUP_32K_CLK    |                               |
| Interface clock | Depends on<br>PRCM<br>registers<br>settings | GPIO <sub>i</sub> _ICLK, where $i = 2$ to $6$  | PER_L4_ICLK     |                               |
|                 |                                             | GPIO1_ICLK                                     | WKUP_L4_ICLK    |                               |

### 25.3.1.1.2 Reset

The general-purpose interface can be reset by using the domain reset (hardware reset) or by setting a dedicated configuration bit (software reset) in each GPIO module.

- Hardware reset: GPIO2 to GPIO6 are attached to the PER\_RST reset domain. GPIO1 is attached to the WKUP\_RST reset domain. The hardware reset has a global reset action on GPIOs of the general-purpose interface. All configuration registers and internal logic are reset when it is active (low-level). In each GPIO module, the RESETDONE bit GPIO<sub>i</sub>.[GPIO\\_SYSSTATUS](#)[0] monitors the internal reset status; it is set when the reset completes. For more information, see [Chapter 3, Power, Reset, and Clock Management](#).
- Software reset: Each GPIO module has its own software reset using the GPIO<sub>i</sub>.[GPIO\\_SYSCONFIG](#)[1] SOFTRESET bit (where  $i = 1, 2, 3, 4, 5$ , or  $6$ ). The software reset has the same effect as the hardware reset signal, but this reset can be applied on one or more modules. Writing 1 to the GPIO<sub>i</sub>.[GPIO\\_SYSCONFIG](#)[1] SOFTRESET bit (where  $i = 1, 2, 3, 4, 5$ , or  $6$ ) resets the module. The bit value of 1 remains until the reset completes. When the software reset completes, the GPIO<sub>i</sub>.[GPIO\\_SYSCONFIG](#)[1] SOFTRESET bit is automatically reset to 0 and has the same effect as the hardware reset. The GPIO<sub>i</sub>.[GPIO\\_SYSSTATUS](#)[0] RESETDONE bit is cleared during a software reset. This bit is set to 1 when the software reset completes.

### 25.3.1.1.3 Power Domain

GPIO1 is attached to the WKUP power domain (see [Chapter 3, Power, Reset, and Clock Management](#)). This domain is composed of the logic permanently supplied to manage domain power state transitions and detect wake-up events. The WKUP power domain is continuously active. GPIO2 to GPIO6 are attached to the PER power domain (see [Chapter 3, Power, Reset, and Clock Management](#)). The PER power domain is not active continuously.

### 25.3.1.1.4 Power Management

#### 25.3.1.1.4.1 Idle Scheme

To save dynamic consumption, an efficient idle scheme is based on:

- An efficient local autoclock gating for each module
- The implementation of control sideband signals between the PRCM module and each module

This enhanced idle control allows clocks to be activated and deactivated safely without requiring a complex software management.

The idle mode request, idle acknowledge, and wake-up request (GPIO<sub>i</sub>\_SWAKEUP, where  $i = 1, 2, 3, 4, 5$ , and  $6$ ) are sideband signals between the PRCM module and the general-purpose interface (see [Section 25.3.1.2, Hardware Requests](#)).

#### **25.3.1.4.2 Operating Modes**

The following four operating modes are defined for the modules:

- Active mode: The module runs synchronously on the interface clock; interrupts can be generated based on the configuration and external signals.
- Idle mode: Power-saving mode with the module in a waiting state. The interface clock can be stopped, an interrupt cannot be generated, and a wake-up signal can be generated based on the configuration and external signals.  
If the debounce clock provided by the PRCM module is active, the debounce cell can sample and filter the input to generate a wake-up event. If the debounce clock is inactive, the debounce cell gates all input signals and thus cannot be used.
- Inactive mode: The module has no activity. The interface clock can be stopped, an interrupt cannot be generated, and the wake-up feature is inhibited.
- Disabled mode: The module is not used. The internal clock paths are gated, and an interrupt or wake-up request cannot be generated.

Idle and inactive modes are configured within the module and activated on request by the PRCM module (see [Chapter 3, Power, Reset, and Clock Management](#)) through sideband signals (see [Section 25.3.1.4.3, System Power Management and Wake-Up](#)).

The disabled mode is set by software through a dedicated configuration bit, the GPIO<sub>i</sub>.[GPIO\\_CTRL\[0\]](#) DISABLEMODULE bit (0: The module is enabled and clocks are not gated; 1: The module is disabled and clocks are gated). It unconditionally gates the internal clock paths that are not used for the L4 interconnect.

#### **25.3.1.4.3 System Power Management and Wake-Up**

The PRCM module can require GPIOs to be idled for power saving purposes.

The general-purpose interface has six identical idle mode request/acknowledge (handshake) mechanisms with the PRCM module (see [Figure 25-4](#) and [Section 25.3.1.2, Hardware Requests](#)): One per GPIO module. The general-purpose interface allows GPIOs to enter idle mode based on the GPIO<sub>i</sub>.[GPIO\\_SYSConfig\[4:3\]](#) IDLEMODE bit field.

The idle acknowledge depends on the configuration and activity of each GPIO module:

- Smart-idle mode (recommended)

When GPIO is configured in smart-idle mode (GPIO<sub>i</sub>.[GPIO\\_SYSConfig\[4:3\]](#) IDLEMODE bit field [10]) and receives an idle request from the PRCM module (for GPIO2 to GPIO6: The corresponding bits in the PRCM.CM\_FCLKEN\_PER and PRCM.CM\_ICLKEN\_PER registers cleared to 0 or the corresponding bit in the PRCM.CM\_AUTOIDLE\_PER bit set to 1 and L4 interface clock idle transitions; for GPIO1: the PRCM.CM\_FCLKEN\_WKUP[3] EN\_GPIO1 bit cleared to 0, PRCM.CM\_ICLKEN\_WKUP[3] EN\_GPIO1 bit cleared to 0, or the PRCM.CM\_AUTOIDLE\_WKUP[3] AUTO\_GPIO1 bit set to 1 and L4 interface clock idle transitions), GPIO checks for more activity (capture of the input GPIO pins in the GPIO<sub>i</sub>.[GPIO\\_DATAin](#) register is complete with no pending interrupt; all interrupt-status bits are cleared); and there is no access to the GPIO.[GPIO\\_DEBOUNCINGTIME](#) register pending synchronization.

The idle acknowledge is then asserted and the module enters into idle mode. It waits for active system clock gating by the PRCM module (when all peripherals supplied by the same L4 interface clock domain are also ready for idle).

When in idle mode (that is, when the PRCM module gates the interface clock), no interrupt occurs and the module is ready to issue a wake-up request.

When the expected transition occurs on an enabled GPIO input pin, GPIO exits from idle mode, if the

GPIOi.GPIO\_SYSConfig[2] ENAWAKEUP bit is set to 1 (wake-up capability enabled), and the corresponding bit in the PRCM.PM\_WKEN\_PER register is also set to 1 for the GPIO2 to GPIO6, and/or the PRCM.PM\_WKEN\_WKUP[3] EN\_GPIO1 bit is also set to 1 for GPIO1.

- Force-idle mode

When GPIO is configured in force-idle mode (GPIOi.GPIO\_SYSConfig[4:3] IDLEMODE bit field [00]) and receives an idle request from the PRCM module for GPIO2 to GPIO6: The corresponding bits in the PRCM.CM\_FCLKEN\_PER and PRCM.CM\_ICLKEN\_PER registers cleared to 0, or the corresponding bit in PRCM.CM\_AUTOIDLE\_PER bit set to 1 and L4 interface clock idle transitions; for GPIO1: the PRCM.CM\_FCLKEN\_WKUP[3] EN\_GPIO1 bit cleared to 0, the PRCM.CM\_ICLKEN\_WKUP[3] EN\_GPIO1 bit cleared to 0, or the PRCM.CM\_AUTOIDLE\_WKUP[3] AUTO\_GPIO1 bit set to 1 and the L4 interface clock idle transitions), GPIO waits unconditionally for an active system clock gating by the PRCM module. (This occurs only when all peripherals supplied by the same L4 interface clock domain are also ready for idle.)

When in idle mode (that is, when the PRCM module gates the interface clock), the module (in inactive mode) has no activity, the interface clock paths are gated, an interrupt cannot be generated, and the wake-up feature is totally inhibited.

- No-idle mode

When GPIO is configured in no-idle mode (GPIOi.GPIO\_SYSConfig[4:3] IDLEMODE bit field [01]) and receives an idle request from the PRCM module (for GPIO2 to GPIO6: The corresponding bits in the PRCM.CM\_FCLKEN\_PER and PRCM.CM\_ICLKEN\_PER registers cleared to 0 or the corresponding bit in the PRCM.CM\_AUTOIDLE\_PER bit set to 1 and L4 interface clock idle transitions; for GPIO1: the PRCM.CM\_FCLKEN\_WKUP[3] EN\_GPIO1 bit cleared to 0, PRCM.CM\_ICLKEN\_WKUP[3] EN\_GPIO1 bit cleared to 0, or PRCM.CM\_AUTOIDLE\_WKUP[3] AUTO\_GPIO1 bit set to 1 and L4 interface clock idle transitions), GPIO does not go to idle mode and the idle acknowledge is never sent.

---

**NOTE:** The GPIO2 to GPIO6 idle state can be checked by reading the corresponding status bits in the PRCM.CM\_IDLEST\_PER register (0: Active; 1: Idle) and is idle only when GPIO2 to GPIO6 are configured in smart-idle mode and have asserted their idle acknowledge.

The GPIO1 idle state can be checked by the PRCM.CM\_IDLEST\_WKUP[3] ST\_GPIO1 bit (0: Idle, 1: active) and is idle only when GPIO1 is configured in smart-idle mode and has asserted its idle acknowledge.

GPIO2 to GPIO6 wake-up status can be checked by accessing the corresponding bits in the PRCM.PM\_WKST\_PER register (read 0: No wakeup occurred; read 1: Wakeup occurred; write 1: Status bit reset).

The GPIO1 wake-up status can also be checked by the PRCM.PM\_WKST\_WKUP[3] ST\_GPIO1 bit (read 0: No wake-up occurred; read 1: Wakeup occurred; write 1: Status bit reset).

---

#### 25.3.1.1.4.4 Module Power Saving

GPIO has local power management by internal clock-gating features:

- Internal interface clock gating: The clock for the L4 interconnect logic can be gated when the module is not accessed, if the GPIOi.GPIO\_SYSConfig[0] AUTOIDLE bit is set. Otherwise, this logic is free-running on the interface clock.
- Clock gating for the input data sample logic: The clock for the input data sample logic can be gated when the data in the register is not accessed.
- Clock gating for the event detection logic: Each GPIO module implements four clock groups used for the logic in synchronous events detection. Each group of eight input GPIO pins has a separate enable signal depending on the edge/level detection register setting. If a group requires no detection, the corresponding clock is gated off (see [Section 25.5.1, Power Saving by Grouping the Edge/Level Detection](#)). All channels are also gated using a one-out-of-N scheme. N is the GPIOi.GPIO\_CTRL[2:1] GATINGRATIO bit field; it can take the values 1 (b00), 2 (0b01), 4 (b10), or 8 (0b11). The interface clock is enabled for this logic one cycle every N cycles. When N equals 1, there is no gating and this logic is free-running on the interface clock. When N is 2, 4, or 8, this logic runs at a frequency equal to

the interface clock frequency divided by N.

- Inactive mode: All internal clock paths are gated.
- Disabled mode: All internal clock paths not used for the L4 interconnect are gated. The GPIOi.GPIO\_CTRL[0] DISABLEMODULE bit controls a clock-gating feature at the module level. When set to 1, this bit forces clock gating for all internal clock paths. Module internal activity is suspended. The L4 interconnect is not affected by this bit.

Each 8-input group of GPIO has a clock-enable signal that can be enabled or disabled depending on the edge/level detection register setting. If a group requires no detection, then the corresponding clock is gated.

The interface clock gating is controlled with the GPIOi.GPIO\_SYSCONFIG[0] AUTOIDLE bit, which is used to save power when the module is not used because of the multiplexing configuration selected at the chip level. This bit has precedence over all other internal configuration bits.

### 25.3.1.2 Hardware Requests

#### 25.3.1.2.1 Interrupt Requests

All interrupt sources (the 32 input GPIO channels) are merged to issue two synchronous interrupt requests in each GPIO module. Thus, the general-purpose interface has 12 interrupt lines (two interrupt lines per GPIO module instance).

Synchronous interrupt request lines 1 and 2 are active depending on their respective interrupt-enable 1 and 2 registers (GPIOi.GPIO\_IRQENABLE1 and GPIOi.GPIO\_IRQENABLE2).

- Synchronous interrupt request line 1 is mapped on the MPU INTC.
- Synchronous interrupt request line 2 is mapped on the IVA2.2 INTC.

**Table 25-3** lists the interrupt lines that are driven out from the general-purpose interface to the MPU INTC and the IVA2.2 INTC.

**Table 25-3. Interrupts**

| Name           | Mapping      | Comments                        |
|----------------|--------------|---------------------------------|
| <b>GPIO1</b>   |              |                                 |
| GPIO1_MPU_IRQ  | M_IRQ_29     | Destination is the MPU INTC.    |
| GPIO1_IVA2_IRQ | IVA2_IRQ[28] | Destination is the IVA2.2 INTC. |
| <b>GPIO2</b>   |              |                                 |
| GPIO2_MPU_IRQ  | M_IRQ_30     | Destination is the MPU INTC.    |
| GPIO2_IVA2_IRQ | IVA2_IRQ[29] | Destination is the IVA2.2 INTC. |
| <b>GPIO3</b>   |              |                                 |
| GPIO3_MPU_IRQ  | M_IRQ_31     | Destination is the MPU INTC.    |
| GPIO3_IVA2_IRQ | IVA2_IRQ[30] | Destination is the IVA2.2 INTC. |
| <b>GPIO4</b>   |              |                                 |
| GPIO4_MPU_IRQ  | M_IRQ_32     | Destination is the MPU INTC.    |
| GPIO4_IVA2_IRQ | IVA2_IRQ[31] | Destination is the IVA2.2 INTC. |
| <b>GPIO5</b>   |              |                                 |
| GPIO5_MPU_IRQ  | M_IRQ_33     | Destination is the MPU INTC.    |
| GPIO5_IVA2_IRQ | IVA2_IRQ[32] | Destination is the IVA2.2 INTC. |
| <b>GPIO6</b>   |              |                                 |
| GPIO6_MPU_IRQ  | M_IRQ_34     | Destination is the MPU INTC.    |
| GPIO6_IVA2_IRQ | IVA2_IRQ[43] | Destination is the IVA2.2 INTC. |

### 25.3.1.2.1.1 Wake-Up Generation

GPIO1 of the general-purpose interface is attached to the WKUP power domain (see [Chapter 3, Power, Reset, and Clock Management](#)) and can wake up the system.

---

**NOTE:** GPIO2 to GPIO6 modules belong to the PER power domain and thus have wake-up system capability only when the PER power domain is active.

---

All wake-up sources (the 32 input GPIO channels) are merged together to issue a single asynchronous wake-up request in each GPIO module following the expected transition(s) (based on register programming). Each GPIO module generates a wake-up signal to the PRCM module.

---

**NOTE:** Only gpio\_1, gpio\_9, gpio\_10, gpio\_11, gpio\_30, and gpio\_31 can be used to generate a direct wake-up event. The other GPIO1 pins cannot be used to generate a direct wake-up event, because they are connected to the device I/O pad logic in the CORE power domain (VDD2). When the CORE power domain is OFF, the VDD2-supplied I/O pins of GPIO1 cannot generate a wake-up event.

---

The asynchronous wake-up request line is active based on the GPIO*i*.[GPIO\\_WAKEENABLE](#) register (where *i* = 1, 2, 3, 4, 5, and 6).

**CAUTION**

The wake-up capabilities of GPIO2 to GPIO6 are operational only when the PER power domain is active.

[Table 25-4](#) shows the wake-up signals mapping.

**Table 25-4. Wake-Up Signals**

| Name                | Mapping                | Comments                                                               |
|---------------------|------------------------|------------------------------------------------------------------------|
| GPIO <i>i</i> _WAKE | GPIO <i>i</i> _SWAKEUP | Where <i>i</i> = 1, 2, 3, 4, 5, and 6. Destination is the PRCM module. |

[Table 25-5](#) describes the GPIO channels.

**Table 25-5. GPIO Channel Description**

| Channel Number | Type <sup>(1)</sup> | Mapping       | Wake-Up Feature    | Comments                                                               |
|----------------|---------------------|---------------|--------------------|------------------------------------------------------------------------|
| <b>GPIO1</b>   |                     |               |                    |                                                                        |
| [31:0]         | I/O                 | gpio_[31:0]   | Yes                | GPIO <sup>(2)</sup>                                                    |
| <b>GPIO2</b>   |                     |               |                    |                                                                        |
| [0]            | I                   | -             | No                 | Not available on external balls. Read value is always 0.               |
| [1]            | I                   | TV_DETECT     | Yes <sup>(3)</sup> | Internal TV detection signal from the 10-bit composite/luma video DAC1 |
| [31:2]         | I/O                 | gpio_[63:34]  | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                    |
| <b>GPIO3</b>   |                     |               |                    |                                                                        |
| [31:0]         | I/O                 | gpio_[95:64]  | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                    |
| <b>GPIO4</b>   |                     |               |                    |                                                                        |
| [2:0]          | I/O                 | gpio_[98:96]  | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                    |
| [4:3]          | I                   | gpio_[100:99] | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                    |

<sup>(1)</sup> I = Input; O = Output

<sup>(2)</sup> Configuration mode 4. See [Chapter 13, System Control Module](#).

<sup>(3)</sup> Only when the PER power domain is active

**Table 25-5. GPIO Channel Description (continued)**

| Channel Number | Type <sup>(1)</sup> | Mapping        | Wake-Up Feature    | Comments                                                                        |
|----------------|---------------------|----------------|--------------------|---------------------------------------------------------------------------------|
| [8:5]          | I/O                 | gpio_[104:101] | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                             |
| [12:9]         | I                   | gpio_[108:105] | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                             |
| [15:13]        | I/O                 | gpio_[111:109] | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                             |
| [19:16]        | I                   | gpio_[115:112] | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                             |
| [23:20]        | I/O                 | gpio_[119:116] | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                             |
| [30:24]        | I/O                 | gpio_[126:120] | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                             |
| [31]           | I/O                 | gpio_127       | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                             |
|                | I                   | TSHUT          | Yes <sup>(3)</sup> | Internal TSHUT signal from the BANDGAP module for the SRAMs LDOs <sup>(4)</sup> |
| <b>GPIO5</b>   |                     |                |                    |                                                                                 |
| [31:0]         | I/O                 | gpio_[159:128] | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                             |
| <b>GPIO6</b>   |                     |                |                    |                                                                                 |
| [26:0]         | I/O                 | gpio_[186:160] | Yes <sup>(3)</sup> | GPIO <sup>(2)</sup>                                                             |
| [27]           | I                   | -              | No                 | Not available on external balls. Read value is always 0.                        |
| [31:28]        | I/O                 | gpio_[191:188] | Yes <sup>(5)</sup> | GPIO <sup>(6)</sup>                                                             |

<sup>(4)</sup> All configuration modes except configuration mode 4. See [Chapter 13, System Control Module](#).

<sup>(5)</sup> Only when the PER power domain is active

<sup>(6)</sup> Configuration mode 4. See [Chapter 13, System Control Module](#).

---

**NOTE:** The thermal shutdown comparator output signal (TSHUT) is an output from the BANDGAP module. This signal is low during normal operation and goes high during a thermal shutdown event. When channel 31 of GPIO4 is not connected to a ball of the device (the corresponding pin is configured in a mode different from the configuration mode 4; for more information about pin configuration see [Chapter 13, System Control Module](#)), TSHUT is connected to channel 31 of GPIO4, and an interrupt can be generated when a low-to-high transition occurs on TSHUT whether or not the interrupt generation for channel 31 of GPIO4 is correctly configured.

---

## 25.4 General-Purpose Interface Functional Description

[Figure 25-5](#) shows the general-purpose interface description.

**Figure 25-5. General-Purpose Interface Description**



[Figure 25-5](#) details GPIOs in the general-purpose interface block diagram with their configuration registers and their main functional paths:

- The synchronous path (for active mode operation) used to generate a synchronous interrupt request on expected event detection on any input GPIO; the synchronous interrupt request lines 1 and 2 are active based on their respective interrupt-enable 1 and 2 registers (`GPIOi.GPIO_IRQENABLE1` and `GPIOi.GPIO_IRQENABLE2`). See [Figure 25-6](#).

**Figure 25-6. Synchronous Path**



- The asynchronous path (for idle mode operation) used to generate an asynchronous wake-up request on the expected edge detection on any input GPIO; the asynchronous wake-up request line is active based on the wakeup-enable register. See [Figure 25-7](#).

**Figure 25-7. Asynchronous Path**

- The blocks handling the internal clock (clock gating) and managing the sleep mode request/acknowledge protocol (enabling the synchronous path in active mode and the asynchronous path in idle mode).

## 25.4.1 Operational Description

### 25.4.1.1 Interrupt and Wake-Up Features

#### 25.4.1.1.1 Synchronous Path: Interrupt Request Generation

The general-purpose interface has 12 interrupt lines (two interrupt lines per GPIO module instance). The 12 interrupt signals are GPIOi\_MPU\_IRQ (used by the MPU subsystem) and GPIOi\_IVA2\_IRQ (used by the IVA2.2 subsystem), where  $i = 1, 2, 3, 4, 5$ , and 6.

Synchronous interrupt requests from each channel are processed by two identical interrupt generation submodules used independently by the IVA2.2 subsystem and the MPU subsystem. Each submodule controls its own synchronous interrupt request line and has its own interrupt-enable (GPIOi.GPIO IRQENABLE1 or GPIOi.GPIO IRQENABLE2) and interrupt-status (GPIOi.GPIO IRQSTATUS1 or GPIOi.GPIO IRQSTATUS2) registers. The interrupt-enable register selects the channel(s) considered for the interrupt request generation, and the interrupt-status register determines which channel(s) activate the interrupt request. Event detection on GPIO channels is reflected in the interrupt-status registers independent of the content of the interrupt-enable registers.

In active mode, when the GPIO configuration registers are set to enable the interrupt generation (see [Section 25.5.3, Interrupt and Wakeup](#)), a synchronous path samples the transitions and levels on the input GPIO with the internally gated interface clock (see [Section 25.3.1.1.4.4, Module Power Saving](#)). When an event matches the programmed settings (see [Section 25.5.3, Interrupt and Wakeup](#)), the corresponding bit in the interrupt-status register is set to 1 and, on the following interface clock cycle, the interrupt lines 1 and/or 2 are activated (depending on the interrupt-enable registers).

Because of the sampling operation, the minimum pulse width on the input GPIO to trigger a synchronous interrupt request is two times the internally gated interface clock period (the internally gated interface clock period equals N times the interface clock period; see [Section 25.3.1.1.4.4, Module Power Saving](#)). This minimum pulse width must be met before and after any expected level transition detection. For level detection, the selected level must be stable for at least two times the internally-gated interface clock period to trigger a synchronous interrupt.

Because the module is synchronous, latency is minimal between the expected event occurrence and the activation of the interrupt line(s). This latency must not exceed four internally gated interface clock cycles plus one interface clock cycle when the debounce feature is not used.

When the debounce feature is active, the latency depends on the value of the debouncing time register (GPIOi.GPIO\_DEBOUNCINGTIME) (see [Section 25.5.5, Debouncing Time](#)) and is less than three internally gated interface clock cycles plus two interface clock cycle, plus GPIOi.GPIO\_DEBOUNCINGTIME register value debounce clock cycles plus three debounce clock cycles.

Synchronous interrupt request line 1 is mapped on the MPU INTC.

Synchronous interrupt request line 2 is mapped on the IVA2.2 INTC.

[Figure 25-8](#) shows an overview of the interrupt request generation.

**Figure 25-8. Interrupt Request Generation**



#### 25.4.1.1.2 Asynchronous Path: Wake-Up Request Generation

The general-purpose interface has six wake-up lines (one wake-up line per GPIO module instance) connected to the PRCM module.

Asynchronous wake-up requests from input channels are merged to issue one wake-up signal to the system per GPIO module. The wakeup-enable register (`GPIOi.GPIO_WAKEUPENABLE`) selects the channel(s) considered for the wake-up request generation. The asynchronous wake-up request is reflected into the synchronous interrupt-status registers (`GPIOi.GPIO_IRQSTATUS1` and `GPIOi.GPIO_IRQSTATUS2`).

In idle mode (the interface clock is shut down and the GPIO configuration registers are programmed; see [Section 25.5.3, Interrupt and Wakeup](#)), an asynchronous path detects the expected transition(s) on a GPIO input (based on register programming) and activates an asynchronous wake-up request by the sideband signal (`GPIOi_SWAKEUP`, where  $i = 1, 2, 3, 4, 5$ , and  $6$ ), if the wakeup-enable register is set.

When the system is awakened, the interface clock is restarted and synchronously set to 1 based on the input GPIO pin triggering the wake-up request and the corresponding bit in the interrupt-status registers (`GPIOi.GPIO_IRQSTATUS1` and `GPIOi.GPIO_IRQSTATUS2`). On the following internal clock cycle, the interrupt lines 1 and/or 2 are active (active low) when the corresponding bits are set in the interrupt-enable registers (`GPIOi.GPIO_IRQENABLE1` and `GPIOi.GPIO_IRQENABLE2`).

**NOTE:** When debouncing is not enabled, a minimum input pulse width does not trigger the wake-up request because there is no sampling operation.

When debouncing is enabled, the minimum pulse width is set by the specified debouncing time.

The `GPIOi.GPIO_SYSCONFIG[2] ENAWAKEUP` bit enables or disables the GPIO wake-up feature globally. If the bit is 0, the wakeup-enable register (`GPIOi.GPIO_WAKEUPENABLE`) has no effect.

Figure 25-9 shows an overview of the wake-up request generation.

**Figure 25-9. Wake-Up Request Generation**



#### 25.4.1.1.3 Interrupt (or Wake-Up) Line Release

When the host processor (the MPU and/or IVA2.2 subsystem in the device) receives an interrupt request issued by GPIO, it reads the corresponding interrupt-status register (GPIO<sub>i</sub>.[GPIO\\_IRQSTATUS1](#) or GPIO<sub>i</sub>.[GPIO\\_IRQSTATUS2](#)) to determine which GPIO input triggered the interrupt (or the wake-up request).

After servicing the interrupt (or acknowledging the wake-up request), the processor resets the status bit and releases the interrupt line by writing 1 in the corresponding bit of the interrupt-status register. If there is still a pending interrupt request to serve (all bits in the interrupt-status register that are not masked by the interrupt-enable register are not cleared), the interrupt line is reasserted.

---

**NOTE:** The status bit must be reset to re-enter idle mode.

---

## 25.5 General-Purpose Interface Basic Programming Model

### 25.5.1 Power Saving by Grouping the Edge/Level Detection

Each GPIO module implements four gated clocks used by the edge/level detection logic to save power. Each group of eight input GPIO pins generates a separate enable signal depending on the edge/level detection register setting (because the input is 32 bits, four groups of eight inputs are defined for each GPIO module). If a group requires no edge/level detection, then the corresponding clock is gated (cut off). Grouping the edge/level enable can save the power consumption of the module as described in the following example.

If any of the following registers

- `GPIOi.GPIO_LEVELDETECT0`
- `GPIOi.GPIO_LEVELDETECT1`
- `GPIOi.GPIO_RISINGDETECT`
- `GPIOi.GPIO_FALLINGDETECT`

are set to 0x01 01 01 01, all clocks are active (power consumption is high). If any of these registers are set to 0x00 00 00 FF, only one clock is active (power saving).

---

**NOTE:** When the clocks are enabled by writing to the `GPIOi.GPIO_LEVELDETECT0`, `GPIOi.GPIO_LEVELDETECT1`, `GPIOi.GPIO_RISINGDETECT`, and `GPIOi.GPIO_FALLINGDETECT` registers, the detection starts after five clock cycles. This period is required to clean the synchronization edge/level detection pipeline.

The mechanism is independent of each clock group. If the clock was started before and a new setting is performed, the following is recommended: First, set the new detection required; second, disable the previous setting (if necessary). In this way, the corresponding clock is not gated and the detection starts immediately.

---

### 25.5.2 Set and Clear Instructions

#### 25.5.2.1 Description

GPIO implements the set-and-clear protocol register update for the `GPIOi.GPIO_DATAOUT`, `GPIOi.GPIO_IRQENABLE1`, `GPIOi.GPIO_IRQENABLE2`, and `GPIOi.GPIO_WAKEUPENABLE` registers. This protocol is an alternative to the atomic test and set operations and consists of writing operations at dedicated addresses (one address for setting bit[s] and one address for clearing bit[s]). The data to write is 1 at bit position(s) to clear (or to set) and 0 at unaffected bit(s). Registers can be accessed in two ways:

- Standard: Full register read and write operations at the primary register address
- Set and clear (recommended): Separate addresses are provided to set (and clear) bits in registers. Writing 1 at these addresses sets (or clears) the corresponding bit into the equivalent register; writing a 0 has no effect.

Therefore, for these registers, three addresses are defined for one unique physical register. Reading these addresses has the same effect and returns the register value.

#### 25.5.2.2 Clear Instruction

##### 25.5.2.2.1 Clear Register Addresses

Clear interrupt-enable registers (`GPIOi.GPIO_CLEARIRQENABLE1` and `GPIOi.GPIO_CLEARIRQENABLE2`).

A write operation in the clear interrupt-enable1 (or enable2) register clears the corresponding bit in the interrupt-enable1 (or enable2) register when the written bit is 1; a written bit at 0 has no effect.

A read of the clear interrupt-enable1 (or enable2) register returns the value of the interrupt-enable1 (or enable2) register.

Clear wakeup-enable register (`GPIOi.GPIO_CLEARWKUENA`).

A write operation in the clear wakeup-enable register clears the corresponding bit in the wakeup-enable register when the written bit is 1; a written bit at 0 has no effect.

A read of the clear wakeup-enable register returns the value of the wakeup-enable register.

Clear data output register (GPIOi.GPIO\_CLEARDATAOUT).

A write operation in the clear data output register clears the corresponding bit in the data output register when the written bit is 1; a written bit at 0 has no effect.

A read of the clear data output register returns the value of the data output register.

#### **25.5.2.2.2 Clear Instruction Example**

Assume the data output register (or one of the interrupt/wakeup-enable registers) contains the binary value 0b0000 0001 0000 0001 and you want to clear bit 0.

With the clear instruction feature, write 0b0000 0000 0000 0001 at the address of the clear data output register (or at the address of the clear interrupt/wakeup-enable register). After this write operation, a reading of the data output register (or the interrupt/wakeup-enable register) returns 0b0000 0001 0000 0000; bit 0 is cleared.

**NOTE:** Although the general-purpose interface registers are 32 bits wide, only the less-significant 16 bits are represented in this example.

Figure 25-10 shows an example of a clear instruction.

**Figure 25-10. Write @GPIO\_CLEARDATAOUT Register Example**



### 25.5.2.3 Set Instruction

### **25.5.2.3.1 Set Register Addresses**

Set interrupt-enable registers (GPIOi.GPIO\_SETIRQENABLE1 and GPIOi.GPIO\_SETIRQENABLE2).

A write operation in the set interrupt-enable1 (or enable2) register sets the corresponding bit in the interrupt-enable1 (or enable2) register when the written bit is 1; a written bit at 0 has no effect.

A read of the set interrupt-enable1 (or enable2) register returns the value of the interrupt-enable1 (or enable2) register.

Set wakeup-enable register (GPIOi.GPIO\_SETWKUENA).

A write operation in the set wakeup-enable register sets the corresponding bit in the wakeup-enable register when the written bit is 1; a written bit at 0 has no effect.

A read of the set wakeup-enable register returns the value of the wakeup-enable register.

Set data output register (GPIOi.GPIO\_SETDATAOUT).

A write operation in the set data output register sets the corresponding bit in the data output register when the written bit is 1; a written bit at 0 has no effect.

A read of the set data output register returns the value of the data output register.

### 25.5.2.3.2 Set Instruction Example

Assume the interrupt-enable1 (or enable2) register (or the data output register) contains the binary value, 0b0000 0001 0000 0000, and you want to set bits 15, 3, 2, and 1.

With the set instruction feature, write 0b1000 0000 0000 1110 at the address of the set interrupt-enable1 (or enable2) register (or at the address of the set data output register). After this write operation, a reading of the interrupt-enable1 (or enable2) register (or the data output register) returns 0b1000 0001 0000 1110; bits 15, 3, 2, and 1 are set.

**NOTE:** Although the general-purpose interface registers are 32 bits wide, only the less-significant 16 bits are represented in this example.

Figure 25-11 shows an example of a set instruction.

**Figure 25-11. Write @GPIO\_SETIRQENABLEEx Register Example**



The set wakeup-enable register offers the same feature with the wakeup-enable register.

### 25.5.3 Interrupt and Wakeup

#### 25.5.3.1 Involved Configuration Registers

- Interrupt-enable registers (GPIOi.GPIO IRQENABLE1 and GPIOi.GPIO IRQENABLE2)

The interrupt-enable1 (or interrupt-enable2) register allows masking of the expected transition on input GPIO to prevent the generation of an interrupt request on line1 (or line2). The interrupt-enable registers are programmed synchronously with the interface clock.

These registers can be accessed with direct read/write operations or using the alternate set-and-clear protocol register update feature. This feature enables to set or clear specific bits of these registers with a single write access to the corresponding set interrupt-enable1 (or interrupt-enable2) registers (or to the clear interrupt-enable1 [or interrupt-enable2] registers) address (see [Section 25.5.2, Set and Clear Instructions](#)).

- Wakeup-enable register (GPIOi.GPIO WAKEUPENABLE)

The wakeup-enable register allows masking of the expected transition on input GPIO to prevent the generation of a wake-up request. The wakeup-enable register is programmed synchronously with the interface clock before any idle mode request coming from the host processor.

This register can be accessed with direct read/write operations or by using the alternate set-and-clear protocol register update feature. This feature allows setting or clearing specific bits of this register with a single write access to the set wakeup-enable register (or to the clear wakeup-enable register) address (see [Section 25.5.2, Set and Clear Instructions](#)).

**NOTE:** There must be a correlation between wakeup-enable and interrupt-enable registers. If a GPIO pin has a wakeup configured on it, it should also have the corresponding interrupt enabled (on one of the two interrupt lines). Otherwise, it is possible to have a wake-up event, but after exiting the Idle mode, no interrupt is generated, thus the corresponding bit from the interrupt-status register is not cleared, and the module does not acknowledge a future IDLE request.

- Interrupt status registers (GPIOi.GPIO\_IRQSTATUS1 and GPIOi.GPIO\_IRQSTATUS2)

The interrupt-status1 (or interrupt-status2) register determines which of the input GPIO pins triggered the interrupt line1 (or interrupt line2) request (or the wake-up line).

When a bit in this register is set to 1, it indicates that the corresponding GPIO pin is requesting the interrupt (or the wakeup). To reset a bit in this register, write 1 to the appropriate bit. However, an interrupt cannot be generated by writing 1 to the interrupt-status1 (or interrupt-status2) register.

If 0 is written to a bit in this register, the value remains unchanged. The interrupt-status1 (or interrupt-status2) register is synchronous with the interface clock. In idle mode, the event is detected through an asynchronous path, and the corresponding bit in the interrupt-status1 and interrupt-status2 registers are set when GPIO is awake.

---

**NOTE:** The wake-up capabilities of GPIO2 to GPIO6 are operational only when the PER power domain is active.

---

### 25.5.3.2 Description

To generate interrupt request to a host processor (the MPU and/or digital signal processor [DSP] subsystem in the device) at a defined event (level or edge logic transition) occurring on a GPIO pin (interrupt source), the GPIO configuration registers must be programmed as follows:

1. The GPIO channel must be configured as input by the output-enable register (write 1 to the corresponding bit of the GPIOi.GPIO\_OE register).
2. The expected event(s) on the GPIO input to trigger the interrupt request must be selected in the low-level interrupt-enable register (write 1 or 0 to the corresponding bit of GPIOi.GPIO\_LEVELDETECT0), and/or high-level interrupt-enable register (write 1 or 0 to the corresponding bit of GPIOi.GPIO\_LEVELDETECT1), and/or rising-edge interrupt/wakeup-enable register (write 1 or 0 to the corresponding bit of GPIOi.GPIO\_RISINGDETECT), and/or falling edge interrupt/wakeup-enable register (write 1 or 0 to the corresponding bit of GPIOi.GPIO\_FALLINGDETECT).

---

**NOTE:** Interrupt generation on both edges on one input is configured by setting the corresponding bit to 1 in the rising detect enabling register (GPIOi.GPIO\_RISINGDETECT) and falling detect enabling register (GPIOi.GPIO\_FALLINGDETECT) along with the interrupt-enable by setting the corresponding bit to 1 in one or both interrupt-enable registers (GPIOi.GPIO\_IRQENABLE1 and GPIOi.GPIO\_IRQENABLE2).

Simultaneous enabling of high-level and low-level detections for one given pin creates a constant-interrupt generator.

3. Interrupts from the GPIO channel must be enabled in the interrupt 1 enable register (write 1 to the corresponding bit of the GPIOi.GPIO\_IRQENABLE1 register) and/or the interrupt 2 enable register (write 1 to the corresponding bit of the GPIOi.GPIO\_IRQENABLE2 register).

To configure a GPIO module to send a wake-up request to the PRCM module at a defined event (logic transition) occurring on a GPIO pin (wake-up source), the GPIO configuration registers must be programmed as follows:

1. The GPIO pin must be configured as input by the output-enable register (write 1 to the corresponding bit of the GPIOi.GPIO\_OE register).
2. The expected event(s) on the GPIO input to trigger the wake-up request must be selected in the rising-edge interrupt/wakeup-enable register (write 1 or 0 to the corresponding bit of GPIOi.GPIO\_RISINGDETECT) and/or falling-edge interrupt/wakeup-enable register (write 1 or 0 to the corresponding bit of GPIOi.GPIO\_FALLINGDETECT). The wake-up request can be generated only on edge transitions.
3. The GPIO channel must be enabled in the wakeup-enable register (write 1 to the corresponding bit of the GPIOi.GPIO\_WAKEUPENABLE register).
4. The wake-up request generation on the expected transition occurring on the GPIO input pins must enable the module (write 1 to the corresponding bit of the GPIOi.GPIO\_SYSConfig[2] ENAWAKEUP).

bit).

**CAUTION**

For each GPIO channel used, do not forget to configure the corresponding pad configuration registers in the system control module (SCM).

After servicing the interrupt, the status bit in the interrupt-status register (`GPIOi.GPIO_IRQSTATUS1` or `GPIOi.GPIO_IRQSTATUS2`) must be reset and the interrupt line released (by writing 1 in the corresponding bit of the interrupt-status register) before enabling an interrupt for the GPIO channel in the interrupt-enable register (`GPIOi.GPIO_IRQENABLE1` or `GPIOi.GPIO_IRQENABLE2`) to prevent the occurrence of unexpected interrupts when enabling an interrupt for the GPIO channel.

### 25.5.4 Data Input (Capture)/Output (Drive)

The output-enable register (`GPIOi.GPIO_OE`) controls the output/input capability for each pin. At reset, all the GPIO-related pins are configured as input and output capabilities are disabled. This register is not used within the module. Its only function is to carry the pads configuration.

When configured as an output (the desired bit reset in the `GPIOi.GPIO_OE` register), the value of the corresponding bit in the `GPIOi.GPIO_DATAOUT` register is driven on the corresponding GPIO pin. Data is written to the data output register synchronously with the interface clock. This register can be accessed with read/write operations or by using the alternate set-and-clear protocol register update feature. This feature lets you set or clear specific bits of this register with a single write access to the set output data register (`GPIOi.GPIO_SETDATAOUT`) or to the clear output data register (`GPIOi.GPIO_CLEARDATAOUT`) address (see [Section 25.5.2, Set and Clear Instructions](#)). If the application uses a pin as an output and does not want interrupt/wake-up generation from this pin, the application must properly configure the wakeup-enable (`GPIOi.GPIO_WAKEUPENABLE`) and the interrupt-enable (`GPIOi.GPIO_IRQENABLE1` and `GPIOi.GPIO_IRQENABLE2`) registers.

When configured as an input (the desired bit set to 1 in the `GPIOi.GPIO_OE` register), the state of the input can be read from the corresponding bit in the `GPIOi.GPIO_DATAIN` register. The input data is sampled synchronously with the interface clock and then captured in the data input register synchronously with the interface clock (see [Section 25.5.2, Set and Clear Instructions](#)). When the GPIO pin levels change, they are captured into this register after two interface clock cycles (the cycles required to synchronize and write data). If the application uses a pin as an input, the application must properly configure the wakeup-enable (`GPIOi.GPIO_WAKEUPENABLE`) and the interrupt-enable (`GPIOi.GPIO_IRQENABLE1` and `GPIOi.GPIO_IRQENABLE2`) registers to the interrupt and wake-up feature as needed.

## 25.5.5 Debouncing Time

To enable the debounce feature for a pin, the GPIO configuration registers must be programmed as follows:

1. The GPIO pin must be configured as input in the output-enable register (write 1 to the corresponding bit of the `GPIOi.GPIO_OE` register).
2. The debouncing time must be set in the debouncing time register (`GPIOi.GPIO_DEBOUNCINGTIME`).

The debouncing value register (`GPIOi.GPIO_DEBOUNCINGTIME`) is used to set the debouncing time for all input lines in GPIO. The value is global for all the ports of one GPIO module, so up to six different debouncing values are possible. The debounce cell is running with the debounce clock (32 kHz). This register represents the number of the clock cycle(s) (one cycle is 31 $\mu$ s long) to be used.

The following formula describes the required input stable time to be propagated to the debounced output:

Required input line stable = (`GPIOi.GPIO_DEBOUNCINGTIME[7:0]` DEBOUNCV<sub>AL</sub> bit field value + 1) x 0.031 ms.

where `GPIOi.GPIO_DEBOUNCINGTIME[7:0]` bit field DEBOUNCV<sub>AL</sub> value is from 0 to 255.

3. The debouncing feature must be enabled in the debouncing-enable register (write 1 to the corresponding bit of the `GPIOi.GPIO_DEBOUNCENABLE` register).

## 25.6 General-Purpose Interface Register Manual

This section summarizes the hardware interface for the GPIO product. Each module instance within the design is shown, together with the module register map and bit definitions for each bit field.

[Table 25-6](#) lists the base address and address space for GPIO instances.

**Table 25-6. Instance Summary**

| Module Name | Base Address | Size |
|-------------|--------------|------|
| GPIO1       | 0x4831 0000  | 4KB  |
| GPIO2       | 0x4905 0000  | 4KB  |
| GPIO3       | 0x4905 2000  | 4KB  |
| GPIO4       | 0x4905 4000  | 4KB  |
| GPIO5       | 0x4905 6000  | 4KB  |
| GPIO6       | 0x4905 8000  | 4KB  |

### 25.6.1 General-Purpose Interface Register Mapping Summary

All module registers are 8-, 16-, or 32-bit accessible through the L4 interconnect (little endian encoding). Access to registers is direct; no shadow registers are implemented.

[Table 25-7](#) through [Table 25-12](#) describe the GPIO register offset addresses.

**Table 25-7. GPIO1 Register Summary**

| Register Name        | Type | Register Width (Bits) | Address Offset | Physical Address |
|----------------------|------|-----------------------|----------------|------------------|
| GPIO_REVISION        | R    | 32                    | 0x000          | 0x4831 0000      |
| GPIO_SYSCONFIG       | RW   | 32                    | 0x010          | 0x4831 0010      |
| GPIO_SYSSTATUS       | R    | 32                    | 0x014          | 0x4831 0014      |
| GPIO_IRQSTATUS1      | RW   | 32                    | 0x018          | 0x4831 0018      |
| GPIO_IRQENABLE1      | RW   | 32                    | 0x01C          | 0x4831 001C      |
| GPIO_WAKEUPENABLE    | RW   | 32                    | 0x020          | 0x4831 0020      |
| GPIO_IRQSTATUS2      | RW   | 32                    | 0x028          | 0x4831 0028      |
| GPIO_IRQENABLE2      | RW   | 32                    | 0x02C          | 0x4831 002C      |
| GPIO_CTRL            | RW   | 32                    | 0x030          | 0x4831 0030      |
| GPIO_OE              | RW   | 32                    | 0x034          | 0x4831 0034      |
| GPIO_DATAIN          | R    | 32                    | 0x038          | 0x4831 0038      |
| GPIO_DATAOUT         | RW   | 32                    | 0x03C          | 0x4831 003C      |
| GPIO_LEVELDETECT0    | RW   | 32                    | 0x040          | 0x4831 0040      |
| GPIO_LEVELDETECT1    | RW   | 32                    | 0x044          | 0x4831 0044      |
| GPIO_RISINGDETECT    | RW   | 32                    | 0x048          | 0x4831 0048      |
| GPIO_FALLINGDETECT   | RW   | 32                    | 0x04C          | 0x4831 004C      |
| GPIO_DEBOUNCENABLE   | RW   | 32                    | 0x050          | 0x4831 0050      |
| GPIO_DEBOUNCINGTIME  | RW   | 32                    | 0x054          | 0x4831 0054      |
| GPIO_CLEARIRQENABLE1 | RW   | 32                    | 0x060          | 0x4831 0060      |
| GPIO_SETIRQENABLE1   | RW   | 32                    | 0x064          | 0x4831 0064      |
| GPIO_CLEARIRQENABLE2 | RW   | 32                    | 0x070          | 0x4831 0070      |
| GPIO_SETIRQENABLE2   | RW   | 32                    | 0x074          | 0x4831 0074      |
| GPIO_CLEARWKUENA     | RW   | 32                    | 0x080          | 0x4831 0080      |
| GPIO_SETWKUENA       | RW   | 32                    | 0x084          | 0x4831 0084      |
| GPIO_CLEARDATAOUT    | RW   | 32                    | 0x090          | 0x4831 0090      |
| GPIO_SETDATAOUT      | RW   | 32                    | 0x094          | 0x4831 0094      |

**Table 25-8. GPIO2 Register Summary**

| Register Name        | Type | Register Width (Bits) | Address Offset | Physical Address |
|----------------------|------|-----------------------|----------------|------------------|
| GPIO_REVISION        | R    | 32                    | 0x000          | 0x4905 0000      |
| GPIO_SYSCONFIG       | RW   | 32                    | 0x010          | 0x4905 0010      |
| GPIO_SYSSTATUS       | R    | 32                    | 0x014          | 0x4905 0014      |
| GPIO_IRQSTATUS1      | RW   | 32                    | 0x018          | 0x4905 0018      |
| GPIO_IRQENABLE1      | RW   | 32                    | 0x01C          | 0x4905 001C      |
| GPIO_WAKEUPENABLE    | RW   | 32                    | 0x020          | 0x4905 0020      |
| GPIO_IRQSTATUS2      | RW   | 32                    | 0x028          | 0x4905 0028      |
| GPIO_IRQENABLE2      | RW   | 32                    | 0x02C          | 0x4905 002C      |
| GPIO_CTRL            | RW   | 32                    | 0x030          | 0x4905 0030      |
| GPIO_OE              | RW   | 32                    | 0x034          | 0x4905 0034      |
| GPIO_DATAIN          | R    | 32                    | 0x038          | 0x4905 0038      |
| GPIO_DATAOUT         | RW   | 32                    | 0x03C          | 0x4905 003C      |
| GPIO_LEVELDETECT0    | RW   | 32                    | 0x040          | 0x4905 0040      |
| GPIO_LEVELDETECT1    | RW   | 32                    | 0x044          | 0x4905 0044      |
| GPIO_RISINGDETECT    | RW   | 32                    | 0x048          | 0x4905 0048      |
| GPIO_FALLINGDETECT   | RW   | 32                    | 0x04C          | 0x4905 004C      |
| GPIO_DEBOUNCENABLE   | RW   | 32                    | 0x050          | 0x4905 0050      |
| GPIO_DEBOUNCINGTIME  | RW   | 32                    | 0x054          | 0x4905 0054      |
| GPIO_CLEARIRQENABLE1 | RW   | 32                    | 0x060          | 0x4905 0060      |
| GPIO_SETIRQENABLE1   | RW   | 32                    | 0x064          | 0x4905 0064      |
| GPIO_CLEARIRQENABLE2 | RW   | 32                    | 0x070          | 0x4905 0070      |
| GPIO_SETIRQENABLE2   | RW   | 32                    | 0x074          | 0x4905 0074      |
| GPIO_CLEARWKUENA     | RW   | 32                    | 0x080          | 0x4905 0080      |
| GPIO_SETWKUENA       | RW   | 32                    | 0x084          | 0x4905 0084      |
| GPIO_CLEARDATAOUT    | RW   | 32                    | 0x090          | 0x4905 0090      |
| GPIO_SETDATAOUT      | RW   | 32                    | 0x094          | 0x4905 0094      |

**Table 25-9. GPIO3 Register Summary**

| Register Name      | Type | Register Width (Bits) | Address Offset | Physical Address |
|--------------------|------|-----------------------|----------------|------------------|
| GPIO_REVISION      | R    | 32                    | 0x000          | 0x4905 2000      |
| GPIO_SYSCONFIG     | RW   | 32                    | 0x010          | 0x4905 2010      |
| GPIO_SYSSTATUS     | R    | 32                    | 0x014          | 0x4905 2014      |
| GPIO_IRQSTATUS1    | RW   | 32                    | 0x018          | 0x4905 2018      |
| GPIO_IRQENABLE1    | RW   | 32                    | 0x01C          | 0x4905 201C      |
| GPIO_WAKEUPENABLE  | RW   | 32                    | 0x020          | 0x4905 2020      |
| GPIO_IRQSTATUS2    | RW   | 32                    | 0x028          | 0x4905 2028      |
| GPIO_IRQENABLE2    | RW   | 32                    | 0x02C          | 0x4905 202C      |
| GPIO_CTRL          | RW   | 32                    | 0x030          | 0x4905 2030      |
| GPIO_OE            | RW   | 32                    | 0x034          | 0x4905 2034      |
| GPIO_DATAIN        | R    | 32                    | 0x038          | 0x4905 2038      |
| GPIO_DATAOUT       | RW   | 32                    | 0x03C          | 0x4905 203C      |
| GPIO_LEVELDETECT0  | RW   | 32                    | 0x040          | 0x4905 2040      |
| GPIO_LEVELDETECT1  | RW   | 32                    | 0x044          | 0x4905 2044      |
| GPIO_RISINGDETECT  | RW   | 32                    | 0x048          | 0x4905 2048      |
| GPIO_FALLINGDETECT | RW   | 32                    | 0x04C          | 0x4905 204C      |

**Table 25-9. GPIO3 Register Summary (continued)**

| Register Name        | Type | Register Width (Bits) | Address Offset | Physical Address |
|----------------------|------|-----------------------|----------------|------------------|
| GPIO_DEBOUNCENABLE   | RW   | 32                    | 0x050          | 0x4905 2050      |
| GPIO_DEBOUNCINGTIME  | RW   | 32                    | 0x054          | 0x4905 2054      |
| GPIO_CLEARIRQENABLE1 | RW   | 32                    | 0x060          | 0x4905 2060      |
| GPIO_SETIRQENABLE1   | RW   | 32                    | 0x064          | 0x4905 2064      |
| GPIO_CLEARIRQENABLE2 | RW   | 32                    | 0x070          | 0x4905 2070      |
| GPIO_SETIRQENABLE2   | RW   | 32                    | 0x074          | 0x4905 2074      |
| GPIO_CLEARWKUENA     | RW   | 32                    | 0x080          | 0x4905 2080      |
| GPIO_SETWKUENA       | RW   | 32                    | 0x084          | 0x4905 2084      |
| GPIO_CLEARDATAOUT    | RW   | 32                    | 0x090          | 0x4905 2090      |
| GPIO_SETDATAOUT      | RW   | 32                    | 0x094          | 0x4905 2094      |

**Table 25-10. GPIO4 Register Summary**

| Register Name        | Type | Register Width (Bits) | Address Offset | Physical Address |
|----------------------|------|-----------------------|----------------|------------------|
| GPIO_REVISION        | R    | 32                    | 0x000          | 0x4905 4000      |
| GPIO_SYSCONFIG       | RW   | 32                    | 0x010          | 0x4905 4010      |
| GPIO_SYSSTATUS       | R    | 32                    | 0x014          | 0x4905 4014      |
| GPIO_IRQSTATUS1      | RW   | 32                    | 0x018          | 0x4905 4018      |
| GPIO_IRQENABLE1      | RW   | 32                    | 0x01C          | 0x4905 401C      |
| GPIO_WAKEUPENABLE    | RW   | 32                    | 0x020          | 0x4905 4020      |
| GPIO_IRQSTATUS2      | RW   | 32                    | 0x028          | 0x4905 4028      |
| GPIO_IRQENABLE2      | RW   | 32                    | 0x02C          | 0x4905 402C      |
| GPIO_CTRL            | RW   | 32                    | 0x030          | 0x4905 4030      |
| GPIO_OE              | RW   | 32                    | 0x034          | 0x4905 4034      |
| GPIO_DATAIN          | R    | 32                    | 0x038          | 0x4905 4038      |
| GPIO_DATAOUT         | RW   | 32                    | 0x03C          | 0x4905 403C      |
| GPIO_LEVELDETECT0    | RW   | 32                    | 0x040          | 0x4905 4040      |
| GPIO_LEVELDETECT1    | RW   | 32                    | 0x044          | 0x4905 4044      |
| GPIO_RISINGDETECT    | RW   | 32                    | 0x048          | 0x4905 4048      |
| GPIO_FALLINGDETECT   | RW   | 32                    | 0x04C          | 0x4905 404C      |
| GPIO_DEBOUNCENABLE   | RW   | 32                    | 0x050          | 0x4905 4050      |
| GPIO_DEBOUNCINGTIME  | RW   | 32                    | 0x054          | 0x4905 4054      |
| GPIO_CLEARIRQENABLE1 | RW   | 32                    | 0x060          | 0x4905 4060      |
| GPIO_SETIRQENABLE1   | RW   | 32                    | 0x064          | 0x4905 4064      |
| GPIO_CLEARIRQENABLE2 | RW   | 32                    | 0x070          | 0x4905 4070      |
| GPIO_SETIRQENABLE2   | RW   | 32                    | 0x074          | 0x4905 4074      |
| GPIO_CLEARWKUENA     | RW   | 32                    | 0x080          | 0x4905 4080      |
| GPIO_SETWKUENA       | RW   | 32                    | 0x084          | 0x4905 4084      |
| GPIO_CLEARDATAOUT    | RW   | 32                    | 0x090          | 0x4905 4090      |
| GPIO_SETDATAOUT      | RW   | 32                    | 0x094          | 0x4905 4094      |

**Table 25-11. GPIO5 Register Summary**

| Register Name  | Type | Register Width (Bits) | Address Offset | Physical Address |
|----------------|------|-----------------------|----------------|------------------|
| GPIO_REVISION  | R    | 32                    | 0x000          | 0x4905 6000      |
| GPIO_SYSCONFIG | RW   | 32                    | 0x010          | 0x4905 6010      |

**Table 25-11. GPIO5 Register Summary (continued)**

| Register Name        | Type | Register Width (Bits) | Address Offset | Physical Address |
|----------------------|------|-----------------------|----------------|------------------|
| GPIO_SYSSTATUS       | R    | 32                    | 0x014          | 0x4905 6014      |
| GPIO_IRQSTATUS1      | RW   | 32                    | 0x018          | 0x4905 6018      |
| GPIO_IRQENABLE1      | RW   | 32                    | 0x01C          | 0x4905 601C      |
| GPIO_WAKEUPENABLE    | RW   | 32                    | 0x020          | 0x4905 6020      |
| GPIO_IRQSTATUS2      | RW   | 32                    | 0x028          | 0x4905 6028      |
| GPIO_IRQENABLE2      | RW   | 32                    | 0x02C          | 0x4905 602C      |
| GPIO_CTRL            | RW   | 32                    | 0x030          | 0x4905 6030      |
| GPIO_OE              | RW   | 32                    | 0x034          | 0x4905 6034      |
| GPIO_DATAIN          | R    | 32                    | 0x038          | 0x4905 6038      |
| GPIO_DATAOUT         | RW   | 32                    | 0x03C          | 0x4905 603C      |
| GPIO_LEVELDETECT0    | RW   | 32                    | 0x040          | 0x4905 6040      |
| GPIO_LEVELDETECT1    | RW   | 32                    | 0x044          | 0x4905 6044      |
| GPIO_RISINGDETECT    | RW   | 32                    | 0x048          | 0x4905 6048      |
| GPIO_FALLINGDETECT   | RW   | 32                    | 0x04C          | 0x4905 604C      |
| GPIO_DEBOUNCENABLE   | RW   | 32                    | 0x050          | 0x4905 6050      |
| GPIO_DEBOUNCINGTIME  | RW   | 32                    | 0x054          | 0x4905 6054      |
| GPIO_CLEARIRQENABLE1 | RW   | 32                    | 0x060          | 0x4905 6060      |
| GPIO_SETIRQENABLE1   | RW   | 32                    | 0x064          | 0x4905 6064      |
| GPIO_CLEARIRQENABLE2 | RW   | 32                    | 0x070          | 0x4905 6070      |
| GPIO_SETIRQENABLE2   | RW   | 32                    | 0x074          | 0x4905 6074      |
| GPIO_CLEARWKUENA     | RW   | 32                    | 0x080          | 0x4905 6080      |
| GPIO_SETWKUENA       | RW   | 32                    | 0x084          | 0x4905 6084      |
| GPIO_CLEARDATAOUT    | RW   | 32                    | 0x090          | 0x4905 6090      |
| GPIO_SETDATAOUT      | RW   | 32                    | 0x094          | 0x4905 6094      |

**Table 25-12. GPIO6 Register Summary**

| Register Name       | Type | Register Width (Bits) | Address Offset | Physical Address |
|---------------------|------|-----------------------|----------------|------------------|
| GPIO_REVISION       | R    | 32                    | 0x000          | 0x4905 8000      |
| GPIO_SYSCONFIG      | RW   | 32                    | 0x010          | 0x4905 8010      |
| GPIO_SYSSTATUS      | R    | 32                    | 0x014          | 0x4905 8014      |
| GPIO_IRQSTATUS1     | RW   | 32                    | 0x018          | 0x4905 8018      |
| GPIO_IRQENABLE1     | RW   | 32                    | 0x01C          | 0x4905 801C      |
| GPIO_WAKEUPENABLE   | RW   | 32                    | 0x020          | 0x4905 8020      |
| GPIO_IRQSTATUS2     | RW   | 32                    | 0x028          | 0x4905 8028      |
| GPIO_IRQENABLE2     | RW   | 32                    | 0x02C          | 0x4905 802C      |
| GPIO_CTRL           | RW   | 32                    | 0x030          | 0x4905 8030      |
| GPIO_OE             | RW   | 32                    | 0x034          | 0x4905 8034      |
| GPIO_DATAIN         | R    | 32                    | 0x038          | 0x4905 8038      |
| GPIO_DATAOUT        | RW   | 32                    | 0x03C          | 0x4905 803C      |
| GPIO_LEVELDETECT0   | RW   | 32                    | 0x040          | 0x4905 8040      |
| GPIO_LEVELDETECT1   | RW   | 32                    | 0x044          | 0x4905 8044      |
| GPIO_RISINGDETECT   | RW   | 32                    | 0x048          | 0x4905 8048      |
| GPIO_FALLINGDETECT  | RW   | 32                    | 0x04C          | 0x4905 804C      |
| GPIO_DEBOUNCENABLE  | RW   | 32                    | 0x050          | 0x4905 8050      |
| GPIO_DEBOUNCINGTIME | RW   | 32                    | 0x054          | 0x4905 8054      |

**Table 25-12. GPIO6 Register Summary (continued)**

| Register Name        | Type | Register Width (Bits) | Address Offset | Physical Address |
|----------------------|------|-----------------------|----------------|------------------|
| GPIO_CLEARIRQENABLE1 | RW   | 32                    | 0x060          | 0x4905 8060      |
| GPIO_SETIRQENABLE1   | RW   | 32                    | 0x064          | 0x4905 8064      |
| GPIO_CLEARIRQENABLE2 | RW   | 32                    | 0x070          | 0x4905 8070      |
| GPIO_SETIRQENABLE2   | RW   | 32                    | 0x074          | 0x4905 8074      |
| GPIO_CLEARWKUENA     | RW   | 32                    | 0x080          | 0x4905 8080      |
| GPIO_SETWKUENA       | RW   | 32                    | 0x084          | 0x4905 8084      |
| GPIO_CLEARDATAOUT    | RW   | 32                    | 0x090          | 0x4905 8090      |
| GPIO_SETDATAOUT      | RW   | 32                    | 0x094          | 0x4905 8094      |

The write latency for all the R/W registers is immediate (with respect to the interface clock).

---

**NOTE:** When two write accesses in the GPIOi.GPIO\_DEBOUNCINGTIME register are performed in less than two debounce clock cycles (32 kHz) plus four interface clock cycles, the first write access latency is immediate, but the second write access is acknowledged only after this interval ends.

---

In the register descriptions in this section, when one single register carries an individual configuration or setting for all the channels of the module, 1 bit in the register is dedicated to each channel. The bit and the corresponding channel are identified with the same number: Bit 0 refers to channel 0, bit 1 refers to channel 1, and so on, up to 31.

### 25.6.2 Register Descriptions

Table 25-13 through Table 25-63 describe the register bits.

**Table 25-13. GPIO\_REVISON**

|                |                                              |                  |             |          |       |
|----------------|----------------------------------------------|------------------|-------------|----------|-------|
| Address Offset | 0x000                                        | Physical Address | 0x4831 0000 | Instance | GPIO1 |
|                |                                              |                  | 0x4905 0000 |          | GPIO2 |
|                |                                              |                  | 0x4905 2000 |          | GPIO3 |
|                |                                              |                  | 0x4905 4000 |          | GPIO4 |
|                |                                              |                  | 0x4905 6000 |          | GPIO5 |
|                |                                              |                  | 0x4905 8000 |          | GPIO6 |
| Description    | This register contains the IP revision code. |                  |             |          |       |
| Type           | R                                            |                  |             |          |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------------|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | GPIOREVISION |   |   |   |   |   |   |

| Bits | Field Name   | Description                                                                                         | Type | Reset              |
|------|--------------|-----------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | RESERVED     | Read returns 0                                                                                      | R    | 0x000000           |
| 7:0  | GPIOREVISION | IP revision<br>[7:4] Major revision<br>[3:0] Minor revision<br>Examples: 0x10 for 1.0, 0x21 for 2.1 | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 25-14. Register Call Summary for Register GPIO\_REVISION**

General-Purpose Interface Register Manual

- General-Purpose Interface Register Mapping Summary: [0] [1] [2] [3] [4] [5]

**Table 25-15. GPIO\_SYS CONFIG**

|                       |                                                                       |                         |             |                 |       |
|-----------------------|-----------------------------------------------------------------------|-------------------------|-------------|-----------------|-------|
| <b>Address Offset</b> | 0x010                                                                 | <b>Physical Address</b> | 0x4831 0010 | <b>Instance</b> | GPIO1 |
|                       |                                                                       |                         | 0x4905 0010 |                 | GPIO2 |
|                       |                                                                       |                         | 0x4905 2010 |                 | GPIO3 |
|                       |                                                                       |                         | 0x4905 4010 |                 | GPIO4 |
|                       |                                                                       |                         | 0x4905 6010 |                 | GPIO5 |
|                       |                                                                       |                         | 0x4905 8010 |                 | GPIO6 |
| <b>Description</b>    | This register controls the various parameters of the L4 interconnect. |                         |             |                 |       |
| <b>Type</b>           | RW                                                                    |                         |             |                 |       |



| Bits | Field Name | Description                                                                                                                                                                                                                                                                                                          | Type | Reset     |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | RESERVED   | Write 0s for future compatibility. Read returns 0                                                                                                                                                                                                                                                                    | RW   | 0x0000000 |
| 4:3  | IDLEMODE   | Power Management, Req/Ack control<br><br>0x0: Force-idle. An idle request is acknowledged unconditionally<br><br>0x1: No-idle. An idle request is never acknowledged<br><br>0x2: Smart-idle. Acknowledgment to an idle request is given based on the internal activity of the module<br><br>0x3: Reserved do not use | RW   | 0x0       |
| 2    | ENAWAKEUP  | Wake-up capability enabled/disabled<br><br>0x0: Wakeup disable<br><br>0x1: Wakeup enable                                                                                                                                                                                                                             | RW   | 0x0       |
| 1    | SOFTRESET  | Software reset. This bit is automatically reset by the hardware. During reads, it always returns 0.<br><br>0x0: Normal mode<br><br>0x1: The module is reset                                                                                                                                                          | RW   | 0x0       |
| 0    | AUTOIDLE   | Internal interface clock gating strategy<br><br>0x0: Interface clock is free-running<br><br>0x1: Automatic interface clock gating strategy is applied, based on the L4 interconnect activity                                                                                                                         | RW   | 0x0       |

**Table 25-16. Register Call Summary for Register GPIO\_SYS CONFIG**

General-Purpose Interface Integration

- Reset: [0] [1] [2]
- System Power Management and Wake-Up: [3] [4] [5] [6]
- Module Power Saving: [7] [8]

General-Purpose Interface Functional Description

- Asynchronous Path: Wake-Up Request Generation: [9]

**Table 25-16. Register Call Summary for Register GPIO\_SYS CONFIG (continued)**

General-Purpose Interface Basic Programming Model

- Description: [10]

General-Purpose Interface Register Manual

- General-Purpose Interface Register Mapping Summary: [11] [12] [13] [14] [15] [16]

**Table 25-17. GPIO\_SYSSTATUS**

|                         |                                                                                                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|-----------|--|--|--|
| <b>Address Offset</b>   | 0x014                                                                                                   |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |
| <b>Physical Address</b> | 0x4831 0014                                                                                             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |
|                         | 0x4905 0014                                                                                             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |
|                         | 0x4905 2014                                                                                             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |
|                         | 0x4905 4014                                                                                             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |
|                         | 0x4905 6014                                                                                             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |
|                         | 0x4905 8014                                                                                             |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |
| <b>Description</b>      | This register provides status information about the module, excluding the interrupt-status information. |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |
| <b>Type</b>             | R                                                                                                       |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |
| RESERVED                |                                                                                                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | RESERVED  |  |  |  |
|                         |                                                                                                         |                       |                 |  |  |  |  |  |  |  |  |  |  |  |  | RESETDONE |  |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                  | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:8        | RESERVED          | Read returns 0                                                                                      | R           | 0x000000     |
| 7:1         | RESERVED          | Read returns 0                                                                                      | R           | 0x00         |
| 0           | RESETDONE         | Internal reset monitoring<br><br>0x0: Internal module reset in on-going<br><br>0x1: Reset completed | R           | -            |

**Table 25-18. Register Call Summary for Register GPIO\_SYSSTATUS**

General-Purpose Interface Integration

- Reset: [0] [1]

General-Purpose Interface Register Manual

- General-Purpose Interface Register Mapping Summary: [2] [3] [4] [5] [6] [7]

**Table 25-19. GPIO\_IRQSTATUS1**

|                         |                                                  |                 |       |
|-------------------------|--------------------------------------------------|-----------------|-------|
| <b>Address Offset</b>   | 0x018                                            |                 |       |
| <b>Physical Address</b> | 0x4831 0018                                      | <b>Instance</b> | GPIO1 |
|                         | 0x4905 0018                                      |                 | GPIO2 |
|                         | 0x4905 2018                                      |                 | GPIO3 |
|                         | 0x4905 4018                                      |                 | GPIO4 |
|                         | 0x4905 6018                                      |                 | GPIO5 |
|                         | 0x4905 8018                                      |                 | GPIO6 |
| <b>Description</b>      | This register provides IRQ 1 status information. |                 |       |
| <b>Type</b>             | RW                                               |                 |       |

|            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| IRQSTATUS1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                           | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | IRQSTATUS1 | Interrupt 1 Status Register. Write a 1 in the corresponding bit to clear it to 0. Write 0 in the corresponding bit does not affect its value.<br><br>0x0: IRQ channel N not triggered<br>0x1: IRQ channel N triggered | RW   | 0x00000000 |

**Table 25-20. Register Call Summary for Register GPIO\_IRQSTATUS1**

General-Purpose Interface Functional Description

- [Synchronous Path: Interrupt Request Generation: \[0\]](#)
- [Asynchronous Path: Wake-Up Request Generation: \[1\] \[2\]](#)
- [Interrupt \(or Wake-Up\) Line Release: \[3\]](#)

General-Purpose Interface Basic Programming Model

- [Involved Configuration Registers: \[4\]](#)
- [Description: \[5\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[6\] \[7\] \[8\] \[9\] \[10\] \[11\]](#)

**Table 25-21. GPIO\_IRQENABLE1**

|                         |                                                  |                 |       |
|-------------------------|--------------------------------------------------|-----------------|-------|
| <b>Address Offset</b>   | 0x01C                                            |                 |       |
| <b>Physical Address</b> | 0x4831 001C                                      | <b>Instance</b> | GPIO1 |
|                         | 0x4905 001C                                      |                 | GPIO2 |
|                         | 0x4905 201C                                      |                 | GPIO3 |
|                         | 0x4905 401C                                      |                 | GPIO4 |
|                         | 0x4905 601C                                      |                 | GPIO5 |
|                         | 0x4905 801C                                      |                 | GPIO6 |
| <b>Description</b>      | This register provides IRQ 1 enable information. |                 |       |
| <b>Type</b>             | RW                                               |                 |       |

|            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| IRQENABLE1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                              | Type | Reset      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | IRQENABLE1 | Interrupt 1 Enable Register<br><br>0x0: Disable IRQ generation for channel N<br>0x1: Enable IRQ generation for channel N | RW   | 0x00000000 |

**Table 25-22. Register Call Summary for Register GPIO\_IRQENABLE1**


---

 General-Purpose Interface Overview

- [Global Features: \[0\]](#)
- 

General-Purpose Interface Integration

- [Interrupt Requests: \[1\]](#)
- 

General-Purpose Interface Functional Description

- [General-Purpose Interface Functional Description: \[2\]](#)
  - [Synchronous Path: Interrupt Request Generation: \[3\]](#)
  - [Asynchronous Path: Wake-Up Request Generation: \[4\]](#)
- 

General-Purpose Interface Basic Programming Model

- [Description: \[5\]](#)
  - [Involved Configuration Registers: \[6\]](#)
  - [Description: \[7\] \[8\] \[9\]](#)
  - [Data Input \(Capture\)/Output \(Drive\): \[10\] \[11\]](#)
- 

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[12\] \[13\] \[14\] \[15\] \[16\] \[17\]](#)
  - [Register Descriptions: \[18\] \[19\] \[20\] \[21\]](#)
- 

**Table 25-23. GPIO\_WAKEUPENABLE**

|                       |                                                   |                         |             |                 |       |
|-----------------------|---------------------------------------------------|-------------------------|-------------|-----------------|-------|
| <b>Address Offset</b> | 0x020                                             | <b>Physical Address</b> | 0x4831 0020 | <b>Instance</b> | GPIO1 |
|                       |                                                   |                         | 0x4905 0020 |                 | GPIO2 |
|                       |                                                   |                         | 0x4905 2020 |                 | GPIO3 |
|                       |                                                   |                         | 0x4905 4020 |                 | GPIO4 |
|                       |                                                   |                         | 0x4905 6020 |                 | GPIO5 |
|                       |                                                   |                         | 0x4905 8020 |                 | GPIO6 |
| <b>Description</b>    | This register provides wakeup-enable information. |                         |             |                 |       |
| <b>Type</b>           | RW                                                |                         |             |                 |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| WAKEUPEN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                      | Type | Reset      |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | WAKEUPEN   | Wake Up Enable Register<br><br>0x0: Disable wake-up generation for channel N<br><br>0x1: Enable wake-up generation for channel N | RW   | 0x00000000 |

**Table 25-24. Register Call Summary for Register GPIO\_WAKEUPENABLE**


---

 General-Purpose Interface Overview

- [Global Features: \[0\]](#)
- 

General-Purpose Interface Integration

- [Wake-Up Generation: \[1\]](#)
- 

General-Purpose Interface Functional Description

- [Asynchronous Path: Wake-Up Request Generation: \[2\] \[3\]](#)
- 

General-Purpose Interface Basic Programming Model

- [Description: \[4\]](#)
  - [Involved Configuration Registers: \[5\]](#)
  - [Description: \[6\]](#)
  - [Data Input \(Capture\)/Output \(Drive\): \[7\] \[8\]](#)
-

**Table 25-24. Register Call Summary for Register GPIO\_WAKEUPENABLE (continued)**

General-Purpose Interface Register Manual

- General-Purpose Interface Register Mapping Summary: [9] [10] [11] [12] [13] [14]
- Register Descriptions: [15] [16] [17] [18]

**Table 25-25. GPIO\_IRQSTATUS2**

|                         |                                                  |                 |       |
|-------------------------|--------------------------------------------------|-----------------|-------|
| <b>Address Offset</b>   | 0x028                                            |                 |       |
| <b>Physical Address</b> | 0x4831 0028                                      | <b>Instance</b> | GPIO1 |
|                         | 0x4905 0028                                      |                 | GPIO2 |
|                         | 0x4905 2028                                      |                 | GPIO3 |
|                         | 0x4905 4028                                      |                 | GPIO4 |
|                         | 0x4905 6028                                      |                 | GPIO5 |
|                         | 0x4905 8028                                      |                 | GPIO6 |
| <b>Description</b>      | This register provides IRQ 2 status information. |                 |       |
| <b>Type</b>             | RW                                               |                 |       |

|            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| IRQSTATUS2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                                                                                                           | Type | Reset      |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | IRQSTATUS2 | Interrupt 2 Status Register. Write a 1 in the corresponding bit to clear it to 0. Write 0 in the corresponding bit does not affect its value.<br><br>0x0: IRQ channel N not triggered<br>0x1: IRQ channel N triggered | RW   | 0x00000000 |

**Table 25-26. Register Call Summary for Register GPIO\_IRQSTATUS2**

General-Purpose Interface Functional Description

- Synchronous Path: Interrupt Request Generation: [0]
- Asynchronous Path: Wake-Up Request Generation: [1]
- Interrupt (or Wake-Up) Line Release: [2]

General-Purpose Interface Basic Programming Model

- Involved Configuration Registers: [3]
- Description: [4]

General-Purpose Interface Register Manual

- General-Purpose Interface Register Mapping Summary: [5] [6] [7] [8] [9] [10]

**Table 25-27. GPIO\_IRQENABLE2**

|                         |                                                  |                 |       |
|-------------------------|--------------------------------------------------|-----------------|-------|
| <b>Address Offset</b>   | 0x02C                                            |                 |       |
| <b>Physical Address</b> | 0x4831 002C                                      | <b>Instance</b> | GPIO1 |
|                         | 0x4905 002C                                      |                 | GPIO2 |
|                         | 0x4905 202C                                      |                 | GPIO3 |
|                         | 0x4905 402C                                      |                 | GPIO4 |
|                         | 0x4905 602C                                      |                 | GPIO5 |
|                         | 0x4905 802C                                      |                 | GPIO6 |
| <b>Description</b>      | This register provides IRQ 2 enable information. |                 |       |
| <b>Type</b>             | RW                                               |                 |       |

|            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| IRQENABLE2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                  | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | IRQENABLE2 | Interrupt 2 Enable Register<br><br>0x0: Disable IRQ generation for channel N<br><br>0x1: Enable IRQ generation for channel N | RW   | 0x00000000 |

**Table 25-28. Register Call Summary for Register GPIO\_IRQENABLE2**

General-Purpose Interface Overview

- [Global Features: \[0\]](#)

General-Purpose Interface Integration

- [Interrupt Requests: \[1\]](#)

General-Purpose Interface Functional Description

- [General-Purpose Interface Functional Description: \[2\]](#)
- [Synchronous Path: Interrupt Request Generation: \[3\]](#)
- [Asynchronous Path: Wake-Up Request Generation: \[4\]](#)

General-Purpose Interface Basic Programming Model

- [Involved Configuration Registers: \[5\]](#)
- [Description: \[6\] \[7\] \[8\]](#)
- [Data Input \(Capture\)/Output \(Drive\): \[9\] \[10\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[11\] \[12\] \[13\] \[14\] \[15\] \[16\]](#)
- [Register Descriptions: \[17\] \[18\] \[19\] \[20\]](#)

**Table 25-29. GPIO\_CTRL**

|                         |                                                        |                 |       |  |
|-------------------------|--------------------------------------------------------|-----------------|-------|--|
| <b>Address Offset</b>   | 0x030                                                  |                 |       |  |
| <b>Physical Address</b> | 0x4831 0030                                            | <b>Instance</b> | GPIO1 |  |
|                         | 0x4905 0030                                            |                 | GPIO2 |  |
|                         | 0x4905 2030                                            |                 | GPIO3 |  |
|                         | 0x4905 4030                                            |                 | GPIO4 |  |
|                         | 0x4905 6030                                            |                 | GPIO5 |  |
|                         | 0x4905 8030                                            |                 | GPIO6 |  |
| <b>Description</b>      | This register controls the clock gating functionality. |                 |       |  |
| <b>Type</b>             | RW                                                     |                 |       |  |



| Bits | Field Name    | Description                                                                                                                                                                                                                                 | Type | Reset      |
|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:3 | RESERVED      | Read returns 0                                                                                                                                                                                                                              | RW   | 0x00000000 |
| 2:1  | GATINGRATIO   | Gating Ratio<br><br>0x0: Functional clock is interface clock.<br>0x1: Functional clock is interface clock divided by 2.<br>0x2: Functional clock is interface clock divided by 4.<br>0x3: Functional clock is interface clock divided by 8. | RW   | 0x1        |
| 0    | DISABLEMODULE | Module Disable<br><br>0x0: Module is enabled, clocks are not gated<br>0x1: Module is disabled, clocks are gated                                                                                                                             | RW   | 0x0        |

**Table 25-30. Register Call Summary for Register GPIO\_CTRL**

General-Purpose Interface Integration

- [Operating Modes: \[0\]](#)
- [Module Power Saving: \[1\] \[2\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\]](#)

**Table 25-31. GPIO\_OE**

| <b>Address Offset</b>   | 0x034                                                                                                               | <b>Instance</b>                                                                                                                                   | GPIO1<br>GPIO2<br>GPIO3<br>GPIO4<br>GPIO5<br>GPIO6 |            |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|------------|--|
| <b>Physical Address</b> | 0x4831 0034                                                                                                         |                                                                                                                                                   |                                                    |            |  |
|                         | 0x4905 0034                                                                                                         |                                                                                                                                                   |                                                    |            |  |
|                         | 0x4905 2034                                                                                                         |                                                                                                                                                   |                                                    |            |  |
|                         | 0x4905 4034                                                                                                         |                                                                                                                                                   |                                                    |            |  |
|                         | 0x4905 6034                                                                                                         |                                                                                                                                                   |                                                    |            |  |
|                         | 0x4905 8034                                                                                                         |                                                                                                                                                   |                                                    |            |  |
| <b>Description</b>      | This register is used to enable the pins output capabilities. Its only function is to carry the pads configuration. |                                                                                                                                                   |                                                    |            |  |
| <b>Type</b>             | RW                                                                                                                  |                                                                                                                                                   |                                                    |            |  |
| 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                                    |            |  |
| OUTPUTEN                |                                                                                                                     |                                                                                                                                                   |                                                    |            |  |
| Bits                    | Field Name                                                                                                          | Description                                                                                                                                       | Type                                               | Reset      |  |
| 31:0                    | OUTPUTEN                                                                                                            | Output Data Enable<br><br>0x0: The corresponding GPIO port is configured as output<br><br>0x1: The corresponding GPIO port is configured as input | RW                                                 | 0xFFFFFFFF |  |

**Table 25-32. Register Call Summary for Register GPIO\_OE**

General-Purpose Interface Overview

- [Global Features: \[0\]](#)

General-Purpose Interface Basic Programming Model

- [Description: \[1\] \[2\]](#)
- [Data Input \(Capture\)/Output \(Drive\): \[3\] \[4\] \[5\]](#)
- [Debouncing Time: \[6\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[7\] \[8\] \[9\] \[10\] \[11\] \[12\]](#)

**Table 25-33. GPIO\_DATAIN**

| <b>Address Offset</b>   | 0x038                                                                       | <b>Instance</b>       | GPIO1<br>GPIO2<br>GPIO3<br>GPIO4<br>GPIO5<br>GPIO6 |            |  |
|-------------------------|-----------------------------------------------------------------------------|-----------------------|----------------------------------------------------|------------|--|
| <b>Physical Address</b> | 0x4831 0038                                                                 |                       |                                                    |            |  |
|                         | 0x4905 0038                                                                 |                       |                                                    |            |  |
|                         | 0x4905 2038                                                                 |                       |                                                    |            |  |
|                         | 0x4905 4038                                                                 |                       |                                                    |            |  |
|                         | 0x4905 6038                                                                 |                       |                                                    |            |  |
|                         | 0x4905 8038                                                                 |                       |                                                    |            |  |
| <b>Description</b>      | This register is used to register the data that is read from the GPIO pins. |                       |                                                    |            |  |
| <b>Type</b>             | R                                                                           |                       |                                                    |            |  |
| 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                                    |            |  |
| DATAINPUT               |                                                                             |                       |                                                    |            |  |
| Bits                    | Field Name                                                                  | Description           | Type                                               | Reset      |  |
| 31:0                    | DATAINPUT                                                                   | Sampled Input Data    | R                                                  | 0x00000000 |  |

**Table 25-34. Register Call Summary for Register GPIO\_DATAIN**

General-Purpose Interface Overview

- [Global Features: \[0\]](#)

General-Purpose Interface Integration

- [System Power Management and Wake-Up: \[1\]](#)

General-Purpose Interface Basic Programming Model

- [Data Input \(Capture\)/Output \(Drive\): \[2\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[3\] \[4\] \[5\] \[6\] \[7\] \[8\]](#)

**Table 25-35. GPIO\_DATAOUT**

|                         |                                                                     |                       |                                                    |  |  |
|-------------------------|---------------------------------------------------------------------|-----------------------|----------------------------------------------------|--|--|
| <b>Address Offset</b>   | 0x03C                                                               | <b>Instance</b>       | GPIO1<br>GPIO2<br>GPIO3<br>GPIO4<br>GPIO5<br>GPIO6 |  |  |
| <b>Physical Address</b> | 0x4831 003C                                                         |                       |                                                    |  |  |
|                         | 0x4905 003C                                                         |                       |                                                    |  |  |
|                         | 0x4905 203C                                                         |                       |                                                    |  |  |
|                         | 0x4905 403C                                                         |                       |                                                    |  |  |
|                         | 0x4905 603C                                                         |                       |                                                    |  |  |
|                         | 0x4905 803C                                                         |                       |                                                    |  |  |
| <b>Description</b>      | This register is used for setting the value of the GPIO output pins |                       |                                                    |  |  |
| <b>Type</b>             | RW                                                                  |                       |                                                    |  |  |
| 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                                    |  |  |
| DATAOUTPUT              |                                                                     |                       |                                                    |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b> | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------|-------------|--------------|
| 31:0        | DATAOUTPUT        | Output Data        | RW          | 0x00000000   |

**Table 25-36. Register Call Summary for Register GPIO\_DATAOUT**

General-Purpose Interface Overview

- [Global Features: \[0\] \[1\]](#)

General-Purpose Interface Basic Programming Model

- [Description: \[2\]](#)
- [Data Input \(Capture\)/Output \(Drive\): \[3\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[4\] \[5\] \[6\] \[7\] \[8\] \[9\]](#)
- [Register Descriptions: \[10\] \[11\] \[12\] \[13\]](#)

**Table 25-37. GPIO\_LEVELDETECT0**

|                         |                                                                                                                                           |                                                    |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-----------------|----------|--|--|--|--|--|--|--|--|--|--|--|-------------|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x040                                                                                                                                     |                                                    |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4831 0040                                                                                                                               | <b>Instance</b>                                    |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4905 0040                                                                                                                               | GPIO1                                              |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4905 2040                                                                                                                               | GPIO2                                              |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4905 4040                                                                                                                               | GPIO3                                              |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4905 6040                                                                                                                               | GPIO4                                              |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4905 8040                                                                                                                               | GPIO5                                              |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                                                                           | GPIO6                                              |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register is used to enable/disable for each input lines the low-level (0) detection to be used for the interrupt request generation. |                                                    |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                        |                                                    |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | LOWLEVEL |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bits</b>             | <b>Field Name</b>                                                                                                                         | <b>Description</b>                                 |                 |          |  |  |  |  |  |  |  |  |  |  |  | <b>Type</b> | <b>Reset</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:0                    | LOWLEVEL                                                                                                                                  | Low Level Interrupt Enable                         |                 |          |  |  |  |  |  |  |  |  |  |  |  | RW          | 0x00000000   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                                                                           | 0x0: Disable the IRQ assertion on low-level detect |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                                                                           | 0x1: Enable the IRQ assertion on low-level detect  |                 |          |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 25-38. Register Call Summary for Register GPIO\_LEVELDETECT0**

General-Purpose Interface Basic Programming Model

- Power Saving by Grouping the Edge/Level Detection: [0] [1]
- Description: [2]

General-Purpose Interface Register Manual

- General-Purpose Interface Register Mapping Summary: [3] [4] [5] [6] [7] [8]

**Table 25-39. GPIO\_LEVELDETECT1**

|                         |                                                                                                                                            |                                                     |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-----------------|-----------|--|--|--|--|--|--|--|--|--|--|--|-------------|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x044                                                                                                                                      |                                                     |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Physical Address</b> | 0x4831 0044                                                                                                                                | <b>Instance</b>                                     |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4905 0044                                                                                                                                | GPIO1                                               |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4905 2044                                                                                                                                | GPIO2                                               |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4905 4044                                                                                                                                | GPIO3                                               |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4905 6044                                                                                                                                | GPIO4                                               |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         | 0x4905 8044                                                                                                                                | GPIO5                                               |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                                                                            | GPIO6                                               |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Description</b>      | This register is used to enable/disable for each input lines the high-level (1) detection to be used for the interrupt request generation. |                                                     |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                         |                                                     |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 | HIGHLEVEL |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bits</b>             | <b>Field Name</b>                                                                                                                          | <b>Description</b>                                  |                 |           |  |  |  |  |  |  |  |  |  |  |  | <b>Type</b> | <b>Reset</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:0                    | HIGHLEVEL                                                                                                                                  | High Level Interrupt Enable                         |                 |           |  |  |  |  |  |  |  |  |  |  |  | RW          | 0x00000000   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                                                                            | 0x0: Disable the IRQ assertion on high-level detect |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                                                                            | 0x1: Enable the IRQ assertion on high-level detect  |                 |           |  |  |  |  |  |  |  |  |  |  |  |             |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Table 25-40. Register Call Summary for Register GPIO\_LEVELDETECT1**

General-Purpose Interface Basic Programming Model

- Power Saving by Grouping the Edge/Level Detection: [0] [1]
- Description: [2]

General-Purpose Interface Register Manual

- General-Purpose Interface Register Mapping Summary: [3] [4] [5] [6] [7] [8]

**Table 25-41. GPIO\_RISINGDETECT**

|                         |                                                                                                                                                                           |                 |                                                    |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------------------------------------------|--|
| <b>Address Offset</b>   | 0x048                                                                                                                                                                     | <b>Instance</b> | GPIO1<br>GPIO2<br>GPIO3<br>GPIO4<br>GPIO5<br>GPIO6 |  |
| <b>Physical Address</b> | 0x4831 0048                                                                                                                                                               |                 |                                                    |  |
|                         | 0x4905 0048                                                                                                                                                               |                 |                                                    |  |
|                         | 0x4905 2048                                                                                                                                                               |                 |                                                    |  |
|                         | 0x4905 4048                                                                                                                                                               |                 |                                                    |  |
|                         | 0x4905 6048                                                                                                                                                               |                 |                                                    |  |
|                         | 0x4905 8048                                                                                                                                                               |                 |                                                    |  |
| <b>Description</b>      | This register is used to enable/disable for each input lines the rising-edge (transition 0=>1) detection to be used for the interrupt request and the wake-up generation. |                 |                                                    |  |
| <b>Type</b>             | RW                                                                                                                                                                        |                 |                                                    |  |

|            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RISINGEDGE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | RISINGEDGE        | Rising Edge Interrupt/wake-up enable<br><br>0x0: Disable IRQ /wake up on rising edge detect<br><br>0x1: Enable IRQ /wake up on rising edge detect | RW          | 0x00000000   |

**Table 25-42. Register Call Summary for Register GPIO\_RISINGDETECT**

General-Purpose Interface Basic Programming Model

- Power Saving by Grouping the Edge/Level Detection: [0] [1]
- Description: [2] [3] [4]

General-Purpose Interface Register Manual

- General-Purpose Interface Register Mapping Summary: [5] [6] [7] [8] [9] [10]

**Table 25-43. GPIO\_FALLINGDETECT**

| <b>Address Offset</b>   | 0x04C                                                                                                                                                                      |                                                                                                                                                    |                 |            |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Physical Address</b> | 0x4831 004C                                                                                                                                                                | <b>Instance</b>                                                                                                                                    | GPIO1           |            |
|                         | 0x4905 004C                                                                                                                                                                |                                                                                                                                                    | GPIO2           |            |
|                         | 0x4905 204C                                                                                                                                                                |                                                                                                                                                    | GPIO3           |            |
|                         | 0x4905 404C                                                                                                                                                                |                                                                                                                                                    | GPIO4           |            |
|                         | 0x4905 604C                                                                                                                                                                |                                                                                                                                                    | GPIO5           |            |
|                         | 0x4905 804C                                                                                                                                                                |                                                                                                                                                    | GPIO6           |            |
| <b>Description</b>      | This register is used to enable/disable for each input lines the falling-edge (transition 1=>0) detection to be used for the interrupt request and the wake-up generation. |                                                                                                                                                    |                 |            |
| <b>Type</b>             | RW                                                                                                                                                                         |                                                                                                                                                    |                 |            |
| 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 |            |
| FALLINGEDGE             |                                                                                                                                                                            |                                                                                                                                                    |                 |            |
| Bits                    | Field Name                                                                                                                                                                 | Description                                                                                                                                        | Type            | Reset      |
| 31:0                    | FALLINGEDGE                                                                                                                                                                | Falling Edge Interrupt/wake-up enable<br><br>0x0: Disable IRQ/wakeup on falling edge detect<br><br>0x1: Enable IRQ /wake up on falling edge detect | RW              | 0x00000000 |

**Table 25-44. Register Call Summary for Register GPIO\_FALLINGDETECT**

General-Purpose Interface Basic Programming Model

- [Power Saving by Grouping the Edge/Level Detection: \[0\]](#) [\[1\]](#)
- [Description: \[2\]](#) [\[3\]](#) [\[4\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[5\]](#) [\[6\]](#) [\[7\]](#) [\[8\]](#) [\[9\]](#) [\[10\]](#)

**Table 25-45. GPIO\_DEBOUNCENABLE**

| <b>Address Offset</b>   | 0x050                                                                               |                                                                                                                                                                    |                 |            |
|-------------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|
| <b>Physical Address</b> | 0x4831 0050                                                                         | <b>Instance</b>                                                                                                                                                    | GPIO1           |            |
|                         | 0x4905 0050                                                                         |                                                                                                                                                                    | GPIO2           |            |
|                         | 0x4905 2050                                                                         |                                                                                                                                                                    | GPIO3           |            |
|                         | 0x4905 4050                                                                         |                                                                                                                                                                    | GPIO4           |            |
|                         | 0x4905 6050                                                                         |                                                                                                                                                                    | GPIO5           |            |
|                         | 0x4905 8050                                                                         |                                                                                                                                                                    | GPIO6           |            |
| <b>Description</b>      | This register is used to enable/disable the debouncing feature for each input line. |                                                                                                                                                                    |                 |            |
| <b>Type</b>             | RW                                                                                  |                                                                                                                                                                    |                 |            |
| 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 |            |
| DEBOUNCEEN              |                                                                                     |                                                                                                                                                                    |                 |            |
| Bits                    | Field Name                                                                          | Description                                                                                                                                                        | Type            | Reset      |
| 31:0                    | DEBOUNCEEN                                                                          | Input Debounce Enable<br><br>0x0: Disable debouncing feature on the corresponding input port<br><br>0x1: Enable debouncing feature on the corresponding input port | RW              | 0x00000000 |

**Table 25-46. Register Call Summary for Register GPIO\_DEBOUNCENABLE**

General-Purpose Interface Basic Programming Model

- Debouncing Time: [0]

General-Purpose Interface Register Manual

- General-Purpose Interface Register Mapping Summary: [1] [2] [3] [4] [5] [6]

**Table 25-47. GPIO\_DEBOUNCINGTIME**

|                         |                                                                             |                 |       |
|-------------------------|-----------------------------------------------------------------------------|-----------------|-------|
| <b>Address Offset</b>   | 0x054                                                                       |                 |       |
| <b>Physical Address</b> | 0x4831 0054                                                                 | <b>Instance</b> | GPIO1 |
|                         | 0x4905 0054                                                                 |                 | GPIO2 |
|                         | 0x4905 2054                                                                 |                 | GPIO3 |
|                         | 0x4905 4054                                                                 |                 | GPIO4 |
|                         | 0x4905 6054                                                                 |                 | GPIO5 |
|                         | 0x4905 8054                                                                 |                 | GPIO6 |
| <b>Description</b>      | This register controls debouncing time (the value is global for all ports). |                 |       |
| <b>Type</b>             | RW                                                                          |                 |       |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |             |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-------------|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | DEBOUNCEVAL |   |   |

| Bits | Field Name  | Description                                                                                       | Type | Reset    |
|------|-------------|---------------------------------------------------------------------------------------------------|------|----------|
| 31:8 | RESERVED    | Read returns 0                                                                                    | RW   | 0x000000 |
| 7:0  | DEBOUNCEVAL | Input Debouncing Value in 31 microsecond steps.<br>debouncing time = (DEBOUNCEVAL+1) x 31 $\mu$ s | RW   | 0x00     |

**Table 25-48. Register Call Summary for Register GPIO\_DEBOUNCINGTIME**

General-Purpose Interface Integration

- System Power Management and Wake-Up: [0]

General-Purpose Interface Functional Description

- Synchronous Path: Interrupt Request Generation: [1] [2]

General-Purpose Interface Basic Programming Model

- Debouncing Time: [3] [4] [5] [6]

General-Purpose Interface Register Manual

- General-Purpose Interface Register Mapping Summary: [7] [8] [9] [10] [11] [12] [13]

**Table 25-49. GPIO\_CLEARIRQENABLE1**

|                         |                                                                                   |                 |       |
|-------------------------|-----------------------------------------------------------------------------------|-----------------|-------|
| <b>Address Offset</b>   | 0x060                                                                             |                 |       |
| <b>Physical Address</b> | 0x4831 0060                                                                       | <b>Instance</b> | GPIO1 |
|                         | 0x4905 0060                                                                       |                 | GPIO2 |
|                         | 0x4905 2060                                                                       |                 | GPIO3 |
|                         | 0x4905 4060                                                                       |                 | GPIO4 |
|                         | 0x4905 6060                                                                       |                 | GPIO5 |
|                         | 0x4905 8060                                                                       |                 | GPIO6 |
| <b>Description</b>      | Clear to 0 the corresponding bits in the <a href="#">GPIO_IRQENABLE1</a> register |                 |       |
| <b>Type</b>             | RW                                                                                |                 |       |

|             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| CLEARIRQEN1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name  | Description                                                                                                                            | Type | Reset      |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | CLEARIRQEN1 | Clear Interrupt Enable 1<br><br>0x0: No effect<br><br>0x1: Clear the corresponding bit in the <a href="#">GPIO_IRQENABLE1</a> register | RW   | 0x00000000 |

**Table 25-50. Register Call Summary for Register GPIO\_CLEARIRQENABLE1**

General-Purpose Interface Basic Programming Model

- [Clear Register Addresses: \[0\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\]](#)

**Table 25-51. GPIO\_SETIRQENABLE1**

|                         |                                                                                 |                 |       |
|-------------------------|---------------------------------------------------------------------------------|-----------------|-------|
| <b>Address Offset</b>   | 0x064                                                                           |                 |       |
| <b>Physical Address</b> | 0x4831 0064                                                                     | <b>Instance</b> | GPIO1 |
|                         | 0x4905 0064                                                                     |                 | GPIO2 |
|                         | 0x4905 2064                                                                     |                 | GPIO3 |
|                         | 0x4905 4064                                                                     |                 | GPIO4 |
|                         | 0x4905 6064                                                                     |                 | GPIO5 |
|                         | 0x4905 8064                                                                     |                 | GPIO6 |
| <b>Description</b>      | Set to 1 the corresponding bits in the <a href="#">GPIO_IRQENABLE1</a> register |                 |       |
| <b>Type</b>             | RW                                                                              |                 |       |

|           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| SETIRQEN1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                        | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | SETIRQEN1  | Set Interrupt Enable 1<br><br>0x0: No effect<br><br>0x1: Set the corresponding bit in the <a href="#">GPIO_IRQENABLE1</a> register | RW   | 0x00000000 |

**Table 25-52. Register Call Summary for Register GPIO\_SETIRQENABLE1**

General-Purpose Interface Basic Programming Model

- Set Register Addresses: [0]

General-Purpose Interface Register Manual

- General-Purpose Interface Register Mapping Summary: [1] [2] [3] [4] [5] [6]

**Table 25-53. GPIO\_CLEARIRQENABLE2**

|                         |                                                                                   |                 |       |
|-------------------------|-----------------------------------------------------------------------------------|-----------------|-------|
| <b>Address Offset</b>   | 0x070                                                                             |                 |       |
| <b>Physical Address</b> | 0x4831 0070                                                                       | <b>Instance</b> | GPIO1 |
|                         | 0x4905 0070                                                                       |                 | GPIO2 |
|                         | 0x4905 2070                                                                       |                 | GPIO3 |
|                         | 0x4905 4070                                                                       |                 | GPIO4 |
|                         | 0x4905 6070                                                                       |                 | GPIO5 |
|                         | 0x4905 8070                                                                       |                 | GPIO6 |
| <b>Description</b>      | Clear to 0 the corresponding bits in the <a href="#">GPIO_IRQENABLE2</a> register |                 |       |
| <b>Type</b>             | RW                                                                                |                 |       |

|             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| CLEARIRQEN2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                     | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:0        | CLEARIRQEN2       | Clear Interrupt Enable 2<br><br>0x0: No effect<br><br>0x1: Clear the corresponding bit in the <a href="#">GPIO_IRQENABLE2</a> register | RW          | 0x00000000   |

**Table 25-54. Register Call Summary for Register GPIO\_CLEARIRQENABLE2**

General-Purpose Interface Basic Programming Model

- Clear Register Addresses: [0]

General-Purpose Interface Register Manual

- General-Purpose Interface Register Mapping Summary: [1] [2] [3] [4] [5] [6]

**Table 25-55. GPIO\_SETIRQENABLE2**

|                         |                                                                                 |                 |       |
|-------------------------|---------------------------------------------------------------------------------|-----------------|-------|
| <b>Address Offset</b>   | 0x074                                                                           |                 |       |
| <b>Physical Address</b> | 0x4831 0074                                                                     | <b>Instance</b> | GPIO1 |
|                         | 0x4905 0074                                                                     |                 | GPIO2 |
|                         | 0x4905 2074                                                                     |                 | GPIO3 |
|                         | 0x4905 4074                                                                     |                 | GPIO4 |
|                         | 0x4905 6074                                                                     |                 | GPIO5 |
|                         | 0x4905 8074                                                                     |                 | GPIO6 |
| <b>Description</b>      | Set to 1 the corresponding bits in the <a href="#">GPIO_IRQENABLE2</a> register |                 |       |
| <b>Type</b>             | RW                                                                              |                 |       |

|           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| SETIRQEN2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name | Description                                                                                                                        | Type | Reset      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | SETIRQEN2  | Set Interrupt Enable 2<br><br>0x0: No effect<br><br>0x1: Set the corresponding bit in the <a href="#">GPIO_IRQENABLE2</a> register | RW   | 0x00000000 |

**Table 25-56. Register Call Summary for Register GPIO\_SETIRQENABLE2**

General-Purpose Interface Basic Programming Model

- [Set Register Addresses: \[0\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\]](#)

**Table 25-57. GPIO\_CLEARWKUENA**

| Address Offset     | 0x080                                                                               | Physical Address | 0x4831 0080 | Instance | GPIO1 |
|--------------------|-------------------------------------------------------------------------------------|------------------|-------------|----------|-------|
|                    |                                                                                     |                  | 0x4905 0080 |          | GPIO2 |
|                    |                                                                                     |                  | 0x4905 2080 |          | GPIO3 |
|                    |                                                                                     |                  | 0x4905 4080 |          | GPIO4 |
|                    |                                                                                     |                  | 0x4905 6080 |          | GPIO5 |
|                    |                                                                                     |                  | 0x4905 8080 |          | GPIO6 |
| <b>Description</b> | Clear to 0 the corresponding bits in the <a href="#">GPIO_WAKEUPENABLE</a> register |                  |             |          |       |
| <b>Type</b>        | RW                                                                                  |                  |             |          |       |

|               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| CLEARWAKEUPEN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name    | Description                                                                                                                          | Type | Reset      |
|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | CLEARWAKEUPEN | Clear wake-up enable<br><br>0x0: No effect<br><br>0x1: Clear the corresponding bit in the <a href="#">GPIO_WAKEUPENABLE</a> register | RW   | 0x00000000 |

**Table 25-58. Register Call Summary for Register GPIO\_CLEARWKUENA**

General-Purpose Interface Basic Programming Model

- [Clear Register Addresses: \[0\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\]](#)

**Table 25-59. GPIO\_SETWKUENA**

|                         |                                                                                   |                 |       |  |
|-------------------------|-----------------------------------------------------------------------------------|-----------------|-------|--|
| <b>Address Offset</b>   | 0x084                                                                             |                 |       |  |
| <b>Physical Address</b> | 0x4831 0084                                                                       | <b>Instance</b> | GPIO1 |  |
|                         | 0x4905 0084                                                                       |                 | GPIO2 |  |
|                         | 0x4905 2084                                                                       |                 | GPIO3 |  |
|                         | 0x4905 4084                                                                       |                 | GPIO4 |  |
|                         | 0x4905 6084                                                                       |                 | GPIO5 |  |
|                         | 0x4905 8084                                                                       |                 | GPIO6 |  |
| <b>Description</b>      | Set to 1 the corresponding bits in the <a href="#">GPIO_WAKEUPENABLE</a> register |                 |       |  |
| <b>Type</b>             | RW                                                                                |                 |       |  |

|             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| SETWAKEUPEN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name  | Description                                                                                                                      | Type | Reset      |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | SETWAKEUPEN | Set wake-up enable<br><br>0x0: No effect<br><br>0x1: Set the corresponding bit in the <a href="#">GPIO_WAKEUPENABLE</a> register | RW   | 0x00000000 |

**Table 25-60. Register Call Summary for Register GPIO\_SETWKUENA**

General-Purpose Interface Basic Programming Model

- [Set Register Addresses: \[0\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[1\] \[2\] \[3\] \[4\] \[5\] \[6\]](#)

**Table 25-61. GPIO\_CLEARDATAOUT**

|                         |                                                                                |                 |       |  |
|-------------------------|--------------------------------------------------------------------------------|-----------------|-------|--|
| <b>Address Offset</b>   | 0x090                                                                          |                 |       |  |
| <b>Physical Address</b> | 0x4831 0090                                                                    | <b>Instance</b> | GPIO1 |  |
|                         | 0x4905 0090                                                                    |                 | GPIO2 |  |
|                         | 0x4905 2090                                                                    |                 | GPIO3 |  |
|                         | 0x4905 4090                                                                    |                 | GPIO4 |  |
|                         | 0x4905 6090                                                                    |                 | GPIO5 |  |
|                         | 0x4905 8090                                                                    |                 | GPIO6 |  |
| <b>Description</b>      | Clear to 0 the corresponding bits in the <a href="#">GPIO_DATAOUT</a> register |                 |       |  |
| <b>Type</b>             | RW                                                                             |                 |       |  |

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| CLEARDATAOUT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name   | Description                                                                                                                           | Type | Reset      |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:0 | CLEARDATAOUT | Clear Data Output Register<br><br>0x0: No effect<br><br>0x1: Clear the corresponding bit in the <a href="#">GPIO_DATAOUT</a> register | RW   | 0x00000000 |

**Table 25-62. Register Call Summary for Register GPIO\_CLEARDATAOUT**

General-Purpose Interface Basic Programming Model

- [Clear Register Addresses: \[0\]](#)
- [Data Input \(Capture\)/Output \(Drive\): \[1\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\]](#)

**Table 25-63. GPIO\_SETDATAOUT**

| <b>Address Offset</b>   | 0x094                                                                        | <b>Instance</b>                                                                                                                   | <b>GPIO1</b>    |              |  |
|-------------------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------|--|
| <b>Physical Address</b> | 0x4831 0094                                                                  |                                                                                                                                   |                 |              |  |
|                         | 0x4905 0094                                                                  |                                                                                                                                   |                 |              |  |
|                         | 0x4905 2094                                                                  |                                                                                                                                   |                 |              |  |
|                         | 0x4905 4094                                                                  |                                                                                                                                   |                 |              |  |
|                         | 0x4905 6094                                                                  |                                                                                                                                   |                 |              |  |
|                         | 0x4905 8094                                                                  |                                                                                                                                   |                 |              |  |
| <b>Description</b>      | Set to 1 the corresponding bits in the <a href="#">GPIO_DATAOUT</a> register |                                                                                                                                   |                 |              |  |
| <b>Type</b>             | RW                                                                           |                                                                                                                                   |                 |              |  |
| 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 |              |  |
| SETDATAOUT              |                                                                              |                                                                                                                                   |                 |              |  |
| <b>Bits</b>             | <b>Field Name</b>                                                            | <b>Description</b>                                                                                                                | <b>Type</b>     | <b>Reset</b> |  |
| 31:0                    | SETDATAOUT                                                                   | Set Data Output Register<br><br>0x0: No effect<br><br>0x1: Set the corresponding bit in the <a href="#">GPIO_DATAOUT</a> register | RW              | 0x00000000   |  |

**Table 25-64. Register Call Summary for Register GPIO\_SETDATAOUT**

General-Purpose Interface Basic Programming Model

- [Set Register Addresses: \[0\]](#)
- [Data Input \(Capture\)/Output \(Drive\): \[1\]](#)

General-Purpose Interface Register Manual

- [General-Purpose Interface Register Mapping Summary: \[2\] \[3\] \[4\] \[5\] \[6\] \[7\]](#)



## **Initialization**

This chapter introduces the initialization steps in the general-purpose (GP) device.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| Topic                                                        | Page        |
|--------------------------------------------------------------|-------------|
| <b>26.1 Initialization Overview .....</b>                    | <b>3542</b> |
| <b>26.2 Preinitialization .....</b>                          | <b>3543</b> |
| <b>26.3 Power, Clocks, and Reset Power-Up Sequence .....</b> | <b>3552</b> |
| <b>26.4 Device Initialization by ROM Code .....</b>          | <b>3552</b> |
| <b>26.5 Wake-Up Booting by ROM Code .....</b>                | <b>3608</b> |
| <b>26.6 Debug Configuration .....</b>                        | <b>3612</b> |

## 26.1 Initialization Overview

This chapter provides an overview of the requirements for initializing the device from power on to firmware execution. An overview of the overall initialization process is given, including hardware- and software-related steps, a general overview of the boot ROM code operational requirements, and behavioral expectations.

### 26.1.1 Terminology

- Bootstrap: Initial software (SW) launched by the ROM code during the memory booting phase
- Downloaded software: Initial software downloaded into the internal static RAM (SRAM) by the ROM code during the peripheral booting phase
- eFuse: A one-time programmable memory location usually set at the factory
- Flash loader: Downloaded software launched by the ROM code in preflashing. It also programs an image in external memories.
- GP device: General-purpose device
- Initial software: Software executed by any of the ROM code mechanisms (memory booting or peripheral booting). Initial software is a generic term for bootstrap and downloaded software.
- Memory booting: ROM code mechanism that consists of executing initial software from external memory
- Peripheral booting: ROM code mechanism that consists of polling selected interfaces, downloading, and executing initial software (in this case, downloaded software) in the internal RAM.
- Permanent booting device: Memory device containing, by default, the image to be executed during the booting sequence. It is the default memory booting device. The permanent booting device is used after warm reset if no software booting configuration is programmed.
- Preflashing: A specific case of peripheral booting where the ROM code mechanism is used to program the external flash memory
- ROM code: The on-chip software in ROM that implements booting

### 26.1.2 Initialization Process

[Figure 26-1](#) is an overview of the initialization process and its steps:

- Preinitialization
- Power/clock/reset ramp sequence
- Boot ROM
- Boot loader
- OS/application

Each step, up to OS/applications running, is explained in the following sections.

**Figure 26-1. Initialization Process**



The first two steps in the initialization process are hardware-oriented; however, they require understanding of the process of configuring those system interface pins (balls on the device) that have software-configurable functionality. This configuration is an essential part of chip configuration and is application-dependent. This chapter refers to those pins and the associated configuration registers that are vital for correct device initialization.

## 26.2 Preinitialization

To accomplish a successful boot-up operation with a general-purpose (GP) device, certain hardware configuration settings must be in place. Clock, reset, and power connections, as well as pins involved in setting the boot memory space for the microprocessor unit (MPU), must be connected and driven correctly for successful device initialization. The following sections describe the specific requirements for the preinitialization stage.

### 26.2.1 Power Connections

The device can be supplied by an external power integrated circuit (IC).

Figure 26-2 shows example power connections between the device and the power IC.

**Figure 26-2. Device and Power Connections**



init\_GN3-001

**NOTE:** Figure 26-2 is an example of power connections between the device and the power IC. These connections depend on the application: For example, if a serial display or camera interface is used, it must be supplied by a low-dropout (LDO) regulator (low noise).

**NOTE:**

- The sys\_clkout output clock cannot be provided to peripherals when the core is off.
- The sys\_clkreq output signal switches the system clock on or off.
- After power-on reset (POR), the hardware configuration enables the internal oscillator (assuming that the input clock comes from a crystal). The decision whether to bypass the internal oscillator is controlled by the polarity of the sys\_boot[6] pin.

**Table 26-1** describes the power pins.

**Table 26-1. Power Pins<sup>(1)</sup>**

| Device Voltage Pin Name | Description                                                                     |
|-------------------------|---------------------------------------------------------------------------------|
| vdd_mpu_iva             | MPU and image and video accelerator (IVA) subsystem power supply                |
| vdd_core                | Core power supply                                                               |
| vdds_io                 | I/O power supply                                                                |
| vdds_mem                | Memory, SDRC, and GPMC I/O power supply                                         |
| vdda_wkup_bg_bb         | Input power for wakeup, band gap and body bias low-dropout regulators (LDO)     |
| vdda_sram               | Input power for SRAM LDOs (common)                                              |
| vdda_dplls_dll          | Input power for digital phase-locked loops (DPLL) and delay-locked loop (DLL)   |
| vdda_dpll_per           | Input power for DPLL (peripheral)                                               |
| vdda_csiphy1            | Dedicated power supply for camera serial interface2 - CSI2a complex I/O         |
| vdds_csiphy2            | Dedicated power supply for CSI2b complex I/O                                    |
| vdda_dsi                | Dedicated power supply for display serial interface (DSI) complex I/O           |
| vdda_dac                | Video buffers and digital-to-analog converter (DAC) power supply                |
| vdds_sdmmc1             | Power supply for multimedia card (MMC)/secure digital (SD) dual voltage buffers |
| vpp                     | eFuse programming voltage                                                       |
| pop_ddr_vdd_ft          | POP DDR core supply <sup>(1)</sup>                                              |
| pop_flash_vdd_ft        | POP FLASH core supply <sup>(1)</sup>                                            |
| pop_flash_vpp_ft        | POP FLASH vpp supply <sup>(1)</sup>                                             |

<sup>(1)</sup> The package-on-package (POP) device provides feedthroughs from the bottom of the package to the POP interface. Among these feedthroughs (FEEDTHROUGH balls), several provide power to the top memory device. The correct power supply to the feedthroughs must be provided based on memory requirements.

For more information about power management, see [Chapter 3, Power, Reset, and Clock Management](#).

## 26.2.2 Clock and Reset

### 26.2.2.1 Clock and Reset Overview

Figure 26-3 shows the clock and reset environment that gathers the clocks and reset signals related at the system level, as well as system expansion signals.

Figure 26-3. Clock and Reset Environment



init-004

The main features of the system interface are:

- A clock request output to an external square clock source
- 12, 13, 16.8, 19.2, 26, or 38.4-MHz reference clock input from the external crystal oscillator (only 12, 13, 16.8, or 19.2 MHz) or the digital clock input (all frequencies)
- 32-kHz CMOS clock input
- An additional clock input up to 54 MHz
- Two configurable output clocks
- Seven input signals to define the boot mode
- Two reset sources
  - POR (cold reset)
  - Bidirectional warm reset

## 26.2.2.2 Clock Configuration

### 26.2.2.2.1 Required System Input Clocks

Figure 26-4 shows the clock interface.

**Figure 26-4. Clock Interface**



Solution 1: Use of internal oscillator:



Solution2: Use of an external square clock source:



**NOTE:**

- The sys\_clkout output clock cannot be provided to peripherals when the core is off.
- The sys\_clkreq output signal switches the system clock on or off.
- After POR, the hardware configuration enables the internal oscillator (assuming that the input clock comes from a crystal). The decision whether to bypass the internal oscillator is controlled by the polarity of the sys\_boot[6] pin.

The device operation requires two external input clocks, as follows:

- sys\_32k: The 32-kHz frequency is used for low-frequency operation.
- sys\_xtal (in/out): The system clock is the main clock source of the device. The system clock input can be connected in either of two ways:
  - Crystal quartz through the sys\_xtalin and sys\_xtalout pins, using an internal oscillator up to 19.2 MHz
  - Complementary metal oxide semiconductor (CMOS) digital clock (square clock) through the sys\_xtalin pin. The oscillator is bypassed.

Table 26-2 lists the mapping for input sources.

**Table 26-2. Mapping For Input Sources**

| Input Source                   | Mapping                              | Frequencies                         | Comment                             |
|--------------------------------|--------------------------------------|-------------------------------------|-------------------------------------|
| Crystal quartz                 | sys_xtalin and sys_xtalout           | 12, 13, 16.8, or 19.2 MHz           | Requires use of internal oscillator |
| Square clock (1.8 CMOS signal) | sys_xtalin (sys_xtalout unconnected) | 12, 13, 16.8, 19.2, 26, or 38.4 MHz | Internal oscillator is bypassed.    |

Because sys\_32k, sys\_xtalin, and sys\_xtalout have permanently assigned pin locations with no pad configuration for these pins through a system control module (SCM) register, only one source input at a time can be used.

#### 26.2.2.2.2 Optional System Input Clock: sys\_altclk

An additional clock can be provided through the sys\_altclk input pin to supply internal peripherals, PLLs, a precise clock for National Television System Committee (NTSC) standard (54 MHz), and a universal serial bus (USB) full-speed (FS) controller (48 MHz). If not used as a clock input, this pin can be configured as a general-purpose input/output (GPIO), using the SCM CONTROL.CONTROL\_PADCONF\_I2C3\_SDA register. As an example, to use the sys\_altclk pin, the CONTROL.CONTROL\_PADCONF\_I2C3\_SDA[18:16] MUXMODE1 bit field must be set to 0x01.

#### 26.2.2.2.3 Optional System Output Clock: sys\_clkout1 and sys\_clkout2

Two output clocks (sys\_clkout1 and sys\_clkout2 pins) are available:

- sys\_clkout1 can output the oscillator clock. Its OFF state polarity is programmable.
- sys\_clkout2 can output the system clock (12, 13, 16.8, 19.2, 26, or 38.4 MHz), the core clock (CORE DPLL output), 96 MHz, or 54 MHz. sys\_clkout2 can be divided by 2, 4, 8, or 16, and its OFF state polarity is programmable.

**CAUTION**

Clock configurations depend on core voltage, and maximum clock frequencies may not be applicable to production.

The clocks can be managed by software with the appropriate register in the power, reset, clock, management (PRCM) module:

- sys\_clkout1 is managed using PRCM.PRM\_CLKOUT\_CTRL and PRCM.PRM\_POLCTRL[2].
- sys\_clkout2 is managed using PRCM.CM\_CLKOUT\_CTRL and PRCM.CM\_CLKSEL1\_PLL[28:27].

#### 26.2.2.3 Reset Configuration

The sys\_nrespwron reset pin resets the entire chip during POR.

The sys\_nreswarm reset pin resets the entire chip when the device is supplied and operating, except for the following:

- Part of synchronous dynamic RAM (SDRAM) controller (SDRC)
- Part of IVA
- Part of PRCM
- Control module
- Watchdog
- 32-kHz synchronization timer
- DPLLS
- SmartReflex™ modules

**CAUTION**

sys\_nrespwron must be driven low during a power-up sequence.

sys\_nreswarm is a bidirectional reset. When an internal reset occurs, sys\_nreswarm goes low and resets all the peripherals. The sys\_nreswarm output is open-drain; consequently, an external pullup resistor is required.

sys\_nrespwron and sys\_nreswarm have permanently assigned pin locations.

At reset, the cause of reset is stored in the PRCM.RM\_RSTST\_MPUR register and used by the boot ROM code.

### 26.2.3 Boot Configuration

Six external pins (sys\_boot[5:0]) are used to select interfaces or devices for booting. The sys\_boot[6] pin is used to select whether the internal oscillator is bypassed.

These seven pins are sampled and latched onto the CONTROL.CONTROL\_STATUS register after POR. After booting, these pins can be used for other functions and the associated CONTROL.CONTROL\_STATUS bits are not updated by the new functionality. For more information about pad multiplexing configuration, see [Chapter 13, System Control Module](#).

---

**NOTE:** If used as GPIOs, these pins must be used in output mode. To ensure that the sys\_boot[6:0] input values are selected by the pullup/down on sys\_boot[6:0] pins at POR, these GPIOs must be used only in output mode. Because these balls have no pullup/down capacity, care must be taken when choosing to use these GPIOs.

---

[Table 26-3](#), [Table 26-4](#), and [Table 26-5](#) are decoding tables for sys\_boot pins. Depending on sys\_boot pin configuration during the reset (leftmost column), the ROM code tries to boot on the first booting device listed. If the boot fails on this first booting device, the ROM code tries the second booting device, then the third, then the fourth.

The following names are used in the tables:

- Memory types:
  - Execute in place (XIP): XIP memory without wait monitoring enabled (NOR flash memories)
  - XIP wait: XIP memory with wait monitoring
  - DOC: DiskOnChip™ memory (H3 device types)
  - NAND: NAND flash memories (non-XIP)
  - OneNAND: OneNAND™ and Flex-OneNAND™ flash memories
  - MMC1: MMC or SD/ eMMC or eSD flash cards connected to the first MMC/Secure Digital Input/Output (SDIO1) card interface
  - MMC2: MMC or SD/ eMMC or eSD flash cards to the second (MMC/SD/SDIO2) card interface
  - MMC2\_H (Hybrid): MMC or SD/ eMMC or eSD flash cards connected to the second (MMC/SD/SDIO2) card interface, but the memory core is powered by VMMC1\_LDO of the power-management IC.
- Peripheral interfaces:
  - USB: High-speed (HS) USB
  - UART3: UART interface
- Permanent booting devices are in *italics*.

[Table 26-3](#) and [Table 26-4](#) list the sys\_boot pin configuration after a POR.

**NOTE:** After reset release, the ROM code tries to boot from several interfaces, one after the other until it finds a bootable one. These interfaces (GPMC, MMC1, MMC2, USB, and UART) are selected in a specific order defined by the sys\_boot settings.

As a consequence, if the first bootable interface found by the ROM code is not the first one in the list, some activity occurs on the interfaces tested before the bootable one.

This must be considered in case these intermediary interfaces are connected to other peripherals for other purposes (for example, an LED connected to a GPMC pad muxed internally to a GPIO).

**CAUTION**

- UART boot: UART3 is the only possible UART from which boot can be performed. Additionally, only UART3 pins that provide UART3 functionality in their MUXMODE 0 can be used. No other UART configuration allows booting from the UART.
- HS USB boot: If the internal USB transceiver of a supported power-management IC is used, the IC's configuration interface must be connected to the device through I<sup>2</sup>C1. No other I<sup>2</sup>C interface is supported for this purpose. If other USB transceiver is used, the ROM code assumes it is powered, clocked, and out of reset.

**Table 26-3. Memory Preferred Booting Configuration Pins After POR**

| sys_boot [4:0] | Booting Sequence When SYS.BOOT[5] = 0 |        |                         |        |       |
|----------------|---------------------------------------|--------|-------------------------|--------|-------|
|                | Memory Preferred Booting Order        |        |                         |        |       |
|                | First                                 | Second | Third                   | Fourth | Fifth |
| 0b00000        |                                       |        | Reserved <sup>(1)</sup> |        |       |
| 0b00001        |                                       |        |                         |        |       |
| 0b00010        |                                       |        |                         |        |       |
| 0b00011        |                                       |        |                         |        |       |
| 0b00100        | OneNAND                               | USB    |                         |        |       |
| 0b00101        | MMC2                                  | USB    |                         |        |       |
| 0b00110        | MMC1                                  | USB    |                         |        |       |
| 0b00111        |                                       |        | Reserved <sup>(1)</sup> |        |       |
| 0b01000        |                                       |        |                         |        |       |
| 0b01001        |                                       |        |                         |        |       |
| 0b01010        |                                       |        |                         |        |       |
| 0b01011        |                                       |        |                         |        |       |
| 0b01100        |                                       |        |                         |        |       |
| 0b01101        | XIP                                   | USB    | UART3                   | MMC1   |       |
| 0b01110        | XIPwait                               | DOC    | USB                     | UART3  | MMC1  |
| 0b01111        | NAND                                  | USB    | UART3                   | MMC1   |       |
| 0b10000        | OneNAND                               | USB    | UART3                   | MMC1   |       |
| 0b10001        | MMC2                                  | USB    | UART3                   | MMC1   |       |
| 0b10010        | MMC1                                  | USB    | UART3                   |        |       |
| 0b10011        | XIP                                   | UART3  |                         |        |       |
| 0b10100        | XIPwait                               | DOC    | UART3                   |        |       |
| 0b10101        | NAND                                  | UART3  |                         |        |       |
| 0b10110        | OneNAND                               | UART3  |                         |        |       |

<sup>(1)</sup> Must not be selected

**Table 26-3. Memory Preferred Booting Configuration Pins After POR (continued)**

| sys_boot [4:0]                 |                                                                      | Booting Sequence When SYS.BOOT[5] = 0 |                               |
|--------------------------------|----------------------------------------------------------------------|---------------------------------------|-------------------------------|
| Memory Preferred Booting Order |                                                                      |                                       |                               |
| 0b10111                        | MMC2                                                                 | UART3                                 |                               |
| 0b11000                        | MMC1                                                                 | UART3                                 |                               |
| 0b11001                        | XIP                                                                  | USB                                   |                               |
| 0b11010                        | XIPwait                                                              | DOC                                   | USB                           |
| 0b11011                        | NAND                                                                 | USB                                   |                               |
| 0b11100                        | MMC2_H                                                               | USB                                   | UART3                         |
| 0b11101                        |                                                                      |                                       | Reserved <sup>(1)</sup>       |
| 0b11110                        |                                                                      |                                       |                               |
| 0b11111                        | Fast XIP booting,<br>Wait monitoring<br>OFF (only for GP<br>devices) | USB (only on GP<br>devices)           | UART3 (only on GP<br>devices) |

**Table 26-4. Peripheral Preferred Booting Configuration Pins After POR**

| sys_boot [4:0]                     |       | Booting Sequence When SYS.BOOT[5] = 1 |        |                         |        |
|------------------------------------|-------|---------------------------------------|--------|-------------------------|--------|
| Peripheral Preferred Booting Order |       |                                       |        |                         |        |
|                                    |       | First                                 | Second | Third                   | Fourth |
| 0b00000                            |       |                                       |        | Reserved <sup>(1)</sup> |        |
| 0b00001                            |       |                                       |        |                         |        |
| 0b00010                            |       |                                       |        |                         |        |
| 0b00011                            |       |                                       |        |                         |        |
| 0b00100                            | USB   | OneNAND                               |        |                         |        |
| 0b00101                            | USB   | MMC2                                  |        |                         |        |
| 0b00110                            | USB   | MMC1                                  |        |                         |        |
| 0b00111                            |       |                                       |        | Reserved <sup>(1)</sup> |        |
| 0b01000                            |       |                                       |        |                         |        |
| 0b01001                            |       |                                       |        |                         |        |
| 0b01010                            |       |                                       |        |                         |        |
| 0b01011                            |       |                                       |        |                         |        |
| 0b01100                            |       |                                       |        |                         |        |
| 0b01101                            | USB   | UART3                                 | MMC1   | XIP                     |        |
| 0b01110                            | USB   | UART3                                 | MMC1   | XIPwait                 | DOC    |
| 0b01111                            | USB   | UART3                                 | MMC1   | NAND                    |        |
| 0b10000                            | USB   | UART3                                 | MMC1   | OneNAND                 |        |
| 0b10001                            | USB   | UART3                                 | MMC1   | MMC2                    |        |
| 0b10010                            | USB   | UART3                                 | MMC1   |                         |        |
| 0b10011                            | UART3 | XIP                                   |        |                         |        |
| 0b10100                            | UART3 | XIPwait                               | DOC    |                         |        |
| 0b10101                            | UART3 | NAND                                  |        |                         |        |
| 0b10110                            | UART3 | OneNAND                               |        |                         |        |
| 0b10111                            | UART3 | MMC2                                  |        |                         |        |
| 0b11000                            | UART3 | MMC1                                  |        |                         |        |
| 0b11001                            | USB   | XIP                                   |        |                         |        |
| 0b11010                            | USB   | XIPwait                               | DOC    |                         |        |
| 0b11011                            | USB   | NAND                                  |        |                         |        |
| 0b11100                            | USB   | UART3                                 | MMC2_H |                         |        |

<sup>(1)</sup> Must not be selected

**Table 26-4. Peripheral Preferred Booting Configuration Pins After POR (continued)**

| sys_boot [4:0] |                                                                     | Booting Sequence When SYS.BOOT[5] = 1 |                               |
|----------------|---------------------------------------------------------------------|---------------------------------------|-------------------------------|
|                |                                                                     | Peripheral Preferred Booting Order    |                               |
| 0b11101        |                                                                     |                                       | Reserved <sup>(1)</sup>       |
| 0b11110        |                                                                     |                                       |                               |
| 0b11111        | Fast XIP booting.<br>Wait monitoring<br>ON (only for GP<br>devices) | USB (only on GP<br>devices)           | UART3 (only on GP<br>devices) |

Table 26-5 shows the sys\_boot pin configuration after a warm reset.

**Table 26-5. Booting Configuration Pins After a Warm Reset**

| sys_boot[4:0] | Booting Sequence When SYS.BOOT[5] = 0           |                         | Booting Sequence When SYS.BOOT[5] = 1           |        |
|---------------|-------------------------------------------------|-------------------------|-------------------------------------------------|--------|
|               | Memory Preferred Booting Order                  |                         | Peripheral Preferred Booting Order              |        |
|               | First                                           | Second                  | First                                           | Second |
| 0b00000       | OneNAND                                         |                         | OneNAND                                         |        |
| 0b00001       | NAND                                            |                         | NAND                                            |        |
| 0b00010       | OneNAND                                         |                         | OneNAND                                         |        |
| 0b00011       | MMC2                                            |                         | MMC2                                            |        |
| 0b00100       | OneNAND                                         |                         | OneNAND                                         |        |
| 0b00101       | MMC2                                            |                         | MMC2                                            |        |
| 0b00110       | MMC1                                            |                         | MMC1                                            |        |
| 0b00111       | XIP                                             |                         | XIP                                             |        |
| 0b01000       | XIPwait                                         | DOC                     | XIPwait                                         | DOC    |
| 0b01001       | MMC2                                            |                         | MMC2                                            |        |
| 0b01010       | XIP                                             |                         | XIP                                             |        |
| 0b01011       | XIPwait                                         | DOC                     | XIPwait                                         | DOC    |
| 0b01100       | NAND                                            |                         | NAND                                            |        |
| 0b01101       | XIP                                             |                         | XIP                                             |        |
| 0b01110       | XIPwait                                         | DOC                     | XIPwait                                         | DOC    |
| 0b01111       | NAND                                            |                         | NAND                                            |        |
| 0b10000       | OneNAND                                         |                         | OneNAND                                         |        |
| 0b10001       | MMC2                                            |                         | MMC2                                            |        |
| 0b10010       | MMC1                                            |                         | MMC1                                            |        |
| 0b10011       | XIP                                             |                         | XIP                                             |        |
| 0b10100       | XIPwait                                         | DOC                     | XIPwait                                         | DOC    |
| 0b10101       | NAND                                            |                         | NAND                                            |        |
| 0b10110       | OneNAND                                         |                         | OneNAND                                         |        |
| 0b10111       | MMC2                                            |                         | MMC2                                            |        |
| 0b11000       | MMC1                                            |                         | MMC1                                            |        |
| 0b11001       | XIP                                             |                         | XIP                                             |        |
| 0b11010       | XIPwait                                         | DOC                     | XIPwait                                         | DOC    |
| 0b11011       | NAND                                            |                         | NAND                                            |        |
| 0b11100       | MMC2_H                                          |                         | MMC2_H                                          |        |
| 0b11101       |                                                 | Reserved <sup>(1)</sup> |                                                 |        |
| 0b11110       |                                                 |                         |                                                 |        |
| 0b11111       | ROM code fast XIP booting (only for GP devices) |                         | ROM code fast XIP booting (only for GP devices) |        |

<sup>(1)</sup> Must not be selected

## 26.3 Power, Clocks, and Reset Power-Up Sequence

See [Chapter 3, Power, Reset, and Clock Management](#), section *Power-Up Sequence*, for the power-on sequence, including power supplies, clocks, and reset signals.

## 26.4 Device Initialization by ROM Code

This section describes high-level booting concepts and provides basic knowledge for booting on the device.

### 26.4.1 Booting Overview

#### CAUTION

To use the level 2 (L2) cache with the device, the ROM code provides three primitive services. These services are implemented in monitor mode and do not use any resources outside the MPU subsystem. The services are described below. To call a service, a register r12 must be set to service ID and the SMI instruction must be executed.

- r12=1: To use the L2 cache, all L2 line data must be invalidated through the CP15 registers. This service invalidates the entire L2 cache and must be performed after a POR or a loss of L2 cache after reset. This register can also be read.
- r12=2: This service writes the value of the central processing unit (CPU) register R0 in the L2 cache auxiliary control register. This register can also be read.
- r12=3: This service writes the value of the CPU register R0 in the auxiliary control. This register can also be read. For more information about ARM L2 cache and registers, see the *Cortex-A8 Technical Reference Manual*. For more information about ARM CP15 registers, see the *ARM Architecture Reference Manual*.

---

**NOTE:** When the ROM Code branches to the first instruction of a GP device Initial software, the L2 cache is disabled.

---

#### 26.4.1.1 Booting Types

Bootstrapping is the process of starting a bootstrap from one of the booting memories.

The ROM code has two booting functions: peripheral booting and memory booting.

- In peripheral booting, the ROM code polls a selected communication interface such as UART or USB, downloads the executable code over the interface, and executes it in internal RAM. Downloaded software from an external host can be used to program flash memories connected to the device. This special case of peripheral booting is called preflashing; software downloaded for preflashing is called the flash loader. The flash loader burns a new client application image in external flash memory. Initial software is a generic term for bootstrap, downloaded software, and flash loader. After the image is burned, a software reset can be performed.
- In memory booting, the ROM code finds the bootstrap in permanent memories such as flash memory or memory cards and executes it. This process is normally performed after cold or warm device reset.

The ROM code detects whether the device should download software from a peripheral interface (HS USB or UART 3) by using the sys\_boot pin configuration. This mechanism encompasses initial flashing in production (external memory is empty) and reflashing in service (external memory is already programmed).

**NOTE:** After reset release, the ROM code tries to boot from several interfaces, one after the other until it finds a bootable one. These interfaces (GPMC, MMC1, MMC2, USB, and UART) are selected in a specific order defined by the sys\_boot settings.

As a consequence, if the first bootable interface found by the ROM code is not the first one in the list, some activity occurs on the interfaces tested before the bootable interface. This should be considered in case these intermediary interfaces are connected to other peripherals for some other purposes (an LED connected to a GPMC pad muxed internally to a GPIO for instance).

[Table 26-6](#) lists the pin multiplexing according to boot peripheral.

**Table 26-6. Pin Multiplexing According to Boot Peripheral**

| Boot Device  | Pins                                                    |
|--------------|---------------------------------------------------------|
| NAND/OneNAND | General-purpose memory controller (GPMC) pins in mode 0 |
| XIP memory   | GPMC pins in mode 0                                     |
| DiskOnChip   | GPMC pins in mode 0                                     |
| MMC/SD1      | MMC1 pins in mode 0                                     |
| MMC/SD2      | MMC2 pins in mode 0                                     |
| UART3        | UART3 pins in mode 0                                    |
| HS USB       | HSUSBO pins in mode 0                                   |

**CAUTION**

- **UART boot:** UART3 is the only possible UART from which boot can be performed. Additionally, only UART3 pins that provide UART3 functionality in their MUXMODE 0 can be used. No other UART configuration allows booting from the UART.
- **HS USB boot:** If the internal USB transceiver of a supported power-management IC is used, the IC's configuration interface must be connected to the device through I<sup>2</sup>C1. No other I<sup>2</sup>C interface is supported for this purpose. If other USB transceiver is used, the ROM code assumes it is powered, clocked, and out of reset.

#### 26.4.1.2 Main Features

The ROM code architecture is shown in [Figure 26-5](#). The ROM code is made up of several modules:

- The start-up module takes care of basic system configuration and dispatches control to the booting module.
- The clock detection module supports startup by detecting the system clock frequency.
- The booting module uses several device drivers to boot from an external device.
- The device drivers implement device protocols and perform logical operation on a device. They are abstracted from interface hardware by several interface drivers, which are responsible for interacting with hardware interface facilities.
- The interrupt handler module provides services used by all modules. It allows registering interrupt service routines (ISRs) and calls them when an interrupt occurs.

[Figure 26-5](#) shows each module.

Figure 26-5. ROM Code Architecture



## 26.4.2 Memory Map

### 26.4.2.1 ROM Memory Map

Figure 26-6 shows the ROM memory map.

**Figure 26-6. 32KB ROM Memory Map**



- ROM exception vectors

Exceptions are redirected to ROM exception vectors (see [Table 26-7](#)). The reset exception is redirected to the public ROM code startup. Other exceptions are redirected to RAM handlers by loading appropriate addresses in the PC register.

**Table 26-7. ROM Exception Vectors**

| Address | Exception                | Content                               |
|---------|--------------------------|---------------------------------------|
| 14000h  | Reset                    | Branch to the public ROM code startup |
| 14004h  | Undefined                | PC = 4020FFC8h                        |
| 14008h  | Software interrupt (SWI) | PC = 4020FFCCh                        |
| 1400Ch  | Prefetch abort           | PC = 4020FFD0h                        |
| 14010h  | Data abort               | PC = 4020FFD4h                        |
| 14014h  | Unused                   | PC = 4020FFD8h                        |
| 14018h  | IRQ                      | PC = 4020FFDCh                        |
| 1401Ch  | FIQ                      | PC = 4020FFE0h                        |

- ROM code cyclic redundancy check (CRC)

The ROM code CRC is calculated as 32-bit CRC code (CRC-32-IEEE 802.3) for the address range 14000h – 1BFFFh. The 4-byte CRC code is stored at location 14020h.

- Dead loops

Dead loops are branch instructions coded in ARM mode. They have multiple purposes (see [Table 26-8](#)).

**Table 26-8. Dead Loops**

| Address | Purpose                                  |
|---------|------------------------------------------|
| 14080h  | Undefined exception default handler      |
| 14084h  | SWI exception default handler            |
| 14088h  | Prefetch abort exception default handler |
| 1408Ch  | Data abort exception default handler     |
| 14090h  | Unused exception default handler         |
| 14094h  | IRQ exception default handler            |
| 14098h  | FIQ exception default handler            |
| 1409Ch  | Validation tests Pass                    |
| 140A0h  | Validation tests Fail                    |
| 140A4h  | Booting failed: No more booting devices  |
| 140A8h  | Image not executed or returned           |
| 140ACh  | Reserved                                 |
| 140B0h  | Reserved                                 |
| 140B4h  | Reserved                                 |
| 140B8h  | Reserved                                 |
| 140BCh  | Reserved                                 |

The fixed location of these dead loops facilitates debugging and testing. The first seven dead loops are default exception handlers linked with RAM exception vectors.

Dead loops can be called directly from code, but there is also a special function called from ROM code to execute a dead loop. This function is at address 140C0h. The function is assembly code in ARM mode, which takes the dead loop address from the R0 register. The main purpose of the function is to issue a global software reset before going to a dead loop. In addition, the function clears the global cold reset status before issuing the global software reset.

- Code

This space is used to keep code.

- Code and data

This space is used to keep code and other data.

- ROM code version

The ROM code version consists of two decimal numbers: major and minor. The major number is 18. The minor number identifies the ROM code version. The minor number is not aligned with the ROM code release number, but it can identify it. The ROM code version is coded as hexadecimal readable values (for example, ROM version 18.04 is coded as a 32-bit word: 00001804h).

#### 26.4.2.2 RAM Memory Map

Figure 26-7 shows the RAM memory map. The partitioning of the on-chip SRAM shown in Figure 26-7 is used only during the booting process.

**Figure 26-7. 64KB RAM Memory Map of GP Devices**

- Downloaded image  
This space is used by the public ROM code to store a downloaded booting image.
- Public stack  
This space is reserved for stacks.
- Tracing data  
The public ROM code tracing data is described in [Table 26-9](#). More information about ROM code tracing can be found in [Section 26.4.9, Tracing](#).

**Table 26-9. Tracing Data**

| Address    | Size [Bytes] | Description                                            |
|------------|--------------|--------------------------------------------------------|
| 0x4020FFB0 | 4            | Current tracing vector, word 1                         |
| 0x4020FFB4 | 4            | Current tracing vector, word 2                         |
| 0x4020FFB8 | 4            | Current copy of the PRM_RSTST register (reset reasons) |
| 0x4020FFBC | 4            | Cold reset run tracing vector, word 1                  |
| 0x4020FFC0 | 4            | Cold reset run tracing vector, word 2                  |
| 0x4020FFC4 | 4            | Reserved                                               |

- RAM exception vectors

The RAM exception vectors provide an easy way to redirect exceptions to the custom handler. [Table 26-10](#) shows the contents of the RAM space reserved for RAM vectors. The first seven addresses are ARM instructions that load into the PC the value in the next seven addresses. These instructions are executed when an exception occurs, because they are called from ROM exception vectors. By default, all exceptions are redirected to the exception dead loops. Users can redirect an exception to another handler by writing its address to the appropriate position from 0x4020FFE4 to 0x4020FFFC, or by overriding instructions between addresses from 0x4020FFC8 to 0x4020FFE0.

**Table 26-10. RAM Exception Vectors**

| Address    | Exception      | Content           |
|------------|----------------|-------------------|
| 0x4020FFC8 | Undefined      | PC = [0x4020FFE4] |
| 0x4020FFCC | SWI            | PC = [0x4020FFE8] |
| 0x4020FFD0 | Prefetch abort | PC = [0x4020FFEC] |

**Table 26-10. RAM Exception Vectors (continued)**

| Address    | Exception                    | Content           |
|------------|------------------------------|-------------------|
| 0x4020FFD4 | Data abort                   | PC = [0x4020FFF0] |
| 0x4020FFD8 | Unused                       | PC = [0x4020FFF4] |
| 0x4020FFDC | IRQ                          | PC = [0x4020FFF8] |
| 0x4020FFE0 | FIQ                          | PC = [0x4020FFFC] |
| 0x4020FFE4 | Undefined                    | 0x14080           |
| 0x4020FFE8 | SWI                          | 0x14084           |
| 0x4020FFEC | Prefetch abort               | 0x14088           |
| 0x4020FFF0 | Data abort                   | 0x1408C           |
| 0x4020FFF4 | Unused                       | 0x14090           |
| 0x4020FFF8 | Interrupt request (IRQ)      | 0x14094           |
| 0x4020FFFC | Fast interrupt request (FIQ) | 0x14098           |

### 26.4.3 Overall Booting Sequence

Figure 26-8 is the ROM code flow chart.

**Figure 26-8. Overall Booting Sequence**



init-007

The main loop of the booting module goes through the booting device list and tries to get an image from the currently selected booting device. The ROM code performs the following steps:

- Step 1. Basic configurations and initializations.
- Step 2. The path named fast external boot is a special low-latency boot mode. It consists of a blind jump to the external addressable memory as soon as possible.
- Step 3. A booting device list is created (see [Section 26.4.4.3, Booting Device List Setup](#)). The list consists of all booting devices to be searched for a booting image. The list is created based on the sys\_boot pins and the software booting configuration described in [Section 26.4.4.4, Software Booting Configuration](#). The software booting configuration structure is in the scratchpad memory and can be written by software before executing a software reset. The scratchpad memory is an internal RAM memory that keeps its contents as long as the power is supplied and is not influenced by wakeups or resets. After a software reset, the software booting configuration has priority over the sys\_boot pin configuration.
- Step 4. After the booting device list is set, the booting procedure examines the booting devices on the list serially and executes memory booting or peripheral booting, depending on current booting device type:
  - Memory booting is executed when the booting device is permanent: XIP memory, NAND, DiskOnChip, OneNAND/Flex-OneNAND, or MMC/SD cards.
  - Peripheral booting is executed when booting device is temporary: UART or USB.
- Step 5. Memory booting reads data from memory type booting devices. Memory booting is described in detail in [Section 26.4.7, Memory Booting](#).
- Step 6. Peripheral booting downloads data from communication interfaces. The ROM code uses a simple logical protocol with peripheral booting. First, the device sends an ASIC-ID structure to inform the host about the peripheral booting start. The host responds by sending a booting message that can have one of three meanings:
  - Skip peripheral booting.
  - Continue peripheral booting.
  - Change the booting device.
 If the message is to continue, the host sends the entire image preceded by its size. Peripheral booting is described in [Section 26.4.5, Peripheral Booting](#).
- Step 7. For this booting device, the image is automatically started.

An additional feature of the booting module is the execution of the configuration header (CH). The CH configures the system for faster and more flexible booting from the selected permanent booting device. The CH, which is optional, is described in [Section 26.4.8.2, Configuration Header](#).

## 26.4.4 Startup and Configuration

### 26.4.4.1 Startup

The ROM code starts at address 0x0001 4000.

### 26.4.4.2 Clocking Configuration

The ROM code detects the system input clock frequency. The supported frequencies are:

- 12 MHz
- 13 MHz
- 16.8 MHz
- 19.2 MHz
- 26 MHz
- 38.4 MHz

After detecting the input clock, the ROM code configures the clocks and DLLs required for ROM code execution.

The configured DPLLS are:

- Peripheral DPLL, set to provide 96 MHz and 48 MHz for peripheral blocks
- MPU DPLL, set to provide 96 MHz for the Cortex-A8 MPU
- Core DPLL, set to provide 192, 96, 48, or 24 MHz for various blocks, such as interconnect, clocked by this DPLL output

The multipliers and dividers of the DPLLS are set to values which depend on the input clock detected.

[Table 26-11](#) summarizes the ROM code default settings for key clocks.

**Table 26-11. ROM Code Default Clock Settings**

| Clock      | Frequency [MHz] | Source                            |
|------------|-----------------|-----------------------------------|
| CORE.CLOCK | 192             | CORE DPLL output                  |
| L3x2.CLOCK | 192             | CORE.CLOCK                        |
| L3.ICLK    | 96              | CORE.CLOCK/2                      |
| L4.ICLK    | 48              | L3.ICLK/2                         |
| RM clock   | 24              | L4.ICLK/2                         |
| MPU        | 96              | CORE.CLOCK/2 (MPU DPLL in bypass) |

The DPLLS and other settings are configured by default after each type of reset to give the ROM code the same working conditions. However, it is possible to override the default clock settings by means of the software booting configuration; for details, see [Section 26.4.4.4, Software Booting Configuration](#).

There are three ways to change DPLLS and all related clock divider, gating, and multiplexer configurations during the boot:

- ROM code default settings, described in this paragraph
- Software booting configuration after a software reset, described in [Section 26.4.4.4, Software Booting Configuration](#)
- CH, described in [Section 26.4.8.2, Configuration Header](#). This configuration can be blocked by the software booting configuration; this is possible during the memory booting. The CH lets the user have a known configuration (about GPMC, SDRC, and clock registers) after memory booting.

#### 26.4.4.3 Booting Device List Setup

The ROM code creates a booting device list based on two sources:

- The software booting configuration is stored in the scratchpad memory.
- The sys\_boot[5:0] pins are used to index the booting device table from which the list of booting devices is extracted.

[Figure 26-9](#) shows how the ROM code sets up the booting device list depending on the reset source.

**NOTE:** Only permanent booting devices are put on the list when reset is not power on and booting devices are taken from the sys\_boot pins. Users can force peripheral booting after software reset using software booting configuration.

**Figure 26-9. Booting Device List Setup**

#### 26.4.4.4 Software Booting Configuration

The software booting configuration is stored in the special scratchpad memory, which is not cleared after resets or wakeups. The software booting configuration is a simple structure at the address stored at the first location of available scratchpad memory: 0x48002910. [Table 26-12](#) shows the software booting configuration. There are two sections in this structure:

- The first section provides booting devices for the booting device list.
- The second section provides clock settings, which are applied before booting.

The sections are not mandatory and their order is not important. The ROM code searches for the next section at the location based on the size filled in the previous section. The clock configuration from software booting configuration overwrites the CH settings.

**Table 26-12. Software Booting Configuration Structure**

| Field                     | Size [bytes] | Description                                                                                                                                                                     |
|---------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Boot Configuration</b> |              |                                                                                                                                                                                 |
| Section 1 key             | 4            | Synchronization key for section 1: 0xCF00AA01                                                                                                                                   |
| Section 1 size            | 4            | Size of section 1: 0x0000000C (12)                                                                                                                                              |
| Flags                     | 2            | Bits [4:1]: Mask the CH, when one of these 4 bits is set to 1, the CH section is not analyzed:<br>[1]: SETTINGS section<br>[2]: RAM<br>[3]: FLASH (GPMC)<br>[4]: MMCSD          |
| First booting device      | 2            | Devices to be put on the booting device list<br>0x00: Void, no booting device<br>0x01: XIP memory<br>0x02: NAND<br>0x03: OneNAND<br>0x04: DOC<br>0x05: MMC/SD2<br>0x06: MMC/SD1 |
| Second booting device     | 2            |                                                                                                                                                                                 |

**Table 26-12. Software Booting Configuration Structure (continued)**

| Field                              | Size [bytes] | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Third booting device               | 2            | 0x07: XIP memory with wait monitoring<br>0x08: MMC/SD2 Hybrid connection<br>0x09 to 0x0F: Reserved<br>0x10: UART<br>0x11: HS USB<br>Others: Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Fourth booting device              |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Padding                            | 2            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>Clock Settings</b>              |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Section 2 key                      | 4            | Synchronization key for section 2: 0xCF00AA02                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Section 2 size                     | 4            | Size of section 2: 0x00000048 (72)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Flags                              | 4            | Bit mask of various switches, active when set to 1:<br>Bit [0]: If 1, the clock configuration defined in this structure is applied.<br>Bit [1]: Reserved<br>Bit [2]: Perform clock configuration settings.<br>Bit [3]: Set and lock DPLL4 PER.<br>Bit [4]: Set and lock DPLL1 (MPU).<br>Bit [5]: Set and lock DPLL3 (CORE).<br>Bit [6]: Bypass DPLL4 before setting clocks.<br>Bit [7]: Bypass DPLL1 before setting clocks.<br>Bit [8]: Bypass DPLL3 before setting clocks.<br>Bits [24..31]: System clock ID<br><br>Must be set accordingly to the SYS.CLK:<br>0x01: 12 MHz<br>0x02: 13 MHz<br>0x03: 16.8 MHz<br>0x04: 19.2 MHz<br>0x05: 26 MHz<br>0x06: 38.4 MHz<br>Others: Reserved, must not be set |
| <b>General Clock Settings</b>      |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| PRM_CLKSRC_CTRL                    | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PRM_CLKSEL                         | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CM_CLKSEL1_EMU                     | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>Clock Configuration</b>         |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| CM_CLKSEL_CORE                     | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CM_CLKSEL_WKUP                     | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>DPLL3 (Core) Settings</b>       |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| CM_CLKEN_PLL                       | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CM_AUTOIDLE_PLL                    | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CM_CLKSEL1_PLL                     | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>DPLL4 (Peripheral) Settings</b> |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| CM_CLKEN_PLL                       | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CM_AUTOIDLE_PLL                    | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CM_CLKSEL2_PLL                     | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CM_CLKSEL3_PLL                     | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>DPLL1 (MPU) Settings</b>        |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| CM_CLKEN_PLL_MPU                   | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CM_AUTOIDLE_PLL_MPU                | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CM_CLKSEL1_PLL_MPU                 | 4            | Register value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

**Table 26-12. Software Booting Configuration Structure (continued)**

| Field              | Size [bytes] | Description    |
|--------------------|--------------|----------------|
| CM_CLKSEL2_PLL_MPU | 4            | Register value |
| CM_CLKSTCTRL_MPU   | 4            | Register value |

## 26.4.5 Peripheral Booting

### 26.4.5.1 Overview

The ROM code can boot from two different peripherals:

- HS USB: HS USB interface
- UART 3: Baud rate 115.2 Kbps, 8 bits, even parity, 1 stop-bit

The purpose of booting from a peripheral is to boot from an external host, such as a PC. This booting method is used primarily for programming flash memories connected to the device. The protocol is common to all peripherals. Some minor exceptions are described in the following sections. The common peripheral booting protocol is shown in [Figure 26-10](#).

**Figure 26-10. Common Peripheral Booting Protocol**

The ROM code first initializes the interface and sends a message called ASIC-ID to a host. The content of this message is summarized in [Table 26-13](#). The host uses this message to send only appropriate data to the device according to the identification codes sent.

The ROM code waits 300 ms for an answer from UART and 3 s from USB host. If a time-out occurs, the peripheral booting returns to the main booting procedure with TIMEOUT status.

**Table 26-13. ASIC-ID Structure**

| ASIC-ID Item                | Size [Bytes] | Description                       |
|-----------------------------|--------------|-----------------------------------|
| Items                       | 1            | Number of subblocks               |
| ID subblock                 | 7            | Device identification information |
| Reserved for non-GP devices | 4            | Reserved                          |
| ID subblock                 | 23           | Identification data               |
| Reserved for non-GP devices | 23           | Reserved                          |
| Checksum subblock           | 11           | CRC (4 bytes)                     |

The host can send different messages, as described in [Table 26-14](#). If the second or third message is not received, the ROM code stops the current peripheral booting procedure and returns to the main booting, which determines the next booting device according to the boot message received.

If the first message is received without a time-out, the image size (a 32-bit word) and the image itself are expected to be received. The image is downloaded directly at address 0x40200000 in the internal RAM.

The ROM code waits up to 1 minute for completion. If the downloading procedure does not complete before this period, the peripheral booting fails. If the download passes, the peripheral booting succeeds and the image can be executed.

**Table 26-14. Boot Messages**

| Message Name          | Value      | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Peripheral boot       | 0xF0030002 | Continue peripheral booting.                                                                                                                                                                                                                                                                                                                                                                |
| Change booting device | 0xF003XX06 | Skip current peripheral booting and continue booting from booting device type indicated by XX:<br><br>0x00: Void, no booting device<br>0x01: XIP memory<br>0x02: NAND<br>0x03: OneNAND<br>0x04: DOC<br>0x05: MMC/SD2<br>0x06: MMC/SD1<br>0x07: XIP memory with wait monitoring<br>0x08: MMC/SD2 Hybrid connection<br>0x09..0x0F: Reserved<br>0x10: UART<br>0x11: HS USB<br>Others: Reserved |
| Next booting device   | 0xFFFFFFFF | Skip current booting device and move to the next booting device on the device list.                                                                                                                                                                                                                                                                                                         |
| Memory booting        | Others     | Skip current peripheral booting and move to the first booting device for memory booting.                                                                                                                                                                                                                                                                                                    |

Figure 26-11 shows the peripheral booting procedure.

**Figure 26-11. Peripheral Booting Procedure**



init-010

### **26.4.5.2 UART**

The ROM code supports booting from a UART interface with the following characteristics:

- UART interface 3 at UART3 pins
- Communication parameters set to 115.2 Kbps, 8 bits, even parity, 1 stop-bit
- Two-pin interface: RX/TX with software flow control (XON/XOFF). The other UART pins are left at their default configuration.
- The UART wait for boot message time-out is 300 ms.

### **26.4.5.3 USB**

The ROM code supports booting from a USB interface with the following characteristics:

- HS USB interface
- USB 2.0 transceiver macrocell interface (UTMI)+ low pin interface (ULPI) 8-bit data transceiver support (single data rate)
- Power IC detection and automatic configuration of its USB transceiver using I2C1
- The enumeration time-out is 3 seconds.
- The USB wait for boot message time-out is 3 seconds

The ROM code USB driver conforms with the USB 2.0 specification and the USB on-the-go (OTG) supplement. It supports transactions at HS (that is, 480 Mbps) and FS (that is, 12 Mbps). During peripheral booting, only the USB device functionality is used. The driver resides in the on-chip memory (OCM) ROM, which is small. The driver therefore contains the minimum functionality needed as a USB device and is not a full-fledged driver. It does not contain the functionality needed for a USB host. The device functionality of the USB OTG controller is used for the peripheral booting process in the ROM code.

#### **26.4.5.3.1 USB Driver Descriptors**

USB devices report their attributes using descriptors. A descriptor is a data structure with a defined format. Each descriptor begins with a byte-wide field that contains the total number of bytes in the descriptor followed by a byte-wide field that identifies the descriptor type. Using descriptors allows concise storage of the attributes of individual configurations so that each configuration can reuse descriptors or portions of descriptors from other configurations that have the same characteristics. Where appropriate, descriptors contain references to string descriptors. String descriptors contain displayable, human-readable information that describes a descriptor. These descriptor details can be used for tool development or debugging:

- Device descriptor

A device descriptor contains general information about a USB device, including information that applies globally to the device and all device configurations. A USB device has only one device descriptor.

Because the ROM code uses the HS feature of the USB core, a device-qualifier descriptor is required.

[Table 26-15](#) describes the device descriptors.

**Table 26-15. Device Descriptor**

| Field           | Value                    | Description                                                           |
|-----------------|--------------------------|-----------------------------------------------------------------------|
| bLength         | 0x12                     | Size of this descriptor in bytes                                      |
| bDescriptorType | 0x01                     | Device descriptor type                                                |
| bcdUSB          | 0x0210                   | USB specification release number in binary coded decimal (BCD) format |
| bDeviceClass    | Vendor-specific (0xFF)   | Class code                                                            |
| bDeviceSubClass | Vendor-specific (0xFF)   | Subclass code                                                         |
| bDeviceProtocol | Vendor-specific (0xFF)   | Protocol code                                                         |
| bMaxPacketSize0 | 0x40                     | Maximum packet size for endpoint 0                                    |
| idVendor        | 0x0451                   | Vendor ID (TI default table)                                          |
| idProduct       | Device-specific (0xD00E) | Product ID (TI default table)                                         |

**Table 26-15. Device Descriptor (continued)**

| Field              | Value                                             | Description                                                |
|--------------------|---------------------------------------------------|------------------------------------------------------------|
| bcdDevice          | 0x0000                                            | Device release number                                      |
| iManufacturer      | See values in <a href="#">Section 26.4.5.3.2.</a> | Index of string descriptor describing manufacturer         |
| iProduct           | See values in <a href="#">Section 26.4.5.3.2.</a> | Index of string descriptor describing product              |
| iSerialNumber      | See values in <a href="#">Section 26.4.5.3.2.</a> | Index of string descriptor describing device serial number |
| bNumConfigurations | 0x01                                              | Number of possible configurations                          |

- Device-qualifier descriptor

The device-qualifier descriptor contains information about a HS-capable device that changes if the device operates at its other speed. This descriptor is retrieved by the host using the GetDescriptor() request (standard device request). [Table 26-16](#) describes a device-qualifier descriptor.

**Table 26-16. Device-Qualifier Descriptor**

| Field              | Value  | Description                             |
|--------------------|--------|-----------------------------------------|
| bLength            | 0x0a   | Size of this descriptor in bytes        |
| bDescriptorType    | 0x06   | Device-qualifier descriptor type        |
| bcdUSB             | 0x0210 | USB specification release number in BCD |
| bDeviceClass       | 0xFF   | Class code                              |
| bDeviceSubClass    | 0xFF   | Subclass code                           |
| bDeviceProtocol    | 0xFF   | Protocol code                           |
| bMaxPacketSize0    | 0x40   | Maximum packet size for endpoint 0      |
| bNumConfigurations | 0x01   | Number of possible configurations       |
| bReserved          | 0x00   | Reserved for future use                 |

- Configuration descriptor

This descriptor gives information about a specific device configuration. The descriptor describes the number of interfaces supported by the configuration. See [Table 26-17](#) for details.

**Table 26-17. Configuration Descriptor**

| Field               | Value | Description                                                    |
|---------------------|-------|----------------------------------------------------------------|
| bLength             | 0x09  | Size of this descriptor in bytes                               |
| bDescriptorType     | 0x02  | Configuration descriptor type                                  |
| wTotalLength        | -     | Combined length of all descriptors                             |
| bNumInterfaces      | 0x01  | Number of interfaces supported                                 |
| bConfigurationValue | 0x01  | Value to use as an argument for the SetConfiguration() request |
| iConfiguration      | Index | Index of string descriptor describing this configuration       |
| bmAttributes        | 0xc0  | Power setting and remote wakeup                                |
| bMaxPower           | 0x32  | Maximum power consumption of the USB device                    |

- Other speed configuration descriptor

This descriptor describes the configuration of a HS-capable device if it operates at its other possible speed. See [Table 26-18](#) for details.

**Table 26-18. Other Speed Configuration Descriptor**

| Field           | Value | Description                               |
|-----------------|-------|-------------------------------------------|
| bLength         | 0x09  | Size of this descriptor in bytes          |
| bDescriptorType | 0x07  | Other speed configuration descriptor type |

**Table 26-18. Other Speed Configuration Descriptor (continued)**

| Field               | Value | Description                                                    |
|---------------------|-------|----------------------------------------------------------------|
| wTotalLength        | -     | Combined length of all descriptors                             |
| bNumInterfaces      | 0x01  | Number of interfaces supported                                 |
| bConfigurationValue | 0x01  | Value to use as an argument for the SetConfiguration() request |
| iConfiguration      | Index | Index of string descriptor describing this configuration       |
| bmAttributes        | 0xc0  | Power setting and remote wakeup                                |
| bMaxPower           | 0x32  | Maximum power consumption of the USB device                    |

- Interface descriptor

This descriptor describes a specific interface in a configuration. See [Table 26-19](#) for details.

**Table 26-19. Interface Descriptor**

| Field              | Value | Description                                          |
|--------------------|-------|------------------------------------------------------|
| bLength            | 0x09  | Size of this descriptor in bytes                     |
| bDescriptorType    | 0x04  | Interface descriptor type                            |
| bInterfaceNumber   | 0x00  | Number of this descriptor                            |
| bAlternateSetting  | 0x00  | Value to select the alternate setting                |
| bNumEndpoints      | 0x02  | Number of endpoints used for this interface          |
| bInterfaceClass    | 0xFF  | Class code                                           |
| bInterfaceSubClass | 0xFF  | Subclass code                                        |
| bInterfaceProtocol | 0xFF  | Protocol code                                        |
| iInterface         | Index | Index of string descriptor describing this interface |

- Endpoint descriptor

Each endpoint used for an interface has its own descriptor. This descriptor contains information required by the host to determine the bandwidth requirements of each endpoint. This descriptor is returned as part of the GetDescriptor(Configuration) request. See [Table 26-20](#) and [Table 26-21](#) for details.

**Table 26-20. BULK IN Endpoint Descriptor**

| Field            | Value                | Description                                 |
|------------------|----------------------|---------------------------------------------|
| bLength          | 0x07                 | Size of this descriptor in bytes            |
| bDescriptorType  | 0x05                 | Endpoint descriptor type                    |
| bEndpointAddress | 0x81 (1 IN)          | Address of the endpoint on the USB device   |
| bmAttributes     | 0x02 (Bulk)          | Type of transfer                            |
| wMaxPacketSize   | See <sup>(1)</sup> . | Number of endpoints used for this interface |
| bInterval        | 0x00                 | Maximum NAK rate                            |

<sup>(1)</sup> The maximum size is 0x0200 (512 bytes) for HS bulk endpoint and 0x0040 (64 bytes) for FS bulk endpoint.

**Table 26-21. BULK OUT Endpoint Descriptor**

| Field            | Value                | Description                                 |
|------------------|----------------------|---------------------------------------------|
| bLength          | 0x07                 | Size of this descriptor in bytes            |
| bDescriptorType  | 0x05                 | Endpoint descriptor type                    |
| bEndpointAddress | 0x01 (1 OUT)         | Address of the endpoint on the USB device   |
| bmAttributes     | 0x02 (Bulk)          | Type of transfer                            |
| wMaxPacketSize   | See <sup>(1)</sup> . | Number of endpoints used for this interface |
| bInterval        | 0x00                 | Maximum NAK rate                            |

<sup>(1)</sup> The maximum size is 0x0200 (512 bytes) for HS bulk endpoint and 0x0040 (64 bytes) for FS bulk endpoint.

- String descriptors

String descriptors use UNICODE encoding. The strings in a USB device can support multiple languages. When requesting a string descriptor, the requester specifies the desired language using a 16-bit language ID (LANGID) defined by the USB interface. String index 0 for all languages returns a string descriptor that contains an array of 2-byte LANGID codes supported by the device.

See the tables describing string descriptors:

- The language ID string descriptor ([Table 26-22](#))
- The manufacturer ID string descriptor ([Table 26-23](#))
- The product ID string descriptor ([Table 26-24](#))
- The configuration string descriptor ([Table 26-25](#))
- The interface string descriptor ([Table 26-26](#))

**Table 26-22. Language ID String Descriptor**

| Field           | Value               | Description                      |
|-----------------|---------------------|----------------------------------|
| bLength         | 0x04                | Size of this descriptor in bytes |
| bDescriptorType | 0x03                | String descriptor type           |
| wLangId         | 0x0409 (US English) | Language ID code                 |

**Table 26-23. Manufacturer ID String Descriptor**

| Field           | Value             | Description                      |
|-----------------|-------------------|----------------------------------|
| bLength         | 0x24              | Size of this descriptor in bytes |
| bDescriptorType | 0x03              | String descriptor type           |
| bString         | Texas Instruments | Manufacturer string              |

**Table 26-24. Product ID String Descriptor**

| Field           | Value                                       | Description                      |
|-----------------|---------------------------------------------|----------------------------------|
| bLength         | 0x12                                        | Size of this descriptor in bytes |
| bDescriptorType | 0x03                                        | String descriptor type           |
| bString         | Multimedia device or specific vendor string | Product string (Device specific) |

**Table 26-25. Configuration String Descriptor**

| Field           | Value | Description                      |
|-----------------|-------|----------------------------------|
| bLength         | 0x08  | Size of this descriptor in bytes |
| bDescriptorType | 0x03  | String descriptor type           |
| bString         | pbc   | Configuration string             |

**Table 26-26. Interface String Descriptor**

| Field           | Value | Description                      |
|-----------------|-------|----------------------------------|
| bLength         | 0x08  | Size of this descriptor in bytes |
| bDescriptorType | 0x03  | String descriptor type           |
| bString         | pbi   | Interface string                 |

### 26.4.5.3.2 USB Customized Descriptors

There are two parameters in USB descriptors that customers can define after the chip is created: vendor ID (VID) and product ID (PID). The ROM code uses dedicated eFuses that hold VID and PID values. Other parameters can also be changed based on VID value. The ROM code has an encoded set of parameters for customers who have defined their requirements before the ROM code has been done. [Table 26-27](#) lists the parameters that depend on VID value.

**Table 26-27. Customized Descriptor Parameters**

| Parameter       | Size [Bytes] | Default Values                              | TI Default Values                           |
|-----------------|--------------|---------------------------------------------|---------------------------------------------|
| Device ID code  | 2            | 0x0000                                      | 0x0000                                      |
| Device class    | 1            | 0xFF                                        | 0xFF                                        |
| Device subclass | 1            | 0xFF                                        | 0xFF                                        |
| Device protocol | 1            | 0xFF                                        | 0xFF                                        |
| Manufacturer    | String       | N/A                                         | Texas Instruments                           |
| Product         | String       | Multimedia device or specific vendor string | Multimedia device or specific vendor string |
| Serial number   | String       | See <sup>(1)</sup>                          | See <sup>(1)</sup>                          |

<sup>(1)</sup> The Standard device descriptor indicates that the device has no serial number.

[Figure 26-12](#) describes an additional customer parameter selection method. It is based on the VID burned in the USB eFuses.

**Figure 26-12. Customer USB Descriptor Selection**



init-011

### 26.4.5.3.3 USB Driver Functionality

- Transactions supported

The following transactions are supported:

- Control transactions: Used for standard device requests
- Bulk transactions: Used for data transfer in the image downloading stage. The ASIC-ID is sent on the Bulk IN endpoint and the image is transferred over the Bulk OUT endpoint from the host.

The USB first attaches to the host as an FS device. In the reset mechanism, the USB core requests HS operation. If the HS negotiation in the reset phase is successful, further transactions are at HS; otherwise, they are at FS. After reset, the USB driver checks for the speed of the device, whether it is FS or HS. Depending on the speed configured by the host, the standard USB device requests are responded to with the corresponding descriptors.

- Standard device request restrictions

Because the USB driver is used only by the ROM code for peripheral booting, some standard device requests are not supported by the driver. [Table 26-28](#) lists the standard device requests supported by the driver.

**Table 26-28. Standard Device Requests Supported**

| Request           | Description                                                        | Support                                                     |
|-------------------|--------------------------------------------------------------------|-------------------------------------------------------------|
| CLEAR_FEATURE     | Sets/clears a specific feature                                     | Supported only for ENDPOINT_HALTED feature                  |
| GET_CONFIGURATION | Returns the current device configuration value                     | Yes                                                         |
| GET_DESCRIPTOR    | Returns the specified descriptor                                   | Yes                                                         |
| GET_INTERFACE     | Returns the selected alternate setting for the specified interface | Yes                                                         |
| GET_STATUS        | Returns the status for the specified recipient                     | Yes                                                         |
| SET_ADDRESS       | Sets the device address                                            | Yes                                                         |
| SET_CONFIGURATION | Sets the device configuration                                      | Yes                                                         |
| SET_DESCRIPTOR    | Updates existing descriptors or adds new descriptors               | No. Runtime updating of descriptors is not supported.       |
| SET_FEATURE       | Sets or enables a specific feature                                 | Supported only for ENDPOINT_HALTED feature                  |
| SET_INTERFACE     | Selects an alternate setting in an interface                       | No. Runtime setting of alternate features is not supported. |
| SYNCH_FRAME       | Sets and reports an endpoint synchronization frame                 | No, because isochronous transfers are not used              |

## 26.4.6 Fast External Booting

### 26.4.6.1 Overview

The fast external boot is a special memory booting mode. It is a blind jump to a code in an external XIP device connected to chip-select 0 (CS0). Fast external booting lets customers create their own booting code.

The jump is performed with minimum on-chip ROM code execution.

### 26.4.6.2 External Booting

[Figure 26-13](#) shows the fast external boot procedure. The code is at the beginning and is written in assembly. The code does not use any RAM.

**Figure 26-13. Fast External Boot Procedure**

### 26.4.7 Memory Booting

#### 26.4.7.1 Overview

The memory booting process starts an external code in memory type booting devices. Because the device always uses the memory type booting devices for booting, they are called permanent booting devices. The supported permanent booting devices are:

- All NOR devices up to 2 Gb (256M bytes)
- NAND devices from 64Mb
- OneNAND/Flex-OneNAND devices from 512Mb
- SD/MMC/eSD/eMMC flash cards with **active** primary partition of type FAT12/16/32 or with raw data
- DiskOnChip H3 devices

Two main groups of permanent booting devices are distinguished by code shadowing. Code shadowing means copying a code from a nondirectly addressable memory device (non-XIP) to RAM, where the code can be executed. Directly addressable memory devices are XIP devices.

[Figure 26-14](#) is the general memory booting procedure common to all types of booting devices. First, the CH is copied to internal RAM. It is copied even for XIP booting devices, because the device can temporarily lose a connection with XIP memory during CH execution. The second step is to shadow the image, if the booting device is not XIP. The last step is image execution.

Unsuccessful execution or return from image results in a dead loop.

If CH copying or shadowing fails, memory booting returns to the main booting procedure, which selects the next booting device for booting.

**Figure 26-14. Memory Booting Procedure**



init-014

#### 26.4.7.2 Non-XIP Memory

[Figure 26-15](#) shows the procedure used when memory booting runs with non-XIP booting devices. The grayed procedures are specific to each booting device. NAND and OneNAND/Flex-OneNAND booting devices use up to four copies of the image in the first four physical blocks. Therefore, the ROM code searches for the image in the first four physical blocks of these booting devices. Other booting devices use only one copy of the image and the block loop runs only once.

During image shadowing on a GP device, the CH is expected to be in a separate sector before the initial software.

**Figure 26-15. Detailed Memory Booting for Non-XIP Booting Devices**


**Table 26-29** summarizes numbers of blocks and sectors that are searched during memory booting from devices requiring image shadowing. NANDs and OneNAND/Flex-OneNAND are organized with blocks, which are erasable units. DOC memory reserves only one block for booting, which overlaps the XIP part. MMC/SD+FAT card booting consists of reading a file. Because there is only one file read, it can be considered one block trial. When no file system is present the first sectors of two blocks (128KB each) are searched.

**Table 26-29. Blocks and Sectors Searched on Non-XIP Memories**

| Memory               | Maximum Number of Checked Blocks | Number of Sectors Searched                  |
|----------------------|----------------------------------|---------------------------------------------|
| NAND                 | First 4                          | Number of sectors in a block <sup>(1)</sup> |
| OneNAND/Flex-OneNAND | First 4                          | 8                                           |
| DOC <sup>(2)</sup>   | 1                                | 4                                           |
| MMC/SD + FAT system  | 1 file                           |                                             |
| MMC/SD raw           | 2                                | 1                                           |

<sup>(1)</sup> Depends on NAND type

<sup>(2)</sup> Because XIP booting always precedes DOC booting and the same data is used for XIP areas, the DOC memory image must contain the first sector filled with 0xFF or 0x00. Therefore, a void sector at the beginning makes XIP booting fail and moves to DOC booting.

The following sections describe the supported booting device types.

For more information about the GPMC module, see [Chapter 10, Memory Subsystem](#).

#### 26.4.7.3 XIP Memory

The ROM code can boot directly from XIP booting devices, such as NOR flash memories, that have the following characteristics:

- The GPMC is the communication interface.
- Memories up to 2 Gb (256MB) can be connected.
- x16 data bus width only
- Asynchronous protocol and address/data multiplexed mode
- The GPMC clock is 48 MHz.
- The booting device is connected to CS0 mapped to address 0x0800 0000.
- The wait pin signal gpmc\_wait0 is monitored according to the sys\_boot configuration pins.

Depending on the sys\_boot option, the GPMC can be configured to use the wait signal connected to the gpmc\_wait0 pin. Wait pin polarity is set to stall accessing memory when gpmc\_wait0 is low. Wait monitoring is used with memories that require a long time for initialization after reset, or that must pause while reading data. An example of such memory is DiskOnChip.

For an XIP memory booting, no user intervention is needed; the following steps are described for debugging. Only the CH, which is not mandatory, lets the user change clock settings and GPMC parameters. Failure in CH copying causes a return to the main booting procedure, which selects the next booting device.

Boot from an XIP booting device consists of the following steps:

1. Configure the GPMC for XIP booting device access.
2. Verify that the CH is present at address 0x0800 0000. If it is, copy the entire sector (512 B) to internal RAM and execute the CH.
3. Set the image location:
  - 0x0800 0000 if the CH is not found
  - 0x0800 0200 if the CH (512 bits) is found
4. Verify that a bootable image is at the image location.
5. Execute the image if it is found.
6. If the image is not found, return from XIP booting to the main booting loop.

##### 26.4.7.3.1 GPMC Initialization

[Table 26-30](#) describes the timing settings of GPMC set for XIP and other address-data accessible booting devices, like DiskOnChip or OneNAND/Flex-OneNAND. [Table 26-30](#) is included for debug information.

**Table 26-30. XIP Timing Parameters**

| Parameter        | Value [Clock Cycles] | Register Initialization (where i = 0...7)                      | Reset Value |
|------------------|----------------------|----------------------------------------------------------------|-------------|
| Write cycle time | 17                   | The GPMC_CONFIG5_i[12:8] WRCYCLETIME bit field is set to 0x11. | 0x11        |
| Read cycle time  | 17                   | The GPMC_CONFIG5_i[4:0] RDCYCLETIME bit field is set to 0x11.  | 0x11        |
| CS low time      | 1                    | The GPMC_CONFIG2_i[3:0] CSONTIME bit field is set to 0x1.      | 0x1         |
| CS high time     | 16                   | The GPMC_CONFIG2_i[12:8] CSRDOFFTIME bit field is set to 0x10. | 0x10        |
| ADV low time     | 1                    | The GPMC_CONFIG3_i[3:0] ADVONTIME bit field is set to 0x1.     | 0x1         |
| ADV high time    | 2                    | The GPMC_CONFIG3_i[12:8] ADVRDOFFTIME bit field is set to 0x2. | 0x2         |
| OE low time      | 3                    | The GPMC_CONFIG4_i[3:0] OEONTIME bit field is set to 0x3.      | 0x3         |

**Table 26-30. XIP Timing Parameters (continued)**

| Parameter       | Value [Clock Cycles] | Register Initialization (where i = 0...7)                       | Reset Value |
|-----------------|----------------------|-----------------------------------------------------------------|-------------|
| OE high time    | 16                   | The GPMC_CONFIG4_i[12:8] OEOFETIME bit field is set to 0x10.    | 0x10        |
| WE low time     | 3                    | The GPMC_CONFIG4_i[19:16] WEONTIME bit field is set to 0x3.     | 0x03        |
| WE high time    | 15                   | The GPMC_CONFIG4_i[28:24] WEOFETIME bit field is set to 0xF.    | 0x10        |
| Data latch time | 15                   | The GPMC_CONFIG5_i[20:16] RDACCESSTIME bit field is set to 0xF. | 0x0F        |

#### 26.4.7.4 NAND

NAND flash memory is not an XIP booting device; it requires shadowing before the code can be executed. ROM code support for the NAND flash booting devices has the following characteristics:

- The GPMC is the communication interface.
- Device from 64 Mb (8MB)
- x8 and x16 bus width
- Small page size (512 bytes + 16 bytes), large page size (2048 bytes + 64 bytes), and very large page size (4096 bytes + 128 bytes)
- Chip enable (CE) don't care booting devices only
- Single level cell (SLC) and multilevel cell (MLC) devices
- Device identification is based on standard identification data or ID2 protocol.
- One-bit error checking and correction (ECC) is used to protect a 512-byte sector.
- GPMC timings are adjusted for NAND access.
- The GPMC clock is 48 MHz.
- The booting device is connected to CS0.
- The wait pin signal gpmc\_wait0 is connected to the NAND BUSY output.
- Four physical blocks are searched for image. Block size depends on the booting device.

For NAND memory booting, no user intervention is needed; the information in the following subsections is included for debugging. Only the CH, which is not mandatory, lets the user change clock settings and GPMC parameters. Failure in CH copying causes a return to the main booting procedure, which selects the next booting device for booting.

##### 26.4.7.4.1 Initialization and NAND Detection

The initialization routine for NAND consists of three parts: GPMC initialization, booting device detection with parameter determination, and bad block detection/verification.

- GPMC initialization

The GPMC interface is configured so that it can access NANDs. Because NANDs do not need the address bus, it is released. The data bus width is initially set to 8 bits. If necessary, it is changed to 16 bits after the booting device parameters are determined. [Table 26-31](#) shows the GPMC configuration used during NAND boot. [Table 26-31](#) is included for debug information.

**Table 26-31. NAND Timing Parameters**

| Parameter        | Value [Clock Cycles] | Register Initialization (where i = 0...7)                      | Reset Value |
|------------------|----------------------|----------------------------------------------------------------|-------------|
| Write cycle time | 20                   | The GPMC_CONFIG5_i[12:8] WRCYCLETIME bit field is set to 0x14. | 0x11        |
| Read cycle time  | 20                   | The GPMC_CONFIG5_i[4:0] RDCYCLETIME bit field is set to 0x14.  | 0x11        |
| CS low time      | 0                    | The GPMC_CONFIG2_i[3:0] CSONTIME bit field is set to 0x0.      | 0x1         |

**Table 26-31. NAND Timing Parameters (continued)**

| Parameter       | Value [Clock Cycles] | Register Initialization (where i = 0...7)                       | Reset Value |
|-----------------|----------------------|-----------------------------------------------------------------|-------------|
| OE low time     | 5                    | The GPMC_CONFIG4_i[3:0] OEONTIME bit field is set to 0x5.       | 0x3         |
| OE high time    | 16                   | The GPMC_CONFIG4_i[12:8] OEOFETIME bit field is set to 0x10.    | 0x10        |
| WE low time     | 3                    | The GPMC_CONFIG4_i[19:16] WEONTIME bit field is set to 0x3.     | 0x3         |
| WE high time    | 15                   | The GPMC_CONFIG4_i[28:24] WEOFETIME bit field is set to 0xF.    | 0x10        |
| Data latch time | 14                   | The GPMC_CONFIG5_i[20:16] RDACCESSTIME bit field is set to 0xE. | 0xF         |

- Booting device detection and parameters

The ROM code must first identify the NAND type connected on the GPMC interface. The GPMC is initialized using 8 bits, asynchronous mode. The NAND booting device is reset and its status is polled until it is ready for operation, then the Read ID command is issued. If the Read Device ID is recognized as a supported booting device, the booting device parameters are extracted from an internal ROM code table. [Table 26-32](#) lists the supported NAND devices.

**Table 26-32. Supported NAND Devices**

| Capacity | Device ID | Bus Width | Page Size in Bytes |
|----------|-----------|-----------|--------------------|
| 64Mb     | E6h       | 8         | 512                |
| 128Mb    | 33h       | 8         | 512                |
| 128Mb    | 73h       | 8         | 512                |
| 128Mb    | 43h       | 16        | 512                |
| 128Mb    | 53h       | 16        | 512                |
| 256Mb    | 35h       | 8         | 512                |
| 256Mb    | 75h       | 8         | 512                |
| 256Mb    | 45h       | 16        | 512                |
| 256Mb    | 55h       | 16        | 512                |
| 512Mb    | 36h       | 8         | 512                |
| 512Mb    | 76h       | 8         | 512                |
| 512Mb    | 46h       | 16        | 512                |
| 512Mb    | 56h       | 16        | 512                |
| 512Mb    | A2h       | 8         | 2048               |
| 512Mb    | F2h       | 8         | 2048               |
| 512Mb    | B2h       | 16        | 2048               |
| 512Mb    | C2h       | 16        | 2048               |
| 1Gb      | 39h       | 8         | 512                |
| 1Gb      | 79h       | 8         | 512                |
| 1Gb      | 49h       | 16        | 512                |
| 1Gb      | 59h       | 16        | 512                |
| 1Gb      | 78h       | 8         | 512                |
| 1Gb      | 72h       | 16        | 512                |
| 1Gb      | 74h       | 16        | 512                |
| 1Gb      | A1h       | 8         | 2048               |
| 1Gb      | F1h       | 8         | 2048               |
| 1Gb      | B1h       | 16        | 2048               |
| 1Gb      | C1h       | 16        | 2048               |
| 2Gb      | AAh       | 8         | 2048 (4096)        |
| 2Gb      | DAh       | 8         | 2048 (4096)        |

**Table 26-32. Supported NAND Devices (continued)**

| <b>Capacity</b> | <b>Device ID</b> | <b>Bus Width</b> | <b>Page Size in Bytes</b> |
|-----------------|------------------|------------------|---------------------------|
| 2Gb             | BAh              | 16               | 2048 (4096)               |
| 2Gb             | CAh              | 16               | 2048 (4096)               |
| 2Gb             | 71h              | 8                | 512                       |
| 2Gb             | 51h              | 16               | 512                       |
| 2Gb             | 31h              | 8                | 512                       |
| 2Gb             | 41h              | 16               | 512                       |
| 4Gb             | ACh              | 8                | 2048 (4096)               |
| 4Gb             | DCh              | 8                | 2048 (4096)               |
| 4Gb             | BCh              | 16               | 2048 (4096)               |
| 4Gb             | CCh              | 16               | 2048 (4096)               |
| 8Gb             | A3h              | 8                | 2048 (4096)               |
| 8Gb             | D3h              | 8                | 2048 (4096)               |
| 8Gb             | B3h              | 16               | 2048 (4096)               |
| 8Gb             | C3h              | 16               | 2048 (4096)               |
| 16Gb            | A5h              | 8                | 2048 (4096)               |
| 16Gb            | D5h              | 8                | 2048 (4096)               |
| 16Gb            | B5h              | 16               | 2048 (4096)               |
| 16Gb            | C5h              | 16               | 2048 (4096)               |
| 32Gb            | A7h              | 8                | 2048 (4096)               |
| 32Gb            | B7h              | 16               | 2048 (4096)               |
| 64Gb            | AEh              | 8                | 2048 (4096)               |
| 64Gb            | BEh              | 16               | 2048 (4096)               |

After retrieving parameters from the table, page size and block size are updated based on the fourth byte of the NAND ID data. Because of inconsistency among manufacturers, only NAND devices recognized to be at least 2Gb have these parameters updated. Therefore, the ROM code supports 4-KB page NAND devices, but only if their size, according to [Table 26-32](#), is at least 2Gb. NAND devices smaller than 2Gb have the block size parameter set to 32KB when the page size is 512 bytes and to 128KB when the page size is 2048 bytes. [Table 26-33](#) shows the fourth ID data byte encoding used in the ROM code.

**Table 26-33. Fourth NAND ID Data Byte**

| <b>Item</b>       | <b>Description</b> | <b>I/O Number</b> |          |          |          |          |          |          |          |
|-------------------|--------------------|-------------------|----------|----------|----------|----------|----------|----------|----------|
|                   |                    | <b>7</b>          | <b>6</b> | <b>5</b> | <b>4</b> | <b>3</b> | <b>2</b> | <b>1</b> | <b>0</b> |
| <b>Page Size</b>  | 512 bytes          |                   |          |          |          |          |          | 0        | 0        |
|                   | 2048 bytes         |                   |          |          |          |          |          | 0        | 1        |
|                   | 4096 bytes         |                   |          |          |          |          |          | 1        | 0        |
|                   | 8192 bytes         |                   |          |          |          |          |          | 1        | 1        |
| <b>Block Size</b> | 64KB               |                   | 0        | 0        |          |          |          |          |          |
|                   | 128KB              |                   | 0        | 1        |          |          |          |          |          |
|                   | 256KB              |                   | 1        | 0        |          |          |          |          |          |
|                   | 512KB              |                   | 1        | 1        |          |          |          |          |          |

The detection procedure is described in [Figure 26-16](#). If the device ID is not recognized, the ROM code tries to read ID2 from the booting device; the sequence is described in [Figure 26-17](#). The description of the ID2 data content is summarized in [Table 26-34](#). If the ROM code fails to identify booting device ID or ID2, it returns with FAIL. When the booting device is successfully detected, the ROM code changes the GPMC to 16-bit bus width if necessary.

**Figure 26-16. NAND Device Detection**


init-023

**Figure 26-17. NAND ID2 Detection**

init-024

**Table 26-34. ID2 Byte Description**

| <b>Byte Number</b> | <b>Name</b>              | <b>Value</b> | <b>Unit</b> | <b>Notes</b>                                                                                          |
|--------------------|--------------------------|--------------|-------------|-------------------------------------------------------------------------------------------------------|
| 1                  | Page size                | 2X           | Bytes       | 00H = 1B<br>09H = 512B<br>0BH = 2KB                                                                   |
| 2                  | Block size               | 2X           | Bytes       | 00H = 1B<br>0EH = 16KB<br>11H = 128KB                                                                 |
| 3                  | Block count              | 2X           | Pcs         | 00H = 1 pc<br>0BH = 2048 pcs<br>0CH = 4096 pcs                                                        |
| 4                  | Spare size               | 2X           | Bytes       | 00H = 1B<br>04H = 16B<br>06H = 64B                                                                    |
| 5                  | Column address           | X            | Pcs         | Higher nibble<br>1H = 1 column address sequence<br>2H = 2 column address sequence                     |
|                    | Row address              | X            | Pcs         | Lower nibble<br>1H = 1 row address sequence<br>2H = 2 row address sequence                            |
| 6                  | ECC type                 | X            | Bit ECC     | Higher nibble<br>0H = No ECC needed<br>1H = 1-bit ECC<br>4H = 4-bit ECC                               |
|                    | Bus width                | 2x           | Width       | Lower nibble<br>3H = 8-bit NAND interface<br>4H = 16-bit NAND interface                               |
| 7                  | Number of CEs            | X            | Pcs         | Higher nibble<br>1H = 1x CE#<br>2H = 2x CE#                                                           |
|                    | Cell type                | X            | Bit/cell    | Lower nibble<br>1H = 1 bit per cell<br>2H = 2 bits per cell                                           |
| 8                  | Boot block               | X            | kB          | 0H = No boot block<br>1H = 1KB boot block<br>2H = 2KB boot block                                      |
| 9                  | Multiple page prg        | X            | Pcs         | Higher nibble<br>1H = 1 plane<br>4H = 4 planes                                                        |
|                    |                          |              |             | For future use                                                                                        |
| 10                 | Partial prg count        | X            | Per page    | 1H = No partial prg allowed<br>2H = 2 per page                                                        |
| 11                 | Read time maximum        |              |             |                                                                                                       |
| 12                 | Prg time maximum         |              |             |                                                                                                       |
| 13                 | Erase time maximum       |              |             |                                                                                                       |
| 252nd<br>255th     | Identification number    | X            |             | B2184D7Bh                                                                                             |
| 256th              | Register/spec<br>version | XvX          |             | Higher nibble: Major digit<br>Lower nibble: Decimal digit<br>Registers according to spec: 2v0:<br>20h |

- Bad block detection/verification

Invalid blocks contain invalid bits whose reliability cannot be ensured by the manufacturer. These bits are identified in the factory or during the programming and reported in the initial invalid block information in the spare area on the first and second page of each block. Because the ROM code looks for an image in the first four blocks, it detects the validity status of these blocks. Blocks detected as invalid are not accessed later. Block validity status is coded in the spare areas of the first two pages of a block. [Table 26-35](#) lists the validity status coding for the four NAND families.

**Table 26-35. Bad Block Mark Locations in NAND Spare Areas**

|                                                                        | Small Page NAND      | Large Page NAND      |
|------------------------------------------------------------------------|----------------------|----------------------|
| 8-bit NAND device<br>Block invalid when any byte does not equal FFh    | 6th byte in 1st page | 1st byte in 1st page |
|                                                                        | 6th byte in 2nd page | 1st byte in 2nd page |
| 16-bit NAND device<br>Block invalid when any word does not equal FFFFh | 1st word in 1st page | 1st word in 1st page |
|                                                                        | 6th word in 1st page | 1st word in 2nd page |
|                                                                        | 1st word in 2nd page |                      |
|                                                                        | 6th word in 2nd page |                      |

Figure 26-18 shows the invalid block detection routine. The routine consists in reading spare areas and checking data according to the conditions listed in Table 26-35. The flags are used internally to give information about the validity of each block.

**Figure 26-18. Bad NAND Invalid Block Detection**

#### 26.4.7.4.2 SLC NAND Read Sector Procedure

During the booting procedure, the ROM code reads 512-byte sectors from the NAND device. The reading fails in two cases:

- The accessed sector is in a block marked as invalid.
- The accessed sector contains an error that cannot be corrected with ECC.

Pages can contain errors caused by memory alteration (1 error bit/sector maximum). The ROM code uses ECC to correct those errors. The ECC algorithm, based on Hamming codes, is used on 512-byte sectors to generate 3 bytes. They are generated by the GPMC hardware on each read cycle. The computed ECC is compared to the ECC stored in the spare area of the corresponding page. Depending on the number of sectors per page (small pages and large pages), several ECC data are stored in the spare area of the page. If the computed ECC data and the stored ECC data are equal, the read sector function returns the read 512-byte sector without error. Otherwise, the ROM code tries to correct the error in the sector and returns the data, if successful. If there are uncorrectable errors, the ROM code returns with FAIL.

[Figure 26-19](#) shows the ECC locations in NAND spare areas.

**Figure 26-19. ECC Locations in NAND Spare Areas**



init-035

For large page NAND memories, the spare area contains four ECC sets, each for a 512-byte sector within the 2048-byte page. Sectors are tagged A, B, C, and D. [Table 26-36](#) shows parity bit locations inside ECC bytes.

**Table 26-36. Hamming Code Parity Bit Locations**

| Byte     | Bit 7  | Bit 6  | Bit 5 | Bit 4 | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|----------|--------|--------|-------|-------|--------|--------|-------|-------|
| ECC-x[0] | 128-2  | 64-2   | 32-2  | 16-2  | 8-2    | 4-2    | 2-2   | 1-2   |
| ECC-x[1] | 128-1  | 64-1   | 32-1  | 16-1  | 8-1    | 4-1    | 2-1   | 1-1   |
| ECC-x[2] | 2048-1 | 1024-1 | 512-1 | 256-1 | 2048-2 | 1024-2 | 512-2 | 256-2 |

The 4-KB page NAND memories have eight ECC sectors tagged A to H. [Figure 26-20](#) shows the spare area organization for such NANDs.

**Figure 26-20. ECC Locations in 4-KB Page NAND Spare Areas**

| 4-KB Large-Page NAND |          |     |                   |
|----------------------|----------|-----|-------------------|
| x8                   | x16      | MSB | Word              |
| Byte                 |          | MSB | Word              |
| 0                    |          | 0   |                   |
| 1                    | ECC-A[0] | 1   | ECC-A[1] ECC-A[0] |
| 2                    | ECC-A[1] | 2   | ECC-B[0] ECC-A[2] |
| 3                    | ECC-A[2] | 3   | ECC-B[2] ECC-B[1] |
| 4                    | ECC-B[0] | 4   | ECC-C[1] ECC-C[0] |
| 5                    | ECC-B[1] | 5   | ECC-D[0] ECC-C[2] |
| 6                    | ECC-B[2] | 6   | ECC-D[2] ECC-D[1] |
| 7                    | ECC-C[0] |     |                   |
| 8                    | ECC-C[1] |     |                   |
| 9                    | ECC-C[2] |     |                   |
| 10                   | ECC-D[0] | 32  |                   |
| 11                   | ECC-D[1] | 33  | ECC-E[1] ECC-E[0] |
| 12                   | ECC-D[2] | 34  | ECC-F[0] ECC-E[2] |
|                      |          | 35  | ECC-F[2] ECC-F[1] |
| 64                   |          | 36  | ECC-G[1] ECC-G[0] |
| 65                   | ECC-E[0] | 37  | ECC-H[0] ECC-G[2] |
| 66                   | ECC-E[1] | 38  | ECC-H[2] ECC-H[1] |
| 67                   | ECC-E[2] |     |                   |
| 68                   | ECC-F[0] |     |                   |
| 69                   | ECC-F[1] |     |                   |
| 70                   | ECC-F[2] |     |                   |
| 71                   | ECC-G[0] |     |                   |
| 72                   | ECC-G[1] |     |                   |
| 73                   | ECC-G[2] |     |                   |
| 74                   | ECC-H[0] |     |                   |
| 75                   | ECC-H[1] |     |                   |
| 76                   | ECC-H[2] |     |                   |

init-036

#### 26.4.7.4.3 MLC NAND Read Sector Procedure

Multilevel cell (MLC) NANDs have a bigger bit error rate than single-level cell (SLC) NANDs. As a consequence, reading data from MLC NANDs requires a stronger error correction capability. Usually, NAND manufacturers recommend Bose-Chaudhuri-Hocquenghem (BCH) code, which can correct 4- or 8-bit errors in 512-byte data sectors. Because of the specific MLC implementation in the device, which is not fully hardware-based, ROM code cannot implement sector BCH encoding. Therefore, ROM code supports MLC booting using its proprietary error correction scheme. This error correction scheme is a combination of BCH, checksum, and redundancy techniques.

##### 26.4.7.4.3.1 MLC Mode Detection

The ROM code verifies whether the block is programmed in MLC mode before reading data from each block. If MLC mode is detected, bad block verification is not performed and the block is considered to be valid. If a user intends a block to be omitted, it should be left erased, which consequently will cause the ROM code to fail in reading data and skipping to the next block.

MLC mode detection consists in reading fifteen 32-bit words of BCH-encoded data and checking whether they match the special encoding scheme described in the following section. The MLC mode is switched on if at least five words match the encoding scheme without errors.

#### 26.4.7.4.3.2 Data Encoding

The plain booting image must be formatted in a special way before being flashed:

1. Checksum modulo 16 is calculated, which means all 256 16-bit words are summed.
2. The checksum result and three empty words of padding are added at the end.
3. A sector is represented by 260 words, 16 bits each.
4. All 16-bit words are converted into 32-bit words by adding 12 bits of the BCH result and 4-bit zero padding.

Figure 26-21 shows how a sector of image data is processed.

**Figure 26-21. MLC NAND Data Encoding**



init-037

The BCH algorithm has the following characteristics:

- 32,20,2 – 32-bit message, 20-bit data, 2-bit error correction capability
- GF polynomial generator:  $p(x) = X^6 + X^5 + 1$
- Generator polynomial:  $g(x) = X^{12} + X^9 + X^8 + X^7 + X^4 + X^2 + 1$

The 2 bytes of data, that is a 16-b word, are encoded as follows:

Input byte stream: Byte0, Byte1, Byte3,  
Byte4, ...

Output byte stream:  $\text{BCH}[3..0]$ ,  
 $\text{BCH}[11..4]+0000b$ , Byte0, Byte1,  $\text{BCH}[3..0]$ ,  $\text{BCH}[11..4]+0000b$ , Byte3, Byte4, ...

#### 26.4.7.4.3.3 Flash Layout

The 1040-encoded sectors are packed into a NAND space as shown in Figure 26-22. Encoded sectors are located serially, without gaps. The area named "Not Programmed" is not read by ROM code. Each encoded sector is put in twice. This redundancy is required to achieve the necessary booting reliability.

**Figure 26-22. MLC NAND Page Layout**

init-038

#### 26.4.7.5 OneNAND/Flex-OneNAND

ROM code support for OneNAND/Flex-OneNAND devices has the following characteristics:

- Devices from 512Mb
- The GPMC is the communication interface.
- x16 data bus width only
- Asynchronous protocol and address/data multiplexed mode
- GPMC reset default timings are used.
- The GPMC clock is 48 MHz.
- The device is connected to CS0 mapped to address 0x0800 0000.
- The wait pin signal gpmc\_wait0 is not monitored.
- Four physical blocks are searched for image. The block size is 128KB.
- The ROM Code fully exploits the ECC controller embedded in the OneNAND/Flex-OneNAND devices themselves. The error code correction capability depends on this controller. ROM Code can support any existing and forecasted OneNAND/Flex-OneNAND devices.

The OneNAND/Flex-OneNAND device is a NAND matrix coupled with RAM buffers and a NOR-type interface. ECC correction handling is done automatically by the internal state-machine. The page to be accessed is first loaded in the RAM buffer using memory-mapped registers. Then, the page is read directly from the buffer using a NOR-type interface.

For OneNAND/Flex-OneNAND memory booting, no user intervention is needed. The information in the following subsections is included for debugging. Only the CH, which is not mandatory, lets the user change clock settings and GPMC parameters. Failure in CH copying causes a return to the main booting procedure, which selects the next device for booting.

##### 26.4.7.5.1 Initialization and OneNAND/Flex-OneNAND Detection

The initialization routine for OneNAND/Flex-OneNAND consists of two parts: GPMC initialization and booting device detection with parameter determination:

- GPMC initialization

The ROM code first initializes the GPMC interface the same way as for an XIP memory (that is, asynchronous 16-bit multiplexed mode). Wait signal monitoring is disabled. See [Table 26-30](#).

- OneNAND/Flex-OneNAND detection and parameters

The ROM code identifies a OneNAND/Flex-OneNAND device by reading its identification data.

There are two ways to read identification data: using serial commands and reading from fixed memory mapped registers. The ROM code reads identification data using both methods and compares the result. When the comparison passes, the ROM code assumes that the OneNAND/Flex-OneNAND device is connected. If the booting device is successfully recognized, the ROM code reads the booting device configuration (amount and size of data buffers) and configures it for asynchronous mode (default).

#### 26.4.7.5.2 OneNAND/Flex-OneNAND Read Sector Procedure

When booting requests a sector from the OneNAND/Flex-OneNAND device, the ROM code issues the load operation, which transfers the content of the requested sector to the data buffer RAM. The ROM code waits until the operation completes, polling the OneNAND/Flex-OneNAND interrupt register. The status register is then checked and the ROM code returns FAIL if the operation completes with an error. Otherwise, the data buffer RAM is copied to the destination buffer. [Figure 26-23](#) shows this procedure.

**Figure 26-23. OneNAND/Flex-OneNAND Read Sector**



init-025

### 26.4.7.5.3 OneNAND/Flex-OneNAND Support Limitations

As described in [Section 26.4.7.5.1, Initialization and OneNAND/Flex-OneNAND Detection](#), the ROM code checks only the coherency of the device ID obtained by two different methods. There is no table of supported OneNANDs/Flex-OneNANDs in the ROM code. This removes any dependency of the ROM code on device IDs from different manufacturers. However, the driver works with the following assumption:

- Page size is assumed to be 2048 bytes, divided into four sectors of 512 bytes. In case of OneNAND/Flex-OneNAND, with pages of 4096 bytes, divided into eight sectors, users must program only the first sectors (sectors 0, 1, 2, 3) of each page. Sectors 4, 5, 6, and 7 of each page are not considered by the driver.

### 26.4.7.6 MMC/SD Cards

The ROM code supports MMC/SD cards, with some limitations:

- Supports MMC/SD cards compliant with the *Multimedia Card System Specification v4.2* from the MMCA Technical Committee and the *SD I/O Card Specification v 2 .0* from the SD Association. Includes high-capacity (size >2GB) cards: HC-SD and HC MMC
- 3-V power supply, 3-V I/O and 1.8-V I/O voltages on port 1
- Supports eMMC/eSD (1.8-V I/O voltage and 3.0-V Core voltage) on port 2. The external transceiver mode on port 2 is not supported.
- Initial 1-bit MMC mode, 4-bit SD mode
- Clock frequency:
  - Identification mode: 400 kHz
  - Data transfer mode: 20 MHz
- Only one card connected to the bus
- Raw mode, image data read directly from card sectors
- FAT12/16/32 support, with or without a master boot record (MBR).
- For a FAT (12/16/32)-formatted memory card, the booting file must not exceed 128 KB.
- For a raw-mode memory card, the booting image must not exceed 128 KB.

For MMC/SD memory booting, no user intervention is needed. The information in the following subsections is included for debugging. Failure in MMC/SD card detection causes a return to the main booting procedure, which selects the next booting device for booting.

The HS MMC/SD/SDIO host controllers (MMCHS) handle the physical layer, while the ROM code handles the simplified logical protocol layer (read-only protocol). A limited range of commands is implemented in the ROM code. The MMC/SD specification defines two operating voltages for standard or HS cards. The ROM code supports only standard operating voltage range (3 V) (both modes supported).

The ROM code reads a booting file from the card file system and boots from it. [Figure 26-24](#) shows the complete procedure.

**Figure 26-24. MMC/SD Booting**


init-016

### 26.4.7.6.1 Initialization and MMC/SD Card Detection

The ROM code initializes the card connected on interface 1 using the standard high-voltage range (3.0 V) if a card is plugged in. If no card is present, the ROM code goes to the next booting device. The standard identification process and relative card address (RCA) assignment are used. However, the ROM code searches for only one card connected on the bus. This is done using the CMD line common to the SD and MMC cards. The MMC and SD standards describe this phase as the initialization phase. They differ in the first commands, CMD1 and ACMD41. The ROM code uses this command difference to differentiate between MMC and SD cards; that is, CMD1 is supported only by MMC, and ACMD41 is supported only by SD. The ROM code first sends a CMD1 to the card and gets an answer only if an MMC card is connected. If no answer is received, ACMD41 (a combination of CMD55 and ACMD41) is sent, and an answer is expected from an SD card. If an answer is not received, no cards are connected and the ROM code exits MMC/SD booting with FAIL.

Figure 26-25 shows the MMC/SD detection procedure.

**Figure 26-25. MMC/SD Detection Procedure**



init-026

#### 26.4.7.6.2 Read Sector Procedure

- Raw mode:

In raw mode, an image can be at offset 0 or 128KB and must not be bigger than 128KB. Raw mode is detected by reading sector 0 and sector 256. The content of these sectors is verified for the presence of a TOC structure. In the case of a GP device, a configuration header (CH) must be in the first sector followed by a GP header. The CH can be void (contains only a CHSETTINGS item for which the valid field is 0), as described in [Section 26.4.8.2, Configuration Header](#). Image data is read directly from continuous sectors of a card. If raw mode is not detected, file system mode is checked.

- File system handling:

The sector read procedure uses the standard MMC/SD read data procedure. The sector address is generated based on the booting memory file map collected during initialization. Thus, the ROM code can address sectors freely in the booting file space.

#### 26.4.7.6.3 File System Handling

The MMC/SD cards can hold a file system that ROM code reads. The image used by the booting procedure is taken from a booting file named MLO. This file must be in the root directory on an active primary partition of type FAT12/16 or FAT32.

An MMC/SD card can be configured as floppy-like or hard-drive-like:

- When acting like a floppy, the content of the card is a single FAT12/16/32 file system without an MBR holding a partition table.
- When acting like a hard drive, an MBR is present in the first sector of the card. This MBR holds a table of partitions, one of which must be FAT12/16/32, primary, and active.

According to the *MultiMediaCard FAT16 File System Specification* from the MMCA Technical Committee, the card must always hold an MBR, except for MMC cards using a floppy-like file system. However, depending on the operating system used, the MMC/SD card is formatted with or without partition(s) (using an MBR). The ROM code supports both types: floppy-like or hard-drive-like. The ROM code retrieves a map of the booting file from the FAT table. The booting file map is a collection of all FAT table entries related to the booting file (a FAT entry points to a cluster holding part of the file). The booting procedure uses this map to access any 512-byte sector in the booting file without involving the ROM code FAT module. [Figure 26-26](#) shows the complete process.

Figure 26-26. SD/MMC Booting



init-027

### 26.4.7.6.3.1 MBR and FAT File System

This section describes the functions used by the ROM code to determine whether an MBR with a FAT is used. It is not intended to fully describe the MBR and the FAT file system detection and reading procedure. The ROM code can detect FAT12/16/32 allocation table types. It cannot boot on devices with NTFS or Linux® FS partitions. Some memory devices that support file systems can be formatted with or without MBR; therefore, the first task of the ROM code is to detect whether the booting device is holding an MBR in the first sector.

The MBR is the first sector of a memory device. It consists of executable code, four partition entries, and one signature. The aim of such a structure is to divide the hard disk in partitions used primarily to boot different systems (for instance, Microsoft Windows™). This structure is described in [Table 26-37](#); partition table entry is described in [Table 26-38](#).

**Table 26-37. Master Boot Record Structure**

| Offset | Length (Bytes) | Entry Description     |
|--------|----------------|-----------------------|
| 0000h  | 446            | Optional code         |
| 01BEh  | 16             | Partition table entry |
| 01CEh  | 16             | Partition table entry |
| 01DEh  | 16             | Partition table entry |
| 01EEh  | 16             | Partition table entry |
| 01FEh  | 2              | Signature (= 0xAA55)  |

**Table 26-38. Partition Table Entry**

| Offset | Length (Bytes) | Entry Description                                        | Value                                                                               |
|--------|----------------|----------------------------------------------------------|-------------------------------------------------------------------------------------|
| 0000h  | 1              | Partition state                                          | 00h: Inactive<br>80h: Active                                                        |
| 0001h  | 1              | Partition start head                                     | Hs                                                                                  |
| 0002h  | 2              | Partition start cylinder and sector                      | Cs[7:0]–Cs[9:8]–Ss[5:0]                                                             |
| 0004h  | 1              | Partition type                                           | 01h: FAT12<br>04h, 06h, 0Eh: FAT16<br>0Bh, 0Ch, 0Fh: FAT32                          |
| 0005h  | 16             | Partition end head                                       | He                                                                                  |
| 0006h  | 2              | Partition end cylinder and sector                        | Ce[7:0]–Ce[9:8]–Se[5:0]                                                             |
| 0008h  | 4              | First sector position relative to the beginning of media | LBA <sub>s</sub> = Cs.H.S+ Hs.S+ Ss–1                                               |
| 000Ch  | 4              | Number of sectors in partition                           | LBA <sub>e</sub> = Ce.H.S+ He.S+ Se–1 Nb s = LBA <sub>e</sub> –LBA <sub>s</sub> + 1 |

SD/MMC booting consists of the following steps:

Step 1. MBR detection:

The ROM code checks whether the MBR signature is present and then it searches an active FAT12/16/32 partition in all four MBR partition entries, based on the type field. If the MBR entries are not valid or if no usable partition is found, the ROM code returns to the booting procedure with FAIL. The extended partitions are not checked; the booting file must reside in a primary partition. Each partition entry is checked:

- (a) If its type is set to 00h, all fields in the entry must be 00h.
- (b) The partition is checked to be within physical boundaries (that is, the partition is inside and it fits the total physical sectors).

[Figure 26-27](#) shows the MBR detection procedure.

## **Figure 26-27. MBR Detection Procedure**



init-028

## Step 2. Get the MBR partition:

Once identified, the ROM code gets the partition using the procedure described in Figure 26-27. The partition type is checked to be FAT12/16 or FAT32. Its state must be 00h (inactive) or 80h (active.) The ROM code returns with FAIL if no active primary FAT12/16/32 is found, or if there is more than one active partition, the test fails. If an active partition is found, its first sector is read and used later. If no MBR is present (in case of a floppy-like system), the first sector of the booting device is read and used later. The read sector is checked to be a valid FAT12/16 or FAT32 partition. If this fails, if another partition type is used (for instance, Linux FS) or if the partition is not valid, the ROM code returns with FAIL.

The FAT file system consists of:

- Boot sector, which holds the BIOS parameter block (BPB). Not all are used by the ROM code.
  - FAT, which describes the use of each cluster of the partition
  - Data area, which holds the files, directories, and root directory (for FAT12/16, the root directory has a specific fixed location)

To check whether a sector holds a valid FAT12/16/32 partition, many fields of the boot sector (used by all FAT types) that must have specific values are checked. Figure 26-28 shows the process to get the MBR partition.

Figure 26-28. Get MBR Partition



init-029

### Step 3. Find the booting file:

When a partition is found, the root directory entries are searched for a booting file named MLO in the root directory of the FAT12/16/32 file system. The file is not searched in any other location. For a FAT12/16 file system, the root directory has a fixed location, which is cluster 0. For a FAT32 file system, its cluster location is given by BPB\_RootClus. The formula to find the sector number (relative to device sector 0, not partition sector 0) of a cluster is given by:

$$\text{Cluster}_{\text{sector}} = \text{BPB\_HiddSec} + \text{BPB\_RsvdSecCnt} + \text{BPB\_NumFATs} \cdot \text{BPB\_FATSz} + \text{Cluster} \cdot \text{BPB\_SecPerCLus}$$

init-E001

**NOTE:** For FAT12/16, BPB\_FatSz is BPB\_FatSz16.

For FAT32, BPB\_FatSz is BPB\_FatSz32.

**NOTE:** The BPB\_HiddSec field can contain 0 even though the FAT file system is somewhere other than on sector 0 (floppy-like). The ROM code uses the partition offset taken from the MBR instead of this field, which can be wrong. If no MBR is found (floppy-like), the value 0 is used.

Each entry in the root directory is 32 bytes and holds information about the file (the filename, date of creation, rights, cluster location, etc.). (See [Table 26-39](#).)

**Table 26-39. FAT Directory Entry**

| Offset | Length [Bytes] | Name             | Description                                                                                                                                                                                                        |
|--------|----------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000h  | 11             | DIR_Name         | Short Name (8 + 3)                                                                                                                                                                                                 |
| 000Bh  | 1              | DIR_Attr         | File Attributes: ATTR_READ_ONLY 01h<br>ATTR_HIDDEN 02h ATTR_SYSTEM 04h<br>ATTR_VOLUME_ID 08h ATTR_DIRECTORY 10h<br>ATTR_ARCHIVE 20h ATTR_LONG_NAME<br>ATTR_READ_ONLY   ATTR_HIDDEN<br>ATTR_SYSTEM   ATTR_VOLUME_ID |
| 000Ch  | 1              | DIR_NTRes        | Reserved. Set to 00h.                                                                                                                                                                                              |
| 000Dh  | 1              | DIR_CrtTimeTenth | Millisecond stamp at file creation                                                                                                                                                                                 |
| 000Eh  | 2              | DIR_CrtTime      | Time file was created.                                                                                                                                                                                             |
| 0010h  | 2              | DIR_CrtDate      | Date file was created.                                                                                                                                                                                             |
| 0012h  | 2              | DIR_LstAccDate   | Last access date                                                                                                                                                                                                   |
| 0014h  | 2              | DIR_FstClusHi    | High word of the first cluster number of this entry                                                                                                                                                                |
| 0016h  | 2              | DIR_WrtTime      | Time of last write                                                                                                                                                                                                 |
| 0018h  | 2              | DIR_WrtDate      | Date of last write                                                                                                                                                                                                 |
| 001Ah  | 2              | DIR_FstClusLo    | Low word of the first cluster number of this entry                                                                                                                                                                 |
| 001Ch  | 4              | DIR_FileSize     | File size in bytes                                                                                                                                                                                                 |

The ROM code checks each entry in the root directory until either the booting file is found or the entry is empty (first byte is 00h), or when the end of the root directory is reached. Entries with the ATTR\_LONG\_NAME attribute (LFN) and first byte at E5h (erased file) are ignored. When found, the first cluster offset of the file is read from the DIR\_FstClusHi/DIR\_FstClusLo fields. There is a slight difference between FAT12/16 and FAT32 when handling the root directory. On FAT12/16, this directory has a fixed location (see above) and length fixed by BPB\_RootEntCnt, which is the total of 32-byte entries. Handling this directory is therefore straightforward. On FAT32, the root directory is like a standard file. The FAT must be used to retrieve each sector of the directory. The way in which the FAT is handled is described in the following paragraph.

#### Step 4. Buffer FAT entries in the FAT buffer.

When the booting file is found, the ROM code reads the FAT and buffers the singly-linked chain of clusters in a FAT buffer used by booting to access the file directly, sector by sector. For FAT12/16 and for FAT32, multiple copies of the FAT exist (ROM code supports only two copies), after the boot sector.

$$FATn_{sector} = BPB\_HiddSec + BPB\_RsvdSecCnt + BPB\_FatSz \cdot n$$

init-E002

The size of the FAT buffer is given by BPB\_FATSz16 or BPB\_FATSz32. The ROM code checks each copy of the FAT if they are identical. If the values are different, the ROM code uses the value from the last FAT copy. With the FAT32 file system, the copy system can be disabled according to a flag in BPB\_ExtFlags[7]. If this flag is set, the FAT BPB\_ExtFlags[3:0] bit field is used. In this case no verification is made by the ROM code with other copies of FAT.

The FAT is a simple array of values, each referring to a cluster located in the data area. One entry of

the array is 12, 16, or 32 bits, depending on the file system in use. The value in an entry defines whether the cluster is being used or not, and if another cluster must be considered. This creates a singly-linked chain of clusters defining the file. The meaning of an entry is described in [Table 26-40](#).

---

**NOTE:** For compatibility, cluster 0 and cluster 1 are not used for files, and those entries must contain FF8h and FFFh (for FAT12), FFF8h and FFFFh (for FAT16), and 0FFFFFF8h and 0FFFFFFFh (for FAT32).

---

**Table 26-40. FAT Entry Description**

| FAT12     | FAT16           | FAT32                   | Description                                |
|-----------|-----------------|-------------------------|--------------------------------------------|
| 000h      | 0000h           | 0000000h                | Free cluster                               |
| 001h      | 0001h           | 00000001h               | Reserved cluster                           |
| 002h-FEFh | 0002h-<br>FFEFh | 00000002h-<br>0FFFFFFEh | Used cluster; value points to next cluster |
| FF0h-FF6h | FFF0h-<br>FFF6h | 0FFFFFF0h-<br>0FFFFFF6h | Reserved values                            |
| FF7h      | FFF7h           | 0FFFFFF7h               | Bad cluster                                |
| FF8h-FFFh | FFF8h-<br>FFFh  | 0FFFFFF8h-<br>0FFFFFFFh | Last cluster in file                       |

---

**NOTE:** FAT32 uses only 28 bits [27:0] of the 32 possible; the upper 4 bits are usually 0 and must be left untouched.

---

When accessing the root directory for FAT32, the ROM code starts from the root directory cluster entry and follows the linked chain to retrieve the clusters.

When the booting file has been found, the ROM code buffers each FAT entry corresponding to the file in a sector way. This means each cluster is translated to one or several sectors, depending on how many sectors are in a cluster (BPB\_SecPerClus). This buffer is used later by the booting procedure to access the file.

#### 26.4.7.7 DiskOnChip

The ROM code support for DiskOnChip devices has the following characteristics:

- DiskOnChip H3
- 1.8-V power supply
- Density from 256MB

The DiskOnChip contains an XIP part that can hold a boot image. In this case, the DiskOnChip is connected just like a regular NOR device, and uses the same procedure as for NOR, described in [Section 26.4.7.3, XIP Memory](#).

If booting determines that it must boot from DOC, the ROM code initializes the GPMC using standard asynchronous, 16-bit, multiplexed mode. The DOC device is then detected using the M-System driver. This proprietary driver handles all DiskOnChip protocols and identification. If the booting device cannot be identified, the ROM code returns a failed code. Otherwise, booting directly requests sectors from the M-System driver.

#### 26.4.8 Image Format

##### 26.4.8.1 Overview

An image has two major parts:

- An optional CH
- Software to execute

The CH, which is optional, can contain several parameters set by users to speed up booting. It is further described in the next section.

The mandatory part contains software that is loaded into the memory and executed.

An overview of the image formats is shown in [Figure 26-29](#). There are two image types:

- GP non-XIP memory booting: This image type is used for memories that require shadowing. The image must begin with a simple header that contains information about the size to copy and the destination. This format is described in [Section 26.4.8.3, Image Format for GP Devices](#).
- GP XIP memory booting and peripheral booting: A GP image on XIP memory contains only code. The first sector can contain CH. The GP peripheral booting image contains only code.

**Figure 26-29. Image Format**



init-018

### 26.4.8.2 Configuration Header

The CH is optional and is required only if the customer wants to use settings different from the ROM code defaults (for example, clock frequencies, SDRAM/double-data rate [DDR] SDRAM settings, GPMC settings). The CH can be present only when booting from a memory-type device (for example, CH is not supported when booting from UART or USB). Therefore, the CH contains settings only for memory booting.

The CH can contain up to four parts:

- Settings: Clock settings (mandatory)
- RAM: SDRAM/DDR SDRAM interface settings
- FLASH: Flash interface (GPMC) settings
- MMC/SD: MMC/SDIO interface settings

The beginning of the CH is a table of contents (TOC) pointing to each item (see [Figure 26-30](#)). Each TOC item is a simple structure described in [Table 26-41](#). The complete CH (CH TOC and items) must fit in a 512-byte sector.

The ROM code identifies the presence of a CH by reading the first TOC item if it contains a known string (CHSETTINGS, CHRAM, etc.). Then, the TOC is identified and searched until a 0xFFFFFFFF offset is found. The CH is read and parameters are executed sequentially.

**Figure 26-30. CH Format**


init-019

**Table 26-41. CH TOC Item**

| Offset | Field    | Size (Bytes) | Description                                                             |
|--------|----------|--------------|-------------------------------------------------------------------------|
| 0x0000 | Start    | 4            | Offset from the start address of TOC to the actual address of a section |
| 0x0004 | Size     | 4            | Size of a section                                                       |
| 0x0008 | Reserved | 4            | Unused                                                                  |
| 0x000C | Reserved | 4            | Unused                                                                  |
| 0x0010 | Reserved | 4            | Unused                                                                  |
| 0x0014 | Filename | 12           | 12-character name of a section, including the zero (\0) terminator      |

#### 26.4.8.2.1 CHSETTINGS

The CHSETTINGS configuration header contains settings specific to the clock system. The ROM code configures the device clocking to some default settings as described in [Section 26.4.4.2, Clocking Configuration](#). The CH CHSETTINGS section contains a method to override the ROM code default clocking settings.

The fields are described in [Table 26-42](#). The clocking procedure, as well as the clocking setting structure are described in [Section 26.4.4.4, Software Booting Configuration](#).

The peripherals used during booting, that is, UART and USB are fed with 96 MHz and 48 MHz. This cannot be changed in the configuration header as it is only available for memory booting.

**Table 26-42. CHSETTINGS**

| Offset | Field       | Description                                  |
|--------|-------------|----------------------------------------------|
| 0000h  | Section key | Key used for section verification: C0C0C0C1h |
| 0004h  | Valid       | Enables/disables the section<br>00h: Disable |

**Table 26-42. CHSETTINGS (continued)**

| Offset | Field             | Description                                                                                                        |
|--------|-------------------|--------------------------------------------------------------------------------------------------------------------|
|        |                   | Other: Enable                                                                                                      |
| 0005h  | Version           | Configuration header version 0001h<br>Others: For future use                                                       |
| 0006h  | Reserved          |                                                                                                                    |
| 0008h  | Clocking settings | Described in <a href="#">Table 26-12, Software Booting Configuration Structure</a> , starting from the FLAGS field |

**26.4.8.2.2 CHRAM**

The CHRAM configuration header contains settings specific to SDRAM memory controller (SDRC). The fields are described in [Table 26-43](#). The ROM code does not configure the SDRC by default, as it cannot assume any external SDR/DDR SDRAM type. For more information, see [Section 10.2, SDRC](#), in [Chapter 10, Memory Subsystem](#).

**Table 26-43. CHRAM**

| Offset | Field                                        | Description                                                                 |                              |
|--------|----------------------------------------------|-----------------------------------------------------------------------------|------------------------------|
|        |                                              | CH – Used in CH Process                                                     | CR – Used in Context Restore |
| 0000h  | Section key                                  | Key used for section verification: C0C0C0C2h.                               |                              |
| 0004h  | Valid                                        | Enables/disables the section:<br>00h: Disable<br>Others: Enable             |                              |
| 0005h  | Reserved                                     |                                                                             |                              |
| 0008h  | SDRC_SYSCONFIG (LSB)                         | CR                                                                          |                              |
| 000Ah  | SDRC_CS_CFG (LSB)                            | CH                                                                          | CR                           |
| 000Ch  | SDRC_SHARING (LSB)                           | CH                                                                          | CR                           |
| 000Eh  | SDRC_ERR_TYPE (LSB)                          |                                                                             | CR                           |
| 0010h  | SDRC_DLLA_CTRL (LSB)                         | CH                                                                          | CR                           |
| 0012h  | SDRC_DLLA_CTRL (MSB)                         | CH                                                                          | CR                           |
| 0014h  | Reserved. Write 0s for future compatibility. |                                                                             | CR                           |
| 0016h  | Reserved. Write 0s for future compatibility. |                                                                             | CR                           |
| 0018h  | SDRC_POWER (LSB)                             |                                                                             | CR                           |
| 001Ah  | SDRC_POWER (MSB)                             |                                                                             | CR                           |
| 001Ch  | Memory type (LSB)                            | CH<br>0: SDRAM<br>1: Low-power SDR<br>2: DDR<br>3: Mobile DDR<br>4: Unknown | CR                           |
| 001Eh  | Must be 0                                    | CH                                                                          | CR                           |
| 0020h  | SDRC_MCFG_0 (LSB)                            | CH                                                                          | CR                           |
| 0022h  | SDRC_MCFG_0 (MSB)                            | CH                                                                          | CR                           |
| 0024h  | SDRC_MR_0 (LSB)                              | CH                                                                          | CR                           |
| 0026h  | SDRC_EMR1_0 (LSB)                            | CH                                                                          | CR                           |
| 0028h  | SDRC_EMR2_0 (LSB)                            | CH                                                                          | CR                           |
| 002Ah  | SDRC_EMR3_0 (LSB)                            |                                                                             | CR                           |
| 002Ch  | SDRC_ACTIM_CTRLA_0 (LSB)                     | CH                                                                          | CR                           |
| 002Eh  | SDRC_ACTIM_CTRLA_0 (MSB)                     | CH                                                                          | CR                           |
| 0030h  | SDRC_ACTIM_CTRLB_0 (LSB)                     | CH                                                                          | CR                           |

**Table 26-43. CHRAM (continued)**

| Offset | Field                                       | Description                                                                                              |    |
|--------|---------------------------------------------|----------------------------------------------------------------------------------------------------------|----|
|        |                                             | CH – Used in CH Process                                                                                  |    |
|        |                                             | CR – Used in Context Restore                                                                             |    |
| 0032h  | SDRC_ACTIM_CTRLB_0 (MSB)                    | CH                                                                                                       | CR |
| 0034h  | SDRC_RFRCTRL_0 (LSB)                        | CH                                                                                                       | CR |
| 0036h  | SDRC_RFRCTRL_0 (MSB)                        | CH                                                                                                       | CR |
|        |                                             | CH                                                                                                       | CR |
| 0038h  | Memory type (LSB)                           | 0: SDRAM<br>1: Low-power SDR<br>2: DDR<br>3: Mobile DDR<br>4: Unknown                                    |    |
| 003Ah  | Must be 0                                   | CH                                                                                                       | CR |
| 003Ch  | SDRC_MCFG_1 (LSB)                           | CH                                                                                                       | CR |
| 003Eh  | SDRC_MCFG_1 (MSB)                           | CH                                                                                                       | CR |
| 0040h  | SDRC_MR_1 (LSB)                             | CH                                                                                                       | CR |
| 0042h  | SDRC_EMR1_1 (LSB)                           | CH                                                                                                       | CR |
| 0044h  | SDRC_EMR2_1 (LSB)                           | CH                                                                                                       | CR |
| 0046h  | SDRC_EMR3_1 (LSB)                           |                                                                                                          | CR |
| 0048h  | SDRC_ACTIM_CTRLA_1 (LSB)                    | CH                                                                                                       | CR |
| 004Ah  | SDRC_ACTIM_CTRLA_1 (MSB)                    | CH                                                                                                       | CR |
| 004Ch  | SDRC_ACTIM_CTRLB_1 (LSB)                    | CH                                                                                                       | CR |
| 004Eh  | SDRC_ACTIM_CTRLB_1 (MSB)                    | CH                                                                                                       | CR |
| 0050h  | SDRC_RFRCTRL_1 (LSB)                        | CH                                                                                                       | CR |
| 0052h  | SDRC_RFRCTRL_1 (MSB)                        | CH                                                                                                       | CR |
| 0054h  | Reserved, write 0s for future compatibility |                                                                                                          | CR |
| 0056h  | Reserved, write 0s for future compatibility |                                                                                                          | CR |
|        |                                             | CH                                                                                                       | CR |
| 0058h  | Flags                                       | [0]:<br>0: CS0 not configured<br>1: CS0 configured<br>[1]:<br>0: CS1 not configured<br>1: CS1 configured |    |
| 005A   | Must be 0                                   | CH                                                                                                       | CR |

#### 26.4.8.2.3 CHFLASH

The CHFLASH configuration header contains settings specific to the GPMC. For more information, see [Section 10.1, GPMC](#), in [Chapter 10, Memory Subsystem](#). [Table 26-44](#) lists the fields. The ROM code configures the GPMC by default to these settings:

- CS0
- Asynchronous mode
- Wait input enabled
- Base address 08000000h

**Table 26-44. CHFLASH**

| Offset | Field                       | Description                                                     |
|--------|-----------------------------|-----------------------------------------------------------------|
| 0000h  | Section key                 | Key used for section verification: C0C0C0C3h                    |
| 0004h  | Valid                       | Enables/disables the section:<br>00h: Disable<br>Others: Enable |
| 0005h  | Reserved                    |                                                                 |
| 0008h  | GPMC_SYSCONFIG (LSB)        | Register value                                                  |
| 000Ah  | GPMC_IRQENABLE (LSB)        |                                                                 |
| 000Ch  | GPMC_TIMEOUT_CONTROL (LSB)  |                                                                 |
| 000Eh  | GPMC_CONFIG (LSB)           |                                                                 |
| 0010h  | GPMC_CONFIG1_0              |                                                                 |
| 0014h  | GPMC_CONFIG2_0              |                                                                 |
| 0018h  | GPMC_CONFIG3_0              |                                                                 |
| 001Ch  | GPMC_CONFIG4_0              |                                                                 |
| 0020h  | GPMC_CONFIG5_0              |                                                                 |
| 0024h  | GPMC_CONFIG6_0              |                                                                 |
| 0028h  | GPMC_CONFIG7_0              |                                                                 |
| 002Ch  | GPMC_PREFETCH_CONFIG1       |                                                                 |
| 0030h  | GPMC_PREFETCH_CONFIG2 (LSB) |                                                                 |
| 0032h  | GPMC_PREFETCH_CONTROL (LSB) |                                                                 |
| 0034h  | GPMC_ECC_CONFIG             |                                                                 |
| 0036h  | GPMC_ECC_CONTROL            |                                                                 |
| 0038h  | GPMC_ECC_SIZE_CONFIG (LSB)  |                                                                 |
| 003Ch  | Enable_A1_A10               | 0: Do not change A1– A10<br>Others: Enable pins A1 – A10        |

**26.4.8.2.4 CHMMCSD**

The CHMMCSD configuration header contains settings specific to the high-speed MMC/SD/SDIO host controller (MMCHS). For more information, see [Chapter 24, MMC/SD/SDIO Card Interface](#). **Table 26-45** lists the fields. The ROM code configures the MMCHS by default to these settings:

- 400-kHz clock during identification mode
- 19.2-MHz clock during data transfer mode

**Table 26-45. CHMMCSD CH**

| Offset | Register Modified  | Description                                                                                                   |
|--------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 0000h  | Section key        | Key used for section verification C0C0C0C4h                                                                   |
| 0004h  | Valid              | Enables/disables the section<br>00h: Disable<br>Other: Enable                                                 |
| 0005h  | Reserved           |                                                                                                               |
| 0008h  | MMCHS_SYSCTRL(MSB) | Register value                                                                                                |
| 000Ah  | MMCHS_SYSCTRL(LSB) | 0xFFFFFFFF -> Do not update register.                                                                         |
| 000Ch  | Bus width          | 1 -> 1 bit<br>2 -> 4 bits<br>4 -> 8 bits (on SD/MMC2 interface only)<br>0xFFFFFFFF -> Do not update register. |

**NOTE:** The ROM code transmits a booting parameter structure to the initial software (see [Section 26.4.8.4, Image Execution](#)). This structure contains a field that indicates whether the configuration header sections have been correctly considered. For the CHMMCSD section, if all the section fields are set to 0xFFFFFFFF, regardless of the value of the VALID bit field, the booting parameters should indicate that the CHMMCSD section has not been executed.

### 26.4.8.3 Image Format for GP Devices

For a GP device, the image is simple and must contain a small header having the size of the software to load and the destination address of where to store it when a booting device is other than XIP. The XIP device image is even simpler and starts with executable code. [Table 26-46](#) describes the image format. The header is used only for memory booting. The peripheral booting image does not have a header and starts directly with executable code.

**Table 26-46. GP Device Software Image**

| Field       | Non-XIP Device | XIP Device | Size (Bytes) | Description                      |
|-------------|----------------|------------|--------------|----------------------------------|
|             | Offset         | Offset     |              |                                  |
| Size        | 0x0000         | —          | 4            | Size of the image                |
| Destination | 0x0004         | —          | 4            | Address where to store the image |
| Image       | 0x0008         | 0x0000     | x            | Image                            |

### 26.4.8.4 Image Execution

The image is executed when the ROM code performs a branch instruction to the first executable instruction in the initial software. The execution address is the first word after the image header. After the branch, the ARM® runs in public ARM supervisor mode. The R0 register points to the booting parameter structure that contains information about booting. [Table 26-47](#) shows the booting parameters structure.

**Table 26-47. Booting Parameter Structure**

| Offset | Field                  | Size (Bytes) | Description                                                                                                                                                                                                                                                                  |
|--------|------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00   | Boot message           | 4            | Last received booting message                                                                                                                                                                                                                                                |
| 0x04   | Current booting device | 1            | Code of booting device used for booting:<br>0x01: XIP memory<br>0x02: NAND<br>0x03: OneNAND<br>0x04: DOC<br>0x05: MMC/SD2<br>0x06: MMC/SD1<br>0x07: XIP memory with wait monitoring<br>0x08: MMC/SD2 with hybrid connection<br>0x10: UART<br>0x11: HS USB<br>Other: Reserved |
| 0x05   | Reserved               | 1            | Reserved                                                                                                                                                                                                                                                                     |

**Table 26-47. Booting Parameter Structure (continued)**

| Offset | Field             | Size (Bytes) | Description                                                                                                                                                                                                                                                                                                                                                          |
|--------|-------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x06   | Reset reason      | 1            | Current reset reason bit mask (bit = 1, event present):<br>[0]: Power-on reset (POR)<br>[1]: Global software reset<br>[2]: Reserved<br>[3]: Reserved<br>[4]: WDT2 reset<br>[5]: Reserved<br>[6]: External warm reset<br>[7]: VDD1 voltage manager reset<br>[8]: VDD2 voltage manager reset<br>[9]: ICEPick™ reset<br>[10]: ICECrusher™ reset<br>Other bits: Reserved |
| 0x07   | CH flags          | 1            | Configuration header sections flag. Each section is described by 1 bit. A set bit indicates that the section was executed:<br>[0]: CHSETTINGS<br>[1]: CHRAM<br>[2]: CHFLASH<br>[3]: CHMMC<br>Other bits: Reserved                                                                                                                                                    |
| 0x08   | Device descriptor | 4            | Pointer to the device descriptor structure. This pointer is required when current booting device driver functions are called.                                                                                                                                                                                                                                        |

#### 26.4.9 Tracing

Tracing in the public ROM code consists of a 64-bit vector in which each bit corresponds to a certain point of the ROM code execution flow. The tracing vector is divided into two 32-bit words. [Table 26-48](#) lists the location and organization of the tracing data in RAM. Tracing data is initialized at the beginning of startup.

There are two sets of tracing data: current trace information and tracing collected during the first ROM code run after a cold reset. This cold reset tracing is copied to its location during the tracing initialization of the second ROM code run after the cold reset run. These data can be used for debugging.

**Table 26-48. Tracing Vector**

| Bit Number | Group           | Meaning                               |
|------------|-----------------|---------------------------------------|
| 0          | General         | Reset                                 |
| 1          | General         | ROM code C main                       |
| 2          | General         | ROM code runs after the cold reset    |
| 3          | Boot            | Booting started                       |
| 4          | Memory boot     | Memory booting started                |
| 5          | Boot            | No more booting device to check       |
| 6          | Peripheral boot | Peripheral booting started            |
| 7          | Boot            | Booting message change booting device |
| 8          | Boot            | Booting message skip per. booting     |
| 9          | Reserved        | Reserved                              |
| 10         | Memory boot     | CH found                              |
| 11         | Memory boot     | Image header correct                  |
| 12         | Peripheral boot | Device initialized                    |
| 13         | Peripheral boot | ASIC-ID sent                          |

**Table 26-48. Tracing Vector (continued)**

| <b>Bit Number</b> | <b>Group</b>    | <b>Meaning</b>                                        |
|-------------------|-----------------|-------------------------------------------------------|
| 14                | Peripheral boot | Booting message received                              |
| 15                | Peripheral boot | Image received                                        |
| 16                | Peripheral boot | Peripheral booting failed                             |
| 17                | Peripheral boot | UART                                                  |
| 18                | Peripheral boot | USB                                                   |
| 19                | Reserved        | Reserved                                              |
| 20                | Reserved        | Reserved                                              |
| 21                | Peripheral boot | NULL device                                           |
| 22                | Execute         | Image executed                                        |
| 23                | Reserved        | Reserved for non-GP devices                           |
| 24                | Reserved        | Reserved for non-GP devices                           |
| 25                | Reserved        | Reserved for non-GP devices                           |
| 26                | Reserved        | Reserved for non-GP devices                           |
| 27                | Reserved        | Reserved for non-GP devices                           |
| 28                | Reserved        | Reserved for non-GP devices                           |
| 29                | Boot            | Software booting configuration section 1 found        |
| 30                | General         | Software booting configuration clocking section found |
| 31                | Reserved        | Reserved                                              |
| 32                | Memory boot     | Null device                                           |
| 33                | Memory boot     | XIP                                                   |
| 34                | Memory boot     | NAND                                                  |
| 35                | Memory boot     | OneNAND                                               |
| 36                | Memory boot     | DOC                                                   |
| 37                | Memory boot     | MMC/SD2                                               |
| 38                | Memory boot     | MMC/SD1                                               |
| 39                | Memory boot     | XIP memory with wait monitoring                       |
| 40                | Reserved        | Reserved                                              |
| 41                | Reserved        | Reserved                                              |
| 42                | Reserved        | Reserved                                              |
| 43                | Reserved        | Reserved                                              |
| 44                | Reserved        | Reserved                                              |
| 45                | Reserved        | Reserved                                              |
| 46                | Reserved        | Reserved                                              |
| 47                | Memory boot     | No known NAND was detected.                           |
| 48                | Memory boot     | MLC NAND image was detected.                          |
| 49                | Memory boot     | NAND boot was attempted from block 0.                 |
| 50                | Memory boot     | NAND boot was attempted from block 1.                 |
| 51                | Memory boot     | NAND boot was attempted from block 2.                 |
| 52                | Memory boot     | NAND boot was attempted from block 3.                 |

## 26.5 Wake-Up Booting by ROM Code

In CORE OFF power state, all configurations outside the WKUP power domain are reset and must be restored to restart the system in the condition it was in before being stopped. After an MPU and CORE power domain wake-up reset, the ROM code restores the SDRC and clock settings to allow a jump to a public restore function. This public restore function is specifically implemented by users to restore their own hardware and software environments. Users must set the public restore function address in the public restore pointer field of the CONTROL\_SAVE\_RESTORE\_MEM structure.

The CONTROL\_SAVE\_RESTORE\_MEM memory of the SCM saves and restores mandatory information to automatically reconfigure the SDRC and PRCM registers. The SDRC and clock registers must be saved by users in the respective structures (see [Table 26-50](#) and [Table 26-51](#)) in the SCM (scratchpad memory) before going to off mode to be automatically restored on wake-up boot by the ROM code.

The size of CONTROL\_SAVE\_RESTORE\_MEM is 240 bytes starting at the hardware physical address 0x48002910 to 0x480029FF. [Figure 26-31](#) shows the memory format that must be obeyed to handle the context restoration.

**Figure 26-31. CONTROL\_SAVE\_RESTORE\_MEM Format**


init-021

**Table 26-49. CONTROL\_SAVE\_RESTORE\_MEM Field Definitions**

| Field Name                            | Size    | Description                                                                           |
|---------------------------------------|---------|---------------------------------------------------------------------------------------|
| Booting Configuration Pointer         | 32 bits | Address of public booting information used after a software reset                     |
| Public Restore Pointer <sup>(1)</sup> | 32 bits | Address of the public restore function to branch to when exiting a wake-up reset boot |

<sup>(1)</sup> Field to be set by users

**Table 26-49. CONTROL\_SAVE\_RESTORE\_MEM Field Definitions (continued)**

| Field Name                           | Size    | Description                                                                                                                                                   |
|--------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SDRC Module Semaphore <sup>(2)</sup> | 32 bits | Semaphore used for accessing the SDRC module                                                                                                                  |
| PRCM Block Offset <sup>(1)</sup>     | 32 bits | Offset of the PRCM configuration in the control save restore memory. Set 0x0 to not use this block. When the block is used the minimum allowed value is 0x18. |
| SDRC Block Offset <sup>(1)</sup>     | 32 bits | Offset of the SDRC configuration in the control save restore memory. Set 0x0 to not use this block. When the block is used the minimum allowed value is 0x18. |

<sup>(2)</sup> ROM code use only

Table 26-50 describes the PRCM context restore block.

**Table 26-50. PRCM Register Organization in the SCM Block**

| Offset        | PRCM Register Byte Organization in the SCM Block |       |      |     |
|---------------|--------------------------------------------------|-------|------|-----|
|               | 31:24                                            | 23:16 | 15:8 | 7:0 |
| <b>0x0000</b> | PRM_CLKSRC_CTRL                                  |       |      |     |
| 0x0004        | PRM_CLKSEL                                       |       |      |     |
| 0x0008        | CM_CLKSEL_CORE                                   |       |      |     |
| 0x000C        | CM_CLKSEL_WKUP                                   |       |      |     |
| 0x0010        | CM_CLKEN_PLL                                     |       |      |     |
| 0x0014        | CM_AUTOIDLE_PLL                                  |       |      |     |
| 0x0018        | CM_CLKSEL1_PLL                                   |       |      |     |
| 0x001C        | CM_CLKSEL2_PLL                                   |       |      |     |
| 0x0020        | CM_CLKSEL3_PLL                                   |       |      |     |
| 0x0024        | CM_CLKEN_PLL_MPU                                 |       |      |     |
| 0x0028        | CM_AUTOIDLE_PLL_MPU                              |       |      |     |
| 0x002C        | CM_CLKSEL1_PLL_MPU                               |       |      |     |
| 0x0030        | CM_CLKSEL2_PLL_MPU                               |       |      |     |
| 0x0034        | Reserved                                         |       |      |     |

Table 26-51 describes the SDRC context restore block.

**Table 26-51. SDRC Register Organization in the SCM Block**

| Offset        | SDRC Register Byte Organization in the SCM Block |       |        |     |  |  |
|---------------|--------------------------------------------------|-------|--------|-----|--|--|
|               | 31:24                                            | 23:16 | 15:8   | 7:0 |  |  |
| <b>0x0000</b> | CS_CFG                                           |       |        |     |  |  |
| 0x0004        | ERR_TYPE                                         |       |        |     |  |  |
| 0x0008        | DLLA_CTRL                                        |       |        |     |  |  |
| 0x000C        | Reserved                                         |       |        |     |  |  |
| 0x0010        | POWER                                            |       |        |     |  |  |
| 0x0014        | Reserved                                         |       |        |     |  |  |
| 0x0018        | MCFG_0                                           |       |        |     |  |  |
| 0x001C        | Reserved                                         |       | MR_0   |     |  |  |
| 0x0020        | Reserved                                         |       | EMR2_0 |     |  |  |
| 0x0024        | ACTIM_CTRLA_0                                    |       |        |     |  |  |
| 0x0028        | ACTIM_CTRLB_0                                    |       |        |     |  |  |
| 0x002C        | RFR_CTRL_0                                       |       |        |     |  |  |
| 0x0030        | Reserved                                         |       |        |     |  |  |
| 0x0034        | MCFG_1                                           |       |        |     |  |  |
| 0x0038        | Reserved                                         |       | MR_1   |     |  |  |
| 0x003C        | Reserved                                         |       | EMR2_1 |     |  |  |

**Table 26-51. SDRC Register Organization in the SCM Block (continued)**

| Offset | SDRC Register Byte Organization in the SCM Block |       |          |     |  |  |
|--------|--------------------------------------------------|-------|----------|-----|--|--|
|        | 31:24                                            | 23:16 | 15:8     | 7:0 |  |  |
| 0x0040 | ACTIM_CTRLA_1                                    |       |          |     |  |  |
| 0x0044 | ACTIM_CTRLB_1                                    |       |          |     |  |  |
| 0x0048 | RFR_CTRL_1                                       |       |          |     |  |  |
| 0x004C | Reserved                                         |       | Reserved |     |  |  |
| 0x0050 | Reserved                                         |       |          |     |  |  |
| 0x0054 | Reserved                                         |       |          |     |  |  |

## 26.6 Debug Configuration

### 26.6.1 Overview

This section provides information for using a debugger on the public ARM Cortex™-A8 in the device. The debug capability is accessible through the JTAG interface with a limited number of pins.

### 26.6.2 JTAG Port Signal Description

The target debug interface of the device uses the five standard IEEE 1149.1 (JTAG) signals (nTRST, TCK, TMS, TDI, and TDO), a return clock (RTCK) to meet the clocking requirements of the ARM968 processor, and two instrumentations pins (EMU0, EMU1). [Table 26-52](#) lists the debug POR signals.

**Table 26-52. Debug POR Signals**

| Pin       | Type <sup>(1)</sup> | Name                | Description                                                                                                                                                                                                            |
|-----------|---------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| jtag_nrst | I                   | Test logic reset    | When asserted (active low), causes all test and debug logic in the device to be reset with the IEEE 1149.1 interface                                                                                                   |
| jtag_tck  | I                   | Test clock          | Test clock used to drive an IEEE 1149.1 test access port (TAP) state-machine and logic. Depending on the emulator attached to the device, this is a free-running clock or a gated clock, depending on RTCK monitoring. |
| jtag_rtck | O                   | Returned test clock | Synchronized TCK. Depending on the emulator attached to device, the JTAG signals are clocked from RTCK or RTCK is monitored by the emulator to gate TCK.                                                               |
| jtag_tms  | I                   | Test mode select    | Directs the next state of the IEEE 1149.1 TAP state-machine                                                                                                                                                            |
| jtag_tdi  | I                   | Test data input     | Scan data input to the device.                                                                                                                                                                                         |
| jtag_tdo  | O                   | Test data output    | Scan data output of the device.                                                                                                                                                                                        |
| jtag_emu0 | I/O                 | Emulation 0         | Channel 0 trigger: Boot mode                                                                                                                                                                                           |
| jtag_emu1 | I/O                 | Emulation 1         | Channel 1 trigger: Boot mode                                                                                                                                                                                           |

<sup>(1)</sup> I = Input; O = Output

To reduce power consumption, the power domain that contains the debug logic can be switched off in normal operating mode.

#### CAUTION

Before starting the debugger, the DEBUG power domain must be activated by applying a minimum of 10 TCK pulses to the device after nTRST is pulled high. To prevent the JTAG\_TMS pin from floating when the EMU power domain is off, an external pullup (10 kΩ) must be added.

### 26.6.3 Initial Scan Chain Configuration

The GP ports that can provide access to many test support functions built into the device (including the test logic defined by the IEEE 1149.1 standard) are the TAP.

The first level of the debug interface that sees the scan controller is the TAP router module.

The debugger can configure the TAP router to link to 16 TAP controllers serially or to scan one TAP controller individually without disrupting the instruction register (IR) state of the other TAPs. The initial scan chain configuration of the device is determined from the level of the EMU0 and EMU1 pins on the release of POR. At POR, EMU0 and EMU1 are automatically configured as inputs. The EMU0 and EMU1 pins must be pulled high at POR to configure the initial scan chain of the device to the TAP router-only mode. In the TAP router-only configuration, no secondary TAPs are selected. The TAP router is the only TAP between the device-level TDI and TDO.

The router TAP has an IR length of 6 bits. This is the recommended boot mode. The third-party debugger must assume that the TAP router is the only TAP between TDI and TDO at boot.

## 26.6.4 Adding TAPs to the Scan Chain

The TAP router must be programmed to add TAPs to the scan chain (used in Design For Test). The following JTAG scans must be completed before the CoreSight debug access port (DAP) is added to the scan chain. CoreSight is the on-chip debug and trace ARM technology. IR and DR are the instruction register and the data register, respectively.

```
## Function : Update the JTAG preamble and post-amble counts. Parameter : The IR pre-amble count is '0'. Parameter : The IR post-amble count is '0'. Parameter : The DR pre-amble count is '0'. Parameter : The DR post-amble count is '0'. Parameter : The IR main count is '6'. Parameter : The DR main count is '1'. ## Function : Do a send-only JTAG IR/DR scan. Parameter : The route to JTAG shift state is 'shortest transition'. Parameter : The JTAG shift state is 'shift-ir'. Parameter : The JTAG destination state is 'pause-ir'. Parameter : The bit length of the command is '6'. Parameter : The send data value is '0x00000007'. Parameter : The actual receive data is 'discarded'. ## Function : Do a send-only JTAG IR/DR scan. Parameter : The route to JTAG shift state is 'shortest transition'. Parameter : The JTAG shift state is 'shift-dr'. Parameter : The JTAG destination state is 'pause-dr'. Parameter : The bit length of the command is '8'. Parameter : The send data value is '0x00000089'. Parameter : The actual receive data is 'discarded'. ## Function : Do a send-only JTAG IR/DR scan. Parameter : The route to JTAG shift state is 'shortest transition'. Parameter : The JTAG shift state is 'shift-ir'. Parameter : The JTAG destination state is 'pause-ir'. Parameter : The bit length of the command is '6'. Parameter : The send data value is '0x00000002'. Parameter : The actual receive data is 'discarded'. ## Function : Embed the POR address in next command. Parameter : The POR address field is '0x0f000000'. Parameter : The POR address value is '3'. ## Function : Do a send-only JTAG IR/DR scan. Parameter : The route to JTAG shift state is 'shortest transition'. Parameter : The JTAG shift state is 'shift-dr'. Parameter : The JTAG destination state is 'pause-dr'. Parameter : The bit length of the command is '32'. Parameter : The send data value is '0xa3002108'. Parameter : The actual receive data is 'discarded'. ## Function : Do a send-only all-ones JTAG IR/DR scan. Parameter : The JTAG shift state is 'shift-ir'. Parameter : The JTAG destination state is 'run-test/idle'. Parameter : The bit length of the command is '6'. Parameter : The send data value is 'all-ones'. Parameter : The actual receive data is 'discarded'. ## Function : Wait for a minimum number of TCLK pulses. Parameter : The count of TCLK pulses is '10'. ## Function : Update the JTAG preamble and post-amble counts. Parameter : The IR pre-amble count is '0'. Parameter : The IR post-amble count is '6'. Parameter : The DR pre-amble count is '0'. Parameter : The DR post-amble count is '1'. Parameter : The IR main count is '4'. Parameter : The DR main count is '1'.
```

After the DAP is added to the scan chain, the debugger can communicate with the Cortex-A8 processor.

## 26.6.5 Debugger Address Space

The CoreSight components are interfaced with the TAP router through the DAP. As recommended by the CoreSight architecture, the DAP is directly interfaced to the device bus. The debugger can directly access the entire memory space without requiring the processor to enter debug state and be programmed with a load or store instruction. [Table 26-53](#) lists the modules that are mapped to the DAP address, and the address space detail.

**Table 26-53. Debugger Address Space**

| Start Addr (Hex) | End Addr (Hex) | Size | Description                               |
|------------------|----------------|------|-------------------------------------------|
| 0x5401 0000      | 0x5401 0FFF    | 4KB  | ARM embedded trace macrocell (ETM) module |
| 0x5401 1000      | 0x5401 1FFF    | 4KB  | Cortex-A8 module                          |
| 0x5401 9000      | 0x5401 9FFF    | 4KB  | Trace port interface unit (TPIU)          |
| 0x5401 B000      | 0x5401 BFFF    | 4KB  | ARM embedded trace buffer (ETB) module    |

The DBGEM signal on the Cortex-A8 is driven by setting bit 13 at address 0x5401 D030 in the DAP-APB address space.



## ***Debug and Emulation***

This chapter describes the debug and emulation module on the device.

---

**NOTE:** This chapter gives information about all modules and features in the high-tier device. To check availability of modules and features, see [Section 1.5, AM/DM37x Family](#) and your device-specific data manual. In unavailable modules and features, the memory area is reserved, read is undefined, and write can lead to unpredictable behavior.

---

| <b>Topic</b>                                   | <b>Page</b> |
|------------------------------------------------|-------------|
| <b>27.1 Debug and Emulation Overview .....</b> | <b>3616</b> |
| <b>27.2 ICEPick Module .....</b>               | <b>3618</b> |
| <b>27.3 SDTI Module .....</b>                  | <b>3638</b> |
| <b>27.4 Emulation Pin Manager .....</b>        | <b>3670</b> |

## 27.1 Debug and Emulation Overview

This chapter presents an overview of the debug and emulation hardware features.

### 27.1.1 Debug and Emulation Overview Features

Debugging a system containing multiple embedded processors involves an environment that connects high-level debugging software, executing on a host computer, to a low-level debug interface supported by the device. Between these levels is an emulator, which facilitates communication between the host debugger and the emulation logic on the device.

Debug and emulation is a combination of hardware and software that connects the host debugger to the target device. It uses one or more hardware interfaces and/or protocols to convert actions dictated by the debugger user to JTAG commands and scans that execute the core hardware.

[Figure 27-1](#) shows the module used in the device for debug and emulation.

**Figure 27-1. Debug and Emulation Hardware in the Device**



The debug software and hardware components lets the user control multiple central processing unit (CPU) cores embedded in the device in a global or local manner. This environment provides:

- Synchronized global starting and stopping of multiple processors (the ICEPick™ feature is not supported by all the platform processors)
- Starting and stopping of an individual processor
- Each processor can generate triggers that can be used to alter the execution flow of other processors.

### 27.1.2 Debug and Emulation Functional Description

#### 27.1.2.1 ICEPick

The device contains multiple processors, each of which has a JTAG test access port (TAP) embedded in the processor. The ICEPick module manages these TAPs and the power, clock, and reset controls for the module that has the TAP. At its root, ICEPick is a scan path linker that allows the scan controller to selectively choose which subsystem TAPs are accessible through the device level debug port. ICEPick is configured through its IEEE 1149.1 JTAG TAP controller.

The ICEPick module is described in [Section 27.2, ICEPick Module](#).

### 27.1.2.2 SDTI

The system debug trace interface (SDTI) is a component that implements the device system trace. The SDTI module provides real-time software tracing functionality to the device. It generates operating system monitor messages that are encoded as defined in the custom protocol.

---

**NOTE:** The custom protocol is not MIPI® compliant.

---

Messages let software provide crucial information, thus providing a high level of visibility on system behavior (task entry, procedures calls, system status, test signatures, and memory allocation); 256 message channels, which can be allocated between software components, are available.

The SDTI implements only trace export from the device to a remote PC through an emulator box. There is no receive path feature in the SDTI. A standard asynchronous serial port (universal asynchronous receiver/transmitter [UART], 8 data bits, 1 stop-bit, no parity) can be used as a back-channel to send emulation-related control requests and data back to the device.

The SDTI is described in [Section 27.3, SDTI Module](#).

### 27.1.2.3 EPM

The emulation pin manager (EPM) manages emulation pin multiplexing to the application pin manager. It allows the selection of an emulation interface to be routed to the device boundary pads.

The EPM is described [Section 27.4, Emulation Pin Manager](#).

### 27.1.2.4 DAP

The debug access port (DAP) enables the external debugger to directly access the entire memory space of the device without requiring the processor to enter the debug state and be programmed with a load or store instruction.

The DAP directly interfaces with the device level 4 (L4) EMU interconnect. The DAP is attached to the last ICEPick secondary TAP and translates JTAG transactions into interconnect transactions.

For more information about the DAP, see the documentation section at <http://www.arm.com/>.

### 27.1.2.5 ETM

The embedded trace macrocell (ETM) generates a real-time trace to the trace port interface unit (TPIU) or is stored in the embedded trace buffer (ETB).

For more information about the ETM, see the documentation section at <http://www.arm.com/>.

### 27.1.2.6 ETB

The ETB stores the trace generated by the ETM. The trace can then be read by the JTAG interface.

For more information about the ETB, see the documentation section at <http://www.arm.com/>.

### 27.1.2.7 TPIU

The TPIU is used to export the ETM trace at the device pads.

For more information about the TPIU, see the documentation section at <http://www.arm.com/>.

## 27.2 ICEPick Module

This section describes the ICEPick module in the device.

### 27.2.1 ICEPick Overview

System-on-a-chip designs typically have multiple processors, each of which has a JTAG TAP embedded in the processor. The ICEPick module manages these TAPs and the power, clock, and reset controls for modules that have TAPs. At its root, ICEPick is a scan path linker that lets the scan controller selectively choose which subsystem TAPs are accessible through the device level debug port. ICEPick is configured through its IEEE 1149.1 JTAG TAP controller. [Figure 27-2](#) is an overview of the ICEPick module in the device.

**Figure 27-2. ICEPick Overview**



ICEPick supports:

- Individually selecting one or more of the TAPs for scan without disrupting the state of other TAPs
- Management of the reset to many processors
- Management of the power and clock of many power domains

The ICEPick module has the following characteristics:

- IR length of 6 bits
- DR length of 1 in bypass mode
- DR length from 1 to 32 (see [Section 27.2.4.5, ICEPick Instructions](#))
- Boot mode controlled by device pins (see [Section 27.2.2, ICEPick Environment](#))

### 27.2.2 ICEPick Environment

The ICEPick module is connected to the JTAG interface in the device. The JTAG interface has six pins plus two pins for selecting ICEPick boot mode (see [Table 27-1](#)).

**Table 27-1. JTAG Pins**

| PAD       | Name             | Width | Type <sup>(1)</sup> | Reset Value | Description                                                                                                                 |
|-----------|------------------|-------|---------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| jtag_nrst | Test Logic Reset | 1     | I                   | HiZ         | When asserted (active low), causes all test and debug logic in the device to be reset along with the IEEE 1149.1 interface. |

<sup>(1)</sup> I = Input; O = Output

**Table 27-1. JTAG Pins (continued)**

| PAD       | Name                | Width | Type<br>( <sup>†</sup> ) | Reset<br>Value | Description                                                                                                                                                                                                     |
|-----------|---------------------|-------|--------------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| jtag_tck  | Test Clock          | 1     | I                        | HiZ            | This is the test clock used to drive an IEEE 1149.1 TAP state-machine and logic. Depending on the emulator attached to the device, this is a free-running clock or a gated clock, depending on RTCK monitoring. |
| jtag_rtck | Returned Test Clock | 1     | O                        | 0              | Synchronized TCK. Depending on the emulator attached to the device, the JTAG signals are clocked from RTCK or RTCK is monitored by the emulator to gate TCK.                                                    |
| jtag_tms  | Test Mode Select    | 1     | I                        | HiZ            | Directs the next state of the IEEE 1149.1 TAP state-machine                                                                                                                                                     |
| jtag_tdi  | Test Data Input     | 1     | I                        | HiZ            | Scans data input to the device                                                                                                                                                                                  |
| jtag_tdo  | Test Data Output    | 1     | O                        | HiZ            | Scans data output of the device                                                                                                                                                                                 |
| jtag_emu0 | Emulation 0         | 1     | IO                       | HiZ            | Channel 0 trigger – boot mode – HS-RTDX – trace port                                                                                                                                                            |
| jtag_emu1 | Emulation 1         | 1     | IO                       | HiZ            | Channel 1 trigger – boot mode – HS-RTDX – trace port                                                                                                                                                            |

For more information about ICEPick boot modes, see [Section 27.2.4.4](#).

The ICEPick module has a TAP state-machine consistent with the IEEE 1149.1 specification. For more information about TAP states, see [Section 27.2.4.3](#).

### 27.2.3 ICEPick Integration

The ICEPick module is in the EMU power domain.

The ICEPick module use only JTAG clocks (jtag\_tck and jtag\_rtck). These clocks are external clocks and are not managed by the device power, reset, and clock management (PRCM) module.

### 27.2.4 ICEPick Functional Description

#### 27.2.4.1 ICEPick Block Diagram

[Figure 27-3](#) is the block diagram of the ICEPick module with the four external (secondary) TAPs connected to the ICEPick scan chain.

**Figure 27-3. ICEPick Overview**


icepick-006

### 27.2.4.2 ICEPick Secondary Debug TAPs

[Table 27-2](#) shows the secondary debug TAPs connected to the ICEPick scan chain. The TAP number shows the position of the TAP in the scan chain and the SDTRj register (see [Table 27-23](#)) used to get access to control and status for this TAP. The ICEPick internal TAP can also be referenced as the primary TAP; it is always in the first position in the scan chain (ICEPick TAP input is connected to the device jtag\_tdi pin).

**Table 27-2. Secondary Debug TAP Mapping**

| Secondary JTAG port | CoreSight | TAP No. | Modules Accessed Through That JTAG Port |
|---------------------|-----------|---------|-----------------------------------------|
| D2D                 | No        | 0       | Die-to-die interface                    |
| IVA                 | No        | 1       | C64x+/ICEMaker                          |
| ARM968™             | No        | 2       | ARM968/ICECrusher™ – IVA Sequencer      |
| DAP                 | Yes       | 3       | MPU/ICECrusher – CS / ETM11 / PSA       |
|                     | Yes       |         | ETB                                     |
|                     | Yes       |         | SDTI                                    |
|                     | No        |         | Clocks Management → L3 → L4_CORE        |
|                     | No        |         | Power Management → L4_EMU → L4_WKUP     |
| Reserved            | No        | 4–15    | Reserved                                |

### 27.2.4.3 ICEPick TAP states

The TAP consists of:

- 32-bit device ID register
- 1-bit bypass register
- 6-bit instruction register (IR)

[Figure 27-4](#) shows ICEPick TAP states. In the figure, TMS corresponds to the jtag\_tms input pin.

**Figure 27-4. TAP State Transitions**



icepick-004

#### 27.2.4.4 ICEPick Boot Modes

The initial configuration of ICEPick is determined from the level of jtag\_emu0 and jtag\_emu1 at POR release. At POR, jtag\_emu0 and jtag\_emu1 are automatically configured as inputs.

In ICEPick-only configuration, none of the secondary TAPs are selected. The ICEPick TAP is the only TAP between the device level TDI and TDO. This is the recommended boot mode (jtag\_emu0 and jtag\_emu1 are set at 1).

The device can boot to invoke wait-in-reset mode. This mode keeps the device microprocessor unit (MPU) in wait-in-reset mode until the ICEPick module disables the MPU reset through a JTAG by writing the SDTRj register (see [Table 27-23](#)).

When TCK direct boot mode is used, the ICEPick clock voting logic is bypassed. TCK is driven onto each secondary TAP.

[Table 27-3](#) shows the values of jtag\_emu0 and jtag\_emu1 used to select different boot modes.

**Table 27-3. ICEPick Boot Mode**

| jtag_emu1 | jtag_emu0 | TAPs in the TDI → TDO Path | Other Effects             |
|-----------|-----------|----------------------------|---------------------------|
| 0         | 0         | ICEPick + D2D              | Boundary scan stacked die |
| 0         | 1         | ICEPick                    | TCK direct                |
| 1         | 0         | ICEPick                    | Wait-in-reset             |
| 1         | 1         | ICEPick                    |                           |

#### 27.2.4.5 ICEPick Instructions

##### 27.2.4.5.1 ICEPick Instruction List

ICEPick TAP supports the instructions listed in [Table 27-4](#). All unused TAP controller instructions default to the bypass register. Several instructions are reserved for extensions to the ICEPick opcodes.

**Table 27-4. ICEPick Instructions**

| IR              | ICEPick Instruction | Extended Instruction         | Access      |
|-----------------|---------------------|------------------------------|-------------|
| 000000          | BYPASS              | Not available                | Always-open |
| 000001          | Reserved            | Not available                | Always-open |
| 000010          | ROUTER              | Not available                | Connected   |
| 000011          | Reserved            | Not available                | Always-open |
| 000100          | IDCODE              | Not available                | Always-open |
| 000101          | ICEPICKCODE         | Not available                | Always-open |
| 000110          | Reserved            | Not available                | Always-open |
| 000111          | CONNECT             | Not available                | Always-open |
| 001000          | USERCODE            | Not available                | Always-open |
| 001001 – 010110 | CONDITIONALBYPASS   | Reserved                     | Connected   |
| 010111          | CONDITIONALBYPASS   | EXTESTnoPUPD (recommended)   | Always-open |
| 011000          | CONDITIONALBYPASS   | EXTEST (recommended)         | Always-open |
| 011001          | CONDITIONALBYPASS   | INTEST (recommended)         | Always-open |
| 011010          | CONDITIONALBYPASS   | RUNBIST (recommended)        | Always-open |
| 011011          | CONDITIONALBYPASS   | SAMPLE (recommended)         | Always-open |
| 011100          | CONDITIONALBYPASS   | PRELOAD (recommended)        | Always-open |
| 011101          | CONDITIONALBYPASS   | CLAMP (recommended)          | Always-open |
| 011110          | CONDITIONALBYPASS   | HIGHZ (recommended)          | Always-open |
| 011111          | CONDITIONALBYPASS   | ENABLE_PRIVATE (recommended) | Connected   |
| 100000 – 100011 | CONDITIONALBYPASS   | Not available                | Always-open |
| 100100          | CONDITIONALBYPASS   | EXT_PULSE (recommended)      | Always-open |

**Table 27-4. ICEPick Instructions (continued)**

| IR              | ICEPick Instruction | Extended Instruction    | Access                |
|-----------------|---------------------|-------------------------|-----------------------|
| 100101          | CONDITIONALBYPASS   | EXT_TRAIN (recommended) | Always-open           |
| 100110 – 110000 | CONDITIONALBYPASS   | Extended opcodes        | Always-open/EnPrivate |
| 110001          | CONDITIONALBYPASS   | Reserved                | Always-open           |
| 110010 – 111110 | CONDITIONALBYPASS   | Extended opcodes        | Always-open/EnPrivate |
| 111111          | BYPASS              | BYPASS                  | Always-open           |

#### 27.2.4.5.2 Instruction Register Scan Path and State

**Capture IR state:** The binary value 000001b is loaded into the data shift register.

**Shift IR state:** The IR shift section of the data shift register is selected as the serial path between the ICEPick TDI and TDO. The value captured at Capture IR is shifted out during Shift IR, with the least significant bit (LSB) first, while a new instruction is shifted in, also with the LSB first.

**Update IR state:** The value in the data shift register is loaded into the instruction register so it becomes the current instruction.

**Test Logic Reset state:** On TAP reset, the IDCODE becomes the current instruction. When the ICEPick TAP reaches the Test Logic Reset state, the IR register is automatically loaded with the IDCODE instruction.

#### 27.2.4.5.3 Data Shift Register Scan Path and State

##### 27.2.4.5.3.1 IDCODE Instruction

**Description:** The IDCODE instruction specifies that the DR shift path is 32 bits long. This path provides a way to export the value of the identification (ID) register in the device. The ID register is a 32-bit register that specifies the manufacturer, part number, and version of the component (see [Table 27-10](#)). The use of this instruction has no effect on the operation of the on-chip system logic.

**Capture DR state:** The 32-bit ID code of the device is loaded into the data shift register during the Capture DR state.

**Shift DR state:** The value captured is shifted out during the Shift DR TAP state with the LSB first, while the value of jtag\_tdi is shifted into the most-significant bit (MSB) of the data shift register. Data is shifted from the MSB to the LSB.

**Update DR state:** The shifted-in data is ignored in the Update DR state.

The device ID can be determined following the generation of the Test Logic Reset TAP state. The Test Logic Reset TAP state causes all JTAG-compliant devices to load the IR with an IDCODE or a BYPASS instruction. These two opcodes provide a different first output (1 for IDCODE; 0 for BYPASS) during the first Shift DR state after the TRST, provided the DR Scan occurs without an intervening IR scan.

Therefore, examination of the first bit of data that is shifted out of a component during a test data scan sequence immediately after exiting the Test Logic Reset state shows whether a device ID register is included in the design.

When test data register scanning is entered in this way, the serial path at the board level includes:

- The device ID registers of components that provide them
- The bypass registers of components that do not include a device ID register

Examination of the first bit of data shifted out of a component as a result of the above interrogation sequence identifies the data as coming from the bypass bit or a device ID register. ICEPick exports a device ID for this sequence, thus providing a way to retrieve and identify the device ID.

#### 27.2.4.5.3.2 ICEPICKCODE Instruction

**Description:** The ICEPICKCODE instruction specifies that the DR shift path is 32 bits long. This path provides a way to export the ICEPick identification (IPID) register (see [Table 27-12](#)). The IPID register is a 32-bit register that specifies the features and version of ICEPick. This ID register is for the ICEPick module and should not be confused with the ID register for the device or any other module. The use of this instruction has no effect on the operation of the on-chip system logic.

**Capture DR state:** The 32-bit ICEPick code is loaded into the data shift register during the Capture DR state.

**Shift DR state:** The value captured is shifted out during the Shift DR TAP state with the LSB first, while the value of `jtag_tdi` is shifted into the MSB of the data shift register. Data is shifted from the MSB to the LSB.

**Update DR state:** The shifted-in data is ignored in the Update DR state.

#### 27.2.4.5.3.3 USERCODE Instruction

**Description:** The USERCODE instruction specifies that the DR shift path is 32 bits long. This path provides a way to export the value of the user code (UC) register (see [Table 27-11](#)). The UC register is a 32-bit register that specifies the variant of a device. The use of this instruction has no effect on the operation of the on-chip system logic.

**Capture DR state:** The 32-bit UC register in the device is loaded into the data shift register during the Capture DR state.

**Shift DR state:** The value captured is shifted out during Shift DR TAP state with the LSB first, while the value of `jtag_tdi` is shifted into the MSB of the data shift register. Data is shifted from the MSB to the LSB.

**Update DR state:** The shifted-in data is ignored in the Update DR state.

#### 27.2.4.5.3.4 BYPASS Instruction

**Description:** The IEEE 1149.1 specification mandates a BYPASS instruction and that the instruction decode must be an all-ones value equal in length to the instruction register length. All unused TAP controller instruction codes default to having the same characteristics as the BYPASS instruction.

The BYPASS instruction, and all instruction codes defaulting to the BYPASS instruction, specifies a DR shift path 1 bit long between the ICEPick TDI and TDO. This path provides a way to export the 0 used to differentiate bypass data from the data in the device ID register, if a DR scan is performed immediately following the Test Logic Reset TAP state.

**Capture DR state:** In the Capture DR state, 0 is loaded into the 1-bit shift path selected by this instruction.

**Shift DR state:** When the BYPASS instruction is the current instruction in the instruction register, serial data is transferred from TDI to TDO through the 1-bit bypass register while in the Shift DR state with a delay of one TCK cycle.

**Update DR state:** The shifted-in data is ignored in the Update DR state.

The BYPASS instruction is used when a scan controller wants to shift in data or commands to another TAP on the scan path without disturbing this TAP.

#### 27.2.4.5.3.5 CONNECT\_PUBLIC Instruction

**Description:** The CONNECT\_PUBLIC instruction, in combination with the connect register, is used to enable many of the other IR instructions. Before being enabled, the instructions act as the BYPASS instruction.

The CONNECT\_PUBLIC instruction specifies that the DR shift path is 8 bits long. This path provides a way to access the connect register, which is described in [Table 27-13](#).

**Capture DR state:** When the CONNECT instruction is in the IR, a DR scan scans through the 8 lower bits of the data shift register. Bit 7 is not part of the connect register (0 is used to read the register; 1 is used to write the register).

**Shift DR state:** When in the Shift IR state, the connect shift section of data shift register is selected as the serial path between the ICEPick TDI and TDO. The value captured at Capture DR is shifted out to ICEPick TAP TDO during Shift DR, with the LSB first. The value on jtag\_tdi is shifted into the data shift register. Data is shifted from the MSB to the LSB.

---

**NOTE:** While the value is being scanned out, a new register access (read or write) can be scanned in.

---

**Update DR state:** On read and write, the scan chain is decoded at the Update DR state. The value of bit 7 determines whether the connect register is written at the Update DR state. If 1, the register is written.

#### 27.2.4.5.3.6 CONNECT\_PRIVATE

**Description:** The CONNECT\_PRIVATE instruction, in combination with the private enable register, is used to enable extended TAP functions. The CONNECT\_PRIVATE instruction is accessible only after the Connect Public scan sequence is complete.

The CONNECT\_PRIVATE instruction specifies that the DR shift path is 1 bit in length. This path provides a way to access the private enable register.

**Capture DR state:** In the Capture DR state, the current value of Private\_Enable is loaded into the 1-bit shift path selected by this instruction.

**Shift DR state:** When the CONNECT\_PRIVATE instruction is the current instruction in the instruction register, serial data is transferred from TDI to TDO through the 1-bit Private\_Enable register while in the Shift DR state with a delay of one TCK cycle.

**Update DR state:** The shifted-in data is latched in a temporary register in the Update DR state.

**Run Test Idle state** The data value in the temporary register is written to Private\_Enable when the Run\_Test\_Idle state is reached.

The Private\_Enable instruction is used to prevent extended TAP functions from being invoked until the connect sequence completes. This can be used to ensure test functions are held in reset, even though the chip-level test reset is no longer asserted.

#### 27.2.4.5.3.7 ROUTER Instruction

**Description:** The ROUTER instruction specifies that the DR shift path is 32 bits long. This path provides a way to access the ICEPick TAP linking, status, and control registers. It provides accessibility to the secondary TAP controls for each TAP that ICEPick manages (see [Section 27.2.4.6.3.1, TAP\\_ROUTING\\_REG Description](#)).

The ROUTER instruction connects the ICEPick router scan path between TDI and TDO when doing a DR scan. This scan chain facilitates reading and writing of all ICEPick registers. All ICEPick functions are accessed through registers. The ROUTER instruction is used to read and write the registers.

---

**NOTE:** To use the ROUTER instruction, ICEPick must be in the connected state. Otherwise, this instruction acts like the BYPASS instruction.

---

**Capture DR state:** During the Capture DR state, the data shift register is inspected. The register specified by the block and register fields is read and the value is placed in the lower 24 bits of the data shift register.

---

**NOTE:** The current contents of the data shift register are those loaded by the previous scan. The register specified in DR scan n-1 is read during scan n. If an intervening IR scan occurs, the contents of the data shift register are unpredictable; therefore, a read of the register indicated in DR scan n-1 does not occur.

---

The write-failure (WF) bit is captured into the data shift register at bit 31. Once the value is captured, the WF flag is cleared.

**Shift DR state:** The 32-bit value captured is shifted out during the Shift DR TAP state with the LSB first, while the value of jtag\_tdi is shifted into the MSB of the data shift register. Data is shifted from the MSB to the LSB.

The shifted-in value may contain a new register read or write request and the associated payload.

**Update DR state:** For a read or write, the scan chain is decoded during the Update DR state.

Figure 27-5 shows multiple read access in the ROUTER instruction.

**Figure 27-5. Multiple Read in ROUTER Instruction**



Figure 27-6 shows multiple write access in the ROUTER instruction.

**Figure 27-6. Multiple Write in ROUTER Instruction**



Figure 27-7 shows mixed read and write access in the ROUTER instruction.

**Figure 27-7. Mixed Read and Write in ROUTER Instruction**



## 27.2.4.6 ICEPick Registers

ICEPick registers are accessed through the ICEPick TAP.

### 27.2.4.6.1 Registers

Table 27-5 shows the ICEPick registers.

**Table 27-5. ICEPick Registers**

| Register                       | Name         | Width             | Number | Description                                                                                      |
|--------------------------------|--------------|-------------------|--------|--------------------------------------------------------------------------------------------------|
| Data shift register            | DSR          | 32                | 1      | TAP data register                                                                                |
| Instruction register           | IR           | 6                 | 1      | TAP instruction register                                                                         |
| Bypass register                | BP           | 1                 | 1      | Used by the BYPASS instruction                                                                   |
| Device identification register | TAPID        | 32                | 1      | Device ID used with IDCODE                                                                       |
| User code register             | UC           | 32                | 1      | User Code used with USERCODE                                                                     |
| ICEPick identification         | IPID         | 32                | 1      | Version of ICEPick                                                                               |
| Connect                        | CONNECT      | 8                 | 1      | Connect code                                                                                     |
| All 0s                         | ALL0S        | 24 <sup>(1)</sup> | 1      | Returns 0s                                                                                       |
| ICEPick control                | CONTROL      | 24 <sup>(1)</sup> | 1      | General ICEPick control                                                                          |
| Linking mode                   | LINKING_MODE | 24 <sup>(1)</sup> | 1      | Specifies how ICEPick manages the TAP selection                                                  |
| Secondary debug TAP register   | SDTRj        | 24 <sup>(1)</sup> | 16     | One register exists for each test TAP instantiated. It is used to control selection of each TAP. |

<sup>(1)</sup> Register is 32 bits, but 8 upper bits are used for read/write, block, and register selection. See [Table 27-14](#) pseudo register.

#### 27.2.4.6.2 Register Reset Conditions

Each register bit has a reset condition. One of these reset conditions is used to reset each bit in ICEPick. [Table 27-6](#) shows the reset conditions.

**Table 27-6. Register Reset Conditions**

| Condition | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -         | The bit always reflects the current value of an input signal.                                                                                                                                                                                                                                                                                                                                                                                                     |
| Fixed     | The bit is set to a particular value and does not change during operation.                                                                                                                                                                                                                                                                                                                                                                                        |
| POR       | The bit is reset upon POR.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| QTLR      | The bit is reset upon state change to Test Logic Reset if the ICEPick TAP is visible and the ICEPick register reset is not blocked. In this sense, reset based on reaching the Test Logic Reset state is qualified.                                                                                                                                                                                                                                               |
| QnTRST    | The bit is reset on assertion low of the device pin nTRST if the ICEPick TAP is visible and the ICEPick register reset is not blocked. In this sense, reset based on nTRST assertion is qualified. Because the assertion of nTRST changes the TAP state to Test Logic Reset, the QTLR reset condition often applies. Unlike QTLR, a bit that is reset based on this condition is not reset if the Test Logic Reset state is reached through changes in TAP state. |
| ARST      | The bit is reset upon any of the above resets. In other words, the bit is reset upon POR or QTLR or QnTRST. In practice, QnTRST is not needed in this equation because nTRST assertion drives the TAP state to Test Logic Reset so the QTLR condition will then apply.                                                                                                                                                                                            |

#### 27.2.4.6.3 Register Description

[Table 27-7](#) through [Table 27-13](#) describe the individual registers.

**Table 27-7. DSR**

|                    |                                                                                                                                                                                                                                        |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Description</b> | The data shift register is the register used to shift bits between the ICEPick TDI and TDO. This register is 32 bits wide. It has multiple shift in points to facilitate shifts on the instruction path and several of the data paths. |
| <b>Type</b>        | RW                                                                                                                                                                                                                                     |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                   |   |   |   |        |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------------|---|---|---|--------|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                   |   |   |   | BYPASS |   |   |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Instruction shift |   |   |   |        |   |   |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Connection shift  |   |   |   |        |   |   |

When asked to shift, one bit is shifted from each bit into the next lower bit. A new value is shifted in from TDI while the LSB is shifted out to TDO. The shift register has several insertion points based upon the current TAP state or value in the instruction register.

**Table 27-8. IR**

|                                                                                                  |                                                                                                                   |
|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| <b>Description</b>                                                                               | The instruction register (IR) contains the current TAP instruction. ICEPick's instruction register is 6 bits wide |
| <b>Type</b>                                                                                      | W                                                                                                                 |
| <b>Reset</b>                                                                                     | IDCODE upon QTLR                                                                                                  |
| 5                  4                  3                  2                  1                  0 |                                                                                                                   |
| INSTRUCTION                                                                                      |                                                                                                                   |

**Table 27-9. BP**

|                    |                                                                                                                                     |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| <b>Description</b> | The bypass register is a 1 bit register. Whatever value is scanned in TDI is preserved and scanned out of TDO one ITCK cycle later. |
| <b>Type</b>        | RW                                                                                                                                  |
| 0                  |                                                                                                                                     |
| BYPASS             |                                                                                                                                     |

**Table 27-10. TAPID**

|                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Description</b>                                                                                                                                                                 | The device identification register allows the manufacturer, part number, and version of a component to be determined through the TAP. The device identification register is scanned in response to the IDCODE instruction. This allows the manufacturer, part number, and variant for the component to be read in a serial binary form. |
| <b>Type</b>                                                                                                                                                                        | R                                                                                                                                                                                                                                                                                                                                       |
| 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 |                                                                                                                                                                                                                                                                                                                                         |
| VERSION                  PARTNUMBER                  MANUFACTURER                                                                                                                  |                                                                                                                                                                                                                                                                                                                                         |
| RESERVED                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                         |

| Bits  | Field Name   | Description                      | Type | Reset              |
|-------|--------------|----------------------------------|------|--------------------|
| 31:28 | VERSION      | Revision of the device.          | R    | See <sup>(1)</sup> |
| 27:12 | PARTNUMBER   | Part number of the device        | R    | See <sup>(1)</sup> |
| 11:1  | MANUFACTURER | TI's JEDEC bank and company code | R    | 00000010111b       |
| 0     | RESERVED     | Bit 0 is always 1.               | R    | 1b                 |

<sup>(1)</sup> TI internal data

**Table 27-11. UC**

|                         |                                                                                                                                                                                                                                                  |                       |                 |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Description</b>      | The User Code register helps to distinguish between the devices built from the same chip. The User Code register value is set through e-Fuse. Each variant, either distinguished by feature set or pinned out interface, is uniquely identified. |                       |                 |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                                                                                                                |                       |                 |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |
| 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 |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |
| VERSION                 | VARIANT                                                                                                                                                                                                                                          |                       |                 |  |  |  |  |  |  |  |  |  | RESERVED |  |  |  |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name | Description                       | Type | Reset              |
|-------|------------|-----------------------------------|------|--------------------|
| 31:28 | VERSION    | Revision of the device            | R    | See <sup>(1)</sup> |
| 27:12 | VARIANT    | Variant of chip                   | R    | See <sup>(1)</sup> |
| 11:0  | RESERVED   | Reserved. Read return reset value | R    | 0x0001             |

<sup>(1)</sup> TI internal data

**Table 27-12. IPID**

|                         |                                                                                                                                                                  |                       |                 |         |  |  |  |  |  |  |  |  |  |  |  |          |          |       |       |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|---------|--|--|--|--|--|--|--|--|--|--|--|----------|----------|-------|-------|--|--|--|--|--|--|
| <b>Description</b>      | The ICEPick identification register indicates the features and version of the ICEPick module. It should not be confused with the device identification register. |                       |                 |         |  |  |  |  |  |  |  |  |  |  |  |          |          |       |       |  |  |  |  |  |  |
| <b>Type</b>             | R                                                                                                                                                                |                       |                 |         |  |  |  |  |  |  |  |  |  |  |  |          |          |       |       |  |  |  |  |  |  |
| 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 |         |  |  |  |  |  |  |  |  |  |  |  |          |          |       |       |  |  |  |  |  |  |
| MAJOR                   | MINOR                                                                                                                                                            | TEST_TAP              | EMU_TAP         | ICEPICK |  |  |  |  |  |  |  |  |  |  |  | RESERVED | RESERVED | CAPA1 | CAPA0 |  |  |  |  |  |  |

| Bits  | Field Name | Description                                                                                            | Type | Reset              |
|-------|------------|--------------------------------------------------------------------------------------------------------|------|--------------------|
| 31:28 | MAJOR      | Revision of ICEPick                                                                                    | R    | See <sup>(1)</sup> |
| 27:24 | MINOR      | Revision of the ICEPick                                                                                | R    | See <sup>(1)</sup> |
| 23:20 | TEST_TAP   | Number of Test TAPs instantiated. A value of 0 indicates 16 TAPs since 0 is an invalid number of TAPs. | R    | -                  |
| 19:16 | EMU_TAP    | Number of EMU TAPs instantiated. A value of 0 indicates 16 TAPs since 0 is an invalid number of TAPs.  | R    | -                  |
| 15:4  | ICEPICK    | An identifier of the Icepick Type. Current Types are A, B and C.                                       | R    | 0x1CC              |
| 3     | RESERVED   | Reserved, reads back a zero                                                                            | R    | 0                  |
| 2     | RESERVED   | A value of 1 indicates Die to Die interface mode is selected                                           | R    | -                  |
| 1     | CAPA1      | A value of 1 indicates Clock Voting is instantiated.                                                   | R    | -                  |
| 0     | CAPA0      | A value of 1 indicated Reduced Tclk Mode is instantiated                                               | R    | -                  |

<sup>(1)</sup> TI internal data

**Table 27-13. CONNECT**

|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |   |   |            |   |   |  |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|------------|---|---|--|
| <b>Description</b> | The Connect Register serves 2 purposes. First, it is used to guard use of most IR instructions. This prevents noise, hot connecting an emulator cable, or accidental scan by a miss configured scan controller, from causing test, debug, or boundary scan operations from mistakenly engaging debug functions. Secondly, this register can be used to signal that a debugger is connected and that emulation logic should be powered and enabled. |   |   |   |            |   |   |  |
| <b>Type</b>        | R (ARST)                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |   |   |            |   |   |  |
| 7                  | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 5 | 4 | 3 | 2          | 1 | 0 |  |
| WRITE              | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |   |   | CONNECTKEY |   |   |  |

| Bits | Field Name | Description                                                                                                                                                                                                     | Type     | Reset |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|
| 7    | WRITE      | Must be 1 to write the Connect Key. A value of 0 is a read. When read, a value of 0 is returned.                                                                                                                | R (ARST) | 0b    |
| 6:4  | RESERVED   | Reserved, read return reset value                                                                                                                                                                               | R (ARST) | 000b  |
| 3:0  | CONNECTKEY | When this field holds the key-code of 1001, the scan controller is considered to be connected. All other values are the not-connected state. In this state, only a limited number of IR instructions are valid. | R (ARST) | 0110b |

#### **27.2.4.6.3.1 TAP\_ROUTING\_REG Description**

[Table 27-14](#) and [Table 27-15](#) describe the TAP\_ROUTING register and the mode block selection, respectively.

**Table 27-14. TAP\_ROUTING**

|                    |       |                                                                                           |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------------|-------|-------------------------------------------------------------------------------------------|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Description</b> |       | This register permit read/write on register situated in different block of ICEPick module |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>        |       | RW                                                                                        |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 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 |
| WRITE              | BLOCK | REGISTER                                                                                  | PAYLOAD |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits  | Field Name | Description                                                                                                                                       | Type | Reset |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31    | WRITE      | Write 0 a read operation is executed<br>Write 1 a write operation is executed<br>Read 0 previous write successful<br>Read 1 previous write failed | RW   | -     |
| 30:28 | BLOCK      | Select the block to read/write. See <a href="#">Table 27-15</a>                                                                                   | RW   | -     |
| 27:24 | REGISTER   | Select the register in the block to read/write. See <a href="#">Section 27.2.4.6.3.1.1</a> and <a href="#">Section 27.2.4.6.3.1.2</a>             | RW   | -     |
| 23:0  | PAYLOAD    | Data payload to read or write                                                                                                                     | RW   | -     |

**Table 27-15. TAP Routing Mode Block Selection**

| Block Select | Block                     |
|--------------|---------------------------|
| 000          | ICEPick Control           |
| 001          | Reserved                  |
| 010          | Debug TAP Linking Control |
| 011          | Reserved                  |
| 100          | Reserved                  |
| 101          | Reserved                  |
| 110          | Reserved                  |
| 111          | Reserved                  |

**NOTE:** A read to a reserved register returns 0.

#### **27.2.4.6.3.1.1 ICEPick Control Block**

[Table 27-16](#) shows registers available in the ICEPick control block and the value of the TAP\_ROUTING\_REG[27:24] bit field used to access them.

**Table 27-16. ICEPick Control Block Registers**

| REGISTER | Register Name |
|----------|---------------|
| 0x0      | ALL0S         |
| 0x1      | CONTROL       |
| 0x2      | LINKING_MODE  |
| 0x3-0xF  | Reserved      |

**NOTE:** A read to a reserved register returns 0.

**Table 27-17. ALL0S**

|                                                                                             |                                                                                                                                                          |
|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description                                                                                 | The ALL0S register is a dummy register that returns 0 when read. Writes are ignored. There are not any side effects to writing or reading this register. |
| Type                                                                                        | RW                                                                                                                                                       |
| 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 | ZERO                                                                                                                                                     |
| TAP_ROUTING                                                                                 |                                                                                                                                                          |

| Bits  | Field Name  | Description                       | Type | Reset |
|-------|-------------|-----------------------------------|------|-------|
| 31:24 | TAP_ROUTING | See <a href="#">Table 27-14</a> . | RW   | -     |
| 23:0  | ZERO        | Read return 0's.                  | R    | 0x0   |

**Table 27-18. CONTROL**

|                                                                                             |                                                                                                                                                                                                     |
|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description                                                                                 | This register control different features of the ICEPick module                                                                                                                                      |
| Type                                                                                        | RW                                                                                                                                                                                                  |
| 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 |                                                                                                                                                                                                     |
| TAP_ROUTING                                                                                 | RESERVED ADVANCERTCKTIMING RESERVED UNNATURALSYSRESET REDUCEDTCK SYSTEMSTATUS FREERUNNINGEMUL RESERVED CLEARALLEXFLAG GLOBALRELEASEMIR KEEPPOWERINTLR TDOALWAYSSOUT RESERVED DEVICETYPE SYSTEMRESET |

| Bits  | Field Name        | Description                                                                                                                                                                                         | Type | Reset      |
|-------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:24 | TAP_ROUTING       | See <a href="#">Table 27-14</a> .                                                                                                                                                                   | RW   | -          |
| 23:18 | RESERVED          | Reserved, Read return reset value, write reset value for further compatibility                                                                                                                      | R    | 0x0 (ARST) |
| 17    | ADVANCERTCKTIMING | When 0, the ICEPick clock voting logic is configured so RTCK lags ITCK.<br>When 1, the ICEPick clock voting logic is configured so RTCK has same timing as ITCK                                     | RW   | 0 (ARST)   |
| 16    | RESERVED          | Reserved, Read return reset value, write reset value for further compatibility                                                                                                                      | R    | -          |
| 15    | UNNATURALSYSRESET | When 0, the system-reset state is consistent with the application controls.<br>When 1, the system-reset state is not consistent with the application controls due to emulation actions or controls. | R    | -          |

| Bits | Field Name       | Description                                                                                                                                                                                                                                                                                                                                                                                              | Type | Reset    |
|------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 14   | REDUCEDTCK       | When 0, the ICEPick clock voting logic is configured to operate upto the TCLK input frequency.<br>When 1, the ICEPick clock voting logic is configured to operate upto the TCLK input frequency when no debug TAPs are selected.                                                                                                                                                                         | RW   | 0 (ARST) |
| 13   | SYSTEMSTATUS     | This bit reflects the value of a system status signal.                                                                                                                                                                                                                                                                                                                                                   | R    | -        |
| 12   | FREERUNNINGEMUL  | This bit drives the FreeRunEmul output port and is used to configure ICECrusher modules for operation with an emulator which has a free running TCLK.                                                                                                                                                                                                                                                    | RW   | 0 (ARST) |
| 11   | RESERVED         | Reserved, Read return reset value, write reset value for further compatibility                                                                                                                                                                                                                                                                                                                           | R/W  | 0 (ARST) |
| 10   | CLEARALLEXEFLAG  | When a 1 is written, the latched value of all run bits in all secondary TAPs is cleared back to 0.<br>Writing a 0 has no effect.                                                                                                                                                                                                                                                                         | W    | 0 (ARST) |
| 9    | GLOBALEXEMASK    | When 0, the value in the Secondary Debug TAP Register ExecuteAction bit is immediately applied to the secondary TAP and module.<br>When 1, the run signal to the terminal is held at 0. After several secondary TAP's run bit have been set while this bit is 1, changing this bit to 0 will cause all of the secondary TAP to see the run signal at the same time.                                      | RW   | 0 (ARST) |
| 8    | GLOBALRELEASEWIR | When a 1 is written to this bit and the device is held in reset due to the GlobalWaitInReset signal, the GlobalWaitInReset signal is deasserted.<br>This is a self-clearing bit. Writing a 0 has no effect.                                                                                                                                                                                              | R/W  | 0 (ARST) |
| 7    | KEEPPOWERINTLR   | When 1, the ICEPick logic remains powered at all times.<br>When 0, the ICEPick logic may be powered down in the Test-Logic-Reset state if ICEPick is visible and TMS is 1.                                                                                                                                                                                                                               | RW   | 0 (POR)  |
| 6    | BLOCKSYSRESET    | When 1, the device system reset signal is blocked.                                                                                                                                                                                                                                                                                                                                                       | RW   | 0 (ARST) |
| 5    | TDOALWAYSOUT     | When 1, the device level TDO pin will always be driven (in output mode) regardless of the TAP state.<br>When 0, the device level TDO pin will be influenced by the current TAP state in compliance with the IEEE1149.1 specification (either output or Hi-Z mode)                                                                                                                                        | RW   | 0 (POR)  |
| 4    | RESERVED         | Reserved, write reset value for further compatibility                                                                                                                                                                                                                                                                                                                                                    | W    | 0 (POR)  |
| 3:1  | DEVICETYPE       | Device Type.                                                                                                                                                                                                                                                                                                                                                                                             | R    | 011b     |
| 0    | SYSTEMRESET      | Emulator controlled System Reset. This signal provides the scan controller with the ability to assert the system warm reset. When a 1 is written, this behaves as if the external chip warm reset signal had been momentarily asserted. This signal does not reset any emulation logic. This is a self-clearing bit. This is cleared by the assertion of the reset requested. Writing a 0 has no effect. | RW   | 0 (ARST) |

**Table 27-19. LINKING\_MODE**

| Description             |                         | This register control link features of the ICEPick module |                 |             |          |             |              |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|-----------------------------------------------------------|-----------------|-------------|----------|-------------|--------------|--|--|--|--|--|--|--|--|--|
| Type                    | RW                      |                                                           |                 |             |          |             |              |  |  |  |  |  |  |  |  |  |
| 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 |             |          |             |              |  |  |  |  |  |  |  |  |  |
| TAP_ROUTING             | RESERVED                | SPONDISCOFLAG                                             | DESELECTMODE    | KEYSEQUENCE | RESERVED | TAPLINKMODE | ActivateMode |  |  |  |  |  |  |  |  |  |

| Bits  | Field Name  | Description                                                                    | Type | Reset      |
|-------|-------------|--------------------------------------------------------------------------------|------|------------|
| 31:24 | TAP_ROUTING | See <a href="#">Table 27-14</a> .                                              | RW   | -          |
| 23:19 | RESERVED    | Reserved, Read return reset value, write reset value for further compatibility | R    | 0x0 (ARST) |

| Bits  | Field Name     | Description                                                                                                                                                                                                                                                                                                              | Type | Reset   |
|-------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 18    | SPONTDISCOFLAG | This flag is set if the TAPs are spontaneously removed from the scan chain or if a selected TAP loses power. It also forces the TDO output to HiZ.<br>Writing a 1 to this bit clears it. Writing a 0 has no effect.                                                                                                      | RW   | 0 (POR) |
| 17:16 | DESELECTMODE   | See <a href="#">Table 27-20</a> .                                                                                                                                                                                                                                                                                        | RW   | 0 (POR) |
| 15:6  | KEYSEQUENCE    | When the TAPLinkMode is set to "key sequence", this field contains the "key sequence pattern" that will make the ICEPick TAP visible again. 0x2CD is the recommended value. Another 10-bit sequence may be used. During KeySequence detection, LSB of the Key sequence should be shifted into TDI first.                 | RW   | 0 (POR) |
| 5:4   | ESERVED        | Reserved, Read return reset value, write reset value for further compatibility                                                                                                                                                                                                                                           | R    | 0       |
| 3:1   | TAPLINKMODE    | See <a href="#">Table 27-21</a> .                                                                                                                                                                                                                                                                                        | RW   | 0 (POR) |
| 0     | ActivateMode   | When a 1 is written to this bit, the currently selected TAPLinkMode is activated. ICEPick will link the TAPs according to these settings when the ICEPick TAP is advanced to Run-Test/Idle with any opcode in the IR.<br>When in key-sequence mode, this bit is automatically cleared when the key sequence is detected. | RW   | 0 (POR) |

**NOTE:** These registers are updated when entering the Update DR state, but the action that results from the update occurs when entering the Run Test/Idle state.

**Table 27-20. DESELECTMODE Values**

| Value | Mode          | Behavior                                                                                                                                              |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00    | Stay-selected | Even though a selected secondary TAP becomes inaccessible, the set of selected TAPs does not change. Scan to any and all modules may not be possible. |
| 01    | Reserved      | Acts like Stay-Selected                                                                                                                               |
| 10    | Reserved      | Acts like Stay-Selected                                                                                                                               |
| 11    | Auto-deselect | When a selected secondary TAP becomes inaccessible due to power constraints, all secondary TAPs are deselected. TDO is forced to HiZ.                 |

**Table 27-21. TAPLINKMODE Values**

| Value | Mode                         | Behavior                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000   | Always-first                 | The ICEPick TAP always exists and is linked as the TAP closest to TDI.                                                                                                                                                                                                                                                                                                                                      |
| 001   | Reserved                     | Reserved (behaves like Always-first)                                                                                                                                                                                                                                                                                                                                                                        |
| 010   | Key-Sequence                 | When this mode is activated, the ICEPick TAP is no longer visible. The selected secondary TAPs are connected between the device TDI and TDO. Although the ICEPick TAP is not visible, it continues to advance state in step with the other selected TAPs. In this sense it is a shadow TAP. When in the Run Test Idle state, a special address can be scanned that will make the ICEPick TAP visible again. |
| 011   | Disappear-forever            | Once activated, the ICEPick TAP is no longer visible between the device TDI and TDO. Only a power-on reset will make the TAP visible again.                                                                                                                                                                                                                                                                 |
| 100   | Reserved                     | Reserved (behaves like Always-first)                                                                                                                                                                                                                                                                                                                                                                        |
| 101   | Reserved                     | Reserved (behaves like Always-first)                                                                                                                                                                                                                                                                                                                                                                        |
| 110   | Key Sequence with Forwarding | This mode operates in the same manner as the KeySequence mode except that any values shifted in during the Run Test Idle state are driven out the device TDO. The device TDO pin is driven during RunTest Idle.                                                                                                                                                                                             |
| 111   | Reserved                     | Reserved (behaves like Always-first)                                                                                                                                                                                                                                                                                                                                                                        |

#### 27.2.4.6.3.1.2 Debug TAP Linking Control Block

The debug TAP linking block contains the control and status registers used in the selection of secondary TAPs into the master scan path. Up to 16 secondary TAPs can be supported. Each TAP has its own debug TAP control and status register.

[Table 27-22](#) shows the registers available in the ICEPick control block and the value of the TAP\_ROUTING\_REG[27:24] bit field used to access them.

**Table 27-22. Debug TAP Linking Control Block Registers**

| Register | Register Name | Description                     |
|----------|---------------|---------------------------------|
| 0x0      | SDTR0         | Secondary debug TAP 0 register  |
| 0x1      | SDTR1         | Secondary debug TAP 1 register  |
| 0x2      | SDTR2         | Secondary debug TAP 2 register  |
| 0x3      | SDTR3         | Secondary debug TAP 3 register  |
| 0x4      | SDTR4         | Secondary debug TAP 4 register  |
| 0x5      | SDTR5         | Secondary debug TAP 5 register  |
| 0x6      | SDTR6         | Secondary debug TAP 6 register  |
| 0x7      | SDTR7         | Secondary debug TAP 7 register  |
| 0x8      | SDTR8         | Secondary debug TAP 8 register  |
| 0x9      | SDTR9         | Secondary debug TAP 9 register  |
| 0xA      | SDTR10        | Secondary debug TAP 10 register |
| 0xB      | SDTR11        | Secondary debug TAP 11 register |
| 0xC      | SDTR12        | Secondary debug TAP 12 register |
| 0xD      | SDTR13        | Secondary debug TAP 13 register |
| 0xE      | SDTR14        | Secondary debug TAP 14 register |
| 0xF      | SDTR15        | Secondary debug TAP 15 register |

**Table 27-23. SDTRj**

|                    |                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Description</b> | There is a separate Secondary Debug TAP Register (SDTR) for each secondary TAP (j = 0 to 15). |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>        | RW                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|             |    |    |    |    |    |    |    |            |          |                   |              |          |                |                      |              |             |           |                 |            |           |                  |            |       |                  |             |       |       |            |            |   |   |
|-------------|----|----|----|----|----|----|----|------------|----------|-------------------|--------------|----------|----------------|----------------------|--------------|-------------|-----------|-----------------|------------|-----------|------------------|------------|-------|------------------|-------------|-------|-------|------------|------------|---|---|
| 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 |
| TAP_ROUTING |    |    |    |    |    |    |    | BLOCKNTRST | RESERVED | POWERLOSSDETECTED | INHIBITSLEEP | TAPPOWER | UNNATURALRESET | INRESETANDRELEASEWIR | RESETCONTROL | DEBUGENABLE | DEBUGMODE | DEBUGANDEXECUTE | VISIBLETAP | SELECTTAP | POWERDOWNDESIRED | FORCEPOWER | POWER | CLOCKDOWNDESIRED | FORCEACTIVE | CLOCK | CLOCK | TAPPRESENT | TAPPRESENT |   |   |

| Bits  | Field Name        | Description                                                                                                                                                                                                                                                                                    | Type | Reset    |
|-------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:24 | TAP_ROUTING       | See <a href="#">Table 27-14</a> .                                                                                                                                                                                                                                                              | RW   | -        |
| 23    | BLOCKNTRST        | When this bit is 0, the nTRST signal for this secondary TAP follows the device level nTRST.<br>When this bit is 1 and the TAP is deselected, the nTRST signal for this secondary TAP is held high.                                                                                             | RW   | 0 (ARST) |
| 22    | RESERVED          | Reserved, read return reset value.                                                                                                                                                                                                                                                             | R    | 0        |
| 21    | POWERLOSSDETECTED | When this bit is 1, the module associated with this TAP has had its power turned off. Once a power loss has been detected, this bit will remain 1 until manually cleared by writing to this bit.<br>Writing a 1 to this bit clears this latched value back to 0.<br>Writing a 0 has no effect. | R    | 0 (ARST) |

## ICEPick Module

www.ti.com

| Bits  | Field Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset    |
|-------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 20    | INHIBITSLEEP         | When 0, this bit does not influence the clock and the power settings to the module.<br>While this bit is 1, if power or clock for TAP's module is not allowed to be turned off once turned on.<br>The value read does not reflect the value written until the power and clock controller has acted upon a change in the written value.                                                                        | RW   | 0 (ARST) |
| 19    | TAPPOWER             | When 0, the module TAP power is off.<br>When 1, the module TAP power is on.                                                                                                                                                                                                                                                                                                                                   | R    | -        |
| 18    | UNNATURALRESET       | When 0, the warm-reset state is consistent with the application controls.<br>When 1, the warm-reset state is not consistent with the application controls due to emulation actions or controls.                                                                                                                                                                                                               | R    | -        |
| 17    | INRESETANDRELEASEWIR | Read 1, the module(s) controlled by the secondary TAP is in the reset state.<br>Read 0, the module(s) is not in reset.<br>When a 1 is written to this bit and the module is held in reset due to the WaitInReset bit, the module reset is released. This only occurs if WaitInReset is 1 and it is the only cause for holding the module in reset.<br>This is a self-clearing bit. Writing a 0 has no effect. | RW   | 0 (ARST) |
| 16:14 | RESETCONTROL         | Override the application controls of the functional warm reset to a module. See <a href="#">Table 27-24</a> .                                                                                                                                                                                                                                                                                                 | RW   | 0 (ARST) |
| 13    | DEBUGENABLE          | When 1, the module(s) associated with this secondary TAP has its debug logic enabled. This is referred to as debug enable or connect on some modules.<br>When 0, the debug logic is allowed to be turned off.                                                                                                                                                                                                 | RW   | 0 (ARST) |
| 12:11 | DEBUGMODE            | Specify the debug mode of the module upon power-on-reset. See <a href="#">Table 27-25</a> .                                                                                                                                                                                                                                                                                                                   | RW   | 0 (ARST) |
| 10    | DEBUGANDEXECUTE      | Read 0, all processors (modules) on this secondary TAP are in execution state.<br>Read 1, one or more processors (modules) on this secondary TAP have entered a state where debugger interaction is required.<br>Writing a 1 enables the module to take action on a preloaded execution command, such as run. This bit may be gated by the GlobalExecuteMask.<br>Writing a 0 has no effect.                   | RW   | 0 (ARST) |
| 9     | VISIBLETAP           | When 1, the TAP is currently selected and visible in the active scan chain.                                                                                                                                                                                                                                                                                                                                   | R    | -        |
| 8     | SELECTTAP            | While 1, the TAP is selected for inclusion in the master scan path.<br>While 0, the TAP is not selected.<br>The effects of changing this bit do not take place until the Run-Test-Idle state is reached.                                                                                                                                                                                                      | RW   | 0 (ARST) |
| 7     | POWERDOWNDESIRED     | When 0, the module's power is not being affected by the emulation controls or actions.<br>When 1, the power would normally be turned off to the module if it were not for emulation controls.                                                                                                                                                                                                                 | R    | -        |
| 6     | FORCEPOWER           | When 0, this bit does not influence the module power state.<br>When 1, the TAP and its module are held in a operational powered state regardless of whether the TAP is selected or not.<br>The value read does not reflect the value written until the power controller has acted upon a change in the written value.                                                                                         | W    | 0        |
| 5     | POWER                | When 0, the module power is off.<br>When 1, the module power is on.                                                                                                                                                                                                                                                                                                                                           | R    | -        |
| 4     | CLOCKDOWNDESIRED     | When 0, the module clock state is not being affected by emulation controls or actions.<br>When 1, the clock would normally be turned off to the module if it were not for emulation controls.                                                                                                                                                                                                                 | R    | -        |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                 | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 3           | FORCEACTIVE       | When 0, this bit does not influence the module's power or clock settings.<br>When 1, the clock for TAP's module is forced on. It is implied that this control will also turn on the power.<br>The value read does not reflect the value written until the power and clock controller has acted upon a change in the written value. | W           | -            |
| 2           | CLOCK             | When 0, the module clock is off (Idle).<br>When 1, the module clock is on.                                                                                                                                                                                                                                                         | R           | -            |
| 1           | TAPACCESSIBLE     | When 0, the TAP cannot be accessed.<br>When 1, the TAP can be accessed.                                                                                                                                                                                                                                                            | R           | -            |
| 0           | TAPPRESENT        | When 0, there is not a TAP assigned to this spot.<br>When 1, this TAP exists in the device.                                                                                                                                                                                                                                        | R           | -            |

**Table 27-24. RESETCONTROL Values**

| <b>Value</b> | <b>Command</b>                 | <b>Description</b>                                                                                                                                     |
|--------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000          | Normal Operation               | Reset operates under the normal control of the application or device controls.                                                                         |
| 001          | Wait-in-reset (extended reset) | The module(s) controlled by this secondary TAP will remain in the reset state once the reset is asserted. This bit alone does not reset the processor. |
| 010          | Block Reset                    | Warm-reset to the module is blocked. At this point, only emulation reset controls will work.                                                           |
| 011          | Block and Assert Reset         | Assert and hold the reset to the module.                                                                                                               |
| 1xx          | Cancel                         | Cancels reset command lockout                                                                                                                          |

**Table 27-25. DEBUGMODE Values**

| <b>Value</b> | <b>Debug Mode</b>   | <b>Description</b>                                                              |
|--------------|---------------------|---------------------------------------------------------------------------------|
| 00           | Default mode        | The processor will use whatever debug mode is its default mode.                 |
| 01           | Monitor mode        | The debug features of the processor will be configured for monitor mode.        |
| 10           | Halt mode           | The debug feature of the processor will be configured for halt or stop mode.    |
| 11           | Real-time halt mode | The debug features of the processor will be configured for real-time halt mode. |

## 27.2.5 ICEPick Basic Programming Model

### 27.2.5.1 Basic Initialization

The following sequence connects the ICEPick to the debugger and configures ICEPick rtck behavior:

1. Connect ICEPick:
  - Select IR scan.
  - Send the CONNECT instruction in IR scan (000111).
  - Select DR scan.
  - Send the following value in DR scan 10001001 (write and connect key).
  - At the update DR, the ICEPick is in connected state.
2. Configure ICEPick:
  - Select IR scan.
  - Send the ROUTER instruction in IR scan (0000010).
  - Select DR scan.
  - Send the following value in DR scan (see [Table 27-18](#)):
    - WRITE (bit 32) = 1
    - BLOCK (bit field [31:28]) = 0x0, block 0 is ICEPick control.
    - REGISTER (bit field [27:24]) = 0x0
    - ADVANCERTCKTIMING (bit 17) must be configured.

- FREERUNNINGEMUL (bit 12) must be configured.
- Configure other bit field if needed.
- At the update DR, the ICEPick is properly configured.

### 27.2.5.2 Adding a TAP in the Debug Chain

The following sequence adds a new TAP in the debug chain:

1. Select IR scan.
2. Send the ROUTER instruction in IR scan (000010).
3. Select DR scan.
4. Send the following value in DR scan (see [Table 27-18](#)) to enable power and clock for the TAP:
  - WRITE (bit 32) = 1
  - BLOCK (bit field [31:28]) = 0x2; bloc 2 is Debug TAP Linking Control.
  - REGISTER (bit field [27:24]) = TAP number, select the TAP to be added to the chain; see [Table 27-2](#) for more information.
  - FORCEACTIVE (bit 3) = 1, enable the TAP power and clock.
  - FORCEPOWER (bit 6) = 1, force the TAP power to ON state regardless of whether the TAP is selected or not.
  - INHIBITSLEEP (bit 20) = 1, force the TAP clock to be active.
5. Read back the value in next DR scan:
  - WRITE (bit 32) = 0
  - BLOCK (bit field [31:28]) = 0x2; block 2 is Debug TAP Linking Control.
  - REGISTER (bit field [27:24]) = TAP number , select the TAP to be added to the chain; see [Table 27-2](#) for more information.
6. Check if the FORCEACTIVE, FORCEPOWER, and INHIBITSLEEP bits are set to 1.
7. Send the following value in DR scan (see [Table 27-18](#)) to enable debug mode:
  - DEBUGENABLE (bit 13) = 1; enable the TAP debug.
  - DEBUGMODE (bit field [12:11]) = MODE; see [Table 27-25](#) for available debug modes.
8. Read back the value in next DR scan:
  - WRITE (bit 32) = 0
  - BLOCK (bit field [31:28]) = 0x2; block 2 is Debug TAP Linking Control.
  - REGISTER (bit field [27:24]) = TAP number , select the TAP to be added to the chain; see [Table 27-2](#) for more information.
9. Check if DEBUGENABLE and DEBUGMODE bit are well set.
10. Send the following value in DR scan (see [Table 27-18](#)) to add the TAP in the chain:
  - SELECTTAP (bit 8) = 1; add the TAP in the chain.
11. Go in Run Test Idle (RTI) so the change takes effect and the TAP is added to the chain (a wait may be needed).

When the TAP is added to the chain, DR and IR are longer (ICEPick length + new TAP).

To write in IR for the new TAP, write BYPASS in ICEPick IR so the next DR is not taken into account and is only 1 bit for ICEPick.

## 27.3 SDTI Module

This section describes the SDTI in the device.

### 27.3.1 SDTI Overview

SDTI is a main component that implements system trace in the device. The SDTI is connected to the L4\_EMU and mapped to the EMU domain. L4\_EMU is accessible by the MPU and the digital signal processor (DSP). Figure 27-8 shows the SDTI in the device.

**Figure 27-8. SDTI in the Device**



The SDTI provides real-time software tracing to device. It generates software messages, which are encoded as defined in the custom protocol.

---

**NOTE:** The custom protocol is not MIPI® compliant.

---

Messages are a way for software to export crucial information and thus provide a high level of visibility on system behavior (task entry, procedures calls, system status, test signatures, and memory allocation); 256 message channels, which can be allocated between software components, are available.

Messages are exported to trace receivers through a serial interface.

SDTI has its own local, dedicated first in first out (FIFO) buffering to allow trace capabilities concurrent to ETM trace captured in ETB.

SDTI implements only trace export from device to remote PC through an emulator box. There is no receive path feature in the SDTI. A standard asynchronous serial port (UART, 8 data bits, 1 stop-bit, no parity) can be used as a back-channel to send emulation related control requests and data back to device.

### 27.3.2 SDTI Environment

The trace interface has four trace data pins and one trace clock, as shown in Table 27-26.

**Table 27-26. SDTI Pins**

| Port     | Width | I/O<br>( <sup>1</sup> ) | Reset Value | Description                  |
|----------|-------|-------------------------|-------------|------------------------------|
| sdти_clk | 1     | O                       | 1           | Trace interface clock output |
| sdти_txd | 4     | O                       | 0000        | Trace interface data         |

<sup>(1)</sup> I = Input; O = Output

---

**NOTE:** 1, 2, and 4-bit serial interface configurations are supported.

---

Serial interface is a dual-edge interface (new sdti\_txd data is available with rising and falling edge of sdti\_clk). Interface can be also configured in single-edge mode where data are available with the falling edge of sdti\_clk. This can be configured in the [SDTI\\_SCONFIG\[4\] SINGLEEDGE](#) bit

Serial interface operates in clock stop regime (the serial clock is not free-running), when there is no trace data there is no trace clock.

### 27.3.2.1 SDTI Pins Configuration Mode

Figure 27-9 through Figure 27-11 show the SDTI connected with an emulator box in four, two, and one data pin configuration, respectively. The number of pins used for transmission can be configured in the [SDTI\\_SCONFIG\[6:5\] TXDSIZE](#) bit field.

**Figure 27-9. SDTI Connected in Four Data Pins Mode**



sdti-002

**Figure 27-10. SDTI Connected in Two Data Pins Mode**



sdti-003

**Figure 27-11. SDTI Connected in One Data Pin Mode**



sdti-004

### 27.3.2.2 SDTI Protocol

The SDTI serial interface is a dual-edge, 4-pin serial interface used to connect the device to trace receivers (for example, XDS560T).

Trace receivers sample trace data on each clock edge. The trace clock (SDTI\_CLK) starts with a falling edge. The sdti\_clk signal is forced high until the first data value is available.

Serial interface operates in clock stop mode; when there is no data available, the clock stops. SDTI\_CLK is not a free-running clock.

To support older trace receivers, serial interface can be placed into single-edge mode where data is captured with the falling edge of the trace clock ([SDTI\\_SCONFIG\[4\] SINGLEEDGE = 1](#)).

[Figure 27-12](#) shows the SDTI dual-edge serial interface waveform.

**Figure 27-12. Dual-Edge Clock Waveform**



[Figure 27-13](#) shows the SDTI single-edge serial interface waveform.

**Figure 27-13. Single-Edge Clock Waveform**



The SDTI serial interface is configurable to support one, two, and four data bits operation. Depending on the configuration, trace data is exported on sdti\_txd[0], sdti\_txd[1:0], or sdti\_txd[3:0].

Serial clock frequency is selected in the SDTI serial configuration register (the [SDTI\\_SCONFIG\[3:0\] SDTISCLKRATE](#) bit field). Programmers must select the correct serial frequency (choose division factor) based on the functional clock frequency.

### 27.3.2.3 SDTI Data Format

[Table 27-27](#) summarizes the message types.

**Table 27-27. SDTI CPU Software Messages**

| Type                     | Identification |
|--------------------------|----------------|
| CPU1 timestamped message | 001D DAtt      |
| CPU1 message             | 010D DA00      |
| CPU2 timestamped message | 011D DAtt      |
| CPU2 message             | 110D DA00      |

**NOTE:**

- DD: Data length
  - 00 = 8-bit data
  - 01 = 16-bit data
  - 10 = 32-bit data
  - 11 = Reserved
- A: Address length
  - 0 = No address
  - 1 = 8-bit address
- tt: Time stamp bits always zero in SDTI

[Table 27-28](#) to [Table 27-31](#) show detailed message structure.

**Table 27-28. CPU1 Timestamped Message**

| Description | Format         |                   |                |
|-------------|----------------|-------------------|----------------|
| Header      | 001D DA00      |                   |                |
| Timestamp   | 0              |                   |                |
| Address     | <b>A = 1</b>   | <b>A = 0</b>      |                |
|             | Ad[7:0]        | Nonexistent field |                |
| Data        | <b>DD = 00</b> | <b>DD = 01</b>    | <b>DD = 10</b> |
|             | Da[7:0]        | Da[15:8]          | Da[31:24]      |
|             |                |                   | Da[23:16]      |
|             |                | Da[7:0]           | Da[15:8]       |
|             |                |                   | Da[7:0]        |

**Table 27-29. CPU1 Message**

| Description | Format         |                   |                |
|-------------|----------------|-------------------|----------------|
| Header      | 010D DA00      |                   |                |
| Address     | <b>A = 1</b>   | <b>A = 0</b>      |                |
|             | Ad[7:0]        | Nonexistent field |                |
| Data        | <b>DD = 00</b> | <b>DD = 01</b>    | <b>DD = 10</b> |
|             | Da[7:0]        | Da[15:8]          | Da[31:24]      |
|             |                |                   | Da[23:16]      |
|             |                | Da[7:0]           | Da[15:8]       |
|             |                |                   | Da[7:0]        |

**Table 27-30. CPU2 Timestamped Message**

| Description | Format         |                   |                |
|-------------|----------------|-------------------|----------------|
| Header      | 011D DA00      |                   |                |
| Timestamp   | 0              |                   |                |
| Address     | <b>A = 1</b>   | <b>A = 0</b>      |                |
|             | Ad[7:0]        | Nonexistent field |                |
| Data        | <b>DD = 00</b> | <b>DD = 01</b>    | <b>DD = 10</b> |
|             | Da[7:0]        | Da[15:8]          | Da[31:24]      |
|             |                |                   | Da[23:16]      |
|             |                | Da[7:0]           | Da[15:8]       |
|             |                |                   | Da[7:0]        |

**Table 27-31. CPU2 Message**

| Description | Format         |                |                   |
|-------------|----------------|----------------|-------------------|
| Header      | 110D DA00      |                |                   |
| Address     | <b>A = 1</b>   | <b>A = 0</b>   |                   |
|             | Ad[7:0]        |                | Nonexistent field |
| Data        | <b>DD = 00</b> | <b>DD = 01</b> | <b>DD = 10</b>    |
|             | Da[7:0]        | Da[15:8]       | Da[31:24]         |
|             |                |                | Da[23:16]         |
|             | Da[7:0]        | Da[15:8]       | Da[7:0]           |
|             |                |                |                   |

### 27.3.3 SDTI Integration

Figure 27-14 shows the internal connections between the SDTI and other modules in the device.

**Figure 27-14. SDTI Integration**

#### 27.3.3.1 Clocking and Reset

##### 27.3.3.1.1 Clocks

The SDTI receives two clocks:

- SDTI\_ICLK: The L4\_EMU clock for the interface and the functional clock for SDTI
- SDTI\_FCLK: The serial interface base clock, which is always twice as fast as SDTI\_ICLK

Trace serial interface (sdti\_clk) runs on a clock generated in SDTI. The serial interface clock is derived from SDTI\_FCLK in programmable clock divider.

Divider factors for serial clock generation are referenced to SDTI\_ICLK. These factors range from 1 to 10. SDTI\_FCLK always has an internal clock that runs twice as fast as the serial clock selected through division factors, which is used as a base clock in dual-edge serial transmitters.

##### 27.3.3.1.2 Reset

The SDTI is reset with hardware POR. All SDTI registers are asynchronously reset. The SDTI remains operational and with its setup preserved when a warm reset is triggered to export the trace history to the trace controller. This trace history may contain key information from a debug perspective for understanding the root cause of the warm reset.

The PRCM module delivers the EMU\_RSTPOWRON reset qualifier and the RESET signal to distinguish power on from a warm (soft) reset.

The application or debugger software can reset the SDTI at any time by writing 1 to the **SDTI\_SYSCONFIG[1]** SOFTRESET bit. This puts the SDTI in the same reset state as a hardware reset.

## 27.3.4 SDTI Functional Description

### 27.3.4.1 SDTI Block Diagram

Figure 27-15 is a block diagram of the SDTI.

Figure 27-15. SDTI Block Diagram



sdti-008

The SDTI is configured through the L4 EMU target interface.

All SDTI registers are 32-bit (double word) aligned. For information about handling non-aligned addresses, supported/not supported byte enables, access to nonexistent memory address, reads to write-only registers, and writes to read-only registers, see [Section 27.3.4.9, SDTI Error Handling](#).

The SDTI is active (enabled) when enabled through claim procedure. For information about the claim procedure, see [Section 27.3.4.2, SDTI Ownership](#). When enabled, SDTI generates messages or test patterns and exports them through the serial interface.

### 27.3.4.2 SDTI Ownership

Some SDTI resources can be owned by the application or by the debugger. Ownership is required to configure or program the SDTI. Ownership determines whether write access is granted to the SDTI configuration registers. SDTI resource ownership is exclusive. Hence, simultaneous use of SDTI resources by both debugger and application is not permitted. However, the debugger can forcibly seize ownership of SDTI resources.

**NOTE:** Read access does not require ownership; therefore, either party can read any SDTI register with or without ownership.

The application and the debugger cannot simultaneously write to the following SDTI resources (also called units):

Window control register (accompanied by the serial configuration register and the test control register)

#### 27.3.4.2.1 Ownership States

Ownership has three basic states:

- Available: The unit has not been claimed.
- Claimed: The unit has been claimed.
- Enabled: The unit is enabled by the owning party.

##### 27.3.4.2.1.1 Available State

The SDTI is set to available state when one of two conditions occurs:

- The state is available when POR is asserted.
- The state is available if the SDTI is owned by the debugger and the emulator is disconnected.

**NOTE:** A warm reset has no effect on the operation of the SDTI. An emulator disconnect has no effect when the application owns the unit.

#### 27.3.4.2.1.2 Claimed State

The SDTI is in claimed state when the debugger or the application claims it. The claimed state provides exclusive access to the owner. The other party is not permitted write access to the unit until the owning party releases the claim. Once a unit has been claimed, only the owner can write to the other resources controlled by the claim.

The debugger, however, is allowed to forcibly seize control of a unit, if already claimed by the application, by setting the [SDTI\\_WINCTRL\[29\]](#) DEBUGGEROVERRIDE bit.

#### 27.3.4.2.1.3 Enabled State

The SDTI enters into enabled state when it is activated. The owner can continue to write to other resources while the SDTI is enabled.

#### 27.3.4.2.2 Ownership Commands

Ownership of SDTI resources is managed through the [SDTI\\_WINCTRL\[31:30\]](#) OWNERSHIP bit field. [Table 27-32](#) lists the ownership commands.

**Table 27-32. Ownership Commands**

| Command | Meaning           | Description                                                                                                                                                                                     |
|---------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00      | Release ownership | Release ownership of SDTI. The release command is accepted only from the owner.                                                                                                                 |
| 01      | Claim ownership   | Claim access to the SDTI. The claim command is successful only if the unit is available or the requester is the debugger and the <a href="#">SDTI_WINCTRL[29]</a> DEBUGGEROVERRIDE bit is high. |
| 10      | Enable unit       | Activate the SDTI for use. The enable command is accepted only from the owner.                                                                                                                  |
| 11      | No operation      | The NOP command does not affect ownership or claim state.                                                                                                                                       |

#### 27.3.4.2.3 Claim Bits

The 4 claim bits are implemented in the [SDTI\\_WINCTRL](#) register, as shown in [Table 27-33](#).

**Table 27-33. Claim Bits**

| Field            | Width | R/W | Reset | Description                                                                                                                                                                                                                                                                                                                                                     |
|------------------|-------|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ownership[1:0]   | 2     | R   | 00    | Read to get current ownership status. The claim status encoding is (0 = available; 1 = claimed; 2 = enabled; 3 = reserved)                                                                                                                                                                                                                                      |
|                  |       |     | W     | Send command to modify ownership state. See <a href="#">Table 27-32</a> . <sup>(1)</sup>                                                                                                                                                                                                                                                                        |
| DebuggerOverride | 1     | R   | 1     | A read from the DEBUGGEROVERRIDE bit returns 1.                                                                                                                                                                                                                                                                                                                 |
|                  |       |     | W     | This qualifier bit is used with the debugger claim request. The DEBUGGEROVERRIDE bit is not registered.<br>When written with DEBUGGEROVERRIDE set to 1, a claim request by the debugger is granted, regardless of the ownership status of the unit.<br>When written with DEBUGGEROVERRIDE set to 0, the claim request is granted only if the unit is available. |
| CurrentOwner     | 1     | R   | 0     | This value reflects the SDTI ownership when the register is in a nonavailable state.<br>0 = Debugger owns resource.<br>1 = Application owns resource.                                                                                                                                                                                                           |

<sup>(1)</sup> A successful command causes these bit values to reflect the new state.

#### 27.3.4.2.4 Claim Resets

When the SDTI is owned by the debugger, the resource is released if the debugger is disconnected.

If the SDTI is owned by the application and the processor enters debug state, the resource continues to belong to the application. The SDTI is not sensitive to debug state.

If the SDTI ownership is released while data are in the SDTI FIFO, the serial interface continues to export data until the FIFO is drained.

#### 27.3.4.3 Trace Data Collection

The messages allow the application software to export, through the serial trace interface, key information that provides high-level visibility on system behavior (task entry, system status, test signature, and memory allocation); 256 message channels are available, starting at 0x5460 0000.

To minimize cycle overhead, the generation of messages is implemented through a dedicated address window. Each write to an address within the window triggers a message.

To facilitate memory management unit (MMU) use for channel enabling and disabling, channel to memory address mapping is organized as follows:

- Each of the 256 channels is allocated 4KB of memory. This corresponds to an MMU page.
- Within 4KB, CPU1 and CPU2 channels are interleaved:
  - 1KB CPU1 message
  - 1KB CPU1 timestamped message
  - 1KB CPU2 message
  - 1KB CPU2 timestamped message
- Each write to addresses within the first KB of channel space triggers a CPU1 message.
- Each write to addresses within the second KB of channel space triggers a CPU1 timestamped message.
- Each write to addresses within third KB of channel space triggers a CPU2 message.
- Each write to addresses within fourth KB of channel space triggers a CPU2 timestamped message.

When there is a write in that range, SDTI hardware decodes the access and stores the address decoded as channel, CPU1/2, and message/ timestamped message, along with the data and access size.

The message header is determined from the accessed address and access type (1, 2, or 4 bytes).

Trace matching for CPU1 and CPU2 message generation can be globally enabled or disabled in the [SDTI\\_WINCTRL](#) register.

Although timestamped messages are supported, the SDTI does not implement time-stamping logic, and all time-stamp-related bit fields in timestamped message are always zeroed.

Timestamped messages can be used as an end message marker. Trace software generates a timestamped message on the same channel with previously exported non-timestamped messages as an end message marker.

There is no MConn-ID supported on L4\_EMU and thus no capability to differentiate accesses from various initiators. Each access to the CPU1 address space generates a CPU1 message/ timestamped message, regardless of the initiator. The same applies for CPU2 message generation.

Debugger accesses are differentiated from other initiators by using the MRegDebug qualifier. If enabled through the [SDTI\\_WINCTRL\[2\]](#) DEBUGGERTRACEEN bit, debugger accesses to the trace matching window generate a CPU1 or CPU2 message, depending only on the address accessed. The external trace receiver cannot differentiate between debugger-initiated and application-initiated trace. Otherwise, debugger writes to the trace matching address window do not generate messages.

Burst writes not supported by L4\_EMU burst from level 3 (L3) are split into single writes in the L3/L4\_EMU bridge (for example, originating from STM instruction), with each of them triggering a separate message.

As a simple compression scheme for serial bandwidth improvement, in case of consecutive writes to the same message channel, the channel address is omitted from a message. For particular message encoding, see [Section 27.3.2.3, SDTI Data Format](#). Because initiators are not differentiated on L4\_EMU compression, the scheme is based only on the address accessed. Consecutive accesses to the same address originating from various initiators activates compression.

The SDTI does not lose messages. If it is necessary, the SDTI stalls its interface until there is enough space in the FIFO to store new messages.

A valid write access to the trace address matching window with an all-zeroes byte-enable pattern do not trigger a message.

The SDTI starts to output serial data as soon as it has at least one captured line in the FIFO.

#### 27.3.4.4 Trace Buffer FIFO

The SDTI FIFO is organized as listed in [Table 27-34](#).

**Table 27-34. FIFO Data Organization**

| Field                                    | Size (Bits) |
|------------------------------------------|-------------|
| Timestamped message (end message marker) | 1           |
| CPU1/CPU2                                | 1           |
| Channel number                           | 8           |
| Data size (in bytes)                     | 2           |
| Data                                     | 32          |

When full, the SDTI FIFO stalls L4\_EMU by not acknowledging the write access. When FIFO room becomes available, the SDTI can capture a new message.

The SDTI FIFO status can be polled by reading the [SDTI\\_SYSSTATUS\[8\]](#) FIFOEMPTY bit. FIFOEMPTY reflects the state of SDTI buffering, including the SDTI FIFO and serial interface shift register. When read as 1, there is no more data in the SDTI to be exported.

Check the SDTI FIFO status before powering down the EMU domain or changing the serial interface configuration.

#### 27.3.4.5 Serial Interface Test Pattern Generation

To support calibration, tuning, and testing, the SDTI includes a test pattern generator, which drives the serial interface when testing mode is selected.

When serial interface test mode is selected and the SDTI is enabled, the SDTI continuously exports test patterns until it is disabled. For the test mode enable procedure, see [Section 27.3.5.2, Serial Interface Test Mode Setup](#).

[Table 27-35](#) lists the different patterns that are supported.

**Table 27-35. Test Pattern Format**

| Pattern Name               | Pattern Example                 |
|----------------------------|---------------------------------|
| Simple A                   | 0x5, 0xA                        |
| Simple F                   | 0x0, 0xF                        |
| Walking ones               | 0x0, 0x1, 0x2, 0x4, 0x8         |
| Ramp (incremental counter) | 0x0, 0x1, 0x2,..., 0xF, 0x0,... |
| Pseudo random (LFSR)       | -                               |

Test patterns are exported in chunks that are sized to the internal serial interface data bus. For example, if the serial interface is configured as 4-wire, test patterns are exported in a multiple of four patterns. For 2-wire interface, patterns are exported in a multiple of 8 patterns; for 1-wire interface, patterns are exported in a multiple of 16 patterns.

#### **27.3.4.5.1 Simple Patterns**

Simple A and F patterns can be used for calibration, observing cross-talk, and ground bounce.

These patterns depend on the interface width selected. [Table 27-36](#) summarizes the patterns generated.

**Table 27-36. Simple Test Pattern**

| Interface Width (Bits) | Pattern A | Pattern F |
|------------------------|-----------|-----------|
| 1                      | 0, 1      | 0, 1      |
| 2                      | 01, 10    | 00, 11    |
| 4                      | 0x5, 0xA  | 0x0, 0xF  |

#### **27.3.4.5.2 Walking Ones**

The walking-ones pattern can be used to verify connectivity and correct bits that are being driven.

This pattern depends on the interface width selected. [Table 27-37](#) lists the patterns generated.

**Table 27-37. Walking Test Pattern**

| Interface Width (Bits) | Pattern                 |
|------------------------|-------------------------|
| 1                      | 0, 1                    |
| 2                      | 00, 01, 10              |
| 4                      | 0x0, 0x1, 0x2, 0x4, 0x8 |

#### **27.3.4.5.3 Ramp Pattern**

The ramp pattern can be used to verify that no data is lost at the trace receiver.

The ramp pattern generator is implemented as a 4-bit up counter.

#### **27.3.4.5.4 Pseudo Random (LFSR) Pattern**

The linear feedback shift register (LFSR) pattern can be used to verify the transporting of SDTI data across the entire software stack without loss of data.

Pseudo random data is obtained from the 16-bit LFSR. The shift register implements the following polynomial:

$$G(x) = x^{16} + x^{15} + x^{13} + x^4 + 1$$

LFSR is initialized with a 0xFFFF each time pattern generation is enabled.

This LFSR can provide a 64-K long unique data sequence of 16-bit data. For the LFSR pattern, the LSBs are output (the lower 4 bits are output in the case of a 4-bit interface). The upper bits keep the pattern unique for 64-K samples.

The first six values of LFSR are:

1. 0xFFFF
2. 0x5FEF
3. 0xBFDE
4. 0xDFAD
5. 0x1F4B
6. 0x3E96

#### 27.3.4.6 CoreSight Integration Mode

As a CoreSight-compliant peripheral, the SDTI provides an integration mode where the interface input ports can be probed and the output ports can be driven. The following CoreSight integration registers are used to set up and use this mode:

- [INT\\_MODE\\_CTRL\\_REG](#)
- [INT\\_OUTPUT\\_REG](#)
- [INT\\_INPUT\\_REG](#)

The [CLAIM\\_TAG\\_SET\\_REG](#) register is included for CoreSight compliance. Normally, the lower 4 bits are used for claiming and releasing debug components. The SDTI, however, implements a more sophisticated claim mechanism. These bits can be used as software semaphores to help manage the debug resources, although the claim-and-enable mechanism of the SDTI resources must still be used. Writing 1 to one of the set bits causes the corresponding bit in the claim tag value word to go high.

The [CLAIM\\_TAG\\_CLEAR\\_REG](#) bits can be used as software semaphores to help manage the debug resources. Writing 1 to one of the CLEAR bits causes the corresponding bit in the claim tag value word to go low. Reading this register returns the value of the claim tag.

#### 27.3.4.7 Serial Interface Clock Generation

The `sdti_clk` is derived from `SDTI_FCLK` with a programmable clock divider controlled by the [SDTI\\_SCONFIG\[3:0\]](#) `SDTISCLKRATE` bit field. [Table 27-38](#) shows the divider for the value of the [SDTI\\_SCONFIG\[3:0\]](#) `SDTISCLKRATE` bit field.

**Table 27-38. `sdti_clk` Divider Value**

| SDTISCLKRATE Value | Division Value |
|--------------------|----------------|
| 0x0                | Division by 1  |
| 0x1                | Division by 1  |
| 0x2                | Division by 2  |
| 0x3                | Division by 3  |
| 0x4                | Division by 4  |
| 0x5                | Division by 5  |
| 0x6                | Division by 6  |
| 0x7                | Division by 7  |
| 0x8                | Division by 8  |
| 0x9                | Division by 9  |
| 0xA                | Division by 10 |
| Others             | Division by 1  |

#### 27.3.4.8 SDTI Memory Mapping

[Table 27-39](#) shows the SDTI memory mapping, and [Table 27-40](#) provides channel address examples.

**Table 27-39. SDTI Memory Mapping**

| Name                                            | Address Offset |           | Address     |             | Size |
|-------------------------------------------------|----------------|-----------|-------------|-------------|------|
|                                                 | Start          | Stop      | Start       | Stop        |      |
| <b>Configuration Space (Base = 0x5450 0000)</b> |                |           |             |             |      |
| Configuration Registers                         | 0x0 0000       | 0x0 002F  | 0x5450 0000 | 0x5450 002F | 48   |
| Reserved                                        | 0x0 0030       | 0x0 0EFF  | 0x5450 0030 | 0x5450 0EFF | 3792 |
| CoreSight Registers                             | 0x0 0F00       | 0x0 OFFF  | 0x5450 0F00 | 0x5450 OFFF | 256  |
| Reserved                                        | 0x0 1000       | 0xF FFFF  | 0x5450 1000 | 0x545F FFFF |      |
| <b>Window Space (Base = 0x5460 0000)</b>        |                |           |             |             |      |
| Channel 0                                       | 0x00 0000      | 0x00 OFFF | 0x5460 0000 | 0x5460 OFFF | 4k   |

**Table 27-39. SDTI Memory Mapping (continued)**

| <b>Name</b>              | <b>Address Offset</b> |             | <b>Address</b> |             | <b>Size</b> |
|--------------------------|-----------------------|-------------|----------------|-------------|-------------|
|                          | <b>Start</b>          | <b>Stop</b> | <b>Start</b>   | <b>Stop</b> |             |
| CPU1 message             | 0x00 0000             | 0x00 03FF   | 0x5460 0000    | 0x5460 03FF | 1k          |
| CPU1 timestamped message | 0x00 0400             | 0x00 07FF   | 0x5460 0400    | 0x5460 07FF | 1k          |
| CPU2 message             | 0x00 0800             | 0x00 0BFF   | 0x5460 0800    | 0x5460 0BFF | 1k          |
| CPU2 timestamped message | 0x00 0C00             | 0x00 0FFF   | 0x5460 0C00    | 0x5460 0FFF | 1k          |
| Channel 1                | 0x00 1000             | 0x00 1FFF   | 0x5460 1000    | 0x5460 1FFF | 4k          |
| Channel 2                | 0x00 2000             | 0x00 2FFF   | 0x5460 2000    | 0x5460 2FFF | 4k          |
| to                       | -                     | -           | -              | -           |             |
| Channel 254              | 0x0F E000             | 0x0F EFFF   | 0x546F E000    | 0x546F EFFF | 4k          |
| Channel 255              | 0x0F F000             | 0x0F FFFF   | 0x546F F000    | 0x546F FFFF | 4k          |
| CPU1 message             | 0x0F F000             | 0x0F F3FF   | 0x546F F000    | 0x546F F3FF | 1k          |
| CPU1 timestamped message | 0x0F F400             | 0x0F F7FF   | 0x546F F400    | 0x546F F7FF | 1k          |
| CPU2 message             | 0x0F F800             | 0x0F FBFF   | 0x546F F800    | 0x546F FBFF | 1k          |
| CPU2 timestamped message | 0x0F FC00             | 0x0F FFFF   | 0x546F FC00    | 0x546F FFFF | 1k          |

**Table 27-40. Channel Access Example**

| <b>Message</b>           | <b>Channel Number</b> | <b>SDTI Address Offset</b> |
|--------------------------|-----------------------|----------------------------|
| CPU1 message             | 0                     | 0x00000 – 0x003FF          |
| CPU1 timestamped message | 0                     | 0x00400 – 0x007FF          |
| CPU1 message             | 26                    | 0x1A000 – 0x1A3FF          |
| CPU1 timestamped message | 134                   | 0x86400 – 0x867FF          |
| CPU2 message             | 0                     | 0x00800 – 0x00BFF          |
| CPU2 timestamped message | 0                     | 0x00C00 – 0x00FFF          |
| CPU2 message             | 51                    | 0x33800 – 0x33BFF          |
| CPU2 timestamped message | 255                   | 0xFFC00 – 0xFFFFF          |

#### 27.3.4.9 SDTI Error Handling

The SDTI port returns the in-band error as a response in the following cases:

- Unsupported master command
- Unsupported byte enable
- Unaligned address
- Application write access to locked SDTI registers

Read and write accesses pointing to memory holes are considered as software errors, not interconnect errors. Such accesses get a valid response, do not affect the module behavior, and are not reported. In case of a read command, the returned data is zeroes.

A read from the trace matching address window is also considered a software error and returns a valid response with don't care data (all zeroes).

A write access to the trace matching window with CPU1 or CPU2 message generation disabled returns a valid response.

Read accesses are not affected by the state of the lock access register.

Debugger write accesses are never locked (affected by the state of the [LOCK\\_ACCESS\\_REG](#) register).

## 27.3.5 SDTI Basic Programming Model

### 27.3.5.1 Trace Setup

To enable trace, perform the following steps:

1. If setup is performed through application software, enable write access to the SDTI by writing unlock key to the lock access register ([LOCK\\_ACCESS\\_REG](#)).
2. Claim the SDTI through the ownership procedure.
3. Configure the serial interface.
4. Configure [SDTI\\_WINCTRL](#) to enable message generation.
5. Enable the SDTI through the ownership procedure.

Interface configuration (data width, serial clock selection, dual-/single-edge of operation) must be considered as static and are not to be changed on the fly. The serial interface must be properly configured before enabling trace capture and the interface configuration must not be changed while data are in the SDTI FIFO.

If the address window is disabled (CPU1 and CPU2 message generation is disabled in the [SDTI\\_WINCTRL](#) register while data are in the SDTI FIFO), the serial interface continues to export data until the FIFO is drained.

Write access to the disabled address window has no effect.

If SDTI ownership is released while data are in the SDTI FIFO, the serial interface continues to export data until the FIFO is drained.

If released (in AVAILABLE ownership state), the SDTI does not generate new messages.

If one trace session ends and a new session starts without a change in the interface configuration, the programming model is:

1. Disable trace.
2. Wait until SDTI FIFO is drained.
3. Enable trace and thus start a new session.

This ensures that the first message in the new session is always exported with the address field.

In case of a short disable/enable sequence (when trace is re-enabled while data from a previous session are still in the SDTI FIFO), session breaks are filtered out (disregarded). From an address compression standpoint, when compression is on, the message address field in the new session depends on the previous trace session.

Functional or message generation mode has priority over serial interface test mode (if message generation and test mode are enabled, the SDTI is in functional mode).

### 27.3.5.2 Serial Interface Test Mode Setup

To enable serial interface test mode, perform the following steps:

1. If setup is performed through application software, enable write access to the SDTI by writing unlock key to the lock access register ([LOCK\\_ACCESS\\_REG](#)).
2. Claim the SDTI through the ownership procedure.
3. Configure the serial interface.
4. Configure [SDTI\\_WINCTRL](#) to disable message generation.
5. Configure [SDTI\\_TESTCTRL](#) to select test pattern and test pattern generation mode.
6. Enable the SDTI through the ownership procedure.

The SDTI continues to export test patterns until one of the following occurs:

- Serial test mode is disabled.
- Message generation is enabled.
- The SDTI is released.

**CAUTION**

Serial interface test mode must be entered only when trace is not enabled and the SDTI FIFO is empty. Switching to serial interface test mode while trace is active leads to unpredictable results.

### 27.3.5.3 CoreSight Integration Mode Setup

To enable the serial CoreSight integration mode, perform the following steps:

1. If setup is performed through application software, enable write access to the SDTI by writing unlock key to the lock access register ([LOCK\\_ACCESS\\_REG](#))
2. Switch to integration mode by setting the [INT\\_MODE\\_CTRL\\_REG\[0\]](#) ITM bit to 1.
3. The SDTI remains in Integration mode until [INT\\_MODE\\_CTRL\\_REG\[0\]](#) ITM is cleared to 0.

**CAUTION**

Integration mode must be entered only when trace is not enabled and the SDTI FIFO is empty. Switching to integration mode while trace is active leads to unpredictable results.

### 27.3.5.4 SDTI Register Ownership

[Table 27-41](#) lists all the SDTI registers with their ownership and description.

**Table 27-41. SDTI Register Ownership**

| Address Offset                        | Mnemonic                              | Description                        | R/W | Ownership                                      |
|---------------------------------------|---------------------------------------|------------------------------------|-----|------------------------------------------------|
| 0x000                                 | <a href="#">SDTI_REVISION</a>         | SDTI identification register       | R   | No ownership                                   |
| 0x010                                 | <a href="#">SDTI_SYSCONFIG</a>        | SDTI system configuration register | R/W | No ownership                                   |
| 0x014                                 | <a href="#">SDTI_SYSSTATUS</a>        | SDTI system status register        | R   | No ownership                                   |
| 0x024                                 | <a href="#">SDTI_WINCTRL</a>          | SDTI window control register       | R/W | Has to be claimed                              |
| 0x028                                 | <a href="#">SDTI_SCONFIG</a>          | SDTI serial configuration register | R/W | Same owner as for <a href="#">SDTI_WINCTRL</a> |
| 0x02C                                 | <a href="#">SDTI_TESTCTRL</a>         | SDTI test control register         | R/W | Same owner as for <a href="#">SDTI_WINCTRL</a> |
| <b>CoreSight Management Registers</b> |                                       |                                    |     |                                                |
| 0xF00                                 | <a href="#">INT_MODE_CTRL_REG</a>     | Integration mode control register  | R/W | No ownership                                   |
| 0xF04                                 | <a href="#">INT_OUTPUT_REG</a>        | Integration output register        | R/W | No ownership                                   |
| 0xF08                                 | <a href="#">INT_INPUT_REG</a>         | Integration input register         | R/W | No ownership                                   |
| 0xFA0                                 | <a href="#">CLAIM_TAG_SET_REG</a>     | Claim tag set register             | R/W | No ownership                                   |
| 0xFA4                                 | <a href="#">CLAIM_TAG_CLEAR_REG</a>   | Claim tag clear register           | R/W | No ownership                                   |
| 0xFB0                                 | <a href="#">LOCK_ACCESS_REG</a>       | Lock access register               | W   | No ownership                                   |
| 0xFB4                                 | <a href="#">LOCK_STATUS_REG</a>       | Lock status register               | R   | No ownership                                   |
| 0xFB8                                 | <a href="#">AUTHENTICATION_STATUS</a> | Authentication status register     | R   | No ownership                                   |
| 0xFC8                                 | <a href="#">DEVICE_ID</a>             | Device ID                          | R   | No ownership                                   |
| 0xFCC                                 | <a href="#">DEVICE_TYPE_REG</a>       | Device type identifier register    | R   | No ownership                                   |
| 0xFD0                                 | <a href="#">PERIPHERAL_ID4</a>        | Peripheral ID4                     | R   | No ownership                                   |
| 0xFD4                                 | <a href="#">PERIPHERAL_ID5</a>        | Peripheral ID5                     | R   | No ownership                                   |
| 0xFD8                                 | <a href="#">PERIPHERAL_ID6</a>        | Peripheral ID6                     | R   | No ownership                                   |
| 0xFDC                                 | <a href="#">PERIPHERAL_ID7</a>        | Peripheral ID7                     | R   | No ownership                                   |
| 0xFE0                                 | <a href="#">PERIPHERAL_ID0</a>        | Peripheral ID0                     | R   | No ownership                                   |
| 0xFE4                                 | <a href="#">PERIPHERAL_ID1</a>        | Peripheral ID1                     | R   | No ownership                                   |

**Table 27-41. SDTI Register Ownership (continued)**

| Address Offset | Mnemonic       | Description    | R/W | Ownership    |
|----------------|----------------|----------------|-----|--------------|
| 0xFE8          | PERIPHERAL_ID2 | Peripheral ID2 | R   | No ownership |
| 0xFEC          | PERIPHERAL_ID3 | Peripheral ID3 | R   | No ownership |
| 0xFF0          | COMPONENT_ID0  | Component ID0  | R   | No ownership |
| 0xFF4          | COMPONENT_ID1  | Component ID1  | R   | No ownership |
| 0xFF8          | COMPONENT_ID2  | Component ID2  | R   | No ownership |
| 0xFFC          | COMPONENT_ID3  | Component ID3  | R   | No ownership |

### 27.3.6 SDTI Register Manual

**Table 27-42. SDTI Instance Summary**

| Module Name | Base Address | Size |
|-------------|--------------|------|
| SDTI        | 0x5450 0000  | 4KB  |

#### 27.3.6.1 SDTI Register Summary

**Table 27-43. SDTI Register Summary**

| Register Name         | Type | Register Width (Bits) | Address Offset | SDTI L3 Base Address |
|-----------------------|------|-----------------------|----------------|----------------------|
| SDTI_REVISION         | R    | 32                    | 0x0000 0000    | 0x5450 0000          |
| SDTI_SYSCONFIG        | RW   | 32                    | 0x0000 0010    | 0x5450 0010          |
| SDTI_SYSSTATUS        | R    | 32                    | 0x0000 0014    | 0x5450 0014          |
| SDTI_WINCTRL          | RW   | 32                    | 0x0000 0024    | 0x5450 0024          |
| SDTI_SCONFIG          | RW   | 32                    | 0x0000 0028    | 0x5450 0028          |
| SDTI_TESTCTRL         | RW   | 32                    | 0x0000 002C    | 0x5450 002C          |
| INT_MODE_CTRL_REG     | RW   | 32                    | 0x0000 0F00    | 0x5450 0F00          |
| INT_OUTPUT_REG        | RW   | 32                    | 0x0000 0F04    | 0x5450 0F04          |
| INT_INPUT_REG         | RW   | 32                    | 0x0000 0F08    | 0x5450 0F08          |
| CLAIM_TAG_SET_REG     | RW   | 32                    | 0x0000 0FA0    | 0x5450 0FA0          |
| CLAIM_TAG_CLEAR_REG   | RW   | 32                    | 0x0000 0FA4    | 0x5450 0FA4          |
| LOCK_ACCESS_REG       | W    | 32                    | 0x0000 0FB0    | 0x5450 0FB0          |
| LOCK_STATUS_REG       | R    | 32                    | 0x0000 0FB4    | 0x5450 0FB4          |
| AUTHENTICATION_STATUS | R    | 32                    | 0x0000 0FB8    | 0x5450 0FB8          |
| DEVICE_ID             | R    | 32                    | 0x0000 0FC8    | 0x5450 0FC8          |
| DEVICE_TYPE_REG       | R    | 32                    | 0x0000 0FCC    | 0x5450 0FCC          |
| PERIPHERAL_ID4        | R    | 32                    | 0x0000 0FD0    | 0x5450 0FD0          |
| PERIPHERAL_ID5        | RW   | 32                    | 0x0000 0FD4    | 0x5450 0FD4          |
| PERIPHERAL_ID6        | R    | 32                    | 0x0000 0FD8    | 0x5450 0FD8          |
| PERIPHERAL_ID7        | R    | 32                    | 0x0000 0FDC    | 0x5450 0FDC          |
| PERIPHERAL_ID0        | R    | 32                    | 0x0000 0FE0    | 0x5450 0FE0          |
| PERIPHERAL_ID1        | R    | 32                    | 0x0000 0FE4    | 0x5450 0FE4          |
| PERIPHERAL_ID2        | R    | 32                    | 0x0000 0FE8    | 0x5450 0FE8          |
| PERIPHERAL_ID3        | R    | 32                    | 0x0000 0FEC    | 0x5450 0FEC          |
| COMPONENT_ID0         | R    | 32                    | 0x0000 OFF0    | 0x5450 OFF0          |
| COMPONENT_ID1         | R    | 32                    | 0x0000 OFF4    | 0x5450 OFF4          |
| COMPONENT_ID2         | R    | 32                    | 0x0000 OFF8    | 0x5450 OFF8          |
| COMPONENT_ID3         | R    | 32                    | 0x0000 OFFC    | 0x5450 OFFC          |

### 27.3.6.2 SDTI Register Description

**Table 27-44. SDTI\_REVISION**

|                         |                                 |                 |      |
|-------------------------|---------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0000                     | <b>Instance</b> | SDTI |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a> |                 |      |
| <b>Description</b>      | SDTI Identification Register    |                 |      |
| <b>Type</b>             | R                               |                 |      |

|                         |                         |                       |                 |           |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|-----------|--|--|--|
| 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 |           |  |  |  |
| RESERVED                |                         | SDTI_REV1             |                 | SDTI_REV0 |  |  |  |

| Bits | Field Name | Description                                                                                       | Type | Reset              |
|------|------------|---------------------------------------------------------------------------------------------------|------|--------------------|
| 31:8 | RESERVED   | Reserved for future use.                                                                          | R    | 0x0000000          |
| 7:4  | SDTI_REV1  | High Part of Revision Number of current SDTI module fixed by hardware: it indicates major change. | R    | See <sup>(1)</sup> |
| 3:0  | SDTI_REV0  | Low Part of Revision Number of current SDTI module fixed by hardware: it indicates minor change.  | R    | See <sup>(1)</sup> |

<sup>(1)</sup> TI internal data

**Table 27-45. Register Call Summary for Register SDTI\_REVISION**

SDTI Basic Programming Model

- [SDTI Register List Ownership: \[0\]](#)

SDTI Register Manual

- [SDTI Register Summary: \[1\]](#)

**Table 27-46. SDTI\_SYSCONFIG**

|                         |                                                                                                                                                                                                                                                                                       |                 |      |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0010                                                                                                                                                                                                                                                                           | <b>Instance</b> | SDTI |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                                                                                                                                                                                                       |                 |      |
| <b>Description</b>      | This register allows controlling various parameters of the OCP interface.<br>Software reset have the same effect as hardware (power on) reset.<br>This register is excluded from erroneous application access lock protection in order to allow standard soft reset OCP write access. |                 |      |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                    |                 |      |

|                         |                         |                       |                 |          |  |  |  |
|-------------------------|-------------------------|-----------------------|-----------------|----------|--|--|--|
| 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 |          |  |  |  |
| RESERVED                |                         | SOFTRESET             |                 | AUTOIDLE |  |  |  |

| Bits | Field Name | Description                                                                                                                                 | Type | Reset       |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:2 | RESERVED   | Reserved for future - read returns 0                                                                                                        | R    | 0x0000 0000 |
| 1    | SOFTRESET  | Read returns 0 / Write 1 to trigger SDTI module reset.                                                                                      | RW   | 0           |
| 0    | AUTOIDLE   | Internal OCP gating strategy<br>OCP clock is free-running<br>Automatic OCP clock gating strategy is applied based on OCP interface activity | RW   | 0           |

**Table 27-47. Register Call Summary for Register SDTI\_SYSCONFIG**

## SDTI Integration

- [Reset: \[0\]](#)

## SDTI Basic Programming Model

- [SDTI Register List Ownership: \[1\]](#)

## SDTI Register Manual

- [SDTI Register Summary: \[2\]](#)
- [SDTI Register Description: \[3\]](#)

**Table 27-48. SDTI\_SYSSTATUS**

|                         |                                                                                                         |                 |      |
|-------------------------|---------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0014                                                                                             | <b>Instance</b> | SDTI |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                         |                 |      |
| <b>Description</b>      | This register provides status information about the module, excluding the interrupt status information. |                 |      |
| <b>Type</b>             | R                                                                                                       |                 |      |



| Bits | Field Name | Description                                                                                                        | Type | Reset    |
|------|------------|--------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:9 | RESERVED   | RFU for module specific status information                                                                         | R    | 0x000000 |
| 8    | FIFOEMPTY  | SDTI FIFO not Empty (something to export)<br>SDTI FIFO Empty<br>Write access has no effect.                        | R    | 1        |
| 7:1  | RESERVED   | RFU for OCP socket status information.<br>Read 0x0: Internal module reset in on-going<br>Read 0x1: Reset completed | R    | 0x00     |
| 0    | RESETDONE  | Internal Module reset monitoring<br>Internal reset is on-going<br>Reset completed                                  | R    | 1        |

**Table 27-49. Register Call Summary for Register SDTI\_SYSSTATUS**

## SDTI Functional Description

- [Trace Buffer FIFO: \[0\]](#)

## SDTI Basic Programming Model

- [SDTI Register List Ownership: \[1\]](#)

## SDTI Register Manual

- [SDTI Register Summary: \[2\]](#)

**Table 27-50. SDTI\_WINCTRL**

|                         |                                 |                       |                 |
|-------------------------|---------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0024                     |                       |                 |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a> | <b>Instance</b>       | SDTI            |
| <b>Description</b>      | Window control register.        |                       |                 |
| <b>Type</b>             | RW                              |                       |                 |
| 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 |
| OWNERSHIP               | DEBUGGEROVERRIDE                | CURRENTOWNER          | RESERVED        |
|                         |                                 |                       | DEBUGGERTRACEEN |
|                         |                                 |                       | CPU2TRACEEN     |
|                         |                                 |                       | CPU1TRACEEN     |

| Bits  | Field Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset      |
|-------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|
| 31:30 | OWNERSHIP         | <p>Read to get current ownership status. The claim status encoding is (0=Available, 1=Claimed, 2=Enabled, 3=Reserved)</p> <p>Send command to modify ownership state. See Table 13</p> <p>Note:</p> <ul style="list-style-type: none"> <li>(1) A successful command would cause these bit values to reflect the new state.</li> </ul>                                                                                                          | RW   | 0x0        |
| 29    | DEBUGGER OVERRIDE | <p>Reading from the DebuggerOverride bit returns a 1</p> <p>This qualifier bit is used with the debugger's CLAIM request. The DebuggerOverride bit shall not be latched.</p> <p>When written with DebuggerOverride=1, a claim request by the debugger shall be granted regardless of current ownership status of the unit.</p> <p>When written with DebuggerOverride=0, the claim request shall be granted only if the unit is available.</p> | RW   | 0          |
| 28    | CURRENTOWNER      | <p>This value reflects the SDTI ownership when the register is in a non-Available state.</p> <p>0=Debugger owns resource.<br/>1=Application owns resource</p>                                                                                                                                                                                                                                                                                 | RW   | 0          |
| 27:3  | RESERVED          | RFU                                                                                                                                                                                                                                                                                                                                                                                                                                           | R    | 0x00000000 |
| 2     | DEBUGGERTRACEEN   | <p>0 Debugger writes to address matching window doesn't generate messages./</p> <p>1 Debugger writes to address matching window will generate messages</p>                                                                                                                                                                                                                                                                                    | RW   | 0          |
| 1     | CPU2TRACEEN       | 0 Window disabled, no message generation/ 1 Window enabled                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0          |
| 0     | CPU1TRACEEN       | 0 Window disabled, no message generation/ 1 Window enabled                                                                                                                                                                                                                                                                                                                                                                                    | RW   | 0          |

**Table 27-51. Register Call Summary for Register SDTI\_WINCTRL**

- **SDTI Functional Description**
  - **Claimed State:** [0]
  - **Ownership commands:** [1] [2]
  - **Claim Bits:** [3]
  - **Trace data collection:** [4] [5]

- Trace setup: [6] [7]
  - Serial interface test mode setup: [8]
  - SDTI Register List Ownership: [9] [10] [11]

- SDTI Register Manual

**Table 27-52. SDTI\_SCONFIG**

|                         |                                     |                       |                 |
|-------------------------|-------------------------------------|-----------------------|-----------------|
| <b>Address Offset</b>   | 0x0000 0028                         | <b>Instance</b>       | SDTI            |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>     |                       |                 |
| <b>Description</b>      | SDTI Serial configuration register. |                       |                 |
| <b>Type</b>             | RW                                  |                       |                 |
| 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 |
|                         |                                     |                       |                 |
|                         | RESERVED                            |                       |                 |
|                         |                                     |                       |                 |
|                         |                                     | TXDSIZE               | SINGLEEDGE      |
|                         |                                     |                       | SDTISCLKRATE    |

  

| Bits | Field Name   | Description                                                                                                                                                                                                                                                              | Type | Reset     |
|------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:7 | RESERVED     | RFU                                                                                                                                                                                                                                                                      | RW   | 0x0000000 |
| 6:5  | TXDSIZE      | 00 1 bit TXD size/<br>01 2-bit TXD size/<br>10 4-bit TXD size/<br>11 Reserved. (if set, interface will behave as 4-bit size)                                                                                                                                             | RW   | 0x2       |
| 4    | SINGLEEDGE   | 0 Dual -edge operation mode/<br>1 Single - edge operation mode                                                                                                                                                                                                           | RW   | 0         |
| 3:0  | SDTISCLKRATE | 0x0: Division by 1<br>0x1: Division by 1<br>0x2: Division by 2<br>0x3: Division by 3<br>0x4: Division by 4<br>0x5: Division by 5<br>0x6: Division by 6<br>0x7: Division by 7<br>0x8: Division by 8<br>0x9: Division by 9<br>0xA: Division by 10<br>Others: Division by 1 | RW   | 0x1       |

**Table 27-53. Register Call Summary for Register SDTI\_SCONFIG**

## SDTI Environment

- [SDTI Environment: \[0\]](#)
- [SDTI Pins Configuration Mode: \[1\]](#)
- [SDTI Protocol: \[2\] \[3\]](#)

## SDTI Functional Description

- [Serial Interface Clock Generation: \[4\] \[5\]](#)

## SDTI Basic Programming Model

- [SDTI Register List Ownership: \[6\]](#)

## SDTI Register Manual

- [SDTI Register Summary: \[7\]](#)

**Table 27-54. SDTI\_TESTCTRL**

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                                                                                         | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| 31:4        | RESERVED          | RFU                                                                                                                                        | R           | 0x00000000   |
| 3           | SIMPLEPATSEL      | 0 - simple pattern A<br>1 - simple pattern F                                                                                               | RW          | 0            |
| 2:1         | TESTPATTERNSEL    | 00 - Simple pattern<br>01 - Walking ones pattern<br>10 - Ramp generation (incremental counter)<br>11 - Pseudo random                       | RW          | 0x0          |
| 0           | TESTMODE          | 0 - SDTI serial interface exports trace messages (functional mode)<br>1 - SDTI serial interface exports selected test patterns (test mode) | RW          | 0            |

**Table 27-55. Register Call Summary for Register SDTI\_TESTCTRL**

- Serial interface test mode setup: [0]
  - SDTI Register List Ownership: [1]

- ## SDTI Register Manual

  - SDTI Register Summary: [2]

**Table 27-56. INT\_MODE\_CTRL\_REG**

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                   | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|----------------------------------------------------------------------|-------------|--------------|
| 31:1        | RESERVED          | RFU                                                                  | R           | 0x0000 0000  |
| 0           | ITM               | Functional Mode<br>When ITM=1, the SDTI is in Integration Test Mode. | RW          | 0            |

**Table 27-57. Register Call Summary for Register INT\_MODE\_CTRL\_REG**

## SDTI Functional Description

- CoreSight Integration Mode: [0]

## SDTI Basic Programming Model

- CoreSight Integration Mode Setup: [1] [2]
- SDTI Register List Ownership: [3]

## SDTI Register Manual

- SDTI Register Summary: [4]

**Table 27-58. INT\_OUTPUT\_REG**

|                         |                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|------|--|--|--|--|--|--|--|
| <b>Address Offset</b>   | 0x0000 0F04                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Instance</b> | SDTI |  |  |  |  |  |  |  |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |                 | SDTI |  |  |  |  |  |  |  |
| <b>Description</b>      | This register allows the software to set any one of the output terminal to a high when the ITM signal is high. This register can be used to establish integration connectivity and topology. Refer to the Appendix, 7.1 SDTI Entity Table 17 to determine the OutBit Select number for each terminal. |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |      |  |  |  |  |  |  |  |

  

|                         |                         |                       |                 |
|-------------------------|-------------------------|-----------------------|-----------------|
| 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 |
| RESERVED                | NUMOUTPUTS              | RESERVED INTEGEN      | OUTBITSELECT    |

| Bits  | Field Name   | Description                                                               | Type | Reset |
|-------|--------------|---------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED     | RFU                                                                       | R    | 0x0   |
| 27:16 | NUMOUTPUTS   | This field shall indicate the number of output terminals on the component | R    | 0x005 |
| 15:13 | RESERVED     | RFU                                                                       | R    | 0x0   |
| 12    | INTEGEN      | When IntegEn=1, the integration output is set to 1                        | RW   | 1     |
| 11:0  | OUTBITSELECT | This field shall selects the output bit to set high                       | RW   | 0x000 |

**Table 27-59. Register Call Summary for Register INT\_OUTPUT\_REG**

## SDTI Functional Description

- CoreSight Integration Mode: [0]

## SDTI Basic Programming Model

- SDTI Register List Ownership: [1]

## SDTI Register Manual

- SDTI Register Summary: [2]

**Table 27-60. INT\_INPUT\_REG**

|                         |                                                                                                                                                                                                                                                                                         |                 |      |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0F08                                                                                                                                                                                                                                                                             | <b>Instance</b> | SDTI |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                                                                                                                                                                                                         | <b>Instance</b> | SDTI |
| <b>Description</b>      | This register allows the software to read any of the input terminals when the ITM signal is high. This register can be used to establish integration connectivity and topology. Refer to the Appendix, 7.1 SDTI Entity Table 17 to determine the InBit Select number for each terminal. |                 |      |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                      |                 |      |



| Bits  | Field Name  | Description                                                              | Type | Reset |
|-------|-------------|--------------------------------------------------------------------------|------|-------|
| 31:28 | RESERVED    | RFU                                                                      | R    | 0x0   |
| 27:16 | NUMINPUTS   | This field shall indicate the number of input terminals on the component | R    | 0x002 |
| 15:13 | RESERVED    | RFU                                                                      | R    | 0x0   |
| 12    | VALUE       | This field shall select the input bit to read                            | R    | 0     |
| 11:0  | INBITSELECT | This field shall select the input bit to read                            | RW   | 0x000 |

**Table 27-61. Register Call Summary for Register INT\_INPUT\_REG**

SDTI Functional Description

- [CoreSight Integration Mode: \[0\]](#)

SDTI Basic Programming Model

- [SDTI Register List Ownership: \[1\]](#)

SDTI Register Manual

- [SDTI Register Summary: \[2\]](#)

**Table 27-62. CLAIM\_TAG\_SET\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                 |      |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0FA0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>Instance</b> | SDTI |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <b>Instance</b> | SDTI |
| <b>Description</b>      | The Claim Tag Set register is included for CoreSight compliance. Normally the lower 4 bits are used for claiming and releasing debug components, but SDTI implements a more sophisticated Claim mechanism. These bits can be used for software semaphores to help manage the debug resources, although the claim and enable mechanism of the SDTI resources must still be used. Writing a 1 to one of the set bits will cause the corresponding bit in the Claim Tag Value word to go high. |                 |      |
| <b>Type</b>             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                 |      |



| Bits | Field Name       | Description                                                                                                                                                                     | Type | Reset       |
|------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED         | RFU                                                                                                                                                                             | R    | 0x0000 0000 |
| 0    | CLAIMTAGSIZE_SET | When read, this field shall indicates the modules supports a 1-bit claim tag<br>Writing a 1 shall: sets the specified Claim Tag Value bit.<br>Writing a 0 shall have no effect. | RW   | 1           |

**Table 27-63. Register Call Summary for Register CLAIM\_TAG\_SET\_REG**

SDTI Functional Description

- CoreSight Integration Mode: [0]

SDTI Basic Programming Model

- SDTI Register List Ownership: [1]

SDTI Register Manual

- SDTI Register Summary: [2]

**Table 27-64. CLAIM\_TAG\_CLEAR\_REG**

|                  |                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |  |  |  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|------|--|--|--|--|--|--|--|
| Address Offset   | 0x0000 0FA4                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |  |  |  |  |  |  |  |
| Physical Address | See Table 27-43                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | SDTI |  |  |  |  |  |  |  |
| Description      | These bits can be used for software semaphores to help manage the debug resources. Writing a 1 to one of the clear bits will cause the corresponding bit in the Claim Tag Value word to go low. Reading this register returns the Claim Tag Value |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |  |  |  |  |  |  |  |
| Type             | RW                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |  |  |  |  |  |  |  |

RESERVED

CLAIMTAGVALUE\_CLEAR

| Bits | Field Name          | Description                                                                                                                                                  | Type | Reset       |
|------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|
| 31:1 | RESERVED            |                                                                                                                                                              | R    | 0x0000 0000 |
| 0    | CLAIMTAGVALUE_CLEAR | Reading from this field shall return the Claim Tag Value<br>Writing a 1 shall: clear the specified Claim Tag Value bit.<br>Writing a 0 shall have no effect. | RW   | 0           |

**Table 27-65. Register Call Summary for Register CLAIM\_TAG\_CLEAR\_REG**

SDTI Functional Description

- CoreSight Integration Mode: [0]

SDTI Basic Programming Model

- SDTI Register List Ownership: [1]

SDTI Register Manual

- SDTI Register Summary: [2]

**Table 27-66. LOCK\_ACCESS\_REG**

|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                 |      |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0FB0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <b>Instance</b> | SDTI |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <b>Instance</b> | SDTI |
| <b>Description</b>      | <p>Note</p> <p>This 32-bit write only register is used to lockout errant accesses by application software. When written with a value of 0xC5ACCE55, application writes to the other registers within SDTI are enabled. Any other value shall inhibit application writes (write to Lock Access Register is always enabled). Inhibited application writes shall return an error response. Debugger accesses (PIMREQDEBUG = 1) are not affected by the Lock Access Register. This register is reset to zero (locked) when POR occurs.</p> <p><a href="#">SDTI_SYSCONFIG</a> register is excluded from lock access scheme.</p> |                 |      |
| <b>Type</b>             | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                 |      |

|                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| LOCK_UNLOCK_KEY |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name      | Description            | Type | Reset       |
|------|-----------------|------------------------|------|-------------|
| 31:0 | LOCK_UNLOCK_KEY | Unlock Key: 0xC5ACCE55 | W    | 0x0000 0000 |

**Table 27-67. Register Call Summary for Register LOCK\_ACCESS\_REG**

## SDTI Functional Description

- [SDTI Error Handling: \[0\]](#)

## SDTI Basic Programming Model

- [Trace setup: \[1\]](#)
- [Serial interface test mode setup: \[2\]](#)
- [CoreSight Integration Mode Setup: \[3\]](#)
- [SDTI Register List Ownership: \[4\]](#)

## SDTI Register Manual

- [SDTI Register Summary: \[5\]](#)

**Table 27-68. LOCK\_STATUS\_REG**

|                         |                                                                                                      |                 |      |
|-------------------------|------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0FB4                                                                                          | <b>Instance</b> | SDTI |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                      | <b>Instance</b> | SDTI |
| <b>Description</b>      | Lock status register - registers provide a mechanism for blocking write access to the SDTI registers |                 |      |
| <b>Type</b>             | R                                                                                                    |                 |      |

|                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 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 |
| RESERVED                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| EIGTBITLOCK      LOCKSTATUS      LOCKIMPLEMENTED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bits | Field Name      | Description                                                                             | Type | Reset       |
|------|-----------------|-----------------------------------------------------------------------------------------|------|-------------|
| 31:3 | RESERVED        | RFU                                                                                     | R    | 0x0000 0000 |
| 2    | EIGTBITLOCK     | 0 indicates a 32-bit Lock Access Register<br>1 indicates an 8-bit Lock Access Register. | R    | 0           |
| 1    | LOCKSTATUS      | 0 indicates unlocked condition<br>1 indicates a locked condition.                       | R    | 1           |
| 0    | LOCKIMPLEMENTED | 0 shall indicate no lock exists.<br>1 indicates a locking mechanism exists,             | R    | 1           |

**Table 27-69. Register Call Summary for Register LOCK\_STATUS\_REG**

SDTI Basic Programming Model

- SDTI Register List Ownership: [0]

SDTI Register Manual

- SDTI Register Summary: [1]

**Table 27-70. AUTHENTICATION\_STATUS**

|                         |                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                |                 |                             |    |                                   |    |                                |   |   |   |   |   |   |   |   |   |
|-------------------------|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------|-----------------|-----------------------------|----|-----------------------------------|----|--------------------------------|---|---|---|---|---|---|---|---|---|
| <b>Address Offset</b>   | 0x0000 0FB8                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                | <b>Instance</b> | SDTI                        |    |                                   |    |                                |   |   |   |   |   |   |   |   |   |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                | <b>Instance</b> | SDTI                        |    |                                   |    |                                |   |   |   |   |   |   |   |   |   |
| <b>Description</b>      | Authentication status register  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                | <b>Type</b>     | R                           |    |                                   |    |                                |   |   |   |   |   |   |   |   |   |
| 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 |
| RESERVED                |                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SECURE_NONINVASIVE_DEBUGSTATUS |                 | SECURE_INVASIVE_DEBUGSTATUS |    | NONSECURE_NONINVASIVE_DEBUGSTATUS |    | NONSECURE_INVASIVE_DEBUGSTATUS |   |   |   |   |   |   |   |   |   |

| Bits | Field Name                            | Description                                                                                 | Type | Reset     |
|------|---------------------------------------|---------------------------------------------------------------------------------------------|------|-----------|
| 31:8 | RESERVED                              | RFU                                                                                         | R    | 0x0000000 |
| 7:6  | SECURE_NONINVASIVE_DEBU<br>GSTATUS    | The Secure Non-Invasive Debug Status shall return 00<br>(functionality not implemented)     | R    | 0x0       |
| 5:4  | SECURE_INVASIVE_DEBUGST<br>ATUS       | The Secure Invasive Debug Status shall return 00.<br>(functionality not implemented)        | R    | 0x0       |
| 3:2  | NONSECURE_NONINVASIVE_<br>DEBUGSTATUS | The Non-Secure Non-Invasive Debug Status shall return<br>00 (functionality not implemented) | R    | 0x0       |
| 1:0  | NONSECURE_INVASIVE_DEBU<br>GSTATUS    | The Non-Secure Invasive Debug Status shall return<br>00.(functionality not implemented)     | R    | 0x0       |

**Table 27-71. Register Call Summary for Register AUTHENTICATION\_STATUS**

SDTI Basic Programming Model

- SDTI Register List Ownership: [0]

SDTI Register Manual

- SDTI Register Summary: [1]

**Table 27-72. DEVICE\_ID**

|                         |                                                                                                                                                         |                         |                                 |                 |           |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|---------------------------------|-----------------|-----------|
| <b>Address Offset</b>   | 0x0000 0FC8                                                                                                                                             | <b>Physical Address</b> | See <a href="#">Table 27-43</a> | <b>Instance</b> | SDTI      |
| <b>Description</b>      | Device identification register.<br>The Device ID register is capability register and is implementation defined according to the CoreSight specification |                         |                                 |                 |           |
| <b>Type</b>             | R                                                                                                                                                       |                         |                                 |                 |           |
| 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                 |                 |           |
|                         |                                                                                                                                                         |                         |                                 | TIMESTAMP       | FIFODEPTH |
|                         | RESERVED                                                                                                                                                |                         |                                 |                 |           |

| Bits | Field Name | Description                                                                        | Type | Reset     |
|------|------------|------------------------------------------------------------------------------------|------|-----------|
| 31:9 | RESERVED   | RFU                                                                                | R    | 0x0000000 |
| 8    | TIMESTAMP  | 0 - TimeStamping feature not supported in SDTI<br>1 - TimeStamping present in SDTI | R    | 0         |
| 7:0  | FIFODEPTH  | SDTI FFIFO depth                                                                   | R    | 0x00      |

**Table 27-73. Register Call Summary for Register DEVICE\_ID**

SDTI Basic Programming Model

- [SDTI Register List Ownership: \[0\]](#)

SDTI Register Manual

- [SDTI Register Summary: \[1\]](#)

**Table 27-74. DEVICE\_TYPE\_REG**

|                         |                         |                         |                                 |                 |            |
|-------------------------|-------------------------|-------------------------|---------------------------------|-----------------|------------|
| <b>Address Offset</b>   | 0x0000 0FCC             | <b>Physical Address</b> | See <a href="#">Table 27-43</a> | <b>Instance</b> | SDTI       |
| <b>Description</b>      | Device type register    |                         |                                 |                 |            |
| <b>Type</b>             | R                       |                         |                                 |                 |            |
| 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                 |                 |            |
|                         | RESERVED                |                         |                                 |                 | DEVICETYPE |

| Bits | Field Name | Description                                                                                      | Type | Reset     |
|------|------------|--------------------------------------------------------------------------------------------------|------|-----------|
| 31:8 | RESERVED   | RFU                                                                                              | R    | 0x0000000 |
| 7:0  | DEVICETYPE | The device type shall return 0x63. Enables devices to be identified as to their CoreSight Class. | R    | 0x63      |

**Table 27-75. Register Call Summary for Register DEVICE\_TYPE\_REG**

SDTI Basic Programming Model

- [SDTI Register List Ownership: \[0\]](#)

SDTI Register Manual

- [SDTI Register Summary: \[1\]](#)

**Table 27-76. PERIPHERAL\_ID4**

|                         |                                                                                                                  |                         |                                 |                 |                            |
|-------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------|---------------------------------|-----------------|----------------------------|
| <b>Address Offset</b>   | 0x0000 0FD0                                                                                                      | <b>Physical Address</b> | See <a href="#">Table 27-43</a> | <b>Instance</b> | SDTI                       |
| <b>Description</b>      | All Peripheral ID registers are implemented as 8-bit registers with the upper 24 bits returning a value of zero. |                         |                                 |                 |                            |
| <b>Type</b>             | R                                                                                                                |                         |                                 |                 |                            |
| 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                 |                 |                            |
| RESERVED                |                                                                                                                  |                         |                                 |                 | FOURKBCOUNT JEP106CONTCODE |

| Bits | Field Name     | Description              | Type | Reset     |
|------|----------------|--------------------------|------|-----------|
| 31:8 | RESERVED       | RFU                      | R    | 0x0000000 |
| 7:4  | FOURKBCOUNT    | 4KB Count                | R    | 0x0       |
| 3:0  | JEP106CONTCODE | JEP106 Continuation Code | R    | 0x0       |

**Table 27-77. Register Call Summary for Register PERIPHERAL\_ID4**

SDTI Basic Programming Model

- [SDTI Register List Ownership: \[0\]](#)

SDTI Register Manual

- [SDTI Register Summary: \[1\]](#)

**Table 27-78. PERIPHERAL\_ID5**

|                         |                                                                                                                  |                         |                                 |                 |          |
|-------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------|---------------------------------|-----------------|----------|
| <b>Address Offset</b>   | 0x0000 0FD4                                                                                                      | <b>Physical Address</b> | See <a href="#">Table 27-43</a> | <b>Instance</b> | SDTI     |
| <b>Description</b>      | All Peripheral ID registers are implemented as 8-bit registers with the upper 24 bits returning a value of zero. |                         |                                 |                 |          |
| <b>Type</b>             | RW                                                                                                               |                         |                                 |                 |          |
| 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                 |                 |          |
| RESERVED                |                                                                                                                  |                         |                                 |                 | RESERVED |

| Bits | Field Name | Description | Type | Reset     |
|------|------------|-------------|------|-----------|
| 31:8 | RESERVED   | RFU         | RW   | 0x0000000 |
| 7:0  | RESERVED   | RFU         | R    | 0x00      |

**Table 27-79. Register Call Summary for Register PERIPHERAL\_ID5**

SDTI Basic Programming Model

- [SDTI Register List Ownership: \[0\]](#)

SDTI Register Manual

- [SDTI Register Summary: \[1\]](#)

**Table 27-80. PERIPHERAL\_ID6**

|                         |                                                                                                                  |                 |      |
|-------------------------|------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0FD8                                                                                                      | <b>Instance</b> | SDTI |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                                  | <b>Instance</b> | SDTI |
| <b>Description</b>      | All Peripheral ID registers are implemented as 8-bit registers with the upper 24 bits returning a value of zero. |                 |      |
| <b>Type</b>             | R                                                                                                                |                 |      |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RESERVED |   |   |   |   |   |   |

| Bits | Field Name | Description | Type | Reset     |
|------|------------|-------------|------|-----------|
| 31:8 | RESERVED   | RFU         | R    | 0x0000000 |
| 7:0  | RESERVED   | RFU         | R    | 0x00      |

**Table 27-81. Register Call Summary for Register PERIPHERAL\_ID6**

SDTI Basic Programming Model

- [SDTI Register List Ownership: \[0\]](#)

SDTI Register Manual

- [SDTI Register Summary: \[1\]](#)

**Table 27-82. PERIPHERAL\_ID7**

|                         |                                                                                                                  |                 |      |
|-------------------------|------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0FDC                                                                                                      | <b>Instance</b> | SDTI |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                                  | <b>Instance</b> | SDTI |
| <b>Description</b>      | All Peripheral ID registers are implemented as 8-bit registers with the upper 24 bits returning a value of zero. |                 |      |
| <b>Type</b>             | R                                                                                                                |                 |      |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RESERVED |   |   |   |   |   |   |   |

  

| Bits | Field Name | Description | Type | Reset     |
|------|------------|-------------|------|-----------|
| 31:8 | RESERVED   | RFU         | R    | 0x0000000 |
| 7:0  | RESERVED   | RFU         | R    | 0x00      |

**Table 27-83. Register Call Summary for Register PERIPHERAL\_ID7**

SDTI Basic Programming Model

- [SDTI Register List Ownership: \[0\]](#)

SDTI Register Manual

- [SDTI Register Summary: \[1\]](#)

**Table 27-84. PERIPHERAL\_ID0**

|                                                                           |                                                                                                                  |                 |                 |
|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|
| <b>Address Offset</b>                                                     | 0x0000 0FE0                                                                                                      | <b>Instance</b> | SDTI            |
| <b>Physical Address</b>                                                   | See <a href="#">Table 27-43</a>                                                                                  | <b>Instance</b> | SDTI            |
| <b>Description</b>                                                        | All Peripheral ID registers are implemented as 8-bit registers with the upper 24 bits returning a value of zero. |                 |                 |
| <b>Type</b>                                                               | R                                                                                                                |                 |                 |
| 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 |
| RESERVED                                                                  |                                                                                                                  |                 | PARTNUMBER0     |

| Bits | Field Name  | Description                                                      | Type | Reset     |
|------|-------------|------------------------------------------------------------------|------|-----------|
| 31:8 | RESERVED    | RFU                                                              | R    | 0x0000000 |
| 7:0  | PARTNUMBER0 | 0x20 Part Number 0 (Middle and Lower BCD value of Device Number) | R    | 0x20      |

**Table 27-85. Register Call Summary for Register PERIPHERAL\_ID0**

SDTI Basic Programming Model

- [SDTI Register List Ownership: \[0\]](#)

SDTI Register Manual

- [SDTI Register Summary: \[1\]](#)

**Table 27-86. PERIPHERAL\_ID1**

|                                                                           |                                                                                                                  |                 |                            |
|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-----------------|----------------------------|
| <b>Address Offset</b>                                                     | 0x0000 0FE4                                                                                                      | <b>Instance</b> | SDTI                       |
| <b>Physical Address</b>                                                   | See <a href="#">Table 27-43</a>                                                                                  | <b>Instance</b> | SDTI                       |
| <b>Description</b>                                                        | All Peripheral ID registers are implemented as 8-bit registers with the upper 24 bits returning a value of zero. |                 |                            |
| <b>Type</b>                                                               | R                                                                                                                |                 |                            |
| 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            |
| RESERVED                                                                  |                                                                                                                  |                 | JEP106IDCODE   PARTNUMBER1 |

| Bits | Field Name   | Description                                      | Type | Reset     |
|------|--------------|--------------------------------------------------|------|-----------|
| 31:8 | RESERVED     | RFU                                              | R    | 0x0000000 |
| 7:4  | JEP106IDCODE | JEP106 identity code [3:0]                       | R    | 0x7       |
| 3:0  | PARTNUMBER1  | Part number 1 (upper BCD value of device number) | R    | 0x1       |

**Table 27-87. Register Call Summary for Register PERIPHERAL\_ID1**

SDTI Basic Programming Model

- [SDTI Register List Ownership: \[0\]](#)

SDTI Register Manual

- [SDTI Register Summary: \[1\]](#)

**Table 27-88. PERIPHERAL\_ID2**

|                         |                                                                                                                  |                         |                                 |                 |                       |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------|---------------------------------|-----------------|-----------------------|--|--|
| <b>Address Offset</b>   | 0x0000 0FE8                                                                                                      | <b>Physical Address</b> | See <a href="#">Table 27-43</a> | <b>Instance</b> | SDTI                  |  |  |
| <b>Description</b>      | All Peripheral ID registers are implemented as 8-bit registers with the upper 24 bits returning a value of zero. |                         |                                 |                 |                       |  |  |
| <b>Type</b>             | R                                                                                                                |                         |                                 |                 |                       |  |  |
| 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                 | REVISION        | JEDEC<br>JEP106IDCODE |  |  |
| RESERVED                |                                                                                                                  |                         |                                 |                 |                       |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>                                                          | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------------------------------------------------------------|-------------|--------------|
| 31:8        | RESERVED          | RFU                                                                         | R           | 0x000000     |
| 7:4         | REVISION          | Revision number of peripheral.<br>Major revision from OCP version register. | R           | 0x1          |
| 3           | JEDEC             | Indicates that a JEDEC assigned value is used.                              | R           | 1            |
| 2:0         | JEP106IDCODE      | JEP106 identity code [6:4]                                                  | R           | 0x1          |

**Table 27-89. Register Call Summary for Register PERIPHERAL\_ID2**

SDTI Basic Programming Model

- [SDTI Register List Ownership: \[0\]](#)

SDTI Register Manual

- [SDTI Register Summary: \[1\]](#)

**Table 27-90. PERIPHERAL\_ID3**

|                         |                                                                                                                  |                         |                                 |                 |                |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------|---------------------------------|-----------------|----------------|--|--|
| <b>Address Offset</b>   | 0x0000 0FEC                                                                                                      | <b>Physical Address</b> | See <a href="#">Table 27-43</a> | <b>Instance</b> | SDTI           |  |  |
| <b>Description</b>      | All Peripheral ID registers are implemented as 8-bit registers with the upper 24 bits returning a value of zero. |                         |                                 |                 |                |  |  |
| <b>Type</b>             | R                                                                                                                |                         |                                 |                 |                |  |  |
| 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                 | REVAND          | CUSTOMMODIFIED |  |  |
| RESERVED                |                                                                                                                  |                         |                                 |                 |                |  |  |

| <b>Bits</b> | <b>Field Name</b> | <b>Description</b>    | <b>Type</b> | <b>Reset</b> |
|-------------|-------------------|-----------------------|-------------|--------------|
| 31:8        | RESERVED          | RFU                   | R           | 0x000000     |
| 7:4         | REVAND            | RevAnd (at top level) | R           | 0x0          |
| 3:0         | CUSTOMMODIFIED    | Customer Modified     | R           | 0x0          |

**Table 27-91. Register Call Summary for Register PERIPHERAL\_ID3**

SDTI Basic Programming Model

- SDTI Register List Ownership: [0]

SDTI Register Manual

- SDTI Register Summary: [1]

**Table 27-92. COMPONENT\_ID0**

|                         |                                                                                                                                                                                                                                                                                                            |                       |                 |          |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|------|
| <b>Address Offset</b>   | 0x0000 0FF0                                                                                                                                                                                                                                                                                                |                       |                 |          |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                                                                                                                                                                                                                            |                       |                 |          |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | SDTI |
| <b>Description</b>      | All Component ID registers are implemented as 8-bit registers with the upper 24 bits returning a value of zero. These registers are used to indicate to software the existence of a peripheral. Software will read the last four locations in each 4K block to determine if a Coresight Peripheral exists. |                       |                 |          |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                          |                       |                 |          |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |
| 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 | RESERVED | COMPONENTID0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |

| Bits | Field Name   | Description                                    | Type | Reset    |
|------|--------------|------------------------------------------------|------|----------|
| 31:8 | RESERVED     | RFU                                            | R    | 0x000000 |
| 7:0  | COMPONENTID0 | This register shall return Preamble value 0x0D | R    | 0x0D     |

**Table 27-93. Register Call Summary for Register COMPONENT\_ID0**

SDTI Basic Programming Model

- SDTI Register List Ownership: [0]

SDTI Register Manual

- SDTI Register Summary: [1]

**Table 27-94. COMPONENT\_ID1**

|                         |                                                                                                                                                                                                                                                                                                            |                       |                 |          |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|----------|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|------|
| <b>Address Offset</b>   | 0x0000 0FF4                                                                                                                                                                                                                                                                                                |                       |                 |          |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                                                                                                                                                                                                                            |                       |                 |          |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | SDTI |
| <b>Description</b>      | All Component ID registers are implemented as 8-bit registers with the upper 24 bits returning a value of zero. These registers are used to indicate to software the existence of a peripheral. Software will read the last four locations in each 4K block to determine if a Coresight Peripheral exists. |                       |                 |          |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                          |                       |                 |          |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |
| 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 | RESERVED | COMPONENTID1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |

| Bits | Field Name   | Description                                    | Type | Reset    |
|------|--------------|------------------------------------------------|------|----------|
| 31:8 | RESERVED     | RFU                                            | R    | 0x000000 |
| 7:0  | COMPONENTID1 | This register shall return Preamble value 0x90 | R    | 0x90     |

**Table 27-95. Register Call Summary for Register COMPONENT\_ID1**

SDTI Basic Programming Model

- SDTI Register List Ownership: [0]

SDTI Register Manual

- SDTI Register Summary: [1]

**Table 27-96. COMPONENT\_ID2**

|                         |                                                                                                                                                                                                                                                                                                            |                 |      |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0FF8                                                                                                                                                                                                                                                                                                |                 |      |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                                                                                                                                                                                                                            | <b>Instance</b> | SDTI |
| <b>Description</b>      | All Component ID registers are implemented as 8-bit registers with the upper 24 bits returning a value of zero. These registers are used to indicate to software the existence of a peripheral. Software will read the last four locations in each 4K block to determine if a Coresight Peripheral exists. |                 |      |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                          |                 |      |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------------|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | COMPONENTID2 |   |   |   |   |   |   |

| Bits | Field Name   | Description                                    | Type | Reset    |
|------|--------------|------------------------------------------------|------|----------|
| 31:8 | RESERVED     | RFU                                            | R    | 0x000000 |
| 7:0  | COMPONENTID2 | This register shall return Preamble value 0x05 | R    | 0x05     |

**Table 27-97. Register Call Summary for Register COMPONENT\_ID2**

- SDTI Basic Programming Model
  - [SDTI Register List Ownership: \[0\]](#)
 SDTI Register Manual
  - [SDTI Register Summary: \[1\]](#)

**Table 27-98. COMPONENT\_ID3**

|                         |                                                                                                                                                                                                                                                                                                            |                 |      |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------|
| <b>Address Offset</b>   | 0x0000 0FFC                                                                                                                                                                                                                                                                                                |                 |      |
| <b>Physical Address</b> | See <a href="#">Table 27-43</a>                                                                                                                                                                                                                                                                            | <b>Instance</b> | SDTI |
| <b>Description</b>      | All Component ID registers are implemented as 8-bit registers with the upper 24 bits returning a value of zero. These registers are used to indicate to software the existence of a peripheral. Software will read the last four locations in each 4K block to determine if a Coresight Peripheral exists. |                 |      |
| <b>Type</b>             | R                                                                                                                                                                                                                                                                                                          |                 |      |

  

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |              |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------------|---|---|---|---|---|---|---|
| 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 |
| RESERVED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | COMPONENTID3 |   |   |   |   |   |   |   |

  

| Bits | Field Name   | Description                                    | Type | Reset    |
|------|--------------|------------------------------------------------|------|----------|
| 31:8 | RESERVED     |                                                | R    | 0x000000 |
| 7:0  | COMPONENTID3 | This register shall return Preamble value 0xB1 | R    | 0xB1     |

**Table 27-99. Register Call Summary for Register COMPONENT\_ID3**

- SDTI Basic Programming Model
  - [SDTI Register List Ownership: \[0\]](#)
 SDTI Register Manual
  - [SDTI Register Summary: \[1\]](#)

## 27.4 Emulation Pin Manager

This section describes the debug pins in the device.

### 27.4.1 EPM Overview

The EPM manages the multiplexing of the emulation pin to the application pin manager. [Figure 27-16](#) shows the EPM in the device.

**Figure 27-16. EPM Overview**



For more informations about the application pin manager, see [Chapter 13, System Control Module](#).

### 27.4.2 EPM Integration

The EPM is in the EMU power domain and is connected to the L4 debug interconnect for register control access.

### 27.4.3 EPM Functional Description

#### 27.4.3.1 EPM Overview

Some subsystems provide a debug port that can be configured to support a specific debug and trace feature. The configuration and debug source selection are done through the EPM.

At the device level, the platform shares a unique debug port. A similar mechanism allows configuring and selecting a specific debug source for each pin. This allows supporting concurrent debug features, provided that pin mapping does not conflict.

The device EPM can be programmed from the application or debugger software. A claim mechanism ensures exclusive ownership. However, the debugger can override the ownership state.

The debug port is mapped on top of a set of application pins. The device platforms provide the application software with the flexibility to map a set of peripheral interfaces to these pins. The configuration and the application source selection are done through the device application pin manager in the system control module (SCM) (for more information, see [Chapter 13, System Control Module](#)).

When the EPM is programmed to map a debug function to the debug port, the application pin manager (in the SCM) automatically selects the EPM channel.

#### 27.4.3.2 EPM Multiplexing

EPM multiplexes multiple debug signals to the etk\_xxx and jtag\_emu0/1 signals. The multiplexing function is controlled by the following registers:

- [DAPC\\_EPM0](#)
- [DAPC\\_EPM1](#)
- [DAPC\\_EPM2](#)

Multiple signals can be controlled by a single bit field (for example, the etk\_d10, etk\_d9, and etk\_d8

signals are controlled by the [DAPC\\_EPM1\[19:16\]](#) DBGP12 bit field).

[Table 27-100](#) lists the different modes supported for each pin and the bit field that controls the output mode.

Table 27-100. EPM Multiplexing

| Debug Control | Interface Signals | ETM 16   |     | ETM 8    |     | IVA HS-RTDX/Triggers 2-Pin Mode |     | SDTI 4 Data               |     | SDTI 4 Data               |     | SDTI 2 Data               |     | SDTI 1 Data               |     |
|---------------|-------------------|----------|-----|----------|-----|---------------------------------|-----|---------------------------|-----|---------------------------|-----|---------------------------|-----|---------------------------|-----|
|               |                   | Function | Dir | Function | Dir | Function                        | Dir | Function                  | Dir | Function                  | Dir | Function                  | Dir | Function                  | Dir |
| DBGP19        | etk_d15           | etk_d15  | O   | —        | —   | emu3                            | IO  | sdти_txtd3                | O   | sdти_txtd3                | O   | —                         | —   | —                         | —   |
| DBGP18        | etk_d14           | etk_d14  | O   | —        | —   | emu2                            | IO  | sdти_txtd2 <sup>(1)</sup> | O   | sdти_txtd2 <sup>(1)</sup> | O   | sdти_clk <sup>(1)</sup>   | O   | —                         | —   |
| DBGP17        | etk_d13           | etk_d13  | O   | —        | —   | —                               | —   | sdти_txtd1                | O   | sdти_txtd1                | O   | —                         | —   | —                         | —   |
| DBGP16        | etk_d12           | etk_d12  | O   | —        | —   | —                               | —   | sdти_txtd0                | O   | —                         | —   | —                         | —   | —                         | —   |
| DBGP15        | etk_d11           | etk_d11  | O   | —        | —   | —                               | —   | sdти_clk                  | O   | —                         | —   | —                         | —   | —                         | —   |
| DBGP12        | etk_d10           | etk_d10  | O   | —        | —   | —                               | —   | uart1_rx <sup>(2)</sup>   | I   | —                         | —   | —                         | —   | —                         | —   |
|               | etk_d9            | etk_d9   | O   | —        | —   | —                               | —   | —                         | —   | —                         | —   | —                         | —   | —                         | —   |
|               | etk_d8            | etk_d8   | O   | —        | —   | —                               | —   | —                         | —   | —                         | —   | —                         | —   | —                         | —   |
| DBGP2         | etk_d7            | etk_d7   | O   | etk_d7   | O   | —                               | —   | —                         | —   | —                         | —   | —                         | —   | —                         | —   |
|               | etk_d6            | etk_d6   | O   | etk_d6   | O   | —                               | —   | —                         | —   | —                         | —   | —                         | —   | —                         | —   |
|               | etk_d5            | etk_d5   | O   | etk_d5   | O   | —                               | —   | —                         | —   | —                         | —   | —                         | —   | —                         | —   |
|               | etk_d4            | etk_d4   | O   | etk_d4   | O   | —                               | —   | —                         | —   | —                         | —   | —                         | —   | —                         | —   |
|               | etk_d3            | etk_d3   | O   | etk_d3   | O   | —                               | —   | —                         | —   | —                         | —   | —                         | —   | —                         | —   |
|               | etk_d2            | etk_d2   | O   | etk_d2   | O   | —                               | —   | —                         | —   | —                         | —   | —                         | —   | —                         | —   |
|               | etk_d1            | etk_d1   | O   | etk_d1   | O   | —                               | —   | —                         | —   | —                         | —   | —                         | —   | —                         | —   |
|               | etk_d0            | etk_d0   | O   | etk_d0   | O   | —                               | —   | —                         | —   | —                         | —   | —                         | —   | —                         | —   |
|               | etk_ctl           | etk_ctl  | O   | etk_ctl  | O   | —                               | —   | —                         | —   | —                         | —   | —                         | —   | —                         | —   |
|               | etk_clk           | etk_clk  | O   | etk_clk  | O   | —                               | —   | —                         | —   | —                         | —   | —                         | —   | —                         | —   |
| DBGP1         | jtag_emu1         | —        | —   | —        | —   | emu1                            | IO  | —                         | O   | sdти_txtd0 <sup>(3)</sup> | O   | sdти_txtd1 <sup>(3)</sup> | O   | sdти_txtd0 <sup>(3)</sup> | O   |
| DBGP0         | jtag_emu0         | —        | —   | —        | —   | emu0                            | IO  | —                         | O   | sdти_clk <sup>(1)</sup>   | O   | sdти_txtd0 <sup>(1)</sup> | O   | sdти_clk <sup>(1)</sup>   | O   |

<sup>(1)</sup> Two SDTI pins can be mapped to the same etk\_#; SDTI\_CLK selects the sdти\_clk pin, and SDTI\_DATA selects the sdти\_txtd# data pin.

<sup>(2)</sup> To map the uart1\_rx pin, configuration must be done on the application pin manager (that is, SCM)

<sup>(3)</sup> Two SDTI data share the same etk\_#; sdти\_txtd0 is mapped on jtag\_emu1 if sdти\_clk is mapped on jtag\_emu0; and sdти\_txtd1 is mapped on jtag\_emu1 if sdти\_txtd0 is mapped on jtag\_emu0.

All the output pins are controlled by a 4-bit bit field that configures the current mode. Table 27-101 shows the list of modes supported and the corresponding values to enter in the EPM control bit field in the following registers:

- [DAPC\\_EPM0](#)
- [DAPC\\_EPM1](#)
- [DAPC\\_EPM2](#)

**Table 27-101. EPM Control**

| EPM Control Value | Debug Mode                       | Subsystem |             |
|-------------------|----------------------------------|-----------|-------------|
| 0000              | Boot mode – Default state at POR |           |             |
| 0001              | Trigger                          | ICEPick   |             |
| 0010              | HS-RTDX                          | IVA       |             |
| 0011              | Reserved                         | Reserved  |             |
| 0100              | Trace                            | ETM       | MPU         |
| 0101              | Trace                            | SDTI      | Trace data  |
| 0110              |                                  |           | Trace clock |
| 0111              | System trace                     | SDTI      |             |
| 1000              |                                  |           |             |
| 1001              | Reserved                         | Reserved  |             |
| -                 |                                  |           |             |
| 1111              |                                  |           |             |

#### 27.4.3.3 Concurrent Debug Support

Table 27-102 summarizes the concurrent debug scenarios supported in the device.

**Table 27-102. Concurrent Debug Interfaces**

|             | ETM16 | ETM8 | Triggers | IVA     | SDTI | SDTI |
|-------------|-------|------|----------|---------|------|------|
|             |       |      |          | HS-RTDX |      |      |
| (1)(2)ETM16 |       |      | x        | x       | x    |      |
| ETM8        |       |      | x        | x       | x    | x    |
| Triggers    | x     | x    |          | x (1)   |      | x    |
| IVA HS-RTDX | x     | x    | x (1)    |         |      | x    |
| SDTI (3)    | x     | x    |          |         |      |      |
| SDTI (2)    |       | x    | x        | x       |      |      |

(1) Single HS-RTDX data line concurrent with single trigger

(2) 4-pin trace data plus trace clock mapped to dedicated SDTI port

(3) Single trace data line plus trace clock mapped to jtag\_emu0, jtag\_emu1 pins

The jtag\_emu0 debug signal routing is directly defined by the EPM CONTROL[0] setup.

The jtag\_emu1 debug signal routing depends on the debug function mapped to jtag\_emu1 and the debug signal routed to jtag\_emu0.

The etk\_clk debug signal routing depends on the debug function mapped to etk\_clk and the debug signals routed to jtag\_emu0 and jtag\_emu.

The etk\_ctl debug signal routing depends on the debug function mapped to etk\_ctl and the debug signal routed to jtag\_emu0, jtag\_emu1, and etk\_clk.

If the same debug feature is mapped to consecutive etk\_d pins and the debug signal [n] is routed to etk\_d[i], the debug signal [n+1] is routed to etk\_d[i+1].

If different features are mapped to consecutive etk\_d pins and the debug signal [x,n] is routed to etk\_d[i], the debug signal [y,0] is routed to etk\_d[i+1].

#### 27.4.3.4 EPM Control Access

The EPM control registers are attached to the emulation L4 bus and can be programmed by the debugger through DAP or by the application software. Figure 27-17 shows the two accesses.

**Figure 27-17. EPM Control Access**

debpin-002

All access done by using DAP are considered debugger access; otherwise, they are considered application access.

#### 27.4.3.5 Claim Procedure

The application or the debugger can own the EPM control registers. The ownership is required to configure or program the EPM. In other words, ownership determines if write access is granted to the component. EPM ownership is exclusive. Hence, simultaneous use of EPM is not permitted. However, the debugger can forcibly seize ownership of the EPM.

Claim state can be read in the [DAPC\\_EPM2\[31:30\]](#) CLAIMOWNERSHIP bit field. [Table 27-103](#) shows the different claim values returned by this bit field.

**Table 27-103. Claim States**

| State     | Value | Definition                              |
|-----------|-------|-----------------------------------------|
| Available | 00    | The EPM has not been claimed.           |
| Claimed   | 01    | The EPM has been claimed.               |
| Enabled   | 10    | The EPM is enabled by the owning party. |
| Reserved  | 11    | Reserved                                |

If the EPM is in a nonavailable state (the [DAPC\\_EPM2\[31:30\]](#) CLAIMOWNERSHIP bit field = 01 or 10), the current owner can be read in the [DAPC\\_EPM2\[28\]](#) CLAIMCURRENTOWNER bit.

To change claim ownership state, write a command in the [DAPC\\_EPM2\[31:30\]](#) CLAIMOWNERSHIP bit field. [Table 27-104](#) shows the different commands to manage EPM ownership.

**Table 27-104. Claim Commands**

| Encoding | Command           | Definition                                                                                                                                               |
|----------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00       | Release ownership | Release EPM ownership. The release command is accepted only from the owner.                                                                              |
| 01       | Claim ownership   | Claim access to the EPM. The claim command is successful only if the EPM is available or requested by the debugger and the DEBUGGEROVERRIDE bit is high. |
| 10       | Enable unit       | Activate the EPM for use. The enable command is accepted only from the owner.                                                                            |
| 11       | No operation      | The NOP command does not affect ownership or the claim state.                                                                                            |

The debugger can force the claim procedure by writing 1 in the [DAPC\\_EPM2\[27\]](#) CLAIMDEBUGGEROVERRIDE bit. When this bit is set to 1, the debugger can get EPM ownership even if the application already ownership. When this bit is cleared to 0, the debugger can get EPM ownership only if the current state is Available.

#### **27.4.4 EPM Programming Model**

##### **27.4.4.1 EPM Concurrent Debug Examples**

[Table 27-105](#) through [Table 27-110](#) show different examples of concurrent debug with the corresponding EPM control field and value.

**Table 27-105. Triggers**

| EMU Pin   | Debug Mode | Debug Signal Routing | EPM Control Field | EPM Control Value |
|-----------|------------|----------------------|-------------------|-------------------|
| jtag_emu0 | Trigger    | Trigger 0            | DBGPO             | 0001              |
| jtag_emu1 | Trigger    | Trigger 1            | DBGPI             | 0001              |

**Table 27-106. Trigger + HS-RTDX**

| EMU Pin   | Debug Mode  | Debug Signal Routing | EPM Control Field | EPM Control Value |
|-----------|-------------|----------------------|-------------------|-------------------|
| jtag_emu0 | Trigger     | Trigger 0            | DBGPO             | 0001              |
| jtag_emu1 | IVA HS-RTDX | HS-RTDX[0]           | DBGPI             | 0010              |
| etk_d14   | IVA HS-RTDX | HS-RTDX[1]           | DBGPI8            | 0010              |
| etk_d15   | Trigger     | Trigger 1            | DBGPI9            | 0001              |

**Table 27-107. SDTI [Single-Pin Data + Clock] + ETM16**

| EMU Pin     | Debug Mode   | Debug Signal Routing | EPM Control Field           | EPM Control Value |
|-------------|--------------|----------------------|-----------------------------|-------------------|
| jtag_emu0   | SDTI – Clock | sdti_clk             | DBGPO                       | 1000              |
| jtag_emu1   | SDTI – Data  | sdti_txd0            | DBGPI                       | 0111              |
| etk_clk     | Trace – ETM  | etk_clk              | DBGPI2, DBGP12, DBGP[19:15] | 1000              |
| etk_ctl     | Trace – ETM  | etk_ctl              |                             |                   |
| etk_d[15:0] | Trace – ETM  | etk_d[15:0]          |                             |                   |

**Table 27-108. Trigger + HS-RTDX + ETM8 + SDTI [4-Pin Data + Clock/Dedicated Port]**

| EMU Pin      | Debug Mode         | Debug Signal Routing | EPM Control Field | EPM Control Value |
|--------------|--------------------|----------------------|-------------------|-------------------|
| jtag_emu0    | Trigger            | Trigger 0            | DBGPO             | 0001              |
| jtag_emu1    | IVA HS-RTDX        | HS-RTDX [0]          | DBGPI             | 0010              |
| etk_clk      | Trace – ETM        | etk_clk              | DBGPI2, DBGP12    | 1000              |
| etk_ctl      | Trace – ETM        | etk_ctl              |                   |                   |
| etk_d[7:0]   | Trace – ETM        | etk_d[7:0]           |                   |                   |
| etk_d[10:8]  | None               | -                    | -                 | -                 |
| etk_d[11]    | SDTI – Trace clock | sdti_clk             | DBGPI5            | 1000              |
| etk_d[15:12] | SDTI – Trace data  | sdti_txd[3:0]        | DBGPI[19:16]      | 0111              |

**Table 27-109. Trigger + HS-RTDX + ETM8 + SDTI [2-Pin Data + Clock]**

| EMU Pin   | Debug Mode  | Debug Signal Routing | EPM Control Field | EPM Control Value |
|-----------|-------------|----------------------|-------------------|-------------------|
| jtag_emu0 | Trigger     | Trigger 0            | DBGPO             | 0001              |
| jtag_emu1 | IVA HS-RTDX | HS-RTDX[0]           | DBGPI             | 0010              |

**Table 27-109. Trigger + HS-RTDX + ETM8 + SDTI [2-Pin Data + Clock] (continued)**

| EMU Pin      | Debug Mode         | Debug Signal Routing | EPM Control Field | EPM Control Value |
|--------------|--------------------|----------------------|-------------------|-------------------|
| etk_clk      | Trace - ETM        | etk_clk              | DBGP2, DBGP12     | 1000              |
| etk_ctl      | Trace - ETM        | etk_ctl              |                   |                   |
| etk_d[7:0]   | Trace - ETM        | etk_d[7:0]           |                   |                   |
| etk_d[10:8]  | None               | -                    | -                 | -                 |
| etk_d[11]    | SDTI – Trace clock | sdti_clk             | DBGP15            | 1000              |
| etk_d[13:12] | None               | -                    | -                 | -                 |
| etk_d[15:14] | SDTI – Trace data  | sdti_txd[1:0]        | DBGP[19:18]       | 0111              |

**Table 27-110. ETM8 + SDTI [4-Pin Data + Clock]**

| EMU Pin      | Debug Mode         | Debug Signal Routing | EPM Control Field | EPM Control Value |
|--------------|--------------------|----------------------|-------------------|-------------------|
| jtag_emu0    | SDTI – Trace data  | sdti_txd[0]          | DBGP0             | 0111              |
| jtag_emu1    | SDTI – Trace data  | sdti_txd[1]          | DBGP1             | 0111              |
| etk_clk      | Trace - ETM        | etk_clk              | DBGP2, DBGP12     | 1000              |
| etk_ctl      | Trace - ETM        | etk_ctl              |                   |                   |
| etk_d[7:0]   | Trace - ETM        | etk_d[7:0]           |                   |                   |
| etk_d[10:8]  | None               | -                    | -                 | -                 |
| etk_d[11]    | SDTI – Trace clock | sdti_clk             | DBGP15            | 1000              |
| etk_d[13:12] | None               | -                    | -                 | -                 |
| etk_d[15:14] | SDTI – Trace data  | sdti_txd[3:2]        | DBGP[19:18]       | 0111              |

## 27.4.5 EPM Register Manual

Table 27-111 summarizes the EPM instance.

**Table 27-111. EPM Instance Summary**

| Module Name | SIMCOP Base Address | Size     |
|-------------|---------------------|----------|
| EPM         | 0x0000 0800         | 32 bytes |

### 27.4.5.1 EPM Register Summary

Table 27-112 is the EPM register mapping summary.

**Table 27-112. EPM Register Summary**

| Register Name | Type | Register Width (Bits) | Address Offset | Physical Address From SIMCOP base address |
|---------------|------|-----------------------|----------------|-------------------------------------------|
| DAPC_EPM0     | RW   | 32                    | 0x0000 0000    | 0x0000 0800                               |
| DAPC_EPM1     | RW   | 32                    | 0x0000 0004    | 0x0000 0804                               |
| DAPC_EPM2     | RW   | 32                    | 0x0000 0008    | 0x0000 0808                               |

### 27.4.5.2 EPM Register Description

**Table 27-113. DAPC\_EPM0**

|                         |                                   |                       |                 |             |
|-------------------------|-----------------------------------|-----------------------|-----------------|-------------|
| <b>Address Offset</b>   | 0x050                             |                       |                 |             |
| <b>Physical address</b> | 0x5401 D050                       | <b>Instance</b>       | DAPC_EPM        |             |
| <b>Description</b>      | Emulation pin manager register 0. |                       |                 |             |
| <b>Type</b>             | RW                                |                       |                 |             |
| 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 |             |
|                         | RESERVED                          |                       | DBGP2           | DBGP1 DBGP0 |

| Bits  | Field Name | Description                                        | Type | Reset   |
|-------|------------|----------------------------------------------------|------|---------|
| 31:12 | RESERVED   | Read returns reset value.                          | R    | 0x00000 |
| 11:8  | DBGP2      | TRACECLK, TRACECTL and TRACEDATA[7:0] pins control | RW   | 0x0     |
| 7:4   | DBGP1      | EMU1 pin control                                   | RW   | 0x0     |
| 3:0   | DBGP0      | EMU0 pin control                                   | RW   | 0x0     |

**Table 27-114. Register Call Summary for Register DAPC\_EPM0**

EPM Functional Description

- [EPM Multiplexing: \[0\] \[1\]](#)

EPM Register Manual

- [EPM Register Manual: \[2\]](#)

**Table 27-115. DAPC\_EPM1**

|                         |                                  |                       |                 |  |
|-------------------------|----------------------------------|-----------------------|-----------------|--|
| <b>Address Offset</b>   | 0x054                            |                       |                 |  |
| <b>Physical address</b> | 0x5401 D054                      | <b>Instance</b>       | DAPC_EPM        |  |
| <b>Description</b>      | Emulation pin manager register 1 |                       |                 |  |
| <b>Type</b>             | RW                               |                       |                 |  |
| 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 |  |
| DBGP15                  | RESERVED                         | DBGP12                | RESERVED        |  |

| Bits  | Field Name | Description                 | Type | Reset  |
|-------|------------|-----------------------------|------|--------|
| 31:28 | DBGP15     | TRACEDATA[11] pin control   | RW   | 0x0    |
| 27:20 | RESERVED   | Read returns reset value.   | R    | 0x00   |
| 19:16 | DBGP12     | TRACEDATA[10:8] pin control | RW   | 0x0    |
| 15:0  | RESERVED   | Read returns reset value.   | R    | 0x0000 |

**Table 27-116. Register Call Summary for Register DAPC\_EPM1**

EPM Functional Description

- [EPM Multiplexing: \[0\] \[1\] \[2\]](#)

EPM Register Manual

- [EPM Register Manual: \[3\]](#)

**Table 27-117. DAPC\_EPM2**

|                         |                                  |                       |                 |  |  |  |        |        |        |        |  |  |  |  |  |
|-------------------------|----------------------------------|-----------------------|-----------------|--|--|--|--------|--------|--------|--------|--|--|--|--|--|
| <b>Address Offset</b>   | 0x058                            |                       |                 |  |  |  |        |        |        |        |  |  |  |  |  |
| <b>Physical address</b> | 0x5401 D058                      |                       |                 |  |  |  |        |        |        |        |  |  |  |  |  |
| <b>Description</b>      | Emulation pin manager register 2 |                       |                 |  |  |  |        |        |        |        |  |  |  |  |  |
| <b>Type</b>             | RW                               |                       |                 |  |  |  |        |        |        |        |  |  |  |  |  |
| 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 |  |  |  |        |        |        |        |  |  |  |  |  |
| CLAIMOWNERSHIP          | CLAIMDEBUGGEROVERRIDE            | CLAIMCURRENTOWNER     | RESERVED        |  |  |  | DBGP19 | DBGP18 | DBGP17 | DBGP16 |  |  |  |  |  |

| Bits  | Field Name            | Description                                                                                                                                                                                                                                                                                                                                                                   | Type | Reset |
|-------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 31:30 | CLAIMOWNERSHIP        | Read:<br>Read to get current ownership status. The claim status encoding shall be (0=Available, 1=Claimed, 2=Enabled, 3=Reserved)<br>Write:<br>Send command to modify ownership state. A successful command would cause these bit values to reflect the new state.                                                                                                            | RW   | 0x0   |
| 29    | CLAIMDEBUGGEROVERRIDE | Read:<br>Reading from the DebuggerOverride bit returns a 1.<br>Write:<br>This qualifier bit is used with the debugger's CLAIM request. When written with DebuggerOverride=1, a claim request by the debugger is granted regardless of current ownership status of the unit. When written with DebuggerOverride=0, the claim request is granted only if the unit is available. | RW   | 0     |
| 28    | CLAIMCURRENTOWNER     | This value reflects the unit ownership when the register is in a non-Available state.<br>0=Debugger owns resource.<br>1=Application owns resource                                                                                                                                                                                                                             | R    | 0     |
| 27:16 | RESERVED              | Read returns reset value.                                                                                                                                                                                                                                                                                                                                                     | R    | 0x000 |
| 15:12 | DBGP19                | TRACEDATA[15] pin control                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0   |
| 11:8  | DBGP18                | TRACEDATA[14] pin control                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0   |
| 7:4   | DBGP17                | TRACEDATA[13] pin control                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0   |
| 3:0   | DBGP16                | TRACEDATA[12] pin control                                                                                                                                                                                                                                                                                                                                                     | RW   | 0x0   |

**Table 27-118. Register Call Summary for Register DAPC\_EPM2**

## EPM Functional Description

- [EPM Multiplexing: \[0\]](#) [\[1\]](#)
- [Claim procedure: \[2\]](#) [\[3\]](#) [\[4\]](#) [\[5\]](#) [\[6\]](#)

## EPM Register Manual

- [EPM Register Manual: \[7\]](#)

## Glossary

---



---



---

### Numerical

- 2D**— Two dimensional
- 3D**— Three dimensional
- 3GPP**— 3rd Generation Partnership Project

### A

- ABS**— Absolute value
- ADC**— Analog-to-digital converter/conversion
- AEW**— Adaptive multirate
- AHB**— Advanced high-performance bus
- AMR**— Adaptive multirate; also Audio modem riser: An Intel specification that defines a new architecture for the design of motherboards.
- APB**— Advanced peripheral bus
- APE**— Applicative processor engine
- API**— Application programming interface; also ARM port interface
- ARAU**— Auxiliary register arithmetic unit
- ARGB**— Alpha, red, green, blue
- ASIC**— Application-specific integrated circuit: A chip built for a specific application. In the context of this document, ASIC refers to the FPGA that resides on the EVM board.
- ASCII**— American standard code for information
- ATR**— Answer to reset
- AVC**— Advanced video coding (MPEG4 - Part 10 also known as H264)
- AXI**— Advanced extensible interface

### B

- BB**— Busy bus
- BCD**— Binary-coded decimal: A representation of decimal digits (0–9) using a nibble that uses a certain number of bits. For example, using 4 bits, two BCDs can be packed into 1 byte.
- BGA**— Ball grid array
- BGAPTS**— Band gap voltage and temperature sensor
- BGT**— Block guard time

## Appendix A

www.ti.com

**BIOS**— Built-in operating system

**BIST**— Built-in self-test

**Bluetooth®**— A short-range radio technology designed to simplify communications among network devices and between devices and the Internet. It also simplifies data synchronization between network devices and other computers.

**BPP**— Bits per pixel

**BTA**— Bus turn around

**C**

**CALU**— Central arithmetic logic unit

**CAVLC**— Context-adaptive variable length coder

**CAVLD**— Context-adaptive variable length decoder

**CBUFF**— Circular buffer

**CDL**— Controlled delay line

**CE**— Chip enable

**CH**— Configuration header. To use settings other than ROM code defaults, (that is, clock frequencies, SDRAM/DDRAM settings, or GPMC settings).

**CID**— Card identification number

**CIF**— Common intermediate format. A video format used in video conferencing systems that easily supports both NTSC and PAL signals. CIF is part of the ITU H.261 video conferencing standard. It specifies a data rate of 30 fps, with each frame containing 288 lines and 352 pixels per line.

**CLE**— Command latch enable

**CLK**— Clock

**CLUT**— Color look-up table

**CMOS**— Complementary metal oxide semiconductor

**CMT**— Cellular mobile telephone

**Codec**— Coder/decoder or compression/decompression: A device that codes in one direction of transmission and decodes in another direction of transmission.

**ConnID**— Connection identifier: An initiator module identifier. A ConnID transmitted in-band with the request and is used for protection and error logging mechanism.

**CP15**— Coprocessor 15: This coprocessor controls the operation and configuration of the TI925T.

**CPSR**— Current program status register

**CPU**— Central processing unit: The CPU is the portion of the processor involved in arithmetic, shifting, and Boolean logic operations, as well as the generation of data and program memory addresses. The CPU includes the CALU, the multiplier, and the ARAU.

**CRC**— Cyclic redundancy check

**CS**— Chip-select

**CTRL**— Control

**CVBS**— Composite video broadcast signal

**CWT**— Command wire tracer

## D

**D2D**— Die-to-die

**DAC**— Digital-to-analog converter

**DBB**— Digital baseband

**DBI**— Display date interface

**DCS**— Display command set

**DCO**— Digitally controlled oscillator

**DCT**— Discrete cosine transform: A fast Fourier transform used to manipulate compressed still and moving picture data.

**DDR**— Dual data rate

**DE**— Date enable

**DFF**— Digital flip-flop

**DFT**— Design for test

**DI**— Data identifier

**DISPC**— Display controller

**DLL**— Delay-locked loop

**DMA**— Direct memory access: A mechanism whereby a device other than the host processor contends for and receives mastery of the memory bus so that data transfers can occur independent of the host.

**DMC**— Data memory controller

**DPD, DPDM**— Deep power-down mode

**DPF**— Dynamic power framework

**DPI**— Display parallel interface. Digital implementation of PLL

**DPLL**— Digital phase-locked loop

**DRD**— Dual role device

**DRDY**— Data ready

**DRM**— Digital rights management

**DSI**— Display serial interface

**DSP**— Digital signal processor: A semiconductor that manipulates discrete or discontinuous electrical impulses in a manner that implements a desired algorithm.

**DSS**— Display subsystem

**DT**— Data type

**DVFS**— Dynamic voltage and frequency scaling

## E

**EAV**— End of active video

## Appendix A

www.ti.com

- ECC**— Error checking and correction; also error correction code.
- ED**— Endpoint descriptor
- EDC**— Error detection code
- eFuse**— Electrical fuse: A one-time programmable memory location usually set at the factory
- EHCI**— Enhanced host controller interface
- EMC**— External memory controller
- EMI**— Electromagnetic interference
- EMV**— Initial letters of Europay, MasterCard, and VISA, the three companies which originally cooperated to develop the EMV standard
- EOF**— End of frame
- EOT**— End of transfer
- ES**— Erase status
- ETB**— Embedded trace buffer
- ETSI**— European Telecommunications Standard Institute
- ETM**— Embedded trace macrocell

**F**

- FC**— Frame counter
- FE**— Framing error: An error that occurs when the asynchronous serial port receives a data character that does not have a valid stop-bit.
- FIFO**— First in first out: A queue; a data structure or hardware buffer from which items are removed in the same order they were put in. A FIFO is useful for buffering a stream of data between a sender and receiver which are not synchronized; that is, the sender and receiver are not sending and receiving at exactly the same rate. If the rates differ by too much in one direction for too long, the FIFO becomes either full (blocking the sender) or empty (blocking the receiver).
- FIQ**— Fast interrupt request
- FlatLink™ 3G**— A Texas Instruments display interface protocol
- FS**— Frame synchronization
- FSM**— Finite state-machine: A model of computation consisting of a set of states, a start state, an input alphabet, and a transition function that maps input symbols and current states to a next state.
- FSR**— Fault status register
- FT**— Feed through

**G**

- GDD**— Generic distributed DMA
- GP device**— General-purpose device
- GPIO**— General-purpose input/output: Pins that can accept input signals and/or send output signals but are not linked to specific uses.
- GPMC**— General-purpose memory controller
- GSM**— Global system for mobile communications

**H**

- HC**— Host controller
- HDTV**— High-definition television
- HFP**— Horizontal Front Porch
- HNP**— Host Negotiation Protocol
- HPI**— Host port interface
- HS**— High speed
- HSEC**— Horizontal sync end code
- HSSC**— Horizontal sync start code
- HSYNC**— Horizontal synchronization: A bidirectional horizontal timing signal occurring once per line with a pulse width defined as an integral number of FCLK periods. Synchronization signals can be used to enable retrace of the electron beam of a display screen. Also HS.
- HSW**— Horizontal Synchronization Pulse Width
- HVGA**— Half-size video graphics array. One-half the resolution of VGA
- HW, H/W**— Hardware
- HWA**— Hardware accelerators

**I**

- I<sup>2</sup>C**— Inter-integrated circuit: A multimaster bus where multiple chips can be connected. Each chip can act as a master by initiating a data transfer.
- I<sup>2</sup>S**— Inter-IC sound: A digital audio interface standard.
- IA**— Initiator agent, also Identifier address
- IC**— Integrated circuit
- ICR**— Intersystem communication registers
- IF**— Interface
- INT**— Interrupt: A signal sent by hardware or software to a processor requesting attention. An interrupt tells the processor to suspend its current operation, save the current task status, and perform a particular set of instructions. Interrupts communicate with the operating system and prioritize tasks to be performed.
- INTC**— Interrupt controller
- I/O**— Input/output
- IP**— Intellectual property
- IPC**— Interprocessor communication. Also referred to as *mailbox*.
- IrDA**— Infrared Data Association: Represents the group of device manufacturers that developed a standard for transmitting data via infrared light waves.
- IRQ**— Interrupt request: IRQs are hardware lines over which devices can send interrupt signals to the microprocessor.

## Appendix A

www.ti.com

**ISO**— Isochronous: This refers to processes where data must be delivered within certain time constraints. For example, multimedia streams require an isochronous transport mechanism to ensure that data is delivered as fast as it is displayed and to ensure that the audio is synchronized with the video. Also, *International Standards Organization*.

**ISP**— Image sensing product; also image signal processor

**ISR**— Interrupt service routine: A function or set of functions that are called when an interrupt is encountered.

**ITU**— International Telecommunications Union

**IVA**— Image and video accelerator

**J**

**JPEG**— Joint Photographic Experts Group

**JTAG**— Joint Test Action Group: The JTAG was formed in 1985 to develop economical test methodologies for systems designed around complex integrated circuits and assembled with surface-mount technologies. The group drafted a standard that was subsequently adopted by IEEE as IEEE Standard 1149.1-1990, IEEE Standard Test Access Port, and Boundary-Scan Architecture.

**K**

**Kb**— Kilobits

**KB**— Kilobyte, 1024 B

**Kbps**— Kilobits per second

**L**

**L1**— Level 1 cache/memory

**L2**— Level 2 cache/memory

**L3**— First level of interconnect in platform

**L4**— Second level of interconnect in AM/DM37x platform

**LCD**— Liquid crystal display: A display that uses two sheets of polarizing material with a liquid crystal solution between them.

**LCh**— Logical DMA channel

**LDM**— Load multiple

**LDO**— Low dropout

**LH**— Local host

**LINK**— Link layer device

**LLP**— Low-level protocol

**LP**— Low power, operation mode for PHY

**LPDDR**— Low-power, double-data rate (SDRAM)

**LPM**— Low-power mode

**LPP**— Lines per panel

**LPSDR**— Low-power, single-data rate (SDRAM)

- LRC**— Longitudinal redundancy check
- LRU**— Least recently used
- LS**— Level shifter; also low speed
- LSB**— Least-significant bit
- LUT**— Look-up table
- LVDS**— Low-voltage differential signaling

**M**

- Mailbox**— See *IPC*
- Mb**— Megabit
- Mbps**— Megabits per second
- McBSP**— Multichannel buffered serial port: An enhanced buffered serial port that includes the following standard features: buffered data registers, full duplex communication, and independent clocking and framing for receive and transmit. In addition, the McBSP includes the following enhanced features: internal programmable clock and frame generation, multichannel mode, and general-purpose I/O.
- MCSPI**— Multichannel serial port interface
- MCP**— Multi-chip package
- MCU**— Microcontroller unit (refers to the MPU)
- DDR**— Mobile double-data-rate SDRAM, dedicated to mobile applications
- MIPI®**— Mobile industry processor interface
- MMC**— Multimedia card
- MMC/SD**— Multimedia card/secure data
- MMU**— Memory management unit: The MMU performs virtual-to-physical address translations, performs access permission checks for access to the system memory, and provides the flexibility and protection required for the OS to manage a shared physical memory space between the two processors.
- MPEG**— Motion Pictures Expert Group: A compression scheme for full-motion video.
- MPEG1**— The first MPEG compression scheme specification
- MPEG4**— The most current MPEG compression scheme specification, intended for very narrow bandwidths.
- MPU**— Microprocessor unit
- MS**— Mobile station
- MSB**— Most-significant bit: The highest order bit in a word. The plural form (MSBs) refers to a specified number of high-order bits, beginning with the highest order bit and counting to the right. For example, the 8 MSBs of a 16-bit value are bits 15 through 8.
- MUX**— Multiplex/multiplexer
- Muxed pin**— A pin is muxed when its pin control register field can be reconfigured by software to change the function associated with the pin.

**Appendix A**

www.ti.com

**MuxMode**— A 3-bit field of the pin control register field which enables to change the mode. Mode programming is assumed by software and selects a function on the device external interface.

**N**

**N/A**— Not applicable

**NAK**— Not acknowledged

**NAND**— NAND flash memory that is a high-capacity, low-cost, embedded, permanent data storage solution

**NF**— Noise filter

**NMI**— Nonmaskable interrupt: An interrupt that cannot be masked or disabled.

**NOP**— No operation (DSP/CPU instruction)

**NR**— Noise reduction

**NSC**— National Semiconductor Corporation

**NTSC**— National Television System Committee (television broadcast system)

**O**

**OCM**— On-chip memory

**OCO**— One change only

**OCP**— Open-core protocol

**OCPI**— Open-core protocol interface

**OEM**— Original equipment manufacturer

**OGL**— Open GL (programming API) enable

**OHCI**— Open host controller interface: This is an industry standard USB host controller interface.

**OMAP**— An open software and hardware platform targeted at second- and third-generation cellular phones with multimedia capabilities.

**OneNand**™— A memory chip based on NAND architecture integrating SRAM buffers and NOR logic interface. It combines the advanced data storage function of NAND flash with fast read speed function of NOR flash.

**OTG**— On-the-go (USB 2.0 specification)

**P**

**PBIAS**— PMOS bias transistor to provide the bias voltage to extended drain I/Os

**PCB**— Printed circuit board

**PCLK**— Pixel clock

**PCM**— Pulse code modulation: A technique for digitizing speech by sampling the sound waves and converting each sample into a binary number.

**PDA**— Personal digital assistant

**PDE**— Personal down enable

**PE**— Packet end

**PF**— Packet footer

- PH**— Packet header
- PG**— Protection group
- PGA**— Pin grid array
- PHY**— Physical layer device
- PI**— Packet identifier
- PID**— Protocol identifier: The PID register is used in Windows CE mode only.
- PLD**— Programmable logic device
- PLL**— Phase-locked loop: A closed loop frequency control system whose function is based on the phase-sensitive detection of the phase difference between the input signal and the output signal of the controlled oscillator (CO).
- PMC**— Program memory controller
- POP**— Package-on-package technology
- PMP**— Power management port
- POR**— Power-on reset
- PPI**— Physical layer protocol interface
- PPS**— Protocol and parameter selection
- PRCM**— Power, reset, and clock management
- PRM**— Power and reset manager
- PS**— Packet start
- PSA**— Parallel signature analyzer
- PT**— Packet type
- PVT**— Process, voltage, and temperature (that is, PVT dispersion)
- PWB**— Printed wiring board
- PWM**— Pulse width modulation
- PWR**— Power

**Q**

- QCIF**— Quarter common intermediate format: A video conferencing format that specifies data rates of 30 fps, with each frame containing 144 lines and 176 pixels per line. This is one-fourth the resolution of CIF. QCIF support is required by the ITU H.261 video conferencing standard.
- QVGA**— Quarter video graphics array (one-fourth the resolution of VGA).

**R**

- R**— Read only
- RBL**— Read buffer logic
- RFBI**— Remote frame buffer interface
- RFU**— Reserved for future use
- RGB**— Red, green, blue

## Appendix A

www.ti.com

**RGBA**— Red, green, blue, alpha

**ROM**— Read only memory: A semiconductor storage element containing permanent data that cannot be changed.

**RST**— Reset

**RT**— Real-time

**RVLC**— Reversible variable length coder

**RVLD**— Reversible variable length decoder

**R/W**— Read/write

**RX**— Receive/receiver

**S**

**S3220**— Abbreviation of Sonics3220. It refers to the L4 interconnect.

**SAM**— Shared access mode: The mode that allows both the DSP and the host to access host port interface (HPI) memory. In this mode, asynchronous host accesses are synchronized internally, and, in case of conflict, the host has access priority and the DSP waits one cycle.

**SAR**— Save and restore: Hardware context saving for power saving

**SAV**— Start of active video

**SCCB**— Serial camera control interface: 3-wire and 2-wire serial bus defined and deployed by Omnivision Technologies, Inc.

**SCL**— Serial clock: Programmable serial clock used in the I<sup>2</sup>C interface. Also SCLK.

**SCM**— Scan combiner module; also statistic collection module

**SCP**— Serial configuration port

**SD**— Starting delimiter

**SDA**— Serial data: Serial data bus in the I<sup>2</sup>C interface.

**SDI**— Serial display interface

**SDIO**— Secure digital input/output

**sDMA**— System direct memory access

**SDR**— Single data rate

**SDRC**— SDRAM controller

**SDRAM**— Synchronous dynamic random access memory

**SDTI**— System debug trace interface

**SDTV**— Standard digital television

**SGX**— Abbreviation for graphic accelerator (GFX in ES1.0)

**SIM**— Subscriber identity module

**SIMD**— Single instruction multiple data

**SILVS**— Scalable low-voltage signaling

**SMS**— SDRAM memory scheduler

- SMX**— Abbreviation of SonicsMX. It refers to the L3 interconnect.
- SNR**— Signal-to-noise ratio
- SOF**— Start of frame
- SOT**— Start of transmission
- SRAM**— Static random access memory. Fast memory that does not require refreshing, as DRAM does. It is more expensive than DRAM, though, and is not available in as high a density as DRAM.
- SRG**— Sample rate generator
- SRP**— Session request protocol
- SRRP**— Session RAM restoration pointer
- SS**— Subsystem
- SSR**— Serial synchronous receiver
- SST**— Serial synchronous transmitter
- ST**— Start timer
- STM**— Synchronous transfer mode; also store multiple
- STN**— Super-Twist Nematic: A technique for improving LCD display screens by twisting light rays.
- SVGA**— Super video graphic adapter
- SW**— Software
- SWI**— Software interrupt

**T**

- TC**— Traffic controller. Allows asynchronous operation among the external memory interface, the MPU, and the DSP.
- TCK**— Test clock
- TD**— Transfer descriptor
- TDM**— Time division multiplex/multiplexing: The process by which a single serial bus is shared by multiple devices with each device taking turns to communicate on the bus. The total number of time slots (channels) depends on the number of devices connected. During a time slot, a given device may talk to any combination of devices on the bus.
- TFT**— Thin film transistor. A type of LCD flat panel display screen in which each pixel is controlled by one to four transistors.
- TLB**— Translation lookaside buffer: A cache that contains entries for virtual-to-physical address translation and access permission checking.
- TLL**— Transceiverless link: This is logic that lets the user connect two USB transceiver interfaces together directly without the use of differential transceivers.
- TM**— Target module: A target module cannot generate read/write requests to the chip interconnects, but it responds to these requests. However, it may generate interrupts or a DMA request to the system (typically: peripherals, memory controllers).
- TOC**— Table of contents
- TRM**— Technical reference manual
- TRX**— USB transceiver: The USB analog driver/receiver.

**Appendix A**

www.ti.com

**TTB**— Translation table base: It points to the base of a table in physical memory that contains section and page table descriptors.

**TWL**— Table walking logic

**TX**— Transmit/transmitter

**U**

**UART**— Universal asynchronous receiver/transmitter: Another name for the asynchronous serial port.

**UICC**— Universal integrated circuit card

**ULPM**— Ultra-low power mode

**ULPI**— UTMI+ low pincount interface

**ULPS**— Ultra-low power state

**UMC**— United memory controller

**UNP**— Unpredictable

**USAR**— Universal synchronous/asynchronous receiver

**USART**— Universal synchronous/asynchronous receiver/transmitter

**USB**— Universal serial bus: An external bus standard that supports data transfer rates of 12M bps (12 million bits per second). A single USB port can be used to connect up to 127 peripheral devices.

**UTMI**— USB 2.0 transceiver macrocell interface

**UTMI+**— UTMI extension supporting USB host and on-the-go

**V**

**VA**— Volt-amps: A form of power management. A VA rating is the volts rating multiplied by the amps (current) rating, used to indicate the output capacity of an uninterruptible power supply (UPS) or other power source.

**VC**— Virtual channel

**VENC**— Video encoder

**VESA**— Video Electronics Standards Association

**VFP**— Vertical front porch

**VGA**— Video graphics array: An industry standard for video cards.

**VLC**— Variable length decoder

**VLD**— Variable length coder

**VMODE**— Bi-level voltage control interface

**VPBE**— Video processing back end

**VSEC**— Vertical synchronization end code

**VSSC**— Vertical synchronization start code

**VSYNC, VS**— Vertical synchronization: A bidirectional vertical timing signal occurring once per frame with a pulse-width defined as an integral number of lines (half-lines for interlaced mode).

**W**

**WBL**— Write buffer logic

**WC**— Word count

**WD**— Watchdog: A timer that requires the user program or OS periodically write to the count register before the counter underflows.

**WDT**— Watchdog timer

**WLAN**— Wireless local area network

**WMV**— Windows media video

**WMA**— Windows media audio

**Word16**— 16-bit word

**Word32**— 32-bit word

**WP**— Write protect

**WSS**— Wide-screen signaling

**WWT**— Work waiting time

**X**

**XGA, XVGA**— Extended graphics array

**XIP**— Execution in place

**Y**

**YUV**— Luminance-Bandwidth-Chrominance

## IMPORTANT NOTICE

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed.

TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

Reproduction of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.

Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products and any use of TI products in such safety-critical applications, notwithstanding any applications-related information or support that may be provided by TI. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in such safety-critical applications.

TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military specifications. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, TI will not be responsible for any failure to meet such requirements.

Following are URLs where you can obtain information on other Texas Instruments products and application solutions:

### Products

|                        |                                                                                      |
|------------------------|--------------------------------------------------------------------------------------|
| Audio                  | <a href="http://www.ti.com/audio">www.ti.com/audio</a>                               |
| Amplifiers             | <a href="http://amplifier.ti.com">amplifier.ti.com</a>                               |
| Data Converters        | <a href="http://dataconverter.ti.com">dataconverter.ti.com</a>                       |
| DLP® Products          | <a href="http://www.dlp.com">www.dlp.com</a>                                         |
| DSP                    | <a href="http://dsp.ti.com">dsp.ti.com</a>                                           |
| Clocks and Timers      | <a href="http://www.ti.com/clocks">www.ti.com/clocks</a>                             |
| Interface              | <a href="http://interface.ti.com">interface.ti.com</a>                               |
| Logic                  | <a href="http://logic.ti.com">logic.ti.com</a>                                       |
| Power Mgmt             | <a href="http://power.ti.com">power.ti.com</a>                                       |
| Microcontrollers       | <a href="http://microcontroller.ti.com">microcontroller.ti.com</a>                   |
| RFID                   | <a href="http://www.ti-rfid.com">www.ti-rfid.com</a>                                 |
| OMAP Mobile Processors | <a href="http://www.ti.com/omap">www.ti.com/omap</a>                                 |
| Wireless Connectivity  | <a href="http://www.ti.com/wirelessconnectivity">www.ti.com/wirelessconnectivity</a> |

### Applications

|                               |                                                                                          |
|-------------------------------|------------------------------------------------------------------------------------------|
| Automotive and Transportation | <a href="http://www.ti.com/automotive">www.ti.com/automotive</a>                         |
| Communications and Telecom    | <a href="http://www.ti.com/communications">www.ti.com/communications</a>                 |
| Computers and Peripherals     | <a href="http://www.ti.com/computers">www.ti.com/computers</a>                           |
| Consumer Electronics          | <a href="http://www.ti.com/consumer-apps">www.ti.com/consumer-apps</a>                   |
| Energy and Lighting           | <a href="http://www.ti.com/energy">www.ti.com/energy</a>                                 |
| Industrial                    | <a href="http://www.ti.com/industrial">www.ti.com/industrial</a>                         |
| Medical                       | <a href="http://www.ti.com/medical">www.ti.com/medical</a>                               |
| Security                      | <a href="http://www.ti.com/security">www.ti.com/security</a>                             |
| Space, Avionics and Defense   | <a href="http://www.ti.com/space-avionics-defense">www.ti.com/space-avionics-defense</a> |
| Video and Imaging             | <a href="http://www.ti.com/video">www.ti.com/video</a>                                   |

[TI E2E Community Home Page](#)

[e2e.ti.com](#)

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265  
Copyright © 2012, Texas Instruments Incorporated